/* ============================================================
   Box Apéro Personnalisée — Frontend styles
   Typo : Fraunces (titres) + Inter (texte)
   Spécificité renforcée pour résister à Hello Elementor
   ============================================================ */

/* Variables */
#bap-builder {
  --bap-bg:         #F5EFE2;
  --bap-card-bg:    rgb(253, 250, 241);
  --bap-tag-bg:     rgb(248, 241, 227);
  --bap-tag-hover:  rgb(240, 231, 214);
  --bap-green:      #2E4D1E;
  --bap-green-dark: #1E3412;
  --bap-text:       #1C1C1C;
  --bap-muted:      #6B6B6B;
  --bap-border:     rgb(218, 216, 201);
  --bap-radius:     1rem;
  --bap-radius-pill: 2rem;
  --bap-shadow:     0 2px 12px rgba(0,0,0,.07);
}

/* -------------------------
   Layout global
   ------------------------- */
#bap-builder {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 2rem;
  align-items: start;
  padding: 2rem 0;
  font-family: 'Inter', sans-serif !important;
  color: var(--bap-text);
  box-sizing: border-box;
}

#bap-builder *,
#bap-builder *::before,
#bap-builder *::after {
  box-sizing: border-box;
}

@media (max-width: 900px) {
  #bap-builder {
    grid-template-columns: 1fr;
  }
  #bap-builder .bap-summary-column {
    order: -1;
  }
}

/* -------------------------
   Header
   ------------------------- */
#bap-builder .bap-header {
  margin-bottom: 1.5rem;
}

#bap-builder .bap-header-tag {
  display: inline-block;
  font-family: 'Inter', sans-serif;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--bap-green);
  margin-bottom: .5rem;
}

#bap-builder .bap-header-title {
  font-family: 'Fraunces', serif !important;
  font-size: 2rem !important;
  font-weight: 700 !important;
  margin: 0 0 .6rem !important;
  line-height: 1.2 !important;
  color: var(--bap-text) !important;
}

#bap-builder .bap-header-desc {
  font-family: 'Inter', sans-serif;
  color: var(--bap-muted);
  margin: 0;
  font-size: .95rem;
  max-width: 480px;
}

/* -------------------------
   Step cards
   ------------------------- */
#bap-builder .bap-step-card {
  background: var(--bap-card-bg);
  border-radius: var(--bap-radius);
  box-shadow: var(--bap-shadow);
  padding: 1.4rem 1.6rem;
  margin-bottom: 1rem;
  border: 1px solid var(--bap-border);
}

#bap-builder .bap-step-header {
  display: flex;
  align-items: center;
  gap: .75rem;
  margin-bottom: 1.1rem;
}

#bap-builder .bap-step-number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  min-width: 32px;
  border-radius: 50%;
  background: var(--bap-green);
  color: #fff;
  font-family: 'Inter', sans-serif;
  font-size: .85rem;
  font-weight: 700;
  line-height: 1;
}

#bap-builder .bap-step-title {
  font-family: 'Fraunces', serif !important;
  font-size: 1.15rem !important;
  font-weight: 600 !important;
  margin: 0 !important;
  color: var(--bap-text) !important;
}

/* -------------------------
   Tag buttons (pills)
   ------------------------- */
#bap-builder .bap-step-options {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}

/* Reset total des boutons pour ne pas hériter d'Elementor/Hello */
#bap-builder .bap-tag {
  display: inline-flex !important;
  align-items: center !important;
  padding: .45rem 1.1rem !important;
  border-radius: var(--bap-radius-pill) !important;
  border: 1px solid var(--bap-border) !important;
  background: rgb(248, 241, 227) !important;
  color: var(--bap-text) !important;
  font-family: 'Inter', sans-serif !important;
  font-size: .88rem !important;
  font-weight: 400 !important;
  line-height: 1.4 !important;
  cursor: pointer !important;
  transition: border-color .15s ease, background .15s ease, color .15s ease !important;
  white-space: nowrap !important;
  box-shadow: none !important;
  text-shadow: none !important;
  text-decoration: none !important;
  outline: none !important;
  letter-spacing: 0 !important;
}

#bap-builder .bap-tag:hover {
  border-color: var(--bap-border) !important;
  color: var(--bap-text) !important;
  background: rgb(240, 231, 214) !important;
}

#bap-builder .bap-tag:focus {
  outline: 2px solid var(--bap-green) !important;
  outline-offset: 2px !important;
}

#bap-builder .bap-tag.bap-selected {
  background: var(--bap-green) !important;
  border-color: var(--bap-green) !important;
  color: #fff !important;
}

#bap-builder .bap-tag.bap-selected:hover {
  background: var(--bap-green-dark) !important;
  border-color: var(--bap-green-dark) !important;
}

/* -------------------------
   Colonne récapitulatif (sticky)
   ------------------------- */
#bap-builder .bap-summary-column {
  position: sticky;
  top: 2rem;
}

#bap-builder .bap-summary-card {
  background: var(--bap-card-bg);
  border-radius: var(--bap-radius);
  box-shadow: var(--bap-shadow);
  padding: 1.6rem;
  border: 1px solid var(--bap-border);
}

#bap-builder .bap-summary-title {
  font-family: 'Fraunces', serif !important;
  font-size: 1.25rem !important;
  font-weight: 700 !important;
  margin: 0 0 1.1rem !important;
  color: var(--bap-text) !important;
}

#bap-builder .bap-summary-size {
  margin-bottom: .8rem;
}

#bap-builder .bap-summary-size-label {
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  font-size: .95rem;
  color: var(--bap-text);
}

#bap-builder .bap-summary-items {
  min-height: 3rem;
  margin-bottom: 1.2rem;
}

#bap-builder .bap-no-selection {
  font-family: 'Inter', sans-serif;
  color: var(--bap-muted);
  font-size: .88rem;
  margin: 0;
}

#bap-builder .bap-summary-list {
  list-style: disc;
  padding-left: 1.2rem;
  margin: 0;
}

#bap-builder .bap-summary-item {
  font-family: 'Inter', sans-serif;
  font-size: .88rem;
  color: var(--bap-text);
  margin-bottom: .3rem;
}

#bap-builder .bap-ing-price {
  font-size: .8rem;
  color: var(--bap-green);
  font-weight: 600;
  margin-left: .3rem;
}

#bap-builder .bap-summary-total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 0;
  border-top: 1px solid var(--bap-border);
  border-bottom: 1px solid var(--bap-border);
  margin-bottom: 1.1rem;
}

#bap-builder .bap-summary-total span:first-child {
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  font-size: .95rem;
  color: var(--bap-text);
}

#bap-builder .bap-total-price {
  font-family: 'Fraunces', serif !important;
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  color: var(--bap-text) !important;
}

/* -------------------------
   Bouton Ajouter au panier
   ------------------------- */
#bap-builder .bap-add-to-cart-btn {
  display: block !important;
  width: 100% !important;
  padding: .9rem 1rem !important;
  background: var(--bap-green) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--bap-radius-pill) !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  line-height: 1.4 !important;
  cursor: pointer !important;
  transition: background .15s ease !important;
  text-align: center !important;
  box-shadow: none !important;
  text-shadow: none !important;
  letter-spacing: 0 !important;
}

#bap-builder .bap-add-to-cart-btn:hover:not(:disabled) {
  background: var(--bap-green-dark) !important;
  color: #fff !important;
}

#bap-builder .bap-add-to-cart-btn:disabled,
#bap-builder .bap-add-to-cart-btn.bap-btn-disabled {
  opacity: .4 !important;
  cursor: not-allowed !important;
}

/* -------------------------
   Message panier
   ------------------------- */
#bap-builder .bap-cart-message {
  font-family: 'Inter', sans-serif;
  margin-top: .75rem;
  font-size: .88rem;
  text-align: center;
  min-height: 1.2em;
}

#bap-builder .bap-msg-success {
  color: var(--bap-green);
}

#bap-builder .bap-msg-success a {
  color: var(--bap-green);
  font-weight: 600;
  text-decoration: underline;
}

#bap-builder .bap-msg-error {
  color: #c0392b;
}
