/*
Theme Name: CBL
Theme URI: https://cblyon.fr
Author: Club Business Lyon
Author URI: https://cblyon.fr
Description: Thème custom du Club Business Lyon. Design system « papier / ambre / menthe » : grille 1180, typo Space Grotesk + Instrument Sans, cartes plates. Soigne les pages publiques, la boutique WooCommerce (inscription aux événements) et l'espace membre.
Version: 2.1.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: cbl
Tags: custom-colors, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready, e-commerce, business, two-columns
*/

/* =========================================================================
   DESIGN TOKENS — système « papier / ambre / menthe »
   Neutres = maquette (inchangés). Accent = marque CBL (ambre + menthe),
   PAS le cobalt de la maquette.
   ========================================================================= */
:root {
    /* Neutres (exactement ceux de la maquette) */
    --paper:      #f4f3ef; /* fond de page (body) */
    --ink:        #15171c; /* texte principal / fonds sombres */
    --ink-2:      #4a4e56; /* texte courant / paragraphes */
    --muted:      #71757c; /* texte secondaire */
    --muted-2:    #8a8e96; /* labels, méta, breadcrumb */
    --surface:    #ffffff; /* cartes, header */
    --surface-2:  #fbfaf7; /* cartes secondaires */
    --line:       #e7e5df; /* bordures / séparateurs */
    --line-2:     #eee9e0; /* lignes de tableau (variante) */
    --line-3:     #f2efe7; /* lignes de tableau (variante douce) */
    --footer-bg:  #111318; /* fond footer */

    /* Accent MARQUE (remplace le cobalt) */
    --primary:        #FFC43D; /* fond bouton primaire (ambre) */
    --primary-ink:    #15171c; /* texte sur ambre (JAMAIS blanc) */
    --primary-hover:  #E0A81F; /* survol bouton primaire (ambre foncé) */
    --accent:         #06A97E; /* liens, eyebrows, « Voir → » (menthe foncée) */
    --accent-hover:   #15171c; /* survol des liens accent */
    --accent-tint:    #FFF3D6; /* fond tags / badges numérotés (ambre-tint) */
    --accent-tint-ink:#15171c; /* texte sur ambre-tint */
    --accent-tint-ink-alt:#B07A00; /* variante texte ambre foncé */
    --mint:           #06D6A0; /* menthe vive (points, puces) */

    /* Badge « Active » (menthe) */
    --active-bg:  #E6FBF4;
    --active-ink: #06A97E;

    /* Bordures d'input / boutons ghost */
    --ctrl-border: #dcdad3;
    --ctrl-border-hover: #15171c;

    /* États panier / erreur */
    --danger:        #c04a4a;
    --danger-soft:   #b98a8a;
    --danger-border: #eadfe0;
    --danger-bg:     #fbeeee;
    --danger-border-hover: #e6b9b9;

    /* Rayons */
    --radius-ctrl: 10px; /* boutons / inputs */
    --radius-card: 16px; /* cartes */
    --radius-lg:   22px; /* grandes cartes / bandeaux */
    --radius-pill: 999px;

    /* Ombres (design plat — ombre seulement au survol carte produit) */
    --shadow-card-hover: 0 8px 24px rgba(20, 22, 26, .07);
    --shadow-soft: 0 1px 2px rgba(20, 22, 26, .05);

    /* Layout */
    --wrap: 1180px;
    --wrap-pad: 32px;
    --gap: 24px;

    /* Typo */
    --font-head: 'Space Grotesk', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
    --font-body: 'Instrument Sans', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
    --font-mono: ui-monospace, Menlo, monospace;

    /* Transition standard */
    --transition: 130ms ease;

    /* --------------------------------------------------------------------
       ALIAS LEGACY — variables sur lesquelles le CSS du plugin cbl2 s'appuie
       (mappées vers la nouvelle palette pour rester on-brand).
       -------------------------------------------------------------------- */
    --cbl-amber:       #FFC43D;
    --cbl-amber-ink:   #15171c;
    --cbl-amber-dark:  #E0A81F;
    --cbl-mint:        #06D6A0;
    --cbl-mint-dark:   #06A97E;
    --cbl-ink:         #15171c;
    --cbl-text:        #4a4e56;
    --cbl-muted:       #71757c;
    --cbl-border:      #e7e5df;
    --cbl-card:        #ffffff;
    --cbl-alt:         #fbfaf7;
    --cbl-notice:      #1B9AAA;
    --cbl-error:       #EF476F;
    --cbl-radius-ctrl: 10px;
    --cbl-radius-card: 16px;
    --cbl-shadow:      0 1px 2px rgba(20, 22, 26, .05);
    --cbl-wrap:        1180px;
    --cbl-gap:         24px;
}

/* =========================================================================
   RESET & BASE
   ========================================================================= */
*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    -webkit-text-size-adjust: 100%;
}

body {
    margin: 0;
    background: var(--paper);
    color: var(--ink-2);
    font-family: var(--font-body);
    font-size: 17px;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

h1, h2, h3, h4, h5, h6 {
    margin: 0;
    font-family: var(--font-head);
    color: var(--ink);
    font-weight: 600;
    line-height: 1.15;
    letter-spacing: -.02em;
}

p {
    margin: 0 0 1em;
}

a {
    color: var(--accent);
    text-decoration: none;
    transition: color var(--transition);
}

a:hover,
a:focus {
    color: var(--accent-hover);
}

img,
svg,
video {
    max-width: 100%;
    height: auto;
}

button {
    font-family: inherit;
    cursor: pointer;
}

ul, ol {
    margin: 0;
    padding: 0;
}

::selection {
    background: var(--primary);
    color: var(--primary-ink);
}

:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
}

/* Skip link (a11y) */
.cbl-skip-link {
    position: absolute;
    left: -9999px;
    top: 0;
    z-index: 100;
    padding: 10px 16px;
    background: var(--ink);
    color: #fff;
    border-radius: 0 0 var(--radius-ctrl) 0;
    font: 600 14px/1 var(--font-body);
}

.cbl-skip-link:focus {
    left: 0;
    color: #fff;
}

/* =========================================================================
   CONTAINER — correctif n°1 : même conteneur partout
   ========================================================================= */
.cbl-container,
.cbl-wrap {
    max-width: var(--wrap);
    margin: 0 auto;
    padding: 0 var(--wrap-pad);
}

/* =========================================================================
   TYPO — échelles (README §Typographie)
   ========================================================================= */
.cbl-h1-hero {
    font-family: var(--font-head);
    font-weight: 600;
    font-size: clamp(38px, 4.4vw, 56px);
    line-height: 1.03;
    letter-spacing: -.025em;
    color: var(--ink);
    text-wrap: balance;
}

.cbl-h1-page {
    font-family: var(--font-head);
    font-weight: 600;
    font-size: clamp(30px, 3.4vw, 40px);
    line-height: 1.05;
    letter-spacing: -.025em;
    color: var(--ink);
}

.cbl-h2 {
    font-family: var(--font-head);
    font-weight: 600;
    font-size: clamp(26px, 3vw, 34px);
    line-height: 1.1;
    letter-spacing: -.02em;
    color: var(--ink);
}

.cbl-eyebrow {
    font-family: var(--font-body);
    font-weight: 600;
    font-size: 12px;
    line-height: 1;
    letter-spacing: .13em;
    text-transform: uppercase;
    color: var(--accent);
}

.cbl-label {
    font-family: var(--font-body);
    font-weight: 500;
    font-size: 11px;
    line-height: 1;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--muted-2);
}

.cbl-lead {
    font-size: 18px;
    line-height: 1.6;
    color: var(--ink-2);
}

.cbl-muted {
    color: var(--muted);
}

/* Prix (Space Grotesk 600) */
.cbl-price-tag {
    font-family: var(--font-head);
    font-weight: 600;
    color: var(--ink);
}

/* =========================================================================
   BOUTONS
   .cbl-btn              → primaire (ambre, texte encre)
   .cbl-btn--ghost       → secondaire (blanc bordé)
   .cbl-btn--dark-ghost  → ghost sur fond sombre
   .cbl-btn--sm          → compact (header)
   .cbl-btn--block       → pleine largeur
   ========================================================================= */
.cbl-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 24px;
    background: var(--primary);
    border: 1px solid var(--primary);
    border-radius: var(--radius-ctrl);
    font: 600 15px/1 var(--font-body);
    color: var(--primary-ink);
    text-decoration: none;
    cursor: pointer;
    transition: background var(--transition), border-color var(--transition), color var(--transition);
}

.cbl-btn:hover,
.cbl-btn:focus {
    background: var(--primary-hover);
    border-color: var(--primary-hover);
    color: var(--primary-ink);
}

.cbl-btn--ghost {
    background: var(--surface);
    border-color: var(--ctrl-border);
    color: var(--ink);
}

.cbl-btn--ghost:hover,
.cbl-btn--ghost:focus {
    background: var(--surface);
    border-color: var(--ctrl-border-hover);
    color: var(--ink);
}

.cbl-btn--dark-ghost {
    background: transparent;
    border-color: #3a3d44;
    color: #fff;
}

.cbl-btn--dark-ghost:hover,
.cbl-btn--dark-ghost:focus {
    background: transparent;
    border-color: var(--muted);
    color: #fff;
}

.cbl-btn--sm {
    padding: 9px 16px;
    font-size: 14px;
}

.cbl-btn--block {
    display: flex;
    width: 100%;
}

/* Header : bouton Panier (fond encre) */
.cbl-cart-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 9px 15px;
    background: var(--ink);
    border: 1px solid var(--ink);
    border-radius: var(--radius-ctrl);
    font: 600 14px/1 var(--font-body);
    color: #fff;
    text-decoration: none;
    transition: background var(--transition);
}

.cbl-cart-btn:hover,
.cbl-cart-btn:focus {
    background: #2b2e36;
    color: #fff;
}

.cbl-cart-btn__count,
.cbl-cart-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 19px;
    height: 19px;
    padding: 0 5px;
    background: var(--primary);
    color: var(--primary-ink);
    border-radius: var(--radius-pill);
    font: 700 11px/1 var(--font-body);
}

/* =========================================================================
   TAGS / PILLS / BADGES
   ========================================================================= */
.cbl-tag {
    display: inline-block;
    align-self: flex-start;
    padding: 5px 11px;
    background: var(--accent-tint);
    color: var(--accent-tint-ink);
    border-radius: var(--radius-pill);
    font: 600 11.5px/1 var(--font-body);
    letter-spacing: .02em;
}

.cbl-badge-num {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border-radius: 8px;
    background: var(--accent-tint);
    color: var(--accent-tint-ink-alt);
    font: 700 13px/1 var(--font-head);
}

.cbl-badge-active {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 11px;
    background: var(--active-bg);
    color: var(--active-ink);
    border-radius: var(--radius-pill);
    font: 600 12px/1 var(--font-body);
}

.cbl-badge-active::before {
    content: "";
    width: 6px;
    height: 6px;
    border-radius: var(--radius-pill);
    background: var(--active-ink);
}

.cbl-status-pill {
    display: inline-block;
    padding: 4px 10px;
    background: #eef1f4;
    color: #5a5f68;
    border-radius: var(--radius-pill);
    font: 600 12px/1 var(--font-body);
}

/* =========================================================================
   CARTES GÉNÉRIQUES
   ========================================================================= */
.cbl-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    padding: 26px;
}

.cbl-card--flush {
    padding: 0;
    overflow: hidden;
}

/* =========================================================================
   BREADCRUMB
   ========================================================================= */
.cbl-breadcrumb {
    font: 500 13px/1 var(--font-body);
    color: var(--muted-2);
    margin-bottom: 22px;
}

.cbl-breadcrumb a {
    color: var(--muted-2);
}

.cbl-breadcrumb a:hover {
    color: var(--ink);
}

.cbl-breadcrumb__sep {
    color: #cdccc4;
    margin: 0 6px;
}

.cbl-breadcrumb__current {
    color: var(--ink);
}

/* =========================================================================
   HEADER
   ========================================================================= */
.cbl-header {
    position: sticky;
    top: 0;
    z-index: 50;
    background: rgba(255, 255, 255, .86);
    backdrop-filter: saturate(1.4) blur(10px);
    -webkit-backdrop-filter: saturate(1.4) blur(10px);
    border-bottom: 1px solid var(--line);
}

.cbl-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    height: 72px;
}

/* Marque (logo réel via the_custom_logo, ou repli texte) */
.cbl-branding {
    display: flex;
    align-items: center;
    gap: 12px;
}

.cbl-branding a,
.cbl-branding img.custom-logo {
    display: inline-flex;
    align-items: center;
}

.cbl-branding img,
.cbl-branding .custom-logo-link img {
    max-height: 44px;
    width: auto;
}

.cbl-site-title {
    margin: 0;
    font: 600 15px/1.1 var(--font-head);
    letter-spacing: -.01em;
}

.cbl-site-title a {
    color: var(--ink);
}

.cbl-site-desc {
    margin: 0;
    font: 500 11px/1.2 var(--font-body);
    color: var(--muted-2);
    letter-spacing: .02em;
}

/* Nav principale */
.cbl-primary-nav {
    display: flex;
    align-items: center;
}

.cbl-menu--primary {
    display: flex;
    align-items: center;
    gap: 30px;
    list-style: none;
}

.cbl-menu--primary li {
    list-style: none;
}

.cbl-menu--primary a {
    font: 500 15px/1 var(--font-body);
    color: #3a3d44;
    text-decoration: none;
    transition: color var(--transition);
}

.cbl-menu--primary a:hover,
.cbl-menu--primary a:focus,
.cbl-menu--primary .current-menu-item > a {
    color: var(--ink);
}

.cbl-header__actions {
    display: flex;
    align-items: center;
    gap: 10px;
}

/* Menu burger (mobile) */
.cbl-nav-toggle {
    display: none;
    width: 42px;
    height: 42px;
    align-items: center;
    justify-content: center;
    background: var(--surface);
    border: 1px solid var(--ctrl-border);
    border-radius: var(--radius-ctrl);
    padding: 0;
}

.cbl-burger,
.cbl-burger::before,
.cbl-burger::after {
    display: block;
    width: 18px;
    height: 2px;
    background: var(--ink);
    border-radius: 2px;
    transition: transform var(--transition), opacity var(--transition);
}

.cbl-burger {
    position: relative;
}

.cbl-burger::before,
.cbl-burger::after {
    content: "";
    position: absolute;
    left: 0;
}

.cbl-burger::before { top: -6px; }
.cbl-burger::after  { top: 6px; }

/* =========================================================================
   FOOTER
   ========================================================================= */
.cbl-footer {
    background: var(--footer-bg);
    color: #c9ccd2;
    padding: 60px 0 36px;
}

.cbl-footer__top {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr 1fr;
    gap: 40px;
    padding-bottom: 44px;
    border-bottom: 1px solid #262932;
}

.cbl-footer__brand-row {
    display: flex;
    align-items: center;
    gap: 11px;
    margin-bottom: 14px;
}

.cbl-footer-logo {
    max-width: 160px;
    height: auto;
}

.cbl-footer__brand-name {
    font: 600 15px/1 var(--font-head);
    color: #fff;
}

.cbl-footer__brand p {
    font: 400 14px/1.6 var(--font-body);
    color: var(--muted-2);
    max-width: 280px;
    margin: 0;
}

.cbl-footer__col {
    display: flex;
    flex-direction: column;
    gap: 11px;
}

.cbl-footer__title {
    font: 600 12px/1 var(--font-body);
    letter-spacing: .06em;
    text-transform: uppercase;
    color: #6b6f78;
    margin: 0 0 3px;
}

.cbl-footer__col ul {
    display: flex;
    flex-direction: column;
    gap: 11px;
    list-style: none;
}

.cbl-footer__col li {
    list-style: none;
}

.cbl-footer__col a {
    font: 400 14px/1 var(--font-body);
    color: #c9ccd2;
    text-decoration: none;
    transition: color var(--transition);
}

.cbl-footer__col a:hover,
.cbl-footer__col a:focus {
    color: #fff;
}

.cbl-footer__bottom {
    padding-top: 24px;
    font: 400 13px/1.5 var(--font-body);
    color: #6b6f78;
}

.cbl-footer__bottom p {
    margin: 0;
}

/* =========================================================================
   ACCUEIL — HERO
   ========================================================================= */
.cbl-hero {
    padding: 80px 0 64px;
}

.cbl-hero__grid {
    display: grid;
    grid-template-columns: 1.05fr .95fr;
    gap: 56px;
    align-items: center;
}

.cbl-hero__title {
    margin: 18px 0 20px;
}

.cbl-hero__intro {
    font: 400 18px/1.6 var(--font-body);
    color: var(--ink-2);
    max-width: 520px;
}

.cbl-hero__actions {
    display: flex;
    gap: 12px;
    margin: 32px 0 22px;
    flex-wrap: wrap;
}

.cbl-hero__reassurance {
    display: flex;
    align-items: center;
    gap: 18px;
    font: 500 13px/1.4 var(--font-body);
    color: var(--muted);
    flex-wrap: wrap;
}

.cbl-hero__reassurance .cbl-sep {
    color: #cdccc4;
}

.cbl-hero__media {
    border: 1px solid var(--line);
    border-radius: 20px;
    overflow: hidden;
    background: var(--surface);
}

.cbl-hero__media img {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
}

/* Placeholder rayé (quand pas d'image) */
.cbl-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    background: repeating-linear-gradient(135deg, #ece9e2, #ece9e2 11px, #e4e1d9 11px, #e4e1d9 22px);
    color: #9a9ea4;
    font: 500 12px/1 var(--font-mono);
    letter-spacing: .03em;
    text-align: center;
    padding: 12px;
}

/* =========================================================================
   ACCUEIL — AVANTAGES
   ========================================================================= */
.cbl-avantages {
    background: var(--surface);
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    padding: 76px 0;
}

.cbl-section-head {
    max-width: 560px;
    margin-bottom: 44px;
}

.cbl-section-head p {
    font: 400 17px/1.6 var(--font-body);
    color: var(--muted);
    margin-top: 12px;
    margin-bottom: 0;
}

.cbl-avantages__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}

.cbl-avantage-card {
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    padding: 26px;
    background: var(--surface-2);
}

.cbl-avantage-card__num {
    margin-bottom: 16px;
}

.cbl-avantage-card h3 {
    font: 600 17px/1.25 var(--font-head);
    color: var(--ink);
    letter-spacing: -.01em;
}

.cbl-avantage-card p {
    font: 400 14.5px/1.55 var(--font-body);
    color: #61656d;
    margin: 8px 0 0;
}

/* =========================================================================
   ACCUEIL — BANDEAU CTA
   ========================================================================= */
.cbl-cta-band {
    padding: 76px 0;
}

.cbl-cta-band__inner {
    background: var(--ink);
    border-radius: var(--radius-lg);
    padding: 56px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 40px;
    flex-wrap: wrap;
}

.cbl-cta-band__text {
    max-width: 520px;
}

.cbl-cta-band__text h2 {
    color: #fff;
    font-size: clamp(26px, 3vw, 32px);
}

.cbl-cta-band__text p {
    font: 400 17px/1.6 var(--font-body);
    color: #9b9fa8;
    margin: 12px 0 0;
}

.cbl-cta-band__actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

/* Sur fond sombre, le primaire ambre reste lisible ; ghost = dark-ghost. */

/* =========================================================================
   PAGE HEADER (boutique / produit / panier / compte)
   ========================================================================= */
.cbl-page-section {
    padding: 48px 0 76px;
}

.cbl-page-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
    margin-bottom: 6px;
}

.cbl-page-subtitle {
    font: 400 15px/1.5 var(--font-body);
    color: var(--muted);
    margin: 0 0 32px;
}

/* Faux/vrai sélecteur « Trier » */
.cbl-sort {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 15px;
    background: var(--surface);
    border: 1px solid var(--ctrl-border);
    border-radius: var(--radius-ctrl);
    font: 600 14px/1 var(--font-body);
    color: var(--ink);
}

.cbl-sort select {
    border: 0;
    background: none;
    font: 500 14px/1 var(--font-body);
    color: var(--muted);
    cursor: pointer;
}

/* =========================================================================
   BOUTIQUE — GRILLE ÉVÉNEMENTS
   ========================================================================= */
.cbl-shop-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

.cbl-event-card {
    display: flex;
    flex-direction: column;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    overflow: hidden;
    text-align: left;
    text-decoration: none;
    transition: border-color var(--transition), box-shadow var(--transition);
}

.cbl-event-card:hover,
.cbl-event-card:focus-within {
    border-color: #c9c6bd;
    box-shadow: var(--shadow-card-hover);
}

.cbl-event-card__media {
    width: 100%;
    aspect-ratio: 16 / 10;
    overflow: hidden;
}

.cbl-event-card__media img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.cbl-event-card__body {
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    flex: 1;
}

.cbl-event-card__title {
    font: 600 18px/1.25 var(--font-head);
    color: var(--ink);
    letter-spacing: -.01em;
}

.cbl-event-card__title a {
    color: inherit;
}

.cbl-event-card__date {
    font: 500 13.5px/1.4 var(--font-body);
    color: var(--muted);
}

.cbl-event-card__foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 8px;
    padding-top: 14px;
    border-top: 1px solid var(--line-2);
}

.cbl-event-card__price {
    font: 600 18px/1 var(--font-head);
    color: var(--ink);
}

.cbl-event-card__price .amount,
.cbl-event-card__price bdi {
    font: inherit;
    color: inherit;
}

.cbl-event-card__more {
    font: 600 14px/1 var(--font-body);
    color: var(--accent);
}

/* =========================================================================
   FICHE PRODUIT
   ========================================================================= */
.cbl-product {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    align-items: start;
}

.cbl-product__gallery {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.cbl-product__media {
    border: 1px solid var(--line);
    border-radius: 18px;
    overflow: hidden;
    background: var(--surface);
}

.cbl-product__media img {
    display: block;
    width: 100%;
    aspect-ratio: 5 / 4;
    object-fit: cover;
}

/* Cartes méta Date / Lieu */
.cbl-meta-cards {
    display: flex;
    gap: 10px;
}

.cbl-meta-card {
    flex: 1;
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 14px;
    background: var(--surface-2);
}

.cbl-meta-card__label {
    font: 500 11px/1 var(--font-body);
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--muted-2);
}

.cbl-meta-card__value {
    font: 600 14px/1.3 var(--font-body);
    color: var(--ink);
    margin-top: 6px;
}

/* Colonne récap / résumé produit */
.cbl-summary__title {
    font: 600 clamp(28px, 3.2vw, 38px)/1.08 var(--font-head);
    letter-spacing: -.025em;
    color: var(--ink);
    margin: 16px 0 10px;
    text-wrap: balance;
}

.cbl-summary__meta {
    font: 500 15px/1.5 var(--font-body);
    color: var(--muted);
}

.cbl-summary__price {
    display: flex;
    align-items: baseline;
    gap: 8px;
    margin: 24px 0;
}

.cbl-summary__price .cbl-amount,
.cbl-summary__price .amount,
.cbl-summary__price bdi {
    font: 600 34px/1 var(--font-head);
    color: var(--ink);
}

.cbl-summary__price-unit {
    font: 500 14px/1 var(--font-body);
    color: var(--muted-2);
}

.cbl-summary__buy {
    display: flex;
    gap: 12px;
    align-items: stretch;
    margin-bottom: 14px;
    flex-wrap: wrap;
}

.cbl-summary__note {
    font: 500 13px/1.4 var(--font-body);
    color: var(--muted-2);
    margin-bottom: 28px;
}

.cbl-summary__included {
    border-top: 1px solid var(--line);
    padding-top: 24px;
}

.cbl-summary__included h3 {
    font: 600 15px/1 var(--font-head);
    color: var(--ink);
    margin-bottom: 14px;
}

.cbl-included-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    list-style: none;
}

.cbl-included-list li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    list-style: none;
    font: 400 15px/1.5 var(--font-body);
    color: var(--ink-2);
}

.cbl-included-list li::before {
    content: "";
    width: 6px;
    height: 6px;
    border-radius: var(--radius-pill);
    background: var(--mint);
    margin-top: 8px;
    flex: none;
}

/* Stepper quantité (fiche + panier) */
.cbl-qty {
    display: flex;
    align-items: center;
    border: 1px solid var(--ctrl-border);
    border-radius: var(--radius-ctrl);
    background: var(--surface);
    overflow: hidden;
}

.cbl-qty button {
    width: 44px;
    height: 48px;
    background: none;
    border: none;
    font: 500 20px/1 var(--font-body);
    color: #3a3d44;
    cursor: pointer;
    transition: background var(--transition);
}

.cbl-qty button:hover {
    background: var(--paper);
}

.cbl-qty input,
.cbl-qty__value {
    width: 44px;
    height: 48px;
    text-align: center;
    border: 0;
    background: none;
    font: 600 16px/1 var(--font-body);
    color: var(--ink);
    -moz-appearance: textfield;
}

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

/* Bloc « À propos » sous le fold */
.cbl-product-about {
    max-width: 720px;
    margin-top: 56px;
    border-top: 1px solid var(--line);
    padding-top: 40px;
}

.cbl-product-about h2 {
    font: 600 24px/1.1 var(--font-head);
    letter-spacing: -.02em;
    color: var(--ink);
    margin-bottom: 16px;
}

.cbl-product-about p {
    font: 400 17px/1.7 var(--font-body);
    color: var(--ink-2);
    margin-bottom: 14px;
}

/* =========================================================================
   PANIER
   ========================================================================= */
.cbl-cart {
    display: grid;
    grid-template-columns: 1.6fr 1fr;
    gap: 40px;
    align-items: start;
}

.cbl-cart__main {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    overflow: hidden;
}

.cbl-cart__table {
    width: 100%;
}

.cbl-cart__head,
.cbl-cart__row {
    display: grid;
    grid-template-columns: 1fr 90px 120px 90px 34px;
    gap: 16px;
    align-items: center;
}

.cbl-cart__head {
    padding: 16px 24px;
    border-bottom: 1px solid var(--line-2);
    font: 600 12px/1 var(--font-body);
    letter-spacing: .04em;
    text-transform: uppercase;
    color: var(--muted-2);
}

.cbl-cart__head .cbl-col-center { text-align: center; }
.cbl-cart__head .cbl-col-right  { text-align: right; }

.cbl-cart__row {
    padding: 20px 24px;
    border-bottom: 1px solid var(--line-3);
}

.cbl-cart__product {
    display: flex;
    align-items: center;
    gap: 14px;
}

.cbl-cart__thumb {
    width: 64px;
    height: 52px;
    border-radius: 8px;
    flex: none;
    overflow: hidden;
    object-fit: cover;
}

.cbl-cart__name {
    font: 600 15px/1.3 var(--font-head);
    color: var(--ink);
}

.cbl-cart__meta {
    font: 500 13px/1.3 var(--font-body);
    color: var(--muted-2);
    margin-top: 3px;
}

.cbl-cart__price {
    font: 500 15px/1 var(--font-body);
    color: var(--ink-2);
}

.cbl-cart__total {
    text-align: right;
    font: 600 16px/1 var(--font-head);
    color: var(--ink);
}

/* Stepper compact (panier) */
.cbl-cart .cbl-qty {
    justify-self: center;
    border-radius: 9px;
}

.cbl-cart .cbl-qty button,
.cbl-cart .cbl-qty input,
.cbl-cart .cbl-qty__value {
    width: 34px;
    height: 38px;
    font-size: 16px;
}

/* Bouton supprimer (×) */
.cbl-remove {
    width: 30px;
    height: 30px;
    justify-self: end;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: none;
    border: 1px solid var(--danger-border);
    border-radius: 8px;
    color: var(--danger-soft);
    font: 400 15px/1 var(--font-body);
    text-decoration: none;
    transition: background var(--transition), border-color var(--transition), color var(--transition);
}

.cbl-remove:hover,
.cbl-remove:focus {
    background: var(--danger-bg);
    border-color: var(--danger-border-hover);
    color: var(--danger);
}

.cbl-cart__foot {
    padding: 18px 24px;
}

.cbl-cart__continue {
    background: none;
    border: none;
    padding: 0;
    font: 600 14px/1 var(--font-body);
    color: var(--accent);
    cursor: pointer;
    text-decoration: none;
}

.cbl-cart__continue:hover {
    color: var(--accent-hover);
}

/* Récap panier (sticky) */
.cbl-cart__summary {
    position: sticky;
    top: 96px;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    padding: 26px;
}

.cbl-cart__summary h2 {
    font: 600 18px/1 var(--font-head);
    color: var(--ink);
    margin-bottom: 20px;
}

.cbl-cart__summary-row {
    display: flex;
    justify-content: space-between;
    font: 400 15px/1 var(--font-body);
    color: var(--ink-2);
    margin-bottom: 14px;
}

.cbl-cart__summary-row--total {
    align-items: baseline;
    border-top: 1px solid var(--line-2);
    padding-top: 18px;
    margin: 4px 0 22px;
}

.cbl-cart__summary-row--total .cbl-cart__summary-label {
    font: 600 16px/1 var(--font-body);
    color: var(--ink);
}

.cbl-cart__summary-row--total .cbl-cart__summary-value,
.cbl-cart__summary-row--total .amount {
    font: 600 24px/1 var(--font-head);
    color: var(--ink);
}

.cbl-cart__secure {
    text-align: center;
    font: 500 13px/1.4 var(--font-body);
    color: var(--muted-2);
    margin-top: 14px;
}

/* Panier vide */
.cbl-cart-empty {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    padding: 48px;
    text-align: center;
}

/* =========================================================================
   COMPTE ADHÉRENT
   ========================================================================= */
.cbl-account {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 40px;
    align-items: start;
}

.cbl-account__nav {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    padding: 10px;
    display: flex;
    flex-direction: column;
    gap: 2px;
    list-style: none;
}

.cbl-account__nav li {
    list-style: none;
}

.cbl-account__nav a {
    display: block;
    padding: 11px 14px;
    border-radius: 9px;
    color: #3a3d44;
    font: 500 14.5px/1 var(--font-body);
    text-decoration: none;
    transition: background var(--transition), color var(--transition);
}

.cbl-account__nav a:hover,
.cbl-account__nav a:focus {
    background: var(--paper);
    color: var(--ink);
}

.cbl-account__nav .is-active > a,
.cbl-account__nav .is-active,
.cbl-account__nav a[aria-current="page"] {
    background: var(--accent-tint);
    color: var(--accent-tint-ink);
    font-weight: 600;
}

.cbl-account__nav-sep {
    height: 1px;
    background: var(--line-2);
    margin: 6px 8px;
}

.cbl-account__nav .cbl-logout a,
.cbl-account__nav a.cbl-logout {
    color: var(--muted-2);
}

.cbl-account__content {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.cbl-account__card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    padding: 28px;
}

.cbl-account__card h2 {
    font: 600 22px/1.1 var(--font-head);
    letter-spacing: -.01em;
    color: var(--ink);
}

.cbl-account__card p {
    font: 400 16px/1.55 var(--font-body);
    color: #61656d;
    margin: 8px 0 0;
    max-width: 560px;
}

/* Cartes stat */
.cbl-stat-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

.cbl-stat-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    padding: 24px;
}

.cbl-stat-card__label {
    font: 500 11px/1 var(--font-body);
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--muted-2);
}

.cbl-stat-card__body {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 12px;
    flex-wrap: wrap;
}

.cbl-stat-card__value {
    font: 600 26px/1 var(--font-head);
    color: var(--ink);
}

.cbl-stat-card__hint {
    font: 500 14px/1 var(--font-body);
    color: #61656d;
}

/* Tableau commandes */
.cbl-orders {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    overflow: hidden;
}

.cbl-orders__title {
    padding: 20px 24px;
    border-bottom: 1px solid var(--line-2);
    font: 600 16px/1 var(--font-head);
    color: var(--ink);
}

.cbl-orders__head,
.cbl-orders__row {
    display: grid;
    grid-template-columns: 100px 1fr 120px 90px;
    gap: 16px;
    align-items: center;
}

.cbl-orders__head {
    padding: 12px 24px;
    border-bottom: 1px solid var(--line-2);
    font: 600 11px/1 var(--font-body);
    letter-spacing: .04em;
    text-transform: uppercase;
    color: var(--muted-2);
}

.cbl-orders__row {
    padding: 16px 24px;
    border-bottom: 1px solid var(--line-3);
}

.cbl-orders__row:last-child {
    border-bottom: 0;
}

.cbl-orders__id {
    font: 600 14px/1 var(--font-body);
    color: var(--accent);
}

.cbl-orders__id a { color: inherit; }

.cbl-orders__date {
    font: 500 14px/1 var(--font-body);
    color: var(--ink-2);
}

.cbl-orders__total {
    text-align: right;
    font: 600 15px/1 var(--font-head);
    color: var(--ink);
}

.cbl-col-right { text-align: right; }

/* =========================================================================
   FORMULAIRES (inputs génériques, cohérents avec la charte)
   ========================================================================= */
.cbl-input,
input[type="text"].input-text,
input[type="email"],
input[type="tel"],
input[type="password"],
input[type="number"],
input[type="search"],
select,
textarea {
    width: 100%;
    padding: 12px 14px;
    background: var(--surface);
    border: 1px solid var(--ctrl-border);
    border-radius: var(--radius-ctrl);
    font: 400 15px/1.4 var(--font-body);
    color: var(--ink);
    transition: border-color var(--transition), box-shadow var(--transition);
}

.cbl-input:focus,
input.input-text:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="password"]:focus,
input[type="number"]:focus,
input[type="search"]:focus,
select:focus,
textarea:focus {
    border-color: var(--ink);
    outline: none;
    box-shadow: 0 0 0 1px var(--ink);
}

.cbl-form-row {
    margin-bottom: 16px;
}

.cbl-form-row label {
    display: block;
    font: 600 13px/1 var(--font-body);
    color: var(--ink);
    margin-bottom: 6px;
}

/* =========================================================================
   BLOC PRIX ÉVÉNEMENT injecté par cbl2 (.cbl-event-pricing)
   ========================================================================= */
.cbl-event-pricing {
    margin: 20px 0;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.cbl-event-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 18px;
    font: 500 14px/1.4 var(--font-body);
    color: var(--muted);
}

.cbl-event-meta .cbl-event-date,
.cbl-event-meta .cbl-event-lieu {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.cbl-price-list {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.cbl-price {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 14px 18px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--surface-2);
    min-width: 160px;
    list-style: none;
}

.cbl-price--member {
    background: var(--accent-tint);
    border-color: transparent;
}

.cbl-price--guest {
    background: var(--surface-2);
}

.cbl-price__label {
    font: 500 11px/1 var(--font-body);
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--muted-2);
}

.cbl-price--member .cbl-price__label {
    color: var(--accent-tint-ink-alt);
}

.cbl-price__value {
    font: 600 20px/1 var(--font-head);
    color: var(--ink);
}

/* =========================================================================
   WOOCOMMERCE — override boutons (BAT le kit Elementor via !important)
   Fond ambre + texte encre partout où Woo pose ses .button.
   ========================================================================= */
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit.alt,
.woocommerce .single_add_to_cart_button,
.woocommerce button.single_add_to_cart_button,
.woocommerce #place_order,
.woocommerce button#place_order,
.woocommerce .checkout-button,
.woocommerce a.checkout-button,
.woocommerce a.button.add_to_cart_button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.cbl-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    padding: 14px 24px !important;
    background: var(--primary) !important;
    border: 1px solid var(--primary) !important;
    border-radius: var(--radius-ctrl) !important;
    color: var(--primary-ink) !important;
    font: 600 15px/1 var(--font-body) !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    text-shadow: none !important;
    box-shadow: none !important;
    cursor: pointer !important;
    transition: background var(--transition), border-color var(--transition) !important;
}

.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover,
.woocommerce #respond input#submit.alt:hover,
.woocommerce .single_add_to_cart_button:hover,
.woocommerce button.single_add_to_cart_button:hover,
.woocommerce #place_order:hover,
.woocommerce button#place_order:hover,
.woocommerce .checkout-button:hover,
.woocommerce a.checkout-button:hover,
.woocommerce a.button.add_to_cart_button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.cbl-btn:hover {
    background: var(--primary-hover) !important;
    border-color: var(--primary-hover) !important;
    color: var(--primary-ink) !important;
}

/* Bouton Woo « ghost » quand on veut un secondaire (opt-in via .cbl-btn--ghost) */
.woocommerce a.button.cbl-btn--ghost,
.woocommerce button.button.cbl-btn--ghost {
    background: var(--surface) !important;
    border-color: var(--ctrl-border) !important;
    color: var(--ink) !important;
}

.woocommerce a.button.cbl-btn--ghost:hover,
.woocommerce button.button.cbl-btn--ghost:hover {
    border-color: var(--ctrl-border-hover) !important;
    background: var(--surface) !important;
}

/* Notices WooCommerce (info / succès / erreur) au système CBL */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error,
.woocommerce-noreviews {
    border-radius: var(--radius-card);
    border: 1px solid var(--line);
    border-top-width: 3px;
    background: var(--surface);
    color: var(--ink-2);
    font: 400 15px/1.5 var(--font-body);
    padding: 16px 20px;
    list-style: none;
    margin: 0 0 24px;
}

.woocommerce-message { border-top-color: var(--mint); }
.woocommerce-info    { border-top-color: var(--cbl-notice); }
.woocommerce-error   { border-top-color: var(--cbl-error); }

.woocommerce-error li { list-style: none; }

/* Prix WooCommerce en Space Grotesk */
.woocommerce .price,
.woocommerce span.amount {
    color: var(--ink);
}

/* =========================================================================
   PAGE / CONTENU GÉNÉRIQUE (page.php, single.php…)
   ========================================================================= */
.cbl-entry {
    padding: 48px 0 76px;
}

.cbl-entry__title {
    font: 600 clamp(30px, 3.4vw, 40px)/1.05 var(--font-head);
    letter-spacing: -.025em;
    color: var(--ink);
    margin-bottom: 24px;
}

.cbl-content > * {
    max-width: 760px;
}

.cbl-content h2 { margin: 40px 0 16px; }
.cbl-content h3 { margin: 32px 0 12px; }

.cbl-content a {
    text-decoration: underline;
    text-underline-offset: 2px;
}

/* =========================================================================
   ACCUEIL — PROSE (blocs éditoriaux « réseau ouvert », SEO, contact)
   ========================================================================= */
.cbl-prose {
    max-width: 760px;
}

.cbl-prose p {
    font: 400 16px/1.7 var(--font-body);
    color: var(--ink-2);
    margin: 0 0 16px;
}

.cbl-prose p:last-child {
    margin-bottom: 0;
}

.cbl-prose .cbl-lead {
    margin-bottom: 18px;
}

.cbl-prose__cta {
    margin-top: 28px;
}

/* Section « Un réseau business ouvert » : léger décalage sous le header. */
.cbl-prose--intro {
    max-width: 720px;
}

/* Liste à puces menthe (bloc SEO) */
.cbl-check-list {
    list-style: none;
    margin: 4px 0 20px;
    padding: 0;
    display: grid;
    gap: 10px;
}

.cbl-check-list li {
    position: relative;
    padding-left: 26px;
    font: 400 16px/1.6 var(--font-body);
    color: var(--ink-2);
}

.cbl-check-list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 9px;
    width: 8px;
    height: 8px;
    border-radius: var(--radius-pill);
    background: var(--mint);
}

/* =========================================================================
   ACCUEIL — FAQ (accordéon natif <details>/<summary>, accessible sans JS)
   ========================================================================= */
.cbl-faq {
    max-width: 820px;
    border-top: 1px solid var(--line);
}

.cbl-faq__item {
    border-bottom: 1px solid var(--line);
}

.cbl-faq__q {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    padding: 22px 4px;
    cursor: pointer;
    list-style: none;
    font: 600 18px/1.35 var(--font-head);
    letter-spacing: -.01em;
    color: var(--ink);
    transition: color var(--transition);
}

.cbl-faq__q:hover {
    color: var(--accent);
}

/* Retire le marqueur natif (triangle) et pose un « + » maison. */
.cbl-faq__q::-webkit-details-marker {
    display: none;
}

.cbl-faq__q::after {
    content: "+";
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: var(--radius-pill);
    background: var(--accent-tint);
    color: var(--accent-tint-ink-alt);
    font: 400 20px/1 var(--font-head);
    transition: transform var(--transition);
}

.cbl-faq__item[open] .cbl-faq__q::after {
    content: "–";
    transform: rotate(0deg);
}

.cbl-faq__item[open] .cbl-faq__q {
    color: var(--ink);
}

.cbl-faq__a {
    padding: 0 4px 24px;
}

.cbl-faq__a p {
    max-width: 700px;
    margin: 0;
    font: 400 16px/1.7 var(--font-body);
    color: var(--ink-2);
}

/* Focus clavier visible sur le résumé (accessibilité). */
.cbl-faq__q:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 3px;
    border-radius: 4px;
}

/* =========================================================================
   MENU — override anti-kit Elementor (liens rouges #EF476F → encre)
   ========================================================================= */
.cbl-menu--primary a {
    color: #3a3d44 !important;
}

.cbl-menu--primary a:hover,
.cbl-menu--primary a:focus,
.cbl-menu--primary .current-menu-item > a {
    color: var(--ink) !important;
}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width: 1024px) {
    .cbl-hero__grid { gap: 40px; }
    .cbl-product { gap: 32px; }
    .cbl-cart { gap: 28px; }
}

@media (max-width: 900px) {
    :root {
        --wrap-pad: 20px;
    }

    /* Grilles multi-colonnes → 1 colonne */
    .cbl-hero__grid,
    .cbl-avantages__grid,
    .cbl-shop-grid,
    .cbl-product,
    .cbl-cart,
    .cbl-account,
    .cbl-stat-grid,
    .cbl-cta-band__inner,
    .cbl-footer__top {
        grid-template-columns: 1fr;
    }

    .cbl-hero__media { order: -1; }

    /* Réduction des paddings de section */
    .cbl-hero { padding: 48px 0 40px; }
    .cbl-avantages,
    .cbl-cta-band { padding: 48px 0; }
    .cbl-page-section { padding: 32px 0 48px; }

    .cbl-cta-band__inner { padding: 36px; align-items: flex-start; }

    /* FAQ : question un cran plus petite sur mobile */
    .cbl-faq__q { font-size: 16px; padding: 18px 2px; }
    .cbl-faq__a { padding: 0 2px 20px; }

    /* Récap panier : ne plus être sticky en 1 colonne */
    .cbl-cart__summary { position: static; }

    /* Nav compte au-dessus du contenu */
    .cbl-account__nav {
        flex-direction: row;
        flex-wrap: wrap;
        overflow-x: auto;
    }
}

/* Header → menu burger sous 861px (aligné sur navigation.js) */
@media (max-width: 860px) {
    .cbl-nav-toggle {
        display: inline-flex;
        order: 3;
    }

    .cbl-header__actions {
        order: 2;
    }

    .cbl-primary-nav {
        position: absolute;
        top: 72px;
        left: 0;
        right: 0;
        display: none;
        background: var(--surface);
        border-bottom: 1px solid var(--line);
        box-shadow: var(--shadow-card-hover);
    }

    .cbl-primary-nav.is-open {
        display: block;
    }

    .cbl-menu--primary {
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        padding: 8px var(--wrap-pad);
    }

    .cbl-menu--primary li {
        border-bottom: 1px solid var(--line-3);
    }

    .cbl-menu--primary li:last-child {
        border-bottom: 0;
    }

    .cbl-menu--primary a {
        display: block;
        padding: 14px 0;
        font-size: 16px;
    }
}

@media (max-width: 560px) {
    .cbl-branding .cbl-site-desc { display: none; }

    /* Tableaux panier / commandes : condensés */
    .cbl-cart__head { display: none; }

    .cbl-cart__row {
        grid-template-columns: 1fr auto;
        gap: 8px 12px;
    }

    .cbl-cart__row .cbl-cart__product { grid-column: 1 / -1; }

    .cbl-orders__head,
    .cbl-orders__row {
        grid-template-columns: 1fr auto;
        gap: 6px 12px;
    }

    .cbl-orders__head { display: none; }

    .cbl-summary__buy { flex-direction: column; }
    .cbl-summary__buy .cbl-qty { align-self: flex-start; }
}
