/* =========================
   QuarterlyBot — Desktop CSS (≥861px)
   Полный десктоп без "base"
   ========================= */

/* -------- Tokens / Resets -------- */
:root{
  --bg:#0a0f16;
  --bg2:#0b1220;
  --text:#e9eefc;
  --muted:#9aa4b2;
  --ring:rgba(255,255,255,.08);
  --accent:#8ea2ff;
  --good:#37d080;
  --grad:linear-gradient(90deg,#aab7ff,#ff4ecd,#ffb800,#aab7ff);
  --surface: rgba(255,255,255,.03);
  --surface-2: rgba(255,255,255,.06);
}

*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}

body{
  margin:0;
  color:var(--text);
  font:16px/1.55 Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;
  background:
    radial-gradient(1200px 800px at 70% 12%, #131b2e 0%, #0a0f16 55%),
    linear-gradient(180deg, #0b1220, #0a0f16);
}

a{color:inherit;text-decoration:none}

.wrap{max-width:1200px;margin:0 auto;padding:24px}

/* -------- NAV -------- */
.nav{display:flex;align-items:center;gap:16px;flex-wrap:wrap}

.brand{display:flex;align-items:center;gap:10px;font-weight:800}
.brand .avatarWrap{
  position:relative;width:28px;height:28px;flex:0 0 28px;border-radius:50%;
  overflow:hidden;box-shadow:0 2px 10px rgba(0,0,0,.35);
  background: radial-gradient(80% 80% at 30% 20%, #1a2440 0%, #0d1528 100%);
  border:1.5px solid rgba(255,255,255,.22);
}
.brand .avatar{width:100%;height:100%;object-fit:cover;object-position:center 35%;display:block}
.brand .avatarFallback{
  position:absolute;inset:0;display:none;place-items:center;
  font-weight:800;color:#e9eefc;font-size:12px;letter-spacing:.3px
}

.menu{
  display:flex;gap:22px;color:var(--muted);font-weight:600;
  margin-left:auto;align-items:center
}
.menu a{position:relative;opacity:.9;transition:opacity .2s, color .2s}
.menu a::after{
  content:"";position:absolute;left:0;right:100%;bottom:-6px;height:2px;
  background:linear-gradient(90deg,#8ea2ff,#37d080);
  transition:right .45s cubic-bezier(.2,.7,.2,1), opacity .3s;opacity:0;border-radius:2px;
}
.menu a:hover{opacity:1}
.menu a.active{color:#fff;opacity:1;text-shadow:0 0 10px rgba(142,162,255,.35)}
.menu a.active::after{right:0;opacity:1}

.navActions{display:flex;gap:12px;align-items:center}

/* -------- Dropdowns -------- */
.dropdown{position:relative}
.dropbtn{
  padding:8px 12px;border-radius:10px;border:1px solid var(--ring);
  background:rgba(255,255,255,.04);color:#e9eefc;font-weight:700;cursor:pointer;list-style:none
}
/* скрываем маркер summary */
details.dropdown > summary::-webkit-details-marker{display:none}
details.dropdown > summary::marker{content:""}

.dropdown[open] .dropbtn{box-shadow:0 0 0 1px rgba(142,162,255,.25) inset}
.dropdown[aria-expanded="true"] .dropbtn{box-shadow:0 0 0 1px rgba(142,162,255,.25) inset}

/* ВАЖНО: видимость меню */
.dropdown > .dropdown-menu{display:none}
.dropdown[open] > .dropdown-menu,
.dropdown[aria-expanded="true"] > .dropdown-menu{display:block}

.dropdown-menu{
  position:absolute;right:0;top:calc(100% + 8px);min-width:220px;z-index:40;
  border:1px solid var(--ring);border-radius:12px;background:rgba(11,19,32,.98);
  box-shadow:0 16px 40px rgba(0,0,0,.35);padding:8px
}
/* соцменю поверх */
#socialDd > .dropdown-menu{z-index:60}

.dropdown-menu a{
  display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;color:#e9eefc
}
.dropdown-menu a:hover{background:rgba(255,255,255,.06)}

/* CTA */
.cta{
  padding:10px 16px;border-radius:12px;border:1px solid var(--ring);
  background:rgba(255,255,255,.03);cursor:pointer;font-weight:800
}
.gtext{
  background:var(--grad);background-size:300% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:shimmer 6s linear infinite;
}
@keyframes shimmer{to{background-position:300% 0}}

/* -------- HERO -------- */
.hero{
  display:grid;grid-template-columns:1fr;gap:12px;align-items:center;
  min-height:42vh;text-align:center
}
.kicker{color:var(--muted);font-size:12px}
.kicker.thin{
  font-weight:300;font-size:clamp(19px,2.5vw,27px);letter-spacing:.01em;color:#e9eefc;opacity:.98;
}
h1{margin:.15em 0 .2em;font-size:clamp(28px,5.6vw,54px);line-height:1.06}
.lead{color:#cbd3e4;max-width:64ch;margin:0 auto}
.actions{margin-top:18px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn{
  padding:12px 16px;border-radius:12px;border:1px solid var(--ring);
  background:rgba(255,255,255,.04);font-weight:700;cursor:pointer;
  display:inline-flex;align-items:center;gap:6px;color:#fff;
}

/* -------- SECTIONS -------- */
section{padding:56px 0; scroll-margin-top:22px}
h2{margin:0 0 .6em;font-size:clamp(22px,3.2vw,32px)}
.muted{color:#9aa4b2;font-size:14px}
.tiny{font-size:12px;opacity:.9}

/* -------- Flip-карточки -------- */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.flip{perspective:1000px}
.flip-inner{
  position:relative;width:100%;height:210px;border-radius:16px;
  transform-style:preserve-3d;transition:transform .7s cubic-bezier(.2,.7,.2,1)
}
.flip:hover .flip-inner,
.flip:focus-within .flip-inner,
.flip.touched .flip-inner{transform:rotateY(180deg)}

.face{
  position:absolute;inset:0;padding:16px;border-radius:16px;border:1px solid var(--ring);
  backface-visibility:hidden;background:rgba(255,255,255,.03);overflow:hidden
}
.back{transform:rotateY(180deg)}
.face h3{margin:.15em 0 .4em;font-size:18px}

/* мини-холст + картинка */
.kv-canvas{
  position:relative;display:block;aspect-ratio:16/7;min-height:96px;margin-top:0;
  border-radius:12px;overflow:hidden;background:transparent;border:0;
}
.kv-img{
  position:absolute;inset:0;display:block;width:100%;height:100%;
  object-fit:contain;padding:8px 10px;max-width:100%;max-height:100%;
}

/* скрываем декоративные элементы из старого демо */
.kv-lines{display:none !important}
.kv-badge{display:none !important}
.face .tag{display:none !important;}

.pill{
  display:inline-block;padding:2px 8px;border:1px solid var(--ring);
  border-radius:999px;background:rgba(255,255,255,.05);font-size:12px;
  color:#cbd3e4;margin-right:6px;white-space:nowrap
}
.hint{margin-top:8px;color:#cbd3e4}

/* -------- Flow-Factory -------- */
.ff-top{display:flex;align-items:center;gap:12px;justify-content:space-between;margin:.2rem 0 12px}
.infocard{
  position:relative;margin:8px 0 14px;padding:14px 16px;border-radius:12px;
  border:1px solid var(--ring);
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.03));
  box-shadow:0 12px 38px rgba(0,0,0,.28)
}
.infocard.compact .tiny{font-size:12px}
.infocard[hidden]{display:none}

.factory{
  position:relative;border:1px solid var(--ring);border-radius:16px;
  background:var(--surface);padding:16px;box-shadow:0 10px 40px rgba(0,0,0,.2)
}
.demo__controls{display:flex;gap:8px;flex-wrap:wrap}
.pillBtn{
  display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:999px;
  border:1px solid var(--ring);background:rgba(255,255,255,.04);
  font-size:12px;color:#cbd3e4;cursor:pointer
}
.pillBtn.is-active{border-color:var(--accent);box-shadow:0 0 0 1px rgba(142,162,255,.25) inset}

#factoryCanvas{
  width:100%;height:460px;display:block;border-radius:12px;background:#0b1320;border:1px solid var(--ring)
}
.factory__status{
  position:absolute;right:22px;bottom:22px;padding:8px 10px;border-radius:10px;
  background:var(--surface-2);border:1px solid var(--ring);font-weight:800
}
.factory__legend{display:flex;gap:12px;align-items:center;margin-top:10px;color:#cbd3e4}
.dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:6px;border:1px solid var(--ring)}
.dot--pine{background:#34d399}.dot--ml{background:#8ea2ff}.dot--rl{background:#f59e0b}

/* Значок внимания */
.attn{
  display:inline-grid;place-items:center;width:22px;height:22px;margin-left:8px;border-radius:999px;
  border:1px solid rgba(255,184,0,.45);background:transparent;color:#ffcc33;font-weight:900;cursor:pointer;
  box-shadow:0 0 0 2px rgba(255,184,0,.12) inset, 0 0 18px rgba(0,0,0,.18);
  transition:transform .15s ease, box-shadow .25s ease;
}
.attn:hover{
  transform:scale(1.07);
  box-shadow:0 0 0 2px rgba(255,184,0,.16) inset, 0 0 22px rgba(0,0,0,.24);
}
.attn::after{content:"!";font-size:15px;line-height:1;animation:attnBlink 1.6s ease-in-out infinite}
@keyframes attnBlink{0%,100%{opacity:.45;transform:translateY(0)}50%{opacity:1;transform:translateY(-1px)}}

/* -------- Roadmap -------- */
.road{margin-top:16px;padding:8px 0}
.rmini{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.stepMini{
  position:relative;padding:14px;border-radius:14px;background:rgba(255,255,255,.03);
  display:flex;align-items:center;justify-content:center;text-align:center;min-height:64px;
  border:1px solid rgba(255,255,255,.06);
  transition:transform .25s, box-shadow .25s, filter .25s;will-change:transform, box-shadow, filter
}
.stepMini:hover{
  transform:translateY(-6px) scale(1.015);
  box-shadow:0 18px 48px rgba(0,0,0,.35);
  filter:drop-shadow(0 6px 16px rgba(142,162,255,.18))
}
.stepMini h4{margin:0;font-size:15px;font-weight:700;letter-spacing:.2px;color:#d6ddf0}
.stepMini.smoke{background:rgba(255,255,255,.02);color:#9aa4b2}
.stepMini.pine{
  color:#0b0f16;background:linear-gradient(135deg,#00d1ff,#7a5cff,#ff4ecd,#ffb800);
  position:relative;overflow:hidden;border:none
}
.stepMini.pine::after{
  content:"";position:absolute;inset:-40%;
  background:conic-gradient(from 0deg,#ffffff20,transparent 35%,#ffffff12 70%,transparent 100%);
  animation:shine 9s linear infinite;mix-blend-mode:overlay;pointer-events:none
}
@keyframes shine{to{transform:rotate(1turn)}}
.stepMini.ml{
  background:linear-gradient(180deg,rgba(142,162,255,.14),rgba(142,162,255,.06));
  border:1px solid rgba(142,162,255,.42);animation:mlpulse 2.6s ease-in-out infinite
}
@keyframes mlpulse{0%,100%{box-shadow:0 0 0 0 rgba(142,162,255,.0)}50%{box-shadow:0 0 32px 6px rgba(142,162,255,.18)}}
.dots{position:absolute;bottom:8px;display:flex;gap:6px}
.dots span{width:6px;height:6px;border-radius:50%;background:#8ea2ff;opacity:.35;animation:dot 1.2s ease-in-out infinite}
.dots span:nth-child(2){animation-delay:.15s}.dots span:nth-child(3){animation-delay:.3s}
@keyframes dot{0%,100%{opacity:.35;transform:translateY(0)}50%{opacity:1;transform:translateY(-3px)}}

/* -------- About -------- */
.about{display:grid;grid-template-columns:1.1fr .9fr;gap:22px;align-items:start}
.card{border:1px solid var(--ring);border-radius:16px;background:rgba(255,255,255,.03);padding:18px}

/* Серебристые переливы */
.silver{
  background: linear-gradient(90deg,#cfd5e3, #f5f7fa 25%, #b7becf 50%, #eef1f5 75%, #c2c9d8);
  background-size: 200% 100%;
  -webkit-background-clip: text; background-clip: text; color: transparent;
  animation: silverShift 12s linear infinite; letter-spacing:.2px;
}
.silver-soft{
  background: linear-gradient(90deg,#d8dee9,#f6f8fb 22%, #c4cbda 50%, #eef1f6 78%, #d1d7e4);
  background-size:180% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation: silverShift 14s linear infinite; opacity:.94;
}
@keyframes silverShift{ to{ background-position: 200% 0; } }

/* -------- Life mosaic -------- */
.mosaic{
  display:grid; gap:12px;
  grid-template-areas: "a b" "a c";
  grid-template-columns: 1.1fr .9fr;
  grid-auto-rows: 160px;
}
.tile{
  position:relative; overflow:hidden; border-radius:14px;
  border:1px solid var(--ring); background:rgba(255,255,255,.04);
  box-shadow:0 10px 28px rgba(0,0,0,.25); cursor:pointer;
  transform:rotate(var(--tilt,0deg)) translateZ(0);
  transition:transform .28s ease, box-shadow .28s ease, filter .28s ease;
}
.tile:hover{
  transform:rotate(0deg) scale(1.02);
  box-shadow:0 18px 44px rgba(0,0,0,.38);
  filter:saturate(1.06) contrast(1.02)
}
.tile img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1.02)}
.tile::before{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.00), rgba(0,0,0,.25) 100%); pointer-events:none;
}
.tile .chip{
  position:absolute; left:10px; bottom:10px; padding:4px 8px; font-size:12px; color:#e9eefc;
  border-radius:999px; background:rgba(0,0,0,.42); border:1px solid rgba(255,255,255,.18);
}
.tile.a{grid-area:a; --tilt:-2.5deg; height:332px}
.tile.b{grid-area:b; --tilt:1.8deg}
.tile.c{grid-area:c; --tilt:-1deg}

/* -------- Lightbox -------- */
.lb{
  position:fixed; inset:0; display:none; place-items:center;
  background:rgba(3,7,18,.85); z-index:1000
}
.lb[aria-hidden="false"]{display:grid}
.lb__img{
  max-width:92vw; max-height:88vh; border-radius:12px;
  border:1px solid rgba(255,255,255,.18); box-shadow:0 24px 80px rgba(0,0,0,.55)
}
.lb__close, .lb__nav{
  position:absolute; display:grid; place-items:center; width:40px; height:40px;
  border-radius:10px; border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.06); color:#fff; font-weight:900; cursor:pointer
}
.lb__close{top:24px; right:24px}
.lb__nav{top:50%; transform:translateY(-50%)}
.lb__nav.prev{left:24px}
.lb__nav.next{right:24px}

/* -------- Waitlist -------- */
.wl{display:grid;grid-template-columns:1.1fr .9fr;gap:22px;align-items:start}
.form{background:rgba(255,255,255,.03);border:1px solid var(--ring);border-radius:16px;padding:18px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:12px}
label{display:block;font-size:13px;color:#9aa4b2;margin-bottom:6px}
input[type="text"],input[type="email"]{
  width:100%;padding:12px 12px;border-radius:10px;
  border:1px solid rgba(255,255,255,.12);background:#0a0f16;color:var(--text)
}
.checkrow{display:flex;gap:12px;align-items:flex-start;margin-top:10px}
.checkrow label{margin:0}
.ok{display:none;margin-top:10px;color:#b2f5b4}
button[type="submit"]{
  padding:10px 14px;border-radius:12px;border:1px solid var(--ring);
  background:rgba(255,255,255,.06);color:#fff;font-weight:800;cursor:pointer
}

/* -------- Reveal on scroll (CSS side) -------- */
.reveal{opacity:0;transform:translateY(18px);transition:.6s ease}
.reveal.show{opacity:1;transform:none}

/* -------- Accessibility -------- */
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0
}

/* -------- Prefers-reduced-motion -------- */
@media (prefers-reduced-motion: reduce){
  .gtext{animation:none}
  .stepMini.pine::after{animation:none}
  .stepMini.ml{animation:none}
}

/* -------- Narrow desktop breakpoints -------- */
/* ≤1100px: сетки упрощаются */
@media (max-width:1100px){
  .grid{grid-template-columns:repeat(2,1fr)}
  .rmini{grid-template-columns:repeat(3,1fr)}
}

/* ≤900px: двухколоночные блоки становятся 1-колоночными (всё ещё ≥861px) */
@media (max-width:900px){
  .about,.wl{grid-template-columns:1fr}
  .tile.a{height:240px}
}

/* ===== Mobile/Lite vs Desktop/Canvas routing ===== */
@media (max-width:860px){
  #mFactoryLite, .mfactory{ display:block !important; }
  #factoryCanvas,
  #factoryOut,
  .factory__status,
  .factory__legend{ display:none !important; }
  #factoryCanvas{
    pointer-events:none !important;
    height:clamp(160px, 46vw, 280px) !important;
    border-width:2px !important;
  }
  .demo__controls{ position:relative; z-index:2; }
  .factory .trashIcon{
    position:absolute !important;
    right:8px !important;
    bottom:8px !important;
    top:auto !important;
    z-index:2;
  }
}

/* Десктоп (≥861px): показываем канвас, прячем Lite */
@media (min-width:861px){
  #mFactoryLite, .mfactory{ display:none !important; }
  #factoryCanvas{ display:block !important; }
}

/* =======================================================
   DESKTOP FACTORY — ON by default
   ======================================================= */
body.no-desktop-factory #factoryOut,
body.no-desktop-factory .factory__status,
body.no-desktop-factory .factory__legend{ display:none !important; }

body.no-desktop-factory #factoryCanvas{
  display:none !important;
  height:0 !important;
  min-height:0 !important;
  border:0 !important;
  padding:0 !important;
  background:transparent !important;
  pointer-events:none !important;
}

body.no-desktop-factory .factory{
  padding:0 !important;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
}

body.no-desktop-factory .factory .demo__controls{ display:none !important; }
/* === LOCK: одинаковый вид на любых больших экранах === */
@media (min-width: 861px){
  .wrap{ max-width:1200px; }
  .grid{ grid-template-columns: repeat(3, 1fr); }
  #factoryCanvas{ height:460px; }
  h1{ font-size: clamp(28px, 5.6vw, 54px); }
}

/* на сверхшироких — подтверждение «без расширений» */
@media (min-width: 1440px){
  .wrap{ max-width:1200px; }
  .grid{ grid-template-columns: repeat(3, 1fr); }
  #factoryCanvas{ height:460px; }
}
@media (min-width: 1920px){
  .wrap{ max-width:1200px; }
  .grid{ grid-template-columns: repeat(3, 1fr); }
  #factoryCanvas{ height:460px; }
}
@media (min-width: 2560px){
  .wrap{ max-width:1200px; }
  .grid{ grid-template-columns: repeat(3, 1fr); }
  #factoryCanvas{ height:460px; }
}

/* =======================================================
   FAQ — эффектная аккордеон-сетка (только десктоп, только #faq)
   ======================================================= */

@media (min-width:861px){
  section#faq{
    display:grid !important;
    grid-template-columns: 1fr 1fr;
    gap:14px;
  }
  section#faq > #faq-heading{
    grid-column: 1 / -1;
    margin-bottom:4px;
  }
  /* карточки FAQ (details) */
  section#faq details{
    position:relative;
    border:1px solid var(--ring);
    border-radius:14px;
    background:rgba(255,255,255,.03);
    box-shadow:0 10px 28px rgba(0,0,0,.22);
    overflow:hidden;
    transition:
      border-color .25s ease,
      box-shadow .25s ease,
      background .25s ease,
      transform .25s ease;
    will-change:transform, box-shadow, background;
  }
  /* лёгкий hover */
  section#faq details:hover{
    transform:translateY(-2px);
    box-shadow:0 16px 40px rgba(0,0,0,.28);
    border-color:rgba(142,162,255,.22);
  }
  /* свечение при открытии */
  section#faq details[open]{
    background:linear-gradient(180deg,rgba(142,162,255,.10),rgba(255,255,255,.03));
    box-shadow:
      0 18px 48px rgba(0,0,0,.35),
      0 0 0 1px rgba(142,162,255,.20) inset;
    border-color:rgba(142,162,255,.35);
  }
  /* шапка (summary) */
  section#faq summary{
    display:flex;
    align-items:center;
    gap:10px;
    cursor:pointer;
    padding:14px 16px;
    font-weight:800;
    color:#e9eefc;
    list-style:none;
    position:relative;
    user-select:none;
    outline:none;
  }
  /* убираем маркеры браузера */
  section#faq summary::-webkit-details-marker{display:none}
  section#faq summary::marker{content:""}
  /* иконка-стрелка */
  section#faq summary::after{
    content:"›";
    margin-left:auto;
    font-weight:900;
    transform:rotate(0deg) translateZ(0);
    transition:transform .25s ease, opacity .25s ease;
    opacity:.85;
  }
  section#faq details[open] summary::after{
    transform:rotate(90deg);
    opacity:1;
  }
  /* мини-бейдж слева — отключён (перестраховка) */
  section#faq summary::before{content:none !important;display:none !important}

  /* контент ответа */
  section#faq details > *:not(summary){
    padding:0 16px 14px 16px;
  }
  section#faq details p{
    margin:6px 0 0;
    color:#cbd3e4;
  }
  /* аккуратная линия сверху контента */
  section#faq details[open] summary{
    border-bottom:1px solid rgba(255,255,255,.08);
  }
  /* акцентная полоса слева при раскрытии */
  section#faq details::before{
    content:"";
    position:absolute;left:0;top:0;bottom:0;width:0;
    background:linear-gradient(180deg,#8ea2ff,#37d080);
    opacity:.85;transition:width .3s ease; border-top-left-radius:14px; border-bottom-left-radius:14px;
  }
  section#faq details[open]::before{ width:3px; }

  /* адаптация сетки FAQ на узком десктопе */
  @media (max-width:1100px){
    section#faq{ grid-template-columns:1fr; }
  }
}

@keyframes faqFade{
  from{opacity:0;transform:translateY(-4px)}
  to{opacity:1;transform:none}
}

/* prefers-reduced-motion уважение в FAQ */
@media (prefers-reduced-motion: reduce){
  section#faq details,
  section#faq summary::after{ transition:none }
  section#faq details[open] > :not(summary){ animation:none }
}