:root {
  --primary: #5469e8;
  --primary-dark: #3d51ce;
  --navy: #17203d;
  --text: #626c85;
  --line: #e2e6f1;
  --tint: #f5f7fc;
  --white: #fff;
  --shadow: 0 20px 55px rgba(36, 48, 100, .11);
  --shadow-soft: 0 12px 34px rgba(38, 53, 112, .07);
  --radius: 22px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; overflow-x: hidden; color: var(--navy); background: #f8f9fd; font-family: "Manrope", Arial, sans-serif; font-size: 15px; line-height: 1.6; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
a { color: inherit; text-decoration: none; }
p { color: var(--text); line-height: 1.8; }
.container { width: min(1160px, calc(100% - 40px)); margin: 0 auto; }

.header { position: fixed; z-index: 50; top: 0; left: 0; width: 100%; border-bottom: 1px solid transparent; transition: .25s ease; }
.header.scrolled { border-color: var(--line); background: rgba(255,255,255,.92); box-shadow: 0 8px 30px rgba(28,38,80,.06); backdrop-filter: blur(14px); }
.header__inner { height: 78px; display: flex; align-items: center; justify-content: space-between; }
.logo { display: inline-flex; align-items: center; gap: 10px; font-size: 18px; font-weight: 800; }
.logo__mark, .mini-logo { display: grid; place-items: center; color: #fff; background: var(--primary); font-weight: 800; transform: rotate(-4deg); }
.logo__mark { width: 34px; height: 34px; border-radius: 10px; }
.nav { display: flex; align-items: center; gap: 34px; font-size: 14px; font-weight: 600; }
.nav > a:not(.button):hover { color: var(--primary); }
.menu-toggle { display: none; padding: 6px; border: 0; background: transparent; }
.menu-toggle span { display: block; width: 24px; height: 2px; margin: 5px; background: var(--navy); transition: .25s; }

.button { display: inline-flex; min-height: 56px; padding: 0 27px; align-items: center; justify-content: center; gap: 13px; border: 1px solid rgba(74, 94, 218, .72); border-radius: 14px; color: #fff; background: linear-gradient(135deg, #6276ee 0%, #4b60dd 100%); box-shadow: 0 12px 28px rgba(74, 94, 218, .28), inset 0 1px 0 rgba(255,255,255,.2); font-size: 14px; font-weight: 700; letter-spacing: -.01em; transition: transform .25s ease, box-shadow .25s ease, background .25s ease; }
.button:hover { background: linear-gradient(135deg, #566be7 0%, #3f54d1 100%); box-shadow: 0 16px 34px rgba(63, 82, 207, .34), inset 0 1px 0 rgba(255,255,255,.2); transform: translateY(-3px); }
.button:focus-visible, a:focus-visible, .menu-toggle:focus-visible { outline: 3px solid rgba(82, 104, 232, .28); outline-offset: 4px; }
.button svg { width: 19px; fill: none; stroke: currentColor; stroke-linecap: round; stroke-linejoin: round; stroke-width: 1.8; }
.button--small { min-height: 42px; padding: 0 18px; border-radius: 10px; }
.button--secondary { border-color: rgba(208,214,233,.95); color: var(--navy); background: rgba(255,255,255,.84); box-shadow: 0 10px 28px rgba(39,50,99,.07); backdrop-filter: blur(8px); }
.button--secondary:hover { color: var(--primary); background: #fff; box-shadow: 0 14px 32px rgba(39,50,99,.11); }

.hero { position: relative; min-height: 780px; padding: 158px 0 110px; overflow: hidden; background: radial-gradient(circle at 78% 22%, rgba(173,182,244,.32), transparent 28%), radial-gradient(circle at 8% 75%, rgba(181,219,242,.28), transparent 25%), linear-gradient(135deg, #fbfcff 5%, #f3f5ff 52%, #eef4fb 100%); }
.hero::before { position: absolute; inset: 0; opacity: .55; background-image: linear-gradient(rgba(104,119,190,.045) 1px, transparent 1px), linear-gradient(90deg, rgba(104,119,190,.045) 1px, transparent 1px), radial-gradient(#bec7ef 1px, transparent 1px); background-position: 0 0, 0 0, 14px 14px; background-size: 56px 56px, 56px 56px, 28px 28px; content: ""; mask-image: linear-gradient(105deg, #000, rgba(0,0,0,.3) 52%, transparent 88%); }
.hero::after { position: absolute; z-index: 1; right: 0; bottom: -1px; left: 0; height: 150px; background: linear-gradient(to bottom, transparent, rgba(244,248,255,.82) 68%, #f4f8ff 100%); content: ""; pointer-events: none; }
.hero__inner { position: relative; z-index: 2; display: grid; grid-template-columns: 1.08fr .92fr; align-items: center; gap: 80px; }
.hero__content h1 { max-width: 660px; margin: 22px 0 25px; font-size: clamp(44px, 5vw, 68px); font-weight: 800; line-height: 1.08; letter-spacing: -.052em; text-wrap: balance; }
.hero__content h1 span { color: var(--primary); }
.hero__content > p { max-width: 640px; margin: 0; font-size: 18px; line-height: 1.75; }
.eyebrow { display: inline-flex; padding: 9px 14px; align-items: center; gap: 9px; border: 1px solid rgba(211,217,241,.9); border-radius: 50px; color: #53607e; background: rgba(255,255,255,.72); box-shadow: 0 7px 22px rgba(52,64,117,.06); backdrop-filter: blur(8px); font-size: 12px; font-weight: 700; }
.eyebrow span { width: 7px; height: 7px; border-radius: 50%; background: #56c79b; box-shadow: 0 0 0 4px rgba(86,199,155,.15); }
.hero__actions { display: flex; gap: 13px; margin-top: 34px; }
.hero__notes { display: flex; gap: 28px; margin-top: 32px; color: #7a8196; font-size: 12px; font-weight: 600; }
.hero__notes span::before { margin-right: 8px; color: #51b990; content: "✓"; }
.hero-card { position: relative; padding: 27px; border: 1px solid rgba(255,255,255,.9); border-radius: 27px; background: rgba(255,255,255,.86); box-shadow: 0 35px 85px rgba(45,58,123,.18), inset 0 1px 0 #fff; backdrop-filter: blur(14px); transform: rotate(1.2deg); }
.hero-card::before { position: absolute; z-index: -1; inset: 18px -18px -18px 18px; border-radius: 25px; background: rgba(158,169,235,.2); content: ""; }
.hero-card__top, .task-item, .hero-card__bottom { display: flex; align-items: center; }
.hero-card__top { padding-bottom: 20px; border-bottom: 1px solid var(--line); gap: 12px; }
.mini-logo { width: 40px; height: 40px; border-radius: 11px; }
.hero-card strong { display: block; font-size: 13px; }
.hero-card small { display: block; margin-top: 3px; color: #9299ad; font-size: 10px; }
.status { margin-left: auto; padding: 6px 9px; border-radius: 20px; color: #369474; background: #eaf9f3; font-size: 9px; font-weight: 700; }
.task-list { display: grid; gap: 11px; padding: 20px 0; }
.task-item { padding: 15px; gap: 13px; border: 1px solid #e9edf6; border-radius: 14px; background: rgba(255,255,255,.92); box-shadow: 0 8px 22px rgba(42,54,110,.055); transition: transform .25s ease, box-shadow .25s ease; }
.task-item:hover { box-shadow: 0 13px 28px rgba(42,54,110,.1); transform: translateX(3px); }
.task-icon { display: grid; width: 39px; height: 39px; place-items: center; border-radius: 10px; color: #4862d8; background: #edf0ff; font-size: 13px; font-weight: 800; }
.task-icon--violet { color: #7858d6; background: #f1edff; }
.task-icon--orange { color: #d98640; background: #fff2e7; }
.check { margin-left: auto; color: #57bd95; }
.hero-card__bottom { justify-content: space-between; color: #7f879d; font-size: 10px; }
.avatars { display: flex; }
.avatars i { display: grid; width: 26px; height: 26px; margin-left: -6px; place-items: center; border: 2px solid #fff; border-radius: 50%; color: #fff; background: #7b8ce6; font-size: 8px; font-style: normal; font-weight: 700; }
.avatars i:nth-child(2) { background: #e6927d; }.avatars i:nth-child(3) { background: #9aa2b7; }
.hero__shape { position: absolute; border-radius: 50%; filter: blur(2px); }
.hero__shape--one { right: 4%; bottom: 12%; width: 200px; height: 200px; background: rgba(111,127,227,.11); }
.hero__shape--two { top: 19%; right: 41%; width: 55px; height: 55px; background: rgba(245,184,112,.16); }

.section { padding: 112px 0; }
.section--tint { background: linear-gradient(180deg, #f7f8fc 0%, #f3f5fa 100%); }
#services {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background:
    radial-gradient(circle at 1px 1px, rgba(91, 108, 190, .11) 1px, transparent 1.2px) 0 0 / 27px 27px,
    linear-gradient(160deg, #f4f8ff 0%, #f5f4fd 48%, #eef5fb 100%);
}
#services::before,
#services::after {
  position: absolute;
  z-index: -1;
  border-radius: 50%;
  content: "";
  pointer-events: none;
  filter: blur(18px);
}
#services::before {
  top: -170px;
  left: -130px;
  width: 420px;
  height: 420px;
  background: rgba(145, 183, 244, .2);
}
#services::after {
  right: -150px;
  bottom: -210px;
  width: 480px;
  height: 480px;
  background: rgba(176, 158, 235, .18);
}
#services .container { position: relative; z-index: 1; }
.section-heading, .split-heading { display: flex; margin-bottom: 54px; align-items: end; justify-content: space-between; gap: 40px; }
.section-heading h2, .split-heading h2, .center-heading h2, .process-intro h2 { margin: 11px 0 0; font-size: clamp(33px, 4vw, 45px); font-weight: 800; line-height: 1.16; letter-spacing: -.044em; text-wrap: balance; }
.section-heading p, .split-heading p { max-width: 440px; margin: 0; }
.section-label { color: var(--primary); font-size: 11px; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.service-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 21px; }
.service-card { padding: 33px; border: 1px solid rgba(204, 211, 233, .88); border-radius: var(--radius); background: rgba(255, 255, 255, .9); box-shadow: 0 13px 34px rgba(52, 67, 126, .075), inset 0 1px 0 #fff; backdrop-filter: blur(8px); transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease; }
.service-card:hover { border-color: #bdc8f1; box-shadow: 0 24px 54px rgba(49, 64, 127, .15), inset 0 1px 0 #fff; transform: translateY(-8px); }
.card-icon { display: grid; width: 50px; height: 50px; margin-bottom: 27px; place-items: center; border: 1px solid rgba(255,255,255,.75); border-radius: 15px; color: #5268df; background: #edf0ff; box-shadow: 0 8px 20px rgba(70,85,153,.08); font-size: 19px; font-weight: 800; }
.card-icon--violet { color: #785ed6; background: #f1edff; }.card-icon--orange { color: #db8640; background: #fff1e5; }.card-icon--green { color: #3c9c7b; background: #e8f7f1; }.card-icon--pink { color: #ca6e89; background: #fcecf2; }.card-icon--cyan { color: #318fa5; background: #e8f7fa; }
.service-card h3, .advantage h3, .audience-card h3 { margin: 0; font-size: 17px; font-weight: 750; letter-spacing: -.02em; }
.service-card p, .advantage p, .audience-card p { margin: 11px 0 22px; font-size: 13px; line-height: 1.7; }
.service-card a { color: var(--navy); font-size: 12px; font-weight: 700; }.service-card a span, .text-link span { margin-left: 5px; color: var(--primary); }

.advantage-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.advantage { position: relative; padding: 31px 27px 23px; border: 1px solid rgba(220,224,237,.95); border-radius: var(--radius); background: rgba(255,255,255,.86); box-shadow: var(--shadow-soft); overflow: hidden; transition: transform .28s ease, box-shadow .28s ease; }
.advantage:hover { box-shadow: 0 18px 42px rgba(45,57,108,.11); transform: translateY(-5px); }
.advantage > span { position: absolute; top: 18px; right: 20px; color: #d4d8e5; font-size: 11px; font-weight: 800; }
.advantage__icon { display: grid; width: 42px; height: 42px; margin-bottom: 23px; place-items: center; border-radius: 50%; color: var(--primary); background: #eef0ff; font-size: 17px; }

#process { position: relative; overflow: hidden; background: radial-gradient(circle at 96% 18%, rgba(195,205,245,.23), transparent 24%), #fff; }
#process::before { position: absolute; top: 55px; right: -90px; width: 270px; height: 270px; border: 1px solid rgba(105,122,207,.11); border-radius: 50%; box-shadow: 0 0 0 45px rgba(105,122,207,.025), 0 0 0 90px rgba(105,122,207,.018); content: ""; pointer-events: none; }
.process-layout { position: relative; display: grid; grid-template-columns: .85fr 1.15fr; gap: 100px; }
.process-intro { position: sticky; top: 130px; align-self: start; }
.process-intro p { max-width: 390px; margin: 20px 0 28px; }
.text-link { color: var(--primary); font-size: 13px; font-weight: 700; }
.steps { position: relative; display: grid; gap: 0; margin: 0; padding: 0; list-style: none; }
.steps::before { position: absolute; top: 28px; bottom: 55px; left: 25px; width: 1px; background: #dce0ef; content: ""; }
.steps li { position: relative; display: flex; padding: 0 0 42px; gap: 25px; }
.step-number { z-index: 1; display: grid; flex: 0 0 54px; height: 54px; place-items: center; border: 1px solid #dce1f0; border-radius: 16px; color: var(--primary); background: linear-gradient(145deg, #fff, #f7f8ff); box-shadow: 0 9px 24px rgba(49,60,110,.09); font-size: 13px; font-weight: 800; }
.steps h3 { margin: 3px 0 6px; font-size: 17px; }.steps p { margin: 0; font-size: 13px; }

.audience { position: relative; overflow: hidden; background: radial-gradient(circle at 10% 10%, rgba(178,210,239,.2), transparent 28%), radial-gradient(circle at 90% 90%, rgba(190,177,235,.16), transparent 25%), linear-gradient(155deg, #f8faff, #f5f6fc); }
.center-heading { max-width: 620px; margin: 0 auto 48px; text-align: center; }.center-heading p { margin: 16px 0 0; }
.audience-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 19px; }
.audience-card { position: relative; min-height: 200px; padding: 32px 27px; border: 1px solid rgba(217,222,238,.95); border-radius: var(--radius); background: rgba(255,255,255,.88); box-shadow: var(--shadow-soft); backdrop-filter: blur(6px); transition: transform .28s ease, box-shadow .28s ease; }
.audience-card:hover { box-shadow: 0 20px 44px rgba(45,57,108,.12); transform: translateY(-5px); }
.audience-card > span { display: block; margin-bottom: 35px; color: var(--primary); font-size: 11px; font-weight: 800; }

.contact-section { padding-top: 58px; background: linear-gradient(180deg, #f8f9fd 0%, #fff 100%); }
.contact-card { position: relative; display: flex; min-height: 350px; padding: 68px 76px; align-items: center; justify-content: space-between; border: 1px solid rgba(255,255,255,.28); border-radius: 30px; color: #fff; background: radial-gradient(circle at 85% 15%, rgba(255,255,255,.13), transparent 30%), linear-gradient(125deg, #465bd5 0%, #6879e9 58%, #7181ed 100%); box-shadow: 0 30px 70px rgba(61,77,183,.27), inset 0 1px 0 rgba(255,255,255,.2); overflow: hidden; }
.contact-card::before, .contact-card::after { position: absolute; border: 1px solid rgba(255,255,255,.1); border-radius: 50%; content: ""; }.contact-card::before { right: -90px; bottom: -220px; width: 450px; height: 450px; }.contact-card::after { top: -180px; right: 100px; width: 330px; height: 330px; }
.contact-card__content { position: relative; z-index: 2; max-width: 640px; }.contact-label { color: #ced5ff; font-size: 11px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.contact-card h2 { margin: 10px 0 10px; font-size: clamp(34px, 5vw, 49px); letter-spacing: -.04em; }.contact-card p { margin: 0 0 28px; color: #e2e6ff; }
.button--light { border-color: #fff; color: var(--primary); background: #fff; box-shadow: 0 13px 30px rgba(29,40,111,.22); }.button--light:hover { color: var(--primary-dark); background: #fff; box-shadow: 0 17px 36px rgba(29,40,111,.28); }
.contact-card__note { z-index: 2; display: flex; min-width: 220px; padding: 18px; align-items: center; gap: 13px; border: 1px solid rgba(255,255,255,.15); border-radius: 14px; background: rgba(255,255,255,.1); backdrop-filter: blur(8px); }
.contact-card__note strong, .contact-card__note small { display: block; }.contact-card__note strong { font-size: 12px; }.contact-card__note small { margin-top: 3px; color: #dce1ff; font-size: 9px; }
.online-dot { width: 10px; height: 10px; border: 3px solid rgba(255,255,255,.35); border-radius: 50%; background: #6ee0ad; box-sizing: content-box; }
.contact-card__decor { position: absolute; top: 15px; right: 35%; color: rgba(255,255,255,.05); font-family: Georgia, serif; font-size: 190px; transform: rotate(-10deg); }

.footer { padding: 30px 0; border-top: 1px solid var(--line); }.footer__inner { display: flex; align-items: center; justify-content: space-between; }.footer p, .footer__inner > a:last-child { font-size: 11px; }.footer__inner > a:last-child { color: var(--primary); font-weight: 700; }
.reveal { opacity: 0; transform: translateY(20px); transition: opacity .6s ease, transform .6s ease; }.reveal.visible { opacity: 1; transform: translateY(0); }

@media (max-width: 900px) {
  .hero { min-height: auto; }.hero__inner { grid-template-columns: 1fr; gap: 60px; }.hero__content { text-align: center; }.hero__content > p { margin-inline: auto; }.eyebrow { margin-inline: auto; }.hero__actions, .hero__notes { justify-content: center; }.hero-card { width: min(520px, 100%); margin: 0 auto; }
  .service-grid { grid-template-columns: repeat(2, 1fr); }.advantage-grid, .audience-grid { grid-template-columns: repeat(2, 1fr); }.process-layout { gap: 55px; }
  .contact-card { padding: 55px 45px; gap: 35px; }
}

@media (max-width: 700px) {
  .container { width: min(100% - 28px, 1160px); }.header__inner { height: 68px; }.menu-toggle { display: block; cursor: pointer; }
  .nav { position: absolute; top: 67px; right: 14px; left: 14px; display: none; padding: 20px; align-items: stretch; gap: 4px; border: 1px solid var(--line); border-radius: 15px; background: #fff; box-shadow: var(--shadow); }.nav.open { display: flex; flex-direction: column; }.nav > a { padding: 12px; }.nav .button { margin-top: 8px; }
  .menu-toggle.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }.menu-toggle.active span:nth-child(2) { opacity: 0; }.menu-toggle.active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
  .hero { padding: 118px 0 86px; }.hero::after { height: 105px; }.hero__content h1 { font-size: clamp(36px, 11vw, 42px); line-height: 1.1; }.hero__content > p { font-size: 16px; }.hero__actions { flex-direction: column; }.hero__actions .button { width: 100%; min-height: 58px; }.hero__notes { flex-direction: column; gap: 10px; }.hero-card { padding: 17px; border-radius: 22px; transform: none; }
  .section { padding: 80px 0; }.section-heading, .split-heading { display: block; margin-bottom: 38px; }.section-heading h2, .split-heading h2, .center-heading h2, .process-intro h2 { font-size: clamp(30px, 9vw, 36px); }.section-heading p, .split-heading p { margin-top: 17px; }.service-grid, .advantage-grid, .audience-grid { grid-template-columns: 1fr; gap: 16px; }.service-card { padding: 28px; }.service-card:hover, .advantage:hover, .audience-card:hover { transform: none; }
  .process-layout { grid-template-columns: 1fr; gap: 45px; }.process-intro { position: static; }.steps li { gap: 18px; }.steps h3 { font-size: 15px; }
  .audience-card { min-height: auto; }.audience-card > span { margin-bottom: 22px; }
  .contact-section { padding-top: 28px; }.contact-card { padding: 46px 26px; align-items: flex-start; flex-direction: column; border-radius: 24px; }.contact-card__note { min-width: 100%; }.contact-card h2 { font-size: 37px; }.contact-card .button { width: 100%; min-height: 58px; }.contact-card__content { width: 100%; }
  .footer__inner { flex-direction: column; gap: 10px; text-align: center; }
}

@media (max-width: 380px) {
  .container { width: min(100% - 22px, 1160px); }
  .hero__content h1 { font-size: 34px; }
  .button { padding-inline: 20px; }
  .service-card, .advantage, .audience-card { padding: 25px 22px; }
  .task-item { padding: 12px; }
  .contact-card { padding-inline: 21px; }
}

@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } *, *::before, *::after { transition-duration: .01ms !important; animation-duration: .01ms !important; } .reveal { opacity: 1; transform: none; } }
