:root,:root[data-theme=dark]{--bg: #0e1117;--bg-2: #151a22;--panel: #171c25;--panel-2: #1e2530;--border: #283041;--text: #e7ebf2;--muted: #8a93a6;--primary: #4f7cff;--primary-ink: #ffffff;--shadow: 0 8px 30px rgba(0, 0, 0, .35)}:root[data-theme=light]{--bg: #f4f6fb;--bg-2: #eef1f7;--panel: #ffffff;--panel-2: #f3f6fb;--border: #e2e7f0;--text: #1b2230;--muted: #6b7384;--primary: #3a63e0;--primary-ink: #ffffff;--shadow: 0 8px 24px rgba(20, 30, 60, .08)}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,sans-serif;background:var(--bg);color:var(--text)}a{color:inherit;text-decoration:none}.muted{color:var(--muted)}.small{font-size:13px}.center{display:flex;align-items:center;justify-content:center;height:100vh}.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(1200px 600px at 50% -10%,var(--bg-2),var(--bg));position:relative}.auth-theme{position:absolute;top:20px;right:20px}.auth-card{width:360px;max-width:90vw;background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:32px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:8px}.auth-card label{font-size:13px;color:var(--muted);margin-top:10px}.auth-sub{margin:0 0 12px}.auth-foot{margin-top:16px;font-size:12px;text-align:center}.brand{font-size:22px;font-weight:800;letter-spacing:.5px}.brand span{color:var(--primary)}.brand-lg{font-size:30px;text-align:center}.app{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--panel);border-right:1px solid var(--border);padding:20px 14px;position:sticky;top:0;height:100vh}.sidebar .brand{padding:0 8px 20px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;color:var(--muted);font-size:14px;margin-bottom:2px}.nav-item:hover{background:var(--panel-2);color:var(--text)}.nav-item.active{background:var(--primary);color:var(--primary-ink)}.nav-icon{width:18px;text-align:center}.main{flex:1;min-width:0}.topbar{height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 28px;border-bottom:1px solid var(--border);background:var(--panel);position:sticky;top:0;z-index:5}.tenant{font-weight:600}.topbar-right{display:flex;align-items:center;gap:16px}.user{text-align:right;line-height:1.1}.user-name{font-size:14px;font-weight:600}.user-role{font-size:11px;color:var(--muted)}.content{padding:28px}.page h1{margin:0 0 22px;font-size:24px}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px;margin-bottom:22px}.card{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:18px;position:relative;overflow:hidden}.card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--primary)}.card.accent-blue:before{background:#4f7cff}.card.accent-violet:before{background:#8b5cf6}.card.accent-teal:before{background:#14b8a6}.card.accent-green:before{background:#22c55e}.card.accent-amber:before{background:#f59e0b}.card.accent-red:before{background:#ef4444}.card-value{font-size:30px;font-weight:800}.card-label{color:var(--muted);font-size:13px;margin-top:4px}.panel{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:20px}.panel h2{margin:0 0 14px;font-size:16px}table{width:100%;border-collapse:collapse;font-size:14px}th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border)}th{color:var(--muted);font-size:12px;text-transform:uppercase}.badge{padding:3px 10px;border-radius:99px;font-size:12px;font-weight:600;background:var(--panel-2);color:var(--muted)}.st-complete{background:#22c55e26;color:#22c55e}.st-in_progress{background:#f59e0b26;color:#f59e0b}.st-overtime{background:#ef444426;color:#ef4444}input{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;padding:11px 13px;color:var(--text);font-size:14px}input:focus{outline:none;border-color:var(--primary)}.btn-primary{margin-top:18px;background:var(--primary);color:var(--primary-ink);border:none;border-radius:10px;padding:12px;font-size:15px;font-weight:600;cursor:pointer}.btn-primary:disabled{opacity:.6;cursor:default}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text);border-radius:9px;padding:8px 12px;cursor:pointer;font-size:13px}.btn-ghost:hover{border-color:var(--primary)}.icon-btn{background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:9px;width:38px;height:38px;cursor:pointer;font-size:16px}.error{background:#ef44441f;color:#ef4444;padding:10px 12px;border-radius:9px;font-size:14px;margin:8px 0}.empty-module{text-align:center;padding:48px 20px}.empty-badge{display:inline-block;background:var(--primary);color:var(--primary-ink);font-size:12px;font-weight:700;padding:4px 12px;border-radius:99px;margin-bottom:14px}.empty-icon{font-size:40px;opacity:.5;margin-bottom:6px}.empty-title{margin:0 0 6px;font-size:18px}.page-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}.page-head h1{margin:0;font-size:24px}.page-head-actions,.filters{display:flex;align-items:center;gap:10px}.hint-banner{background:var(--panel-2);border:1px solid var(--border);border-left:3px solid var(--primary);border-radius:10px;padding:12px 14px;font-size:14px;margin-bottom:16px}select{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;padding:9px 12px;color:var(--text);font-size:14px;cursor:pointer}select:focus{outline:none;border-color:var(--primary)}code{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:12.5px;background:var(--panel-2);padding:2px 7px;border-radius:6px}.btn-primary.slim{margin-top:0;padding:9px 16px;font-size:14px}.btn-ghost.slim,.btn-danger.slim{padding:6px 11px;font-size:13px}.btn-primary:disabled{opacity:.5;cursor:default}.btn-danger{background:transparent;border:1px solid var(--border);color:#ef4444;border-radius:9px;padding:8px 12px;cursor:pointer;font-size:13px}.btn-danger:hover{border-color:#ef4444;background:#ef444414}.icon-btn.xs{width:26px;height:26px;font-size:13px}.panel.no-pad{padding:0;overflow:hidden}.panel.no-pad table{margin:0}.panel-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.panel-head h2{margin:0;font-size:16px}td.strong,.strong{font-weight:600}tr.clickable{cursor:pointer}tr.clickable:hover{background:var(--panel-2)}.row-actions{display:flex;gap:6px;justify-content:flex-end;white-space:nowrap}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#080b128c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:flex-start;justify-content:center;padding:60px 16px;z-index:50;overflow-y:auto}.modal{width:520px;max-width:100%;background:var(--panel);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow)}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border)}.modal-head h2{margin:0;font-size:17px}.modal-body{padding:20px}.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px;border-top:1px solid var(--border)}.form-grid{display:flex;flex-direction:column;gap:14px}.form-grid input,.form-grid select{width:100%}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-size:13px;font-weight:600;color:var(--muted)}.field-hint{font-size:12px;color:var(--muted)}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:12px}.check-row{display:flex;align-items:center;gap:8px;font-size:14px;cursor:pointer}.check-row input,.tag-opt input{width:auto}.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.circuit-card-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.circuit-card-head h3{margin:0;font-size:17px}.chips{display:flex;flex-wrap:wrap;gap:12px;margin:10px 0}.circuit-steps{margin:8px 0 0;padding-left:20px}.circuit-steps li{padding:3px 0}.step-name{font-weight:500}.tag-picker{display:flex;flex-wrap:wrap;gap:8px}.tag-opt{display:inline-flex;align-items:center;gap:6px;padding:7px 11px;border:1px solid var(--border);border-radius:99px;font-size:13px;cursor:pointer}.tag-opt.sel{border-color:var(--primary);background:#4f7cff1a}.order-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.order-list li{display:flex;align-items:center;gap:10px;background:var(--panel-2);border-radius:9px;padding:7px 10px}.ord-num{width:22px;height:22px;border-radius:50%;background:var(--primary);color:var(--primary-ink);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.ord-name{flex:1}.ord-btns{display:flex;gap:4px}.day-picker{display:flex;gap:6px}.day-btn{flex:1;background:var(--bg-2);border:1px solid var(--border);color:var(--muted);border-radius:9px;padding:9px 0;cursor:pointer;font-size:13px}.day-btn.on{background:var(--primary);color:var(--primary-ink);border-color:var(--primary)}.day-pills{display:flex;gap:3px}.day-pill{width:20px;height:20px;border-radius:5px;background:var(--panel-2);color:var(--muted);display:flex;align-items:center;justify-content:center;font-size:11px}.day-pill.on{background:var(--primary);color:var(--primary-ink)}.track{list-style:none;margin:6px 0 0;padding:0;display:flex;flex-direction:column;gap:4px}.track li{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:9px;background:var(--panel-2)}.track-dot{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.track-done .track-dot{background:#22c55e2e;color:#22c55e}.track-miss .track-dot{background:#ef444426;color:#ef4444}.track-name{flex:1;font-weight:500}.alert-list{display:flex;flex-direction:column;gap:8px}.alert-row{display:flex;align-items:center;gap:14px;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:12px 16px}.alert-row.done{opacity:.6}.alert-type{font-size:12px;font-weight:700;padding:5px 11px;border-radius:8px;white-space:nowrap;background:#ef44441f;color:#ef4444}.alert-type.t-ROUND_OVERTIME,.alert-type.t-WRONG_ORDER{background:#f59e0b24;color:#f59e0b}.alert-type.t-UNKNOWN_TAG,.alert-type.t-TAG_NO_CIRCUIT{background:#8b5cf624;color:#8b5cf6}.alert-main{flex:1;min-width:0}.alert-detail{font-size:14px}.analytics-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.analytics-grid .panel:first-child{grid-column:1 / -1}.bar-chart{display:flex;align-items:flex-end;gap:6px;height:180px;padding-top:10px}.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;gap:6px}.bar{width:70%;min-height:2px;background:linear-gradient(180deg,var(--primary),rgba(79,124,255,.4));border-radius:5px 5px 0 0;transition:height .3s}.bar-x{font-size:10px;color:var(--muted)}.hbars{display:flex;flex-direction:column;gap:12px}.hbar-row{display:flex;align-items:center;gap:12px;font-size:13px}.hbar-label{width:110px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hbar-track{flex:1;background:var(--panel-2);border-radius:6px;height:12px;overflow:hidden}.hbar-fill{height:100%;background:var(--primary);border-radius:6px}.hbar-fill.warn{background:#f59e0b}.hbar-val{width:30px;text-align:right;font-weight:600}.kv{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}.kv .strong{font-size:16px}@media(max-width:760px){.analytics-grid{grid-template-columns:1fr}.sidebar{width:64px}}
