@font-face{font-family:Roboto;font-style:normal;font-weight:400;font-display:swap;src:url(/assets/roboto-latin-400-normal-BqEyEoaF.woff2) format("woff2")}@font-face{font-family:Roboto;font-style:normal;font-weight:500;font-display:swap;src:url(/assets/roboto-latin-500-normal-7RbcRiD8.woff2) format("woff2")}@font-face{font-family:Roboto;font-style:normal;font-weight:700;font-display:swap;src:url(/assets/roboto-latin-700-normal-BZpUvMxY.woff2) format("woff2")}:root{--bg: #f4f7f8;--surface: #ffffff;--border: #e2e8ea;--text: #1c2b33;--text-muted: #5c6d75;--primary: #0094B7;--primary-strong: #007695;--primary-soft: #e0f2f6;--accent-green: #72BF44;--danger: #a63a38;--radius: 10px;--shadow: 0 1px 3px rgb(12 45 56 / .08);--font: "Roboto", system-ui, -apple-system, "Segoe UI", sans-serif;--chart-1: #0094B7;--chart-2: #55972F;--chart-3: #3F6FB5;--chart-4: #F15A22;--chart-5: #A63A38;--chart-6: #B08600;--seq-1: #e0f2f6;--seq-2: #b3dfe9;--seq-3: #66bfd4;--seq-4: #26a3c2;--seq-5: #0094B7;--radius-lg: 14px;--shadow-hero: 0 6px 16px rgb(0 148 183 / .25);--nav-height: 56px}*{box-sizing:border-box}body{margin:0;font-family:var(--font);background:var(--bg);color:var(--text)}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.layout{display:flex;min-height:100vh}.sidebar{width:230px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);padding:20px 12px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column}.sidebar .brand{font-weight:700;font-size:18px;padding:0 10px 18px;color:var(--primary);letter-spacing:.01em}.sidebar a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;color:var(--text-muted);text-decoration:none;font-size:14px;margin-bottom:2px}.sidebar a svg{flex-shrink:0}.sidebar a.active{background:var(--primary-soft);color:var(--primary);font-weight:600}.sidebar a:hover:not(.active){background:var(--bg)}.sidebar-footer{margin-top:auto;padding-top:14px;border-top:1px solid var(--border);display:grid;gap:10px}.sidebar-user{display:flex;align-items:center;gap:10px;padding:0 4px;min-width:0}.sidebar-avatar{width:32px;height:32px;flex-shrink:0;border-radius:50%;background:var(--primary-soft);color:var(--primary);display:grid;place-items:center;font-weight:700;font-size:14px}.sidebar-username{font-size:13px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-logout{display:flex;align-items:center;gap:8px;width:100%;text-align:left;border:1px solid var(--border);background:var(--surface);border-radius:8px;padding:8px 12px;font:inherit;font-size:13px;cursor:pointer;color:var(--text-muted)}.sidebar-logout svg{flex-shrink:0}.sidebar-logout:hover{border-color:var(--primary);color:var(--primary)}.main{flex:1;display:flex;flex-direction:column;min-width:0}.header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 24px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.header-titles{min-width:0}.header h1{font-size:18px;font-weight:600;margin:0}.header-sub{font-size:12px;color:var(--text-muted);margin:2px 0 0;font-variant-numeric:tabular-nums}.header-right{display:flex;align-items:center;gap:16px}.content{padding:24px;display:grid;gap:20px}.header-logout{display:none;align-items:center;justify-content:center;flex-shrink:0;width:36px;height:36px;padding:0;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text-muted);cursor:pointer}.header-logout svg{width:18px;height:18px}.header-logout:hover{border-color:var(--primary);color:var(--primary)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;box-shadow:0 1px 3px #0c2d3814,0 4px 12px #0c2d380a}.kpi-card .label{font-size:12px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.kpi-card .value{font-size:26px;font-weight:700;margin-top:6px;font-variant-numeric:tabular-nums}.kpi-card .hint{font-size:12px;color:var(--text-muted);margin-top:4px;font-variant-numeric:tabular-nums}.kpi-card .delta-row{display:flex;align-items:baseline;gap:7px;margin-top:10px;flex-wrap:wrap}.kpi-card .delta{display:inline-flex;align-items:baseline;gap:3px;font-size:12px;font-weight:600;font-variant-numeric:tabular-nums;border-radius:999px;padding:2px 9px;white-space:nowrap}.kpi-card .delta.up{color:var(--chart-2);background:color-mix(in srgb,var(--chart-2) 14%,transparent)}.kpi-card .delta.down{color:var(--danger);background:color-mix(in srgb,var(--danger) 12%,transparent)}.kpi-card .delta.flat{color:var(--text-muted);background:color-mix(in srgb,var(--text-muted) 12%,transparent)}.kpi-card .delta-caption{font-size:12px;color:var(--text-muted)}.kpi-card.hero{grid-column:span 2;display:flex;flex-direction:column;background:linear-gradient(135deg,var(--primary),var(--primary-strong));border-color:transparent;color:#fff;box-shadow:var(--shadow-hero)}.kpi-card.hero .label{color:#ffffffd9}.kpi-card.hero .value{color:#fff}.kpi-card.hero .hint{color:#fffc}.kpi-card.hero .delta,.kpi-card.hero .delta.up,.kpi-card.hero .delta.down{background:#ffffff40;color:#fff}.kpi-card.hero .delta-caption{color:#ffffffd9}.kpi-card .spark{margin-top:auto;padding-top:14px}.sparkline{display:block;width:100%}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;box-shadow:0 1px 3px #0c2d3814,0 4px 12px #0c2d380a;min-width:0;animation:fadeSlideIn .25s ease-out}.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 0 14px}.card h2{font-size:15px;font-weight:500;margin:0}.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:20px}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@media (prefers-reduced-motion: reduce){.card{animation:none}}.donut-wrap{display:flex;align-items:center;gap:24px;flex-wrap:wrap}.donut-chart{position:relative;flex:1 1 200px;min-width:180px}.donut-center{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;align-content:center;pointer-events:none;text-align:center;gap:2px}.donut-total{font-size:22px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.donut-total-label{font-size:12px;color:var(--text-muted)}.donut-legend{list-style:none;margin:0;padding:0;display:grid;gap:10px;flex:1 1 160px;min-width:150px}.donut-legend li{display:flex;align-items:center;gap:8px;font-size:13px}.donut-legend .mark{width:12px;height:12px;border-radius:3px;flex-shrink:0}.donut-legend .name{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.donut-legend .pct{margin-left:auto;color:var(--text-muted);font-weight:600;font-variant-numeric:tabular-nums}.heatmap-weekdays{display:grid;grid-template-columns:repeat(7,16px);gap:3px;margin-bottom:6px;font-size:10px;color:var(--text-muted);text-align:center}.heatmap-grid{display:grid;grid-template-columns:repeat(7,16px);gap:3px}.heatmap-cell{width:16px;height:16px;border-radius:3px}.heatmap-legend{display:flex;align-items:center;gap:4px;margin-top:12px;font-size:11px;color:var(--text-muted)}.heatmap-legend .heat-sample{width:14px;height:14px;border-radius:3px}.table-wrap{overflow-x:auto}table.data{width:100%;border-collapse:collapse;font-size:13px}table.data th,table.data td{padding:8px 10px;border-bottom:1px solid var(--border);text-align:left}table.data th{font-weight:500;color:var(--text-muted)}table.data td.num,table.data th.num{text-align:right;font-variant-numeric:tabular-nums}table.data tbody tr:hover{background:var(--bg)}.bar-list{display:grid;gap:12px}.bar-row{display:grid;grid-template-columns:1fr auto;gap:8px 12px;align-items:baseline}.bar-row .bar-label{font-size:13px;color:var(--text);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bar-row .bar-value{font-size:13px;color:var(--text-muted);font-variant-numeric:tabular-nums}.bar-track{grid-column:1 / -1;height:8px;background:var(--bg);border-radius:4px;overflow:hidden}.bar-fill{height:100%;border-radius:4px}.dim-select{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted)}.dim-select select{border:1px solid var(--border);border-radius:8px;padding:6px 10px;font:inherit;color:var(--text);background:var(--surface);cursor:pointer}.state{padding:40px;text-align:center;color:var(--text-muted);font-size:14px}.state.error{color:var(--danger)}.state .retry{display:inline-block;margin-top:12px;border:1px solid var(--danger);background:var(--surface);color:var(--danger);border-radius:8px;padding:7px 14px;font:inherit;font-size:13px;cursor:pointer}.state .retry:hover{background:var(--danger);color:#fff}.skeleton{display:grid;gap:10px;padding:20px 0}.skeleton .line{height:12px;border-radius:6px;background:linear-gradient(90deg,var(--bg) 25%,var(--border) 37%,var(--bg) 63%);background-size:400% 100%;animation:skeleton 1.4s ease infinite}.skeleton .line.short{width:45%}@keyframes skeleton{0%{background-position:100% 50%}to{background-position:0 50%}}@media (prefers-reduced-motion: reduce){.skeleton .line{animation:none}}.range-picker{display:flex;align-items:center;gap:12px;font-size:13px;flex-wrap:wrap}.range-inputs{display:flex;align-items:center;gap:8px}.range-inputs input{border:1px solid var(--border);border-radius:8px;padding:7px 10px;font:inherit;color:var(--text)}.date-presets{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.preset{border:1px solid var(--border);background:var(--surface);border-radius:8px;padding:6px 10px;font:inherit;font-size:12px;cursor:pointer;color:var(--text-muted)}.preset:hover:not(.active){background:var(--primary-soft);border-color:var(--primary);color:var(--primary)}.preset.active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:500}.login{display:grid;place-items:center;min-height:100vh;padding:24px}.login form{width:100%;max-width:340px;display:grid;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:32px 28px}.login .brand{font-size:28px;font-weight:700;color:var(--primary);text-align:center;margin:0;letter-spacing:.01em}.login .subtitle{text-align:center;color:var(--text-muted);font-size:13px;margin:-6px 0 6px}.login label{font-size:12px;font-weight:500;color:var(--text-muted);display:grid;gap:6px}.login input{padding:10px 12px;border-radius:8px;border:1px solid var(--border);font:inherit;color:var(--text)}.login button{padding:11px 12px;border-radius:8px;border:none;background:var(--primary);color:#fff;font:inherit;font-weight:600;cursor:pointer;margin-top:4px}.login button:hover:not(:disabled){background:var(--primary-strong)}.login button:disabled{opacity:.6;cursor:default}.page-placeholder{color:var(--text-muted)}.page-placeholder .card{display:grid;gap:6px}.page-placeholder .badge{justify-self:start;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--primary);background:var(--primary-soft);border-radius:6px;padding:3px 8px}.bottom-nav{display:none}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;flex:1;height:100%;padding:6px 2px;text-decoration:none;color:var(--text-muted);font-size:11px;font-weight:500;min-width:0}.bottom-nav-item svg{flex-shrink:0}.bottom-nav-item span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.bottom-nav-item.active{color:var(--primary);position:relative}.bottom-nav-item.active:before{content:"";position:absolute;top:0;right:6px;bottom:0;left:6px;border-radius:var(--radius);background:var(--primary-soft);z-index:-1}@media (max-width: 1100px){.sidebar{width:64px;padding:20px 8px}.sidebar .brand{display:none}.sidebar a{justify-content:center;padding:10px 0}.sidebar .nav-label,.sidebar .user-name{display:none}.sidebar-user{justify-content:center;padding:0}.sidebar-logout{justify-content:center;padding:8px 0}}@media (max-width: 767px){.sidebar{display:none}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:calc(var(--nav-height) + env(safe-area-inset-bottom));background:var(--surface);border-top:1px solid var(--border);justify-content:space-around;align-items:center;z-index:30;padding-bottom:env(safe-area-inset-bottom)}.content{padding:16px;padding-bottom:calc(var(--nav-height) + env(safe-area-inset-bottom) + 24px);gap:16px}.header{flex-wrap:wrap;gap:10px;padding:12px 16px}.header-right{width:100%;flex-wrap:wrap;justify-content:flex-end}.range-picker{width:100%}.header-logout{display:inline-flex}.kpi-grid{grid-template-columns:1fr 1fr;gap:10px}.kpi-card.hero{grid-column:1 / -1}.kpi-card{padding:12px}.kpi-card .value{font-size:22px}.grid-2{grid-template-columns:1fr;gap:16px}}
