:root {
  --bg: #fefcfb;
  --surface: #ffffff;
  --surface-2: #fff5f2;
  --text: #1f1f1f;
  --muted: #555;

  --orange-300: #fdba74;
  --orange-400: #fb923c;
  --orange-500: #f97316;
  --orange-600: #ea580c;
  --orange-700: #c2410c;

  --accent: var(--orange-600);

  --radius-xl: 22px;
  --radius-lg: 16px;
  --radius-md: 12px;

  --shadow-s: 0 1px 2px rgba(0, 0, 0, .08), 0 8px 24px rgba(34, 35, 58, .08);
  --shadow-m: 0 10px 30px rgba(234, 88, 12, .18), inset 0 1px 0 rgba(255, 255, 255, 1);

  /* Make layout fluid: container spans full width */
  --grid-max: 100%;
  --grid-pad: clamp(16px, 3vw, 28px);

  --anim-dur: .7s;
  --anim-ease: cubic-bezier(.2, .65, .2, 1);

  --border: #e5e7eb;
  --field: #fef2f2;
}

/* Base */
*,
*::before,
*::after {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.5;
}

img {
  max-width: 100%;
  display: block;
}

a {
  text-decoration: none;
  color: inherit;
}

.container {
  width: min(100%, var(--grid-max));
  margin: 0 auto;
  padding: 0 var(--grid-pad);
}

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 18px;
  border-radius: 14px;
  background: linear-gradient(180deg, var(--orange-400), var(--orange-600));
  color: #ffffff !important;
  font-weight: 700;
  border: 0;
  cursor: pointer;
  box-shadow: var(--shadow-m);
  transition: transform .2s ease, filter .2s ease;
}

.btn:hover {
  transform: translateY(-2px);
  filter: brightness(1.06);
}

.btn.ghost {

  color: var(--accent);
  border: 1px solid var(--orange-400);
  box-shadow: none;
}

/* Header / Nav */
header {
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(8px);
  background: #ffffff;
  border-bottom: 1px solid var(--border);
  box-shadow: var(--shadow-s);
}

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 72px;
}

.logo {
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 800;
  color: var(--accent);

}

.logo img {
  height: 45px;
}


/* Header actions */
.actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.phone {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 12px;
  background: #fff7ed;
  border: 1px solid var(--orange-300);
  color: var(--accent);
  font-weight: 800;
  white-space: nowrap;
  box-shadow: var(--shadow-s);
}

.phone:hover {
  background: #fff0e6;
}

.phone-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
}

.phone-icon svg {
  width: 27px;
  height: 27px;
}

/* Desktop nav links */
.nav ul {
  display: flex;
  gap: 18px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.nav a {
  display: inline-block;
  padding: 10px 12px;
  border-radius: 10px;
  color: var(--muted);
  font-weight: 600;
  transition: background .2s ease, color .2s ease, box-shadow .2s ease;
}

.nav ul li a:hover {
  color: var(--accent);
  background: #fff0e6;
  box-shadow: 0 1px 0 rgba(0, 0, 0, .03);
}

.nav a:focus-visible {
  outline: 2px solid var(--orange-400);
  outline-offset: 2px;
  border-radius: 10px;
}

.nav a.active {
  color: var(--accent);
  background: #fff0e6;
  box-shadow: 0 1px 0 rgba(0, 0, 0, .03);
}

/* Burger (mobile) */
.burger {
  display: none;
  background: #ffffff;
  border: 1px solid var(--border);
  width: 44px;
  height: 44px;
  border-radius: 12px;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  box-shadow: var(--shadow-s);
}

.burger:focus-visible {
  outline: 2px solid var(--orange-400);
  outline-offset: 2px;
}

/* Hero */
.hero {
  /* Restore original spacing; we'll move the glow instead */
  padding: 48px 0 48px;
  background: linear-gradient(180deg, #ffffff, #fff5f2);
  position: relative;
  overflow: clip;
}

.glow {
  position: absolute;
  inset: -120px -20vw auto -20vw;
  height: 420px;
  background:
    radial-gradient(60% 80% at 50% 0%, rgba(251, 146, 60, .25), rgba(234, 88, 12, .12), transparent 70%);
  filter: blur(30px);
  opacity: .9;
}

.hero-grid {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 28px;
  align-items: center;
}

h1 {
  font-size: clamp(32px, 5vw, 56px);
  line-height: 1.1;
  margin: 0;
  color: var(--accent);
}

.lead {
  font-size: clamp(16px, 2.3vw, 20px);
  color: var(--muted);
  /* Limit reading width on ultra-wide screens */
  max-width: 65ch;
}

.cta {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--accent);
  border: 1px solid var(--orange-300);
  padding: 8px 12px;
  border-radius: 999px;
  background: #fff7ed;
  box-shadow: var(--shadow-s);
  /* Raise only the badge a bit without shifting layout */
  transform: translateY(-12px);
}

@media (max-width: 720px) {
  .badge {
    transform: translateY(-18px);
  }
}

.badge1 {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--accent);
  border: 1px solid var(--orange-300);
  padding: 8px 12px;
  border-radius: 999px;
  background: #fff7ed;
  box-shadow: var(--shadow-s);
}
/* Sections */
section {
  padding: 30px 0;
}

.section-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 28px;
  flex-wrap: wrap;
}

.section-head h2 {
  margin: 0;
  font-size: clamp(24px, 3.5vw, 36px);
  color: var(--accent);
}

.section-head p {
  color: var(--muted);
  /* Fluid readable width instead of fixed px */
  max-width: 72ch;
}

/* Services */
.services {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.card {
  background: #ffffff;
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 22px;
  box-shadow: var(--shadow-s);
}

.card .icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: linear-gradient(180deg, var(--orange-500), var(--orange-700));
  color: #ffffff;
  margin-bottom: 12px;
}

/* Partners */
.partners {
  display: grid;
  /* Wider tiles so logos can grow larger */
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 16px;
  align-items: center;
}

.partner {
  border-radius: 12px;
  background: #ffffff;
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px;
  /* Taller tile to accommodate larger logos */
  min-height: 130px;
  box-shadow: var(--shadow-s);
}

.partner img {
  /* Larger, responsive logos: grow on wide screens, stay tidy on mobile */
  max-height: clamp(56px, 6.5vw, 96px);
  max-width: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
}

/* Process steps */
.steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  counter-reset: step;
}

.step {
  background: #ffffff;
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 18px;
  box-shadow: var(--shadow-s);
  position: relative;
}

.step::before {
  counter-increment: step;
  content: counter(step, decimal-leading-zero);
  position: absolute;
  top: 14px;
  right: 14px;
  font-weight: 800;
  font-size: 12px;
  color: var(--orange-400);
}

/* Why us */
.why {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.why .item {
  background: #ffffff;
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 18px;
  box-shadow: var(--shadow-s);
}

.why .item h3 {
  margin: 6px 0 8px;
  color: var(--accent);
}

/* Contact */
.cta-box {
  background: #ffffff;
  border: 1px solid var(--border);
  border-radius: 22px;
  padding: 22px;
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 18px;
  align-items: center;
  box-shadow: var(--shadow-s);
}

form {
  display: grid;
  gap: 12px;
}

.form-status {
  min-height: 18px;
}

input,
textarea {
  width: 100%;
  background: var(--field);
  color: var(--text);
  border: 1px solid #f3af9a;
  border-radius: 12px;
  padding: 12px 14px;
  font: inherit;
}

textarea {
  min-height: 120px;
  resize: vertical;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

/* Footer */
footer {
  padding: 48px 0;
  color: var(--muted);
  background: #fff7ed;
  border-top: 1px solid var(--border);
}

.foot {
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 16px;
  align-items: center;
}

/* Reveal animations */
[data-reveal] {
  opacity: 0;
  transform: translateY(24px) scale(.98);
  filter: blur(2px);
  transition-property: opacity, transform, filter;
  transition-duration: var(--anim-dur);
  transition-timing-function: var(--anim-ease);
}

.in-view {
  opacity: 1 !important;
  transform: translateY(0) scale(1) !important;
  filter: blur(0) !important;
}

/* Motion reduce */
@media (prefers-reduced-motion: reduce) {
  [data-reveal],
  [data-reveal] > * {
    transition: none !important;
    transform: none !important;
    opacity: 1 !important;
    filter: none !important;
  }
}

/* Responsive */
@media (max-width: 1020px) {
  .nav {
    gap: 10px;
    position: relative;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
  }

  .burger {
    display: inline-flex;
    position: static;
    left: auto;
    top: auto;
    transform: none;
    z-index: auto;
    justify-self: center;
  }

  /* Don't let the nav wrapper occupy its own grid cell */
  .nav nav { display: contents; }

  /* Keep phone on the right grid cell */
  .actions { grid-column: 3; justify-self: end; }

  .nav ul {
    position: absolute;
    top: calc(72px + 8px);
    left: var(--grid-pad);
    right: var(--grid-pad);
    background: #ffffff;
    border: 1px solid var(--border);
    border-radius: 16px;
    box-shadow: var(--shadow-s);
    padding: 8px;
    display: none;
    flex-direction: column;
    /* Full-width dropdown within container gutters */
    width: auto;
    min-width: 0;
    z-index: 1000;
    max-height: calc(100vh - 120px);
    overflow: auto;
    text-align: center;
  }

  .nav ul.open {
    display: flex;
  }

  .nav a {
    padding: 12px 14px;
    display: block;
    width: 100%;
    text-align: center;
  }

  /* Keep phone tidy on small screens */
  .phone {
    padding: 8px 12px;
    border-radius: 10px;
    font-weight: 800;
  }

  .hero-grid,
  .cta-box,
  .foot {
    grid-template-columns: 1fr;
  }

  .services {
    grid-template-columns: repeat(2, 1fr);
  }

  .steps {
    grid-template-columns: repeat(2, 1fr);
  }

  .partners {
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  }

  .why {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 720px) {
  .services {
    grid-template-columns: 1fr;
  }

  .steps {
    grid-template-columns: 1fr;
  }

  .partners {
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  }

  .why {
    grid-template-columns: 1fr;
  }
}

/* Wide screens: improve readability and spacing */
@media (min-width: 1440px) {
  :root {
    /* roomier gutters on very wide screens */
    --grid-pad: 40px;
  }

  /* logos grid breathes more on wide viewports */
  .partners { gap: 20px; }
}

@media (min-width: 1920px) {
  :root {
    --grid-pad: 60px;
  }

  /* Keep using the base adaptive columns on ultra-wide */
}

/* Pricing (Bitrix / Bitrix24) */
.pricing {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.price-card {
  background: #ffffff;
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 18px;
  box-shadow: var(--shadow-s);
  display: grid;
  gap: 10px;
}

.price-card h3 {
  margin: 0 0 6px 0;
  font-size: 18px;
  color: var(--accent);
}

.price {
  font-weight: 800;
  font-size: 22px;
  color: var(--accent);
}

.price small {
  color: var(--muted);
  font-weight: 600;
}

.features {
  color: var(--muted);
  font-size: 14px;
  display: grid;
  gap: 6px;
}

.price-note {
  color: var(--muted);
  font-size: 12px;
}

.toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.toggle {
  display: inline-grid;
  grid-auto-flow: column;
  gap: 6px;
  align-items: center;
  padding: 6px;
  border-radius: 999px;
  background: #fff7ed;
  border: 1px solid var(--orange-300);
}

.toggle button {
  border: 0;
  padding: 8px 12px;
  border-radius: 999px;
  background: transparent;
  color: var(--muted);
  font-weight: 700;
  cursor: pointer;
}

.toggle button.active {
  background: linear-gradient(180deg, var(--orange-400), var(--orange-600));
  color: #ffffff;
  box-shadow: 0 6px 14px rgba(234, 88, 12, .25);
}

/* Responsive additions for pricing */
@media (max-width: 1024px) {
  .pricing {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 720px) {
  .pricing {
    grid-template-columns: 1fr;
  }
}

/* Screen-reader only helper */
.sr {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* якорные секции сдвигаем чуть ниже sticky-меню */
section {
  scroll-margin-top: 80px; /* высота хедера + небольшой запас */
}

/* FAQ */
.faq {
  display: grid;
  gap: 12px;
}

.faq-item {
  background: #ffffff;
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow: var(--shadow-s);
  overflow: hidden;
}

.faq-q {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  background: #ffffff;
  border: 0;
  text-align: left;
  font: inherit;
  color: var(--text);
  cursor: pointer;
}

.faq-q:hover {
  background: #fff7ed;
}

.faq-q[aria-expanded="true"] svg {
  transform: rotate(45deg);
}

.faq-q svg {
  transition: transform .2s ease;
  color: var(--accent);
}

.faq-a {
  display: none;
  padding: 0 16px 14px 16px;
  color: var(--muted);
}

.faq-item.open .faq-a {
  display: block;
}

/* WHY — преимущества */
.why {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.why .item {
  background: #ffffff;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 18px;
  box-shadow: var(--shadow-s);
}

.why .item h3 {
  margin-top: 0;
  margin-bottom: 8px;
  font-size: 18px;
  color: var(--accent);
}

.why .item p {
  margin: 0;
  color: var(--muted);
}

/* FAQ */
.faq {
  display: grid;
  gap: 12px;
}

.faq-item {
  background: #ffffff;
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow: var(--shadow-s);
  overflow: hidden;
}

.faq-q {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  background: #ffffff;
  border: 0;
  text-align: left;
  font: inherit;
  color: var(--text);
  cursor: pointer;
}

.faq-q:hover {
  background: #fff7ed;
}

.faq-q[aria-expanded="true"] svg {
  transform: rotate(45deg);
}

.faq-q svg {
  transition: transform .2s ease;
  color: var(--accent);
}

.faq-a {
  display: none;
  padding: 0 16px 14px 16px;
  color: var(--muted);
}

.faq-item.open .faq-a {
  display: block;
}

/* ===== Responsive ===== */
@media (max-width: 1024px) {
  .why {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 720px) {
  .why {
    grid-template-columns: 1fr;
  }

  .faq-q {
    padding: 12px 14px;
    font-size: 15px;
  }

  .faq-a {
    font-size: 14px;
  }
}
.phone-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
}

/* Hide phone icon on tablets and mobiles */
@media (max-width: 1024px) {
  .phone-icon { display: none !important; }
}
