/* ========== base ===================================================== */
:root{
  --bg: #050505;
  --fg: #f2f2f2;
  --dim: #101010;
  --accent: #6a6a6a;
  --muted: #9c9c9c;
  --border: #2a2a2a;
  --shadow: rgba(0,0,0,0.6);
  --mono: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono","Courier New", monospace;
}

*{ box-sizing: border-box; }
html,body{ height:100%; }
html{ color-scheme: dark; }
body{
  margin:0; background: var(--bg); color: var(--fg); 
  font-family: var(--mono); line-height: 1.6;
  text-rendering: optimizeLegibility; -webkit-font-smoothing: antialiased;
}

a{ color: var(--fg); text-decoration: none; border-bottom: 1px dashed var(--accent); }
a:hover{ background: rgba(255,255,255,0.08); }

h1,h2,h3{ letter-spacing: 0.5px; }
h2{ margin: 2rem 0 1rem; }

pre, code, kbd{ font-family: var(--mono); }

.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; }

/* ========== CRT + glitch ========= */
body.crt::before{
  content:""; pointer-events:none; position:fixed; inset:0;
  background: repeating-linear-gradient(0deg, rgba(255,255,255,0.08), rgba(255,255,255,0.08) 1px, transparent 1px, transparent 2px);
  mix-blend-mode: overlay; opacity: .4;
}
.glitch{
  position: relative; display: inline-block;
  filter: drop-shadow(0 0 0.75rem var(--shadow));
  animation: glitch-fuzz 3s infinite linear;
}
.glitch::before, .glitch::after{
  content: attr(text); position:absolute; inset:0; pointer-events:none;
}
.glitch::before{ text-shadow: -1px 0 #f0f, -2px 0 #f0f; mix-blend-mode: screen; }
.glitch::after { text-shadow:  1px 0 #0ff,  2px 0 #0ff; mix-blend-mode: screen; }
@keyframes glitch-fuzz{
  0%, 95%, 100% { transform: none; }
  10% { transform: translate(1px,-1px) skewX(1deg); }
  20% { transform: translate(-1px,1px) skewX(-1deg); }
  30% { transform: translate(2px,0) }
  40% { transform: translate(-2px,0) }
}

@media (prefers-reduced-motion: reduce){
  .glitch{ animation: none; }
  body.crt::before{ display:none; }
  .ascii-frame{ animation: none; }
}

@media (prefers-reduced-motion: no-preference){
  .ascii-frame{
    animation-duration: 14s;
    animation-timing-function: ease-in-out;
    animation-iteration-count: infinite;
    animation-fill-mode: both;
  }
  .ascii-frame--primary{ animation-name: ascii-frame-primary; }
  .ascii-frame--alternate{ animation-name: ascii-frame-alternate; }
}

@keyframes ascii-frame-primary{
  0%, 42% { opacity: 1; }
  52%, 100% { opacity: 0; }
}

@keyframes ascii-frame-alternate{
  0%, 48% { opacity: 0; }
  58%, 92% { opacity: 1; }
  100% { opacity: 0; }
}

/* ========== layout ============================== */
.site-header{ padding: 1rem; border-bottom: 1px solid var(--border); }
.brand{ display:inline-block; border-bottom:none; }
.brand:hover{ background:none; }
.ascii{ margin:0; font-size: 10px; line-height: 1.1; white-space: pre; }
.ascii-stack{ display:grid; position:relative; }
.ascii-frame{ grid-area:1/1; opacity:0; transition: opacity 1.2s ease-in-out; }
.ascii-frame--primary{ opacity:1; }
.nav{ display:flex; justify-content:space-between; align-items:center; gap: 1rem; flex-wrap:wrap; margin-top: .5rem; }
.nav-links{ display:flex; gap: 1rem; flex-wrap:wrap; align-items:center; }
.nav-social{ display:flex; gap:.4rem; align-items:center; margin-left:auto; }
.nav-button{
  display:inline-flex; align-items:center; justify-content:center;
  min-width: 2.2rem;
  padding: .2rem .6rem;
  border: 1px solid var(--border);
  border-radius: 3px;
  font-weight: 600;
  border-bottom: none;
  background: rgba(255,255,255,0.06);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.08);
  text-shadow: 0 0 4px rgba(0,0,0,0.4);
  color: var(--fg);
  transition: border-color .2s ease, background .2s ease, box-shadow .2s ease;
}
.nav-button:hover,
.nav-button:focus-visible{
  border-color: var(--accent);
  background: rgba(255,255,255,0.12);
  outline: none;
}
.nav-link[aria-current="page"]{
  border-color: var(--accent);
  background: rgba(255,255,255,0.14);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.12);
}

main,
.layout-constrained{ max-width: 1000px; margin: 0 auto; padding: 1rem; }
.section{ margin-bottom: 3rem; }
.hint{ color: var(--muted); font-size: .9rem; }

.site-footer{ padding: 2rem 1rem; border-top: 1px solid var(--border); color: var(--muted); }

/* ========== blurbs (post‑its but terminal) ========== */
.blurbs-grid{
  display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 1rem;
}
.blurb{
  --blurb-bg: #0d0d0d; --blurb-fg: var(--fg); --blurb-border: #333333;
  position: relative;
  border: 1px solid var(--blurb-border);
  padding: .75rem .8rem; background: var(--blurb-bg); color: var(--blurb-fg, var(--fg));
  min-height: 150px; overflow: hidden;
  box-shadow: 0 10px 30px -10px var(--shadow);
}
.blurb .blurb-meta{ color: var(--muted); font-size: .85rem; margin-top:.5rem; display:flex; gap:.5rem; }
.tilt{ transform: rotate(-0.25deg); }
.tilt:hover{ transform: rotate(0deg); }

/* pull text from CSS variables into pseudo-elements only until JS hydrates */

.blurb.blurb-teamwalk .blurb-body:empty::before{ content: var(--body, ""); white-space: pre-wrap; }
.blurb.blurb-teamwalk .blurb-date:empty::before{ content: var(--date, ""); }
.blurb.blurb-teamwalk .blurb-tags:empty::before{ content: var(--tags, ""); }

.blurb.blurb-second .blurb-body:empty::before{ content: var(--body, ""); white-space: pre-wrap; }
.blurb.blurb-second .blurb-date:empty::before{ content: var(--date, ""); }
.blurb.blurb-second .blurb-tags:empty::before{ content: var(--tags, ""); }

/* ========== tracks ========== */
.album-player{
  --player-gap: clamp(1rem, 2.5vw, 1.8rem);
  --player-padding: clamp(1rem, 2vw + 0.6rem, 1.8rem);
  --frame-font-size: clamp(.7rem, 1.4vw, .82rem);
  position:relative;
  display:flex;
  flex-direction:column;
  gap:var(--player-gap);
  width:min(100%, 68rem);
  margin: clamp(1.5rem, 4vw, 3rem) auto;
  padding: var(--player-padding);
  border:1px solid var(--border);
  border-radius:.9rem;
  background: linear-gradient(145deg, rgba(18,18,18,0.98), rgba(6,6,6,0.92));
  box-shadow:0 18px 38px -18px var(--shadow);
}
.album-player::before,
.album-player::after{
  display:block;
  font-family: var(--mono);
  font-size: var(--frame-font-size);
  letter-spacing:.08em;
  text-transform:none;
  color: var(--muted);
  text-align:center;
}
.album-player::before{
  content: "+------------ " attr(data-album-title) " ------------+";
  margin-bottom:.6rem;
}
.album-player::after{
  content: "+------------------------------------------------+";
  margin-top:.8rem;
}

.album-player.is-compact{
  --player-gap: clamp(.75rem, 2.6vw, 1.05rem);
  --player-padding: clamp(.6rem, 2vw + .2rem, 1rem);
  width:min(100%, 24rem);
  margin: clamp(1rem, 3vw, 2rem) auto;
  padding: var(--player-padding);
  border-radius:.85rem;
  border:1px solid var(--border);
  background: rgba(8,8,8,0.96);
  box-shadow:0 12px 32px -18px var(--shadow);
}
.album-player.is-compact::before,
.album-player.is-compact::after{
  display:none;
}
.album-body{
  display:grid;
  grid-template-columns: minmax(0, 1fr);
  gap:var(--player-gap);
}
.album-player.is-compact .album-body{
  display:flex;
  flex-direction:column;
  gap:var(--player-gap);
}
@media (min-width: 52rem){
  .album-body{
    grid-template-columns: clamp(16rem, 28vw, 24rem) minmax(0, 1fr);
    align-items:start;
  }
}
.album-cover{
  margin:0;
  display:flex;
  flex-direction:column;
  gap:clamp(.65rem, 1.6vw, 1rem);
  padding:clamp(.75rem, 1.6vw, 1rem);
  border:1px solid var(--border);
  border-radius:.65rem;
  background: linear-gradient(135deg, rgba(20,20,20,0.9), rgba(10,10,10,0.92));
  width:100%;
  max-width: clamp(16rem, 32vw, 24rem);
}
.album-player.is-compact .album-cover{
  max-width:none;
  padding:0;
  border:none;
  background:none;
  border-radius:.6rem;
}
.album-player.is-compact .album-cover-caption{
  display:none;
}
.album-cover-frame{
  position:relative;
}
.album-cover-toggle{
  display:block;
  width:100%;
  padding:0;
  margin:0;
  border:none;
  background:none;
  border-radius:.5rem;
  cursor:pointer;
  font:inherit;
  color:inherit;
}
.album-cover-toggle:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:4px;
}
.album-cover-toggle .album-cover-art{
  pointer-events:none;
}
.album-cover-art{
  display:block;
  width:100%;
  aspect-ratio:1 / 1;
  border:1px solid var(--border);
  border-radius:.5rem;
  object-fit:cover;
  box-shadow:0 12px 28px -18px var(--shadow);
}
.album-player.is-compact .album-cover-art{
  box-shadow:0 10px 24px -16px var(--shadow);
}
.album-cover-console{
  display:flex;
  align-items:flex-end;
  justify-content:center;
  width:100%;
  margin-top:clamp(.9rem, 2vw, 1.4rem);
}
.album-player.is-compact .album-cover-console{
  margin-top:clamp(.6rem, 2vw, .9rem);
}
.album-console-frame{
  display:flex;
  flex-direction:column;
  gap:.22rem;
  font-family:var(--mono);
  font-size:var(--frame-font-size);
  line-height:1.1;
  color: var(--accent);
  background:rgba(0,0,0,0.72);
  border:1px dashed rgba(255,255,255,0.22);
  border-radius:.65rem;
  box-shadow:0 18px 36px -24px rgba(0,0,0,0.9);
  padding:.2rem;
}
.album-player.is-compact .album-console-frame{
  width:100%;
}
.album-console-line{
  padding:0 clamp(.65rem, 2.2vw, 1rem);
  text-align:center;
  letter-spacing:.08em;
  white-space:nowrap;
}
.album-console-body{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:clamp(.6rem, 2vw, 1rem);
  padding:clamp(.45rem, 2vw, .75rem) clamp(.65rem, 2.5vw, 1.1rem);
  background:rgba(5,5,5,0.9);
  border:1px dashed rgba(255,255,255,0.22);
  border-radius:.55rem;
  flex-wrap:wrap;
}
.album-player.is-compact .album-console-body{
  justify-content:space-between;
  gap:clamp(.45rem, 2.4vw, .75rem);
}
.album-console-brace,
.album-console-divider{
  color: var(--muted);
}
.album-console-divider{
  margin:0 -.35rem;
}
.album-player.is-compact .album-console-brace,
.album-player.is-compact .album-console-divider{
  display:none;
}
.album-console-btn{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  border:none;
  background:none;
  color:inherit;
  font:inherit;
  letter-spacing:.08em;
  text-transform:lowercase;
  padding:0;
  cursor:pointer;
  transition: color .2s ease, text-shadow .2s ease;
}
.album-console-icon{
  font-weight:700;
}
.album-console-text{
  white-space:nowrap;
}
.album-console-btn:hover,
.album-console-btn:focus-visible{
  outline:none;
  color: var(--fg);
  text-shadow:0 0 6px rgba(255,255,255,0.4);
}
.album-console-btn[disabled]{
  opacity:.45;
  cursor:not-allowed;
}
.album-play-label{
  display:inline-block;
  min-width:6ch;
}
.album-player.is-compact .album-console-text,
.album-player.is-compact .album-play-label{
  display:none;
}
.album-play-toggle[data-state="playing"] .album-console-icon,
.album-play-toggle[data-state="playing"] .album-play-label{
  color: var(--fg);
}

.album-progress,
.album-volume{
  display:flex;
  align-items:center;
  gap:.45rem;
  font-family:var(--mono);
  text-transform:lowercase;
  cursor:pointer;
  white-space:nowrap;
}
.album-progress{
  flex:1 1 14rem;
}
.album-volume{
  flex:0 0 auto;
}
.album-player.is-compact .album-volume{
  flex:1 1 12rem;
}
.album-meter{
  display:flex;
  align-items:center;
  gap:.55rem;
  flex:1 1 auto;
  min-width:0;
}
.album-player.is-compact .album-meter{
  gap:.45rem;
}
.album-meter-track{
  position:relative;
  flex:1 1 auto;
  min-width:clamp(10ch, 22vw, 18ch);
}
.album-player.is-compact .album-meter-track{
  min-width:clamp(9ch, 40vw, 14ch);
}
.album-progress-label,
.album-volume-label{
  letter-spacing:.16em;
  font-size:.68rem;
  color: var(--muted);
}
.album-progress-ascii,
.album-volume-ascii{
  color: var(--accent);
  display:block;
  width:100%;
  text-align:center;
}
.album-meter-track .album-progress-input,
.album-meter-track .album-volume-input{
  position:absolute;
  inset:-.3rem 0;
  width:100%;
  height:calc(100% + .6rem);
  opacity:0;
  cursor:inherit;
}
.album-meter-track:focus-within .album-progress-ascii,
.album-meter-track:focus-within .album-volume-ascii{
  color: var(--fg);
}
.album-progress-display,
.album-volume-display{
  flex:0 0 clamp(10ch, 16vw, 14ch);
  min-width:clamp(10ch, 16vw, 14ch);
  font-size:.75rem;
  letter-spacing:.08em;
  color: var(--muted);
  white-space:nowrap;
  font-variant-numeric:tabular-nums;
  justify-content:flex-end;
}
.album-progress-display{
  display:flex;
  align-items:center;
  gap:.25rem;
}
.album-volume-display{
  display:flex;
  align-items:center;
  text-align:right;
}
.album-progress-separator{
  opacity:.65;
}
.album-cover-caption{
  display:block;
  text-align:center;
  font-family:var(--mono);
  font-size:.75rem;
  color: var(--muted);
  letter-spacing:.12em;
  text-transform:uppercase;
}
.album-content{
  display:flex;
  flex-direction:column;
  gap:clamp(1rem, 2.4vw, 1.4rem);
}
.album-player.is-compact .album-content{
  position:static;
  padding:0;
  background:none;
  gap:clamp(.5rem, 2vw, .9rem);
  align-items:flex-start;
}
.album-now-playing{
  display:flex;
  flex-direction:column;
  gap:.35rem;
  border-left:2px solid var(--border);
  padding-left: clamp(.9rem, 2vw, 1.2rem);
}
.album-player.is-compact .album-now-playing{
  border-left:none;
  border-top:1px dashed var(--border);
  padding-left:0;
  padding-top:.6rem;
  width:100%;
}
.album-now-label{
  font-family:var(--mono);
  font-size:.75rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color: var(--accent);
}
.album-player.is-compact .album-now-label{
  font-size:.68rem;
  letter-spacing:.16em;
}
.album-current-title{
  font-size:clamp(1.3rem, 2.4vw, 1.75rem);
  font-weight:700;
  text-transform:lowercase;
}
.album-player.is-compact .album-current-title{
  font-size:clamp(1rem, 4vw, 1.25rem);
}
.album-current-meta{
  font-size:clamp(.85rem, 2vw, .95rem);
  color: var(--muted);
}
.album-player.is-compact .album-current-meta{
  color: rgba(255,255,255,0.7);
}
.album-current-meta[hidden]{
  display:none;
}
.album-tracklist{
  list-style:none;
  margin:0;
  padding:0;
  border:1px dashed var(--border);
  background: rgba(12,12,12,0.88);
}
.album-player.is-compact .album-tracklist{
  display:none;
}
.album-track{
  border-bottom:1px dashed var(--border);
}
.album-track:last-child{
  border-bottom:none;
}
.album-track-button{
  width:100%;
  border:none;
  background:transparent;
  color:inherit;
  display:flex;
  align-items:center;
  gap:.75rem;
  padding:.65rem .85rem;
  font-family:var(--mono);
  font-size:1rem;
  text-transform:lowercase;
  letter-spacing:.05em;
  cursor:pointer;
  transition: background .2s ease, color .2s ease;
}
.album-track-button:focus-visible,
.album-track-button:hover{
  outline:none;
  background: rgba(255,255,255,0.08);
}
.album-track.is-active .album-track-button{
  background: rgba(255,255,255,0.12);
  color: var(--fg);
}
.album-track-num{
  color: var(--muted);
  min-width:2.4rem;
}
.album-controls{
  display:flex;
  flex-direction:column;
  gap:clamp(.8rem, 2vw, 1.1rem);
  border-top:1px dashed var(--border);
  padding-top:clamp(.9rem, 2vw, 1.2rem);
}
.album-player.is-compact .album-controls{
  align-items:stretch;
  justify-content:flex-end;
  gap:clamp(.6rem, 2vw, .85rem);
  border-top:none;
  padding-top:0;
}
.album-skip{
  font-family:var(--mono);
  letter-spacing:.08em;
}
.album-player.is-compact .album-lyrics{
  width:100%;
}
.album-player.is-compact .album-annotations-body{
  max-height:12rem;
  overflow:auto;
}
.album-audio{ width:100%; }
.album-lyrics summary{
  cursor:pointer;
  font-family:var(--mono);
  letter-spacing:.08em;
  text-transform:uppercase;
}
.album-lyrics[open] summary{
  color: var(--accent);
}
.album-annotations{
  margin-top:.6rem;
  display:flex;
  flex-direction:column;
  gap:.6rem;
}
.album-annotations-tabs{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  padding:.3rem;
  border:1px dashed var(--border);
  border-radius:.55rem;
  background:rgba(0,0,0,0.55);
}
.album-annotations-tab{
  border:none;
  background:none;
  color: var(--muted);
  font-family:var(--mono);
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:.72rem;
  padding:.4rem .85rem;
  border-radius:.4rem;
  cursor:pointer;
  transition: color .2s ease, background .2s ease, box-shadow .2s ease;
}
.album-annotations-tab:hover{
  color: var(--fg);
}
.album-annotations-tab:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:2px;
}
.album-annotations-tab.is-active{
  background:rgba(255,255,255,0.08);
  color: var(--fg);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.12);
}
.album-annotations-panels{
  position:relative;
}
.album-annotations-body{
  margin:0;
  padding:.75rem;
  background:#050505;
  border:1px dashed var(--border);
  white-space:pre-wrap;
  font-size:.95rem;
  color: var(--muted);
  min-height:4rem;
  font-family:var(--mono);
}
.album-annotations-body:not(.is-active){
  display:none;
}

.album-toggle{
  align-self:flex-end;
  border:1px solid var(--border);
  background: rgba(255,255,255,0.05);
  color: var(--muted);
  padding:.35rem .65rem;
  font-family:var(--mono);
  font-size:.75rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  cursor:pointer;
  transition: background .2s ease, color .2s ease, border-color .2s ease;
}
.album-toggle:hover,
.album-toggle:focus-visible{
  background: rgba(255,255,255,0.1);
  border-color: var(--accent);
  color: var(--fg);
  outline:none;
}
.album-player.is-compact .album-toggle{
  align-self:center;
  margin-top:.2rem;
}

@media (max-width: 52rem){
  .album-player{
    padding: clamp(.9rem, 1vw + .8rem, 1.3rem);
  }
  .album-player::before,
  .album-player::after{
    font-size: clamp(.64rem, 1.6vw, .74rem);
    letter-spacing:.06em;
  }
  .album-body{
    grid-template-columns: minmax(0, 1fr);
  }
  .album-cover{
    max-width: min(100%, 24rem);
    margin:0 auto;
  }
}

.tracklist-fallback{
  list-style:none;
  padding:0;
  margin:1.5rem 0 0;
  display:grid;
  gap:.35rem;
  font-size:1rem;
}
.tracklist-fallback li{
  display:flex;
  gap:.75rem;
  border-bottom:1px dotted var(--border);
  padding-bottom:.25rem;
}
.tracklist-fallback li:last-child{
  border-bottom:none;
}
.tracklist-index{ color: var(--muted); }
.tracklist-year{ margin-left:auto; color: var(--muted); }
.hint-strong{ color: var(--fg); font-weight:600; }

/* ========== rune list ========== */
.rune-list{ list-style:none; padding:0; margin:0; }
.rune-list li{ display:flex; align-items:center; gap:.75rem; padding:.4rem 0; }
.rune-list time{ color: var(--muted); font-size:.9rem; }

/* ========== helpers ========== */
kbd{ padding: .1rem .25rem; border: 1px solid var(--border); border-bottom-width: 2px; border-radius:3px; background: rgba(255,255,255,0.08); }
code{ background: #111111; padding: .15rem .25rem; border: 1px dashed var(--border); color: var(--fg); }
