/* ============================================================================
   StoneVane — shared chrome for the inner pages.
   Same design system as the home engine (index.html): tokens, header/footer,
   halftone + grain + drafting-ground texture, line motifs, reveal-on-scroll.
   The home page keeps its self-contained 3D experience; these pages share this.
   ============================================================================ */
:root{
  /* warm rose-gold / champagne palette over a deep espresso base (onyx-derived) */
  --g0:#0b0a09; --g1:#13110f; --g2:#1c1916;
  --paper:#f1e9dd; --paper-soft:#d1bfa7; --dim:#8e8e90; --faint:#5f5d59;
  --line:rgba(209,191,167,0.13); --line-soft:rgba(209,191,167,0.06);
  --steel:#bd8c7d; --ice:#e7d6bd;
  --mono:"IBM Plex Mono",ui-monospace,Menlo,Consolas,monospace;
  --sans:"Inter Tight",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --serif:"Newsreader",Georgia,"Times New Roman",serif;
  --ease:cubic-bezier(.16,.84,.3,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%;scroll-padding-top:88px}
body{min-height:100%;background:var(--g1);color:var(--paper);font-family:var(--sans);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;
  -webkit-tap-highlight-color:rgba(189,140,125,.16)}
::selection{background:rgba(189,140,125,.22)}
a{color:inherit}

/* ---- fixed texture stack (matches home: drafting ground + halftone + grain) ---- */
.ground{position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(120vmax 90vmax at 78% -6%, rgba(189,140,125,0.06), transparent 55%),
    linear-gradient(180deg, var(--g1), var(--g0))}
.halftone{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.22;mix-blend-mode:soft-light;
  background-image:radial-gradient(rgba(231,214,189,.9) 1px, transparent 1.7px);background-size:5px 5px}
.halftone.b{opacity:.12;background-image:radial-gradient(rgba(189,140,125,.7) 1.2px, transparent 2.3px);background-size:10px 10px}
.grain{position:fixed;inset:-40%;z-index:2;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 1.1s steps(2) infinite}
@keyframes grain{0%{transform:translate(0,0)}33%{transform:translate(-2%,1.5%)}66%{transform:translate(1.5%,-1.5%)}100%{transform:translate(-1%,1%)}}
.frame{position:fixed;inset:14px;z-index:3;pointer-events:none}
.frame i{position:absolute;width:13px;height:13px;border:1px solid var(--line)}
.frame .c1{top:0;left:0;border-right:0;border-bottom:0}
.frame .c2{top:0;right:0;border-left:0;border-bottom:0}
.frame .c3{bottom:0;left:0;border-right:0;border-top:0}
.frame .c4{bottom:0;right:0;border-left:0;border-top:0}

/* ---------- top bar ---------- */
header{position:fixed;top:0;left:0;right:0;z-index:40;display:flex;align-items:center;justify-content:space-between;
  padding:22px clamp(20px,3.6vw,52px);
  background:linear-gradient(to bottom, rgba(11,10,9,.88) 0%, rgba(11,10,9,.55) 52%, rgba(11,10,9,0) 100%);backdrop-filter:blur(3px)}
.wm{font-size:19px;line-height:1;white-space:nowrap;text-decoration:none;display:inline-flex;align-items:center;gap:9px}
.wm .wmlogo{height:1.5em;width:auto;flex:none}
.wm .wmtype{height:1.05em;width:auto;flex:none}
nav{display:flex;align-items:center;gap:clamp(16px,2.2vw,34px)}
nav a{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:#cdc7bd;text-decoration:none;transition:color .3s;text-shadow:0 1px 12px rgba(8,7,6,.65)}
nav a:hover{color:var(--paper)}
nav a[aria-current="page"]{color:var(--paper)}
.talk{border:1px solid var(--line);border-radius:2px;padding:8px 16px;color:var(--paper) !important;
  font-family:var(--serif) !important;font-style:italic;font-size:13px !important;letter-spacing:0 !important;text-transform:none !important;transition:border-color .3s,background .3s}
.talk:hover{border-color:var(--steel);background:rgba(189,140,125,.06)}
@media(max-width:880px){nav a.navlink{display:none}}

/* ---------- mobile menu (hamburger + full overlay) — built by site.js, present on every page ---------- */
.menu-btn{display:none;width:44px;height:44px;margin:-10px -10px -10px 0;padding:0;border:0;background:none;cursor:pointer;
  flex-direction:column;align-items:center;justify-content:center;gap:5px;-webkit-tap-highlight-color:transparent}
.menu-btn span{display:block;width:23px;height:1.5px;background:var(--paper);border-radius:2px;
  transition:transform .32s var(--ease),opacity .22s}
body.menu-open .menu-btn span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
body.menu-open .menu-btn span:nth-child(2){opacity:0}
body.menu-open .menu-btn span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

.mobile-menu{position:fixed;inset:0;z-index:39;visibility:hidden;opacity:0;pointer-events:none;overflow-y:auto;
  background:radial-gradient(120% 80% at 80% 0%, rgba(189,140,125,.10), transparent 60%), rgba(11,10,9,.90);
  -webkit-backdrop-filter:blur(18px) saturate(1.1);backdrop-filter:blur(18px) saturate(1.1);
  transition:opacity .42s var(--ease),visibility .42s}
body.menu-open .mobile-menu{visibility:visible;opacity:1;pointer-events:auto}
body.menu-open{overflow:hidden}
.mm-inner{min-height:100%;display:flex;flex-direction:column;justify-content:center;
  padding:108px clamp(24px,7vw,52px) 56px;box-sizing:border-box}
.mm-lbl{font-family:var(--mono);font-size:10px;letter-spacing:.4em;text-transform:uppercase;color:var(--steel);margin-bottom:24px}
.mm-links{display:flex;flex-direction:column}
.mm-links a{font-family:var(--serif);font-weight:300;font-size:clamp(30px,8.4vw,44px);letter-spacing:-.012em;line-height:1.1;
  color:var(--paper-soft);text-decoration:none;padding:13px 0;border-bottom:1px solid var(--line-soft);
  display:flex;align-items:center;opacity:0;transform:translateY(12px);transition:color .3s}
.mm-links a[aria-current="page"]{color:var(--paper)}
.mm-links a[aria-current="page"]::before{content:"";width:20px;height:1px;background:var(--steel);margin-right:15px;flex:none}
.mm-links a:active{color:var(--steel)}
body.menu-open .mm-links a{opacity:1;transform:none;
  transition:opacity .5s var(--ease),transform .55s var(--ease),color .3s;transition-delay:calc(.055s * var(--i) + .1s)}
.mm-talk{margin-top:36px;align-self:flex-start;border:1px solid var(--steel);border-radius:2px;padding:15px 30px;
  font-family:var(--serif);font-style:italic;font-size:18px;color:var(--paper);text-decoration:none;
  background:rgba(189,140,125,.07);opacity:0;transform:translateY(12px);transition:background .3s}
body.menu-open .mm-talk{opacity:1;transform:none;transition:opacity .5s var(--ease) .46s,transform .55s var(--ease) .46s,background .3s}
.mm-talk:active{background:rgba(189,140,125,.18)}
@media(max-width:880px){
  .menu-btn{display:flex}
  .talk{display:none}    /* the CTA moves into the menu on mobile, keeping the bar to wordmark + toggle */
}

/* ---------- generic page scaffold ---------- */
.page{position:relative;z-index:10}
.sec{position:relative;max-width:1280px;margin:0 auto;padding:clamp(72px,11vh,150px) clamp(20px,3.6vw,52px)}
.sec + .sec{border-top:1px solid var(--line-soft)}

/* page hero: kicker + big headline + lede, with one signature canvas motif */
.phero{position:relative;z-index:10;max-width:1280px;margin:0 auto;
  padding:clamp(118px,17vh,210px) clamp(20px,3.6vw,52px) clamp(40px,7vh,90px);
  display:grid;grid-template-columns:1fr 1.04fr;gap:clamp(34px,5vw,84px);align-items:center}
@media(max-width:900px){.phero{grid-template-columns:1fr;gap:38px}}
.phero .pk{font-family:var(--mono);font-size:11px;letter-spacing:.42em;text-transform:uppercase;color:var(--steel);
  display:flex;align-items:center;gap:12px;margin-bottom:26px}
.phero .pk .tk{width:26px;height:1px;background:var(--steel);opacity:.6}
.phero h1{font-weight:600;letter-spacing:-.018em;line-height:.96;font-size:clamp(44px,7vw,104px);color:var(--paper)}
.phero h1 em{font-family:var(--serif);font-style:italic;font-weight:300;letter-spacing:-.01em}
.phero .rule{height:1px;background:var(--line);margin:34px 0 24px;max-width:430px}
.phero .lede{max-width:46ch;font-size:clamp(14px,1.12vw,17px);line-height:1.62;color:var(--dim)}
.phero .lede b{color:var(--paper-soft);font-weight:500}

/* the signature motif card (mirrors the home Network card) */
.motif{position:relative;aspect-ratio:16/11;border:1px solid var(--line);overflow:hidden;
  background:radial-gradient(120% 90% at 62% 34%, rgba(189,140,125,0.05), transparent 62%), var(--g1)}
.motif::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:linear-gradient(var(--line-soft) 1px,transparent 1px),linear-gradient(90deg,var(--line-soft) 1px,transparent 1px);
  background-size:14.28% 16.66%}
.motif canvas{position:absolute;inset:0;width:100%;height:100%;display:block}
.motif img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.motif video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
/* "bare" motif: no frame, no grid, no label — the transparent turbine floats free into the page */
.motif.bare{border:0;background:none;overflow:visible;aspect-ratio:1/1}
.motif.bare::before{display:none}
.motif.bare .motcorners,.motif.bare .motlabel{display:none}
.motif.bare img{object-fit:contain;transform:scale(1.08)}
.motif.bare .turbine-still{display:none}
@media(prefers-reduced-motion:reduce){
  .motif.bare .turbine-anim{display:none}
  .motif.bare .turbine-still{display:block}
}
@media(prefers-reduced-motion:reduce){.motif video{display:none}}
.motcorners i{position:absolute;width:11px;height:11px;border:1px solid var(--steel);opacity:.5}
.motcorners i:nth-child(1){top:10px;left:10px;border-right:0;border-bottom:0}
.motcorners i:nth-child(2){top:10px;right:10px;border-left:0;border-bottom:0}
.motcorners i:nth-child(3){bottom:10px;left:10px;border-right:0;border-top:0}
.motcorners i:nth-child(4){bottom:10px;right:10px;border-left:0;border-top:0}
.motlabel{position:absolute;left:16px;bottom:13px;font-family:var(--mono);font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--faint)}

/* section heading (matches home Act II) */
.sechead{display:grid;grid-template-columns:1fr auto;gap:30px;align-items:end;border-bottom:1px solid var(--line);padding-bottom:28px;margin-bottom:54px}
@media(max-width:760px){.sechead{grid-template-columns:1fr}}
.sechead .pk{font-family:var(--mono);font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:var(--steel);display:flex;align-items:center;gap:12px;margin-bottom:20px}
.sechead .pk .tk{width:26px;height:1px;background:var(--steel);opacity:.6}
.sechead h2{font-weight:600;font-size:clamp(34px,5vw,74px);letter-spacing:-.015em;line-height:.98;color:var(--paper)}
.sechead h2 em{font-family:var(--serif);font-style:italic;font-weight:300}
.sechead .note{max-width:34ch;font-size:14.5px;line-height:1.6;color:var(--dim)}

/* card grids (verbatim from home) */
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
@media(max-width:900px){.grid4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.grid4{grid-template-columns:1fr}}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
@media(max-width:820px){.grid3{grid-template-columns:1fr}}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
@media(max-width:760px){.grid2{grid-template-columns:1fr}}
.card{background:var(--g1);padding:30px 26px;min-height:280px;display:flex;flex-direction:column;transition:background .45s var(--ease)}
.card:hover{background:#1b1714}
.card .no{font-family:var(--mono);font-size:12px;color:var(--steel);letter-spacing:.05em}
.card .stage{font-family:var(--mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint);margin-top:6px}
.card h3{font-weight:600;font-size:clamp(19px,1.6vw,23px);color:var(--paper);margin:16px 0 12px;letter-spacing:-.01em}
.card p{font-size:13.5px;line-height:1.58;color:var(--dim)}
.card p + p{margin-top:10px}
.card .meta{margin-top:auto;padding-top:20px;font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint)}
.card .meta b{color:var(--steel);font-weight:400}

/* numbered "leak / principle" rows */
.leakc{background:var(--g1);padding:30px;display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:start;transition:background .45s var(--ease)}
.leakc:hover{background:#1b1714}
.leakc .ln{font-family:var(--sans);font-weight:600;font-size:40px;line-height:1;color:var(--faint)}
.leakc h3{font-weight:600;font-size:18px;color:var(--paper);margin-bottom:8px}
.leakc p{font-size:13.5px;line-height:1.55;color:var(--dim);max-width:46ch}

/* engagement / two-up tiles */
.eng2{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
@media(max-width:760px){.eng2{grid-template-columns:1fr}}
.engc{background:var(--g1);padding:38px 32px;transition:background .45s var(--ease)}
.engc:hover{background:#1b1714}
.engc .ph{font-family:var(--mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--faint)}
.engc .big{font-weight:600;font-size:clamp(40px,5vw,66px);letter-spacing:-.02em;color:var(--paper);margin:20px 0 2px;line-height:1}
.engc .big i{font-style:normal;color:var(--steel);font-size:.5em;margin:0 2px;vertical-align:.16em}
.engc .unit{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--steel)}
.engc p{font-size:13.5px;line-height:1.6;color:var(--dim);margin-top:18px;max-width:42ch}
.engc ul{list-style:none;margin-top:18px;display:flex;flex-direction:column;gap:11px}
.engc li{font-size:13.5px;line-height:1.45;color:var(--dim);padding-left:18px;position:relative}
.engc li::before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:50%;background:var(--steel);opacity:.7}
.engc .casehero{position:relative;margin:-38px -32px 26px;height:190px;overflow:hidden;border-bottom:1px solid var(--line)}
.engc .casehero img{width:100%;height:100%;object-fit:cover;display:block;
  filter:grayscale(1) brightness(.6) contrast(1.04);transform:scale(1.02);
  transition:filter .7s var(--ease),transform 1.3s var(--ease)}
.engc:hover .casehero img{filter:grayscale(.35) brightness(.82) contrast(1.02);transform:scale(1.07)}
.engc .casehero::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(to bottom, rgba(19,17,15,0) 38%, rgba(19,17,15,.92))}
.engc .casehero .sct{position:absolute;left:18px;top:14px;z-index:2;font-family:var(--mono);font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--paper-soft)}
.engc .quote{margin-top:22px;border-top:1px solid var(--line-soft);padding-top:18px;font-family:var(--serif);font-style:italic;font-size:16px;line-height:1.5;color:var(--paper-soft)}
.engc .quote span{display:block;margin-top:12px;font-family:var(--mono);font-style:normal;font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint)}

/* big stat row (the Ledger) */
.lstats{display:flex;gap:clamp(28px,6vw,90px);flex-wrap:wrap;align-items:flex-end;border-bottom:1px solid var(--line);padding-bottom:34px;margin-bottom:54px}
.lstat .v{font-family:var(--sans);font-weight:600;font-size:clamp(38px,5.5vw,76px);letter-spacing:-.02em;color:var(--paper);line-height:1;font-variant-numeric:tabular-nums}
.lstat .v i{font-style:normal;color:var(--steel);font-size:.42em;vertical-align:.22em;margin:0 1px}
.lstat .k{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint);margin-top:14px}
.lstat .sub{font-size:12.5px;color:var(--dim);margin-top:6px;max-width:22ch}

/* case grid (the Ledger proof tiles) */
.cases{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
@media(max-width:820px){.cases{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.cases{grid-template-columns:1fr}}
.case{background:var(--g1);padding:26px 24px;transition:background .45s var(--ease)}
.case:hover{background:#1b1714}
.case .sec0{font-family:var(--mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint)}
.case .nm{font-family:var(--sans);font-weight:600;font-size:16px;color:var(--paper);margin:8px 0 18px;letter-spacing:-.01em}
.case .big{font-family:var(--sans);font-weight:600;font-size:clamp(28px,3vw,40px);color:var(--paper);letter-spacing:-.015em;line-height:1}
.case .big i{font-style:normal;color:var(--steel);font-size:.46em;margin:0 1px;vertical-align:.18em}
.case .cl{font-family:var(--mono);font-size:8.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin-top:8px}
.case .note{font-size:12.5px;line-height:1.5;color:var(--dim);margin-top:16px;border-top:1px solid var(--line-soft);padding-top:14px}

/* prose block (Approach philosophy / Advisory who-we-serve) */
.prose{max-width:62ch}
.prose p{font-size:clamp(15px,1.2vw,17px);line-height:1.68;color:var(--paper-soft)}
.prose p + p{margin-top:20px}
.prose b{color:var(--paper);font-weight:500}
.prose em{font-family:var(--serif);font-style:italic;font-weight:300;color:var(--ice)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,80px);align-items:start}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:40px}}
.aside{font-family:var(--mono);font-size:11px;letter-spacing:.06em;line-height:1.9;color:var(--dim)}
.aside .row{display:grid;grid-template-columns:108px 1fr;column-gap:clamp(18px,2.5vw,40px);align-items:baseline;padding:13px 0;border-bottom:1px solid var(--line-soft)}
.aside .row b{color:var(--steel);font-weight:400;text-transform:uppercase;letter-spacing:.18em;font-size:10px}
.aside .row span{color:var(--paper-soft)}

/* buttons */
.btnrow{display:flex;gap:16px;flex-wrap:wrap;margin-top:34px}
.btn{display:inline-flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:2px;padding:14px 30px;
  font-family:var(--serif);font-style:italic;font-size:17px;color:var(--paper);text-decoration:none;transition:border-color .3s,background .3s}
.btn:hover{border-color:var(--steel);background:rgba(189,140,125,.06)}
.btn.mono{font-family:var(--mono);font-style:normal;font-size:11px;letter-spacing:.22em;text-transform:uppercase}
.btn .arw{display:inline-flex;width:28px;height:28px;border:1px solid var(--line);border-radius:50%;align-items:center;justify-content:center;color:var(--steel);transition:border-color .3s,transform .3s}
.btn:hover .arw{border-color:var(--steel);transform:translateX(2px)}

/* the contact close (shared, used on Advisory) */
.endclose{position:relative;z-index:10;min-height:74vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:90px 24px;border-top:1px solid var(--line)}
.endclose .pk{font-family:var(--mono);font-size:11px;letter-spacing:.42em;text-transform:uppercase;color:var(--steel);margin-bottom:26px}
.endclose h2{font-weight:600;font-size:clamp(58px,12vw,168px);line-height:.86;letter-spacing:-.025em;color:var(--paper)}
.endclose h2 em{font-family:var(--serif);font-style:italic;font-weight:300}
.endclose .sub{margin-top:24px;max-width:46ch;font-size:15px;line-height:1.6;color:var(--dim)}

/* ---------- footer ---------- */
.sitefoot{position:relative;z-index:10;background:var(--g0);border-top:1px solid var(--line);padding:44px clamp(20px,3.6vw,52px);
  display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint)}
.sitefoot a{color:var(--dim);text-decoration:none;transition:color .3s}
.sitefoot a:hover{color:var(--paper)}
@media(max-width:600px){
  .sitefoot{font-size:11px;gap:16px;line-height:1.6}
  .sitefoot .links{line-height:2.3}
  .sitefoot .links a{padding:3px 2px}   /* larger hit area for the footer nav links */
}

/* ---------- reveal-on-scroll ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){*{transition:none !important;animation:none !important}.reveal{opacity:1 !important;transform:none !important}html{scroll-behavior:auto}}

/* ============================ journal / insights ============================ */
.jfilters{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 44px}
.jchip{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);
  border:1px solid var(--line);border-radius:2px;padding:8px 14px;background:none;cursor:pointer;transition:color .3s,border-color .3s,background .3s}
.jchip:hover{color:var(--paper);border-color:var(--steel)}
.jchip.on{color:var(--g0);background:var(--steel);border-color:var(--steel)}
.jfeature{display:grid;grid-template-columns:1.1fr .9fr;gap:1px;background:var(--line);border:1px solid var(--line);margin-bottom:1px;text-decoration:none}
@media(max-width:820px){.jfeature{grid-template-columns:1fr}}
.jfeature .ftxt{background:var(--g1);padding:clamp(28px,4vw,54px);display:flex;flex-direction:column;justify-content:center;transition:background .45s var(--ease)}
.jfeature:hover .ftxt{background:#1b1714}
.jfeature .fart{background:var(--g2);position:relative;min-height:240px;overflow:hidden}
.jfeature .fart canvas{position:absolute;inset:0;width:100%;height:100%}
.jfeature .fart img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;
  filter:grayscale(1) brightness(.62) contrast(1.05);transform:scale(1.02);
  transition:filter .7s var(--ease),transform 1.3s var(--ease)}
.jfeature:hover .fart img{filter:grayscale(.4) brightness(.8) contrast(1.02);transform:scale(1.06)}
.jfeature .fart::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(110deg, rgba(19,17,15,.55), rgba(19,17,15,0) 52%),linear-gradient(to top, rgba(19,17,15,.55), rgba(19,17,15,0) 55%)}
.jfeature .fart .ftag{position:absolute;left:18px;top:15px;z-index:2;font-family:var(--mono);font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--paper-soft)}
/* hero montage: a wall of treated live photography, unique to the journal */
.jmontage{position:relative;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:1px;
  background:var(--line);border:1px solid var(--line);aspect-ratio:11/9;min-height:300px}
.jmontage .jm{position:relative;overflow:hidden;background:var(--g2)}
.jmontage .jm img{width:100%;height:100%;object-fit:cover;display:block;
  filter:grayscale(1) brightness(.5) contrast(1.06);transform:scale(1.02);
  transition:filter .8s var(--ease),transform 1.4s var(--ease)}
.jmontage .jm:hover img{filter:grayscale(.15) brightness(.92) contrast(1.02);transform:scale(1.09)}
.jmontage .mcorners i{position:absolute;width:11px;height:11px;border:1px solid var(--steel);opacity:.5;z-index:3}
.jmontage .mcorners i:nth-child(1){left:9px;top:9px;border-right:0;border-bottom:0}
.jmontage .mcorners i:nth-child(2){right:9px;top:9px;border-left:0;border-bottom:0}
.jmontage .mcorners i:nth-child(3){left:9px;bottom:9px;border-right:0;border-top:0}
.jmontage .mcorners i:nth-child(4){right:9px;bottom:9px;border-left:0;border-top:0}
.jmontage .mlabel{position:absolute;left:50%;bottom:14px;transform:translateX(-50%);z-index:3;
  font-family:var(--mono);font-size:9px;letter-spacing:.26em;text-transform:uppercase;color:var(--paper-soft);
  background:rgba(11,10,9,.7);padding:5px 12px;border:1px solid var(--line)}
/* card thumbnails */
.jcard .jthumb{position:relative;margin:-26px -24px 18px;height:158px;overflow:hidden;border-bottom:1px solid var(--line)}
.jcard .jthumb img{width:100%;height:100%;object-fit:cover;display:block;
  filter:grayscale(1) brightness(.58) contrast(1.05);transform:scale(1.02);
  transition:filter .7s var(--ease),transform 1.3s var(--ease)}
.jcard:hover .jthumb img{filter:grayscale(.35) brightness(.8) contrast(1.02);transform:scale(1.07)}
.jcard .jthumb::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(to top, rgba(19,17,15,.7), rgba(19,17,15,0) 62%)}
/* article cover image */
.art .arthero{position:relative;margin:30px 0 6px;height:clamp(230px,38vw,440px);overflow:hidden;border:1px solid var(--line)}
.art .arthero img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(1) brightness(.66) contrast(1.05)}
.art .arthero::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(to top, rgba(11,10,9,.66), rgba(11,10,9,0) 58%)}
.jfeature h2{font-weight:600;font-size:clamp(28px,3.2vw,46px);line-height:1.02;letter-spacing:-.018em;color:var(--paper);margin:16px 0 14px}
.jfeature h2 em{font-family:var(--serif);font-style:italic;font-weight:300}
.jfeature .fx{font-size:14.5px;line-height:1.6;color:var(--dim);max-width:48ch}
.jfeature .by{margin-top:24px;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint)}
.jfeature .by b{color:var(--paper-soft);font-weight:400}
.jgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
@media(max-width:900px){.jgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.jgrid{grid-template-columns:1fr}}
.jcard{display:flex;flex-direction:column;background:var(--g1);padding:26px 24px;min-height:236px;text-decoration:none;overflow:hidden;transition:background .45s var(--ease)}
.jcard:hover{background:#1b1714}
.jcat{font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--steel)}
.jdate{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);margin-top:6px}
.jcard h3{font-weight:600;font-size:clamp(18px,1.5vw,22px);line-height:1.16;letter-spacing:-.01em;color:var(--paper);margin:14px 0 10px}
.jcard p{font-size:13px;line-height:1.55;color:var(--dim)}
.jcard .by{margin-top:auto;padding-top:18px;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);display:flex;justify-content:space-between;gap:10px}
.jcard .by b{color:var(--paper-soft);font-weight:400}

/* newsletter */
.news{border:1px solid var(--line);background:radial-gradient(120% 120% at 50% -20%, rgba(189,140,125,0.07), transparent 60%), var(--g1);padding:clamp(34px,5vw,66px);text-align:center}
.news h2{font-weight:600;font-size:clamp(30px,4vw,52px);letter-spacing:-.02em;color:var(--paper)}
.news h2 em{font-family:var(--serif);font-style:italic;font-weight:300}
.news .sub{max-width:48ch;margin:16px auto 0;font-size:14.5px;line-height:1.6;color:var(--dim)}
.news form{display:flex;gap:10px;max-width:480px;margin:30px auto 0;flex-wrap:wrap;justify-content:center}
.news input{flex:1;min-width:220px;background:var(--g0);border:1px solid var(--line);border-radius:2px;padding:13px 16px;color:var(--paper);font-family:var(--mono);font-size:12px;letter-spacing:.06em}
.news input:focus{outline:none;border-color:var(--steel)}
.news button{border:1px solid var(--steel);background:var(--steel);color:var(--g0);border-radius:2px;padding:13px 26px;font-family:var(--serif);font-style:italic;font-size:15px;cursor:pointer;transition:opacity .3s}
.news button:hover{opacity:.88}
.news .stats{display:flex;justify-content:center;gap:clamp(24px,5vw,64px);margin-top:36px;flex-wrap:wrap}
.news .stats .v{font-weight:600;font-size:26px;color:var(--paper);font-variant-numeric:tabular-nums}
.news .stats .k{font-family:var(--mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint);margin-top:6px}

/* faq */
.faq{display:grid;gap:1px;background:var(--line);border:1px solid var(--line)}
.faq details{background:var(--g1)}
.faq summary{cursor:pointer;list-style:none;padding:23px 26px;font-family:var(--sans);font-weight:500;font-size:15.5px;color:var(--paper);display:flex;justify-content:space-between;gap:16px;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--steel);font-size:20px;line-height:1}
.faq details[open] summary::after{content:"\2013"}
.faq details .a{padding:0 26px 24px;font-size:14px;line-height:1.62;color:var(--dim);max-width:72ch}

/* article page */
.art{max-width:760px;margin:0 auto;padding:clamp(118px,16vh,200px) clamp(20px,3.6vw,52px) clamp(50px,8vh,90px)}
.art .eyebrow{display:flex;gap:14px;align-items:center;font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--steel);margin-bottom:22px}
.art .eyebrow .dt{color:var(--faint)}
.art h1{font-weight:600;font-size:clamp(33px,4.6vw,58px);line-height:1.04;letter-spacing:-.018em;color:var(--paper)}
.art h1 em{font-family:var(--serif);font-style:italic;font-weight:300}
.art .teaser{font-family:var(--serif);font-style:italic;font-size:clamp(17px,1.5vw,21px);line-height:1.5;color:var(--paper-soft);margin-top:20px}
.art .byline{display:flex;align-items:center;gap:14px;margin-top:28px;padding:22px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.art .byline .av{width:38px;height:38px;border-radius:50%;border:1px solid var(--steel);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--steel);flex:none}
.art .byline .who{font-size:13px;color:var(--paper)}
.art .byline .who span{display:block;font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);margin-top:3px}
.art .byline .rt{margin-left:auto;font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint)}
.art-body{margin-top:40px}
.art-body p{font-size:clamp(15px,1.15vw,17px);line-height:1.74;color:var(--paper-soft);margin-bottom:22px}
.art-body h3{font-weight:600;font-size:clamp(20px,1.7vw,25px);letter-spacing:-.01em;color:var(--paper);margin:40px 0 16px}
.art-callout{border-left:2px solid var(--steel);background:rgba(189,140,125,0.05);padding:22px 26px;margin:30px 0}
.art-callout .lbl{font-family:var(--mono);font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--steel);display:block;margin-bottom:12px}
.art-callout p{font-family:var(--serif);font-style:italic;font-size:18px;line-height:1.5;color:var(--ice);margin:0}
.art-quote{font-family:var(--serif);font-style:italic;font-size:clamp(18px,1.8vw,23px);line-height:1.5;color:var(--ice);margin:30px 0;padding-left:22px;border-left:2px solid var(--steel)}
.art-back{display:inline-flex;align-items:center;gap:8px;margin-top:14px;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--steel);text-decoration:none}
.art-back:hover{color:var(--paper)}
/* z-index keeps it above the fixed .ground; translateZ promotes it to its own
   compositing layer so the fixed mix-blend-mode overlays cannot drop it when the
   page is static (Chromium/Edge compositor bug: visible while scrolling, gone when idle) */
.art-foot{position:relative;z-index:10;transform:translateZ(0);max-width:1100px;margin:0 auto;padding:0 clamp(20px,3.6vw,52px) clamp(70px,10vh,120px)}
