:root{
  --bg:#f5f6f8; --card:#fff; --ink:#15171c; --ink-dim:#52555e; --ink-faint:#8a8f99;
  --line:#e7e8ec; --line-soft:#eef0f3;
  --accent:#1f5cff; --accent-deep:#1545d6; --accent-soft:#eef3ff;
  --green:#16a06a; --green-soft:#e7f6ef;
  --blue:#2b86ff; --blue-soft:#e9f2ff;
  --amber:#c98a00; --amber-soft:#fbf2dc;
  --red:#e5484d; --red-soft:#fdeced;
  --gray-soft:#eef0f3;
  --shadow:0 18px 44px -22px rgba(20,30,55,.22);
  --shadow-sm:0 6px 18px -10px rgba(20,30,55,.16);
  --r:16px;
}
*{margin:0;padding:0;box-sizing:border-box}
body{background:var(--bg);color:var(--ink);font-family:'Onest',sans-serif;font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased}

/* header */
header{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.82);backdrop-filter:saturate(180%) blur(16px);border-bottom:1px solid var(--line)}
.bar{max-width:1120px;margin:0 auto;padding:0 24px;height:62px;display:flex;align-items:center;gap:28px}
.logo{display:flex;align-items:center;gap:9px;font-weight:700;font-size:20px;letter-spacing:-.01em}
a.logo{text-decoration:none;color:inherit}
.logo .mark{width:30px;height:30px;background:url(/logo-icon.svg) center/contain no-repeat;flex-shrink:0}
.logo .mark::after{display:none}
.logo .wm .b{background:linear-gradient(135deg,#4F6EF7,#8B5CF6);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.tabs{display:flex;gap:6px}
.tab{background:none;border:none;font-family:inherit;font-size:15px;font-weight:600;color:var(--ink-dim);
  padding:8px 16px;border-radius:980px;cursor:pointer;transition:background .2s,color .2s}
.tab:hover{color:var(--ink)}
.tab.active{background:var(--accent-soft);color:var(--accent)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:12px}
.mode-badge{font-size:13px;font-weight:600;color:var(--ink-faint);background:var(--gray-soft);padding:6px 12px;border-radius:980px}
.user-name{font-size:14px;font-weight:600;color:var(--ink-dim)}
.plan-badge{font-size:12px;font-weight:700;text-transform:capitalize;color:var(--accent);background:var(--accent-soft);padding:4px 11px;border-radius:980px}
.plan-badge.free{color:var(--ink-faint);background:var(--gray-soft)}

/* layout */
main{max-width:1120px;margin:0 auto;padding:34px 24px 90px}
.tabpanel{display:none;animation:fade .4s ease}
.tabpanel.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.grid-2{display:grid;grid-template-columns:1fr 1.4fr;gap:22px;align-items:start}
@media(max-width:860px){.grid-2{grid-template-columns:1fr}}

.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:28px;box-shadow:var(--shadow-sm)}
.panel + .status,.panel + .dashboard{margin-top:22px}
h2{font-size:22px;font-weight:700;letter-spacing:-.02em;margin-bottom:8px}
h3{font-size:15px;font-weight:700;margin:24px 0 10px}
.hint{color:var(--ink-dim);font-size:15px;margin-bottom:18px}
.muted{color:var(--ink-faint);font-weight:400;font-size:13px}

/* form */
.field{margin-bottom:18px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--ink-dim);margin-bottom:8px}
select,input[type=text],input[type=email],input[type=password],input:not([type]){width:100%;font-family:inherit;
  font-size:15px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:12px;padding:13px 15px;
  transition:border-color .2s,box-shadow .2s}
select:focus,input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(31,92,255,.14)}
.pw-wrap{position:relative}
.pw-wrap input{padding-right:46px}
.pw-eye{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;
  color:var(--ink-faint);padding:6px;border-radius:8px;display:grid;place-items:center;line-height:0}
.pw-eye:hover{color:var(--ink-dim);background:var(--gray-soft)}
.pw-eye svg{width:20px;height:20px}
.field-msg{font-size:13px;margin-top:6px;min-height:15px}
.field-msg.err{color:var(--red)}
.field-msg.ok{color:var(--green)}
.fb-ic{width:18px;height:18px;vertical-align:-4px;color:var(--green);margin-right:4px}
input[type=range]{width:100%;accent-color:var(--accent)}
.add-row{display:flex;gap:10px;margin-bottom:12px}
.add-row input{flex:1}

.checks{display:flex;flex-wrap:wrap;gap:10px}
.chk{display:flex;align-items:center;gap:9px;border:1px solid var(--line);border-radius:10px;padding:9px 13px;cursor:pointer;font-size:14px;transition:border-color .2s,background .2s}
.chk:hover{border-color:#cfd3db}
.chk input{width:auto;accent-color:var(--accent)}
.chk .tag{font-size:11px;font-weight:700;padding:2px 7px;border-radius:980px;text-transform:uppercase;letter-spacing:.03em}
.chk .tag.real{background:var(--green-soft);color:var(--green)}
.chk .tag.mock{background:var(--gray-soft);color:var(--ink-faint)}

/* buttons */
.btn{font-family:inherit;font-weight:600;font-size:16px;background:var(--accent);color:#fff;border:none;
  border-radius:980px;padding:13px 26px;cursor:pointer;transition:background .2s,transform .15s,box-shadow .25s}
.btn:hover{background:var(--accent-deep);transform:translateY(-1px);box-shadow:0 12px 26px -10px rgba(31,92,255,.5)}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}
.btn.sm{padding:10px 18px;font-size:14px}
.btn.ghost{background:var(--gray-soft);color:var(--ink)}
.btn.ghost:hover{background:#e4e7ec;box-shadow:none}

/* lists */
.list{list-style:none;display:flex;flex-direction:column;gap:8px}
.list li{display:flex;align-items:center;gap:10px;justify-content:space-between;background:#fff;border:1px solid var(--line);
  border-radius:10px;padding:11px 14px;font-size:15px}
.list li .txt{flex:1}
.list li.active{border-color:var(--accent);background:var(--accent-soft)}
.list li.clickable{cursor:pointer;transition:border-color .2s,background .2s}
.list li.clickable:hover{border-color:#cfd3db}
.del{background:none;border:none;color:var(--ink-faint);cursor:pointer;font-size:15px;padding:2px 6px;border-radius:6px;transition:color .2s,background .2s}
.del:hover{color:var(--red);background:var(--red-soft)}
.empty{color:var(--ink-faint);font-size:14px;font-style:italic;padding:6px 2px}

/* status */
.status{background:var(--accent-soft);border:1px solid #d6e2ff;color:var(--accent-deep);border-radius:12px;padding:16px 20px;font-size:15px;font-weight:500}
.status.err{background:var(--red-soft);border-color:#f6cccf;color:#b42318}

/* dashboard */
.dashboard{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:18px;margin-top:22px}
.run-meta{grid-column:1/-1;display:flex;flex-wrap:wrap;gap:8px 22px;align-items:baseline;margin-bottom:2px}
.run-meta h2{margin:0}
.run-meta .q{color:var(--ink-dim);font-size:15px}
.run-meta .q b{color:var(--ink)}

.netcard{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:22px;box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;gap:14px;animation:fade .4s ease}
.netcard.unavailable{opacity:.7}
.nc-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.nc-name{display:flex;align-items:center;gap:10px;font-weight:700;font-size:17px}
.nc-ic{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;font-weight:700;font-size:13px;color:#fff;background:var(--accent)}
/* Реальные логотипы нейросетей (Simple Icons): на светлой плашке, фирменный цвет */
.nc-ic.nc-ic-logo{background:#fff;border:1px solid var(--line)}
.nc-ic.nc-ic-logo img,.nc-ic.nc-ic-logo svg{width:18px;height:18px;object-fit:contain;display:block}
.nc-mode{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:3px 8px;border-radius:980px}
.nc-mode.real{background:var(--green-soft);color:var(--green)}
.nc-mode.mock{background:var(--gray-soft);color:var(--ink-faint)}

.nc-metrics{display:flex;gap:10px}
.metric{flex:1;background:var(--bg);border-radius:12px;padding:13px}
.metric .l{font-size:12px;color:var(--ink-faint);font-weight:600;margin-bottom:5px}
.metric .v{font-size:24px;font-weight:800;letter-spacing:-.02em}

.badge{display:inline-flex;align-items:center;font-size:13px;font-weight:700;padding:5px 11px;border-radius:980px;white-space:nowrap}
.badge.pos{color:var(--green);background:var(--green-soft)}
.badge.neu{color:var(--blue);background:var(--blue-soft)}
.badge.mixed{color:var(--amber);background:var(--amber-soft)}
.badge.neg{color:var(--red);background:var(--red-soft)}
.badge.none{color:var(--ink-faint);background:var(--gray-soft)}

/* .stab-bar / .stab-pct оставлены — используются в блоке «Соответствие УТП» */
.stab-bar{flex:1;height:7px;border-radius:99px;background:var(--bg);overflow:hidden}
.stab-bar i{display:block;height:100%;border-radius:99px}
.stab-pct{font-weight:700;font-variant-numeric:tabular-nums}

/* 0-состояние подаём как инсайт, а не как «пусто» */
.nc-insight{font-size:13px;line-height:1.45;color:var(--ink-dim);background:var(--gray-soft);
  border-left:3px solid var(--accent);border-radius:6px;padding:8px 10px}

.nc-block .t,.nc-ni-top .t{font-size:12px;font-weight:700;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.04em;margin-bottom:7px}
/* НейроИндекс — главный показатель, наверху карточки по центру */
.nc-ni-top{text-align:center;padding:2px 0 4px;border-bottom:1px solid var(--line-soft)}
.nc-ni-top .neuroindex{justify-content:center}
.chips{display:flex;flex-wrap:wrap;gap:6px}
.chip{font-size:13px;background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:5px 10px;color:var(--ink-dim)}
.narr{font-size:13.5px;color:var(--ink-dim);line-height:1.45}
.narr li{margin-left:16px;margin-bottom:4px}

/* Упомянутые бренды */
.chip.brand{font-variant-numeric:tabular-nums}
.chip.brand.own{background:var(--accent-soft);border-color:#cfdcff;color:var(--accent);font-weight:700}

/* Саммари ответов + соответствие УТП */
.ai-gist{font-size:13.5px;color:var(--ink-dim);line-height:1.45;margin-bottom:8px}
.utp{display:flex;align-items:center;gap:10px;font-size:13px}
.utp-l{color:var(--ink-faint);font-weight:600;white-space:nowrap}
.stab-bar i.utp-fill{background:linear-gradient(90deg,#4F6EF7,#8B5CF6)}

/* Нейроиндекс: число + мини-график в стиле логотипа */
.neuroindex{display:flex;align-items:flex-end;gap:14px}
.ni-num{font-size:32px;font-weight:800;letter-spacing:-.02em;line-height:1;
  background:linear-gradient(135deg,#4F6EF7,#8B5CF6);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;font-variant-numeric:tabular-nums}
.ni-chart{position:relative;display:flex;align-items:flex-end;gap:4px;height:34px;padding-top:6px}
.ni-bar{width:6px;border-radius:3px;background:var(--line);transition:background .2s}
.ni-bar.lit{background:linear-gradient(180deg,#8B5CF6,#4F6EF7)}
.ni-dot{position:absolute;top:0;right:0;width:6px;height:6px;border-radius:50%;background:#8B5CF6}
/* Тот же компонент НейроИндекса в свёрнутом баре бренда (компактный) */
.neuroindex.ni-sm{display:inline-flex;gap:7px;vertical-align:middle}
.neuroindex.ni-sm .ni-num{font-size:16px}
.neuroindex.ni-sm .ni-chart{height:16px;gap:2.5px;padding-top:3px}
.neuroindex.ni-sm .ni-bar{width:3.5px}
.neuroindex.ni-sm .ni-dot{width:4px;height:4px}
.mini.ni-mini{gap:7px}
/* Тот же компонент НейроИндекса в блоке «Средние оценки» — крупный, по центру
   своей колонки, без серого бокса avg-card (см. .avg-ni ниже) */
.avg-ni .neuroindex{justify-content:center;gap:16px;margin:2px 0}
.avg-ni .neuroindex .ni-num{font-size:34px}
.avg-ni .neuroindex .ni-chart{height:36px}

.gen-btn{margin-top:auto;align-self:flex-start;background:none;border:1px solid var(--line);color:var(--accent);
  font-family:inherit;font-weight:600;font-size:14px;padding:9px 16px;border-radius:980px;cursor:pointer;transition:background .2s,border-color .2s}
.gen-btn:hover{background:var(--accent-soft);border-color:#cfdcff}

/* ===== auth / onboarding pages ===== */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px 20px}
.auth-card{background:var(--card);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);
  width:100%;max-width:420px;padding:38px 34px}
.auth-card .logo{justify-content:center;margin-bottom:8px}
.auth-card h1{font-size:24px;font-weight:800;letter-spacing:-.02em;text-align:center;margin-bottom:6px}
.auth-card .sub{color:var(--ink-dim);font-size:15px;text-align:center;margin-bottom:26px}
.auth-card .btn{width:100%;justify-content:center;margin-top:6px}
.auth-alt{text-align:center;margin-top:20px;font-size:15px;color:var(--ink-dim)}
.auth-alt a{color:var(--accent);font-weight:600;text-decoration:none}
.auth-err{background:var(--red-soft);color:#b42318;border:1px solid #f6cccf;border-radius:10px;
  padding:11px 14px;font-size:14px;margin-bottom:16px;display:none}
.auth-err.show{display:block}

/* wizard */
.wiz-top{position:sticky;top:0;z-index:30;background:rgba(255,255,255,.85);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line)}
.wiz-top .bar{max-width:760px;margin:0 auto;padding:0 24px;height:62px;display:flex;align-items:center;justify-content:space-between}
.wiz-top .logo{font-weight:700;font-size:20px;display:flex;align-items:center;gap:9px}
.wiz-top .logo .mark{width:30px;height:30px;background:url(/logo-icon.svg) center/contain no-repeat;flex-shrink:0}
.wiz-top .logo .mark::after{display:none}
.wiz-top .login-link{color:var(--ink-dim);font-size:15px;font-weight:600;text-decoration:none}
.wiz-top .login-link:hover{color:var(--ink)}
.wizard{max-width:620px;margin:0 auto;padding:34px 24px 90px}
.free-banner{background:linear-gradient(120deg,var(--accent-soft),#eafaf2);border:1px solid #d6e2ff;
  border-radius:12px;padding:13px 16px;font-size:15px;color:var(--ink);margin-bottom:20px;text-align:center}
.free-banner b{color:var(--green)}
.progress{display:flex;gap:8px;margin-bottom:12px}
.prog-cap{font-size:13px;font-weight:600;color:var(--accent);margin-bottom:26px}
.progress .seg{flex:1;height:5px;border-radius:99px;background:var(--line);transition:background .3s}
.progress .seg.done{background:var(--accent)}
.step{display:none;animation:fade .4s ease}
.step.active{display:block}
.step .step-n{font-size:13px;font-weight:700;color:var(--accent);letter-spacing:.04em;margin-bottom:10px}
.step h2{font-size:26px;font-weight:800;letter-spacing:-.02em;margin-bottom:8px}
.step .note{color:var(--ink-dim);font-size:15px;margin-bottom:22px;line-height:1.5}
.step .note.example{background:var(--accent-soft);border-radius:12px;padding:13px 16px;color:var(--ink-dim)}
.step textarea{width:100%;font-family:inherit;font-size:15px;color:var(--ink);background:#fff;border:1px solid var(--line);
  border-radius:12px;padding:13px 15px;min-height:90px;resize:vertical;transition:border-color .2s,box-shadow .2s}
.step textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(31,92,255,.14)}
.wiz-nav{display:flex;justify-content:space-between;gap:12px;margin-top:30px}
.wiz-nav .btn.back{background:var(--gray-soft);color:var(--ink)}
.wiz-nav .btn.back:hover{background:#e4e7ec;box-shadow:none}

.suggest-box{margin:6px 0 18px}
.suggest-box .btn{font-size:14px;padding:10px 18px}
.suggestions{display:flex;flex-direction:column;gap:8px;margin-top:12px}
.suggestion{text-align:left;background:var(--accent-soft);border:1px solid #d6e2ff;border-radius:10px;
  padding:11px 14px;font-size:14px;color:var(--ink);cursor:pointer;transition:background .2s,border-color .2s}
.suggestion:hover{background:#e2ebff;border-color:#b9d0ff}
.suggesting{color:var(--ink-faint);font-size:14px;margin-top:10px}

.test-note{background:var(--amber-soft);color:#8a6400;border-radius:10px;padding:12px 15px;font-size:14px;margin-top:16px}

/* tariff cards */
.tariffs{margin-top:40px}
.tariffs h3{font-size:18px;font-weight:700;margin-bottom:16px;text-align:center}
.tariff-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}
.tariff{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px;display:flex;flex-direction:column;gap:6px}
.tariff.pro{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.tariff .tname{font-weight:800;font-size:17px}
.tariff .tprice{font-size:22px;font-weight:800;letter-spacing:-.02em;color:var(--accent);margin:4px 0 8px}
.tariff ul{list-style:none;display:flex;flex-direction:column;gap:6px;font-size:13.5px;color:var(--ink-dim)}
.tariff li::before{content:"✓ ";color:var(--green);font-weight:700}

.run-progress{text-align:center;padding:60px 20px}
.run-progress .spinner{width:42px;height:42px;border:4px solid var(--line);border-top-color:var(--accent);
  border-radius:50%;margin:0 auto 20px;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.run-progress h2{font-size:22px;margin-bottom:8px}
.run-progress p{color:var(--ink-dim)}
.run-progress .run-facts{color:var(--accent);font-weight:600;font-size:15px;margin-top:12px;min-height:46px;
  max-width:440px;margin-left:auto;margin-right:auto;line-height:1.45;opacity:1;transition:opacity .25s ease}

.tariff-offer{text-align:center;margin-top:16px;font-size:14px}
.tariff-offer a{color:var(--accent);text-decoration:none;font-weight:600}
.tariff-offer a:hover{text-decoration:underline}
.legal-footer{max-width:1120px;margin:0 auto;padding:22px 24px 40px;color:var(--ink-faint);font-size:12.5px;line-height:1.6;text-align:center}
.legal-footer a{color:var(--ink-faint);text-decoration:underline;text-underline-offset:2px}
.legal-footer a:hover{color:var(--ink-dim)}
.dash-replay{text-align:center;margin:26px 0 10px}
.link-muted{background:none;border:none;color:var(--ink-faint);font-family:inherit;font-size:13.5px;
  cursor:pointer;text-decoration:underline;text-underline-offset:3px}
.link-muted:hover{color:var(--ink-dim)}

/* ===== интерактивный тур ===== */
.tour{position:fixed;inset:0;z-index:200}
.tour[hidden]{display:none}
.tour-spot{position:absolute;border-radius:12px;box-shadow:0 0 0 9999px rgba(15,17,22,.66);
  pointer-events:none;border:2px solid var(--accent)}
.tour-card{position:absolute;width:340px;max-width:calc(100vw - 28px);background:#fff;border-radius:26px;padding:22px 24px;
  box-shadow:0 30px 70px -20px rgba(0,0,0,.5)}
.tour-arrow{position:absolute;left:26px;width:50px;height:50px;color:var(--accent);pointer-events:none;display:none}
.tour-card.below .tour-arrow{display:block;top:-44px}
.tour-card.above .tour-arrow{display:block;bottom:-44px;transform:scaleY(-1)}
.tour-arrow svg{width:100%;height:100%}
.tour-step{font-size:12px;font-weight:700;color:var(--accent);letter-spacing:.04em;margin-bottom:8px}
.tour-text{font-size:15.5px;line-height:1.5;color:var(--ink)}
.tour-text b{color:var(--accent)}
.tour-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:16px}
.tour-skip{background:none;border:none;color:var(--ink-faint);font-family:inherit;font-size:13px;cursor:pointer;padding:4px}
.tour-skip:hover{color:var(--ink)}
.tour-hint{font-size:13px;font-weight:600;color:var(--accent)}

/* ===== авто-замер ===== */
.auto-box{margin-top:8px}
.auto-cfg{margin-top:6px}
.help{display:inline-grid;place-items:center;width:18px;height:18px;border-radius:50%;background:var(--gray-soft);
  color:var(--ink-faint);font-size:12px;font-weight:700;cursor:help;margin-left:5px}
.auto-status{font-size:13px;margin-top:10px}

/* ===== админка ===== */
.admin-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.admin-table th,.admin-table td{padding:13px 16px;text-align:left;border-bottom:1px solid var(--line-soft);vertical-align:top;font-size:14px}
.admin-table th{background:var(--bg-alt);font-weight:700;color:var(--ink-dim);white-space:nowrap}
.admin-table tr:last-child td{border-bottom:none}
.admin-table .sub{color:var(--ink-dim);font-size:13px}
.admin-table select{padding:7px 10px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:14px}
.admin-brand{font-weight:600}
.admin-prompts{color:var(--ink-dim);font-size:13px;margin:3px 0 8px;padding-left:14px}

/* ===== dashboard (Этап 2) ===== */
.dash-section{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-sm);
  padding:24px 26px;margin-bottom:20px}
.dash-h{font-size:19px;font-weight:700;letter-spacing:-.01em;margin-bottom:4px}
.dash-section .hint{margin-bottom:18px}
/* тулбар периода/масштаба над графиком */
.chart-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:12px}
.ct-btn{font-family:inherit;font-size:12px;font-weight:600;color:var(--ink-dim);background:var(--gray-soft);
  border:1px solid var(--line);border-radius:980px;padding:5px 12px;cursor:pointer;transition:background .15s,color .15s,border-color .15s}
.ct-btn:hover{border-color:#cfd3db}
.ct-btn.active{background:var(--accent-soft);color:var(--accent);border-color:#d6e2ff}
.ct-nav{font-family:inherit;font-size:15px;font-weight:700;line-height:1;color:var(--ink-dim);background:var(--gray-soft);
  border:1px solid var(--line);border-radius:8px;width:26px;height:26px;cursor:pointer;display:grid;place-items:center}
.ct-nav:hover{border-color:#cfd3db;color:var(--ink)}
.ct-nav:disabled{opacity:.4;cursor:not-allowed}
.ct-range{font-size:13px;font-weight:600;color:var(--ink-faint);margin-left:4px}
.chart-wrap{position:relative;height:300px}
.net-charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:18px}
.net-chart{border:1px solid var(--line);border-radius:14px;padding:16px}
.net-chart .nc-title{font-weight:700;font-size:15px;margin-bottom:10px;display:flex;align-items:center;gap:9px}
.net-chart .nc-dot{width:12px;height:12px;border-radius:4px}
.net-chart .chart-wrap{height:220px}

.sum-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.sum-head .dash-h{margin:0}
.summary-box{background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:18px 20px;
  font-size:15.5px;line-height:1.6;color:var(--ink);white-space:pre-wrap;min-height:60px}
.summary-box.loading{color:var(--ink-faint)}
.summary-at{font-size:12px;color:var(--ink-faint);margin-top:8px}

.averages{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;align-items:stretch}
.avg-card{background:var(--bg);border:1px solid var(--line);border-radius:14px;padding:22px;text-align:center}
.avg-card .l{font-size:13px;color:var(--ink-faint);font-weight:600;margin-bottom:8px}
.avg-card .v{font-size:34px;font-weight:800;letter-spacing:-.03em}
.avg-card .v.tone-pos{color:var(--green)}
.avg-card .v.tone-neu{color:var(--blue)}
.avg-card .v.tone-neg{color:var(--red)}
.avg-card .v.tone-none{color:var(--ink-faint)}
/* НейроИндекс — центральная колонка без серого бокса, центр по верт./гориз. */
.avg-ni{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:22px 12px}
.avg-ni .l{font-size:13px;color:var(--ink-faint);font-weight:600;margin-bottom:8px}
@media(max-width:560px){.averages{grid-template-columns:1fr}}
.avg-trend{margin-top:10px}

/* per-brand collapsible blocks */
.brand-block{border:1px solid var(--line);border-radius:var(--r);background:var(--bg-alt);box-shadow:var(--shadow-sm);margin-bottom:18px;overflow:hidden}
.brand-head{display:flex;align-items:center;gap:12px;padding:18px 22px;cursor:pointer;user-select:none}
.brand-head:hover{background:rgba(31,92,255,.03)}
.brand-head .caret{color:var(--ink-faint);font-size:13px;transition:transform .2s}
.brand-block.open > .brand-head .caret{transform:rotate(90deg)}
.brand-name{font-weight:700;font-size:18px;letter-spacing:-.01em}
.brand-compact{margin-left:auto;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.brand-block.open > .brand-head .brand-compact{display:none}
.mini{font-size:13px;color:var(--ink-dim);display:inline-flex;align-items:center;gap:6px}
.mini b{color:var(--ink);font-weight:700}
.tone-mini{font-size:12px;font-weight:700;padding:3px 10px;border-radius:980px}
.tone-mini.tone-pos{color:var(--green);background:var(--green-soft)}
.tone-mini.tone-neu{color:var(--blue);background:var(--blue-soft)}
.tone-mini.tone-neg{color:var(--red);background:var(--red-soft)}
.tone-mini.tone-none{color:var(--ink-faint);background:var(--gray-soft)}
.trend{font-weight:700;font-size:13px;display:inline-flex;align-items:center;gap:3px}
.trend.up{color:var(--green)}
.trend.down{color:var(--red)}
.trend.flat{color:var(--ink-faint)}
.brand-body{display:none;padding:0 18px 18px}
.brand-block.open > .brand-body{display:block}

/* «Последний замер» — сворачиваемая подсекция */
.dash-section.sub{background:#fff}
.lr-sec .sec-head{cursor:pointer;user-select:none;display:flex;align-items:center;gap:8px;font-size:16px;font-weight:700}
.lr-sec .sec-head .caret{color:var(--ink-faint);font-size:12px;transition:transform .2s}
.lr-sec.open .sec-head .caret{transform:rotate(90deg)}
.lr-sec .sec-body{display:none;margin-top:16px}
.lr-sec.open .sec-body{display:block}
/* Селект выбора промта в заголовке «Последнего замера» (компактный, не растягивается) */
.lr-prompt-sel{width:auto;max-width:300px;margin-left:auto;font-size:13px;font-weight:600;
  color:var(--ink-dim);padding:7px 11px;border-radius:10px;cursor:pointer}

.chip.link{color:var(--accent);text-decoration:none;border-color:#cfdcff;cursor:pointer}
.chip.link:hover{background:var(--accent-soft)}

/* history table */
.hist-head{margin-bottom:22px}
.hist-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-sm);margin-bottom:22px;overflow:hidden}
.hist-card-head{padding:20px 24px;border-bottom:1px solid var(--line);display:flex;flex-wrap:wrap;align-items:baseline;gap:6px 14px}
.hc-brand{font-weight:700;font-size:17px}
.hc-prompt{color:var(--ink-dim);font-size:15px}
.hist-table-wrap{overflow-x:auto}
.hist-table{border-collapse:collapse;width:100%;min-width:max-content}
.hist-table th,.hist-table td{border-bottom:1px solid var(--line-soft);border-right:1px solid var(--line-soft);padding:12px 16px;text-align:center;vertical-align:middle}
.hist-table th:last-child,.hist-table td:last-child{border-right:none}
.hist-table thead th{background:var(--bg);font-size:13px;font-weight:700;color:var(--ink-dim);white-space:nowrap;position:sticky;top:0}
.hist-table th.th-sub{font-weight:400}
.hist-table .th-sub{display:block;font-size:11px;font-weight:400;color:var(--ink-faint);margin-top:2px}
.hist-table .rowhead{text-align:left;font-weight:600;font-size:14px;background:var(--bg);white-space:nowrap;position:sticky;left:0;z-index:1}
.hist-table tbody tr:last-child td{border-bottom:none}

.cell{display:flex;flex-direction:column;align-items:center;gap:5px;min-width:88px}
.cell-m{font-size:20px;font-weight:800;letter-spacing:-.02em;display:inline-flex;align-items:center;gap:5px}
.cell-m .tr{font-size:12px;font-weight:700}
.tr.up{color:var(--green)}
.tr.down{color:var(--red)}
.tr.eq{color:var(--ink-faint)}
.cell-t .tone{font-size:11px;font-weight:700;padding:3px 9px;border-radius:980px;white-space:nowrap}
.cell-t .tone.pos{color:var(--green);background:var(--green-soft)}
.cell-t .tone.neu{color:var(--blue);background:var(--blue-soft)}
.cell-t .tone.mixed{color:var(--amber);background:var(--amber-soft)}
.cell-t .tone.neg{color:var(--red);background:var(--red-soft)}
.cell-t .tone.none{color:var(--ink-faint);background:var(--gray-soft)}
.cell-s{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--ink-dim);font-variant-numeric:tabular-nums}
.cell-s .dot{width:8px;height:8px;border-radius:50%}
.cell-s .dot.ok{background:var(--green)}
.cell-s .dot.bad{background:var(--red)}
.cell-na{font-size:13px;color:var(--red);font-weight:600}
.cell-empty{color:var(--ink-faint)}

/* modal */
.modal{position:fixed;inset:0;z-index:80;background:rgba(15,17,22,.55);display:flex;align-items:center;justify-content:center;padding:24px;animation:fade .25s ease}
.modal[hidden]{display:none}
.modal-card{background:#fff;border-radius:18px;max-width:760px;width:100%;max-height:84vh;display:flex;flex-direction:column;box-shadow:0 40px 90px -30px rgba(0,0,0,.5)}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--line)}
.modal-head h3{margin:0;font-size:18px}
.x{background:none;border:none;font-size:18px;color:var(--ink-faint);cursor:pointer;padding:4px 8px;border-radius:8px}
.x:hover{background:var(--gray-soft);color:var(--ink)}
.draft{padding:24px;overflow:auto;white-space:pre-wrap;font-family:'Onest',monospace;font-size:14.5px;line-height:1.6;color:var(--ink)}
/* ===== мобильная адаптация ===== */
@media(max-width:680px){
  main{padding:22px 16px 80px}
  .bar{gap:10px;padding:0 14px}
  .logo{font-size:17px;gap:7px}
  .tabs{gap:3px}
  .tab{padding:7px 10px;font-size:13px}
  .nav-right{gap:8px}
  .mode-badge,.user-name{display:none}
  .dash-section{padding:18px 16px}
  .brand-head{padding:15px 16px}
  .brand-body{padding:0 12px 14px}
  .brand-name{font-size:16px}
  .brand-compact{gap:10px}
  .tour-card{padding:18px;border-radius:20px;width:300px}
  .wizard{padding:24px 16px 88px}
  .run-progress{padding:40px 16px}
  /* «Далее»/«Назад» всегда видны на телефоне */
  .wiz-nav{position:sticky;bottom:0;background:var(--bg);padding:12px 0 14px;margin-top:18px;
    border-top:1px solid var(--line);box-shadow:0 -8px 16px -10px rgba(20,30,55,.18)}
}
@media(max-width:480px){
  .logo{font-size:0}
  .tab{padding:7px 8px;font-size:12px}
}

/* ===== поле кода подтверждения (onboarding / login) ===== */
.code-wrap{display:flex;gap:10px;align-items:stretch}
.code-wrap input{flex:1;letter-spacing:.4em;font-weight:700;font-variant-numeric:tabular-nums;text-align:center}
.code-wrap .code-paste{flex:0 0 auto;white-space:nowrap;align-self:center}
.verify-step{animation:fade .4s ease}
.verify-step .step-n{font-size:13px;font-weight:700;color:var(--accent);letter-spacing:.04em;margin-bottom:10px}
.verify-step h2{font-size:26px;font-weight:800;letter-spacing:-.02em;margin-bottom:8px}
.verify-step .note{color:var(--ink-dim);font-size:15px;margin-bottom:22px;line-height:1.5}

/* «или»-разделитель на странице входа */
.auth-or{display:flex;align-items:center;gap:12px;margin:20px 0 16px;color:var(--ink-faint);font-size:13px;font-weight:600}
.auth-or::before,.auth-or::after{content:"";flex:1;height:1px;background:var(--line)}

/* ===== попап тарифа в шапке ===== */
.acct{position:relative;display:flex;align-items:center;gap:12px;cursor:pointer;border-radius:980px;outline:none}
.acct:focus-visible{box-shadow:0 0 0 3px rgba(31,92,255,.25)}
.plan-pop{position:absolute;top:calc(100% + 10px);right:0;z-index:60;width:264px;background:#fff;border:1px solid var(--line);
  border-radius:16px;box-shadow:var(--shadow);padding:18px;display:flex;flex-direction:column;gap:10px;animation:fade .2s ease}
.plan-pop[hidden]{display:none}
.plan-pop .pp-plan{font-weight:800;font-size:16px;letter-spacing:-.01em}
.plan-pop .pp-charge{font-size:13.5px;color:var(--ink-dim)}
.plan-pop .pp-status{font-size:13px;color:var(--amber);font-weight:600;background:var(--amber-soft);border-radius:8px;padding:7px 10px}
.plan-pop .btn{width:100%;justify-content:center;margin-top:2px}
.plan-pop .pp-cancel{background:none;border:none;font-family:inherit;font-size:12.5px;color:var(--ink-faint);
  cursor:pointer;padding:4px;text-decoration:underline;text-underline-offset:2px;align-self:center}
.plan-pop .pp-cancel:hover{color:var(--ink-dim)}
@media(max-width:680px){
  /* на мобиле имя скрыто (см. правило выше) — попап якорим к бейджу, прижимаем к краю экрана */
  .plan-pop{right:-8px;width:min(264px,calc(100vw - 28px))}
}