/* ═══════════════════════════════════════════════════════════════
   STUDIO PERSONALIZER — Mobile CSS  (≤ 1024px)
   Chargé après studio-personalizer.css
   ═══════════════════════════════════════════════════════════════ */

/* ── Éléments mobile-only : cachés par défaut (desktop) ── */
.studio-mobile-view-tabs    { display: none; }
.studio-mobile-continue-btn { display: none; }
.studio-mobile-sizes-recap  { display: none; }
.studio-mobile-flow         { display: none; }
.studio-mobile-preview-tools { display: none; }

/* ═══════════════════════════════════════════════════════════════
   STYLES GLOBAUX — boutons confirm modal (dynamiquement créés par JS,
   non stylés dans le CSS principal)
   ═══════════════════════════════════════════════════════════════ */

.studio-confirm-footer {
  flex-shrink: 0;
  padding: 14px 20px 18px;
  border-top: 1px solid #f1f5f9;
  background: #fff;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.studio-confirm-footer-main {
  display: flex;
  gap: 10px;
}

.studio-confirm-btn {
  flex: 1;
  min-height: 48px;
  border-radius: 11px;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  border: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  transition: background 0.15s, transform 0.12s, box-shadow 0.15s;
  touch-action: manipulation;
}

.studio-confirm-btn:active { transform: scale(0.98); }

.studio-confirm-btn-back {
  background: #f3f4f6;
  color: #111827;
  border: 1px solid #e5e7eb;
}
.studio-confirm-btn-back:hover { background: #e5e7eb; }

.studio-confirm-btn-ok {
  background: linear-gradient(180deg, #2563eb 0%, #1d4ed8 100%);
  color: #fff;
  border: 1px solid #1d4ed8;
  box-shadow: 0 8px 20px rgba(29, 78, 216, 0.25);
}
.studio-confirm-btn-ok:hover {
  background: linear-gradient(180deg, #1d4ed8 0%, #1e40af 100%);
  box-shadow: 0 10px 24px rgba(29, 78, 216, 0.32);
}
.studio-confirm-btn-ok:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.studio-confirm-copyright-check {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 12px;
  color: #4b5563;
  cursor: pointer;
  line-height: 1.35;
}
.studio-confirm-copyright-check.is-error { color: #b91c1c; }

/* ═══════════════════════════════════════════════════════════════
   MOBILE  ≤ 1024px
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {

  /* ── 1. Masquer le bouton "Changer de produit" ── */
  .studio-personalizer-root .studio-change-product-btn {
    display: none !important;
  }
  .studio-personalizer-root .studio-dtf-banner,
  .studio-personalizer-root .studio-drawer-dtf-help {
    display: none !important;
  }

  /* ── 2. Barre d'étapes — masquée sur mobile (trop cramped) ──
     On garde le progress lisible via le texte du bouton Continuer. */
  .studio-personalizer-root .studio-steps-bar {
    display: none !important;
  }

  /* ── 3. Onglets de vues produit (pastilles) ── */
  .studio-mobile-view-tabs {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    overflow-x: auto !important;
    scrollbar-width: none !important;
    -webkit-overflow-scrolling: touch !important;
    padding: 8px 14px !important;
    background: #ffffff !important;
    border-bottom: 1px solid #f0f2f5 !important;
    flex-shrink: 0 !important;
  }
  .studio-personalizer-root .studio-personalizer-preview-column .studio-mobile-view-tabs {
    margin: 0 0 8px !important;
    padding: 2px 0 6px !important;
    background: transparent !important;
    border-bottom: 0 !important;
  }
  .studio-personalizer-root .studio-personalizer-preview-column {
    position: relative !important;
  }
  .studio-mobile-view-tabs::-webkit-scrollbar { display: none !important; }

  /* Caché si une seule vue */
  .studio-personalizer-root:not(.has-multiple-views) .studio-mobile-view-tabs {
    display: none !important;
  }

  .studio-mobile-view-tab {
    flex-shrink: 0 !important;
    border: 1.5px solid #e5e7eb !important;
    background: #f9fafb !important;
    color: #374151 !important;
    border-radius: 999px !important;
    padding: 5px 14px !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    white-space: nowrap !important;
    touch-action: manipulation !important;
    transition: border-color 0.15s, background 0.15s, color 0.15s !important;
  }
  .studio-mobile-view-tab.is-active {
    border-color: #2563eb !important;
    background: #eff6ff !important;
    color: #1d4ed8 !important;
  }

  /* ── 4. Bottom sheet — poignée discrète ── */
  .studio-personalizer-root .studio-editor-body::before {
    content: '' !important;
    display: block !important;
    width: 36px !important;
    height: 4px !important;
    border-radius: 2px !important;
    background: #e2e8f0 !important;
    margin: 8px auto 0 !important;
    flex-shrink: 0 !important;
  }

  /* ── 5. Cartes Image / Texte / Couleur — 3 colonnes compactes ── */
  .studio-personalizer-root .studio-type-cards {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }

  .studio-personalizer-root .studio-type-card {
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    padding: 14px 6px 12px !important;
    min-height: 80px !important;
    border: 1.5px solid #e8ecf4 !important;
    border-radius: 14px !important;
    background: #ffffff !important;
    box-shadow: 0 1px 4px rgba(15, 23, 42, 0.05) !important;
    transition: border-color 0.15s, background 0.15s, box-shadow 0.15s !important;
    touch-action: manipulation !important;
  }
  .studio-personalizer-root .studio-type-card:active {
    transform: scale(0.96) !important;
  }
  .studio-personalizer-root .studio-type-card.is-active {
    border-color: #2563eb !important;
    background: linear-gradient(180deg, #f0f5ff 0%, #eff6ff 100%) !important;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12), 0 1px 4px rgba(15, 23, 42, 0.06) !important;
  }
  .studio-personalizer-root .studio-type-card-icon {
    width: 38px !important;
    height: 38px !important;
    border-radius: 11px !important;
  }
  .studio-personalizer-root .studio-type-card span {
    font-size: 11px !important;
    font-weight: 700 !important;
    text-align: center !important;
    line-height: 1.3 !important;
  }
  .studio-personalizer-root .studio-type-card span strong {
    display: none !important;
  }

  /* ── 6. Bouton Continuer ── */
  .studio-personalizer-root .studio-mobile-continue-btn {
    display: flex !important;
    width: 100% !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    min-height: 50px !important;
    margin-top: 10px !important;
    border: 1px solid #1d4ed8 !important;
    border-radius: 13px !important;
    background: linear-gradient(180deg, #2563eb 0%, #1d4ed8 100%) !important;
    color: #ffffff !important;
    font-size: 15px !important;
    font-weight: 800 !important;
    letter-spacing: 0.01em !important;
    box-shadow: 0 6px 18px rgba(29, 78, 216, 0.3) !important;
    touch-action: manipulation !important;
    cursor: pointer !important;
  }
  .studio-personalizer-root .studio-mobile-continue-btn::after {
    content: "→" !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    opacity: 0.7 !important;
  }

  /* ── 7. Messages d'erreur / statut visibles sur mobile ──
     Le footer est montré mais uniquement le .studio-status.
     Les boutons add-to-cart restent cachés. */
  .studio-personalizer-root .studio-editor-footer {
    display: flex !important;
    flex-direction: column !important;
    padding: 0 !important;
    background: transparent !important;
    border-top: none !important;
    gap: 0 !important;
    pointer-events: auto !important;
  }
  .studio-personalizer-root .studio-footer-actions,
  .studio-personalizer-root .studio-sticky-summary,
  .studio-personalizer-root .studio-editor-footer .studio-copyright-check {
    display: none !important;
  }
  /* Statut — visible seulement si rempli */
  .studio-personalizer-root .studio-editor-footer .studio-status:not(:empty) {
    margin: 0 12px calc(10px + env(safe-area-inset-bottom)) !important;
    padding: 10px 12px !important;
    border-radius: 10px !important;
    font-size: 13px !important;
  }
  .studio-personalizer-root .studio-editor-footer .studio-status.is-info,
  .studio-personalizer-root .studio-editor-footer .studio-status.is-success {
    display: none !important;
  }
  .studio-personalizer-root .studio-preview-toolbar {
    position: static !important;
    left: auto !important;
    bottom: auto !important;
    transform: none !important;
    z-index: auto !important;
    display: flex !important;
    justify-content: center !important;
    width: auto !important;
    margin: 8px 0 0 !important;
    padding: 8px 10px !important;
    border-radius: 14px !important;
    background: rgba(255, 255, 255, 0.96) !important;
    box-shadow: 0 8px 20px rgba(15, 23, 42, 0.1) !important;
  }
  .studio-personalizer-root .studio-preview-toolbar .studio-zoom-controls {
    width: 100% !important;
    gap: 10px !important;
  }
  .studio-personalizer-root .studio-preview-toolbar .studio-zoom-slider {
    flex: 1 1 auto !important;
  }
  .studio-personalizer-root .studio-preview-toolbar .studio-zoom-level {
    min-width: 38px !important;
    text-align: right !important;
    font-weight: 800 !important;
  }
  /* Post-ajout panier */
  .studio-personalizer-root .studio-cart-added-confirm {
    pointer-events: auto !important;
    padding: 8px 12px calc(10px + env(safe-area-inset-bottom)) !important;
  }
  .studio-personalizer-root .studio-cart-added-confirm .studio-confirm-actions {
    flex-direction: column !important;
    gap: 8px !important;
  }
  .studio-personalizer-root .studio-cart-added-confirm .studio-confirm-continue,
  .studio-personalizer-root .studio-cart-added-confirm .studio-confirm-goto-cart {
    width: 100% !important;
    min-height: 46px !important;
    border-radius: 11px !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    touch-action: manipulation !important;
  }

  /* ── 8. Tiroir contenu — plein écran via position fixed ── */
  .studio-personalizer-root .studio-content-drawer {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    z-index: 200 !important;
    transform: translateX(100%) !important;
    border-radius: 0 !important;
    background: #ffffff !important;
    height: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
  }
  .studio-personalizer-root .studio-content-drawer.is-open {
    transform: translateX(0) !important;
  }
  .studio-personalizer-root .studio-content-drawer[aria-hidden="true"] {
    visibility: hidden !important;
    pointer-events: none !important;
  }
  .studio-personalizer-root .studio-content-drawer[aria-hidden="false"] {
    visibility: visible !important;
    pointer-events: auto !important;
  }

  /* Header du tiroir */
  .studio-personalizer-root .studio-content-drawer-header {
    padding: 0 16px !important;
    min-height: 58px !important;
    background: #ffffff !important;
    border-bottom: 1px solid #f0f0f0 !important;
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    flex-shrink: 0 !important;
  }
  .studio-personalizer-root .studio-drawer-back-circle {
    width: 38px !important;
    height: 38px !important;
  }
  .studio-personalizer-root .studio-drawer-title {
    font-size: 16px !important;
    font-weight: 800 !important;
    color: #111827 !important;
  }

  /* Corps du tiroir */
  .studio-personalizer-root .studio-content-drawer-body {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    padding: 16px !important;
    gap: 14px !important;
  }

  /* Footer tiroir (Retour / Suivant) */
  .studio-personalizer-root .studio-content-drawer .studio-drawer-step-actions {
    flex-shrink: 0 !important;
    gap: 10px !important;
    padding: 12px 16px calc(14px + env(safe-area-inset-bottom)) !important;
    border-top: 1px solid #f0f0f0 !important;
    background: #ffffff !important;
    display: flex !important;
  }
  .studio-personalizer-root .studio-content-drawer .studio-drawer-step-btn {
    min-height: 50px !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    border-radius: 12px !important;
    touch-action: manipulation !important;
  }
  .studio-personalizer-root .studio-mobile-continue-btn[data-step="image"] {
    background: linear-gradient(180deg, #0f766e 0%, #0f766e 100%) !important;
    border-color: #0f766e !important;
    box-shadow: 0 10px 24px rgba(15, 118, 110, 0.28) !important;
  }
  .studio-personalizer-root .studio-mobile-continue-btn[data-step="adjust"] {
    background: linear-gradient(180deg, #2563eb 0%, #1d4ed8 100%) !important;
  }
  .studio-personalizer-root .studio-mobile-continue-btn[data-step="sizes"] {
    background: linear-gradient(180deg, #7c3aed 0%, #6d28d9 100%) !important;
    border-color: #6d28d9 !important;
    box-shadow: 0 10px 24px rgba(109, 40, 217, 0.28) !important;
  }
  .studio-personalizer-root .studio-mobile-continue-btn[data-step="confirm"] {
    background: linear-gradient(180deg, #ea580c 0%, #c2410c 100%) !important;
    border-color: #c2410c !important;
    box-shadow: 0 10px 24px rgba(194, 65, 12, 0.3) !important;
  }
  .studio-personalizer-root .studio-mobile-continue-btn:disabled,
  .studio-personalizer-root .studio-mobile-continue-btn[disabled] {
    opacity: 0.58 !important;
    box-shadow: none !important;
  }

  /* Dé-densifier le layout mobile : aperçu en haut, actions séparées en bas */
  .studio-personalizer-root .studio-personalizer-layout {
    display: grid !important;
    grid-template-rows: minmax(220px, 40dvh) minmax(0, 1fr) !important;
    height: calc(100dvh - 58px) !important;
    background: #f3f4f6 !important;
  }
  .studio-personalizer-root .studio-personalizer-preview-column {
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
    padding: 10px 12px 8px !important;
    background: #f3f4f6 !important;
  }
  .studio-personalizer-root .studio-preview-scroll-area {
    flex: 1 1 auto !important;
    min-height: 0 !important;
  }
  .studio-personalizer-root .studio-personalizer-preview-box {
    border-radius: 18px !important;
    overflow: hidden !important;
    background: #ffffff !important;
    box-shadow: 0 8px 22px rgba(15, 23, 42, 0.08) !important;
  }
  .studio-personalizer-root .studio-personalizer-editor-column {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    z-index: auto !important;
    display: block !important;
    background: #ffffff !important;
    border-top: 1px solid #e5e7eb !important;
    border-radius: 22px 22px 0 0 !important;
    box-shadow: 0 -10px 28px rgba(15, 23, 42, 0.08) !important;
    pointer-events: auto !important;
    overflow: hidden !important;
  }
  .studio-personalizer-root .studio-editor-body {
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
    background: #ffffff !important;
  }
  .studio-personalizer-root .studio-editor-main {
    padding: 8px 12px calc(12px + env(safe-area-inset-bottom)) !important;
  }
  .studio-personalizer-root .studio-personalize-section {
    padding: 0 !important;
  }
  .studio-personalizer-root .studio-type-cards {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 6px !important;
    padding: 4px !important;
    background: #f8fafc !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 14px !important;
  }
  .studio-personalizer-root .studio-type-card {
    min-height: 46px !important;
    gap: 4px !important;
    padding: 8px 4px !important;
    border: 1px solid transparent !important;
    border-radius: 10px !important;
    background: transparent !important;
    box-shadow: none !important;
  }
  .studio-personalizer-root .studio-type-card-icon {
    width: 24px !important;
    height: 24px !important;
    border-radius: 8px !important;
  }
  .studio-personalizer-root .studio-type-card span {
    font-size: 10px !important;
    line-height: 1.1 !important;
    letter-spacing: 0 !important;
    color: #475569 !important;
  }
  .studio-personalizer-root .studio-type-card.is-active {
    background: #ffffff !important;
    border-color: #bfdbfe !important;
    box-shadow: 0 4px 12px rgba(37, 99, 235, 0.12) !important;
  }
  .studio-personalizer-root .studio-type-card.is-active span {
    color: #1d4ed8 !important;
  }
  .studio-personalizer-root .studio-order-section {
    margin-top: 8px !important;
    padding: 10px 0 0 !important;
    border-top: 1px solid #eef2f7 !important;
  }
  .studio-personalizer-root .studio-option-row {
    padding: 11px 12px !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 12px !important;
    background: #ffffff !important;
    gap: 8px !important;
  }
  .studio-personalizer-root .studio-colors-row,
  .studio-personalizer-root .studio-sizes-row {
    padding: 11px 12px !important;
    border-radius: 12px !important;
    background: #ffffff !important;
  }
  .studio-personalizer-root .studio-size-qty-section {
    margin-top: 8px !important;
  }
  .studio-personalizer-root .studio-option-row-label {
    font-size: 12px !important;
    font-weight: 800 !important;
    color: #0f172a !important;
  }
  .studio-personalizer-root .studio-option-row-value,
  .studio-personalizer-root .studio-sizes-badges {
    font-size: 11px !important;
    color: #64748b !important;
  }
  .studio-personalizer-root .studio-option-row-edit {
    width: 24px !important;
    height: 24px !important;
    background: #f8fafc !important;
  }
  .studio-personalizer-root .studio-mobile-continue-btn {
    margin-top: 8px !important;
  }

  @media (max-width: 380px) {
    .studio-personalizer-root .studio-personalizer-layout {
      grid-template-rows: minmax(200px, 36dvh) minmax(0, 1fr) !important;
    }
    .studio-personalizer-root .studio-type-card span {
      font-size: 9px !important;
    }
    .studio-personalizer-root .studio-mobile-continue-btn {
      font-size: 14px !important;
    }
  }

  /* ── 9. Modal de confirmation — bottom sheet sur mobile ── */
  .studio-personalizer-root .studio-confirm-overlay {
    padding: 0 !important;
    align-items: flex-end !important;
  }
  .studio-personalizer-root .studio-confirm-panel {
    width: 100% !important;
    max-width: none !important;
    max-height: 90dvh !important;
    border-radius: 20px 20px 0 0 !important;
  }
  .studio-personalizer-root .studio-confirm-body {
    flex-direction: column !important;
    overflow-y: auto !important;
  }
  .studio-personalizer-root .studio-confirm-previews-col {
    width: 100% !important;
    border-right: none !important;
    border-bottom: 1px solid #f1f5f9 !important;
    padding: 14px !important;
    max-height: 180px !important;
    overflow-y: auto !important;
  }
  .studio-personalizer-root .studio-confirm-details-col {
    width: 100% !important;
    padding: 14px !important;
  }
  .studio-personalizer-root .studio-confirm-footer {
    padding-bottom: calc(18px + env(safe-area-inset-bottom)) !important;
  }
  .studio-personalizer-root .studio-confirm-footer-main {
    flex-direction: column-reverse !important;
    gap: 8px !important;
  }
  .studio-personalizer-root .studio-confirm-btn {
    min-height: 50px !important;
    touch-action: manipulation !important;
  }

  /* ── 10. Récapitulatif tailles ── */
  .studio-personalizer-root .studio-panel-sizes .studio-mobile-sizes-recap {
    display: block !important;
    margin-top: 14px !important;
    padding: 12px 14px !important;
    background: linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%) !important;
    border: 1px solid #86efac !important;
    border-radius: 12px !important;
  }
  .studio-mobile-sizes-recap-title {
    display: block !important;
    font-size: 10px !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.09em !important;
    color: #166534 !important;
    margin-bottom: 4px !important;
  }
  .studio-mobile-sizes-recap-total {
    display: block !important;
    font-size: 20px !important;
    font-weight: 800 !important;
    color: #111827 !important;
    letter-spacing: -0.03em !important;
  }

  /* ── 11. Tableau tailles & quantités — touch-friendly ── */
  .studio-personalizer-root .studio-stepper-btn {
    width: 40px !important;
    height: 40px !important;
    font-size: 20px !important;
  }
  .studio-personalizer-root .studio-size-qty-input {
    width: 42px !important;
    height: 40px !important;
    font-size: 15px !important;
  }

  /* ── 12. Upload zone ── */
  .studio-personalizer-root .studio-insert-image-btn {
    min-height: 46px !important;
    font-size: 14px !important;
    border-radius: 11px !important;
    touch-action: manipulation !important;
  }

  /* ── 13. Swatches couleurs ── */
  .studio-personalizer-root .studio-color-swatch {
    width: 44px !important;
    height: 44px !important;
    touch-action: manipulation !important;
  }

  /* ── 14. Ligne couleur / option-row — zone de tap élargie ── */
  .studio-personalizer-root .studio-colors-row,
  .studio-personalizer-root .studio-sizes-row {
    min-height: 52px !important;
    touch-action: manipulation !important;
    cursor: pointer !important;
  }

  /* ── 15. Panel couleur dans le tiroir — option-body toujours ouvert ── */
  .studio-personalizer-root .studio-content-drawer .studio-option-body {
    display: block !important;
    max-height: none !important;
    overflow: visible !important;
  }
  .studio-personalizer-root .studio-content-drawer .studio-option-row {
    pointer-events: none !important;
  }
  .studio-personalizer-root .studio-content-drawer .studio-color-swatches {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    padding: 4px 0 !important;
  }

  /* Mobile conversion UX: header compact, apercu prioritaire, parcours clair */
  .studio-personalizer-root .studio-personalizer-panel {
    display: flex !important;
    flex-direction: column !important;
    background: #f4f6f8 !important;
  }

  .studio-personalizer-root .studio-panel-header {
    flex-shrink: 0 !important;
    min-height: 52px !important;
    padding: 8px 12px !important;
  }

  .studio-personalizer-root .studio-panel-title {
    font-size: 13px !important;
    padding: 5px 12px !important;
  }

  .studio-personalizer-root .studio-personalizer-close {
    width: 36px !important;
    height: 36px !important;
    border-radius: 999px !important;
    background: #f8fafc !important;
    border: 1px solid #e2e8f0 !important;
  }

  .studio-personalizer-root .studio-mobile-flow {
    display: block !important;
    flex-shrink: 0 !important;
    padding: 8px 12px 10px !important;
    background: #ffffff !important;
    border-bottom: 1px solid #e5e7eb !important;
  }

  .studio-personalizer-root .studio-mobile-flow-summary {
    display: flex !important;
    align-items: baseline !important;
    justify-content: space-between !important;
    gap: 10px !important;
    margin-bottom: 8px !important;
  }

  .studio-personalizer-root .studio-mobile-flow-kicker {
    color: #0f172a !important;
    font-size: 12px !important;
    font-weight: 900 !important;
  }

  .studio-personalizer-root .studio-mobile-flow-current {
    color: #64748b !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    line-height: 1.25 !important;
    text-align: right !important;
  }

  .studio-personalizer-root .studio-mobile-flow-nav {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 6px !important;
  }

  .studio-personalizer-root .studio-mobile-flow-step {
    min-width: 0 !important;
    min-height: 44px !important;
    padding: 6px 4px !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 10px !important;
    background: #f8fafc !important;
    color: #64748b !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 4px !important;
    touch-action: manipulation !important;
  }

  .studio-personalizer-root .studio-mobile-flow-step[aria-disabled="true"] {
    opacity: 0.5 !important;
  }

  .studio-personalizer-root .studio-mobile-flow-step.is-active {
    color: #0f172a !important;
    background: #ffffff !important;
    border-color: #2563eb !important;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.11) !important;
  }

  .studio-personalizer-root .studio-mobile-flow-step.is-done {
    color: #0f766e !important;
    border-color: #99f6e4 !important;
    background: #f0fdfa !important;
  }

  .studio-personalizer-root .studio-mobile-flow-step.is-active .studio-mobile-flow-dot {
    background: #2563eb !important;
    color: #ffffff !important;
  }

  .studio-personalizer-root .studio-mobile-flow-step.is-done .studio-mobile-flow-dot {
    background: #0f766e !important;
    color: #ffffff !important;
  }

  .studio-personalizer-root .studio-mobile-flow-dot {
    width: 18px !important;
    height: 18px !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #e2e8f0 !important;
    color: #475569 !important;
    font-size: 10px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
  }

  .studio-personalizer-root .studio-mobile-flow-label {
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    font-size: 10px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
  }

  .studio-personalizer-root .studio-personalizer-layout {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    height: auto !important;
    grid-template-rows: minmax(300px, 52dvh) minmax(0, 1fr) !important;
  }

  .studio-personalizer-root .studio-personalizer-preview-column {
    padding: 8px 12px 10px !important;
  }

  .studio-personalizer-root .studio-mobile-preview-tools {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 10px !important;
    flex-shrink: 0 !important;
    margin-bottom: 6px !important;
  }

  .studio-personalizer-root .studio-mobile-preview-copy {
    display: flex !important;
    min-width: 0 !important;
    flex-direction: column !important;
    gap: 1px !important;
  }

  .studio-personalizer-root .studio-mobile-preview-title {
    color: #0f172a !important;
    font-size: 12px !important;
    font-weight: 900 !important;
  }

  .studio-personalizer-root .studio-mobile-preview-meta {
    max-width: 58vw !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    color: #64748b !important;
    font-size: 11px !important;
    font-weight: 700 !important;
  }

  .studio-personalizer-root .studio-mobile-preview-toggle {
    flex-shrink: 0 !important;
    min-height: 32px !important;
    padding: 0 10px !important;
    border-radius: 999px !important;
    border: 1px solid #cbd5e1 !important;
    background: #ffffff !important;
    color: #0f172a !important;
    font-size: 11px !important;
    font-weight: 900 !important;
    touch-action: manipulation !important;
  }

  .studio-personalizer-root.sp-preview-expanded .studio-personalizer-layout {
    grid-template-rows: minmax(380px, 66dvh) minmax(0, 1fr) !important;
  }

  .studio-personalizer-root.sp-preview-expanded .studio-personalizer-editor-column {
    min-height: 0 !important;
  }

  .studio-personalizer-root.sp-preview-expanded .studio-order-section {
    display: none !important;
  }

  .studio-personalizer-root .studio-mobile-view-tabs {
    padding: 0 0 7px !important;
    gap: 8px !important;
  }

  .studio-personalizer-root .studio-mobile-view-tab {
    min-height: 34px !important;
    padding: 7px 12px !important;
    border-radius: 10px !important;
    background: #ffffff !important;
    box-shadow: 0 2px 8px rgba(15, 23, 42, 0.05) !important;
  }

  .studio-personalizer-root .studio-mobile-view-tab.is-active {
    background: #0f172a !important;
    border-color: #0f172a !important;
    color: #ffffff !important;
  }

  .studio-personalizer-root .studio-preview-scroll-area {
    border-radius: 18px !important;
    background: #ffffff !important;
    overflow: auto !important;
  }

  .studio-personalizer-root .studio-personalizer-preview-box {
    min-height: 0 !important;
    border: 1px solid #e2e8f0 !important;
  }

  .studio-personalizer-root .studio-preview-toolbar {
    margin: 7px 0 0 !important;
    padding: 7px 9px !important;
  }

  .studio-personalizer-root .studio-personalizer-editor-column {
    min-height: 0 !important;
    overflow: auto !important;
  }

  .studio-personalizer-root .studio-editor-body::before {
    margin-top: 7px !important;
  }

  .studio-personalizer-root .studio-editor-main {
    padding: 7px 12px calc(12px + env(safe-area-inset-bottom)) !important;
  }

  .studio-personalizer-root .studio-type-cards {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
    background: #f1f5f9 !important;
  }

  .studio-personalizer-root .studio-type-card {
    min-height: 54px !important;
  }

  .studio-personalizer-root .studio-mobile-continue-btn {
    position: sticky !important;
    bottom: calc(8px + env(safe-area-inset-bottom)) !important;
    z-index: 4 !important;
    min-height: 52px !important;
    margin-top: 10px !important;
    border-radius: 14px !important;
  }

  @media (max-width: 380px) {
    .studio-personalizer-root .studio-mobile-flow-current {
      display: none !important;
    }
    .studio-personalizer-root .studio-personalizer-layout {
      grid-template-rows: minmax(260px, 48dvh) minmax(0, 1fr) !important;
    }
    .studio-personalizer-root.sp-preview-expanded .studio-personalizer-layout {
      grid-template-rows: minmax(330px, 62dvh) minmax(0, 1fr) !important;
    }
  }
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE — Écran de bienvenue (avant que le flow démarre)
   ═══════════════════════════════════════════════════════════════ */
.studio-mobile-welcome { display: none; }

@media (max-width: 1024px) {
  .studio-mobile-welcome {
    display: flex !important;
    position: absolute !important;
    inset: 0 !important;
    z-index: 30 !important;
    background: #ffffff !important;
    border-radius: 22px 22px 0 0 !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 28px 24px calc(28px + env(safe-area-inset-bottom)) !important;
  }

  .studio-mobile-welcome-body {
    width: 100% !important;
    max-width: 360px !important;
    text-align: center !important;
  }

  .studio-mobile-welcome-title {
    margin: 0 0 22px !important;
    font-size: 20px !important;
    font-weight: 900 !important;
    letter-spacing: -0.02em !important;
    color: #0f172a !important;
    line-height: 1.2 !important;
  }

  .studio-mobile-welcome-steps {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: center !important;
    gap: 8px !important;
    margin-bottom: 30px !important;
  }

  .studio-mobile-welcome-step-item {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 7px !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    color: #374151 !important;
  }

  .studio-mobile-welcome-step-num {
    width: 34px !important;
    height: 34px !important;
    border-radius: 50% !important;
    background: linear-gradient(180deg, #2563eb 0%, #1d4ed8 100%) !important;
    color: #ffffff !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 15px !important;
    font-weight: 800 !important;
    box-shadow: 0 4px 12px rgba(29, 78, 216, 0.3) !important;
  }

  .studio-mobile-welcome-sep {
    color: #cbd5e1 !important;
    font-size: 22px !important;
    font-weight: 400 !important;
    padding-top: 6px !important;
  }

  .studio-mobile-welcome-cta {
    width: 100% !important;
    min-height: 56px !important;
    border-radius: 16px !important;
    background: linear-gradient(180deg, #2563eb 0%, #1d4ed8 100%) !important;
    color: #ffffff !important;
    font-size: 16px !important;
    font-weight: 800 !important;
    border: none !important;
    cursor: pointer !important;
    touch-action: manipulation !important;
    box-shadow: 0 10px 28px rgba(29, 78, 216, 0.35) !important;
    letter-spacing: 0.005em !important;
    transition: transform 0.12s, box-shadow 0.12s !important;
  }

  .studio-mobile-welcome-cta:active {
    transform: scale(0.97) !important;
    box-shadow: 0 6px 16px rgba(29, 78, 216, 0.3) !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE ≤ 1024px — barre flottante toujours cachée
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
  .studio-personalizer-root .studio-image-floating-actions {
    display: none !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   DESKTOP ≥ 1025px — éléments mobile-only toujours cachés
   ═══════════════════════════════════════════════════════════════ */
@media (min-width: 1025px) {
  .studio-mobile-view-tabs,
  .studio-mobile-continue-btn,
  .studio-mobile-sizes-recap,
  .studio-mobile-flow,
  .studio-mobile-preview-tools {
    display: none !important;
  }
}
