/* Rubtsov.pro — site styles */
:root {
    --purple: #9747fe;
    --lime: #ccfd66;
    --dark: #1f1f1f;
    --bg: #f1f1f1;
    --white: #ffffff;
    --radius: 12px;
    --radius-lg: 20px;
    --font: 'Raleway', Arial, sans-serif;
    --font-flow: 'Flow', Arial, sans-serif;
    --shell: 1440px;
    --shell-pad: 16px;
    --shadow: 0 8px 32px rgba(0, 0, 0, 0.06);
}

@font-face {
    font-family: 'Flow';
    src: url('/assets/fonts/Flow.woff') format('woff');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Flow';
    src: url('/assets/fonts/Flow_B.woff') format('woff');
    font-weight: 600 700;
    font-style: normal;
    font-display: swap;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body.site-body {
    margin: 0;
    font-family: var(--font);
    color: var(--dark);
    background: var(--bg);
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; display: block; }
a { color: inherit; }

.mod-container { max-width: var(--shell); margin: 0 auto; padding: 0 var(--shell-pad); }
.mod-facts .mod-container,
.mod-services .mod-container,
.mod-features .mod-container,
.mod-card-grid .mod-container,
.mod-svc-audit .mod-container,
.mod-steps .mod-container,
.mod-pricing .mod-container,
.mod-cases .mod-container,
.mod-arsenal .mod-container,
.mod-clients .mod-container,
.mod-testimonials .mod-container,
.mod-faq .mod-container,
.mod-about-intro .mod-container,
.mod-about-mission .mod-container,
.mod-about-values .mod-container,
.mod-about-team .mod-container,
.mod-about-patents .mod-container,
.mod-content--legal .mod-container {
    width: calc(100% * 10 / 12);
    max-width: calc(var(--shell) * 10 / 12);
    padding-inline: 0;
}
.site-shell { max-width: var(--shell); margin: 0 auto; padding: 0 var(--shell-pad); }
.mod-section-title { font-size: clamp(28px, 4vw, 42px); font-weight: 700; margin: 0 0 32px; line-height: 1.15; }
.mod-headline { margin: 0; font-size: clamp(32px, 4.5vw, 47px); font-weight: 600; line-height: 1.05; }
.mod-headline--section { margin-bottom: 40px; }
.mod-headline__main { color: var(--dark); }
.mod-headline__accent { font-family: var(--font-flow); color: var(--purple); font-weight: 400; }
.mod-page-title { font-size: clamp(32px, 5vw, 52px); font-weight: 700; margin: 0 0 16px; line-height: 1.12; }
.mod-page-lead { font-size: 18px; opacity: .75; margin: 0 0 32px; max-width: 720px; }
.mod-link { color: var(--purple); font-weight: 600; text-decoration: none; }
.mod-link:hover { text-decoration: underline; }

.btn {
    display: inline-flex; align-items: center; justify-content: center;
    padding: 14px 28px; border-radius: var(--radius); font-weight: 600;
    text-decoration: none; border: none; cursor: pointer; font-family: inherit;
    font-size: 14px; transition: background .2s, color .2s, transform .15s;
}
.btn--primary { background: var(--purple); color: #fff; }
.btn--primary:hover { background: var(--lime); color: var(--dark); }
.btn--purple { background: var(--purple); color: #fff; }
.btn--purple:hover { background: #7f35e8; color: #fff; }
.btn--secondary, .btn--lime { background: var(--lime); color: var(--dark); }
.btn--secondary:hover, .btn--lime:hover { background: var(--purple); color: #fff; }
.btn--sm { padding: 10px 18px; font-size: 13px; border-radius: 10px; }
.btn--white { background: var(--white); color: var(--dark); }
.btn--white:hover { background: var(--lime); color: var(--dark); }
.btn--outline-white {
    background: transparent; color: var(--white);
    border: 2px solid rgba(255,255,255,.85);
}
.btn--outline-white:hover { background: var(--white); color: var(--dark); }

/* Header */
.site-header {
    position: sticky; top: 0; z-index: 200;
    padding: 12px 0 8px;
    background: transparent;
}
.site-header__shell { max-width: var(--shell); margin: 0 auto; padding: 0 var(--shell-pad); }
.site-header__inner {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center; gap: 12px 20px;
    background: var(--white); border-radius: var(--radius-lg);
    padding: 16px 48px; box-shadow: var(--shadow); min-height: 70px;
}
.site-header__brand { grid-column: 1; grid-row: 1; display: flex; align-items: center; text-decoration: none; flex-shrink: 0; }
.site-header__logo-img { height: 31px; width: auto; max-width: 200px; }
.site-header__tagline { display: none !important; }
.site-header__nav {
    grid-column: 2; grid-row: 1;
    display: flex; align-items: center; justify-content: center;
    gap: clamp(12px, 2vw, 24px); min-width: 0;
}
.site-header__nav > a,
.site-header__dropdown-toggle {
    text-decoration: none; font-weight: 600; font-size: 15px; color: var(--dark);
    background: none; border: none; cursor: pointer; font-family: inherit;
    display: inline-flex; align-items: center; gap: 6px; padding: 0; white-space: nowrap;
    transition: color .2s;
}
.site-header__nav > a:hover,
.site-header__dropdown-toggle:hover { color: var(--purple); }
.site-header__dropdown { position: relative; }
.site-header__dropdown-menu {
    display: none; position: absolute; top: calc(100% + 10px); left: 50%;
    transform: translateX(-50%); min-width: 220px;
    background: var(--white); border-radius: var(--radius); padding: 8px;
    box-shadow: 0 12px 40px rgba(0,0,0,.12); z-index: 400;
}
.site-header__dropdown-menu a {
    display: block; padding: 10px 12px; border-radius: 8px;
    text-decoration: none; font-size: 14px; font-weight: 500; color: var(--dark);
}
.site-header__dropdown-menu a:hover { background: var(--bg); color: var(--purple); }
.site-header__dropdown.is-open .site-header__dropdown-menu { display: block; }
.site-header__dropdown.is-open .site-header__dropdown-toggle { color: var(--purple); }
.site-header__right {
    grid-column: 3; grid-row: 1;
    display: flex; align-items: center; gap: 12px; justify-content: flex-end;
}
.site-header__phone {
    display: inline-flex; align-items: center; gap: 8px;
    font-weight: 600; text-decoration: none; font-size: 14px; white-space: nowrap;
}
.site-header__phone img { flex-shrink: 0; width: 20px; height: 20px; }
.site-header__nav-mobile { display: none; }
.site-header__burger {
    display: none; grid-column: 3; grid-row: 1;
    flex-direction: column; gap: 5px; justify-self: end;
    background: none; border: none; padding: 8px; cursor: pointer;
}
.site-header__burger span {
    display: block; width: 22px; height: 2px; background: var(--dark); border-radius: 2px;
}

@media (max-width: 1100px) {
    .site-header__phone span { display: none; }
    .site-header__nav { gap: 14px; }
    .site-header__nav > a,
    .site-header__dropdown-toggle { font-size: 14px; }
}

@media (max-width: 960px) {
    .site-header__inner {
        grid-template-columns: 1fr auto;
        padding: 14px 28px;
    }
    .site-header__brand { grid-column: 1; }
    .site-header__burger { display: flex; grid-column: 2; }
    .site-header__right { display: none; }
    .site-header__nav {
        grid-column: 1 / -1; grid-row: 2;
        display: none; flex-direction: column; align-items: stretch;
        gap: 0; padding-top: 8px; margin-top: 4px;
        border-top: 1px solid #eee;
    }
    .site-header__nav.is-open { display: flex; }
    .site-header__nav > a,
    .site-header__dropdown { padding: 12px 0; border-bottom: 1px solid #f0f0f0; }
    .site-header__dropdown-toggle { width: 100%; justify-content: space-between; }
    .site-header__dropdown-menu {
        position: static; transform: none; box-shadow: none;
        padding: 4px 0 0 12px; min-width: 0;
    }
    .site-header__nav-mobile {
        display: flex; flex-direction: column; gap: 12px;
        padding-top: 16px; margin-top: 8px; border-top: 1px solid #eee;
    }
    .site-header__nav-mobile .site-header__phone span { display: inline; }
}

/* Hero */
.mod-hero { padding: 8px 0 48px; background: var(--bg); }
.mod-hero__shell { max-width: var(--shell); margin: 0 auto; padding: 0 var(--shell-pad); }
.mod-hero__card {
    position: relative; overflow: hidden;
    background: var(--purple); border-radius: 24px;
    display: flex; align-items: center;
    min-height: min(80vh, 620px);
    padding: 64px 56px 56px 72px;
}
.mod-hero__card::before {
    content: '';
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 90%; height: 100%;
    background: url('/assets/img/Vector_2.svg') center / cover no-repeat;
    pointer-events: none;
    z-index: 0;
}
.mod-hero__art {
    position: absolute; inset: 0;
    z-index: 1; pointer-events: none;
}
.mod-hero__scene {
    position: absolute; inset: 0;
}
.mod-hero__content {
    position: relative; z-index: 3;
    max-width: 740px;
    width: min(740px, 56%);
    padding: 8px 0;
}
.mod-hero__headline {
    margin: 0 0 28px;
    display: flex; flex-direction: column; gap: 10px;
}
.mod-hero__title,
.mod-hero__title-accent {
    font-size: 47px;
    line-height: 1;
    letter-spacing: 0;
}
.mod-hero__title {
    font-family: var(--font);
    font-weight: 600;
    color: var(--white);
}
.mod-hero__title-accent {
    font-family: var(--font-flow);
    font-weight: 600;
    color: var(--lime);
}
.mod-hero__subtitle {
    font-size: 16px;
    font-weight: 400;
    line-height: 1.55;
    color: rgba(255, 255, 255, 0.9);
    margin: 0 0 36px;
    max-width: 680px;
}
.mod-hero__actions { display: flex; gap: 12px; flex-wrap: wrap; }
.mod-hero__ill {
    position: absolute; height: auto;
    pointer-events: none; user-select: none;
}
.site-main--home .mod-hero__card[data-hero-parallax] .mod-hero__scene {
    transform-style: preserve-3d;
    transform: perspective(1100px) rotateX(var(--hero-tilt-x, 0deg)) rotateY(var(--hero-tilt-y, 0deg));
    will-change: transform;
}
.site-main--home .mod-hero__card[data-hero-parallax] .mod-hero__ill {
    will-change: transform;
}
.site-main--home .mod-hero__card[data-hero-parallax]::before {
    transform: translate(calc(-50% + var(--hero-bg-x, 0px)), calc(-50% + var(--hero-bg-y, 0px)));
}
.mod-hero__ill--picnic {
    width: clamp(210px, 22vw, 326px);
    top: calc(50% - 109px);
    right: clamp(70px, 8%, 111px);
    transform: translateY(-50%);
    z-index: 2;
}
.mod-hero__ill--globe {
    width: clamp(140px, 14vw, 190px);
    left: 66%;
    right: auto;
    transform: translateX(-50%);
    bottom: 0;
    z-index: 4;
}
.mod-hero__ill--ufo {
    width: clamp(44px, 4vw, 56px);
    left: 58%;
    right: auto;
    transform: translateX(-50%);
    bottom: 0;
    z-index: 5;
}
.mod-hero__ill--archer {
    width: clamp(110px, 11vw, 156px);
    right: clamp(16px, 2%, 24px);
    bottom: 41px;
    z-index: 5;
}
.mod-hero__ill--bike {
    width: clamp(60px, 6vw, 85px);
    top: calc(50% + 67px);
    right: clamp(340px, 38%, 520px);
    transform: translateY(-50%);
    z-index: 3;
}
.mod-hero__ill--chair {
    width: clamp(70px, 7vw, 93px);
    top: calc(50% + 95px);
    right: clamp(140px, 15%, 210px);
    transform: translateY(-50%);
    z-index: 3;
}
.mod-hero__ill--plane {
    width: clamp(38px, 4vw, 52px);
    top: calc(50% + 165px);
    right: clamp(430px, 48%, 660px);
    transform: translateY(-50%);
    z-index: 3;
}
.mod-hero__ill--rocket {
    width: clamp(28px, 3vw, 40px);
    top: calc(50% + 5px);
    right: clamp(290px, 32%, 433px);
    transform: translateY(-50%);
    z-index: 3;
}

@media (max-width: 1199px) {
    .mod-hero__title,
    .mod-hero__title-accent { font-size: 37px; }
    .mod-hero__card { padding: 56px 48px 48px 56px; min-height: 540px; }
    .mod-hero__ill--picnic { width: clamp(190px, 28vw, 256px); }
}

@media (max-width: 1024px) {
    .mod-hero__card {
        display: block;
        padding: 48px 40px 0;
        min-height: 0;
    }
    .mod-hero__content { width: 100%; max-width: none; padding: 0; }
    .mod-hero__art {
        position: relative; inset: auto;
        height: 320px; margin-top: 16px;
    }
    .mod-hero__scene { position: relative; height: 100%; }
    .mod-hero__ill--picnic {
        top: 0; right: 8%; transform: none;
        width: min(240px, 52%);
    }
    .mod-hero__ill--ufo {
        left: 50%; right: auto;
        transform: translateX(-50%);
        bottom: 0;
        width: min(56px, 14%);
    }
    .mod-hero__ill--archer {
        right: 0; bottom: 8%;
        width: 120px;
    }
    .mod-hero__ill--bike {
        top: 38%; right: 38%; transform: translateY(-50%);
        width: 72px;
    }
    .mod-hero__ill--chair {
        top: 52%; right: 14%; transform: translateY(-50%);
        width: 80px;
    }
    .mod-hero__ill--globe,
    .mod-hero__ill--plane,
    .mod-hero__ill--rocket { display: none; }
}

@media (max-width: 639px) {
    .mod-hero__card::before { width: 100%; top: 13px; transform: translate(-50%, 0); }
    .mod-hero__title,
    .mod-hero__title-accent { font-size: 30px; }
    .mod-hero__title { line-height: 1.1; }
    .mod-hero__card { padding: 32px 24px 0; border-radius: 18px; }
    .mod-hero__headline { margin-bottom: 20px; gap: 8px; }
    .mod-hero__subtitle { font-size: 15px; margin-bottom: 24px; }
    .mod-hero__actions .btn { width: 100%; }
    .mod-hero__art { height: 240px; }
    .mod-hero__ill--picnic { width: min(200px, 58%); right: 4%; }
    .mod-hero__ill--ufo { width: min(48px, 16%); left: 50%; right: auto; transform: translateX(-50%); bottom: 0; }
    .mod-hero__ill--archer { width: 96px; }
    .mod-hero__ill--bike,
    .mod-hero__ill--chair { display: none; }
}

@media (max-width: 479px) {
    .mod-hero__title,
    .mod-hero__title-accent { font-size: 19px; }
    .mod-hero__title { line-height: 1.3; }
}

@media (max-width: 400px) {
    .mod-hero__ill--archer { display: none; }
}

/* Service page modules */
.mod-svc-hero { padding: 8px 0 48px; background: var(--bg); }
.mod-svc-hero__shell { max-width: var(--shell); margin: 0 auto; padding: 0 var(--shell-pad); }
.mod-svc-hero__card {
    position: relative; overflow: hidden;
    background: var(--purple); border-radius: 24px;
    min-height: min(80vh, 620px);
    padding: 40px 56px 48px 72px;
    display: flex; flex-direction: column; justify-content: center;
}
.mod-svc-hero__card::before {
    content: '';
    position: absolute; top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 90%; height: 100%;
    background: url('/assets/img/Vector_2.svg') center / cover no-repeat;
    pointer-events: none; z-index: 0;
}
.mod-svc-hero__breadcrumb {
    position: relative; z-index: 2;
    display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
    margin: 0 0 32px; font-size: 14px; font-weight: 500;
    color: rgba(255, 255, 255, 0.72);
}
.mod-svc-hero__breadcrumb a { color: inherit; text-decoration: none; }
.mod-svc-hero__breadcrumb a:hover { color: #fff; }
.mod-svc-hero__breadcrumb-current { color: rgba(255, 255, 255, 0.72); font-weight: 500; }
.mod-svc-hero__layout {
    position: relative; z-index: 2;
    display: flex; align-items: center; justify-content: space-between;
    gap: 32px; flex: 1;
}
.mod-svc-hero__content {
    flex: 0 1 740px; max-width: 740px; min-width: 0;
}
.mod-svc-hero__headline {
    margin: 0 0 20px;
    display: flex; flex-direction: column; gap: 8px;
}
.mod-svc-hero__title,
.mod-svc-hero__title-accent {
    font-size: 47px; line-height: 1.05; letter-spacing: 0;
}
.mod-svc-hero__title {
    font-family: var(--font); font-weight: 600; color: var(--white);
}
.mod-svc-hero__title-accent {
    font-family: var(--font-flow); font-weight: 600; color: var(--lime);
}
.mod-svc-hero__subtitle {
    margin: 0 0 28px; max-width: 560px;
    font-size: 16px; line-height: 1.55; color: rgba(255, 255, 255, 0.92);
}
.mod-svc-hero__actions {
    display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 28px;
}
.mod-svc-hero__actions .btn {
    border-radius: 50px; padding: 14px 32px;
}
.mod-svc-hero__tags { display: flex; flex-wrap: wrap; gap: 12px 16px; }
.mod-svc-hero__tag {
    font-size: 14px; font-weight: 500; color: rgba(255, 255, 255, 0.72);
}
.mod-svc-hero__art {
    position: relative; flex: 1 1 480px;
    min-height: 400px; max-width: 580px; margin-left: auto;
}
.mod-svc-hero__scene { position: relative; width: 100%; height: 100%; min-height: 400px; }
.mod-svc-hero__ill {
    position: absolute; height: auto; pointer-events: none; user-select: none;
}
.mod-svc-hero__ill--main {
    width: clamp(260px, 34vw, 420px);
    right: clamp(0px, 2%, 16px);
    top: 50%; transform: translateY(-50%);
    z-index: 2;
}
.mod-svc-hero__ill--decor {
    width: clamp(100px, 14vw, 160px);
    left: 0; right: auto;
    top: calc(50% - 140px); transform: translateY(-50%);
    z-index: 3;
}

.mod-card-grid { padding: 72px 0; background: var(--bg); }
.mod-card-grid--pain { background: transparent; }
.mod-card-grid--types {
    position: relative; background: var(--lime); overflow: hidden;
}
.mod-card-grid--types .mod-card-grid__bg {
    position: absolute; top: 0; bottom: 0;
    left: calc(100% / 12); right: calc(100% / 12);
    border-radius: 20px; overflow: hidden;
    pointer-events: none; z-index: 0;
}
.mod-card-grid--types .mod-card-grid__bg img {
    width: 100%; height: 100%;
    object-fit: cover; object-position: top center; display: block;
}
.mod-card-grid--types .mod-container { position: relative; z-index: 1; }
.mod-card-grid__top {
    display: flex; align-items: flex-start; justify-content: space-between;
    gap: 24px; flex-wrap: wrap; margin-bottom: 40px;
}
.mod-card-grid--pain .mod-card-grid__top,
.mod-card-grid--default .mod-card-grid__top { display: block; margin-bottom: 32px; }
.mod-card-grid__headline { margin: 0; }
.mod-card-grid__lead {
    margin: 0; max-width: 420px;
    font-size: 14px; line-height: 1.55; color: var(--dark);
}
.mod-card-grid--types .mod-card-grid__lead { margin-left: auto; text-align: right; }
.mod-card-grid__title-icon { flex-shrink: 0; margin-top: 8px; }
.mod-card-grid__items {
    display: grid; gap: 24px;
}
.mod-card-grid--pain .mod-card-grid__items {
    grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 32px 24px;
}
.mod-card-grid--pain.mod-card-grid--cols-3 .mod-card-grid__items {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}
.mod-card-grid--types .mod-card-grid__items {
    grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 28px;
}
.mod-card-grid--default .mod-card-grid__items {
    grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 20px;
}
.mod-card-grid__item { min-width: 0; }
.mod-card-grid--pain .mod-card-grid__item { background: transparent; padding: 0; border-radius: 0; }
.mod-card-grid--pain .mod-card-grid__icon {
    width: 80px; height: 80px; margin-bottom: 20px;
    padding: 14px; box-sizing: border-box;
    background: var(--white); border-radius: 16px;
    object-fit: contain; display: block;
}
.mod-card-grid--types .mod-card-grid__item {
    position: relative;
    padding: 28px 24px 24px; min-height: 100%;
    display: flex; flex-direction: column;
    background: transparent;
}
.mod-card-grid--types .mod-card-grid__item::before {
    content: '';
    position: absolute; inset: 0;
    background: #f1f1f1; border-radius: 20px;
    z-index: 0;
}
.mod-card-grid--types .mod-card-grid__item:nth-child(1)::before {
    transform: translate(11px, 13px) rotate(-5deg);
}
.mod-card-grid--types .mod-card-grid__item:nth-child(2)::before {
    transform: translate(11px, 13px) rotate(5deg);
}
.mod-card-grid--types .mod-card-grid__item:nth-child(3)::before {
    transform: translate(11px, 13px) rotate(-2deg);
}
.mod-card-grid--types .mod-card-grid__item:nth-child(4)::before {
    transform: translate(11px, 13px) rotate(3deg);
}
.mod-card-grid--types .mod-card-grid__item::after {
    content: '';
    position: absolute; inset: 0;
    background: var(--white); border-radius: 20px;
    z-index: 1;
}
.mod-card-grid--types .mod-card-grid__item > * {
    position: relative; z-index: 2;
}
.mod-card-grid--default .mod-card-grid__item {
    background: var(--white); border-radius: 20px;
    padding: 28px 24px; box-shadow: 0 2px 16px rgba(0,0,0,.04);
}
.mod-card-grid__icon {
    width: 72px; height: auto; margin-bottom: 20px;
}
.mod-card-grid--types .mod-card-grid__icon { display: none; }
.mod-card-grid__title { margin: 0 0 10px; font-size: 24px; font-weight: 700; line-height: 1.15; }
.mod-card-grid--pain .mod-card-grid__title { display: none; }
.mod-card-grid__text {
    margin: 0; font-size: 14px; line-height: 1.55; color: #666;
}
.mod-card-grid--pain .mod-card-grid__text { color: var(--dark); font-size: 15px; }
.mod-card-grid--types .mod-card-grid__text { flex: 1; margin-bottom: 20px; }
.mod-card-grid__btn { width: 100%; border-radius: 12px; margin-top: auto; }

.mod-svc-audit { padding: 72px 0; background: var(--bg); }
.mod-svc-audit__layout {
    display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
    gap: 48px; align-items: start;
}
.mod-svc-audit__headline { margin: 0 0 32px; }
.mod-svc-audit__ill { width: min(100%, 255px); height: auto; }
.mod-svc-audit__lead {
    margin: 0 0 24px; font-size: 16px; line-height: 1.55; color: var(--dark);
}
.mod-svc-audit__list {
    list-style: none; margin: 0 0 28px; padding: 0;
    display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px 24px;
}
.mod-svc-audit__item {
    display: flex; align-items: flex-start; gap: 12px;
    font-size: 14px; line-height: 1.45; color: var(--dark);
}
.mod-svc-audit__num {
    flex-shrink: 0; width: 28px; height: 28px; border-radius: 50%;
    background: transparent; color: var(--purple);
    border: 2px solid var(--purple);
    display: flex; align-items: center; justify-content: center;
    font-family: var(--font-flow); font-size: 15px; font-weight: 600;
}
.mod-svc-audit__label { padding-top: 3px; }
.mod-svc-audit__btn { border-radius: 12px; }

.mod-card-grid--audience { background: var(--bg); }
.mod-card-grid--audience .mod-card-grid__layout {
    display: grid; grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.4fr);
    gap: 48px; align-items: center;
}
.mod-card-grid--audience .mod-card-grid__intro { min-width: 0; }
.mod-card-grid--audience .mod-card-grid__headline { margin: 0; }
.mod-card-grid--audience .mod-card-grid__items {
    display: flex; flex-direction: column; gap: 20px;
}
.mod-card-grid--audience .mod-card-grid__item {
    display: flex; align-items: center; justify-content: space-between; gap: 24px;
    background: var(--white); border-radius: 20px; padding: 28px 32px;
    box-shadow: 0 2px 16px rgba(0,0,0,.04);
}
.mod-card-grid--audience .mod-card-grid__item-body { flex: 1; min-width: 0; }
.mod-card-grid--audience .mod-card-grid__title {
    margin: 0 0 12px; font-size: 20px; font-weight: 700; line-height: 1.2;
}
.mod-card-grid--audience .mod-card-grid__icon--end {
    flex-shrink: 0; width: 100px; max-width: 100px; height: auto; margin: 0;
}

.mod-card-grid--spheres { background: var(--bg); }
.mod-card-grid__top--spheres {
    display: grid; grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
    gap: 32px 48px; align-items: start; margin-bottom: 40px;
}
.mod-card-grid__lead-wrap { max-width: 520px; }
.mod-card-grid__lead--extra { margin-top: 8px; }
.mod-card-grid__items--spheres {
    display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 32px 28px;
}
.mod-card-grid__sphere {
    display: flex; align-items: flex-start; gap: 16px; min-width: 0;
}
.mod-card-grid__sphere-num {
    flex-shrink: 0; width: 56px; height: 56px; border-radius: 14px;
    background: var(--lime); color: var(--purple);
    display: flex; align-items: center; justify-content: center;
    font-size: 22px; font-weight: 700;
}
.mod-card-grid__sphere-title {
    margin: 0 0 8px; font-size: 16px; font-weight: 700; line-height: 1.25;
}
.mod-card-grid__sphere-text {
    margin: 0; font-size: 14px; line-height: 1.55; color: #666;
}

.mod-card-grid--reasons { background: var(--bg); }
.mod-card-grid__layout--reasons {
    display: grid; grid-template-columns: minmax(0, 0.75fr) minmax(0, 1.25fr);
    gap: 48px; align-items: start;
}
.mod-card-grid--reasons .mod-card-grid__intro {
    display: flex; flex-direction: column; gap: 32px; min-height: 100%;
}
.mod-card-grid--reasons .mod-card-grid__headline { margin: 0; }
.mod-card-grid__reasons-ill { width: min(100%, 200px); height: auto; margin-top: auto; }
.mod-card-grid__items--reasons {
    display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px 20px;
}
.mod-card-grid__reason {
    display: flex; align-items: flex-start; gap: 12px; min-width: 0;
}
.mod-card-grid__reason-num {
    flex-shrink: 0; width: 28px; height: 28px; border-radius: 50%;
    background: transparent; color: var(--purple);
    border: 2px solid var(--purple);
    display: flex; align-items: center; justify-content: center;
    font-family: var(--font-flow); font-size: 14px; font-weight: 600;
}
.mod-card-grid__reason-text {
    margin: 0; padding-top: 2px; font-size: 14px; line-height: 1.45; color: var(--dark);
}
.mod-card-grid__reason-text strong { font-weight: 700; }
.mod-card-grid__reasons-caption {
    margin: 0; font-size: 16px; line-height: 1.45; font-weight: 600; color: var(--purple);
}

.mod-steps { padding: 72px 0; background: var(--bg); }
.mod-steps__headline {
    display: flex; flex-direction: column; align-items: flex-start; gap: 4px;
}
.mod-steps__list {
    list-style: none; margin: 0; padding: 0;
    display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 40px 28px;
}
.mod-steps__item { min-width: 0; }
.mod-steps__head {
    display: flex; align-items: flex-start; gap: 12px; margin-bottom: 12px;
}
.mod-steps__num {
    flex-shrink: 0; width: 80px; height: 80px; border-radius: 20px;
    background: var(--lime); color: var(--purple);
    display: flex; align-items: center; justify-content: center;
    font-size: 36px; font-weight: 700;
}
.mod-steps__title {
    margin: 0; padding-top: 12px;
    font-size: 20px; line-height: 1.25; font-weight: 700;
}
.mod-steps__text {
    margin: 0; padding-left: 92px;
    font-size: 14px; line-height: 1.55; color: #666;
}
.mod-steps__result {
    margin: 12px 0 0; padding-left: 92px;
    font-size: 14px; line-height: 1.55; color: #666;
}
.mod-steps__result strong { color: var(--dark); font-weight: 700; }
.mod-steps__foot { margin-top: 40px; display: flex; justify-content: center; }
.mod-steps__foot-btn { border-radius: 50px; min-width: 220px; }
.mod-steps--stages .mod-steps__layout {
    display: grid; grid-template-columns: minmax(0, 0.42fr) minmax(0, 1fr);
    gap: 48px; align-items: start;
}
.mod-steps--stages .mod-steps__headline { margin: 0; }
.mod-steps--stages .mod-steps__list { grid-template-columns: repeat(2, minmax(0, 1fr)); }

.mod-card-grid--objections { background: var(--bg); }
.mod-card-grid__items--objections {
    display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 32px 24px;
}
.mod-card-grid__objection { min-width: 0; }
.mod-card-grid__objection-q,
.mod-card-grid__objection-a {
    display: flex; align-items: flex-start; gap: 12px;
    margin: 0; font-size: 15px; line-height: 1.5; color: var(--dark);
}
.mod-card-grid__objection-q { margin-bottom: 16px; font-weight: 600; }
.mod-card-grid__objection-a { color: #666; }
.mod-card-grid__objection-icon {
    flex-shrink: 0; width: 28px; height: 28px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 14px; font-weight: 700;
}
.mod-card-grid__objection-icon--q { background: rgba(151, 71, 254, 0.15); color: var(--purple); }
.mod-card-grid__objection-icon--a {
    background: rgba(204, 253, 102, 0.45); color: var(--dark);
    position: relative;
}
.mod-card-grid__objection-icon--a::before {
    content: '';
    width: 10px; height: 6px;
    border-left: 2px solid currentColor; border-bottom: 2px solid currentColor;
    transform: rotate(-45deg) translateY(-1px);
}

.mod-card-grid--icons { background: var(--bg); }
.mod-card-grid__top--icons {
    display: grid; grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
    gap: 32px 48px; align-items: start; margin-bottom: 40px;
}
.mod-card-grid__items--icons {
    display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 24px 20px;
}
.mod-card-grid__icon-card { min-width: 0; }
.mod-card-grid__icon-card-media {
    width: 88px; height: 88px; border-radius: 20px;
    display: flex; align-items: center; justify-content: center; margin-bottom: 20px;
}
.mod-card-grid__icon-card-media img { width: 72px; height: auto; max-height: 72px; object-fit: contain; }
.mod-card-grid__icon-card-title {
    margin: 0 0 10px; font-size: 18px; line-height: 1.25; font-weight: 700;
}
.mod-card-grid__icon-card-text {
    margin: 0; font-size: 14px; line-height: 1.55; color: #666;
}

.mod-card-grid--highlight { background: var(--bg); }

/* Compare (complex service) */
.mod-card-grid--compare { background: var(--bg); padding: 80px 0; }
.mod-card-grid--compare .mod-card-grid__top { margin-bottom: 40px; }
.mod-card-grid__compare {
    display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 24px; align-items: stretch;
}
.mod-card-grid__compare-wrap {
    position: relative; min-height: 100%;
}
.mod-card-grid__compare-back {
    position: absolute; inset: 0; border-radius: 24px; pointer-events: none; z-index: 0;
}
.mod-card-grid__compare-wrap--negative .mod-card-grid__compare-back {
    background: #e3e3e3;
    transform: rotate(-2.5deg) translate(-10px, 12px);
}
.mod-card-grid__compare-wrap--positive .mod-card-grid__compare-back {
    background: transparent;
    border: 2px solid #fff;
    box-shadow: 0 0 0 1px rgba(0,0,0,.04);
    transform: rotate(2.5deg) translate(10px, 12px);
}
.mod-card-grid__compare-col {
    position: relative; z-index: 1;
    border-radius: 24px; padding: 36px 32px 32px;
    display: flex; flex-direction: column; height: 100%;
}
.mod-card-grid__compare-col--negative {
    background: var(--white); box-shadow: 0 12px 40px rgba(0,0,0,.07);
}
.mod-card-grid__compare-col--positive { background: var(--lime); }
.mod-card-grid__compare-badge {
    position: absolute; top: 24px; right: 24px; width: 32px; height: 32px;
}
.mod-card-grid__compare-col--negative .mod-card-grid__compare-badge::before,
.mod-card-grid__compare-col--negative .mod-card-grid__compare-badge::after {
    content: ''; position: absolute; top: 50%; left: 50%;
    width: 22px; height: 2.5px; background: #e74c3c; border-radius: 1px;
}
.mod-card-grid__compare-col--negative .mod-card-grid__compare-badge::before { transform: translate(-50%, -50%) rotate(45deg); }
.mod-card-grid__compare-col--negative .mod-card-grid__compare-badge::after { transform: translate(-50%, -50%) rotate(-45deg); }
.mod-card-grid__compare-col--positive .mod-card-grid__compare-badge::before {
    content: ''; position: absolute; top: 46%; left: 50%;
    width: 11px; height: 18px; border-right: 3px solid var(--purple); border-bottom: 3px solid var(--purple);
    transform: translate(-50%, -50%) rotate(45deg);
}
.mod-card-grid__compare-title { margin: 0 0 28px; font-size: 22px; font-weight: 700; padding-right: 40px; }
.mod-card-grid__compare-list {
    list-style: none; margin: 0; padding: 0;
    display: flex; flex-direction: column; flex: 1;
}
.mod-card-grid__compare-col--negative .mod-card-grid__compare-list { gap: 22px; }
.mod-card-grid__compare-col--positive .mod-card-grid__compare-list { gap: 10px; }
.mod-card-grid__compare-item {
    display: flex; align-items: flex-start; gap: 16px;
}
.mod-card-grid__compare-col--positive .mod-card-grid__compare-item {
    align-items: center;
    background: var(--white); border-radius: 20px; padding: 16px 20px;
}
.mod-card-grid__compare-num {
    flex-shrink: 0; width: 32px; height: 32px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 14px; font-weight: 700; line-height: 1;
}
.mod-card-grid__compare-col--negative .mod-card-grid__compare-num {
    border: 2px solid var(--purple); color: var(--purple); background: transparent;
}
.mod-card-grid__compare-col--positive .mod-card-grid__compare-num {
    background: var(--purple); color: #fff; width: 28px; height: 28px; font-size: 13px;
}
.mod-card-grid__compare-text {
    margin: 0; font-size: 14px; line-height: 1.55; color: #555;
}
.mod-card-grid__compare-text strong {
    display: inline; font-weight: 700; color: var(--dark);
}
@media (max-width: 900px) {
    .mod-card-grid__compare { grid-template-columns: 1fr; }
    .mod-card-grid--compare { padding: 56px 0; }
}
.mod-card-grid__highlight {
    display: flex; align-items: center; justify-content: space-between; gap: 32px;
    background: var(--white); border-radius: 24px; padding: 40px 48px;
    box-shadow: 0 2px 16px rgba(0,0,0,.04);
}
.mod-card-grid__highlight-body { flex: 1; min-width: 0; max-width: 640px; }
.mod-card-grid__highlight-text {
    margin: 16px 0 0; font-size: 16px; line-height: 1.55; color: #666;
}
.mod-card-grid__highlight-ill {
    flex-shrink: 0; width: min(280px, 34vw); height: auto;
}

.mod-pricing__top {
    display: flex; align-items: flex-end; justify-content: space-between;
    gap: 24px; flex-wrap: wrap; margin-bottom: 32px;
}
.mod-pricing__title--inline { margin: 0; }
.mod-pricing__lead {
    margin: 0; max-width: 420px; font-size: 14px; line-height: 1.55; color: #666;
}
.mod-pricing__card-price--top { margin: 0 0 8px; }
.mod-pricing__card-text {
    margin: 0; font-size: 14px; line-height: 1.45;
    position: relative; z-index: 1;
}
.mod-pricing__card-btn {
    margin-top: auto; width: 100%; border-radius: 12px; justify-content: center;
}
.mod-pricing__audit {
    margin-top: 20px; border-radius: 24px;
    padding: 28px 32px; display: flex; align-items: center; justify-content: space-between;
    gap: 24px; flex-wrap: wrap;
}
.mod-pricing__audit-title {
    margin: 0 0 8px; font-size: 24px; line-height: 1.2; font-weight: 700; color: var(--dark);
}
.mod-pricing__audit-text {
    margin: 0; max-width: 520px; font-size: 14px; line-height: 1.55; color: #666;
}
.mod-pricing__audit-btn { border-radius: 50px; flex-shrink: 0; }

.mod-svc-hero + .mod-pricing--cards { padding-top: 0; }
.mod-pricing--cards + .mod-steps { padding-top: 48px; }
.mod-pricing--cards + .mod-card-grid--objections { padding-top: 48px; }

.mod-pricing { padding: 72px 0; background: var(--bg); }
.mod-pricing__title { margin-bottom: 32px; }
.mod-pricing__layout {
    display: grid; grid-template-columns: minmax(0, 1fr) 280px; gap: 20px; align-items: stretch;
}
.mod-pricing__panel {
    background: var(--purple); border-radius: 24px;
    padding: 36px 40px 28px; color: #fff;
    display: flex; flex-direction: column; gap: 28px;
}
.mod-pricing__tiers {
    display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px;
}
.mod-pricing__tier { display: flex; flex-direction: column; gap: 16px; min-width: 0; }
.mod-pricing__tier-icon { width: 56px; height: auto; }
.mod-pricing__tier-title {
    margin: 0; font-size: 20px; line-height: 1.2; font-weight: 700; color: #fff;
}
.mod-pricing__tier-price { margin: 8px 0 0; font-size: 18px; font-weight: 600; color: #fff; }
.mod-pricing__panel-foot {
    display: flex; align-items: center; justify-content: space-between;
    gap: 20px; flex-wrap: wrap; margin-top: auto;
}
.mod-pricing__panel-btn { border-radius: 50px; color: var(--dark); }
.mod-pricing__note {
    margin: 0; max-width: 360px; font-size: 12px; line-height: 1.45;
    color: rgba(255, 255, 255, 0.78);
}
.mod-pricing__stat-card {
    background: var(--white); border-radius: 24px; padding: 28px 24px;
    display: flex; flex-direction: column; justify-content: space-between; gap: 16px;
}
.mod-pricing__stat { text-align: left; }
.mod-pricing__stat-line {
    margin: 0; font-family: var(--font-flow); font-size: 50px;
    line-height: 1; font-weight: 600; color: var(--purple);
}
.mod-pricing__stat-value,
.mod-pricing__stat-suffix { font: inherit; color: inherit; }
.mod-pricing__stat-text { margin: 12px 0 0; font-size: 14px; line-height: 1.45; color: #666; }
.mod-pricing__stat-ill { width: 100px; height: auto; margin-top: auto; align-self: flex-end; }

.mod-pricing--cards .mod-pricing__cards {
    display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 20px;
}
.mod-pricing__card {
    position: relative; overflow: hidden;
    display: flex; flex-direction: column; gap: 20px;
    min-height: 360px; padding: 32px 28px 28px; border-radius: 24px;
}
.mod-pricing__card::after {
    content: '';
    position: absolute; top: 0; right: 0;
    width: 55%; height: 55%;
    background: linear-gradient(135deg, rgba(255,255,255,.14) 0%, transparent 60%);
    pointer-events: none;
}
.mod-pricing__card--purple { background: var(--purple); color: #fff; }
.mod-pricing__card--lime { background: var(--lime); color: var(--dark); }
.mod-pricing__card-icon { width: 64px; height: auto; position: relative; z-index: 1; }
.mod-pricing__card-title {
    margin: 0; font-size: 22px; line-height: 1.2; font-weight: 700;
    position: relative; z-index: 1;
}
.mod-pricing__card-features {
    list-style: none; margin: 0; padding: 0;
    display: flex; flex-direction: column; gap: 10px;
    font-size: 14px; line-height: 1.45;
    position: relative; z-index: 1;
}
.mod-pricing__card-features li {
    position: relative; padding-left: 18px;
}
.mod-pricing__card-features li::before {
    content: ''; position: absolute; left: 0; top: 6px;
    width: 8px; height: 8px; border-radius: 50%; background: currentColor;
}
.mod-pricing__feature-label { font-weight: 700; }
.mod-pricing__card-price {
    margin: auto 0 0; font-size: 22px; font-weight: 700; line-height: 1.2;
    position: relative; z-index: 1;
}
.mod-pricing__foot {
    display: flex; align-items: center; justify-content: space-between;
    gap: 24px; flex-wrap: wrap; margin-top: 28px;
}
.mod-pricing__foot-btn { border-radius: 50px; min-width: 210px; }
.mod-pricing__foot-note {
    margin: 0; max-width: 360px; font-size: 12px; line-height: 1.45; color: #666;
}

.mod-pricing--split .mod-pricing__split {
    display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 20px;
}
.mod-pricing__split-card {
    position: relative; overflow: hidden; border-radius: 24px;
    min-height: 320px; padding: 32px 28px;
    display: flex; flex-direction: column; gap: 20px;
}
.mod-pricing__split-card::after {
    content: '';
    position: absolute; top: 0; right: 0;
    width: 55%; height: 55%;
    background: linear-gradient(135deg, rgba(255,255,255,.12) 0%, transparent 60%);
    pointer-events: none;
}
.mod-pricing__split-card--purple { background: var(--purple); color: #fff; }
.mod-pricing__split-card--diagram {
    background: var(--white); align-items: center; justify-content: center; padding: 24px;
}
.mod-pricing__split-card--lime { background: var(--lime); color: var(--dark); }
.mod-pricing__split-icon { width: 56px; height: auto; position: relative; z-index: 1; }
.mod-pricing__split-title {
    margin: 0; font-size: 20px; line-height: 1.25; font-weight: 700;
    position: relative; z-index: 1;
}
.mod-pricing__split-price {
    margin: auto 0 0; font-size: 24px; font-weight: 700; line-height: 1.2;
    position: relative; z-index: 1;
}
.mod-pricing__split-diagram {
    width: min(100%, 280px); height: auto; display: block; position: relative; z-index: 1;
}
.mod-pricing__split-note {
    margin: 0; font-size: 13px; line-height: 1.5; flex: 1;
    position: relative; z-index: 1;
}
.mod-pricing__split-note--light { color: rgba(255, 255, 255, 0.92); font-size: 16px; line-height: 1.55; }
.mod-pricing__split-btn {
    align-self: flex-start; border-radius: 50px; position: relative; z-index: 1;
}

.mod-services--crosssell { padding: 72px 0 96px; overflow: hidden; }
.mod-services--crosssell .mod-services__head {
    align-items: flex-end; justify-content: space-between; gap: 24px;
}
.mod-services--crosssell .mod-services__title {
    display: flex; flex-wrap: wrap; align-items: baseline; gap: 8px 12px;
    font-size: 47px; line-height: 1; font-weight: 600;
}
.mod-services--crosssell .mod-services__arrow { display: none; }
.mod-services--crosssell .mod-services__nav {
    display: flex; align-items: center; gap: 12px; flex-shrink: 0;
}
.mod-services--crosssell .mod-services__nav-btn {
    display: flex; align-items: center; justify-content: center;
    width: 48px; height: 48px; padding: 0; border: none;
    background: transparent; cursor: pointer;
    transition: transform .2s ease;
}
.mod-services--crosssell .mod-services__nav-btn:hover { transform: scale(1.08); }
.mod-services--crosssell .mod-services__nav-btn img { width: 48px; height: auto; display: block; }
.mod-services--crosssell .mod-services__slider {
    overflow-x: auto; scroll-snap-type: x mandatory;
    scrollbar-width: none; -ms-overflow-style: none;
    margin-right: calc(-1 * var(--shell-pad));
    padding-right: var(--shell-pad);
}
.mod-services--crosssell .mod-services__slider::-webkit-scrollbar { display: none; }
.mod-services--crosssell .mod-services__grid {
    display: flex; gap: 20px; width: max-content; padding-bottom: 4px; align-items: stretch;
}
.mod-services--crosssell .mod-services__card {
    flex: 0 0 320px; width: 320px; scroll-snap-align: start;
    display: flex; flex-direction: column; gap: 16px; height: auto;
}
.mod-services--crosssell .mod-services__card::before,
.mod-services--crosssell .mod-services__card::after { display: none; }
.mod-services--crosssell .mod-services__card-art {
    display: flex; align-items: center; justify-content: center;
    flex: 0 0 240px; height: 240px; padding: 24px 20px; box-sizing: border-box;
    background: var(--white); border-radius: 20px; overflow: hidden;
}
.mod-services--crosssell .mod-services__card-art img {
    display: block; width: auto; max-width: 100%; max-height: 100%;
    height: auto; object-fit: contain;
}
.mod-services--crosssell .mod-services__card-body {
    display: flex; flex-direction: column; flex: 1 1 auto;
    padding: 0 4px;
}
.mod-services--crosssell .mod-services__card-title {
    margin: 0 0 8px; padding: 0;
    background: none; color: var(--dark);
    font-size: 18px; font-weight: 600; line-height: 1.2;
    display: block; align-self: stretch;
}
.mod-services--crosssell .mod-services__card-text {
    margin: 0 0 16px; flex: 1 1 auto;
    font-size: 14px; line-height: 1.45; color: rgba(31, 31, 31, 0.72);
}
.mod-services--crosssell .mod-services__card-btn {
    display: inline-flex; align-items: center; justify-content: center;
    width: 100%; min-height: 40px; margin-top: auto;
    padding: 10px 18px; border-radius: 10px;
    background: var(--purple); color: var(--white);
    font-size: 14px; font-weight: 600; line-height: 1.2;
    transition: background .2s ease, transform .2s ease;
}
.mod-services--crosssell .mod-services__card:hover .mod-services__card-btn {
    background: var(--dark);
}
.mod-services--crosssell .mod-services__card:hover .mod-services__card-title {
    background: none; color: var(--dark);
}

@media (max-width: 960px) {
    .mod-svc-hero__card { padding: 32px 24px 40px; min-height: min(70vh, 520px); }
    .mod-svc-hero__layout { flex-direction: column; align-items: stretch; }
    .mod-svc-hero__title,
    .mod-svc-hero__title-accent { font-size: 34px; }
    .mod-svc-hero__art {
        order: -1; max-width: none; min-height: 300px; margin: 0 auto;
    }
    .mod-svc-hero__scene { min-height: 300px; }
    .mod-svc-hero__ill--main {
        right: 50%; transform: translate(50%, -50%);
        width: min(300px, 80vw);
    }
    .mod-svc-hero__ill--decor { display: none; }
    .mod-card-grid--pain .mod-card-grid__items { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .mod-card-grid--audience .mod-card-grid__layout { grid-template-columns: 1fr; gap: 32px; }
    .mod-card-grid__top--spheres { grid-template-columns: 1fr; }
    .mod-card-grid__items--spheres { grid-template-columns: 1fr 1fr; }
    .mod-card-grid__layout--reasons { grid-template-columns: 1fr; }
    .mod-card-grid__items--reasons { grid-template-columns: 1fr 1fr; }
    .mod-card-grid__top--icons { grid-template-columns: 1fr; }
    .mod-card-grid__highlight { flex-direction: column; align-items: flex-start; padding: 28px 24px; }
    .mod-card-grid__highlight-ill { width: min(240px, 80vw); margin: 0 auto; }
    .mod-card-grid--types .mod-card-grid__items { grid-template-columns: 1fr 1fr; }
    .mod-svc-audit__layout { grid-template-columns: 1fr; }
    .mod-svc-audit__list { grid-template-columns: 1fr; }
    .mod-steps__list { grid-template-columns: 1fr 1fr; }
    .mod-steps--stages .mod-steps__layout { grid-template-columns: 1fr; gap: 32px; }
    .mod-pricing__layout { grid-template-columns: 1fr; }
    .mod-pricing__tiers { grid-template-columns: 1fr; }
    .mod-pricing--cards .mod-pricing__cards { grid-template-columns: 1fr; }
    .mod-pricing--split .mod-pricing__split { grid-template-columns: 1fr; }
    .mod-pricing__panel-foot { flex-direction: column; align-items: flex-start; }
    .mod-services--crosssell .mod-services__card { flex-basis: 280px; width: 280px; }
    .mod-services--crosssell .mod-services__card-art { flex-basis: 200px; height: 200px; }
}
@media (max-width: 640px) {
    .mod-card-grid--pain .mod-card-grid__items,
    .mod-card-grid__items--spheres,
    .mod-card-grid__items--icons { grid-template-columns: 1fr 1fr; }
    .mod-card-grid__items--objections { grid-template-columns: 1fr; }
    .mod-card-grid--types .mod-card-grid__items,
    .mod-card-grid--default .mod-card-grid__items,
    .mod-steps__list,
    .mod-services--crosssell .mod-services__card { flex-basis: 260px; width: 260px; }
    .mod-services--crosssell .mod-services__title { font-size: 34px; }
    .mod-services--crosssell .mod-services__card-art { flex-basis: 180px; height: 180px; padding: 16px; }
    .mod-card-grid--types .mod-card-grid__top { flex-direction: column; }
    .mod-card-grid--types .mod-card-grid__lead { margin-left: 0; text-align: left; }
    .mod-svc-hero__title,
    .mod-svc-hero__title-accent { font-size: 28px; }
    .mod-svc-hero__actions { flex-direction: column; align-items: stretch; }
    .mod-svc-hero__actions .btn { justify-content: center; }
    .mod-pricing__head { flex-direction: column; align-items: flex-start; }
    .mod-pricing__stat { text-align: left; }
}

/* Facts */
.mod-facts { padding: 120px 0 60px; background: var(--bg); }
.mod-facts__headline {
    margin: 0 0 40px;
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 8px 12px;
    font-size: 47px;
    line-height: 1;
    font-weight: 600;
}
.mod-facts__title {
    font-family: var(--font);
    color: var(--dark);
}
.mod-facts__title-accent {
    font-family: var(--font-flow);
    color: var(--purple);
}
.mod-facts__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}
.mod-facts__item {
    display: flex;
    align-items: center;
    gap: 24px;
    min-height: 132px;
    padding: 28px 32px;
    background: var(--white);
    border-radius: var(--radius-lg);
}
.mod-facts__value {
    flex: 0 0 auto;
    min-width: 72px;
    font-family: var(--font-flow);
    font-size: 47px;
    font-weight: 600;
    line-height: 1;
    color: var(--purple);
    white-space: nowrap;
}
.mod-facts__text {
    flex: 1 1 auto;
    font-size: 16px;
    font-weight: 600;
    line-height: 1.25;
    color: var(--dark);
}

@media (max-width: 1199px) {
    .mod-facts { padding: 96px 0 48px; }
    .mod-facts__headline { font-size: 37px; margin-bottom: 32px; }
    .mod-facts__value { font-size: 37px; }
}

@media (max-width: 959px) {
    .mod-facts { padding: 72px 0 40px; }
    .mod-facts__headline { font-size: 30px; }
    .mod-facts__value { font-size: 30px; min-width: 60px; }
    .mod-facts__item { min-height: 0; padding: 24px; gap: 16px; }
}

@media (max-width: 639px) {
    .mod-facts { padding: 48px 0 32px; }
    .mod-facts__headline { font-size: 25px; margin-bottom: 24px; }
    .mod-facts__grid { grid-template-columns: 1fr; }
    .mod-facts__value { font-size: 28px; }
    .mod-facts__text { font-size: 15px; }
}

/* Services */
.mod-services {
    position: relative;
    overflow: hidden;
    padding: 80px 0 96px;
    background: var(--lime);
}
.mod-services--crosssell,
.mod-services--page {
    background: var(--bg);
}
.mod-services--page {
    padding: 48px 0 80px;
}
.mod-services--page .mod-services__bg { display: none; }
.mod-services__breadcrumb {
    display: flex; align-items: center; gap: 8px; margin: 0 0 32px;
    font-size: 14px; line-height: 1.55;
}
.mod-services__breadcrumb a {
    color: var(--dark); font-weight: 500; text-decoration: none; transition: color .2s;
}
.mod-services__breadcrumb a:hover { color: var(--purple); }
.mod-services__breadcrumb-sep,
.mod-services__breadcrumb-current { color: var(--purple); font-weight: 600; }
.mod-services .mod-container {
    position: relative;
    z-index: 1;
}
.mod-services__bg {
    position: absolute;
    top: 0;
    left: calc(100% / 12);
    right: calc(100% / 12);
    bottom: 0;
    border-radius: 20px;
    overflow: hidden;
    pointer-events: none;
    z-index: 0;
}
.mod-services__bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
    display: block;
}
.mod-services__head {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: flex-end;
    gap: 20px;
    margin-bottom: 40px;
}
.mod-services__title {
    margin: 0;
    font-size: 47px;
    font-weight: 600;
    line-height: 1;
    color: var(--dark);
}
.mod-services__arrow {
    width: 102px;
    height: auto;
    margin-bottom: 6px;
    flex-shrink: 0;
}
.mod-services__grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 40px 32px;
}
.mod-services__card {
    position: relative;
    display: block;
    color: inherit;
    text-decoration: none;
    overflow: visible;
}
.mod-services__card::before {
    content: '';
    position: absolute;
    inset: 10px -8px -10px 10px;
    background: var(--bg);
    border-radius: 20px;
    transform: rotate(-4deg);
    z-index: 0;
    pointer-events: none;
}
.mod-services__card:nth-child(even)::before {
    transform: rotate(4deg);
    inset: 8px 10px -10px -8px;
}
.mod-services__card-inner {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    min-height: 278px;
    padding: 24px 24px 20px;
    background: var(--white);
    border-radius: 20px;
}
.mod-services__card-title {
    margin: 0 0 12px;
    font-size: 18px;
    font-weight: 600;
    line-height: 1.15;
    color: var(--dark);
}
.mod-services__card-text {
    margin: 0;
    flex: 1 1 auto;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.45;
    color: var(--dark);
}
.mod-services__card-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 40px;
    margin-top: 20px;
    padding: 10px 18px;
    border-radius: 10px;
    background: var(--purple);
    color: var(--white);
    font-size: 14px;
    font-weight: 600;
    line-height: 1.2;
}
.mod-services__card--cta::before {
    display: block;
    background: var(--bg);
    transform: rotate(-4deg);
    inset: 10px -8px -10px 10px;
}
.mod-services__card--cta::after {
    content: '';
    position: absolute;
    inset: 8px -6px -8px 8px;
    border: 2px solid var(--white);
    border-radius: 20px;
    background: transparent;
    transform: rotate(3deg);
    z-index: 0;
    pointer-events: none;
}
.mod-services__card--cta .mod-services__card-inner {
    background: var(--purple);
    color: var(--white);
}
.mod-services__card--cta .mod-services__card-title,
.mod-services__card--cta .mod-services__card-text {
    color: var(--white);
}
.mod-services__card--cta .mod-services__card-btn {
    background: var(--white);
    color: var(--purple);
}
.mod-services__card:hover .mod-services__card-btn {
    background: var(--dark);
    color: var(--white);
}
.mod-services__card--cta:hover .mod-services__card-btn {
    background: var(--lime);
    color: var(--dark);
}

@media (max-width: 1199px) {
    .mod-services__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 36px 28px; }
    .mod-services__title { font-size: 37px; }
}

@media (max-width: 959px) {
    .mod-services { padding: 64px 0 72px; }
    .mod-services__head { margin-bottom: 28px; }
    .mod-services__arrow { width: 72px; }
    .mod-services__card-inner { min-height: 240px; }
}

@media (max-width: 639px) {
    .mod-services { padding: 48px 0 56px; }
    .mod-services__title { font-size: 30px; }
    .mod-services__grid { grid-template-columns: 1fr; }
    .mod-services__arrow { display: none; }
}

/* Features */
.mod-features { padding: 80px 0; background: var(--bg); }
.mod-features__grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 20px; }
.mod-features__card {
    display: flex; align-items: center; justify-content: space-between; gap: 24px;
    background: var(--white); border-radius: 20px;
    padding: 28px 32px; min-height: 180px; overflow: hidden;
}
.mod-features__body { flex: 1; min-width: 0; }
.mod-features__title { margin: 0 0 12px; font-size: 22px; font-weight: 700; }
.mod-features__text { margin: 0; font-size: 14px; line-height: 1.55; color: #666; max-width: 420px; }
.mod-features__ill {
    flex-shrink: 0; width: 120px; max-width: 120px; height: auto;
    pointer-events: none; display: block;
}
.mod-features--benefits .mod-features__grid { gap: 16px; }
.mod-features--benefits .mod-features__card {
    min-height: 0; padding: 22px 24px;
}
.mod-features--benefits .mod-features__title {
    margin: 0; font-size: 16px; font-weight: 600; line-height: 1.45; max-width: none;
}
.mod-features--benefits .mod-features__text { display: none; }
.mod-features--benefits .mod-features__ill { width: 72px; max-width: 72px; }
.mod-features__lead {
    margin: -24px 0 32px; max-width: 640px;
    font-size: 16px; line-height: 1.55; color: #666;
}
.mod-features--split .mod-features__top {
    display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
    gap: 32px 48px; align-items: start; margin-bottom: 40px;
}
.mod-features--split .mod-features__headline { margin: 0; }
.mod-features--split .mod-features__lead { margin: 0; max-width: none; }
.mod-features__foot { margin-top: 36px; text-align: center; }
@media (max-width: 768px) {
    .mod-features__grid { grid-template-columns: 1fr; }
    .mod-features { padding: 56px 0; }
    .mod-features__card { padding: 24px 20px; }
    .mod-features__ill { width: 88px; max-width: 88px; }
    .mod-features--split .mod-features__top { grid-template-columns: 1fr; gap: 20px; margin-bottom: 28px; }
}

/* Cases */
.mod-cases { padding: 80px 0; background: var(--bg); }
.mod-cases--page { padding: 48px 0 80px; }
.mod-cases__breadcrumb {
    display: flex; align-items: center; gap: 8px; margin: 0 0 32px;
    font-size: 14px; line-height: 1.55;
}
.mod-cases__breadcrumb a { color: var(--dark); font-weight: 500; text-decoration: none; transition: color .2s; }
.mod-cases__breadcrumb a:hover { color: var(--purple); }
.mod-cases__breadcrumb-sep,
.mod-cases__breadcrumb-current { color: var(--purple); font-weight: 600; }
.mod-cases__head { display: flex; justify-content: space-between; align-items: flex-end; flex-wrap: wrap; gap: 20px; margin-bottom: 32px; }
.mod-cases__head .mod-headline { margin: 0; }
.mod-cases__all { flex-shrink: 0; }
.mod-cases__tabs {
    display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 32px;
    padding: 4px; border-radius: 999px; background: #fff; width: fit-content; max-width: 100%;
}
.mod-cases__tab {
    border: none; background: transparent; cursor: pointer;
    font: inherit; font-size: 14px; font-weight: 600; color: var(--dark);
    padding: 12px 20px; border-radius: 999px; transition: background .2s, color .2s;
}
.mod-cases__tab.is-active { background: var(--lime); color: var(--dark); }
.mod-cases__tab:hover:not(.is-active) { background: rgba(0,0,0,.05); }
.mod-cases__grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 20px; }
.mod-cases__card {
    text-decoration: none; color: inherit; display: block;
    background: var(--white); border-radius: 20px; padding: 12px;
    box-shadow: 0 2px 16px rgba(0,0,0,.06);
    transition: box-shadow .2s, transform .2s;
}
.mod-cases__card:hover {
    box-shadow: 0 8px 32px rgba(0,0,0,.08);
    transform: translateY(-2px);
}
.mod-cases__card.is-hidden { display: none; }
.mod-cases__card--page { padding: 16px; }
.mod-cases__card--page:hover { box-shadow: 0 8px 32px rgba(0,0,0,.08); transform: translateY(-2px); }
.mod-cases__cover {
    border-radius: 16px; overflow: hidden; aspect-ratio: 4/3;
    display: flex; align-items: center; justify-content: center; padding: 12px;
    background: var(--white);
    border: 1px solid rgba(0,0,0,.04);
}
.mod-cases__cover img { width: 100%; height: 100%; object-fit: contain; border-radius: 8px; }
.mod-cases--page .mod-cases__cover { padding: 0; border: none; }
.mod-cases--page .mod-cases__cover img { object-fit: contain; border-radius: 20px; }
.mod-cases__tag {
    display: inline-block; margin: 12px auto 0; padding: 8px 20px;
    background: var(--white); border-radius: 999px; font-size: 14px; font-weight: 600;
    box-shadow: 0 4px 16px rgba(0,0,0,.1); text-align: center;
    width: fit-content; left: 50%; position: relative; transform: translateX(-50%);
}
.mod-cases__url {
    display: block; margin-top: 14px; font-size: 12px; color: rgba(31,31,31,.45);
    word-break: break-all;
}
.mod-cases__card-title {
    display: block; margin-top: 8px; font-size: 16px; font-weight: 700; line-height: 1.35;
}
.mod-cases__more {
    display: inline-flex; align-items: center; justify-content: center;
    margin-top: 16px; padding: 10px 20px; border-radius: 999px;
    border: 1px solid var(--dark); font-size: 14px; font-weight: 600;
    transition: background .2s, color .2s;
}
.mod-cases__card--page:hover .mod-cases__more { background: var(--dark); color: #fff; }
.mod-cases--related { padding: 64px 0; background: var(--bg); }
.mod-cases--related .mod-cases__head { margin-bottom: 24px; }
@media (max-width: 900px) { .mod-cases__grid { grid-template-columns: 1fr; } }

/* Arsenal */
.mod-arsenal { padding: 0 0 80px; background: var(--bg); }
.mod-arsenal__grid {
    border: 1px solid #c1c1c1; border-radius: 24px; overflow: hidden;
    background: transparent;
}
.mod-arsenal__row { display: flex; border-bottom: 1px solid #c1c1c1; }
.mod-arsenal__row:last-child { border-bottom: none; }
.mod-arsenal__row--split { display: grid; grid-template-columns: 1fr 1fr; }
.mod-arsenal__cell, .mod-arsenal__row--full {
    display: flex; align-items: center; gap: 32px; padding: 32px 36px;
    flex-wrap: nowrap; min-height: 88px;
}
.mod-arsenal__row--split .mod-arsenal__cell:first-child { border-right: 1px solid #c1c1c1; }
.mod-arsenal__label {
    font-size: 15px; font-weight: 600; line-height: 1.3;
    width: 168px; min-width: 168px; flex-shrink: 0;
}
.mod-arsenal__logos {
    display: flex; flex-wrap: wrap; align-items: center; gap: 24px 36px; flex: 1; min-width: 0;
}
.mod-arsenal__row--full .mod-arsenal__logos { gap: 24px 48px; }
.mod-arsenal__logos img { height: 30px; width: auto; max-width: 140px; object-fit: contain; }
@media (max-width: 768px) {
    .mod-arsenal__row--split { grid-template-columns: 1fr; }
    .mod-arsenal__row--split .mod-arsenal__cell:first-child { border-right: none; border-bottom: 1px solid #c1c1c1; }
    .mod-arsenal__cell, .mod-arsenal__row--full { padding: 20px; flex-wrap: wrap; }
    .mod-arsenal__label { width: auto; min-width: 120px; }
}

/* Promo banner */
.mod-promo { padding: 0 0 80px; background: var(--bg); }
.mod-promo__card {
    display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: end;
    border-radius: 24px; padding: 48px 0 0;
    overflow: hidden; position: relative;
    background: var(--purple);
}
@media (min-width: 901px) {
    .mod-promo__card {
        padding-left: calc(100% / 12);
        padding-right: calc(100% / 12);
    }
    .mod-promo__bg {
        left: calc(100% / 12);
        right: calc(100% / 12);
    }
}
.mod-promo__bg {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border-radius: 20px;
    overflow: hidden;
    pointer-events: none;
    z-index: 0;
}
.mod-promo__bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}
.mod-promo__content,
.mod-promo__ill { position: relative; z-index: 1; }
.mod-promo__content { align-self: center; }
.mod-promo__title { margin: 0 0 16px; font-size: clamp(28px, 4vw, 42px); font-weight: 700; color: #fff; line-height: 1.1; }
.mod-promo__title-accent { color: var(--lime); font-family: var(--font-flow); font-weight: 400; }
.mod-promo__text { margin: 0 0 28px; color: rgba(255,255,255,.9); font-size: 16px; max-width: 400px; }
.mod-promo__btn { margin-bottom: 0; }
.mod-promo__ill {
    align-self: end; justify-self: end;
    max-height: 420px; max-width: 630px; width: auto; height: auto;
}
@media (max-width: 768px) {
    .mod-promo__card { grid-template-columns: 1fr; padding: 32px 24px 0; }
    .mod-promo__ill { max-height: 300px; max-width: 450px; margin: 0 auto; }
}

/* Clients */
.mod-clients { padding: 80px 0; background: var(--bg); }
.mod-clients__head { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 28px; gap: 16px; }
.mod-clients__head .mod-headline { margin: 0; }
.mod-clients__nav { display: flex; gap: 8px; }
.mod-clients__arrow {
    width: 48px; height: 48px; border-radius: 50%; border: none; cursor: pointer;
    background: var(--lime); color: var(--dark);
    display: flex; align-items: center; justify-content: center; transition: transform .15s;
    padding: 0;
}
.mod-clients__arrow-icon { display: block; flex-shrink: 0; }
.mod-clients__arrow:hover { transform: scale(1.06); }
.mod-clients__track-wrap { overflow: hidden; }
.mod-clients__track { display: flex; gap: 16px; transition: transform .35s ease; }
.mod-clients__slide {
    flex: 0 0 calc(25% - 12px); min-width: 200px;
    background: var(--white); border-radius: 16px; padding: 24px;
    display: flex; align-items: center; justify-content: center; min-height: 140px;
}
.mod-clients__slide img { max-height: 96px; width: auto; max-width: 100%; object-fit: contain; }
@media (max-width: 768px) { .mod-clients__slide { flex: 0 0 calc(50% - 8px); } }

/* Testimonials */
.mod-testimonials { padding: 80px 0; background: var(--bg); }
.mod-testimonials__head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 32px; }
.mod-testimonials__head .mod-headline { margin: 0; }
.mod-testimonials__icon { flex-shrink: 0; opacity: .9; }
.mod-testimonials__grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 20px; }
.mod-testimonials__card { display: flex; flex-direction: column; min-height: 100%; }
.mod-testimonials__card--more { display: none; }
.mod-testimonials.is-expanded .mod-testimonials__card--more { display: flex; }
.mod-testimonials__letter {
    display: block;
    width: 100%;
    background: #fff; border: none; border-radius: 16px; padding: 8px; margin-bottom: 16px;
    box-shadow: 0 4px 20px rgba(0,0,0,.06); aspect-ratio: 5 / 6; overflow: hidden;
    cursor: zoom-in;
    transition: box-shadow .2s ease, transform .2s ease;
}
.mod-testimonials__letter:hover {
    box-shadow: 0 8px 28px rgba(151, 71, 254, .18);
    transform: translateY(-2px);
}
.mod-testimonials__letter:focus-visible {
    outline: 2px solid var(--purple);
    outline-offset: 2px;
}
.mod-testimonials__letter img { width: 100%; height: 100%; object-fit: contain; border-radius: 8px; background: #fff; pointer-events: none; }
.mod-testimonials__company { margin: 0 0 8px; font-size: 16px; font-weight: 700; }
.mod-testimonials__text { margin: 0 0 16px; font-size: 14px; line-height: 1.5; color: #555; flex: 1; }
.mod-testimonials__btn { width: 100%; margin-top: auto; }
.mod-testimonials__footer { margin-top: 32px; text-align: center; }
.mod-testimonials__toggle { min-width: 200px; }
@media (max-width: 1100px) { .mod-testimonials__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .mod-testimonials__grid { grid-template-columns: 1fr; } }

.mod-testimonial-modal {
    position: fixed; inset: 0; z-index: 1000;
    display: flex; align-items: center; justify-content: center;
    padding: 20px;
}
.mod-testimonial-modal[hidden] { display: none; }
.mod-testimonial-modal__backdrop {
    position: absolute; inset: 0;
    background: rgba(151, 71, 254, .2);
}
.mod-testimonial-modal__dialog {
    position: relative; z-index: 1;
    width: 100%; max-width: 560px; max-height: min(90vh, 720px);
    overflow: auto; padding: 40px 32px 32px;
    background: #fbfbf9; border-radius: 20px;
    text-align: center;
}
.mod-testimonial-modal__close {
    position: absolute; top: 10px; right: 10px;
    display: flex; align-items: center; justify-content: center;
    width: 40px; height: 40px; padding: 0;
    border: none; background: transparent; cursor: pointer;
}
.mod-testimonial-modal__title {
    margin: 0 0 20px; font-size: 30px; line-height: 1.3; font-weight: 600; color: var(--dark);
}
.mod-testimonial-modal__text {
    font-size: 16px; line-height: 1.55; color: var(--dark); text-align: center;
}
.mod-testimonial-modal__text p { margin: 0 0 1em; }
.mod-testimonial-modal__text p:last-child { margin-bottom: 0; }
body.is-testimonial-modal-open { overflow: hidden; }
@media (max-width: 480px) {
    .mod-testimonial-modal__dialog { padding: 36px 20px 24px; }
    .mod-testimonial-modal__title { font-size: 23px; }
    .mod-testimonial-modal__text { font-size: 14px; line-height: 1.45; }
}

.mod-image-lightbox {
    position: fixed; inset: 0; z-index: 1010;
    display: flex; align-items: center; justify-content: center;
    padding: 20px;
}
.mod-image-lightbox[hidden] { display: none; }
.mod-image-lightbox__backdrop {
    position: absolute; inset: 0;
    background: rgba(20, 20, 20, .82);
}
.mod-image-lightbox__dialog {
    position: relative; z-index: 1;
    display: flex; flex-direction: column; align-items: center;
    width: min(100%, 920px); max-height: min(92vh, 1100px);
}
.mod-image-lightbox__close {
    position: absolute; top: -44px; right: 0;
    display: flex; align-items: center; justify-content: center;
    width: 40px; height: 40px; padding: 0;
    border: none; border-radius: 50%;
    background: rgba(255, 255, 255, .95); cursor: pointer;
}
.mod-image-lightbox__img {
    display: block;
    width: auto; height: auto;
    max-width: 100%; max-height: min(82vh, 1000px);
    object-fit: contain;
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 12px 48px rgba(0, 0, 0, .35);
}
.mod-image-lightbox__caption {
    margin: 14px 0 0; padding: 0 12px;
    font-size: 15px; line-height: 1.4; font-weight: 600;
    color: #fff; text-align: center;
}
body.is-image-lightbox-open { overflow: hidden; }
@media (max-width: 640px) {
    .mod-image-lightbox { padding: 12px; }
    .mod-image-lightbox__close { top: 8px; right: 8px; }
    .mod-image-lightbox__img { max-height: 78vh; border-radius: 8px; }
}

.mod-form-popup {
    position: fixed; inset: 0; z-index: 1100;
    display: flex; align-items: center; justify-content: center;
    padding: 20px;
    opacity: 0;
    transition: opacity .3s ease-in-out;
}
.mod-form-popup[hidden] { display: none; }
.mod-form-popup.is-open { opacity: 1; }
.mod-form-popup.is-closing { opacity: 0; pointer-events: none; }
.mod-form-popup__backdrop {
    position: absolute; inset: 0;
    background: rgba(151, 71, 254, .2);
}
.mod-form-popup__dialog {
    position: relative; z-index: 1;
    width: 100%; max-width: 560px; max-height: min(90vh, 720px);
    overflow: auto; padding: 40px 32px 32px;
    background: var(--bg); border-radius: 20px;
    transform: translateY(calc(-30% + 20px)) scale(.9);
    opacity: 0;
}
.mod-form-popup.is-open .mod-form-popup__dialog {
    animation: mod-form-popup-enter .45s ease-out both;
}
.mod-form-popup.is-closing .mod-form-popup__dialog {
    animation: none;
    opacity: 0;
    transform: translateY(16px) scale(.94);
    transition: transform .25s ease-in, opacity .25s ease-in;
}
@keyframes mod-form-popup-enter {
    0% {
        opacity: 0;
        transform: translateY(calc(-30% + 20px)) scale(.9) rotate(-1.2deg);
    }
    40% {
        opacity: 1;
        transform: translateY(10px) scale(1.03) rotate(.8deg);
    }
    65% {
        transform: translateY(-6px) scale(.992) rotate(-.5deg);
    }
    82% {
        transform: translateY(3px) scale(1.008) rotate(.25deg);
    }
    100% {
        opacity: 1;
        transform: translateY(0) scale(1) rotate(0);
    }
}
@media (prefers-reduced-motion: reduce) {
    .mod-form-popup,
    .mod-form-popup__dialog {
        transition: none;
        animation: none !important;
    }
    .mod-form-popup.is-open .mod-form-popup__dialog {
        opacity: 1;
        transform: none;
    }
}
.mod-form-popup__close {
    position: absolute; top: 10px; right: 10px;
    display: flex; align-items: center; justify-content: center;
    width: 40px; height: 40px; padding: 0;
    border: none; background: transparent; cursor: pointer;
}
.mod-form-popup__title {
    margin: 0 0 12px; font-size: 32px; line-height: 1.2; font-weight: 600; text-align: center;
}
.mod-form-popup__descr {
    margin: 0 0 24px; font-size: 16px; line-height: 1.55; text-align: center; color: var(--dark);
}
.mod-form-popup__form .mod-input {
    background: var(--white);
    border: 2px solid #e5e5e5;
}
.mod-form-popup__submit { width: 100%; margin-top: 4px; }
.mod-checkbox--popup { font-size: 12px; line-height: 1.45; }
.mod-checkbox--popup a { color: var(--purple); }
body.is-form-popup-open { overflow: hidden; }
@media (max-width: 480px) {
    .mod-form-popup__dialog { padding: 36px 20px 24px; }
    .mod-form-popup__title { font-size: 25px; }
    .mod-form-popup__descr { font-size: 14px; line-height: 1.45; }
}

/* FAQ */
.mod-faq { padding: 80px 0; background: var(--bg); }
.mod-faq__layout { display: grid; grid-template-columns: 1fr 1.2fr; gap: 48px; align-items: start; }
.mod-faq__intro { position: sticky; top: 100px; }
.mod-faq__arrow { margin-top: 24px; width: 172px; height: auto; }
.mod-faq__list { display: flex; flex-direction: column; gap: 12px; }
.mod-faq__item {
    background: var(--white); border-radius: 20px; overflow: hidden;
    border: none; transition: background .2s;
}
.mod-faq__item[open], .mod-faq__item.is-open { background: var(--purple); color: #fff; }
.mod-faq__question {
    cursor: pointer; font-weight: 700; font-size: 16px; line-height: 1.35;
    padding: 20px 56px 20px 24px; list-style: none; position: relative;
    display: flex; align-items: center; gap: 12px;
}
.mod-faq__question::-webkit-details-marker { display: none; }
.mod-faq__toggle {
    position: absolute; right: 16px; top: 50%; transform: translateY(-50%);
    width: 36px; height: 36px; border-radius: 50%; flex-shrink: 0;
    background: var(--lime); transition: transform .2s;
}
.mod-faq__toggle::after {
    content: ''; position: absolute; inset: 0; margin: auto;
    width: 8px; height: 8px; border-right: 2px solid var(--dark); border-bottom: 2px solid var(--dark);
    transform: rotate(-45deg) translate(-1px, -1px);
}
.mod-faq__item[open] .mod-faq__toggle { background: rgba(255,255,255,.2); transform: translateY(-50%) rotate(90deg); }
.mod-faq__item[open] .mod-faq__toggle::after { border-color: #fff; }
.mod-faq__answer { padding: 0 24px 20px; font-size: 14px; line-height: 1.6; opacity: .95; }
.mod-faq__item:not([open]) .mod-faq__answer { display: none; }
.mod-faq--grid .mod-faq__list {
    display: flex; flex-direction: column; gap: 12px;
}
.mod-faq--grid .mod-faq__item { min-height: 72px; }
.mod-faq--grid .mod-faq__question { font-size: 15px; padding: 18px 52px 18px 20px; }
.mod-faq--grid .mod-faq__answer { padding: 0 20px 18px; }
@media (max-width: 900px) {
    .mod-faq__layout { grid-template-columns: 1fr; }
    .mod-faq__intro { position: static; }
    .mod-faq__arrow { display: none; }
    .mod-faq--grid .mod-faq__list { grid-template-columns: 1fr; }
}

/* CTA / Form */
.mod-cta { padding: 80px 0; background: var(--bg); }
.mod-cta .mod-container {
    width: 100%;
    max-width: var(--shell);
    padding-inline: var(--shell-pad);
    box-sizing: border-box;
}
.mod-cta__card {
    display: grid; grid-template-columns: 1fr 1.1fr; gap: 40px;
    border-radius: 24px; padding: 48px 0 0;
    overflow: hidden; position: relative;
    background: var(--lime);
    width: 100%;
    box-sizing: border-box;
}
@media (min-width: 901px) {
    .mod-cta__card {
        padding-inline: calc(100% / 12);
    }
    .mod-cta__bg {
        left: calc(100% / 12);
        right: calc(100% / 12);
    }
}
.mod-cta__bg {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border-radius: 20px;
    overflow: hidden;
    pointer-events: none;
    z-index: 0;
}
.mod-cta__bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}
.mod-cta__info,
.mod-cta__form { position: relative; z-index: 1; }
.mod-cta__title { margin: 0 0 16px; font-size: clamp(28px, 4vw, 42px); font-weight: 700; line-height: 1.1; }
.mod-cta__title-accent { font-family: var(--font-flow); color: var(--purple); font-weight: 400; }
.mod-cta__subtitle { margin: 0 0 24px; font-size: 15px; max-width: 360px; line-height: 1.55; }
.mod-cta__info {
    display: flex; flex-direction: column; position: relative;
    min-height: 100%; padding-bottom: 0;
}
.mod-cta__plane {
    position: absolute; top: 72px; right: 0;
    width: 61px; height: auto; pointer-events: none;
}
.mod-cta__character {
    display: block; margin-top: auto; width: 271px; max-width: 100%;
    height: auto; align-self: flex-start; transform: scaleX(-1);
}
.mod-cta__form { padding-bottom: 48px; }
.mod-input--white { background: var(--white); }
.mod-checkbox--cta { font-size: 12px; line-height: 1.4; }
.mod-checkbox--cta strong { font-weight: 700; }
.mod-cta__submit { width: 100%; padding: 16px; font-size: 15px; }
.mod-cta__submit.btn--primary:hover { background: var(--white); color: var(--dark); }
@media (max-width: 900px) {
    .mod-cta__card { grid-template-columns: 1fr; padding: 32px 24px; }
    .mod-cta__bg { left: 0; right: 0; }
    .mod-cta__plane,
    .mod-cta__character { display: none; }
    .mod-cta__form { padding-bottom: 0; }
}
.mod-form { display: flex; flex-direction: column; gap: 12px; }
.mod-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 500px) { .mod-form__row { grid-template-columns: 1fr; } }
.mod-form.site-form > .mod-form__field,
.mod-form.site-form > .mod-form__row { margin-bottom: 12px; }
.mod-form__contact-method {
    margin: 0 0 12px; padding: 0; border: none;
}
.mod-form__contact-label {
    display: block; margin-bottom: 10px; padding: 0;
    font-size: 14px; font-weight: 600; line-height: 1.35; color: var(--dark);
}
.mod-form__contact-options {
    display: flex; flex-wrap: wrap; gap: 10px;
}
.mod-form__contact-option {
    display: inline-flex; align-items: center; gap: 8px;
    min-height: 44px; padding: 8px 14px;
    border: 2px solid #e5e5e5; border-radius: 12px;
    background: var(--white); cursor: pointer; font-size: 14px; line-height: 1.2;
    transition: border-color .2s;
}
.mod-form__contact-option:has(input:checked) { border-color: var(--purple); }
.mod-form__contact-option input {
    width: 16px; height: 16px; margin: 0; accent-color: var(--purple);
}
.mod-cta__form .mod-form__contact-option,
.mod-contacts__form .mod-form__contact-option {
    background: var(--bg); color: var(--dark);
}
.mod-contacts__form .mod-form__contact-label { color: var(--white); }
.mod-contacts__form .mod-form__contact-option:has(input:checked) { border-color: var(--lime); }
.mod-input {
    padding: 14px 16px; border: 2px solid transparent; border-radius: var(--radius);
    background: var(--bg); font-family: inherit; font-size: 15px; width: 100%;
    transition: border-color .2s;
}
.mod-input:focus { outline: none; border-color: var(--purple); }
.mod-input--area { min-height: 110px; resize: vertical; }
.mod-checkbox { font-size: 13px; display: flex; gap: 8px; align-items: flex-start; cursor: pointer; }
.mod-form__success { background: var(--lime); padding: 16px; border-radius: var(--radius); font-weight: 600; }
.mod-form__error { background: #ffe0e0; padding: 16px; border-radius: var(--radius); color: #a00; }

/* Contacts page */
.mod-contacts { padding: 48px 0 80px; background: var(--bg); }
.mod-contacts .mod-container {
    width: 100%; max-width: var(--shell); padding-inline: var(--shell-pad);
}
.mod-contacts__card {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    color: var(--white);
    background: var(--purple);
    min-height: 520px;
    padding: 40px calc(100% / 12);
    display: flex;
    flex-direction: column;
}
@media (min-width: 901px) {
    .mod-contacts__card {
        padding: 48px calc(100% / 12) 40px;
        min-height: 626px;
    }
    .mod-contacts__bg {
        left: calc(100% / 12);
        right: calc(100% / 12);
    }
}
.mod-contacts__bg {
    position: absolute;
    inset: 0;
    border-radius: var(--radius-lg);
    overflow: hidden;
    pointer-events: none;
    z-index: 0;
}
.mod-contacts__bg img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}
.mod-contacts__breadcrumb,
.mod-contacts__grid { position: relative; z-index: 1; }
.mod-contacts__breadcrumb {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0 0 32px;
    font-size: 14px;
    line-height: 1.55;
}
.mod-contacts__breadcrumb a {
    color: var(--white);
    font-weight: 500;
    text-decoration: none;
    transition: color .2s;
}
.mod-contacts__breadcrumb a:hover { color: var(--lime); }
.mod-contacts__breadcrumb-sep { color: var(--lime); font-weight: 600; }
.mod-contacts__breadcrumb-current { color: var(--lime); font-weight: 600; }
.mod-contacts__grid {
    display: grid;
    grid-template-columns: 1fr 1.05fr;
    gap: 48px;
    align-items: stretch;
    flex: 1;
}
.mod-contacts__info {
    display: flex;
    flex-direction: column;
    min-height: 100%;
}
.mod-contacts__title {
    margin: 0 0 24px;
    font-size: clamp(30px, 4.5vw, 47px);
    font-weight: 600;
    line-height: 1;
}
.mod-contacts__hours {
    margin: 0 0 32px;
    max-width: 360px;
    font-size: 16px;
    line-height: 1.55;
}
.mod-contacts__links {
    display: flex;
    flex-direction: column;
    gap: 20px;
}
.mod-contacts__link {
    display: inline-flex;
    align-items: center;
    gap: 16px;
    color: var(--white);
    text-decoration: none;
    font-size: 24px;
    font-weight: 600;
    line-height: 1.3;
    transition: color .2s;
}
.mod-contacts__link:hover { color: var(--lime); }
.mod-contacts__link img { flex-shrink: 0; width: 24px; height: 24px; }
.mod-contacts__character {
    display: block;
    width: 277px;
    max-width: 100%;
    height: auto;
    transform: scaleX(-1);
    flex-shrink: 0;
    pointer-events: none;
}
@media (min-width: 901px) {
    .mod-contacts__character {
        position: absolute;
        left: calc(100% / 12);
        bottom: 0;
        z-index: 2;
    }
}
.mod-contacts__form-title {
    margin: 0 0 12px;
    font-size: clamp(20px, 2.5vw, 24px);
    font-weight: 600;
    line-height: 1.3;
}
.mod-contacts__form-lead {
    margin: 0 0 24px;
    font-size: 16px;
    line-height: 1.55;
    max-width: 400px;
}
.mod-contacts__form { max-width: 420px; }
.mod-checkbox--contacts {
    color: var(--white);
    font-size: 12px;
    line-height: 1.4;
}
.mod-checkbox--contacts a { color: inherit; }
.mod-checkbox--contacts strong { font-weight: 700; }
.mod-contacts__submit { width: 100%; padding: 16px; font-size: 15px; margin-top: 4px; }
.mod-contacts__submit.btn--lime:hover { background: var(--white); color: var(--dark); }
@media (max-width: 900px) {
    .mod-contacts__card { padding: 32px calc(100% / 12) 40px; }
    .mod-contacts__grid { grid-template-columns: 1fr; gap: 40px; }
    .mod-contacts__character { display: none; }
    .mod-contacts__link { font-size: 20px; }
    .mod-contacts__form { max-width: none; }
}

/* About page */
.mod-about-intro { padding: 48px 0 80px; background: var(--bg); }
.mod-about__breadcrumb {
    display: flex; align-items: center; gap: 8px; margin: 0 0 32px;
    font-size: 14px; line-height: 1.55;
}
.mod-about__breadcrumb a { color: var(--dark); font-weight: 500; text-decoration: none; }
.mod-about__breadcrumb a:hover { color: var(--purple); }
.mod-about__breadcrumb-sep { color: var(--purple); font-weight: 600; }
.mod-about__breadcrumb-current { color: var(--purple); font-weight: 600; }
.mod-about-intro__title {
    margin: 0 0 40px; font-size: clamp(32px, 4.5vw, 47px); font-weight: 600; line-height: 1.05;
}
.mod-about-intro__title-accent { font-family: var(--font-flow); color: var(--purple); font-weight: 400; }
.mod-about-intro__grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start;
}
.mod-about-intro__text { font-size: 16px; line-height: 1.75; }
.mod-about-intro__text p { margin: 0 0 16px; }
.mod-about-intro__text p:last-child { margin-bottom: 0; }
.mod-about-intro__leader-wrap {
    margin: 0 0 0 auto; position: relative; padding: 6px 16px 13px 10px;
    width: 56%; max-width: 323px;
}
.mod-about-intro__leader-wrap::before {
    content: '';
    position: absolute; z-index: 0; pointer-events: none;
    top: 0; left: 0; width: 92%; height: 103%;
    border: 2px solid #fff; border-radius: 16px;
    transform: rotate(-7deg); transform-origin: center center;
}
.mod-about-intro__leader {
    position: relative; z-index: 1; margin: 0;
    border-radius: 16px; overflow: hidden; background: var(--dark);
    aspect-ratio: 358 / 384;
}
.mod-about-intro__leader img {
    width: 100%; height: 100%; object-fit: cover; object-position: center top; display: block;
}
.mod-about-intro__leader figcaption {
    position: absolute; left: 19px; bottom: 19px; right: 19px; color: var(--white);
}
.mod-about-intro__leader strong {
    display: block; font-size: 19px; font-weight: 600; line-height: 1.2; margin-bottom: 5px;
}
.mod-about-intro__leader span { font-size: 11px; line-height: 1.4; opacity: .9; }

.mod-about-mission { padding: 0 0 80px; background: var(--bg); }
.mod-about-mission__card {
    display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 48px; align-items: center;
    background: var(--white); color: var(--dark); border-radius: var(--radius-lg);
    padding: 60px 80px; overflow: hidden;
}
.mod-about-mission__title {
    margin: 0 0 32px; font-size: clamp(32px, 4vw, 47px); font-weight: 600; line-height: 1.1;
}
.mod-about-mission__title-accent { font-family: var(--font-flow); color: var(--purple); font-weight: 400; }
.mod-about-mission__text { margin: 0 0 16px; font-size: 16px; line-height: 1.75; max-width: 560px; color: var(--dark); }
.mod-about-mission__text:last-child { margin-bottom: 0; }
.mod-about-mission__media { display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.mod-about-mission__image { width: 302px; max-width: 100%; height: auto; }

.mod-about-values { padding: 0 0 80px; background: var(--bg); }
.mod-about-values__title { margin-bottom: 40px; }
.mod-about-values__grid {
    display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 48px 40px;
}
.mod-about-values__card { padding: 0; }
.mod-about-values__icon { width: 77px; height: 77px; margin-bottom: 20px; display: block; }
.mod-about-values__name { margin: 0 0 12px; font-size: 24px; font-weight: 700; color: var(--dark); }
.mod-about-values__text { margin: 0; font-size: 16px; line-height: 1.6; color: #555; max-width: 360px; }

.mod-about-team { padding: 0 0 80px; background: var(--bg); }
.mod-about-team__grid {
    display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 32px 28px;
}
@media (min-width: 1280px) {
    .mod-about-team__grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
.mod-about-team__card { text-align: left; }
.mod-about-team__photo {
    width: 100%; aspect-ratio: 360 / 296; object-fit: cover; border-radius: var(--radius-lg);
    display: block; background: #ddd;
}
.mod-about-team__info {
    position: relative; margin-top: 20px; min-height: 200px; padding: 20px 20px 12px 24px;
    background: var(--white); border-radius: var(--radius-lg); overflow: hidden;
}
.mod-about-team__name { margin: 0 0 8px; font-size: 18px; font-weight: 700; color: var(--dark); }
.mod-about-team__role {
    margin: 0; max-width: calc(100% - 120px); font-size: 14px; line-height: 1.45; color: #666;
}
@media (max-width: 1100px) {
    .mod-about-team__role { max-width: calc(100% - 80px); }
}
.mod-about-team__decor {
    position: absolute; right: 0; bottom: 0; width: 260px; height: auto;
    pointer-events: none; display: block;
}

.mod-about-patents { padding: 0 0 80px; background: var(--bg); }
.mod-about-patents__title { margin-bottom: 32px; }
.mod-about-patents__grid {
    display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px;
}
.mod-about-patents__item { margin: 0; }
.mod-about-patents__open {
    display: block;
    width: 100%;
    padding: 0;
    border: none;
    background: transparent;
    border-radius: var(--radius-lg);
    cursor: zoom-in;
    transition: transform .2s ease, box-shadow .2s ease;
}
.mod-about-patents__open:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 32px rgba(151, 71, 254, .18);
}
.mod-about-patents__open:focus-visible {
    outline: 2px solid var(--purple);
    outline-offset: 4px;
}
.mod-about-patents__open img {
    width: 100%; border-radius: var(--radius-lg); box-shadow: var(--shadow);
    display: block; pointer-events: none;
}

@media (max-width: 1100px) {
    .mod-about-values__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 900px) {
    .mod-about-intro__grid,
    .mod-about-mission__card { grid-template-columns: 1fr; padding: 40px 24px; gap: 32px; }
    .mod-about-intro__leader-wrap { width: min(80%, 461px); margin-left: auto; margin-right: auto; }
    .mod-about-mission__image { width: 240px; }
    .mod-about-patents__grid { grid-template-columns: 1fr; max-width: 360px; }
}
@media (max-width: 600px) {
    .mod-about-team__grid,
    .mod-about-values__grid { grid-template-columns: 1fr; }
    .mod-about-intro { padding-top: 32px; }
}

/* Content pages */
.mod-content { padding: 48px 0 80px; }
.mod-content--intro { padding-top: 32px; }
.mod-content__body { font-size: 17px; line-height: 1.75; }
.mod-content__body h2, .mod-content__body h3 { margin-top: 40px; margin-bottom: 16px; line-height: 1.2; }
.mod-content__body p { margin: 0 0 16px; }
.blog-cta { margin: 32px 0 0; }
.blog-cta .btn { display: inline-block; }
.mod-content__body .content-figure { margin: 32px 0; }
.mod-content__body .content-figure img { border-radius: var(--radius-lg); width: 100%; }
.mod-content__body--legal { max-width: none; width: 100%; }
.mod-content__body--legal h2 { font-size: 22px; margin-top: 48px; }
.mod-content__body--legal h2:first-child { margin-top: 0; }
.mod-content__body--legal ul,
.mod-content__body--legal ol { margin: 0 0 16px; padding-left: 1.4em; }
.mod-content__body--legal li { margin-bottom: 8px; }
.mod-content__body--legal a { color: var(--purple); text-decoration: none; }
.mod-content__body--legal a:hover { text-decoration: underline; }
.privacy-policy__operator {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: 24px 28px;
    margin-bottom: 32px;
    box-shadow: var(--shadow);
}
.privacy-policy__operator p { margin: 0; }

/* Articles */
.mod-articles { padding: 48px 0 80px; }
.mod-articles__lead { margin: 0 0 24px; opacity: .75; max-width: 640px; }
.mod-articles__filters { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 28px; }
.mod-articles__filter {
    padding: 8px 14px; border-radius: 999px; font-size: 14px; text-decoration: none;
    background: var(--surface-2, #f4f4f5); color: inherit; transition: background .15s;
}
.mod-articles__filter:hover { background: var(--surface-3, #e8e8ea); }
.mod-articles__filter.is-active { background: var(--accent, #111); color: #fff; }
.mod-articles__badge {
    display: inline-block; font-size: 12px; font-weight: 600; text-transform: uppercase;
    letter-spacing: .04em; opacity: .65; margin-bottom: 6px;
}
.mod-articles__badge--solo { text-decoration: none; margin: 8px 0 0; }
.mod-articles__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 24px; }
.mod-articles__card {
    background: var(--white); border-radius: var(--radius-lg); padding: 24px;
    text-decoration: none; color: inherit; display: block; transition: transform .2s;
}
.mod-articles__card:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.mod-articles__img { width: 100%; height: 180px; object-fit: cover; border-radius: var(--radius); margin-bottom: 12px; }
.mod-articles__card time { font-size: 13px; opacity: .5; }
.mod-articles__card h3 { margin: 8px 0; font-size: 20px; }
.mod-articles__card p { margin: 0; opacity: .7; font-size: 15px; }

.mod-article { padding: 48px 0 80px; }
.mod-article__cover { width: 100%; max-height: 400px; object-fit: cover; border-radius: var(--radius-lg); margin: 24px 0; }
.mod-article__date { font-size: 14px; opacity: .5; display: block; margin: 16px 0; }

/* Footer */
.site-footer { background: var(--white); padding: 72px 0 32px; margin-top: 0; }
.site-footer__top {
    display: grid; grid-template-columns: 1.4fr 0.8fr 0.9fr 1.2fr; gap: 32px 40px;
    position: relative; padding-bottom: 40px; border-bottom: 1px solid #e8e8e8;
}
.site-footer__logo { display: inline-flex; align-items: baseline; gap: 8px; text-decoration: none; margin-bottom: 20px; }
.site-footer__logo-text { font-size: 22px; font-weight: 700; color: var(--dark); }
.site-footer__logo-accent { font-family: var(--font-flow); color: var(--purple); font-size: 20px; }
.site-footer__social { display: flex; gap: 12px; margin-bottom: 20px; }
.site-footer__social-link {
    width: 38px; height: 38px; border-radius: 50%; overflow: hidden;
    display: flex; align-items: center; justify-content: center; transition: transform .15s;
}
.site-footer__social-link:hover { transform: scale(1.08); }
.site-footer__social-link img { width: 100%; height: 100%; object-fit: cover; }
.site-footer__ask {
    background: var(--bg); color: var(--purple); border: none; font-weight: 600;
    text-decoration: none; display: inline-flex;
}
.site-footer__ask:hover { background: var(--purple); color: #fff; }
.site-footer__col-title { display: block; font-weight: 600; margin-bottom: 16px; font-size: 14px; opacity: .5; }
.site-footer__links { display: flex; flex-direction: column; gap: 10px; }
.site-footer__links a { text-decoration: none; font-size: 15px; font-weight: 600; transition: color .2s; }
.site-footer__links a:hover { color: var(--purple); }
.site-footer__contact-link { display: block; color: var(--purple); font-weight: 600; text-decoration: none; margin-bottom: 8px; }
.site-footer__phone { display: block; text-decoration: none; font-weight: 600; font-size: 15px; }
.site-footer__rocket {
    position: absolute; top: 0; right: 0; width: 48px; height: auto;
    transform: translate(-65px, 70px);
    transition: transform 700ms ease-in-out;
    will-change: transform;
}
.site-footer__rocket.is-flying { transform: translate(0, 0); }
@media (prefers-reduced-motion: reduce) {
    .site-footer__rocket { transform: none; transition: none; }
}
.site-footer__bottom {
    display: grid; grid-template-columns: auto 1fr auto; gap: 24px; align-items: start;
    padding-top: 24px; font-size: 13px; color: #888;
}
.site-footer__legal-entity { margin: 0; text-align: center; font-size: 12px; line-height: 1.5; opacity: .6; }
.site-footer__legal { margin: 0; text-align: center; font-size: 12px; line-height: 1.5; opacity: .6; }
.site-footer__privacy { color: inherit; text-decoration: none; white-space: nowrap; }
.site-footer__privacy:hover { color: var(--purple); }
@media (max-width: 900px) {
    .site-footer__top { grid-template-columns: 1fr 1fr; }
    .site-footer__rocket { display: none; }
    .site-footer__bottom { grid-template-columns: 1fr; text-align: center; }
    .site-footer__legal-entity,
    .site-footer__legal { text-align: center; }
}

/* Cookie banner */
.cookie-banner {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 10050;
    pointer-events: none;
}
.cookie-banner[hidden] { display: none !important; }
.cookie-banner:not([hidden]) {
    display: block !important;
    pointer-events: auto;
}
.cookie-banner__box {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    width: 100%;
    max-width: none;
    margin: 0;
    padding: 16px var(--shell-pad, 20px);
    background: var(--white);
    border-radius: 0;
    box-shadow: 0 -2px 12px rgba(0, 0, 0, 0.08);
}
.cookie-banner__text {
    margin: 0;
    flex: 1;
    font-size: 14px;
    line-height: 1.45;
    color: var(--dark);
}
.cookie-banner__link {
    color: var(--purple);
    font-weight: 600;
    text-decoration: none;
}
.cookie-banner__link:hover { text-decoration: underline; }
.cookie-banner__btn {
    flex-shrink: 0;
    min-width: 72px;
    padding: 10px 24px;
    border-radius: 12px;
    background: var(--purple);
    color: #fff;
    border: none;
    font-weight: 600;
    font-size: 14px;
    cursor: pointer;
}
.cookie-banner__btn:hover {
    background: var(--lime);
    color: var(--dark);
}
@media (max-width: 640px) {
    .cookie-banner__box {
        flex-direction: column;
        align-items: stretch;
        gap: 14px;
        padding: 14px var(--shell-pad);
    }
    .cookie-banner__btn { width: 100%; }
}

.site-main { display: block; min-height: 50vh; }

.legacy-html { display: none !important; }

/* Case detail pages */
.mod-case-hero {
    padding: 90px 0 32px;
    background: var(--bg);
}
.mod-case-intro,
.mod-case-goal,
.mod-case-tasks,
.mod-case-gallery,
.mod-case-story,
.mod-case-stats,
.mod-case-block {
    --case-side: calc(100% / 12);
    padding-inline: var(--case-side);
    box-sizing: border-box;
}
@media (min-width: 1440px) {
    .mod-case-intro,
    .mod-case-goal,
    .mod-case-tasks,
    .mod-case-gallery,
    .mod-case-story,
    .mod-case-stats,
    .mod-case-block {
        --case-side: calc((100% - var(--shell)) / 2 + var(--shell) / 12);
    }
}
.mod-case-hero__shell,
.mod-case-intro__shell,
.mod-case-goal__shell,
.mod-case-tasks__shell,
.mod-case-story__shell,
.mod-case-stats__shell,
.mod-case-gallery__shell,
.mod-case-block__shell {
    width: 100%;
    max-width: calc(var(--shell) * 10 / 12);
    margin-inline: 0;
    padding-inline: 0;
}
.mod-case-intro .mod-case-intro__shell.mod-container {
    margin-inline: 0;
}
.mod-case-hero__breadcrumb {
    display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
    font-size: 14px; color: rgba(31, 31, 31, 0.55); margin-bottom: 24px;
}
.mod-case-hero__breadcrumb a { color: inherit; text-decoration: none; }
.mod-case-hero__breadcrumb a:hover { color: var(--dark); }
.mod-case-hero__breadcrumb-current { color: var(--dark); font-weight: 500; }
.mod-case-hero__headline {
    display: flex; flex-direction: column; gap: 4px;
    font-size: clamp(32px, 5vw, 56px); line-height: 1.05; font-weight: 700;
    max-width: 900px;
}
.mod-case-hero__line--main { color: var(--dark); font-weight: 700; }
.mod-case-hero__line--accent {
    font-family: var(--font-flow); color: var(--purple); font-weight: 400;
    font-size: clamp(36px, 5.5vw, 64px); line-height: 1.02;
}

.mod-case-intro { padding-block: 8px 48px; background: var(--bg); }
.mod-case-intro--unified {
    padding-block-start: 90px;
    padding-block-end: 0;
}
.mod-case-intro__top { margin-bottom: 32px; }
.mod-case-intro__breadcrumb {
    display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
    font-size: 14px; color: rgba(31, 31, 31, 0.55); margin-bottom: 24px;
}
.mod-case-intro__breadcrumb a { color: inherit; text-decoration: none; }
.mod-case-intro__breadcrumb a:hover { color: var(--dark); }
.mod-case-intro__breadcrumb-current { color: var(--dark); font-weight: 500; }
.mod-case-intro__headline {
    display: flex; flex-direction: column; gap: 4px;
    font-size: clamp(32px, 5vw, 56px); line-height: 1.05; font-weight: 700;
    max-width: 900px; margin: 0;
}
.mod-case-intro__line--main { color: var(--dark); font-weight: 700; }
.mod-case-intro__line--accent {
    font-family: var(--font-flow); color: var(--purple); font-weight: 400;
    font-size: clamp(36px, 5.5vw, 64px); line-height: 1.02;
}
.mod-case-intro__subtitle {
    font-size: clamp(22px, 3vw, 32px);
    font-weight: 700;
    line-height: 1.2;
    color: var(--dark);
    margin: 24px 0 0;
    max-width: 900px;
}
.mod-case-intro__head {
    display: flex; justify-content: space-between; align-items: flex-start;
    gap: 24px; flex-wrap: wrap; margin-bottom: 32px;
}
.mod-case-intro__top {
    display: block;
}
.mod-case-intro__label { font-size: 14px; color: rgba(31, 31, 31, 0.55); margin-bottom: 8px; }
.mod-case-intro__value { font-size: 20px; font-weight: 700; margin: 0; }
.mod-case-intro__site {
    flex-shrink: 0;
    margin-top: 10px;
    min-height: 40px;
    padding: 10px 24px;
    border-radius: 10px;
    font-size: 14px;
    line-height: 1.55;
    font-weight: 600;
    white-space: nowrap;
    text-decoration: none;
    box-shadow: none;
}
.mod-case-intro__site:hover,
.mod-case-intro__site:focus-visible {
    text-decoration: none;
    color: #fff;
}
.mod-case-intro__gallery {
    display: grid; grid-template-columns: 1.4fr 0.8fr; gap: 16px; align-items: start;
}
.mod-case-intro__gallery--split {
    grid-template-columns: minmax(0, 860fr) minmax(0, 262fr);
    gap: 20px;
    align-items: start;
}
.mod-case-intro__wireframe {
    border-radius: 20px;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 8px 32px rgba(0,0,0,.06);
}
.mod-case-intro__wireframe img { display: block; width: 100%; height: auto; }
.mod-case-intro__panel--side {
    background: #dce9f7;
    border-radius: 28px;
    overflow: hidden;
    padding: 24px 16px 0;
}
.mod-case-intro__panel--side img {
    display: block; width: 100%; height: auto; border-radius: 16px 16px 0 0;
}
.mod-case-intro__gallery--panel { display: block; }
.mod-case-intro__panel {
    background: #dce9f7; border-radius: 28px; overflow: hidden; padding: 32px 32px 0;
}
.mod-case-intro__panel img {
    display: block; width: 100%; height: auto; border-radius: 16px 16px 0 0;
}
.mod-case-intro__shot { border-radius: 20px; overflow: hidden; background: #fff; box-shadow: 0 8px 32px rgba(0,0,0,.08); }
.mod-case-intro__shot img { display: block; width: 100%; height: auto; }
.mod-case-intro__shot--side { margin-top: 48px; }
.mod-case-intro__lead {
    margin-top: 40px; max-width: 820px; font-size: 18px; line-height: 1.6; color: var(--dark);
}

/* Avto-logistics intro: full shell + green device frame */
.mod-case-intro--shell-wide {
    padding-inline: 0;
    padding-block: 8px 48px;
}
.mod-case-intro--shell-wide .mod-case-intro__shell {
    width: 100%;
    max-width: var(--shell);
    margin-inline: auto;
    padding-inline: var(--shell-pad);
    box-sizing: border-box;
}
.mod-case-intro--shell-wide .mod-case-intro__head {
    padding-inline: calc(100% / 12);
    box-sizing: border-box;
    margin-bottom: 24px;
}
.mod-case-intro--shell-wide .mod-case-intro__gallery--frame-green {
    margin-inline: calc(100% / 12);
    width: auto;
    background: transparent;
    border-radius: 0;
    padding: 0;
    gap: clamp(20px, 3vw, 40px);
    align-items: stretch;
}
.mod-case-intro--shell-wide .mod-case-intro__gallery--frame-wide {
    margin-inline: calc(100% / 12);
    width: auto;
}
.mod-case-intro--shell-wide .mod-case-intro__gallery--frame-wide .mod-case-intro__panel {
    border-radius: 20px;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
}
.mod-case-intro--shell-wide .mod-case-intro__gallery--frame-wide .mod-case-intro__panel img {
    display: block;
    width: 100%;
    height: auto;
}
.mod-case-intro__gallery--frame-green {
    background: transparent;
    border-radius: 0;
    padding: 0;
    gap: clamp(20px, 3vw, 40px);
    align-items: stretch;
}
.mod-case-intro__gallery--frame-green .mod-case-intro__panel--side {
    background: #4a5c3a;
    border-radius: 20px;
    padding: clamp(16px, 2.5vw, 28px);
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    min-height: 0;
}
.mod-case-intro__gallery--frame-green .mod-case-intro__panel--side img {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 8px;
    box-shadow: none;
}
.mod-case-intro__gallery--frame-green .mod-case-intro__wireframe {
    background: #8fa88a;
    box-shadow: none;
    border: 4px solid #3a5233;
    border-radius: 20px;
    padding: 0;
    box-sizing: border-box;
    overflow: hidden;
    width: 100%;
    max-width: none;
    margin-inline: 0;
    justify-self: stretch;
    display: block;
    min-height: 0;
}
.mod-case-intro__gallery--frame-green .mod-case-intro__wireframe img {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 100%;
    object-fit: cover;
    object-position: top center;
    border-radius: 14px;
}

.mod-case-goal { padding-block: 48px 64px; background: var(--bg); }
.mod-case-goal__layout {
    display: grid; grid-template-columns: minmax(220px, 320px) 1fr; gap: 56px; align-items: start;
}
.mod-case-goal__services {
    list-style: none; padding: 0; margin: 0 0 20px; display: flex; flex-direction: column; gap: 10px;
}
.mod-case-goal__services li {
    font-size: 15px; font-weight: 600; color: var(--dark);
    background: #fff; border-radius: 12px; padding: 12px 16px;
}
.mod-case-goal__hash-tags { display: flex; flex-wrap: wrap; gap: 10px; }
.mod-case-goal__hash {
    font-size: 14px; font-weight: 600; color: var(--purple);
    background: rgba(151, 71, 254, 0.1); border-radius: 999px; padding: 6px 14px;
}
.mod-case-goal__goal-title { font-size: 20px; font-weight: 700; margin: 0 0 20px; }
.mod-case-goal__list {
    list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 18px;
}
.mod-case-goal__list-item {
    display: grid; grid-template-columns: 36px 1fr; gap: 14px; align-items: start;
    font-size: 15px; line-height: 1.55;
}
.mod-case-goal__list-item p { margin: 0; }
.mod-case-goal__num {
    width: 36px; height: 36px; border-radius: 50%;
    background: transparent;
    border: 2px solid var(--purple);
    box-sizing: border-box;
    position: relative; flex-shrink: 0;
}
.mod-case-goal__num::after {
    counter-increment: none;
}
.mod-case-goal__list { counter-reset: goal; }
.mod-case-goal__list-item { counter-increment: goal; }
.mod-case-goal__num::before {
    content: counter(goal);
    position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
    color: var(--purple); font-size: 14px; font-weight: 700;
}

.mod-case-tasks { padding-block: 64px; background: transparent; }
.mod-case-tasks + .mod-case-gallery--mockup { padding-top: 120px; }
.mod-case-tasks__headline {
    font-size: clamp(28px, 4vw, 40px); line-height: 1.1; font-weight: 700; margin-bottom: 32px;
}
.mod-case-tasks__title { color: var(--dark); }
.mod-case-tasks__accent { font-family: var(--font-flow); color: var(--purple); font-weight: 400; }
.mod-case-tasks__grid {
    list-style: none; padding: 0; margin: 0;
    display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px;
}
.mod-case-tasks__card {
    background: transparent;
    border-radius: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 16px;
    min-height: 0;
}
.mod-case-tasks__num {
    width: 64px; height: 64px; border-radius: 14px; background: var(--lime);
    display: flex; align-items: center; justify-content: center;
    font-size: 32px; font-weight: 700; color: var(--dark); flex-shrink: 0;
    line-height: 1;
}
.mod-case-tasks__card p { margin: 0; font-size: 15px; line-height: 1.55; color: var(--dark); }

.mod-case-gallery { padding-block: 32px; background: transparent; }
.mod-case-gallery__grid { display: grid; gap: 16px; }
.mod-case-gallery--wide .mod-case-gallery__grid { grid-template-columns: 1fr; }
.mod-case-gallery--wide .mod-case-gallery__item {
    border-radius: 24px; overflow: hidden; background: #fff;
    box-shadow: 0 8px 32px rgba(0,0,0,.06);
}
.mod-case-gallery--prototype { padding-block: 80px 48px; }
.mod-case-gallery--prototype .mod-case-gallery__item {
    border-radius: 0; overflow: hidden; background: transparent;
    box-shadow: none;
}
.mod-case-gallery--mockup { padding-block: 80px 40px; }
.mod-case-gallery--mockup .mod-case-gallery__grid {
    grid-template-columns: minmax(0, 860fr) minmax(0, 262fr);
    gap: clamp(16px, 3vw, 40px);
    align-items: stretch;
}
.mod-case-gallery--mockup .mod-case-gallery__item {
    display: flex;
    min-height: 0;
    margin: 0;
}
.mod-case-gallery--mockup .mod-case-gallery__item--desktop {
    border-radius: 20px; overflow: hidden; background: #fff;
}
.mod-case-gallery--mockup .mod-case-gallery__item--mobile {
    border-radius: 10px; overflow: hidden; background: #fff;
    border: 8px solid #767676; box-sizing: border-box;
}
.mod-case-gallery--mockup .mod-case-gallery__item img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
}
.mod-case-gallery--phones .mod-case-gallery__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.mod-case-gallery--phones .mod-case-gallery__item {
    border-radius: 10px;
    overflow: hidden;
    background: #fff;
    border: 8px solid #767676;
    box-sizing: border-box;
}
.mod-case-gallery__item img { display: block; width: 100%; height: auto; }

.mod-case-story { padding-block: 48px; background: var(--bg); }
.mod-case-story__block { margin-bottom: 48px; }
.mod-case-story__block:last-child { margin-bottom: 0; }
.mod-case-story__title {
    font-size: clamp(24px, 3vw, 32px); font-weight: 700; margin-bottom: 16px; color: var(--dark);
}
.mod-case-story__body {
    font-size: 16px; line-height: 1.65; color: var(--dark); max-width: 820px;
}
.mod-case-story__body ul { margin: 12px 0; padding-left: 20px; }
.mod-case-story__body li { margin-bottom: 8px; }
.mod-case-story__body strong { font-weight: 700; }
.mod-case-story__body .quill-table__wrapper { overflow-x: auto; margin: 20px 0; }
.mod-case-story__body .quill-table__table {
    width: 100%; border-collapse: collapse; font-size: 14px; line-height: 1.45;
}
.mod-case-story__body .quill-table__cell {
    border: 1px solid #c1c1c1; padding: 12px 14px; vertical-align: top;
}
.mod-case-story__body .quill-table__cell p { margin: 0; }
.mod-case-story__figure { margin: 24px 0 0; border-radius: 20px; overflow: hidden; }
.mod-case-story__figure img { display: block; width: 100%; height: auto; }
.mod-case-story__title--sub {
    font-size: 20px;
    margin-bottom: 12px;
}
.mod-case-story__block--sub {
    margin-bottom: 32px;
}
.mod-case-story__block--sub:last-child {
    margin-bottom: 0;
}
.mod-case-story--flow {
    padding-block: 0 48px;
}
.mod-case-story--flow .mod-case-story__block:first-child {
    padding-top: 60px;
}
.mod-case-story--flow .mod-case-story__block:not(.mod-case-story__block--sub):not(.mod-case-story__block--media) {
    margin-bottom: 60px;
}
.mod-case-story--flow .mod-case-story__block--head {
    margin-bottom: 0;
}
.mod-case-story--flow .mod-case-story__block--head + .mod-case-story__block--sub {
    margin-top: 30px;
}
.mod-case-story--flow .mod-case-story__block--media {
    margin-bottom: 60px;
}
.mod-case-story--flow .mod-case-story__block--sub {
    margin-bottom: 48px;
}
.mod-case-story--flow .mod-case-story__block--sub:last-child {
    margin-bottom: 0;
}
.mod-case-story--flow .mod-case-story__title--sub strong {
    font-weight: 700;
}
.mod-case-story__gallery {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
    margin-top: 24px;
}
.mod-case-story__gallery-item {
    margin: 0;
    border-radius: 20px;
    overflow: hidden;
}
.mod-case-story--flow .mod-case-story__gallery-item {
    border-radius: 10px;
}
.mod-case-story--flow .mod-case-story__figure--phone {
    width: calc((100% - 32px) / 3);
    max-width: 389px;
    margin: 24px auto 0;
    border-radius: 10px;
}
.mod-case-story__gallery-item img {
    display: block;
    width: 100%;
    height: auto;
}

.mod-case-stats { padding-block: 48px 64px; background: #fff; }
.mod-case-stats__headline { font-size: 28px; font-weight: 700; margin-bottom: 28px; }
.mod-case-stats__grid {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px;
}
.mod-case-stats__item {
    background: var(--bg); border-radius: 20px; padding: 24px 20px;
}
.mod-case-stats__value {
    font-size: clamp(28px, 4vw, 40px); font-weight: 700; color: var(--purple); line-height: 1.1; margin-bottom: 8px;
}
.mod-case-stats__text { font-size: 14px; line-height: 1.5; color: rgba(31, 31, 31, 0.8); }
.mod-case-stats--inline {
    padding-block: 60px 45px;
    background: var(--bg);
}
.mod-case-stats--inline .mod-case-stats__headline {
    font-size: clamp(24px, 3vw, 32px);
    margin-bottom: 24px;
}
.mod-case-stats--inline .mod-case-stats__item {
    background: none;
    border-radius: 0;
    padding: 0;
}
.mod-case-stats--inline .mod-case-stats__value {
    font-size: clamp(28px, 4vw, 42px);
    color: var(--dark);
    padding-bottom: 12px;
    margin-bottom: 12px;
    border-bottom: 2px solid var(--purple);
}
.mod-case-stats--inline .mod-case-stats__text {
    font-size: 15px;
    line-height: 1.55;
    color: var(--dark);
}
.mod-case-stats--inline .mod-case-stats__footer {
    margin-top: 60px;
}
.mod-case-stats--inline .mod-case-stats__footer-title {
    font-size: clamp(24px, 3vw, 32px);
    font-weight: 700;
    margin: 0 0 16px;
    color: var(--dark);
}
.mod-case-stats--inline .mod-case-stats__footer-body {
    font-size: 16px;
    line-height: 1.65;
    color: var(--dark);
    max-width: 820px;
}
.mod-case-stats--inline .mod-case-stats__footer-body ul {
    margin: 12px 0;
    padding-left: 20px;
}
.mod-case-stats--inline .mod-case-stats__footer-body li {
    margin-bottom: 8px;
}
.mod-case-stats--inline .mod-case-stats__footer-body strong {
    font-weight: 700;
}

/* Case promo hero — full shell width, 1/12 inner gutters */
.mod-case-hero--promo {
    padding-block: 24px 0;
    background: var(--bg);
    padding-inline: 0;
    box-sizing: border-box;
}
.mod-case-hero--promo .mod-case-hero__shell {
    width: 100%;
    max-width: var(--shell);
    margin-inline: auto;
    padding-inline: var(--shell-pad);
    box-sizing: border-box;
}
.mod-case-hero__promo-card {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(300px, 46%);
    gap: clamp(16px, 3vw, 32px);
    align-items: center;
    width: 100%;
    min-height: clamp(420px, 60vh, 550px);
    padding-block: clamp(32px, 5vw, 56px);
    padding-inline: calc(100% / 12);
    border-radius: 24px;
    background: #9747fe;
    overflow: hidden;
    box-sizing: border-box;
}
.mod-case-hero__breadcrumb--light { color: rgba(255,255,255,.7); margin-bottom: 20px; }
.mod-case-hero__breadcrumb--light a { color: inherit; text-decoration: none; }
.mod-case-hero__breadcrumb--light a:hover { color: #fff; }
.mod-case-hero__breadcrumb--light .mod-case-hero__breadcrumb-current { color: #fff; font-weight: 500; }
.mod-case-hero__promo-headline { display: flex; flex-direction: column; gap: 16px; margin: 0 0 24px; max-width: 560px; }
.mod-case-hero__promo-title {
    font-family: var(--font-flow); color: #ccfd66; font-size: clamp(34px, 5vw, 56px);
    line-height: 1.02; font-weight: 400;
}
.mod-case-hero__promo-subtitle { color: #fff; font-size: clamp(16px, 2vw, 20px); line-height: 1.45; font-weight: 400; }
.mod-case-hero__promo-btn { margin-bottom: 20px; }
.mod-case-hero__tags { display: flex; flex-wrap: wrap; gap: 8px; }
.mod-case-hero__tag { font-size: 14px; color: rgba(255,255,255,.85); font-style: italic; }
.mod-case-hero__promo-art { margin: 0; align-self: center; justify-self: end; }
.mod-case-hero__promo-art img { display: block; width: min(100%, 671px); height: auto; }

/* Case content blocks */
.mod-case-block { padding-block: 40px; background: var(--bg); }
.mod-case-block__shell { width: 100%; max-width: calc(var(--shell) * 10 / 12); margin-inline: 0; padding-inline: 0; }
.mod-case-block--card {
    padding-inline: 0;
    padding-block: 12px 40px;
}
.mod-case-block--card .mod-case-block__shell {
    width: 100%;
    max-width: var(--shell);
    margin-inline: auto;
    padding-inline: var(--shell-pad);
    box-sizing: border-box;
}
.mod-case-block--card .mod-case-block__card {
    margin-inline: calc(100% / 12);
    width: auto;
}
.mod-case-block__head { margin-bottom: 28px; }
.mod-case-block__title {
    margin: 0; font-size: clamp(28px, 4vw, 40px); line-height: 1.1; font-weight: 700; color: var(--dark);
}
.mod-case-block__title-accent { font-family: var(--font-flow); color: var(--purple); font-weight: 400; }
.mod-case-block--before .mod-case-block__title,
.mod-case-block--solution .mod-case-block__title,
.mod-case-block--approach .mod-case-block__title { font-family: var(--font-flow); color: var(--purple); font-weight: 400; font-size: clamp(32px, 4.5vw, 48px); }
.mod-case-block--split .mod-case-block__title {
    font-family: inherit;
    color: var(--dark);
    font-weight: 700;
    font-size: clamp(24px, 3vw, 32px);
}
.mod-case-block--split .mod-case-block__title-accent { font-family: var(--font-flow); color: var(--purple); font-weight: 400; }
.mod-case-block--split .mod-case-block__subtitle {
    margin: 8px 0 0;
    font-family: var(--font-flow);
    color: var(--purple);
    font-weight: 400;
    font-size: clamp(28px, 3.5vw, 40px);
}
.mod-case-block__head--center { text-align: center; max-width: 900px; margin-inline: auto; }
.mod-case-block__subtitle { margin: 8px 0 0; font-size: clamp(18px, 2.5vw, 24px); font-weight: 700; color: var(--dark); }
.mod-case-block__lead { margin: 0 0 24px; font-size: 16px; line-height: 1.65; color: var(--dark); max-width: 820px; }
.mod-case-block__lead--html p { margin: 0 0 16px; }
.mod-case-block__lead--html p:last-child { margin-bottom: 0; }
.mod-case-block__footer { margin-top: 24px; font-size: 15px; line-height: 1.6; color: var(--dark); }
.mod-case-block__footer p { margin: 0 0 12px; }
.mod-case-block__footer p:last-child { margin-bottom: 0; }
.mod-case-block__lead--center { max-width: 900px; margin-inline: auto; text-align: left; }

.mod-case-block__card {
    width: 100%;
    box-sizing: border-box;
    display: grid;
    grid-template-columns: minmax(0, 1.75fr) minmax(200px, 302px);
    gap: clamp(24px, 4vw, 48px);
    align-items: center;
    padding: clamp(36px, 4vw, 48px) clamp(32px, 4.5vw, 56px);
    border-radius: 20px;
    background: #fff;
}
.mod-case-block__card-title {
    margin: 0 0 clamp(20px, 3vw, 28px);
    font-size: clamp(32px, 3.5vw, 48px);
    line-height: 1.1;
    font-weight: 700;
    color: var(--dark);
}
.mod-case-block__text {
    font-size: clamp(16px, 1.6vw, 18px);
    line-height: 1.65;
    color: var(--dark);
}
.mod-case-block__text strong { font-weight: 700; }
.mod-case-block__card .mod-case-block__text p { margin: 0 0 20px; }
.mod-case-block__card .mod-case-block__text p:last-child { margin-bottom: 0; }
.mod-case-block__card-figure {
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.mod-case-block__card-figure img {
    display: block;
    width: min(100%, 302px);
    height: auto;
}
.mod-case-block__before {
    display: grid; grid-template-columns: minmax(180px, 240px) minmax(0, 1fr); gap: clamp(24px, 4vw, 48px);
}
.mod-case-block__tag { margin: 0 0 8px; font-size: 15px; line-height: 1.4; color: var(--dark); }
.mod-case-block__hash-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 16px; }
.mod-case-block__hash {
    display: inline-flex; padding: 8px 14px; border-radius: 999px; background: #fff;
    font-size: 13px; color: var(--dark);
}
.mod-case-block__steps { list-style: none; margin: 0; padding: 0; display: grid; gap: 20px; }
.mod-case-block__step { display: grid; grid-template-columns: 40px minmax(0, 1fr); gap: 16px; align-items: start; }
.mod-case-block__step-num {
    width: 40px; height: 40px; border-radius: 50%; border: 2px solid var(--purple);
    display: flex; align-items: center; justify-content: center; font-weight: 700; color: var(--purple); flex-shrink: 0;
}
.mod-case-block__step-body { font-size: 15px; line-height: 1.6; color: var(--dark); }
.mod-case-block__step-body strong { display: block; margin-bottom: 4px; }
.mod-case-block__grid4 { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 20px; align-items: start; }
.mod-case-block__grid4-item {
    display: grid;
    grid-template-rows: 110px auto;
    gap: 20px;
    align-content: start;
}
.mod-case-block__grid4-num {
    width: 48px; height: 48px; border-radius: 12px; background: var(--lime);
    display: flex; align-items: center; justify-content: center; font-size: 22px; font-weight: 700; color: var(--purple); margin-bottom: 16px;
}
.mod-case-block__grid4-icon {
    width: 110px;
    height: 110px;
    margin: 0;
    display: flex;
    align-items: flex-end;
    justify-content: flex-start;
}
.mod-case-block__grid4-icon img {
    display: block;
    width: auto;
    max-width: 110px;
    height: auto;
    max-height: 110px;
    object-fit: contain;
    object-position: left bottom;
}
.mod-case-block__grid4-title { margin: 0 0 8px; font-size: 16px; font-weight: 700; color: var(--dark); }
.mod-case-block__grid4-text { margin: 0; font-size: 14px; line-height: 1.55; color: rgba(31,31,31,.8); }
.mod-case-block__split { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: clamp(24px, 4vw, 40px); align-items: start; }
.mod-case-block__split--content-card {
    grid-template-columns: minmax(220px, 360px) minmax(0, 1fr);
    align-items: stretch;
}
.mod-case-block__split--content-card .mod-case-block__split-media {
    display: flex;
    align-items: stretch;
    justify-content: center;
    min-height: 0;
}
.mod-case-block__split--content-card .mod-case-block__split-figure--plain {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    max-width: 360px;
    height: 100%;
    min-height: 0;
}
.mod-case-block__split--content-card .mod-case-block__split-figure--plain img {
    display: block;
    width: auto;
    max-width: 100%;
    height: 100%;
    max-height: 100%;
    object-fit: contain;
    margin-inline: auto;
}
.mod-case-block__split--left .mod-case-block__split-media { order: -1; }
.mod-case-block__split--right .mod-case-block__split-content { order: -1; }
.mod-case-block__split-media { display: grid; gap: 16px; }
.mod-case-block__split-figure { margin: 0; border-radius: 16px; overflow: hidden; background: #fff; box-shadow: 0 8px 32px rgba(0,0,0,.06); }
.mod-case-block__split-figure--plain {
    border-radius: 0;
    overflow: visible;
    background: transparent;
    box-shadow: none;
}
.mod-case-block__split-figure img { display: block; width: 100%; height: auto; }
.mod-case-block__split-figure--plain img { max-width: 360px; margin-inline: auto; }

.mod-case-block__solution {
    display: flex;
    flex-direction: column;
    gap: clamp(36px, 5vw, 56px);
}
.mod-case-block__solution-section,
.mod-case-block__solution-row {
    display: grid;
    grid-template-columns: minmax(0, 460px) minmax(0, 1fr);
    gap: clamp(24px, 4vw, 40px);
    align-items: start;
}
.mod-case-block__solution-media {
    display: grid;
    gap: 16px;
}
.mod-case-block__solution-figure {
    margin: 0;
    border-radius: 16px;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.06);
}
.mod-case-block__solution-figure img {
    display: block;
    width: 100%;
    height: auto;
}
.mod-case-block__solution-content .mod-case-block__text {
    font-size: 16px;
    line-height: 1.65;
    color: var(--dark);
    margin-bottom: 24px;
}
.mod-case-block__solution-content .mod-case-block__steps {
    margin-top: 0;
}
.mod-case-block__compare {
    margin-top: 16px;
    font-size: 15px;
    line-height: 1.6;
    color: var(--dark);
}
.mod-case-block__compare p {
    margin: 0 0 12px;
}
.mod-case-block__compare p:last-child {
    margin-bottom: 0;
}
.mod-case-block__compare ul {
    list-style: none;
    margin: 0 0 12px;
    padding: 0;
}
.mod-case-block__compare li {
    margin: 0 0 12px;
}

.mod-case-block__split-content--card {
    background: #fff;
    border-radius: 20px;
    padding: clamp(28px, 4vw, 40px) clamp(24px, 3.5vw, 48px);
    box-sizing: border-box;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.mod-case-block__split-content--card .mod-case-block__text {
    font-size: clamp(16px, 1.6vw, 18px);
    line-height: 1.65;
}
.mod-case-block__split-content--card .mod-case-block__text strong { font-weight: 700; }
.mod-case-block__steps--compact { margin-top: 8px; }
.mod-case-block__shot { margin: 0; border-radius: 20px; overflow: hidden; background: transparent; }
.mod-case-block--shot { padding-block: 24px 48px; }
.mod-case-block--shot .mod-case-block__shot img {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 20px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.06);
}

.mod-case-block--grid4 .mod-case-block__head--center .mod-case-block__title {
    font-size: clamp(24px, 3.5vw, 36px);
}
.mod-case-block--grid4 .mod-case-block__grid4-text {
    font-size: 15px;
    line-height: 1.55;
}

.mod-case-block__approach {
    display: grid;
    grid-template-columns: minmax(200px, 300px) minmax(0, 1fr);
    gap: clamp(24px, 4vw, 40px);
    align-items: start;
}
.mod-case-block__approach-media {
    width: 100%;
    max-width: 300px;
}
.mod-case-block__approach-photo {
    margin: 0;
    border-radius: 20px;
    overflow: hidden;
    background: #1a1a1a;
    height: auto;
    min-height: 0;
}
.mod-case-block__approach-photo img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
    object-position: center top;
}
.mod-case-block__approach-card {
    background: #fff;
    border-radius: 20px;
    padding: clamp(28px, 4vw, 40px) clamp(24px, 3.5vw, 48px);
    box-sizing: border-box;
}
.mod-case-block__approach-card .mod-case-block__text {
    font-size: clamp(15px, 1.5vw, 17px);
    line-height: 1.65;
}
.mod-case-block__approach-card .mod-case-block__text p {
    margin: 0 0 20px;
}
.mod-case-block__approach-card .mod-case-block__text p:last-child {
    margin-bottom: 0;
}

.mod-case-block--review .mod-case-block__title {
    font-family: inherit;
    color: var(--dark);
    font-weight: 700;
    font-size: clamp(24px, 3vw, 32px);
}
.mod-case-block__review {
    margin: 0;
    border-radius: 24px;
    overflow: hidden;
    background: #1a1a1a;
    padding: clamp(24px, 4vw, 48px);
    box-sizing: border-box;
}
.mod-case-block__review img {
    display: block;
    width: 100%;
    max-width: 720px;
    margin-inline: auto;
    height: auto;
    border-radius: 12px;
}

.mod-case-block--flow4 { padding-block: 80px 100px; }
.mod-case-block--flow4 .mod-case-block__title {
    font-family: inherit;
    color: var(--dark);
    font-weight: 700;
    font-size: clamp(28px, 4vw, 47px);
    margin-bottom: clamp(48px, 8vw, 105px);
}
.mod-case-block__flow4 {
    display: flex;
    align-items: flex-start;
    gap: 0;
}
.mod-case-block__flow4-step {
    flex: 1 1 0;
    min-width: 0;
}
.mod-case-block__flow4-top {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
    min-height: 80px;
}
.mod-case-block__flow4-num {
    width: 80px;
    height: 80px;
    border-radius: 4px;
    background: var(--lime);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-flow);
    font-size: clamp(36px, 4vw, 48px);
    font-weight: 400;
    color: var(--purple);
    flex-shrink: 0;
    line-height: 1;
}
.mod-case-block__flow4-icon {
    margin: 0;
    width: 80px;
    height: 80px;
    flex-shrink: 0;
}
.mod-case-block__flow4-icon img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.mod-case-block__flow4-arrow {
    flex: 0 0 clamp(24px, 3vw, 40px);
    align-self: flex-start;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 80px;
    color: var(--purple);
}
.mod-case-block__flow4-arrow svg {
    display: block;
    width: 100%;
    height: auto;
    max-width: 40px;
}
.mod-case-block__flow4-text {
    margin: 0;
    text-align: center;
    font-size: 15px;
    line-height: 1.55;
    font-weight: 500;
    color: var(--dark);
}

.mod-case-intro__gallery--problem { display: block; }
.mod-case-intro__problem {
    display: grid;
    grid-template-columns: 1fr;
    align-items: stretch;
    margin-top: 16px;
}
.mod-case-intro__problem-back {
    grid-area: 1 / 1;
    justify-self: end;
    align-self: stretch;
    width: min(54%, 560px);
    min-height: clamp(280px, 32vw, 420px);
    border-radius: 20px;
    overflow: hidden;
    background: #5a6b3c;
}
.mod-case-intro__problem-back img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.mod-case-intro__problem-card {
    grid-area: 1 / 1;
    align-self: stretch;
    justify-self: start;
    width: min(60%, 620px);
    background: #fff;
    border-radius: 20px;
    padding: clamp(28px, 4vw, 40px) clamp(24px, 3.5vw, 48px);
    box-sizing: border-box;
    z-index: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: clamp(280px, 32vw, 420px);
}
.mod-case-intro__problem-title {
    margin: 0 0 12px;
    font-size: clamp(22px, 3vw, 28px);
    font-weight: 700;
    color: var(--dark);
}
.mod-case-intro__problem-line {
    display: block;
    width: 48px;
    height: 3px;
    border-radius: 2px;
    background: rgba(151, 71, 254, 0.6);
    margin-bottom: 20px;
    flex-shrink: 0;
}
.mod-case-intro__problem-text {
    margin: 0;
    font-size: clamp(16px, 1.6vw, 18px);
    line-height: 1.65;
    font-weight: 500;
    color: var(--dark);
}

.mod-case-gallery--slider { padding-block: 60px 80px; }
.mod-case-gallery__head--slider {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    margin-bottom: 40px;
}
.mod-case-gallery__head--slider .mod-case-gallery__title {
    font-size: clamp(28px, 4vw, 47px);
    font-weight: 600;
}
.mod-case-gallery__nav { display: flex; gap: 12px; flex-shrink: 0; }
.mod-case-gallery__nav-btn {
    width: 48px;
    height: 48px;
    border: 0;
    border-radius: 50%;
    background: var(--purple);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: opacity .2s ease;
}
.mod-case-gallery__nav-btn:hover { opacity: .85; }
.mod-case-gallery__slider-viewport {
    overflow: hidden;
    margin-inline: calc(-1 * var(--shell-pad, 20px));
    padding-inline: var(--shell-pad, 20px);
}
.mod-case-gallery__slider-track {
    display: flex;
    gap: 20px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding-bottom: 4px;
}
.mod-case-gallery__slider-track::-webkit-scrollbar { display: none; }
.mod-case-gallery__slider-slide {
    margin: 0;
    flex: 0 0 min(78%, 860px);
    scroll-snap-align: start;
    border-radius: 20px;
    overflow: hidden;
    background: #f3f3f3;
}
.mod-case-gallery__slider-slide img {
    display: block;
    width: 100%;
    height: auto;
}

.mod-case-gallery__head { margin-bottom: 28px; }
.mod-case-gallery__title { margin: 0; font-size: clamp(24px, 3vw, 32px); font-weight: 700; color: var(--dark); }
.mod-case-gallery__title-accent { font-family: var(--font-flow); color: var(--purple); font-weight: 400; }
.mod-case-gallery__subtitle { margin: 8px 0 0; font-size: clamp(18px, 2.5vw, 24px); font-weight: 700; color: var(--dark); }
.mod-case-intro__gallery--sphere .mod-case-intro__panel { border-radius: 20px; overflow: hidden; background: #3d5a32; }
.mod-case-intro__gallery--sphere .mod-case-intro__panel img { display: block; width: 100%; height: auto; }

.mod-faq--case { background: var(--bg); }
.mod-faq--case .mod-faq__item {
    background: var(--white);
    color: var(--dark);
}
.mod-faq--case .mod-faq__item[open],
.mod-faq--case .mod-faq__item.is-open {
    background: var(--purple);
    color: #fff;
}
.mod-faq--case .mod-faq__item[open] .mod-faq__question,
.mod-faq--case .mod-faq__item.is-open .mod-faq__question,
.mod-faq--case .mod-faq__item[open] .mod-faq__answer,
.mod-faq--case .mod-faq__item.is-open .mod-faq__answer {
    color: #fff;
}
.mod-faq--case .mod-faq__item:not([open]):not(.is-open) .mod-faq__toggle {
    background: var(--lime);
}
.mod-faq--case .mod-faq__item[open] .mod-faq__toggle,
.mod-faq--case .mod-faq__item.is-open .mod-faq__toggle {
    background: rgba(255, 255, 255, 0.2);
}

@media (max-width: 900px) {
    .mod-case-goal__layout { grid-template-columns: 1fr; }
    .mod-case-intro--unified { padding-block-start: 45px; }
    .mod-case-intro__head { align-items: flex-start; }
    .mod-case-intro__site { margin-top: 0; width: 100%; justify-content: center; }
    .mod-case-intro__gallery,
    .mod-case-intro__gallery--split { grid-template-columns: 1fr; }
    .mod-case-intro__shot--side { margin-top: 0; }
    .mod-case-tasks__grid { grid-template-columns: 1fr; }
    .mod-case-gallery--phones .mod-case-gallery__grid { grid-template-columns: 1fr; }
    .mod-case-story__gallery { grid-template-columns: 1fr; }
    .mod-case-story--flow .mod-case-story__figure--phone {
        width: min(100%, 389px);
    }
    .mod-case-gallery--mockup .mod-case-gallery__grid { grid-template-columns: 1fr; }
    .mod-case-gallery--mockup .mod-case-gallery__item--mobile { max-width: 320px; margin-inline: auto; }
    .mod-case-stats__grid { grid-template-columns: repeat(2, 1fr); }
    .mod-case-hero__promo-card { grid-template-columns: 1fr; min-height: 0; }
    .mod-case-hero__promo-art { justify-self: center; }
    .mod-case-block__before,
    .mod-case-block__split,
    .mod-case-block__card,
    .mod-case-block__grid4,
    .mod-case-block__approach,
    .mod-case-block__solution-section,
    .mod-case-block__solution-row { grid-template-columns: 1fr; }
    .mod-case-block__split--left .mod-case-block__split-media { order: 0; }
    .mod-case-block__split--right .mod-case-block__split-content { order: 0; }
    .mod-case-block__flow4 { flex-direction: column; align-items: stretch; }
    .mod-case-block__flow4-arrow { display: none; }
    .mod-case-intro__problem { display: flex; flex-direction: column; gap: 0; }
    .mod-case-intro__problem-back { width: 100%; min-height: 240px; margin-bottom: -40px; }
    .mod-case-intro__problem-card { width: 100%; min-height: 0; }
    .mod-case-gallery__head--slider { flex-direction: column; align-items: flex-start; }
    .mod-case-gallery__slider-slide { flex-basis: 88%; }
}
@media (max-width: 560px) {
    .mod-case-hero { padding-top: 48px; }
    .mod-case-stats__grid { grid-template-columns: 1fr; }
}
