.event-hero {
    position: relative;
    height: 716px;
    overflow: hidden;
}

.event-map-hero {
    position: absolute;
    inset: 0;
    z-index: 0;
    width: 100%;
    height: 100%;
    min-height: 716px;
    background: #0c1321;
}

.event-map-side,
.event-map {
    position: relative;
    z-index: 0;
    width: 100%;
    background: #111827;
}

.event-map-side {
    min-height: 192px;
}

.event-map {
    min-height: 224px;
}

.event-map-hero .leaflet-pane,
.event-map-hero .leaflet-tile-pane,
.event-map-hero .leaflet-overlay-pane,
.event-map-hero .leaflet-shadow-pane,
.event-map-hero .leaflet-marker-pane,
.event-map-hero .leaflet-tooltip-pane,
.event-map-hero .leaflet-popup-pane,
.event-map-side .leaflet-pane,
.event-map-side .leaflet-tile-pane,
.event-map-side .leaflet-overlay-pane,
.event-map-side .leaflet-shadow-pane,
.event-map-side .leaflet-marker-pane,
.event-map-side .leaflet-tooltip-pane,
.event-map-side .leaflet-popup-pane,
.event-map .leaflet-pane,
.event-map .leaflet-tile-pane,
.event-map .leaflet-overlay-pane,
.event-map .leaflet-shadow-pane,
.event-map .leaflet-marker-pane,
.event-map .leaflet-tooltip-pane,
.event-map .leaflet-popup-pane {
    z-index: 1 !important;
}

.event-map-hero .leaflet-control-container,
.event-map-side .leaflet-control-container,
.event-map .leaflet-control-container {
    display: none;
}

.event-hero-gradient {
    position: absolute;
    inset-inline: 0;
    bottom: 0;
    height: 75%;
    z-index: 20;
    background: linear-gradient(to top, #0C1321 0%, rgba(12,19,33,0.42) 50%, transparent 100%);
}

.event-hero-content {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 30;
}

.mc-map-popup .leaflet-popup-content-wrapper {
    background: #151b2a;
    color: #dce2f6;
    border: 1px solid rgba(88, 66, 55, 0.25);
    box-shadow: none;
}

.mc-map-popup .leaflet-popup-tip {
    background: #151b2a;
}

.events-layout {
    min-height: 100vh;
    background: #0c1321;
}

.events-content {
    min-height: 100vh;
    background: #0c1321;
}

/* =====================================================
   Valeurs arbitraires non générées par le build Tailwind V1
   ===================================================== */

/* Container centré principal — aligné sur le reste du site (max-w-screen-xl = 1280px) */
.events-main {
    max-width: 1280px;
    margin-left: auto;
    margin-right: auto;
    width: 100%;
}

/* Hero — hauteur + radius (maquette Stitch) */
.events-hero {
    position: relative;
    overflow: hidden;
    border-radius: 1.5rem;
    height: 320px;
    display: flex;
    align-items: center;
}

@media (max-width: 767px) {
    .events-hero {
        height: 360px;
    }
}

.events-hero-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.7;
    filter: grayscale(1);
}

.events-hero-fallback {
    position: absolute;
    inset: 0;
    z-index: 0;
    background:
        radial-gradient(circle at 25% 20%, rgba(249, 115, 22, 0.25) 0%, transparent 45%),
        radial-gradient(circle at 80% 85%, rgba(249, 115, 22, 0.15) 0%, transparent 50%),
        linear-gradient(135deg, #232a39 0%, #0c1321 100%);
}

.events-hero-overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(to right, rgba(12, 19, 33, 0.5) 0%, rgba(12, 19, 33, 0.3) 50%, transparent 100%);
}

.events-hero-content {
    position: relative;
    z-index: 2;
    padding: 0 2rem;
    max-width: 48rem;
}

@media (min-width: 768px) {
    .events-hero-content {
        padding: 0 3rem;
    }
}

.events-hero-title {
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-size: 2.25rem;
    font-weight: 900;
    font-style: italic;
    color: #dce2f6;
    margin-bottom: 1rem;
    letter-spacing: -0.025em;
    line-height: 1.05;
}

@media (min-width: 768px) {
    .events-hero-title {
        font-size: 3rem;
    }
}

.events-hero-title .accent {
    color: #f97316;
}

.events-hero-sub {
    color: #b9c7e0;
    font-size: 1rem;
    margin-bottom: 1.5rem;
    max-width: 32rem;
    line-height: 1.6;
}

@media (min-width: 768px) {
    .events-hero-sub {
        font-size: 1.125rem;
    }
}

.events-hero-form {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

@media (min-width: 640px) {
    .events-hero-form {
        flex-direction: row;
    }
}

.events-hero-search {
    flex: 1;
    max-width: 28rem;
    position: relative;
}

.events-hero-search .material-symbols-outlined {
    position: absolute;
    left: 1rem;
    top: 50%;
    transform: translateY(-50%);
    color: #f97316;
    pointer-events: none;
}

.events-hero-search input {
    width: 100%;
    background: rgba(35, 42, 57, 0.6);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: none;
    border-radius: 1rem;
    padding: 1rem 1.5rem 1rem 3rem;
    color: #dce2f6;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
    transition: box-shadow 0.2s ease;
}

.events-hero-search input::placeholder {
    color: #3c4a5e;
}

.events-hero-search input:focus {
    outline: none;
    box-shadow: 0 0 0 2px #f97316;
}

/* Bouton CTA Explorer (gradient orange cohérent avec le reste du site) */
.events-cta {
    background-image: linear-gradient(135deg, #ffb690 0%, #f97316 100%);
    color: #341100;
    font-weight: 700;
    transition: box-shadow 0.2s ease, transform 0.1s ease;
}

.events-cta:hover {
    box-shadow: 0 0 20px rgba(249, 115, 22, 0.4);
}

.events-cta:active {
    transform: scale(0.95);
}

/* ============================================
   Card événement — maquette Stitch (desktop)
   ============================================ */
.events-card {
    border-radius: 2rem;
    background: #151b2a;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    text-decoration: none;
    color: inherit;
}

.events-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 32px 64px rgba(7, 14, 28, 0.6);
}

.events-card-media {
    position: relative;
    width: 100%;
    height: 16rem;
    overflow: hidden;
}

.events-card-img,
.events-card .event-map {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    transition: transform 0.7s ease;
}

.events-card:hover .events-card-img {
    transform: scale(1.1);
}

.events-card-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, #232a39 0%, #151b2a 100%);
    color: #e0c0b1;
}

.events-card-placeholder .material-symbols-outlined {
    font-size: 3rem;
}

/* Badges dans l'image */
.events-card-badge-cat {
    position: absolute;
    top: 1rem;
    left: 1rem;
    background: rgba(12, 19, 33, 0.8);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    color: #f97316;
    padding: 0.375rem 1rem;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    border: 1px solid rgba(249, 115, 22, 0.2);
}

.events-card-badge-level {
    position: absolute;
    bottom: 1rem;
    right: 1rem;
    padding: 0.25rem 0.75rem;
    border-radius: 0.5rem;
    font-size: 0.75rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.events-card-badge-level--expert {
    background: #f97316;
    color: #341100;
}

.events-card-badge-level--all {
    background: #3c4a5e;
    color: #233144;
}

.events-card-badge-level--pro {
    background: #dc2626;
    color: #ffffff;
}

.events-card-badge-level--free {
    background: #10b981;
    color: #ffffff;
}

/* Corps de la carte */
.events-card-body {
    padding: 2rem;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.events-card-title {
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-size: 1.25rem;
    font-weight: 700;
    color: #dce2f6;
    margin-bottom: 1rem;
    line-height: 1.25;
    transition: color 0.2s ease;
}

.events-card:hover .events-card-title {
    color: #ffb690;
}

.events-card-info {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-bottom: 2rem;
}

.events-card-info-row {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    color: #b9c7e0;
}

.events-card-info-row .material-symbols-outlined {
    color: #f97316;
    font-size: 18px;
}

.events-card-info-row span:last-child {
    font-size: 0.875rem;
    font-weight: 500;
}

/* Footer card — avatars + CTA */
.events-card-footer {
    margin-top: auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.events-card-avatars {
    display: flex;
}

.events-card-avatars > * {
    margin-left: -0.75rem;
    width: 2rem;
    height: 2rem;
    border-radius: 9999px;
    border: 2px solid #151b2a;
    overflow: hidden;
    background: #2e3544;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 10px;
    font-weight: 700;
    color: #e0c0b1;
}

.events-card-avatars > *:first-child {
    margin-left: 0;
}

.events-card-avatars img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.events-card-footer-empty {
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: #e0c0b1;
}

/* Empty/fallback grid rounded */
.events-empty {
    border-radius: 1.5rem;
}

/* CTA "Voir D\u00e9tails" sur les cards */
.events-card-cta {
    color: #f97316;
    font-weight: 700;
    font-size: 0.875rem;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    transition: color 0.15s ease;
}

.events-card:hover .events-card-cta {
    color: #ffb690;
}

.events-card-cta .material-symbols-outlined {
    transition: transform 0.2s ease;
    font-size: 18px;
}

.events-card:hover .events-card-cta .material-symbols-outlined {
    transform: translateX(4px);
}

/* Breadcrumb events */
.events-breadcrumb {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.75rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: #475569;
    margin-bottom: 1.5rem;
}

.events-breadcrumb a {
    color: #475569;
    transition: color 0.15s ease;
}

.events-breadcrumb a:hover {
    color: #fb923c;
}

.events-breadcrumb .bc-current {
    color: #f97316;
}

/* "J'y vais" action block */
.events-going {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.events-going-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    width: 100%;
    padding: 1rem 1.25rem;
    border-radius: 0.75rem;
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-size: 0.875rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    transition: filter 0.15s ease, transform 0.1s ease;
    cursor: pointer;
    border: none;
}

.events-going-btn--join {
    background-image: linear-gradient(135deg, #ffb690 0%, #f97316 100%);
    color: #341100;
    box-shadow: 0 10px 20px rgba(249, 115, 22, 0.15);
}

.events-going-btn--join:hover {
    filter: brightness(1.08);
}

.events-going-btn--leave {
    background: #232a39;
    color: #fca5a5;
    border: 1px solid rgba(239, 68, 68, 0.3);
}

.events-going-btn--leave:hover {
    background: #2e3544;
    color: #fecaca;
}

.events-going-btn:active {
    transform: scale(0.98);
}

.events-going-avatars {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.events-going-avatars .stack {
    display: flex;
}

.events-going-avatars .stack > * {
    margin-left: -0.75rem;
    width: 2rem;
    height: 2rem;
    border-radius: 9999px;
    border: 2px solid #232a39;
    overflow: hidden;
    background: #2e3544;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 10px;
    font-weight: 700;
    color: #e0c0b1;
}

.events-going-avatars .stack > *:first-child {
    margin-left: 0;
}

.events-going-avatars .stack img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* =====================================================
   DRAWERS — z-index explicites
   Les valeurs arbitraires Tailwind z-[120]/z-[130]
   ne sont pas générées dans le build CSS V1.
   ===================================================== */

[data-drawer="events-filters"],
[data-drawer="events-nav"] {
    z-index: 9000;
}

/* Desktop (xl = 1280px+) : le drawer filtre démarre
   sous la navigation (h-20 = 5rem) pour laisser le
   header accessible */
@media (min-width: 1280px) {
    [data-drawer="events-filters"] {
        top: 5rem;
    }
}

@media (max-width: 1279px) {
    .event-hero {
        height: 560px;
    }

    .event-map-hero {
        min-height: 560px;
    }
}

@media (max-width: 767px) {
    .event-hero {
        height: 460px;
    }

    .event-map-hero {
        min-height: 460px;
    }
}

/* ── GP Carousel items ──────────────────────────────────────────────────── */
.gp-carousel-item {
    flex: 0 0 380px;
}
@media (max-width: 1023px) {
    .gp-carousel-item { flex: 0 0 320px; }
}
@media (max-width: 639px) {
    .gp-carousel-item { flex: 0 0 82vw; }
}

/* ── GP Card ────────────────────────────────────────────────────────────── */
.events-card--gp {
    border-color: rgba(249, 115, 22, 0.25);
    box-shadow: 0 0 0 1px rgba(249, 115, 22, 0.10);
}
.events-card--gp:hover {
    border-color: rgba(249, 115, 22, 0.55);
    box-shadow: 0 0 0 1px rgba(249, 115, 22, 0.22), 0 8px 24px rgba(249, 115, 22, 0.10);
}
.events-card-placeholder--gp {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    height: 100%;
    background: linear-gradient(135deg, #0c1321 0%, #130e1e 100%);
}