/* ===========================================================================
   ЛогоИгры — sections, catalog, animated game previews
   =========================================================================== */

/* ---- generic grids ------------------------------------------------------ */
.grid { display: grid; gap: 22px; }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px) { .grid-3, .grid-4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; } }

/* ===========================================================================
   PROBLEM
   =========================================================================== */
.problem-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(36px, 5vw, 72px); align-items: center; }
@media (max-width: 880px) { .problem-grid { grid-template-columns: 1fr; } }

.mess-board {
  position: relative; aspect-ratio: 1 / 0.92; border-radius: 24px;
  background: var(--bg-2); border: 1px solid var(--border); overflow: hidden;
  box-shadow: inset 0 2px 20px rgb(var(--shadow-rgb) / 0.05);
}
.mess-item {
  position: absolute; background: var(--surface); border: 1px solid var(--border);
  border-radius: 12px; padding: 12px 14px; font-size: 0.82rem; font-weight: 600; color: var(--ink-soft);
  box-shadow: 0 12px 24px -16px rgb(var(--shadow-rgb) / 0.35);
  display: flex; align-items: center; gap: 9px; max-width: 200px;
  transition: transform .3s ease;
}
.mess-item .mi-ico { width: 26px; height: 26px; border-radius: 7px; display: grid; place-items: center; flex-shrink: 0; background: var(--surface-2); }
.mess-item .mi-ico svg { width: 15px; height: 15px; color: var(--ink-faint); }
.mess-board:hover .mess-item { transform: rotate(0deg) translate(0,0) !important; }
.mess-board .stamp {
  position: absolute; bottom: 18px; left: 50%; transform: translateX(-50%) rotate(-4deg);
  background: var(--primary); color: var(--primary-ink); font-family: var(--font-display);
  font-weight: 800; font-size: 0.86rem; padding: 8px 16px; border-radius: 999px; z-index: 10;
  box-shadow: 0 12px 26px -10px rgb(var(--shadow-rgb) / 0.5); white-space: nowrap;
  transition: transform .3s ease;
}
.mess-board:hover .stamp { transform: translateX(-50%) rotate(0deg); }

.pain-list { display: flex; flex-direction: column; gap: 14px; margin-top: 30px; }
.pain {
  display: flex; gap: 15px; align-items: flex-start; padding: 16px 18px;
  background: var(--surface); border: 1px solid var(--border); border-radius: 16px;
}
.pain .x { width: 30px; height: 30px; border-radius: 9px; background: var(--secondary-soft); color: var(--secondary); display: grid; place-items: center; flex-shrink: 0; }
.pain .x svg { width: 17px; height: 17px; }
.pain b { display: block; color: var(--ink); font-size: 1rem; margin-bottom: 2px; }
.pain span { font-size: 0.92rem; color: var(--ink-soft); }

/* ===========================================================================
   SOLUTION / HOW IT WORKS
   =========================================================================== */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; counter-reset: step; }
@media (max-width: 880px) { .steps { grid-template-columns: 1fr; } }
.step { position: relative; padding: 30px 26px; }
.step-n {
  font-family: var(--font-display); font-weight: 800; font-size: 1.05rem;
  width: 42px; height: 42px; border-radius: 12px; display: grid; place-items: center;
  background: var(--primary-soft); color: var(--primary-strong); margin-bottom: 20px;
}
.step h3 { font-size: 1.28rem; margin-bottom: 10px; }
.step p { font-size: 0.98rem; color: var(--ink-soft); margin: 0; }
.step-arrow { position: absolute; top: 50px; right: -24px; color: var(--border-strong); z-index: 2; }
@media (max-width: 880px) { .step-arrow { display: none; } }

/* ===========================================================================
   GAME CATALOG
   =========================================================================== */
.catalog { display: grid; grid-template-columns: 340px 1fr; gap: 36px; align-items: start; }
@media (max-width: 980px) { .catalog { grid-template-columns: 1fr; gap: 28px; } }

.cat-filters { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 22px; }
.cat-filter {
  appearance: none; cursor: pointer; font-family: var(--font-body); font-weight: 600; font-size: 0.86rem;
  padding: 8px 14px; border-radius: 999px; border: 1px solid var(--border);
  background: var(--surface); color: var(--ink-soft); transition: all .15s;
}
.cat-filter:hover { border-color: var(--ink-faint); color: var(--ink); }
.cat-filter[data-on="1"] { background: var(--ink); color: var(--bg); border-color: var(--ink); }

.cat-list { display: flex; flex-direction: column; gap: 10px; max-height: 560px; overflow-y: auto; padding-right: 6px; }
.cat-list::-webkit-scrollbar { width: 8px; }
.cat-list::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: 8px; }
.game-row {
  display: flex; gap: 14px; align-items: center; text-align: left;
  padding: 12px; border-radius: 16px; border: 1.5px solid var(--border);
  background: var(--surface); cursor: pointer; transition: all .16s; width: 100%;
  font-family: var(--font-body);
}
.game-row:hover { border-color: var(--border-strong); transform: translateX(2px); }
.game-row[data-on="1"] { border-color: var(--primary); background: var(--primary-soft); box-shadow: 0 10px 26px -16px rgb(var(--shadow-rgb) / 0.4); }
.game-thumb { width: 54px; height: 54px; border-radius: 12px; flex-shrink: 0; display: grid; place-items: center; color: #fff; position: relative; overflow: hidden; }
.game-thumb svg { width: 26px; height: 26px; z-index: 2; }
.game-row-info { min-width: 0; flex: 1; }
.game-row-info b { display: block; font-family: var(--font-display); font-weight: 800; font-size: 1rem; color: var(--ink); }
.game-row-info .tags { display: flex; gap: 6px; margin-top: 3px; flex-wrap: wrap; }
.game-row-info .tg { font-size: 0.72rem; font-weight: 600; color: var(--ink-faint); }
.sound-chip { font-family: var(--font-display); font-weight: 800; background: var(--surface-2); color: var(--ink); border-radius: 7px; padding: 1px 7px; font-size: 0.72rem; }

/* preview pane */
.cat-preview { position: sticky; top: 96px; }
.preview-card { padding: 26px; display: grid; grid-template-columns: 200px 1fr; gap: 30px; align-items: center; }
@media (max-width: 600px) { .preview-card { grid-template-columns: 1fr; justify-items: center; text-align: center; } }
.preview-phone-wrap { display: flex; justify-content: center; }
.preview-meta .badge-row { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 14px; }
.badge { display: inline-flex; align-items: center; gap: 6px; font-size: 0.78rem; font-weight: 700; padding: 5px 11px; border-radius: 999px; }
.badge.mech { background: var(--secondary-soft); color: var(--secondary); }
.badge.age { background: var(--primary-soft); color: var(--primary-strong); }
.preview-meta h3 { font-size: 1.7rem; margin-bottom: 10px; }
.preview-meta p { color: var(--ink-soft); font-size: 1rem; margin-bottom: 16px; }
.preview-sounds { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.preview-sounds .lbl { font-size: 0.82rem; color: var(--ink-faint); font-weight: 600; }
.preview-sounds .sound-chip { font-size: 0.92rem; padding: 3px 10px; background: var(--ink); color: var(--bg); }
.live-tag {
  position: absolute; top: 10px; left: 10px; z-index: 8;
  display: inline-flex; align-items: center; gap: 5px; font-size: 0.6rem; font-weight: 800;
  letter-spacing: 0.06em; text-transform: uppercase; color: #fff; background: rgba(0,0,0,.42);
  padding: 4px 8px; border-radius: 999px; -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px);
}
.live-tag .rec { width: 7px; height: 7px; border-radius: 50%; background: #ff5a5a; animation: recpulse 1.4s infinite; }
@keyframes recpulse { 0%,100% { opacity: 1; } 50% { opacity: 0.3; } }

/* GAME PREVIEW SCENES live in styles/games.css */

/* ===========================================================================
   FEATURES (for therapist)
   =========================================================================== */
.feat-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }
@media (max-width: 820px) { .feat-grid { grid-template-columns: 1fr; } }
.feat { padding: 30px; display: flex; flex-direction: column; gap: 16px; }
.feat .ico { width: 50px; height: 50px; border-radius: 14px; display: grid; place-items: center; background: var(--primary-soft); color: var(--primary-strong); }
.feat .ico svg { width: 26px; height: 26px; }
.feat h3 { font-size: 1.3rem; }
.feat p { color: var(--ink-soft); margin: 0; font-size: 0.98rem; }
.feat.wide { grid-column: span 2; }
@media (max-width: 820px) { .feat.wide { grid-column: span 1; } }

/* feature with embedded mini UI */
.feat-ui { background: var(--bg-2); border: 1px solid var(--border); border-radius: 16px; padding: 16px; margin-top: 4px; }
.mini-patient { display: flex; align-items: center; gap: 12px; }
.mini-patient .pa { width: 40px; height: 40px; border-radius: 12px; background: var(--secondary-soft); display: grid; place-items: center; font-family: var(--font-display); font-weight: 800; color: var(--secondary); }
.mini-patient .pn { font-weight: 700; color: var(--ink); }
.mini-patient .pm { font-size: 0.82rem; color: var(--ink-faint); }
.mini-bars { display: flex; flex-direction: column; gap: 9px; }
.mini-bar-row { display: flex; align-items: center; gap: 10px; font-size: 0.84rem; }
.mini-bar-row .sc { font-family: var(--font-display); font-weight: 800; width: 30px; color: var(--ink); }
.mini-bar { flex: 1; height: 9px; border-radius: 999px; background: var(--surface-2); overflow: hidden; }
.mini-bar i { display: block; height: 100%; border-radius: 999px; background: var(--primary); }
.mini-bar-row .pct { font-size: 0.78rem; color: var(--ink-faint); width: 34px; text-align: right; }
.mini-waveform { display: flex; align-items: center; gap: 3px; height: 38px; }
.mini-waveform i { flex: 1; background: var(--secondary); border-radius: 3px; opacity: .8; }
.mini-timecodes { display: flex; gap: 8px; margin-top: 10px; flex-wrap: wrap; }
.tc { font-size: 0.72rem; font-weight: 700; background: var(--surface); border: 1px solid var(--border); border-radius: 7px; padding: 3px 8px; color: var(--ink-soft); }
.constructor-chips { display: flex; flex-direction: column; gap: 8px; }
.cn-chip { display: flex; align-items: center; gap: 10px; background: var(--surface); border: 1px solid var(--border); border-radius: 11px; padding: 9px 11px; }
.cn-chip .h { width: 5px; height: 22px; border-radius: 4px; background: var(--border-strong); }
.cn-chip .nm { font-weight: 700; font-size: 0.84rem; color: var(--ink); }
.cn-chip .dur { margin-left: auto; font-size: 0.74rem; color: var(--ink-faint); }

/* ===========================================================================
   PROGRAMS (methodologies)
   =========================================================================== */
.prog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
@media (max-width: 880px) { .prog-grid { grid-template-columns: 1fr; } }
.prog { padding: 28px; display: flex; flex-direction: column; }
.prog .tag { font-size: 0.78rem; font-weight: 700; color: var(--primary-strong); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 14px; }
.prog h3 { font-size: 1.45rem; margin-bottom: 8px; }
.prog .desc { color: var(--ink-soft); font-size: 0.94rem; margin-bottom: 18px; flex: 1; }
.prog .meta { display: flex; gap: 18px; padding-top: 16px; border-top: 1px solid var(--border); }
.prog .meta .m .v { font-family: var(--font-display); font-weight: 800; font-size: 1.2rem; color: var(--ink); }
.prog .meta .m .k { font-size: 0.76rem; color: var(--ink-faint); }

/* ===========================================================================
   AUDIENCE
   =========================================================================== */
.aud-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
@media (max-width: 820px) { .aud-grid { grid-template-columns: 1fr; } }
.aud { padding: 36px; position: relative; overflow: hidden; }
.aud.primary { background: var(--ink); color: var(--bg); border-color: transparent; }
.aud.primary h3, .aud.primary .aud-role { color: var(--bg); }
.aud.primary p { color: color-mix(in oklab, var(--bg) 80%, var(--ink)); }
.aud.primary .aud-check .c { background: rgba(255,255,255,.14); color: var(--bg); }
.aud-role { font-size: 0.8rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--primary-strong); margin-bottom: 12px; }
.aud h3 { font-size: 1.6rem; margin-bottom: 12px; }
.aud > p { color: var(--ink-soft); margin-bottom: 22px; }
.aud-checks { display: flex; flex-direction: column; gap: 12px; }
.aud-check { display: flex; gap: 12px; align-items: flex-start; }
.aud-check .c { width: 24px; height: 24px; border-radius: 8px; background: var(--primary-soft); color: var(--primary-strong); display: grid; place-items: center; flex-shrink: 0; }
.aud-check .c svg { width: 14px; height: 14px; }
.aud-check span { font-size: 0.95rem; }

/* ===========================================================================
   PRICING
   =========================================================================== */
.price-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; align-items: stretch; }
@media (max-width: 880px) { .price-grid { grid-template-columns: 1fr; max-width: 460px; margin: 0 auto; } }
.price { padding: 32px 30px; display: flex; flex-direction: column; position: relative; }
.price.featured { border-color: var(--primary); box-shadow: 0 30px 60px -34px rgb(var(--shadow-rgb) / 0.4); }
.price .ribbon { position: absolute; top: -13px; left: 50%; transform: translateX(-50%); background: var(--primary); color: var(--primary-ink); font-weight: 700; font-size: 0.76rem; padding: 6px 16px; border-radius: 999px; white-space: nowrap; }
.price .pname { font-family: var(--font-display); font-weight: 800; font-size: 1.3rem; margin-bottom: 6px; }
.price .pdesc { font-size: 0.88rem; color: var(--ink-faint); margin-bottom: 22px; min-height: 38px; }
.price .pamt { display: flex; align-items: baseline; gap: 4px; margin-bottom: 4px; }
.price .pamt .v { font-family: var(--font-display); font-weight: 800; font-size: 2.6rem; letter-spacing: -0.04em; }
.price .pamt .per { font-size: 0.92rem; color: var(--ink-faint); }
.price .pnote { font-size: 0.82rem; color: var(--ink-faint); margin-bottom: 24px; }
.price .btn { width: 100%; margin-bottom: 24px; }
.price ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.price li { display: flex; gap: 11px; align-items: flex-start; font-size: 0.92rem; color: var(--ink-soft); }
.price li svg { width: 18px; height: 18px; color: var(--primary); flex-shrink: 0; margin-top: 2px; }

/* ===========================================================================
   FAQ
   =========================================================================== */
.faq-list { max-width: 800px; margin: 0 auto; display: flex; flex-direction: column; gap: 12px; }
.faq-item { border: 1px solid var(--border); border-radius: 16px; background: var(--surface); overflow: hidden; transition: border-color .2s; }
.faq-item[data-open="1"] { border-color: var(--border-strong); }
.faq-q { width: 100%; appearance: none; background: none; border: 0; cursor: pointer; font-family: var(--font-display); font-weight: 800; font-size: 1.08rem; color: var(--ink); text-align: left; padding: 22px 24px; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.faq-q .pm { width: 26px; height: 26px; flex-shrink: 0; border-radius: 50%; background: var(--surface-2); display: grid; place-items: center; transition: transform .25s, background .2s; }
.faq-item[data-open="1"] .faq-q .pm { background: var(--primary); color: var(--primary-ink); transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .3s ease; }
.faq-a-inner { padding: 0 24px 22px; color: var(--ink-soft); font-size: 0.98rem; }

/* ===========================================================================
   CTA + FOOTER
   =========================================================================== */
.cta-band { position: relative; }
.cta-card { background: var(--ink); color: var(--bg); border-radius: 32px; padding: clamp(40px, 6vw, 76px); text-align: center; position: relative; overflow: hidden; }
.cta-card .blob { position: absolute; border-radius: 50%; filter: blur(70px); opacity: .35; }
.cta-card .blob.a { width: 360px; height: 360px; background: var(--primary); top: -120px; right: -80px; }
.cta-card .blob.b { width: 300px; height: 300px; background: var(--secondary); bottom: -120px; left: -60px; }
.cta-card-inner { position: relative; z-index: 2; max-width: 680px; margin: 0 auto; }
.cta-card h2 { color: var(--bg); margin-bottom: 18px; }
.cta-card p { color: color-mix(in oklab, var(--bg) 78%, var(--ink)); font-size: 1.15rem; margin-bottom: 32px; }

/* lead form */
.lead-form { display: flex; gap: 10px; max-width: 520px; margin: 0 auto; flex-wrap: wrap; }
.lead-form input {
  flex: 1; min-width: 200px; padding: 16px 20px; border-radius: 999px; border: 1.5px solid transparent;
  background: var(--surface); color: var(--ink); font-family: var(--font-body); font-size: 1rem; outline: none;
}
.lead-form input:focus { border-color: var(--primary); }
.lead-form .btn { flex-shrink: 0; }
.form-note { margin-top: 16px; font-size: 0.84rem; color: color-mix(in oklab, var(--bg) 65%, var(--ink)); }
.form-success { display: flex; align-items: center; justify-content: center; gap: 12px; font-size: 1.15rem; font-weight: 700; color: var(--bg); padding: 14px; }
.form-success .ch { width: 34px; height: 34px; border-radius: 50%; background: var(--primary); display: grid; place-items: center; }

.footer { padding: 60px 0 40px; border-top: 1px solid var(--border); }
.footer-top { display: flex; justify-content: space-between; gap: 40px; flex-wrap: wrap; margin-bottom: 40px; }
.footer-brand { max-width: 300px; }
.footer-brand p { color: var(--ink-soft); font-size: 0.92rem; margin-top: 14px; }
.footer-cols { display: flex; gap: 56px; flex-wrap: wrap; }
.footer-col h4 { font-family: var(--font-body); font-size: 0.82rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-faint); margin-bottom: 16px; font-weight: 700; }
.footer-col a { display: block; color: var(--ink-soft); text-decoration: none; font-size: 0.94rem; margin-bottom: 11px; transition: color .15s; }
.footer-col a:hover { color: var(--primary-strong); }
.footer-bottom { display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; padding-top: 26px; border-top: 1px solid var(--border); color: var(--ink-faint); font-size: 0.86rem; }

/* reveal on scroll */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s cubic-bezier(.2,.7,.3,1), transform .7s cubic-bezier(.2,.7,.3,1); }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; } }

/* ===========================================================================
   MOBILE SPACE OPTIMIZATION
   =========================================================================== */
@media (max-width: 700px) {
  .problem-grid {
    gap: 28px;
  }
  .problem-grid > .reveal {
    min-width: 0;
  }
  .problem-grid > .reveal:first-child {
    display: none;
  }

  .mess-board {
    display: flex;
    gap: 10px;
    width: 100%;
    max-width: 100%;
    aspect-ratio: auto;
    min-height: 156px;
    padding: 18px 18px 56px;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }
  .mess-board::-webkit-scrollbar,
  .mobile-rail::-webkit-scrollbar,
  .cat-filters::-webkit-scrollbar,
  .cat-list::-webkit-scrollbar,
  .steps::-webkit-scrollbar,
  .feat-grid::-webkit-scrollbar,
  .prog-grid::-webkit-scrollbar,
  .aud-grid::-webkit-scrollbar,
  .price-grid::-webkit-scrollbar {
    display: none;
  }
  .mess-item {
    position: static;
    flex: 0 0 178px;
    min-height: 64px;
    transform: none !important;
    scroll-snap-align: start;
  }
  .mess-board:hover .mess-item {
    transform: none !important;
  }
  .mess-board .stamp {
    left: 18px;
    right: auto;
    bottom: 14px;
    transform: rotate(-2deg);
    font-size: 0.78rem;
  }
  .mess-board:hover .stamp {
    transform: rotate(0deg);
  }

  .pain-list {
    display: flex;
    flex-direction: row;
    gap: 10px;
    margin-top: 22px;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 2px 0 10px;
    margin-inline: 0;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }
  .pain-list::-webkit-scrollbar {
    display: none;
  }
  .pain {
    flex: 0 0 min(292px, 84vw);
    padding: 14px;
    border-radius: 14px;
    scroll-snap-align: start;
  }
  .pain b { font-size: 0.96rem; }
  .pain span { font-size: 0.86rem; }

  .steps,
  .feat-grid,
  .prog-grid,
  .aud-grid,
  .price-grid {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(272px, 84%);
    grid-template-columns: none;
    gap: 14px;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    scroll-padding-inline: 0;
    padding: 2px 0 12px;
    margin-inline: 0;
    max-width: none;
    -webkit-overflow-scrolling: touch;
  }
  .price-grid {
    grid-auto-columns: minmax(276px, min(78vw, 360px));
    margin-inline: calc(50% - 50vw);
    padding: 38px max(24px, calc((100vw - min(78vw, 360px)) / 2)) 14px;
    scroll-padding-inline: max(24px, calc((100vw - min(78vw, 360px)) / 2));
  }
  .steps > *,
  .feat-grid > *,
  .prog-grid > *,
  .aud-grid > *,
  .price-grid > * {
    scroll-snap-align: start;
  }
  .price-grid > * {
    scroll-snap-align: center;
  }
  .step,
  .feat,
  .prog,
  .aud,
  .price {
    padding: 22px;
    border-radius: 18px;
  }
  .step-n {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    margin-bottom: 14px;
  }
  .step h3,
  .feat h3,
  .prog h3 {
    font-size: 1.16rem;
  }
  .step p,
  .feat p,
  .prog .desc {
    font-size: 0.9rem;
  }
  .feat .ico {
    width: 42px;
    height: 42px;
    border-radius: 12px;
  }
  .feat-ui {
    padding: 12px;
    border-radius: 14px;
  }
  .prog .meta {
    gap: 14px;
  }
  .aud h3 {
    font-size: 1.32rem;
  }
  .aud > p,
  .aud-check span {
    font-size: 0.9rem;
  }
  .price .pdesc {
    min-height: 0;
  }
  .price .ribbon {
    max-width: calc(100% - 32px);
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .price .pamt .v {
    font-size: 2.1rem;
  }

  .cat-filters {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 4px;
    margin-inline: 0;
    padding-inline: 0;
    scroll-snap-type: x mandatory;
  }
  .cat-filter {
    flex: 0 0 auto;
    scroll-snap-align: start;
  }
  .catalog {
    gap: 18px;
  }
  .cat-list {
    flex-direction: row;
    max-height: none;
    overflow-x: auto;
    padding: 2px 0 12px;
    margin-inline: 0;
    scroll-snap-type: x mandatory;
  }
  .game-row {
    flex: 0 0 272px;
    scroll-snap-align: start;
  }
  .game-row:hover {
    transform: translateY(-1px);
  }
  .cat-preview {
    position: static;
  }
  .preview-card {
    grid-template-columns: 118px 1fr;
    gap: 16px;
    padding: 18px;
    text-align: left;
  }
  .preview-phone-wrap .phone {
    width: 118px !important;
  }
  .preview-meta .badge-row {
    gap: 6px;
    margin-bottom: 10px;
  }
  .badge {
    font-size: 0.68rem;
    padding: 4px 8px;
  }
  .preview-meta h3 {
    font-size: 1.24rem;
  }
  .preview-meta p {
    font-size: 0.86rem;
    line-height: 1.45;
    margin-bottom: 12px;
  }
  .preview-sounds .sound-chip {
    font-size: 0.76rem;
  }

  .cta-card {
    border-radius: 24px;
    padding: 36px 20px;
  }
  .cta-card h2 {
    font-size: clamp(1.9rem, 9vw, 2.35rem);
  }
  .cta-card p {
    font-size: 1rem;
    margin-bottom: 24px;
  }
  .lead-form {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    max-width: 360px;
    justify-items: stretch;
  }
  .lead-form input {
    width: 100%;
    min-width: 0;
    text-align: center;
    padding: 15px 18px;
  }
  .lead-form .btn {
    width: 100%;
    justify-self: stretch;
  }
  .form-note {
    max-width: 28ch;
    margin: 14px auto 0;
  }

  .footer {
    padding: 44px 0 30px;
  }
  .footer-cols {
    gap: 28px;
  }
}

@media (max-width: 380px) {
  .steps,
  .feat-grid,
  .prog-grid,
  .aud-grid,
  .price-grid {
    grid-auto-columns: minmax(258px, 86%);
    scroll-padding-inline: 0;
  }
  .price-grid {
    grid-auto-columns: minmax(258px, 84vw);
    padding-inline: max(18px, calc((100vw - 84vw) / 2));
    scroll-padding-inline: max(18px, calc((100vw - 84vw) / 2));
  }
  .cat-filters,
  .cat-list,
  .pain-list {
    padding-inline: 0;
    margin-inline: 0;
  }
  .game-row {
    flex-basis: 258px;
  }
  .preview-card {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
  }
  .preview-sounds {
    justify-content: center;
  }
}
