/* ============================================================
   RETRO ASCII GREEN PHOSPHOR TERMINAL — IDENTITY CARD
   v0.7.0 — 8-Crypto + Full Responsive
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;700&display=swap');

:root {
  --green-bright: #00ff41;
  --green-mid:    #00cc33;
  --green-dim:    #008f11;
  --green-glow:   rgba(0, 255, 65, 0.15);
  --bg:           #0a0a0a;
  --bg-terminal:  rgba(12, 12, 12, 0.92);
  --text-dim:     #006620;
  --alien-cyan:   #00ffcc;
  --card-min-w:   140px;
  --terminal-w:   860px;
  --screen-px:    20px;
  --screen-py:    20px;
  --header-fs:    11px;
  --line-fs:      14px;
  --label-w:      140px;
  --divider-fs:   12px;
  --card-name-fs: 10px;
  --card-price-fs:18px;
  --card-change-fs:11px;
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

html, body {
  width: 100%; height: 100%;
  overflow-y: auto; overflow-x: hidden;
  background: #000;
  font-family: 'IBM Plex Mono', 'Courier New', monospace;
  cursor: default;
  -webkit-overflow-scrolling: touch;
}

/* ===== 矩阵代码雨 ===== */
#matrix-rain {
  position: fixed; top: 0; left: 0;
  width: 100%; height: 100%;
  z-index: 1; opacity: 0.25; pointer-events: none;
}

/* ===== CRT 效果 ===== */
.scanlines {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  pointer-events: none; z-index: 10;
  background: repeating-linear-gradient(to bottom, transparent 0px, transparent 2px, rgba(0,0,0,0.18) 2px, rgba(0,0,0,0.18) 4px);
}
.crt-glow {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  pointer-events: none; z-index: 11;
  background: radial-gradient(ellipse at center, transparent 55%, rgba(0,0,0,0.6) 100%);
  box-shadow: inset 0 0 140px rgba(0,255,65,0.04);
}
.flicker {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  pointer-events: none; z-index: 12; background: transparent;
  animation: flicker 0.15s infinite; opacity: 0;
}
@keyframes flicker {
  0%{opacity:.02}5%{opacity:.01}10%{opacity:.03}15%{opacity:.01}20%{opacity:.04}50%{opacity:.01}80%{opacity:.02}90%{opacity:.03}100%{opacity:.01}
}

/* ===== UFO + 外星人 ===== */
.ufo {
  position: fixed; z-index: 8; top: 5%; pointer-events: none;
  animation: ufo-float 12s ease-in-out infinite;
}
.ufo pre { color: var(--alien-cyan); font-size: 10px; line-height: 1.1; text-shadow: 0 0 10px var(--alien-cyan), 0 0 30px rgba(0,255,204,0.5); opacity: 0.7; }
@keyframes ufo-float {
  0%{left:-80px;top:5%;transform:rotate(0)}25%{left:30%;top:12%;transform:rotate(3deg)}50%{left:60%;top:3%;transform:rotate(-2deg)}75%{left:85%;top:10%;transform:rotate(2deg)}100%{left:105%;top:5%;transform:rotate(0)}
}
.alien-left {
  position: fixed; z-index: 8; bottom: 8%; left: 2%; pointer-events: none;
  opacity: 0.5; animation: alien-pulse 4s ease-in-out infinite;
}
.alien-right {
  position: fixed; z-index: 8; bottom: 8%; right: 2%; pointer-events: none;
  opacity: 0.5; animation: alien-pulse 4s ease-in-out 1s infinite;
}
.alien-left pre, .alien-right pre { color: var(--green-dim); font-size: 10px; line-height: 1.1; text-shadow: 0 0 8px var(--green-dim); }
@keyframes alien-pulse { 0%,100%{opacity:.35;transform:scale(1)}50%{opacity:.65;transform:scale(1.08)} }

/* ===== 终端容器 ===== */
.terminal {
  position: relative; z-index: 5;
  width: var(--terminal-w); max-width: 98vw;
  margin: 12px auto;
  background: var(--bg-terminal);
  border: 2px solid var(--green-dim); border-radius: 6px;
  box-shadow: 0 0 20px var(--green-glow), 0 0 60px rgba(0,255,65,0.06), inset 0 0 60px rgba(0,255,65,0.02);
  display: flex; flex-direction: column;
  max-height: calc(100vh - 24px);
  backdrop-filter: blur(2px);
}

/* ===== 状态栏 ===== */
.status-bar {
  background: var(--green-dim); color: #000;
  display: flex; justify-content: space-between; align-items: center;
  padding: 4px 10px; font-size: 11px; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase; user-select: none;
}
.status-bar.bottom { border-top: 2px solid var(--green-dim); }
.status-left, .status-center, .status-right { flex: 1; }
.status-left{text-align:left}.status-center{text-align:center}.status-right{text-align:right}

/* ===== 主屏幕 ===== */
.screen {
  padding: var(--screen-py) var(--screen-px);
  color: var(--green-bright); overflow-y: auto; flex: 1;
  text-shadow: 0 0 5px var(--green-bright), 0 0 10px var(--green-mid);
}
.screen::-webkit-scrollbar { width: 5px; }
.screen::-webkit-scrollbar-track { background: var(--bg-terminal); }
.screen::-webkit-scrollbar-thumb { background: var(--green-dim); border-radius: 3px; }

/* ===== ASCII 头部 ===== */
.ascii-header {
  font-size: var(--header-fs); line-height: 1.2;
  color: var(--green-bright); text-align: center; margin-bottom: 2px;
  text-shadow: 0 0 8px var(--green-bright), 0 0 20px var(--green-mid);
}

/* ===== 分割线 ===== */
.divider {
  text-align: center; color: var(--green-dim);
  font-size: var(--divider-fs); margin: 8px 0; letter-spacing: 2px; user-select: none;
}

/* ===== 信号线 ===== */
.signal-line {
  display: flex; align-items: center; justify-content: center; gap: 6px;
  font-size: 12px; color: var(--alien-cyan); text-shadow: 0 0 8px var(--alien-cyan);
  margin: 4px 0; animation: signal-shimmer 2s ease-in-out infinite; flex-wrap: wrap;
}
.signal-dot { font-size: 14px; color: var(--green-bright); text-shadow: 0 0 10px var(--green-bright); animation: dot-ping 2s ease-in-out infinite; }
.signal-wave { letter-spacing: -2px; color: var(--green-mid); }
.signal-text { font-weight: 700; letter-spacing: 2px; }
@keyframes signal-shimmer { 0%,100%{opacity:.8}50%{opacity:1} }
@keyframes dot-ping { 0%,100%{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.3)} }

/* ===== 信息块 ===== */
.info-block { margin: 6px 0; }
.line { display: flex; align-items: baseline; margin: 4px 0; font-size: var(--line-fs); line-height: 1.6; flex-wrap: wrap; }
.label { color: var(--green-mid); font-weight: 700; white-space: pre; min-width: var(--label-w); text-shadow: 0 0 6px var(--green-mid); }
.value { color: var(--green-bright); text-shadow: 0 0 6px var(--green-bright); }
.value.placeholder { color: var(--text-dim); text-shadow: none; font-style: italic; }
.glitch-tag {
  margin-left: 8px; font-size: 11px; color: var(--alien-cyan);
  text-shadow: 0 0 6px var(--alien-cyan); letter-spacing: 1px;
  animation: glitch-skew 3s steps(1) infinite;
}
@keyframes glitch-skew {
  0%,90%,100%{transform:none;opacity:.9}92%{transform:translateX(-2px) skewX(-2deg);opacity:.6}94%{transform:translateX(2px) skewX(2deg);opacity:1}96%{transform:none}
}

/* ===== 外星解码文字 ===== */
.alien-code {
  text-align: center; display: flex; justify-content: center; gap: 16px;
  margin: 6px 0; font-size: 13px; color: var(--alien-cyan);
  text-shadow: 0 0 10px var(--alien-cyan), 0 0 20px rgba(0,255,204,0.4);
  opacity: 0.7; letter-spacing: 2px; flex-wrap: wrap;
  animation: alien-code-fade 3s ease-in-out infinite;
}
@keyframes alien-code-fade { 0%,100%{opacity:.5}50%{opacity:.85} }

/* ===== 命令提示符 ===== */
.prompt-line { display: flex; align-items: center; font-size: 14px; margin-top: 6px; }
.prompt { color: var(--green-mid); font-weight: 700; text-shadow: 0 0 6px var(--green-mid); }
.cursor-blink {
  color: var(--green-bright); font-size: 16px; margin-left: 6px;
  animation: blink 1s step-end infinite;
  text-shadow: 0 0 10px var(--green-bright), 0 0 30px var(--green-mid);
}
@keyframes blink { 0%,100%{opacity:1}50%{opacity:0} }

/* ============================================================
   金融数据看板
   ============================================================ */
.finance-wrapper { margin: 4px 0; }
.finance-updated {
  text-align: center; font-size: 10px; color: var(--green-dim);
  letter-spacing: 1.5px; margin-bottom: 6px;
}
.finance-refresh { margin-left: 8px; color: var(--green-mid); text-shadow: 0 0 4px var(--green-mid); animation: signal-shimmer 2s ease-in-out infinite; }
.finance-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  justify-items: center;
}
.finance-card {
  background: #060a06; border: 1px solid var(--green-dim); border-radius: 4px;
  padding: 8px 10px; width: 100%; max-width: 200px; text-align: center;
  box-shadow: 0 0 8px rgba(0,255,65,0.03);
  transition: border-color 0.3s, box-shadow 0.3s;
}
.finance-card:hover { border-color: var(--green-mid); box-shadow: 0 0 14px var(--green-glow); }
.fin-name { font-size: var(--card-name-fs); font-weight: 700; color: var(--green-dim); letter-spacing: 1.5px; text-shadow: 0 0 3px var(--green-dim); margin-bottom: 3px; }
.fin-price { font-size: var(--card-price-fs); font-weight: 700; color: var(--green-bright); text-shadow: 0 0 8px var(--green-bright), 0 0 15px var(--green-mid); letter-spacing: 1px; line-height: 1.2; word-break: break-all; }
.fin-change { font-size: var(--card-change-fs); font-weight: 700; margin-top: 2px; letter-spacing: 0.5px; }
.fin-change.up { color: #00ff41; text-shadow: 0 0 5px #00ff41; }
.fin-change.down { color: #ff4444; text-shadow: 0 0 5px #ff4444; }
.finance-status { text-align: center; font-size: 10px; color: var(--green-dim); margin-top: 6px; letter-spacing: 1px; min-height: 14px; }
.finance-status.error { color: #ff4444; }

/* ============================================================
   翻译模块
   ============================================================ */
.translator-wrapper { margin: 4px 0; padding: 0 2px; }
.translate-input-row { display: flex; align-items: center; gap: 6px; margin-bottom: 6px; flex-wrap: wrap; }
.translate-label { color: var(--green-mid); font-weight: 700; font-size: 13px; text-shadow: 0 0 4px var(--green-mid); white-space: nowrap; }
.trans-input {
  flex: 1; min-width: 120px;
  background: #0a0a0a; border: 1px solid var(--green-dim);
  color: var(--green-bright); font-family: 'IBM Plex Mono', monospace;
  font-size: 13px; padding: 6px 10px; outline: none; caret-color: var(--green-bright);
  text-shadow: 0 0 4px var(--green-bright);
}
.trans-input:focus { border-color: var(--green-bright); box-shadow: 0 0 8px var(--green-glow); }
.trans-input::placeholder { color: var(--text-dim); }
.trans-btn {
  background: var(--green-dim); color: #000; border: none;
  padding: 7px 12px; font-family: 'IBM Plex Mono', monospace;
  font-size: 12px; font-weight: 700; cursor: pointer; letter-spacing: 1px; white-space: nowrap;
  transition: background 0.15s;
}
.trans-btn:hover { background: var(--green-mid); box-shadow: 0 0 10px var(--green-glow); }
.translate-results { margin: 4px 0; }
.trans-row { display: flex; align-items: baseline; gap: 6px; margin: 3px 0; font-size: 13px; }
.trans-lang { color: var(--alien-cyan); font-weight: 700; min-width: 28px; text-shadow: 0 0 4px var(--alien-cyan); }
.trans-text { color: var(--green-bright); text-shadow: 0 0 4px var(--green-bright); word-break: break-all; }
.trans-text.placeholder { color: var(--text-dim); text-shadow: none; font-style: italic; }
.trans-status { font-size: 10px; color: var(--green-dim); min-height: 14px; }
.trans-status.error { color: #ff4444; }

/* ============================================================
   ASCII 艺术字生成器
   ============================================================ */
.ascii-gen-wrapper { margin: 4px 0; padding: 0 2px; }
.ascii-gen-input-row { display: flex; align-items: center; gap: 6px; margin-bottom: 6px; flex-wrap: wrap; }
.ascii-font-select {
  background: #0a0a0a; border: 1px solid var(--green-dim);
  color: var(--green-bright); font-family: 'IBM Plex Mono', monospace;
  font-size: 11px; font-weight: 700; padding: 6px 6px; outline: none; cursor: pointer; min-width: 100px;
}
.ascii-font-select:focus { border-color: var(--green-bright); box-shadow: 0 0 8px var(--green-glow); }
.ascii-font-select option { background: #0a0a0a; color: var(--green-bright); }
.ascii-output {
  background: #050505; border: 1px solid var(--green-dim); border-radius: 4px;
  padding: 10px 12px; font-family: 'IBM Plex Mono', 'Courier New', monospace;
  font-size: 10px; line-height: 1.15; color: var(--alien-cyan);
  text-shadow: 0 0 6px var(--alien-cyan), 0 0 12px rgba(0,255,204,0.3);
  min-height: 30px; max-height: 200px; overflow: auto; white-space: pre; margin: 4px 0;
}
.ascii-output::-webkit-scrollbar { width: 4px; height: 4px; }
.ascii-output::-webkit-scrollbar-track { background: #050505; }
.ascii-output::-webkit-scrollbar-thumb { background: var(--green-dim); border-radius: 2px; }
.ascii-gen-controls { text-align: center; font-size: 10px; color: var(--green-dim); letter-spacing: 1px; margin-top: 2px; }

/* ============================================================
   Pac-Man
   ============================================================ */
.game-wrapper { margin: 4px 0; text-align: center; }
.game-stats { display: flex; justify-content: center; gap: 20px; font-size: 13px; font-weight: 700; color: var(--alien-cyan); text-shadow: 0 0 6px var(--alien-cyan); margin-bottom: 6px; letter-spacing: 2px; flex-wrap: wrap; }
#game-canvas {
  border: 1px solid var(--green-dim); border-radius: 4px;
  box-shadow: 0 0 12px var(--green-glow), inset 0 0 12px rgba(0,255,65,0.05);
  background: #050505; display: block; margin: 0 auto;
  image-rendering: pixelated; max-width: 100%; height: auto;
}
.game-controls { display: flex; justify-content: center; gap: 16px; margin-top: 6px; font-size: 10px; color: var(--green-dim); letter-spacing: 1px; flex-wrap: wrap; }

/* ============================================================
   Tetris
   ============================================================ */
.tetris-wrapper { margin: 4px 0; }
.tetris-row { display: flex; justify-content: center; gap: 12px; align-items: flex-start; flex-wrap: wrap; }
.tetris-left { flex-shrink: 0; }
#tetris-canvas {
  border: 1px solid var(--green-dim); border-radius: 4px;
  box-shadow: 0 0 12px var(--green-glow), inset 0 0 12px rgba(0,255,65,0.05);
  background: #050505; display: block; image-rendering: pixelated; max-width: 100%; height: auto;
}
.tetris-right { flex-shrink: 0; }
#tetris-next-canvas {
  border: 1px solid var(--green-dim); border-radius: 3px;
  background: #050505; display: block; margin: 4px 0; image-rendering: pixelated;
}
.tetris-info { text-align: left; }
.tetris-stat { font-size: 12px; color: var(--green-mid); font-weight: 700; margin: 4px 0; text-shadow: 0 0 4px var(--green-mid); letter-spacing: 2px; }
.tetris-stat span { color: var(--green-bright); }

/* ============================================================
   响应式 — 平板
   ============================================================ */
@media (max-width: 860px) {
  :root {
    --terminal-w: 100%;
    --screen-px: 14px;
    --screen-py: 12px;
    --header-fs: 8px;
    --line-fs: 13px;
    --label-w: 110px;
    --divider-fs: 10px;
    --card-name-fs: 9px;
    --card-price-fs: 15px;
    --card-change-fs: 10px;
  }
  .terminal { margin: 6px auto; max-height: calc(100vh - 12px); border-radius: 4px; }
  .finance-grid { grid-template-columns: repeat(4, 1fr); gap: 6px; }
  .ufo pre { font-size: 8px; }
  .alien-left pre, .alien-right pre { font-size: 8px; }
  .signal-line { font-size: 10px; gap: 4px; }
  .alien-code { font-size: 11px; gap: 10px; }
  .game-stats { gap: 12px; font-size: 11px; }
  #game-canvas { width: 320px; height: 320px; }
  #tetris-canvas { width: 200px; height: 340px; }
  #tetris-next-canvas { width: 100px; height: 66px; }
}

/* ============================================================
   响应式 — 手机
   ============================================================ */
@media (max-width: 520px) {
  :root {
    --screen-px: 8px;
    --screen-py: 8px;
    --header-fs: 5px;
    --line-fs: 11px;
    --label-w: 80px;
    --divider-fs: 8px;
    --card-name-fs: 8px;
    --card-price-fs: 13px;
    --card-change-fs: 9px;
  }
  .terminal { margin: 3px auto; max-height: calc(100vh - 6px); border-width: 1px; }
  .status-bar { font-size: 8px; padding: 3px 6px; letter-spacing: 0.5px; }
  .finance-grid { grid-template-columns: repeat(2, 1fr); gap: 4px; }
  .finance-card { padding: 6px 6px; }
  .ufo { display: none; }
  .alien-left, .alien-right { display: none; }
  .signal-line { font-size: 8px; gap: 2px; }
  .signal-text { letter-spacing: 1px; }
  .alien-code { font-size: 8px; gap: 6px; }
  .glitch-tag { font-size: 8px; margin-left: 4px; }
  .translate-input-row { flex-direction: column; align-items: stretch; }
  .trans-input { width: 100%; }
  .ascii-gen-input-row { flex-direction: column; align-items: stretch; }
  .ascii-output { font-size: 8px; padding: 6px 8px; max-height: 140px; }
  .game-stats { gap: 8px; font-size: 10px; }
  #game-canvas { width: 280px; height: 280px; }
  #tetris-canvas { width: 180px; height: 320px; }
  #tetris-next-canvas { width: 90px; height: 60px; }
  .game-controls { font-size: 8px; gap: 8px; }
  .line { flex-direction: column; }
  .label { min-width: auto; }
  .prompt-line { font-size: 12px; }
  .cursor-blink { font-size: 14px; }
  .tetris-row { gap: 8px; }
}

/* ============================================================
   响应式 — 极小屏
   ============================================================ */
@media (max-width: 360px) {
  :root {
    --line-fs: 10px;
    --label-w: 70px;
    --card-price-fs: 11px;
  }
  .finance-grid { gap: 3px; }
  .finance-card { padding: 4px 4px; }
  #game-canvas { width: 240px; height: 240px; }
  #tetris-canvas { width: 160px; height: 280px; }
  #tetris-next-canvas { width: 75px; height: 50px; }
}

/* ============================================================
   天气模块
   ============================================================ */
.weather-wrapper { margin: 4px 0; text-align: center; }
.weather-main { display: flex; align-items: center; justify-content: center; gap: 12px; margin-bottom: 4px; flex-wrap: wrap; }
.weather-icon { font-size: 36px; text-shadow: 0 0 10px var(--green-bright); }
.weather-temp { font-size: 28px; font-weight: 700; color: var(--green-bright); text-shadow: 0 0 8px var(--green-bright), 0 0 15px var(--green-mid); }
.weather-desc { font-size: 14px; color: var(--alien-cyan); text-shadow: 0 0 4px var(--alien-cyan); }
.weather-details { display: flex; justify-content: center; gap: 16px; font-size: 11px; color: var(--green-mid); margin: 4px 0; flex-wrap: wrap; }
.weather-details span { text-shadow: 0 0 3px var(--green-mid); }

/* ============================================================
   NBA 模块
   ============================================================ */
.nba-wrapper { margin: 4px 0; }
.nba-games { display: flex; flex-direction: column; gap: 6px; align-items: center; }
.nba-game-card {
  background: #060a06; border: 1px solid var(--green-dim); border-radius: 4px;
  padding: 8px 14px; width: 100%; max-width: 520px; cursor: pointer;
  box-shadow: 0 0 8px rgba(0,255,65,0.03);
  transition: border-color 0.3s, box-shadow 0.3s;
}
.nba-game-card:hover { border-color: var(--green-mid); box-shadow: 0 0 14px var(--green-glow); }
.nba-game-date { font-size: 9px; color: var(--green-dim); letter-spacing: 1px; margin-bottom: 2px; }
.nba-game-teams { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.nba-team { flex: 1; text-align: center; }
.nba-team-name { font-size: 12px; font-weight: 700; color: var(--green-mid); text-shadow: 0 0 3px var(--green-mid); }
.nba-team-score { font-size: 20px; font-weight: 700; color: var(--green-bright); text-shadow: 0 0 6px var(--green-bright); }
.nba-vs { font-size: 10px; color: var(--green-dim); }
.nba-game-status { text-align: center; font-size: 9px; color: var(--alien-cyan); margin-top: 2px; }

/* Box score */
.nba-boxscore-header { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; flex-wrap: wrap; }
#nba-boxscore-title { font-size: 12px; font-weight: 700; color: var(--green-mid); text-shadow: 0 0 3px var(--green-mid); }
.nba-players { display: flex; gap: 12px; flex-wrap: wrap; }
.nba-team-players { flex: 1; min-width: 200px; }
.nba-players-title { font-size: 11px; font-weight: 700; color: var(--alien-cyan); text-shadow: 0 0 4px var(--alien-cyan); margin-bottom: 4px; }
.nba-player-row { display: flex; justify-content: space-between; font-size: 10px; color: var(--green-bright); padding: 2px 4px; border-bottom: 1px solid rgba(0,255,65,0.06); }
.nba-player-row .player-name { flex: 2; }
.nba-player-row .player-stat { flex: 1; text-align: center; color: var(--green-mid); }

/* NBA 响应式 */
@media (max-width: 520px) {
  .nba-game-teams { gap: 4px; }
  .nba-team-name { font-size: 10px; }
  .nba-team-score { font-size: 16px; }
  .nba-players { flex-direction: column; }
  .nba-team-players { min-width: auto; }
  .weather-icon { font-size: 28px; }
  .weather-temp { font-size: 22px; }
}

/* ============================================================
   新闻滚动列表
   ============================================================ */
.news-wrapper { margin: 4px 0; }
.news-ticker {
  background: #060a06; border: 1px solid var(--green-dim); border-radius: 4px;
  overflow-y: auto; overflow-x: hidden; position: relative;
  max-height: 160px;
  scroll-behavior: smooth;
}
.news-ticker::-webkit-scrollbar { width: 5px; }
.news-ticker::-webkit-scrollbar-track { background: #050505; }
.news-ticker::-webkit-scrollbar-thumb { background: var(--green-dim); border-radius: 3px; }
.news-ticker-track {
  display: flex; flex-direction: column;
}
.news-item {
  display: flex; align-items: baseline; gap: 6px;
  font-size: 11px; color: var(--green-bright);
  text-shadow: 0 0 3px var(--green-bright);
  letter-spacing: 0.3px; cursor: pointer;
  padding: 6px 10px; border-bottom: 1px solid rgba(0,255,65,0.06);
  transition: background 0.15s, color 0.15s;
  line-height: 1.3; text-decoration: none;
  font-family: 'IBM Plex Mono', monospace;
}
.news-item:last-child { border-bottom: none; }
.news-item:hover { background: rgba(0,255,65,0.04); color: var(--alien-cyan); text-shadow: 0 0 8px var(--alien-cyan); }
.news-dot { color: var(--alien-cyan); font-size: 9px; flex-shrink: 0; }
.news-time {
  font-size: 9px; color: var(--green-dim); flex-shrink: 0;
  margin-left: auto; white-space: nowrap;
}

@media (max-width: 520px) {
  .news-ticker { max-height: 140px; }
  .news-item { font-size: 10px; padding: 4px 8px; }
  .news-time { font-size: 8px; }
}

/* ===== BOOT SCREEN OVERLAY ===== */
#boot-overlay {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  background: #000; z-index: 1000;
  display: flex; align-items: center; justify-content: center;
  font-family: 'IBM Plex Mono', 'Courier New', monospace;
}
#boot-console {
  color: #00ff41; font-size: 14px; line-height: 1.8;
  text-shadow: 0 0 5px #00ff41, 0 0 10px #00cc33;
  white-space: pre; margin: 0; padding: 20px;
  min-width: 500px; max-width: 90vw;
}
#boot-console .dim { color: #008f11; text-shadow: 0 0 3px #008f11; }
#boot-console .ok { color: #00ff41; }
#boot-cursor {
  color: #00ff41; font-size: 16px;
  text-shadow: 0 0 10px #00ff41, 0 0 25px #00cc33;
  animation: blink 1s step-end infinite;
  margin-left: 4px;
}


/* ===== BOOT OVERLAY — retro phosphor terminal ===== */
#boot-overlay {
  position: fixed; top: 0; left: 0;
  width: 100%; height: 100%;
  background: #0a0a0a;
  z-index: 9999;
  display: flex; align-items: center; justify-content: center;
  font-family: 'IBM Plex Mono', 'Courier New', monospace;
}
.boot-scanlines {
  position: absolute; top: 0; left: 0; width: 100%; height: 100%;
  pointer-events: none;
  background: repeating-linear-gradient(to bottom, transparent 0px, transparent 2px, rgba(0,0,0,0.15) 2px, rgba(0,0,0,0.15) 4px);
  z-index: 1;
}
.boot-crt-glow {
  position: absolute; top: 0; left: 0; width: 100%; height: 100%;
  pointer-events: none; z-index: 2;
  background: radial-gradient(ellipse at center, transparent 50%, rgba(0,0,0,0.7) 100%);
  box-shadow: inset 0 0 120px rgba(0,255,65,0.03);
}
.boot-flicker {
  position: absolute; top: 0; left: 0; width: 100%; height: 100%;
  pointer-events: none; z-index: 3; background: transparent;
  animation: flicker 0.15s infinite; opacity: 0;
}
#boot-center {
  text-align: left; position: relative; z-index: 5;
}
#boot-console {
  color: #00ff41; font-size: 14px; line-height: 1.7;
  text-shadow: 0 0 6px #00ff41, 0 0 14px #00cc33;
  white-space: pre; margin: 0;
}
#boot-console .dim { color: #006620; text-shadow: 0 0 3px #006620; }
#boot-cursor {
  color: #00ff41; font-size: 15px;
  text-shadow: 0 0 10px #00ff41, 0 0 30px #00cc33;
  animation: blink 1s step-end infinite;
}

/* ===== Boot overlay mobile ===== */
@media (max-width: 600px) {
  #boot-overlay {
    overflow: hidden;
  }
  #boot-cursor {
    font-size: 10px;
  }
}
