/* Основные переменные цветов */
:root {
    --color-primary: #D50E2E;
    --color-dark: #1A1A1A;
    --color-light-bg: #EFF3FF;
    --color-white: #FFFFFF;
    --font-roboto: 'Roboto', sans-serif;
    --font-roboto-condensed: 'Roboto Condensed', sans-serif;
}

/* Сброс стилей */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
}

body {
    font-family: var(--font-roboto);
    color: var(--color-dark);
    line-height: 1.4;
    overflow-x: hidden;
    max-width: 100%;
    width: 100%;
    min-height: 100vh;
    min-height: -webkit-fill-available;
    position: relative;
}

img {
    max-width: 100%;
    height: auto;
}

a {
    text-decoration: none;
    color: inherit;
    transition: all 0.3s ease;
}

button {
    transition: all 0.3s ease;
    cursor: pointer;
}

button:hover {
    transform: translateY(-2px);
}

button:active {
    transform: translateY(0);
}

.header {
    position: absolute;
    top: 20px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10;
    background: rgba(255, 255, 255, 0.12);

    border-radius: 14px;
    padding: 20px 80px;
    width: calc(100% - 40px);
    max-width: calc(100vw - 40px);
    box-sizing: border-box;
}

.header--inner.header {
    position: relative;
    background: #1A1A1A;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border-radius: 14px;
    box-sizing: border-box;
    width: calc(100% - 65px);
    left: unset;
    transform: unset;
    max-width: 100%;
    /* Из-за смещения relative - тяжело рассчитывать отступы у низлежащих блоков */
    top:0;
    margin: 20px auto 0;
}


/* Main Content */
.main-content {
    min-height: calc(100vh - 445px);
}

/* Main content for inner pages with fixed header */
.main-content--inner {
    padding-top: 0;
}

/* Hero Section */
.hero {
    position: relative;
    background: url('../images/hero-bg.webp') center/cover no-repeat;
    border-radius: 22px;
    padding: 20px;
    margin: 20px 12.5px 50px;
    min-height: 862px;
    overflow: visible;
    max-width: calc(100vw - 40px);
    box-sizing: border-box;
}



.hero::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 22px;
    background: rgba(0, 0, 0, 0.6);
    z-index: 1;
}

.hero__content {
    position: relative;
    z-index: 2;
    padding: 236px 160px 15px;
}

.hero__title {
    font-family: var(--font-roboto-condensed);
    font-weight: 800;
    font-size: 62px;
    line-height: 1.2;
    letter-spacing: 1.24px;
    text-transform: uppercase;
    color: var(--color-white);
    margin-bottom: 30px;
    max-width: 1430px;
}
.hero__title.mobile {
    display: none;
}

.inline {
    display: inline-block;
}


.hero__title span {
    background: var(--color-primary);
    border-radius: 12px;
    padding: 7px 14px;
    margin-bottom: 5px;
    display: inline-block;
}


.hero__description {
    font-size: 22px;
    line-height: 1.2;
    color: var(--color-white);
    margin-bottom: 25px;
    max-width: 850px;
}

.hero__metal {
    height: 130px;
    border-radius: 15px;
    opacity: 1;
    background: rgba(213, 14, 46, 0.7);
    margin-bottom: 25px;
    padding: 25px;
    display: flex;
}

.hero__metal--desktop {
    display: flex;
    align-items: center;
}

.hero__metal-calendar {
    width: 75px;
    height: 75px;
}
.hero__metal-date {
    font-family: var(--font-roboto);
    font-weight: 800;
    font-size: 30px;
    line-height: 120%;
    letter-spacing: 0;
    color: var(--color-white);
    align-self: center;
    margin-left: 15px;
    white-space: nowrap;
}

.hero__metal-division {
    height: 70px;
    width: 0;
    background-color: var(--color-white);
    margin: auto 25px;
    border-left: 1px white solid;
}

.hero__metal--name {
    white-space: nowrap;
}

.hero__metal--name--caption {
    font-family: var(--font-roboto);
    font-weight: 800;
    font-size: 42px;
    line-height: 120%;
    letter-spacing: 2%;
    text-transform: uppercase;
    color: var(--color-white);
}
.hero__metal--name--caption-mobile {
    display: none;
}
.hero__metal--name--detail {
    color: var(--color-white);
    font-family: var(--font-roboto);
    font-weight: 300;
    font-size: 22px;
    line-height: 120%;
    letter-spacing: 0%;

}
.hero__metal--name--detail span {
    font-family: var(--font-roboto);
    font-weight: 700;
    font-size: 22px;
    leading-trim: NONE;
    line-height: 120%;
    letter-spacing: 0%;
}
.hero__metal--button {
    width: 400px;
    height: 80px;
    border-radius: 8px;
    display: flex;
    padding: 25px;
    background-color: var(--color-white);
    justify-content: space-between;
    margin: auto 0 auto auto;
}
.hero__metal--button span{
    font-family: var(--font-roboto);
    font-weight: 800;
    font-size: 26px;
    line-height: 120%;
    letter-spacing: 2%;
    text-transform: uppercase;
    color: rgba(213, 14, 46, 1);
}

/* Hero Button (Mobile only) */
.hero__btn {
    display: none; /* Hidden by default */
    background: var(--color-primary);
    color: var(--color-white);
    padding: 9px 15px;
    border-radius: 6px;
    font-family: var(--font-roboto);
    font-weight: 600;
    font-size: 16px;
    letter-spacing: 0.32px;
    text-transform: uppercase;
    border: none;
    cursor: pointer;
    text-decoration: none;
    margin-bottom: 20px;
    transition: all 0.3s ease;
}

.hero__btn:hover {
    background: #b50c26;
}

.hero__features {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 25px;
}

.hero__feature {
    background: rgba(255, 255, 255, 0.12);
    backdrop-filter: blur(5px);
    border: 1px solid var(--color-white);
    border-radius: 15px;
    padding: 25px;
    transition: all 0.3s ease;
    cursor: pointer;
}

.hero__feature:hover {
    background: rgba(255, 255, 255, 0.2);
    border-color: rgba(255, 255, 255, 0.8);
    transform: translateY(-5px) scale(1.02);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
}

.hero__feature-icon {
    width: 75px;
    height: 75px;
    margin-bottom: 15px;
}

.hero__feature-text {
    font-weight: 800;
    font-size: 20px;
    line-height: 1.2;
    color: var(--color-white);
}

/* Section Title */
.section {
    padding: 50px 192.5px 100px;
}
.section {
    padding: 50px 192.5px;
}
.manufacturer-detail__container {
    padding: 0 192.5px;
}
.manufacturer-supplies__content {
    max-width: 1520px;
    margin: 0 auto;
    padding: 40px 60px;
}

.section__title {
    font-family: var(--font-roboto-condensed);
    font-weight: 800;
    font-size: 56px;
    line-height: 1.3;
    letter-spacing: 1.12px;
    text-transform: uppercase;
}

.section__title--accent {
    color: var(--color-primary);
}

.section__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 50px;
}

 .news-page .section__header, .text.privacy .section__title, .text.privacy.consent h1 {
    margin-bottom: 40px;
 } 

.section__link {
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 600;
    font-size: 16px;
    letter-spacing: 0.32px;
    text-transform: uppercase;
    cursor: pointer;
    transition: color 0.3s ease;
}

.section__link:hover {
    color: var(--color-primary);
}

.section__link-arrow {
    width: 39px;
    height: 39px;
    background: var(--color-primary);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    flex-shrink: 0;
}

.section__link-arrow svg {
    color: white;
}

/* About Section */
.about__content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
}

.about__content.mobile-block {
    display: none;
}

.about__text {
    font-size: 18px;
    line-height: 1.4;
    margin-bottom: 40px;
    width: 190%;
}

.about__image {
    border-radius: 16px;
    overflow: hidden;
    height: 585px;
    max-width: 644px;
}

.about__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.about__stats {
    display: flex;
    flex-direction: column;
    gap: 20px;
    justify-content: flex-end;
}

.about__stat {
    display: flex;
    align-items: center;
    gap: 20px;
    justify-content: flex-end;
}

.about__stat-number {
    font-family: var(--font-roboto-condensed);
    font-weight: 800;
    font-size: 90px;
    color: var(--color-primary);
    line-height: 1.2;
    display: flex;
    align-items: center;
    gap: 10px;
}

.about__stat-plus {
    font-family: var(--font-roboto-condensed);
    font-weight: 800;
    font-size: 46px;
    color: var(--color-primary);
    letter-spacing: 2.3px;
    vertical-align: middle;
}

.about__stat-text {
    font-weight: 800;
    max-width: 278px;
    font-size: 22px;
    line-height: 1.3;
}

/* Кнопка в блоке about на главной - скрыта по умолчанию */
.section:has(.about__content) .about-hero__button-group {
    display: none;
    align-items: center;
    gap: 2px;
}

.section:has(.about__content) .about-hero__button--main {
    display: inline-block;
    background: var(--color-primary);
    color: var(--color-white);
    padding: 9.5px 30px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 18px;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    transition: background 0.2s ease, transform 0.15s ease;
    cursor: pointer;
    border: none;
}

.section:has(.about__content) .about-hero__button--icon {
    width: 44.19px;
    height: 100%;
    background: var(--color-primary);
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 6px 18px rgba(213, 14, 46, 0.12);
    transition: background 0.2s ease, transform 0.15s ease;
    cursor: pointer;
    border: none;
}

.section:has(.about__content) .about-hero__button--icon svg {
    width: 18px;
    height: 14px;
    display: block;
    flex-shrink: 0;
}

.section:has(.about__content) .about-hero__button--icon svg path {
    fill: white;
}

/* Кнопка в блоке catalog на главной - скрыта по умолчанию */
.section:has(.catalog__grid) .about-hero__button-group {
    display: none;
    align-items: center;
    gap: 2px;
}

.section:has(.catalog__grid) .about-hero__button--main {
    display: inline-block;
    background: var(--color-primary);
    color: var(--color-white);
    padding: 9.5px 30px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 18px;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    transition: background 0.2s ease, transform 0.15s ease;
    cursor: pointer;
    border: none;
}

.section:has(.catalog__grid) .about-hero__button--icon {
    width: 44.19px;
    height: 100%;
    background: var(--color-primary);
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 6px 18px rgba(213, 14, 46, 0.12);
    transition: background 0.2s ease, transform 0.15s ease;
    cursor: pointer;
    border: none;
}

.section:has(.catalog__grid) .about-hero__button--icon svg {
    width: 18px;
    height: 14px;
    display: block;
    flex-shrink: 0;
}

.section:has(.catalog__grid) .about-hero__button--icon svg path {
    fill: white;
}

/* Кнопка в блоке partners на главной - скрыта по умолчанию */
.section:has(.partners__grid) .about-hero__button-group {
    display: none;
    align-items: center;
    gap: 2px;
}

.section:has(.partners__grid) .about-hero__button--main {
    display: inline-block;
    background: var(--color-primary);
    color: var(--color-white);
    padding: 9.5px 30px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 18px;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    transition: background 0.2s ease, transform 0.15s ease;
    cursor: pointer;
    border: none;
}

.section:has(.partners__grid) .about-hero__button--icon {
    width: 44.19px;
    height: 100%;
    background: var(--color-primary);
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 6px 18px rgba(213, 14, 46, 0.12);
    transition: background 0.2s ease, transform 0.15s ease;
    cursor: pointer;
    border: none;
}

.section:has(.partners__grid) .about-hero__button--icon svg {
    width: 18px;
    height: 14px;
    display: block;
    flex-shrink: 0;
}

.section:has(.partners__grid) .about-hero__button--icon svg path {
    fill: white;
}

/* Кнопка в блоке geography на главной - скрыта по умолчанию */
.section:has(.geography__content) .about-hero__button-group {
    display: none;
    align-items: center;
    gap: 2px;
}

.section:has(.geography__content) .about-hero__button--main {
    display: inline-block;
    background: var(--color-primary);
    color: var(--color-white);
    padding: 9.5px 30px 8px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 18px;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    transition: background 0.2s ease, transform 0.15s ease;
    cursor: pointer;
    border: none;
}

.section:has(.geography__content) .about-hero__button--icon {
    width: 42.69px;
    height: 100%;
    background: var(--color-primary);
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 6px 18px rgba(213, 14, 46, 0.12);
    transition: background 0.2s ease, transform 0.15s ease;
    cursor: pointer;
    border: none;
}

.section:has(.geography__content) .about-hero__button--icon svg {
    width: 18px;
    height: 14px;
    display: block;
    flex-shrink: 0;
}

.section:has(.geography__content) .about-hero__button--icon svg path {
    fill: white;
}

/* Кнопка в блоке news на главной - скрыта по умолчанию */
.section:has(.news__grid) .about-hero__button-group {
    display: none;
    align-items: center;
    gap: 2px;
}

.section:has(.news__grid) .about-hero__button--main {
    display: inline-block;
    background: var(--color-primary);
    color: var(--color-white);
    padding: 9.5px 30px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 18px;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    transition: background 0.2s ease, transform 0.15s ease;
    cursor: pointer;
    border: none;
}

.section:has(.news__grid) .about-hero__button--icon {
    width: 44.19px;
    height: 100%;
    background: var(--color-primary);
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 6px 18px rgba(213, 14, 46, 0.12);
    transition: background 0.2s ease, transform 0.15s ease;
    cursor: pointer;
    border: none;
}

.section:has(.news__grid) .about-hero__button--icon svg {
    width: 18px;
    height: 14px;
    display: block;
    flex-shrink: 0;
}

.section:has(.news__grid) .about-hero__button--icon svg path {
    fill: white;
}

/* Projects Mobile Version - скрыта по умолчанию */
.projects__mobile-wrapper {
    display: none;
}

.projects__grid--desktop {
    display: flex;
    gap: 60px;
}

/* Catalog Section */
.catalog__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
}

.catalog__item {
    background: var(--color-light-bg);
    border-radius: 18px;
    overflow: hidden;
    position: relative;
    height: 550px;
    transition: all 0.3s ease;
    cursor: pointer;
    display: block;
    text-decoration: none;
}

.catalog__item:hover {
    transform: translateY(-8px);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.15);
}

.catalog__item:hover .catalog__item-image {
    transform: scale(1.05);
}

.catalog__item:hover .catalog__item-arrow {
    opacity: 1;
}

.catalog__item-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.catalog__item-content {
    position: absolute;
    bottom: 25px;
    left: 25px;
}

.catalog__item-title {
    background: var(--color-primary);
    color: var(--color-white);
    padding: 12px 25px;
    border-radius: 8px;
    font-weight: 800;
    font-size: 24px;
    letter-spacing: 0.48px;
    text-transform: uppercase;
    display: inline-block;
}

.catalog__item-arrow {
    width: 39px;
    height: 39px;
    background: var(--color-primary);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: all 0.3s ease;
    flex-shrink: 0;
    position: absolute;
    top: 25px;
    right: 25px;
}

/* Projects Section */
.projects {
    background:
    linear-gradient(
            135deg,
            rgba(0, 0, 0, 0.10) 10%,
            rgba(0, 0, 0, 0.80) 80%
    ),
    url('../images/projects-bg.webp') center / cover no-repeat;
    border-radius: 22px;
    padding: 100px 180px;
    margin: 50px 12.5px 50px;
    color: var(--color-white);
    display: flex;
    gap: 60px;
}

.projects__header {
    flex-shrink: 0;
    min-width: 650px;
    font-family: var(--font-roboto-condensed);
}

.directions__label, .directions__title {
    font-family: var(--font-roboto-condensed);
}

.projects__label {
    background: var(--color-primary);
    border-radius: 10px;
     padding: 5px 15px;
    display: inline-block;
    font-weight: 800;
    font-size: 56px;
    line-height: 1.2;
    letter-spacing: 1px;
}

.projects__title {
    font-size: 56px;
    font-weight: 800;
    line-height: 1.2;
    margin-top: 5px;
    letter-spacing: 1px;
    margin-left: 15px;
}

.projects__grid {
    display: flex;
    flex-direction: column;
    gap: 25px;
    flex: 1;
}

.projects__item {
    background: linear-gradient(261deg, rgba(26, 26, 26, 0.68) 0%, rgba(26, 26, 26, 0.85) 100%);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: 14px;
    padding: 25px;
    transition: all 0.3s ease;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    position: relative;
    text-decoration: none;
    color: inherit;
}

.projects__item:hover {
    background: linear-gradient(261deg, rgba(26, 26, 26, 0.85) 0%, rgba(26, 26, 26, 0.95) 100%);
    border-color: var(--color-primary);
    transform: translateY(-5px);
    box-shadow: 0 10px 30px rgba(236, 28, 36, 0.2);
}

.projects__item-content {
    flex: 1;
}

.projects__item-arrow {
    width: 39px;
    height: 39px;
    background: var(--color-primary);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: all 0.3s ease;
    flex-shrink: 0;
    margin-left: 20px;
}

.projects__item:hover .projects__item-arrow {
    opacity: 1;
}

.projects__item-title {
    font-weight: 800;
    font-size: 24px;
    line-height: 1.2;
    margin-bottom: 15px;
}

.projects__item-text {
    font-size: 18px;
    line-height: 1.4;
}

.projects__btn {
    background: var(--color-primary);
    color: var(--color-white);
    padding: 8px 20px;
    border-radius: 8px;
    font-weight: 700;
    font-size: 20px;
    letter-spacing: 0.4px;
    text-transform: uppercase;
    display: inline-block;
    cursor: pointer;
    transition: all 0.3s ease;
    width: 202px;
    text-align: center;
}

.projects__btn:hover {
    background: #b50c26;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(213, 14, 46, 0.3);
}

/* Partners Section */
.partners__grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 25px;
}

.partners__item {
    background: var(--color-light-bg);
    border-radius: 10px;
    padding: 35px;
    height: 120px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    cursor: pointer;
}

.partners__item:hover {
    background: #e0e7f7;
    transform: translateY(-5px);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.1);
}

.partners__item:hover img {
    transform: scale(1.1);
}

.partners__item img {
    max-height: 50px;
    width: auto;
    transition: transform 0.3s ease;
}

/* Geography Section */
.geography__content {
    display: grid;
    grid-template-columns: 490px 1fr;
    gap: 40px;
}

.geography__list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    justify-content: space-between;
}

.geography__item {
    background: var(--color-light-bg);
    border-radius: 8px;
    padding: 25px 30px;
    font-weight: 800;
    font-size: 24px;
    cursor: pointer;
    transition: all 0.3s ease;
}

.geography__item--active {
    background: var(--color-primary);
    color: var(--color-white);
}

.geography__item:hover {
    background: var(--color-primary);
    color: var(--color-white);
    transform: translateX(5px);
    box-shadow: 0 4px 12px rgba(213, 14, 46, 0.2);
}

.geography__info {
    background: var(--color-light-bg);
    border-radius: 20px;
    padding: 60px 40px 25px 40px;
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: row-reverse;

    align-items: flex-start;
    gap: 10px;
    justify-content: space-between;
}

.geography__background.contactInfo__rowBelow__left__img {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translate(0, -50%);
    height: 100%;
}

.geography__map {
    position: static;
    top: 25px;
    right: 25px;
    width: 542px;
    height: calc(100% - 50px);
    border-radius: 18px;
    overflow: hidden;
    z-index: 2;
    flex: 0 0 auto;
}

.geography__map img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.geography__details {
    max-width: 372px;
    transition: opacity 0.3s ease;
    z-index: 1;
    position: relative;
}

.geography__detail {
    margin-bottom: 30px;
}

.geography__detail-text a {
    color: inherit;
    transition: color 0.3s ease;
}

.geography__detail-text a:hover {
    color: var(--color-primary);
}

.geography__detail-title {
    font-weight: 800;
    font-size: 24px;
    margin-bottom: 10px;
}

.geography__detail-text {
    font-size: 18px;
    line-height: 1.4;
    color: #141414;
    text-align: left;
}

/* Geography Dropdown (Mobile) */
.geography__dropdown {
    display: none; /* Показывается только на мобильных */
    position: relative;
}

.geography__dropdown-btn {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 12px 20px;
    background: var(--color-primary);
    border: none;
    border-radius: 6px;
    font-family: var(--font-roboto);
    font-weight: 800;
    font-size: 16px;
    color: var(--color-white);
    cursor: pointer;
    transition: all 0.3s ease;
    height: 43px;
}

.geography__dropdown-btn:hover {
    color: var(--color-white);
}

.geography__dropdown-arrow {
    width: 33px;
    height: 33px;
    background: var(--color-white);
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.3s ease;
    flex-shrink: 0;
}

.geography__dropdown-arrow svg {
    width: 15px;
    height: 15px;
    fill: var(--color-dark);
}

.geography__dropdown.active .geography__dropdown-arrow {
    transform: rotate(180deg);
}

.geography__dropdown-menu {
    position: absolute;
    top: calc(100% + 12px);
    left: 0;
    right: 0;
    background: var(--color-light-bg);
    border: none;
    border-radius: 10px;
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
    z-index: 100;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.geography__dropdown.active .geography__dropdown-menu {
    max-height: fit-content;
    opacity: 1;
    visibility: visible;
}

.geography__dropdown-item {
    padding: 15px 20px;
    font-family: var(--font-roboto);
    font-weight: 600;
    font-size: 16px;
    color: var(--color-dark);
    cursor: pointer;
    transition: all 0.3s ease;
    border-bottom: none;
    line-height: 1.2;
}

.geography__dropdown-item:first-child {
    padding-top: 20px;
}

.geography__dropdown-item:last-child {
    padding-bottom: 20px;
}

.geography__dropdown-item:hover {
    color: var(--color-primary);
}

.geography__dropdown-item.active {
    font-weight: 800;
    color: var(--color-dark);
}

/* Directions Section */


/* Desktop version wrapper - visible by default */
.directions__desktop {
    background:
            linear-gradient(#1A1A1ACC, #1A1A1AFF),
            url('../images/directions-bg.webp') center/cover no-repeat;
    border-radius: 22px;
    padding: 100px 180px;
    color: var(--color-white);
    margin: 50px 12.5px;

}
.news.section {
    margin-bottom: 50px;
}

/* Mobile version - hidden by default */
.directions__mobile-wrapper {
    display: none;
}

.directions__top {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 25px;
    margin-bottom: 25px;
}


.directions__label {
    background: var(--color-primary);
    border-radius: 10px;
    padding: 5px 15px;
    display: inline-block;
    font-weight: 800;
    font-size: 56px;
    line-height: 1.2;
    letter-spacing: 1px;
    text-transform: uppercase;
}

.directions__title {
    font-size: 56px;
    font-weight: 800;
    line-height: 1.2;
    margin-top: 5px;
    letter-spacing: 1px;
    margin-left: 15px;
    text-transform: uppercase;
}

.directions__description {
    font-size: 18px;
    line-height: 1.4;
    margin-top: 20px;
    font-weight: 400;
    margin-left: 15px;
}

.directions__top-cards {
    display: grid;
    grid-template-columns: 1fr;
    gap: 25px;
}

.directions__bottom {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 25px;
}

.directions__item {
    background: linear-gradient(261deg, rgba(26, 26, 26, 0.68) 0%, rgba(26, 26, 26, 0.85) 100%);
    backdrop-filter: blur(8.891px);
    border: 0.889px solid rgba(255, 255, 255, 0.3);
    border-radius: 14px;
    padding: 25px;
    display: flex;
    gap: 20px;
    transition: all 0.3s ease;
    cursor: pointer;
}
.about-hero__card-text-mobile {
    display: none;
}
.header-directions__item .directions__item-title {
    display: none;
}

.directions__item:hover {
    transform: translateY(-5px);
    background: linear-gradient(261deg, rgba(26, 26, 26, 0.85) 0%, rgba(26, 26, 26, 0.95) 100%);
    border-color: var(--color-primary);
    box-shadow: 0 10px 30px rgba(236, 28, 36, 0.2);
}

.directions__item:hover .directions__item-icon {
    transform: scale(1.1) rotate(5deg);
}

.directions__item-icon {
    width: 83px;
    height: 83px;
    flex-shrink: 0;
    transition: transform 0.3s ease;
}

.directions__item-content {
    flex: 1;
}

.directions__item-title {
    font-weight: 800;
    font-size: 24px;
    line-height: 1.2;
    margin-bottom: 10px;
}

.directions__item-text {
    font-size: 18px;
    line-height: 1.4;
}

/* News Section */
.news__desktop {
    display: block;
}

.news__mobile-wrapper {

}


.news__mobile-wrapper {
    display: block;
}

.news__mobile-header {
    margin-bottom: 30px;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    padding-left: 0;
}

.news__label {
    font-size: 36px;
    font-family: var(--font-roboto-condensed);
    font-weight: 800;
    color: var(--color-dark);
    text-transform: uppercase;
    letter-spacing: 0.72px;
    display: block;
}

/* News Section */


/* Hide desktop, show mobile */


.news__mobile-wrapper {
    display: block;
}


.news__mobile-title {
    font-family: var(--font-roboto-condensed);
    font-size: 36px;
    font-weight: 800;
    line-height: 1.2;
    color: var(--color-primary);
    text-transform: uppercase;
    letter-spacing: 0.72px;
}

/* Slider wrapper - full width, no padding */
.news__slider-wrapper {
    width: 100vw;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    margin-bottom: 20px;
    overflow: visible;
    padding: 0px 200px 0px;
}

.news__slider {
    width: 100%;
}

.news__slider .swiper-wrapper {
    padding-left: 0;
}

.news__slide {
    border-radius: 14px;
    overflow: hidden;
    height: 250px !important;
}

.news__slide-link {
    display: block;
    position: relative;
    width: 100%;
    height: 100%;
}

.news__slide-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.news__slide-overlay {
    position: absolute;
    inset: 0;
    background: rgba(26, 26, 26, 0.7);
    opacity: 0;
    transition: opacity 0.4s ease;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 25px;
}

.news__slide-link:hover .news__slide-overlay,
.news__slide-link:active .news__slide-overlay {
    opacity: 1;
}

.news__slide-content {
    margin-top: auto;
    transform: translateY(20px);
    transition: transform 0.4s ease;
}

.news__slide-link:hover .news__slide-content,
.news__slide-link:active .news__slide-content {
    transform: translateY(0);
}

.news__slide-title {
    font-weight: 800;
    font-size: 18px;
    line-height: 1.2;
    color: var(--color-white);
}

.news__slide-arrow {
    position: absolute;
    top: 25px;
    right: 25px;
    width: 39px;
    height: 39px;
    background: var(--color-primary);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    transform: translateY(20px);
    opacity: 0;
    transition: all 0.4s ease;
}

.news__slide-link:hover .news__slide-arrow,
.news__slide-link:active .news__slide-arrow {
    transform: translateY(0);
    opacity: 1;
}

.news__slide-arrow svg {
    color: white;
}

.news__pagination {
    position: static;
    margin-top: 20px;
    text-align: center;
}

.news__pagination .swiper-pagination-bullet {
    width: 10px;
    height: 10px;
    background: #D9D9D9;
    opacity: 1;
    margin: 0 5px;
}

.news__pagination .swiper-pagination-bullet-active {
    background: var(--color-primary);
}



.news__desktop-btn {
    display: none;
}


.news__desktop-btn {
    display: none;
}

.news__grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 25px;
}

.news__item {
    border-radius: 16px;
    overflow: hidden;
    height: 250px;
    position: relative;
    cursor: pointer;
}

.news__item-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}

.news__item:hover .news__item-image {
    transform: scale(1.05);
}

.news__item-overlay {
    position: absolute;
    inset: 0;
    background: rgba(26, 26, 26, 0.7);
    opacity: 0;
    transition: opacity 0.4s ease;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.news__item:hover .news__item-overlay {
    opacity: 1;
}

.news__item-content {
    padding: 25px;
    margin-top: auto;
    transform: translateY(20px);
    transition: transform 0.4s ease;
}

.news__item:hover .news__item-content {
    transform: translateY(0);
}

.news__item-title {
    font-weight: 800;
    font-size: 20px;
    line-height: 1.2;
    color: var(--color-white);
}

.news__item-arrow {
    position: absolute;
    top: 25px;
    right: 25px;
    width: 39px;
    height: 39px;
    background: var(--color-primary);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    transform: translateY(20px);
    opacity: 0;
    transition: all 0.4s ease;
}

.news__item-arrow svg {
    color: white;
}

.news__item:hover .news__item-arrow {
    transform: translateY(0);
    opacity: 1;
}


/* About Page Styles */

/* About Hero Section */
.about-hero {
    margin: 0 0 50px;
}

.about-hero__top {
    padding: 60px 192.5px 40px;
}

.about-hero__top-container {
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    gap: 25px;
    align-items: flex-start;
}

.about-hero__top-left {
    display: flex;
    flex-direction: column;
}

.about-hero__title {
    font-family: var(--font-roboto-condensed);
    font-weight: 800;
    font-size: 62px;
    line-height: 1.2;
    letter-spacing: 1.24px;
    text-transform: uppercase;
    color: #1A1A1A;
    margin: 0;
}

.about-hero__title .text-red {
    color: var(--color-primary);
}

.about-hero__top-right {
    display: flex;
    flex-direction: column;
    gap: 30px;
}

.about-hero__description {
    font-size: 22px;
    line-height: 1.4;
    color: #1A1A1A;
}

.about-hero__description p {
    margin: 0;
}

.about-hero__button-text {
    font-weight: 600;
    font-size: 16px;
    letter-spacing: 0.32px;
    text-transform: uppercase;
    color: var(--color-white);
}

.about-hero__button svg {
    width: 18px;
    height: 14px;
}

.about-hero__bottom {
    position: relative;
    margin: 0 192.5px;
}

.about-hero__image {
    border-radius: 22px;
    overflow: hidden;
    height: 540px;
}

.about-hero__image.mobile {
    display: none;
}

.about-hero__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* New button group: main label + square icon */
.about-hero__button-group {
   /* display: inline-flex;*/
    display: none;
    grid-template-columns: auto auto;
    align-items: center;
    justify-content: start;
    gap: 2px;
}

.about-hero__button-group.desktop {
    display: inline-grid;
}



.about-hero__button--main {
    display: inline-block;
    background: var(--color-primary);
    color: var(--color-white);
    padding: 9.5px 30px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 20px;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    transition: background 0.2s ease, transform 0.15s ease;
    cursor: pointer;
    border: none;
    line-height: 120%;
}

/* .about-hero__button--main:hover {
    background: #b50c26;
} */

.about-hr__content .about-hero__button--icon {
    display: none;
}

.about-hero__button--icon {
    width: 44.19px;
    height: 100%;
    background: var(--color-primary);
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 6px 18px rgba(213, 14, 46, 0.12);
    transition: background 0.2s ease, transform 0.15s ease;
    cursor: pointer;
    border: none;

}

.about-hero__button--icon svg {
    width: 18px;
    height: 14px;
    display: block;
    flex-shrink: 0;
}

.about-hero__button--icon svg path {
    fill: white;
}

.about-hero__button--icon:hover, .about-hero__button--main:hover {
    background: #b50c26;
}

.about-hero__cards {
    position: absolute;
    bottom: 40px;
    left: 40px;
    right: 40px;
    display: flex;
    gap: 25px;
    z-index: 2;
}

.about-hero__card {
    flex: 1;
    background: rgba(255, 255, 255, 0.18);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid var(--4, #FFF);
    border-radius: 14px;
    padding: 30px 20px;
    transition: all 0.3s ease;
    cursor: pointer;
}

.about-hero__card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
}

.about-hero__card-title {
    font-weight: 800;
    font-size: 24px;
    line-height: 1.2;
    color: var(--color-white);
    margin-bottom: 10px;
}

.about-hero__card-text {
    font-size: 18px;
    line-height: 1.4;
    color: var(--color-white);
    opacity: 0.9;
    max-width: 188px;
}

/* About Goal Section */
.about-goal {
    padding: 50px 192.5px 50px;
}

.about-goal__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    align-items: stretch;
}

.about-goal__grid.tablet {
    display: none;
}

.about-goal__grid.mobile {
    display: none;
}

.about-goal__left {
    display: flex;
    flex-direction: column;
    gap: 40px;

}

.about-goal__title {
    font-family: var(--font-roboto-condensed);
    font-weight: 800;
    font-size: 56px;
    line-height: 1.3;
    letter-spacing: 1.12px;
    text-transform: uppercase;
    color: #1A1A1A;
}

.about-goal__title .text-red {
    color: var(--color-primary);
}

.about-goal__text {
    font-size: 18px;
    line-height: 1.4;
    color: #1A1A1A;
    max-width: 619px;
}

.about-goal__text strong {
    font-weight: 600;
}

.about-goal__highlight {
    background: var(--color-primary);
    border-radius: 8px;
    padding: 10px 25px;
    font-size: 18px;
    line-height: 1.4;
    color: var(--color-white);
}

.about-goal__video {
    position: relative;
    border-radius: 18px;
    overflow: hidden;
    height: 21vw;
    cursor: pointer;
    transition: all 0.3s ease;
    max-height: 396px;
}

.about-goal__video:hover {
    transform: scale(1.02);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
}

.about-goal__video-poster {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
    object-position: 40%;

}

.about-goal__video:hover .about-goal__video-poster {
    transform: scale(1.05);
}

.about-goal__video::after {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.2);
    transition: background 0.3s ease;
}

.about-goal__video:hover::after {
    background: rgba(0, 0, 0, 0.1);
}

.about-goal__video-play {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scaleY(-1);
    width: 58px;
    height: 58px;
    z-index: 2;
    transition: all 0.3s ease;
}

.about-goal__video:hover .about-goal__video-play {
    transform: translate(-50%, -50%) scaleY(-1) scale(1.1);
}

/* About Timeline Section */
.about-timeline {
    padding: 50px 195px;
    background: var(--color-white);
}

.about-timeline__title {
    font-family: var(--font-roboto-condensed);
    font-weight: 800;
    font-size: 56px;
    line-height: 1.3;
    letter-spacing: 1.12px;
    text-transform: uppercase;
    color: #1A1A1A;
    margin-bottom: 50px;
}

.about-timeline__title .text-red {
    color: var(--color-primary);
}

.about-timeline__wrapper {
    position: relative;
    overflow: hidden;
}

.timeline-swiper {
    padding-bottom: 80px;
}

.swiper-wrapper {
    padding-left: 0;
}

.timeline-slide {
    display: flex;
    column-gap: 16px;
    height: 243px;
    user-select: none;
    position: relative;
}

.timeline-slide::before {
    content: '';
    position: absolute;
    left: 6px;
    top: 0;
    height: 243px;
    width: 1px;
    background: #1A1A1A;
}

.timeline-slide__border {
    position: relative;
    height: 100%;
    width: 12px;
    flex-shrink: 0;
    display: flex;
    align-items: flex-start;
    justify-content: center;
}

.timeline-slide__border::before {
    content: '';
    display: block;
    width: 12px;
    height: 12px;
    background: var(--color-primary);
    border-radius: 50%;
    position: relative;
    z-index: 2;
}

.timeline-slide__border::after {
    display: none;
}

.timeline-slide__content {
    flex: 1;
    padding-top: 20px;
    padding-left: 25px;
    height: 250px;
}

.timeline-slide__content::after {
    display: none;
}

.timeline-slide__year {
    font-family: var(--font-roboto-condensed);
    font-weight: 800;
    font-size: 46px;
    line-height: normal;
    color: #1A1A1A;
    margin-bottom: 24px;
}

.timeline-slide__text {
    font-size: 18px;
    line-height: 1.4;
    color: #1A1A1A;
}

.timeline-slide__text p {
    margin: 0;
}

.timeline-slide__text p + p {
    margin-top: 24px;
}

.timeline-scrollbar {
    position: relative;
    margin: 0;
    height: 39px;
}

.timeline-scrollbar__divider {
    position: absolute;
    left: 0;
    right: 0;
    top: 12px;
    height: 11px;
    z-index: 1;
    pointer-events: none;
}

.timeline-scrollbar__divider::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    background-image: repeating-linear-gradient(to right, transparent 0px, transparent 20px, #1A1A1A 20px, #1A1A1A 21px);
}

.timeline-swiper .swiper-scrollbar {
    position: absolute;
    left: 0;
    top: 0 !important;
    transform: translateY(-50%);
    width: 100%;
    height: 39px;
    background: transparent;
    z-index: 2;
}

.timeline-swiper .swiper-scrollbar-drag {
    height: 39px;
    width: 87px;
    min-width: 87px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='87' height='39' viewBox='0 0 87 39' fill='none'%3E%3Crect width='87' height='39' rx='8' fill='%23D50E2E'/%3E%3Cpath d='M30.1077 19.7603C30.1967 19.504 30.0574 19.1753 29.7955 19.0137C29.7259 18.9719 27.3972 18.9547 22.0546 18.9535L14.4083 18.949L17.4439 15.9135C19.41 13.9473 20.5045 12.8306 20.5546 12.747C20.652 12.5716 20.6325 12.2457 20.5099 12.0729C20.3873 11.9002 20.0892 11.7915 19.8636 11.8388L19.7048 11.8694L15.8533 15.7209L11.999 19.5752L15.855 23.4312L19.7082 27.2844L19.867 27.3151C20.0927 27.3625 20.3907 27.2539 20.5132 27.0813C20.6357 26.9086 20.6552 26.5827 20.5576 26.4072C20.5075 26.3236 19.4125 25.2064 17.4455 23.2394L14.4086 20.2025L22.0214 20.2014C26.2136 20.1995 29.6816 20.1864 29.7317 20.1697C29.8626 20.1279 30.0548 19.919 30.1077 19.7603Z' fill='white' stroke='white'/%3E%3Cpath d='M56.2752 19.0053C56.1861 19.2616 56.3254 19.5903 56.5873 19.7519C56.6569 19.7937 58.9856 19.811 64.3282 19.8121L71.9745 19.8166L68.9389 22.8522C66.9728 24.8183 65.8783 25.935 65.8282 26.0186C65.7308 26.1941 65.7503 26.52 65.8729 26.6927C65.9955 26.8654 66.2936 26.9741 66.5192 26.9268L66.678 26.8962L70.5295 23.0447L74.3838 19.1904L70.5278 15.3344L66.6746 11.4812L66.5158 11.4505C66.2902 11.4031 65.9921 11.5117 65.8696 11.6844C65.7471 11.857 65.7277 12.1829 65.8252 12.3585C65.8754 12.442 66.9703 13.5593 68.9373 15.5263L71.9742 18.5631L64.3614 18.5642C60.1692 18.5661 56.7012 18.5793 56.6511 18.596C56.5202 18.6377 56.328 18.8466 56.2752 19.0053Z' fill='white' stroke='white'/%3E%3C/svg%3E");
    background-size: 87px 39px;
    background-repeat: no-repeat;
    background-position: center;
    border-radius: 8px;
    cursor: grab;
    touch-action: pan-y;
}

.timeline-swiper .swiper-scrollbar-drag:active {
    cursor: grabbing;
}

/* About Advantages Section */
.about-advantages {
    padding: 50px 192.5px;
}

.about-advantages__title {
    font-family: var(--font-roboto-condensed);
    font-weight: 800;
    font-size: 56px;
    line-height: 1.3;
    letter-spacing: 1.12px;
    text-transform: uppercase;
    color: #1A1A1A;
    margin-bottom: 50px;
}

.about-advantages__title .text-red {
    color: var(--color-primary);
}

.about-hero__button-group.about-advantages-button {
    margin-top: 25px;
    display: none!important;
}



.about-hero__button-group.about-advantages-button .about-hero__button--icon {
    transform: rotate(90deg);
}


.about-advantages__item {
    overflow: hidden;
    transition: all 0.3s ease;
    max-height: 200px;
}

.about-advantages__item.hidden {
    display: none;
}

.about-advantages-button .about-hero__button--icon {
    transition: transform 0.25s ease;
    transform: rotate(90deg);
}

.about-advantages-button.open .about-hero__button--icon {
    transform: rotate(270deg);
}

.about-advantages__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 25px;
}

.about-advantages__item {
    border: 1px solid #1A1A1A;
    border-radius: 10px;
    padding: 25px;
    min-height: 96px;
    display: flex;
    align-items: center;
    transition: all 0.3s ease;
    cursor: pointer;
}

.about-advantages__item:hover {
    border-color: var(--color-primary);
    transform: translateY(-3px);
    box-shadow: 0 4px 12px rgba(213, 14, 46, 0.15);
}
.about-advantages__item:hover .about-advantages__item-text {
    color: var(--color-primary);
}

.about-advantages__item-text {
    font-size: 18px;
    line-height: 1.4;
    color: #1A1A1A;
}

/* About Geography Section */
.about-geography {
    position: relative;
    margin: 50px 12.5px;
    border-radius: 22px;
    overflow: hidden;
    min-height: 862px;
}

.about-geography__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.about-geography__bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.about-geography__overlay {
    position: absolute;
    inset: 0;
    background: rgba(26, 26, 26, 0.7);
    backdrop-filter: blur(10px);
    z-index: 1;
}

.about-geography__container {
    position: relative;
    z-index: 2;
    padding: 80px clamp(106px, 8vw, 180px);
}

/* Десктопная версия header - внутри контейнера */
.about-geography__header--desktop {
    margin-bottom: -60px;
}

/* Мобильная версия header - скрыта на десктопе */
.about-geography__header--mobile {
    display: none;
}


.about-geography__title {
    font-family: var(--font-roboto-condensed);
    font-weight: 800;
    font-size: 56px;
    line-height: 1.3;
    letter-spacing: 1.12px;
    text-transform: uppercase;
    color: var(--color-white);
    margin: 0;
}

.about-geography__title-red {
    background: var(--color-primary);
    border-radius: 10px;
    padding: 0px 20px;
    display: inline-block;
}

.about-geography__content {
    position: relative;
    width: 100%;
}

.about-geography__map {
    position: relative;
    width: 100%;
}

.about-geography__map-image {
    width: 100%;
    height: auto;
    display: block;
}

.about-geography__cities {
    position: absolute;
    inset: 0;
}

.about-geography__city {
    position: absolute;
    display: flex;
    align-items: center;
    gap: 10px;
    background: rgba(255, 255, 255, 0.15);
    backdrop-filter: blur(7.5px);
    border: 1px solid var(--color-white);
    border-radius: 8px;
    padding: 15px 20px;
    cursor: pointer;
    transition: all 0.3s ease;
}

.about-geography__city:hover,
.about-geography__city--active {
    background: rgba(255, 255, 255, 0.8);
}

.about-geography__city:hover .about-geography__city-name,
.about-geography__city--active .about-geography__city-name {
    color: #1A1A1A;
}

.about-geography__city-icon {
    width: 28px;
    height: 28px;
    transform: scaleY(-1);
}

.about-geography__city-name {
    font-size: 16px;
    line-height: 1.3;
    color: var(--color-white);
}

.about-geography__city--spb {
    top: 27%;
    left: 19%;
}

.about-geography__city--msk {
    top: 42%;
    left: 22%;
}

.about-geography__city--kazan {
    top: 50%;
    left: 35%;
}

.about-geography__city--samara {
    top: 61%;
    left: 19%;
}

.about-geography__city--krasnodar {
    bottom: 22%;
    left: 3%;
}

.about-geography__city--ekb {
    top: 70%;
    left: 35%;
}

.about-geography__city--tyumen {
    bottom: 35%;
    left: 50%;
}

.about-geography__city--nsk {
    bottom: 18%;
    left: 50%;
}

.about-geography__city--vvo {
    bottom: 1%;
    right: 12%;
}

.about-geography__info {
    position: absolute;
    top: 100px;
    right: 0;
    background: rgba(255, 255, 255, 0.12);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid var(--color-white);
    border-radius: 20px;
    padding: 50px;
    min-width: 460px;
    max-width: 460px;
    z-index: 3;
}

.about-geography__info-section {
    margin-bottom: 40px;
}

.about-geography__info-section:last-child {
    margin-bottom: 0;
}

.about-geography__info-title {
    font-weight: 800;
    font-size: 24px;
    line-height: 1.2;
    color: var(--color-white);
    margin-bottom: 15px;
}

.about-geography__info-text {
    font-size: 18px;
    line-height: 1.4;
    color: var(--color-white);
    text-align: left;
    transition: opacity 0.3s ease;
}

.about-geography__city.active {
    background: rgba(255, 255, 255, 0.8);
}

.about-geography__city.active .about-geography__city-name {
    color: #1A1A1A;
}

/* About HR Section */
.about-hr {
    padding: 50px 192.5px 100px;
}

.about-hr__title {
    font-family: var(--font-roboto-condensed);
    font-weight: 800;
    font-size: 56px;
    line-height: 1.3;
    letter-spacing: 1.12px;
    text-transform: uppercase;
    color: #1A1A1A;
    margin-bottom: 50px;
}

.about-hr__title .text-red {
    color: var(--color-primary);
}

.about-hr__content {
    display: grid;
    grid-template-columns: 0.476fr 0.222fr 0.302fr;
    gap: 25px;
}
/* Manufacturer Detail Page Styles */

.manufacturer-detail {
    padding: 40px 0 30px;
  }
  
  
  /* Breadcrumbs */
  .manufacturer-detail__breadcrumbs {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 40px;
    font-size: 16px;
    line-height: 1.4;
    min-width: 0;
  }
  
  .manufacturer-detail__breadcrumb {
    color: #000;
    text-decoration: none;
    transition: color 0.3s ease;
    min-width: 0;
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: break-word;

  }
  
  .manufacturer-detail__breadcrumb:hover {
    color: #E45E58;
  }
  
  .manufacturer-detail__breadcrumb--active {
    color: #1A1A1A;
    font-weight: 700;
  }
  
  .manufacturer-detail__breadcrumb-separator {
    color: #666;
  }
  
  /* Title */
  .manufacturer-detail__title {
    font-size: 56px;
    font-weight: 700;
    line-height: 1.1;
    color: #000;
    margin: 0 0 35px 0;
    text-transform: uppercase;
  }
  
  /* Main Content */
  .manufacturer-detail__content {
    display: grid;
    grid-template-columns: 250px 1fr;
    gap: 64px;
    margin-bottom: 40px;
  }
  
  /* Left Column */
  .manufacturer-detail__left {
    display: flex;
    flex-direction: column;
    gap: 24px;
  }
  
  .manufacturer-detail__logo {
    width: 104px;
    height: 104px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
  }
  
  .manufacturer-detail__logo img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
  }
  
  .manufacturer-detail__info-item {
    display: flex;
    gap: 8px;
  }
  
  .manufacturer-detail__info-label {
    font-size: 18px;
    line-height: 1.8;
    color: var(--color-dark);
    font-weight: 800;
  }
  
  .manufacturer-detail__info-value {
    font-size: 18px;
    line-height: 1.8;
    color: var(--color-dark);
    font-weight: 400;
    display: flex;
    align-items: center;
    gap: 8px;
    white-space: nowrap; 
  }
  
  .manufacturer-detail__country-flag {
    width: 16px;
    height: 11px;
    object-fit: cover;
  }
  
  /* Manufacturers Alphabet Filter Reset Button */
  .manufacturers__alphabet-reset {
    display: inline-block;
    padding: 9px 16px;
    background: var(--color-primary);
    color: var(--color-white);
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.3s ease;
    margin-left: 8px;
    height: fit-content;
  }
  
  .manufacturers__alphabet-reset:hover {
    background: #b50c26;
  }
  
  /* Right Column - USP Block */
  .manufacturer-detail__right {
    flex: 1;
  }
  
  .manufacturer-detail__usp-block {
    background: var(--color-light-bg);
    border-radius: 16px;
    padding: 40px;
    display: flex;
    flex-direction: column;
    gap: 24px;
  }
  
  /* USP Grid */
  .manufacturer-detail__usp-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
  }
  
  .manufacturer-detail__usp-column {
    display: flex;
    flex-direction: column;
    gap: 12px;
    justify-content: space-between;
  }
  
  .manufacturer-detail__usp-item {
    display: flex;
    align-items: center;
    gap: 12px;
  }
  
  .manufacturer-detail__usp-icon {
    flex-shrink: 0;
    width: 39px;
    height: 39px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  
  .manufacturer-detail__usp-icon svg {
    width: 100%;
    height: 100%;
  }
  
  .manufacturer-detail__usp-text {
    font-size: 16px;
    line-height: 1.4;
    color: #000;
    font-weight: 400;
  }
  
  /* Contact Buttons */
  .manufacturer-detail__contact-buttons {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
  }
  
  .manufacturer-detail__button {
    height: 49px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    font-size: 16px;
    line-height: 1.5;
    font-weight: 500;
    text-decoration: none;
    transition: all 0.3s ease;
    cursor: pointer;
    border: none;
    text-transform: uppercase;
  }
  
  .manufacturer-detail__button--primary {
    background: var(--color-primary);
    color: #fff;
  }
  
  .manufacturer-detail__button--primary:hover {
    background: #b50c26;
  }
  
  .manufacturer-detail__button--secondary {
    background: transparent;
    color: var(--color-primary);
    border: 1px solid var(--color-primary);
    font-weight: 600;
  }
  
  .manufacturer-detail__button--secondary:hover {
    background: var(--color-primary);
    color: var(--color-white)
  }
  
  /* Notice */
  .manufacturer-detail__notice {
    display: flex;
    align-items: center;
    gap: 10px;
  }
  
  .manufacturer-detail__notice-icon {
    flex-shrink: 0;
    width: 50px;
    height: 50px;
  }
  
  .manufacturer-detail__notice-text {
    font-size: 14px;
    line-height: 1.5;
    color: var(--color-dark);
    margin: 0;
  }
  
  /* Description */
  .manufacturer-detail__description {
      color: var(--color-dark);
  }
  
  .manufacturer-detail__description h3 {
      font-size: 24px;
      font-weight: 800;
      line-height: 1.2;
      margin: 0 0 12px 0;
  }
  
  .manufacturer-detail__description p {
      font-size: 18px;
      font-weight: 400;
      line-height: 1.4;
      margin: 0 0 16px 0;
  }
  
  .manufacturer-detail__description ul {
      margin: 0 0 16px 0;
      padding-left: 25px;
      list-style: disc;
  }
  
  .manufacturer-detail__description li {
      font-size: 18px;
      font-weight: 400;
      line-height: 1.4;
      margin: 0 0 6px 0;
      list-style: disc;
  }
  
  .manufacturer-detail__description li:last-child,
  .manufacturer-detail__description p:last-child {
      margin-bottom: 0;
  }
  
  /* Manufacturer Categories */
  .manufacturer-categories {
      margin: 30px 0 0;
  }
  
  
  
  .manufacturer-categories__title {
      font-family: var(--font-roboto-condensed);
      font-size: 56px;
      font-weight: 800;
      line-height: 1.3;
      letter-spacing: 1.12px;
      text-transform: uppercase;
      color: #1A1A1A;
      margin: 0 0 32px 0;
  }
  
  .manufacturer-categories__grid {
      display: grid;
      grid-template-columns: repeat(6, minmax(0, 1fr));
      gap: 25px;
  }
  
  .manufacturer-categories__extra {
      overflow: hidden;
      max-height: 0;
      opacity: 0;
      transition: max-height 0.5s ease, opacity 0.35s ease;
  }
  
  .manufacturer-categories__grid--extra {
      margin-top: 25px;
  }
  
  .manufacturer-categories--expanded .manufacturer-categories__extra {
      max-height: 1200px;
      opacity: 1;
  }
  
  .manufacturer-categories__item {
      border: 1px solid #1A1A1A;
      border-radius: 12px;
      min-height: 268px;
      padding: 24px 16px 20px;
      display: flex;
      flex-direction: column;
      align-items: center;
      text-align: center;
      transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease, opacity 0.35s ease;
  }
  
  .manufacturer-categories__item:hover {
      transform: translateY(-4px);
      box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12);
      border-color: var(--color-primary);
  }
  
  
  .manufacturer-categories__image {
      width: 150px;
      height: 150px;
      display: flex;
      align-items: center;
      justify-content: center;
      margin-bottom: 18px;
  }
  
  .manufacturer-categories__image img {
      width: 100%;
      height: 100%;
      object-fit: contain;
  }
  
  .manufacturer-categories__name {
      font-size: 18px;
      font-weight: 800;
      line-height: 1.3;
      color: #1A1A1A;
  }
  
  .manufacturer-categories__toggle {
      margin-top: 20px;
      display: inline-flex;
      align-items: center;
      gap: 6px;
      background: transparent;
      border: none;
      cursor: pointer;
      padding: 0;
  }
  
  .manufacturer-categories__toggle-text {
      background: var(--color-primary);
      color: var(--color-white);
      font-size: 20px;
      font-weight: 600;
      line-height: 1.2;
      letter-spacing: 0.4px;
      text-transform: uppercase;
      padding: 10px 18px;
      border-radius: 6px;
      transition: background 0.25s ease, transform 0.25s ease;
  }
  
  .manufacturer-categories__toggle-icon {
      width: 44px;
      height: 44px;
      background: var(--color-primary);
      border-radius: 6px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      transition: background 0.25s ease, transform 0.25s ease;
  }
  
  .manufacturer-categories__toggle-icon svg {
      width: 18px;
      height: 14px;
      transform: rotate(90deg);
      transition: transform 0.35s ease;
  }
  
  .manufacturer-categories--expanded .manufacturer-categories__toggle-icon svg {
      transform: rotate(-90deg);
  }
  
  .manufacturer-categories__toggle:hover .manufacturer-categories__toggle-text,
  .manufacturer-categories__toggle:hover .manufacturer-categories__toggle-icon {
      background: #b50c26;
  }
  
  /* Manufacturer Supplies */
  .manufacturer-supplies {
      margin: 70px 0 0;
  }
  .manufacturer-supplies__bg .mobile-supplies_img {
      display: none !important;
  }
  .manufacturer-supplies {
      padding: 0 192.5px;
  }
  
  .manufacturer-supplies__link {
      display: block;
      position: relative;
      text-decoration: none;
      color: inherit;
  }
  
  .manufacturer-supplies__container {
      position: relative;
  }
  
  .manufacturer-supplies__bg {
      position: relative;
      border-radius: 14px;
      overflow: hidden;
      min-height: 312px;
  }
  
  .manufacturer-supplies__bg img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      min-height: 312px
  }
  
  /* .manufacturer-supplies__overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(90deg, rgba(0, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0) 122.43%);
  } */
  
  .manufacturer-supplies__content {
      position: absolute;
      inset: 0;
      z-index: 2;
      color: #fff;
  }
  
  .manufacturer-supplies__title {
      font-family: var(--font-roboto-condensed);
      font-size: 56px;
      font-weight: 800;
      line-height: 1.2;
      letter-spacing: 1.12px;
      text-transform: uppercase;
      position: absolute;
      top: 40px;
      left: 60px;
      right: 60px;
      display: inline-flex;
      flex-wrap: wrap;
      align-items: center;
      gap: 12px;
  }
  
  .manufacturer-supplies__title-pill {
      background: var(--color-primary);
      color: #fff;
      padding: 0 10px;
      border-radius: 12px;
      display: inline-block;
  }
  
  .manufacturer-supplies__logo {
      width: 151px;
      height: 44px;
      position: absolute;
      left: 60px;
      bottom: 40px;
  }
  
  .manufacturer-supplies__logo img {
      width: 100%;
      height: 100%;
      object-fit: contain;
  }
  
  .manufacturer-supplies__button {
      position: absolute;
      right: 60px;
      bottom: 40px;
      display: inline-flex;
      align-items: center;
      gap: 6px;
      text-decoration: none;
  }
  
  .manufacturer-supplies__button-text {
      background: var(--color-primary);
      color: #fff;
      font-size: 20px;
      font-weight: 600;
      line-height: 1.2;
      letter-spacing: 0.4px;
      text-transform: uppercase;
      padding: 10px 18px;
      border-radius: 6px;
      transition: background 0.25s ease;
  }
  
  .manufacturer-supplies__button-icon {
      width: 44px;
      height: 44px;
      background: var(--color-primary);
      border-radius: 6px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      transition: background 0.25s ease;
  }
  
  .manufacturer-supplies__button-icon svg {
      width: 18px;
      height: 14px;
  }
  
  .manufacturer-supplies__link:hover .manufacturer-supplies__button-text,
  .manufacturer-supplies__link:hover .manufacturer-supplies__button-icon {
      background: #b50c26;
  }
  
  /* Certificates */
  .manufacturer-detail__certificates {
    margin-top: 60px;
  }
  
  .manufacturer-detail__certificates-title {
    font-size: 32px;
    font-weight: 700;
    line-height: 1.2;
    color: #000;
    margin: 0 0 32px 0;
  }
  
  .manufacturer-detail__certificates-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 24px;
  }
  
  .manufacturer-detail__certificate-item {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 20px;
    background: #F5F5F5;
    border-radius: 8px;
    text-decoration: none;
    transition: all 0.3s ease;
  }
  
  .manufacturer-detail__certificate-item:hover {
    background: #E8E8E8;
    transform: translateY(-2px);
  }
  
  .manufacturer-detail__certificate-icon {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  
  .manufacturer-detail__certificate-icon svg {
    width: 100%;
    height: 100%;
  }
  
  .manufacturer-detail__certificate-name {
    font-size: 14px;
    line-height: 1.4;
    color: #000;
    margin: 0;
  }
  
  .manufacturer-detail__certificate-size {
    font-size: 12px;
    color: #666;
  }

/* Manufacturer Supplies */
.manufacturer-supplies {
    margin: 70px 0 0;
}
.manufacturer-supplies__bg .mobile-supplies_img {
    display: none !important;
}
.manufacturer-supplies {
    padding: 0 192.5px;
}

.manufacturer-supplies__link {
    display: block;
    position: relative;
    text-decoration: none;
    color: inherit;
}

.manufacturer-supplies__container {
    position: relative;
}

.manufacturer-supplies__bg {
    position: relative;
    border-radius: 14px;
    overflow: hidden;
    min-height: 312px;
}

.manufacturer-supplies__bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    min-height: 312px
}

/* .manufacturer-supplies__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(0, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0) 122.43%);
} */

.manufacturer-supplies__content {
    position: absolute;
    inset: 0;
    z-index: 2;
    color: #fff;
}

.manufacturer-supplies__title {
    font-family: var(--font-roboto-condensed);
    font-size: 56px;
    font-weight: 800;
    line-height: 1.2;
    letter-spacing: 1.12px;
    text-transform: uppercase;
    position: absolute;
    top: 40px;
    left: 60px;
    right: 60px;
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
}

.manufacturer-supplies__title-pill {
    background: var(--color-primary);
    color: #fff;
    padding: 0 10px;
    border-radius: 12px;
    display: inline-block;
}

.manufacturer-supplies__logo {
    width: 151px;
    height: 44px;
    position: absolute;
    left: 60px;
    bottom: 40px;
}

.manufacturer-supplies__logo img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.manufacturer-supplies__button {
    position: absolute;
    right: 60px;
    bottom: 40px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    text-decoration: none;
}

.manufacturer-supplies__button-text {
    background: var(--color-primary);
    color: #fff;
    font-size: 20px;
    font-weight: 600;
    line-height: 1.2;
    letter-spacing: 0.4px;
    text-transform: uppercase;
    padding: 10px 18px;
    border-radius: 6px;
    transition: background 0.25s ease;
}

.manufacturer-supplies__button-icon {
    width: 44px;
    height: 44px;
    background: var(--color-primary);
    border-radius: 6px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background 0.25s ease;
}

.manufacturer-supplies__button-icon svg {
    width: 18px;
    height: 14px;
}

.manufacturer-supplies__link:hover .manufacturer-supplies__button-text,
.manufacturer-supplies__link:hover .manufacturer-supplies__button-icon {
    background: #b50c26;
}

/* Certificates */
.manufacturer-detail__certificates {
  margin-top: 60px;
}

.manufacturer-detail__certificates-title {
  font-size: 32px;
  font-weight: 700;
  line-height: 1.2;
  color: #000;
  margin: 0 0 32px 0;
}

.manufacturer-detail__certificates-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 24px;
}

.manufacturer-detail__certificate-item {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 20px;
  background: #F5F5F5;
  border-radius: 8px;
  text-decoration: none;
  transition: all 0.3s ease;
}

.manufacturer-detail__certificate-item:hover {
  background: #E8E8E8;
  transform: translateY(-2px);
}

.manufacturer-detail__certificate-icon {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.manufacturer-detail__certificate-icon svg {
  width: 100%;
  height: 100%;
}

.manufacturer-detail__certificate-name {
  font-size: 14px;
  line-height: 1.4;
  color: #000;
  margin: 0;
}

.manufacturer-detail__certificate-size {
  font-size: 12px;
  color: #666;
}


.about-hr__content .about-hero__button-group {
    margin-top: auto;
}

.about-hr__content.tablet {
    display: none;
}

.about-hr__left {
    display: flex;
    flex-direction: column;
    gap: 25px;
}

.about-hr__item {
    display: flex;
    align-items: center;
    gap: 15px;
    transition: all 0.3s ease;
}

.about-hr__item:hover {
    transform: translateX(5px);
}

.about-hr__icon {
    width: 49px;
    height: 49px;
    flex-shrink: 0;
}

.about-hr__text {
    font-size: 18px;
    line-height: 1.4;
    color: #1A1A1A;
    padding-top: 5px;
}

.about-hr__button {
    display: inline-flex;
    align-items: center;
    background: var(--color-primary);
    border-radius: 8px;
    padding: 10px 25px;
    cursor: pointer;
    align-self: flex-start;
    margin-top: 12px;
    border: none;
    transition: background 0.3s ease;
}

.about-hr__button:hover {
    background: #b50c26;
}

.about-hr__button-text {
    font-weight: 600;
    font-size: 20px;
    letter-spacing: 0.4px;
    text-transform: uppercase;
    color: var(--color-white);
}

.about-hr__center {
    display: flex;
    flex-direction: column;
    gap: 25px;
}

.about-hr__photo {
    border-radius: 14px;
    overflow: hidden;
    height: 249px;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    cursor: pointer;
}

.about-hr__photo:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
}

.about-hr__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.about-hr__photo-large {
    border-radius: 14px;
    overflow: hidden;
    height: 523px;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    cursor: pointer;
}

.about-hr__photo-large:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
}

.about-hr__photo-large img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.scroll-to-top {
    position: fixed;
    right: 20px;
    bottom: 30px;
    width: 45px;
    height: 45px;
    background: #000;
    border-radius: 8px;
    display: none;
    z-index: 1000;
    cursor: pointer;
    justify-content: center;
    align-items: center;
    background: var(--color-primary);
    transition: all 0.3s ease;
}

.scroll-to-top:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(213, 14, 46, 0.3);
}

/* Contact Form Section */
.contact-form-section {
    position: relative;
    margin: 50px 33.5px;
    border-radius: 16px;
    overflow: hidden;
    min-height: 624px;
}

.contact-form-section__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.contact-form-section__bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.contact-form-section__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.25);
    backdrop-filter: blur(1px);
    z-index: 1;
}

.contact-form-section__container {
    position: relative;
    z-index: 2;
    padding: 50px 162.5px;
}

.contact-form-section__header {
    margin-bottom: 40px;
}

.contact-form-section__title {
    font-family: var(--font-roboto-condensed);
    font-weight: 800;
    font-size: 62px;
    line-height: 1.2;
    letter-spacing: 1.24px;
    text-transform: uppercase;
    color: var(--color-white);
    margin: 0 0 20px 0;
}

.contact-form-section__title-red {
    background: var(--color-primary);
    border-radius: 12px;
    padding: 0 10px;
    display: inline-block;
}

.contact-form-section__description {
    font-family: var(--font-roboto);
    font-weight: 600;
    font-size: 22px;
    line-height: 1.2;
    color: var(--color-white);
    margin: 0;
}

.contact-form-section__form {
    display: flex;
    flex-direction: column;
    gap: 25px;
}

.contact-form-section__row {
    display: flex;
    gap: 25px;
}

.contact-form-section__row--three {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 25px;
}

.contact-form-section__row--bottom {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 25px;
    align-items: start;
}

.contact-form-section__left-fields {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 25px;
}

.contact-form-section__right-content {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.contact-form-section__field {
    flex: 1;
}
.contact-form-section__field.contact-form-section__two-field {
    flex: 1;
}
.contact-form-section__field--full {
    width: 100%;
}
.contact-form-section__field--file-list {
    width: 100%;
    display: block;
}
.contact-form-section__field input, .contact-form-section__field select, .contact-form-section__field option {
    width: 100%;
    height: 48px;
    padding: 0 25px;
    font-family: var(--font-roboto);
    font-weight: 400;
    font-size: 18px;
    line-height: 1.4;
    color: #1A1A1A;
    background: var(--color-white);
    backdrop-filter: blur(5px);
    border: none;
    border-radius: 6px;
    outline: none;
    transition: all 0.3s ease;
}

.contact-form-section__field input::placeholder {
    color: rgba(26, 26, 26, 0.6);
}

.contact-form-section__field input:focus {
    box-shadow: 0 0 0 3px rgba(213, 14, 46, 0.3);
}

.contact-form-section__field input.error, .contact-form-section__field select.error {
    box-shadow: 0 0 0 2px #ff4444;
}
.contact-form-section__field--file {
    min-height: 48px;
    background: var(--color-primary);
    backdrop-filter: blur(5px);
    border: none;
    border-radius: 6px;
    position: relative;
    color: var(--color-white);
    text-align: center;
    margin: 2px 0;
}
.contact-form-section__field--file:hover {
    background: #b50c26;
    box-shadow: 0 4px 12px rgba(213, 14, 46, 0.3);
    color: #CD3035;
}
.contact-form-section__field--file.filled {
    background: var(--color-white);
    color: var(--color-primary);
}
.contact-form-section__field--file.filled:hover {
    background: var(--color-white);
    color: var(--color-primary);
}
.contact-form-section__field--file-caption {
    position: relative;
    width: 100%;
    height: inherit;
    line-height: 48px;
    overflow: hidden;
    display: grid;
    /*grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));*/
}
.contact-form-section__field--file-caption div {
    position: relative;
    width: calc(100% - 50px);
    /*padding: 2px 10px;*/
    margin: 0 auto;
    overflow: hidden;
    max-height: 48px;
}
.contact-form-section__field--file-caption div.caption--element:after {
    content: '×';
    position: absolute;
    right: 0;
    top: 0;
    z-index: 200;
    padding: 0 10px;
    background-color: white;
    opacity: .7;
    cursor: pointer;
}
.contact-form-section__field--file-caption div.caption {
    width: 100%;
}
.contact-form-section__field--file-caption div.caption.hidden {
    display: none;
}
.contact-form-section__field--file-caption.grid {
    grid-template-columns: repeat(4, 1fr);
}
.contact-form-section__field.contact-form-section__field--file input.contact-form-section-files {
    height: 100%;
}
.contact-form-section__field--file input {
    width: 100%;
    height: inherit;
    opacity: 0;
    cursor: pointer;
    position: absolute;
    left: 0;
    top: 0;
}
.contact-form-section__textarea {
    width: 100%;
    height: 102px; /*4 строки*/
    padding: 10px 25px;
    font-family: var(--font-roboto);
    font-weight: 400;
    font-size: 18px;
    line-height: 1.4;
    color: #1A1A1A;
    background: var(--color-white);
    backdrop-filter: blur(5px);
    border: none;
    border-radius: 6px;
    outline: none;
    transition: all 0.3s ease;
}
.submit-result {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(26, 26, 26, 0.6);
    z-index: 1000;
}
.submit-result.visible {
    display: block;
}
.submit-result .result-msg-box {
    position: absolute;
    width: 300px;
    height: 200px;
    background-color: var(--color-white);
    border-radius: 30px;
    top: calc(50% - 100px);
    left: calc(50% - 150px);
    padding: 30px;
    text-align: center;
    align-items: center;
}
.submit-result .result-msg-box .result-msg-box--text {

}
.result-msg-box--button {
    position: absolute;
    bottom: 20px;
    background-color: red;
    padding: 10px 30px;
    border-radius: 6px;
    color: white;
    left: calc(50% - 70px);
    width: 140px;
    cursor: pointer;
}

/* Textarea for mobile comment field */
.contact-form-section__textarea--mobile {
    display: none;
    width: 100%;
    min-height: 86px;
    padding: 15px 25px;
    font-family: var(--font-roboto);
    font-weight: 400;
    font-size: 14px;
    line-height: 1.4;
    color: #1A1A1A;
    background: var(--color-white);
    backdrop-filter: blur(5px);
    border: none;
    border-radius: 6px;
    outline: none;
    resize: vertical;
    transition: all 0.3s ease;
}

.contact-form-section__textarea--mobile::placeholder {
    color: rgba(26, 26, 26, 0.6);
}

.contact-form-section__textarea--mobile:focus {
    box-shadow: 0 0 0 3px rgba(213, 14, 46, 0.3);
}

.contact-form-section__submit {
    width: 100%;
    height: 48px;
    padding: 0 25px;
    font-family: var(--font-roboto);
    font-weight: 600;
    font-size: 20px;
    line-height: 1.2;
    letter-spacing: 0.4px;
    text-transform: uppercase;
    color: var(--color-white);
    background: var(--color-primary);
    border: none;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.3s ease;
}

.contact-form-section__submit:hover {
    background: #b50c26;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(213, 14, 46, 0.3);
}

.contact-form-section__submit:active {
    transform: translateY(0);
}

.contact-form-section__submit:disabled {
    background: #999;
    cursor: not-allowed;
    transform: none;
}

.contact-form-section__checkboxes {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.contact-form-section__checkbox {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
}

.contact-form-section__checkbox input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    width: 20px;
    height: 20px;
    min-width: 20px;
    border: 1px solid var(--color-white);
    border-radius: 4px;
    background: transparent;
    cursor: pointer;
    position: relative;
    transition: all 0.2s ease;
}

.contact-form-section__checkbox input[type="checkbox"]:checked {
    background: var(--color-primary);
    border-color: var(--color-primary);
}

.contact-form-section__checkbox input[type="checkbox"]:checked::after {
    content: '';
    position: absolute;
    top: 1px;
    left: 6px;
    width: 5px;
    height: 10px;
    border: solid var(--color-white);
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

.contact-form-section__checkbox span {
    font-family: var(--font-roboto);
    font-weight: 400;
    font-size: 14px;
    line-height: 1.4;
    letter-spacing: 0.28px;
    color: var(--color-white);
}

.contact-form-section__checkbox span a {
    color: var(--color-white);
    text-decoration: underline;
    transition: opacity 0.2s ease;
}

.contact-form-section__checkbox span a:hover {
    opacity: 0.8;
}

.contact-form-section__messages {
    margin-top: 20px;
}

.contact-form-section__success {
    padding: 20px;
    background: rgba(76, 175, 80, 0.9);
    border-radius: 8px;
    color: var(--color-white);
    font-size: 18px;
    font-weight: 500;
    text-align: center;
}

.contact-form-section__error {
    padding: 20px;
    background: rgba(244, 67, 54, 0.9);
    border-radius: 8px;
    color: var(--color-white);
    font-size: 16px;
    font-weight: 500;
    text-align: center;
}

/* ========================================
   Contact Info Section
======================================== */
.contact-info-section {
    padding: 50px 192.5px;
}

.contact-info-section__wrapper {
    display: grid;
    grid-template-columns: 1fr 489px;
    gap: 25px;
}

.contact-info-section__left {
    display: flex;
    flex-direction: column;
}

.contact-info-section__title {
    font-family: var(--font-roboto-condensed);
    font-weight: 800;
    font-size: 56px;
    line-height: 1.3;
    letter-spacing: 1.12px;
    text-transform: uppercase;
    color: #1A1A1A;
    margin: 0 0 25px 0;
}

.contact-info-section__title-red {
    color: var(--color-primary);
}

.contact-info-section__warning {
    border: 1px solid #1A1A1A;
    border-radius: 8px;
    padding: 10px 25px;
    margin-bottom: 25px;
}

.contact-info-section__warning p {
    font-family: var(--font-roboto);
    font-weight: 400;
    font-size: 18px;
    line-height: 1.4;
    color: #1A1A1A;
    margin: 0;
}

.contact-info-section__warning-red {
    font-weight: 600;
    color: var(--color-primary);
}

.contact-info-section__cards {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 25px;
}

.contact-info-section__card {
    background: #EFF3FF;
    border-radius: 16px;
    padding: 30px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    min-height: 154px;
}

.contact-info-section__card:nth-child(3),
.contact-info-section__card:nth-child(4) {
    min-height: 179px;
}

.contact-info-section__card-header {
    display: flex;
    align-items: center;
    gap: 17px;
    margin-bottom: 20px;
}

.contact-info-section__card-icon {
    width: 49px;
    height: 49px;
    flex-shrink: 0;
    background: var(--color-primary);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px;
}

.contact-info-section__card-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.contact-info-section__card-title {
    font-family: var(--font-roboto);
    font-weight: 800;
    font-size: 24px;
    line-height: 1.2;
    color: #1A1A1A;
    margin: 0;
}

.contact-info-section__card-text {
    font-family: var(--font-roboto);
    font-weight: 400;
    font-size: 18px;
    line-height: 1.4;
    color: #1A1A1A;
    margin: 0;
    text-align: center;
}

.contact-info-section__card-text a {
    color: #1A1A1A;
    text-decoration: none;
    transition: color 0.3s ease;
}

.contact-info-section__card-text a:hover {
    color: var(--color-primary);
}

.contact-info-section__image {
    border-radius: 16px;
    overflow: hidden;
}

.contact-info-section__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

/* ========================================
   Company Details Section (Реквизиты компании)
======================================== */
.company-details-section {
    padding: 50px 192.5px;
}

.company-details-section__title {
    font-family: var(--font-roboto-condensed);
    font-weight: 800;
    font-size: 56px;
    line-height: 1.3;
    letter-spacing: 1.12px;
    text-transform: uppercase;
    color: #1A1A1A;
    margin: 0 0 50px 0;
}

.company-details-section__title-red {
    color: var(--color-primary);
}

.company-details-section__cards {
    display: grid;
    grid-template-columns: 490px 233px 232px 490px;
    gap: 25px;
}

.company-details-section__card {
    background: #EFF3FF;
    border-radius: 16px;
    padding: 30px 25px;
    display: flex;
    flex-direction: column;
    min-height: 204px;
}

.company-details-section__card--wide {
    /* Широкие карточки - 490px */
}

.company-details-section__card--small {
    /* Узкие карточки - 232-233px */
}

.company-details-section__card-header {
    display: flex;
    align-items: center;
    gap: 17px;
    margin-bottom: 30px;
}

.company-details-section__card-icon {
    width: 49px;
    height: 49px;
    flex-shrink: 0;
    background: var(--color-primary);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px;
}

.company-details-section__card-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.company-details-section__card-title {
    font-family: var(--font-roboto);
    font-weight: 800;
    font-size: 24px;
    line-height: 1.2;
    color: #1A1A1A;
    margin: 0;
}

.company-details-section__card-text {
    font-family: var(--font-roboto);
    font-weight: 400;
    font-size: 18px;
    line-height: 1.4;
    color: #1A1A1A;
    margin: 0;
    text-align: left;
}

/* ========================================
   Contact Popup Styles
======================================== */
.contact-popup-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.6);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10000;
}

.contact-popup {
    background: #fff;
    border-radius: 16px;
    padding: 40px;
    max-width: 400px;
    width: 90%;
    text-align: center;
    position: relative;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.2);
}

.contact-popup__close {
    position: absolute;
    top: 15px;
    right: 15px;
    background: none;
    border: none;
    font-size: 24px;
    cursor: pointer;
    color: #999;
    line-height: 1;
}

.contact-popup__close:hover {
    color: #333;
}

.contact-popup__icon {
    margin-bottom: 20px;
}

.contact-popup__text {
    font-family: var(--font-roboto, 'Roboto', sans-serif);
    font-size: 16px;
    line-height: 1.5;
    color: #333;
}

/* Стиль ошибки для input */
.contact-form-section__field input.input-error,
.contact-form-section__field textarea.input-error {
    border-color: #D50E2E !important;
    box-shadow: 0 0 0 2px rgba(213, 14, 46, 0.2);
}


.contact-form-section__checkbox.checkbox-error input[type="checkbox"] {
    outline: 2px solid #D50E2E;
    outline-offset: 2px;
}


.hero__attention {
    position: relative;
    bottom: 28px;
    background: var(--color-primary);
    text-align: center;
    font-size: 18px;
    line-height: 140%;
    color: white;
    padding: 7px 14px;
    width: calc(100% + 40px);
    left: 0;
    z-index: 9;
    margin-top: 53px;
    margin-left: -20px;
}
/* ===================================
   Manufacturers Section
   =================================== */

   .manufacturers-section .section__header {
    margin-bottom: 40px;
    justify-content: center;
}
.manufacturers-section {
    margin-top: 40px;
}


.manufacturers__alphabet {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 40px;
    justify-content: center;
}

.manufacturers__alphabet-item {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 39px;
    height: 39px;
    background: #FFFFFF;
    border-radius: 6px;
    font-family: 'Roboto', sans-serif;
    font-weight: 800;
    font-size: 24px;
    line-height: 1.2;
    text-align: center;
    color: #1A1A1A;
    text-decoration: none;
    transition: all 0.3s ease;
}

.manufacturers__alphabet-item:hover {
    background: var(--color-primary);
    transform: translateY(-2px);
    color: #FFFFFF;
}

.manufacturers__alphabet-item--active {
    background: var(--color-primary);
    color: #FFFFFF;
}

.manufacturers__grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 25px;
    margin-bottom: 40px;
}

.manufacturers__card {
    background: #FFFFFF;
    border: 1px solid #1A1A1A;
    border-radius: 10px;
    padding: 25px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    height: 267px;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.manufacturers__card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1);
    border: 1px solid var(--color-primary);
}

.manufacturers__card-link {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    text-decoration: none;
    width: 100%;
    height: 100%;
}

.manufacturers__card-image {
    width: 163px;
    height: 163px;
    background: #FFFFFF;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.manufacturers__card-image img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.manufacturers__card-title {
    font-weight: 800;
    font-size: 18px;
    line-height: 1.3;
    text-align: center;
    color: #1A1A1A;
    width: 183px;
    white-space: pre-wrap;
    margin: 0;
}
.section-contact-manufactures {
    margin-bottom: 50px;
}

.manufacturers__pagination {
    display: flex;
    justify-content: center;
    margin-top: 40px;
}

/* ===================================
   Global Pagination Styles
   =================================== */
.pagination {
    display: flex;
    justify-content: center;
    align-items: center;
}

.pagination__container {
    display: flex;
    align-items: center;
    gap: 10px;
}

.pagination__arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 39px;
    height: 39px;
    background: transparent;
    border-radius: 6px;
    color: #1A1A1A;
    text-decoration: none;
    transition: all 0.3s ease;
    cursor: pointer;
}

.pagination__arrow:hover {
    background: #EFF3FF;
    transform: translateY(-2px);
}

.pagination__arrow--disabled {
    color: #999999;
    cursor: not-allowed;
    pointer-events: none;
}

.pagination__arrow svg {
    width: 16px;
    height: 16x;
}

.pagination__numbers {
    display: flex;
    align-items: center;
    gap: 10px;
}

.pagination__number {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 39px;
    height: 39px;
    background: transparent;
    border-radius: 6px;
    font-weight: 800;
    font-size: 24px;
    line-height: 1.2;
    text-align: center;
    color: #1A1A1A;
    text-decoration: none;
    transition: all 0.3s ease;
}

.pagination__number:hover {
    background: var(--color-primary);
    transform: translateY(-2px);
    color: #FFFFFF;
}

.pagination__number--active {
    background: var(--color-primary);
    color: #FFFFFF;
    cursor: default;
    pointer-events: none;
}

/* ===================================
   Manufacturers Section end
   =================================== */


/* Pagination Styles */
.text3 {
  text-align: center;
  padding: 20px;
  font-size: 14px;
  font-weight: bold;
  font-stretch: normal;
  font-style: normal;
  line-height: normal;
  letter-spacing: normal;
  color: var(--dark-blue-grey);
}

.text3 a {
  border-radius: 5px;
  width: 9px;
  height: 16px;
  padding-left: 10px;
  padding-right: 10px;
}

.text3 .active {
  width: 9px;
  height: 16px;
  font-size: 14px;
  font-weight: bold;
  font-stretch: normal;
  font-style: normal;
  line-height: 23px;
  letter-spacing: normal;
  text-align: center;
  color: #f9fafc;
}

.strelka {
  font-size: x-large;
}
.pagactive {
  display: inline-block;
  width: 25px;
  height: 25px;
  border: 1px solid var(--color-primary);
  border-radius: 5px;
  background: var(--color-primary);
}
.text1  {
    display: none;
}
/* end Pagination Styles */

/* Manufacturer Products Section */
.manufacturer-products {
  margin: 60px 0;
}


.manufacturer-products__title {
  font-family: var(--font-roboto-condensed);
  font-size: 56px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--color-dark);
  margin-bottom: 40px;
  line-height: 1.3;
}

.manufacturer-products__grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 25px;
  margin-bottom: 40px;
}

.manufacturer-products__item {
  display: flex;
  flex-direction: column;
  border: 1px solid #1A1A1A;
  border-radius: 10px;
  padding: 10px;
  gap: 25px;
  min-height: 495px;
  position: relative;
  transition: all 0.3s ease;
  cursor: pointer;
}

.manufacturer-products__item:hover {
  border-color: var(--color-primary);
  transform: translateY(-5px);
  box-shadow: 0 8px 24px rgba(213, 14, 46, 0.15);
}


.manufacturer-products__image {
  width: 100%;
  height: 150px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.manufacturer-products__image img {
  width: 212px;
  height: 150px;
  object-fit: contain;
}

.manufacturer-products__item-title {
  font-family: var(--font-roboto);
  font-size: 18px;
  font-weight: 800;
  text-transform: none;
  letter-spacing: 0;
  color: var(--color-dark);
  text-align: center;
  line-height: 1.3;
  margin-bottom: 0;
  overflow-wrap: break-word;
  word-break: break-word;
}

.manufacturer-products__item-description {
  font-family: var(--font-roboto);
  font-size: 14px;
  font-weight: 400;
  color: var(--color-dark);
  text-align: center;
  line-height: 1.4;
  margin: 0;
  flex-grow: 1;
}

.manufacturer-products__buttons {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.manufacturer-products__button {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 35px;
  width: 100%;
  border-radius: 6px;
  font-family: var(--font-roboto);
  font-size: 16px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.32px;
  transition: background 0.25s ease;
  text-align: center;
  line-height: 1.2;
}

.manufacturer-products__button--primary {
  background: var(--color-primary);
  color: var(--color-white);
  border: none;
}

.manufacturer-products__button--primary:hover {
  background: #b50c26;
}

.manufacturer-products__button--secondary {
  background: var(--color-white);
  color: var(--color-primary);
  border: 1px solid var(--color-primary);
}

.manufacturer-products__button--secondary:hover {
  background: var(--color-primary);
  color: var(--color-white);
}

.manufacturer-products__pagination {
  display: flex;
  justify-content: center;
  margin-top: 40px;
}

/* Request Form Section */
.request-form-section {
  position: relative;
  margin: 100px 20px 20px 20px;
  background: var(--color-light-bg);
  border-radius: 16px;
  overflow: hidden;
}

.request-form-section.divider-bottom {
    margin: 80px 20px 50px 20px;
}

.request-form-section__container {
  position: relative;
  width: 100%;
  margin: 0 auto;
  padding: 100px 152.5px;
  z-index: 2;
}

.request-form-section__bg-decoration {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 360px;
  background-image: url('../images/decorate-form.png');
  background-size: cover;
  background-position: left center;
  background-repeat: no-repeat;
  pointer-events: none;
  z-index: 1;
}

.request-form-section__header {
  margin-bottom: 40px;
  position: relative;
  z-index: 2;
}

.request-form-section__title {
  font-family: var(--font-roboto-condensed);
  font-weight: 800;
  font-size: 62px;
  line-height: 1.2;
  letter-spacing: 1.24px;
  text-transform: uppercase;
  margin: 0 0 20px 0;
}

.request-form-section__title-black {
  color: var(--color-dark);
}

.request-form-section__title-red {
  color: var(--color-primary);
}

.request-form-section__description {
  font-family: var(--font-roboto);
  font-weight: 400;
  font-size: 22px;
  line-height: 1.2;
  color: var(--color-dark);
  margin: 0;
  max-width: 1520px;
}

.request-form-section__form {
  display: flex;
  flex-direction: column;
  gap: 25px;
  position: relative;
  z-index: 2;
}

.request-form-section__row {
  display: flex;
  gap: 25px;
}

.request-form-section__row--three {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 25px;
}

.request-form-section__row--bottom {
  display: grid;
  grid-template-columns: 1fr 490px;
  gap: 25px;
  align-items: start;
}

.request-form-section__left-fields {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 25px;
}

.request-form-section__right-content {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.request-form-section__field {
  flex: 1;
}

.request-form-section__field--full {
  width: 100%;
}

.request-form-section__input {
  width: 100%;
  height: 48px;
  padding: 0 25px;
  font-family: var(--font-roboto);
  font-weight: 400;
  font-size: 18px;
  line-height: 1.4;
  color: var(--color-dark);
  background: var(--color-white);
  backdrop-filter: blur(5px);
  border: 1px solid transparent;
  border-radius: 6px;
  outline: none;
  transition: all 0.3s ease;
}

.request-form-section__input::placeholder {
  color: rgba(26, 26, 26, 0.6);
}

.request-form-section__input:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(213, 14, 46, 0.1);
}

.request-form-section__input:-webkit-autofill,
.request-form-section__input:-webkit-autofill:hover,
.request-form-section__input:-webkit-autofill:focus {
  -webkit-text-fill-color: var(--color-dark);
  -webkit-box-shadow: 0 0 0 1000px var(--color-white) inset;
  box-shadow: 0 0 0 1000px var(--color-white) inset;
  transition: background-color 5000s ease-in-out 0s;
}

.request-form-section__input.error {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 2px rgba(213, 14, 46, 0.2);
}

.request-form-section__submit {
  width: 100%;
  height: 48px;
  padding: 0 25px;
  font-family: var(--font-roboto);
  font-weight: 600;
  font-size: 20px;
  line-height: 1.2;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--color-white) !important;
  background: var(--color-primary) !important;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.3s ease;
}

.request-form-section__submit:hover {
  background: #b50c26 !important;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(213, 14, 46, 0.3);
}

.request-form-section__submit:active {
  transform: translateY(0);
}

.request-form-section__submit:disabled {
  background: #999;
  cursor: not-allowed;
  transform: none;
}

.request-form-section__checkboxes {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.request-form-section__checkbox {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
}

.request-form-section__checkbox input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 20px;
  height: 20px;
  min-width: 20px;
  border: 1px solid var(--color-dark);
  border-radius: 4px;
  background: transparent;
  cursor: pointer;
  position: relative;
  transition: all 0.2s ease;
}

.request-form-section__checkbox input[type="checkbox"]:checked {
  background: var(--color-primary);
  border-color: var(--color-primary);
}

.request-form-section__checkbox input[type="checkbox"]:checked::after {
  content: '';
  position: absolute;
  top: 1px;
  left: 6px;
  width: 5px;
  height: 10px;
  border: solid var(--color-white);
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

.request-form-section__checkbox span {
  font-family: var(--font-roboto);
  font-weight: 400;
  font-size: 14px;
  line-height: normal;
  letter-spacing: 0.28px;
  color: var(--color-dark);
}

.request-form-section__checkbox span a {
  color: var(--color-primary);
  transition: color 0.2s ease;
}

.request-form-section__checkbox span a:hover {
  color: #b50c26
}

.request-form-section__checkbox.checkbox-error input[type="checkbox"] {
  outline: 2px solid #D50E2E;
  outline-offset: 2px;
}

.request-form-section__input.input-error {
  border: 1px solid #D50E2E;
  box-shadow: 0 0 0 3px rgba(213, 14, 46, 0.2);
}

.container.breadcrumbs-container {
  max-width: 1680px;
}

.breadcrumbs-container .wrapper {
    max-width: 1520px;
}

.breadcrumbs {
    /*padding-top: 50px;*/
    padding-left: 0;
}

.breadcrumbs ul li {
    margin-bottom: 0;
}

.breadcrumbs ul li span {
    color: rgba(26, 26, 26, 1);
}

.breadcrumbs ul li a {
    margin: 0;
}

.breadcrumbs ul li a span {
    font-size: 16px;
    line-height: 1.4;
    font-weight: 400;
    margin: 0;
}

.breadcrumbs ul li:first-child a span {
    margin-left: 0;
}

.breadcrumbs ul li span {
    font-size: 16px;
    line-height: 1.4;
    font-weight: 600;
    margin: 0;
}
.wrapper.wrapper--inner {
    max-width: 1520px;
}

.container.container-supplies {
    max-width: 1520px;
    margin-bottom: 50px;
}

.container.container-supplies.container-supplies--main {
    margin-bottom: 0;
    margin-top: 80px;
}

.content-title, h1.content-title {
    margin-top: 60px;
    font-family: var(--font-roboto-condensed), sans-serif;
    font-weight: 800;
    font-size: 56px;
    line-height: 130%;
    text-transform: uppercase;
    letter-spacing: 1.02px;
}
h1.content-title {
    margin-top: 40px;
}
h1.content-title span {
    color: rgba(213, 14, 46, 1);

}
.content-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(232px, 1fr));
    gap: 25px;
    margin-top: 40px;
}

.content-grid--item {
    border: 1px solid rgba(26, 26, 26, 1);
    width: 100%;
    border-radius: 10px;
    padding: 25px 9px;
    position: relative;
    transition: all .4s;
}
.content-grid--item:hover {
    box-shadow: 0 2px 30px 0 rgba(92,103,133,.2),0 2px 5px 0 rgba(79,75,108,.15);
    background-color: #fdfdff;
}

.content-grid-item--container {
    display: block;
    height: 245px;
    text-align: center;
}
.content-grid-item--category {
    height: 160px;
    max-width: 183px;
    margin: 0 auto;
    line-height: 160px;
}
.content-grid-item--image {
    margin: auto;
    vertical-align: middle;
    max-width: 100%;
    height: auto;
    max-height: 150px;
    border-style: none;
}
.content-grid--image__container {
    display: flex;
    justify-content: center;
    height: 150px;
    text-align: center;
}
.category-image {
    max-height: 160px;
}
.content-grid-item--name {
    height: 46px;
    margin-top: 25px;
    overflow: hidden;
    font-family: var(--font-roboto), sans-serif;
    font-weight: 800;
    font-size: 18px;
    line-height: 130%;
    text-align: center;
    padding: 0 1px;
}
.content-grid-item--name.category-name {
    margin-top: 12px;
    height: 69px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.content-grid-item--description {
    height: 80px;
    overflow: hidden;
    font-family: var(--font-roboto), sans-serif;
    font-weight: 400;
    font-size: 14px;
    line-height: 140%;
    letter-spacing: 0;
    text-align: center;
    margin-top: 12px;
}
.content-grid-item--button {
    display: block;
    margin: 12px auto 0;
    width: calc(100% - 10px);
    height: 35px;
    border-radius: 6px;
    background: rgba(213, 14, 46, 1);
    font-family: var(--font-roboto), sans-serif;
    font-weight: 600;
    font-size: 16px;
    line-height: 35px;
    letter-spacing: 0;
    text-transform: uppercase;
    color: var(--color-white);
    text-align: center;
    transition: background 0.3s ease;
}
.content-grid-item--button:hover {
    background: #b50c26;
}
.content-grid-item--more {
    display: block;
    margin: 10px auto 0;
    width: calc(100% - 10px);
    height: 35px;
    border-radius: 6px;
    border: 1px solid rgba(213, 14, 46, 1);
    font-family: var(--font-roboto), sans-serif;;
    font-weight: 600;
    font-size: 16px;
    line-height: 35px;
    letter-spacing: 0;
    text-align: center;
    text-transform: uppercase;
    color: rgba(213, 14, 46, 1);
    transition: background 0.3s ease;
}
.content-grid-item--more:hover {
    background: var(--color-primary);
    color: var(--color-white);
}
.content-pagination {
    margin: 40px auto 0;
    display: flex;
    justify-content: center;
}
.content-pagination--cell {
    display: inline-block;
    font-family: var(--font-roboto), sans-serif;
    font-weight: 800;
    font-size: 24px;
    line-height: 39px;
    letter-spacing: 0;
    text-align: center;
    color: rgba(26, 26, 26, 1);
    padding: 0 13px;
}
.cell--current {
    background: rgba(213, 14, 46, 1);
    border-radius: 6px;
    color: var(--color-white);
}
.content-pagination--icon {
    --fill-bg: transparent;
    --fill-stroke: black;
    --stroke: black;
    width: 39px;
    height: 39px;
    transform-origin: center;
}
.content-pagination--icon__left {
  transform: rotate(135deg);
  transform-origin: center;
}
.content-pagination--icon__right {
  transform: rotate(-45deg);
  transform-origin: center;
}
.catalog-menu {
    float: right;
    top: 0;
    margin-top: 20px;
    margin-left: 22px;
    width: 491px;
}
.catalog-menu--warning {
    padding: 40px;
    box-sizing: border-box;
    background: rgba(239, 243, 255, 1);
    border-radius: 16px;
    display: flex;
    margin-bottom: 25px;
}
.warning-icon {
    min-width: 50px;
    max-width: 50px;
}
.warning-icon img {
    width: 50px;
    height: 50px;
}
.warning-text {
    padding-left: 12px;
    font-family: var(--font-roboto), sans-serif;
    font-weight: 400;
    font-size: 18px;
    line-height: 140%;
    letter-spacing: 0;
}
.catalog-menu-groups {
    background: rgba(239, 243, 255, 1);
    border-radius: 16px;
    padding: 50px 50px;
    transition: all 0.3s;
}
.catalog-menu-groups a:hover {
    font-weight: 600;
}
.catalog-menu-groups li {
    font-family: var(--font-roboto), sans-serif;
    font-weight: 400;
    font-size: 18px;
    line-height: 140%;
    letter-spacing: 0;

}
.catalog-menu-groups li a {
    padding-left: 12px;
}
.catalog-menu-groups li a.active {
    font-family: var(--font-roboto), sans-serif;
    font-weight: 600;
    font-size: 18px;
    line-height: 140%;
    letter-spacing: 0;
    color: rgba(213, 14, 46, 1);
    display: block;
    margin-bottom: 10px;
    border-left: 2px rgba(213, 14, 46, 1) solid;
    padding-left: 10px;
}
.catalog-menu-groups li li {
    font-size: 16px;
    font-weight: 400;
    color: rgba(26, 26, 26, 0.6);
}
.catalog-menu-title {
    margin-bottom: 25px;
    padding-left: 10px;
    font-family: var(--font-roboto), sans-serif;
    font-weight: 800;
    font-size: 24px;
    line-height: 120%;
    letter-spacing: 0;
    color: rgba(26, 26, 26, 1);
}
.catalog-main {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(232px, 1fr));
    gap: 25px;
    margin-top: 20px;
}
.catalog-description {
    margin-top: 32px;
}
.catalog-description * {
    font-family: var(--font-roboto), sans-serif;
    font-weight: 400;
    font-size: 18px;
    line-height: 140%;
    letter-spacing: 0;
    color: rgba(26, 26, 26, 1);
}
.catalog-description h2 {
    font-size: 24px;
    font-weight: 800;
    font-stretch: normal;
    font-style: normal;
    line-height: normal;
    letter-spacing: normal;
    color: #1A1A1A;
    padding: 25px 30px;
    text-align: center;

}
.catalog-description ol li {
    margin-left: 30px;
}

.catalog-description ul li {
    margin-left: 30px;
    list-style: disc;
}
.catalog-description p {
    font-family: var(--font-roboto), sans-serif;
    font-weight: 400;
    font-size: 18px;
    line-height: 140%;
    letter-spacing: 0;
    color: rgba(26, 26, 26, 1);
}

.supplies-search--container {
    margin-top: 20px;
    width: 100%;
    height: 44px;
    border: 1px solid rgba(26, 26, 26, 1);
    border-radius: 6px;

}
.supplies-search--container form {
    display: flex;
    justify-content: center;
    height: 100%;
}
.supplies-search--icon {
    width: 39px;
    height: 39px;
    display: block;
    transform: scaleY(-1);
}
.supplies-search--button {
    width: 113px;
    height: 34px;
    border-radius: 6px;
    background: rgba(213, 14, 46, 1);
    margin: auto 5px auto auto;
    border: none;
    color: white;
    font-family: var(--font-roboto);
    font-weight: 600;
    font-size: 18px;
    line-height: 120%;
    letter-spacing: 1.02;
    text-transform: uppercase;
    cursor: pointer;
}

.supplies-search--input {
    /*margin: auto;*/
    height: 100%;
    border: none;
    font-size: 18px;

}
.catalog_other_h2 {
    font-size: 24px;
    font-weight: 800;
    font-stretch: normal;
    font-style: normal;
    line-height: normal;
    letter-spacing: normal;
    color: #231349;
    padding: 32px 0px 12px;
}
.margin-bottom--50 {
    margin-bottom: 50px;
}

/* ===================================
   Catalog Detail Page — modifier --catalog for manufacturer-detail
   (страница 15.02 добавлено)
   =================================== */


/* Title row: title + brand logo */
.manufacturer-detail--catalog .manufacturer-detail__title-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 60px;
    min-width: 0;
}

.manufacturer-detail--catalog .manufacturer-detail__title {
    min-width: 0;
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.manufacturer-detail--catalog .manufacturer-detail__usp-block {
    min-height: auto;
    height: 100%;

}

.manufacturer-detail--catalog-form .request-form-section {
    margin: 0px 20px 20px 20px;
}

/* Brand logo */
.manufacturer-detail--catalog .manufacturer-detail__brand-logo {
    flex-shrink: 0;
    width: 104px;
    height: 104px;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
}

.manufacturer-detail--catalog .manufacturer-detail__brand-logo img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

/* Content grid override: image left (580px) + USP right (fill) */
.manufacturer-detail--catalog .manufacturer-detail__content {
    grid-template-columns: 580px 1fr;
    gap: 25px;
}

/* USP grid: 2 columns with 3 items each (Figma 48:9961) */
.manufacturer-detail--catalog .manufacturer-detail__usp-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px 40px;
}

.manufacturer-detail--catalog .manufacturer-detail__usp-column {
    gap: 12px;
}

/* Contact buttons: primary full width, secondary 2 columns */
.manufacturer-detail--catalog .manufacturer-detail__contact-buttons {
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

.manufacturer-detail--catalog .manufacturer-detail__button--primary {
    grid-column: 1 / -1;
}

/* Product image card */
.manufacturer-detail--catalog .manufacturer-detail__product-image {
    border-radius: 16px;
    padding: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 429px;
    height: 100%;
    box-sizing: border-box;
    position: relative;
}

.manufacturer-detail--catalog .manufacturer-detail__product-image.bordered {
    border: 1px solid #000;
}

.manufacturer-detail--catalog .manufacturer-detail__product-image img {
    max-width: 100%;
    max-height: 380px;
    object-fit: contain;
    border-radius: 16px;
}

.manufacturer-detail--catalog .manufacturer-detail__product-image .catalog-item-badge {
    position: absolute;
    top: 15px;
    left: 15px;
    right: unset;
}

.manufacturer-detail--catalog .manufacturer-detail__product-image--placeholder {
    padding: 0 !important;
    height: 457px;
    min-height: 457px;
   
}

.manufacturer-detail--catalog .manufacturer-detail__product-image--placeholder img {
    max-width: 100%;
    max-height: 100% !important;
    width: 100%;
    height: 100% !important;
    object-fit: cover;
    border-radius: 16px;
}

/* Description */
.manufacturer-detail--catalog .manufacturer-detail__description {
    margin-top: 40px;
    font-size: 18px;
    line-height: 1.4;
    color: #1a1a1a;
}

.manufacturer-detail--catalog .manufacturer-detail__description p {
    margin: 0;
}

.manufacturer-detail--catalog .manufacturer-detail__description a {
    /* color: var(--color-primary); */
    text-decoration: none;
    font-weight: 400;
    color: #1a1a1a;
}

.manufacturer-detail--catalog .manufacturer-detail__description a:hover {
    text-decoration: underline;
}

/* Tech specs */
.manufacturer-detail--catalog .manufacturer-detail__tech-specs {
    margin-top: 20px;
}

.manufacturer-detail--catalog .manufacturer-detail__tech-title {
    font-family: var(--font-roboto);
    font-weight: 800;
    font-size: 18px;
    line-height: 1.3;
    color: #1a1a1a;
}

.manufacturer-detail--catalog .manufacturer-detail__tech-list {
    margin-top: 8px;
    padding-left: 27px;
    font-family: var(--font-roboto);
    font-size: 18px;
    line-height: 1.4;
    color: #1a1a1a;
    list-style: disc;
}

.manufacturer-detail--catalog .manufacturer-detail__tech-list li {
    margin-bottom: 2px;
    list-style: disc;
}

/* Markings (old pill style) */
.manufacturer-detail--catalog .manufacturer-detail__markings {
    margin-top: 15px;
    font-family: var(--font-roboto);
    font-size: 14px;
    font-weight: 400;
    line-height: 24px;
    color: #2f2e37;
    text-align: left;
}

.manufacturer-detail--catalog .manufacturer-detail__markings strong {
    font-size: 16px;
    font-weight: 800;
}

.manufacturer-detail--catalog .manufacturer-detail__markings span {
    border-radius: 10px;
    background-color: #e7e8ed;
    padding: 5px 6px;
    margin: 4px;
    display: inline-block;
}

/* Other products modifier */
.manufacturer-products--catalog {
    margin-top: 60px;
}

.manufacturer-products--catalog .manufacturer-products__item {
    min-height: auto;
}

.manufacturer-products--catalog .manufacturer-products__buttons {
    margin-top: auto;
}

.manufacturer-products--catalog .manufacturer-products__item-description:empty {
    display: none;
}

.manufacturer-products--catalog .manufacturer-products__title {
    text-transform: uppercase;
}

.min-banner {
    display: block;
}
.min-banner__picture img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

/* cookies accept*/

#pjAcceptCookieBar {
    position: fixed;
    bottom: 10px;
    right: 80px;
    overflow-x: hidden;
    overflow-y: auto;
    width: auto;
    max-width: 600px;
    max-height: 100%;
    padding: 20px;
    background: #1A1A1A;
    opacity: 1;
    font-family: 'Roboto', sans-serif;
    text-align: center;
    border-radius: 14px;
    box-shadow: 0.3em 0.3em 1em #2d2d2d;
    z-index: 2000;
}
#pjAcceptCookieBar * {
    box-sizing: border-box;
}


.pjAcceptCookieBarShell.hidden {
    display: none;
}

.pjAcceptCookieBarText {
    margin-bottom: 10px;
}

.pjAcceptCookieBarText p {
    /*text-align: left;*/
}

#pjAcceptCookieBar p {
    font-size: 13px;
    line-height: 1.4;
    color: #FFFFFF;
    font-weight: 600;
}

#pjAcceptCookieBar button {
    transition: all .2s ease-in-out;
    border-radius: 8px;
    display: inline-block;
    padding: 10px 30px;
    border: 0;
    background: #D50E2E;
    font-size: 14px;
    line-height: 14px;
    color: #fff;
    text-decoration: none;
    cursor: pointer;
    max-height: 34px;
}

#pjAcceptCookieBar button:hover {
    background-color: #b50c26;
    transform: unset;
}

#pjAcceptCookieBar .pjClearCookie, #pjAcceptCookieBar .cookie-button--setting {
    background-color: white;
    color:#b50c26;
}
#pjAcceptCookieBar button.pjClearCookie:hover, #pjAcceptCookieBar button.cookie-button--setting:hover {
    color: white;
}

#pjAcceptCookieBar .cookie-link {
    text-decoration: underline;
}

.cookie-settings.hidden {
    display: none;
}

.cookie-settings--description p{
    text-align: left;
}

.cookie-settings--checkboxes {
    margin-top: 10px;
}

.cookie-settings--flex {
    display: flex;
    color: white;
    font-size: 13px;
    line-height: 1.4;
    font-weight: 600;
    padding: 10px 0;
    border-bottom: 1px white solid;
}

.cookie-settings--flex:first-child {
    border-top: 1px white solid;
}


.cookie-settings--state {
    min-width: 24px;
    max-height: 24px;
    min-height: 24px;
    font-size: 21px;
    line-height: 24px;
    font-weight: 100;
    cursor: pointer;
}



.cookie-settings--state .open {
    display: none;
}
.cookie-settings--state.open .open{
    display: block;
}
.cookie-settings--state.open .close{
    display: none;
}
.cookie-settings--checkbox {
    height: 22px;
    min-width: 40px;
    border-radius: 11px;
    background-color: white;
    cursor: pointer;
    margin-left: auto;
}

.cookie-settings--circle {
    height: 20px;
    width: 20px;
    background-color: #ced4da;
    border-radius: 10px;
    margin: 1px auto 1px 1px;

}
.cookie-settings--checkbox.enabled {
    background-color: #feff00;
}

.cookie-settings--checkbox.enabled.locked {
    background-color: white;
}

.cookie-settings--checkbox.enabled .cookie-settings--circle {
    margin: 1px 1px 1px auto;

}

.cookie-text--left {
    text-align: left;
    padding-left: 20px;
    line-height: 24px;

}

.cookie-settings--detail {
    text-align: left;
}

.cookie-settings--detail.hidden {
    display: none;
}

.cookie-settings--actions {
    display: flex;
    margin-top: 10px;
}
.cookie-settings--actions button {
    margin-right: 20px;
}

#pjAcceptCookieBar .cookie-settings--actions button.white {
    background-color: white;
    color:#b50c26;
}

@media only screen and (max-width: 768px) {
    #pjAcceptCookieBar {
        width: calc(100% - 140px);
    }

}

@media only screen and (max-width: 670px) {
    #pjAcceptCookieBar {
        bottom: 10px;
        left: 5px;
        width: calc(100% - 10px);
        height: auto;
    }
    #pjAcceptCookieBar  .pjAcceptCookieBarShell button {
        margin: 10px auto 0;
        display: block;
    }
    #pjAcceptCookieBar button {
        width: 100%;
        max-width: 200px;
    }

}