/**
 * Styles pour le système de réservation Unixp
 * Interface de calendrier et réservation
 */

/* === NOTIFICATIONS === */
.unixp-notification {
    position: fixed;
    top: 20px;
    right: 20px;
    padding: 15px 20px;
    border-radius: 5px;
    z-index: 10000;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
    font-weight: bold;
    max-width: 400px;
}

.unixp-notification.success {
    background: #28a745;
    color: white;
}

.unixp-notification.error {
    background: #dc3545;
    color: white;
}

.unixp-notification.info {
    background: #17a2b8;
    color: white;
}

.unixp-notification .close-btn {
    background: none;
    border: none;
    color: white;
    float: right;
    font-size: 18px;
    cursor: pointer;
    margin-top: -5px;
}

.unixp-notification .close-btn:hover {
    opacity: 0.8;
}

/* === MAIN CONTAINER === */
.unixp-booking-form-container {
    max-width: 1200px;
    margin: 0 auto;
}

.unixp-activity-info {
    background: #f8f9fa;
    padding: 20px;
    border-radius: 8px;
    margin-bottom: 20px;
}

.unixp-activity-info h3 {
    margin-top: 0;
    color: #2c3e50;
}

/* === INTERFACE PRINCIPALE === */
.unixp-booking-interface {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
    margin-top: 20px;
}

.unixp-calendar-section h4,
.unixp-slots-section h4 {
    margin-top: 0;
    margin-bottom: 15px;
    color: #fff;
    font-size: 18px;
}

/* === CALENDRIER === */
.unixp-month-calendar {
    padding: 20px;
}

/* === Calendar Container === */
.unixp-month-calendar {
    --fc-border-color: transparent;
    --fc-page-bg-color: transparent;
    --fc-neutral-bg-color: transparent;
    --fc-today-bg-color: transparent;
}

.unixp-month-calendar a {
    text-decoration: none;
}

/* === Toolbar === */
.unixp-month-calendar .fc-toolbar {
    margin-bottom: 30px !important;
    padding: 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.unixp-month-calendar .fc-toolbar-chunk {
    display: flex;
    align-items: center;
    gap: 15px;
}

.unixp-month-calendar .fc-toolbar-title {
    color: white;
    font-family: 'Quinn', sans-serif;
    font-size: 42px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin: 0;
}

/* === Buttons === */
.unixp-month-calendar .fc-button {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
    width: 20px;
    height: 20px;
}

.fc .fc-button-group {
    gap: 12px;
}

.unixp-month-calendar .fc-button .fc-icon {
    display: none;
}

/* Navigation Buttons */
.unixp-month-calendar .fc-prev-button,
.unixp-month-calendar .fc-next-button {
    background-color: #47e4ff !important;
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: contain;
    transition: transform 0.2s;
}

.unixp-month-calendar .fc-prev-button {
    mask-image: url(https://uni-xp.collectifexcalibur.fr/wp-content/uploads/2025/10/fleche-noire-gauche-uni-xp-salle-gaming-brest.svg);
}

.unixp-month-calendar .fc-next-button {
    mask-image: url(https://uni-xp.collectifexcalibur.fr/wp-content/uploads/2025/10/fleche-noire-droite-uni-xp-salle-gaming-brest.svg);
}

.unixp-month-calendar .fc-prev-button:hover,
.unixp-month-calendar .fc-next-button:hover {
    transform: scale(1.1);
}

/* Today Button */
.unixp-month-calendar .fc-today-button {
    background-color: #98EECC !important;
    color: #000 !important;
    border-radius: 50px !important;
    padding: 12px 30px !important;
    font-family: 'Univa Nova', sans-serif;
    font-weight: 700;
    font-size: 16px;
    width: auto !important;
    height: auto !important;
    text-transform: capitalize;
}

.unixp-month-calendar .fc-today-button:disabled {
    opacity: 0.8;
    color: #fff !important;
}

/* === Table Structure === */
.unixp-month-calendar table {
    border-collapse: separate !important;
    border-spacing: 6px !important;
}

.unixp-month-calendar .fc-view {
    position: relative;
    z-index: 1;
}

.unixp-month-calendar .fc-col-header {
    margin-bottom: 4px;
}

.unixp-month-calendar .fc-scrollgrid-sync-table {
    width: 100% !important;
}

/* === Column Headers === */
.unixp-month-calendar .fc-col-header-cell {
    background-color: #4c1eb8 !important;
    border: none !important;
    border-radius: 15px;
    padding: 6px 6px;
}

.unixp-month-calendar .fc-col-header-cell-cushion {
    font-family: 'Univa Nova', sans-serif;
    font-weight: 700;
    font-size: 16px;
    text-transform: capitalize;
    display: block;
    text-align: center;
    color: #fff;
}

/* === Grid Structure === */
.unixp-month-calendar .fc-scrollgrid {
    border: none !important;
}

.unixp-month-calendar .fc-scroller {
    overflow: visible !important;
}

.unixp-month-calendar .fc-scroller-liquid-absolute {
    position: static !important;
}

.unixp-month-calendar .fc-daygrid-body {
    border: none !important;
    width: 100% !important;
}

.unixp-month-calendar .fc-scrollgrid-section>* {
    border: none !important;
}

.unixp-month-calendar .fc-scrollgrid-section-body>td {
    border: none !important;
}

.unixp-month-calendar .fc-daygrid-body-unbalanced .fc-daygrid-day-events {
    min-height: 0 !important;
}

/* === Day Cells === */
.unixp-month-calendar .fc-daygrid-day {
    position: relative;
    border: none !important;
    padding: 0;
}

.unixp-month-calendar .fc-daygrid-day:hover {
    z-index: 10;
}

/* Day Frame - Base Style */
.unixp-month-calendar .fc-daygrid-day-frame {
    background-color: rgba(255, 255, 255, 0.25);
    border-radius: 15px;
    height: 98px;
    padding: 2px;
    position: relative;
    border: none !important;
    display: flex;
    align-items: flex-end;
    justify-content: center;
}

/* Day Frame - Other Month */
.unixp-month-calendar .fc-day-other .fc-daygrid-day-frame {
    background-color: rgba(255, 255, 255, 0.15);
}

/* Day Frame - Past Days */
.unixp-month-calendar .fc-day-past .fc-daygrid-day-frame {
    background-color: rgba(255, 255, 255, 0.12);
}

.unixp-month-calendar .fc-day-past .fc-daygrid-day-frame::before {
    content: '';
    position: absolute;
    top: 65%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(-8deg);
    width: 60%;
    height: 60%;
    background-image: url(https://uni-xp.collectifexcalibur.fr/wp-content/uploads/2025/10/game-over-calendrier-uni-xp-salle-gaming-brest.svg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    opacity: 0.15;
    filter: brightness(0) invert(1);
    pointer-events: none;
}

/* Day Frame - Today */
.unixp-month-calendar .fc-day-today .fc-daygrid-day-frame {
    border: 2px solid #98EECC !important;
}

/* Day frame - Interactions */
.unixp-month-calendar .fc-day:not(.fc-day-past) {
    cursor: pointer;
}

.unixp-month-calendar .fc-day:not(.fc-day-past):hover .fc-daygrid-day-frame {
    background-color: rgba(152, 238, 204, 0.5);
}

.unixp-month-calendar .fc-day-selected .fc-daygrid-day-frame {
    background-color: #98EECC !important;
    border: 2px solid #98EECC !important;
}

/* === Day Numbers === */
.unixp-month-calendar .fc-daygrid-day-top {
    position: absolute;
    top: 8px;
    right: 8px;
    z-index: 5;
}

.unixp-month-calendar .fc-daygrid-day-number {
    color: #FFF;
    font-family: 'Univa Nova', sans-serif;
    font-weight: 800;
    font-size: 10px;
    padding: 0;
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
}

/* Day Number Background Circle */
.unixp-month-calendar .fc-daygrid-day-number::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 24px;
    height: 24px;
    background-color: rgba(255, 255, 255, 0.15);
    border-radius: 50%;
    z-index: -1;
}

/* Day Number - Future Days */
.unixp-month-calendar .fc-day-future:not(.fc-day-other) .fc-daygrid-day-number::before {
    background-color: rgba(255, 255, 255, 0.35);
}

/* Day Number - Today */
.unixp-month-calendar .fc-day-today .fc-daygrid-day-number::before {
    background-color: #98EECC;
}

/* Day Number - Past & Other Month Days */
.unixp-month-calendar .fc-day-past .fc-daygrid-day-number::before,
.unixp-month-calendar .fc-day-other .fc-daygrid-day-number::before {
    background-color: rgba(255, 255, 255, 0.15);
}

.unixp-month-calendar .fc-day-past .fc-daygrid-day-number {
    color: #666;
}

/* === Hide Default Events === */
.unixp-month-calendar .fc-daygrid-event-harness,
.unixp-month-calendar .fc-daygrid-day-events,
.unixp-month-calendar .fc-daygrid-day-bottom {
    display: none !important;
}

/* === Custom Event Markers === */
.event-marker {
    background-color: #0069FF;
    border-radius: 12px;
    padding: 8px 4px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    width: 75px !important;
    max-width: 100%;
    min-width: 75px;
    margin-bottom: 2px;
    cursor: pointer;
    color: #fff;
    font-family: 'Univa Nova', sans-serif;
    font-size: 11px;
    font-weight: 600;
    text-align: center;
}

.event-marker-icon {
    width: 17px;
    height: 17px;
    background-color: #fff;
    opacity: 0.5;
    mask-image: url(https://uni-xp.collectifexcalibur.fr/wp-content/uploads/2025/10/calendar.svg);
    mask-size: contain;
    mask-position: center;
    mask-repeat: no-repeat;
}

/* === SECTION CRÉNEAUX === */
.unixp-slots-section {
    padding: 20px;
}

.unixp-slots-list {
    max-height: 430px !important;
    max-height: 80vh;
    overflow-y: auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
    margin-top: 0px;
    padding: 10px;


}

@media (max-width: 768px) {
    .unixp-slots-list {
        grid-template-columns: 1fr;
        gap: 10px;
    }
}


.unixp-no-date-selected {
    text-align: center;
    color: #6c757d;
    padding: 40px 20px;
    min-width: 450px;
}

@media (max-width: 768px) {
    .unixp-no-date-selected {
        max-width: 250px !important;
        min-width: 250px !important;
        padding: 0px 20px !important;
    }

    .unixp-month-calendar .fc-today-button:disabled,
    .unixp-month-calendar .fc-today-button {
        display: none !important;
    }

    .unixp-month-calendar .fc-col-header-cell-cushion {
        font-weight: 800 !important;
        font-size: 11px !important;
    }

    .unixp-month-calendar .fc-daygrid-day-frame {
        height: 54px !important;
    }

    .unixp-month-calendar .fc-day-past .fc-daygrid-day-frame::before {

        top: 75% !important;
    }


}

.unixp-no-date-selected p {
    margin: 0;
    font-style: italic;
}

/* === CRÉNEAUX === */
.unixp-slot-item {
    background: transparent;
    border: 2px solid rgba(255, 255, 255, 0.3) !important;
    border-radius: 12px;
    color: white;
    padding: 10px 15px 14px 10px;
    margin-bottom: 0;
    /* CHANGÉ de 10px à 0 */
    cursor: pointer;
    transition: all 0.3s ease;
    position: relative;
}

.unixp-slot-item:hover {
    background: #98eecc;
    border: 2px solid #98eecc;
    scale: 1.03;
}

.unixp-slot-item.unavailable {
    background: #f8d7da;
    border-color: #f5c6cb;
    cursor: not-allowed;
    opacity: 0.7;
}

.unixp-slot-item.unavailable:hover {
    border-color: #f5c6cb;
    background: #f8d7da;
}

.unixp-slot-item.selected {
    border-color: #98eecc !important;
    background: #98eecc !important;
}

.unixp-slot-item.in-cart {
    border-color: #98eecc;
    background: #98eecc;
    cursor: default;
    box-shadow: 0px 0px 30px 0px rgba(152, 238, 204, 0.6);
}

.unixp-slot-item.selected:hover .unixp-slot-availability.available,
.unixp-slot-item.selected:hover .unixp-slot-time,
.unixp-slot-item.selected .unixp-slot-availability.available,
.unixp-slot-item.selected .unixp-slot-time {
    color: #1c1c1c !important;
}

.unixp-slot-item.in-cart:hover .unixp-slot-availability.available,
.unixp-slot-item.in-cart:hover .unixp-slot-time,
.unixp-slot-item.in-cart .unixp-slot-availability.available,
.unixp-slot-item.in-cart .unixp-slot-time {
    color: #1c1c1c !important;
}

.unixp-slot-item.in-cart:hover {
    border-color: #98eecc;
    background: #98eecc;
}

.unixp-slot-checkmark {
    position: absolute;
    top: 5px;
    right: 5px;
    background: #28a745;
    color: white;
    font-size: 12px;
    padding: 2px 6px;
    border-radius: 3px;
    font-weight: bold;
}

.unixp-slot-time {
    font-weight: 900;
    color: #fff;
    font-size: 22px;
    font-family: 'quinn';
    letter-spacing: 1.3px;
}

.unixp-slot-item:hover .unixp-slot-time {
    color: #1c1c1c !important;
}

.unixp-slot-item.unavailable:hover .unixp-slot-time {
    color: #fff !important;
}

.unixp-slot-availability {
    color: #fff;
    font-size: 14px;
}

.unixp-slot-availability.available {
    color: #98eecc;
    font-family: 'Univa Nova';
    font-weight: 800;
    letter-spacing: 0.6px;
}

.unixp-slot-item:hover .unixp-slot-availability.available {
    color: #1c1c1c !important;
}

.unixp-slot-availability.unavailable {
    color: #dc3545;
    font-family: 'Univa Nova';
    font-weight: 800;
    letter-spacing: 0.6px;
}

.unixp-slot-availability.in-cart {
    color: #249D6E;
    font-weight: 800;
    font-family: 'Univa Nova';
}


/* === ÉTATS DE CHARGEMENT === */
.unixp-loading {
    text-align: center;
    padding: 20px;
    color: #6c757d;
    font-style: italic;
}

.unixp-no-slots {
    text-align: center;
    padding: 20px;
    color: #6c757d;
}

.unixp-error {
    text-align: center;
    padding: 20px;
    color: #dc3545;
    background: #f8d7da;
    border-radius: 5px;
    margin: 10px 0;
}

/* === MODAL === */
.unixp-modal {
    position: fixed;
    z-index: 9999;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.7);
}

.unixp-modal-content {
    background-color: #0069FF;
    margin: 8% auto;
    padding: 40px 35px;
    border-radius: 25px;
    width: 80%;
    max-width: 550px;
    position: relative;
}

.unixp-modal-content h4 {
    color: #fff;
    font-size: 30px;
    font-family: 'Quinn';
    margin-bottom: 35px;
    /* 5px (espace) + 3px (hauteur trait) + 12px (margin après) - 3px (ajustement) */
    position: relative;
    letter-spacing: 1.3px;
    margin-top: 0px;
}


.unixp-modal-content h4::after {
    content: '';
    display: block;
    width: 60px;
    height: 4px;
    background-color: #98eecc;
    position: absolute;
    bottom: -4px;
    left: 0;
}

.unixp-modal-content p {
    color: #fff;
    font-family: 'Univa Nova';
    font-weight: 600;
    letter-spacing: 0.6px;
}

.unixp-modal-close {
    color: #fff;
    opacity: 0.7;
    float: right;
    font-size: 28px;
    font-weight: bold;
    cursor: pointer;
    position: absolute;
    right: 15px;
    top: 10px;
}

.unixp-modal-close:hover {
    color: #fff;
    opacity: 1;
}

.unixp-participants-field {
    margin: 35px 0;
}

.unixp-game-selection-field {
    margin: 15px 0;
}

.unixp-participants-field label,
.unixp-game-selection-field label {
    display: block;
    margin: 20px 0px 8px 0px;
    color: #fff;
    font-family: 'Univa Nova';
    font-weight: 800;
    font-size: 16px;
    letter-spacing: 0.6px;
}

.unixp-participants-field select,
.unixp-game-selection-field select {
    width: 100%;
    padding: 14px 12px;
    border-radius: 6px;
    background-color: rgba(255, 255, 255, 0.1);
    font-size: 15px;
    font-family: 'Univa Nova';
    color: #fff;
    font-weight: 500;
    border: none !important;
}

/* Personnalisation des selects dans la modal Unixp */
.unixp-modal-content select,
.unixp-participants-field select,
.unixp-game-selection-field select {
    appearance: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="20" height="12" viewBox="0 0 20 12"><polyline points="2,2 10,10 18,2" fill="none" stroke="%2398eecc" stroke-width="3.5" stroke-linecap="round" stroke-linejoin="round"/></svg>') !important;
    background-repeat: no-repeat !important;
    background-position: right 18px center !important;
    background-size: 18px !important;
    padding-right: 50px !important;
    cursor: pointer !important;
}

.unixp-modal-content select::after,
.unixp-participants-field select::after,
.unixp-game-selection-field select::after {
    display: none !important;
}

/* Fond des options du select */
.unixp-participants-field select option,
.unixp-game-selection-field select option {
    background-color: #1a1a2e;
    /* Fond sombre au lieu de blanc */
    color: #fff;
}

/* Hover sur les options (fonctionne sur certains navigateurs) */
.unixp-participants-field select option:hover,
.unixp-game-selection-field select option:hover {
    background-color: #98eecc !important;
    /* Vert au lieu de gris */
    color: #000;
}

/* Pour le select lui-même quand il est ouvert (certains navigateurs) */
.unixp-participants-field select:focus option:checked,
.unixp-game-selection-field select:focus option:checked {
    background-color: #98eecc;
    color: #000;
}

/* Options du select - fond et couleurs */
.unixp-participants-field select option,
.unixp-game-selection-field select option {
    background-color: #1a1a2e !important;
    color: #fff !important;
}

/* Hover et focus sur les options */
.unixp-participants-field select option:hover,
.unixp-participants-field select option:focus,
.unixp-participants-field select option:checked,
.unixp-game-selection-field select option:hover,
.unixp-game-selection-field select option:focus,
.unixp-game-selection-field select option:checked {
    background-color: #98eecc !important;
    background: #98eecc !important;
    color: #000 !important;
}

/* Pour Firefox */
.unixp-participants-field select option:checked,
.unixp-game-selection-field select option:checked {
    background: linear-gradient(#98eecc, #98eecc) !important;
    background-color: #98eecc !important;
}

.unixp-game-selection-field select:focus {
    outline: none;
    border-color: #007cba;
    box-shadow: 0 0 20px 0 rgba(152, 238, 204, 1);
}

.unixp-modal-actions {
    margin-top: 20px;
    text-align: center;
}

.unixp-modal-actions .button {
    margin: 0 10px;
    padding: 15px 25px;
    border: none;
    border-radius: 100px;
    cursor: pointer;
    background-color: #4c1eb8 !important;
    color: #fff !important;
    transition: 0.3s all ease-out;
}

.unixp-modal-actions .button:hover {
    scale: 1.03;
}

.unixp-modal-content .unixp-modal-actions .unixp-confirm-btn,
.unixp-modal-actions button.unixp-confirm-btn {
    background-color: #98eecc !important;
    color: #1c1c1c !important;
    transition: 0.3s all ease-out;
}

button .unixp-confirm-btn:hover,
.unixp-confirm-btn:hover,
.unixp-confirm-btn .button:hover {
    background-color: #98eecc;
    scale: 1.03;
}

/* === NOTIFICATIONS === */
.unixp-notification {
    position: fixed;
    top: 20px;
    right: 20px;
    padding: 15px 20px;
    border-radius: 5px;
    z-index: 10000;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
    max-width: 400px;
}

.unixp-notification.success {
    background: #28a745;
    color: white;
}

.unixp-notification.error {
    background: #dc3545;
    color: white;
}

.unixp-notification.info {
    background: #17a2b8;
    color: white;
}

.unixp-notification .close-btn {
    background: none;
    border: none;
    color: white;
    float: right;
    font-size: 18px;
    cursor: pointer;
    margin-top: -5px;
}

/* === RESPONSIVE === */
@media (max-width: 768px) {
    .unixp-booking-interface {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .unixp-modal-content {
        width: 95%;
        margin: 20% auto;
    }

    .unixp-notification {
        left: 10px;
        right: 10px;
        max-width: none;
    }
}

/* === BOUTON RESERVEZ === */
.unixp-cart-button-container {
    margin-top: 20px;
    text-align: center;
}

.unixp-cart-button {
    display: inline-block;
    background: #0069ff;
    color: white !important;
    padding: 15px 25px;
    border-radius: 100px;
    text-decoration: none !important;
    font-weight: 800;
    font-size: 16px;
    transition: all 0.3s ease-out;
    border: none;
    cursor: pointer;
    font-family: 'Univa Nova';
}

.unixp-cart-button:hover {
    scale: 1.03;
    color: white !important;
    text-decoration: none !important;
}

.unixp-cart-button:focus {
    outline: 2px solid #005a87;
    outline-offset: 2px;
}

/* === TOURNOIS === */
.unixp-tournament-booking-container {
    margin: 0px 0;
}

/* Styles du bouton personnalisable (basé sur le snippet) */
.unixp-custom-button {
    display: inline-block;
    padding: 15px 35px;
    font-family: 'Univa Nova', sans-serif;
    font-size: 16px;
    font-weight: 700;
    border: none;
    border-radius: 100px;
    cursor: pointer;
    transition: transform 0.3s ease-in-out;
    text-align: center;
    text-decoration: none;
    line-height: 1.2;
    /* Ajout pour la cohérence */
}

.unixp-custom-button:hover {
    transform: scale(1.05);
}

.unixp-tournament-register-btn {
    background: #27ae60;
    color: white;
    padding: 15px 30px;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    font-size: 16px;
}

.unixp-tournament-register-btn:hover {
    background: #219a52;
}

/* === MODAL TOURNOI === */
.unixp-tournament-modal {
    display: none;
    position: fixed;
    z-index: 10000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
}

.unixp-tournament-modal-content {
    background-color: #0069ff;
    margin: 8% auto;
    padding: 0;
    border-radius: 25px;
    width: 90%;
    max-width: 600px;
}

.unixp-tournament-modal-header {
    padding: 20px;
    background: #0069ff;
    color: white;
    border-radius: 25px 25px 0 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.unixp-tournament-modal-header h3 {
    color: #fff;
    font-size: 30px;
    font-family: 'Quinn';
    margin-bottom: 35px;
    /* 5px (espace) + 3px (hauteur trait) + 12px (margin après) - 3px (ajustement) */
    position: relative;
    letter-spacing: 1.3px;
    margin-top: 0px;
    line-height: 1.1em;
}

.unixp-tournament-modal-header h3::after {
    content: '';
    display: block;
    width: 60px;
    height: 4px;
    background-color: #98eecc;
    position: absolute;
    bottom: -4px;
    left: 0;
}

.unixp-tournament-modal-close {
    background: none !important;
    border: none !important;
    color: #98eecc !important;
    font-size: 28px !important;
    cursor: pointer;
    font-weight: 900 !important;
}

.tournament-team-form h4,
.tournament-recap h4,
.spectator-form h4 {
    color: #fff;
    font-size: 1.55em;
    font-family: 'Quinn';
    letter-spacing: 1.3px;
    line-height: 1.2em;
    margin: 0px !important;
}

.tournament-recap ul {
    list-style: none;
    /* Supprime les bullet points */
    padding-left: 0;
    /* Supprime le padding par défaut de la liste */
    margin: 20px 20px 40px 20px;
}

@media (max-width: 768px) {
    .tournament-recap ul {
        margin: 20px 0px 40px 0px !important;
    }
}

.tournament-recap ul li {
    font-family: 'Univa Nova', sans-serif;
    font-size: 1em;
    color: #fff;
    margin-bottom: 10px;
    /* Espacement entre les lignes */
    line-height: 1.2;
}

.tournament-recap ul li strong {
    color: #fff;
    /* Couleur pour les labels en gras */
    font-weight: 700;
}

/* Style spécifique pour les montants */
.tournament-recap ul li .woocommerce-Price-amount {
    color: #fff;
    font-weight: 600;
}

.form-group {
    font-family: 'Univa Nova', sans-serif;
    font-size: 1em;
    color: #fff;
    margin-top: 20px;
    margin-bottom: 10px;
    /* Espacement entre les lignes */
    line-height: 1.1;
    transition: box-shadow 0.3s ease-in-out;
}

.form-group input[type="text"]:focus {
    outline: none;
    /* Supprime le focus par défaut du navigateur */
}

.unixp-tournament-modal-body {
    padding: 0px 40px 30px 40px;
}

@media (max-width: 768px) {
    .unixp-tournament-modal-body {
        padding: 0px 25px 20px 25px;
    }
}

.tournament-team-name,
.spectator-places-select,
.spectator-places-input , .event-participants-input {
    width: 100%;
    padding: 17px;
    border: none;
    border-radius: 8px;
    margin-top: 5px;
    background-color: rgba(255, 255, 255, 0.1) !important;
    color: #fff !important;
    font-family: 'Univa Nova' !important;
    font-size: 1em !important;
    font-weight: 600;
}

.tournament-team-name::placeholder {
    color: #fff;
    opacity: 1;
    /* Certains navigateurs (comme Firefox) appliquent une opacité par défaut */
}

/* Anciens WebKit (Chrome, Safari) */
.tournament-team-name::-webkit-input-placeholder {
    color: #fff;
}

/* Anciens Firefox */
.tournament-team-name::-moz-placeholder {
    color: #fff;
    opacity: 1;
}

/* Internet Explorer 10-11 */
.tournament-team-name:-ms-input-placeholder {
    color: #fff;
}

/* Edge (anciennes versions) */
.tournament-team-name::-ms-input-placeholder {
    color: #fff;
}

.unixp-tournament-modal-footer {
    padding: 20px;
    display: flex;
    justify-content: flex-end;
    gap: 10px;
}
.unixp-tournament-cancel,
.unixp-spectator-cancel {
    background: #4c1eb8 !important;
    color: white !important;
    cursor: pointer;
    border: none !important;
    transition: all 0.3s ease-out;
}

.unixp-tournament-confirm,
.unixp-spectator-confirm {
    background: #98eecc;
    cursor: pointer;
    border: none !important;
    transition: all 0.3s ease-out;
}

.unixp-tournament-cancel:hover,
.unixp-tournament-confirm:hover,
.unixp-spectator-cancel:hover,
.unixp-spectator-confirm:hover {
    scale: 1.05;
}

.unixp-spectator-confirm:disabled {
    background: rgba(152, 238, 204, 0.7) !important;
    cursor: not-allowed;
}

/* === SPECTATEUR TOURNOI === */
.unixp-tournament-booking-buttons {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.unixp-tournament-spectator-btn {
    background: #3498db;
    color: white;
    padding: 15px 30px;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    font-size: 16px;
}

.unixp-tournament-spectator-btn:hover {
    background: #2980b9;
}

.spectator-places-select,
.spectator-places-input {
    width: 100%;
    padding: 10px;
    border: 1px solid #ddd;
    border-radius: 4px;
    margin-top: 5px;
}

.spectator-places-input {
    max-width: 150px;
}

.form-group small {
    display: block;
    color: #98eecc;
    font-size: 14px;
    font-weight: 600;
}

.spectator-total-price {
    text-align: center;
    font-size: 1.5em;
    font-family: 'Quinn';
    color: #fff;
    letter-spacing: 0.6px;
}






button .unixp-event-cancel{
background-color: #4c1eb8 !important;
border: none !important;
color: #fff !important; 
transition: all 0.3s ease-out !important; 
}

button .unixp-event-confirm{
border: none !important;
transition: all 0.3s ease-out !important; 
}




button .unixp-event-cancel:hover ,  button .unixp-event-confirm:hover{
scale:1.05 !important; 
}
















/* Forcer le calendrier à s'adapter au conteneur sur mobile */
@media (max-width: 768px) {

    .unixp-month-calendar,
    .unixp-month-calendar .fc,
    .unixp-month-calendar .fc-view-harness {
        width: 100% !important;
        max-width: 100% !important;
        overflow: hidden !important;
    }

    .unixp-month-calendar table {
        width: 100% !important;
        table-layout: fixed !important;
    }

    .unixp-month-calendar .fc-daygrid-day-frame {
        width: 100% !important;
        min-width: 0 !important;
        height: 60px !important;
        /* Réduire la hauteur des cellules */
    }

    .unixp-month-calendar .fc-daygrid-day {
        min-width: 0 !important;
    }

    .unixp-month-calendar .fc-toolbar-title {
        font-size: 24px !important;
        /* Titre plus petit */
    }
}
