/* ============================================================
   GAVO — First Light website (v2)
   Shared stylesheet · 18 June 2026
   Brand rules enforced here:
   - Colour lives ONLY in the dawn band. Headlines stay one colour.
   - Gold is a small-UI accent, never a button fill.
   - Spectral = display/serif/anchor. Space Grotesk = UI/body/figures.
   ============================================================ */

:root{
  --night:#0E1530; --indigo:#18203C; --plum:#4A3A5E; --ember:#A85A36;
  --gold:#E7A24A; --gold-soft:#F4C879; --bone:#F1ECE3; --paper:#F8F4EC;
  --ink:#14182A; --muted:#5b6076; --line:rgba(20,24,42,.12);
  --band:linear-gradient(105deg,#0E1530 0%,#101A38 28%,#4A3A5E 54%,#A85A36 78%,#E7A24A 92%,#F4C879 100%);
  --hr:linear-gradient(90deg,#4A3A5E 0%,#A85A36 50%,#E7A24A 100%);
  --maxw:1160px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Space Grotesk',system-ui,sans-serif;
  color:var(--ink); background:var(--paper);
  line-height:1.6; -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.serif,.anchor{font-family:'Spectral',Georgia,serif;font-weight:400;letter-spacing:-.01em;line-height:1.1}
a{color:inherit}
img,svg{max-width:100%}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
section{padding:84px 0}
.section-tight{padding:56px 0}
.eyebrow{font-family:'Space Grotesk',sans-serif;font-size:12px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--ember);display:block;margin-bottom:18px}
.dark .eyebrow{color:var(--gold-soft)}
.hr2{height:3px;width:128px;background:var(--hr);border-radius:3px;margin:0 0 26px}
.lede{font-size:clamp(17px,1.9vw,22px);font-weight:300;line-height:1.55;max-width:60ch;color:#2a2e40}
.dark .lede{color:var(--bone);opacity:.92}
p{max-width:66ch}
.muted{color:var(--muted)}

/* ---------- backgrounds ---------- */
.dark{background:var(--night);color:var(--bone);position:relative;overflow:hidden}
.dark h1,.dark h2,.dark h3{color:var(--bone)}
.dark p{color:rgba(241,236,227,.84)}
.bone{background:var(--bone)}
.paper{background:var(--paper)}
/* the single signature device: the dawn band, masked into a corner glow */
.dawnglow::after{
  content:"";position:absolute;inset:0;background:var(--band);opacity:.82;
  -webkit-mask-image:radial-gradient(120% 88% at 100% 0%,#000 0%,transparent 60%);
  mask-image:radial-gradient(120% 88% at 100% 0%,#000 0%,transparent 60%);
  pointer-events:none;z-index:0;
}
.dark .wrap{position:relative;z-index:1}

/* ---------- top nav ---------- */
header.nav{position:sticky;top:0;z-index:40;background:rgba(14,21,48,.86);backdrop-filter:blur(10px);border-bottom:1px solid rgba(241,236,227,.10)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;color:var(--bone)}
.brand svg,.brand img{height:34px;width:auto;display:block}
.brand .wm{font-family:'Spectral',serif;font-size:23px;letter-spacing:.01em;color:var(--bone)}
.brand .wm b{font-weight:500}
.navlinks{display:flex;align-items:center;gap:28px;list-style:none;margin:0;padding:0}
.navlinks a{font-size:14px;font-weight:500;text-decoration:none;color:rgba(241,236,227,.82);transition:color .15s}
.navlinks a:hover,.navlinks a.active{color:var(--bone)}
.navlinks a.btn-primary{color:var(--ink)}   /* CTA label must stay dark on the bone button, not inherit the light nav colour */
.navtoggle{display:none;background:none;border:0;color:var(--bone);font-size:24px;cursor:pointer;line-height:1}

/* ---------- buttons (gold never fills a button) ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:'Space Grotesk',sans-serif;font-size:14.5px;font-weight:600;
  text-decoration:none;padding:13px 24px;border-radius:100px;border:1.5px solid transparent;cursor:pointer;transition:transform .12s,box-shadow .15s,background .15s}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--bone);color:var(--ink)}
.btn-primary:hover{box-shadow:0 8px 26px rgba(0,0,0,.28)}
.btn-ink{background:var(--ink);color:var(--bone)}
.btn-ink:hover{box-shadow:0 8px 24px rgba(20,24,42,.25)}
.btn-ghost{background:transparent;color:var(--bone);border-color:rgba(241,236,227,.4)}
.btn-ghost:hover{border-color:var(--bone)}
.btn-ghost-ink{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost-ink:hover{border-color:var(--ink)}
.btnrow{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}

/* ---------- hero ---------- */
.hero{padding:120px 0 110px}
.hero h1{font-size:clamp(40px,6.4vw,82px);line-height:1.02;margin:0 0 26px;max-width:16ch}
.hero .lede{max-width:52ch}
.kicker{font-family:'Space Grotesk',sans-serif;font-style:normal;font-weight:400;font-size:clamp(14px,1.55vw,18px);letter-spacing:.01em;color:var(--bone);opacity:.66;margin-top:20px}

/* ---------- generic grid + cards ---------- */
.grid{display:grid;gap:20px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:26px}
.dark .card{background:rgba(241,236,227,.045);border-color:rgba(241,236,227,.14)}
.card .k{font-family:'Space Grotesk',sans-serif;font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ember);margin-bottom:11px}
.dark .card .k{color:var(--gold-soft)}
.card h3{font-size:21px;line-height:1.12;margin:0 0 9px}
.card p{font-size:14.5px;line-height:1.55;color:#3f4a5d;margin:0}
.dark .card p{color:rgba(241,236,227,.82)}
.card.lead{box-shadow:inset 3px 0 0 var(--gold)}   /* gold as accent line only */

/* hand-drawn line icons — ink/bone strokes with twinkling gold accents */
.icn{width:34px;height:34px;display:block;flex:none;color:var(--ink);transition:transform .3s ease}
.card .icn{width:48px;height:48px;margin-bottom:18px}
.milestone .icn{width:62px;height:62px;margin-bottom:12px}
.milestone.slate .icn{color:var(--bone)}                             /* white line on dark tiles */
.milestone:hover .icn,.card.lead:hover .icn,.fact:hover .icn{transform:rotate(-2deg) scale(1.05)}

/* gold accent flourishes (sparkle + tick + dot) injected into every .icn */
.icn .acc{stroke:var(--gold);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.icn .acc circle{fill:var(--gold);stroke:none}
@keyframes gv-twinkle{0%,100%{opacity:.28}50%{opacity:1}}
@media (prefers-reduced-motion:no-preference){ .icn .acc{animation:gv-twinkle 1.5s ease-in-out infinite} }

/* fact list — icon bullets (About founder), ~40% smaller than milestone icons */
.factlist{list-style:none;padding:0;margin:0;display:grid;gap:20px}
.fact{display:flex;gap:15px;align-items:flex-start}
.fact .icn{width:37px;height:37px;flex:none}
.fact .ft{font-size:15.5px;line-height:1.5;color:#34384a;max-width:42ch}
.fact .ft strong{color:var(--ink)}

/* draw-on reveal of the MAIN strokes only ('>' excludes the injected .acc group) */
@media (prefers-reduced-motion:no-preference){
  .js-draw .milestone .icn>path,.js-draw .milestone .icn>circle,
  .js-draw .card.lead .icn>path,.js-draw .card.lead .icn>circle,
  .js-draw .fact .icn>path,.js-draw .fact .icn>circle{stroke-dasharray:300;stroke-dashoffset:300}
  .js-draw .milestone.in-view .icn>path,.js-draw .milestone.in-view .icn>circle,
  .js-draw .card.lead.in-view .icn>path,.js-draw .card.lead.in-view .icn>circle,
  .js-draw .fact.in-view .icn>path,.js-draw .fact.in-view .icn>circle{animation:gavo-draw 1.05s ease forwards}
}
@keyframes gavo-draw{to{stroke-dashoffset:0}}
.step .icn{width:44px;height:44px}
@media (prefers-reduced-motion:no-preference){
  .js-draw .step .icn>path,.js-draw .step .icn>circle{stroke-dasharray:300;stroke-dashoffset:300}
  .js-draw .step.in-view .icn>path,.js-draw .step.in-view .icn>circle{animation:gavo-draw 1.05s ease forwards}
}

/* milestone tiles */
.milestone{display:flex;flex-direction:column;gap:7px;padding:22px;border:1px solid var(--line);border-radius:13px;background:#fff}
.milestone .m-amt{font-family:'Spectral',serif;font-size:15px;color:var(--ember)}
.milestone h3{font-size:18px;margin:0}
.milestone p{font-size:13.5px;color:var(--muted);margin:0}
/* slate = dark chalkboard tile (carries bone chalk icons) */
.milestone.slate{background:var(--night);color:var(--bone);border-color:rgba(241,236,227,.14)}
.milestone.slate .m-amt{color:var(--gold-soft)}
.milestone.slate h3{color:var(--bone)}
.milestone.slate p{color:rgba(241,236,227,.72)}

/* stat */
.stat .n{font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:clamp(30px,4.4vw,52px);line-height:1;letter-spacing:-.02em}
.stat .n .accent{color:var(--ember)}
.dark .stat .n .accent{color:var(--gold-soft)}
.stat .l{font-size:13px;color:var(--muted);margin-top:10px;max-width:24ch}
.dark .stat .l{color:rgba(241,236,227,.62)}

/* numbered process steps */
.steps{counter-reset:step;display:grid;gap:2px}
.step{display:grid;grid-template-columns:74px 1fr;gap:20px;align-items:start;padding:26px 0;border-top:1px solid var(--line)}
.stepleft{display:flex;flex-direction:column;gap:14px;align-items:flex-start}
.dark .step{border-top-color:rgba(241,236,227,.16)}
.step .num{counter-increment:step;font-family:'Spectral',serif;font-size:34px;color:var(--ember);line-height:1}
.dark .step .num{color:var(--gold-soft)}
.step h3{font-size:21px;margin:0 0 7px}
.step p{margin:0}

/* clean list */
ul.clean{list-style:none;padding:0;margin:0}
ul.clean li{position:relative;padding:13px 0 13px 26px;border-bottom:1px solid var(--line);font-size:15.5px;max-width:84ch}
.dark ul.clean li{border-bottom-color:rgba(241,236,227,.16)}
ul.clean li::before{content:"";position:absolute;left:0;top:21px;width:7px;height:7px;border-radius:50%;background:var(--gold)}
ul.clean li strong{font-weight:600}

/* pull / quote */
.pull{font-family:'Spectral',serif;font-size:clamp(22px,3.1vw,34px);line-height:1.28;max-width:20ch}
.signoff{font-family:'Spectral',serif;font-style:italic;font-size:17px;color:var(--muted);margin-top:18px}
.dark .signoff{color:rgba(241,236,227,.7)}

/* disclosure / compliance block */
.disclosure{font-size:13px;line-height:1.6;color:var(--muted);border-left:2px solid var(--line);padding:6px 0 6px 18px;max-width:70ch}
.dark .disclosure{color:rgba(241,236,227,.66);border-left-color:rgba(241,236,227,.22)}
.confirm{background:rgba(168,90,54,.10);color:var(--ember);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:.9em;padding:1px 7px;border-radius:5px;border:1px dashed rgba(168,90,54,.5);white-space:nowrap}

/* ---------- forms (Apply) ---------- */
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:22px}
.field label{font-size:13.5px;font-weight:600;letter-spacing:.01em}
.field .hint{font-size:12.5px;color:var(--muted);font-weight:400}
.field input,.field select,.field textarea{
  font-family:'Space Grotesk',sans-serif;font-size:15px;color:var(--ink);
  background:#fff;border:1.5px solid var(--line);border-radius:10px;padding:13px 14px;width:100%}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--plum);box-shadow:0 0 0 3px rgba(74,58,94,.12)}
.choice{display:flex;flex-wrap:wrap;gap:10px}
.choice label{display:flex;align-items:center;gap:9px;border:1.5px solid var(--line);border-radius:100px;padding:10px 16px;font-size:13.5px;font-weight:500;cursor:pointer;background:#fff}
.choice input{accent-color:var(--plum);width:auto}
.consent{display:flex;gap:11px;align-items:flex-start;font-size:13px;color:var(--muted);line-height:1.5;max-width:74ch}
.consent input{margin-top:3px;accent-color:var(--plum)}
.formnote{font-size:12.5px;color:var(--muted);margin-top:6px}

/* ---------- legal documents (Privacy / Terms) ---------- */
.legal-doc{max-width:860px}
.legal-doc .langtoggle{font-size:13px;margin:0 0 14px;font-weight:600;letter-spacing:.02em}
.legal-doc .langtoggle a{color:var(--muted);text-decoration:none;margin-right:10px}
.legal-doc .langtoggle a:hover{color:var(--ink)}
.legal-doc .langtoggle a.on{color:var(--ember)}
.legal-doc .updated{font-size:13px;color:var(--muted);margin:0 0 26px}
.legal-doc .intro{font-size:15.5px;line-height:1.72;color:#34384a;margin:0 0 14px;max-width:84ch}
.legal-doc h2{font-size:19px;margin:36px 0 14px;letter-spacing:-.005em}
.legal-doc .clause{display:flex;gap:14px;margin:0 0 13px;max-width:88ch}
.legal-doc .clause > .cn{flex:none;min-width:34px;color:var(--ember);font-weight:600;font-family:'Space Grotesk',sans-serif;font-size:14px;line-height:1.6}
.legal-doc .clause > .ct{font-size:15px;line-height:1.66;color:#34384a}
.legal-doc .clause .ct strong{color:var(--ink)}
.legal-doc .sub{display:flex;gap:12px;margin:0 0 9px;padding-left:48px;max-width:88ch}
.legal-doc .sub > .cn{flex:none;min-width:30px;color:var(--muted);font-weight:600;font-family:'Space Grotesk',sans-serif;font-size:13.5px;line-height:1.6}
.legal-doc .sub > .ct{font-size:14.5px;line-height:1.62;color:#3f4a5d}
.legal-doc .collected{margin:6px 0 14px;padding:18px 20px;border:1px solid var(--line);border-radius:12px;background:#fff;font-size:14.5px;line-height:1.7;color:#34384a}
.legal-doc .collected strong{color:var(--ink)}
.legal-doc .lnote{font-style:italic;color:var(--muted);font-size:13.5px;margin:4px 0 12px;padding-left:48px}
.legal-doc .pending{background:rgba(168,90,54,.10);color:var(--ember);font-weight:600;font-size:.92em;padding:0 6px;border-radius:5px;border:1px dashed rgba(168,90,54,.5);white-space:nowrap}

/* ---------- footer ---------- */
footer.foot{background:var(--night);color:var(--bone);position:relative;overflow:hidden}
.foot .band{height:4px;background:var(--band)}
.foot .wrap{padding:64px 28px 40px;position:relative;z-index:1}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
.foot .brand .wm{font-size:26px}
.foot .anchorline{font-family:'Spectral',serif;font-style:italic;color:var(--gold-soft);margin-top:14px;font-size:15px}
.foot h4{font-family:'Space Grotesk',sans-serif;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(241,236,227,.6);margin:0 0 16px;font-weight:600}
.foot ul{list-style:none;padding:0;margin:0;display:grid;gap:11px}
.foot a{font-size:14px;color:rgba(241,236,227,.82);text-decoration:none}
.foot a:hover{color:var(--bone)}
.foot .legal{margin-top:44px;padding-top:24px;border-top:1px solid rgba(241,236,227,.14);font-size:12px;line-height:1.7;color:rgba(241,236,227,.6);max-width:90ch}
.foot .footlinks{margin-top:22px;font-size:12.5px}
.foot .footlinks a{color:rgba(241,236,227,.74);text-decoration:none;margin:0 6px}
.foot .footlinks a:first-child{margin-left:0}
.foot .footlinks a:hover{color:var(--bone);text-decoration:underline}
.foot .copyright{margin-top:10px;text-align:left;font-size:12px;letter-spacing:.02em;color:rgba(241,236,227,.55)}

/* ---------- responsive ---------- */
@media(max-width:860px){
  .navlinks{position:fixed;inset:70px 0 auto 0;flex-direction:column;align-items:flex-start;gap:0;background:var(--night);padding:8px 28px 22px;border-bottom:1px solid rgba(241,236,227,.12);display:none}
  .navlinks.open{display:flex}
  .navlinks li{width:100%}
  .navlinks a{display:block;padding:14px 0;width:100%;border-bottom:1px solid rgba(241,236,227,.08)}
  .navtoggle{display:block}
  .g2,.g3,.g4{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr;gap:30px}
  section{padding:60px 0}
  .hero{padding:80px 0 72px}
  .step{grid-template-columns:52px 1fr;gap:14px}
  .step .icn{width:34px;height:34px}
}
@media(max-width:560px){
  .wrap{padding:0 20px}
  .btnrow .btn{width:100%;justify-content:center}
}
