/* Communications-Terminal-Ästhetik (UX-Spec §7). Rot-auf-Schwarz, radialer Gradient,
   Serif-Headings small-caps, Monospace für Operator-Stimme. Kein Material/Bootstrap. */
:root{
  --bg:#000000; --bg2:#0a0a0a; --primary:#cc0000; --primary-hot:#ff2200;
  --text:#e8e8e8; --muted:#888888; --blue:#2255cc; --red:#cc2211;
  --border:#333333; --warning:#ff8800; --success:#226622;
  --mono:'IBM Plex Mono','Courier Prime',ui-monospace,monospace;
  --serif:'Libre Baskerville','Playfair Display',Georgia,serif;
  --sans:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  background:radial-gradient(ellipse at 50% 0%, #1a0000 0%, var(--bg2) 45%, var(--bg) 100%);
  color:var(--text); font-family:var(--sans); -webkit-font-smoothing:antialiased;
  min-height:100dvh;
}
.terminal{display:flex;flex-direction:column;min-height:100dvh;max-width:640px;margin:0 auto}
.view{flex:1;padding:18px 16px 88px;overflow-y:auto}
.hidden{display:none!important}
pre{margin:0;font-family:var(--mono);white-space:pre-wrap;line-height:1.5}

/* Headings */
h1{font-family:var(--serif);font-variant:small-caps;letter-spacing:.06em;margin:.2em 0}
.terminal-title h1{font-size:2rem}
.terminal-title p,.terminal-title-sm{font-family:var(--serif);font-variant:small-caps;color:var(--muted);letter-spacing:.12em}
.section-head{font-family:var(--serif);font-variant:small-caps;letter-spacing:.08em;border-bottom:1px solid var(--border);padding-bottom:8px;font-size:1.4rem}
.sub-head{font-family:var(--sans);text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-size:.8rem;margin-top:22px}

/* Operator */
.operator-portrait{width:96px;height:96px;border:1px solid var(--border);border-radius:4px;overflow:hidden;flex:none;
  background:repeating-linear-gradient(45deg,#111,#111 2px,#181818 2px,#181818 4px);filter:grayscale(1) contrast(1.1)}
.operator-portrait img{width:100%;height:100%;object-fit:cover;display:block}
.operator-portrait.intro{width:160px;height:160px;margin:14px auto}
.operator-portrait.small{width:56px;height:56px}
/* Wordmark (Brand-Logo statt Text). intro = gross/zentriert, sm = Operator-Header */
.wordmark{display:block;height:auto;max-width:100%}
.terminal-title .wordmark{width:70%;max-width:240px;margin:0 auto 4px}
.wordmark.sm{height:20px;width:auto;margin-bottom:2px}
.operator-bubble{font-family:var(--mono);background:#0c0c0c;border:1px solid var(--border);border-left:3px solid var(--primary);
  padding:14px 16px;border-radius:3px;margin:12px 0;line-height:1.55}
.operator-bubble.success{border-left-color:var(--success)}
.operator-bubble.danger{border-left-color:var(--primary-hot)}
.op-note{font-family:var(--mono);margin-top:8px;color:var(--muted)}
.op-note.red{color:var(--red)}

/* Operator-Chat layout */
.op-header{display:flex;gap:12px;align-items:center;border-bottom:1px solid var(--border);padding-bottom:12px}
.agent-line{font-family:var(--mono);letter-spacing:.05em;margin-top:4px;color:var(--text)}
.op-thread{display:flex;flex-direction:column;gap:6px;padding:14px 0}
.op-composer{position:sticky;bottom:0;padding-top:8px}

/* Buttons */
.btn{font-family:var(--sans);text-transform:uppercase;letter-spacing:.1em;font-weight:600;
  padding:14px 18px;border-radius:3px;border:1px solid var(--primary);background:transparent;color:var(--text);
  cursor:pointer;font-size:.85rem;transition:background .2s ease,opacity .2s ease}
.btn.primary{border-color:var(--primary);box-shadow:inset 0 0 0 1px rgba(204,0,0,.25)}
.btn.primary:hover{background:rgba(204,0,0,.15)}
.btn.ghost{border-color:var(--border);color:var(--muted)}
.btn.ghost:hover{border-color:var(--muted);color:var(--text)}
.btn.small{padding:8px 12px;font-size:.7rem}
.btn.disabled,.btn:disabled{opacity:.4;cursor:not-allowed}
.btn-row{display:flex;gap:12px;margin-top:12px}
.btn-row .btn{flex:1}

/* Inputs */
.codename-input,.report-input{width:100%;font-family:var(--mono);font-size:1.1rem;letter-spacing:.08em;
  background:#0c0c0c;border:1px solid var(--border);color:var(--text);padding:14px;border-radius:3px;margin:8px 0}
.codename-input:focus,.report-input:focus{outline:none;border-color:var(--primary)}
.field-label{display:block;font-family:var(--sans);text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-size:.75rem;margin-top:14px}
.field-hint{color:var(--muted);font-size:.8rem;margin:4px 0}
.field-hint.error,.error{color:var(--primary-hot)}
.suggest-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:8px 0}
.muted{color:var(--muted)} .small{font-size:.78rem}

/* Faction cards */
.faction-card{border:1px solid var(--border);border-radius:4px;padding:14px;margin:12px 0;background:#0a0a0a}
.faction-card.blue{border-left:3px solid var(--blue)}
.faction-card.red{border-left:3px solid var(--red)}
.faction-head{display:flex;gap:10px;align-items:center;font-weight:600;letter-spacing:.06em}
.faction-head .sym{font-size:1.2rem}
.faction-emblem{width:28px;height:28px;object-fit:contain;flex:none;border-radius:3px}
.faction-card.blue .sym{color:var(--blue)} .faction-card.red .sym{color:var(--red)}
.role-label{color:var(--muted);font-size:.75rem;font-weight:400;margin-left:auto}
.trust-level{font-family:var(--mono);margin:8px 0 4px;font-size:.85rem}
.redacted .noise{font-family:var(--mono);color:#444;letter-spacing:2px;filter:blur(.5px)}

/* Progress bars */
.progress{display:inline-block;width:140px;height:10px;background:#1a1a1a;border:1px solid var(--border);border-radius:2px;vertical-align:middle;overflow:hidden}
.progress .fill{display:block;height:100%;background:var(--primary)}
.progress.blue .fill{background:var(--blue)} .progress.red .fill{background:var(--red)}
.progress.influence .fill{background:var(--primary)}
.val{font-family:var(--mono);font-size:.8rem;color:var(--muted)}

/* Profile dl */
.profile{display:grid;grid-template-columns:auto 1fr;gap:6px 14px;font-family:var(--mono);margin:12px 0}
.profile dt{color:var(--muted)} .profile dd{margin:0}

/* Mission rows */
.mission-row{border:1px solid var(--border);border-radius:4px;padding:12px 14px;margin:10px 0;cursor:pointer;background:#0a0a0a}
.mission-row:hover{border-color:var(--muted)}
.m-title{font-weight:600;letter-spacing:.04em}
.m-meta{color:var(--muted);font-size:.82rem;font-family:var(--mono);margin-top:2px}
.m-link{color:var(--primary);font-size:.75rem;letter-spacing:.1em}
.reward-line{font-family:var(--mono);color:var(--text);margin:8px 0}

/* Countdown */
.countdown{font-family:var(--mono);color:var(--primary);margin:6px 0}
.countdown.warning{color:var(--warning)}

/* Report box */
.report-box{border-top:1px dashed var(--border);padding-top:12px}
.report-label{font-family:var(--sans);text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-size:.75rem}

/* Map */
.map-canvas{height:240px;border:1px solid var(--border);border-radius:4px;margin:12px 0;position:relative;
  background:radial-gradient(circle at 60% 40%, #10131a, #050608);display:flex;align-items:center;justify-content:center;flex-direction:column}
.cp-marker{color:var(--red);font-size:2rem;animation:pulse 1.4s ease-in-out infinite}
.cp-name{font-family:var(--mono);color:var(--muted);font-size:.8rem;margin-top:6px}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.dist-line{font-family:var(--mono);margin:8px 0}
.unlock.ok{color:var(--success)} .unlock.warn{color:var(--warning)}

/* Lock cards (Cell) */
.lock-card{border:1px dashed var(--border);border-radius:4px;padding:16px;margin:14px 0}
.lock-card.dimmed{opacity:.6} .lock-card.premium{border-color:var(--primary)}
.lock-head{font-weight:600;letter-spacing:.05em;margin-bottom:8px}

/* Bottom nav */
.bottom-nav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:640px;
  display:flex;border-top:1px solid var(--border);background:rgba(0,0,0,.92);backdrop-filter:blur(6px)}
.nav-btn{flex:1;background:none;border:none;color:var(--muted);font-family:var(--sans);text-transform:uppercase;
  letter-spacing:.08em;font-size:.7rem;padding:14px 4px;cursor:pointer}
.nav-btn.active{color:var(--primary)}
.nav-btn.locked{opacity:.4}
.back-link{background:none;border:none;color:var(--muted);font-family:var(--sans);letter-spacing:.08em;
  text-transform:uppercase;font-size:.75rem;cursor:pointer;padding:0 0 12px}

.onb.screen{display:flex;flex-direction:column;gap:6px;align-items:stretch;text-align:center}
.onb .operator-portrait{align-self:center}
@media (prefers-reduced-motion: reduce){.cp-marker{animation:none}}
