

/* merged: boutique.css */

/* Boutique vendeur (vitrine publique) */

:root {
    --map-white: #fff;
    --map-white-full: #ffffff;
    --map-surface: #f8fafc;
    --map-surface-muted: #f1f5f9;
    --map-border: #e2e8f0;
    --map-text: #0f172a;
    --map-text-strong: #2c3e50;
    --map-text-muted: #64748b;
    --map-neutral: #666;
    --map-neutral-dark: #333;
    --map-neutral-light: #999;
    --map-warning: #ffc107;
    --map-dark: #0b0f14;
    --map-panel-line: rgba(15, 23, 42, 0.18);
    --map-white-line: rgba(255,255,255,0.14);
    --map-white-line-strong: rgba(255,255,255,0.18);
    --map-white-text: rgba(255,255,255,0.92);
    --map-overlay-soft: rgba(0,0,0,0.28);
}

.shop-page {
    max-width: 1200px;
    margin: 0 auto;
    padding: 18px;
    background: transparent;
}

.shop-shelf {
    margin: 12px 0 22px;
}

/* Hero moderne (bannière + overlay) */
.seller-hero { position: relative; border-radius: 18px; overflow: hidden; border: 1px solid color-mix(in oklab, var(--shop-accent) 22%, rgba(0,0,0,0.10)); }
.seller-hero__bg {
    position: absolute; inset: 0;
    background:
      var(--seller-banner-url, none),
      radial-gradient(1100px 420px at 20% 0%, color-mix(in oklab, var(--shop-accent) 30%, transparent) 0%, transparent 60%),
      radial-gradient(900px 420px at 85% 0%, color-mix(in oklab, var(--shop-accent-2) 26%, transparent) 0%, transparent 62%),
      linear-gradient(135deg, color-mix(in oklab, var(--shop-accent) 55%, var(--map-dark)), color-mix(in oklab, var(--shop-accent-2) 45%, var(--map-dark)));
    background-size: cover;
    background-position: center;
    filter: saturate(1.05) contrast(1.02);
    transform: scale(1.02);
}
.seller-hero__overlay {
    position: absolute; inset: 0;
    background:
      linear-gradient(180deg, rgba(0,0,0,0.30) 0%, rgba(0,0,0,0.55) 60%, rgba(0,0,0,0.75) 100%),
      radial-gradient(900px 500px at 20% 30%, rgba(255,255,255,0.10) 0%, transparent 55%);
    pointer-events: none;
}
.seller-hero__inner { position: relative; padding: 18px; }

.seller-header {
    color: white;
    padding: 22px 18px;
    border-radius: 14px;
    margin-bottom: 18px;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    flex-wrap: wrap;
    gap: 20px clamp(20px, 4vw, 44px);
    background: rgba(0,0,0,0.14);
    border: 1px solid var(--map-white-line);
    backdrop-filter: blur(10px);
}

/* Variables de thèmes dans /css/showcase-themes.css */

.seller-welcome {
    margin-top: 12px;
    padding: 10px 12px;
    background: var(--map-white-line);
    border: 1px solid var(--map-white-line-strong);
    border-radius: 10px;
    font-weight: 600;
    font-size: 14px;
}
.seller-badges { display:flex; flex-wrap:wrap; gap:8px; margin-top: 10px; }
.seller-badge {
    background: var(--map-white-line-strong);
    border: 1px solid rgba(255,255,255,0.2);
    color: var(--map-white);
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
}
.seller-bio { margin-top: 14px; max-width: 680px; }
.seller-bio-text { margin: 0 0 10px 0; color: var(--map-white-text); font-size: 14px; line-height: 1.45; }
.seller-links { display:flex; flex-wrap:wrap; gap:10px; }
.seller-links a { color: var(--shop-link); font-weight: 700; text-decoration: none; border-bottom: 1px solid rgba(255,255,255,0.35); }
.seller-links a:hover { opacity: 0.95; }

.seller-info {
    display: flex;
    align-items: flex-start;
    gap: 20px;
    flex: 1 1 280px;
    min-width: 0;
}

.seller-details {
    flex: 1 1 auto;
    min-width: 0;
}

.seller-avatar {
    width: 92px;
    height: 92px;
    border-radius: 50%;
    overflow: hidden;
    border: 1px solid var(--map-white-line-strong);
    box-shadow: 0 10px 30px var(--map-overlay-soft);
}

.seller-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.avatar-placeholder {
    width: 100%;
    height: 100%;
    background: rgba(255,255,255,0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    font-weight: bold;
}

.seller-details h1 {
    margin: 0 0 10px 0;
    font-size: 34px;
    letter-spacing: -0.02em;
}

.seller-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 14px;
    font-size: 14px;
    opacity: 0.9;
}

.rating .stars {
    color: var(--map-warning);
    margin-right: 5px;
}

.seller-stats {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 12px clamp(14px, 2.5vw, 22px);
    flex: 0 0 auto;
    align-self: center;
    margin-left: auto;
    padding: 8px 0 8px clamp(18px, 3.5vw, 36px);
    border-left: 1px solid rgba(255, 255, 255, 0.22);
}

.stat-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    min-width: 86px;
    max-width: 130px;
    min-height: 76px;
    padding: 10px 14px;
    border-radius: 14px;
    background: rgba(255,255,255,0.08);
    border: 1px solid var(--map-white-line);
    box-sizing: border-box;
}

.stat-number {
    font-size: 26px;
    font-weight: 900;
    line-height: 1.1;
    margin-bottom: 4px;
}

.stat-label {
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.02em;
    opacity: 0.88;
    line-height: 1.2;
}

.shop-content {
    background:
      radial-gradient(1200px 420px at 20% 0%, color-mix(in oklab, var(--shop-accent) 16%, transparent) 0%, transparent 62%),
      radial-gradient(900px 420px at 85% 0%, color-mix(in oklab, var(--shop-accent-2) 14%, transparent) 0%, transparent 64%),
      color-mix(in oklab, var(--shop-surface) 92%, var(--map-white-full));
    border-radius: 18px;
    border: 1px solid var(--shop-border);
    padding: 22px;
}

.shop-theme-midnight .shop-content {
    color: var(--map-white-text);
    background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.03));
}

.shop-theme-midnight .listing-info h3 a { color: var(--map-white-text); }
.shop-theme-midnight .listing-description { color: rgba(255,255,255,0.72); }
.shop-theme-midnight .listing-meta { color: rgba(255,255,255,0.55); }
.shop-theme-midnight .listing-card { border-color: rgba(255,255,255,0.12); }
.shop-theme-midnight .image-placeholder { color: rgba(255,255,255,0.6); }

.shop-tabs {
    display: flex;
    border-bottom: 1px solid color-mix(in oklab, var(--shop-accent) 18%, var(--shop-border));
    margin-bottom: 18px;
    gap: 6px;
}

.tab-btn {
    background: none;
    border: none;
    padding: 12px 14px;
    font-size: 15px;
    font-weight: bold;
    color: color-mix(in oklab, var(--shop-ink) 55%, var(--map-text-muted));
    cursor: pointer;
    border-bottom: 3px solid transparent;
    border-radius: 12px 12px 0 0;
}

.tab-btn.active {
    color: var(--shop-accent);
    border-bottom-color: var(--shop-accent);
}

.tab-btn:hover {
    color: var(--shop-accent);
}

.shop-theme-midnight .tab-btn { color: rgba(255,255,255,0.75); }
.shop-theme-midnight .shop-tabs { border-bottom-color: var(--map-white-line); }

.tab-content {
    display: none;
}

.tab-content.active {
    display: block;
}

.shop-tab-title {
    margin: 0 0 18px;
    font-size: 1.15rem;
    font-weight: 800;
    letter-spacing: -0.02em;
    color: color-mix(in oklab, var(--shop-ink) 88%, var(--map-text-muted));
}

.listings-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 20px;
}

/* Colonnes configurables (réglage vendeur) */
.listings-grid.shop-grid-cols-2 { grid-template-columns: repeat(2, minmax(220px, 1fr)); }
.listings-grid.shop-grid-cols-3 { grid-template-columns: repeat(3, minmax(220px, 1fr)); }
.listings-grid.shop-grid-cols-4 { grid-template-columns: repeat(4, minmax(200px, 1fr)); }
.listings-grid.shop-grid-cols-5 { grid-template-columns: repeat(5, minmax(180px, 1fr)); }
.listings-grid.shop-grid-cols-6 { grid-template-columns: repeat(6, minmax(170px, 1fr)); }

.listing-card {
    border: 1px solid var(--shop-border);
    border-radius: 16px;
    overflow: hidden;
    transition: transform 0.2s;
    background: color-mix(in oklab, var(--shop-surface) 96%, var(--map-white-full));
}

.listing-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

.listing-card:hover {
    border-color: color-mix(in oklab, var(--shop-accent) 45%, var(--shop-border));
}

.listing-image {
    height: 210px;
    background: color-mix(in oklab, var(--shop-surface) 92%, var(--map-surface-muted));
}

.listing-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 0;
}

.image-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--map-neutral-light);
    font-size: 14px;
}

.listing-info {
    padding: 15px;
}

.listing-info h3 {
    margin: 0 0 10px 0;
    font-size: 16px;
    line-height: 1.25;
}

.listing-info h3 a {
    color: var(--map-neutral-dark);
    text-decoration: none;
}

.listing-info h3 a:hover {
    color: var(--shop-accent);
}

.listing-price {
    font-size: 20px;
    font-weight: bold;
    color: var(--shop-accent);
    margin: 0 0 10px 0;
}

.listing-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
}

.listing-tag {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 800;
    border: 1px solid color-mix(in oklab, var(--shop-accent) 18%, var(--shop-border));
    color: color-mix(in oklab, var(--shop-accent) 60%, var(--map-text-muted));
    background: color-mix(in oklab, var(--shop-surface) 88%, transparent);
}

.listing-tag--gold {
    border-color: color-mix(in oklab, var(--shop-accent) 40%, var(--shop-border));
    color: var(--shop-link);
    background: color-mix(in oklab, var(--shop-accent) 22%, transparent);
}

.listings-grid--grid_dense { grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); }
.listings-grid--list { grid-template-columns: 1fr; }
.listings-grid--list .listing-card { display:flex; gap: 14px; }
.listings-grid--list .listing-image { width: 220px; height: 160px; flex-shrink: 0; }
.listings-grid--list .listing-image img { height: 160px !important; border-radius: 10px; }
.listings-grid--list .listing-info { flex: 1; min-width: 0; }

.listing-description {
    color: var(--map-neutral);
    font-size: 14px;
    line-height: 1.4;
    margin: 0 0 10px 0;
}

.listing-note {
    margin: 10px 0 0;
    padding: 10px 12px;
    border-radius: 12px;
    border: 1px solid color-mix(in oklab, var(--shop-accent) 18%, var(--shop-border));
    background: color-mix(in oklab, var(--shop-surface) 90%, transparent);
    color: color-mix(in oklab, var(--shop-ink) 86%, var(--map-text-muted));
    font-size: 13px;
    line-height: 1.35;
}

.listing-meta {
    font-size: 12px;
    color: var(--map-neutral-light);
}

.no-listings {
    text-align: center;
    padding: 60px 20px;
    color: var(--map-neutral);
    grid-column: 1 / -1;
}

.reviews-list {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.review-card {
    padding: 20px;
    border: 1px solid #e1e5e9;
    border-radius: 8px;
}

.review-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px;
}

.review-author strong {
    color: var(--map-neutral-dark);
}

.review-date {
    color: var(--map-neutral);
    font-size: 14px;
    margin-left: 10px;
}

.review-rating {
    color: var(--map-warning);
    font-size: 18px;
}

.review-comment {
    color: #555;
    line-height: 1.5;
    margin-bottom: 10px;
}

.review-product {
    font-size: 14px;
    color: var(--map-neutral);
    font-style: italic;
}

/* Tablette / fenêtre étroite : stats sur une ligne dédiée sous le bloc identité */
@media (max-width: 900px) and (min-width: 769px) {
    .seller-header {
        gap: 18px;
    }

    .seller-info {
        flex-basis: 100%;
    }

    .seller-stats {
        width: 100%;
        margin-left: 0;
        padding: 14px 0 4px;
        border-left: none;
        border-top: 1px solid rgba(255, 255, 255, 0.18);
        justify-content: flex-end;
    }
}

@media (max-width: 768px) {
    .seller-header {
        flex-direction: column;
        align-items: stretch;
        gap: 22px;
        text-align: center;
    }
    .seller-hero__inner { padding: 14px; }

    .seller-info {
        flex-direction: column;
        align-items: center;
    }

    .seller-stats {
        width: 100%;
        margin-left: 0;
        padding: 16px 8px 8px;
        border-left: none;
        border-top: 1px solid rgba(255, 255, 255, 0.18);
        justify-content: center;
        gap: 14px 20px;
    }

    .stat-item {
        min-width: 92px;
        flex: 0 1 auto;
    }
    
    .listings-grid {
        grid-template-columns: 1fr;
    }
    .listings-grid--list .listing-card { flex-direction: column; }
    .listings-grid--list .listing-image { width: 100%; height: 200px; }
}

/* —— Titre page-shell (h1) + air sous la nav principale —— */
main:has(.shop-page) {
    padding-top: clamp(20px, 4vw, 40px);
}

main:has(.shop-page) .page-container {
    padding-top: 0;
}

main:has(.shop-page) .page-title {
    text-align: center;
    font-family: var(--font-heading, 'Poppins', 'Inter', sans-serif);
    font-size: clamp(1.1rem, 2.4vw, 1.45rem);
    font-weight: 700;
    color: var(--primary-dark, var(--map-text-strong));
    letter-spacing: -0.02em;
    line-height: 1.35;
    max-width: 40rem;
    margin: 0 auto clamp(18px, 2.5vw, 28px);
    padding: 0 12px;
}



/* merged: carte-statues.css */

.carte-statues-page {
  max-width: 1100px;
  margin: 0 auto;
  padding: 1.5rem 1rem 3rem;
}
.carte-statues-lead {
  color: var(--muted, var(--map-text-muted));
  margin-bottom: 1rem;
}
.carte-statues-map {
  height: 70vh;
  min-height: 320px;
  border-radius: 12px;
  border: 1px solid var(--border, var(--map-border));
  overflow: hidden;
}

/* La carte ne doit jamais passer au-dessus des menus du header */
.carte-statues-map .leaflet-container {
  z-index: 0;
}

/* Réduire explicitement la pile Leaflet (contrôles/panes) sous le header */
.carte-statues-map .leaflet-pane,
.carte-statues-map .leaflet-top,
.carte-statues-map .leaflet-bottom,
.carte-statues-map .leaflet-control {
  z-index: 0 !important;
}
.carte-statues-meta {
  margin-top: 1rem;
  font-size: 0.95rem;
}
.carte-statues-meta--small{
  margin-top: 0.35rem;
  font-size: 0.9rem;
}

.carte-filtres{
  margin: 0.75rem 0 0.75rem;
  padding: 0.75rem;
  border-radius: 12px;
  border: 1px solid var(--border, var(--map-border));
  background: var(--map-white);
}
.carte-filtres-row{
  display: grid;
  grid-template-columns: 180px 1fr 1fr 160px auto;
  gap: 10px;
  align-items: end;
}
@media (max-width: 980px){
  .carte-filtres-row{
    grid-template-columns: 1fr 1fr;
  }
  .carte-filtre--actions{
    grid-column: 1 / -1;
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
  }
}
.carte-filtre label{
  display: block;
  font-weight: 800;
  font-size: 0.9rem;
  color: var(--map-text);
  margin-bottom: 6px;
}
.carte-filtre input,
.carte-filtre select{
  width: 100%;
  appearance: none;
  border: 1px solid var(--border, var(--map-border));
  border-radius: 10px;
  padding: 10px 12px;
  font-weight: 700;
  background: var(--map-white);
}
.carte-filtre input:focus,
.carte-filtre select:focus{
  outline: none;
  border-color: rgba(59, 130, 246, 0.35);
  box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.10);
}

/* Autocomplete (marque/licence/échelle) : la carte n'utilise pas toujours styles.css */
.depot-autocomplete-wrap{
  position: relative;
}
.marque-suggestions-list,
.univers-suggestions-list{
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--map-white);
  border: 1px solid var(--border, var(--map-border));
  border-top: none;
  border-radius: 0 0 10px 10px;
  box-shadow: 0 14px 30px rgba(15, 23, 42, 0.12);
  z-index: 50;
  display: none;
  max-height: 220px;
  overflow-y: auto;
}
.marque-suggestions-list.marque-suggestions-visible,
.univers-suggestions-list.univers-suggestions-visible{
  display: block;
}
.marque-suggestions-list .marque-suggestion-item,
.univers-suggestions-list .univers-suggestion-item{
  padding: 10px 12px;
  cursor: pointer;
  background: var(--map-white);
  border-bottom: 1px solid rgba(226, 232, 240, 0.9);
  font-weight: 700;
  /* Couleur explicite : sinon le texte hérite du parent et devient
     invisible quand le composant est utilisé dans un contexte dark
     (ex. panneau filtres centrale de l'accueil grand-line). */
  color: #1a2236;
}
.marque-suggestions-list .marque-suggestion-item:hover,
.univers-suggestions-list .univers-suggestion-item:hover{
  background: var(--map-surface);
  color: #0a0f1a;
}
.marque-suggestions-list .marque-suggestion-item:last-child,
.univers-suggestions-list .univers-suggestion-item:last-child{
  border-bottom: none;
}

.carte-statues-actions{
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin: 0.75rem 0 0.75rem;
}
.carte-statues-btn{
  appearance: none;
  border: 1px solid var(--border, var(--map-border));
  background: var(--map-white);
  color: var(--map-text);
  font-weight: 800;
  border-radius: 999px;
  padding: 10px 14px;
  cursor: pointer;
}
.carte-statues-btn:hover{
  background: var(--map-surface);
}
.carte-statues-status{
  color: var(--muted, var(--map-text-muted));
  font-size: 0.95rem;
}

/* Marqueur "bulle" avec image de statue */
.lt-bubble-icon {
  background: transparent;
  border: 0;
}
.lt-bubble {
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 2px solid rgba(56, 94, 107, 0.85);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.22);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.lt-bubble-icon--sell .lt-bubble{
  border-color: rgba(185, 28, 28, 0.88);
  box-shadow: 0 10px 24px rgba(185, 28, 28, 0.14), 0 10px 24px var(--map-panel-line);
}
.lt-bubble-icon--wanted .lt-bubble{
  border-color: rgba(29, 78, 216, 0.88);
  box-shadow: 0 10px 24px rgba(29, 78, 216, 0.14), 0 10px 24px var(--map-panel-line);
}
.lt-bubble-icon--showcase .lt-bubble{
  border-color: rgba(180, 83, 9, 0.88);
  box-shadow: 0 10px 24px rgba(180, 83, 9, 0.14), 0 10px 24px var(--map-panel-line);
}
.lt-bubble img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Badge "Vous" (point utilisateur courant) */
.lt-you-icon{
  background: transparent;
  border: 0;
}
.lt-you{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 22px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(242, 222, 185, 0.92);
  color: var(--map-text-strong);
  font-weight: 900;
  font-size: 12px;
  letter-spacing: 0.02em;
  border: 1px solid rgba(44, 62, 80, 0.18);
  box-shadow: 0 10px 26px var(--map-overlay-soft);
}
