/* K.BAU MV Vorstandsplattform – studioBLOME-Stil (RAL-Palette, Bold-Body) */
:root{
  --gelb:#F3A505; --rot:#A52019; --violett:#A03472; --blau:#3E5F8A;
  --gruen:#2D572C; --orange:#EC7C25; --pink:#E55B8A;
  --fg:#1a1a1a; --muted:#6b6b6b; --bg:#f4f3f1; --card:#ffffff;
  --b:#e3e1dd; --r:14px;
  --shadow:0 1px 3px rgba(0,0,0,.06),0 6px 20px rgba(0,0,0,.04);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:-apple-system,"Inter","Segoe UI",system-ui,sans-serif;
  font-weight:700; color:var(--fg); background:var(--bg);
  font-size:15px; line-height:1.45;
  -webkit-font-smoothing:antialiased;
}
.muted{color:var(--muted);font-weight:600}
.dim{opacity:.6;font-weight:600}
a{color:var(--blau);text-decoration:none}
a:hover{text-decoration:underline}

/* Layout */
header.top{
  display:flex;align-items:center;gap:16px;
  padding:14px 22px;background:var(--card);border-bottom:1px solid var(--b);
  position:sticky;top:0;z-index:20;
}
header.top .logo{
  width:34px;height:34px;border-radius:9px;background:var(--fg);color:#fff;
  display:grid;place-items:center;font-weight:800;font-size:15px;letter-spacing:-.5px;
}
header.top h1{font-size:17px;margin:0;letter-spacing:-.3px}
header.top h1 small{color:var(--muted);font-weight:600;font-size:13px;margin-left:8px}
.shell{display:flex;min-height:calc(100vh - 63px)}
nav.side{
  width:210px;flex-shrink:0;padding:16px 10px;background:var(--card);
  border-right:1px solid var(--b);
}
nav.side button{
  display:flex;align-items:center;gap:10px;width:100%;text-align:left;
  padding:9px 12px;margin:2px 0;border:0;border-radius:10px;background:transparent;
  font:inherit;color:var(--fg);cursor:pointer;
}
nav.side button .ico{width:20px;text-align:center;opacity:.7}
nav.side button:hover{background:#f0eeea}
nav.side button.active{background:var(--fg);color:#fff}
nav.side button.active .ico{opacity:1}
nav.side .badge{margin-left:auto;background:var(--gelb);color:#3a2a00;border-radius:999px;
  padding:1px 8px;font-size:12px;font-weight:800}
main.view{flex:1;padding:24px 28px;max-width:1100px}

/* Cards & grid */
.card{background:var(--card);border:1px solid var(--b);border-radius:var(--r);
  padding:18px 20px;box-shadow:var(--shadow);margin-bottom:16px}
.grid{display:grid;gap:14px}
.grid2{grid-template-columns:repeat(2,1fr)}
.grid3{grid-template-columns:repeat(3,1fr)}
.grid4{grid-template-columns:repeat(4,1fr)}
@media(max-width:820px){.grid2,.grid3,.grid4{grid-template-columns:1fr}}
h2.view-title{font-size:22px;margin:0 0 4px;letter-spacing:-.4px}
.view-sub{color:var(--muted);font-weight:600;margin:0 0 18px}
.row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.spacer{flex:1}

/* KPI */
.kpi{background:var(--card);border:1px solid var(--b);border-radius:var(--r);padding:16px 18px}
.kpi .n{font-size:30px;font-weight:800;letter-spacing:-1px;line-height:1}
.kpi .l{color:var(--muted);font-weight:600;margin-top:6px;font-size:13px}
.kpi.accent-gelb{border-top:4px solid var(--gelb)}
.kpi.accent-blau{border-top:4px solid var(--blau)}
.kpi.accent-gruen{border-top:4px solid var(--gruen)}
.kpi.accent-violett{border-top:4px solid var(--violett)}

/* Buttons & inputs */
button.btn,a.btn{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--b);
  background:var(--card);border-radius:10px;padding:8px 14px;font:inherit;font-weight:700;
  cursor:pointer;color:var(--fg)}
button.btn:hover,a.btn:hover{background:#f0eeea;text-decoration:none}
button.btn.primary{background:var(--fg);color:#fff;border-color:var(--fg)}
button.btn.primary:hover{opacity:.9}
button.btn.danger{color:var(--rot);border-color:#e8cfcf}
button.btn.sm{padding:5px 10px;font-size:13px}
input,textarea,select{font:inherit;font-weight:600;border:1px solid var(--b);border-radius:9px;
  padding:9px 11px;width:100%;background:#fff;color:var(--fg)}
input:focus,textarea:focus,select:focus{outline:2px solid var(--blau);outline-offset:-1px}
textarea{min-height:90px;resize:vertical}
label.field{display:block;margin-bottom:10px}
label.field > span{display:block;font-size:13px;color:var(--muted);font-weight:700;margin-bottom:4px}

/* Pills / tags */
.pill{display:inline-flex;align-items:center;gap:5px;border-radius:999px;padding:2px 10px;
  font-size:12px;font-weight:800;background:#eee}
.pill.gelb{background:#fdeccb;color:#7a5400}
.pill.gruen{background:#d7ebd6;color:#1f3d1e}
.pill.blau{background:#d9e3f0;color:#274063}
.pill.rot{background:#f3d7d7;color:#7a1812}
.pill.violett{background:#ecd7e6;color:#5e2049}
.pill.grau{background:#e7e5e1;color:#555}

/* Lists & tables */
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:12px;color:var(--muted);font-weight:800;padding:8px 10px;border-bottom:2px solid var(--b);text-transform:uppercase;letter-spacing:.4px}
td{padding:10px;border-bottom:1px solid var(--b);vertical-align:middle;font-weight:600}
tr:hover td{background:#faf9f7}
.item{display:flex;gap:12px;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--b)}
.item:last-child{border-bottom:0}
.avatar{width:38px;height:38px;border-radius:50%;flex-shrink:0;display:grid;place-items:center;
  background:var(--blau);color:#fff;font-weight:800;font-size:14px}

/* Modal */
.modal-bg{position:fixed;inset:0;background:rgba(20,18,16,.45);display:none;z-index:50;
  align-items:flex-start;justify-content:center;padding:40px 16px;overflow:auto}
.modal-bg.open{display:flex}
.modal{background:var(--card);border-radius:16px;max-width:560px;width:100%;padding:24px;
  box-shadow:0 20px 60px rgba(0,0,0,.3)}
.modal h3{margin:0 0 16px;font-size:19px}
.modal .actions{display:flex;gap:10px;justify-content:flex-end;margin-top:18px}

/* Forum thread */
.post{background:#faf9f7;border:1px solid var(--b);border-radius:12px;padding:12px 14px;margin:10px 0}
.post .meta{font-size:12px;color:var(--muted);font-weight:700;margin-bottom:4px}
.post .body{white-space:pre-wrap;font-weight:600}

/* Kalender */
.cal-head{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:6px}
.cal-head div{font-size:12px;color:var(--muted);font-weight:800;text-align:center}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-cell{min-height:96px;border:1px solid var(--b);border-radius:10px;padding:6px;background:#fff}
.cal-cell.other{background:#f7f6f4;opacity:.55}
.cal-cell.today{outline:2px solid var(--blau);outline-offset:-1px}
.cal-daynum{font-size:12px;font-weight:800;color:var(--muted)}
.cal-ev{display:block;font-size:11px;font-weight:700;border-radius:6px;padding:2px 6px;margin-top:3px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cal-ev.sitzung{background:#d9e3f0;color:#274063}
.cal-ev.termin{background:#d7ebd6;color:#1f3d1e}
.cal-ev.vorschlag{background:#fdeccb;color:#7a5400}
.cal-ev.cancelled{background:#eee;color:#999;text-decoration:line-through}
/* Mini-Kalender im Doodle */
.mc-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.mc-wd{font-size:10px;color:var(--muted);text-align:center;font-weight:800;padding-bottom:2px}
.mc-day{text-align:center;padding:7px 0;border-radius:8px;cursor:pointer;font-size:13px;font-weight:700;border:1px solid var(--b)}
.mc-day:hover{background:#f0eeea}
.mc-day.other{opacity:.35}
.mc-day.today{outline:2px solid var(--blau);outline-offset:-2px}
.mc-day.sel{background:var(--fg);color:#fff;border-color:var(--fg)}
.slot-row{display:flex;align-items:center;gap:8px;margin:6px 0;flex-wrap:wrap;background:#faf9f7;border:1px solid var(--b);border-radius:9px;padding:6px 8px}
.modeseg{display:inline-flex;border:1px solid var(--b);border-radius:8px;overflow:hidden}
.modeseg label{padding:4px 9px;font-size:12px;font-weight:700;cursor:pointer}
.modeseg label.on{background:var(--blau);color:#fff}
.modeseg input{display:none}
body:not(.is-admin) .admin-only{display:none !important}
.empty{text-align:center;color:var(--muted);font-weight:700;padding:40px 20px}
.toast{position:fixed;bottom:24px;right:24px;background:var(--fg);color:#fff;padding:12px 18px;
  border-radius:12px;z-index:100;box-shadow:var(--shadow);font-weight:700;opacity:0;transform:translateY(8px);
  transition:.2s}
.toast.show{opacity:1;transform:none}
.toast.err{background:var(--rot)}
