/* ==========================================================================
   Espace Partenaire - Feuille de Style Unifiée (Cards & Formulaires)
   ========================================================================== */

:root {
    --esp-primary: #0098d7; /* Bleu FLIP */
    --esp-primary-h: #11a8e7; 
    --esp-sec: #6c757d;
    --esp-success: #28a745; --esp-danger: #dc3545;
    --esp-border: #e2e8f0; --esp-bg: #f8fafc; --esp-text: #1e293b; 
    --esp-text-l: #64748b; --esp-radius: 16px;
    --esp-shadow: 0 4px 6px -1px rgba(0,0,0,0.1), 0 2px 4px -1px rgba(0,0,0,0.06);
}

.scheme_original input[type="password"]:hover, .scheme_original input[type="text"]:hover, .scheme_original input[type="number"]:hover, .scheme_original input[type="email"]:hover{
    border-color: grey !important;
}

body { background-color: var(--esp-bg); color: var(--esp-text); font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif; }

/* Masquage fort et permanent d'éléments du thème */
.post_info, .social-box { display: none !important; }

/* Suppression du padding sur le wrap du thème pour le plein écran */
.page_content_wrap { padding: 0 !important; }

/* 1. Containers & Layout Général */
.esp-container { max-width: 1200px; margin: 40px auto; padding: 0 20px; }
.esp-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 30px; }

.esp-logout { 
    font-size: 11px; color: var(--esp-text-l); text-decoration: none; font-weight: 600;
    padding: 8px 16px; border: 1px solid var(--esp-border); border-radius: 30px; transition: .3s;
}
.esp-logout:hover { background: var(--esp-danger); color: white; border-color: var(--esp-danger); }

/* 2. Style des Box (Formulaires & Sections) */
.esp-box, .esp-events-section { 
    background: white; border-radius: var(--esp-radius); 
    box-shadow: var(--esp-shadow); padding: 30px; margin-bottom: 30px; 
}
.esp-box { max-width: 500px; margin-left: auto; margin-right: auto; padding: 40px; }

/* Optimisation spécifique pour rendre le formulaire d'inscription plus compact */
#register-box.esp-box { padding: 25px 40px; }
#register-box.esp-box h2 { margin-bottom: 20px; }

.esp-box h2 { margin-top: 0; margin-bottom: 30px; font-size: 24px; text-align: center; color: var(--esp-text); }

/* 3. Formulaires (Champs & Groupes) */
.esp-form-group { margin-bottom: 15px; }
.esp-form-group label { display: block; margin-bottom: 5px; font-weight: 600; font-size: 14px; color: var(--esp-text); }
.esp-form-group input { 
    width: 100%; padding: 10px 15px; border: 1px solid var(--esp-border); 
    border-radius: var(--esp-radius); box-sizing: border-box; transition: .3s; font-size: 14px;
}
.esp-form-group input:focus { outline: none; border-color: var(--esp-primary); box-shadow: 0 0 0 3px rgba(0, 152, 215, 0.1); }
.esp-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 15px; }

/* 4. ACTIONS FORMULAIRES (.esp-btn) */
.esp-form-actions { display: flex; justify-content: center; gap: 15px; margin-top: 25px; }

.esp-btn {
    font-size: 0.938em;
    text-align: center;
    text-transform: uppercase;
    flex: 0 0 auto;
    min-width: 140px;
    padding: 10px 20px;
    border-radius: 8px;
    font-weight: normal !important;
    font-family: 'Roboto', sans-serif;
    border: none;
    cursor: pointer;
    transition: 0.3s ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    position: relative;
    margin-left: 20px;
}

.esp-btn-large{
    flex: 1 1 auto;
    margin: 0;
}

/* Bouton 1 - Inscription (Bleu FLIP) */
 .esp-btn:nth-child(1) { background: #0098d7; color: #fff !important; }
 .esp-btn:nth-child(1):hover { background: #11a8e7; transform: translateY(-1px); }

/* Bouton 2 - Réservation (Jaune/Orange FLIP) */
 .esp-btn-yellow { background: linear-gradient(135deg, #ffe27a, #f5b800); color: #222 !important; }
 .esp-btn-yellow:hover { background: linear-gradient(135deg, #ffcc00, #ff9900); color: #000 !important; transform: translateY(-1px); }

.scheme_original button.esp-btn-icon{
    background: transparent !important;
    border-color: transparent !important;
}

.voir::before {
    font-family: "fontello";
    content: "\e81b";
    color: var(--esp-primary);
    padding-right: 20px;
}

.esp-date-item, .esp-event-times{
    font-size: 14px;
}

#show-register, #show-forgot-password{
    display: block;
    margin-top: 20px;
}

#show-forgot-password{
    text-align: right;
}

.esp-btn-red, #events-empty .esp-btn { background: linear-gradient(to left, #c72f3c, #b9212e); color: white !important; }
.esp-btn-red:hover , #events-empty .esp-btn:hover { background: linear-gradient(135deg, #ffcc00, #ff9900); color: #000 !important; transform: translateY(-1px); }

/* Dashboard Headers */
.esp-section-header { display: flex; align-items: center; margin-bottom: 30px; padding-bottom: 20px; border-bottom: 2px solid var(--esp-bg); }

/* Limitation de la largeur du bouton d'ajout dans le header */
.esp-section-header .esp-btn-primary { 
    max-width: 260px; 
    display: inline-flex; 
    align-items: center; 
    justify-content: center; 
    gap: 8px; 
    background: linear-gradient(135deg, var(--esp-primary) 0%, var(--esp-primary-h) 100%); 
    color: white !important; 
    padding: 10px 20px; 
    font-size: 15px; 
    font-weight: 700; 
    text-decoration: none; 
    border: none; 
    box-shadow: 0 6px 12px -3px rgba(0, 115, 170, 0.3); 
    transition: 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275); 
    cursor: pointer; 
}

.esp-section-header h3 {
    margin: 0;
    flex: 1;
}

.esp-section-header .esp-btn-primary:hover { transform: translateY(-2px); box-shadow: 0 10px 15px -3px rgba(0, 115, 170, 0.4); }

/* Animation Pulsation */
.esp-empty .esp-btn-primary { animation: esp-pulse 2s infinite; }
@keyframes esp-pulse {
    0% { box-shadow: 0 0 0 0 rgba(0, 152, 215, 0.7); }
    70% { box-shadow: 0 0 0 15px rgba(0, 152, 215, 0); }
    100% { box-shadow: 0 0 0 0 rgba(0, 152, 215, 0); }
}

/* 5. Grid de Cartes Dashboard */
.esp-table { width: 100%; border-collapse: separate; border-spacing: 0 15px; margin-top: -15px; }
.esp-table thead { display: none; }
.esp-table tr { background: white; border-radius: var(--esp-radius); box-shadow: var(--esp-shadow); transition: .3s ease; }
.esp-table td { border: none; padding: 15px 20px; vertical-align: middle; }

/* 6. Thumbnail Sexy 110x110 */
.esp-event-thumbnail { width: 110px; padding: 12px !important; }
.esp-thumbnail-link { display: block; width: 110px; height: 110px; border-radius: var(--esp-radius); overflow: hidden; position: relative; }
.esp-thumbnail-link img { width: 100%; height: 100%; object-fit: cover; transition: .4s; display: block; }
.esp-table tr:hover img { transform: scale(1.1); }

/* 8. BADGES LEGES ET MODERNES */
.esp-badge {
    display: inline-flex;
    padding: 4px 10px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    border-radius: 6px;
    background: var(--esp-bg);
    color: var(--esp-text-l);
}

.esp-badge-success {
    background: rgba(40, 167, 69, 0.1); /* Vert Flip translucide */
    color: #28a745;
    border: 1px solid rgba(40, 167, 69, 0.15);
}

/* Styles des icônes */
.icone-pdf {
    font-size: 24px;
    color: #f0f0f0;
    position: absolute;
    left : -16px;
}

/* 9. Responsive */
@media (max-width: 768px) {
    #register-box.esp-box { padding: 20px; }
    .esp-form-row { grid-template-columns: 1fr; }
    .esp-form-actions { flex-direction: column; align-items: stretch; gap: 10px; }
    .esp-btn { width: 100%; min-width: unset; }
    .esp-section-header .esp-btn-primary { max-width: 100%; width: 100%; }
    .esp-table tr { display: grid; grid-template-columns: 110px 1fr; gap: 0; grid-template-areas: "thumb title" "thumb data" "thumb actions"; padding: 10px; }
}