/* ================= CSS VARIABLES - COLOR CONTROL ================= */
:root {
    /* ========== MAIN COLOR PALETTE ========== */
    --color-primary: #fe284a;
    /* Основной зелёный цвет */
    --color-primary-hover: #93FC3B;
    /* Зелёный при наведении */
    --color-primary-light: rgba(154, 255, 0, 0.1);
    /* Светлый зелёный */

    /* ========== TEXT COLORS ========== */
    --color-text: #ffffff;
    /* Основной цвет текста */
    --color-text-secondary: #ffffff;
    /* Вторичный текст */
    --color-text-muted: #000000;
    /* Текст серый/приглушённый */
    --color-text-dark: #000;
    /* Чёрный текст */
    --color-text-light: #ffffff;
    /* Белый текст */

    /* ========== BACKGROUND COLORS ========== */
    --color-bg: #212132;
    /* Основной фон страницы */
    --color-bg-light: #ffffff;
    /* Светлый фон */
    --color-bg-dark: #0d0f0e;
    /* Тёмный фон */
    --color-bg-card: rgba(255, 255, 255, 0.55);
    /* Фон карточек */
    --color-bg-overlay: rgba(0, 0, 0, 0.8);
    /* Фон оверлеев */

    /* ========== BORDER COLORS ========== */
    --color-border: #1f2a24;
    /* Основные границы */
    --color-border-dark: #2a3a30;
    /* Тёмные границы */
    --color-border-light: #9aff00;
    /* Светлые/акцентные границы */

    /* ========== BUTTON COLORS ========== */
    --color-btn-primary-bg: linear-gradient(90deg, rgb(202, 252, 63) 0%, rgb(147, 252, 59) 100%);
    /* Фон основной кнопки */
    --color-btn-primary-text: #000;
    /* Текст основной кнопки */
    --color-btn-outline-border: #fff;
    /* Граница контурной кнопки */
    --color-btn-outline-text: #fff;
    /* Текст контурной кнопки */

    /* ========== SHADOW COLORS ========== */
    --color-shadow-primary: rgba(154, 255, 0, 0.3);
    /* Тени зелёные */
    --color-shadow-dark: rgba(0, 0, 0, 0.3);
    /* Тени тёмные */
    --color-shadow-light: rgba(255, 255, 255, 0.1);
    /* Тени светлые */

    /* ========== STATUS COLORS ========== */
    --color-success: #9aff00;
    /* Успех */
    --color-warning: #ffa500;
    /* Предупреждение */
    --color-error: #ff4444;
    /* Ошибка */
    --color-info: #00aaff;
    /* Информация */

    /* ========== TYPOGRAPHY ========== */
    --font-family: Jost, Arial, Helvetica, sans-serif;
    --line-height-base: 1.6;

    /* Font Sizes */
    --font-size-xs: 13px;
    --font-size-sm: 14px;
    --font-size-base: 18px;
    --font-size-md: 20px;
    --font-size-lg: 20px;
    --font-size-xl: 26px;
    --font-size-2xl: 30px;
    --font-size-3xl: 36px;
    --font-size-4xl: 35px;
    --font-size-5xl: 45px;
    --font-size-button: 18px;

    /* Font Weights */
    --font-weight-light: 300;
    --font-weight-normal: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --font-weight-extrabold: 800;

    /* ========== SPACING ========== */
    --spacing-xs: 4px;
    --spacing-sm: 20px;
    --spacing-md: 16px;
    --spacing-lg: 24px;
    --spacing-xl: 32px;
    --spacing-2xl: 40px;
    --spacing-3xl: 48px;
    --spacing-4xl: 60px;

    /* ========== BORDER RADIUS ========== */
    --radius-sm: 4px;
    --radius-md: 6px;
    --radius-lg: 8px;
    --radius-xl: 10px;
    --radius-2xl: 14px;
    --radius-3xl: 18px;
    --radius-circle: 50%;

    /* ========== TRANSITIONS ========== */
    --transition-fast: 0.2s ease;
    --transition-normal: 0.3s ease;
    --transition-slow: 0.5s ease;
}

/* ================= RESET & BASE ================= */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: var(--font-family);
    background-color: #212132;
    color: var(--color-text);
    line-height: var(--line-height-base);

}

/* ================= BASE HTML TAGS ================= */
/* Headings */
h1,
.h1 {
    font-size: var(--font-size-5xl);
    font-weight: var(--font-weight-extrabold);
    line-height: 1.2;
    margin-bottom: var(--spacing-lg);
    color: var(--color-text);
}

h2,
.h2 {
    font-size: var(--font-size-4xl);
    font-weight: var(--font-weight-bold);
    line-height: 1.3;
    margin-bottom: var(--spacing-lg);
    color: var(--color-primary);
}

h3,
.h3 {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-semibold);
    line-height: 1.4;
    margin-bottom: var(--spacing-md);
    color: var(--color-text);
}

h4,
.h4 {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-medium);
    line-height: 1.4;
    margin-bottom: var(--spacing-md);
    color: var(--color-text);
}

h5,
.h5 {
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-medium);
    line-height: 1.4;
    margin-bottom: var(--spacing-sm);
    color: var(--color-text);
}

h6,
.h6 {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-medium);
    line-height: 1.4;
    margin-bottom: var(--spacing-sm);
    color: var(--color-text);
}

/* Paragraphs */
p {
    font-size: var(--font-size-md);
    line-height: var(--line-height-base);
    margin-bottom: var(--spacing-lg);
    color: var(--color-text-secondary);
}

/* Links */
a {
    color: var(--color-text-secondary);
    text-decoration: none;
    transition: color var(--transition-normal);
}



/* Lists */
ul,
ol {
    margin-bottom: var(--spacing-lg);
    padding-left: var(--spacing-2xl);
}

li {
    margin-bottom: var(--spacing-xs);
    color: var(--color-text-secondary);
}

/* Strong text */
strong,
b {
    font-size: 16px;
    font-weight: var(--font-weight-semibold);
    color: var(--color-text);
}

/* Emphasis */
em,
i {
    font-style: italic;
}

/* Small text */
small {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

/* Blockquotes */
blockquote {
    border-left: 4px solid var(--color-primary);
    padding-left: var(--spacing-lg);
    margin: var(--spacing-lg) 0;
    color: var(--color-text-secondary);
    font-style: italic;
}

/* Code */
code {
    font-family: monospace;
    background: var(--color-bg-light);
    padding: 2px 6px;
    border-radius: var(--radius-sm);
    color: var(--color-primary);
    font-size: var(--font-size-sm);
}

pre {
    background: var(--color-bg-light);
    padding: var(--spacing-md);
    border-radius: var(--radius-md);
    overflow-x: auto;
    margin-bottom: var(--spacing-lg);
}

pre code {
    background: none;
    padding: 0;
    color: var(--color-text-secondary);
}

/* Horizontal rule */
hr {
    border: none;
    border-top: 1px solid var(--color-border);
    margin: var(--spacing-xl) 0;
}

/* Images */
img {
    border-radius: 15px;
    max-width: 100%;
    height: auto;
    display: block;
}

button {
    font-size: var(--font-size-button) !important;
}

/* ================= CONTAINER ================= */
.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 var(--spacing-lg);
}

.quick-overview {
    margin: 0 0 20px 0;
}

/* ================= HEADER ================= */
.header {
    width: 100%;
    background-color: #252536f2;
    border-bottom: 1px solid var(--color-border);
    position: sticky;
    top: 0;
    z-index: 1000;
}

.header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 76px;
    position: relative;
}

/* Столбцы header */
.header-col {
    display: flex;
    align-items: center;
}

/* 1-й столбец: Логотип */
.header-col-logo {
    flex-shrink: 0;
}

.logo img {
    height: 150px;
    width: auto;
}

/* 2-й столбец: Навигация */
.header-col-nav {
    flex: 1;
    justify-content: flex-start;
    padding-left: var(--spacing-2xl);
}

.nav {
    display: flex;
    gap: 28px;
}

.nav a {
    text-decoration: none;
    color: var(--color-text-secondary);
    font-weight: var(--font-weight-semibold);
    font-size: var(--font-size-sm);
    letter-spacing: .5px;
    text-transform: uppercase;
    transition: color var(--transition-normal);
}

.nav a:hover {
    color: var(--color-primary);
}

/* 3-й столбец: Кнопки */
.header-col-auth {
    flex-shrink: 0;
}

.auth {
    display: flex;
    gap: var(--spacing-md);
}

.btn {
    padding: 15px;
    border-radius: var(--radius-md);
    font-weight: var(--font-weight-semibold);
    font-size: var(--font-size-sm);
    text-decoration: none;
    transition: all var(--transition-normal);
    text-align: center;
    display: inline-block;
    cursor: pointer;
    border: 1px solid transparent;
}

.btn-outline {
    border: 1px solid var(--color-btn-outline-border);
    color: var(--color-btn-outline-text);
    background: transparent;
    font-size: var(--font-size-button);
}

.btn-outline:hover {
    background: var(--color-shadow-light);
    border-color: var(--color-primary);
    color: var(--color-primary);
}

.btn-accent {
    background: #fe284a;
    color: #000000;
    font-size: var(--font-size-button);
}

.btn-accent:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px var(--color-shadow-primary);
}

/* Мобильное меню (бургер) */
.mobile-menu-btn {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    width: 30px;
    height: 30px;
    flex-direction: column;
    justify-content: space-between;
    padding: 0;
}

.mobile-menu-btn span {
    display: block;
    width: 100%;
    height: 3px;
    background: var(--color-text-secondary);
    border-radius: 2px;
    transition: all var(--transition-normal);
}

/* ================= HERO ================= */
.review-hero {
    padding: var(--spacing-3xl) 0 40px;
    text-align: center;
}

.hero-title {
    font-size: var(--font-size-5xl);
    font-weight: var(--font-weight-extrabold);
    margin-bottom: var(--spacing-lg);
    color: var(--color-text);
    text-align: center;
}

/* META */
/* ================= REVIEW META - ШИРИНА КАК У BONUS-CARD ================= */
.review-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 0 auto 0 auto;
    border-bottom: 1px solid var(--color-border);
    /* Такая же ширина как у .bonus-card */
    width: 100%;
    position: relative;
}

.updated {
    color: var(--color-text-secondary);
    font-size: var(--font-size-base);
}

.updated span {
    font-weight: var(--font-weight-bold);
    color: var(--color-text);
}

.rating {
    color: linear-gradient(90deg, rgb(202, 252, 63) 0%, rgb(147, 252, 59) 100%);
    border-radius: var(--radius-md);
    font-weight: var(--font-weight-bold);
    font-size: var(--font-size-base);
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.rating strong {
    font-size: var(--font-size-lg);
    color: #fff;
}

/* ================= BONUS CARD - ОБНОВЛЯЕМ ДЛЯ ВЫРАВНИВАНИЯ ================= */
.bonus-card {
    margin: 0 auto;
    padding: var(--spacing-3xl) var(--spacing-2xl);
    border-radius: var(--radius-3xl);
    background: linear-gradient(180deg,
            var(--color-bg-card),
            var(--color-bg-overlay));
    backdrop-filter: blur(6px);
}

/* ================= MEDIA QUERIES ================= */
@media (max-width: 992px) {

    .review-meta,
    .bonus-card {
        max-width: 95%;
    }
}

@media (max-width: 768px) {
    .review-meta {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
        padding-bottom: 12px;
    }

    .rating {
        align-self: flex-start;
    }
}

@media (max-width: 480px) {

    .review-meta,
    .bonus-card {
        max-width: 100%;
    }
}

/* BONUS CARD */
.bonus-card {
    background: url(/images/bg.webp) center center no-repeat;
    margin: 0 auto;
    padding: var(--spacing-3xl) var(--spacing-2xl);
    border-radius: var(--radius-3xl);
    border-radius: 15px;
    backdrop-filter: blur(6px);
}

.bonus-label {
    display: inline-block;
    color: var(--color-primary);
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--radius-md);
    font-size: 19px;
    font-weight: var(--font-weight-bold);
    margin-bottom: var(--spacing-xl);
}

.bonus-card h2 {
    font-size: var(--font-size-3xl);
    margin-bottom: var(--spacing-2xl);
    color: #fff;
}

.btn-primary {
    padding: var(--spacing-md) var(--spacing-4xl);
    background: var(--color-primary);
    color: var(--color-text-dark);
    font-weight: var(--font-weight-bold);
    font-size: var(--font-size-md);
    border-radius: var(--radius-xl);
    text-decoration: none;
    display: inline-block;
    transition: all var(--transition-normal);
}

.btn-primary:hover {
    color: #000;
    box-shadow: 0 10px 25px var(--color-shadow-primary);
    transform: translateY(-2px);
}

.bonus-description {
    color: #ffffff;
    font-size: 13px;
}

/* ================= QUICK OVERVIEW ================= */
.overview-inner {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 80px;
}

.overview-text {
    flex: 1;
    max-width: calc(100% - 480px);
}

.overview-text h2 {
    font-size: var(--font-size-4xl);
    color: #ffffff;
    margin-bottom: 28px;
}

.overview-text p {
    font-size: var(--font-size-md);
    margin-bottom: var(--spacing-md);
    color: var(--color-text-secondary);
}

/* IMAGES */
.overview-images {
    flex-shrink: 0;
    position: relative;
    width: 400px;
}

.img-main {
    width: 400px;
    height: 600px;
    border-radius: var(--radius-2xl);
    object-fit: cover;
    box-shadow: 0 10px 30px var(--color-shadow-dark);
    border: 1px solid var(--color-border);
}

/* Убираем старые классы для img-chip и img-slot если они не нужны */
.overview-images img:not(.img-main) {
    display: none;
}

/* ================= RESPONSIVE ================= */

/* Планшеты и маленькие ноутбуки */
@media (max-width: 992px) {
    .header-col-nav {
        padding-left: var(--spacing-lg);
    }

    .nav {
        gap: var(--spacing-lg);
    }

    .btn {
        padding: var(--spacing-md) var(--spacing-xl);
        font-size: var(--font-size-xs);
    }
}

/* Планшеты вертикально */
@media (max-width: 768px) {
    .header-inner {
        height: 70px;
    }

    .logo img {
        height: 35px;
    }

    .nav {
        gap: var(--spacing-md);
    }

    .nav a {
        font-size: var(--font-size-xs);
    }

    .auth {
        gap: var(--spacing-sm);
    }

    .btn {
        padding: var(--spacing-sm) var(--spacing-md);
    }
}

/* Мобильные устройства */
@media (max-width: 576px) {

    /* Прячем обычную навигацию и кнопки */
    .header-col-nav,
    .header-col-auth {
        display: none;
    }

    /* Показываем бургер меню */
    .mobile-menu-btn {
        display: flex;
    }

    /* Мобильное меню (открывается по клику) */
    .mobile-menu {
        position: fixed;
        top: 70px;
        left: 0;
        right: 0;
        background: linear-gradient(180deg, var(--color-bg-light), var(--color-bg-dark));
        border-bottom: 1px solid var(--color-border);
        padding: var(--spacing-lg);
        display: none;
        flex-direction: column;
        gap: var(--spacing-lg);
    }

    .mobile-menu.active {
        display: flex;
    }

    .mobile-nav {
        display: flex;
        flex-direction: column;
        gap: var(--spacing-md);
        border-bottom: 1px solid var(--color-border);
        padding-bottom: var(--spacing-lg);
    }

    .mobile-nav a {
        color: var(--color-text-secondary);
        text-decoration: none;
        font-weight: var(--font-weight-semibold);
        font-size: var(--font-size-base);
        text-transform: uppercase;
        letter-spacing: 0.5px;
    }

    .mobile-auth {
        display: flex;
        flex-direction: column;
        gap: var(--spacing-sm);
    }

    .mobile-auth .btn {
        width: 100%;
        padding: var(--spacing-md);
        font-size: var(--font-size-base);
    }
}

/* Очень маленькие экраны */
@media (max-width: 375px) {
    .header-inner {
        height: 65px;
        padding: 0 var(--spacing-md);
    }

    .logo img {
        height: 30px;
    }

    .mobile-menu {
        top: 65px;
    }
}

/* ================= FOOTER ================= */
.footer {
    padding: var(--spacing-2xl) 0;
    text-align: center;
    border-top: 1px solid var(--color-border);
    color: var(--color-text-muted);
}

/* ================= RESPONSIVE ================= */
@media (max-width: 1024px) {
    .overview-inner {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .overview-images {
        height: 360px;
    }

    .overview-images img {
        left: 50%;
        transform: translateX(-50%);
    }
}

@media (max-width: 768px) {
    .hero-title {
        font-size: var(--font-size-3xl);
    }

    .bonus-card h2 {
        font-size: var(--font-size-2xl);
    }

    .overview-text h2 {
        font-size: var(--font-size-2xl);
    }
}

@media (max-width: 480px) {
    .header-inner {
        height: auto;
        gap: var(--spacing-md);
        padding: var(--spacing-md) 0;
    }

    .nav {
        flex-direction: column;
        gap: var(--spacing-sm);
    }

    .auth {
        flex-direction: column;
        width: 100%;
        max-width: 220px;
    }

    .btn {
        width: 100%;
        text-align: center;
    }

    .hero-title {
        font-size: var(--font-size-xl);
    }

    .bonus-card {
        padding: var(--spacing-2xl) var(--spacing-lg);
    }
}

/* ================= BOTTOM BANNER ================= */
.bottom-banner {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 100;
}

.banner-content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-2xl);
    position: relative;
}

/* Логотип */
.banner-logo {
    flex-shrink: 0;
}

.logo-img {
    height: 120px;
    width: auto;
    filter: brightness(0) invert(1);
    /* Делаем лого белым */
}

/* Правая часть: текст + кнопка */
.banner-right {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-xl);
}

.banner-text {
    flex: 1;
}

.banner-title {
    font-size: var(--font-size-lg);
    color: #fff;
    margin-bottom: var(--spacing-xs);
    font-weight: var(--font-weight-semibold);
    letter-spacing: 0.5px;
}

.banner-subtitle {
    font-size: var(--font-size-xl);
    color: var(--color-primary);
    margin-bottom: 0;
    font-weight: var(--font-weight-bold);
}

.banner-subtitle strong {
    color: #fff;
    font-weight: var(--font-weight-extrabold);
}

.banner-description {
    font-size: var(--font-size-sm);
    color: #fff;
    margin: 0;
}

/* Крестик для закрытия баннера */
.banner-close {
    position: absolute;
    top: 0px;
    right: 20px;
    width: 32px;
    height: 32px;
    background: transparent !important;
    border: none;
    border-radius: 0;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.3s ease;
    flex-shrink: 0;
    padding: 0;
    outline: none;
    box-shadow: none !important;
    z-index: 101;
}

.banner-close:hover {
    transform: rotate(90deg);
}

.banner-close svg {
    width: 24px;
    height: 24px;
    color: #fff;
}

/* Баннер с состоянием закрыто */
.bottom-banner.hidden {
    display: none;
}


/* Кнопка */
.btn-banner {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-md) var(--spacing-xl);
    background: #fe284a;
    color: #000000;
    font-weight: var(--font-weight-bold);
    font-size: var(--font-size-base);
    border-radius: var(--radius-lg);
    text-decoration: none;
    transition: all var(--transition-normal);
    border: none;
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
}

.btn-banner:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px var(--color-shadow-primary);
}

.btn-banner svg {
    transition: transform var(--transition-normal);
}

.btn-banner:hover svg {
    transform: translateX(5px);
}

/* ================= RESPONSIVE BANNER ================= */
@media (max-width: 992px) {
    .banner-content {
        gap: var(--spacing-xl);
    }

    .banner-right {
        gap: var(--spacing-lg);
    }

    .logo-img {
        height: 45px;
    }

    .banner-title {
        font-size: var(--font-size-md);
    }

    .banner-subtitle {
        font-size: var(--font-size-lg);
    }

    .btn-banner {
        padding: var(--spacing-md) var(--spacing-lg);
        font-size: var(--font-size-base);
    }
}

@media (max-width: 768px) {

    .banner-content {
        gap: var(--spacing-lg);
        position: relative;
    }

    .banner-right {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-md);
        width: 100%;
        position: relative;
    }

    .banner-text {
        display: block;
    }

    .banner-close {
        position: absolute;
        top: 5px;
        right: 15px;
        width: 28px;
        height: 28px;
        flex-shrink: 0;
        margin: 0;
        padding: 0;
    }

    .logo-img {
        height: 40px;
    }

    .banner-title {
        font-size: var(--font-size-base);
    }

    .banner-subtitle {
        font-size: var(--font-size-lg);
    }

    .banner-description {
        font-size: var(--font-size-xs);
        max-width: 100%;
    }

    .btn-banner {
        width: 100%;
        justify-content: center;
    }
}

@media (max-width: 480px) {

    .banner-content {
        flex-direction: column;
        text-align: center;
        gap: var(--spacing-md);
    }

    .banner-logo {
        display: none;
        /* Можно скрыть лого на очень маленьких экранах */
    }

    .banner-right {
        width: 100%;
        align-items: center;
    }

    .banner-text {
        text-align: center;
    }

    .btn-banner {
        padding: var(--spacing-md) var(--spacing-lg);
    }
}

/* Для очень широких экранов */
@media (min-width: 1400px) {
    .banner-content {
        max-width: 1200px;
        margin: 0 auto;
    }
}

/* Добавляем отступ для основного контента, чтобы он не перекрывался баннером */




/* ================= BONUS SPORT ================= */
.bonus-sport {
    padding: 110px 0;
    background: transparent;
}

.bonus-inner {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 80px;
}

.bonus-text {
    flex: 1;
    max-width: calc(100% - 480px);
}

.bonus-text h2 {
    font-size: var(--font-size-4xl);
    color: #ffffff;
    margin-bottom: var(--spacing-lg);
    font-weight: var(--font-weight-bold);
}

.bonus-text h3 {
    font-size: var(--font-size-xl);
    color: var(--color-text-light);
    margin-bottom: var(--spacing-xl);
    font-weight: var(--font-weight-semibold);
    line-height: 1.4;
}

.bonus-text h3 strong {
    color: var(--color-primary);
    font-weight: var(--font-weight-bold);
}

.bonus-text>p {
    font-size: var(--font-size-md);
    color: var(--color-text-secondary);
    margin-bottom: var(--spacing-xl);
    line-height: 1.6;
}

.bonus-text>p strong {
    color: var(--color-text-light);
    font-weight: var(--font-weight-semibold);
}

/* Список с точками */
.bonus-list {
    list-style: none;
    padding: 10px 0 0 0;
    margin: 0;
}

.bonus-list li {
    margin-bottom: var(--spacing-sm);
    padding-bottom: var(--spacing-sm);
    border-bottom: 1px solid var(--color-border-dark);
}

.bonus-list li:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
}

.list-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

.list-marker {
    display: inline-block;
    width: 12px;
    height: 12px;
    background: var(--color-primary);
    border-radius: var(--radius-circle);
    flex-shrink: 0;
    box-shadow: 0 0 10px var(--color-shadow-primary);
}

.list-title {
    font-size: var(--font-size-lg);
    color: var(--color-text-light);
    font-weight: var(--font-weight-bold);
    line-height: 1.3;
}

.list-description {
    font-size: var(--font-size-base);
    color: var(--color-text-secondary);
    line-height: 1.6;
    margin: 0;
    padding-left: 27px;
    /* 12px marker + 15px gap */
}

.list-description strong {
    color: var(--color-text-light);
    font-weight: var(--font-weight-semibold);
}

/* Картинка */
.bonus-images {
    flex-shrink: 0;
    position: relative;
    width: 400px;
}

.bonus-images .img-main {
    width: 400px;
    height: 600px;
    border-radius: var(--radius-2xl);
    object-fit: cover;
    box-shadow: 0 10px 30px var(--color-shadow-dark);
    border: 1px solid var(--color-border-dark);
}

/* ================= RESPONSIVE BONUS SPORT ================= */
@media (max-width: 1200px) {
    .bonus-inner {
        gap: 60px;
    }

    .bonus-text {
        max-width: calc(100% - 460px);
    }
}

@media (max-width: 1024px) {
    .bonus-inner {
        flex-direction: column;
        align-items: center;
        gap: 50px;
    }

    .bonus-text {
        max-width: 100%;
        text-align: center;
    }

    .bonus-images {
        order: 2;
    }

    .list-description {
        padding-left: 0;
        text-align: left;
    }
}

@media (max-width: 768px) {
    .bonus-sport {
        padding: 70px 0;
    }

    .bonus-text h2 {
        font-size: var(--font-size-2xl);
        margin-bottom: var(--spacing-lg);
    }

    .bonus-text h3 {
        font-size: var(--font-size-lg);
        margin-bottom: var(--spacing-lg);
    }

    .bonus-text>p {
        font-size: var(--font-size-base);
        margin-bottom: var(--spacing-lg);
    }

    .list-title {
        font-size: var(--font-size-md);
    }

    .list-description {
        font-size: var(--font-size-base);
    }

    .bonus-images {
        width: 100%;
        max-width: 400px;
    }

    .bonus-images .img-main {
        width: 100%;
        height: auto;
        max-height: 500px;
    }
}

@media (max-width: 480px) {
    .bonus-sport {
        padding: 60px 0;
    }

    .bonus-inner {
        gap: var(--spacing-2xl);
    }

    .bonus-text h2 {
        font-size: var(--font-size-xl);
    }

    .bonus-text h3 {
        font-size: var(--font-size-md);
    }

    .bonus-text>p {
        font-size: var(--font-size-base);
    }

    .list-header {
        gap: var(--spacing-sm);
    }

    .list-marker {
        width: 10px;
        height: 10px;
    }

    .list-title {
        font-size: var(--font-size-base);
    }

    .list-description {
        font-size: var(--font-size-sm);
    }

    .bonus-images .img-main {
        max-height: 400px;
    }
}

/* Анимация для маркеров списка */
.list-marker {
    position: relative;
    animation: pulse 2s infinite;
}

@keyframes pulse {
    0% {
        box-shadow: 0 0 0 0 var(--color-shadow-primary);
    }

    70% {
        box-shadow: 0 0 0 6px rgba(154, 255, 0, 0);
    }

    100% {
        box-shadow: 0 0 0 0 rgba(154, 255, 0, 0);
    }
}

/*Стили для списка*/
.list {
    list-style: none;
    padding: 0;
}

/* Элемент списка */
.list li {
    padding-left: 25px;
    position: relative;
}

/* Точка */
.list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 8px;
    height: 8px;
    background-color: var(--color-primary);
    border-radius: var(--radius-circle);
}

/* Текст */
.list li span {
    color: var(--color-text-secondary);
    font-size: var(--font-size-base);
}

/* Вариант с квадратными точками */
.list-square li::before {
    border-radius: 0;
    background-color: var(--color-error);
}

/* Вариант с треугольными точками */
.list-triangle li::before {
    width: 0;
    height: 0;
    background: transparent;
    border-left: 6px solid var(--color-info);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
}

/* ================= PROVIDERS SECTION ================= */
.providers-section {
    padding: 110px 0;
    background: transparent;
}

.providers-header {
    text-align: center;
    max-width: 800px;
    margin: 0 auto 60px;
}

.providers-header h2 {
    font-size: var(--font-size-4xl);
    color: var(--color-primary);
    margin-bottom: var(--spacing-lg);
    font-weight: var(--font-weight-bold);
}

.providers-header h3 {
    font-size: var(--font-size-xl);
    color: var(--color-text-light);
    margin-bottom: var(--spacing-lg);
    font-weight: var(--font-weight-semibold);
    line-height: 1.4;
}

.providers-header p {
    font-size: var(--font-size-md);
    color: var(--color-text-secondary);
    line-height: 1.6;
}

/* Контент с картинкой и таблицей */
.providers-content {
    display: flex;
    flex-direction: column;
    gap: 60px;
    max-width: 1000px;
    margin: 0 auto;
}

.providers-images {
    text-align: center;
}

.providers-images .img-main {
    width: 400px;
    height: 400px;
    border-radius: var(--radius-2xl);
    object-fit: cover;
    box-shadow: 0 10px 30px var(--color-shadow-dark);
    border: 1px solid var(--color-border-dark);
}

/* Контейнер таблицы */
.providers-table-container {
    margin: 10px 0 0 0;
    background: rgba(255, 255, 255, 0.5);
    border-radius: var(--radius-2xl);
    padding: var(--spacing-xl);
    border: 1px solid var(--color-border-dark);
    position: relative;
}

/* Таблица */
.providers-table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: var(--spacing-lg);
}

.providers-table thead {
    background: rgba(255, 255, 255, 0.8);
}

.providers-table th {
    background-color: #fe284a;
    padding: var(--spacing-lg) var(--spacing-md);
    text-align: left;
    font-weight: var(--font-weight-bold);
    font-size: var(--font-size-base);
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.providers-table td {
    padding: var(--spacing-md) var(--spacing-md);
    text-align: left;
    font-size: var(--font-size-base);
    color: var(--color-text-secondary);
    border-bottom: 1px solid var(--color-border-dark);
    transition: background-color var(--transition-normal);
}

.providers-table tbody tr:last-child td {
    border-bottom: none;
}

.providers-table tbody tr:hover td {
    background-color: #ff8b9f;
}

.providers-table td:first-child {
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-light);
}

.providers-table td:nth-child(2) {
    font-weight: var(--font-weight-semibold);
}

/* Скрытые строки */
.hidden-row {
    display: none;
}

.hidden-row.show {
    display: table-row;
    animation: fadeIn 0.3s ease;
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

/* Кнопки + и - */
.table-buttons {
    display: flex;
    justify-content: center;
    margin-top: var(--spacing-sm);
}

.table-toggle-btn {
    width: 50px;
    height: 50px;
    background: var(--color-primary-light);
    border: 2px solid rgba(154, 255, 0, 0.3);
    border-radius: var(--radius-circle);
    color: var(--color-primary);
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    cursor: pointer;
    transition: all var(--transition-normal);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
}

.table-toggle-btn:hover {
    background: rgba(154, 255, 0, 0.2);
    border-color: var(--color-primary);
    transform: scale(1.1);
    box-shadow: 0 0 15px var(--color-shadow-primary);
}

.btn-icon {
    line-height: 1;
    margin-top: -2px;
}

.expand-btn {
    display: block;
}

.collapse-btn {
    display: none;
}

.table-expanded .expand-btn {
    display: none;
}

.table-expanded .collapse-btn {
    display: flex;
}

/* ================= Стили для таблиц ================= */
@media (max-width: 1024px) {
    .providers-header {
        max-width: 90%;
        margin-bottom: 50px;
    }

    .providers-header h2 {
        font-size: var(--font-size-3xl);
    }

    .providers-header h3 {
        font-size: var(--font-size-lg);
    }

    .providers-images .img-main {
        width: 350px;
        height: 350px;
    }

    .providers-table-container {
        padding: var(--spacing-lg);
    }
}

@media (max-width: 768px) {
    .providers-section {
        padding: 70px 0;
    }

    .providers-header h2 {
        font-size: var(--font-size-2xl);
    }

    .providers-header h3 {
        font-size: var(--font-size-lg);
    }

    .providers-header p {
        font-size: var(--font-size-base);
    }

    .providers-content {
        gap: var(--spacing-2xl);
    }

    .providers-images .img-main {
        width: 300px;
        height: 300px;
    }

    .providers-table th {
        font-size: var(--font-size-sm);
        padding: var(--spacing-md) var(--spacing-sm);
    }

    .providers-table td {
        font-size: var(--font-size-sm);
        padding: var(--spacing-sm) var(--spacing-sm);
    }

    .table-toggle-btn {
        width: 45px;
        height: 45px;
        font-size: var(--font-size-lg);
    }
}

@media (max-width: 480px) {
    .providers-section {
        padding: 60px 0;
    }

    .providers-header {
        margin-bottom: var(--spacing-2xl);
    }

    .providers-header h2 {
        font-size: var(--font-size-xl);
    }

    .providers-header h3 {
        font-size: var(--font-size-md);
    }

    .providers-images .img-main {
        width: 250px;
        height: 250px;
    }

    .providers-table-container {
        padding: var(--spacing-lg);
    }

    .providers-table {
        display: block;
        overflow-x: auto;
        white-space: nowrap;
    }

    .providers-table th,
    .providers-table td {
        min-width: 120px;
    }

    .table-toggle-btn {
        width: 40px;
        height: 40px;
        font-size: var(--font-size-lg);
    }
}

@media (max-width: 360px) {
    .providers-images .img-main {
        width: 200px;
        height: 200px;
    }

    .providers-table td:nth-child(2),
    .providers-table th:nth-child(2) {
        display: none;
    }
}

/* ================= UTILITY CLASSES ================= */
/* Text alignment */
.text-left {
    text-align: left;
}

.text-center {
    text-align: center;
}

.text-right {
    text-align: right;
}

/* Display */
.d-block {
    display: block;
}

.d-inline {
    display: inline;
}

.d-inline-block {
    display: inline-block;
}

.d-flex {
    display: flex;
}

.d-none {
    display: none;
}

/* Margins */
.m-0 {
    margin: 0;
}

.mt-0 {
    margin-top: 0;
}

.mb-0 {
    margin-bottom: 0;
}

.ml-0 {
    margin-left: 0;
}

.mr-0 {
    margin-right: 0;
}

/* Paddings */
.p-0 {
    padding: 0;
}

.pt-0 {
    padding-top: 0;
}

.pb-0 {
    padding-bottom: 0;
}

.pl-0 {
    padding-left: 0;
}

.pr-0 {
    padding-right: 0;
}

/* Font weights */
.fw-light {
    font-weight: var(--font-weight-light);
}

.fw-normal {
    font-weight: var(--font-weight-normal);
}

.fw-medium {
    font-weight: var(--font-weight-medium);
}

.fw-semibold {
    font-weight: var(--font-weight-semibold);
}

.fw-bold {
    font-weight: var(--font-weight-bold);
}

.fw-extrabold {
    font-weight: var(--font-weight-extrabold);
}

/* Colors */
.text-primary {
    color: var(--color-primary);
}

.text-secondary {
    color: var(--color-text-secondary);
}

.text-muted {
    color: var(--color-text-muted);
}

.text-white {
    color: var(--color-text-light);
}

.text-dark {
    color: var(--color-text-dark);
}

.text-error {
    color: var(--color-error);
}

.text-success {
    color: var(--color-success);
}

.text-warning {
    color: var(--color-warning);
}

.text-info {
    color: var(--color-info);
}



/*Стили для мнения автора*/


.meta-info {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 5px;
    font-size: 14px;
    color: #33ff00;
}

.date-info {
    font-size: 16px;
    color: #33ff00;
}

.date-info span {
    font-weight: bold;
    color: #000000;
}

.rating-info {
    background-color: #4CAF50;
    color: white;
    padding: 5px 12px;
    border-radius: 4px;
    font-weight: bold;
    font-size: 16px;
}

.rating-info strong {
    font-size: 18px;
}

.author-section {
    display: flex;
    align-items: flex-start;
    gap: 25px;
    background-color: #ffffff;
    border-radius: 10px;
    border: 1px solid var(--color-border-dark);
}

.author-avatar {
    flex-shrink: 0;
    width: 100px;
    height: 100px;
    border-radius: 50%;
    overflow: hidden;
    margin: 10px;
    border: 3px solid #a9f756;
}

.author-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.author-info {
    flex: 1;
}

.author-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 15px;
}

.author-name {
    font-size: 24px;
    font-weight: bold;
    color: #000000;
    margin-bottom: 5px;
}

.author-h2 {
    margin: 10px 0 0 0;
    font-size: 14px;
    color: #000;
}

.author-title {
    font-size: 18px;
    color: #ffffff;
    font-weight: normal;
    margin-bottom: 15px;
}

.author-description {
    color: #000000;
    line-height: 1.6;
    margin-bottom: 25px;
    font-size: 16px;
}

.stats-container {
    display: flex;
    gap: 30px;
    margin-bottom: 25px;
    flex-wrap: wrap;
}

.stat-item {
    flex: 1;
    min-width: 150px;
}

.stat-value {
    font-size: 24px;
    font-weight: bold;
    color: #333;
    margin-bottom: 5px;
}

.stat-label {
    font-size: 14px;
    color: #777;
}

.update-info {
    color: #888;
    font-size: 14px;
    padding-top: 20px;
    border-top: 1px solid #eee;
}

@media (max-width: 768px) {
    .author-section {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }

    .author-header {
        flex-direction: column;
        align-items: center;
        gap: 15px;
    }

    .stats-container {
        flex-direction: column;
        align-items: center;
        gap: 15px;
    }

    .stat-item {
        text-align: center;
        min-width: 200px;
    }
}

/*FAQ Section*/
.faq-title {
    font-size: var(--font-size-4xl);
    color: #ffffff;
    font-weight: var(--font-weight-bold);
    text-align: center;
}

.faq-container {
    margin: 0 auto;
}

/* FAQ Item */
.faq-item {
    margin-bottom: 20px;
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1px solid var(--color-border-dark);
    background-color: var(--color-bg-light);
    transition: all var(--transition-normal);
}

.faq-item.active {
    border-color: var(--color-primary);
}

/* FAQ Question */
.faq-question {
    padding: var(--spacing-xl) var(--spacing-2xl);
    cursor: pointer;
    display: flex;
    align-items: center;
    background-color: var(--color-bg-light);
    transition: background-color var(--transition-normal);
    gap: var(--spacing-lg);
}

.faq-question:hover {
    background-color: #ff8b9f;
}

.faq-item.active .faq-question {
    background-color: #ff8b9f
}

/* Question Icon */
.question-icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.question-icon img {
    width: 30px;
    height: 30px;
    object-fit: contain;
}

.question-title {
    font-size: var(--font-size-lg);
    color: #000;
    font-weight: var(--font-weight-semibold);
    margin: 0;
    flex: 1;
    padding-right: var(--spacing-lg);
}

.faq-arrow {
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-primary);
    transition: transform var(--transition-normal);
    flex-shrink: 0;
}

.faq-item.active .faq-arrow {
    transform: rotate(180deg);
}

/* FAQ Answer */
.faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height var(--transition-normal);
    background-color: var(--color-bg-card);
}

.faq-item.active .faq-answer {
    max-height: 500px;
    /* Достаточно для контента */
}

.faq-answer p {
    padding: var(--spacing-2xl);
    margin: 0;
    color: #000;
    font-size: var(--font-size-md);
    line-height: 1.6;
}

/* ================= RESPONSIVE FAQ ================= */
@media (max-width: 768px) {
    .faq-title {
        font-size: var(--font-size-2xl);
        margin-bottom: 40px;
    }

    .faq-question {
        padding: var(--spacing-lg);
        gap: var(--spacing-md);
    }

    .question-icon {
        width: 32px;
        height: 32px;
    }

    .question-icon img {
        width: 32px;
        height: 32px;
    }

    .question-title {
        font-size: var(--font-size-md);
    }

    .faq-answer p {
        padding: var(--spacing-lg);
    }
}

@media (max-width: 480px) {
    .faq-title {
        font-size: var(--font-size-xl);
        margin-bottom: 30px;
    }

    .faq-question {
        padding: var(--spacing-md);
        flex-direction: row;
        align-items: center;
        gap: var(--spacing-sm);
    }

    .question-icon {
        width: 28px;
        height: 28px;
    }

    .question-icon img {
        width: 28px;
        height: 28px;
    }

    .question-title {
        padding-right: 0;
        margin-bottom: 0;
        font-size: var(--font-size-base);
    }

    .faq-arrow {
        align-self: center;
    }
}

/* Для очень маленьких экранов */
@media (max-width: 360px) {
    .faq-question {
        padding: var(--spacing-sm);
        flex-wrap: wrap;
    }

    .question-title {
        order: 3;
        width: 100%;
        margin-top: var(--spacing-xs);
    }
}

/* ================= PROS & CONS SECTION ================= */
.pros-cons-section {
    padding: 10px 0;
}

.pros-cons-container {
    display: flex;
    gap: 40px;
    margin: 0 auto;
}

/* PROs and CONs Columns */
.pros-column,
.cons-column {
    flex: 1;
    overflow: hidden;
    border: 1px solid var(--color-border-dark);
    background-color: var(--color-bg-light);
}

/* Headers */
.pros-cons-header {
    padding: 20px 0 15px 40px;
    border-bottom: 1px solid var(--color-border-dark);
}

.pros-header {
    background-image: linear-gradient(102.12deg, #005733, #039e41);
    color: #C1FC3E;
}

.cons-header {
    background-image: linear-gradient(102.12deg, #005733, #039e41);
    color: #C1FC3E;
}

.pros-cons-header h3 {
    font-size: 18px;
    font-weight: var(--font-weight-bold);
    margin: 0;
    color: var(--color-text);
}

.pros-header h3 {
    color: var(--color-success);
}

.cons-header h3 {
    color: var(--color-error);
}

/* Lists */
.pros-cons-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.pros-item,
.cons-item {
    margin: 10px 0 15px 40px;
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-md);
    transition: background-color var(--transition-normal);
}

.pros-item:last-child,
.cons-item:last-child {
    border-bottom: none;
}

.pros-item:hover {
    background-color: rgba(154, 255, 0, 0.05);
}

.cons-item:hover {
    background-color: rgba(255, 68, 68, 0.05);
}

/* Icons */
.list-icon {
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 2px;
}

.pros-icon svg,
.cons-icon svg {
    width: 100%;
    height: 100%;
}

/* List Text */
.pros-item span,
.cons-item span {
    font-size: var(--font-size-md);
    color: var(--color-text-secondary);
    line-height: 1.5;
    flex: 1;
}

/* ================= RESPONSIVE PROS & CONS ================= */
@media (max-width: 992px) {
    .pros-cons-container {
        gap: 30px;
    }

    .pros-cons-header {
        padding: var(--spacing-lg) var(--spacing-xl);
    }
}

@media (max-width: 768px) {
    .pros-cons-section {
        padding: 60px 0;
    }

    .pros-cons-container {
        flex-direction: column;
        gap: 30px;
        max-width: 600px;
    }

    .pros-cons-header h3 {
        font-size: var(--font-size-xl);
    }

    .pros-item span,
    .cons-item span {
        font-size: var(--font-size-base);
    }
}

@media (max-width: 480px) {
    .pros-cons-section {
        padding: 40px 0;
    }

    .pros-cons-container {
        gap: 20px;
    }

    .pros-cons-header {
        padding: var(--spacing-md);
    }

    .pros-cons-header h3 {
        font-size: var(--font-size-lg);
    }

    .pros-item,
    .cons-item {
        gap: var(--spacing-sm);
    }

    .list-icon {
        width: 20px;
        height: 20px;
    }

    .pros-item span,
    .cons-item span {
        font-size: var(--font-size-sm);
    }
}



/* ================= GLOBAL MEDIA QUERIES ================= */

/* Большие экраны (более 1400px) */

/* Ноутбуки и маленькие десктопы (1200px - 992px) */
@media (max-width: 1200px) {
    .container {
        max-width: 1140px;
        padding: 0 var(--spacing-lg);
    }

    .hero-title {
        font-size: var(--font-size-4xl);
    }

    .bonus-card h2 {
        font-size: var(--font-size-2xl);
    }

    .overview-inner {
        gap: 60px;
    }

    .overview-text {
        max-width: calc(100% - 440px);
    }

    .overview-images,
    .img-main {
        width: 380px;
    }

    .bonus-images,
    .bonus-images .img-main {
        width: 380px;
    }

    .providers-images .img-main {
        width: 350px;
        height: 350px;
    }
}

/* Планшеты горизонтально (992px - 768px) */
@media (max-width: 992px) {
    .container {
        max-width: 960px;
        padding: 0 var(--spacing-md);
    }

    /* Header адаптация */
    .header-col-nav {
        padding-left: var(--spacing-lg);
    }

    .nav {
        gap: var(--spacing-lg);
    }

    .nav a {
        font-size: var(--font-size-xs);
    }

    .btn {
        padding: var(--spacing-sm) var(--spacing-xl);
        font-size: var(--font-size-xs);
    }

    /* Hero адаптация */
    .review-hero {
        padding: var(--spacing-2xl) 0 100px;
    }

    .hero-title {
        font-size: var(--font-size-3xl);
        margin-bottom: var(--spacing-md);
    }

    .review-meta {
        max-width: 95%;
    }

    .bonus-card {
        max-width: 95%;
        padding: var(--spacing-2xl) var(--spacing-xl);
    }

    .bonus-label {
        font-size: var(--font-size-sm);
        margin-bottom: var(--spacing-lg);
    }

    .bonus-card h2 {
        font-size: var(--font-size-xl);
        margin-bottom: var(--spacing-xl);
    }

    .btn-primary {
        padding: var(--spacing-md) var(--spacing-3xl);
        font-size: var(--font-size-base);
    }

    /* Overview адаптация */
    .overview-inner {
        flex-direction: column;
        gap: 50px;
        text-align: center;
    }

    .overview-text {
        max-width: 100%;
    }

    .overview-text h2 {
        font-size: var(--font-size-2xl);
        margin-bottom: var(--spacing-lg);
    }

    .overview-images {
        width: 100%;
        max-width: 500px;
        margin: 0 auto;
    }

    .img-main {
        width: 100%;
        height: 500px;
    }

    /* Bonus sport адаптация */
    .bonus-sport {
        padding: 80px 0;
    }

    .bonus-inner {
        flex-direction: column;
        gap: 40px;
        text-align: center;
    }

    .bonus-text {
        max-width: 100%;
    }

    .bonus-text h2 {
        font-size: var(--font-size-2xl);
    }

    .bonus-text h3 {
        font-size: var(--font-size-lg);
    }

    .bonus-images {
        width: 100%;
        max-width: 400px;
        margin: 0 auto;
        order: 2;
    }

    .bonus-images .img-main {
        width: 100%;
        height: 500px;
    }

    /* Providers адаптация */
    .providers-section {
        padding: 80px 0;
    }

    .providers-header h2 {
        font-size: var(--font-size-2xl);
    }

    .providers-header h3 {
        font-size: var(--font-size-lg);
    }

    .providers-images .img-main {
        width: 320px;
        height: 320px;
    }

    /* Pros & Cons адаптация */
    .pros-cons-section {
        padding: 60px 0;
    }

    .pros-cons-container {
        gap: 30px;
        max-width: 95%;
    }

    /* FAQ адаптация */
    .faq-title {
        font-size: var(--font-size-2xl);
        margin-bottom: 40px;
    }

    .faq-question {
        padding: var(--spacing-lg);
    }

    .question-title {
        font-size: var(--font-size-md);
    }
}

/* Планшеты вертикально и большие телефоны (768px - 576px) */
@media (max-width: 768px) {
    .container {
        padding: 0 var(--spacing-md);
    }

    /* Header мобильная версия */
    .header-inner {
        height: 70px;
        padding: 0 var(--spacing-md);
    }

    .logo img {
        height: 150px;
    }

    .header-col-nav,
    .header-col-auth {
        display: none;
    }

    .mobile-menu-btn {
        display: flex;
    }

    /* Hero адаптация */
    .review-hero {
        padding: var(--spacing-xl) 0 80px;
    }

    .hero-title {
        font-size: var(--font-size-2xl);
    }

    .review-meta {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
        padding-bottom: 12px;
        max-width: 100%;
    }

    .rating {
        align-self: flex-start;
    }

    .bonus-card {
        max-width: 100%;
        padding: var(--spacing-xl) var(--spacing-lg);
        border-radius: var(--radius-2xl);
    }

    .bonus-label {
        font-size: var(--font-size-xs);
        padding: var(--spacing-xs) var(--spacing-sm);
    }

    .bonus-card h2 {
        font-size: var(--font-size-lg);
        margin-bottom: var(--spacing-lg);
    }

    .btn-primary {
        padding: var(--spacing-sm) var(--spacing-2xl);
        font-size: var(--font-size-base);
        border-radius: var(--radius-lg);
    }

    .bonus-description {
        font-size: var(--font-size-sm);
        margin-top: var(--spacing-md);
    }

    /* Общие стили текста */
    h1,
    .h1 {
        font-size: var(--font-size-2xl);
    }

    h2,
    .h2 {
        font-size: var(--font-size-xl);
    }

    h3,
    .h3 {
        font-size: var(--font-size-lg);
    }

    h4,
    .h4 {
        font-size: var(--font-size-md);
    }

    p {
        font-size: var(--font-size-base);
    }

    /* Overview адаптация */
    .overview-text h2 {
        font-size: var(--font-size-xl);
    }

    .overview-text p {
        font-size: var(--font-size-base);
    }

    .img-main {
        height: 400px;
    }

    /* Bonus sport адаптация */
    .bonus-sport {
        padding: 60px 0;
    }

    .bonus-text h2 {
        font-size: var(--font-size-xl);
    }

    .bonus-text h3 {
        font-size: var(--font-size-md);
        text-align: start;
    }

    .bonus-text>p {
        font-size: var(--font-size-base);
        text-align: start;
    }

    .bonus-images .img-main {
        height: 400px;
    }

    /* Providers адаптация */
    .providers-section {
        padding: 60px 0;
    }

    .providers-header {
        margin-bottom: 40px;
    }

    .providers-header h2 {
        font-size: var(--font-size-xl);
    }

    .providers-header h3 {
        font-size: var(--font-size-md);
    }

    .providers-images .img-main {
        width: 280px;
        height: 280px;
    }

    .providers-table th,
    .providers-table td {
        font-size: var(--font-size-sm);
        padding: var(--spacing-sm);
    }

    /* Pros & Cons адаптация */
    .pros-cons-section {
        padding: 40px 0;
    }

    .pros-cons-container {
        flex-direction: column;
        gap: 20px;
        max-width: 100%;
    }

    .pros-cons-header {
        padding: var(--spacing-md);
    }

    .pros-cons-header h3 {
        font-size: var(--font-size-lg);
    }

    .pros-item,
    .cons-item {
        margin: 8px 0 12px 20px;
        font-size: var(--font-size-base);
    }

    /* FAQ адаптация */
    .faq-container {
        max-width: 100%;
    }

    .faq-question {
        padding: var(--spacing-md);
        gap: var(--spacing-sm);
    }

    .question-icon {
        width: 30px;
        height: 30px;
    }

    .question-icon img {
        width: 24px;
        height: 24px;
    }

    .question-title {
        font-size: var(--font-size-base);
        padding-right: var(--spacing-md);
    }

    .faq-answer p {
        padding: var(--spacing-lg);
        font-size: var(--font-size-base);
    }

    /* Author section адаптация */
    .author-section {
        flex-direction: column;
        align-items: center;
        text-align: center;
        gap: 20px;
    }

    .author-avatar {
        margin: 15px auto;
    }

    .author-header {
        flex-direction: column;
        align-items: center;
        gap: 10px;
    }

    .author-name {
        font-size: var(--font-size-xl);
    }

    .author-description {
        font-size: var(--font-size-base);
        text-align: center;
    }

    /* Bottom banner адаптация */

    .banner-content {
        flex-direction: column;
        gap: var(--spacing-md);
        text-align: center;
    }

    .banner-logo {
        display: none;
    }

    .banner-right {
        width: 100%;
        flex-direction: column;
        align-items: center;
        gap: var(--spacing-md);
    }

    .banner-text {
        text-align: center;
    }

    .banner-title {
        font-size: var(--font-size-base);
    }

    .banner-subtitle {
        font-size: var(--font-size-lg);
    }

    .btn-banner {
        width: 100%;
        padding: var(--spacing-md);
        justify-content: center;
        background: #93FC3B !important;
    }

    /* Main content padding for banner */
}

/* Телефоны (576px - 375px) */
@media (max-width: 576px) {


    .container {
        padding: 0 var(--spacing-sm);
    }

    /* Header */
    .header-inner {
        height: 65px;
        padding: 0 var(--spacing-sm);
    }

    .logo img {
        height: 120px;
        width: 120px;
    }

    /* Hero */
    .review-hero {
        padding: var(--spacing-lg) 0 60px;
    }

    .hero-title {
        font-size: var(--font-size-xl);
        margin-bottom: var(--spacing-md);
    }

    .bonus-card {
        padding: var(--spacing-lg) var(--spacing-md);
        border-radius: var(--radius-xl);
    }

    .bonus-card h2 {
        font-size: var(--font-size-md);
    }

    .btn-primary {
        padding: var(--spacing-sm) var(--spacing-xl);
        font-size: var(--font-size-sm);
    }

    /* Images */
    .img-main,
    .bonus-images .img-main {
        height: 350px;
    }

    .providers-images .img-main {
        width: 250px;
        height: 250px;
    }

    /* Tables */
    .providers-table {
        display: block;
        overflow-x: auto;
    }

    .providers-table th,
    .providers-table td {
        min-width: 100px;
        font-size: var(--font-size-xs);
        padding: 8px;
    }

    /* FAQ */
    .faq-question {
        padding: var(--spacing-sm);
        flex-wrap: wrap;
    }

    .question-title {
        order: 3;
        width: 100%;
        margin-top: var(--spacing-xs);
        padding-right: 0;
    }

    .question-icon {
        width: 25px;
        height: 25px;
    }

    .question-icon img {
        width: 20px;
        height: 20px;
    }

    .faq-arrow {
        margin-left: auto;
    }

    /* Pros & Cons */
    .pros-cons-header {
        padding: var(--spacing-sm);
    }

    .pros-cons-header h3 {
        font-size: var(--font-size-md);
    }

    .pros-item,
    .cons-item {
        margin: 6px 0 10px 15px;
        font-size: var(--font-size-sm);
    }

    /* Main content padding for banner */
}

/* Очень маленькие телефоны (до 375px) */
@media (max-width: 375px) {
    .container {
        padding: 0 12px;
    }

    .hero-title {
        font-size: var(--font-size-lg);
    }

    .bonus-card {
        padding: var(--spacing-md) var(--spacing-sm);
    }

    .bonus-card h2 {
        font-size: var(--font-size-base);
    }

    .btn-primary {
        padding: 10px 20px;
        font-size: var(--font-size-xs);
    }

    .img-main,
    .bonus-images .img-main {
        height: 300px;
    }

    .providers-images .img-main {
        width: 220px;
        height: 220px;
    }

    /* Убираем вторую колонку таблицы на очень маленьких экранах */
    .providers-table td:nth-child(2),
    .providers-table th:nth-child(2) {
        display: none;
    }

    /* Bottom banner на очень маленьких экранах */
    .bottom-banner {
        padding: 10px 0;
    }

    .banner-subtitle {
        font-size: var(--font-size-md);
    }

    .banner-description {
        font-size: var(--font-size-xs);
    }

    .banner-close {
        position: absolute;
        top: 8px;
        right: 12px;
        width: 28px;
        height: 28px;
        background: transparent !important;
        box-shadow: none !important;
    }

    .banner-close svg {
        width: 20px;
        height: 20px;
    }
}

/* Landscape ориентация для телефонов */
@media (max-height: 500px) and (orientation: landscape) {
    .review-hero {
        padding: var(--spacing-lg) 0 60px;
    }

    .hero-title {
        font-size: var(--font-size-lg);
        margin-bottom: var(--spacing-sm);
    }

    .bonus-card {
        padding: var(--spacing-md) var(--spacing-lg);
    }

    .img-main,
    .bonus-images .img-main {
        height: 250px;
    }

    /* Уменьшаем высоту секций в ландшафте */
    .bonus-sport,
    .providers-section,
    .pros-cons-section {
        padding: 40px 0;
    }
}

/* Поддержка темной темы */

/* Поддержка редуцированного движения */
@media (prefers-reduced-motion: reduce) {

    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}




/* ================= SAFE MOBILE ADAPTATION ================= */

/* 992px */
@media (max-width: 992px) {
    .container {
        padding: 0 16px;
    }

    .overview-inner,
    .bonus-inner {
        flex-direction: column;
        text-align: center;
    }

    .overview-text,
    .bonus-text {
        max-width: 100%;
    }
}

/* 768px */
@media (max-width: 768px) {

    h1,
    .hero-title {
        font-size: 32px;
    }

    h2 {
        font-size: 26px;
    }

    .header-col-nav,
    .header-col-auth {
        display: none;
    }

    .mobile-menu-btn {
        display: flex;
    }

    .img-main {
        width: 100%;
        height: auto;
        max-height: 450px;
    }

    .banner-right {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }
}

/* 480px */
@media (max-width: 480px) {

    h1,
    .hero-title {
        font-size: 34px;
    }

    h2 {
        font-size: 20px;
    }

    .btn,
    .btn-banner {
        width: 100%;
        justify-content: center;
        font-size: 16px;
    }

    .bonus-card {
        padding: 24px 16px;
    }

    .providers-table {
        overflow-x: auto;
        display: block;
    }
}

/* 360px */
@media (max-width: 360px) {
    h1 {
        font-size: 22px;
    }

    .logo img {
        height: 100px;
    }
}


p,
li,
h1,
h2,
h3,
h4,
h5,
h6 {
    text-align: left;
}

@media (max-width: 768px) {
    .author-h2 {
        text-align: center;
    }
}









.footer {
    background-color: #0a0a14;
    color: #ffffff;
    font-family: Inter, Arial, sans-serif;
}

/* ---------- TOP ---------- */

.footer-top {
    max-width: 1200px;
    margin: 0 auto;
    padding: 24px 16px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
}

.footer-logo img {
    height: 120px;
}

.footer-text {
    flex: 1;
    text-align: center;
    font-size: 14px;
    line-height: 1.4;
    opacity: 0.85;
}

.footer-icons {
    display: flex;
    align-items: center;
    gap: 16px;
}

.footer-icons img {
    height: 28px;
    opacity: 0.9;
}

/* ---------- BOTTOM ---------- */

.footer-bottom {
    border-top: 1px solid rgba(255, 255, 255, 0.05);
    padding: 20px 16px;
    display: flex;
    justify-content: center;
}

.footer-bottom img {
    height: 40px;
    opacity: 0.9;
}

/* ---------- TABLET ---------- */

@media (max-width: 1024px) {
    .footer-top {
        gap: 16px;
    }

    .footer-text {
        font-size: 13px;
    }

    .footer-icons img {
        height: 24px;
    }
}

/* ---------- MOBILE ---------- */

@media (max-width: 768px) {
    .footer-top {
        flex-direction: column;
        text-align: center;
    }

    .footer-logo img {
        height: 120px;
    }

    .footer-text {
        font-size: 13px;
        max-width: 420px;
    }

    .footer-icons {
        justify-content: center;
        flex-wrap: wrap;
        gap: 12px;
    }

    .footer-icons img {
        height: 24px;
    }

    .footer-bottom img {
        height: 34px;
    }
}

/* ---------- SMALL MOBILE ---------- */

@media (max-width: 420px) {
    .footer {
        font-size: 12px;
    }

    .footer-text {
        line-height: 1.35;
    }

    .footer-icons img {
        height: 22px;
    }
}






@media (max-width: 768px) {
    .banner-content {
        padding: 4px 6px;
    }

    /* скрываем логотип */
    .banner-logo {
        display: none;
    }

    /* выстраиваем в одну строку */
    .banner-right {
        width: 100%;
        flex-wrap: nowrap;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0px;
        padding: 0 0 10px 0;
    }

    /* оставляем только сумму бонуса */
    .banner-title,
    .banner-description {
        display: none;
    }

    .banner-text {
        flex-wrap: nowrap;
        flex: 1;
    }

    .banner-subtitle {
        font-size: 20px;
        white-space: nowrap;
        flex-wrap: nowrap;
        margin: 0;
    }

    /* кнопка компактная */
    .btn-banner {
        padding: 10px 16px;
        font-size: 14px;
        background: #93FC3B !important;
        flex-wrap: nowrap;
        white-space: nowrap;
    }

    /* стрелку убираем */
    .btn-banner svg {
        display: none;
    }
}




.nav {
    display: flex;
    align-items: center;
    gap: 20px;
}

.nav a {
    color: #fff;
    text-decoration: none;
    position: relative;
}

/* Dropdown wrapper */
.nav-dropdown {
    position: relative;
}

/* Выпадающее меню */
.nav-dropdown-menu {
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 200px;
    background: #111;
    border-radius: 6px;
    padding: 10px 0;
    display: none;
    z-index: 1000;
}

/* Ссылки внутри */
.nav-dropdown-menu a {
    display: block;
    padding: 8px 16px;
    color: #fff;
    white-space: nowrap;
}

.nav-dropdown-menu a:hover {
    background: #222;
}

/* Показ меню */
.nav-dropdown:hover .nav-dropdown-menu {
    display: block;
}

/* Стрелка */
.nav-dropdown-toggle::after {
    content: "▾";
    margin-left: 6px;
    font-size: 12px;
}