@font-face{font-family:'Cormorant SC';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/cormorant-sc-400.woff2') format('woff2')}
@font-face{font-family:'Cormorant SC';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/cormorant-sc-500.woff2') format('woff2')}
@font-face{font-family:'Cormorant SC';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/cormorant-sc-600.woff2') format('woff2')}
@font-face{font-family:'Cormorant SC';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/cormorant-sc-700.woff2') format('woff2')}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:400 600;font-display:swap;src:url('fonts/cormorant-garamond-400.woff2') format('woff2')}
@font-face{font-family:'Cormorant Garamond';font-style:italic;font-weight:400;font-display:swap;src:url('fonts/cormorant-garamond-italic-400.woff2') format('woff2')}
@font-face{font-family:'IBM Plex Sans';font-style:normal;font-weight:300 700;font-display:swap;src:url('fonts/ibm-plex-sans.woff2') format('woff2')}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:300;font-display:swap;src:url('fonts/ibm-plex-mono-300.woff2') format('woff2')}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/ibm-plex-mono-400.woff2') format('woff2')}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/ibm-plex-mono-500.woff2') format('woff2')}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/ibm-plex-mono-600.woff2') format('woff2')}

:root{
  --bg:        #0d0f14;
  --bg-2:      #14171f;
  --surface:   #1a1e28;
  --surface-2: #232836;
  --line:      rgba(212,180,114,.16);
  --line-2:    rgba(255,255,255,.06);
  --ink:       #e9e2cf;
  --ink-2:     #b8b09a;
  --ink-3:     #7a7361;
  --accent:    #d4b472;
  --accent-2:  #8a6a2c;
  --accent-ink:#0d0f14;
  --rune:      #b88c3a;
  --term-bg:   #07090d;
  --term-fg:   #d4b472;
  --term-dim:  rgba(212,180,114,.5);
  --term-cursor:#e9e2cf;
  --danger:    #c45a4a;
  --good:      #6f9a6a;

  --serif: "Cormorant SC", "Cormorant Garamond", Georgia, serif;
  --serif-2: "Cormorant Garamond", Georgia, serif;
  --sans: "IBM Plex Sans", ui-sans-serif, system-ui, sans-serif;
  --mono: "IBM Plex Mono", ui-monospace, Menlo, monospace;

  --pad-x: clamp(20px, 5vw, 96px);
  --maxw: 1280px;
  --gap: clamp(48px, 8vw, 120px);
}

html[data-theme="parchment"]{
  --bg:        #f1e9d6;
  --bg-2:      #e7dec5;
  --surface:   #ede2c6;
  --surface-2: #e0d3b1;
  --line:      rgba(60,42,18,.18);
  --line-2:    rgba(60,42,18,.08);
  --ink:       #2b1f10;
  --ink-2:     #5a4730;
  --ink-3:     #8a7456;
  --accent:    #7a3a1a;
  --accent-2:  #5a2810;
  --accent-ink:#f1e9d6;
  --rune:      #7a3a1a;
  --term-bg:   #211a0e;
  --term-fg:   #e8d9b0;
  --term-dim:  rgba(232,217,176,.55);
  --term-cursor:#fff;
}

html[data-theme="terminal"]{
  --bg:        #02060a;
  --bg-2:      #02060a;
  --surface:   #04090e;
  --surface-2: #07101a;
  --line:      rgba(120,255,180,.18);
  --line-2:    rgba(120,255,180,.08);
  --ink:       #b9ffd2;
  --ink-2:     #6cd5a1;
  --ink-3:     #3a8a66;
  --accent:    #5cf7a5;
  --accent-2:  #2cb47a;
  --accent-ink:#02060a;
  --rune:      #5cf7a5;
  --term-bg:   #02060a;
  --term-fg:   #5cf7a5;
  --term-dim:  rgba(92,247,165,.5);
  --term-cursor:#b9ffd2;
  --serif: var(--mono);
  --serif-2: var(--mono);
  --sans: var(--mono);
}

html[data-density="compact"]{ --gap: clamp(32px, 5vw, 72px); }
html[data-density="comfy"]  { --gap: clamp(72px, 10vw, 160px); }

*{box-sizing:border-box}
[hidden]{display:none!important}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--sans);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer}

/* ── Screen-reader only ─────────────────────────────────────────────── */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ── Skip link ──────────────────────────────────────────────────────── */
.skip-link{
  position:absolute;left:-9999px;top:0;z-index:999;
  padding:12px 20px;background:var(--accent);color:var(--accent-ink);
  font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  white-space:nowrap
}
.skip-link:focus{left:0;position:fixed}

/* ── Focus styles ───────────────────────────────────────────────────── */
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:1px}

/* ── Reduced motion ─────────────────────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  .pulse{animation:none}
  .blink{animation:none}
  .reveal{animation:none;opacity:1;transform:none}
}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x)}
.row{display:flex;align-items:center;gap:16px}
.col{display:flex;flex-direction:column;gap:16px}
.eyebrow{
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent);font-weight:500;
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:18px;height:1px;background:var(--accent);display:inline-block}
.h-display{font-family:var(--serif);font-weight:500;letter-spacing:.02em;
  line-height:.92;margin:0;color:var(--ink);
  font-size:clamp(56px, 11vw, 168px);text-transform:uppercase}
.h-1{font-family:var(--serif);font-weight:500;font-size:clamp(36px,6vw,76px);
  line-height:1;margin:0;text-transform:uppercase;letter-spacing:.04em}
.h-2{font-family:var(--serif);font-weight:500;font-size:clamp(28px,3.6vw,44px);
  line-height:1.05;margin:0;text-transform:uppercase;letter-spacing:.04em}
.h-3{font-family:var(--serif-2);font-style:italic;font-weight:500;
  font-size:clamp(20px,2vw,28px);line-height:1.2;margin:0;color:var(--ink-2)}
.lede{font-family:var(--serif-2);font-size:clamp(18px,1.5vw,22px);line-height:1.5;
  color:var(--ink-2);max-width:62ch;margin:0}
.body{font-size:15.5px;line-height:1.65;color:var(--ink-2);max-width:62ch}
.mono{font-family:var(--mono);font-size:13px;letter-spacing:.02em;color:var(--ink-3)}
.rule{height:1px;background:var(--line);width:100%}

.nav{position:sticky;top:0;z-index:40;background:color-mix(in oklab, var(--bg) 80%, transparent);
  backdrop-filter:blur(12px) saturate(140%);-webkit-backdrop-filter:blur(12px) saturate(140%);
  border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;
  padding:14px var(--pad-x);max-width:var(--maxw);margin:0 auto}
.brand{display:flex;align-items:center;gap:14px}
.brand-mark{width:34px;height:34px;display:grid;place-items:center;
  border:1px solid var(--accent);border-radius:50%;color:var(--accent);
  font-family:var(--serif);font-weight:600;font-size:18px}
.brand-name{font-family:var(--serif);font-weight:600;font-size:16px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink)}
.brand-sub{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;color:var(--ink-3);
  text-transform:uppercase;margin-top:2px}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{font-family:var(--mono);font-size:12px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink-2)}
.nav-links a:hover{color:var(--accent)}
.nav-status{display:flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:11px;color:var(--ink-2);letter-spacing:.1em}
.pulse{width:8px;height:8px;border-radius:50%;background:var(--good);position:relative}
.pulse::after{content:'';position:absolute;inset:0;border-radius:50%;
  background:var(--good);animation:pulse 10s infinite}
@keyframes pulse{
  0%{opacity:.6;transform:scale(1)}
  20%{opacity:0;transform:scale(2.5)}
  21%,100%{opacity:0;transform:scale(1)}
}

.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 22px;
  font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  border:1px solid var(--accent);background:var(--accent);color:var(--accent-ink);
  cursor:default;transition:transform .15s ease, background .15s ease}
.btn:hover{transform:translateY(-1px);background:transparent;color:var(--accent)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);background:transparent}
.btn .arrow{transition:transform .2s ease}
.btn:hover .arrow{transform:translateX(3px)}

.hero{position:relative;padding:clamp(60px,10vh,120px) 0 clamp(80px,12vh,160px);
  overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(40px,6vw,80px);
  align-items:end}
@media (max-width:980px){.hero-grid{grid-template-columns:1fr}}
.hero-meta{display:flex;justify-content:space-between;align-items:center;
  border-top:1px solid var(--line);padding-top:18px;margin-top:48px;
  font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.14em;
  text-transform:uppercase}
.hero-meta b{color:var(--ink);font-weight:500}
.hero-cta{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap}
.hero-bg{position:absolute;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(ellipse 60% 50% at 80% 20%, color-mix(in oklab, var(--accent) 14%, transparent), transparent 60%),
    radial-gradient(ellipse 50% 60% at 10% 90%, color-mix(in oklab, var(--accent) 8%, transparent), transparent 60%);
}
.hero > .wrap{position:relative;z-index:1}

.title-block{position:relative}
.title-block .est{position:absolute;top:6px;right:0;
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--ink-3);
  text-transform:uppercase}

.ygg{
  position:relative;aspect-ratio:4/5;width:100%;
  background:transparent;overflow:visible;display:grid;place-items:center;
}
.ygg-img{
  width:100%;height:100%;object-fit:contain;object-position:center;
  opacity:1;
  -webkit-mask-image:radial-gradient(ellipse 75% 75% at 50% 48%, #000 55%, transparent 92%);
          mask-image:radial-gradient(ellipse 75% 75% at 50% 48%, #000 55%, transparent 92%);
  filter:drop-shadow(0 18px 60px color-mix(in oklab, var(--accent) 30%, transparent));
}
html[data-theme="midnight"] .ygg-img,
html:not([data-theme]) .ygg-img{
  filter:drop-shadow(0 18px 60px color-mix(in oklab, var(--accent) 35%, transparent))
         brightness(1.05) contrast(1.05);
}
html[data-theme="terminal"] .ygg-img{
  filter:drop-shadow(0 0 40px rgba(92,247,165,.45)) saturate(0) sepia(1) hue-rotate(75deg) saturate(6);
}

.term{
  background:var(--term-bg);border:1px solid var(--line);
  font-family:var(--mono);color:var(--term-fg);
  box-shadow:inset 0 0 80px color-mix(in oklab, var(--accent) 6%, transparent);
  position:relative;overflow:hidden;
}
.term::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(0deg, rgba(0,0,0,.12) 0 1px, transparent 1px 3px);
  mix-blend-mode:multiply;opacity:.6;
}
.term-bar{display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;border-bottom:1px solid var(--line);font-size:11px;
  color:var(--term-dim);letter-spacing:.14em;text-transform:uppercase;position:relative;z-index:1}
.term-bar .dot{width:8px;height:8px;border-radius:50%;background:var(--term-dim);display:inline-block;margin-right:6px}
.term-body{padding:18px 18px 14px;font-size:13px;line-height:1.55;
  height:420px;white-space:pre-wrap;word-break:break-word;position:relative;z-index:1;
  overflow-y:auto}
.term-body .room{color:var(--term-fg);font-weight:500}
.term-body .desc{color:var(--term-dim)}
.term-body .exits{color:#82c47c}
.term-body .mud-prompt{color:#c878c8;font-weight:500}
.demo-end{color:var(--accent);text-align:center;padding:18px 0 8px;
  letter-spacing:.18em;font-size:12px;text-transform:uppercase;font-family:var(--mono)}
.term-body .you{color:var(--term-cursor)}
.term-body .sys{color:var(--accent)}
.term-input{display:flex;gap:8px;align-items:center;padding:12px 14px;
  border-top:1px solid var(--line);font-size:13px;position:relative;z-index:1}
.term-input .prompt{color:var(--accent)}
.term-input input{flex:1;background:transparent;border:0;outline:0;
  color:var(--term-cursor);font:inherit;caret-color:var(--accent)}
.term-input input::placeholder{color:var(--term-dim)}
.blink{animation:blink 1s steps(2) infinite}
@keyframes blink{50%{opacity:0}}

section{padding:var(--gap) 0;position:relative}
.sec-head{display:grid;grid-template-columns:auto 1fr;gap:clamp(24px,4vw,80px);
  align-items:end;margin-bottom:clamp(36px,5vw,64px)}
@media (max-width:780px){.sec-head{grid-template-columns:1fr;gap:18px}}
.sec-num{font-family:var(--mono);font-size:11px;letter-spacing:.22em;
  color:var(--accent);text-transform:uppercase;display:flex;flex-direction:column;gap:6px;
  border-left:1px solid var(--accent);padding-left:14px;align-self:start;margin-top:6px}
.sec-num span{color:var(--ink-3)}
.sec-title{font-family:var(--serif);font-weight:500;font-size:clamp(40px,5.5vw,68px);
  text-transform:uppercase;letter-spacing:.04em;line-height:1;margin:0;text-wrap:balance}

.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);
  align-items:start}
@media (max-width:880px){.intro-grid{grid-template-columns:1fr}}
.intro-stat{border-top:1px solid var(--line);padding-top:14px}
.intro-stat .n{font-family:var(--serif);font-size:64px;line-height:1;color:var(--ink);
  font-weight:500}
.intro-stat .l{font-family:var(--mono);font-size:11px;letter-spacing:.16em;
  color:var(--ink-3);text-transform:uppercase;margin-top:8px;display:block}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:600px){.stats{grid-template-columns:1fr 1fr}}

.news-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:1px;
  background:var(--line);border:1px solid var(--line)}
@media (max-width:880px){.news-grid{grid-template-columns:1fr}}
.news-item{background:var(--bg);padding:28px;display:flex;flex-direction:column;
  gap:16px;min-height:240px;cursor:default;transition:background .2s ease}
.news-item:hover{background:var(--surface)}
.news-item.feature{grid-row:span 2}
@media (max-width:880px){.news-item.feature{grid-row:auto}}
.news-date{font-family:var(--mono);font-size:11px;letter-spacing:.14em;
  color:var(--ink-3);text-transform:uppercase}
.news-tag{display:inline-block;font-family:var(--mono);font-size:10px;letter-spacing:.16em;
  color:var(--accent);border:1px solid var(--accent);padding:3px 8px;text-transform:uppercase}
.news-title{font-family:var(--serif);font-weight:500;font-size:24px;line-height:1.15;
  color:var(--ink);text-transform:uppercase;letter-spacing:.02em;margin:0}
.news-item.feature .news-title{font-size:36px}
.news-author{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;
  color:var(--ink-3);text-transform:uppercase}
.news-excerpt{color:var(--ink-2);line-height:1.55;font-size:14.5px;margin:0}
.news-foot{margin-top:auto;display:flex;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--ink-3);
  text-transform:uppercase}
.news-foot .read{color:var(--accent)}

.guild-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line)}
@media (max-width:980px){.guild-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.guild-grid{grid-template-columns:1fr}}
.guild{background:var(--bg);padding:28px 24px;min-height:260px;
  display:flex;flex-direction:column;justify-content:space-between;
  transition:background .2s ease;cursor:default;position:relative;overflow:hidden}
.guild:hover{background:var(--surface)}
.guild .glyph{font-family:var(--serif);font-size:84px;line-height:1;color:var(--accent);
  font-weight:600;letter-spacing:0;align-self:flex-start;
  text-shadow:0 0 30px color-mix(in oklab, var(--accent) 30%, transparent)}
.guild h3{font-family:var(--serif);font-weight:500;font-size:22px;letter-spacing:.04em;
  text-transform:uppercase;margin:0 0 6px}
.guild p{font-size:13.5px;color:var(--ink-2);line-height:1.5;margin:0}
.guild .tag{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;
  color:var(--ink-3);text-transform:uppercase;margin-top:18px;margin-bottom:14px}
.guild .pop{position:absolute;top:18px;right:20px;font-family:var(--mono);font-size:10.5px;
  color:var(--ink-3);letter-spacing:.12em}
.guild .pop b{color:var(--accent);font-weight:500}

.connect{
  background:var(--surface);border:1px solid var(--line);
  padding:clamp(40px,5vw,72px);
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,4vw,64px);align-items:center}
@media (max-width:880px){.connect{grid-template-columns:1fr}}
.conn-cmd{
  font-family:var(--mono);font-size:15px;color:var(--accent);
  background:var(--term-bg);padding:18px 22px;border:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  letter-spacing:.04em
}
.conn-cmd .copy{font-size:11px;color:var(--ink-3);text-transform:uppercase;
  letter-spacing:.16em;cursor:pointer;transition:color .15s ease;
  background:none;border:none;padding:0}
.conn-cmd .copy:hover{color:var(--accent)}
.conn-list{display:flex;flex-direction:column;gap:12px;font-family:var(--mono);font-size:13px}
.conn-list .ln{display:flex;justify-content:space-between;border-bottom:1px dashed var(--line);
  padding-bottom:10px;color:var(--ink-2)}
.conn-list .ln b{color:var(--accent);font-weight:500}
.conn-list .ln .status-good{color:var(--good)}

.links-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line)}
@media (max-width:880px){.links-grid{grid-template-columns:repeat(2,1fr)}}
.link-card{background:var(--bg);padding:28px 24px;min-height:140px;
  display:flex;flex-direction:column;justify-content:space-between;cursor:default;
  transition:background .2s ease}
.link-card:hover{background:var(--surface)}
.link-card h3{font-family:var(--serif);font-weight:500;font-size:22px;letter-spacing:.04em;
  text-transform:uppercase;margin:0}
.link-card p{font-size:13px;color:var(--ink-3);line-height:1.5;margin:8px 0 0}
.link-card .arr{font-family:var(--mono);font-size:11px;letter-spacing:.16em;
  color:var(--accent);text-transform:uppercase;margin-top:18px;display:flex;align-items:center;gap:8px}

footer{padding:48px 0 36px;border-top:1px solid var(--line);margin-top:var(--gap);
  font-family:var(--mono);font-size:11.5px;color:var(--ink-3);letter-spacing:.1em}
.foot-grid{display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;
  text-transform:uppercase}
.foot-back{color:inherit}

@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(14px);
    animation:reveal .9s cubic-bezier(.2,.7,.2,1) forwards;
    animation-timeline:view();animation-range:entry 0% cover 30%}
}
@keyframes reveal{to{opacity:1;transform:none}}

/* ── Helpers that replace inline styles ────────────────────────────── */
.brand-text{display:flex;flex-direction:column}
.col-18{gap:18px}
.col-24{gap:24px}
.row-split{justify-content:space-between}
.lede-mt{margin-top:8px}
.sec-demo{padding-top:0;padding-bottom:var(--gap)}
.term-wrap{max-width:920px;margin:0 auto}
.demo-stage{position:relative}
.demo-play-btn[hidden]{display:none}
.demo-play-btn{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  z-index:10;display:inline-flex;align-items:center;gap:12px;
  padding:16px 32px;
  font-family:var(--mono);font-size:13px;letter-spacing:.2em;text-transform:uppercase;
  background:var(--term-bg);border:1px solid var(--term-fg);color:var(--term-fg);
  cursor:pointer;transition:background .2s ease,color .2s ease;
  box-shadow:0 0 40px color-mix(in oklab,var(--accent) 20%,transparent);
}
.demo-play-btn:hover{background:var(--term-fg);color:var(--term-bg)}
.demo-play-btn:focus-visible{outline:2px solid var(--accent);outline-offset:4px}
.term-enter{color:var(--term-dim);font-size:11px;letter-spacing:.14em}
.term-note{text-align:center;margin-top:14px}
.news-item .row{justify-content:space-between}
.guilds-foot{text-align:center;margin-top:24px;color:var(--ink-3)}
.code{font-family:var(--mono);color:var(--accent)}
.conn-cmd-text{font-size:14px}
.body-mt{margin-top:6px}

/* ── Connect: first-time callout ───────────────────────────────────── */
.connect-newbie{
  margin-top:clamp(28px,4vw,48px);padding:clamp(24px,3vw,36px);
  border:1px solid var(--line);background:var(--bg-2);
  display:flex;flex-direction:column;gap:20px;align-items:flex-start;
}
.newbie-steps{
  margin:0;padding:0 0 0 1.4em;display:flex;flex-direction:column;gap:10px;
  font-size:14.5px;color:var(--ink-2);line-height:1.6;
}
.newbie-steps li::marker{color:var(--accent);font-family:var(--mono);font-size:12px}

/* ── Contact emails in link card ───────────────────────────────────── */
.contact-emails{
  list-style:none;margin:12px 0 0;padding:0;
  display:flex;flex-direction:column;gap:6px;
}
.contact-emails li{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--ink-2)}
.contact-emails li span{color:var(--ink-3);text-transform:uppercase;letter-spacing:.14em;
  font-size:10px;margin-right:8px}

/* ── Administration section ────────────────────────────────────────── */
.admin-grid{display:grid;grid-template-columns:1fr;gap:clamp(40px,6vw,80px);align-items:start}
.admin-note{margin-top:28px;max-width:72ch}
.rank-table{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:12.5px;margin-top:20px}
.rank-table th{text-align:left;font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-3);padding:0 16px 12px 0;border-bottom:1px solid var(--line)}
.rank-table td{color:var(--ink-2);padding:11px 16px 11px 0;border-bottom:1px solid var(--line-2);
  vertical-align:top}
.rank-table td:first-child{color:var(--ink);white-space:nowrap}
.rank-table td:nth-child(2){color:var(--accent);font-weight:500}

/* ── RC5 page ──────────────────────────────────────────────────────── */
.rc5-statbar{
  background:var(--surface);border-bottom:1px solid var(--line);
  padding:clamp(24px,3vw,36px) 0;
}
.rc5-stats{display:flex;gap:clamp(32px,6vw,80px);flex-wrap:wrap}
.rc5-stat{display:flex;flex-direction:column;gap:6px}
.rc5-n{font-family:var(--serif);font-size:clamp(32px,4vw,52px);font-weight:500;
  color:var(--accent);line-height:1}
.rc5-l{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-3)}
.rc5-prize-table{
  border:1px solid var(--line);margin:24px 0;
  display:flex;flex-direction:column;
}
.rc5-prize-row{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:14px 20px;border-bottom:1px solid var(--line-2);
  font-size:14.5px;color:var(--ink-2);gap:24px;
}
.rc5-prize-row:last-child{border-bottom:0}
.rc5-prize-row b{font-family:var(--mono);font-size:13px;color:var(--accent);
  white-space:nowrap;font-weight:500}
.rc5-note{font-size:12.5px;color:var(--ink-3);font-style:italic}
.rc5-steps{
  margin:0;padding:0 0 0 1.4em;
  display:flex;flex-direction:column;gap:20px;
  font-size:15px;line-height:1.7;color:var(--ink-2);
}
.rc5-steps li::marker{color:var(--accent);font-family:var(--mono);font-size:12px}
.rc5-steps strong{color:var(--ink)}
.rc5-aside{
  margin:10px 0 0;font-size:13px;color:var(--ink-3);
  border-left:2px solid var(--accent-2);padding-left:14px;
  font-style:italic;max-width:58ch;
}

/* ── Guide page ────────────────────────────────────────────────────── */
.guide-header{
  padding:clamp(48px,8vh,96px) 0 clamp(40px,6vh,72px);
  border-bottom:1px solid var(--line);
}
.guide-header .eyebrow{margin-bottom:18px}
.guide-header .h-1{margin:18px 0 24px}
.guide-toc{
  padding:24px 0;border-bottom:1px solid var(--line);
  background:var(--bg-2);
}
.guide-toc ol{
  margin:0;padding:0 0 0 1.4em;display:flex;flex-wrap:wrap;gap:6px 32px;
  font-family:var(--mono);font-size:12px;letter-spacing:.08em;color:var(--ink-2);
  list-style:decimal;
}
.guide-toc a{color:var(--ink-2);border-bottom:1px solid var(--line)}
.guide-toc a:hover{color:var(--accent);border-color:var(--accent)}
.guide-sec{padding:clamp(48px,7vh,80px) 0;border-bottom:1px solid var(--line)}
.guide-wrap{max-width:800px}
.guide-sec h2{
  font-family:var(--serif);font-weight:500;font-size:clamp(28px,3.5vw,40px);
  text-transform:uppercase;letter-spacing:.04em;margin:0 0 28px;color:var(--ink)
}
.guide-sec h3{
  font-family:var(--serif-2);font-style:italic;font-size:clamp(18px,2vw,22px);
  color:var(--ink-2);margin:32px 0 12px;font-weight:500
}
.guide-sec p{font-size:15px;line-height:1.7;color:var(--ink-2);max-width:66ch;margin:0 0 16px}
.guide-sec ul,.guide-sec ol{
  margin:0 0 18px;padding:0 0 0 1.6em;display:flex;flex-direction:column;gap:8px;
  font-size:14.5px;line-height:1.6;color:var(--ink-2)
}
.guide-sec li::marker{color:var(--accent)}
.cmd-block{
  background:var(--term-bg);border:1px solid var(--line);
  padding:16px 20px;margin:18px 0;font-family:var(--mono);font-size:13px;
  color:var(--term-fg);display:flex;flex-direction:column;gap:8px;letter-spacing:.03em
}
.cmd-block .prompt{color:var(--term-dim)}
.cmd-inline{font-family:var(--mono);font-size:13.5px;color:var(--accent);
  background:color-mix(in oklab, var(--accent) 8%, transparent);
  padding:1px 6px;border-radius:2px}
.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);margin:24px 0}
@media (max-width:600px){.stat-grid{grid-template-columns:1fr}}
.stat-card{background:var(--bg);padding:20px 22px}
.stat-card b{font-family:var(--serif);font-size:22px;font-weight:500;
  text-transform:uppercase;letter-spacing:.04em;color:var(--accent);display:block;margin-bottom:6px}
.stat-card span{font-size:13.5px;color:var(--ink-2)}
.legal-dl{margin:0 0 18px;display:flex;flex-direction:column;gap:0}
.legal-dl dt{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--accent);margin-top:18px}
.legal-dl dd{margin:6px 0 0;font-size:14.5px;color:var(--ink-2);line-height:1.6;
  border-left:2px solid var(--line);padding-left:14px}
.accent-link{color:var(--accent)}

/* ── Guide: quests CTA block ────────────────────────────────────────── */
.quest-cta-block{
  margin-top:32px;border:1px solid var(--line);background:var(--bg-2);
}
.quest-cta-inner{
  display:flex;align-items:center;gap:20px;padding:clamp(18px,3vw,28px);
  flex-wrap:wrap;
}
.quest-cta-rune{
  font-family:var(--serif);font-size:48px;font-weight:600;
  color:var(--accent);line-height:1;flex-shrink:0;
  text-shadow:0 0 24px color-mix(in oklab, var(--accent) 30%, transparent);
}
.quest-cta-label{
  font-family:var(--serif);font-weight:500;font-size:18px;
  text-transform:uppercase;letter-spacing:.04em;
  color:var(--ink);margin:0 0 4px;
}
.quest-cta-sub{
  font-size:13.5px;line-height:1.55;color:var(--ink-2);margin:0;max-width:none;
}
.quest-cta-link{
  margin-left:auto;flex-shrink:0;
  font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--accent);
  border:1px solid var(--accent);padding:12px 20px;
  transition:background .15s ease,color .15s ease;white-space:nowrap;
}
.quest-cta-link:hover{background:var(--accent);color:var(--accent-ink)}
.quest-cta-continue{
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-3);
  padding:10px clamp(18px,3vw,28px);
  border-top:1px solid var(--line-2);margin:0;
}
.quest-cta-continue a{
  color:var(--accent);
  border-bottom:1px solid color-mix(in oklab, var(--accent) 40%, transparent);
  transition:color .15s,border-color .15s;
}
.quest-cta-continue a:hover{color:var(--ink);border-color:var(--ink)}

/* ── Guide: path chooser ────────────────────────────────────────────── */
.guide-paths{
  padding:clamp(32px,5vw,56px) 0;
  border-bottom:1px solid var(--line);
  background:var(--bg-2);
}
.guide-paths-label{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-3);margin:0 0 20px;
}
.guide-path-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:1px;
  background:var(--line);border:1px solid var(--line);
}
@media (max-width:640px){.guide-path-grid{grid-template-columns:1fr}}
.guide-path-card{
  background:var(--bg);padding:clamp(24px,3vw,36px);
  display:flex;flex-direction:column;gap:20px;
  transition:background .2s ease;
}
a.guide-path-card{text-decoration:none;cursor:pointer}
a.guide-path-card:hover{background:var(--surface)}
.guide-path-rune{
  font-family:var(--serif);font-size:clamp(48px,7vw,72px);font-weight:600;
  color:var(--accent);line-height:1;
  text-shadow:0 0 30px color-mix(in oklab, var(--accent) 30%, transparent);
}
.guide-path-title{
  font-family:var(--serif);font-weight:500;font-size:clamp(22px,2.5vw,28px);
  text-transform:uppercase;letter-spacing:.04em;margin:0 0 8px;color:var(--ink);
}
.guide-path-desc{
  font-size:14px;line-height:1.6;color:var(--ink-2);margin:0;
}
.guide-path-cta{
  font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--accent);margin-top:auto;
}

/* ── Creator guide: header tint ─────────────────────────────────────── */
.guide-header-wiz{
  background:color-mix(in oklab, var(--accent) 4%, var(--bg));
}

/* ── Creator guide: wizard rule footer callout ──────────────────────── */
.wiz-rule-footer{
  margin-top:36px;padding:clamp(20px,3vw,28px);
  border:1px solid var(--line);background:var(--bg-2);
}
.wiz-rule-footer p{
  font-size:15px;line-height:1.7;color:var(--ink-2);max-width:66ch;margin:0 0 10px;
}
.wiz-rule-footer p:last-child{margin-bottom:0}

/* ── Creator guide: contributor agreement list ──────────────────────── */
.wiz-agreement-list{
  margin:24px 0 0;padding:0 0 0 1.6em;display:flex;flex-direction:column;gap:18px;
  font-size:15px;line-height:1.7;color:var(--ink-2);
}
.wiz-agreement-list li::marker{color:var(--accent);font-family:var(--mono);font-weight:600}
.wiz-agreement-list ul{
  margin:10px 0 0;padding:0 0 0 1.4em;display:flex;flex-direction:column;gap:6px;
  font-size:14px;line-height:1.6;
}
.wiz-agreement-list ul li::marker{color:var(--accent-2)}

/* ── Help terminal widget ─────────────────────────────────────────────────── */
#help-fab {
  position: fixed;
  bottom: 28px;
  right: 28px;
  z-index: 9000;
  width: 46px;
  height: 46px;
  border-radius: 50%;
  border: 2px solid var(--accent, #d4b472);
  background: var(--term-bg, #07090d);
  color: var(--accent, #d4b472);
  font-family: var(--mono, monospace);
  font-size: 1.25rem;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 18px rgba(212,180,114,.18);
  transition: box-shadow .2s, background .2s;
}
#help-fab:hover,
#help-fab.active {
  background: var(--accent, #d4b472);
  color: var(--term-bg, #07090d);
  box-shadow: 0 0 28px rgba(212,180,114,.45);
}
#help-panel {
  position: fixed;
  bottom: 84px;
  right: 28px;
  z-index: 8999;
  width: min(calc(80ch + 24px), calc(100vw - 40px));
  height: min(480px, calc(100vh - 120px));
  background: var(--term-bg, #07090d);
  border: 1px solid rgba(212,180,114,.28);
  border-radius: 6px;
  box-shadow: 0 8px 40px rgba(0,0,0,.7);
  display: flex;
  flex-direction: column;
  font-family: var(--mono, monospace);
  font-size: .8rem;
  overflow: hidden;
}
#help-panel[hidden] { display: none; }
#help-titlebar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 10px;
  background: rgba(212,180,114,.08);
  border-bottom: 1px solid rgba(212,180,114,.18);
  flex-shrink: 0;
}
#help-titlebar span {
  color: var(--term-fg, #d4b472);
  font-size: .7rem;
  letter-spacing: .12em;
  text-transform: uppercase;
}
#help-close-btn {
  background: none;
  border: none;
  color: var(--term-dim, rgba(212,180,114,.5));
  font-size: 1.1rem;
  line-height: 1;
  cursor: pointer;
  padding: 0 2px;
  font-family: inherit;
}
#help-close-btn:hover { color: var(--term-fg, #d4b472); }
#help-output {
  flex: 1 1 0;
  overflow-y: auto;
  padding: 10px 12px;
  scrollbar-width: thin;
  scrollbar-color: rgba(212,180,114,.3) transparent;
}
#help-output .hl {
  line-height: 1.55;
  white-space: pre-wrap;
  word-break: break-word;
}
#help-output .hl-cmd { color: var(--term-dim, rgba(212,180,114,.55)); }
#help-output .hl-hdr { color: var(--accent, #d4b472); font-weight: 600; margin-top: 6px; }
#help-output .hl-lst { color: var(--term-fg, #d4b472); }
#help-output .hl-txt { color: rgba(212,180,114,.85); }
#help-output .hl-msg { color: rgba(212,180,114,.6); font-style: italic; }
#help-output .hl-err { color: var(--danger, #c45a4a); }
#help-input-row {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 7px 12px;
  border-top: 1px solid rgba(212,180,114,.18);
  background: rgba(212,180,114,.04);
  flex-shrink: 0;
}
#help-prompt {
  color: var(--accent, #d4b472);
  user-select: none;
  flex-shrink: 0;
}
#help-input {
  flex: 1;
  background: none;
  border: none;
  outline: none;
  color: var(--term-fg, #d4b472);
  font-family: var(--mono, monospace);
  font-size: .8rem;
  caret-color: var(--term-cursor, #e9e2cf);
}
#help-input::placeholder { color: var(--term-dim, rgba(212,180,114,.4)); }

/* help file color codes — foreground */
.hc-black    { color: #000000; }
.hc-red      { color: #aa0000; }
.hc-green    { color: #00aa00; }
.hc-yellow   { color: #aa5500; }
.hc-blue     { color: #0000aa; }
.hc-magenta  { color: #aa00aa; }
.hc-cyan     { color: #00aaaa; }
.hc-white    { color: #aaaaaa; }
.hc-grey     { color: #555555; }
/* light/bright variants */
.hc-l-black  { color: #555555; }
.hc-l-red    { color: #ff5555; }
.hc-l-green  { color: #55ff55; }
.hc-l-yellow { color: #ffff55; }
.hc-l-blue   { color: #5555ff; }
.hc-l-magenta{ color: #ff55ff; }
.hc-l-cyan   { color: #55ffff; }
.hc-l-white  { color: #ffffff; }
.hc-l-grey   { color: #aaaaaa; }
/* background */
.hc-b-black  { background-color: #000000; }
.hc-b-red    { background-color: #aa0000; }
.hc-b-green  { background-color: #00aa00; }
.hc-b-yellow { background-color: #aa5500; }
.hc-b-blue   { background-color: #0000aa; }
.hc-b-magenta{ background-color: #aa00aa; }
.hc-b-cyan   { background-color: #00aaaa; }
.hc-b-white  { background-color: #aaaaaa; }
.hc-b-grey   { background-color: #555555; }
/* attributes */
.hc-bold      { font-weight: bold; }
.hc-underline { text-decoration: underline; }
.hc-inverse   { filter: invert(1); }
.hc-blink     { animation: hc-blink 1s step-end infinite; }

/* quests page */
.quest-header{padding:clamp(48px,8vh,96px) 0 clamp(40px,6vh,72px);border-bottom:1px solid var(--line)}
.quest-header .eyebrow{margin-bottom:18px}
.quest-header .h-1{margin:18px 0 24px}
.quest-stats{display:flex;gap:clamp(32px,6vw,64px);flex-wrap:wrap;margin-top:40px;padding-top:24px;border-top:1px solid var(--line)}
.quest-stat{display:flex;flex-direction:column;gap:4px}
.quest-stat-n{font-family:var(--serif);font-size:clamp(32px,4vw,48px);font-weight:500;color:var(--accent);line-height:1}
.quest-stat-l{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3)}
.quest-breadcrumb{padding:14px 0;border-bottom:1px solid var(--line);background:var(--bg-2)}
.quest-breadcrumb .wrap{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}
.quest-bc-link{font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);display:inline-flex;align-items:center;gap:8px;transition:color .15s ease}
.quest-bc-link:hover{color:var(--accent)}
.quest-bc-continue{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3)}
.quest-bc-continue a{color:var(--accent);border-bottom:1px solid color-mix(in oklab, var(--accent) 40%, transparent);transition:color .15s ease,border-color .15s ease}
.quest-bc-continue a:hover{color:var(--ink);border-color:var(--ink)}
.quest-filter-bar{padding:18px 0;border-bottom:1px solid var(--line);background:color-mix(in oklab, var(--bg-2) 90%, transparent);backdrop-filter:blur(10px) saturate(120%);-webkit-backdrop-filter:blur(10px) saturate(120%);position:sticky;top:57px;z-index:20}
.quest-filter-inner{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.quest-search{flex:1;min-width:200px;background:var(--surface);border:1px solid var(--line);color:var(--ink);font-family:var(--mono);font-size:13px;padding:10px 14px;outline:none;transition:border-color .15s ease}
.quest-search::placeholder{color:var(--ink-3)}
.quest-search:focus{border-color:var(--accent)}
.quest-filter-btns{display:flex;gap:4px;flex-wrap:wrap}
.filter-btn{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;padding:8px 12px;border:1px solid var(--line);background:transparent;color:var(--ink-3);cursor:pointer;transition:all .15s ease}
.filter-btn:hover{border-color:var(--accent);color:var(--accent)}
.filter-btn.active{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.quest-count{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);white-space:nowrap;margin-left:auto}
.quest-grid-section{padding:clamp(32px,5vh,56px) 0}
.quest-grid{display:grid;grid-template-columns:1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
.quest-card{background:var(--bg);padding:22px;display:flex;flex-direction:column;gap:10px;transition:background .2s ease}
.quest-card:hover{background:var(--surface)}
.quest-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.quest-card-name{font-family:var(--serif);font-weight:500;font-size:19px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink);line-height:1.1;margin:0}
.quest-qp{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-ink);background:var(--accent);padding:4px 9px;white-space:nowrap;flex-shrink:0;align-self:flex-start}
.quest-hint{font-family:var(--mono);font-size:13px;line-height:1.6;color:var(--ink-2);margin:0;flex:1;white-space:pre-wrap;min-width:80ch}
.quest-difficulty{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;padding-top:10px;border-top:1px solid var(--line-2);display:flex;align-items:center;gap:6px;margin-top:auto}
.diff-dot{width:6px;height:6px;border-radius:50%;display:inline-block;flex-shrink:0}
.diff-easy  .diff-dot{background:var(--good)}
.diff-medium .diff-dot{background:var(--accent)}
.diff-hard  .diff-dot{background:#d4934a}
.diff-epic  .diff-dot{background:var(--danger)}
.diff-easy  {color:var(--good)}
.diff-medium{color:var(--accent)}
.diff-hard  {color:#d4934a}
.diff-epic  {color:var(--danger)}
.quest-qp-label{font-size:10px;color:var(--ink-3);letter-spacing:.1em}
.quest-empty{grid-column:1/-1;padding:72px 24px;text-align:center;font-family:var(--mono);font-size:13px;color:var(--ink-3);letter-spacing:.14em}
.quest-loading{grid-column:1/-1;padding:80px 24px;text-align:center;font-family:var(--mono);font-size:12px;color:var(--ink-3);letter-spacing:.2em;text-transform:uppercase}
.quest-footer-nav{border-top:1px solid var(--line);padding:clamp(28px,4vw,48px) 0;background:var(--bg-2)}
.quest-footer-nav .wrap{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.quest-footer-text{font-size:14.5px;color:var(--ink-2);line-height:1.5}
.quest-footer-text strong{color:var(--ink);display:block;font-family:var(--serif);font-size:22px;text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}
.quest-footer-cta{font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);border:1px solid var(--accent);padding:13px 24px;transition:all .15s ease;display:inline-flex;align-items:center;gap:8px;white-space:nowrap}
.quest-footer-cta:hover{background:var(--accent);color:var(--accent-ink)}
@keyframes hc-blink { 50% { opacity: 0; } }

/* ── Wizard Dashboard ─────────────────────────────────────────────────────── */

/* Full-height page layout */
body.page-devdash{display:flex;flex-direction:column;height:100vh;overflow:hidden}
body.page-devdash .nav{flex-shrink:0}

/* Three-panel grid */
.devdash-layout{
  flex:1;min-height:0;
  display:grid;
  grid-template-columns:280px 1fr 300px;
  overflow:hidden;
}

/* ── Left panel ──────────────────────────────────────────────────────────── */
.devdash-left{
  display:flex;flex-direction:column;
  border-right:1px solid var(--line);
  overflow:hidden;
  background:var(--bg);
}

.devdash-searchbar{
  display:flex;align-items:center;gap:8px;
  padding:10px 12px;
  border-bottom:1px solid var(--line);
  background:var(--bg-2);
  flex-shrink:0;
}
.devdash-search-icon{
  color:var(--ink-3);font-size:16px;flex-shrink:0;
  font-family:var(--mono);line-height:1;
}
#devdash-search{
  flex:1;min-width:0;
  background:transparent;border:none;outline:none;
  font-family:var(--mono);font-size:12.5px;color:var(--ink);
  caret-color:var(--accent);
}
#devdash-search::placeholder{color:var(--ink-3)}
#devdash-search::-webkit-search-cancel-button{-webkit-appearance:none}
.devdash-search-count{
  font-family:var(--mono);font-size:10px;letter-spacing:.1em;
  color:var(--ink-3);white-space:nowrap;flex-shrink:0;
}

.devdash-tree-wrap{
  flex:1;overflow-y:auto;
  scrollbar-width:thin;
  scrollbar-color:var(--line) transparent;
}

/* Tree directory node */
.devdash-dir{display:flex;flex-direction:column}
.devdash-dir-head{
  display:flex;align-items:center;gap:7px;
  padding:6px 12px;
  background:none;border:none;
  font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;
  color:var(--ink-2);text-align:left;width:100%;
  cursor:pointer;transition:background .12s ease,color .12s ease;
}
.devdash-dir-head:hover{background:var(--surface);color:var(--ink)}
.devdash-dir-head.devdash-dir-empty{color:var(--ink-3);cursor:default}
.dd-arrow{color:var(--accent);font-size:9px;flex-shrink:0;width:10px}
.dd-name{flex:1;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}
.dd-count{
  font-size:10px;color:var(--ink-3);
  background:var(--surface-2);padding:1px 5px;
  border-radius:2px;flex-shrink:0;
}
.devdash-dir-body{padding-left:14px}

/* File node */
.devdash-file{
  display:block;width:100%;
  padding:4px 12px;
  background:none;border:none;
  font-family:var(--mono);font-size:12px;letter-spacing:.02em;
  color:var(--ink-2);text-align:left;
  cursor:pointer;transition:background .1s ease,color .1s ease;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.devdash-file:hover{background:var(--surface);color:var(--ink)}
.devdash-file.devdash-active{color:var(--accent);background:color-mix(in oklab,var(--accent) 8%,transparent)}
.devdash-file.devdash-focused{background:var(--surface-2);color:var(--ink);outline:1px solid var(--accent);outline-offset:-1px}

/* Filter flat list item */
.devdash-flat{
  display:flex;flex-direction:column;gap:1px;
  padding:5px 12px;
}
.dff-name{font-size:12.5px;color:var(--ink);font-family:var(--mono)}
.dff-sect{font-size:10px;color:var(--ink-3);font-family:var(--mono);letter-spacing:.04em}

.devdash-status{
  padding:14px 12px;
  font-family:var(--mono);font-size:11.5px;color:var(--ink-3);
  letter-spacing:.08em;
}
.devdash-loading{color:var(--ink-3)}
.devdash-err{color:var(--danger);font-family:var(--mono);font-size:12px}

/* ── Center panel ────────────────────────────────────────────────────────── */
.devdash-center{
  display:flex;flex-direction:column;
  min-width:0;overflow:hidden;
  background:var(--bg);
}

/* Compact top-bar welcome — shown when no content is loaded */
.devdash-welcome{
  display:flex;align-items:center;gap:10px;
  padding:7px 14px;
  border-bottom:1px solid var(--line);
  background:var(--bg-2);
  flex-shrink:0;
}
.devdash-welcome-rune{
  font-family:var(--serif);font-size:17px;font-weight:600;
  color:var(--accent);line-height:1;flex-shrink:0;
}
.devdash-welcome-title{
  font-family:var(--serif);font-weight:500;font-size:12px;
  text-transform:uppercase;letter-spacing:.1em;color:var(--ink);margin:0;
}
.devdash-welcome-sub{display:none}
.devdash-welcome-hint{
  font-family:var(--mono);font-size:10px;color:var(--ink-3);
  letter-spacing:.08em;margin:0 0 0 auto;white-space:nowrap;
}

.devdash-viewer{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}
.devdash-viewer-bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 14px;
  border-bottom:1px solid var(--line);
  background:var(--bg-2);flex-shrink:0;
}
.devdash-viewer-path{
  font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;
  color:var(--accent);text-overflow:ellipsis;overflow:hidden;white-space:nowrap;
}
.devdash-viewer-ext{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--ink-3);
  white-space:nowrap;flex-shrink:0;margin-left:12px;
  transition:color .15s;
}
.devdash-viewer-ext:hover{color:var(--accent)}
.devdash-viewer-body{
  flex:1;overflow-y:auto;
  padding:18px 20px;
  font-family:var(--mono);font-size:13px;line-height:1.65;
  color:var(--term-fg);
  white-space:pre-wrap;word-break:break-word;
  background:var(--term-bg);
  scrollbar-width:thin;scrollbar-color:var(--line) transparent;
}

/* ── Right panel ─────────────────────────────────────────────────────────── */
.devdash-right{
  border-left:1px solid var(--line);
  overflow:hidden;display:flex;flex-direction:column;
  background:var(--bg);
}
.devdash-right-inner{
  flex:1;overflow-y:auto;
  scrollbar-width:thin;scrollbar-color:var(--line) transparent;
}

/* Override global section padding inside the right panel */
.devdash-rsec{padding:0;border-bottom:1px solid var(--line)}
.devdash-rsec-head{
  padding:8px 14px 6px;
  background:var(--bg-2);
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:1;
}
.devdash-rsec-eye{
  font-family:var(--mono);font-size:9.5px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--accent);
  display:flex;align-items:center;gap:8px;
}
.devdash-rsec-eye::before{content:"";width:12px;height:1px;background:var(--accent)}
.devdash-rsec-title{
  font-family:var(--serif);font-weight:500;font-size:17px;
  text-transform:uppercase;letter-spacing:.06em;
  color:var(--ink);margin:3px 0 0;
}

/* Section toggle — collapsible section head */
.devdash-rsec-head.devdash-rsec-toggle{
  cursor:pointer;user-select:none;
  display:flex;align-items:center;flex-wrap:wrap;gap:4px;
}
.devdash-rsec-head.devdash-rsec-toggle:hover{background:var(--surface)}
.devdash-rsec-head.devdash-rsec-toggle .devdash-rsec-title{flex:1}
.devdash-rsec-arrow{
  font-size:8px;color:var(--ink-3);flex-shrink:0;
  transition:transform .15s ease, color .15s ease;
  align-self:center;
}
.devdash-rsec[aria-expanded="true"] .devdash-rsec-arrow{
  transform:rotate(90deg);color:var(--accent);
}

/* Lesson list */
.devdash-lessons{display:flex;flex-direction:column}
.devdash-lesson{
  display:flex;align-items:center;gap:10px;
  padding:7px 14px;
  background:none;border:none;border-bottom:1px solid var(--line-2);
  text-align:left;cursor:pointer;width:100%;
  transition:background .12s ease;
}
.devdash-lesson:hover{background:var(--surface)}
.devdash-lesson.devdash-active{background:color-mix(in oklab,var(--accent) 8%,transparent)}
.dll-num{
  font-family:var(--serif);font-weight:600;font-size:18px;
  color:var(--accent);line-height:1;
  min-width:24px;text-align:center;flex-shrink:0;
  text-shadow:0 0 14px color-mix(in oklab,var(--accent) 25%,transparent);
}
.dll-body{display:flex;flex-direction:column;gap:2px;min-width:0}
.dll-title{
  font-family:var(--serif);font-weight:500;font-size:13.5px;
  text-transform:uppercase;letter-spacing:.04em;
  color:var(--ink);line-height:1.1;
}
.dll-desc{
  font-family:var(--mono);font-size:10px;letter-spacing:.04em;
  color:var(--ink-3);line-height:1.3;
}
.devdash-lesson:hover .dll-title{color:var(--accent)}

/* Hook grid */
.devdash-hookgrid{
  display:flex;flex-wrap:wrap;gap:0;
  padding:8px;
}
.devdash-hook{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.02em;
  color:var(--ink-2);background:none;border:1px solid var(--line-2);
  padding:4px 7px;margin:2px;cursor:pointer;
  transition:all .12s ease;text-align:left;
}
.devdash-hook:hover{border-color:var(--accent);color:var(--accent);background:color-mix(in oklab,var(--accent) 6%,transparent)}
.devdash-hook.devdash-active{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}

/* ── Doc viewer: section headings ────────────────────────────────────────── */
/* Keep display:inline (span default) — display:block + pre-wrap causes a
   double line-break because the \n separator also renders */
.wdoc-h-num  { color:var(--accent);font-weight:600; }
.wdoc-h-maj  { color:var(--term-fg);font-weight:700;letter-spacing:.07em; }

/* Inline code block within a doc file */
.wdoc-code-block{
  display:block;
  margin:.3em 0;
  padding:.35em .7em;
  border-left:2px solid color-mix(in oklab,var(--accent) 45%,transparent);
  background:color-mix(in oklab,var(--accent) 3%,var(--bg));
}

/* ── LPC syntax highlighting ─────────────────────────────────────────────── */
/* Colours chosen against var(--term-bg) dark background */
.lpc-kw      { color: #7799ff; }
.lpc-builtin { color: #55ffff; }
.lpc-string  { color: #88dd66; }
.lpc-comment { color: #666677; font-style: italic; }
.lpc-preproc { color: #dd77ff; }
.lpc-num     { color: #ffcc44; }

/* Responsive: stack panels below 900px */
@media (max-width:900px){
  body.page-devdash{height:auto;overflow:auto}
  .devdash-layout{
    grid-template-columns:1fr;
    height:auto;overflow:visible;
  }
  .devdash-left{height:50vh;border-right:none;border-bottom:1px solid var(--line)}
  .devdash-center{min-height:60vh}
  .devdash-right{border-left:none;border-top:1px solid var(--line)}
  .devdash-viewer{overflow:visible}
  .devdash-viewer-body{max-height:60vh;overflow-y:auto}
}
