/* Colibri Soli — Founders Digest v2.
   Editorial field guide with motion: cream paper, ink chapters, one inverted
   section, hand-drawn SVG only. Typography does the heavy lifting. */

:root{
  --paper:#FAF6EF; --paper-2:#F2EBDD; --paper-3:#EDE4D2; --card:#FFFFFF;
  --ink:#161D24; --ink-2:#222B34; --ink-soft:#3A434D; --muted:#6A7480;
  --line:#E5DED2; --line-2:#D2C8B5;
  --teal:#1FA792; --teal-deep:#0E7A68; --teal-pale:#E3F2EE;
  --coral:#FF8A5C; --coral-deep:#D4502B; --coral-pale:#FFEFE6;
  --gold:#E0B45C; --gold-deep:#9C7420; --gold-pale:#F8EFDA;
  --radius:14px; --wrap:1120px;
  --serif:Fraunces,Georgia,"Times New Roman",serif;
  --sans:Inter,-apple-system,"Segoe UI",sans-serif;
  --mono:"Spline Sans Mono",ui-monospace,monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:84px}
body{margin:0;background:var(--paper);color:var(--ink);font:15.5px/1.62 var(--sans);-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.1;margin:0 0 .4em}
a{color:var(--teal-deep)}
button{font:inherit}
::selection{background:var(--gold);color:var(--ink)}

/* ───────── progress rail ───────── */
#rail{position:fixed;left:18px;top:0;bottom:0;width:26px;z-index:55;display:flex;justify-content:center}
.rail-line{position:absolute;top:90px;bottom:60px;width:1px;background:var(--line-2)}
.rail-bird{position:absolute;top:90px;width:22px;height:22px;margin-left:1px;transform:translateY(0);transition:transform .25s ease}
.rail-bird img{width:22px;height:22px;filter:saturate(.9)}
#railDots{list-style:none;margin:0;padding:0;position:absolute;top:90px;bottom:60px;width:100%}
#railDots a{position:absolute;left:50%;transform:translateX(-50%);width:7px;height:7px;border-radius:50%;
  background:var(--line-2);display:block;transition:background .2s, transform .2s}
#railDots a:hover{transform:translateX(-50%) scale(1.7)}
#railDots a.active{background:var(--coral-deep)}
#railDots a .tip{position:absolute;left:16px;top:50%;transform:translateY(-50%);white-space:nowrap;
  font-size:.72rem;font-weight:600;color:var(--ink);background:var(--card);border:1px solid var(--line);
  padding:3px 9px;border-radius:7px;opacity:0;pointer-events:none;transition:opacity .15s}
#railDots a:hover .tip{opacity:1}
@media (max-width:1280px){#rail{display:none}}

/* ───────── topbar: two calm rows, zero layout shift ───────── */
#topbar{position:sticky;top:0;z-index:60;background:color-mix(in srgb,var(--paper) 92%,transparent);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.tb-row{display:flex;align-items:center;gap:14px;max-width:var(--wrap);margin:0 auto;padding:0 22px}
.tb-main{height:52px}
.tb-tools{height:46px;border-top:1px solid var(--line)}
.tb-spacer{flex:1}
.brand{display:flex;align-items:center;gap:9px;text-decoration:none;color:var(--ink);
  font-family:var(--serif);font-size:1.02rem;font-weight:600;white-space:nowrap}
.brand img{width:28px;height:28px}
.brand em{font-style:italic;color:var(--muted);font-weight:400}
#herepin{display:flex;flex-direction:column;justify-content:center;line-height:1.2;text-decoration:none;
  padding:0 14px;border-left:2px solid var(--coral);min-width:150px;height:34px;
  opacity:0;transition:opacity .25s ease;pointer-events:none}
#herepin.show{opacity:1;pointer-events:auto}
#herepin em{font-family:var(--mono);font-style:normal;font-size:.58rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted)}
#herepin b{font-family:var(--serif);font-weight:600;font-size:.92rem;color:var(--ink);white-space:nowrap}
@media (max-width:760px){#herepin{display:none}}
.search{display:flex;align-items:center;gap:7px;background:var(--card);border:1px solid var(--line);
  border-radius:999px;padding:7px 13px;flex:0 0 auto}
.search svg{width:14px;height:14px;color:var(--muted);flex:none}
.search input{border:0;outline:0;background:none;font:inherit;font-size:.85rem;width:150px;color:var(--ink)}
.flabel{font-family:var(--mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);white-space:nowrap;flex:0 0 auto}
.filterchips{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;min-width:0;flex:1;
  -webkit-mask:linear-gradient(90deg,#000 92%,transparent);mask:linear-gradient(90deg,#000 92%,transparent)}
.filterchips::-webkit-scrollbar{display:none}
.fchip{padding:6px 13px;border-radius:999px;border:1px solid var(--line-2);background:transparent;
  font-size:.76rem;font-weight:600;color:var(--muted);cursor:pointer;white-space:nowrap;transition:all .15s;flex:0 0 auto}
.fchip:hover{border-color:var(--ink);color:var(--ink)}
.fchip.on{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.pill{display:inline-flex;align-items:center;gap:7px;padding:7px 14px;border-radius:999px;
  border:1px solid var(--line-2);background:var(--card);cursor:pointer;font-size:.82rem;font-weight:600;color:var(--ink);white-space:nowrap}
.pill:hover{border-color:var(--gold-deep)}
.pill .staricon{width:14px;height:14px;fill:var(--gold)}
#shortlistCount{color:var(--muted);font-weight:500}
.whoami{font-size:.78rem;color:var(--muted);white-space:nowrap}
.whoami .dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:5px}
@media (max-width:640px){.pill-label{display:none}.whoami b{display:none}.search input{width:110px}}

/* ───────── card reader modal ───────── */
#cardmodal{position:fixed;inset:0;z-index:100;background:rgba(22,29,36,.45);
  display:flex;align-items:flex-start;justify-content:center;padding:7vh 18px 5vh;overflow-y:auto;
  backdrop-filter:blur(3px)}
#cardmodal[hidden]{display:none}
.cm-card{position:relative;width:min(780px,100%);background:var(--card);border-radius:18px;
  border:1px solid var(--line-2);box-shadow:0 30px 90px rgba(22,29,36,.3);
  padding:34px 38px 30px;animation:cmIn .22s cubic-bezier(.2,.8,.3,1)}
@keyframes cmIn{from{opacity:0;transform:translateY(14px) scale(.985)}to{opacity:1;transform:none}}
@media (max-width:600px){.cm-card{padding:24px 20px}}
.cm-x{position:absolute;top:14px;right:16px;background:none;border:0;cursor:pointer;
  color:var(--muted);font-size:1.05rem;padding:8px;border-radius:9px}
.cm-x:hover{background:var(--paper-2);color:var(--ink)}
.cm-kind{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.cm-kind.success{color:var(--teal-deep)} .cm-kind.caution{color:var(--coral-deep)}
.cm-kind.path{color:var(--gold-deep)} .cm-kind.deadline{color:var(--coral-deep)}
.cm-card h2{font-size:clamp(1.5rem,3.4vw,2.1rem);margin:.25em 0 .15em}
.cm-era{font-size:.86rem;color:var(--muted);margin:0 0 4px}
.cm-when{display:inline-block;font-family:var(--mono);font-size:.7rem;color:var(--coral-deep);
  background:var(--coral-pale);padding:3px 10px;border-radius:999px;margin:4px 0 2px}
.cm-hallmark{font-family:var(--serif);font-style:italic;font-size:1.18rem;color:var(--ink-soft);margin:8px 0 2px}
.cm-gist{font-size:1.02rem;color:var(--ink-soft);margin:10px 0 4px}
.cm-card .facts{border-top:1px solid var(--line);padding-top:14px;margin-top:12px}
.cm-card .fact{font-size:.92rem}
.cm-card .meta{display:flex;gap:22px;flex-wrap:wrap;margin:12px 0 0}
.cm-card .meta span{display:flex;flex-direction:column;font-size:.66rem;text-transform:uppercase;
  letter-spacing:.1em;color:var(--muted);font-weight:600}
.cm-card .meta b{font-family:var(--serif);font-size:1.05rem;font-weight:600;color:var(--ink);text-transform:none;letter-spacing:0}
.cm-star{position:absolute;top:14px;right:56px}
body.cm-open{overflow:hidden}

/* ───────── hero ───────── */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.hero-inner{max-width:var(--wrap);margin:0 auto;padding:84px 24px 70px;position:relative}
.hero-mark{position:absolute;right:-30px;top:30px;width:min(40vw,460px);opacity:.9;pointer-events:none}
@media (max-width:900px){.hero-mark{width:230px;opacity:.35;right:-40px}}
#birdDraw{width:100%}
#birdDraw .bd-ring{fill:none;stroke:var(--gold);stroke-width:1.6;stroke-linecap:round;
  stroke-dasharray:214;stroke-dashoffset:214;animation:draw 2.2s .3s ease forwards}
#birdDraw .bd-bird{fill:none;stroke:var(--teal-deep);stroke-width:1.6;stroke-linecap:round;
  stroke-dasharray:330;stroke-dashoffset:330;animation:draw 2.6s 1s ease forwards}
@keyframes draw{to{stroke-dashoffset:0}}
.overline{font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--coral-deep)}
.hero h1{font-size:clamp(2.6rem,6.2vw,4.6rem);font-weight:400;margin:16px 0 20px;max-width:13em}
.hero h1 em{font-style:italic;font-weight:600;color:var(--coral-deep)}
.lede{max-width:560px;font-size:1.12rem;color:var(--ink-soft)}
.hero-stats{display:flex;gap:34px;margin:30px 0 8px;flex-wrap:wrap}
.hero-stats span{display:flex;flex-direction:column;font-size:.78rem;color:var(--muted);
  text-transform:uppercase;letter-spacing:.12em;font-weight:600}
.hero-stats b{font-family:var(--serif);font-size:2.1rem;font-weight:600;color:var(--ink);line-height:1}
.doors3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin:30px 0 12px;max-width:830px}
@media (max-width:760px){.doors3{grid-template-columns:1fr}}
.door{display:flex;flex-direction:column;gap:3px;padding:18px 20px;background:var(--card);
  border:1px solid var(--line);border-radius:var(--radius);text-decoration:none;color:var(--ink);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s}
.door:hover{transform:translateY(-3px);border-color:var(--teal);box-shadow:0 12px 30px rgba(22,29,36,.08)}
.door-k{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.door-t{font-family:var(--serif);font-size:1.3rem;font-weight:600;font-style:italic}
.door-a{font-size:.82rem;color:var(--teal-deep);font-weight:600;margin-top:7px}
.hero-hint{font-size:.84rem;color:var(--muted)}

/* ───────── shelf scaffolding ───────── */
.shelf{padding:70px 0 26px}
.shelf-inner,.shelf-head,.liblist{max-width:var(--wrap);margin:0 auto;padding-left:24px;padding-right:24px}
.shelf-head{max-width:calc(660px + 48px);margin-bottom:30px}
.ch-rule{display:flex;align-items:baseline;gap:14px;border-top:2px solid var(--ink);padding-top:12px;margin-bottom:14px}
.ch-num{font-family:var(--serif);font-style:italic;font-size:1.05rem;color:var(--coral-deep)}
.ch-kicker{font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:500}
.shelf h2{font-size:clamp(1.9rem,3.6vw,2.7rem);font-weight:600}
.shelf-intro{color:var(--ink-soft);font-size:1.02rem}
.shelf[data-tone="2"]{background:var(--paper-2)}
.shelf[data-tone="3"]{background:var(--paper-3)}

/* starbox (shared) */
.starbox{position:absolute;top:12px;right:12px;display:flex;align-items:center;gap:3px;z-index:3}
.starbtn{background:none;border:0;cursor:pointer;padding:4px;line-height:0;border-radius:8px}
.starbtn:hover{background:rgba(0,0,0,.05)}
.starbtn svg{width:17px;height:17px;fill:none;stroke:var(--line-2);stroke-width:1.6;transition:transform .15s}
.starbtn.on svg{fill:var(--me-color);stroke:var(--me-color)}
.starbtn.pop svg{animation:starpop .4s ease}
@keyframes starpop{0%{transform:scale(1)}40%{transform:scale(1.45) rotate(12deg)}100%{transform:scale(1)}}
.otherstars{display:flex;gap:2px}
.otherstars svg{width:12px;height:12px}
.inverted .starbtn:hover{background:rgba(255,255,255,.12)}
.inverted .starbtn svg{stroke:#5A6570}

/* citation sups */
sup.cite{cursor:pointer;color:var(--teal-deep);font-weight:600;padding:0 2px;font-size:.72em}
sup.cite:hover{text-decoration:underline}
.inverted sup.cite{color:#7FD8C8}
.cites{margin-top:10px;font-size:.78rem;color:var(--muted)}

/* spark line */
.spark{margin-top:12px;padding:10px 14px;border-left:3px solid var(--gold);
  font-family:var(--serif);font-size:1rem;font-style:italic;color:var(--ink-soft);
  background:var(--gold-pale);border-radius:0 9px 9px 0}
.inverted .spark{background:#1F2933;color:#D9CFBA;border-left-color:var(--gold)}

/* chips */
.chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.chip{font-size:.74rem;padding:4px 10px;border-radius:999px;background:var(--teal-pale);color:var(--teal-deep);
  border:1px solid #CDE9E2;font-weight:500}

/* facts grid */
.facts{margin:10px 0 2px;display:flex;flex-direction:column;gap:9px}
.fact{display:grid;grid-template-columns:130px 1fr;gap:10px;font-size:.88rem}
.fact b{font-family:var(--mono);font-weight:500;color:var(--muted);font-size:.72rem;
  text-transform:uppercase;letter-spacing:.06em;line-height:1.7}
@media (max-width:560px){.fact{grid-template-columns:1fr;gap:2px}}

/* ── HAND: ledger rows ── */
.ledger{display:flex;flex-direction:column;border-top:1px solid var(--line-2)}
.ledger .row{position:relative;display:grid;grid-template-columns:minmax(220px,.85fr) 1.6fr;gap:26px;
  padding:26px 56px 26px 0;border-bottom:1px solid var(--line-2);cursor:pointer;transition:background .15s}
.ledger .row:hover{background:rgba(255,255,255,.55)}
.ledger h3{font-size:clamp(1.3rem,2.4vw,1.8rem);font-weight:600;margin:0}
.ledger .gist{color:var(--ink-soft);margin:0;font-size:.95rem}
.ledger .body{grid-column:2;display:none}
.ledger .row.open .body{display:block}
.ledger .row .more{font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--teal-deep);margin-top:8px;display:inline-block}
.ledger .row.open .more{display:none}
@media (max-width:760px){.ledger .row{grid-template-columns:1fr}.ledger .body{grid-column:1}}

/* ── GRAVITY: inverted forces ── */
.shelf-gravity{background:var(--ink);color:#EDE7DA}
.shelf-gravity .ch-rule{border-top-color:#EDE7DA}
.shelf-gravity .ch-kicker{color:#9AA5B1}
.shelf-gravity .shelf-intro{color:#B9C1CA}
.forces{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:16px;padding-bottom:46px}
.force{position:relative;background:var(--ink-2);border:1px solid #2E3944;border-radius:var(--radius);
  padding:22px 20px 18px;cursor:pointer;overflow:hidden;transition:border-color .2s, transform .2s}
.force:hover{border-color:#4A5663;transform:translateY(-2px)}
.force.open{border-color:var(--gold);cursor:default}
.force .bignum{position:absolute;right:10px;top:-14px;font-family:var(--serif);font-style:italic;
  font-size:5.4rem;font-weight:300;color:#2A3640;line-height:1;user-select:none}
.force h3{font-size:1.18rem;color:#F2EEE4;position:relative}
.force .gist{font-size:.9rem;color:#AEB7C0;position:relative;margin:0}
.force .body{display:none;position:relative}
.force.open .body{display:block}
.force .fact b{color:#8893A0}
.force .fact{color:#D5DAE0}
.force .more{font-family:var(--mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-top:10px;display:inline-block}
.force.open .more{display:none}
.force .cites{color:#7E8995}

/* ── MAP: chart + stat tiles ── */
.mapwrap{display:grid;grid-template-columns:1.05fr .95fr;gap:26px;align-items:start;padding-bottom:46px}
@media (max-width:900px){.mapwrap{grid-template-columns:1fr}}
.mapchart{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.mapchart h3{font-size:1.05rem}
.mapchart .sub{font-size:.8rem;color:var(--muted);margin:0 0 14px}
.bars{display:flex;flex-direction:column;gap:14px}
.bar{display:grid;grid-template-columns:150px 1fr 74px;align-items:center;gap:10px;font-size:.82rem}
.bar .lbl{color:var(--ink-soft);font-weight:500}
.bar .track{height:14px;background:var(--paper-2);border-radius:7px;overflow:hidden}
.bar .fill{height:100%;border-radius:7px;width:0;transition:width 1.1s cubic-bezier(.2,.7,.2,1)}
.bar .val{font-family:var(--mono);font-size:.74rem;color:var(--muted);text-align:right}
.bar.up .fill{background:linear-gradient(90deg,var(--teal),#36C2AB)}
.bar.down .fill{background:linear-gradient(90deg,var(--coral),#FFA37C)}
.mapchart .note{font-size:.76rem;color:var(--muted);margin-top:12px}
.maptiles{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:560px){.maptiles{grid-template-columns:1fr}}
.tile{position:relative;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px;cursor:pointer;transition:border-color .15s}
.tile:hover{border-color:var(--line-2)}
.tile.open{cursor:default;border-color:var(--ink)}
.tile .kpi{font-family:var(--serif);font-size:1.7rem;font-weight:600;line-height:1.1}
.tile h3{font-size:.98rem;margin:.2em 0}
.tile .gist{font-size:.84rem;color:var(--ink-soft);margin:0}
.tile .body{display:none}
.tile.open .body{display:block}
.tile .more{font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--teal-deep)}
.tile.open .more{display:none}

/* ── PATHS: feature panels ── */
.paths{display:grid;grid-template-columns:1fr 1fr;gap:18px;padding-bottom:46px}
@media (max-width:980px){.paths{grid-template-columns:1fr}}
.panel{position:relative;background:var(--card);border:1px solid var(--line);border-left:5px solid var(--accent,var(--gold));
  border-radius:var(--radius);padding:24px 24px 18px;cursor:pointer;transition:transform .18s, box-shadow .18s}
.panel:hover{transform:translateY(-2px);box-shadow:0 14px 36px rgba(22,29,36,.08)}
.panel.open{cursor:default}
.panel .pk{font-family:var(--mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-deep,var(--gold-deep));font-weight:500}
.panel h3{font-size:clamp(1.35rem,2.4vw,1.7rem);margin:.25em 0 .3em}
.panel .gist{color:var(--ink-soft);font-size:.95rem;margin:0}
.panel .meta{display:flex;gap:18px;margin-top:14px;flex-wrap:wrap}
.panel .meta span{display:flex;flex-direction:column;font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:600}
.panel .meta b{font-family:var(--serif);font-size:1.06rem;font-weight:600;color:var(--ink);text-transform:none;letter-spacing:0}
.panel .body{display:none}
.panel.open .body{display:block}
.panel .more{font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--teal-deep);margin-top:12px;display:inline-block}
.panel.open .more{display:none}

/* ── FIELD GUIDE: expand-in-place story cards ── */
.fgcards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;padding-bottom:46px;grid-auto-flow:dense}
.fgcard{position:relative;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;cursor:pointer;display:flex;flex-direction:column;min-height:200px;
  transition:border-color .18s, box-shadow .18s}
.fgcard:hover{box-shadow:0 10px 28px rgba(22,29,36,.07)}
.fgcard.success{border-top:4px solid var(--teal)}
.fgcard.caution{border-top:4px solid var(--coral)}
.fgcard .era{font-family:var(--mono);font-size:.7rem;color:var(--muted);letter-spacing:.06em;padding-right:54px}
.fgcard h3{font-size:1.35rem;margin:.3em 0 .2em}
.fgcard .bignote{font-family:var(--serif);font-style:italic;font-size:1.04rem;color:var(--ink-soft);margin-top:auto}
.fgcard .more{font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--teal-deep);margin-top:14px}
.fgcard .tag{position:absolute;bottom:18px;right:18px;font-family:var(--mono);font-size:.64rem;
  text-transform:uppercase;letter-spacing:.1em;padding:3px 9px;border-radius:999px}
.fgcard.success .tag{background:var(--teal-pale);color:var(--teal-deep)}
.fgcard.caution .tag{background:var(--coral-pale);color:var(--coral-deep)}
.fgcard .body{display:none}
.fgcard.open{grid-column:1 / -1;cursor:default;border-color:var(--ink)}
.fgcard.open .bignote,.fgcard.open .more,.fgcard.open .tag{display:none}
.fgcard.open .body{display:grid;grid-template-columns:230px 1fr;gap:28px;margin-top:14px;
  border-top:1px solid var(--line);padding-top:18px}
@media (max-width:760px){.fgcard.open .body{grid-template-columns:1fr}}
.fgcard .id-col .hallmark{font-family:var(--serif);font-style:italic;font-size:1.25rem;line-height:1.3;color:var(--ink)}
.fgcard .id-col .verdict{display:inline-block;margin-top:12px;font-family:var(--mono);font-size:.64rem;
  text-transform:uppercase;letter-spacing:.1em;padding:3px 9px;border-radius:999px}
.fgcard.success .id-col .verdict{background:var(--teal-pale);color:var(--teal-deep)}
.fgcard.caution .id-col .verdict{background:var(--coral-pale);color:var(--coral-deep)}
.fgcard .tale .gist{font-size:.95rem;color:var(--ink-soft);margin:0 0 4px}
.closex{display:none;position:absolute;top:10px;right:42px;background:none;border:0;cursor:pointer;
  color:var(--muted);font-size:1rem;padding:6px;border-radius:8px}
.closex:hover{background:var(--paper-2);color:var(--ink)}
.fgcard.open .closex{display:block}

/* ── BORROWED: recipe cards ── */
.recipes{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:14px;padding-bottom:46px}
.recipe{position:relative;background:var(--card);border:1px dashed var(--line-2);border-radius:var(--radius);
  padding:20px;cursor:pointer;transition:border-color .15s, background .15s}
.recipe:hover{border-color:var(--gold-deep)}
.recipe.open{border-style:solid;border-color:var(--ink);cursor:default}
.recipe .from{font-family:var(--mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-deep)}
.recipe h3{font-size:1.2rem;margin:.25em 0}
.recipe .gist{font-size:.88rem;color:var(--ink-soft);margin:0}
.recipe .body{display:none}
.recipe.open .body{display:block}
.recipe .more{font-family:var(--mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--teal-deep);margin-top:10px;display:inline-block}
.recipe.open .more{display:none}

/* ── grants wing band ── */
.grantswing{position:relative;background:var(--ink);color:#EDE7DA;border-radius:var(--radius);
  padding:30px 30px 26px;margin:6px 0 34px;overflow:hidden}
.grantswing::after{content:"";position:absolute;right:-50px;top:-60px;width:240px;height:240px;
  border:1.5px solid var(--gold);border-radius:50%;opacity:.25;transform:rotate(-38deg)}
.grantswing .gw-k{font-family:var(--mono);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.grantswing h3{font-size:clamp(1.4rem,2.6vw,1.9rem);color:#F2EEE4;margin:.3em 0 .35em}
.grantswing p{color:#B9C1CA;max-width:620px;font-size:.95rem;margin:0 0 16px}
.gw-stats{display:flex;gap:30px;flex-wrap:wrap;margin:4px 0 18px}
.gw-stats span{display:flex;flex-direction:column;font-family:var(--mono);font-size:.64rem;
  letter-spacing:.12em;text-transform:uppercase;color:#8893A0}
.gw-stats b{font-family:var(--serif);font-size:1.7rem;font-weight:600;color:#F2EEE4;line-height:1.1;letter-spacing:0}
.gw-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.gw-btn{display:inline-flex;align-items:center;gap:8px;padding:11px 20px;border-radius:999px;
  background:var(--gold);color:var(--ink);font-weight:600;font-size:.88rem;text-decoration:none;
  transition:transform .15s, background .15s}
.gw-btn:hover{background:#EBC777;color:var(--ink);transform:translateY(-1px)}
.gw-link{color:#7FD8C8;font-size:.85rem;text-decoration:none;font-weight:600}
.gw-link:hover{text-decoration:underline}
.gw-note{font-family:var(--mono);font-size:.68rem;color:#7E8995;margin-top:14px !important}
.gw-kit{margin-top:16px;border-top:1px solid #2E3944;padding-top:14px}
.gw-kit .kit-k{font-family:var(--mono);font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.reqviz{max-width:600px;margin:12px 0 4px}
.reqviz svg{width:100%;height:auto}
.rv-sort{display:flex;align-items:center;gap:8px;margin:10px 0 8px}
.rv-btn{padding:5px 13px;border-radius:999px;border:1px solid #3A4754;background:transparent;
  color:#AEB7C0;font-size:.74rem;font-weight:600;cursor:pointer;font-family:var(--mono);letter-spacing:.04em}
.rv-btn.on{background:var(--gold);border-color:var(--gold);color:var(--ink)}
.rv-hint{font-family:var(--mono);font-size:.64rem;color:#7E8995}
.rv-rows{max-width:680px;display:flex;flex-direction:column}
.rv-row{display:grid;grid-template-columns:150px 70px 1fr 64px;gap:12px;align-items:center;
  padding:7px 8px;border-radius:8px;cursor:pointer;font-size:.82rem}
.rv-row:hover{background:#222B34}
.rv-row .rv-label{color:#E7E1D4;font-weight:500}
.rv-row .rv-n{font-family:var(--mono);font-size:.7rem;color:#8893A0;text-align:right}
.rv-track{height:9px;background:#222B34;border-radius:5px;overflow:hidden}
.rv-track i{display:block;height:100%;background:linear-gradient(90deg,var(--gold),#C89A3F);border-radius:5px}
.rv-total{font-family:var(--mono);font-size:.74rem;color:var(--gold);text-align:right}
.rv-top{display:none;grid-column:1 / -1;padding:6px 4px 8px;border-bottom:1px solid #2E3944}
.rv-row.open .rv-top{display:flex;flex-direction:column;gap:4px}
.rv-top span{font-size:.78rem;color:#AEB7C0}
.rv-top b{color:#E7E1D4;font-family:var(--mono);font-size:.72rem;margin-right:4px}
@media (max-width:640px){.rv-row{grid-template-columns:110px 1fr 56px}.rv-row .rv-n{display:none}}

/* ── CALENDAR: timeline ── */
.timeline{position:relative;margin:8px 0 26px;height:74px}
.timeline .tl-line{position:absolute;left:0;right:0;top:34px;height:2px;background:var(--line-2)}
.timeline .tl-stop{position:absolute;top:0;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:5px;
  text-decoration:none;color:var(--ink)}
.tl-stop .tl-when{font-family:var(--mono);font-size:.64rem;letter-spacing:.08em;color:var(--muted);white-space:nowrap}
.tl-stop .tl-dot{width:13px;height:13px;border-radius:50%;background:var(--card);border:3px solid var(--teal-deep);transition:transform .15s}
.tl-stop:hover .tl-dot{transform:scale(1.35)}
.tl-stop.hot .tl-dot{border-color:var(--coral-deep);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(212,80,43,.35)}50%{box-shadow:0 0 0 7px rgba(212,80,43,0)}}
.tl-stop .tl-lbl{font-size:.7rem;font-weight:600;white-space:nowrap}
@media (max-width:760px){.timeline{display:none}}
.cal{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:14px;padding-bottom:46px}
.calcard{position:relative;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px 18px 14px;cursor:pointer;transition:border-color .15s}
.calcard:hover{border-color:var(--line-2)}
.calcard.open{border-color:var(--ink);cursor:default}
.calcard .when{display:inline-block;font-family:var(--mono);font-size:.7rem;font-weight:500;letter-spacing:.06em;
  color:var(--coral-deep);background:var(--coral-pale);padding:3px 10px;border-radius:999px;margin-bottom:8px}
.calcard h3{font-size:1.12rem;margin:0 0 .25em}
.calcard .gist{font-size:.88rem;color:var(--ink-soft);margin:0}
.calcard .body{display:none}
.calcard.open .body{display:block}
.calcard .more{font-family:var(--mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--teal-deep);margin-top:8px;display:inline-block}
.calcard.open .more{display:none}

/* ── DOORS: punch list ── */
.punch{display:flex;flex-direction:column;gap:10px;max-width:780px;padding-bottom:46px}
.punchrow{position:relative;display:flex;gap:16px;align-items:flex-start;background:var(--card);
  border:1px solid var(--line);border-radius:12px;padding:16px 56px 14px 18px;cursor:pointer;transition:border-color .15s}
.punchrow:hover{border-color:var(--line-2)}
.punchrow.open{border-color:var(--ink);cursor:default}
.punchrow .box{flex:none;width:22px;height:22px;border:2px solid var(--ink);border-radius:6px;margin-top:2px;
  display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--teal-deep)}
.punchrow h3{font-size:1.08rem;margin:0}
.punchrow .gist{font-size:.88rem;color:var(--ink-soft);margin:.15em 0 0}
.punchrow .body{display:none}
.punchrow.open .body{display:block}
.punchrow .more{font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--teal-deep)}
.punchrow.open .more{display:none}

/* ── library ── */
.shelf-library{background:var(--paper-2)}
.liblist{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:10px;padding-bottom:50px}
.libitem{display:flex;flex-direction:column;gap:2px;padding:14px 16px;background:var(--card);
  border:1px solid var(--line);border-radius:10px;font-size:.88rem;text-decoration:none;transition:border-color .15s, transform .15s}
.libitem:hover{border-color:var(--teal);transform:translateY(-1px)}
.libitem b{font-family:var(--serif);font-size:1rem;color:var(--ink)}
.libitem span{color:var(--muted);font-size:.8rem}

/* footer */
footer{max-width:var(--wrap);margin:0 auto;padding:40px 24px 60px;border-top:1px solid var(--line);
  display:flex;gap:16px;align-items:flex-start;color:var(--muted);font-size:.82rem}
.foot-line{font-family:var(--serif);font-size:1rem;color:var(--ink);margin:0 0 4px}
footer p{margin:0}
.prov{display:inline-block;font-size:.7rem;padding:1px 7px;border-radius:6px;font-weight:600}
.prov-web{background:var(--teal-pale);color:var(--teal-deep)} .prov-doc{background:var(--gold-pale);color:var(--gold-deep)}

/* drawer */
#drawer{position:fixed;inset:0;background:rgba(22,29,36,.4);z-index:90;display:flex;justify-content:flex-end}
#drawer[hidden]{display:none}
.drawer-card{width:min(440px,94vw);height:100%;background:var(--paper);border-left:1px solid var(--line-2);
  display:flex;flex-direction:column;padding:20px 22px;overflow-y:auto;animation:slidein .25s ease}
@keyframes slidein{from{transform:translateX(30px);opacity:.4}to{transform:none;opacity:1}}
.drawer-card header{display:flex;justify-content:space-between;align-items:center}
.drawer-card h3{font-size:1.5rem;margin:0}
.x{background:none;border:0;font-size:1.1rem;cursor:pointer;color:var(--muted);padding:6px}
.drawer-sub{font-size:.84rem;color:var(--muted)}
.legend{display:flex;gap:14px;margin:6px 0 14px;font-size:.8rem;flex-wrap:wrap}
.legend .dot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:5px}
.dr-item{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:12px 14px;margin-bottom:9px}
.dr-item h4{margin:0 0 3px;font-size:1rem}
.dr-item p{margin:0;font-size:.82rem;color:var(--ink-soft)}
.dr-item .who{display:flex;gap:4px;margin-top:7px}
.dr-item .who span{font-size:.7rem;font-weight:600;color:#fff;border-radius:999px;padding:2px 8px}
.dr-empty{color:var(--muted);font-size:.88rem;padding:18px 4px}

/* citation popover */
#citepop{position:absolute;z-index:120;max-width:330px;background:var(--ink);color:var(--paper);
  border-radius:10px;padding:11px 14px;font-size:.8rem;line-height:1.5;box-shadow:0 10px 34px rgba(0,0,0,.3);
  animation:popin .14s ease}
#citepop[hidden]{display:none}
@keyframes popin{from{opacity:0;transform:translateY(4px)}to{opacity:1}}
#citepop a{color:#7FD8C8;word-break:break-all}
#citepop .pv{font-family:var(--mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);font-weight:500}

/* hidden-by-filter */
.filtered-out{display:none !important}
.no-results{padding:30px 0 50px;color:var(--muted);font-style:italic;display:none}
.no-results.show{display:block}

/* reveal-on-scroll */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .65s ease, transform .65s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  #birdDraw .bd-ring,#birdDraw .bd-bird{animation:none;stroke-dashoffset:0}
  .flip-in{transition:none}
  .bar .fill{transition:none}
  .tl-stop.hot .tl-dot{animation:none}
  .drawer-card,#citepop{animation:none}
}
