/* ════════════════════════════════════════════════════════════════════
   LEGACY CREAM OVERLAY
   ─────────────────────────────────────────────────────────────────────
   Re-skins the legacy stone+indigo pages (account, settings, checkout,
   change-payment) with the cream-editorial design language. Loaded
   AFTER each page's legacy <style> so the cascade swaps every surface,
   typography, button and accent. Markup and JS are 100% unchanged.

   Pair with design-system.css (loaded first) which provides the cream
   tokens (--paper, --ink, --lav, --line, etc.).
   ════════════════════════════════════════════════════════════════════ */

/* ── Token redirects: legacy --bg/--sf/--ac/--tx all map to cream ── */
:root{
  /* Surfaces */
  --bg:var(--paper);
  --sf:var(--paper-warm);
  --sf2:var(--paper-deep);
  --sf3:var(--paper-deep);
  /* Text */
  --tx:var(--ink);
  --tx2:var(--ink-mute);
  --tx3:var(--ink-soft);
  /* Lines */
  --bd:var(--line);
  --bd2:var(--line-strong);
  /* Accent — legacy indigo becomes lavender */
  --ac:var(--lav-deep);
  --ac-h:var(--ink);
  --ac-l:var(--lav);
  --ac-ll:var(--lav-mist);
  /* Status — warm muted variants instead of clinical green/orange/red */
  --ok:#3a7a4f;
  --warn:#a05a00;
  --danger:#a92a2a;
  --radius:14px;
}
/* Dark theme is intentionally collapsed onto cream — the design system
   is single-mode by choice. The dark-toggle remains functional but has
   no visual effect (kept this way to avoid touching theme-toggle JS). */
[data-theme="dark"]{
  --bg:var(--paper);
  --sf:var(--paper-warm);
  --sf2:var(--paper-deep);
  --sf3:var(--paper-deep);
  --tx:var(--ink);
  --tx2:var(--ink-mute);
  --tx3:var(--ink-soft);
  --bd:var(--line);
  --bd2:var(--line-strong);
  --ac:var(--lav-deep);
  --ac-h:var(--ink);
  --ac-l:var(--lav);
  --ac-ll:var(--lav-mist);
  --ok:#3a7a4f;
  --warn:#a05a00;
  --danger:#a92a2a;
}

/* ── Body & global typography ─────────────────────────── */
body{
  font-family:var(--font-body);
  letter-spacing:-.005em;
  background:var(--paper);
  color:var(--ink);
}
::selection{background:var(--lav-mist);color:var(--lav-deep)}

/* ── Top nav (sticky, hairline-on-scroll) ─────────────── */
.nav{
  position:sticky;top:0;height:auto;
  padding:14px clamp(20px,4vw,48px);
  background:color-mix(in srgb,var(--paper) 80%,transparent);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
          backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .25s var(--ease,cubic-bezier(.2,.6,0,1));
}
.nav.stuck{border-bottom-color:var(--line)}
.logo{
  font-family:var(--font-body);
  font-size:22px;font-weight:800;letter-spacing:-.04em;color:var(--ink);
}
.logo span{color:var(--lav)}
.nav-link{
  font-family:var(--font-body);font-weight:500;font-size:13.5px;
  color:var(--ink-mute);letter-spacing:-.005em;
  border-radius:8px;
}
.nav-link:hover{color:var(--ink);background:transparent}
.nav-link.active{color:var(--lav-deep);background:transparent}
.theme-btn{
  border:1px solid var(--line-strong);
  color:var(--ink-mute);background:transparent;
}
.theme-btn:hover{
  border-color:var(--lav);color:var(--ink);background:var(--lav-mist);
}

/* ── Hero (eyebrow + h1 + subtitle) ───────────────────── */
.hero .eyebrow{
  font-family:var(--font-body);
  color:var(--lav-deep);
  font-weight:700;font-size:11px;letter-spacing:.16em;text-transform:uppercase;
}
.hero .eyebrow::before{background:var(--lav)}
.hero h1{
  font-family:var(--font-body);font-weight:700;
  letter-spacing:-.04em;color:var(--ink);
}
.hero h1 em{
  font-family:var(--font-display);font-style:italic;font-weight:500;
  color:var(--lav-deep);letter-spacing:-.02em;
}
.hero p{color:var(--ink-mute)}

/* ── Cards (paper-warm + line-strong) ─────────────────── */
.card{
  background:var(--paper-warm);
  border:1px solid var(--line-strong);
  border-radius:14px;
  box-shadow:none;
}
.card:hover{
  border-color:color-mix(in srgb,var(--lav) 35%,var(--line-strong));
}
.card h2{
  font-family:var(--font-body);
  color:var(--ink-soft);
  font-weight:700;font-size:11px;letter-spacing:.14em;
}

/* ── Buttons (ink-fill primary, paper ghost, soft danger) ── */
.btn{
  font-family:var(--font-body);
  letter-spacing:-.005em;
}
.btn-primary{
  background:var(--ink);color:var(--paper);
  border-color:var(--ink);
  box-shadow:0 1px 2px rgba(20,16,8,.08),0 6px 18px -4px rgba(20,16,8,.18);
}
.btn-primary:hover{
  background:var(--ink);filter:brightness(1.18);transform:translateY(-1px);
  box-shadow:0 1px 2px rgba(20,16,8,.10),0 10px 24px -4px rgba(20,16,8,.22);
}
.btn-ghost{
  background:var(--paper);color:var(--ink);
  border-color:var(--line-strong);
}
.btn-ghost:hover{
  background:var(--paper-deep);
  border-color:color-mix(in srgb,var(--lav) 30%,var(--line-strong));
}
.btn-danger{
  background:transparent;color:#a92a2a;
  border-color:color-mix(in srgb,#a92a2a 25%,var(--line-strong));
}
.btn-danger:hover{
  background:rgba(169,42,42,.08);border-color:#a92a2a;
}

/* ── Pills (status badges) ────────────────────────────── */
.pill-ok{color:#3a7a4f;background:rgba(58,122,79,.10)}
.pill-warn{color:#a05a00;background:rgba(160,90,0,.10)}
.pill-neu{color:var(--ink-mute);background:var(--paper-deep);border:1px solid var(--line)}
.pill-err{color:#a92a2a;background:rgba(169,42,42,.10)}

/* ── Plan summary (account.html) ──────────────────────── */
.plan-headline{border-bottom-color:var(--line)}
.plan-name{
  font-family:var(--font-body);
  color:var(--ink);letter-spacing:-.03em;
}
.plan-price{color:var(--ink-mute)}
.plan-price strong{color:var(--ink)}

.meta-item .label{
  color:var(--ink-soft);font-weight:700;letter-spacing:.08em;
  font-family:var(--font-body);
}
.meta-item .sub{color:var(--ink-soft)}

/* ── Credits visual ───────────────────────────────────── */
.credits-big{
  font-family:var(--font-body);font-weight:800;
  color:var(--ink);letter-spacing:-.04em;
}
.credits-label{color:var(--ink-mute)}
.credits-bar{background:var(--paper-deep)}
.credits-bar-fill{
  background:linear-gradient(90deg,var(--lav-deep),var(--lav));
}
.credits-legend{color:var(--ink-soft)}

/* ── Empty state ──────────────────────────────────────── */
.empty-icon{
  background:linear-gradient(135deg,var(--lav-mist),color-mix(in srgb,var(--lav) 8%,var(--paper-warm)));
  border:1px solid color-mix(in srgb,var(--lav) 25%,var(--line-strong));
}
.empty-icon svg{stroke:var(--lav-deep)}
.empty h3{color:var(--ink);font-family:var(--font-body);font-weight:700}
.empty p{color:var(--ink-mute)}

/* ── Banner notices (warn / ok) ───────────────────────── */
.banner.warn{
  background:rgba(160,90,0,.06);
  border:1px solid rgba(160,90,0,.22);
  color:var(--ink);
}
.banner.warn .icon{
  background:rgba(160,90,0,.12);color:#a05a00;
}
.banner.ok{
  background:rgba(58,122,79,.06);
  border:1px solid rgba(58,122,79,.22);
  color:var(--ink);
}
.banner.ok .icon{
  background:rgba(58,122,79,.12);color:#3a7a4f;
}

/* ── Help cards (account.html) ────────────────────────── */
.help-card{background:var(--paper-deep);border:1px solid var(--line)}
.help-list a{
  background:var(--paper-warm);border:1px solid var(--line-strong);
}
.help-list a:hover{
  background:color-mix(in srgb,var(--lav) 6%,var(--paper-warm));
  border-color:color-mix(in srgb,var(--lav) 30%,var(--line-strong));
}
.help-list .help-row-static{
  background:var(--paper);border:1px solid var(--line);
}
.help-list .help-row-static .help-text strong{color:var(--ink)}
.help-list .help-row-static .help-text span{color:var(--ink-mute)}

/* ── Modal & toast ────────────────────────────────────── */
.modal-overlay{background:color-mix(in srgb,var(--ink) 55%,transparent)}
.modal{
  background:var(--paper);border:1px solid var(--line-strong);
  border-radius:18px;
  box-shadow:0 24px 64px -12px rgba(20,16,8,.25);
}
.modal-icon{
  background:rgba(160,90,0,.10);color:#a05a00;
}
.toast{
  background:var(--paper);border:1px solid var(--line-strong);
}

/* ── Skeleton loader ──────────────────────────────────── */
.skel{
  background:linear-gradient(90deg,var(--paper-deep),var(--paper-warm) 50%,var(--paper-deep));
}

/* ── Settings (row layouts) ───────────────────────────── */
.row{border-bottom-color:var(--line)}
.row-text strong{color:var(--ink);font-family:var(--font-body)}
.row-text span{color:var(--ink-mute)}

/* ── Form inputs (settings + change-payment) ──────────── */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="search"],
textarea,
select{
  font-family:var(--font-body);
  background:var(--paper);
  border-color:var(--line-strong);
  color:var(--ink);
}
input:focus,
textarea:focus,
select:focus{
  border-color:var(--lav);
  box-shadow:0 0 0 4px var(--lav-mist);
  outline:none;
}
input::placeholder,textarea::placeholder{color:var(--ink-soft)}

/* ── Checkout-specific (PayPal pages) ─────────────────── */
/* Order summary, line items, totals — reuse card styles + ink type */
.order-summary,.line-item,.totals,.summary-card{
  background:var(--paper-warm);border:1px solid var(--line-strong);
}
.line-item + .line-item,.totals{border-top:1px solid var(--line)}
.amount,.total-amount,.line-amount{
  font-family:var(--font-body);font-weight:700;color:var(--ink);
}
.boot-msg{color:var(--ink-mute)}

/* ── Footer (where present) ───────────────────────────── */
.footer,.foot{
  border-top:1px solid var(--line);
  background:var(--paper-warm);
  color:var(--ink-soft);
}
.footer a,.foot a{color:var(--ink-soft)}
.footer a:hover,.foot a:hover{color:var(--ink)}

/* ── Generic refinements ──────────────────────────────── */
strong,b{color:var(--ink)}
hr{border-color:var(--line)}
