/* ===== Atlas design system — clean white SaaS ===== */
:root{
  --bg:#ffffff; --surface:#ffffff; --sidebar:#ffffff;
  --line:#ececee; --line-2:#e2e2e5; --line-3:#f4f4f5;
  --ink:#18181b; --ink-2:#71717a; --ink-3:#a1a1aa;
  --brand:#5b54e6; --brand-ink:#4a43d6; --brand-soft:#eeedfd;
  --green:#15803d; --green-soft:#edf7f0; --green-dot:#22c55e;
  --amber:#b45309; --amber-soft:#fdf6ea; --amber-dot:#f59e0b;
  --red:#dc2626;   --red-soft:#fdeeee;   --red-dot:#ef4444;
  --gray:#6b7280;  --gray-soft:#f4f4f5;  --gray-dot:#a1a1aa;
  --shadow-xs:0 1px 3px rgba(24,24,27,.06);
  --shadow-sm:0 4px 12px rgba(24,24,27,.07);
  --shadow:0 10px 30px rgba(24,24,27,.10);
  --shadow-lg:0 18px 50px rgba(24,24,27,.18);
  --r:14px; --r-sm:10px;
}
html{color-scheme:only light}
*{box-sizing:border-box}
html,body{margin:0;height:100%;background:#ffffff}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;font-size:14px;letter-spacing:-.006em}
a{color:inherit;text-decoration:none}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#dcdcdf;border-radius:8px;border:3px solid transparent;background-clip:content-box}
::-webkit-scrollbar-thumb:hover{background:#c7c7cc;background-clip:content-box}
.muted{color:var(--ink-2)} .t3{color:var(--ink-3)} .grow{flex:1} .hidden{display:none!important}
.num{font-variant-numeric:tabular-nums}

/* ===== layout ===== */
.app{display:grid;grid-template-columns:244px 1fr;height:100vh}
.sidebar{background:var(--sidebar);border-right:1px solid var(--line);display:flex;flex-direction:column;padding:14px 12px}
.content{overflow-y:auto;height:100vh}
.topbar{height:60px;background:rgba(255,255,255,.82);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:14px;padding:0 28px}
.page{padding:28px 28px 64px;max-width:1360px}

/* ===== sidebar ===== */
.brand{display:flex;align-items:center;gap:10px;padding:6px 8px 14px}
.brand .mark{width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,#7b74f7,#5b54e6);color:#fff;display:grid;place-items:center;font-size:16px;box-shadow:var(--shadow-xs)}
.brand .name{font-weight:700;font-size:16px;letter-spacing:-.02em}
.ws{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:11px;cursor:pointer;border:1px solid var(--line-2);background:var(--surface);margin-bottom:16px;transition:border-color .15s}
.ws:hover{border-color:#d4d4d8}
.ws .logo{width:26px;height:26px;border-radius:7px;background:#18181b;color:#fff;display:grid;place-items:center;font-weight:700;font-size:12px}
.ws .t{line-height:1.2;flex:1}.ws .t b{font-size:13px;font-weight:600;display:block}.ws .t span{font-size:11px;color:var(--ink-3)}
.ws svg{color:var(--ink-3)}
.nav-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-3);font-weight:600;padding:6px 10px}
.nav a{display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:10px;color:var(--ink-2);font-size:13.5px;font-weight:500;margin-bottom:2px;transition:background .12s,color .12s}
.nav a svg{width:17px;height:17px;stroke-width:1.9;fill:none;stroke:currentColor}
.nav a:hover{background:#f5f5f6;color:var(--ink)}
.nav a.active{background:var(--brand-soft);color:var(--brand-ink)}
.nav a .badge{margin-left:auto;background:var(--amber-soft);color:var(--amber);font-size:11px;font-weight:700;padding:1px 7px;border-radius:999px}
.side-foot{margin-top:auto}
.usercard{display:flex;align-items:center;gap:10px;padding:8px;border-radius:11px;cursor:pointer}
.usercard:hover{background:#f5f5f6}
.usercard .av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff;display:grid;place-items:center;font-weight:600;font-size:12px}
.usercard .t{line-height:1.2;flex:1}.usercard .t b{font-size:12.5px;font-weight:600;display:block}.usercard .t span{font-size:11px;color:var(--ink-3)}

/* ===== topbar ===== */
.search{position:relative;flex:0 0 340px}
.search input{width:100%;height:38px;border:1px solid var(--line-2);border-radius:10px;padding:0 12px 0 36px;font-family:inherit;font-size:13.5px;background:var(--surface);color:var(--ink);transition:border-color .15s,box-shadow .15s}
.search input::placeholder{color:var(--ink-3)}
.search input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3.5px var(--brand-soft)}
.search svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--ink-3)}
.region{display:flex;align-items:center;gap:8px;height:38px;padding:0 12px;border-radius:10px;border:1px solid var(--line-2);background:var(--surface);cursor:pointer;font-size:13px;font-weight:500;color:var(--ink-2)}
.region:hover{border-color:#d4d4d8}
.tb-icon{width:38px;height:38px;border-radius:10px;border:1px solid var(--line-2);background:var(--surface);display:grid;place-items:center;color:var(--ink-2);cursor:pointer;position:relative}
.tb-icon:hover{border-color:#d4d4d8;color:var(--ink)}
.tb-icon .ping{position:absolute;top:9px;right:10px;width:7px;height:7px;border-radius:50%;background:var(--red);border:2px solid var(--surface)}

/* ===== page head ===== */
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.page-head h1{font-size:23px;font-weight:700;letter-spacing:-.025em;margin:0 0 5px}
.page-head p{margin:0;color:var(--ink-2);font-size:13.5px}
.back{display:inline-flex;align-items:center;gap:7px;color:var(--ink-2);font-size:13px;font-weight:500;margin-bottom:14px}
.back:hover{color:var(--ink)}
.sec-title{font-size:13px;font-weight:600;color:var(--ink);margin:0 0 12px;display:flex;align-items:center;gap:8px}
.sec-title .c{color:var(--ink-3);font-weight:500}

/* ===== buttons ===== */
.btn{height:40px;padding:0 16px;border-radius:10px;font-family:inherit;font-weight:600;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid transparent;transition:background .15s,border-color .15s}
.btn svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2.2}
.btn-primary{background:var(--ink);color:#fff;box-shadow:var(--shadow-xs)}.btn-primary:hover{background:#2b2b30}
.btn-brand{background:var(--brand);color:#fff}.btn-brand:hover{background:var(--brand-ink)}
.btn-ghost{background:var(--surface);border-color:var(--line-2);color:var(--ink)}.btn-ghost:hover{border-color:#d4d4d8}
.btn-sm{height:34px;padding:0 13px;font-size:12.5px;border-radius:9px}

/* ===== KPIs ===== */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:18px}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:18px 18px 16px;box-shadow:var(--shadow-xs)}
.kpi .l{color:var(--ink-2);font-size:12.5px;font-weight:500;display:flex;align-items:center;gap:7px}
.kpi .l .d{width:8px;height:8px;border-radius:50%}
.kpi .v{font-size:30px;font-weight:700;letter-spacing:-.03em;margin-top:12px;line-height:1}
.kpi .v small{font-size:15px;color:var(--ink-3);font-weight:600;letter-spacing:0}
.kpi .s{font-size:12px;color:var(--ink-3);margin-top:8px}.kpi .s b{font-weight:600}
.kpi .s b.up{color:var(--green)}.kpi .s b.warn{color:var(--amber)}.kpi .s b.br{color:var(--brand)}.kpi .s b.dn{color:var(--red)}

/* ===== generic card ===== */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-xs);overflow:hidden}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;border-bottom:1px solid var(--line)}
.card-head h3{margin:0;font-size:14px;font-weight:600}
.card-body{padding:18px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}

/* ===== insight banner ===== */
.insight{display:flex;align-items:center;gap:13px;padding:13px 16px;border-radius:12px;margin-bottom:18px;background:linear-gradient(90deg,var(--brand-soft),#f6f5ff);border:1px solid #e4e2fb}
.insight .ic{width:32px;height:32px;border-radius:9px;background:#fff;display:grid;place-items:center;font-size:16px;box-shadow:var(--shadow-xs);flex-shrink:0}
.insight .tx{flex:1;font-size:13px;color:#44417a}.insight .tx b{color:#2f2c66;font-weight:600}
.insight .act{background:var(--brand);color:#fff;border:none;border-radius:9px;padding:8px 14px;font-weight:600;font-size:12.5px;cursor:pointer;white-space:nowrap}.insight .act:hover{background:var(--brand-ink)}
.insight .x{color:#8b88bf;cursor:pointer;width:28px;height:28px;display:grid;place-items:center;border-radius:8px}.insight .x:hover{background:#ffffff80}

/* ===== toolbar ===== */
.toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.pillgroup{display:inline-flex;background:var(--surface);border:1px solid var(--line-2);border-radius:11px;padding:3px;gap:2px}
.pillgroup button{height:32px;padding:0 13px;border:none;background:transparent;border-radius:8px;font-family:inherit;font-size:12.8px;font-weight:500;color:var(--ink-2);cursor:pointer;display:flex;align-items:center;gap:7px;transition:all .12s}
.pillgroup button:hover{color:var(--ink)}
.pillgroup button.active{background:var(--ink);color:#fff}
.pillgroup button .d{width:7px;height:7px;border-radius:50%}
.gap-toggle{height:38px;padding:0 14px;border-radius:10px;border:1px solid var(--line-2);background:var(--surface);color:var(--ink-2);font-family:inherit;font-size:12.8px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .14s}
.gap-toggle .sw{width:30px;height:18px;border-radius:999px;background:#d7d7db;position:relative;transition:background .15s}
.gap-toggle .sw::after{content:'';position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;box-shadow:var(--shadow-xs);transition:transform .16s}
.gap-toggle.on{color:var(--brand-ink);border-color:#cfcdf7;background:var(--brand-soft)}
.gap-toggle.on .sw{background:var(--brand)}.gap-toggle.on .sw::after{transform:translateX(12px)}
.seg{display:inline-flex;border:1px solid var(--line-2);border-radius:10px;overflow:hidden;background:var(--surface)}
.seg button{height:38px;width:40px;border:none;background:transparent;cursor:pointer;color:var(--ink-3);display:grid;place-items:center}
.seg button.active{background:var(--brand-soft);color:var(--brand-ink)}
.seg button+button{border-left:1px solid var(--line-2)}

/* ===== matrix ===== */
.matrix-scroll{overflow:auto;max-height:calc(100vh - 290px)}
table.matrix{border-collapse:separate;border-spacing:0;width:100%}
table.matrix th,table.matrix td{white-space:nowrap}
table.matrix thead th{position:sticky;top:0;z-index:2;background:var(--surface);border-bottom:1px solid var(--line);padding:14px 6px 12px;min-width:88px;text-align:center}
table.matrix thead th .flag{font-size:19px;display:block;line-height:1.25}
table.matrix thead th .cc{font-size:11px;color:var(--ink-3);font-weight:600}
.col-prod{position:sticky;left:0;z-index:1;background:var(--surface);text-align:left!important;min-width:296px;box-shadow:1px 0 0 var(--line)}
thead .col-prod{z-index:3;padding-left:22px!important;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3);font-weight:600}
tbody th.col-prod{border-bottom:1px solid var(--line);padding:12px 18px 12px 22px;font-weight:500}
.prod{display:flex;align-items:center;gap:12px}
.prod .thumb{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;font-size:20px;background:var(--gray-soft);flex-shrink:0}
.prod .info{min-width:0;flex:1}
.prod .pn{font-weight:600;font-size:13.5px;color:var(--ink);line-height:1.25}
.prod .meta{display:flex;align-items:center;gap:8px;margin-top:3px}
.prod .asin{font-size:11px;color:var(--ink-3);font-variant-numeric:tabular-nums}
.cov{display:flex;align-items:center;gap:6px}
.cov .bar{width:42px;height:4px;border-radius:999px;background:#ececee;overflow:hidden}
.cov .bar i{display:block;height:100%;background:var(--green);border-radius:999px}
.cov span{font-size:10.5px;color:var(--ink-3);font-weight:500}
table.matrix tbody td{padding:5px;text-align:center;border-bottom:1px solid var(--line)}
table.matrix tbody tr:hover th.col-prod,table.matrix tbody tr:hover td{background:#fafafa}
.tile{width:100%;min-width:76px;height:40px;border-radius:10px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;border:1px solid transparent;transition:transform .08s,box-shadow .14s;position:relative}
.tile:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm);z-index:1}
.tile .g{display:grid;place-items:center;font-size:14px;font-weight:700}
.tile.live{background:var(--green-soft)}.tile.live .g{color:var(--green)}
.tile.oos{background:var(--amber-soft)}.tile.oos .g{color:var(--amber)}
.tile.suppr{background:var(--amber-soft)}.tile.suppr .g{color:var(--amber)}
.tile.block{background:var(--red-soft)}.tile.block .g{color:var(--red)}
.tile.inactive{background:var(--gray-soft)}.tile.inactive .g{color:var(--gray)}
.tile.none{background:transparent;border:1.5px dashed var(--line-2)}.tile.none .g{color:#c9c9cf;font-weight:400;font-size:15px}
.tile.dim{opacity:.16;pointer-events:none}
.tile.gap-hi{border:1.5px solid var(--brand);background:var(--brand-soft)}.tile.gap-hi .g{color:var(--brand);font-size:16px}
.legend{display:flex;gap:18px;flex-wrap:wrap;padding:14px 20px;border-top:1px solid var(--line);background:#fcfcfc}
.legend .i{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--ink-2)}
.legend .sw{width:12px;height:12px;border-radius:4px}

/* ===== clean tables ===== */
.tbl{width:100%;border-collapse:collapse}
.tbl thead th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3);font-weight:600;padding:12px 16px;border-bottom:1px solid var(--line);white-space:nowrap}
.tbl tbody td{padding:13px 16px;border-bottom:1px solid var(--line);font-size:13px;vertical-align:middle;white-space:nowrap}
.tbl tbody tr{cursor:pointer}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl tbody tr:hover td{background:#fafafa}
.tbl .r{text-align:right;font-variant-numeric:tabular-nums}
.tbl .pn{font-weight:600;font-size:13px}

/* ===== status tag / dot ===== */
.tag{display:inline-flex;align-items:center;gap:7px;padding:4px 11px;border-radius:999px;font-size:12px;font-weight:600;white-space:nowrap}
.tag .d{width:7px;height:7px;border-radius:50%}
.tag.live{background:var(--green-soft);color:var(--green)}.tag.live .d{background:var(--green-dot)}
.tag.oos,.tag.suppr{background:var(--amber-soft);color:var(--amber)}.tag.oos .d,.tag.suppr .d{background:var(--amber-dot)}
.tag.block{background:var(--red-soft);color:var(--red)}.tag.block .d{background:var(--red-dot)}
.tag.inactive{background:var(--gray-soft);color:var(--gray)}.tag.inactive .d{background:var(--gray-dot)}
.tag.none{background:var(--gray-soft);color:var(--ink-3)}.tag.none .d{background:#c9c9cf}
.tag.gap{background:var(--brand-soft);color:var(--brand-ink)}.tag.gap .d{background:var(--brand)}
.trend{font-size:12px;font-weight:600;font-variant-numeric:tabular-nums}
.trend.up{color:var(--green)}.trend.dn{color:var(--red)}.trend.flat{color:var(--ink-3)}

/* spark */
.spark{display:block}
.spark path{fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* ===== charts ===== */
.bars{display:flex;flex-direction:column;gap:2px}
.bar-row{display:flex;align-items:center;gap:12px;padding:7px 0}
.bar-row .bl{width:130px;font-size:12.5px;color:var(--ink-2);display:flex;align-items:center;gap:8px;flex-shrink:0}
.bar-row .track{flex:1;height:9px;border-radius:6px;background:var(--line-3);overflow:hidden}
.bar-row .fill{height:100%;border-radius:6px;background:var(--brand)}
.bar-row .bv{width:78px;text-align:right;font-size:12.5px;font-weight:600;font-variant-numeric:tabular-nums}
.legend-dot{display:inline-block;width:9px;height:9px;border-radius:3px;margin-right:7px}
.donut-wrap{display:flex;align-items:center;gap:22px}
.donut{width:148px;height:148px;border-radius:50%;position:relative;flex-shrink:0}
.donut::after{content:'';position:absolute;inset:20px;background:var(--surface);border-radius:50%}
.donut-c{position:absolute;inset:0;display:grid;place-items:center;z-index:1;text-align:center}
.donut-c b{font-size:20px;font-weight:700;letter-spacing:-.02em}.donut-c span{font-size:11px;color:var(--ink-3);display:block}
.dlegend{display:flex;flex-direction:column;gap:10px}
.dlegend .row{display:flex;align-items:center;font-size:12.5px;color:var(--ink-2)}
.dlegend .row b{margin-left:auto;color:var(--ink);font-weight:600;padding-left:18px}

/* ===== product detail header ===== */
.phead{display:flex;align-items:flex-start;gap:18px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:20px;box-shadow:var(--shadow-xs);margin-bottom:16px}
.phead .thumb{width:64px;height:64px;border-radius:14px;background:var(--gray-soft);display:grid;place-items:center;font-size:32px;flex-shrink:0}
.phead h2{margin:0;font-size:18px;font-weight:700;letter-spacing:-.02em}
.phead .sub{color:var(--ink-3);font-size:12.5px;margin-top:4px;display:flex;gap:10px;flex-wrap:wrap}
.phead .sub .chip{background:var(--gray-soft);color:var(--ink-2);padding:2px 9px;border-radius:999px;font-weight:500}
.phead .acts{margin-left:auto;display:flex;gap:10px}

/* ===== connections ===== */
.conn{display:flex;align-items:center;gap:16px;padding:18px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);box-shadow:var(--shadow-xs)}
.conn .logo{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;font-size:22px;flex-shrink:0}
.conn .body{flex:1}.conn .body b{font-size:14.5px}.conn .body p{margin:3px 0 0;font-size:12.5px;color:var(--ink-2)}
.conn .mk{display:flex;gap:6px;margin-top:9px;flex-wrap:wrap}
.conn .mk span{font-size:11px;padding:2px 8px;border-radius:999px;background:var(--gray-soft);color:var(--ink-2);display:inline-flex;align-items:center;gap:5px}
.status-pill{display:inline-flex;align-items:center;gap:7px;padding:5px 11px;border-radius:999px;font-size:12px;font-weight:600}
.status-pill.ok{background:var(--green-soft);color:var(--green)}.status-pill.ok .d{width:7px;height:7px;border-radius:50%;background:var(--green-dot)}
.status-pill.off{background:var(--gray-soft);color:var(--ink-2)}.status-pill.off .d{width:7px;height:7px;border-radius:50%;background:var(--gray-dot)}

/* ===== empty states ===== */
.empty{padding:56px 24px;display:flex;flex-direction:column;align-items:center;text-align:center}
.empty-ic{font-size:30px;margin-bottom:14px}
.empty-t{font-size:15px;font-weight:600;color:var(--ink)}
.empty-b{font-size:13px;color:var(--ink-2);margin-top:6px;max-width:360px;line-height:1.5}
.empty-btn{margin-top:16px;height:36px;padding:0 16px;border-radius:9px;border:1px solid var(--line-2);background:var(--surface);font-family:inherit;font-size:13px;font-weight:600;color:var(--ink);cursor:pointer}
.empty-btn:hover{border-color:#d4d4d8}

/* ===== drawer ===== */
.scrim{position:fixed;inset:0;background:rgba(24,24,27,.32);opacity:0;pointer-events:none;transition:opacity .22s;z-index:50}
.scrim.show{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;height:100%;width:420px;max-width:94vw;background:var(--surface);box-shadow:var(--shadow-lg);z-index:60;transform:translateX(100%);transition:transform .3s cubic-bezier(.32,.72,0,1);display:flex;flex-direction:column}
.drawer.show{transform:translateX(0)}
.dh{padding:22px 22px 20px;display:flex;align-items:flex-start;gap:13px;border-bottom:1px solid var(--line)}
.dh .thumb{width:46px;height:46px;border-radius:11px;background:var(--gray-soft);display:grid;place-items:center;font-size:23px}
.dh .pn{font-weight:700;font-size:15.5px;letter-spacing:-.01em;line-height:1.25}
.dh .sub{color:var(--ink-3);font-size:12px;margin-top:3px}
.dh .x{margin-left:auto;width:32px;height:32px;border-radius:9px;display:grid;place-items:center;color:var(--ink-3);cursor:pointer}.dh .x:hover{background:var(--bg);color:var(--ink)}
.db{padding:22px;overflow-y:auto;flex:1}
.mkrow{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:12px;background:var(--bg);margin-bottom:18px}
.mkrow .flag{font-size:26px}.mkrow b{font-size:14.5px}.mkrow span{display:block;color:var(--ink-3);font-size:12px;margin-top:1px}
.statebox{border-radius:13px;padding:16px 17px;margin-bottom:18px}
.statebox .top{display:flex;align-items:center;gap:10px}
.statebox .g{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-size:15px;font-weight:800;background:#fff}
.statebox .lab{font-size:16px;font-weight:700;letter-spacing:-.01em}
.statebox p{margin:12px 0 0;font-size:13px;line-height:1.55;color:var(--ink-2)}
.statebox.live{background:var(--green-soft)}.statebox.live .g,.statebox.live .lab{color:var(--green)}
.statebox.oos,.statebox.suppr{background:var(--amber-soft)}.statebox.oos .g,.statebox.suppr .g,.statebox.oos .lab,.statebox.suppr .lab{color:var(--amber)}
.statebox.block{background:var(--red-soft)}.statebox.block .g,.statebox.block .lab{color:var(--red)}
.statebox.inactive{background:var(--gray-soft)}.statebox.inactive .g,.statebox.inactive .lab{color:var(--gray)}
.statebox.gap{background:var(--brand-soft)}.statebox.gap .g,.statebox.gap .lab{color:var(--brand-ink)}
.facts{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fact{border:1px solid var(--line);border-radius:11px;padding:13px 14px}
.fact .k{font-size:11.5px;color:var(--ink-3);font-weight:500}
.fact .v{font-size:17px;font-weight:700;margin-top:5px;letter-spacing:-.01em}
.df{padding:16px 22px;border-top:1px solid var(--line);display:flex;gap:10px}
.dlink{display:block;text-align:center;margin-top:-4px;margin-bottom:4px;font-size:12.5px;font-weight:600;color:var(--brand-ink)}

@media (max-width:1180px){.app{grid-template-columns:1fr}.sidebar{display:none}.kpis,.grid-2,.grid-3{grid-template-columns:1fr 1fr}}
@media (max-width:760px){.kpis,.grid-2,.grid-3{grid-template-columns:1fr}}

/* ===== topbar interactive bits ===== */
.search input{padding-right:48px}
.search .hint{position:absolute;right:9px;top:50%;transform:translateY(-50%);font-size:11px;color:var(--ink-3);background:var(--gray-soft);border:1px solid var(--line-2);border-radius:6px;padding:1px 6px;pointer-events:none}
.synct{font-size:12px;color:var(--ink-3);display:flex;align-items:center;gap:7px;white-space:nowrap}
.synct .dot{width:7px;height:7px;border-radius:50%;background:var(--green-dot)}
.tb-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff;display:grid;place-items:center;font-weight:600;font-size:12.5px;cursor:pointer;flex-shrink:0}
.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}

/* ===== dropdown menus ===== */
.menu{position:fixed;min-width:208px;background:var(--surface);border:1px solid var(--line-2);border-radius:12px;box-shadow:var(--shadow);padding:6px;z-index:88;opacity:0;transform:translateY(-4px) scale(.98);pointer-events:none;transition:opacity .14s,transform .14s}
.menu.show{opacity:1;transform:none;pointer-events:auto}
.menu .mi{display:flex;align-items:center;gap:11px;padding:8px 10px;border-radius:8px;font-size:13px;color:var(--ink);cursor:pointer}
.menu .mi:hover{background:#f5f5f6}
.menu .mi svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:1.9;color:var(--ink-3)}
.menu .mi.danger{color:var(--red)}.menu .mi.danger svg{color:var(--red)}
.menu .mi .kbd,.menu .mi .chk{margin-left:auto;font-size:11px;color:var(--ink-3)}
.menu .sep{height:1px;background:var(--line);margin:6px 4px}
.menu .mlabel{font-size:10.5px;color:var(--ink-3);padding:7px 10px 4px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.menu .mi.sel{color:var(--brand-ink)}.menu .mi.sel .chk{color:var(--brand-ink)}
/* notifications panel */
.npanel{width:344px;padding:0}
.npanel .nh{display:flex;align-items:center;justify-content:space-between;padding:12px 15px;border-bottom:1px solid var(--line)}
.npanel .nh b{font-size:13px}.npanel .nh a{font-size:12px;color:var(--brand-ink);cursor:pointer}
.npanel .nl{max-height:340px;overflow-y:auto}
.npanel .ni{display:flex;gap:11px;padding:12px 15px;border-bottom:1px solid var(--line);cursor:pointer}
.npanel .ni:last-child{border-bottom:none}.npanel .ni:hover{background:#f5f5f6}
.npanel .ni .nd{width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0}
.npanel .ni .tx{font-size:12.5px;line-height:1.45}.npanel .ni .tx b{font-weight:600}
.npanel .ni .tm{font-size:11px;color:var(--ink-3);margin-top:3px}

/* ===== command palette ===== */
.ov-scrim{position:fixed;inset:0;background:rgba(24,24,27,.4);backdrop-filter:blur(2px);opacity:0;pointer-events:none;transition:opacity .15s;z-index:90}
.ov-scrim.show{opacity:1;pointer-events:auto}
.cmdk{position:fixed;top:13vh;left:50%;transform:translateX(-50%) scale(.98);width:600px;max-width:92vw;background:var(--surface);border:1px solid var(--line-2);border-radius:16px;box-shadow:var(--shadow-lg);z-index:91;opacity:0;pointer-events:none;transition:opacity .15s,transform .15s;overflow:hidden}
.cmdk.show{opacity:1;transform:translateX(-50%) scale(1);pointer-events:auto}
.cmdk-in{display:flex;align-items:center;gap:11px;padding:15px 18px;border-bottom:1px solid var(--line)}
.cmdk-in svg{color:var(--ink-3)}
.cmdk-in input{flex:1;border:none;outline:none;font-family:inherit;font-size:15px;background:none;color:var(--ink)}
.cmdk-list{max-height:52vh;overflow-y:auto;padding:8px}
.cmdk-group{font-size:10.5px;color:var(--ink-3);font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:9px 10px 4px}
.cmdk-item{display:flex;align-items:center;gap:12px;padding:9px 10px;border-radius:9px;cursor:pointer;font-size:13.5px}
.cmdk-item .ic{width:28px;height:28px;border-radius:7px;background:var(--gray-soft);display:grid;place-items:center;font-size:15px;flex-shrink:0}
.cmdk-item .sub{color:var(--ink-3);font-size:12px;margin-top:1px}
.cmdk-item.active{background:var(--brand-soft)}
.cmdk-item .arrow{margin-left:auto;color:var(--ink-3);font-size:14px}
.cmdk-foot{display:flex;gap:16px;padding:10px 16px;border-top:1px solid var(--line);font-size:11.5px;color:var(--ink-3)}
.kbd-key{font-family:inherit;background:var(--gray-soft);border:1px solid var(--line-2);border-radius:5px;padding:1px 6px;font-size:11px;color:var(--ink-2)}
/* shortcuts modal */
.scmodal{position:fixed;top:18vh;left:50%;transform:translateX(-50%) scale(.98);width:440px;max-width:92vw;background:var(--surface);border:1px solid var(--line-2);border-radius:16px;box-shadow:var(--shadow-lg);z-index:91;opacity:0;pointer-events:none;transition:opacity .15s,transform .15s}
.scmodal.show{opacity:1;transform:translateX(-50%) scale(1);pointer-events:auto}
.scmodal h3{margin:0;padding:16px 20px;border-bottom:1px solid var(--line);font-size:14px}
.scmodal .body{padding:8px 20px 18px}
.scrow{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--line)}
.scrow:last-child{border-bottom:none}.scrow span{font-size:13px;color:var(--ink-2)}

/* ===== toasts ===== */
.toasts{position:fixed;bottom:22px;right:22px;display:flex;flex-direction:column;gap:10px;z-index:95}
.toast{display:flex;align-items:center;gap:11px;background:var(--ink);color:#fff;padding:12px 15px;border-radius:11px;box-shadow:var(--shadow);font-size:13px;font-weight:500;min-width:230px;transform:translateY(12px);opacity:0;transition:opacity .22s,transform .22s}
.toast.show{opacity:1;transform:none}
.toast .tic{width:20px;height:20px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;font-size:12px;color:#fff;font-weight:700}
.toast.ok .tic{background:var(--green-dot)}.toast.info .tic{background:var(--brand)}.toast.warn .tic{background:var(--amber-dot)}

/* ===== skeleton ===== */
.skel{position:relative;overflow:hidden;background:#eef0f2;border-radius:7px}
.skel::after{content:'';position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.65),transparent);animation:shimmer 1.3s infinite}
@keyframes shimmer{100%{transform:translateX(100%)}}
.skel-line{height:13px;margin:11px 0}

/* ===== power tables ===== */
.ck{appearance:none;-webkit-appearance:none;width:17px;height:17px;border:1.5px solid var(--line-2);border-radius:5px;cursor:pointer;position:relative;flex-shrink:0;transition:all .12s;background:var(--surface);vertical-align:middle}
.ck:hover{border-color:#c2c2c8}
.ck:checked{background:var(--brand);border-color:var(--brand)}
.ck:checked::after{content:'';position:absolute;left:5px;top:1.5px;width:4px;height:8px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}
.tbl td.ckcell,.tbl th.ckcell{width:44px;padding-right:0;text-align:center}
.tbl th.sortable{cursor:pointer;user-select:none;white-space:nowrap}
.tbl th.sortable:hover{color:var(--ink-2)}
.tbl th .sortarr{display:inline-block;width:10px;opacity:0;transition:opacity .12s}
.tbl th.sorted .sortarr{opacity:1}
.rowmenu{width:30px;height:30px;border-radius:8px;border:1px solid transparent;background:none;cursor:pointer;color:var(--ink-3);display:grid;place-items:center}
.rowmenu:hover{background:#f0f0f1;color:var(--ink)}
.tbl tr.selected td{background:var(--brand-soft)!important}
.bulkbar{position:fixed;bottom:24px;left:calc(50% + 122px);transform:translateX(-50%) translateY(20px);opacity:0;pointer-events:none;display:flex;align-items:center;gap:14px;background:var(--ink);color:#fff;padding:9px 10px 9px 18px;border-radius:13px;box-shadow:var(--shadow-lg);font-size:13px;z-index:40;transition:opacity .18s,transform .18s}
.bulkbar.show{opacity:1;transform:translateX(-50%);pointer-events:auto}
.bulkbar .n{font-weight:600}
.bulkbar button{background:rgba(255,255,255,.14);border:none;color:#fff;font-family:inherit;font-size:12.5px;font-weight:600;padding:8px 13px;border-radius:9px;cursor:pointer}
.bulkbar button:hover{background:rgba(255,255,255,.26)}
.bulkbar .bx{background:none;padding:7px 9px;color:#c7c7cf}
@media (max-width:1180px){.bulkbar{left:50%}}

/* ===== settings / markets ===== */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:24px}
.tabs button{height:40px;padding:0 14px;border:none;background:none;font-family:inherit;font-size:13.5px;font-weight:500;color:var(--ink-2);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}
.tabs button.active{color:var(--ink);border-bottom-color:var(--brand)}
.setrow{display:flex;align-items:center;gap:16px;padding:18px 0;border-bottom:1px solid var(--line)}
.setrow:last-child{border-bottom:none}
.setrow .info{flex:1}.setrow .info b{font-size:13.5px;font-weight:600}.setrow .info p{margin:3px 0 0;font-size:12.5px;color:var(--ink-2);line-height:1.5}
.switch{width:42px;height:24px;border-radius:999px;background:#d7d7db;position:relative;cursor:pointer;flex-shrink:0;transition:background .15s;border:none}
.switch::after{content:'';position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:var(--shadow-xs);transition:transform .16s}
.switch.on{background:var(--brand)}.switch.on::after{transform:translateX(18px)}
.input{height:40px;border:1px solid var(--line-2);border-radius:10px;padding:0 12px;font-family:inherit;font-size:13.5px;background:var(--surface);color:var(--ink);width:300px}
.input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3.5px var(--brand-soft)}
.mkcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-xs);padding:18px;cursor:pointer;transition:box-shadow .15s,transform .08s}
.mkcard:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.mkcard .top{display:flex;align-items:center;gap:11px;margin-bottom:15px}
.mkcard .flag{font-size:26px}.mkcard .nm{font-weight:600;font-size:14px}.mkcard .rg{font-size:11.5px;color:var(--ink-3)}
.mkcard .mkstat{display:flex;justify-content:space-between;font-size:12.5px;padding:5px 0;color:var(--ink-2)}.mkcard .mkstat .v{font-weight:600;color:var(--ink)}

/* ===== create-listing wizard ===== */
.wiz{position:fixed;top:7vh;left:50%;transform:translateX(-50%) scale(.98);width:680px;max-width:94vw;max-height:86vh;background:var(--surface);border:1px solid var(--line-2);border-radius:18px;box-shadow:var(--shadow-lg);z-index:91;opacity:0;pointer-events:none;transition:opacity .18s,transform .18s;display:flex;flex-direction:column;overflow:hidden}
.wiz.show{opacity:1;transform:translateX(-50%) scale(1);pointer-events:auto}
.wiz-h{display:flex;align-items:center;gap:13px;padding:18px 20px;border-bottom:1px solid var(--line)}
.wiz-h .ic{width:40px;height:40px;border-radius:11px;background:var(--brand-soft);display:grid;place-items:center;font-size:19px}
.wiz-h .t b{font-size:15.5px;font-weight:700;letter-spacing:-.01em;display:block}
.wiz-h .t span{font-size:12px;color:var(--ink-3)}
.wiz-h .x{margin-left:auto;width:32px;height:32px;border-radius:9px;display:grid;place-items:center;color:var(--ink-3);cursor:pointer}.wiz-h .x:hover{background:var(--bg);color:var(--ink)}
.wiz-steps{display:flex;align-items:center;gap:8px;padding:13px 20px;border-bottom:1px solid var(--line);overflow-x:auto}
.wiz-step{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--ink-3);white-space:nowrap;font-weight:500}
.wiz-step .n{width:21px;height:21px;border-radius:50%;border:1.5px solid var(--line-2);display:grid;place-items:center;font-size:10.5px;font-weight:700;color:var(--ink-3);background:var(--surface)}
.wiz-step.active{color:var(--ink)}.wiz-step.active .n{border-color:var(--brand);background:var(--brand);color:#fff}
.wiz-step.done .n{border-color:var(--green);background:var(--green);color:#fff}
.wsep{color:var(--ink-3);font-size:13px;flex-shrink:0}
.wiz-body{padding:22px 24px;overflow-y:auto;flex:1}
.wiz-foot{display:flex;align-items:center;gap:12px;padding:15px 20px;border-top:1px solid var(--line)}
.wiz-count{font-size:12px;color:var(--ink-3);font-weight:500}
.wiz-lead{margin:0 0 18px;font-size:13px;color:var(--ink-2);line-height:1.55}
.field{margin-bottom:16px}
.field label{display:flex;align-items:center;font-size:12.5px;font-weight:600;margin-bottom:6px}
.winput{width:100%;min-height:40px;border:1px solid var(--line-2);border-radius:10px;padding:0 12px;font-family:inherit;font-size:13.5px;background:var(--surface);color:var(--ink)}
select.winput{height:40px}
textarea.winput{padding:10px 12px;height:78px;resize:vertical;line-height:1.5}
.winput:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3.5px var(--brand-soft)}
.winput.ro{background:var(--gray-soft);color:var(--ink-2);display:flex;align-items:center;font-weight:500}
.prefill{font-size:10.5px;color:var(--brand-ink);background:var(--brand-soft);padding:1px 7px;border-radius:999px;margin-left:7px;font-weight:600}
.srcnote{font-size:11.5px;color:var(--ink-3);margin:-8px 0 16px}
.schemanote{font-size:11.5px;color:var(--ink-3);margin:14px 0 0;line-height:1.5}
.grid2w{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.checkrow{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--line)}
.checkrow:last-child{border-bottom:none}
.checkrow .ci{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;font-size:14px;font-weight:800;flex-shrink:0}
.checkrow.ok .ci{background:var(--green-soft);color:var(--green)}.checkrow.warn .ci{background:var(--amber-soft);color:var(--amber)}
.checkrow .ct{flex:1}.checkrow .ct b{font-size:13px;font-weight:600}.checkrow .ct p{margin:2px 0 0;font-size:12px;color:var(--ink-2);line-height:1.45}
.compsum{margin-top:14px;font-size:12.5px;color:var(--ink-2)}
.summary-row{display:flex;justify-content:space-between;gap:14px;padding:11px 0;border-bottom:1px solid var(--line);font-size:13px}
.summary-row:last-child{border-bottom:none}.summary-row .k{color:var(--ink-2)}.summary-row .v{font-weight:600;text-align:right}
.wiz-submit{padding:46px 24px;text-align:center}
.wiz-submit .big-spin{width:46px;height:46px;margin:0 auto 18px;color:var(--brand)}
.wiz-submit .ss{font-size:14px;font-weight:600}
.wiz-success{padding:40px 24px;text-align:center}
.wiz-success .big{width:66px;height:66px;border-radius:50%;background:var(--green-soft);color:var(--green);display:grid;place-items:center;font-size:32px;margin:0 auto 18px}
.wiz-success h3{margin:0 0 6px;font-size:17px;letter-spacing:-.01em}
.wiz-success p{margin:0 0 22px;font-size:13px;color:var(--ink-2);line-height:1.55}

/* ===== final polish pass ===== */
.proto{font-size:9px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);background:var(--gray-soft);border:1px solid var(--line-2);padding:2px 6px;border-radius:6px;margin-left:4px}
.navsoon{margin-left:auto;font-size:9px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--brand-ink);background:var(--brand-soft);padding:1px 6px;border-radius:999px}
.demo-banner{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:11px;margin-bottom:18px;background:#fbfaf6;border:1px dashed var(--line-2);font-size:12.5px;color:var(--ink-2)}
.demo-banner b{color:var(--ink);font-weight:600}
.demo-banner .x{margin-left:auto;cursor:pointer;color:var(--ink-3);padding:2px 6px;border-radius:6px}.demo-banner .x:hover{background:var(--gray-soft)}
polyline{vector-effect:non-scaling-stroke}
.tile.live{background:#dbf1e3}.tile.oos,.tile.suppr{background:#fbeacb}.tile.block{background:#fbd9d9}.tile.inactive{background:#eceef1}
.tile.dim{opacity:1!important;background:#fbfbfc!important;border-color:var(--line-3)!important;pointer-events:none}
.tile.dim .g{opacity:.2}
.tile.gap-hi{background:var(--brand-soft)!important}
.navtog{display:none}
.navscrim{position:fixed;inset:0;background:rgba(24,24,27,.34);opacity:0;pointer-events:none;transition:opacity .2s;z-index:69}
@media(max-width:1180px){
 .sidebar{position:fixed;top:0;left:0;height:100%;width:248px;z-index:70;transform:translateX(-100%);transition:transform .22s cubic-bezier(.32,.72,0,1);display:flex;box-shadow:var(--shadow-lg)}
 body.navopen .sidebar{transform:none}
 body.navopen .navscrim{opacity:1;pointer-events:auto}
 .navtog{display:grid}
}
/* ===== connect-account wizard ===== */
.connreg{margin-bottom:16px}
.connreg-h{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3);font-weight:600;margin-bottom:8px}
.mkgrid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.mkopt{display:flex;align-items:center;gap:9px;padding:9px 11px;border:1px solid var(--line-2);border-radius:10px;font-size:13px;font-weight:500;cursor:pointer;transition:all .12s}
.mkopt:hover{border-color:#c9c9cf}
.mkopt.sel{border-color:var(--brand);background:var(--brand-soft)}
.perm{margin:4px 0 18px}
.btn-amazon{display:flex;align-items:center;justify-content:center;gap:9px;width:100%;height:46px;border-radius:11px;background:#ffd814;border:1px solid #f0c000;color:#0f1111;font-family:inherit;font-weight:600;font-size:14px;cursor:pointer;transition:background .14s}
.btn-amazon:hover{background:#f7ca00}
