/* ==========================================================================
   KONTAKT PAGE
   ========================================================================== */
.page-kontakt {
  background: var(--brand-dark);
  min-height: 100vh;
  padding: 10rem 0 5rem;
}

.kontakt-header {
  margin-bottom: 4rem;
}

.kontakt-title {
  font-size: clamp(2.5rem, 6vw, 5rem);
  font-weight: 700;
  color: var(--color-white);
  margin-bottom: 1.5rem;
  line-height: 1.1;
  letter-spacing: -0.025em;
}

.kontakt-title span {
  color: rgba(255,255,255,0.9);
}

.kontakt-subtitle {
  font-size: 1rem;
  color: var(--color-gray-400);
  max-width: 40rem;
  line-height: 1.7;
}

.kontakt-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  align-items: start;
  margin-bottom: 6rem;
}

@media (min-width: 1024px) {
  .kontakt-grid {
    grid-template-columns: 1fr 2fr;
  }
}

.kontakt-sidebar {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.kontakt-card {
  display: block;
  background: var(--brand-gray);
  border: 1px solid var(--color-white-5);
  border-radius: 1rem;
  padding: 1.5rem;
  text-decoration: none;
  transition: all var(--transition-fast);
}

.kontakt-card:hover {
  border-color: var(--color-white-20);
}

.kontakt-card-icon {
  width: 3rem;
  height: 3rem;
  background: var(--color-white-5);
  border-radius: 0.75rem;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.5rem;
  color: var(--color-white);
}

.kontakt-card-title {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--color-white);
  margin-bottom: 0.25rem;
}

.kontakt-card-text {
  font-size: 0.875rem;
  color: var(--color-gray-500);
}

.kontakt-hours {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-top: 1rem;
}

.kontakt-hours-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.875rem;
  color: var(--color-gray-500);
}

.kontakt-hours-time {
  color: var(--color-white);
  font-weight: 500;
}

/* Contact Form */
.kontakt-form-wrap {
  background: var(--brand-gray);
  border: 1px solid var(--color-white-5);
  border-radius: 1.5rem;
  padding: 2.5rem;
}

.kontakt-form-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 2.5rem;
  color: var(--brand-accent);
}

.kontakt-form-header h2 {
  font-size: 0.625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--color-white);
}

.kontakt-form {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.kontakt-field-group {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.kontakt-label {
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  font-weight: 700;
  color: var(--color-gray-500);
}

.kontakt-input {
  width: 100%;
  background: var(--brand-dark);
  border: 1px solid var(--color-white-10);
  border-radius: 0.75rem;
  padding: 1rem 1.25rem;
  color: var(--color-white);
  font-size: 1rem;
  outline: none;
  transition: all var(--transition-fast);
}

.kontakt-input:focus {
  border-color: var(--brand-accent);
  box-shadow: 0 0 0 1px rgba(209,209,219,0.3);
}

.kontakt-input::placeholder {
  color: var(--color-gray-600);
}

.kontakt-textarea {
  resize: vertical;
  min-height: 8rem;
}

.kontakt-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}

@media (min-width: 768px) {
  .kontakt-row {
    grid-template-columns: 1fr 1fr;
  }
}

.kontakt-quick-actions {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
}

@media (min-width: 768px) {
  .kontakt-quick-actions {
    grid-template-columns: 1fr 1fr;
  }
}

.kontakt-action-btn {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  text-align: left;
  padding: 1rem;
  border-radius: 0.75rem;
  border: 1px solid var(--color-white-10);
  background: var(--brand-dark);
  color: var(--color-white);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.kontakt-action-btn:hover {
  border-color: var(--color-white-30);
}

.kontakt-action-btn.is-selected {
  background: var(--brand-accent);
  border-color: var(--brand-accent);
  color: #000;
}

.kontakt-action-icon {
  margin-top: 0.125rem;
  color: var(--brand-accent);
}

.kontakt-action-btn.is-selected .kontakt-action-icon {
  color: #000;
}

.kontakt-action-text {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.kontakt-action-text strong {
  font-size: 0.875rem;
  font-weight: 700;
}

.kontakt-action-text span {
  font-size: 0.75rem;
  opacity: 0.6;
}

.kontakt-submit {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 1.25rem;
  font-size: 1rem;
  font-weight: 700;
  background: var(--color-white);
  color: #000;
  border: none;
  border-radius: 0.75rem;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.kontakt-submit:hover {
  background: #e5e7eb;
}

.kontakt-privacy {
  font-size: 0.625rem;
  color: var(--color-gray-600);
  text-align: center;
  line-height: 1.5;
}

.kontakt-privacy a {
  color: var(--color-gray-400);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.kontakt-privacy a:hover {
  color: var(--brand-accent);
}

.kontakt-success {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 5rem 2rem;
  text-align: center;
}

.kontakt-success-icon {
  width: 3.75rem;
  height: 3.75rem;
  border-radius: 50%;
  background: #22c55e;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  font-weight: 700;
  margin-bottom: 1.5rem;
}

.kontakt-success h3 {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-white);
  margin-bottom: 1rem;
}

.kontakt-success p {
  color: var(--color-gray-400);
  max-width: 24rem;
}

/* FAQ Section */
.kontakt-faq {
  border-top: 1px solid var(--color-white-5);
  padding-top: 7rem;
}

.kontakt-faq-header {
  text-align: center;
  margin-bottom: 3rem;
}

.kontakt-faq-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  background: rgba(209,209,219,0.1);
  color: var(--brand-accent);
  font-size: 1.25rem;
  font-weight: 700;
  margin-bottom: 1rem;
}

.kontakt-faq-header h2 {
  font-size: clamp(1.5rem, 3vw, 2.25rem);
  font-weight: 700;
  color: var(--color-white);
  margin-bottom: 0.5rem;
}

.kontakt-faq-header p {
  color: var(--color-gray-400);
}

.kontakt-faq-list {
  max-width: 48rem;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.kontakt-faq-item {
  border: 1px solid var(--color-white-5);
  border-radius: 0.75rem;
  transition: all 0.3s;
  overflow: hidden;
}

.kontakt-faq-item.is-open {
  background: var(--color-white-5);
  border-color: rgba(209,209,219,0.2);
}

.kontakt-faq-question {
  width: 100%;
  padding: 1.25rem 1.5rem;
  text-align: left;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  background: none;
  border: none;
  color: var(--color-white);
  font-size: 1.125rem;
  font-weight: 500;
  cursor: pointer;
}

.kontakt-faq-item.is-open .kontakt-faq-question {
  color: var(--brand-accent);
}

.kontakt-faq-chevron {
  flex-shrink: 0;
  color: var(--color-gray-500);
  transition: transform 0.3s;
}

.kontakt-faq-item.is-open .kontakt-faq-chevron {
  transform: rotate(180deg);
  color: var(--brand-accent);
}

.kontakt-faq-answer {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.3s;
}

.kontakt-faq-item.is-open .kontakt-faq-answer {
  grid-template-rows: 1fr;
}

.kontakt-faq-answer-inner {
  overflow: hidden;
  padding: 0 1.5rem;
  color: var(--color-gray-400);
  line-height: 1.7;
}

.kontakt-faq-item.is-open .kontakt-faq-answer-inner {
  padding-bottom: 1.5rem;
}

/* ==========================================================================
   PAGE: FF-WHEELS
   ========================================================================== */
.page-ff-wheels {
  background: var(--brand-dark);
  min-height: 100vh;
  padding-top: 5rem;
}

/* ==========================================================================
   WOOCOMMERCE – Dark Theme Overrides
   ========================================================================== */

/* Page Wrapper */
.woo-page {
  background: var(--brand-dark);
  min-height: 100vh;
  padding: 10rem 0 5rem;
}

.woo-page-header {
  margin-bottom: 3rem;
}

.woo-page-title {
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 700;
  color: var(--color-white);
  line-height: 1.1;
  margin-top: 1rem;
}

.woo-content {
  color: var(--color-gray-400);
}

/* ── General WooCommerce Typography ── */
.woocommerce h2,
.woocommerce h3,
.woocommerce h4 {
  color: var(--color-white);
}

.woocommerce a {
  color: var(--brand-accent);
}

.woocommerce a:hover {
  color: var(--color-white);
}

/* ── Tables (Cart, Order Details) ── */
.woocommerce table.shop_table {
  background: var(--brand-gray);
  border: 1px solid var(--color-white-5);
  border-radius: 1rem;
  border-collapse: separate;
  border-spacing: 0;
  overflow: hidden;
  width: 100%;
}

.woocommerce table.shop_table th {
  background: rgba(255,255,255,0.03);
  color: var(--color-gray-400);
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 1rem 1.5rem;
  border-bottom: 1px solid var(--color-white-5);
}

.woocommerce table.shop_table td {
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--color-white-5);
  color: var(--color-white);
  vertical-align: middle;
}

.woocommerce table.shop_table tr:last-child td {
  border-bottom: none;
}

.woocommerce table.shop_table .product-thumbnail img {
  width: 80px;
  max-width: 80px;
  height: 80px;
  object-fit: cover;
  border-radius: 0.75rem;
  border: 1px solid var(--color-white-10);
}

.woocommerce table.shop_table .product-name a {
  color: var(--color-white);
  font-weight: 600;
  text-decoration: none;
}

.woocommerce table.shop_table .product-name a:hover {
  color: var(--brand-accent);
}

.woocommerce table.shop_table .product-price,
.woocommerce table.shop_table .product-subtotal {
  font-weight: 600;
  color: var(--color-white);
}

.woocommerce table.shop_table .product-remove a {
  color: var(--color-gray-500) !important;
  font-size: 1.5rem;
  text-decoration: none;
}

.woocommerce table.shop_table .product-remove a:hover {
  color: #ef4444 !important;
}

.woocommerce table.shop_table .product-quantity .quantity {
  display: inline-flex;
  align-items: center;
}

/* ── Quantity Input ── */
.woocommerce .quantity .qty {
  background: var(--brand-dark);
  border: 1px solid var(--color-white-10);
  border-radius: 0.5rem;
  color: var(--color-white);
  padding: 0.5rem 0.75rem;
  width: 4rem;
  text-align: center;
  font-size: 1rem;
  outline: none;
}
/* Compact qty when inside +/- wrapper */
.woocommerce .ff-qty-wrap .qty,
.woocommerce .quantity.ff-qty-wrap .qty {
  background: none !important;
  border: none !important;
  padding: 0.125rem 0 !important;
  width: 1.75rem !important;
  font-size: 0.75rem !important;
  height: auto !important;
  min-height: 0 !important;
  line-height: 1 !important;
  box-shadow: none !important;
}

.woocommerce .quantity .qty:focus {
  border-color: var(--brand-accent);
}

/* ── Coupon ── */
.woocommerce .coupon {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.woocommerce .coupon .input-text {
  background: #1a1a1a;
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 0.75rem;
  color: var(--color-white);
  padding: 0.75rem 1rem;
  font-size: 0.875rem;
  outline: none;
  flex: 1;
  min-width: 180px;
}

.woocommerce .coupon .input-text:focus {
  border-color: var(--brand-accent);
}

.woocommerce .coupon .button {
  white-space: nowrap;
}

/* ── Cart Totals ── */
.woocommerce .cart_totals,
.woocommerce-checkout .cart_totals {
  background: #1a1a1a;
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 1rem;
  padding: 2rem;
}

.woocommerce .cart_totals h2 {
  font-size: 1rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 1.5rem;
}

.woocommerce .cart_totals table {
  background: transparent;
  border: none;
}

.woocommerce .cart_totals table th {
  background: transparent;
  color: var(--color-gray-400);
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--color-white-5);
  font-weight: 500;
  font-size: 0.875rem;
  text-transform: none;
  letter-spacing: 0;
}

.woocommerce .cart_totals table td {
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--color-white-5);
  text-align: right;
}

.woocommerce .cart_totals .order-total th,
.woocommerce .cart_totals .order-total td {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-white);
  border-bottom: none;
  padding-top: 1.5rem;
}

/* ── Buttons ── */
.woocommerce .button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce a.button,
.woocommerce #respond input#submit {
  background: var(--color-white);
  color: #000;
  border: none;
  border-radius: 0.75rem;
  padding: 0.875rem 2rem;
  font-size: 0.875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  cursor: pointer;
  transition: all var(--transition-fast);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* ── Cart Quantity +/- Buttons ── */
.woocommerce .ff-qty-wrap,
.ff-qty-wrap {
  display: inline-flex !important;
  align-items: center !important;
  background: rgba(0,0,0,0.4) !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  border-radius: 0.5rem !important;
  padding: 0.125rem 0.375rem !important;
  width: auto !important;
  height: auto !important;
  min-height: 0 !important;
}
.woocommerce .ff-qty-wrap input.qty,
.ff-qty-wrap input.qty {
  background: none !important;
  border: none !important;
  color: var(--color-white) !important;
  width: 2rem !important;
  height: auto !important;
  min-height: 0 !important;
  text-align: center !important;
  font-size: 0.8125rem !important;
  font-weight: 500 !important;
  padding: 0.125rem 0 !important;
  margin: 0 !important;
  -moz-appearance: textfield !important;
  box-shadow: none !important;
  outline: none !important;
  line-height: 1.2 !important;
}
.ff-qty-wrap input.qty::-webkit-outer-spin-button,
.ff-qty-wrap input.qty::-webkit-inner-spin-button {
  -webkit-appearance: none;
  appearance: none;
  margin: 0;
}
.woocommerce button.ff-qty-btn,
.woocommerce button.button.ff-qty-btn,
button.ff-qty-btn {
  background: none !important;
  border: none !important;
  color: var(--color-gray-500) !important;
  cursor: pointer;
  padding: 0.125rem !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: auto !important;
  min-width: 0 !important;
  min-height: 0 !important;
  font-size: 0 !important;
  line-height: 1 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  transition: color 0.3s;
}
.woocommerce button.ff-qty-btn:hover,
button.ff-qty-btn:hover {
  color: var(--color-white) !important;
  background: none !important;
}

/* ── Hide Cart Quantity Column (moved inline) ── */
body.woocommerce-cart .shop_table th.product-quantity,
body.woocommerce-cart .shop_table td.product-quantity {
  display: none !important;
}

/* ── Cart Vehicle Row (HSN/TSN + Edit) ── */
.ff-cart-vehicle-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 0.5rem;
}
.ff-cart-vehicle-tag {
  font-size: 0.75rem;
  color: var(--color-gray-400);
  background: rgba(255,255,255,0.05);
  padding: 0.25rem 0.625rem;
  border-radius: 0.375rem;
  border: 1px solid rgba(255,255,255,0.08);
}
.ff-hsn-cart-edit {
  background: none;
  border: none;
  color: var(--color-gray-500);
  cursor: pointer;
  padding: 0.25rem;
  display: flex;
  transition: color 0.3s;
}
.ff-hsn-cart-edit:hover { color: var(--color-white); }
.ff-hsn-cart-add {
  font-size: 0.75rem;
  font-weight: 600;
  color: #a78bfa;
  border: 1px solid #a78bfa !important;
  padding: 0.25rem 0.75rem !important;
  border-radius: 0.5rem;
}

/* ── Cart Inline Qty (moved from column) ── */
.ff-cart-inline-qty {
  margin-top: 0.75rem;
}

/* ── Cart Actions Layout ── */
body.woocommerce-cart .woocommerce-cart-form .actions {
  padding: 1rem 0 0;
}
body.woocommerce-cart .woocommerce-cart-form .actions .coupon {
  display: inline-flex;
  gap: 0.5rem;
  align-items: center;
}
body.woocommerce-cart .woocommerce-cart-form .actions > button[name="update_cart"] {
  float: right;
}

/* ── Checkout Button Full Width ── */
.woocommerce .wc-proceed-to-checkout {
  padding: 0;
}
.woocommerce .wc-proceed-to-checkout a.checkout-button {
  display: block;
  width: 100%;
  text-align: center;
  padding: 1rem 2rem;
  font-size: 1rem;
  border-radius: 0.75rem;
}

.woocommerce .button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce a.button:hover {
  background: #e5e7eb;
  color: #000;
}

.woocommerce .button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce a.button.alt,
.woocommerce #respond input#submit.alt {
  background: var(--brand-accent);
  color: #000;
}

.woocommerce .button.alt:hover,
.woocommerce button.button.alt:hover {
  background: #fff;
}

.woocommerce a.button.wc-forward {
  background: var(--brand-accent);
  color: #000;
}

/* ── Checkout Form ── */
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3,
.woocommerce-checkout .woocommerce-additional-fields h3,
.woocommerce-checkout #order_review_heading {
  font-size: 1rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-white);
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--color-white-5);
}

.woocommerce form .form-row label {
  color: var(--color-gray-400);
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 0.5rem;
  display: block;
}

/* 50/50 Flex Layout for First/Last Name, Zip/Town */
.woocommerce-billing-fields__field-wrapper,
.woocommerce-shipping-fields__field-wrapper,
.woocommerce-additional-fields__field-wrapper {
  display: flex !important;
  flex-wrap: wrap;
  gap: 0 4%;
}

.woocommerce form .form-row {
  width: 100% !important;
  float: none !important;
  margin-bottom: 1.25rem;
  box-sizing: border-box;
}

.woocommerce form .form-row-first,
.woocommerce form .form-row-last {
  width: 48% !important;
  float: none !important;
}

@media (max-width: 767px) {
  .woocommerce form .form-row-first,
  .woocommerce form .form-row-last {
    width: 100% !important;
  }
}

.woocommerce form .form-row .input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce-checkout .select2-container--default .select2-selection--single {
  background: #1a1a1a !important;
  border: 1px solid rgba(255,255,255,0.2) !important;
  border-radius: 0.75rem !important;
  color: var(--color-white) !important;
  padding: 0.875rem 1rem;
  font-size: 1rem;
  outline: none;
  width: 100%;
  transition: all var(--transition-fast);
}

.woocommerce form .form-row .input-text:focus,
.woocommerce form .form-row textarea:focus {
  border-color: var(--brand-accent) !important;
  box-shadow: 0 0 0 1px rgba(209,209,219,0.2);
}

.woocommerce form .form-row select {
  appearance: auto;
}

/* Select2 overrides */
.select2-container--default .select2-selection--single {
  height: auto !important;
  min-height: 3rem;
  display: flex;
  align-items: center;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
  color: var(--color-white) !important;
  padding: 0 1rem;
  display: flex !important;
  align-items: center !important;
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 100%;
}

.select2-dropdown {
  background: var(--brand-gray) !important;
  border: 1px solid var(--color-white-10) !important;
  border-radius: 0.75rem !important;
}

.select2-container--default .select2-results__option {
  color: var(--color-white);
  padding: 0.75rem 1rem;
  display: flex !important;
  align-items: center !important;
}

.select2-container--default .select2-results__option--highlighted[aria-selected],
.select2-container--default .select2-results__option[aria-selected="true"] {
  background: var(--brand-accent) !important;
  color: #000 !important;
}

.select2-container--default .select2-search--dropdown .select2-search__field {
  background: var(--brand-dark);
  border: 1px solid var(--color-white-10);
  color: var(--color-white);
  border-radius: 0.5rem;
  padding: 0.5rem;
}

/* ── Order Review (Checkout) ── */
.woocommerce-checkout #order_review {
  background: var(--brand-gray);
  border: 1px solid var(--color-white-5);
  border-radius: 1rem;
  padding: 2rem;
}

.woocommerce-checkout #order_review table.shop_table {
  background: transparent;
  border: none;
}

/* ── Payment Methods ── */
.woocommerce-checkout #payment {
  background: var(--brand-gray);
  border-radius: 1rem;
}

.woocommerce-checkout #payment ul.payment_methods {
  list-style: none;
  padding: 1.5rem;
  margin: 0;
  border-bottom: 1px solid var(--color-white-5);
}

.woocommerce-checkout #payment ul.payment_methods li {
  padding: 1rem;
  border: 1px solid var(--color-white-5);
  border-radius: 0.75rem;
  margin-bottom: 0.75rem;
  background: var(--brand-dark);
}

.woocommerce-checkout #payment ul.payment_methods li label {
  color: var(--color-white);
  font-weight: 600;
  cursor: pointer;
}

.woocommerce-checkout #payment .payment_box {
  background: var(--brand-dark) !important;
  color: var(--color-gray-400);
  padding: 1rem;
  border-radius: 0.5rem;
  margin-top: 0.75rem;
}

.woocommerce-checkout #payment .payment_box::before {
  display: none;
}

.woocommerce-checkout #payment .place-order {
  padding: 1.5rem;
}

.woocommerce-checkout #payment #place_order {
  width: 100%;
  padding: 1.25rem;
  font-size: 1rem;
  background: var(--color-white);
  color: #000;
  border-radius: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.woocommerce-checkout #payment #place_order:hover {
  background: var(--brand-accent);
}

/* ── Order Received ── */
.woocommerce-order-received .woocommerce-thankyou-order-received {
  color: #22c55e;
  font-weight: 700;
  font-size: 1.25rem;
  margin-bottom: 2rem;
}

.woocommerce-order-received .woocommerce-order-details {
  background: var(--brand-gray);
  border: 1px solid var(--color-white-5);
  border-radius: 1rem;
  padding: 2rem;
  margin-bottom: 2rem;
}

/* ── Notices ── */
.woocommerce-message,
.woocommerce-info {
  background: var(--brand-gray);
  border: 1px solid var(--color-white-10);
  border-left: 4px solid var(--brand-accent);
  color: var(--color-white);
  border-radius: 0.75rem;
  padding: 1rem 1.5rem;
  margin-bottom: 1.5rem;
}

.woocommerce-error {
  background: var(--brand-gray);
  border: 1px solid rgba(239,68,68,0.2);
  border-left: 4px solid #ef4444;
  color: var(--color-white);
  border-radius: 0.75rem;
  padding: 1rem 1.5rem;
  margin-bottom: 1.5rem;
}

.woocommerce-error li {
  color: #fca5a5;
}

/* ── Empty Cart ── */
.woocommerce .cart-empty {
  background: var(--brand-gray);
  border: 1px solid var(--color-white-5);
  border-radius: 1rem;
  padding: 4rem 2rem;
  text-align: center;
  color: var(--color-gray-400);
  font-size: 1.125rem;
}

.woocommerce .return-to-shop {
  text-align: center;
  margin-top: 2rem;
}

/* ── My Account ── */
.woocommerce-MyAccount-navigation {
  background: var(--brand-gray);
  border: 1px solid var(--color-white-5);
  border-radius: 1rem;
  overflow: hidden;
}

.woocommerce-MyAccount-navigation ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.woocommerce-MyAccount-navigation ul li {
  border-bottom: 1px solid var(--color-white-5);
}

.woocommerce-MyAccount-navigation ul li:last-child {
  border-bottom: none;
}

.woocommerce-MyAccount-navigation ul li a {
  display: block;
  padding: 1rem 1.5rem;
  color: var(--color-gray-400);
  text-decoration: none;
  font-weight: 500;
  transition: all var(--transition-fast);
}

.woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-MyAccount-navigation ul li.is-active a {
  background: var(--color-white-5);
  color: var(--color-white);
}

.woocommerce-MyAccount-content {
  color: var(--color-gray-400);
}

/* ── Breadcrumbs ── */
.woocommerce .woocommerce-breadcrumb {
  color: var(--color-gray-500);
  font-size: 0.75rem;
  margin-bottom: 2rem;
}

.woocommerce .woocommerce-breadcrumb a {
  color: var(--color-gray-400);
}

/* ── Responsive Cart ── */
@media (max-width: 767px) {
  .woocommerce table.shop_table_responsive tr {
    display: flex;
    flex-wrap: wrap;
    padding: 1rem;
    border-bottom: 1px solid var(--color-white-5);
    gap: 0.5rem;
  }

  .woocommerce table.shop_table_responsive tr td {
    border: none;
    padding: 0.25rem 0;
  }

  .woocommerce table.shop_table_responsive tr td::before {
    color: var(--color-gray-500);
    font-weight: 600;
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
  }

  .woo-page {
    padding: 8rem 0 3rem;
  }
}

/* ==========================================================================
   CHECKOUT STEP INDICATOR
   ========================================================================== */
.ff-checkout-steps {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
}

.ff-step {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.ff-step-num {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 50%;
  font-size: 0.75rem;
  font-weight: 700;
  border: 1px solid rgba(255,255,255,0.15);
  color: rgba(255,255,255,0.3);
  background: transparent;
  flex-shrink: 0;
  transition: all 0.3s;
}

.ff-step-label {
  font-size: 0.8125rem;
  font-weight: 600;
  color: rgba(255,255,255,0.3);
  text-decoration: none;
  transition: color 0.3s;
}

/* Active step */
.ff-step--active .ff-step-num {
  background: var(--color-white);
  color: #000;
  border-color: var(--color-white);
}

.ff-step--active .ff-step-label {
  color: var(--color-white);
}

/* Completed step */
.ff-step--done .ff-step-num {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.2);
  color: var(--color-white);
}

.ff-step--done .ff-step-label {
  color: rgba(255,255,255,0.6);
}

.ff-step--done a.ff-step-label:hover {
  color: var(--color-white);
}

/* Divider chevron */
.ff-step-divider {
  display: flex;
  align-items: center;
  color: rgba(255,255,255,0.15);
  margin: 0 0.25rem;
}

/* Responsive */
@media (max-width: 600px) {
  .ff-checkout-steps {
    gap: 0.25rem;
  }

  .ff-step-label {
    font-size: 0.6875rem;
  }

  .ff-step-num {
    width: 1.5rem;
    height: 1.5rem;
    font-size: 0.625rem;
  }
}

