/* AI Site Builder — тёмная дизайн-система «sourceAI» (фиолетовый акцент + glow, моно-акценты). */
:root{
  /* фоны */
  --bg:#08080c; --card:#0d0d14; --surface-2:#0e0e16; --input-bg:#0a0a10; --popover:#12121a;
  /* границы (всегда полупрозрачный белый) */
  --line:rgba(255,255,255,.09); --line-soft:rgba(255,255,255,.06); --line-strong:rgba(255,255,255,.16);
  /* текст */
  --ink:#ececf0; --muted:#b6b6c2; --dim:#9a9aa8; --faint:#9a9aac;
  /* акцент */
  --accent:#7c6bff; --accent2:#54e0c7; --glow:rgba(124,107,255,.35); --ok:#41d995; --danger:#ff7a7a; --star:#f5b942; --cost:#f0a868;
  --radius:16px; --shadow:0 24px 60px -30px rgba(0,0,0,.8);
  --font:'Manrope',system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
  --head:'Space Grotesk',var(--font); --mono:'IBM Plex Mono',ui-monospace,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
html{scroll-behavior:smooth}
body{background:radial-gradient(circle at 1px 1px,rgba(255,255,255,.03) 1px,transparent 0) 0 0/24px 24px,var(--bg);color:var(--ink);font:15px/1.55 var(--font);-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:var(--head);letter-spacing:-.02em}
button{font:inherit;cursor:pointer}
a{color:var(--accent);text-decoration:none}
a:hover{color:#fff}
input,textarea,select{font:inherit}
::selection{background:var(--accent);color:#08080c}
::placeholder{color:var(--faint)}
/* видимый фокус для клавиатуры/скринридера (бирюза, чтобы не сливалась с фиолетовыми кнопками) */
:where(button,a,select,input,textarea,[tabindex]):focus-visible{outline:2px solid var(--accent2);outline-offset:2px;border-radius:8px}

/* layout */
.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:14px;padding:13px 24px;background:rgba(8,8,12,.72);backdrop-filter:blur(14px);border-bottom:1px solid var(--line-soft)}
.brand{display:flex;align-items:center;gap:10px;cursor:pointer}
.logo-mark{width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;box-shadow:0 0 22px var(--glow);flex:none}
.logo-mark i{width:11px;height:11px;background:var(--bg);transform:rotate(45deg);border-radius:2px;display:block}
.logo-text{font-family:var(--head);font-weight:700;font-size:19px;letter-spacing:-.01em;color:var(--ink)}
.logo-text span{color:var(--accent)}
.spacer{flex:1}
.nav{display:flex;gap:4px}
.nav button{background:transparent;border:0;color:var(--muted);padding:8px 13px;border-radius:10px;font-weight:600}
.nav button:hover{background:rgba(255,255,255,.05);color:#fff}
.nav button.active{background:rgba(124,107,255,.18);color:#fff}
.pill{font-family:var(--mono);font-size:12px;font-weight:500;padding:5px 11px;border-radius:999px;background:rgba(255,255,255,.04);border:1px solid var(--line);color:var(--accent)}
/* кастомный дропдаун языка (тёмный, открывается вниз) */
.langdd{position:relative}
.langbtn{display:inline-flex;align-items:center;gap:7px;appearance:none;border:1px solid var(--line-strong);background:var(--input-bg);color:var(--ink);border-radius:10px;padding:7px 11px;font:inherit;font-size:13px;line-height:1.2;cursor:pointer}
.langbtn::after{content:"▾";color:var(--dim);font-size:11px}
.langbtn:hover{border-color:rgba(255,255,255,.28)}
.langbtn:focus-visible{outline:2px solid var(--accent2);outline-offset:2px}
.langmenu{display:none;position:absolute;top:calc(100% + 6px);right:0;min-width:172px;background:var(--popover);border:1px solid var(--line-strong);border-radius:12px;padding:6px;z-index:90;box-shadow:var(--shadow)}
.langmenu.open{display:block}
.langmenu button{display:flex;align-items:center;justify-content:space-between;gap:14px;width:100%;text-align:left;background:transparent;border:0;color:var(--ink);border-radius:8px;padding:9px 11px;font:inherit;font-size:14px;cursor:pointer}
.langmenu button:hover{background:rgba(255,255,255,.06)}
.langmenu button[aria-current="true"]{color:var(--accent2);font-weight:600}
.langmenu button[aria-current="true"]::after{content:"✓";font-size:12px}

.wrap{max-width:1000px;margin:0 auto;padding:32px 24px 90px}
.wide{max-width:1200px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line-strong);background:transparent;color:var(--ink);padding:10px 16px;border-radius:11px;font-weight:700}
.btn:hover{border-color:rgba(255,255,255,.28);background:rgba(255,255,255,.03)}
.btn.primary{background:var(--accent);border:0;color:#08080c;box-shadow:0 8px 26px var(--glow)}
.btn.primary:hover{filter:brightness(1.1);transform:translateY(-1px)}
.btn.ghost{background:transparent;border:1px solid var(--line-strong);color:var(--muted)}
.btn.ghost:hover{color:#fff;border-color:rgba(255,255,255,.28)}
.btn.danger{color:var(--danger);border-color:rgba(255,122,122,.4)}
.btn.on{background:var(--accent);border-color:var(--accent);color:#08080c}
.btn:disabled{opacity:.45;cursor:not-allowed}
.btn.lg{padding:14px 22px;font-size:16px;border-radius:13px}

/* cards / auth */
.card{background:linear-gradient(180deg,rgba(255,255,255,.025),transparent),var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px}
.center{min-height:84vh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative;overflow:hidden}
/* Фирменный фон auth-экранов (вход/реєстрація/сброс/код) — приём из hero лендинга: маскированная сетка
   + пульсирующее свечение. .center используют ТОЛЬКО эти экраны. */
.center::before{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);
  background-size:58px 58px;
  -webkit-mask-image:radial-gradient(ellipse 92% 70% at 50% 6%,#000 36%,transparent 78%);
  mask-image:radial-gradient(ellipse 92% 70% at 50% 6%,#000 36%,transparent 78%)}
.center::after{content:"";position:absolute;top:38%;left:50%;transform:translate(-50%,-50%);z-index:-1;pointer-events:none;
  width:820px;height:620px;max-width:130vw;
  background:radial-gradient(circle at 50% 38%,rgba(124,107,255,.5),transparent 58%),radial-gradient(480px 340px at 76% 90%,rgba(84,224,199,.16),transparent 70%);
  filter:blur(46px);opacity:.72;animation:pulseGlow 7s ease-in-out infinite}
@media(prefers-reduced-motion:reduce){.center::after{animation:none}}
/* Декор auth-фона: «строка-промпт печатается → собирается мини-сайт» (НАД карточкой, за ней по z-index) */
.ad-wrap{position:absolute;left:50%;top:7%;transform:translateX(-50%);z-index:-1;pointer-events:none;opacity:.6;
  display:flex;align-items:center;justify-content:center;gap:16px;width:min(500px,92vw)}
.ad-prompt{flex:1;min-width:0;font-family:var(--mono);font-size:12.5px;color:var(--muted);border:1px solid var(--line);
  background:rgba(255,255,255,.03);border-radius:10px;padding:10px 13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ad-spark{color:var(--accent2)}
.ad-type::after{content:"▌";color:var(--accent2);animation:adCaret 1s step-end infinite}
@keyframes adCaret{50%{opacity:0}}
.ad-site{flex:none;width:124px;height:84px;border:1px solid var(--line);border-radius:10px;background:rgba(255,255,255,.025);
  padding:9px;display:flex;flex-direction:column;gap:6px}
.ad-site>span{display:block;border-radius:4px;background:rgba(124,107,255,.22);opacity:0;transform:translateY(6px)}
.ad-bar{height:6px;width:40%}
.ad-hero{height:26px;width:100%;background:rgba(84,224,199,.20)!important}
.ad-row{height:6px;width:84%}
.ad-row.s{width:58%}
.ad-site.built>span{animation:adBlock .5s cubic-bezier(.2,.8,.3,1) forwards}
.ad-site.built>span:nth-child(2){animation-delay:.1s}
.ad-site.built>span:nth-child(3){animation-delay:.2s}
.ad-site.built>span:nth-child(4){animation-delay:.3s}
@keyframes adBlock{to{opacity:1;transform:none}}
@media(max-width:620px),(max-height:760px){.ad-wrap{display:none}} /* не наезжаем на карточку на средних/низких окнах */
@media(max-width:760px){.ad-site{display:none}} /* на средних — прячем мини-сайт, оставляем только строку-промпт */
@media(prefers-reduced-motion:reduce){.ad-type::after{content:"";animation:none}.ad-site>span{opacity:1;transform:none}}
.auth{width:100%;max-width:410px}
.auth h1{margin:0 0 6px;font-size:27px}
.auth p.sub{margin:0 0 22px;color:var(--dim)}
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1px solid var(--line-strong);border-radius:11px;background:var(--input-bg);color:var(--ink);outline:none}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(124,107,255,.18)}
.muted{color:var(--muted)}
.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.linkbtn{background:none;border:0;color:var(--accent);font-weight:700;padding:6px 4px}
.linkbtn:hover{color:#fff}
.linkbtn:disabled{opacity:.5;cursor:not-allowed}
/* инлайн-ошибка под полем (экран кода) */
.fielderr{min-height:18px;margin-top:8px;color:var(--danger);font-size:13px;font-weight:600}
.field input.bad{border-color:var(--danger);box-shadow:0 0 0 3px rgba(255,122,122,.16)}

/* new-site hero */
.hero{text-align:center;padding:40px 0 8px;position:relative}
/* мягкие радиальные glow-блобы за hero (фиолет + бирюза) — глубина, как в sourceAI */
.hero::before{content:"";position:absolute;inset:-30px 0 auto;height:340px;z-index:-1;pointer-events:none;
  background:radial-gradient(420px 200px at 32% 18%,rgba(124,107,255,.18),transparent 70%),radial-gradient(360px 180px at 74% 30%,rgba(84,224,199,.1),transparent 70%)}
.eyebrow{display:block;font-family:var(--mono);font-size:12.5px;letter-spacing:.08em;color:var(--accent);text-transform:uppercase;margin-bottom:10px}
.hero h1{font-size:clamp(32px,5vw,52px);line-height:1.06;margin:0 0 10px;text-wrap:balance}
.hero h1 .grad{background:linear-gradient(120deg,var(--accent),var(--accent2));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p{color:var(--dim);font-size:18px;margin:0 auto 26px;max-width:600px;text-wrap:pretty}
.promptbox{position:relative;max-width:680px;margin:0 auto;background:var(--surface-2);border:1px solid var(--line-strong);border-radius:18px;padding:8px;box-shadow:var(--shadow),0 0 0 1px rgba(124,107,255,.06)}
.promptbox textarea{width:100%;min-height:130px;padding:14px;font-size:17px;border:0;border-radius:14px;resize:vertical;background:transparent;color:var(--ink);outline:none}
.examples{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin:16px 0}
.examples button{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:999px;padding:8px 15px;color:var(--muted);font-weight:600}
.examples button:hover{border-color:var(--accent);color:#fff}
.genrow{display:flex;gap:12px;align-items:center;justify-content:center;margin-top:10px;flex-wrap:wrap}

/* загрузка изображений */
.uploader{max-width:680px;margin:14px auto 0;display:flex;align-items:center;gap:12px;flex-wrap:wrap;border:1px dashed transparent;border-radius:14px;transition:border-color .15s,background .15s;padding:6px}
.uploader.drop{border-color:var(--accent);background:rgba(124,107,255,.08)}
.uploader .muted{font-size:13px}
.thumbs{display:flex;gap:10px;flex-wrap:wrap;width:100%;margin-top:4px}
.thumb{position:relative;width:108px;border:1px solid var(--line-strong);border-radius:12px;background:var(--surface-2);padding:6px;display:flex;flex-direction:column;gap:6px}
.thumb img{width:100%;height:70px;object-fit:cover;border-radius:8px;background:#0c0c12}
.thumb.pending{align-items:center;justify-content:center;height:108px;color:var(--muted)}
.thumb .thumbname{font-size:11px;color:var(--muted);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}
.thumb .thumbtag{width:100%;padding:6px 8px;font-size:13px;border:1px solid var(--line);border-radius:8px;background:var(--input-bg);color:var(--ink);outline:none}
.thumb .thumbdel{position:absolute;top:-9px;right:-9px;width:24px;height:24px;border-radius:50%;border:1px solid var(--line-strong);background:var(--card);color:var(--ink);cursor:pointer;font-size:15px;line-height:1;display:flex;align-items:center;justify-content:center}
.thumb .thumbdel:hover{border-color:var(--danger);color:var(--danger)}
@media(max-width:600px){
  .thumb{width:calc(50% - 5px)}
  .thumb img{height:96px}
  .thumb .thumbtag{font-size:14px;padding:9px 8px}
  .thumb .thumbdel{width:30px;height:30px;font-size:17px;top:-10px;right:-10px}
}

/* интейк-вопросы (шаг 2 создания сайта) */
.intake{max-width:680px;margin:0 auto;display:flex;flex-direction:column;gap:18px}
.ifield{background:var(--surface-2);border:1px solid var(--line-strong);border-radius:14px;padding:16px 16px 14px}
.ifield label{display:block;font-size:15px;font-weight:600;color:var(--ink);margin-bottom:10px}
.ichips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.ichip{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:999px;padding:6px 13px;color:var(--muted);font-weight:600;font-size:13px;cursor:pointer}
.ichip:hover{border-color:var(--accent);color:#fff}
.ichip.on{background:var(--accent);border-color:var(--accent);color:#08080c}
/* свотчи выбора цветовой гаммы (single-select) */
.iswatch{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:4px}
.iswatch-btn{display:inline-flex;align-items:center;gap:8px;background:var(--input-bg);border:1.5px solid var(--line-strong);border-radius:11px;padding:7px 12px 7px 8px;color:var(--ink);font:inherit;font-size:13px;font-weight:600;cursor:pointer}
.iswatch-btn:hover{border-color:rgba(255,255,255,.28)}
.iswatch-btn .sw-dot{width:18px;height:18px;border-radius:6px;flex:none;box-shadow:inset 0 0 0 1px rgba(255,255,255,.12)}
.iswatch-btn[aria-checked="true"]{background:rgba(84,224,199,.14);border-color:var(--accent2);box-shadow:0 0 0 1px var(--accent2)}
.ians{width:100%;padding:11px 13px;border:1px solid var(--line-strong);border-radius:10px;background:var(--input-bg);color:var(--ink);outline:none;font-size:15px}
.ians:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(124,107,255,.18)}

/* preview / editor */
.stage{display:flex;flex-direction:column;height:calc(100vh - 58px)}
.toolbar{display:flex;gap:8px;align-items:center;padding:10px 18px;border-bottom:1px solid var(--line);background:var(--card);flex-wrap:wrap}
.aiedit-input{flex:1;min-width:160px;max-width:440px;padding:9px 12px;border:1px solid var(--line-strong);border-radius:10px;background:var(--input-bg);color:var(--ink);outline:none;font-size:14px}
.aiedit-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(124,107,255,.18)}
@media(max-width:600px){.aiedit-input{flex-basis:100%;max-width:none;order:5}}
.frameWrap{flex:1;overflow:auto;background:#050507;display:flex;justify-content:center;padding:18px}
.frameWrap iframe{width:100%;max-width:100%;height:100%;min-height:600px;border:0;background:#fff;border-radius:12px;box-shadow:var(--shadow)}
.frameWrap.mobile iframe{width:390px;max-width:390px}
.spin{width:18px;height:18px;border:3px solid rgba(255,255,255,.14);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}
.overlay{position:fixed;inset:0;background:rgba(8,8,12,.9);backdrop-filter:blur(6px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;z-index:50}
.overlay .big{font-size:20px;font-weight:700;font-family:var(--head)}

/* sites grid */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.sitecard{background:linear-gradient(180deg,rgba(255,255,255,.025),transparent),var(--card);border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:var(--shadow)}
.sitecard h3{margin:0 0 4px;font-size:16px}
.badge{font-family:var(--mono);font-size:11px;font-weight:500;padding:3px 9px;border-radius:6px;border:1px solid var(--line)}
.badge.pub{background:rgba(65,217,149,.12);color:var(--ok);border-color:rgba(65,217,149,.3)}
.badge.draft{background:rgba(255,255,255,.05);color:var(--dim)}
.sitecard .acts{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}

/* plans */
.plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;margin-top:18px}
.plan{position:relative;background:linear-gradient(180deg,rgba(255,255,255,.025),transparent),var(--card);border:1px solid var(--line);border-radius:16px;padding:24px}
.plan.cur{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.plan.featured{border-color:var(--accent);background:linear-gradient(180deg,rgba(124,107,255,.1),var(--card));box-shadow:0 24px 60px -28px var(--glow)}
.plan.featured.cur{box-shadow:0 24px 60px -28px var(--glow),0 0 0 1px var(--accent);outline:1px solid rgba(124,107,255,.5)}
.plan .ribbon{position:absolute;top:-11px;left:24px;background:var(--accent);color:#08080c;font-family:var(--mono);font-size:11px;font-weight:700;padding:4px 10px;border-radius:6px}
.plan h3{margin:0;text-transform:capitalize;font-size:20px}
.plan .price{font-family:var(--head);font-size:30px;font-weight:700;margin:8px 0}
.plan ul{list-style:none;padding:0;margin:14px 0;color:var(--muted);font-size:14px}
.plan li{padding:4px 0}
.plan li.on{color:var(--ink)}
.plan li.off{color:var(--faint);opacity:.75}
.plan .btn{width:100%;justify-content:center;margin-top:6px}

/* toast */
#toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);z-index:99}
.toastmsg{background:var(--popover);border:1px solid var(--line-strong);color:#fff;padding:12px 18px;border-radius:12px;box-shadow:var(--shadow);margin-top:8px;font-weight:600;animation:pop .2s ease}
.toastmsg.err{background:rgba(255,122,122,.15);border-color:rgba(255,122,122,.4);color:#ffd9d9}
.toastmsg.ok{background:rgba(65,217,149,.14);border-color:rgba(65,217,149,.4);color:#c9ffe8}
@keyframes pop{from{opacity:0;transform:translateY(8px)}}

/* ===== Лендинг sourceAI: стили инлайн в renderLanding; здесь только hover/FAQ/glow/адаптив ===== */
@keyframes pulseGlow{0%,100%{opacity:.45}50%{opacity:.85}}
@media(prefers-reduced-motion:reduce){.lp-glow{animation:none!important}}
.lp-hov:hover{color:#fff!important}
.lp-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}
.lp-btnghost:hover{border-color:rgba(255,255,255,.4)!important}
.lp-chip:hover{border-color:var(--accent)!important;color:#fff!important}
.lp-card:hover{transform:translateY(-5px);border-color:rgba(124,107,255,.4)!important}
.lp-fcard:hover{border-color:rgba(124,107,255,.35)!important}
/* адаптив: перекрываем inline-сетки (целимся только в прямых детей section, чтобы не трогать мини-мокапы галереи) */
@media(max-width:1024px){section>div[style*="repeat(4,1fr)"]{grid-template-columns:repeat(2,1fr)!important}}
@media(max-width:820px){section>div[style*="repeat(3,1fr)"]{grid-template-columns:repeat(2,1fr)!important}}
@media(max-width:600px){
  section>div[style*="repeat(4,1fr)"],section>div[style*="repeat(3,1fr)"],section>div[style*="repeat(2,1fr)"]{grid-template-columns:1fr!important}
  .lp-navlinks{display:none!important}
}

/* мобайл */
@media(max-width:600px){
  .topbar{flex-wrap:wrap;gap:8px;padding:10px 14px}
  .topbar .nav{order:3;width:100%;justify-content:space-between}
  .nav button{flex:1;padding:8px 6px}
  .wrap{padding:24px 16px 80px}
  .genrow{flex-direction:column;align-items:stretch}
  .genrow .btn{width:100%;justify-content:center}
  .hero h1{font-size:30px}
}

/* ===== toast с действием ===== */
.toastmsg{display:flex;align-items:center;gap:12px}
.toastact{background:rgba(255,255,255,.14);border:1px solid var(--line-strong);color:#fff;padding:5px 12px;border-radius:8px;font-weight:700;font-size:13px;white-space:nowrap}
.toastact:hover{background:rgba(255,255,255,.24)}

/* ===== прогресс генерации (честный тайминг + этапы + советы) ===== */
.genprog{display:flex;flex-direction:column;align-items:center;gap:14px;max-width:430px;text-align:center;padding:0 20px}
.progbar{width:300px;max-width:80vw;height:8px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}
.progfill{height:100%;width:5%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:999px;transition:width .6s ease}
.genstage{font-weight:600;color:var(--ink)}
.overlay .ovlnote{font-size:13.5px;max-width:350px}
.gentip{font-size:13px;color:var(--dim);min-height:18px}
.gentip .tiplabel{color:var(--accent);font-weight:700}

/* ===== модальные окна (доступные) ===== */
.modalwrap{position:fixed;inset:0;z-index:80;display:flex;align-items:center;justify-content:center;padding:20px}
.modalback{position:absolute;inset:0;background:rgba(4,4,8,.72);backdrop-filter:blur(4px)}
.modalcard{position:relative;width:100%;max-width:460px;max-height:90vh;overflow:auto;background:linear-gradient(180deg,rgba(255,255,255,.03),transparent),var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:26px;animation:pop .2s ease}
.modalcard.wide{max-width:620px}
.modalx{position:absolute;top:12px;right:12px;width:32px;height:32px;border:0;background:transparent;color:var(--dim);font-size:22px;line-height:1;border-radius:8px}
.modalx:hover{background:rgba(255,255,255,.06);color:#fff}
.modaltitle{margin:0 0 12px;font-size:21px;padding-right:28px}
.modalbody{color:var(--muted)}
.modaltext{margin:0 0 14px;color:var(--dim);line-height:1.6}
.modalacts{display:flex;gap:10px;justify-content:flex-end;margin-top:20px;flex-wrap:wrap}
.modalacts .btn{min-width:120px;justify-content:center}
.upglist{list-style:none;padding:0;margin:8px 0 0;display:flex;flex-direction:column;gap:9px;color:var(--ink);font-weight:600}
.upglist li{font-size:14.5px}
.coachlist{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px;color:var(--ink);font-size:15px;line-height:1.5}
.copyrow{display:flex;gap:8px;margin:6px 0 16px}
.copyrow input{flex:1;min-width:0;padding:11px 13px;border:1px solid var(--line-strong);border-radius:10px;background:var(--input-bg);color:var(--ink);font-size:14px;outline:none}
.copyrow input:focus{border-color:var(--accent)}
.sharerow{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.sharebtn{padding:8px 14px;font-size:13px}

/* ===== настройки сайта ===== */
.fieldhint{font-size:12.5px;color:var(--faint);margin-top:6px}
.slugrow{display:flex;align-items:stretch;border:1px solid var(--line-strong);border-radius:11px;overflow:hidden;background:var(--input-bg)}
.slugpre{display:flex;align-items:center;padding:0 10px;background:rgba(255,255,255,.04);color:var(--faint);font-size:12.5px;font-family:var(--mono);white-space:nowrap}
.slugrow input{border:0 !important;background:transparent !important;flex:1;min-width:0;padding:11px 12px;color:var(--ink);outline:none;box-shadow:none !important}
.settingsexport{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:18px;padding-top:18px;border-top:1px solid var(--line)}

/* ===== кастом-домен сайта (секция в настройках) ===== */
.domainbox{display:flex;flex-direction:column;gap:9px}
.domrow{display:flex;gap:8px}
.domrow input{flex:1;min-width:0;padding:11px 13px;border:1px solid var(--line-strong);border-radius:11px;background:var(--input-bg);color:var(--ink);outline:none}
.domhead{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:15px}
.dombadge{font-size:12px;font-weight:700;padding:3px 9px;border-radius:999px;border:1px solid var(--line-strong);white-space:nowrap}
.dombadge.ok{color:var(--accent2);border-color:rgba(84,224,199,.5);background:rgba(84,224,199,.1)}
.dombadge.wait{color:#e8c477;border-color:rgba(232,196,119,.45);background:rgba(232,196,119,.1)}
.dombadge.err{color:#ff8b8b;border-color:rgba(255,139,139,.45);background:rgba(255,139,139,.1)}
.domdns{width:100%;border-collapse:collapse;font-size:12.5px;background:var(--input-bg);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.domdns th{padding:7px 11px;text-align:left;font-size:11px;font-weight:600;color:var(--dim);text-transform:uppercase;letter-spacing:.03em;background:rgba(255,255,255,.03);border-bottom:1px solid var(--line)}
.domdns td{padding:8px 11px;border-top:1px solid var(--line-soft);color:var(--muted)}
.domdns tbody tr:first-child td{border-top:0}
.domdns code{font-family:var(--mono);color:var(--ink);font-size:12px;word-break:break-all}
.domdns #domTarget{cursor:pointer;border-bottom:1px dashed var(--line-strong);padding-bottom:1px}
.domdns #domTarget:hover{color:var(--accent2)}
.domacts{display:flex;gap:8px;margin-top:2px}
@media(max-width:600px){.domrow input{font-size:16px}}

/* ===== статистика (просмотры + заявки) ===== */
.statsbody{min-height:140px}
.statrow{display:flex;align-items:baseline;gap:10px;margin-bottom:8px}
.statbig{font-family:var(--head);font-size:34px;font-weight:700;color:var(--ink)}
.barchart{display:flex;align-items:flex-end;gap:6px;height:120px;padding:8px 0 4px;border-bottom:1px solid var(--line);margin-bottom:6px}
.bar{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;gap:4px}
.barfill{width:70%;min-height:4px;background:linear-gradient(180deg,var(--accent),var(--accent2));border-radius:4px 4px 0 0}
.bar span{font-size:10px;color:var(--faint);font-family:var(--mono)}
.statsh{font-size:16px;margin:18px 0 10px}
.leadlist{display:flex;flex-direction:column;gap:10px;max-height:280px;overflow:auto}
.leadrow{border:1px solid var(--line);border-radius:10px;padding:12px;background:var(--surface-2);font-size:14px;color:var(--ink)}
.leadrow>div{margin:2px 0;word-break:break-word}
.leadmeta{font-size:12px;color:var(--faint);font-family:var(--mono);margin-bottom:6px}

/* ===== пустое состояние + скелетоны ===== */
.empty{text-align:center;padding:56px 20px;max-width:460px;margin:0 auto}
.empty .emptyicon{display:flex;justify-content:center;gap:8px;margin-bottom:18px;transform:scale(1.35);opacity:.92}
.empty h2{font-size:22px;margin:0 0 8px}
.empty p{margin:0 0 22px}
.sitecard.skeleton{pointer-events:none}
.skline{height:12px;border-radius:6px;background:linear-gradient(90deg,rgba(255,255,255,.05),rgba(255,255,255,.12),rgba(255,255,255,.05));background-size:200% 100%;animation:shimmer 1.3s linear infinite;margin:12px 0}
.skline.w40{width:40%}.skline.w60{width:60%}.skline.w80{width:80%}
@keyframes shimmer{to{background-position:-200% 0}}
@media(prefers-reduced-motion:reduce){.skline{animation:none}}
.sitestats{font-size:13px;color:var(--dim);margin-top:8px;font-family:var(--mono)}

/* ===== тарифы: подзаголовок «для кого» + soon ===== */
.plansub{font-size:13px;color:var(--dim);margin:2px 0 0}
.plan li.soon{color:var(--faint)}

/* ===== контекст-промпт на регистрации ===== */
.pendprompt{background:rgba(124,107,255,.1);border:1px solid rgba(124,107,255,.3);border-radius:12px;padding:14px 16px;margin-bottom:18px}
.pendlabel{font-size:13px;color:var(--muted);font-weight:600;margin-bottom:6px}
.pendquote{font-size:14px;color:var(--ink);font-style:italic;line-height:1.5}

/* ===== тултипы (чистый CSS, без библиотек) ===== */
[data-tip]{position:relative}
[data-tip]::after{content:attr(data-tip);position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(4px);background:var(--popover);color:var(--ink);border:1px solid var(--line-strong);border-radius:8px;padding:7px 10px;font-size:12px;font-weight:600;line-height:1.35;width:max-content;max-width:220px;white-space:normal;box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:opacity .15s,transform .15s;z-index:60}
[data-tip]:hover::after,[data-tip]:focus-visible::after{opacity:1;transform:translateX(-50%) translateY(0)}
@media(max-width:760px){[data-tip]::after{display:none}}

/* ===== лендинг: бургер-меню (мобильная навигация) ===== */
.lp-burger{display:none;background:transparent;border:1px solid rgba(255,255,255,.14);color:#ececf0;border-radius:9px;width:38px;height:38px;font-size:18px;cursor:pointer;align-items:center;justify-content:center}
.lp-mobmenu{display:none;position:absolute;top:100%;left:0;right:0;background:#0d0d14;border-bottom:1px solid var(--line);border-top:1px solid var(--line-soft);padding:8px 18px 16px;flex-direction:column;gap:2px;box-shadow:0 24px 40px rgba(0,0,0,.5)}
.lp-mobmenu.open{display:flex}
.lp-mobmenu a{display:block;padding:13px 6px;color:#dcdce4 !important;text-decoration:none;border-bottom:1px solid var(--line-soft);font-size:15px}
.lp-mobmenu a:last-child{border-bottom:0}
@media(max-width:760px){.lp-burger{display:flex}.lp-navlinks{display:none !important}}
@media(max-width:600px){#lpGlobe{display:none}} /* на узких прячем ИИ-перевод 文A, чтобы навбар не ломался (язык-селект + бургер остаются) */

/* ===== overflow-меню тулбара редактора ===== */
.toolmore-wrap{position:relative}
.toolmenu{display:none;position:absolute;top:calc(100% + 6px);right:0;flex-direction:column;gap:4px;background:var(--popover);border:1px solid var(--line-strong);border-radius:12px;padding:8px;box-shadow:var(--shadow);z-index:40;min-width:200px}
.toolmenu.open{display:flex}
.toolmenu .btn{width:100%;justify-content:flex-start;border-color:transparent;background:transparent;font-weight:600}
.toolmenu .btn:hover{background:rgba(255,255,255,.06)}
.toolmenu .btn:disabled{opacity:.4}
@media(max-width:760px){.edhint{display:none}}

/* ===== тултип у крайних кнопок тулбара (не обрезать за краем) ===== */
.toolbar>[data-tip]:last-of-type::after{left:auto;right:0;transform:translateY(4px)}
.toolbar>[data-tip]:last-of-type:hover::after,.toolbar>[data-tip]:last-of-type:focus-visible::after{transform:translateY(0)}
.toolbar>[data-tip]:first-of-type::after{left:0;transform:translateY(4px)}
.toolbar>[data-tip]:first-of-type:hover::after,.toolbar>[data-tip]:first-of-type:focus-visible::after{transform:translateY(0)}

/* ===== значения над столбцами статистики ===== */
.barval{font-size:10px;color:var(--dim);font-family:var(--mono);font-weight:600}
.barday{font-size:10px;color:var(--faint);font-family:var(--mono)}

/* ===== маленькая кнопка + разделитель «или» ===== */
.btn.sm{padding:6px 11px;border-radius:9px;font-size:12.5px;font-weight:600}
.orsep{display:flex;align-items:center;gap:14px;color:var(--faint);font-size:13px;margin:26px auto 4px;max-width:520px}
.orsep::before,.orsep::after{content:"";flex:1;height:1px;background:var(--line)}

/* ===== готовые шаблоны (живое превью) ===== */
.tplgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.tplgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.tplgrid{grid-template-columns:1fr}}
.tpl-card{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--card);transition:transform .2s,border-color .2s}
.tpl-card:hover{transform:translateY(-3px);border-color:var(--line-strong)}
.tpl-chrome{display:flex;align-items:center;gap:6px;padding:10px 13px;border-bottom:1px solid var(--line-soft);background:rgba(255,255,255,.02)}
.tpl-chrome>span{width:9px;height:9px;border-radius:50%;background:#39394a}
.tpl-chrome .tpl-url{margin-left:8px;flex:1;height:15px;border-radius:5px;background:rgba(255,255,255,.05)}
.tpl-thumb{position:relative;width:100%;aspect-ratio:1440/900;overflow:hidden;background:#0e0e16;cursor:pointer}
.tpl-thumb:focus-visible{outline:2px solid var(--accent2);outline-offset:2px}
.tpl-shot{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;opacity:0;transition:opacity .35s ease}
.tpl-shot.ready{opacity:1}
/* iframe-фолбэк (если картинка-превью ещё не сгенерирована): тёмный фон вместо белого + тот же fade */
.tpl-thumb iframe{border:0;display:block;background:#0e0e16;opacity:0;transition:opacity .35s ease}
.tpl-thumb iframe.ready{opacity:1}
.tpl-ovl{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(8,8,12,.0);opacity:0;transition:opacity .2s}
.tpl-thumb:hover .tpl-ovl{opacity:1;background:rgba(8,8,12,.45)}
.tpl-ovl span{background:var(--accent);color:#08080c;font-weight:700;font-size:13px;padding:8px 14px;border-radius:10px;box-shadow:0 8px 24px var(--glow)}
.tpl-body{padding:14px 15px;display:flex;flex-direction:column;gap:10px;flex:1}
.tpl-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.tpl-name{font-weight:600;font-size:15px}
.tpl-cat{font-family:var(--mono);font-size:11px;border:1px solid var(--line-strong);border-radius:6px;padding:3px 8px;white-space:nowrap}
.tpl-desc{margin:0;color:var(--dim);font-size:13px;line-height:1.5;flex:1}
.tpl-use{justify-content:center;color:#08080c!important;border:0}

/* ===== админ-кабинет ===== */
.admin h1{font-size:26px}
.admtabs{display:flex;gap:8px;border-bottom:1px solid var(--line);margin-bottom:22px;flex-wrap:wrap}
.admtab{background:transparent;border:0;color:var(--muted);padding:11px 16px;font-weight:600;font-size:14px;border-bottom:2px solid transparent;margin-bottom:-1px}
.admtab:hover{color:var(--ink)}
.admtab.active{color:var(--ink);border-bottom-color:var(--accent)}
.admgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
.admstat{border:1px solid var(--line);border-radius:14px;padding:18px 18px;background:var(--card)}
.admstatv{font-family:var(--head);font-size:30px;font-weight:700;letter-spacing:-.02em}
.admstatl{color:var(--muted);font-size:13px;margin-top:4px}
.admstatsub{color:var(--faint);font-size:12px;margin-top:8px;font-family:var(--mono)}
.admh{margin:30px 0 12px;font-size:17px}
.admdist{display:flex;flex-direction:column;gap:8px;max-width:360px}
.admdistrow{display:flex;align-items:center;justify-content:space-between;border:1px solid var(--line);border-radius:10px;padding:10px 14px;background:var(--card)}
.planpill{display:inline-block;font-family:var(--mono);font-size:11.5px;text-transform:uppercase;border:1px solid var(--line-strong);border-radius:6px;padding:2px 8px;color:var(--muted)}
.admtablewrap{overflow-x:auto;border:1px solid var(--line);border-radius:14px}
.admtable{width:100%;border-collapse:collapse;font-size:13.5px;min-width:760px}
.admtable th{text-align:left;padding:12px 14px;color:var(--faint);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--line);white-space:nowrap}
.admtable td{padding:12px 14px;border-bottom:1px solid var(--line-soft);vertical-align:top}
.admtable tr:last-child td{border-bottom:0}
.admtable tbody tr:hover{background:rgba(255,255,255,.02)}
.admuemail{font-weight:600;word-break:break-all}
.admmeta{color:var(--faint);font-size:11.5px;margin-top:3px;font-family:var(--mono)}
.admbadge{display:inline-block;background:var(--accent);color:#08080c;font-size:10px;font-weight:700;padding:1px 6px;border-radius:5px;vertical-align:middle}
.admbadge.warn{background:#f5b942}
.admacts{display:flex;gap:7px;flex-wrap:wrap;white-space:nowrap}
.dotok{color:var(--ok)}.dotbad{color:var(--danger)}
.admselect{width:100%;background:var(--input-bg);border:1px solid var(--line-strong);border-radius:10px;color:var(--ink);padding:11px 12px;font:inherit;text-transform:capitalize}
/* ревью-доводка: контраст, акценты карточек, поиск, предупреждение, опасные действия */
.admmeta{color:var(--dim)}
.admstat.ok .admstatv{color:var(--ok)}
.admstat.cost .admstatv{color:var(--cost)}
.admbar{margin-bottom:14px}
.admsearch{width:100%;max-width:340px;background:var(--input-bg);border:1px solid var(--line-strong);border-radius:10px;color:var(--ink);padding:10px 13px;font:inherit;outline:none}
.admsearch:focus{border-color:var(--accent)}
.admwarn{background:rgba(240,168,104,.12);border:1px solid rgba(240,168,104,.4);color:#f0c89a;border-radius:10px;padding:10px 12px;font-size:13px;margin:0 0 12px}
.admbadge.warn{background:var(--star);color:#08080c}
.btn.danger:hover{background:rgba(255,122,122,.12);border-color:rgba(255,122,122,.55)}
.admtablewrap{position:relative}
@media(max-width:620px){.admtablewrap::after{content:"";position:absolute;top:0;right:0;bottom:0;width:26px;background:linear-gradient(90deg,transparent,var(--bg));pointer-events:none}}

/* ===== шаблоны: скелет загрузки превью + постоянный аффорданс ===== */
.tpl-skel{position:absolute;inset:0;z-index:2;background:linear-gradient(90deg,#0e0e16,#15151f,#0e0e16);background-size:200% 100%;animation:shimmer 1.3s linear infinite;transition:opacity .35s}
.tpl-skel.hide{opacity:0;pointer-events:none}
.tpl-peek{position:absolute;top:10px;right:10px;z-index:3;width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:rgba(8,8,12,.62);color:#fff;font-size:14px;font-weight:700;backdrop-filter:blur(4px);pointer-events:none}
@media(prefers-reduced-motion:reduce){.tpl-skel{animation:none}.tpl-shot,.tpl-thumb iframe{transition:none}}
.tplnote{margin:14px 0 0;font-size:13px}
.tpl-card.skeleton{pointer-events:none}
.tplskel-thumb{aspect-ratio:16/10;background:linear-gradient(90deg,rgba(255,255,255,.05),rgba(255,255,255,.12),rgba(255,255,255,.05));background-size:200% 100%;animation:shimmer 1.3s linear infinite}
.tplskel-body{padding:14px 15px}
