121 lines
5.3 KiB
CSS
121 lines
5.3 KiB
CSS
/* =========================================================================
|
|
base.css — Design-Tokens, Reset, App-Layout (Sidebar + Topbar + Content)
|
|
Optik orientiert an docs/mission-control-overview.png (GitHub-Dark-Familie).
|
|
========================================================================= */
|
|
|
|
:root{
|
|
/* Flächen */
|
|
--bg:#0a0d12; --bg2:#0d1117; --panel:#10151c; --panel2:#151b23; --inset:#0a0e13;
|
|
--line:rgba(255,255,255,.07); --line2:rgba(255,255,255,.13);
|
|
/* Text */
|
|
--tx:#d7dee7; --mut:#8b97a5; --dim:#5c6773;
|
|
/* Akzente */
|
|
--on:#3fb950; --act:#4493e0; --purple:#a371f7; --warn:#e0a32e; --err:#e5534b;
|
|
--teal:#2dd4bf;
|
|
/* Tints (für getönte Karten) */
|
|
--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(229,83,75,.08); --b-red:rgba(229,83,75,.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:62px; --radius:6px;
|
|
}
|
|
|
|
*{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(--act);text-decoration:none}
|
|
::selection{background:rgba(68,147,224,.32)}
|
|
|
|
/* ---- App-Shell: feste 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;align-items:center;
|
|
padding:var(--sp-4) 0;gap:var(--sp-2);position:sticky;top:0;height:100vh;
|
|
}
|
|
.side-logo{
|
|
width:34px;height:34px;border-radius:9px;margin-bottom:10px;
|
|
display:grid;place-items:center;color:var(--teal);
|
|
background:rgba(45,212,191,.10);border:1px solid rgba(45,212,191,.22);
|
|
}
|
|
.side-nav{display:flex;flex-direction:column;gap:4px;flex:1}
|
|
.side-foot{margin-top:auto}
|
|
.nav-item{
|
|
width:40px;height:40px;border-radius:var(--radius);display:grid;place-items:center;
|
|
color:var(--mut);cursor:pointer;border:1px solid transparent;transition:.15s;
|
|
}
|
|
.nav-item:hover{color:var(--tx);background:var(--panel)}
|
|
.nav-item.active{
|
|
color:var(--teal);background:rgba(45,212,191,.12);border-color:rgba(45,212,191,.22);
|
|
}
|
|
.nav-item.disabled{opacity:.34;cursor:not-allowed}
|
|
.nav-item.disabled:hover{background:transparent;color:var(--mut)}
|
|
.nav-item svg{width:20px;height:20px}
|
|
|
|
/* ---- 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-4);flex-wrap:wrap;
|
|
padding:var(--sp-3) var(--sp-6);background:rgba(10,13,18,.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:var(--sp-1) var(--sp-3);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:600;margin-left:4px}
|
|
.top-clock{font-family:var(--mono);font-size:var(--text-sm);color:var(--act)}
|
|
.tokin{
|
|
font-family:var(--mono);font-size:var(--text-sm);background:var(--panel);border:1px solid var(--line);
|
|
color:var(--tx);border-radius:var(--radius);padding:var(--sp-2) var(--sp-3);width:128px;
|
|
}
|
|
.tokin:focus{outline:none;border-color:var(--act)}
|
|
|
|
/* ---- Content-Bereich ---- */
|
|
.content{padding:var(--sp-5) var(--sp-6) var(--sp-10);max-width:1300px;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)}
|
|
@media(max-width:1180px){.grid-3{grid-template-columns:1fr 1fr}.kpis{grid-template-columns:repeat(2,1fr)}}
|
|
@media(max-width:760px){.grid-3,.grid-2,.kpis{grid-template-columns:1fr}}
|
|
|
|
/* Alert-Banner */
|
|
.alert{
|
|
margin:var(--sp-4) var(--sp-6) 0;padding:var(--sp-3) var(--sp-4);border-radius:var(--radius);
|
|
background:rgba(229,83,75,.08);
|
|
border:1px solid rgba(229,83,75,.2);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,.08);
|
|
border-color:rgba(224,163,46,.2);color:#f3dca6}
|
|
.alert.warn .a-dot{background:var(--warn)}
|