@font-face {
    font-family: 'Afacad', sans-serif !important;
    font-display: swap;
    src: url('../bestSpa-fonts/bestSpa-Afacad.woff2') format("woff2")
}

body {
    margin: 0;
    padding: 0;
    background-color: #0D5EB0;
}

/* Базовые настройки */
h1,
h2,
h3,
p,
ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.bestSpa-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 15px;
    box-sizing: border-box;
}

/* Header */
.bestSpa-header-sec {
    background-color: #F1F1F1;
    padding: 10px 0;
}

.bestSpa-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.bestSpa-logo {
    display: flex;
    align-items: center;
    gap: 10px;
    color: #fff;
}

.bestSpa-logo-text {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 700;
    font-size: 18px;
    line-height: 1.1;
    font-style: italic;
}

.bestSpa-nav-list {
    display: flex;
    gap: 40px;
}

.bestSpa-nav-link {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 400;
    font-style: Regular;
    font-size: 16px;
    color: #222;
    padding: 10px;
    text-decoration: none;
    transition: opacity 0.3s;
}

.bestSpa-nav-link:hover {
    opacity: 0.8;
}

.bestSpa-age-badge {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 700;
    font-size: 24px;
    color: #fff;
    font-style: italic;
}

/* Hero Section */
.bestSpa-hero-sec {
    background-color: rgba(57, 113, 198, 1);
    padding: 10px 0;
    text-align: center;
    position: relative;
    overflow: hidden;
}

.yell-p {
    background: linear-gradient(90deg, #FA8500 0%, #FFB500 50%, #FA8500 100%);
    padding: 8px 24px;
    font-family: 'Afacad', sans-serif !important;
    width: 100%;
    max-width: 470px;
    text-align: center;
    border-radius: 16px;
    font-weight: 700;
    font-style: Bold;
    font-size: 12px;
    color: #FFFFFF;
}

.bestSpa-hero-cont {
    position: relative;
}



.bestSpa-hero-content {
    width: 100%;
    max-width: 805px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 10px 0px;
    align-items: center;
}

.bestSpa-title {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 600;
    font-style: SemiBold;
    font-size: 36px;
    text-align: center;
    color: rgba(255, 255, 255, 1);
}

.bestSpa-subtitle {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 400;
    font-style: Regular;
    font-size: 16px;
    max-width: 780px;
    text-align: center;
    color: rgba(255, 255, 255, 1);
}

.bestSpa-features {
    display: flex;
    justify-content: center;
    gap: 20px;
    background: linear-gradient(90deg, #FA8500 0%, #FFB500 50%, #FA8500 100%);
    padding: 4px 24px;
    font-family: 'Afacad', sans-serif !important;
    width: 100%;
    text-align: center;
    border-radius: 16px;
    font-weight: 700;
    font-style: Bold;
    font-size: 12px;
    color: #FFFFFF;
    box-sizing: border-box;
}

.bestSpa-feature-item {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 500;
    font-size: 13px;
    display: flex;
    align-items: center;
    gap: 10px;
    color: rgba(255, 255, 255, 1);
    text-align: left;
}

/* Casino List Section */
.bestSpa-list-sec {
    /* Добавляем полупрозрачный слой вашего цвета поверх картинки */
    background-image: linear-gradient(0deg, rgba(13, 94, 176, 0.8), rgba(13, 94, 176, 0.8)),
        url('../bestSpa-img/bestSpa-city.webp');
    background-color: #0D5EB0;
    /* Цвет как запасной вариант (fallback) */
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    padding-bottom: 150px;
}

.cas-sec {
    margin-top: -150px;
}

.bestSpa-casino-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 10px 0px;
}

.bestSpa-card {
    display: flex;
    background: #F6FAFF;
    box-shadow: 0px 0px 14px 0px #4996F0;
    border-radius: 12px;
    position: relative;
    border: 1px solid #F6FAFF;
}

.bestSpa-card-badge {
    position: absolute;
    top: -10px;
    padding: 5px 20px;
    left: 8px;
    border-radius: 100px;
    font-family: 'Afacad', sans-serif !important;
    font-weight: 700;
    font-style: Bold;
    font-size: 14px;
    color: #272727;
}

.bestSpa-badge-top {
    background: #FFFFFF;
}

.bestSpa-badge-rec {
    background: #ff76ad;
    opacity: 0.8;
}

.bestSpa-card-content {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 7px;
    justify-content: space-between;
}

.bestSpa-card-logo {
    background: #0050A1;
    width: 260px;
    height: 120px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-top-left-radius: 12px;
    border-bottom-left-radius: 12px;
}

.bestSpa-card-logo a {
    width: 260px;
    display: flex;
    justify-content: center;
}

.bestSpa-card-logo img {
    max-width: 240px;
    max-height: 82px;
}

.bestSpa-card-info {
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 100%;
    max-width: 400px;
    align-items: center;
}

.bestSpa-card-info h2 {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 700;
    font-style: Bold;
    font-size: 20px;
    color: #0050A1;
    text-align: center;
}

.blue-div {
    font-family: 'Afacad', sans-serif !important;
    display: flex;
    align-items: center;
    gap: 5px;
    background: #0050A1;
    border-top-left-radius: 60px;
    border-top-right-radius: 60px;
    border-bottom-left-radius: 60px;
    padding: 2px 10px;
    color: #fff;
}

.bestSpa-license {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 400;
    font-size: 12px;
    color: #999;
}

.bestSpa-container-list {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 15px;
    box-sizing: border-box;
}

.bestSpa-card-rating {
    display: flex;
    flex-direction: column;
    gap: 5px;
    align-items: center;
}

.bestSpa-card-rating p {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 500;
    font-size: 12px;
    text-align: center;
    color: #0050A1;
}

.bestSpa-online-status p {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 700;
    font-style: Bold;
    font-size: 15px;
    text-align: center;
    color: rgba(57, 113, 198, 1);
}

.bestSpa-rating-num {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 500;
    font-style: Medium;
    font-size: 42px;
    text-align: center;
    color: #0050A1;
    line-height: 100%;
}

.bestSpa-stars {
    display: flex;
    align-items: center;
    gap: 2px;
}

.bestSpa-card-action {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 5px;
    width: 100%;
    max-width: 311px;
}

.bestSpa-online-status li {
    display: flex;
}

.bestSpa-online-status {
    font-family: 'Afacad', sans-serif !important;
    padding: 5px 10px;
    border: 1px solid #8ACB3F;
    border-radius: 100px;
    font-weight: 400;
    font-size: 13px;
    color: rgba(57, 113, 198, 1);
    display: flex;
    align-items: center;
    gap: 20px;
}

.bestSpa-pulse-dot {
    width: 8px;
    height: 8px;
    background: #28a745;
    border-radius: 50%;
    box-shadow: 0 0 0 rgba(40, 167, 69, 0.4);
    animation: bestSpa-pulse 2s infinite;
}

.bestSpa-btn {
    background: linear-gradient(90deg, #7029FF 0%, #F444DD 100%);
    color: rgba(255, 255, 255, 1);
    padding: 15px 36px;
    border-radius: 100px;
    text-decoration: none;
    font-family: 'Afacad', sans-serif !important;
    font-weight: 700;
    font-style: Bold;
    font-size: 16px;
    text-transform: uppercase;
    transition: transform 0.3s;
}

.bestSpa-btn:hover {
    transform: scale(1.05);
}

@keyframes bestSpa-pulse {
    0% {
        transform: scale(0.95);
        box-shadow: 0 0 0 0 rgba(40, 167, 69, 0.7);
    }

    70% {
        transform: scale(1);
        box-shadow: 0 0 0 10px rgba(40, 167, 69, 0);
    }

    100% {
        transform: scale(0.95);
        box-shadow: 0 0 0 0 rgba(40, 167, 69, 0);
    }
}

.bestSpa-mob-item {
    display: none;
}

/* Адаптив */
@media (max-width: 922px) {
    .bestSpa-card-content {
        flex-direction: column;
        text-align: center;
    }

    .bestSpa-flag-left,
    .bestSpa-flag-right {
        display: none;
    }

    .card-shadow {
        display: none;
    }

    .bestSpa-mob-item {
        display: block;
    }

    .bestSpa-card {
        display: none;
    }


}

/* Родителю задаем относительное позиционирование */
.bestSpa-hero-cont {
    position: relative;
    z-index: 10;
}

/* Общий стиль для обоих флагов */
.bestSpa-flag {
    position: absolute;
    top: 30%;
    transform: translateY(-1%);
    width: 180px;
    pointer-events: none;
}

.bestSpa-flag img {
    width: 100%;
    height: auto;
    display: block;
}

/* Позиция левого флага */
.bestSpa-flag-left {
    left: -1px;
    /* Выносим за пределы контейнера 1140px влево */
}

/* Позиция правого флага */
.bestSpa-flag-right {
    right: -1px;
    /* Выносим за пределы контейнера 1140px вправо */
}

/* Адаптив: убираем флаги или уменьшаем их, чтобы они не перекрывали текст на мобилках */
@media (max-width: 1300px) {
    .bestSpa-flag-left {
        left: 0;
        opacity: 0.5;
    }

    .bestSpa-flag-right {
        right: 0;
        opacity: 0.5;
    }
}

@media (max-width: 1100px) {

    /* На маленьких экранах флаги обычно скрывают, чтобы не загромождать интерфейс */
    .bestSpa-flag {
        display: none;
    }
}

/* Базовый контейнер */
.bestSpa-container {
    max-width: 1140px;
    margin: 0 auto;
    padding: 0 15px;
    box-sizing: border-box;
}

/* --- SECTION CHOOSE --- */
.bestSpa-choose-sec {
    background-color: rgba(57, 113, 198, 1);
    padding: 70px 0;
    color: #ffffff;
}

.bestSpa-choose-flex {
    display: flex;
    justify-content: space-between;
    gap: 20px;
}

.bestSpa-choose-text {
    display: flex;
    flex-direction: column;
    gap: 20px;
    max-width: 560px;
}

.bestSpa-choose-title {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 700;
    font-style: Bold;
    font-size: 32px;
    color: rgba(255, 255, 255, 1);
}

.bestSpa-choose-desc {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 400;
    font-style: Regular;
    font-size: 15px;
    color: rgba(255, 255, 255, 1);
}

.bestSpa-choose-desc:last-child {
    margin-bottom: 0;
}


.bestSpa-choose-img img {
    width: 100%;
    height: auto;
}

/* --- SECTION LEGAL CARDS --- */
.bestSpa-legal-sec {
    background-color: rgba(57, 113, 198, 1);
    padding: 70px 0;
    /* Чтобы секции сливались фоном */
}

.bestSpa-legal-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

.bestSpa-legal-card {
    background-color: rgba(222, 235, 255, 1);
    /* Светло-голубой фон карточек */
    padding: 40px;
    border-radius: 20px;
    /* Сильное скругление как на макете */
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.bestSpa-legal-title {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 700;
    font-style: Bold;
    font-size: 32px;
    color: rgba(57, 113, 198, 1);
    text-align: left;
}

.bestSpa-legal-text {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 400;
    font-style: Regular;
    font-size: 15px;
    color: rgba(57, 113, 198, 1);
    margin-bottom: 20px;
}

.bestSpa-legal-text:last-child {
    margin-bottom: 0;
}

/* --- АДАПТИВНОСТЬ --- */

@media (max-width: 992px) {
    .bestSpa-choose-flex {
        flex-direction: column;
    }

    .bestSpa-choose-title {
        font-size: 28px;
    }

    .bestSpa-legal-grid {
        grid-template-columns: 1fr;
        /* Карточки одна под другой */
    }

    .bestSpa-legal-card {
        padding: 30px;
    }
}

@media (max-width: 600px) {
    .bestSpa-choose-sec {
        padding: 50px 0;
    }

    .bestSpa-choose-title {
        font-size: 24px;
    }

    .bestSpa-legal-title {
        font-size: 24px;
    }
}

/* --- FOOTER STYLES (bestSpa) --- */
.bestSpa-footer {
    background-color: rgba(57, 113, 198, 1);
    color: #ffffff;
    padding: 70px 0;
    border-top: 1px solid rgba(255, 255, 255, 0.4);
    font-family: 'Afacad', sans-serif !important;
}

.bestSpa-container {
    max-width: 1140px;
    margin: 0 auto;
    padding: 0 15px;
    box-sizing: border-box;
}

/* Верхний блок в две колонки */
.bestSpa-footer-top {
    display: flex;
    gap: 20px;
    margin-bottom: 60px;
}

.bestSpa-footer-col p {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 400;
    font-style: Regular;
    font-size: 15px;
    color: rgba(255, 255, 255, 1);
}

.bestSpa-footer-col {
    max-width: 560px;
}

/* Центральные текстовые предупреждения */
.bestSpa-footer-info {
    text-align: center;
    margin-bottom: 60px;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.bestSpa-footer-info p {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 400;
    font-style: Regular;
    font-size: 15px;
    color: rgba(255, 255, 255, 1);
    text-align: center;
}

/* Юридическая плашка с логотипами */
.bestSpa-footer-legal-bar {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 60px;
}

.bestSpa-legal-text-main p {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 700;
    font-style: Bold;
    font-size: 20px;
    color: rgba(255, 255, 255, 1);
}

/* Ссылки */
.bestSpa-footer-nav {
    margin-bottom: 60px;
}

.bestSpa-footer-links {
    display: flex;
    justify-content: center;
    gap: 60px;
    flex-wrap: wrap;
    list-style: none;
    padding: 0;
}

.bestSpa-footer-links a {
    color: rgba(255, 255, 255, 1);
    text-decoration: underline;
    font-family: 'Afacad', sans-serif !important;
    font-weight: 400;
    font-style: Regular;
    font-size: 15px;
    transition: opacity 0.3s;
}

.bestSpa-footer-links a:hover {
    opacity: 0.7;
}

/* Копирайт */
.bestSpa-footer-bottom {
    text-align: center;
}

.bestSpa-footer-bottom p {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 700;
    font-style: Bold;
    font-size: 15px;
    text-align: center;
    color: rgba(255, 255, 255, 1);
}

/* --- АДАПТИВНОСТЬ --- */
@media (max-width: 992px) {
    .bestSpa-footer-top {
        flex-direction: column;
    }

    .bestSpa-footer-legal-bar {
        flex-direction: column;
        gap: 20px;
    }

    .bestSpa-footer-legal-bar {
        align-items: flex-start;
    }

    .bestSpa-legal-text-main p {
        font-size: 16px;
    }
}

@media (max-width: 600px) {
    .bestSpa-footer-links {
        align-items: center;
    }

    .bestSpa-footer-info p {
        font-size: 13px;
    }
}

/* --- АНИМАЦИЯ ПЕРΕЛИВАЮЩЕЙСЯ КНОПКИ --- */
.bestSpa-btn {
    /* Делаем градиент длиннее, чтобы было чему двигаться */
    background: linear-gradient(90deg, #8ACB3F 0%, #8ACB3F 100%);
    background-size: 200% auto;
    color: #fff;
    width: 100%;
    max-width: 243px;
    padding: 20px 10px;
    border-radius: 10px;
    text-decoration: none;
    font-family: 'Afacad', sans-serif !important;
    font-weight: 700;
    font-size: 16px;
    display: inline-block;
    text-align: center;
    transition: transform 0.3s ease;
    /* Запуск анимации */
    animation: bestSpa-gradient-shift 3s linear infinite;
    border: none;
    cursor: pointer;
}

.bestSpa-btn:hover {
    transform: scale(1.05);
}

@keyframes bestSpa-gradient-shift {
    0% {
        background-position: 0% 50%;
    }

    100% {
        background-position: 200% 50%;
    }
}

/* --- СТИЛИ БУРГЕРА (Кнопка) --- */
.burger {
    display: none;
    /* Скрыт на десктопе */
    flex-direction: column;
    justify-content: space-between;
    width: 30px;
    height: 20px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    z-index: 1001;
}

.burger span {
    display: block;
    width: 100%;
    height: 3px;
    background-color: #fff;
    border-radius: 3px;
    transition: all 0.3s ease;
}

/* Анимация превращения в крестик */
.bestSpa-burger-open span:nth-child(1) {
    transform: translateY(8.5px) rotate(45deg);
}

.bestSpa-burger-open span:nth-child(2) {
    opacity: 0;
}

.bestSpa-burger-open span:nth-child(3) {
    transform: translateY(-8.5px) rotate(-45deg);
}

/* --- МОБИЛЬНАЯ НАВИГАЦИЯ --- */
@media (max-width: 922px) {
    .burger {
        display: flex;
    }

    .bestSpa-nav {
        position: fixed;
        top: 0;
        right: -100%;
        /* Прячем за экран */
        width: 100%;
        height: 100vh;
        background-color: rgba(57, 113, 198, 0.98);
        backdrop-filter: blur(10px);
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        transition: right 0.5s cubic-bezier(0.77, 0.2, 0.05, 1.0);
        z-index: 1000;
    }

    .bestSpa-nav.bestSpa-nav-active {
        right: 0;
        /* Выезжает */
    }

    .bestSpa-nav-list {
        flex-direction: column;
        gap: 30px;
        text-align: center;
    }

    .bestSpa-nav-link {
        font-size: 24px;
    }

    .bestSpa-no-scroll {
        overflow: hidden;
    }
}

/* Кнопка бургера */
.bestSpa-burger {
    display: none;
    /* Скрыта на десктопе */
    flex-direction: column;
    justify-content: space-between;
    width: 30px;
    height: 22px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    z-index: 1005;
    /* Чтобы была поверх выезжающего меню */
}

.bestSpa-logomob {
    display: none;
}

/* Показываем бургер только на экранах меньше 922px */
@media (max-width: 922px) {
    .bestSpa-burger {
        display: flex;
        justify-content: center;
    }

    /* Скрываем обычную навигацию на мобилках, 
       она будет выезжать по клику (логика в предыдущем сообщении) */
    .bestSpa-nav {
        display: none;
    }

    .bestSpa-nav.bestSpa-nav-active {
        display: flex;
    }

    .bestSpa-logo {
        display: none;
    }

    .bestSpa-logomob a {
        display: flex;
    }

    .bestSpa-logomob {
        display: flex;
    }
}

/* --- МОБИЛЬНАЯ КΑΡТОЧКА (bestSpa) --- */

.bestSpa-mob-item {
    background-color: #E2ECF9;
    /* Нежно-голубой фон */
    border-radius: 10px;
    padding: 35px 10px 20px;
    position: relative;
    list-style: none;
    margin-bottom: 10px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
}

.bestSpa-mob-brand a {
    display: flex;
    width: 100%;
    justify-content: center;
}

/* Розовый бейдж сверху */
.bestSpa-mob-tag {
    position: absolute;
    top: -15px;
    left: 50%;
    transform: translateX(-50%);
    background-color: #FF97C1;
    color: #ffffff;
    padding: 6px 30px;
    border-radius: 50px;
    font-family: 'Afacad', sans-serif !important;
    font-weight: 700;
    font-size: 16px;
    white-space: nowrap;
    z-index: 10;
}

/* Индикатор live (в углу) */
.bestSpa-mob-live {
    position: absolute;
    top: 15px;
    left: 15px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.bestSpa-mob-live img {
    width: 20px;
    height: auto;
}

.bestSpa-mob-live-count {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 700;
    font-size: 15px;
    color: rgba(57, 113, 198, 1);
}

/* Контентная обертка */
.bestSpa-mob-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.bestSpa-mob-brand {
    width: 180px;
    margin-bottom: 12px;
}

.bestSpa-mob-brand img {
    max-width: 180px;
    max-height: 52px;
}

/* Сетка заголовка и рейтинга */
.bestSpa-mob-info-grid {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    margin-bottom: 10px;
}

.bestSpa-mob-title {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 700;
    font-size: 20px;
    line-height: 1.2;
    color: rgba(57, 113, 198, 1);
    text-align: left;
}

/* Блок рейтинга */
.bestSpa-mob-rating-box {
    display: flex;
    flex-direction: column;
    gap: 5px;
    align-items: center;
}

.bestSpa-mob-score {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 700;
    font-size: 30px;
    color: rgba(57, 113, 198, 1);
    display: block;
    line-height: 1;
}

.bestSpa-mob-license {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 400;
    font-size: 11px;
    color: rgba(57, 113, 198, 0.7);
}

.bestSpa-mob-stars-list {
    display: flex;
    justify-content: flex-end;
    gap: 2px;
    padding: 0;
}

/* --- ПЕРЕЛИВАЮЩАЯСЯ КНОПКА --- */
.bestSpa-mob-action-btn {
    width: 100%;
    display: block;
    padding: 16px 10px;
    border-radius: 50px;
    color: #ffffff;
    font-family: 'Afacad', sans-serif !important;
    font-weight: 700;
    font-size: 16px;
    text-decoration: none;
    text-align: center;
    border: none;
    cursor: pointer;

    /* Градиент */
    background: linear-gradient(90deg, #6e3eff, #ff3ec9, #6e3eff);
    background-size: 200% auto;
    animation: bestSpa-btn-glow 3s linear infinite;
    transition: transform 0.3s ease;
    box-sizing: border-box;
}

.bestSpa-mob-action-btn:hover {
    transform: scale(1.03);
}

@keyframes bestSpa-btn-glow {
    0% {
        background-position: 0% 50%;
    }

    100% {
        background-position: 200% 50%;
    }
}

.bestSpa-mob-footer {
    width: 100%;
}

/* Адаптив для совсем маленьких экранов */
@media (max-width: 600px) {
    .bestSpa-mob-title {
        font-size: 16px;
        text-align: center;
        max-width: 164px;
    }

    .bestSpa-mob-score {
        font-size: 24px;
    }

    .bestSpa-title {
        font-size: 20px;
        padding: 0px 40px;
    }

    .bestSpa-subtitle {
        display: none;
    }

    .bestSpa-features {
        gap: 5px;
        padding: 5px 16px;
    }

    .bestSpa-feature-item {
        font-size: 8px;
        gap: 5px;
        text-align: center;
    }
}

/* --- CONTACT PAGE SECTION (bestSpa) --- */

.bestSpa-contact-page-sec {
    background-color: rgba(57, 113, 198, 1);
    padding: 70px 0;
    font-family: 'Afacad', sans-serif !important;
}

.bestSpa-container {
    max-width: 1140px;
    margin: 0 auto;
    padding: 0 15px;
    box-sizing: border-box;
}

.bestSpa-contact-page-title {
    color: rgba(255, 255, 255, 1);
    font-weight: 700;
    font-size: 32px;
    margin-bottom: 20px;
    text-align: left;
}

.bestSpa-contact-page-list {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.bestSpa-contact-page-card {
    background-color: rgba(222, 235, 255, 1);
    /* Светло-голубой фон как на макете */
    padding: 40px;
    border-radius: 20px;
    /* Большое скругление */
    display: flex;
    flex-direction: column;
    gap: 20px;
    transition: transform 0.3s ease;
}

.bestSpa-contact-page-card:hover {
    transform: translateY(-5px);
}

.bestSpa-contact-page-h2 {
    color: rgba(57, 113, 198, 1);
    font-weight: 700;
    font-size: 32px;
    margin: 0;
}

.bestSpa-contact-page-text p {
    color: rgba(57, 113, 198, 1);
    font-family: 'Afacad', sans-serif !important;
    font-weight: 400;
    font-style: Regular;
    font-size: 15px;
}

.bestSpa-contact-page-text p:last-child {
    margin-bottom: 0;
}

.bestSpa-contact-page-text a {
    color: inherit;
    text-decoration: none;
    transition: opacity 0.3s;
}

.bestSpa-contact-page-text a:hover {
    opacity: 0.7;
    text-decoration: underline;
}

/* --- АДАПТИВНОСТЬ --- */

@media (max-width: 768px) {

    .bestSpa-contact-page-text p {
        font-size: 15px;
    }
}

/* --- RESPONSIBLE GAMING SECTION (bestSpa) --- */

.bestSpa-responsible-sec {
    background-color: rgba(57, 113, 198, 1);
    padding: 80px 0;
    color: #ffffff;
    font-family: 'Afacad', sans-serif !important;
}

.bestSpa-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 15px;
    box-sizing: border-box;
}

.bestSpa-responsible-title {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 700;
    /* Afacad 700 */
    font-size: 32px;
    margin-bottom: 20px;
    line-height: 1.2;
    text-align: left;
}

.bestSpa-responsible-content {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.bestSpa-responsible-content p {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 400;
    /* Afacad 400 */
    font-size: 15px;
    color: rgba(255, 255, 255, 0.9);
}

.bestSpa-responsible-list {
    list-style: none;
    padding-left: 20px;
}

.bestSpa-responsible-list li {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 400;
    font-size: 17px;
    line-height: 1.6;
    margin-bottom: 12px;
    position: relative;
    padding-left: 20px;
}

/* Кастомный маркер для списка - белая точка */
.bestSpa-responsible-list li::before {
    content: "•";
    position: absolute;
    left: 0;
    font-size: 20px;
    color: #ffffff;
}

.bestSpa-responsible-list a {
    color: #ffffff;
    text-decoration: underline;
    transition: opacity 0.3s;
}

.bestSpa-responsible-list a:hover {
    opacity: 0.7;
}

/* --- АДАПТИВНОСТЬ --- */

@media (max-width: 768px) {
    .bestSpa-responsible-sec {
        padding: 60px 0;
    }

    .bestSpa-responsible-title {
        font-size: 28px;
    }

    .bestSpa-responsible-content p,
    .bestSpa-responsible-list li {
        font-size: 15px;
    }

    .bestSpa-responsible-list {
        padding-left: 0;
    }

    .bestSpa-responsible-list li::before {
        display: none;
    }
}

@media (max-width: 480px) {
    .bestSpa-responsible-title {
        font-size: 24px;
    }
}

.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}


/* --- CONTENT SECTION STYLES (bestSpa) --- */

.bestSpa-content-section {
    background-color: #0D5EB0;
    /* Основной синий фон секции */
    padding: 30px 0;
    font-family: 'Afacad', sans-serif !important;
}

/* 1. Инфо-полоска сверху */
.bestSpa-info-strip {
    background-color: #ffffff;
    border-radius: 18px;
    padding: 24px;
    display: flex;
    align-items: center;
    gap: 30px;
    margin-bottom: 10px;
    box-shadow: 0px 4px 8px 0px #0000001F;
}


.bestSpa-info-strip p {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 500;
    font-style: Medium;
    font-size: 16px;
    color: #4A4A4A;
}

/* Общие стили карточек */
.bestSpa-main-card,
.bestSpa-disclaimer-card,
.bestSpa-partnership-card {
    border-radius: 18px;
    padding: 36px;
    margin-bottom: 10px;
    box-shadow: 0px 4px 8px 0px #0000001F;
}

/* 2. Белая главная карточка */
.bestSpa-main-card {
    background-color: #ffffff;
}

.bestSpa-main-h1 {
    font-family: 'Afacad', sans-serif !important;
    font-size: 36px;
    color: #4A4A4A;
    margin-bottom: 40px;
    font-weight: 600;
}

.bestSpa-text-block {
    margin-bottom: 35px;
}

.bestSpa-blue-h2 {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 600;
    font-style: SemiBold;
    font-size: 30px;
    color: #0050A1;
    margin-bottom: 20px;
}

.bestSpa-main-card p {
    font-family: 'Afacad', sans-serif !important;
    color: #4A4A4A;
    font-weight: 500;
    font-style: Medium;
    font-size: 16px;
}

/* Нумерованный список */
.bestSpa-ordered-list {
    padding: 0;
    counter-reset: my-counter;
    margin: 0;
}

.bestSpa-ordered-list li {
    list-style: none;
    counter-increment: my-counter;
    margin-bottom: 20px;
    padding-left: 15px;
    position: relative;
    margin: 0;
}

.bestSpa-ordered-list li::before {
    content: counter(my-counter) ". ";
    position: absolute;
    left: 0;
    font-weight: 500;
    color: #4A4A4A;
}

.bestSpa-ordered-list li p {
    font-family: 'Afacad', sans-serif !important;
    color: #4A4A4A;
    font-weight: 500;
    font-style: Medium;
    font-size: 16px;
}

/* 3. Синяя карточка (Disclaimer) */
.bestSpa-disclaimer-card {
    background-color: #00458B;
    /* Более темный синий для контраста */
    color: #ffffff;
}

.bestSpa-white-h2 {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 600;
    font-style: SemiBold;
    font-size: 30px;
    color: #FFFFFF;
    padding-bottom: 20px;
}

.bestSpa-disclaimer-card p {
    font-family: 'Afacad', sans-serif !important;
    color: #FFFFFF;
    font-weight: 500;
    font-style: Medium;
    font-size: 16px;
}

/* 4. Нижняя белая карточка (Partnership) */
.bestSpa-partnership-card {
    background-color: #ffffff;
}

.bestSpa-partnership-text p {
    margin-bottom: 15px;
}

/* --- АДАПТИВНОСТЬ --- */
@media (max-width: 768px) {

    .bestSpa-main-card,
    .bestSpa-disclaimer-card,
    .bestSpa-partnership-card {
        padding: 36px 16px;
    }

    .bestSpa-main-h1 {
        font-size: 24px;
    }

    .bestSpa-info-strip {
        flex-direction: column;
        text-align: center;
        padding: 24px 16px;
    }

    .bestSpa-blue-h2 {
        font-size: 18px;
    }

    .bestSpa-white-h2 {
        font-size: 24px;
    }
}






/* --- FOOTER MAIN STYLES (bestSpa) --- */

.bestSpa-footer {
    background-color: #2B2F38;
    /* Темный цвет фона из макета */
    color: #ffffff;
    padding: 50px 0px;
    text-align: center;
    font-family: 'Afacad', sans-serif !important;
}

.bestSpa-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 15px;
}

/* 1. Верхний юридический текст */
.bestSpa-footer-top-legal {
    margin-bottom: 20px;
}

.bestSpa-footer-top-legal p {
    font-weight: 400;
    font-size: 12px;
    color: #E8E8E8;
}

/* 2. Блок контактов */
.bestSpa-footer-company {
    margin-bottom: 20px;
}

.bestSpa-footer-company p {
    font-weight: 400;
    font-size: 12px;
    color: #E8E8E8;
    padding-bottom: 5px;
}

/* 3. Иконка возраста */
.bestSpa-footer-age-icon {
    margin-bottom: 20px;
}

.bestSpa-footer-warning-paragraph {
    padding-bottom: 20px;
}


.bestSpa-footer-warning-paragraph p {
    font-weight: 400;
    font-size: 12px;
    color: #E8E8E8;
}

/* 5. Главный юридический стрип */
.bestSpa-footer-strip {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 40px;
    margin: 0;
    margin-bottom: 20px;
}



.bestSpa-footer-bold-warning p {
    font-family: 'Afacad', sans-serif !important;
    font-weight: 400;
    font-style: Regular;
    font-size: 19px;
    line-height: 22.8px;
    vertical-align: middle;
    color: #E8E8E8;
    text-align: left;
}

/* 6. Навигация */
.bestSpa-footer-nav {
    margin-bottom: 20px;
}

.bestSpa-footer-links {
    display: flex;
    justify-content: center;
    gap: 40px;
    flex-wrap: wrap;
    list-style: none;
    padding: 0;
}

.bestSpa-footer-links a {
    color: #ffffff;
    font-family: 'Afacad', sans-serif !important;
    font-weight: 400;
    font-size: 12px;
    text-transform: uppercase;
    text-decoration: none;
    transition: opacity 0.3s;
}

.bestSpa-footer-links a:hover {
    opacity: 0.7;
}

/* 7. Копирайт */
.bestSpa-footer-bottom p {
    font-weight: 400;
    font-style: Regular;
    font-size: 12px;
    text-align: center;
    color: #E8E8E8;
}

/* --- АДАΠТИВНОСТЬ --- */

@media (max-width: 992px) {
    .bestSpa-footer-strip {
        flex-direction: column;
        gap: 20px;
    }

    .bestSpa-footer-bold-warning p {
        font-size: 16px;
    }
}

@media (max-width: 768px) {
    .bestSpa-footer {
        padding: 40px 10px;
    }

    .bestSpa-footer-links {
        gap: 40px;
    }

    .bestSpa-footer-warning-paragraph p {
        font-size: 12px;
    }
}



.spaMob-card {
    display: none;
}

@media (max-width: 960px) {
    .bestSpa-card {
        display: none;
    }

    .bestSpa-card-badge {
        position: relative;
        top: 0px;
    }

    /* --- NEW MOBILE CARD (spaMob) --- */

    .spaMob-card {
        display: flex;
        background-color: #ffffff;
        border-radius: 12px;
        /* Сильное скругление как на макете */
        overflow: hidden;
        width: 100%;
        /* Оптимально для мобилок */
        box-shadow: 0px 0px 14px 0px #4996F0;
        border: 1px solid #E0E0E0;
        font-family: 'Afacad', sans-serif !important;
    }

    /* Синяя сторона */
    .spaMob-brand-col {
        background-color: #0050A1;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: space-between;
        position: relative;
        flex-shrink: 0;
        padding-bottom: 20px;
        width: 50%;
    }

    .spaMob-top-label {
        position: absolute;
        top: 12px;
        left: 0;
        background: #ffffff;
        color: #333;
        font-weight: 700;
        font-size: 12px;
        padding: 4px 12px;
        border-radius: 0 15px 15px 0;
        box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.1);
    }

    .spaMob-logo-wrap img {
        width: 100%;
        max-width: 140px;
        height: auto;
    }

    /* Овал с рейтингом */
    .spaMob-rating-pill {
        background: #ffffff;
        border-radius: 30px;
        padding: 5px 10px;
        display: flex;
        align-items: center;
        gap: 5px;
    }

    .bestSpa-stars li {
        display: flex;
    }

    .spaMob-score {
        font-size: 24px;
        font-weight: 800;
        color: #0050A1;
        line-height: 1;
    }

    .spaMob-stars {
        display: flex;
        gap: 1px;
    }

    .spaMob-stars img {
        width: 12px;
    }

    /* Белая сторона */
    .spaMob-info-col {
        flex: 1;
        padding: 15px;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: space-between;
        gap: 10px;
    }

    /* Капсула онлайна */
    .spaMob-online-status {
        display: flex;
        align-items: center;
        gap: 6px;
        color: #0050A1;
        font-weight: 700;
        font-size: 16px;
    }

    .spaMob-dot {
        width: 8px;
        height: 8px;
        background: #28a745;
        border-radius: 50%;
        box-shadow: 0 0 5px #28a745;
    }

    .spaMob-title {
        font-size: 18px;
        font-weight: 700;
        color: #0050A1;
        text-align: center;
        line-height: 1.2;
    }

    /* Кнопка с градиентом */
    .spaMob-btn {
        background: linear-gradient(180deg, #91cc41 0%, #7ab32f 100%);
        color: #ffffff;
        text-decoration: none;
        font-weight: 700;
        font-size: 18px;
        padding: 12px;
        width: 100%;
        text-align: center;
        border-radius: 15px;
        box-sizing: border-box;
    }

    /* Платежки в рамке */
    .spaMob-payments-border {
        border: 1px solid #DEDEDE;
        border-radius: 20px;
        padding: 5px 15px;
        width: 100%;
        box-sizing: border-box;
    }

    .spaMob-pay-list {
        display: flex;
        justify-content: center;
        gap: 8px;
    }

    .spaMob-pay-list img {
        height: 14px;
        width: auto;
    }
}

.podpic {
    display: none;
}

@media (max-width: 600px) {
    /* --- NEW MOBILE CARD (spaMob) --- */

    .podpic {
        display: flex;
        justify-content: center;
    }

    .podpic p {
        display: flex;
        font-family: 'Afacad', sans-serif !important;
        font-weight: 500;
        font-size: 8px;
        text-align: center;
        color: #fff;
    }

    .bestSpa-casino-list {
        display: flex;
        flex-direction: column;
        gap: 5px;
    }

    .spaMob-card {
        display: flex;
        background-color: #ffffff;
        border-radius: 12px;
        /* Сильное скругление как на макете */
        overflow: hidden;
        width: 100%;
        /* Оптимально для мобилок */
        box-shadow: 0px 0px 14px 0px #4996F0;
        border: 1px solid #E0E0E0;
        font-family: 'Afacad', sans-serif !important;
        height: 168px;
    }

    .flex-badge {
        width: 100%;
        display: flex;
        justify-content: flex-start;
    }

    /* Синяя сторона */
    .spaMob-brand-col {
        background-color: #0050A1;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: flex-start;
        position: relative;
        flex-shrink: 0;
        padding-bottom: 0;
        gap: 0px;
    }

    .spaMob-top-label {
        position: absolute;
        top: 12px;
        left: 0;
        background: #ffffff;
        color: #333;
        font-weight: 700;
        font-size: 12px;
        padding: 4px 12px;
        border-radius: 0 15px 15px 0;
        box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.1);
    }

    .spaMob-logo-wrap img {
        width: 100%;
        max-width: 140px;
        height: auto;
    }

    /* Овал с рейтингом */
    .spaMob-rating-pill {
        background: #ffffff;
        border-radius: 30px;
        padding: 5px 10px;
        display: flex;
        align-items: center;
        gap: 5px;
    }

    .bestSpa-stars li {
        display: flex;
    }

    .spaMob-score {
        font-size: 24px;
        font-weight: 800;
        color: #0050A1;
        line-height: 1;
    }

    .spaMob-stars {
        display: flex;
        gap: 1px;
    }

    .spaMob-stars img {
        width: 12px;
    }

    /* Белая сторона */
    .spaMob-info-col {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 8px;
    }

    /* Капсула онлайна */
    .spaMob-online-status {
        display: flex;
        align-items: center;
        gap: 6px;
        color: #0050A1;
        font-weight: 700;
        font-size: 16px;
    }

    .spaMob-dot {
        width: 8px;
        height: 8px;
        background: #28a745;
        border-radius: 50%;
        box-shadow: 0 0 5px #28a745;
    }

    .spaMob-title {
        font-family: 'Afacad', sans-serif !important;
        font-size: 18px;
        font-weight: 700;
        color: #0050A1;
        text-align: center;
        line-height: 1.2;
    }

    /* Кнопка с градиентом */
    .spaMob-btn {
        background: linear-gradient(180deg, #91cc41 0%, #7ab32f 100%);
        color: #ffffff;
        text-decoration: none;
        font-weight: 700;
        font-size: 18px;
        padding: 12px;
        width: 100%;
        text-align: center;
        border-radius: 15px;
        box-sizing: border-box;
    }

    /* Платежки в рамке */
    .spaMob-payments-border {
        border: 1px solid #DEDEDE;
        border-radius: 20px;
        padding: 5px 15px;
        width: 100%;
        box-sizing: border-box;
    }

    .spaMob-pay-list {
        display: flex;
        justify-content: center;
        gap: 8px;
    }

    .spaMob-pay-list img {
        height: 14px;
        width: auto;
    }

    .bestSpa-card-logo {
        width: 160px;
        height: 80px;
    }

    .bestSpa-card-logo a {
        width: 160px;
    }

    .bestSpa-card-badge {
        position: relative;
        top: 0px;
        left: 0px;
        padding: 6px 14px;
        font-family: 'Afacad', sans-serif !important;
        font-weight: 700;
        font-style: Bold;
        font-size: 9px;
        border-bottom-left-radius: 0px;
    }

    .bestSpa-card-logo img {
        max-width: 140px;
        max-height: 75px;
    }

    .rate-mob {
        width: 29px;
        height: 32px;
    }

    .spaMob-info-col {
        padding: 0px 6px;
        gap: 8px;
        display: flex;
        justify-content: center;
    }

    .blue-div p {
        font-family: 'Afacad', sans-serif !important;
        font-weight: 500;
        font-size: 12px;
    }

    .spaMob-title {
        font-family: 'Afacad', sans-serif !important;
        font-size: 12px;
        font-weight: 700;
        color: #0050A1;
        text-align: center;
        line-height: 1;
    }

    .yell-p {
        display: none;
    }

    .bestSpa-btn {
        background: linear-gradient(90deg, #8ACB3F 0%, #8ACB3F 100%);
        background-size: 200% auto;
        color: #fff;
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
        padding: 15px 10px;
        border-radius: 10px;
        text-decoration: none;
        font-family: 'Afacad', sans-serif !important;
        font-weight: 700;
        font-size: 14px;
        display: inline-block;
        text-align: center;
        transition: transform 0.3s ease;
        animation: bestSpa-gradient-shift 3s linear infinite;
        border: none;
        cursor: pointer;
    }

    .bestSpa-online-status {
        font-family: 'Afacad', sans-serif !important;
        padding: 4px 0px;
        border: 1px solid #8ACB3F;
        border-radius: 100px;
        font-weight: 400;
        font-size: 13px;
        color: rgba(57, 113, 198, 1);
        display: flex;
        align-items: center;
        gap: 6px;
        width: 100%;
        justify-content: center;
    }
}

@media (max-width: 360px) {
    .spaMob-brand-col {
        width: auto;
    }
}

@media (max-width: 340px) {
    .spaMob-info-col {
        padding: 16px 3px;
        gap: 8px;
    }

    .bestSpa-card-logo {
        width: 150px;
        height: 80px;
    }
}

/* --- CONTACT PAGE STYLES (bestSpa) --- */

.bestSpa-contact-page-sec {
    background-color: #0D5EB0;
    /* Твой синий фон */
    padding: 30px 0px;
    display: flex;
    align-items: center;
    font-family: 'Afacad', sans-serif !important;
}

.bestSpa-contact-card {
    background-color: #ffffff;
    border-radius: 18px;
    /* Скругление как на макете */
    padding: 36px;
    margin: 0 auto;
    box-shadow: 0px 4px 8px 0px #0000001F;
}

.bestSpa-contact-main-h1 {
    font-size: 36px;
    font-weight: 700;
    color: #4A4A4A;
    margin-bottom: 40px;
    text-align: left;
}

.bestSpa-contact-intro {
    font-size: 16px;
    color: #4A4A4A;
    margin-bottom: 40px;
}

.bestSpa-contact-block {
    margin-bottom: 40px;
}

.bestSpa-contact-blue-label {
    color: #0D5EB0;
    font-size: 30px;
    font-weight: 700;
    margin-bottom: 20px;
}

.bestSpa-contact-details p {
    font-size: 16px;
    color: #4A4A4A;
    margin-bottom: 3px;
}

.bestSpa-contact-details a {
    color: inherit;
    text-decoration: none;
    transition: opacity 0.3s;
}

.bestSpa-contact-details a:hover {
    text-decoration: underline;
    opacity: 0.8;
}

.bestSpa-contact-footer-note {
    font-size: 16px;
    color: #4A4A4A;
    margin-top: 30px;
}

/* --- АДАΠТИВНОСТЬ --- */

@media (max-width: 768px) {
    .bestSpa-contact-page-sec {
        padding: 40px 10px;
    }

    .bestSpa-contact-card {
        padding: 35px 20px;
        border-radius: 20px;
    }

    .bestSpa-contact-main-h1 {
        font-size: 28px;
        text-align: center;
    }

    .bestSpa-contact-blue-label {
        font-size: 22px;
        text-align: center;
    }

    .bestSpa-contact-details p,
    .bestSpa-contact-intro,
    .bestSpa-contact-footer-note {
        text-align: center;
        font-size: 12px;
    }
}