/*!
 * Winevizer Embed v1.2 — shared stylesheet
 * Used by:
 *   - winevizer.js (injects this CSS at runtime via <style>)
 *   - SSR endpoint (/r/{token}, /resto/api/e/{token}/embed.html) via <link>
 * Keep in sync with the CSS string inside winevizer.js (injectStyles).
 */
.wvz-embed {
    --wvz-primary: #8e041b;
    --wvz-white: #fefefe;
    --wvz-whitelight: #d0d0ce;
    --wvz-black: #1e1e1e;
    --wvz-bg-grey: #424242;
    --wvz-border-grey: #575757;
    background: var(--wvz-black);
    color: var(--wvz-white);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    line-height: 1.4;
    border-top: 2px solid var(--wvz-border-grey);
    overflow: hidden;
}
.wvz-embed * { box-sizing: border-box; }
.wvz-embed img { display: block; max-width: 100%; }

/* Toolbar (JS embed only — SSR omits it) */
.wvz-embed .wvz-toolbar { display: flex; gap: 8px; padding: 10px 12px; flex-wrap: wrap; align-items: center; background: var(--wvz-black); border-bottom: 1px solid var(--wvz-border-grey); }
.wvz-embed .wvz-search-input { flex: 1 1 220px; padding: 8px 12px; border: 1px solid var(--wvz-border-grey); border-radius: 5px; font-size: 0.95rem; background: var(--wvz-bg-grey); color: var(--wvz-white); }
.wvz-embed .wvz-search-input::placeholder { color: var(--wvz-whitelight); }
.wvz-embed .wvz-filter { padding: 8px 10px; border: 1px solid var(--wvz-border-grey); border-radius: 5px; font-size: 0.9rem; background: var(--wvz-bg-grey); color: var(--wvz-white); }
.wvz-embed .wvz-filter option.wvz-opt-country { font-weight: 700; }
.wvz-embed .wvz-filter option.wvz-opt-region { font-weight: 400; }
.wvz-embed .wvz-filter-price { display: flex; align-items: center; gap: 8px; padding: 4px 10px; }
.wvz-embed .wvz-filter-price-label { white-space: nowrap; font-size: 0.8rem; color: var(--wvz-whitelight); }
.wvz-embed .wvz-filter-price input[type=range] { accent-color: var(--wvz-primary); }

/* List & dividers */
.wvz-embed .wvz-list { background: var(--wvz-black); }
.wvz-embed .wvz-divider { background: var(--wvz-black); color: var(--wvz-white); padding: 12px 12px; font-weight: bold; display: flex; align-items: center; gap: 10px; border-top: 1px solid var(--wvz-border-grey); }
.wvz-embed .wvz-divider-bullet { width: 14px; height: 14px; border-radius: 50%; flex-shrink: 0; border: 1px solid rgba(255,255,255,0.2); }
.wvz-embed .wvz-divider-title { font-size: 1rem; font-weight: 700; margin: 0; }
.wvz-embed .wvz-sub-divider-title { font-size: 0.95rem; font-weight: 600; margin: 0; }
/* Sub-divider (2e niveau : région / pays sous une couleur) */
.wvz-embed .wvz-sub-divider { background: #505050; padding: 8px 12px; border-top: 0; gap: 8px; }
.wvz-embed .wvz-sub-divider-flag { width: 22px; height: 22px; flex-shrink: 0; }
.wvz-embed .wvz-sub-divider-title { font-size: 0.95rem; font-weight: 600; }
.wvz-embed .wvz-group { display: flex; flex-direction: column; }

/* Digital wine card — img-container utilise la technique resto :
   image positionnée en absolute, débordant le cadre, centrée par
   transform: translate(-50%, -50%). La bouteille apparaît zoomée. */
.wvz-embed.wvz-design-digital .wvz-wine { display: flex; position: relative; width: 100%; background: var(--wvz-bg-grey); min-height: 145px; align-items: center; border: 0; border-bottom: 6px solid var(--wvz-border-grey); padding: 10px; gap: 10px; }
.wvz-embed .wvz-wine-image { height: 125px; width: 60px; flex-shrink: 0; background: var(--wvz-white); border: 1px solid var(--wvz-black); border-radius: 5px; padding: 7px 10px; overflow: hidden; position: relative; }
.wvz-embed .wvz-wine-image img { height: 110px; max-width: none; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); -webkit-transform: translate(-50%, -50%); }
.wvz-embed .wvz-wine-image-placeholder { width: 100%; height: 100%; }
.wvz-embed .wvz-wine-info { flex: 1; min-width: 0; padding-right: 90px; padding-top: 4px; line-height: 1.25rem; position: relative; }
.wvz-embed .wvz-wine-winery { color: var(--wvz-whitelight); font-size: 0.8rem; display: block; }
.wvz-embed .wvz-wine-name { font-size: 0.95rem; line-height: 1.1rem; color: var(--wvz-white); display: block; font-weight: 700; margin-top: 2px; margin-bottom: 0; }
.wvz-embed .wvz-wine-vintage { font-weight: normal; }
.wvz-embed .wvz-wine-location { display: block; margin-top: 5px; }
.wvz-embed .wvz-wine-location-text { font-size: 0.7rem; color: var(--wvz-whitelight); }
.wvz-embed .wvz-flag { display: inline-block; width: 18px; height: 18px; vertical-align: middle; margin-right: 5px; }
.wvz-embed .wvz-wine-cepages { margin-top: 4px; font-size: 0.7rem; color: var(--wvz-whitelight); font-style: italic; }
.wvz-embed .wvz-wine-note { display: inline-block; max-width: 65%; background: grey; color: var(--wvz-white); font-size: 0.65rem; border-radius: 5px; margin: 8px 0 0; line-height: 0.9rem; padding: 5px 8px; }

/* Prices (bottom-right) — pas de padding vertical sur le container, le padding
   interne est sur .wvz-price-wrapper / .wvz-price-cont pour rester collés. */
.wvz-embed .wvz-wine-prices { position: absolute; right: 0; bottom: 0; background: var(--wvz-black); color: var(--wvz-white); border-radius: 5px; font-size: 0.85rem; min-width: 90px; display: flex; flex-direction: column; align-items: stretch; overflow: hidden; }
.wvz-embed .wvz-wine-prices.wvz-prices-2,
.wvz-embed .wvz-wine-prices.wvz-prices-3,
.wvz-embed .wvz-wine-prices.wvz-prices-4 { flex-direction: row; flex-wrap: wrap; justify-content: flex-end; }
.wvz-embed .wvz-price { display: flex; align-items: stretch; }
.wvz-embed .wvz-price-wrapper { display: flex; flex-direction: column; justify-content: center; padding: 4px 8px; font-weight: 700; }
.wvz-embed .wvz-price-value { white-space: nowrap; line-height: 1; }
.wvz-embed .wvz-price-value.wvz-price-promo { text-decoration: line-through; opacity: 0.7; font-weight: 400; }
.wvz-embed .wvz-price-promo-value { color: #ff4444; font-weight: 700; line-height: 1; }
.wvz-embed .wvz-price-cont { font-size: 0.7rem; background: var(--wvz-border-grey); padding: 4px 8px; white-space: nowrap; display: flex; align-items: center; }

/* Wine color tags + dividers (bg color used by both) */
.wvz-embed .wvz-color-1 { background: #d71320; } .wvz-embed .wvz-color-bg-1 { border-left: 4px solid #d71320; }
.wvz-embed .wvz-color-2 { background: #c9f56a; } .wvz-embed .wvz-color-bg-2 { border-left: 4px solid #c9f56a; }
.wvz-embed .wvz-color-3 { background: #07f561; } .wvz-embed .wvz-color-bg-3 { border-left: 4px solid #07f561; }
.wvz-embed .wvz-color-4 { background: #f16eb3; } .wvz-embed .wvz-color-bg-4 { border-left: 4px solid #f16eb3; }
.wvz-embed .wvz-color-5 { background: #ddbd54; } .wvz-embed .wvz-color-bg-5 { border-left: 4px solid #ddbd54; }
.wvz-embed .wvz-color-6 { background: #ebae32; } .wvz-embed .wvz-color-bg-6 { border-left: 4px solid #ebae32; }
.wvz-embed .wvz-color-7 { background: #adadad; } .wvz-embed .wvz-color-bg-7 { border-left: 4px solid #adadad; }
.wvz-embed .wvz-color-9 { background: orange; } .wvz-embed .wvz-color-bg-9 { border-left: 4px solid orange; }
.wvz-embed .wvz-color-11 { background: #adadad; } .wvz-embed .wvz-color-bg-11 { border-left: 4px solid #adadad; }

/* Mosaic design — 3 vues séquentielles (colors -> wines -> detail).
   Pas de toolbar / filtres : la couleur sélectionnée fait office de filtre. */
.wvz-embed .wvz-hidden { display: none !important; }
.wvz-embed.wvz-design-mosaic { padding: 12px; }
.wvz-embed.wvz-design-mosaic .wvz-mosaic-root { display: block; transition: opacity 0.18s ease, transform 0.18s ease; }
.wvz-embed.wvz-design-mosaic .wvz-mosaic-root.wvz-mosaic-fade-out { opacity: 0; transform: translateY(4px); }
.wvz-embed.wvz-design-mosaic .wvz-mosaic-root.wvz-mosaic-fade-in { opacity: 1; transform: translateY(0); }
.wvz-embed .wvz-mosaic-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 0 0 12px; border-bottom: 1px solid var(--wvz-border-grey); margin-bottom: 12px; flex-wrap: wrap; }
.wvz-embed .wvz-mosaic-toolbar-title { font-weight: 700; font-size: 1.1rem; }
.wvz-embed .wvz-mosaic-toolbar-filters { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; flex: 1 1 220px; min-width: 0; }
.wvz-embed .wvz-mosaic-search { flex: 1 1 160px; min-width: 0; }
.wvz-embed .wvz-mosaic-color-tag { display: inline-flex; align-items: center; padding: 6px 14px; border-radius: 5px; font-weight: 700; font-size: 0.95rem; color: #1e1e1e; flex-shrink: 0; }
.wvz-embed .wvz-mosaic-back { background: var(--wvz-bg-grey); color: var(--wvz-white); border: 1px solid var(--wvz-border-grey); border-radius: 5px; padding: 6px 12px; font-size: 0.9rem; cursor: pointer; display: inline-flex; align-items: center; gap: 6px; flex-shrink: 0; }
.wvz-embed .wvz-mosaic-back:hover { background: var(--wvz-border-grey); }
.wvz-embed .wvz-mosaic-back-arrow { font-size: 1.1rem; line-height: 1; }

/* Prev/Next nav dans la vue detail */
.wvz-embed .wvz-mosaic-nav { display: inline-flex; align-items: center; gap: 8px; }
.wvz-embed .wvz-mosaic-nav-btn { background: var(--wvz-bg-grey); color: var(--wvz-white); border: 1px solid var(--wvz-border-grey); border-radius: 50%; width: 32px; height: 32px; font-size: 1rem; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; padding: 0; }
.wvz-embed .wvz-mosaic-nav-btn:hover:not([disabled]) { background: var(--wvz-border-grey); }
.wvz-embed .wvz-mosaic-nav-btn[disabled] { opacity: 0.35; cursor: not-allowed; }
.wvz-embed .wvz-mosaic-nav-pos { font-size: 0.85rem; color: var(--wvz-whitelight); min-width: 60px; text-align: center; }

/* Vue 1 : grille de couleurs (responsive jusqu'à 6 cols) */
.wvz-embed .wvz-mosaic-colors { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (min-width: 480px) { .wvz-embed .wvz-mosaic-colors { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 720px) { .wvz-embed .wvz-mosaic-colors { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 1000px) { .wvz-embed .wvz-mosaic-colors { grid-template-columns: repeat(5, 1fr); } }
@media (min-width: 1280px) { .wvz-embed .wvz-mosaic-colors { grid-template-columns: repeat(6, 1fr); } }
.wvz-embed .wvz-mosaic-color-tile { display: flex; flex-direction: column; align-items: center; justify-content: flex-start; gap: 8px; padding: 14px 10px 12px; background: var(--wvz-bg-grey); border: 1px solid var(--wvz-border-grey); border-radius: 8px; color: var(--wvz-white); cursor: pointer; transition: transform 0.15s, background 0.15s; }
.wvz-embed .wvz-mosaic-color-tile:hover { background: var(--wvz-border-grey); transform: translateY(-2px); }
.wvz-embed .wvz-mosaic-color-icon { width: 72px; height: 72px; display: flex; align-items: center; justify-content: center; }
.wvz-embed .wvz-mosaic-color-icon img { width: 100%; height: 100%; object-fit: contain; }
.wvz-embed .wvz-mosaic-color-swatch { width: 56px; height: 56px; border-radius: 50%; border: 2px solid rgba(0,0,0,0.1); }
.wvz-embed .wvz-mosaic-color-label { font-weight: 700; font-size: 0.95rem; text-align: center; }
.wvz-embed .wvz-mosaic-color-count { font-size: 0.75rem; color: var(--wvz-whitelight); }

/* Vue 2 : grille d'images vins (responsive jusqu'à 6 cols) */
.wvz-embed .wvz-mosaic-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (min-width: 480px) { .wvz-embed .wvz-mosaic-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 720px) { .wvz-embed .wvz-mosaic-grid { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 1000px) { .wvz-embed .wvz-mosaic-grid { grid-template-columns: repeat(5, 1fr); } }
@media (min-width: 1280px) { .wvz-embed .wvz-mosaic-grid { grid-template-columns: repeat(6, 1fr); } }
.wvz-embed .wvz-mosaic-tile { display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 12px; background: var(--wvz-bg-grey); border: 1px solid var(--wvz-border-grey); border-radius: 8px; cursor: pointer; transition: transform 0.15s, background 0.15s; color: var(--wvz-white); }
.wvz-embed .wvz-mosaic-tile:hover { background: var(--wvz-border-grey); transform: translateY(-2px); }
.wvz-embed .wvz-mosaic-tile-image { width: 100%; height: 160px; background: var(--wvz-white); border-radius: 5px; padding: 10px; overflow: hidden; position: relative; display: flex; align-items: center; justify-content: center; }
.wvz-embed .wvz-mosaic-tile-image img:not(.wvz-mosaic-tile-flag) { max-height: 100%; max-width: 100%; object-fit: contain; }
.wvz-embed .wvz-mosaic-tile-flag { position: absolute; top: 6px; right: 6px; width: 22px; height: 22px; }
.wvz-embed .wvz-mosaic-tile-placeholder { width: 60%; height: 80%; background: linear-gradient(135deg, #ddd 0%, #ccc 100%); border-radius: 4px; }
.wvz-embed .wvz-mosaic-tile-name { font-size: 0.8rem; font-weight: 700; text-align: center; line-height: 1.2; min-height: 1.2em; }
.wvz-embed .wvz-mosaic-tile-vintage { font-weight: normal; color: var(--wvz-whitelight); }
.wvz-embed .wvz-mosaic-tile-region { font-size: 0.7rem; color: var(--wvz-whitelight); text-align: center; font-style: italic; line-height: 1.2; }

/* Vue 3 : detail vin (in-place, pas un overlay) */
.wvz-embed .wvz-mosaic-detail { display: flex; gap: 20px; padding: 16px; background: var(--wvz-bg-grey); border-radius: 8px; flex-direction: column; }
@media (min-width: 600px) { .wvz-embed .wvz-mosaic-detail { flex-direction: row; } }
.wvz-embed .wvz-mosaic-detail-image { flex-shrink: 0; width: 200px; max-width: 100%; height: 280px; background: var(--wvz-white); border-radius: 5px; padding: 16px; display: flex; align-items: center; justify-content: center; margin: 0 auto; }
.wvz-embed .wvz-mosaic-detail-image img { max-height: 100%; max-width: 100%; object-fit: contain; }
.wvz-embed .wvz-mosaic-detail-info { flex: 1; min-width: 0; position: relative; padding-bottom: 60px; }
.wvz-embed .wvz-mosaic-detail-winery { color: var(--wvz-whitelight); font-size: 0.95rem; }
.wvz-embed .wvz-mosaic-detail-name { font-size: 1.4rem; margin: 4px 0 8px; color: var(--wvz-white); font-weight: 700; }
.wvz-embed .wvz-mosaic-detail-vintage { font-weight: normal; }
.wvz-embed .wvz-mosaic-detail-location { color: var(--wvz-whitelight); font-size: 0.9rem; margin-bottom: 6px; display: flex; align-items: center; gap: 8px; }
.wvz-embed .wvz-mosaic-detail-location .wvz-flag { width: 22px; height: 22px; }
.wvz-embed .wvz-mosaic-detail-cepages { font-size: 0.85rem; color: var(--wvz-whitelight); margin-bottom: 8px; display: flex; align-items: center; gap: 8px; }
.wvz-embed .wvz-mosaic-detail-icon { width: 18px; height: 18px; flex-shrink: 0; filter: brightness(0) invert(1) opacity(0.7); }
.wvz-embed .wvz-mosaic-detail-note { background: grey; color: var(--wvz-white); font-size: 0.85rem; border-radius: 5px; padding: 8px 10px; margin: 8px 0; }
.wvz-embed .wvz-mosaic-detail .wvz-wine-prices { right: 0; bottom: 0; }

/* Paper design (lecture) */
.wvz-embed.wvz-design-paper { --wvz-paper-bg: #fdfbf6; --wvz-paper-text: #2a2a2a; --wvz-paper-border: #d8cfba; background: var(--wvz-paper-bg); color: var(--wvz-paper-text); border-top: 0; }
.wvz-embed.wvz-design-paper .wvz-toolbar { background: var(--wvz-paper-bg); border-bottom: 1px solid var(--wvz-paper-border); }
.wvz-embed.wvz-design-paper .wvz-search-input,
.wvz-embed.wvz-design-paper .wvz-filter { background: #fff; color: var(--wvz-paper-text); border-color: var(--wvz-paper-border); }
.wvz-embed.wvz-design-paper .wvz-search-input::placeholder { color: #999; }
.wvz-embed.wvz-design-paper .wvz-list { background: var(--wvz-paper-bg); padding: 16px; }
.wvz-embed.wvz-design-paper .wvz-divider { background: transparent; color: var(--wvz-primary); border-top: 1px solid var(--wvz-paper-border); padding: 16px 0 6px; font-size: 1.1rem; }
.wvz-embed.wvz-design-paper .wvz-wine-row { display: flex; justify-content: space-between; align-items: baseline; padding: 8px 0; border-bottom: 1px dotted var(--wvz-paper-border); gap: 12px; }
.wvz-embed.wvz-design-paper .wvz-wine-row em { color: #6b6b6b; font-style: italic; font-size: 0.85em; font-weight: normal; }
.wvz-embed.wvz-design-paper .wvz-wine-row-name { flex: 1; min-width: 0; }
.wvz-embed.wvz-design-paper .wvz-wine-row-price { font-weight: 600; padding-left: 12px; white-space: nowrap; color: var(--wvz-primary); }
.wvz-embed.wvz-design-paper .wvz-price-paper { margin-left: 0; }
.wvz-embed.wvz-design-paper .wvz-price-paper + .wvz-price-paper::before { content: '\00a0·\00a0'; color: #b0a896; font-weight: 400; }
.wvz-embed.wvz-design-paper .wvz-price-paper .wvz-price-cont { background: none; padding: 0; display: inline; font-size: 0.75em; font-style: italic; font-weight: 400; color: #8a8278; margin-right: 2px; }

/* States */
.wvz-embed .wvz-loading { display: flex; align-items: center; gap: 12px; padding: 5vh 0; color: var(--wvz-whitelight); justify-content: center; background: var(--wvz-bg-grey); }
.wvz-embed .wvz-spinner { width: 28px; height: 28px; border: 3px solid var(--wvz-border-grey); border-top-color: var(--wvz-primary); border-radius: 50%; animation: wvz-spin 0.8s linear infinite; }
@keyframes wvz-spin { to { transform: rotate(360deg); } }
.wvz-embed .wvz-error { padding: 16px; background: #fdf3f3; color: #a33; border: 1px solid #f3c8c8; border-radius: 4px; margin: 16px; }
.wvz-embed .wvz-empty { padding: 40px 10px; background: var(--wvz-border-grey); color: var(--wvz-white); font-size: 0.95rem; text-align: center; }

/* Focus visible — navigation clavier (WCAG 2.1 AA) */
.wvz-embed button:focus { outline: none; }
.wvz-embed button:focus-visible { outline: 3px solid var(--wvz-primary); outline-offset: 2px; }
.wvz-embed.wvz-design-mosaic .wvz-mosaic-color-tile:focus-visible { outline: 3px solid var(--wvz-primary); outline-offset: 3px; box-shadow: 0 0 0 5px rgba(142,4,27,0.25); }
.wvz-embed.wvz-design-mosaic .wvz-mosaic-tile:focus-visible { outline: 3px solid var(--wvz-primary); outline-offset: 3px; }
.wvz-embed.wvz-design-mosaic .wvz-mosaic-back:focus-visible,
.wvz-embed.wvz-design-mosaic .wvz-mosaic-nav-btn:focus-visible { outline: 3px solid var(--wvz-primary); outline-offset: 2px; }
.wvz-embed.wvz-design-paper button:focus-visible { outline: 3px solid var(--wvz-paper-text, #2a2a2a); outline-offset: 2px; }

/* Pas de border-bottom sur la dernière carte d'un groupe (la section de
   séparation suivante fait déjà la coupure visuelle). */
.wvz-embed.wvz-design-digital .wvz-group .wvz-wine:last-child { border-bottom: 0; }

/* Responsive — 2 colonnes sur >720px avec un séparateur vertical entre
   les deux vins de la même ligne. */
@media (min-width: 720px) {
    .wvz-embed.wvz-design-digital .wvz-group { display: grid; grid-template-columns: 1fr 1fr; gap: 0; }
    .wvz-embed.wvz-design-digital .wvz-group .wvz-wine:nth-child(odd) { border-right: 6px solid var(--wvz-border-grey); }
    .wvz-embed.wvz-design-digital .wvz-group .wvz-wine:nth-child(odd):last-child { border-right: 0; }
    /* En 2-colonnes, les 2 dernières cartes d'un groupe à compte pair sont
       sur la même ligne : retirer aussi border-bottom sur l'avant-dernière
       (en position impaire). */
    .wvz-embed.wvz-design-digital .wvz-group .wvz-wine:nth-last-child(2):nth-child(odd) { border-bottom: 0; }
    .wvz-embed .wvz-wine-info { padding-right: 110px; }
}
