*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --bg:      #080b08;
  --surface: #0b0f0b;
  --panel:   #0d120d;
  --panel2:  #0f140f;
  --olive:   #141c14;
  --olive2:  #1c2a1c;
  --border:  #1a2418;
  --border2: #223020;
  --amber:   #e09428;
  --amber2:  #a06018;
  --amber3:  #5a3a08;
  --cream:   #ccc4a4;
  --cream2:  #8a8468;
  --crt:     #a8d4e8;
  --g-line:  #40e870;
  --g-dim:   #206438;
  --y-line:  #e0d040;
  --r-line:  #e04030;
  --c-line:  #30d0c8;
  --orange:  #ff8028;
  --mono:    'Share Tech Mono', 'Courier New', monospace;
  --px:      'Press Start 2P', monospace;
}
body {
  background: var(--bg);
  color: var(--cream);
  font-family: var(--mono);
  font-size: 16px;
  min-height: 100vh;
  position: relative;
  overflow-x: hidden;
}
/* CRT scanlines */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(0,0,0,0.13) 2px,
    rgba(0,0,0,0.13) 4px
  );
  pointer-events: none;
  z-index: 9999;
}
/* Vignette */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  background: radial-gradient(ellipse at center, transparent 55%, rgba(0,0,0,0.55) 100%);
  pointer-events: none;
  z-index: 9998;
}

/* ── Selection ── */
::selection {
  background: var(--amber3);
  color: var(--cream);
}

/* ── Focus ── */
:focus-visible {
  outline: 1px solid var(--amber2);
  outline-offset: 2px;
}

/* ── Custom scrollbar ── */
::-webkit-scrollbar { width: 6px; background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--border2); }
::-webkit-scrollbar-thumb:hover { background: var(--amber3); }

/* ── Layout ── */
.wrap { max-width: 1140px; margin: 0 auto; padding: 0 0 80px; }
/* ── Ticker ── */
.ticker-wrap {
  background: #060906;
  border-bottom: 1px solid var(--amber3);
  overflow: hidden;
  height: 26px;
  display: flex;
  align-items: center;
}
.ticker-label {
  flex-shrink: 0;
  background: var(--amber);
  color: #050704;
  font-size: 0.52rem;
  letter-spacing: 3px;
  padding: 0 10px;
  height: 100%;
  display: flex;
  align-items: center;
  font-weight: bold;
}
.ticker-track {
  display: flex;
  white-space: nowrap;
  animation: ticker 38s linear infinite;
}
.ticker-track span {
  font-size: 0.52rem;
  color: var(--amber);
  letter-spacing: 2px;
  padding: 0 30px;
  opacity: 0.75;
}
.ticker-track span.sep {
  color: var(--amber3);
  padding: 0 4px;
  opacity: 1;
}
@keyframes ticker {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
/* ── Top strip ── */
.top-strip {
  background: var(--olive);
  border-bottom: 2px solid var(--border2);
  padding: 0 18px;
  display: flex;
  align-items: stretch;
}
.strip-id {
  font-size: 0.7rem;
  color: var(--cream2);
  letter-spacing: 3px;
  padding: 10px 16px 10px 0;
  border-right: 1px solid var(--border2);
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.strip-id::before {
  content: '';
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--g-line);
  box-shadow: 0 0 6px var(--g-line);
  margin-right: 10px;
  animation: bl 2.2s ease-in-out infinite;
}
.readouts { display: flex; flex-wrap: wrap; }
.r-cell {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 6px 14px;
  border-right: 1px solid var(--border);
  gap: 2px;
}
.r-lbl { font-size: 0.44rem; color: var(--cream2); letter-spacing: 3px; opacity: 0.55; }
.r-val { font-size: 0.85rem; color: var(--amber); letter-spacing: 1px; }
.r-val.g   { color: var(--g-line); text-shadow: 0 0 8px rgba(64,232,112,0.5); }
.r-val.c   { color: var(--cream); font-size: 0.72rem; }
.r-val.red { color: var(--r-line); }
.blink { animation: bl 1.1s step-end infinite; }
@keyframes bl { 0%,100%{opacity:1} 50%{opacity:0} }
/* ── Header ── */
header {
  padding: 20px 18px 18px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 20px;
  background: linear-gradient(180deg, #0c110c 0%, var(--bg) 100%);
  position: relative;
}
header::before, header::after {
  content: '';
  position: absolute;
  width: 18px; height: 18px;
  bottom: -1px;
}
header::before { left: 18px;  border-left:  1px solid var(--amber3); border-bottom: 1px solid var(--amber3); }
header::after  { right: 18px; border-right: 1px solid var(--amber3); border-bottom: 1px solid var(--amber3); }
h1 {
  font-family: var(--px);
  font-size: clamp(1.1rem, 3vw, 1.85rem);
  color: var(--cream);
  line-height: 1.6;
}
.h-badge { font-size: 0.48rem; letter-spacing: 3px; color: var(--amber2); margin-bottom: 7px; }
.h-right { text-align: right; }
.h-right .stat { font-size: 1rem; color: var(--cream2); }
.h-right .sub  { font-size: 0.78rem; color: var(--cream2); opacity: 0.5; margin-top: 5px; }
/* ── Nav ── */
nav {
  background: var(--olive);
  border-bottom: 2px solid var(--border2);
  display: flex;
  padding: 0 18px;
  position: relative;
}
nav::after {
  content: '';
  position: absolute;
  bottom: -3px; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--amber3) 30%, var(--amber3) 70%, transparent);
  opacity: 0.5;
}
nav a {
  font-size: 0.82rem;
  color: var(--cream2);
  text-decoration: none;
  padding: 11px 16px;
  cursor: pointer;
  border-right: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 7px;
  transition: background 0.1s, color 0.1s;
}
nav a .pn { font-size: 0.52rem; color: var(--amber2); opacity: 0.7; }
nav a:hover,
nav a.active { background: var(--olive2); color: var(--cream); }
nav a.active .pn { opacity: 1; color: var(--amber); }
nav a.active { border-top: 1px solid var(--amber3); }
/* ── Content ── */
.content { padding: 22px 18px 0; }
/* ── Intro (index only) ── */
.intro {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 18px;
  align-items: start;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 20px;
}
.intro-left { display: flex; flex-direction: column; gap: 12px; }
/* ── MC Panel ── */
.mc-panel {
  border: 1px solid var(--border2);
  background: var(--panel);
  position: relative;
}
.mc-panel::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, var(--amber3), transparent);
}
.mc-panel-head {
  background: var(--olive);
  border-bottom: 1px solid var(--border);
  padding: 5px 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.mc-panel-head .mc-id {
  font-size: 0.5rem;
  color: var(--amber);
  letter-spacing: 3px;
}
.mc-panel-head .mc-status {
  font-size: 0.46rem;
  color: var(--g-line);
  letter-spacing: 2px;
  display: flex;
  align-items: center;
  gap: 5px;
}
.mc-panel-head .mc-status::before {
  content: '';
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--g-line);
  box-shadow: 0 0 4px var(--g-line);
}
.mc-panel-body { padding: 12px 14px; }
.intro-text p { font-size: 0.95rem; line-height: 2; color: var(--cream2); margin-bottom: 10px; }
.intro-text p:last-child { margin-bottom: 0; }
.intro-text em { color: var(--cream); font-style: normal; }
/* ── Status grid ── */
.status-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border);
}
.sg-cell { background: var(--panel2); padding: 7px 8px; display: flex; flex-direction: column; gap: 2px; }
.sg-lbl  { font-size: 0.42rem; color: var(--cream2); opacity: 0.5; letter-spacing: 2px; }
.sg-val  { font-size: 0.8rem; letter-spacing: 1px; }
.sg-val.g { color: var(--g-line); text-shadow: 0 0 8px rgba(64,232,112,0.5); }
.sg-val.a { color: var(--amber); }
.sg-val.r { color: var(--r-line); }
.sg-val.c { color: var(--c-line); }
/* ── ISS Monitor ── */
.iss-monitor {
  background: #040704;
  border: 1px solid var(--olive2);
  border-top: 2px solid var(--border2);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  position: relative;
}
.iss-monitor::before {
  content: '';
  position: absolute;
  inset: 0;
  box-shadow: inset 0 0 20px rgba(0,0,0,0.7);
  pointer-events: none;
  z-index: 1;
}
.iss-head {
  background: #070d07;
  border-bottom: 1px solid var(--border);
  color: var(--amber);
  font-size: 0.54rem;
  letter-spacing: 3px;
  padding: 6px 9px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.iss-head-right { font-size: 0.44rem; color: var(--cream2); opacity: 0.4; letter-spacing: 2px; }
.iss-monitor canvas { display: block; width: 100%; position: relative; z-index: 0; }
.iss-readout {
  background: #030603;
  border-top: 1px solid var(--border);
  padding: 6px 9px;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr auto;
  gap: 4px;
  align-items: center;
}
.iss-readout .ir     { display: flex; flex-direction: column; gap: 1px; }
.iss-readout .ir-lbl { font-size: 0.38rem; color: var(--cream2); opacity: 0.4; letter-spacing: 2px; }
.iss-readout .ir-val { font-size: 0.7rem; color: var(--orange); letter-spacing: 1px; }
.iss-label  { font-size: 0.38rem; color: var(--cream2); opacity: 0.3; letter-spacing: 2px; text-align: right; }
.iss-credit {
  background: #020402;
  border-top: 1px solid rgba(34,48,32,0.65);
  padding: 4px 9px 5px;
  font-size: 0.34rem;
  letter-spacing: 1.5px;
  color: var(--cream2);
  opacity: 0.42;
  text-align: right;
  position: relative;
  z-index: 2;
}
/* ── Bench panel (index) ── */
.bench { margin-bottom: 18px; }
.bench .mc-panel-body p { font-size: 0.95rem; line-height: 1.9; color: var(--cream2); }
/* ── Section label ── */
.s-label {
  font-size: 0.66rem;
  color: var(--cream2);
  letter-spacing: 3px;
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
  opacity: 0.8;
}
.s-label .tag {
  background: var(--olive2);
  color: var(--amber);
  padding: 4px 9px;
  font-size: 0.52rem;
  letter-spacing: 3px;
  border: 1px solid var(--amber3);
}
.s-label::after { content:''; flex:1; height:1px; background: linear-gradient(90deg, var(--border), transparent); }
/* ── Category accordions (index) ── */
.cats { display: flex; flex-direction: column; gap: 5px; }
.cat  { border: 1px solid var(--border2); background: var(--panel); position: relative; }
.cat.d-m { border-left: 2px solid var(--c-line); }
.cat.d-t { border-left: 2px solid var(--g-line); }
.cat.d-l { border-left: 2px solid var(--amber); }
.cat.d-f { border-left: 2px solid var(--r-line); }
.cat-toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 14px;
  cursor: pointer;
  user-select: none;
  transition: background 0.1s;
}
.cat-toggle:hover { background: var(--olive); }
.cat-arr { font-size: 0.6rem; color: var(--cream2); transition: transform 0.12s; flex-shrink: 0; opacity: 0.4; }
.cat.open .cat-arr { transform: rotate(90deg); opacity: 0.9; }
.cat-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.d-m .cat-dot { background: var(--c-line); box-shadow: 0 0 6px var(--c-line); }
.d-t .cat-dot { background: var(--g-line); box-shadow: 0 0 6px var(--g-line); }
.d-l .cat-dot { background: var(--amber);  box-shadow: 0 0 6px var(--amber);  }
.d-f .cat-dot { background: var(--r-line); box-shadow: 0 0 6px var(--r-line); }
.cat-name { font-size: 0.95rem; color: var(--cream); flex: 1; }
.cat-stat { font-size: 0.56rem; color: var(--cream2); letter-spacing: 2px; opacity: 0.5; }
.cat.open .cat-stat { color: var(--amber); opacity: 0.9; }
.cat-body {
  display: none;
  border-top: 1px solid var(--border);
  padding: 10px 14px 14px 38px;
  background: var(--surface);
}
.cat.open .cat-body { display: block; }
.yr { font-size: 0.66rem; color: var(--cream2); letter-spacing: 2px; margin: 4px 0 9px; opacity: 0.5; }
/* ── Entry rows ── */
.entry {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7px 0;
  font-size: 0.95rem;
  border-bottom: 1px solid var(--surface);
}
.entry:last-child { border-bottom: none; }
.entry a { color: var(--cream2); text-decoration: none; cursor: pointer; transition: color 0.1s; }
.entry a::before { content: '→ '; color: var(--amber2); }
.entry a:hover { color: var(--cream); }
.entry .ntag {
  font-size: 0.52rem;
  border: 1px solid var(--amber2);
  color: var(--amber);
  padding: 2px 6px;
  margin-left: auto;
  background: rgba(160,96,24,0.08);
}
.entry.soon { color: var(--cream2); opacity: 0.35; font-size: 0.88rem; }
.entry.soon::before { content: '· '; }
/* ── Back button ── */
.back {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 0.84rem;
  color: var(--cream2);
  cursor: pointer;
  padding: 6px 12px;
  border: 1px solid var(--border2);
  text-decoration: none;
  margin-bottom: 20px;
  transition: color 0.1s, border-color 0.1s;
}
.back:hover { color: var(--cream); border-color: var(--amber2); }
/* ── Article / Post styles ── */
.post-cat {
  font-size: 0.62rem;
  color: var(--amber2);
  letter-spacing: 3px;
  margin-bottom: 8px;
}
.post-title {
  font-family: var(--px);
  font-size: clamp(0.85rem, 2.2vw, 1.05rem);
  line-height: 1.9;
  color: var(--cream);
  margin-bottom: 24px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border);
}
.post-body {
  font-size: 0.95rem;
  line-height: 2.1;
  color: var(--cream2);
  max-width: 740px;
}
.post-body p { margin-bottom: 16px; text-align: justify; }
.post-body h3 {
  font-size: 0.78rem;
  color: var(--cream);
  letter-spacing: 3px;
  text-transform: uppercase;
  margin: 26px 0 10px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.post-body h3::before { content: '▶'; font-size: 0.52rem; color: var(--amber2); }
.post-body code {
  background: var(--olive2);
  color: var(--crt);
  padding: 1px 7px;
  font-size: 0.9em;
  border: 1px solid var(--border2);
}
.post-body em { color: var(--cream2); opacity: 0.55; font-style: italic; }
/* ── Figure / image captions (articles) ── */
.fig {
  margin: 22px 0;
  border: 1px solid var(--olive2);
  border-top: 2px solid var(--border2);
  background: #030503;
  padding: 10px;
}
.fig img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
}
.fig figcaption {
  margin-top: 7px;
  font-size: 0.52rem;
  color: var(--cream2);
  opacity: 0.55;
  letter-spacing: 1.5px;
}
/* ── Static pages (about / contact) ── */
.s-title {
  font-family: var(--px);
  font-size: 0.88rem;
  color: var(--cream);
  letter-spacing: 3px;
  margin-bottom: 20px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
}
.s-body { font-size: 0.95rem; line-height: 2.1; color: var(--cream2); max-width: 640px; }
.s-body p { margin-bottom: 16px; }
.contact-email { color: var(--crt); text-decoration: none; }
/* ── Footer ── */
footer {
  margin-top: 50px;
  padding: 10px 18px;
  border-top: 1px solid var(--border);
  background: var(--olive);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 6px;
}
footer span    { font-size: 0.62rem; color: var(--cream2); opacity: 0.45; }
footer .pn     { opacity: 0.7; color: var(--amber); }
footer .fc     { display: flex; gap: 14px; }
/* ── Responsive ── */
@media (max-width: 780px) {
  .intro { grid-template-columns: 1fr; }
  header { flex-direction: column; align-items: flex-start; }
  .h-right { text-align: left; }
  nav { flex-wrap: wrap; }
  .top-strip { flex-direction: column; }
  .status-grid { grid-template-columns: repeat(2, 1fr); }
}
/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  .ticker-track { animation: none; }
  .blink,
  .strip-id::before { animation: none; opacity: 1; }
}
