/* --- 1. VARIABLES GLOBALES --- */
:root {
  /* Couleurs */
  --toppia-bg: #F8F0D8;
  --toppia-primary: hsl(345 100% 16%); /* Bordeaux */
  --toppia-accent: hsl(348 72% 68%);    /* Rose */
  --toppia-border: hsl(345 30% 75%);
  --toppia-border-strong: #D2ACB6;
  
  /* États */
  --toppia-accent-soft: hsl(348 72% 68% / 10%);
  --toppia-accent-soft-hover: hsl(348 72% 68% / 20%);
  
  /* Structure */
  --toppia-card-radius: 2rem;
  --toppia-opt-radius: .75rem;
  --toppia-pill-radius: 999px;
  --toppia-gap: 18px;
  --toppia-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);
  --toppia-font: "Gliker", sans-serif;
}

/* --- 2. UTILITAIRES & HACKS WOOCOMMERCE --- */
/* Masquer la table de variations native proprement */
.toppia-variations table.variations {
  position: absolute !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  height: 1px !important;
  width: 1px !important;
  margin: -1px !important;
  padding: 0 !important;
  border: 0 !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Reset marges Elementor sur bouton ATC */
:is(.elementor-widget-woocommerce-product-add-to-cart, .woocommerce div.product .elementor-widget-woocommerce-product-add-to-cart) 
form.cart button:where(:not(:first-child)) {
  margin-inline-start: 0 !important;
}

.woocommerce-variation { display: none !important; }

/* --- 3. COMPOSANT : CARTE DE VARIATION --- */
.toppia-variation-card {
  background: var(--toppia-bg);
  border: 1px solid var(--toppia-border-strong);
  border-radius: var(--toppia-card-radius);
  padding: 1.5rem;
}

.toppia-options-wrap { margin-bottom: var(--toppia-gap); }

/* Grille des boutons (12 pièces, 24 pièces...) */
.toppia-btns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.toppia-opt {
  border: 2px solid var(--toppia-border) !important;
  border-radius: var(--toppia-opt-radius) !important;
  padding: 1rem !important;
  background: transparent;
  font-weight: 600 !important;
  font-size: 1rem;
  color: var(--toppia-primary) !important;
  cursor: pointer;
  transition: all .18s ease;
}

.toppia-opt:hover { border-color: var(--toppia-accent) !important; background: transparent;}

.toppia-opt.is-active {
  background: var(--toppia-accent-soft) !important;
  border-color: var(--toppia-accent) !important;
  color: var(--toppia-accent) !important;
}

/* --- 4. PRIX ET QUANTITÉ --- */
.toppia-price-zone {
  display: flex;
  align-items: baseline;
  gap: 10px;
  color: var(--toppia-primary);
  margin-top: 10px;
}

.toppia-price-zone .toppia-price {
  font-family: var(--toppia-font);
  font-size: 1.875rem !important;
  font-weight: 700 !important;
  color: var(--toppia-primary) !important;
}

.toppia-qty-row {
  display: flex;
  align-items: center;
  gap: var(--toppia-gap);
  margin: 22px 0;
}

.toppia-qty {
  display: flex;
  align-items: center;
  border: 2px solid var(--toppia-border);
  border-radius: var(--toppia-pill-radius);
  padding: .25rem;
}

.toppia-qty-btn {
  width: 30px;
  height: 30px;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  border: none !important;
  background: transparent !important;
  font-size: 18px !important;
  font-weight: 900;
  color: var(--toppia-primary);
  cursor: pointer;
}

.toppia-qty-btn:hover {
  background: var(--toppia-accent-soft-hover) !important;
  border-radius: var(--toppia-pill-radius) !important;
}

.toppia-qty input.qty {
  width: 50px;
  border: 0;
  background: transparent;
  font-weight: 800;
  padding: 0.5rem 0;
  text-align: center;
  color: var(--toppia-primary) !important;
  -moz-appearance: textfield;
}

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

/* --- 5. BOUTON AJOUTER AU PANIER --- */
.toppia-atc-container { margin-top: 22px; }

.toppia-atc-btn {
  width: 100%;
  border-radius: var(--toppia-pill-radius) !important;
  padding: 22px 24px !important;
  background: var(--toppia-accent) !important;
  border: 0;
  font-size: 1.5rem;
  font-weight: 900;
  color: #fff;
  box-shadow: var(--toppia-shadow) !important;
  transition: transform .3s ease;
}

.toppia-atc-btn:not(:disabled):hover { transform: scale(1.03) !important; }

/* --- 6. GROUPES DE TAXONOMIES (TOPPINGS, NAPPAGES) --- */
.toppia-taxo-group {
  background: var(--toppia-bg);
  border: 1px solid var(--toppia-border);
  border-radius: var(--toppia-card-radius);
  padding: 1.5rem;
  margin-top: 20px;
}

.toppia-taxo-header {
  display: flex;
  justify-content: space-between;
}

.toppia-taxo-title-wrap h3 {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--toppia-primary);
}

.toppia-taxo-status {
  color: var(--toppia-accent);
  font-size: 0.9rem;
  margin-bottom: 15px;
  font-weight: 600;
}

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

/* Custom Checkbox */
.toppia-option-item {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  font-weight: 500;
  color: var(--toppia-primary);
}

.toppia-option-item input { display: none; }

.toppia-custom-check {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  border: 2px solid var(--toppia-primary);
  border-radius: 50%;
  position: relative;
  transition: all 0.2s;
}

.toppia-option-item input:checked + .toppia-custom-check {
  background: var(--toppia-primary);
}

.toppia-option-item input:checked + .toppia-custom-check::after {
  content: "✓";
  color: white;
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  font-size: 11px;
}

/* --- 7. MODAL PANIER --- */
.toppia-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 999999;
}

.toppia-modal.is-open { display: block; }

.toppia-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgb(0 0 0 / 0.45);
}

.toppia-modal__panel {
  position: fixed;
  right: 24px;
  top: 24px;
  width: min(420px, calc(100vw - 48px));
  background: #fff;
  border-radius: 20px;
  padding: 20px;
  box-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.12);
}

.toppia-modal__close {
  position: absolute;
  right: 12px; top: 10px;
  border: 0; background: transparent !important;
  font-size: 24px; color: var(--toppia-primary) !important;
  cursor: pointer;
}

.toppia-modal__title { font-weight: 800; font-size: 1.1rem; margin-bottom: 10px; }
.toppia-modal__name { font-weight: 800; color: var(--toppia-primary); }
.toppia-modal__meta { font-weight: 600; opacity: 0.7; margin-bottom: 15px; font-size: 0.9rem; }

.toppia-modal__actions { display: flex; gap: 10px; }

.toppia-modal__btn {
  flex: 1;
  text-align: center;
  padding: 12px;
  border-radius: var(--toppia-pill-radius);
  font-weight: 800;
  text-decoration: none;
  transition: opacity 0.2s;
}

.toppia-modal__btn--ghost {
  color: var(--toppia-primary);
  border: 2px solid hsl(345 100% 16% / 0.2);
}

.toppia-modal__btn--primary {
  background: var(--toppia-accent);
  color: #fff !important;
}

.toppia-option-label::after {
    content: attr(data-supplement-label);
    font-size: 0.8em;
    color: var(--toppia-accent);
    margin-left: 5px;
    font-weight: 800;
}

.toppia-option-label {
    line-height: 1.6; 
}

/* --- 8. RESPONSIVE --- */
@media (max-width: 768px) {
  .toppia-modal__panel {
    top: auto;
    bottom: 24px;
    right: 50%;
    transform: translateX(50%);
    width: calc(100vw - 32px);
  }

  .toppia-taxo-grid { grid-template-columns: 1fr; }

}