/* ============================================================
   CORE — shared design system
   Warm cream + terracotta. Premium, clean Helvetica.
   ============================================================ */

:root{
  /* surfaces */
  --cream:        #FAF3E1;   /* page background */
  --cream-2:      #F4E9CE;   /* deeper panel */
  --paper:        #FFFCF2;   /* cards / near-white warm */
  --espresso:     #241310;   /* dark dramatic section */
  --espresso-2:   #311b14;

  /* ink */
  --ink:          #2A1C14;
  --ink-soft:     #6E5B4B;
  --ink-faint:    #9A8979;
  --line:         #E7D9BC;   /* hairline on cream */
  --line-dark:    rgba(255,247,232,.14);

  /* brand blocks */
  --orange:       #E08A2B;
  --terra:        #B65A27;
  --redorange:    #E2532F;
  --red:          #D93B32;
  --maroon:       #882430;
  --coral:        #E0837C;

  /* primary action */
  --brand:        #D9442F;
  --brand-ink:    #B8361F;

  /* type */
  --sans: "Helvetica Neue", Helvetica, Arial, sans-serif;

  /* rhythm */
  --maxw: 1200px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 18px;
  --radius-sm: 12px;

  --shadow-sm: 0 1px 2px rgba(42,28,20,.06), 0 4px 14px rgba(42,28,20,.05);
  --shadow:    0 8px 24px rgba(42,28,20,.08), 0 2px 6px rgba(42,28,20,.05);
  --shadow-lg: 0 30px 70px -24px rgba(64,24,14,.34), 0 10px 24px -12px rgba(42,28,20,.18);

  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  font-family:var(--sans);
  background:var(--cream);
  color:var(--ink);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; }
::selection{ background:rgba(217,68,47,.22); }

/* ---- layout ---- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:clamp(72px,11vw,140px); position:relative; }
.center{ text-align:center; }

/* ---- type ---- */
h1,h2,h3,h4{ margin:0; font-weight:700; letter-spacing:-.02em; line-height:1.02; }
.display{
  font-weight:800;
  font-size:clamp(46px, 8.2vw, 104px);
  letter-spacing:-.045em;
  line-height:.94;
}
h2.title{ font-size:clamp(32px,4.6vw,60px); letter-spacing:-.035em; line-height:1.0; }
h3{ font-size:clamp(20px,2.2vw,26px); letter-spacing:-.02em; }
.lead{ font-size:clamp(18px,2vw,22px); color:var(--ink-soft); line-height:1.55; }
.eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  font-size:13px; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
  color:var(--brand-ink);
}
.eyebrow::before{ content:""; width:22px; height:2px; background:var(--brand); border-radius:2px; }
.eyebrow.on-dark{ color:var(--coral); }
.eyebrow.on-dark::before{ background:var(--coral); }
.muted{ color:var(--ink-soft); }

/* ---- buttons ---- */
.btn{
  --bg:var(--brand); --fg:#fff;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:15px 26px; border-radius:999px; border:0;
  background:var(--bg); color:var(--fg);
  font-size:15.5px; font-weight:700; letter-spacing:-.01em;
  cursor:pointer; position:relative; isolation:isolate;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .2s;
  box-shadow:0 10px 24px -10px rgba(217,68,47,.6);
  will-change:transform;
}
.btn:hover{ transform:translateY(-2px); box-shadow:0 18px 34px -12px rgba(217,68,47,.62); }
.btn:active{ transform:translateY(0); }
.btn.ghost{
  --bg:transparent; --fg:var(--ink);
  border:1.5px solid var(--line); box-shadow:none;
}
.btn.ghost:hover{ background:var(--paper); border-color:#d9c39b; box-shadow:var(--shadow-sm); }
.btn.on-dark.ghost{ --fg:#fff; border-color:var(--line-dark); }
.btn.on-dark.ghost:hover{ background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.3); }
.btn .ico{ width:18px; height:18px; }

/* store buttons */
.stores{ display:flex; flex-wrap:wrap; gap:14px; }
.store{
  display:inline-flex; align-items:center; gap:12px;
  padding:12px 22px 12px 18px; border-radius:14px;
  background:var(--ink); color:#fff;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
  box-shadow:var(--shadow-sm);
}
.store:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.store svg{ width:26px; height:26px; flex:none; }
.store > span{ display:flex; flex-direction:column; }
.store .s-top{ font-size:11px; opacity:.72; letter-spacing:.02em; line-height:1.1; }
.store .s-big{ font-size:18px; font-weight:700; letter-spacing:-.01em; line-height:1.15; }

/* ---- nav ---- */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:100;
  transition:background .3s, box-shadow .3s, border-color .3s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(250,243,225,.82);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom-color:var(--line);
}
.nav-inner{ display:flex; align-items:center; gap:18px; height:72px; }
.brand{ display:inline-flex; align-items:center; gap:11px; font-weight:800; letter-spacing:-.03em; font-size:21px; }
.brand img{ width:34px; height:34px; }
.nav-links{ display:flex; align-items:center; gap:6px; margin-left:auto; }
.nav-links a:not(.btn){
  padding:9px 14px; border-radius:10px; font-size:15px; font-weight:600; color:var(--ink-soft);
  transition:color .2s, background .2s;
}
.nav-links a:not(.btn):hover{ color:var(--ink); background:rgba(42,28,20,.05); }
.nav-cta{ display:flex; align-items:center; gap:10px; margin-left:8px; }
.nav-toggle{ display:none; }

@media (max-width: 900px){
  .nav-links{
    position:fixed; inset:72px 0 auto 0;
    flex-direction:column; align-items:stretch; gap:4px;
    background:var(--cream); border-bottom:1px solid var(--line);
    padding:16px var(--gutter) 24px; margin:0;
    transform:translateY(-12px); opacity:0; pointer-events:none;
    transition:transform .3s var(--ease), opacity .3s;
    box-shadow:var(--shadow);
  }
  .nav.open .nav-links{ transform:none; opacity:1; pointer-events:auto; }
  .nav-links a:not(.btn){ padding:13px 14px; font-size:17px; }
  .nav-cta{ margin:8px 0 0; flex-direction:column; align-items:stretch; }
  .nav-cta .btn{ width:100%; }
  .nav-toggle{
    display:inline-flex; flex-direction:column; gap:5px; margin-left:auto;
    background:none; border:0; padding:10px; cursor:pointer;
  }
  .nav-toggle span{ width:24px; height:2px; background:var(--ink); border-radius:2px; transition:transform .3s, opacity .2s; }
  .nav.open .nav-toggle span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  .nav.open .nav-toggle span:nth-child(2){ opacity:0; }
  .nav.open .nav-toggle span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
}

/* ---- pills / chips ---- */
.chips{ display:flex; flex-wrap:wrap; gap:10px; }
.chip{
  display:inline-flex; align-items:center; gap:8px;
  padding:9px 16px; border-radius:999px;
  background:var(--paper); border:1px solid var(--line);
  font-size:14.5px; font-weight:600; color:var(--ink);
  box-shadow:var(--shadow-sm);
}
.chip .dot{ width:9px; height:9px; border-radius:3px; }

/* ---- cards ---- */
.card{
  background:var(--paper); border:1px solid var(--line); border-radius:var(--radius);
  padding:28px; box-shadow:var(--shadow-sm);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s;
}

/* ---- footer ---- */
.footer{ background:var(--espresso); color:#EFE3CF; padding-block:64px 40px; }
.footer a{ color:#C9B8A2; transition:color .2s; }
.footer a:hover{ color:#fff; }
.footer .brand{ color:#fff; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:36px; }
.foot-grid h4{ font-size:13px; letter-spacing:.14em; text-transform:uppercase; color:var(--coral); margin-bottom:16px; font-weight:700; }
.foot-col ul{ list-style:none; margin:0; padding:0; display:grid; gap:11px; font-size:15px; }
.foot-bottom{
  display:flex; flex-wrap:wrap; gap:14px 26px; justify-content:space-between; align-items:center;
  margin-top:48px; padding-top:26px; border-top:1px solid var(--line-dark);
  font-size:14px; color:#A4917B;
}
@media (max-width:760px){ .foot-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:460px){ .foot-grid{ grid-template-columns:1fr; } }

/* ---- reveal-on-scroll ---- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s; }
.reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; }
.reveal[data-d="4"]{ transition-delay:.32s; }
.reveal[data-d="5"]{ transition-delay:.4s; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none; } }

/* generic page header offset so fixed nav doesn't cover content */
.page-top{ padding-top:120px; }

/* ---- forms ---- */
.field{ display:block; margin-bottom:16px; }
.field label{ display:block; font-size:13.5px; font-weight:700; margin-bottom:7px; color:var(--ink); }
.input{
  width:100%; padding:14px 16px; border-radius:12px; border:1.5px solid var(--line);
  background:var(--paper); font:inherit; font-size:15.5px; color:var(--ink);
  transition:border-color .2s, box-shadow .2s;
}
.input::placeholder{ color:var(--ink-faint); }
.input:focus{ outline:0; border-color:var(--brand); box-shadow:0 0 0 4px rgba(217,68,47,.13); }
.input.err{ border-color:#c23; box-shadow:0 0 0 4px rgba(204,34,51,.12); }
.field .msg{ font-size:12.5px; color:#b22; margin-top:6px; min-height:0; display:none; }
.field.show-msg .msg{ display:block; }
textarea.input{ resize:vertical; min-height:120px; }
.pw-wrap{ position:relative; }
.pw-wrap .toggle{ position:absolute; right:10px; top:50%; transform:translateY(-50%); background:none; border:0; cursor:pointer; color:var(--ink-soft); font-size:13px; font-weight:700; padding:6px 8px; border-radius:8px; }
.pw-wrap .toggle:hover{ background:rgba(42,28,20,.06); }

/* ---- auth split ---- */
.auth{ min-height:100vh; display:grid; grid-template-columns:1.05fr 1fr; }
.auth-aside{ background:var(--espresso); color:#F3E7D3; padding:48px; display:flex; flex-direction:column; justify-content:space-between; position:relative; overflow:hidden; }
.auth-aside .brand{ color:#fff; position:relative; z-index:2; }
.auth-main{ display:grid; place-items:center; padding:48px 24px; }
.auth-card{ width:100%; max-width:420px; }
.auth-card h1{ font-size:34px; letter-spacing:-.03em; }
.auth-blocks{ position:absolute; right:-40px; bottom:-30px; width:380px; opacity:.9; }
.auth-quote{ position:relative; z-index:2; max-width:30ch; }
.auth-quote p{ font-size:22px; line-height:1.4; letter-spacing:-.01em; font-weight:600; color:#fff; }
.auth-quote span{ color:var(--coral); font-size:14px; font-weight:700; }
@media (max-width:820px){ .auth{ grid-template-columns:1fr; } .auth-aside{ display:none; } }

/* ---- prose / legal ---- */
.prose{ max-width:760px; }
.prose h2{ font-size:26px; letter-spacing:-.02em; margin:42px 0 12px; }
.prose h3{ font-size:18px; margin:26px 0 8px; }
.prose p, .prose li{ color:var(--ink-soft); font-size:16.5px; line-height:1.7; }
.prose p{ margin:0 0 16px; }
.prose ul{ margin:0 0 16px; padding-left:22px; display:grid; gap:8px; }
.prose strong{ color:var(--ink); }
.prose a{ color:var(--brand-ink); text-decoration:underline; text-underline-offset:3px; }
.toc{ position:sticky; top:96px; font-size:14.5px; display:grid; gap:9px; align-content:start; }
.toc a{ color:var(--ink-soft); padding:4px 0; border-left:2px solid transparent; padding-left:12px; transition:color .2s,border-color .2s; }
.toc a:hover, .toc a.active{ color:var(--ink); border-color:var(--brand); }
.legal-grid{ display:grid; grid-template-columns:220px 1fr; gap:54px; }
@media (max-width:860px){ .legal-grid{ grid-template-columns:1fr; } .toc{ position:static; display:none; } }

/* ---- page hero (secondary) ---- */
.subhero{ padding:140px 0 40px; position:relative; }
.subhero h1{ font-size:clamp(38px,6vw,72px); letter-spacing:-.04em; line-height:1; }
.subhero .lead{ margin-top:18px; max-width:52ch; }

/* placeholder media */
.ph{
  position:relative; border-radius:var(--radius); overflow:hidden;
  background:
    repeating-linear-gradient(135deg, rgba(182,90,39,.10) 0 11px, transparent 11px 22px),
    var(--cream-2);
  border:1px dashed #cdb487;
  display:grid; place-items:center; color:var(--ink-soft);
}
.ph .ph-tag{ font-family:ui-monospace,Menlo,Consolas,monospace; font-size:12.5px; letter-spacing:.02em; background:rgba(255,252,242,.8); padding:5px 10px; border-radius:7px; border:1px solid var(--line); }
