﻿/* club-fixes.css */
/* Этот файл должен подключаться ПОСЛЕ site.css и adaptability.css */

/* ===== 1. ФИКС ДЛЯ СКРУГЛЕНИЯ БЛОКОВ ===== */
.program-block,
.program-brick,
.cardindex-item,
.program-module {
    border-radius: 20px !important;
    overflow: hidden !important; /* Убираем перекрытие фона */
    position: relative !important;
    z-index: 1 !important;
}

    /* Фон для округлых блоков */
    .program-block::before,
    .program-brick::before {
        content: '';
        position: absolute;
        top: -10px;
        left: -10px;
        right: -10px;
        bottom: -10px;
        background: inherit;
        border-radius: 30px !important;
        z-index: -1;
        opacity: 0;
        transition: opacity 0.3s ease;
    }

    .program-block:hover::before,
    .program-brick:hover::before {
        opacity: 1;
    }

/* ===== 2. УБИРАЕМ ВНУТРЕННИЕ СКРОЛЛЫ ===== */
/* Отменяем глобальные !important переопределения для наших блоков */
#current-program,
#records,
.program-section,
.records-section,
.program-bricks,
.blocks-grid,
.program-brick,
.program-block,
.brick-content,
.block-content {
    overflow: visible !important; /* Разрешаем overflow */
    overflow-x: visible !important;
    overflow-y: visible !important;
    max-height: none !important;
    min-height: auto !important;
    height: auto !important;
}

/* Специфично запрещаем скроллы в наших элементах */
.program-brick,
.program-block,
.brick-content,
.block-content,
.program-module {
    overflow: hidden !important; /* Запрещаем скролл */
}

/* Для мобильных - делаем контент видимым */
@media (max-width: 991.98px) {
    .program-brick,
    .program-block {
        overflow: visible !important;
    }

    .brick-content,
    .block-content {
        overflow: visible !important;
        max-height: none !important;
    }
}

/* ===== 3. ЦЕНТРИРОВАНИЕ НА МОБИЛЬНЫХ ===== */
@media (max-width: 991.98px) {
    /* Центрируем все контейнеры */
    .program-section .container,
    .records-section .container {
        padding-left: 15px !important;
        padding-right: 15px !important;
        margin-left: auto !important;
        margin-right: auto !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    /* Центрируем сетки */
    .program-bricks,
    .blocks-grid {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 1.5rem !important;
        width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    /* Центрируем карточки */
    .program-brick,
    .program-block {
        width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        max-width: 100% !important;
    }

        /* Убираем глобальные ограничения */
        .program-brick *,
        .program-block * {
            max-width: 100% !important;
        }
}

/* ===== 4. ФИКС КАРТОЧЕК ТАРИФОВ ===== */
/* Исправляем обрезку "Экономия" */
.tariff-pricing .price-option.popular {
    position: relative !important;
    z-index: 2 !important;
    margin-top: 0.5rem !important;
    margin-bottom: 0.5rem !important;
}

.price-save {
    position: absolute !important;
    top: -10px !important; /* Поднимаем выше */
    right: 2rem !important;
    background: var(--primary-color) !important;
    color: white !important;
    padding: 0.3rem 1rem !important;
    border-radius: 12px !important;
    font-size: 0.75rem !important;
    font-weight: 600 !important;
    z-index: 3 !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.2) !important;
}

/* Кнопка картотеки в стиле кнопок тарифов */
.cardindex-toggle {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: transparent !important;
    color: var(--primary-color) !important;
    border: 2px solid var(--primary-color) !important;
    padding: 0.75rem 1.5rem !important;
    border-radius: 15px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: all 0.3s ease !important;
    width: 100% !important;
    max-width: 300px !important;
    margin: 0.5rem auto !important;
    text-align: center !important;
}

    .cardindex-toggle:hover {
        background: var(--primary-color) !important;
        color: white !important;
        transform: translateY(-2px) !important;
        box-shadow: 0 5px 15px rgba(109, 123, 212, 0.3) !important;
    }

/* На мобильных */
@media (max-width: 767.98px) {
    .tariff-card {
        margin: 1rem 0 !important;
        padding: 0 !important;
    }

    .price-save {
        top: -8px !important;
        right: 1rem !important;
        font-size: 0.7rem !important;
        padding: 0.2rem 0.8rem !important;
    }

    .cardindex-toggle {
        padding: 0.6rem 1rem !important;
        font-size: 0.9rem !important;
        margin: 0.5rem auto !important;
    }
}

/* ===== 5. ФИКС БЛОКОВ ПО МЕСЯЦАМ ===== */
/* Убираем выход за пределы экрана */
@media (max-width: 991.98px) {
    .program-block {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 0 1.5rem 0 !important;
        padding: 0 !important;
        box-sizing: border-box !important;
    }

    .block-header {
        padding: 1.5rem 1rem !important;
        border-radius: 20px 20px 0 0 !important;
        position: relative !important;
    }

    .block-period {
        color: rgba(255, 255, 255, 0.95) !important;
        font-weight: 600 !important;
        text-shadow: 0 1px 3px rgba(0,0,0,0.3) !important;
        margin-bottom: 0.5rem !important;
        font-size: 0.9rem !important;
    }

    .block-name {
        color: white !important;
        text-shadow: 0 2px 4px rgba(0,0,0,0.3) !important;
        font-size: 1.3rem !important;
    }

    .block-content {
        padding: 1.5rem 1rem !important;
        width: 100% !important;
        box-sizing: border-box !important;
    }

    .block-actions {
        flex-direction: column !important;
        gap: 0.75rem !important;
        margin-top: 1.5rem !important;
    }

    .btn-program {
        width: 100% !important;
        margin: 0 !important;
    }
}

/* ===== 6. ФИКС БЛОКА "ПОЧЕМУ ЗАПИСИ ЭФФЕКТИВНЫ" ===== */
@media (max-width: 991.98px) {
    .benefits-card {
        flex-direction: column !important;
        padding: 1.5rem !important;
        border-radius: 15px !important;
        width: 100% !important;
        margin: 0 !important;
        gap: 1.5rem !important;
    }

    .benefits-content {
        width: 100% !important;
        padding: 0 !important;
    }

    .benefits-pricing {
        width: 100% !important;
        min-width: auto !important;
        padding: 1.5rem !important;
        border-radius: 12px !important;
    }

    .record-price-option {
        padding: 0.75rem 0 !important;
    }

        .record-price-option.popular {
            margin: 0.75rem 0 !important;
            padding: 0.75rem 1rem !important;
        }

    .btn-records {
        width: 100% !important;
        margin-top: 1rem !important;
        padding: 0.75rem !important;
    }
}

/* ===== ДОПОЛНИТЕЛЬНЫЕ ФИКСЫ ДЛЯ СКРОЛЛА ===== */

/* Полностью убираем внутренние скроллы на мобильных */
@media (max-width: 991.98px) {
    /* Отменяем все глобальные overflow: visible !important для наших секций */
    #current-program,
    #records,
    .program-section,
    .records-section,
    .program-bricks,
    .blocks-grid {
        overflow: visible !important;
    }

    /* Но запрещаем скролл внутри карточек */
    .program-brick,
    .program-block,
    .benefits-card {
        overflow: hidden !important;
        max-height: none !important;
        height: auto !important;
    }

    /* Разрешаем видеть весь контент */
    .brick-content,
    .block-content,
    .benefits-content,
    .benefits-pricing {
        overflow: visible !important;
        max-height: none !important;
        height: auto !important;
    }
}

/* Фикс для текста, который выходит за пределы */
.brick-text,
.block-description,
.benefits-text {
    word-wrap: break-word !important;
    overflow-wrap: break-word !important;
    hyphens: auto !important;
}

/* ===== ФИКС ДЛЯ ШИРИНЫ КОНТЕЙНЕРОВ ===== */

/* Убираем глобальные ограничения ширины для наших секций */
/*#current-program .container,
#records .container {
    max-width: 100% !important;
    width: 100% !important;
    padding-left: 15px !important;
    padding-right: 15px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}*/

/* На десктопе - нормальная ширина */
@media (min-width: 992px) {
    #current-program .container,
    #records .container {
        max-width: 1140px !important;
    }
}

/* ===== ФИКС ДЛЯ МОДАЛЬНЫХ ОКОН ===== */
/* Создаем уникальные классы, чтобы избежать конфликтов */

.modal-club-overlay {
    display: none;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: rgba(0,0,0,0.9) !important;
    z-index: 99999 !important; /* ОЧЕНЬ ВЫСОКИЙ z-index */
    align-items: center !important;
    justify-content: center !important;
    padding: 1rem !important;
}

.modal-club-content {
    background: white !important;
    border-radius: 20px !important;
    width: 100% !important;
    max-width: 800px !important;
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    max-height: 90vh !important;
    overflow: hidden !important;
}

.modal-club-header {
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color)) !important;
    color: white !important;
    padding: 2rem !important;
    border-radius: 20px 20px 0 0 !important;
    text-align: center !important;
    flex-shrink: 0 !important;
    position: relative !important;
}

.modal-club-body {
    padding: 2rem !important;
    overflow-y: auto !important;
    flex-grow: 1 !important;
    max-height: calc(90vh - 140px) !important;
    -webkit-overflow-scrolling: touch !important;
}

.btn-close-club-modal {
    position: absolute !important;
    top: 1.5rem !important;
    right: 1.5rem !important;
    background: rgba(255,255,255,0.2) !important;
    color: white !important;
    border: none !important;
    width: 40px !important;
    height: 40px !important;
    border-radius: 50% !important;
    font-size: 1.5rem !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: all 0.3s ease !important;
    z-index: 10 !important;
}

/* Адаптивность модальных окон */
@media (max-width: 767.98px) {
    .modal-club-overlay {
        padding: 0 !important;
        align-items: flex-end !important;
    }

    .modal-club-content {
        max-height: 90vh !important;
        border-radius: 20px 20px 0 0 !important;
        margin: 0 !important;
        width: 100% !important;
    }

    .modal-club-header {
        padding: 1.5rem 1rem !important;
        position: sticky !important;
        top: 0 !important;
    }

    .modal-club-body {
        padding: 1.5rem 1rem !important;
        max-height: calc(90vh - 120px) !important;
    }

    .btn-close-club-modal {
        top: 1rem !important;
        right: 1rem !important;
        width: 35px !important;
        height: 35px !important;
        font-size: 1.2rem !important;
    }
}


.no-scroll {
    overflow: hidden !important;
    height: 100% !important;
}



.program-block .block-header .block-period {
    display: flex;
    justify-content: center;
    align-items: center;
    letter-spacing: 1px;
    padding: 0.25rem 0.75rem;
    margin: 0 auto;
    background-color: rgba(0,0,0,0.3);
    border-radius: 50px;
}


.program-section,
.program-bricks {
    overflow: visible;
}



