/*************************************************
 * FORMAVIS CHECKOUT · Layout, Steps, Summary,
 * Kundentyp, Payment & Select2
 *************************************************/

/* ============================================
   1) GRUNDLAYOUT CHECKOUT-FORM
   ============================================ */

.formavis-checkout-form {
  max-width: 1200px;
  margin: 2.5rem auto 3rem;
  padding: 0 1.5rem;
}

.formavis-checkout-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr);
  gap: 2rem;
  align-items: flex-start;
}

.formavis-checkout-col {
  min-width: 0;
}

/* Linke Spalte – Kundendaten / Rechnungs- & Lieferadresse */
.formavis-checkout-details {
  background: var(--fv-bg-elevated);
  border-radius: 18px;
  border: 1px solid var(--fv-border);
  padding: 1.8rem 1.6rem 1.9rem;
  box-shadow:
    0 22px 44px rgba(0, 0, 0, 0.75),
    0 0 0 1px rgba(15, 23, 42, 0.85);
}

/* Rechte Spalte – Bestellübersicht */
.formavis-checkout-review {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

/* Mobil: untereinander */
@media (max-width: 960px) {
  .formavis-checkout-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .formavis-checkout-form {
    padding: 0 1rem;
  }
}

/* ============================================
   2) KUNDENTYP & UST-ID (SPEZIALFELDER)
   ============================================ */

/* Kundentyp-Block */
.formavis-kundentyp#billing_customer_type_field,
.woocommerce-address-fields .formavis-kundentyp {
  border: 1px solid var(--fv-border);
  border-radius: 14px;
  padding: 1rem 1.2rem 0.4rem;
  margin-bottom: 1rem;
  background: var(--fv-bg-soft);
}

.formavis-kundentyp#billing_customer_type_field > label,
.woocommerce-address-fields .formavis-kundentyp > label {
  display: block;
  font-weight: 600;
  margin-bottom: 0.4rem;
  color: var(--fv-text);
}

.formavis-kundentyp .woocommerce-input-wrapper label {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  margin-right: 1.5rem;
  font-weight: 400;
  color: var(--fv-text-soft);
  font-size: 0.92rem;
}

/* USt-ID im Verbund mit Kundentyp */
.formavis-vat-id#billing_vat_id_field,
.woocommerce-address-fields .formavis-vat-id {
  margin-top: -0.4rem;
  margin-bottom: 1.5rem;
}

/* ============================================
   3) CHECKOUT-TYPO, INPUTS & LESBARKEIT
   ============================================ */

/* Labels, Tabellen, Hinweistexte im Checkout */
.woocommerce form .form-row label,
.woocommerce-checkout-review-order-table th,
.woocommerce-checkout-review-order-table td,
.woocommerce table.shop_table td,
.woocommerce table.shop_table th,
.woocommerce-checkout h3,
#order_review_heading,
.woocommerce-checkout #order_review,
.woocommerce-info,
.woocommerce-error,
.woocommerce-message {
  color: var(--fv-text) !important;
}

/* Checkbox-/Radio-Texte */
.formavis-radio,
.woocommerce form .form-row .input-radio + label,
.woocommerce form .form-row .input-checkbox + label {
  color: var(--fv-text) !important;
}

/* Placeholder */
.woocommerce-input-wrapper input::placeholder,
.woocommerce-input-wrapper textarea::placeholder {
  color: var(--fv-muted) !important;
  opacity: 1 !important;
}

/* Checkout-Box für Gruppen (optional verwendbar) */
.formavis-checkout-box {
  background: var(--fv-bg-soft);
  padding: 20px;
  border: 1px solid var(--fv-border);
  border-radius: 14px;
  margin-bottom: 25px;
}

.formavis-box-title {
  margin: 0 0 10px;
  font-size: 1.2rem;
  color: var(--fv-text);
}

/* ============================================
   4) RECHTE SPALTE · BESTELLÜBERSICHT & PAYMENT
   ============================================ */

/* Bestellübersicht-Card */
.woocommerce-checkout-review-order,
#order_review {
  background: var(--fv-bg-soft) !important;
  border: 1px solid var(--fv-border) !important;
  border-radius: 14px !important;
  padding: 20px 25px !important;
  color: var(--fv-text) !important;
}

#order_review_heading {
  text-align: left !important;
  font-size: 1.4rem !important;
  font-weight: 600 !important;
  margin-bottom: 15px !important;
  color: var(--fv-text) !important;
}

/* Tabelle in der rechten Spalte */
.woocommerce-checkout-review-order-table th,
.woocommerce-checkout-review-order-table td {
  color: var(--fv-text) !important;
  border-color: var(--fv-border-soft) !important;
  padding: 10px 0 !important;
}

.woocommerce-checkout-review-order-table .product-name {
  font-weight: 500;
  color: var(--fv-text) !important;
}

.woocommerce-checkout-review-order-table .cart-subtotal td,
.woocommerce-checkout-review-order-table .order-total td {
  font-weight: 700 !important;
  color: var(--fv-text) !important;
}

/* Payment-Bereich */
.woocommerce-checkout #payment,
.woocommerce-checkout #payment p,
.woocommerce-checkout #payment span,
.woocommerce-checkout #payment label,
.woocommerce-checkout #payment small,
.woocommerce-checkout #payment .payment_box,
.woocommerce-checkout #payment .payment_box p {
  color: var(--fv-text) !important;
}

.woocommerce-checkout #payment a {
  color: var(--fv-primary) !important;
}

.woocommerce-checkout .woocommerce-form__label,
.woocommerce-checkout .woocommerce-form__label span,
.woocommerce-checkout .woocommerce-form__label-for-checkbox,
.woocommerce-checkout .woocommerce-form__label-for-checkbox span,
.woocommerce-checkout .form-row label.checkbox {
  color: var(--fv-text) !important;
}

.woocommerce-checkout .form-row .woocommerce-input-wrapper span,
.woocommerce-checkout .form-row .woocommerce-input-wrapper p {
  color: var(--fv-text) !important;
}

/* Versandoptionen lesbar */
.woocommerce-checkout .woocommerce-shipping-methods label,
.woocommerce-checkout .woocommerce-shipping-methods label span,
.woocommerce-checkout .woocommerce-shipping-methods li,
.woocommerce-checkout .woocommerce-shipping-methods div,
.woocommerce-checkout #shipping_method li label {
  color: var(--fv-text) !important;
}

.woocommerce-checkout .woocommerce-shipping-methods label .woocommerce-Price-amount,
.woocommerce-checkout #shipping_method li label .woocommerce-Price-amount {
  color: var(--fv-text) !important;
}

.woocommerce-checkout .woocommerce-shipping-destination,
.woocommerce-checkout .woocommerce-shipping-totals td,
.woocommerce-checkout .woocommerce-shipping-totals th {
  color: var(--fv-text) !important;
}

/* Abstand zum Payment-Block in der rechten Spalte */
.woocommerce-checkout #order_review {
  margin-top: 0 !important;
}

/* ============================================
   5) MULTI-STEP CHECKOUT-SHELL
   (CSS ist bereit, auch wenn Steps im PHP
    später ergänzt werden)
   ============================================ */

/* Steps-Container (optional, wenn du Schritte nutzt) */
.formavis-checkout-steps {
  margin-bottom: 2rem;
}

.formavis-checkout-step {
  display: none;
  background: var(--fv-bg-elevated, #0B0C0D);
  border-radius: 16px;
  border: 1px solid var(--fv-border, #2A2D30);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.55);
  padding: 1.5rem 1.6rem;
  margin-bottom: 1.2rem;
}

.formavis-checkout-step.is-active {
  display: block;
}

.formavis-step-title {
  margin: 0 0 0.75rem;
  font-size: 1.1rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--fv-muted, #9CA3AF);
}

.formavis-step-inner {
  display: block;
}

/* Navigation zwischen Steps */
.formavis-step-nav {
  display: flex;
  justify-content: space-between;
  gap: 0.75rem;
  margin-top: 1rem;
}

.formavis-step-nav .formavis-step-btn {
  border-radius: 999px;
  padding: 0.45rem 1.2rem;
  border: 1px solid var(--fv-border-soft, #202225);
  background: var(--fv-bg-soft, #121314);
  color: var(--fv-text, #E5E7EB);
  font-size: 0.9rem;
  cursor: pointer;
  transition:
    border-color 0.18s ease,
    background 0.18s ease,
    transform 0.12s ease;
}

.formavis-step-nav .formavis-step-btn:hover {
  border-color: var(--fv-primary, #2C9C7C);
  background: #111315;
  transform: translateY(-1px);
}

@media (max-width: 600px) {
  .formavis-step-nav {
    flex-direction: column;
    align-items: stretch;
  }
  .formavis-step-nav .formavis-step-btn {
    width: 100%;
    text-align: center;
  }
}

/* ============================================
   6) STEP 5 / ÜBERSICHT · FORMAVIS SUMMARY
   (passt exakt zu deiner review-order.php)
   ============================================ */

.fv-step-panel.formavis-summary-panel {
  max-width: 1200px !important;
  margin: 0 auto !important;
  width: 100% !important;
  padding: 0 20px;
}

/* Gesamt-Wrapper */
.formavis-summary {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}

/* Adressen nebeneinander */
.formavis-summary__addresses {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
}

/* Adressboxen */
.formavis-summary__address-box {
  flex: 1 1 calc(50% - 1.5rem);
  background: var(--fv-bg-elevated);
  color: var(--fv-text);
  padding: 1.5rem;
  border-radius: 16px;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.4);
  font-size: 0.95rem;
}

/* Versand-Hinweis */
.formavis-summary__shipping-note {
  background: var(--fv-bg-soft);
  color: var(--fv-text);
  padding: 1.2rem 1.5rem;
  border-radius: 12px;
  font-size: 0.9rem;
}

/* Tabellen-Wrapper */
.formavis-summary__table-wrapper {
  background: var(--fv-bg-soft);
  color: var(--fv-text);
  padding: 1.5rem;
  border-radius: 16px;
  margin-top: 1.5rem;
}

/* Tabelle */
.formavis-summary__table {
  width: 100%;
  border-collapse: collapse;
}

.formavis-summary__table th,
.formavis-summary__table td {
  padding: 0.75rem 0.5rem;
  border-bottom: 1px solid var(--fv-border-soft);
  font-size: 0.9rem;
}

.formavis-summary__table th {
  text-align: left;
  font-weight: 600;
}

/* Artikelbild in Tabelle */
.formavis-summary__table .column-image img {
  max-width: 60px;
  height: auto;
}

/* Abstand zwischen den Boxen im Summary-Panel */
.formavis-summary > div {
  margin-bottom: 2rem;
}

@media (max-width: 768px) {
  .formavis-summary__address-box {
    flex: 1 1 100%;
  }

  .formavis-summary__table th,
  .formavis-summary__table td {
    font-size: 0.8rem;
  }
}

/* ============================================
   7) SELECT2 · DARK CI IM CHECKOUT
   ============================================ */

/* Basis Select2-Look im Checkout */
.woocommerce form .form-row select,
.select2-container--default .select2-selection--single,
.select2-container--default .select2-selection--single .select2-selection__rendered,
.select2-container--default .select2-results__option,
.select2-dropdown,
.select2-container--default .select2-selection--single .select2-selection__arrow b {
  background-color: var(--fv-bg-elevated) !important;
  border: 1px solid var(--fv-border) !important;
  color: var(--fv-text) !important;
}

/* Dropdown-Layer */
.select2-container--open .select2-dropdown {
  background-color: var(--fv-bg-elevated) !important;
  border-color: var(--fv-border) !important;
}

/* Hover/Highlight */
.select2-results__option--highlighted {
  background-color: var(--fv-primary-soft) !important;
  color: var(--fv-text) !important;
}

.select2-results__option--selected {
  background-color: var(--fv-primary) !important;
  color: white !important;
}

/* Placeholder */
.select2-selection__placeholder {
  color: var(--fv-muted) !important;
}

/* Pfeil im Select2 */
.select2-container--default .select2-selection--single .select2-selection__arrow b {
  border-color: var(--fv-text) transparent transparent transparent !important;
}

/* Höhe & Radius */
.select2-container--default .select2-selection--single {
  height: 48px !important;
  padding: 8px 12px !important;
  border-radius: 12px !important;
}

.select2-selection__rendered {
  line-height: 40px !important;
}

/* ============================================
   Ende · FORMAVIS CHECKOUT
   ============================================ */