:root{
  --tg:#229ED9;
  --tg-bright:#2BB0EE;
  --tg-dark:#1B86BC;
  --tg-deep:#0C6390;
  --ink:#0E2330;
  --ink-soft:#36505F;
  --muted:#6B8696;
  --bg:#EAF3F9;
  --bg-2:#F4F9FC;
  --surface:#FFFFFF;
  --line:rgba(14,35,48,.09);
  --line-2:rgba(14,35,48,.06);
  --yt:#FF0033;
  --shadow-sm:0 1px 2px rgba(14,35,48,.05), 0 2px 6px rgba(14,35,48,.04);
  --shadow-md:0 2px 4px rgba(14,35,48,.05), 0 14px 30px -12px rgba(20,90,130,.22);
  --shadow-lg:0 4px 8px rgba(14,35,48,.06), 0 34px 60px -24px rgba(20,90,130,.34);
  --shadow-blue:0 18px 40px -16px rgba(34,158,217,.55);
  --r-sm:14px; --r:20px; --r-lg:28px; --r-xl:36px;
  --maxw:1160px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:"Onest",system-ui,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
/* page texture */
body::before{
  content:"";
  position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(1100px 700px at 85% -10%, rgba(43,176,238,.20), transparent 60%),
    radial-gradient(900px 600px at -10% 8%, rgba(34,158,217,.12), transparent 55%),
    linear-gradient(180deg,#F4F9FC 0%, var(--bg) 38%, var(--bg) 100%);
}
body::after{
  content:"";
  position:fixed;inset:0;z-index:-1;
  background-image:radial-gradient(rgba(14,35,48,.05) 1px, transparent 1.4px);
  background-size:26px 26px;
  -webkit-mask-image:linear-gradient(180deg,#000,transparent 70%);
  mask-image:linear-gradient(180deg,#000,transparent 70%);
  opacity:.5;
  pointer-events:none;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:"Rubik",sans-serif;line-height:1.06;letter-spacing:-.02em;font-weight:700}

.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:20px}

/* ---------- Buttons ---------- */
.btn{
  --pad:15px 24px;
  display:inline-flex;align-items:center;gap:10px;
  font-family:"Onest",sans-serif;font-weight:600;font-size:16px;
  padding:var(--pad);border-radius:999px;border:1px solid transparent;
  cursor:pointer;line-height:1;white-space:nowrap;
  transition:transform .18s cubic-bezier(.2,.7,.2,1), box-shadow .22s, background .2s, color .2s;
  will-change:transform;
}
.btn:focus-visible{outline:3px solid rgba(34,158,217,.5);outline-offset:3px}
.btn-tg{
  color:#fff;
  background:linear-gradient(180deg,var(--tg-bright),var(--tg));
  box-shadow:var(--shadow-blue), inset 0 1px 0 rgba(255,255,255,.45);
}
.btn-tg:hover{transform:translateY(-2px);box-shadow:0 24px 48px -16px rgba(34,158,217,.7), inset 0 1px 0 rgba(255,255,255,.45);background:linear-gradient(180deg,#39b8f0,var(--tg-dark))}
.btn-tg:active{transform:translateY(0) scale(.985)}
.btn-tg svg{flex:none}
.btn-lg{--pad:19px 34px;font-size:18px}
.btn-ghost{
  background:var(--surface);color:var(--ink);border-color:var(--line);
  box-shadow:var(--shadow-sm);
}
.btn-ghost:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:rgba(34,158,217,.4)}
.btn-ghost:active{transform:translateY(0)}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  background:rgba(244,249,252,.72);
  border-bottom:1px solid transparent;
  transition:border-color .25s, background .25s, box-shadow .25s;
}
.site-header.scrolled{border-bottom-color:var(--line-2);box-shadow:0 6px 24px -16px rgba(20,90,130,.4);background:rgba(244,249,252,.86)}
.hdr-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:11px;font-family:"Rubik",sans-serif;font-weight:700;font-size:21px;letter-spacing:-.02em;color:var(--ink)}
.brand-mark{
  width:40px;height:40px;border-radius:12px;flex:none;overflow:hidden;
  display:grid;place-items:center;
  background:linear-gradient(150deg,rgba(43,176,238,.16),rgba(27,134,188,.12));
  box-shadow:inset 0 0 0 1px rgba(34,158,217,.2);
}
.brand-mark img{width:100%;height:100%;object-fit:contain}
.brand b{font-weight:700}
.brand span{color:var(--tg-dark)}

/* ---------- Hero ---------- */
.hero{position:relative;padding:54px 0 40px}
.hero-grid{display:grid;grid-template-columns:1fr;gap:30px;align-items:center}
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-weight:600;font-size:14px;letter-spacing:.01em;color:var(--tg-deep);
  background:rgba(34,158,217,.10);border:1px solid rgba(34,158,217,.22);
  padding:8px 14px 8px 11px;border-radius:999px;
}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--tg);box-shadow:0 0 0 4px rgba(34,158,217,.2)}
h1{font-size:clamp(34px,8.4vw,68px);margin:0 0 18px;font-weight:800}
.hero-socials{display:flex;align-items:center;gap:18px;margin:0 0 28px}
.hero-socials svg{width:30px;height:30px;transition:transform .2s ease}
.hero-socials svg:hover{transform:translateY(-3px)}
h1 .hl{color:var(--tg-dark);position:relative}
.hero p.lead{font-size:clamp(17px,2.4vw,21px);color:var(--ink-soft);max-width:36ch;margin-bottom:30px}
.hero p.lead b{color:var(--ink);font-weight:600}
.cta-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.cta-note{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:14.5px;font-weight:500;margin-top:18px}
.cta-note svg{color:var(--tg);flex:none}

.hero-copy{min-width:0}
.hero-visual{position:relative;display:grid;place-items:center;min-height:340px;min-width:0}
.hero-glow{position:absolute;inset:0;margin:auto;width:78%;aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle,rgba(43,176,238,.38),rgba(34,158,217,.06) 60%,transparent 72%);
  filter:blur(6px);z-index:0}
.hero-mascot{position:relative;z-index:2;width:min(94%,420px);height:auto;
  filter:drop-shadow(0 36px 46px rgba(15,70,100,.32))}
.hero-badge{
  position:absolute;z-index:3;background:var(--surface);border-radius:16px;
  padding:11px 15px;box-shadow:var(--shadow-lg);border:1px solid var(--line-2);
  display:flex;align-items:center;gap:10px;font-weight:600;font-size:14px;
}
.hero-badge small{display:block;color:var(--muted);font-weight:500;font-size:12px;line-height:1.2}
.hero-badge .ic{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;flex:none}
.badge-clean{top:8%;left:-2%}
.badge-fast{bottom:9%;right:-1%}
@media(max-width:760px){.badge-clean{left:0;top:2%}.badge-fast{right:0;bottom:2%}}

/* ---------- Section primitives ---------- */
section{position:relative}
.sec{padding:64px 0}
.sec-head{max-width:none;margin-bottom:38px}
.kicker{font-weight:600;font-size:13.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--tg-dark);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.kicker::before{content:"";width:26px;height:2px;border-radius:2px;background:var(--tg)}
.sec h2{font-size:clamp(27px,4.6vw,42px);font-weight:700;max-width:18ch}
.sec-head p{color:var(--ink-soft);font-size:clamp(16px,2vw,19px);max-width:52ch;margin-top:16px}

/* ---------- Platforms ---------- */
.platforms{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media(min-width:720px){.platforms{grid-template-columns:repeat(4,1fr)}}
.plat{
  position:relative;background:var(--surface);border:1px solid var(--line-2);
  border-radius:var(--r);padding:24px 22px 20px;box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;gap:16px;overflow:hidden;
  transition:transform .2s cubic-bezier(.2,.7,.2,1), box-shadow .25s, border-color .25s;
  min-height:172px;justify-content:space-between;
}
.plat::after{content:"";position:absolute;inset:auto -40% -60% auto;width:150px;height:150px;border-radius:50%;background:var(--accent,var(--tg));opacity:.07;transition:transform .35s ease, opacity .25s}
.plat:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:rgba(34,158,217,.28)}
.plat:hover::after{transform:scale(1.4) translate(-6%,-6%);opacity:.12}
.plat:focus-visible{outline:3px solid rgba(34,158,217,.5);outline-offset:3px}
.plat-ic{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;background:#fff;box-shadow:var(--shadow-sm);border:1px solid var(--line-2);position:relative;z-index:1}
.plat-ic svg{width:28px;height:28px}
.plat-name{font-family:"Rubik",sans-serif;font-weight:600;font-size:17px;position:relative;z-index:1}
.plat-go{display:flex;align-items:center;gap:7px;color:var(--muted);font-weight:600;font-size:13.5px;position:relative;z-index:1;transition:color .2s,gap .2s}
.plat:hover .plat-go{color:var(--tg-dark);gap:11px}
.plat-go svg{transition:transform .2s}
.plat:hover .plat-go svg{transform:translateX(2px)}

/* ---------- Groups & Channels ---------- */
.groups{
  position:relative;background:linear-gradient(165deg,#0E2330 0%, #123A50 55%, #0E2A3C 100%);
  color:#fff;border-radius:var(--r-xl);overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.groups::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.05) 1px,transparent 1.4px);background-size:24px 24px;opacity:.6}
.groups::after{content:"";position:absolute;top:-30%;right:-10%;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(43,176,238,.5),transparent 62%);filter:blur(8px)}
.groups-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr;gap:36px;padding:44px 26px}
@media(min-width:960px){.groups-inner{grid-template-columns:1.05fr .95fr;gap:48px;padding:56px 56px;align-items:center}}
.groups .kicker{color:#8FD6F6}
.groups .kicker::before{background:#2BB0EE}
.groups h2{color:#fff;font-size:clamp(26px,4.2vw,40px)}
.groups .g-lead{color:rgba(231,243,250,.8);margin-top:16px;font-size:clamp(16px,2vw,18.5px)}
.g-feats{display:grid;gap:14px;margin-top:30px}
.g-feat{display:flex;gap:15px;align-items:flex-start;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.10);padding:18px 20px;border-radius:var(--r);backdrop-filter:blur(2px)}
.g-feat .gic{width:42px;height:42px;border-radius:12px;flex:none;display:grid;place-items:center;background:linear-gradient(150deg,var(--tg-bright),var(--tg-dark));box-shadow:0 8px 18px -8px rgba(34,158,217,.9)}
.g-feat h3{font-family:"Onest",sans-serif;font-size:17.5px;font-weight:700;letter-spacing:0;color:#fff}
.g-feat p{color:rgba(225,240,248,.72);font-size:15px;margin-top:4px}

.g-visual{position:relative;display:grid;place-items:center}
.chat-mascot{position:absolute;z-index:3;width:128px;height:auto;right:-6px;top:-58px;filter:drop-shadow(0 16px 24px rgba(0,0,0,.35))}
@media(max-width:600px){.chat-mascot{width:96px;top:-40px;right:0}}

/* chat mock */
.chat{
  width:100%;max-width:380px;background:#D7E7F0;border-radius:24px;padding:16px 14px 18px;
  box-shadow:0 30px 60px -20px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.6);
  position:relative;z-index:2;
  background-image:radial-gradient(rgba(34,158,217,.10) 1.2px,transparent 1.2px);
  background-size:18px 18px;background-color:#DCEAF2;
}
.chat-top{display:flex;align-items:center;gap:10px;padding:4px 6px 14px;border-bottom:1px solid rgba(14,35,48,.08);margin-bottom:14px}
.chat-ava{width:34px;height:34px;border-radius:50%;background:linear-gradient(150deg,var(--tg-bright),var(--tg-dark));display:grid;place-items:center;color:#fff;font-weight:700;font-size:13px;flex:none;box-shadow:var(--shadow-sm)}
.chat-top .ct-name{font-weight:700;font-size:14px;color:var(--ink);line-height:1.1}
.chat-top .ct-sub{font-size:11.5px;color:var(--muted)}
.msg{max-width:86%;padding:9px 13px;border-radius:16px;font-size:13.5px;line-height:1.45;margin-bottom:9px;position:relative;box-shadow:0 1px 1px rgba(14,35,48,.08)}
.msg .who{display:block;font-weight:700;font-size:11.5px;margin-bottom:2px}
.msg.in{background:#fff;color:var(--ink);border-bottom-left-radius:5px}
.msg.in .who{color:var(--tg-dark)}
.msg.in .who.pink{color:#C13584}
.msg .lnk{color:var(--tg-dark);font-weight:600;word-break:break-all}
.msg.bot{background:linear-gradient(180deg,var(--tg-bright),var(--tg));color:#fff;margin-left:auto;border-bottom-right-radius:5px}
.msg.bot .who{color:rgba(255,255,255,.85)}
.vidcard{display:flex;align-items:center;gap:11px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.25);padding:9px 11px;border-radius:12px;margin-top:6px}
.vidcard .thumb{width:40px;height:40px;border-radius:9px;flex:none;display:grid;place-items:center;background:rgba(0,0,0,.22)}
.vidcard .f-name{font-weight:700;font-size:13px;line-height:1.2}
.vidcard .f-meta{font-size:11px;opacity:.85}
.msg .tick{font-size:10.5px;opacity:.85;float:right;margin:5px 0 -2px 8px}

/* ---------- How it works ---------- */
.how{display:grid;grid-template-columns:1fr;gap:36px;align-items:center}
@media(min-width:880px){.how{grid-template-columns:.82fr 1.18fr;gap:52px}}
.how-visual{position:relative;display:grid;place-items:center;order:-1}
@media(min-width:880px){.how-visual{order:0}}
.how-glow{position:absolute;width:80%;aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,rgba(43,176,238,.28),transparent 65%);filter:blur(4px)}
.phone-mascot{position:relative;z-index:2;width:min(86%,360px);height:auto;filter:drop-shadow(0 30px 40px rgba(15,70,100,.28))}
.phone-frame{position:relative;z-index:2;max-width:288px;width:82%;margin:0 auto;background:#0a0e14;padding:9px;border-radius:36px;box-shadow:0 36px 60px -22px rgba(0,0,0,.5), 0 10px 22px -10px rgba(0,0,0,.3), inset 0 0 0 1px rgba(255,255,255,.08)}
.phone-frame img{display:block;width:100%;height:auto;border-radius:28px}
.steps{display:grid;gap:14px;counter-reset:step}
.step{
  display:flex;gap:18px;align-items:flex-start;background:var(--surface);
  border:1px solid var(--line-2);border-radius:var(--r);padding:20px 22px;box-shadow:var(--shadow-sm);
  transition:transform .2s,box-shadow .25s,border-color .25s;
}
.step:hover{transform:translateX(4px);box-shadow:var(--shadow-md);border-color:rgba(34,158,217,.25)}
.step-num{counter-increment:step;flex:none;width:46px;height:46px;border-radius:14px;
  display:grid;place-items:center;font-family:"Rubik",sans-serif;font-weight:700;font-size:19px;
  color:#fff;background:linear-gradient(150deg,var(--tg-bright),var(--tg-dark));box-shadow:0 10px 20px -8px rgba(34,158,217,.8)}
.step-num::before{content:counter(step,decimal-leading-zero)}
.step h3{font-family:"Onest",sans-serif;font-size:18.5px;font-weight:700;letter-spacing:0}
.step p{color:var(--ink-soft);font-size:15.5px;margin-top:3px}

/* ---------- Benefits ---------- */
.benefits{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media(min-width:760px){.benefits{grid-template-columns:repeat(3,1fr)}}
.benefit{
  background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r);
  padding:24px 22px;box-shadow:var(--shadow-sm);
  transition:transform .2s,box-shadow .25s,border-color .25s;
}
.benefit:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:rgba(34,158,217,.25)}
.benefit .bic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;margin-bottom:15px;
  color:var(--tg-dark);background:rgba(34,158,217,.12);border:1px solid rgba(34,158,217,.18)}
.benefit.wide{grid-column:span 2}
@media(min-width:760px){.benefit.wide{grid-column:span 1}}
.benefit h3{font-family:"Onest",sans-serif;font-size:18px;font-weight:700;letter-spacing:0;margin-bottom:5px}
.benefit p{color:var(--ink-soft);font-size:15px}

/* ---------- FAQ ---------- */
.faq{display:grid;gap:12px;max-width:820px}
.q{background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r);box-shadow:var(--shadow-sm);overflow:hidden;transition:box-shadow .25s,border-color .25s}
.q[open]{box-shadow:var(--shadow-md);border-color:rgba(34,158,217,.25)}
.q summary{
  list-style:none;cursor:pointer;padding:20px 22px;display:flex;align-items:center;gap:16px;
  font-family:"Onest",sans-serif;font-weight:600;font-size:17.5px;color:var(--ink);
}
.q summary::-webkit-details-marker{display:none}
.q summary:focus-visible{outline:3px solid rgba(34,158,217,.5);outline-offset:-3px;border-radius:var(--r)}
.q .sign{margin-left:auto;flex:none;width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:rgba(34,158,217,.10);color:var(--tg-dark);transition:transform .28s cubic-bezier(.2,.7,.2,1),background .2s}
.q[open] .sign{transform:rotate(45deg);background:var(--tg);color:#fff}
.q .ans{padding:0 22px 22px 22px;color:var(--ink-soft);font-size:16px;max-width:64ch}
.q .ans a{color:var(--tg-dark);font-weight:600;text-decoration:underline;text-underline-offset:2px}

/* ---------- Final CTA ---------- */
.final{
  position:relative;border-radius:var(--r-xl);overflow:hidden;
  background:linear-gradient(155deg,var(--tg-bright) 0%, var(--tg) 42%, var(--tg-deep) 100%);
  color:#fff;box-shadow:var(--shadow-lg);
  display:grid;grid-template-columns:1fr;align-items:center;gap:18px;
  padding:46px 26px;text-align:center;
}
@media(min-width:840px){.final{grid-template-columns:1.4fr .6fr;text-align:left;padding:56px 56px}}
.final::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.12) 1px,transparent 1.4px);background-size:22px 22px;opacity:.5}
.final-copy{position:relative;z-index:2}
.final h2{color:#fff;font-size:clamp(26px,4.4vw,42px)}
.final p{color:rgba(255,255,255,.9);margin:14px 0 26px;font-size:clamp(16px,2vw,19px);max-width:42ch}
@media(min-width:840px){.final p{margin-inline:0}}
.final-copy .cta-row{justify-content:center}
@media(min-width:840px){.final-copy .cta-row{justify-content:flex-start}}
.btn-white{background:#fff;color:var(--tg-deep);box-shadow:0 18px 40px -16px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.6)}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 26px 50px -16px rgba(0,0,0,.55)}
.final-handle{display:inline-flex;align-items:center;gap:8px;margin-top:18px;font-size:15px;color:rgba(255,255,255,.85);font-weight:500;position:relative;z-index:2}
.final-visual{position:relative;z-index:2;display:grid;place-items:center}
.final-mascot{width:min(72%,230px);height:auto;filter:drop-shadow(0 24px 30px rgba(0,40,60,.4))}

/* ---------- Footer ---------- */
.site-footer{padding:46px 0 40px;color:var(--ink-soft)}
.foot-inner{display:flex;flex-direction:column;gap:22px}
@media(min-width:680px){.foot-inner{flex-direction:row;align-items:center;justify-content:space-between}}
.foot-links{display:flex;flex-wrap:wrap;gap:8px 22px;font-size:15px;font-weight:500}
.foot-links a{color:var(--ink-soft);transition:color .2s;padding:4px 0;border-bottom:1px solid transparent}
.foot-links a:hover{color:var(--tg-dark)}
.foot-bottom{margin-top:24px;padding-top:22px;border-top:1px solid var(--line);font-size:13.5px;color:var(--muted);display:flex;flex-wrap:wrap;gap:6px 18px;justify-content:space-between}

/* ---------- Load-in animation (one staggered intro) ---------- */
/* Base state is always visible — safe for no-JS and frozen-animation environments. */
.reveal{opacity:1}
@keyframes rise{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
@media(prefers-reduced-motion:no-preference){
  /* Only when JS confirms motion is allowed (html.play) do we hide + animate in. */
  .play .reveal,.play .hero-badge{opacity:0;transform:translateY(20px);animation:rise .8s cubic-bezier(.2,.75,.25,1) both}
  .play .d1{animation-delay:.06s}.play .d2{animation-delay:.16s}.play .d3{animation-delay:.26s}
  .play .d4{animation-delay:.36s}.play .d5{animation-delay:.46s}.play .d6{animation-delay:.58s}
  .play .badge-clean{animation-delay:.6s}.play .badge-fast{animation-delay:.72s}
  .play .hero-mascot{animation:float 4s ease-in-out infinite}
}
/* Safety net: once load settles, force final visible state even if animations were frozen. */
.played .reveal,.played .hero-badge{opacity:1!important;transform:none!important}
.played .reveal{animation:none!important}

/* larger layout */
@media(min-width:880px){
  .hero{padding:72px 0 56px}
  .sec{padding:84px 0}
}
@media(min-width:1000px){
  .hero-grid{grid-template-columns:1.08fr .92fr;gap:40px}
}
@media(min-width:1040px){
  h1{margin-top:26px}
  .hero p.lead{max-width:32ch}
}

/* ---------- Mobile fixes (≤560px) ---------- */
@media(max-width:560px){
  /* Компактна шапка: CTA лише іконкою, без обрізання тексту */
  .hdr-inner{height:62px;gap:10px}
  .brand{font-size:18px;gap:9px}
  .brand-mark{width:34px;height:34px;border-radius:10px}
  .hdr-cta{padding:11px;border-radius:14px}
  .hdr-cta-label{display:none}
  .hdr-cta svg{width:20px;height:20px}

  /* Декоративні плашки прибираємо — на вузькому екрані налазять на маскота */
  .hero-badge{display:none!important}

  /* Hero на мобільному — лише текст. Маскот прибрано: на вузькому екрані
     він або тисне текст, або робить колонку надто вузькою. Маскоти лишаються
     в інших секціях (groups / how / final) і праворуч від тексту на десктопі. */
  .hero{padding:26px 0 28px}
  .hero-visual{display:none}
  h1{font-size:clamp(30px,8.8vw,40px);margin:14px 0 14px}
  .hero p.lead{font-size:16.5px;max-width:none;margin-bottom:22px}

  /* CTA на всю ширину, не тиснуться */
  .cta-row{gap:11px}
  .cta-row .btn{width:100%;justify-content:center}
  .btn-lg{--pad:16px 24px;font-size:16.5px}

  /* Менші відступи секцій — менше «порожнечі» */
  .sec{padding:48px 0}
  .sec-head{margin-bottom:26px}
  .groups-inner{padding:34px 20px}
  .final{padding:38px 22px}

  /* Картки трохи компактніші */
  .plat{padding:20px 18px;min-height:150px}
  .step{padding:18px 18px;gap:14px}
  .benefit{padding:20px 18px}
  .q summary{padding:17px 18px;font-size:16px;gap:12px}
  .q .ans{padding:0 18px 18px}

  /* Маскоти в секціях — менші й чітко по центру на мобільному */
  .how-visual,.final-visual{justify-items:center;text-align:center}
  .phone-frame{width:min(66%,240px)}
  .final-mascot{width:min(56%,200px);margin-inline:auto}
  .chat-mascot{width:108px;right:6px;top:-48px}
}

/* Дуже вузькі екрани (≤360px) — прибрати горизонтальні переповнення */
@media(max-width:360px){
  .wrap{padding-inline:16px}
  h1{font-size:clamp(27px,8.6vw,34px)}
  .chat{max-width:100%}
}