/* ============================================================
   LIBERTA MAP v2 — Design unifié avec la homepage
   ============================================================ */

:root {
    --lm-green:      #2d6a4f;
    --lm-green-l:    #52b788;
    --lm-green-bg:   #eef6ee;
    --lm-green-bd:   #b7d9c3;
    --lm-dark:       #1a2e1a;
    --lm-text:       #2c2416;
    --lm-muted:      #6b7c5a;
    --lm-light:      #f5efe0;
    --lm-border:     #ddd0b8;
    --lm-white:      #ffffff;
    --lm-cream:      #fdf6e3;
    --lm-earth:      #8b5e3c;
    --lm-honey:      #c9973a;
    --lm-radius:     10px;
    --lm-orange:     #d97706;
    --lm-red:        #dc2626;
    --lm-blue:       #2563eb;
}

/* ============================================================
   CARTE PRINCIPALE
   ============================================================ */

#liberta-map-wrap { width: 100%; font-family: inherit; }

/* ── En-tête page carte ── */
.lm-carte-header {
    background: linear-gradient(135deg, #1a2e1a 0%, #2a4a1a 60%, #1a2e1a 100%);
    border-radius: 16px 16px 0 0;
    padding: 28px 28px 20px;
    margin-bottom: 0;
}

.lm-carte-header-content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 16px;
}

.lm-carte-title {
    font-size: 24px !important;
    font-weight: 800 !important;
    color: #fff !important;
    margin: 0 0 4px !important;
    letter-spacing: -0.3px;
}

.lm-carte-sub {
    font-size: 14px;
    color: rgba(255,255,255,0.65);
    margin: 0;
}

.lm-carte-stats {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-shrink: 0;
}

.lm-carte-stat {
    text-align: center;
    color: #fff;
}

.lm-carte-stat span {
    display: block;
    font-size: 22px;
    font-weight: 800;
    color: #4ade80;
    line-height: 1;
}

.lm-carte-stat { font-size: 11px; color: rgba(255,255,255,0.6); text-transform: uppercase; letter-spacing: 0.5px; }

.lm-carte-stat-sep {
    width: 1px;
    height: 36px;
    background: rgba(255,255,255,0.15);
}

/* ── Wrapper filtres ── */
.lm-filters-wrap {
    background: #fff;
    border: 1px solid #ddd0b8;
    border-top: none;
    padding: 14px 16px 10px;
}

#liberta-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    margin: 0;
    padding: 0;
}

/* ── Filtre "Tous" ── */
.liberta-filter {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 6px 12px;
    border: 1.5px solid var(--lm-border);
    border-radius: 100px;
    background: var(--lm-white);
    cursor: pointer;
    font-size: 12px;
    font-weight: 600;
    color: var(--lm-text);
    transition: all 0.15s;
    user-select: none;
    white-space: nowrap;
}

.liberta-filter:not(.lm-filter-colored):hover {
    border-color: var(--lm-green);
    color: var(--lm-green);
    background: var(--lm-green-bg);
}

.liberta-filter:not(.lm-filter-colored).active {
    background: #1a2e1a;
    border-color: #1a2e1a;
    color: #fff;
}

/* ── Filtres colorés (catégories) ── */
.lm-filter-colored {
    background: var(--fb, #f5efe0);
    border-color: color-mix(in srgb, var(--fc, #6b7c5a) 40%, transparent);
    color: var(--fc, #6b7c5a);
}

.lm-filter-colored:hover {
    background: var(--fc, #6b7c5a) !important;
    border-color: var(--fc, #6b7c5a) !important;
    color: #fff !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px color-mix(in srgb, var(--fc) 30%, transparent);
}

.lm-filter-colored.active {
    background: var(--fc, #6b7c5a) !important;
    border-color: var(--fc, #6b7c5a) !important;
    color: #fff !important;
    box-shadow: 0 2px 8px color-mix(in srgb, var(--fc) 35%, transparent);
}

.lm-filter-emoji { font-size: 14px; line-height: 1; }
.lm-filter-label { line-height: 1; }

/* ── Cadre carte + bouton ── */
.lm-map-frame {
    border: 1px solid #ddd0b8;
    border-top: none;
    overflow: hidden;
}

#liberta-map {
    width: 100%;
    border-radius: 0;
    box-shadow: none;
    z-index: 1;
}

.lm-map-actions {
    background: #f5efe0;
    border: 1px solid #ddd0b8;
    border-top: none;
    border-radius: 0 0 16px 16px;
    padding: 14px 20px;
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.lm-add-btn {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 10px 20px;
    background: #2d6a4f;
    color: #fff !important;
    border: none;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    text-decoration: none !important;
    transition: background 0.15s, transform 0.12s;
}

.lm-add-btn:hover {
    background: #15803d;
    transform: translateY(-1px);
    color: #fff !important;
}

.lm-add-btn-outline {
    background: transparent;
    color: #2d6a4f !important;
    border: 1.5px solid #2d6a4f;
}

.lm-add-btn-outline:hover {
    background: #eef6ee;
    transform: translateY(-1px);
}

/* ── Responsive ── */
@media (max-width: 768px) {
    .lm-carte-header { padding: 20px 16px 16px; border-radius: 12px 12px 0 0; }
    .lm-carte-title  { font-size: 20px !important; }
    .lm-carte-stats  { gap: 12px; }
    .lm-carte-stat span { font-size: 18px; }
    .lm-filters-wrap { padding: 10px 12px 8px; }
    .lm-map-actions  { border-radius: 0 0 12px 12px; padding: 12px 14px; }
}

@media (max-width: 480px) {
    .lm-carte-header-content { flex-direction: column; align-items: flex-start; }
    .lm-carte-stats  { gap: 10px; }
    .liberta-filter  { font-size: 11px; padding: 5px 9px; }
    .lm-filter-emoji { font-size: 12px; }
}

.liberta-sub-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 12px;
    padding-left: 8px;
    border-left: 2px solid var(--lm-green-bd);
}

.liberta-sub-filter {
    padding: 4px 12px;
    border: 1px solid var(--lm-green-bd);
    border-radius: 100px;
    background: var(--lm-green-bg);
    cursor: pointer;
    font-size: 12px;
    font-weight: 500;
    color: var(--lm-green);
    transition: all 0.18s;
}

.liberta-sub-filter:hover,
.liberta-sub-filter.active {
    background: var(--lm-green);
    border-color: var(--lm-green);
    color: #fff;
}

/* ============================================================
   MARKERS
   ============================================================ */

.liberta-pin {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.28);
    border: 2.5px solid rgba(255,255,255,0.95);
    position: relative;
}

/* Triangle pointant vers le bas — couleur via --lp-color injecté en inline style */
.liberta-pin::after {
    content: '';
    position: absolute;
    bottom: -9px;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 10px solid var(--lp-color, #27ae60);
    filter: drop-shadow(0 2px 2px rgba(0,0,0,0.18));
}

.liberta-pin-inner { display: block; line-height: 1; }

/* ============================================================
   POPUP CARTE
   ============================================================ */

.liberta-popup {
    max-width: 280px;
    font-family: inherit;
}

.liberta-popup img {
    width: 100%;
    height: 130px;
    object-fit: cover;
    border-radius: 8px;
    margin-bottom: 10px;
}

.liberta-popup h4 {
    margin: 0 0 6px;
    font-size: 15px;
    font-weight: 700;
    color: var(--lm-dark);
}

.liberta-popup p {
    margin: 3px 0;
    font-size: 13px;
    color: var(--lm-muted);
    line-height: 1.5;
}

.liberta-cat-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-bottom: 8px;
}

.liberta-cat-badge {
    display: inline-block;
    padding: 2px 8px;
    background: var(--lm-green-bg);
    color: var(--lm-green);
    border-radius: 100px;
    font-size: 11px;
    font-weight: 600;
}

.liberta-popup-stars { color: var(--lm-orange); font-size: 13px; }

.liberta-popup-actions {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-top: 12px;
}

.liberta-popup-btn {
    display: block;
    padding: 9px 14px;
    background: var(--lm-green);
    color: #fff !important;
    text-align: center;
    border-radius: 8px;
    text-decoration: none !important;
    font-size: 13px;
    font-weight: 700;
    transition: background 0.18s;
    border: none;
}

.liberta-popup-btn:hover { background: #15803d; }

.liberta-popup-btn-secondary {
    display: block;
    padding: 8px 14px;
    background: var(--lm-white);
    color: var(--lm-green) !important;
    border: 1.5px solid var(--lm-green-bd);
    text-align: center;
    border-radius: 8px;
    text-decoration: none !important;
    font-size: 13px;
    font-weight: 600;
    transition: all 0.18s;
}

.liberta-popup-btn-secondary:hover {
    background: var(--lm-green-bg);
    border-color: var(--lm-green);
}

.liberta-pay-icons { font-size: 15px; letter-spacing: 2px; margin: 4px 0; }

/* ============================================================
   BOUTON AJOUTER UN LIEU / BOUTONS PLUGIN
   ============================================================ */

#liberta-add-btn,
.liberta-btn-primary {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px;
    background: var(--lm-green);
    color: #fff !important;
    border: none;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    text-decoration: none !important;
    transition: background 0.18s, transform 0.15s;
    margin-top: 12px;
}

#liberta-add-btn:hover,
.liberta-btn-primary:hover {
    background: #15803d;
    transform: translateY(-1px);
    color: #fff !important;
}

.liberta-btn-secondary {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 9px 18px;
    background: var(--lm-white);
    color: var(--lm-text) !important;
    border: 1.5px solid var(--lm-border);
    border-radius: 8px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none !important;
    transition: all 0.18s;
}

.liberta-btn-secondary:hover {
    border-color: var(--lm-green);
    color: var(--lm-green) !important;
    background: var(--lm-green-bg);
}

.liberta-btn-register {
    display: inline-flex;
    align-items: center;
    padding: 11px 22px;
    background: var(--lm-green);
    color: #fff !important;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 700;
    text-decoration: none !important;
    transition: background 0.18s;
}

.liberta-btn-register:hover { background: #15803d; color: #fff !important; }

/* ============================================================
   FORMULAIRE AJOUT LIEU
   ============================================================ */

#liberta-form-wrap {
    background: var(--lm-white);
    border: 1px solid var(--lm-border);
    border-radius: var(--lm-radius);
    padding: 28px;
    margin-top: 16px;
    box-shadow: 0 4px 24px rgba(0,0,0,0.07);
}

/* Étapes */
.liberta-steps-indicator {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-bottom: 24px;
}

.liberta-step-dot {
    padding: 6px 14px;
    border-radius: 100px;
    font-size: 12px;
    font-weight: 700;
    background: var(--lm-light);
    color: var(--lm-muted);
    border: 1.5px solid var(--lm-border);
    transition: all 0.2s;
    cursor: default;
}

.liberta-step-dot.active {
    background: var(--lm-green);
    color: #fff;
    border-color: var(--lm-green);
}

.liberta-step-dot.done {
    background: var(--lm-green-bg);
    color: var(--lm-green);
    border-color: var(--lm-green-bd);
}

.liberta-form-step { display: none; }
.liberta-form-step.active { display: block; }

/* Champs */
.liberta-form-field {
    margin-bottom: 18px;
}

.liberta-form-field label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--lm-text);
    margin-bottom: 6px;
}

.liberta-form-field input[type="text"],
.liberta-form-field input[type="email"],
.liberta-form-field input[type="password"],
.liberta-form-field input[type="tel"],
.liberta-form-field input[type="url"],
.liberta-form-field input[type="number"],
.liberta-form-field textarea,
.liberta-form-field select {
    width: 100%;
    padding: 10px 14px;
    border: 1.5px solid var(--lm-border);
    border-radius: 8px;
    font-size: 14px;
    color: var(--lm-text);
    background: var(--lm-white);
    transition: border-color 0.18s, box-shadow 0.18s;
    box-sizing: border-box;
    outline: none;
}

.liberta-form-field input:focus,
.liberta-form-field textarea:focus,
.liberta-form-field select:focus {
    border-color: var(--lm-green);
    box-shadow: 0 0 0 3px rgba(22,163,74,0.1);
}

.liberta-form-field textarea { resize: vertical; min-height: 90px; }

.liberta-form-field small {
    display: block;
    font-size: 12px;
    color: var(--lm-muted);
    margin-top: 4px;
}

/* Hint */
.liberta-hint {
    background: #eff6ff;
    border: 1px solid #bfdbfe;
    border-radius: 8px;
    padding: 10px 14px;
    font-size: 13px;
    color: #1d4ed8;
    margin-bottom: 16px;
}

/* Coordonnées */
#liberta-coords-info {
    font-size: 13px;
    color: var(--lm-muted);
    padding: 8px 12px;
    background: var(--lm-light);
    border-radius: 8px;
    margin: 10px 0;
    border: 1px solid var(--lm-border);
}

#liberta-coords-info.has-coords {
    color: var(--lm-green);
    background: var(--lm-green-bg);
    border-color: var(--lm-green-bd);
}

/* Autocomplete */
#liberta-autocomplete {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--lm-white);
    border: 1.5px solid var(--lm-border);
    border-top: none;
    border-radius: 0 0 8px 8px;
    max-height: 200px;
    overflow-y: auto;
    z-index: 9999;
    box-shadow: 0 8px 24px rgba(0,0,0,0.1);
}

.liberta-autocomplete-item {
    padding: 10px 14px;
    cursor: pointer;
    font-size: 13px;
    color: var(--lm-text);
    border-bottom: 1px solid var(--lm-light);
    transition: background 0.15s;
}

.liberta-autocomplete-item:hover { background: var(--lm-green-bg); color: var(--lm-green); }

/* Catégories grille */
.liberta-cat-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    max-height: 300px;
    overflow-y: auto;
    padding-right: 4px;
}

.liberta-cat-item {
    padding: 10px 12px;
    border: 1.5px solid var(--lm-border);
    border-radius: 8px;
    cursor: pointer;
    font-size: 13px;
    text-align: center;
    transition: all 0.18s;
    background: var(--lm-white);
    font-weight: 500;
    color: var(--lm-text);
}

.liberta-cat-item:hover {
    border-color: var(--lm-green);
    background: var(--lm-green-bg);
    color: var(--lm-green);
}

.liberta-cat-item.selected {
    background: var(--lm-green);
    border-color: var(--lm-green);
    color: #fff;
}

.liberta-subcat-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 12px;
    padding: 12px;
    background: var(--lm-light);
    border-radius: 8px;
    border: 1px solid var(--lm-border);
}

.liberta-subcat-item {
    padding: 5px 12px;
    border: 1px solid var(--lm-border);
    border-radius: 100px;
    cursor: pointer;
    font-size: 12px;
    font-weight: 500;
    transition: all 0.18s;
    background: var(--lm-white);
    color: var(--lm-text);
}

.liberta-subcat-item:hover {
    border-color: var(--lm-green);
    color: var(--lm-green);
}

.liberta-subcat-item.selected {
    background: var(--lm-green);
    border-color: var(--lm-green);
    color: #fff;
}

/* Paiements cases à cocher */
.liberta-pay-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
}

.liberta-pay-item,
.liberta-avail-item,
.liberta-delivery-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    border: 1.5px solid var(--lm-border);
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.18s;
    background: var(--lm-white);
    font-size: 13px;
    font-weight: 500;
    color: var(--lm-text);
}

.liberta-pay-item:hover,
.liberta-avail-item:hover,
.liberta-delivery-item:hover {
    border-color: var(--lm-green);
    background: var(--lm-green-bg);
}

.liberta-pay-item.selected,
.liberta-avail-item.selected,
.liberta-delivery-item.selected {
    border-color: var(--lm-green);
    background: var(--lm-green-bg);
    color: var(--lm-green);
    font-weight: 600;
}

/* Slider Ğ1 */
.liberta-g1-slider-wrap {
    background: var(--lm-light);
    border: 1px solid var(--lm-border);
    border-radius: 8px;
    padding: 14px;
    margin-top: 8px;
}

.liberta-g1-slider-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--lm-text);
    margin-bottom: 8px;
}

/* Boutons navigation formulaire */
.liberta-form-buttons {
    display: flex;
    gap: 10px;
    margin-top: 24px;
    padding-top: 20px;
    border-top: 1px solid var(--lm-border);
}

#liberta-submit-btn {
    flex: 1;
    padding: 13px 20px;
    background: var(--lm-green);
    color: #fff !important;
    border: none;
    border-radius: 8px;
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
    transition: background 0.18s;
}

#liberta-submit-btn:hover { background: #15803d; }
#liberta-submit-btn:disabled { opacity: 0.6; cursor: not-allowed; }

.liberta-btn-prev {
    padding: 12px 20px;
    background: var(--lm-light);
    color: var(--lm-text) !important;
    border: 1.5px solid var(--lm-border);
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.18s;
    text-decoration: none !important;
}

.liberta-btn-prev:hover { border-color: var(--lm-green); color: var(--lm-green) !important; }

.liberta-btn-next {
    flex: 1;
    padding: 12px 20px;
    background: var(--lm-dark);
    color: #fff !important;
    border: none;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    transition: background 0.18s;
}

.liberta-btn-next:hover { background: #2c2416; }

/* Messages */
.liberta-success {
    background: var(--lm-green-bg);
    border: 1px solid var(--lm-green-bd);
    color: #15803d;
    padding: 12px 16px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 14px;
    margin-top: 12px;
}

.liberta-error {
    background: #fef2f2;
    border: 1px solid #fecaca;
    color: var(--lm-red);
    padding: 12px 16px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 14px;
    margin-top: 12px;
}

#liberta-form-message,
#liberta-register-message,
#liberta-account-message { margin-top: 12px; }

/* ============================================================
   DASHBOARD MEMBRE
   ============================================================ */

#liberta-dashboard { max-width: 960px; margin: 0 auto; padding: 0 0 48px; }

#liberta-dash-header {
    padding: 28px 0 20px;
    border-bottom: 2px solid var(--lm-border);
    margin-bottom: 24px;
}

#liberta-dash-header h2 {
    margin: 0;
    font-size: 22px;
    font-weight: 800;
    color: var(--lm-dark);
}

/* Onglets */
#liberta-dash-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-bottom: 28px;
    border-bottom: 2px solid var(--lm-border);
    padding-bottom: 0;
}

.liberta-dash-tab {
    padding: 10px 18px;
    cursor: pointer;
    font-size: 14px;
    font-weight: 600;
    color: var(--lm-muted);
    border-radius: 8px 8px 0 0;
    transition: all 0.18s;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
}

.liberta-dash-tab:hover { color: var(--lm-green); background: var(--lm-green-bg); }

.liberta-dash-tab.active {
    color: var(--lm-green);
    border-bottom-color: var(--lm-green);
    background: var(--lm-light);
}

.liberta-dash-panel { display: none; }
.liberta-dash-panel.active { display: block; }

/* Cartes de lieux */
.liberta-dash-location-card {
    padding: 18px 20px;
    border: 1px solid var(--lm-border);
    border-radius: var(--lm-radius);
    margin-bottom: 12px;
    background: var(--lm-white);
    transition: box-shadow 0.18s;
}

.liberta-dash-location-card:hover {
    box-shadow: 0 4px 16px rgba(0,0,0,0.07);
}

.liberta-dash-loc-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
    flex-wrap: wrap;
    gap: 8px;
}

.liberta-dash-loc-header strong {
    font-size: 16px;
    font-weight: 700;
    color: var(--lm-dark);
}

.liberta-status-badge {
    padding: 4px 12px;
    border-radius: 100px;
    font-size: 12px;
    font-weight: 700;
}

.status-approved  { background: var(--lm-green-bg); color: var(--lm-green); }
.status-pending   { background: #fef9c3; color: #854d0e; }
.status-suspended { background: #fef2f2; color: var(--lm-red); }

.liberta-dash-loc-actions { display: flex; gap: 8px; flex-wrap: wrap; }

.liberta-btn-edit-location {
    padding: 7px 14px;
    background: var(--lm-light);
    border: 1.5px solid var(--lm-border);
    border-radius: 7px;
    font-size: 13px;
    font-weight: 600;
    color: var(--lm-text);
    cursor: pointer;
    transition: all 0.18s;
}

.liberta-btn-edit-location:hover {
    border-color: var(--lm-green);
    color: var(--lm-green);
    background: var(--lm-green-bg);
}

/* ============================================================
   CO-LIVRAISON DASHBOARD
   ============================================================ */

#liberta-colivraison-dashboard h3 {
    margin-top: 0;
    font-size: 18px;
    font-weight: 700;
    color: var(--lm-dark);
}

.liberta-partner-card {
    padding: 16px 18px;
    border: 1px solid var(--lm-border);
    border-radius: var(--lm-radius);
    margin-bottom: 10px;
    background: var(--lm-white);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    transition: box-shadow 0.18s;
}

.liberta-partner-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.07); }

.liberta-partner-card .partner-info strong {
    font-size: 15px;
    font-weight: 700;
    color: var(--lm-dark);
}

.liberta-partner-card .partner-info span {
    font-size: 13px;
    color: var(--lm-muted);
    display: block;
    margin-top: 2px;
}

.liberta-request-card {
    padding: 16px 18px;
    border: 1.5px solid #fed7aa;
    border-radius: var(--lm-radius);
    margin-bottom: 10px;
    background: #fff7ed;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
}

/* ============================================================
   FORMULAIRE INSCRIPTION
   ============================================================ */

#liberta-register-wrap {
    max-width: 520px;
    margin: 0 auto;
    padding: 36px 32px;
    background: var(--lm-white);
    border: 1px solid var(--lm-border);
    border-radius: 16px;
    box-shadow: 0 4px 32px rgba(0,0,0,0.08);
}

#liberta-register-wrap h2 {
    margin: 0 0 8px;
    font-size: 24px;
    font-weight: 800;
    color: var(--lm-dark);
}

#liberta-register-wrap > p {
    font-size: 14px;
    color: var(--lm-muted);
    margin: 0 0 24px;
}

/* ============================================================
   RÉPUTATION
   ============================================================ */

.liberta-reputation {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    margin: 4px 0;
    color: var(--lm-muted);
}

.liberta-stars { color: var(--lm-orange); }

/* ============================================================
   PAGE AJOUT LIEU (/ajouter-lieu/)
   ============================================================ */

#liberta-add-location-page {
    max-width: 900px;
    margin: 0 auto;
}

#liberta-add-map {
    border-radius: var(--lm-radius);
    box-shadow: 0 2px 16px rgba(0,0,0,0.1);
    margin-bottom: 24px;
}

#liberta-add-form-wrap {
    background: var(--lm-white);
    border: 1px solid var(--lm-border);
    border-radius: var(--lm-radius);
    padding: 28px;
    box-shadow: 0 4px 24px rgba(0,0,0,0.07);
}

/* ============================================================
   RESPONSIVE MOBILE
   ============================================================ */

@media (max-width: 600px) {
    #liberta-filters { gap: 6px; }
    .liberta-filter { font-size: 12px; padding: 5px 11px; }
    #liberta-form-wrap { padding: 18px 14px; }
    .liberta-cat-grid { grid-template-columns: repeat(2, 1fr); }
    .liberta-pay-grid { grid-template-columns: 1fr; }
    #liberta-dash-tabs { gap: 2px; }
    .liberta-dash-tab { padding: 8px 10px; font-size: 12px; }
    .liberta-form-buttons { flex-direction: column; }
    #liberta-submit-btn { flex: none; }
    #liberta-register-wrap { padding: 24px 18px; }
    .liberta-partner-card { flex-direction: column; align-items: flex-start; }
}

/* ============================================================
   COULEURS FILTRES — une couleur par catégorie
   ============================================================ */
.liberta-filter[data-cat="agriculture-alimentation"]:hover,
.liberta-filter[data-cat="agriculture-alimentation"].active { border-color:#27ae60; color:#27ae60; background:#eef6ee; }
.liberta-filter[data-cat="agriculture-alimentation"].active { background:#27ae60; color:#fff; }

.liberta-filter[data-cat="jardins-echanges"]:hover,
.liberta-filter[data-cat="jardins-echanges"].active { border-color:#2ecc71; color:#2ecc71; background:#eef6ee; }
.liberta-filter[data-cat="jardins-echanges"].active { background:#2ecc71; color:#fff; }

.liberta-filter[data-cat="ecolieux-habitat"]:hover,
.liberta-filter[data-cat="ecolieux-habitat"].active { border-color:#8e44ad; color:#8e44ad; background:#faf5ff; }
.liberta-filter[data-cat="ecolieux-habitat"].active { background:#8e44ad; color:#fff; }

.liberta-filter[data-cat="tiers-lieux"]:hover,
.liberta-filter[data-cat="tiers-lieux"].active { border-color:#3498db; color:#3498db; background:#eff6ff; }
.liberta-filter[data-cat="tiers-lieux"].active { background:#3498db; color:#fff; }

.liberta-filter[data-cat="ateliers-pratiques"]:hover,
.liberta-filter[data-cat="ateliers-pratiques"].active { border-color:#e67e22; color:#e67e22; background:#fff7ed; }
.liberta-filter[data-cat="ateliers-pratiques"].active { background:#e67e22; color:#fff; }

.liberta-filter[data-cat="ateliers-numeriques"]:hover,
.liberta-filter[data-cat="ateliers-numeriques"].active { border-color:#1abc9c; color:#1abc9c; background:#f0fdfa; }
.liberta-filter[data-cat="ateliers-numeriques"].active { background:#1abc9c; color:#fff; }

.liberta-filter[data-cat="solidarite-alimentaire"]:hover,
.liberta-filter[data-cat="solidarite-alimentaire"].active { border-color:#e74c3c; color:#e74c3c; background:#fff1f2; }
.liberta-filter[data-cat="solidarite-alimentaire"].active { background:#e74c3c; color:#fff; }

.liberta-filter[data-cat="economie-alternative"]:hover,
.liberta-filter[data-cat="economie-alternative"].active { border-color:#f39c12; color:#f39c12; background:#fffbeb; }
.liberta-filter[data-cat="economie-alternative"].active { background:#f39c12; color:#fff; }

.liberta-filter[data-cat="art-culture"]:hover,
.liberta-filter[data-cat="art-culture"].active { border-color:#e91e63; color:#e91e63; background:#fdf2f8; }
.liberta-filter[data-cat="art-culture"].active { background:#e91e63; color:#fff; }

.liberta-filter[data-cat="evenements-rencontres"]:hover,
.liberta-filter[data-cat="evenements-rencontres"].active { border-color:#2980b9; color:#2980b9; background:#eff6ff; }
.liberta-filter[data-cat="evenements-rencontres"].active { background:#2980b9; color:#fff; }

.liberta-filter[data-cat="sante-bien-etre"]:hover,
.liberta-filter[data-cat="sante-bien-etre"].active { border-color:#16a085; color:#16a085; background:#f0fdfa; }
.liberta-filter[data-cat="sante-bien-etre"].active { background:#16a085; color:#fff; }

.liberta-filter[data-cat="artisanat-creation"]:hover,
.liberta-filter[data-cat="artisanat-creation"].active { border-color:#d35400; color:#d35400; background:#fff7ed; }
.liberta-filter[data-cat="artisanat-creation"].active { background:#d35400; color:#fff; }

.liberta-filter[data-cat="mobilite-transport"]:hover,
.liberta-filter[data-cat="mobilite-transport"].active { border-color:#7f8c8d; color:#7f8c8d; background:#f5efe0; }
.liberta-filter[data-cat="mobilite-transport"].active { background:#7f8c8d; color:#fff; }

.liberta-filter[data-cat="animaux-nature"]:hover,
.liberta-filter[data-cat="animaux-nature"].active { border-color:#27ae60; color:#27ae60; background:#eef6ee; }
.liberta-filter[data-cat="animaux-nature"].active { background:#27ae60; color:#fff; }

/* ============================================================
   ÉVÉNEMENTS — Styles RSVP et dashboard
   ============================================================ */
.liberta-event-card { border:1.5px solid var(--lm-border); border-radius:12px; padding:20px; margin-bottom:16px; background:#fff; }
.liberta-event-card.event-upcoming { border-color:#2980b9; }
.liberta-event-card.event-past { opacity:0.7; }
.liberta-event-meta { display:flex; gap:16px; flex-wrap:wrap; font-size:13px; color:var(--lm-muted); margin:8px 0 12px; }
.liberta-event-meta span { display:flex; align-items:center; gap:4px; }
.liberta-event-badge { display:inline-block; padding:2px 10px; border-radius:20px; font-size:11px; font-weight:700; }
.liberta-event-badge.free { background:#dff0e8; color:#2d6a4f; }
.liberta-event-badge.paid { background:#dbeafe; color:#1d4ed8; }
.liberta-rsvp-bar { display:flex; gap:8px; margin-top:12px; flex-wrap:wrap; align-items:center; }
.liberta-rsvp-btn { padding:8px 16px; border-radius:8px; border:1.5px solid var(--lm-border); font-size:13px; font-weight:600; cursor:pointer; transition:all 0.15s; background:#fff; }
.liberta-rsvp-btn.yes { border-color:#2d6a4f; color:#2d6a4f; }
.liberta-rsvp-btn.yes.active, .liberta-rsvp-btn.yes:hover { background:#2d6a4f; color:#fff; }
.liberta-rsvp-btn.maybe { border-color:#f59e0b; color:#f59e0b; }
.liberta-rsvp-btn.maybe.active, .liberta-rsvp-btn.maybe:hover { background:#f59e0b; color:#fff; }
.liberta-rsvp-btn.cancel { border-color:#e74c3c; color:#e74c3c; font-size:12px; padding:6px 12px; }
.liberta-rsvp-btn.cancel:hover { background:#e74c3c; color:#fff; }
.liberta-rsvp-counts { font-size:12px; color:var(--lm-muted); margin-left:auto; }
.liberta-event-organizer-stats { background:#f5efe0; border-radius:8px; padding:16px; margin-top:12px; }
.liberta-event-organizer-stats h4 { font-size:13px; margin:0 0 8px; color:var(--lm-text); }
.liberta-event-stat-row { display:flex; gap:24px; }
.liberta-event-stat { text-align:center; }
.liberta-event-stat .num { font-size:22px; font-weight:800; color:var(--lm-text); }
.liberta-event-stat .lbl { font-size:11px; color:var(--lm-muted); }
.liberta-event-form { background:#f5efe0; border-radius:12px; padding:24px; margin-top:16px; }
.liberta-event-form h3 { margin:0 0 16px; font-size:16px; }
.liberta-event-datetime { display:grid; grid-template-columns:1fr 1fr; gap:12px; }

/* ============================================================
   ACCOUNT TYPE — Selector à l'inscription
   ============================================================ */
.liberta-account-type-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin:8px 0 20px; }
.liberta-account-type-item { border:2px solid var(--lm-border); border-radius:10px; padding:16px 12px; text-align:center; cursor:pointer; transition:all 0.15s; }
.liberta-account-type-item:hover { border-color:var(--lm-green); }
.liberta-account-type-item input[type=radio] { display:none; }
.liberta-account-type-item.selected { border-color:var(--lm-green); background:var(--lm-green-bg); }
.liberta-account-type-icon { font-size:28px; margin-bottom:6px; }
.liberta-account-type-label { font-size:12px; font-weight:700; line-height:1.3; }
.liberta-account-type-desc { font-size:11px; color:var(--lm-muted); margin-top:4px; }

/* ============================================================
   2FA — Interface dashboard
   ============================================================ */
.liberta-2fa-section { background:#f5efe0; border-radius:12px; padding:24px; margin-top:20px; }
.liberta-2fa-section h4 { margin:0 0 12px; font-size:15px; }
.liberta-2fa-qr { text-align:center; margin:16px 0; }
.liberta-2fa-qr img { border:4px solid #fff; border-radius:8px; box-shadow:0 2px 12px rgba(0,0,0,0.1); }
.liberta-2fa-secret { font-family:monospace; background:#fff; border:1px solid var(--lm-border); border-radius:6px; padding:10px 14px; font-size:13px; letter-spacing:2px; text-align:center; margin:12px 0; }
.liberta-2fa-active { display:flex; align-items:center; gap:10px; padding:12px 16px; background:#dff0e8; border-radius:8px; color:#2d6a4f; font-weight:600; }

/* ============================================================
   COMMISSION — Vue vendeur + admin
   ============================================================ */
.liberta-commission-box { background:linear-gradient(135deg,#eef6ee,#dff0e8); border:1.5px solid #b7d9c3; border-radius:12px; padding:20px; margin-top:16px; }
.liberta-commission-amount { font-size:28px; font-weight:800; color:#2d6a4f; }
.liberta-commission-label { font-size:13px; color:#6b7c5a; margin-bottom:16px; }
.liberta-commission-rate-input { display:flex; align-items:center; gap:10px; margin:12px 0; }
.liberta-commission-rate-input input[type=range] { flex:1; }
.liberta-commission-rate-display { font-size:18px; font-weight:700; min-width:48px; }
.liberta-admin-commission-table { width:100%; border-collapse:collapse; margin-top:16px; }
.liberta-admin-commission-table th { background:#f5efe0; padding:10px 14px; text-align:left; font-size:13px; border-bottom:2px solid #ddd0b8; }
.liberta-admin-commission-table td { padding:10px 14px; border-bottom:1px solid #ddd0b8; font-size:13px; }
.liberta-admin-commission-table tr:hover td { background:#f5efe0; }

@media (max-width:600px) {
    .liberta-account-type-grid { grid-template-columns:1fr; }
    .liberta-event-datetime { grid-template-columns:1fr; }
}

/* ============================================================
   CARTE — Hauteur responsive + tiles fix
   ============================================================ */
#liberta-map {
    min-height: 400px;
    width: 100%;
    display: block;
    background: #e5e0d8; /* fond neutre pendant le chargement des tuiles */
}

/* Tuiles Leaflet — éviter les problèmes de rendu */
.leaflet-tile {
    filter: none !important;
}

.leaflet-tile-container img {
    max-width: none !important;
    max-height: none !important;
}

@media (max-width: 768px) {
    #liberta-map { min-height: 350px; }
}

@media (max-width: 480px) {
    #liberta-map { min-height: 300px; }
}

/* ============================================================
   SOUS-FILTRES (ligne 2 contextuelle)
   ============================================================ */
#liberta-subfilters {
    display: none;
    flex-wrap: wrap;
    gap: 6px;
    padding: 8px 16px 10px;
    background: #f5efe0;
    border-top: 1px solid #ddd0b8;
    animation: lm-subfilter-in 0.2s ease;
}

@keyframes lm-subfilter-in {
    from { opacity:0; transform:translateY(-6px); }
    to   { opacity:1; transform:translateY(0); }
}

.liberta-subfilter {
    display: inline-flex;
    align-items: center;
    padding: 4px 11px;
    border: 1.5px solid color-mix(in srgb, var(--sc,#6b7c5a) 30%, transparent);
    border-radius: 100px;
    background: color-mix(in srgb, var(--sc,#6b7c5a) 8%, white);
    color: var(--sc, #6b7c5a);
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.15s;
    user-select: none;
    white-space: nowrap;
}

.liberta-subfilter:hover {
    background: var(--sc, #6b7c5a) !important;
    border-color: var(--sc, #6b7c5a) !important;
    color: #fff !important;
}

.liberta-subfilter.active {
    background: var(--sc, #6b7c5a) !important;
    border-color: var(--sc, #6b7c5a) !important;
    color: #fff !important;
}

/* ── Bouton "Affiner" ── */
.lm-advanced-btn {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 6px 12px;
    border: 1.5px dashed #cbd5e1;
    border-radius: 100px;
    background: transparent;
    color: #6b7c5a;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.15s;
    white-space: nowrap;
}

.lm-advanced-btn:hover {
    border-color: #475569;
    color: #2c2416;
    background: #f1f5f9;
}

/* ============================================================
   TIROIR RECHERCHE AVANCÉE
   ============================================================ */
#lm-drawer {
    position: fixed;
    inset: 0;
    z-index: 99999;
    display: flex;
    align-items: flex-end;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.25s;
}

#lm-drawer.open {
    opacity: 1;
    pointer-events: all;
}

#lm-drawer-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15,23,42,0.5);
    backdrop-filter: blur(2px);
}

#lm-drawer-panel {
    position: relative;
    width: 100%;
    max-width: 680px;
    margin: 0 auto;
    background: #fff;
    border-radius: 20px 20px 0 0;
    max-height: 85vh;
    display: flex;
    flex-direction: column;
    transform: translateY(40px);
    transition: transform 0.3s cubic-bezier(0.34,1.56,0.64,1);
    box-shadow: 0 -8px 40px rgba(0,0,0,0.15);
}

#lm-drawer.open #lm-drawer-panel {
    transform: translateY(0);
}

#lm-drawer-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 24px 16px;
    border-bottom: 1px solid #f1f5f9;
    flex-shrink: 0;
}

#lm-drawer-header h3 {
    font-size: 17px;
    font-weight: 800;
    color: #1a2e1a;
    margin: 0;
}

#lm-drawer-close {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: none;
    background: #f1f5f9;
    color: #6b7c5a;
    font-size: 14px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s;
}

#lm-drawer-close:hover { background: #ddd0b8; color: #1a2e1a; }

#lm-drawer-search-wrap {
    padding: 12px 20px;
    flex-shrink: 0;
}

#lm-drawer-search {
    width: 100%;
    padding: 10px 16px;
    border: 2px solid #ddd0b8;
    border-radius: 12px;
    font-size: 15px;
    outline: none;
    transition: border-color 0.15s;
    box-sizing: border-box;
}

#lm-drawer-search:focus { border-color: #2d6a4f; }

#lm-drawer-results {
    flex: 1;
    overflow-y: auto;
    padding: 4px 20px 8px;
    overscroll-behavior: contain;
}

.lm-drawer-group { margin-bottom: 18px; }

.lm-drawer-group-header {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    color: #475569;
    margin-bottom: 8px;
    padding-left: 6px;
    border-left: 3px solid;
}

.lm-drawer-group-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}

.lm-drawer-group-count {
    margin-left: auto;
    font-size: 10px;
    background: #f1f5f9;
    padding: 1px 6px;
    border-radius: 20px;
    font-weight: 600;
}

.lm-drawer-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.lm-drawer-chip {
    padding: 5px 12px;
    border: 1.5px solid color-mix(in srgb, var(--dc,#6b7c5a) 25%, transparent);
    border-radius: 100px;
    background: color-mix(in srgb, var(--dc,#6b7c5a) 7%, white);
    color: var(--dc, #475569);
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.13s;
    user-select: none;
}

.lm-drawer-chip:hover {
    background: var(--dc) !important;
    border-color: var(--dc) !important;
    color: #fff !important;
    transform: translateY(-1px);
}

.lm-chip-active {
    background: var(--dc) !important;
    border-color: var(--dc) !important;
    color: #fff !important;
}

.lm-drawer-chip mark {
    background: rgba(255,255,0,0.5);
    color: inherit;
    border-radius: 2px;
    font-style: normal;
}

.lm-drawer-empty {
    text-align: center;
    padding: 40px 20px;
    color: #6b7c5a;
}

#lm-drawer-footer {
    display: flex;
    gap: 10px;
    padding: 14px 20px;
    border-top: 1px solid #f1f5f9;
    flex-shrink: 0;
}

.lm-drawer-btn-primary {
    flex: 1;
    padding: 12px;
    background: #2d6a4f;
    color: #fff;
    border: none;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    transition: background 0.15s;
}

.lm-drawer-btn-primary:hover { background: #15803d; }

.lm-drawer-btn-outline {
    padding: 12px 20px;
    background: transparent;
    color: #6b7c5a;
    border: 1.5px solid #ddd0b8;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.15s;
}

.lm-drawer-btn-outline:hover { border-color: #94a3b8; color: #2c2416; }

@media (max-width: 600px) {
    #lm-drawer-panel { max-height: 92vh; border-radius: 16px 16px 0 0; }
    #lm-drawer-header { padding: 16px 18px 12px; }
    #lm-drawer-results { padding: 4px 14px 8px; }
    #lm-drawer-footer  { padding: 12px 14px; }
    #lm-drawer-search-wrap { padding: 10px 14px; }
}

/* ============================================================
   BADGES OUVERT / FERMÉ sur les marqueurs
   ============================================================ */
.lm-marker-badge {
    display: block;
    text-align: center;
    font-size: 9px;
    font-weight: 800;
    padding: 2px 5px;
    border-radius: 6px;
    margin-top: 2px;
    white-space: nowrap;
    letter-spacing: 0.3px;
    text-transform: uppercase;
}
.lm-badge-open   { background: #2d6a4f; color: #fff; box-shadow: 0 1px 4px rgba(22,163,74,0.4); }
.lm-badge-closed { background: #6b7c5a; color: #fff; }

.liberta-pin-event {
    border-radius: 6px !important;
    border: 2px solid rgba(255,255,255,0.9);
}
.liberta-pin-event::after { display: none; } /* pas de triangle pour les événements */

/* ── Compteur de résultats filtres ── */
.lm-filter-count {
    display: none;
    align-items: center;
    padding: 4px 10px;
    background: #1a2e1a;
    color: #fff;
    border-radius: 100px;
    font-size: 11px;
    font-weight: 700;
    white-space: nowrap;
    margin-left: 4px;
}

/* ── Filtre avec multiple sélections actives ── */
.liberta-filter.active.lm-filter-colored {
    box-shadow: 0 0 0 2px #fff, 0 0 0 4px var(--fc, #6b7c5a);
}

/* ============================================================
   FORMULAIRE AJOUT LIEU — Autocomplete & Mini-carte
   ============================================================ */

/* Dropdown autocomplete */
#liberta-autocomplete {
    position: absolute;
    top: 100%;
    left: 0; right: 0;
    background: #fff;
    border: 1.5px solid #ddd0b8;
    border-top: none;
    border-radius: 0 0 10px 10px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.10);
    z-index: 9999;
    max-height: 240px;
    overflow-y: auto;
}

.liberta-ac-item {
    padding: 10px 14px;
    font-size: 13px;
    color: #2c2416;
    cursor: pointer;
    border-bottom: 1px solid #f1f5f9;
    line-height: 1.4;
    transition: background 0.1s;
}

.liberta-ac-item:last-child { border-bottom: none; }

.liberta-ac-item:hover { background: #eef6ee; }

.liberta-ac-item.liberta-ac-none {
    color: #94a3b8;
    cursor: default;
    font-style: italic;
}

.lm-ac-main { display: block; }

/* Mini-carte de sélection */
#liberta-pick-map {
    width: 100%;
    height: 260px;
    border-radius: 12px;
    border: 2px solid #ddd0b8;
    overflow: hidden;
    cursor: crosshair;
    transition: border-color 0.15s;
}

#liberta-pick-map:hover { border-color: #2d6a4f; }

#liberta-pick-map .leaflet-container { cursor: crosshair !important; }

/* ============================================================
   ÉTAPE 2 — Sous-catégories groupées par parent
   ============================================================ */
.liberta-subcat-group-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 0 6px 10px;
    margin: 14px 0 6px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: #475569;
}
.liberta-subcat-group-header:first-child { margin-top: 4px; }

.liberta-subcat-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    margin-bottom: 6px;
}

/* Chip sous-catégorie coloré selon son parent */
.liberta-subcat-item {
    padding: 5px 13px;
    border: 1.5px solid color-mix(in srgb, var(--sc, #6b7c5a) 30%, transparent);
    border-radius: 100px;
    background: color-mix(in srgb, var(--sc, #6b7c5a) 8%, white);
    color: var(--sc, #475569);
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.13s;
    user-select: none;
}

.liberta-subcat-item:hover {
    background: var(--sc, #6b7c5a) !important;
    border-color: var(--sc, #6b7c5a) !important;
    color: #fff !important;
}

.liberta-subcat-item.selected {
    background: var(--sc, #6b7c5a) !important;
    border-color: var(--sc, #6b7c5a) !important;
    color: #fff !important;
    font-weight: 700;
}

/* ---- Badges saisonnalité ---- */
.liberta-seasonal-badge {
    display: inline-flex; align-items: center; gap: 4px;
    font-size: 11px; font-weight: 700; padding: 3px 8px;
    border-radius: 20px; white-space: nowrap; line-height: 1.4;
}
.liberta-seasonal-badge.lsb-in  { background: #dff0e8; color: #2d6a4f; border: 1px solid #b7d9c3; }
.liberta-seasonal-badge.lsb-off { background: #f0f4f8; color: #6b7c5a; border: 1px solid #ddd0b8; }
.liberta-seasonal-badge .lsb-months { font-weight: 400; opacity: .8; }
.ll-shop-dir-seasonal { display: block; margin: 2px 0 4px; }

/* ---- Gestionnaire saisonnalité (dashboard producteur) ---- */
.liberta-seasonal-manager {
    margin-top: 32px;
    padding: 24px;
    background: var(--lm-light);
    border-radius: 14px;
    border: 1.5px solid var(--lm-border);
}
.liberta-seasonal-manager h3 { margin: 0 0 6px; font-size: 17px; font-weight: 800; color: var(--lm-dark); }
.liberta-seasonal-manager > p { font-size: 13px; color: var(--lm-muted); margin: 0 0 20px; }

.lsm-product-row {
    background: #fff;
    border: 1px solid var(--lm-border);
    border-radius: 10px;
    padding: 16px;
    margin-bottom: 10px;
}
.lsm-product-info {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
    flex-wrap: wrap;
}
.lsm-thumb { width: 48px; height: 48px; object-fit: cover; border-radius: 8px; flex-shrink: 0; }
.lsm-product-name { font-size: 14px; font-weight: 700; color: var(--lm-dark); }
.lsm-product-price { font-size: 12px; color: var(--lm-muted); margin-top: 2px; }
.lsm-badge-wrap { margin-left: auto; }

.lsm-months {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    margin-bottom: 12px;
}
.lsm-month {
    padding: 5px 9px;
    font-size: 12px;
    font-weight: 600;
    border: 1.5px solid var(--lm-border);
    border-radius: 6px;
    background: #fff;
    color: var(--lm-muted);
    cursor: pointer;
    transition: all .15s;
}
.lsm-month.active { background: var(--lm-green); border-color: var(--lm-green); color: #fff; }
.lsm-month:hover:not(.active) { border-color: var(--lm-green); color: var(--lm-green); }

.lsm-actions { display: flex; align-items: center; gap: 10px; }
.lsm-feedback { font-size: 12px; font-weight: 600; }

@media (max-width: 480px) {
    .lsm-month { padding: 4px 7px; font-size: 11px; }
    .lsm-product-info { gap: 8px; }
}

/* ---- Page connexion branded (/connexion/) ---- */
.liberta-login-wrap {
    display: flex; align-items: center; justify-content: center;
    min-height: 60vh; padding: 40px 16px;
}
.liberta-login-box {
    background: #fff; border: 1px solid var(--lm-border);
    border-radius: 16px; padding: 40px 36px; width: 100%; max-width: 420px;
    box-shadow: 0 4px 24px rgba(0,0,0,.07);
}
.liberta-login-logo { text-align: center; margin-bottom: 24px; }
.liberta-login-logo img { height: 52px; width: auto; }
.liberta-login-site-name { font-family: 'Lora', Georgia, serif; font-size: 22px; font-weight: 700; color: var(--lm-dark); }
.liberta-login-title { text-align: center; font-size: 22px; font-weight: 700; color: var(--lm-dark); margin: 0 0 24px; }

.liberta-login-box #liberta-login-form label { font-size: 13px; font-weight: 600; color: var(--lm-text); }
.liberta-login-box #liberta-login-form input[type=text],
.liberta-login-box #liberta-login-form input[type=password] {
    width: 100%; padding: 10px 14px; border: 1.5px solid var(--lm-border);
    border-radius: 8px; font-size: 15px; box-sizing: border-box; margin-top: 4px;
    transition: border-color .15s;
}
.liberta-login-box #liberta-login-form input:focus { border-color: var(--lm-green); outline: none; }
.liberta-login-box #liberta-login-form p { margin-bottom: 16px; }
.liberta-login-box #liberta-login-form .forgetmenot { display: flex; align-items: center; gap: 6px; font-size: 13px; }
.liberta-login-box #liberta-login-form input[type=submit] {
    width: 100%; padding: 12px; background: var(--lm-green); color: #fff;
    border: none; border-radius: 8px; font-size: 15px; font-weight: 700;
    cursor: pointer; transition: background .15s; margin-top: 4px;
}
.liberta-login-box #liberta-login-form input[type=submit]:hover { background: #1a5c3f; }

.liberta-login-links {
    text-align: center; margin-top: 20px; font-size: 13px; color: var(--lm-muted);
    display: flex; justify-content: center; gap: 10px;
}
.liberta-login-links a { color: var(--lm-green); text-decoration: none; font-weight: 600; }
.liberta-login-links a:hover { text-decoration: underline; }

/* ============================================================
   DASHBOARD BOUTIQUE (.liberta-boutique-dashboard)
   ============================================================ */
.liberta-boutique-dashboard { padding: 4px 0 24px; }
.lbd-header { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; gap: 8px; margin-bottom: 20px; }
.lbd-store-name { margin: 0 0 4px; font-size: 20px; font-weight: 800; color: var(--lm-dark); }
.lbd-visit-link { font-size: 13px; color: var(--lm-green); font-weight: 600; text-decoration: none; }
.lbd-visit-link:hover { text-decoration: underline; }
.lbd-stats { display: flex; gap: 16px; margin-bottom: 24px; flex-wrap: wrap; }
.lbd-stat-card {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    padding: 16px 24px; background: var(--lm-green-bg);
    border: 1.5px solid var(--lm-green-bd); border-radius: 12px;
    text-decoration: none; transition: background .15s, transform .15s; min-width: 100px;
}
.lbd-stat-card:hover { background: var(--lm-green-bd); transform: translateY(-2px); }
.lbd-stat-num { font-size: 28px; font-weight: 900; color: var(--lm-green); line-height: 1; }
.lbd-stat-label { font-size: 12px; color: var(--lm-muted); margin-top: 4px; text-align: center; }
.lbd-actions { display: flex; flex-wrap: wrap; gap: 10px; }

/* ============================================================
   RÉPERTOIRE BOUTIQUES & ÉVÉNEMENTS (.ll-dir)
   ============================================================ */

.ll-dir { font-family: inherit; padding: 0 0 40px; }

/* En-tête */
.ll-dir-header {
    display: flex; justify-content: space-between; align-items: flex-start;
    flex-wrap: wrap; gap: 12px; margin-bottom: 24px; padding-bottom: 20px;
    border-bottom: 1.5px solid var(--lm-border);
}
.ll-dir-title { margin: 0 0 6px; font-size: 26px; color: var(--lm-dark); }
.ll-dir-subtitle { margin: 0; font-size: 14px; color: var(--lm-muted); max-width: 500px; }
.ll-dir-stats { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.ll-dir-stats span { font-size: 13px; color: var(--lm-muted); font-weight: 600; }
.ll-dir-map-btn {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 7px 16px; background: var(--lm-green-bg);
    color: var(--lm-green); border-radius: 8px; font-size: 13px;
    font-weight: 700; text-decoration: none; border: 1.5px solid var(--lm-green-bd);
    transition: background .15s;
}
.ll-dir-map-btn:hover { background: var(--lm-green-bd); color: var(--lm-dark); }

/* Filtres */
.ll-dir-filters { margin-bottom: 28px; display: flex; flex-direction: column; gap: 12px; }
.ll-dir-filter-row { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.ll-dir-search-wrap { flex: 1; min-width: 200px; }
.ll-dir-search {
    width: 100%; padding: 10px 14px; border: 1.5px solid var(--lm-border);
    border-radius: 10px; font-size: 14px; background: #fff;
    transition: border-color .15s;
}
.ll-dir-search:focus { outline: none; border-color: var(--lm-green); }
.ll-dir-proximity-wrap { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.ll-prox-ac-wrap { position: relative; }
.ll-prox-ac-list {
    position: absolute; top: calc(100% + 4px); left: 0; z-index: 9000;
    background: #fff; border: 1.5px solid var(--lm-border); border-radius: 10px;
    box-shadow: 0 6px 20px rgba(0,0,0,.12); overflow: hidden; min-width: 220px;
}
.ll-prox-ac-item {
    padding: 10px 14px; font-size: 14px; color: var(--lm-dark); cursor: pointer;
    border-bottom: 1px solid #f1f5f9; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.ll-prox-ac-item:last-child { border-bottom: none; }
.ll-prox-ac-item:hover { background: var(--lm-green-bg); color: var(--lm-green); }
.ll-dir-prox-input {
    padding: 10px 14px; border: 1.5px solid var(--lm-border);
    border-radius: 10px; font-size: 14px; background: #fff;
    width: 200px; transition: border-color .15s;
}
.ll-dir-prox-input:focus { outline: none; border-color: var(--lm-green); }
.ll-dir-prox-radius {
    padding: 9px 10px; border: 1.5px solid var(--lm-border);
    border-radius: 10px; font-size: 13px; background: #fff; cursor: pointer;
}
.ll-dir-prox-btn {
    padding: 10px 16px; background: var(--lm-green); color: #fff;
    border: none; border-radius: 10px; font-size: 13px; font-weight: 700;
    cursor: pointer; transition: background .15s;
}
.ll-dir-prox-btn:hover:not(:disabled) { background: #1a5c3f; }
.ll-dir-prox-btn:disabled { opacity: .6; cursor: default; }
.ll-dir-prox-clear {
    padding: 9px 13px; background: #f1f5f9; color: #64748b;
    border: 1.5px solid #cbd5e1; border-radius: 10px; font-size: 13px;
    cursor: pointer; font-weight: 700;
}
.ll-dir-prox-clear:hover { background: #e2e8f0; }
.ll-dir-prox-info { font-size: 12px; color: var(--lm-muted); padding: 4px 0; }
.ll-dir-cats-filter { display: flex; flex-wrap: wrap; gap: 8px; }
.ll-dir-cat-pill {
    padding: 6px 14px; border-radius: 100px; font-size: 13px; font-weight: 600;
    border: 1.5px solid var(--lm-border); background: #fff; color: var(--lm-muted);
    cursor: pointer; transition: all .15s; white-space: nowrap;
}
.ll-dir-cat-pill:hover { border-color: var(--lm-green); color: var(--lm-green); background: var(--lm-green-bg); }
.ll-dir-cat-pill.active { background: var(--lm-green); color: #fff; border-color: var(--lm-green); }

/* Grille boutiques */
.ll-dir-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 24px;
}

/* Carte boutique */
.ll-dir-card {
    background: #fff; border-radius: 14px; overflow: hidden;
    box-shadow: 0 2px 12px rgba(0,0,0,.07); border: 1.5px solid var(--lm-border);
    display: flex; flex-direction: column; transition: box-shadow .2s, transform .2s;
}
.ll-dir-card:hover { box-shadow: 0 6px 24px rgba(0,0,0,.12); transform: translateY(-2px); }

.ll-dir-card-banner { display: block; width: 100%; height: 140px; overflow: hidden; position: relative; background: var(--lm-green-bg); flex-shrink: 0; }
.ll-dir-card-banner img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ll-dir-card-banner-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 40px; }
.ll-dir-card-dist {
    position: absolute; top: 8px; right: 8px;
    background: rgba(26,46,26,.8); color: #fff; font-size: 11px; font-weight: 700;
    padding: 3px 8px; border-radius: 100px;
}

.ll-dir-card-body { padding: 16px; display: flex; flex-direction: column; flex: 1; }
.ll-dir-card-name { margin: 0 0 4px; font-size: 16px; font-weight: 800; color: var(--lm-dark); }
.ll-dir-card-name a { color: inherit; text-decoration: none; }
.ll-dir-card-name a:hover { color: var(--lm-green); }
.ll-dir-card-city { margin: 0 0 8px; font-size: 13px; color: var(--lm-muted); }
.ll-dir-card-cats { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 10px; }
.ll-dir-card-cat {
    font-size: 11px; font-weight: 700; padding: 3px 9px;
    border-radius: 100px; background: var(--lm-green-bg);
    color: var(--lm-green); border: 1px solid var(--lm-green-bd);
}
.ll-dir-card-bio { font-size: 13px; color: var(--lm-muted); margin: 0 0 12px; line-height: 1.5; flex: 1; }

/* Aperçu produits dans carte boutique */
.ll-dir-card-products { display: flex; gap: 6px; overflow-x: auto; margin-bottom: 14px; padding-bottom: 2px; }
.ll-dir-card-product {
    flex-shrink: 0; width: 72px; border-radius: 8px; overflow: hidden;
    background: var(--lm-green-bg); text-decoration: none;
    display: flex; flex-direction: column; align-items: center;
    font-size: 10px; color: var(--lm-dark); border: 1px solid var(--lm-green-bd);
    transition: transform .15s;
}
.ll-dir-card-product:hover { transform: scale(1.05); }
.ll-dir-card-product img { width: 72px; height: 52px; object-fit: cover; display: block; }
.ll-dir-card-product-ph { font-size: 22px; padding: 10px 0 4px; }
.ll-dir-card-product-price { font-size: 10px; font-weight: 700; color: var(--lm-green); padding: 2px 4px; text-align: center; }
.ll-dir-card-product-more {
    justify-content: center; color: var(--lm-green); font-size: 13px;
    font-weight: 800; min-height: 52px;
}

/* Boutons dans carte */
.ll-dir-card-actions { display: flex; gap: 8px; margin-top: auto; }
.ll-dir-card-btn-primary {
    flex: 1; text-align: center; padding: 9px 12px;
    background: var(--lm-green); color: #fff; border-radius: 8px;
    font-size: 13px; font-weight: 700; text-decoration: none;
    transition: background .15s; border: none; cursor: pointer;
}
.ll-dir-card-btn-primary:hover { background: #1a5c3f; color: #fff; }
.ll-dir-card-btn-secondary {
    padding: 9px 12px; background: #fff; color: var(--lm-green);
    border: 1.5px solid var(--lm-green-bd); border-radius: 8px;
    font-size: 13px; font-weight: 700; text-decoration: none;
    transition: all .15s; cursor: pointer;
}
.ll-dir-card-btn-secondary:hover { background: var(--lm-green-bg); }

/* Messages vides */
.ll-dir-empty, .ll-dir-no-results {
    text-align: center; padding: 48px 24px; color: var(--lm-muted);
    font-size: 15px; background: #f8fafc; border-radius: 12px;
    border: 1.5px dashed var(--lm-border);
}
.ll-dir-empty a, .ll-dir-no-results a { color: var(--lm-green); font-weight: 600; }

/* CTA rejoindre */
.ll-dir-cta {
    text-align: center; margin-top: 40px; padding: 28px;
    background: var(--lm-green-bg); border-radius: 14px;
    border: 1.5px solid var(--lm-green-bd);
}
.ll-dir-cta p { margin: 0 0 12px; font-size: 15px; font-weight: 700; color: var(--lm-dark); }
.ll-dir-cta a { color: var(--lm-green); font-weight: 700; font-size: 14px; text-decoration: none; }
.ll-dir-cta a:hover { text-decoration: underline; }

/* ── Liste événements ── */
.ll-events-list { display: flex; flex-direction: column; gap: 18px; }

.ll-event-card {
    display: flex; gap: 0; background: #fff; border-radius: 14px;
    border: 1.5px solid var(--lm-border); overflow: hidden;
    box-shadow: 0 2px 10px rgba(0,0,0,.06); transition: box-shadow .2s, transform .2s;
}
.ll-event-card:hover { box-shadow: 0 5px 20px rgba(0,0,0,.11); transform: translateY(-1px); }

.ll-event-card-thumb { flex-shrink: 0; width: 130px; display: block; overflow: hidden; background: var(--lm-green-bg); }
.ll-event-card-thumb img { width: 130px; height: 100%; object-fit: cover; display: block; }

.ll-event-card-date-badge {
    flex-shrink: 0; width: 64px; display: flex; flex-direction: column;
    align-items: center; justify-content: center; padding: 14px 8px;
    background: linear-gradient(160deg, #1a2e1a, #2d4a1e);
    color: #fff; text-align: center;
}
.ll-event-card-day { font-size: 28px; font-weight: 900; line-height: 1; font-family: 'Lora', serif; }
.ll-event-card-month { font-size: 11px; text-transform: uppercase; letter-spacing: .8px; opacity: .8; margin-top: 2px; }

.ll-event-card-body { flex: 1; padding: 16px 20px; display: flex; flex-direction: column; min-width: 0; }
.ll-event-card-title { margin: 0 0 8px; font-size: 16px; font-weight: 800; color: var(--lm-dark); }
.ll-event-card-title a { color: inherit; text-decoration: none; }
.ll-event-card-title a:hover { color: var(--lm-green); }

.ll-event-card-meta { display: flex; flex-wrap: wrap; gap: 8px 16px; margin-bottom: 10px; }
.ll-event-meta-item { font-size: 13px; color: var(--lm-muted); }

.ll-event-card-badges { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 8px; }
.ll-event-badge {
    display: inline-block; font-size: 12px; font-weight: 700;
    padding: 3px 10px; border-radius: 100px;
}
.ll-event-badge-free { background: #dff0e8; color: var(--lm-green); }
.ll-event-badge-price { background: #fef3c7; color: #92400e; }
.ll-event-badge-rsvp { background: #eff6ff; color: #1d4ed8; }
.ll-event-badge-alert { background: #fee2e2; color: #dc2626; }

.ll-event-card-excerpt { font-size: 13px; color: var(--lm-muted); margin: 0 0 14px; line-height: 1.5; flex: 1; }
.ll-event-card-actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: auto; }
.ll-event-rsvp-confirmed { background: var(--lm-green-bg) !important; color: var(--lm-green) !important; border-color: var(--lm-green-bd) !important; }

/* Responsive */
@media (max-width: 640px) {
    .ll-dir-grid { grid-template-columns: 1fr; }
    .ll-dir-filter-row { flex-direction: column; }
    .ll-dir-prox-input { width: 100%; }
    .ll-dir-search-wrap { width: 100%; }
    .ll-event-card { flex-direction: column; }
    .ll-event-card-thumb { width: 100%; height: 160px; }
    .ll-event-card-date-badge { width: 100%; flex-direction: row; gap: 8px; padding: 10px 16px; }
    .ll-event-card-day { font-size: 20px; }
    .ll-dir-proximity-wrap { flex-direction: column; align-items: stretch; width: 100%; }
    .ll-dir-prox-btn, .ll-dir-prox-radius { width: 100%; }
}

/* ── Type toggle (main map: Tout / Lieux / Événements) ── */
.lm-type-toggle {
    display: flex; gap: 6px; margin-bottom: 10px;
    flex-wrap: wrap;
}
.lm-type-btn {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 7px 16px; border-radius: 100px; font-size: 13px;
    font-weight: 700; cursor: pointer; border: 1.5px solid var(--lm-green-bd);
    background: #fff; color: var(--lm-muted); transition: background .15s, color .15s;
}
.lm-type-btn:hover { background: var(--lm-green-bg); color: var(--lm-dark); }
.lm-type-btn.active { background: var(--lm-green); color: #fff; border-color: var(--lm-green); }

/* ── Event popup on main map ── */
.liberta-popup-event h4 { margin: 6px 0 4px; color: #1a2e1a; font-size: 15px; }
.lm-ev-tag {
    display: inline-block; font-size: 11px; font-weight: 700;
    background: #dbeafe; color: #1d4ed8; border-radius: 100px;
    padding: 2px 9px; margin-bottom: 4px;
}
.lm-ev-popup-date { font-size: 12px; color: #1d4ed8; font-weight: 600; margin-bottom: 3px; }
.lm-ev-popup-addr { font-size: 12px; color: var(--lm-muted); margin-bottom: 8px; }
.lm-ev-popup-foot { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 8px; }
.lm-ev-badge {
    display: inline-block; font-size: 12px; font-weight: 700;
    padding: 3px 9px; border-radius: 100px;
}
.lm-ev-badge-free { background: #dff0e8; color: var(--lm-green); }
.lm-ev-badge-paid { background: #fef3c7; color: #92400e; }
.lm-ev-popup-rsvp { font-size: 12px; color: #1d4ed8; font-weight: 600; }

/* ── Events page: mini-map toggle button ── */
.ll-events-map-btn {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 7px 16px; background: #eff6ff;
    color: #1d4ed8; border-radius: 8px; font-size: 13px;
    font-weight: 700; border: 1.5px solid #bfdbfe;
    cursor: pointer; transition: background .15s;
}
.ll-events-map-btn:hover,
.ll-events-map-btn.active { background: #1d4ed8; color: #fff; border-color: #1d4ed8; }

/* ── Events page: mini-map container ── */
.ll-events-map-wrap {
    margin-bottom: 24px; border-radius: 12px;
    overflow: hidden; box-shadow: 0 2px 12px rgba(0,0,0,.1);
    border: 1.5px solid var(--lm-green-bd);
}

