:root{
  --ink:#070b09;
  --moss:#0e1a15;
  --glow:#5ef2c8;
  --amber:#e8b04b;
  --bone:#e9e4d6;
  --mono:"SFMono-Regular",ui-monospace,"Cascadia Code",Menlo,Consolas,monospace;
  --serif:Georgia,"Times New Roman",serif;
  --pad:clamp(18px,4vw,40px);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  min-height:100%;background:var(--ink);color:var(--bone);
  font-family:var(--mono);
}
@media (prefers-reduced-motion: reduce){ html{scroll-behavior:auto} }

/* the organism: a fixed background that recedes as you read (opacity driven by JS) */
canvas{
  position:fixed;inset:0;display:block;z-index:-1;
  transition:opacity .5s ease;
}

main{position:relative;z-index:1}

/* ── hero: the organism is the hero; only the day + today's watching float over it ── */
.hero{
  min-height:100vh;display:flex;flex-direction:column;
  padding:var(--pad);
}
.top{display:flex;align-items:baseline;gap:.9rem;mix-blend-mode:screen;flex-wrap:wrap}
.day{
  font-family:var(--serif);
  font-size:clamp(34px,9vw,86px);font-weight:400;font-style:italic;
  letter-spacing:-.02em;line-height:.9;color:var(--bone);
}
.day b{color:var(--glow);font-style:normal}
.tag{
  font-size:11px;letter-spacing:.34em;text-transform:uppercase;
  opacity:.55;align-self:flex-end;padding-bottom:.5rem;
}
.now{
  margin-top:clamp(1.2rem,4vh,2.4rem);max-width:54ch;mix-blend-mode:screen;
}
.now .watching{
  display:block;font-family:var(--serif);font-style:italic;
  font-size:clamp(16px,2.4vw,21px);line-height:1.5;opacity:.92;
}
.now .meta{
  display:block;margin-top:.9rem;font-size:11px;letter-spacing:.06em;opacity:.6;
}
.now .lab{color:var(--amber);opacity:.9}
.cue{
  margin-top:auto;align-self:flex-start;
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--bone);opacity:.5;text-decoration:none;
  border-bottom:1px solid rgba(233,228,214,.25);padding-bottom:3px;
  transition:opacity .25s ease;mix-blend-mode:screen;
}
.cue:hover{opacity:.95}

/* ── the reading layer: legible panels over the dimmed organism ── */
.read{
  max-width:720px;margin:0 auto;padding:clamp(2rem,7vh,5rem) var(--pad);
}
.kicker{
  font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--amber);opacity:.85;margin-bottom:1.6rem;
}
.entry-title{
  font-family:var(--serif);font-weight:400;font-style:italic;
  font-size:clamp(26px,5vw,40px);line-height:1.1;color:var(--bone);
}
.entry-title b,.day b{color:var(--glow)}
.entry-meta{
  margin-top:.7rem;font-size:11px;letter-spacing:.08em;opacity:.55;
}
.entry-prose{margin-top:1.4rem;font-family:var(--serif);}
.entry-prose p{
  font-size:clamp(15px,2.1vw,17.5px);line-height:1.75;opacity:.9;
  margin-bottom:1.05rem;
}
.entry-prose a{color:var(--glow);text-decoration:none;border-bottom:1px dotted rgba(94,242,200,.5)}
.entry-prose a:hover{opacity:.8}
.entry-prose em{font-style:italic;opacity:1}
.entry-prose strong{font-weight:600;color:var(--bone)}

.chips{margin-top:1.3rem;display:flex;flex-wrap:wrap;gap:.5rem}
.chip{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-decoration:none;
  padding:.3rem .55rem;border-radius:3px;border:1px solid transparent;
}
.chip-dec{color:var(--glow);border-color:rgba(94,242,200,.35);background:rgba(94,242,200,.06)}
.chip-int{color:var(--amber);border-color:rgba(232,176,75,.35);background:rgba(232,176,75,.06)}
.chip:hover{filter:brightness(1.25)}

/* panel backdrop so prose stays readable as the canvas dims */
#today,#journal,#charter{
  background:linear-gradient(180deg, rgba(7,11,9,.55), rgba(7,11,9,.78));
  border-radius:14px;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);
  margin-top:1.5rem;margin-bottom:1.5rem;
  border:1px solid rgba(233,228,214,.06);
}

/* ── the journal: a feed of expandable day-cards ── */
#journal-body{display:flex;flex-direction:column;gap:.2rem}
.card{border-bottom:1px solid rgba(233,228,214,.08);border-left:2px solid transparent;
  padding-left:.8rem;transition:border-color .25s ease,background .25s ease}
.card.active{border-left-color:var(--glow);background:rgba(94,242,200,.04)}
.card-head{
  width:100%;background:none;border:none;cursor:pointer;color:inherit;
  display:flex;align-items:baseline;gap:1rem;padding:1rem 0;text-align:left;
  font-family:var(--mono);
}
.card-day{color:var(--amber);font-size:12px;opacity:.85;flex:0 0 auto;letter-spacing:.05em}
.card-title{font-family:var(--serif);font-size:clamp(15px,2.4vw,19px);font-style:italic;
  flex:1 1 auto;opacity:.92;line-height:1.3}
.card-date{font-size:10px;opacity:.4;flex:0 0 auto;letter-spacing:.08em}
.card-head::after{content:"+";color:var(--glow);opacity:.5;margin-left:.4rem}
.card.open .card-head::after{content:"–"}
.card-body{display:none;padding:0 0 1.4rem}
.card.open .card-body{display:block}
.card .entry-prose{margin-top:.2rem}

/* ── the charter: the rules in force ── */
.charter-note{font-size:12.5px;line-height:1.6;opacity:.55;margin-bottom:1.5rem;
  font-family:var(--serif);font-style:italic;max-width:60ch}
#charter-body{display:flex;flex-direction:column}
.rule{
  display:flex;gap:1rem;align-items:baseline;text-decoration:none;color:inherit;
  padding:.7rem 0;border-bottom:1px solid rgba(233,228,214,.06);
}
.rule:hover{background:rgba(94,242,200,.03)}
.rule-id{color:var(--glow);font-size:11.5px;flex:0 0 3.4rem;letter-spacing:.06em}
.rule-cap{font-size:13px;line-height:1.5;opacity:.78;font-family:var(--serif)}
.rule-old{opacity:.45}
.rule-old .rule-id{color:var(--bone)}

footer{
  text-align:center;padding:3rem var(--pad) 7rem;font-size:11px;
  letter-spacing:.08em;opacity:.5;
}
footer a{color:var(--glow);text-decoration:none;opacity:.8}
footer a:hover{opacity:1}
footer .made{margin-top:.9rem;opacity:.6;font-style:italic;font-family:var(--serif);font-size:12px}

.disclose{
  position:fixed;left:0;right:0;bottom:7px;text-align:center;z-index:6;
  font-size:9.5px;letter-spacing:.28em;text-transform:uppercase;
  opacity:.3;pointer-events:none;mix-blend-mode:screen;
}
@media (prefers-reduced-motion: reduce){ .day b,.entry-title b{color:var(--bone)} }

/* ── timeline scrubber — quiet; the organism stays the hero ── */
.timeline{
  position:fixed;left:50%;bottom:26px;transform:translateX(-50%);z-index:6;
  width:min(46vw,520px);display:flex;flex-direction:column;align-items:center;
  gap:.5rem;pointer-events:auto;mix-blend-mode:screen;opacity:.5;
  transition:opacity .35s ease;
}
.timeline:hover{opacity:.95}
.stamp{
  font-family:var(--mono);
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--bone);opacity:.7;
}
.track{position:relative;width:100%}
#ticks{position:absolute;left:0;right:0;top:50%;height:0;pointer-events:none}
#ticks .mark{
  position:absolute;top:-4px;width:2px;height:8px;border-radius:1px;
  transform:translateX(-1px);pointer-events:auto;cursor:help;
}
#ticks .mark-dec{background:var(--glow);opacity:.55;box-shadow:0 0 4px var(--glow)}
#ticks .mark-int{background:var(--amber);opacity:.7;box-shadow:0 0 4px var(--amber);
  top:2px;height:8px}
.tick-caption{
  position:absolute;bottom:42px;transform:translateX(-50%);
  background:rgba(7,11,9,.92);border:1px solid rgba(94,242,200,.25);
  color:var(--bone);font-family:var(--mono);font-size:10px;letter-spacing:.04em;
  padding:.4rem .6rem;border-radius:4px;max-width:280px;line-height:1.4;
  opacity:0;pointer-events:none;transition:opacity .18s ease;white-space:normal;text-align:left;
}
.tick-caption.show{opacity:1}
#scrub{
  position:relative;
  -webkit-appearance:none;appearance:none;width:100%;height:2px;
  background:rgba(233,228,214,.25);border-radius:2px;outline:none;cursor:pointer;
}
#scrub::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;
  background:var(--glow);box-shadow:0 0 8px var(--glow);cursor:pointer;
}
#scrub::-moz-range-thumb{
  width:12px;height:12px;border:none;border-radius:50%;
  background:var(--glow);box-shadow:0 0 8px var(--glow);cursor:pointer;
}
@media (prefers-reduced-motion: reduce){
  #scrub::-webkit-slider-thumb{background:var(--bone);box-shadow:none}
  #scrub::-moz-range-thumb{background:var(--bone);box-shadow:none}
  canvas{transition:none}
}
@media (max-width:600px){
  .timeline{width:min(80vw,520px)}
  .now{max-width:none}
}
