/* =========================================================================
   Solae Global — Swiss / International Typographic Style
   Off-white + near-black + one restrained gold accent. Grotesque type, grid,
   strong hierarchy, generous negative space. One stylesheet, all pages.
   ====================================================================== */

:root{
  --paper:#F4F1EA;        /* warm off-white (page) */
  --paper-2:#FAF8F3;      /* near-white panel / cards */
  --paper-3:#EBE7DD;      /* subtle band */
  --ink:#1C1A17;          /* near-black (warm) */
  --ink-soft:#3F3A32;     /* secondary text — darkened to pass WCAG AA */
  --ink-faint:#554E44;    /* labels / hints — darkened, still legible */
  --brass:#9A7A3C;
  --brass-deep:#6A4C15;   /* gold accent — darkened for readable emphasis */
  --terra:#A6492F;        /* warm accent, sparing */
  --od:#F4F1EA;           /* text on the dark bands */
  --od-soft:rgba(244,241,234,.66);
  --od-faint:rgba(244,241,234,.42);
  --line:rgba(28,26,23,.14);
  --line-2:rgba(28,26,23,.07);
  --display:'Inter',system-ui,-apple-system,sans-serif;
  --body:'Inter',system-ui,-apple-system,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --gutter:clamp(20px,5vw,72px);
  --max:1200px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--paper);color:var(--ink);
  font-family:var(--body);font-weight:400;font-size:16px;line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
::selection{background:var(--ink);color:var(--paper);}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:2px solid var(--brass);outline-offset:3px;
}
.wrap{max-width:var(--max);margin:0 auto;padding-left:var(--gutter);padding-right:var(--gutter);}

/* reveal-on-scroll */
.rv{opacity:0;transform:translateY(16px);transition:opacity .8s cubic-bezier(.22,.61,.36,1),transform .8s cubic-bezier(.22,.61,.36,1);}
.rv.in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  .rv{opacity:1;transform:none;transition:none;}
}

.eyebrow{font-family:var(--mono);font-weight:500;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);}
h1 em,h2 em,h3 em{font-style:normal;color:var(--brass-deep);}
h1,h2,h3,h4{font-weight:700;letter-spacing:-.03em;}

/* ===================== HEADER ===================== */
header{position:fixed;inset:0 0 auto 0;z-index:90;transition:background .35s,box-shadow .35s,backdrop-filter .35s;}
header.solid{background:rgba(244,241,234,.92);backdrop-filter:saturate(1.2) blur(10px);box-shadow:0 1px 0 var(--line);}
.hd{display:flex;align-items:center;justify-content:space-between;padding-top:18px;padding-bottom:18px;}
.wordmark{display:inline-flex;align-items:center;gap:11px;font-family:var(--mono);font-weight:500;font-size:13px;letter-spacing:.36em;text-transform:uppercase;white-space:nowrap;color:var(--ink);}
.wordmark .mark{width:30px;height:30px;display:block;flex:none;}
.wordmark .wm-text span{color:var(--brass-deep);}
.custom-logo,.custom-logo-link img{height:40px;width:auto;display:block;}
@media (max-width:520px){.wordmark .wm-text{display:none;}}
nav.primary{display:flex;align-items:center;gap:24px;}
nav.primary a.nl{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);transition:color .25s;}
nav.primary a.nl:hover{color:var(--brass-deep);}
nav.primary a.nl.act{color:var(--brass-deep);border-bottom:1px solid var(--brass);padding-bottom:3px;}
.hd-cta{
  font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  color:#fff;background:var(--brass-deep);padding:11px 20px;border-radius:2px;transition:background .3s,transform .3s;white-space:nowrap;
}
.hd-cta:hover{background:var(--ink);transform:translateY(-1px);}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px;}
.burger span{display:block;width:24px;height:1.6px;background:var(--ink);margin:6px 0;border-radius:2px;}
@media (max-width:1060px){nav.primary{display:none;}.burger{display:block;}}
.mmenu{
  position:fixed;inset:0;z-index:80;background:var(--paper);
  display:flex;flex-direction:column;justify-content:center;padding:0 var(--gutter);
  opacity:0;pointer-events:none;transition:opacity .3s;
}
.mmenu.open{opacity:1;pointer-events:auto;}
.mmenu a{font-family:var(--display);font-size:30px;font-weight:500;line-height:1.16;padding:11px 0;border-bottom:1px solid var(--line);color:var(--ink);}
.mmenu a em{font-style:italic;color:var(--brass-deep);}
.mmenu .m-cta{margin-top:26px;border:0;text-align:center;font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;background:var(--brass-deep);color:#fff;padding:18px;border-radius:2px;}
body.locked{overflow:hidden;}

/* ===================== BUTTONS ===================== */
.btn{
  display:inline-block;font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  color:#fff;background:var(--brass-deep);border:1px solid var(--brass-deep);padding:17px 32px;cursor:pointer;border-radius:2px;
  transition:background .3s,color .3s,border-color .3s,transform .3s;
}
.btn:hover{background:var(--ink);border-color:var(--ink);color:#fff;transform:translateY(-2px);}
.btn.ghost{background:transparent;color:var(--brass-deep);border-color:rgba(138,101,38,.4);}
.btn.ghost:hover{background:transparent;color:var(--ink);border-color:var(--ink);transform:none;}
.textlink{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--brass-deep);border-bottom:1px solid var(--brass);padding-bottom:4px;transition:color .3s,border-color .3s;}
.textlink:hover{color:var(--ink);border-color:var(--ink);}

/* ===================== HERO + GLOBE ===================== */
.hero{
  min-height:100svh;display:flex;align-items:center;padding-top:clamp(104px,12vh,132px);padding-bottom:clamp(88px,11vh,124px);position:relative;overflow:hidden;
  background:
    radial-gradient(900px 540px at 88% 14%,rgba(176,134,63,.12),transparent 60%),
    radial-gradient(680px 460px at 4% 92%,rgba(166,73,47,.06),transparent 55%),
    var(--paper);
}
.hero-grid{display:grid;grid-template-columns:1.04fr .96fr;align-items:center;gap:clamp(24px,4vw,64px);width:100%;}
.hero .kicker{font-family:var(--mono);font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--brass-deep);display:block;}
.hero h1{font-family:var(--display);font-weight:700;font-size:clamp(40px,5.6vw,76px);line-height:1.0;letter-spacing:-.035em;margin-top:24px;}
.hero .sub{margin-top:26px;max-width:46ch;font-size:clamp(16px,1.5vw,18.5px);color:var(--ink-soft);}
.hero .sub strong{color:var(--ink);font-weight:500;}
.hero-actions{margin-top:36px;display:flex;flex-wrap:wrap;gap:16px;align-items:center;}
.proofbar{margin-top:clamp(40px,6vw,56px);display:flex;flex-wrap:wrap;gap:30px 40px;border-top:1px solid var(--line);padding-top:26px;}
.proof .v{font-family:var(--display);font-weight:600;font-size:clamp(26px,3vw,34px);color:var(--ink);line-height:1;display:block;}
.proof .v i{font-style:normal;color:var(--brass-deep);}
.proof .k{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);margin-top:7px;display:block;line-height:1.7;}
.hero-globe{position:relative;display:flex;align-items:center;justify-content:center;align-self:center;transform:translateY(-8px);}
#globe{width:100%;max-width:600px;aspect-ratio:1/1;touch-action:none;cursor:grab;}
#globe:active{cursor:grabbing;}
.globe-cap{position:absolute;bottom:2px;left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);white-space:nowrap;}
@media (max-width:900px){
  .hero{text-align:center;}
  .hero-grid{grid-template-columns:1fr;}
  .hero-globe{order:-1;}
  #globe{max-width:320px;}
  .hero .sub{margin-left:auto;margin-right:auto;}
  .hero-actions,.proofbar{justify-content:center;}
}

/* ===================== PLATFORM STRIP ===================== */
.strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:18px 0;background:var(--paper-2);}
.strip .inner{display:flex;flex-wrap:wrap;align-items:center;gap:14px 34px;justify-content:space-between;}
.strip .lbl{font-family:var(--mono);font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);}
.strip .names{display:flex;flex-wrap:wrap;gap:10px 26px;}
.strip .names span{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);}
.strip .names span.ai{color:var(--brass-deep);}
.strip .inner{margin-bottom:14px;}
.strip .plogo{display:inline-flex;align-items:center;gap:9px;white-space:nowrap;}
.strip .plogo svg{width:21px;height:21px;flex:none;fill:var(--ink);opacity:.72;transition:opacity .35s ease,transform .35s ease;}
.strip .plogo b{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);}
.strip .plogo.ai svg{fill:var(--brass-deep);opacity:.92;}
.strip .plogo.ai b{color:var(--brass-deep);}
.strip .marquee:hover .plogo svg{opacity:.42;}
.strip .marquee .plogo:hover svg{opacity:1;transform:translateY(-2px) scale(1.08);}

/* ===================== SECTIONS ===================== */
section{padding:clamp(76px,9vw,118px) 0;}
section:not(.hero){border-top:1px solid var(--line);}
.light{background:var(--paper-2);}
.sec-head{margin-bottom:clamp(36px,5vw,60px);max-width:840px;}
.sec-head h2{font-family:var(--display);font-weight:700;font-size:clamp(28px,3.6vw,44px);line-height:1.06;margin-top:16px;letter-spacing:-.03em;}
.sec-head .lede{margin-top:16px;font-size:17px;color:var(--ink-soft);max-width:60ch;}

/* ===================== THESIS ===================== */
#thesis{padding:clamp(74px,9vw,116px) 0;}
.thesis-q{font-family:var(--display);font-weight:700;font-size:clamp(28px,4.4vw,52px);line-height:1.22;max-width:26ch;}
.thesis-q em{font-style:italic;color:var(--brass-deep);}
.thesis-tags{margin-top:28px;font-family:var(--mono);font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-faint);display:flex;gap:10px 26px;flex-wrap:wrap;}

/* ===================== ACCORDION ===================== */
.acc{border-top:1px solid var(--line);}
.acc-item{border-bottom:1px solid var(--line);}
.acc-head{width:100%;background:none;border:0;cursor:pointer;text-align:left;color:inherit;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:20px;padding:clamp(22px,3vw,32px) 0;}
.acc-head .t{display:flex;align-items:baseline;gap:16px;flex-wrap:wrap;}
.acc-head .tag{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);}
.acc-head h3{font-family:var(--display);font-weight:700;font-size:clamp(23px,2.8vw,32px);line-height:1.15;color:var(--ink);}
.acc-head .pill{font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:#fff;background:var(--brass-deep);padding:4px 9px;border-radius:2px;}
.acc-head .ind{font-family:var(--mono);font-size:20px;color:var(--brass-deep);transition:transform .35s;line-height:1;}
.acc-item.open .ind{transform:rotate(45deg);}
.acc-body{overflow:hidden;max-height:0;transition:max-height .45s cubic-bezier(.22,.61,.36,1);}
.acc-inner{padding:0 0 clamp(26px,3.4vw,38px);display:grid;grid-template-columns:minmax(0,7fr) minmax(0,5fr);gap:clamp(20px,4vw,64px);}
.acc-inner .outcome{font-size:clamp(16px,1.6vw,18px);max-width:58ch;color:var(--ink);}
.acc-inner .more{margin-top:12px;font-size:14.5px;color:var(--ink-soft);max-width:58ch;}
.acc-inner .more b{font-weight:500;color:var(--brass-deep);}
.inc h4{font-family:var(--mono);font-weight:400;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:12px;}
.chips{display:flex;flex-wrap:wrap;gap:8px;}
.chips span{font-family:var(--mono);font-size:10.5px;letter-spacing:.05em;border:1px solid var(--line);color:var(--ink-soft);padding:7px 12px;border-radius:2px;background:var(--paper-2);}
.spine-note{margin-top:26px;font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);}
.spine-note b{color:var(--brass-deep);font-weight:400;}

/* Expanded service cards — always visible (SEO/GEO-friendly), replaces the old click-to-open accordion */
.svc-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:clamp(16px,2vw,22px);border-top:1px solid var(--line);padding-top:clamp(30px,3.6vw,46px);}
.svc{display:flex;flex-direction:column;background:var(--paper-2);border:1px solid var(--line);border-radius:5px;padding:clamp(24px,2.6vw,34px);transition:border-color .4s ease,box-shadow .5s ease,transform .5s cubic-bezier(.22,.61,.36,1);}
.svc:hover{border-color:var(--brass);box-shadow:0 22px 48px -30px rgba(28,26,23,.5);transform:translateY(-4px);}
.svc .tag{font-family:var(--mono);font-weight:500;font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);}
.svc h3{font-family:var(--display);font-weight:700;font-size:clamp(20px,2.1vw,25px);line-height:1.16;letter-spacing:-.02em;margin-top:11px;color:var(--ink);}
.svc .outcome{margin-top:12px;font-size:15px;line-height:1.62;color:var(--ink-soft);}
.svc .chips{margin-top:16px;}
.svc-link{margin-top:auto;padding-top:20px;display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-weight:500;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--brass-deep);transition:gap .3s ease,color .3s ease;}
.svc:hover .svc-link{gap:12px;color:var(--brass);}
.svc .pill{display:inline-block;margin-top:11px;font-family:var(--mono);font-weight:500;font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:#fff;background:var(--brass-deep);padding:4px 9px;border-radius:2px;}
@media(max-width:720px){.svc-grid{grid-template-columns:1fr;}}

/* ===================== GEO (warm band) ===================== */
#geo{background:var(--paper-3);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.geo-grid{display:grid;grid-template-columns:minmax(0,6fr) minmax(0,6fr);gap:clamp(36px,5.5vw,84px);align-items:center;}
@media (max-width:880px){.geo-grid{grid-template-columns:1fr;}}
.geo-copy h2{font-family:var(--display);font-weight:700;font-size:clamp(30px,4vw,46px);line-height:1.12;margin-top:14px;}
.geo-copy p{margin-top:18px;color:var(--ink-soft);max-width:54ch;}
.geo-copy p strong{color:var(--ink);font-weight:500;}
.geo-demo{border:1px solid rgba(176,134,63,.4);background:var(--paper-2);padding:clamp(22px,3vw,32px);border-radius:4px;box-shadow:0 18px 50px -30px rgba(138,101,38,.5);}
.geo-demo .bar{display:flex;gap:6px;margin-bottom:18px;}
.geo-demo .bar i{width:8px;height:8px;border-radius:50%;background:var(--line);display:block;}
.geo-demo .q{font-family:var(--mono);font-size:12.5px;color:var(--ink-soft);border:1px solid var(--line);padding:12px 14px;margin-bottom:16px;border-radius:3px;}
.geo-demo .q b{color:var(--ink);font-weight:500;}
.geo-demo .a{font-size:14px;color:var(--ink-soft);line-height:1.75;}
.geo-demo .a .hl{color:#fff;background:var(--brass-deep);padding:1px 7px;font-weight:500;border-radius:2px;}

/* The Constellation — faint gold star motif drifting behind every hero */
.solae-stars{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.62;}
.hero > .wrap,.page-hero > .wrap{position:relative;z-index:1;}
/* GEO — brief "AI is answering" caret */
.solae-caret{display:inline-block;width:.55ch;}
.solae-caret::after{content:"▌";color:var(--brass-deep);animation:solae-blink .9s steps(1) infinite;}
@keyframes solae-blink{50%{opacity:0;}}
@media (prefers-reduced-motion:reduce){.solae-caret{display:none;}}
.geo-demo .src{margin-top:16px;font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);}

/* ===================== CARDS (mandates / sectors) ===================== */
.mand-grid,.sector-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px);}
.mand,.sector{background:var(--paper-2);border:1px solid var(--line);padding:clamp(22px,2.6vw,30px);border-radius:4px;transition:border-color .3s,transform .3s,box-shadow .3s;}
.mand:hover,.sector:hover{border-color:var(--brass);transform:translateY(-4px);box-shadow:0 22px 50px -34px rgba(138,101,38,.55);}
.mand .pn,.sector .ic{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-deep);display:block;margin-bottom:14px;}
.mand h3,.sector h3{font-family:var(--display);font-weight:600;font-size:22px;line-height:1.25;color:var(--ink);}
.mand .cat{margin-top:12px;font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);line-height:1.9;}
.sector p{margin-top:8px;font-size:13.8px;color:var(--ink-soft);}
.mand .scope{margin-top:14px;border-top:1px solid var(--line);padding-top:12px;font-size:13.5px;color:var(--ink-soft);}
@media (max-width:880px){.mand-grid,.sector-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.mand-grid,.sector-grid{grid-template-columns:1fr;}}
.nda-line{margin-top:clamp(30px,4vw,42px);font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);max-width:70ch;line-height:2;}
.unity-line{margin-top:clamp(40px,5vw,56px);display:flex;align-items:center;gap:18px;flex-wrap:wrap;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);}
.unity-line b{color:var(--brass-deep);font-weight:500;}

/* ===================== RECORD BAND (Swiss stat block) ===================== */
.record{background:var(--paper-2);padding:clamp(56px,8vw,88px) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.record .lbl{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);display:block;margin-bottom:34px;}
.rec-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(22px,3vw,40px);}
.rec .v{font-family:var(--display);font-weight:700;font-size:clamp(40px,5vw,62px);line-height:.95;letter-spacing:-.03em;color:var(--ink);}
.rec .v i{font-style:normal;color:var(--brass-deep);}
.rec .k{display:block;margin-top:12px;font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);line-height:1.8;}
.record .foot{margin-top:36px;font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);}
@media (max-width:760px){.rec-grid{grid-template-columns:1fr 1fr;row-gap:34px;}}

/* ===================== PROTOCOL / HOW WE WORK ===================== */
.method-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,2.4vw,32px);}
.step{border-top:1px solid var(--line);padding-top:22px;}
.step .n{font-family:var(--mono);font-weight:400;font-size:13px;letter-spacing:.18em;color:var(--brass-deep);display:block;}
.step h3{font-family:var(--display);font-weight:700;font-size:24px;line-height:1.2;margin:12px 0 10px;color:var(--ink);}
.step p{font-size:14.2px;color:var(--ink-soft);}
.step .out{margin-top:14px;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);line-height:1.8;}
.step .out b{color:var(--brass-deep);font-weight:400;}
@media (max-width:980px){.method-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.method-grid{grid-template-columns:1fr;}}

/* ===================== FOUNDER ===================== */
.founder-grid{display:grid;grid-template-columns:minmax(0,5fr) minmax(0,7fr);gap:clamp(32px,5vw,80px);align-items:start;}
@media (max-width:880px){.founder-grid{grid-template-columns:1fr;}}
.f-card{background:var(--paper-3);border:1px solid var(--line);border-left:3px solid var(--brass);padding:clamp(26px,3.4vw,40px);position:sticky;top:110px;border-radius:4px;}
.f-card .mono-line{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);}
.f-card h3{font-family:var(--display);font-weight:600;font-size:30px;margin-top:14px;color:var(--ink);}
.f-card .role{margin-top:6px;font-size:14px;color:var(--ink-soft);}
.f-card ul{list-style:none;margin-top:22px;}
.f-card li{border-top:1px solid var(--line);padding:12px 0;font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--ink-soft);display:flex;justify-content:space-between;gap:14px;}
.f-card li b{color:var(--brass-deep);font-weight:500;white-space:nowrap;text-align:right;}
.founder-copy h2{font-family:var(--display);font-weight:700;font-size:clamp(28px,3.6vw,42px);line-height:1.15;margin-top:14px;}
.founder-copy p{margin-top:18px;color:var(--ink-soft);max-width:60ch;font-size:16.5px;}
.founder-copy p strong{color:var(--ink);font-weight:500;}
.founder-copy .sig{margin-top:26px;font-family:var(--display);font-style:italic;font-weight:500;font-size:24px;color:var(--brass-deep);}

/* ===================== PROPOSAL / FORMS ===================== */
#proposal,#evaluation{background:var(--paper-2);}
.eval-grid{display:grid;grid-template-columns:minmax(0,6fr) minmax(0,6fr);gap:clamp(40px,6vw,88px);align-items:start;}
@media (max-width:880px){.eval-grid{grid-template-columns:1fr;}}
.eval-copy p{color:var(--ink-soft);max-width:54ch;}
.eval-copy p+p{margin-top:16px;}
.eval-copy strong{font-weight:500;color:var(--ink);}
.ledger{display:flex;flex-direction:column;gap:9px;margin:26px 0 8px;}
.ledger-marks{display:flex;gap:7px;}
.seat{width:30px;height:9px;border:1px solid var(--brass);border-radius:2px;}
.seat.held{background:var(--brass);}
.ledger-label{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);}
.ledger-label b{font-weight:500;color:var(--ink);}
.gets{list-style:none;margin:26px 0 0;}
.gets li{border-top:1px solid var(--line);padding:14px 0;display:flex;gap:14px;align-items:baseline;font-size:14.6px;color:var(--ink-soft);}
.gets li::before{content:"—";color:var(--brass-deep);flex:none;}
.gets li b{font-weight:500;color:var(--ink);}
.form-card{border:1px solid var(--line);padding:clamp(24px,3.4vw,40px);background:var(--paper);border-radius:6px;box-shadow:0 24px 60px -40px rgba(138,101,38,.5);}
.form-card .form-title{font-family:var(--mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--brass-deep);}
.form-card .form-sub{font-size:13.5px;color:var(--ink-soft);margin-top:6px;}
.prog{margin:24px 0 28px;}
.prog .track{height:3px;background:var(--line);position:relative;border-radius:3px;overflow:hidden;}
.prog .fill{position:absolute;inset:0 auto 0 0;width:14%;background:var(--brass-deep);transition:width .5s cubic-bezier(.22,.61,.36,1);}
.prog .meta{display:flex;justify-content:space-between;margin-top:10px;font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);}
.prog .meta b{color:var(--brass-deep);font-weight:500;}
.fstep{display:none;}
.fstep.active{display:block;animation:fadeUp .4s cubic-bezier(.22,.61,.36,1);}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
@media (prefers-reduced-motion:reduce){.fstep.active{animation:none;}}
.field{margin-bottom:22px;}
.field label{display:block;font-family:var(--mono);font-weight:500;font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);margin-bottom:9px;}
.field input,.field select,.field textarea{
  width:100%;background:var(--paper-2);border:1px solid var(--line);color:var(--ink);
  font-family:var(--body);font-weight:300;font-size:15px;padding:13px 14px;border-radius:4px;transition:border-color .3s,box-shadow .3s;appearance:none;-webkit-appearance:none;
}
.field textarea{resize:vertical;min-height:96px;line-height:1.6;}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--brass);box-shadow:0 0 0 3px rgba(176,134,63,.14);outline:none;}
.field select{background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238A6526' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;cursor:pointer;padding-right:34px;}
.field .err{display:none;font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--terra);margin-top:8px;text-transform:uppercase;}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:var(--terra);}
.field.invalid .err{display:block;}
.field input[type=file]{width:100%;font-family:var(--mono);font-size:12px;color:var(--ink-soft);padding:11px 12px;border:1px dashed var(--line);border-radius:4px;background:var(--paper-2);cursor:pointer;}
.field input[type=file]::file-selector-button{font-family:var(--mono);font-weight:500;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--paper);background:var(--ink);border:0;padding:9px 14px;border-radius:3px;margin-right:14px;cursor:pointer;transition:background .25s ease;}
.field input[type=file]::file-selector-button:hover{background:var(--brass-deep);}
.field input[type=file]::-webkit-file-upload-button{font-family:var(--mono);font-weight:500;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--paper);background:var(--ink);border:0;padding:9px 14px;border-radius:3px;margin-right:14px;cursor:pointer;}
.fnav{display:flex;gap:12px;margin-top:6px;}
.fnav .btn{flex:1;padding:16px 18px;}
.fnav .btn.back{flex:0 0 auto;background:transparent;color:var(--ink-soft);border-color:var(--line);}
.fnav .btn.back:hover{color:var(--ink);border-color:var(--ink);background:transparent;}
.form-note{margin-top:16px;font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;color:var(--ink-faint);text-transform:uppercase;text-align:center;line-height:1.9;}
.received{display:none;}
.received.show{display:block;animation:fadeUp .5s cubic-bezier(.22,.61,.36,1);}
.received .stamp{font-family:var(--display);font-weight:700;font-size:clamp(30px,3.2vw,40px);line-height:1.12;}
.received .stamp em{font-style:italic;color:var(--brass-deep);font-weight:500;}
.received p{margin-top:16px;color:var(--ink-soft);font-size:14.8px;max-width:46ch;}
.received .ref{margin-top:26px;border-top:1px solid var(--line);padding-top:16px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.received .ref b{font-weight:500;color:var(--brass-deep);}

/* ===================== FAQ ===================== */
.faq{border-top:1px solid var(--line);max-width:860px;}
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{width:100%;background:none;border:0;cursor:pointer;text-align:left;color:inherit;display:flex;justify-content:space-between;align-items:center;gap:18px;padding:22px 0;font-family:var(--display);font-weight:600;font-size:clamp(18px,2vw,22px);line-height:1.3;}
.faq-q .ind{font-family:var(--mono);font-size:16px;color:var(--brass-deep);transition:transform .3s;flex:none;}
.faq-item.open .ind{transform:rotate(45deg);}
.faq-a{overflow:hidden;max-height:0;transition:max-height .4s cubic-bezier(.22,.61,.36,1);}
.faq-a p{padding:0 0 22px;color:var(--ink-soft);font-size:15px;max-width:64ch;}

/* ===================== CLOSING ===================== */
.close-strip{text-align:center;}
.close-strip h2{font-family:var(--display);font-weight:700;font-size:clamp(32px,5vw,62px);line-height:1.12;max-width:20ch;margin:18px auto 0;}
.close-strip h2 em{font-style:italic;font-weight:500;color:var(--brass-deep);}
.close-strip .sub{margin:20px auto 0;max-width:54ch;color:var(--ink-soft);font-size:16.5px;}
.close-strip .btn{margin-top:38px;}
.close-meta{margin-top:34px;display:flex;justify-content:center;gap:16px 38px;flex-wrap:wrap;font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);}

/* ===================== INTERIOR PAGES ===================== */
.page-hero{padding-top:clamp(150px,17vw,210px);padding-bottom:clamp(48px,7vw,84px);background:radial-gradient(900px 420px at 85% -10%,rgba(176,134,63,.12),transparent 60%),var(--paper);}
.crumb{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:22px;}
.crumb a{color:var(--ink-soft);border-bottom:1px solid var(--line);padding-bottom:2px;transition:color .25s;}
.crumb a:hover{color:var(--brass-deep);}
.page-hero h1{font-family:var(--display);font-weight:700;font-size:clamp(36px,5.4vw,66px);line-height:1.08;letter-spacing:-.01em;max-width:22ch;margin-top:16px;}
.page-hero h1 em{font-style:italic;font-weight:500;color:var(--brass-deep);}
.page-hero .sub{margin-top:22px;max-width:58ch;font-size:clamp(16px,1.55vw,18px);color:var(--ink-soft);}
.page-hero .sub strong{color:var(--ink);font-weight:500;}
.prac{border-top:1px solid var(--line);padding:clamp(44px,6vw,68px) 0;}
.prac-grid{display:grid;grid-template-columns:minmax(0,7fr) minmax(0,5fr);gap:clamp(24px,4.5vw,72px);}
@media (max-width:820px){.prac-grid{grid-template-columns:1fr;}}
.prac .tag{font-family:var(--mono);font-weight:500;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);display:block;}
.prac h2{font-family:var(--display);font-weight:700;font-size:clamp(27px,3.4vw,40px);line-height:1.12;margin-top:12px;}
.prac h2 em{font-style:italic;color:var(--brass-deep);}
.prac .outcome{margin-top:16px;font-size:clamp(16px,1.6vw,17.5px);max-width:58ch;color:var(--ink);}
.prac .more{margin-top:12px;font-size:14.6px;color:var(--ink-soft);max-width:58ch;}
.prac .more b{color:var(--brass-deep);font-weight:500;}
.rule-list{list-style:none;margin-top:8px;}
.rule-list li{border-top:1px solid var(--line);padding:13px 0;display:flex;gap:13px;align-items:baseline;font-size:14.4px;color:var(--ink-soft);}
.rule-list li::before{content:"—";color:var(--brass-deep);flex:none;}
.rule-list li b{color:var(--ink);font-weight:500;}
.tl{list-style:none;margin-top:34px;border-left:1px solid var(--line);}
.tl li{position:relative;padding:0 0 30px 28px;}
.tl li::before{content:"";position:absolute;left:-5px;top:7px;width:9px;height:9px;background:var(--brass);border-radius:50%;}
.tl .t-k{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-deep);display:block;}
.tl h3{font-family:var(--display);font-weight:700;font-size:22px;margin:8px 0 6px;color:var(--ink);}
.tl p{font-size:14.4px;color:var(--ink-soft);max-width:56ch;}
.principle{border-top:1px solid var(--line);padding:26px 0;display:grid;grid-template-columns:minmax(0,3fr) minmax(0,9fr);gap:18px 40px;}
@media (max-width:720px){.principle{grid-template-columns:1fr;}}
.principle .pnum{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--brass-deep);}
.principle h3{font-family:var(--display);font-weight:600;font-size:24px;line-height:1.2;color:var(--ink);}
.principle p{margin-top:8px;font-size:15px;color:var(--ink-soft);max-width:60ch;}
.legal h2{font-family:var(--display);font-weight:600;font-size:26px;margin:38px 0 12px;color:var(--ink);}
.legal p,.legal li{font-size:15px;color:var(--ink-soft);max-width:70ch;}
.legal ul{margin:10px 0 0 18px;}

/* ===================== JOURNAL ===================== */
.j-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px);}
@media (max-width:880px){.j-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.j-grid{grid-template-columns:1fr;}}
.note-card{background:var(--paper-2);border:1px solid var(--line);padding:clamp(22px,2.6vw,28px);display:flex;flex-direction:column;gap:12px;transition:border-color .3s,transform .3s,box-shadow .3s;color:var(--ink);border-radius:4px;}
.note-card .nc-img{display:block;margin:calc(-1 * clamp(22px,2.6vw,28px)) calc(-1 * clamp(22px,2.6vw,28px)) 4px;aspect-ratio:16/10;overflow:hidden;border-bottom:1px solid var(--line);border-radius:4px 4px 0 0;}
.note-card .nc-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s cubic-bezier(.22,.61,.36,1);}
a.note-card:hover .nc-img img{transform:scale(1.04);}
a.note-card:hover{border-color:var(--brass);transform:translateY(-4px);box-shadow:0 22px 50px -34px rgba(138,101,38,.55);}
.note-card .nc-meta{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--brass-deep);display:flex;gap:8px 16px;flex-wrap:wrap;}
.note-card h3{font-family:var(--display);font-weight:600;font-size:23px;line-height:1.22;color:var(--ink);}
.note-card p{font-size:14px;color:var(--ink-soft);}
.note-card .read{margin-top:auto;padding-top:10px;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--brass-deep);}
.note-card.lock{border-style:dashed;background:transparent;}
.note-card.lock h3{color:var(--ink-faint);}
.note-card.lock .nc-meta{color:var(--ink-faint);}
.lockpill{font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;background:var(--brass-deep);color:#fff;padding:4px 10px;align-self:flex-start;border-radius:2px;}
.brief-box{border:1px solid var(--line);background:var(--paper-2);padding:clamp(24px,3vw,36px);border-radius:6px;max-width:560px;}

/* Solae Circle — creator / brand toggle */
.circle-switch{display:inline-flex;gap:6px;padding:6px;border:1px solid var(--line);border-radius:50px;background:var(--paper-2);margin-bottom:clamp(40px,5vw,64px);}
.cs-btn{font-family:var(--mono);font-weight:500;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);background:none;border:0;padding:12px 26px;border-radius:50px;cursor:pointer;transition:background .3s ease,color .3s ease;}
.cs-btn.active{background:var(--ink);color:var(--paper);}
.cs-btn:not(.active):hover{color:var(--ink);}
.circle-panel[hidden]{display:none;}

/* ===================== SINGLE POST ===================== */
.post-meta{margin-top:18px;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);display:flex;gap:10px 22px;flex-wrap:wrap;}
.post{max-width:720px;}
.post p,.post li{font-size:17px;color:var(--ink-soft);line-height:1.8;margin-top:18px;}
.post p b,.post li b{color:var(--ink);font-weight:600;}

/* ===================== ENHANCEMENTS (enhance.js) ===================== */
/* Scroll progress — thin brass bar pinned to the top of the viewport. */
.scroll-progress{
  position:fixed;top:0;left:0;z-index:200;
  width:0;height:2px;
  background:linear-gradient(90deg,var(--brass-deep),var(--brass));
  pointer-events:none;will-change:width;
}
/* Image reveal — soft rise + fade once `.in` is added. */
.reveal-img{
  opacity:0;transform:translateY(18px);
  transition:opacity 1s cubic-bezier(.22,.61,.36,1),transform 1s cubic-bezier(.22,.61,.36,1);
}
.reveal-img.in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){
  .reveal-img{opacity:1;transform:none;transition:none;}
}
/* Tilt — establish a stacking/transform context without forcing it. */
[data-tilt]{transform-style:preserve-3d;}
.post h2{font-family:var(--display);font-weight:600;font-size:clamp(24px,3vw,32px);margin-top:40px;color:var(--ink);}
.post .pull{font-family:var(--display);font-style:italic;font-weight:500;font-size:clamp(22px,2.6vw,28px);line-height:1.4;color:var(--brass-deep);border-left:2px solid var(--brass);padding-left:22px;margin:30px 0;}
.post .rule-list{margin-top:18px;}
.post .kt{margin-top:34px;background:var(--paper-3);border:1px solid var(--line);border-radius:6px;padding:clamp(20px,3vw,28px);}
.post .kt h4{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-deep);margin-bottom:8px;}
.post-foot{margin-top:40px;border-top:1px solid var(--line);padding-top:22px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;align-items:center;}
.post-foot .sig{font-family:var(--display);font-style:italic;font-weight:500;font-size:20px;color:var(--brass-deep);}

/* ===================== FOOTER ===================== */
footer{border-top:1px solid var(--line);padding:clamp(46px,6vw,66px) 0 40px;background:#16140F;color:var(--od);}
.ft-grid{display:grid;grid-template-columns:minmax(0,3fr) repeat(4,minmax(0,1.8fr));gap:clamp(24px,3vw,44px);}
.ft-brand .wordmark{color:var(--od);}
.ft-brand .wordmark span{color:var(--brass);}
.ft-brand p{margin-top:14px;font-size:13.5px;color:var(--od-soft);max-width:34ch;}
.ft-social{display:flex;gap:12px;margin-top:22px;}
.ft-social a{display:inline-flex;width:36px;height:36px;align-items:center;justify-content:center;border:1px solid rgba(244,236,221,.16);border-radius:50%;transition:border-color .3s ease,transform .3s ease,background .3s ease;}
.ft-social a:hover{border-color:var(--brass);background:rgba(244,236,221,.05);transform:translateY(-3px);}
.ft-social svg{width:15px;height:15px;fill:var(--od-soft);transition:fill .3s ease;}
.ft-social a:hover svg{fill:var(--brass);}
.ft h5{font-family:var(--mono);font-weight:400;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--od-faint);margin-bottom:14px;}
.ft ul{list-style:none;}
.ft li{margin-bottom:9px;}
.ft li a{font-size:13.5px;color:var(--od-soft);transition:color .25s;}
.ft li a:hover{color:var(--brass);}
.ft-bottom{margin-top:clamp(34px,5vw,52px);padding-top:20px;border-top:1px solid rgba(244,236,221,.12);display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--od-faint);}
.ft-legal a{color:var(--od-soft);transition:color .25s;}
.ft-legal a:hover{color:var(--brass);}
/* cookie consent bar */
.cookie-bar{position:fixed;left:0;right:0;bottom:0;z-index:120;background:#16140F;padding:15px clamp(20px,5vw,40px);display:flex;align-items:center;justify-content:space-between;gap:14px 28px;flex-wrap:wrap;box-shadow:0 -8px 30px -20px rgba(0,0,0,.7);}
.cookie-bar[hidden]{display:none;}
.cookie-bar p{font-size:13px;line-height:1.55;max-width:74ch;color:var(--od-soft);}
.cookie-bar p a{color:var(--brass);border-bottom:1px solid rgba(154,122,60,.5);}
.cookie-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap;}
.cookie-actions button{font-family:var(--mono);font-weight:500;font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:11px 18px;border-radius:3px;cursor:pointer;border:1px solid transparent;transition:background .25s ease,border-color .25s ease,color .25s ease;}
.cookie-actions button[data-cookie=essential]{background:none;border-color:rgba(244,236,221,.28);color:var(--od);}
.cookie-actions button[data-cookie=essential]:hover{border-color:var(--brass);color:var(--brass);}
.cookie-actions button[data-cookie=all]{background:var(--brass);border-color:var(--brass);color:#16140F;}
.cookie-actions button[data-cookie=all]:hover{background:var(--od);border-color:var(--od);}
@media (max-width:880px){.ft-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.ft-grid{grid-template-columns:1fr;}}
