/*
 * Moonlit Homecoming theme
 * A quiet, restrained visual system for the pet memorial experience.
 */

:root {
  --moon-bg: #101827;
  --moon-bg-deep: #0b121e;
  --moon-surface: #151f2e;
  --moon-surface-soft: #1a2534;
  --moon-surface-raised: #202c3b;
  --moon-line: rgba(156, 184, 197, .24);
  --moon-line-strong: rgba(212, 170, 112, .48);
  --moon-text: #e7e3dc;
  --moon-text-soft: #b9c0c1;
  --moon-muted: #849298;
  --moon-blue: #9cb8c5;
  --moon-gold: #d4aa70;
  --moon-lilac: #9d8faf;
  --moon-green: #8eab91;
  --moon-danger: #c58c87;
  --moon-display: "Noto Serif SC", "Songti SC", serif;
  --moon-body: "Noto Sans SC", "Microsoft YaHei", sans-serif;
  --moon-pixel: "Ark Pixel SC", "Noto Sans SC", sans-serif;

  --bg: var(--moon-bg-deep);
  --window: var(--moon-bg);
  --panel: var(--moon-surface);
  --panel-2: var(--moon-surface-soft);
  --cell: #111a28;
  --line: var(--moon-line);
  --cyan: var(--moon-blue);
  --pink: var(--moon-lilac);
  --green: var(--moon-green);
  --yellow: var(--moon-gold);
  --orange: var(--moon-gold);
  --purple: var(--moon-lilac);
  --text: var(--moon-text);
  --muted: var(--moon-muted);
  --pixel: var(--moon-pixel);
  --mono: var(--moon-pixel);
  --console-bg: var(--moon-bg-deep);
  --console-panel: rgba(17, 26, 40, .96);
  --console-panel-hi: rgba(26, 37, 52, .98);
  --console-line: var(--moon-line);
  --console-line-hi: var(--moon-blue);
  --console-purple: var(--moon-lilac);
  --console-pink: var(--moon-lilac);
  --console-yellow: var(--moon-gold);
  --console-green: var(--moon-green);
  --console-cut: 8px;
  --console-grid: transparent;
}

*, *::before, *::after { box-sizing: border-box; }

html {
  color-scheme: dark;
  background: var(--moon-bg-deep);
  scroll-behavior: smooth;
}

body {
  min-width: 320px;
  overflow-x: hidden;
  background: var(--moon-bg-deep) !important;
  color: var(--moon-text);
  font-family: var(--moon-body);
  font-weight: 300;
  letter-spacing: .02em;
  -webkit-font-smoothing: antialiased;
}

button, input, textarea, select { font: inherit; }
button { letter-spacing: .04em; }

::selection {
  background: rgba(212, 170, 112, .28);
  color: #fff;
}

/* Real image icons replace the former text-glyph and CSS-drawn icon system. */
.brand-mark {
  width: 38px !important;
  height: 38px !important;
  border: 1px solid var(--moon-line-strong) !important;
  border-radius: 6px !important;
  background: url("cyberpet_cemetery_assets_v1/ui_memorial_16x16.png") center / 18px 18px no-repeat !important;
  box-shadow: none !important;
  filter: sepia(1) saturate(.7) brightness(1.2);
}

.brand-mark::before,
.brand-mark::after,
.brand-paw,
.nav-btn > span,
.cta-btn > span:first-child,
.create-cta-plus,
.frame-emblem,
.search-box > span,
.empty-state > span,
.detail-copy .life-dates > span,
.account-icon { display: none !important; }

.nav-btn::before {
  content: "";
  width: 16px;
  height: 16px;
  flex: 0 0 16px;
  background: center / contain no-repeat;
  image-rendering: pixelated;
  opacity: .72;
  filter: sepia(1) saturate(.55) brightness(1.15);
}

.nav-btn[data-route="map"]::before { background-image: url("cyberpet_cemetery_assets_v1/ui_map_16x16.png"); }
.nav-btn[data-route="archive"]::before { background-image: url("cyberpet_cemetery_assets_v1/ui_search_16x16.png"); }
.nav-btn[data-route="account"]::before { background-image: url("cyberpet_cemetery_assets_v1/ui_account_16x16.png"); }

.modal-close,
.drawer-close {
  color: transparent !important;
  background: url("cyberpet_cemetery_assets_v1/ui_close_16x16.png") center / 16px 16px no-repeat !important;
}

/* Header */
.topbar {
  z-index: 80;
  height: 78px !important;
  min-height: 78px !important;
  padding: 0 clamp(20px, 3.2vw, 52px) !important;
  border: 0 !important;
  border-bottom: 1px solid var(--moon-line) !important;
  background: rgba(11, 18, 30, .94) !important;
  box-shadow: none !important;
}

.topbar::before,
.topbar::after { display: none !important; }

.topbar .brand::before,
.topbar .brand::after { display: none !important; }

.brand {
  min-width: 210px;
  padding: 0 !important;
  gap: 12px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: var(--moon-text) !important;
  box-shadow: none !important;
  clip-path: none !important;
}

.brand strong {
  color: #ead5b7 !important;
  font-family: var(--moon-display) !important;
  font-size: 17px !important;
  font-weight: 500 !important;
  letter-spacing: .16em !important;
  text-shadow: none !important;
}

.brand small {
  margin-top: 2px !important;
  color: var(--moon-muted) !important;
  font-family: var(--moon-body) !important;
  font-size: 10px !important;
  letter-spacing: .18em !important;
}

.nav {
  gap: 3px !important;
  margin-left: auto !important;
}

.nav-btn {
  min-height: 42px !important;
  padding: 0 14px !important;
  gap: 8px !important;
  border: 0 !important;
  border-radius: 6px !important;
  background: transparent !important;
  color: var(--moon-text-soft) !important;
  box-shadow: none !important;
  clip-path: none !important;
}

.nav-btn b {
  font-family: var(--moon-body) !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  letter-spacing: .08em !important;
}

.nav-btn:hover,
.nav-btn.active {
  background: rgba(156, 184, 197, .08) !important;
  color: var(--moon-text) !important;
  box-shadow: inset 0 -1px var(--moon-gold) !important;
}

.nav-btn.active::before { opacity: 1; }

.header-status { display: none !important; }

.cta-btn,
.create-cta-compact,
.create-cta-card,
.action-btn,
.gate-create-btn,
.gate-enter-btn,
.detail-terminal-button,
.ritual-action,
.ritual-message-form button,
.species-tabs button,
.text-btn,
.icon-btn {
  border: 1px solid var(--moon-line) !important;
  border-radius: 6px !important;
  clip-path: none !important;
  background: transparent !important;
  color: var(--moon-text-soft) !important;
  box-shadow: none !important;
  text-shadow: none !important;
  transition: color .2s ease, border-color .2s ease, background-color .2s ease, transform .2s ease !important;
}

.cta-btn,
.create-cta-compact,
.gate-create-btn,
.action-btn.primary,
.detail-terminal-button-share {
  border-color: rgba(212, 170, 112, .68) !important;
  background: #a77f50 !important;
  color: #fff9ed !important;
}

.topbar > .create-cta-compact {
  width: auto !important;
  min-width: 154px !important;
  flex: 0 0 auto !important;
  min-height: 42px !important;
  margin-left: 16px;
  padding: 0 20px !important;
  font-family: var(--moon-body) !important;
  font-size: 13px !important;
  overflow: visible !important;
  white-space: nowrap !important;
}

.cta-btn::before,
.create-cta-compact::before,
.create-cta-card::before,
.action-btn::before { display: none !important; }

.cta-btn:hover,
.create-cta-compact:hover,
.create-cta-card:hover,
.action-btn:hover,
.gate-create-btn:hover,
.gate-enter-btn:hover,
.detail-terminal-button:hover,
.ritual-action:hover,
.ritual-message-form button:hover,
.species-tabs button:hover,
.text-btn:hover,
.icon-btn:hover {
  transform: translateY(-1px) !important;
  border-color: var(--moon-gold) !important;
  background: rgba(212, 170, 112, .12) !important;
  color: #fff !important;
  filter: none !important;
}

.cta-btn:hover,
.create-cta-compact:hover,
.gate-create-btn:hover,
.action-btn.primary:hover,
.detail-terminal-button-share:hover {
  background: #bd9460 !important;
}

button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
[tabindex="0"]:focus-visible {
  outline: 2px solid var(--moon-gold) !important;
  outline-offset: 3px;
}

/* Entrance: left editorial promise, right moonlit garden. */
.app.gate-active .topbar {
  position: fixed !important;
  inset: 0 0 auto;
  display: flex !important;
  background: rgba(8, 14, 24, .88) !important;
}

.app.gate-active .config-banner { display: none !important; }

.gate-view {
  min-height: 132vh !important;
  background: var(--moon-bg-deep) !important;
}

.gate-bg {
  inset: 0 !important;
  background: url("assets/moonlit-garden-hero.png") center / cover no-repeat !important;
  filter: brightness(.82) saturate(.86) !important;
  image-rendering: auto;
}

.gate-shade {
  background: rgba(7, 13, 22, .08) !important;
  box-shadow: inset 48vw 0 90px rgba(7, 13, 22, .28) !important;
  opacity: 1 !important;
}

.gate-view::after {
  background: rgba(8, 14, 24, .06) !important;
}

.gate-content {
  place-items: start !important;
  align-content: start !important;
  width: min(1440px, 100%) !important;
  min-height: 100vh !important;
  margin: 0 auto !important;
  padding: clamp(170px, 20vh, 220px) clamp(32px, 5.5vw, 84px) 40px !important;
  text-align: left !important;
}

.gate-kicker {
  margin: 0 0 20px !important;
  color: var(--moon-gold) !important;
  font-family: var(--moon-pixel) !important;
  font-size: 12px !important;
  letter-spacing: .18em !important;
  text-shadow: none !important;
}

.gate-content h1 {
  max-width: 780px;
  color: #eadfce !important;
  font-family: var(--moon-display) !important;
  font-size: clamp(38px, 4vw, 60px) !important;
  font-weight: 500 !important;
  line-height: 1.42 !important;
  letter-spacing: .04em !important;
  text-shadow: 0 3px 24px rgba(0, 0, 0, .42) !important;
}

.gate-content .gate-lead {
  max-width: 520px !important;
  margin: 22px 0 30px !important;
  color: var(--moon-text-soft) !important;
  font-family: var(--moon-body) !important;
  font-size: clamp(15px, 1.35vw, 19px) !important;
  font-weight: 300;
  line-height: 1.8 !important;
  text-shadow: none !important;
}

.gate-actions {
  display: flex;
  gap: 12px;
  width: min(520px, 100%);
}

.gate-create-btn,
.gate-enter-btn {
  min-width: 0 !important;
  min-height: 54px;
  padding: 0 28px !important;
  font-family: var(--moon-body) !important;
  font-size: 15px !important;
  letter-spacing: .08em !important;
}

.gate-create-btn { flex: 1.1; }
.gate-enter-btn { flex: .9; background: rgba(11, 18, 30, .7) !important; }

.gate-assurance {
  position: relative;
  max-width: none !important;
  margin: 20px 0 0 24px !important;
  color: var(--moon-muted) !important;
  font-family: var(--moon-body) !important;
  font-size: 12px !important;
  line-height: 1.5 !important;
  text-shadow: none !important;
}

.gate-assurance::before {
  content: "";
  position: absolute;
  top: 5px;
  left: -20px;
  width: 8px;
  height: 8px;
  background: url("cyberpet_cemetery_assets_v1/ui_memorial_16x16.png") center / contain no-repeat;
  image-rendering: pixelated;
}

.gate-memory-preview {
  display: grid;
  grid-template-columns: 86px 1fr;
  gap: 18px;
  width: min(520px, 100%);
  margin-top: 28px;
  padding: 14px;
  border: 1px solid var(--moon-line);
  border-radius: 8px;
  background: rgba(15, 24, 38, .78);
}

.gate-memory-preview img {
  width: 86px;
  height: 86px;
  object-fit: cover;
  border: 1px solid rgba(212, 170, 112, .28);
  border-radius: 4px;
  image-rendering: pixelated;
  filter: saturate(.78) brightness(.9);
}

.gate-memory-preview span,
.eyebrow,
.panel-kicker,
.panel-heading,
.field-label,
.coordinate {
  color: var(--moon-gold) !important;
  font-family: var(--moon-pixel) !important;
  font-size: 10px !important;
  font-weight: 400 !important;
  letter-spacing: .12em !important;
  text-shadow: none !important;
}

.gate-memory-preview h2 {
  margin: 5px 0 0;
  color: var(--moon-text);
  font-family: var(--moon-display);
  font-size: 20px;
  font-weight: 500;
}

.gate-memory-preview p,
.gate-memory-preview blockquote {
  margin: 3px 0 0 !important;
  color: var(--moon-muted) !important;
  font-family: var(--moon-body) !important;
  font-size: 12px !important;
  line-height: 1.55 !important;
  text-shadow: none !important;
}

.gate-memory-preview blockquote { color: var(--moon-text-soft) !important; }

.gate-transition-text {
  color: var(--moon-text) !important;
  font-family: var(--moon-display) !important;
  font-size: clamp(22px, 2.6vw, 38px) !important;
  font-weight: 400;
  text-shadow: 0 3px 22px rgba(0, 0, 0, .7) !important;
}

.gate-view.entering .gate-bg { filter: brightness(.54) saturate(.65) !important; }

/* Shared app surfaces */
.app:not(.gate-active) {
  min-height: 100vh;
  background: var(--moon-bg-deep) !important;
}

.config-banner {
  min-height: 34px;
  padding: 8px 20px !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(212, 170, 112, .18) !important;
  background: #171e28 !important;
  color: var(--moon-muted) !important;
  font-family: var(--moon-body) !important;
  font-size: 12px !important;
}

.main-shell { background: var(--moon-bg-deep); }

.map-view {
  gap: 0 !important;
  padding: 0 !important;
  background: var(--moon-bg-deep);
}

.map-stage {
  border: 0 !important;
  border-right: 1px solid var(--moon-line) !important;
  background: #0d1622 !important;
  box-shadow: none !important;
}

#mapCanvas {
  filter: saturate(.54) brightness(.78) contrast(.95) sepia(.08);
}

.map-stage::before,
.map-stage::after,
.scanlines { display: none !important; }

.map-status,
.map-hint,
.map-controls,
.plot-select-banner,
.plot-hover-card {
  border: 1px solid var(--moon-line) !important;
  border-radius: 6px !important;
  background: rgba(13, 22, 34, .9) !important;
  color: var(--moon-text-soft) !important;
  box-shadow: none !important;
  clip-path: none !important;
  font-family: var(--moon-body) !important;
}

.map-status i {
  background: var(--moon-gold) !important;
  box-shadow: 0 0 10px rgba(212, 170, 112, .45) !important;
}

.map-controls button {
  border-color: var(--moon-line) !important;
  background: transparent !important;
  color: var(--moon-text-soft) !important;
}

.map-controls span { color: var(--moon-gold) !important; }

.sidebar {
  width: clamp(310px, 27vw, 390px) !important;
  padding: 20px !important;
  gap: 14px !important;
  border: 0 !important;
  background: #111a28 !important;
  box-shadow: none !important;
}

.panel,
.account-guest,
.account-panel {
  border: 1px solid var(--moon-line) !important;
  border-radius: 8px !important;
  background: var(--moon-surface) !important;
  box-shadow: none !important;
  clip-path: none !important;
}

.panel::before,
.panel::after,
.account-guest::before,
.account-panel::before,
.node-corner { display: none !important; }

.selected-panel { border-color: rgba(212, 170, 112, .34) !important; }

.selected-hero h2,
.memorial-card h3,
.account-item h3 {
  color: var(--moon-text) !important;
  font-family: var(--moon-display) !important;
  font-weight: 500 !important;
  text-shadow: none !important;
}

.sprite-box {
  border: 1px solid var(--moon-line) !important;
  border-radius: 6px !important;
  background: #101a28 !important;
  box-shadow: none !important;
}

.pet-meta div,
.cemetery-stats div { border-color: rgba(156, 184, 197, .1) !important; }
.pet-meta dd { color: var(--moon-text-soft) !important; }

blockquote {
  border-left: 1px solid rgba(212, 170, 112, .5) !important;
  background: transparent !important;
  color: var(--moon-text-soft) !important;
  font-family: var(--moon-display) !important;
  font-weight: 400;
  box-shadow: none !important;
}

.signal {
  border: 1px solid transparent !important;
  border-radius: 5px !important;
  background: #101a28 !important;
  box-shadow: none !important;
}

.signal:hover,
.signal.selected {
  border-color: var(--moon-line-strong) !important;
  background: #1a2635 !important;
  box-shadow: none !important;
}

.species-tabs button.active {
  border-color: rgba(212, 170, 112, .56) !important;
  background: rgba(212, 170, 112, .12) !important;
  color: var(--moon-gold) !important;
}

.create-cta-card {
  grid-template-columns: 48px 1fr !important;
  min-height: 82px !important;
  padding: 12px !important;
  background: #1b2531 !important;
}

.create-cta-icon {
  width: 44px !important;
  height: 44px !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.create-cta-copy strong {
  color: var(--moon-text) !important;
  font-family: var(--moon-display) !important;
  font-size: 15px !important;
  text-shadow: none !important;
}

.create-cta-copy small { color: var(--moon-muted) !important; }

/* Archive and account */
.content-view,
.detail-view {
  background: var(--moon-bg-deep) !important;
  color: var(--moon-text);
}

.content-view {
  padding: clamp(32px, 5vw, 72px) clamp(24px, 6vw, 92px) !important;
}

.archive-console,
.account-console {
  padding: clamp(32px, 5vw, 72px) clamp(24px, 6vw, 92px) !important;
  background: var(--moon-bg-deep) !important;
}

.archive-console::before,
.archive-console::after,
.account-console::before,
.account-console::after,
.archive-console .page-head::after,
.account-console .page-head::after,
.search-row::before,
.memorial-card::before { display: none !important; }

.archive-console .page-head,
.account-console .page-head {
  margin: 0 0 24px !important;
  padding: 0 0 24px !important;
  border: 0 !important;
  border-bottom: 1px solid var(--moon-line) !important;
  background: transparent !important;
  box-shadow: none !important;
}

.archive-console .search-row,
.account-console .search-row {
  margin: 0 0 20px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  clip-path: none !important;
}

.archive-console .memorial-grid,
.account-console #accountContent {
  margin: 0 !important;
}

.page-head {
  align-items: center !important;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--moon-line);
}

.page-head::before,
.page-head::after { display: none !important; }

.page-head h1 {
  margin: 10px 0 8px !important;
  color: var(--moon-text) !important;
  font-family: var(--moon-display) !important;
  font-size: clamp(28px, 3.2vw, 44px) !important;
  font-weight: 500 !important;
  line-height: 1.35 !important;
  letter-spacing: .05em !important;
  text-shadow: none !important;
}

.page-head p { color: var(--moon-muted) !important; }

.search-row { gap: 12px !important; }

.search-box,
.field input,
.field textarea,
.pixel-select,
.ritual-message-form input {
  border: 1px solid var(--moon-line) !important;
  border-radius: 6px !important;
  background: #111a28 !important;
  color: var(--moon-text) !important;
  box-shadow: none !important;
}

.search-box {
  min-height: 48px;
  padding-left: 42px;
  background: #111a28 url("cyberpet_cemetery_assets_v1/ui_search_16x16.png") 16px center / 16px 16px no-repeat !important;
}

.search-box::before,
.search-box::after { display: none !important; }

.search-box input { padding-left: 0 !important; }

.search-box:focus-within,
.field input:focus,
.field textarea:focus,
.pixel-select:focus,
.ritual-message-form input:focus {
  border-color: rgba(212, 170, 112, .7) !important;
  box-shadow: 0 0 0 3px rgba(212, 170, 112, .08) !important;
}

.memorial-grid {
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)) !important;
  gap: 18px !important;
}

.memorial-card,
.account-item {
  border: 1px solid var(--moon-line) !important;
  border-radius: 8px !important;
  background: var(--moon-surface) !important;
  box-shadow: none !important;
  clip-path: none !important;
}

.memorial-card {
  min-height: 230px !important;
  padding: 18px !important;
}

.memorial-card .card-top { border-color: rgba(156, 184, 197, .12) !important; }
.memorial-card .sprite-box { background: #101a28 !important; box-shadow: none !important; }
.sprite-box canvas { filter: saturate(.58) sepia(.12) brightness(.9); }
.memorial-card blockquote {
  padding: 14px 4px 14px 16px !important;
  border: 0 !important;
  border-left: 1px solid rgba(212, 170, 112, .5) !important;
  background: transparent !important;
}

.memorial-card:hover,
.account-item:hover {
  transform: translateY(-2px) !important;
  border-color: rgba(212, 170, 112, .52) !important;
  background: var(--moon-surface-soft) !important;
  box-shadow: 0 12px 28px rgba(2, 7, 14, .24) !important;
}

.card-footer { border-top: 1px solid rgba(156, 184, 197, .12); padding-top: 12px; }
.card-footer span:last-child { color: var(--moon-gold) !important; }

.account-guest,
.account-panel { padding: clamp(24px, 4vw, 48px) !important; }

.account-guest {
  max-width: 720px !important;
  margin: 28px auto !important;
}

.account-guest::after { display: none !important; }

.account-header { border-color: var(--moon-line) !important; }
.account-header h2 { color: var(--moon-text) !important; font-family: var(--moon-display); }
.danger { color: var(--moon-danger) !important; border-color: rgba(197, 140, 135, .4) !important; }

/* Memorial detail: pet first, then name, time, words and gentle rituals. */
.detail-bg-canvas { opacity: .2 !important; }

.detail-view.active {
  overflow: auto !important;
  padding: 74px clamp(20px, 4vw, 64px) 48px !important;
}

.detail-view .back-btn {
  position: static !important;
  align-self: flex-start !important;
  margin: 0 0 18px !important;
  min-height: 38px !important;
  padding: 0 14px !important;
  border: 1px solid var(--moon-line) !important;
  border-radius: 5px !important;
  background: rgba(17, 26, 40, .82) !important;
  color: var(--moon-text-soft) !important;
  font-family: var(--moon-body) !important;
  font-size: 13px !important;
  box-shadow: none !important;
  clip-path: none !important;
}

.detail-card {
  width: min(1100px, 100%) !important;
  border: 1px solid var(--moon-line) !important;
  border-radius: 10px !important;
  background: var(--moon-surface) !important;
  box-shadow: 0 24px 70px rgba(0, 0, 0, .2) !important;
  clip-path: none !important;
  transform: none !important;
  overflow: visible !important;
}

.detail-card::before,
.detail-card::after,
.detail-terminal-frame::before,
.detail-terminal-frame::after,
.detail-copy::before,
.detail-copy::after,
.detail-media::before,
.detail-media::after,
.detail-photo-chamber::after,
.detail-hologram i,
.detail-node-line i,
.detail-divider { display: none !important; }

.detail-terminal-frame {
  position: relative !important;
  display: grid !important;
  grid-template-columns: minmax(380px, 1.06fr) minmax(360px, .94fr) !important;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: auto !important;
  min-height: 560px !important;
  overflow: hidden !important;
  border: 0 !important;
  background: transparent !important;
  filter: none !important;
}

.detail-media {
  position: relative !important;
  inset: auto !important;
  top: auto !important;
  right: auto !important;
  bottom: auto !important;
  left: auto !important;
  width: auto !important;
  height: auto !important;
  min-height: 560px !important;
  padding: 18px !important;
  overflow: hidden !important;
  border: 0 !important;
  border-right: 1px solid var(--moon-line) !important;
  background: #0f1826 !important;
}

.detail-photo-chamber {
  position: relative !important;
  inset: auto !important;
  width: 100% !important;
  height: 100% !important;
  min-height: 524px !important;
  border: 0 !important;
  border-radius: 6px;
  clip-path: none !important;
}
.detail-photo-chamber img { filter: saturate(.78) contrast(.96) !important; }

.detail-hologram {
  position: absolute !important;
  top: auto !important;
  right: 30px !important;
  bottom: 30px !important;
  left: auto !important;
  width: 112px !important;
  height: 112px !important;
  min-width: 0 !important;
  min-height: 0 !important;
  filter: none !important;
}

.detail-hologram .sprite-box,
.detail-hologram .sprite-box.xlarge {
  position: static !important;
  width: 112px !important;
  height: 112px !important;
  margin: 0 !important;
  filter: saturate(.58) sepia(.12) brightness(.9) !important;
  animation: none !important;
}

.detail-copy {
  position: relative !important;
  inset: auto !important;
  top: auto !important;
  right: auto !important;
  bottom: auto !important;
  left: auto !important;
  width: auto !important;
  height: auto !important;
  justify-content: center !important;
  display: flex !important;
  padding: clamp(36px, 5vw, 68px) !important;
  background: transparent !important;
}

.detail-copy > *,
.detail-node-line,
.detail-placement,
.detail-copy h1,
.detail-copy .life-dates,
.detail-copy blockquote {
  position: static !important;
  width: auto !important;
  height: auto !important;
  min-height: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.detail-copy blockquote span { color: var(--moon-gold) !important; }

.detail-node-line { display: block !important; padding: 0 !important; }

.detail-placement { color: var(--moon-muted) !important; }

.detail-copy h1 {
  margin: 28px 0 10px !important;
  color: var(--moon-text) !important;
  font-family: var(--moon-display) !important;
  font-size: clamp(42px, 5vw, 68px) !important;
  font-weight: 500 !important;
  letter-spacing: .08em !important;
  text-shadow: none !important;
}

.detail-copy .life-dates { color: var(--moon-text-soft) !important; font-size: 15px !important; }

.detail-copy blockquote {
  margin: 38px 0 0 !important;
  padding: 4px 0 4px 22px !important;
  font-size: clamp(20px, 2.2vw, 28px) !important;
  line-height: 1.8 !important;
}

.detail-terminal-actions,
.detail-ritual-panel {
  border-top: 1px solid var(--moon-line) !important;
  background: #121c2a !important;
}

.detail-terminal-actions {
  position: relative !important;
  inset: auto !important;
  top: auto !important;
  right: auto !important;
  bottom: auto !important;
  left: auto !important;
  width: auto !important;
  display: flex !important;
  justify-content: flex-end !important;
  gap: 10px !important;
  padding: 18px 22px !important;
  transform: none !important;
  pointer-events: auto !important;
}

.detail-terminal-button {
  position: relative !important;
  width: auto !important;
  min-width: 142px !important;
  height: 44px !important;
  min-height: 44px !important;
  aspect-ratio: auto !important;
  padding: 0 20px !important;
  background-image: none !important;
}

.detail-terminal-button span {
  position: static !important;
  inset: auto !important;
  transform: none !important;
}

.detail-ritual-panel {
  position: relative !important;
  inset: auto !important;
  top: auto !important;
  right: auto !important;
  bottom: auto !important;
  left: auto !important;
  width: auto !important;
  max-height: none !important;
  margin: 0 !important;
  padding: 22px !important;
  overflow: visible !important;
  border-right: 0 !important;
  border-bottom: 0 !important;
  border-left: 0 !important;
  border-radius: 0 0 10px 10px !important;
  box-shadow: none !important;
  clip-path: none !important;
  transform: none !important;
}
.ritual-action-row { gap: 10px !important; }
.ritual-action { min-height: 48px !important; }
.ritual-action b { color: var(--moon-gold) !important; }
.ritual-message-list { color: var(--moon-text-soft) !important; }

/* Forms, modals and completion ritual */
.modal { background: rgba(5, 10, 17, .78) !important; backdrop-filter: blur(8px); }

.modal-card {
  border: 1px solid var(--moon-line) !important;
  border-radius: 10px !important;
  background: #141f2e !important;
  box-shadow: 0 30px 90px rgba(0, 0, 0, .38) !important;
  clip-path: none !important;
}

.modal-card::before,
.modal-card::after,
.modal-head::before,
.modal-head::after,
.completion-glow { display: none !important; }

.modal-head {
  border-bottom: 1px solid var(--moon-line) !important;
  background: transparent !important;
}

.modal-head small { color: var(--moon-muted) !important; font-family: var(--moon-body) !important; }

.modal-head h2,
.completion-copy h2 {
  color: var(--moon-text) !important;
  font-family: var(--moon-display) !important;
  font-weight: 500 !important;
  text-shadow: none !important;
}

.modal-close {
  width: 36px !important;
  height: 36px !important;
  border: 1px solid var(--moon-line) !important;
  border-radius: 5px !important;
  box-shadow: none !important;
}

.auth-tabs { border-color: var(--moon-line) !important; }
.auth-tabs button { color: var(--moon-muted) !important; background: transparent !important; }
.auth-tabs button.active { color: var(--moon-gold) !important; border-color: var(--moon-gold) !important; }

.field > span,
.field legend { color: var(--moon-text-soft) !important; font-family: var(--moon-body) !important; }

.selected-plot-field,
.photo-drop,
.sprite-preview,
.tombstone-option {
  border: 1px solid var(--moon-line) !important;
  border-radius: 6px !important;
  background: #111a28 !important;
  box-shadow: none !important;
  clip-path: none !important;
}

.photo-drop:hover,
.tombstone-option:hover,
.tombstone-option.selected { border-color: rgba(212, 170, 112, .62) !important; box-shadow: none !important; }

.color-option { border: 2px solid #141f2e !important; box-shadow: 0 0 0 1px var(--moon-line) !important; }
.color-option.selected { box-shadow: 0 0 0 2px var(--moon-text) !important; }

.completion-card { text-align: left !important; }
.completion-copy { padding: clamp(28px, 5vw, 56px) !important; }
.completion-copy small { color: var(--moon-gold) !important; }
.completion-sub { color: var(--moon-muted) !important; }
.completion-meta { border-color: var(--moon-line) !important; }

.toast {
  border: 1px solid rgba(212, 170, 112, .45) !important;
  border-radius: 6px !important;
  background: #1a2534 !important;
  color: var(--moon-text) !important;
  box-shadow: 0 16px 40px rgba(0, 0, 0, .3) !important;
  clip-path: none !important;
}

.toast.error { border-color: rgba(197, 140, 135, .62) !important; color: #efd5d2 !important; }

/* Responsive */
@media (max-width: 1100px) {
  .topbar { padding: 0 22px !important; }
  .brand { min-width: 180px; }
  .nav-btn { padding: 0 10px !important; }
  .sidebar { width: 330px !important; }
  .gate-shade { box-shadow: inset 64vw 0 110px rgba(7, 13, 22, .94) !important; }
  .detail-terminal-frame { grid-template-columns: 1fr 1fr !important; }
}

@media (max-width: 900px) {
  .topbar {
    height: 66px !important;
    min-height: 66px !important;
    padding: 0 14px !important;
  }

  .brand { min-width: 0; }
  .brand-copy small { display: none !important; }
  .brand strong { font-size: 14px !important; }
  .nav { gap: 0 !important; }
  .nav-btn { min-width: 42px !important; padding: 0 10px !important; }
  .nav-btn b { display: none; }
  .topbar > .create-cta-compact { width: 46px !important; min-width: 46px !important; padding: 0 !important; }
  .topbar > .create-cta-compact span:last-child { display: none !important; }
  .topbar > .create-cta-compact::after {
    content: "";
    width: 18px;
    height: 18px;
    margin: auto;
    background: url("cyberpet_cemetery_assets_v1/ui_memorial_16x16.png") center / contain no-repeat;
    image-rendering: pixelated;
  }

  .gate-view { min-height: 118vh !important; }
  .gate-bg { background-position: 58% center !important; filter: brightness(.52) saturate(.68) !important; }
  .gate-shade { background: rgba(7, 13, 22, .5) !important; box-shadow: none !important; }
  .gate-content { padding: 100px 24px 36px !important; align-content: end !important; }
  .gate-content h1 { max-width: 600px; font-size: clamp(34px, 8vw, 54px) !important; }
  .gate-content .gate-lead { margin: 16px 0 24px !important; }
  .gate-memory-preview { display: none; }
  .gate-actions { max-width: 520px; }

  .map-view.active { display: block !important; }
  .map-view:not(.active) { display: none !important; }
  .map-stage {
    width: 100% !important;
    height: calc(100vh - 66px) !important;
    min-height: 620px !important;
    border-right: 0 !important;
  }
  .sidebar {
    width: min(380px, 92vw) !important;
    border-left: 1px solid var(--moon-line) !important;
    box-shadow: -20px 0 50px rgba(0, 0, 0, .28) !important;
  }

  .content-view { padding: 32px 20px !important; }
  .page-head { align-items: flex-start !important; }
  .detail-terminal-frame { grid-template-columns: 1fr !important; }
  .detail-media { min-height: 420px !important; border-right: 0 !important; border-bottom: 1px solid var(--moon-line) !important; }
  .detail-photo-chamber { min-height: 384px !important; }
  .detail-terminal-actions { justify-content: stretch !important; }
  .detail-terminal-button { flex: 1; }
}

@media (max-width: 600px) {
  .app,
  .main-shell,
  .gate-view { max-width: 100vw; overflow-x: hidden !important; }
  .app.gate-active .nav { display: none !important; }
  .app.gate-active .topbar > .create-cta-compact { margin-left: auto !important; }
  .topbar .brand { min-width: 0 !important; width: auto !important; flex: 1 1 auto !important; }
  .brand-mark { width: 34px !important; height: 34px !important; }
  .brand strong { letter-spacing: .08em !important; }
  .gate-content {
    align-content: start !important;
    width: 100% !important;
    padding: 46vh 20px 28px !important;
  }
  .gate-content h1 { max-width: 100%; font-size: clamp(29px, 8.2vw, 38px) !important; line-height: 1.38 !important; }
  .gate-content .gate-lead { margin: 12px 0 16px !important; font-size: 14px !important; }
  .gate-actions { flex-direction: column; }
  .gate-create-btn,
  .gate-enter-btn { width: 100%; min-height: 46px; }
  .gate-assurance { margin-top: 12px !important; }
  .page-head { gap: 14px !important; }
  .page-head .create-cta-compact { width: 100% !important; }
  .search-row { flex-direction: column !important; }
  .pixel-select { max-width: none !important; width: 100% !important; }
  .memorial-grid { grid-template-columns: 1fr !important; }
  .account-header { align-items: flex-start !important; flex-direction: column !important; }
  .account-item { grid-template-columns: 58px 1fr !important; }
  .item-actions { grid-column: 1 / -1; width: 100%; }
  .item-actions button { flex: 1; }
  .detail-view.active { padding: 72px 14px 28px !important; }
  .detail-copy { padding: 30px 24px !important; }
  .detail-copy h1 { font-size: 42px !important; }
  .detail-copy blockquote { font-size: 20px !important; }
  .detail-terminal-actions { flex-direction: column; }
  .ritual-action-row { grid-template-columns: 1fr !important; }
  .ritual-message-form { grid-template-columns: 1fr !important; }
  .modal-card { border-radius: 8px !important; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    scroll-behavior: auto !important;
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
}

/* Official homepage v2: reference-led landing page, kept separate from product views. */
:root {
  --home-bg-deep: #061326;
  --home-bg-deeper: #020817;
  --home-text-main: #f3dfc8;
  --home-text-soft: #b9adc4;
  --home-text-dim: #7f8aa3;
  --home-gold: #d6ad72;
  --home-gold-soft: #e8c98f;
  --home-border-soft: rgba(232, 201, 143, .22);
  --home-card-bg: rgba(9, 20, 39, .72);
  --home-card-border: rgba(255, 255, 255, .14);
  --home-moon-blue: #88aee8;
}

.home-navigation,
.home-menu-toggle {
  display: none;
}

.app.gate-active {
  background: var(--home-bg-deep) !important;
}

.app.gate-active .topbar {
  position: fixed !important;
  z-index: 100;
  inset: 0 0 auto;
  display: flex !important;
  height: 82px !important;
  min-height: 82px !important;
  padding: 0 clamp(28px, 4vw, 64px) !important;
  border-bottom: 1px solid rgba(232, 201, 143, .16) !important;
  background: rgba(4, 15, 31, .74) !important;
  box-shadow: 0 10px 34px rgba(1, 7, 16, .12) !important;
  backdrop-filter: blur(14px);
}

.app.gate-active .topbar .brand {
  width: auto !important;
  min-width: 216px !important;
  flex: 0 0 auto !important;
  margin-right: auto;
}

.app.gate-active .brand-mark {
  width: 42px !important;
  height: 42px !important;
  background-image: url("assets/brand-paw.png") !important;
  background-size: 20px 20px !important;
  filter: none !important;
}

.app.gate-active .brand strong {
  color: var(--home-text-main) !important;
  font-size: 18px !important;
}

.app.gate-active .brand small {
  display: block !important;
  color: var(--home-text-dim) !important;
}

.app.gate-active .product-nav,
.app.gate-active .product-create-button,
.app.gate-active .header-status {
  display: none !important;
}

.app.gate-active .home-navigation {
  display: flex;
  align-items: center;
  gap: clamp(18px, 2.2vw, 34px);
}

.home-nav {
  display: flex;
  align-items: center;
  gap: clamp(18px, 2.1vw, 32px);
}

.home-nav button,
.home-auth-button,
.home-menu-toggle {
  min-height: 42px;
  padding: 0;
  border: 0;
  background: transparent;
  color: rgba(243, 235, 225, .76);
  cursor: pointer;
  font-family: var(--moon-body);
  font-size: 13px;
  font-weight: 300;
  letter-spacing: .08em;
  transition: color .2s ease, border-color .2s ease, background-color .2s ease;
}

.home-nav button:hover,
.home-nav button:focus-visible {
  color: var(--home-gold-soft);
}

.home-auth-button {
  min-width: 112px;
  padding: 0 18px;
  border: 1px solid rgba(232, 201, 143, .42);
  border-radius: 4px;
  color: var(--home-text-main);
}

.home-auth-button:hover,
.home-auth-button:focus-visible {
  border-color: var(--home-gold-soft);
  background: rgba(214, 173, 114, .08);
  color: #fff7ec;
}

.gate-view.active {
  display: block !important;
  min-height: auto !important;
  height: auto !important;
  overflow: visible !important;
  background: var(--home-bg-deep) !important;
  isolation: auto !important;
}

.home-hero {
  position: relative;
  min-height: max(820px, 100svh);
  overflow: hidden;
  background: var(--home-bg-deeper);
  isolation: isolate;
}

.home-hero .gate-bg {
  position: absolute !important;
  inset: 0 !important;
  background: url("assets/moonlit-garden-hero.png") center / cover no-repeat !important;
  filter: brightness(.96) saturate(.9) sepia(.04) !important;
  transform: none !important;
  transition: filter .65s ease, transform .65s ease !important;
}

.home-hero .gate-shade {
  position: absolute !important;
  inset: 0 !important;
  background:
    linear-gradient(90deg, rgba(2, 8, 23, .94) 0%, rgba(5, 17, 35, .84) 32%, rgba(6, 19, 38, .48) 51%, rgba(6, 19, 38, .1) 76%, rgba(2, 8, 23, .04) 100%),
    linear-gradient(180deg, rgba(2, 8, 23, .03) 52%, rgba(2, 8, 23, .68) 100%) !important;
  box-shadow: none !important;
  opacity: 1 !important;
}

.home-hero::after {
  content: "";
  position: absolute;
  z-index: 1;
  inset: 0;
  background: rgba(85, 64, 44, .045);
  pointer-events: none;
}

.home-hero .gate-content {
  position: relative !important;
  z-index: 3;
  top: auto !important;
  display: grid !important;
  place-items: start !important;
  align-content: center !important;
  width: min(1440px, 100%) !important;
  min-height: max(820px, 100svh) !important;
  margin: 0 auto !important;
  padding: 128px clamp(48px, 6vw, 92px) 54px !important;
  opacity: 1;
  transform: none;
}

.home-hero .gate-kicker {
  margin-bottom: 18px !important;
  color: var(--home-gold-soft) !important;
}

.home-hero .gate-content h1 {
  max-width: 760px;
  color: var(--home-text-main) !important;
  font-size: clamp(44px, 4.45vw, 68px) !important;
  line-height: 1.36 !important;
  text-shadow: 0 5px 28px rgba(2, 8, 23, .52) !important;
}

.home-hero .gate-content .gate-lead {
  margin: 18px 0 28px !important;
  color: var(--home-text-soft) !important;
  font-size: clamp(16px, 1.35vw, 20px) !important;
}

.home-hero .gate-actions {
  width: min(520px, 100%);
}

.home-hero .gate-create-btn {
  background: #b58a51 !important;
  border-color: var(--home-gold-soft) !important;
  color: #fff8ed !important;
}

.home-hero .gate-create-btn:hover {
  background: #c79a5e !important;
}

.home-hero .gate-enter-btn {
  border-color: rgba(185, 173, 196, .32) !important;
  background: rgba(6, 19, 38, .42) !important;
  color: rgba(243, 235, 225, .74) !important;
}

.home-hero .gate-assurance {
  color: var(--home-text-dim) !important;
}

.home-hero .gate-memory-preview {
  grid-template-columns: 126px 1fr;
  gap: 22px;
  width: min(650px, 100%);
  min-height: 166px;
  margin-top: 30px;
  padding: 18px;
  border-color: var(--home-card-border);
  background: rgba(9, 20, 39, .76);
  box-shadow: 0 18px 50px rgba(1, 7, 16, .18);
  backdrop-filter: blur(8px);
}

.home-hero .gate-memory-preview img {
  width: 126px;
  height: 126px;
  border-color: var(--home-border-soft);
}

.home-hero .gate-memory-preview h2 {
  margin-top: 8px;
  color: var(--home-text-main);
  font-size: 25px;
}

.home-hero .gate-memory-preview p {
  font-size: 13px !important;
}

.home-hero .gate-memory-preview blockquote {
  margin-top: 8px !important;
  padding-left: 14px;
  color: #d8cec6 !important;
  font-size: 14px !important;
}

.home-hero .gate-transition-text {
  position: absolute !important;
  z-index: 5;
}

.gate-view.entering .home-hero .gate-bg {
  filter: brightness(.76) saturate(.82) !important;
  transform: scale(1.015) !important;
}

.home-sections {
  position: relative;
  z-index: 4;
  background:
    radial-gradient(circle at 8% 18%, rgba(136, 174, 232, .08), transparent 28%),
    linear-gradient(180deg, #07162b 0%, var(--home-bg-deep) 46%, #071428 100%);
}

.home-section {
  width: min(1240px, calc(100% - 64px));
  margin: 0 auto;
  padding: 104px 0;
  scroll-margin-top: 98px;
  border-bottom: 1px solid rgba(232, 201, 143, .1);
}

.home-section-heading {
  max-width: 760px;
  margin-bottom: 44px;
}

.home-section-heading > span,
.home-final-cta > span {
  display: block;
  margin-bottom: 12px;
  color: var(--home-gold);
  font-family: var(--moon-pixel);
  font-size: 10px;
  letter-spacing: .18em;
}

.home-section-heading h2,
.home-final-cta h2 {
  margin: 0;
  color: var(--home-text-main);
  font-family: var(--moon-display);
  font-size: clamp(34px, 3.4vw, 50px);
  font-weight: 500;
  letter-spacing: .05em;
}

.home-section-heading p,
.home-final-cta p {
  margin: 14px 0 0;
  color: var(--home-text-soft);
  font-size: 16px;
  line-height: 1.8;
}

.home-step-grid,
.home-story-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.home-step-card,
.home-story-card,
.home-garden-card {
  border: 1px solid var(--home-card-border);
  border-radius: 9px;
  background: var(--home-card-bg);
  box-shadow: 0 16px 44px rgba(1, 7, 16, .16);
}

.home-step-card {
  min-height: 248px;
  padding: 30px;
}

.home-step-card img {
  width: 32px;
  height: 32px;
  margin-bottom: 24px;
  object-fit: contain;
  image-rendering: pixelated;
  filter: sepia(1) saturate(.72) brightness(1.35);
}

.home-step-card span {
  color: var(--home-gold);
  font-size: 11px;
  letter-spacing: .12em;
}

.home-step-card h3,
.home-garden-card h3 {
  margin: 12px 0 10px;
  color: #eadbc9;
  font-family: var(--moon-display);
  font-size: 22px;
  font-weight: 500;
}

.home-step-card p,
.home-garden-card p {
  margin: 0;
  color: var(--home-text-dim);
  font-size: 14px;
  line-height: 1.8;
}

.home-story-card {
  display: flex;
  min-width: 0;
  min-height: 390px;
  overflow: hidden;
  flex-direction: column;
  cursor: pointer;
  transition: transform .22s ease, border-color .22s ease, background-color .22s ease;
}

.home-story-card:hover,
.home-story-card:focus-visible {
  transform: translateY(-4px);
  border-color: rgba(232, 201, 143, .36);
  background: rgba(13, 27, 49, .88);
}

.home-story-media {
  position: relative;
  height: 190px;
  overflow: hidden;
  border-bottom: 1px solid var(--home-card-border);
  background: #0a1729;
}

.home-story-media > img {
  position: absolute;
  z-index: 2;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(.76) brightness(.86);
}

.home-story-sprite {
  position: absolute !important;
  z-index: 1;
  top: 50%;
  left: 50%;
  width: 112px !important;
  height: 112px !important;
  transform: translate(-50%, -50%);
  border: 0 !important;
  background: transparent !important;
}

.home-story-copy {
  display: flex;
  min-height: 198px;
  padding: 24px;
  flex: 1;
  flex-direction: column;
}

.home-story-copy h3 {
  margin: 0;
  color: var(--home-text-main);
  font-family: var(--moon-display);
  font-size: 24px;
  font-weight: 500;
}

.home-story-dates {
  margin-top: 6px;
  color: var(--home-text-dim);
  font-size: 13px;
}

.home-story-copy blockquote {
  display: -webkit-box;
  margin: 22px 0 0 !important;
  padding: 0 0 0 15px !important;
  overflow: hidden;
  color: #d9d0c9 !important;
  font-size: 16px !important;
  line-height: 1.7;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

.home-story-copy small {
  margin-top: auto;
  padding-top: 18px;
  color: var(--home-gold);
  font-size: 12px;
}

.home-garden-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
}

.home-garden-card {
  position: relative;
  display: grid;
  grid-template-columns: 78px 1fr;
  gap: 24px;
  min-height: 200px;
  padding: 36px;
  align-items: center;
  overflow: hidden;
}

.home-garden-card::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: .72;
}

.home-garden-card > * {
  position: relative;
  z-index: 1;
}

.home-garden-card img {
  width: 64px;
  height: 64px;
  object-fit: contain;
  image-rendering: pixelated;
  filter: sepia(.7) saturate(.62) brightness(1.2);
}

.garden-lake { background: linear-gradient(135deg, rgba(22, 51, 76, .82), rgba(9, 20, 39, .78)); }
.garden-meadow { background: linear-gradient(135deg, rgba(31, 54, 55, .72), rgba(9, 20, 39, .8)); }
.garden-cherry { background: linear-gradient(135deg, rgba(63, 46, 63, .66), rgba(9, 20, 39, .8)); }
.garden-rainbow { background: linear-gradient(135deg, rgba(51, 48, 74, .68), rgba(9, 20, 39, .8)); }

.home-faq-list {
  width: min(900px, 100%);
  border-top: 1px solid var(--home-card-border);
}

.home-faq-list details {
  border-bottom: 1px solid var(--home-card-border);
}

.home-faq-list summary {
  padding: 24px 4px;
  color: #e5d8ca;
  cursor: pointer;
  font-family: var(--moon-display);
  font-size: 18px;
  list-style-position: outside;
}

.home-faq-list summary::marker {
  color: var(--home-gold);
}

.home-faq-list details p {
  max-width: 760px;
  margin: -6px 0 0;
  padding: 0 4px 24px;
  color: var(--home-text-dim);
  font-size: 14px;
  line-height: 1.8;
}

.home-final-cta {
  width: min(1240px, calc(100% - 64px));
  margin: 0 auto;
  padding: 92px 32px;
  border: 1px solid var(--home-border-soft);
  border-radius: 10px;
  background:
    linear-gradient(110deg, rgba(214, 173, 114, .1), transparent 42%),
    rgba(9, 20, 39, .82);
  text-align: center;
}

.home-final-cta > span { margin-bottom: 14px; }
.home-final-cta p { margin-bottom: 28px; }

.home-final-cta button {
  min-width: 190px;
  min-height: 50px;
  padding: 0 26px;
  border: 1px solid var(--home-gold-soft);
  border-radius: 6px;
  background: #b58a51;
  color: #fff8ed;
  cursor: pointer;
  transition: background-color .2s ease, transform .2s ease;
}

.home-final-cta button:hover {
  background: #c79a5e;
  transform: translateY(-2px);
}

.home-footer {
  display: grid;
  width: min(1240px, calc(100% - 64px));
  margin: 0 auto;
  padding: 64px 0 52px;
  grid-template-columns: 1fr auto;
  gap: 8px 30px;
  align-items: end;
  color: var(--home-text-dim);
}

.home-footer > div {
  display: flex;
  gap: 12px;
  align-items: baseline;
}

.home-footer strong {
  color: var(--home-text-main);
  font-family: var(--moon-display);
  font-size: 20px;
  font-weight: 500;
}

.home-footer span,
.home-footer small { font-size: 12px; }
.home-footer p { grid-column: 1; margin: 0; font-size: 13px; }
.home-footer small { grid-column: 2; grid-row: 1 / span 2; }

@media (max-width: 1040px) {
  .app.gate-active .topbar { padding-inline: 22px !important; }
  .app.gate-active .home-navigation { gap: 18px; }
  .home-nav { gap: 15px; }
  .home-step-grid { gap: 14px; }
  .home-step-card { padding: 24px; }
}

@media (max-width: 860px) {
  .app.gate-active .topbar {
    height: 70px !important;
    min-height: 70px !important;
  }

  .app.gate-active .topbar .brand {
    min-width: 0 !important;
    flex: 0 1 auto !important;
  }

  .app.gate-active .brand-copy small { display: block !important; }
  .app.gate-active .home-menu-toggle {
    display: inline-flex;
    min-width: 68px;
    min-height: 40px;
    margin-left: auto;
    padding: 0 14px;
    border: 1px solid var(--home-border-soft);
    border-radius: 4px;
    align-items: center;
    justify-content: center;
    color: var(--home-text-main);
  }

  .app.gate-active .home-navigation {
    position: absolute;
    top: 70px;
    right: 16px;
    left: 16px;
    display: none;
    padding: 16px;
    border: 1px solid var(--home-card-border);
    border-radius: 8px;
    background: rgba(5, 17, 35, .97);
    box-shadow: 0 22px 55px rgba(1, 7, 16, .44);
    backdrop-filter: blur(16px);
  }

  .app.gate-active .home-navigation.is-open {
    display: grid;
    gap: 12px;
  }

  .home-nav {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
  }

  .home-nav button {
    min-height: 44px;
    padding: 0 12px;
    text-align: left;
  }

  .home-auth-button { width: 100%; }

  .home-hero,
  .home-hero .gate-content { min-height: 820px !important; }
  .home-hero .gate-bg { background-position: 57% center !important; }
  .home-hero .gate-content { padding: 116px 28px 46px !important; }
  .home-hero .gate-content h1 { max-width: 650px; font-size: clamp(38px, 7.1vw, 56px) !important; }

  .home-step-grid,
  .home-story-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .home-step-card:last-child { grid-column: 1 / -1; }
  .home-garden-card { padding: 28px; }
}

@media (max-width: 600px) {
  .app.gate-active .topbar { padding-inline: 16px !important; }
  .app.gate-active .brand-mark { width: 36px !important; height: 36px !important; }
  .app.gate-active .brand strong { font-size: 15px !important; }
  .app.gate-active .brand small { font-size: 9px !important; }
  .home-nav { grid-template-columns: 1fr; }

  .home-hero { min-height: 940px !important; }
  .home-hero .gate-bg {
    background-position: 62% center !important;
    filter: brightness(.88) saturate(.86) !important;
  }
  .home-hero .gate-shade {
    background:
      linear-gradient(180deg, rgba(2, 8, 23, .08) 0%, rgba(3, 11, 25, .2) 28%, rgba(3, 11, 25, .9) 63%, rgba(2, 8, 23, .98) 100%),
      linear-gradient(90deg, rgba(2, 8, 23, .56), rgba(2, 8, 23, .06)) !important;
  }
  .home-hero .gate-content {
    min-height: 940px !important;
    padding: 340px 20px 38px !important;
    align-content: start !important;
  }
  .home-hero .gate-kicker { margin-bottom: 13px !important; }
  .home-hero .gate-content h1 { font-size: clamp(30px, 9.1vw, 38px) !important; line-height: 1.42 !important; }
  .home-hero .gate-content .gate-lead { margin: 12px 0 18px !important; font-size: 14px !important; }
  .home-hero .gate-actions { gap: 9px; flex-direction: column; }
  .home-hero .gate-create-btn,
  .home-hero .gate-enter-btn { min-height: 47px; }
  .home-hero .gate-memory-preview {
    grid-template-columns: 88px 1fr;
    gap: 14px;
    min-height: 120px;
    margin-top: 20px;
    padding: 13px;
  }
  .home-hero .gate-memory-preview img { width: 88px; height: 88px; }
  .home-hero .gate-memory-preview h2 { margin-top: 4px; font-size: 20px; }
  .home-hero .gate-memory-preview blockquote { font-size: 12px !important; -webkit-line-clamp: 2; }

  .home-section {
    width: min(100% - 40px, 1240px);
    padding: 76px 0;
    scroll-margin-top: 82px;
  }
  .home-section-heading { margin-bottom: 30px; }
  .home-section-heading h2,
  .home-final-cta h2 { font-size: 32px; }
  .home-section-heading p,
  .home-final-cta p { font-size: 14px; }
  .home-step-grid,
  .home-story-grid,
  .home-garden-grid { grid-template-columns: 1fr; }
  .home-step-card:last-child { grid-column: auto; }
  .home-step-card { min-height: 0; padding: 24px; }
  .home-step-card img { margin-bottom: 16px; }
  .home-story-card { min-height: 360px; }
  .home-story-media { height: 174px; }
  .home-garden-card { grid-template-columns: 58px 1fr; min-height: 164px; padding: 24px 20px; }
  .home-garden-card img { width: 48px; height: 48px; }
  .home-faq-list summary { font-size: 16px; }

  .home-final-cta {
    width: calc(100% - 40px);
    padding: 62px 20px;
  }
  .home-footer {
    width: calc(100% - 40px);
    padding: 48px 0 38px;
    grid-template-columns: 1fr;
  }
  .home-footer > div { flex-direction: column; gap: 3px; }
  .home-footer p,
  .home-footer small { grid-column: 1; grid-row: auto; }
}
