/* =====================================================================
   The Old Web Project — flagship stylesheet
   Retro soul + modern execution + institutional credibility.
   Brand DNA carried from the original hub: black canvas, neon green +
   signal red + gold, Georgia serif body, Courier mono for UI/labels,
   3D extruded logo, perspective checker floor.
   ===================================================================== */

:root{
  --green:#39ff14; --green-dim:#1f9c12; --green-deep:#0e4a0a;
  --red:#ff003c; --red-deep:#8a0010;
  --gold:#e7b53b; --blue:#3a5bff;
  --ink:#f1eee4; --ink-dim:#cfcbbd; --ink-faint:#9a948a;
  --bg:#07070a; --bg-2:#0d0c14; --panel:#100c1a; --panel-2:#15131f;
  --border:#3a342c; --border-lit:#4a4636;
  --serif:Georgia,"Times New Roman",Times,serif;
  --mono:"Courier New",Courier,monospace;
  --maxw:1040px; --readw:720px;
  --shadow:4px 4px 0 #000;
}

*{box-sizing:border-box}
html{background:#000;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:var(--serif);font-size:17px;line-height:1.62;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--gold);text-decoration:underline;text-underline-offset:2px}
a:hover{color:#fff}
h1,h2,h3,h4{font-family:var(--serif);line-height:1.18;color:#fff}
p{margin:0 0 1em}
hr{border:0;border-top:1px solid var(--border);margin:30px 0}
code,kbd{font-family:var(--mono);color:var(--green);font-size:.92em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--green);color:#000;
  padding:8px 14px;font-family:var(--mono);z-index:200}
.skip-link:focus{left:8px;top:8px}

/* subtle CRT scanline veil over everything (decorative, very faint) */
body::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:5;
  background:repeating-linear-gradient(to bottom,rgba(0,0,0,0) 0 2px,rgba(0,0,0,.05) 2px 3px);
  mix-blend-mode:multiply;opacity:.6}
@media (prefers-reduced-motion:reduce){body::after{display:none}}

/* ---- top marquee bar ------------------------------------------------ */
.topbar{background:#000;border-bottom:1px solid var(--green-deep);color:var(--green);
  font-family:var(--mono);font-size:12px;letter-spacing:.5px;text-align:center;
  padding:5px 10px;overflow:hidden;white-space:nowrap}
.topbar b{color:var(--gold)}

/* ---- progress bar (scroll) ----------------------------------------- */
#progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:120;
  background:linear-gradient(90deg,var(--green),var(--gold),var(--red));
  box-shadow:0 0 8px rgba(57,255,20,.6)}

/* ---- header / logo -------------------------------------------------- */
.site-header{background:
   radial-gradient(ellipse 90% 120% at 50% -10%, #1d1430 0%, #0a0712 60%, #000 100%);
  border-bottom:3px double var(--red-deep);text-align:center;padding:26px 0 18px}
.logo{display:inline-block;text-decoration:none}
.logo:hover{color:inherit}
.logo .l1{display:block;font-weight:bold;font-size:46px;letter-spacing:2px;color:var(--green);
  line-height:.92;text-shadow:2px 2px 0 var(--green-deep),4px 4px 0 #093506,6px 6px 0 #062404,8px 9px 12px rgba(0,0,0,.85)}
.logo .l2{display:block;font-size:19px;letter-spacing:11px;color:var(--red);font-weight:bold;
  margin:7px 0 0;padding-left:11px;text-shadow:2px 2px 0 #4a0008,3px 3px 6px #000}
.logo-tag{color:var(--ink-dim);font-style:italic;font-size:15px;margin:12px 0 0}
.logo-tag em{color:#fff;font-style:italic}

/* ---- global nav ----------------------------------------------------- */
.nav{background:#000;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}
.nav .wrap{display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap;padding-top:0;padding-bottom:0}
.nav a{font-family:var(--mono);font-size:13px;text-transform:uppercase;letter-spacing:1px;
  color:var(--ink-dim);text-decoration:none;padding:11px 9px;white-space:nowrap;border-bottom:3px solid transparent}
.nav a:hover{color:var(--green);background:rgba(57,255,20,.06)}
.nav a.on{color:var(--green);border-bottom-color:var(--green)}
.nav .nav-cta{color:#000 !important;background:var(--green);border:1px solid var(--green-dim);
  font-weight:bold;padding:7px 14px;margin:6px 0;box-shadow:2px 2px 0 #000}
.nav .nav-cta:hover{background:#fff;color:#000 !important}
.nav-toggle{display:none}

/* ---- generic sections / containers ---------------------------------- */
main{display:block}
.section{padding:46px 0}
.section.alt{background:var(--bg-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.eyebrow{font-family:var(--mono);text-transform:uppercase;letter-spacing:3px;font-size:12px;
  color:var(--green);margin:0 0 10px}
.section h2{font-size:30px;margin:0 0 8px;text-shadow:0 0 14px rgba(57,255,20,.18)}
.section .lede{font-size:19px;color:var(--ink-dim);max-width:var(--readw)}
.prose{max-width:var(--readw)}
.prose p,.prose li{font-size:17px}
.prose h3{font-size:21px;color:var(--green);margin:30px 0 8px}
.prose ul{padding-left:22px}
.prose li{margin:0 0 6px}
.center{text-align:center}
.muted{color:var(--ink-faint)}
.pull{font-family:var(--serif);font-style:italic;font-size:22px;color:#fff;
  border-left:3px solid var(--red);padding-left:16px;margin:24px 0;max-width:var(--readw)}
.pull.green{border-left-color:var(--green);color:var(--green)}

/* ---- buttons -------------------------------------------------------- */
.btn{display:inline-block;font-family:var(--mono);font-weight:bold;font-size:15px;letter-spacing:1px;
  text-transform:uppercase;text-decoration:none;cursor:pointer;padding:12px 22px;border:1px solid var(--green-dim);
  background:var(--green);color:#000 !important;box-shadow:var(--shadow);transition:transform .04s}
.btn:hover{background:#fff}
.btn:active{transform:translate(2px,2px);box-shadow:2px 2px 0 #000}
.btn.ghost{background:transparent;color:var(--green) !important;border-color:var(--green-dim);box-shadow:none}
.btn.ghost:hover{background:rgba(57,255,20,.1);color:#fff !important}
.btn.red{background:var(--red);border-color:var(--red-deep);color:#fff !important}
.btn.red:hover{background:#ff385f}
.btn-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin:22px 0 0}

/* ---- browser-window component (retro UI chrome) --------------------- */
.win{background:var(--panel);border:1px solid var(--border-lit);box-shadow:var(--shadow);margin:0 0 22px}
.win-bar{display:flex;align-items:center;gap:8px;background:linear-gradient(#2a2740,#1a1828);
  border-bottom:1px solid var(--border-lit);padding:7px 10px;font-family:var(--mono);font-size:12px;color:var(--ink-dim)}
.win-dots{display:flex;gap:5px}
.win-dots i{width:11px;height:11px;border-radius:50%;display:block;border:1px solid rgba(0,0,0,.5)}
.win-dots .r{background:var(--red)}.win-dots .y{background:var(--gold)}.win-dots .g{background:var(--green)}
.win-title{flex:1;text-align:center;letter-spacing:.5px;color:var(--ink-faint);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.win-body{padding:18px}

/* ---- hero (home) ---------------------------------------------------- */
.hero{position:relative;overflow:hidden;border-bottom:3px double var(--red-deep);
  background:radial-gradient(ellipse 90% 80% at 50% 0%, #1d1430 0%, #0a0712 55%, #000 100%);
  padding:54px 0 0;text-align:center}
.hero h1{font-size:46px;margin:0 0 14px;letter-spacing:.5px;
  text-shadow:0 2px 0 #000,0 0 26px rgba(57,255,20,.22)}
.hero h1 .hl{color:var(--green)}
.hero .sub{font-size:19px;color:var(--ink-dim);max-width:680px;margin:0 auto 8px}
.hero .btn-row{justify-content:center;margin-bottom:34px}
.floor{position:relative;z-index:1;height:140px;margin-top:8px;background-color:#000;
  background-image:linear-gradient(45deg,#16225e 25%,transparent 25%,transparent 75%,#5e0a14 75%),
                   linear-gradient(45deg,#5e0a14 25%,#0b0b0b 25%,#0b0b0b 75%,#16225e 75%);
  background-size:38px 38px;background-position:0 0,19px 19px;
  transform:perspective(190px) rotateX(60deg);transform-origin:bottom center;
  border-top:2px solid var(--green-dim);box-shadow:0 -6px 26px rgba(57,255,20,.18)}

/* ---- card grids ----------------------------------------------------- */
.grid{display:grid;gap:18px}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.card{background:var(--panel);border:1px solid var(--border-lit);padding:20px;box-shadow:var(--shadow)}
.card h3{font-size:19px;margin:0 0 8px;color:#fff}
.card .ico{font-size:26px;display:block;margin:0 0 8px}
.card p{font-size:15px;color:var(--ink-dim);margin:0 0 8px}
.card .more{font-family:var(--mono);font-size:13px;text-transform:uppercase;letter-spacing:1px}
.card.lit{border-color:var(--green-dim);box-shadow:0 0 0 1px rgba(57,255,20,.12),var(--shadow)}

/* directory / member cards */
.dir{display:grid;gap:14px;grid-template-columns:repeat(2,1fr)}
.dir .site{background:var(--bg-2);border:1px solid var(--border);padding:14px 16px}
.dir .site a{font-weight:bold;font-size:17px}
.dir .site .t{display:block;color:var(--ink-faint);font-size:13.5px;margin-top:3px}

/* ---- "what went wrong" numbered problems ---------------------------- */
.prob{display:flex;gap:16px;padding:20px 0;border-top:1px solid var(--border)}
.prob:first-of-type{border-top:0}
.prob .num{font-family:var(--mono);font-weight:bold;font-size:26px;color:var(--red);
  flex:0 0 46px;line-height:1.2}
.prob .body{flex:1;min-width:0}
.prob h3{font-size:20px;margin:0 0 6px;color:#fff}
.prob p{font-size:16px;color:var(--ink-dim);margin:0 0 8px}
.prob .ex{font-family:var(--mono);font-size:13px;color:var(--ink-faint)}
.prob .key{border-left:3px solid var(--red);padding-left:12px;color:#fff;font-style:italic}

/* ---- principles manifesto ------------------------------------------- */
.tenets{display:grid;gap:0}
.tenet{border-top:1px solid var(--border);padding:24px 0;display:grid;grid-template-columns:54px 1fr;gap:18px}
.tenet:first-child{border-top:0}
.tenet .n{font-family:var(--mono);color:var(--green);font-size:14px;letter-spacing:1px}
.tenet h3{font-size:24px;margin:0 0 6px;color:#fff}
.tenet p{font-size:16px;color:var(--ink-dim);margin:0}
.tenet .say{color:var(--green);font-style:italic;font-family:var(--serif)}

/* ---- timeline ------------------------------------------------------- */
.tl-progress{position:sticky;top:44px;z-index:40;height:4px;background:#000;border-bottom:1px solid var(--border)}
.tl-progress i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--green),var(--gold),var(--red))}
.timeline{position:relative;max-width:880px;margin:30px auto 0;padding:0 12px}
.timeline::before{content:"";position:absolute;left:50%;top:0;bottom:0;width:3px;margin-left:-1.5px;
  background:linear-gradient(var(--green-dim),var(--red-deep))}
.tl-era{position:relative;text-align:center;margin:34px 0 18px;z-index:2}
.tl-era span{display:inline-block;background:#000;border:1px solid var(--gold);color:var(--gold);
  font-family:var(--mono);text-transform:uppercase;letter-spacing:2px;font-size:13px;padding:6px 14px}
.tl-entry{position:relative;width:50%;padding:0 34px 26px;z-index:1}
.tl-entry .dot{position:absolute;top:6px;width:15px;height:15px;background:var(--green);
  border:3px solid #000;border-radius:50%;box-shadow:0 0 0 2px var(--green-dim)}
.tl-entry .card2{background:var(--panel);border:1px solid var(--border-lit);box-shadow:var(--shadow);padding:16px}
.tl-entry .yr{font-family:var(--mono);color:var(--green);font-size:13px;letter-spacing:1px}
.tl-entry h3{font-size:19px;margin:3px 0 6px;color:#fff}
.tl-entry p{font-size:15px;color:var(--ink-dim);margin:0}
.tl-entry.left{left:0;text-align:right}
.tl-entry.left .dot{right:-7.5px}
.tl-entry.right{left:50%;text-align:left}
.tl-entry.right .dot{left:-7.5px}
.tl-future .card2{border-color:var(--gold)}
.tl-future .dot{background:var(--gold);box-shadow:0 0 0 2px var(--gold)}
.tl-hope .card2{border-color:var(--red-deep);background:#160a10}
.tl-hope .dot{background:var(--red);box-shadow:0 0 0 2px var(--red-deep)}
/* reveal */
.js-on .tl-entry,.js-on .tl-era{opacity:0;transform:translateY(18px);transition:opacity .5s,transform .5s}
.js-on .tl-entry.left{transform:translate(-18px,0)}
.js-on .tl-entry.right{transform:translate(18px,0)}
.js-on .tl-entry.in,.js-on .tl-era.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .js-on .tl-entry,.js-on .tl-era{opacity:1 !important;transform:none !important;transition:none}
}

/* ---- forms ---------------------------------------------------------- */
.form{background:var(--panel);border:2px solid var(--green-dim);box-shadow:var(--shadow);
  padding:22px;max-width:560px}
.form label{display:block;font-family:var(--mono);font-size:13px;text-transform:uppercase;
  letter-spacing:1px;color:var(--green);margin:14px 0 4px}
.form input,.form select,.form textarea{width:100%;padding:10px;background:#000;color:var(--ink);
  border:1px solid var(--border);font-family:var(--mono);font-size:15px}
.form input:focus,.form select:focus,.form textarea:focus{outline:1px solid var(--green);border-color:var(--green)}
.form textarea{min-height:140px;resize:vertical;line-height:1.5}
.form .hp{position:absolute;left:-9999px}
.form .btn{margin-top:18px;width:100%}
.form .hint{font-size:13px;color:var(--ink-faint);margin:10px 0 0}
.formerr{background:rgba(255,0,60,.12);border:1px solid var(--red-deep);color:#ff6b85;
  font-family:var(--mono);font-size:14px;padding:10px 12px;margin:0 0 14px}
.formok{background:rgba(57,255,20,.1);border:1px solid var(--green-dim);color:var(--green);
  font-family:var(--mono);font-size:14px;padding:12px 14px;margin:0 0 16px}

/* ---- webring widget / badge ----------------------------------------- */
.ring-box{background:#000;border:1px solid var(--green-dim);padding:16px;text-align:center;
  font-family:var(--mono)}
.ring-box .badge{display:inline-block;box-shadow:2px 2px 0 #000;margin:0 auto 8px}
.ring-nav{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;font-size:14px;margin-top:6px}
pre.code{background:#000;border:1px solid var(--border);color:var(--green);padding:14px;overflow:auto;
  font-family:var(--mono);font-size:12.5px;line-height:1.5;text-align:left}

/* ---- press / kit ---------------------------------------------------- */
.kit{display:grid;gap:14px;grid-template-columns:repeat(3,1fr)}
.kit a{display:block;background:var(--bg-2);border:1px solid var(--border);padding:16px;
  font-family:var(--mono);font-size:13px;text-decoration:none;color:var(--ink-dim)}
.kit a:hover{border-color:var(--green-dim);color:var(--green)}
.boiler{background:var(--bg-2);border-left:3px solid var(--green);padding:14px 18px;
  font-size:15px;color:var(--ink-dim);max-width:var(--readw)}

/* ---- footer --------------------------------------------------------- */
.site-footer{border-top:3px double var(--red-deep);margin-top:10px;background:#050507;
  padding:30px 0 50px;font-size:14px;color:var(--ink-faint)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:24px;margin-bottom:22px}
.foot-grid h4{font-family:var(--mono);text-transform:uppercase;letter-spacing:1px;font-size:12px;
  color:var(--green);margin:0 0 10px}
.foot-grid a{display:block;color:var(--ink-dim);text-decoration:none;padding:3px 0}
.foot-grid a:hover{color:var(--green)}
.foot-brand .l1{font-weight:bold;color:var(--green)}
.foot-brand p{font-size:13px;margin:8px 0 0}
.foot-ring{text-align:center;border-top:1px solid var(--border);padding:20px 0 6px;margin-bottom:14px}
.foot-ring .badge{display:inline-block;box-shadow:2px 2px 0 #000;margin:0 auto 8px}
.foot-ring .head{display:block;font-family:var(--mono);text-transform:uppercase;letter-spacing:2px;
  font-size:12px;color:var(--green);margin:0 0 8px}
.foot-ring .ring-nav{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;font-family:var(--mono);font-size:14px}
.foot-ring .tag{display:block;color:var(--ink-faint);font-size:12px;margin-top:8px}
.foot-bottom{border-top:1px solid var(--border);padding-top:16px;text-align:center;line-height:1.7}
.counter{font-family:var(--mono);color:var(--green);font-size:12px}
.odometer{background:#000;border:1px solid var(--green-dim);padding:1px 6px;letter-spacing:3px}
.blink{animation:blink 1.1s steps(2,start) infinite}
@keyframes blink{to{visibility:hidden}}
@media (prefers-reduced-motion:reduce){.blink{animation:none}}

/* ---- persistent CTA band ------------------------------------------- */
.cta-band{background:
   radial-gradient(ellipse 80% 120% at 50% 0%, #16122a 0%, #0b0a12 70%, var(--bg) 100%);
  border-top:3px double var(--red-deep);border-bottom:3px double var(--red-deep)}
.cta-band h2{text-shadow:0 0 16px rgba(57,255,20,.25)}

/* ---- manifesto ------------------------------------------------------ */
.manifesto-hero{position:relative;border-bottom:3px double var(--red-deep);text-align:center;padding:54px 0 46px;
  background:radial-gradient(ellipse 90% 90% at 50% 0%, #1d1430 0%, #0a0712 55%, #000 100%)}
.manifesto-hero h1{font-size:42px;margin:6px auto 14px;max-width:780px;
  text-shadow:0 2px 0 #000,0 0 26px rgba(57,255,20,.2)}
.manifesto-hero h1 .hl{color:var(--green)}
.manifesto-hero .sub{font-size:18px;color:var(--ink-dim);max-width:660px;margin:0 auto}
.creed-wrap{padding-top:30px}
.creed{max-width:760px;margin:0 auto 14px;border-left:4px solid var(--green);padding:14px 0 14px 22px}
.creed.alt{border-left-color:var(--red)}
.creed-line{font-family:var(--serif);font-weight:bold;font-size:30px;line-height:1.15;color:#fff;margin:0 0 6px}
.creed.alt .creed-line{color:#fff}
.creed-sub{font-size:16px;color:var(--ink-dim);margin:0}
@media(max-width:680px){.creed-line{font-size:23px}}

/* ---- big quote band ------------------------------------------------- */
.big-quote{background:#0b0a12;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.bq-lead{font-family:var(--serif);font-style:italic;font-weight:bold;font-size:30px;color:var(--green);
  max-width:760px;margin:0 auto 12px;text-shadow:0 0 16px rgba(57,255,20,.22)}
.bq-body{font-size:18px;color:var(--ink-dim);max-width:680px;margin:0 auto}
@media(max-width:680px){.bq-lead{font-size:23px}}

/* ---- research ------------------------------------------------------- */
.rsec{border-top:1px solid var(--border);padding:24px 0}
.rsec:first-child{border-top:0}
.rsec-head{display:flex;align-items:baseline;gap:14px}
.rnum{font-family:var(--mono);color:var(--green);font-size:15px;font-weight:bold}
.rsec h3{font-size:23px;margin:0;color:#fff}
.rsec>p{font-size:16px;color:var(--ink-dim);margin:8px 0 12px}
.rsrc{list-style:none;padding:0;margin:0 0 12px}
.rsrc li{font-size:15px;color:var(--ink-dim);padding:10px 0 10px 16px;border-left:2px solid var(--border-lit);margin:0 0 8px}
.cite{display:inline-block;margin-top:4px;font-family:var(--mono);font-size:12.5px;text-transform:uppercase;letter-spacing:.5px}
.rkey{border-left:3px solid var(--red);padding-left:12px;color:#fff;font-style:italic;font-size:17px;margin:0}

/* ---- directory ------------------------------------------------------ */
.dir-tools{margin:0 0 24px}
#dir-search{width:100%;max-width:520px;padding:11px 14px;background:#000;color:var(--ink);
  border:1px solid var(--border);font-family:var(--mono);font-size:15px;margin:0 0 14px}
#dir-search:focus{outline:1px solid var(--green);border-color:var(--green)}
.dir-chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{font-family:var(--mono);font-size:12.5px;text-transform:uppercase;letter-spacing:.5px;text-decoration:none;
  color:var(--ink-dim);background:var(--bg-2);border:1px solid var(--border);padding:6px 11px}
.chip:hover{border-color:var(--green-dim);color:var(--green)}
.chip.on{background:var(--green);color:#000;border-color:var(--green-dim);font-weight:bold}
.chip span{opacity:.7;margin-left:3px}
.chip.on span{opacity:.85}
.dir-h{font-size:16px;font-family:var(--mono);text-transform:uppercase;letter-spacing:2px;color:var(--green);
  margin:26px 0 12px;border-bottom:1px solid var(--green-dim);padding-bottom:6px}
.cat-tag{display:inline-block;font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.5px;
  color:var(--gold);border:1px solid var(--border-lit);padding:1px 6px;margin:4px 0 0;vertical-align:middle}
.dir-emptycat{text-align:center;background:var(--bg-2);border:1px dashed var(--border-lit);padding:26px;margin-top:10px}
.dir-emptycat p{color:var(--ink-dim)}

/* ---- support -------------------------------------------------------- */
.soon{display:inline-block;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:1px;
  color:var(--gold);border:1px solid var(--gold);padding:1px 7px;margin-left:4px}

/* ---- founder -------------------------------------------------------- */
.founder-grid{display:grid;grid-template-columns:300px 1fr;gap:30px;align-items:start;margin-top:18px}
@media(max-width:680px){.founder-grid{grid-template-columns:1fr;gap:18px}}

/* ---- responsive ----------------------------------------------------- */
@media (max-width:860px){
  .foot-grid{grid-template-columns:1fr 1fr}
  .grid.cols-3{grid-template-columns:1fr 1fr}
  .kit{grid-template-columns:1fr 1fr}
}
@media (max-width:680px){
  body{font-size:16px}
  .logo .l1{font-size:34px}
  .logo .l2{font-size:15px;letter-spacing:7px}
  .hero h1,.section h2{font-size:26px}
  .grid.cols-2,.grid.cols-3,.dir,.kit{grid-template-columns:1fr}
  /* mobile nav toggle */
  .nav .wrap{align-items:stretch}
  .nav-toggle{display:block;margin-left:auto;background:#000;color:var(--green);
    border:1px solid var(--green-dim);font-family:var(--mono);font-size:13px;text-transform:uppercase;
    letter-spacing:1px;padding:9px 14px;cursor:pointer}
  .nav-links{display:none;flex-basis:100%;flex-direction:column}
  .nav-links.open{display:flex}
  .nav-links a{border-bottom:1px solid var(--border)}
  .nav .nav-cta{margin:8px 0}
  /* timeline collapses to single column on the left */
  .timeline::before{left:9px}
  .tl-era{text-align:left;padding-left:6px}
  .tl-entry{width:100%;left:0 !important;text-align:left !important;padding:0 0 22px 34px}
  .tl-entry .dot{left:2px !important;right:auto !important}
  .js-on .tl-entry.left,.js-on .tl-entry.right{transform:translateY(18px)}
  .js-on .tl-entry.in{transform:none}
}
