/* ============================================================
   3nuggets — The Operator — shared styles (Warm + Acid themes)
   ============================================================ */

:root,
[data-theme="warm"]{
  --bg:#f4ede0; --surface:#e9e0cd;
  --fg:#161106; --fg-2:#4c4030; --fg-3:#8a7d68;
  --line:rgba(22,17,6,.14);
  --accent:#e0a24a; --accent-deep:#b87a32; --accent-fg:#161106;
  --accent-2:#d64321;
  --panel-bg:#161106; --panel-fg:#f4ede0; --panel-muted:rgba(244,237,224,.78);
  --loud-bg:#161106; --loud-fg:#f4ede0; --loud-star:#e0a24a;
  --term-bg:#0c0a06;
  --header-bg:rgba(244,237,224,.85);
  --ph-a:#e9e0cd; --ph-b:#ddd2bb;
  --shadow:rgba(22,17,6,1);
}
[data-theme="acid"]{
  --bg:#0c0d0a; --surface:#15170f;
  --fg:#eef1e3; --fg-2:#b6bda6; --fg-3:#7c8369;
  --line:rgba(238,241,227,.16);
  --accent:#c6f24e; --accent-deep:#a9d63a; --accent-fg:#0c0d0a;
  --accent-2:#ff6a3d;
  --panel-bg:#14160f; --panel-fg:#eef1e3; --panel-muted:rgba(238,241,227,.72);
  --loud-bg:#c6f24e; --loud-fg:#0c0d0a; --loud-star:rgba(12,13,10,.55);
  --term-bg:#070804;
  --header-bg:rgba(12,13,10,.85);
  --ph-a:#15170f; --ph-b:#20241a;
  --shadow:#c6f24e;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;background:var(--bg);color:var(--fg);font-family:"Inter",system-ui,sans-serif;line-height:1.55;-webkit-font-smoothing:antialiased;transition:background .25s ease,color .25s ease;}
a{color:inherit;}
.wrap{max-width:1180px;margin:0 auto;padding:0 34px;}
.mono{font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.04em;color:var(--fg-3);}
.tag{display:inline-flex;align-items:center;gap:8px;font-family:"JetBrains Mono",monospace;font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent-fg);background:var(--accent);padding:6px 12px;border-radius:999px;}

/* ---- header ---- */
header{position:sticky;top:0;z-index:50;background:var(--header-bg);backdrop-filter:blur(10px);border-bottom:2px solid var(--fg);}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px;gap:18px;}
.logo{font-family:"Fraunces",serif;font-weight:800;font-size:22px;letter-spacing:-.02em;text-decoration:none;color:var(--fg);display:inline-flex;align-items:center;}
.logo img{height:26px;width:auto;}
.nav .logo .logo-acid{display:block;}
.nav .logo .logo-warm{display:none;}
[data-theme="warm"] .nav .logo .logo-acid{display:none;}
[data-theme="warm"] .nav .logo .logo-warm{display:block;}
.navlinks{display:flex;gap:24px;align-items:center;}
.navlinks a:not(.btn){font-size:14px;font-weight:500;color:var(--fg-2);text-decoration:none;}
.navlinks a:not(.btn):hover{color:var(--fg);}
.navlinks a.btn{color:var(--bg);}
.navlinks a.btn-gold{color:var(--accent-fg);}
.navlinks a.btn-out{color:var(--fg);}

/* theme switch */
.themesw{display:none;}  /* theme switch hidden — site is acid-only */
.themesw button{font-family:"JetBrains Mono",monospace;font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;padding:7px 12px;border:0;background:transparent;color:var(--fg-2);cursor:pointer;transition:.15s;}
.themesw button[aria-pressed="true"]{background:var(--fg);color:var(--bg);}

/* buttons */
.btn{font-weight:700;font-size:14.5px;border-radius:8px;padding:11px 18px;text-decoration:none;display:inline-flex;align-items:center;gap:8px;border:2px solid var(--fg);cursor:pointer;transition:transform .14s,box-shadow .14s,background .15s;background:var(--fg);color:var(--bg);font-family:"Inter",sans-serif;}
.btn:hover{transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--shadow);}
.btn-gold{background:var(--accent);color:var(--accent-fg);border-color:var(--accent);}
/* gold buttons: force dark (near-black) text, immune to any descendant color rule */
a.btn-gold,.btn.btn-gold{color:var(--accent-fg);}
.btn-out{background:transparent;color:var(--fg);}
.btn-lg{padding:16px 26px;font-size:17px;}

/* ---- hero ---- */
.hero{padding:64px 0 26px;}
.kicker{display:flex;align-items:center;gap:14px;margin-bottom:28px;flex-wrap:wrap;}
h1{font-family:"Fraunces",serif;font-weight:800;font-size:clamp(46px,7.6vw,104px);line-height:.94;letter-spacing:-.035em;margin:0;}
h1 .out{color:transparent;-webkit-text-stroke:2px var(--fg);}
h1 em{font-style:italic;color:var(--accent-deep);font-weight:700;}
.herobody{display:grid;grid-template-columns:1.15fr .85fr;gap:44px;margin-top:40px;align-items:center;}
.herobody .big{font-family:"Fraunces",serif;font-size:23px;line-height:1.32;font-weight:500;margin:0 0 26px;max-width:30ch;}
.herobody .big b{font-weight:700;font-style:italic;color:var(--accent-deep);}
.ctastack{display:flex;flex-direction:column;gap:12px;border:2px solid var(--fg);border-radius:14px;padding:22px;background:var(--surface);}
.ctastack .row{display:flex;align-items:center;gap:14px;}
.ctastack .lvl{font-family:"JetBrains Mono",monospace;font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-3);width:48px;flex:none;}
.ctastack .btn{flex:1;justify-content:space-between;}

/* hero portrait */
.heroportrait{position:relative;}
.heroportrait .frame{aspect-ratio:4/5;border:2px solid var(--fg);border-radius:16px;overflow:hidden;box-shadow:8px 8px 0 var(--accent);}
.ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;text-align:center;padding:16px;
    background:repeating-linear-gradient(45deg,var(--ph-a),var(--ph-a) 12px,var(--ph-b) 12px,var(--ph-b) 24px);
    font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--fg-3);}
.heroportrait .name{position:absolute;left:14px;bottom:14px;display:flex;align-items:center;gap:9px;background:var(--fg);color:var(--bg);font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.04em;padding:7px 12px;border-radius:999px;}
.heroportrait .name .live{width:8px;height:8px;border-radius:50%;background:var(--accent);}

/* marquee */
.marquee{border-top:2px solid var(--fg);border-bottom:2px solid var(--fg);background:var(--loud-bg);color:var(--loud-fg);overflow:hidden;white-space:nowrap;padding:14px 0;}
.marquee .track{display:inline-block;animation:scroll 26s linear infinite;font-family:"Fraunces",serif;font-style:italic;font-size:26px;font-weight:600;}
.marquee .track span{margin:0 24px;}
.marquee .track .star{color:var(--loud-star);font-style:normal;}
@keyframes scroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}
@media(prefers-reduced-motion:reduce){.marquee .track{animation:none;}}

/* ---- generic section ---- */
section{padding:84px 0;}
.lbl{font-family:"JetBrains Mono",monospace;font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--accent-2);margin-bottom:20px;}
h2{font-family:"Fraunces",serif;font-weight:700;font-size:clamp(34px,5vw,60px);line-height:1.0;letter-spacing:-.025em;margin:0;}
h2 em{font-style:italic;color:var(--accent-deep);}
.sectionsub{font-size:18px;color:var(--fg-2);max-width:60ch;margin:18px 0 0;}

/* comparison table */
.ctablewrap{border:2px solid var(--fg);border-radius:14px;overflow:hidden;margin-top:26px;}
.ctable{width:100%;border-collapse:collapse;font-size:15px;background:var(--surface);}
.ctable th,.ctable td{padding:13px 16px;border-bottom:1px solid var(--line);border-right:1px solid var(--line);text-align:left;vertical-align:top;line-height:1.45;}
.ctable th:last-child,.ctable td:last-child{border-right:0;}
.ctable tbody tr:last-child td,.ctable tbody tr:last-child th{border-bottom:0;}
.ctable thead th{background:var(--panel-bg);color:var(--panel-fg);font-family:"JetBrains Mono",monospace;font-size:11px;text-transform:uppercase;letter-spacing:.05em;font-weight:600;}
.ctable thead th:first-child{color:var(--panel-muted);}
.ctable tbody th{font-weight:600;color:var(--fg);background:var(--bg);width:26%;}
.ctable .em{color:var(--accent-deep);font-weight:700;}
@media(max-width:720px){.ctable{font-size:13px;}.ctable th,.ctable td{padding:10px 11px;}}

/* wedge two-up */
.twoup{display:grid;grid-template-columns:1fr 1fr;gap:0;border:2px solid var(--fg);border-radius:16px;overflow:hidden;margin-top:24px;}
.twoup .cell{padding:34px;}
.twoup .cell:first-child{border-right:2px solid var(--fg);}
.twoup .cell.bad{background:var(--surface);}
.twoup .cell.good{background:var(--loud-bg);color:var(--loud-fg);}
.twoup .cap{font-family:"JetBrains Mono",monospace;font-size:11px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px;}
.twoup .bad .cap{color:var(--fg-3);}
.twoup .good .cap{color:var(--loud-fg);opacity:.7;}
.twoup .q{font-family:"Fraunces",serif;font-size:21px;line-height:1.35;font-weight:500;margin:0;}
.twoup .good .q b{color:var(--loud-fg);}

/* problems / sound familiar */
.problems{margin-top:30px;display:grid;gap:18px;}
.prow{display:grid;grid-template-columns:1fr 1fr;gap:0;border:2px solid var(--fg);border-radius:16px;overflow:hidden;}
.prow .pq{padding:30px 32px;background:var(--surface);display:flex;flex-direction:column;justify-content:center;}
.prow .pq .youtag{font-family:"JetBrains Mono",monospace;font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-3);margin-bottom:12px;}
.prow .pq p{font-family:"Fraunces",serif;font-style:italic;font-size:21px;line-height:1.3;margin:0;font-weight:500;}
.prow .pa{padding:30px 32px;border-left:2px solid var(--fg);display:flex;flex-direction:column;justify-content:center;}
.prow .pa .fixtag{display:inline-flex;align-items:center;gap:8px;font-family:"JetBrains Mono",monospace;font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:12px;}
.prow .pa .fixtag::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--accent);}
.prow .pa p{font-size:16.5px;line-height:1.5;margin:0;color:var(--fg);}
.prow .pa p b{font-weight:700;}

/* manifesto list */
.manifesto{margin-top:30px;border-top:2px solid var(--fg);}
.mrow{display:grid;grid-template-columns:80px 1fr;gap:30px;padding:30px 0;border-bottom:2px solid var(--fg);align-items:start;}
.mrow .num{font-family:"Fraunces",serif;font-style:italic;font-size:34px;font-weight:700;color:var(--accent-deep);line-height:1;}
.mrow h3{font-family:"Fraunces",serif;font-size:clamp(23px,3vw,33px);font-weight:600;margin:0 0 8px;letter-spacing:-.01em;}
.mrow p{margin:0;font-size:17px;color:var(--fg-2);max-width:62ch;}

/* about */
.about{display:grid;grid-template-columns:.8fr 1.2fr;gap:48px;align-items:center;}
.about .frame{aspect-ratio:4/5;border:2px solid var(--fg);border-radius:14px;overflow:hidden;box-shadow:8px 8px 0 var(--accent);}
.about .text h2{margin-bottom:20px;}
.about .text p{font-size:18px;color:var(--fg-2);margin:0 0 16px;max-width:54ch;}
.about .text p b{color:var(--fg);}
.sig{font-family:"Fraunces",serif;font-style:italic;font-size:26px;font-weight:600;margin-top:10px;color:var(--fg);}

/* product band */
.band{background:var(--panel-bg);color:var(--panel-fg);border-radius:20px;padding:54px;display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;}
.band .tag{margin-bottom:18px;}
.band h2{color:var(--panel-fg);}
.band h2 em{color:var(--accent);}
.band p{color:var(--panel-muted);font-size:18px;max-width:46ch;margin:18px 0 20px;}
.band ul{list-style:none;padding:0;margin:0 0 28px;display:flex;flex-direction:column;gap:10px;}
.band li{font-size:15px;color:var(--panel-fg);padding-left:24px;position:relative;}
.band li::before{content:"✓";position:absolute;left:0;color:var(--accent);font-weight:700;}
.band .btn-gold{border-color:var(--accent);}
.termbox{background:var(--term-bg);border:1px solid rgba(238,241,227,.16);border-radius:12px;padding:22px;font-family:"JetBrains Mono",monospace;font-size:13px;line-height:1.85;color:rgba(238,241,227,.82);}
.termbox .c{color:var(--accent);}
.termbox .g{color:#8fd17a;}
.termbox .d{color:#6f7560;}
[data-theme="acid"] .termbox .g{color:#9be06a;}

/* proof */
.logos{display:grid;grid-template-columns:repeat(5,1fr);gap:0;border:2px solid var(--fg);border-radius:14px;overflow:hidden;}
.logo-ph{height:84px;display:flex;align-items:center;justify-content:center;font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--fg-3);border-right:2px solid var(--fg);}
.logo-ph:last-child{border-right:0;}

/* final */
.final{text-align:center;}
.final h2{font-size:clamp(42px,7vw,90px);max-width:16ch;margin:0 auto 24px;}
.final p{font-size:20px;color:var(--fg-2);max-width:48ch;margin:0 auto 34px;}

/* footer */
footer{border-top:2px solid var(--fg);padding:34px 0;}
.foot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;font-size:14px;}
.foot a{text-decoration:none;margin-left:22px;font-weight:500;color:var(--fg);}
.foot .fl{display:flex;flex-wrap:wrap;}

/* ---- projects ---- */
.page-hero{padding:72px 0 40px;border-bottom:2px solid var(--fg);}
.page-hero .lbl{margin-bottom:18px;}
.page-hero h1{font-size:clamp(44px,7vw,88px);}
.page-hero p{font-size:19px;color:var(--fg-2);max-width:56ch;margin:24px 0 0;}

.projgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.pcard{border:2px solid var(--fg);border-radius:16px;overflow:hidden;background:var(--surface);text-decoration:none;color:var(--fg);display:flex;flex-direction:column;transition:transform .14s,box-shadow .14s;}
.pcard:hover{transform:translate(-3px,-3px);box-shadow:6px 6px 0 var(--shadow);}
.pcard .thumb{height:190px;display:flex;align-items:center;justify-content:center;border-bottom:2px solid var(--fg);
  background:repeating-linear-gradient(45deg,var(--ph-a),var(--ph-a) 12px,var(--ph-b) 12px,var(--ph-b) 24px);font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--fg-3);}
.pcard .pbody{padding:26px 28px 28px;display:flex;flex-direction:column;flex:1;}
.pcard .pmeta{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:10px;}
.pcard h3{font-family:"Fraunces",serif;font-size:26px;font-weight:700;margin:0 0 10px;letter-spacing:-.01em;line-height:1.1;}
.pcard p{font-size:15px;color:var(--fg-2);margin:0 0 18px;}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto;}
.chip{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--fg-2);border:1px solid var(--line);border-radius:999px;padding:6px 11px;background:var(--bg);}
.readmore{margin-top:18px;font-weight:700;font-size:14px;color:var(--accent-deep);}

/* project detail */
.detail .meta{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px;}
.detail-body{display:grid;grid-template-columns:1fr;gap:0;}
.dblock{padding:56px 0;border-bottom:2px solid var(--line);}
.dblock:last-child{border-bottom:0;}
.dblock .lbl{color:var(--accent-2);}
.dblock h2{font-size:clamp(28px,4vw,44px);margin-bottom:18px;}
.dblock p{font-size:18px;color:var(--fg-2);max-width:64ch;margin:0 0 14px;}
.dblock .shot{margin-top:26px;aspect-ratio:16/9;border:2px solid var(--fg);border-radius:14px;
  background:repeating-linear-gradient(45deg,var(--ph-a),var(--ph-a) 12px,var(--ph-b) 12px,var(--ph-b) 24px);
  display:flex;align-items:center;justify-content:center;font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--fg-3);}
.statrow{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:2px solid var(--fg);border-radius:14px;overflow:hidden;margin-top:8px;}
.statrow .st{padding:28px;border-right:2px solid var(--fg);}
.statrow .st:last-child{border-right:0;}
.statrow .st .v{font-family:"Fraunces",serif;font-weight:700;font-size:40px;line-height:1;color:var(--accent-deep);}
.statrow .st .k{font-size:13.5px;color:var(--fg-2);margin-top:8px;}

@media(max-width:900px){
  .herobody,.about,.band,.twoup,.prow,.projgrid,.statrow{grid-template-columns:1fr;}
  .twoup .cell:first-child{border-right:0;border-bottom:2px solid var(--fg);}
  .prow .pa{border-left:0;border-top:2px solid var(--fg);}
  .statrow .st{border-right:0;border-bottom:2px solid var(--fg);}
  .statrow .st:last-child{border-bottom:0;}
  .logos{grid-template-columns:repeat(2,1fr);}
  .logo-ph{border-bottom:2px solid var(--fg);}
  .mrow{grid-template-columns:1fr;gap:6px;}
  .nav .navtoggle{display:inline-flex;}
  .navlinks{position:absolute;top:64px;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;
    background:var(--header-bg);backdrop-filter:blur(10px);border-bottom:2px solid var(--fg);padding:10px 0 16px;display:none;}
  header[data-mobileopen] .navlinks{display:flex;}
  .navlinks a:not(.btn){padding:13px 34px;font-size:16px;color:var(--fg);}
  .navlinks a.btn{margin:12px 34px 4px;justify-content:center;}
  .themesw{margin:10px 34px;align-self:flex-start;}
  .heroportrait{max-width:340px;}
}

/* ============================================================
   v3.1 additions — sprints, mastermind, about, blog, tools, logos
   ============================================================ */

/* placeholder callout (remove before launch) */
.todo{border:2px dashed var(--accent-2);border-radius:12px;padding:14px 18px;margin:16px 0;
  font-family:"JetBrains Mono",monospace;font-size:12.5px;line-height:1.6;color:var(--fg-2);background:var(--surface);}
.todo b{color:var(--accent-2);}
.todo code{background:var(--bg);padding:1px 6px;border-radius:5px;border:1px solid var(--line);}

/* ---- sprints / services ---- */
.sprints{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:34px;}
.sprint{border:2px solid var(--fg);border-radius:18px;background:var(--surface);padding:34px;display:flex;flex-direction:column;}
.sprint .stier{font-family:"JetBrains Mono",monospace;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--accent-deep);margin-bottom:14px;}
.sprint h3{font-family:"Fraunces",serif;font-size:30px;font-weight:700;letter-spacing:-.01em;margin:0 0 10px;line-height:1.05;}
.sprint .who{font-size:16px;color:var(--fg-2);margin:0 0 20px;}
.sprint ul{list-style:none;padding:0;margin:0 0 26px;display:flex;flex-direction:column;gap:11px;}
.sprint li{font-size:15.5px;color:var(--fg);padding-left:26px;position:relative;}
.sprint li::before{content:"\2192";position:absolute;left:0;color:var(--accent-deep);font-weight:700;}
.sprint .cta{margin-top:auto;}

/* numbered steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:2px solid var(--fg);border-radius:16px;overflow:hidden;margin-top:30px;}
.steps .step{padding:28px;border-right:2px solid var(--fg);}
.steps .step:last-child{border-right:0;}
.steps .step .n{font-family:"Fraunces",serif;font-style:italic;font-weight:700;font-size:30px;color:var(--accent-deep);line-height:1;}
.steps .step h4{font-family:"Fraunces",serif;font-size:19px;margin:12px 0 8px;font-weight:600;}
.steps .step p{margin:0;font-size:15px;color:var(--fg-2);}

/* ---- mastermind upcoming sessions ---- */
.sessions{display:grid;gap:18px;margin-top:34px;}
.session{border:2px solid var(--fg);border-radius:16px;background:var(--surface);padding:24px 28px;
  display:grid;grid-template-columns:150px 1fr auto;gap:26px;align-items:center;}
.session .when{font-family:"JetBrains Mono",monospace;font-size:14px;color:var(--accent-deep);line-height:1.4;font-weight:600;}
.session .when .mo{display:block;font-size:10.5px;color:var(--fg-3);text-transform:uppercase;letter-spacing:.08em;font-weight:500;}
.session h3{font-family:"Fraunces",serif;font-size:22px;font-weight:600;margin:0 0 6px;}
.session p{margin:0;font-size:15px;color:var(--fg-2);}
.session .signup{flex:none;}
.session.tbd{opacity:.65;}

/* ---- about / bio ---- */
.bio{max-width:64ch;}
.bio p{font-size:18px;color:var(--fg-2);margin:0 0 18px;}
.bio p b{color:var(--fg);}

/* ---- blog ---- */
.bloglist{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:8px;}
.bpost{border:2px solid var(--fg);border-radius:16px;background:var(--surface);padding:28px;text-decoration:none;color:var(--fg);display:flex;flex-direction:column;transition:transform .14s,box-shadow .14s;}
.bpost:hover{transform:translate(-3px,-3px);box-shadow:6px 6px 0 var(--shadow);}
.bpost .date{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--fg-3);letter-spacing:.06em;margin-bottom:12px;}
.bpost h3{font-family:"Fraunces",serif;font-size:24px;font-weight:700;margin:0 0 10px;line-height:1.15;}
.bpost p{font-size:15px;color:var(--fg-2);margin:0;}
.empty{border:2px dashed var(--line);border-radius:16px;padding:64px 30px;text-align:center;color:var(--fg-3);
  font-family:"JetBrains Mono",monospace;font-size:13px;margin-top:24px;}

/* ---- client logo strip (drop files in images/clients/) ---- */
.logos a,.logos .logo-cell{height:84px;display:flex;align-items:center;justify-content:center;border-right:2px solid var(--fg);}
.logos a:last-child,.logos .logo-cell:last-child{border-right:0;}
.logos img{max-height:34px;max-width:78%;width:auto;object-fit:contain;filter:grayscale(1);opacity:.78;transition:filter .15s,opacity .15s;}
.logos a:hover img{filter:grayscale(0);opacity:1;}

/* tools / stack chips */
.toolset{display:flex;flex-wrap:wrap;gap:11px;margin-top:8px;}
.toolset .chip{font-size:13px;padding:9px 15px;color:var(--fg);}

@media(max-width:900px){
  .sprints,.bloglist{grid-template-columns:1fr;}
  .steps{grid-template-columns:1fr;}
  .steps .step{border-right:0;border-bottom:2px solid var(--fg);}
  .steps .step:last-child{border-bottom:0;}
  .session{grid-template-columns:1fr;gap:14px;text-align:left;}
}

/* ---- mermaid diagram panel (dark in both themes) ---- */
.diagram{border:1px solid rgba(238,241,227,.18);border-radius:14px;padding:24px;margin:26px 0;background:#0a0b07;overflow-x:auto;}
.diagram .cap{font-family:"JetBrains Mono",monospace;font-size:11px;color:#8a8f7a;margin-bottom:14px;text-transform:uppercase;letter-spacing:.08em;}
.diagram .mermaid{display:flex;justify-content:center;min-width:520px;}

/* ---- FAQ (native accordion, no JS) ---- */
.faq{margin-top:34px;border-top:2px solid var(--fg);}
.faq details{border-bottom:2px solid var(--fg);padding:22px 2px;}
.faq summary{font-family:"Fraunces",serif;font-size:21px;font-weight:600;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px;color:var(--fg);}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"+";color:var(--accent-deep);font-weight:700;font-size:24px;line-height:1;}
.faq details[open] summary::after{content:"\2013";}
.faq .a{margin:14px 0 0;font-size:16.5px;line-height:1.55;color:var(--fg-2);max-width:72ch;}
.faq .a b{color:var(--fg);}

/* ---- client logo carousel ---- */
.logoscroll{overflow:hidden;}
.logoscroll .track{display:flex;align-items:center;gap:20px;width:max-content;padding:8px 2px 18px;animation:scroll 40s linear infinite;}
.logoscroll .item{height:90px;width:188px;display:flex;align-items:center;justify-content:center;padding:0 12px;background:#eef1e3;border:2px solid var(--fg);border-radius:14px;box-shadow:4px 4px 0 var(--shadow);transition:transform .14s,box-shadow .14s;}
.logoscroll .item:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--shadow);}
.logoscroll img{width:158px;height:auto;object-fit:contain;display:block;}
.logoscroll .item.svglogo img{width:120px;}
.logoscroll:hover .track{animation-play-state:paused;}
@media(prefers-reduced-motion:reduce){.logoscroll .track{animation:none;}}

/* ---- mobile nav toggle (hamburger) ---- */
.navtoggle{display:none;background:transparent;border:2px solid var(--fg);border-radius:8px;color:var(--fg);
  width:44px;height:40px;font-size:18px;line-height:1;cursor:pointer;align-items:center;justify-content:center;}
