:root {
    --gcub-ink: #07111f;
    --gcub-navy: #101f36;
    --gcub-blue: #1473f8;
    --gcub-lime: #c7ff4a;
    --gcub-paper: #f5f8fc;
    --gcub-line: rgba(16, 31, 54, .12);
    --gcub-muted: rgba(7, 17, 31, .66);
    --gcub-soft: rgba(255, 255, 255, .76);
    --gcub-shadow: 0 24px 70px rgba(16, 31, 54, .08);
    --gcub-shadow-hover: 0 32px 84px rgba(16, 31, 54, .13);
}

body {
    margin: 0;
    background: var(--gcub-paper);
}

.header.header--index {
    background: rgba(248, 251, 255, .78);
    border-bottom: 1px solid rgba(20, 115, 248, .13);
    box-shadow: 0 18px 46px rgba(16, 31, 54, .07);
    backdrop-filter: blur(22px) saturate(1.2);
}

.header.header--index .header__items {
    align-items: center;
}

.header.header--index .header__logo svg {
    width: 212px;
    height: auto;
}

.header.header--index .header__navbar {
    display: flex;
    flex: 1 1 auto;
    align-items: center;
    justify-content: flex-end;
    gap: 28px;
}

.header.header--index .header__navbar-list {
    gap: 34px;
}

.header.header--index .header__navbar-item > a {
    position: relative;
    color: rgba(16, 31, 54, .74);
    font-size: 13px;
    font-weight: 800;
    letter-spacing: .04em;
    transition: color .2s ease;
}

.header.header--index .header__navbar-item > a::after {
    content: "";
    position: absolute;
    right: 0;
    bottom: -12px;
    left: 0;
    height: 2px;
    border-radius: 2px;
    background: var(--gcub-blue);
    opacity: 0;
    transform: scaleX(.4);
    transform-origin: center;
    transition: opacity .2s ease, transform .2s ease;
}

.header.header--index .header__navbar-item:hover > a,
.header.header--index .header__navbar-item.active > a,
.header.header--index .header__navbar-item--active > a,
.header.header--index .header__navbar-item.selected > a,
.header.header--index .header__navbar-item.is-active > a {
    color: var(--gcub-blue);
}

.header.header--index .header__navbar-item:hover > a::after,
.header.header--index .header__navbar-item.active > a::after,
.header.header--index .header__navbar-item--active > a::after,
.header.header--index .header__navbar-item.selected > a::after,
.header.header--index .header__navbar-item.is-active > a::after {
    opacity: 1;
    transform: scaleX(1);
}

.header.header--index .header__navbar-number a {
    display: inline-flex;
    min-height: 44px;
    align-items: center;
    padding: 10px 14px;
    border: 1px solid rgba(16, 31, 54, .1);
    border-radius: 8px;
    color: rgba(16, 31, 54, .82);
    background: rgba(255, 255, 255, .42);
    font-size: 17px;
    font-weight: 900;
    line-height: 1;
    text-decoration: none;
    white-space: nowrap;
}

.header.header--index > .container > .header__items > .button {
    min-height: 52px;
    padding: 13px 26px;
    border: 0;
    border-radius: 8px;
    color: #fff;
    background: var(--gcub-blue);
    box-shadow: 0 16px 34px rgba(20, 115, 248, .24);
    font-weight: 900;
    line-height: 1.05;
    transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}

.header.header--index > .container > .header__items > .button:hover {
    transform: translateY(-1px);
    box-shadow: 0 20px 44px rgba(20, 115, 248, .28);
    background: #0f68e3;
}

.header.header--index .header__dropdown-wrapper {
    border: 1px solid rgba(16, 31, 54, .1);
    border-radius: 8px;
    background: rgba(255, 255, 255, .94);
    box-shadow: 0 26px 70px rgba(16, 31, 54, .14);
    backdrop-filter: blur(18px);
}

.main {
    color: var(--gcub-ink);
    background: var(--gcub-paper);
    overflow: hidden;
}

.main *,
.main *::before,
.main *::after {
    box-sizing: border-box;
}

.main .container {
    width: min(calc(100% - 64px), 1500px);
    max-width: none;
    margin-right: auto;
    margin-left: auto;
    padding-right: 0;
    padding-left: 0;
}

.main a:focus-visible,
.main button:focus-visible,
.main summary:focus-visible {
    outline: 3px solid rgba(20, 115, 248, .32);
    outline-offset: 4px;
}

.services-hub {
    position: relative;
    padding: 76px 0 84px;
    background:
        radial-gradient(circle at 16% 8%, rgba(20, 115, 248, .16), transparent 28%),
        radial-gradient(circle at 88% 22%, rgba(199, 255, 74, .2), transparent 30%),
        linear-gradient(115deg, rgba(20,115,248,.08), transparent 38%),
        linear-gradient(180deg, #f8fbff 0%, #eef4fb 100%);
}

.service-section-breadcrumbs {
    position: relative;
    z-index: 1;
    padding: 28px 0 0;
    background:
        radial-gradient(circle at 16% 8%, rgba(20, 115, 248, .15), transparent 28%),
        radial-gradient(circle at 86% 20%, rgba(199, 255, 74, .18), transparent 30%),
        linear-gradient(115deg, rgba(20,115,248,.07), transparent 38%),
        linear-gradient(180deg, #f8fbff 0%, #f8fbff 100%);
}

.service-section-breadcrumbs .breadcrumbs {
    margin: 0 !important;
    padding: 0 !important;
}

.service-section-breadcrumbs .breadcrumbs > .container {
    width: auto !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.service-section-breadcrumbs .breadcrumbs__items {
    display: flex !important;
    flex-wrap: wrap;
    align-items: center;
    gap: 0;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

.service-section-breadcrumbs .breadcrumbs__item {
    display: inline-flex;
    align-items: center;
    margin: 0 !important;
    padding: 0 !important;
    color: rgba(7, 17, 31, .48);
    font-size: 13px;
    line-height: 1.2;
    font-weight: 800;
    letter-spacing: .02em;
    list-style: none !important;
}

.service-section-breadcrumbs .breadcrumbs__item::marker {
    content: "";
}

.service-section-breadcrumbs .breadcrumbs__item:not(:last-child)::after {
    content: "";
    width: 6px;
    height: 6px;
    margin: 0 12px;
    border-top: 2px solid rgba(20, 115, 248, .34);
    border-right: 2px solid rgba(20, 115, 248, .34);
    transform: rotate(45deg);
}

.service-section-breadcrumbs .breadcrumbs__link,
.service-section-breadcrumbs .breadcrumbs__item a {
    color: rgba(7, 17, 31, .52) !important;
    text-decoration: none !important;
    transition: color .2s ease;
}

.service-section-breadcrumbs .breadcrumbs__link:hover,
.service-section-breadcrumbs .breadcrumbs__item a:hover {
    color: var(--gcub-blue) !important;
}

.service-section-breadcrumbs .breadcrumbs__item--active,
.service-section-breadcrumbs .breadcrumbs__item--active span {
    color: rgba(7, 17, 31, .72) !important;
}

.service-section-hero {
    position: relative;
    padding: 48px 0 86px;
    background:
        radial-gradient(circle at 16% 8%, rgba(20, 115, 248, .15), transparent 28%),
        radial-gradient(circle at 86% 20%, rgba(199, 255, 74, .18), transparent 30%),
        linear-gradient(115deg, rgba(20,115,248,.07), transparent 38%),
        linear-gradient(180deg, #f8fbff 0%, #eef4fb 100%);
}

.service-section-hero__grid {
    position: absolute;
    inset: 0;
    opacity: .36;
    background-image:
        linear-gradient(rgba(16,31,54,.055) 1px, transparent 1px),
        linear-gradient(90deg, rgba(16,31,54,.055) 1px, transparent 1px);
    background-size: 56px 56px;
    mask-image: linear-gradient(to bottom, #000, transparent 88%);
}

.service-section-hero .container {
    position: relative;
    z-index: 1;
}

.service-section-hero__head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 480px);
    gap: clamp(32px, 4vw, 64px);
    align-items: start;
}

.service-section-hero__title {
    max-width: 1020px;
    margin: 0;
    color: var(--gcub-ink);
    font-size: var(--gcub-type-h1, clamp(52px, 5vw, 80px));
    line-height: .98;
    font-weight: 900;
    letter-spacing: 0;
    text-wrap: balance;
}

.service-section-hero__summary p {
    max-width: 660px;
    margin: 0;
    color: var(--gcub-muted);
    font-size: 22px;
    line-height: 1.45;
    font-weight: 400;
    text-wrap: pretty;
}

.service-section-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 34px;
}

.service-section-hero__proof {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 22px;
}

.service-section-hero__proof span {
    display: inline-flex;
    min-height: 36px;
    align-items: center;
    padding: 9px 13px;
    border: 1px solid rgba(16,31,54,.1);
    border-radius: 8px;
    color: rgba(7,17,31,.62);
    background: rgba(255,255,255,.58);
    box-shadow: 0 12px 34px rgba(16,31,54,.045);
    font-size: 13px;
    line-height: 1.15;
    font-weight: 900;
}

.services-hub__grid {
    position: absolute;
    inset: 0;
    opacity: .38;
    background-image:
        linear-gradient(rgba(16,31,54,.055) 1px, transparent 1px),
        linear-gradient(90deg, rgba(16,31,54,.055) 1px, transparent 1px);
    background-size: 56px 56px;
    mask-image: linear-gradient(to bottom, #000, transparent 88%);
}

.services-hub .container {
    position: relative;
    z-index: 1;
}

.services-hub__breadcrumbs {
    margin-bottom: 44px;
}

.services-hub__breadcrumbs,
.services-hub__breadcrumbs a,
.services-hub__breadcrumbs span {
    color: rgba(16, 31, 54, .52) !important;
}

.services-hub__head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 480px);
    gap: clamp(32px, 4vw, 64px);
    align-items: start;
}

.services-hub__title {
    max-width: 980px;
    margin: 0;
    color: var(--gcub-ink);
    font-size: clamp(48px, 5.2vw, 78px);
    line-height: .98;
    font-weight: 900;
    letter-spacing: 0;
    text-wrap: balance;
}

.services-hub__summary p {
    min-width: 0;
    max-width: 610px;
    margin: 0;
    color: rgba(7, 17, 31, .68);
    font-size: 22px;
    line-height: 1.45;
    font-weight: 400;
    text-wrap: pretty;
}

.services-hub__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 32px;
}

.services-hub__button {
    display: inline-flex;
    min-height: 56px;
    align-items: center;
    justify-content: center;
    padding: 16px 24px;
    border: 1px solid transparent;
    border-radius: 8px;
    font: inherit;
    font-size: 16px;
    line-height: 1.15;
    font-weight: 900;
    text-decoration: none;
    cursor: pointer;
    transition: transform .2s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease, color .2s ease;
}

.services-hub__button:hover {
    transform: translateY(-2px);
}

.services-hub__button--primary {
    color: #fff;
    background: var(--gcub-blue);
    box-shadow: 0 18px 44px rgba(20, 115, 248, .2);
}

.services-hub__button--primary:hover {
    background: #0f68e3;
    box-shadow: 0 24px 58px rgba(20, 115, 248, .28);
}

.services-hub__button--ghost {
    color: var(--gcub-ink);
    border-color: rgba(16, 31, 54, .14);
    background: rgba(255,255,255,.7);
}

.services-hub__button--ghost:hover {
    border-color: rgba(20,115,248,.26);
    color: var(--gcub-blue);
    background: rgba(255,255,255,.9);
}

.services-hub__routes {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    margin: 62px 0 0;
    padding: 0;
    overflow: hidden;
    border: 1px solid rgba(16, 31, 54, .1);
    border-radius: 8px;
    background: rgba(255,255,255,.48);
    box-shadow: 0 24px 70px rgba(16,31,54,.08);
    backdrop-filter: blur(16px);
    list-style: none;
}

.services-hub__routes li {
    min-height: 108px;
    padding: 24px 22px;
    border-right: 1px solid rgba(16, 31, 54, .1);
    color: rgba(7, 17, 31, .72);
    font-size: 15px;
    line-height: 1.28;
    font-weight: 900;
}

.services-hub__routes li:last-child {
    border-right: 0;
}

.services-hub__routes span {
    display: block;
    margin-bottom: 14px;
    color: var(--gcub-blue);
}

.main .services {
    padding: 92px 0 112px;
    background: var(--gcub-paper);
}

.main .services__wrapper {
    display: grid !important;
    grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
    gap: 18px !important;
    margin: 0 !important;
}

.main .services__intro {
    display: grid;
    grid-template-columns: minmax(0, .58fr) minmax(360px, .42fr);
    gap: 40px;
    align-items: end;
    margin: 0 0 24px;
}

.main .services__intro span {
    color: var(--gcub-ink);
    font-size: clamp(38px, 4.4vw, 64px);
    line-height: 1;
    font-weight: 900;
    text-wrap: balance;
}

.main .services__intro p {
    max-width: 560px;
    margin: 0;
    color: var(--gcub-muted);
    font-size: 19px;
    line-height: 1.48;
    text-wrap: pretty;
}

.main .services__item {
    position: relative;
    display: flex !important;
    min-width: 0;
    grid-column: span 4;
    min-height: 310px;
    flex-direction: column;
    justify-content: space-between !important;
    gap: 0 !important;
    overflow: hidden;
    padding: 30px;
    border: 1px solid rgba(16, 31, 54, .11);
    border-radius: 8px !important;
    color: var(--gcub-ink);
    background: #fff;
    box-shadow: none !important;
    text-decoration: none;
    isolation: isolate;
    transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease, background .22s ease;
}

.main .services__item::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    background: linear-gradient(135deg, rgba(20,115,248,.08), transparent 42%);
    opacity: 0;
    transition: opacity .22s ease;
}

.main .services__item:first-child {
    grid-column: span 8;
    min-height: 390px;
    color: #fff;
    background:
        linear-gradient(135deg, rgba(20,115,248,.95), rgba(31,216,143,.84)),
        var(--gcub-blue);
}

.main .services__item:hover {
    border-color: rgba(20, 115, 248, .22);
    box-shadow: var(--gcub-shadow-hover) !important;
    transform: translateY(-4px);
}

.main .services__item:hover::before {
    opacity: 1;
}

.main .services__item-text {
    position: relative;
    z-index: 1;
    display: flex;
    min-width: 0;
    min-height: 100%;
    max-width: none !important;
    flex: 1 1 auto;
    flex-direction: column;
    padding: 0 !important;
}

.main .services__item-title {
    min-width: 0;
    max-width: 520px;
    margin: 0 0 18px !important;
    color: inherit;
    font-size: var(--gcub-type-h3, clamp(26px, 2.25vw, 34px)) !important;
    line-height: 1.04 !important;
    font-weight: 900 !important;
    overflow-wrap: anywhere;
    text-wrap: balance;
}

.main .services__item:not(:first-child) .services__item-title {
    max-width: 360px;
    font-size: var(--gcub-type-h3, clamp(26px, 2.25vw, 34px)) !important;
}

.main .services__item-description {
    min-width: 0;
    max-width: 560px;
    margin: 0 !important;
    color: var(--gcub-muted);
    font-size: 17px !important;
    line-height: 1.45 !important;
    font-weight: 400 !important;
    overflow-wrap: anywhere;
    text-wrap: pretty;
}

.main .services__item:first-child .services__item-description {
    color: rgba(255,255,255,.78);
}

.main .services__item-arrow {
    position: static !important;
    display: inline-flex;
    width: fit-content;
    margin-top: auto;
    padding-top: 34px;
    color: var(--gcub-blue);
    transition: transform .2s ease;
}

.main .services__item:first-child .services__item-arrow {
    color: #fff;
}

.main .services__item:hover .services__item-arrow {
    transform: translateX(8px) !important;
}

.main .services__img-wrapper {
    position: absolute;
    right: -18px;
    bottom: -18px;
    z-index: 0;
    display: block !important;
    max-width: 220px !important;
    opacity: .2;
    pointer-events: none;
}

.main .services__item:first-child .services__img-wrapper {
    right: 22px;
    bottom: 12px;
    max-width: 330px !important;
    opacity: .28;
}

.main .services__img-wrapper img {
    max-height: 260px !important;
    object-fit: contain;
}

.main .service-section-hero + .services {
    padding: 82px 0 88px;
    background:
        linear-gradient(180deg, #eef4fb 0%, var(--gcub-paper) 24%, var(--gcub-paper) 100%);
}

.main .service-section-hero + .services .services__wrapper {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 20px !important;
}

.main .service-section-hero + .services .services__item,
.main .service-section-hero + .services .services__item:first-child {
    grid-column: auto;
    min-height: 352px;
    padding: 36px;
    color: var(--gcub-ink);
    background:
        radial-gradient(circle at 92% 12%, rgba(20,115,248,.075), transparent 28%),
        var(--gcub-soft);
    box-shadow: var(--gcub-shadow) !important;
    backdrop-filter: blur(14px);
}

.main .service-section-hero + .services .services__item:first-child {
    border-color: rgba(20,115,248,.2);
    background:
        radial-gradient(circle at 88% 12%, rgba(199,255,74,.28), transparent 34%),
        linear-gradient(135deg, rgba(20,115,248,.14), rgba(255,255,255,.9));
}

.main .service-section-hero + .services .services__item-title,
.main .service-section-hero + .services .services__item:not(:first-child) .services__item-title {
    max-width: 560px;
    font-size: var(--gcub-type-h3, clamp(26px, 2.25vw, 34px)) !important;
}

.main .service-section-hero + .services .services__item:first-child .services__item-description {
    color: rgba(7, 17, 31, .64);
}

.main .service-section-hero + .services .services__item-arrow {
    align-items: center;
    gap: 14px;
    color: var(--gcub-blue);
    font-size: 16px;
    font-weight: 900;
    text-decoration: none;
}

.main .service-section-hero + .services .services__item-arrow::before {
    content: "Подробнее";
}

.main .service-section-hero + .services .services__img-wrapper,
.main .service-section-hero + .services .services__item:first-child .services__img-wrapper {
    right: 18px;
    bottom: 10px;
    max-width: 210px !important;
    opacity: .16;
}

.service-seo {
    padding: 0 0 92px;
    background:
        radial-gradient(circle at 12% 28%, rgba(20,115,248,.08), transparent 26%),
        var(--gcub-paper);
}

.service-showcase {
    position: relative;
    padding: 96px 0;
    color: #fff;
    background:
        radial-gradient(circle at 84% 12%, rgba(199,255,74,.2), transparent 30%),
        radial-gradient(circle at 12% 78%, rgba(20,115,248,.34), transparent 34%),
        linear-gradient(135deg, #081326 0%, #101f36 100%);
}

.service-showcase::before {
    content: "";
    position: absolute;
    inset: 0;
    opacity: .18;
    background-image:
        linear-gradient(rgba(255,255,255,.11) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.11) 1px, transparent 1px);
    background-size: 56px 56px;
    mask-image: linear-gradient(to bottom, #000, transparent 92%);
    pointer-events: none;
}

.service-showcase .container {
    position: relative;
    z-index: 1;
}

.service-showcase__head {
    display: grid;
    grid-template-columns: minmax(0, .98fr) minmax(360px, .62fr);
    gap: 56px;
    align-items: end;
    margin-bottom: 30px;
}

.service-showcase__head h2 {
    max-width: 960px;
    margin: 0;
    color: #fff;
    font-size: var(--gcub-type-h2-inner, clamp(34px, 3.4vw, 50px));
    line-height: 1;
    font-weight: 900;
    text-wrap: balance;
}

.service-showcase__head p {
    max-width: 620px;
    margin: 0;
    color: rgba(255,255,255,.68);
    font-size: 20px;
    line-height: 1.48;
    text-wrap: pretty;
}

.service-showcase__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.service-showcase__card {
    position: relative;
    display: flex;
    min-height: 350px;
    flex-direction: column;
    padding: 30px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 8px;
    color: #fff;
    background: rgba(255,255,255,.07);
    box-shadow: 0 28px 90px rgba(0,0,0,.18);
    text-decoration: none;
    backdrop-filter: blur(18px);
    transition: transform .22s ease, border-color .22s ease, background .22s ease, box-shadow .22s ease;
}

.service-showcase__card::after {
    content: "";
    position: absolute;
    inset: auto -20% -38% -20%;
    height: 58%;
    background: radial-gradient(circle, rgba(20,115,248,.32), transparent 62%);
    opacity: 0;
    transition: opacity .22s ease;
}

.service-showcase__card:hover {
    border-color: rgba(199,255,74,.36);
    background: rgba(255,255,255,.1);
    box-shadow: 0 34px 100px rgba(0,0,0,.24);
    transform: translateY(-5px);
}

.service-showcase__card:hover::after {
    opacity: 1;
}

.service-showcase__tag {
    position: relative;
    z-index: 1;
    display: inline-flex;
    width: fit-content;
    min-height: 34px;
    align-items: center;
    margin-bottom: 44px;
    padding: 8px 11px;
    border-radius: 8px;
    color: var(--gcub-lime);
    background: rgba(199,255,74,.1);
    font-size: 13px;
    line-height: 1;
    font-weight: 900;
}

.service-showcase__card h3 {
    position: relative;
    z-index: 1;
    margin: 0 0 16px;
    color: #fff;
    font-size: var(--gcub-type-h3, clamp(26px, 2.25vw, 34px));
    line-height: 1.08;
    font-weight: 900;
    text-wrap: balance;
}

.service-showcase__card p {
    position: relative;
    z-index: 1;
    max-width: 520px;
    margin: 0;
    color: rgba(255,255,255,.7);
    font-size: 17px;
    line-height: 1.45;
}

.service-showcase__facts {
    position: relative;
    z-index: 1;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: auto;
    padding-top: 34px;
}

.service-showcase__facts span {
    display: inline-flex;
    min-height: 30px;
    align-items: center;
    padding: 7px 10px;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 8px;
    color: rgba(255,255,255,.74);
    font-size: 12px;
    line-height: 1;
    font-weight: 900;
}

.service-showcase__note {
    display: grid;
    grid-template-columns: minmax(0, .34fr) minmax(0, .66fr);
    gap: 28px;
    align-items: center;
    margin-top: 18px;
    padding: 28px 30px;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 8px;
    background: rgba(255,255,255,.06);
}

.service-showcase__note span {
    color: var(--gcub-lime);
    font-size: 18px;
    line-height: 1.1;
    font-weight: 900;
}

.service-showcase__note p {
    max-width: 920px;
    margin: 0;
    color: rgba(255,255,255,.72);
    font-size: 18px;
    line-height: 1.45;
}

.service-seo__head {
    display: grid;
    grid-template-columns: minmax(0, .92fr) minmax(360px, .78fr);
    gap: 56px;
    align-items: end;
    margin-bottom: 28px;
    padding-top: 32px;
    border-top: 1px solid rgba(16,31,54,.1);
}

.service-seo__head h2,
.service-faq h2 {
    margin: 0;
    color: var(--gcub-ink);
    font-size: clamp(42px, 4.4vw, 68px);
    line-height: 1;
    font-weight: 900;
    letter-spacing: 0;
    text-wrap: balance;
}

.service-seo__head p {
    max-width: 690px;
    margin: 0;
    color: var(--gcub-muted);
    font-size: 20px;
    line-height: 1.48;
    text-wrap: pretty;
}

.service-seo__grid {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, .95fr) minmax(0, .95fr);
    gap: 20px;
}

.service-seo__card {
    min-height: 280px;
    padding: 32px;
    border: 1px solid rgba(16,31,54,.1);
    border-radius: 8px;
    background: var(--gcub-soft);
    box-shadow: var(--gcub-shadow);
    backdrop-filter: blur(12px);
    transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.service-seo__card:hover {
    border-color: rgba(20,115,248,.2);
    box-shadow: var(--gcub-shadow-hover);
    transform: translateY(-3px);
}

.service-seo__card--wide {
    background:
        radial-gradient(circle at 88% 12%, rgba(199,255,74,.34), transparent 34%),
        linear-gradient(135deg, rgba(20,115,248,.1), rgba(255,255,255,.82));
}

.service-seo__card span {
    display: inline-flex;
    min-height: 34px;
    align-items: center;
    margin-bottom: 30px;
    padding: 8px 11px;
    border: 1px solid rgba(20,115,248,.16);
    border-radius: 8px;
    color: var(--gcub-blue);
    background: rgba(20,115,248,.06);
    font-size: 14px;
    line-height: 1;
    font-weight: 900;
}

.service-seo__card h3 {
    max-width: 520px;
    margin: 0 0 18px;
    color: var(--gcub-ink);
    font-size: clamp(28px, 2.7vw, 36px);
    line-height: 1.05;
    font-weight: 900;
    text-wrap: balance;
}

.service-seo__card p {
    max-width: 570px;
    margin: 0;
    color: var(--gcub-muted);
    font-size: 17px;
    line-height: 1.46;
    text-wrap: pretty;
}

.service-faq {
    padding: 0 0 112px;
    background: var(--gcub-paper);
}

.service-faq h2 {
    max-width: 980px;
    margin-bottom: 28px;
}

.service-faq__list {
    display: grid;
    gap: 14px;
}

.service-faq details {
    overflow: hidden;
    border: 1px solid rgba(16,31,54,.1);
    border-radius: 8px;
    background: var(--gcub-soft);
    box-shadow: 0 16px 48px rgba(16,31,54,.045);
    transition: border-color .2s ease, box-shadow .2s ease;
}

.service-faq details:hover,
.service-faq details[open] {
    border-color: rgba(20,115,248,.2);
    box-shadow: var(--gcub-shadow);
}

.service-faq summary {
    position: relative;
    display: block;
    padding: 26px 72px 26px 28px;
    color: var(--gcub-ink);
    font-size: 24px;
    line-height: 1.2;
    font-weight: 900;
    cursor: pointer;
    list-style: none;
}

.service-faq summary::-webkit-details-marker {
    display: none;
}

.service-faq summary::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 30px;
    width: 14px;
    height: 14px;
    border-right: 3px solid var(--gcub-blue);
    border-bottom: 3px solid var(--gcub-blue);
    transform: translateY(-62%) rotate(45deg);
    transition: transform .2s ease;
}

.service-faq details[open] summary::after {
    transform: translateY(-28%) rotate(225deg);
}

.service-faq details p {
    max-width: 960px;
    margin: -8px 72px 28px 28px;
    color: rgba(7, 17, 31, .66);
    font-size: 19px;
    line-height: 1.5;
}

.footer {
    margin-top: 0;
}

@media (max-width: 1180px) {
    .services-hub__head {
        grid-template-columns: 1fr;
        gap: 26px;
    }

    .service-section-hero__head {
        grid-template-columns: 1fr;
        gap: 30px;
    }

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

    .services-hub__routes li {
        border-bottom: 1px solid rgba(16, 31, 54, .1);
    }

    .services-hub__routes li:nth-child(2n) {
        border-right: 0;
    }

    .main .services__wrapper {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .main .services__item,
    .main .services__item:first-child {
        grid-column: auto;
        min-height: 300px;
    }

    .main .service-section-hero + .services .services__item:first-child {
        grid-column: auto;
        min-height: 300px;
    }

    .main .services__intro {
        grid-template-columns: 1fr;
        gap: 18px;
    }

    .main .service-section-hero + .services .services__wrapper {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .service-seo__head {
        grid-template-columns: 1fr;
        gap: 22px;
    }

    .service-showcase__head {
        grid-template-columns: 1fr;
        gap: 22px;
    }

    .service-showcase__grid {
        grid-template-columns: 1fr;
    }

    .service-showcase__card {
        min-height: 300px;
    }

    .service-showcase__note {
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .service-seo__grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 900px) {
    .main .service-section-hero + .services .services__wrapper {
        grid-template-columns: 1fr !important;
    }

    .main .service-section-hero + .services .services__item,
    .main .service-section-hero + .services .services__item:first-child {
        min-height: 280px;
    }
}

@media (max-width: 720px) {
    html,
    body {
        max-width: 100%;
        overflow-x: hidden;
    }

    .header.header--index {
        background: #f5f8fc;
    }

    .header.header--index.header--fixed {
        height: 72px !important;
        padding: 0 !important;
        background: rgba(245,248,252,.94) !important;
    }

    .header.header--index.header--fixed .header__items {
        height: 72px !important;
        align-items: center !important;
    }

    .header.header--index .header__logo {
        display: block !important;
        opacity: 1;
    }

    .header.header--index .header__mobile-logo {
        display: none !important;
    }

    .header.header--index > .container .button {
        display: none;
    }

    .header.header--index .header__navbar {
        display: none !important;
    }

    .header.header--index .header__logo svg {
        width: 164px;
        max-width: 42vw;
    }

    .header.header--index .header__mobile-sidebar {
        display: flex !important;
        align-items: center;
        justify-content: center;
        right: 12px;
        left: auto;
        top: 16px !important;
        width: auto;
        min-width: 54px;
        padding: 7px 10px;
        border: 1px solid rgba(16,31,54,.1);
        border-radius: 8px;
        background: rgba(255,255,255,.9);
        box-shadow: 0 14px 34px rgba(16,31,54,.16);
        backdrop-filter: blur(14px);
    }

    .header.header--index .header__mobile-sidebar .header__menu-button {
        display: flex;
    }

    .header.header--index .header__mobile-sidebar .header__submit-button,
    .header.header--index .header__mobile-sidebar .header__whatsapp-button,
    .header.header--index .header__mobile-sidebar .header__call-button {
        display: none;
    }

    .services-hub {
        padding: 44px 0 52px;
        overflow: hidden;
    }

    .service-section-hero {
        padding: 42px 0 48px;
        overflow: hidden;
    }

    .main .container {
        width: min(calc(100% - 32px), 1500px);
    }

    .services-hub__breadcrumbs {
        display: none;
    }

    .service-section-breadcrumbs {
        display: none;
    }

    .services-hub__title {
        max-width: 100%;
        font-size: 38px;
        line-height: 1;
        overflow-wrap: anywhere;
    }

    .service-section-hero__title {
        max-width: 100%;
        font-size: var(--gcub-type-h1-mobile, clamp(34px, 10vw, 44px));
        line-height: 1.02;
        overflow-wrap: anywhere;
    }

    .services-hub__summary p {
        max-width: 100%;
        font-size: 18px;
        overflow-wrap: anywhere;
    }

    .service-section-hero__summary p {
        max-width: 100%;
        font-size: 18px;
        line-height: 1.44;
        overflow-wrap: anywhere;
    }

    .services-hub__actions {
        flex-direction: column;
        margin-top: 28px;
    }

    .service-section-hero__actions {
        flex-direction: column;
        margin-top: 24px;
    }

    .services-hub__button {
        width: 100%;
        min-height: 54px;
    }

    .service-section-hero__proof {
        gap: 8px;
        margin-top: 18px;
    }

    .service-section-hero__proof span {
        width: 100%;
        min-height: 34px;
        justify-content: center;
        text-align: center;
    }

    .services-hub__routes {
        grid-template-columns: 1fr;
        margin-top: 32px;
    }

    .services-hub__routes li {
        min-height: 0;
        padding: 17px 18px;
        border-right: 0;
        border-bottom: 1px solid rgba(16, 31, 54, .1);
    }

    .services-hub__routes li:last-child {
        border-bottom: 0;
    }

    .services-hub__routes span {
        display: inline;
        margin: 0 12px 0 0;
    }

    .main .services {
        padding: 44px 0 64px;
        overflow: hidden;
    }

    .main .services__wrapper {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
        width: 100% !important;
        min-width: 0 !important;
    }

    .main .services__item,
    .main .services__item:first-child {
        min-height: 0;
        padding: 22px;
    }

    .main .services__item-title,
    .main .services__item:not(:first-child) .services__item-title {
        margin-bottom: 12px !important;
        font-size: var(--gcub-type-h3-mobile, clamp(23px, 6.2vw, 28px)) !important;
    }

    .main .services__item-description {
        font-size: 15px !important;
        line-height: 1.4 !important;
    }

    .main .services__item-arrow {
        padding-top: 24px;
    }

    .main .services__img-wrapper {
        display: none !important;
    }

    .main .service-section-hero + .services {
        padding: 44px 0 56px;
    }

    .main .services__intro {
        margin-bottom: 18px;
    }

    .main .services__intro span {
        font-size: 34px;
    }

    .main .services__intro p {
        font-size: 16px;
        line-height: 1.45;
    }

    .main .service-section-hero + .services .services__item,
    .main .service-section-hero + .services .services__item:first-child {
        min-height: 0;
        padding: 24px;
        box-shadow: 0 14px 42px rgba(16,31,54,.055) !important;
    }

    .main .service-section-hero + .services .services__item-title,
    .main .service-section-hero + .services .services__item:not(:first-child) .services__item-title {
        font-size: var(--gcub-type-h3-mobile, clamp(23px, 6.2vw, 28px)) !important;
        line-height: 1.07 !important;
    }

    .main .service-section-hero + .services .services__item-arrow {
        padding-top: 26px;
    }

    .service-seo {
        padding: 0 0 58px;
    }

    .service-showcase {
        padding: 58px 0;
    }

    .service-showcase__head {
        margin-bottom: 18px;
    }

    .service-showcase__head h2 {
        font-size: var(--gcub-type-h2-inner-mobile, clamp(29px, 7.8vw, 34px));
    }

    .service-showcase__head p {
        font-size: 17px;
        line-height: 1.45;
    }

    .service-showcase__grid {
        gap: 12px;
    }

    .service-showcase__card {
        min-height: 0;
        padding: 24px;
    }

    .service-showcase__tag {
        margin-bottom: 28px;
    }

    .service-showcase__card h3 {
        font-size: var(--gcub-type-h3-mobile, clamp(23px, 6.2vw, 28px));
    }

    .service-showcase__card p {
        font-size: 15px;
    }

    .service-showcase__facts {
        padding-top: 28px;
    }

    .service-showcase__note {
        margin-top: 12px;
        padding: 22px;
    }

    .service-showcase__note p {
        font-size: 16px;
    }

    .service-seo__head {
        margin-bottom: 18px;
        padding-top: 24px;
    }

    .service-seo__head h2,
    .service-faq h2 {
        font-size: 36px;
    }

    .service-seo__head p {
        font-size: 17px;
        line-height: 1.45;
    }

    .service-seo__card {
        min-height: 0;
        padding: 24px;
        box-shadow: 0 14px 42px rgba(16,31,54,.055);
    }

    .service-seo__card span {
        margin-bottom: 22px;
    }

    .service-seo__card h3 {
        font-size: 28px;
    }

    .service-seo__card p {
        font-size: 15px;
    }

    .service-faq {
        padding: 0 0 76px;
    }

    .service-faq h2 {
        margin-bottom: 18px;
    }

    .service-faq summary {
        padding: 22px 56px 22px 20px;
        font-size: 20px;
    }

    .service-faq summary::after {
        right: 22px;
        width: 12px;
        height: 12px;
    }

    .service-faq details p {
        margin: -4px 20px 22px;
        font-size: 16px;
    }
}

@media (max-width: 420px) {
    .services-hub__title {
        font-size: 36px;
    }

    .service-section-hero__title {
        font-size: var(--gcub-type-h1-mobile, clamp(34px, 10vw, 44px));
    }

    .service-seo__head h2,
    .service-faq h2,
    .service-showcase__head h2 {
        font-size: var(--gcub-type-h2-inner-mobile, clamp(29px, 7.8vw, 34px));
    }
}

/* Services typography lock */
.service-section-hero__title,
.services-hub__title,
.service-detail-hero__title {
    font-size: var(--gcub-type-h1, clamp(52px, 5vw, 80px)) !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    letter-spacing: 0 !important;
    text-wrap: balance;
}

.service-showcase__head h2,
.service-seo__head h2,
.service-faq h2,
.service-detail-page .services-detail__slogan,
.service-detail-page .services-detail__section-head h2,
.service-detail-page .services-detail__wrapper-title,
.service-detail-page .service-price-head h2,
.service-detail-page .service-growth__head h2 {
    font-size: var(--gcub-type-h2-inner, clamp(34px, 3.4vw, 50px)) !important;
    line-height: 1.04 !important;
    font-weight: 900 !important;
    letter-spacing: 0 !important;
    text-wrap: balance;
}

.main .services__item-title,
.main .services__item:not(:first-child) .services__item-title,
.main .service-section-hero + .services .services__item-title,
.main .service-section-hero + .services .services__item:not(:first-child) .services__item-title,
.service-showcase__card h3,
.service-seo__card h3,
.service-detail-page .services-detail__advantages-item h3,
.service-detail-page .services-detail__prices-item h3,
.service-detail-page .service-growth__card h3,
.service-detail-page .service-growth__outcomes h3,
.service-detail-page .accordion__header-title {
    font-size: var(--gcub-type-h3, clamp(26px, 2.25vw, 34px)) !important;
    line-height: 1.1 !important;
    font-weight: 900 !important;
    letter-spacing: 0 !important;
    text-wrap: balance;
}

.service-detail-page .accordion__body-title,
.service-detail-page .services-detail__your-rewards-item-title {
    font-size: var(--gcub-type-h4, clamp(22px, 1.55vw, 26px)) !important;
    line-height: 1.16 !important;
    font-weight: 900 !important;
    letter-spacing: 0 !important;
    text-wrap: balance;
}

@media (max-width: 767px) {
    .service-section-hero__title,
    .services-hub__title,
    .service-detail-hero__title {
        font-size: var(--gcub-type-h1-mobile, clamp(34px, 10vw, 44px)) !important;
        line-height: 1.04 !important;
    }

    .service-showcase__head h2,
    .service-seo__head h2,
    .service-faq h2,
    .service-detail-page .services-detail__slogan,
    .service-detail-page .services-detail__section-head h2,
    .service-detail-page .services-detail__wrapper-title,
    .service-detail-page .service-price-head h2,
    .service-detail-page .service-growth__head h2 {
        font-size: var(--gcub-type-h2-inner-mobile, clamp(29px, 7.8vw, 34px)) !important;
        line-height: 1.08 !important;
    }

    .main .services__item-title,
    .main .services__item:not(:first-child) .services__item-title,
    .main .service-section-hero + .services .services__item-title,
    .main .service-section-hero + .services .services__item:not(:first-child) .services__item-title,
    .service-showcase__card h3,
    .service-seo__card h3,
    .service-detail-page .services-detail__advantages-item h3,
    .service-detail-page .services-detail__prices-item h3,
    .service-detail-page .service-growth__card h3,
    .service-detail-page .service-growth__outcomes h3,
    .service-detail-page .accordion__header-title {
        font-size: var(--gcub-type-h3-mobile, clamp(23px, 6.2vw, 28px)) !important;
        line-height: 1.12 !important;
    }

    .service-detail-page .accordion__body-title,
    .service-detail-page .services-detail__your-rewards-item-title {
        font-size: var(--gcub-type-h4-mobile, clamp(20px, 5.2vw, 24px)) !important;
        line-height: 1.16 !important;
    }
}

/* Services design-system pass: this file is loaded after site-polish.css. */
.main .container {
    width: min(calc(100% - 64px), 1500px);
}

.service-section-hero,
.service-detail-hero {
    padding-top: clamp(56px, 5.2vw, 88px) !important;
    padding-bottom: clamp(64px, 5.8vw, 96px) !important;
}

.service-section-hero__title,
.services-hub__title,
.service-detail-hero__title {
    font-size: var(--gcub-type-h1, clamp(38px, 3.4vw, 56px)) !important;
    line-height: 1.04 !important;
    letter-spacing: 0 !important;
    font-weight: 900 !important;
    text-wrap: balance;
}

.service-section-hero__summary p,
.service-detail-hero__text {
    font-size: var(--gcub-type-body-lg, 19px) !important;
    line-height: 1.45 !important;
    color: var(--gcub-color-muted, rgba(7, 17, 31, .62)) !important;
}

.services-hub,
.service-showcase,
.service-seo,
.service-detail-page .services-detail,
.service-detail-page .services-detail__advantages,
.service-detail-page .services-detail__prices,
.service-detail-page .services-detail__your-rewards,
.service-detail-page .service-growth,
.service-detail-page .accordion {
    padding-top: var(--gcub-section-y, 96px) !important;
    padding-bottom: var(--gcub-section-y, 96px) !important;
}

.service-showcase__head h2,
.service-seo__head h2,
.service-faq h2,
.service-detail-page .services-detail__slogan,
.service-detail-page .services-detail__section-head h2,
.service-detail-page .services-detail__wrapper-title,
.service-detail-page .service-price-head h2,
.service-detail-page .service-growth__head h2 {
    font-size: var(--gcub-type-h2, clamp(30px, 2.8vw, 42px)) !important;
    line-height: 1.06 !important;
    letter-spacing: 0 !important;
    font-weight: 900 !important;
    text-wrap: balance;
}

.main .services__item-title,
.main .services__item:not(:first-child) .services__item-title,
.main .service-section-hero + .services .services__item-title,
.main .service-section-hero + .services .services__item:not(:first-child) .services__item-title,
.service-showcase__card h3,
.service-seo__card h3,
.service-detail-page .services-detail__advantages-item h3,
.service-detail-page .services-detail__advantages-item:first-child h3,
.service-detail-page .services-detail__advantages-wrapper > .services-detail__advantages-item--wide h3,
.service-detail-page .services-detail__prices-item h3,
.service-detail-page .service-growth__card h3,
.service-detail-page .service-growth__card--accent h3,
.service-detail-page .service-growth__outcomes h3,
.service-detail-page .accordion__header-title {
    font-size: var(--gcub-type-h3, clamp(23px, 1.8vw, 29px)) !important;
    line-height: 1.1 !important;
    letter-spacing: 0 !important;
    font-weight: 900 !important;
    text-wrap: balance;
}

.service-detail-page .accordion__body-title,
.service-detail-page .services-detail__your-rewards-item-title {
    font-size: var(--gcub-type-h4, clamp(20px, 1.35vw, 22px)) !important;
    line-height: 1.16 !important;
}

.services__item,
.service-showcase__card,
.service-seo__card,
.service-detail-page .services-detail__advantages-item,
.service-detail-page .services-detail__prices-item,
.service-detail-page .services-detail__your-rewards-item,
.service-detail-page .service-growth__card,
.service-detail-page .service-growth__outcomes,
.service-detail-page .service-growth__local,
.service-detail-page .accordion__item {
    border-radius: var(--gcub-radius-md, 8px) !important;
}

.service-detail-page .services-detail__advantages-item,
.service-detail-page .services-detail__prices-item,
.service-detail-page .services-detail__your-rewards-item,
.service-detail-page .service-growth__card,
.service-detail-page .service-growth__outcomes,
.service-detail-page .service-growth__local {
    padding: var(--gcub-card-pad, 32px) !important;
}

@media (max-width: 767px) {
    .main .container {
        width: min(calc(100% - 32px), 1500px);
    }

    .service-section-hero,
    .service-detail-hero {
        padding-top: 40px !important;
        padding-bottom: 56px !important;
    }

    .service-section-hero__title,
    .services-hub__title,
    .service-detail-hero__title {
        font-size: var(--gcub-type-h1-mobile, clamp(30px, 8vw, 36px)) !important;
        line-height: 1.06 !important;
    }

    .service-section-hero__summary p,
    .service-detail-hero__text {
        font-size: var(--gcub-type-body-mobile, 16px) !important;
        line-height: 1.5 !important;
    }

    .services-hub,
    .service-showcase,
    .service-seo,
    .service-detail-page .services-detail,
    .service-detail-page .services-detail__advantages,
    .service-detail-page .services-detail__prices,
    .service-detail-page .services-detail__your-rewards,
    .service-detail-page .service-growth,
    .service-detail-page .accordion {
        padding-top: var(--gcub-section-y, 64px) !important;
        padding-bottom: var(--gcub-section-y, 64px) !important;
    }

    .service-showcase__head h2,
    .service-seo__head h2,
    .service-faq h2,
    .service-detail-page .services-detail__slogan,
    .service-detail-page .services-detail__section-head h2,
    .service-detail-page .services-detail__wrapper-title,
    .service-detail-page .service-price-head h2,
    .service-detail-page .service-growth__head h2 {
        font-size: var(--gcub-type-h2-mobile, clamp(26px, 7vw, 31px)) !important;
        line-height: 1.08 !important;
    }

    .main .services__item-title,
    .main .services__item:not(:first-child) .services__item-title,
    .main .service-section-hero + .services .services__item-title,
    .main .service-section-hero + .services .services__item:not(:first-child) .services__item-title,
    .service-showcase__card h3,
    .service-seo__card h3,
    .service-detail-page .services-detail__advantages-item h3,
    .service-detail-page .services-detail__advantages-item:first-child h3,
    .service-detail-page .services-detail__advantages-wrapper > .services-detail__advantages-item--wide h3,
    .service-detail-page .services-detail__prices-item h3,
    .service-detail-page .service-growth__card h3,
    .service-detail-page .service-growth__card--accent h3,
    .service-detail-page .service-growth__outcomes h3,
    .service-detail-page .accordion__header-title {
        font-size: var(--gcub-type-h3-mobile, clamp(22px, 5.8vw, 25px)) !important;
        line-height: 1.12 !important;
    }

    .service-detail-page .services-detail__advantages-item,
    .service-detail-page .services-detail__prices-item,
    .service-detail-page .services-detail__your-rewards-item,
    .service-detail-page .service-growth__card,
    .service-detail-page .service-growth__outcomes,
    .service-detail-page .service-growth__local {
        padding: var(--gcub-card-pad, 24px) !important;
    }
}

/* Services final rhythm layer: all service pages share one premium density. */
.main .container,
.service-section-hero .container,
.services-hub .container,
.service-showcase .container,
.service-seo .container,
.service-detail-page .container {
    width: min(calc(100% - var(--gcub-gutter, 64px)), var(--gcub-container, 1500px)) !important;
    max-width: var(--gcub-container, 1500px) !important;
}

.service-section-hero,
.service-detail-hero {
    padding-top: 64px !important;
    padding-bottom: 96px !important;
}

.service-section-hero__grid,
.service-detail-hero__grid {
    gap: 64px !important;
    align-items: center !important;
}

.service-section-hero__title,
.services-hub__title,
.service-detail-hero__title {
    font-size: var(--gcub-type-h1, clamp(36px, 3.25vw, 52px)) !important;
    line-height: 1.04 !important;
}

.service-section-hero__summary p,
.service-detail-hero__text {
    max-width: 720px;
    font-size: var(--gcub-type-body-lg, 18px) !important;
    line-height: 1.5 !important;
}

.service-section-hero__actions,
.service-detail-hero__actions {
    margin-top: 32px !important;
    gap: 16px !important;
}

.services-hub,
.service-showcase,
.service-seo,
.service-detail-page .services-detail,
.service-detail-page .services-detail__advantages,
.service-detail-page .services-detail__prices,
.service-detail-page .services-detail__your-rewards,
.service-detail-page .service-growth,
.service-detail-page .accordion {
    padding-top: 96px !important;
    padding-bottom: 96px !important;
}

.service-showcase__head,
.service-seo__head,
.service-detail-page .services-detail__intro,
.service-detail-page .services-detail__section-head,
.service-detail-page .service-price-head,
.service-detail-page .service-growth__head {
    margin-bottom: 32px !important;
}

.service-showcase__head h2,
.service-seo__head h2,
.service-faq h2,
.service-detail-page .services-detail__slogan,
.service-detail-page .services-detail__section-head h2,
.service-detail-page .services-detail__wrapper-title,
.service-detail-page .service-price-head h2,
.service-detail-page .service-growth__head h2 {
    font-size: var(--gcub-type-h2, clamp(30px, 2.65vw, 40px)) !important;
    line-height: 1.08 !important;
}

.main .services__item-title,
.main .services__item:not(:first-child) .services__item-title,
.main .service-section-hero + .services .services__item-title,
.main .service-section-hero + .services .services__item:not(:first-child) .services__item-title,
.service-showcase__card h3,
.service-seo__card h3,
.service-detail-page .services-detail__advantages-item h3,
.service-detail-page .services-detail__advantages-item:first-child h3,
.service-detail-page .services-detail__advantages-wrapper > .services-detail__advantages-item--wide h3,
.service-detail-page .services-detail__prices-item h3,
.service-detail-page .service-growth__card h3,
.service-detail-page .service-growth__card--accent h3,
.service-detail-page .service-growth__outcomes h3,
.service-detail-page .accordion__header-title {
    font-size: var(--gcub-type-h3, clamp(22px, 1.65vw, 28px)) !important;
    line-height: 1.14 !important;
}

.service-showcase__grid,
.service-seo__grid,
.main .service-section-hero + .services .services__wrapper,
.service-detail-page .services-detail__advantages-wrapper,
.service-detail-page .services-detail__prices-wrapper,
.service-detail-page .services-detail__your-rewards-wrapper,
.service-detail-page .service-growth__grid {
    gap: 24px !important;
}

.main .service-section-hero + .services .services__item,
.service-showcase__card,
.service-seo__card,
.service-detail-page .services-detail__advantages-item,
.service-detail-page .services-detail__prices-item,
.service-detail-page .services-detail__your-rewards-item,
.service-detail-page .service-growth__card,
.service-detail-page .service-growth__outcomes,
.service-detail-page .service-growth__local {
    padding: 32px !important;
    border-radius: 8px !important;
}

.service-detail-page .accordion__item {
    border-radius: 8px !important;
}

.service-detail-page .accordion__header {
    min-height: 72px !important;
    padding: 24px 64px 24px 24px !important;
}

.service-detail-page .accordion__body-wrapper {
    padding: 0 24px 32px !important;
}

.service-detail-page .services-detail__prices-item .bx-package-card,
.service-detail-page .services-detail__prices-item .bx-package-card__services {
    border-radius: 8px !important;
}

.service-detail-page .services-detail__prices-item .bx-package-card__services {
    padding: 32px !important;
}

.service-detail-page .services-detail__prices-item .bx-services-list {
    gap: 16px !important;
}

@media (max-width: 767px) {
    .main .container,
    .service-section-hero .container,
    .services-hub .container,
    .service-showcase .container,
    .service-seo .container,
    .service-detail-page .container {
        width: min(calc(100% - var(--gcub-gutter, 32px)), var(--gcub-container, 1500px)) !important;
    }

    .service-section-hero,
    .service-detail-hero {
        padding-top: 48px !important;
        padding-bottom: 64px !important;
    }

    .service-section-hero__grid,
    .service-detail-hero__grid {
        gap: 32px !important;
    }

    .service-section-hero__title,
    .services-hub__title,
    .service-detail-hero__title {
        font-size: var(--gcub-type-h1-mobile, clamp(30px, 8vw, 36px)) !important;
        line-height: 1.08 !important;
    }

    .services-hub,
    .service-showcase,
    .service-seo,
    .service-detail-page .services-detail,
    .service-detail-page .services-detail__advantages,
    .service-detail-page .services-detail__prices,
    .service-detail-page .services-detail__your-rewards,
    .service-detail-page .service-growth,
    .service-detail-page .accordion {
        padding-top: 64px !important;
        padding-bottom: 64px !important;
    }

    .service-showcase__grid,
    .service-seo__grid,
    .main .service-section-hero + .services .services__wrapper,
    .service-detail-page .services-detail__advantages-wrapper,
    .service-detail-page .services-detail__prices-wrapper,
    .service-detail-page .services-detail__your-rewards-wrapper,
    .service-detail-page .service-growth__grid {
        gap: 16px !important;
    }

    .main .service-section-hero + .services .services__item,
    .service-showcase__card,
    .service-seo__card,
    .service-detail-page .services-detail__advantages-item,
    .service-detail-page .services-detail__prices-item,
    .service-detail-page .services-detail__your-rewards-item,
    .service-detail-page .service-growth__card,
    .service-detail-page .service-growth__outcomes,
    .service-detail-page .service-growth__local {
        padding: 24px !important;
    }

    .service-detail-page .accordion__header {
        min-height: 64px !important;
        padding: 24px 48px 24px 16px !important;
    }

    .service-detail-page .accordion__body-wrapper,
    .service-detail-page .services-detail__prices-item .bx-package-card__services {
        padding: 24px !important;
    }
}

/* Final mobile pricing layout: keep service package cards full-width and readable. */
@media (max-width: 767px) {
    html body .main .service-detail-page .services-detail__prices {
        padding: 28px 16px !important;
    }

    html body .main .service-detail-page .services-detail__prices > .container {
        width: 100% !important;
        max-width: none !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    html body .main .service-detail-page .service-price-head {
        width: 100% !important;
        margin-bottom: 24px !important;
    }

    html body .main .service-detail-page .service-price-head h2 {
        font-size: clamp(30px, 8vw, 36px) !important;
        line-height: 1.08 !important;
    }

    html body .main .service-detail-page .service-price-head p {
        font-size: 16px !important;
        line-height: 1.48 !important;
    }

    html body .main .service-detail-page .services-detail__prices-wrapper {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
        width: 100% !important;
        margin-bottom: 36px !important;
    }

    html body .main .service-detail-page .services-detail__prices-item {
        width: 100% !important;
        min-width: 0 !important;
        padding: 0 !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card {
        width: 100% !important;
        min-width: 0 !important;
        padding: 22px !important;
        border-radius: 8px !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__content {
        width: 100% !important;
        min-width: 0 !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__badge {
        width: fit-content !important;
        margin-bottom: 20px !important;
        padding: 8px 12px !important;
        font-size: 12px !important;
        line-height: 1 !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__title {
        margin-bottom: 16px !important;
        font-size: 24px !important;
        line-height: 1.12 !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__price {
        margin-bottom: 24px !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-price-main {
        white-space: nowrap !important;
        font-size: clamp(29px, 8.2vw, 34px) !important;
        line-height: 1.02 !important;
        letter-spacing: 0 !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-price-note {
        flex-wrap: wrap !important;
        gap: 4px 8px !important;
        margin-top: 8px !important;
        font-size: 14px !important;
        line-height: 1.35 !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__highlights {
        gap: 12px !important;
        margin-bottom: 22px !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-highlight-item {
        grid-template-columns: 38px minmax(0, 1fr) !important;
        gap: 12px !important;
        align-items: center !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-highlight-icon {
        width: 38px !important;
        height: 38px !important;
        min-width: 38px !important;
        font-size: 17px !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-highlight-text {
        font-size: 15px !important;
        line-height: 1.35 !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__toggle {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 12px !important;
        width: 100% !important;
        min-height: 52px !important;
        margin: 0 0 14px !important;
        padding: 0 14px !important;
        font-size: 14px !important;
        line-height: 1.2 !important;
    }

    html body .main .service-detail-page .services-detail__prices-item:first-child .bx-package-card__toggle {
        color: var(--gcub-ink, #07111f) !important;
        border-color: rgba(20, 115, 248, .16) !important;
        background: rgba(255, 255, 255, .82) !important;
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, .72), 0 10px 24px rgba(16, 31, 54, .06) !important;
    }

    html body .main .service-detail-page .services-detail__prices-item:first-child .bx-package-card__toggle [data-bx-element="toggle-text"] {
        color: var(--gcub-ink, #07111f) !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__toggle > div {
        flex: 0 0 auto !important;
        gap: 6px !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-service-count {
        font-size: 12px !important;
        white-space: nowrap !important;
    }

    html body .main .service-detail-page .services-detail__prices-item:first-child .bx-service-count {
        color: rgba(7, 17, 31, .56) !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-toggle-arrow {
        width: 26px !important;
        height: 26px !important;
        min-width: 26px !important;
        font-size: 11px !important;
    }

    html body .main .service-detail-page .services-detail__prices-item:first-child .bx-toggle-arrow {
        color: var(--gcub-blue, #1473f8) !important;
        border-color: rgba(20, 115, 248, .18) !important;
        background: rgba(20, 115, 248, .08) !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__cta {
        width: 100% !important;
        min-height: 54px !important;
        margin-bottom: 10px !important;
        padding: 15px !important;
        font-size: 15px !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-project-note {
        font-size: 13px !important;
        line-height: 1.35 !important;
    }
}

.bx-package-card__services-close {
    display: none;
}

/* Mobile package contents: open as a full-screen layer with an explicit close control. */
@media (max-width: 767px) {
    html body.package-services-open {
        overflow: hidden !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__services {
        position: fixed !important;
        inset: 0 !important;
        z-index: 3000 !important;
        display: flex !important;
        flex-direction: column !important;
        width: 100vw !important;
        height: 100dvh !important;
        max-height: none !important;
        margin: 0 !important;
        padding: max(24px, env(safe-area-inset-top)) 18px max(24px, env(safe-area-inset-bottom)) !important;
        border: 0 !important;
        border-radius: 0 !important;
        background:
            radial-gradient(circle at 88% 8%, rgba(199, 255, 74, .2), transparent 34%),
            linear-gradient(180deg, #f7faff 0%, #eef4fb 100%) !important;
        box-shadow: none !important;
        filter: none !important;
        opacity: 0 !important;
        visibility: hidden !important;
        transform: translateY(16px) !important;
        pointer-events: none !important;
        overflow: hidden !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__services--open {
        opacity: 1 !important;
        visibility: visible !important;
        transform: none !important;
        pointer-events: auto !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__services::before {
        content: "Что входит в пакет" !important;
        flex: 0 0 auto !important;
        margin: 0 64px 18px 0 !important;
        color: var(--gcub-ink, #07111f) !important;
        font-size: 24px !important;
        line-height: 1.12 !important;
        font-weight: 900 !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__services-close {
        position: fixed !important;
        top: max(14px, env(safe-area-inset-top)) !important;
        right: 14px !important;
        z-index: 3001 !important;
        display: block !important;
        width: 44px !important;
        height: 44px !important;
        padding: 0 !important;
        border: 1px solid rgba(16, 31, 54, .1) !important;
        border-radius: 999px !important;
        background: rgba(255, 255, 255, .94) !important;
        box-shadow: 0 14px 34px rgba(16, 31, 54, .14) !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__services-close::before,
    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__services-close::after {
        content: "" !important;
        position: absolute !important;
        top: 50% !important;
        left: 50% !important;
        width: 18px !important;
        height: 2px !important;
        border-radius: 999px !important;
        background: var(--gcub-ink, #07111f) !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__services-close::before {
        transform: translate(-50%, -50%) rotate(45deg) !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__services-close::after {
        transform: translate(-50%, -50%) rotate(-45deg) !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-services-list {
        flex: 1 1 auto !important;
        display: grid !important;
        grid-template-columns: 1fr !important;
        grid-auto-rows: auto !important;
        gap: 10px !important;
        min-height: 0 !important;
        max-height: none !important;
        margin: 0 !important;
        padding: 0 2px 8px 0 !important;
        border: 0 !important;
        border-radius: 0 !important;
        background: transparent !important;
        overflow: auto !important;
        overscroll-behavior: contain !important;
        -webkit-overflow-scrolling: touch !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-services-list li {
        display: flex !important;
        min-height: 58px !important;
        align-items: center !important;
        gap: 10px !important;
        padding: 14px 16px !important;
        border: 1px solid rgba(16, 31, 54, .08) !important;
        border-radius: 8px !important;
        color: var(--gcub-ink, #07111f) !important;
        background: rgba(255, 255, 255, .86) !important;
        box-shadow: 0 10px 26px rgba(16, 31, 54, .06) !important;
        font-size: 14px !important;
        line-height: 1.28 !important;
        font-weight: 800 !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-services-list li > div {
        min-width: 0 !important;
    }
}

@media (max-width: 767px) {
    html body > .bx-package-card__services {
        position: fixed !important;
        inset: 0 !important;
        z-index: 3000 !important;
        display: flex !important;
        flex-direction: column !important;
        width: 100vw !important;
        height: 100dvh !important;
        max-height: none !important;
        margin: 0 !important;
        padding: max(24px, env(safe-area-inset-top)) 18px max(24px, env(safe-area-inset-bottom)) !important;
        border: 0 !important;
        border-radius: 0 !important;
        background:
            radial-gradient(circle at 88% 8%, rgba(199, 255, 74, .2), transparent 34%),
            linear-gradient(180deg, #f7faff 0%, #eef4fb 100%) !important;
        box-shadow: none !important;
        filter: none !important;
        opacity: 0 !important;
        visibility: hidden !important;
        transform: translateY(16px) !important;
        pointer-events: none !important;
        overflow: hidden !important;
    }

    html body > .bx-package-card__services--open {
        opacity: 1 !important;
        visibility: visible !important;
        transform: none !important;
        pointer-events: auto !important;
    }

    html body > .bx-package-card__services::before {
        content: "Что входит в пакет" !important;
        flex: 0 0 auto !important;
        margin: 0 64px 18px 0 !important;
        color: var(--gcub-ink, #07111f) !important;
        font-size: 24px !important;
        line-height: 1.12 !important;
        font-weight: 900 !important;
    }

    html body > .bx-package-card__services .bx-package-card__services-close {
        position: fixed !important;
        top: max(14px, env(safe-area-inset-top)) !important;
        right: 14px !important;
        z-index: 3001 !important;
        display: block !important;
        width: 44px !important;
        height: 44px !important;
        padding: 0 !important;
        border: 1px solid rgba(16, 31, 54, .1) !important;
        border-radius: 999px !important;
        background: rgba(255, 255, 255, .94) !important;
        box-shadow: 0 14px 34px rgba(16, 31, 54, .14) !important;
    }

    html body > .bx-package-card__services .bx-package-card__services-close::before,
    html body > .bx-package-card__services .bx-package-card__services-close::after {
        content: "" !important;
        position: absolute !important;
        top: 50% !important;
        left: 50% !important;
        width: 18px !important;
        height: 2px !important;
        border-radius: 999px !important;
        background: var(--gcub-ink, #07111f) !important;
    }

    html body > .bx-package-card__services .bx-package-card__services-close::before {
        transform: translate(-50%, -50%) rotate(45deg) !important;
    }

    html body > .bx-package-card__services .bx-package-card__services-close::after {
        transform: translate(-50%, -50%) rotate(-45deg) !important;
    }

    html body > .bx-package-card__services .bx-services-list {
        flex: 1 1 auto !important;
        display: grid !important;
        grid-template-columns: 1fr !important;
        grid-auto-rows: auto !important;
        gap: 10px !important;
        min-height: 0 !important;
        max-height: none !important;
        margin: 0 !important;
        padding: 0 2px 8px 0 !important;
        border: 0 !important;
        border-radius: 0 !important;
        background: transparent !important;
        overflow: auto !important;
        overscroll-behavior: contain !important;
        -webkit-overflow-scrolling: touch !important;
    }

    html body > .bx-package-card__services .bx-services-list li {
        display: flex !important;
        min-height: 58px !important;
        align-items: center !important;
        gap: 10px !important;
        padding: 14px 16px !important;
        border: 1px solid rgba(16, 31, 54, .08) !important;
        border-radius: 8px !important;
        color: var(--gcub-ink, #07111f) !important;
        background: rgba(255, 255, 255, .86) !important;
        box-shadow: 0 10px 26px rgba(16, 31, 54, .06) !important;
        font-size: 14px !important;
        line-height: 1.28 !important;
        font-weight: 800 !important;
    }
}

@media (max-width: 767px) {
    body .service-detail-page .services-detail__prices > .container {
        width: 100% !important;
        max-width: none !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    body .service-detail-page .services-detail__prices-wrapper {
        width: 100% !important;
        grid-template-columns: 1fr !important;
    }

    body .service-detail-page .services-detail__prices-item,
    body .service-detail-page .services-detail__prices-item .bx-package-card {
        width: 100% !important;
        max-width: none !important;
    }
}

@media (max-width: 360px) {
    html body .main .service-detail-page .services-detail__prices,
    html body .service-detail-page .services-detail__prices {
        padding: 28px 8px !important;
    }
}

/* Unified template price cards: keep readable contrast on dark cards */
html body .main .service-detail-page .services-detail__prices-item:not(:first-child) .bx-package-card--seo .bx-package-card__summary {
    color: rgba(255, 255, 255, .76) !important;
}

html body .main .service-detail-page .services-detail__prices-item:first-child .bx-package-card--seo .bx-package-card__summary {
    color: rgba(7, 17, 31, .68) !important;
}

/* Service result cards: smaller icons on mobile */
@media (max-width: 767px) {
    html body .main .service-detail-page .services-detail__your-rewards-item img,
    html body .service-detail-page .services-detail__your-rewards-item img {
        width: 43px !important;
        max-width: 43px !important;
        height: auto !important;
        max-height: 43px !important;
        object-fit: contain !important;
    }
}

/* Support service: keep three pricing tariffs in one desktop row */
@media (min-width: 1180px) {
    html body .main .service-detail-page .services-detail--support .services-detail__prices > .container,
    html body .service-detail-page .services-detail--support .services-detail__prices > .container {
        width: min(calc(100% - 64px), 1320px) !important;
        max-width: 1320px !important;
    }

    html body .main .service-detail-page .services-detail--support .services-detail__prices-wrapper,
    html body .service-detail-page .services-detail--support .services-detail__prices-wrapper {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        gap: 24px !important;
    }
}

@media (min-width: 1180px) {
    html body .main .service-detail-page .services-detail--support > .container:has(> .services-detail__prices),
    html body .service-detail-page .services-detail--support > .container:has(> .services-detail__prices) {
        width: min(calc(100% - 64px), 1320px) !important;
        max-width: 1320px !important;
    }
}

@media (min-width: 1180px) {
    html body .main .service-detail-page .services-detail--support .services-detail__prices-wrapper,
    html body .service-detail-page .services-detail--support .services-detail__prices-wrapper {
        width: 100% !important;
        max-width: none !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }
}

@media (min-width: 1180px) {
    html body .main .service-detail-page .services-detail--support .services-detail__prices,
    html body .service-detail-page .services-detail--support .services-detail__prices {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    html body .main .service-detail-page .services-detail--support .services-detail__prices-wrapper,
    html body .service-detail-page .services-detail--support .services-detail__prices-wrapper {
        min-width: 100% !important;
    }
}

/* Service prices: remove small tariff labels above card titles */
html body .main .service-detail-page .services-detail__prices-item .bx-package-card__badge,
html body .service-detail-page .services-detail__prices-item .bx-package-card__badge,
html body .main .service-detail-page .services-detail__prices-item .bx-package-card__content::before,
html body .service-detail-page .services-detail__prices-item .bx-package-card__content::before {
    content: none !important;
    display: none !important;
}

/* Support prices: visually align controls and footer notes inside cards */
html body .main .service-detail-page .services-detail--support .services-detail__prices-item .bx-package-card__toggle,
html body .service-detail-page .services-detail--support .services-detail__prices-item .bx-package-card__toggle {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    min-height: 56px !important;
    margin-bottom: 18px !important;
    padding: 0 18px !important;
    border: 1px solid rgba(255, 255, 255, .14) !important;
    border-radius: 8px !important;
    background: rgba(255, 255, 255, .075) !important;
    color: rgba(255, 255, 255, .92) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .08) !important;
}

html body .main .service-detail-page .services-detail--support .services-detail__prices-item:first-child .bx-package-card__toggle,
html body .service-detail-page .services-detail--support .services-detail__prices-item:first-child .bx-package-card__toggle {
    border-color: rgba(16, 31, 54, .1) !important;
    background: rgba(7, 17, 31, .045) !important;
    color: rgba(7, 17, 31, .86) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .8), 0 10px 24px rgba(16, 31, 54, .04) !important;
}

html body .main .service-detail-page .services-detail--support .services-detail__prices-item:first-child .bx-package-card__toggle [data-bx-element="toggle-text"],
html body .service-detail-page .services-detail--support .services-detail__prices-item:first-child .bx-package-card__toggle [data-bx-element="toggle-text"] {
    color: rgba(7, 17, 31, .86) !important;
}

html body .main .service-detail-page .services-detail--support .services-detail__prices-item:first-child .bx-service-count,
html body .service-detail-page .services-detail--support .services-detail__prices-item:first-child .bx-service-count {
    color: rgba(7, 17, 31, .56) !important;
}

html body .main .service-detail-page .services-detail--support .services-detail__prices-item:first-child .bx-toggle-arrow,
html body .service-detail-page .services-detail--support .services-detail__prices-item:first-child .bx-toggle-arrow {
    color: var(--gcub-blue, #1473f8) !important;
    border-color: rgba(20, 115, 248, .18) !important;
    background: rgba(20, 115, 248, .08) !important;
}

html body .main .service-detail-page .services-detail--support .services-detail__prices-item .bx-project-note,
html body .service-detail-page .services-detail--support .services-detail__prices-item .bx-project-note {
    display: grid !important;
    grid-template-columns: 28px minmax(0, 1fr) !important;
    align-items: center !important;
    justify-content: stretch !important;
    gap: 12px !important;
    min-height: 58px !important;
    margin-top: 18px !important;
    padding-top: 16px !important;
    text-align: left !important;
}

html body .main .service-detail-page .services-detail--support .services-detail__prices-item .bx-note-icon,
html body .service-detail-page .services-detail--support .services-detail__prices-item .bx-note-icon {
    display: inline-flex !important;
    width: 28px !important;
    height: 28px !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 !important;
    font-size: 18px !important;
    line-height: 1 !important;
}

/* Support prices: prevent inner package cards from overflowing three-column grid */
html body .main .service-detail-page .services-detail--support .services-detail__prices-item,
html body .service-detail-page .services-detail--support .services-detail__prices-item {
    padding: 0 !important;
    overflow: hidden !important;
}

html body .main .service-detail-page .services-detail--support .services-detail__prices-item .bx-package-card,
html body .service-detail-page .services-detail--support .services-detail__prices-item .bx-package-card {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: 100% !important;
    padding: 32px !important;
}

@media (max-width: 767px) {
    html body .main .service-detail-page .services-detail--support .services-detail__prices-item .bx-package-card,
    html body .service-detail-page .services-detail--support .services-detail__prices-item .bx-package-card {
        padding: 24px !important;
    }
}

/* Service package contents: prevent long item labels from escaping cards */
html body .main .service-detail-page .services-detail__prices-item .bx-package-card__services .bx-services-list,
html body .service-detail-page .services-detail__prices-item .bx-package-card__services .bx-services-list,
html body > .bx-package-card__services .bx-services-list {
    grid-template-columns: repeat(auto-fit, minmax(min(220px, 100%), 1fr)) !important;
}

html body .main .service-detail-page .services-detail__prices-item .bx-package-card__services .bx-services-list li,
html body .service-detail-page .services-detail__prices-item .bx-package-card__services .bx-services-list li,
html body > .bx-package-card__services .bx-services-list li {
    display: grid !important;
    grid-template-columns: 24px minmax(0, 1fr) !important;
    align-items: flex-start !important;
    gap: 10px !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-align: left !important;
}

html body .main .service-detail-page .services-detail__prices-item .bx-package-card__services .bx-services-list li > div,
html body .service-detail-page .services-detail__prices-item .bx-package-card__services .bx-services-list li > div,
html body > .bx-package-card__services .bx-services-list li > div {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow-wrap: anywhere !important;
    word-break: normal !important;
    white-space: normal !important;
}

html body .main .service-detail-page .services-detail__prices-item .bx-package-card__services .bx-service-check,
html body .service-detail-page .services-detail__prices-item .bx-package-card__services .bx-service-check,
html body > .bx-package-card__services .bx-service-check {
    width: 24px !important;
    min-width: 24px !important;
    margin-top: 0 !important;
    text-align: center !important;
}

/* Service package contents: use fullscreen layer on tablet/narrow layouts too */
@media (min-width: 768px) and (max-width: 1179px) {
    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__services--open,
    html body .service-detail-page .services-detail__prices-item .bx-package-card__services--open {
        position: fixed !important;
        inset: 0 !important;
        z-index: 3000 !important;
        display: flex !important;
        flex-direction: column !important;
        width: 100vw !important;
        height: 100dvh !important;
        max-height: none !important;
        margin: 0 !important;
        padding: max(32px, env(safe-area-inset-top)) 24px max(32px, env(safe-area-inset-bottom)) !important;
        border: 0 !important;
        border-radius: 0 !important;
        background:
            radial-gradient(circle at 88% 8%, rgba(199, 255, 74, .2), transparent 34%),
            linear-gradient(180deg, #07111f 0%, #0e223c 100%) !important;
        box-shadow: none !important;
        overflow: hidden !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__services--open::before,
    html body .service-detail-page .services-detail__prices-item .bx-package-card__services--open::before {
        content: "Что входит в пакет" !important;
        flex: 0 0 auto !important;
        margin: 0 64px 22px 0 !important;
        color: #fff !important;
        font-size: 30px !important;
        line-height: 1.08 !important;
        font-weight: 900 !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__services--open .bx-package-card__services-close,
    html body .service-detail-page .services-detail__prices-item .bx-package-card__services--open .bx-package-card__services-close {
        position: fixed !important;
        top: max(18px, env(safe-area-inset-top)) !important;
        right: 18px !important;
        z-index: 3001 !important;
        display: block !important;
        width: 46px !important;
        height: 46px !important;
        padding: 0 !important;
        border: 1px solid rgba(255, 255, 255, .16) !important;
        border-radius: 999px !important;
        background: rgba(255, 255, 255, .1) !important;
        box-shadow: 0 14px 34px rgba(0, 0, 0, .22) !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__services--open .bx-package-card__services-close::before,
    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__services--open .bx-package-card__services-close::after,
    html body .service-detail-page .services-detail__prices-item .bx-package-card__services--open .bx-package-card__services-close::before,
    html body .service-detail-page .services-detail__prices-item .bx-package-card__services--open .bx-package-card__services-close::after {
        content: "" !important;
        position: absolute !important;
        top: 50% !important;
        left: 50% !important;
        width: 18px !important;
        height: 2px !important;
        border-radius: 999px !important;
        background: #fff !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__services--open .bx-package-card__services-close::before,
    html body .service-detail-page .services-detail__prices-item .bx-package-card__services--open .bx-package-card__services-close::before {
        transform: translate(-50%, -50%) rotate(45deg) !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__services--open .bx-package-card__services-close::after,
    html body .service-detail-page .services-detail__prices-item .bx-package-card__services--open .bx-package-card__services-close::after {
        transform: translate(-50%, -50%) rotate(-45deg) !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__services--open .bx-services-list,
    html body .service-detail-page .services-detail__prices-item .bx-package-card__services--open .bx-services-list {
        flex: 1 1 auto !important;
        display: grid !important;
        grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)) !important;
        gap: 12px !important;
        min-height: 0 !important;
        max-height: none !important;
        margin: 0 !important;
        padding: 0 2px 8px 0 !important;
        border: 0 !important;
        border-radius: 0 !important;
        background: transparent !important;
        overflow: auto !important;
        overscroll-behavior: contain !important;
        -webkit-overflow-scrolling: touch !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card__services--open .bx-services-list li,
    html body .service-detail-page .services-detail__prices-item .bx-package-card__services--open .bx-services-list li {
        min-height: 72px !important;
        padding: 18px !important;
        border-color: rgba(255, 255, 255, .14) !important;
        color: #fff !important;
        background: rgba(255, 255, 255, .08) !important;
        box-shadow: none !important;
    }
}

/* Service package contents: tablet fullscreen styling after moving layer to body */
@media (min-width: 768px) and (max-width: 1179px) {
    html body > .bx-package-card__services--open {
        position: fixed !important;
        inset: 0 !important;
        z-index: 3000 !important;
        display: flex !important;
        flex-direction: column !important;
        width: 100vw !important;
        height: 100dvh !important;
        max-height: none !important;
        margin: 0 !important;
        padding: max(32px, env(safe-area-inset-top)) 24px max(32px, env(safe-area-inset-bottom)) !important;
        border: 0 !important;
        border-radius: 0 !important;
        background:
            radial-gradient(circle at 88% 8%, rgba(199, 255, 74, .2), transparent 34%),
            linear-gradient(180deg, #07111f 0%, #0e223c 100%) !important;
        box-shadow: none !important;
        overflow: hidden !important;
    }

    html body > .bx-package-card__services--open::before {
        content: "Что входит в пакет" !important;
        flex: 0 0 auto !important;
        margin: 0 64px 22px 0 !important;
        color: #fff !important;
        font-size: 30px !important;
        line-height: 1.08 !important;
        font-weight: 900 !important;
    }

    html body > .bx-package-card__services--open .bx-package-card__services-close {
        position: fixed !important;
        top: max(18px, env(safe-area-inset-top)) !important;
        right: 18px !important;
        z-index: 3001 !important;
        display: block !important;
        width: 46px !important;
        height: 46px !important;
        padding: 0 !important;
        border: 1px solid rgba(255, 255, 255, .16) !important;
        border-radius: 999px !important;
        background: rgba(255, 255, 255, .1) !important;
        box-shadow: 0 14px 34px rgba(0, 0, 0, .22) !important;
    }

    html body > .bx-package-card__services--open .bx-package-card__services-close::before,
    html body > .bx-package-card__services--open .bx-package-card__services-close::after {
        content: "" !important;
        position: absolute !important;
        top: 50% !important;
        left: 50% !important;
        width: 18px !important;
        height: 2px !important;
        border-radius: 999px !important;
        background: #fff !important;
    }

    html body > .bx-package-card__services--open .bx-package-card__services-close::before {
        transform: translate(-50%, -50%) rotate(45deg) !important;
    }

    html body > .bx-package-card__services--open .bx-package-card__services-close::after {
        transform: translate(-50%, -50%) rotate(-45deg) !important;
    }

    html body > .bx-package-card__services--open .bx-services-list {
        flex: 1 1 auto !important;
        display: grid !important;
        grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)) !important;
        gap: 12px !important;
        min-height: 0 !important;
        max-height: none !important;
        margin: 0 !important;
        padding: 0 2px 8px 0 !important;
        border: 0 !important;
        border-radius: 0 !important;
        background: transparent !important;
        overflow: auto !important;
        overscroll-behavior: contain !important;
        -webkit-overflow-scrolling: touch !important;
    }

    html body > .bx-package-card__services--open .bx-services-list li {
        min-height: 72px !important;
        padding: 18px !important;
        border-color: rgba(255, 255, 255, .14) !important;
        color: #fff !important;
        background: rgba(255, 255, 255, .08) !important;
        box-shadow: none !important;
    }
}

/* Service package contents: keep package rows compact in fullscreen layer */
html body > .bx-package-card__services--open .bx-services-list,
html body .main .service-detail-page .services-detail__prices-item .bx-package-card__services--open .bx-services-list,
html body .service-detail-page .services-detail__prices-item .bx-package-card__services--open .bx-services-list {
    align-content: start !important;
}

/* Service FAQ: slightly smaller question titles */
html body .main .service-detail-page .accordion__header-title,
html body .service-detail-page .accordion__header-title {
    font-size: 20px !important;
    line-height: 1.18 !important;
}

@media (max-width: 767px) {
    html body .main .service-detail-page .accordion__header-title,
    html body .service-detail-page .accordion__header-title {
        font-size: 17px !important;
        line-height: 1.24 !important;
    }
}

/* Online store pricing: make the second format card match the light visual style */
html body .main .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child),
html body .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child) {
    border-color: rgba(16, 31, 54, .1) !important;
    color: rgba(7, 17, 31, .72) !important;
    background:
        radial-gradient(circle at 82% 12%, rgba(199, 255, 74, .28), transparent 36%),
        linear-gradient(135deg, rgba(255, 255, 255, .96), rgba(245, 248, 252, .9)) !important;
    box-shadow: 0 26px 76px rgba(16, 31, 54, .1) !important;
}

html body .main .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child)::before,
html body .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child)::before {
    opacity: .42 !important;
}

html body .main .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child) .bx-package-card--seo,
html body .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child) .bx-package-card--seo {
    color: rgba(7, 17, 31, .72) !important;
}

html body .main .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child) .bx-package-card--seo .bx-package-card__title,
html body .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child) .bx-package-card--seo .bx-package-card__title {
    color: var(--gcub-ink, #07111f) !important;
}

html body .main .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child) .bx-package-card--seo .bx-package-card__summary,
html body .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child) .bx-package-card--seo .bx-package-card__summary,
html body .main .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child) .bx-package-card--seo .bx-price-note,
html body .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child) .bx-package-card--seo .bx-price-note {
    color: rgba(7, 17, 31, .68) !important;
}

html body .main .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child) .bx-package-card--seo .bx-price-main,
html body .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child) .bx-package-card--seo .bx-price-main {
    color: var(--gcub-blue, #1473f8) !important;
}

html body .main .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child) .bx-package-card--seo .bx-package-card__price,
html body .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child) .bx-package-card--seo .bx-package-card__price {
    border-bottom-color: rgba(16, 31, 54, .1) !important;
}

html body .main .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child) .bx-package-card--seo .bx-highlight-text,
html body .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child) .bx-package-card--seo .bx-highlight-text {
    color: rgba(7, 17, 31, .78) !important;
}

html body .main .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child) .bx-package-card--seo .bx-highlight-icon,
html body .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child) .bx-package-card--seo .bx-highlight-icon {
    border-color: rgba(20, 115, 248, .16) !important;
    color: var(--gcub-blue, #1473f8) !important;
    background: rgba(20, 115, 248, .08) !important;
}

html body .main .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child) .bx-package-card--seo .bx-package-card__cta,
html body .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child) .bx-package-card--seo .bx-package-card__cta {
    color: #fff !important;
    background: var(--gcub-blue, #1473f8) !important;
    box-shadow: 0 18px 40px rgba(20, 115, 248, .22) !important;
}

/* Online store pricing: exact light card background match */
html body .main .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child),
html body .service-detail-page .services-detail--shop .services-detail__prices-item:not(:first-child) {
    background:
        linear-gradient(rgba(255, 255, 255, .96), rgba(255, 255, 255, .88)),
        radial-gradient(circle at 90% 8%, rgba(199, 255, 74, .32), transparent 30%) !important;
}

/* AI promotion: assistant logos inside the wide pricing card */
html body .main .service-detail-page .services-detail__prices-item .bx-package-card--ai,
html body .service-detail-page .services-detail__prices-item .bx-package-card--ai {
    position: relative !important;
    overflow: hidden !important;
}

html body .main .service-detail-page .services-detail__prices-item .bx-package-card--ai .bx-package-card__summary,
html body .service-detail-page .services-detail__prices-item .bx-package-card--ai .bx-package-card__summary {
    max-width: 640px !important;
}

html body .main .service-detail-page .bx-ai-logos,
html body .service-detail-page .bx-ai-logos {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
    width: min(330px, 32%) !important;
    position: absolute !important;
    top: clamp(96px, 8vw, 126px) !important;
    right: clamp(46px, 5.4vw, 82px) !important;
    z-index: 1 !important;
}

html body .main .service-detail-page .bx-ai-logo,
html body .service-detail-page .bx-ai-logo {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    min-width: 0 !important;
    min-height: 58px !important;
    padding: 11px 12px !important;
    border: 1px solid rgba(20, 115, 248, .12) !important;
    border-radius: 8px !important;
    background: rgba(255, 255, 255, .74) !important;
    box-shadow: 0 16px 36px rgba(16, 31, 54, .08), inset 0 1px 0 rgba(255, 255, 255, .8) !important;
    backdrop-filter: blur(10px) !important;
}

html body .main .service-detail-page .bx-ai-logo__mark,
html body .service-detail-page .bx-ai-logo__mark {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 34px !important;
    height: 34px !important;
    flex: 0 0 34px !important;
    border-radius: 8px !important;
    color: #fff !important;
    font-size: 11px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
    letter-spacing: 0 !important;
}

html body .main .service-detail-page .bx-ai-logo__name,
html body .service-detail-page .bx-ai-logo__name {
    min-width: 0 !important;
    color: #07111f !important;
    font-size: 14px !important;
    line-height: 1.12 !important;
    font-weight: 900 !important;
    white-space: nowrap !important;
}

html body .main .service-detail-page .bx-ai-logo--chatgpt .bx-ai-logo__mark,
html body .service-detail-page .bx-ai-logo--chatgpt .bx-ai-logo__mark {
    background: #10a37f !important;
}

html body .main .service-detail-page .bx-ai-logo--deepseek .bx-ai-logo__mark,
html body .service-detail-page .bx-ai-logo--deepseek .bx-ai-logo__mark {
    background: #3662ff !important;
}

html body .main .service-detail-page .bx-ai-logo--alisa .bx-ai-logo__mark,
html body .service-detail-page .bx-ai-logo--alisa .bx-ai-logo__mark {
    background: linear-gradient(135deg, #ff3b7f, #7b3cff 58%, #18a0ff) !important;
}

html body .main .service-detail-page .bx-ai-logo--gigachat .bx-ai-logo__mark,
html body .service-detail-page .bx-ai-logo--gigachat .bx-ai-logo__mark {
    background: #7fd321 !important;
    color: #07111f !important;
}

@media (max-width: 1180px) {
    html body .main .service-detail-page .bx-ai-logos,
    html body .service-detail-page .bx-ai-logos {
        position: static !important;
        width: 100% !important;
        max-width: 520px !important;
        margin: 0 0 24px !important;
    }
}

@media (max-width: 767px) {
    html body .main .service-detail-page .bx-ai-logos,
    html body .service-detail-page .bx-ai-logos {
        grid-template-columns: 1fr 1fr !important;
        gap: 10px !important;
        margin-bottom: 22px !important;
    }

    html body .main .service-detail-page .bx-ai-logo,
    html body .service-detail-page .bx-ai-logo {
        min-height: 52px !important;
        padding: 9px 10px !important;
        gap: 8px !important;
    }

    html body .main .service-detail-page .bx-ai-logo__mark,
    html body .service-detail-page .bx-ai-logo__mark {
        width: 30px !important;
        height: 30px !important;
        flex-basis: 30px !important;
        font-size: 10px !important;
    }

    html body .main .service-detail-page .bx-ai-logo__name,
    html body .service-detail-page .bx-ai-logo__name {
        font-size: 12px !important;
    }
}

/* AI promotion: keep text column clear of the logo cluster */
@media (min-width: 1181px) {
    html body .main .service-detail-page .services-detail__prices-item .bx-package-card--ai .bx-package-card__summary,
    html body .service-detail-page .services-detail__prices-item .bx-package-card--ai .bx-package-card__summary {
        max-width: 500px !important;
    }
}

/* Online store: replace old monitor cards with a product-focused e-commerce stack */
html body .main .service-detail-page .services-detail--shop .services-detail__advantages-wrapper--custom,
html body .service-detail-page .services-detail--shop .services-detail__advantages-wrapper--custom {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 18px !important;
}

html body .main .service-detail-page .services-detail--shop .services-detail__advantages-item--custom,
html body .service-detail-page .services-detail--shop .services-detail__advantages-item--custom {
    position: relative !important;
    display: flex !important;
    min-height: 260px !important;
    flex-direction: column !important;
    padding: 28px !important;
    border: 1px solid rgba(20, 115, 248, .10) !important;
    border-radius: 8px !important;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, .96), rgba(246, 249, 252, .92)),
        radial-gradient(circle at 100% 0%, rgba(199, 255, 74, .20), transparent 34%) !important;
    box-shadow: 0 18px 42px rgba(16, 31, 54, .06) !important;
    overflow: hidden !important;
}

html body .main .service-detail-page .services-detail--shop .services-detail__advantages-item--custom::after,
html body .service-detail-page .services-detail--shop .services-detail__advantages-item--custom::after {
    content: "" !important;
    position: absolute !important;
    right: -34px !important;
    bottom: -34px !important;
    width: 120px !important;
    height: 120px !important;
    border: 1px solid rgba(20, 115, 248, .08) !important;
    border-radius: 50% !important;
    background: rgba(20, 115, 248, .035) !important;
}

html body .main .service-detail-page .services-detail--shop .services-detail__advantages-number,
html body .service-detail-page .services-detail--shop .services-detail__advantages-number {
    display: inline-flex !important;
    width: 38px !important;
    height: 38px !important;
    align-items: center !important;
    justify-content: center !important;
    margin-bottom: 28px !important;
    border: 1px solid rgba(20, 115, 248, .18) !important;
    border-radius: 8px !important;
    color: #1473f8 !important;
    background: rgba(20, 115, 248, .08) !important;
    font-size: 15px !important;
    line-height: 1 !important;
    font-weight: 900 !important;
}

html body .main .service-detail-page .services-detail--shop .services-detail__advantages-item--custom h3,
html body .service-detail-page .services-detail--shop .services-detail__advantages-item--custom h3 {
    max-width: 360px !important;
    margin: 0 0 14px !important;
    color: #07111f !important;
    font-size: clamp(22px, 1.55vw, 26px) !important;
    line-height: 1.08 !important;
    font-weight: 900 !important;
    letter-spacing: 0 !important;
}

html body .main .service-detail-page .services-detail--shop .services-detail__advantages-item--custom p,
html body .service-detail-page .services-detail--shop .services-detail__advantages-item--custom p {
    position: relative !important;
    z-index: 1 !important;
    max-width: 420px !important;
    margin: 0 !important;
    color: rgba(7, 17, 31, .68) !important;
    font-size: 16px !important;
    line-height: 1.52 !important;
    font-weight: 650 !important;
}

@media (max-width: 1180px) {
    html body .main .service-detail-page .services-detail--shop .services-detail__advantages-wrapper--custom,
    html body .service-detail-page .services-detail--shop .services-detail__advantages-wrapper--custom {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 767px) {
    html body .main .service-detail-page .services-detail--shop .services-detail__advantages-wrapper--custom,
    html body .service-detail-page .services-detail--shop .services-detail__advantages-wrapper--custom {
        grid-template-columns: 1fr !important;
        gap: 14px !important;
    }

    html body .main .service-detail-page .services-detail--shop .services-detail__advantages-item--custom,
    html body .service-detail-page .services-detail--shop .services-detail__advantages-item--custom {
        min-height: 0 !important;
        padding: 22px !important;
    }

    html body .main .service-detail-page .services-detail--shop .services-detail__advantages-number,
    html body .service-detail-page .services-detail--shop .services-detail__advantages-number {
        width: 34px !important;
        height: 34px !important;
        margin-bottom: 20px !important;
        font-size: 14px !important;
    }

    html body .main .service-detail-page .services-detail--shop .services-detail__advantages-item--custom h3,
    html body .service-detail-page .services-detail--shop .services-detail__advantages-item--custom h3 {
        font-size: 22px !important;
        line-height: 1.12 !important;
    }

    html body .main .service-detail-page .services-detail--shop .services-detail__advantages-item--custom p,
    html body .service-detail-page .services-detail--shop .services-detail__advantages-item--custom p {
        font-size: 15px !important;
        line-height: 1.45 !important;
    }
}

/* Online store: prevent inherited old wide-card rules on the new custom stack */
html body .main .service-detail-page .services-detail--shop .services-detail__advantages-wrapper--custom > .services-detail__advantages-item--custom,
html body .service-detail-page .services-detail--shop .services-detail__advantages-wrapper--custom > .services-detail__advantages-item--custom,
html body .main .service-detail-page .services-detail--shop .services-detail__advantages-wrapper--custom > .services-detail__advantages-item--custom:first-child,
html body .service-detail-page .services-detail--shop .services-detail__advantages-wrapper--custom > .services-detail__advantages-item--custom:first-child,
html body .main .service-detail-page .services-detail--shop .services-detail__advantages-wrapper--custom > .services-detail__advantages-item--custom:last-child:nth-child(odd):not(:first-child),
html body .service-detail-page .services-detail--shop .services-detail__advantages-wrapper--custom > .services-detail__advantages-item--custom:last-child:nth-child(odd):not(:first-child) {
    grid-column: auto !important;
    min-height: 260px !important;
    align-items: flex-start !important;
    text-align: left !important;
}

html body .main .service-detail-page .services-detail--shop .services-detail__advantages-wrapper--custom > .services-detail__advantages-item--custom:first-child h3,
html body .service-detail-page .services-detail--shop .services-detail__advantages-wrapper--custom > .services-detail__advantages-item--custom:first-child h3,
html body .main .service-detail-page .services-detail--shop .services-detail__advantages-wrapper--custom > .services-detail__advantages-item--custom:first-child p,
html body .service-detail-page .services-detail--shop .services-detail__advantages-wrapper--custom > .services-detail__advantages-item--custom:first-child p {
    max-width: 420px !important;
    text-align: left !important;
}

/* Service pages mobile: remove only duplicated vertical gaps between adjacent late-page blocks */
@media (max-width: 767px) {
    html body .main .service-detail-page .services-detail__your-rewards + .service-growth,
    html body .service-detail-page .services-detail__your-rewards + .service-growth {
        padding-top: 40px !important;
    }

    html body .main .service-detail-page .service-growth + .accordion,
    html body .service-detail-page .service-growth + .accordion {
        padding-top: 40px !important;
    }

    html body .main .service-detail-page .accordion,
    html body .service-detail-page .accordion {
        padding-bottom: 40px !important;
    }

    html body .main .service-detail-page .accordion + .another-pages,
    html body .service-detail-page .accordion + .another-pages {
        padding-top: 36px !important;
    }
}

/* Service pages mobile: remove duplicated FAQ-to-cases spacing */
@media (max-width: 767px) {
    html body .main.service-detail-page .accordion,
    html body .main .service-detail-page .accordion,
    html body .service-detail-page .accordion {
        margin-bottom: 24px !important;
    }

    html body .main.service-detail-page .another-pages,
    html body .main .service-detail-page .another-pages,
    html body .service-detail-page .another-pages {
        margin-top: 0 !important;
        padding-top: 40px !important;
    }
}

/* Service pages mobile: final compact FAQ-to-cases handoff */
@media (max-width: 767px) {
    html body .main.service-detail-page .accordion,
    html body .main .service-detail-page .accordion,
    html body .service-detail-page .accordion {
        padding-bottom: 24px !important;
    }

    html body .main.service-detail-page .another-pages,
    html body .main .service-detail-page .another-pages,
    html body .service-detail-page .another-pages {
        padding-top: 32px !important;
    }
}

/* Service pages mobile: compact the visible handoff from result cards to expertise */
@media (max-width: 767px) {
    html body .main.service-detail-page .services-detail__your-rewards,
    html body .main .service-detail-page .services-detail__your-rewards,
    html body .service-detail-page .services-detail__your-rewards {
        padding-bottom: 24px !important;
        margin-bottom: 24px !important;
    }

    html body .main.service-detail-page .services-detail__your-rewards + .service-growth,
    html body .main .service-detail-page .services-detail__your-rewards + .service-growth,
    html body .service-detail-page .services-detail__your-rewards + .service-growth {
        margin-top: 0 !important;
        padding-top: 24px !important;
    }
}

/* Service pages mobile: tighter result-to-expertise transition after visual check */
@media (max-width: 767px) {
    html body .main.service-detail-page .services-detail__your-rewards,
    html body .main .service-detail-page .services-detail__your-rewards,
    html body .service-detail-page .services-detail__your-rewards {
        padding-bottom: 8px !important;
        margin-bottom: 16px !important;
    }

    html body .main.service-detail-page .services-detail__your-rewards + .service-growth,
    html body .main .service-detail-page .services-detail__your-rewards + .service-growth,
    html body .service-detail-page .services-detail__your-rewards + .service-growth {
        padding-top: 16px !important;
    }
}

/* Compact hero only on root Web Development and SEO/Direct section pages */
.service-section-hero--compact-root {
    padding-top: 36px;
    padding-bottom: 54px;
}

.service-section-hero--compact-root .service-section-hero__head {
    align-items: center;
    gap: clamp(24px, 3vw, 48px);
}

.service-section-hero--compact-root .service-section-hero__summary p {
    font-size: 20px;
    line-height: 1.38;
}

.service-section-hero--compact-root .service-section-hero__actions {
    margin-top: 24px;
}

@media (max-width: 1180px) {
    .service-section-hero--compact-root {
        padding-top: 34px;
        padding-bottom: 38px;
    }

    .service-section-hero--compact-root .service-section-hero__head {
        gap: 20px;
    }
}

@media (max-width: 767px) {
    .service-section-hero--compact-root {
        padding-top: 30px !important;
        padding-bottom: 34px !important;
    }

    .service-section-hero--compact-root .service-section-hero__head {
        gap: 18px !important;
    }

    .service-section-hero--compact-root .service-section-hero__summary p {
        font-size: 16px !important;
        line-height: 1.38 !important;
    }

    .service-section-hero--compact-root .service-section-hero__actions {
        margin-top: 18px !important;
    }
}

/* Final compact override for root section heroes */
html body .main .service-section-hero.service-section-hero--compact-root {
    padding-top: 36px !important;
    padding-bottom: 54px !important;
}

html body .main .service-section-hero.service-section-hero--compact-root .service-section-hero__head {
    align-items: center !important;
    gap: clamp(24px, 3vw, 48px) !important;
}

html body .main .service-section-hero.service-section-hero--compact-root .service-section-hero__summary {
    margin-top: 0 !important;
}

html body .main .service-section-hero.service-section-hero--compact-root .service-section-hero__summary p {
    font-size: 20px !important;
    line-height: 1.38 !important;
}

html body .main .service-section-hero.service-section-hero--compact-root .service-section-hero__actions {
    margin-top: 22px !important;
}

@media (max-width: 767px) {
    html body .main .service-section-hero.service-section-hero--compact-root {
        padding-top: 30px !important;
        padding-bottom: 34px !important;
    }

    html body .main .service-section-hero.service-section-hero--compact-root .service-section-hero__head {
        gap: 18px !important;
    }

    html body .main .service-section-hero.service-section-hero--compact-root .service-section-hero__summary p {
        font-size: 16px !important;
        line-height: 1.38 !important;
    }

    html body .main .service-section-hero.service-section-hero--compact-root .service-section-hero__actions {
        margin-top: 18px !important;
    }
}

/* Final mobile price width guard: prevent narrow cards after cascade/cache rebuilds */
@media (max-width: 767px) {
    html body .main .service-detail-page .services-detail__prices,
    html body .service-detail-page .services-detail__prices {
        padding: 32px 12px !important;
        overflow-x: hidden !important;
    }

    html body .main .service-detail-page .services-detail__prices > .container,
    html body .service-detail-page .services-detail__prices > .container {
        width: 100% !important;
        max-width: none !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    html body .main .service-detail-page .services-detail__prices-wrapper,
    html body .service-detail-page .services-detail__prices-wrapper {
        width: 100% !important;
        min-width: 0 !important;
        max-width: none !important;
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 20px !important;
        margin-right: 0 !important;
        margin-left: 0 !important;
    }

    html body .main .service-detail-page .services-detail__prices-item,
    html body .service-detail-page .services-detail__prices-item {
        width: 100% !important;
        min-width: 0 !important;
        max-width: none !important;
        padding: 0 !important;
        overflow: visible !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-package-card,
    html body .service-detail-page .services-detail__prices-item .bx-package-card {
        width: 100% !important;
        min-width: 0 !important;
        max-width: none !important;
        padding: 24px !important;
    }

    html body .main .service-detail-page .services-detail__prices-item .bx-price-main,
    html body .service-detail-page .services-detail__prices-item .bx-price-main {
        font-size: clamp(46px, 17vw, 66px) !important;
        line-height: .94 !important;
        overflow-wrap: normal !important;
        word-break: normal !important;
    }
}

/* Final mobile price typography guard: keep prices on one line */
@media (max-width: 767px) {
    html body .main .service-detail-page .services-detail__prices-item .bx-price-main,
    html body .service-detail-page .services-detail__prices-item .bx-price-main {
        display: block !important;
        max-width: 100% !important;
        white-space: nowrap !important;
        font-size: clamp(38px, 11.5vw, 48px) !important;
        line-height: .96 !important;
        letter-spacing: 0 !important;
        overflow-wrap: normal !important;
        word-break: normal !important;
    }
}
