/* ==========================================================================
   Inverse Collective — "The Ledger" design system
   Editorial & restrained: warm paper, ink, serif display, monospace labels.
   Shared across every page. Single source of truth.
   ========================================================================== */

:root{
  --paper:#f4f1e9;
  --paper-2:#efebe0;
  --ink:#17150f;
  --ink-soft:#4a463c;
  --ink-faint:#6f6a54;       /* AA-contrast muted tone (~4.8:1 on paper) */
  --line:#d8d2c2;
  --accent:#5b3a2e;          /* oxblood-brown */
  --accent-2:#2f4733;        /* deep evergreen */
  --error:#a23b2d;
  --serif:"Newsreader",Georgia,serif;
  --sans:"Hanken Grotesk",system-ui,-apple-system,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  min-height:100vh;
  display:flex;
  flex-direction:column;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--accent);color:var(--paper)}

/* keyboard focus visibility (a11y) */
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}
.field input:focus-visible,.field select:focus-visible,.field textarea:focus-visible{outline:none}
body.menu-open{overflow:hidden}

.wrap{max-width:1240px;margin:0 auto;padding:0 40px;width:100%}
.wrap-narrow{max-width:840px;margin:0 auto;padding:0 40px;width:100%}
.mono{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint)}
.serif{font-family:var(--serif)}
main{flex:1 0 auto}

/* ---------- brand mark ---------- */
.brand{display:flex;align-items:center;gap:12px;font-family:var(--serif);font-size:21px;letter-spacing:-.01em;color:var(--ink)}
.brand .mark{width:26px;height:26px;position:relative;flex:0 0 auto}
.brand .mark::before,.brand .mark::after{content:"";position:absolute;inset:0;border:1.5px solid var(--ink);border-radius:50%}
.brand .mark::after{transform:scale(.5);background:var(--ink)}

/* ---------- nav ---------- */
nav{position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 40px;
  transition:background .4s ease,border-color .4s ease,padding .4s ease;
  border-bottom:1px solid transparent}
nav.scrolled{background:rgba(244,241,233,.82);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line);padding:14px 40px}
.navlinks{display:flex;gap:34px;align-items:center}
.navlinks a{font-size:14px;color:var(--ink-soft);position:relative;transition:color .25s}
.navlinks a::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:1px;background:var(--ink);transition:width .3s}
.navlinks a:hover{color:var(--ink)}
.navlinks a:hover::after{width:100%}
.navlinks a.current{color:var(--ink)}
/* keep the 6-item nav comfortable on mid-size laptops */
@media(min-width:861px) and (max-width:1080px){.navlinks{gap:22px}.navlinks a{font-size:13px}}
.navlinks a.current::after{width:100%;background:var(--accent)}
.navcta{border:1px solid var(--ink);padding:9px 18px;border-radius:100px;font-size:13px!important;color:var(--ink)!important;white-space:nowrap}
.navcta::after{display:none!important}
.navcta:hover{background:var(--ink);color:var(--paper)!important}
.navtoggle{display:none;background:none;border:none;cursor:pointer;width:30px;height:30px;position:relative}
.navtoggle span{position:absolute;left:4px;right:4px;height:1.5px;background:var(--ink);transition:.3s}
.navtoggle span:nth-child(1){top:9px}
.navtoggle span:nth-child(2){bottom:9px}
.navtoggle.open span:nth-child(1){top:14px;transform:rotate(45deg)}
.navtoggle.open span:nth-child(2){bottom:14px;transform:rotate(-45deg)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 26px;border-radius:100px;font-size:15px;font-weight:500;white-space:nowrap;cursor:pointer;border:none;font-family:var(--sans);transition:transform .25s ease,background .25s,box-shadow .25s,color .25s}
.btn.primary{background:var(--ink);color:var(--paper)}
.btn.primary:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(23,21,15,.22)}
.btn.ghost{border:1px solid var(--ink);color:var(--ink);background:transparent}
.btn.ghost:hover{background:var(--ink);color:var(--paper)}
.btn .arr{transition:transform .25s}
.btn:hover .arr{transform:translateX(4px)}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}
.btn.block{width:100%;justify-content:center}

/* ---------- hero (home) ---------- */
header.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding-top:90px;overflow:hidden}
#growth{position:absolute;inset:0;width:100%;height:100%;opacity:.9}
.hero-grad{position:absolute;inset:0;background:linear-gradient(180deg,var(--paper) 0%,transparent 22%,transparent 70%,var(--paper) 100%);pointer-events:none}
.hero-inner{position:relative;z-index:2;width:100%}
.eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:34px}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--accent-2);box-shadow:0 0 0 4px rgba(47,71,51,.14);flex:0 0 auto}
h1.hero{font-family:var(--serif);font-weight:300;font-size:clamp(46px,8vw,108px);line-height:.98;letter-spacing:-.025em;max-width:16ch}
h1.hero em{font-style:italic;color:var(--accent)}
h1.hero .l{display:block;opacity:0;transform:translateY(28px);animation:rise 1s forwards}
h1.hero .l:nth-child(1){animation-delay:.32s}
h1.hero .l:nth-child(2){animation-delay:.46s}
h1.hero .l:nth-child(3){animation-delay:.6s}
.hero-sub{margin-top:38px;max-width:46ch;font-size:19px;color:var(--ink-soft)}
.hero-cta{margin-top:42px;display:flex;gap:16px;flex-wrap:wrap}
.anim-rise{opacity:0;animation:rise 1s forwards}
.anim-rise.d1{animation-delay:.2s}.anim-rise.d2{animation-delay:.8s}.anim-rise.d3{animation-delay:.95s}
.scrollcue{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:8px;opacity:0;animation:fade 1s 1.4s forwards}
.scrollcue .bar{width:1px;height:46px;background:linear-gradient(var(--ink-faint),transparent);position:relative;overflow:hidden}
.scrollcue .bar::after{content:"";position:absolute;top:-46px;left:0;width:1px;height:46px;background:var(--ink);animation:drop 2.2s infinite}

@keyframes rise{to{opacity:1;transform:translateY(0)}}
@keyframes fade{to{opacity:1}}
@keyframes drop{0%{top:-46px}60%,100%{top:46px}}

/* ---------- inner-page hero ---------- */
.phead{padding:170px 0 70px;border-bottom:1px solid var(--line)}
.phead .eyebrow{margin-bottom:28px}
.phead h1{font-family:var(--serif);font-weight:300;font-size:clamp(44px,7vw,94px);line-height:.98;letter-spacing:-.025em;max-width:15ch}
.phead h1 em{font-style:italic;color:var(--accent)}
.phead .lead{margin-top:30px;max-width:54ch;font-size:20px;color:var(--ink-soft)}

/* ---------- section scaffolding ---------- */
section{position:relative;padding:110px 0}
.sec-head{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:end;margin-bottom:70px}
.sec-head .eyebrow{margin-bottom:18px}
.sec-head h2{font-family:var(--serif);font-weight:300;font-size:clamp(34px,4.6vw,60px);line-height:1.02;letter-spacing:-.02em}
.sec-head h2 em{font-style:italic;color:var(--accent)}
.sec-head p{color:var(--ink-soft);max-width:42ch;font-size:17px}
.sec-head.single{grid-template-columns:1fr;max-width:42ch}

/* ---------- reveal ----------
   Progressive enhancement: content is fully visible by default. Only when JS
   is active (html.js) do we hide-then-reveal on scroll, so a JS failure or a
   non-observing browser never leaves content invisible. */
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
html.js .reveal{opacity:0;transform:translateY(34px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
html.js .reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  html.js .reveal{opacity:1;transform:none;transition:none}
  h1.hero .l,.anim-rise,.scrollcue{opacity:1;animation:none}
  html{scroll-behavior:auto}
}

/* ---------- model (numbered ledger rows) ---------- */
.model{border-top:1px solid var(--line)}
.step{display:grid;grid-template-columns:90px 1fr 1.1fr;gap:40px;align-items:start;
  padding:42px 0;border-bottom:1px solid var(--line);position:relative;transition:background .4s}
.step:hover{background:linear-gradient(90deg,rgba(91,58,46,.04),transparent 60%)}
.step .idx{font-family:var(--serif);font-size:30px;color:var(--ink-faint);font-style:italic}
.step h3{font-family:var(--serif);font-weight:400;font-size:30px;letter-spacing:-.01em;line-height:1.05}
.step p{color:var(--ink-soft);font-size:16.5px;max-width:44ch}

/* ---------- criteria grid ---------- */
.crit-section{background:var(--paper-2)}
.crit-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:1px solid var(--line);border-radius:6px;overflow:hidden;background:var(--paper)}
.cell{padding:46px 44px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);position:relative;transition:background .3s}
.cell:nth-child(2n){border-right:none}
.crit-grid .cell:nth-last-child(-n+2){border-bottom:none}
.cell:hover{background:var(--paper-2)}
.cell .num{font-family:var(--mono);font-size:11px;color:var(--accent);letter-spacing:.15em}
.cell h4{font-family:var(--serif);font-weight:400;font-size:25px;margin:18px 0 12px;letter-spacing:-.01em}
.cell p{color:var(--ink-soft);font-size:16px;max-width:38ch}

/* ---------- featured ventures ---------- */
.feat-row{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:center}
.feat-row + .feat-row{margin-top:110px;padding-top:110px;border-top:1px solid var(--line)}
.feat-row.flip .feat-copy{order:2}
.feat-row.flip .feat-media{order:1}
/* browser-chrome framed website screenshot */
.site-frame{position:relative;border-radius:10px;overflow:hidden;border:1px solid var(--line);background:#fff;box-shadow:0 30px 60px -38px rgba(23,21,15,.5);transition:transform .4s ease,box-shadow .4s ease}
.site-frame:hover{transform:translateY(-4px);box-shadow:0 40px 70px -38px rgba(23,21,15,.55)}
.site-frame .bar{display:flex;align-items:center;gap:7px;padding:11px 14px;background:var(--paper-2);border-bottom:1px solid var(--line)}
.site-frame .bar i{width:10px;height:10px;border-radius:50%;background:var(--line);flex:0 0 auto}
.site-frame .bar .url{margin-left:12px;font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--ink-faint);background:var(--paper);border:1px solid var(--line);border-radius:100px;padding:4px 14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.site-frame .shot{display:block;width:100%;height:auto;aspect-ratio:1280/820;object-fit:cover;object-position:top}
/* legacy single featured (kept for reference) */
.feat-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.feat-copy .tag{display:inline-flex;align-items:center;gap:9px;border:1px solid var(--accent-2);color:var(--accent-2);padding:6px 14px;border-radius:100px;font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase}
.feat-copy h3{font-family:var(--serif);font-weight:300;font-size:clamp(40px,5.5vw,68px);line-height:1;letter-spacing:-.02em;margin:24px 0 20px}
.feat-copy .lead{font-size:20px;font-family:var(--serif);font-style:italic;color:var(--accent);margin-bottom:18px;max-width:30ch}
.feat-copy p{color:var(--ink-soft);max-width:46ch;margin-bottom:14px}
.feat-link{display:inline-flex;align-items:center;gap:10px;margin-top:18px;font-weight:500;border-bottom:1px solid var(--ink);padding-bottom:3px}
.feat-link .arr{transition:transform .25s}
.feat-link:hover .arr{transform:translateX(4px)}
.feat-vis{position:relative;aspect-ratio:4/5;border-radius:8px;overflow:hidden;border:1px solid var(--line);background:var(--paper-2)}
.feat-vis img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(.92)}
.feat-vis::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(23,21,15,.45) 0%,transparent 26%,transparent 60%,rgba(23,21,15,.42));pointer-events:none}
.wave{position:absolute;left:0;right:0;bottom:0;height:46%;display:flex;align-items:flex-end;justify-content:center;gap:5px;padding:0 28px 34px;z-index:2}
.wave span{flex:1;max-width:7px;background:var(--paper);border-radius:4px;opacity:.8;animation:vu 1.4s ease-in-out infinite}
@keyframes vu{0%,100%{height:14%}50%{height:80%}}
.vstatus{position:absolute;top:22px;left:24px;z-index:2;font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--paper);display:flex;align-items:center;gap:8px;text-shadow:0 1px 4px rgba(0,0,0,.4)}
.vstatus .pulse{width:7px;height:7px;border-radius:50%;background:#7fd6a0;animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:.3}50%{opacity:1}}

/* ---------- closing CTA ---------- */
.closing{text-align:center;padding:150px 0}
.closing h2{font-family:var(--serif);font-weight:300;font-size:clamp(40px,7vw,92px);line-height:.98;letter-spacing:-.025em;max-width:18ch;margin:0 auto}
.closing h2 em{font-style:italic;color:var(--accent)}
.closing .hero-cta{justify-content:center;margin-top:40px}

/* ---------- thesis (about) ---------- */
.thesis{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:start}
.thesis .label{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.thesis .big{font-family:var(--serif);font-weight:300;font-size:clamp(26px,2.8vw,38px);line-height:1.28;letter-spacing:-.01em}
.thesis .big em{font-style:italic;color:var(--accent)}
.pullquote{margin-top:34px;padding-top:30px;border-top:1px solid var(--line);font-family:var(--serif);font-style:italic;font-size:22px;color:var(--ink-soft);max-width:44ch}

/* ---------- principles (about) ---------- */
.principles{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.plist{border-top:1px solid var(--line)}
.prow{display:grid;grid-template-columns:80px 1fr 1.2fr;gap:40px;align-items:baseline;padding:38px 0;border-bottom:1px solid var(--line);transition:.3s}
.prow:hover{background:linear-gradient(90deg,rgba(91,58,46,.05),transparent 55%)}
.prow .pn{font-family:var(--serif);font-style:italic;font-size:24px;color:var(--ink-faint)}
.prow h3{font-family:var(--serif);font-weight:400;font-size:28px;letter-spacing:-.01em;line-height:1.05}
.prow .vs{display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-top:8px}
.prow p{color:var(--ink-soft);font-size:16.5px;max-width:46ch}

/* ---------- partner cards (about) ---------- */
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pcard{border:1px solid var(--line);border-radius:8px;padding:34px 30px 30px;background:var(--paper);display:flex;flex-direction:column;min-height:300px;transition:.3s}
.pcard:hover{transform:translateY(-4px);box-shadow:0 18px 40px -24px rgba(23,21,15,.4)}
.pcard .ic{width:42px;height:42px;border-radius:50%;border:1.5px solid var(--ink);position:relative;margin-bottom:auto}
.pcard.b .ic::after{content:"";position:absolute;inset:0;margin:auto;width:16px;height:16px;border-radius:50%;background:var(--accent)}
.pcard.a .ic::after{content:"";position:absolute;inset:7px;border:1.5px solid var(--ink);border-radius:50%}
.pcard.c .ic{border-radius:6px}
.pcard.c .ic::after{content:"";position:absolute;inset:0;margin:auto;width:16px;height:2px;background:var(--ink);box-shadow:0 -6px 0 var(--ink),0 6px 0 var(--ink)}
.pcard h3{font-family:var(--serif);font-weight:400;font-size:26px;margin:26px 0 12px;letter-spacing:-.01em}
.pcard p{color:var(--ink-soft);font-size:15.5px;margin-bottom:20px}
.pcard a{display:inline-flex;align-items:center;gap:9px;font-weight:500;font-size:14.5px;border-bottom:1px solid var(--ink);padding-bottom:3px;align-self:flex-start}
.pcard a .arr{transition:transform .25s}.pcard a:hover .arr{transform:translateX(4px)}

/* ---------- pillars (approach) ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pillar{border:1px solid var(--line);border-radius:8px;padding:38px 34px;background:var(--paper);transition:.3s;position:relative;overflow:hidden}
.pillar:hover{transform:translateY(-4px);box-shadow:0 18px 40px -24px rgba(23,21,15,.4)}
.pillar .pi{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--ink-faint);margin-bottom:18px}
.pillar h3{font-family:var(--serif);font-weight:400;font-size:27px;margin-bottom:14px;letter-spacing:-.01em}
.pillar p{color:var(--ink-soft);font-size:16px}

/* ---------- playbook image cards ---------- */
.pbgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pbcard{border:1px solid var(--line);border-radius:8px;overflow:hidden;background:var(--paper);display:flex;flex-direction:column;transition:.3s}
.pbcard:hover{transform:translateY(-4px);box-shadow:0 18px 40px -24px rgba(23,21,15,.4)}
.pbcard .img{height:170px;background-size:cover;background-position:center;filter:grayscale(1) sepia(.18);transition:filter .5s}
.pbcard:hover .img{filter:grayscale(0) sepia(0)}
.pbcard .body{padding:28px 28px 30px}
.pbcard .kicker{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.pbcard h3{font-family:var(--serif);font-weight:400;font-size:24px;margin:12px 0 12px;letter-spacing:-.01em}
.pbcard p{color:var(--ink-soft);font-size:15.5px}

/* ---------- founder bio ---------- */
.founder{display:grid;grid-template-columns:.8fr 1.2fr;gap:0;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--paper)}
.founder .photo{min-height:380px;background-size:cover;background-position:center top;filter:grayscale(1) sepia(.12)}
.founder .bio{padding:48px 50px;display:flex;flex-direction:column;justify-content:center}
.founder .bio h3{font-family:var(--serif);font-weight:400;font-size:34px;letter-spacing:-.01em}
.founder .bio .role{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin:8px 0 24px}
.founder .bio p{color:var(--ink-soft);margin-bottom:16px;max-width:52ch}
.founder .bio .social{display:flex;gap:12px;margin-top:14px}
.founder .bio .social a{width:40px;height:40px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;transition:.25s;color:var(--ink-soft)}
.founder .bio .social a:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* ---------- forms ---------- */
.layout{display:grid;grid-template-columns:.82fr 1.18fr;gap:70px;align-items:start;padding:60px 0 120px}
.rail{position:sticky;top:110px}
.rail .eyebrow{margin-bottom:18px}
.rail h2{font-family:var(--serif);font-weight:300;font-size:34px;line-height:1.05;letter-spacing:-.015em;margin-bottom:26px}
.rail h2 em{font-style:italic;color:var(--accent)}
.raillist{border-top:1px solid var(--line);list-style:none}
.raillist li{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--line);align-items:baseline}
.raillist li .n{font-family:var(--mono);font-size:11px;color:var(--accent);letter-spacing:.1em;flex:0 0 auto}
.raillist li b{font-family:var(--serif);font-weight:400;font-size:18px}
.raillist li span{display:block;color:var(--ink-soft);font-size:14px;margin-top:3px}

.formcard{border:1px solid var(--line);border-radius:12px;background:var(--paper);overflow:hidden;box-shadow:0 30px 60px -40px rgba(23,21,15,.3)}
.formcard .formhead{padding:34px 42px 0}
.formcard .formhead h2{font-family:var(--serif);font-weight:400;font-size:28px;letter-spacing:-.01em}
.formcard .formhead p{color:var(--ink-soft);font-size:15px;margin-top:6px}
.formbody{padding:30px 42px 40px}
.field{margin-bottom:22px}
.field label{display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:9px}
.field .opt{color:var(--ink-faint);text-transform:none;letter-spacing:0}
.field .req{color:var(--accent)}
.field .help{font-size:12.5px;color:var(--ink-faint);margin:-4px 0 9px}
.field input,.field select,.field textarea{width:100%;background:var(--paper-2);border:1px solid var(--line);border-radius:7px;padding:13px 15px;font-family:var(--sans);font-size:16px;color:var(--ink);transition:border-color .2s,box-shadow .2s}
.field textarea{resize:vertical;min-height:104px;line-height:1.5}
.field select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238a8473' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 15px center;padding-right:38px}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-faint)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(91,58,46,.12)}
.field input:invalid:not(:placeholder-shown),.field textarea:invalid:not(:placeholder-shown){border-color:var(--error)}
.two{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.formfoot{display:flex;justify-content:flex-end;align-items:center;gap:16px;padding:24px 42px;border-top:1px solid var(--line);background:var(--paper-2)}

/* ---------- contact info column ---------- */
.contact-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:64px;align-items:start;padding:70px 0 120px}
.cinfo h3{font-family:var(--serif);font-weight:400;font-size:22px;margin-bottom:12px}
.cinfo .block{margin-bottom:38px}
.cinfo p{color:var(--ink-soft);line-height:1.7}
.cinfo a.email{color:var(--accent);border-bottom:1px solid var(--line);transition:.2s}
.cinfo a.email:hover{border-color:var(--accent)}
.clink{display:flex;gap:14px;align-items:center;padding:16px 18px;border:1px solid var(--line);border-radius:9px;margin-bottom:12px;transition:.25s;background:var(--paper)}
.clink:hover{border-color:var(--ink-faint);transform:translateX(3px)}
.clink .cmk{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);flex:0 0 auto;position:relative}
.clink .cmk::after{content:"";position:absolute;inset:0;margin:auto;width:12px;height:12px;border-radius:50%;background:var(--accent)}
.clink b{font-weight:500;display:block;font-size:15px}
.clink span{font-size:13px;color:var(--ink-faint)}

/* ---------- prose (legal / blog) ---------- */
.prose{max-width:760px}
.prose h2,.prose h3{font-family:var(--serif);font-weight:400;letter-spacing:-.01em;color:var(--ink);margin:42px 0 14px}
.prose h2{font-size:30px}
.prose h3{font-size:24px}
.prose h2:first-child,.prose h3:first-child{margin-top:0}
.prose p{color:var(--ink-soft);margin-bottom:18px;line-height:1.75}
.prose ul,.prose ol{color:var(--ink-soft);margin:0 0 18px 1.2em;line-height:1.75}
.prose li{margin-bottom:8px}
.prose strong{color:var(--ink);font-weight:600}
.prose a{color:var(--accent);border-bottom:1px solid var(--line);transition:.2s}
.prose a:hover{border-color:var(--accent)}
.prose blockquote{border-left:2px solid var(--accent);padding-left:22px;margin:24px 0;font-family:var(--serif);font-style:italic;font-size:20px;color:var(--ink-soft)}
.prose hr{border:none;border-top:1px solid var(--line);margin:40px 0}

/* ---------- footer ---------- */
footer.site{border-top:1px solid var(--line);padding:54px 0 60px;background:var(--paper-2);flex-shrink:0}
.foot-grid{display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap}
.foot-grid .links{display:flex;gap:26px}
.foot-grid .links a{color:var(--ink-soft);font-size:14px;transition:color .2s}
.foot-grid .links a:hover{color:var(--ink)}

/* ---------- blog index (Journal) ---------- */
.postlist{border-top:1px solid var(--line);margin-top:8px}
.postlist .post{display:grid;grid-template-columns:170px 1fr;gap:32px;padding:36px 0;border-bottom:1px solid var(--line);transition:background .3s;align-items:start}
.postlist .post:hover{background:linear-gradient(90deg,rgba(91,58,46,.04),transparent 60%)}
.postlist .post .pmeta{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);padding-top:7px;line-height:1.7}
.postlist .post h3{font-family:var(--serif);font-weight:400;font-size:27px;letter-spacing:-.01em;line-height:1.1;margin-bottom:10px}
.postlist .post p{color:var(--ink-soft);font-size:16px;max-width:62ch}
.postlist .post .readmore{display:inline-flex;align-items:center;gap:8px;margin-top:14px;font-size:14px;font-weight:500;color:var(--accent)}
.postlist .post .readmore .arr{transition:transform .25s}
.postlist .post:hover .readmore .arr{transform:translateX(4px)}
@media(max-width:860px){.postlist .post{grid-template-columns:1fr;gap:10px;padding:28px 0}}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .layout{grid-template-columns:1fr;gap:40px}
  .rail{position:static}
  .founder{grid-template-columns:1fr}
  .founder .photo{min-height:300px}
  .contact-grid{grid-template-columns:1fr;gap:40px}
}
@media(max-width:860px){
  .navlinks{position:fixed;top:0;right:0;bottom:0;width:min(78vw,320px);flex-direction:column;align-items:flex-start;justify-content:center;gap:26px;background:var(--paper);border-left:1px solid var(--line);padding:40px;transform:translateX(100%);transition:transform .35s ease;box-shadow:-20px 0 60px -30px rgba(23,21,15,.5)}
  .navlinks.open{transform:translateX(0)}
  .navlinks a{font-size:18px}
  .navtoggle{display:block;z-index:60}
  nav{padding:18px 24px}
  nav.scrolled{padding:14px 24px}
  .wrap,.wrap-narrow{padding:0 24px}
  .sec-head{grid-template-columns:1fr;gap:18px}
  .step{grid-template-columns:50px 1fr;gap:14px 20px}
  .step p{grid-column:2}
  .crit-grid{grid-template-columns:1fr}
  .cell{border-right:none!important}
  .feat-grid{grid-template-columns:1fr;gap:36px}
  .feat-row{grid-template-columns:1fr;gap:32px}
  .feat-row + .feat-row{margin-top:64px;padding-top:64px}
  .feat-row.flip .feat-copy{order:0}
  .feat-row.flip .feat-media{order:0}
  .thesis{grid-template-columns:1fr;gap:28px}
  .prow{grid-template-columns:46px 1fr;gap:10px 18px}
  .prow p{grid-column:1/-1}
  .pgrid,.pillars,.pbgrid{grid-template-columns:1fr}
  .two{grid-template-columns:1fr}
  .formbody,.formfoot,.formcard .formhead{padding-left:24px;padding-right:24px}
  section{padding:80px 0}
  .phead{padding:140px 0 56px}
  .closing{padding:100px 0}
}
