/* ==========================================================
   Lavish Gains — editorial overlay on top of design-system marketing.css.
   Loaded AFTER assets/fonts.css and assets/marketing.css. Carries the v2
   editorial token palette (--gold, --bg-0, --ink, ...), theme switching
   ([data-theme="dark"|"light"]), Cormorant/Inter type, and every editorial
   component the marketing pages consume (nav.top, .btn-gold/.btn-ghost,
   .page-hero, .press, footer, form-row, .field, .nav-burger, .reveal, ...).
   The design-system marketing.css sits underneath as a future foundation
   (panel/card/btn--primary, dark-only). As pages migrate to design-system
   markup their styles will resolve against marketing.css and rules here
   can be retired.
   ========================================================== */

:root {
  --gold:        #B49450;
  --gold-soft:   #8A7340;
  --gold-bright: #C9A96E;
  --serif: 'Cormorant Garamond', 'Times New Roman', serif;
  --sans:  'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

[data-theme="dark"] {
  --bg-0:        #0E1F12;
  --bg-1:        #122518;
  --bg-2:        #162D1D;
  --bg-3:        #1B3724;
  --ink:         #F5F0E8;
  --ink-soft:    #E5DECC;
  --muted:       #9AA39C;
  --muted-soft:  #6E7A72;
  --line:        rgba(245,240,232,0.09);
  --line-strong: rgba(180,148,80,0.45);
  --glow-warm:   rgba(180,148,80,0.30);
  --glow-deep:   rgba(138,115,64,0.22);
  --skyline:     rgba(6,15,9,0.80);
  --silhouette:  #050E08;
  --vignette:    rgba(0,0,0,0.55);
  --grain-blend: overlay;
  --grain-opacity: 0.55;
  --nav-bg-top:  rgba(14,31,18,0.55);
  --nav-bg-scrolled: rgba(14,31,18,0.90);
  --form-bg:     rgba(18,37,24,0.65);
  --btn-ink:     #0E1F12;
  --press-opacity: 0.55;
}

[data-theme="light"] {
  --bg-0:        #F5F0E8;
  --bg-1:        #ECE6D6;
  --bg-2:        #FFFFFF;
  --bg-3:        #F9F4E8;
  --ink:         #1A2E1F;
  --ink-soft:    #2A4030;
  --muted:       #5A6660;
  --muted-soft:  #8A8478;
  --line:        rgba(26,46,31,0.10);
  --line-strong: rgba(180,148,80,0.50);
  --glow-warm:   rgba(180,148,80,0.55);
  --glow-deep:   rgba(138,115,64,0.30);
  --skyline:     rgba(26,46,31,0.18);
  --silhouette:  #1A2E1F;
  --vignette:    rgba(26,46,31,0.10);
  --grain-blend: multiply;
  --grain-opacity: 0.16;
  --nav-bg-top:  rgba(245,240,232,0.65);
  --nav-bg-scrolled: rgba(245,240,232,0.92);
  --form-bg:     rgba(255,255,255,0.65);
  --btn-ink:     #F5F0E8;
  --press-opacity: 0.75;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--bg-0);
  color: var(--ink);
  font-family: var(--sans);
  font-weight: 300;
  line-height: 1.6;
  letter-spacing: 0.01em;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  transition: background-color 0.6s ease, color 0.6s ease;
}
a { color: inherit; text-decoration: none; }
::selection { background: var(--gold); color: var(--btn-ink); }

/* ─── Type ─── */
.display { font-family: var(--serif); font-weight: 300; letter-spacing: -0.02em; line-height: 1.02; }
.display em { font-style: italic; color: var(--gold); font-weight: 300; }
.eyebrow { font-family: var(--sans); text-transform: uppercase; letter-spacing: 0.32em; font-size: 11px; color: var(--gold); font-weight: 500; }
.lede { font-family: var(--serif); font-weight: 300; font-size: 22px; line-height: 1.5; color: var(--ink-soft); letter-spacing: 0; }

/* ─── Nav ─── */
nav.top {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  padding: 22px 56px;
  display: flex; align-items: center; justify-content: space-between;
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  background: var(--nav-bg-top);
  border-bottom: 1px solid var(--line);
  transition: padding 0.4s ease, background-color 0.4s ease;
}
nav.top.scrolled { padding: 14px 56px; background: var(--nav-bg-scrolled); }
nav.top .logo { font-family: var(--serif); font-size: 28px; letter-spacing: 0.18em; font-weight: 400; color: var(--ink); }
nav.top .logo span { color: var(--gold); }
nav.top ul {
  display: flex; gap: 44px; list-style: none;
  font-size: 13px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-soft);
}
nav.top ul li.mobile-only { display: none; }
nav.top ul a { transition: color 0.25s ease; }
nav.top ul a:hover, nav.top ul a.active { color: var(--gold); }
nav.top .actions { display: flex; gap: 14px; align-items: center; }
nav.top .actions .signin { font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--muted); transition: color 0.25s ease; }
nav.top .actions .signin:hover { color: var(--ink); }

.theme-toggle {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 14px;
  border: 1px solid var(--line);
  background: transparent; color: var(--muted);
  cursor: pointer;
  font-family: var(--sans); font-size: 10px; font-weight: 500;
  letter-spacing: 0.28em; text-transform: uppercase;
  transition: border-color 0.25s ease, color 0.25s ease;
}
.theme-toggle:hover { border-color: var(--gold); color: var(--gold); }
.theme-toggle .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); transition: transform 0.4s ease; }
[data-theme="light"] .theme-toggle .dot { transform: translateX(2px); }

/* ─── Buttons ─── */
.btn-gold, .btn-ghost {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 28px;
  font-size: 11px; font-weight: 500; letter-spacing: 0.28em; text-transform: uppercase;
  cursor: pointer; transition: all 0.3s ease;
  border: 1px solid var(--gold);
}
.btn-gold { color: var(--btn-ink); background: var(--gold); }
.btn-gold:hover { background: transparent; color: var(--gold); }
.btn-ghost { color: var(--ink); background: transparent; border-color: var(--line-strong); }
.btn-ghost:hover { border-color: var(--gold); color: var(--gold); }
.arrow { display: inline-block; transition: transform 0.3s ease; }
.btn-gold:hover .arrow, .btn-ghost:hover .arrow { transform: translateX(4px); }

/* ─── Section base ─── */
section { padding: 140px 56px; position: relative; }
.container { max-width: 1320px; margin: 0 auto; }
.container-narrow { max-width: 880px; margin: 0 auto; }
.section-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 80px; margin-bottom: 80px; flex-wrap: wrap;
}
.section-head h2 { font-size: clamp(40px, 4.5vw, 64px); max-width: 720px; }
.section-head .meta { max-width: 380px; color: var(--muted); font-size: 15px; }

/* ─── Page hero (subordinate pages) ─── */
.page-hero {
  position: relative;
  padding: 220px 56px 120px;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}
.page-hero-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 70% 50% at 80% 20%, var(--glow-warm), transparent 65%),
    radial-gradient(ellipse 60% 60% at 0% 100%, var(--glow-deep), transparent 70%),
    linear-gradient(180deg, var(--bg-0) 0%, var(--bg-1) 100%);
  z-index: 0;
}
.page-hero .grain {
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.08 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity: var(--grain-opacity);
  pointer-events: none;
  z-index: 1;
  mix-blend-mode: var(--grain-blend);
}
.page-hero .container, .page-hero .container-narrow { position: relative; z-index: 2; }
.page-hero h1 {
  font-size: clamp(52px, 6.5vw, 96px);
  margin-top: 28px;
  margin-bottom: 32px;
  max-width: 960px;
}
.page-hero .lede { max-width: 640px; }
.page-hero .breadcrumb {
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 20px;
}
.page-hero .breadcrumb a { color: var(--muted); border-bottom: 1px solid transparent; transition: border-color 0.3s; }
.page-hero .breadcrumb a:hover { border-color: var(--gold); color: var(--gold); }

/* ─── Press strip ─── */
.press { border-top: 1px solid var(--line); padding: 80px 56px; background: var(--bg-0); }
.press-inner { max-width: 1320px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 60px; flex-wrap: wrap; }
.press .label { font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--muted); flex-shrink: 0; }
.press .logos { display: flex; gap: 56px; flex-wrap: wrap; align-items: center; }
.press .logos span {
  font-family: var(--serif); font-size: 22px; letter-spacing: 0.05em;
  color: var(--ink-soft); opacity: var(--press-opacity);
  font-style: italic; transition: opacity 0.3s ease, color 0.3s ease;
}
.press .logos span:hover { opacity: 1; color: var(--gold); }
.press .logos span.bold { font-family: var(--sans); font-weight: 600; font-style: normal; letter-spacing: 0.18em; text-transform: uppercase; font-size: 14px; }

/* ─── Forms ─── */
.form-row { display: flex; gap: 0; border: 1px solid var(--line-strong); background: var(--form-bg); backdrop-filter: blur(10px); }
.form-row input, .form-row select, .form-row textarea {
  flex: 1; background: transparent; border: none;
  padding: 18px 24px;
  color: var(--ink); font-family: var(--sans);
  font-size: 14px; letter-spacing: 0.05em; outline: none;
}
.form-row input::placeholder, .form-row textarea::placeholder { color: var(--muted-soft); }
.form-row button {
  border: none; border-left: 1px solid var(--line-strong);
  background: transparent; color: var(--gold);
  padding: 18px 28px;
  font-size: 11px; font-weight: 500; letter-spacing: 0.28em; text-transform: uppercase;
  cursor: pointer; transition: all 0.3s ease;
}
.form-row button:hover { background: var(--gold); color: var(--btn-ink); }

.field-group { display: grid; gap: 16px; margin-bottom: 16px; }
.field-group.cols-2 { grid-template-columns: 1fr 1fr; }
.field {
  border: 1px solid var(--line);
  background: var(--form-bg);
  padding: 16px 20px;
  transition: border-color 0.25s ease;
}
.field label {
  display: block;
  font-size: 10px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 8px;
}
.field input, .field select, .field textarea {
  width: 100%;
  background: transparent;
  border: none;
  color: var(--ink);
  font-family: var(--sans);
  font-size: 15px;
  outline: none;
  padding: 0;
}
.field textarea { resize: vertical; min-height: 84px; }
.field:focus-within { border-color: var(--gold); }

/* ─── Footer ─── */
footer { background: var(--bg-0); padding: 100px 56px 40px; }
footer .container { max-width: 1320px; margin: 0 auto; }
footer .top {
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1fr;
  gap: 60px; padding-bottom: 80px; border-bottom: 1px solid var(--line);
}
footer .wordmark { font-family: var(--serif); font-size: 56px; letter-spacing: 0.08em; color: var(--ink); margin-bottom: 20px; }
footer .wordmark span { color: var(--gold); }
footer .tag { font-family: var(--serif); font-style: italic; color: var(--muted); font-size: 18px; line-height: 1.5; max-width: 320px; }
footer h5 { font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--gold); font-weight: 500; margin-bottom: 22px; }
footer ul { list-style: none; }
footer ul li { margin-bottom: 12px; }
footer ul a { font-size: 14px; color: var(--ink-soft); transition: color 0.25s ease; }
footer ul a:hover { color: var(--gold); }
footer .bottom { padding-top: 28px; display: flex; justify-content: space-between; align-items: center; color: var(--muted-soft); font-size: 12px; letter-spacing: 0.12em; gap: 24px; flex-wrap: wrap; }
footer .social { display: inline-flex; gap: 18px; align-items: center; }
footer .social a { color: var(--muted-soft); transition: color 0.25s ease; line-height: 0; }
footer .social a:hover { color: var(--gold); }
footer .social svg { width: 18px; height: 18px; display: block; }

/* ─── Animations ─── */
@keyframes fadeUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: none; } }
.reveal { animation: fadeUp 1s ease forwards; }

/* ─── Hamburger + drawer (mobile only — built by lvsh-v2.js) ─── */
.nav-burger {
  display: none;
  width: 36px; height: 36px;
  border: 1px solid var(--line-strong);
  background: transparent;
  cursor: pointer;
  padding: 0;
  position: relative;
  flex-shrink: 0;
}
.nav-burger span {
  display: block;
  position: absolute;
  left: 8px; right: 8px;
  height: 1.5px;
  background: var(--ink);
  transition: transform 0.3s ease, opacity 0.3s ease;
}
.nav-burger span:nth-child(1) { top: 11px; }
.nav-burger span:nth-child(2) { top: 17px; }
.nav-burger span:nth-child(3) { top: 23px; }
nav.top.is-open .nav-burger span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
nav.top.is-open .nav-burger span:nth-child(2) { opacity: 0; }
nav.top.is-open .nav-burger span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

/* ─── Responsive: tablet/laptop ─── */
@media (max-width: 1080px) {
  nav.top { padding: 16px 24px; }
  nav.top.scrolled { padding: 12px 24px; }
  .nav-burger { display: block; }

  /* Drawer: convert ul into a slide-down panel */
  nav.top ul {
    display: flex;
    flex-direction: column;
    gap: 0;
    position: fixed;
    top: 60px; left: 0; right: 0;
    max-height: calc(100vh - 60px);
    overflow-y: auto;
    background: var(--nav-bg-scrolled);
    backdrop-filter: blur(18px) saturate(140%);
    -webkit-backdrop-filter: blur(18px) saturate(140%);
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    padding: 20px 24px 32px;
    transform: translateY(-12px);
    opacity: 0;
    pointer-events: none;
    transition: transform 0.3s ease, opacity 0.3s ease;
    text-transform: uppercase;
    letter-spacing: 0.18em;
  }
  nav.top ul li { padding: 0; border-bottom: 1px solid var(--line); }
  nav.top ul li:last-child { border-bottom: none; }
  nav.top ul li a {
    display: block;
    padding: 18px 0;
    font-size: 14px;
    color: var(--ink);
  }
  nav.top ul li.mobile-only { display: block; padding-top: 12px; }
  nav.top ul li.mobile-only a {
    text-transform: uppercase;
    letter-spacing: 0.22em;
    font-size: 12px;
    color: var(--muted);
  }
  nav.top ul li.mobile-only a.btn-gold {
    margin-top: 16px;
    color: var(--btn-ink);
    background: var(--gold);
    border: 1px solid var(--gold);
    padding: 14px 22px;
    text-align: center;
    justify-content: center;
  }
  nav.top.is-open ul {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
  }
  nav.top .actions .signin, nav.top .actions .btn-gold { display: none; }

  section, .press, footer, .page-hero { padding-left: 28px; padding-right: 28px; }
  section { padding-top: 90px; padding-bottom: 90px; }
  .page-hero { padding-top: 140px; padding-bottom: 70px; }
  .section-head { gap: 32px; margin-bottom: 56px; }
  footer .top { grid-template-columns: 1fr 1fr; gap: 40px; }
  .field-group.cols-2 { grid-template-columns: 1fr; }
}

/* ─── Responsive: tablet ─── */
@media (max-width: 768px) {
  body { font-size: 15px; }
  section, .press, footer, .page-hero { padding-left: 22px; padding-right: 22px; }
  section { padding-top: 70px; padding-bottom: 70px; }
  .page-hero { padding-top: 130px; padding-bottom: 60px; }
  .page-hero h1 { font-size: clamp(36px, 9vw, 60px); margin-top: 18px; margin-bottom: 22px; }
  .page-hero .lede { font-size: 18px; }
  .lede { font-size: 18px; }
  .section-head h2 { font-size: clamp(32px, 7vw, 48px); }
  .press { padding: 56px 22px; }
  .press-inner { gap: 32px; }
  .press .logos { gap: 28px; }
  .press .logos span { font-size: 18px; }
  footer { padding: 70px 22px 32px; }
  footer .top { grid-template-columns: 1fr; gap: 36px; padding-bottom: 56px; }
  footer .wordmark { font-size: 44px; }
  footer .tag { font-size: 16px; max-width: none; }
  footer .bottom { flex-direction: column; align-items: flex-start; gap: 14px; }
}

/* ─── Responsive: phone ─── */
@media (max-width: 560px) {
  nav.top { padding: 12px 18px; }
  nav.top.scrolled { padding: 10px 18px; }
  nav.top .logo { font-size: 22px; }
  nav.top .actions { gap: 10px; }
  .theme-toggle { padding: 6px 10px; font-size: 9px; letter-spacing: 0.22em; gap: 8px; }
  .theme-toggle #themeLabel { display: none; }
  .nav-burger { width: 32px; height: 32px; }
  .nav-burger span:nth-child(1) { top: 9px; }
  .nav-burger span:nth-child(2) { top: 15px; }
  .nav-burger span:nth-child(3) { top: 21px; }

  section, .press, footer, .page-hero { padding-left: 18px; padding-right: 18px; }
  section { padding-top: 56px; padding-bottom: 56px; }
  .page-hero { padding-top: 110px; padding-bottom: 50px; }
  .page-hero h1 { font-size: clamp(30px, 11vw, 44px); }

  .btn-gold, .btn-ghost { padding: 12px 20px; font-size: 10px; letter-spacing: 0.22em; }
  .form-row { flex-direction: column; }
  .form-row button { border-left: none; border-top: 1px solid var(--line-strong); }

  footer { padding: 56px 18px 28px; }
  footer .wordmark { font-size: 36px; }
}
