:root {
  --bg: #f5f6f8;
  --surface: #ffffff;
  --surface-muted: #eef4fb;
  --surface-soft: #f1f6fd;
  --text: #18263f;
  --text-soft: #5b6679;
  --primary: #2e7de1;
  --primary-dark: #0f3d89;
  --accent: #6cc344;
  --border: #dbe3ee;
  --shadow: 0 14px 40px rgba(17, 50, 94, .08);
  --container: min(100% - 32px, 1200px);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: "Manrope", system-ui, sans-serif; color: var(--text); background: var(--bg); text-rendering: optimizeLegibility; -webkit-font-smoothing: antialiased; }
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button, input { font: inherit; }
.container { width: var(--container); margin-inline: auto; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }
.btn { display: inline-flex; align-items: center; justify-content: center; min-height: 54px; padding: 0 28px; border-radius: 16px; font-weight: 700; transition: .2s ease; border: 1.5px solid transparent; white-space: nowrap; }
.btn:hover { transform: translateY(-1px); }
.btn-primary { background: var(--primary); color: #fff; box-shadow: 0 10px 24px rgba(46, 125, 225, .24); }
.btn-secondary { background: rgba(255,255,255,.72); color: var(--primary); border-color: rgba(46, 125, 225, .55); }
.btn-accent { background: var(--accent); color: #fff; min-height: 46px; padding-inline: 20px; border-radius: 14px; }
.btn-footer { background: #215bb6; color: #fff; min-height: 42px; padding-inline: 22px; border-radius: 12px; }
.site-header { position: sticky; top: 0; z-index: 20; background: rgba(255,255,255,.94); backdrop-filter: blur(14px); border-bottom: 1px solid rgba(219,227,238,.7); }
.header-inner { display: grid; grid-template-columns: auto 1fr auto auto; gap: 20px; align-items: center; min-height: 70px; }
.brand { display: inline-flex; align-items: center; gap: 12px; min-width: 0; }
.brand img { width: 42px; height: 42px; object-fit: contain; }
.brand-copy { display: grid; gap: 2px; }
.brand-copy strong { font-size: 20px; line-height: 1; font-weight: 800; letter-spacing: -.02em; }
.brand-copy small { font-size: 11px; line-height: 1.2; color: var(--text-soft); }
.main-nav { display: flex; justify-content: center; gap: clamp(14px, 1.5vw, 28px); font-size: 15px; color: #273244; margin-inline: auto; }
.main-nav a, .mobile-nav a { position: relative; }
.main-nav a::after, .mobile-nav a::after { content: ""; position: absolute; left: 0; bottom: -6px; width: 100%; height: 2px; background: var(--primary); transform: scaleX(0); transform-origin: left; transition: .2s ease; }
.main-nav a:hover::after, .mobile-nav a:hover::after { transform: scaleX(1); }
.header-contact { display: grid; gap: 2px; text-align: right; }
.phone { font-size: 16px; font-weight: 800; }
.header-contact span { font-size: 12px; color: var(--text-soft); }
.header-cta { min-width: 170px; }
.menu-toggle { display: none; width: 44px; height: 44px; padding: 0; border: 0; background: transparent; border-radius: 12px; }
.menu-toggle span { display: block; width: 22px; height: 2px; background: var(--text); margin: 5px auto; border-radius: 2px; }
.mobile-menu { display: none; border-top: 1px solid rgba(219,227,238,.9); background: #fff; }
.mobile-menu.is-open { display: block; }
.mobile-menu-inner { padding: 18px 0 24px; }
.mobile-nav { display: grid; gap: 16px; font-weight: 700; }
.mobile-contact { margin: 20px 0; display: grid; gap: 6px; color: var(--text-soft); }
.mobile-contact .phone { color: var(--text); }
.mobile-cta { width: 100%; }
.hero-section { position: relative; overflow: clip; background: linear-gradient(180deg, #f6f7f8 0%, #fafafa 100%); min-height: 640px; }
.hero-section::before { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(246,247,248,.98) 0%, rgba(246,247,248,.95) 40%, rgba(246,247,248,.3) 62%, rgba(246,247,248,0) 78%); z-index: 1; }
.hero-media { position: absolute; inset: 0; display: flex; justify-content: flex-end; align-items: stretch; }
.hero-media img { width: clamp(760px, 58vw, 1040px); height: 100%; object-fit: cover; object-position: center right; filter: saturate(.95); }
.hero-grid { position: relative; z-index: 2; display: grid; grid-template-columns: minmax(520px, 560px) minmax(340px, 1fr); align-items: center; gap: 18px; min-height: 640px; padding: 40px 0 110px; }
.hero-copy { max-width: 560px; }
.eyebrow { display: inline-flex; align-items: center; min-height: 34px; padding: 0 14px; border-radius: 999px; font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: .02em; color: var(--primary); background: #e9f2ff; margin-bottom: 20px; }
.hero-copy h1 { margin: 0 0 18px; font-size: clamp(42px, 5vw, 68px); line-height: .98; font-weight: 800; letter-spacing: -.04em; max-width: 12ch; }
.hero-copy h1 span { color: var(--primary); }
.hero-lead { margin: 0 0 30px; color: #344053; font-size: clamp(17px, 1.55vw, 21px); line-height: 1.65; max-width: 34rem; }
.hero-actions { display: flex; gap: 16px; flex-wrap: wrap; margin-bottom: 24px; }
.hero-features { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(2, max-content); gap: 20px 28px; color: #3d4a5d; font-size: 15px; }
.hero-features li { display: inline-flex; align-items: center; gap: 10px; }
.hero-features svg, .service-icon svg, .benefits-grid svg, .step-icon svg { width: 22px; height: 22px; stroke: var(--primary); stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.hero-side { display: flex; justify-content: flex-end; align-items: center; min-height: 100%; }
.review-badge { margin-top: 84px; margin-right: 8px; background: rgba(255,255,255,.94); border-radius: 22px; padding: 24px 26px; box-shadow: var(--shadow); width: min(100%, 246px); backdrop-filter: blur(10px); }
.review-line { display: flex; align-items: center; gap: 10px; font-weight: 800; font-size: 22px; }
.review-line strong { color: #36a852; font-size: 34px; line-height: 1; }
.stars { color: #f6c343; letter-spacing: .12em; font-size: 16px; }
.review-badge p { margin: 10px 0 0; font-size: 18px; color: #364154; }
.hero-curve { position: absolute; left: 50%; bottom: -78px; width: 120%; height: 170px; transform: translateX(-50%); background: var(--bg); border-radius: 50%; z-index: 0; }
.section { position: relative; z-index: 3; }
.services { padding: 0 0 40px; }
.section-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 32px; }
.section-head.compact { margin-bottom: 18px; }
.section h2, .section-head h2, .workflow h2 { margin: 0; font-size: clamp(34px, 3.2vw, 52px); line-height: 1.05; font-weight: 800; letter-spacing: -.035em; }
.section h2 span, .section-head h2 span, .workflow h2 span { color: var(--primary); }
.section-head a { color: var(--primary); font-weight: 700; }
.services-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; align-items: stretch; }
.service-card { background: #fff; border: 1px solid rgba(219,227,238,.95); border-radius: 18px; overflow: hidden; box-shadow: 0 8px 24px rgba(16, 41, 81, .04); display: grid; grid-template-rows: auto 1fr; height: 100%; }
.service-card img { width: 100%; aspect-ratio: 1.85 / 1; object-fit: cover; }
.service-body { padding: 18px 18px 20px; display: flex; flex-direction: column; height: 100%; }
.service-icon { display: inline-flex; width: 42px; height: 42px; align-items: center; justify-content: center; border-radius: 14px; background: var(--primary); margin-top: -38px; position: relative; box-shadow: 0 8px 18px rgba(46,125,225,.25); }
.service-icon svg { stroke: #fff; width: 20px; height: 20px; }
.service-card h3 { margin: 14px 0 10px; font-size: 25px; line-height: 1.15; letter-spacing: -.02em; }
.service-card p { margin: 0 0 18px; color: var(--text-soft); font-size: 15px; line-height: 1.55; flex-grow: 1; }
.service-card strong { color: var(--primary); font-size: 26px; line-height: 1; font-weight: 800; margin-top: auto; }
.benefits { padding: 0 0 40px; }
.benefits-panel { background: linear-gradient(180deg, #eef4fb 0%, #eff4fa 100%); border-radius: 28px; padding: 36px 32px; display: grid; grid-template-columns: minmax(0, 1.25fr) minmax(220px, .45fr); align-items: center; gap: 32px; }
.benefits-copy h2 { margin-bottom: 26px; }
.benefits-grid { display: grid; grid-template-columns: repeat(5, minmax(160px, 1fr)); gap: 24px; align-items: start; }
.benefits-grid article { min-width: 0; display: grid; align-content: start; grid-template-rows: auto auto 1fr; row-gap: 0; }
.benefits-grid article svg { margin-bottom: 18px; }
.benefits-grid article h3 { margin: 0 0 12px; font-size: 18px; line-height: 1.2; letter-spacing: -.02em; max-width: none; min-height: 2.4em; }
.benefits-grid article p { margin: 0; font-size: 14px; line-height: 1.5; color: var(--text-soft); max-width: none; }
.benefits-media { align-self: stretch; display: flex; justify-content: flex-end; align-items: flex-end; }
.benefits-media img { width: min(100%, 290px); filter: drop-shadow(0 18px 22px rgba(56, 102, 170, .12)); }
.workflow { padding: 0 0 40px; }
.workflow-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 18px; margin-top: 32px; position: relative; }
.workflow-grid article { text-align: center; position: relative; }
.workflow-grid article:not(:last-child)::after { content: "→"; position: absolute; right: -16px; top: 34px; color: #b8c9e8; font-size: 24px; font-weight: 700; }
.step-icon { width: 82px; height: 82px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; background: #eef4fb; margin-bottom: 16px; }
.step-icon svg { width: 34px; height: 34px; }
.workflow-grid h3 { margin: 0 0 10px; font-size: 26px; line-height: 1.1; }
.workflow-grid p { margin: 0; color: var(--text-soft); line-height: 1.55; font-size: 15px; }
.reviews-cta { padding: 0 0 40px; }
.reviews-cta-grid { display: grid; grid-template-columns: 1.42fr .98fr; gap: 18px; align-items: start; }
.reviews-box, .cta-box { border-radius: 22px; min-height: 100%; }
.reviews-box { overflow: hidden; }
.cta-box { overflow: visible; position: relative; }
.reviews-box { background: #edf3fa; padding: 24px; }
.reviews-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.review-card { background: #fff; padding: 18px; border-radius: 16px; border: 1px solid rgba(219,227,238,.95); }
.review-top { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.review-top img { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; }
.review-top h3 { margin: 0 0 4px; font-size: 17px; }
.small { font-size: 12px; letter-spacing: .08em; }
.review-card p { margin: 0; font-size: 15px; line-height: 1.65; color: #354154; }
.cta-box { background: linear-gradient(135deg, #2c7be3 0%, #2a71cf 100%); color: #fff; display: grid; grid-template-columns: 1fr; align-items: stretch; min-height: 372px; align-self: start; }
.cta-copy { padding: 32px 210px 32px 32px; display: flex; flex-direction: column; justify-content: center; min-width: 0; }
.cta-copy h2 { margin: 0 0 16px; font-size: clamp(28px, 2.6vw, 36px); line-height: 1.02; letter-spacing: -.03em; max-width: 8ch; }
.cta-copy p { margin: 0 0 22px; color: rgba(255,255,255,.9); font-size: 16px; line-height: 1.5; max-width: 20ch; }
.cta-form { display: grid; grid-template-columns: 1fr; gap: 12px; align-items: stretch; max-width: 300px; }
.cta-form input { width: 100%; min-width: 0; min-height: 46px; padding: 0 16px; border-radius: 14px; border: 0; outline: none; }
.cta-media { position: absolute; right: -18px; bottom: 0; display: flex; align-items: flex-end; justify-content: flex-end; pointer-events: none; }
.cta-media img { width: min(280px, 31vw); }
.site-footer { background: linear-gradient(180deg, #0d3b82 0%, #08336f 100%); color: #fff; padding-top: 30px; }
.footer-grid { display: grid; grid-template-columns: 1.08fr .95fr .85fr .92fr .86fr; gap: 26px; }
.footer-grid h3 { margin: 8px 0 18px; font-size: 20px; }
.footer-grid ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.footer-grid li, .footer-grid p, .footer-bottom { color: rgba(255,255,255,.82); font-size: 14px; line-height: 1.55; }
.footer-brand { padding-right: 10px; }
.footer-brand-link { margin-bottom: 18px; }
.footer-brand .brand-copy small, .footer-brand .brand-copy strong { color: #fff; }
.socials { display: flex; gap: 10px; margin-top: 16px; }
.socials a { width: 34px; height: 34px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; background: rgba(255,255,255,.1); color: #fff; font-size: 11px; text-transform: uppercase; font-weight: 800; }
.footer-contacts { margin-bottom: 16px !important; }
.footer-map { width: 100%; border-radius: 12px; min-height: 128px; object-fit: cover; }
.footer-bottom { display: flex; flex-wrap: wrap; gap: 18px 30px; padding: 20px 0 24px; margin-top: 20px; border-top: 1px solid rgba(255,255,255,.12); }
@media (max-width: 1279px) {
  .header-inner { grid-template-columns: auto 1fr auto; }
  .header-cta { display: none; }
  .hero-grid { min-height: 580px; grid-template-columns: minmax(420px, 1fr) minmax(280px, .95fr); }
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .benefits-grid { grid-template-columns: repeat(3, 1fr); }
  .workflow-grid { grid-template-columns: repeat(3, 1fr); }
  .workflow-grid article:nth-child(3)::after { display: none; }
  .reviews-cta-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 1023px) {
  :root { --container: min(100% - 28px, 960px); }
  .main-nav, .header-contact { display: none; }
  .menu-toggle { display: inline-block; margin-left: auto; }
  .header-inner { grid-template-columns: auto 1fr auto; min-height: 64px; }
  .hero-section::before { background: linear-gradient(180deg, rgba(246,247,248,.95) 0%, rgba(246,247,248,.8) 36%, rgba(246,247,248,.56) 55%, rgba(246,247,248,.75) 100%); }
  .hero-media img { width: 100%; object-position: 68% center; opacity: .78; }
  .hero-grid { grid-template-columns: 1fr; align-items: start; min-height: auto; padding: 34px 0 56px; }
  .hero-copy { max-width: 680px; }
  .hero-section { min-height: auto; }
  .hero-copy h1 { max-width: none; }
  .hero-side { justify-content: flex-start; }
  .review-badge { margin: 0; width: fit-content; }
  .hero-curve { bottom: -62px; height: 130px; }
  .benefits-panel { grid-template-columns: 1fr; padding: 28px 24px; }
  .benefits-media { justify-content: center; }
  .workflow-grid { grid-template-columns: repeat(2, 1fr); }
  .workflow-grid article::after { display: none !important; }
  .reviews-grid { grid-template-columns: 1fr; }
  .cta-box { grid-template-columns: 1fr; min-height: auto; overflow: hidden; }
  .cta-copy { padding: 24px; }
  .cta-media { position: static; justify-content: center; pointer-events: auto; }
  .cta-media img { width: min(220px, 56vw); }
}
@media (max-width: 767px) {
  :root { --container: min(100% - 24px, 720px); }
  .brand-copy strong { font-size: 16px; }
  .brand-copy small { font-size: 10px; }
  .hero-copy h1 { font-size: clamp(34px, 10.5vw, 54px); }
  .hero-lead { font-size: 16px; }
  .hero-actions { flex-direction: column; align-items: stretch; }
  .hero-actions .btn { width: 100%; }
  .hero-features { display: grid; grid-template-columns: 1fr; gap: 12px; }
  .section-head { align-items: flex-start; flex-direction: column; }
  .services-grid, .benefits-grid, .workflow-grid, .footer-grid { grid-template-columns: 1fr; }
  .service-card h3, .workflow-grid h3 { font-size: 22px; }
  .benefits-grid article h3 { font-size: 20px; max-width: none; min-height: 0; }
  .benefits-grid article p { max-width: none; }
  .service-card strong { font-size: 24px; }
  .benefits-panel { border-radius: 22px; }
  .benefits-media img { width: min(240px, 74vw); }
  .cta-copy h2 { max-width: none; }
  .cta-copy p { max-width: none; }
  .cta-form { max-width: none; grid-template-columns: 1fr; }
  .cta-form { flex-direction: column; align-items: stretch; }
  .cta-form input { width: 100%; }
  .footer-bottom { flex-direction: column; gap: 10px; }
}
@media (max-width: 479px) {
  .header-inner { gap: 10px; }
  .brand { gap: 10px; }
  .brand img { width: 36px; height: 36px; }
  .btn { min-height: 50px; padding-inline: 20px; border-radius: 14px; }
  .hero-grid { padding-top: 26px; }
  .eyebrow { margin-bottom: 16px; }
  .review-badge { width: 100%; padding: 20px; }
  .section h2, .section-head h2, .workflow h2 { font-size: 32px; }
  .reviews-box { padding: 18px; }
  .review-card { padding: 16px; }
  .cta-copy { padding: 20px; }
}