
:root{
  --bg:#f7f9fc; --panel:#ffffff; --text:#0f1a2a; --muted:#5a6b8a; --accent:#2e5bea;
  --brand:#2e5bea; --primary:#2e5bea; --ghost:#eff3fb; --border:#d9e2ef; --success:#19b37a;
  --header-h: 68px; --vh: 1vh;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;color:var(--text);font:17.5px/1.7 'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:
    radial-gradient(1000px 480px at 80% -10%, #eef3ff 0%, transparent 60%),
    linear-gradient(180deg, #f9fbff 0%, #f2f6ff 40%, #f7f9fc 100%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140' viewBox='0 0 40 40'%3E%3Cg fill='none' stroke='%23cfd8f3' stroke-opacity='0.25' stroke-width='0.4'%3E%3Ccircle cx='5' cy='5' r='0.9'/%3E%3Ccircle cx='25' cy='10' r='0.7'/%3E%3Ccircle cx='15' cy='25' r='0.6'/%3E%3Ccircle cx='35' cy='30' r='0.8'/%3E%3Ccircle cx='8' cy='32' r='0.7'/%3E%3Ccircle cx='30' cy='5' r='0.6'/%3E%3C/g%3E%3C/svg%3E");
}
img{max-width:100%;display:block}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
.container{width:min(1120px,92%);margin:auto}

/* Header */
.site-header{position:sticky;top:0;background:rgba(255,255,255,.9);backdrop-filter:saturate(150%) blur(8px);border-bottom:1px solid var(--border);z-index:20;height:var(--header-h)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:100%}
.brand{display:flex;gap:.6rem;align-items:center}
.logo{width:36px;height:36px}
.logo.small{width:28px;height:28px}
.brand-name{font-weight:700;letter-spacing:.2px}
.nav-toggle{display:none;background:none;border:1px solid var(--border);color:var(--text);padding:.5rem .7rem;border-radius:.6rem}
.nav-list{display:flex;gap:1rem;list-style:none;margin:0;padding:0}
.nav-list a{padding:.5rem .7rem;border-radius:.6rem;white-space:nowrap}
.nav-list a:hover{background:var(--ghost);text-decoration:none}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.05rem;border-radius:.8rem;border:1px solid var(--border);cursor:pointer}
.btn-primary{background:var(--primary);color:#fff;border-color:transparent}
.btn-primary:hover{filter:brightness(1.05)}
.btn-ghost{background:#fff;color:var(--text);border-color:var(--border)}
.link{display:inline-block;margin-top:.45rem}

/* Main structure */
.site-main > section{padding:64px 0;border-top:1px dashed var(--border)}
.home .hero{padding:48px 0 0;border-top:0;min-height:calc(100vh - var(--header-h));display:flex;align-items:center}
.hero-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:center}
.hero h1{font-size:clamp(1.8rem, 3.4vw, 2.8rem);line-height:1.2;margin:0 0 .6rem;letter-spacing:.2px}
.hero p{font-size:clamp(1rem, 1.2vw, 1.125rem);color:#2a3550;max-width:62ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1rem}
.hero-media img{width:100%;height:100%;max-height:540px;object-fit:cover;border-radius:1.1rem;border:1px solid rgba(0,0,0,.06);box-shadow:0 16px 40px rgba(31,41,55,.08)}

.section h2{margin:.2rem 0 .8rem;font-size:clamp(1.5rem, 2.4vw, 2rem)}
.muted{color:#2a3550}

/* Cards */
.section-cards .cards{display:grid;grid-template-columns:repeat(5,1fr);gap:1.1rem}
.card{background:linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);border:1px solid rgba(0,0,0,.06);border-radius:1.1rem;overflow:hidden;padding:0 0 1.2rem;display:flex;flex-direction:column;box-shadow:0 16px 40px rgba(31,41,55,.08)}
.card img{aspect-ratio:4 / 3;object-fit:cover}
.card h3{margin:1rem 1.1rem .35rem;font-size:clamp(1.15rem, 1.8vw, 1.3rem)}
.card p{margin:0 1.1rem .6rem;color:var(--muted)}
.card .link{margin:0 1.1rem}

/* Steps */
.section-steps .grid{display:grid;grid-template-columns:2fr 1fr;gap:1.2rem}
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(5,1fr);gap:1.1rem;margin:.6rem 0}
.steps li{list-style:none;background:var(--panel);border:1px solid rgba(0,0,0,.06);padding:1.1rem;border-radius:1.1rem;position:relative;box-shadow:0 12px 28px rgba(31,41,55,.08);min-height:140px;display:flex;align-items:flex-start}
.steps li:before{counter-increment:step;content:counter(step);position:absolute;top:-12px;left:-12px;width:34px;height:34px;border-radius:999px;background:var(--primary);color:#fff;display:grid;place-items:center;font-weight:700;border:2px solid #fff}
.aside{background:var(--panel);border:1px solid rgba(0,0,0,.06);border-radius:1.1rem;padding:1.1rem;box-shadow:0 12px 28px rgba(31,41,55,.08)}

/* Benefits */
.section-benefits .grid{display:grid;grid-template-columns:2fr 1fr;gap:1.2rem}
.benefits{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
.benefit{display:flex;gap:.75rem;align-items:center;background:var(--panel);border:1px solid rgba(0,0,0,.06);padding:1rem 1.1rem;border-radius:1.1rem;box-shadow:0 12px 28px rgba(31,41,55,.08)}
.benefit img{width:28px;height:28px}
.facts{background:var(--panel);border:1px solid rgba(0,0,0,.06);border-radius:1.1rem;padding:1.1rem;color:#2a3550;box-shadow:0 12px 28px rgba(31,41,55,.08)}

/* Local */
.two-col{display:grid;grid-template-columns:1.2fr .8fr;gap:1.4rem;align-items:center}
.map img{border-radius:1.1rem;border:1px solid rgba(0,0,0,.06);box-shadow:0 12px 28px rgba(31,41,55,.08)}
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem;margin-top:.6rem}
.info{background:var(--panel);border:1px solid rgba(0,0,0,.06);border-radius:1rem;padding:.8rem;color:#2a3550}

/* Testimonials */
.testimonials{display:grid;grid-template-columns:repeat(5,1fr);gap:1.1rem}
.testimonial{background:var(--panel);border:1px solid rgba(0,0,0,.06);padding:1rem;border-radius:1.1rem;box-shadow:0 12px 28px rgba(31,41,55,.08)}
.testimonial img{width:60px;height:60px;border-radius:999px;margin-bottom:.4rem}

/* CTA */
.section-cta .container{display:grid;gap:1rem;justify-items:center}
.cta-box{background:linear-gradient(180deg, rgba(46,91,234,.08), transparent), var(--panel);border:1px solid rgba(0,0,0,.06);border-radius:1.1rem;padding:1.2rem;box-shadow:0 12px 28px rgba(31,41,55,.08);max-width:760px;margin:0 auto}
.cta-form{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem;margin-top:.6rem}
.cta-form label{display:flex;flex-direction:column;gap:.35rem}
input, textarea{background:#fff;border:1px solid var(--border);color:var(--text);padding:.8rem 1rem;border-radius:.7rem;outline-color:var(--primary)}
.form-note{color:var(--muted);font-size:.95rem}
.badges{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap;justify-content:center}
.badge{background:#eef2ff;border:1px solid #dbe3ff;color:#2e5bea;border-radius:999px;padding:.3rem .7rem;font-weight:600;font-size:.95rem}

/* Subpages */
.page-hero{padding:calc(var(--header-h) + 16px) 0 16px;background:#f1f5ff;border-top:0}
.article-list{display:grid;gap:1.1rem;padding:1.2rem 0}
.post{display:grid;grid-template-columns:140px 1fr;gap:1.1rem;background:var(--panel);border:1px solid rgba(0,0,0,.06);padding:1rem;border-radius:1.1rem;box-shadow:0 12px 28px rgba(31,41,55,.08)}
.post img{width:140px;height:104px;object-fit:cover;border-radius:.6rem}
.post .meta{font-size:.95rem;color:var(--muted)}
.faq details{background:var(--panel);border:1px solid rgba(0,0,0,.06);border-radius:1rem;padding:1rem;margin:.5rem 0;box-shadow:0 12px 28px rgba(31,41,55,.06)}

/* Footer */
.site-footer{border-top:1px solid var(--border);margin-top:0;padding:24px 0 0;background:#fff}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:1rem}
.footer-brand{display:flex;gap:.8rem;align-items:flex-start}
.footer-links{list-style:none;margin:0;padding:0;display:grid;gap:.4rem}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--border);padding:.9rem 0;margin-top:1rem}
.footer-disclaimer{color:var(--muted)}

/* Cookie banner */
.cookie-banner{position:fixed;inset:auto 0 0 0;background:#ffffff;border-top:1px solid var(--border);transform:translateY(120%);transition:.3s;z-index:50}
.cookie-banner.show{transform:translateY(0)}
.cookie-content{display:flex;justify-content:space-between;align-items:center;padding:.9rem 0;gap:.8rem}
.cookie-actions{display:flex;gap:.6rem}

/* Utilities */
.list{padding-left:1.1rem}
.list li{margin:.22rem 0}

/* Responsive */
@media (max-width: 1200px){
  .section-cards .cards{grid-template-columns:repeat(3,1fr)}
  .benefits{grid-template-columns:repeat(3,1fr)}
  .testimonials{grid-template-columns:repeat(3,1fr)}
}
@media (max-width: 920px){
  .hero-inner{grid-template-columns:1fr}
  .two-col{grid-template-columns:1fr}
  .section-steps .grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr}
  .facts{order:-1;margin-bottom:1rem}
  .section-cards .cards{grid-template-columns:repeat(2,1fr)}
  .benefits{grid-template-columns:repeat(2,1fr)}
  .info-grid{grid-template-columns:1fr 1fr}
  .testimonials{grid-template-columns:1fr 1fr}
  .cta-form{grid-template-columns:1fr}
  .container{width:min(96%, 760px)}
  .nav-toggle{display:inline-block}
  .nav-list{display:none;position:absolute;right:2%;top:60px;background:var(--panel);border:1px solid rgba(0,0,0,0.06);padding:.8rem;border-radius:1rem;flex-direction:column;box-shadow:0 16px 40px rgba(31,41,55,.12);z-index:30}
  .nav-list.show{display:flex}
  .nav-list a{padding:.8rem 1rem}
}
@media (max-width: 620px){
  body{font-size:16.5px}
  .steps{grid-template-columns:1fr}
  .benefits{grid-template-columns:1fr}
  .section-cards .cards{grid-template-columns:1fr}
  .testimonials{grid-template-columns:1fr}
  .info-grid{grid-template-columns:1fr}
}
/* ---------- Testimonials (reworked) ---------- */
.section-testimonials { padding: 56px 0; border-top: 1px dashed var(--border); }
.section-testimonials h2 { margin-bottom: 1rem; }

.testimonials{
  display: grid;
  /* адаптивная сетка: от 300px до растяжения */
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 1.2rem;
  align-items: stretch;
}

.testimonial{
  display: flex;
  flex-direction: column;
  gap: .6rem;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 18px;
  padding: 1.1rem 1.2rem 1.0rem;
  box-shadow: 0 16px 40px rgba(31,41,55,.08);
}

.testimonial img{
  width: 56px; height: 56px;
  border-radius: 50%;
  margin-bottom: .2rem;
}

.testimonial blockquote{
  margin: .2rem 0 0;
  font-size: 1.05rem;
  line-height: 1.65;
  color: var(--text);
  flex: 1; /* растягиваем текст, чтобы подпись «прилипала» к низу */
}
.testimonial blockquote::before{
  content: "„";
  color: var(--accent);
  font-size: 2.2rem;
  line-height: 0;
  margin-right: .2rem;
  vertical-align: -.35rem;
}
.testimonial blockquote::after{
  content: "“";
  color: transparent; /* закрывающую можно скрыть, если не нужна */
}

.testimonial figcaption{
  margin-top: .4rem;
  color: var(--muted);
  font-weight: 600;
}

/* ----- Планшеты: 2–3 карточки ----- */
@media (max-width: 980px){
  .testimonials{
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1rem;
  }
}

/* ----- Телефоны: горизонтальный скролл с привязкой ----- */
@media (max-width: 640px){
  .testimonials{
    display: flex;
    overflow-x: auto;
    gap: .9rem;
    padding-bottom: .4rem;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }
  .testimonials::-webkit-scrollbar{ height: 6px }
  .testimonials::-webkit-scrollbar-thumb{ background: #dbe3ff; border-radius: 999px }

  .testimonial{
    flex: 0 0 85vw;          /* широкая карточка */
    scroll-snap-align: start;/* липкая остановка у начала */
  }
}
/* ---------- Steps (reworked) ---------- */
.section-steps .grid{
  display:grid;
  grid-template-columns:minmax(0,2fr) minmax(0,1fr);
  gap:1.6rem; align-items:start;
}

.steps{
  counter-reset:step;
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:1.1rem; margin:.6rem 0;
}

.steps li{
  list-style:none;
  position:relative;
  background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);
  border:1px solid rgba(0,0,0,.06);
  border-radius:18px;
  padding:1rem 1rem 1rem 1rem;
  box-shadow:0 16px 40px rgba(31,41,55,.08);
  min-height:auto; display:flex; align-items:flex-start;
}

.steps li:before{
  counter-increment:step; content:counter(step);
  position:absolute; top:-10px; left:-10px;
  width:30px; height:30px; border-radius:50%;
  display:grid; place-items:center;
  background:var(--primary); color:#fff; font-weight:700;
  border:2px solid #fff; box-shadow:0 6px 16px rgba(31,41,55,.15);
}

.aside{
  background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);
  border:1px solid rgba(0,0,0,.06);
  border-radius:18px; padding:1.1rem;
  box-shadow:0 12px 28px rgba(31,41,55,.08);
}

@media (max-width:980px){
  .section-steps .grid{ grid-template-columns:1fr; }
  .steps{ grid-template-columns:repeat(auto-fit, minmax(240px, 1fr)); }
}
@media (max-width:640px){
  /* скролл-карусель для шагов */
  .steps{ display:flex; overflow-x:auto; gap:.9rem;
          scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch;
          padding-bottom:.4rem; }
  .steps::-webkit-scrollbar{ height:6px }
  .steps::-webkit-scrollbar-thumb{ background:#dbe3ff; border-radius:999px }
  .steps li{ flex:0 0 82vw; scroll-snap-align:start; }
}
/* ---------- Benefits (reworked) ---------- */
.section-benefits .grid{
  display:grid;
  grid-template-columns:minmax(0,2fr) minmax(0,1fr);
  gap:1.6rem; align-items:stretch;
}

.benefits{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
  gap:1.1rem;
}

.benefit{
  display:grid; grid-template-columns:48px 1fr; align-items:center;
  gap:.9rem;
  background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);
  border:1px solid rgba(0,0,0,.06);
  border-radius:18px; padding:1rem 1.2rem;
  box-shadow:0 12px 28px rgba(31,41,55,.08);
  transition:.15s transform, .15s box-shadow;
}
.benefit:hover{ transform:translateY(-2px); box-shadow:0 18px 44px rgba(31,41,55,.10); }

.benefit img{
  width:36px; height:36px; object-fit:contain;
  padding:8px; border-radius:12px;
  background:radial-gradient(120% 120% at 30% 20%, rgba(46,91,234,.18), rgba(46,91,234,.06));
  box-shadow:inset 0 0 0 1px rgba(46,91,234,.15);
}
.benefit span{ font-weight:600; line-height:1.55; }

.facts{
  background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);
  border:1px solid rgba(0,0,0,.06);
  border-radius:18px; padding:1.1rem 1.3rem;
  box-shadow:0 12px 28px rgba(31,41,55,.08);
}
.facts ul{ padding-left:1.1rem; margin:.2rem 0; }
.facts li{ margin:.35rem 0; }

@media (max-width:980px){
  .section-benefits .grid{ grid-template-columns:1fr; }
  .benefits{ grid-template-columns:repeat(auto-fit, minmax(210px, 1fr)); }
}
@media (max-width:640px){
  .benefits{ grid-template-columns:1fr; }
}
/* ---------- Kontakt: form card + responsive grid ---------- */
.contact .contact-form{
  display:grid;
  grid-template-columns: 1fr 1fr;
  grid-template-areas: 
    "name email"
    "msg  msg"
    "btn  btn"
    "note note";
  gap: 1rem;
  max-width: 860px;
  margin: 0 auto 1.2rem;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 18px;
  padding: 1.2rem 1.2rem 1rem;
  box-shadow: 0 12px 28px rgba(31,41,55,.08);
}
.contact .contact-form label:nth-of-type(1){ grid-area: name; }
.contact .contact-form label:nth-of-type(2){ grid-area: email; }
.contact .contact-form label:nth-of-type(3){ grid-area: msg; }
.contact .contact-form button{ grid-area: btn; justify-self: start; }
.contact .contact-form .form-note{ grid-area: note; margin:.2rem 0 0; color: var(--muted); }

.contact .contact-form input,
.contact .contact-form textarea{ width: 100%; }

/* Improve contact info + image block */
.contact .two-col{ 
  display:grid; grid-template-columns: 1.1fr .9fr; gap: 1.4rem; align-items: start;
}
.contact .two-col img{ 
  width:100%; height:auto; max-width: 580px; object-fit: cover; 
  border-radius: 18px; border: 1px solid rgba(0,0,0,.06); 
  box-shadow: 0 12px 28px rgba(31,41,55,.08);
  justify-self: center;
}

@media (max-width: 860px){
  .contact .contact-form{
    grid-template-columns: 1fr;
    grid-template-areas:
      "name"
      "email"
      "msg"
      "btn"
      "note";
  }
  .contact .two-col{ grid-template-columns: 1fr; }
}
