/* ============================================================
   EPITOPE — product mockup UI
   Pixel-matched to the deck product screens (slides 6–10):
   macOS browser frame · 192px icon sidebar · blue active state
   ============================================================ */

.app, .viz{
  /* deck-exact tokens */
  --ap-bg:#f2f4fa; --ap-card:#ffffff; --ap-panel:#fbfcff;
  --ap-line:#e4e8f0; --ap-line2:#eef1f7;
  --ap-ink:#1a222c; --ap-ink2:#26303c; --ap-mut:#5f6b7a; --ap-faint:#93a0b0;
  --ap-blue:#577399; --ap-blueT:#41597a; --ap-activeBg:#eef3f8;
  --ap-chipBg:#dfeaf4; --ap-chipT:#3f5f7d;
  --ap-coral:#fe5f55; --ap-coralSoft:#ffe9e7; --ap-coralT:#e8493f;
  --ap-green:#2f8f6b; --ap-teal:#4f9da6; --ap-amber:#e0a23e;
  --ap-mid:#7fb2d2; --ap-pale:#bdd5ea;
  /* legacy aliases (used by platform.html inline styles) */
  --app-ink:#1a222c; --app-ink2:#26303c; --app-mut:#5f6b7a; --app-faint:#93a0b0;
  --app-line:#e4e8f0; --app-line2:#eef1f7; --app-card:#ffffff; --app-bg:#f2f4fa;
}

/* ---------- browser window frame ---------- */
.brwin{
  position:relative; width:100%; height:100%;
  background:var(--ap-card); border:1px solid #dbe2ec;
  border-radius:13px; overflow:hidden;
  box-shadow:var(--shadow-lg);
  display:flex; flex-direction:column;
  font-family:var(--sans);
}
.brwin *{ box-sizing:border-box; }
.brwin-bar{
  height:42px; flex:none; background:#f4f6fa; border-bottom:1px solid #e7eaf1;
  display:flex; align-items:center; padding:0 16px; gap:8px; position:relative;
}
.brwin-dot{ width:12px; height:12px; border-radius:50%; }
.brwin-dot.r{ background:#ff5f57; } .brwin-dot.y{ background:#febc2e; } .brwin-dot.g{ background:#28c840; }
.brwin-url{
  position:absolute; left:50%; transform:translateX(-50%);
  background:#fff; border:1px solid #e7eaf1; border-radius:7px;
  height:28px; min-width:300px; display:flex; align-items:center; justify-content:center;
  font-size:12px; color:var(--ap-mut); gap:7px; padding:0 14px;
}
.brwin-url svg{ width:11px; height:11px; opacity:.6; }

/* ---------- app shell ---------- */
.app{
  flex:1; min-height:0; display:grid; grid-template-columns:190px 1fr;
  background:var(--ap-bg); overflow:hidden;
}

/* sidebar */
.app-side{ background:#fff; border-right:1px solid var(--ap-line); display:flex; flex-direction:column; padding:16px 14px; gap:2px; min-width:0; }
.app-side .brand{ display:flex; align-items:center; gap:9px; font-weight:700; font-size:16px; letter-spacing:-.03em; color:var(--ap-ink); padding:4px 6px 16px; }
.app-side .brand .mark{ width:24px; height:24px; flex:none; }
.app-nav-item{ display:flex; align-items:center; gap:11px; padding:8px 12px; border-radius:8px; font-size:13.5px; color:var(--ap-mut); cursor:pointer; transition:background .15s,color .15s; border:none; background:none; text-align:left; width:100%; line-height:1; }
.app-nav-item svg{ width:16px; height:16px; flex:none; opacity:.75; }
.app-nav-item:hover{ background:#f4f7fb; color:var(--ap-ink2); }
.app-nav-item.active{ background:var(--ap-activeBg); color:var(--ap-blueT); font-weight:600; }
.app-nav-item.active svg{ opacity:1; color:var(--ap-blue); }
.app-nav-item .badge{ margin-left:auto; background:var(--ap-coral); color:#fff; font-size:10px; font-weight:700; border-radius:20px; padding:1px 6px; line-height:1.4; }
.app-side .sp{ flex:1; }
.app-user{ display:flex; align-items:center; gap:9px; padding:9px 8px; border-radius:9px; background:var(--ap-panel); border:1px solid var(--ap-line); }
.app-user .av{ width:30px; height:30px; border-radius:50%; background:linear-gradient(135deg,#6f8bad,#495867); color:#fff; display:grid; place-items:center; font-size:11px; font-weight:600; flex:none; }
.app-user .nm{ font-size:12px; font-weight:600; line-height:1.25; color:var(--ap-ink); }
.app-user .rl{ font-size:10.5px; color:var(--ap-mut); }

/* main */
.app-main{ overflow:hidden; display:flex; flex-direction:column; min-width:0; padding:18px 22px; gap:12px; }
.app-head{ display:flex; align-items:flex-start; gap:14px; }
.app-eyb{ font-family:var(--mono); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--ap-blue); font-weight:500; }
.app-title{ font-size:19px; font-weight:600; letter-spacing:-.02em; color:var(--ap-ink); margin-top:3px; }
.app-sub{ font-size:12.5px; color:var(--ap-mut); margin-top:3px; max-width:60ch; }
.app-head .right{ margin-left:auto; display:flex; gap:8px; align-items:center; flex:none; }

/* buttons */
.axbtn{ font-size:12px; font-weight:500; padding:7px 13px; border-radius:7px; border:1px solid var(--ap-line); background:#fff; color:var(--ap-ink2); display:inline-flex; gap:6px; align-items:center; cursor:pointer; white-space:nowrap; line-height:1; }
.axbtn.coral{ background:var(--ap-coral); color:#fff; border-color:var(--ap-coral); }
.axbtn.blue{ background:var(--ap-blue); color:#fff; border-color:var(--ap-blue); }
.axbtn.icon{ padding:7px 9px; }

/* cards / panels */
.card{ background:var(--ap-card); border:1px solid var(--ap-line); border-radius:11px; padding:15px 16px; }
.panel{ background:var(--ap-panel); border:1px solid var(--ap-line); border-radius:9px; padding:11px 12px; }
.lbl{ font-family:var(--mono); font-size:10px; letter-spacing:.13em; text-transform:uppercase; color:var(--ap-faint); }
.lbl.blue{ color:var(--ap-mut); }

/* chips */
.chip{ display:inline-flex; align-items:center; font-size:11.5px; font-weight:500; padding:4px 9px; border-radius:6px; background:var(--ap-chipBg); color:var(--ap-chipT); white-space:nowrap; }
.chip.solid{ background:var(--ap-blue); color:#fff; }
.chip.ghost{ background:#fff; border:1px solid var(--ap-line); color:var(--ap-mut); }
.chip.coral{ background:var(--ap-coralSoft); color:var(--ap-coralT); }
.chip.green{ background:#e2f1ea; color:var(--ap-green); }
.chips{ display:flex; flex-wrap:wrap; gap:6px; }

/* tabs */
.tabs{ display:flex; gap:20px; border-bottom:1px solid var(--ap-line); }
.tab{ font-size:12.5px; color:var(--ap-mut); padding:0 0 9px; border-bottom:2px solid transparent; white-space:nowrap; }
.tab.on{ color:var(--ap-blueT); font-weight:600; border-color:var(--ap-blue); }

/* stat tiles */
.stat .v{ font-size:23px; font-weight:600; letter-spacing:-.03em; color:var(--ap-ink); line-height:1; }
.stat .k{ font-size:11.5px; color:var(--ap-mut); margin-top:7px; }
.stat .s{ font-size:10.5px; color:var(--ap-faint); margin-top:5px; }
.delta{ color:var(--ap-green); font-weight:600; }

/* progress bars */
.bar{ display:flex; align-items:center; gap:10px; margin-bottom:10px; }
.bar .nm{ font-size:11.5px; color:var(--ap-mut); width:104px; flex:none; }
.bar .track{ flex:1; height:6px; border-radius:6px; background:var(--ap-chipBg); overflow:hidden; }
.bar .fill{ height:100%; border-radius:6px; background:var(--ap-blue); }
.bar .pct{ font-size:11.5px; font-weight:700; color:var(--ap-ink); width:22px; text-align:right; }

/* mini trend cards */
.trend{ display:flex; gap:9px; }
.trend .t{ flex:1; background:var(--ap-panel); border:1px solid var(--ap-line); border-radius:8px; padding:9px 10px; }
.trend .t .pc{ font-size:13px; font-weight:700; color:var(--ap-green); display:flex; align-items:center; gap:3px; }
.trend .t .nm{ font-size:11px; color:var(--ap-ink); margin-top:5px; font-weight:600; }
.trend .t .spark{ height:14px; margin-top:6px; display:flex; align-items:flex-end; gap:2px; }
.trend .t .spark i{ flex:1; background:var(--ap-pale); border-radius:1px; }

/* generic rows / lists */
.row{ display:flex; align-items:center; gap:11px; }
.rank{ width:20px; height:20px; border-radius:6px; background:var(--ap-blue); color:#fff; font-size:11px; font-weight:700; display:grid; place-items:center; flex:none; }
.rank.coral{ background:var(--ap-coral); }
.score{ font-size:15px; font-weight:700; flex:none; }
.score.green{ color:var(--ap-green); } .score.dark{ color:var(--ap-ink); }
.av{ width:30px; height:30px; border-radius:50%; display:grid; place-items:center; font-size:11px; font-weight:600; color:#fff; flex:none; }
.av-az{ background:#7a4ec0; border-radius:8px; }
.av-1{ background:#b8536f; } .av-2{ background:#577399; } .av-3{ background:#2f8f6b; } .av-4{ background:#c9803a; }

/* market-intel account card */
.acct{ background:#fff; border:1px solid var(--ap-line); border-radius:10px; padding:13px; display:flex; flex-direction:column; gap:0; }
.acct .top{ display:flex; align-items:center; gap:8px; }
.acct .nm{ font-size:13.5px; font-weight:700; color:var(--ap-ink); }
.acct .loc{ font-size:10.5px; color:var(--ap-mut); margin-top:2px; }
.acct .sc{ font-size:30px; font-weight:700; color:var(--ap-ink); letter-spacing:-.03em; line-height:1; }

/* bubble scatter */
.scatter{ position:relative; background:#fff; border-radius:8px; }
.bub{ position:absolute; border-radius:50%; transform:translate(-50%,-50%); display:grid; place-items:center; color:#fff; font-size:9px; font-weight:600; box-shadow:0 2px 5px rgba(38,48,60,.14); }
.axline{ position:absolute; font-family:var(--mono); font-size:9px; color:var(--ap-faint); }

/* graph board */
.board{ position:relative; background:var(--ap-panel); border:1px solid var(--ap-line); border-radius:10px; overflow:hidden; }
.gnode{ position:absolute; transform:translate(-50%,-50%); display:flex; flex-direction:column; align-items:center; gap:3px; }
.gnode .ball{ border-radius:50%; border:2px solid #fff; box-shadow:0 2px 7px rgba(38,48,60,.16); }
.gnode .lab{ font-size:9.5px; font-weight:600; color:#495867; white-space:nowrap; background:rgba(255,255,255,.8); padding:0 3px; border-radius:3px; }
.glegend{ position:absolute; background:rgba(255,255,255,.94); border:1px solid var(--ap-line); border-radius:8px; padding:9px 11px; display:flex; flex-direction:column; gap:6px; }
.glegend .it{ display:flex; align-items:center; gap:7px; font-size:10.5px; color:var(--ap-mut); }
.glegend .it i{ width:16px; height:0; border-top:2px solid; display:inline-block; }
.glegend .it .dot{ width:9px; height:9px; border-radius:50%; }

/* org / influence tree */
.tree{ display:flex; flex-direction:column; align-items:center; }
.tnode{ background:var(--ap-panel); border:1px solid var(--ap-line); border-radius:8px; padding:7px 12px; text-align:center; }
.tnode.lead{ background:#fff; }
.tnode .n{ font-size:11.5px; font-weight:600; color:var(--ap-ink); white-space:nowrap; }
.tnode .t{ font-size:10px; color:var(--ap-mut); }
.tnode .inf{ font-size:10px; color:var(--ap-blue); font-weight:600; margin-top:1px; }
.stem{ width:1px; background:#dbdfeb; }
.trow{ display:flex; gap:9px; }

/* connection path */
.path{ display:flex; align-items:center; gap:6px; }
.pcol{ display:flex; flex-direction:column; align-items:center; gap:6px; flex:1; }
.pball{ width:40px; height:40px; border-radius:50%; display:grid; place-items:center; font-size:12px; font-weight:600; color:#fff; }
.pball.you{ background:var(--ap-blue); }
.pball.mid{ background:#fff; border:1.5px solid var(--ap-line); color:var(--ap-blue); }
.pball.tgt{ background:var(--ap-coral); }
.pcap{ text-align:center; }
.pcap b{ font-size:11px; color:var(--ap-ink); display:block; white-space:nowrap; }
.pcap span{ font-size:9.5px; color:var(--ap-mut); white-space:nowrap; }
.parrow{ color:var(--ap-faint); font-size:15px; margin-bottom:18px; }

/* intro draft */
.draft{ background:var(--ap-panel); border:1px solid var(--ap-line); border-radius:9px; padding:13px; font-size:12px; color:var(--ap-ink2); line-height:1.6; }

/* access routes */
.route{ padding:9px 0; border-bottom:1px solid var(--ap-line2); }
.route:last-child{ border-bottom:none; }
.route .hd{ display:flex; align-items:center; gap:8px; }
.route .hd b{ font-size:12px; color:var(--ap-ink); }
.route .pct{ margin-left:auto; font-size:12px; font-weight:700; color:var(--ap-blue); }
.route .pth{ font-size:11px; color:var(--ap-mut); margin-top:4px; }

/* utility */
.grid2{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.grid3{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:12px; }
.grid4{ display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
.gap8{ gap:8px; } .gap10{ gap:10px; }
.mt6{ margin-top:7px; } .mt10{ margin-top:11px; } .mt14{ margin-top:15px; }
.divider{ height:1px; background:var(--ap-line); }
.scrollcol{ display:flex; flex-direction:column; min-height:0; }

/* ============================================================
   LEGACY .ax-* components (platform.html viz panels)
   ============================================================ */
.two{ display:grid; grid-template-columns:1fr 1fr; gap:11px; }
.three{ display:grid; grid-template-columns:1.2fr 1fr 1fr; gap:11px; }
.stack > * + *{ margin-top:11px; }
.mb6{ margin-bottom:7px; } .mb10{ margin-bottom:11px; } .mb14{ margin-bottom:15px; }
.viz-graph{ height:264px; position:relative; }

.ax-card{ background:#fff; border:1px solid var(--ap-line); border-radius:11px; padding:14px; }
.ax-label{ font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--ap-faint); }
.ax-chip{ display:inline-flex; align-items:center; font-size:11.5px; font-weight:500; padding:4px 9px; border-radius:6px; background:var(--ap-chipBg); color:var(--ap-chipT); }
.ax-chip.coral{ background:var(--ap-coralSoft); color:var(--ap-coralT); }
.ax-chip.green{ background:#e2f1ea; color:var(--ap-green); }
.ax-row{ display:flex; align-items:center; gap:11px; padding:10px 12px; border:1px solid var(--ap-line); border-radius:9px; background:#fff; }
.ax-rank{ width:22px; height:22px; border-radius:6px; background:#eef3f9; color:var(--ap-mut); font-size:11px; font-weight:700; display:grid; place-items:center; flex:none; }
.ax-score{ margin-left:auto; font-size:16px; font-weight:700; color:var(--ap-green); flex:none; }
.ax-av{ width:30px; height:30px; border-radius:50%; display:grid; place-items:center; font-size:11px; font-weight:600; color:#fff; flex:none; }
.ax-av.av-1{ background:#577399; } .ax-av.av-2{ background:#2f8f6b; } .ax-av.av-3{ background:#9a6cd0; }
.ax-av.av-4{ background:#c9803a; } .ax-av.av-5{ background:#3f7dc0; } .ax-av.av-6{ background:#b8536f; }

.ax-ring{ --p:89; --c:#2f8f6b; width:74px; height:74px; border-radius:50%; display:grid; place-items:center; background:conic-gradient(var(--c) calc(var(--p)*1%), #e7eef5 0); flex:none; }
.ax-ring .in{ width:58px; height:58px; border-radius:50%; background:#fff; display:flex; align-items:center; justify-content:center; flex-direction:column; }
.ax-ring .in b{ font-size:19px; font-weight:700; line-height:1; color:var(--ap-ink); }
.ax-ring .in span{ font-size:9px; color:var(--ap-faint); }

.ax-bar{ display:flex; align-items:center; gap:10px; margin-bottom:9px; }
.ax-bar .nm{ font-size:12px; width:108px; color:var(--ap-mut); flex:none; }
.ax-bar .track{ flex:1; height:6px; border-radius:6px; background:#e7eef5; overflow:hidden; }
.ax-bar .fill{ height:100%; border-radius:6px; background:var(--ap-blue); }
.ax-bar .pct{ font-size:11px; font-weight:600; width:26px; text-align:right; color:var(--ap-ink); }

.ax-graph{ position:relative; background:radial-gradient(120% 120% at 50% 30%, #fbfdff, #eef3f9); border:1px solid var(--ap-line); border-radius:11px; overflow:hidden; }
.ax-org{ display:flex; flex-direction:column; align-items:center; gap:0; }
.ax-org .ceo{ background:#495867; color:#fff; padding:8px 14px; border-radius:9px; font-size:12px; font-weight:600; }
.ax-org .stem{ width:1px; height:16px; background:#dbdfeb; }
.ax-org .branch{ display:flex; gap:10px; }
.ax-org .unit{ background:#fff; border:1px solid var(--ap-line); border-radius:9px; padding:9px 12px; text-align:center; }
.ax-org .unit b{ font-size:12px; display:block; color:var(--ap-ink); } .ax-org .unit span{ font-size:10.5px; color:var(--ap-faint); }

.ax-path{ display:flex; align-items:center; gap:8px; }
.ax-path .pnode{ background:#fff; border:1px solid var(--ap-line); border-radius:9px; padding:8px 11px; text-align:center; flex:1; }
.ax-path .pnode.me{ border-color:var(--ap-coral); background:var(--ap-coralSoft); }
.ax-path .pnode b{ font-size:12px; display:block; color:var(--ap-ink); } .ax-path .pnode span{ font-size:10px; color:var(--ap-faint); }
.ax-path .lk{ color:var(--ap-coral); font-size:14px; flex:none; }

.ax-draft{ background:#fbfcff; border:1px dashed var(--ap-chipBg); border-radius:10px; padding:14px; font-size:12.5px; color:var(--ap-ink2); line-height:1.55; }
.ax-stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
.ax-stat .v{ font-size:24px; font-weight:600; letter-spacing:-.03em; color:var(--ap-ink); }
.ax-stat .l{ font-size:11.5px; color:var(--ap-mut); margin-top:2px; }
.ax-btn{ font-size:12px; font-weight:500; padding:7px 13px; border-radius:7px; border:1px solid var(--ap-line); background:#fff; color:var(--ap-mut); display:inline-flex; gap:6px; align-items:center; cursor:pointer; }
.ax-btn.solid{ background:var(--ap-coral); color:#fff; border-color:var(--ap-coral); }
.ax-up{ color:var(--ap-green); font-weight:600; font-size:11px; }

/* platform graph legend (dots + anchored bottom-left) */
.ax-graph .glegend{ position:absolute; left:14px; bottom:12px; background:rgba(255,255,255,.94); border:1px solid var(--ap-line); border-radius:8px; padding:9px 11px; flex-direction:column; gap:6px; }
.ax-graph .glegend .it i{ width:9px; height:9px; border-radius:50%; border:none; }
