/* wAIne labs - V1.1
   Forest & Bone, dark-primary. Premium, editorial, de-slopped.
   Anton is reserved for the logo only. Display runs in Young Serif (organic), body in Hanken Grotesk.
   Palette widened: amber (gold) + sky (cool) + clay (rose) used as category accents. */

:root{
  --bg:#13201A; --bg2:#172A22; --panel:#1B3329;
  --bone:#ECE7D7; --bone-dim:#C2C7BA;
  --amber:#D08B4C; --amber-hi:#E6A968;
  --sky:#8DB2CC; --clay:#D29A86;
  --forest:#0E1813; --rule:rgba(236,231,215,0.12); --rule-2:rgba(236,231,215,0.22);
  --muted:#8B988E;
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--bone);font-family:"Hanken Grotesk",-apple-system,sans-serif;font-size:17px;line-height:1.62;-webkit-font-smoothing:antialiased;overflow-x:hidden;position:relative;}
/* film grain texture */
body::before{content:"";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.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
a{color:inherit;text-decoration:none;}
img,svg{display:block;}
.container{max-width:var(--maxw);margin:0 auto;padding:0 32px;position:relative;}

/* ---- type ---- */
.block{font-family:"Anton";transform:skewX(-9deg);display:inline-block;line-height:.85;letter-spacing:-0.01em;}
.block .ai{color:var(--amber);}
.block .labs{font-size:.40em;margin-left:.12em;}
.eyebrow{font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);display:inline-flex;align-items:center;gap:10px;}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--amber);}
.display{font-family:"Young Serif";font-weight:400;line-height:1.02;letter-spacing:-0.005em;}
.dot{color:var(--amber);}
h2.h{font-family:"Young Serif";font-size:clamp(29px,3.8vw,45px);font-weight:400;letter-spacing:0;line-height:1.16;}
h2.h em{font-style:normal;color:var(--amber);}
h2.h .sky{color:var(--sky);font-style:normal;}
.lede{font-size:clamp(18px,2vw,21px);line-height:1.55;color:var(--bone-dim);}
.section{padding:118px 0;border-top:1px solid var(--rule);}
.section.tight{padding:84px 0;}
.idxmark{font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.1em;color:var(--muted);position:absolute;top:-2px;right:32px;}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:"IBM Plex Mono";font-size:12px;letter-spacing:.16em;text-transform:uppercase;padding:15px 28px;border:1px solid var(--amber);color:var(--amber);transition:all .35s var(--ease);position:relative;overflow:hidden;border-radius:2px;}
.btn::after{content:"";position:absolute;inset:0;background:var(--amber);transform:translateY(101%);transition:transform .4s var(--ease);z-index:-1;}
.btn:hover{color:var(--forest);}
.btn:hover::after{transform:translateY(0);}
.btn.solid{background:var(--amber);color:var(--forest);}
.btn.ghost{border-color:var(--rule-2);color:var(--bone);}
.btn.ghost::after{background:var(--bone);}
.arrow{transition:transform .35s var(--ease);}
.btn:hover .arrow{transform:translateX(4px);}

/* ---- nav ---- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:22px 32px;transition:padding .4s var(--ease),background .4s var(--ease),border-color .4s var(--ease);border-bottom:1px solid transparent;}
.nav.scrolled{padding:13px 32px;background:rgba(14,24,19,.8);backdrop-filter:blur(14px);border-bottom:1px solid var(--rule);}
.nav .logo{font-family:"Anton";transform:skewX(-9deg);font-size:24px;}
.nav .logo .ai{color:var(--amber);} .nav .logo .labs{font-size:.42em;margin-left:.1em;}
.nav .links{display:flex;gap:30px;align-items:center;font-family:"IBM Plex Mono";font-size:12px;letter-spacing:.13em;text-transform:uppercase;}
.nav .links a{position:relative;padding:4px 0;color:var(--bone-dim);transition:color .3s;}
.nav .links a:hover,.nav .links a.active{color:var(--bone);}
.nav .links a:not(.cta)::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--amber);transition:width .3s var(--ease);}
.nav .links a:not(.cta):hover::after,.nav .links a.active::after{width:100%;}
.nav .cta{border:1px solid var(--amber);color:var(--amber);padding:10px 16px;border-radius:2px;}
.nav .cta:hover{background:var(--amber);color:var(--forest);}
.navtoggle{display:none;background:none;border:0;color:var(--bone);font-family:"IBM Plex Mono";font-size:12px;letter-spacing:.13em;text-transform:uppercase;cursor:pointer;}

/* ---- marquee ---- */
.marquee{overflow:hidden;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);background:var(--forest);padding:16px 0;white-space:nowrap;}
.marquee .track{display:inline-flex;gap:0;animation:slide 32s linear infinite;}
.marquee span{font-family:"IBM Plex Mono";font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--bone-dim);padding:0 26px;display:inline-flex;align-items:center;gap:26px;}
.marquee span::after{content:"";width:6px;height:6px;border-radius:50%;background:var(--amber);}
.marquee span:nth-child(3n)::after{background:var(--sky);}
.marquee span:nth-child(3n+1)::after{background:var(--clay);}
@keyframes slide{to{transform:translateX(-50%);}}

/* ---- hero ---- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;border:0;padding:150px 0 100px;}
.hero .orbit{position:absolute;top:50%;right:-6%;width:min(82vw,820px);height:min(82vw,820px);transform:translateY(-50%);opacity:.5;pointer-events:none;}
.hero .orbit .spin{transform-origin:100px 100px;animation:spin 90s linear infinite;}
.hero .orbit .spin.rev{animation-duration:140s;animation-direction:reverse;}
@keyframes spin{to{transform:rotate(360deg);}}
.hero .glow{position:absolute;top:46%;right:6%;width:560px;height:560px;transform:translateY(-50%);background:radial-gradient(circle,rgba(208,139,76,.15),transparent 62%);pointer-events:none;}
.hero .glow.two{right:auto;left:8%;top:62%;width:420px;height:420px;background:radial-gradient(circle,rgba(141,178,204,.1),transparent 64%);}
.hero .inner{position:relative;z-index:2;max-width:840px;}
.hero .display{font-size:clamp(58px,11vw,150px);}
.hero .display .ln2{color:var(--bone);}
.hero .lede{margin:34px 0 0;max-width:600px;}
.hero .cta-row{display:flex;gap:16px;margin-top:42px;flex-wrap:wrap;}
.hero .scrollcue{position:absolute;bottom:34px;left:32px;font-family:"IBM Plex Mono";font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:12px;z-index:2;}
.hero .scrollcue .line{width:46px;height:1px;background:linear-gradient(90deg,var(--amber),transparent);}

/* underline detail */
.uline{position:relative;display:inline-block;}
.uline::after{content:"";position:absolute;left:0;right:0;bottom:.08em;height:3px;background:var(--sky);opacity:.55;}

/* ---- premise / equation ---- */
.lead-2{display:grid;grid-template-columns:1.08fr .92fr;gap:60px;align-items:start;}
.qs{margin-top:34px;}
.q{display:flex;gap:18px;padding:22px 0;border-top:1px solid var(--rule);align-items:center;}
.q .mk{font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.1em;width:70px;flex:none;text-transform:uppercase;}
.q.wrong .mk{color:var(--muted);} .q.right .mk{color:var(--amber);}
.q .txt{font-size:21px;font-weight:500;}
.q.wrong .txt{color:var(--muted);}
.q.wrong .txt s{text-decoration-color:rgba(139,152,142,.5);}
.q.right .txt{color:var(--bone);}
.eqcard{background:linear-gradient(160deg,var(--bg2),var(--forest));border:1px solid var(--rule);padding:40px 36px;border-radius:10px;position:relative;overflow:hidden;}
.eqcard .eqlabel{font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);}
.eq{font-family:"Young Serif";font-weight:400;font-size:clamp(25px,3.1vw,40px);letter-spacing:0;margin:20px 0 6px;display:flex;gap:.3em;flex-wrap:wrap;align-items:baseline;}
.eq .op{color:var(--muted);font-weight:400;}
.eq .term{color:var(--bone-dim);}
.eq .tools{color:var(--amber);position:relative;display:inline-block;animation:toolspulse 3.6s var(--ease) infinite;}
@keyframes toolspulse{0%,100%{transform:scale(1);}50%{transform:scale(1.1);}}
.eqcard p{color:var(--bone-dim);font-size:15.5px;margin-top:16px;line-height:1.6;}
.eqcard .hl{color:var(--amber);font-weight:600;}

/* ---- three multipliers ---- */
.mult{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:56px;border:1px solid var(--rule);border-radius:10px;overflow:hidden;}
.mult .m{padding:36px 30px 32px;border-right:1px solid var(--rule);position:relative;transition:background .4s var(--ease);}
.mult .m:hover{background:var(--bg2);}
.mult .m:last-child{border-right:0;}
.mult .m .n{font-family:"IBM Plex Mono";font-size:12px;letter-spacing:.1em;}
.mult .m h3{font-size:23px;font-weight:600;margin:16px 0 10px;}
.mult .m p{font-size:15px;color:var(--bone-dim);line-height:1.55;}
.mult .m .ghost{position:absolute;top:18px;right:22px;font-family:"Young Serif";font-weight:400;font-size:66px;line-height:1;color:var(--rule);letter-spacing:0;}
.mult .m.a .n{color:var(--amber);} .mult .m.a .ghost{color:rgba(208,139,76,.14);}
.mult .m.s .n{color:var(--sky);} .mult .m.s .ghost{color:rgba(141,178,204,.13);}
.mult .m.c .n{color:var(--clay);} .mult .m.c .ghost{color:rgba(210,154,134,.14);}

/* ---- assistant + chat ---- */
.assist{display:grid;grid-template-columns:1fr 410px;gap:64px;align-items:center;}
.caprows{margin-top:30px;}
.caprow{display:grid;grid-template-columns:38px 190px 1fr;gap:24px;padding:24px 0;border-top:1px solid var(--rule);align-items:start;transition:padding-left .35s var(--ease);}
.caprow:hover{padding-left:8px;}
.caprow .num{font-family:"IBM Plex Mono";font-size:13px;}
.caprow:nth-child(1) .num{color:var(--amber);}
.caprow:nth-child(2) .num{color:var(--sky);}
.caprow:nth-child(3) .num{color:var(--clay);}
.caprow h3{font-size:21px;font-weight:600;}
.caprow p{font-size:15px;color:var(--bone-dim);line-height:1.55;}
.phone{background:var(--forest);border:1px solid var(--rule-2);border-radius:24px;padding:22px 18px 26px;box-shadow:0 40px 80px -34px rgba(0,0,0,.75);}
.phone .ph-top{display:flex;align-items:center;gap:10px;padding:4px 8px 16px;border-bottom:1px solid var(--rule);}
.phone .dot{width:9px;height:9px;border-radius:50%;background:var(--sky);color:transparent;}
.phone .ph-top span{font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);}
.chat{display:flex;flex-direction:column;gap:12px;padding:20px 6px 4px;}
.bub{max-width:82%;padding:12px 16px;border-radius:16px;font-size:15px;line-height:1.45;opacity:0;transform:translateY(10px);}
.bub.me{align-self:flex-end;background:var(--amber);color:var(--forest);border-bottom-right-radius:5px;}
.bub.ai{align-self:flex-start;background:var(--bg2);color:var(--bone);border:1px solid var(--rule);border-bottom-left-radius:5px;}
.in-view .bub{animation:bub .5s var(--ease) forwards;}
.in-view .bub:nth-child(1){animation-delay:.15s;}
.in-view .bub:nth-child(2){animation-delay:.7s;}
.in-view .bub:nth-child(3){animation-delay:1.5s;}
.in-view .bub:nth-child(4){animation-delay:2.2s;}
.in-view .bub:nth-child(5){animation-delay:3.0s;}
.in-view .bub:nth-child(6){animation-delay:3.7s;}
@keyframes bub{to{opacity:1;transform:translateY(0);}}

/* ---- case study cards ---- */
.cs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:50px;}
.cs-card{background:var(--bg2);border:1px solid var(--rule);border-radius:10px;padding:30px 28px 26px;display:flex;flex-direction:column;min-height:300px;transition:transform .4s var(--ease),border-color .4s var(--ease);position:relative;overflow:hidden;}
.cs-card::before{content:"";position:absolute;left:0;top:0;height:3px;width:36px;background:var(--amber);transition:width .5s var(--ease);}
.cs-card.s::before{background:var(--sky);} .cs-card.c::before{background:var(--clay);}
.cs-card:hover{transform:translateY(-6px);border-color:var(--rule-2);}
.cs-card:hover::before{width:100%;}
.cs-card .gho{position:absolute;right:18px;bottom:6px;font-family:"Young Serif";font-weight:400;font-size:120px;line-height:1;color:var(--rule);letter-spacing:0;}
.cs-card .kicker{font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--amber);position:relative;z-index:2;}
.cs-card.s .kicker{color:var(--sky);} .cs-card.c .kicker{color:var(--clay);}
.cs-card h3{font-size:25px;font-weight:700;letter-spacing:-0.025em;margin:14px 0 12px;position:relative;z-index:2;line-height:1.12;}
.cs-card p{font-size:15px;color:var(--bone-dim);line-height:1.55;flex:1;position:relative;z-index:2;}
.cs-card .more{font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--bone);margin-top:18px;display:flex;align-items:center;gap:8px;position:relative;z-index:2;}

/* ---- the cluster ---- */
.cluster{margin-top:50px;border:1px solid var(--rule-2);border-radius:14px;background:linear-gradient(155deg,var(--panel),var(--forest));padding:50px 46px;display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center;position:relative;overflow:hidden;}
.cluster .clabel{font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--sky);display:inline-flex;align-items:center;gap:10px;}
.cluster .clabel::before{content:"";width:22px;height:1px;background:var(--sky);}
.cluster h3{font-family:"Young Serif";font-weight:400;font-size:clamp(26px,3vw,38px);margin:16px 0 16px;line-height:1.14;letter-spacing:-0.005em;}
.cluster h3 em{font-style:normal;color:var(--sky);}
.cluster p{color:var(--bone-dim);font-size:16px;line-height:1.62;max-width:540px;}
.cluster .pills{display:flex;gap:10px;flex-wrap:wrap;margin-top:24px;}
.cluster .pill{font-family:"IBM Plex Mono";font-size:10px;letter-spacing:.14em;text-transform:uppercase;padding:8px 14px;border:1px solid var(--rule-2);border-radius:22px;color:var(--bone-dim);}
.cluster .diagram{display:flex;align-items:center;justify-content:center;}
.cluster .diagram svg{width:100%;max-width:340px;height:auto;}
.cluster .diagram .node{fill:var(--bg);stroke:var(--rule-2);stroke-width:1;}
.cluster .diagram .core{fill:var(--sky);}
.cluster .diagram .sat{fill:var(--bone-dim);}
.cluster .diagram .lnk{stroke:var(--rule-2);stroke-width:1;}
.cluster .diagram .pulse{transform-origin:center;animation:pulsering 3.4s var(--ease) infinite;}
@keyframes pulsering{0%{r:30;opacity:.5;}70%{r:96;opacity:0;}100%{opacity:0;}}

/* full case study blocks (work page) */
.cs{padding:96px 0;border-top:1px solid var(--rule);position:relative;}
.cs .cshead{display:flex;align-items:baseline;gap:24px;flex-wrap:wrap;}
.cs .csno{font-family:"IBM Plex Mono";font-size:13px;letter-spacing:.1em;}
.cs.a .csno{color:var(--amber);} .cs.s .csno{color:var(--sky);} .cs.c .csno{color:var(--clay);}
.cs .cstitle{font-family:"Young Serif";font-size:clamp(27px,3.6vw,44px);font-weight:400;letter-spacing:0;line-height:1.1;}
.cs .cssub{font-family:"IBM Plex Mono";font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:8px;}
.cs .tagpill{font-family:"IBM Plex Mono";font-size:10px;letter-spacing:.16em;text-transform:uppercase;padding:6px 12px;border-radius:20px;border:1px solid var(--rule-2);}
.cs.a .tagpill{color:var(--amber);border-color:rgba(208,139,76,.4);}
.cs.s .tagpill{color:var(--sky);border-color:rgba(141,178,204,.4);}
.cs.c .tagpill{color:var(--clay);border-color:rgba(210,154,134,.4);}
.cs .csbody{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:46px;}
.cs .csbody .blk .bl{font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.16em;text-transform:uppercase;border-top:2px solid var(--rule-2);padding-top:14px;}
.cs.a .csbody .blk .bl{color:var(--amber);} .cs.s .csbody .blk .bl{color:var(--sky);} .cs.c .csbody .blk .bl{color:var(--clay);}
.cs .csbody .blk p{font-size:16px;color:var(--bone-dim);line-height:1.6;margin-top:14px;}
.cs .csstats{display:flex;gap:48px;margin-top:46px;flex-wrap:wrap;}
.cs .csstats .s .v{font-family:"Young Serif";font-weight:400;font-size:48px;letter-spacing:0;color:var(--bone);}
.cs.a .csstats .v .ai{color:var(--amber);} .cs.s .csstats .v .ai{color:var(--sky);} .cs.c .csstats .v .ai{color:var(--clay);}
.cs .csstats .s .k{font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:6px;}

/* ---- about ---- */
.about-hero{display:grid;grid-template-columns:1.3fr .7fr;gap:56px;align-items:end;padding-top:170px;}
.portrait{aspect-ratio:4/5;border:1px solid var(--rule-2);border-radius:10px;background:linear-gradient(160deg,var(--panel),var(--forest));display:flex;align-items:flex-end;padding:24px;position:relative;overflow:hidden;}
.portrait .ph{font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);position:relative;z-index:2;}
.portrait .mono-mark{position:absolute;top:-24px;right:-16px;font-family:"Anton";transform:skewX(-9deg);font-size:210px;color:rgba(208,139,76,.08);}
.portrait::after{content:"";position:absolute;left:0;right:0;bottom:0;height:60%;background:linear-gradient(transparent,rgba(141,178,204,.06));}
.bio p{font-size:18px;line-height:1.7;color:var(--bone-dim);margin-top:20px;}
.bio p b{color:var(--bone);font-weight:600;}
.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--rule);border-radius:10px;overflow:hidden;margin-top:60px;}
.stats-row .s{padding:34px 28px;border-right:1px solid var(--rule);}
.stats-row .s:last-child{border-right:0;}
.stats-row .s .v{font-family:"Young Serif";font-weight:400;font-size:52px;letter-spacing:0;color:var(--bone);}
.stats-row .s:nth-child(1) .v .ai{color:var(--amber);}
.stats-row .s:nth-child(2) .v .ai{color:var(--sky);}
.stats-row .s:nth-child(3) .v .ai{color:var(--clay);}
.stats-row .s .k{font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:8px;line-height:1.5;}

/* principles */
.principles{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:1px solid var(--rule);border-radius:10px;overflow:hidden;margin-top:50px;}
.principles .p{padding:32px 30px;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);transition:background .35s var(--ease);}
.principles .p:hover{background:var(--bg2);}
.principles .p:nth-child(2n){border-right:0;}
.principles .p:nth-last-child(-n+2){border-bottom:0;}
.principles .p .n{font-family:"IBM Plex Mono";font-size:12px;}
.principles .p:nth-child(1) .n{color:var(--amber);}
.principles .p:nth-child(2) .n{color:var(--sky);}
.principles .p:nth-child(3) .n{color:var(--clay);}
.principles .p:nth-child(4) .n{color:var(--amber);}
.principles .p h3{font-size:20px;font-weight:600;margin:14px 0 8px;}
.principles .p p{font-size:15px;color:var(--bone-dim);line-height:1.55;}

/* ---- CTA band ---- */
.cta-band{padding:118px 0;border-top:1px solid var(--rule);text-align:center;position:relative;overflow:hidden;}
.cta-band .glow{position:absolute;top:50%;left:50%;width:680px;height:480px;transform:translate(-50%,-50%);background:radial-gradient(ellipse,rgba(208,139,76,.13),transparent 65%);}
.cta-band .glow.two{left:34%;background:radial-gradient(ellipse,rgba(141,178,204,.08),transparent 66%);}
.cta-band .inner{position:relative;z-index:2;}
.cta-band .display{font-size:clamp(40px,6vw,80px);}
.cta-band p{color:var(--bone-dim);max-width:520px;margin:22px auto 0;}
.cta-band .btn{margin-top:38px;}

/* ---- footer ---- */
.footer{background:var(--forest);border-top:1px solid var(--rule);padding:70px 0 44px;}
.footer .top{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap;}
.footer .big{font-family:"Anton";transform:skewX(-9deg);font-size:60px;}
.footer .big .ai{color:var(--amber);} .footer .big .labs{font-size:.4em;margin-left:.1em;}
.footer .tagline{font-family:"IBM Plex Mono";font-size:12px;letter-spacing:.1em;color:var(--muted);margin-top:16px;}
.footer .cols{display:flex;gap:64px;}
.footer .col h4{font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;}
.footer .col a,.footer .col div{display:block;font-size:14px;color:var(--bone-dim);margin-bottom:9px;transition:color .3s;}
.footer .col a:hover{color:var(--amber);}
.footer .base{display:flex;justify-content:space-between;margin-top:54px;padding-top:22px;border-top:1px solid var(--rule);font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.1em;color:var(--muted);flex-wrap:wrap;gap:12px;}

/* ---- reveal ---- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s;} .reveal.d2{transition-delay:.16s;} .reveal.d3{transition-delay:.24s;} .reveal.d4{transition-delay:.32s;}

/* ---- responsive ---- */
@media(max-width:900px){
  .nav .links{position:fixed;inset:0;height:100dvh;background:var(--bg);flex-direction:column;justify-content:center;align-items:center;gap:26px;font-size:18px;opacity:0;visibility:hidden;transform:translateY(-10px);transition:opacity .4s var(--ease),transform .4s var(--ease),visibility .4s;z-index:90;}
  .nav .links.open{opacity:1;visibility:visible;transform:none;}
  .nav .links a{color:var(--bone);}
  .nav .links .cta{padding:14px 24px;}
  .navtoggle{display:block;position:relative;z-index:101;}
  .nav .logo{position:relative;z-index:101;}
  .idxmark{display:none;}
  .lead-2,.assist,.about-hero,.cluster{grid-template-columns:1fr;gap:40px;}
  .cluster{padding:38px 26px;}
  .cluster .diagram{order:-1;}
  .mult,.cs-grid,.cs .csbody,.stats-row,.principles{grid-template-columns:1fr;}
  .mult .m,.stats-row .s{border-right:0;border-bottom:1px solid var(--rule);}
  .principles .p{border-right:0;}
  .footer .top{flex-direction:column;}
  .caprow{grid-template-columns:32px 1fr;}
  .caprow p{grid-column:1/-1;}
  .hero .orbit{right:-30%;opacity:.32;}
}
@media print, (prefers-reduced-motion:reduce){
  *{animation:none!important;}
  .reveal{opacity:1!important;transform:none!important;}
  .bub{opacity:1!important;transform:none!important;}
}

/* =========================================================
   V1.2 — Executive elevation
   amber-led restraint · editorial proof · bespoke sections
   ========================================================= */

/* No-JS fallback: never hide content unless JS confirmed live */
html:not(.js-loaded) .reveal{opacity:1!important;transform:none!important;}
html:not(.js-loaded) .bub{opacity:1!important;transform:none!important;}

/* Accent restraint: amber leads everywhere; sky/clay survive only in diagrams + marquee */
.mult .m.s .n,.mult .m.c .n{color:var(--amber);}
.mult .m.s .ghost,.mult .m.c .ghost{color:var(--rule);}
.caprow:nth-child(2) .num,.caprow:nth-child(3) .num{color:var(--amber);}
.cs-card.s::before,.cs-card.c::before{background:var(--amber);}
.cs-card.s .kicker,.cs-card.c .kicker{color:var(--amber);}
.cs.s .csno,.cs.c .csno{color:var(--amber);}
.cs.s .tagpill,.cs.c .tagpill{color:var(--amber);border-color:rgba(208,139,76,.4);}
.cs.s .csbody .blk .bl,.cs.c .csbody .blk .bl{color:var(--amber);}
.cs.s .csstats .v .ai,.cs.c .csstats .v .ai{color:var(--amber);}
.stats-row .s:nth-child(2) .v .ai,.stats-row .s:nth-child(3) .v .ai{color:var(--amber);}
.principles .p:nth-child(2) .n,.principles .p:nth-child(3) .n{color:var(--amber);}

/* Proof authority: bigger stat numerals, hairline framed */
.cs .csstats{gap:clamp(34px,5vw,76px);}
.cs .csstats .s{padding-top:18px;border-top:1px solid var(--rule-2);}
.cs .csstats .s .v{font-size:clamp(54px,6vw,82px);line-height:.9;}
.stats-row .s .v{font-size:clamp(46px,4.4vw,58px);}

/* Signature discretion moment: typing dots before the assistant replies */
.bub.ai.typing{display:inline-flex;gap:5px;align-items:center;padding:14px 16px;max-width:none;}
.bub.ai.typing span{width:6px;height:6px;border-radius:50%;background:var(--bone-dim);opacity:.35;animation:blink 1.3s infinite;}
.bub.ai.typing span:nth-child(2){animation-delay:.18s;} .bub.ai.typing span:nth-child(3){animation-delay:.36s;}
@keyframes blink{0%,60%,100%{opacity:.22;}30%{opacity:.95;}}
.in-view .bub.declass{animation:bub .5s var(--ease) forwards, declass .8s var(--ease) forwards;}
@keyframes declass{from{filter:blur(5px);}to{filter:blur(0);}}

/* ---- editorial section: The engagement (How it works, done bespoke) ---- */
.engage{margin-top:20px;border-top:1px solid var(--rule-2);}
.engage .step{display:grid;grid-template-columns:130px 1fr 300px;gap:44px;padding:40px 0;border-bottom:1px solid var(--rule);align-items:baseline;transition:padding-left .4s var(--ease);}
.engage .step:hover{padding-left:10px;}
.engage .step .no{font-family:"Young Serif";font-size:62px;line-height:.8;color:var(--bone);}
.engage .step .no b{color:var(--amber);font-weight:400;}
.engage .step h3{font-family:"Young Serif";font-size:25px;font-weight:400;letter-spacing:-0.005em;}
.engage .step .meta{font-size:15px;color:var(--bone-dim);line-height:1.6;}
.engage .step .tagm{font-family:"IBM Plex Mono";font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);}

/* ---- editorial section: The covenant (confidentiality, done bespoke) ---- */
.covenant{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;margin-top:8px;}
.covenant .lead h2{font-family:"Young Serif";font-weight:400;font-size:clamp(28px,3.4vw,42px);line-height:1.14;letter-spacing:-0.005em;}
.covenant .lead h2 em{font-style:normal;color:var(--amber);}
.covenant .lead p{color:var(--bone-dim);font-size:16px;line-height:1.62;margin-top:22px;max-width:460px;}
.covenant .terms .t{display:grid;grid-template-columns:30px 1fr;gap:18px;padding:22px 0;border-top:1px solid var(--rule);}
.covenant .terms .t:first-child{border-top:0;}
.covenant .terms .t .tk{font-family:"IBM Plex Mono";font-size:12px;color:var(--amber);padding-top:3px;}
.covenant .terms .t h4{font-size:17px;font-weight:600;}
.covenant .terms .t p{font-size:14.5px;color:var(--bone-dim);line-height:1.55;margin-top:5px;}

/* ---- The evidence (cited proof band, editorial) ---- */
.evidence{background:var(--forest);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);}
.proofrow{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:30px;}
.proofrow .pf{padding:6px 36px 6px 0;border-left:1px solid var(--rule);padding-left:32px;}
.proofrow .pf:first-child{border-left:0;padding-left:0;}
.proofrow .pf .v{font-family:"Young Serif";font-size:clamp(44px,5vw,66px);line-height:.9;color:var(--amber);}
.proofrow .pf .c{font-size:15px;color:var(--bone-dim);line-height:1.5;margin-top:14px;max-width:280px;}
.proofrow .pf .src{font-family:"IBM Plex Mono";font-size:9.5px;letter-spacing:.06em;color:var(--muted);margin-top:12px;}

/* ---- The invitation (refined intake, editorial underline fields) ---- */
.invite{max-width:600px;margin:30px auto 0;text-align:left;}
.invite .row{display:grid;grid-template-columns:1fr 1fr;gap:30px;}
.invite .fld{margin-bottom:26px;}
.invite label{display:block;font-family:"IBM Plex Mono";font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:10px;}
.invite input,.invite textarea{width:100%;background:transparent;border:0;border-bottom:1px solid var(--rule-2);color:var(--bone);font-family:"Young Serif";font-size:20px;padding:6px 0 10px;transition:border-color .3s var(--ease);}
.invite input::placeholder,.invite textarea::placeholder{color:var(--muted);font-family:"Hanken Grotesk";font-size:16px;}
.invite input:focus,.invite textarea:focus{outline:0;border-color:var(--amber);}
.invite .actions{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-top:14px;flex-wrap:wrap;}
.invite .note{font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.04em;color:var(--muted);max-width:320px;line-height:1.5;}

/* who it is for / not for */
.fitline{display:grid;grid-template-columns:1fr 1fr;gap:44px;margin-top:54px;border-top:1px solid var(--rule);padding-top:34px;}
.fitline .ti{font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--amber);}
.fitline .f2 .ti{color:var(--muted);}
.fitline p{font-size:17px;color:var(--bone-dim);line-height:1.55;margin-top:14px;}

/* refined focus-visible for accessibility */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,.btn:focus-visible{outline:2px solid var(--amber);outline-offset:3px;}

/* ---- mobile elevation ---- */
@media(max-width:900px){
  .section{padding:70px 0;}
  .section.tight{padding:52px 0;}
  .cta-band{padding:74px 0;}
  .container{padding:0 22px;}
  .hero{padding:120px 0 80px;}
  .hero .display{font-size:clamp(42px,13vw,64px);word-break:break-word;}
  .btn{min-height:48px;padding:14px 24px;}
  .nav .cta{min-height:44px;}
  .hero .cta-row{flex-direction:column;align-items:stretch;}
  .hero .cta-row .btn{width:100%;justify-content:center;}
  .chat-wrap{display:flex;justify-content:center;}
  .phone{max-width:360px;width:100%;}
  .cluster .diagram{order:1;}
  .engage .step{grid-template-columns:64px 1fr;gap:20px;}
  .engage .step .meta{grid-column:1/-1;}
  .engage .step .tagm{display:none;}
  .covenant,.proofrow,.invite .row,.fitline{grid-template-columns:1fr;gap:32px;}
  .proofrow .pf{border-left:0;padding-left:0;border-top:1px solid var(--rule);padding-top:24px;margin-top:0;}
}
@media(max-width:480px){
  .section{padding:58px 0;}
  .container{padding:0 18px;}
  .hero .display{font-size:clamp(38px,14vw,54px);}
}

/* =========================================================
   V1.3 — charts, side projects, scroll motion
   ========================================================= */

/* scroll progress bar */
.scrollprog{position:fixed;top:0;left:0;height:2px;width:0;background:linear-gradient(90deg,var(--amber),var(--amber-hi));z-index:200;will-change:width;}

/* parallax drift (driven by JS via --py) */
[data-parallax]{will-change:transform;transform:translateY(var(--py,0));}

/* clip-wipe reveal for hero/section headings */
.reveal-clip{clip-path:inset(0 100% 0 0);opacity:0;transition:clip-path 1.1s var(--ease),opacity .6s var(--ease);}
.reveal-clip.in{clip-path:inset(0 0 0 0);opacity:1;}

/* ---- bar chart ---- */
.chart{margin-top:26px;}
.chart .bars{display:flex;align-items:flex-end;gap:16px;height:150px;}
.chart .bar{flex:1;display:flex;flex-direction:column;justify-content:flex-end;height:100%;}
.chart .bar .fill{width:100%;border-radius:5px 5px 0 0;height:var(--h,40%);background:var(--rule-2);transform:scaleY(0);transform-origin:bottom;transition:transform 1s var(--ease);}
.chart .bar.amber .fill{background:linear-gradient(var(--amber-hi),var(--amber));}
.chart.in .bar .fill,.in .chart .bar .fill{transform:scaleY(1);}
.chart .bar:nth-child(2) .fill{transition-delay:.12s;}
.chart .bar:nth-child(3) .fill{transition-delay:.24s;}
.chart .bar:nth-child(4) .fill{transition-delay:.36s;}
.chart .bar .lab{font-family:"IBM Plex Mono";font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:12px;text-align:center;}
.chart .bar .val{font-family:"Young Serif";font-size:18px;color:var(--bone);text-align:center;margin-top:2px;}
.chart .bar.amber .val{color:var(--amber);}

/* sparkline for case stats */
.spark{width:100%;height:34px;margin-top:14px;overflow:visible;}
.spark path.ln{fill:none;stroke:var(--amber);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:200;stroke-dashoffset:200;transition:stroke-dashoffset 1.4s var(--ease);}
.in .spark path.ln,.spark.in path.ln{stroke-dashoffset:0;}
.spark path.area{fill:url(#sparkfill);opacity:0;transition:opacity 1s var(--ease) .4s;}
.in .spark path.area{opacity:.18;}

/* ---- side projects ---- */
.projhead{display:grid;grid-template-columns:1.2fr .8fr;gap:50px;align-items:end;padding-top:170px;}
.proj-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:54px;}
.proj{position:relative;border:1px solid var(--rule);border-radius:12px;overflow:hidden;background:var(--bg2);min-height:300px;display:flex;flex-direction:column;justify-content:space-between;padding:32px 32px 28px;transition:transform .5s var(--ease),border-color .5s var(--ease);}
.proj:hover{transform:translateY(-7px);border-color:var(--rule-2);}
.proj .art{position:absolute;inset:0;opacity:.5;pointer-events:none;}
.proj .art svg{width:100%;height:100%;}
.proj .ptop{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:flex-start;}
.proj .pno{font-family:"IBM Plex Mono";font-size:12px;color:var(--amber);letter-spacing:.1em;}
.proj .pstatus{font-family:"IBM Plex Mono";font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--bone-dim);border:1px solid var(--rule-2);border-radius:20px;padding:5px 11px;}
.proj .pbody{position:relative;z-index:2;}
.proj h3{font-family:"Young Serif";font-size:32px;font-weight:400;letter-spacing:-0.01em;}
.proj .ptag{font-family:"IBM Plex Mono";font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--amber);margin-bottom:10px;}
.proj p{font-size:15px;color:var(--bone-dim);line-height:1.55;margin-top:10px;max-width:380px;}
.proj.wide{grid-column:1/-1;min-height:240px;}
.proj.wide .pbody{max-width:560px;}
@media(max-width:900px){
  .projhead{grid-template-columns:1fr;gap:30px;padding-top:140px;}
  .proj-grid{grid-template-columns:1fr;}
  .proj.wide{grid-column:auto;}
  .chart .bars{height:120px;}
}

/* ---- compounding curve (refined, replaces the bar chart) ---- */
.curve{margin-top:26px;}
.curve svg{width:100%;height:auto;overflow:visible;display:block;}
.curve .axis{stroke:var(--rule);stroke-width:1;}
.curve .grid{stroke:var(--rule);stroke-width:1;stroke-dasharray:2 5;opacity:.6;}
.curve .ln{fill:none;stroke:var(--amber);stroke-width:2.5;stroke-linecap:round;stroke-dasharray:640;stroke-dashoffset:640;transition:stroke-dashoffset 1.7s var(--ease);}
.in .curve .ln,.curve.in .ln{stroke-dashoffset:0;}
.curve .ar{fill:url(#curvefill);opacity:0;transition:opacity 1.1s var(--ease) .55s;}
.in .curve .ar,.curve.in .ar{opacity:1;}
.curve .end{opacity:0;transition:opacity .5s var(--ease) 1.55s;}
.in .curve .end,.curve.in .end{opacity:1;}
.curve .lab{font-family:"IBM Plex Mono";font-size:8.5px;letter-spacing:.14em;text-transform:uppercase;fill:var(--muted);}
.curvecap{display:flex;justify-content:space-between;align-items:baseline;margin-top:14px;}
.curvecap .c1{font-family:"IBM Plex Mono";font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);}
.curvecap .c2{font-family:"Young Serif";font-size:17px;color:var(--amber);}

/* ---- side projects: case-study rows with action shots ---- */
.projcase{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;padding:64px 0;border-top:1px solid var(--rule);}
.projcase:first-of-type{border-top:0;}
.projcase.flip .shot{order:2;}
.projcase .shot{border:1px solid var(--rule-2);border-radius:12px;overflow:hidden;background:var(--bg2);box-shadow:0 36px 80px -40px rgba(0,0,0,.7);transition:transform .6s var(--ease);}
.projcase:hover .shot{transform:translateY(-6px);}
.projcase .shot img{width:100%;display:block;}
.projcase .pno{font-family:"IBM Plex Mono";font-size:12px;letter-spacing:.1em;color:var(--amber);}
.projcase .ptag{font-family:"IBM Plex Mono";font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin:14px 0 6px;}
.projcase h3{font-family:"Young Serif";font-size:clamp(30px,3.6vw,44px);font-weight:400;letter-spacing:-0.01em;line-height:1.04;}
.projcase .lead{font-size:17px;color:var(--bone-dim);line-height:1.6;margin-top:18px;max-width:460px;}
.projcase .meta{display:flex;gap:36px;margin-top:26px;}
.projcase .meta .m .mk{font-family:"IBM Plex Mono";font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);}
.projcase .meta .m .mv{font-size:15px;color:var(--bone);margin-top:5px;}
.projcase .meta .m .mv.amber{color:var(--amber);}
.projmore{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:54px;}
.projmore .pm{border:1px solid var(--rule);border-radius:12px;padding:30px;background:var(--bg2);transition:transform .5s var(--ease),border-color .5s var(--ease);}
.projmore .pm:hover{transform:translateY(-6px);border-color:var(--rule-2);}
.projmore .pm .ptop{display:flex;justify-content:space-between;align-items:flex-start;}
.projmore .pm .pstatus{font-family:"IBM Plex Mono";font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--bone-dim);border:1px solid var(--rule-2);border-radius:20px;padding:5px 11px;}
.projmore .pm .ptag{font-family:"IBM Plex Mono";font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--amber);}
.projmore .pm h3{font-family:"Young Serif";font-size:26px;font-weight:400;margin:12px 0 8px;}
.projmore .pm p{font-size:14.5px;color:var(--bone-dim);line-height:1.55;}
@media(max-width:900px){
  .projcase{grid-template-columns:1fr;gap:26px;padding:44px 0;}
  .projcase.flip .shot{order:0;}
  .projmore{grid-template-columns:1fr;}
}

/* ---- side projects v2: bigger showcases, browser + phone frames ---- */
.browser{border:1px solid var(--rule-2);border-radius:12px;overflow:hidden;box-shadow:0 40px 90px -44px rgba(0,0,0,.75);background:#0e1813;}
.browser .bbar{display:flex;align-items:center;gap:7px;padding:11px 14px;background:var(--forest);border-bottom:1px solid var(--rule);}
.browser .bbar i{width:10px;height:10px;border-radius:50%;background:var(--rule-2);display:block;}
.browser .bbar .url{margin-left:12px;font-family:"IBM Plex Mono";font-size:10px;letter-spacing:.06em;color:var(--muted);}
.browser img{width:100%;display:block;}
.projcase{padding:84px 0;}
.projcase .lead{font-size:18px;max-width:480px;}
.projcase .feats{display:flex;flex-wrap:wrap;gap:9px;margin-top:24px;}
.projcase .feats span{font-family:"IBM Plex Mono";font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--bone-dim);border:1px solid var(--rule-2);border-radius:20px;padding:6px 12px;}

.tiltfeature{padding:84px 0;border-top:1px solid var(--rule);}
.tiltfeature .tf-copy{max-width:660px;}
.badge{display:inline-flex;align-items:center;gap:8px;font-family:"IBM Plex Mono";font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--amber);border:1px solid rgba(208,139,76,.4);border-radius:20px;padding:6px 13px;}
.phones{display:flex;gap:22px;justify-content:center;align-items:flex-start;margin-top:46px;}
.iphone{width:212px;flex:none;border:9px solid #0a1310;border-radius:32px;background:#000;overflow:hidden;box-shadow:0 44px 90px -38px rgba(0,0,0,.82);}
.iphone img{width:100%;display:block;}
.iphone.up{transform:translateY(-26px);}
@media(max-width:900px){
  .tiltfeature .phones{flex-wrap:wrap;gap:14px;}
  .iphone{width:30%;min-width:104px;border-width:6px;border-radius:20px;}
  .iphone.up{transform:none;}
  .projcase{padding:48px 0;}
}

/* ---- proof callout (replaces the cramped eqcard chart) ---- */
.proofline{margin-top:28px;border-top:1px solid var(--rule);padding-top:24px;}
.proofline .big{font-family:"Young Serif";font-size:56px;line-height:.85;color:var(--amber);}
.proofline .txt{font-size:15.5px;color:var(--bone-dim);line-height:1.58;margin-top:14px;}
.proofline .txt b{color:var(--bone);font-weight:600;}
.proofline .src{font-family:"IBM Plex Mono";font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:14px;}

/* ---- the executive's week (real, full-width graph) ---- */
.weekbar{display:flex;height:68px;border-radius:9px;overflow:hidden;margin-top:38px;border:1px solid var(--rule-2);}
.weekbar .seg{display:flex;align-items:center;padding:0 20px;font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.14em;text-transform:uppercase;white-space:nowrap;overflow:hidden;}
.weekbar .seg.meet{width:8%;background:repeating-linear-gradient(45deg,#1c2c23,#1c2c23 7px,#162720 7px,#162720 14px);color:var(--bone-dim);transition:width 1.6s var(--ease);}
.in .weekbar .seg.meet,.weekbar.in .seg.meet{width:72%;}
.weekbar .seg.rest{flex:1;background:linear-gradient(180deg,var(--amber-hi),var(--amber));color:var(--forest);font-weight:600;}
.weekcap{display:flex;justify-content:space-between;margin-top:16px;font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.06em;color:var(--muted);flex-wrap:wrap;gap:12px;}
.weekcap b{color:var(--amber);font-weight:500;}
@media(max-width:900px){.weekbar{height:60px;}.weekbar .seg{padding:0 13px;font-size:9px;letter-spacing:.08em;}}

/* ---- capabilities: what it actually does ---- */
.capgrid{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--rule);border-radius:10px;overflow:hidden;margin-top:44px;}
.capgrid .cap{padding:28px 24px;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);transition:background .35s var(--ease);}
.capgrid .cap:hover{background:var(--bg2);}
.capgrid .cap:nth-child(4n){border-right:0;}
.capgrid .cap:nth-last-child(-n+4){border-bottom:0;}
.capgrid .cap .ci{font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.1em;color:var(--amber);}
.capgrid .cap h3{font-size:17px;font-weight:600;margin:13px 0 8px;}
.capgrid .cap p{font-size:14px;color:var(--bone-dim);line-height:1.52;}
.capnote{font-size:16px;color:var(--bone-dim);margin-top:24px;max-width:680px;}
.capnote b{color:var(--amber);font-weight:500;}

/* ---- a day with it (timeline) ---- */
.daywrap{margin-top:46px;border-top:1px solid var(--rule-2);}
.dayrow{display:grid;grid-template-columns:96px 1fr;gap:30px;padding:24px 0;border-bottom:1px solid var(--rule);align-items:baseline;transition:padding-left .35s var(--ease);}
.dayrow:hover{padding-left:8px;}
.dayrow .t{font-family:"IBM Plex Mono";font-size:13px;letter-spacing:.08em;color:var(--amber);}
.dayrow p{font-size:17px;color:var(--bone-dim);line-height:1.5;max-width:680px;}
.dayrow p b{color:var(--bone);font-weight:600;}

/* ---- FAQ ---- */
.faq{margin-top:44px;border-top:1px solid var(--rule-2);}
.faq .qa{display:grid;grid-template-columns:1fr 1.1fr;gap:44px;padding:30px 0;border-bottom:1px solid var(--rule);}
.faq .qa .q{font-family:"Young Serif";font-size:21px;font-weight:400;line-height:1.22;letter-spacing:-0.005em;}
.faq .qa .a{font-size:16px;color:var(--bone-dim);line-height:1.62;}
@media(max-width:900px){
  .capgrid{grid-template-columns:1fr 1fr;}
  .capgrid .cap:nth-child(4n){border-right:1px solid var(--rule);}
  .capgrid .cap:nth-child(2n){border-right:0;}
  .capgrid .cap:nth-last-child(-n+4){border-bottom:1px solid var(--rule);}
  .capgrid .cap:nth-last-child(-n+2){border-bottom:0;}
  .dayrow{grid-template-columns:70px 1fr;gap:18px;}
  .dayrow p{font-size:15px;}
  .faq .qa{grid-template-columns:1fr;gap:10px;}
}
@media(max-width:560px){ .capgrid{grid-template-columns:1fr;} .capgrid .cap{border-right:0!important;border-bottom:1px solid var(--rule)!important;} .capgrid .cap:last-child{border-bottom:0!important;} }

/* ---- about portrait: the wizard ---- */
.portrait.wiz{padding:0;background:radial-gradient(ellipse at 50% 32%, #213a2d, var(--forest) 70%);}
.portrait.wiz .wizimg{position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:106%;max-width:none;z-index:2;filter:drop-shadow(0 30px 50px rgba(0,0,0,.45));}
.portrait.wiz .wiztitle{position:absolute;top:18px;left:0;right:0;text-align:center;z-index:3;font-family:"Anton";transform:skewX(-9deg);font-size:clamp(32px,4.6vw,50px);color:var(--amber);letter-spacing:-0.01em;text-shadow:0 6px 26px rgba(0,0,0,.55);pointer-events:none;}
.portrait.wiz .ph{position:absolute;bottom:16px;left:0;right:0;text-align:center;z-index:4;}
.portrait.wiz::after{height:46%;background:linear-gradient(transparent,rgba(14,24,19,.85));}

/* about portrait: plain photo */
.portrait .pphoto{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 30%;z-index:0;}

/* about portrait: editorial illustration on a bone card */
.portrait.illus{padding:0;display:block;background:var(--bone);border-color:var(--rule-2);}
.portrait.illus::after{display:none;}
.portrait.illus .illusimg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 6%;}
.pcap{font-family:"IBM Plex Mono";font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:15px;}
