/* ===========================================================
   Дизайн-система оболонки "Командний центр" (напрямок 1).
   Темна тактична тема: холодний фон + теплий бурштиновий акцент.
   Шрифти: Manrope (заголовки), Hanken Grotesk (текст), JetBrains Mono (коди).
   =========================================================== */
:root{
  --bg:#0A0C10;
  --bg2:#11141B;
  --panel:#12161E;
  --panel2:#171C26;
  --line:#222936;
  --line2:#2E3645;
  --txt:#E7EAF0;
  --muted:#8B94A4;
  --faint:#586273;
  /* Бренд-акцент "electric" (синьо-фіолетовий, у гамі лого). Імена --amber/--gold
     лишені як були (щоб не правити сотні посилань), але тепер це electric-палітра.
     --*-rgb - ті самі кольори в RGB-каналах, для прозорих підсвічувань rgba(...). */
  --amber:#6B8CFF;       /* головний акцент (перівінкл-синій) */
  --gold:#B79BFF;        /* світліший акцент (лаванда): прогрес-бари, ранг, типи в симуляторі */
  --amber-rgb:107,140,255;
  --gold-rgb:183,155,255;
  --on-accent:#FFFFFF;   /* текст НА акценті: світлий, бо синій темніший за амбер */
  /* градієнт для великих CTA-кнопок: трохи глибший синій знизу -> білий текст читається впевнено */
  --accent-grad:linear-gradient(135deg,#7C99FF,#5871EE);
  --cyan:#5FD0E0;        /* інфо (семантичний/декоративний: пипка .d2, синтаксис у симуляторі) */
  --kw:#FF9F43;          /* highlight КОНТЕНТУ: інлайн-код, pre, посилання в уроках/брифінгах (теплий помаранч, комплемент до синього UI; чітко відрізняється від --red) */
  --green:#6FE0A0;       /* семантика "успіх/легка складність" - НЕ прогрес */
  --done:var(--amber);   /* "пройдено/прогрес" - бренд-синій (як колір кікера, не лаванда) */
  --done-rgb:var(--amber-rgb);
  --red:#FF6B6B;
  --r:13px;
  --d:"Manrope",sans-serif;
  --b:"Hanken Grotesk",system-ui,sans-serif;
  --m:"JetBrains Mono",monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--txt);font-family:var(--b);font-size:16px;line-height:1.55;
  -webkit-font-smoothing:antialiased;min-height:100vh;
  /* sticky-footer: колонка, де .wrap росте й виштовхує футер у низ короткої сторінки */
  display:flex;flex-direction:column;
  background-image:
    radial-gradient(800px 460px at 88% -8%,rgba(var(--amber-rgb),.07),transparent 60%),
    radial-gradient(700px 500px at -5% 100%,rgba(95,208,224,.05),transparent 55%);
}
::selection{background:var(--amber);color:var(--on-accent)}

/* --- Фон ЛИШЕ для лендінгу (body.is-home) ---
   "Аврора": м'яке діагональне сяйво - 2 холодні розмиті поля
   + тиха тепла бурштинова смуга навскіс. Чистий CSS, без картинок.
   Лежить позаду контенту (z-index:0, фіксований, не перехоплює кліки).
   Інші сторінки його НЕ отримують. */
body.is-home::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:0;                /* нижче контенту (.wrap нижче має z-index) */
  pointer-events:none;
  /* діагональні розмиті поля холодного сяйва */
  background:
    radial-gradient(900px 520px at 8% -8%,rgba(255,159,67,.08),transparent 60%),
    radial-gradient(1000px 600px at 82% 14%,rgba(96,120,190,.07),transparent 62%);
  -webkit-mask-image:linear-gradient(180deg,#000 0,#000 50%,transparent 94%);
          mask-image:linear-gradient(180deg,#000 0,#000 50%,transparent 94%);
}
body.is-home::after{
  content:"";
  position:fixed;
  inset:0;
  z-index:0;                /* теж позаду контенту */
  pointer-events:none;
  /* одна тепла amber-смуга сяйва навскіс */
  background:linear-gradient(118deg,transparent 30%,rgba(var(--amber-rgb),.05) 52%,transparent 70%);
  -webkit-mask-image:linear-gradient(180deg,#000 0,#000 48%,transparent 90%);
          mask-image:linear-gradient(180deg,#000 0,#000 48%,transparent 90%);
}
/* Контент лендінгу має лежати над фоновими шарами. ВАЖЛИВО: топбар сюди НЕ включаємо -
   він лишається sticky з z-index:60 (своє правило нижче). Інакше топбар отримав би
   z-index:1, а .wrap (той самий z-index, але пізніше в DOM) накрив би випадне меню
   користувача, і кліки по «Профіль»/«Налаштування» не доходили б до анкорів. */
body.is-home .wrap{position:relative;z-index:1}
a{color:inherit;text-decoration:none}

/* топбар */
.topbar{position:sticky;top:0;z-index:60;flex-shrink:0;display:flex;align-items:center;gap:26px;
  /* центруємо вміст шапки в колонку контенту (.wrap), смуга-фон лишається повноширинною */
  padding:13px max(34px, calc((100% - 1132px) / 2));background:rgba(10,12,16,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
/* Тонкий банер "підтверди email" під топбаром: мʼякий амбер-інфо (--kw), НЕ тривожний.
   Центруємо вміст у колонку контенту так само, як у .topbar; смуга-фон на всю ширину */
.verify-bar{flex-shrink:0;display:flex;align-items:center;gap:14px;
  padding:8px max(34px, calc((100% - 1132px) / 2));
  font:600 13px/1.4 var(--b);color:var(--kw);
  background:rgba(255,159,67,.07);border-bottom:1px solid rgba(255,159,67,.22)}
.verify-resend{margin:0;display:inline-flex}
.verify-resend button{cursor:pointer;font:600 12.5px/1 var(--b);color:var(--kw);
  background:rgba(255,159,67,.1);border:1px solid rgba(255,159,67,.35);
  border-radius:7px;padding:6px 12px;transition:.15s}
.verify-resend button:hover{background:rgba(255,159,67,.18);border-color:rgba(255,159,67,.5)}
/* Вордмарк HACKULARITY: технологічний дисплей-шрифт Space Grotesk - лише на тексті лого, решта UI без змін */
.logo{display:flex;align-items:center;gap:10px;font-family:"Space Grotesk",var(--d);font-weight:700;font-size:21px;letter-spacing:1px;text-transform:uppercase}
/* лого-знак (сингулярність + H): кольором керує var(--amber),
   градієнт диска лишається власний; .mark - просто рамка розміру */
.mark{display:inline-grid;place-items:center;color:var(--amber);line-height:0}
.mark .logo-mark-svg{display:block;width:100%;height:100%}
.logo .mark{width:46px;height:46px}
.logo .dim{font-family:var(--b);font-weight:500;font-size:11px;color:var(--faint);letter-spacing:0;text-transform:none}
.tabs{display:flex;gap:2px}
.tab{font:600 13px/1 var(--b);color:var(--muted);padding:9px 15px;border-radius:8px;cursor:pointer;transition:.15s;letter-spacing:.02em}
.tab:hover{color:var(--txt);background:var(--panel)}
.tab.active{color:var(--amber);background:var(--panel2);box-shadow:inset 0 0 0 1px var(--line2)}

/* Дропдаун «Операції» в топбарі (тригер-таб + випадне меню кампаній) */
.opsbox{position:relative}
.ops-trigger{display:flex;align-items:center;border:none;background:none;font-family:var(--b)}
.opsbox.open .ops-trigger{color:var(--txt);background:var(--panel)}
.ops-menu{position:absolute;top:calc(100% + 10px);left:0;z-index:80;min-width:256px;
  background:var(--panel2);border:1px solid var(--line2);border-radius:12px;padding:6px;
  box-shadow:0 18px 44px -16px rgba(0,0,0,.7)}
.ops-item{display:flex;align-items:center;gap:11px;padding:10px 11px;border-radius:8px;
  text-decoration:none;color:var(--muted);transition:.13s}
.ops-item:hover{background:var(--panel);color:var(--txt)}
.ops-item.active{background:var(--panel);color:var(--amber);box-shadow:inset 0 0 0 1px var(--line2)}
.ops-ic{flex:0 0 auto;font-size:17px;line-height:1}
.ops-name{font:600 13.5px/1.2 var(--b);white-space:nowrap}
.ops-prog{margin-left:auto;flex:0 0 auto;display:flex;align-items:center;gap:8px}
.ops-count{font:600 11.5px/1 var(--m);color:var(--faint)}
.ops-item.active .ops-count{color:var(--amber)}
.ops-bar{width:46px;height:6px;border-radius:99px;background:var(--panel);border:1px solid var(--line);overflow:hidden}
.ops-bar i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--amber),var(--gold))}

.sp{flex:1}
.hud{font-family:var(--m);font-size:12px;color:var(--muted);display:flex;gap:18px}
.hud b{color:var(--amber)} .hud .g{color:var(--green)}
.av{width:32px;height:32px;border-radius:7px;background:linear-gradient(135deg,#2a3140,#171c26);border:1px solid var(--line2);display:grid;place-items:center;font-weight:600;font-size:13px;font-family:var(--d)}

/* flex:1 0 auto - контент тягнеться й штовхає футер донизу; max-width+margin:auto
   у flex-колонці зі stretch зберігають горизонтальне центрування */
/* width:100% обовʼязковий: у body-flex-колонці авто-маргіни скасовують stretch і .wrap
   зсихався до ширини контенту - тож задаємо визначену ширину, max-width центрує як було */
.wrap{flex:1 0 auto;width:100%;max-width:1200px;margin:0 auto;padding:34px 34px 100px}

.kicker{font:700 11px/1 var(--m);letter-spacing:.18em;text-transform:uppercase;color:var(--amber)}
h1.t{font-family:var(--d);font-weight:600;font-size:33px;letter-spacing:0;text-transform:uppercase;margin:12px 0 6px}
.sub{color:var(--muted);max-width:70ch;font-size:16px}

/* повідомлення (зараховано ціль / помилка) */

/* бейдж складності - пипки + слово, без цифр */
/* інлайн-код не розривається посеред чипа (напр. role = "admin") */
:not(pre) > code{white-space:nowrap}

.diff{display:inline-flex;align-items:center;gap:7px;font:700 10.5px/1 var(--m);letter-spacing:.04em;padding:5px 9px;border-radius:99px;white-space:nowrap}
.diff .pips{display:inline-flex;gap:3px}
.diff .pips i{width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.24}
.diff .pips i.on{opacity:1}
.d1{color:var(--green);background:rgba(111,224,160,.12)}
.d2{color:#FFD15C;background:rgba(255,209,92,.12)}
.d3{color:#FF8A3D;background:rgba(255,138,61,.12)}
.d4{color:var(--red);background:rgba(255,107,107,.12)}

/* шапка кампанії */
.camp{display:flex;gap:22px;align-items:flex-end;justify-content:space-between;margin:24px 0 4px;flex-wrap:wrap}
.camp .meta{display:flex;gap:30px;flex-wrap:wrap}
.camp .meta .it .k{font:600 11px/1 var(--m);letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:6px}
.camp .meta .it .v{font-family:var(--d);font-weight:600;font-size:18px}
.camp .meta .it .v.amb{color:var(--amber)}
.prog{min-width:280px;flex:1;max-width:420px}
.prog .lab{display:flex;justify-content:space-between;font:600 12px/1 var(--m);color:var(--muted);margin-bottom:8px}
.prog .bar{height:8px;border-radius:99px;background:var(--panel2);border:1px solid var(--line);overflow:hidden;position:relative}
.prog .bar i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--amber),var(--gold))}

/* двоколонкова розкладка карти: таймлайн + командний блок */
.map-layout{display:grid;grid-template-columns:1fr 326px;gap:26px;align-items:start;margin-top:26px}
@media(max-width:980px){.map-layout{grid-template-columns:1fr}}

/* КАРТА ОПЕРАЦІЇ: ліво-рейковий таймлайн */
.opmap{position:relative}
.opmap::before{content:"";position:absolute;left:21px;top:10px;bottom:54px;width:2px;border-radius:99px;
  background:linear-gradient(180deg,var(--done) 0,var(--done) var(--done-pct,28%),var(--line) var(--done-pct,28%),var(--line) 100%)}
.stagerow{position:relative;display:grid;grid-template-columns:44px 1fr;align-items:center;margin-bottom:13px}
.marker{grid-column:1;justify-self:center;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;
  font-family:var(--d);font-weight:600;font-size:15px;z-index:2;border:2px solid var(--line2);background:var(--bg2);color:var(--muted)}
.marker.done{background:linear-gradient(135deg,#7C99FF,#5871EE);border-color:transparent;color:var(--on-accent)}
.marker.cur{background:var(--amber);border-color:transparent;color:var(--on-accent);box-shadow:0 0 0 5px rgba(var(--amber-rgb),.16)}
.marker.lock{color:var(--faint)}
/* ТИМЧАСОВО (UNLOCK_ALL): нейтральний маркер відкритого, але ще не здобутого етапу -
   звичайний номер без тьмяності, не такий приглушений, як замок */
.marker.open{color:var(--txt)}

.node{grid-column:2;margin-left:16px;background:var(--panel);border:1px solid var(--line2);border-radius:var(--r);
  padding:16px 19px;cursor:pointer;transition:.18s;display:flex;align-items:center;justify-content:space-between;gap:18px}
.node:hover{transform:translateX(3px);border-color:var(--amber)}
.node.locked{opacity:.5;cursor:not-allowed}
.node.locked:hover{transform:none;border-color:var(--line2)}
.node.cur{border-color:var(--amber);box-shadow:0 14px 30px -16px rgba(var(--amber-rgb),.5)}
/* ТИМЧАСОВО (UNLOCK_ALL): відкритий, але ще не здобутий етап - звичайна яскрава
   картка (повна непрозорість і клікабельність наслідуються від базового .node) */
.node.open .trophy{color:var(--faint)}
.node .n-top{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.node .code{font:700 11px/1 var(--m);color:var(--faint);letter-spacing:.05em}
.node h3{font-family:var(--d);font-weight:600;font-size:17px;letter-spacing:.3px;text-transform:uppercase}
.node p{color:var(--muted);font-size:13.5px;line-height:1.4}
.node .n-side{flex:0 0 auto;display:flex;flex-direction:column;align-items:flex-end;gap:9px;text-align:right}
.node .trophy{font:500 12px/1 var(--m);color:var(--faint);display:flex;align-items:center;gap:6px}
/* статус-значок етапу (✓ / ▸ / 🏁) - крупніший за текст поряд */
.node .trophy .ti{font-size:18px;line-height:1;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}
/* трикутник "поточний етап" - інлайн-SVG (текстовий гліф ▸ сидить низько в боксі);
   SVG центрується чисто через flex батька .trophy/.ti, колір успадковує (currentColor = янтарний) */
.node .trophy .ti.tri{width:13px;height:13px}
.node .trophy .ti.tri svg{width:100%;height:100%;display:block}
/* замок лишаємо як був (розмір тексту поряд), бо він і так нормальний */
.node.locked .trophy .ti{font-size:12px}
.node.done .trophy{color:var(--done)} .node.cur .trophy{color:var(--amber)}

/* командний блок (правий) */
.ops-panel{display:flex;flex-direction:column;gap:14px}
/* Картка скиду притискається до низу панелі - щоб її низ був на рівні останньої лаби. */
.ops-panel .reset-card{margin-top:0}
.op-card{background:var(--panel);border:1px solid var(--line2);border-radius:var(--r);padding:18px}
.op-card .lbl{font:700 11px/1 var(--m);letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:13px}
.op-current{border-color:var(--amber);background:linear-gradient(160deg,rgba(var(--amber-rgb),.07),var(--panel))}
.op-current .oc-code{font:700 11px/1 var(--m);color:var(--amber);letter-spacing:.06em;margin-bottom:7px}
.op-current h4{font-family:var(--d);font-weight:600;font-size:19px;letter-spacing:.3px;text-transform:uppercase;margin-bottom:6px}
.op-current p{color:var(--muted);font-size:13.5px;line-height:1.45;margin-bottom:15px}
/* картка "Операцію завершено" - успіх у бренд-лаванді */
.op-done{border-color:var(--done);background:linear-gradient(160deg,rgba(var(--done-rgb),.09),var(--panel))}
.op-done .od-title{font-family:var(--d);font-weight:600;font-size:19px;letter-spacing:.3px;text-transform:uppercase;margin-bottom:8px;color:var(--done)}
.op-done .od-conseq{color:var(--muted);font-size:13.5px;line-height:1.45;margin-bottom:11px}
.op-done .od-conseq b{color:var(--txt);font-weight:600}
.op-done .od-stat{font:600 12px/1.4 var(--m);color:var(--faint);letter-spacing:.02em;margin-bottom:0}
.op-done .od-locked{font:600 12.5px/1 var(--m);color:var(--faint);display:flex;align-items:center;justify-content:center;gap:7px;padding:13px;border-radius:11px;background:var(--panel2);border:1px solid var(--line2)}
/* прогрес-бар у правій колонці (вже не на всю ширину шапки) */
.ops-panel .prog{min-width:0;max-width:none;margin-bottom:2px}
.btn{width:100%;border:none;cursor:pointer;font:700 14.5px/1 var(--b);padding:14px;border-radius:11px;display:flex;align-items:center;justify-content:center;gap:9px;transition:.16s;letter-spacing:.02em}
/* форма-обгортка кнопки "Запустити" - сама не додає відступів, кнопка всередині лишається повної ширини */
.launch-form{margin:0;display:block}
.btn-run{background:var(--accent-grad);color:var(--on-accent);box-shadow:0 10px 26px -10px var(--amber)}
.btn-run:hover{filter:brightness(1.07);transform:translateY(-1px)}
/* "Зупинити лабу" - повноширинна, та сама геометрія від .btn (без реальної рамки,
   тож при перемиканні з .btn-run розмір не стрибає - контур через inset box-shadow).
   Не основна помаранчева, а приглушено-деструктивна у дусі --red/.btn-reset */
/* "Запустити/Відкрити" і "Зупинити" тепер видимі одночасно - розділяємо їх відступом */
.btn-stop{margin-top:9px;background:rgba(255,107,107,.08);color:var(--red);box-shadow:inset 0 0 0 1px rgba(255,107,107,.4)}
.btn-stop:hover{background:rgba(255,107,107,.16);box-shadow:inset 0 0 0 1px var(--red);transform:translateY(-1px)}
.btn-stop:disabled{opacity:.5;cursor:not-allowed;transform:none}
.intel{list-style:none;display:flex;flex-direction:column;gap:1px}
.intel li{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--line);font:500 12px/1 var(--m)}
.intel li:last-child{border-bottom:none}
/* статус-значок у «Ланцюгу цілей» - крупніший за текст рядка;
   inline-flex центрує і текстовий ✓, і інлайн-SVG-трикутник по центру висоти рядка */
.intel li .st{width:18px;font-size:18px;line-height:1;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}
/* трикутник "поточний етап" як SVG (гліф ▸ у шрифті зміщений донизу) */
.intel li .st .tri{width:11px;height:11px;display:block}
.intel li .st.ok{color:var(--done)} .intel li .st.cur{color:var(--amber)} .intel li .st.lk{color:var(--faint)}
/* заблокований маркер (крапка) лишаємо як був - збільшуємо лише ✓ і ▸ */
.intel li .st.lk{font-size:12px;width:16px}
.intel li .code{color:var(--faint);width:24px;flex:0 0 auto}
.intel li .val{color:var(--muted);flex:1;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.intel li.done .val{color:var(--txt)} .intel li.cur .val{color:var(--amber)}
.legend{display:flex;flex-direction:column;gap:9px}
.legend .lg{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted)}
.legend .lg .m{width:20px;height:20px;border-radius:50%;display:grid;place-items:center;font:700 16px/1 var(--m);flex:0 0 auto}
.legend .lg .m svg{display:block}
.legend .lg .m.done{background:linear-gradient(135deg,#B79BFF,#8E78D6);color:#1a1430}
.legend .lg .m.cur{background:var(--amber);color:var(--on-accent)}
.legend .lg .m.lock{border:2px solid var(--line2);color:var(--faint)}

/* інші кампанії */
.others{margin-top:42px}
.others h2{font-family:var(--d);font-weight:600;text-transform:uppercase;letter-spacing:.4px;font-size:15px;color:var(--muted);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.others h2::after{content:"";flex:1;height:1px;background:var(--line)}
.ocards{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:620px){.ocards{grid-template-columns:1fr}}
.ocard{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:18px;display:flex;gap:15px;align-items:center;opacity:.78}
.ocard .ic{flex:0 0 auto;width:46px;height:46px;border-radius:11px;background:var(--panel2);border:1px solid var(--line2);display:grid;place-items:center;font-size:20px}
.ocard h4{font-family:var(--d);font-weight:600;font-size:16px;letter-spacing:.2px}
.ocard p{color:var(--faint);font-size:12.5px;margin-top:2px}
.ocard .lk{margin-left:auto;font:600 11px/1 var(--m);color:var(--faint)}
/* клікабельна картка наступної (реальної) операції - повна яскравість + стрілка */
a.ocard{text-decoration:none;color:inherit;opacity:1;transition:.16s}
a.ocard:hover{transform:translateY(-3px);border-color:var(--amber)}
a.ocard .go{margin-left:auto;font:700 12px/1 var(--m);color:var(--amber);letter-spacing:.03em;flex:0 0 auto}

/* ===== ЕТАП / БРИФІНГ ===== */
.crumb{font:500 13px/1 var(--m);color:var(--faint);margin-bottom:16px}
.crumb a:hover{color:var(--amber)} .crumb .s{margin:0 7px;color:#333a47}
.bgrid{display:grid;grid-template-columns:1fr 330px;gap:32px;align-items:start;margin-top:22px}
@media(max-width:920px){.bgrid{grid-template-columns:1fr}}
.stage-tag{display:inline-flex;align-items:center;gap:9px;font:700 12px/1 var(--m);letter-spacing:.06em;color:var(--amber);background:rgba(var(--amber-rgb),.08);border:1px solid rgba(var(--amber-rgb),.22);padding:7px 12px;border-radius:7px}
h1.bt{font-family:var(--d);font-weight:600;text-transform:uppercase;letter-spacing:0;font-size:27px;line-height:1.2;margin:14px 0 4px}

.scn{border:1px solid var(--line2);border-left:3px solid var(--amber);background:linear-gradient(180deg,rgba(var(--amber-rgb),.05),transparent 65%),var(--panel);border-radius:var(--r);padding:22px 24px;margin:0 0 28px}
.scn .tag{font:700 11px/1 var(--m);letter-spacing:.1em;text-transform:uppercase;color:var(--amber);display:block;margin-bottom:11px}
.scn p{font-size:16px;line-height:1.62;color:#D5D9E1}
.scn p+p{margin-top:11px}
.scn pre,.scn code{font-family:var(--m)}
.scn pre{background:var(--bg);border:1px solid var(--line2);border-radius:8px;padding:12px 14px;margin:11px 0;overflow:auto;font-size:13px;color:var(--kw)}
.scn :not(pre)>code{background:var(--bg);border:1px solid var(--line2);border-radius:5px;padding:2px 6px;font-size:13px;color:var(--kw)}
.scn .prev{margin-top:16px;padding:14px 16px;border-radius:10px;background:rgba(111,224,160,.07);border:1px solid rgba(111,224,160,.18)}
.scn .prev .prev-tag{display:block;font:700 11px/1 var(--m);letter-spacing:.09em;text-transform:uppercase;color:var(--green);margin-bottom:8px}
.scn .prev .prev-tag .prev-tag__ico{font-size:1.5em;line-height:0;vertical-align:-.12em;color:inherit}
.scn .prev p{font-family:var(--b);font-size:14.5px;line-height:1.6;color:#CBE3D2;margin:0}

.blk{margin-bottom:24px}
.blk h2{font-family:var(--d);font-weight:600;text-transform:uppercase;letter-spacing:.3px;font-size:18px;margin-bottom:9px;color:var(--amber)}
.blk p{color:#C8CCD5;margin-bottom:8px}
.blk a{color:var(--kw);text-decoration:underline;text-underline-offset:2px}
.blk strong{color:var(--txt)}
.blk :not(pre)>code{font-family:var(--m);font-size:13px;background:var(--bg);border:1px solid var(--line2);border-radius:5px;padding:2px 6px;color:var(--kw)}
.blk pre{font-family:var(--m);background:var(--bg);border:1px solid var(--line2);border-radius:8px;padding:12px 14px;margin:10px 0;overflow:auto;font-size:13px;color:var(--kw)}
.blk ul,.blk ol{margin:8px 0 0 0;padding-left:0;list-style:none}
.blk li{color:#C8CCD5;padding-left:22px;position:relative;margin-bottom:7px;line-height:1.5}
.blk ul>li::before{content:"▸";position:absolute;left:3px;color:var(--amber)}
.blk ol{counter-reset:n}
.blk ol>li{counter-increment:n}
.blk ol>li::before{content:counter(n);position:absolute;left:0;top:0;color:var(--amber);font:700 12px/1.6 var(--m)}

/* Locked-плейсхолдер "Розбору": спойлер відкривається лише після проходження. */
.locked{display:flex;align-items:center;gap:9px;padding:14px 16px;border-radius:10px;background:var(--panel2);border:1px dashed var(--line2);color:var(--faint);font:600 13px/1.4 var(--m);letter-spacing:.02em}

.mission{background:var(--panel);border:1px solid var(--line2);border-radius:var(--r);padding:20px 22px}
.mission h2{margin-bottom:10px}
.mission p{color:#C8CCD5;margin-bottom:8px}
.mission p:last-child{margin-bottom:0}

.hint-head{display:flex;align-items:baseline;gap:10px;margin:6px 0 12px}
.hints{display:flex;flex-direction:column;gap:9px}
.hint{border:1px solid var(--line2);border-radius:10px;background:var(--panel);overflow:hidden}
.hint summary{list-style:none;cursor:pointer;padding:13px 16px;display:flex;align-items:center;gap:12px;font-weight:600;font-size:14.5px}
.hint summary::-webkit-details-marker{display:none}
.hint summary:hover{background:var(--panel2)}
.hint .step{width:26px;height:26px;border-radius:6px;background:var(--panel2);border:1px solid var(--line2);display:grid;place-items:center;font:700 12px/1 var(--m);color:var(--amber);flex:0 0 auto}
.hint .ar{margin-left:auto;color:var(--faint);transition:.2s}
.hint[open] .ar{transform:rotate(90deg);color:var(--amber)}
.hint[open]{border-color:var(--amber)}
.hint .b{padding:2px 16px 15px 54px;color:var(--muted);font-size:14px;line-height:1.6}
.hint .b p{margin-bottom:8px} .hint .b p:last-child{margin-bottom:0}
.hint .b :not(pre)>code{font-family:var(--m);font-size:12.5px;background:var(--bg);border:1px solid var(--line2);border-radius:5px;padding:2px 6px;color:var(--kw)}
.hint .b pre{font-family:var(--m);background:var(--bg);border:1px solid var(--line2);border-radius:8px;padding:11px 13px;margin:9px 0;overflow:auto;font-size:12.5px;color:var(--kw)}
.hint .b ol,.hint .b ul{margin:6px 0 0;padding-left:0;list-style:none}
.hint .b li{position:relative;padding-left:20px;margin-bottom:6px}
.hint .b ol{counter-reset:h} .hint .b ol>li{counter-increment:h}
.hint .b ol>li::before{content:counter(h);position:absolute;left:0;color:var(--amber);font:700 11px/1.6 var(--m)}
.hint .b ul>li::before{content:"▸";position:absolute;left:3px;color:var(--amber)}
.hint .b a{color:var(--kw);text-decoration:underline}

.next{margin-top:26px;border:1px solid var(--line2);border-radius:var(--r);background:linear-gradient(120deg,rgba(95,208,224,.06),transparent 60%),var(--panel);padding:20px 22px;display:flex;gap:16px;align-items:flex-start}
.next .arrowbox{flex:0 0 auto;width:44px;height:44px;border-radius:11px;background:var(--panel2);border:1px solid var(--line2);display:grid;place-items:center;font-size:20px}
.next .tag{font:700 11px/1 var(--m);letter-spacing:.1em;text-transform:uppercase;color:var(--kw);display:block;margin-bottom:7px}
.next .nbody{color:var(--muted);font-size:14px;line-height:1.55}
.next .nbody :not(pre)>code{font-family:var(--m);font-size:12.5px;background:var(--bg);border:1px solid var(--line2);border-radius:5px;padding:2px 5px;color:var(--kw)}
/* клікабельний варіант блоку - реальний перехід до наступного етапу */
.next-link{text-decoration:none;color:inherit;cursor:pointer;transition:.16s}
.next-link:hover{border-color:rgba(var(--amber-rgb),.5)}

.side{position:sticky;top:80px;display:flex;flex-direction:column;gap:15px}
.card{background:var(--panel);border:1px solid var(--line2);border-radius:var(--r);padding:19px}
.card .label{font:700 11px/1 var(--m);letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:14px}
.ml{display:flex;flex-direction:column;gap:11px;margin-bottom:17px}
.ml .r{display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:13.5px}
.ml .r>span:first-child{color:var(--muted);flex:0 0 auto} .ml .r b{font-weight:600;font-family:var(--b);text-align:right}
.loot .label{margin-bottom:8px}
.loot .desc{font-size:12.5px;color:var(--muted);margin-bottom:12px;line-height:1.45}
.loot-row{display:flex;gap:8px}
.loot-in{flex:1;min-width:0;background:var(--bg);border:1px solid var(--line2);border-radius:9px;padding:12px 13px;color:var(--txt);font-family:var(--m);font-size:13px;outline:none;transition:.15s;letter-spacing:.04em}
.loot-in::placeholder{color:var(--faint)}
.loot-in:focus{border-color:var(--amber);box-shadow:0 0 0 3px rgba(var(--amber-rgb),.13)}
.loot-sub{background:var(--panel2);border:1px solid var(--line2);color:var(--txt);padding:0 16px;border-radius:9px;cursor:pointer;font-weight:600}
.loot-sub:hover{border-color:var(--amber);color:var(--amber)}
.note-s{font:500 11.5px/1.5 var(--m);color:var(--faint);margin-top:11px}

/* ===== ТАЙМЕР АВТО-СТОПУ ІНСТАНСУ (приглушено-акцентний рядок) ===== */
.lab-timer{display:flex;align-items:center;gap:7px;margin-top:11px;
  font:500 12px/1.4 var(--b);color:var(--muted);
  padding:9px 12px;border-radius:9px;
  background:rgba(111,224,160,.06);border:1px solid rgba(111,224,160,.22)}
.lab-timer .lt-ic{flex:0 0 auto;color:var(--green);font-size:13px;line-height:1}
.lab-timer b{font-family:var(--m);font-weight:600;letter-spacing:.04em;color:var(--green);
  font-variant-numeric:tabular-nums}

/* ===== СКИД ПРОГРЕСУ (деструктивні, ненав'язливі ghost-кнопки) ===== */
/* приглушено-червоний контур, прозорий фон; яскравішає лише на hover */
.btn-reset{width:100%;cursor:pointer;font:600 13px/1 var(--m);letter-spacing:.03em;
  padding:11px 14px;border-radius:9px;background:transparent;
  color:var(--red);border:1px solid rgba(255,107,107,.32);
  opacity:.82;transition:.16s}
.btn-reset:hover{opacity:1;border-color:var(--red);background:rgba(255,107,107,.08)}
.btn-reset.sm{padding:8px 12px;font-size:12px;border-radius:8px;width:100%}
/* Недоступна (нема прогресу для скиду): приглушена, без ховеру/курсора. */
.btn-reset:disabled{opacity:.32;cursor:not-allowed;border-color:rgba(255,107,107,.16);color:rgba(255,107,107,.7)}
.btn-reset:disabled:hover{background:transparent;border-color:rgba(255,107,107,.16);opacity:.32}
/* картка-скид на карті: трохи притишений підпис */
.op-danger .lbl{color:var(--red);opacity:.7}
.reset-note{font:500 11.5px/1.5 var(--m);color:var(--faint);margin-bottom:13px}
/* рядок-підтвердження над кнопкою скиду етапу */
.loot-done{display:flex;align-items:center;gap:7px;margin-top:13px;
  font:600 12.5px/1 var(--m);letter-spacing:.02em;color:var(--green)}
.loot-done .ld-ic{font-size:13px}
/* кнопка скиду етапу - окрема standalone-дія внизу .side (поза картками) */
.reset-stage{margin-top:1px}

/* ===== МОДАЛКА ПІДТВЕРДЖЕННЯ (деструктивні дії) ===== */
/* оверлей: фіксований, затемнення, центрування, поверх усього */
.cdlg-ov{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;
  padding:24px;background:rgba(6,8,11,.72);backdrop-filter:blur(3px);
  opacity:0;transition:opacity .16s ease}
.cdlg-ov.open{opacity:1}
/* діалог: темна панель у стилі командного центру */
.cdlg{width:100%;max-width:420px;background:var(--panel);border:1px solid var(--line2);
  border-radius:var(--r);padding:24px;box-shadow:0 24px 60px -20px rgba(0,0,0,.7);
  transform:translateY(8px) scale(.985);transition:transform .16s ease;outline:none}
.cdlg-ov.open .cdlg{transform:none}
.cdlg-h{font:700 16px/1.2 var(--d);color:var(--txt);margin-bottom:10px}
.cdlg-b{font:500 13.5px/1.55 var(--b);color:var(--muted);margin-bottom:20px}
.cdlg-act{display:flex;gap:10px;justify-content:flex-end}
.cdlg-btn{cursor:pointer;font:600 13px/1 var(--b);padding:11px 18px;border-radius:9px;transition:.16s}
/* "Скасувати" - ghost */
.cdlg-cancel{background:transparent;border:1px solid var(--line2);color:var(--muted)}
.cdlg-cancel:hover{border-color:var(--faint);color:var(--txt)}
/* "Скинути" - червона деструктивна (узгоджено з --red / .btn-reset) */
.cdlg-go{background:rgba(255,107,107,.1);border:1px solid rgba(255,107,107,.5);color:var(--red)}
.cdlg-go:hover{background:var(--red);border-color:var(--red);color:#1a0808}

/* ===== ПРОФІЛЬ ===== */
.phead{display:flex;gap:22px;align-items:center;margin-bottom:30px}
.pav-img{width:84px;height:84px;border-radius:22px;object-fit:cover;display:block;background:var(--panel2);border:1px solid var(--line2);box-shadow:0 12px 30px -14px rgba(0,0,0,.7)}
.phead h1{font-family:var(--d);font-weight:600;text-transform:uppercase;letter-spacing:.4px;font-size:28px}
.phead .sub{color:var(--muted);margin-top:4px}
.phead .rank{display:inline-flex;align-items:center;gap:7px;margin-top:9px;font:700 12px/1 var(--m);letter-spacing:.05em;color:var(--amber);border:1px solid rgba(var(--amber-rgb),.25);background:rgba(var(--amber-rgb),.06);padding:8px 13px;border-radius:7px}
.phead .rank .star{width:15px;height:15px;flex:0 0 auto;display:block}
.phead .rank-next{margin-top:7px;font:500 11.5px/1 var(--m);color:var(--faint)}

.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:15px;margin-bottom:30px}
@media(max-width:760px){.grid3{grid-template-columns:1fr}}
.sc{background:var(--panel);border:1px solid var(--line2);border-radius:var(--r);padding:20px}
.sc .big{font-family:var(--d);font-weight:600;font-size:38px;line-height:1}
.sc .cap{color:var(--muted);font-size:13px;margin-top:7px}

.ops{display:flex;flex-direction:column;gap:13px;margin-bottom:30px}
.op-row{background:var(--panel);border:1px solid var(--line2);border-radius:var(--r);padding:18px 20px}
.op-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:13px}
.op-name{display:inline-flex;align-items:center;gap:9px;font-family:var(--d);font-weight:600;text-transform:uppercase;letter-spacing:.3px;font-size:15px}
.op-ic{font-size:17px;line-height:1}
.op-count{font:600 12px/1 var(--m);color:var(--amber)}
.pips-row{display:flex;gap:6px}
.pip{flex:1;min-height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:var(--panel2);border:1px solid var(--line);font:700 11px/1 var(--m);color:var(--faint)}
.pip.done{background:rgba(var(--done-rgb),.14);border-color:var(--done);color:var(--done)}
.pip.cur{background:var(--amber);border-color:var(--amber);color:var(--on-accent)}

.sh{font-family:var(--d);font-weight:600;text-transform:uppercase;letter-spacing:.3px;font-size:16px;color:var(--muted);margin:8px 0 14px}
.sh-count{font:500 12px/1 var(--m);letter-spacing:0;text-transform:none;color:var(--faint);margin-left:9px}

/* Техніки - сітка чипів-навичок (арсенал) */
.techs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:30px}
.tech{font:600 12px/1 var(--m);letter-spacing:.02em;color:var(--faint);background:var(--panel);border:1px solid var(--line2);border-radius:99px;padding:8px 13px;transition:.16s}
.tech.on{color:var(--green);border-color:rgba(111,224,160,.4);background:rgba(111,224,160,.08)}

.badges{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:13px}
.bdg{background:var(--panel);border:1px solid var(--line2);border-radius:var(--r);padding:18px;text-align:center;transition:.18s}
.bdg:hover{transform:translateY(-3px);border-color:var(--amber)}
.bdg.lock{opacity:.4}
.bdg .ic{width:52px;height:52px;margin:0 auto 11px;border-radius:13px;display:grid;place-items:center;font-size:23px;background:var(--panel2);border:1px solid var(--line2)}
.bdg.on .ic{background:rgba(var(--amber-rgb),.1);border-color:rgba(var(--amber-rgb),.28)}
.bdg h4{font-family:var(--d);font-weight:600;font-size:14px;letter-spacing:.2px;margin-bottom:3px}
.bdg p{color:var(--faint);font-size:11.5px;font-family:var(--m)}

.note{margin-top:40px;padding:17px 20px;border:1px dashed var(--line2);border-radius:var(--r);color:var(--faint);font:500 13px/1.5 var(--m)}

/* ===== СТАРТОВА СТОРІНКА (лендінг) ===== */
.hero{margin:6px 0 46px;max-width:74ch}
/* головний титул героя - помітний заголовок сторінки (не дрібний eyebrow) */
.hero-kicker{font-family:var(--d);font-weight:700;font-size:32px;line-height:1.08;letter-spacing:.2px;color:var(--txt);margin:2px 0 18px}
.hero-title{font-family:var(--d);font-weight:800;font-size:54px;line-height:1.02;letter-spacing:.5px;text-transform:uppercase;margin:14px 0 16px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.hero-mark{display:inline-flex;width:52px;height:52px;color:var(--amber);flex:0 0 auto}
.hero-mark .logo-mark-svg{display:block;width:100%;height:100%}
.hero-lead{color:var(--muted);font-size:17px;line-height:1.6;max-width:70ch}
.hero-lead b{color:var(--txt);font-weight:600}

/* спільний заголовок секцій лендінгу (uppercase Manrope з рейкою) */
.sec-h{font-family:var(--d);font-weight:600;text-transform:uppercase;letter-spacing:.4px;font-size:15px;color:var(--muted);margin-bottom:16px;display:flex;align-items:center;gap:10px}

/* як це працює - 4 картки */
.how{margin-bottom:48px}
.how-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:900px){.how-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.how-grid{grid-template-columns:1fr}}
.how-card{background:var(--panel);border:1px solid var(--line2);border-radius:var(--r);padding:18px 19px}
.how-card .hn{font:700 12px/1 var(--m);letter-spacing:.1em;color:var(--amber);margin-bottom:11px}
.how-card h3{font-family:var(--d);font-weight:600;font-size:16px;letter-spacing:.2px;text-transform:uppercase;margin-bottom:7px}
.how-card p{color:var(--muted);font-size:13.5px;line-height:1.5}

/* кампанії */
.camps{margin-bottom:8px}
.camp-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;align-items:stretch}
@media(max-width:820px){.camp-grid{grid-template-columns:1fr}}
.camp-card{background:var(--panel);border:1px solid var(--line2);border-radius:var(--r);padding:20px 22px;display:flex;flex-direction:column;gap:16px}
.camp-card.soon{opacity:.72}
.cc-head{display:flex;align-items:center;gap:13px}
.cc-ic{flex:0 0 auto;width:46px;height:46px;border-radius:11px;background:var(--panel2);border:1px solid var(--line2);display:grid;place-items:center;font-size:22px}
.cc-id{min-width:0}
.cc-id h3{font-family:var(--d);font-weight:600;font-size:22px;letter-spacing:.3px;text-transform:uppercase;margin-top:3px}
.cc-live{margin-left:auto;flex:0 0 auto;font:700 10.5px/1 var(--m);letter-spacing:.06em;text-transform:uppercase;color:var(--green);background:rgba(111,224,160,.12);border:1px solid rgba(111,224,160,.28);padding:6px 10px;border-radius:99px}
.cc-soon{margin-left:auto;flex:0 0 auto;font:600 11px/1 var(--m);color:var(--faint)}
/* Опис обрізаємо до 4 рядків - щоб нижні блоки (Наслідок/Прогрес/кнопка) збігались по всіх картках */
.cc-intro{color:var(--muted);font-size:14px;line-height:1.55;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:4;overflow:hidden;min-height:calc(14px * 1.55 * 4)}
.cc-meta{display:flex;gap:26px;flex-wrap:wrap}
.cc-meta .it .k{font:600 11px/1 var(--m);letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:7px}
.cc-meta .it .v{font-family:var(--d);font-weight:600;font-size:18px;min-height:22px;display:flex;align-items:center}
.cc-diff{display:flex;align-items:center;gap:8px}
.cc-dash{color:var(--faint);font-family:var(--m)}
/* «Наслідок» - окремий блок (не 3-я колонка meta, бо там нестабільно переносився).
   margin-top:auto притискає хвіст (Наслідок+Прогрес+кнопка) донизу -> блоки збігаються по всіх картках. */
.cc-conseq{margin-top:auto}
.cc-conseq .k{font:600 11px/1 var(--m);letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:8px}
.cc-conseq .v{font-family:var(--d);font-weight:600;font-size:21px;line-height:1.2;color:var(--txt)}
.camp-card .btn-run{text-decoration:none}

/* ===========================================================
   WEB FUNDAMENTALS - навчальний розділ (лендінг тем, урок,
   симулятор, квіз). Переюзує токени :root і базові класи.
   =========================================================== */

/* --- прогрес курсу на лендінгу --- */
.wf-prog{margin:22px 0 30px}
.wf-prog .prog{max-width:none}

/* --- сітка карток тем --- */
.topic-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:900px){.topic-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.topic-grid{grid-template-columns:1fr}}
.topic-card{background:var(--panel);border:1px solid var(--line2);border-radius:var(--r);
  padding:20px 21px;display:flex;flex-direction:column;gap:10px;transition:.18s;position:relative}
.topic-card:hover{transform:translateY(-3px);border-color:var(--amber)}
.topic-card.done{border-color:rgba(var(--done-rgb),.34)}
.topic-card.done:hover{border-color:var(--done)}
.tc-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.tc-ic{flex:0 0 auto;width:46px;height:46px;border-radius:11px;background:var(--panel2);
  border:1px solid var(--line2);display:grid;place-items:center;font-size:22px}
.tc-done{font:700 10.5px/1 var(--m);letter-spacing:.05em;text-transform:uppercase;color:var(--done);
  background:rgba(var(--done-rgb),.12);border:1px solid rgba(var(--done-rgb),.3);padding:6px 10px;border-radius:99px}
.tc-title{font-family:var(--d);font-weight:600;font-size:18px;letter-spacing:.2px;text-transform:uppercase}
.tc-blurb{color:var(--muted);font-size:13.5px;line-height:1.5;flex:1}
.tc-go{font:700 12px/1 var(--m);color:var(--amber);letter-spacing:.03em;margin-top:2px;display:inline-flex;align-items:center;gap:7px}
.tc-go .tc-arr{font-size:1.7em;line-height:0}
.topic-card.done .tc-go{color:var(--done)}

/* --- сторінка теми: іконка в заголовку --- */
.tt-ic{font-size:.85em;margin-right:6px}
/* кікер "ТЕМА N" на сторінці теми - крупніший (~15px), щоб не губився під назвою */
.topic-kicker{font-size:15px;letter-spacing:.14em}

/* --- блок уроку (готовий HTML з marked) --- */
.panel{background:var(--panel);border:1px solid var(--line2);border-radius:var(--r);padding:24px 26px}
.lesson{margin:24px 0}
.lesson h2{font-family:var(--d);font-weight:600;text-transform:uppercase;letter-spacing:.3px;
  font-size:17px;color:var(--amber);margin:22px 0 9px}
.lesson h2:first-child{margin-top:0}
.lesson p{color:#C8CCD5;margin-bottom:10px;line-height:1.62}
.lesson strong{color:var(--txt)}
.lesson a{color:var(--kw);text-decoration:underline;text-underline-offset:2px}
.lesson :not(pre)>code{font-family:var(--m);font-size:13px;background:var(--bg);
  border:1px solid var(--line2);border-radius:5px;padding:2px 6px;color:var(--kw)}
.lesson pre{font-family:var(--m);background:var(--bg);border:1px solid var(--line2);border-radius:8px;
  padding:12px 14px;margin:10px 0;overflow:auto;font-size:13px;color:var(--kw)}
.lesson ul,.lesson ol{margin:8px 0 12px;padding-left:0;list-style:none}
.lesson li{color:#C8CCD5;padding-left:22px;position:relative;margin-bottom:7px;line-height:1.55}
.lesson ul>li::before{content:"\25B8";position:absolute;left:1px;top:0;color:var(--amber);font-size:1.3em;line-height:1.2}
.lesson ol{counter-reset:n}
.lesson ol>li{counter-increment:n;padding-left:34px}
/* номер як бейдж-у-рамці (суголосно з .qq-num); вирівняний по першому рядку тексту */
.lesson ol>li::before{content:counter(n);position:absolute;left:0;top:.1em;width:22px;height:22px;
  border-radius:7px;background:var(--panel2);border:1px solid var(--line2);
  display:grid;place-items:center;font:700 11.5px/1 var(--m);color:var(--amber)}

/* --- заголовок секції теми (Симулятор / Перевір себе) --- */
.wf-sec{margin:30px 0}
.wf-h{font-family:var(--d);font-weight:600;text-transform:uppercase;letter-spacing:.4px;
  font-size:15px;color:var(--muted);margin-bottom:14px}

/* ============ СИМУЛЯТОР ============ */
.sim{background:var(--panel);border:1px solid var(--line2);border-radius:var(--r);overflow:hidden}
.sim-soon{background:var(--panel);border:1px dashed var(--line2);border-radius:var(--r);
  padding:24px;color:var(--faint);font:600 13px/1.4 var(--m);text-align:center}
/* верхня смуга-"вікно" консолі */
.sim-bar{display:flex;align-items:center;gap:7px;padding:11px 16px;background:var(--bg2);border-bottom:1px solid var(--line)}
.sim-dot{width:10px;height:10px;border-radius:50%;flex:0 0 auto}
.sim-dot.r{background:#FF6B6B}.sim-dot.y{background:var(--amber)}.sim-dot.g{background:var(--green)}
.sim-title{margin-left:8px;font:600 12px/1 var(--m);color:var(--muted);letter-spacing:.04em}

/* блок запиту */
.sim-req{display:flex;align-items:center;gap:14px;flex-wrap:wrap;padding:16px 18px;border-bottom:1px solid var(--line)}
.sr-lbl{font:700 10.5px/1 var(--m);letter-spacing:.1em;text-transform:uppercase;color:var(--faint)}
.sr-line{font-family:var(--m);font-size:14px;color:var(--txt);background:var(--bg);
  border:1px solid var(--line2);border-radius:8px;padding:9px 13px}
.sr-line b{color:var(--amber)}.sr-line .dim{color:var(--faint)}
.sim-send{margin-left:auto;border:none;cursor:pointer;font:700 13px/1 var(--b);letter-spacing:.02em;
  padding:11px 18px;border-radius:9px;background:var(--accent-grad);color:var(--on-accent);
  box-shadow:0 8px 20px -10px var(--amber);transition:.16s}
.sim-send:hover{filter:brightness(1.07);transform:translateY(-1px)}

/* відповідь, розкладена на частини */
.sim-resp{padding:16px 18px;display:flex;flex-direction:column;gap:11px}
.rp-part{position:relative;border:1px solid var(--line2);border-radius:10px;padding:14px 15px 14px;
  background:var(--bg);cursor:pointer;transition:.15s}
.rp-part:hover{border-color:var(--line2);background:var(--bg2)}
.rp-part.active{border-color:var(--amber);box-shadow:0 0 0 3px rgba(var(--amber-rgb),.12)}
.rp-tag{display:inline-block;font:700 10px/1 var(--m);letter-spacing:.1em;text-transform:uppercase;
  color:var(--faint);margin-bottom:9px}
.rp-part.active .rp-tag{color:var(--amber)}
.rp-status{display:block;font-family:var(--m);font-size:14px;color:var(--txt)}
.rp-status .dim{color:var(--faint)}.rp-status b{color:var(--green)}
.rp-headers{display:flex;flex-direction:column;gap:5px}
.rp-h{font-family:var(--m);font-size:13px;color:var(--muted);word-break:break-all}
.rp-h .hk{color:var(--kw)}.rp-h .hv{color:var(--txt)}
.rp-h.hot{position:relative}
.rp-h.hot .hk{color:var(--kw)}
.rp-body{font-family:var(--m);font-size:13px;color:var(--green);background:transparent;border:none;
  padding:0;margin:0;overflow:auto;line-height:1.5}

/* пояснення частини / підказка */
.sim-explain{margin:0 18px 16px;padding:13px 15px;border-radius:10px;
  background:var(--panel2);border:1px solid var(--line2);color:var(--muted);font-size:13.5px;line-height:1.55}
.sim-explain.hint{color:var(--faint);font-family:var(--m);font-size:12.5px;border-style:dashed}
.sim-explain .se-k{color:var(--amber);font-weight:600}

/* міні-челендж (X-Training-Token) */
/* челендж - повноширинна секція (як решта секцій сима), а не плаваючий інсет-бокс,
   щоб не виглядати окремою «полоскою» з порожнечею навколо */
.sim-chal{padding:16px 18px;
  background:linear-gradient(160deg,rgba(var(--amber-rgb),.05),var(--panel2));border-top:1px solid var(--line)}
/* лейбл челенджу БЕЗ хвостового відступу - щоб бокс не мав порожньої смужки під одним рядком.
   Відступ додаємо лише коли далі реально є поле вводу (.sc-row), а не порожнеча */
.sc-q{display:block;font:600 13.5px/1.5 var(--b);color:var(--txt);margin-bottom:0}
.sc-q + .sc-row{margin-top:11px}
.sc-q code{font-family:var(--m);font-size:12.5px;background:var(--bg);border:1px solid var(--line2);
  border-radius:5px;padding:2px 6px;color:var(--kw)}
.sc-row{display:flex;gap:9px}
.sc-in{flex:1;min-width:0;background:var(--bg);border:1px solid var(--line2);border-radius:9px;
  padding:11px 13px;color:var(--txt);font-family:var(--m);font-size:13px;outline:none;transition:.15s;letter-spacing:.04em}
.sc-in::placeholder{color:var(--faint)}
.sc-in:focus{border-color:var(--amber);box-shadow:0 0 0 3px rgba(var(--amber-rgb),.13)}
.sc-btn{border:1px solid var(--line2);background:var(--panel2);color:var(--txt);padding:10px 16px;
  border-radius:9px;cursor:pointer;font:700 13px/1 var(--b);transition:.15s}
.sc-btn:hover{border-color:var(--amber);color:var(--amber)}
/* hidden завжди ховає: не даємо display-правилам показувати порожні плейсхолдери */
[hidden]{display:none!important}
/* вимкнути лігатури: у навчальному коді/пейлоадах "--", "->", "!=" мають рендеритись БУКВАЛЬНО,
   інакше моношрифт зливає "--" у єдину тире-лігатуру й ламає синтаксис (HTML-коментарі, curl, оператори) */
body,input,textarea,button,select,code,pre,kbd,samp{font-variant-ligatures:none;font-feature-settings:"liga" 0,"calt" 0}
/* блок звичайного текстового потоку: інлайн-чипи (code) течуть у рядок, не ламаються в стовпці */
.sc-out{margin-top:12px;padding:11px 14px;border-radius:9px;font:600 13px/1.6 var(--b)}
.sc-out .sc-ico{font-weight:700;margin-right:5px}
.sc-out code{font-family:var(--m);font-size:12px;background:var(--bg);border:1px solid var(--line2);
  border-radius:5px;padding:1px 5px;color:var(--kw)}
.sc-out.ok{color:var(--green);background:rgba(111,224,160,.08);border:1px solid rgba(111,224,160,.3)}
.sc-out.bad{color:var(--red);background:rgba(255,107,107,.07);border:1px solid rgba(255,107,107,.28)}

/* ============ КВІЗ ============ */
#quiz{display:flex;flex-direction:column;gap:14px}
.quiz-q{background:var(--panel);border:1px solid var(--line2);border-radius:var(--r);padding:18px 20px}
.qq-text{display:flex;gap:11px;align-items:flex-start;font:600 15px/1.5 var(--b);color:var(--txt);margin-bottom:13px}
.qq-num{flex:0 0 auto;width:24px;height:24px;border-radius:7px;background:var(--panel2);border:1px solid var(--line2);
  display:grid;place-items:center;font:700 12px/1 var(--m);color:var(--amber)}
.qq-opts{display:flex;flex-direction:column;gap:8px}
.qq-opt{display:flex;align-items:center;gap:11px;width:100%;text-align:left;cursor:pointer;
  background:var(--bg);border:1px solid var(--line2);border-radius:9px;padding:11px 13px;
  color:var(--txt);font:500 14px/1.4 var(--b);transition:.14s}
.qq-opt:hover{border-color:var(--line2);background:var(--bg2)}
.qq-mark{flex:0 0 auto;width:16px;height:16px;border-radius:50%;border:2px solid var(--line2);transition:.14s}
.qq-opt.sel{border-color:var(--amber)}
.qq-opt.sel .qq-mark{border-color:var(--amber);background:radial-gradient(circle,var(--amber) 0 45%,transparent 52%)}
.qq-opt.ok{border-color:var(--green);background:rgba(111,224,160,.08)}
.qq-opt.ok .qq-mark{border-color:var(--green);background:radial-gradient(circle,var(--green) 0 45%,transparent 52%)}
.qq-opt.bad{border-color:var(--red);background:rgba(255,107,107,.07)}
.qq-opt.bad .qq-mark{border-color:var(--red);background:radial-gradient(circle,var(--red) 0 45%,transparent 52%)}
/* блок звичайного потоку: мітка - інлайн-лейбл перед поясненням, вирівняний по рядку тексту */
.qq-explain{margin-top:12px;padding:13px 15px;border-radius:9px;background:var(--panel2);
  border:1px solid var(--line2);color:var(--muted);font-size:13.5px;line-height:1.7}
.qe-tag{display:inline-flex;align-items:center;gap:6px;font:700 14px/1 var(--d);
  letter-spacing:.02em;text-transform:uppercase;vertical-align:middle;margin-right:9px;white-space:nowrap}
.qe-tag .qe-ico{font-size:15px;line-height:1}
.qe-tag.ok{color:var(--green)}.qe-tag.bad{color:var(--red)}
.qe-text{color:var(--muted);vertical-align:middle}
.quiz-foot{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:4px}
.quiz-btn{border:none;cursor:pointer;font:700 14px/1 var(--b);letter-spacing:.02em;padding:13px 22px;
  border-radius:10px;background:var(--accent-grad);color:var(--on-accent);box-shadow:0 8px 20px -10px var(--amber);transition:.16s}
.quiz-btn:hover{filter:brightness(1.07);transform:translateY(-1px)}
.quiz-result{font:600 13.5px/1.5 var(--b)}
.quiz-result.warn{color:var(--amber)}
.quiz-result.bad{color:var(--red)}
.quiz-result.ok{color:var(--green)}
.quiz-result .qr-ok{font-family:var(--d);font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--green)}
/* пройдена тема: "Тему пройдено" по центру футера (кнопку "Перевірити" сховано) */
.quiz-result.done{flex:1;text-align:center;font-size:16px}
.quiz-result.done .qr-ok{font-size:17px}

/* ============ НАВІГАЦІЯ ТЕМИ ============ */
/* три рівні кнопки в один ряд: однакова ширина, висота й стиль */
.topic-nav{display:flex;justify-content:space-between;align-items:center;gap:12px;margin:34px 0 0}
.tn-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;height:44px;overflow:hidden;background:var(--panel);
  border:1px solid rgba(var(--amber-rgb),.26);border-radius:11px;padding:0 16px;
  font:600 13.5px/1 var(--b);color:var(--txt);transition:.16s;white-space:nowrap}
.tn-btn:hover{border-color:var(--amber);color:var(--amber)}
.tn-ar{display:inline-block;line-height:0;vertical-align:middle;font-family:var(--m)}
@media(max-width:560px){.topic-nav{flex-direction:column;align-items:stretch}.tn-btn{text-align:center}}

/* ============ СИМ - РЕЖИМ 'methods' (тема 4) ============ */
.mt-build{padding:16px 18px;display:flex;flex-direction:column;gap:14px;border-bottom:1px solid var(--line)}
.mt-group{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.mt-lbl{font:700 10.5px/1 var(--m);letter-spacing:.1em;text-transform:uppercase;color:var(--faint);width:54px;flex:0 0 auto}
.mt-seg{display:inline-flex;background:var(--bg);border:1px solid var(--line2);border-radius:9px;padding:3px;gap:2px}
.mt-seg-b{border:none;background:transparent;color:var(--muted);font:700 12.5px/1 var(--m);padding:8px 13px;border-radius:7px;cursor:pointer;transition:.14s}
.mt-seg-b:hover{color:var(--txt)}
.mt-seg-b.on{background:var(--amber);color:var(--on-accent)}
.mt-targets{display:flex;gap:8px;flex-wrap:wrap;flex:1}
.mt-target-b{display:flex;flex-direction:column;align-items:flex-start;gap:3px;background:var(--bg);border:1px solid var(--line2);border-radius:9px;padding:9px 12px;cursor:pointer;transition:.14s;text-align:left}
.mt-target-b:hover{border-color:var(--line2);background:var(--bg2)}
.mt-target-b.on{border-color:var(--amber);box-shadow:0 0 0 2px rgba(var(--amber-rgb),.13)}
.mt-target-b code{font-family:var(--m);font-size:12.5px;color:var(--txt)}
.mt-target-b.on code{color:var(--amber)}
.mt-t-desc{font:500 11px/1 var(--b);color:var(--muted)}
.mt-line{display:flex;align-items:center;justify-content:center;gap:11px;flex-wrap:wrap;margin-top:18px;margin-bottom:6px}
/* кнопка "Виконати" стоїть ліворуч у контент-зоні (там де раніше був прев'ю запиту) */
.mt-line .sim-send{margin-left:0}
.mt-pre{font:700 10.5px/1 var(--m);letter-spacing:.1em;text-transform:uppercase;color:var(--faint);width:54px;flex:0 0 auto}
.mt-req{font-family:var(--m);font-size:14px;color:var(--txt);background:var(--bg);border:1px solid var(--line2);border-radius:8px;padding:9px 13px}
.mt-req b{color:var(--amber)}
/* відповідь сервера: один інлайн-рядок (іконка + статус + опис), колір за класом */
.mt-resp{margin:13px 18px;padding:11px 14px;border-radius:9px;font:600 13px/1.6 var(--b)}
.mt-resp .sc-ico{font-weight:700;margin-right:5px}
.mt-resp b{font-weight:700}
.mt-resp.ok{color:var(--green);background:rgba(111,224,160,.08);border:1px solid rgba(111,224,160,.3)}
/* warn = справжній теплий амбер (--kw #FF9F43); тут --amber перевизначено на синій, тож беремо --kw */
.mt-resp.warn{color:var(--kw);background:rgba(255,159,67,.08);border:1px solid rgba(255,159,67,.3)}
.mt-resp.bad{color:var(--red);background:rgba(255,107,107,.07);border:1px solid rgba(255,107,107,.28)}

/* ============ СИМ - РЕЖИМ 'url' (тема 5) ============ */
/* без border-bottom: зайва лінія над блоком челенджу прибрана (картка челенджу
   має власну рамку, тож роздільник тут дублює її й виглядає погано) */
.ur-wrap{padding:16px 18px}
.ur-bar{display:flex;align-items:center;flex-wrap:wrap;background:var(--bg);border:1px solid var(--line2);border-radius:9px;padding:11px 13px;font-family:var(--m);font-size:14px;overflow:auto}
.ur-part{padding:3px 4px;border-radius:5px;cursor:pointer;transition:.13s;color:var(--txt);white-space:nowrap}
.ur-part:hover{background:var(--panel2)}
.ur-part.active{background:rgba(var(--amber-rgb),.16);color:var(--amber)}
.ur-part.query{color:var(--kw)}
.ur-sep{color:var(--faint)}
.ur-controls{display:flex;align-items:center;gap:13px;flex-wrap:wrap;margin-top:13px}
.ur-clbl{font:700 10.5px/1 var(--m);letter-spacing:.08em;text-transform:uppercase;color:var(--faint)}
.ur-pp{display:inline-flex;align-items:center;gap:6px;font-family:var(--m);font-size:13px;color:var(--muted)}
.ur-tog{border:1px solid var(--line2);background:var(--bg);color:var(--muted);font:600 12.5px/1 var(--m);padding:7px 11px;border-radius:7px;cursor:pointer;transition:.14s}
.ur-tog:hover{color:var(--txt);border-color:var(--line2)}
.ur-tog.on{border-color:var(--amber);background:rgba(var(--amber-rgb),.1);color:var(--amber)}
.ur-controls .sim-send{margin-left:auto}
.ur-resp{padding:16px 18px}
.ur-rtag{display:inline-block;font:700 11px/1 var(--m);letter-spacing:.04em;color:var(--muted);margin-bottom:10px}
.ur-resp.full .ur-rtag{color:var(--green)}
.ur-rbody{font-family:var(--m);font-size:13px;color:var(--muted);background:var(--bg);border:1px solid var(--line2);border-radius:8px;padding:12px 14px;margin:0;overflow:auto;line-height:1.5}
.ur-resp.full .ur-rbody{color:var(--green);border-color:rgba(111,224,160,.3)}

/* ============ СИМ - РЕЖИМ 'cookie' (тема 7) ============ */
.ck-steps{display:flex;gap:10px;flex-wrap:wrap;padding:16px 18px;border-bottom:1px solid var(--line)}
.ck-btn{margin-left:0}
.ck-btn:disabled{opacity:.45;cursor:not-allowed;filter:none;transform:none;box-shadow:none}
.ck-log{padding:0 18px}
.ck-log:not(:empty){padding:16px 18px;border-bottom:1px solid var(--line)}
.ck-entry{background:var(--bg);border:1px solid var(--line2);border-radius:10px;padding:12px 14px;margin-bottom:10px;display:flex;flex-direction:column;gap:6px}
.ck-entry:last-child{margin-bottom:0}
.ck-dir{font-family:var(--m);font-size:13px;color:var(--muted)}
.ck-dir code{font-family:var(--m)}.ck-dir code b{color:var(--amber)}
.ck-arr{color:var(--faint)}
.ck-setcookie,.ck-sentcookie{font-family:var(--m);font-size:12.5px;word-break:break-all;background:var(--panel2);border:1px solid var(--line2);border-radius:7px;padding:8px 10px}
.ck-setcookie{border-color:rgba(var(--amber-rgb),.35)}
.ck-sentcookie{border-color:rgba(95,208,224,.3)}
.ck-setcookie .hk{color:var(--amber)}
.ck-sentcookie .hk{color:var(--kw)}
.ck-note{font:500 12px/1.4 var(--m);color:var(--faint)}
.ck-store{padding:16px 18px;border-bottom:1px solid var(--line)}
.ck-store-h{font:700 10.5px/1 var(--m);letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-bottom:11px}
.ck-jar{margin-bottom:12px}
.ck-jar-item{font-family:var(--m);font-size:12.5px;word-break:break-all;background:var(--bg);border:1px solid var(--line2);border-radius:8px;padding:10px 12px;display:block}
.ck-jar-item .hk{color:var(--kw)}.ck-jar-item .hv{color:var(--txt)}
.ck-dec{margin-bottom:0}
.ck-decoded{margin-top:12px}
.ck-dec-h{font:500 12px/1.4 var(--m);color:var(--faint);margin-bottom:8px}
.ck-dec-body{font-family:var(--m);font-size:13px;color:var(--green);background:var(--bg);border:1px solid rgba(111,224,160,.28);border-radius:8px;padding:12px 14px;margin:0;overflow:auto;line-height:1.5}

/* ============ СИМ - РЕЖИМ 'data' (тема 9) ============ */
.dt-resp{padding:16px 18px;border-bottom:1px solid var(--line)}
.dt-rtag{display:inline-block;font:700 11px/1 var(--m);letter-spacing:.03em;color:var(--muted);margin-bottom:11px}
.dt-json{background:var(--bg);border:1px solid var(--line2);border-radius:9px;padding:14px 16px;font-family:var(--m);font-size:13px;line-height:1.55;overflow:auto}
.dt-line{white-space:nowrap}
.dt-ind0{padding-left:0}.dt-ind1{padding-left:18px}.dt-ind2{padding-left:36px}
.dt-json .jk{color:var(--kw)}
.dt-json .jp{color:var(--faint)}
/* клікабельні значення - підсвічування кольором за типом */
/* значення - чиста підсвічена частина коду (без чип-падінгу), щоб коми/дужки стояли впритул */
.dt-val{cursor:pointer;border-radius:4px;transition:.13s}
.dt-val:hover{background:var(--panel2)}
.dt-val.active{background:var(--panel2);box-shadow:inset 0 0 0 1px currentColor}
/* кольори типів значень (переюзуємо токени палітри) */
.dt-t-string{color:var(--green)}
.dt-t-number{color:var(--kw)}
.dt-t-boolean{color:var(--amber)}
.dt-t-null{color:var(--faint)}
.dt-t-array{color:var(--gold)}
.dt-t-object{color:var(--gold)}
/* панель типу клікнутого значення */
.dt-type{margin:0 18px 16px;padding:13px 15px;border-radius:10px;background:var(--panel2);
  border:1px solid var(--line2);display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.dt-badge{font:700 10.5px/1 var(--m);letter-spacing:.06em;text-transform:uppercase;
  padding:6px 10px;border-radius:99px;border:1px solid currentColor;flex:0 0 auto}
.dt-badge.dt-t-string{background:rgba(111,224,160,.1)}
.dt-badge.dt-t-number{background:rgba(95,208,224,.1)}
.dt-badge.dt-t-boolean{background:rgba(var(--amber-rgb),.1)}
.dt-badge.dt-t-null{background:rgba(88,98,115,.12)}
.dt-badge.dt-t-array,.dt-badge.dt-t-object{background:rgba(var(--gold-rgb),.1)}
.dt-type-note{font:500 13px/1.5 var(--b);color:var(--muted);flex:1;min-width:160px}

/* ============ СИМ - РЕЖИМ 'devtools' (тема 11) ============ */
.dv-page{padding:11px 18px;background:var(--bg2);border-bottom:1px solid var(--line);font-size:13px;color:var(--muted)}
.dv-page b{color:var(--txt)}
.dv-tabs{display:flex;gap:2px;padding:0 12px;background:var(--bg);border-bottom:1px solid var(--line)}
.dv-tab{border:none;background:transparent;color:var(--muted);font:600 12.5px/1 var(--b);padding:12px 14px;cursor:pointer;border-bottom:2px solid transparent;transition:.14s}
.dv-tab:hover{color:var(--txt)}
.dv-tab.on{color:var(--amber);border-bottom-color:var(--amber)}
.dv-pane{padding:16px 18px;min-height:120px}
.dv-pane-h{font:700 10.5px/1 var(--m);letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-bottom:11px}
.dv-pane-sub{font:700 10px/1 var(--m);letter-spacing:.06em;text-transform:uppercase;color:var(--faint);margin:10px 0 7px}
.dv-code{font-family:var(--m);font-size:13px;color:var(--muted);background:var(--bg);border:1px solid var(--line2);border-radius:8px;padding:12px 14px;margin:0;overflow:auto;line-height:1.55}
.dv-comment{color:var(--green);opacity:.8}
.dv-tip{margin-top:11px;font:500 12.5px/1.5 var(--m);color:var(--faint)}
.dv-tip code{font-family:var(--m);color:var(--kw)}
.dv-net-row{font-family:var(--m);font-size:13px;background:var(--bg);border:1px solid var(--line2);border-radius:8px;padding:10px 13px;cursor:pointer;transition:.14s}
.dv-net-row:hover{border-color:var(--amber)}
.dv-net-m{color:var(--amber);font-weight:700}
.dv-net-u{color:var(--txt)}
.dv-net-s{color:var(--green);float:right}
.dv-net-detail{margin-top:11px;background:var(--bg);border:1px solid var(--line2);border-radius:8px;padding:12px 14px;display:flex;flex-direction:column;gap:5px}
.dv-h{font-family:var(--m);font-size:12.5px;color:var(--muted);word-break:break-all}
.dv-h-hot{cursor:pointer;color:var(--amber);border:1px solid rgba(var(--amber-rgb),.3);border-radius:6px;padding:6px 9px;transition:.14s}
.dv-h-hot:hover{background:rgba(var(--amber-rgb),.1)}
.dv-store-row{display:flex;justify-content:space-between;gap:14px;font-family:var(--m);font-size:13px;background:var(--bg);border:1px solid var(--line2);border-radius:8px;padding:9px 13px;margin-bottom:7px}
.dv-sk{color:var(--kw)}.dv-sv{color:var(--txt);word-break:break-all;text-align:right}
.dv-console{font-family:var(--m);font-size:13px;color:var(--txt);padding:4px 2px;margin-bottom:2px}
.dv-prompt{color:var(--green);margin-right:7px}
.dv-dim{color:var(--faint)}
/* повідомлення успіху devtools: рівні відступи, без поламаних переносів */
.sc-out.dv-solved{display:flex;align-items:flex-start;gap:9px}
.dv-solved-body{flex:1;min-width:0}
.dv-solved-body p{margin:0 0 4px;line-height:1.55}
.dv-solved-sub{color:var(--green);margin-top:8px}
.dv-solved-list{list-style:none;margin:6px 0 0;padding:0;display:flex;flex-direction:column;gap:4px}
.dv-solved-list li{position:relative;padding-left:16px;font:500 13px/1.5 var(--b);color:var(--green)}
.dv-solved-list li::before{content:"·";position:absolute;left:5px;color:var(--green)}
.dv-solved-list li b{color:var(--txt);font-weight:600}

/* ============ СИМ - РЕЖИМ 'curl' (тема 12) ============ */
.cl-hint{padding:13px 18px;border-bottom:1px solid var(--line);font:500 12.5px/1.6 var(--m);color:var(--faint)}
.cl-hint code{font-family:var(--m);color:var(--kw);background:var(--bg);border:1px solid var(--line2);border-radius:5px;padding:1px 5px}
.cl-term{padding:14px 16px;background:var(--bg);min-height:160px;max-height:300px;overflow:auto;cursor:text;font-family:var(--m);font-size:13px}
.cl-out{display:flex;flex-direction:column;gap:9px}
.cl-block{white-space:pre-wrap;word-break:break-word;color:var(--muted);line-height:1.5}
.cl-block.cl-cmd{color:var(--txt)}
.cl-block.cl-tip{color:var(--faint)}
.cl-input-row{display:flex;align-items:center;gap:8px;margin-top:9px}
.cl-ps{color:var(--green);flex:0 0 auto}
.cl-input{flex:1;min-width:0;background:transparent;border:none;outline:none;color:var(--txt);font-family:var(--m);font-size:13px}
.cl-input::placeholder{color:var(--faint)}

/* ============ СИМ - РЕЖИМ 'clientserver' (тема 2) ============ */
.cs-cols{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:16px 18px;border-bottom:1px solid var(--line)}
@media(max-width:560px){.cs-cols{grid-template-columns:1fr}}
.cs-col{background:var(--bg);border:1px solid var(--line2);border-radius:10px;padding:14px 15px;display:flex;flex-direction:column;gap:11px}
.cs-client{border-color:rgba(var(--amber-rgb),.3)}
.cs-col-h{font:700 11px/1 var(--m);letter-spacing:.06em;text-transform:uppercase;color:var(--txt);display:flex;align-items:center;gap:9px}
.cs-tag{font:700 9.5px/1 var(--m);letter-spacing:.05em;text-transform:uppercase;color:var(--amber);background:rgba(var(--amber-rgb),.12);border:1px solid rgba(var(--amber-rgb),.3);padding:4px 7px;border-radius:99px}
.cs-req{display:flex;flex-direction:column;gap:10px}
.cs-req-line{font-family:var(--m);font-size:13.5px;color:var(--txt)}
.cs-req-line b{color:var(--amber)}
.cs-field{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.cs-field-k{font:700 11px/1 var(--m);color:var(--kw)}
.cs-body{font-family:var(--m);font-size:13px;color:var(--muted);background:var(--panel2);border:1px solid var(--line2);border-radius:8px;padding:9px 12px;margin:0;overflow:auto;white-space:pre-wrap;word-break:break-all}
.cs-body .jk{color:var(--kw)}.cs-body .js{color:var(--green)}.cs-body .jp{color:var(--faint)}
.cs-client .sim-send{margin:0}
.cs-srv{min-height:90px;display:flex;flex-direction:column;gap:9px}
.cs-srv-idle{font:500 12.5px/1.5 var(--m);color:var(--faint)}
.cs-srv-got{font-family:var(--m);font-size:12.5px;color:var(--muted)}
.cs-srv-got code{font-family:var(--m);color:var(--txt)}
.cs-srv-ok{font:600 13.5px/1.5 var(--b);color:var(--green)}
.cs-srv-plain{font:600 13.5px/1.5 var(--b);color:var(--muted)}
.cs-srv-secret{display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:rgba(111,224,160,.07);border:1px solid rgba(111,224,160,.3);border-radius:8px;padding:9px 12px}
.cs-secret-k{font:700 10.5px/1 var(--m);letter-spacing:.05em;text-transform:uppercase;color:var(--green)}
.cs-secret-v{font-family:var(--m);font-size:13px;color:var(--green);word-break:break-all}

/* ============ СИМ - РЕЖИМ 'html' (тема 3) ============ */
.hp-tabs{display:flex;gap:2px;padding:0 12px;background:var(--bg);border-bottom:1px solid var(--line)}
.hp-pane{padding:16px 18px;min-height:120px}
/* "Вигляд": відрендерена картка профілю */
.hp-card{background:var(--bg);border:1px solid var(--line2);border-radius:10px;padding:18px 20px}
.hp-card-h{font-family:var(--d);font-weight:600;font-size:17px;letter-spacing:.2px;color:var(--txt);margin-bottom:7px}
.hp-card-p{font:500 14px/1.55 var(--b);color:var(--muted);margin:0}

/* ============ СИМ - РЕЖИМ 'forms' (тема 6) ============ */
.fm-build{padding:16px 18px;display:flex;flex-direction:column;gap:14px;border-bottom:1px solid var(--line)}
.fm-fields{display:flex;gap:12px;flex-wrap:wrap}
.fm-field{display:flex;flex-direction:column;gap:6px;flex:1;min-width:140px}
.fm-k{font:700 10.5px/1 var(--m);letter-spacing:.08em;text-transform:uppercase;color:var(--faint)}
.fm-opts{display:flex;flex-direction:column;gap:12px}
.fm-build .sim-send{margin:2px 0 0;align-self:flex-start}
.fm-resp{padding:16px 18px;border-bottom:1px solid var(--line)}
.fm-resp-h{font:700 10.5px/1 var(--m);letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-bottom:11px}
.fm-req{font-family:var(--m);font-size:13px;color:var(--txt);background:var(--bg);border:1px solid var(--line2);border-radius:8px;padding:12px 14px;margin:0 0 10px;overflow:auto;white-space:pre-wrap;word-break:break-all;line-height:1.55}
.fm-req b{color:var(--amber)}
.fm-resp.danger .fm-req{border-color:rgba(255,107,107,.32)}
.fm-resp.safe .fm-req{border-color:rgba(111,224,160,.3)}
.fm-warn{font:600 12.5px/1.5 var(--b);color:var(--red)}
.fm-good{font:600 12.5px/1.5 var(--b);color:var(--green)}

/* ============ СИМ - РЕЖИМ 'auth' (тема 8) ============ */
.au-steps{display:flex;gap:10px;flex-wrap:wrap;padding:16px 18px;border-bottom:1px solid var(--line)}
.au-btn{margin-left:0}
.au-log{padding:0 18px}
.au-log:not(:empty){padding:16px 18px;border-bottom:1px solid var(--line)}
.au-entry{background:var(--bg);border:1px solid var(--line2);border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:6px}
.au-dir{font-family:var(--m);font-size:13px;color:var(--muted)}
.au-dir code b{color:var(--amber)}
.au-arr{color:var(--faint)}
.au-setcookie{display:block;font-family:var(--m);font-size:12.5px;white-space:normal;word-break:break-all;overflow-wrap:anywhere;background:var(--panel2);border:1px solid rgba(var(--amber-rgb),.35);border-radius:7px;padding:8px 10px;line-height:1.6}
.au-setcookie .hk{color:var(--amber)}
.au-hint{font:500 12px/1.5 var(--b);color:var(--muted)}
.au-hint code{font-family:var(--m);font-size:11px;color:var(--amber)}
.au-decode{padding:16px 18px;border-bottom:1px solid var(--line)}
.au-decode-h{font:700 10.5px/1 var(--m);letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-bottom:11px}
.au-bad{font:600 12.5px/1.5 var(--b);color:var(--red);background:rgba(255,107,107,.07);border:1px solid rgba(255,107,107,.28);border-radius:8px;padding:10px 12px}
.au-parts{margin-top:13px}
/* JWT, розкладений на три кольорові частини */
.au-jwt-colored{font-family:var(--m);font-size:12.5px;background:var(--bg);border:1px solid var(--line2);border-radius:8px;padding:11px 13px;word-break:break-all;line-height:1.6}
.au-p-h{color:var(--red)}
.au-p-p{color:var(--amber)}
.au-p-s{color:var(--kw)}
.au-dot{color:var(--faint)}
.au-legend{display:flex;gap:8px;flex-wrap:wrap;margin-top:9px}
.au-lg{font:700 9.5px/1 var(--m);letter-spacing:.05em;text-transform:uppercase;padding:5px 9px;border-radius:99px;border:1px solid currentColor}
.au-lg-h{color:var(--red);background:rgba(255,107,107,.08)}
.au-lg-p{color:var(--amber);background:rgba(var(--amber-rgb),.08)}
.au-lg-s{color:var(--kw);background:rgba(255,159,67,.08)}
.au-decoded{margin-top:12px}
.au-dec-h{font:500 12px/1.4 var(--m);color:var(--faint);margin-bottom:8px}
.au-dec-body{font-family:var(--m);font-size:13px;color:var(--amber);background:var(--bg);border:1px solid rgba(var(--amber-rgb),.28);border-radius:8px;padding:12px 14px;margin:0;overflow:auto;line-height:1.5}
.au-note{margin-top:12px;font:500 12.5px/1.55 var(--b);color:var(--muted)}
.au-note b{color:var(--txt)}

/* ============ СИМ - РЕЖИМ 'encoding' (тема 10) ============ */
.en-build{padding:16px 18px;display:flex;flex-direction:column;gap:14px;border-bottom:1px solid var(--line)}
.en-row{display:flex;gap:9px}
.en-in{flex:1;min-width:0}
.en-out{margin-top:2px}
.en-out.warn{font:600 12.5px/1.5 var(--m);color:var(--red)}
.en-out.err{font:600 12.5px/1.5 var(--m);color:var(--red)}
.en-out-arrow{font:700 10px/1 var(--m);letter-spacing:.06em;text-transform:uppercase;color:var(--faint);margin-bottom:7px}
.en-out-val{font-family:var(--m);font-size:13px;color:var(--txt);background:var(--bg);border:1px solid var(--line2);border-radius:8px;padding:11px 13px;margin:0 0 8px;overflow:auto;white-space:pre-wrap;word-break:break-all;line-height:1.5}
.en-out-note{font:500 12px/1.5 var(--b);color:var(--muted)}
.en-out-note b{color:var(--txt)}
/* перехоплений рядок (вхід челенджу) */
.en-intercept{padding:16px 18px;border-bottom:1px solid var(--line)}
.en-int-h{font:700 10.5px/1 var(--m);letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-bottom:11px}
.en-int-val{font-family:var(--m);font-size:13px;color:var(--amber);background:var(--bg);border:1px solid rgba(var(--amber-rgb),.3);border-radius:8px;padding:11px 13px;display:block;word-break:break-all}
.en-int-note{font:500 12px/1.5 var(--m);color:var(--faint);margin-top:9px}

/* ============ АВАТАРИ (згенеровані картинки) ============ */
/* Аватар - SVG-картинка з роуту /avatar/<seed>. Кругла рамка з підкладкою
   --panel2, бо в bottts прозорий фон. Використовується в топбарі, меню,
   профілі (.pav-img) і в сітці вибору налаштувань (.av-img-pick). */
.av-img{display:block;width:32px;height:32px;border-radius:50%;object-fit:cover;
  background:var(--panel2);border:1px solid var(--line2)}
.av-img-sm{width:30px;height:30px;flex:0 0 auto}

/* ============ БЛОК КОРИСТУВАЧА В ТОПБАРІ ============ */
.userbox{position:relative}
.user-trigger{background:none;border:none;padding:0;cursor:pointer;display:block;border-radius:50%;
  transition:.15s;box-shadow:0 0 0 0 rgba(var(--amber-rgb),0)}
.user-trigger:hover,.userbox.open .user-trigger{box-shadow:0 0 0 2px var(--line2)}
.userbox.open .user-trigger{box-shadow:0 0 0 2px var(--amber)}
.user-menu{position:absolute;top:calc(100% + 10px);right:0;z-index:80;min-width:208px;
  background:var(--panel2);border:1px solid var(--line2);border-radius:12px;padding:6px;
  box-shadow:0 18px 44px -16px rgba(0,0,0,.7)}
.um-head{display:flex;align-items:center;gap:10px;padding:9px 10px 11px;margin-bottom:5px;
  border-bottom:1px solid var(--line)}
.um-name{font:700 13.5px/1.2 var(--b);color:var(--txt);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.um-item{display:block;width:100%;text-align:left;background:none;border:none;cursor:pointer;
  padding:10px 11px;border-radius:8px;font:600 13.5px/1 var(--b);color:var(--muted);transition:.13s}
.um-item:hover{background:var(--panel);color:var(--txt)}
.um-logout{margin:0}
.um-exit{color:var(--red)}
.um-exit:hover{background:rgba(255,107,107,.09);color:var(--red)}

/* Кнопка «Вхід» у топбарі (стан аноніма - замість блоку користувача) */
.btn-login{display:inline-flex;align-items:center;height:34px;padding:0 18px;border-radius:9px;
  background:var(--accent-grad);color:var(--on-accent);font:700 13.5px/1 var(--b);text-decoration:none;transition:.15s}
.btn-login:hover{filter:brightness(1.07)}

/* ============ СТОРІНКА ВХОДУ / РЕЄСТРАЦІЇ ============ */
.auth-wrap{min-height:calc(100vh - 200px);display:grid;place-items:center;padding:30px 0}
.auth-card{width:100%;max-width:420px;background:var(--panel);border:1px solid var(--line2);
  border-radius:18px;padding:34px 32px;box-shadow:0 24px 60px -28px rgba(0,0,0,.7)}
.auth-mark{display:flex;justify-content:center;margin-bottom:18px}
.auth-mark .mark{width:130px;height:130px}
/* Інтро-кросфейд лого (citrus -> electric) - лише на auth-сторінці.
   Обидва знаки absolute в стеку й ідеально збігаються (однаковий 200x200 viewBox). */
.auth-logo-stack{position:relative;display:block}
.auth-logo{position:absolute;inset:0;display:block}
.auth-logo .logo-mark-svg{width:100%;height:100%}
/* electric (знизу) одразу повноцінний; citrus (зверху) проявляє його, фейдячись у 0 */
.auth-logo--electric{position:static}
.auth-logo--citrus{
  opacity:1;
  /* один раз, без повтору, застигає на кінцевому стані (citrus невидимий) */
  animation:authLogoFade 1.5s ease-in forwards;
}
/* легкий супровід: знак ледь "дихає" разом із переходом кольору */
@keyframes authLogoFade{
  0%{opacity:1;transform:scale(1.015)}
  100%{opacity:0;transform:scale(1)}
}
/* без анімації: показуємо лише electric, citrus прибрано */
@media (prefers-reduced-motion:reduce){
  .auth-logo--citrus{animation:none;opacity:0}
}
.auth-title{font-family:var(--d);font-weight:600;text-transform:uppercase;letter-spacing:.4px;
  font-size:22px;text-align:center;margin-bottom:22px}
.auth-err{margin-bottom:18px;padding:12px 15px;border-radius:10px;font:600 13px/1.45 var(--b);
  color:var(--red);background:rgba(255,107,107,.08);border:1px solid rgba(255,107,107,.3)}
/* Нейтральний інфо-блок (анти-енумерація на /forgot) */
.auth-note{margin-bottom:18px;padding:13px 16px;border-radius:10px;font:500 13.5px/1.5 var(--b);
  color:var(--muted);background:var(--bg);border:1px solid var(--line2)}
/* Вступний рядок над формою */
.auth-lead{margin:-6px 0 20px;text-align:center;font-size:13.5px;line-height:1.5;color:var(--muted)}
.auth-form{display:flex;flex-direction:column;gap:15px}
.auth-field{display:flex;flex-direction:column;gap:7px}
/* Дрібна підказка під полем (напр. для чого email / довжина пароля) */
.af-hint{font:500 11.5px/1.35 var(--b);color:var(--faint)}
.af-lbl{font:700 11px/1 var(--m);letter-spacing:.08em;text-transform:uppercase;color:var(--faint)}
.af-in{background:var(--bg);border:1px solid var(--line2);border-radius:10px;padding:12px 14px;
  color:var(--txt);font:500 14px/1 var(--b);outline:none;transition:.15s;width:100%}
.af-in:focus{border-color:var(--amber);box-shadow:0 0 0 3px rgba(var(--amber-rgb),.13)}
.auth-form .btn{margin-top:6px}
.auth-alt{margin-top:18px;text-align:center;font-size:13.5px;color:var(--muted)}
.auth-alt a{color:var(--amber);font-weight:600;text-decoration:none}
.auth-alt a:hover{text-decoration:underline;text-underline-offset:2px}
/* Дрібний допоміжний лінк ("Забув пароль?") під формою входу */
.auth-sub{margin-top:13px;text-align:center;font-size:12.5px}
.auth-sub a{color:var(--muted);text-decoration:none}
.auth-sub a:hover{color:var(--amber);text-decoration:underline;text-underline-offset:2px}

/* ============ НАЛАШТУВАННЯ ============ */
/* Список карток-фічей: вертикальний стек рядків "інфо зліва - кнопка справа" */
.set-list{display:flex;flex-direction:column;gap:14px;margin-top:26px}
.set-card{display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:20px 24px;background:var(--panel);border:1px solid var(--line2);border-radius:var(--r)}
.set-card-info{flex:1;min-width:0}
/* картка аватара: мініатюра + текст в один рядок */
.set-card-info-av{display:flex;align-items:center;gap:14px}
.set-card-av{width:44px;height:44px;border-radius:50%;object-fit:cover;flex:0 0 auto;
  background:var(--panel2);border:1px solid var(--line2)}
.set-card-h{font-family:var(--d);font-weight:600;font-size:15px;color:var(--txt);margin:0}
.set-card-desc{color:var(--muted);font-size:13.5px;margin:6px 0 0}
/* кнопка картки: не тягнеться на всю ширину, природна ширина по тексту */
.set-card-btn{flex-shrink:0;width:auto;padding:11px 20px;margin:0}
.set-card-form{flex-shrink:0;margin:0}
.set-card-form .btn{margin-top:0}
/* небезпечна картка: червоний акцент рамки */
.set-card-danger{border-color:rgba(255,107,107,.32)}
.set-form{display:flex;flex-direction:column;gap:15px}
.set-form .btn{margin-top:6px}
.set-avatars{margin:0}

/* ===== АДМІНКА ===== */
/* Статистика: рядок із трьох карток (велике число + дрібний підпис) */
.adm-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:26px}
.adm-stat{display:flex;flex-direction:column;gap:7px;padding:20px 22px;
  background:var(--panel);border:1px solid var(--line2);border-radius:var(--r)}
.adm-stat-num{font:600 30px/1 var(--d);color:var(--txt)}
.adm-stat-lbl{font:600 12px/1 var(--m);letter-spacing:.04em;color:var(--muted)}
/* Підзаголовок секції звернень */
.adm-h{font-family:var(--d);font-weight:600;font-size:18px;color:var(--txt);margin:34px 0 16px}
.adm-empty{color:var(--muted);font-size:14px}
/* Список звернень */
.adm-list{display:flex;flex-direction:column;gap:12px}
.adm-item{padding:16px 18px;background:var(--panel);border:1px solid var(--line2);border-radius:var(--r)}
.adm-item-top{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
/* Чип типу: нейтральний за замовчуванням, легке підфарбування за типом */
.adm-chip{font:700 11px/1 var(--m);letter-spacing:.04em;padding:5px 9px;border-radius:99px;
  color:var(--muted);background:var(--panel2);border:1px solid var(--line2)}
.adm-chip-bug{color:var(--red);background:rgba(255,107,107,.1);border-color:rgba(255,107,107,.32)}
.adm-chip-idea{color:var(--amber);background:rgba(var(--amber-rgb),.1);border-color:rgba(var(--amber-rgb),.32)}
.adm-who{font:600 13px/1 var(--b);color:var(--txt)}
.adm-when{margin-left:auto;font:500 12px/1 var(--m);color:var(--faint)}
/* Текст звернення: користувацький, з переносами рядків */
.adm-msg{margin-top:11px;color:var(--txt);font-size:14px;line-height:1.55;white-space:pre-wrap;word-break:break-word}
.adm-page{margin-top:9px;font:500 12px/1 var(--m);color:var(--faint)}
@media (max-width:640px){
  .adm-stats{grid-template-columns:1fr}
}

/* ===== МОДАЛКИ З ФОРМАМИ (налаштування) ===== */
/* оверлей: затемнений бекдроп, центрування (у стилі .cdlg-ov) */
.modal-ov{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;
  padding:24px;background:rgba(6,8,11,.72);backdrop-filter:blur(3px);
  opacity:0;transition:opacity .16s ease}
.modal-ov.open{opacity:1}
/* картка-діалог: як .panel, з анімацією появи */
.modal{position:relative;width:calc(100% - 40px);max-width:480px;max-height:90vh;overflow:auto;
  background:var(--panel);border:1px solid var(--line2);border-radius:var(--r);padding:26px 28px;
  box-shadow:0 24px 60px -20px rgba(0,0,0,.7);
  transform:translateY(8px) scale(.985);transition:transform .16s ease;outline:none}
.modal-ov.open .modal{transform:none}
.modal-h{font:600 17px/1.2 var(--d);color:var(--txt);margin:0 0 18px}
/* помилка під конкретним полем: червона, показується лише з текстом (ховається [hidden]).
   .field-err - flex-дитина форми (.set-form gap:15px), тож компенсуємо gap від'ємним
   верхнім маргіном, аби помилка сиділа щільно під своїм полем (~5px), а не за весь gap.
   Прихований елемент (display:none через [hidden]) маргіном нічого не зсуває. */
.field-err{margin:-10px 0 0;font:600 12.5px/1.4 var(--b);color:var(--red)}
/* запасна помилка модалки (CSRF/мережа): червоний інлайн-потік, лише з текстом */
.modal-err{margin-top:4px;font:600 13px/1.5 var(--b);color:var(--red)}
/* хрестик закриття: ненав'язливий, угорі справа */
.modal-x{position:absolute;top:14px;right:14px;width:30px;height:30px;display:flex;
  align-items:center;justify-content:center;background:none;border:0;cursor:pointer;
  color:var(--muted);font:400 22px/1 var(--b);border-radius:8px;transition:.15s}
.modal-x:hover{color:var(--txt);background:var(--panel2)}
/* 2FA: стан "увімкнено" - зелений акцент */
.set-2fa-on{margin:0 0 16px;font:600 13.5px/1.5 var(--b);color:var(--green)}
/* короткий вступ/попередження над формою (інлайн-потік, приглушений) */
.set-2fa-lead{margin:0 0 16px;font:500 13.5px/1.55 var(--b);color:var(--muted)}
/* QR-код для сканування: біла картка-контейнер, чорні модулі НЕ перефарбовуємо темою (контраст для сканера) */
.set-2fa-qr{width:196px;box-sizing:border-box;background:#fff;padding:10px;border-radius:12px;margin:0 auto 16px}
.set-2fa-qr svg{display:block;width:100%;height:auto}
/* секрет для ручного введення: великий моноширинний рядок, легкий для копіювання */
.set-2fa-secret{display:flex;flex-direction:column;gap:7px;margin:0 0 14px}
.set-2fa-code{display:block;width:100%;box-sizing:border-box;padding:13px 15px;border-radius:10px;
  background:var(--bg);border:1px solid var(--line2);color:var(--kw);
  font:600 15px/1.5 var(--m);letter-spacing:.04em;text-align:center;
  white-space:normal;word-break:break-all;overflow-wrap:anywhere;user-select:all}
/* небезпечна зона: червоний акцент рамки й заголовка */
.set-danger{border-color:rgba(255,107,107,.32)}
.set-danger-h{color:var(--red)}
.av-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:13px}
.av-pick{position:relative;aspect-ratio:1;width:100%;border:none;border-radius:50%;cursor:pointer;
  outline:2px solid transparent;outline-offset:3px;transition:.15s;padding:0;background:none}
.av-pick:hover{outline-color:var(--line2);transform:translateY(-2px)}
.av-pick.on{outline-color:var(--amber)}
.av-img-pick{width:100%;height:100%}
.av-chk{position:absolute;inset:0;display:grid;place-items:center;color:#fff;font-weight:700;
  font-size:18px;font-family:var(--d);text-shadow:0 1px 3px rgba(0,0,0,.6)}

/* профіль: теги шапки */
.phead-tags{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:9px}
.phead-tags .rank{margin-top:0}

/* ===== ОКО В ПОЛЯХ ПАРОЛЯ ===== */
/* wrap огортає ЛИШЕ інпут (не лейбл), щоб око центрувалось по висоті поля */
.pw-wrap{position:relative;display:block}
.pw-wrap .af-in{padding-right:42px}
.pw-eye{position:absolute;right:8px;top:50%;transform:translateY(-50%);
  width:28px;height:28px;display:none;align-items:center;justify-content:center;
  background:none;border:0;cursor:pointer;color:var(--faint);border-radius:7px;transition:.15s}
.pw-eye:hover{color:var(--txt)}
.pw-wrap.has-val .pw-eye{display:inline-flex}
/* нативний ревіл/clear від Edge приглушуємо - маємо власне "око" */
.af-in::-ms-reveal,.af-in::-ms-clear{display:none}

/* на вузькому екрані картки налаштувань стають стеком, кнопка на всю ширину */
@media (max-width:600px){
  .set-card{flex-direction:column;align-items:stretch}
  .set-card-btn,.set-card-form,.set-card-form .btn{width:100%}
}

/* ============ ФУТЕР (скромний рядок із правовими лінками) ============ */
.site-foot{flex-shrink:0;border-top:1px solid var(--line);margin-top:70px;
  padding:20px max(34px, calc((100% - 1132px) / 2))}
.site-foot-in{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap;
  font:500 12px/1 var(--m);color:var(--faint)}
.site-foot a{color:var(--faint);text-decoration:none;letter-spacing:.02em}
.site-foot a:hover{color:var(--amber)}
.site-foot .sf-sep{color:#333a47}
@media (max-width:560px){.site-foot-in{gap:11px}}

/* ============ ПРАВОВІ СТОРІНКИ (приватність / умови) - прозова колонка ============ */
.legal{max-width:720px;margin:0 auto}
.legal-updated{color:var(--faint);font:500 13px/1 var(--m);letter-spacing:.02em;margin:0 0 30px}
.legal section{margin:26px 0}
.legal h2{font-family:var(--d);font-weight:600;text-transform:uppercase;letter-spacing:.3px;
  font-size:17px;color:var(--amber);margin:0 0 11px}
.legal p{color:#C8CCD5;margin:0 0 11px;line-height:1.64}
.legal p:last-child{margin-bottom:0}
.legal a{color:var(--kw);text-decoration:underline;text-underline-offset:2px}
.legal ul{margin:8px 0 0;padding-left:0;list-style:none}
.legal li{color:#C8CCD5;padding-left:22px;position:relative;margin-bottom:8px;line-height:1.56}
.legal li:last-child{margin-bottom:0}
.legal li::before{content:"\25B8";position:absolute;left:1px;top:0;color:var(--amber);
  font-size:1.3em;line-height:1.2}
.legal strong{color:var(--txt)}

/* ============ ЧЕКБОКС ЗГОДИ В РЕЄСТРАЦІЇ ============ */
.auth-agree{display:flex;align-items:flex-start;gap:9px;cursor:pointer;
  font:500 12px/1.5 var(--b);color:var(--muted);margin-top:2px}
.auth-agree input{flex:0 0 auto;margin-top:1px;width:15px;height:15px;
  accent-color:var(--amber);cursor:pointer}
.auth-agree a{color:var(--amber);text-decoration:none}
.auth-agree a:hover{text-decoration:underline;text-underline-offset:2px}

/* ============ СТОРІНКА ФОРМИ (зворотний звʼязок) - вузька центрована колонка ============ */
/* .wrap тягнеться на 1200px; .form-page стискає форму до охайної колонки */
.form-page{max-width:560px;margin:0 auto}
.form-page .t{margin-top:6px;margin-bottom:0}
/* щільний відступ заголовок -> перше поле (.auth-form вже flex-стек із gap) */
.fb-form{margin-top:20px}
/* примітка замість поля email для залогінених */
.fb-note{font:500 12.5px/1.5 var(--b);color:var(--muted);margin:0}

/* textarea успадковує вигляд .af-in; додаємо лише специфічне для багаторядкового поля */
textarea.af-in{font-family:var(--b);line-height:1.55;resize:vertical;min-height:120px}

/* Кастомний дропдаун "Тип звернення".
   Нативний <select> на macOS/Chrome відкриває меню ВГОРУ (напрямок не керується CSS),
   тож замість нього - кнопка + абсолютний список, що завжди розкривається ВНИЗ.
   Тригер виглядає точно як інші .af-in. JS - окремий IIFE в app.js (CSP-friendly). */
.fbsel{position:relative}
.fbsel-trigger{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  width:100%;text-align:left;cursor:pointer;
}
.fbsel-caret{color:var(--faint);flex:none;transition:transform .15s}
.fbsel.open .fbsel-caret{transform:rotate(180deg)}
/* список опцій - абсолютно ПІД тригером */
.fbsel-list{
  position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:50;
  margin:0;padding:6px;list-style:none;
  background:var(--panel);border:1px solid var(--line2);border-radius:10px;
  box-shadow:0 12px 28px rgba(0,0,0,.4);
  max-height:260px;overflow:auto;
}
.fbsel-opt{
  padding:9px 12px;border-radius:7px;cursor:pointer;color:var(--txt);
  font:500 14px/1.2 var(--b);transition:background .12s;
}
.fbsel-opt:hover,.fbsel-opt.is-active{background:var(--panel2)}
/* поточний вибір - акцентний колір тексту */
.fbsel-opt.is-sel{color:var(--amber);font-weight:600}

/* подяка після надсилання - центрована панель замість форми */
.fb-thanks{margin-top:4px;text-align:center;background:var(--panel);border:1px solid var(--line2);
  border-radius:18px;padding:38px 30px}
.fb-thanks-ic{width:56px;height:56px;margin:0 auto 18px;display:grid;place-items:center;
  border-radius:50%;font-size:28px;color:var(--green);
  background:rgba(111,224,160,.1);border:1px solid rgba(111,224,160,.4)}
.fb-thanks-h{font-family:var(--d);font-weight:600;font-size:19px;color:var(--txt);margin:0 0 28px;line-height:1.35}
.fb-thanks-act{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap}
.fb-thanks-act .btn-run{text-decoration:none}
.fb-thanks-alt{color:var(--muted);font-size:13.5px;text-decoration:none}
.fb-thanks-alt:hover{color:var(--amber);text-decoration:underline;text-underline-offset:2px}

/* ===== Тости: транзитні статуси (успіх/помилка), спливають і самі зникають =====
   Контейнер фіксований у правому нижньому куті; тости стекаються в стовпчик.
   pointer-events:none на контейнері, щоб порожні зони не блокували кліки сторінки. */
/* верхній правий кут, але ПІД липкою шапкою (~63px), щоб не перекривати навігацію */
.toaster{position:fixed;right:20px;top:76px;z-index:1000;
  display:flex;flex-direction:column;gap:10px;align-items:flex-end;
  pointer-events:none;max-width:calc(100vw - 40px)}
.toast{pointer-events:auto;display:flex;align-items:center;gap:12px;max-width:360px;
  background:var(--panel);border:1px solid var(--line2);border-left:3px solid var(--line2);
  border-radius:12px;padding:13px 16px;box-shadow:0 10px 30px rgba(0,0,0,.45);
  font:600 13.5px/1.4 var(--b);color:var(--txt);
  opacity:0;transform:translateY(-8px);transition:opacity .22s, transform .22s}
.toast.show{opacity:1;transform:none}
.toast-ic{flex:0 0 auto;font-size:14px;line-height:1}
.toast-ok{border-left-color:var(--green)} .toast-ok .toast-ic{color:var(--green)}
.toast-err{border-left-color:var(--red)} .toast-err .toast-ic{color:var(--red)}
.toast-msg{flex:1 1 auto}
.toast-x{flex:0 0 auto;background:none;border:0;cursor:pointer;color:var(--faint);
  font-size:18px;line-height:1;padding:0 2px;transition:color .15s}
.toast-x:hover{color:var(--txt)}
