/* ══════════════════════════════════════════════════════════════
   PUNCH — Page Carte (style brutaliste, ref. Claude Design)
   Préfixe body.page-template-page-carte pour vaincre les overrides parent.
   ══════════════════════════════════════════════════════════════ */

body.page-template-page-carte .punch-page-carte {
    background: var(--punch-blanc);
}

/* ── PAGEBAND : rouge, eyebrow + titre Aldo + lead ───────── */
body.page-template-page-carte .pb-pageband {
    background    : var(--punch-rouge);
    color         : var(--punch-blanc);
    border-bottom : 2px solid var(--punch-noir);
    padding       : clamp(48px, 8vw, 96px) 0 clamp(32px, 5vw, 64px);
}

body.page-template-page-carte .pb-pageband__inner {
    max-width: 1440px;
    margin   : 0 auto;
    padding  : 0 clamp(20px, 4vw, 64px);
}

body.page-template-page-carte .pb-pageband__eyebrow {
    display       : flex;
    align-items   : center;
    gap           : 12px;
    font-family   : var(--punch-font-base);
    font-size     : 13px;
    font-weight   : 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color         : var(--punch-blanc);
    opacity       : 0.92;
    margin        : 0 0 18px;
}

body.page-template-page-carte .pb-pageband__eyebrow::before {
    content: '';
    width  : 40px;
    height : 2px;
    background: currentColor;
    display: inline-block;
}

body.page-template-page-carte .pb-pageband__title {
    font-family   : var(--punch-font-display);
    font-size     : clamp(3rem, 9vw + 1rem, 8.75rem);
    line-height   : 0.9;
    letter-spacing: -0.02em;
    text-transform: uppercase;
    color         : var(--punch-blanc) !important;
    margin        : 0;
}

body.page-template-page-carte .pb-pageband__title .accent,
body.page-template-page-carte .pb-pageband__title strong {
    color      : var(--punch-noir) !important;
    font-weight: inherit;
}

body.page-template-page-carte .pb-pageband__lead {
    margin-top : 24px;
    max-width  : 640px;
    font-family: var(--punch-font-base);
    font-size  : 1.0625rem;
    line-height: 1.55;
    color      : var(--punch-blanc);
    opacity    : 0.95;
}

body.page-template-page-carte .pb-pageband__lead p {
    margin: 0 0 0.75em;
}

body.page-template-page-carte .pb-pageband__lead p:last-child {
    margin-bottom: 0;
}

/* ── WRAPPER GRID 2 colonnes ─────────────────────────────── */
body.page-template-page-carte .pb-carte-wrap {
    display              : grid;
    grid-template-columns: 420px 1fr;
    height               : calc(100vh - 80px);
    min-height           : 700px;
    border-top           : 2px solid var(--punch-noir);
    background           : var(--punch-blanc);
}

@media (max-width: 991.98px) {
    body.page-template-page-carte .pb-carte-wrap {
        grid-template-columns: 1fr;
        height               : auto;
        min-height           : 0;
    }
}

/* ══════════════════════════════════════════════════════════
   SIDEBAR
   ══════════════════════════════════════════════════════════ */
body.page-template-page-carte .pb-carte-side {
    background   : var(--punch-blanc);
    border-right : 2px solid var(--punch-noir);
    overflow-y   : auto;
    color        : var(--punch-noir);
    display      : flex;
    flex-direction: column;
}

@media (max-width: 991.98px) {
    body.page-template-page-carte .pb-carte-side {
        border-right : 0;
        border-bottom: 2px solid var(--punch-noir);
        max-height   : 60vh;
    }
}

body.page-template-page-carte .pb-carte-side__head {
    position     : sticky;
    top          : 0;
    z-index      : 5;
    background   : var(--punch-blanc);
    padding      : 24px 24px 16px;
    border-bottom: 2px solid var(--punch-noir);
}

body.page-template-page-carte .pb-carte-side__title {
    font-family   : var(--punch-font-display);
    font-size     : 40px;
    line-height   : 1;
    text-transform: uppercase;
    color         : var(--punch-rouge);
    letter-spacing: -0.01em;
    margin        : 0;
}

body.page-template-page-carte .pb-carte-side__stat {
    margin-top    : 8px;
    display       : flex;
    gap           : 14px;
    font-family   : 'JetBrains Mono', ui-monospace, monospace;
    font-size     : 11px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color         : #6B655D;
}

body.page-template-page-carte .pb-carte-side__stat b {
    color      : var(--punch-rouge);
    font-weight: 700;
}

/* ── FILTRES (chips) ─────────────────────────────────────── */
body.page-template-page-carte .pb-carte-filters {
    padding      : 16px 24px;
    border-bottom: 1px dashed #E5E5E5;
}

body.page-template-page-carte .pb-carte-filters__group {
    margin-bottom: 16px;
}
body.page-template-page-carte .pb-carte-filters__group:last-child {
    margin-bottom: 0;
}

body.page-template-page-carte .pb-carte-filters__label {
    font-family   : 'JetBrains Mono', ui-monospace, monospace;
    font-size     : 10px;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color         : #6B655D;
    margin        : 0 0 8px;
}

body.page-template-page-carte .pb-carte-filters__chips {
    display  : flex;
    flex-wrap: wrap;
    gap      : 6px;
}

body.page-template-page-carte .pb-chip {
    display       : inline-flex;
    align-items   : center;
    gap           : 6px;
    padding       : 6px 12px;
    background    : var(--punch-blanc);
    border        : 2px solid var(--punch-noir);
    color         : var(--punch-noir);
    font-family   : var(--punch-font-base);
    font-size     : 12px;
    font-weight   : 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    cursor        : pointer;
    transition    : background 0.12s ease, color 0.12s ease, transform 0.1s ease;
    line-height   : 1;
}

body.page-template-page-carte .pb-chip:hover {
    background: #F4F4F4;
}

body.page-template-page-carte .pb-chip.is-active {
    background: var(--punch-noir);
    color     : var(--punch-blanc);
}

body.page-template-page-carte .pb-chip__dot {
    width        : 8px;
    height       : 8px;
    border-radius: 50%;
    background   : currentColor;
    display      : inline-block;
}

/* ── LISTE événements/structures ─────────────────────────── */
body.page-template-page-carte .pb-carte-list {
    padding: 12px 0;
    flex   : 1;
}

body.page-template-page-carte .pb-carte-list__item {
    display              : grid;
    grid-template-columns: 56px 1fr auto;
    gap                  : 12px;
    padding              : 16px 24px;
    border-bottom        : 1px solid #E5E5E5;
    cursor               : pointer;
    transition           : background 0.12s ease;
    align-items          : center;
    background           : var(--punch-blanc);
}

body.page-template-page-carte .pb-carte-list__item:hover,
body.page-template-page-carte .pb-carte-list__item.is-active {
    background: #F9E7E5;
}

body.page-template-page-carte .pb-carte-list__item.is-active {
    border-left  : 4px solid var(--punch-rouge);
    padding-left : 20px;
}

body.page-template-page-carte .pb-cl__date {
    text-align : center;
    background : var(--punch-noir);
    color      : var(--punch-blanc);
    padding    : 6px 4px;
    line-height: 1;
}

body.page-template-page-carte .pb-cl__date-day {
    font-family: var(--punch-font-display);
    font-size  : 22px;
}

body.page-template-page-carte .pb-cl__date-mo {
    display       : block;
    margin-top    : 2px;
    font-size     : 9px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    opacity       : 0.7;
}

body.page-template-page-carte .pb-cl__t {
    font-family   : var(--punch-font-display);
    font-size     : 17px;
    line-height   : 1.15;
    text-transform: uppercase;
    color         : var(--punch-noir);
    letter-spacing: -0.005em;
}

body.page-template-page-carte .pb-cl__meta {
    margin-top : 2px;
    font-family: var(--punch-font-base);
    font-size  : 12px;
    color      : #6B655D;
}

body.page-template-page-carte .pb-cl__type {
    font-family   : 'JetBrains Mono', ui-monospace, monospace;
    font-size     : 10px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    padding       : 3px 7px;
    border        : 1px solid var(--punch-noir);
    color         : var(--punch-noir);
    background    : var(--punch-blanc);
    white-space   : nowrap;
}

body.page-template-page-carte .pb-carte-list__empty {
    padding    : 40px 24px;
    text-align : center;
    font-family: var(--punch-font-base);
    font-size  : 14px;
    color      : #6B655D;
    font-style : italic;
}

/* ══════════════════════════════════════════════════════════
   MAP AREA
   ══════════════════════════════════════════════════════════ */
body.page-template-page-carte .pb-carte-main {
    position  : relative;
    background: var(--punch-rouge);
    overflow  : hidden;
}

@media (max-width: 991.98px) {
    body.page-template-page-carte .pb-carte-main {
        height: 70vh;
    }
}

body.page-template-page-carte #punch-map {
    width    : 100%;
    height   : 100%;
    min-height: 600px;
}

@media (max-width: 991.98px) {
    body.page-template-page-carte #punch-map {
        min-height: 500px;
    }
}

/* ── Toolbar zoom (top-right) ────────────────────────────── */
body.page-template-page-carte .pb-carte-toolbar {
    position     : absolute;
    top          : 16px;
    right        : 16px;
    display      : flex;
    flex-direction: column;
    gap          : 6px;
    z-index      : 4;
}

body.page-template-page-carte .pb-carte-toolbar button {
    width       : 44px;
    height      : 44px;
    background  : var(--punch-blanc);
    border      : 2px solid var(--punch-noir);
    border-radius: 0;
    font-family : var(--punch-font-display);
    font-size   : 20px;
    color       : var(--punch-noir);
    cursor      : pointer;
    box-shadow  : 3px 3px 0 0 var(--punch-noir);
    transition  : transform 0.1s ease, box-shadow 0.1s ease, background 0.12s ease;
    display     : inline-flex;
    align-items : center;
    justify-content: center;
    padding     : 0;
}

body.page-template-page-carte .pb-carte-toolbar button:hover {
    background: var(--punch-noir);
    color     : var(--punch-blanc);
    transform : translate(-1px, -1px);
    box-shadow: 4px 4px 0 0 var(--punch-noir);
}

body.page-template-page-carte .pb-carte-toolbar button:active {
    transform : translate(1px, 1px);
    box-shadow: 1px 1px 0 0 var(--punch-noir);
}

/* On masque les contrôles natifs Mapbox (notre toolbar custom prend le relais) */
body.page-template-page-carte .mapboxgl-ctrl-top-right,
body.page-template-page-carte .mapboxgl-ctrl-bottom-right {
    display: none !important;
}

/* ══════════════════════════════════════════════════════════
   POPUP MAPBOX (style brutaliste)
   ══════════════════════════════════════════════════════════ */
/* Wrapper Mapbox : son max-width par défaut (240px) écrase notre largeur */
body.page-template-page-carte .punch-popup,
body.page-template-page-carte .mapboxgl-popup.punch-popup {
    max-width: 380px !important;
}

body.page-template-page-carte .punch-popup .mapboxgl-popup-content {
    padding      : 0 !important;
    border       : 2px solid var(--punch-noir);
    border-radius: 0;
    box-shadow   : 8px 8px 0 0 var(--punch-noir);
    background   : var(--punch-blanc);
    color        : var(--punch-noir);
    width        : 340px;
    max-width    : 340px;
    /* Limite la hauteur + scroll interne si beaucoup d'événements */
    max-height   : calc(100vh - 220px);
    overflow-y   : auto;
    overflow-x   : hidden;
}

body.page-template-page-carte .punch-popup .mapboxgl-popup-tip {
    display: none;
}

body.page-template-page-carte .punch-popup .mapboxgl-popup-close-button {
    top         : 8px;
    right       : 8px;
    width       : 28px;
    height      : 28px;
    background  : var(--punch-noir);
    color       : var(--punch-blanc);
    border      : 0;
    border-radius: 0;
    font-size   : 18px;
    line-height : 1;
    cursor      : pointer;
    z-index     : 2;
}

body.page-template-page-carte .punch-popup .mapboxgl-popup-close-button:hover {
    background: var(--punch-rouge);
}

body.page-template-page-carte .punch-popup-img {
    position    : relative;
    height      : 110px;
    background  : var(--punch-rouge);
    overflow    : hidden;
}

body.page-template-page-carte .punch-popup-img img,
body.page-template-page-carte .punch-popup-img .punch-popup-logo {
    width      : 100%;
    height     : 100%;
    object-fit : contain;
    background : var(--punch-rouge);
    padding    : 12px 16px;
}

body.page-template-page-carte .punch-popup-img-placeholder {
    display       : flex;
    align-items   : center;
    justify-content: center;
    height        : 100%;
    color         : rgba(255, 255, 255, 0.5);
    font-family   : 'JetBrains Mono', ui-monospace, monospace;
    font-size     : 11px;
    text-transform: uppercase;
    letter-spacing: 0.14em;
}

body.page-template-page-carte .punch-popup-type {
    position     : absolute;
    top          : 12px;
    left         : 12px;
    background   : var(--punch-noir);
    color        : var(--punch-blanc);
    font-family  : 'JetBrains Mono', ui-monospace, monospace;
    font-size    : 10px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    padding      : 4px 8px;
    z-index      : 1;
}

body.page-template-page-carte .punch-popup-body {
    padding: 16px;
}

body.page-template-page-carte .punch-popup-title {
    margin        : 0 0 10px;
    font-family   : var(--punch-font-display);
    font-size     : 24px;
    line-height   : 1.05;
    text-transform: uppercase;
    color         : var(--punch-noir);
    letter-spacing: -0.01em;
}

body.page-template-page-carte .punch-popup-meta {
    display       : flex;
    flex-direction: column;
    gap           : 4px;
    font-family   : var(--punch-font-base);
    font-size     : 13px;
    color         : #2E2A26;
    margin        : 0 0 12px;
}

body.page-template-page-carte .punch-popup-meta-row {
    display: flex;
    gap    : 8px;
}

body.page-template-page-carte .punch-popup-meta-row b {
    flex          : 0 0 70px;
    font-family   : 'JetBrains Mono', ui-monospace, monospace;
    font-size     : 10px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color         : #6B655D;
    font-weight   : 600;
    padding-top   : 1px;
}

body.page-template-page-carte .punch-popup-events {
    list-style   : none;
    margin       : 0 0 12px;
    padding      : 12px 0 0;
    border-top   : 1px solid #E5E5E5;
    display      : flex;
    flex-direction: column;
    gap          : 10px;
}

body.page-template-page-carte .punch-popup-event {
    padding: 0;
    border : 0;
}

body.page-template-page-carte .punch-popup-event strong {
    display       : block;
    font-family   : var(--punch-font-display);
    font-size     : 15px;
    line-height   : 1.15;
    text-transform: uppercase;
    color         : var(--punch-noir);
    margin-bottom : 4px;
}

body.page-template-page-carte .punch-popup-event-meta {
    display       : block;
    font-family   : var(--punch-font-base);
    font-size     : 12px;
    color         : #6B655D;
    margin-bottom : 4px;
}

body.page-template-page-carte .punch-popup-tag {
    display       : inline-block;
    padding       : 3px 7px;
    background    : var(--punch-blanc);
    color         : var(--punch-noir);
    border        : 1px solid var(--punch-noir);
    font-family   : 'JetBrains Mono', ui-monospace, monospace;
    font-size     : 10px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-right  : 6px;
}

body.page-template-page-carte .punch-popup-empty {
    padding    : 12px 0 0;
    border-top : 1px solid #E5E5E5;
    color      : #999;
    font-style : italic;
    font-family: var(--punch-font-base);
    font-size  : 13px;
    margin     : 0 0 12px;
}

body.page-template-page-carte .punch-popup-actions {
    display  : flex;
    gap      : 8px;
    flex-wrap: wrap;
}

body.page-template-page-carte .punch-popup-btn {
    display       : inline-block;
    padding       : 8px 14px;
    background    : var(--punch-rouge);
    color         : var(--punch-blanc) !important;
    border        : 2px solid var(--punch-noir);
    font-family   : var(--punch-font-base);
    font-size     : 12px;
    font-weight   : 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    text-decoration: none;
    box-shadow    : 3px 3px 0 0 var(--punch-noir);
    transition    : transform 0.1s ease, box-shadow 0.1s ease;
    cursor        : pointer;
}

body.page-template-page-carte .punch-popup-btn:hover {
    transform : translate(-1px, -1px);
    box-shadow: 4px 4px 0 0 var(--punch-noir);
    text-decoration: none;
}

body.page-template-page-carte .punch-popup-btn--ghost {
    background: var(--punch-blanc);
    color     : var(--punch-noir) !important;
}
