/* ====================================================================
   MAJOR TEAM CLOAKING · admin · style.css · v=mtc1
   Двухтемный зеркально-облачный дизайн.
   - light: белая основа, фиолетовый акцент
   - dark : глубокий графит, неон-индиго
   - Анимации: fade-in / slide / shimmer / glow / float
   - Видео-фон только на login-page
   ==================================================================== */

:root, html[data-theme="light"]{
  --bg:               #f5f7fb;
  --bg-soft:          #eef1f9;
  --surface:          #ffffff;
  --surface-2:        #f8fafd;
  --surface-3:        rgba(255,255,255,.85);
  --glass:            rgba(255,255,255,.62);
  --glass-2:          rgba(255,255,255,.42);
  --line:             rgba(20,28,58,.08);
  --line-2:           rgba(20,28,58,.14);
  --ink:              #161a2c;
  --ink-2:            #2d3454;
  --ink-soft:         #6b7393;
  --ink-mute:         #97a0bf;
  --accent:           #5b48ff;
  --accent-2:         #7c5dfa;
  --accent-3:         #3b5bdb;
  --accent-soft:      rgba(91,72,255,.10);
  --good:             #16a34a;
  --good-soft:        #ebfbee;
  --bad:              #ef4444;
  --bad-soft:         #fff0f0;
  --warn:             #f59e0b;
  --warn-soft:        #fff9db;
  --grad:             linear-gradient(135deg,#7c5dfa 0%,#3b5bdb 100%);
  --grad-2:           linear-gradient(135deg,#5b48ff 0%,#a855f7 100%);
  --grad-soft:        linear-gradient(135deg,rgba(124,93,250,.14),rgba(59,91,219,.10));
  --shadow-sm:        0 1px 2px rgba(20,28,58,.04),0 2px 6px rgba(20,28,58,.04);
  --shadow:           0 4px 12px rgba(20,28,58,.06),0 12px 32px rgba(20,28,58,.06);
  --shadow-lg:        0 12px 32px rgba(20,28,58,.10),0 32px 80px rgba(20,28,58,.08);
  --shadow-glow:      0 0 0 1px rgba(124,93,250,.18),0 16px 40px rgba(91,72,255,.18);
  --r:                14px;
  --r-lg:             20px;
  --sb-bg:            #ffffff;
  --sb-line:          rgba(20,28,58,.06);
}

html[data-theme="dark"]{
  --bg:               #0a0d14;
  --bg-soft:          #0f1320;
  --surface:          #131829;
  --surface-2:        #181d33;
  --surface-3:        rgba(20,26,48,.78);
  --glass:            rgba(28,34,60,.55);
  --glass-2:          rgba(28,34,60,.36);
  --line:             rgba(255,255,255,.06);
  --line-2:           rgba(255,255,255,.12);
  --ink:              #e8ebf6;
  --ink-2:            #c5cae0;
  --ink-soft:         #8a91b3;
  --ink-mute:         #5d6587;
  --accent:           #8b78ff;
  --accent-2:         #a18bff;
  --accent-3:         #6b7eff;
  --accent-soft:      rgba(139,120,255,.18);
  --good:             #22c55e;
  --good-soft:        rgba(34,197,94,.14);
  --bad:              #f87171;
  --bad-soft:         rgba(248,113,113,.14);
  --warn:             #fbbf24;
  --warn-soft:        rgba(251,191,36,.14);
  --grad:             linear-gradient(135deg,#8b78ff 0%,#6b7eff 100%);
  --grad-2:           linear-gradient(135deg,#a18bff 0%,#cf7bff 100%);
  --grad-soft:        linear-gradient(135deg,rgba(139,120,255,.18),rgba(107,126,255,.12));
  --shadow-sm:        0 1px 2px rgba(0,0,0,.30),0 2px 6px rgba(0,0,0,.25);
  --shadow:           0 4px 12px rgba(0,0,0,.30),0 12px 32px rgba(0,0,0,.30);
  --shadow-lg:        0 12px 32px rgba(0,0,0,.45),0 32px 80px rgba(0,0,0,.40);
  --shadow-glow:      0 0 0 1px rgba(139,120,255,.30),0 16px 40px rgba(139,120,255,.28);
  --sb-bg:            #0f1320;
  --sb-line:          rgba(255,255,255,.06);
}

/* ====== Base ====== */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg); color:var(--ink);
  font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,Arial,sans-serif;
  font-size:14px; line-height:1.55;
  -webkit-font-smoothing:antialiased;
  min-height:100vh; overflow-x:hidden;
  transition: background .35s ease, color .35s ease;
}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:.2s}
button{font:inherit;color:inherit;cursor:pointer;border:0;background:0;padding:0}
input,select,textarea{font:inherit;color:inherit}
::selection{background:rgba(124,93,250,.22);color:inherit}
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:8px}
*::-webkit-scrollbar-thumb:hover{background:var(--ink-mute)}

/* mode hint баннер */
.mode-hint{
  display:flex;align-items:flex-start;gap:10px;
  padding:12px 14px;margin-bottom:14px;border-radius:10px;
  background:var(--accent-soft);border:1px solid var(--line-2);
  color:var(--ink-2);
}
.mode-hint b{color:var(--accent);font-size:13px;display:block}
.mode-hint-ic{flex-shrink:0;color:var(--accent);margin-top:1px}
.mode-hint-ic svg{width:18px;height:18px}

/* ====== Multi-select dropdown ====== */
.ms-wrap{position:relative}
.ms-head{
  display:flex;align-items:center;flex-wrap:wrap;gap:6px;
  min-height:42px;padding:7px 38px 7px 12px;
  border-radius:10px;background:var(--surface-2);border:1px solid var(--line);
  cursor:pointer;transition:.2s;font-size:13.5px;color:var(--ink)
}
.ms-head:hover{border-color:var(--accent)}
.ms-wrap.open .ms-head{border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 3px var(--accent-soft)}
.ms-placeholder{color:var(--ink-mute);font-size:13.5px}
.ms-tags{display:flex;flex-wrap:wrap;gap:6px;flex:1;min-width:0}
.ms-tag{
  display:inline-flex;align-items:center;gap:6px;padding:4px 8px 4px 10px;border-radius:999px;
  background:var(--grad);color:#fff;font-size:12.5px;font-weight:600;line-height:1;
  box-shadow:0 2px 6px rgba(124,93,250,.30);animation:popIn .25s ease both
}
.ms-tag-x{
  width:18px;height:18px;border-radius:50%;background:rgba(255,255,255,.22);color:#fff;
  display:grid;place-items:center;font-size:14px;line-height:1;transition:.15s
}
.ms-tag-x:hover{background:rgba(255,255,255,.4)}
.ms-arrow{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--ink-soft);transition:transform .25s,color .2s;pointer-events:none}
.ms-wrap.open .ms-arrow{transform:translateY(-50%) rotate(180deg);color:var(--accent)}

.ms-dropdown{
  position:absolute;left:0;right:0;top:calc(100% + 6px);z-index:200;
  background:var(--surface);border:1px solid var(--line);border-radius:12px;
  box-shadow:var(--shadow-lg);
  display:none;flex-direction:column;overflow:hidden;
  animation:fadeUp .2s ease both;
}
.ms-wrap.open .ms-dropdown{display:flex}
.ms-search{padding:10px 12px;border:0;border-bottom:1px solid var(--line);background:var(--surface);font-size:13px;color:var(--ink);outline:none;font-family:inherit}
.ms-search:focus{background:var(--surface-2)}
.ms-list{max-height:260px;overflow-y:auto;padding:4px}
.ms-opt{
  display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;
  font-size:13px;color:var(--ink);transition:background .12s
}
.ms-opt:hover{background:var(--accent-soft)}
.ms-opt.selected{background:var(--accent-soft);color:var(--accent);font-weight:600}
.ms-check{
  width:18px;height:18px;border-radius:5px;border:1.5px solid var(--line-2);
  display:grid;place-items:center;flex-shrink:0;font-size:11px;font-weight:800;color:#fff;
  transition:.15s
}
.ms-check.on{background:var(--accent);border-color:var(--accent)}
.ms-flag{font-size:16px;line-height:1;flex-shrink:0}
.ms-opt-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ms-opt-val{font-size:11px;color:var(--ink-mute);font-family:'JetBrains Mono','Consolas',monospace;flex-shrink:0}
.ms-empty{padding:18px;text-align:center;font-size:12.5px;color:var(--ink-soft)}

/* ====== Tag-input (chips) ====== */
.tag-wrap{}
.tag-inner{
  display:flex;flex-wrap:wrap;align-items:center;gap:6px;
  padding:7px 10px;border-radius:10px;background:var(--surface-2);border:1px solid var(--line);
  min-height:42px;transition:.2s
}
.tag-inner:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--surface)}
.tag-add{
  width:24px;height:24px;border-radius:50%;background:#22c55e;color:#fff;
  display:grid;place-items:center;flex-shrink:0;transition:transform .2s,box-shadow .2s;
  box-shadow:0 2px 6px rgba(34,197,94,.40)
}
.tag-add:hover{transform:scale(1.1);box-shadow:0 4px 10px rgba(34,197,94,.50)}
.tag-chip{
  display:inline-flex;align-items:center;gap:6px;padding:4px 8px 4px 10px;border-radius:999px;
  background:var(--grad);color:#fff;font-size:12.5px;font-weight:600;line-height:1;
  box-shadow:0 2px 6px rgba(124,93,250,.30);animation:popIn .25s ease both
}
.tag-x{width:18px;height:18px;border-radius:50%;background:rgba(255,255,255,.22);color:#fff;display:grid;place-items:center;font-size:14px;line-height:1;transition:.15s}
.tag-x:hover{background:rgba(255,255,255,.4)}
.tag-input{flex:1;min-width:120px;border:0;background:transparent;outline:none;font-size:13px;color:var(--ink);font-family:inherit;padding:4px 0}
.tag-input::placeholder{color:var(--ink-mute)}
.tag-sugs{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.tag-sug{
  padding:4px 10px;border-radius:999px;background:var(--surface-2);border:1px solid var(--line);
  font-size:11.5px;color:var(--ink-soft);transition:.15s
}
.tag-sug:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}

/* ====== Days picker ====== */
.days-wrap{display:flex;flex-wrap:wrap;gap:6px}
.day-chip{
  width:42px;height:36px;border-radius:10px;background:var(--surface-2);border:1px solid var(--line);
  font-size:12.5px;font-weight:700;color:var(--ink-soft);transition:.2s;font-family:inherit
}
.day-chip:hover{border-color:var(--accent);color:var(--accent)}
.day-chip.on{background:var(--grad);color:#fff;border-color:transparent;box-shadow:0 4px 10px rgba(124,93,250,.30)}

/* ====== Подсветка применённых тумблеров пресетом ====== */
.toggle.applied{
  animation:appliedPulse 1.4s cubic-bezier(.2,.7,.2,1) both;
  border-color:var(--accent)!important;
}
@keyframes appliedPulse{
  0%  { box-shadow:0 0 0 0 rgba(124,93,250,.55);background:var(--accent-soft); }
  60% { box-shadow:0 0 0 8px rgba(124,93,250,0); background:var(--accent-soft); }
  100%{ box-shadow:0 0 0 0 rgba(124,93,250,0);   background:var(--surface-2); }
}

/* ====== Старый полноэкранный фон (отключён в split-layout) ====== */
.bg-stage{display:none}
.bg-img,.bg-video,.bg-veil,.bg-orb,.bg-grid{display:none}

/* В app-page (после логина) фон НЕ показываем — даже если случайно прокинули .bg-stage */
.app-page .bg-stage{display:none}

/* ====== App layout ====== */
.app-page{display:flex;min-height:100vh}
.sidebar{
  width:268px;flex-shrink:0;
  background:var(--sb-bg);
  border-right:1px solid var(--sb-line);
  display:flex;flex-direction:column;
  padding:18px 14px 18px;
  position:sticky;top:0;height:100vh;
  transition: background .35s ease, border-color .35s ease;
}
.sidebar-top{display:flex;align-items:center;gap:10px;margin-bottom:22px;padding:6px 4px 0}

/* ====== Theme toggle (sun/moon) ====== */
.theme-toggle{
  --sz:40px;
  width:var(--sz);height:var(--sz);
  border-radius:12px;
  background:var(--surface-2);
  border:1px solid var(--line);
  display:grid;place-items:center;
  transition:.25s;
  flex-shrink:0;
}
.theme-toggle:hover{background:var(--accent-soft);border-color:var(--accent);transform:translateY(-1px)}
.theme-toggle .th-track{position:relative;width:24px;height:24px;display:block}
.theme-toggle .th-thumb{position:absolute;inset:0;display:grid;place-items:center;color:var(--accent)}
.theme-toggle .th-sun, .theme-toggle .th-moon{
  position:absolute;width:20px;height:20px;
  transition: opacity .35s ease, transform .35s cubic-bezier(.2,.7,.2,1.4);
}
html[data-theme="light"] .theme-toggle .th-sun{opacity:1;transform:rotate(0)}
html[data-theme="light"] .theme-toggle .th-moon{opacity:0;transform:rotate(-90deg) scale(.5)}
html[data-theme="dark"]  .theme-toggle .th-sun{opacity:0;transform:rotate(90deg) scale(.5)}
html[data-theme="dark"]  .theme-toggle .th-moon{opacity:1;transform:rotate(0)}

/* fixed-вариант на login странице (слева вверху) */
.theme-toggle-fixed{position:fixed;top:18px;left:18px;z-index:100;
  background:var(--glass);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
}

/* ====== Sidebar logo ====== */
.sidebar-logo{display:flex;align-items:center;gap:10px;flex:1;min-width:0}
.logo-icon{width:34px;height:34px;flex-shrink:0;display:grid;place-items:center;
  filter:drop-shadow(0 6px 14px rgba(124,93,250,.32))}
.logo-icon svg{width:100%;height:100%}
.logo-text{font-family:'Sora','Inter',sans-serif;font-weight:800;font-size:16px;line-height:1.05;color:var(--ink);
  display:flex;flex-direction:column;letter-spacing:-.01em}
.logo-text b{font-weight:800}
.logo-text i{font-style:normal;font-weight:600;color:var(--accent);margin-left:1px}
.logo-text small{font-family:'Inter';font-size:10.5px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin-top:2px}

/* ====== Sidebar nav ====== */
.sidebar-nav{display:flex;flex-direction:column;gap:3px;margin-top:6px}
.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;color:var(--ink-soft);
  font-weight:500;font-size:14px;transition:.2s;position:relative}
.nav-item svg{width:18px;height:18px;flex-shrink:0}
.nav-item:hover{background:var(--surface-2);color:var(--ink)}
.nav-item.active{background:var(--grad-soft);color:var(--accent);font-weight:600}
.nav-item.active::before{content:"";position:absolute;left:-14px;top:8px;bottom:8px;width:3px;border-radius:0 4px 4px 0;background:var(--grad)}
.nav-divider{height:1px;background:var(--line);margin:8px 6px}

/* sidebar plan */
.sidebar-plan{margin-top:auto;padding:14px 14px 16px;border-radius:14px;background:var(--grad-soft);border:1px solid var(--line);margin-bottom:10px;position:relative;overflow:hidden}
.sidebar-plan::before{content:"";position:absolute;top:-30%;right:-10%;width:140%;height:140%;background:radial-gradient(circle at 80% 20%,rgba(124,93,250,.30),transparent 50%);pointer-events:none}
.pl-title{display:flex;align-items:center;gap:8px;font-weight:700;font-size:13.5px;color:var(--ink);position:relative}
.pl-title svg{color:var(--accent)}
.pl-sub{font-size:11.5px;color:var(--ink-soft);margin-top:4px;position:relative}

/* sidebar user */
.sidebar-user{padding:12px;border-radius:12px;background:var(--surface-2);border:1px solid var(--line)}
.su-top{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.su-av{width:34px;height:34px;border-radius:10px;background:var(--grad);color:#fff;display:grid;place-items:center;flex-shrink:0;box-shadow:0 6px 14px rgba(124,93,250,.32)}
.su-name{font-weight:600;font-size:13.5px;color:var(--ink);line-height:1.2}
.su-mail{font-size:11.5px;color:var(--ink-soft);margin-top:1px}
.btn-logout{width:100%;padding:8px 10px;border-radius:8px;background:transparent;border:1px solid var(--line);color:var(--ink-soft);font-size:12.5px;font-weight:500;transition:.2s}
.btn-logout:hover{background:var(--bad-soft);border-color:var(--bad);color:var(--bad)}

/* ====== Main / Topbar / Content ====== */
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:12px;padding:14px 28px;
  background:var(--surface-3);backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid var(--line);min-height:64px}
.burger{display:none;width:36px;height:36px;border-radius:10px;background:var(--surface-2);border:1px solid var(--line);align-items:center;justify-content:center}
.burger:hover{background:var(--accent-soft);border-color:var(--accent)}
.burger svg{width:18px;height:18px;color:var(--ink)}
.breadcrumbs{font-weight:600;font-size:14.5px;color:var(--ink);flex:1;min-width:0}
.breadcrumbs a{color:var(--ink-soft);font-weight:500}
.breadcrumbs a:hover{color:var(--accent)}
.breadcrumbs strong{font-weight:700;color:var(--ink)}
.topbar-actions{display:flex;align-items:center;gap:10px}
.select{padding:8px 32px 8px 12px;border-radius:10px;background:var(--surface);border:1px solid var(--line);font-size:13px;color:var(--ink);cursor:pointer;
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23808baa' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><path d='m6 9 6 6 6-6'/></svg>");
  background-repeat:no-repeat;background-position:right 10px center;background-size:12px}
.select:hover{border-color:var(--accent)}
.select:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}

.content{flex:1;padding:24px 28px 60px;min-width:0;animation:fadeUp .45s cubic-bezier(.2,.7,.2,1) both}

/* ====== Buttons ====== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:10px;font-size:13.5px;font-weight:600;
  transition:transform .2s,box-shadow .2s,background .2s,border-color .2s;
  border:1px solid transparent;line-height:1;white-space:nowrap}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn svg{width:15px;height:15px;flex-shrink:0}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 6px 18px rgba(124,93,250,.30)}
.btn-primary:hover{box-shadow:0 10px 26px rgba(124,93,250,.42)}
.btn-secondary{background:var(--surface);border-color:var(--line);color:var(--ink)}
.btn-secondary:hover{background:var(--surface-2);border-color:var(--accent);color:var(--accent)}
.btn-accent{background:var(--grad-2);color:#fff;box-shadow:0 6px 18px rgba(168,85,247,.30)}
.btn-accent:hover{box-shadow:0 10px 26px rgba(168,85,247,.42)}
.btn-danger{background:transparent;border-color:var(--bad);color:var(--bad)}
.btn-danger:hover{background:var(--bad-soft)}
.btn-icon{padding:0;width:36px;height:36px;justify-content:center}
.btn-icon svg{width:16px;height:16px}
/* shimmer on primary */
.btn-primary,.btn-accent{position:relative;overflow:hidden}
.btn-primary::after,.btn-accent::after{content:"";position:absolute;top:0;left:-90%;width:55%;height:100%;
  background:linear-gradient(110deg,transparent,rgba(255,255,255,.35),transparent);transform:skewX(-18deg);transition:left .55s}
.btn-primary:hover::after,.btn-accent:hover::after{left:150%}

/* ====== Stat grid ====== */
.stat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin:20px 0 22px}
.stat{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:18px 18px 16px;
  border-radius:var(--r);background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-sm);
  transition:transform .25s cubic-bezier(.2,.7,.2,1),box-shadow .25s,border-color .25s;
  position:relative;overflow:hidden;animation:fadeUp .5s cubic-bezier(.2,.7,.2,1) both}
.stat:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--line-2)}
.stat::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:linear-gradient(135deg,rgba(124,93,250,.18),transparent 40%,transparent 60%,rgba(59,91,219,.20));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .35s}
.stat:hover::before{opacity:1}
.stat-info{font-size:12px;font-weight:500;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.stat-value{font-family:'Sora','Inter';font-weight:800;font-size:24px;color:var(--ink);display:flex;align-items:baseline;gap:8px;line-height:1}
.stat-delta{font-size:11.5px;font-weight:700;padding:2px 8px;border-radius:999px}
.stat-delta.up{background:var(--good-soft);color:var(--good)}
.stat-delta.down{background:var(--bad-soft);color:var(--bad)}
.stat-icon{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;flex-shrink:0;color:#fff;
  box-shadow:0 6px 14px rgba(20,28,58,.10)}
.stat-icon svg{width:18px;height:18px}
.stat-icon-clicks{background:linear-gradient(135deg,#7c5dfa,#3b5bdb)}
.stat-icon-good{background:linear-gradient(135deg,#16a34a,#22c55e)}
.stat-icon-bad{background:linear-gradient(135deg,#ef4444,#f87171)}
.stat-icon-unique{background:linear-gradient(135deg,#22b8cf,#3b82f6)}
.stat-icon-conv{background:linear-gradient(135deg,#e64980,#a855f7)}

/* ====== Page head ====== */
.page-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:6px;flex-wrap:wrap}
.page-title{font-family:'Sora','Inter';font-weight:800;font-size:28px;letter-spacing:-.02em;color:var(--ink)}
.camp-title{display:flex;align-items:center;gap:12px;font-family:'Sora';font-weight:800;font-size:24px;color:var(--ink)}
.camp-title a{color:var(--ink-soft);font-size:22px;font-weight:600}

/* ====== Tables ====== */
.table-wrap{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);margin-top:16px;animation:fadeUp .5s cubic-bezier(.2,.7,.2,1) both}
.table-controls{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.table-controls input[type="text"]{padding:8px 12px;border-radius:10px;background:var(--surface-2);border:1px solid var(--line);font-size:13px;color:var(--ink);min-width:240px;transition:.2s}
.table-controls input[type="text"]:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--surface)}
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{padding:12px 14px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:11px;color:var(--ink-soft);text-align:left;background:var(--surface-2);border-bottom:1px solid var(--line);white-space:nowrap}
.tbl td{padding:13px 14px;border-bottom:1px solid var(--line);color:var(--ink-2);vertical-align:middle}
.tbl tbody tr{transition:background .15s}
.tbl tbody tr:hover{background:var(--surface-2)}
.tbl tbody tr:last-child td{border-bottom:0}
.row-actions{cursor:pointer;color:var(--ink-soft);font-size:18px;width:30px;text-align:center;padding:8px 12px;border-radius:8px}
.row-actions:hover{color:var(--accent);background:var(--accent-soft)}
.row-menu{position:fixed;background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);padding:6px;z-index:9000;min-width:200px;animation:fadeUp .15s ease both}
.rm-item{padding:9px 12px;border-radius:8px;font-size:13px;color:var(--ink);cursor:pointer;transition:.15s}
.rm-item:hover{background:var(--accent-soft);color:var(--accent)}
.rm-item.danger{color:var(--bad)}
.rm-item.danger:hover{background:var(--bad-soft)}
.muted{color:var(--ink-mute)}
.empty-state{padding:80px 28px;text-align:center;color:var(--ink-soft)}
.empty-state h3{font-family:'Sora';font-weight:700;font-size:18px;color:var(--ink);margin:0 0 8px}
.spinner-inline{display:inline-block;width:16px;height:16px;border:2px solid var(--line-2);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite;margin-right:10px;vertical-align:middle}
@keyframes spin{to{transform:rotate(360deg)}}

/* badges */
.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.badge-off{background:rgba(150,160,180,.16);color:var(--ink-soft)}
.badge-basic{background:rgba(34,184,207,.14);color:#0891b2}
.badge-smart{background:rgba(91,72,255,.14);color:var(--accent)}
.badge-strict{background:rgba(20,30,80,.14);color:var(--ink)}
.badge-inapp{background:rgba(34,197,94,.14);color:var(--good)}
.badge-moderation{background:rgba(245,158,11,.14);color:var(--warn)}
html[data-theme="dark"] .badge-strict{background:rgba(255,255,255,.08);color:var(--ink)}

.tag{display:inline-flex;align-items:center;padding:3px 9px;border-radius:6px;font-size:11px;font-weight:600}
.tag.ok{background:var(--good-soft);color:var(--good)}
.tag.bot{background:var(--bad-soft);color:var(--bad)}
.tag.gray{background:var(--surface-2);color:var(--ink-soft)}

/* ====== Panels / charts ====== */
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow-sm);
  animation:fadeUp .5s cubic-bezier(.2,.7,.2,1) both;transition:box-shadow .25s,border-color .25s}
.panel:hover{border-color:var(--line-2)}
.panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.panel-title{font-family:'Sora';font-weight:700;font-size:16px;color:var(--ink)}
.panel-sub{font-size:12px;color:var(--good);margin-top:2px;font-weight:600}
.panel-sub.down{color:var(--bad)}
.legend{display:flex;gap:16px;font-size:12px;color:var(--ink-soft);flex-wrap:wrap}
.legend i{display:inline-block;width:8px;height:8px;border-radius:2px;margin-right:6px;vertical-align:middle}
.chart-wrap{position:relative;height:240px;width:100%}

/* grid 2 */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}
.grid-2-eq{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}

/* donut */
.donut-wrap{position:relative;height:200px;display:flex;align-items:center;justify-content:center}
.donut-center{position:absolute;text-align:center;pointer-events:none}
.donut-center .big{font-family:'Sora';font-weight:800;font-size:30px;color:var(--ink);line-height:1}
.donut-center .lbl{font-size:11px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em;margin-top:4px}

/* quality cells */
.quality-cells{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:14px}
.qcell{padding:12px;border-radius:12px;background:var(--surface-2);border:1px solid var(--line);transition:.2s}
.qcell:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.qcell .ic{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;font-weight:700;font-size:12px;margin-bottom:8px}
.qcell .v{font-family:'Sora';font-weight:800;font-size:18px;color:var(--ink)}
.qcell .l{font-size:11px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.05em;margin-top:2px;margin-bottom:8px}
.qcell .bar{height:4px;border-radius:4px;background:var(--line);overflow:hidden}
.qcell .bar i{display:block;height:100%;border-radius:4px;transition:width .8s cubic-bezier(.2,.7,.2,1)}

/* geo row */
.geo-row{display:flex;align-items:center;gap:10px}
.geo-flag{font-size:18px;line-height:1}

/* ====== FAB ====== */
.fab{position:fixed;right:30px;bottom:30px;z-index:90;width:56px;height:56px;border-radius:50%;background:var(--grad);color:#fff;font-size:24px;font-weight:300;
  box-shadow:0 12px 28px rgba(124,93,250,.40);display:grid;place-items:center;transition:transform .25s,box-shadow .25s}
.fab:hover{transform:scale(1.08) rotate(90deg);box-shadow:0 18px 40px rgba(124,93,250,.55)}

/* ====== Modal ====== */
.modal-overlay{position:fixed;inset:0;z-index:9000;background:rgba(20,28,58,.55);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .25s ease both}
html[data-theme="dark"] .modal-overlay{background:rgba(0,0,0,.65)}
.modal{background:var(--surface);border:1px solid var(--line);border-radius:18px;width:100%;max-width:760px;height:92vh;max-height:92vh;display:flex;flex-direction:column;
  box-shadow:var(--shadow-lg);animation:popIn .35s cubic-bezier(.2,.7,.2,1.1) both;overflow:hidden}
.modal-header{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:14px;flex-shrink:0}
.modal-header h2{font-family:'Sora';font-weight:700;font-size:18px;color:var(--ink);margin:0}
.modal-tabs{display:flex;gap:4px;background:var(--surface-2);border-radius:10px;padding:3px;border:1px solid var(--line)}
.modal-tabs button{padding:6px 14px;border-radius:8px;font-size:13px;font-weight:600;color:var(--ink-soft);transition:.2s}
.modal-tabs button.active{background:var(--surface);color:var(--accent);box-shadow:var(--shadow-sm)}
.modal-tabs button:hover:not(.active){color:var(--ink)}
.modal-close{width:32px;height:32px;border-radius:8px;font-size:22px;color:var(--ink-soft);transition:.2s}
.modal-close:hover{background:var(--surface-2);color:var(--ink)}
.modal-body{flex:1 1 auto;overflow-y:auto;padding:20px 22px;min-height:0}
.modal-footer{padding:14px 22px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:10px;align-items:center;flex-shrink:0;
  background:var(--surface);position:sticky;bottom:0;z-index:5;
  box-shadow:0 -4px 12px rgba(20,28,58,.06)}
html[data-theme="dark"] .modal-footer{box-shadow:0 -4px 12px rgba(0,0,0,.35)}

/* ====== Form ====== */
.form-section{margin-bottom:22px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.form-section:last-child{border-bottom:0;margin-bottom:0;padding-bottom:0}
.form-section h3{font-family:'Sora';font-weight:700;font-size:14px;color:var(--ink);margin:0 0 12px;text-transform:uppercase;letter-spacing:.04em}
.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:12px}
.field{margin-bottom:12px}
.field label{display:block;font-size:12px;font-weight:600;color:var(--ink-soft);margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}
.field input,.field select,.field textarea{width:100%;padding:10px 12px;border-radius:10px;background:var(--surface-2);border:1px solid var(--line);font-size:13.5px;color:var(--ink);transition:.2s;font-family:inherit}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--surface)}
.field textarea{resize:vertical;min-height:60px;font-family:'JetBrains Mono','Consolas',monospace;font-size:12.5px}
.field-suffix{display:flex;gap:8px}
.field-suffix input{flex:1}
.field-suffix select{flex:0 0 180px}

/* radio group (modes) */
.radio-group{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}
.radio-item{cursor:pointer;padding:14px;border-radius:12px;background:var(--surface-2);border:1px solid var(--line);transition:.2s;position:relative;overflow:hidden}
.radio-item:hover{border-color:var(--accent);background:var(--accent-soft)}
.radio-item.selected{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 3px var(--accent-soft)}
.radio-item input[type="radio"]{position:absolute;opacity:0;pointer-events:none}
.radio-item-content .title{display:flex;align-items:center;gap:8px;font-weight:700;font-size:14px;color:var(--ink);margin-bottom:6px}
.radio-item-content .title .dot{width:8px;height:8px;border-radius:50%}
.dot.gray{background:#94a3b8}.dot.cyan{background:#22b8cf}.dot.blue{background:#7c5dfa}.dot.dark{background:#1e293b}.dot.green{background:#22c55e}.dot.warn{background:#f59e0b}
.radio-item-content .desc{font-size:12px;color:var(--ink-soft);line-height:1.45}
.radio-item-content .desc.warn{color:var(--warn)}

/* segmented (browser_check) */
.seg-group{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}
.seg{cursor:pointer;padding:12px;border-radius:12px;background:var(--surface-2);border:1px solid var(--line);transition:.2s}
.seg:hover{border-color:var(--accent)}
.seg.selected{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 3px var(--accent-soft)}
.seg .t{font-weight:700;font-size:13.5px;color:var(--ink);margin-bottom:3px}
.seg .d{font-size:11.5px;color:var(--ink-soft)}

/* toggle */
.toggle{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 14px;border-radius:10px;background:var(--surface-2);border:1px solid var(--line);margin-bottom:7px;transition:.15s}
.toggle:hover{border-color:var(--line-2)}
.toggle .label{font-size:13.5px;font-weight:600;color:var(--ink)}
.toggle .desc{font-size:11.5px;color:var(--ink-soft);margin-top:2px}
.switch{position:relative;display:inline-block;width:38px;height:22px;flex-shrink:0}
.switch input{display:none}
.slider{position:absolute;cursor:pointer;inset:0;background:var(--line-2);border-radius:22px;transition:.25s}
.slider::before{content:"";position:absolute;width:18px;height:18px;left:2px;top:2px;background:#fff;border-radius:50%;transition:.25s;box-shadow:0 1px 4px rgba(0,0,0,.18)}
.switch input:checked + .slider{background:var(--grad)}
.switch input:checked + .slider::before{transform:translateX(16px)}

/* copy row */
.copy-row{display:flex;gap:8px}
.copy-row input{flex:1;padding:9px 12px;border-radius:10px;background:var(--surface-2);border:1px solid var(--line);font-family:'JetBrains Mono','Consolas',monospace;font-size:12.5px;color:var(--ink)}
.copy-row button{width:40px;height:auto;border-radius:10px;background:var(--surface-2);border:1px solid var(--line);color:var(--ink-soft);transition:.2s;display:grid;place-items:center}
.copy-row button:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}

.code-block{padding:14px;border-radius:10px;background:var(--surface-2);border:1px solid var(--line);font-family:'JetBrains Mono','Consolas',monospace;font-size:12px;color:var(--ink);white-space:pre-wrap;word-break:break-all;line-height:1.6}

/* integration block */
.integration-block{display:flex;align-items:center;gap:14px;padding:14px;border-radius:12px;background:var(--surface-2);border:1px solid var(--line);margin-bottom:10px}
.integration-block .icon{width:38px;height:38px;border-radius:10px;background:var(--grad);color:#fff;display:grid;place-items:center;font-weight:800;font-size:14px;flex-shrink:0;font-family:'Sora'}
.integration-block .meta{flex:1;min-width:0}
.integration-block .title{font-weight:700;font-size:14px;color:var(--ink)}
.integration-block .desc{font-size:11.5px;color:var(--ink-soft);margin-top:2px}
.integration-block .actions{display:flex;gap:8px;flex-shrink:0}

/* diagnostic */
.diagnostic-card{padding:16px;border-radius:12px;border:1px solid var(--line);margin:10px 0;animation:fadeUp .25s ease both}
.diagnostic-card.ok{background:var(--good-soft);border-color:rgba(34,197,94,.30)}
.diagnostic-card.error{background:var(--bad-soft);border-color:rgba(239,68,68,.28)}
.diagnostic-card .head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:12.5px;color:var(--ink-2)}
.diagnostic-card .status.ok{color:var(--good);font-weight:700}
.diagnostic-card .status.error{color:var(--bad);font-weight:700}
.diag-msg{font-size:13px;color:var(--ink-2);margin:8px 0}
.diag-section{margin-top:10px}
.diag-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);margin-bottom:6px}
.diag-row{display:flex;align-items:center;gap:10px;padding:6px 0;font-size:12.5px;color:var(--ink-2)}
.diag-row.ok .diag-ic{background:var(--good-soft);color:var(--good)}
.diag-row.err .diag-ic{background:var(--bad-soft);color:var(--bad)}
.diag-ic{width:18px;height:18px;border-radius:4px;display:grid;place-items:center;font-weight:800;font-size:11px;flex-shrink:0}
.diag-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.diag-detail{color:var(--ink-soft);font-size:11.5px;flex-shrink:0}

/* toast */
.toast-wrap{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:10px;pointer-events:none}
.toast{padding:12px 18px;border-radius:12px;background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-lg);font-size:13px;color:var(--ink);min-width:200px;max-width:340px;
  animation:slideInRight .35s cubic-bezier(.2,.7,.2,1.1) both;transition:opacity .25s,transform .25s;pointer-events:auto}
.toast.ok{border-left:3px solid var(--good)}
.toast.err{border-left:3px solid var(--bad)}

/* ====== LOGIN PAGE — split layout (видео слева, форма справа) ====== */
.login-page{min-height:100vh;display:block;padding:0;background:var(--bg)}
.login-page.split{overflow:hidden}
.split-stage{position:relative;display:flex;width:100%;height:100vh;height:100dvh;align-items:stretch;background:var(--bg)}

/* === ЛЕВАЯ ПОЛОВИНА — видео в исходных пропорциях (9:16) === */
.split-left{
  position:relative;flex:0 0 clamp(320px, 30vw, 460px);min-width:0;
  display:flex;align-items:stretch;justify-content:center;
  padding:24px 14px 24px 24px;
  background:transparent;
}
.split-video-frame{
  position:relative;flex:1 1 auto;
  border-radius:22px;overflow:hidden;
  background:#0a0d14;
  box-shadow:0 30px 80px rgba(20,20,60,.18), 0 0 0 1px rgba(124,93,250,.18);
  isolation:isolate;
}
html[data-theme="dark"] .split-video-frame{box-shadow:0 30px 80px rgba(0,0,0,.55), 0 0 0 1px rgba(124,93,250,.30)}
.split-video{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  /* без фильтров — максимальное качество */
}
.split-left-veil{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(10,13,24,.10) 0%, rgba(10,13,24,.0) 25%, rgba(10,13,24,.0) 55%, rgba(10,13,24,.55) 100%),
    linear-gradient(180deg, rgba(10,13,24,.40) 0%, rgba(10,13,24,.0) 35%);
  pointer-events:none;
}
.split-left-content{
  position:absolute;inset:0;z-index:2;
  display:flex;flex-direction:column;justify-content:space-between;
  padding:24px 22px;
  color:#fff;pointer-events:none;
}
.split-left-content > *{pointer-events:auto}
.split-bottom{display:flex;flex-direction:column;gap:6px}

.split-brand{display:flex;align-items:center;gap:11px}
.split-brand-mark{width:38px;height:38px;flex-shrink:0;
  filter:drop-shadow(0 8px 24px rgba(124,93,250,.55))}
.split-brand-text{font-family:'Sora','Inter';font-weight:800;font-size:17px;color:#fff;display:flex;flex-direction:column;line-height:1.05;letter-spacing:-.01em}
.split-brand-text b{font-weight:800}
.split-brand-text i{font-style:normal;font-weight:600;color:#c5b8ff;margin-left:2px}
.split-brand-text small{font-family:'Inter';font-size:9.5px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.70);margin-top:3px}

.split-title{
  font-family:'Sora','Inter';font-weight:800;
  font-size:clamp(22px,2.0vw,30px);line-height:1.10;letter-spacing:-.02em;
  margin:0;
  text-shadow:0 4px 30px rgba(0,0,0,.55);
}
.split-title span{
  background:linear-gradient(135deg,#c5b8ff 0%,#7c5dfa 50%,#a18bff 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.split-sub{font-size:12.5px;line-height:1.45;color:rgba(255,255,255,.86);max-width:380px;margin:6px 0 0;
  text-shadow:0 2px 16px rgba(0,0,0,.50)}

/* === ГРАНЬ между колонками: вертикальная стеклянная полоса с градиентом === */
.split-edge{
  position:absolute;top:0;right:0;width:14px;height:100%;
  pointer-events:none;
  display:flex;align-items:center;justify-content:center;
}
.split-edge::before{
  content:"";position:absolute;top:8%;right:6px;width:1px;height:84%;
  background:linear-gradient(180deg,
    transparent 0%,
    rgba(124,93,250,.0) 5%,
    rgba(124,93,250,.55) 35%,
    rgba(167,139,250,.95) 50%,
    rgba(124,93,250,.55) 65%,
    rgba(124,93,250,.0) 95%,
    transparent 100%);
  box-shadow:
    0 0 12px rgba(124,93,250,.45),
    0 0 28px rgba(124,93,250,.25);
}
.edge-glow{
  position:absolute;top:50%;right:6px;width:1px;height:120px;
  transform:translateY(-50%);
  background:linear-gradient(180deg,transparent,#fff,transparent);
  filter:blur(2px);
  animation:edgePulse 3.5s ease-in-out infinite;
}
@keyframes edgePulse{
  0%,100%{opacity:.4;height:120px}
  50%{opacity:1;height:240px}
}

/* === ПРАВАЯ ПОЛОВИНА — форма === */
.split-right{
  position:relative;flex:1 1 auto;min-width:0;
  display:flex;align-items:center;justify-content:center;
  padding:40px 48px;
  background:var(--bg);
}
html[data-theme="dark"] .split-right{background:var(--bg)}
.split-right-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.orb-r{position:absolute;border-radius:50%;filter:blur(80px);opacity:.30;mix-blend-mode:screen}
.orb-r-1{width:380px;height:380px;background:#a78bfa;top:-10%;right:-10%;animation:orbA 22s ease-in-out infinite alternate}
.orb-r-2{width:300px;height:300px;background:#7c5dfa;bottom:-10%;left:10%;animation:orbB 26s ease-in-out infinite alternate}
html[data-theme="dark"] .orb-r-1{opacity:.40}
html[data-theme="dark"] .orb-r-2{opacity:.30}
@keyframes orbA{0%{transform:translate(0,0) scale(1)}100%{transform:translate(40px,30px) scale(1.18)}}
@keyframes orbB{0%{transform:translate(0,0) scale(1)}100%{transform:translate(-50px,40px) scale(1.12)}}

.login-card{
  position:relative;z-index:2;
  width:100%;max-width:420px;padding:36px 32px 28px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:22px;
  box-shadow:0 24px 60px rgba(20,28,58,.10),0 4px 14px rgba(20,28,58,.04);
  animation:popIn .55s cubic-bezier(.2,.7,.2,1.1) both;
}
html[data-theme="dark"] .login-card{
  background:var(--surface);
  border-color:var(--line);
  box-shadow:0 24px 60px rgba(0,0,0,.45),0 4px 14px rgba(0,0,0,.30);
}
.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.login-brand .mark{width:42px;height:42px;flex-shrink:0;filter:drop-shadow(0 8px 20px rgba(124,93,250,.45))}
.login-brand .name{font-family:'Sora','Inter';font-weight:800;font-size:20px;color:var(--ink);display:flex;flex-direction:column;line-height:1.05;letter-spacing:-.01em}
.login-brand .name b{font-weight:800}
.login-brand .name i{font-style:normal;font-weight:600;color:var(--accent);margin-left:2px}
.login-brand .name small{font-family:'Inter';font-size:10.5px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin-top:2px}
.login-h2{font-family:'Sora';font-weight:700;font-size:22px;color:var(--ink);margin:18px 0 4px;letter-spacing:-.01em}
.login-sub{font-size:13.5px;color:var(--ink-soft);margin:0 0 22px}
#login-form .field{margin-bottom:14px}
#login-form input{padding:12px 14px;font-size:14px;background:var(--surface-2);border:1px solid var(--line)}
.login-btn{width:100%;padding:13px 18px;border-radius:12px;background:var(--grad);color:#fff;font-weight:700;font-size:14.5px;
  display:flex;align-items:center;justify-content:center;gap:10px;
  box-shadow:0 10px 28px rgba(124,93,250,.40);transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden;margin-top:4px}
.login-btn:hover{transform:translateY(-1px);box-shadow:0 14px 38px rgba(124,93,250,.55)}
.login-btn:disabled{opacity:.7;cursor:wait}
.login-btn::after{content:"";position:absolute;top:0;left:-90%;width:55%;height:100%;background:linear-gradient(110deg,transparent,rgba(255,255,255,.4),transparent);transform:skewX(-18deg);animation:shimmerBtn 4s ease-in-out infinite}
@keyframes shimmerBtn{0%,100%{left:-90%}55%,70%{left:150%}}
.login-err{margin-top:14px;font-size:12.5px;color:var(--bad);min-height:18px}
.login-foot{margin-top:18px;text-align:center;font-size:11.5px;color:var(--ink-mute);letter-spacing:.04em}

/* === MOBILE: видео сверху узкой полосой, форма снизу === */
@media (max-width:980px){
  .split-stage{flex-direction:column;height:auto;min-height:100vh}
  .split-left{order:1;flex:0 0 auto;padding:14px 14px 0;height:46vh;min-height:280px}
  .split-video-frame{width:100%;height:100%;border-radius:18px}
  .split-left-content{padding:18px 18px 22px}
  .split-title{font-size:clamp(20px,5vw,28px)}
  .split-sub{font-size:12px}
  .split-edge{display:none}
  .split-right{order:2;flex:1 1 auto;padding:28px 18px 28px;align-items:flex-start}
  .login-card{padding:28px 22px 22px;border-radius:18px;max-width:560px}
}
@media (max-width:560px){
  .split-left{height:40vh;min-height:240px;padding:12px 12px 0}
  .split-video-frame{border-radius:16px}
  .split-left-content{padding:14px 14px 18px}
  .split-brand-text{font-size:15px}
  .split-brand-mark{width:34px;height:34px}
  .login-card{padding:26px 20px 20px;border-radius:16px}
}

body:not(.login-page) .bg-stage{display:none!important}
