/* =========================================================
   KesKonFé — Design system v2
   Direction : moderne/épuré, inspiré du mockup 22/06/2026
   - Fond blanc, primaire bleu, accent corail
   - Hero deux colonnes, cards paysage, scroll horizontal
   ========================================================= */

:root {
    --kk-paper:      #FFFFFF;
    --kk-paper-2:    #F8FAFF;
    --kk-ink:        #1A1A2E;
    --kk-ink-soft:   #6B7280;
    --kk-primary:    #1D6EF5;
    --kk-primary-dk: #1557C8;
    --kk-primary-lt: #EEF4FF;
    --kk-accent:     #FF6448;
    --kk-poppy:      #FF6448;
    --kk-marigold:   #F59E0B;
    --kk-meadow:     #10B981;
    --kk-sky:        #1D6EF5;
    --kk-line:       #E5E7EB;
    --kk-line-light: #F3F4F6;

    --kk-radius:    16px;
    --kk-radius-sm: 10px;
    --kk-radius-xs: 6px;
    --kk-shadow:    0 4px 20px rgba(29,110,245,.07);
    --kk-shadow-lg: 0 8px 40px rgba(29,110,245,.12);

    --font-display: 'Baloo 2', system-ui, sans-serif;
    --font-body:    'Inter', system-ui, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
    margin: 0;
    font-family: var(--font-body);
    background: var(--kk-paper);
    color: var(--kk-ink);
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

h1, h2, h3, h4 {
    font-family: var(--font-display);
    line-height: 1.15;
    margin: 0 0 .5em;
    font-weight: 700;
}

.container {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}

.accent { color: var(--kk-primary); }

/* ── Boutons ─────────────────────────────────────────────── */

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-family: var(--font-display);
    font-weight: 600;
    font-size: .95rem;
    padding: 12px 24px;
    border-radius: 999px;
    border: 2px solid transparent;
    cursor: pointer;
    transition: transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
    white-space: nowrap;
}
.btn:hover { transform: translateY(-2px); }

.btn-primary { background: var(--kk-primary); color: #fff; box-shadow: 0 4px 14px rgba(29,110,245,.35); }
.btn-primary:hover { background: var(--kk-primary-dk); }

.btn-accent  { background: var(--kk-accent); color: #fff; box-shadow: 0 4px 14px rgba(255,100,72,.35); }
.btn-accent:hover { background: #e85336; }

.btn-secondary { background: #fff; color: var(--kk-ink); border-color: var(--kk-line); }
.btn-secondary:hover { border-color: var(--kk-primary); color: var(--kk-primary); }

.btn-outline { background: transparent; border-color: currentColor; }
.btn-sm      { padding: 8px 16px; font-size: .825rem; }
.btn-block   { width: 100%; }
.btn-danger  { background: #DC2626; color: #fff; }

/* ── Liseré (signature, très discret) ───────────────────── */

.guirlande {
    height: 4px;
    width: 100%;
    background: linear-gradient(90deg,
        var(--kk-primary) 0%, var(--kk-accent) 33%,
        var(--kk-marigold) 66%, var(--kk-meadow) 100%);
}

/* ── En-tête ─────────────────────────────────────────────── */

.site-header {
    background: #fff;
    border-bottom: 1px solid var(--kk-line);
    position: sticky;
    top: 0;
    z-index: 50;
}
.site-header .container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 14px;
    padding-bottom: 14px;
    gap: 16px;
}
.logo {
    font-family: var(--font-display);
    font-size: 1.55rem;
    font-weight: 800;
    color: var(--kk-ink);
    display: flex;
    align-items: center;
    gap: 6px;
}
.logo .dot { color: var(--kk-primary); }

.main-nav {
    display: flex;
    align-items: center;
    gap: 16px;
    font-size: .875rem;
    font-weight: 500;
    white-space: nowrap;
}
.main-nav a { color: var(--kk-ink-soft); }
.main-nav a:hover, .main-nav a.active { color: var(--kk-primary); }
.main-nav .nav-cta { margin-left: 4px; }

/* User dropdown */
.nav-user-menu { position: relative; }
.nav-user-btn {
    background: none;
    border: 1.5px solid var(--kk-line);
    border-radius: 999px;
    padding: 7px 14px;
    font-size: .875rem;
    font-weight: 600;
    color: var(--kk-ink);
    cursor: pointer;
    white-space: nowrap;
}
.nav-user-btn:hover { border-color: var(--kk-primary); color: var(--kk-primary); }
.nav-user-dropdown {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    background: #fff;
    border: 1.5px solid var(--kk-line);
    border-radius: var(--kk-radius-sm);
    box-shadow: var(--kk-shadow-lg);
    min-width: 160px;
    padding: 6px 0;
    z-index: 100;
    display: none;
}
.nav-user-dropdown.open { display: block; }
.nav-user-dropdown a {
    display: block;
    padding: 9px 16px;
    font-size: .875rem;
    color: var(--kk-ink);
}
.nav-user-dropdown a:hover { background: var(--kk-paper-2); color: var(--kk-primary); }

.nav-toggle {
    display: none;
    background: none;
    border: none;
    font-size: 1.6rem;
    cursor: pointer;
}

@media (max-width: 860px) {
    .main-nav {
        position: fixed;
        inset: 64px 0 0 0;
        background: #fff;
        flex-direction: column;
        align-items: flex-start;
        padding: 24px;
        gap: 18px;
        transform: translateY(-110%);
        transition: transform .25s ease;
        border-top: 1px solid var(--kk-line);
        overflow-y: auto;
        z-index: 49;
    }
    .main-nav.open { transform: translateY(0); }
    .nav-toggle { display: block; }
}

/* ── Hero deux colonnes ──────────────────────────────────── */

.hero {
    padding: 56px 0 48px;
    background: var(--kk-paper-2);
    overflow: hidden;
}
.hero-inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    align-items: center;
}
@media (max-width: 860px) {
    .hero-inner { grid-template-columns: 1fr; }
    .hero-mosaic { display: none; }
}

.hero h1 {
    font-size: clamp(2rem, 4vw, 3.2rem);
    letter-spacing: -.02em;
    margin-bottom: .4em;
}
.hero h1 em { color: var(--kk-primary); font-style: normal; }
.hero .lead {
    color: var(--kk-ink-soft);
    font-size: 1.05rem;
    margin-bottom: 28px;
    line-height: 1.6;
}

/* Barre de recherche hero */
.hero-search {
    background: #fff;
    border-radius: 999px;
    box-shadow: 0 4px 24px rgba(0,0,0,.10);
    display: flex;
    align-items: center;
    padding: 6px 6px 6px 18px;
    gap: 8px;
    margin-bottom: 18px;
}
.hero-search .hs-icon { color: var(--kk-ink-soft); font-size: 1.1rem; flex-shrink: 0; }
.hero-search input {
    flex: 1;
    border: none;
    background: transparent;
    font-family: var(--font-body);
    font-size: .95rem;
    color: var(--kk-ink);
    outline: none;
    min-width: 0;
}
.hero-search input::placeholder { color: var(--kk-ink-soft); }
.hero-search .hs-sep { width: 1px; height: 24px; background: var(--kk-line); flex-shrink: 0; }
.hero-search select {
    border: none;
    background: transparent;
    font-family: var(--font-body);
    font-size: .875rem;
    color: var(--kk-ink);
    cursor: pointer;
    padding: 0 8px;
    outline: none;
    flex-shrink: 0;
}
.hero-search .btn { flex-shrink: 0; }

/* Chips filtres rapides */
.filter-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.filter-chip {
    padding: 7px 16px;
    border-radius: 999px;
    font-size: .83rem;
    font-weight: 600;
    border: 1.5px solid var(--kk-line);
    background: #fff;
    color: var(--kk-ink-soft);
    cursor: pointer;
    transition: all .15s ease;
}
.filter-chip:hover { border-color: var(--kk-primary); color: var(--kk-primary); }
.filter-chip.active { background: var(--kk-primary); color: #fff; border-color: var(--kk-primary); }

/* Mosaïque photos à droite */
.hero-mosaic {
    position: relative;
    height: 420px;
}
.hero-mosaic .tile {
    position: absolute;
    border-radius: 22px;
    background-size: cover;
    background-position: center;
    overflow: hidden;
    box-shadow: 0 8px 24px rgba(0,0,0,.14);
}
.hero-mosaic .tile-1 { top: 0;    left: 30px;  width: 210px; height: 200px; }
.hero-mosaic .tile-2 { top: 0;    right: 0;    width: 210px; height: 260px; border-radius: 80px 22px 22px 22px; }
.hero-mosaic .tile-3 { bottom: 0; left: 0;     width: 190px; height: 220px; border-radius: 22px 22px 22px 80px; }
.hero-mosaic .tile-4 { bottom: 10px; left: 210px; width: 200px; height: 200px; }
.hero-mosaic .blob {
    position: absolute;
    border-radius: 50%;
    z-index: -1;
}
.hero-mosaic .blob-1 { width: 80px; height: 80px; background: var(--kk-primary); bottom: 40px; right: 0; opacity: .7; }
.hero-mosaic .blob-2 { width: 54px; height: 54px; background: var(--kk-marigold); top: 60px; left: 0; opacity: .7; }
.hero-mosaic .blob-3 { width: 40px; height: 40px; background: var(--kk-meadow); top: 200px; right: 220px; opacity: .8; }

/* ── Sections génériques ─────────────────────────────────── */

.section { padding: 52px 0; }
.section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 28px;
    flex-wrap: wrap;
}
.section-head h2 { font-size: 1.55rem; margin: 0; }
.section-head h2 .ico { margin-right: 8px; }
.section-head .see-all {
    font-weight: 700;
    font-size: .875rem;
    color: var(--kk-primary);
    white-space: nowrap;
    display: flex;
    align-items: center;
    gap: 4px;
}
.section-head .see-all:hover { text-decoration: underline; }

/* ── Catégories (scroll horizontal) ─────────────────────── */

.cat-scroll-wrap {
    overflow-x: auto;
    padding-bottom: 8px;
    -ms-overflow-style: none;
    scrollbar-width: none;
}
.cat-scroll-wrap::-webkit-scrollbar { display: none; }

.cat-row {
    display: flex;
    gap: 12px;
    min-width: max-content;
}

.cat-card {
    background: #fff;
    border: 1.5px solid var(--kk-line);
    border-radius: var(--kk-radius);
    padding: 18px 20px;
    text-align: center;
    min-width: 120px;
    transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
    cursor: pointer;
}
.cat-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 20px color-mix(in srgb, var(--cat-color, var(--kk-primary)) 25%, transparent);
    border-color: var(--cat-color, var(--kk-primary));
}
.cat-card .icon {
    font-size: 1.6rem;
    width: 52px; height: 52px;
    margin: 0 auto 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 14px;
    background: color-mix(in srgb, var(--cat-color, var(--kk-primary)) 15%, white);
}
.cat-card .name { font-weight: 700; font-size: .83rem; color: var(--kk-ink); }

/* ── Cartes événement ────────────────────────────────────── */

.event-scroll-wrap {
    overflow-x: auto;
    padding-bottom: 12px;
    -ms-overflow-style: none;
    scrollbar-width: none;
}
.event-scroll-wrap::-webkit-scrollbar { display: none; }

.event-row {
    display: flex;
    gap: 18px;
    min-width: max-content;
}
.event-row .event-card { width: 240px; flex-shrink: 0; }

/* Grid pour la page liste */
.event-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 22px;
}

.event-card {
    background: #fff;
    border: 1.5px solid var(--kk-line);
    border-radius: var(--kk-radius);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: transform .15s ease, box-shadow .15s ease;
}
.event-card:hover { transform: translateY(-4px); box-shadow: var(--kk-shadow-lg); }

/* Photo paysage */
.event-card .thumb {
    aspect-ratio: 16 / 10;
    background-size: cover;
    background-position: center;
    position: relative;
}
.event-card .thumb.no-photo {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.4rem;
    background-image:
        radial-gradient(circle at 30% 25%, rgba(255,255,255,.45), transparent 50%),
        linear-gradient(140deg,
            var(--thumb-color, var(--kk-primary)) 0%,
            color-mix(in srgb, var(--thumb-color, var(--kk-primary)) 65%, #000) 100%);
}

/* Badge catégorie sur la photo */
.badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: .7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    padding: 5px 10px;
    border-radius: 999px;
    background: rgba(255,255,255,.95);
    color: var(--kk-ink);
    backdrop-filter: blur(4px);
}
.badge-overlay {
    position: absolute;
    top: 10px; left: 10px;
    background: var(--badge-color, var(--kk-primary));
    color: #fff;
}

/* Corps de la carte */
.event-card .body {
    padding: 14px 16px 16px;
    display: flex;
    gap: 12px;
    flex: 1;
}
.event-card .date-col {
    flex-shrink: 0;
    width: 44px;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-top: 2px;
}
.event-card .date-col .day {
    font-family: var(--font-display);
    font-size: 1.6rem;
    font-weight: 800;
    line-height: 1;
    color: var(--kk-primary);
}
.event-card .date-col .month {
    font-size: .65rem;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--kk-ink-soft);
    letter-spacing: .05em;
}
.event-card .content-col { flex: 1; min-width: 0; }
.event-card .title {
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 6px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.event-card .meta {
    font-size: .8rem;
    color: var(--kk-ink-soft);
    display: flex;
    flex-direction: column;
    gap: 3px;
}
.event-card .meta span { display: flex; align-items: center; gap: 4px; }
.event-card .distance { color: var(--kk-meadow); font-weight: 700; }

/* ── Carte interactive ────────────────────────────────────── */

.map-shell {
    border-radius: var(--kk-radius);
    overflow: hidden;
    border: 1px solid var(--kk-line);
    box-shadow: var(--kk-shadow);
}
#map, #map-event, #map-picker { height: 420px; width: 100%; background: #EEF4FF; }
#map-event { height: 280px; }
#map-picker { height: 320px; }
.leaflet-popup-content-wrapper { border-radius: 12px; font-family: var(--font-body); }

/* ── CTA organisateur ──────────────────────────────────────── */

.cta-band {
    background: linear-gradient(135deg, var(--kk-ink) 60%, #2a3060);
    color: #fff;
    border-radius: var(--kk-radius);
    padding: 44px 40px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
}
.cta-band h2 { color: #fff; margin-bottom: 6px; }
.cta-band p  { color: rgba(255,255,255,.72); margin: 0; max-width: 460px; }

/* ── Features strip (bas de page accueil) ─────────────────── */

.features-strip {
    background: var(--kk-paper-2);
    border-radius: var(--kk-radius);
    padding: 32px 36px;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 28px;
    margin-top: 52px;
}
.feature-item { display: flex; align-items: flex-start; gap: 14px; }
.feature-item .fi-icon {
    width: 44px; height: 44px; flex-shrink: 0;
    border-radius: 12px;
    background: var(--fi-color, var(--kk-primary-lt));
    color: var(--fi-text, var(--kk-primary));
    display: flex; align-items: center; justify-content: center;
    font-size: 1.3rem;
}
.feature-item .fi-title { font-weight: 700; font-size: .9rem; margin-bottom: 3px; }
.feature-item .fi-desc  { font-size: .8rem; color: var(--kk-ink-soft); }

/* ── Filtres (page liste) ─────────────────────────────────── */

.filters-bar {
    background: #fff;
    border: 1.5px solid var(--kk-line);
    border-radius: var(--kk-radius);
    padding: 16px 18px;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 28px;
    box-shadow: var(--kk-shadow);
}
.filters-bar .field { display: flex; flex-direction: column; gap: 4px; flex: 1 1 150px; }
.filters-bar label { font-size: .72rem; text-transform: uppercase; font-weight: 700; color: var(--kk-ink-soft); }
.filters-bar input, .filters-bar select {
    border: 1px solid var(--kk-line);
    border-radius: var(--kk-radius-sm);
    padding: 10px 11px;
    font-family: var(--font-body);
    background: var(--kk-paper-2);
    font-size: .9rem;
}
.filters-bar input:focus, .filters-bar select:focus {
    outline: none;
    border-color: var(--kk-primary);
}
.filters-bar .field-submit { flex: 0 0 auto; align-self: flex-end; }

.chip-row { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 20px; }
.chip {
    border: 1.5px solid var(--kk-line);
    border-radius: 999px;
    padding: 7px 14px;
    font-size: .83rem;
    font-weight: 600;
    background: #fff;
    color: var(--kk-ink-soft);
}
.chip.active { background: var(--kk-primary); color: #fff; border-color: var(--kk-primary); }

/* Géo banner */
.geo-banner {
    margin-top: 18px;
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}
.geo-banner .btn-secondary { border-color: var(--kk-primary); color: var(--kk-primary); }
.geo-banner .btn-secondary:hover { background: var(--kk-primary); color: #fff; }
.geo-status { font-size: .83rem; color: var(--kk-ink-soft); }

/* ── Empty state & pagination ────────────────────────────── */

.empty-state { text-align: center; padding: 70px 20px; color: var(--kk-ink-soft); }
.empty-state .icon { font-size: 3rem; margin-bottom: 12px; }

.pagination { display: flex; justify-content: center; gap: 8px; margin-top: 34px; }
.pagination a, .pagination span {
    width: 38px; height: 38px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 50%;
    border: 1.5px solid var(--kk-line);
    font-weight: 700;
    background: #fff;
    font-size: .9rem;
}
.pagination a:hover { border-color: var(--kk-primary); color: var(--kk-primary); }
.pagination .current { background: var(--kk-primary); color: #fff; border-color: var(--kk-primary); }

/* ── Fiche événement ─────────────────────────────────────── */

.event-hero {
    border-radius: var(--kk-radius);
    overflow: hidden;
    background: #fff;
    border: 1.5px solid var(--kk-line);
    box-shadow: var(--kk-shadow);
    display: flex;
    align-items: stretch;
}
.event-hero-poster {
    flex: 0 0 260px;
    aspect-ratio: 3 / 4;
    background-size: cover;
    background-position: center;
    position: relative;
}
.event-hero-poster.no-photo {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 4rem;
    background-image:
        radial-gradient(circle at 30% 25%, rgba(255,255,255,.5), transparent 45%),
        linear-gradient(160deg,
            var(--thumb-color, var(--kk-primary)) 0%,
            color-mix(in srgb, var(--thumb-color, var(--kk-primary)) 70%, #000) 100%);
}
.event-hero-poster.js-zoom-poster { cursor: zoom-in; position: relative; }
.zoom-hint {
    position: absolute;
    left: 50%; bottom: 10px;
    transform: translateX(-50%);
    background: rgba(26,26,46,.8);
    color: #fff;
    font-size: .7rem;
    font-weight: 700;
    padding: 5px 11px;
    border-radius: 999px;
    opacity: 0;
    transition: opacity .15s ease;
}
.event-hero-poster.js-zoom-poster:hover .zoom-hint,
.event-hero-poster.js-zoom-poster:focus-visible .zoom-hint { opacity: 1; }

.event-hero-content { padding: 28px 32px; display: flex; flex-direction: column; justify-content: center; }
.event-hero-content h1 { font-size: clamp(1.5rem, 3vw, 2.2rem); }
.event-hero-content .muted { color: var(--kk-ink-soft); }

@media (max-width: 640px) {
    .event-hero { flex-direction: column; }
    .event-hero-poster { flex-basis: auto; aspect-ratio: 16 / 9; }
}

.event-layout {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 32px;
    align-items: start;
    margin-top: 28px;
}
@media (max-width: 880px) { .event-layout { grid-template-columns: 1fr; } }

.info-card {
    background: #fff;
    border: 1.5px solid var(--kk-line);
    border-radius: var(--kk-radius);
    padding: 20px;
    box-shadow: var(--kk-shadow);
}
.info-card + .info-card { margin-top: 16px; }
.info-row { display: flex; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--kk-line-light); }
.info-row:last-child { border-bottom: none; }
.info-row .ic  { font-size: 1.1rem; width: 24px; text-align: center; flex-shrink: 0; }
.info-row .label { font-size: .73rem; text-transform: uppercase; font-weight: 700; color: var(--kk-ink-soft); margin-bottom: 2px; }

/* Partage */
.share-row { display: flex; gap: 10px; flex-wrap: wrap; }
.share-btn {
    width: 42px; height: 42px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.1rem;
    border: none;
    cursor: pointer;
    transition: transform .15s ease, box-shadow .15s ease;
    box-shadow: 0 2px 8px rgba(0,0,0,.12);
}
.share-btn:hover { transform: translateY(-2px); box-shadow: 0 4px 14px rgba(0,0,0,.18); }
.share-fb   { background: #1877F2; }
.share-wa   { background: #25D366; }
.share-fbm  { background: #0084FF; }
.share-ig   { background: linear-gradient(135deg, #f9ce34, #ee2a7b 50%, #6228d7); }
.share-mail { background: var(--kk-ink); }
.share-link { background: var(--kk-line); color: var(--kk-ink); }

/* Lightbox */
.lightbox {
    position: fixed; inset: 0;
    background: rgba(20,22,33,.9);
    display: flex; align-items: center; justify-content: center;
    padding: 30px; z-index: 999;
}
.lightbox[hidden] { display: none; }
.lightbox img { max-width: 90vw; max-height: 88vh; border-radius: 14px; box-shadow: 0 20px 60px rgba(0,0,0,.5); }
.lightbox-close {
    position: absolute; top: 18px; right: 22px;
    width: 42px; height: 42px; border-radius: 50%;
    background: rgba(255,255,255,.18);
    color: #fff; border: none; font-size: 1.3rem; cursor: pointer;
}
.lightbox-close:hover { background: rgba(255,255,255,.3); }

/* ── Formulaires ─────────────────────────────────────────── */

.form-card {
    background: #fff;
    border: 1.5px solid var(--kk-line);
    border-radius: var(--kk-radius);
    padding: 32px;
    max-width: 640px;
    margin: 0 auto;
    box-shadow: var(--kk-shadow);
}
.form-card.wide { max-width: 840px; }
.form-row { margin-bottom: 18px; }
.form-row label { display: block; font-weight: 700; font-size: .875rem; margin-bottom: 6px; }
.form-row .hint { font-size: .76rem; color: var(--kk-ink-soft); margin-top: 4px; }
.form-row input, .form-row select, .form-row textarea {
    width: 100%;
    border: 1.5px solid var(--kk-line);
    border-radius: var(--kk-radius-sm);
    padding: 11px 13px;
    font-family: var(--font-body);
    font-size: .9rem;
    background: var(--kk-paper-2);
    transition: border-color .15s ease;
}
.form-row input:focus, .form-row select:focus, .form-row textarea:focus {
    outline: none;
    border-color: var(--kk-primary);
    background: #fff;
}
.form-row textarea { resize: vertical; min-height: 110px; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 600px) { .form-grid { grid-template-columns: 1fr; } }

.password-field { position: relative; }
.password-field input { padding-right: 44px; }
.js-toggle-password {
    position: absolute; top: 50%; right: 6px;
    transform: translateY(-50%);
    background: none; border: none;
    font-size: 1.1rem; line-height: 1; cursor: pointer; padding: 6px;
}

/* Sélecteur catégorie visuel */
.cat-picker {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 8px;
}
.cat-picker input {
    position: absolute; width: 1px; height: 1px;
    opacity: 0; pointer-events: none;
}
.cat-pick {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 10px;
    padding: 11px 14px;
    border: 1.5px solid var(--kk-line);
    border-radius: var(--kk-radius-sm);
    cursor: pointer;
    font-size: .875rem;
    font-weight: 600;
    color: var(--kk-ink-soft);
    background: var(--kk-paper-2);
    transition: all .15s ease;
    white-space: nowrap;
}
.cat-pick .ic { font-size: 1.35rem; flex-shrink: 0; }
.cat-picker input:checked + .cat-pick {
    border-color: var(--cat-color, var(--kk-primary));
    background: color-mix(in srgb, var(--cat-color, var(--kk-primary)) 12%, white);
    color: var(--kk-ink);
}
.cat-picker input:focus-visible + .cat-pick { outline: 2px solid var(--kk-primary); outline-offset: 2px; }

/* Zone d'exemples dynamiques sous le sélecteur */
.cat-examples {
    margin-top: 10px;
    padding: 10px 14px;
    background: var(--kk-primary-lt);
    border-radius: var(--kk-radius-sm);
    font-size: .8rem;
    color: var(--kk-ink-soft);
    display: none;
}
.cat-examples.visible { display: block; }
.cat-examples strong { color: var(--kk-ink); font-size: .85rem; }
.cat-examples .tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 6px; }
.cat-examples .tag {
    background: #fff;
    border: 1px solid var(--kk-line);
    border-radius: 999px;
    padding: 3px 10px;
    font-size: .75rem;
}

/* Accent dynamique (couleur dominante de l'affiche) */
#publishForm .form-card { border-top: 5px solid var(--kk-form-accent, var(--kk-primary)); transition: border-color .35s ease; }
#publishForm .btn-primary { background: var(--kk-form-accent, var(--kk-primary)); transition: background .35s ease; }
#publishForm .btn-primary:hover { filter: brightness(.92); }

/* Champs obligatoires */
.req { color: var(--kk-accent); font-weight: 700; margin-left: 2px; }
.form-note { font-size: .78rem; color: var(--kk-ink-soft); margin-bottom: 18px; }

/* Compteur de caractères */
#descCounter { font-size: .76rem; font-weight: 600; color: var(--kk-ink-soft); }
#descCounter.warn { color: var(--kk-accent); }

/* Bloc inscription */
.inscription-count {
    display: flex;
    align-items: baseline;
    gap: 6px;
    margin-bottom: 4px;
}
.insc-number {
    font-family: var(--font-display);
    font-size: 2rem;
    font-weight: 800;
    color: var(--kk-primary);
    line-height: 1;
}
.insc-label { font-size: .875rem; color: var(--kk-ink-soft); }

.btn-secondary:disabled { opacity: .55; cursor: not-allowed; transform: none; }
.alert { border-radius: var(--kk-radius-sm); padding: 13px 16px; font-size: .9rem; margin-bottom: 18px; font-weight: 600; }
.alert-error   { background: #FEF2F2; color: #991B1B; border: 1px solid #FCA5A5; }
.alert-success { background: #ECFDF5; color: #065F46; border: 1px solid #6EE7B7; }

/* ── Mon compte / tableau ────────────────────────────────── */

.table-card { background: #fff; border: 1.5px solid var(--kk-line); border-radius: var(--kk-radius); overflow: hidden; box-shadow: var(--kk-shadow); }
table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: 13px 16px; border-bottom: 1px solid var(--kk-line-light); font-size: .875rem; }
th { background: var(--kk-paper-2); font-family: var(--font-display); font-size: .75rem; text-transform: uppercase; letter-spacing: .04em; color: var(--kk-ink-soft); font-weight: 700; }
tr:last-child td { border-bottom: none; }
.status-pill { padding: 4px 10px; border-radius: 999px; font-size: .7rem; font-weight: 700; }
.status-valide    { background: #ECFDF5; color: #065F46; }
.status-en_attente{ background: #FFFBEB; color: #92400E; }
.status-refuse    { background: #FEF2F2; color: #991B1B; }
.action-links { display: flex; gap: 12px; }
.action-links a { font-weight: 700; color: var(--kk-primary); }
.action-links a.danger { color: var(--kk-accent); }

/* ── Pied de page ────────────────────────────────────────── */

.site-footer { background: var(--kk-ink); color: rgba(255,255,255,.72); margin-top: 60px; }
.footer-inner {
    padding: 44px 0 26px;
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr;
    gap: 32px;
}
@media (max-width: 700px) { .footer-inner { grid-template-columns: 1fr; } }
.footer-inner h4 { color: #fff; font-size: .95rem; margin-bottom: 14px; }
.footer-inner .logo { color: #fff; }
.footer-inner ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.footer-inner a:hover { color: #fff; }
.footer-bottom {
    border-top: 1px solid rgba(255,255,255,.12);
    padding: 16px 0 28px;
    font-size: .78rem; text-align: center; color: rgba(255,255,255,.45);
}

/* ── Utilitaires ─────────────────────────────────────────── */

.mt-0 { margin-top: 0; }
.text-center { text-align: center; }
.muted { color: var(--kk-ink-soft); }

/* ── Administration ──────────────────────────────────────── */

.admin-stats {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
    gap: 16px;
    margin: 28px 0;
}
.stat-card {
    background: #fff;
    border: 1.5px solid var(--kk-line);
    border-radius: var(--kk-radius);
    padding: 20px;
    box-shadow: var(--kk-shadow);
}
.stat-card.stat-warn { border-color: #F59E0B; background: #FFFBEB; }
.stat-card.stat-ok   { border-color: #10B981; background: #ECFDF5; }
.stat-card.stat-err  { border-color: #DC2626; background: #FEF2F2; }
.stat-num  { font-family: var(--font-display); font-size: 2.4rem; font-weight: 800; line-height: 1; color: var(--kk-ink); }
.stat-label{ font-size: .8rem; color: var(--kk-ink-soft); margin-top: 4px; }
.stat-link { font-size: .8rem; font-weight: 700; color: var(--kk-primary); display: block; margin-top: 10px; }
.status-en_attente { background: #FFFBEB; color: #92400E; }

/* ── Page Qui sommes-nous ─────────────────────────────────── */

.team-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 24px;
}
.team-card {
    background: #fff;
    border: 1.5px solid var(--kk-line);
    border-radius: var(--kk-radius);
    padding: 28px;
    box-shadow: var(--kk-shadow);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}
.team-photo-placeholder {
    width: 100px; height: 100px;
    border-radius: 50%;
    background: var(--kk-primary-lt);
    display: flex; align-items: center; justify-content: center;
    font-size: 3rem;
    margin-bottom: 16px;
    overflow: hidden;
}
.team-photo-placeholder img { width: 100%; height: 100%; object-fit: cover; }
.team-card h3 { margin: 0 0 4px; }
.team-role { font-size: .8rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--kk-primary); margin-bottom: 12px; }
.team-card p { font-size: .875rem; color: var(--kk-ink-soft); margin: 0; }

/* =========================================================
   KesKonFé — V3 UI homepage
   Objectif : nouveau design sans modification métier.
   ========================================================= */
:root{
  --v3-navy:#071a3d;
  --v3-text:#0b1736;
  --v3-muted:#607089;
  --v3-blue:#246BFE;
  --v3-purple:#8B46F6;
  --v3-red:#FF4E45;
  --v3-orange:#FF9F00;
  --v3-green:#09A766;
  --v3-line:#E7ECF5;
  --v3-card:#FFFFFF;
  --v3-bg:#FBFCFF;
  --v3-shadow:0 18px 45px rgba(18,33,74,.10);
}
html{scroll-behavior:smooth;}
body{background:linear-gradient(180deg,#fff 0%,#fbfdff 48%,#fff 100%); color:var(--v3-text); font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;}
.container{max-width:1220px;margin:0 auto;padding-left:26px;padding-right:26px;}

.v3-header.site-header{position:relative;z-index:1000;background:rgba(255,255,255,.96);backdrop-filter:blur(12px);border-bottom:0;box-shadow:none;}
.v3-header .header-container{height:92px;display:flex;align-items:center;justify-content:space-between;gap:28px;}
.v3-logo{display:inline-flex;align-items:center;text-decoration:none;min-width:380px;}
.v3-logo img{display:block;height:160px;width:auto;max-width:380px;object-fit:contain;}
.v3-header .main-nav{display:flex;align-items:center;gap:26px;font-weight:800;font-size:.94rem;}
.v3-header .main-nav>a:not(.btn), .v3-header .nav-user-btn{color:var(--v3-text);text-decoration:none;white-space:nowrap;}
.v3-header .main-nav>a:first-child{color:var(--v3-purple);position:relative;}
.v3-header .main-nav>a:first-child::after{content:"";position:absolute;left:0;right:0;bottom:-26px;height:3px;border-radius:99px;background:var(--v3-purple);}
.v3-header .admin-link{color:var(--v3-purple)!important;font-weight:800!important;}
.v3-header .nav-user-btn{border:0;background:#fff;border-radius:999px;padding:11px 16px;box-shadow:0 9px 26px rgba(18,33,74,.08);}
.v3-header .nav-cta.btn{background:linear-gradient(135deg,#8B46F6,#7C3AED);box-shadow:0 16px 32px rgba(124,58,237,.24);border-radius:20px;padding:16px 20px;color:#fff;font-weight:900;}
.v3-header .nav-cta.btn:hover{transform:translateY(-2px);}

.v3-hero{position:relative;padding:70px 0 64px;overflow:hidden;background:
  radial-gradient(circle at 68% 12%,rgba(139,70,246,.08),transparent 26%),
  radial-gradient(circle at 18% 55%,rgba(36,107,254,.06),transparent 30%);
}
.v3-hero-grid{display:grid;grid-template-columns:1.02fr .98fr;align-items:center;gap:52px;}
.v3-hero-copy h1{margin:0;font-family:"Baloo 2",Inter,sans-serif;font-size:clamp(3.15rem,6vw,5.95rem);line-height:.94;letter-spacing:-.045em;font-weight:800;color:var(--v3-navy);}
.v3-hero-copy .orange-script,.v3-hero-copy .green-script{font-family:"Baloo 2",Inter,sans-serif;font-style:italic;font-weight:800;letter-spacing:-.035em;}
.v3-hero-copy .orange-script{color:var(--v3-orange);}
.v3-hero-copy .green-script{color:var(--v3-green);}
.v3-hero-copy .comma{color:var(--v3-red);}
.v3-lead{margin:34px 0 0;color:var(--v3-text);font-size:1.2rem;line-height:1.55;font-weight:500;}

.v3-hero-visual{position:relative;height:430px;min-width:0;}
.v3-photo{position:absolute;overflow:hidden;background:#eef4ff;box-shadow:0 18px 44px rgba(18,33,74,.13);transform:translateZ(0);backface-visibility:hidden;isolation:isolate;}
.v3-photo img{width:100%;height:100%;object-fit:cover;display:block;}
.v3-photo-concert{left:44px;top:12px;width:270px;height:205px;border-radius:26px 26px 70px 26px;}
.v3-photo-market{right:40px;top:10px;width:250px;height:238px;border-radius:78px 26px 26px 26px;}
.v3-photo-family{left:40px;bottom:16px;width:265px;height:165px;border-radius:26px 26px 26px 75px;}
.v3-photo-sport{right:74px;bottom:18px;width:220px;height:165px;border-radius:26px 26px 72px 26px;}
.v3-dot{position:absolute;display:block;border-radius:26px;box-shadow:0 16px 34px rgba(18,33,74,.13);}
.v3-dot-purple{left:0;top:22px;width:54px;height:54px;background:linear-gradient(135deg,#6D28D9,#8B46F6);}
.v3-dot-orange{right:0;top:118px;width:54px;height:54px;background:#FFA500;border-radius:50%;}
.v3-dot-red{right:6px;top:270px;width:76px;height:76px;background:#FF4E58;border-radius:26px;}
.v3-dot-green{left:295px;bottom:0;width:42px;height:42px;background:#14B96D;border-radius:14px;}
.v3-confetti{position:absolute;left:-55px;top:178px;font-size:48px;font-weight:900;letter-spacing:-10px;color:#8B46F6;transform:rotate(-8deg);}
.v3-hero-visual::after{content:"";position:absolute;right:22px;top:134px;width:100px;height:130px;background-image:radial-gradient(#CBD5E1 2px,transparent 2px);background-size:16px 16px;opacity:.9;z-index:-1;}

.v3-search-section{margin-top:-36px;position:relative;z-index:10;}
.v3-searchbar{display:grid;grid-template-columns:1.05fr .9fr .9fr auto;align-items:center;gap:0;background:#fff;border:1px solid var(--v3-line);border-radius:30px;box-shadow:var(--v3-shadow);padding:20px 22px;}
.v3-search-cell{display:grid;grid-template-columns:42px 1fr;grid-template-rows:auto auto;column-gap:12px;align-items:center;padding:0 26px;border-right:1px solid var(--v3-line);min-height:56px;}
.v3-search-cell:first-child{padding-left:10px;}
.v3-search-icon{grid-row:1/3;font-size:1.8rem;color:var(--v3-navy);}
.v3-search-label{font-weight:900;color:var(--v3-text);font-size:1rem;}
.v3-searchbar input,.v3-searchbar select{border:0;background:transparent;color:var(--v3-muted);font:600 .95rem Inter,sans-serif;outline:none;min-width:0;width:100%;padding:3px 0;}
.v3-search-button{justify-self:end;border:0;border-radius:999px;padding:22px 34px;background:linear-gradient(135deg,#FF644D,#FF3F3B);color:#fff;font-weight:900;font-size:1.08rem;box-shadow:0 18px 32px rgba(255,78,69,.24);cursor:pointer;transition:.2s ease;white-space:nowrap;}
.v3-search-button:hover{transform:translateY(-2px);filter:saturate(1.08);}

.v3-categories{padding:38px 26px 28px;}
.v3-category-row{display:grid;grid-template-columns:repeat(9,1fr);gap:18px;align-items:start;}
.v3-category{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;text-decoration:none;color:var(--v3-text);font-weight:900;font-size:.98rem;line-height:1.15;}
.v3-category-icon{width:78px;height:78px;border-radius:50%;display:grid;place-items:center;font-size:2rem;background:color-mix(in srgb, var(--cat) 17%, white);color:var(--cat);box-shadow:0 12px 24px rgba(18,33,74,.06);transition:.2s ease;}
.v3-category:hover .v3-category-icon{transform:translateY(-4px) scale(1.04);background:color-mix(in srgb, var(--cat) 24%, white);}

.v3-must-see{padding-top:16px;}
.v3-section-head{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:24px;}
.v3-section-head h2{font-family:"Baloo 2",Inter,sans-serif;font-size:2rem;line-height:1;margin:0;color:var(--v3-navy);font-weight:800;letter-spacing:-.025em;}
.v3-section-head h2 span{color:var(--v3-purple);}
.v3-section-head a{color:var(--v3-purple);font-weight:900;text-decoration:none;}
.v3-event-row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:22px;position:relative;}
.v3-event-card{display:block;background:#fff;border:1px solid var(--v3-line);border-radius:16px;overflow:hidden;text-decoration:none;color:var(--v3-text);box-shadow:0 10px 26px rgba(18,33,74,.07);transition:.2s ease;}
.v3-event-card:hover{transform:translateY(-5px);box-shadow:0 18px 38px rgba(18,33,74,.12);}
.v3-event-image{height:150px;background-size:cover;background-position:center;position:relative;border-radius:16px 16px 0 0;}
.v3-event-badge{position:absolute;left:12px;top:12px;background:var(--badge);color:#fff;border-radius:10px;padding:7px 11px;font-size:.75rem;font-weight:900;box-shadow:0 8px 16px rgba(0,0,0,.16);}
.v3-heart{position:absolute;right:12px;top:9px;color:#fff;font-size:2rem;text-shadow:0 3px 10px rgba(0,0,0,.45);line-height:1;background:none;border:none;cursor:pointer;padding:4px;transition:transform .15s ease;}
.v3-heart:hover{transform:scale(1.15);}
.v3-heart.is-favori{color:#FF4D6D;text-shadow:0 3px 10px rgba(0,0,0,.3);}

.follow-tag{position:absolute;left:12px;bottom:10px;background:rgba(16,185,129,.95);color:#fff;font-size:.7rem;font-weight:800;padding:5px 10px;border-radius:999px;box-shadow:0 4px 12px rgba(0,0,0,.18);}
.v3-event-body{display:grid;grid-template-columns:62px 1fr;gap:12px;padding:18px 14px 18px;min-height:150px;}
.v3-date{height:62px;border-radius:10px;background:color-mix(in srgb, var(--date) 13%, white);display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--date);font-weight:900;line-height:1;}
.v3-date strong{font-size:1.7rem;}
.v3-date span{font-size:.78rem;text-transform:uppercase;margin-top:5px;}
.v3-event-info h3{margin:0 0 8px;font-size:1.01rem;line-height:1.25;color:var(--v3-text);font-weight:900;}
.v3-event-info p{margin:5px 0;color:#536178;font-size:.86rem;font-weight:600;}
.v3-price{display:inline-flex;margin-top:13px;border-radius:9px;background:#FFF3D8;color:#59411A;padding:7px 10px;font-size:.78rem;font-weight:900;}
.v3-map-section{padding:38px 26px 70px;}
.v3-map-shell{border-radius:18px;overflow:hidden;box-shadow:0 16px 40px rgba(18,33,74,.13);border:1px solid var(--v3-line);position:relative;z-index:1;}
.v3-map-shell #map{height:420px;width:100%;}
.leaflet-container{z-index:1;}

/* Petits ajustements des pages internes pour rester cohérent V3 */
.btn-primary,.btn-accent{border-radius:999px;}
.event-card,.card,.form-card{border-radius:22px;}

@media (max-width:1100px){
  .v3-header .main-nav{gap:16px;font-size:.88rem;}
  .v3-logo{min-width:205px}.v3-logo img{height:56px;max-width:205px;}
  .v3-hero-grid{gap:26px;grid-template-columns:1fr .92fr;}
  .v3-hero-visual{transform:scale(.9);transform-origin:center right;}
  .v3-category-row{grid-template-columns:repeat(5,1fr);}
  .v3-event-row{grid-template-columns:repeat(3,1fr);}
}
@media (max-width:860px){
  .v3-header .header-container{height:78px;}
  .v3-logo img{height:54px;}
  .nav-toggle{display:block;}
  .v3-header .main-nav{display:none;position:absolute;top:78px;left:16px;right:16px;background:#fff;border:1px solid var(--v3-line);border-radius:24px;padding:18px;box-shadow:var(--v3-shadow);flex-direction:column;align-items:stretch;}
  .v3-header .main-nav.open{display:flex;}
  .v3-header .main-nav>a:first-child::after{display:none;}
  .v3-hero{padding-top:36px;}
  .v3-hero-grid{grid-template-columns:1fr;}
  .v3-hero-visual{height:330px;transform:none;max-width:560px;margin:0 auto;width:100%;}
  .v3-photo-concert{left:8%;top:0;width:42%;height:42%;}
  .v3-photo-market{right:6%;top:0;width:42%;height:48%;}
  .v3-photo-family{left:8%;bottom:0;width:42%;height:38%;}
  .v3-photo-sport{right:8%;bottom:0;width:38%;height:38%;}
  .v3-searchbar{grid-template-columns:1fr;gap:12px;border-radius:24px;}
  .v3-search-cell{border-right:0;border-bottom:1px solid var(--v3-line);padding:10px 4px 16px;}
  .v3-search-button{width:100%;justify-self:stretch;}
  .v3-category-row{grid-template-columns:repeat(3,1fr);}
  .v3-event-row{display:flex;overflow-x:auto;padding-bottom:14px;scroll-snap-type:x mandatory;}
  .v3-event-card{min-width:250px;scroll-snap-align:start;}
}
@media (max-width:560px){
  .container{padding-left:18px;padding-right:18px;}
  .v3-hero-copy h1{font-size:3.25rem;}
  .v3-lead{font-size:1rem;}
  .v3-category-row{grid-template-columns:repeat(2,1fr);}
  .v3-map-shell #map{height:330px;}
}

/* =========================================================
   KesKonFé — Correctif V3.1
   Objectifs : accueil plus équilibré, visuel hero propre,
   événements plus compacts, aucune modification métier.
   ========================================================= */

.v3-hero{
  padding:48px 0 48px;
  background:
    radial-gradient(circle at 72% 18%,rgba(139,70,246,.06),transparent 27%),
    radial-gradient(circle at 18% 62%,rgba(36,107,254,.045),transparent 34%),
    linear-gradient(180deg,#fff 0%,#fbfdff 100%);
}

/* Réduction globale de 10% du bloc hero (titre + mosaïque photo) pour que
   la barre de recherche reste visible sans avoir à scroller. Le zoom CSS
   recalcule réellement la mise en page (contrairement à transform:scale qui
   laisserait un vide), donc rien d'autre n'a besoin d'être modifié. */
.v3-hero{ zoom: 0.9; }

.v3-hero-grid{
  grid-template-columns:minmax(0,0.94fr) minmax(440px,0.96fr);
  gap:44px;
  align-items:center;
}

.v3-hero-copy h1{
  font-size:clamp(2.65rem,4.45vw,4.35rem);
  line-height:1.04;
  letter-spacing:-.035em;
  max-width:560px;
}

.v3-hero-copy .orange-script,
.v3-hero-copy .green-script{
  font-weight:800;
  text-shadow:none;
}
.v3-hero-copy .orange-script{color:#F59E0B;}
.v3-hero-copy .green-script{color:#159A61;}
.v3-hero-copy .comma{color:#FF6B4A;}

.v3-lead{
  margin-top:26px;
  font-size:1.04rem;
  line-height:1.55;
  color:#31415A;
  max-width:520px;
}

/* Le visuel de droite passe en vraie grille : plus de superposition rafistolée */
.v3-hero-visual{
  position:relative;
  display:grid;
  grid-template-columns:1.06fr .94fr;
  grid-template-rows:1fr .82fr;
  gap:16px;
  height:auto;
  min-height:0;
  max-width:590px;
  margin-left:auto;
  padding:10px 42px 12px 12px;
}
.v3-photo{
  position:relative;
  left:auto!important;
  right:auto!important;
  top:auto!important;
  bottom:auto!important;
  width:100%!important;
  height:100%!important;
  min-height:0;
  box-shadow:0 14px 32px rgba(18,33,74,.12);
}
.v3-photo-concert{
  grid-column:1;
  grid-row:1;
  aspect-ratio:1.28/1;
  border-radius:26px 26px 62px 26px;
}
.v3-photo-market{
  grid-column:2;
  grid-row:1;
  aspect-ratio:1/1.03;
  border-radius:64px 24px 24px 24px;
}
.v3-photo-family{
  grid-column:1;
  grid-row:2;
  aspect-ratio:1.55/1;
  border-radius:24px 24px 24px 62px;
}
.v3-photo-sport{
  grid-column:2;
  grid-row:2;
  aspect-ratio:1.28/1;
  border-radius:24px 24px 62px 24px;
}
.v3-dot{z-index:3;}
.v3-dot-purple{left:-8px;top:18px;width:46px;height:46px;border-radius:16px;}
.v3-dot-orange{right:0;top:104px;width:44px;height:44px;}
.v3-dot-red{right:2px;top:244px;width:62px;height:62px;border-radius:22px;}
.v3-dot-green{left:auto;right:210px;bottom:0;width:36px;height:36px;border-radius:12px;}
.v3-confetti{
  left:-56px;
  top:175px;
  font-size:36px;
  opacity:.9;
}
.v3-hero-visual::after{
  right:42px;
  top:92px;
  width:92px;
  height:118px;
  opacity:.75;
}

.v3-search-section{margin-top:-22px;}
.v3-searchbar{
  border-radius:28px;
  padding:17px 20px;
  box-shadow:0 16px 36px rgba(18,33,74,.10);
}
.v3-search-cell{min-height:50px;}
.v3-search-button{padding:18px 30px;font-size:1rem;}

.v3-categories{padding-top:34px;padding-bottom:22px;}
.v3-category-row{gap:14px;}
.v3-category-icon{width:70px;height:70px;font-size:1.85rem;}
.v3-category{font-size:.9rem;}

.v3-must-see{padding-top:10px;}
.v3-section-head{margin-bottom:18px;}
.v3-section-head h2{font-size:1.72rem;}

/* Cartes événements plus petites et plus stables */
.v3-event-row{
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:16px;
}
.v3-event-card{
  border-radius:14px;
  box-shadow:0 8px 20px rgba(18,33,74,.06);
  min-width:0;
}
.v3-event-card:hover{transform:translateY(-3px);}
.v3-event-image{
  height:122px;
  border-radius:14px 14px 0 0;
}
.v3-event-badge{
  left:9px;
  top:9px;
  border-radius:9px;
  padding:5px 8px;
  font-size:.65rem;
  max-width:calc(100% - 48px);
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.v3-heart{right:9px;top:5px;font-size:1.65rem;}
.v3-event-body{
  grid-template-columns:50px 1fr;
  gap:10px;
  padding:12px 11px 14px;
  min-height:126px;
}
.v3-date{height:50px;border-radius:9px;}
.v3-date strong{font-size:1.38rem;}
.v3-date span{font-size:.66rem;margin-top:3px;}
.v3-event-info{min-width:0;}
.v3-event-info h3{
  font-size:.88rem;
  line-height:1.22;
  margin-bottom:6px;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.v3-event-info p{
  margin:4px 0;
  font-size:.74rem;
  line-height:1.25;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.v3-price{
  margin-top:8px;
  padding:5px 8px;
  border-radius:8px;
  font-size:.68rem;
}

.v3-map-section{padding-top:34px;}
.v3-map-shell{border-radius:18px;}
.v3-map-shell #map{height:390px;}

@media (max-width:1100px){
  .v3-hero-grid{grid-template-columns:1fr;gap:28px;}
  .v3-hero-visual{margin:0 auto;transform:none;max-width:640px;width:100%;}
  .v3-event-row{grid-template-columns:repeat(3,minmax(0,1fr));}
}

@media (max-width:860px){
  .v3-hero{padding-top:34px;}
  .v3-hero-copy h1{font-size:clamp(2.35rem,11vw,3.6rem);}
  .v3-hero-visual{
    max-width:560px;
    padding:8px 34px 10px 10px;
    gap:12px;
  }
  .v3-dot-orange{top:88px;}
  .v3-dot-red{top:auto;bottom:48px;}
  .v3-search-section{margin-top:-10px;}
  .v3-event-row{display:flex;overflow-x:auto;gap:14px;}
  .v3-event-card{min-width:210px;max-width:210px;}
  .v3-event-image{height:118px;}
}

@media (max-width:560px){
  .v3-hero-copy h1{font-size:2.55rem;}
  .v3-lead{font-size:.96rem;}
  .v3-hero-visual{display:none;}
  .v3-searchbar{padding:16px;border-radius:22px;}
  .v3-category-icon{width:64px;height:64px;font-size:1.65rem;}
  .v3-event-card{min-width:205px;max-width:205px;}
  .v3-map-shell #map{height:320px;}
}

/* =========================================================
   KesKonFé — Correctif V3.2 final
   - ballon du hero sport remplacé par un visuel net
   - images par défaut des événements en format affiche/portrait
   - affichage des affiches sans recadrage violent
   ========================================================= */

.v3-photo-sport img{
  object-position:center center;
}

.v3-event-image{
  height:136px;
  background-repeat:no-repeat;
  background-position:center;
}

.v3-event-image-photo{
  background-size:cover;
}

.v3-event-image-fallback{
  background-size:contain;
  background-color:#F8FAFC;
  background-position:center center;
}

.v3-event-image-fallback::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(15,23,42,.02));
  pointer-events:none;
}

.v3-event-card{
  min-height:0;
}

.v3-event-body{
  min-height:118px;
}

@media (max-width:860px){
  .v3-event-image{height:132px;}
}

/* =========================================================
   KesKonFé — Correctif V3.3
   - retour des images par défaut en photo paysage
   - photo sport du hero remise en style photo
   ========================================================= */
.v3-photo-sport img{
  object-fit:cover;
  object-position:center center;
}

.v3-event-image,
.v3-event-image-photo,
.v3-event-image-fallback{
  height:122px;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  background-color:#F8FAFC;
}

.v3-event-image-fallback::before{
  display:none;
}

@media (max-width:860px){
  .v3-event-image,
  .v3-event-image-photo,
  .v3-event-image-fallback{height:118px;}
}


/* =========================================================
   KesKonFé — Correctif V3.4
   - toutes les images par défaut des événements repassent en format affiche/portrait
   - les vraies photos des organisateurs restent en photo paysage/cover
   ========================================================= */
.v3-event-image-photo{
  height:122px;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  background-color:#F8FAFC;
}

.v3-event-image-fallback{
  height:122px;
  background-size:contain;
  background-position:center top;
  background-repeat:no-repeat;
  background-color:#F8FAFC;
}

.v3-event-image-fallback::before{
  display:none !important;
}

@media (max-width:860px){
  .v3-event-image-photo,
  .v3-event-image-fallback{height:118px;}
}


/* =========================================================
   KesKonFé — Correctif V3.5 final
   - images organisateur : conservées en photo classique
   - absence de photo : vraie photo portrait par catégorie
   - suppression de l'effet "fiche/affiche générique"
   ========================================================= */
.v3-event-image-photo{
  height:122px;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  background-color:#F8FAFC;
}

.v3-event-image-fallback{
  height:136px;
  background-size:contain;
  background-position:center center;
  background-repeat:no-repeat;
  background-color:#F8FAFC;
}

.v3-event-image-fallback::before{
  display:none !important;
}

@media (max-width:860px){
  .v3-event-image-photo{height:118px;}
  .v3-event-image-fallback{height:132px;}
}

/* ── Profil organisateur ──────────────────────────────────── */

.org-profile-header {
    display: flex;
    align-items: center;
    gap: 22px;
    padding-bottom: 32px;
    border-bottom: 1px solid var(--kk-line);
}
.org-avatar {
    width: 84px;
    height: 84px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--kk-primary), var(--kk-accent));
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-display);
    font-size: 2.1rem;
    font-weight: 800;
    flex-shrink: 0;
    box-shadow: 0 8px 22px rgba(29,110,245,.25);
}
@media (max-width: 600px) {
    .org-profile-header { gap: 14px; }
    .org-avatar { width: 64px; height: 64px; font-size: 1.6rem; }
}

/* ── Images portrait en entier (contain) ─────────────────────────────────── */
/* Les cartes événement affichent l'affiche complète sans recadrage.
   Un fond légèrement teinté (var(--thumb-bg)) complète les bords vides. */

.event-card .thumb,
.v3-event-image {
    background-size: contain !important;
    background-repeat: no-repeat !important;
    background-color: #F0F2F8;
}
/* Quand une vraie photo d'organisateur est uploadée : on affiche quand même en contain
   pour respecter le format portrait de l'affiche. */
.v3-event-image-photo {
    background-size: contain !important;
    background-color: #F0F2F8 !important;
}

/* ── Liste événements : grille 2 colonnes, photo portrait gauche ─────────── */

.ev-list-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 18px;
}
@media (max-width: 768px) {
    .ev-list-grid { grid-template-columns: 1fr; }
}

.ev-list-card {
    display: flex;
    align-items: stretch;
    background: #fff;
    border: 1.5px solid var(--kk-line);
    border-radius: var(--kk-radius);
    overflow: hidden;
    box-shadow: var(--kk-shadow);
    transition: transform .15s ease, box-shadow .15s ease;
    min-height: 160px;
}
.ev-list-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--kk-shadow-lg);
}

/* Photo portrait (gauche) */
.ev-list-photo {
    flex-shrink: 0;
    width: 130px;
    min-width: 130px;
    min-height: 160px;
    position: relative;
    background-color: #EDF0F8;
    overflow: hidden;
    /* align-self:stretch (défaut flex) → hauteur = hauteur de la colonne droite */
}
.ev-list-photo img {
    /* Remplit exactement le conteneur sans dépasser */
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center;
    display: block;
}
.ev-list-photo .badge-overlay { font-size: .6rem; padding: 3px 7px; }
.ev-list-photo .v3-heart     { font-size: 1.3rem; right: 6px; top: 5px; }

/* Infos droite */
.ev-list-body {
    flex: 1;
    padding: 14px 16px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 0;
}
.ev-list-date {
    display: inline-flex;
    align-items: baseline;
    gap: 5px;
    background: color-mix(in srgb, var(--date, var(--kk-primary)) 14%, white);
    color: var(--date, var(--kk-primary));
    border-radius: 8px;
    padding: 4px 10px;
    align-self: flex-start;
}
.ev-list-date strong { font-family: var(--font-display); font-size: 1.2rem; font-weight: 800; line-height: 1; }
.ev-list-date span   { font-size: .65rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; }

.ev-list-title {
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 700;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.25;
}
.ev-list-meta {
    display: flex;
    flex-direction: column;
    gap: 3px;
    font-size: .8rem;
    color: var(--kk-ink-soft);
    margin-top: auto;
}
.ev-list-meta .distance { color: var(--kk-meadow); font-weight: 700; }