/* ================= БРЕНДОВАЯ ТЕМА «НОЧНАЯ СИНЬ» (Claude Design) ================= */
:root{
  --ink:#e9eefb; --ink-2:#cdd8ef; --soft:#9aa6c6; --faint:#8893b2;
  --bg-deep:#04081a; --bg:#060b1a; --bg-2:#0a1228; --card:rgba(255,255,255,.04); --card-2:rgba(255,255,255,.065); --white:#fff;
  --line:rgba(255,255,255,.09); --line2:rgba(255,255,255,.14); --ring:rgba(255,255,255,.24);
  --accent:#8fd4ff; --accent-d:#4f9fe6; --accent-ink:#bfe6ff;
  --accent-soft:rgba(143,212,255,.32); --accent-bg:rgba(143,212,255,.12);
  --brand:#4f9fe6; --brand-d:#3a7fc4;
  --warm:#f0c98e; --warm-soft:rgba(240,201,142,.15); --cream:#F2EAD9;
  --on-accent:#06122a; --on-ink:#fff;
  /* совместимость со старыми именами переменных */
  --blue:#4f9fe6; --blue-d:#3a7fc4; --blue-deep:#bfe6ff; --blue-ink:#cfe6ff;
  --blue-bg:rgba(79,159,230,.16); --blue-soft:rgba(79,159,230,.34); --blue-l:#8fd4ff; --paper:rgba(255,255,255,.05);
  --accent-2:#bfe6ff;
  --corner:6.28%;
  --r:20px;
  --shadow-sm:0 2px 10px rgba(0,0,0,.4);
  --shadow:0 18px 46px -18px rgba(0,0,0,.66),0 2px 8px rgba(0,0,0,.32);
  --shadow-lg:0 44px 96px -32px rgba(0,0,0,.8),0 8px 22px -10px rgba(0,0,0,.5);
  --glow-accent:0 14px 40px -12px rgba(143,212,255,.42);
  --grad-accent:linear-gradient(135deg,#8fd4ff 0%,#bfe6ff 100%);
  --grad-blue:linear-gradient(135deg,#4f9fe6 0%,#8fd4ff 100%);
  --grad-prog:linear-gradient(90deg,#4f9fe6,#8fd4ff 60%,#bfe6ff);
  --font-display:"Nunito",system-ui,-apple-system,sans-serif;
  --font-body:"Onest",system-ui,-apple-system,sans-serif;
  --mono:"Space Mono",ui-monospace,Menlo,Consolas,monospace;
  color-scheme:dark;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth}
html,body{min-height:100%}
body{
  font-family:var(--font-body);color:var(--ink);min-height:100dvh;line-height:1.6;
  background:
    radial-gradient(1000px 640px at 84% -12%,rgba(79,159,230,.22),transparent 60%),
    radial-gradient(820px 560px at 6% 2%,rgba(143,212,255,.10),transparent 55%),
    radial-gradient(700px 520px at 50% 116%,rgba(240,201,142,.06),transparent 60%),
    linear-gradient(180deg,#0a1228 0%,#060b1a 58%,#04081a 100%);
  background-attachment:fixed;-webkit-font-smoothing:antialiased;overscroll-behavior-y:none;
}
/* звёздное небо рисуется на <canvas> (см. app.js) — чёткие точки + лёгкий хаотичный дрейф */
#starfield{position:fixed;inset:0;width:100%;height:100%;display:block;z-index:-1;pointer-events:none}
.screen{display:none}
/* утилиты вместо инлайн-стилей (CSP без 'unsafe-inline') */
.is-hidden{display:none!important}
.u-mb7{margin-bottom:7px}
.u-mrow{margin:10px 0 3px}
.u-mb11{margin-bottom:11px}
.u-mhint{text-align:center;margin-top:9px}
#screen-gate.on{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:clamp(14px,4vw,40px)}
#screen-guide.on{display:block}
@keyframes rise{from{opacity:0;transform:translateY(14px) scale(.99)}to{opacity:1;transform:none}}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{0%{transform:scale(.9)}60%{transform:scale(1.04)}100%{transform:scale(1)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{0%{transform:scale(.96);opacity:.5}70%{transform:scale(1.14);opacity:0}100%{opacity:0}}
@keyframes twinkle{0%,100%{opacity:.5}50%{opacity:1}}

/* общий бренд-знак в шапках */
.mark{width:42px;height:42px;flex:0 0 auto;border-radius:13px;background:var(--accent-bg);color:var(--accent);
  display:grid;place-items:center;box-shadow:inset 0 0 0 1px var(--accent-soft)}
.mark svg{width:22px;height:22px;display:block}

/* ================= ЭКРАН 1 · КОД ДОСТУПА ================= */
#screen-gate .authcard{width:min(420px,100%);background:var(--card);border-radius:26px;
  box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid var(--line);
  animation:rise .6s cubic-bezier(.2,.8,.2,1) both}
#screen-gate .hero{position:relative;min-height:210px;display:flex;flex-direction:column;justify-content:flex-end;
  padding:24px;color:#fff;overflow:hidden;
  background:radial-gradient(120% 90% at 82% -12%,rgba(79,159,230,.32),transparent 58%),
    linear-gradient(165deg,#0e2a55 0%,#0a1f44 56%,#06122a 100%)}
#screen-gate .hero-bg{display:none}
#screen-gate .hero::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(130% 80% at 72% -10%,rgba(31,208,252,.18),transparent 60%)}
#screen-gate .hero-inner{position:relative;z-index:1}
#screen-gate .brandrow{display:flex;align-items:center;gap:10px;font-family:var(--font-display);
  font-weight:600;font-size:1.1rem;letter-spacing:0;margin-bottom:54px}
#screen-gate .brand-logo{height:88px;width:auto;display:block;
  filter:drop-shadow(0 0 16px rgba(255,199,32,.25))}
#screen-gate .hero-title{font-family:var(--font-display);font-weight:600;font-size:1.6rem;line-height:1.1;
  letter-spacing:-.01em;text-shadow:0 2px 18px rgba(0,0,0,.45)}
#screen-gate .hero-sub{font-size:.85rem;opacity:.92;margin-top:8px;font-weight:400;max-width:92%}
#screen-gate .authbody{padding:24px}
#screen-gate label{display:block;font-size:.72rem;color:var(--faint);margin-bottom:9px;text-transform:uppercase;
  letter-spacing:.16em;font-weight:700}
#screen-gate input[type=text]{width:100%;background:rgba(255,255,255,.05);border:1.5px solid var(--line2);color:var(--ink);
  font-family:"Space Mono",ui-monospace,monospace;font-size:1.5rem;letter-spacing:.3em;text-align:center;padding:16px;border-radius:14px;
  text-transform:uppercase;outline:none;transition:.18s}
#screen-gate input[type=text]::placeholder{color:var(--ring)}
#screen-gate input[type=text]:focus{border-color:var(--accent);background:rgba(31,208,252,.07);box-shadow:0 0 0 4px var(--accent-bg)}
#screen-gate button{width:100%;margin-top:16px;padding:16px;border:0;border-radius:14px;cursor:pointer;
  background:var(--grad-accent);color:var(--on-accent);font-family:var(--font-body);font-weight:800;font-size:1rem;
  box-shadow:var(--glow-accent);transition:transform .1s,filter .2s;display:flex;align-items:center;justify-content:center;gap:9px}
#screen-gate button:hover{filter:brightness(1.06)}
#screen-gate button:active{transform:scale(.985)}
#screen-gate button:disabled{opacity:.55;cursor:wait}
#screen-gate .msg{margin-top:13px;font-size:.9rem;min-height:1.2em;text-align:center;color:var(--soft)}
#screen-gate .msg.err{color:#ff8a73}
#screen-gate .authhint{margin-top:14px;text-align:center;font-size:.78rem;color:var(--faint);line-height:1.5}
#screen-gate .spinner{width:18px;height:18px;border:3px solid rgba(5,34,54,.35);border-top-color:var(--on-accent);border-radius:50%;animation:spin .7s linear infinite}
#screen-gate .linkback{width:auto;margin:16px auto 0;display:block;background:none;box-shadow:none;
  color:var(--soft);font-family:var(--font-body);font-weight:600;font-size:.84rem;padding:8px 12px}
#screen-gate .linkback:hover{filter:none;color:var(--accent)}

/* ================= ЭКРАН 2 · КАДРИРОВАНИЕ ================= */
/* единая верхняя панель экранов-карточек: лого слева, действие справа */
#screen-home .apptop,#screen-crop .apptop,#screen-preview .apptop{width:min(560px,100%);display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:clamp(16px,3vw,24px)}
#screen-preview .apptop{width:min(940px,100%)}
#screen-home .apptop-brand,#screen-crop .apptop-brand,#screen-preview .apptop-brand{display:flex;align-items:center;text-decoration:none}
#screen-home .apptop-logo,#screen-crop .apptop-logo,#screen-preview .apptop-logo{height:42px;width:auto;display:block;filter:drop-shadow(0 0 12px rgba(255,199,32,.22))}
#screen-home .backbtn,#screen-crop .backbtn,#screen-preview .backbtn,#screen-guide .backbtn{display:inline-flex;align-items:center;gap:6px;background:none;border:1px solid var(--line2);color:var(--soft);font-family:var(--font-body);font-size:13px;font-weight:600;cursor:pointer;padding:8px 15px;border-radius:99px;transition:.15s;text-decoration:none}
#screen-home .backbtn:hover,#screen-crop .backbtn:hover,#screen-preview .backbtn:hover,#screen-guide .backbtn:hover{color:var(--ink);border-color:var(--soft);background:rgba(255,255,255,.04)}
#screen-home .backbtn svg,#screen-crop .backbtn svg,#screen-preview .backbtn svg{width:17px;height:17px;margin-left:-3px}
/* действие «уйти» (Назад / выйти) — внизу слева под карточкой */
#screen-home .appbottom,#screen-crop .appbottom,#screen-preview .appbottom{width:min(560px,100%);display:flex;margin-top:clamp(18px,3vw,26px)}
#screen-preview .appbottom{width:min(940px,100%)}
#screen-crop .card{width:min(560px,100%);margin-block:auto;background:var(--card);border-radius:24px;
  box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid var(--line);animation:rise .6s cubic-bezier(.2,.8,.2,1) both}
#screen-crop header{padding:24px 26px 18px;display:flex;align-items:center;gap:14px;color:var(--ink);border-bottom:1px solid var(--line)}
#screen-crop .titles h1{font-family:var(--font-display);font-weight:600;font-size:1.35rem;letter-spacing:-.01em;line-height:1.1;color:var(--ink)}
#screen-crop .titles p{font-size:.85rem;color:var(--soft);margin-top:5px;font-weight:400}
#screen-crop .body{padding:24px}
#screen-crop .drop{position:relative;border:2px dashed var(--line2);border-radius:20px;
  background:rgba(255,255,255,.03);padding:52px 22px;text-align:center;cursor:pointer;transition:.22s cubic-bezier(.2,.8,.2,1);overflow:hidden}
#screen-crop .drop:hover,#screen-crop .drop.drag{border-color:var(--accent);background:var(--accent-bg);transform:translateY(-2px);box-shadow:var(--shadow)}
#screen-crop .drop .ico{position:relative;width:72px;height:72px;margin:0 auto 18px;border-radius:20px;background:var(--grad-accent);display:grid;place-items:center;color:var(--on-accent);box-shadow:var(--glow-accent)}
#screen-crop .drop .ico::after{content:"";position:absolute;inset:-9px;border-radius:28px;border:2px solid var(--accent);opacity:.4;animation:pulse 2.4s ease-out infinite}
#screen-crop .drop .ico svg{width:30px;height:30px}
#screen-crop .drop .ico svg path{stroke:var(--on-accent)}
#screen-crop .drop h2{font-family:var(--font-display);font-weight:600;font-size:1.18rem;margin-bottom:6px;letter-spacing:-.01em;color:var(--ink)}
#screen-crop .drop p{color:var(--soft);font-size:.9rem}
#screen-crop .drop .hint{margin-top:16px;font-size:.72rem;color:var(--accent-ink);font-family:var(--font-body);display:inline-block;padding:5px 12px;background:var(--accent-bg);border-radius:99px}
#screen-crop .editor{display:none}
#screen-crop .editor.on{display:block;animation:fade .35s ease both}
#screen-crop .stage-wrap{display:flex;flex-direction:column;align-items:center;gap:6px}
#screen-crop .vp{position:relative;width:min(420px,82vw);aspect-ratio:1/1;border-radius:var(--corner);overflow:hidden;
  background:#04122a;touch-action:none;cursor:grab;box-shadow:0 0 0 1px var(--line2),var(--shadow);user-select:none;-webkit-user-select:none}
#screen-crop .vp.grabbing{cursor:grabbing}
#screen-crop .vp img{position:absolute;top:0;left:0;transform-origin:0 0;pointer-events:none;-webkit-user-drag:none;max-width:none}
#screen-crop .vp .ring{position:absolute;inset:0;border-radius:var(--corner);box-shadow:inset 0 0 0 2px rgba(255,255,255,.2),inset 0 0 0 3px rgba(31,208,252,.32);pointer-events:none}
#screen-crop .vp .grid{position:absolute;inset:0;pointer-events:none;opacity:0;transition:opacity .2s}
#screen-crop .vp.grabbing .grid{opacity:1}
#screen-crop .vp .grid::before{content:"";position:absolute;left:33.33%;right:33.33%;top:0;bottom:0;border-left:1px solid rgba(255,255,255,.35);border-right:1px solid rgba(255,255,255,.35)}
#screen-crop .vp .grid::after{content:"";position:absolute;top:33.33%;bottom:33.33%;left:0;right:0;border-top:1px solid rgba(255,255,255,.35);border-bottom:1px solid rgba(255,255,255,.35)}
#screen-crop .tip{font-size:.74rem;color:var(--faint);margin-top:2px;text-align:center}
#screen-crop .zoom{display:flex;align-items:center;gap:12px;margin:20px 2px 4px}
#screen-crop .zoom .zico{color:var(--accent);flex:0 0 auto;display:grid;place-items:center}
#screen-crop .zoom .zico svg{width:18px;height:18px}
#screen-crop input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:99px;background:var(--line2);outline:none;cursor:pointer}
#screen-crop input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;border-radius:50%;background:var(--accent);border:3px solid #0b2348;box-shadow:0 0 0 1px var(--accent),0 2px 10px rgba(31,208,252,.55);cursor:grab}
#screen-crop input[type=range]::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:var(--accent);border:3px solid #0b2348;box-shadow:0 0 0 1px var(--accent),0 2px 10px rgba(31,208,252,.55);cursor:grab}
#screen-crop .actions{display:flex;gap:10px;margin-top:18px}
#screen-crop .btn{flex:1;border:none;border-radius:14px;padding:14px 16px;font-family:var(--font-body);font-weight:700;font-size:.92rem;cursor:pointer;transition:.18s ease;display:flex;align-items:center;justify-content:center;gap:8px}
#screen-crop .btn:active{transform:translateY(1px)}
#screen-crop .btn svg{width:18px;height:18px}
#screen-crop .btn-ghost{background:rgba(255,255,255,.06);color:var(--ink);box-shadow:inset 0 0 0 1.5px var(--line2)}
#screen-crop .btn-ghost:hover{background:rgba(255,255,255,.1)}
#screen-crop .btn-primary{background:var(--grad-accent);color:var(--on-accent);box-shadow:var(--glow-accent)}
#screen-crop .btn-primary:hover{filter:brightness(1.05)}
#screen-crop .btn-primary:disabled{opacity:.55;cursor:not-allowed}
#screen-crop .spinner{width:18px;height:18px;border:3px solid rgba(5,34,54,.35);border-top-color:var(--on-accent);border-radius:50%;animation:spin .7s linear infinite}
#screen-crop .crop-msg{font-size:.86rem;text-align:center;margin-top:14px;min-height:1.1em;color:var(--accent-ink)}
#screen-crop .crop-msg.err{color:#ff9a82}
#screen-crop footer{padding:14px 24px 20px;color:var(--faint);font-size:.72rem;text-align:center;font-family:var(--font-body)}

/* ================= ЭКРАН 3 · СХЕМА ПРОБИВКИ ================= */
#screen-guide .appbar{position:sticky;top:0;z-index:40;background:rgba(11,35,72,.86);backdrop-filter:saturate(150%) blur(12px);border-bottom:1px solid var(--line)}
#screen-guide .appbar .inner{max-width:1080px;margin:0 auto}
/* строка 1 — глобальное меню (логика навигации) */
#screen-guide .topbar .inner{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:8px 20px}
#screen-guide .navleft{display:flex;align-items:center;gap:12px}
#screen-guide .brand{display:flex;align-items:center;pointer-events:none;-webkit-user-select:none;user-select:none}
#screen-guide .appbar-logo{-webkit-user-drag:none}
#screen-guide .appbar-logo{height:30px;width:auto;display:block;filter:drop-shadow(0 0 11px rgba(255,199,32,.2))}
#screen-guide .menulink{background:none;border:none;color:var(--ink);font-family:var(--font-body);font-size:13px;font-weight:800;cursor:pointer;padding:6px 9px;border-radius:9px;transition:.15s;white-space:nowrap}
#screen-guide .menulink:hover{color:var(--accent);background:rgba(255,255,255,.06)}
#screen-guide .exitbtn{background:none;border:1px solid var(--line2);color:var(--soft);font-family:var(--font-body);font-size:12px;font-weight:600;cursor:pointer;padding:5px 13px;border-radius:99px;transition:.15s;white-space:nowrap}
#screen-guide .exitbtn:hover{color:var(--ink);border-color:var(--soft)}
/* прогресс — под слайдером «Этап I / Этап II» */
#screen-guide .guideprog{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding:0 4px}
#screen-guide .pbar{flex:1;height:6px;background:var(--line);border-radius:99px;overflow:hidden}
#screen-guide .pbar i{display:block;height:100%;width:0;background:var(--grad-prog);border-radius:99px;transition:width .35s cubic-bezier(.4,0,.2,1)}
#screen-guide .pct{font-family:var(--font-body);font-size:13px;color:var(--accent);font-weight:700;min-width:34px;text-align:right}
#screen-guide .btn{appearance:none;border:none;font-family:inherit;font-size:16px;font-weight:700;border-radius:14px;padding:16px 22px;cursor:pointer;transition:transform .1s,box-shadow .2s,background .2s;display:inline-flex;align-items:center;justify-content:center;gap:9px}
#screen-guide .btn.primary{background:var(--grad-accent);color:var(--on-accent);box-shadow:var(--glow-accent)}
#screen-guide .btn.primary:hover{filter:brightness(1.05)}
#screen-guide .btn.primary:active{transform:scale(.98)}
#screen-guide .btn.ghost{background:var(--card-2);color:var(--ink);border:1.5px solid var(--line2)}
#screen-guide .btn.ghost:active{background:var(--blue-bg)}
#screen-guide .buildwrap{max-width:1080px;margin:0 auto;padding:16px 16px 0}
#screen-guide .maincol>*,#screen-guide .sidecol>*{animation:rise .4s ease both}
#screen-guide .card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-sm)}
#screen-guide .seg{display:flex;background:rgba(255,255,255,.05);border-radius:16px;padding:5px;gap:5px;margin-bottom:12px;border:1px solid var(--line)}
#screen-guide .seg button{flex:1;border:none;background:transparent;font-family:inherit;font-weight:700;font-size:14px;padding:13px;border-radius:12px;color:var(--soft);cursor:pointer;transition:.18s;letter-spacing:-.01em}
#screen-guide .seg button.on{background:var(--grad-accent);color:var(--on-accent);box-shadow:0 6px 18px rgba(31,208,252,.35)}
#screen-guide .seg button.on .s{color:rgba(5,34,54,.72)}
#screen-guide .seg .s{display:block;font-size:11px;font-weight:500;margin-top:2px;color:var(--faint)}
#screen-guide .area{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:14px;padding:0 4px}
#screen-guide .area .code{font-size:clamp(40px,11vw,56px);font-weight:600;letter-spacing:-.03em;line-height:.9;display:flex;align-items:baseline;font-family:var(--font-display);color:var(--ink)}
#screen-guide .area .code .dash{color:var(--accent);padding:0 .04em}
#screen-guide .area .sub{font-family:var(--font-body);font-size:12px;color:var(--soft);margin-top:8px}
#screen-guide .donepill{display:inline-flex;align-items:center;gap:8px;border:1.5px solid var(--line2);background:var(--card-2);border-radius:99px;padding:11px 17px;font-weight:700;font-size:13px;cursor:pointer;color:var(--soft);white-space:nowrap;transition:.18s}
#screen-guide .donepill .c{width:19px;height:19px;border-radius:50%;border:2px solid var(--line2);display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--on-accent);transition:.18s}
#screen-guide .donepill.on{background:var(--accent-bg);border-color:var(--accent-soft);color:var(--accent)}
#screen-guide .donepill.on .c{background:var(--grad-accent);border-color:transparent}
#screen-guide .gridcard{padding:20px;margin-bottom:16px}
#screen-guide .flipnote{display:flex;align-items:center;gap:10px;background:var(--accent-bg);border:1px solid var(--accent-soft);color:var(--accent-ink);border-radius:14px;padding:11px 14px;font-size:13px;font-weight:600;margin-bottom:16px}
#screen-guide .flipnote .fi{font-size:16px;color:var(--accent)}
#screen-guide .rownote{background:var(--blue-bg);border-color:var(--blue-soft);color:var(--blue-ink)}
#screen-guide .rownote .fi{color:var(--accent)}
#screen-guide .gridsvg{width:100%;height:auto;display:block;touch-action:pan-y;max-width:440px;margin:0 auto}
#screen-guide .emptybox{padding:46px 12px;text-align:center;color:var(--soft);font-size:15px;font-weight:600}
#screen-guide .emptybox .e{width:64px;height:64px;border-radius:50%;background:var(--accent-bg);color:var(--accent);font-size:32px;display:flex;align-items:center;justify-content:center;margin:0 auto 12px}
#screen-guide .legend{display:flex;gap:20px;justify-content:center;margin-top:16px;font-size:12.5px;color:var(--soft);font-family:var(--font-body)}
#screen-guide .legend .li{display:flex;align-items:center;gap:8px}
#screen-guide .lg{width:18px;height:18px;border-radius:50%;flex:none}
#screen-guide .lg.p{background:var(--accent);box-shadow:0 0 10px rgba(31,208,252,.7);border:1.5px solid var(--accent-d)}
#screen-guide .lg.s{background:transparent;border:2.5px solid var(--ring)}
#screen-guide .navrow{display:flex;gap:12px;align-items:stretch;position:relative}
#screen-guide .navrow .back{width:60px;flex:none;font-size:20px}
#screen-guide .navrow .next{flex:1;height:58px;font-size:16px;letter-spacing:-.01em}
#screen-guide .navrow .counter{position:absolute;top:-10px;left:50%;transform:translateX(-50%);font-family:var(--font-body);font-size:11px;color:var(--faint);background:var(--bg);padding:0 9px}
#screen-guide .navrow .counter b{color:var(--accent)}
#screen-guide details.adv{margin-bottom:14px}
#screen-guide details.adv>summary{cursor:pointer;color:var(--ink);font-size:14px;padding:15px 18px;list-style:none;font-weight:700;letter-spacing:-.01em;background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:9px}
#screen-guide details.adv>summary::-webkit-details-marker{display:none}
#screen-guide details.adv>summary:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px rgba(31,208,252,.8);flex:none}
#screen-guide details.adv>summary:after{content:"⌄";margin-left:auto;font-size:18px;color:var(--faint);transition:.2s}
#screen-guide details.adv[open]>summary{border-radius:16px 16px 0 0;border-bottom:none}
#screen-guide details.adv[open]>summary:after{transform:rotate(180deg)}
#screen-guide .subcard{background:var(--card);border:1px solid var(--line);border-top:none;border-radius:0 0 16px 16px;padding:16px 18px;box-shadow:var(--shadow-sm)}
#screen-guide .muted{color:var(--soft);font-size:12.5px;line-height:1.5;font-family:var(--font-body)}
#screen-guide .rowstrip{display:flex;gap:7px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:3px 0 7px}
#screen-guide .rowstrip::-webkit-scrollbar{height:5px}
#screen-guide .rowstrip::-webkit-scrollbar-thumb{background:var(--line2);border-radius:9px}
#screen-guide .rowstrip button{flex:none;width:44px;height:44px;border:1.5px solid var(--line2);background:var(--card-2);border-radius:13px;font-family:var(--font-body);font-weight:700;font-size:15px;cursor:pointer;color:var(--ink);transition:.12s}
#screen-guide .rowstrip button.on{background:var(--grad-accent);color:var(--on-accent);border-color:transparent}
#screen-guide .rowstrip button.empty{color:var(--faint)}
#screen-guide .jump{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin-top:11px}
#screen-guide .jump button{padding:13px 0;border:1.5px solid var(--line2);background:var(--card-2);border-radius:13px;font-family:var(--font-body);font-size:14px;font-weight:700;cursor:pointer;color:var(--ink);position:relative;transition:.12s}
#screen-guide .jump button.on{background:var(--grad-accent);color:var(--on-accent);border-color:transparent;box-shadow:0 5px 13px rgba(31,208,252,.35)}
#screen-guide .jump button.empty{color:var(--faint);background:rgba(255,255,255,.03)}
#screen-guide .jump button.done:after{content:"";position:absolute;top:6px;right:6px;width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px rgba(31,208,252,.9)}
#screen-guide .jump button.on.done:after{background:var(--on-accent);box-shadow:none}
#screen-guide #ovScroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
#screen-guide #ovScroll svg{height:118px;display:block}
#screen-guide #mini{width:100%;max-width:230px;display:block;margin:0 auto;image-rendering:pixelated;border-radius:14px;background:#04122a}
#screen-guide .toplinks{display:flex;justify-content:center;padding:10px 0 18px}
#screen-guide .toplinks .linkbtn{background:none;border:1px solid var(--line2);color:var(--soft);font:inherit;font-size:12.5px;font-weight:600;cursor:pointer;padding:7px 16px;border-radius:99px;transition:.15s}
#screen-guide .toplinks .linkbtn:hover{color:var(--ink);border-color:var(--soft)}
#screen-guide .toplinks .linkbtn.danger{color:var(--soft)}
@media(max-width:899px){
  #screen-guide .navrow{position:sticky;bottom:0;z-index:40;background:linear-gradient(0deg,var(--bg) 72%,rgba(11,35,72,.6));margin:0 -16px;padding:10px 16px calc(12px + env(safe-area-inset-bottom));border-top:1px solid var(--line)}
  #screen-guide .sidecol{padding-bottom:6px}
}
@media(min-width:900px){
  #screen-guide .buildwrap{display:grid;grid-template-columns:minmax(0,1fr) 372px;gap:28px;align-items:start;padding:26px 24px 40px}
  #screen-guide .maincol{position:sticky;top:62px}
  #screen-guide .navrow{margin-top:4px}
  #screen-guide .navrow .next{height:60px}
  #screen-guide details.adv[open]>summary:after{display:none}
  #screen-guide details.adv>summary{cursor:default}
}

/* ================= ЭКРАНЫ · ИСТОРИЯ И ПРЕДПРОСМОТР ================= */
#screen-home.on,#screen-crop.on,#screen-preview.on{display:flex;flex-direction:column;align-items:center;min-height:100dvh;padding:clamp(14px,4vw,40px)}
#screen-home .card,#screen-preview .card{width:min(560px,100%);margin-block:auto;background:var(--card);border-radius:24px;box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid var(--line);animation:rise .6s cubic-bezier(.2,.8,.2,1) both}
#screen-home header,#screen-preview header{padding:24px 26px 18px;display:flex;align-items:center;gap:14px;color:var(--ink);border-bottom:1px solid var(--line)}
#screen-home .titles h1,#screen-preview .titles h1{font-family:var(--font-display);font-weight:600;font-size:1.35rem;letter-spacing:-.01em;line-height:1.1;color:var(--ink)}
#screen-home .titles p,#screen-preview .titles p{font-size:.85rem;color:var(--soft);margin-top:5px;font-weight:400}
#screen-home .body,#screen-preview .body{padding:24px}
#screen-home .lead,#screen-preview .lead{color:var(--soft);font-size:.92rem;line-height:1.55;margin:14px 2px}

#screen-home .btn,#screen-preview .btn{border:none;border-radius:14px;padding:14px 16px;font-family:var(--font-body);font-weight:700;font-size:.92rem;cursor:pointer;transition:.18s ease;display:flex;align-items:center;justify-content:center;gap:8px}
#screen-home .btn:active,#screen-preview .btn:active{transform:translateY(1px)}
#screen-home .btn svg,#screen-preview .btn svg{width:18px;height:18px}
#screen-preview .actions{display:flex;gap:10px;margin-top:4px}
#screen-preview .btn{flex:1}
#screen-home .btn-primary,#screen-preview .btn-primary{background:var(--grad-accent);color:var(--on-accent);box-shadow:var(--glow-accent)}
#screen-home .btn-primary{width:100%}
#screen-home .btn-primary:hover,#screen-preview .btn-primary:hover{filter:brightness(1.05)}
#screen-preview .btn-ghost{background:rgba(255,255,255,.06);color:var(--ink);box-shadow:inset 0 0 0 1.5px var(--line2)}
#screen-preview .btn-ghost:hover{background:rgba(255,255,255,.1)}
#screen-home .btn:disabled,#screen-preview .btn:disabled{opacity:.55;cursor:not-allowed}
#screen-home .spinner,#screen-preview .spinner{width:18px;height:18px;border:3px solid rgba(5,34,54,.35);border-top-color:var(--on-accent);border-radius:50%;animation:spin .7s linear infinite}
#screen-preview .crop-msg{font-size:.86rem;text-align:center;margin-top:14px;min-height:1.1em;color:var(--accent-ink)}
#screen-preview .crop-msg.err{color:#ff9a82}

#screen-preview .pvbox{display:flex;justify-content:center;margin-bottom:6px}
#screen-preview .card{width:min(940px,100%)}
#screen-preview .pvstage{position:relative;width:min(880px,95vw);aspect-ratio:1/1;border-radius:18px;overflow:hidden;
  box-shadow:var(--shadow),0 0 0 1px var(--line),0 0 60px -12px rgba(31,208,252,.3)}
#screen-preview .pvstage img,#screen-preview .pvstage svg{position:absolute;inset:0;width:100%;height:100%;display:block}
#screen-preview .pvbg{object-fit:cover;z-index:0}
#screen-preview .pvdots{z-index:1}
#screen-preview .pvframe{z-index:2;pointer-events:none}
#screen-preview .buycta{margin-top:8px;padding:20px 18px;border-radius:18px;text-align:center;
  border:1px solid var(--accent-soft);background:var(--accent-bg)}
#screen-preview .buylead{font-family:var(--font-display);font-weight:600;font-size:1.1rem;color:var(--ink);letter-spacing:-.01em;margin-bottom:14px}
#screen-preview .buybtn{display:inline-flex;width:auto;padding:15px 28px;text-decoration:none;font-size:1rem}

#screen-home .empty{text-align:center;padding:26px 10px 6px;color:var(--soft)}
#screen-home .empty-ico{width:66px;height:66px;margin:0 auto 14px;border-radius:20px;background:var(--accent-bg);color:var(--accent);display:grid;place-items:center;box-shadow:inset 0 0 0 1px var(--accent-soft)}
#screen-home .empty-ico svg{width:30px;height:30px}
#screen-home .empty p{font-size:.9rem;line-height:1.55;max-width:300px;margin:0 auto}
#screen-home .histgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:14px;margin-top:18px}
.histcard{position:relative;border-radius:16px;overflow:hidden;background:var(--card-2);box-shadow:var(--shadow-sm);border:1px solid var(--line);cursor:pointer;transition:.16s ease}
.histcard:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--line2)}
.histcard .thumb{width:100%;aspect-ratio:1/1;display:block;background:#04122a;object-fit:cover}
.histcard .meta{padding:9px 11px 12px}
.histcard .date{font-size:.72rem;color:var(--faint);font-family:var(--font-body)}
.histcard .pbar{height:7px;border-radius:99px;background:var(--line2);overflow:hidden;margin-top:7px}
.histcard .pbar i{display:block;height:100%;border-radius:99px;background:var(--grad-prog)}
.histcard .pct{font-size:.74rem;color:var(--soft);font-weight:700;margin-top:5px}
.histcard .del{position:absolute;top:7px;right:7px;width:27px;height:27px;border:none;border-radius:50%;background:rgba(4,12,28,.6);color:#fff;font-size:16px;line-height:1;cursor:pointer;display:grid;place-items:center;opacity:.9}
.histcard .del:hover{background:#c0392b}
#screen-home .toplinks{display:flex;gap:8px;justify-content:center;padding:18px 0 2px}
#screen-home .linkbtn{background:none;border:none;color:var(--soft);font:inherit;font-size:13px;font-weight:600;cursor:pointer;padding:9px}
#screen-home .linkbtn.danger{color:#ff7a66}

/* ================= ГЛАВНАЯ · ЛЕНДИНГ ================= */
#screen-landing.on{display:block;animation:fade .4s ease both}
.lnav-in,.lhero-in,.lstrip-in,.lsec-in,.lfinal-in,.lfoot-in{max-width:1180px;margin:0 auto;
  padding-left:clamp(18px,5vw,44px);padding-right:clamp(18px,5vw,44px)}
.lsec-narrow{max-width:860px}

/* reveal on scroll */
.rv{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.8,.2,1)}
.rv-in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .rv{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
  #screen-crop .drop .ico::after{animation:none}
}

/* кнопки лендинга */
.lbtn{display:inline-flex;align-items:center;justify-content:center;gap:9px;border:none;cursor:pointer;
  font-family:var(--font-body);font-weight:700;border-radius:999px;text-decoration:none;color:var(--ink);
  transition:transform .12s,filter .2s,background .2s,box-shadow .2s,border-color .2s;line-height:1.15}
.lbtn:active{transform:translateY(1px)}
.lbtn svg{width:19px;height:19px;flex:none}
.lbtn-primary{background:var(--grad-accent);color:var(--on-accent);box-shadow:var(--glow-accent)}
.lbtn-primary:hover{filter:brightness(1.06);transform:translateY(-1px)}
.lbtn-ghost{background:rgba(255,255,255,.06);color:var(--ink);box-shadow:inset 0 0 0 1.5px var(--line2)}
.lbtn-ghost:hover{background:rgba(255,255,255,.1);box-shadow:inset 0 0 0 1.5px var(--accent-soft)}
.lbtn-sm{padding:10px 18px;font-size:.88rem}
.lbtn-xl{padding:15px 26px;font-size:1rem}
.lbtn .ltxt{display:flex;flex-direction:column;align-items:flex-start;gap:1px;text-align:left}
.lbtn .ltxt b{font-weight:700;font-size:.98rem;letter-spacing:-.01em}
.lbtn .ltxt i{font-style:normal;font-weight:500;font-size:.74rem;opacity:.8}

/* шапка */
.lnav{position:sticky;top:0;z-index:50;background:rgba(11,35,72,.6);
  -webkit-backdrop-filter:saturate(160%) blur(14px);backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid transparent;transition:border-color .2s,background .2s}
.lnav-in{display:flex;align-items:center;gap:18px;height:70px}
.lnav.scrolled{border-bottom-color:var(--line);background:rgba(9,29,60,.8)}
.lbrand{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:600;
  font-size:1.2rem;color:var(--ink);cursor:pointer;text-decoration:none;letter-spacing:-.01em}
.lbrand .logo{width:34px;height:34px;border-radius:11px;background:var(--accent-bg);color:var(--accent);
  display:grid;place-items:center;box-shadow:inset 0 0 0 1px var(--accent-soft)}
.lbrand .logo svg{width:19px;height:19px;filter:drop-shadow(0 0 7px rgba(255,212,94,.7))}
.lbrand-logo{height:48px;width:auto;display:block;filter:drop-shadow(0 0 14px rgba(255,199,32,.22))}
.lnav-links{display:none;gap:28px}
.lnav-links a{color:var(--soft);font-weight:500;font-size:.92rem;cursor:pointer;text-decoration:none;transition:.15s}
.lnav-links a:hover{color:var(--ink)}
.lnav-codebtn{margin-left:auto;padding-top:6px;padding-bottom:6px}
.lnav-codebtn .ltxt{align-items:center;gap:1px}
.lnav-codebtn .ltxt b{font-size:.86rem;line-height:1.15}
.lnav-codebtn .ltxt i{font-size:.64rem;opacity:.72}
@media(min-width:900px){.lnav-links{display:flex}}

/* герой */
.lhero{position:relative;overflow:hidden}
.lhero-in{display:grid;gap:18px;padding-top:clamp(16px,4vw,80px);padding-bottom:clamp(36px,7vw,84px)}
.lbadge{display:inline-flex;align-items:center;gap:8px;background:var(--accent-bg);color:var(--accent-ink);
  border:1px solid var(--accent-soft);border-radius:99px;padding:7px 15px;font-size:.78rem;font-weight:600}
.lbadge .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px rgba(31,208,252,.9)}
.lh1{font-family:var(--font-display);font-weight:800;font-size:clamp(2.5rem,6.6vw,4.2rem);line-height:1.07;
  letter-spacing:-.02em;margin:0;color:var(--ink)}
.lh1 .accent{color:var(--cream);text-shadow:0 0 40px rgba(242,234,217,.28)}
.llead{margin-top:0;font-size:clamp(1.02rem,2.2vw,1.2rem);line-height:1.6;color:var(--soft);max-width:520px}
.lcta{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.lhero-copy .lcta{margin-top:0}   /* в герое отступ задаёт общий ритм .lhero-copy */
.lcta.center{justify-content:center}
/* подзаголовок-нота под кнопками героя */
.hero-note{margin-top:2px;font-size:.84rem;color:var(--faint);max-width:430px;line-height:1.5;letter-spacing:.01em}
.hero-note .ast{color:var(--accent);font-weight:700;margin-right:4px}
.lbtn-ast{font-size:.56em;font-weight:700;opacity:.6;margin-left:1px}
.dot-pulse{position:relative;width:9px;height:9px;flex:none;border-radius:50%;background:var(--accent);box-shadow:0 0 10px rgba(143,212,255,.9)}
.dot-pulse::after{content:"";position:absolute;inset:-5px;border-radius:50%;border:1.5px solid var(--accent);opacity:.5;animation:pulse 2.2s ease-out infinite}
@media(prefers-reduced-motion:reduce){.dot-pulse::after{animation:none}}
.lhero-trust{display:flex;align-items:center;gap:14px;margin-top:26px;flex-wrap:wrap}
.lstars{display:inline-flex;gap:3px;color:#FFD45E}
.lstars svg{width:18px;height:18px}
.lhero-trust span{font-size:.86rem;color:var(--soft);font-weight:500}
.lhero-trust b{color:var(--ink);font-weight:700}
.ltrust{display:flex;flex-wrap:wrap;gap:14px 22px;margin-top:24px;list-style:none}
.ltrust li{display:flex;align-items:center;gap:8px;font-size:.86rem;color:var(--soft);font-weight:500}
.ltrust .ck{width:20px;height:20px;border-radius:50%;background:var(--accent-bg);color:var(--accent);
  display:grid;place-items:center;font-size:12px;font-weight:800}
/* мобильный порядок героя: заголовок -> фото -> текст/кнопки */
.lh1{order:1}
.lhero-art{position:relative;order:2}
.lhero-copy{order:3;display:flex;flex-direction:column;gap:18px}
.lhero-frame{position:relative;border-radius:24px;overflow:hidden;box-shadow:var(--shadow-lg),0 0 70px -14px rgba(31,208,252,.35);
  border:1px solid var(--line2);height:clamp(210px,34vh,340px);background:#04122a}
.lhero-frame img{width:100%;height:100%;object-fit:cover;display:block}
.lhero-tag{position:absolute;left:16px;bottom:16px;display:inline-flex;align-items:center;gap:8px;
  background:rgba(7,26,55,.72);color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.18);border-radius:99px;padding:8px 14px;font-size:.8rem;font-weight:600}
.lhero-tag .logo.sm{width:20px;height:20px;color:var(--accent);display:grid;place-items:center}
.lhero-tag .logo.sm svg{width:14px;height:14px}
.lhero-glow{display:none}
@media(min-width:900px){
  .lhero-in{grid-template-columns:1.05fr .95fr;align-items:center;column-gap:56px;row-gap:18px}
  .lh1{grid-column:1;grid-row:1;order:0;margin-top:0}
  .lhero-copy{grid-column:1;grid-row:2;order:0}
  .lhero-art{grid-column:2;grid-row:1 / span 2;order:0;align-self:center}
  .lhero-frame{aspect-ratio:1/1;height:auto}
}

/* полоса со статистикой */
.lstrip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:rgba(255,255,255,.03)}
.lstrip-in{display:grid;grid-template-columns:repeat(2,1fr);gap:28px 18px;padding-top:34px;padding-bottom:34px}
.lstat{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.lstat b{display:block;font-family:var(--font-display);font-weight:700;font-size:1.12rem;line-height:1.25;color:var(--ink);letter-spacing:-.01em}
.lstat span{display:block;margin-top:6px;font-size:.82rem;line-height:1.45;color:var(--soft)}
@media(min-width:760px){
  .lstrip-in{grid-template-columns:repeat(4,1fr);gap:0}
  .lstat{padding:2px 12px}
  .lstat + .lstat{border-left:1px solid var(--line)}
}
/* на широких экранах подпись точно умещается в одну строку */
@media(min-width:1200px){.lstat span{white-space:nowrap}}

/* секции */
.lsec{position:relative;padding-top:clamp(54px,8vw,100px);padding-bottom:clamp(54px,8vw,100px)}
.lsec.alt{background:rgba(255,255,255,.03);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.lsec-head{max-width:700px;margin:0 auto clamp(32px,5vw,56px);text-align:center}
.leyebrow{font-weight:700;font-size:.76rem;text-transform:uppercase;letter-spacing:.18em;color:var(--accent)}
.lsec-head h2{font-family:var(--font-display);font-weight:800;font-size:clamp(1.8rem,4.5vw,2.7rem);
  letter-spacing:-.02em;color:var(--ink);margin-top:14px;line-height:1.1}
.lsec-head p{margin-top:16px;color:var(--soft);font-size:1.05rem;line-height:1.6}

/* как это работает */
.lsteps{display:grid;gap:20px}
.lstep{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:30px 26px;box-shadow:var(--shadow-sm);transition:.2s}
.lstep:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line2)}
.lstep .lnum{display:grid;place-items:center;width:44px;height:44px;border-radius:50%;background:var(--accent-bg);
  color:var(--accent);font-family:var(--font-display);font-weight:600;font-size:1.2rem;border:1px solid var(--accent-soft)}
.lstep h3{font-family:var(--font-display);font-weight:600;font-size:1.2rem;margin:18px 0 9px;color:var(--ink);letter-spacing:-.01em}
.lstep p{color:var(--soft);font-size:.95rem;line-height:1.6}
@media(min-width:760px){.lsteps{grid-template-columns:repeat(3,1fr)}}

/* возможности */
.lfeat{display:grid;gap:20px}
.lcard{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:28px 24px;box-shadow:var(--shadow-sm);transition:.2s}
.lcard:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line2)}
.lico{display:grid;place-items:center;width:48px;height:48px;border-radius:14px;background:var(--accent-bg);
  color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent-soft)}
.lico svg{width:24px;height:24px}
.lcard h3{font-family:var(--font-display);font-weight:600;font-size:1.14rem;margin:18px 0 9px;color:var(--ink)}
.lcard p{color:var(--soft);font-size:.93rem;line-height:1.6}
@media(min-width:680px){.lfeat{grid-template-columns:repeat(2,1fr)}}
@media(min-width:980px){.lfeat{grid-template-columns:repeat(3,1fr)}}

/* примеры */
.lgal{display:grid;gap:18px}
.lgal-card{position:relative;border-radius:20px;overflow:hidden;background:#04122a;box-shadow:var(--shadow);border:1px solid var(--line2)}
.lgal-card img{width:100%;aspect-ratio:4/5;object-fit:cover;display:block;transition:transform .5s cubic-bezier(.2,.8,.2,1)}
.lgal-card:hover img{transform:scale(1.04)}
.lgal-card figcaption{position:absolute;left:0;right:0;bottom:0;padding:32px 16px 15px;color:#fff;font-weight:600;
  font-size:.96rem;display:flex;align-items:center;gap:10px;background:linear-gradient(0deg,rgba(4,12,28,.9),transparent)}
.ltag{font-size:.64rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;
  background:rgba(31,208,252,.22);color:#cdf3ff;border:1px solid rgba(31,208,252,.4);padding:3px 9px;border-radius:99px}
@media(min-width:760px){.lgal{grid-template-columns:repeat(3,1fr)}}

/* отзывы */
.lrev{display:grid;gap:20px}
.lrev-card{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:28px 26px;box-shadow:var(--shadow-sm)}
.lrev-stars{display:inline-flex;gap:3px;color:#FFD45E;margin-bottom:14px}
.lrev-stars svg{width:17px;height:17px}
.lrev-card blockquote{font-family:var(--font-display);font-weight:500;font-size:1.08rem;line-height:1.5;color:var(--ink-2);letter-spacing:-.01em}
.lrev-who{display:flex;align-items:center;gap:12px;margin-top:20px}
.lrev-ava{width:42px;height:42px;border-radius:50%;background:var(--accent-bg);color:var(--accent);display:grid;place-items:center;font-weight:700;font-size:1rem;border:1px solid var(--accent-soft)}
.lrev-name{font-weight:700;font-size:.92rem;color:var(--ink)}
.lrev-role{font-size:.8rem;color:var(--faint)}
@media(min-width:860px){.lrev{grid-template-columns:repeat(3,1fr)}}

/* где купить */
.lshops{display:grid;gap:14px;max-width:780px;margin:0 auto}
.lshop{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 22px;border-radius:16px;
  background:var(--card);border:1.5px solid var(--line2);text-decoration:none;color:var(--ink);transition:.16s}
.lshop-name{font-weight:700;font-size:1.06rem;font-family:var(--font-display)}
.lshop-tag{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;
  color:var(--faint);background:rgba(255,255,255,.05);border:1px solid var(--line2);padding:5px 12px;border-radius:99px}
.lshop.is-soon{cursor:default;opacity:.8}
.lshop:not(.is-soon):hover{border-color:var(--accent-soft);background:var(--accent-bg);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
@media(min-width:680px){.lshops{grid-template-columns:repeat(3,1fr)}}

/* FAQ */
.lfaq{display:flex;flex-direction:column;gap:12px}
.lq{background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-sm);overflow:hidden}
.lq>summary{cursor:pointer;list-style:none;padding:20px 22px;font-weight:600;font-size:1.02rem;color:var(--ink);display:flex;align-items:center;gap:12px}
.lq>summary::-webkit-details-marker{display:none}
.lq>summary::after{content:"+";margin-left:auto;font-size:1.5rem;line-height:1;color:var(--accent);font-weight:400;transition:.2s}
.lq[open]>summary::after{transform:rotate(45deg)}
.lq p{padding:0 22px 20px;color:var(--soft);font-size:.95rem;line-height:1.6}

/* финальный CTA */
.lfinal{position:relative;overflow:hidden;background:linear-gradient(135deg,#0c3a73 0%,#1366a8 55%,#1f7fc4 100%);color:#fff}
.lfinal::after{content:"";position:absolute;width:600px;height:600px;left:50%;top:-70%;transform:translateX(-50%);
  background:radial-gradient(circle,rgba(31,208,252,.45),transparent 62%);filter:blur(40px);pointer-events:none}
.lfinal-in{position:relative;z-index:1;text-align:center;padding-top:clamp(56px,8vw,96px);padding-bottom:clamp(56px,8vw,96px)}
.lfinal h2{font-family:var(--font-display);font-weight:600;font-size:clamp(1.9rem,5vw,2.9rem);letter-spacing:-.02em}
.lfinal p{margin:16px auto 0;font-size:1.08rem;color:rgba(255,255,255,.85);max-width:560px}
.lfinal .lbtn-primary{background:#fff;color:#0c3a73;box-shadow:0 16px 40px -14px rgba(0,0,0,.5)}
.lfinal .lbtn-primary:hover{background:#eaf7ff;filter:none}
.lfinal .lbtn-ghost{background:transparent;color:#fff;box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.45)}
.lfinal .lbtn-ghost:hover{background:rgba(255,255,255,.12)}

/* футер */
.lfoot{background:#071a37;color:var(--soft);border-top:1px solid var(--line)}
.lfoot-in{display:grid;gap:34px;padding-top:clamp(44px,6vw,64px);padding-bottom:34px}
.lfoot-brand .lbrand.light{color:var(--ink)}
.lfoot-brand .lbrand.light .logo{background:var(--accent-bg);color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent-soft)}
.lfoot-brand .lbrand-logo{height:64px}
.lfoot-brand p{margin-top:14px;color:var(--soft);font-size:.92rem;line-height:1.6;max-width:340px}
.lfoot-cols{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.lfoot-col h4{font-family:var(--font-display);font-weight:600;font-size:1rem;color:var(--ink);margin-bottom:14px}
.lfoot-col a{display:block;color:var(--soft);font-size:.9rem;margin-bottom:11px;text-decoration:none;cursor:pointer;transition:.15s}
.lfoot-col a:hover{color:var(--accent)}
.lfoot-bottom{border-top:1px solid var(--line);max-width:1180px;margin:0 auto;
  padding:18px clamp(18px,5vw,44px);display:flex;flex-wrap:wrap;gap:8px 18px;justify-content:space-between;align-items:center;font-size:.8rem;color:var(--faint)}
.lfoot-mini{color:var(--faint)}
@media(min-width:760px){.lfoot-cols{grid-template-columns:repeat(3,1fr)}}
@media(min-width:880px){.lfoot-in{grid-template-columns:1fr 1.4fr}}

/* баннер cookie */
.cookiebar{position:fixed;left:0;right:0;bottom:0;z-index:90;background:rgba(9,29,60,.96);
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--line2);
  box-shadow:0 -12px 40px -22px rgba(0,0,0,.7);padding:16px clamp(16px,5vw,44px);
  display:flex;flex-direction:column;gap:12px;animation:rise .4s ease both}
.cookiebar p{font-size:.86rem;color:var(--soft);line-height:1.5;margin:0}
.cookiebar a{color:var(--accent);font-weight:700}
.cookiebtns{display:flex;gap:10px;flex-wrap:wrap}
.cookiebtns .lbtn{flex:1;min-width:140px}
@media(min-width:760px){
  .cookiebar{flex-direction:row;align-items:center;justify-content:center;gap:24px}
  .cookiebar p{flex:1;max-width:780px}
  .cookiebtns .lbtn{flex:none;min-width:0}
}
/* резерв места под cookie-баннер */
:root{--cookie-h:0px}
body.has-cookie{--cookie-h:168px}
@media(min-width:760px){body.has-cookie{--cookie-h:84px}}
body.has-cookie #screen-gate.on,
body.has-cookie #screen-crop.on,
body.has-cookie #screen-home.on,
body.has-cookie #screen-preview.on{padding-bottom:calc(var(--cookie-h) + 20px)}
@media(max-width:899px){
  body.has-cookie #screen-guide .navrow{bottom:var(--cookie-h)}
}

/* ================= РЕДИЗАЙН · ЖИВОЙ / ЛЁГКИЙ / ИНТЕРЕСНЫЙ ================= */

/* мягкая аврора-подсветка фона */
body::after{content:"";position:fixed;inset:-25%;z-index:-1;pointer-events:none;
  background:
    radial-gradient(40% 38% at 22% 30%,rgba(79,159,230,.16),transparent 70%),
    radial-gradient(36% 34% at 80% 64%,rgba(143,212,255,.12),transparent 70%),
    radial-gradient(30% 30% at 60% 12%,rgba(240,201,142,.05),transparent 70%);
  filter:blur(34px);animation:aurora 26s ease-in-out infinite alternate}
@keyframes aurora{
  0%{transform:translate3d(0,0,0) scale(1)}
  50%{transform:translate3d(2%,-2%,0) scale(1.06)}
  100%{transform:translate3d(-2%,2%,0) scale(1.02)}}
/* вход героя со стаггером */
@keyframes heroIn{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.lh1,.lhero-copy>*{animation:heroIn .7s cubic-bezier(.22,.61,.36,1) both}
.lhero-art{animation:heroIn .8s .12s cubic-bezier(.22,.61,.36,1) both}
.lhero-copy>.llead{animation-delay:.2s}
.lhero-copy>.lcta{animation-delay:.28s}
.lhero-copy>.hero-note{animation-delay:.36s}

/* степпер «как это работает» */
.lflow{position:relative;display:grid;gap:26px}
.lflow-line{display:none}
.lflow-step{position:relative;padding-left:64px}
.lflow-node{position:absolute;left:0;top:0;width:46px;height:46px;border-radius:50%;
  display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:1.2rem;
  color:var(--on-accent);background:var(--grad-accent);box-shadow:0 0 0 6px var(--accent-bg),var(--glow-accent)}
.lflow-step h3{font-family:var(--font-display);font-weight:700;font-size:1.16rem;color:var(--ink);margin:4px 0 8px;letter-spacing:-.01em}
.lflow-step p{color:var(--soft);font-size:.96rem;line-height:1.6;max-width:48ch}
.lflow-step:not(:last-child)::before{content:"";position:absolute;left:22px;top:50px;bottom:-26px;width:2px;
  background:linear-gradient(180deg,var(--accent-soft),transparent)}
@media(min-width:820px){
  .lflow{grid-template-columns:repeat(3,1fr);gap:34px}
  .lflow-step{padding-left:0;padding-top:64px}
  .lflow-step:not(:last-child)::before{display:none}
  .lflow-line{display:block;position:absolute;top:23px;left:8%;right:8%;height:2px;
    background:linear-gradient(90deg,transparent,var(--accent-soft) 12%,var(--accent-soft) 88%,transparent)}
}

/* bento «возможности» */
.lbento{display:grid;grid-template-columns:1fr;gap:16px}
.lbtile{position:relative;overflow:hidden;background:var(--card);border:1px solid var(--line);
  border-radius:20px;padding:26px 24px;box-shadow:var(--shadow-sm);
  transition:transform .2s cubic-bezier(.22,.61,.36,1),box-shadow .2s,border-color .2s}
.lbtile:hover{transform:translateY(-4px);box-shadow:var(--shadow),0 0 0 1px var(--accent-soft);border-color:var(--accent-soft)}
.lbtile .lico{display:grid;place-items:center;width:48px;height:48px;border-radius:14px;background:var(--accent-bg);
  color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent-soft)}
.lbtile .lico svg{width:24px;height:24px}
.lbtile h3{font-family:var(--font-display);font-weight:700;font-size:1.14rem;margin:16px 0 8px;color:var(--ink);letter-spacing:-.01em}
.lbtile p{color:var(--soft);font-size:.93rem;line-height:1.6}
.lbtile.b-glow{background:radial-gradient(120% 120% at 82% 0%,rgba(143,212,255,.15),transparent 58%),var(--card)}
.lbtile.b-warm{background:radial-gradient(120% 120% at 82% 0%,rgba(240,201,142,.13),transparent 58%),var(--card)}
.lbtile.b-warm .lico{background:var(--warm-soft);color:var(--warm);box-shadow:inset 0 0 0 1px rgba(240,201,142,.32)}
.lbtile-dots{position:absolute;right:-24px;bottom:-24px;width:190px;height:190px;pointer-events:none;opacity:.55;
  background-image:radial-gradient(var(--accent) 1.5px,transparent 1.8px);background-size:15px 15px;
  -webkit-mask-image:radial-gradient(circle at 72% 72%,#000,transparent 64%);mask-image:radial-gradient(circle at 72% 72%,#000,transparent 64%)}
.lbtile-lg{display:flex;flex-direction:column;justify-content:center}
.lbtile-lg h3{font-size:1.42rem;margin-top:18px}
.lbtile-lg p{font-size:1rem;max-width:44ch}
@media(min-width:680px){
  .lbento{grid-template-columns:repeat(3,1fr)}
}

/* glow-ховеры галереи/отзывов */
.lgal-card:hover{box-shadow:var(--shadow),0 0 0 1px var(--accent-soft)}
.lrev-card{transition:transform .2s,box-shadow .2s,border-color .2s}
.lrev-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--accent-soft)}

/* галерея: 2×2 на мобильном, 4 квадрата в ряд на ПК */
.lgal{grid-template-columns:repeat(2,1fr);gap:12px}
@media(min-width:900px){
  .lgal{grid-template-columns:repeat(4,1fr);gap:18px}
  .lgal-card img{aspect-ratio:1/1}     /* все равные квадраты в одну строку */
}

/* отзывы — авто-лента + свайп/перетаскивание (нативная горизонтальная прокрутка) */
.lrev-marquee{overflow-x:auto;overflow-y:hidden;margin-top:6px;cursor:grab;
  -webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;user-select:none;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.lrev-marquee::-webkit-scrollbar{display:none}
.lrev-marquee.dragging{cursor:grabbing}
.lrev-track{display:flex;width:max-content}
.lrev-track .lrev-card{width:340px;max-width:78vw;flex:none;margin-right:20px}

@media(prefers-reduced-motion:reduce){
  body::after{animation:none}
  .lh1,.lhero-copy>*,.lhero-art{animation:none}
  /* лента отзывов крутится всегда (по явному пожеланию) — не отключаем */
}

/* ================= ОЖИВЛЕНИЕ ЭКРАНОВ ПРИЛОЖЕНИЯ ================= */
/* лёгкий подъём основных кнопок при наведении */
#screen-crop .btn-primary:hover,#screen-preview .btn-primary:hover,#screen-home .btn-primary:hover,#screen-gate button:hover{transform:translateY(-1px)}
/* тактильный «физический» отклик кнопок (перекрывает hover при нажатии) */
#screen-crop .btn:active,#screen-home .btn:active,#screen-preview .btn:active,.lbtn:active{transform:translateY(1px) scale(.985)}
#screen-gate button:active{transform:translateY(1px) scale(.985)}
/* плавное проявление результата предпросмотра (точки) */
#screen-preview .pvdots{opacity:0;transform:scale(.985);transition:opacity .55s ease,transform .55s cubic-bezier(.22,.61,.36,1)}
#screen-preview .pvdots.in{opacity:1;transform:none}
/* мягкое появление сетки при смене области в схеме */
#screen-guide .gridsvg{animation:gridIn .34s cubic-bezier(.22,.61,.36,1) both}
@keyframes gridIn{from{opacity:0;transform:scale(.97)}to{opacity:1;transform:none}}
#screen-guide .emptybox{animation:fade .3s ease both}
/* стаггер-появление карточек истории */
.histcard{animation:rise .45s cubic-bezier(.22,.61,.36,1) both}
/* на схеме пробивки фон не должен отвлекать: приглушаем аврору (звёзды — в app.js) */
body:has(#screen-guide.on)::after{opacity:.4}
/* рабочая область сетки — на сплошной подложке (звёзды не просвечивают сквозь точки) */
#screen-guide .gridcard{background:#0b1430;border-color:var(--line2)}
@media(prefers-reduced-motion:reduce){
  #screen-crop .btn:active,#screen-home .btn:active,#screen-preview .btn:active,#screen-gate button:active,.lbtn:active{transform:none}
  #screen-preview .pvdots{opacity:1;transform:none;transition:none}
  #screen-guide .gridsvg,#screen-guide .emptybox,.histcard{animation:none}
}

/* ================= ДОСТУПНОСТЬ: видимый фокус с клавиатуры ================= */
a:focus-visible,button:focus-visible,summary:focus-visible,input:focus-visible,
[tabindex]:focus-visible,[data-go]:focus-visible,[data-scroll]:focus-visible{
  outline:2px solid var(--accent);outline-offset:2px;border-radius:10px}
/* мышь/тач не показывают кольцо (только клавиатура) */
a:focus:not(:focus-visible),button:focus:not(:focus-visible),summary:focus:not(:focus-visible){outline:none}
/* тач-цель кнопки удаления в истории чуть крупнее */
.histcard .del{width:30px;height:30px}

/* модалка «переверните пластину» (Этап II) */
.flipmodal{position:fixed;inset:0;z-index:80;display:grid;place-items:center;padding:24px;
  background:rgba(4,8,20,.66);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:fade .25s ease both}
.flipmodal-card{width:min(420px,100%);background:var(--card-2);border:1px solid var(--line2);border-radius:22px;
  padding:30px 26px;text-align:center;box-shadow:var(--shadow-lg);animation:rise .35s cubic-bezier(.2,.8,.2,1) both}
.flipmodal-ico{display:inline-grid;place-items:center;width:60px;height:60px;border-radius:50%;
  background:var(--accent-bg);color:var(--accent);font-size:30px;margin-bottom:16px;box-shadow:inset 0 0 0 1px var(--accent-soft)}
.flipmodal-card h3{font-family:var(--font-display);font-weight:800;font-size:1.25rem;color:var(--ink);letter-spacing:-.01em;line-height:1.2}
.flipmodal-card p{color:var(--soft);font-size:.96rem;line-height:1.55;margin:10px 0 22px}
.flipmodal-card p b{color:var(--accent)}
.flipmodal-card .btn.primary{width:100%}
.flipmodal-ico.warn{background:rgba(229,84,78,.15);color:#ff8a82;box-shadow:inset 0 0 0 1px rgba(229,84,78,.42);font-weight:800}
.modal-actions{display:flex;gap:10px}
.modal-actions .btn{flex:1}
#screen-guide .btn.danger{background:#e5544e;color:#fff;box-shadow:0 6px 18px rgba(229,84,78,.32)}
#screen-guide .btn.danger:hover{filter:brightness(1.06)}
#screen-guide .btn.danger:active{transform:scale(.98)}
@media(prefers-reduced-motion:reduce){.flipmodal,.flipmodal-card{animation:none}}

/* ================= КНОПКИ МАГАЗИНОВ (фирменные цвета) ================= */
.lshops{max-width:620px}
@media(min-width:680px){.lshops{grid-template-columns:repeat(2,1fr)}}
.lshop-ozon,.lshop-wb{justify-content:center;gap:10px;border:0;color:#fff;padding:18px 24px;
  font-weight:800;transition:transform .16s,filter .2s,box-shadow .2s}
.lshop .lshop-name{font-family:var(--font-display);font-weight:800;font-size:1.14rem;letter-spacing:.02em}
.lshop-go{width:20px;height:20px;flex:none;opacity:.92}
/* Ozon — фирменный синий */
.lshop.lshop-ozon{background:linear-gradient(135deg,#0a5cff,#1f8bff);box-shadow:0 14px 34px -16px rgba(10,92,255,.8)}
.lshop.lshop-ozon:hover{transform:translateY(-2px);filter:brightness(1.07);box-shadow:0 18px 40px -16px rgba(10,92,255,.9)}
/* Wildberries — фирменный фиолетово-розовый градиент */
.lshop.lshop-wb{background:linear-gradient(135deg,#7b2ff7,#cb11ab 55%,#e6107a)}
.lshop.lshop-wb{box-shadow:0 14px 34px -16px rgba(193,17,171,.75)}
.lshop.lshop-wb:hover{transform:translateY(-2px);filter:brightness(1.07);box-shadow:0 18px 40px -16px rgba(193,17,171,.85)}

/* ================= ИНФО-СТРАНИЦЫ ФУТЕРА (О нас, политики и т.д.) ================= */
/* Тот же бренд (Ночная синь): nav-шапка как на главной, фон body-starfield. */
#screen-page.on{display:block}
#screen-page .lnav-sub .lnav-in{justify-content:space-between}
.lpage{padding:clamp(26px,6vw,60px) 0 clamp(40px,8vw,80px);min-height:60vh}
.lpage-in{max-width:780px;margin:0 auto;padding:0 clamp(18px,5vw,28px)}
.lpage-crumbs{display:flex;gap:8px;align-items:center;font-size:.82rem;color:var(--faint);margin-bottom:16px}
.lpage-crumbs a{color:var(--soft);text-decoration:none;cursor:pointer;transition:.15s}
.lpage-crumbs a:hover{color:var(--accent)}
.lpage h1{font-family:var(--font-display);font-weight:800;font-size:clamp(1.85rem,5.5vw,2.6rem);letter-spacing:-.02em;line-height:1.1;color:var(--ink);margin-bottom:20px}
.lpage-body{font-size:1.02rem;line-height:1.75;color:var(--soft)}
.lpage-body .lpage-lead{font-size:1.12rem;line-height:1.65;color:var(--ink);margin:0 0 10px}
.lpage-body h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.22rem,3.5vw,1.5rem);letter-spacing:-.01em;color:var(--ink);margin:32px 0 12px}
.lpage-body p{margin:0 0 16px}
.lpage-body ul{margin:0 0 16px;padding-left:20px;display:flex;flex-direction:column;gap:9px}
.lpage-body li{line-height:1.6}
.lpage-body strong{color:var(--ink);font-weight:700}
.lpage-body a{color:var(--accent);text-decoration:none;border-bottom:1px solid var(--accent-soft);cursor:pointer;transition:.15s}
.lpage-body a:hover{border-bottom-color:var(--accent)}
.lpage-body .lpage-muted{color:var(--faint)}
.lpage-body .lpage-note{font-size:.86rem;color:var(--faint);margin-top:26px;padding-top:16px;border-top:1px solid var(--line)}
.lpage-empty{padding:18px 0}
.lfoot-slim .lfoot-bottom{border-top:none}
