/* ===== Reset / base ===== */
*,*::before,*::after{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";
  font-size:16px; line-height:1.6; color:#0b1220;

  /* Больше НЕТ вертикального градиента на весь документ */
  background:
    radial-gradient(60% 40% at 80% -10%, rgba(124,58,237,.10), rgba(255,255,255,0) 60%) no-repeat,
    #ffffff;
}
img{max-width:100%;display:block}
a{text-decoration:none}

/* ===== Theme tokens ===== */
:root{
  --radius:16px;
  --radius-xl:26px;
 --header-h: 72px;
  --shadow-sm:0 4px 14px rgba(79,70,229,.12);
  --shadow-md:0 10px 30px rgba(79,70,229,.14);
  --shadow-lg:0 18px 40px rgba(79,70,229,.18);

  --container:1120px;

  --h1: clamp(36px, 6vw, 54px);
  --h2: clamp(24px, 3.2vw, 32px);
  --h3: clamp(18px, 2.2vw, 22px);
  --lead: clamp(16px, 2.2vw, 18px);

  --ink:#0b1220;
  --muted:#475569;
  --line:#dbe2f1;
  --link:#1f2a44;
  --brand:#4f46e5;
  --brand-2:#7c3aed;

  --bg:#ffffff;
  --bg-soft:#eef2ff;

  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:24px; --s-6:32px; --s-7:48px; --s-8:64px;

  --section-py: 96px;
  --section-py-sm: 72px;
  --section-gap: 0px;         /* пространственный «пояс» между секциями; оставим 0, фоны не просвечивают */
  --grid-gap: 28px;
}

.container{max-width:var(--container);margin-inline:auto;padding-inline:20px}

/* Типографика */
h1{font-size:var(--h1);line-height:1.12;margin:0 0 var(--s-2)}
h1 .gradient{
  background:linear-gradient(90deg,var(--brand),var(--brand-2));
  -webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent;display:inline-block;padding-bottom:2px
}
h2{font-size:var(--h2);line-height:1.15;margin:0 0 22px}
h3{font-size:var(--h3);margin:0}
p.lead{font-size:var(--lead);color:var(--muted);margin:8px 0 0}
.muted{color:var(--muted)}

/* ===== Sections ===== */
section{scroll-margin-top:84px}
.section{
  position:relative;
  padding:var(--section-py) 0;
  background:#fff;                 /* каждая секция перекрывает фон страницы */
}
.section + .section{ margin-top: var(--section-gap); }


.section.alt::before{
  content:"";
  position:absolute; inset:0; z-index:-1;
  background:linear-gradient(180deg,#fff 0%, var(--bg-soft) 100%);
  border-block:1px solid var(--line);
  /* никаких фиксированных высот! */
}

@media (max-width:760px){
  .section{ padding:var(--section-py-sm) 0 }
}

/* ===== Grid ===== */
.grid{display:grid;gap:var(--grid-gap);align-items:stretch}
@media(min-width:760px){
  .cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
}

/* ===== Header ===== */
/* 1) подними слой шапки — сейчас z-index:50 не хватает */
/* ===== Header (фиксированная шапка) ===== */
header{
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 9999;
  -webkit-backdrop-filter: saturate(180%) blur(8px);
  backdrop-filter: saturate(180%) blur(8px);
  background: rgba(255,255,255,.85);
  border-bottom: 1px solid var(--line);
  padding-top: env(safe-area-inset-top); /* iOS-«чёлка» */
}

/* отступ под фиксированную шапку */
body{
  padding-top: calc(var(--header-h) + env(safe-area-inset-top));
}

/* остальное оставляем как есть */
.header-row{display:flex;align-items:center;justify-content:space-between;padding-block:14px;gap:16px}
.brand{display:flex;align-items:center;gap:12px;color:var(--ink)}
.logo{width:34px;height:34px;border-radius:12px;background:linear-gradient(135deg,var(--brand),var(--brand-2))}
.nav{display:none;gap:22px;align-items:center}
.nav a{font-size:14px;color:var(--link)}
.nav a:hover{color:var(--ink);text-decoration:underline}
@media(min-width:1000px){.nav{display:flex}}


/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;border:1px solid transparent;border-radius:12px;font-weight:700;cursor:pointer;transition:transform .06s ease, filter .2s;height:52px;padding:0 20px}
.btn:active{transform:translateY(1px)}
.btn.primary{background:linear-gradient(90deg,var(--brand),var(--brand-2));color:#fff;box-shadow:var(--shadow-lg)}
.btn.primary:hover{filter:brightness(.98)}
.btn.secondary{background:#fff;border-color:var(--line)}
.btn.secondary:hover{background:var(--bg-soft)}
.btn.block{width:100%}
.badge{display:inline-block;padding:6px 10px;border-radius:999px;font-size:12px;background:linear-gradient(90deg,var(--brand),var(--brand-2));color:#fff;box-shadow:0 2px 10px rgba(124,58,237,.25)}

/* ===== Cards / tiles ===== */
.card{border:1px solid var(--line);border-radius:var(--radius-xl);background:#fff;box-shadow:var(--shadow-md);padding:28px;height:100%}
.tile{border:1px solid var(--line);border-radius:var(--radius);background:#fff;padding:26px;box-shadow:var(--shadow-sm);height:100%}
.tile:hover{box-shadow:var(--shadow-md)}
.bullets{list-style:none;margin:12px 0 0;padding:0}
.bullets li{display:flex;gap:12px;margin:10px 0}
.bullets li:before{content:"";display:block;width:8px;height:8px;border-radius:999px;background:var(--ink);margin-top:9px}
.num{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:10px;background:var(--bg-soft);border:1px solid var(--line);font-weight:700}

/* ===== Table ===== */
table{width:100%;border-collapse:collapse}
th,td{padding:14px;border-bottom:1px solid var(--line);text-align:left}
th{font-weight:700}

/* ===== FAQ ===== */
#faq .grid{ /* убираем инлайновые margin у гридов, всё через gap */
  margin:0 !important;
}
details{border:1px solid var(--line);border-radius:14px;padding:14px;background:#fff}
details+details{margin-top:12px}
summary{cursor:pointer;font-weight:600}

/* ===== Form ===== */
.field{display:flex;flex-direction:column;gap:6px}
input,select,textarea{
  width:100%;border:1px solid #cbd5e1;border-radius:14px;padding:12px 14px;font:inherit;outline:none;transition:.15s;background:#fff
}
input:focus,select:focus,textarea:focus{box-shadow:0 0 0 6px rgba(79,70,229,.15);border-color:#94a3b8}
textarea{min-height:120px;resize:vertical}

/* ===== Footer ===== */
footer{border-top:1px solid var(--line);padding-block:22px;color:#64748b}

/* ===== HERO ===== */
.hero{padding-top:96px}
.hero-row{display:grid;gap:56px}
@media(min-width:960px){.hero-row{grid-template-columns:1.1fr .9fr;align-items:center}}
.hero-collage{
  position:relative;min-height:62vh;border-radius:var(--radius-xl);overflow:hidden;
  --hero-bg-size: 1200px;
  background:
    url('hero-collage-desktop.png') right top / var(--hero-bg-size) auto no-repeat,
    #fff;
}
.hero-collage::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,255,255,.55) 40%, rgba(255,255,255,.82));
  -webkit-backdrop-filter: blur(1.2px);
  backdrop-filter: blur(1.2px);
}
@media (min-width:1440px){
  .hero-collage{ --hero-bg-size: 1400px; background-position: right 10% top; }
}
@media (max-width:1200px){
  .hero-collage{ --hero-bg-size: 1050px; }
}
@media (max-width:640px){
  .hero-collage{
    --hero-bg-size: 900px;
    background:
      url('hero-collage-mobile.png') center 10% / var(--hero-bg-size) auto no-repeat,
      #fff;
  }
}
/* чуть воздуха под героем */
main > section.hero { padding-bottom: 40px; }

/* ===== A11y ===== */
a:focus-visible,.btn:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:3px solid var(--brand); outline-offset:2px;
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
}
/* === Mobile-only overrides (≤640px). Desktop не затрагиваем. === */
@media (max-width: 640px){
  /* Чуть меньше «воздуха» в hero под фикс-шапкой */
  .hero{ padding-top: 72px; }
  .hero-row{ gap: 28px; }

  /* Кнопки в hero — в колонку и на всю ширину (переопределяем inline-стиль) */
  .hero .grid{ grid-auto-flow: row !important; width: 100% !important; }
  .hero .grid .btn{ width: 100%; height: 50px; }

  /* Фон-коллаж: меньше масштаб и выше позиция, чтобы не казался «лупой» */
  .hero-collage{
    min-height: 48vh;
    --hero-bg-size: 720px;
    background-position: center 0%;
  }
  /* Вуаль — чуть прозрачнее сверху, чтобы фон читался */
  .hero-collage::before{
    background: linear-gradient(180deg, rgba(255,255,255,.90), rgba(255,255,255,.50) 35%, rgba(255,255,255,.78));
  }

  /* Типографика — мягче на мобиле */
  h1{ font-size: clamp(28px, 8vw, 40px); }
  p.lead{ font-size: clamp(15px, 4vw, 17px); }

  /* Уплотняем отступы и сетку */
  .container{ padding-inline: 16px; }
  .grid{ gap: 20px; }
  .card, .tile{ padding: 20px; }

  /* Форма контактов — поля в одну колонку на узких экранах */
  #contact .grid.cols-2{ grid-template-columns: 1fr; }
}
