:root{
  --bg:#eaeef8; --card:#fff;
  --primary:#143b74; --primary-light:#26559e; --primary-dark:#0c3165; --primary-darkest:#081935;
  --accent:#e0bd69; --accent-dark:#bb9b4b; --gold-text:#9a7d2e;
  --periwinkle:#d7ddf3; --warning:#d99a1c; --danger:#ef4444;
  --text:#16233b; --muted:#64748b; --border:#dce2ee;
  --shadow:0 2px 12px rgba(8,25,53,.08); --shadow-lg:0 10px 30px rgba(8,25,53,.14);
  --radius:14px; --radius-sm:9px;
  /* шкала вертикальных отступов (база 8) — единый ритм, чтобы не плодить «случайные» 6/14/42 */
  --space-1:8px; --space-2:16px; --space-3:24px; --space-4:32px; --space-5:48px; --space-6:64px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{overflow-x:hidden;max-width:100%}
body{font-family:'Open Sans',system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;line-height:1.5}
/* header */
header{background:linear-gradient(135deg,var(--primary-darkest),var(--primary));color:#fff;height:66px;display:flex;align-items:center;justify-content:space-between;padding:0 26px;box-shadow:0 2px 16px rgba(8,25,53,.3);position:sticky;top:0;z-index:10}
.hl{display:flex;align-items:center;gap:13px}
.logo{width:40px;height:40px;background:linear-gradient(135deg,var(--accent),var(--accent-dark));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px}
.h-title{font-size:18px;font-weight:800}
.h-title .dom{color:var(--accent)}
.h-sub{font-size:12px;opacity:.75}
/* footer (юр-ссылки) */
.site-footer{max-width:1080px;margin:10px auto 0;padding:22px 20px 34px;border-top:1px solid var(--border);text-align:center}
.site-footer-links{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 22px;margin-bottom:10px}
.site-footer-links a{font-size:13px;color:var(--primary);text-decoration:none}
.site-footer-links a:hover{text-decoration:underline;color:var(--accent-dark)}
.site-footer-copy{font-size:12px;color:var(--muted)}
/* hero-превью результата (страницы-инструменты) */
.hero-prev{background:#fff;border-radius:10px;padding:14px 15px;width:100%;max-width:330px;box-shadow:0 12px 30px rgba(8,25,53,.28);text-align:left}
.hp-title{font-size:12px;font-weight:700;color:var(--primary-dark);margin-bottom:9px}
.hp-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:7px 0;border-bottom:1px solid #eef1f7;font-size:12.5px;color:var(--text)}
.hp-row:last-child{border-bottom:none}
.hp-key{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hp-badge{flex:none;font-size:11px;font-weight:700;padding:2px 8px;border-radius:11px;background:var(--periwinkle);color:var(--primary-dark)}
.hp-badge.g{background:#e1f5ee;color:#0f6e56}
.hp-badge.gold{background:#fbf4e0;color:var(--gold-text)}
.hp-bar{height:6px;border-radius:3px;background:#eef1f7;overflow:hidden;flex:none;width:64px}
.hp-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--accent-dark),var(--accent))}
.hp-snip-url{font-size:11px;color:#1d9e75}
.hp-snip-title{font-size:13px;color:#1a47b8;font-weight:600;line-height:1.3;margin:2px 0}
.hp-snip-desc{font-size:11px;color:#4d5156;line-height:1.45}
.hp-line{height:7px;border-radius:3px;background:#eef1f7;margin:7px 0}
.hp-score{display:flex;align-items:center;gap:11px;margin-bottom:8px}
.hp-score-n{width:46px;height:46px;border-radius:50%;background:#e1f5ee;color:#0f6e56;font-size:18px;font-weight:800;display:flex;align-items:center;justify-content:center;flex:none}
.hp-step{display:flex;align-items:center;gap:8px;font-size:12.5px;padding:5px 0;color:var(--text)}
.hp-step .ok{color:#1d9e75;font-weight:800}
/* пример результата — таблица (страницы-инструменты) */
.shot-tbl{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:6px 4px;overflow-x:auto;box-shadow:var(--shadow)}
.ex-tbl{width:100%;border-collapse:collapse;font-size:13px;text-align:left;min-width:420px}
.ex-tbl th{padding:9px 12px;border-bottom:1.5px solid var(--border);color:var(--muted);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}
.ex-tbl td{padding:9px 12px;border-bottom:1px solid #eef1f7;color:var(--text)}
.ex-tbl tr:last-child td{border-bottom:none}
.ex-tbl .num{text-align:right;font-variant-numeric:tabular-nums;color:var(--primary-dark);font-weight:600}
.ex-tbl .ok{color:#0f6e56;font-weight:700}
.ex-tbl .warn{color:var(--warning);font-weight:700}
/* layout */
.main{max-width:1080px;margin:0 auto;padding:26px 20px 60px}
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;margin-bottom:20px}
/* Промо-карточки разделов: hover через CSS (а не inline-JS), чтобы стиль не «залипал»
   при скрытии вью через display:none — иначе карточка выглядит «выбранной» при возврате. */
.promo-card{cursor:pointer;transition:transform .15s,box-shadow .15s}
.promo-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
#semPromo:hover{box-shadow:0 8px 22px rgba(8,25,53,.22)}
/* Аудит сайта: строки проблем по важности + балл */
.site-issue{border-left:4px solid var(--muted);background:#f7f9fd;border-radius:0 6px 6px 0;padding:6px 11px;margin:5px 0;font-size:13px}
.site-issue.sev-crit{border-left-color:var(--danger)}
.site-issue.sev-warn{border-left-color:var(--warning)}
.site-issue.sev-info{border-left-color:var(--muted)}
.score-badge{font-size:30px;font-weight:800;color:var(--primary);text-align:center;line-height:1.1}
.ch{display:flex;align-items:center;gap:11px;margin-bottom:20px}
.ci{width:38px;height:38px;background:var(--periwinkle);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}
.ct{font-size:16px;font-weight:700}
.cs{font-size:12.5px;color:var(--muted)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px}
/* upload */
.uz{border:2px dashed var(--border);border-radius:var(--radius-sm);padding:38px 18px;text-align:center;cursor:pointer;transition:.2s;background:#f7f9fd}
.uz:hover,.uz.drag{border-color:var(--accent);background:#fbf4e0}
.ui{font-size:38px;margin-bottom:10px}
.utxt{font-size:15px;font-weight:600;margin-bottom:5px}
.uh{font-size:12px;color:var(--muted)}
.udone{display:none;align-items:center;gap:12px;padding:13px 16px;background:#eef3fb;border:1px solid #9fb6dc;border-radius:var(--radius-sm)}
.udone.show{display:flex}
.ud-t{font-size:14px;font-weight:700;color:var(--primary-dark)}
.ud-c{font-size:12px;color:var(--primary-light)}
.or-sep{display:flex;align-items:center;gap:10px;margin:14px 0;color:var(--muted);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.or-sep::before,.or-sep::after{content:'';flex:1;height:1px;background:var(--border)}
.kw-ta{width:100%;min-height:88px;padding:11px 13px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:inherit;color:var(--text);background:#fff;resize:vertical;line-height:1.5}
.kw-ta:focus{outline:none;border-color:var(--primary)}
.kw-apply{width:100%;justify-content:center;margin-top:10px}
/* forms */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:15px}
.fg{display:flex;flex-direction:column;gap:6px}
.fl{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.sw{position:relative}
.sw::after{content:'▾';position:absolute;right:13px;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--muted);font-size:12px}
select,.inp{width:100%;padding:11px 13px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;color:var(--text);background:#fff;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;transition:border-color .15s}
select:focus,.inp:focus{outline:none;border-color:var(--primary)}
.inp.need,select.need{border-color:var(--accent);background:#fbf4e0}
.inp.err,select.err{border-color:var(--danger);background:#fdecec}
/* панель-помощник «Собрать маркеры с вашего сайта» (semantika + кабинет) */
.sm-helper{background:linear-gradient(135deg,#fbf4e0,#fff);border:1.5px solid var(--accent);border-radius:10px;padding:12px 14px;margin-top:10px;transition:.25s}
.sm-helper-t{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--primary);margin-bottom:8px}
.sm-helper-row{display:flex;gap:8px;flex-wrap:wrap}
.sm-helper-row .inp{flex:1;min-width:170px;border-color:#e0d3a8;background:#fff}
.sm-btn{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:var(--primary-darkest);padding:10px 18px;font-size:13px;white-space:nowrap;box-shadow:0 2px 8px rgba(224,189,105,.4)}
.sm-btn:hover{transform:translateY(-1px);box-shadow:0 5px 14px rgba(224,189,105,.55)}
.sm-helper-note{font-size:12px;color:var(--gold-text);margin-top:8px}
.sm-helper.done{background:linear-gradient(135deg,#eef7ee,#fff);border-color:#8fcd8f}
.sm-helper.done .sm-helper-t{color:#2e6b2e}
.sm-helper.done .sm-helper-note{color:#2e6b2e}
@media(max-width:600px){.sm-helper-row{flex-direction:column}.sm-helper-row .inp{min-width:0}.sm-btn{justify-content:center}}
/* пресеты минус-слов (чипы) + метки маркерных фраз в шаге 4 */
.mn-presets{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:8px}
.mn-chip{border:1.5px solid #b9c5da;background:#fff;color:var(--primary);border-radius:16px;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:700;cursor:pointer;transition:.15s}
.mn-chip:hover{border-color:var(--accent);background:#fbf4e0}
.mn-chip.on{background:linear-gradient(135deg,var(--accent),var(--accent-dark));border-color:var(--accent-dark);color:var(--primary-darkest)}
.mn-chip.on::before{content:'✓ '}
.sem-seed-badge{display:inline-block;margin-left:8px;font-size:11px;font-weight:700;color:var(--gold-text);background:#fbf4e0;border:1px solid var(--accent);border-radius:10px;padding:1px 8px;vertical-align:1px}
.sem-seed-mark{color:var(--accent-dark);font-size:12px}
/* бейджи классификации кандидатов-конкурентов (🏢 конкурент / 📰 контент-сосед / ⭐ ком-фразы).
   Бейджи живут ВТОРОЙ строкой карточки (.sem-comp-badges, flex-basis:100%): nowrap-бейдж в одну
   строку с доменом выдавливал домен в ноль и распирал сетку (скрин Дмитрия 03.07). */
.chip.has-badges{flex-wrap:wrap;row-gap:4px}
.sem-comp .sem-comp-dom{min-width:0;flex:1 1 auto}
.sem-comp-badges{flex-basis:100%;display:flex;gap:4px;flex-wrap:wrap;min-width:0}
.sem-kind-badge{display:inline-block;font-size:10.5px;font-weight:700;border-radius:9px;padding:1px 7px;white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis}
.sem-kind-badge.comp{color:#2e6b2e;background:#eef7ee;border:1px solid #bfe0bf}
.sem-kind-badge.cont{color:var(--muted);background:#f1f3f8;border:1px solid #d7dce8}
.sem-kind-badge.comm{color:var(--gold-text);background:#fbf4e0;border:1px solid var(--accent)}
.sem-kind-badge.man{color:var(--gold-text);background:#fbf4e0;border:1px solid var(--accent)}
.sem-comp-del{border:none;background:transparent;color:var(--muted);cursor:pointer;font-size:12px;line-height:1;padding:0 3px;margin-left:2px;font-weight:700}
.sem-comp-del:hover{color:#c0392b}
/* калькулятор наших лимитов (форма кластеризации) */
.lim-calc{background:linear-gradient(135deg,#fbf4e0,#fff);border:1.5px solid var(--accent);border-radius:var(--radius-sm);padding:14px 18px;margin-top:16px}
.lc-head{font-size:15px;color:var(--primary-dark);font-weight:600}
.lc-ic{margin-right:4px}
.lc-head b{font-size:22px;color:var(--gold-text);font-weight:800;margin:0 4px}
.lc-hint{font-size:12px;color:var(--muted);font-weight:400;margin-left:6px}
.lc-break{font-size:12.5px;color:var(--muted);margin-top:7px}
.lc-break b{color:var(--primary-dark);font-weight:700}
.lc-tag{background:var(--accent);color:var(--primary-darkest);font-size:11px;font-weight:700;padding:1px 8px;border-radius:10px;margin:0 3px}
.lc-extra{margin-top:5px;font-size:12px;color:var(--muted)}
.opts{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}
.chip{display:flex;align-items:center;gap:8px;padding:9px 15px;border:1.5px solid var(--border);border-radius:22px;cursor:pointer;font-size:13px;font-weight:600;transition:.15s;user-select:none}
.chip:hover{border-color:var(--primary-light)}
.chip.on{border-color:var(--accent);background:#fbf4e0;color:var(--gold-text)}
.chip input{display:none}
.h-lim{color:#fff;opacity:.92;font-size:13px;font-weight:600;text-decoration:none;margin-right:14px;white-space:nowrap}
.h-lim b{color:var(--accent);font-weight:700}
.h-lim:hover{opacity:1}
@media(max-width:640px){.h-lim{display:none}}
/* buttons */
.run-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.btn{border:none;border-radius:22px;font-size:14px;font-weight:700;font-family:inherit;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:.2s}
.btn-run{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:var(--primary-darkest);padding:14px 30px;font-size:15px;box-shadow:0 4px 14px rgba(224,189,105,.5)}
.btn-run:hover{transform:translateY(-1px);box-shadow:0 7px 20px rgba(224,189,105,.62)}
.btn-2{background:#fff;color:var(--primary-dark);border:1.5px solid var(--border);padding:12px 18px}
.btn-2:hover{border-color:var(--primary-light);background:#f4f7fc}
.run-info{font-size:13px;color:var(--muted)}
/* progress */
#progress,#results{display:none}
#progress.show,#results.show{display:block}
.op{margin-bottom:22px}
.op-h{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:8px}
.op-l{font-size:14px;font-weight:600}
.op-p{font-size:26px;font-weight:800;color:var(--primary);line-height:1}
.bar{height:13px;background:#dce2ee;border-radius:7px;overflow:hidden;position:relative}
.bar-f{height:100%;background:linear-gradient(90deg,var(--accent-dark),var(--accent));border-radius:7px;width:0;transition:width .5s ease;position:relative}
.bar-f::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.45),transparent);animation:sh 1.6s infinite}
@keyframes sh{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
.op-m{display:flex;justify-content:space-between;margin-top:8px;font-size:12px;color:var(--muted)}
.stages{display:flex;flex-direction:column;gap:11px}
.st{display:flex;align-items:center;gap:14px;padding:14px 16px;border:1.5px solid var(--border);border-radius:var(--radius-sm);transition:.3s}
.st.active{border-color:var(--accent);background:#fdf8ec;box-shadow:0 0 0 3px rgba(224,189,105,.22)}
.st.done{border-color:#9fb6dc;background:#eef3fb}
.st.pending{opacity:.5}
.st.error{border-color:var(--danger);background:#fef2f2;opacity:1}
.st-i{font-size:20px;min-width:26px;text-align:center}
.st-info{flex:1;min-width:0}
.st-n{font-size:14px;font-weight:700;margin-bottom:3px}
.st-d{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.st-pw{flex:1;max-width:170px}
.st-bc{height:6px;background:#dce2ee;border-radius:3px;overflow:hidden;margin-bottom:4px}
.st-bf{height:100%;background:var(--accent-dark);border-radius:3px;width:0;transition:width .4s ease}
.st-pct{font-size:12px;font-weight:700;text-align:right;color:var(--muted)}
.st-s{min-width:104px;text-align:right}
.bdg{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:13px;font-size:11px;font-weight:700;white-space:nowrap}
.bdg-pending{background:#eef1f7;color:var(--muted)}
.bdg-active{background:#f6ecce;color:var(--gold-text)}
.bdg-done{background:#dce7f7;color:var(--primary-dark)}
.bdg-waiting{background:#faf0d6;color:#8a6a16}
.bdg-error{background:#fee2e2;color:#991b1b}
.spin{display:inline-block;width:11px;height:11px;border:2px solid rgba(187,155,75,.35);border-top-color:var(--accent-dark);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
/* log */
.logc{background:var(--primary-darkest);border-radius:var(--radius-sm);padding:15px;height:210px;overflow-y:auto;font-family:'JetBrains Mono',monospace;font-size:12px}
.ll{display:flex;gap:10px;padding:2px 0;animation:fi .3s ease}
@keyframes fi{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.lt{color:#5e7197;min-width:56px;flex-shrink:0}
.lm{color:#aeb9cf;word-break:break-word}
.lm.success{color:var(--accent)}.lm.info{color:#82a8e6}.lm.warning{color:#e8c069}.lm.error{color:#f08a8a}
/* results */
.rc{background:linear-gradient(135deg,var(--primary-darkest),var(--primary));color:#fff;border-radius:var(--radius);padding:30px 24px;text-align:center;border:1px solid rgba(224,189,105,.25)}
.r-i{font-size:50px;margin-bottom:10px}
.r-t{font-size:23px;font-weight:800;margin-bottom:6px}
.r-s{font-size:14px;opacity:.82;margin-bottom:24px}
.r-stats{display:flex;justify-content:center;gap:34px;margin-bottom:26px;flex-wrap:wrap}
.r-sv{font-size:28px;font-weight:800;color:var(--accent)}
.r-sl{font-size:12px;opacity:.72}
.r-spend{font-size:13px;opacity:.9;margin-bottom:18px}
.r-spend b{color:var(--accent)}
.btn-dl{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:var(--primary-darkest);padding:15px 36px;font-size:16px;font-weight:800;border-radius:22px;box-shadow:0 4px 16px rgba(224,189,105,.4)}
.btn-dl:hover{transform:translateY(-2px);box-shadow:0 9px 24px rgba(224,189,105,.55)}
/* misc */
details.card>summary{cursor:pointer;font-size:14px;font-weight:700;display:flex;align-items:center;gap:8px;list-style:none}
details.card>summary::-webkit-details-marker{display:none}
.akey{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.akey-l{font-size:12px;font-weight:700;min-width:118px;color:var(--primary-dark)}
.akey-i{flex:1;padding:9px 12px;border:1px solid var(--border);border-radius:7px;font-size:13px;font-family:'JetBrains Mono',monospace;background:#fff}
.note{font-size:12px;color:var(--gold-text);margin-top:8px}
.acct-wrap{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.acct{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);border:1px solid rgba(224,189,105,.45);border-radius:20px;padding:6px 15px;font-size:13px;font-weight:600;white-space:nowrap}
.acct b{color:var(--accent);font-weight:800}
.acct.err{border-color:rgba(248,138,138,.6)}
.acct.err b{color:#f08a8a}
/* ---- модуль «Генерация мета-тегов» (3 колонки) ---- */
/* minmax(0,…) + min-width:0 — чтобы колонки СЖИМАЛИСЬ под контент, а не вылезали за экран
   (иначе широкая таблица/длинный URL внутри колонки растягивал грид и обрезал страницу). */
.meta-layout{display:grid;grid-template-columns:minmax(0,230px) minmax(0,310px) minmax(0,1fr);gap:18px;align-items:start}
.meta-col{margin-bottom:0;min-width:0}
/* проекты / кластеры — кликабельные строки */
.mrow{display:flex;align-items:center;gap:9px;padding:9px 11px;border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:.12s;font-size:13px;background:#fff}
.mrow:hover{border-color:var(--primary-light);background:#f4f7fc}
.mrow.sel{border-color:var(--accent);background:#fbf4e0}
.mrow-t{flex:1;min-width:0;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mrow-m{font-size:11px;color:var(--muted);font-weight:400}
.mrow-del{background:none;border:none;cursor:pointer;color:#b6c0d4;font-size:14px;flex-shrink:0;padding:0 2px}
.mrow-del:hover{color:var(--danger)}
/* статус-точка кластера */
.sdot{width:9px;height:9px;border-radius:50%;flex-shrink:0;background:#cbd5e1}
.sdot.empty{background:#cbd5e1}
.sdot.generating{background:var(--primary-light);animation:pulse 1s infinite}
.sdot.done{background:#22a06b}
.sdot.error{background:var(--danger)}
.sdot.edited{background:var(--accent-dark)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
/* счётчик символов */
.cc{font-weight:700;font-size:10.5px;margin-left:6px}
.cc-ok{color:#22a06b}.cc-warn{color:var(--warning)}.cc-bad{color:var(--danger)}.cc-empty{color:var(--muted)}
/* превью сниппета */
.snip{border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;background:#fff}
.snip-host{font-size:13px;color:#3a7d23}
.snip-host.g{color:#202124}
.snip-url{font-size:12px;color:#0b6b1f;margin-bottom:2px;word-break:break-all}
.snip-url.g{color:#5f6368}
.snip-title{font-size:18px;line-height:1.25;color:#1a0dab;font-weight:400;margin:2px 0 3px;word-break:break-word}
.snip-title.y{color:#0b57d0}
.snip-desc{font-size:13px;line-height:1.45;color:#4d5156;word-break:break-word}
.snip-empty{color:var(--muted);font-size:13px;font-style:italic}
/* чипы анализа слов */
.wch{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:14px;font-size:12px;border:1px solid var(--border);background:#f7f9fd}
.wch b{font-weight:700}
.wch .wfreq{color:var(--muted);font-size:11px}
.wch.high{border-color:var(--accent);background:#fbf4e0}
.wch.mid{border-color:#9fb6dc;background:#eef3fb}
/* индикатор «процесс пошёл» в карточке сбора семантики (бегающий спиннер) */
.sem-spin{display:inline-block;width:12px;height:12px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;vertical-align:-2px;animation:semspin .7s linear infinite}
@keyframes semspin{to{transform:rotate(360deg)}}
/* ---- адаптив ---- */
@media(max-width:980px){
  .meta-layout{grid-template-columns:1fr 1fr;gap:14px}
  .meta-col:last-child{grid-column:1/-1}
}
@media(max-width:900px){
  /* шапка: тянется по высоте и переносит чипы на свою строку — без наложений со слоганом */
  header{height:auto;min-height:60px;flex-wrap:wrap;gap:9px 14px;padding:11px 18px;position:static}
  .hl{flex:1 1 auto;min-width:0}
  .h-sub{font-size:11.5px;line-height:1.35}
  .acct-wrap{width:100%;justify-content:flex-start;gap:8px}
}
@media(max-width:760px){
  .two-col{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr 1fr}
  .st-pw{display:none}
  .meta-layout{grid-template-columns:1fr}   /* мета/тексты: все колонки в одну, друг под другом */
}
@media(max-width:640px){
  header{padding:11px 16px}
  .acct{padding:5px 12px;font-size:12px}
  /* 16px в полях ввода — чтобы iOS Safari не зумил страницу при фокусе */
  select,.inp,.kw-ta{font-size:16px}
  .main{padding:18px 14px 52px}
  .card{padding:18px 16px}
  .ch{margin-bottom:16px}
  .r-stats{gap:16px 26px}
  .rc{padding:26px 18px}
  .r-t{font-size:20px}
}
@media(max-width:440px){
  .grid{grid-template-columns:1fr}
  .h-title{font-size:17px}
  .logo{width:36px;height:36px}
  .uz{padding:30px 14px}
  .btn-run{width:100%;justify-content:center;padding:14px 20px}
  .run-info{font-size:12px}
  .acct{flex:1 1 auto;justify-content:center}
}
/* Превью готового текста (Markdown→HTML) в модуле «Тексты под кластеры» */
#bPreview{padding:16px 18px;line-height:1.6;color:var(--text)}
#bPreview h1{font-size:20px;font-weight:800;color:var(--primary-dark);margin:14px 0 8px}
#bPreview h2{font-size:18px;font-weight:800;color:var(--primary-dark);margin:16px 0 8px}
#bPreview h3{font-size:15px;font-weight:700;color:var(--primary-dark);margin:14px 0 6px}
#bPreview h4{font-size:13.5px;font-weight:700;color:var(--text);margin:12px 0 5px}
#bPreview p{margin:0 0 10px}
#bPreview ul,#bPreview ol{margin:0 0 10px 22px}
#bPreview li{margin:3px 0}
#bPreview blockquote{margin:10px 0;padding:8px 14px;border-left:3px solid var(--accent);background:#fbf7ec;color:#555;border-radius:0 6px 6px 0}
#bPreview table.bt{border-collapse:collapse;width:100%;margin:10px 0;font-size:13px}
#bPreview table.bt th{background:var(--primary);color:#fff;padding:7px 10px;text-align:left;border:1px solid #d6deef}
#bPreview table.bt td{padding:7px 10px;border:1px solid #d6deef}
#bPreview table.bt tr:nth-child(even) td{background:#f7f9fd}
#bPreview code{background:#eef1f7;padding:1px 5px;border-radius:4px;font-size:12px}
#bPreview hr{border:none;border-top:1px solid #e2e6ef;margin:14px 0}

/* ===== Личный кабинет ===== */
.bar-f.warn{background:linear-gradient(90deg,var(--accent-dark),var(--warning))}
.bar-f.over{background:linear-gradient(90deg,#c0392b,var(--danger))}
.bar-f.warn::after,.bar-f.over::after{display:none}
.over-txt{color:var(--danger);font-weight:700}
.warn-txt{color:var(--warning);font-weight:700}
.bdg-byo{background:#fbf4e0;color:var(--gold-text)}
.lim-banner{border:1.5px solid var(--accent);border-left:4px solid var(--accent);background:#fdf8ec}
.acct-tbl{width:100%;border-collapse:collapse;font-size:13px}
.acct-tbl th{text-align:left;padding:7px 9px;border-bottom:2px solid var(--border);font-size:11px;text-transform:uppercase;color:var(--muted)}
.acct-tbl td{padding:7px 9px;border-bottom:1px solid var(--border);vertical-align:middle}
.adm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:12px}
.adm-card{border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:13px}
.adm-card.off{opacity:.6}
.iact{background:none;border:1px solid var(--border);border-radius:7px;cursor:pointer;font-size:14px;padding:3px 8px;margin:0 1px}
.iact:hover{border-color:var(--primary-light);background:#f4f7fc}
@media(max-width:760px){.adm-grid{grid-template-columns:1fr}.acct-tbl.usrtbl{display:none}}
@media(min-width:761px){.adm-grid.usrcards{display:none}}
@media(max-width:640px){.akey{flex-direction:column;align-items:stretch;gap:6px}.akey-l{min-width:0}}

/* ===== Аудит сайта: тултипы метрик + раздел ключей ===== */
/* значок «?» с подсказкой по наведению (CSS-only, через data-tip) */
.help{display:inline-flex;align-items:center;justify-content:center;width:15px;height:15px;border-radius:50%;
  background:var(--periwinkle);color:var(--primary-dark);font-size:10px;font-weight:800;cursor:help;
  position:relative;flex-shrink:0;line-height:1;text-transform:none;letter-spacing:0}
.help:hover{background:var(--accent);color:var(--primary-darkest)}
/* Тултип рендерится в <body> через JS (.tip-pop) — иначе обрезается контейнерами
   с overflow:auto (таблицы со скроллом). Здесь только всплывающий блок. */
.tip-pop{position:fixed;z-index:9999;max-width:270px;background:var(--primary-darkest);color:#fff;
  font-size:11.5px;font-weight:400;line-height:1.4;text-align:left;padding:7px 10px;border-radius:7px;
  box-shadow:var(--shadow-lg);pointer-events:none;white-space:normal}
/* таблицы аудита: компактнее, с зеброй и липкой шапкой */
.site-tbl th{white-space:nowrap;position:sticky;top:0;background:#fff;z-index:1}
.site-tbl th .help{margin-left:3px;vertical-align:middle}
.site-tbl td{font-size:12.5px}
.site-tbl tbody tr:nth-child(even){background:#f7f9fd}
.site-tbl tbody tr:hover{background:#eef3fb}
.thh{display:inline-flex;align-items:center;gap:3px}
/* сводка по ключам: чипы-счётчики */
.kw-sum{display:flex;gap:10px;flex-wrap:wrap;margin:6px 0 14px}
.kw-stat{display:flex;align-items:center;gap:7px;padding:8px 14px;border:1.5px solid var(--border);border-radius:11px;background:#f7f9fd}
.kw-stat b{font-size:19px;font-weight:800;line-height:1}
.kw-stat span{font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.3px}
.kw-stat.ok b{color:#16a34a}.kw-stat.part b{color:var(--warning)}.kw-stat.miss b{color:var(--danger)}.kw-stat.cann b{color:#9333ea}
/* бейдж статуса ключа */
.kw-badge{display:inline-block;padding:2px 9px;border-radius:11px;font-size:11px;font-weight:700;white-space:nowrap}
.kw-badge.ok{background:#dcfce7;color:#15803d}
.kw-badge.part{background:#fef3c7;color:#92600e}
.kw-badge.miss{background:#fee2e2;color:#991b1b}
.kw-badge.weak{background:#fde8d4;color:#9a4a16}
/* галочки присутствия в зонах */
.zc{font-weight:800}.zc.y{color:#16a34a}.zc.n{color:#cbd5e1}
/* AI-подсказка под страницей */
.kw-ai{border-left:3px solid var(--accent);background:#fbf7ec;border-radius:0 7px 7px 0;padding:9px 12px;margin-top:8px;font-size:12.5px}
.kw-ai b{color:var(--primary-dark)}
.kw-rec{font-size:12px;color:var(--primary-dark)}
/* раздел «Скорость» (Core Web Vitals): блок на тип страницы + цветовая оценка метрик */
.cwv-block{border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;margin-top:10px}
.cwv-url{font-size:12px;color:var(--primary-light);word-break:break-all;margin-bottom:6px;font-weight:600}
.cwv-tbl td{text-align:center;font-weight:700}
.cwv-tbl td:first-child{text-align:left;font-weight:600;white-space:nowrap}
.cwv-g{background:#dcfce7;color:#15803d}
.cwv-a{background:#fef3c7;color:#92600e}
.cwv-b{background:#fee2e2;color:#991b1b}
.cwv-na{color:#cbd5e1;font-weight:400}
/* строка предварительной оценки стоимости аудита */
.site-est{margin-top:10px;padding:9px 13px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;
  background:#eef7f0;border:1px solid #bfe3c8;color:#15803d}
.site-est.paid{background:#fdf8ec;border-color:var(--accent);color:var(--gold-text)}
.site-est.over{background:#fef2f2;border-color:#f3b4b4;color:#991b1b}
.site-est small{font-weight:400;opacity:.85}
/* группа проблем — лёгкая карточка */
.site-grp{border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;margin-top:12px}
.site-grp-h{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;margin-bottom:4px}
.site-grp-n{font-size:11px;font-weight:700;color:var(--muted);background:#eef1f7;border-radius:10px;padding:1px 8px}
/* ===== Гейт доступа: модалка для анонимов на страницах-инструментах (js/gate.js) ===== */
.kg-overlay{position:fixed;inset:0;z-index:10000;display:none;align-items:center;justify-content:center;
  padding:20px;background:rgba(8,25,53,.55);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}
.kg-overlay.show{display:flex;animation:kgFade .18s ease}
@keyframes kgFade{from{opacity:0}to{opacity:1}}
.kg-card{position:relative;background:var(--card);border-radius:16px;box-shadow:var(--shadow-lg);
  width:100%;max-width:400px;padding:30px 28px 26px;text-align:center;animation:kgPop .2s ease}
@keyframes kgPop{from{transform:translateY(12px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.kg-x{position:absolute;top:12px;right:14px;width:30px;height:30px;border:none;background:transparent;
  font-size:24px;line-height:1;color:var(--muted);cursor:pointer;border-radius:8px;transition:background .15s}
.kg-x:hover{background:#eef1f7;color:var(--text)}
.kg-logo{width:50px;height:50px;border-radius:13px;background:linear-gradient(135deg,var(--accent),var(--accent-dark));
  display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.kg-title{font-size:20px;color:var(--primary-dark);margin-bottom:8px;line-height:1.25}
.kg-sub{font-size:13.5px;color:var(--muted);line-height:1.5;margin-bottom:20px}
.kg-btn{display:block;width:100%;padding:12px;border-radius:10px;font-size:15px;font-weight:700;
  text-decoration:none;cursor:pointer;border:none;text-align:center;transition:filter .15s,background .15s}
.kg-btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:var(--primary-darkest)}
.kg-btn-primary:hover{filter:brightness(1.05)}
.kg-btn-ghost{background:#fff;color:var(--primary);border:1.5px solid var(--border)}
.kg-btn-ghost:hover{border-color:var(--primary-light);background:#f7f9fd}
.kg-or{display:flex;align-items:center;gap:12px;margin:18px 0 14px;color:var(--muted);font-size:12px}
.kg-or::before,.kg-or::after{content:"";flex:1;height:1px;background:var(--border)}
.kg-form{display:flex;flex-direction:column;gap:10px;text-align:left}
.kg-inp{width:100%;padding:11px 13px;border:1.5px solid var(--border);border-radius:9px;font-size:14px;
  font-family:inherit;color:var(--text);background:#fff;transition:border-color .15s}
.kg-inp:focus{outline:none;border-color:var(--primary-light)}
.kg-ta{resize:vertical;min-height:48px}
.kg-err{background:#fdecec;color:#b42318;border:1px solid #f3c0bd;border-radius:8px;padding:8px 11px;font-size:13px}
.kg-ok{background:#e1f5ee;color:#0f6e56;border:1px solid #b7e3d3;border-radius:10px;padding:14px;font-size:14px;font-weight:600}
@media (max-width:480px){.kg-card{padding:26px 20px 22px}.kg-title{font-size:18px}}
/* ===== Мета-теги: рабочий блок на странице (js/meta.js) ===== */
.meta-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
  background:#f7f9fd;border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px}
.meta-bar-info{font-size:14px;color:var(--text)}
.m-pbar-wrap{height:8px;background:#eef1f7;border-radius:4px;overflow:hidden}
.m-pbar{height:100%;width:0;background:linear-gradient(90deg,var(--accent-dark),var(--accent));transition:width .3s}
.m-pmeta{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-top:5px}
.m-log{margin-top:8px;max-height:120px;overflow:auto;background:var(--primary-darkest);color:#cdd7ea;
  border-radius:8px;padding:8px 11px;font:12px/1.5 ui-monospace,SFMono-Regular,Menlo,monospace}
.m-log .m-ll{white-space:pre-wrap}
.meta-tbl-wrap{margin-top:14px;overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-sm)}
.meta-tbl{width:100%;border-collapse:collapse;font-size:13px;min-width:640px}
.meta-tbl th{position:sticky;top:0;background:#fff;text-align:left;padding:9px 12px;border-bottom:1.5px solid var(--border);
  color:var(--muted);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}
.meta-tbl td{padding:9px 12px;border-bottom:1px solid #eef1f7;color:var(--text);vertical-align:top}
.meta-tbl tr:last-child td{border-bottom:none}
.meta-tbl .mc-name{font-weight:600;color:var(--primary-dark);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.meta-tbl .mc-v{max-width:260px}
.meta-tbl .mc-v.ok{color:#15803d}.meta-tbl .mc-v.warn{color:#92600e}.meta-tbl .mc-v.bad{color:#991b1b}
.m-bdg{display:inline-block;padding:2px 9px;border-radius:11px;font-size:11px;font-weight:700;white-space:nowrap}
.m-bdg-empty{background:#eef1f7;color:var(--muted)}
.m-bdg-generating{background:#fef3c7;color:#92600e}
.m-bdg-done{background:#dcfce7;color:#15803d}
.m-bdg-edited{background:#e0e7ff;color:#3730a3}
.m-bdg-error{background:#fee2e2;color:#991b1b}
/* ===== Прайс + пополнение баланса на страницах-инструментах (общее, js/buy.js) ===== */
.price-box{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px 20px}
.price-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid #eef1f7;font-size:14px}
.price-row:last-child{border-bottom:none}
.price-row .p-n{flex:1;color:var(--text)}
.price-row .p-p{font-weight:700;color:var(--primary-dark);white-space:nowrap}
.price-row.hi{background:#fbf7ec;margin:0 -12px;padding-left:12px;padding-right:12px;border-radius:8px;border-bottom-color:transparent}
.price-row.hi .p-p{color:var(--gold-text)}
.buy-card{background:linear-gradient(135deg,#fff,#fbf4e0);border:2px solid var(--accent);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:28px 26px;max-width:560px;margin:0 auto;text-align:center}
.buy-rec{display:inline-block;background:linear-gradient(135deg,var(--accent),var(--accent-dark));color:var(--primary-darkest);font-size:12px;font-weight:800;padding:4px 14px;border-radius:11px;margin-bottom:12px}
.buy-title{font-size:21px;color:var(--primary-dark);margin-bottom:18px}
.buy-presets{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:16px}
.buy-presets button{font-size:14px;font-weight:700;color:var(--primary-dark);background:#fff;border:1.5px solid var(--border);border-radius:9px;padding:9px 16px;cursor:pointer;transition:.15s}
.buy-presets button:hover{border-color:var(--accent)}
.buy-presets button.on{background:var(--primary);color:#fff;border-color:var(--primary)}
.buy-input-row{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:18px;flex-wrap:wrap}
.buy-field{position:relative;display:inline-flex;align-items:center}
.buy-field input{width:170px;font-size:22px;font-weight:800;color:var(--primary);text-align:center;padding:10px 32px 10px 14px;border:1.5px solid var(--border);border-radius:10px;font-family:inherit}
.buy-field input:focus{outline:none;border-color:var(--accent)}
.buy-cur{position:absolute;right:13px;font-size:16px;color:var(--muted);font-weight:700;pointer-events:none}
.buy-eq{font-size:20px;color:var(--muted);font-weight:700}
.buy-limits{font-size:16px;color:var(--text)}
.buy-limits b{font-size:24px;color:var(--gold-text);font-weight:800}
.buy-btn{width:100%;max-width:320px;justify-content:center;padding:13px;font-size:15px;margin:0 auto;cursor:pointer}
.buy-email-row{max-width:320px;margin:0 auto 12px}
.buy-email-row input{width:100%;box-sizing:border-box;padding:11px 14px;font-size:14px;color:var(--primary);text-align:center;border:1.5px solid var(--border);border-radius:10px;font-family:inherit;background:#fff}
.buy-email-row input:focus{outline:none;border-color:var(--accent)}
.buy-email-row input.err{border-color:#dc3545;background:#fff7f7}
.buy-note{font-size:12.5px;color:var(--muted);margin-top:12px;line-height:1.5}
.enough-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px}
.enough-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);padding:18px 14px;text-align:center}
.enough-card .e-n{font-size:24px;font-weight:800;color:var(--primary)}
.enough-card .e-l{font-size:12.5px;color:var(--muted);margin-top:4px;line-height:1.35}
@media(max-width:560px){.buy-input-row{flex-direction:column;gap:8px}}

/* ===== Сбор семантики на /semantika.html (competitor-gap, ревью) ===== */
.sem-block-h{font-size:14px;font-weight:700;color:var(--primary-dark);margin:0 0 10px;display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.sem-block-sub{font-size:12px;font-weight:400;color:var(--muted)}
.sem-comp-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:8px}
.sem-comp{justify-content:flex-start;border-radius:9px;font-weight:600}
.sem-comp .sem-comp-dom{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sem-comp .sem-comp-meta{color:var(--muted);font-weight:400;margin-left:auto;white-space:nowrap;font-size:12px}
/* ручное добавление своего конкурента в таблицу (клиент вписывает URL → карточка) */
.sem-add-comp{margin-top:12px;padding:11px 13px;background:#fbf4e0;border:1px dashed var(--accent);border-radius:9px}
.sem-add-comp .fl{display:block;margin:0 0 6px}
.sem-add-row{display:flex;gap:8px;align-items:center}
.sem-add-row .inp{flex:1}
@media(max-width:600px){.sem-add-row{flex-direction:column;align-items:stretch}}
.sem-stats{background:#f7f9fd;border:1px solid var(--border);border-radius:9px;padding:11px 14px;font-size:13px;color:var(--text);line-height:1.6;margin-bottom:16px}
.sem-stats b{color:var(--primary-dark)}
/* Воронка семантики «конвейер»: 4 шага пути ключа + состав ядра (живой пересчёт) */
.sem-fun-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}
.sf-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:11px 13px;min-width:0}
.sf-h{font-size:11px;font-weight:700;color:var(--muted);letter-spacing:.03em;text-transform:uppercase}
.sf-n{font-size:21px;font-weight:800;color:var(--text);margin-top:3px;white-space:nowrap}
.sf-s{font-size:11.5px;color:var(--muted);margin-top:3px;line-height:1.45}
.sf-red .sf-h,.sf-red .sf-n{color:#991b1b}
.sf-navy{background:var(--primary);border-color:var(--primary)}
.sf-navy .sf-h{color:var(--accent)}
.sf-navy .sf-n{color:#fff}
.sf-navy .sf-s{color:var(--periwinkle)}
.sf-of{font-size:11.5px;font-weight:600;color:var(--muted);margin-top:1px}
.sf-navy .sf-of{color:var(--periwinkle)}
.sf-note{font-size:11.5px;color:var(--muted);margin-top:8px;line-height:1.45}
.sf-mix{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 13px;margin-top:10px;font-size:12px;color:var(--muted);flex-wrap:wrap}
.sf-bar{flex:1 1 140px;height:10px;border-radius:5px;overflow:hidden;display:flex;background:var(--periwinkle)}
.sf-bar>div{height:100%}
.sf-seg-gap{background:var(--primary-light)}
.sf-seg-top{background:var(--accent)}
.sf-mix b{color:var(--primary-dark)}
.sem-rev-block{margin-bottom:16px}
.sem-rev-tools{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:10px}
.sem-chk{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--text);cursor:pointer}
.sem-chk input{accent-color:var(--primary)}
.sem-mini{font-size:12px;font-weight:600;color:var(--primary);background:none;border:none;cursor:pointer;padding:0;text-decoration:underline}
.sem-mini:hover{color:var(--accent-dark)}
.sem-group-list{display:flex;flex-direction:column;gap:8px;max-height:480px;overflow:auto;padding-right:2px}
.sem-group{border:1px solid var(--border);border-radius:9px;padding:9px 11px;background:#f7f9fd}
.sem-group-head{display:flex;align-items:flex-start;gap:9px;cursor:pointer}
.sem-group-head input{margin-top:3px;accent-color:var(--primary)}
.sem-group-body{flex:1;min-width:0}
.sem-group-lead{font-weight:600;font-size:13.5px;color:var(--text)}
.sem-group-var{font-weight:400;color:var(--muted);margin-left:8px;font-size:11.5px}
.sem-group-sub{font-size:11.5px;color:var(--muted);margin-top:2px}
.sem-group-det{margin-top:6px}
.sem-group-det summary{cursor:pointer;font-size:11.5px;color:var(--primary-light)}
.sem-member-list{margin-top:6px;display:flex;flex-direction:column;gap:3px}
.sem-pick{display:flex;align-items:center;gap:8px;font-size:12.5px;cursor:pointer}
.sem-pick input{accent-color:var(--primary)}
.sem-member{padding-left:26px}
.sem-drop{font-size:13px;opacity:.85}
.sem-row-ws{color:var(--muted);margin-left:auto;white-space:nowrap}
.sem-dim{color:#94a3b8}
.sem-list{display:flex;flex-direction:column;gap:5px;max-height:260px;overflow:auto;margin-top:8px}
.sem-row{display:flex;gap:8px;align-items:center;font-size:13px}
.sem-row-pos{color:var(--muted);min-width:56px}
.sem-rev-fold{border:1px solid var(--border);border-radius:9px;margin-bottom:10px;background:var(--card)}
.sem-rev-fold>summary{cursor:pointer;font-size:13px;font-weight:600;color:var(--primary-dark);padding:11px 14px;list-style:none}
.sem-rev-fold>summary::-webkit-details-marker{display:none}
.sem-rev-fold[open]>summary{border-bottom:1px solid var(--border)}
.sem-rev-fold .sem-list{padding:0 14px 12px}
.sem-apply-row{display:flex;gap:18px;flex-wrap:wrap;margin-top:14px}
.sem-done{display:flex;align-items:center;gap:14px;flex-wrap:wrap;background:linear-gradient(135deg,#fff,#fbf4e0);border:2px solid var(--accent);border-radius:var(--radius);padding:18px 20px}
.sem-done-ic{font-size:30px;flex:none}
.sem-done-t{font-size:16px;font-weight:700;color:var(--primary-dark)}
.sem-done-t b{color:var(--gold-text)}
.sem-done-s{font-size:13px;color:var(--muted);margin-top:2px}
@media(max-width:600px){.sem-comp-list{grid-template-columns:1fr}.sem-done{flex-direction:column;align-items:flex-start}.sem-done .btn-run{margin-left:0!important;width:100%;justify-content:center}}
