/* ===== FixedOps AI — prototype design system (TimeAi-style) ===== */
:root{
  --navy:#15294e; --navy2:#1d3a6b; --navy-grad:linear-gradient(90deg,#15294e,#1d3a6b);
  --green:#16a34a; --green-bg:#e7f7ec; --green-line:#22c55e;
  --red:#dc2626; --red-bg:#fdeaea;
  --amber:#f59e0b; --amber-bg:#fff4e0;
  --blue:#2563eb; --blue-bg:#e8f0fe;
  --purple:#8b5cf6;
  --ink:#1f2937; --muted:#7b8499; --faint:#aab1c2;
  --line:#e7e9ef; --bg:#eef1f6; --card:#ffffff;
  --heat:linear-gradient(90deg,#fb7a59,#ef5b6b);
  --shadow:0 1px 3px rgba(20,30,60,.08),0 1px 2px rgba(20,30,60,.04);
  --shadow-lg:0 12px 40px rgba(20,30,60,.22);
  --radius:12px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,Arial,sans-serif;
  background:var(--bg);color:var(--ink);font-size:14px;line-height:1.4}
.hidden{display:none !important}

/* ---- top bar ---- */
.topbar{background:var(--navy-grad);color:#fff;display:flex;align-items:center;gap:18px;
  padding:0 20px;height:58px;position:sticky;top:0;z-index:40}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:.2px}
.brand .logo{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,#22c55e,#2563eb);
  display:grid;place-items:center;font-size:13px;font-weight:800;color:#fff}
.brand .ver{font-size:9px;font-weight:600;opacity:.7;border:1px solid rgba(255,255,255,.4);
  padding:1px 5px;border-radius:6px;margin-left:2px}
.proto-badge{background:#f59e0b;color:#3a2a00;font-weight:700;font-size:10px;padding:3px 8px;
  border-radius:20px;letter-spacing:.4px}
.user{display:flex;align-items:center;gap:8px;margin-left:6px}
.user .av{width:30px;height:30px;border-radius:50%;background:#cfd6e4;display:grid;place-items:center;
  color:#5b667d;font-weight:700;font-size:12px}
.topnav{display:flex;gap:4px;margin-left:6px}
.topnav button{background:transparent;border:0;color:#cdd6ea;font-size:13px;font-weight:600;
  padding:8px 12px;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:7px}
.topnav button:hover{color:#fff;background:rgba(255,255,255,.08)}
.topnav button.active{color:#fff;background:rgba(255,255,255,.12)}
.topnav button.active .ic{color:#34d399}
.spacer{flex:1}
.store-select{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);border-radius:8px;padding:7px 12px;color:#fff;
  font-weight:600;cursor:pointer;font-size:13px}
.iconbtn{width:32px;height:32px;border-radius:8px;display:grid;place-items:center;color:#cdd6ea;cursor:pointer}
.iconbtn:hover{background:rgba(255,255,255,.1);color:#fff}

/* ---- sub nav ---- */
.subnav{background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;
  gap:2px;padding:0 20px;position:sticky;top:58px;z-index:30}
.subnav .tab{border:0;background:transparent;padding:14px 14px;font-weight:700;color:var(--muted);
  cursor:pointer;border-bottom:3px solid transparent;display:flex;gap:7px;align-items:center;font-size:12.5px;
  text-transform:uppercase;letter-spacing:.4px}
.subnav .tab:hover{color:var(--ink)}
.subnav .tab.active{color:var(--green);border-bottom-color:var(--green)}
.subnav .right{margin-left:auto;display:flex;align-items:center;gap:14px;color:var(--muted)}
.period{display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:8px;
  padding:6px 11px;font-weight:600;color:var(--ink);cursor:pointer;background:#fff}
.qsearch{display:flex;align-items:center;gap:7px;color:var(--faint);font-weight:600}

/* ---- layout ---- */
.wrap{max-width:1380px;margin:0 auto;padding:22px 20px 60px}
.section-title{display:flex;align-items:center;gap:9px;font-size:15px;font-weight:800;color:var(--navy);
  letter-spacing:.3px;margin:26px 2px 12px;text-transform:uppercase}
.section-title .ic{color:var(--blue)}
.grid{display:grid;gap:16px}
.cols-2{grid-template-columns:1fr 1fr}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.cols-6{grid-template-columns:repeat(6,1fr)}
@media(max-width:1100px){.cols-3,.cols-4,.cols-6,.cols-2{grid-template-columns:1fr 1fr}}

.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card.pad{padding:18px}
.card h3{margin:0 0 14px;font-size:14px;font-weight:800;color:var(--navy);display:flex;
  align-items:center;gap:8px;text-transform:uppercase;letter-spacing:.3px}
.card h3 .ic{color:var(--blue)}
.card h3 .legend{margin-left:auto;display:flex;gap:12px;font-size:11px;font-weight:600;
  color:var(--muted);text-transform:none;letter-spacing:0}
.dot{width:9px;height:9px;border-radius:50%;display:inline-block;margin-right:5px;vertical-align:-1px}

/* ---- actual/pace/smly summary card ---- */
.sumh{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:800;color:var(--navy);
  text-transform:uppercase;letter-spacing:.4px;margin:0 0 12px}
.sumh .info{width:17px;height:17px;border-radius:50%;background:var(--blue);color:#fff;font-size:11px;
  font-weight:800;display:grid;place-items:center;font-style:italic;font-family:Georgia,serif}
.apx{display:grid;grid-template-columns:repeat(4,1fr);gap:0;column-gap:10px}
.apx .colh{font-size:11px;font-weight:700;color:var(--blue);padding:0 0 9px;display:flex;gap:5px;align-items:center}
.apx .band{background:#f3f4f6;font-size:9.5px;font-weight:700;color:var(--muted);text-transform:uppercase;
  letter-spacing:.4px;padding:5px 9px;margin:0 -3px}
.apx .band.empty{background:transparent}
.apx .val{font-size:21px;font-weight:800;padding:9px 0 13px}
.apx .val.pos{color:var(--green)}
.apx .val.gp{font-size:18px}

/* ---- KPI tiles ---- */
.kpi{border:2px solid var(--line);border-radius:10px;padding:12px 14px;background:#fff}
.kpi .l{font-size:10.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
.kpi .n{font-size:20px;font-weight:800;margin-top:3px}
.kpi.good{border-color:var(--green-line);background:var(--green-bg)} .kpi.good .n{color:#15803d}
.kpi.warn{border-color:#fbbf24;background:var(--amber-bg)} .kpi.warn .n{color:#b45309}
.kpi.bad{border-color:#f87171;background:var(--red-bg)} .kpi.bad .n{color:#b91c1c}
.kpi.info{border-color:#93c5fd;background:var(--blue-bg)} .kpi.info .n{color:#1d4ed8}

/* ---- heat tiles ---- */
.heat{border:1px solid var(--line);border-radius:10px;overflow:hidden;background:#fff}
.heat .top{padding:13px 15px 13px}
.heat .l{font-size:10.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.3px}
.heat .n{font-size:23px;font-weight:800;margin-top:5px;color:var(--ink)}
.heat .bar{background:var(--heat);color:#fff;padding:8px 14px;display:flex;justify-content:space-between;
  align-items:center;font-weight:800}
.heat .bar .bl{font-size:9.5px;font-weight:700;opacity:.95;text-transform:uppercase;letter-spacing:.4px}
.heat .bar .br{display:flex;align-items:center;gap:9px}
.heat .bar .bn{font-size:15px}
.heat .bar .cyc{width:17px;height:17px;border-radius:50%;background:rgba(255,255,255,.28);
  display:grid;place-items:center;font-size:10px;line-height:1}
.heat.clickable{cursor:pointer;transition:transform .08s,box-shadow .12s}
.heat.clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}

/* ---- bars (sales by category) ---- */
.barrow{margin-bottom:16px}
.barrow .t{font-weight:700;font-size:13px;margin-bottom:7px;color:var(--ink)}
.bg{display:flex;align-items:center;gap:8px;margin:4px 0}
.bg .track{flex:1;background:#eef1f6;border-radius:6px;height:15px;overflow:hidden}
.bg .fill{height:100%;border-radius:6px}
.barrow .axis{display:grid;grid-template-columns:repeat(4,1fr);margin-top:5px}
.barrow .axis span{font-size:10px;color:var(--faint);font-weight:600;text-align:right;padding-right:2px}

/* ---- donut ---- */
.donut-wrap{display:flex;gap:18px;flex-wrap:wrap;align-items:center}
.donut{--p:0;--c:var(--blue);width:78px;height:78px;border-radius:50%;
  background:conic-gradient(var(--c) calc(var(--p)*1%),#edf0f6 0);display:grid;place-items:center;position:relative}
.donut::before{content:"";position:absolute;width:58px;height:58px;border-radius:50%;background:#fff}
.donut .dn{position:relative;font-weight:800;font-size:15px}
.donut-item{text-align:center}
.donut-item .lbl{font-size:11px;font-weight:700;color:var(--muted);margin-top:6px;text-transform:uppercase}
.donut-item .sub{font-size:11px;color:var(--faint);font-weight:600}

/* ---- shop rings ---- */
.ring{--p:0;--c:var(--blue);width:96px;height:96px;border-radius:50%;
  background:conic-gradient(var(--c) calc(var(--p)*1%),#edf0f6 0);display:grid;place-items:center;
  position:relative;margin:0 auto}
.ring::before{content:"";position:absolute;width:74px;height:74px;border-radius:50%;background:#fff}
.ring .rn{position:relative;text-align:center}
.ring .rn b{font-size:22px;font-weight:800;display:block;color:var(--ink)}
.ring .rn span{font-size:10px;color:var(--muted);font-weight:700;text-transform:uppercase}
.shop{padding:6px}
.shop .name{text-align:center;font-weight:800;font-size:11px;color:var(--muted);text-transform:uppercase;
  letter-spacing:.4px;margin:8px 0 8px}
.shop .mini{border-radius:8px;color:#fff;padding:7px 10px;margin-top:6px;font-weight:800}
.shop .mini .ml{font-size:9px;font-weight:700;opacity:.92;text-transform:uppercase;letter-spacing:.3px}
.shop .mini .mn{font-size:14px}
.mini.b1{background:linear-gradient(135deg,#60a5fa,#3b82f6)}
.mini.b2{background:linear-gradient(135deg,#818cf8,#6366f1)}
.add-shop{border:2px dashed var(--line);border-radius:12px;display:grid;place-items:center;
  color:var(--faint);font-weight:700;min-height:150px;cursor:pointer}
.add-shop:hover{border-color:#c4cad6;color:var(--muted)}
.unmapped{display:inline-flex;align-items:center;gap:6px;border:1px solid #f5b5b5;color:#b91c1c;
  background:#fdeef0;border-radius:8px;padding:4px 10px;font-weight:700;font-size:12px}

/* ---- alert strip ---- */
.alerts{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:6px}
.alert{flex:1;min-width:200px;background:var(--heat);color:#fff;border-radius:10px;padding:12px 16px}
.alert .al{font-size:10px;font-weight:700;opacity:.95;text-transform:uppercase;letter-spacing:.4px}
.alert .an{font-size:20px;font-weight:800;margin-top:3px}

/* ---- opportunity badges ---- */
.avgcard .pt{margin-top:9px}
.avgcard .pt .pl{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase}
.avgcard .pt .pv{font-size:16px;font-weight:800}
.avgcard .meter{height:5px;border-radius:4px;background:#eef1f6;margin:5px 0 2px;overflow:hidden}
.avgcard .meter i{display:block;height:100%}
.opp{margin-top:10px;border-radius:9px;padding:9px 12px;color:#fff;font-weight:800;display:flex;
  justify-content:space-between;align-items:center;font-size:13px}
.opp.lost{background:linear-gradient(90deg,#fb7a59,#ef5b6b)}
.opp.lost.amber{background:linear-gradient(90deg,#fbbf24,#f59e0b)}
.opp.great{background:linear-gradient(90deg,#34d399,#16a34a)}
.opp .ol{font-size:9px;opacity:.95;text-transform:uppercase;letter-spacing:.4px;font-weight:700}

/* ---- tables ---- */
.tablewrap{overflow:auto;border-radius:10px;border:1px solid var(--line)}
table{border-collapse:collapse;width:100%;font-size:13px}
thead th{background:#f7f8fb;text-align:right;padding:11px 14px;font-size:10.5px;font-weight:700;
  color:var(--muted);text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;border-bottom:1px solid var(--line);
  position:sticky;top:0}
thead th:first-child,tbody td:first-child{text-align:left}
thead th.l,tbody td.l{text-align:left}
tbody td{padding:11px 14px;text-align:right;border-bottom:1px solid #f1f3f7;white-space:nowrap}
tbody tr:hover{background:#fafbfd}
tbody tr:last-child td{border-bottom:0}
td .lnk{color:var(--blue);font-weight:700;cursor:pointer}
td .lnk:hover{text-decoration:underline}
.cell-red{color:var(--red);background:#fdf0f0}
.cell-redtext{color:var(--red);font-weight:700}
.cell-greentext{color:var(--green);font-weight:700}
.pen-strong{color:#15803d;font-weight:800}
.note-ic{color:var(--blue);cursor:pointer}
.totrow td{font-weight:800;background:#eef4ff;color:var(--navy);border-top:2px solid #d6e2fb}
.grp td{font-weight:800;background:#f3f6fc;color:var(--navy);text-transform:uppercase;font-size:11px;letter-spacing:.3px}

/* ---- modal ---- */
.scrim{position:fixed;inset:0;background:rgba(15,23,42,.55);z-index:60;display:none;
  align-items:flex-start;justify-content:center;padding:34px 20px;overflow:auto}
.scrim.open{display:flex}
.modal{background:#fff;border-radius:14px;width:min(1180px,100%);box-shadow:var(--shadow-lg);overflow:hidden}
.modal .mh{background:var(--navy-grad);color:#fff;padding:16px 22px;display:flex;align-items:center}
.modal .mh h2{margin:0;font-size:17px;font-weight:800;letter-spacing:.4px}
.modal .mh .x{margin-left:auto;cursor:pointer;font-size:22px;opacity:.85;line-height:1}
.modal .mh .x:hover{opacity:1}
.modal .mbody{padding:18px 22px 22px}
.tabs{display:flex;gap:18px;border-bottom:1px solid var(--line);margin-bottom:16px}
.tabs button{border:0;background:0;padding:9px 2px;font-weight:700;color:var(--muted);cursor:pointer;
  border-bottom:2px solid transparent;font-size:12.5px;text-transform:uppercase;letter-spacing:.3px}
.tabs button.active{color:var(--blue);border-bottom-color:var(--blue)}
.filterbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:14px}
.chips{display:flex;align-items:center;gap:6px;border:1px solid var(--line);border-radius:8px;padding:6px 10px;
  font-weight:600;color:var(--ink);background:#fff;min-width:170px}
.chip{background:#eef2fb;border:1px solid #d8e2f8;border-radius:6px;padding:1px 7px;font-size:12px;font-weight:700;color:#2950a8}
.toggle{display:inline-flex;align-items:center;gap:7px;font-weight:700;color:var(--muted);cursor:pointer;font-size:12.5px}
.toggle input{accent-color:var(--blue);width:15px;height:15px}
.toggle.red{color:var(--red)}
.exports{margin-left:auto;display:flex;gap:8px;align-items:center;color:var(--muted);font-weight:700;font-size:12px}
.exbtn{width:30px;height:30px;border:1px solid var(--line);border-radius:7px;display:grid;place-items:center;
  color:var(--blue);cursor:pointer;background:#fff}
.exbtn:hover{background:var(--blue-bg)}
.placeholder{display:grid;place-items:center;min-height:380px;text-align:center;color:var(--muted)}
.placeholder .big{font-size:42px;margin-bottom:10px}
.placeholder h2{color:var(--navy);margin:0 0 6px}

/* toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--navy);color:#fff;
  padding:11px 20px;border-radius:10px;font-weight:700;box-shadow:var(--shadow-lg);z-index:90;opacity:0;
  transition:opacity .25s,transform .25s;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(-4px)}

svg.ic{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex:none}
svg.ic.sm{width:14px;height:14px}
