:root{--bg:#ffffff;--c:#f7f7fa;--bd:#e0e0e6;--tx:#575756;--mu:#8a8a8a;--r:#ce2128;--rd:#a81b21;--rl:rgba(206,33,40,.08);--gl:#e8e9f0;--bl:#2a5fad;--g:#2e8540;--gd:#d4edda;--y:#d4a017;--yd:rgba(212,160,23,.1)}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Open Sans',Arial,sans-serif;background:var(--gl);color:var(--tx);padding:10px;max-width:1540px;margin:0 auto;font-size:13px}
h1{font-size:1.2em;color:var(--r);font-weight:700;margin-bottom:1px} .sub{color:var(--mu);font-size:.73em;margin-bottom:10px}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
@media(max-width:1000px){.g2{grid-template-columns:1fr}}
.cd{background:var(--bg);border:1px solid var(--bd);border-radius:6px;padding:12px;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.cd h2{font-size:.9em;color:var(--r);font-weight:700;margin-bottom:8px;padding-bottom:5px;border-bottom:2px solid var(--r)}
.rg{display:grid;grid-template-columns:repeat(7,1fr);gap:7px;margin-bottom:10px}
@media(max-width:900px){.rg{grid-template-columns:repeat(4,1fr)}}
.m{background:var(--bg);border:1px solid var(--bd);border-radius:6px;padding:7px;text-align:center;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.m .l{font-size:.64em;color:var(--mu);font-weight:600;text-transform:uppercase;letter-spacing:.3px} .m .v{font-size:1.05em;font-weight:700;color:var(--tx)}
.m .v.g{color:var(--g)} .m .v.r{color:var(--r)} .m .v.b{color:var(--bl)} .m .v.y{color:var(--y)}
.m .d{font-size:.6em;color:var(--mu)}
.pr{display:grid;grid-template-columns:18px 1fr;gap:1px 5px;padding:5px 8px;margin:3px 0;border-radius:6px;background:var(--c);border:1px solid var(--bd);font-size:.77em;align-items:center}
.pr:hover{border-color:#ccc;background:#f2f2f5}
.pr input[type=checkbox]{width:15px;height:15px;accent-color:var(--r);cursor:pointer;grid-row:1/3}
.pr .r1{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.pr .r2{display:flex;align-items:center;gap:6px;font-size:.88em;flex-wrap:wrap}
.pr .nm{font-weight:700;color:var(--tx);white-space:nowrap}
.pr select{background:var(--bg);border:1px solid var(--bd);color:var(--r);font-size:.82em;padding:2px 4px;border-radius:4px;min-width:110px;font-family:inherit}
.pr .rl{color:var(--mu);font-size:.8em}
.pr .ci{width:54px;background:var(--bg);border:1px solid var(--bd);color:var(--bl);text-align:right;padding:2px 4px;border-radius:4px;font-size:.9em;font-family:inherit;font-weight:600}
.pr .ci:focus,.pr select:focus{border-color:var(--r);outline:none;box-shadow:0 0 0 2px rgba(206,33,40,.15)}
.pr .ag{color:var(--mu);font-size:.82em;font-weight:600}
.pr .lbl{color:var(--mu);font-size:.78em}
.pr.off{background:var(--bg);border-color:#eee;opacity:.55} .pr.off .nm{color:#aaa;text-decoration:line-through}
/* Stepper component */
.stp{display:inline-flex;align-items:center;border:1px solid var(--bd);border-radius:4px;overflow:hidden;height:20px;vertical-align:middle}
.stp button{width:18px;height:20px;border:none;background:var(--bg);color:var(--mu);font-weight:700;font-size:.8em;cursor:pointer;padding:0;line-height:1;font-family:inherit}
.stp button:hover{background:var(--rl);color:var(--r)}
.stp button:active{background:var(--r);color:#fff}
.stp .sv{min-width:28px;text-align:center;font-weight:700;font-size:.85em;background:var(--bg);height:20px;line-height:20px;border-left:1px solid var(--bd);border-right:1px solid var(--bd);padding:0 2px;white-space:nowrap}
.stp .sv.c-r{color:var(--r)} .stp .sv.c-b{color:var(--bl)} .stp .sv.c-t{color:var(--tx)}
.cl{font-weight:700;font-size:.7em;color:var(--r);margin:6px 0 1px;text-transform:uppercase;letter-spacing:.4px}
.sr{display:flex;align-items:center;gap:6px;margin:4px 0}
.sr label{font-size:.76em;min-width:120px;font-weight:600;color:var(--tx)}
.sr input[type=range]{flex:1;accent-color:var(--r);cursor:pointer}
.sr .svi{width:74px;background:var(--bg);border:1px solid var(--bd);color:var(--r);text-align:right;padding:2px 5px;border-radius:4px;font-size:.82em;font-family:inherit;font-weight:700}
.sr .svi:focus{border-color:var(--r);outline:none;box-shadow:0 0 0 2px rgba(206,33,40,.15)}
.bt{width:100%;border-collapse:collapse;font-size:.73em}
.bt th{text-align:left;padding:3px 5px;background:var(--r);color:#fff;font-weight:700;font-size:.82em;white-space:nowrap}
.bt td{padding:3px 5px;border-bottom:1px solid var(--gl)}
.bt tr:hover{background:var(--rl)}
.bt .rv{text-align:right;font-variant-numeric:tabular-nums}
.bt .G{background:var(--gl);font-weight:700;color:var(--r)} .bt .S{background:var(--gl);font-weight:700;color:var(--tx)}
.bt .E{background:var(--gd);font-weight:700;color:var(--g)} .bt .N{background:#fde8e8;font-weight:700;color:var(--r)}
.bt .X td{height:3px;border:none;background:transparent}
.fbar{height:10px;border-radius:3px;display:flex;overflow:hidden;width:100%;background:#eee}
.fbar .fx{background:var(--r)} .fbar .vx{background:var(--bl)}
.w{background:var(--yd);border:1px solid var(--y);border-radius:5px;padding:5px 8px;margin-top:4px;font-size:.74em;color:#7a5800}
.w::before{content:'⚠️ '} .w.x{background:#fde8e8;border-color:var(--r);color:var(--rd)} .w.x::before{content:'⛔ '}
.i{background:#e8f0fe;border:1px solid #a8c5f0;border-radius:5px;padding:5px 8px;margin:4px 0;font-size:.74em;color:#1a4a8a}
.o{background:var(--gd);border:1px solid #8bc48f;border-radius:5px;padding:5px 8px;margin-top:4px;font-size:.74em;color:#1a5c24} .o::before{content:'✅ '}
.ca{background:var(--yd);border:1px solid var(--y);border-radius:5px;padding:5px 8px;margin-top:4px;font-size:.74em;color:#7a5800} .ca::before{content:'🔶 '}
.sect{font-size:.7em;color:var(--r);font-weight:700;margin:7px 0 3px;text-transform:uppercase;letter-spacing:.4px;padding:3px 0;border-bottom:2px solid var(--r)}
.add-row{display:flex;gap:4px;margin-top:6px;padding-top:5px;border-top:1px solid var(--bd);flex-wrap:wrap}
.add-row input,.add-row select{background:var(--bg);border:1px solid var(--bd);color:var(--tx);padding:3px 5px;border-radius:4px;font-size:.74em;font-family:inherit}
.add-row button{background:var(--r);color:#fff;border:none;padding:3px 12px;border-radius:4px;cursor:pointer;font-size:.74em;font-weight:700;font-family:inherit}
.add-row button:hover{background:var(--rd)}
.leg{display:inline-flex;gap:10px;font-size:.68em;color:var(--mu);margin:4px 0;font-weight:600}
.leg span{display:flex;align-items:center;gap:3px} .leg span::before{content:'';width:10px;height:10px;border-radius:2px;display:inline-block}
.leg .lf::before{background:var(--r)} .leg .lv::before{background:var(--bl)}
.org{margin-top:10px;overflow-x:auto}
.org-wrap{position:relative;display:inline-block;min-width:100%;padding:10px 20px}
.org-wrap svg{position:absolute;top:0;left:0;pointer-events:none}
.org-nd{position:absolute;background:var(--bg);border:1.5px solid var(--bd);border-radius:6px;padding:2px 4px;text-align:center;font-size:.65em;box-shadow:0 1px 2px rgba(0,0,0,.04);white-space:nowrap}
.org-nd.ac{border-color:var(--r);background:var(--rl)}
.org-nd.off{opacity:.35;border-style:dashed}
.org-nd .on{font-weight:700;font-size:.88em;color:var(--tx)}
.org-nd .ot{font-size:.75em;color:var(--r);font-weight:600;line-height:1.1;white-space:normal;max-width:100px}
.org-nd .oh{font-size:.75em;color:var(--mu)}
.exp-btn{display:inline-flex;align-items:center;gap:4px;background:var(--bg);border:1px solid var(--bd);color:var(--tx);padding:4px 10px;border-radius:4px;cursor:pointer;font-size:.74em;font-weight:600;font-family:inherit;transition:all .15s}
.exp-btn:hover{border-color:var(--r);color:var(--r)}
.exp-btn svg{width:14px;height:14px}
.exp-bar{display:flex;gap:6px;margin-left:auto}
.cg-bar-wrap{margin-top:6px}
.cg-bar-row{display:flex;align-items:center;gap:6px;margin:3px 0;font-size:.72em}
.cg-bar-label{min-width:55px;font-weight:600;text-align:right}
.cg-bar-track{flex:1;height:16px;background:#eee;border-radius:3px;position:relative;overflow:hidden}
.cg-bar-fill{height:100%;border-radius:3px;transition:width .3s;display:flex;align-items:center;justify-content:flex-end;padding-right:4px;font-size:.82em;font-weight:700;color:#fff;min-width:fit-content}
.cg-bar-scale{display:flex;justify-content:space-between;font-size:.62em;color:var(--mu);padding:0 1px}
.sum{font-size:.72em;color:var(--mu);margin-top:3px;font-weight:600}
.hdr{display:flex;align-items:center;gap:10px;margin-bottom:4px;padding-bottom:8px;border-bottom:3px solid var(--r)}
.hdr h1{margin:0;border:none}
/* Miete row */
.mr{display:flex;align-items:center;gap:6px;padding:4px 8px;margin:2px 0;border-radius:5px;background:var(--c);border:1px solid var(--bd);font-size:.76em}
.mr:hover{border-color:#ccc} .mr.off{opacity:.45}
.mr input[type=checkbox]{width:14px;height:14px;accent-color:var(--r);cursor:pointer}
.mr .mn{font-weight:600;min-width:100px} .mr .md{color:var(--mu);font-size:.88em}
/* BWA drill-down */
.bt .clickable{cursor:pointer;user-select:none}
.bt .clickable:hover{background:var(--rl)}
.bt .clickable td:first-child::before{content:'▸ ';color:var(--r);font-size:.8em}
.bt .clickable.open td:first-child::before{content:'▾ '}
.bt .detail td{background:#fafafa;font-size:.88em;padding:2px 5px;border-bottom:1px solid #f0f0f3}
.bt .detail:hover{background:#f3f3f6}
.bt .detail .di{width:46px;text-align:right;border:1px solid var(--bd);border-radius:3px;padding:1px 3px;font-size:.9em;font-family:inherit;font-weight:600;background:var(--bg);color:var(--tx)}
.bt .detail .di:focus{border-color:var(--r);outline:none}
.bt .detail .dt{color:var(--mu);font-size:.9em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:150px}
.bt .add-item{cursor:pointer;color:var(--r);font-weight:600;font-size:.82em}
.bt .add-item:hover{text-decoration:underline}
.del{cursor:pointer;color:var(--bd);font-size:.82em;font-weight:700;padding:0 3px;border-radius:3px;line-height:1;margin-left:auto;flex-shrink:0}
.del:hover{color:var(--r);background:#fee}
.mi-info{border:1px solid transparent;border-radius:3px;padding:1px 4px;font-size:.82em;font-family:inherit;background:transparent;color:var(--mu);width:90px}
.mi-info:hover,.mi-info:focus{border-color:var(--bd);background:var(--bg);outline:none}
/* Tooltip */
.tip{position:relative;display:inline-flex;align-items:center;justify-content:center;width:15px;height:15px;border-radius:50%;background:var(--bd);color:var(--mu);font-size:.6em;font-weight:700;cursor:help;flex-shrink:0}
.tip:hover::after{content:attr(data-t);position:absolute;bottom:calc(100% + 4px);left:50%;transform:translateX(-50%);background:#333;color:#fff;padding:5px 8px;border-radius:4px;font-size:10px;font-weight:400;white-space:pre-line;width:max-content;max-width:260px;z-index:999;line-height:1.4;pointer-events:none;box-shadow:0 2px 8px rgba(0,0,0,.2)}
.tip:hover::before{content:'';position:absolute;bottom:calc(100%);left:50%;transform:translateX(-50%);border:4px solid transparent;border-top-color:#333;z-index:999}
/* Sparten-Bar */
.sp-bar{display:flex;height:6px;border-radius:3px;overflow:hidden;width:100%;min-width:60px;max-width:120px;transition:height .15s,box-shadow .15s}
.sp-bar:hover{height:10px;box-shadow:0 0 0 2px rgba(206,33,40,.2)}
.sp-bar div{height:100%}
.sp-k{background:#ce2128} .sp-c{background:#d4a017} .sp-t{background:#2a5fad} .sp-w{background:#7b61ff} .sp-g{background:#2e8540} .sp-a{background:#bbb}
/* Sparten editor */
.sp-edit{grid-column:1/-1;padding:6px 8px;margin:2px 0 0;background:var(--gl);border-radius:4px;display:flex;flex-wrap:wrap;gap:4px 10px;align-items:center;font-size:.78em}
.sp-edit label{display:flex;align-items:center;gap:3px;min-width:110px}
.sp-edit label span:first-child{font-weight:600;min-width:52px;white-space:nowrap}
.sp-edit input[type=range]{width:60px;accent-color:var(--r)}
.sp-edit .spv{width:28px;text-align:center;font-weight:700;font-size:.9em}
.sp-edit .sp-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}
.sp-edit .sp-sum{font-weight:700;margin-left:auto;padding-left:10px}
/* Investitions-Tabelle (aus JS extrahiert) */
.inv-inp{width:28px;text-align:center;border:1px solid var(--bd);border-radius:3px;padding:1px 2px;font-size:.78em;font-weight:600;font-family:inherit;background:var(--bg)}
.inv-inp:focus{border-color:var(--r);outline:none}
/* Sparten-Tabelle (aus JS extrahiert) */
.sp-inp{width:32px;text-align:center;border:1px solid var(--bd);border-radius:3px;padding:1px 2px;font-size:.82em;font-weight:600;font-family:inherit;background:var(--bg)}
.sp-inp:focus{border-color:var(--r);outline:none}
/* SPA Layout */
.app-shell{display:grid;grid-template-columns:200px 1fr;min-height:100vh}
@media(max-width:768px){.app-shell{grid-template-columns:1fr} .sidebar{position:fixed;bottom:0;left:0;right:0;z-index:100;flex-direction:row;overflow-x:auto;height:auto;padding:0;border-right:none;border-top:2px solid var(--r)} .sidebar .nav-brand,.sidebar .nav-footer{display:none} .nav-item{flex-direction:column;padding:6px 10px;font-size:.65em;min-width:60px;text-align:center} .nav-icon{margin-right:0;font-size:1.2em} .main-content{padding-bottom:60px}}
.sidebar{background:var(--bg);border-right:2px solid var(--r);display:flex;flex-direction:column;padding:8px 0;position:sticky;top:0;height:100vh;overflow-y:auto}
.nav-brand{padding:10px 14px 12px;border-bottom:1px solid var(--bd);margin-bottom:4px;display:flex;flex-direction:column}
.nav-item{display:flex;align-items:center;gap:8px;padding:7px 14px;color:var(--tx);text-decoration:none;font-size:.82em;font-weight:600;border-left:3px solid transparent;transition:all .1s}
.nav-item:hover{background:var(--rl);color:var(--r);border-left-color:var(--r)}
.nav-item.active{background:var(--rl);color:var(--r);border-left-color:var(--r);font-weight:700}
.nav-icon{font-size:1.1em;width:20px;text-align:center;flex-shrink:0}
.nav-footer{margin-top:auto;border-top:1px solid var(--bd);padding-top:4px}
.main-content{padding:10px;max-width:1540px;overflow-y:auto}
/* Login */
.login-box{max-width:360px;margin:80px auto;background:var(--bg);border:1px solid var(--bd);border-radius:8px;padding:30px;box-shadow:0 2px 12px rgba(0,0,0,.08);text-align:center}
.login-box h1{font-size:1.3em;color:var(--r);margin-bottom:2px}
.login-box p{color:var(--mu);font-size:.82em;margin-bottom:20px}
.login-box label{display:block;text-align:left;font-size:.78em;font-weight:600;color:var(--tx);margin-bottom:3px;margin-top:12px}
.login-box input{width:100%;padding:8px 10px;border:1px solid var(--bd);border-radius:4px;font-size:.9em;font-family:inherit;box-sizing:border-box}
.login-box input:focus{border-color:var(--r);outline:none;box-shadow:0 0 0 2px rgba(206,33,40,.15)}
.login-box button{width:100%;padding:9px;margin-top:14px;background:var(--r);color:#fff;border:none;border-radius:4px;font-size:.88em;font-weight:700;cursor:pointer;font-family:inherit}
.login-box button:hover{background:var(--rd)}
.login-err{color:var(--r);font-size:.76em;margin-top:6px;min-height:18px}
.login-code{font-size:1.8em;letter-spacing:8px;text-align:center;font-weight:700;color:var(--r)}
/* Read-only mode */
.readonly-mode input,.readonly-mode select,.readonly-mode button:not(.exp-btn){pointer-events:none;opacity:.6}
.readonly-mode .stp button,.readonly-mode .del,.readonly-mode .add-row{display:none}
.readonly-badge{display:inline-block;font-size:.68em;font-weight:700;color:var(--bl);background:rgba(42,95,173,.08);padding:1px 6px;border-radius:3px;margin-left:6px}
/* Result bar (persistent on all pages) */
.result-bar{display:flex;gap:4px;padding:6px 8px;margin-bottom:10px;font-size:.7em;flex-wrap:wrap;align-items:stretch;border:1px solid var(--bd);border-radius:8px;background:var(--bg);position:sticky;top:0;z-index:40;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.result-bar .rb-group{display:flex;gap:3px;align-items:center;padding:3px 6px;background:var(--c);border:1px solid var(--bd);border-radius:6px;align-self:stretch}
.result-bar .rb-group-title{font-weight:700;color:var(--r);font-size:.85em;margin-right:2px}
.result-bar .rb-item{display:flex;flex-direction:column;align-items:center;padding:0 4px;min-width:50px}
.result-bar .rb-label{color:var(--mu);font-weight:600;font-size:.82em;line-height:1}
.result-bar .rb-value{font-weight:700;font-size:1em;line-height:1.2}
.result-bar .rb-sub{color:var(--mu);font-size:.78em;line-height:1}
.result-bar .rb-sep{color:var(--bd);font-weight:300;font-size:1.2em;margin:0 1px}
/* Card menu (three dots) */
.card-menu-wrap{position:relative;display:flex;justify-content:flex-end;margin-bottom:2px}
.card-menu-btn{background:none;border:none;font-size:1.2em;cursor:pointer;color:var(--mu);padding:0 4px;line-height:1;font-family:inherit;border-radius:3px}
.card-menu-btn:hover{color:var(--r);background:var(--rl)}
.card-menu{display:none;position:absolute;right:0;top:100%;background:var(--bg);border:1px solid var(--bd);border-radius:4px;box-shadow:0 2px 8px rgba(0,0,0,.12);z-index:50;min-width:120px}
.card-menu.open{display:block}
.card-menu button{display:block;width:100%;text-align:left;padding:6px 12px;border:none;background:none;font-size:.82em;font-family:inherit;cursor:pointer;color:var(--tx)}
.card-menu button:hover{background:var(--rl);color:var(--r)}
/* Online users */
.online-dot{width:8px;height:8px;border-radius:50%;display:inline-block;border:1.5px solid var(--bg);cursor:default}
/* Lock banner */
.lock-banner{background:var(--yd);border:1px solid var(--y);border-radius:4px;padding:6px 10px;font-size:.78em;color:#7a5800;margin-bottom:6px;text-align:center}
/* Sync mode select */
.sync-select{font-size:.72em;padding:1px 4px;border:1px solid var(--bd);border-radius:3px;font-family:inherit;color:var(--mu);background:var(--bg)}
