/* ============================================================
   MFM CONSTRUCTOR — BASE + COMPONENTS + SECTIONS
   Все секции используют эти классы. Стиль управляется токенами (tokens.css).
   ============================================================ */

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--font-body); font-size:17px; line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img,svg,video{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--accent); color:var(--accent-ink); }

/* --- сетка / контейнер --- */
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:var(--s-7); background:var(--bg); color:var(--ink); }
.section--alt{ background:var(--bg-alt); }
.section--dark{ background:var(--dark); color:var(--on-dark); }
.section--dark .muted{ color:var(--on-dark-mut); }
.section--tight{ padding-block:var(--s-6); }

/* --- типографика --- */
.eyebrow{
  font-family:var(--font-head); font-weight:700; font-size:13px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--accent); margin:0 0 14px;
}
.section--dark .eyebrow{ color:var(--accent); }
h1,h2,h3{ font-family:var(--font-head); font-weight:var(--fw-head); letter-spacing:var(--tracking-head); line-height:1.05; text-transform:uppercase; margin:0 0 .4em; }
h1{ font-size:clamp(34px, 6vw, 64px); }
h2{ font-size:clamp(28px, 4.4vw, 46px); }
h3{ font-size:clamp(19px, 2.4vw, 24px); line-height:1.15; }
p{ margin:0 0 1em; }
.lead{ font-size:clamp(17px,2.1vw,21px); color:var(--muted); max-width:62ch; }
.muted{ color:var(--muted); }
.hl{ background:var(--accent); color:var(--accent-ink); padding:0 .18em; border-radius:6px;
     -webkit-box-decoration-break:clone; box-decoration-break:clone; }
.center{ text-align:center; } .mx-auto{ margin-inline:auto; }

/* --- кнопки --- */
.btn{
  display:inline-flex; align-items:center; gap:10px; cursor:pointer; border:0;
  font-family:var(--font-head); font-weight:700; text-transform:uppercase; letter-spacing:.04em;
  font-size:15px; padding:15px 26px; border-radius:12px; transition:transform .15s ease, filter .15s ease, background .15s ease;
}
.btn:hover{ transform:translateY(-1px) scale(1.015); }
.btn--primary{ background:var(--accent); color:var(--accent-ink); box-shadow:var(--shadow-sm); }
.btn--primary:hover{ filter:brightness(1.05); }
.btn--ghost{ background:transparent; color:var(--ink); border:1.5px solid var(--line); }
.section--dark .btn--ghost{ color:var(--on-dark); border-color:rgba(255,255,255,.22); }
.btn .iconify{ font-size:1.15em; }

/* --- бейдж-пилюля --- */
.badge{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-head); font-weight:700; font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  background:var(--accent); color:var(--accent-ink); padding:7px 14px; border-radius:var(--radius-pill);
}
.badge--soft{ background:var(--accent-soft); color:var(--accent); }
.badge--num{ background:var(--accent); color:var(--accent-ink); min-width:34px; height:34px; justify-content:center; border-radius:9px; font-size:15px; }

/* --- карточки / сетки --- */
.grid{ display:grid; gap:clamp(16px,2.2vw,24px); }
.grid-2{ grid-template-columns:repeat(2,1fr); }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-4{ grid-template-columns:repeat(4,1fr); }
.card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:clamp(20px,2.6vw,30px); box-shadow:var(--shadow-sm);
}
.section--dark .card{ background:var(--dark-alt); border-color:rgba(255,255,255,.08); }

/* иконка-бокс */
.iconbox{ display:flex; flex-direction:column; gap:12px; }
.iconbox__ic{ width:52px; height:52px; display:grid; place-items:center; border-radius:13px;
  background:var(--accent-soft); color:var(--accent); font-size:26px; }
[data-brand="fixhub"] .iconbox__ic{ background:rgba(255,214,0,.14); color:var(--accent); }

/* --- header / nav --- */
.site-head{ position:sticky; top:0; z-index:50; backdrop-filter:saturate(140%) blur(10px);
  background:color-mix(in srgb, var(--bg) 82%, transparent); border-bottom:1px solid var(--line); }
.site-head .container{ display:flex; align-items:center; justify-content:space-between; height:68px; }
.brand{ display:flex; align-items:center; gap:10px; font-family:var(--font-head); font-weight:700; text-transform:uppercase; letter-spacing:.04em; }
.brand .mark{ display:flex; gap:3px; }
.brand .mark i{ width:6px; height:18px; background:var(--accent); transform:skewX(-18deg); display:block; }
.nav{ display:flex; gap:26px; align-items:center; }
.nav a{ font-size:14px; color:var(--muted); } .nav a:hover{ color:var(--ink); }
@media(max-width:780px){ .nav .nav__links{ display:none; } }

/* --- HERO --- */
.hero{ position:relative; overflow:hidden; padding-block:clamp(56px,9vw,120px); }
.hero__grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(24px,4vw,56px); align-items:center; }
.hero__title{ margin-bottom:.5em; }
.hero__media{ position:relative; }
.hero__media img{ width:100%; border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); aspect-ratio:16/11; object-fit:cover; }
.hero__media .ph{ aspect-ratio:16/11; border-radius:var(--radius-lg); background:
   linear-gradient(135deg, var(--accent-soft), transparent 60%), var(--dark-alt);
   display:grid; place-items:center; color:var(--on-dark-mut); box-shadow:var(--shadow-lg); }
.hero__cta{ display:flex; gap:14px; flex-wrap:wrap; margin-top:8px; }
.hero__trust{ display:flex; gap:22px; flex-wrap:wrap; margin-top:26px; color:var(--muted); font-size:14px; }
.hero__trust b{ color:var(--ink); font-family:var(--font-head); font-size:22px; display:block; }
@media(max-width:880px){ .hero__grid{ grid-template-columns:1fr; } }

/* --- TICKER (бегущая лента-пруф) --- */
.ticker{ background:var(--accent); color:var(--accent-ink); overflow:hidden; padding:12px 0; }
.ticker__row{ display:flex; gap:40px; white-space:nowrap; width:max-content; animation:ticker 28s linear infinite; font-family:var(--font-head); font-weight:700; text-transform:uppercase; letter-spacing:.06em; font-size:14px; }
.ticker__row span{ display:inline-flex; gap:40px; }
@keyframes ticker{ to{ transform:translateX(-50%); } }
@media(prefers-reduced-motion:reduce){ .ticker__row{ animation:none; } }

/* --- STEPS (3 шага) --- */
.step{ position:relative; }
.step__n{ font-family:var(--font-head); font-size:14px; }
.steps__line{ }

/* --- PRICING / тарифы --- */
.price{ display:flex; align-items:baseline; gap:6px; font-family:var(--font-head); }
.price__num{ font-size:44px; } .price__per{ color:var(--muted); font-size:15px; }
.tier{ position:relative; }
.tier--pop{ border-color:var(--accent); box-shadow:0 0 0 2px var(--accent) inset, var(--shadow); }
.tier ul{ list-style:none; padding:0; margin:18px 0; display:grid; gap:10px; }
.tier li{ display:flex; gap:10px; align-items:flex-start; font-size:15px; }
.tier li .iconify{ color:var(--accent); margin-top:3px; flex:none; }

/* --- TABLE сравнение --- */
.cmp{ width:100%; border-collapse:collapse; overflow:hidden; border-radius:var(--radius); }
.cmp th,.cmp td{ padding:14px 16px; text-align:left; border-bottom:1px solid var(--line); font-size:15px; }
.cmp thead th{ font-family:var(--font-head); text-transform:uppercase; font-size:13px; letter-spacing:.08em; }
.cmp .col-accent{ background:var(--accent-soft); color:var(--ink); font-weight:600; }
.cmp thead .col-accent{ color:var(--accent); }

/* --- FAQ аккордеон --- */
.faq__item{ border-bottom:1px solid var(--line); }
.faq__q{ width:100%; text-align:left; background:none; border:0; cursor:pointer; color:inherit;
  display:flex; justify-content:space-between; gap:16px; align-items:center; padding:20px 0; font-family:var(--font-head); text-transform:uppercase; font-size:17px; }
.faq__q .iconify{ transition:transform .25s ease; color:var(--accent); flex:none; }
.faq__item[open] .faq__q .iconify{ transform:rotate(45deg); }
.faq__a{ padding:0 0 20px; color:var(--muted); max-width:70ch; }

/* --- REVIEWS --- */
.review{ } .review__stars{ color:var(--accent); display:flex; gap:2px; margin-bottom:10px; }
.review__who{ display:flex; align-items:center; gap:12px; margin-top:16px; }
.review__ava{ width:42px; height:42px; border-radius:50%; background:var(--accent-soft); color:var(--accent);
  display:grid; place-items:center; font-family:var(--font-head); }

/* --- LEAD FORM --- */
.form{ display:grid; gap:14px; }
.field{ display:grid; gap:6px; }
.field label{ font-size:13px; color:var(--muted); }
.input,.textarea{ width:100%; font:inherit; color:var(--ink); background:var(--surface);
  border:1.5px solid var(--line); border-radius:12px; padding:13px 15px; }
.input:focus,.textarea:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-soft); }
.consent{ display:flex; gap:10px; align-items:flex-start; font-size:13px; color:var(--muted); }

/* --- FOOTER --- */
.site-foot{ background:var(--dark); color:var(--on-dark); padding-block:var(--s-6); }
.site-foot a{ color:var(--on-dark-mut); } .site-foot a:hover{ color:var(--on-dark); }
.foot-legal{ font-size:13px; color:var(--on-dark-mut); }

/* --- reveal на скролле ---
   Прячем ТОЛЬКО если JS включён (html.js). Без JS (краулеры/no-JS) контент виден — важно для SEO. */
.js [data-reveal]{ opacity:0; transform:translateY(18px); }
.js [data-reveal].is-in{ opacity:1; transform:none; transition:opacity .6s ease, transform .6s ease; }
@media(prefers-reduced-motion:reduce){ .js [data-reveal]{ opacity:1!important; transform:none!important; } }

/* --- responsive grids --- */
@media(max-width:900px){ .grid-4{ grid-template-columns:repeat(2,1fr); } .grid-3{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:620px){ .grid-2,.grid-3,.grid-4{ grid-template-columns:1fr; } h1{ font-size:34px; } }
