/* Theme overrides that rely on CSS variables set in _Layout.cshtml */

/* hover/active calculados */
.btn-primary {
    --bs-btn-color: var(--bs-secondary);
    --bs-btn-bg: var(--bs-primary);
    --bs-btn-border-color: var(--bs-primary);
    --bs-btn-hover-color: var(--bs-secondary);
    --bs-btn-hover-bg: color-mix(in srgb, var(--bs-primary) 88%, #000);
    --bs-btn-hover-border-color: color-mix(in srgb, var(--bs-primary) 88%, #000);
    --bs-btn-active-color: var(--bs-secondary);
    --bs-btn-active-bg: color-mix(in srgb, var(--bs-primary) 78%, #000);
    --bs-btn-active-border-color: color-mix(in srgb, var(--bs-primary) 78%, #000);
    --bs-btn-disabled-bg: var(--bs-primary);
    --bs-btn-disabled-border-color: var(--bs-primary);
}

.btn-outline-primary {
    --bs-btn-bg: var(--bs-secondary);
    --bs-btn-color: var(--bs-primary);
    --bs-btn-border-color: var(--bs-primary);
    --bs-btn-hover-color: var(--bs-secondary);
    --bs-btn-hover-bg: var(--bs-primary);
    --bs-btn-hover-border-color: var(--bs-primary);
    --bs-btn-active-color: var(--bs-secondary);
    --bs-btn-active-bg: color-mix(in srgb, var(--bs-primary) 78%, #000);
    --bs-btn-active-border-color: color-mix(in srgb, var(--bs-primary) 78%, #000);
    --bs-btn-disabled-color: var(--bs-primary);
    --bs-btn-disabled-border-color: var(--bs-primary);
}

/* BTN SECONDARY (dinâmico) */
.btn-secondary {
    --bs-btn-color: var(--bs-primary);
    --bs-btn-bg: var(--bs-secondary);
    --bs-btn-border-color: var(--bs-secondary);
    --bs-btn-hover-color: var(--bs-primary);
    --bs-btn-hover-bg: color-mix(in srgb, var(--bs-secondary) 88%, #000);
    --bs-btn-hover-border-color: color-mix(in srgb, var(--bs-secondary) 88%, #000);
    --bs-btn-active-color: var(--bs-primary);
    --bs-btn-active-bg: color-mix(in srgb, var(--bs-secondary) 78%, #000);
    --bs-btn-active-border-color: color-mix(in srgb, var(--bs-secondary) 78%, #000);
    --bs-btn-disabled-bg: var(--bs-secondary);
    --bs-btn-disabled-border-color: var(--bs-secondary);
}

/* BTN OUTLINE SECONDARY (dinâmico) */
.btn-outline-secondary {
    --bs-btn-color: var(--bs-secondary);
    --bs-btn-border-color: var(--bs-secondary);
    --bs-btn-hover-color: var(--bs-primary);
    --bs-btn-hover-bg: var(--bs-secondary);
    --bs-btn-hover-border-color: var(--bs-secondary);
    --bs-btn-active-color: var(--bs-primary);
    --bs-btn-active-bg: color-mix(in srgb, var(--bs-secondary) 78%, #000);
    --bs-btn-active-border-color: color-mix(in srgb, var(--bs-secondary) 78%, #000);
    --bs-btn-disabled-color: var(--bs-secondary);
    --bs-btn-disabled-border-color: var(--bs-secondary);
}

/* Base (checkbox + radio) */
.form-check-input {
    border-color: rgba(var(--bs-primary-rgb), 0.25);
}

/* Focus ring */
.form-check-input:focus {
    border-color: var(--bs-primary);
    /* Fallback for browsers that do not support color-mix */
    box-shadow: 0 0 0 .25rem rgba(var(--bs-primary-rgb), 0.25);
}

/* Checked (fundo e borda) */
.form-check-input:checked {
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
    color: #fff; /* cor do ícone via currentColor */
}

/* INDETERMINATE: traço com currentColor */
.form-check-input:indeterminate {
    border-color: var(--bs-primary);
    color: var(--bs-secondary);
}

/* SWITCH: thumb com currentColor (igual ao que falámos) */
.form-switch .form-check-input {
    --bs-form-switch-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='currentColor'/%3e%3c/svg%3e");
    color: rgba(0,0,0,.25); /* thumb off */
}

.form-switch .form-check-input:checked {
    color: #fff; /* thumb on */
}

/* Texto/borda do select */
.form-select {
    color: var(--bs-primary);
    border-color: color-mix(in srgb, rgb(var(--bs-primary-rgb)) 45%, #000);
    /* seta (indicator) com currentColor para seguir a cor do select */
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='currentColor' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e");
}

/* foco */
.form-select:focus {
    border-color: var(--bs-primary);
    /* Fallback for browsers that do not support color-mix */
    box-shadow: 0 0 0 .25rem rgba(var(--bs-primary-rgb), 0.25);
}

/* Fallback para browsers sem color-mix(): hover/active ficam iguais */
@supports not (color: color-mix(in srgb, #000 50%, #fff)) {
    .btn-primary {
        --bs-btn-hover-bg: var(--bs-primary);
        --bs-btn-hover-border-color: var(--bs-primary);
        --bs-btn-active-bg: var(--bs-primary);
        --bs-btn-active-border-color: var(--bs-primary);
    }

    .btn-outline-primary {
        --bs-btn-active-bg: var(--bs-primary);
        --bs-btn-active-border-color: var(--bs-primary);
    }

    .btn-secondary {
        --bs-btn-hover-bg: var(--bs-secondary);
        --bs-btn-hover-border-color: var(--bs-secondary);
        --bs-btn-active-bg: var(--bs-secondary);
        --bs-btn-active-border-color: var(--bs-secondary);
    }

    .btn-outline-secondary {
        --bs-btn-active-bg: var(--bs-secondary);
        --bs-btn-active-border-color: var(--bs-secondary);
    }

    .form-check-input {
        border-color: var(--bs-primary);
    }

    .form-check-input:focus {
        /* Fallback for browsers that do not support color-mix */
        box-shadow: 0 0 0 .25rem rgba(0,0,0,.15);
    }

    .form-select:focus {
        /* Fallback for browsers that do not support color-mix */
        box-shadow: 0 0 0 .25rem rgba(0,0,0,.15);
    }
}

/* SweetAlert2 - cores globais */
.swal2-popup,
.swal2-toast {
    background: var(--bs-secondary) !important;
    color: var(--bs-body-color) !important;
}

.swal2-title,
.swal2-html-container,
.swal2-content,
.swal2-footer {
    color: var(--bs-body-color) !important;
}

/* Botão fechar e progress */
.swal2-close,
.swal2-timer-progress-bar {
    color: var(--bs-body-color) !important;
    background: var(--bs-body-color) !important;
}

/* Ícones */
.swal2-icon,
.swal2-icon .swal2-icon-content {
    color: var(--bs-body-color) !important;
    border-color: var(--bs-body-color) !important;
}

/* Inputs dentro do SweetAlert2 */
.swal2-input,
.swal2-textarea,
.swal2-select {
    background: var(--bs-secondary) !important;
    color: var(--bs-body-color) !important;
    border-color: color-mix(in srgb, var(--bs-body-color) 35%, transparent) !important;
}

/* Category card */
.category-card__link {
    --category-icon-color: var(--bs-primary);
}

.partner-header {
    background-color: var(--bt-header-color) !important;
    color: var(--bt-header-text-color) !important;
}

.partner-footer {
    background-color: var(--bt-footer-color) !important;
    color: var(--bt-footer-text-color) !important;
}

.partner-footer a:hover {
    color: inherit !important;
    opacity: 0.8;
}

.card-carousel .swiper-slide a,
.card-carousel .swiper-slide a:hover,
.card-carousel .swiper-slide a:focus {
    color: inherit !important;
}

.card-carousel .swiper-slide a *,
.card-carousel .swiper-slide a:hover *,
.card-carousel .swiper-slide a:focus * {
    color: inherit !important;
}

.card-carousel .swiper-slide a:hover,
.card-carousel .swiper-slide a:focus {
    opacity: 0.6;
}

.contentgroupdetailed-events-carousel .swiper-slide a {
    color: var(--bs-secondary) !important;
}

.contentgroupdetailed-events-carousel .swiper-slide a *,
.contentgroupdetailed-events-carousel .swiper-slide a:hover *,
.contentgroupdetailed-events-carousel .swiper-slide a:focus * {
    color: inherit !important;
}

.contentgroupdetailed-events-carousel .swiper-slide a:hover,
.contentgroupdetailed-events-carousel .swiper-slide a:focus {
    color: var(--bs-secondary) !important;
    opacity: 0.6;
}

.categories-carousel .swiper-slide a:hover,
.categories-carousel .swiper-slide a:focus {
    opacity: 1;
}

.top-highlight-carrousel .swiper-slide {
    box-shadow: 0 4px 8px 0 rgba(var(--bs-primary-rgb), 0.28);
}

.sectors-nav-wrapper .sectors-nav {
    flex: 1;
    min-width: 0;
}

.sectors-nav-wrapper .sectors-nav-button-prev,
.sectors-nav-wrapper .sectors-nav-button-next {
    flex: 0 0 auto;
    width: 40px;
    height: 40px;
    border: 1px solid var(--bs-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

.sectors-nav-wrapper .sectors-nav-button-prev::after,
.sectors-nav-wrapper .sectors-nav-button-next::after {
    font-family: swiper-icons;
    font-size: 1rem;
    color: var(--bs-primary);
}

.sectors-nav-wrapper .sectors-nav-button-prev::after {
    content: 'prev';
}

.sectors-nav-wrapper .sectors-nav-button-next::after {
    content: 'next';
}

.sectors-nav-wrapper .sectors-nav-button-disabled {
    opacity: 0.35;
    cursor: default;
}

.sectors-nav-wrapper .swiper-button-lock {
    display: none;
}

#swiper-interest-options .swiper-button-next,
#swiper-interest-options .swiper-button-prev {
    border-color: var(--bs-primary);
}

#swiper-interest-options .swiper-button-next::after,
#swiper-interest-options .swiper-button-prev::after {
    color: var(--bs-primary);
}

@media (max-width: 767.98px) {
    .section-highlight > .container {
        width: 100vw;
        max-width: 100vw;
        margin-left: calc(50% - 50vw);
        margin-right: calc(50% - 50vw);
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    .event-card-row-media {
        padding-top: 0 !important;
        height: min(300px, 75vw);
        max-height: 300px;
    }

    .event-card-row-media img {
        position: relative;
        height: 100%;
    }

    .conditions-checkbox-label {
        color: var(--bs-light);
        font-size: 0.75rem;
        line-height: 1.35;
    }

    .conditions-checkbox-label a {
        color: var(--bs-light) !important;
        text-decoration: underline;
        text-shadow: none;
    }
}

@media (max-width: 575.98px) {
    .top-highlight-carrousel .swiper-slide {
        width: calc(100vw - 88px) !important;
        height: auto !important;
    }

    .top-highlight-carrousel .swiper-slide .slide-media__holder {
        height: auto !important;
        background-color: transparent;
    }

    .top-highlight-carrousel .swiper-slide .slide-media__holder img,
    .top-highlight-carrousel .swiper-slide .slide-media__holder video {
        position: relative !important;
        display: block;
        object-fit: contain !important;
        width: 100%;
        height: auto !important;
    }
}

@media (min-width: 768px) {
    .conditions-checkbox-label {
        color: inherit;
        font-size: .825rem;
        line-height: normal;
    }

    .conditions-checkbox-label a {
        color: inherit !important;
        text-decoration: underline;
        text-shadow: none;
    }
}

.category-card__icon-wrap,
.category-card__icon,
.category-card__title {
    transition: all .2s ease-in-out;
}

.category-card__link:hover .category-card__icon-wrap,
.category-card__link:focus-visible .category-card__icon-wrap {
    background-color: var(--bs-primary);
}

.category-card__link:hover .category-card__icon,
.category-card__link:focus-visible .category-card__icon {
    --category-icon-color: var(--bs-secondary);
}
