@import "https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700&family=DM+Mono:wght@400;500&display=swap";:root{--bg:#f5f4f0;--surface:#fff;--surface2:#eeecea;--border:#00000012;--border-md:#00000021;--text:#18180f;--text2:#5a5a50;--text3:#9e9e92;--blue:#1a5fa8;--blue-bg:#e5f0fb;--blue-light:#b8d4f5;--green:#2d6b0f;--green-bg:#e8f5df;--amber:#7a4800;--amber-bg:#faecd8;--red:#9e2020;--red-bg:#fbe8e8;--purple:#4a3fb0;--purple-bg:#eceafb;--teal:#0a6b52;--teal-bg:#dff5ee;--pink:#8c2252;--pink-bg:#fae8f2;--orange:#8a4000;--orange-bg:#fde8d5;--r-sm:6px;--r-md:10px;--r-lg:14px;--r-xl:20px;--shadow:0 1px 4px #0000000f;--shadow-md:0 4px 16px #00000017;--font:"DM Sans", sans-serif;--mono:"DM Mono", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}input,select,textarea,button{font-family:var(--font)}input:not([type=checkbox]):not([type=radio]):not([type=range]),textarea{border:1.5px solid var(--border-md);border-radius:var(--r-sm);background:var(--surface);color:var(--text);appearance:none;padding:8px 11px;font-size:13px;line-height:1.4;transition:border-color .15s,box-shadow .15s}input:not([type=checkbox]):not([type=radio]):not([type=range]):focus,textarea:focus{border-color:var(--blue);outline:none;box-shadow:0 0 0 3px #1a5fa81a}input::placeholder,textarea::placeholder{color:var(--text3);font-weight:400}input:disabled,textarea:disabled{background:var(--surface2);cursor:not-allowed;opacity:.7}input[type=date]{color:var(--text)}select{border:1.5px solid var(--border-md);border-radius:var(--r-sm);background:var(--surface);color:var(--text);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239e9e92' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding:8px 30px 8px 11px;font-size:13px;line-height:1.4;transition:border-color .15s,box-shadow .15s}select:focus{border-color:var(--blue);outline:none;box-shadow:0 0 0 3px #1a5fa81a}select:disabled{background-color:var(--surface2);cursor:not-allowed;opacity:.7}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:4px}.shell{height:100vh;display:flex;overflow:hidden}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:230px;display:flex;overflow-y:auto}.main{flex-direction:column;flex:1;display:flex;overflow:hidden}.topbar{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;height:52px;padding:0 1.25rem;display:flex}.content{flex:1;padding:1.25rem;overflow-y:auto}.sb-logo{border-bottom:1px solid var(--border);padding:1rem 1rem .75rem}.sb-logo-row{align-items:center;gap:9px;display:flex}.sb-logo-icon{background:var(--blue);border-radius:var(--r-md);flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.sb-logo-icon svg{color:#fff;width:17px;height:17px}.sb-brand{color:var(--text);font-size:12px;font-weight:600}.sb-sub{color:var(--text3);margin-top:1px;font-size:10px}.sb-role{background:var(--blue-bg);border-radius:var(--r-md);margin:.5rem .75rem;padding:.5rem .75rem}.sb-role-label{color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px;font-size:9px;font-weight:600}.sb-role-select{width:100%;color:var(--blue);cursor:pointer;appearance:none;background:0 0;border:none;font-size:11px;font-weight:500}.sb-section{color:var(--text3);text-transform:uppercase;letter-spacing:.09em;padding:.75rem 1rem .25rem;font-size:9px;font-weight:600}.sb-item{cursor:pointer;color:var(--text2);border-left:3px solid #0000;align-items:center;gap:8px;padding:.45rem 1rem;font-size:12px;transition:all .12s;display:flex}.sb-item:hover{background:var(--bg);color:var(--text)}.sb-item.active{background:var(--blue);color:#fff;border-left-color:var(--blue);font-weight:600}.sb-item.locked{opacity:.4;cursor:default;pointer-events:none}.sb-item svg{flex-shrink:0;width:13px;height:13px}.sb-badge{border-radius:10px;margin-left:auto;padding:1px 5px;font-size:8px;font-weight:600}.sb-badge.live{background:var(--green-bg);color:var(--green)}.sb-badge.soon{background:var(--surface2);color:var(--text3)}.sb-footer{border-top:1px solid var(--border);margin-top:auto;padding:.75rem 1rem}.sb-user{align-items:center;gap:8px;display:flex}.sb-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:10px;font-weight:700;display:flex}.tb-left{align-items:center;gap:8px;display:flex}.tb-breadcrumb{color:var(--text3);font-size:11px}.tb-breadcrumb span{color:var(--text);font-weight:500}.tb-right{align-items:center;gap:6px;display:flex}.tb-btn{border:1px solid var(--border-md);border-radius:var(--r-sm);cursor:pointer;width:30px;height:30px;color:var(--text2);background:0 0;justify-content:center;align-items:center;display:flex}.tb-btn svg{width:13px;height:13px}.tb-date{color:var(--text2);background:var(--bg);border:1px solid var(--border);border-radius:var(--r-sm);padding:4px 10px;font-size:11px}.page-hdr{margin-bottom:1.25rem}.page-title{color:var(--text);font-size:20px;font-weight:600}.page-sub{color:var(--text3);margin-top:2px;font-size:12px}.kpi-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;margin-bottom:1.25rem;display:grid}.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow);padding:.875rem 1rem}.kpi-label{color:var(--text3);margin-bottom:3px;font-size:10px;font-weight:500}.kpi-val{color:var(--text);font-size:22px;font-weight:700;font-family:var(--mono);letter-spacing:-.02em}.kpi-delta{margin-top:3px;font-size:10px}.kpi.accent-blue{border-left:3px solid var(--blue)}.kpi.accent-green{border-left:3px solid var(--green)}.kpi.accent-red{border-left:3px solid var(--red)}.kpi.accent-amber{border-left:3px solid #d97706}.up{color:#2d6b0f}.down{color:#9e2020}.neutral{color:var(--text3)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow);margin-bottom:1rem;padding:1rem 1.1rem}.card-title{color:var(--text);margin-bottom:.875rem;font-size:12px;font-weight:600}.two-col{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:10px;margin-bottom:1rem;display:grid}.three-col{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-bottom:1rem;display:grid}.tab-row{background:var(--surface2);border-radius:var(--r-md);flex-wrap:nowrap;gap:2px;width:fit-content;max-width:100%;margin-bottom:1.25rem;padding:3px;display:flex;overflow-x:auto}.tab-btn{border-radius:var(--r-sm);color:var(--text2);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:5px 13px;font-size:11px;transition:all .15s}.tab-btn.active{background:var(--blue);color:#fff;box-shadow:none;font-weight:600}.tbl-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow);margin-bottom:1rem;overflow-x:auto}.tbl{border-collapse:collapse;width:100%;font-size:12px}.tbl th{color:var(--text3);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);background:var(--bg);text-align:left;white-space:nowrap;padding:9px 12px;font-size:10px;font-weight:600}.tbl td{border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;padding:8px 12px}.tbl tr:last-child td{border-bottom:none}.tbl tr:hover td{background:var(--bg)}.badge{white-space:nowrap;border-radius:20px;padding:2px 8px;font-size:10px;font-weight:500;display:inline-block}.bar-wrap{background:var(--surface2);vertical-align:middle;border-radius:2px;height:5px;display:inline-block}.bar-fill{border-radius:2px;height:100%;display:block}.alert-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);align-items:flex-start;gap:10px;margin-bottom:6px;padding:.75rem;display:flex}.alert-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px;margin-top:4px}.fgrid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px;margin-bottom:1rem;display:grid}.fld{flex-direction:column;gap:4px;margin-bottom:12px;display:flex}.fld label{color:var(--text3);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:4px;font-size:10px;font-weight:600;display:flex}.fld input,.fld select,.fld textarea{width:100%}.fld textarea{resize:vertical}.btn{border-radius:var(--r-sm);cursor:pointer;font-size:12px;font-family:var(--font);border:none;padding:6px 16px;font-weight:500;transition:opacity .15s}.btn-primary{background:var(--blue);color:#fff}.btn-primary:hover{opacity:.88}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border-md)}.btn-secondary:hover{background:var(--bg)}.btn-sm{padding:4px 12px;font-size:11px}.chart-wrap{width:100%;position:relative}.legend{color:var(--text2);flex-wrap:wrap;gap:10px;margin-bottom:8px;font-size:11px;display:flex}.legend-item{align-items:center;gap:4px;display:flex}.legend-sq{border-radius:2px;flex-shrink:0;width:9px;height:9px}.prog-row{align-items:center;gap:8px;margin-bottom:8px;display:flex}.prog-label{color:var(--text);flex-shrink:0;width:130px;font-size:11px}.prog-track{background:var(--surface2);border-radius:3px;flex:1;height:5px}.prog-fill{border-radius:3px;height:100%}.prog-val{color:var(--text2);text-align:right;width:40px;font-size:11px;font-family:var(--mono)}.mod-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:8px;margin-bottom:1.25rem;display:grid}.mod-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);cursor:pointer;box-shadow:var(--shadow);flex-direction:column;gap:4px;padding:.875rem 1rem;transition:transform .12s,box-shadow .12s;display:flex}.mod-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.mod-card.live{border-left:3px solid var(--green)}.mod-card.soon{opacity:.7}.mod-icon{border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;margin-bottom:3px;display:flex}.mod-icon svg{width:13px;height:13px}.mod-name{color:var(--text);font-size:11px;font-weight:600;line-height:1.3}.mod-kpis{color:var(--text3);font-size:10px;line-height:1.4}.mod-badge{border-radius:10px;width:fit-content;margin-top:2px;padding:1px 6px;font-size:9px;font-weight:600;display:inline-block}.unit-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px;margin-bottom:1.25rem;display:grid}.unit-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow);padding:.875rem 1rem}.sec-hdr{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.sec-title{color:var(--text3);text-transform:uppercase;letter-spacing:.07em;font-size:10px;font-weight:600}.sec-action{color:var(--blue);cursor:pointer;background:0 0;border:none;padding:0;font-size:11px}.metric-tile{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-md);text-align:center;padding:.75rem}.metric-tile .val{font-size:20px;font-weight:700;font-family:var(--mono)}.metric-tile .lbl{color:var(--text3);margin-top:2px;font-size:10px}.metric-tile .sub{margin-top:1px;font-size:10px}.access-denied{height:400px;color:var(--text3);flex-direction:column;justify-content:center;align-items:center;gap:10px;display:flex}.access-denied svg{opacity:.25;width:48px;height:48px}.loading{text-align:center;color:var(--text3);padding:2rem;font-size:12px}@media (width<=768px){.sidebar{display:none}.content{padding:1rem}}
