
:root{
  --ink:#100e0b; --ink-2:#17140f; --ink-3:#1d1913; --card:#1a1611;
  --line:#2c271d; --line-2:#403929;
  --paper:#ece3d2; --dim:#a79e8a; --faint:#736b59;
  --gold:#e3a64b; --gold-soft:#f4cd8a; --ember:#c9743a;
  --display:"Fraunces",Georgia,serif; --body:"Newsreader",Georgia,serif;
  --mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  --sidebar-w:262px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--ink);color:var(--paper);font-family:var(--body);
  font-size:17px;line-height:1.72;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body::selection,*::selection{background:rgba(227,166,75,.25)}
a{color:var(--gold);text-decoration:none}
a:hover{color:var(--gold-soft)}
.mono{font-family:var(--mono)}

/* ---------- shared bits ---------- */
.kicker{font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--faint)}

/* ---------- HOME ---------- */
.home{background:
  radial-gradient(1100px 520px at 72% -8%, rgba(227,166,75,.10), transparent 60%),
  radial-gradient(800px 600px at -10% 110%, rgba(201,116,58,.06), transparent 55%),
  var(--ink);
  background-attachment:fixed}
.hub{max-width:880px;margin:0 auto;padding:5.5rem 2rem 5rem}
.reveal{opacity:0;transform:translateY(14px);animation:rise .8s cubic-bezier(.2,.65,.2,1) forwards;animation-delay:var(--d,0s)}
@keyframes rise{to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.reveal{animation:none;opacity:1;transform:none}}

.masthead{border-bottom:1px solid var(--line);padding-bottom:2.4rem;margin-bottom:3rem}
.masthead .kicker{display:block;margin-bottom:1.6rem}
.manifesto{font-family:var(--display);font-weight:500;font-size:clamp(2.7rem,7vw,4.6rem);
  line-height:.98;letter-spacing:-.025em;margin:0 0 1.3rem}
.manifesto em{font-style:italic;font-weight:500;color:var(--gold);
  background:linear-gradient(180deg,transparent 62%,rgba(227,166,75,.16) 62%)}
.lede{font-size:1.18rem;line-height:1.6;color:var(--dim);max-width:33em;margin:0}
.lede b{color:var(--paper);font-weight:500}

section{margin:3.2rem 0}
.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:1.1rem}
.section-head h2,.seasons h2,.index h2{font-family:var(--display);font-weight:500;font-size:1.55rem;
  letter-spacing:-.015em;margin:0}
.section-head .meta{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;color:var(--faint);
  text-transform:uppercase;white-space:nowrap}

/* today card */
.today{background:linear-gradient(180deg,var(--ink-3),var(--ink-2));border:1px solid var(--line-2);
  border-radius:16px;padding:1.9rem 2rem 1.6rem;position:relative;overflow:hidden}
.today::before{content:"";position:absolute;inset:0 0 auto 0;height:2px;
  background:linear-gradient(90deg,var(--gold),transparent 55%)}
.today-label{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);display:flex;align-items:center;gap:.6rem;margin-bottom:1.2rem}
.pulse{width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 0 rgba(227,166,75,.6);
  animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(227,166,75,.5)}70%{box-shadow:0 0 0 9px rgba(227,166,75,0)}100%{box-shadow:0 0 0 0 rgba(227,166,75,0)}}
.loop{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.65rem}
.loop li{display:flex;gap:1rem;align-items:baseline;font-size:1.18rem;font-family:var(--display);font-weight:400}
.loop .n{font-family:var(--mono);font-size:.8rem;color:var(--gold);font-weight:500;flex:0 0 auto;
  width:1.6em;padding-top:.2em}
.today-foot{margin-top:1.4rem;padding-top:1.1rem;border-top:1px solid var(--line);
  font-family:var(--mono);font-size:.74rem;letter-spacing:.08em;color:var(--faint);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem}
.today-foot b{color:var(--dim);font-weight:500}

/* terrain */
.terrain svg{width:100%;height:auto;display:block}
.terrain-caption{margin-top:.9rem;color:var(--dim);font-size:1rem}
.terrain-caption b{color:var(--paper);font-weight:500}

/* seasons timeline */
.timeline{list-style:none;margin:1rem 0 0;padding:0;position:relative}
.timeline::before{content:"";position:absolute;left:21px;top:10px;bottom:10px;width:1px;background:var(--line-2)}
.timeline li{display:flex;gap:1.2rem;align-items:flex-start;padding:.7rem 0;position:relative}
.timeline a{display:flex;gap:1.2rem;align-items:flex-start;color:inherit;width:100%}
.timeline a:hover .t-title{color:var(--gold-soft)}
.t-mark{font-family:var(--mono);font-size:.72rem;font-weight:500;color:var(--faint);
  flex:0 0 auto;width:42px;height:42px;border:1px solid var(--line-2);border-radius:50%;
  display:flex;align-items:center;justify-content:center;background:var(--ink);z-index:1}
.timeline .active .t-mark{color:var(--ink);background:var(--gold);border-color:var(--gold)}
.t-title{font-family:var(--display);font-size:1.18rem;font-weight:500;display:block;line-height:1.3}
.t-sub{font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--faint)}
.timeline .active .t-sub{color:var(--gold)}
.t-body{padding-top:.35rem}

/* index cards */
.cards{display:grid;grid-template-columns:1fr 1fr;gap:.9rem;margin-top:1rem}
.card{border:1px solid var(--line);border-radius:13px;padding:1.2rem 1.3rem;background:var(--ink-2);
  transition:border-color .2s,transform .2s;display:block}
.card:hover{border-color:var(--gold);transform:translateY(-2px)}
.card .c-k{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--faint)}
.card .c-t{font-family:var(--display);font-size:1.22rem;font-weight:500;color:var(--paper);margin:.45rem 0 .3rem;display:flex;align-items:center;justify-content:space-between}
.card:hover .c-t{color:var(--gold)}
.card .c-d{color:var(--dim);font-size:.96rem;line-height:1.5}
.hub > footer{margin-top:4rem;padding-top:1.6rem;border-top:1px solid var(--line);
  font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;color:var(--faint);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem}

/* ---------- CONTENT PAGES ---------- */
.topbar{display:none;position:sticky;top:0;z-index:20;align-items:center;gap:.6rem;
  padding:.55rem .9rem;background:var(--ink);border-bottom:1px solid var(--line)}
.topbar button{font-size:1.1rem;background:none;border:1px solid var(--line-2);border-radius:8px;color:var(--paper);padding:.1rem .5rem;cursor:pointer}
.topbar-title{font-family:var(--display);font-weight:500}
.layout{display:flex;align-items:flex-start}
.sidebar{width:var(--sidebar-w);flex:0 0 var(--sidebar-w);position:sticky;top:0;height:100vh;
  overflow-y:auto;padding:2.2rem 1.1rem;border-right:1px solid var(--line);background:var(--ink-2)}
.brand{display:flex;align-items:center;gap:.5rem;font-family:var(--display);font-weight:600;font-size:1.06rem;
  color:var(--paper);margin:.1rem .55rem 1.6rem;letter-spacing:-.01em}
.brand:hover{color:var(--gold)}
.brand-mark{color:var(--gold)}
.sidebar .nav-group{font-family:var(--mono);font-size:.64rem;text-transform:uppercase;letter-spacing:.14em;
  color:var(--faint);margin:1.5rem .65rem .4rem}
.sidebar ul{list-style:none;margin:0;padding:0}
.sidebar li a{display:block;padding:.28rem .6rem;border-radius:7px;color:var(--dim);font-size:.92rem}
.sidebar li a:hover{color:var(--paper);background:var(--ink-3)}
.sidebar li a.active{color:var(--gold);background:rgba(227,166,75,.08)}

main{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;align-items:center}
.prose{width:100%;max-width:720px;padding:3.4rem 2rem 1rem}
.foot{max-width:720px;width:100%;padding:2rem;color:var(--faint);font-family:var(--mono);font-size:.72rem}

.prose h1{font-family:var(--display);font-size:2.3rem;font-weight:500;letter-spacing:-.02em;line-height:1.12;margin:0 0 .55em}
.prose h2{font-family:var(--display);font-size:1.5rem;font-weight:500;letter-spacing:-.01em;margin:2.5em 0 .55em}
.prose h3{font-family:var(--display);font-size:1.18rem;font-weight:600;margin:1.9em 0 .4em}
.prose h4{font-family:var(--mono);font-size:.82rem;letter-spacing:.05em;text-transform:uppercase;margin:1.5em 0 .3em;color:var(--dim)}
.prose p{margin:.9em 0}
.prose ul,.prose ol{padding-left:1.3em;margin:.6em 0}
.prose li{margin:.34em 0}
.prose li::marker{color:var(--gold)}
.prose strong{font-weight:600;color:#f3ecdd}
.prose code{background:var(--ink-3);padding:.13em .42em;border-radius:5px;font-size:.8em;font-family:var(--mono);color:var(--gold-soft)}
.prose pre{background:var(--ink-2);border:1px solid var(--line);border-radius:11px;padding:1rem 1.1rem;overflow:auto;margin:1.1em 0}
.prose pre code{background:none;padding:0;color:var(--paper);font-size:.82em;line-height:1.55}
.prose blockquote{margin:1.3em 0;padding:.1em 0 .1em 1.2em;border-left:2px solid var(--gold);color:var(--dim);
  font-family:var(--display);font-style:italic;font-size:1.12em}
.prose blockquote p{margin:.3em 0}
.prose table{border-collapse:collapse;width:100%;margin:1.3em 0;font-size:.9rem;display:block;overflow-x:auto}
.prose th,.prose td{padding:.5em .85em;text-align:left;vertical-align:top;border-bottom:1px solid var(--line)}
.prose th{font-family:var(--mono);font-size:.74rem;letter-spacing:.04em;text-transform:uppercase;font-weight:500;color:var(--dim)}
.prose hr{border:none;border-top:1px solid var(--line);margin:2.6em 0}
.prose img{max-width:100%}
.prose details{margin:.4em 0 1.5em;border-left:2px solid var(--line-2);padding:.1em 0 .1em 1rem}
.prose summary{cursor:pointer;font-family:var(--mono);color:var(--gold);font-size:.8rem;letter-spacing:.04em;
  list-style:none;padding:.15em 0;user-select:none}
.prose summary::-webkit-details-marker{display:none}
.prose summary::before{content:"▸";color:var(--faint);margin-right:.55em}
.prose details[open]>summary::before{content:"▾"}
.prose details[open]>summary{margin-bottom:.5em;color:var(--gold-soft)}

@media (max-width:880px){
  .topbar{display:flex}
  .layout{flex-direction:column}
  .sidebar{position:fixed;top:46px;left:0;bottom:0;height:auto;width:82%;max-width:300px;
    transform:translateX(-105%);transition:transform .2s ease;z-index:15;box-shadow:0 0 50px rgba(0,0,0,.5)}
  .sidebar.open{transform:translateX(0)}
  .hub{padding:3.5rem 1.4rem 4rem}
  .prose{padding:2rem 1.3rem}
  .cards{grid-template-columns:1fr}
  .prose h1{font-size:1.7rem}
}
