:root{
  --navy:#1f4e79; --blue:#2e75b6; --light:#d6e4f0; --bg:#f5f7fa;
  --zebra:#f2f6fb; --ink:#1c2733; --muted:#6b7785; --line:#e2e8f0;
  --ok:#2e7d52; --ok-bg:#e2efda; --warn:#b9770e; --warn-bg:#fcefd6;
  --crit:#c0392b; --crit-bg:#fbe1dc; --white:#fff;
  --radius:10px; --shadow:0 1px 3px rgba(20,40,80,.08),0 1px 2px rgba(20,40,80,.06);
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--ink);font-size:15px;line-height:1.5}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{color:var(--navy);margin:.2em 0 .5em;line-height:1.25}
h1{font-size:1.6rem}h2{font-size:1.25rem}h3{font-size:1.05rem}
.container{max-width:1200px;margin:0 auto;padding:24px}

/* ---- Topbar ---- */
.topbar{background:var(--navy);color:#fff;position:sticky;top:0;z-index:50;box-shadow:var(--shadow)}
.topbar .inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:24px;padding:0 24px;height:58px}
.topbar .brand{font-weight:700;font-size:1.05rem;color:#fff;letter-spacing:.2px}
.topbar .brand span{color:var(--light);font-weight:400}
.topbar nav{display:flex;gap:4px;margin-left:auto;align-items:center}
.topbar nav a{color:#dce7f3;padding:8px 12px;border-radius:6px;font-size:.92rem}
.topbar nav a:hover{background:rgba(255,255,255,.1);text-decoration:none}
.topbar nav a.active{background:var(--blue);color:#fff}
.topbar .user{color:var(--light);font-size:.85rem;margin-left:8px}

/* ---- Sub-Nav (Projekt) ---- */
.subnav{background:#fff;border-bottom:1px solid var(--line);overflow-x:auto}
.subnav .inner{max-width:1200px;margin:0 auto;display:flex;gap:2px;padding:0 24px}
.subnav a{padding:12px 14px;color:var(--muted);font-size:.9rem;white-space:nowrap;border-bottom:2px solid transparent}
.subnav a:hover{color:var(--navy);text-decoration:none}
.subnav a.active{color:var(--navy);border-bottom-color:var(--blue);font-weight:600}

/* ---- Cards ---- */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;margin-bottom:20px}
.card h2:first-child,.card h3:first-child{margin-top:0}
.grid{display:grid;gap:20px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

/* ---- KPI ---- */
.kpi{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.kpi .label{color:var(--muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.5px}
.kpi .value{font-size:1.7rem;font-weight:700;color:var(--navy);margin-top:4px}
.kpi .value.pos{color:var(--ok)}.kpi .value.neg{color:var(--crit)}
.kpi .sub{color:var(--muted);font-size:.82rem;margin-top:2px}

/* ---- Tabellen ---- */
table.data{width:100%;border-collapse:collapse;font-size:.9rem}
table.data th{background:var(--light);color:var(--navy);text-align:left;padding:10px 12px;font-weight:600;border-bottom:1px solid var(--line)}
table.data td{padding:9px 12px;border-bottom:1px solid var(--line)}
table.data tr:nth-child(even) td{background:var(--zebra)}
table.data tr:hover td{background:#eef4fb}
table.data td.num,table.data th.num{text-align:right;font-variant-numeric:tabular-nums}

/* ---- Badges / Ampeln ---- */
.badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:.78rem;font-weight:600}
.badge.ok{background:var(--ok-bg);color:var(--ok)}
.badge.warn{background:var(--warn-bg);color:var(--warn)}
.badge.crit{background:var(--crit-bg);color:var(--crit)}
.badge.info{background:var(--light);color:var(--navy)}
.badge.muted{background:#eef1f5;color:var(--muted)}
.dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:6px;vertical-align:middle}
.dot.gruen{background:var(--ok)}.dot.gelb{background:#e0a800}.dot.rot{background:var(--crit)}

/* ---- Buttons ---- */
.btn{display:inline-block;background:var(--blue);color:#fff;border:none;border-radius:7px;padding:9px 16px;
  font-size:.92rem;font-weight:600;cursor:pointer;transition:background .15s}
.btn:hover{background:var(--navy);text-decoration:none}
.btn.sec{background:#fff;color:var(--navy);border:1px solid var(--line)}
.btn.sec:hover{background:var(--bg)}
.btn.danger{background:var(--crit)}
.btn.sm{padding:5px 10px;font-size:.82rem}
.btn-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}

/* ---- Forms ---- */
label{display:block;font-size:.85rem;color:var(--muted);margin:10px 0 4px;font-weight:600}
input,select,textarea{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:7px;
  font-size:.92rem;font-family:inherit;background:#fff;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(46,117,182,.12)}
textarea{min-height:90px;resize:vertical}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0 18px}
.form-grid.three{grid-template-columns:repeat(3,1fr)}
@media(max-width:700px){.form-grid,.form-grid.three{grid-template-columns:1fr}}
.inline-check{display:flex;align-items:center;gap:8px;margin-top:8px}
.inline-check input{width:auto}

/* ---- Flash ---- */
.flash{padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:.9rem}
.flash.success{background:var(--ok-bg);color:var(--ok)}
.flash.error{background:var(--crit-bg);color:var(--crit)}
.flash.info{background:var(--light);color:var(--navy)}

/* ---- Misc ---- */
.muted{color:var(--muted)}
.right{text-align:right}
.pagehead{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:18px}
.pagehead h1{margin:0}
.result-row{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--line)}
.result-row .k{color:var(--muted)}
.result-row .v{font-weight:600;font-variant-numeric:tabular-nums}
.result-row.big .v{font-size:1.15rem;color:var(--navy)}
.slider-row{display:grid;grid-template-columns:160px 1fr 80px;gap:12px;align-items:center;margin:10px 0}
.slider-row output{font-weight:700;color:var(--navy);text-align:right}
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.photo-grid .ph{border:1px solid var(--line);border-radius:8px;overflow:hidden;background:#fff}
.photo-grid .ph img{width:100%;height:120px;object-fit:cover;display:block}
.photo-grid .ph .cap{padding:6px 8px;font-size:.8rem}
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1f4e79,#2e75b6)}
.login-box{background:#fff;padding:36px;border-radius:14px;box-shadow:0 10px 40px rgba(0,0,0,.2);width:360px}
.login-box h1{text-align:center}
.tag{font-size:.75rem;color:var(--muted);background:#eef1f5;padding:2px 7px;border-radius:5px}
