

body {
    margin: 0;
    padding: 0;
    cursor: default;
    background: url(/images/bgr.png) center 1784px no-repeat #0A0018;
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 16px;
    line-height: 130%;
    color: #000;
}

.flex {
    display: flex;
    flex-wrap: wrap;
}
.align-between {
    justify-content: space-between;
}
.align-right {
    justify-content: right;
}
.overlay {
    width: 100%;
    height: 100%;
    position: fixed;
    left: 0;
    top: 0;
    z-index: 100;
    background: transparent;
    display: none;
}
.content_inject {
    width: 543px;
    height: 100%;
    backdrop-filter: blur(20px);
    background: rgba(0, 0, 0, 0.8);
    border-radius: 0;
    margin: auto;
    z-index: 101;
    bottom: 0;
    top: 0;
    right: 0;
    left: auto;
    position: fixed;
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 14px;
    line-height: 143%;
    color: #fff;
    display: none;
}
.content_inject_default {
    padding: 40px;
    display: flex;
    /* align-items: center; */
    height: calc(100% - 80px);
    flex-direction: column;
    justify-content: center;

}
.content_inject_default h2 {
    color: #fff !important;
    margin: 0 0 24px 0 !important;
}

.content_inject_close {
    position: absolute;
    right: 31px;
    top: 31px;
    cursor: pointer;
}
.align-center {
    justify-content: center;
}
.vertical-center {
    align-items: center;
}
.cookies {
    background: #fff;
    border-radius: 5px;
    position: fixed;
    z-index: 950;
    bottom: var(--s32);
    left: 0;
    right: 0;
    box-shadow: 0 0 10px #999;
}
.cookies a {
    text-decoration: underline !important;
    text-decoration-skip-ink: none;
    color: #273a8c !important;
}
.cookies-close {
    background: url(/images/close.png);
    width: 14px;
    height: 14px;
    position: absolute;
    right: 16px;
    top: 16px;
    cursor: pointer;
}
.cookies-grid {
    padding: 15px 90px;
    display: grid;
    gap: var(--s32);
    grid-template-columns: 1fr 140px;
    align-items: center;
}
.cookies-agree {

    border-radius: 5px;
    padding: 10px 18px;
    background: #f63b60;
    display: inline-block;
    cursor: pointer;
    font-family: var(--font-family);
    font-weight: 600;
    font-size: 16px;
    line-height: 150%;
    text-transform: uppercase;
    text-align: center;
    color: #fff;
}
.header {
    border-radius: 0 0 40px 40px;
    background: #0a0018;
    padding: 24px 0;
}
.header.white {
    background: #fff;
}

a {
    color: #f63b60;
    text-decoration: none;
}
.header-menu {
    gap: 24px;
}
.header-menu-link {
    font-family: var(--font-family);
    font-weight: 500;
    font-size: 15px;
    text-align: center;
    color: #fff;
    transition: all ease 0.8s;
}
.header-menu-link:hover, .header-menu-link.active {
    color: #f63b60;
}

.header-phone {

    font-weight: 500;
    font-size: 16px;
    text-align: right;
    color: #fff;
}
.header-contacts {
    font-family: var(--font-family);
    gap: 16px;
}
.hero-partner {
    border-radius: 0 0 160px 160px;
    padding: 238px 0 59px;
    background: url("/images/ya.png") center 59px no-repeat #fff;
}
.hero-title {
    margin: 0 0 65px 0;
    font-family: var(--second-family);
    font-weight: 700;
    font-size: 88px;
    line-height: 105%;
    text-align: center;
    color: #222;
}
.white .header-menu-link {
    color: #222222;
}
.white .header-menu-link:hover, .white .header-menu-link.active {
    color: #f63b60;
}
.hero-title span {
    color: #f63b60;
}
.white .header-phone {
    color: #222;
}
.hero-stat-value {
    font-family: var(--font-family);
    font-weight: 700;
    font-size: 32px;
    line-height: 125%;
    color: #f63b60;
    margin-bottom: 8px;
}
.hero-stat-text {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 16px;
    line-height: 175%;
    color: #222;
}
.hero-subtitle {
    font-family: var(--second-family);
    font-weight: 500;
    font-size: 24px;
    line-height: 186%;
    text-align: center;
    color: #222;
    margin-top: 57px;
}
.hero-partners {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.services {
    color: #fff;
    padding-bottom: 117px;
}
.section-title {
    font-family: var(--second-family);
    font-weight: 700;
    font-size: 48px;
    line-height: 117%;
    text-align: center;
    margin: 81px 0 48px;
}
.section-title-white {
    color: #fff;
}
.service-card-title {
    font-family: var(--font-family);
    font-weight: 500;
    font-size: 16px;
    line-height: 150%;
    text-transform: uppercase;
    color: #fff;
    margin-bottom: 16px;
}
.service-card-text {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 16px;
    line-height: 175%;
    color: rgba(255, 255, 255, 0.6);
    padding-left: 64px;
}
.service-card {
    border-radius: 8px;
    padding: 24px;
    background: #292136;
    height: calc(100% - 48px);
}
.service-card-price {
    margin-top: 24px;
    font-family: var(--font-family);
    font-weight: 500;
    font-size: 20px;
    line-height: 120%;
    color: #fff;
    padding-left: 64px;
}
.service-card-top {
    display: grid;
    grid-template-columns: 48px 1fr;
    gap: 16px;
}
.radius-top {
    border-radius: 160px 160px 0 0;
    width: 100%;
    height: 160px;
    background: #fff;
}
.projects {
    background: #fff;
    padding: 0 0 40px 0;
}
.projects-filter {
    gap: 24px;
}
.projects-filter a {
    font-family: var(--font-family);
    font-weight: 500;
    font-size: 13px;
    line-height: 154%;
    color: #222;
}
.mt-0 {
    margin-top: 0;
}
.project-badge {
    display: none;
}
.project-card img {
    width: 100%;
    display: block;
    height: auto;
    aspect-ratio: 380 / 240;
}

.projects-mosaic {
    overflow: hidden;
    width: 100%;
}

.projects-mosaic-row {
    display: flex;
    gap: 20px;
    width: 115%;
}

.projects-mosaic-row + .projects-mosaic-row {
    margin-top: 20px;
}

.projects-mosaic-row-1 {
    margin-left: -7.5%;
}

.projects-mosaic-row-2 {
    margin-left: -22%;
    width: 144%;
}

.projects-mosaic-row-3 {
    margin-left: -4%;
}

.project-card,
.project-card-case {
    display: block;
    position: relative;
    overflow: hidden;
    border-radius: 20px;
    flex: 1 1 0;
    min-width: 0;
}

.project-card img {
    width: 100%;
    display: block;
    aspect-ratio: 380 / 240;
    object-fit: cover;
}

.project-card-small {
    flex: 0.72 1 0;
}

.project-card-case {
    flex: 1.15 1 0;
    aspect-ratio: 380 / 240;
    display: flex;
    align-items: center;
    justify-content: center;
}

.projects-more {
    text-align: center;
    margin-top: 48px;
}
.btn-more {
    background: linear-gradient(125deg, #ff9b70 0%, #f63b60 100%);
    border-radius: 32px;
    padding: 16px 32px;
    font-family: var(--font-family);
    font-weight: 500;
    font-size: 16px;
    color: #fff;
    display: inline-block;
}
.projects-form {
    padding: 40px 55px;
    background: #0a0018;
    border-radius: 8px;
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 14px;
    color: #fff;
}
.projects-form-title {
    font-family: var(--font-family);
    font-weight: 500;
    font-size: 48px;
    color: #fff;
    line-height: 115%;
    margin-bottom: 30px;
}
.projects-form-title span {
    font-weight: 500;
    background: linear-gradient(125deg, #ff9b70 0%, #f63b60 100%);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}
.projects-form-text {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 20px;
    line-height: 140%;
    color: #fff;
}
button {
    border-radius: 32px;
    padding: 16px 32px;
    font-family: var(--font-family);
    font-weight: 500;
    font-size: 16px;
    color: #fff;
    border: none;
    cursor: pointer;
    outline: none;
    display: inline-block;
    background: linear-gradient(125deg, #ff9b70 0%, #f63b60 100%);
}
input[type=text] {
    border-radius: 8px;
    width: calc(100% - 24px);
    margin-bottom: 24px;
    padding: 10px 12px;
    display: block;
    border: none;
    outline: none;
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 14px;
    line-height: 143%;
    color: #bcbcbc;
}
textarea {
    border-radius: 8px;
    width: calc(100% - 24px);

    padding: 10px 12px;
    display: block;
    border: none;
    outline: none;
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 14px;
    line-height: 143%;
    color: #bcbcbc;
    min-height: 85px;
}
.mb-0 {
    margin-bottom: 0 !important;
}
.certificates-slider img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    object-position: center;
    border-radius: 8px;
}
.slider-line {
    position: relative;
    height: 4px;
    background: #e5e5e5;
    margin-top: 20px;
    overflow: hidden;
}

.slider-line::after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    width: 0%;
    background: #f63b60;
    transition: width 0.3s ease;
}
.slider-line-fill {
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    width: 0%;
    background: #f63b60;
    transition: width 0.3s ease;
}
.divider {
    background: #dbdbdb;
    width: 100%;
    height: 1px;
    margin-top: 100px;
}


.client-logo {
    display: flex;
    flex-wrap: nowrap;
    height: 185px;
    align-items: center;
    justify-content: center;
}
.client-logo img {
    max-width: 100%;
}
.radius-bottom {
    border-radius: 0 0 160px 160px;
    width: 100%;
    height: 160px;
    background: #fff;
}

.team-card-name {
    font-family: var(--font-family);
    font-weight: 500;
    font-size: 18px;
    line-height: 156%;

    color: #fff;
    margin: 32px 0 8px 0;
}
.team-card-position {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 16px;
    line-height: 144%;
    letter-spacing: 0.03em;
    color: rgba(255, 255, 255, 0.6);
}
.team-card-photo img{
    display: block;
    width: 100%;
    border-radius: 12px;
}
.footer {
    padding-top: 53px;
    background: #0a0018;
}
.footer-menu-grid {
    display: grid;
    grid-template-columns: 200px 180px 80px;
    gap: 80px;
}
.footer-menu-col {
    display: flex;
    flex-direction: column;
    gap: 20px;
}
.footer-menu-grid a {
    display: block;
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 16px;
    color: #fff;
}
.footer-phone {
    font-family: var(--font-family);
    font-weight: 500;
    font-size: 24px;
    text-align: right;
    color: #fff;
    margin-bottom: 16px;
    display: block;
}
.footer-email {
    font-family: var(--font-family);
    font-weight: 500;
    font-size: 16px;
    text-align: right;
    color: #f63b60;
    display: block;
}
.footer-contacts {
    flex-direction: column;
}
.footer-bottom{
    background: #f63b60;
    color: #fff;
    padding: 16px 0;
    margin-top: 33px;
}
.footer-bottom a {
    color: #fff;
}
.footer-socials {
    gap: 8px;
    margin-top: 18px;
}
* {
    outline: none;
}



.cookies {
    display: none !important;
}

.page-about {
    background:
        radial-gradient(circle at top right, rgba(246, 59, 96, 0.2), transparent 26%),
        linear-gradient(180deg, #0a0018 0%, #120327 18%, #fff 18%, #fff 100%);
    color: #222;
}

.page-about .container {
    position: relative;
    z-index: 1;
}

.about-header {
    position: sticky;
    top: 0;
    z-index: 20;
    background: rgba(10, 0, 24, 0.92);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.about-header-grid,
.about-footer-grid,
.footer-bottom-row,
.about-cta-box .grid-12 {
    align-items: center;
}

.header-logo img,
.footer-logo img {
    display: block;
    max-width: 188px;
}

.header-email {
    font-family: var(--font-family);
    font-weight: 500;
    font-size: 14px;
    color: #f63b60;
}

.about-header-contacts,
.about-actions,
.about-team-tags,
.about-cta-actions {
    gap: 16px;
}

.about-hero {
    padding: 110px 0 48px;
    color: #fff;
}

.about-hero-grid,
.about-story-grid,
.expertise-grid,
.process-grid,
.about-team-grid {
    row-gap: 20px;
}

.about-kicker {
    display: inline-block;
    padding: 8px 16px;
    border-radius: 999px;
    background: rgba(246, 59, 96, 0.14);
    color: #fda3b3;
    font-weight: 500;
    font-size: 14px;
    line-height: 143%;
    margin-bottom: 24px;
}

.about-title {
    margin: 0 0 24px;
    font-family: var(--second-family);
    font-weight: 700;
    font-size: 68px;
    line-height: 102%;
    color: #fff;
    max-width: 820px;
}

.about-lead,
.about-section-text,
.about-story-card p,
.about-principle p,
.process-step p,
.about-team-note,
.expertise-feature p {
    font-size: 18px;
    line-height: 167%;
}

.about-link-more {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 16px 8px;
    color: #fff;
    font-weight: 500;
    font-size: 16px;
}

.about-link-more.light {
    color: #ffd5dd;
}

.about-link-more:hover,
.footer-menu-grid a:hover,
.footer-bottom a:hover {
    color: #f63b60;
}

.about-hero-card,
.about-story-card,
.expertise-feature,
.process-step,
.team-visual-card,
.about-team-copy {
    border-radius: 24px;
}

.about-hero-card {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.03));
    border: 1px solid rgba(255, 255, 255, 0.08);
    padding: 32px;
    min-height: 100%;
}

.about-hero-card-label,
.about-story-label,
.expertise-feature-badge {
    font-size: 14px;
    line-height: 143%;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.about-hero-card-label {
    color: rgba(255, 255, 255, 0.7);
    margin-bottom: 28px;
}

.about-hero-stats {
    display: grid;
    gap: 24px;
}

.about-hero-stat {
    padding-top: 24px;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
}

.about-hero-stat:first-child {
    padding-top: 0;
    border-top: none;
}

.about-hero-stat-value,
.about-metric-value {
    font-family: var(--second-family);
    font-weight: 700;
    color: #f63b60;
}

.about-hero-stat-value {
    font-size: 48px;
    line-height: 104%;
    margin-bottom: 10px;
}

.about-hero-stat-text,
.about-metric-text {
    color: rgba(255, 255, 255, 0.8);
    font-size: 16px;
    line-height: 162%;
}

.about-metrics {
    margin-top: 28px;
    row-gap: 20px;
}

.about-metric-card {
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 20px;
    padding: 24px;
    height: calc(100% - 48px);
}

.about-metric-value {
    font-size: 40px;
    line-height: 105%;
    margin-bottom: 12px;
}

.about-story,
.about-team,
.about-cta {
    background: #fff;
}

.about-story {
    padding: 48px 0;
}

.about-story-card {
    padding: 36px;
    height: calc(100% - 72px);
}

.about-story-card-dark {
    background: #120327;
    color: #fff;
}

.about-story-card-light {
    background: #fff5f7;
    color: #222;
}

.about-story-title {
    margin: 0 0 20px;
    font-family: var(--second-family);
    font-weight: 700;
    font-size: 42px;
    line-height: 114%;
}

.pink {
    color: #f63b60;
}

.about-story-columns,
.about-principles {
    display: grid;
    gap: 24px;
}

.about-story-columns {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-bottom: 28px;
}

.about-principles {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.about-principle {
    background: rgba(255, 255, 255, 0.8);
    border-radius: 20px;
    padding: 24px;
}

.about-principle span,
.process-step-number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: rgba(246, 59, 96, 0.12);
    color: #f63b60;
    font-weight: 700;
    margin-bottom: 18px;
}

.about-principle strong,
.process-step h3,
.expertise-feature h3 {
    display: block;
    margin-bottom: 12px;
    font-size: 24px;
    line-height: 125%;
}

.about-expertise {
    padding: 72px 0;
    background: linear-gradient(180deg, #120327 0%, #0a0018 100%);
    color: #fff;
}

.section-heading {
    max-width: 840px;
    margin-bottom: 40px;
}

.section-heading-dark {
    color: #222;
}

.about-section-title {
    margin: 0 0 20px;
    text-align: left;
}

.expertise-card {
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.expertise-feature {
    background: #fff;
    color: #222;
    padding: 32px;
    height: calc(100% - 64px);
}

.expertise-feature-badge {
    color: #f63b60;
    margin-bottom: 20px;
}

.about-process {
    padding: 72px 0;
    background: linear-gradient(180deg, #fff5f7 0%, #fff 100%);
}

.process-step {
    background: #fff;
    padding: 32px;
    box-shadow: 0 20px 60px rgba(31, 18, 53, 0.08);
    height: calc(100% - 64px);
}

.about-team {
    padding: 24px 0 72px;
}

.team-visual-card {
    overflow: hidden;
    height: 100%;
    min-height: 460px;
}

.team-visual-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.about-team-copy {
    background: #fff5f7;
    padding: 36px;
    height: calc(100% - 72px);
}

.about-section-text.dark,
.about-team-note {
    color: rgba(34, 34, 34, 0.8);
}

.align-left {
    text-align: left;
}

.about-team-tags span {
    padding: 10px 16px;
    background: #fff;
    border-radius: 999px;
    font-weight: 500;
    font-size: 15px;
    color: #222;
}

.about-team-note {
    margin-top: 28px;
    padding-top: 24px;
    border-top: 1px solid rgba(34, 34, 34, 0.12);
}

.about-cta {
    padding-bottom: 72px;
}

.about-cta-box {
    border-radius: 24px;
    padding: 48px 52px;
}

.about-cta-actions {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.about-footer {
    margin-top: 0;
    background: #0a0018;
    padding-top: 38px;
}

.about-footer-menu {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 32px;
}

.about-footer .footer-menu-grid a {
    opacity: 0.8;
}

.about-footer .footer-socials a {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    background: #444;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.about-footer .footer-socials img {
    width: 18px;
    height: 18px;
}

.footer-bottom-row {
    font-family: var(--font-family);
    font-size: 12px;
    line-height: 100%;
}

.page-about-screen {
    background: #fff;
}

.about-company-hero {
    background: #fff;
    padding: 0 0 40px;
}
.about-service-visual {
    background-repeat: no-repeat;
    background-position: right bottom;
    padding-bottom: 49px;
}
.about-service-text {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 16px;
    line-height: 175%;
    color: rgba(255, 255, 255, 0.6);
}
.contacts-card {
    border-radius: 16px;
    padding: 32px;
    background: #f5f5f5;
    margin-bottom: 20px;
}
.contact-row {
    font-family: var(--font-family);
    font-weight: 700;
    font-size: 24px;
    line-height: 133%;
    color: #000;
    display: flex;
    margin-bottom: 12px;
    align-items: center;
    gap: 22px;
}
.contact-phone a {
    color: #000;
}
.contact-email {
    margin-top: 20px;
}
.contact-icon {
    min-height: 1px;
    width: 20px;
}
.contact-icon-phone {
    height: 17px;
    background: url("/images/phone.svg") center top no-repeat;
}
.contact-icon-mail {
    height: 16px;
    background: url("/images/email.svg") center top no-repeat;
}
.contacts-title {
    font-family: var(--font-family);
    font-weight: 700;
    font-size: 20px;
    line-height: 140%;
    color: #222;
}
.contacts-address {
    margin-top: 50px;
    display: flex;
    align-items: center;
    gap: 12px;
}
.contacts-address-text {
    font-family: var(--font-family);
    font-weight: 700;
    font-size: 20px;
    line-height: 140%;
    color: #222;

}
.contact-icon-pin {
    background: url("/images/pin.svg");
    width: 16px;
    height: 21px;
}
.gap-20 {
    gap: 20px;
}
.social-btn {
    width: 32px;
    height: 32px;
}
.contacts-socials {
    display: flex;
    gap: 16px;
}
.social-btn-telegram {
    background: url("/images/tg1.svg") center no-repeat;
}
.social-btn-whatsapp {
    background: url("/images/whatsapp.svg") center no-repeat;
}
.social-btn-vk {
    background: url("/images/vk1.svg") center no-repeat;
}
.social-btn-youtube {
    background: url("/images/yt1.svg") center no-repeat;
}
.mt-20 {
    margin-top: 20px;
}
.contacts-map iframe {
    border-radius: 16px;
}
.about-service-ttl {
    font-family: var(--font-family);
    font-weight: 500;
    font-size: 16px;
    line-height: 175%;
    text-transform: uppercase;
    color: #fff;
}
.about-service-ttl span {
    color: #f63b60;
}
.service-price-name {
    font-family: var(--second-family);
    font-weight: 700;
    font-size: 40px;
    line-height: 120%;
    color: #222;
    margin-top: 40px;
    margin-bottom: 78px;
}
.about-company-shell {
    /*background:
        radial-gradient(circle at 84% 64%, rgba(246, 59, 96, 0.85), transparent 18%),
        linear-gradient(104deg, #0a0018 0%, #0a0018 64%, #0a0018 100%);*/
    background: url("/images/bgr1.png") right 0 #0a0018 no-repeat;
    border-radius: 0 0 44px 44px;
    overflow: hidden;
    padding: 48px 56px 0 48px;
}
.pb-56 {
    padding-bottom: 56px;
}
.about-company-grid {
    align-items: center;
}

.about-company-title {
    margin: 0 0 24px;
    font-family: var(--second-family);
    font-weight: 700;
    font-size: 48px;
    line-height: 117%;
    color: #fff;
}

.about-company-text {
    max-width: 520px;
    margin: 0 0 16px;
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 16px;
    line-height: 162%;
    color: rgba(255, 255, 255, 0.8);
}

.about-company-visual {
    position: relative;
    min-height: 280px;
}

.about-company-shape {
    position: absolute;
    border-radius: 32px;
    transform: rotate(36deg);
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.24);
}

.about-company-shape-a {
    width: 112px;
    height: 112px;
    right: 100px;
    top: 12px;
    background: linear-gradient(180deg, #ffba7b 0%, #ff7c78 100%);
}

.about-company-shape-b {
    width: 124px;
    height: 124px;
    right: 24px;
    top: 98px;
    background: linear-gradient(180deg, #ff9d74 0%, #f63b60 100%);
}

.about-company-shape-c {
    width: 92px;
    height: 92px;
    right: 144px;
    top: 136px;
    background: linear-gradient(180deg, #ffd2a5 0%, #ff8b76 100%);
}

.about-advantages {
    padding: 0 0 40px;
}

.about-adv-card {
    background: #f5f5f5;
    border-radius: 8px;
    padding: 24px;
    height: calc(100% - 48px);
}

.about-adv-icon {
    width: 40px;
    height: 97px;
    margin-bottom: 20px;

}
.portfolio-select-name {
    font-family: var(--second-family);
    font-weight: 700;
    font-size: 40px;
    line-height: 120%;
    color: #222;
    margin: 80px 0 40px;
}
.portfolio-item {

}
.adv-price {
    font-family: var(--second-family);
    font-weight: 700;
    font-size: 24px;
    line-height: 133%;
    color: #f63b60;
}
.about-adv-title {
    margin: 0 0 24px;
    font-family: var(--second-family);
    font-weight: 700;
    font-size: 24px;
    line-height: 133%;
    color: #222;
}

.about-adv-text {
    margin: 0 0 20px 0;
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 16px;
    line-height: 175%;
    color: #222;
}

.about-page-title {
    text-align: left;
    color: #222;
    margin: 0 0 32px;
}

.slider-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 24px;
}

.slider-caption {
    font-family: var(--font-family);
    font-weight: 500;
    font-size: 12px;
    line-height: 150%;
    text-transform: uppercase;
    color: #f63b60;
}

.slider-caption-light {
    color: rgba(255, 255, 255, 0.7);
}

.slider-arrows {
    display: flex;
    gap: 12px;
}

.slider-prev,
.slider-next {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: #fff;
    border: 1px solid #ececec;
    position: relative;
    cursor: pointer;
}

.team-block .slider-prev,
.team-block .slider-next {
    background: rgba(255, 255, 255, 0.12);
    border-color: rgba(255, 255, 255, 0.15);
}

.slider-prev::before,
.slider-next::before {
    content: "";
    position: absolute;
    inset: 0;
    margin: auto;
    width: 8px;
    height: 8px;
    border-top: 2px solid #f63b60;
    border-right: 2px solid #f63b60;
}

.slider-prev::before {
    transform: rotate(-135deg);
    left: 2px;
}

.slider-next::before {
    transform: rotate(45deg);
    right: 2px;
}

.team-block .slider-prev::before,
.team-block .slider-next::before {
    border-color: #fff;
}

.about-media {
    padding: 30px 0 54px;
    background: #fff;
}

.media-card {
    background: #fff;
    border: 1px solid #ececec;
    border-radius: 8px;
    overflow: hidden;
    height: 100%;
}

.media-card img {
    width: 100%;
    height: 186px;
    object-fit: cover;
    display: block;
}

.media-card-body {
    padding: 20px 20px 24px;
}

.media-card-meta {
    margin-bottom: 12px;
    font-size: 12px;
    line-height: 150%;
    text-transform: uppercase;
    color: #0089ce;
}

.media-card h3 {
    margin: 0 0 12px;
    font-family: var(--font-family);
    font-weight: 500;
    font-size: 18px;
    line-height: 144%;
    color: #222;
}

.media-card p {
    margin: 0 0 20px;
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 14px;
    line-height: 157%;
    color: rgba(34, 34, 34, 0.76);
}

.media-card-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 32px;
    padding: 10px 18px;
    background: linear-gradient(125deg, #ff9b70 0%, #f63b60 100%);
    font-family: var(--font-family);
    font-weight: 500;
    font-size: 13px;
    color: #fff;
}

.projects.certificates,
.letters.projects
 {
    background: #fff;
}

.letters.projects {
    padding-top: 18px;
}

.team-block {
    padding: 16px 0 0;
}

.form-policy {
    display: grid;
    grid-template-columns: 18px 1fr;
    gap: 12px;
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 12px;
    line-height: 150%;
    color: rgba(255, 255, 255, 0.74);
}
#projects-part-2 {
    padding-bottom: 120px !important;
}
.form-policy a {
    color: #fff;
    text-decoration: underline;
}

.page-service-screen {
    background: #fff;
    color: #222;
}

.service-header {
    background: #fff;
    border-radius: 0 0 28px 28px;
    box-shadow: 0 8px 24px rgba(20, 10, 40, 0.04);
}

.service-header .header-menu-link,
.service-header .header-phone {
    color: #222;
}

.service-header .header-menu-link:hover,
.service-header .header-menu-link.active {
    color: #f63b60;
}

.service-header-phone {
    font-size: 15px;
}

.service-page {
    padding: 44px 0 46px;
}

.service-breadcrumbs {
    margin-top: 40px;
    margin-bottom: 34px;
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 12px;
    line-height: 150%;
    color: rgba(34, 34, 34, 0.42);
}
.service-breadcrumbs-1 {
    margin-top: 40px;
    margin-bottom: 34px;
}
.service-breadcrumbs-1 a, .service-breadcrumbs-1 {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 14px;
    color: rgba(255, 255, 255, 0.6);
}
.service-breadcrumbs a, .service-breadcrumbs {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 14px;
    color: rgba(34, 34, 34, 0.6);
}
.service-page-title {
    margin: 0 0 36px;
    font-family: var(--second-family);
    font-weight: 700;
    font-size: 56px;
    line-height: 110%;
    color: #222;
}

.service-grid {
    row-gap: 20px;
}

.service-light-card {
    background: #f4f4f4;
    border-radius: 8px;
    padding: 24px;
    height: calc(100% - 48px);
}

.service-light-card-small {
    min-height: 144px;
}

.service-light-card-wide {
    min-height: 170px;
}

.service-light-title {
    color: #222;
}

.service-light-text {
    padding-left: 64px;
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 14px;
    line-height: 157%;
    color: rgba(34, 34, 34, 0.74);
}

.service-light-price {
    margin-top: 22px;
    padding-left: 64px;
    font-family: var(--font-family);
    font-weight: 500;
    font-size: 28px;
    line-height: 114%;
    color: #222;
}

.service-form-section {
    padding-bottom: 54px;
}

@media (max-width: 650px) {
    .service-header {
        border-radius: 0 0 20px 20px;
    }

    .service-page {
        padding: 28px 0 32px;
    }

    .service-breadcrumbs {
        margin-bottom: 22px;
    }

    .service-page-title {
        font-size: 40px;
        margin-bottom: 26px;
    }

    .service-light-card,
    .service-light-card-small,
    .service-light-card-wide {
        min-height: auto;
    }

    .service-light-price {
        font-size: 24px;
    }

    .about-company-hero {
        padding-top: 0;
    }

    .about-company-shell {
        padding: 28px 24px;
        border-radius: 0 0 28px 28px;
    }

    .about-company-title {
        font-size: 34px;
        margin-bottom: 18px;
    }

    .about-company-visual {
        min-height: 190px;
        margin-top: 12px;
    }

    .about-company-shape-a {
        width: 82px;
        height: 82px;
        right: 70px;
    }

    .about-company-shape-b {
        width: 92px;
        height: 92px;
        right: 12px;
        top: 72px;
    }

    .about-company-shape-c {
        width: 66px;
        height: 66px;
        right: 108px;
        top: 102px;
    }

    .about-advantages {
        padding-bottom: 28px;
    }

    .about-page-title {
        margin-bottom: 24px;
    }

    .slider-nav {
        margin-top: 18px;
    }

    .media-card img {
        height: 160px;
    }

    .media-card h3 {
        font-size: 16px;
    }

    .page-about {
        background:
            radial-gradient(circle at top center, rgba(246, 59, 96, 0.25), transparent 30%),
            linear-gradient(180deg, #0a0018 0%, #120327 22%, #fff 22%, #fff 100%);
    }

    .about-header {
        position: static;
        border-radius: 0 0 24px 24px;
    }

    .about-title {
        font-size: 36px;
    }

    .about-lead,
    .about-section-text,
    .about-story-card p,
    .about-principle p,
    .process-step p,
    .about-team-note,
    .expertise-feature p {
        font-size: 16px;
        line-height: 162%;
    }

    .about-story-columns,
    .about-principles,
    .about-footer-menu {
        grid-template-columns: 1fr;
    }

    .about-hero,
    .about-expertise,
    .about-process,
    .about-team,
    .about-cta {
        padding-top: 48px;
    }

    .about-hero-card,
    .about-story-card,
    .expertise-feature,
    .process-step,
    .about-team-copy,
    .about-cta-box {
        padding: 24px;
    }

    .team-visual-card {
        min-height: 320px;
    }

    .about-cta-actions {
        margin-top: 24px;
    }

    .about-header-grid,
    .about-footer-grid,
    .footer-bottom-row {
        row-gap: 20px;
    }

    .footer-bottom-row {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    .projects-mosaic-row {
        width: 100%;
        margin-left: 0 !important;
        flex-wrap: wrap;
    }

    .project-card,
    .project-card-small,
    .project-card-case {
        flex: 0 0 calc(50% - 10px);
    }
    .bar {
        position: fixed;
        right: 31px;
        top: 37px;
        z-index: 100;
        width: 23px;
        height: 23px;
    }
    .bar-unactive {
        background: url("/images/bar.svg") center no-repeat;
    }
    .bar-active {
        background: url("/images/close.png") center no-repeat;
    }


}

.certificates-page {
    padding-bottom: 28px;
}

.cert-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
}

.cert-tile {
    display: block;
    border-radius: 8px;
    overflow: hidden;
    background: #f6f6f6;
    border: 1px solid #ececec;
}

.cert-tile img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.cases-page {
    padding-bottom: 28px;
}

.cases-filter {
    margin-bottom: 24px;
}

.cases-filter-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 8px 16px;
    background: #f4f4f4;
    font-size: 13px;
    font-weight: 500;
    color: #222;
}

.cases-filter-pill.active {
    background: #f63b60;
    color: #fff;
}

.cases-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
}

.cases-grid-compact {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.cases-card,
.related-card {
    position: relative;
    display: block;
    border-radius: 8px;
    overflow: hidden;
    background: #eee;
}

.cases-card img,
.related-card img {
    width: 100%;
    display: block;
    aspect-ratio: 380 / 240;
    object-fit: cover;
}

.cases-badge {
    position: absolute;
    left: 24px;
    bottom: 24px;
    border-radius: 8px;
    padding: 4px 8px;
    background: #f63b60;
    font-family: var(--font-family);
    font-weight: 500;
    font-size: 13px;
    line-height: 154%;
    color: #fff;
}
.case-name {
    font-family: var(--second-family);
    font-weight: 700;
    font-size: 40px;
    line-height: 120%;
    color: #222;
    margin-bottom: 32px;
}
.case-text {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 16px;
    line-height: 175%;
    color: #222;
}
.mb-48 {
    margin-bottom: 48px !important;
}
.mb-120 {
    margin-bottom: 120px !important;
}
.case-image {
    aspect-ratio: 580 / 388;
    width: 100%;
    object-fit: cover;
    object-position: center;
    border-radius: 16px;
}
.case-page {
    padding-bottom: 32px;
}

.case-title {
    margin: 0 0 40px;
    max-width: 840px;
    font-family: var(--second-family);
    font-weight: 700;
    font-size: 44px;
    line-height: 118%;
    color: #222;
}

.case-section {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(320px, 0.8fr);
    gap: 48px;
    align-items: start;
    margin-bottom: 48px;
}

.case-copy h2,
.case-review h2,
.related-projects h2,
.context-title {
    margin: 0 0 18px;
    font-family: var(--font-family);
    font-weight: 500;
    font-size: 28px;
    line-height: 120%;
    color: #222;
}

.case-copy p,
.case-review blockquote,
.service-kicker,
.context-card li,
.context-card h3,
.context-card ul {
    font-family: var(--font-family);
}

.case-copy p {
    margin: 0 0 14px;
    font-size: 16px;
    line-height: 170%;
    color: rgba(34, 34, 34, 0.78);
}

.case-visual,
.case-visual-inner {
    min-height: 220px;
    border-radius: 8px;
    background: #f2f2f2;
}

.case-visual-gallery {
    display: grid;
    gap: 12px;
}

.case-thumbs {
    display: flex;
    gap: 8px;
    justify-content: center;
}

.case-thumbs span {
    width: 56px;
    height: 28px;
    border-radius: 4px;
    background: #f2f2f2;
}

.case-review {
    padding: 36px 0 24px;
}

.case-review blockquote {
    margin: 0 0 20px;
    max-width: 760px;
    font-size: 18px;
    line-height: 170%;
    color: rgba(34, 34, 34, 0.8);
}

.case-review-author {
    font-weight: 500;
    margin-bottom: 6px;
}

.case-review-role {
    color: rgba(34, 34, 34, 0.6);
}

.related-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
}

.page-dark-screen {
    background: #0a0018;
    color: #fff;
}

.dark-hero,
.dark-form-section,
.context-packages,
.context-projects {
    background: #0a0018;
}

.dark-hero {
    padding: 22px 0 36px;
}

.dark-hero-shell,
.media-hero-shell {
    border-radius: 0 0 44px 44px;
    overflow: hidden;
    padding: 42px 56px;
}

.dark-hero-shell {
    background: radial-gradient(circle at 84% 62%, rgba(246, 59, 96, 0.85), transparent 16%), linear-gradient(104deg, #17012d 0%, #17012d 64%, #34104d 100%);
}

.dark-hero-grid,
.media-hero-grid {
    align-items: center;
}

.dark-hero-title,
.media-hero-title {
    margin: 0 0 20px;
    font-family: var(--second-family);
    font-size: 56px;
    line-height: 108%;
    font-weight: 700;
    color: #fff;
}

.dark-hero-text,
.media-hero-text {
    max-width: 560px;
    font-size: 16px;
    line-height: 170%;
    color: rgba(255, 255, 255, 0.76);
}

.price-tabs {
    display: flex;
    gap: 12px;
    margin-top: 36px;
}

.price-tabs span {
    border-radius: 999px;
    padding: 12px 22px;
    background: rgba(255, 255, 255, 0.08);
    color: #fff;
}

.price-tabs .active {
    background: linear-gradient(125deg, #ff9b70 0%, #f63b60 100%);
}

.price-hero-visual,
.context-hero-visual,
.media-hero-visual {
    min-height: 260px;
    border-radius: 20px;
}

.price-hero-visual {
    background: linear-gradient(180deg, #ffb07e 0%, #f63b60 100%);
}

.context-hero-visual {
    background: linear-gradient(180deg, #ffb08f 0%, #f46b8f 55%, #5a2f66 100%);
}

.pricing-cards {
    padding: 24px 0 40px;
}

.price-card {
    background: #fff;
    color: #222;
    border-radius: 16px;
    padding: 28px;
    height: calc(100% - 56px);
}

.price-card h2 {
    margin: 0 0 18px;
    font-size: 38px;
    line-height: 110%;
}

.price-card h3 {
    margin: 0 0 14px;
    font-size: 20px;
}

.price-card ul {
    margin: 0 0 24px;
    padding-left: 18px;
    color: rgba(34, 34, 34, 0.8);
    line-height: 165%;
}

.price-card-value {
    font-size: 42px;
    font-weight: 700;
    margin-bottom: 8px;
}

.price-card-time {
    color: rgba(34, 34, 34, 0.56);
    margin-bottom: 22px;
}

.media-breadcrumbs {
    color: rgba(255, 255, 255, 0.45);
}

.page-media-screen {
    background: linear-gradient(180deg, #fff 0%, #fff 28%, #ffe6eb 74%, #fff 100%);
}

.media-hero {
    background: #fff;
    padding-top: 22px;
}

.media-hero-shell {
    background: radial-gradient(circle at 84% 62%, rgba(246, 59, 96, 0.85), transparent 16%), linear-gradient(104deg, #17012d 0%, #17012d 64%, #34104d 100%);
}

.media-hero-visual {
    background: linear-gradient(180deg, #ffb39a 0%, #f46b8f 55%, #613a6a 100%);
}

.media-columns {
    padding: 34px 0 56px;
}

.media-columns-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
    align-items: start;
}

.media-stack-card {
    background: rgba(255, 255, 255, 0.92);
    border-radius: 10px;
    border: 1px solid rgba(255, 255, 255, 0.8);
    overflow: hidden;
    box-shadow: 0 18px 50px rgba(246, 59, 96, 0.08);
}

.media-stack-card img {
    display: block;
    width: 100%;
    height: 170px;
    object-fit: cover;
}

.media-stack-body {
    padding: 18px;
}

.media-stack-body h3 {
    margin: 0 0 12px;
    font-size: 18px;
    line-height: 145%;
}

.media-stack-body p {
    margin: 0 0 18px;
    color: rgba(34, 34, 34, 0.74);
    line-height: 160%;
}

.media-stack-card-highlight {
    min-height: 220px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(180deg, rgba(246, 59, 96, 0.18), rgba(255, 255, 255, 0.9));
}

.media-stack-quote {
    max-width: 240px;
    font-size: 28px;
    line-height: 120%;
    color: #f63b60;
}

.media-pagination {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: 28px;
}

.media-pagination span {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: rgba(246, 59, 96, 0.3);
}

.media-pagination .active {
    background: #f63b60;
}

.service-kicker {
    margin-bottom: 16px;
    color: #f9909f;
    text-transform: uppercase;
    font-size: 13px;
}

.context-packages,
.context-projects {
    padding: 16px 0 32px;
    color: #fff;
}

.context-card {
    background: #fff;
    color: #222;
    border-radius: 10px;
    padding: 24px;
    height: calc(100% - 48px);
}

.context-card h3 {
    margin: 0 0 18px;
    font-size: 24px;
}

.context-card ul {
    margin: 0 0 20px;
    padding-left: 18px;
    color: rgba(34, 34, 34, 0.75);
    line-height: 160%;
}

.context-price {
    color: #f63b60;
    font-weight: 700;
    font-size: 28px;
}
.white-body {
    background: #fff;
}
.h1-inside {
    font-family: var(--second-family);
    font-weight: 700;
    font-size: 48px;
    line-height: 117%;
    color: #222;
}
.black-bgr {
    background: #0A0018;
}
.content {
    min-height: calc(100vh - 401px);
}
@media (max-width: 900px) {
    .cert-grid,
    .cases-grid,
    .related-grid,
    .media-columns-grid {
        grid-template-columns: 1fr 1fr;
    }

    .cases-grid-compact {
        grid-template-columns: 1fr 1fr;
    }

    .case-section {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .dark-hero-shell,
    .media-hero-shell {
        padding: 28px 24px;
        border-radius: 0 0 28px 28px;
    }

    .dark-hero-title,
    .media-hero-title,
    .case-title,
    .service-page-title {
        font-size: 36px;
    }
}

@media (max-width: 650px) {
    .cert-grid,
    .cases-grid,
    .related-grid,
    .media-columns-grid,
    .cases-grid-compact {
        grid-template-columns: 1fr;
    }

    .price-card h2 {
        font-size: 30px;
    }

    .price-card-value {
        font-size: 34px;
    }

    .media-stack-quote {
        font-size: 22px;
    }
}
