/* ============================================================
   Inventaire — feuille de style mobile-first
   ============================================================ */

/* Les variables de couleur (--bg, --surface, --primary, --text, …) sont
   définies dans themes.css, qui est chargé AVANT app.css. On garde ici
   uniquement les variables non-thématiques (rayons, ombres, espacement). */
:root {
    --radius: 14px;
    --radius-lg: 22px;
    --shadow: 0 6px 20px rgba(0, 0, 0, 0.35);
    --gap: 14px;

    /* Tap target minimum size — Apple HIG / Material */
    --tap: 48px;

    /* Safe-area iOS */
    --safe-top: env(safe-area-inset-top, 0px);
    --safe-bot: env(safe-area-inset-bottom, 0px);
}

* {
    box-sizing: border-box;
    -webkit-tap-highlight-color: transparent;
}

html, body {
    margin: 0;
    padding: 0;
    height: 100%;
    background: linear-gradient(160deg, var(--bg), var(--bg-2));
    color: var(--text);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    font-size: 16px;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
}

body {
    padding-top: var(--safe-top);
    padding-bottom: var(--safe-bot);
    min-height: 100vh;
}

button {
    font: inherit;
    color: inherit;
    border: none;
    background: none;
    cursor: pointer;
}

input, button, select, textarea {
    font-family: inherit;
}

h1, h2, h3 { margin: 0 0 8px; font-weight: 600; }
h1 { font-size: 1.6rem; }
h2 { font-size: 1.1rem; color: var(--text-dim); text-transform: uppercase; letter-spacing: 0.05em; }

/* ====== Login screen ====== */
.screen-login {
    display: flex;
    align-items: stretch;
    justify-content: center;
}

.login {
    width: 100%;
    max-width: 420px;
    padding: 32px 20px 24px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 28px;
    margin: auto;
}

.login__header {
    text-align: center;
}

.logo {
    font-size: 56px;
    line-height: 1;
    margin-bottom: 8px;
}

/* --- Logo SVG « tube » inliné sur la page de login (marque Inventaure) ---
   Corps = var(--text), niveau = var(--primary) : géré dans le SVG lui-même. */
.brand-mark {
    height: 104px;
    width: auto;
    margin: 0 auto 12px;
    display: block;
}

/* --- Logo uploadé par l'organisation --- */
.login__org-logo {
    max-width: 200px;
    max-height: 110px;
    margin: 0 auto 12px;
    display: block;
    object-fit: contain;
}

/* --- "propulsé par Inventaure" en bas du header --- */
.login__powered {
    margin-top: 14px;
    font-size: 0.75rem;
    color: var(--text-dim);
    letter-spacing: 0.04em;
    text-align: center;
}
.login__powered strong {
    color: var(--primary);
    font-weight: 700;
    letter-spacing: 0;
}

.login__sub {
    color: var(--text-dim);
    margin: 6px 0 0;
}

.pin {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
}

.pin__dots {
    display: flex;
    gap: 18px;
}

.pin__dot {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.12);
    transition: background 0.15s, transform 0.15s;
}

.pin__dot.filled {
    background: var(--primary);
    transform: scale(1.1);
}

.pin__error {
    min-height: 1.2em;
    color: var(--danger);
    font-size: 0.95rem;
    text-align: center;
}

/* Keypad */
.keypad {
    width: 100%;
    max-width: 340px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}

.key {
    height: 72px;
    font-size: 1.8rem;
    font-weight: 500;
    background: var(--surface);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    color: var(--text);
    transition: transform 0.08s, background 0.15s;
    user-select: none;
}

.key:active {
    transform: scale(0.94);
    background: var(--surface-2);
}

.key--ghost {
    background: transparent;
    box-shadow: none;
    color: var(--text-dim);
    font-size: 1.4rem;
}

.key--ghost:active {
    background: rgba(255, 255, 255, 0.06);
}

/* Shake animation on invalid PIN */
@keyframes shake {
    0%, 100% { transform: translateX(0); }
    20% { transform: translateX(-8px); }
    40% { transform: translateX(8px); }
    60% { transform: translateX(-6px); }
    80% { transform: translateX(6px); }
}

.pin__dots.shake { animation: shake 0.4s; }

/* ====== Top bar ====== */
.topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    background: rgba(0, 0, 0, 0.25);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    position: sticky;
    top: 0;
    z-index: 10;
}

.topbar__user {
    display: flex;
    align-items: center;
    gap: 12px;
}

.avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--primary);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 0.95rem;
}

.topbar__name { font-weight: 600; }
.topbar__role { font-size: 0.8rem; color: var(--text-dim); }

/* ====== Cards / Choose screen ====== */
.choose {
    padding: 20px 16px 32px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    max-width: 640px;
    margin: 0 auto;
}

.card {
    background: var(--surface);
    border-radius: var(--radius);
    padding: 18px 18px 20px;
    box-shadow: var(--shadow);
}

.empty {
    color: var(--text-dim);
    text-align: center;
    padding: 16px 0;
}

/* Segmented control (start/end of shift) */
.segmented {
    display: grid;
    grid-template-columns: 1fr 1fr;
    background: var(--bg);
    border-radius: 12px;
    padding: 4px;
    gap: 4px;
}

.segmented__opt {
    position: relative;
    text-align: center;
}

.segmented__opt input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.segmented__opt span {
    display: block;
    padding: 12px;
    border-radius: 10px;
    color: var(--text-dim);
    font-weight: 500;
    transition: background 0.15s, color 0.15s;
}

.segmented__opt input:checked + span {
    background: var(--primary);
    color: white;
}

/* Template cards */
.template-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.template-card {
    text-align: left;
    background: var(--surface-2);
    border-radius: var(--radius);
    padding: 14px 16px;
    transition: transform 0.08s, outline 0.15s;
    outline: 2px solid transparent;
    width: 100%;
}

.template-card:active { transform: scale(0.985); }

.template-card.selected {
    outline-color: var(--primary);
}

.template-card__name {
    font-weight: 600;
    font-size: 1.05rem;
}

.template-card__desc {
    color: var(--text-dim);
    font-size: 0.9rem;
    margin-top: 2px;
}

.template-card__locations {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 10px;
}

.chip {
    background: rgba(255, 255, 255, 0.08);
    color: var(--text-dim);
    border-radius: 999px;
    padding: 4px 10px;
    font-size: 0.8rem;
}

/* Liste de lieux (sélection principale) */
.location-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 10px;
}

.location-btn {
    background: var(--surface-2);
    border-radius: var(--radius);
    padding: 16px 12px;
    text-align: center;
    outline: 2px solid transparent;
    transition: outline 0.15s, transform 0.08s, background 0.15s;
    min-height: 72px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 4px;
}

.location-btn:active { transform: scale(0.97); }

.location-btn.selected {
    outline-color: var(--primary);
    background: rgba(255, 107, 107, 0.15);
}
.location-btn--done {
    background: rgba(6, 214, 160, 0.12);
    border-left: 3px solid var(--success);
}
.location-btn--done.selected {
    background: rgba(255, 107, 107, 0.18);
}

.location-btn__name {
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    flex-wrap: wrap;
}
.location-btn__count { font-size: 0.78rem; color: var(--text-dim); }
.location-btn__done {
    display: flex;
    flex-direction: column;
    gap: 2px;
    margin-top: 4px;
}
.location-btn__done-item {
    font-size: 0.72rem;
    color: var(--success);
    line-height: 1.3;
}

/* Options de template (filtre optionnel) */
.template-options {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 10px;
}

.template-option {
    width: 100%;
    text-align: left;
    background: var(--surface-2);
    border-radius: var(--radius);
    padding: 12px 14px;
    outline: 2px solid transparent;
    transition: outline 0.15s, transform 0.08s, background 0.15s;
}
.template-option:active { transform: scale(0.985); }
.template-option--selected {
    outline-color: var(--primary);
    background: rgba(255, 107, 107, 0.12);
}
.template-option--done {
    background: rgba(6, 214, 160, 0.10);
    border-left: 3px solid var(--success);
}
.template-option__name {
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.template-option__desc { font-size: 0.8rem; color: var(--text-dim); margin-top: 2px; }
.template-option__done {
    margin-top: 6px;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.template-option__done-item {
    font-size: 0.78rem;
    color: var(--success);
}
.badge--freq { background: rgba(255, 209, 102, 0.18); color: var(--accent); font-weight: 500; }

/* Table de comparaison de shift */
.comparison-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.85rem;
    margin-top: 8px;
}
.comparison-table th {
    text-align: left;
    padding: 6px 4px;
    color: var(--text-dim);
    font-weight: 500;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}
.comparison-table th:nth-child(n+2) { text-align: right; }
.comparison-table td {
    padding: 6px 4px;
    border-bottom: 1px solid rgba(255,255,255,0.04);
    font-variant-numeric: tabular-nums;
}
.comparison-table td:nth-child(n+2) { text-align: right; }
.comparison-table .comparison-row__name { color: var(--text); font-weight: 500; }
.comparison-table__group td {
    background: rgba(255,255,255,0.04);
    color: var(--text-dim);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: 600;
    padding: 6px 4px;
}
.comparison-row--anomaly { background: rgba(239, 71, 111, 0.10); }
.comparison-row--anomaly td:last-child { color: var(--danger); }

/* Table de livraison */
.delivery-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.9rem;
    margin: 8px 0 12px;
}
.delivery-table th {
    text-align: left;
    padding: 6px 4px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    color: var(--text-dim);
    font-weight: 500;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.delivery-table td {
    padding: 6px 4px;
    border-bottom: 1px solid rgba(255,255,255,0.03);
    vertical-align: middle;
}
.delivery-table td input {
    width: 100%;
    min-width: 60px;
    background: var(--bg);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 6px;
    padding: 6px 8px;
    color: var(--text);
    font-size: 0.9rem;
}

/* Statuts de commandes */
.badge--status { font-weight: 500; }
.badge--status-draft { background: rgba(255,255,255,0.08); color: var(--text-dim); }
.badge--status-ordered { background: rgba(255, 209, 102, 0.18); color: var(--accent); }
.badge--status-confirmed { background: rgba(102, 178, 255, 0.15); color: #66b2ff; }
.badge--status-delivered { background: rgba(6, 214, 160, 0.15); color: var(--success); }
.badge--status-invoiced { background: rgba(178, 102, 255, 0.15); color: #b266ff; }
.badge--status-paid { background: rgba(6, 214, 160, 0.25); color: var(--success); font-weight: 600; }
.badge--status-cancelled { background: rgba(239, 71, 111, 0.15); color: var(--danger); }

/* Buttons */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: var(--tap);
    padding: 0 18px;
    border-radius: 12px;
    font-weight: 600;
    transition: background 0.15s, transform 0.08s, opacity 0.15s;
}

.btn:active { transform: scale(0.97); }

.btn--primary { background: var(--primary); color: white; }
.btn--primary:hover { background: var(--primary-dark); }

.btn--ghost { background: rgba(255, 255, 255, 0.06); color: var(--text); }

.btn--sm { min-height: 36px; padding: 0 12px; font-size: 0.9rem; }
.btn--lg { min-height: 56px; font-size: 1.05rem; }

.btn:disabled { opacity: 0.4; pointer-events: none; }

/* ====== Page de comptage ====== */
.count {
    padding: 16px 12px 100px;
    display: flex;
    flex-direction: column;
    gap: 14px;
    max-width: 720px;
    margin: 0 auto;
}

.product-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.product-group {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.product-group__name {
    margin: 4px 4px 2px;
    font-size: 1.05rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 8px;
}

.product-card {
    background: var(--surface);
    border-radius: var(--radius);
    padding: 14px;
    box-shadow: var(--shadow);
    transition: outline 0.4s;
    outline: 2px solid transparent;
}

.product-card--saved {
    outline-color: var(--success);
}

.product-card__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 12px;
}

.product-card__name {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
}

.counter-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

.counter {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.counter label {
    font-size: 0.75rem;
    color: var(--text-dim);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.counter__controls {
    display: flex;
    align-items: center;
    background: var(--bg);
    border-radius: 10px;
    overflow: hidden;
}

.counter__btn {
    flex: 0 0 44px;
    height: 44px;
    font-size: 1.4rem;
    color: var(--text);
    background: transparent;
    transition: background 0.12s;
}

.counter__btn:active {
    background: rgba(255, 255, 255, 0.08);
}

.counter__controls input {
    flex: 1;
    border: none;
    background: transparent;
    color: var(--text);
    font-size: 1.1rem;
    font-weight: 600;
    text-align: center;
    height: 44px;
    min-width: 0;
    /* Cacher les flèches natives */
    -moz-appearance: textfield;
    appearance: textfield;
}

.counter__controls input::-webkit-outer-spin-button,
.counter__controls input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

/* Bloc volume (bouteilles pleines + bouteilles ouvertes) */
.volume-block {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.open-bottles-block {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.open-bottles-block__label {
    font-size: 0.75rem;
    color: var(--text-dim);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.open-bottles-list {
    display: flex;
    gap: 14px;
    overflow-x: auto;
    padding: 4px 2px 12px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
}

.open-bottle {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    flex: 0 0 auto;
    scroll-snap-align: start;
    padding: 6px 4px;
    border-radius: 10px;
    background: var(--bg);
}

.open-bottle__remove {
    position: absolute;
    top: 2px;
    right: 2px;
    z-index: 3;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: rgba(239, 71, 111, 0.85);
    color: white;
    font-size: 1rem;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
}
.open-bottle__remove:active { transform: scale(0.92); }

.open-bottle__add {
    align-self: flex-start;
    background: rgba(255, 255, 255, 0.06);
    color: var(--text);
    padding: 10px 14px;
    border-radius: 10px;
    font-size: 0.9rem;
    min-height: 40px;
}
.open-bottle__add:active { background: rgba(255, 255, 255, 0.12); }

.open-bottles-total {
    font-size: 0.8rem;
    text-align: right;
}

.bottle {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
}

.bottle label {
    font-size: 0.75rem;
    color: var(--text-dim);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.bottle__widget {
    width: 110px;
    /* La hauteur n'est fixée que pour le mode SVG ; le mode photo se cale
       sur la hauteur naturelle de l'image (.bottle-photo n'a pas de height). */
    touch-action: none;
    user-select: none;
    -webkit-user-select: none;
    position: relative;
}

/* En mode SVG uniquement, on garde une hauteur fixe pour la silhouette générique */
.bottle__widget:has(.bottle__svg) {
    height: 220px;
}

.bottle__svg {
    width: 100%;
    height: 100%;
    display: block;
    overflow: visible;
}

.bottle__outline {
    fill: none;
    stroke: var(--text-dim);
    stroke-width: 2.5;
    stroke-linejoin: round;
    pointer-events: none;
}

.bottle__cap {
    fill: var(--text-dim);
}

.bottle__liquid {
    fill: var(--primary);
    opacity: 0.85;
    transition: y 0.08s linear, height 0.08s linear;
    pointer-events: none;
}

.bottle__liquid-surface {
    fill: var(--accent);
    pointer-events: none;
    transition: y 0.08s linear;
}

.bottle__handle-line {
    stroke: var(--accent);
    stroke-width: 2;
    stroke-dasharray: 4 3;
    pointer-events: none;
}

.bottle__handle-grip {
    fill: var(--accent);
    stroke: var(--bg);
    stroke-width: 2;
    cursor: ns-resize;
    pointer-events: none;
}

.bottle__readout {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
}

.bottle__fraction {
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--accent);
    font-variant-numeric: tabular-nums;
}

.bottle__sub {
    font-size: 0.75rem;
    color: var(--text-dim);
    font-variant-numeric: tabular-nums;
}

/* ====== Mode "photo réelle" de la bouteille ====== */
.bottle-photo {
    position: relative;
    width: 100%;
    height: 100%;
    user-select: none;
    -webkit-user-select: none;
    touch-action: none;
}

.bottle-photo__img {
    width: 100%;
    height: auto;       /* hauteur naturelle de l'image, pas de whitespace */
    pointer-events: none;
    display: block;
}

/* Bande de liquide : occupe tout le bas et s'arrête à `top` */
.bottle-photo__liquid {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    top: 100%;
    background: linear-gradient(
        to bottom,
        rgba(255, 107, 107, 0.55) 0%,
        rgba(255, 107, 107, 0.35) 100%
    );
    pointer-events: none;
    transition: top 0.08s linear;
    mix-blend-mode: multiply;
}

.bottle-photo__handle {
    position: absolute;
    left: -8px;
    right: -8px;
    top: 100%;
    height: 0;
    border-top: 2px dashed var(--accent);
    pointer-events: none;
    transition: top 0.08s linear;
    z-index: 2;
}

.bottle-photo__grip {
    position: absolute;
    right: -8px;
    top: -10px;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: var(--accent);
    border: 2px solid var(--bg);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.4);
}

/* Indicateur de sauvegarde dans la topbar */
.save-status {
    font-size: 0.8rem;
    color: var(--text-dim);
    min-width: 100px;
    text-align: right;
}

.save-status[data-kind="ok"] { color: var(--success); }
.save-status[data-kind="pending"] { color: var(--accent); }
.save-status[data-kind="error"] { color: var(--danger); }

/* ====== Espace admin ====== */
.admin {
    max-width: 720px;
    margin: 0 auto;
    padding: 20px 16px 60px;
}

.admin h1 { font-size: 1.4rem; margin-bottom: 18px; }

.admin-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 12px;
    margin-bottom: 24px;
}

.admin-tile {
    background: var(--surface);
    border-radius: var(--radius);
    padding: 22px 16px;
    text-align: center;
    text-decoration: none;
    color: var(--text);
    box-shadow: var(--shadow);
    transition: transform 0.08s;
}
.admin-tile:active { transform: scale(0.97); }
.admin-tile--disabled { opacity: 0.5; pointer-events: none; }
.admin-tile--feature {
    background: linear-gradient(135deg, rgba(255, 107, 107, 0.18), rgba(255, 209, 102, 0.12));
    border: 1px solid rgba(255, 209, 102, 0.3);
    padding: 24px 18px;
    margin-bottom: 18px;
    display: flex;
    align-items: center;
    gap: 16px;
    text-align: left;
}
.admin-tile--feature .admin-tile__num { font-size: 2.4rem; }
.admin-tile--feature .admin-tile__lbl { font-size: 1.05rem; color: var(--text); margin: 0; }

/* Chips jours de la semaine (calendrier fournisseur) */
.weekday-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 4px;
}
.weekday-chip {
    position: relative;
}
.weekday-chip input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}
.weekday-chip span {
    display: block;
    padding: 8px 14px;
    border-radius: 999px;
    background: var(--surface-2);
    color: var(--text-dim);
    font-size: 0.85rem;
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
    user-select: none;
}
.weekday-chip input:checked + span {
    background: var(--primary);
    color: white;
    font-weight: 500;
}

/* Bouton flottant "retour à l'accueil admin" — visible sur toutes les pages admin */
.admin-home-fab {
    position: fixed;
    /* On le décale au-dessus de la bottombar (~52px de haut) pour ne pas se chevaucher */
    bottom: calc(18px + 56px + var(--safe-bot));
    right: 18px;
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: var(--primary);
    color: white;
    font-size: 1.6rem;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.5);
    z-index: 1000;
    transition: transform 0.12s, background 0.15s;
}
.admin-home-fab:active { transform: scale(0.92); background: var(--primary-dark); }
.admin-home-fab:hover { background: var(--primary-dark); }

.admin-tile__num {
    font-size: 2.1rem;
    font-weight: 700;
    color: var(--primary);
}
.admin-tile__lbl { color: var(--text-dim); font-size: 0.9rem; margin-top: 4px; }

.admin__note { color: var(--text-dim); font-size: 0.85rem; }

.product-admin-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.product-admin-row {
    display: flex;
    align-items: center;
    gap: 12px;
    background: var(--surface);
    padding: 10px 12px;
    border-radius: var(--radius);
    text-decoration: none;
    color: inherit;
    transition: background 0.12s;
}
.product-admin-row:active { background: var(--surface-2); }

.product-admin-row__thumb {
    width: 48px;
    height: 60px;
    background: var(--bg);
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    flex-shrink: 0;
}
.product-admin-row__thumb img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}
.product-admin-row__placeholder { font-size: 1.4rem; opacity: 0.4; }

.product-admin-row__info { flex: 1; min-width: 0; }
.product-admin-row__name { font-weight: 600; }
.product-admin-row__meta {
    font-size: 0.8rem;
    color: var(--text-dim);
    margin-top: 2px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.product-admin-row__chev { font-size: 1.6rem; color: var(--text-dim); }

.muted { color: var(--text-dim); }

/* Formulaires admin */
.form { display: flex; flex-direction: column; gap: 14px; }
.form label { display: flex; flex-direction: column; gap: 4px; font-size: 0.85rem; color: var(--text-dim); }
.form label span { text-transform: uppercase; letter-spacing: 0.04em; font-size: 0.7rem; }
.form input[type="text"],
.form input[type="number"],
.form input[type="file"],
.form select {
    background: var(--bg);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 10px;
    padding: 10px 12px;
    color: var(--text);
    font-size: 1rem;
    min-height: 44px;
}
.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}
.form .checkbox {
    flex-direction: row;
    align-items: center;
    gap: 10px;
}
.form .checkbox input { transform: scale(1.4); }
.form .checkbox span { text-transform: none; letter-spacing: 0; font-size: 0.95rem; color: var(--text); }

.flash {
    padding: 10px 14px;
    border-radius: 10px;
    margin-bottom: 14px;
}
.flash--ok { background: rgba(6, 214, 160, 0.15); color: var(--success); }

/* Aperçu et calibration de bouteille */
.bottle-preview {
    background: var(--bg);
    border-radius: var(--radius);
    padding: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 220px;
    margin-bottom: 16px;
}
.bottle-preview img { max-height: 260px; max-width: 100%; object-fit: contain; }
.bottle-preview__empty { color: var(--text-dim); font-size: 0.9rem; }

.calibrator {
    position: relative;
    margin: 16px auto 8px;
    width: 200px;
    max-width: 80%;
    cursor: crosshair;
    background: var(--bg);
    border-radius: 10px;
    padding: 8px;
}
.calibrator__img {
    width: 100%;
    display: block;
    pointer-events: none;
}
.calibrator__marker {
    position: absolute;
    left: 0; right: 0;
    height: 0;
    pointer-events: none;
}
.calibrator__marker--full { border-top: 2px solid var(--accent); }
.calibrator__marker--empty { border-top: 2px dashed var(--text-dim); }
.calibrator__marker--full::after,
.calibrator__marker--empty::after {
    position: absolute;
    right: 4px;
    top: -18px;
    font-size: 0.7rem;
    background: var(--bg);
    padding: 2px 6px;
    border-radius: 4px;
}
.calibrator__marker--full::after { content: "↕ plein"; color: var(--accent); }
.calibrator__marker--empty::after { content: "↕ vide"; color: var(--text-dim); top: 4px; }
.calibrator__readout {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 0.9rem;
    justify-content: center;
}

/* Login admin */
.screen-admin-login { display: flex; align-items: center; justify-content: center; min-height: 100vh; }
.admin-login { width: 100%; max-width: 420px; padding: 24px 20px; }
.admin-login__card {
    background: var(--surface);
    border-radius: var(--radius);
    padding: 28px 24px;
    box-shadow: var(--shadow);
}
.admin-login__head { text-align: center; margin-bottom: 20px; }
.admin-login__head .logo { font-size: 48px; margin-bottom: 8px; }
.admin-login__head h1 { font-size: 1.4rem; margin: 0 0 4px; }
.admin-login__footer { text-align: center; margin: 18px 0 0; }
.admin-login__footer a { text-decoration: none; font-size: 0.85rem; }

.flash--error {
    background: rgba(239, 71, 111, 0.15);
    color: var(--danger);
    padding: 10px 14px;
    border-radius: 10px;
    margin-bottom: 14px;
}

/* Appareils */
.device-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.device-row {
    display: flex; align-items: center; gap: 12px;
    background: var(--surface-2);
    padding: 12px 14px; border-radius: var(--radius);
}
.device-row--revoked { opacity: 0.5; }
.device-row__info { flex: 1; min-width: 0; }
.device-row__name { font-weight: 600; display: flex; align-items: center; gap: 8px; }
.device-row__meta { font-size: 0.8rem; color: var(--text-dim); margin-top: 2px; }

.badge {
    display: inline-block;
    font-size: 0.7rem;
    padding: 2px 8px;
    border-radius: 999px;
    background: rgba(255,255,255,0.08);
    color: var(--text-dim);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.badge--ok { background: rgba(6,214,160,0.15); color: var(--success); }
.badge--danger { background: rgba(239,71,111,0.15); color: var(--danger); }

.qr-wrap {
    background: white;
    padding: 18px;
    border-radius: 12px;
    margin: 12px auto;
    max-width: 320px;
    display: flex;
    justify-content: center;
}
.qr-img { width: 100%; height: auto; display: block; }

.kv { display: flex; flex-direction: column; gap: 6px; font-size: 0.9rem; }
.kv strong { color: var(--text-dim); font-weight: 500; margin-right: 6px; }

/* ===== Format ↔ lieux (admin format_edit) ===== */
.loc-links {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 14px;
}
.loc-link {
    display: flex;
    align-items: center;
    gap: 12px;
    background: var(--surface-2);
    padding: 8px 12px;
    border-radius: 8px;
}
.loc-link__check {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
}
.loc-link__check input { transform: scale(1.3); cursor: pointer; }
.loc-link__check span { text-transform: none !important; letter-spacing: 0 !important; font-size: 0.95rem !important; color: var(--text) !important; }
.loc-link__target {
    display: flex !important;
    flex-direction: row !important;
    align-items: center;
    gap: 6px;
    margin: 0 !important;
}
.loc-link__target span { font-size: 0.75rem !important; text-transform: uppercase; letter-spacing: 0.04em; color: var(--text-dim); }
.loc-link__target input { width: 64px; min-height: 36px !important; padding: 6px 8px !important; text-align: center; }

/* ===== Vue stock réel ===== */
.stock-sub {
    margin: 14px 0 4px;
    font-size: 0.85rem;
    color: var(--text-dim);
    font-weight: 500;
    text-transform: none;
    letter-spacing: 0;
}

.stock-format {
    background: var(--surface-2);
    border-radius: 10px;
    padding: 10px 12px;
    margin-bottom: 10px;
}
.stock-format__head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 6px;
}
.stock-format__title {
    font-weight: 700;
    font-size: 1rem;
}
.stock-format__agg {
    font-size: 0.85rem;
    color: var(--text-dim);
    font-variant-numeric: tabular-nums;
}
.stock-format__agg strong { color: var(--accent); }

.stock-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    padding: 6px 0;
    border-top: 1px solid rgba(255,255,255,0.05);
}
.stock-row__main { flex: 1; min-width: 0; }
.stock-row__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 2px;
}
.stock-row__qty-text { font-variant-numeric: tabular-nums; color: var(--text); }
.stock-row__qty {
    text-align: right;
    flex-shrink: 0;
    min-width: 130px;
}
.stock-row__total { font-variant-numeric: tabular-nums; }
.stock-row__meta { font-size: 0.75rem; color: var(--text-dim); margin-top: 2px; }

.chip--loc { background: rgba(255,255,255,0.08); }
.chip--delta { font-variant-numeric: tabular-nums; }
.chip--delta-down { background: rgba(6,214,160,0.15); color: var(--success); }
.chip--delta-up { background: rgba(255,209,102,0.18); color: var(--accent); }
.chip--delta-same { background: rgba(255,255,255,0.05); color: var(--text-dim); }
.chip--delta-delivered { background: rgba(102, 178, 255, 0.15); color: #66b2ff; }

@media (max-width: 520px) {
    .stock-row { flex-direction: column; }
    .stock-row__qty { text-align: left; min-width: 0; }
}

.cat-tree {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.cat-tree--children {
    margin-left: 18px;
    margin-top: 4px;
    padding-left: 8px;
    border-left: 2px solid rgba(255,255,255,0.06);
}
.cat-tree__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    background: var(--surface-2);
    padding: 8px 12px;
    border-radius: 8px;
}
.cat-tree__name { font-weight: 600; }
.cat-tree__name--child { font-weight: 500; color: var(--text-dim); }

.ordered-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.ordered-row {
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--surface-2);
    border-radius: 10px;
    padding: 8px 12px;
}
.ordered-row__num {
    color: var(--text-dim);
    font-variant-numeric: tabular-nums;
    min-width: 24px;
}
.ordered-row__name {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.ordered-row__actions {
    display: flex;
    gap: 4px;
    flex-shrink: 0;
}
.ordered-row__actions button[disabled] {
    opacity: 0.25;
    pointer-events: none;
}

.delivery-banner {
    background: linear-gradient(135deg, rgba(255, 209, 102, 0.18), rgba(102, 178, 255, 0.10));
    border-left: 4px solid var(--accent);
}
.delivery-banner h2 {
    color: var(--accent);
    text-transform: none;
    letter-spacing: 0;
    margin-bottom: 4px;
}
.delivery-banner__items {
    list-style: none;
    padding: 0;
    margin: 8px 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-size: 0.95rem;
}
.delivery-banner__items li {
    background: rgba(255,255,255,0.04);
    padding: 6px 10px;
    border-radius: 6px;
}
.delivery-banner__actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 10px;
}

.pin-reveal {
    background: linear-gradient(135deg, rgba(255, 209, 102, 0.18), rgba(255, 107, 107, 0.12));
    border: 1px solid rgba(255, 209, 102, 0.4);
    text-align: center;
}
.pin-reveal h2 {
    color: var(--accent);
    margin: 0 0 12px;
    text-transform: none;
    letter-spacing: 0;
}
.pin-reveal__code {
    font-size: 3rem;
    font-weight: 700;
    letter-spacing: 0.4em;
    padding-left: 0.4em;
    color: var(--text);
    margin: 8px 0;
    font-variant-numeric: tabular-nums;
}

/* Placeholder admin */
.placeholder {
    max-width: 520px;
    margin: 0 auto;
    padding: 40px 20px;
    text-align: center;
}

.placeholder p { color: var(--text-dim); margin: 16px 0 24px; }

/* ====== Bottombar : toggle mode + lien Signaler (visible partout) ====== */
.bottombar {
    position: fixed;
    left: 12px;
    bottom: calc(12px + var(--safe-bot));
    display: flex;
    gap: 6px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 999px;
    padding: 4px;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.25);
    z-index: 999;
}
.bottombar__btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    border-radius: 999px;
    color: var(--text);
    background: transparent;
    text-decoration: none;
    font-size: 0.85rem;
    cursor: pointer;
    border: none;
    transition: background 0.15s;
}
.bottombar__btn:hover { background: var(--surface-2); }
.bottombar__icon { font-size: 1.05rem; line-height: 1; }
.bottombar__lbl { color: var(--text); }
@media (max-width: 380px) {
    .bottombar__lbl { display: none; }
}
