:root {
    --conso-bg: #070707;
    --conso-bg-soft: #111111;
    --conso-surface: #171717;
    --conso-surface-2: #1f1f1f;
    --conso-gold: #c9a24d;
    --conso-gold-soft: #e1c27a;
    --conso-text: #f6f6f6;
    --conso-muted: #b9b9b9;
    --conso-border: rgba(201, 162, 77, 0.34);
    --conso-danger: #ff6b6b;
    --conso-success: #81d89a;
    --conso-radius: 12px;
}

html,
body {
    margin: 0;
    padding: 0;
    min-height: 100%;
    background: radial-gradient(circle at top, #1a1a1a 0%, #0c0c0c 46%, #060606 100%) !important;
    color: var(--conso-text) !important;
}

/* Index bar : fond dégradé jusqu'en bas de l'écran */
body.conso-bar-index {
    background: radial-gradient(circle at top, #1a1a1a 0%, #0c0c0c 46%, #060606 100%) !important;
    min-height: 100vh !important;
}

a,
.path__name,
.link__forgot,
.size-13,
.size-14 {
    color: var(--conso-muted);
}

h1,
h2,
h3,
h4,
h5,
h6,
.txt_gradient,
.color-secondary {
    color: var(--conso-gold) !important;
}

.conso-app-shell {
    width: min(100%, 1220px);
    margin: 0 auto;
}

/* Barre dorée commune : même barre sous tous les headers (caisse index, bar index, caisse conso, bar conso) */
.conso-barre-doree {
    height: 3px !important;
    width: 100% !important;
    min-width: 100% !important;
    background: linear-gradient(90deg, transparent 0%, var(--conso-gold) 15%, var(--conso-gold) 85%, transparent 100%) !important;
    flex-shrink: 0 !important;
}

/* Barre dorée pleine largeur uniquement sous le header (pas en bas de page) */
.main_header,
.main_haeder,
.header-sticky {
    background: linear-gradient(135deg, rgba(19, 19, 19, 0.97), rgba(7, 7, 7, 0.99)) !important;
    border-bottom: none !important;
    box-shadow: 0 8px 26px rgba(0, 0, 0, 0.38);
    backdrop-filter: blur(8px);
}
/* Index caisse / index bar : barre dorée en ::after sous le header */
.conso-caisse-index .main_header,
.conso-bar-index .main_header,
.conso-bar-index .main_haeder {
    border-bottom: none !important;
    box-shadow: 0 8px 26px rgba(0, 0, 0, 0.38) !important;
}
.conso-caisse-index .main_header::after,
.conso-bar-index .main_header::after,
.conso-bar-index .main_haeder::after {
    content: '' !important;
    display: block !important;
    height: 3px !important;
    width: 100% !important;
    background: linear-gradient(90deg, transparent 0%, var(--conso-gold) 15%, var(--conso-gold) 85%, transparent 100%) !important;
}
/* Index bar : header en colonne pour que la barre dorée soit sous le logo, pas à côté du bloc Vente */
.conso-bar-index .main_header {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    padding: 0.6rem 0.85rem 0.65rem !important;
}
.conso-bar-index .main_header > div,
.conso-bar-index .main_header .conso-index-header-row {
    display: grid !important;
    grid-template-columns: 1fr auto 1fr !important;
    align-items: center !important;
    width: 100% !important;
    gap: 0.5rem !important;
}
.conso-bar-index .main_header .em_brand.conso-index-top-brand {
    display: flex !important;
    justify-content: center !important;
}
.conso-bar-index .main_header .conso-index-side {
    display: flex !important;
    align-items: center !important;
    font-size: 0.92rem !important;
    line-height: 1.35 !important;
    padding: 0.25rem 0.4rem !important;
}
.conso-bar-index .main_header .em_side_left.conso-index-side {
    justify-content: flex-start !important;
}
.conso-bar-index .main_header .em_side_right.conso-index-side {
    justify-content: flex-end !important;
}
.conso-index-vendeur-link {
    color: inherit !important;
    text-decoration: none !important;
}
.conso-index-vendeur-link:hover {
    color: var(--conso-gold) !important;
}

/* Page co (connexion bar) : message d’erreur carte inconnue */
.conso-co-error-msg {
    text-align: center !important;
    font-size: 0.75rem !important;
    background: rgba(255, 64, 64, 0.25) !important;
    color: #ffcccc !important;
    margin: 0.5rem 1rem !important;
    padding: 0.4rem 0.75rem !important;
    border: 1px solid rgba(255, 64, 64, 0.6) !important;
    border-radius: 10px !important;
    font-weight: 600 !important;
}

.conso-caisse-page .main_haeder,
.conso-bar-page .main_haeder {
    box-shadow: 0 8px 26px rgba(0, 0, 0, 0.38);
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    max-width: 100vw !important;
    z-index: 12;
    box-sizing: border-box;
}

/* Caisse : header et barre dorée sur toute la largeur de l’écran (même si #wrapper est centré) */
.conso-caisse-page .main_haeder {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    left: 0 !important;
    right: auto !important;
}

/* Caisse conso : header = logo + barre dorée + bloc pseudo/montant (tout d’un bloc) */
/* Ordre: LOGO > BARRE > BANDEAU COLORÉ (pseudo gauche, montant droite) > TABS */
.conso-caisse-page .main_haeder.conso-page-header {
    border-bottom: 0 !important;
    padding: 0 !important;
    min-height: 0 !important;
    display: flex !important;
    flex-direction: column !important;
}

/* 1. LOGO  2. BARRE DORÉE = toute la largeur sous le logo (même barre que paramètres) */
.conso-caisse-page .conso-header-top {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0.2rem 0.6rem 0 !important;
    min-height: 0 !important;
    display: grid !important;
    grid-template-columns: 1fr auto 1fr !important;
    grid-template-rows: 34px 3px !important;
    align-items: center !important;
    background: linear-gradient(135deg, rgba(19, 19, 19, 0.97), rgba(7, 7, 7, 0.99));
    border-bottom: none !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
}
.conso-caisse-page .conso-header-top .em_brand {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    max-height: 34px !important;
    overflow: hidden !important;
}
.conso-caisse-page .conso-header-top::after {
    content: '' !important;
    display: block !important;
    height: 3px !important;
    width: 100% !important;
    grid-column: 1 / -1 !important;
    grid-row: 2 !important;
    background: linear-gradient(90deg, transparent 0%, var(--conso-gold) 15%, var(--conso-gold) 85%, transparent 100%) !important;
}

/* BANDEAU : bien décalé des bords de l’écran */
.conso-caisse-page .conso-header-bar {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    width: 100%;
    padding: 0.2rem 1rem 0.28rem !important;
    background: rgba(255, 255, 255, 0.03) !important;
    border: 0 !important;
    border-bottom: 0 !important;
    flex-shrink: 0;
}

/* Bar : même structure header que caisse (pleine largeur + conso-header-top + conso-header-bar) */
.conso-bar-page .main_haeder {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    left: 0 !important;
    right: auto !important;
}
.conso-bar-page .main_haeder.conso-page-header {
    border-bottom: 0 !important;
    padding: 0 !important;
    min-height: 0 !important;
    display: flex !important;
    flex-direction: column !important;
}
.conso-bar-page .conso-header-top {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0.2rem 0.6rem !important;
    min-height: 34px !important;
    display: grid !important;
    grid-template-columns: 1fr auto 1fr !important;
    grid-template-rows: 34px 3px !important;
    align-items: center !important;
    background: linear-gradient(135deg, rgba(19, 19, 19, 0.97), rgba(7, 7, 7, 0.99));
    border-bottom: none !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
}
.conso-bar-page .conso-header-top .em_brand {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    max-height: 34px !important;
    overflow: hidden !important;
}
/* Bar conso : barre dorée sous le logo uniquement (::after de conso-header-top, pas du header entier) */
.conso-bar-page .main_haeder::after {
    display: none !important; /* plus de barre en bas du header */
}
.conso-bar-page .conso-header-top {
    grid-template-rows: 34px 3px !important; /* ligne logo + ligne barre */
}
.conso-bar-page .conso-header-top > * {
    grid-row: 1 !important;
}
.conso-bar-page .conso-header-top .em_menu_sidebar { grid-column: 1 !important; }
.conso-bar-page .conso-header-top .em_brand { grid-column: 2 !important; }
.conso-bar-page .conso-header-top .em_side_right { grid-column: 3 !important; }
.conso-bar-page .conso-header-top .conso-vip-banner { grid-column: 2 !important; }
.conso-bar-page .conso-header-top::after {
    content: '' !important;
    display: block !important;
    height: 3px !important;
    width: 100% !important;
    grid-column: 1 / -1 !important;
    grid-row: 2 !important;
    background: linear-gradient(90deg, transparent 0%, var(--conso-gold) 15%, var(--conso-gold) 85%, transparent 100%) !important;
    flex-shrink: 0 !important;
}
.conso-bar-page .conso-header-bar {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    width: 100%;
    padding: 0.2rem 1rem 0.28rem !important;
    background: rgba(255, 255, 255, 0.03) !important;
    border: 0 !important;
    border-bottom: 0 !important;
    flex-shrink: 0;
}

.conso-caisse-page .main_haeder .em_brand,
.conso-bar-page .main_haeder .em_brand {
    display: flex;
    align-items: center;
    justify-content: center;
}

.scan-hidden-input {
    position: absolute !important;
    opacity: 0 !important;
    left: -9999px !important;
    top: 0 !important;
    width: 1px !important;
    height: 1px !important;
    pointer-events: none !important;
    border: 0 !important;
    padding: 0 !important;

    margin: 0 !important;
    background: transparent !important;
    color: transparent !important;
    caret-color: transparent !important;
}

.scan-submit-hidden {
    display: none !important;
    visibility: hidden !important;
}

.scan-form-group {
    border-bottom: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

.conso-club-logo {
    display: block;
    width: clamp(130px, 32vw, 230px);
    margin: 0.45rem auto 0.9rem auto;
    filter: drop-shadow(0 8px 22px rgba(0, 0, 0, 0.38));
}

.conso-index-header-logo {
    width: clamp(56px, 8vw, 82px);
    display: block;
    margin: 0.1rem 0 0.15rem 0.1rem;
    filter: drop-shadow(0 5px 14px rgba(0, 0, 0, 0.45));
}

.conso-caisse-index .main_header .em_side_left,
.conso-bar-index .conso-index-head-logo-wrap {
    display: flex;
    align-items: center;
}

.conso-caisse-index .main_header > div {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
}

.conso-caisse-index .conso-index-top-brand {
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
}

.conso-bar-index .conso-bar-index-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    gap: 0.75rem;
}

.conso-bar-index .conso-index-head-logo-wrap {
    position: relative;
}

.conso-caisse-index .main_header .em_side_right {
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

/* Bloc sous la barre du header (Bracelet actif | Carte de membre) */
.conso-index-info-bar {
    width: 100%;
    padding: 0.4rem 0.6rem 0.5rem;
    background: rgba(255, 255, 255, 0.02);
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    display: flex;
    justify-content: center;
    align-items: center;
}

.conso-index-info-bar .conso-index-info {
    width: 100%;
    max-width: min(94%, 1040px);
    margin: 0 auto;
    text-align: center !important;
    padding: 0.32rem 0.58rem;
    border: none;
    border-radius: 0;
    background: transparent;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.conso-index-info-bar .conso-index-status-text {
    display: inline-flex;
    align-items: center;
    justify-content: center !important;
    gap: 0.6rem;
    flex-wrap: wrap;
    margin: 0;
    font-size: 0.88rem;
    line-height: 1.35;
}

.conso-index-sep {
    display: inline-block;
    width: 2px;
    height: 18px;
    background: linear-gradient(180deg, rgba(201, 162, 77, 0.35), rgba(225, 194, 122, 1), rgba(201, 162, 77, 0.35));
    border-radius: 999px;
    box-shadow: 0 0 6px rgba(201, 162, 77, 0.35);
    flex-shrink: 0;
}

.conso-index-line {
    display: inline;
}

.conso-index-info-bar .conso-index-extra {
    margin: 0.35rem 0 0 0;
    font-size: 0.88rem;
    text-align: center;
}

.conso-index-extra {
    margin: 0.35rem 0 0 0;
    font-size: 0.88rem;
}

.conso-index-info {
    text-align: right;
    padding: 0.32rem 0.58rem;
    border-radius: 8px;
    border: 1px solid rgba(201, 162, 77, 0.22);
    background: rgba(255, 255, 255, 0.02);
}

.conso-caisse-index .scan-shell,
.conso-bar-index .bar-scan-box {
    margin-top: 104px;
    padding: 0.35rem 0.2rem;
    background: transparent;
    border: 0;
}

.conso-bar-index .conso-index-staff-pseudo {
    text-align: center !important;
    margin: 0.6rem 0 0.5rem !important;
    font-size: clamp(1.2rem, 4vw, 1.65rem) !important;
    font-weight: 500 !important;
    letter-spacing: 0.05em;
    color: var(--conso-text, #e8e8e8) !important;
}

.conso-caisse-index .scan-hero,
.conso-bar-index .bar-scan-icon {
    width: 112px;
    height: 112px;
    border-radius: 50%;
    margin: 0 auto 0.85rem auto;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.3rem;
    color: var(--conso-gold);
    border: 1px solid rgba(201, 162, 77, 0.46);
    background: rgba(201, 162, 77, 0.08);
}

.conso-caisse-index .content_text h2,
.conso-bar-index .content_text h2 {
    letter-spacing: 0.08em;
    font-size: clamp(1.65rem, 5vw, 2.2rem);
    margin-bottom: 0.45rem;
}

.conso-caisse-index .content_text p,
.conso-bar-index .content_text p {
    color: #d6d6d6 !important;
    font-size: 0.96rem !important;
    margin-bottom: 0.2rem !important;
}

.conso-caisse-index .conso-index-status,
.conso-bar-index .vendor-chip {
    display: inline-block;
    border: 0 !important;
    border-radius: 0;
    padding: 0.1rem 0 !important;
    background: transparent !important;
    color: #d7c089 !important;
    font-weight: 700;
    box-shadow: none !important;
}

.conso-index-status-text {
    margin: 0;
    font-size: 0.88rem;
    line-height: 1.35;
}

.conso-debug-badge {
    color: #ff6b6b;
    font-size: 1rem;
    font-weight: 800;
    letter-spacing: 0.03em;
}

.conso-danger-text {
    color: #ff6b6b !important;
}

.conso-success-text {
    color: #6fd48a !important;
}

.conso-danger-icon {
    color: #ff6b6b !important;
    font-size: 42px !important;
}

.conso-caisse-index #modalErreur {
    width: min(92vw, 560px) !important;
    border-color: rgba(201, 162, 77, 0.56) !important;
    border-radius: 12px !important;
    z-index: 9999 !important;
}

/* Pages CONSO */
.conso-caisse-page,
.conso-bar-page {
    overflow: hidden;
}

.conso-caisse-page #wrapper,
.conso-bar-page #wrapper {
    display: flex;
    flex-direction: column;
    height: 100%;
    transform: none !important;
}

/* Rotation 180° pour la page conso bar (écran orienté) */
body.conso-bar-page {
    transform: rotate(180deg) !important;
}

.conso-caisse-page .banner__wallet,
.conso-bar-page .banner__wallet {
    background: transparent !important;
    border-bottom: 0 !important;
    box-shadow: none !important;
    overflow: visible;
    position: fixed;
    left: 0;
    right: 0;
    z-index: 11;
    /* Juste sous le header (logo 34px + barre 3px + bandeau) */
    top: 58px;
}

.conso-caisse-page .banner__wallet {
    height: 108px;
    min-height: 108px;
}

.conso-bar-page .banner__wallet {
    height: 108px;
    min-height: 108px;
}

.conso-caisse-page .emhead,
.conso-bar-page .emhead {
    width: min(94%, 1040px);
    margin: 0 auto;
    padding: 0.25rem 0.5rem;
    display: grid !important;
    grid-template-columns: minmax(260px, 1fr) auto;
    column-gap: 0.5rem;
    align-items: start !important;
    background: transparent;
    border: 0;
    border-radius: 10px;
    box-shadow: none;
    min-height: 0;
}

/* Bandeau caisse : ne pas limiter la largeur pour éviter tout retour à la ligne */
.conso-caisse-page .conso-header-bar .emhead,
.conso-caisse-page .conso-header-bar .conso-header-bar-emhead,
.conso-bar-page .conso-header-bar .emhead,
.conso-bar-page .conso-header-bar .conso-header-bar-emhead {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
}

/* Bandeau : une ligne, pseudo à gauche, montant à droite, espace entre les deux */
.conso-caisse-page .conso-header-bar .emhead,
.conso-caisse-page .conso-header-bar .conso-header-bar-emhead,
.conso-bar-page .conso-header-bar .emhead,
.conso-bar-page .conso-header-bar .conso-header-bar-emhead {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    justify-content: space-between !important;
    align-items: flex-start !important;
    gap: 2rem !important; /* plus d’espace entre bloc pseudo et bloc montant */
    width: 100% !important;
    padding: 0.2rem 0.5rem;
    min-width: 0;
}
.conso-caisse-page .conso-header-bar .emhead > .side__right,
.conso-caisse-page .conso-header-bar .conso-header-bar-emhead > .side__right,
.conso-bar-page .conso-header-bar .emhead > .side__right,
.conso-bar-page .conso-header-bar .conso-header-bar-emhead > .side__right {
    order: 1 !important;
    flex: 0 0 auto !important;
    text-align: left !important;
}
.conso-caisse-page .conso-header-bar .emhead > .item__total,
.conso-caisse-page .conso-header-bar .conso-header-bar-emhead > .item__total,
.conso-bar-page .conso-header-bar .emhead > .item__total,
.conso-bar-page .conso-header-bar .conso-header-bar-emhead > .item__total {
    order: 2 !important;
    flex: 0 0 auto !important;
    text-align: right !important;
}

.conso-caisse-page .item__total,
.conso-bar-page .item__total {
    grid-column: 2;
    justify-self: end;
    align-self: start;
    text-align: right;
    border: 0 !important;
    border-left: 1px solid rgba(201, 162, 77, 0.4) !important; /* séparation avec le bloc pseudo */
    padding: 0.25rem 0 0 0.58rem;
}

/* Bloc tarif / montant dans le bandeau : pas de cadre, juste le texte */
.conso-caisse-page .conso-header-bar .item__total,
.conso-bar-page .conso-header-bar .item__total {
    padding: 0.4rem 0 0 0.85rem !important;
}
.conso-caisse-page .conso-header-bar .item__total a.btn,
.conso-bar-page .conso-header-bar .item__total a.btn {
    display: inline-flex !important;
    flex-direction: column !important;
    align-items: flex-end !important;
    text-align: right !important;
    padding: 0.25rem 0 !important;
    background: transparent !important;
    border: 0 !important;
    text-decoration: none !important;
}
.conso-caisse-page .conso-header-bar .item__total a.btn:hover,
.conso-bar-page .conso-header-bar .item__total a.btn:hover {
    background: transparent !important;
}
.conso-caisse-page .conso-header-bar .item__total .conso-total-title,
.conso-bar-page .conso-header-bar .item__total .conso-total-title {
    margin: 0 !important;
    font-size: clamp(1.35rem, 3.5vw, 1.9rem) !important;
}
.conso-caisse-page .conso-header-bar .item__total p,
.conso-caisse-page .conso-header-bar .item__total b,
.conso-bar-page .conso-header-bar .item__total p,
.conso-bar-page .conso-header-bar .item__total b {
    margin: 0.2rem 0 0 !important;
    font-size: 0.8rem !important;
}
.conso-caisse-page .conso-header-bar .side__right,
.conso-bar-page .conso-header-bar .side__right {
    padding-left: 0 !important;
}

.conso-caisse-page .item__total h2,
.conso-bar-page .item__total h2 {
    font-size: clamp(1.6rem, 4.2vw, 2.25rem) !important;
    color: var(--conso-gold) !important;
    margin: 0 0 0.15rem 0 !important;
    line-height: 1.2;
}

.conso-caisse-page .item__total span,
.conso-caisse-page .item__total p,
.conso-bar-page .item__total span,
.conso-bar-page .item__total p {
    color: #d0d0d0 !important;
}

.conso-caisse-page .side__right,
.conso-bar-page .side__right {
    grid-column: 1;
    align-self: start;
    margin: 0;
    min-width: 240px;
    text-align: left;
    padding: 0.25rem 0.55rem 0.35rem !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0;
    box-shadow: none !important;
}

/* Bandeau caisse uniquement : pas de largeur min qui casse la ligne */
.conso-caisse-page .conso-header-bar .side__right,
.conso-bar-page .conso-header-bar .side__right {
    min-width: 0 !important;
}

.conso-caisse-page .conso-header-bar .side__right,
.conso-bar-page .conso-header-bar .side__right {
    padding: 0.2rem 0.5rem 0.3rem !important;
}

.conso-caisse-page .side__right p,
.conso-bar-page .side__right p {
    margin: 0.1rem 0 !important;
    line-height: 1.28;
}

.conso-user-mainline {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.2rem;
}

.conso-entry-separator {
    display: inline-block;
    width: 1px;
    height: 14px;
    background: linear-gradient(180deg, rgba(201, 162, 77, 0.35), rgba(225, 194, 122, 1), rgba(201, 162, 77, 0.35));
    border-radius: 999px;
    box-shadow: 0 0 6px rgba(201, 162, 77, 0.35);
}

.conso-entry-count {
    color: #e6e6e6;
    font-size: 0.78rem;
    font-weight: 400;
    letter-spacing: 0.02em;
    white-space: nowrap;
}

.conso-user-type b,
.conso-user-presence,
.conso-user-offert,
.conso-user-status {
    font-size: 0.78rem;
    color: #d9d9d9;
}

.conso-total-offert {
    margin: 0.1rem 0 0 0 !important;
    font-size: 0.78rem;
}

.conso-type-status {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    margin: 0.08rem 0 !important;
}

.conso-type-value,
.conso-status-value {
    display: inline-flex;
    align-items: center;
}
.conso-type-value {
    font-weight: 500;
    font-size: 0.8rem;
    color: #d9d9d9;
}

.conso-user-presence b {
    color: #f0f0f0;
}

.conso-total-title {
    font-size: clamp(1.9rem, 5vw, 2.8rem) !important;
    letter-spacing: 0.01em;
}

.conso-pseudo {
    color: #f0c975 !important;
    font-size: 1.1rem !important;
    font-weight: 600;
}

.conso-info-count {
    color: #53a7f9 !important;
}

.conso-inline-note {
    margin: 0.2rem 0 0.25rem 0 !important;
    color: #f0f0f0 !important;
    font-size: 0.82rem !important;
}

.conso-fidelite-chip {
    background: rgba(201, 162, 77, 0.16);
    color: #fff;
    padding: 0.4rem 0.55rem;
    border-radius: 6px;
    margin-top: 0.45rem;
    text-align: left;
    border: 1px solid rgba(201, 162, 77, 0.34);
    font-size: 0.78rem;
}

/* Statut : Vert = Validé, Orange = À surveiller, Rouge = Nouveau (clignotant) */
.conso-badge-new,
.conso-status-new {
    visibility: visible;
    color: #e04545 !important;  /* Rouge pour Nouveau */
    font-size: 0.8rem !important;
    font-weight: 700;
}

.conso-status-valid { color: #2ecc71 !important; font-size: 0.8rem !important; font-weight: 600; }  /* Vert valide */
.conso-status-danger { color: #ff6b6b !important; font-size: 0.8rem !important; }
.conso-status-watch { color: #f39c12 !important; font-size: 0.8rem !important; font-weight: 600; }  /* Orange à surveiller */
.conso-status-orga { color: #e67e22 !important; font-size: 0.8rem !important; font-weight: 600; }   /* Orange Orga soirée */
.conso-status-muted { color: #c2c2c2 !important; font-size: 0.8rem !important; }
.conso-status-premium { color: #d8d8d8 !important; font-size: 0.8rem !important; font-weight: 700; }
.conso-status-clickable { cursor: pointer; text-decoration: underline; text-underline-offset: 2px; }
.conso-status-clickable:hover { opacity: 0.9; }
.conso-status-btn-link {
    background: none !important;
    border: 0 !important;
    padding: 0 !important;
    font: inherit !important;
    line-height: inherit !important;
    -webkit-appearance: none;
    appearance: none;
}

.conso-vip-banner {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    background-color: #cba248;
    font-size: 1rem;
    color: #fff;
    font-weight: 800;
    text-align: center;
    padding: 8px;
    z-index: 9999;
}

.conso-header-logo {
    width: auto !important;
    max-width: clamp(85px, 11vw, 140px) !important;
    max-height: 44px !important;
    height: auto !important;
    object-fit: contain !important;
}

.conso-caisse-page .conso-header-logo,
.conso-bar-page .conso-header-logo {
    max-height: 42px !important;
}

.conso-marqueur-dot {
    position: relative;
    display: inline-block;
    margin-left: 6px;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: #00ced1;
    vertical-align: middle;
}

/* Tabs : dans le header (conso-tabs-in-header) = pas de position fixed, plus de barre noire */
.conso-caisse-page .main_haeder .tab__line.conso-tabs-in-header,
.conso-bar-page .main_haeder .tab__line.conso-tabs-in-header {
    position: static !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    flex-shrink: 0 !important;
    z-index: 10;
}

/* Tabs : pleine largeur, même fond que bandeau */
.conso-caisse-page .tab__line,
.conso-bar-page .tab__line {
    min-height: 46px;
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0.2rem !important;
    box-sizing: border-box !important;
    background: rgba(255, 255, 255, 0.03) !important;
    border: none !important;
    display: flex;
    align-items: stretch;
}

.conso-caisse-page .main_haeder .tab__line,
.conso-bar-page .main_haeder .tab__line {
    position: static !important;
    top: auto !important;
}
/* Bar : 5 onglets, texte un peu plus petit */
.conso-bar-page .tab__line .nav-link {
    font-size: 0.7rem !important;
    padding: 0.4rem 0.5rem !important;
    letter-spacing: 0.02em !important;
}

.conso-caisse-page .tab__line .nav,
.conso-bar-page .tab__line .nav {
    display: flex !important;
    flex: 1;
    width: 100% !important;
    justify-content: stretch;
    flex-wrap: nowrap !important;
    overflow-x: auto;
    scrollbar-width: none;
    gap: 0 !important;
}
.conso-caisse-page .tab__line .nav-item,
.conso-bar-page .tab__line .nav-item {
    flex: 1 !important;
    min-width: 0 !important;
}
.conso-caisse-page .tab__line .nav-link,
.conso-bar-page .tab__line .nav-link {
    width: 100% !important;
}

.conso-caisse-page .tab__line .nav::-webkit-scrollbar,
.conso-bar-page .tab__line .nav::-webkit-scrollbar {
    display: none;
}

/* Pas de séparation / contour entre les tabs */
.conso-caisse-page .tab__line .nav-item,
.conso-bar-page .tab__line .nav-item {
    border: none !important;
    border-right: none !important;
}

.conso-caisse-page .tab__line .nav-link,
.conso-bar-page .tab__line .nav-link {
    border-radius: 0 !important;
    border: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    color: var(--conso-muted) !important;
    font-weight: 700;
    letter-spacing: 0.04em;
    padding: 0.4rem 0.25rem !important;
    outline: 0 !important;
    box-shadow: none !important;
    min-height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 1 !important;
}
.conso-caisse-page .tab__line .nav-link:hover,
.conso-bar-page .tab__line .nav-link:hover {
    color: var(--conso-text) !important;
    background: transparent !important;
}
.conso-caisse-page .tab__line .nav-link:focus,
.conso-bar-page .tab__line .nav-link:focus,
.conso-caisse-page .tab__line .nav-link:focus-visible,
.conso-bar-page .tab__line .nav-link:focus-visible {
    outline: 0 !important;
    box-shadow: none !important;
}
.conso-caisse-page .tab__line .nav-link.active,
.conso-bar-page .tab__line .nav-link.active {
    color: var(--conso-gold) !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    outline: 0 !important;
}
.conso-caisse-page .tab__line .nav-link.active:focus,
.conso-bar-page .tab__line .nav-link.active:focus {
    outline: 0 !important;
    box-shadow: none !important;
}

.conso-caisse-page .tab__line .nav-pills .nav-link,
.conso-bar-page .tab__line .nav-pills .nav-link {
    background: transparent !important;
}
.conso-caisse-page .tab__line .nav-pills .nav-link.active,
.conso-bar-page .tab__line .nav-pills .nav-link.active {
    background: transparent !important;
    color: var(--conso-gold) !important;
    border: none !important;
}

.conso-caisse-page #content,
.conso-bar-page #content {
    transform: none !important;
    margin-bottom: 40px;
    overflow-y: auto;
    height: calc(100vh - 200px);
    padding: 12px 18px 14px;
    background: #000;
    scrollbar-width: none;
}

.conso-caisse-page #content {
    margin-top: 175px;
}

.conso-bar-page #content {
    margin-top: 142px;
}

.conso-caisse-page #content::-webkit-scrollbar,
.conso-bar-page #content::-webkit-scrollbar {
    display: none;
}

/* Grilles des onglets Entrée / Bouteilles / Divers - alignement et espacement */
.conso-caisse-page .emCategories__learning,
.conso-bar-page .emCategories__learning {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
}

/* Titres de catégories (SOFTS, ALCOOLS, CHAMPAGNES ET VINS, etc.) : centrés */
.conso-caisse-page .emPage__cgLearning > h2,
.conso-bar-page .emPage__cgLearning > h2,
.conso-caisse-page .emCategories__learning > h2,
.conso-bar-page .emCategories__learning > h2 {
    width: 100% !important;
    text-align: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.conso-caisse-page .group--grid,
.conso-bar-page .group--grid {
    display: grid !important;
    width: 100%;
    min-width: 0;
    justify-content: center;
    justify-items: center;
}

/* Bar : .group sans group--grid (verres, cocktails, etc.) → grille 3 colonnes, pas de stacking */
.conso-bar-page .group {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 10px !important;
    width: 100% !important;
    justify-content: center;
    justify-items: stretch;
}
.conso-bar-page .group .item {
    min-width: 0 !important;
    display: flex !important;
    justify-content: center !important;
}

/* Entrée : nombre de colonnes selon le nombre d'items, au moins 2 colonnes si la place le permet */
.conso-caisse-page .group-entree.group--grid,
.conso-bar-page .group-entree.group--grid {
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 1rem;
    max-width: 960px;
}

.conso-caisse-page .group-entree.group--grid .item,
.conso-bar-page .group-entree.group--grid .item {
    max-width: 320px;
}

/* Bouteilles : 4 colonnes fixes sur PC pour éviter le stacking */
.conso-caisse-page .group-bouteilles.group--grid,
.conso-bar-page .group-bouteilles.group--grid {
    grid-template-columns: repeat(4, 280px);
    gap: 12px;
}

@media (max-width: 1200px) {
    .conso-caisse-page .group-bouteilles.group--grid,
    .conso-bar-page .group-bouteilles.group--grid {
        grid-template-columns: repeat(3, 280px);
    }
}

@media (max-width: 900px) {
    .conso-caisse-page .group-bouteilles.group--grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 8px !important;
    }
    .conso-bar-page .group-bouteilles.group--grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 8px !important;
    }
    .conso-caisse-page .group-bouteilles.group--grid .item,
    .conso-bar-page .group-bouteilles.group--grid .item {
        max-width: 100%;
    }
    .conso-caisse-page .group-bouteilles .box__ele,
    .conso-bar-page .group-bouteilles .box__ele {
        width: 100% !important;
    }
}

.conso-caisse-page .group-divers.group--grid,
.conso-bar-page .group-divers.group--grid {
    grid-template-columns: repeat(auto-fill, minmax(260px, 280px));
    gap: 12px;
}

.conso-caisse-page .group--grid .item,
.conso-bar-page .group--grid .item {
    width: 100%;
    max-width: 280px;
    display: flex;
    justify-content: center;
}

.conso-caisse-page .group-bouteilles.group--grid .item,
.conso-bar-page .group-bouteilles.group--grid .item {
    max-width: 280px;
}

.box__ele,
.group .item button,
.group .item form {
    border-radius: 8px !important;
}

.conso-caisse-page .box__ele,
.conso-bar-page .box__ele {
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    background: linear-gradient(155deg, #1e1e1e 0%, #141414 100%) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.03) !important;
    transition: transform 0.15s ease, border-color 0.2s ease, box-shadow 0.2s ease;
    min-height: 72px !important;
    width: 280px !important;
    height: auto !important;
    padding: 0.5rem 0.65rem !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    border-radius: 10px !important;
}
/* Bar : même emplacement du rond/prix dans toutes les cards */
.conso-bar-page .box__ele {
    justify-content: flex-start !important;
}

/* Paiement effectué / Transférer bracelet : style distinct + icône + centrage */
.conso-caisse-page .box__ele.conso-btn-paiement,
.conso-bar-page .box__ele.conso-btn-paiement {
    border-color: rgba(129, 216, 154, 0.5) !important;
    background: linear-gradient(155deg, #1a2420 0%, #121a16 100%) !important;
    min-height: 80px !important;
}

.conso-caisse-page .box__ele.conso-btn-paiement .conso-btn-icon,
.conso-bar-page .box__ele.conso-btn-paiement .conso-btn-icon {
    color: var(--conso-success);
    font-size: 1.4rem;
    margin-bottom: 0.25rem;
}

.conso-caisse-page .box__ele.conso-btn-transfer,
.conso-bar-page .box__ele.conso-btn-transfer {
    border-color: rgba(201, 162, 77, 0.55) !important;
    background: linear-gradient(155deg, #232019 0%, #1a1612 100%) !important;
    min-height: 80px !important;
}

.conso-caisse-page .box__ele.conso-btn-transfer .conso-btn-icon,
.conso-bar-page .box__ele.conso-btn-transfer .conso-btn-icon {
    color: var(--conso-gold);
    font-size: 1.4rem;
    margin-bottom: 0.25rem;
}

.conso-caisse-page .box__ele.conso-btn-erreur .conso-btn-icon,
.conso-bar-page .box__ele.conso-btn-erreur .conso-btn-icon {
    color: var(--conso-danger);
    font-size: 1.4rem;
    margin-bottom: 0.25rem;
}

/* Groupe Paiement / Transfer : bien écartés entre eux, rangée plus en bas */
.conso-caisse-page .group-entree.group--grid.conso-group-actions,
.conso-caisse-page .group-entree.group--grid:has(.conso-btn-paiement) {
    gap: 2rem !important;
    margin-top: 2.25rem !important;
}
.conso-caisse-page .group-entree.group--grid.conso-group-actions .item {
    margin: 0;
}

.conso-caisse-page .box__ele:hover,
.conso-bar-page .box__ele:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.05) !important;
}

/* Bar : boutons dans les grilles prennent la taille de la cellule */
.conso-bar-page .group .box__ele {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
}
.conso-bar-page .group .item {
    min-width: 0 !important;
}

/* Bar : tarif dans un rectangle à coins arrondis */
.conso-bar-page .box__ele .icon {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 0 !important;
    width: auto !important;
    height: auto !important;
    padding: 0.35rem 0.65rem !important;
    margin-bottom: 0.35rem !important;
    border-radius: 8px !important;
    background: rgba(0, 0, 0, 0.45) !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04) !important;
    font-size: 1.25rem !important;
    font-weight: 800 !important;
    color: var(--conso-gold) !important;
    box-sizing: border-box !important;
    white-space: nowrap !important;
    line-height: 1 !important;
    letter-spacing: 0.02em !important;
}
.conso-bar-page .box__ele .icon b {
    font-size: inherit !important;
    color: inherit !important;
    font-weight: 800 !important;
}

.conso-caisse-page .box__ele .txt h2,
.conso-bar-page .box__ele .txt h2 {
    font-size: 0.9rem !important;
    line-height: 1.3 !important;
    color: #f5f5f5 !important;
    letter-spacing: 0.01em;
}

/* Stock : caisse = sous le nom ; bar = montant seul en haut à droite du bouton */
.conso-caisse-page .box__ele .stock {
    display: block !important;
    margin-top: 0.25rem !important;
    margin-bottom: 0 !important;
    font-size: 0.7rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.02em;
    order: 10;
}
.conso-bar-page .box__ele {
    position: relative !important;
}
.conso-bar-page .box__ele .stock {
    position: absolute !important;
    top: 0.4rem !important;
    right: 0.5rem !important;
    left: auto !important;
    margin: 0 !important;
    font-size: 0.75rem !important;
    font-weight: 700 !important;
    order: 0 !important;
    transform: none !important;
}

/* Tarif (prix) dans les boutons : sans encadrement lourd */
.conso-tarif {
    display: inline-block;
    border: 0 !important;
    border-radius: 0;
    padding: 0.1rem 0.25rem;
    background: transparent !important;
    font-weight: 700;
    color: var(--conso-gold) !important;
}

/* Couleurs boutons BAR : couleurs différentes par type, pas flashy (tons doux) */
.conso-bar-page .box__ele.business-color {
    border-color: rgba(100, 130, 160, 0.35) !important;
    background: linear-gradient(155deg, #1c2128 0%, #161b22 100%) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.35), inset 0 1px 0 rgba(100, 130, 160, 0.06) !important;
}
.conso-bar-page .box__ele.business-color:hover {
    border-color: rgba(100, 130, 160, 0.5) !important;
    background: linear-gradient(155deg, #222830 0%, #1a1f26 100%) !important;
}

.conso-bar-page .box__ele.marketing-color {
    border-color: rgba(120, 100, 130, 0.35) !important;
    background: linear-gradient(155deg, #221e28 0%, #1a1722 100%) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.35), inset 0 1px 0 rgba(120, 100, 130, 0.06) !important;
}
.conso-bar-page .box__ele.marketing-color:hover {
    border-color: rgba(120, 100, 130, 0.5) !important;
    background: linear-gradient(155deg, #2a2532 0%, #201d28 100%) !important;
}

.conso-bar-page .box__ele.lifestyle-color {
    border-color: rgba(160, 140, 90, 0.4) !important;
    background: linear-gradient(155deg, #252219 0%, #1c1a14 100%) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.35), inset 0 1px 0 rgba(160, 140, 90, 0.08) !important;
}
.conso-bar-page .box__ele.lifestyle-color:hover {
    border-color: rgba(160, 140, 90, 0.55) !important;
    background: linear-gradient(155deg, #2d281f 0%, #222019 100%) !important;
}

.btn,
button,
.btn-primary,
.btn-secondary,
.btn-danger {
    border-radius: 8px !important;
}

.btn-primary,
.bg-primary {
    background: linear-gradient(135deg, var(--conso-gold), var(--conso-gold-soft)) !important;
    color: #111 !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    font-weight: 700;
}

/* ========== Bar : Bouton ENVOYER (barre fixe en bas) – bloc unique ========== */
#envoyerOverlay {
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    height: 40px !important;
    min-height: 40px !important;
    z-index: 20 !important;
    background: #0a0a0a !important;
    border-top: 1px solid var(--conso-gold) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 1rem !important;
    margin: 0 !important;
}
#envoyerOverlay form {
    margin: 0 !important;
    width: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}
#envoyerBtn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 !important;
    padding: 0.35rem 1.5rem !important;
    min-height: 28px !important;
    height: auto !important;
    width: auto !important;
    background: linear-gradient(135deg, var(--conso-gold), var(--conso-gold-soft)) !important;
    color: #111 !important;
    border: 1px solid rgba(255, 255, 255, 0.25) !important;
    border-radius: 6px !important;
    font-size: 0.8rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.05em !important;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.35) !important;
    position: relative !important;
    left: auto !important;
    bottom: auto !important;
    transform: none !important;
    transition: opacity 0.2s, transform 0.15s !important;
}
#envoyerBtn .icon {
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    border-radius: 0 !important;
    background: transparent !important;
    font-size: inherit !important;
    font-weight: inherit !important;
}
#envoyerBtn:hover {
    opacity: 0.92 !important;
    transform: none !important;
}
#envoyerBtn:active {
    opacity: 0.88 !important;
}

/* Modal restriction bar */
.restriction-modal {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: min(90vw, 460px);
    padding: 0;
    border: 2px solid #d84c4c;
    border-radius: 10px;
    background: #0d0d0d;
    color: #fff;
    box-shadow: 0 12px 36px rgba(0, 0, 0, 0.44);
    z-index: 1000;
}

.restriction-modal-content {
    background: transparent !important;
    text-align: center;
    padding: 1.1rem 1rem 0.7rem 1rem;
}

.restriction-modal-title {
    color: #ff6767 !important;
    margin: 0 0 0.45rem 0 !important;
}

.restriction-modal-text {
    color: #f1f1f1;
    margin: 0;
}

.modal-close-btn {
    background: #c93f3f;
    color: #fff;
    border: 0;
    border-radius: 8px;
    padding: 0.45rem 0.9rem;
    cursor: pointer;
}

.modal-close-btn:hover {
    background: #a82f2f;
}

/* Modals : même style que le reste du site (fond sombre, bordure dorée) */
/* Z-index : contenu au-dessus du voile (backdrop), sinon modal grisé et inutilisable */
.conso-caisse-page .modal.show,
.conso-bar-page .modal.show {
    z-index: 1060 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 1rem !important;
}
.conso-caisse-page .modal.show .modal-dialog,
.conso-bar-page .modal.show .modal-dialog {
    position: relative !important;
    z-index: 1061 !important;
    margin: 0 auto !important;
}
.conso-caisse-page .modal.show .modal-content,
.conso-bar-page .modal.show .modal-content {
    position: relative !important;
    z-index: 1 !important;
}
/* Modals promo + carte payante : centrés au milieu de la page */
/* Ne pas appliquer margin auto au modal liste bar (pleine largeur + rotation) */
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show .modal-dialog {
    margin: 0 !important;
}

.conso-caisse-page .modal-content,
.conso-bar-page .modal-content {
    padding: 0 !important;
    border-radius: var(--conso-radius) !important;
    overflow: hidden;
    background: linear-gradient(155deg, var(--conso-surface) 0%, var(--conso-bg-soft) 100%) !important;
    border: 1px solid var(--conso-border) !important;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.5) !important;
    color: var(--conso-text) !important;
}
.conso-caisse-page .modal-header,
.conso-bar-page .modal-header {
    padding: 1rem 1.5rem !important;
    background: rgba(255, 255, 255, 0.03) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    color: var(--conso-gold) !important;
}
.conso-caisse-page .modal-header .modal-title,
.conso-bar-page .modal-header .modal-title {
    color: var(--conso-gold) !important;
    font-weight: 700 !important;
}
.conso-caisse-page .modal-header .close,
.conso-bar-page .modal-header .close {
    color: var(--conso-text) !important;
    opacity: 0.8;
}
.conso-caisse-page .modal-body,
.conso-bar-page .modal-body {
    padding: 1.25rem 1.5rem !important;
    background: transparent !important;
    color: var(--conso-text) !important;
}
.conso-caisse-page .modal-footer,
.conso-bar-page .modal-footer {
    padding: 1rem 1.5rem !important;
    background: rgba(0, 0, 0, 0.2) !important;
    border-top: 1px solid rgba(255, 255, 255, 0.06) !important;
}
.conso-caisse-page .modal .form-control,
.conso-bar-page .modal .form-control {
    background: var(--conso-surface-2) !important;
    border: 1px solid var(--conso-border) !important;
    color: var(--conso-text) !important;
    border-radius: 8px !important;
}

/* Bouton Vestiaire : style cohérent avec le thème conso */
/* Ligne Prix d’entrée + Bouton vestiaire : alignés, même hauteur */
.conso-prix-vestiaire-row {
    display: flex !important;
    align-items: stretch !important;
    justify-content: center !important;
    gap: 1.25rem !important;
    margin-bottom: 1rem !important;
    margin-top: 0 !important;
    flex-wrap: wrap;
}
.conso-prix-entree-block {
    background: rgba(201, 162, 77, 0.08) !important;
    border: 1px solid rgba(201, 162, 77, 0.4) !important;
    padding: 0.65rem 1rem !important;
    border-radius: 10px !important;
    text-align: center !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.06) !important;
}
.conso-prix-entree-line {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    justify-content: center;
}
.conso-prix-entree-label {
    color: var(--conso-gold) !important;
    font-size: 0.875rem !important;
    font-weight: 700 !important;
}
.conso-prix-entree-value { font-size: 0.875rem !important; font-weight: 700 !important; }
.conso-prix-entree-info {
    font-size: 0.65rem !important;
    color: #53a7f9 !important;
}
.conso-prix-entree-note {
    font-size: 0.55rem !important;
    color: var(--conso-muted) !important;
    margin-top: 0.25rem !important;
}
.conso-vestiaire-wrap {
    margin-bottom: 0 !important;
    display: flex !important;
    align-items: stretch !important;
}
.conso-btn-vestiaire {
    border: 1px solid rgba(201, 162, 77, 0.4) !important;
    min-height: 56px !important;
    height: auto !important;
    padding: 0.5rem 1rem !important;
    min-width: 150px !important;
    border-radius: var(--conso-radius) !important;
    font-size: 0.85rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.02em !important;
    color: var(--conso-text) !important;
    background: linear-gradient(155deg, var(--conso-surface-2) 0%, var(--conso-surface) 100%) !important;
    display: inline-flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25) !important;
    transition: border-color 0.2s, background 0.2s, transform 0.15s !important;
}
.conso-btn-vestiaire:hover {
    border-color: var(--conso-gold) !important;
    background: linear-gradient(155deg, rgba(201, 162, 77, 0.15) 0%, var(--conso-surface) 100%) !important;
    transform: translateY(-1px);
}
.conso-btn-vestiaire--has-num {
    border-color: rgba(129, 216, 154, 0.5) !important;
    background: linear-gradient(155deg, rgba(26, 36, 32, 0.9) 0%, var(--conso-surface) 100%) !important;
}
.conso-btn-vestiaire--has-num:hover {
    border-color: var(--conso-success) !important;
}
.conso-btn-vestiaire-icon {
    font-size: 1.35rem !important;
    color: var(--conso-gold) !important;
    margin-bottom: 0.2rem;
}
.conso-btn-vestiaire .txt { color: inherit !important; }
.conso-vestiaire-num {
    font-size: 0.75rem !important;
    color: var(--conso-gold-soft) !important;
    font-weight: 700 !important;
    margin-top: 3px;
}
.conso-btn-vestiaire--has-num .conso-vestiaire-num {
    color: var(--conso-success) !important;
}

/* Modal vestiaire : clavier et champ au style du site */
.conso-vestiaire-input {
    text-align: center !important;
    font-size: 1.5rem !important;
    font-weight: 700 !important;
    padding: 0.85rem 1rem !important;
    background: var(--conso-surface-2) !important;
    color: var(--conso-text) !important;
    border: 1px solid var(--conso-border) !important;
    border-radius: var(--conso-radius) !important;
}
.conso-vestiaire-keyboard {
    margin-top: 1.25rem;
}
.conso-numpad {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.5rem;
    max-width: 280px;
    margin: 0 auto;
}
.conso-num-btn {
    min-height: 48px;
    border: 1px solid var(--conso-border) !important;
    border-radius: var(--conso-radius) !important;
    background: linear-gradient(155deg, var(--conso-surface-2) 0%, var(--conso-surface) 100%) !important;
    color: var(--conso-text) !important;
    font-size: 1.15rem !important;
    font-weight: 700 !important;
    cursor: pointer;
    transition: border-color 0.2s, background 0.2s;
}
.conso-num-btn:hover {
    border-color: var(--conso-gold) !important;
    background: rgba(201, 162, 77, 0.12) !important;
}
.conso-num-btn--back {
    font-size: 1.25rem !important;
}
.conso-num-btn--clear {
    grid-column: span 2;
    font-size: 0.9rem !important;
    color: var(--conso-muted) !important;
}
.conso-num-btn--clear:hover {
    color: var(--conso-danger) !important;
}
.conso-vestiaire-infos {
    margin-top: 1.25rem;
}
.conso-vestiaire-infos-p {
    color: var(--conso-muted) !important;
    font-size: 0.9rem !important;
    margin: 0 !important;
}

/* Modal historique (liste des consommations) : base commune */
#mdllContent-listview .modal-content {
    background: linear-gradient(155deg, var(--conso-surface) 0%, var(--conso-bg-soft) 100%) !important;
    border: 1px solid var(--conso-border) !important;
    border-radius: var(--conso-radius) !important;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.5) !important;
}
#mdllContent-listview .modal-header {
    position: relative !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    background: rgba(255, 255, 255, 0.03) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    padding: 1rem 1.5rem !important;
    color: var(--conso-gold) !important;
}
#mdllContent-listview .modal-header .close {
    position: absolute !important;
    right: 1rem !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    margin: 0 !important;
    padding: 0.35rem !important;
    opacity: 0.9;
    color: var(--conso-text) !important;
}
#mdllContent-listview .modal-title {
    color: var(--conso-gold) !important;
    font-weight: 700 !important;
}
#mdllContent-listview .modal-body {
    background: transparent !important;
    color: var(--conso-text) !important;
    padding: 1rem 1.25rem !important;
    overflow-y: auto !important;
    max-height: 70vh !important;
}

/* Caisse : modal historique plus stylé (bordure dorée, header soigné) */
.conso-caisse-page #mdllContent-listview .modal-content {
    border: 2px solid var(--conso-border) !important;
    box-shadow: 0 16px 48px rgba(0, 0, 0, 0.55), 0 0 0 1px rgba(201, 162, 77, 0.15) !important;
}
.conso-caisse-page #mdllContent-listview .modal-header {
    background: linear-gradient(180deg, rgba(201, 162, 77, 0.08) 0%, rgba(255, 255, 255, 0.02) 100%) !important;
    border-bottom: 1px solid rgba(201, 162, 77, 0.25) !important;
    padding: 1.1rem 1.5rem !important;
}
.conso-caisse-page #mdllContent-listview .modal-title {
    font-size: 1.1rem !important;
    letter-spacing: 0.03em !important;
}
.conso-caisse-page #mdllContent-listview .modal-body {
    padding: 1.25rem 1.5rem !important;
}
.conso-caisse-page #mdllContent-listview .item-link {
    padding: 0.75rem 0 !important;
    border-radius: 6px !important;
}
.conso-caisse-page #mdllContent-listview .item-link:hover {
    background: rgba(255, 255, 255, 0.03) !important;
}
#mdllContent-listview .padding-t-20,
#mdllContent-listview .em__pkLink {
    background: transparent !important;
    border: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
}
#mdllContent-listview .nav__list,
#mdllContent-listview .nav__list.with_border {
    border: 0 !important;
    border-top: none !important;
    border-bottom: none !important;
    background: transparent !important;
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}
#mdllContent-listview .nav__list li {
    background: transparent !important;
    border: 0 !important;
    border-bottom: none !important;
    list-style: none !important;
}
#mdllContent-listview .item-link {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-wrap: wrap;
    padding: 0.65rem 0 !important;
    border-bottom: none !important;
    gap: 0.5rem;
    background: transparent !important;
    visibility: visible !important;
    opacity: 1 !important;
}
.conso-hist-delete {
    flex-shrink: 0 !important;
}
#mdllContent-listview .item-link .group {
    position: static !important;
    float: none !important;
    margin: 0 !important;
    flex: 1 1 auto;
    min-width: 0;
    background: transparent !important;
    visibility: visible !important;
    opacity: 1 !important;
}
#mdllContent-listview .item-link .group:last-of-type {
    flex: 0 0 auto;
}
#mdllContent-listview .coverImag {
    background: transparent !important;
    border: 0 !important;
    padding: 0 !important;
    margin-right: 0.75rem !important;
    color: var(--conso-muted) !important;
    font-size: 0.85rem !important;
}
#mdllContent-listview .path__name,
#mdllContent-listview .path__name a,
#mdllContent-listview .path__name b {
    color: var(--conso-text) !important;
    font-size: 0.95rem !important;
    visibility: visible !important;
    opacity: 1 !important;
}
#mdllContent-listview .path__name a:hover {
    color: var(--conso-gold) !important;
}
#mdllContent-listview li {
    list-style: none !important;
}
#mdllContent-listview .text-center {
    color: var(--conso-muted) !important;
}
.conso-hist-delete {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 8px;
    color: var(--conso-danger) !important;
    background: rgba(255, 107, 107, 0.12) !important;
    transition: background 0.2s, color 0.2s;
}
.conso-hist-delete:hover {
    background: rgba(255, 107, 107, 0.25) !important;
    color: #ff8787 !important;
}
.conso-hist-delete i {
    font-size: 1.2rem;
}
#mdllContent-listview .conso-offert { color: #53a7f9 !important; }
#mdllContent-listview .conso-supprime { color: var(--conso-danger) !important; }
#mdllContent-listview .conso-non-utilise { color: #f5b14f !important; }
#mdllContent-listview .conso-non-recupere { color: #f5b14f !important; }
#mdllContent-listview .conso-deja-regle { color: var(--conso-success) !important; }

/* ========== BAR : Modal "Liste des consommations" – refait proprement ========== */
/* Body bar a transform rotate(180deg) → contre-rotation du modal pour afficher à l’endroit */
/* Modal liste bar : caché quand fermé (:not(.show)) pour éviter ouverture auto */
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview:not(.show),
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview:not(.show) {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
}
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview {
    z-index: 1055 !important;
    padding: 0 !important;
    max-width: 100% !important;
}
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 1060 !important;
    background: rgba(0, 0, 0, 0.85) !important;
}
/* Quand le modal liste est ouvert, cacher le header (plus de "Bouteilles" visible) */
body.conso-bar-page.conso-bar-listview-open .conso-page-header {
    visibility: hidden !important;
    pointer-events: none !important;
}
body.conso-bar-page .modal-backdrop.show {
    z-index: 1055 !important;
    opacity: 0.85 !important;
}
/* Contre-rotation sur le dialog uniquement (body bar est en 180°) */
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show .modal-dialog,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show .modal-dialog {
    transform: rotate(-180deg) !important;
    transform-origin: center center !important;
    margin: 0 !important;
    max-width: 100% !important;
    width: 100% !important;
    min-width: 100% !important;
    min-height: 280px !important;
    max-height: 85vh !important;
    display: flex !important;
    flex-direction: column !important;
}
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-dialog,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-dialog {
    margin: 0 !important;
    max-width: 100% !important;
    width: 100% !important;
    min-width: 100% !important;
    min-height: 280px !important;
    max-height: 85vh !important;
    display: flex !important;
    flex-direction: column !important;
    transform: none !important;
}
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show .modal-dialog {
    transform: rotate(-180deg) !important;
    transform-origin: center center !important;
}
/* Bar : même apparence que caisse (bordure dorée, header dégradé, padding) */
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-content,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-content {
    flex: 1 !important;
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
    border: 2px solid var(--conso-border) !important;
    box-shadow: 0 16px 48px rgba(0, 0, 0, 0.55), 0 0 0 1px rgba(201, 162, 77, 0.15) !important;
    background: linear-gradient(155deg, var(--conso-surface) 0%, var(--conso-bg-soft) 100%) !important;
    color: #f0f0f0 !important;
    -webkit-text-fill-color: #f0f0f0 !important;
}
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-header,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-header {
    background: linear-gradient(180deg, rgba(201, 162, 77, 0.08) 0%, rgba(255, 255, 255, 0.02) 100%) !important;
    border-bottom: 1px solid rgba(201, 162, 77, 0.25) !important;
    padding: 1.1rem 1.5rem !important;
}
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-title,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-title {
    color: var(--conso-gold) !important;
    font-size: 1.1rem !important;
    letter-spacing: 0.03em !important;
}
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-header .close,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-header .close {
    color: var(--conso-gold) !important;
    opacity: 1 !important;
}
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body {
    flex: 1 !important;
    min-height: 160px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    padding: 1.25rem 1.5rem !important;
    background: #1a1a1a !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .em__pkLink,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .em__pkLink {
    color: #f0f0f0 !important;
    -webkit-text-fill-color: #f0f0f0 !important;
}
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .nav__list,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .nav__list {
    color: #f0f0f0 !important;
    -webkit-text-fill-color: #f0f0f0 !important;
}
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .item-link,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .item-link {
    padding: 0.75rem 0 !important;
    border-radius: 6px !important;
}
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .item-link:hover,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .item-link:hover {
    background: rgba(255, 255, 255, 0.03) !important;
}

/* ========== BAR : liste des consos avec classes dédiées (conso-bar-conso-*) – pas de conflit thème ========== */
#mdllContent-listview .conso-bar-conso-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
    background: transparent !important;
}
#mdllContent-listview .conso-bar-conso-item {
    list-style: none !important;
    border: none !important;
    border-bottom: none !important;
    padding: 0 !important;
    margin: 0 !important;
}
#mdllContent-listview .conso-bar-conso-row {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    width: 100% !important;
    padding: 0.65rem 0 !important;
    gap: 0.5rem !important;
    border: none !important;
    background: transparent !important;
    color: #ffffff !important;
}
#mdllContent-listview .conso-bar-conso-info {
    display: flex !important;
    align-items: center !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
    border: none !important;
}
#mdllContent-listview .conso-bar-conso-time {
    flex-shrink: 0 !important;
    margin-right: 0.75rem !important;
    color: #b0b0b0 !important;
    font-size: 0.9rem !important;
}
#mdllContent-listview .conso-bar-conso-name,
#mdllContent-listview .conso-bar-conso-name a,
#mdllContent-listview .conso-bar-conso-name b {
    color: #ffffff !important;
    font-size: 1rem !important;
}
#mdllContent-listview .conso-bar-conso-name a:hover {
    color: #cba248 !important;
}
#mdllContent-listview .conso-bar-conso-actions {
    flex: 0 0 auto !important;
    margin-left: auto !important;
}
#mdllContent-listview .conso-bar-conso-list .conso-offert { color: #6bb3ff !important; }
#mdllContent-listview .conso-bar-conso-list .conso-supprime { color: #ff8888 !important; }
#mdllContent-listview .conso-bar-conso-list .conso-non-utilise,
#mdllContent-listview .conso-bar-conso-list .conso-non-recupere { color: #f5c050 !important; }
#mdllContent-listview .conso-bar-conso-list .conso-deja-regle { color: #88dd99 !important; }

.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .padding-t-20,
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .em__pkLink,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .padding-t-20,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .em__pkLink {
    display: block !important;
    visibility: visible !important;
    color: #f0f0f0 !important;
    border: none !important;
    border-top: none !important;
    border-bottom: none !important;
}
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .nav__list,
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .nav__list.with_border,
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview ul.nav__list,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .nav__list,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .nav__list.with_border,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview ul.nav__list {
    display: block !important;
    visibility: visible !important;
    border: none !important;
    border-top: none !important;
    border-bottom: none !important;
    border-left: none !important;
    border-right: none !important;
    box-shadow: none !important;
}
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .nav__list li,
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview li,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .nav__list li,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview li {
    border: none !important;
    border-bottom: none !important;
    border-top: none !important;
    box-shadow: none !important;
}
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .item-link,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .item-link {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    justify-content: space-between !important;
    width: 100% !important;
    gap: 0.75rem !important;
    visibility: visible !important;
    opacity: 1 !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    border: none !important;
    border-bottom: none !important;
}
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .item-link .group:first-of-type,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .item-link .group:first-of-type {
    flex: 1 1 auto !important;
    min-width: 0 !important;
    overflow: visible !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 0.5rem !important;
}
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .item-link .group:last-of-type,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .item-link .group:last-of-type {
    flex: 0 0 auto !important;
    flex-shrink: 0 !important;
    margin-left: 0 !important;
}
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .item-link .group,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .item-link .group {
    border: none !important;
}
/* Texte entier visible, pas de troncature */
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .path__name,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .path__name {
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    word-break: break-word !important;
}
/* Texte liste bar : couleurs explicites (override .path__name global) */
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .path__name,
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .path__name a,
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .path__name b,
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .path__name *,
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .coverImag,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .path__name,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .path__name a,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .path__name b,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .path__name *,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .coverImag {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    visibility: visible !important;
    opacity: 1 !important;
    font-size: 1rem !important;
}
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .coverImag,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .coverImag {
    color: #b8b8b8 !important;
    -webkit-text-fill-color: #b8b8b8 !important;
}
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .path__name,
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .path__name a,
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .path__name b,
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .path__name *,
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .coverImag,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .path__name,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .path__name a,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .path__name b,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .path__name *,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .coverImag {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    visibility: visible !important;
    opacity: 1 !important;
    font-size: 1rem !important;
}
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .coverImag,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .coverImag {
    color: #b8b8b8 !important;
    -webkit-text-fill-color: #b8b8b8 !important;
}
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .conso-hist-delete,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .conso-hist-delete,
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .conso-hist-delete i,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .conso-hist-delete i {
    color: #ff8888 !important;
    -webkit-text-fill-color: #ff8888 !important;
}
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .text-center,
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .text-center b,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .text-center,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .text-center b {
    color: #b0b0b0 !important;
    -webkit-text-fill-color: #b0b0b0 !important;
}
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .path__name {
    display: block !important;
}
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .item-link .group:first-of-type {
    display: flex !important;
}
/* Bar listview : couleurs des statuts (offert, supprimé, etc.) bien visibles */
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .conso-offert,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .conso-offert { color: #6bb3ff !important; -webkit-text-fill-color: #6bb3ff !important; }
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .conso-supprime,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .conso-supprime { color: #ff8888 !important; -webkit-text-fill-color: #ff8888 !important; }
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .conso-non-utilise,
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .conso-non-recupere,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .conso-non-utilise,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .conso-non-recupere { color: #f5c050 !important; -webkit-text-fill-color: #f5c050 !important; }
.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .conso-deja-regle,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .conso-deja-regle { color: #88dd99 !important; -webkit-text-fill-color: #88dd99 !important; }

/* Bar listview : surcharge quand le modal est ouvert (.show) – garder bordure dorée sur .modal-content */
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show .modal-body,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show .modal-header,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show .nav__list,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show .nav__list.with_border,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show .nav__list li,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show .item-link,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show .padding-t-20,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show .em__pkLink {
    border: none !important;
    border-bottom: none !important;
    border-top: none !important;
    outline: none !important;
    box-shadow: none !important;
}
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show .nav__list::before,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show .nav__list::after,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show .nav__list li::before,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show .nav__list li::after,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show .item-link::before,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show .item-link::after {
    display: none !important;
    border: none !important;
}
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show .modal-body .path__name,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show .modal-body .path__name a,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show .modal-body .path__name b,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show .modal-body .coverImag,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview.show .modal-body .item-link {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    opacity: 1 !important;
    visibility: visible !important;
}
/* Forcer tout le contenu texte du body du modal bar (override thème / rotation) – path__name b exclu pour garder les couleurs statut */
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .padding-t-20,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .em__pkLink,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .nav__list,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .nav__list li,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .item-link,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .group,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .path__name,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .path__name a,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .coverImag {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    font-size: 1rem !important;
    opacity: 1 !important;
    visibility: visible !important;
}
/* Prix / libellé dans path__name sans classe statut */
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .path__name b:not([class*="conso-"]) {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .text-center,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .text-center b {
    color: #b0b0b0 !important;
    -webkit-text-fill-color: #b0b0b0 !important;
}

/* Bar modal : forcer visibilité du nom des consos (override thème global .path__name) */
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .path__name.conso-bar-list-name,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .path__name.conso-bar-list-name a,
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .path__name.conso-bar-list-name b:not([class*="conso-"]) {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    opacity: 1 !important;
    visibility: visible !important;
}
body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .path__name.conso-bar-list-name a:hover {
    color: var(--conso-gold) !important;
    -webkit-text-fill-color: var(--conso-gold) !important;
}

/* Bar modal liste : texte plus petit sur mobile */
@media (max-width: 768px) {
    .conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-title,
    body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-title {
        font-size: 0.95rem !important;
    }
    .conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .path__name,
    .conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .path__name a,
    .conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .path__name b,
    .conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .coverImag,
    body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .path__name,
    body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .path__name a,
    body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .path__name b,
    body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .coverImag {
        font-size: 0.8rem !important;
    }
    .conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .text-center,
    .conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .text-center b,
    body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .text-center,
    body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .modal-body .text-center b {
        font-size: 0.8rem !important;
    }
}

/* ========== Modal bar liste consos : même style que caisse, pleine largeur, rotation sur le modal ========== */
#conso-bar-listview-modal:not(.show) {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
}
#conso-bar-listview-modal.show {
    display: flex !important;
    align-items: center;
    justify-content: center;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    z-index: 1060 !important;
    background: rgba(0,0,0,0.6) !important;
    overflow: auto;
}
/* Rotation sur le .modal-dialog (comme avant) pour compenser le body bar en 180° */
#conso-bar-listview-modal.show .modal-dialog {
    transform: rotate(-180deg) !important;
    transform-origin: center center !important;
}
/* Pleine largeur comme caisse */
#conso-bar-listview-modal .modal-dialog {
    margin: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 100% !important;
    height: 100%;
}
#conso-bar-listview-modal .modal-content {
    width: 100% !important;
    max-width: 100vw !important;
    min-height: 50vh;
    border: 2px solid var(--conso-border) !important;
    border-radius: var(--conso-radius) !important;
    background: linear-gradient(155deg, var(--conso-surface) 0%, var(--conso-bg-soft) 100%) !important;
    box-shadow: 0 16px 48px rgba(0, 0, 0, 0.55), 0 0 0 1px rgba(201, 162, 77, 0.15) !important;
}
#conso-bar-listview-modal .modal-header {
    position: relative !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    background: linear-gradient(180deg, rgba(201, 162, 77, 0.08) 0%, rgba(255, 255, 255, 0.02) 100%) !important;
    border-bottom: 1px solid rgba(201, 162, 77, 0.25) !important;
    padding: 0.5rem 1rem !important;
    color: var(--conso-gold) !important;
}
#conso-bar-listview-modal .modal-title {
    color: var(--conso-gold) !important;
    font-weight: 700 !important;
    font-size: 0.95rem !important;
    letter-spacing: 0.03em !important;
}
#conso-bar-listview-modal .modal-header .close {
    position: absolute !important;
    right: 1rem !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    margin: 0 !important;
    padding: 0.35rem !important;
    opacity: 0.9;
    color: var(--conso-text) !important;
}
#conso-bar-listview-modal .modal-body {
    background: transparent !important;
    color: var(--conso-text) !important;
    padding: 0.5rem 0.75rem !important;
    overflow-y: auto !important;
    overflow-x: visible !important;
    max-height: 70vh !important;
}
#conso-bar-listview-modal .conso-bar-lv-body .em__pkLink,
#conso-bar-listview-modal .conso-bar-lv-body .padding-t-20 {
    background: transparent !important;
    border: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
}
#conso-bar-listview-modal .conso-bar-lv-body .text-center,
#conso-bar-listview-modal .conso-bar-lv-body .text-center b {
    color: var(--conso-muted) !important;
    font-size: 0.8rem !important;
}
#conso-bar-listview-modal .conso-bar-lv-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    border-top: none !important;
}
#conso-bar-listview-modal .conso-bar-lv-item {
    border: 0 !important;
    border-bottom: none !important;
    list-style: none !important;
}
#conso-bar-listview-modal .conso-bar-lv-row {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-wrap: wrap !important;
    padding: 0.35rem 0 !important;
    border-radius: 4px !important;
    gap: 0.35rem !important;
    background: transparent !important;
}
#conso-bar-listview-modal .conso-bar-lv-row:hover {
    background: rgba(255, 255, 255, 0.03) !important;
}
#conso-bar-listview-modal .conso-bar-lv-left {
    flex: 1 1 auto !important;
    min-width: 0 !important;
    overflow: visible !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.35rem !important;
}
#conso-bar-listview-modal .conso-bar-lv-time {
    flex-shrink: 0;
    color: var(--conso-muted) !important;
    font-size: 0.72rem !important;
}
#conso-bar-listview-modal .conso-bar-lv-text,
#conso-bar-listview-modal .conso-bar-lv-text a,
#conso-bar-listview-modal .conso-bar-lv-text b {
    color: var(--conso-text) !important;
    font-size: 0.8rem !important;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    word-break: break-word;
    visibility: visible !important;
    opacity: 1 !important;
}
#conso-bar-listview-modal .conso-bar-lv-text a:hover {
    color: var(--conso-gold) !important;
}
#conso-bar-listview-modal .conso-bar-lv-right {
    flex-shrink: 0 !important;
}
/* Bouton supprimer : réduit pour liste compacte */
#conso-bar-listview-modal .conso-bar-lv-delete {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 28px !important;
    height: 28px !important;
    border-radius: 6px !important;
    color: var(--conso-danger) !important;
    background: rgba(255, 107, 107, 0.12) !important;
    padding: 0 !important;
    transition: background 0.2s, color 0.2s;
}
#conso-bar-listview-modal .conso-bar-lv-delete:hover {
    background: rgba(255, 107, 107, 0.25) !important;
    color: #ff8787 !important;
}
#conso-bar-listview-modal .conso-bar-lv-delete i {
    font-size: 1rem !important;
    color: var(--conso-danger) !important;
}
#conso-bar-listview-modal .conso-bar-lv-delete:hover i {
    color: #ff8787 !important;
}
#conso-bar-listview-modal .conso-offert { color: #53a7f9 !important; }
#conso-bar-listview-modal .conso-supprime { color: var(--conso-danger) !important; }
#conso-bar-listview-modal .conso-non-utilise,
#conso-bar-listview-modal .conso-non-recupere { color: #f5b14f !important; }
#conso-bar-listview-modal .conso-deja-regle { color: var(--conso-success) !important; }
body.conso-bar-listview-open .conso-page-header {
    visibility: hidden !important;
}

.conso-caisse-page .group-entree.group--grid.conso-group-offres {
    margin-top: 1.5rem !important;
}

@media (max-width: 900px) {
    .conso-caisse-index .scan-shell,
    .conso-bar-index .bar-scan-box {
        margin-top: 94px;
    }
    .conso-caisse-index .conso-index-top-brand,
    .conso-bar-index .conso-index-top-brand {
        font-size: clamp(1.4rem, 4.5vw, 1.75rem) !important;
    }
    .conso-caisse-index .scan-shell h1,
    .conso-bar-index .bar-scan-box h1 {
        font-size: clamp(1.5rem, 4.5vw, 1.9rem) !important;
    }
    .conso-caisse-index .conso-index-status-text,
    .conso-bar-index .conso-index-status-text {
        font-size: 0.84rem !important;
    }
    .conso-caisse-index .conso-index-info-bar .conso-index-info,
    .conso-caisse-index .conso-index-extra,
    .conso-bar-index .conso-index-info-bar .conso-index-info,
    .conso-bar-index .conso-index-extra {
        font-size: 0.84rem !important;
    }

    .conso-caisse-page .emhead,
    .conso-bar-page .emhead {
        display: block !important;
    }

    /* Bandeau caisse : forcer une seule ligne pseudo à gauche | 0€ à droite */
    .conso-caisse-page .conso-header-bar .emhead,
    .conso-caisse-page .conso-header-bar .conso-header-bar-emhead,
    .conso-bar-page .conso-header-bar .emhead,
    .conso-bar-page .conso-header-bar .conso-header-bar-emhead {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
    }
    .conso-caisse-page .conso-header-bar .emhead > .side__right,
    .conso-caisse-page .conso-header-bar .conso-header-bar-emhead > .side__right,
    .conso-bar-page .conso-header-bar .emhead > .side__right,
    .conso-bar-page .conso-header-bar .conso-header-bar-emhead > .side__right {
        flex: 1 1 auto !important;
        min-width: 0 !important;
    }
    .conso-caisse-page .conso-header-bar .emhead > .item__total,
    .conso-caisse-page .conso-header-bar .conso-header-bar-emhead > .item__total,
    .conso-bar-page .conso-header-bar .emhead > .item__total,
    .conso-bar-page .conso-header-bar .conso-header-bar-emhead > .item__total {
        flex: 0 0 auto !important;
    }

    .conso-index-info {
        padding: 0.15rem 0;
        border: 0;
        background: transparent;
    }

    .conso-caisse-page .item__total,
    .conso-bar-page .item__total {
        border-right: 0;
        border-bottom: 1px solid rgba(201, 162, 77, 0.25);
        padding-right: 0;
        padding-bottom: 0.35rem;
        margin-bottom: 0.35rem;
    }

    .conso-caisse-page .side__right,
    .conso-bar-page .side__right {
        min-width: 0;
        text-align: left;
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    .conso-user-mainline {
        justify-content: flex-start;
    }

    .conso-caisse-page .box__ele,
    .conso-bar-page .box__ele {
        width: 100% !important;
    }

    .conso-caisse-page #content,
    .conso-bar-page #content {
        padding-left: 10px;
        padding-right: 10px;
    }

    /* Onglet Entrée : note juste sous vestiaire (prix + bouton vestiaire) */
    .conso-caisse-page #pills-1 .emPage__cgLearning,
    .conso-bar-page #pills-1 .emPage__cgLearning {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: wrap !important;
    }
    .conso-caisse-page #pills-1 .conso-prix-vestiaire-row,
    .conso-bar-page #pills-1 .conso-prix-vestiaire-row {
        order: 1;
        width: 100%;
    }
    .conso-caisse-page #pills-1 .group-entree.conso-group-actions,
    .conso-bar-page #pills-1 .group-entree.conso-group-actions {
        display: contents !important;
    }
    .conso-caisse-page #pills-1 .conso-group-actions .item:has(.conso-note-card),
    .conso-bar-page #pills-1 .conso-group-actions .item:has(.conso-note-card) {
        order: 2;
        width: 100%;
    }
    .conso-caisse-page #pills-1 .conso-group-offres,
    .conso-bar-page #pills-1 .conso-group-offres {
        order: 3;
        width: 100%;
    }
    .conso-caisse-page #pills-1 .conso-group-actions .item:not(:has(.conso-note-card)),
    .conso-bar-page #pills-1 .conso-group-actions .item:not(:has(.conso-note-card)) {
        order: 4;
        width: 50%;
        min-width: 0;
        box-sizing: border-box;
    }

    /* Mobile : grilles pleine largeur, TOUS les boutons exactement la même taille */
    .conso-caisse-page .group--grid,
    .conso-bar-page .group--grid,
    .conso-bar-page .group {
        width: 100% !important;
        max-width: none !important;
        justify-content: center !important;
        justify-items: stretch !important;
        align-items: stretch !important;
        grid-auto-rows: 92px !important;
    }
    .conso-caisse-page .group--grid .item,
    .conso-bar-page .group--grid .item,
    .conso-bar-page .group .item {
        width: 100% !important;
        max-width: none !important;
        min-width: 0 !important;
        min-height: 0 !important;
        display: flex !important;
        align-items: stretch !important;
    }
    .conso-caisse-page .group--grid .item form,
    .conso-bar-page .group--grid .item form,
    .conso-bar-page .group .item form {
        flex: 1 !important;
        min-width: 0 !important;
        min-height: 0 !important;
        display: flex !important;
        width: 100% !important;
        max-width: 100% !important;
    }
    .conso-caisse-page .group--grid .item form button,
    .conso-bar-page .group--grid .item form button,
    .conso-bar-page .group .item form button {
        flex: 1 !important;
        min-width: 0 !important;
        box-sizing: border-box !important;
    }
    .conso-bar-page .group {
        grid-template-columns: repeat(3, 1fr) !important;
        justify-items: stretch !important;
    }

    .conso-caisse-page .group-entree.group--grid,
    .conso-bar-page .group-entree.group--grid {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 0.5rem !important;
        max-width: none !important;
    }
    .conso-caisse-page .group-entree.group--grid .item,
    .conso-bar-page .group-entree.group--grid .item {
        max-width: none !important;
    }
    .conso-caisse-page .group-entree.group--grid.conso-group-actions,
    .conso-caisse-page .group-entree.group--grid:has(.conso-btn-paiement) {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 0.5rem !important;
        margin-top: 1.5rem !important;
    }
    .conso-caisse-page .group-entree.group--grid.conso-group-offres {
        margin-top: 1.25rem !important;
    }
    .conso-caisse-page .group--grid:not(.group-entree),
    .conso-bar-page .group--grid:not(.group-entree) {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 10px !important;
    }
    .conso-caisse-page .group-bouteilles.group--grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
    .conso-bar-page .group-bouteilles.group--grid {
        grid-template-columns: repeat(3, 1fr) !important;
    }

    /* Tous les boutons : même taille (override styles inline bar + pas d’exception paiement/transfer) */
    .conso-caisse-page .group--grid .item button,
    .conso-caisse-page .group--grid .item .box__ele,
    .conso-caisse-page .box__ele,
    .conso-bar-page .box__ele,
    .conso-bar-page .group .item button,
    .conso-bar-page .group .item .box__ele {
        width: 100% !important;
        height: 100% !important;
        min-height: 90px !important;
        max-width: 100% !important;
        padding: 0.65rem 0.7rem !important;
        margin: 0 !important;
        flex: 1 1 0 !important;
        min-width: 0 !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        box-sizing: border-box !important;
    }

    /* Header : bandeau plus fin sur mobile */
    .conso-caisse-page .conso-header-bar,
    .conso-bar-page .conso-header-bar {
        padding: 0.2rem 0.6rem 0.25rem !important;
    }
    .conso-caisse-page .conso-header-bar .side__right,
    .conso-bar-page .conso-header-bar .side__right {
        padding: 0.15rem 0.4rem 0.18rem !important;
    }
    .conso-caisse-page .conso-header-bar .item__total,
    .conso-bar-page .conso-header-bar .item__total {
        padding: 0.2rem 0 0 0.6rem !important;
    }
    .conso-caisse-page .conso-header-bar .item__total a.btn,
    .conso-bar-page .conso-header-bar .item__total a.btn {
        padding: 0.15rem 0 !important;
    }
    .conso-caisse-page .conso-header-bar .item__total p,
    .conso-caisse-page .conso-header-bar .item__total b,
    .conso-bar-page .conso-header-bar .item__total p,
    .conso-bar-page .conso-header-bar .item__total b {
        margin: 0.12rem 0 0 !important;
    }
    .conso-caisse-page .conso-user-mainline,
    .conso-bar-page .conso-user-mainline {
        margin-bottom: 0.1rem !important;
    }
    .conso-caisse-page .side__right p,
    .conso-bar-page .side__right p {
        margin: 0.06rem 0 !important;
    }
    .conso-caisse-page .conso-pseudo,
    .conso-bar-page .conso-pseudo {
        font-size: 0.85rem !important;
    }
    .conso-caisse-page .conso-entry-count,
    .conso-caisse-page .conso-type-status,
    .conso-caisse-page .conso-user-presence,
    .conso-bar-page .side__right p {
        font-size: 0.7rem !important;
    }
    .conso-caisse-page .item__total h2,
    .conso-bar-page .item__total h2,
    .conso-caisse-page .conso-header-bar .item__total .conso-total-title,
    .conso-bar-page .conso-header-bar .item__total .conso-total-title {
        font-size: 1.1rem !important;
    }
    .conso-caisse-page .item__total p,
    .conso-caisse-page .item__total span,
    .conso-bar-page .item__total p,
    .conso-bar-page .item__total span {
        font-size: 0.7rem !important;
    }
    .conso-caisse-page .tab__line .nav-link,
    .conso-bar-page .tab__line .nav-link {
        font-size: 0.74rem !important;
        padding: 0.32rem 0.4rem 0.36rem !important;
        min-height: 36px !important;
    }
    .conso-bar-page .tab__line .nav-link {
        font-size: 0.62rem !important;
        padding: 0.28rem 0.3rem !important;
    }
    .conso-caisse-page .tab__line,
    .conso-bar-page .tab__line {
        min-height: 38px !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
        padding-top: 0.15rem !important;
        padding-bottom: 0.15rem !important;
    }

    /* Stock : bien calé dans l’angle du bouton sur mobile */
    .conso-bar-page .box__ele .stock {
        position: absolute !important;
        top: 0.2rem !important;
        right: 0.35rem !important;
        left: auto !important;
        margin: 0 !important;
        font-size: 0.65rem !important;
        font-weight: 700 !important;
        white-space: nowrap !important;
        line-height: 1.2 !important;
    }
    .conso-bar-page .box__ele {
        position: relative !important;
        overflow: visible !important;
    }

    .conso-prix-entree-label,
    .conso-prix-entree-value {
        font-size: 0.75rem !important;
    }
    .conso-prix-entree-note,
    .conso-prix-entree-info {
        font-size: 0.62rem !important;
    }
    .conso-prix-vestiaire-row {
        gap: 0.6rem !important;
        margin-top: 0.6rem !important;
        margin-bottom: 0.75rem !important;
    }
    /* Historique : garder l’icône supprimer sur la même ligne */
    #mdllContent-listview .item-link {
        flex-wrap: nowrap !important;
        padding: 0.4rem 0 !important;
    }
    #mdllContent-listview .item-link .group:first-of-type {
        min-width: 0 !important;
        overflow: hidden !important;
    }
    #mdllContent-listview .item-link .path__name {
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        font-size: 0.8rem !important;
    }
    /* Bar modal liste : texte entier visible (pas de troncature) */
    .conso-bar-page #mdllContent-listview.conso-bar-modal-listview .item-link .group:first-of-type,
    body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .item-link .group:first-of-type {
        overflow: visible !important;
    }
    .conso-bar-page #mdllContent-listview.conso-bar-modal-listview .item-link .path__name,
    body.conso-bar-page #mdllContent-listview.conso-bar-modal-listview .item-link .path__name {
        white-space: normal !important;
        overflow: visible !important;
        text-overflow: clip !important;
    }
    #mdllContent-listview .coverImag {
        font-size: 0.75rem !important;
    }
    .conso-hist-delete {
        width: 34px !important;
        height: 34px !important;
    }
    .conso-hist-delete i {
        font-size: 1.1rem !important;
    }
    .conso-btn-vestiaire {
        font-size: 0.75rem !important;
        min-height: 44px !important;
        padding: 0.32rem 0.6rem !important;
        min-width: 100px !important;
    }
    .conso-btn-vestiaire-icon {
        font-size: 1.05rem !important;
    }
    .conso-vestiaire-num {
        font-size: 0.65rem !important;
    }
    .conso-caisse-page .box__ele .txt h2,
    .conso-bar-page .box__ele .txt h2 {
        font-size: 0.8rem !important;
        line-height: 1.22 !important;
    }
    /* Bar mobile : rond et prix un peu plus petits, noms de boissons plus petits, titres catégories plus petits */
    .conso-bar-page .emPage__cgLearning > h2,
    .conso-bar-page .emCategories__learning > h2 {
        font-size: 0.95rem !important;
    }
    .conso-bar-page .box__ele .txt h2 {
        font-size: 0.72rem !important;
        line-height: 1.2 !important;
    }
    /* Bar mobile : tarif un peu plus petit (pas de rond) */
    .conso-bar-page .box__ele .icon {
        font-size: 1rem !important;
        margin-bottom: 0.3rem !important;
    }
    .conso-caisse-page .box__ele.conso-btn-paiement .conso-btn-icon,
    .conso-caisse-page .box__ele.conso-btn-transfer .conso-btn-icon,
    .conso-caisse-page .box__ele.conso-btn-erreur .conso-btn-icon {
        font-size: 1.1rem !important;
        margin-bottom: 0.18rem !important;
    }
    .conso-tarif {
        font-size: 0.78rem !important;
    }
    .conso-fidelite-chip {
        font-size: 0.75rem !important;
        padding: 0.35rem 0.5rem !important;
        margin-top: 0.4rem !important;
    }
    .conso-inline-note {
        font-size: 0.8rem !important;
        margin: 0.18rem 0 0.22rem 0 !important;
    }
    .conso-note-card {
        padding: 0.6rem 1.2rem 0.6rem 0.9rem !important;
        margin: 0.45rem auto !important;
    }
    .conso-note-title {
        font-size: 0.72rem !important;
    }
    .conso-note-text {
        font-size: 0.8rem !important;
        margin: 0 0 0.35rem 0 !important;
    }
    .conso-note-meta {
        font-size: 0.65rem !important;
    }
    .conso-promo-title {
        font-size: 0.95rem !important;
    }
    .conso-promo-subtitle {
        font-size: 0.75rem !important;
        padding: 0.3rem 0.6rem 0 !important;
    }
    .conso-promo-item {
        font-size: 0.8rem !important;
        padding: 0.45rem 0 !important;
        line-height: 1.32 !important;
    }
    .conso-promo-header,
    .conso-promo-body,
    .conso-promo-footer {
        padding: 0.6rem 0.85rem !important;
    }
    .conso-caisse-page .modal-header .modal-title,
    .conso-bar-page .modal-header .modal-title {
        font-size: 0.92rem !important;
    }
    .conso-caisse-page .modal-body,
    .conso-bar-page .modal-body {
        padding: 0.75rem 0.9rem !important;
        font-size: 0.82rem !important;
    }
}

/* Très petit écran mobile : 2 colonnes caisse, 3 colonnes bar */
@media (max-width: 400px) {
    .conso-caisse-page .group-entree.group--grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
    .conso-bar-page .group-entree.group--grid {
        grid-template-columns: repeat(3, 1fr) !important;
    }
    .conso-caisse-page .group--grid:not(.group-entree) {
        grid-template-columns: repeat(2, 1fr) !important;
    }
    .conso-bar-page .group,
    .conso-bar-page .group--grid:not(.group-entree) {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

/* ========== NOTES (module note.php) – différencié des boutons d’action ========== */
.conso-note-card {
    position: relative;
    max-width: 400px;
    margin: 0.75rem auto;
    padding: 1rem 2rem 1rem 1.25rem;
    background: linear-gradient(145deg, rgba(201, 162, 77, 0.06) 0%, var(--conso-surface-2) 100%) !important;
    border: 1px solid rgba(201, 162, 77, 0.5) !important;
    border-radius: 12px !important;
    color: var(--conso-text);
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.25), 0 0 0 1px rgba(201, 162, 77, 0.15) !important;
}
.conso-note-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--conso-gold), transparent);
    border-radius: 12px 12px 0 0;
    opacity: 0.6;
}
.conso-note-title {
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    color: var(--conso-gold);
    text-align: center;
    margin: 0 0 0.5rem 0;
}
.conso-note-text {
    font-size: 0.9rem;
    line-height: 1.4;
    color: var(--conso-success);
    text-align: center;
    margin: 0 0 0.6rem 0;
}
.conso-note-meta {
    font-size: 0.75rem;
    color: var(--conso-muted);
    text-align: center;
    margin: 0;
}
.conso-note-meta strong { color: var(--conso-text); }
.conso-note-meta em { font-style: italic; opacity: 0.95; }
.conso-note-delete {
    position: absolute;
    top: 0.5rem;
    right: 0.5rem;
    width: 28px;
    height: 28px;
    border: 0;
    border-radius: 6px;
    background: rgba(255, 107, 107, 0.15);
    color: var(--conso-danger);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    transition: background 0.2s;
}
.conso-note-delete:hover {
    background: rgba(255, 107, 107, 0.3);
}
.conso-note-delete i { font-size: 1.1rem; }
.conso-hidden-form { display: none !important; }

/* ========== MODAL PROMO (module promo.php) ========== */
.conso-promo-modal .modal-dialog {
    max-width: 360px;
}
/* Modal promo : plus large, header/footer moins épais, texte plus petit */
.conso-promo-modal .modal-dialog {
    max-width: 420px !important;
}
.conso-promo-content {
    background: linear-gradient(155deg, var(--conso-surface) 0%, var(--conso-bg-soft) 100%) !important;
    border: 1px solid rgba(129, 216, 154, 0.4) !important;
    border-radius: var(--conso-radius) !important;
    overflow: hidden;
}
.conso-promo-header {
    padding: 0.5rem 0.75rem !important;
    background: rgba(129, 216, 154, 0.08) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    position: relative;
}
.conso-promo-title {
    margin: 0 !important;
    font-size: 0.95rem !important;
    font-weight: 700 !important;
    color: var(--conso-success) !important;
    letter-spacing: 0.03em;
}
.conso-promo-header .close {
    position: absolute;
    right: 0.5rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--conso-text) !important;
    opacity: 0.8;
    font-size: 1rem !important;
}
.conso-promo-subtitle {
    text-align: center;
    font-size: 0.8rem;
    color: var(--conso-muted);
    margin: 0;
    padding: 0.35rem 0.75rem 0;
}
.conso-promo-pseudo {
    color: var(--conso-gold) !important;
}
.conso-promo-body {
    padding: 0.75rem 1rem !important;
    max-height: 50vh;
    overflow-y: auto;
}
.conso-promo-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
}
.conso-promo-item {
    padding: 0.75rem 0 !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06) !important;
    font-size: 0.9rem !important;
    line-height: 1.45 !important;
    color: var(--conso-text) !important;
}
.conso-promo-item:last-child {
    border-bottom: 0 !important;
}
.conso-promo-item-title {
    color: var(--conso-gold) !important;
    font-weight: 700;
}
.conso-promo-item .conso-text-danger {
    color: var(--conso-danger) !important;
}
.conso-promo-footer {
    padding: 0.5rem 0.75rem !important;
    background: rgba(0, 0, 0, 0.2) !important;
    border-top: 1px solid rgba(255, 255, 255, 0.06) !important;
    justify-content: center !important;
}
.conso-promo-btn {
    min-width: 100px !important;
    padding: 0.4rem 1rem !important;
    font-size: 0.85rem !important;
    border-radius: var(--conso-radius) !important;
    font-weight: 700 !important;
    background: linear-gradient(135deg, var(--conso-success), #5ecf86) !important;
    border: 0 !important;
    color: #fff !important;
    cursor: pointer;
}
.conso-promo-btn:hover {
    opacity: 0.95;
    color: #fff !important;
}

/* ========== Modal motif (À surveiller / Orga soirée) : au-dessus du voile, fermable ========== */
#consoMotifModal.show,
#consoMotifModal.modal.show {
    z-index: 1070 !important;
}
#consoMotifModal .modal-dialog {
    position: relative;
    z-index: 1071 !important;
}
#consoMotifModal .modal-content {
    position: relative;
    z-index: 1;
}
.conso-motif-content {
    background: linear-gradient(155deg, var(--conso-surface) 0%, var(--conso-bg-soft) 100%) !important;
    border: 1px solid rgba(243, 156, 18, 0.4) !important;
    border-radius: var(--conso-radius) !important;
}
.conso-motif-header {
    padding: 0.25rem 0.5rem 0.25rem 0.75rem !important;
    min-height: auto !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    align-items: center !important;
}
.conso-motif-title {
    margin: 0 !important;
    font-size: 0.8rem !important;
    font-weight: 700 !important;
    color: var(--conso-text) !important;
    flex: 1 1 auto !important;
}
.conso-motif-close {
    margin: 0 !important;
    padding: 0.25rem 0.4rem !important;
    font-size: 1.4rem !important;
    line-height: 1 !important;
    color: #fff !important;
    opacity: 0.9 !important;
    background: transparent !important;
    border: 0 !important;
    cursor: pointer !important;
}
.conso-motif-close:hover {
    opacity: 1 !important;
    color: #fff !important;
}
.conso-motif-body {
    padding: 0.75rem 1rem !important;
    max-height: 50vh;
    overflow-y: auto;
}
.conso-motif-text {
    margin: 0 !important;
    font-size: 0.9rem !important;
    line-height: 1.5 !important;
    color: var(--conso-text) !important;
    white-space: pre-wrap;
}

/* ========== Modal Carte payante (paye_carte.php) : plus large, header/footer moins épais, texte plus petit ========== */
.conso-paye-carte-modal .modal-dialog {
    max-width: 400px !important;
}
.conso-paye-carte-content {
    background: linear-gradient(155deg, var(--conso-surface) 0%, var(--conso-bg-soft) 100%) !important;
    border: 1px solid rgba(255, 107, 107, 0.4) !important;
    border-radius: var(--conso-radius) !important;
    color: var(--conso-text) !important;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.4) !important;
}
.conso-paye-carte-header {
    padding: 0.5rem 0.75rem !important;
    background: rgba(255, 107, 107, 0.12) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
}
.conso-paye-carte-title {
    margin: 0 !important;
    font-size: 0.95rem !important;
    font-weight: 700 !important;
    color: var(--conso-danger) !important;
}
.conso-paye-carte-subtitle {
    text-align: center;
    font-size: 0.8rem;
    color: var(--conso-muted);
    padding: 0 0.75rem;
    margin: 0 !important;
}
.conso-paye-carte-pseudo {
    color: var(--conso-gold) !important;
}
.conso-paye-carte-body {
    padding: 0.75rem 1rem !important;
    text-align: center;
}
.conso-paye-carte-amount {
    margin: 0 !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    color: #f5f5f5 !important;
}
.conso-paye-carte-footer {
    padding: 0.5rem 0.75rem !important;
    background: rgba(0, 0, 0, 0.2) !important;
    border-top: 1px solid rgba(255, 255, 255, 0.06) !important;
}
.conso-paye-carte-btn {
    min-width: 90px !important;
    padding: 0.4rem 1rem !important;
    font-size: 0.85rem !important;
    border-radius: var(--conso-radius) !important;
    background: linear-gradient(135deg, var(--conso-danger), #d94545) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    color: #fff !important;
    font-weight: 700 !important;
    cursor: pointer;
}
.conso-paye-carte-btn:hover {
    opacity: 0.95;
    color: #fff !important;
}

/* ========== PAGE PARAMÈTRES CAISSE (parametre.php) ========== */
.conso-parametre-page #wrapper,
.conso-parametre-page #content {
    background: #0a0a0a !important;
    min-height: 100vh;
}

/* Header paramètres : logo centré + barre dorée visible (comme index/conso) */
body.conso-parametre-page .conso-parametre-header {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 12 !important;
    width: 100% !important;
    max-width: 100vw !important;
    margin: 0 !important;
    padding: 0 !important;
    background: linear-gradient(135deg, rgba(19, 19, 19, 0.98), rgba(7, 7, 7, 0.99)) !important;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.4) !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    text-align: center !important;
}
body.conso-parametre-page .conso-parametre-header-inner {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0.6rem 1rem !important;
    min-height: 56px !important;
    width: 100% !important;
    box-sizing: border-box !important;
}
body.conso-parametre-page .conso-parametre-logo-wrap {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    max-width: 100% !important;
}
body.conso-parametre-page .conso-parametre-header .conso-header-logo {
    max-height: 44px !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
    display: block !important;
    margin: 0 auto !important;
}
/* Barre dorée sous le logo */
body.conso-parametre-page .conso-parametre-barre {
    height: 3px !important;
    width: 100% !important;
    min-width: 100% !important;
    background: linear-gradient(90deg, transparent 0%, var(--conso-gold) 15%, var(--conso-gold) 85%, transparent 100%) !important;
    flex-shrink: 0 !important;
}
body.conso-parametre-page .conso-parametre-title-bar {
    padding: 0.5rem 1rem !important;
    text-align: center !important;
    background: rgba(0, 0, 0, 0.3) !important;
    width: 100% !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}
body.conso-parametre-page .conso-parametre-title {
    margin: 0 !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.04em !important;
    color: var(--conso-gold) !important;
    text-align: center !important;
}

/* Contenu sous le header fixe – pleine largeur */
body.conso-parametre-page #content {
    width: 100% !important;
    max-width: 100% !important;
    display: block !important;
}
body.conso-parametre-page .conso-parametre-main {
    padding-top: 0 !important;
    padding-bottom: 2rem !important;
    width: 100% !important;
    max-width: 100% !important;
    display: block !important;
    box-sizing: border-box !important;
}
body.conso-parametre-page .tab-content {
    width: 100% !important;
    max-width: 100% !important;
    display: block !important;
}
body.conso-parametre-page .tab-pane {
    width: 100% !important;
}
body.conso-parametre-page .tab-pane.active {
    display: block !important;
}
.conso-parametre-tabs {
    margin-top: 0.9rem !important;
    margin-bottom: 0.35rem !important;
}

/* Alertes (offert, addbtl, delete) */
.conso-parametre-alert {
    text-align: center !important;
    font-size: 0.85rem !important;
    padding: 0.5rem 1rem !important;
    margin-bottom: 1rem !important;
    border-radius: 8px !important;
    visibility: visible !important;
}
.conso-parametre-alert--success {
    color: #7dd39b !important;
    background: rgba(125, 211, 155, 0.12) !important;
    border: 1px solid rgba(125, 211, 155, 0.35) !important;
}
.conso-parametre-alert--error {
    color: #f08080 !important;
    background: rgba(240, 128, 128, 0.12) !important;
    border: 1px solid rgba(240, 128, 128, 0.35) !important;
}

/* Boutons bien sous le header (marge haute) + peu d'écart avec l'onglet "Suivi..." */
body.conso-parametre-page .conso-parametre-actions {
    margin-top: 125px !important;
    margin-bottom: 0.25rem !important;
    padding-top: 0 !important;
}
.conso-parametre-page .conso-parametre-actions .btn.conso-parametre-btn {
    height: 80px !important;
    font-weight: 700 !important;
    letter-spacing: 0.03em !important;
    border-radius: 10px !important;
    border: 1px solid rgba(201, 162, 77, 0.35) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.4rem !important;
}
.conso-parametre-page .conso-parametre-actions .btn.conso-parametre-btn i {
    font-size: 1.2rem !important;
}
.conso-parametre-page .conso-parametre-actions .btn-primary {
    background: linear-gradient(135deg, var(--conso-gold), var(--conso-gold-soft)) !important;
    color: #111 !important;
}
.conso-parametre-page .conso-parametre-actions .btn-primary:hover {
    opacity: 0.92;
    color: #111 !important;
}
.conso-parametre-page .conso-parametre-actions .btn-secondary {
    background: linear-gradient(135deg, #2a2a2a, #1a1a1a) !important;
    color: #e0e0e0 !important;
    border-color: rgba(255, 255, 255, 0.15) !important;
}
.conso-parametre-page .conso-parametre-actions .btn-danger {
    background: linear-gradient(135deg, #c93a3a, #a02d2d) !important;
    color: #fff !important;
    border-color: rgba(255, 255, 255, 0.2) !important;
}
.conso-parametre-page .conso-parametre-actions .btn-danger:hover {
    opacity: 0.9;
    color: #fff !important;
}
.conso-parametre-page .tab__line {
    border-bottom: 1px solid var(--conso-gold) !important;
}
.conso-parametre-page .tab__line .nav-link {
    color: var(--conso-gold) !important;
    font-weight: 600 !important;
}

/* Bloc "Montant restant à régler" – style tarif conso */
.conso-parametre-montant-wrap {
    display: flex !important;
    justify-content: center !important;
    margin: 1.25rem 0 1.5rem !important;
}
.conso-parametre-montant-block {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 0.35rem !important;
    padding: 0.85rem 1.5rem !important;
    min-width: 200px !important;
    background: rgba(201, 162, 77, 0.08) !important;
    border: 1px solid rgba(201, 162, 77, 0.45) !important;
    border-radius: 12px !important;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.25), inset 0 1px 0 rgba(255, 255, 255, 0.04) !important;
}
.conso-parametre-montant-label {
    font-size: 0.8rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.03em !important;
    color: var(--conso-gold) !important;
}
.conso-parametre-montant-value {
    font-size: 1.5rem !important;
    font-weight: 700 !important;
    color: #fff !important;
}

/* Liste / tableau paramètres – style propre, mise en page forcée */
body.conso-parametre-page .conso-parametre-list-section {
    padding: 1rem 0 2rem !important;
    max-width: 100% !important;
    width: 100% !important;
    overflow-x: auto !important;
    display: block !important;
    box-sizing: border-box !important;
}
body.conso-parametre-page .conso-parametre-table {
    display: table !important;
    table-layout: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    border-collapse: collapse !important;
    background: transparent !important;
    font-size: 0.9rem !important;
}
body.conso-parametre-page .conso-parametre-table thead {
    display: table-header-group !important;
}
body.conso-parametre-page .conso-parametre-table tbody {
    display: table-row-group !important;
}
body.conso-parametre-page .conso-parametre-table tr {
    display: table-row !important;
}
body.conso-parametre-page .conso-parametre-table th,
body.conso-parametre-page .conso-parametre-table td {
    display: table-cell !important;
}
body.conso-parametre-page .conso-parametre-table thead th {
    text-align: left !important;
    padding: 0.65rem 0.75rem !important;
    font-weight: 600 !important;
    color: var(--conso-gold) !important;
    background: rgba(201, 162, 77, 0.08) !important;
    border-bottom: 1px solid rgba(201, 162, 77, 0.4) !important;
}
body.conso-parametre-page .conso-parametre-table thead th:first-child { border-radius: 8px 0 0 0; }
body.conso-parametre-page .conso-parametre-table thead th:last-child { border-radius: 0 8px 0 0; }
body.conso-parametre-page .conso-parametre-table tbody tr {
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    transition: background 0.15s !important;
}
body.conso-parametre-page .conso-parametre-table tbody tr:hover {
    background: rgba(201, 162, 77, 0.06) !important;
}
body.conso-parametre-page .conso-parametre-table tbody tr:last-child { border-bottom: none !important; }
body.conso-parametre-page .conso-parametre-table td {
    padding: 0.7rem 0.75rem !important;
    color: #e5e5e5 !important;
}
body.conso-parametre-page .conso-parametre-table .conso-parametre-pseudo-link {
    color: var(--conso-gold-soft) !important;
    text-decoration: none !important;
    font-weight: 500 !important;
}
body.conso-parametre-page .conso-parametre-table .conso-parametre-pseudo-link:hover {
    color: var(--conso-gold) !important;
}
body.conso-parametre-page .conso-parametre-table .conso-parametre-montant {
    color: var(--conso-gold) !important;
    font-weight: 700 !important;
}
/* Modal code sécurité (parametre.php) */
#codeModal {
    display: none;
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.92);
    justify-content: center;
    align-items: center;
}
#codeModal[style*="flex"] {
    display: flex !important;
}
#codeModal .modal-content {
    background: linear-gradient(145deg, #141414, #0d0d0d) !important;
    padding: 1.5rem !important;
    border-radius: 12px !important;
    border: 1px solid rgba(201, 162, 77, 0.45) !important;
    text-align: center !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(201, 162, 77, 0.15) !important;
    width: min(400px, 92vw) !important;
    animation: conso-modal-fadeIn 0.3s ease-in-out;
}
#codeModal .modal-title {
    font-size: 1.25rem !important;
    margin-bottom: 1rem !important;
    color: #f0f0f0 !important;
}
#codeModal p {
    color: #b0b0b0 !important;
    margin-bottom: 1rem !important;
}
#codeModal .code-display {
    width: 80% !important;
    padding: 0.75rem 1rem !important;
    margin-bottom: 1.25rem !important;
    border: 1px solid rgba(201, 162, 77, 0.4) !important;
    border-radius: 8px !important;
    font-size: 1.25rem !important;
    text-align: center !important;
    background: rgba(0, 0, 0, 0.4) !important;
    color: #fff !important;
}
#codeModal .keypad {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 0.5rem !important;
}
#codeModal .key {
    background: linear-gradient(135deg, #2a2a2a, #1a1a1a) !important;
    color: #fff !important;
    padding: 0.9rem !important;
    font-size: 1.1rem !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    transition: background 0.2s, border-color 0.2s !important;
}
#codeModal .key:hover {
    background: linear-gradient(135deg, rgba(201, 162, 77, 0.25), rgba(201, 162, 77, 0.12)) !important;
    border-color: rgba(201, 162, 77, 0.5) !important;
}
#codeModal .key.ok-button {
    background: linear-gradient(135deg, #2d6b3a, #1e4d28) !important;
    border-color: rgba(129, 216, 154, 0.4) !important;
}
#codeModal .key.ok-button:hover {
    background: linear-gradient(135deg, #3a8050, #2d6b3a) !important;
    border-color: var(--conso-success) !important;
}
@keyframes conso-modal-fadeIn {
    from { opacity: 0; transform: scale(0.95); }
    to { opacity: 1; transform: scale(1); }
}
