:root{--bg-base:#0f172a;--bg-surface:#1e293b;--bg-card:#1e293b;--bg-elevated:#334155;--bg-hover:#3b4963;--text-primary:#f8fafc;--text-body:#e2e8f0;--text-secondary:#cbd5e1;--text-muted:#94a3b8;--text-dim:#64748b;--brand:#e8788a;--brand-hover:#d4667a;--brand-light:#e8788a26;--brand-border:#e8788a4d;--accent:#6366f1;--accent-light:#a5b4fc;--amber:#fbbf24;--orange:#f97316;--green:#4ade80;--red:#f87171;--cyan:#38bdf8;--border:#293548;--border-light:#334155;--table-head-bg:#334155;--table-row-hover:#263449;--table-row-border:#293548;--table-selected-bg:#e8788a14;--shadow-soft:0 14px 36px #0000002e;--focus-ring:#e8788a3d;--color-scheme:dark;--sidebar-w:240px;--header-h:64px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--transition:.2s ease;--control-h:36px}[data-theme=light]{--bg-base:#f1f5f9;--bg-surface:#fff;--bg-card:#fff;--bg-elevated:#e2e8f0;--bg-hover:#cbd5e1;--text-primary:#0f172a;--text-body:#1e293b;--text-secondary:#334155;--text-muted:#64748b;--text-dim:#94a3b8;--border:#cbd5e1;--border-light:#e2e8f0;--table-head-bg:#e2e8f0;--table-row-hover:#f8fafc;--table-row-border:#e2e8f0;--table-selected-bg:#e8788a1a;--shadow-soft:0 14px 36px #0f172a14;--focus-ring:#e8788a3d;--color-scheme:light;color:#1e293b;background:#f1f5f9}[data-theme=graphite]{--bg-base:#111317;--bg-surface:#1c2027;--bg-card:#1c2027;--bg-elevated:#2a3039;--bg-hover:#363e49;--text-primary:#f7f7f8;--text-body:#e5e7eb;--text-secondary:#cbd5e1;--text-muted:#9ca3af;--text-dim:#6b7280;--brand:#f472b6;--brand-hover:#ec4899;--brand-light:#f472b621;--brand-border:#f472b64d;--accent:#94a3b8;--accent-light:#d1d5db;--border:#2f3641;--border-light:#3b4451;--table-head-bg:#252b34;--table-row-hover:#252b34;--table-row-border:#2f3641;--table-selected-bg:#f472b614;--shadow-soft:0 14px 36px #00000038;--focus-ring:#f472b63d}[data-theme=forest]{--bg-base:#0f1f1a;--bg-surface:#173027;--bg-card:#173027;--bg-elevated:#214438;--bg-hover:#2a5748;--text-primary:#f0fdf4;--text-body:#dcfce7;--text-secondary:#bbf7d0;--text-muted:#86efac;--text-dim:#6b8f7a;--brand:#34d399;--brand-hover:#10b981;--brand-light:#34d39921;--brand-border:#34d3994d;--accent:#f59e0b;--accent-light:#fbbf24;--border:#24483c;--border-light:#2d5a4b;--table-head-bg:#214438;--table-row-hover:#1d3a30;--table-row-border:#24483c;--table-selected-bg:#34d39914;--shadow-soft:0 14px 36px #00000038;--focus-ring:#34d3993d}[data-theme=indigo]{--bg-base:#10172b;--bg-surface:#1a2440;--bg-card:#1a2440;--bg-elevated:#29375c;--bg-hover:#354673;--text-primary:#eef2ff;--text-body:#e0e7ff;--text-secondary:#c7d2fe;--text-muted:#a5b4fc;--text-dim:#6f7dac;--brand:#818cf8;--brand-hover:#6366f1;--brand-light:#818cf824;--brand-border:#818cf852;--accent:#38bdf8;--accent-light:#7dd3fc;--border:#263354;--border-light:#354673;--table-head-bg:#29375c;--table-row-hover:#233051;--table-row-border:#263354;--table-selected-bg:#818cf817;--shadow-soft:0 14px 36px #0003;--focus-ring:#818cf83d}[data-theme=contrast]{--bg-base:#050505;--bg-surface:#111;--bg-card:#111;--bg-elevated:#1f1f1f;--bg-hover:#2c2c2c;--text-primary:#fff;--text-body:#f5f5f5;--text-secondary:#e5e5e5;--text-muted:#cbd5e1;--text-dim:#94a3b8;--brand:#ff6b8a;--brand-hover:#fb4770;--brand-light:#ff6b8a29;--brand-border:#ff6b8a75;--accent:#60a5fa;--accent-light:#93c5fd;--border:#3f3f46;--border-light:#52525b;--table-head-bg:#1f1f1f;--table-row-hover:#242424;--table-row-border:#3f3f46;--table-selected-bg:#ff6b8a1a;--shadow-soft:0 14px 36px #00000061;--focus-ring:#ff6b8a4d}[data-theme=rose]{--bg-base:#fff1f2;--bg-surface:#fff;--bg-card:#fff;--bg-elevated:#ffe4e6;--bg-hover:#fecdd3;--text-primary:#3b1420;--text-body:#4a1d2b;--text-secondary:#713447;--text-muted:#9f5b70;--text-dim:#b78191;--brand:#e11d48;--brand-hover:#be123c;--brand-light:#e11d481a;--brand-border:#e11d4842;--accent:#0f766e;--accent-light:#14b8a6;--border:#fecdd3;--border-light:#ffe4e6;--table-head-bg:#ffe4e6;--table-row-hover:#fff7f8;--table-row-border:#ffe4e6;--table-selected-bg:#e11d4814;--shadow-soft:0 14px 36px #88133714;--focus-ring:#e11d4838;--color-scheme:light}[data-theme=light] ::-webkit-scrollbar-track{background:var(--bg-base)}[data-theme=light] ::-webkit-scrollbar-thumb{background:#94a3b8}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-base);color:var(--text-body);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}a{color:inherit;text-decoration:none}::selection{background:var(--brand);color:#fff}select{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='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;padding-right:28px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:#475569;border-radius:3px}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--bg-surface);border-right:1px solid var(--border);z-index:100;flex-direction:column;transition:width .2s;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden}.sidebar--collapsed{width:56px}.sidebar-brand{height:var(--header-h);border-bottom:1px solid var(--border);transition:padding var(--transition);flex-shrink:0;align-items:center;gap:12px;padding:0 20px;display:flex}.sidebar--collapsed .sidebar-brand{justify-content:center;padding:0}.brand-logo{object-fit:contain;flex-shrink:0;width:36px;height:36px}.brand-name{color:var(--text-primary);white-space:nowrap;font-size:18px;font-weight:700}.brand-sub{color:var(--text-dim);white-space:nowrap;font-size:10px}.sidebar-nav{overscroll-behavior:contain;scrollbar-width:none;flex-direction:column;flex:1;gap:2px;min-height:0;padding:16px 10px;display:flex;overflow:hidden auto}.sidebar-nav::-webkit-scrollbar{width:0;height:0}.sidebar--collapsed .sidebar-nav{padding:16px 8px}.nav-item{border-radius:var(--radius-sm);color:var(--text-muted);transition:color var(--transition), background-color var(--transition);white-space:nowrap;border:1px solid #0000;outline:none;grid-template-columns:18px minmax(0,1fr) 14px;align-items:center;gap:10px;padding:10px;font-size:14px;font-weight:600;display:grid;overflow:hidden}.sidebar--collapsed .nav-item{justify-content:center;gap:0;padding:10px;display:flex}.nav-item svg{opacity:.5;width:18px;height:18px;transition:opacity var(--transition);flex-shrink:0;display:block}.nav-item:hover{color:var(--text-body);background:var(--bg-elevated)}.nav-item:hover svg{opacity:.8}.nav-item.active{color:var(--brand);background:var(--brand-light);border-color:var(--brand-border)}.nav-item.active svg{opacity:1;color:var(--brand)}.sidebar--collapsed .nav-label{display:none}.sidebar-footer{border-top:1px solid var(--border);color:var(--text-dim);white-space:nowrap;justify-content:space-between;align-items:center;gap:8px;padding:14px 20px;font-size:11px;display:flex}.sidebar--collapsed .sidebar-footer{justify-content:center;padding:14px 0}.sidebar-nav>.nav-item,.nav-group,.nav-section-btn,.nav-sub,.nav-sub-item{flex-shrink:0}.nav-group{flex-direction:column;display:flex}.nav-section-btn{text-align:left;cursor:pointer;border-radius:var(--radius-sm);width:100%;color:var(--text-muted);white-space:nowrap;transition:color var(--transition), background-color var(--transition);background:0 0;border:1px solid #0000;outline:none;grid-template-columns:18px minmax(0,1fr) 14px;align-items:center;gap:10px;padding:10px;font-family:inherit;font-size:14px;font-weight:600;display:grid;overflow:hidden}.nav-section-btn svg:first-child{opacity:.5;width:18px;height:18px;transition:opacity var(--transition);flex-shrink:0;display:block}.nav-section-btn:hover{color:var(--text-body);background:var(--bg-elevated)}.nav-section-btn:hover svg:first-child{opacity:.8}.nav-section-btn.active{color:var(--brand);background:var(--brand-light);border-color:var(--brand-border)}.nav-section-btn.active svg:first-child{opacity:1;color:var(--brand)}.nav-section-btn .nav-label,.nav-item .nav-label{text-overflow:ellipsis;min-width:0;overflow:hidden}.nav-section-icon{border-radius:var(--radius-sm);color:var(--text-muted);transition:color var(--transition), background-color var(--transition);border:1px solid #0000;outline:none;justify-content:center;align-items:center;padding:10px;display:flex}.nav-item:focus,.nav-section-btn:focus,.nav-section-icon:focus{outline:none}.nav-item:focus-visible,.nav-section-btn:focus-visible,.nav-section-icon:focus-visible{border-color:var(--brand-border)}.nav-section-icon svg{opacity:.5;width:18px;height:18px;display:block}.nav-section-icon.active{color:var(--brand);background:var(--brand-light);border-color:var(--brand-border)}.nav-section-icon.active svg{opacity:1;color:var(--brand)}.nav-collapsed-popup{z-index:9999;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);flex-direction:column;gap:1px;min-width:180px;padding:6px;display:flex;position:fixed;box-shadow:0 8px 24px #0006}.nav-collapsed-popup-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);white-space:nowrap;margin-bottom:4px;padding:4px 10px 6px;font-size:11px;font-weight:600}.nav-collapsed-popup .nav-sub-item{border-radius:var(--radius-sm);padding:7px 10px;overflow:visible}.theme-menu{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-soft);z-index:9999;gap:2px;min-width:172px;padding:6px;display:grid;position:absolute;bottom:36px;right:0}.theme-toggle-btn{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-muted);width:30px;height:30px}.theme-toggle-btn:hover,.theme-toggle-btn:focus-visible{background:var(--brand-light);border-color:var(--brand-border);color:var(--brand)}.theme-toggle-btn svg{color:currentColor}.theme-menu-item{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;grid-template-columns:14px 1fr 14px;align-items:center;gap:8px;padding:7px 8px;font-family:inherit;font-size:12px;display:grid}.theme-menu-item:hover,.theme-menu-item.active{background:var(--brand-light);border-color:var(--brand-border);color:var(--text-primary)}.theme-swatch{border:1px solid #ffffff40;border-radius:999px;width:12px;height:12px}.theme-swatch--dark{background:#e8788a}.theme-swatch--light{background:#f8fafc;border-color:#cbd5e1}.theme-swatch--graphite{background:#2a3039}.theme-swatch--forest{background:#34d399}.theme-swatch--indigo{background:#818cf8}.theme-swatch--contrast{background:#050505}.theme-swatch--rose{background:#e11d48}.nav-sub{flex-direction:column;gap:1px;padding:2px 0 4px 28px;display:flex}.nav-sub-item{border-radius:var(--radius-sm);color:var(--text-muted);transition:all var(--transition);white-space:nowrap;border:1px solid #0000;padding:6px 12px;font-size:13px;font-weight:400;text-decoration:none;display:block;overflow:hidden}.nav-sub-item:hover{color:var(--text-body);background:var(--bg-elevated)}.nav-sub-item.active{color:var(--brand);background:var(--brand-light);border-color:var(--brand-border);font-weight:500}.staff-toolbar{flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:16px;display:flex}.staff-search-wrap{flex:260px;min-width:200px;position:relative}.staff-search-icon{width:15px;height:15px;color:var(--text-dim);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.staff-search{box-sizing:border-box;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);transition:border-color var(--transition);outline:none;padding:9px 36px;font-size:13px}.staff-search::placeholder{color:var(--text-dim)}.staff-search:focus{border-color:var(--brand)}.staff-search-clear{cursor:pointer;color:var(--text-dim);transition:color var(--transition);background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.staff-search-clear:hover{color:var(--text-primary)}.staff-toggle{cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text-secondary);align-items:center;gap:10px;font-size:13px;display:flex}.staff-toggle-track{background:var(--bg-elevated);border:1px solid var(--border);cursor:pointer;border-radius:10px;flex-shrink:0;width:36px;height:20px;transition:background .2s,border-color .2s;position:relative}.staff-toggle-track--on{background:var(--brand);border-color:var(--brand)}.staff-toggle-thumb{background:#fff;border-radius:50%;width:14px;height:14px;transition:transform .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #0000004d}.staff-toggle-track--on .staff-toggle-thumb{transform:translate(16px)}.staff-toggle-label{color:var(--text-secondary);white-space:nowrap;font-size:13px}.staff-code{color:var(--text-secondary);font-family:monospace;font-size:13px}.staff-row--dismissed td{opacity:.4}.staff-row--hidden td{opacity:.5;background:repeating-linear-gradient(135deg,#0000,#0000 8px,#8080800a 8px 16px)}.staff-badge{white-space:nowrap;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.staff-badge--active{color:var(--green);background:#22c55e1f}.staff-badge--dismissed{background:var(--bg-elevated);color:var(--text-dim)}.staff-datepicker-field .drp-wrap{width:100%;display:block}.staff-datepicker-field .drp-trigger{box-sizing:border-box;width:100%}.emp-date-field .drp-wrap{width:100%;display:block}.emp-date-field .drp-trigger{box-sizing:border-box;border-color:var(--border);width:100%}.main{margin-left:var(--sidebar-w);max-width:calc(100vw - var(--sidebar-w));background:var(--bg-base);min-width:0;min-height:100vh;width:calc(100vw - var(--sidebar-w));flex:1;transition:margin-left .2s,max-width .2s;overflow-x:hidden}.app-layout.sidebar-collapsed{--sidebar-w:56px}.page-header{height:var(--header-h);border-bottom:1px solid var(--border);background:var(--bg-surface);z-index:50;justify-content:space-between;align-items:center;gap:16px;padding:0 32px 0 0;display:flex;position:sticky;top:0}.page-header-left{flex-shrink:0;align-items:center;gap:0;display:flex}.page-header-right{align-items:center;margin-left:auto;display:flex}.header-sidebar-toggle{width:28px;height:36px;color:var(--text-dim);cursor:pointer;transition:color var(--transition), background var(--transition);background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-self:center;align-items:center;padding:0;display:flex}.header-sidebar-toggle:hover{color:var(--text-body);background:var(--bg-elevated)}.header-sidebar-toggle svg{width:18px;height:18px}.page-title{color:var(--text-primary);padding-left:20px;font-size:20px;font-weight:600}.page-status{color:var(--text-dim);align-items:center;gap:8px;font-size:13px;display:flex}.status-time{color:var(--text-dim);align-items:center;gap:6px;font-size:13px;display:flex}.status-auto{color:var(--green);letter-spacing:.3px;align-items:center;gap:3px;font-size:10px;display:inline-flex}.status-spinner{border:1.5px solid #4ade804d;border-top-color:var(--green);vertical-align:middle;border-radius:50%;flex-shrink:0;width:8px;height:8px;margin:0;animation:.8s linear infinite spin;display:inline-block}.page-body{padding:28px 32px 48px}.page-body--compact{height:calc(100vh - var(--header-h));flex-direction:column;padding-top:12px;padding-bottom:0;display:flex}.page-body--compact .controls-row{margin-bottom:8px}.page-body--compact .stats-grid{margin-bottom:10px}.page-body--compact .stat-card{padding:8px 14px}.table-page-body{box-sizing:border-box;height:calc(100vh - var(--header-h));flex-direction:column;gap:12px;min-height:0;padding:16px;display:flex;overflow:hidden}.table-page-body .settings-section,.table-page-body .chart-card{flex-shrink:0}.table-page-body>.settings-section:only-child{flex-direction:column;flex:1;min-height:0;margin-bottom:0;display:flex;overflow:hidden}.table-page-body>.settings-section:only-child>.settings-lc-wrap{flex:1;min-height:0;max-height:none}.table-page-body .table-panel{flex-direction:column;flex:1;min-height:0;margin-bottom:0;display:flex;overflow:hidden}.table-toolbar{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);flex-wrap:wrap;align-items:center;gap:10px;padding:10px 12px;display:flex}.table-toolbar--between{justify-content:space-between}.table-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-soft);flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.table-card__header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex}.table-card__title{color:var(--text-secondary);font-size:13px;font-weight:700}.table-scroll{flex:1;min-height:0;overflow:auto}.table-state{color:var(--text-dim);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;min-height:180px;padding:32px 16px;font-size:13px;display:flex}.table-state--error{color:var(--amber)}.table-actions{white-space:nowrap;justify-content:flex-end;align-items:center;gap:6px;display:inline-flex}.icon-btn{justify-content:center;align-items:center;min-width:30px;padding:0;display:inline-flex}.icon-btn svg,.btn svg{flex-shrink:0}.badge{background:var(--bg-elevated);border:1px solid var(--border-light);color:var(--text-muted);white-space:nowrap;border-radius:999px;padding:4px 8px;font-size:11px;font-weight:700;line-height:1;display:inline-flex}.badge--warning{color:var(--amber);background:#fbbf241f;border-color:#fbbf2438}.badge--success{color:var(--green);background:#34d3991f;border-color:#34d39938}.badge--danger{color:var(--red);background:#ef44441f;border-color:#ef444438}.controls-row{flex-wrap:wrap;align-items:flex-end;gap:12px;margin-bottom:24px;display:flex}.control-group{flex-direction:column;gap:4px;display:flex}.control-label{color:var(--text-dim);font-size:12px}input[type=date],.input{height:var(--control-h);border-radius:var(--radius-sm);border:1px solid var(--border-light);background:var(--bg-surface);color:var(--text-body);box-sizing:border-box;color-scheme:var(--color-scheme);outline:none;padding:0 12px;font-family:inherit;font-size:14px}input[type=date]:focus,.input:focus{border-color:var(--brand)}input[type=date]:hover{border-color:var(--bg-hover)}input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.7;width:24px;height:24px;transition:opacity var(--transition), background-color var(--transition);background-color:#0000;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23cbd5e1' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:15px 15px;border-radius:4px}input[type=date]::-webkit-calendar-picker-indicator:hover{background-color:var(--bg-elevated);opacity:1;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23E8788A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E")}input[type=date]:focus::-webkit-calendar-picker-indicator{opacity:1;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23E8788A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E")}input[type=date]::-webkit-datetime-edit{color:var(--text-body)}input[type=date]::-webkit-datetime-edit-fields-wrapper{padding:0}input[type=date]::-webkit-datetime-edit-text{color:var(--text-dim);padding:0 1px}input[type=date]::-webkit-datetime-edit-day-field{color:var(--text-body);border-radius:3px;padding:1px 2px}input[type=date]::-webkit-datetime-edit-month-field{color:var(--text-body);border-radius:3px;padding:1px 2px}input[type=date]::-webkit-datetime-edit-year-field{color:var(--text-body);border-radius:3px;padding:1px 2px}input[type=date]::-webkit-datetime-edit-day-field:focus{background:var(--brand);color:#fff;outline:none}input[type=date]::-webkit-datetime-edit-month-field:focus{background:var(--brand);color:#fff;outline:none}input[type=date]::-webkit-datetime-edit-year-field:focus{background:var(--brand);color:#fff;outline:none}input[type=number]{-moz-appearance:textfield}input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.btn{height:var(--control-h);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);box-sizing:border-box;border:none;align-items:center;gap:6px;padding:0 16px;font-family:inherit;font-size:14px;font-weight:500;display:inline-flex}.btn-primary{background:var(--brand);color:#fff}.btn-primary:hover{background:var(--brand-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{background:var(--bg-elevated);color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-body)}.btn-ghost:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.icon-btn{width:var(--control-h);flex-shrink:0;justify-content:center;padding:0}.icon-btn svg{width:16px;height:16px}.mode-toggle{border:1px solid var(--border-light);border-radius:var(--radius-sm);flex-shrink:0;display:flex;overflow:hidden}.mode-btn{width:var(--control-h);height:var(--control-h);border-radius:var(--radius-sm);background:var(--bg-elevated);color:var(--text-dim);cursor:pointer;transition:all var(--transition);border:none;justify-content:center;align-items:center;display:flex}.mode-btn svg{width:15px;height:15px}.mode-btn:hover{background:var(--bg-hover);color:var(--text-body)}.mode-btn--active{background:var(--brand);color:#fff}.mode-btn--active:hover{background:var(--brand-hover);color:#fff}.btn-group{flex-wrap:wrap;gap:8px;display:flex}.search-input{border-radius:var(--radius-sm);border:1px solid var(--border-light);background:var(--bg-surface);min-width:200px;color:var(--text-body);outline:none;flex:1;padding:8px 12px;font-family:inherit;font-size:14px}.search-input:focus{border-color:var(--brand)}.search-input::placeholder{color:var(--text-dim)}.filter-select{border-radius:var(--radius-sm);border:1px solid var(--border-light);background:var(--bg-surface);color:var(--text-body);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='%23cbd5e1' 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;outline:none;padding:8px 36px 8px 12px;font-family:inherit;font-size:14px}.filter-select:focus{border-color:var(--brand)}.hero-card{background:linear-gradient(135deg, var(--brand), #c0607a);border-radius:var(--radius-lg);margin-bottom:24px;padding:24px 28px}.hero-card-inner{justify-content:space-between;align-items:center;gap:16px;display:flex}.hero-label{color:#ffffffd9;align-items:center;gap:8px;margin-bottom:4px;font-size:14px;display:flex}.hero-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:12px;height:12px;margin:0;animation:.8s linear infinite spin;display:inline-block}.hero-value{color:#fff;font-size:36px;font-weight:700}.refresh-btn{color:#fff;cursor:pointer;width:44px;height:44px;transition:background var(--transition), transform var(--transition);background:#ffffff26;border:1px solid #ffffff40;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.refresh-btn:hover{background:#ffffff40}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}.refresh-btn svg{width:20px;height:20px}.refresh-btn.spinning svg{animation:.6s ease-in-out spin}.stats-grid{flex-wrap:wrap;gap:12px;margin-bottom:24px;display:flex}.stat-card{background:var(--bg-surface);border-radius:var(--radius-md);flex:1;min-width:120px;padding:14px 20px}.stat-card--clickable{cursor:pointer;transition:background var(--transition), box-shadow var(--transition)}.stat-card--clickable:hover{background:var(--bg-elevated);box-shadow:0 0 0 1px var(--border-light)}.stat-label{color:var(--text-dim);text-transform:uppercase;margin-bottom:4px;font-size:11px}.stat-value{color:var(--text-body);font-size:20px;font-weight:700}.stat-value.amber{color:var(--amber)}.stat-value.orange{color:var(--orange)}.stat-value.green{color:var(--green)}.list-section{flex-direction:column;gap:8px;display:flex}.list-row{background:var(--bg-surface);border-radius:var(--radius-md);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.list-row-name{color:var(--text-secondary);font-size:15px}.list-row-value{color:var(--accent-light);font-size:17px;font-weight:600}.hero-card--clickable{cursor:pointer;transition:filter var(--transition), box-shadow var(--transition);position:relative}.hero-card--clickable:hover{filter:brightness(1.06);box-shadow:0 4px 24px #e8788a40}.hero-card--expanded{border-radius:var(--radius-lg) var(--radius-lg) var(--radius-sm) var(--radius-sm)}.hero-expand-hint{color:#fff9;align-items:center;display:flex;position:absolute;bottom:10px;right:16px}.comp-row{flex-wrap:wrap;align-items:stretch;gap:12px;margin-bottom:24px;display:flex}.comp-card{background:var(--bg-surface);border-radius:var(--radius-md);border-left:3px solid var(--brand);flex:1;min-width:140px;padding:16px 20px}.comp-card--week{border-left-color:var(--accent)}.comp-card--checkable{cursor:pointer;transition:background var(--transition), border-color var(--transition)}.comp-card--checkable:hover,.comp-card--checked{background:var(--bg-elevated)}.comp-card-header{justify-content:space-between;align-items:center;margin-bottom:2px;display:flex}.comp-checkbox{border:1.5px solid var(--border-light);width:18px;height:18px;transition:all var(--transition);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.comp-checkbox--checked{border-color:#0000}.comp-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;font-size:12px}.comp-period{color:var(--text-muted);margin-bottom:8px;font-size:11px}.comp-value{color:var(--text-body);font-size:22px;font-weight:700;line-height:1.1}.comp-delta{margin-top:6px;font-size:13px;font-weight:600}.comp-delta--up{color:var(--green)}.comp-delta--down{color:var(--red)}.comp-delta--neutral{color:var(--text-dim)}.comp-week{background:var(--bg-surface);border-radius:var(--radius-md);border-left:3px solid var(--accent);flex:1;min-width:140px;padding:16px 20px}.comp-week-nav{align-items:center;gap:6px;margin:6px 0 8px;display:flex}.comp-week-label{text-align:center;color:var(--text-secondary);white-space:nowrap;flex:1;font-size:13px}.week-nav-btn{background:var(--bg-elevated);border:1px solid var(--border-light);color:var(--text-muted);cursor:pointer;transition:all var(--transition);border-radius:6px;justify-content:center;align-items:center;padding:4px 6px;display:flex}.week-nav-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-body)}.week-nav-btn:disabled{opacity:.35;cursor:default}.charts-grid{gap:16px;margin-bottom:24px;display:grid}.chart-card{background:var(--bg-surface);border-radius:var(--radius-lg);padding:24px}.chart-card-title{color:var(--text-primary);margin-bottom:16px;font-size:16px;font-weight:600}.chart-card-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.context-period-bar{flex-wrap:wrap;align-items:center;gap:4px;margin-bottom:16px;display:flex}.context-period-switcher{flex-wrap:wrap;gap:4px;display:flex}.context-period-btn{border:1px solid var(--border-light);color:var(--text-dim);cursor:pointer;transition:all var(--transition);background:0 0;border-radius:6px;padding:3px 10px;font-size:12px}.context-period-btn:hover{color:var(--text-body);border-color:var(--text-muted)}.context-period-btn--active{background:var(--bg-elevated);border-color:var(--accent);color:var(--accent-light)}.settings-panel{background:var(--bg-surface);border-radius:var(--radius-md);margin-bottom:16px;overflow:hidden}.settings-header{cursor:pointer;justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.settings-header:hover{background:var(--bg-elevated)}.settings-title{color:var(--accent-light);font-size:14px;font-weight:600}.settings-toggle{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:18px}.settings-body{flex-wrap:wrap;gap:16px;padding:4px 20px 16px;display:flex}.store-card{background:var(--bg-base);border-radius:var(--radius-sm);flex:1;min-width:200px;padding:12px 16px}.store-card-name{color:var(--text-secondary);margin-bottom:6px;font-size:13px}.settings-tabs{border-bottom:1px solid var(--border);gap:0;margin-bottom:28px;display:flex}.settings-tab{color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 20px;font-size:14px;font-weight:500}.settings-tab:hover{color:var(--text-body)}.settings-tab--active{color:var(--brand);border-bottom-color:var(--brand)}.settings-section{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border);margin-bottom:24px;padding:28px 32px}.settings-section-header{border-bottom:1px solid var(--border);align-items:center;gap:10px;margin-bottom:20px;padding-bottom:16px;display:flex}.settings-section-title{color:var(--text-primary);margin:0;font-size:16px;font-weight:600}.settings-section-hint{color:var(--text-dim);margin-bottom:20px;font-size:13px;line-height:1.5}.settings-inner-tabs{gap:4px;margin-bottom:20px;display:flex}.settings-inner-tab{background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all var(--transition);padding:5px 14px;font-size:13px;font-weight:500}.settings-inner-tab:hover{color:var(--text-body);border-color:var(--text-dim)}.settings-inner-tab--active{background:var(--bg-elevated);border-color:var(--accent);color:var(--accent-light)}.settings-lc-wrap{border-radius:var(--radius-sm);border:1px solid var(--border);max-height:calc(100vh - 220px);overflow:auto}.settings-addr-input{border-radius:var(--radius-sm);border:1px solid var(--border-light);background:var(--bg-base);width:100%;color:var(--text-body);transition:border-color var(--transition);outline:none;padding:7px 12px;font-family:inherit;font-size:13px}.settings-addr-input:focus{border-color:var(--brand)}.settings-addr-input::placeholder{color:var(--text-dim)}.geo-search-btn{white-space:nowrap;align-items:center;gap:5px;display:flex}.geo-dropdown{z-index:200;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-md);position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:hidden;box-shadow:0 8px 24px #0006}.geo-result{text-align:left;border:none;border-bottom:1px solid var(--border);width:100%;color:var(--text-secondary);cursor:pointer;transition:background var(--transition);background:0 0;align-items:flex-start;gap:8px;padding:10px 14px;font-family:inherit;font-size:13px;line-height:1.4;display:flex}.geo-result:last-child{border-bottom:none}.geo-result:hover{background:var(--bg-hover);color:var(--text-primary)}.geo-result svg{margin-top:2px}.geo-coords{color:var(--text-dim);align-items:center;gap:4px;margin-top:4px;font-size:11px;transition:color .15s;display:flex}.geo-coords[style*=cursor]{-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.geo-coords[style*=cursor]:hover{color:var(--brand)}.geo-coords--pending{color:var(--accent-light)}.geo-coords--pending[style*=cursor]:hover{color:var(--brand)}.weather-badge{border:1px solid var(--border);border-radius:10px;align-items:center;gap:3px;padding:1px 6px;font-size:10px;display:inline-flex}.weather-badge--ok{color:var(--green);border-color:var(--green);background:color-mix(in srgb, var(--green) 10%, transparent)}.weather-badge--empty{color:var(--text-dim)}.weather-sync-btn{cursor:pointer;color:var(--text-dim);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:2px;transition:color .15s,background .15s;display:inline-flex}.weather-sync-btn:hover:not(:disabled){color:var(--brand);background:var(--bg-hover)}.weather-sync-btn:disabled{opacity:.4;cursor:default}.weather-stat{background:var(--bg-elevated);border-radius:var(--radius-md);min-width:110px;padding:12px 18px}.weather-stat-val{color:var(--text-primary);font-size:22px;font-weight:700;line-height:1.2}.weather-stat-label{color:var(--text-dim);margin-top:2px;font-size:11px}.weather-progress-wrap{background:var(--bg-elevated);border-radius:var(--radius-md);margin-bottom:16px;padding:12px 16px}.weather-progress-bar{background:var(--bg-hover);border-radius:3px;height:6px;overflow:hidden}.weather-progress-fill{background:var(--brand);border-radius:3px;min-width:4px;height:100%;transition:width .4s}.geo-no-results{z-index:200;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-md);color:var(--text-dim);padding:12px 14px;font-size:13px;position:absolute;top:calc(100% + 4px);left:0;right:0;box-shadow:0 8px 24px #0006}.geo-row td{vertical-align:top}.store-card-input{border:1px solid var(--border-light);background:var(--bg-surface);width:80px;color:var(--text-body);text-align:right;border-radius:6px;outline:none;padding:6px 10px;font-family:inherit;font-size:14px}.store-card-input:focus{border-color:var(--brand)}.store-card-suffix{color:var(--text-dim);margin-left:4px;font-size:13px}.table-meta{color:var(--text-dim);margin-bottom:12px;font-size:13px}.table-wrap{border-radius:var(--radius-md);overflow:hidden auto}.table-wrap--fill{flex:1;min-height:0;margin-bottom:16px}.data-table{border-collapse:collapse;background:var(--bg-surface);width:100%}.data-table th{text-align:left;background:var(--bg-elevated);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;z-index:2;padding:12px 16px;font-size:12px;font-weight:600;position:sticky;top:0}.data-table td{border-top:1px solid var(--bg-base);color:var(--text-secondary);padding:10px 16px;font-size:14px}.data-table tbody tr{cursor:pointer;transition:background var(--transition)}.data-table tbody tr:hover td{background:var(--bg-elevated)}.data-table .num{text-align:right;font-variant-numeric:tabular-nums}.sort-th{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.sort-th:hover{color:var(--text-body)}.sort-arrow{color:var(--brand);font-weight:700}.cat-header td{text-transform:uppercase;letter-spacing:.04em;cursor:default;box-shadow:inset 3px 0 0 var(--brand);padding:8px 16px;font-size:13px;font-weight:700;background:var(--bg-elevated)!important;color:var(--text-primary)!important;border-top:1px solid var(--border)!important;border-bottom:1px solid var(--border)!important}.sub-row td{cursor:default;font-size:12px;background:var(--table-row-hover)!important;color:var(--text-muted)!important}.expand-btn{color:var(--accent-light);cursor:pointer;background:0 0;border:none;padding:2px 4px;font-size:12px;line-height:1}.tc-table-section{flex-direction:column;min-height:0;display:flex}.tc-table-wrap{max-height:calc(90vh - 350px);overflow:auto}.tc-table{border-collapse:collapse;width:100%}.tc-table th{z-index:2;text-align:left;background:var(--bg-elevated);color:var(--text-muted);text-transform:uppercase;padding:8px 12px;font-size:11px;font-weight:600;position:sticky;top:0}.tc-table td{color:var(--text-secondary);border-top:1px solid #293548;padding:6px 12px;font-size:13px}.tc-table tr:hover td{background:#293548}.tc-labor-table{table-layout:fixed;min-width:1040px}.tc-labor-table .tc-labor-name-col,.tc-labor-table .tc-labor-name-cell{white-space:normal;overflow-wrap:anywhere;word-break:normal;width:440px;max-width:440px;line-height:1.35}.tc-labor-table .tc-labor-workshop-col{white-space:normal;overflow-wrap:anywhere;width:130px;max-width:130px;line-height:1.35}.tc-labor-table .tc-labor-section-col{white-space:normal;overflow-wrap:anywhere;width:180px;max-width:180px;line-height:1.35}.tc-labor-table .tc-labor-unit-col{width:58px;max-width:58px}.tc-labor-table .tc-labor-amount-col{width:78px;max-width:78px}.tc-labor-table .tc-labor-rate-col{width:72px;max-width:72px}.tc-labor-table .tc-labor-sum-col{width:86px;max-width:86px}.tc-unlink-btn{width:22px;min-width:22px;height:22px;color:var(--red);vertical-align:middle;justify-content:center;align-items:center;margin-left:8px;padding:0}.tc-unlink-btn svg{display:block}.tc-num{color:var(--text-dim);text-align:center;width:72px;min-width:72px;max-width:72px;font-size:12px}.tc-amount{text-align:right;font-variant-numeric:tabular-nums}.tc-cost{text-align:right;font-variant-numeric:tabular-nums;color:var(--amber)}.tc-labor{text-align:right;font-variant-numeric:tabular-nums;color:var(--orange)}.tc-table th.tc-num,.tc-table th.tc-amount,.tc-table th.tc-cost,.tc-table th.tc-labor{text-align:right}.tc-table th.tc-num{text-align:center}.tc-level0 td{background:#1a2744}.tc-semi{color:var(--accent-light);cursor:pointer;font-weight:600}.tc-semi:hover{text-decoration:underline}.tc-badge{vertical-align:middle;border:1px solid #0000;border-radius:3px;margin-left:6px;padding:1px 6px;font-size:10px;font-weight:600;display:inline-block}.tc-badge-pf{background:color-mix(in srgb, var(--amber) 14%, transparent);color:color-mix(in srgb, var(--amber) 72%, var(--text-primary));border-color:color-mix(in srgb, var(--amber) 28%, transparent)}.tc-badge-raw{background:color-mix(in srgb, var(--green) 14%, transparent);color:color-mix(in srgb, var(--green) 72%, var(--text-primary));border-color:color-mix(in srgb, var(--green) 28%, transparent)}.tc-badge-labor{background:color-mix(in srgb, var(--orange) 14%, transparent);color:color-mix(in srgb, var(--orange) 72%, var(--text-primary));border-color:color-mix(in srgb, var(--orange) 28%, transparent)}.tc-badge-dish{background:color-mix(in srgb, var(--cyan) 14%, transparent);color:color-mix(in srgb, var(--cyan) 72%, var(--text-primary));border-color:color-mix(in srgb, var(--cyan) 28%, transparent)}.tc-total-row td{border-top:2px solid var(--accent);font-weight:700;background:var(--bg-base)!important}.tc-subtotal-row td{border-top:1px dashed var(--border-light);background:0 0!important}.modal-overlay{z-index:1000;background:#000000bf;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--bg-surface);border-radius:var(--radius-lg);width:100%;max-width:1300px;max-height:90vh;padding:28px;position:relative;overflow-y:auto}.modal::-webkit-scrollbar{width:6px}.modal::-webkit-scrollbar-thumb{background:#475569;border-radius:3px}.modal h2{color:var(--text-primary);margin-bottom:4px;font-size:22px;font-weight:600}.modal h3{color:var(--accent-light);margin:20px 0 8px;font-size:15px;font-weight:600}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:28px;line-height:1;position:absolute;top:12px;right:16px}.modal-close:hover{color:var(--text-primary)}.modal-subtitle{color:var(--text-dim);margin-bottom:16px;font-size:13px}.modal-stats{flex-wrap:wrap;gap:16px;margin-bottom:20px;display:flex}.modal-stat{background:var(--bg-base);border-radius:var(--radius-md);flex:1;min-width:120px;padding:14px 20px}.modal-stat-label{color:var(--text-dim);text-transform:uppercase;margin-bottom:4px;font-size:11px}.modal-stat-value{color:var(--text-body);font-size:20px;font-weight:700}.modal-stat-value.amber{color:var(--amber)}.modal-stat-value.orange{color:var(--orange)}.modal-stat-value.green{color:var(--green)}.spinner{border:2px solid #475569;border-top-color:var(--brand);vertical-align:middle;border-radius:50%;width:16px;height:16px;margin-right:8px;animation:.8s linear infinite spin;display:inline-block}.error-msg{color:var(--red);background:var(--bg-surface);border-radius:var(--radius-md);margin-bottom:16px;padding:16px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.kpi-grid{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px;display:grid}@media (width<=1100px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.kpi-grid{grid-template-columns:1fr 1fr}}.kpi-card{background:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--border);flex-direction:column;gap:6px;padding:18px 20px;display:flex}.kpi-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;font-size:11px}.kpi-value{color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:22px;font-weight:700;line-height:1.2}.kpi-footer{align-items:center;gap:6px;min-height:20px;display:flex}.kpi-delta{align-items:center;gap:3px;font-size:13px;font-weight:600;display:flex}.kpi-delta.up{color:var(--green)}.kpi-delta.down{color:var(--red)}.kpi-delta.neutral{color:var(--text-muted)}.kpi-prev{color:var(--text-dim);font-size:12px}.charts-grid-2{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;display:grid}@media (width<=900px){.charts-grid-2{grid-template-columns:1fr}}.chart-card-full{grid-column:1/-1}.compare-toggle{color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;font-size:13px;display:flex}.compare-toggle input[type=checkbox]{width:15px;height:15px;accent-color:var(--brand);cursor:pointer}.dept-expand-wrap{border-radius:var(--radius-md);overflow-x:auto}.dept-expand-table{border-collapse:collapse;background:var(--bg-surface);white-space:nowrap;width:100%;font-size:13px}.dept-expand-table thead tr:first-child th{background:var(--bg-elevated);text-align:center;border-bottom:1px solid var(--border);color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;padding:8px 12px;font-size:11px;font-weight:600}.dept-expand-table thead tr:last-child th{background:var(--bg-elevated);text-align:right;border-bottom:2px solid var(--border);color:var(--text-dim);padding:5px 10px;font-size:11px;font-weight:500}.dept-expand-table td{border-top:1px solid var(--bg-base);color:var(--text-secondary);padding:8px 10px}.dept-expand-table tbody tr:hover td{background:var(--bg-elevated)}.de-name{background:var(--bg-elevated);z-index:2;min-width:160px;max-width:220px;position:sticky;left:0;text-align:left!important}.de-name-cell{text-align:left;background:inherit;z-index:1;text-overflow:ellipsis;max-width:220px;position:sticky;left:0;overflow:hidden;color:var(--text-body)!important}.dept-expand-table tbody tr:hover .de-name-cell{background:var(--bg-elevated)}.de-num{text-align:right;font-variant-numeric:tabular-nums;color:var(--accent-light)!important}.de-pct{text-align:right;font-size:12px;color:var(--text-dim)!important}.de-group{border-top:2px solid var(--border-light)}.de-group--cur{border-top-color:var(--brand)!important}.de-group--week{border-top-color:var(--accent)!important}.de-group-period{color:var(--text-dim);text-transform:none;letter-spacing:0;margin-top:1px;font-size:10px;font-weight:400}.dept-table{border-collapse:collapse;background:var(--bg-surface);border-radius:var(--radius-md);width:100%;overflow:hidden}.dept-table th{text-align:left;background:var(--bg-elevated);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:10px 16px;font-size:11px;font-weight:600}.dept-table th.num{text-align:right}.dept-table td{border-top:1px solid var(--bg-base);color:var(--text-secondary);padding:10px 16px;font-size:14px}.dept-table td.num{text-align:right;font-variant-numeric:tabular-nums;color:var(--accent-light)}.dept-table td.pct{text-align:right;color:var(--text-dim);font-size:12px}.dept-table td.delta-up{text-align:right;color:var(--green);font-size:13px;font-weight:600}.dept-table td.delta-down{text-align:right;color:var(--red);font-size:13px;font-weight:600}.dept-table tbody tr:hover td{background:var(--bg-elevated)}@media (width<=1024px){.header-sidebar-toggle{display:none}:root{--sidebar-w:56px}.sidebar:not(.sidebar--collapsed){width:56px}.sidebar:not(.sidebar--collapsed) .brand-text,.sidebar:not(.sidebar--collapsed) .nav-label,.sidebar:not(.sidebar--collapsed) .sidebar-footer{display:none}.sidebar:not(.sidebar--collapsed) .sidebar-brand{justify-content:center;padding:0}.sidebar:not(.sidebar--collapsed) .nav-item{justify-content:center;gap:0;padding:10px}.page-body{padding:20px 16px 40px}.page-header{padding:0 16px}}@media (width<=768px){:root{--sidebar-w:0px}.sidebar{border-right:none;border-top:1px solid var(--border);flex-direction:row;width:100%;height:56px;inset:auto 0 0}.sidebar-brand,.sidebar-footer{display:none}.sidebar-nav{scrollbar-gutter:auto;flex-direction:row;justify-content:space-around;align-items:center;width:100%;padding:0;overflow:auto hidden}.nav-item{border-radius:0;flex-direction:column;gap:2px;padding:6px 8px;font-size:10px;background:0 0!important;border:none!important}.nav-item.active{color:var(--brand)}.nav-label{display:block!important}.main{width:100vw;max-width:100vw;margin-bottom:56px;margin-left:0}.page-body{padding:16px 12px 24px}.page-header{padding:0 12px}.hero-value{font-size:28px}}.refresh-btn--pending{background:#ffffff47;box-shadow:0 0 0 2px #fff6}.drp-wrap{position:relative}.drp-trigger{height:var(--control-h);background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-body);cursor:pointer;transition:border-color var(--transition), background var(--transition);white-space:nowrap;align-items:center;gap:8px;padding:0 12px;font-size:14px;display:flex}select.drp-trigger{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='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;padding:0 28px 0 12px}.drp-trigger:hover{border-color:var(--text-dim);background-color:var(--bg-hover)}.drp-trigger--open{border-color:var(--brand)}.drp-trigger--pending{border-color:var(--amber)}.drp-trigger--pending .drp-label{color:var(--amber)}.drp-icon-cal{width:14px;height:14px;color:var(--text-dim);flex-shrink:0}.drp-label{font-variant-numeric:tabular-nums}.drp-dot{background:var(--amber);border-radius:50%;flex-shrink:0;width:6px;height:6px}.drp-chevron{width:14px;height:14px;color:var(--text-dim);transition:transform var(--transition);flex-shrink:0}.drp-chevron--up{transform:rotate(180deg)}.drp-popover{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-md);z-index:200;background:var(--bg-surface);width:272px;padding:12px;position:absolute;top:calc(100% + 8px);left:auto;right:0;box-shadow:0 16px 48px #00000080}.revenue-compare-page{z-index:150;position:relative}.revenue-compare-page .drp-popover{z-index:10050}.rdp-root{color:var(--text-body);font-family:inherit;position:relative}.rdp-months{gap:16px;display:flex}.rdp-month{width:100%}.rdp-nav{pointer-events:none;z-index:1;justify-content:space-between;align-items:center;height:30px;display:flex;position:absolute;top:0;left:0;right:0}.rdp-nav-btn{pointer-events:all;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;width:28px;height:28px;transition:all var(--transition);justify-content:center;align-items:center;display:flex;color:var(--text-body)!important}.rdp-nav-btn:hover{background:var(--bg-hover);color:#fff!important}.rdp-nav-btn svg,.rdp-nav-btn svg *{fill:var(--text-body)!important;stroke:none!important}.rdp-nav-btn:hover svg,.rdp-nav-btn:hover svg *{fill:#fff!important;stroke:none!important}.rdp-caption{justify-content:center;align-items:center;height:30px;margin-bottom:10px;padding:0 34px;display:flex}.rdp-caption-label{display:none}.rdp-dropdowns{align-items:center;gap:6px;display:flex}.rdp-dropdown-root{position:relative}.rdp-dropdown{appearance:none;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-sm);height:28px;color:var(--text-body);cursor:pointer;transition:border-color var(--transition), background-color var(--transition);color-scheme:var(--color-scheme);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='%23cbd5e1' 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 6px center;background-repeat:no-repeat;outline:none;padding:0 24px 0 10px;font-family:inherit;font-size:13px;font-weight:600}.rdp-dropdown:hover{border-color:var(--text-dim);background-color:var(--bg-hover)}.rdp-dropdown:focus{border-color:var(--brand)}.rdp-head-row{grid-template-columns:repeat(7,1fr);margin-bottom:4px;display:grid}.rdp-head-cell{text-align:center;color:var(--text-dim);text-transform:uppercase;padding:4px 0;font-size:11px;font-weight:600}.rdp-tbody{flex-direction:column;gap:1px;display:flex}.rdp-row{grid-template-columns:repeat(7,1fr);display:grid}.rdp-cell{justify-content:center;align-items:center;height:36px;display:flex}.rdp-day{border-radius:var(--radius-sm);cursor:pointer;width:34px;height:34px;color:var(--text-body);transition:all var(--transition);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;display:flex}.rdp-day:hover:not(:disabled){background:var(--bg-elevated);color:var(--text-primary)}.rdp-day--today{color:var(--brand);font-weight:700}.rdp-day--outside{color:var(--text-dim);opacity:.4}.rdp-day--disabled{color:var(--text-dim);opacity:.3;cursor:not-allowed}.rdp-day--hidden{visibility:hidden}.rdp-day--selected,.rdp-day--range-start,.rdp-day--range-end{border-radius:var(--radius-sm);font-weight:600;background:var(--brand)!important;color:#fff!important}.rdp-day--range-middle{background:var(--brand-light);color:var(--brand);border-radius:0}.rdp-cell:has(.rdp-day--range-start){border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.rdp-cell:has(.rdp-day--range-end){border-radius:0 var(--radius-sm) var(--radius-sm) 0}.rdp-cell:has(.rdp-day--range-middle){background:var(--brand-light)}.drp-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;margin-top:12px;padding-top:12px;display:flex}.drp-cancel{height:30px;padding:0 12px;font-size:13px}.btn-sm{height:28px;padding:4px 12px;font-size:12px}.btn-danger{color:var(--red);background:#f8717126;border:1px solid #f871714d}.btn-danger:hover{background:#f8717140}.db-sync-bar{background:var(--bg-surface);border-radius:var(--radius-sm);border:1px solid var(--border-light);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;padding:8px 14px;display:flex}.db-sync-info{color:var(--text-dim);align-items:center;gap:6px;font-size:12px;display:flex}.db-sync-label b{color:var(--text-secondary)}.db-sync-actions{align-items:center;gap:10px;display:flex}.db-sync-btn{align-items:center;gap:5px;font-size:12px;display:flex}.db-sync-ok{color:var(--green);align-items:center;gap:4px;font-size:12px;display:flex}.db-sync-err{color:var(--red);font-size:12px}.db-sync-badge{border-radius:12px;align-items:center;gap:3px;margin-left:8px;padding:1px 7px;font-size:11px;font-weight:600;display:inline-flex}.db-sync-badge--ok{color:var(--green);background:#4ade801f}.db-sync-badge--warn{color:var(--amber);background:#fbbf241f}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-panel{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border-light);flex-direction:column;width:640px;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 24px 60px #00000080}.modal-panel--wide{width:min(780px,96vw)}.modal-panel--confirm{width:min(460px,94vw)}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 24px 14px;display:flex}.modal-header-left{align-items:center;gap:10px;display:flex}.modal-title{color:var(--text-primary);font-size:16px;font-weight:700}.modal-close{color:var(--text-dim);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:6px;padding:2px 6px;font-size:18px;line-height:1}.modal-close:hover{background:var(--bg-elevated);color:var(--text-body)}.modal-close--corner{z-index:1;padding:4px 8px;font-size:16px;position:absolute;top:14px;right:16px}.modal-tabs{border-bottom:1px solid var(--border);gap:0;padding:0 24px;display:flex}.modal-tab{color:var(--text-dim);cursor:pointer;transition:color var(--transition);background:0 0;border:none;padding:10px 16px;font-family:inherit;font-size:13px;font-weight:500;position:relative}.modal-tab:hover{color:var(--text-secondary)}.modal-tab--active{color:var(--brand)}.modal-tab--active:after{content:"";background:var(--brand);border-radius:2px 2px 0 0;height:2px;position:absolute;bottom:-1px;left:0;right:0}.modal-body{flex:1;padding:20px 24px;overflow-y:auto}.modal-hint{color:var(--text-dim);margin-bottom:16px;font-size:13px}.modal-loading{color:var(--text-dim);align-items:center;gap:8px;padding:16px 0;font-size:13px;display:flex}.modal-db-warn{color:var(--amber);border-radius:var(--radius-sm);background:#fbbf2414;border:1px solid #fbbf2433;align-items:center;gap:6px;margin-top:12px;padding:8px 12px;font-size:12px;display:flex}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:14px 24px 18px;display:flex}.confirm-modal-text{color:var(--text-secondary);margin-bottom:12px;font-size:13px;line-height:1.45}.confirm-modal-card{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-base);grid-template-columns:auto 1fr;align-items:start;gap:12px;padding:12px;display:grid}.confirm-modal-code{color:var(--text-dim);font-family:var(--font-mono,monospace);min-width:48px;font-size:12px;line-height:1.4}.confirm-modal-name{color:var(--text-primary);overflow-wrap:anywhere;font-size:14px;font-weight:700;line-height:1.35}.confirm-modal-meta{color:var(--text-dim);margin-top:4px;font-size:12px;line-height:1.4}.lc-table-wrap{border-radius:var(--radius-sm);border:1px solid var(--border-light);max-height:520px;overflow:auto}.lc-table{border-collapse:collapse;width:100%;font-size:13px}.lc-table>thead>tr>th{background:var(--bg-elevated);color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;text-align:center;z-index:3;box-shadow:0 1px 0 var(--border);padding:8px 4px;font-size:11px;font-weight:600;position:sticky;top:0}.lc-table>thead>tr>th.num{text-align:center}.lc-table>tbody>tr.lc-row>td{border-top:1px solid var(--border);color:var(--text-secondary);vertical-align:middle;text-align:center;padding:5px 4px}.lc-table>tbody>tr.lc-row>td:first-child{text-align:left;padding-left:12px}.lc-table>tbody>tr.lc-row>td:last-child{padding-right:8px}.lc-table>tbody>tr.lc-row:hover>td{background:var(--bg-elevated)}.lc-table>tbody>tr.lc-row--clickable{cursor:pointer}.lc-actions{white-space:nowrap;justify-content:flex-end;align-items:center;gap:6px;width:100%;display:flex}.lc-actions--compact{gap:6px}.lc-action-btn{background:var(--bg-surface);border:1px solid var(--border-light);color:var(--text-secondary)}.lc-action-btn:hover{background:var(--bg-hover);border-color:var(--text-dim);color:var(--text-body)}.lc-table>tbody>tr.lc-row:hover .lc-action-btn{background:var(--bg-surface);border-color:var(--border-light)}.lc-table>tbody>tr.lc-row:hover .lc-action-btn:hover{background:var(--bg-hover);border-color:var(--text-dim)}.lc-delete-btn{width:28px;color:var(--red);justify-content:center;padding:0}.lc-delete-btn:hover{color:var(--red)}.lc-table .drp-wrap{text-align:left;color:var(--text-body)}.lc-table>tbody>tr.lc-row:hover .drp-trigger{border-color:var(--text-dim)}.lc-dept{color:var(--text-body);white-space:nowrap;font-weight:500}.lc-meta{color:var(--text-dim);font-size:12px}.lc-current-pct{text-align:right}.production-motivation-table{table-layout:fixed;min-width:0}.production-motivation-table__name{white-space:normal;overflow-wrap:anywhere;word-break:normal;line-height:1.35}.production-motivation-table__workshop,.production-motivation-table__section{white-space:normal}.pct-badge{color:var(--brand);background:#e8788a1f;border-radius:12px;padding:2px 8px;font-size:12px;font-weight:600;display:inline-block}.pct-none{color:var(--text-dim)}.lc-input{border:1px solid var(--border-light);background:var(--bg-elevated);width:72px;color:var(--text-body);border-radius:6px;outline:none;padding:5px 8px;font-family:inherit;font-size:13px}.lc-input:focus{border-color:var(--brand);outline:2px solid var(--brand-border)}.lc-input--date{width:130px}.lc-input--prominent{border:2px solid var(--border-light);background:var(--bg-base);width:80px;color:var(--text-primary);padding:7px 10px;font-size:14px;font-weight:500}.lc-input--prominent:focus{border-color:var(--brand);outline:none}.input-field{border-radius:var(--radius-sm);border:1px solid var(--border-light);background:var(--bg-base);height:36px;color:var(--text-primary);box-sizing:border-box;padding:6px 12px;font-family:inherit;font-size:13px}.input-field:focus{border-color:var(--brand);outline:2px solid var(--brand-border)}select.input-field{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='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.stock-table{border-collapse:collapse;width:100%;font-size:13px}.stock-table th{z-index:1;background:var(--bg-surface);color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;-webkit-user-select:none;user-select:none;padding:10px 12px;font-size:11px;font-weight:600;position:sticky;top:0}.stock-table td{border-bottom:1px solid var(--border);color:var(--text-body);padding:8px 12px}.stock-table tbody tr:hover{background:var(--bg-hover)}.stock-table tbody tr:last-child td{border-bottom:none}.app-table,.data-table,.lc-table,.stock-table,.dept-table{background:var(--bg-surface);border-collapse:separate;border-spacing:0;width:100%;font-size:13px}.app-table th,.data-table th,.lc-table>thead>tr>th,.stock-table th,.dept-table th{background:var(--table-head-bg);border-bottom:1px solid var(--table-row-border);box-shadow:none;color:var(--text-muted);letter-spacing:0;text-align:left;text-transform:uppercase;-webkit-user-select:none;user-select:none;white-space:nowrap;z-index:3;padding:10px 12px;font-size:11px;font-weight:700;line-height:1.25;position:sticky;top:0}.app-table td,.data-table td,.lc-table>tbody>tr.lc-row>td,.stock-table td,.dept-table td{border-bottom:1px solid var(--table-row-border);color:var(--text-secondary);vertical-align:middle;border-top:0;padding:8px 12px;font-size:13px;line-height:1.35}.app-table tbody tr:hover td,.data-table tbody tr:hover td,.lc-table>tbody>tr.lc-row:hover>td,.stock-table tbody tr:hover td,.stock-table tbody tr:hover,.dept-table tbody tr:hover td{background:var(--table-row-hover)}.app-table th.num,.app-table td.num,.data-table .num,.lc-table th.num,.lc-table td.num,.stock-table th.num,.stock-table td.num,.dept-table th.num,.dept-table td.num{font-variant-numeric:tabular-nums;text-align:right}.app-table .is-center,.lc-table .is-center{text-align:center}.app-table .is-muted,.lc-meta,.pct-none{color:var(--text-dim)}.settings-lc-wrap.table-scroll,.lc-table-wrap.table-scroll,.table-wrap.table-scroll{border:1px solid var(--border);border-radius:var(--radius-md);flex:1;min-height:0;max-height:none}.settings-section.table-panel>.settings-lc-wrap,.chart-card.table-panel>.table-scroll,.table-card>.table-scroll{margin:0}
