/* ═══════════════════════════════════════════════
   PAGE CONTACT — CDTT76
   ═══════════════════════════════════════════════ */

:root {
    --navy:       #0D2A6B;
    --navy-light: #1a3a85;
    --red:        #D4192C;
    --red-hover:  #b8152b;
    --light:      #F4F6FB;
    --border:     #e2e6f0;
    --text:       #1a1a2e;
    --muted:      #6b7280;
    --white:      #ffffff;
    --radius:     12px;
    --shadow:     0 2px 16px rgba(13,42,107,.08);
    --shadow-lg:  0 8px 32px rgba(13,42,107,.14);
    --transition: .22s ease;

    --color-blue:  #1565c0;
    --color-green: #2e7d32;
}

.page-contact .container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 24px;
}

/* ═══ HERO ══════════════════════════════════════ */
.contact-hero {
    position: relative;
    background: var(--navy);
    color: var(--white);
    padding: 72px 0 64px;
    overflow: hidden;
    text-align: center;
}

.contact-hero__bg {
    position: absolute;
    inset: 0;
    background-image:
        radial-gradient(circle at 10% 70%, rgba(212,25,44,.18) 0%, transparent 45%),
        radial-gradient(circle at 88% 25%, rgba(255,255,255,.05) 0%, transparent 40%);
    pointer-events: none;
}

.page-contact .section-label {
    display: inline-block;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--red);
    background: rgba(212,25,44,.15);
    padding: 4px 14px;
    border-radius: 100px;
    margin-bottom: 16px;
}

.contact-hero__title {
    font-size: clamp(1.9rem, 4.5vw, 3rem);
    font-weight: 900;
    line-height: 1.1;
    margin: 0 0 14px;
    color: var(--white);
}

.contact-hero__title span { color: var(--red); }

.contact-hero__sub {
    font-size: .95rem;
    color: rgba(255,255,255,.65);
    max-width: 520px;
    margin: 0 auto 28px;
    line-height: 1.6;
}

.contact-hero__stats {
    display: inline-flex;
    align-items: center;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 100px;
    padding: 10px 28px;
}

.contact-stat {
    display: flex;
    align-items: center;
    gap: 8px;
}

.contact-stat__num {
    font-size: 1.5rem;
    font-weight: 900;
    color: var(--white);
}

.contact-stat__label {
    font-size: .8rem;
    color: rgba(255,255,255,.65);
}

.contact-stat__sep {
    width: 1px;
    height: 28px;
    background: rgba(255,255,255,.2);
    margin: 0 20px;
}

/* ═══ INFOS + CARTE ══════════════════════════════ */
.contact-info-section {
    background: var(--light);
    padding: 56px 0 60px;
}

.contact-info-layout {
    display: grid;
    grid-template-columns: 420px 1fr;
    gap: 32px;
    align-items: stretch;
    min-height: 420px;
}

/* Colonne infos */
.contact-details {
    background: var(--white);
    border-radius: var(--radius);
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
    padding: 32px 32px 28px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.contact-details__title {
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--navy);
    margin: 0 0 18px;
    padding-bottom: 16px;
    border-bottom: 2px solid var(--border);
}

/* Item contact */
.contact-item {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 13px 14px;
    border-radius: 10px;
    text-decoration: none;
    transition: background var(--transition), box-shadow var(--transition);
    border: 1px solid transparent;
}

a.contact-item:hover {
    background: var(--light);
    border-color: var(--border);
}

.contact-item--static {
    cursor: default;
}

.contact-item__icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--white);
}

.contact-item__icon--loc   { background: var(--red); }
.contact-item__icon--mail  { background: var(--navy); }
.contact-item__icon--phone { background: #2e7d32; }
.contact-item__icon--clock { background: #e65100; }

.contact-item__body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.contact-item__label {
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--muted);
}

.contact-item__value {
    font-size: .9rem;
    font-weight: 600;
    color: var(--text);
    line-height: 1.4;
}

.contact-item__arrow {
    color: var(--muted);
    flex-shrink: 0;
    opacity: 0;
    transition: opacity var(--transition), transform var(--transition);
}

a.contact-item:hover .contact-item__arrow {
    opacity: 1;
    transform: translateX(2px);
}

.contact-item__badge {
    font-size: .7rem;
    font-weight: 700;
    color: #2e7d32;
    background: rgba(46,125,50,.1);
    padding: 3px 10px;
    border-radius: 100px;
    flex-shrink: 0;
}

/* Réseaux */
.contact-socials {
    margin-top: 12px;
    padding-top: 16px;
    border-top: 1px solid var(--border);
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.contact-socials__label {
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--muted);
    margin-right: 4px;
}

.social-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: .78rem;
    font-weight: 600;
    padding: 6px 14px;
    border-radius: 8px;
    text-decoration: none;
    transition: all var(--transition);
    color: var(--white);
}

.social-btn--fb { background: #1877f2; }
.social-btn--fb:hover { background: #0f5ec9; }
.social-btn--yt { background: #ff0000; }
.social-btn--yt:hover { background: #cc0000; }

/* Carte */
.contact-map {
    border-radius: var(--radius);
    overflow: hidden;
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
    min-height: 380px;
}

.contact-map iframe {
    width: 100%;
    height: 100%;
    min-height: 380px;
    display: block;
    border: none;
}

/* ═══ BUREAU ══════════════════════════════════════ */
.bureau-section {
    background: var(--white);
    padding: 64px 0 72px;
}

.bureau-header {
    text-align: center;
    margin-bottom: 52px;
}

.bureau-title {
    font-size: clamp(1.6rem, 3vw, 2.2rem);
    font-weight: 900;
    color: var(--navy);
    margin: 8px 0 10px;
}

.bureau-sub {
    font-size: .9rem;
    color: var(--muted);
    max-width: 460px;
    margin: 0 auto;
}

/* Groupe */
.bureau-group {
    margin-bottom: 48px;
}

.bureau-group:last-child { margin-bottom: 0; }

.bureau-group__label {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    font-size: .72rem;
    font-weight: 800;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--navy);
    background: rgba(13,42,107,.07);
    padding: 6px 14px;
    border-radius: 100px;
    margin-bottom: 20px;
}

.bureau-group__label--districts {
    color: var(--color-blue);
    background: rgba(21,101,192,.08);
}

.bureau-group__label--commissions {
    color: var(--color-green);
    background: rgba(46,125,50,.08);
}

/* Grille membres */
.members-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}

.members-grid--exec {
    grid-template-columns: repeat(4, 1fr);
}

/* Card membre */
.member-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px;
    display: flex;
    gap: 14px;
    align-items: flex-start;
    box-shadow: var(--shadow);
    transition: transform var(--transition), box-shadow var(--transition);
}

.member-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-lg);
}

.member-card--exec {
    border-top: 3px solid var(--navy);
}

/* Avatar */
.member-card__avatar {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .75rem;
    font-weight: 900;
    letter-spacing: .02em;
    color: var(--white);
    flex-shrink: 0;
}

.member-card__avatar--navy  { background: var(--navy); }
.member-card__avatar--blue  { background: var(--color-blue); }
.member-card__avatar--green { background: var(--color-green); }

.member-card__body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.member-card__role {
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .07em;
    text-transform: uppercase;
    color: var(--red);
}

.member-card__role--blue  { color: var(--color-blue); }
.member-card__role--green { color: var(--color-green); }

.member-card__name {
    font-size: .9rem;
    font-weight: 700;
    color: var(--navy);
    margin: 0;
    line-height: 1.2;
}

.member-card__email {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: .72rem;
    color: var(--muted);
    text-decoration: none;
    margin-top: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: color var(--transition);
}

.member-card__email:hover { color: var(--red); }

.contact-item__badge--closed {
    color: var(--red);
    background: rgba(212, 25, 44, 0.1); /* Rouge transparent assorti à votre charte */
}

/* ═══ RESPONSIVE (CORRIGÉ & OPTIMISÉ) ═════════════════════════════ */
@media (max-width: 1024px) {
    .contact-info-layout { 
        grid-template-columns: 1fr; 
        min-height: auto; /* Permet au bloc de s'adapter naturellement en hauteur */
    }
    .contact-map { 
        min-height: 320px; 
        height: 320px; 
    }
    .contact-map iframe { 
        min-height: 100%; 
    }
    .members-grid { 
        grid-template-columns: repeat(2, 1fr); 
    }
    .members-grid--exec { 
        grid-template-columns: repeat(2, 1fr); 
    }
}

@media (max-width: 768px) {
    .contact-hero {
        padding: 56px 0 48px;
    }
    .members-grid,
    .members-grid--exec { 
        grid-template-columns: repeat(2, 1fr); 
    }
}

@media (max-width: 540px) {
    .contact-hero { 
        padding: 44px 0 40px; 
    }
    .contact-hero__stats { 
        flex-direction: column; 
        gap: 12px; 
        padding: 16px 20px; 
        border-radius: 16px; 
        width: 100%;
        box-sizing: border-box;
    }
    .contact-stat__sep { 
        width: 40px; 
        height: 1px; 
        margin: 4px 0; 
    }
    
    /* Ajustements de la carte de contact */
    .contact-details { 
        padding: 24px 20px; 
    }
    
    /* Évite que les longs textes (comme l'adresse mail) ne dépassent de l'écran */
    .contact-item {
        padding: 10px 12px;
    }
    .contact-item__value {
        font-size: 0.85rem;
        word-break: break-word; 
    }
    
    /* Correction de l'alignement des réseaux sociaux */
    .contact-socials {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }
    .contact-socials__links {
        display: flex;
        gap: 10px;
        width: 100%;
    }
    .social-btn {
        flex: 1; /* Les boutons prennent la même largeur équitablement */
        justify-content: center;
    }

    /* Grilles des membres sur une seule colonne */
    .members-grid,
    .members-grid--exec { 
        grid-template-columns: 1fr; 
    }
    .member-card { 
        padding: 16px; 
    }
}