    :root {
        /* --- Базовые Настройки --- */
        --zen-border-radius: 0.75rem; /* Единый радиус скругления */
        --zen-transition: all 0.3s ease-in-out;

        /* --- Цвета Светлой Темы --- */
        --zen-primary-gradient-light: linear-gradient(45deg, #014063, #48dbfb); /* Бирюзовый -> Голубой */
        --zen-primary-solid-light: #014063;
        --zen-primary-rgb-light: 255, 79, 93;
        --zen-body-bg-light: #ffffff;
        --zen-section-bg-light: #f8f9fa;
        --zen-card-bg-light: #ffffff;
        --zen-heading-color-light: #1a202c; /* Темно-серый */
        --zen-body-color-light: #4a5568; /* Средне-серый */
        --zen-muted-color-light: #718096; /* Светло-серый */
        --zen-border-color-light: rgba(0, 0, 0, 0.1);
        --zen-map-color-light: rgba(0, 0, 0, 0.3); /* Цвет точек на карте для светлой темы */

         /* --- Переменные Bootstrap для Светлой Темы --- */
        --bs-body-font-family: 'Montserrat', sans-serif;
        --bs-body-bg: var(--zen-body-bg-light);
        --bs-body-color: var(--zen-body-color-light);
        --bs-primary: var(--zen-primary-solid-light);
        --bs-primary-rgb: var(--zen-primary-rgb-light);
        --bs-link-color: var(--zen-primary-solid-light);
        --bs-link-color-rgb: var(--zen-primary-rgb-light);
        --bs-link-hover-color: #007a62; /* Темнее основного */
        --bs-border-color: var(--zen-border-color-light);
        --bs-tertiary-bg: var(--zen-section-bg-light);
        --bs-heading-color: var(--zen-heading-color-light);
    }

    [data-bs-theme="dark"] {
         /* --- Цвета Темной Темы --- */
        --zen-primary-gradient-dark: linear-gradient(45deg, #55efc4, #48dbfb); /* Ярко-зеленый -> Голубой */
        --zen-primary-solid-dark: #55efc4;
        --zen-primary-rgb-dark: 85, 239, 196;
        --zen-body-bg-dark: #121212; /* Очень темный */
        --zen-section-bg-dark: #1a1a1a; /* Чуть светлее фона */
        --zen-card-bg-dark: #1f1f1f; /* Фон карточек */
        --zen-heading-color-dark: #ffffff;
        --zen-body-color-dark: #c1c1c1; /* Светло-серый */
        --zen-muted-color-dark: #8a8a8a;
        --zen-border-color-dark: rgba(255, 255, 255, 0.1);
        --zen-map-color-dark: rgba(255, 255, 255, 0.4); /* Цвет точек на карте для темной темы */

        /* --- Переменные Bootstrap для Темной Темы --- */
        --bs-body-bg: var(--zen-body-bg-dark);
        --bs-body-color: var(--zen-body-color-dark);
        --bs-primary: var(--zen-primary-solid-dark);
        --bs-primary-rgb: var(--zen-primary-rgb-dark);
        --bs-link-color: var(--zen-primary-solid-dark);
        --bs-link-color-rgb: var(--zen-primary-rgb-dark);
        --bs-link-hover-color: #a3fce6; /* Светлее основного */
        --bs-border-color: var(--zen-border-color-dark);
        --bs-tertiary-bg: var(--zen-section-bg-dark);
        --bs-heading-color: var(--zen-heading-color-dark);
        color-scheme: dark;
    }

    /* --- Общие Стили --- */

    /* --- Класс для доступного скрытия элементов --- */
    .visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    border: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    }
    body {
        transition: background-color 0.3s ease, color 0.3s ease;
        overflow-x: hidden;
    }
    h1, h2, h3, h4, h5, h6 {
        font-family: 'Outfit', sans-serif;
        font-weight: 700;
        color: var(--bs-heading-color);
    }
    .section {
        padding: 5rem 0;
        position: relative;
    }
    .section-title {
        font-size: clamp(2rem, calc(1.8rem + 1.2vw), 3.5rem);
        font-weight: 800;
        margin-bottom: 4rem;
        text-align: center;
    }
    .section-title span {
        background: var(--zen-primary-gradient-light);
        -webkit-background-clip: text;
        background-clip: text;
        color: transparent;
    }
    [data-bs-theme="dark"] .section-title span {
        background: var(--zen-primary-gradient-dark);
         -webkit-background-clip: text;
        background-clip: text;
        color: transparent;
    }

    /* --- Навигация --- */
    .navbar {
        background-color: rgba(248, 249, 250, 0.8); /* Светлая */
        backdrop-filter: blur(12px);
        -webkit-backdrop-filter: blur(12px);
        border-bottom: 1px solid var(--zen-border-color-light);
        padding: 0.75rem 0;
        transition: var(--zen-transition);
    }
    [data-bs-theme="dark"] .navbar {
         background-color: rgba(26, 26, 26, 0.8); /* Темная */
         border-bottom-color: var(--zen-border-color-dark);
    }
    .navbar-brand img { max-height: 35px; }
    /* Стили для новой кнопки переключения темы */
    .theme-toggle-button {
        width: 40px;
        height: 40px;
        border-radius: 50%;
        background-color: var(--bs-tertiary-bg); /* Фон секции или другой нейтральный цвет */
        border: 1px solid var(--bs-border-color);
        display: flex;
        align-items: center;
        justify-content: center;
        cursor: pointer;
        transition: var(--zen-transition);
        box-shadow: 0 2px 5px rgba(0,0,0,0.05);
        flex-shrink: 0; /* Предотвращаем сжатие */
    }
    [data-bs-theme="dark"] .theme-toggle-button {
         background-color: var(--zen-card-bg-dark); /* Или фон карточки */
         border-color: var(--zen-border-color-dark);
         box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    }
    .theme-toggle-button:hover {
        border-color: var(--bs-primary);
        box-shadow: 0 4px 8px rgba(0,0,0,0.08);
    }
     [data-bs-theme="dark"] .theme-toggle-button:hover {
         border-color: var(--bs-primary);
         box-shadow: 0 4px 8px rgba(0,0,0,0.15);
    }
    /* Стили для иконок внутри кнопки */
    .theme-icon {
        font-size: 1.1rem; /* Размер иконки */
        /* Цвет иконки будет установлен ниже в правилах для тем */
        transition: color 0.3s ease;
         margin: 0; /* Убираем любые внешние отступы */
         padding: 0; /* Убираем любые внутренние отступы */
    }

    /* Стили для ДИНАМИЧЕСКИХ иконок переключателя тем */
    /* Показываем СОЛНЦЕ, когда тема СВЕТЛАЯ, и устанавливаем цвет */
    [data-bs-theme="light"] .theme-icon-sun {
        display: inline-block;
        color: #ffb142; /* Цвет солнца */
    }
    /* Скрываем ЛУНУ, когда тема СВЕТЛАЯ */
     [data-bs-theme="light"] .theme-icon-moon {
         display: none;
     }

    /* Показываем ЛУНУ, когда тема ТЕМНАЯ, и устанавливаем цвет */
    [data-bs-theme="dark"] .theme-icon-moon {
        display: inline-block;
        color: #cbd5e0; /* Цвет луны (светло-серый) */
    }
    /* Скрываем СОЛНЦЕ, когда тема ТЕМНАЯ */
     [data-bs-theme="dark"] .theme-icon-sun {
         display: none;
     }

     /* Ховер эффект на иконку внутри кнопки */
     .theme-toggle-button:hover .theme-icon {
         color: var(--bs-primary); /* Подсветка иконки цветом primary при наведении на кнопку */
     }


    .navbar-brand-text {
        font-family: 'Montserrat', sans-serif; /* Шрифт как у заголовков */
        font-weight: 600; /* Жирность */
        font-size: 1.1rem; /* Размер шрифта, подберите по вкусу */
        color: var(--bs-heading-color); /* Цвет текста как у заголовков */
        line-height: 1; /* Убедиться, что выравнивание по центру работает */
    }
    /* Убираем подчеркивание у ссылки-бренда */
    .navbar-brand:hover {
        text-decoration: none;
    }

    [data-bs-theme="light"] footer 
    .navbar-brand-text {
    color: #fff; /* Цвет текста в светлой теме футера (белый) */
    }

    footer a.d-flex.align-items-center {
    display: inline-flex !important; /* Переопределяем Bootstrap d-flex */
    }
    /* Удаляем специфические стили для .theme-switch-label */
    /* .theme-switch-label { ... } */
    /* Удаляем специфические стили для .form-switch */
    /* .form-switch .form-check-input { ... } */
    /* Удаляем специфические стили для .form-check-input:checked */
    /* .form-check-input:checked { ... } */
    /* Удаляем специфические стили для .form-switch.d-flex */
    /* .form-switch.d-flex { ... } */


    /* --- Hero Section --- */
    .hero-section {
        padding: 6rem 0 8rem;
        background-color: var(--bs-tertiary-bg);
        overflow: hidden;
        position: relative;
    }
    .hero-section .container {
         position: relative;
         z-index: 1;
    }
    /* ВСТАВЬТЕ ЭТОТ КОД НА МЕСТО СТАРОГО */
    .hero-title { /* Мы создали специальный класс */
        font-size: clamp(2.5rem, calc(2rem + 3vw), 5rem);
        font-weight: 900;
        line-height: 1.2;
        margin-bottom: 1.5rem;
        /* Убедимся, что цвет текста заголовка наследуется правильно */
        color: var(--bs-heading-color); 
    }
    .hero-title span { /* Стили для динамической части теперь привязаны к классу */
        background: var(--zen-primary-gradient-light);
        -webkit-background-clip: text;
        background-clip: text;
        color: transparent;
        display: inline-block;
    }
    [data-bs-theme="dark"] .hero-title span {
        background: var(--zen-primary-gradient-dark);
        -webkit-background-clip: text;
        background-clip: text;
        color: transparent;
    }
    /* Стиль для курсора Typed.js */
    .typed-cursor {
        display: inline-block; /* Курсор должен быть inline */
        font-size: clamp(2.5rem, calc(2rem + 3vw), 5rem); /* Размер курсора как у заголовка */
        font-weight: 900; /* Жирность курсора как у заголовка */
        line-height: 1.2; /* Высота линии курсора как у заголовка */
        color: var(--bs-primary); /* Цвет курсора */
        opacity: 1;
        animation: blink 0.7s infinite;
    }
    @keyframes blink {
        0% { opacity: 1; }
        50% { opacity: 0; }
        100% { opacity: 1; }
    }


    .hero-section .lead {
        font-size: clamp(1rem, calc(1rem + 0.3vw), 1.4rem);
        color: var(--zen-muted-color-light);
        margin-bottom: 2.5rem;
        max-width: 650px;
    }
    [data-bs-theme="dark"] .hero-section .lead { color: var(--zen-muted-color-dark); }
    .hero-image-wrapper:hover .hero-image { transform: rotate(3deg) scale(1.05); }
    /* Показываем обычное лого в светлой теме (по умолчанию) */
    .hero-image-dark {
        display: none; /* Скрываем темное лого */
    }
    .hero-image-light {
        display: inline-block; /* Показываем светлое лого */
        /* Копируем стили из твоего .hero-image */
        max-width: 650px;
        height: auto;
        transition: transform 0.4s ease-out;
    }

    /* Стили для темной темы */
    [data-bs-theme="dark"] .hero-image-light {
        display: none; /* Скрываем светлое лого */
    }
    [data-bs-theme="dark"] .hero-image-dark {
        display: inline-block; /* Показываем темное лого */
        /* Копируем стили из твоего .hero-image */
        max-width: 650px;
        height: auto;
        transition: transform 0.4s ease-out;
    }

    /* Можно общий hover-эффект вынести */
    .hero-image-wrapper:hover .hero-image-light,
    .hero-image-wrapper:hover .hero-image-dark {
        transform: rotate(3deg) scale(1.05);
    }

    /* --- Кнопки --- */
    .btn {
        border-radius: var(--zen-border-radius); /* Этот стиль уже дает закругление */
        padding: 0.8rem 1.8rem; /* Общий padding для большинства кнопок */
        font-weight: 600;
        font-family: 'Outfit', sans-serif;
        transition: var(--zen-transition), transform 0.2s ease-out, box-shadow 0.2s ease-out;
        box-shadow: 0 4px 10px rgba(0,0,0,0.05);
        border: none;
        position: relative;
        overflow: hidden;
        z-index: 1;
    }
    /* Новый стиль для кнопки в навигации (чуть меньше) */
    .btn-navbar {
        padding: 0.5rem 1rem; /* Уменьшенный padding */
        font-size: 0.9rem; /* Размер текста как у btn-sm */
        /* border-radius уже берется из .btn */
    }

    .btn::before {
        content: '';
        position: absolute;
        top: 0; left: 0;
        width: 100%; height: 100%;
        background: rgba(255,255,255,0.1);
        transform: scaleX(0);
        transform-origin: left;
        transition: transform 0.3s ease-in-out;
        z-index: -1;
        border-radius: inherit;
    }
    [data-bs-theme="dark"] .btn::before { background: rgba(0,0,0,0.1); }
    .btn:hover::before { transform: scaleX(1); }
    .btn:hover {
        transform: none;
        /* transform: translateY(-3px);
        box-shadow: 0 8px 18px rgba(0,0,0,0.1); */
    }
    .btn-primary {
        background: var(--zen-primary-gradient-light);
        color: #fff;
        border: none;
    }
    [data-bs-theme="dark"] .btn-primary { background: var(--zen-primary-gradient-dark); color: #000; }
    .btn-primary:hover {
        filter: brightness(1.1);
        box-shadow: 0 8px 18px rgba(var(--zen-primary-rgb-light), 0.25);
    }
    [data-bs-theme="dark"] .btn-primary:hover { box-shadow: 0 8px 18px rgba(var(--zen-primary-rgb-dark), 0.25); }
    .btn-outline-secondary {
        background-color: transparent;
        border: 2px solid var(--bs-border-color);
        color: var(--bs-body-color);
    }
    .btn-outline-secondary:hover {
         background-color: var(--bs-body-color);
         color: var(--bs-body-bg);
         border-color: var(--bs-body-color);
    }


    .btn-outline-orange {
        /* Используй один из цветов твоего оранжевого градиента */
        --orange-color: #ff7e5f; /* Например, коралловый */
        border: 1px solid var(--orange-color);
        color: var(--orange-color);
        background-color: transparent;
    }
    .btn-outline-orange:hover {
        background-color: var(--orange-color);
        color: #fff; /* Белый текст при наведении */
        border-color: var(--orange-color);
        transform: none; /* Убираем подпрыгивание */
        box-shadow: none;
    }

    .btn-secondary-gradient {
        /* Замени на выбранный градиент */
        background: linear-gradient(45deg, #adb5bd, #6c757d); /* Пример серого */
        color: #fff; /* Цвет текста */
        /* Можно добавить стили для темной темы, если нужно */
    }
    .btn-secondary-gradient:hover {
        filter: brightness(1.1); /* Немного ярче при наведении */
        box-shadow: 0 8px 18px rgba(108, 117, 125, 0.2); /* Серая тень */
    }
    /* Не забудь эффекты :before и :hover из общих стилей .btn, они применятся автоматически */

    .btn-orange-gradient {
        /* Пример градиента (можешь подобрать другие оттенки) */
        /* От кораллового к теплому оранжевому */
        background: linear-gradient(45deg, #ff4f5d, #feb47b);
        color: #fff; /* Белый текст хорошо смотрится на оранжевом */
        /* Тень можно сделать оранжевой */
        box-shadow: 0 4px 10px rgba(255, 126, 95, 0.2);
    }
    /* Стили при наведении */
    .btn-orange-gradient:hover {
        filter: brightness(1.1); /* Немного ярче */
        box-shadow: 0 8px 18px rgba(255, 126, 95, 0.3); /* Усиленная тень */
        color: #fff
    }
    /* Эффекты ::before и :hover из .btn применятся */

    /* Стили для оранжевой обводки популярного тарифа */
    .card-price.featured-orange::before {
        background: linear-gradient(45deg, #ff7e5f, #feb47b); /* Тот же оранжевый градиент */
        opacity: 1; /* Делаем обводку видимой по умолчанию */
    }

    /* Если вы хотите, чтобы значок "Популярный" был другого цвета для оранжевого тарифа */
    .card-price.featured-orange .badge.bg-primary {
        background: linear-gradient(45deg, #ff7e5f, #feb47b) !important;  
        color: #fff !important;
        box-shadow: 0 4px 10px rgba(255, 126, 95, 0.2);  
    }
    [data-bs-theme="dark"] .card-price.featured-orange .badge.bg-primary {
        background: linear-gradient(45deg, #ff8a6e, #fec18e) !important;
        color: #000 !important;
        box-shadow: 0 4px 10px rgba(255, 138, 110, 0.25);
    }

    /* (Опционально) Стили для темной темы, если нужно */
    [data-bs-theme="dark"] .btn-orange-gradient {
        /* Можно оставить тот же градиент или сделать его чуть ярче */
        background: linear-gradient(45deg, #ff8a6e, #fec18e);
        color: #000; /* Можно попробовать темный текст */
        box-shadow: 0 4px 10px rgba(255, 138, 110, 0.25);
    }
    [data-bs-theme="dark"] .btn-orange-gradient:hover {
        filter: brightness(1.15);
        box-shadow: 0 8px 18px rgba(255, 138, 110, 0.35);
    }

    /* === НОВЫЕ СТИЛИ ДЛЯ ОРАНЖЕВОЙ ТЕНИ У ПОПУЛЯРНОГО ТАРИФА === */

    /* Тень для светлой темы */
    .card-price.featured.featured-orange { /* Добавляем .featured-orange к селектору */
        /* Можно определить переменные для оранжевого RGB, если хотите */
        /* --zen-orange-rgb: 255, 126, 95; (это примерно #ff7e5f) */
        box-shadow: 0 15px 40px rgba(255, 126, 95, 0.15); /* Оранжевая тень */
    }
    .card-price.featured.featured-orange:hover { /* Тень при наведении для светлой темы */
        box-shadow: 0 20px 45px rgba(255, 126, 95, 0.20); /* Чуть интенсивнее оранжевая тень */
    }


    /* Тень для темной темы */
    [data-bs-theme="dark"] .card-price.featured.featured-orange {
        /* --zen-orange-dark-rgb: 255, 138, 110; (это примерно #ff8a6e) */
        box-shadow: 0 15px 40px rgba(255, 138, 110, 0.2); /* Оранжевая тень для темной темы */
    }
    [data-bs-theme="dark"] .card-price.featured.featured-orange:hover {
        box-shadow: 0 20px 45px rgba(255, 138, 110, 0.25); /* Чуть интенсивнее оранжевая тень для темной темы */
    }
    /* === КОНЕЦ НОВЫХ СТИЛЕЙ ДЛЯ ТЕНИ === */

    /* --- Секция Преимуществ (Features) --- */
    #features { background-color: var(--bs-body-bg); }
    .card-feature {
        background-color: var(--zen-card-bg-light);
        border: 1px solid var(--bs-border-color);
        border-radius: var(--zen-border-radius);
        padding: 2rem 1.5rem;
        text-align: center;
        transition: var(--zen-transition);
        box-shadow: 0 5px 15px rgba(0,0,0,0.03);
        height: 100%;
    }
    [data-bs-theme="dark"] .card-feature { background-color: var(--zen-card-bg-dark); }
    .card-feature:hover {
        transform: translateY(-8px);
        box-shadow: 0 12px 30px rgba(0,0,0,0.08);
        border-color: var(--bs-primary);
    }
    [data-bs-theme="dark"] .card-feature:hover { box-shadow: 0 10px 25px rgba(var(--zen-primary-rgb-dark), 0.1); }
    .feature-icon-wrapper {
        width: 70px; height: 70px;
        margin: 0 auto 1.5rem;
        border-radius: 50%;
        display: flex; align-items: center; justify-content: center;
        background: var(--zen-primary-gradient-light);
        color: #fff;
        font-size: 1.8rem;
        transition: var(--zen-transition);
    }
    [data-bs-theme="dark"] .feature-icon-wrapper { background: var(--zen-primary-gradient-dark); color: #000; }
    .card-feature:hover .feature-icon-wrapper { transform: scale(1.1) rotate(-5deg); }
    .card-feature h5 { font-weight: 700; font-size: 1.2rem; margin-bottom: 0.75rem; }
    .card-feature p { font-size: 0.95rem; color: var(--zen-muted-color-light); line-height: 1.6; }
    [data-bs-theme="dark"] .card-feature p { color: var(--zen-muted-color-dark); }

    /* --- Секция География (Locations) --- ДОБАВЛЕНА --- */
    .locations-section {
        background-color: var(--zen-section-bg-light);
        padding-bottom: 3rem; /* Меньший отступ снизу */
    }
    [data-bs-theme="dark"] .locations-section { background-color: var(--zen-section-bg-dark); }
    .map-container {
        position: relative;
        width: 100%;
        max-width: 800px; /* Увеличил макс. ширину */
        margin: 0 auto;
        aspect-ratio: 2 / 1; /* Пропорции карты, подберите под вашу */
        overflow: hidden;
    }
    .world-map-img {
         display: block;
         width: 100%;
         height: 100%;
         object-fit: contain; /* Или cover, если карта не SVG */
         user-select: none; /* Запретить выделение карты */
         pointer-events: none; /* Запретить взаимодействие с картой */
         opacity: 0.5; /* Прозрачность карты */
         filter: grayscale(50%) contrast(80%); /* Легкая стилизация для светлой темы */
    }
    [data-bs-theme="dark"] .world-map-img {
        opacity: 0.3;
        filter: grayscale(80%) contrast(70%) brightness(0.8) invert(1); /* Стилизация для темной темы */
    }
    .map-point {
        position: absolute;
        width: 12px;
        height: 12px;
        background-color: var(--bs-primary);
        border-radius: 50%;
        box-shadow: 0 0 8px 3px rgba(var(--bs-primary-rgb), 0.6);
        transform: translate(-50%, -50%);
        animation: pulse 2s infinite ease-in-out;
        cursor: default; /* Убрать курсор-руку */
        z-index: 1; /* Быть над картой */
    }
    @keyframes pulse {
         0% { transform: translate(-50%, -50%) scale(0.9); box-shadow: 0 0 0 0 rgba(var(--bs-primary-rgb), 0.7); }
         70% { transform: translate(-50%, -50%) scale(1.1); box-shadow: 0 0 8px 12px rgba(var(--bs-primary-rgb), 0); } /* Увеличенный радиус тени */
         100% { transform: translate(-50%, -50%) scale(0.9); box-shadow: 0 0 0 0 rgba(var(--bs-primary-rgb), 0); }
    }
    .location-list {
         list-style: none;
         padding-left: 0;
    }
    .location-list li {
        margin-bottom: 0.8rem;
        font-size: 1.05rem;
        color: var(--bs-body-color);
        font-weight: 500;
    }
    .location-list i.fas { /* Используем fas для Font Awesome 6 */
         width: 20px;
         text-align: center;
         color: var(--bs-primary);
         margin-right: 0.5rem; /* Добавим отступ справа */
    }

    /* --- Секция Тарифов (Pricing) --- */
    .pricing-section {
        background-color: var(--bs-tertiary-bg);
        clip-path: polygon(0 5%, 100% 0, 100% 100%, 0 100%);
        margin-top: -5rem;
        padding-top: 10rem;
        position: relative;
    }
    .card-price {
        background-color: var(--zen-card-bg-light);
        border: 1px solid var(--bs-border-color);
        border-radius: var(--zen-border-radius);
        box-shadow: 0 8px 20px rgba(0, 0, 0, 0.05);
        transition: var(--zen-transition);
        display: flex; flex-direction: column; height: 100%;
        /* overflow: hidden; */ /* <-- ИСПРАВЛЕНО: Убрано */
        position: relative;
    }
    [data-bs-theme="dark"] .card-price { background-color: var(--zen-card-bg-dark); }
    .card-price::before {
         content: '';
         position: absolute;
         inset: 0;
         border-radius: inherit;
         padding: 2px;
         background: var(--zen-primary-gradient-light);
         -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
                 mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
         -webkit-mask-composite: xor;
                 mask-composite: exclude;
         opacity: 0;
         transition: opacity 0.3s ease;
         z-index: 0;
         pointer-events: none;
    }
    [data-bs-theme="dark"] .card-price::before { background: var(--zen-primary-gradient-dark); }
    .card-price:hover {
        transform: translateY(-10px) scale(1.02);
        box-shadow: 0 15px 35px rgba(0, 0, 0, 0.1);
    }
    [data-bs-theme="dark"] .card-price:hover { box-shadow: 0 15px 35px rgba(var(--zen-primary-rgb-dark), 0.15); }
    .card-price:hover::before { opacity: 1; }
    .card-price .card-body {
        padding: 2rem 1.5rem;
        text-align: center;
        display: flex;
        flex-direction: column;
        flex-grow: 1;
        position: relative;
        z-index: 1;
    }
    .card-price .card-title { font-size: 0.9rem; font-weight: 600; margin-bottom: 0.5rem; color: var(--zen-muted-color-light); text-transform: uppercase; letter-spacing: 1px; }
    [data-bs-theme="dark"] .card-price .card-title { color: var(--zen-muted-color-dark); }
    .price { font-size: 2.8rem; font-weight: 800; color: var(--bs-heading-color); line-height: 1; margin-bottom: 0.5rem; }
    .price-subtext { font-size: 0.9rem; color: var(--zen-muted-color-light); margin-bottom: 2.5rem; }
    [data-bs-theme="dark"] .price-subtext { color: var(--zen-muted-color-dark); }
    .card-price .btn { margin-top: auto; width: 100%; }
    .card-price .btn-outline-primary { border: 2px solid var(--bs-primary); color: var(--bs-primary); background: transparent; }
    .card-price .btn-outline-primary:hover { background: var(--bs-primary); color: #fff; }
    [data-bs-theme="dark"] .card-price .btn-outline-primary:hover { color: #000; }
    .card-price.featured {
        border-color: transparent;
        transform: scale(1.03);
        box-shadow: 0 15px 40px rgba(var(--zen-primary-rgb-light), 0.15);
    }
    [data-bs-theme="dark"] .card-price.featured { box-shadow: 0 15px 40px rgba(var(--zen-primary-rgb-dark), 0.2); }
    .card-price.featured::before { opacity: 1; }
    .card-price.featured:hover { transform: translateY(-5px) scale(1.05); }
    /* .card-price.featured .btn {
        background: var(--zen-primary-gradient-light);
        color: #fff;
        border: none;
    }*/
    [data-bs-theme="dark"] {

        /* Обводка для ОБЫЧНОГО featured тарифа в темной теме (если он у вас был зеленым) */
        .card-price.featured::before { /* Это правило может остаться, если вы хотите, чтобы другие featured (не -orange) были с зеленой обводкой */
            background: var(--zen-primary-gradient-dark);
            opacity: 1; /* Убедимся, что она видна */
        }

        /* === НОВОЕ ПРАВИЛО ДЛЯ ОРАНЖЕВОЙ ОБВОДКИ В ТЕМНОЙ ТЕМЕ === */
        .card-price.featured-orange::before {
            background: linear-gradient(45deg, #ff8a6e, #fec18e); /* Оранжевый градиент для ТЕМНОЙ темы (может быть тот же, что и для кнопки) */
            opacity: 1; /* Убедимся, что она видна */
        }

    }

    /* --- ИСПРАВЛЕНО: Позиция значка "Популярный" --- */
    .badge.bg-primary {
        background: var(--zen-primary-gradient-light) !important;
        color: #fff !important;
        font-size: 0.75rem;
        padding: 0.5em 1em;
        border-radius: 50rem;
        position: absolute;
        top: 0; /* На верхней границе карточки */
        left: 50%;
        transform: translate(-50%, -50%); /* Центрирование и подъем на 50% */
        font-weight: 600;
        box-shadow: 0 4px 10px rgba(var(--zen-primary-rgb-light), 0.2);
        z-index: 2; /* Над рамкой и контентом */
     }
     [data-bs-theme="dark"] .badge.bg-primary {
          background: var(--zen-primary-gradient-dark) !important;
          color: #000 !important;
          box-shadow: 0 4px 10px rgba(var(--zen-primary-rgb-dark), 0.2);
     }
     /* Отступ для контента под значком */
     .card-price.featured .card-body {
        padding-top: 3rem; /* Добавляем отступ сверху */
     }
     .card-price.featured .card-title {
         /* Убираем специфический margin-top, так как отступ теперь на card-body */
         margin-top: 0;
     }

    .pricing-note { font-size: 0.95rem; margin-top: 3rem; color: var(--zen-muted-color-light); }
     [data-bs-theme="dark"] .pricing-note { color: var(--zen-muted-color-dark); }

    /* --- Секция Шагов (Steps) --- */
    .steps-section {
        background-color: var(--zen-section-bg-light); /* Серый фон для светлой темы */
    }
    [data-bs-theme="dark"] .steps-section {
        background-color: var(--zen-section-bg-dark); /* Серый фон для темной темы */
    }
    .step-item { text-align: center; }
    .step-icon-wrapper {
        width: 80px; height: 80px;
        margin: 0 auto 1.5rem;
        border-radius: 50%;
        display: flex; align-items: center; justify-content: center;
        border: 2px dashed var(--bs-primary);
         background: rgba(var(--bs-primary-rgb), 0.05);
        transition: var(--zen-transition);
    }
    .step-icon { font-size: 2.2rem; color: var(--bs-primary); transition: var(--zen-transition); }
    .step-item:hover .step-icon-wrapper { background: rgba(var(--bs-primary-rgb), 0.1); border-style: solid; }
    .step-item:hover .step-icon { transform: scale(1.1) rotate(5deg); }
    .steps-section h5 { font-weight: 700; font-size: 1.1rem; margin-bottom: 0.5rem; }
    .steps-section p { font-size: 0.9rem; color: var(--zen-muted-color-light); }
     [data-bs-theme="dark"] .steps-section p { color: var(--zen-muted-color-dark); }

    /* --- FAQ Section --- */
    .faq-section {
        background-color: var(--bs-tertiary-bg);
         clip-path: polygon(0 5%, 100% 0, 100% 100%, 0 100%);
         margin-top: -5rem;
         padding-top: 10rem;
    }
    .accordion-item {
        background-color: var(--zen-card-bg-light);
        border: 1px solid var(--bs-border-color);
        border-radius: var(--zen-border-radius) !important;
        margin-bottom: 1rem;
        overflow: hidden;
         transition: var(--zen-transition), box-shadow 0.3s ease, background-color 0.3s ease;
    }
     [data-bs-theme="dark"] .accordion-item { background-color: var(--zen-card-bg-dark); }
     .accordion-item:hover {
         background-color: var(--zen-section-bg-light);
         box-shadow: 0 5px 15px rgba(0,0,0,0.04);
     }
     [data-bs-theme="dark"] .accordion-item:hover {
         background-color: var(--zen-card-bg-dark);
         border-color: rgba(255, 255, 255, 0.15);
         box-shadow: 0 5px 15px rgba(0,0,0,0.1);
     }
    .accordion-button {
        font-weight: 600;
        font-family: 'Outfit', sans-serif;
        background-color: transparent;
        color: var(--bs-heading-color);
        padding: 1.25rem 1.5rem;
         transition: background-color 0.3s ease;
         width: 100%;
         text-align: left;
    }
    .accordion-button:not(.collapsed) {
        background-color: rgba(var(--bs-primary-rgb), 0.1);
        color: var(--bs-primary);
        box-shadow: none;
    }
    .accordion-button:focus { box-shadow: none; }
    .accordion-button::after {
        flex-shrink: 0;
        width: 1.2rem;
        height: 1.2rem;
        margin-left: auto;
        content: "";
        background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%236c757d'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
        background-repeat: no-repeat;
        background-size: 1.2rem;
        transition: transform .3s ease-in-out;
    }
    [data-bs-theme="dark"] .accordion-button::after {
         background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%238a8a8a'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
    }
    .accordion-button:not(.collapsed)::after { transform: rotate(-180deg); }
     [data-bs-theme="dark"] .accordion-button:not(.collapsed)::after {
         background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%2355efc4'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
     }
    .accordion-body {
        padding: 1.25rem 1.5rem; /* Изменено: верх/низ=1.25rem, лево/право=1.5rem */
        font-size: 0.95rem;
        line-height: 1.7;
        color: var(--zen-muted-color-light);
    }
    [data-bs-theme="dark"] .accordion-body { color: var(--zen-muted-color-dark); }

    /* --- Стили для нового футера --- */
    .footer {
        background-color: #1a202c; /* Темный для светлой */
        color: rgba(255,255,255,0.7);
        font-size: 0.9em;
        border-top: none;
    }
    [data-bs-theme="dark"] .footer {
        background-color: var(--zen-section-bg-dark); /* Фон секции для темной */
        color: var(--zen-muted-color-dark);
    }
    .footer .logo-footer {
        max-height: 30px; /* Можете изменить высоту малого лого */
        opacity: 0.9;
        filter: brightness(0) invert(1); /* Делаем лого белым для светлой темы (т.к. фон темный) */
    }
    [data-bs-theme="dark"] .footer .logo-footer {
        filter: none; /* Убираем фильтр для темной темы */
    }
    /* ДОБАВЬТЕ ЭТО ПРАВИЛО: */
    [data-bs-theme="light"] .footer .logo-footer {
        filter: none; /* Отменяем фильтр для светлой темы */
    }
    [data-bs-theme="light"] .footer .text-muted {
        color: rgba(255, 255, 255, 0.75) !important; /* Явный, чуть более яркий цвет для светлой темы */
    }
    .footer-heading {
        font-family: 'Outfit', sans-serif;
        font-weight: 600;
        font-size: 1rem;
        color: #fff; /* Белый заголовок для светлой темы */
        margin-bottom: 1rem;
        margin-top: 0.3rem; /* Подберите это значение, пока верхний край текста "КОНТАКТЫ" не совпадет с верхним краем логотипа ZenXNet */
        text-transform: uppercase;
        letter-spacing: 0.5px;
    }
    [data-bs-theme="dark"] .footer-heading {
        color: var(--bs-heading-color); /* Цвет заголовка для темной темы */
    }
    /* --- Обновленные стили для ссылок в футере --- */
    .footer-links li {
        margin-bottom: 0.5rem; /* Немного уменьшим отступ между строками */
    }
    .footer-links a {
        color: rgba(255, 255, 255, 0.75); /* Чуть светлее для светлой темы */
        text-decoration: none; /* Убираем подчеркивание по умолчанию */
        transition: var(--zen-transition);
        display: inline-block; /* Для корректного hover-эффекта */
        position: relative; /* Для псевдоэлемента подчеркивания */
    }
    [data-bs-theme="dark"] .footer-links a {
        color: var(--zen-muted-color-dark); /* Используем приглушенный цвет для темной темы */
    }

    /* Эффект подчеркивания при наведении */
    .footer-links a::after {
        content: '';
        position: absolute;
        width: 0;
        height: 1px;
        display: block;
        margin-top: 2px; /* Небольшой отступ от текста */
        right: 0;
        background: var(--bs-primary);
        transition: width 0.3s ease;
        -webkit-transition: width 0.3s ease;
    }
    .footer-links a:hover::after {
        width: 100%;
        left: 0;
        background: var(--bs-primary);
    }
    .footer-links a:hover {
        color: #fff; /* Ярче при наведении для светлой темы */
        /* text-decoration: underline; Убрали, используем псевдоэлемент */
    }
    [data-bs-theme="dark"] .footer-links a:hover {
        color: var(--bs-link-hover-color); /* Цвет при наведении для темной темы */
    }

    /* Выравнивание иконок (оставляем как было или чуть корректируем) */
    .footer-links i.fa-fw {
        width: 1.2em;
        text-align: center;
        opacity: 0.8; /* Чуть приглушим иконки */
        margin-right: 0.3rem; /* Немного уменьшим отступ от иконки */
    }

    @media (max-width: 991px) {
    .hero-section .lead {
        max-width: none;
    }

    .hero-section {
        padding: 4rem 0 5rem;
    }
    .hero-section h1 {
        font-size: calc(1.8rem + 4vw);
    }
     /* Адаптация размера курсора Typed.js */
    .hero-section h1 .typed-cursor {
        font-size: calc(1.8rem + 4vw); /* Размер курсора совпадает с h1 */
    }


    .hero-image-light,
    [data-bs-theme="dark"] .hero-image-dark {
        max-width: 350px; /* Размер лого для этого брейкпоинта */
    }

    .location-list {
        margin-top: 2.5rem;
        text-align: center;
    }

    /* --- Дополнительно (если нужно скрыть лого уже на 991px) --- */

    /* .hero-image-wrapper {
        display: none;
    } */
    }

    /* --- Медиа-запросы (адаптивность) --- */
    @media (max-width: 767px) {
        .section { padding: 3.5rem 0; }
        .section-title { font-size: calc(1.6rem + 1.5vw); margin-bottom: 2.5rem;}
         .locations-section, .pricing-section, .faq-section { margin-top: -3.5rem; padding-top: 7rem; clip-path: polygon(0 3%, 100% 0, 100% 100%, 0 100%); }
        .card-price { margin-bottom: 1.5rem; }
        /* Убираем специфический отступ для .featured на мобильных, т.к. бейдж по центру */
         .card-price.featured .card-body { padding-top: 3rem; }
         .card-price.featured .card-title { margin-top: 0; }
         .badge.bg-primary { top: 0; transform: translate(-50%, -50%); } /* Переопределяем для точного центрирования по границе */

         /* .hero-image-wrapper {
            display: none;
         } */

         .hero-image-light,
         [data-bs-theme="dark"] .hero-image-dark {
         max-width: 280px;
         }

        .footer { text-align: center; padding: 2rem 0; }
        .footer .row > div { margin-bottom: 1rem; }
        .footer .text-md-end, .footer .text-md-start { text-align: center !important; }
    }

    /* Удаляем старые стили для динамических иконок, они перенесены наверх */
    /* .theme-icon { ... } */
    /* [data-bs-theme="light"] .theme-icon-sun { ... } */
    /* [data-bs-theme="dark"] .theme-icon-moon { ... } */
    /* .theme-switch-wrapper:hover .theme-icon { ... } */


    #paymentModal .modal-dialog {
        /* Можно немного увеличить максимальную ширину, если нужно */
        max-width: 550px;
    }

    #paymentModal .modal-content {
        /* Используем переменные для фона и границы из темы */
        background-color: var(--zen-card-bg-light);
        border: 1px solid var(--bs-border-color);
        border-radius: var(--zen-border-radius); /* Твое скругление */
        box-shadow: 0 0.5rem 2rem rgba(0, 0, 0, 0.1); /* Более выраженная тень */
        /* Убираем стандартную рамку Bootstrap Modal */
        border: none;
    }
    [data-bs-theme="dark"] #paymentModal .modal-content {
        background-color: var(--zen-card-bg-dark);
        border-color: var(--zen-border-color-dark);
        box-shadow: 0 0.5rem 2rem rgba(0, 0, 0, 0.25);
    }

    #paymentModal .modal-header {
        border-bottom: 1px solid var(--bs-border-color);
        padding: 1rem 1.5rem;
        /* Добавляем небольшой градиентный фон для заголовка */
        background: linear-gradient(to right, rgba(var(--bs-primary-rgb), 0.05), transparent);
    }
    [data-bs-theme="dark"] #paymentModal .modal-header {
        background: linear-gradient(to right, rgba(var(--bs-primary-rgb), 0.1), transparent);
    }

    #paymentModal .modal-header .modal-title {
        font-family: 'Outfit', sans-serif;
        font-weight: 700;
        color: var(--bs-heading-color);
        /* Можно сделать чуть крупнее */
        font-size: 1.1rem;
    }
    #paymentModal .modal-header .btn-close {
        /* Стилизация кнопки закрытия */
        filter: var(--bs-body-color) /* Фильтр для цвета крестика */;
    }
    [data-bs-theme="dark"] #paymentModal .modal-header .btn-close {
        filter: invert(1) grayscale(100%) brightness(2); /* Белый крестик для темной */
    }


    #paymentModal .modal-body {
        padding: 1.5rem 1.5rem; /* Основные отступы тела */
    }

    /* Блок с информацией о тарифе и цене */
    #paymentModal #modalTariffInfo {
        margin-bottom: 1.5rem; /* Отступ под блоком цены */
    }
    #paymentModal #modalTariffInfo .lead {
        color: var(--bs-body-color);
        margin-bottom: 0.5rem; /* Меньше отступ */
    }
    #paymentModal #modalTariffInfo .h4 { /* Финальная цена */
        font-weight: 800;
        color: var(--bs-primary);
        margin-bottom: 0.25rem !important;
        /* Можно сделать чуть крупнее */
        font-size: 1.6rem;
    }
    [data-bs-theme="dark"] #paymentModal #modalTariffInfo .h4 { color: var(--zen-primary-solid-dark); }
    #paymentModal #modalTariffInfo .price-original {
        font-weight: 400; /* Не жирным */
        font-size: 0.85em; /* Чуть меньше */
        color: var(--zen-muted-color-light); /* Приглушенный цвет */
    }
    [data-bs-theme="dark"] #paymentModal #modalTariffInfo .price-original {
        color: var(--zen-muted-color-dark);
    }
    #paymentModal #modalDiscountInfo { /* Текст скидки */
        font-weight: 500;
        margin-bottom: 1rem !important;
    }
    #paymentModal #modalDiscountInfo code { /* Промокод в тексте скидки */
        font-size: 1em; /* Нормальный размер */
        padding: 0.1em 0.3em;
    }

    /* Форма промокода - стили уже должны быть от pay.php, можно не дублировать */
    /* Если их нет, скопируй блок "Стили для формы промокода" сюда */


    /* Кнопки оплаты */
    #paymentModal #modalPaymentOptions .btn-payment {
        /* Можно добавить специфичные стили, если нужно */
        /* Например, немного уменьшить вертикальные отступы */
        padding-top: 0.7rem;
        padding-bottom: 0.7rem;
    }

    /* Подвал модального окна */
    #paymentModal .modal-footer {
        border-top: none; /* Убираем верхнюю границу футера */
        padding: 1rem 1.5rem; /* Отступы */
        background-color: transparent; /* Убираем фон футера */
    }
    #paymentModal .modal-footer .btn-link {
        color: var(--zen-muted-color-light);
        text-decoration: none;
        font-weight: 500;
        padding: 0.5rem 1rem;
        border-radius: var(--zen-border-radius);
        transition: var(--zen-transition);
        /* Делаем ее похожей на outline-secondary */
        border: 1px solid var(--bs-border-color);
        background-color: transparent;
    }
    [data-bs-theme="dark"] #paymentModal .modal-footer .btn-link {
        color: var(--zen-muted-color-dark);
        border-color: var(--zen-border-color-dark);
    }
    #paymentModal .modal-footer .btn-link:hover {
        background-color: var(--bs-secondary-bg); /* Легкий фон при наведении */
        color: var(--bs-body-color);
        border-color: transparent; /* Убираем рамку при наведении */
    }
    [data-bs-theme="dark"] #paymentModal .modal-footer .btn-link:hover {
        background-color: var(--zen-card-bg-dark); /* Другой фон для темной */
    }
    /* === Конец стилей для модального окна === */