/* ========================================================================= base.css — Design-Tokens, Reset, App-Layout (Sidebar + Topbar + Content) v3: dichtes Control-Plane-Design, EINE Akzentfarbe (Teal), Klartext-tauglich. Orientierung: docs/mission-control-overview.png ========================================================================= */ :root{ /* Flächen */ --bg:#0b0e13; --bg2:#0d1117; --panel:#141a24; --tile:#11161e; --panel2:#11161e; --inset:#0a0e13; --line:rgba(255,255,255,.08); --line2:rgba(255,255,255,.14); /* Text */ --tx:#e6edf3; --mut:#8b97a5; --dim:#5d6b79; /* EINE Akzentfarbe für alles Klickbare/Aktive */ --accent:#2dd4bf; --accent-ink:#06231f; --teal:#2dd4bf; /* Status-/Datenfarben (NUR für Bedeutung, nicht für Buttons) */ --on:#3fb950; --act:#4493e0; --purple:#a371f7; --warn:#e0a32e; --err:#f0573f; /* Kompat-Aliase (von Phase-B-Panels referenziert) */ --hi:var(--accent); --red:var(--err); --red-dim:rgba(240,87,63,.12); /* Tints (getönte Karten, Legacy) */ --t-green:rgba(63,185,80,.07); --b-green:rgba(63,185,80,.22); --t-blue:rgba(68,147,224,.07); --b-blue:rgba(68,147,224,.22); --t-purple:rgba(163,113,247,.08);--b-purple:rgba(163,113,247,.24); --t-red:rgba(240,87,63,.08); --b-red:rgba(240,87,63,.24); /* Schrift */ --mono:ui-monospace,"SF Mono",Menlo,Consolas,"Liberation Mono",monospace; --sans:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif; /* Typografie-Skala */ --text-xs:11.5px; --text-sm:13px; --text-base:14px; --text-lg:16px; --text-xl:20px; --text-2xl:24px; /* Spacing-Skala */ --sp-1:4px; --sp-2:8px; --sp-3:12px; --sp-4:16px; --sp-5:20px; --sp-6:24px; --sp-8:32px; --sp-10:40px; /* Maße */ --side:212px; --radius:12px; --radius-sm:8px; } *{box-sizing:border-box} html,body{height:100%} body{ margin:0;background:var(--bg);color:var(--tx); font-family:var(--sans);font-size:var(--text-base);line-height:1.5; -webkit-font-smoothing:antialiased; } a{color:var(--accent);text-decoration:none} ::selection{background:rgba(45,212,191,.28)} /* ---- App-Shell: feste, beschriftete Sidebar + scrollender Main ---- */ #app{display:flex;min-height:100vh} .sidebar{ width:var(--side);flex:0 0 var(--side); background:var(--bg2);border-right:1px solid var(--line); display:flex;flex-direction:column; padding:var(--sp-4) var(--sp-3);gap:2px;position:sticky;top:0;height:100vh; } .brand{display:flex;align-items:center;gap:10px;padding:4px 8px 16px} .brand-logo{ width:30px;height:30px;border-radius:9px;flex:0 0 auto; display:grid;place-items:center;color:var(--accent-ink);background:var(--accent); } .brand-logo svg{width:18px;height:18px} .brand-tx{font-size:15px;font-weight:500;letter-spacing:.2px} .side-nav{display:flex;flex-direction:column;gap:2px;flex:1} .side-foot{margin-top:auto;padding-top:var(--sp-2);border-top:1px solid var(--line)} .nav-cap{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);padding:8px 10px 6px} .nav-item{ display:flex;align-items:center;gap:11px; padding:9px 11px;border-radius:10px;color:var(--mut);cursor:pointer; border:1px solid transparent;transition:.13s;font-size:13.5px;user-select:none; } .nav-item:hover{color:var(--tx);background:var(--panel)} .nav-item.active{color:var(--tx);background:rgba(45,212,191,.12);border-color:rgba(45,212,191,.20);font-weight:500} .nav-item.active .ni-ic{color:var(--accent)} .ni-ic{display:grid;place-items:center;color:inherit;flex:0 0 auto} .ni-ic svg{width:18px;height:18px} .nav-item.disabled{opacity:.34;cursor:not-allowed} /* ---- Main-Spalte ---- */ .main{flex:1;min-width:0;display:flex;flex-direction:column} .topbar{ position:sticky;top:0;z-index:20; display:flex;align-items:center;gap:var(--sp-3);flex-wrap:wrap; padding:var(--sp-3) var(--sp-6);background:rgba(11,14,19,.86);backdrop-filter:blur(8px); border-bottom:1px solid var(--line); } .spacer{flex:1} .status-pill{ display:inline-flex;align-items:center;gap:var(--sp-2);font-family:var(--mono);font-size:var(--text-xs); padding:5px 12px;border:1px solid var(--line);border-radius:999px;color:var(--mut);background:var(--panel); } .dot{width:8px;height:8px;border-radius:50%;background:var(--mut);flex:0 0 auto} .dot.on{background:var(--on);box-shadow:0 0 0 0 rgba(63,185,80,.5);animation:pulse 2.2s infinite} .dot.off{background:var(--err)} @keyframes pulse{0%{box-shadow:0 0 0 0 rgba(63,185,80,.45)}70%{box-shadow:0 0 0 7px rgba(63,185,80,0)}100%{box-shadow:0 0 0 0 rgba(63,185,80,0)}} .top-stat{font-size:var(--text-sm);color:var(--mut)} .top-stat b{color:var(--tx);font-family:var(--mono);font-weight:500;margin-left:4px} .top-clock{font-family:var(--mono);font-size:var(--text-sm);color:var(--accent)} /* Security-Chip (zeigt LAN/Token-Status) */ .sec-chip{ display:inline-flex;align-items:center;gap:7px;font-size:var(--text-xs); padding:5px 11px;border-radius:999px;border:1px solid var(--line); background:var(--panel);color:var(--mut); } .sec-chip.ok{background:rgba(63,185,80,.12);border-color:rgba(63,185,80,.25);color:#7ee29a} .sec-chip .ti, .sec-chip svg{width:14px;height:14px} .icon-btn{color:var(--dim);cursor:pointer;display:grid;place-items:center;background:none;border:0;padding:6px} .icon-btn:hover{color:var(--tx);border-color:transparent} .icon-btn svg{width:18px;height:18px} /* ---- Content-Bereich ---- */ .content{padding:var(--sp-5) var(--sp-6) var(--sp-10);max-width:1320px;margin:0 auto;width:100%} .view[hidden]{display:none} .view{display:flex;flex-direction:column;gap:var(--sp-4)} /* Raster-Helfer */ .grid{display:grid;gap:var(--sp-4)} .grid-3{grid-template-columns:repeat(auto-fit, minmax(300px, 1fr))} .grid-2{grid-template-columns:repeat(auto-fit, minmax(400px, 1fr))} .kpis{grid-template-columns:repeat(5,1fr)} .tiles{display:grid;gap:var(--sp-3);grid-template-columns:repeat(auto-fit, minmax(165px, 1fr))} .split{display:grid;gap:var(--sp-4);grid-template-columns:1.05fr 1fr} @media(max-width:1180px){.grid-3{grid-template-columns:1fr 1fr}.kpis{grid-template-columns:repeat(2,1fr)}} @media(max-width:900px){.split{grid-template-columns:1fr}} @media(max-width:760px){.grid-3,.grid-2,.kpis{grid-template-columns:1fr} .sidebar{width:60px;flex-basis:60px} .ni-tx,.brand-tx{display:none} .nav-item{justify-content:center}.brand{justify-content:center}} /* Alert-Banner */ .alert{ margin:var(--sp-4) var(--sp-6) 0;padding:var(--sp-3) var(--sp-4);border-radius:var(--radius); background:rgba(240,87,63,.10);border:1px solid rgba(240,87,63,.26);color:#ffcdc8; display:flex;align-items:center;gap:var(--sp-3);font-size:var(--text-sm); } .alert .a-dot{width:8px;height:8px;border-radius:50%;background:var(--err);flex:0 0 auto} .alert b{color:#ffe2de} .alert.warn{background:rgba(224,163,46,.10);border-color:rgba(224,163,46,.26);color:#f3dca6} .alert.warn .a-dot{background:var(--warn)}