/* CCode Bible, Larry's How-To. Self-contained, mobile-first, dark. */
:root{
  --bg:#0e1116; --bg2:#151a21; --bg3:#1b222b; --line:#262f3a;
  --ink:#dbe3ec; --ink2:#9aa7b6; --ink3:#6b7888;
  --accent:#39d0a8; --accent2:#5aa9ff; --warn:#f2b441;
  --max:760px; --nav:300px;
  --mono:ui-monospace,"SF Mono",Menlo,Consolas,monospace;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Inter,Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);
  font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased}
a{color:var(--accent2);text-decoration:none}
a:hover{text-decoration:underline}

/* layout */
.wrap{display:flex;min-height:100vh}
.nav{width:var(--nav);flex:0 0 var(--nav);background:var(--bg2);border-right:1px solid var(--line);
  position:sticky;top:0;height:100vh;overflow-y:auto;padding:22px 18px 60px}
.main{flex:1;min-width:0;display:flex;justify-content:center;padding:48px 32px 120px}
.col{width:100%;max-width:var(--max)}

/* nav */
.brand{display:block;font-weight:800;font-size:18px;letter-spacing:.3px;color:var(--ink);margin:0 0 2px;text-decoration:none}
.brand:hover{color:var(--accent);text-decoration:none}

/* global search */
.search-wrap{margin:0 0 14px}
.search{width:100%;background:var(--bg3);border:1px solid var(--line);color:var(--ink);border-radius:9px;padding:8px 11px;font-size:14px;font-family:var(--sans)}
.search:focus{outline:none;border-color:var(--accent)}
.search::placeholder{color:var(--ink3)}
.search-results{margin-top:7px;max-height:46vh;overflow-y:auto;background:var(--bg2);border:1px solid var(--line);border-radius:10px}
.search-results[hidden]{display:none}
.search-results a{display:block;padding:9px 12px;border-bottom:1px solid var(--line);color:var(--ink)}
.search-results a:last-child{border-bottom:none}
.search-results a:hover{background:var(--bg3);text-decoration:none}
.search-results b{display:block;font-size:13px;color:var(--accent2);font-weight:600}
.search-results .sr-p{font-size:10.5px;color:var(--ink3);font-family:var(--mono)}
.search-results em{display:block;font-style:normal;font-size:11.5px;color:var(--ink2);margin-top:3px;line-height:1.4}
.sr-none{padding:12px;color:var(--ink3);font-size:13px}

/* mentor banner, every chapter page 2+ is Larry raising the new Larry */
.mentor{margin:0 0 28px;padding:13px 17px;border:1px solid #3a2f5c;border-radius:11px;
  background:linear-gradient(180deg,rgba(150,120,255,.08),rgba(150,120,255,.02));
  color:var(--ink2);font-size:13.5px;line-height:1.6}
.mentor b{color:#b39cff}
.mentor em{color:var(--ink);font-style:normal}

/* persistent ethos footer (every page) */
.ethos{margin:54px 0 0;padding:16px 18px;border:1px dashed #2a5c4f;border-radius:11px;
  background:rgba(57,208,168,.04);color:var(--ink2);font-size:13.5px;line-height:1.55}
.ethos b{color:var(--accent)}
.ethos em{color:var(--ink);font-style:normal}

/* The Invitation */
.cta-nav.invite{border-color:var(--accent2);color:var(--accent2)}
.cta-nav.invite:hover{background:rgba(90,169,255,.1)}
.cta-nav.invite.here{background:var(--accent2);color:#02152e}
.invite-card{margin:22px 0;padding:22px 24px;border:1px solid #2a4a6a;border-radius:14px;
  background:linear-gradient(180deg,rgba(90,169,255,.08),rgba(90,169,255,.02));font-size:17px;line-height:1.7}
.invite-card em{color:var(--accent2);font-style:normal;font-weight:600}
.invite-msg{margin:18px 0;padding:20px 24px;background:#0b0f14;border-left:3px solid var(--accent2);
  border-radius:0 12px 12px 0;color:var(--ink);font-size:16.5px;line-height:1.75;font-style:italic}
.invite-msg .sig{display:block;margin-top:14px;font-style:normal;font-family:var(--mono);font-size:13px;color:var(--accent2)}
.invite-foot{margin-top:34px;padding-top:18px;border-top:1px solid var(--line);font-size:15px;color:var(--ink2);text-align:center}
.brand .by{color:var(--accent)}
.brand-sub{color:var(--ink3);font-size:12px;margin:0 0 20px;font-family:var(--mono)}
.nav .part{color:var(--accent);font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.12em;margin:18px 0 6px}
.nav ol{list-style:none;margin:0;padding:0}
.nav li{margin:1px 0}
.nav a,.nav .soon{display:block;padding:5px 9px;border-radius:7px;font-size:13.5px;line-height:1.35;color:var(--ink2)}
.nav a:hover{background:var(--bg3);color:var(--ink);text-decoration:none}
.nav a.here{background:var(--bg3);color:var(--accent);font-weight:600}
.nav .soon{color:var(--ink3)}
.nav .soon::after{content:" · soon";color:#46525f;font-size:11px}
.nav .num{color:var(--ink3);font-family:var(--mono);font-size:11px;margin-right:7px}

/* content */
.col h1{font-size:34px;line-height:1.18;letter-spacing:-.5px;margin:0 0 8px}
.col h2{font-size:23px;margin:42px 0 10px;padding-top:14px;border-top:1px solid var(--line);letter-spacing:-.2px}
.col h3{font-size:18px;margin:28px 0 6px;color:var(--ink)}
.col .eyebrow{color:var(--accent);font-family:var(--mono);font-size:12px;letter-spacing:.1em;
  text-transform:uppercase;margin:0 0 14px}
.col p{margin:13px 0}
.col ul,.col ol{margin:13px 0;padding-left:24px}
.col li{margin:6px 0}
.col strong{color:#fff}
.col code{font-family:var(--mono);font-size:.86em;background:var(--bg3);border:1px solid var(--line);
  padding:1px 6px;border-radius:5px;color:var(--accent)}
.col pre{background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:16px 18px;overflow-x:auto}
.col pre code{background:none;border:none;padding:0;color:var(--ink)}
.col blockquote{margin:20px 0;padding:14px 18px;background:var(--bg2);border-left:3px solid var(--accent);
  border-radius:0 10px 10px 0;color:var(--ink2)}
.col blockquote strong{color:var(--accent)}
.col hr{border:none;border-top:1px solid var(--line);margin:34px 0}

/* larry callout (blockquotes that start with Larry's read) */
.col blockquote em{color:var(--ink)}

/* prev/next */
.pager{display:flex;justify-content:space-between;gap:14px;margin-top:54px;padding-top:22px;border-top:1px solid var(--line)}
.pager a{flex:1;background:var(--bg2);border:1px solid var(--line);border-radius:11px;padding:14px 16px;color:var(--ink)}
.pager a:hover{border-color:var(--accent);text-decoration:none}
.pager .dir{color:var(--ink3);font-size:12px;font-family:var(--mono)}
.pager .t{display:block;margin-top:3px;font-weight:600}
.pager .nx{text-align:right}

/* index landing */
.hero{margin-bottom:8px}
.hero .kicker{color:var(--accent);font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase}
.hero h1{font-size:42px;line-height:1.1;margin:10px 0}
.lede{font-size:19px;color:var(--ink2);max-width:62ch}
.toc-part{margin:30px 0 0}
.toc-part h2{font-size:14px;color:var(--accent);text-transform:uppercase;letter-spacing:.1em;border:none;padding:0;margin:26px 0 8px}
.toc-row{display:flex;gap:12px;padding:9px 12px;border:1px solid var(--line);border-radius:10px;margin:6px 0;background:var(--bg2)}
.toc-row .n{font-family:var(--mono);color:var(--ink3);font-size:13px;min-width:26px}
.toc-row .ttl{flex:1}
.toc-row .badge{font-size:11px;font-family:var(--mono);color:var(--ink3);align-self:center}
.toc-row.ready{border-color:#2a5c4f} .toc-row.ready .badge{color:var(--accent)}
.toc-row.ready:hover{border-color:var(--accent)}

.meta-foot{color:var(--ink3);font-size:12.5px;font-family:var(--mono);margin-top:60px;border-top:1px solid var(--line);padding-top:18px}

/* mobile */
.navtoggle{display:none}
@media(max-width:860px){
  .nav{position:fixed;left:0;top:0;z-index:30;transform:translateX(-100%);transition:transform .2s;box-shadow:0 0 40px #000a}
  .nav.open{transform:translateX(0)}
  .navtoggle{display:flex;align-items:center;gap:8px;position:fixed;top:12px;left:12px;z-index:40;
    background:var(--bg3);border:1px solid var(--line);color:var(--ink);border-radius:9px;padding:8px 13px;font-size:14px;cursor:pointer}
  .main{padding:64px 18px 100px}
  .col h1{font-size:28px}.hero h1{font-size:32px}
}

/* nav checklist CTA */
.cta-nav{display:block;margin:0 0 10px;padding:9px 11px;border:1px solid var(--accent);border-radius:9px;
  color:var(--accent);font-size:13.5px;font-weight:600;text-align:center}
.cta-nav:hover{background:rgba(57,208,168,.1);text-decoration:none}
.cta-nav.here{background:var(--accent);color:#06281f}
.cta-nav.primary{background:var(--accent);color:#06281f;border-color:var(--accent)}
.cta-nav.primary:hover{filter:brightness(1.08);background:var(--accent)}
.cta-nav.home{background:var(--bg3);border-color:var(--accent2);color:var(--accent2);margin-bottom:14px;font-size:14px;letter-spacing:.2px}
.cta-nav.home:hover{background:rgba(90,169,255,.12)}

/* hero buttons */
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.btn{display:inline-block;background:var(--accent);color:#06281f;font-weight:700;padding:11px 18px;border-radius:10px;
  border:1px solid var(--accent);font-size:15px;cursor:pointer}
.btn:hover{filter:brightness(1.08);text-decoration:none}
.btn.ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn.ghost:hover{border-color:var(--accent);color:var(--accent);filter:none}

/* click-to-copy on code blocks */
.col pre{position:relative}
.col pre .copy{position:absolute;top:8px;right:8px;background:var(--bg3);border:1px solid var(--line);color:var(--ink2);
  font-family:var(--mono);font-size:11px;padding:3px 9px;border-radius:6px;cursor:pointer;opacity:0;transition:opacity .15s}
.col pre:hover .copy{opacity:1}
.col pre .copy:hover{color:var(--accent);border-color:var(--accent)}

/* quickstart block */
.quickstart{margin:30px 0 10px;padding:22px 24px;background:linear-gradient(180deg,rgba(57,208,168,.07),rgba(57,208,168,.02));
  border:1px solid #2a5c4f;border-radius:14px}
.quickstart h2{border:none;padding:0;margin:0 0 8px;font-size:20px;color:var(--accent)}
.quickstart p{margin:8px 0;color:var(--ink2)}
.quickstart pre{background:#0b0f14;border-color:#2a5c4f}
.quickstart .qs-foot{font-size:13.5px;color:var(--ink3);margin-top:12px}
.quickstart .qs-foot code{font-size:.86em}

/* checklist */
.progress{position:relative;height:34px;background:var(--bg3);border:1px solid var(--line);border-radius:8px;overflow:hidden;margin:22px 0 30px}
.progress .bar{position:absolute;left:0;top:0;bottom:0;width:0;background:var(--accent);transition:width .25s}
.progress span{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-family:var(--mono);font-size:13px;color:var(--ink);z-index:2}
.checks{display:flex;flex-direction:column;gap:3px;margin:6px 0 8px}
.check{display:flex;gap:11px;align-items:flex-start;padding:10px 12px;border:1px solid var(--line);border-radius:9px;background:var(--bg2);cursor:pointer}
.check:hover{border-color:var(--accent2)}
.check input{margin-top:3px;width:17px;height:17px;accent-color:var(--accent);flex:0 0 auto;cursor:pointer}
.check span{font-size:15px;color:var(--ink)}
.check code{font-size:.82em}
.check input:checked ~ span{color:var(--ink3);text-decoration:line-through}

/* TELOS nav CTA + homepage feature (warm/gold accent) */
.cta-nav.telos{border-color:var(--warn);color:var(--warn)}
.cta-nav.telos:hover{background:rgba(242,180,65,.1)}
.cta-nav.telos.here{background:var(--warn);color:#2b1d00}
.telos-feature{background:linear-gradient(180deg,rgba(242,180,65,.07),rgba(242,180,65,.02));border-color:#5c4a22}
.telos-feature h2{color:var(--warn)}
.telos-feature .btn{background:var(--warn);color:#2b1d00;border-color:var(--warn)}

/* TELOS questionnaire */
.copy-all-bar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin:18px 0;padding:16px 18px;
  background:rgba(242,180,65,.07);border:1px solid #5c4a22;border-radius:12px}
.copy-all-bar .btn{background:var(--warn);color:#2b1d00;border-color:var(--warn)}
.copy-all-bar span{color:var(--ink2);font-size:14px;flex:1;min-width:220px}
.telos-grid{display:flex;flex-direction:column;gap:8px;margin:24px 0}
details.telos-sec{border:1px solid var(--line);border-radius:11px;background:var(--bg2);overflow:hidden}
details.telos-sec[open]{border-color:#5c4a22}
.telos-sec summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:12px;padding:14px 16px;font-size:16px;color:var(--ink);user-select:none}
.telos-sec summary::-webkit-details-marker{display:none}
.telos-sec summary:hover{background:var(--bg3)}
.telos-sec .tn{font-family:var(--mono);font-size:13px;color:var(--warn);min-width:24px}
.telos-sec .tt{flex:1;font-weight:600}
.telos-sec .qc{font-family:var(--mono);font-size:12px;color:var(--ink3);border:1px solid var(--line);border-radius:999px;padding:2px 10px}
.telos-sec .qc::after{content:" q"}
.telos-sec[open] summary{border-bottom:1px solid var(--line)}
.telos-body{padding:6px 20px 18px}
.copy-sec{margin:12px 0 6px;background:var(--bg3);border:1px solid var(--line);color:var(--ink2);font-family:var(--mono);font-size:12px;padding:6px 13px;border-radius:7px;cursor:pointer}
.copy-sec:hover{color:var(--warn);border-color:var(--warn)}
.telos-body ol{margin:6px 0 0;padding-left:26px}
.telos-body li{margin:7px 0;color:var(--ink);font-size:15.5px;line-height:1.5}

/* ── front-page feature story / bad-ads / big red button ── */
.sell{margin:0 0 26px}
.sell h1{font-size:clamp(30px,5.2vw,54px);line-height:1.04;margin:8px 0 18px;letter-spacing:-.5px}
.sell .brag{font-size:18px;line-height:1.6;color:var(--ink2)}
.sell .brag b{color:var(--accent);font-weight:700}
.sell .warnbox{border-left:3px solid var(--warn);background:rgba(242,180,65,.06);padding:14px 20px;margin:22px 0;border-radius:0 12px 12px 0;color:var(--ink2);font-size:16px;line-height:1.6}
.sell .warnbox b{color:var(--warn)}
.sell .dare{font-size:21px;font-weight:700;color:var(--ink);margin:20px 0 6px;line-height:1.4}
.sell code{font-family:var(--mono);background:var(--bg3);padding:2px 8px;border-radius:6px;color:var(--accent);font-size:.92em}
.starburst{display:inline-block;background:var(--warn);color:#2b1d00;font-weight:800;padding:8px 16px;border-radius:9px;transform:rotate(-2.5deg);font-size:14px;letter-spacing:.5px;margin:8px 0 4px}
.badads{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin:18px 0 10px}
@media(max-width:560px){.badads{grid-template-columns:1fr}}
.badad{border:2px dashed var(--warn);border-radius:12px;padding:15px 16px;background:repeating-linear-gradient(45deg,rgba(242,180,65,.045),rgba(242,180,65,.045) 9px,transparent 9px,transparent 18px);transform:rotate(-.5deg)}
.badad:nth-child(even){transform:rotate(.6deg);border-color:var(--accent2)}
.badad .stars{color:var(--warn);font-size:15px;letter-spacing:2px}
.badad .q{font-size:14.5px;color:var(--ink);font-style:italic;margin:7px 0 5px;line-height:1.45}
.badad .who{font-size:12px;color:var(--ink3);margin:0}
.finefoot{color:var(--ink3);font-size:12px;text-align:center;line-height:1.5;margin:8px auto 0;max-width:620px}
.bigred-wrap{text-align:center;margin:36px 0 14px}
.bigred{display:inline-block;background:#e23b3b;color:#fff;font-weight:800;font-size:22px;letter-spacing:.6px;padding:20px 42px;border-radius:14px;border:2px solid #ff7676;box-shadow:0 6px 0 #9e1f1f,0 12px 30px rgba(226,59,59,.34);text-transform:uppercase;transition:transform .08s ease,box-shadow .08s ease}
.bigred:hover{text-decoration:none;color:#fff;transform:translateY(2px);box-shadow:0 4px 0 #9e1f1f,0 8px 22px rgba(226,59,59,.42)}
.bigred:active{transform:translateY(6px);box-shadow:0 0 0 #9e1f1f}
.bigred-sub{color:var(--ink3);font-size:13px;margin-top:12px;font-family:var(--mono)}
.seemore{display:inline-block;margin-top:4px;font-family:var(--mono);font-size:13.5px}
.realtalk{margin:30px 0;padding:22px 26px;border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:0 14px 14px 0;background:var(--bg2)}
.realtalk h2{margin:0 0 12px;font-size:24px;border:none;padding:0;letter-spacing:-.3px}
.realtalk p{font-size:16.5px;line-height:1.65;color:var(--ink2);margin:12px 0}
.realtalk strong{color:var(--ink)}
.realtalk em{color:var(--accent);font-style:normal}
.realtalk .ten{color:var(--ink3);text-decoration:line-through}
.realtalk .whoruns{color:var(--ink3);font-size:14.5px}
.offer{margin:0 0 30px;padding:24px 28px;border:1px solid #2a5c4f;border-left:4px solid var(--accent);border-radius:0 16px 16px 0;background:linear-gradient(180deg,rgba(57,208,168,.08),rgba(57,208,168,.02))}
.offer .tag{color:var(--accent);font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;margin:0 0 8px}
.offer h2{margin:0 0 8px;font-size:28px;border:none;padding:0;letter-spacing:-.4px;color:var(--ink)}
.offer p{font-size:16.5px;line-height:1.62;color:var(--ink2);margin:11px 0}
.offer strong{color:var(--ink)}
.offer .snark{color:var(--ink3);font-style:italic}
.offer .offer-cta{margin-top:16px}
.offer .offer-cta a.em{display:inline-block;background:var(--accent);color:#04221a;font-weight:700;padding:12px 22px;border-radius:10px;font-size:15.5px}
.offer .offer-cta a.em:hover{text-decoration:none;filter:brightness(1.08)}
.offer a{font-weight:600}
.invite-ribbon{margin:20px 0 0;padding:13px 18px;border:1px solid #2a4a6a;border-radius:11px;background:linear-gradient(180deg,rgba(90,169,255,.1),rgba(90,169,255,.02));color:var(--ink2);font-size:13.5px;line-height:1.55}
.invite-ribbon b{color:var(--accent2)}
.invite-ribbon em{color:var(--ink);font-style:normal;font-weight:600}
.invite-ribbon a{color:var(--accent2);font-weight:600;white-space:nowrap}
.obsession{margin:28px 0;padding:22px 26px;border:1px solid #6a5424;border-left:4px solid var(--warn);border-radius:0 14px 14px 0;background:linear-gradient(180deg,rgba(242,180,65,.10),rgba(242,180,65,.02))}
.obsession h2{margin:0 0 10px;font-size:25px;border:none;padding:0;color:var(--warn);letter-spacing:-.3px}
.obsession p{font-size:16.5px;line-height:1.62;color:var(--ink2);margin:11px 0}
.obsession strong{color:var(--ink)}
.obsession em{color:var(--warn);font-style:normal}
.obsession .kicker-line{font-weight:700;color:var(--ink)}
.fixit{margin:14px 0 0;padding:14px 18px;border:1px solid #5a4a2a;border-left:4px solid var(--warn);border-radius:0 11px 11px 0;background:linear-gradient(180deg,rgba(242,180,65,.07),rgba(242,180,65,.02));color:var(--ink2);font-size:13.5px;line-height:1.6}
.fixit b{color:var(--warn)}
.fixit em{color:var(--ink);font-style:normal}
.fixit a{color:var(--accent2);font-weight:600}
