/* ===================================================================
   SPECTRUM · shared shell for the multi-page 1DigitalC portfolio
   One live "signal" color retunes per section/page. Dark operator console.
   =================================================================== */
:root{
  --bg:#07080A;
  --bg2:#0B0D11;
  --ink:#E8EAED;
  --muted:#8A8F98;
  --dim:#565B64;
  --signal:#00FFC2;          /* live channel color, JS retunes this */
  --signal-rgb:0,255,194;
  --line:rgba(255,255,255,0.08);
  --line2:rgba(255,255,255,0.14);
  --serif:'Fraunces',Georgia,serif;
  --slab:'Anton',Impact,sans-serif;
  --mono:'DM Mono',ui-monospace,monospace;
  --sans:'Inter',system-ui,sans-serif;
  --pad:clamp(20px,5vw,80px);
  --nav-h:60px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);overflow-x:hidden;line-height:1.5;cursor:none}
@media (hover:none){body{cursor:auto}}
a{color:inherit;text-decoration:none}
canvas{display:block}
::selection{background:var(--signal);color:#000}

#swarm{position:fixed;inset:0;z-index:0;pointer-events:none}
/* legibility veil over the node field on every page EXCEPT home (home keeps the full
   bright swarm + fish as its hero). Sits above swarm(0), below all sections(z-index:2). */
body:not([data-base-name="HOME"])::before{content:"";position:fixed;inset:0;z-index:1;pointer-events:none;background:rgba(6,7,10,.55)}
#hero3d{position:fixed;inset:0;width:100%;height:100%;z-index:1;pointer-events:none;opacity:0;transition:opacity 1.2s ease}
#hero3d.lit{opacity:.92}
@media(max-width:720px){#hero3d.lit{opacity:.7}}
.grain{position:fixed;inset:0;z-index:1;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'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.vignette{position:fixed;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(120% 90% at 50% 35%,transparent 45%,rgba(0,0,0,.6) 100%)}

/* FISH LEGIBILITY SCRIM: soft, faded dark halo behind reading text so the background
   fish (z-index:1, behind all sections) never hurts legibility when it swims past. */
.panel .grid>div,
.hero .claim,.hero .hmission,.hero .readouts,.hero .sub,
.tsec .lead2,.tsec .solverow,.statwall{isolation:isolate}
.panel .grid>div::before,
.hero .claim::before,.hero .hmission::before,.hero .readouts::before,.hero .sub::before,
.tsec .lead2::before,.tsec .solverow::before,.statwall::before{
  content:"";position:absolute;z-index:-1;inset:-16px -28px;pointer-events:none;border-radius:22px;
  background:radial-gradient(115% 105% at 50% 50%,rgba(3,7,9,.66) 0%,rgba(3,7,9,.5) 52%,transparent 82%);
  filter:blur(7px)}

/* cursor */
.cursor{position:fixed;top:0;left:0;width:26px;height:26px;border:1px solid var(--signal);
  border-radius:50%;transform:translate(-50%,-50%);z-index:9999;pointer-events:none;
  transition:width .25s,height .25s,background .25s,border-color .6s;mix-blend-mode:difference}
.cursor.big{width:64px;height:64px;background:rgba(255,255,255,.08)}
.cursor-dot{position:fixed;top:0;left:0;width:4px;height:4px;background:var(--signal);
  border-radius:50%;transform:translate(-50%,-50%);z-index:9999;pointer-events:none;transition:background .6s}
@media (hover:none){.cursor,.cursor-dot{display:none}}

/* ===== top NAV (multi-page) ===== */
.nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:60;display:flex;align-items:center;
  justify-content:space-between;padding:0 var(--pad);
  background:linear-gradient(180deg,rgba(7,8,10,.92),rgba(7,8,10,.55) 70%,transparent);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.nav .wm{font-family:var(--mono);font-weight:500;color:var(--ink);letter-spacing:.18em;font-size:13px}
.nav .wm b{color:var(--signal);transition:color .6s}
.nav .links{display:flex;gap:4px;align-items:center}
.nav .links a{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);
  padding:8px 12px;border-radius:30px;transition:color .25s,background .25s;white-space:nowrap;display:flex;gap:7px;align-items:center}
.nav .links a .code{color:var(--dim);font-size:10px}
.nav .links a:hover{color:var(--ink)}
.nav .links a.active{color:var(--signal)}
.nav .links a.active .code{color:var(--signal)}
.nav .links a.active{background:rgba(var(--signal-rgb),.08)}
.nav .burger{display:none;font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:var(--ink);
  border:1px solid var(--line2);border-radius:30px;padding:8px 14px;text-transform:uppercase}
@media(max-width:1080px){
  .nav .links{position:fixed;top:var(--nav-h);left:0;right:0;flex-direction:column;gap:0;align-items:stretch;
    background:var(--bg2);border-bottom:1px solid var(--line);padding:8px var(--pad) 18px;
    transform:translateY(-120%);transition:transform .4s cubic-bezier(.6,.05,.1,1);pointer-events:none}
  .nav .links.open{transform:translateY(0);pointer-events:auto}
  .nav .links a{padding:14px 4px;border-bottom:1px solid var(--line);font-size:13px}
  .nav .burger{display:block}
}

/* HUD */
.hud{position:fixed;inset:0;z-index:5;pointer-events:none;font-family:var(--mono);
  font-size:11px;letter-spacing:.08em;color:var(--muted);text-transform:uppercase}
.hud .corner{position:absolute;width:18px;height:18px;border-color:var(--line2)}
.hud .tl{top:calc(var(--nav-h) + 8px);left:14px;border-top:1px solid;border-left:1px solid}
.hud .tr{top:calc(var(--nav-h) + 8px);right:14px;border-top:1px solid;border-right:1px solid}
.hud .bl{bottom:14px;left:14px;border-bottom:1px solid;border-left:1px solid}
.hud .br{bottom:14px;right:14px;border-bottom:1px solid;border-right:1px solid}
.hud .dot{width:7px;height:7px;border-radius:50%;background:var(--signal);box-shadow:0 0 10px var(--signal);animation:pulse 1.8s infinite;transition:background .6s,box-shadow .6s;display:inline-block}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.25}}
.hud .channel{position:absolute;left:14px;top:50%;transform:rotate(-90deg) translateX(50%);
  transform-origin:left center;white-space:nowrap;color:var(--signal);transition:color .6s;font-weight:500}
.hud .sidecoord{position:absolute;right:14px;top:50%;transform:rotate(90deg) translateX(-50%);transform-origin:right center;white-space:nowrap}
.hud .progress{position:absolute;bottom:18px;left:0;right:0;padding:0 var(--pad);display:flex;justify-content:space-between;align-items:center}
.hud .pbar{flex:1;height:1px;background:var(--line);margin:0 18px;position:relative;overflow:hidden}
.hud .pbar i{position:absolute;left:0;top:0;height:100%;width:0;background:var(--signal);box-shadow:0 0 8px var(--signal);transition:background .6s}
@media(max-width:720px){.hud .channel,.hud .sidecoord{display:none}}

/* boot */
#boot{position:fixed;inset:0;z-index:9998;background:var(--bg);display:flex;align-items:center;justify-content:center;flex-direction:column;font-family:var(--mono);font-size:12px;color:var(--signal);gap:14px}
#boot .bootbar{width:min(280px,60vw);height:2px;background:var(--line)}
#boot .bootbar i{display:block;height:100%;width:0;background:var(--signal);box-shadow:0 0 10px var(--signal)}
#boot .boottxt{color:var(--muted);letter-spacing:.1em;min-height:16px}

/* layout */
section{position:relative;z-index:2;padding:0 var(--pad)}
.wrap{max-width:1280px;margin:0 auto;width:100%}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--signal);display:flex;align-items:center;gap:10px;margin-bottom:26px;transition:color .6s}
.eyebrow::before{content:"";width:28px;height:1px;background:var(--signal);transition:background .6s}

/* hero (page header) */
.hero{min-height:76vh;display:flex;flex-direction:column;justify-content:center;padding-top:var(--nav-h)}
.hero h1{font-family:var(--serif);font-weight:600;line-height:.92;letter-spacing:-.02em;font-size:clamp(38px,5.4vw,76px);margin:.08em 0 .3em}
/* homepage name treatment stays giant; deep pages use the smaller hero above */
body[data-base-name="HOME"] .hero{min-height:100vh}
body[data-base-name="HOME"] .hero h1{line-height:.9;font-size:clamp(54px,12vw,180px)}
.hero h1 .l{display:block;overflow:hidden}
.hero h1 .l span{display:block;transform:translateY(110%)}
.hero .claim{font-family:var(--serif);font-weight:400;font-style:italic;font-size:clamp(20px,2.6vw,36px);max-width:24ch;color:var(--ink);line-height:1.25;opacity:0}
.hero .sub{font-family:var(--mono);font-size:13px;color:var(--muted);max-width:56ch;margin-top:26px;letter-spacing:.02em;line-height:1.7;opacity:0}
.scrollcue{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--dim);text-transform:uppercase;margin-top:56px;display:flex;align-items:center;gap:10px;opacity:0}
.scrollcue .ln{width:1px;height:40px;background:linear-gradient(var(--signal),transparent);animation:cue 2s infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* compact page hero (deep pages) */
.phero{min-height:60vh;display:flex;flex-direction:column;justify-content:center;padding-top:calc(var(--nav-h) + 28px);padding-bottom:40px}
.phero .kick{font-family:var(--mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--signal);margin-bottom:20px;display:flex;align-items:center;gap:10px;transition:color .6s}
.phero .kick .id{border:1px solid var(--signal);border-radius:30px;padding:3px 11px;transition:border-color .6s,color .6s}
.phero h1{font-family:var(--serif);font-weight:600;line-height:1;letter-spacing:-.02em;font-size:clamp(34px,4.4vw,60px);margin-bottom:26px}
.phero h1 b{color:var(--signal);transition:color .6s;font-weight:600}
.phero .lede{font-family:var(--sans);font-size:clamp(17px,1.8vw,22px);color:var(--muted);max-width:60ch;line-height:1.6}
.phero .lede b{color:var(--ink);font-weight:600}

/* ===== BIG SIGNAL PANEL ===== */
.panel{min-height:auto;display:flex;align-items:center;padding-top:clamp(56px,8vh,110px);padding-bottom:clamp(56px,8vh,110px)}
.panel.short{min-height:auto;padding:clamp(44px,6vh,80px) 0}
.panel .grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);gap:3vw;align-items:center;width:100%}
.chtag{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--signal);margin-bottom:22px;display:flex;align-items:center;gap:12px;transition:color .6s}
.chtag .id{border:1px solid var(--signal);border-radius:30px;padding:3px 11px;transition:border-color .6s,color .6s}
.bignum{font-family:var(--slab);font-size:clamp(72px,15vw,220px);line-height:.84;letter-spacing:-.01em;color:var(--signal);
  transition:color .6s;text-shadow:0 0 60px rgba(var(--signal-rgb),.25);position:relative;padding-top:.14em;overflow-wrap:anywhere}
.bignum .kick{display:block;font-family:var(--mono);font-size:clamp(14px,1.6vw,22px);letter-spacing:.06em;color:var(--muted);
  -webkit-text-fill-color:var(--muted);text-shadow:none;margin-bottom:clamp(16px,2.4vh,30px);font-weight:500;line-height:1.35}
.bignum .u{font-size:.42em;vertical-align:baseline;color:var(--ink);-webkit-text-fill-color:var(--ink)}
.bignum.mid{font-size:clamp(52px,9vw,132px)}
.panel h2{font-family:var(--serif);font-weight:500;font-size:clamp(28px,3.6vw,50px);line-height:1.05;letter-spacing:-.02em;margin:2px 0 18px}
.panel h2 b{color:var(--signal);transition:color .6s;font-weight:600}
.panel .body{color:var(--muted);font-size:clamp(15px,1.35vw,17px);line-height:1.55;max-width:56ch;margin-bottom:14px}
.panel .body:last-of-type{margin-bottom:0}
.panel .body b{color:var(--ink);font-weight:600}
.panel .src{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--signal);margin-top:18px;transition:color .6s}
.panel .rule{height:2px;width:0;background:var(--signal);margin:18px 0;box-shadow:0 0 16px var(--signal);transition:background .6s}
@media(max-width:860px){.panel .grid{grid-template-columns:1fr;gap:5vh}.panel{min-height:auto;padding:clamp(48px,8vh,90px) 0}}

/* media panel bg */
.panel.media{position:relative;overflow:hidden}
.panel.media .bg{position:absolute;inset:0;z-index:-1}
.panel.media .bg img{width:100%;height:100%;object-fit:cover;filter:grayscale(.5) contrast(1.02) brightness(.55) blur(2.5px)}
.panel.media .bg:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,var(--bg) 10%,rgba(7,8,10,.55) 100%)}

/* stat strip */
.strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.strip .s{background:var(--bg);padding:34px 26px}
.strip .s .n{font-family:var(--slab);font-size:clamp(34px,4.4vw,58px);color:var(--ink);line-height:.9}
.strip .s .n em{font-style:normal;color:var(--signal);transition:color .6s}
.strip .s .l{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:12px;line-height:1.5}
@media(max-width:860px){.strip{grid-template-columns:1fr 1fr}}

/* systems */
.sysgrid{display:grid;grid-template-columns:1.05fr 1fr;gap:50px;align-items:center}
.terminal{background:#050608;border:1px solid var(--line2);border-radius:8px;overflow:hidden;font-family:var(--mono);font-size:13px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.terminal .tbar{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--line);color:var(--dim);font-size:11px;letter-spacing:.1em}
.terminal .tbar .d{width:9px;height:9px;border-radius:50%;background:var(--line2)}
.terminal .tbody{padding:20px 18px;min-height:300px}
.terminal .ln{margin-bottom:9px;color:var(--muted);opacity:0}
.terminal .ln .ag{color:var(--signal);transition:color .6s}
.terminal .ln .ok{color:#7CFFB0}
.terminal .cur{display:inline-block;width:8px;height:15px;background:var(--signal);vertical-align:middle;animation:blink 1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
@media(max-width:860px){.sysgrid{grid-template-columns:1fr;gap:30px}}

/* operator */
.opgrid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.opgrid .photo{aspect-ratio:4/5;border:1px solid var(--line2);border-radius:8px;overflow:hidden;position:relative;background:var(--bg2)}
.opgrid .photo img{width:100%;height:100%;object-fit:cover;object-position:50% 30%;filter:grayscale(.5) contrast(1.05)}
.opgrid .photo:after{content:"";position:absolute;inset:0;background:radial-gradient(70% 60% at 40% 20%,rgba(var(--signal-rgb),.18),transparent 60%);mix-blend-mode:screen;transition:background .6s}
#opgraph{width:100%;aspect-ratio:1/1;max-height:420px}
.opgrid .lead{font-family:var(--serif);font-size:clamp(26px,3.4vw,46px);font-weight:500;line-height:1.12;letter-spacing:-.01em;margin-bottom:22px}
.opgrid p{color:var(--muted);font-size:17px;line-height:1.65;margin-bottom:16px;max-width:46ch}
.opgrid p b{color:var(--ink)}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px}
.chips span{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line2);border-radius:30px;padding:6px 13px}
@media(max-width:860px){.opgrid{grid-template-columns:1fr;gap:34px}}

/* worlds media */
.worldsgrid{display:grid;grid-template-columns:.9fr 1.1fr;gap:5vw;align-items:center}
.worldsgrid .plate{aspect-ratio:3/2;border:1px solid var(--line2);border-radius:8px;overflow:hidden;position:relative}
.worldsgrid .plate img{width:100%;height:100%;object-fit:cover;filter:contrast(1.08) saturate(1.1)}
.worldsgrid .plate:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(7,8,10,.6),transparent 60%)}
@media(max-width:860px){.worldsgrid{grid-template-columns:1fr;gap:5vh}}

/* ===== FIELD / MEDIA PAGE COMPONENTS (faithful ports) ===== */
/* six-up stat wall variant */
.statwall.six{grid-template-columns:repeat(3,1fr)}
@media(max-width:980px){.statwall.six{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.statwall.six{grid-template-columns:1fr}}

/* hero image = big right-side backdrop centerpiece (faithful to the current
   site): FIXED 16:9 box sized off the viewport, vertically centered on the
   whole hero section, bleeding to the right edge, torn-edge PNG mask on both
   canvas and static img, center-out digitize reveal. */
.heroshot{--hero-mask:url("/assets/img/hero-mask-0.png");position:absolute;top:50%;right:0;transform:translateY(-50%);margin:0;width:62vw;aspect-ratio:16/9;z-index:0;pointer-events:none;background:none;border:0;border-radius:0;overflow:visible;-webkit-mask-image:var(--hero-mask);mask-image:var(--hero-mask);-webkit-mask-size:100% 100%;mask-size:100% 100%;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;-webkit-mask-mode:luminance;mask-mode:luminance}
@media(min-width:1024px){.heroshot{width:58vw}}
@media(min-width:1280px){.heroshot{width:54vw}}
.heroshot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;filter:grayscale(.3) contrast(1.06) saturate(1.05)}
.heroshot .voxel-canvas{filter:grayscale(.3) contrast(1.06) saturate(1.05)}
.phero:has(.heroshot),.hero:has(.heroshot){position:relative;overflow:hidden}
.phero:has(.heroshot)>.wrap,.hero:has(.heroshot)>.wrap{position:relative;z-index:1}
.phero:has(.heroshot) .lede{max-width:46ch}
.phero:has(.heroshot) h1{max-width:15ch}
.hero:has(.heroshot) .sub,.hero:has(.heroshot) .claim{max-width:46ch}
.hero:has(.heroshot) h1{max-width:15ch}
@media(max-width:900px){.heroshot{position:relative;top:auto;right:auto;transform:none;width:100%;margin-top:34px;aspect-ratio:16/9;opacity:.9}.phero:has(.heroshot) .lede,.phero:has(.heroshot) h1,.hero:has(.heroshot) .sub,.hero:has(.heroshot) .claim,.hero:has(.heroshot) h1{max-width:none}}

/* feature figure (image + overlay label + caption bar + text) */
.feature{margin-top:14px}
.figframe{position:relative;border:1px solid var(--line2);border-radius:8px;overflow:hidden;aspect-ratio:16/9;background:var(--bg2)}
.figframe img{width:100%;height:100%;object-fit:cover;filter:grayscale(.32) contrast(1.06) saturate(1.05)}
.figframe .tl{position:absolute;top:14px;left:16px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--signal);background:rgba(7,8,10,.6);padding:5px 10px;border-radius:4px;transition:color .6s}
.figcap{display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;border-bottom:1px solid var(--line);padding:16px 2px 22px}
.figcap .cl{font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink)}
.figcap .cl .sub{display:block;color:var(--dim);margin-top:5px;font-size:11px;letter-spacing:.04em}
.figcap .cr{text-align:right}
.figcap .cr .rl{font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--signal);transition:color .6s}
.figcap .cr .rs{font-family:var(--mono);font-size:11px;color:var(--dim);margin-top:5px;letter-spacing:.04em}
.feature .ftext{margin-top:30px;max-width:72ch}
.feature .flbl{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--signal);margin-bottom:12px;transition:color .6s}
.feature .ftext h2{font-family:var(--serif);font-weight:500;font-size:clamp(26px,3.6vw,48px);line-height:1.05;letter-spacing:-.02em;margin-bottom:20px}
.feature .ftext p{color:var(--muted);font-size:clamp(16px,1.5vw,18px);line-height:1.65}
.feature .ftext p b{color:var(--ink);font-weight:600}

/* media-card grid (image cards: badge / meta / title / desc) */
.mediagrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:44px}
@media(max-width:980px){.mediagrid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.mediagrid{grid-template-columns:1fr}}
.mcard{border:1px solid var(--line);border-radius:10px;overflow:hidden;background:linear-gradient(160deg,rgba(255,255,255,.02),rgba(255,255,255,0));transition:.35s cubic-bezier(.2,.7,.2,1)}
.mcard:hover{transform:translateY(-4px);border-color:rgba(var(--signal-rgb),.6);box-shadow:0 18px 50px rgba(0,0,0,.5)}
.mcard .mth{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--bg2)}
.mcard .mth img,.mcard .mth video{width:100%;height:100%;object-fit:cover;filter:grayscale(.3) contrast(1.06) saturate(1.05);transition:filter .4s,transform .5s}
.mcard:hover .mth img,.mcard:hover .mth video{filter:grayscale(0) contrast(1.08) saturate(1.12);transform:scale(1.04)}
.mcard .badge{position:absolute;top:12px;left:12px;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--signal);background:rgba(7,8,10,.62);padding:4px 9px;border-radius:4px;transition:color .6s}
.mcard .mbody{padding:20px 20px 24px}
.mcard .mmeta{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--dim);margin-bottom:10px;display:flex;gap:10px;flex-wrap:wrap}
.mcard h3{font-family:var(--serif);font-weight:600;font-size:clamp(19px,2vw,25px);letter-spacing:-.01em;margin-bottom:9px;line-height:1.1}
.mcard p{color:var(--muted);font-size:14px;line-height:1.6}

/* event ledger */
.ledlabel{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--signal);margin:52px 0 20px;transition:color .6s}
.ledger{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
@media(max-width:860px){.ledger{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.ledger{grid-template-columns:1fr}}
.led{background:var(--bg);padding:18px 18px}
.led .lwhere{font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink)}
.led .lwhen{font-family:var(--mono);font-size:10.5px;color:var(--signal);margin:5px 0 8px;transition:color .6s}
.led .lwhat{color:var(--muted);font-size:13px;line-height:1.5}

/* section heading */
.shead{display:flex;justify-content:space-between;align-items:flex-end;border-bottom:1px solid var(--line);padding-bottom:24px;margin-bottom:56px;gap:30px;flex-wrap:wrap}
.shead h2{font-family:var(--serif);font-weight:500;font-size:clamp(28px,4.4vw,56px);line-height:1;letter-spacing:-.02em}
.shead .idx{font-family:var(--mono);font-size:12px;color:var(--dim);letter-spacing:.1em;white-space:nowrap}
.gap{height:clamp(70px,10vh,140px)}

/* ===== section-card grid (homepage hub + cross-links) ===== */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.cards.two{grid-template-columns:repeat(auto-fill,minmax(380px,1fr))}
.cards.hub{grid-template-columns:repeat(3,1fr)}
@media(max-width:980px){.cards.hub{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.cards.hub{grid-template-columns:1fr}}
.card{display:block;border:1px solid var(--line);border-radius:12px;padding:28px 26px;position:relative;overflow:hidden;
  background:linear-gradient(160deg,rgba(255,255,255,.02),rgba(255,255,255,0));transition:.35s cubic-bezier(.2,.7,.2,1)}
.card:hover{transform:translateY(-4px);border-color:rgba(var(--card-rgb,var(--signal-rgb)),.7);box-shadow:0 18px 50px rgba(0,0,0,.5)}
.card .cch{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgb(var(--card-rgb,var(--signal-rgb)));margin-bottom:16px;display:flex;align-items:center;gap:8px}
.card .cch .cdot{width:8px;height:8px;border-radius:50%;background:rgb(var(--card-rgb,var(--signal-rgb)));box-shadow:0 0 10px rgb(var(--card-rgb,var(--signal-rgb)))}
.card h3{font-family:var(--serif);font-weight:600;font-size:clamp(24px,2.6vw,34px);letter-spacing:-.01em;margin-bottom:10px}
.card p{color:var(--muted);font-size:14.5px;line-height:1.6}
.card .go{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);margin-top:20px;display:flex;align-items:center;gap:8px}
.card .bar{height:2px;width:0;background:rgb(var(--card-rgb,var(--signal-rgb)));margin-top:16px;transition:width .5s;box-shadow:0 0 12px rgb(var(--card-rgb,var(--signal-rgb)))}
.card:hover .bar{width:100%}

/* ===== chlink (deep-page tune-in) ===== */
.chlink{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--signal);
  display:inline-flex;align-items:center;gap:8px;margin-top:26px;transition:color .6s;border-bottom:1px solid transparent;padding-bottom:3px}
.chlink:hover{border-bottom-color:var(--signal)}

/* ===== generic themed content section ===== */
.tsec{position:relative;z-index:2;padding:clamp(48px,7vh,92px) 0;border-top:1px solid var(--line)}
.tsec.noline{border-top:0}
.tsec .lead2{font-family:var(--serif);font-weight:500;font-size:clamp(26px,3.8vw,52px);line-height:1.05;letter-spacing:-.02em;max-width:20ch}
.tsec .lead2 b{color:var(--signal);transition:color .6s;font-weight:600}
.tsec .intro{color:var(--muted);font-size:clamp(16px,1.5vw,19px);line-height:1.65;max-width:60ch;margin-top:20px}
.tsec .intro b{color:var(--ink);font-weight:600}

/* hero terminal + proof readouts */
.hmission{font-family:var(--mono);font-size:13px;line-height:1.95;color:var(--muted);margin-top:34px;max-width:60ch}
.hmission .p{color:var(--signal);transition:color .6s}
.hmission .c{color:var(--ink)}
.readouts{display:grid;margin-top:40px;border-top:1px solid var(--line);max-width:70ch}
.readouts .ro{display:grid;grid-template-columns:180px 1fr;gap:24px;padding:20px 0;border-bottom:1px solid var(--line);align-items:baseline}
.readouts .ro .tag{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--signal);white-space:nowrap;transition:color .6s}
.readouts .ro .txt{color:var(--muted);font-size:clamp(14.5px,1.4vw,17px);line-height:1.55}
.readouts .ro .txt b{color:var(--ink);font-weight:600}
@media(max-width:680px){.readouts .ro{grid-template-columns:1fr;gap:8px}}

/* problem rows (WHAT I'M HIRED TO SOLVE) */
.solvelist{display:grid;margin-top:44px;border-top:1px solid var(--line)}
.solverow{display:grid;grid-template-columns:56px 1.1fr 1.4fr;gap:34px;padding:28px 0;border-bottom:1px solid var(--line);align-items:start}
.solverow .no{font-family:var(--slab);font-size:36px;color:var(--signal);line-height:1;transition:color .6s}
.solverow h4{font-family:var(--serif);font-weight:500;font-size:clamp(19px,2vw,27px);line-height:1.18}
.solverow p{color:var(--muted);font-size:15.5px;line-height:1.6}
.solverow p b{color:var(--ink);font-weight:600}
@media(max-width:860px){.solverow{grid-template-columns:40px 1fr;gap:14px}.solverow p{grid-column:1/-1;margin-top:4px}}

/* campaign KPIs (three slab numbers) */
.kpirow{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:20px}
.kpirow .kpi .n{font-family:var(--slab);font-size:clamp(60px,10vw,130px);line-height:.85;color:var(--signal);transition:color .6s;text-shadow:0 0 50px rgba(var(--signal-rgb),.22)}
.kpirow .kpi .k{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:14px;line-height:1.5}
@media(max-width:860px){.kpirow{grid-template-columns:1fr;gap:26px}}

/* stat wall (VERIFIED RECORD / AT A GLANCE) */
.statwall{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:40px}
.statwall .cell{background:var(--bg);padding:26px 22px}
.statwall .cell .n{font-family:var(--slab);font-size:clamp(30px,3.6vw,52px);color:var(--signal);line-height:.9;transition:color .6s}
.statwall .cell .k{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);margin-top:12px}
.statwall .cell .d{font-family:var(--mono);font-size:10px;letter-spacing:.03em;color:var(--dim);margin-top:7px;line-height:1.5;text-transform:uppercase}
@media(max-width:980px){.statwall{grid-template-columns:1fr 1fr}}

/* glance bio grid */
.glance{display:grid;grid-template-columns:1.4fr .9fr;gap:56px;align-items:start}
.glance .bio p{color:var(--muted);font-size:clamp(15.5px,1.5vw,18px);line-height:1.7;margin-bottom:18px}
.glance .bio p b{color:var(--ink);font-weight:600}
.glance .aside{background:rgba(255,255,255,.015);padding:26px 26px;border-radius:2px}
.glance .aside .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--signal);margin-bottom:14px;transition:color .6s}
.glance .aside p{color:var(--muted);font-size:14px;line-height:1.6;margin-bottom:18px}
@media(max-width:900px){.glance{grid-template-columns:1fr;gap:34px}}

/* machine-readable rail */
.mrail{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}
.mrail a{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line2);border-radius:30px;padding:9px 15px;transition:.25s}
.mrail a:hover{border-color:var(--signal);color:var(--signal)}

/* credential rows (institutional + press) */
.credrow{display:grid;grid-template-columns:.85fr 1.15fr;gap:34px;padding:28px 0;border-bottom:1px solid var(--line);align-items:baseline}
.credrow:first-child{border-top:1px solid var(--line)}
.credrow .m{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--signal);margin-bottom:10px;transition:color .6s}
.credrow .h{font-family:var(--serif);font-weight:600;font-size:clamp(21px,2.4vw,32px);line-height:1.1;display:block}
.credrow p{color:var(--muted);font-size:15px;line-height:1.6}
.credrow p b{color:var(--ink)}
a.credrow:hover .h{color:var(--signal);transition:color .3s}
@media(max-width:760px){.credrow{grid-template-columns:1fr;gap:12px}}

/* the work · editorial rows (no boxes, no left borders) */
.worksub{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin:44px 0 6px}
.worklist{display:grid;border-top:1px solid var(--line)}
.workrow{display:grid;grid-template-columns:210px 1.1fr 1.5fr;gap:36px;padding:26px 4px;border-bottom:1px solid var(--line);align-items:baseline;transition:background .3s}
.workrow:hover{background:rgba(255,255,255,.02)}
.workrow .code2{font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:rgb(var(--card-rgb,var(--signal-rgb)));text-transform:uppercase}
.workrow h3{font-family:var(--serif);font-weight:600;font-size:clamp(21px,2.2vw,30px);margin:0 0 5px;line-height:1.08}
.workrow h3 .go{font-family:var(--mono);font-size:12px;color:var(--dim);margin-left:10px;transition:color .3s}
.workrow:hover h3 .go{color:rgb(var(--card-rgb,var(--signal-rgb)))}
.workrow .stat{font-family:var(--mono);font-size:11px;color:var(--dim);letter-spacing:.06em;text-transform:uppercase}
.workrow p{color:var(--muted);font-size:15px;line-height:1.6}
@media(max-width:860px){.workrow{grid-template-columns:1fr;gap:8px;padding:24px 4px}.workrow p{margin-top:4px}}

/* operator essay + three proofs */
.essay{max-width:72ch}
.essay p{color:var(--muted);font-size:clamp(16px,1.55vw,19px);line-height:1.75;margin-bottom:22px}
.essay p b{color:var(--ink);font-weight:600}
.proofs{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:50px}
.proofs .pf{border-top:2px solid var(--signal);padding-top:22px;transition:border-color .6s}
.proofs .pf h4{font-family:var(--serif);font-weight:500;font-size:20px;line-height:1.18;margin-bottom:12px}
.proofs .pf p{color:var(--muted);font-size:14.5px;line-height:1.62}
.proofs .pf p b{color:var(--ink)}
@media(max-width:860px){.proofs{grid-template-columns:1fr;gap:22px}}

/* pull quote (departure) */
.pullquote{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(22px,3.1vw,38px);line-height:1.22;color:var(--ink);
  margin:6px 0 22px;max-width:30ch;letter-spacing:-.01em}
.essay .qsrc{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--signal);margin-bottom:30px;transition:color .6s}

/* now board */
.nowboard{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:40px}
.nowboard .nb{background:var(--bg);padding:24px 20px}
.nowboard .nb .st{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--signal);display:flex;align-items:center;gap:7px;transition:color .6s}
.nowboard .nb .st:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--signal);box-shadow:0 0 8px var(--signal);transition:background .6s,box-shadow .6s}
.nowboard .nb .nm{font-family:var(--serif);font-weight:600;font-size:22px;margin:14px 0 6px}
.nowboard .nb .ds{font-family:var(--mono);font-size:11px;color:var(--dim);letter-spacing:.03em;line-height:1.5}
@media(max-width:860px){.nowboard{grid-template-columns:1fr 1fr}}

/* contact */
.contact{min-height:70vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:clamp(60px,10vh,120px) 0}
.contact h2{font-family:var(--serif);font-weight:600;font-size:clamp(40px,7vw,110px);line-height:.92;letter-spacing:-.03em;margin-bottom:30px}
.contact h2 b{color:var(--signal);transition:color .6s}
.contact .cta{font-family:var(--mono);font-size:14px;color:var(--muted);max-width:48ch;margin:0 auto 46px;line-height:1.7}
.contact .links{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.btn{font-family:var(--mono);font-size:13px;letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--line2);padding:16px 28px;border-radius:40px;transition:.3s;position:relative;overflow:hidden;color:var(--ink);display:inline-block}
.btn:hover{border-color:var(--signal);color:#000}
.btn span{position:relative;z-index:2}
.btn::before{content:"";position:absolute;inset:0;background:var(--signal);transform:translateY(101%);transition:transform .35s cubic-bezier(.6,.05,.1,1)}
.btn:hover::before{transform:translateY(0)}
.btn.solid{background:var(--signal);color:#000;border-color:var(--signal);transition:background .6s,color .3s}
.btn.solid::before{background:#fff}

footer{padding:40px var(--pad);border-top:1px solid var(--line);font-family:var(--mono);font-size:11px;color:var(--dim);display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;letter-spacing:.06em;z-index:2;position:relative}
footer a:hover{color:var(--signal)}

.reveal{opacity:0;transform:translateY(30px)}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}

/* ============ MARKETING PAGE COMPONENTS ============ */

/* role list (what Patrick owned, end to end) */
.rolelist{display:grid;gap:0;margin-top:26px;max-width:60ch}
.rolelist .rl{font-family:var(--mono);font-size:13.5px;letter-spacing:.02em;color:var(--muted);padding:14px 0;border-bottom:1px solid var(--line)}
.rolelist .rl:first-child{border-top:1px solid var(--line)}

/* team grid (directed, not solo) */
.teamgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:40px}
.teamgrid .member{background:var(--bg);padding:30px 28px}
.teamgrid .member .role{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--signal);margin-bottom:14px;transition:color .6s}
.teamgrid .member .who{font-family:var(--serif);font-weight:600;font-size:clamp(22px,2.4vw,30px);line-height:1.05;margin-bottom:6px}
.teamgrid .member .tag{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--dim);margin-bottom:16px}
.teamgrid .member p{color:var(--muted);font-size:14.5px;line-height:1.62}
@media(max-width:820px){.teamgrid{grid-template-columns:1fr}}

/* quad grid (4-up lists under a top rule) */
.quadgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:44px 48px;margin-top:40px}
.quadgrid .quad{border-top:2px solid var(--signal);padding-top:22px;transition:border-color .6s}
.quadgrid .quad .qh{font-family:var(--serif);font-weight:600;font-size:20px;line-height:1.15;margin-bottom:16px}
.quadgrid .quad ul{list-style:none;display:grid;gap:11px}
.quadgrid .quad li{color:var(--muted);font-size:14.5px;line-height:1.5;padding-left:18px;position:relative}
.quadgrid .quad li:before{content:"▸";position:absolute;left:0;color:var(--signal);font-size:11px;top:2px;transition:color .6s}
.quadgrid .quad p{color:var(--muted);font-size:14.5px;line-height:1.62}
.quadgrid .quad .qn{color:var(--dim);font-size:12.5px;font-style:italic;margin-top:14px;line-height:1.55}
@media(max-width:820px){.quadgrid{grid-template-columns:1fr;gap:34px}}

/* phase row (campaign phases) */
.phaserow{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:40px}
.phaserow .phase{background:var(--bg);padding:30px 26px}
.phaserow .phase .pnum{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--signal);margin-bottom:16px;transition:color .6s}
.phaserow .phase h4{font-family:var(--serif);font-weight:600;font-size:clamp(19px,2vw,25px);line-height:1.1;margin-bottom:10px}
.phaserow .phase p{color:var(--muted);font-size:14px;line-height:1.6}
@media(max-width:820px){.phaserow{grid-template-columns:1fr}}

/* link list (first-party sources) */
.linklist{display:grid;grid-template-columns:repeat(2,1fr);gap:0 40px;margin-top:20px;max-width:80ch}
.linklist .ll{font-family:var(--mono);font-size:13px;letter-spacing:.02em;color:var(--muted);padding:13px 0;border-bottom:1px solid var(--line);transition:color .25s}
.linklist .ll:hover{color:var(--signal)}
@media(max-width:720px){.linklist{grid-template-columns:1fr}}

/* mini stat wall (impression tests) */
.miniwall{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:36px}
.miniwall .mc{background:var(--bg);padding:26px 22px}
.miniwall .mc .n{font-family:var(--slab);font-size:clamp(34px,4vw,58px);color:var(--signal);line-height:.9;transition:color .6s}
.miniwall .mc .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.05em;color:var(--dim);margin-top:12px;line-height:1.5;text-transform:uppercase}
@media(max-width:820px){.miniwall{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.miniwall{grid-template-columns:1fr}}

/* name grid (influencer roster, linked) */
.namegrid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:40px}
.namegrid .ncard{background:var(--bg);padding:26px 26px;transition:background .3s;display:block}
.namegrid .ncard:hover{background:rgba(255,255,255,.02)}
.namegrid .ncard .who{font-family:var(--serif);font-weight:600;font-size:clamp(20px,2.2vw,26px);line-height:1.05;margin-bottom:4px}
.namegrid .ncard:hover .who{color:var(--signal);transition:color .3s}
.namegrid .ncard .tag{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--dim);margin-bottom:13px}
.namegrid .ncard p{color:var(--muted);font-size:14px;line-height:1.58}
@media(max-width:820px){.namegrid{grid-template-columns:1fr}}

/* soften the solid-black grid cards: let ~14% of the (veiled) node field show through
   so the boxes read as deep charcoal, not harsh pure black. Hover states still win (higher
   specificity). Terminal/boot stay fully opaque on purpose. */
.strip .s,.led,.statwall .cell,.nowboard .nb,.teamgrid .member,.phaserow .phase,.miniwall .mc,.namegrid .ncard{background:rgba(9,11,15,.86)}

/* call list (foresight calls, receipts) */
.calllist{display:grid;margin-top:40px;border-top:1px solid var(--line)}
.calllist .call{display:grid;grid-template-columns:150px 1fr;gap:36px;padding:30px 4px;border-bottom:1px solid var(--line)}
.calllist .call .cdate{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--signal);transition:color .6s}
.calllist .call .cq{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(19px,2vw,26px);line-height:1.28;color:var(--ink);margin-bottom:16px}
.calllist .call .cmeta{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--dim);margin-bottom:8px}
.calllist .call .cmv{color:var(--muted);font-size:14px;line-height:1.6}
@media(max-width:760px){.calllist .call{grid-template-columns:1fr;gap:12px}}

/* end CTA (channel handoff) */
.endcta{font-family:var(--mono);font-size:13px;letter-spacing:.04em;color:var(--muted);margin-top:20px;line-height:1.7}
.endcta a{color:var(--signal);border-bottom:1px solid rgba(var(--signal-rgb),.4);transition:.25s}
.endcta a:hover{border-color:var(--signal)}

/* ===================================================================
   PRINT · tenure dossier PDFs (Playwright, emulate print + print_background)
   Keeps the dark Spectrum identity but flattens the interactive console
   into a clean, paginated document. Generated pages: /tenure/*.
   =================================================================== */
@media print{
  @page{size:Letter;margin:14mm 15mm 16mm}
  html,body{background:var(--bg) !important;color:var(--ink) !important;overflow:visible !important;cursor:auto !important}
  /* kill fixed / interactive / animated chrome */
  #boot,#swarm,#hero3d,.grain,.vignette,.cursor,.cursor-dot,.nav,.hud,.scrollcue,footer{display:none !important}
  /* kill the fish legibility scrim halos (blurred boxes hurt print) */
  .panel .grid>div::before,.hero .claim::before,.hero .hmission::before,.hero .readouts::before,
  .hero .sub::before,.tsec .lead2::before,.tsec .solverow::before,.statwall::before{display:none !important}
  /* everything animated in must be visible on paper */
  .reveal{opacity:1 !important;transform:none !important}
  *,*::before,*::after{animation:none !important;transition:none !important}
  /* self-referential "download this PDF" sections + bottom web-nav are chrome */
  section[data-tag*="FULL DOSSIER"]{display:none !important}
  /* flatten the full-bleed section padding to the page box */
  section{padding-left:0 !important;padding-right:0 !important;z-index:auto !important;position:relative !important}
  .wrap{max-width:none !important}
  /* compact cover (hero) so it doesn't eat a whole sheet */
  .phero{min-height:0 !important;padding-top:2mm !important;padding-bottom:7mm !important;break-after:avoid}
  .phero h1{font-size:30pt !important;line-height:1.02 !important}
  .phero .lede{font-size:11.5pt !important;max-width:none !important}
  .phero .kick{margin-bottom:12px !important}
  .tsec{padding:8mm 0 !important;border-top:1px solid var(--line) !important}
  /* drop heavy glows so ink stays crisp; keep the signal color */
  .bignum,.kpirow .kpi .n,.statwall .cell .n,.miniwall .mc .n,.hud .dot{text-shadow:none !important;box-shadow:none !important}
  /* keep small units intact across page breaks */
  .credrow,.workrow,.statwall .cell,.miniwall .mc,.phaserow .phase,.teamgrid .member,
  .quadgrid .quad,.proofs .pf,.feature,.figframe,.figcap,.led,.namegrid .ncard,
  .calllist .call,.readouts .ro,.solverow{break-inside:avoid;page-break-inside:avoid}
  .eyebrow,h1,h2,h3,h4,.lead2{break-after:avoid;page-break-after:avoid}
  img{max-width:100% !important}
  a{color:inherit !important;border-bottom:0 !important}
  /* start each Part on structural boundaries but avoid orphaned headers */
  .tsec{break-inside:auto}
}
