*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
 --bg:#f2ede4;--surface:#fff;--surface-2:#faf8f4;
 --border:rgba(80,60,30,0.11);--border-mid:rgba(80,60,30,0.16);
 --text:#28231c;--text-soft:#3d3529;--text-muted:#7a7268;--text-faint:#aea89f;
 --blue:#1a5296;--blue-hover:#14437c;--blue-light:#e6eef8;--blue-mid:#4878bc;--blue-faint:#eef3fb;
 --teal:#0e7490;--teal-light:#ccf0f5;--teal-faint:#f0fbfc;
 --green:#3d6e1a;--green-bg:#edf5e6;
 --amber:#9e6b00;--amber-bg:#fdf3d8;
 --red:#c70d2d;--red-bg:#fbe0e8;
 --shadow-xs:0 1px 3px rgba(40,30,10,0.06);
 --shadow-sm:0 2px 8px rgba(40,30,10,0.07),0 1px 2px rgba(40,30,10,0.04);
 --r:8px;--r-sm:5px;
 --font-serif:'Lora',Georgia,serif;
 --font-sans:'Source Sans 3','Gill Sans',sans-serif;
}
html,body{height:100%;font-family:var(--font-sans);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}

/* ── TOPBAR ── */
.topbar{background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;height:50px;padding:0 24px;position:sticky;top:0;z-index:20;gap:14px}
.back-link{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:var(--text-muted);text-decoration:none;transition:color .15s}
.back-link:hover{color:var(--blue)}
.topbar-sep{width:1px;height:16px;background:var(--border-mid)}
.topbar-title{font-family:var(--font-serif);font-size:15px;font-weight:600;color:var(--text);letter-spacing:.04em}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.avatar{width:26px;height:26px;border-radius:50%;background:var(--teal);color:#fff;font-size:10.5px;font-weight:700;display:flex;align-items:center;justify-content:center}
.user-name{font-size:12px;font-weight:600;color:var(--text)}

/* ── LAYOUT ── */
.layout{display:flex;height:calc(100vh - 50px)}
.sidebar{width:240px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);overflow-y:auto;display:flex;flex-direction:column}
.main{flex:1;overflow-y:auto;padding:24px}

/* ── SIDEBAR ── */
.sidebar-head{padding:14px 16px;border-bottom:1px solid var(--border)}
.sidebar-head h2{font-family:var(--font-serif);font-size:11.5px;font-weight:600;color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;margin-bottom:10px}
.sem-select{width:100%;padding:6px 9px;border:1px solid var(--border-mid);border-radius:var(--r-sm);background:var(--surface);font-family:inherit;font-size:12.5px;color:var(--text);cursor:pointer}
.fak-list{flex:1;overflow-y:auto}
.fak-item{padding:10px 16px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .12s;display:flex;align-items:center;gap:8px}
.fak-item:hover{background:var(--blue-faint)}
.fak-item.active{background:var(--blue-light);border-left:3px solid var(--blue)}
.fak-name{font-weight:600;font-size:13px;color:var(--text)}
.fak-kuerzel{font-size:11px;color:var(--text-muted);margin-top:1px}
.fak-empty{padding:20px 16px;color:var(--text-faint);font-size:12px;text-align:center}
.fak-badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--blue-light);color:var(--blue);font-size:10px;font-weight:700;flex-shrink:0}

/* ── CARD / BTN ── */
.card{background:var(--surface);border-radius:var(--r);border:1px solid var(--border);box-shadow:var(--shadow-xs);margin-bottom:16px}
.card-head{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}
.card-title{font-family:var(--font-serif);font-size:15px;font-weight:600;color:var(--text)}
.card-body{padding:16px 18px}
.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:var(--r-sm);border:1px solid var(--border-mid);background:var(--surface);color:var(--text-soft);font-size:12.5px;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit}
.btn:hover{background:var(--bg);border-color:var(--blue);color:var(--blue)}
.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue)}
.btn-primary:hover{background:var(--blue-hover);border-color:var(--blue-hover);color:#fff}
.btn-teal{background:var(--teal);color:#fff;border-color:var(--teal)}
.btn-teal:hover{background:#0b5e73;border-color:#0b5e73;color:#fff}
.btn-danger{background:var(--red-bg);color:var(--red);border-color:rgba(140,32,96,.2)}
.btn-danger:hover{background:var(--red);color:#fff}
.btn-sm{padding:4px 9px;font-size:11.5px}

/* ── TABS ── */
.tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:20px;gap:0}
.tab{padding:9px 18px;cursor:pointer;font-size:13px;font-weight:500;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s;white-space:nowrap}
.tab:hover{color:var(--teal)}
.tab.active{color:var(--teal);border-bottom-color:var(--teal);font-weight:600}
.tab-panel{display:none}
.tab-panel.active{display:block}

/* ── TABELLE ── */
.ntable{width:100%;border-collapse:collapse;font-size:13px}
.ntable th{text-align:left;padding:8px 12px;background:var(--surface-2);border-bottom:1px solid var(--border);font-weight:600;color:var(--text-muted);font-size:11.5px;white-space:nowrap}
.ntable td{padding:8px 12px;border-bottom:1px solid var(--border)}
.ntable tr:last-child td{border-bottom:none}
.ntable tr:hover td{background:var(--bg)}
.ntable tbody tr.total-row td{background:var(--blue-faint);font-weight:700;border-top:2px solid var(--border-mid)}

/* ── KPI TILES ── */
.kpi-row{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}
.kpi-tile{flex:1;min-width:150px;background:var(--surface);border-radius:var(--r);border:1px solid var(--border);padding:14px 16px;box-shadow:var(--shadow-xs)}
.kpi-tile.effektiv{border-left:3px solid var(--teal)}
.kpi-tile.angebot{border-left:3px solid var(--blue)}
.kpi-tile.reduktion{border-left:3px solid var(--amber)}
.kti-label{font-size:11.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}
.kti-val{font-family:var(--font-serif);font-size:26px;font-weight:700;color:var(--text)}
.kti-unit{font-size:12px;color:var(--text-muted);margin-top:2px}
.ld-spark{line-height:0}
.ld-spark svg{display:block}
.ld-delta{font-size:13px;font-weight:700;white-space:nowrap;text-align:right}

/* ── BADGE ── */
.grund-badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;background:var(--blue-light);color:var(--blue)}

/* ── LEHRANGEBOT INLINE EDIT ── */
.angebot-edit{display:flex;align-items:center;gap:8px}
.angebot-edit input{width:80px;padding:4px 8px;border:1px solid var(--border-mid);border-radius:var(--r-sm);font-family:inherit;font-size:13px;text-align:right}
.angebot-edit .sws-label{font-weight:700;font-size:16px;color:var(--blue)}

/* ── CHART CONTAINER ── */
.chart-wrap{position:relative;height:320px}

/* ── MODAL ── */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:100;align-items:center;justify-content:center}
.modal-bg.open{display:flex}
.modal{background:var(--surface);border-radius:var(--r);box-shadow:0 8px 40px rgba(0,0,0,.18);width:440px;max-width:95vw;max-height:90vh;overflow-y:auto;padding:0}
.modal-head{padding:18px 22px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-title{font-family:var(--font-serif);font-size:16px;font-weight:600}
.modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--text-muted);line-height:1;padding:2px 6px}
.modal-body{padding:18px 22px}
.modal-footer{padding:14px 22px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}
.form-row{margin-bottom:14px}
.form-row label{display:block;font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:5px}
.form-row input,.form-row select,.form-row textarea{width:100%;padding:8px 10px;border:1px solid var(--border-mid);border-radius:var(--r-sm);font-family:inherit;font-size:13px;background:var(--surface);color:var(--text)}
.form-row textarea{resize:vertical;min-height:70px}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(14,116,144,.12)}
.form-row .hint{font-size:11px;color:var(--text-faint);margin-top:4px}

/* ── FARB-DOT ── */
.color-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:5px}

/* ── EMPTY STATE ── */
.empty-state{text-align:center;padding:40px 20px;color:var(--text-faint)}
.empty-state svg{margin-bottom:12px;opacity:.4}
.empty-state p{font-size:13px}

/* ── ALERT ── */
.alert{padding:10px 14px;border-radius:var(--r-sm);font-size:12.5px;margin-bottom:12px}
.alert.error{background:var(--red-bg);color:var(--red);border:1px solid rgba(140,32,96,.2)}
.alert.success{background:var(--green-bg);color:var(--green)}

/* ── TOAST ── */
#toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:#28231c;color:#fff;padding:10px 20px;border-radius:var(--r-sm);font-size:13px;z-index:999;opacity:0;transition:opacity .25s;pointer-events:none}
#toast.show{opacity:1}

/* ── SCHREIBSCHUTZ-HINWEIS ── */
.ro-notice{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;color:var(--amber);background:var(--amber-bg);border:1px solid rgba(158,107,0,.2);border-radius:var(--r-sm);padding:5px 10px}

/* ── SETTINGS SECTION ── */
.settings-section{margin-bottom:28px}
.settings-section h3{font-family:var(--font-serif);font-size:14px;font-weight:600;color:var(--text);margin-bottom:12px;padding-bottom:6px;border-bottom:1px solid var(--border)}
