
:root{
  --bg:#0a0e16;
  --bg-2:#0f1420;
  --surface:rgba(22,28,42,.72);
  --surface-2:rgba(28,36,56,.55);
  --border:rgba(120,140,180,.18);
  --border-hi:rgba(120,140,180,.32);
  --text:#e6edf6;
  --muted:#7d8aa3;
  --dim:#5a6477;
  --accent:#7c5cff;
  --accent-2:#22d3ee;
  --accent-3:#34d399;
  --warn:#fbbf24;
  --bad:#f87171;
  --grad-1:linear-gradient(135deg,#7c5cff 0%,#22d3ee 100%);
  --grad-2:linear-gradient(135deg,#34d399 0%,#22d3ee 100%);
  --grad-3:linear-gradient(135deg,#fbbf24 0%,#f87171 100%);
  --grad-4:linear-gradient(135deg,#a855f7 0%,#ec4899 100%);
  --shadow:0 10px 30px -10px rgba(0,0,0,.5),0 0 0 1px rgba(120,140,180,.12);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{font-family:'Inter',-apple-system,'Segoe UI',Roboto,sans-serif;color:var(--text);background:var(--bg);font-size:13px;-webkit-font-smoothing:antialiased}
body{min-height:100vh;background:
  radial-gradient(1200px 600px at 80% -10%,rgba(124,92,255,.18),transparent 60%),
  radial-gradient(1000px 500px at -10% 80%,rgba(34,211,238,.10),transparent 60%),
  radial-gradient(800px 400px at 50% 110%,rgba(168,85,247,.08),transparent 60%),
  var(--bg);
  background-attachment:fixed;padding:24px 28px 60px}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(52,211,153,.45)}50%{box-shadow:0 0 0 8px rgba(52,211,153,0)}}
@keyframes shine{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes count-up{from{opacity:.4;transform:translateY(6px) scale(.95)}to{opacity:1;transform:none}}

/* Header */
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;animation:fadeIn .4s ease-out}
.brand{display:flex;align-items:center;gap:14px}
.logo{width:42px;height:42px;border-radius:11px;background:var(--grad-1);display:flex;align-items:center;justify-content:center;font-size:22px;box-shadow:0 8px 24px -8px rgba(124,92,255,.55);position:relative;overflow:hidden}
.logo::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.25) 50%,transparent 70%);transform:translateX(-100%);animation:shine 3s infinite}
.brand h1{font-size:20px;font-weight:700;background:var(--grad-1);-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:-.02em}
.brand .sub{color:var(--muted);font-size:12px;margin-top:2px}
.connection{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--surface);border:1px solid var(--border);border-radius:99px;backdrop-filter:blur(12px);font-size:12px;color:var(--muted)}
.connection .dot{width:8px;height:8px;border-radius:50%;background:var(--accent-3);animation:pulse 2s infinite}
.connection.bad .dot{background:var(--bad);animation:none}
.connection.bad{color:var(--bad)}

/* Action bar */
.actionbar{display:flex;gap:8px;align-items:center;margin-bottom:18px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:14px;backdrop-filter:blur(12px);animation:fadeIn .5s ease-out;flex-wrap:wrap}
.user-pill{display:flex;align-items:center;gap:6px;padding:6px 12px;background:rgba(120,140,180,.08);border:1px solid var(--border);border-radius:99px;font-size:12px;color:var(--text);font-weight:500;margin-right:6px}
.user-pill .user-icon{color:var(--accent-3);font-size:9px}
button{cursor:pointer;border:none;border-radius:9px;padding:8px 14px;font-weight:600;font-size:12px;font-family:inherit;transition:.15s;letter-spacing:.01em;display:inline-flex;align-items:center;gap:6px}
button.primary{background:var(--grad-1);color:white;box-shadow:0 4px 14px -4px rgba(124,92,255,.5)}
button.primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px -4px rgba(124,92,255,.7)}
button.ghost{background:rgba(120,140,180,.08);color:var(--text);border:1px solid var(--border)}
button.ghost:hover{background:rgba(120,140,180,.15);border-color:var(--border-hi)}
button.danger{background:linear-gradient(135deg,#f87171,#ef4444);color:white}
button.danger:hover{filter:brightness(1.1);transform:translateY(-1px)}
button:active{transform:translateY(0)!important}

/* Stat cards row */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.stat{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:18px;backdrop-filter:blur(14px);position:relative;overflow:hidden;animation:fadeIn .5s ease-out backwards;transition:.2s}
.stat:nth-child(1){animation-delay:.05s}.stat:nth-child(2){animation-delay:.1s}.stat:nth-child(3){animation-delay:.15s}.stat:nth-child(4){animation-delay:.2s}
.stat:hover{transform:translateY(-2px);border-color:var(--border-hi);box-shadow:var(--shadow)}
.stat::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad-1)}
.stat.green::before{background:var(--grad-2)}.stat.gold::before{background:var(--grad-3)}.stat.pink::before{background:var(--grad-4)}
.stat .label{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin-bottom:8px}
.stat .num{font-size:28px;font-weight:700;letter-spacing:-.03em;animation:count-up .35s ease-out}
.stat .delta{color:var(--muted);font-size:11px;margin-top:4px}
.stat .icon{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:10px;background:rgba(124,92,255,.12);display:flex;align-items:center;justify-content:center;font-size:17px}

/* Card (generic) */
.card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:16px 18px;backdrop-filter:blur(14px);animation:fadeIn .5s ease-out;margin-bottom:18px;transition:.2s;contain:layout style;content-visibility:auto;contain-intrinsic-size:auto 400px}
.card table{table-layout:fixed;width:100%}
.card table td,.card table th{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.card:hover{border-color:var(--border-hi)}
.card h2{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.card h2 .accent{color:var(--accent-2)}
.card h2 .count{margin-left:auto;background:rgba(120,140,180,.1);color:var(--text);padding:2px 9px;border-radius:99px;font-size:11px;text-transform:none;letter-spacing:0}

/* Table */
table{width:100%;border-collapse:collapse;font-size:12px}
th{text-align:left;color:var(--muted);font-size:10px;text-transform:uppercase;letter-spacing:.1em;font-weight:600;padding:10px 8px;border-bottom:1px solid var(--border)}
td{padding:10px 8px;border-bottom:1px solid rgba(120,140,180,.07);transition:.12s}
tr:last-child td{border-bottom:0}
tbody tr:hover td{background:rgba(124,92,255,.05)}
td.mono{font-family:'JetBrains Mono','Consolas',monospace;font-size:11px;color:var(--text)}
td .row{display:flex;align-items:center;gap:8px}

/* Tags */
.tag{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:99px;font-size:10px;font-weight:600;letter-spacing:.03em}
.tag .pulse-dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.tag.pro{background:rgba(34,211,238,.12);color:#22d3ee;border:1px solid rgba(34,211,238,.3)}
.tag.max{background:rgba(168,85,247,.14);color:#c084fc;border:1px solid rgba(168,85,247,.35)}
.tag.raven{background:rgba(236,72,153,.12);color:#f472b6;border:1px solid rgba(236,72,153,.3)}
.tag.free{background:rgba(120,140,180,.08);color:var(--muted);border:1px solid var(--border)}
.tag.team{background:rgba(251,191,36,.12);color:#fbbf24;border:1px solid rgba(251,191,36,.3)}
.tag.alive{background:rgba(52,211,153,.12);color:#34d399;border:1px solid rgba(52,211,153,.3)}
.tag.dead{background:rgba(248,113,113,.12);color:#f87171;border:1px solid rgba(248,113,113,.3)}
.tag.cookie{background:rgba(251,191,36,.1);color:#fbbf24;border:1px solid rgba(251,191,36,.25)}

/* Process row */
.proc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}
.proc{display:flex;align-items:center;gap:10px;padding:10px 12px;background:rgba(0,0,0,.18);border:1px solid var(--border);border-radius:11px;transition:.15s}
.proc:hover{border-color:var(--border-hi)}
.proc .dot{width:8px;height:8px;border-radius:50%;background:var(--accent-3);animation:pulse 2s infinite;flex-shrink:0}
.proc.down .dot{background:var(--bad);animation:none}
.proc .name{font-weight:600;color:var(--text);font-size:12px}
.proc .pid{color:var(--muted);font-size:10px;font-family:'JetBrains Mono','Consolas',monospace;margin-left:auto}
.proc.down .name{color:var(--bad)}

/* Logs */
.tabs{display:flex;gap:4px;margin-bottom:10px;flex-wrap:wrap;padding:4px;background:rgba(0,0,0,.2);border:1px solid var(--border);border-radius:11px;width:fit-content}
.tabs button{background:transparent;color:var(--muted);padding:6px 12px;border-radius:7px;font-size:11px;text-transform:uppercase;letter-spacing:.05em;transition:.15s}
.tabs button:hover{color:var(--text)}
.tabs button.active{background:var(--grad-1);color:white;box-shadow:0 4px 12px -3px rgba(124,92,255,.5)}
.logs{background:rgba(0,0,0,.55);border:1px solid var(--border);border-radius:12px;padding:12px 14px;height:340px;overflow-y:auto;font-family:'JetBrains Mono','Consolas',monospace;font-size:11px;line-height:1.6;color:#cbd2e0;position:relative}
.logs::-webkit-scrollbar{width:8px;height:8px}
.logs::-webkit-scrollbar-track{background:transparent}
.logs::-webkit-scrollbar-thumb{background:rgba(120,140,180,.2);border-radius:4px}
.logs::-webkit-scrollbar-thumb:hover{background:rgba(120,140,180,.35)}
.log-line{display:block;padding:1px 0;white-space:pre-wrap;word-break:break-all;animation:logIn .35s ease-out}
.log-line.error{color:#f87171}.log-line.warn{color:#fbbf24}.log-line.ok{color:#34d399}.log-line.info{color:#7d8aa3}
@keyframes logIn{0%{opacity:0;transform:translateX(-12px)}100%{opacity:1;transform:none}}
.log-line.fast{animation-duration:0s}
.log-cursor{display:inline-block;width:7px;height:11px;background:var(--accent-3);vertical-align:middle;margin-left:3px;animation:blink 1.2s infinite}
@keyframes blink{0%,49%{opacity:1}50%,100%{opacity:0}}

/* Filter */
.filter{flex:1;background:rgba(0,0,0,.25);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:7px 12px;font-size:12px;outline:none;font-family:inherit;transition:.15s;max-width:280px}
.filter:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(124,92,255,.18)}
.row-flex{display:flex;gap:10px;align-items:center;margin-bottom:12px;flex-wrap:wrap}

/* Toast */
.toasts{position:fixed;top:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:1000;pointer-events:none}
.toast{pointer-events:auto;background:var(--surface);border:1px solid var(--border);backdrop-filter:blur(20px);border-radius:11px;padding:12px 16px;box-shadow:var(--shadow);animation:fadeIn .25s ease-out;font-size:12px;max-width:340px;display:flex;align-items:center;gap:10px;color:var(--text)}
.toast.ok{border-left:3px solid var(--accent-3)}
.toast.bad{border-left:3px solid var(--bad)}
.toast.info{border-left:3px solid var(--accent)}

/* Empty / loading */
.muted{color:var(--muted);font-size:12px;text-align:center;padding:18px 0}
.spinner{width:14px;height:14px;border:2px solid rgba(120,140,180,.25);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}

/* Gift link */
.gift-link{color:#22d3ee;font-family:'JetBrains Mono','Consolas',monospace;font-size:11px;word-break:break-all;text-decoration:none;border-bottom:1px dashed rgba(34,211,238,.3);transition:.15s}
.gift-link:hover{color:white;border-bottom-color:#22d3ee}

/* Responsive */
@media(max-width:900px){
  .stats{grid-template-columns:repeat(2,1fr)}
  body{padding:14px}
}

/* small helper */
.right{margin-left:auto}
.dim{color:var(--dim);font-size:10px}
.spaced{display:flex;align-items:center;gap:8px}

/* Drag-drop zone */
.drop-zone{position:relative;border:2px dashed var(--border-hi);border-radius:14px;padding:22px;text-align:center;color:var(--muted);font-size:13px;transition:.2s;background:rgba(0,0,0,.18);margin-bottom:18px;cursor:pointer}
.drop-zone:hover{border-color:var(--accent);color:var(--text);background:rgba(124,92,255,.08)}
.drop-zone.dragover{border-color:var(--accent);background:rgba(124,92,255,.16);color:var(--text);transform:scale(1.01)}
.drop-zone .icon{font-size:32px;margin-bottom:6px;display:block}
.drop-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}
.drop-zone .hint{font-size:11px;color:var(--dim);margin-top:6px}

/* Modal */
.modal-bg{position:fixed;inset:0;background:rgba(5,8,16,.78);backdrop-filter:blur(6px);z-index:600;display:none;align-items:center;justify-content:center;animation:fadeIn .2s ease-out}
.modal-bg.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:24px 26px;width:min(680px,94vw);max-height:90vh;overflow-y:auto;backdrop-filter:blur(16px);box-shadow:var(--shadow);animation:fadeIn .25s ease-out}
.modal h2{font-size:14px;color:var(--accent-2);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}
.modal .modal-email{font-size:18px;color:var(--text);font-weight:700;margin-bottom:14px;font-family:'JetBrains Mono','Consolas',monospace}
.modal .meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.modal .meta-grid .kv{background:rgba(0,0,0,.22);padding:8px 10px;border-radius:9px;font-size:11px}
.modal .meta-grid .kv .k{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-size:9px;font-weight:600;display:block;margin-bottom:2px}
.modal .meta-grid .kv .v{color:var(--text);font-family:'JetBrains Mono','Consolas',monospace;word-break:break-all}
.modal .modal-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:16px}
.modal .modal-actions button{flex:1;min-width:120px}
.modal .modal-close{position:absolute;top:14px;right:18px;background:none;border:none;color:var(--muted);font-size:22px;cursor:pointer;padding:0;width:auto}
.modal .modal-close:hover{color:var(--text)}

/* Charts */
.charts-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;margin-bottom:18px}
.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px 16px;backdrop-filter:blur(12px);transition:.2s}
.chart-card:hover{border-color:var(--border-hi)}
.chart-card .label{color:var(--muted);font-size:10px;text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin-bottom:10px}
.chart-card .body{display:flex;align-items:center;gap:18px}
.chart-card canvas{display:block;width:96px!important;height:96px!important;flex-shrink:0}
.chart-card .legend{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0}
.chart-card .legend-row{display:grid;grid-template-columns:12px 1fr auto auto;gap:8px;align-items:center;font-size:11px;line-height:1.3}
.chart-card .legend-row .swatch{width:9px;height:9px;border-radius:2px}
.chart-card .legend-row .name{color:var(--muted);text-transform:lowercase;letter-spacing:.02em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.chart-card .legend-row .num{color:var(--text);font-family:'JetBrains Mono','Consolas',monospace;font-weight:600;font-variant-numeric:tabular-nums;text-align:right;min-width:22px}
.chart-card .legend-row .pct{color:var(--dim);font-family:'JetBrains Mono','Consolas',monospace;font-size:10px;text-align:right;font-variant-numeric:tabular-nums;min-width:38px}

/* Usage bar */
.usage-cell{display:flex;align-items:center;gap:8px;min-width:120px}
.usage-bar{flex:1;height:6px;background:rgba(120,140,180,.15);border-radius:99px;overflow:hidden;min-width:60px}
.usage-fill{height:100%;border-radius:99px;transition:width .3s ease-out}
.usage-fill.good{background:linear-gradient(90deg,#34d399,#22d3ee)}
.usage-fill.warn{background:linear-gradient(90deg,#fbbf24,#f59e0b)}
.usage-fill.bad{background:linear-gradient(90deg,#f87171,#ef4444)}
.usage-text{font-family:'JetBrains Mono','Consolas',monospace;font-size:10px;font-weight:600;color:var(--text);font-variant-numeric:tabular-nums;min-width:34px;text-align:right}

/* Card pill */
.card-pill{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;background:rgba(124,92,255,.1);border:1px solid rgba(124,92,255,.25);border-radius:7px;font-size:10px;color:var(--text)}
.card-pill .card-brand{font-weight:700;text-transform:uppercase;color:#c4b5fd;font-size:9px;letter-spacing:.04em}
.card-pill .card-num{font-family:'JetBrains Mono','Consolas',monospace;font-weight:600}
.card-pill .card-country{background:rgba(0,0,0,.3);padding:1px 4px;border-radius:3px;font-size:9px;font-weight:600;color:var(--muted)}

/* Buy gift button on row */
.btn-mini{background:rgba(124,92,255,.15);color:#c4b5fd;border:1px solid rgba(124,92,255,.4);border-radius:7px;padding:3px 9px;font-size:10px;font-weight:600;cursor:pointer;transition:.15s;font-family:inherit}
.btn-mini:hover{background:rgba(124,92,255,.3);transform:translateY(-1px)}
.btn-mini.bad{background:rgba(248,113,113,.12);color:#f87171;border-color:rgba(248,113,113,.4)}
.btn-mini.bad:hover{background:rgba(248,113,113,.25)}
.btn-mini.gold{background:rgba(251,191,36,.14);color:#fbbf24;border-color:rgba(251,191,36,.4)}
.btn-mini.gold:hover{background:rgba(251,191,36,.25)}
.btn-mini.probe{background:rgba(56,189,248,.14);color:#38bdf8;border-color:rgba(56,189,248,.4)}
.btn-mini.probe:hover{background:rgba(56,189,248,.28)}
.btn-mini.act-trigger{background:rgba(124,92,255,.18);color:#c4b5fd;border-color:rgba(124,92,255,.5);font-weight:700;letter-spacing:.04em;padding:4px 12px;transition:.15s}
.btn-mini.act-trigger:hover,.btn-mini.act-trigger.open{background:linear-gradient(135deg,rgba(124,92,255,.45),rgba(34,211,238,.3));color:#fff}
.btn-mini.act-trigger.open{box-shadow:0 0 0 2px rgba(124,92,255,.3)}
/* Popover dropdown */
.actions-popover{background:linear-gradient(180deg,#1a1830,#15132a);border:1px solid rgba(124,92,255,.45);border-radius:10px;padding:5px;min-width:180px;box-shadow:0 10px 30px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.04);animation:popIn .15s ease-out;backdrop-filter:blur(8px)}
@keyframes popIn{from{opacity:0;transform:translateY(-4px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}
.actions-popover .act-item{display:flex;align-items:center;gap:9px;width:100%;background:transparent;color:#cbd2e0;border:none;padding:7px 11px;border-radius:6px;font-size:11px;font-weight:600;cursor:pointer;text-align:left;font-family:inherit;transition:.1s}
.actions-popover .act-item:hover{background:rgba(124,92,255,.22);color:#fff}
.actions-popover .act-item.probe:hover{background:rgba(56,189,248,.25);color:#7dd3fc}
.actions-popover .act-item.gold:hover{background:rgba(251,191,36,.22);color:#fbbf24}
.actions-popover .act-item.bad:hover{background:rgba(248,113,113,.22);color:#fca5a5}
.actions-popover .act-item span{flex:1}
.card-probe-badge{display:inline-block;margin-left:6px;padding:1px 6px;border-radius:5px;font-size:9px;font-weight:700;letter-spacing:.04em;vertical-align:middle;font-family:'JetBrains Mono','Consolas',monospace}
/* FRICTIONLESS = приоритет — горячий красный с пульсацией (нет 3DS challenge → любой CVC пройдёт) */
.card-probe-badge.frictionless{background:linear-gradient(135deg,#ef4444,#f97316);color:#fff;border:1px solid #fca5a5;box-shadow:0 0 12px rgba(239,68,68,.7),inset 0 0 6px rgba(255,255,255,.2);font-weight:800;text-shadow:0 0 4px rgba(0,0,0,.5);animation:pulseHot 1.6s ease-in-out infinite}
@keyframes pulseHot{0%,100%{box-shadow:0 0 8px rgba(239,68,68,.5),inset 0 0 4px rgba(255,255,255,.15)}50%{box-shadow:0 0 18px rgba(239,68,68,.9),inset 0 0 8px rgba(255,255,255,.3)}}
.card-probe-badge.live{background:rgba(56,189,248,.18);color:#7dd3fc;border:1px solid rgba(56,189,248,.5)}
.card-probe-badge.dead{background:rgba(248,113,113,.15);color:#fca5a5;border:1px solid rgba(248,113,113,.4)}
.card-probe-badge.needs3ds{background:rgba(168,85,247,.18);color:#d8b4fe;border:1px solid rgba(168,85,247,.5)}
.card-probe-badge.attempt{background:rgba(251,191,36,.18);color:#fcd34d;border:1px solid rgba(251,191,36,.5)}
.card-probe-badge.unk{background:rgba(120,140,180,.15);color:#94a3b8;border:1px solid rgba(120,140,180,.3)}
/* Подсветка всей строки если frictionless — чтобы их видно было сразу при скролле */
tr.row-frictionless{background:linear-gradient(90deg,rgba(239,68,68,.10),rgba(239,68,68,0)) !important}
tr.row-frictionless td:first-child{border-left:3px solid #ef4444}
tr.row-frictionless td:first-child::before{content:'★ ';color:#fbbf24;font-weight:700}
/* Sessions scrollable block — 801 строк не лезут на страницу, ограничиваем 60vh */
.sessions-scroll{max-height:62vh;overflow-y:auto;contain:layout style paint;border:1px solid var(--border);border-radius:11px;background:rgba(0,0,0,.15);margin-top:8px}
.sessions-scroll table{margin:0;width:100%}
.sessions-scroll table thead th{position:sticky;top:0;z-index:5;background:linear-gradient(180deg,rgba(20,18,40,.96),rgba(20,18,40,.92));backdrop-filter:blur(8px);border-bottom:1px solid var(--border);padding:8px 10px;text-align:left;font-size:11px;color:var(--accent);letter-spacing:.04em;text-transform:uppercase}
.sessions-scroll::-webkit-scrollbar{width:10px}
.sessions-scroll::-webkit-scrollbar-track{background:rgba(0,0,0,.2)}
.sessions-scroll::-webkit-scrollbar-thumb{background:rgba(124,92,255,.4);border-radius:5px}
.sessions-scroll::-webkit-scrollbar-thumb:hover{background:rgba(124,92,255,.6)}
/* Plan filter pills */
.plan-pills{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.plan-pill{padding:4px 12px;background:rgba(124,92,255,.08);border:1px solid rgba(124,92,255,.25);border-radius:14px;font-size:10px;font-weight:600;color:var(--muted);cursor:pointer;transition:.15s;text-transform:uppercase;letter-spacing:.04em;font-family:'JetBrains Mono','Consolas',monospace;user-select:none}
.plan-pill:hover{background:rgba(124,92,255,.2);color:var(--text)}
.plan-pill.active{background:linear-gradient(135deg,#7c5cff,#22d3ee);color:#fff;border-color:transparent;box-shadow:0 2px 10px rgba(124,92,255,.4)}
.plan-pill .pill-count{margin-left:6px;opacity:.7;font-weight:400}
.inv-cell{display:flex;flex-direction:column;gap:1px;font-family:'JetBrains Mono','Consolas',monospace}
.inv-cell .inv-amt{font-size:11px;color:var(--accent-3);font-weight:700;white-space:nowrap}
.inv-cell .inv-ago{font-size:9px;color:var(--muted)}
.card-pill.ghost{background:rgba(120,120,120,.15);color:#94a3b8;border-color:rgba(120,120,120,.3);opacity:.7}
/* Stripe Link брендовый стиль — зелёный градиент со стрелкой */
.card-pill.link-pill{background:linear-gradient(135deg,#00d924,#00b819);color:#fff;border-color:#00d924;font-weight:700;letter-spacing:.02em;box-shadow:0 1px 6px rgba(0,217,36,.3)}
.card-pill.link-pill .link-arrow{display:inline-block;font-size:11px;font-weight:900;margin-right:2px;color:#fff}
.card-pill.link-pill .link-by{font-size:9px;font-weight:500;opacity:.85;margin-left:3px}
.card-pill.link-pill.ghost{background:linear-gradient(135deg,rgba(0,217,36,.18),rgba(0,184,25,.12));color:#86efac;border-color:rgba(0,217,36,.4);box-shadow:none;font-weight:600}
.card-pill.link-pill.ghost .link-arrow{color:#86efac}
.bal-pill{display:inline-flex;align-items:center;gap:3px;margin-left:5px;padding:2px 7px;background:rgba(52,211,153,.12);color:#86efac;border:1px solid rgba(52,211,153,.35);border-radius:6px;font-size:10px;font-weight:700;font-family:'JetBrains Mono','Consolas',monospace}
.bal-pill.bal-hot{background:rgba(251,191,36,.16);color:#fcd34d;border-color:rgba(251,191,36,.5);box-shadow:0 0 6px rgba(251,191,36,.3)}
.bal-pill.bal-zero{background:rgba(120,140,180,.07);color:#64748b;border-color:rgba(120,140,180,.15);opacity:.55;font-weight:500}
.bal-pill .fx{margin-left:4px;font-size:8px;opacity:.6;font-weight:500;letter-spacing:.04em}
.gift-stats{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}
.gstat{padding:5px 11px;background:rgba(124,92,255,.08);border:1px solid rgba(124,92,255,.2);border-radius:8px;font-size:11px;color:var(--muted);font-family:'JetBrains Mono','Consolas',monospace}
.gstat.ok{background:rgba(52,211,153,.12);color:#86efac;border-color:rgba(52,211,153,.35)}
.gstat.dim{opacity:.55}
.gstat b{color:var(--text);margin-left:3px}
.btn-tiny{background:rgba(56,189,248,.12);color:#7dd3fc;border:1px solid rgba(56,189,248,.35);border-radius:5px;padding:2px 7px;font-size:9px;font-family:'JetBrains Mono','Consolas',monospace;font-weight:600;cursor:pointer;transition:.15s}
.btn-tiny:hover{background:rgba(56,189,248,.25)}
/* Компактнее ряды + лучше читаемость для 800+ строк */
.sessions-scroll table tbody tr{content-visibility:auto;contain-intrinsic-size:0 34px}
.sessions-scroll table td{padding:6px 8px;font-size:11px;border-bottom:1px solid rgba(124,92,255,.08)}
.sessions-scroll table tr:hover{background:rgba(124,92,255,.04)}
.sessions-scroll table tr.row-frictionless:hover{background:linear-gradient(90deg,rgba(239,68,68,.18),rgba(239,68,68,.04)) !important}

td.actions{white-space:nowrap}
td.actions .btn-mini{margin-right:4px}

/* Gate (login) */
.gate{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(800px 500px at 30% 30%,rgba(124,92,255,.14),transparent 60%),radial-gradient(700px 400px at 70% 70%,rgba(34,211,238,.10),transparent 60%),var(--bg);backdrop-filter:blur(2px);z-index:500;animation:fadeIn .35s ease-out}
.gate-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:36px 38px;backdrop-filter:blur(18px);box-shadow:var(--shadow);width:min(420px,92vw);text-align:center;animation:fadeIn .5s ease-out}
.gate-logo{width:64px;height:64px;border-radius:16px;background:var(--grad-1);margin:0 auto 18px;display:flex;align-items:center;justify-content:center;font-size:32px;box-shadow:0 16px 40px -10px rgba(124,92,255,.55);position:relative;overflow:hidden}
.gate-logo::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.3) 50%,transparent 70%);transform:translateX(-100%);animation:shine 2.6s infinite}
.gate-card h1{background:var(--grad-1);-webkit-background-clip:text;background-clip:text;color:transparent;font-size:24px;font-weight:700;letter-spacing:-.02em;margin-bottom:6px}
.gate-card .gate-sub{color:var(--muted);font-size:13px;margin-bottom:18px;text-transform:uppercase;letter-spacing:.18em;font-weight:500}
.gate-card input{width:100%;background:rgba(0,0,0,.3);color:var(--text);border:1px solid var(--border);border-radius:11px;padding:13px 16px;font-family:'Inter',sans-serif;font-size:13px;outline:none;transition:.15s;text-align:center;letter-spacing:.02em;margin-top:10px}
.gate-card input[type=password]{font-family:'JetBrains Mono','Consolas',monospace}
.gate-card input:focus{border-color:var(--accent);box-shadow:0 0 0 4px rgba(124,92,255,.18)}
.gate-card input::placeholder{color:var(--dim)}
.gate-card button{width:100%;margin-top:18px;padding:13px 16px;font-size:13px;justify-content:center}
.gate-card .gate-err{color:var(--bad);font-size:12px;margin-top:14px;min-height:16px;text-align:center;animation:fadeIn .25s ease-out}
.hidden{display:none!important}
