  :root {
    /* Palette MBDS — alignée sur mabachedeserre.fr */
    --c-bg: #f5f2ec;                /* fond crème de la page */
    --c-paper: #fbf9f5;             /* fond du widget (légèrement plus clair) */
    --c-ink: #142b00;               /* vert nuit du header MBDS */
    --c-ink-soft: #3d5938;          /* vert sombre adouci pour textes secondaires */
    --c-line: #d8d2c5;              /* bordures discrètes */
    --c-line-strong: #142b00;       /* bordures fortes (= ink) */

    /* Vert lime électrique de la marque */
    --c-leaf-bright: #9ee86f;       /* vert pomme principal (bandeaux, fond CTA) */
    --c-leaf-soft: #b8e98e;         /* vert pomme adouci */
    --c-leaf: #5a9233;              /* vert mid pour ACCENTS TYPOGRAPHIQUES (lisibilité sur fond clair) */

    /* Alias pour compat code existant */
    --c-leaf-dark: #142b00;         /* alias pour vert nuit */

    --c-accent: #c8462c;            /* rouge erreur (inchangé) */
    --c-warn: #b8860b;
  }
  /* IMPORTANT : tous les styles ci-dessous sont SCOPÉS à .mbds-widget pour ne
     PAS impacter le reste de la page WordPress (body, headers, footer, etc.). */
  .mbds-widget * { -webkit-tap-highlight-color: transparent; }
  .mbds-widget {
    font-family: 'Inter', system-ui, sans-serif;
    color: var(--c-ink);
  }
  .mbds-widget .font-display { font-family: 'Fraunces', Georgia, serif; font-feature-settings: "ss01"; }
  .mbds-widget .text-soft { color: var(--c-ink-soft); }
  .mbds-widget .bg-paper { background: var(--c-paper); }
  .mbds-widget .bg-leaf { background: var(--c-leaf); }
  .mbds-widget .bg-leaf-bright { background: var(--c-leaf-bright); }
  .mbds-widget .bg-leaf-dark { background: var(--c-leaf-dark); }
  .mbds-widget .text-leaf { color: var(--c-leaf); }
  .mbds-widget .text-leaf-bright { color: var(--c-leaf-bright); }
  .mbds-widget .text-leaf-dark { color: var(--c-leaf-dark); }
  .mbds-widget .text-accent { color: var(--c-accent); }
  .mbds-widget .border-line { border-color: var(--c-line); }

  /* --- Container widget intégrable (insertion via shortcode WP) --- */
  .mbds-widget,
  .mbds-widget * {
    box-sizing: border-box;
  }
  .mbds-widget {
    width: 100%;
    max-width: 960px;
    margin: 0 auto;
    background: var(--c-paper);
    display: flex;
    flex-direction: column;
    /* Reset défensif : neutraliser une éventuelle bordure héritée du thème WP */
    border: 0 !important;
    box-shadow: none !important;
    outline: 0 !important;
  }
  /* Neutralise les bordures éventuelles ajoutées par le thème WP / Gutenberg
     sur le ou les conteneurs immédiats où le shortcode est inséré. Le sélecteur
     :has() est supporté par tous les navigateurs modernes (>2023). */
  *:has(> .mbds-widget) {
    border: 0 !important;
    box-shadow: none !important;
    outline: 0 !important;
  }
  .mbds-widget__content {
    min-height: 560px;
    display: flex;
    flex-direction: column;
  }

  /* --- Progress bar (en haut du widget) --- */
  .progress-track {
    height: 3px;
    background: var(--c-line);
    position: relative;
    overflow: hidden;
    flex-shrink: 0;
  }
  .progress-fill {
    height: 100%;
    background: var(--c-leaf-bright);
    transition: width 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  }

  /* --- Footer du widget --- */
  .mbds-widget__footer {
    border-top: 1px solid var(--c-line);
    padding: 0.7rem 1.5rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    font-size: 0.75rem;
    color: var(--c-ink-soft);
    flex-shrink: 0;
  }
  .mbds-widget__footer .meta {
    text-transform: uppercase;
    letter-spacing: 0.08em;
    opacity: 0.7;
  }
  .mbds-widget__footer button {
    background: transparent;
    border: none;
    color: var(--c-ink-soft);
    cursor: pointer;
    font-size: 0.75rem;
    padding: 0.25rem 0.5rem;
    transition: color 0.15s;
  }
  .mbds-widget__footer button:hover { color: var(--c-ink); }

  /* --- Step content (intérieur du widget) --- */
  .step-wrap {
    flex: 1;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 2.5rem 2rem;
  }
  @media (max-width: 640px) { .step-wrap { padding: 1.75rem 1.25rem; } }
  .step-inner {
    width: 100%;
    max-width: 720px;
  }

  /* --- Fade animation --- */
  .step-enter { animation: fadeIn 0.45s cubic-bezier(0.4, 0, 0.2, 1) both; }
  @keyframes fadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
  }
  .step-exit { animation: fadeOut 0.25s cubic-bezier(0.4, 0, 0.2, 1) both; }
  @keyframes fadeOut {
    from { opacity: 1; transform: translateY(0); }
    to   { opacity: 0; transform: translateY(-8px); }
  }

  /* --- Question label --- */
  .question-eyebrow {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--c-ink-soft);
    font-weight: 600;
    margin-bottom: 0.75rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
  }
  .question-eyebrow .arrow { color: var(--c-leaf); }
  .question-title {
    font-family: 'Fraunces', Georgia, serif;
    font-size: clamp(1.75rem, 4vw, 2.75rem);
    line-height: 1.1;
    font-weight: 600;
    margin-bottom: 0.5rem;
    letter-spacing: -0.01em;
  }
  .question-help {
    color: var(--c-ink-soft);
    font-size: 1rem;
    margin-bottom: 2.5rem;
    max-width: 36rem;
  }

  /* --- Option cards (radios) --- */
  .option-card {
    background: var(--c-paper);
    border: 1.5px solid var(--c-line);
    padding: 1.5rem;
    cursor: pointer;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    text-align: left;
    width: 100%;
  }
  .option-card:hover {
    border-color: var(--c-leaf-dark);
    transform: translateY(-2px);
    box-shadow: 0 8px 24px -8px rgba(31, 62, 42, 0.15);
  }
  .option-card.is-disabled {
    opacity: 0.45;
    cursor: not-allowed;
    pointer-events: none;
  }
  .option-key {
    position: absolute;
    top: 0.5rem;
    right: 0.5rem;
    font-size: 0.65rem;
    font-weight: 700;
    background: var(--c-ink);
    color: var(--c-paper);
    width: 1.5rem;
    height: 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 2px;
    font-family: 'JetBrains Mono', monospace;
  }
  .option-badge {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    background: var(--c-leaf-dark);
    color: white;
    padding: 0.2rem 0.5rem;
    font-weight: 600;
  }

  /* === Ordre des cards pose selon le film === */
  /* Films transparent/diffusant : pose multi d'abord */
  .pose-cards-grid.pose-multi-first .pose-card-multi { order: 1; }
  .pose-cards-grid.pose-multi-first .pose-card-unique { order: 2; }
  /* Film abri : pose unique d'abord */
  .pose-cards-grid.pose-unique-first .pose-card-unique { order: 1; }
  .pose-cards-grid.pose-unique-first .pose-card-multi { order: 2; }

  /* Badge "Déconseillé" sur card pose unique — positionné à l'intérieur (overflow hidden de la card) */
  .badge-deconseille {
    position: absolute;
    top: 0.5rem;
    right: 0.5rem;
    background: #d97706;
    color: #fff;
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.25rem 0.55rem;
    border-radius: 3px;
    z-index: 2;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
  }

  /* === Cards AVEC PHOTOS (étapes 1 et 4) === */
  /* Photo en haut, texte dessous, padding réduit côté top pour le visuel */
  .option-card-with-photo {
    padding: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
  }
  .option-card-with-photo .option-photo {
    width: 100%;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: #f3f3ed;
    border-bottom: 1.5px solid var(--c-line);
  }
  .option-card-with-photo .option-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  }
  .option-card-with-photo:hover .option-photo img {
    transform: scale(1.04);
  }
  .option-card-with-photo > div:not(.option-photo),
  .option-card-with-photo > .font-display,
  .option-card-with-photo > .text-sm,
  .option-card-with-photo > .text-xs {
    margin-left: 1.25rem;
    margin-right: 1.25rem;
  }
  .option-card-with-photo > .font-display { margin-top: 1rem; }
  .option-card-with-photo > div:last-child { margin-bottom: 1.25rem; }

  /* === Cards FILM (étape 3) — photo à gauche, texte à droite === */
  .option-card-film {
    padding: 0;
    overflow: hidden;
    display: flex;
    align-items: stretch;
    gap: 0;
  }
  .option-card-film .film-photo {
    flex: 0 0 160px;
    aspect-ratio: 1;
    overflow: hidden;
    background: #f3f3ed;
    border-right: 1.5px solid var(--c-line);
  }
  .option-card-film .film-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  }
  .option-card-film:hover .film-photo img {
    transform: scale(1.04);
  }
  .option-card-film .film-body {
    flex: 1 1 auto;
    padding: 1.25rem 1.5rem;
    min-width: 0;
  }
  /* Liste à puces (feature list) pour les cards films */
  .film-features {
    list-style: none !important;
    list-style-type: none !important;
    list-style-image: none !important;
    padding: 0 !important;
    margin: 0 !important;
  }
  .film-features li {
    list-style: none !important;
    list-style-type: none !important;
    position: relative;
    padding-left: 1.1rem;
    font-size: 0.9rem;
    color: var(--c-ink);
    line-height: 1.5;
    margin-bottom: 0.15rem;
    background: none !important;
  }
  .film-features li::marker {
    content: "" !important;
    display: none !important;
  }
  .film-features li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.55em;
    width: 5px;
    height: 5px;
    background: var(--c-leaf-bright);
    border-radius: 50%;
  }
  @media (max-width: 540px) {
    /* Sur mobile, cards film passent en vertical (photo en haut) */
    .option-card-film {
      flex-direction: column;
    }
    .option-card-film .film-photo {
      flex: 0 0 auto;
      width: 100%;
      aspect-ratio: 16 / 9;
      border-right: 0;
      border-bottom: 1.5px solid var(--c-line);
    }
  }

  /* --- Big input --- */
  .big-input {
    background: transparent;
    border: none;
    border-bottom: 2px solid var(--c-line-strong);
    font-family: 'Fraunces', Georgia, serif;
    font-size: clamp(2rem, 5vw, 3rem);
    font-weight: 600;
    width: 100%;
    padding: 0.5rem 0;
    color: var(--c-ink);
    outline: none;
    transition: border-color 0.2s;
  }
  .big-input:focus { border-bottom-color: var(--c-leaf-dark); }
  .big-input::placeholder { color: var(--c-line); }

  /* Cleanup number inputs */
  .mbds-widget input[type="number"]::-webkit-outer-spin-button,
  .mbds-widget input[type="number"]::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
  .mbds-widget input[type="number"] { -moz-appearance: textfield; }

  .input-suffix {
    font-family: 'Inter', sans-serif;
    color: var(--c-ink-soft);
    font-size: 1rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-left: 0.5rem;
  }

  /* --- Buttons --- */
  .btn-primary {
    background: var(--c-ink);
    color: var(--c-paper);
    padding: 1rem 2rem;
    font-weight: 600;
    font-size: 1rem;
    letter-spacing: 0.02em;
    border: 1.5px solid var(--c-ink);
    cursor: pointer;
    transition: all 0.2s;
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
  }
  .btn-primary:hover:not(:disabled) { background: var(--c-leaf-dark); border-color: var(--c-leaf-dark); }
  .btn-primary:disabled { opacity: 0.4; cursor: not-allowed; }
  .btn-primary .arrow { transition: transform 0.2s; }
  .btn-primary:hover:not(:disabled) .arrow { transform: translateX(4px); }

  .btn-ghost {
    background: transparent;
    border: none;
    color: var(--c-ink-soft);
    font-size: 0.9rem;
    cursor: pointer;
    padding: 0.5rem 0.75rem;
    transition: color 0.2s;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
  }
  .btn-ghost:hover { color: var(--c-ink); }

  /* --- Topbar : barre haute avec bouton retour visible dès écran 2 --- */
  .mbds-topbar {
    display: flex;
    align-items: center;
    padding: 0.75rem 1.5rem 0;
  }
  .btn-back-top {
    background: transparent;
    border: 0;
    color: var(--c-ink-soft);
    font-size: 0.85rem;
    cursor: pointer;
    padding: 0.3rem 0.6rem;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    border-radius: 4px;
    transition: background 0.15s, color 0.15s;
  }
  .btn-back-top:hover {
    background: rgba(0, 0, 0, 0.04);
    color: var(--c-ink);
  }
  .btn-back-top .arrow { font-size: 1rem; }
  @media (max-width: 640px) {
    .mbds-topbar { padding: 0.5rem 0.75rem 0; }
  }

  /* --- Stepper --- */
  .stepper {
    display: inline-flex;
    align-items: center;
    gap: 1rem;
    background: var(--c-paper);
    border: 1.5px solid var(--c-line-strong);
    padding: 0.5rem;
  }
  .stepper-btn {
    width: 3rem;
    height: 3rem;
    border: none;
    background: transparent;
    font-size: 1.5rem;
    cursor: pointer;
    transition: background 0.15s;
    color: var(--c-ink);
  }
  .stepper-btn:hover { background: var(--c-bg); }
  .stepper-value {
    font-family: 'Fraunces', Georgia, serif;
    font-size: 2.5rem;
    font-weight: 600;
    min-width: 4rem;
    text-align: center;
    color: var(--c-ink);
  }

  /* --- Final recap --- */
  .recap-card {
    background: var(--c-paper);
    border: 1.5px solid var(--c-line-strong);
    padding: 1.5rem;
    margin-bottom: 1rem;
    transition: all 0.2s;
  }
  .recap-card:hover { border-color: var(--c-leaf-dark); }
  .recap-header {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 0.75rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px dashed var(--c-line);
  }
  .recap-line {
    display: flex;
    justify-content: space-between;
    padding: 0.3rem 0;
    font-size: 0.9rem;
  }
  .recap-line .label { color: var(--c-ink-soft); }
  .recap-line .value { font-weight: 500; font-variant-numeric: tabular-nums; }

  /* --- Quote table (devis) --- */
  .quote-table {
    font-size: 0.875rem;
  }
  .quote-row {
    display: grid;
    grid-template-columns: 1fr 60px 100px;
    gap: 0.75rem;
    padding: 0.45rem 0;
    border-bottom: 1px dotted var(--c-line);
    align-items: baseline;
  }
  .quote-row:last-child { border-bottom: none; }
  .quote-row--head {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--c-ink-soft);
    font-weight: 600;
    border-bottom: 1px solid var(--c-line);
    padding-bottom: 0.4rem;
    margin-bottom: 0.2rem;
  }
  .quote-col-qty { text-align: center; }
  .quote-col-price { text-align: right; font-weight: 500; }

  /* --- Delivery row --- */
  .delivery-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.6rem 0;
  }
  .delivery-cp-input {
    background: transparent;
    border: none;
    border-bottom: 1.5px solid rgba(255,255,255,0.4);
    color: white;
    font-family: 'Fraunces', Georgia, serif;
    font-weight: 600;
    font-size: 1rem;
    width: 80px;
    text-align: right;
    padding: 0.15rem 0.25rem;
    outline: none;
    transition: border-color 0.2s;
  }
  .delivery-cp-input:focus { border-bottom-color: white; }
  .delivery-cp-input::placeholder { color: rgba(255,255,255,0.4); }
  .delivery-status {
    font-size: 0.85rem;
    color: rgba(255,255,255,0.85);
  }
  .delivery-status.is-error { color: #ffd2a8; }
  .delivery-warning {
    background: rgba(200, 70, 44, 0.15);
    border: 1px solid rgba(200, 70, 44, 0.4);
    padding: 0.75rem 0.9rem;
    margin: 0.75rem 0;
    font-size: 0.85rem;
    color: #ffd6c4;
  }

  /* --- Mini stepper inline (dans header de card) --- */
  .mini-stepper {
    display: inline-flex;
    align-items: stretch;
    border: 1px solid var(--c-line-strong);
    overflow: hidden;
    height: 1.85rem;
  }
  .mini-stepper-btn {
    width: 1.85rem;
    height: 100%;
    border: none;
    background: transparent;
    cursor: pointer;
    font-size: 1rem;
    line-height: 1;
    color: var(--c-ink);
    transition: background 0.15s;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .mini-stepper-btn:hover:not(:disabled) { background: var(--c-bg); }
  .mini-stepper-btn:disabled { opacity: 0.3; cursor: not-allowed; }
  .mini-stepper-value {
    min-width: 2.5rem;
    text-align: center;
    font-family: 'Fraunces', Georgia, serif;
    font-weight: 600;
    font-size: 1rem;
    line-height: 1.85rem;
    border-left: 1px solid var(--c-line-strong);
    border-right: 1px solid var(--c-line-strong);
    padding: 0 0.25rem;
    background: var(--c-paper);
  }

  /* --- Erreur tunnel (dépassement gamme) --- */
  .tunnel-error-card {
    background: rgba(200, 70, 44, 0.08);
    border: 1.5px solid var(--c-accent);
    padding: 1.5rem;
    margin-bottom: 1rem;
  }
  .tunnel-error-card .err-title {
    font-family: 'Fraunces', Georgia, serif;
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--c-accent);
    margin-bottom: 0.5rem;
  }
  .tunnel-error-card .err-body {
    font-size: 0.9rem;
    color: var(--c-ink);
    line-height: 1.5;
    margin-bottom: 1rem;
  }
  .tunnel-error-card .err-list {
    margin-top: 0.75rem;
    padding-left: 0;
    list-style: none;
  }
  .tunnel-error-card .err-list li {
    position: relative;
    padding-left: 1.25rem;
    margin-bottom: 0.5rem;
    font-size: 0.875rem;
  }
  .tunnel-error-card .err-list li::before {
    content: '→';
    position: absolute;
    left: 0;
    top: 0;
    color: var(--c-accent);
    font-weight: 700;
  }

  /* --- Form layout for dimensions --- */
  .dim-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
    margin-bottom: 2rem;
    width: 100%;
    max-width: 100%;
  }
  @media (min-width: 640px) {
    .dim-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1.25rem; }
  }
  .dim-field {
    min-width: 0;
  }
  .dim-field label {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--c-ink-soft);
    font-weight: 600;
    margin-bottom: 0.4rem;
    display: block;
  }
  .dim-field .input-row {
    display: flex;
    align-items: baseline;
    border-bottom: 2px solid var(--c-line-strong);
    min-width: 0;
    width: 100%;
  }
  .dim-field .input-row:focus-within { border-bottom-color: var(--c-leaf-dark); }
  .dim-field input {
    background: transparent;
    border: none;
    font-family: 'Fraunces', Georgia, serif;
    font-size: clamp(1.5rem, 2.5vw, 2rem);
    font-weight: 600;
    flex: 1 1 0;
    width: 100%;
    min-width: 0;
    padding: 0.4rem 0;
    color: var(--c-ink);
    outline: none;
  }
  .dim-field input::placeholder { color: var(--c-line); }
  .dim-field .input-suffix {
    flex-shrink: 0;
    margin-left: 0.4rem;
  }
  /* État erreur (out of range) */
  .dim-field .input-row.input-row-error { border-bottom-color: #b00020; }
  .dim-field .input-row.input-row-error:focus-within { border-bottom-color: #b00020; }
  .dim-field .dim-error {
    margin-top: 0.4rem;
    font-size: 0.78rem;
    color: #b00020;
    font-style: italic;
  }

  /* --- Final summary stage --- */
  .final-totals {
    background: var(--c-ink);
    color: var(--c-paper);
    padding: 2rem;
    margin-top: 1.5rem;
  }

  /* --- Keyboard hint --- */
  .kbd-hint {
    font-size: 0.75rem;
    color: var(--c-ink-soft);
    margin-top: 1rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
  }
  .kbd {
    background: var(--c-paper);
    border: 1px solid var(--c-line);
    border-bottom-width: 2px;
    padding: 0.1rem 0.4rem;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.7rem;
    border-radius: 3px;
  }

  /* SVG illustration container */
  .svg-illu {
    aspect-ratio: 16 / 9;
    background: #fff;
    border: 1px solid var(--c-line);
    padding: 0.75rem;
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .svg-illu svg { width: 100%; height: 100%; }
  /* === Card option bâchage (nouvelle structure tags + prix) === */
  .bachage-card {
    position: relative;
    display: block;
    width: 100%;
    padding: 1.25rem 1.5rem;
    background: var(--c-paper);
    border: 1px solid var(--c-line);
    text-align: left;
    cursor: pointer;
    transition: all 0.15s;
  }
  .bachage-card:hover:not(.is-disabled) {
    border-color: var(--c-ink);
  }
  .bachage-card.is-selected {
    background: rgba(45, 90, 61, 0.05);
    border-color: var(--c-leaf-dark);
    box-shadow: 0 0 0 1px var(--c-leaf-dark);
  }
  .bachage-card.is-disabled {
    opacity: 0.55;
    cursor: not-allowed;
    background: rgba(0,0,0,0.02);
    pointer-events: none;
  }
  .bachage-card-body {
    display: flex;
    gap: 1.5rem;
    align-items: flex-start;
  }
  .bachage-card-left {
    flex: 1;
    min-width: 0;
  }
  .bachage-card-title {
    font-family: 'Fraunces', Georgia, serif;
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--c-ink);
    margin-bottom: 0.85rem;
    line-height: 1.35;
  }
  .bachage-tags {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
  }
  .bachage-tag {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.5rem 0.75rem;
    background: rgba(0,0,0,0.025);
    border-left: 3px solid var(--c-line-strong);
    font-size: 0.85rem;
    line-height: 1.35;
  }
  .bachage-tag-label {
    color: var(--c-ink-soft);
    font-weight: 500;
    flex: 1;
  }
  .bachage-tag-value {
    font-weight: 600;
    color: var(--c-ink);
    flex-shrink: 0;
    text-align: right;
  }
  .bachage-tag-detail {
    display: block;
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--c-ink-soft);
    margin-top: 0.1rem;
  }
  /* Variantes selon qualité du débord */
  .bachage-tag.debord-ideal {
    background: rgba(45, 90, 61, 0.07);
    border-left-color: var(--c-leaf-dark);
  }
  .bachage-tag.debord-ideal .bachage-tag-value > span:first-child {
    color: var(--c-leaf-dark);
  }
  .bachage-tag.debord-large {
    background: rgba(59, 130, 246, 0.06);
    border-left-color: #3b82f6;
  }
  .bachage-tag.debord-large .bachage-tag-value > span:first-child {
    color: #1d4ed8;
  }
  .bachage-tag.debord-serre {
    background: rgba(245, 158, 11, 0.08);
    border-left-color: #d97706;
  }
  .bachage-tag.debord-serre .bachage-tag-value > span:first-child {
    color: #92400e;
  }
  .bachage-tag.debord-excessif {
    background: rgba(217, 119, 6, 0.10);
    border-left-color: #ca8a04;
  }
  .bachage-tag.debord-excessif .bachage-tag-value > span:first-child {
    color: #92400e;
  }
  /* Bloc Prix HT à droite */
  .bachage-card-price {
    flex-shrink: 0;
    min-width: 140px;
    padding: 0.85rem 1rem;
    background: var(--c-ink);
    color: var(--c-leaf-bright);
    text-align: center;
    align-self: flex-start;
  }
  .bachage-card-price-label {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    opacity: 0.7;
    margin-bottom: 0.25rem;
    font-weight: 600;
  }
  .bachage-card-price-value {
    font-family: 'Fraunces', Georgia, serif;
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1.1;
  }
  @media (max-width: 640px) {
    .bachage-card-body { flex-direction: column; }
    .bachage-card-price { width: 100%; }
  }

  /* === Zone schéma de pose (dépliable) === */
  /* ============================================================
   * CARDS BÂCHAGE V2 — design épuré avec bouton "Choisir"
   * ============================================================ */
  .mbds-widget .bachage-card-v2 {
    background: #fff;
    border: 1px solid var(--c-line);
    padding: 1.5rem;
    transition: border-color 0.2s, box-shadow 0.2s;
  }
  .mbds-widget .bachage-card-v2:hover {
    border-color: var(--c-leaf-dark);
    box-shadow: 0 2px 12px -6px rgba(20, 43, 0, 0.12);
  }
  .mbds-widget .bachage-card-v2.is-selected {
    border-color: var(--c-leaf-dark);
    border-width: 2px;
    padding: calc(1.5rem - 1px);
  }
  .mbds-widget .bachage-card-v2.is-disabled {
    opacity: 0.4;
    pointer-events: none;
  }

  /* Header : titre + flags à gauche, prix à droite */
  .mbds-widget .bachage-v2-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1.5rem;
    margin-bottom: 1.25rem;
  }
  .mbds-widget .bachage-v2-header-left {
    flex: 1 1 auto;
    min-width: 0;
  }
  .mbds-widget .bachage-v2-title {
    font-family: 'Fraunces', Georgia, serif;
    font-size: 1.15rem;
    font-weight: 600;
    color: var(--c-ink);
    line-height: 1.35;
    margin-bottom: 0.6rem;
  }
  .mbds-widget .bachage-v2-flags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
  }
  .mbds-widget .bachage-v2-flag {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.28rem 0.6rem;
    background: var(--c-paper);
    border: 1px solid var(--c-line-strong);
    color: var(--c-ink);
    border-radius: 0;
    line-height: 1.3;
  }
  .mbds-widget .bachage-v2-flag svg {
    width: 12px;
    height: 12px;
    flex-shrink: 0;
    color: var(--c-leaf);
  }
  .mbds-widget .bachage-v2-flag.flag-economic svg { color: var(--c-leaf-dark); }
  .mbds-widget .bachage-v2-flag.flag-aeration svg { color: #4a90c2; }
  .mbds-widget .bachage-v2-flag.flag-easy svg { color: var(--c-leaf-dark); }

  /* Prix : typo serif, sans boîte noire */
  .mbds-widget .bachage-v2-price {
    flex: 0 0 auto;
    text-align: right;
  }
  .mbds-widget .bachage-v2-price-label {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--c-ink-soft);
    margin-bottom: 0.15rem;
  }
  .mbds-widget .bachage-v2-price-value {
    font-family: 'Fraunces', Georgia, serif;
    font-size: 1.75rem;
    font-weight: 600;
    color: var(--c-ink);
    line-height: 1;
    white-space: nowrap;
  }

  /* Specs : grille épurée 2 colonnes, séparateurs fins */
  .mbds-widget .bachage-v2-specs {
    margin: 0;
    padding: 0;
    border-top: 1px solid var(--c-line);
  }
  .mbds-widget .bachage-v2-spec-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 1rem;
    padding: 0.55rem 0;
    border-bottom: 1px solid var(--c-line);
  }
  .mbds-widget .bachage-v2-spec-row:last-child { border-bottom: 0; }
  .mbds-widget .bachage-v2-spec-row dt {
    font-size: 0.82rem;
    color: var(--c-ink-soft);
    margin: 0;
    flex: 1 1 auto;
  }
  .mbds-widget .bachage-v2-spec-row dd {
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--c-ink);
    margin: 0;
    text-align: right;
    flex: 0 0 auto;
  }

  /* Footer : lien schéma à gauche, bouton Choisir à droite */
  .mbds-widget .bachage-v2-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--c-line);
  }
  .mbds-widget .bachage-v2-schema-link {
    background: transparent;
    color: var(--c-leaf-dark);
    border: 1.5px solid var(--c-leaf-dark);
    font-size: 0.82rem;
    font-weight: 600;
    cursor: pointer;
    padding: 0.55rem 0.95rem;
    text-decoration: none;
    transition: background 0.15s, color 0.15s;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
  }
  .mbds-widget .bachage-v2-schema-link:hover {
    background: var(--c-leaf-dark);
    color: var(--c-leaf-bright);
  }
  .mbds-widget .bachage-v2-choose-btn {
    background: var(--c-leaf-bright);
    color: var(--c-leaf-dark);
    border: 1.5px solid var(--c-leaf-bright);
    font-weight: 700;
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 0.65rem 1.4rem;
    cursor: pointer;
    transition: background 0.15s, transform 0.1s;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
  }
  .mbds-widget .bachage-v2-choose-btn:hover {
    background: #8fd962;
    border-color: #8fd962;
  }
  .mbds-widget .bachage-v2-choose-btn:active {
    transform: translateY(1px);
  }
  .mbds-widget .bachage-v2-choose-btn .arrow {
    font-weight: 400;
  }

  /* Responsive : mobile, tout en colonne */
  @media (max-width: 640px) {
    .mbds-widget .bachage-card-v2 {
      padding: 1.25rem;
    }
    .mbds-widget .bachage-v2-header {
      flex-direction: column;
      align-items: stretch;
      gap: 0.75rem;
    }
    .mbds-widget .bachage-v2-price {
      text-align: left;
    }
    .mbds-widget .bachage-v2-price-value {
      font-size: 1.5rem;
    }
    .mbds-widget .bachage-v2-spec-row {
      flex-direction: column;
      gap: 0.1rem;
    }
    .mbds-widget .bachage-v2-spec-row dd {
      text-align: left;
    }
    .mbds-widget .bachage-v2-footer {
      flex-direction: column-reverse;
      align-items: stretch;
      gap: 0.6rem;
    }
    .mbds-widget .bachage-v2-choose-btn {
      width: 100%;
      justify-content: center;
    }
    .mbds-widget .bachage-v2-schema-link {
      text-align: center;
    }
  }

  /* ============================================================ */

  .bachage-card-wrap {
    display: flex;
    flex-direction: column;
  }
  .bachage-schema-toggle-wrap {
    margin-top: 0.85rem;
    padding-top: 0.85rem;
    border-top: 1px dashed var(--c-line);
  }
  .bachage-schema-toggle {
    background: transparent;
    border: 0;
    color: var(--c-leaf-dark);
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    padding: 0.25rem 0;
    text-decoration: underline;
    text-decoration-color: rgba(45, 90, 61, 0.3);
    text-underline-offset: 3px;
  }
  .bachage-schema-toggle:hover {
    text-decoration-color: var(--c-leaf-dark);
  }
  .bachage-schema-zone {
    background: #fff;
    border: 1px solid var(--c-line);
    border-top: 0;
    padding: 1.25rem 1.5rem;
    margin-top: -1px;
  }
  /* Variante : schéma intégré DANS la card (pas autour). Neutralise le wrapper
     blanc/bordure puisque la card v2 en a déjà un. */
  .mbds-widget .bachage-schema-zone--inside {
    background: transparent;
    border: 0;
    margin-top: 1rem;
    padding: 1rem 0 0;
    border-top: 1px solid var(--c-line);
  }
  /* Desktop : le SVG s'adapte à la largeur dispo dans la card (pas de scroll) */
  .mbds-widget .bachage-schema-zone--inside .schema-svg {
    width: 100%;
    max-width: 100%;
  }
  /* Mobile : on reprend le scroll horizontal car la card est trop étroite */
  @media (max-width: 640px) {
    .mbds-widget .bachage-schema-zone--inside .schema-svg {
      width: 900px;
      max-width: none;
    }
  }
  .bachage-schema-scroller {
    overflow-x: auto;
    overflow-y: hidden;
    /* Scrollbar discrète */
    scrollbar-width: thin;
    scrollbar-color: var(--c-line-strong) transparent;
    /* Smooth scroll inertia sur iOS */
    -webkit-overflow-scrolling: touch;
  }
  .bachage-schema-scroller::-webkit-scrollbar { height: 6px; }
  .bachage-schema-scroller::-webkit-scrollbar-thumb { background: var(--c-line-strong); border-radius: 3px; }
  .bachage-schema-zone .schema-svg {
    display: block;
    height: auto;
    /* Desktop : largeur fixe pour bonne lisibilité + scroll si conteneur plus petit */
    width: 1000px;
    max-width: none;
  }
  /* Hint scroll mobile : icône + texte au-dessus du SVG */
  .bachage-schema-scroll-hint {
    display: none;
    font-size: 0.72rem;
    color: var(--c-ink-soft);
    font-style: italic;
    margin-bottom: 0.4rem;
    text-align: center;
  }
  @media (max-width: 640px) {
    /* Sur mobile : SVG forcé à 900 px (lisibilité) + scroll horizontal */
    .bachage-schema-zone .schema-svg {
      width: 900px;
      max-width: none;
    }
    .bachage-schema-scroll-hint {
      display: block;
    }
    .bachage-schema-zone {
      padding: 1rem 0.75rem;
    }
  }
  .bachage-schema-legend {
    display: flex;
    gap: 1.25rem;
    font-size: 0.78rem;
    color: #555;
    margin-bottom: 0.75rem;
    flex-wrap: wrap;
  }
  .bachage-schema-legend-item {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
  }
  .bachage-schema-legend-swatch {
    display: inline-block;
    width: 1.5rem;
    height: 3px;
  }
  .bachage-schema-caption {
    font-size: 0.75rem;
    color: #777;
    margin-top: 0.5rem;
    font-style: italic;
  }

  /* === Flags de préconisation (en haut à droite, en flux dans la card) === */
  .bachage-flags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    justify-content: flex-end;
    margin-bottom: 0.85rem;
  }
  .bachage-flag {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.65rem;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border: 1px solid;
    border-radius: 4px;
    line-height: 1;
    white-space: nowrap;
  }
  .bachage-flag.flag-easy {
    background: rgba(45, 90, 61, 0.10);
    color: var(--c-leaf-dark);
    border-color: var(--c-leaf-dark);
  }
  .bachage-flag.flag-aeration {
    background: rgba(59, 130, 246, 0.10);
    color: #1d4ed8;
    border-color: #3b82f6;
  }
  .bachage-flag.flag-economic {
    background: var(--c-leaf-bright);
    color: var(--c-leaf-dark);
    border-color: var(--c-leaf-dark);
  }
  @media (max-width: 640px) {
    .bachage-flags {
      justify-content: flex-start;
    }
  }

  /* --- Badge "Plus économique" sur card option bâchage (legacy, gardé pour compat) --- */
  .bachage-economic-badge {
    position: absolute;
    top: -10px;
    left: 12px;
    padding: 0.2rem 0.6rem;
    background: var(--c-leaf-bright);
    color: var(--c-leaf-dark);
    border: 1px solid var(--c-leaf-dark);
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border-radius: 4px;
  }

  /* --- CTA téléphone sur récap final --- */
  .recap-phone-cta {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin: 0 0 1.5rem;
    padding: 0.85rem 1rem;
    background: var(--c-leaf-bright);
    border: 1px solid var(--c-line-strong);
    border-left: 4px solid var(--c-leaf-dark);
  }
  .recap-phone-text {
    flex: 1;
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--c-ink);
  }
  .recap-phone-btn {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    padding: 0.6rem 1rem;
    background: var(--c-ink);
    color: var(--c-leaf-bright);
    font-weight: 700;
    font-size: 1rem;
    text-decoration: none;
    transition: background 0.15s;
    font-family: 'Fraunces', Georgia, serif;
  }
  .recap-phone-btn:hover {
    background: var(--c-ink-soft);
    color: var(--c-leaf-bright);
  }
  @media (max-width: 640px) {
    .recap-phone-cta {
      flex-direction: column;
      align-items: stretch;
      text-align: center;
    }
    .recap-phone-btn {
      justify-content: center;
    }
  }
  /* Variante : CTA téléphone en bas du récap (après le bouton Commander) */
  .mbds-widget .recap-phone-cta--bottom {
    margin: 2rem 0 0;
  }

  /* === Toast succès ajout panier === */
  .mbds-widget .cart-success-toast {
    margin-top: 1rem;
    padding: 0.85rem 1rem;
    background: var(--c-leaf-bright);
    color: var(--c-leaf-dark);
    border: 1.5px solid var(--c-leaf-dark);
    font-size: 0.9rem;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 0.6rem;
    animation: fadeInUp 0.3s ease-out;
  }
  .mbds-widget .cart-success-icon {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    background: var(--c-leaf-dark);
    color: var(--c-leaf-bright);
    border-radius: 50%;
    font-weight: 700;
    font-size: 0.78rem;
  }
  @keyframes fadeInUp {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0); }
  }

  /* === Bloc réassurance final === */
  .mbds-widget .reassurance-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem 1.25rem;
    margin: 2rem 0 0;
    padding: 1.75rem 1.5rem;
    background: var(--c-paper);
    border: 1px solid var(--c-line);
  }
  .mbds-widget .reassurance-item {
    display: flex;
    align-items: flex-start;
    gap: 0.7rem;
  }
  .mbds-widget .reassurance-icon {
    flex: 0 0 28px;
    font-size: 1.4rem;
    line-height: 1;
    color: var(--c-leaf-dark);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 0.1rem;
  }
  .mbds-widget .reassurance-icon svg {
    display: block;
  }
  .mbds-widget .reassurance-text {
    display: flex;
    flex-direction: column;
    gap: 0.05rem;
    min-width: 0;
  }
  .mbds-widget .reassurance-text strong {
    font-size: 0.88rem;
    font-weight: 700;
    color: var(--c-ink);
    line-height: 1.3;
  }
  .mbds-widget .reassurance-text span {
    font-size: 0.78rem;
    color: var(--c-ink-soft);
    line-height: 1.35;
  }
  @media (max-width: 640px) {
    .mbds-widget .reassurance-grid {
      grid-template-columns: 1fr;
      padding: 1.25rem;
      gap: 0.85rem;
    }
  }

  /* === "Made in France" stamp discret (étape 1) === */
  .mbds-widget .mif-stamp {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin: 0.5rem 0 1.5rem;
    padding: 0.4rem 0.8rem;
    background: rgba(158, 232, 111, 0.16);
    border: 1px solid rgba(45, 90, 29, 0.25);
    border-radius: 3px;
    font-size: 0.8rem;
  }
  .mbds-widget .mif-flag {
    font-size: 1.05rem;
    line-height: 1;
  }
  .mbds-widget .mif-text {
    color: var(--c-ink);
    font-weight: 500;
  }

  /* --- Encart "aération latérale" (jaune) sur écran POSE --- */
  .aeration-callout {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin: 0 0 1.25rem;
    padding: 0.85rem 1rem;
    background: #fef9c3;
    border: 1px solid #fde047;
    border-left: 4px solid #ca8a04;
    color: #713f12;
  }
  .aeration-callout-text {
    flex: 1;
    font-size: 0.85rem;
    line-height: 1.45;
  }
  .aeration-callout-btn {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.55rem 1rem;
    background: var(--c-leaf-dark);
    color: var(--c-leaf-bright);
    font-weight: 600;
    font-size: 0.85rem;
    border: 1.5px solid var(--c-leaf-dark);
    text-decoration: none;
    transition: background 0.15s, color 0.15s;
    white-space: nowrap;
  }
  .aeration-callout-btn:hover {
    background: var(--c-leaf-bright);
    color: var(--c-leaf-dark);
  }
  @media (max-width: 640px) {
    .aeration-callout {
      flex-direction: column;
      align-items: stretch;
    }
    .aeration-callout-btn {
      justify-content: center;
    }
  }

  /* --- Encart "tunnels enregistrés" sur écran shape (multi-tunnels) --- */
  /* === Mention "autres structures sur demande" (sous cards forme) === */
  .mbds-widget .other-shapes-note {
    margin: 1.75rem 0 0;
    padding: 1.25rem 0 0;
    border-top: 1px solid var(--c-line);
  }
  .mbds-widget .other-shapes-note-title {
    font-family: 'Fraunces', Georgia, serif;
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--c-ink);
    line-height: 1.35;
    margin-bottom: 0.45rem;
  }
  .mbds-widget .other-shapes-note-text {
    margin: 0;
    font-size: 0.88rem;
    color: var(--c-ink-soft);
    line-height: 1.6;
    max-width: 42rem;
  }
  .mbds-widget .other-shapes-note-text a {
    color: var(--c-leaf-dark);
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 2px;
    text-decoration-color: rgba(20, 43, 0, 0.3);
    transition: text-decoration-color 0.15s, color 0.15s;
  }
  .mbds-widget .other-shapes-note-text a:hover {
    color: var(--c-leaf);
    text-decoration-color: var(--c-leaf);
  }
  .mbds-widget .other-shapes-sep {
    margin: 0 0.35rem;
    color: var(--c-line-strong);
    opacity: 0.4;
  }

  /* === Bloc "Autres structures : contactez-nous" (fin du récap) === */
  .mbds-widget .other-structures {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
  }
  .mbds-widget .other-structures-eyebrow {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--c-ink-soft);
    margin: 0 0 0.5rem;
    font-weight: 600;
  }
  .mbds-widget .other-structures-title {
    font-family: 'Fraunces', Georgia, serif;
    font-size: 1.3rem;
    font-weight: 600;
    color: var(--c-ink);
    margin: 0 0 0.6rem;
    line-height: 1.3;
  }
  .mbds-widget .other-structures-text {
    font-size: 0.9rem;
    color: var(--c-ink);
    line-height: 1.55;
    margin: 0;
    max-width: 38rem;
  }
  .mbds-widget .other-structures-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
  }
  .mbds-widget .other-structures-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.7rem 1.1rem;
    font-size: 0.85rem;
    font-weight: 600;
    text-decoration: none;
    transition: background 0.15s, color 0.15s, border-color 0.15s;
    border: 1.5px solid var(--c-leaf-dark);
    white-space: nowrap;
  }
  .mbds-widget .other-structures-btn--primary {
    background: var(--c-leaf-dark);
    color: var(--c-leaf-bright);
  }
  .mbds-widget .other-structures-btn--primary:hover {
    background: var(--c-leaf-bright);
    color: var(--c-leaf-dark);
  }
  .mbds-widget .other-structures-btn--secondary {
    background: transparent;
    color: var(--c-leaf-dark);
  }
  .mbds-widget .other-structures-btn--secondary:hover {
    background: var(--c-leaf-dark);
    color: var(--c-leaf-bright);
  }
  .mbds-widget .other-structures-thumbs {
    display: flex;
    flex-wrap: wrap;
    gap: 1.25rem;
    padding-top: 1.25rem;
    border-top: 1px dashed var(--c-line);
  }
  .mbds-widget .other-structures-thumb {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    color: var(--c-ink-soft);
    font-size: 0.82rem;
    font-weight: 500;
  }
  .mbds-widget .other-structures-thumb svg {
    width: 56px;
    height: 28px;
    flex-shrink: 0;
    color: var(--c-ink-soft);
    opacity: 0.7;
  }
  @media (max-width: 640px) {
    .mbds-widget .other-structures-actions {
      flex-direction: column;
    }
    .mbds-widget .other-structures-btn {
      justify-content: center;
    }
    .mbds-widget .other-structures-thumbs {
      gap: 0.85rem;
    }
  }

  .saved-tunnels-card {
    margin: 0 0 1.5rem;
    padding: 0.85rem 1rem;
    background: rgba(45,90,61,0.06);
    border-left: 3px solid var(--c-leaf-dark);
    font-size: 0.85rem;
  }
  .saved-tunnels-title {
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--c-leaf-dark);
    margin-bottom: 0.5rem;
    display: flex;
    align-items: center;
  }
  .saved-tunnels-list {
    margin: 0;
    padding: 0;
    list-style: none;
  }
  .saved-tunnels-list li {
    padding: 0.15rem 0;
    color: var(--c-ink);
  }
  .saved-tunnels-num {
    display: inline-block;
    font-weight: 700;
    color: var(--c-leaf-dark);
    margin-right: 0.4rem;
  }
  .saved-tunnels-sep {
    margin: 0 0.4rem;
    opacity: 0.4;
  }

  /* --- Switch stratégies bâchage au récap --- */
  .bachage-switch {
    margin: 0.75rem 0 0.5rem;
    padding: 0.75rem;
    background: rgba(45,90,61,0.04);
    border: 1px solid var(--c-line);
  }
  .bachage-switch-label {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--c-ink-soft);
    margin-bottom: 0.5rem;
    font-weight: 600;
  }
  .bachage-switch-options {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
  }
  .bachage-switch-opt {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.35rem 0.75rem;
    background: var(--c-paper);
    border: 1px solid var(--c-line);
    cursor: pointer;
    font-size: 0.85rem;
    transition: all 0.15s;
  }
  .bachage-switch-opt:hover:not(.is-disabled) {
    border-color: var(--c-ink);
  }
  .bachage-switch-opt.is-selected {
    background: var(--c-ink);
    color: var(--c-leaf-bright);
    border-color: var(--c-ink);
  }
  .bachage-switch-opt.is-disabled {
    opacity: 0.45;
    cursor: not-allowed;
  }
  .bachage-switch-opt input { margin: 0; cursor: inherit; }
  .bachage-switch-na {
    font-size: 0.7rem;
    font-style: italic;
    color: var(--c-accent);
    margin-left: 0.25rem;
  }
