/* =====================================================
   IT-Planet — конверсионный редизайн
   Brand: purple #6a25c2 + orange #ff8a1f, dark background
   ===================================================== */

:root{
  --bg:           #0b0612;
  --bg-2:         #15082a;
  --surface:      #1a0b30;
  --surface-2:    #2a1450;
  --text:         #eee9f6;
  --text-dim:     #b5a8cc;
  --muted:        #9a8fb4;   /* поднят для контраста WCAG AA на тёмном фоне */
  --line:         rgba(255,255,255,.08);
  --line-strong:  rgba(255,255,255,.16);

  --primary:      #6a25c2;
  --primary-2:    #9c46ff;
  --accent:       #ff8a1f;
  --accent-2:     #ffb45a;
  --success:      #34d399;
  --danger:       #ef4444;

  --grad-primary: linear-gradient(135deg, #9c46ff 0%, #6a25c2 60%, #4a14a0 100%);
  --grad-accent:  linear-gradient(135deg, #ffb45a 0%, #ff8a1f 60%, #e76b00 100%);
  --grad-mix:     linear-gradient(135deg, #9c46ff 0%, #ff8a1f 100%);

  --radius:       18px;
  --radius-sm:    12px;
  --radius-xs:    8px;

  --shadow-sm:    0 4px 18px rgba(106, 37, 194, .15);
  --shadow-md:    0 18px 48px rgba(106, 37, 194, .22);
  --shadow-lg:    0 30px 70px rgba(0, 0, 0, .45);

  --font-sans:    'Manrope', system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  --font-display: 'Unbounded', 'Manrope', system-ui, sans-serif;

  --container:    1240px;
  --pad:          clamp(16px, 4vw, 28px);
}

/* ---------- Base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-sans);
  color:var(--text);
  background:var(--bg);
  font-size:17px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font:inherit;color:inherit}
h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:700;
  line-height:1.12;
  letter-spacing:-.01em;
  margin:0 0 .4em;
}
h1{font-size:clamp(34px, 5.4vw, 64px); font-weight:800; letter-spacing:-.03em}
h2{font-size:clamp(28px, 3.8vw, 46px)}
h3{font-size:clamp(20px, 1.8vw, 24px); font-weight:600}
p{margin:0 0 1em}

.container{
  width:100%;
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:var(--pad);
}

/* ---------- Buttons ---------- */
.btn{
  --bg: var(--primary);
  --col: #fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.6em;
  background:var(--bg);
  color:var(--col);
  padding:14px 22px;
  border-radius:14px;
  font-weight:700;
  font-size:15px;
  line-height:1;
  letter-spacing:.01em;
  white-space:nowrap;
  transition:transform .18s ease, box-shadow .25s ease, background .25s ease, color .25s ease;
  box-shadow: var(--shadow-sm);
  user-select:none;
}
.btn:hover{transform:translateY(-2px); box-shadow: var(--shadow-md)}
.btn:active{transform:translateY(0)}
.btn--primary{background:var(--grad-primary); color:#fff; box-shadow: 0 14px 30px rgba(156,70,255,.35)}
.btn--primary:hover{box-shadow: 0 20px 44px rgba(156,70,255,.5)}
.btn--tg{background:#2aabee; color:#fff; box-shadow:0 14px 30px rgba(42,171,238,.32)}
.btn--tg:hover{background:#1d9bd9; box-shadow:0 20px 44px rgba(42,171,238,.45)}
.btn--secondary{background:rgba(255,255,255,.06); color:#fff; border:1px solid var(--line-strong); backdrop-filter:blur(8px)}
.btn--secondary:hover{background:rgba(255,255,255,.12)}
.btn--ghost{background:transparent; color:#fff; border:1px solid var(--line-strong)}
.btn--ghost:hover{background:rgba(255,255,255,.06)}
.btn--lg{padding:18px 28px; font-size:16px; border-radius:16px}
.btn--sm{padding:10px 16px; font-size:14px; border-radius:11px}
.btn--block{width:100%}
.btn[disabled], .btn[data-loading]{opacity:.78; cursor:wait}
.spin{
  display:inline-block; width:16px; height:16px;
  border-radius:50%;
  border:2.4px solid rgba(255,255,255,.35);
  border-top-color:#fff;
  animation:spin .8s linear infinite;
  vertical-align:-3px; margin-right:6px;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- Top bar ---------- */
.top-bar{
  background:linear-gradient(90deg, #1c0640, #2a0a5e);
  font-size:13px;
  color:var(--text-dim);
  border-bottom:1px solid var(--line);
}
.top-bar__row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:8px 0;
  flex-wrap:wrap;
}
.top-bar__phone{color:#fff; font-weight:600}
.top-bar__phone:hover{color:var(--accent-2)}

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(11,6,18,.78);
  backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line);
}
.site-header__row{
  display:flex;
  align-items:center;
  gap:24px;
  padding:14px 0;
}
.logo{display:inline-flex; align-items:center; gap:10px; font-family:var(--font-display); font-weight:800; font-size:20px; color:#fff}
.logo__text b{background:var(--grad-mix); -webkit-background-clip:text; background-clip:text; color:transparent}
.logo__text span{color:var(--text)}
.nav{display:flex; gap:22px; margin-inline:auto}
.nav a{color:var(--text-dim); font-size:15px; font-weight:500; transition:color .2s}
.nav a:hover{color:#fff}
.header-cta{display:flex; gap:10px}

.burger{
  display:none; width:42px; height:42px; flex-direction:column; justify-content:center; align-items:center; gap:4px;
  border-radius:11px; border:1px solid var(--line-strong);
}
.burger span{width:22px; height:2px; background:#fff; border-radius:2px; transition:.25s}
.burger.is-open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* ---------- Eyebrow / headings ---------- */
.eyebrow{
  display:inline-block;
  padding:6px 12px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
  border-radius:99px;
  background:rgba(156,70,255,.16);
  color:#b88cff;            /* светлее для контраста WCAG AA на тёмном фоне */
  border:1px solid rgba(156,70,255,.34);
  margin-bottom:14px;
}
.eyebrow--on-dark{background:rgba(255,138,31,.12); color:var(--accent-2); border-color:rgba(255,138,31,.32)}
.section-head{margin-bottom:36px; max-width:780px}
.section-head--center{margin:0 auto 40px; text-align:center}
.section-head p{color:var(--text-dim); font-size:17px; margin:6px 0 0}

.grad{
  background:var(--grad-mix);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.grad-2{
  background:var(--grad-accent);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

/* ---------- HERO ---------- */
.hero{
  position:relative;
  overflow:hidden;
  padding:64px 0 40px;
  background:radial-gradient(1400px 600px at 75% -10%, rgba(156,70,255,.25), transparent 60%),
             radial-gradient(900px 500px at 0% 100%, rgba(255,138,31,.18), transparent 60%),
             var(--bg);
}
.hero__bg{position:absolute; inset:0; z-index:0; overflow:hidden; pointer-events:none}
.orb{position:absolute; border-radius:50%; filter:blur(60px); opacity:.6; animation:float 18s ease-in-out infinite}
.orb--1{width:520px; height:520px; background:radial-gradient(circle, #9c46ff, transparent 70%); top:-120px; right:-100px}
.orb--2{width:380px; height:380px; background:radial-gradient(circle, #ff8a1f, transparent 70%); bottom:-100px; left:-80px; animation-delay:-6s}
.orb--3{width:300px; height:300px; background:radial-gradient(circle, #4a14a0, transparent 70%); top:40%; left:55%; animation-delay:-12s}
.grid-overlay{
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size:54px 54px;
  mask-image:radial-gradient(ellipse at center, #000 30%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 30%, transparent 75%);
}
@keyframes float{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(40px,-30px) scale(1.06)}
}

.hero__inner{
  position:relative; z-index:1;
  display:grid;
  grid-template-columns: 1.15fr .9fr;
  gap:48px;
  align-items:center;
  padding-block:24px 40px;
}
.hero__copy h1{margin-top:8px}
.hero__lead{color:var(--text-dim); font-size:clamp(16px,1.6vw,19px); max-width:600px}
.hero__cta{display:flex; gap:12px; flex-wrap:wrap; margin:24px 0 20px}
.hero__bullets{list-style:none; padding:0; margin:0; display:flex; gap:18px; flex-wrap:wrap; color:var(--text-dim); font-size:14px}
.hero__bullets li{padding:6px 0}

/* Quick form card */
.hero__card{
  background:linear-gradient(180deg, rgba(40,16,80,.85), rgba(20,8,40,.75));
  border:1px solid var(--line-strong);
  border-radius:24px;
  padding:26px;
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(14px);
}
.hero__card-head{
  display:flex; align-items:center; gap:8px;
  font-size:13px; color:var(--text-dim); margin-bottom:14px;
}
.dot{width:8px; height:8px; border-radius:50%; background:var(--success); box-shadow:0 0 0 4px rgba(52,211,153,.18); animation:pulse 1.8s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 4px rgba(52,211,153,.18)} 50%{box-shadow:0 0 0 8px rgba(52,211,153,.05)}}

/* Forms */
.field{display:block; margin-bottom:12px}
.field>span{display:block; font-size:13px; color:var(--text-dim); margin-bottom:6px; font-weight:500}
.field>span em{color:var(--muted); font-style:normal; font-weight:400}
.field input, .field select, .field textarea{
  width:100%;
  padding:13px 14px;
  border-radius:12px;
  border:1px solid var(--line-strong);
  background:rgba(0,0,0,.25);
  color:var(--text);
  font-size:15px;
  transition:border .2s, background .2s, box-shadow .2s;
}
.field input::placeholder, .field textarea::placeholder{color:var(--muted)}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none;
  border-color:var(--primary-2);
  box-shadow:0 0 0 3px rgba(156,70,255,.22);
  background:rgba(0,0,0,.35);
}
.field--error input, .field--error select, .field--error textarea{
  border-color:var(--danger);
  box-shadow:0 0 0 3px rgba(239,68,68,.16);
}
.hp-trap{position:absolute; left:-9999px; width:1px; height:1px; opacity:0}
.check{display:flex; gap:10px; align-items:flex-start; font-size:13px; color:var(--text-dim); margin:6px 0 10px; cursor:pointer}
.check input{margin-top:3px; accent-color:var(--primary-2)}
.quick-form__note{margin-top:10px; font-size:12px; color:var(--muted); line-height:1.5}

/* ---------- Trust strip ---------- */
.trust{
  position:relative; z-index:1;
  display:grid;
  grid-template-columns: repeat(5, 1fr);
  gap:12px;
  margin-top:36px;
  padding:22px 12px;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border:1px solid var(--line);
  border-radius:20px;
  backdrop-filter:blur(6px);
}
.trust__item{text-align:center}
.trust__item b{
  display:block;
  font-family:var(--font-display);
  font-size:clamp(22px, 2.6vw, 32px);
  font-weight:800;
  background:var(--grad-mix);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  margin-bottom:4px;
}
.trust__item b span{font-size:.65em; color:var(--accent); -webkit-background-clip:initial; background:none; opacity:.8}
.trust__item em{color:var(--text-dim); font-style:normal; font-size:13px; font-weight:500}

/* ---------- Brands ---------- */
.brands{padding:36px 0; border-bottom:1px solid var(--line)}
.brands__title{text-align:center; font-size:13px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin-bottom:16px}
.brands__row{
  display:flex; gap:36px; flex-wrap:wrap; justify-content:center; align-items:center;
  font-family:var(--font-display); font-weight:700; font-size:clamp(18px, 2vw, 22px); color:var(--text-dim);
  opacity:.85;
}
.brands__row span{transition:color .2s, transform .2s}
.brands__row span:hover{color:#fff; transform:scale(1.06)}
.brands__title--sub{margin-top:18px}
.brands__row--sm{gap:24px; opacity:1}
.brands__row--sm span{font-size:clamp(14px,1.4vw,17px); font-weight:600; color:var(--text-dim); font-family:var(--font-sans); text-transform:uppercase; letter-spacing:.06em}

/* ---------- Catalog ---------- */
.catalog{padding:88px 0}
.cards{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:20px;
}

/* Icon cards (no images) */
.cards--icons{grid-template-columns:repeat(4, 1fr)}
.ic-card{
  position:relative;
  display:flex; flex-direction:column;
  gap:6px;
  padding:24px;
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border:1px solid var(--line);
  border-radius:var(--radius);
  transition: transform .25s, border-color .25s, background .25s, box-shadow .25s;
  overflow:hidden;
  min-height:180px;
  color:inherit;
}
.ic-card::before{
  content:""; position:absolute; top:-40%; right:-30%;
  width:240px; height:240px; border-radius:50%;
  background:radial-gradient(circle, rgba(156,70,255,.22), transparent 65%);
  opacity:0; transition:opacity .35s;
  pointer-events:none;
}
.ic-card:hover{transform:translateY(-4px); border-color:rgba(156,70,255,.55); box-shadow: var(--shadow-md)}
.ic-card:hover::before{opacity:1}
.ic-card__ico{
  width:54px; height:54px; border-radius:14px;
  display:grid; place-items:center;
  background:linear-gradient(135deg, rgba(156,70,255,.22), rgba(255,138,31,.18));
  border:1px solid rgba(156,70,255,.35);
  color:var(--primary-2);
  margin-bottom:8px;
  transition: transform .35s, color .25s;
}
.ic-card:hover .ic-card__ico{transform:rotate(-6deg) scale(1.08); color:var(--accent)}
.ic-card__ico svg{width:30px; height:30px}
.ic-card h3{margin:4px 0 0; font-size:17px; line-height:1.2}
.ic-card p{margin:2px 0 0; color:var(--text-dim); font-size:14px}
.ic-card--cta{
  background:var(--grad-primary);
  border-color:transparent;
  justify-content:center;
  align-items:flex-start;
}
.ic-card--cta h3, .ic-card--cta p{color:#fff}
.ic-card--cta p{opacity:.85}
.ic-card__plus{
  font-family:var(--font-display);
  font-weight:200;
  font-size:64px; line-height:1;
  color:#fff; opacity:.9;
  margin-bottom:4px;
}

/* ---------- Clients / logo wall ---------- */
.clients{padding:70px 0 88px}
.logo-wall{
  display:grid;
  grid-template-columns:repeat(6, 1fr);
  gap:14px;
}
.logo-wall__tile{
  display:grid; place-items:center;
  aspect-ratio: 1 / 1;
  background:#f4f1fb;
  border:1px solid var(--line);
  border-radius:18px;
  padding:18px;
  transition: transform .25s, box-shadow .25s, background .25s;
  overflow:hidden;
}
.logo-wall__tile:hover{transform:translateY(-3px); background:#fff; box-shadow:0 14px 36px rgba(106,37,194,.25)}
.logo-wall__tile img{
  max-width:100%; max-height:80%;
  width:auto; height:auto;
  object-fit:contain;
  filter:grayscale(.4);
  transition:filter .25s;
}
.logo-wall__tile:hover img{filter:none}
.logo-wall__tile--plus{
  background:var(--grad-primary);
  border-color:transparent;
  color:#fff;
  text-align:center;
  flex-direction:column;
  font-family:var(--font-display);
}
.logo-wall__tile--plus:hover{background:var(--grad-primary)}
.logo-wall__tile--plus span{
  display:block; font-size:clamp(22px, 2.4vw, 30px); font-weight:800; line-height:1;
}
.logo-wall__tile--plus em{display:block; font-style:normal; font-weight:600; opacity:.85; font-size:13px; margin-top:6px; letter-spacing:.05em; text-transform:uppercase}
.card{
  position:relative;
  display:block;
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:22px;
  transition: transform .25s, border-color .25s, background .25s, box-shadow .25s;
  overflow:hidden;
}
.card::before{
  content:""; position:absolute; inset:-1px; border-radius:inherit; pointer-events:none;
  background: linear-gradient(135deg, transparent 60%, rgba(156,70,255,.35));
  opacity:0; transition:opacity .3s;
}
.card:hover{transform:translateY(-4px); border-color:rgba(156,70,255,.55); box-shadow: var(--shadow-md)}
.card:hover::before{opacity:1}
.card img{
  width:100%; height:180px; object-fit:contain;
  background:rgba(0,0,0,.18); border-radius:var(--radius-sm); margin-bottom:14px;
  transition: transform .35s ease;
}
.card:hover img{transform:scale(1.04)}
.card h3{margin:0 0 4px; font-size:18px}
.card p{margin:0; color:var(--text-dim); font-size:14px}
.card--cta{
  display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center;
  background:var(--grad-primary); border-color:transparent;
}
.card--cta h3, .card--cta p{color:#fff}
.card--cta .card__plus{
  font-size:60px; line-height:1; font-weight:200; color:#fff; opacity:.85; margin-bottom:6px;
}

/* ---------- Advantages ---------- */
.adv{padding:80px 0; background:linear-gradient(180deg, transparent, rgba(255,255,255,.02))}
.adv__grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:18px;
}
.adv__card{
  background: linear-gradient(180deg, rgba(40,16,80,.55), rgba(20,8,40,.4));
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:26px;
  transition: transform .25s, border-color .25s, box-shadow .25s;
}
.adv__card:hover{transform:translateY(-3px); border-color:rgba(255,138,31,.45); box-shadow:0 14px 36px rgba(255,138,31,.12)}
.adv__icon{
  width:52px; height:52px; border-radius:14px;
  display:grid; place-items:center;
  font-size:26px;
  background:var(--grad-primary);
  margin-bottom:14px;
}
.adv__card h3{margin-bottom:6px}
.adv__card p{margin:0; color:var(--text-dim); font-size:15px}

/* ---------- Price magnet ---------- */
.price{
  padding:90px 0;
  background:
    radial-gradient(900px 500px at 100% 0%, rgba(255,138,31,.18), transparent 60%),
    linear-gradient(180deg, #14062c, #0e0521);
  border-block:1px solid var(--line);
}
.price__wrap{
  display:grid; grid-template-columns: 1.1fr .9fr; gap:48px; align-items:center;
}
.price__points{list-style:none; padding:0; margin:18px 0 0; display:grid; gap:10px}
.price__points li{
  background:rgba(255,255,255,.04); padding:12px 14px; border-radius:12px;
  border:1px solid var(--line); color:var(--text-dim); font-size:15px;
}
.price__form{
  background:rgba(255,255,255,.04);
  border:1px solid var(--line-strong);
  border-radius:22px;
  padding:28px;
  box-shadow: var(--shadow-lg);
}
.price__form h3{margin:0 0 16px}
.price__direct{display:inline-block; margin-top:14px; color:var(--accent-2); font-weight:600; font-size:14px; text-decoration:underline; text-decoration-color:rgba(255,180,90,.4)}
.price__direct:hover{text-decoration-color:var(--accent-2)}
.price__direct--tg{display:block; margin-top:8px; color:#5bc0f0; text-decoration-color:rgba(91,192,240,.4)}
.price__direct--tg:hover{text-decoration-color:#5bc0f0}

/* ---------- Discounts ladder ---------- */
.discounts{padding:90px 0}
.ladder{
  display:grid; grid-template-columns:repeat(3,1fr); gap:18px;
  margin-top:30px;
  align-items:end;
}
.ladder__step{
  position:relative;
  text-align:center;
  padding:24px 18px 30px;
  border-radius:var(--radius);
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  overflow:hidden;
}
.ladder__bar{
  height:8px; width:100%; border-radius:99px;
  background:linear-gradient(90deg, var(--primary), var(--primary-2));
  margin-bottom:18px;
}
.ladder__step--1{}
.ladder__step--2{padding-top:36px; background:linear-gradient(180deg, rgba(156,70,255,.14), rgba(20,8,40,.4)); border-color:rgba(156,70,255,.4)}
.ladder__step--2 .ladder__bar{background:linear-gradient(90deg, var(--primary-2), var(--accent))}
.ladder__step--3{padding-top:48px; background:linear-gradient(180deg, rgba(255,138,31,.16), rgba(20,8,40,.4)); border-color:rgba(255,138,31,.45)}
.ladder__step--3 .ladder__bar{background:var(--grad-accent)}
.ladder__pct{
  font-family:var(--font-display); font-weight:800; font-size:clamp(40px,5vw,64px);
  background:var(--grad-mix); -webkit-background-clip:text; background-clip:text; color:transparent;
  line-height:1; margin-bottom:8px;
}
.ladder__sum{color:var(--text-dim); font-weight:600; font-size:15px}
.ladder__badge{
  display:inline-block; margin-top:14px; padding:6px 12px;
  font-size:12px; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  border-radius:99px; background:rgba(52,211,153,.16); color:var(--success);
  border:1px solid rgba(52,211,153,.32);
}
.ladder__badge--top{background:var(--grad-accent); color:#1a0a00; border-color:transparent}

.first-order{
  display:flex; align-items:center; gap:16px;
  max-width:680px; margin:28px auto 0;
  padding:18px 22px;
  border-radius:16px;
  background:linear-gradient(90deg, rgba(52,211,153,.10), rgba(255,138,31,.10));
  border:1px solid rgba(52,211,153,.32);
  color:var(--text);
}
.first-order__icon{font-size:30px; flex:0 0 auto}
.first-order b{color:#fff}
.first-order em{font-style:normal; color:var(--text-dim); font-size:14px}

.discounts__note{text-align:center; color:var(--muted); font-size:13px; margin-top:18px}

/* ---------- Process / Steps ---------- */
.process{padding:90px 0; background:linear-gradient(180deg, transparent, rgba(255,255,255,.02))}
.steps{list-style:none; padding:0; margin:0; display:grid; grid-template-columns:repeat(4,1fr); gap:18px; counter-reset:steps}
.steps__item{
  position:relative;
  background:linear-gradient(180deg, rgba(40,16,80,.6), rgba(20,8,40,.4));
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:24px;
}
.steps__num{
  position:absolute; top:-18px; right:14px;
  font-family:var(--font-display); font-weight:800; font-size:48px;
  background:var(--grad-mix); -webkit-background-clip:text; background-clip:text; color:transparent;
  opacity:.55; letter-spacing:-.04em;
}
.steps__item h3{margin:8px 0 6px; font-size:18px}
.steps__item p{margin:0; color:var(--text-dim); font-size:14px}

/* ---------- Reviews ---------- */
.reviews{padding:90px 0}
.reviews__grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.review{
  margin:0; background:linear-gradient(180deg, rgba(40,16,80,.55), rgba(20,8,40,.4));
  border:1px solid var(--line); border-radius:var(--radius); padding:24px;
}
.review blockquote{margin:0 0 16px; font-size:16px; color:var(--text); line-height:1.55}
.review__name{display:block; font-weight:700; color:#fff}
.review__role{display:block; color:var(--text-dim); font-size:13px}
.reviews__note{text-align:center; color:var(--muted); margin-top:18px}

/* ---------- Lead form ---------- */
.lead{
  padding:90px 0;
  background:
    radial-gradient(800px 400px at 10% 50%, rgba(156,70,255,.22), transparent 60%),
    linear-gradient(180deg, #0e0521, #14062c);
  border-block:1px solid var(--line);
}
.lead__inner{display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center}
.lead__bullets{list-style:none; padding:0; margin:18px 0 0; color:var(--text-dim)}
.lead__bullets li{padding:8px 0}
.lead__form{background:rgba(255,255,255,.04); border:1px solid var(--line-strong); border-radius:22px; padding:28px; box-shadow:var(--shadow-lg)}

/* ---------- FAQ ---------- */
.faq{padding:90px 0}
.faq__list{display:grid; gap:12px; max-width:880px; margin-inline:auto}
.faq__item{
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
  transition: border-color .25s;
}
.faq__item[open]{border-color:rgba(156,70,255,.45)}
.faq__item>summary{
  list-style:none;
  padding:18px 22px;
  font-weight:600; font-size:17px;
  cursor:pointer;
  display:flex; align-items:center; gap:12px;
  position:relative;
}
.faq__item>summary::-webkit-details-marker{display:none}
.faq__item>summary::after{
  content:""; margin-left:auto; width:22px; height:22px;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23b5a8cc' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") center/contain no-repeat;
  transition: transform .25s;
}
.faq__item[open]>summary::after{transform:rotate(180deg)}
.faq__body{padding:0 22px 20px}
.faq__body p{margin:0; color:var(--text-dim)}

/* ---------- Contacts ---------- */
.contacts{padding:90px 0; background:linear-gradient(180deg, transparent, rgba(255,255,255,.02))}
.contacts__grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-bottom:28px}
.contacts__card{
  background:linear-gradient(180deg, rgba(40,16,80,.6), rgba(20,8,40,.4));
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:22px;
  transition:transform .25s, border-color .25s;
}
.contacts__card[href]:hover{transform:translateY(-3px); border-color:rgba(255,138,31,.45)}
.contacts__ico{font-size:26px; margin-bottom:6px}
.contacts__lbl{color:var(--text-dim); font-size:13px; margin-bottom:2px}
.contacts__val{font-weight:700; font-size:18px}

.contacts__map{
  position:relative; display:grid; grid-template-columns:2fr 1fr; gap:0;
  border-radius:var(--radius); overflow:hidden; border:1px solid var(--line);
}
.contacts__map iframe{width:100%; height:420px; border:0; background:#0c0420}
.contacts__addr{
  padding:24px; background:linear-gradient(180deg, rgba(40,16,80,.6), rgba(20,8,40,.5));
  display:flex; align-items:center;
}
.contacts__addr b{display:block; margin-bottom:8px; font-family:var(--font-display); font-size:18px}

/* ---------- Footer ---------- */
.footer{
  padding:60px 0 24px;
  background:#080315;
  border-top:1px solid var(--line);
}
.footer__grid{display:grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap:28px; margin-bottom:30px}
.footer__brand p{color:var(--text-dim); font-size:14px; margin-top:14px; max-width:300px}
.footer__col{display:flex; flex-direction:column; gap:10px}
.footer__col h4{margin:0 0 8px; font-family:var(--font-display); font-size:14px; letter-spacing:.12em; text-transform:uppercase; color:#fff}
.footer__col a, .footer__col span{color:var(--text-dim); font-size:14px; transition:color .2s}
.footer__col a:hover{color:var(--accent-2)}
.footer__bottom{
  display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap;
  padding-top:20px; border-top:1px solid var(--line);
  font-size:13px; color:var(--muted);
}

/* ---------- Sticky CTA (mobile) ---------- */
.sticky-cta{
  position:fixed; left:12px; right:12px; bottom:12px; z-index:60;
  display:none;
  gap:10px;
  padding:8px;
  background:rgba(11,6,18,.92);
  border:1px solid var(--line-strong);
  border-radius:18px;
  backdrop-filter:blur(14px);
  box-shadow: 0 20px 50px rgba(0,0,0,.6);
}
.sticky-cta__btn{
  flex:1; display:inline-flex; align-items:center; justify-content:center;
  padding:14px 12px; border-radius:12px; font-weight:700; font-size:14px; text-align:center;
}
.sticky-cta__btn--main{background:var(--grad-primary); color:#fff; flex:2}
.sticky-cta__btn--lead{background:var(--grad-accent); color:#1a0a00}
.sticky-cta__btn--call{background:rgba(255,255,255,.08); color:#fff; flex:0 0 48px; font-size:18px}

/* ---------- Toast ---------- */
.toast{
  position:fixed; left:50%; bottom:24px; transform:translate(-50%, 30px);
  background:#1a0b30; border:1px solid var(--line-strong); border-radius:12px;
  padding:14px 18px; color:#fff; font-size:14px; max-width:90vw;
  box-shadow: var(--shadow-lg);
  opacity:0; pointer-events:none; transition: transform .35s, opacity .35s; z-index:90;
}
.toast.is-show{transform:translate(-50%, 0); opacity:1; pointer-events:auto}
.toast--ok{border-color:rgba(52,211,153,.5)}
.toast--err{border-color:rgba(239,68,68,.5)}

/* ---------- Animations on view ---------- */
@media (prefers-reduced-motion: no-preference){
  .reveal{opacity:0; transform:translateY(14px); transition: opacity .6s ease, transform .6s ease}
  .reveal.is-in{opacity:1; transform:none}
}

/* ---------- Responsive ---------- */
@media (max-width: 1100px){
  .nav{display:none}
  .burger{display:flex}
  .header-cta .btn--ghost{display:none}
  .nav.is-open{
    display:flex; flex-direction:column; gap:0;
    position:absolute; top:100%; left:0; right:0;
    background:rgba(11,6,18,.98); border-top:1px solid var(--line);
    padding:12px 0;
  }
  .nav.is-open a{padding:14px var(--pad); border-bottom:1px solid var(--line)}
  .cards, .cards--icons, .adv__grid, .steps, .reviews__grid, .contacts__grid{grid-template-columns:repeat(2,1fr)}
  .logo-wall{grid-template-columns:repeat(4,1fr)}
  .footer__grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 880px){
  .hero__inner, .price__wrap, .lead__inner{grid-template-columns:1fr; gap:28px}
  .hero{padding-top:36px}
  .trust{grid-template-columns:repeat(3,1fr)}
  .trust__item:nth-child(n+4){display:none}
  .ladder{grid-template-columns:1fr; gap:14px}
  .contacts__map{grid-template-columns:1fr}
  .contacts__map iframe{height:300px}
  .sticky-cta{display:flex}
  body{padding-bottom:84px}
  .first-order{flex-direction:column; align-items:flex-start; text-align:left}
}
@media (max-width: 560px){
  .cards, .cards--icons, .adv__grid, .steps, .reviews__grid, .contacts__grid{grid-template-columns:1fr}
  .logo-wall{grid-template-columns:repeat(3,1fr)}
  .footer__grid{grid-template-columns:1fr}
  .top-bar__item:nth-child(2){display:none}
  .hero__cta .btn{width:100%}
  .hero__bullets{flex-direction:column; gap:6px}
}

/* =====================================================
   ENHANCEMENTS v2 — эффекты, анимации, мобайл-полировка
   ===================================================== */

/* Tabular numbers for counters */
.count{font-variant-numeric:tabular-nums; font-feature-settings:"tnum"}

/* ---------- Scroll progress ---------- */
.scroll-progress{
  position:fixed; top:0; left:0; height:3px; width:0%;
  z-index:100; pointer-events:none;
  background:var(--grad-mix);
  box-shadow:0 0 12px rgba(156,70,255,.7);
  transition:width .08s linear;
}

/* ---------- Cursor glow (desktop only) ---------- */
.cursor-glow{
  position:fixed; top:0; left:0; width:520px; height:520px;
  margin:-260px 0 0 -260px; border-radius:50%;
  z-index:0; pointer-events:none; opacity:0;
  background:radial-gradient(circle, rgba(156,70,255,.16), rgba(255,138,31,.06) 40%, transparent 65%);
  transition:opacity .4s ease;
  mix-blend-mode:screen;
  will-change:transform;
}
@media (hover:hover) and (pointer:fine){ .cursor-glow.is-on{opacity:1} }

/* ---------- HERO showcase (парящие телефоны) ---------- */
.hero__inner{align-items:center}
.hero__inner>*{min-width:0}            /* чтобы колонки грида могли сжиматься */
.hero__copy{min-width:0}
.hero__phones{min-width:0}
.hero__showcase picture{display:contents}
.price__wrap>*, .lead__inner>*{min-width:0}
.hero__right{display:flex; flex-direction:column; gap:22px; min-width:0}
.hero__showcase{
  position:relative; margin:0;
  min-height:300px;
  display:grid; place-items:center;
  perspective:1200px;
}
.hero__glow{
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(closest-side, rgba(156,70,255,.42), transparent 72%),
    radial-gradient(closest-side, rgba(255,138,31,.28), transparent 70%);
  background-position:42% 40%, 70% 70%;
  background-repeat:no-repeat;
  background-size:80% 80%, 55% 55%;
  filter:blur(8px);
  animation:glowPulse 7s ease-in-out infinite;
}
@keyframes glowPulse{0%,100%{opacity:.75; transform:scale(1)} 50%{opacity:1; transform:scale(1.06)}}
.hero__phones{
  position:relative; z-index:1;
  width:min(100%, 460px); height:auto;
  filter:drop-shadow(0 30px 50px rgba(0,0,0,.55)) drop-shadow(0 0 30px rgba(156,70,255,.25));
  animation:phoneFloat 6s ease-in-out infinite;
  transform-style:preserve-3d;
  will-change:transform;
}
@keyframes phoneFloat{0%,100%{transform:translateY(0) rotateZ(0)} 50%{transform:translateY(-14px) rotateZ(-.4deg)}}
.chip{
  position:absolute; z-index:2;
  display:flex; flex-direction:column; gap:1px;
  padding:10px 14px; border-radius:14px;
  background:rgba(20,8,40,.72);
  border:1px solid var(--line-strong);
  backdrop-filter:blur(10px);
  box-shadow:0 12px 30px rgba(0,0,0,.45);
  animation:chipFloat 5s ease-in-out infinite;
  will-change:transform;
}
.chip b{font-family:var(--font-display); font-weight:800; font-size:18px; line-height:1;
  background:var(--grad-mix); -webkit-background-clip:text; background-clip:text; color:transparent}
.chip i{font-style:normal; font-size:11px; color:var(--text-dim); letter-spacing:.02em}
.chip--a{top:6%; left:-4%; animation-delay:-.5s}
.chip--b{top:42%; right:-6%; animation-delay:-1.8s}
.chip--b b{background:var(--grad-accent); -webkit-background-clip:text; background-clip:text}
.chip--c{bottom:6%; left:6%; animation-delay:-3s}
@keyframes chipFloat{0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)}}

/* ---------- Brands marquee ---------- */
.brands__marquee{
  position:relative; overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
  mask-image:linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
}
.brands__track{
  display:inline-flex; gap:54px; align-items:center;
  white-space:nowrap; will-change:transform;
  font-family:var(--font-display); font-weight:700;
  font-size:clamp(18px, 2vw, 24px); color:var(--text-dim);
  animation:marquee 26s linear infinite;
}
.brands__marquee:hover .brands__track{animation-play-state:paused}
.brands__track span{transition:color .2s; padding:6px 0}
.brands__track span:hover{color:#fff}
@keyframes marquee{from{transform:translateX(0)} to{transform:translateX(-50%)}}

/* ---------- Gradient text shimmer ---------- */
.grad, .grad-2, .trust__item b, .ladder__pct, .logo__text b{
  background-size:200% auto;
}
.grad{animation:shimmer 6s linear infinite}
@keyframes shimmer{to{background-position:200% center}}

/* ---------- Buttons: shine sweep + magnetic ---------- */
.btn{position:relative; overflow:hidden; will-change:transform}
.btn::after{
  content:""; position:absolute; top:0; left:-120%;
  width:60%; height:100%;
  background:linear-gradient(120deg, transparent, rgba(255,255,255,.35), transparent);
  transform:skewX(-18deg); transition:none; pointer-events:none;
}
.btn:hover::after{animation:shine .7s ease}
@keyframes shine{from{left:-120%} to{left:140%}}

/* ---------- Interactive tilt cards ---------- */
.ic-card, .adv__card, .steps__item, .contacts__card, .review{
  transform-style:preserve-3d;
  will-change:transform;
}
/* JS sets --mx/--my (0..100%) for spotlight follow */
.ic-card{--mx:50%; --my:0%}
.ic-card::after{
  content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  background:radial-gradient(220px circle at var(--mx) var(--my), rgba(156,70,255,.18), transparent 60%);
  opacity:0; transition:opacity .3s;
}
.ic-card:hover::after{opacity:1}

/* ---------- Reveal variants + stagger ---------- */
@media (prefers-reduced-motion: no-preference){
  .reveal{opacity:0; transform:translateY(22px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1)}
  .reveal--left{transform:translateX(-28px)}
  .reveal--right{transform:translateX(28px)}
  .reveal--scale{transform:scale(.94)}
  .reveal.is-in{opacity:1; transform:none}
  /* hero entrance */
  .hero__copy>*{opacity:0; transform:translateY(20px); animation:heroIn .8s cubic-bezier(.2,.7,.2,1) forwards}
  .hero__copy .eyebrow{animation-delay:.05s}
  .hero__copy h1{animation-delay:.16s}
  .hero__copy .hero__lead{animation-delay:.28s}
  .hero__copy .hero__cta{animation-delay:.4s}
  .hero__copy .hero__bullets{animation-delay:.52s}
  .hero__right{opacity:0; transform:translateY(24px) scale(.98); animation:heroIn .9s cubic-bezier(.2,.7,.2,1) .35s forwards}
  @keyframes heroIn{to{opacity:1; transform:none}}
}

/* ---------- Section heading accent underline ---------- */
.section-head h2{position:relative; display:inline-block}

/* ---------- Product gallery (реальные фото товара) ---------- */
.gallery{padding:20px 0 92px}
.gallery__grid{ column-count:3; column-gap:16px; }
.gcard{
  display:block; break-inside:avoid; margin:0 0 16px;
  position:relative; overflow:hidden;
  border-radius:var(--radius);
  border:1px solid var(--line);
  background:#1a0b30;
  box-shadow:0 10px 30px rgba(0,0,0,.35);
  transition:transform .3s, box-shadow .3s, border-color .3s;
  will-change:transform;
}
.gcard img{ width:100%; height:auto; display:block; }
.gcard:hover{transform:translateY(-4px); border-color:rgba(156,70,255,.6); box-shadow:0 22px 50px rgba(106,37,194,.4)}
.gallery__note{text-align:center; color:var(--muted); font-size:13px; margin:22px 0 0}
.gallery__cta{display:flex; justify-content:center; margin-top:26px}
@media (max-width:900px){ .gallery__grid{column-count:2} }
@media (max-width:520px){ .gallery__grid{column-count:1} }

/* ---------- Floating messengers ---------- */
.msg-fab{position:fixed; right:18px; bottom:24px; z-index:70; display:flex; flex-direction:column; gap:12px}
.msg-fab__btn{
  position:relative; width:54px; height:54px; border-radius:50%;
  display:grid; place-items:center; color:#fff;
  box-shadow:0 10px 26px rgba(0,0,0,.4);
  transition:transform .2s, box-shadow .25s;
}
.msg-fab__btn--wa{background:#25d366}
.msg-fab__btn--tg{background:#2aabee}
.msg-fab__btn--vb{background:#7360f2}
.msg-fab__btn--vb::after{animation:vbPulse 2.6s ease-out infinite 1.2s}
@keyframes vbPulse{0%{box-shadow:0 0 0 0 rgba(115,96,242,.55)} 80%,100%{box-shadow:0 0 0 15px rgba(115,96,242,0)}}
.msg-fab__btn:hover{transform:translateY(-3px) scale(1.07); box-shadow:0 16px 34px rgba(0,0,0,.5)}
.msg-fab__btn::after{content:""; position:absolute; inset:0; border-radius:50%; pointer-events:none}
.msg-fab__btn--wa::after{animation:waPulse 2.6s ease-out infinite}
.msg-fab__btn--tg::after{animation:tgPulse 2.6s ease-out infinite .6s}
@keyframes waPulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.55)} 80%,100%{box-shadow:0 0 0 15px rgba(37,211,102,0)}}
@keyframes tgPulse{0%{box-shadow:0 0 0 0 rgba(42,171,238,.55)} 80%,100%{box-shadow:0 0 0 15px rgba(42,171,238,0)}}
@media (max-width:880px){ .msg-fab{bottom:90px; right:12px} .msg-fab__btn{width:50px; height:50px} }
@media (prefers-reduced-motion: reduce){ .msg-fab__btn::after{animation:none} }
@media print{ .msg-fab{display:none} }

/* footer legal + map link */
.footer__legal{color:var(--muted); font-size:12.5px; margin-top:10px; max-width:320px; line-height:1.5}
.contacts__maplink{display:inline-block; margin-top:12px; color:var(--accent-2); font-weight:600; font-size:14px}
.contacts__maplink:hover{text-decoration:underline}

/* ---------- Новые поступления (фишка со старого сайта) ---------- */
.news{padding:14px 0 92px}
.news__grid{display:grid; grid-template-columns:repeat(4,1fr); gap:16px}
.news-card{
  position:relative; display:flex; flex-direction:column; gap:6px;
  padding:20px; border-radius:var(--radius); color:inherit; overflow:hidden;
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  transition:transform .25s, border-color .25s, box-shadow .25s; will-change:transform;
}
.news-card:hover{transform:translateY(-4px); border-color:rgba(156,70,255,.5); box-shadow:var(--shadow-md)}
.news-card__top{display:flex; align-items:center; justify-content:space-between; gap:8px; margin-bottom:6px}
.news-card__badge{font-size:11px; font-weight:800; letter-spacing:.05em; text-transform:uppercase; padding:4px 10px; border-radius:99px; background:var(--grad-accent); color:#1a0a00}
.news-card__tag{font-size:12px; color:var(--success); font-weight:600}
.news-card__ico{width:46px; height:46px; border-radius:12px; display:grid; place-items:center; background:linear-gradient(135deg, rgba(156,70,255,.22), rgba(255,138,31,.18)); border:1px solid rgba(156,70,255,.35); color:var(--primary-2)}
.news-card__ico svg{width:26px; height:26px}
.news-card h3{margin:8px 0 0; font-size:15.5px; line-height:1.25}
.news-card__more{margin-top:auto; padding-top:8px; color:var(--accent-2); font-weight:600; font-size:13px}
@media (max-width:1100px){ .news__grid{grid-template-columns:repeat(3,1fr)} }
@media (max-width:760px){ .news__grid{grid-template-columns:repeat(2,1fr); gap:12px} }
@media (max-width:380px){ .news__grid{grid-template-columns:1fr} }

/* ---------- Подписка на рассылку (фишка со старого сайта) ---------- */
.subscribe{padding:0 0 90px}
.subscribe__inner{
  position:relative; overflow:hidden;
  display:grid; grid-template-columns:1.1fr .9fr; gap:32px; align-items:center;
  padding:clamp(28px,4vw,48px);
  border-radius:26px; border:1px solid var(--line-strong);
  background:radial-gradient(700px 300px at 0% 0%, rgba(156,70,255,.22), transparent 60%), linear-gradient(180deg, rgba(40,16,80,.6), rgba(20,8,40,.5));
  box-shadow:var(--shadow-lg);
}
.subscribe h2{margin:0 0 8px}
.subscribe p{color:var(--text-dim); margin:0; max-width:520px}
.subscribe__form{display:flex; gap:10px; flex-wrap:wrap}
.subscribe__form input{flex:1; min-width:200px; padding:15px 16px; border-radius:13px; border:1px solid var(--line-strong); background:rgba(0,0,0,.28); color:var(--text); font-size:15px}
.subscribe__form input:focus{outline:none; border-color:var(--primary-2); box-shadow:0 0 0 3px rgba(156,70,255,.22)}
.subscribe__tg{display:inline-flex; align-items:center; gap:8px; margin-top:14px; color:#5bc0f0; font-weight:600; font-size:14px}
.subscribe__note{margin-top:10px; font-size:12px; color:var(--muted)}
@media (max-width:880px){ .subscribe__inner{grid-template-columns:1fr; gap:18px} }

/* =====================================================
   MOBILE POLISH
   ===================================================== */
@media (max-width: 1100px){
  .hero__showcase{min-height:240px}
  .hero__phones{width:min(78%, 380px)}
}
@media (max-width: 880px){
  .hero{padding-top:30px}
  /* единая колонка, способная сжиматься ниже min-content картинки */
  .hero__inner, .price__wrap, .lead__inner{grid-template-columns:minmax(0,1fr)}
  .hero__inner{padding-block:8px 24px}
  .hero__right{gap:18px}
  .hero__showcase{min-height:230px; margin-top:4px}
  .hero__phones{width:min(70%, 330px)}
  .chip{padding:8px 12px}
  .chip b{font-size:16px}
  .chip--a{left:0}
  .chip--b{right:-2%}
  .brands__track{gap:38px}
  /* show 4 trust items in 2x2 nicely */
  .trust{grid-template-columns:repeat(2,1fr); gap:8px; padding:18px 10px}
  .trust__item:nth-child(n+4){display:none}
}
@media (max-width: 560px){
  body{font-size:16px}
  h1{font-size:clamp(30px, 8.5vw, 42px)}
  h2{font-size:clamp(25px, 6.6vw, 34px)}
  .container{--pad:18px}
  .top-bar__row{justify-content:center; gap:6px 14px; font-size:12px}
  .top-bar__item:first-child{flex-basis:100%; text-align:center}
  .site-header__row{gap:12px}
  .header-cta .btn--primary{padding:9px 13px; font-size:13px}
  .hero{padding-top:22px}
  .hero__showcase{min-height:210px}
  .hero__phones{width:min(72%, 290px)}
  .chip--c{bottom:0; left:0}
  .hero__card{padding:20px; border-radius:20px}
  .hero__bullets{gap:8px}
  .trust{grid-template-columns:repeat(2,1fr)}
  .trust__item b{font-size:clamp(22px,7vw,28px)}
  /* tighter section paddings */
  .catalog,.clients,.adv,.price,.discounts,.process,.reviews,.lead,.faq,.contacts{padding-top:56px; padding-bottom:56px}
  .ic-card{min-height:auto; padding:18px}
  .ic-card__ico{width:46px; height:46px}
  .ic-card__ico svg{width:26px; height:26px}
  .adv__card,.steps__item,.review,.contacts__card,.price__form,.lead__form,.hero__card{padding:20px}
  .section-head{margin-bottom:26px}
  .faq__item>summary{font-size:15.5px; padding:16px 18px}
  /* sticky CTA breathing room above */
  body{padding-bottom:88px}
  /* make tap targets comfy */
  .nav.is-open a{padding:16px var(--pad)}
  .contacts__card{display:flex; flex-direction:column; align-items:flex-start}
}
@media (max-width: 380px){
  .chip--a, .chip--c{display:none}
  .hero__phones{width:78%}
}

/* ---------- Reduced motion: calm everything ---------- */
@media (prefers-reduced-motion: reduce){
  .orb,.hero__phones,.hero__glow,.chip,.brands__track,.grad,.dot{animation:none !important}
  .scroll-progress{transition:none}
  .cursor-glow{display:none}
  *{scroll-behavior:auto}
}

/* ---------- Print ---------- */
@media print{
  .top-bar, .site-header, .sticky-cta, .hero__bg, .toast, .contacts__map,
  .scroll-progress, .cursor-glow, .hero__showcase{display:none}
  body{background:#fff; color:#000}
}

/* =====================================================
   USP — «новинки первыми на рынке» (фирменный блок 9/10)
   ===================================================== */
.usp{padding:60px 0}
.usp__inner{
  position:relative; overflow:hidden;
  display:grid; grid-template-columns:1.18fr .82fr; gap:40px; align-items:center;
  padding:clamp(26px,4vw,46px);
  border-radius:26px; border:1px solid var(--line-strong);
  background:
    radial-gradient(640px 280px at 0% 0%, rgba(255,138,31,.16), transparent 60%),
    radial-gradient(700px 320px at 100% 100%, rgba(156,70,255,.24), transparent 62%),
    linear-gradient(180deg, rgba(40,16,80,.62), rgba(20,8,40,.55));
  box-shadow:var(--shadow-lg);
}
/* «скоростные» диагональные штрихи — ощущение опережения */
.usp__inner::before{
  content:""; position:absolute; inset:0; pointer-events:none; opacity:.6;
  background:repeating-linear-gradient(116deg, transparent 0 40px, rgba(255,255,255,.035) 40px 41px);
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 35%, transparent);
  mask-image:linear-gradient(90deg, transparent, #000 35%, transparent);
}
.usp__copy{position:relative; z-index:1; min-width:0}
.usp__copy h2{margin:0 0 12px}
.usp__lead{color:var(--text-dim); font-size:clamp(15px,1.5vw,18px); max-width:580px; margin:0 0 22px}
.usp__cta{display:flex; gap:12px; flex-wrap:wrap}

.usp__stat{
  position:relative; z-index:1; text-align:center;
  padding:26px 22px; border-radius:20px;
  border:1px solid var(--line-strong);
  background:linear-gradient(180deg, rgba(0,0,0,.30), rgba(0,0,0,.14));
  backdrop-filter:blur(8px);
}
.usp__ratio{display:flex; align-items:baseline; justify-content:center; line-height:1}
.usp__num{
  font-family:var(--font-display); font-weight:800; font-size:clamp(76px,12vw,128px);
  letter-spacing:-.05em;
  background:var(--grad-accent); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.usp__den{font-family:var(--font-display); font-weight:700; font-size:clamp(28px,4.4vw,44px); color:var(--text-dim)}
.usp__dots{display:flex; justify-content:center; flex-wrap:wrap; gap:8px; margin:14px 0 16px}
.usp__dots i{
  width:14px; height:14px; border-radius:50%;
  background:rgba(255,255,255,.10); border:1px solid var(--line-strong);
  transition:transform .25s;
}
.usp__dots i.on{
  background:var(--grad-accent); border-color:transparent;
  box-shadow:0 0 10px rgba(255,138,31,.55);
}
.usp__statlabel{margin:0; color:var(--text-dim); font-size:14px; line-height:1.5}
.usp__statlabel b{color:#fff}
@media (max-width:880px){
  .usp__inner{grid-template-columns:1fr; gap:24px}
}
@media (max-width:560px){
  .usp{padding:44px 0}
  .usp__cta .btn{width:100%}
  .usp__num{font-size:clamp(64px,20vw,96px)}
}

/* ---------- Polish: якорный отступ + акцент под заголовками секций ---------- */
section[id]{scroll-margin-top:84px}
.section-head h2::after{
  content:""; display:block; height:4px; width:88px; margin-top:16px;
  border-radius:99px; background:var(--grad-mix);
}
.section-head--center h2::after{margin-left:auto; margin-right:auto}

/* ---------- Turnstile (капча) ---------- */
/* капча невидима (execute + interaction-only); место не занимает */
.ts-slot{margin:0}
.ts-slot:empty{display:none}

/* ---------- Согласия в формах ---------- */
.check a{color:var(--accent-2); text-decoration:underline; text-decoration-color:rgba(255,180,90,.5)}
.check a:hover{text-decoration-color:var(--accent-2)}
.check.field--error span{color:var(--danger)}
.footer__bottom a{color:var(--text-dim); text-decoration:underline; text-decoration-color:rgba(255,255,255,.25)}
.footer__bottom a:hover{color:#fff}
