/* Bildungsschmiede – Bauhaus-Design (Blautöne). Klar, geometrisch, benutzerfreundlich. */
:root{
  --navy:#0d2440;        /* dunkelstes Blau (Text/Kopf) */
  --blue:#1f5fd0;        /* Primär */
  --blue-bright:#2f80ed; /* Aktion */
  --sky:#4aa3e8;         /* mittel */
  --ice:#dbe9fb;         /* hell */
  --ice-2:#eef4fc;       /* Flächen */
  --paper:#f6f8fc;       /* Hintergrund */
  --white:#ffffff;
  --line:#d4e0f0;
  --ink:#0d2440;
  --muted:#5d7290;
  --ok:#2b915f; --warn:#d98a1f; --bad:#c0432f;
  --r:14px;
  --shadow:0 1px 2px rgba(13,36,64,.06),0 6px 22px rgba(13,36,64,.07);
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  font-family:"Helvetica Neue",Arial,system-ui,sans-serif;
  background:var(--paper);color:var(--ink);font-size:15px;line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--blue);text-decoration:none}
h1,h2,h3{margin:0;font-weight:800;letter-spacing:-.01em}
h1{font-size:26px}
.upper{text-transform:uppercase;letter-spacing:.12em;font-size:12px;font-weight:800;color:var(--muted)}

/* ---- App-Rahmen: Sidebar + Inhalt ---- */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.side{background:var(--navy);color:#cdd9ec;padding:22px 16px;display:flex;flex-direction:column;gap:6px}
.brand{display:flex;align-items:center;gap:12px;padding:6px 8px 22px}
.brand .marks{display:flex;gap:5px}
.brand .marks i{width:13px;height:13px;display:block}
.brand .sq{background:var(--blue-bright)}
.brand .ci{background:var(--sky);border-radius:50%}
.brand .tri{width:0;height:0;border-left:7px solid transparent;border-right:7px solid transparent;border-bottom:13px solid var(--ice)}
.brand b{color:#fff;font-size:15px;letter-spacing:.02em;line-height:1.1}
.brand span{display:block;color:#7f97ba;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.1em}
.nav a{display:flex;align-items:center;gap:12px;color:#cdd9ec;padding:11px 14px;border-radius:10px;font-weight:600}
.nav a .dot{width:10px;height:10px;border-radius:2px;background:var(--sky);flex:none}
.nav a:hover{background:#15315a;color:#fff}
.nav a.active{background:var(--blue-bright);color:#fff}
.nav a.active .dot{background:#fff;border-radius:50%}
.side .foot{margin-top:auto;font-size:12px;color:#7f97ba;padding:8px}
.side .foot a{color:#9fb6d8}

.main{padding:28px 34px;max-width:1180px}
.topbar{display:flex;justify-content:space-between;align-items:center;gap:20px;margin-bottom:24px}
.crumbs{color:var(--muted);font-size:13px;margin-bottom:4px}
.search{display:flex;gap:10px;min-width:440px}
.search input{flex:1;padding:13px 16px;border:2px solid var(--line);border-radius:12px;font-size:16px;background:#fff}
.search input:focus{outline:none;border-color:var(--blue-bright)}
.search button,.btn{padding:11px 18px;background:var(--blue-bright);color:#fff;border:0;border-radius:10px;font-weight:700;cursor:pointer;font-size:15px}
.search-btn{padding:13px 26px !important;font-size:16px !important;white-space:nowrap;box-shadow:0 4px 14px rgba(47,128,237,.35);letter-spacing:.01em}
.search-btn:hover{background:var(--blue) !important;transform:translateY(-1px)}
.btn.ghost{background:#fff;color:var(--blue);border:2px solid var(--line)}
.btn:hover{filter:brightness(1.05)}

/* ---- KPIs ---- */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:16px;margin-bottom:26px}
.kpi{background:#fff;border-radius:var(--r);padding:18px 20px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.kpi .big{font-size:40px;font-weight:800;line-height:1}
.kpi .lbl{margin-top:6px}
.kpi::after{content:"";position:absolute;right:-18px;top:-18px;width:60px;height:60px;border-radius:50%;background:var(--ice)}
.kpi.b1::after{background:var(--ice)} .kpi.b2::after{background:#cfe0f7;border-radius:0}
.kpi.b3::after{background:var(--sky);opacity:.25} .kpi.b4::after{background:var(--blue);opacity:.18}

/* ---- Karten / Grid ---- */
.section-title{display:flex;align-items:center;gap:10px;margin:26px 0 14px}
.section-title .bar{width:22px;height:6px;background:var(--blue-bright)}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.card{background:#fff;border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}
.card .head{padding:16px 18px;color:#fff;background:var(--blue)}
.card.gruppe .head{background:var(--blue)} .card.einzel .head{background:var(--sky)}
.card .head h3{font-size:17px}
.card .head .tag{font-size:11px;text-transform:uppercase;letter-spacing:.1em;opacity:.9;font-weight:700}
.card .body{padding:16px 18px;display:flex;flex-direction:column;gap:10px}
.card .stat{display:flex;justify-content:space-between;font-size:14px;border-bottom:1px solid var(--line);padding-bottom:8px}
.card .stat:last-child{border:0}
.card .foot{padding:12px 18px;background:var(--ice-2);display:flex;justify-content:flex-end}

/* ---- Listen-Tabellen ---- */
.panel{background:#fff;border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden;margin-bottom:22px}
.panel .ph{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;border-bottom:1px solid var(--line)}
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:12px 16px;border-bottom:1px solid var(--line);font-size:14px}
th{background:var(--ice-2);color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:800}
tbody tr:hover{background:var(--ice-2)}
td a{font-weight:600}
.group-row td{background:var(--navy);color:#fff;font-weight:800;text-transform:uppercase;letter-spacing:.06em;font-size:12px}

/* ---- Badges ---- */
.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:700}
.s-aktiv{background:#dff1e7;color:var(--ok)}
.s-geplant{background:var(--ice);color:var(--blue)}
.s-abgeschlossen{background:#e6e9ef;color:var(--navy)}
.s-abgebrochen{background:#fbe3de;color:var(--bad)}
.s-nicht_angetreten{background:#fdeecf;color:var(--warn)}

/* ---- Anwesenheits-Matrix (Monat) ---- */
.monthbar{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.monthbar .nowm{font-size:20px;font-weight:800}
.matrix{overflow-x:auto}
.matrix table{min-width:760px}
.matrix th.day,.matrix td.day{text-align:center;padding:8px 6px;width:30px;font-variant-numeric:tabular-nums}
.matrix th.we,.matrix td.we{background:#eef2f8}
.matrix td.has{background:var(--blue-bright);color:#fff;font-weight:700;border-radius:6px}
.matrix td.name{font-weight:600;white-space:nowrap}
.matrix td.sum{font-weight:800;text-align:center}
.matrix td.rest{text-align:center;font-weight:700}
.rest-ok{color:var(--ok)} .rest-low{color:var(--bad)}

/* Profil */
.profile{display:grid;grid-template-columns:320px 1fr;gap:22px}
@media(max-width:900px){.profile{grid-template-columns:1fr}.app{grid-template-columns:1fr}.side{flex-direction:row;flex-wrap:wrap;align-items:center}}
.box{background:#fff;border-radius:var(--r);box-shadow:var(--shadow);padding:18px 20px;margin-bottom:18px;overflow-wrap:break-word}
.box h3{margin-bottom:12px;display:flex;align-items:center;gap:8px}
.box h3::before{content:"";width:14px;height:14px;background:var(--blue-bright)}
.kv{display:grid;grid-template-columns:130px 1fr;gap:6px 12px;font-size:14px}
.kv dt{color:var(--muted)}
.timeline .item{border-left:3px solid var(--sky);padding:4px 0 14px 14px;margin-left:6px}
.timeline .item .meta{font-size:12px;color:var(--muted)}
.timeline .item .cat{display:inline-block;background:var(--ice);color:var(--blue);border-radius:6px;padding:1px 8px;font-size:11px;font-weight:700;margin-right:6px}
.empty{color:var(--muted);font-style:italic;padding:6px 0}
.bigring{width:84px;height:84px;border-radius:50%;background:conic-gradient(var(--blue-bright) var(--p,0%),var(--ice) 0);display:grid;place-items:center}
.bigring span{width:62px;height:62px;border-radius:50%;background:#fff;display:grid;place-items:center;font-weight:800}

/* Anwesenheits-Status-Zellen */
.matrix td.clk{cursor:pointer}
.matrix td.clk:hover{outline:2px solid var(--blue-bright);outline-offset:-2px}
.matrix td.st-an{background:var(--blue-bright);color:#fff;font-weight:700}
.matrix td.st-kr{background:#fbe3de;color:var(--bad);font-weight:800}
.matrix td.st-en{background:#fdeecf;color:var(--warn);font-weight:800}
.matrix td.st-un{background:#f3d4cd;color:#7a1f12;font-weight:800}
.matrix td.st-pr{background:#dbeee6;color:#1d6b4a;font-weight:800}
.legend{display:flex;gap:14px;flex-wrap:wrap;font-size:12px;color:var(--muted);margin:8px 0 2px}
.legend i{display:inline-block;width:14px;height:14px;border-radius:4px;vertical-align:-2px;margin-right:5px}
.lg-an{background:var(--blue-bright)} .lg-kr{background:#fbe3de} .lg-en{background:#fdeecf} .lg-un{background:#f3d4cd} .lg-pr{background:#dbeee6}

/* Klick-Menü (Popover) */
.pop{position:absolute;z-index:50;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:8px;min-width:180px}
.pop button{display:block;width:100%;text-align:left;border:0;background:#fff;padding:9px 12px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;color:var(--ink)}
.pop button:hover{background:var(--ice-2)}
.pop .sw{display:inline-block;width:11px;height:11px;border-radius:3px;margin-right:9px;vertical-align:-1px}
.pop .ue-row{display:flex;gap:6px;padding:6px 8px}
.pop .ue-row input{width:64px;padding:7px 8px;border:2px solid var(--line);border-radius:8px}
.pop .clear{color:var(--bad)}
.pop hr{border:0;border-top:1px solid var(--line);margin:6px 4px}

/* Formulare */
.frow{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.frow label{font-weight:700;font-size:13px;color:var(--navy)}
.f-inp{padding:10px 12px;border:2px solid var(--line);border-radius:10px;font-size:15px;background:#fff;width:100%;font-family:inherit}
.f-inp:focus{outline:none;border-color:var(--blue-bright)}
select.f-inp{appearance:auto}
.f-multi{min-height:120px}
.frow-check{flex-direction:row;align-items:center;gap:10px}
.frow-check label{order:2}
.f-check{width:18px;height:18px}
.fhelp{color:var(--muted);font-size:12px}
.ferr{background:#fbe3de;color:var(--bad);border-radius:8px;padding:8px 12px;font-size:13px;font-weight:600;margin-bottom:10px}
.fbtns{display:flex;gap:10px;margin-top:8px}
.f-multi{list-style:none;padding:8px;border:2px solid var(--line);border-radius:10px}

/* Login */
.login-wrap{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,var(--navy),var(--blue))}
.login-card{background:#fff;border-radius:18px;box-shadow:0 20px 60px rgba(0,0,0,.25);padding:30px;width:340px}
.logout-btn{background:none;border:0;color:#9fb6d8;cursor:pointer;font:inherit;padding:0;text-decoration:underline}

.flash{background:#dff1e7;color:var(--ok);border-radius:10px;padding:11px 16px;font-weight:600;margin-bottom:16px}
.qrow{display:flex;justify-content:space-between;font-size:14px;margin:8px 0 3px}
.qbar{height:8px;background:var(--ice);border-radius:5px;overflow:hidden}
.qbar i{display:block;height:100%;background:var(--blue-bright)}
.xbtn{border:0;background:none;color:var(--bad);font-size:18px;line-height:1;cursor:pointer;padding:0 4px;font-weight:800}
.xbtn:hover{color:#7a1f12}
.catcount{display:flex;flex-wrap:wrap;gap:16px;align-items:center;padding:12px 18px;border-top:1px solid var(--line);background:var(--ice-2)}
.catcount .cc{font-size:13px;color:var(--navy)}
.filterbar{display:flex;gap:18px;align-items:center;flex-wrap:wrap;margin-bottom:18px}
.filterbar label{font-size:13px;font-weight:700;color:var(--muted);display:flex;align-items:center;gap:8px}
.filterbar select{width:auto;min-width:150px}
