:root{--ink:#17202a;--muted:#667085;--line:#d8e1ea;--panel:#fff;--bg:#eef3f7;--brand:#0f766e;--blue:#2563eb;--danger:#b91c1c;--ok:#047857}*{box-sizing:border-box}body{margin:0;font-family:Segoe UI,Inter,Roboto,Arial,sans-serif;background:var(--bg);color:var(--ink)}.shell{display:grid;grid-template-columns:280px 1fr;min-height:100vh;transition:grid-template-columns .18s ease}.shell.sidebar-collapsed{grid-template-columns:86px 1fr}aside{background:#111827;color:#e5edf5;padding:28px 20px;display:flex;flex-direction:column;gap:34px;overflow:hidden}.sidebar-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.sidebar-toggle{width:34px;height:34px;display:grid;place-items:center;flex:0 0 34px;padding:0;border-color:#374151;background:#1f2937;color:#e5edf5;font-size:22px;line-height:1}.brand{display:flex;gap:12px;align-items:center;min-width:0}.brand span{display:grid;place-items:center;width:46px;height:46px;flex:0 0 46px;border-radius:8px;background:linear-gradient(135deg,var(--brand),var(--blue));font-weight:900}.brand strong{display:block;font-size:18px}.brand small{display:block;color:#9ca3af;margin-top:4px}.shell.sidebar-collapsed aside{padding:28px 14px}.shell.sidebar-collapsed .sidebar-head{justify-content:center;align-items:center;flex-direction:column}.shell.sidebar-collapsed .brand div{display:none}.shell.sidebar-collapsed nav a{width:58px;text-align:center;padding:12px 6px;font-size:0}.shell.sidebar-collapsed nav a::first-letter{font-size:15px}nav{display:grid;gap:8px}nav a{color:#cbd5e1;text-decoration:none;padding:12px 14px;border-radius:8px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}nav a:hover,nav a.active{background:#1f2937;color:#fff}main{padding:34px;overflow:auto}.top{margin-bottom:24px}.top.split{display:flex;justify-content:space-between;align-items:flex-end;gap:20px}.top p{text-transform:uppercase;color:var(--brand);font-weight:900;font-size:12px;letter-spacing:.08em;margin:0 0 8px}h1{font-size:38px;line-height:1.05;margin:0}h2{font-size:20px;margin:0 0 18px}.grid{display:grid;gap:20px}.grid.two{grid-template-columns:minmax(320px,.85fr) minmax(420px,1.4fr);align-items:start}.panel{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:22px;box-shadow:0 12px 30px rgba(15,23,42,.06)}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}.stats div{background:#fff;border:1px solid var(--line);border-left:4px solid var(--brand);border-radius:8px;padding:18px}.stats b{display:block;font-size:24px}.stats span{color:var(--muted)}label{display:grid;gap:7px;color:#334155;font-weight:800;margin-bottom:14px}input,select,textarea{width:100%;border:1px solid #cbd5e1;border-radius:8px;padding:11px 12px;font:inherit;background:#fff;color:var(--ink)}textarea{min-height:88px;resize:vertical}.check{display:flex;align-items:center;gap:10px}.check input{width:auto}button{border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:8px;padding:10px 14px;font-weight:900;cursor:pointer}.primary{background:var(--brand);border-color:var(--brand);color:#fff}.small{padding:7px 10px;font-size:13px}table{width:100%;border-collapse:collapse}th{text-align:left;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--line);padding:10px}td{border-bottom:1px solid #edf2f7;padding:12px 10px;vertical-align:middle}td small{display:block;color:var(--muted);margin-top:3px}.actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.actions form{display:inline}.actions a{font-weight:900;color:var(--blue);text-decoration:none}.pill{display:inline-flex;border-radius:999px;background:#e0f2fe;color:#075985;padding:4px 9px;font-size:12px;font-weight:900}.flash{padding:12px 14px;border-radius:8px;margin-bottom:18px;font-weight:900}.flash.success{background:#dcfce7;color:#166534}.flash.error{background:#fee2e2;color:#991b1b}.log{border-left:4px solid var(--line);padding:10px 0 10px 12px;margin-bottom:12px}.log b{text-transform:uppercase;font-size:12px}.log span{display:block;margin:4px 0}.log small{color:var(--muted)}.log.error{border-color:var(--danger)}.log.info{border-color:var(--ok)}@media(max-width:980px){.shell,.shell.sidebar-collapsed{grid-template-columns:1fr}.shell.sidebar-collapsed aside{padding:22px}.shell.sidebar-collapsed .sidebar-head{align-items:flex-start;flex-direction:row}.shell.sidebar-collapsed .brand div{display:block}.shell.sidebar-collapsed nav a{width:auto;text-align:left;padding:12px 14px;font-size:inherit}.grid.two,.stats{grid-template-columns:1fr}.top.split{align-items:flex-start;flex-direction:column}h1{font-size:30px}main{padding:22px}table{display:block;overflow-x:auto;white-space:nowrap}}
.login-screen{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at 20% 20%,rgba(15,118,110,.18),transparent 32%),linear-gradient(135deg,#0f172a,#1e293b 55%,#0f766e)}.login-card{width:min(420px,100%);background:#fff;border:1px solid var(--line);border-radius:8px;padding:28px;box-shadow:0 24px 70px rgba(2,6,23,.35)}.login-brand{color:var(--ink);margin-bottom:24px}.login-brand small{color:var(--muted)}.login-card button{width:100%;margin-top:4px}
.stack{display:grid;gap:20px}.usage-summary{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:18px}.usage-summary div{border:1px solid var(--line);border-radius:8px;padding:12px;background:#f8fafc}.usage-summary strong{display:block;font-size:18px}.usage-summary span{color:var(--muted);font-size:13px}.chart{border:1px solid var(--line);border-radius:8px;background:#f8fafc;padding:14px 10px 8px;overflow-x:auto}.chart-bars{height:190px;display:flex;align-items:flex-end;gap:7px;min-width:680px}.chart-day{height:100%;flex:1;display:flex;align-items:flex-end;justify-content:center;gap:2px;position:relative;padding-bottom:22px}.bar{width:7px;min-height:2px;border-radius:4px 4px 0 0;display:block}.bar.down{background:var(--brand)}.bar.up{background:var(--blue)}.chart-day small{position:absolute;bottom:0;font-size:10px;color:var(--muted)}.chart-legend{display:flex;gap:16px;margin-top:12px;color:var(--muted);font-weight:800;font-size:13px}.chart-legend span{display:flex;align-items:center;gap:7px}.chart-legend i{width:10px;height:10px;border-radius:3px;display:inline-block}.down-key{background:var(--brand)}.up-key{background:var(--blue)}
.button-link{border:1px solid var(--line);background:#fff;color:var(--blue);border-radius:8px;padding:9px 12px;font-weight:900;text-decoration:none;display:inline-flex;align-items:center;white-space:nowrap}
th[data-sort]{cursor:pointer;user-select:none}th[data-sort]:hover{color:var(--brand)}th[data-direction="asc"]::after{content:" ^"}th[data-direction="desc"]::after{content:" v"}

.actions button[name="reset_usage"],.actions form button{white-space:nowrap}
.danger-panel{margin-top:20px;border-color:#fecaca}.danger{background:#b91c1c;border-color:#b91c1c;color:#fff}.muted{color:var(--muted);line-height:1.45}

main,.grid,.grid>*,.panel{min-width:0}.grid.two{grid-template-columns:minmax(0,.85fr) minmax(0,1.4fr)}.customers-layout{grid-template-columns:minmax(360px,.9fr) minmax(0,1.1fr)}.table-panel{overflow:auto;max-height:calc(100vh - 178px);overscroll-behavior:contain}.table-panel table{min-width:760px}.managed-panel table{min-width:900px}.managed-panel .actions{min-width:220px}.button-link,.actions button{white-space:nowrap}.panel{max-width:100%}.chart-panel{overflow:hidden}.chart{max-width:100%}
.shell.sidebar-collapsed aside{overflow:visible;z-index:5}.shell.sidebar-collapsed nav{align-items:center}.shell.sidebar-collapsed nav a{position:relative;display:grid;place-items:center;width:58px;height:46px;padding:0;font-size:0;overflow:visible;text-overflow:clip}.shell.sidebar-collapsed nav a::first-letter{font-size:0}.shell.sidebar-collapsed nav a::before{content:attr(data-icon);font-size:20px;line-height:1;color:#dbeafe}.shell.sidebar-collapsed nav a::after{content:attr(data-label);position:absolute;left:calc(100% + 12px);top:50%;transform:translateY(-50%);z-index:20;display:none;width:max-content;max-width:220px;padding:8px 10px;border-radius:8px;background:#0f172a;color:#fff;border:1px solid #334155;box-shadow:0 12px 28px rgba(2,6,23,.28);font-size:13px;font-weight:800;white-space:nowrap}.shell.sidebar-collapsed nav a:hover::after,.shell.sidebar-collapsed nav a:focus-visible::after{display:block}.shell.sidebar-collapsed nav a.active::before{color:#fff}
@media(max-width:980px){.customers-layout{grid-template-columns:1fr}.table-panel{max-height:none}.table-panel table,.managed-panel table{min-width:760px}.shell.sidebar-collapsed nav a::after{display:none}}
.panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.panel-head h2{margin:0}.find-field{width:min(320px,100%);margin:0;font-size:13px}.find-field input{padding:9px 11px}@media(max-width:720px){.panel-head{display:grid}.find-field{width:100%}}
.period-select{display:flex;align-items:end;gap:10px;flex-wrap:wrap;justify-content:flex-end}.period-select label{margin:0;font-size:13px}.period-select select,.period-select input{padding:8px 10px}.period-select button{padding:8px 12px}.month-bars{min-width:520px}@media(max-width:720px){.period-select{justify-content:flex-start}.period-select label{width:100%}}
.chart{display:flex;gap:10px}.chart-scale{height:190px;display:flex;flex-direction:column;justify-content:space-between;flex:0 0 74px;padding-bottom:22px;color:var(--muted);font-size:11px;text-align:right}.chart-bars{flex:1}.hour-bars{min-width:620px}.hour-bars .chart-day small{font-size:9px}
.line-chart{flex:1;min-width:680px}.line-chart svg{width:100%;height:190px;display:block;overflow:visible;background:linear-gradient(to bottom,#e5edf5 1px,transparent 1px);background-size:100% 25%}.line{fill:none;stroke-width:2.2;vector-effect:non-scaling-stroke}.down-line{stroke:var(--brand)}.up-line{stroke:var(--blue)}.point{stroke:#fff;stroke-width:.7;vector-effect:non-scaling-stroke}.down-point{fill:var(--brand)}.up-point{fill:var(--blue)}.line-labels{display:grid;grid-template-columns:repeat(24,1fr);gap:2px;padding-top:7px;color:var(--muted);font-size:9px;text-align:center}.line-labels small{min-width:0}
.icon-actions{gap:6px;flex-wrap:nowrap;min-width:176px}.icon-actions form{display:inline-flex}.icon-action{position:relative;width:36px;height:36px;display:inline-grid;place-items:center;padding:0;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--blue);font-size:13px;font-weight:900;text-decoration:none;line-height:1}.icon-action:hover{border-color:var(--blue);background:#eff6ff}.icon-action.danger-icon{color:var(--danger)}.icon-action.danger-icon:hover{border-color:#fecaca;background:#fef2f2}.icon-action::after{content:attr(data-tip);position:absolute;left:50%;bottom:calc(100% + 8px);transform:translateX(-50%);display:none;z-index:30;width:max-content;max-width:190px;padding:7px 9px;border-radius:8px;background:#0f172a;color:#fff;border:1px solid #334155;box-shadow:0 12px 28px rgba(2,6,23,.24);font-size:12px;font-weight:800;white-space:nowrap;pointer-events:none}.icon-action:hover::after,.icon-action:focus-visible::after{display:block}
.icon-action svg{width:18px;height:18px;display:block;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.cron-output{margin-top:18px}.cron-output textarea{font-family:Consolas,Menlo,monospace;font-size:13px;line-height:1.45;min-height:118px;background:#f8fafc;white-space:pre;overflow:auto}
.import-warning{margin:12px 0;padding:10px;border:1px solid #f3b4b4;border-radius:8px;background:#fff7f7}.import-warning label{display:flex;gap:8px;align-items:center;font-weight:800;color:#991b1b;margin:0}.import-warning input{width:auto}.import-warning p{margin:6px 0 0}.import-progress{margin:14px 0}.import-progress-bar{height:12px;border-radius:999px;background:#e5edf5;overflow:hidden;border:1px solid var(--line)}.import-progress-bar span{display:block;width:0;height:100%;background:linear-gradient(90deg,var(--brand),var(--blue));transition:width .18s ease}.import-progress-bar span.is-busy{background:linear-gradient(90deg,var(--brand),var(--blue),var(--brand));background-size:180% 100%;animation:progressBusy 1.1s linear infinite}.import-progress-bar span.is-error{background:var(--danger)}.import-progress p{margin:7px 0 0;color:var(--muted);font-weight:800;font-size:13px}@keyframes progressBusy{from{background-position:0 0}to{background-position:180% 0}}
.danger-pill{background:#fee2e2;color:#991b1b}.flash.warning{background:#fef3c7;color:#92400e}.queue-preview-table{min-width:1180px}.queue-preview-table td:last-child{min-width:320px;white-space:normal}
.import-command-log{margin-top:10px;border:1px solid var(--line);border-radius:8px;background:#0f172a;color:#dbeafe;overflow:hidden}.import-command-log pre{margin:0;max-height:260px;overflow:auto;padding:12px;font:12px/1.45 Consolas,Menlo,monospace;white-space:pre-wrap}.import-progress .small{margin-top:8px}
