/*
Theme Name: Runic Flame
Theme URI: https://runicflame.local
Author: Ralph
Description: Custom WooCommerce checkout theme for Runic Flame, matching the Next.js headless storefront design. Modern Coastal / Scandi-Minimalist aesthetic.
Template: twentytwentyfive
Version: 1.2.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: runic-flame
*/

/* Overthinking brand font is loaded via PHP (wp_head) with an absolute URL
   to ensure it works regardless of how WordPress serves CSS. */

/* ==========================================================================
   Design Tokens (matching Next.js frontend)
   ========================================================================== */
:root {
  --rf-coral: #E8734A;
  --rf-coral-light: #F09A7A;
  --rf-coral-dark: #D45A2E;
  --rf-burnt-orange: #C4572A;
  --rf-slate: #4A5568;
  --rf-slate-light: #718096;
  --rf-slate-dark: #2D3748;
  --rf-cream: #FAF7F2;
  --rf-cream-dark: #F0EBE1;
  --rf-warm-white: #FEFCF9;
  --rf-charcoal: #3A3A3A;
  --rf-charcoal-light: #5A5A5A;
}

/* ==========================================================================
   Global Overrides
   ========================================================================== */
body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background-color: var(--rf-cream);
  color: var(--rf-charcoal);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Cormorant Garamond', 'Georgia', serif;
  color: var(--rf-charcoal);
  font-weight: 600;
}

a {
  color: var(--rf-coral);
  text-decoration: none;
  transition: color 0.2s ease;
}

a:hover {
  color: var(--rf-coral-dark);
}

/* ==========================================================================
   Custom Header (matching Next.js header)
   ========================================================================== */
.rf-header {
  position: sticky;
  top: 0;
  z-index: 50;
  width: 100%;
  background-color: var(--rf-cream);
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

.rf-header__inner {
  max-width: 80rem;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  padding: 0.75rem 1rem;
}

@media (min-width: 640px) {
  .rf-header__inner {
    padding: 0.75rem 1.5rem;
  }
}

@media (min-width: 1024px) {
  .rf-header__inner {
    padding: 0.75rem 2rem;
  }
}

.rf-header__logo {
  position: absolute;
  left: 1rem;
}

@media (min-width: 640px) {
  .rf-header__logo {
    left: 1.5rem;
  }
}

@media (min-width: 1024px) {
  .rf-header__logo {
    left: 2rem;
  }
}

.rf-header__logo img {
  height: 80px;
  width: auto;
}

.rf-header__nav {
  display: flex;
  align-items: center;
  gap: 2rem;
}

.rf-header__nav a {
  font-family: 'Lora', Georgia, serif;
  font-size: 1.125rem;
  font-weight: 500;
  color: var(--rf-charcoal);
  text-decoration: none;
  transition: color 0.2s ease;
}

.rf-header__nav a:hover {
  color: var(--rf-coral);
}

@media (max-width: 767px) {
  .rf-header__nav {
    gap: 1rem;
  }
  .rf-header__nav a {
    font-size: 0.9rem;
  }
  .rf-header__logo img {
    height: 58px;
  }
}

/* ==========================================================================
   Custom Footer (matching Next.js footer)
   ========================================================================== */
.rf-footer {
  background-color: var(--rf-slate-dark);
  color: var(--rf-cream-dark);
  font-family: 'Lora', Georgia, serif;
}

.rf-footer__inner {
  max-width: 80rem;
  margin: 0 auto;
  padding: 3rem 1rem 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
}

@media (min-width: 768px) {
  .rf-footer__inner {
    grid-template-columns: repeat(3, 1fr);
    padding: 3rem 1.5rem 0;
  }
}

@media (min-width: 1024px) {
  .rf-footer__inner {
    padding: 3rem 2rem 0;
  }
}

/* Brand heading — Overthinking font matching Next.js font-brand */
.rf-footer__brand {
  font-family: 'Overthinking', cursive;
  font-size: 1.5rem;
  color: var(--rf-warm-white);
  line-height: 1.3;
  margin-bottom: 0.5rem;
}

/* Section headings — Lora medium weight matching Next.js text-lg font-medium */
.rf-footer h4 {
  font-family: 'Lora', Georgia, serif;
  font-size: 1.125rem;
  font-weight: 500;
  color: var(--rf-warm-white);
  margin-bottom: 0.75rem;
}

.rf-footer p {
  font-size: 0.875rem;
  line-height: 1.7;
  color: var(--rf-slate-light);
  margin-top: 0.5rem;
}

/* Address and email — matching Next.js Footer */
.rf-footer__address {
  font-style: normal;
  font-size: 0.875rem;
  line-height: 1.7;
  color: var(--rf-slate-light);
  margin-top: 1.5rem;
}

.rf-footer__email {
  display: inline-block;
  font-size: 0.875rem;
  color: var(--rf-slate-light);
  margin-top: 0.25rem;
  transition: color 0.2s ease;
}

.rf-footer__email:hover {
  color: var(--rf-coral-light);
}

/* Links column — push right on desktop to match Next.js md:ml-auto */
.rf-footer__links {
  /* default: no offset on mobile */
}

@media (min-width: 768px) {
  .rf-footer__links {
    margin-left: auto;
  }
}

.rf-footer ul {
  list-style: none;
  padding: 0;
  margin: 0.75rem 0 0;
}

.rf-footer ul li {
  margin-bottom: 0.5rem;
}

.rf-footer ul a {
  font-size: 0.875rem;
  color: var(--rf-slate-light);
  transition: color 0.2s ease;
}

.rf-footer ul a:hover {
  color: var(--rf-coral-light);
}

/* Social icons */
.rf-footer__social {
  display: flex;
  gap: 1rem;
  margin-top: 0.75rem;
}

.rf-footer__social a {
  color: var(--rf-slate-light);
  transition: color 0.2s ease;
}

.rf-footer__social a:hover {
  color: var(--rf-coral-light);
}

.rf-footer__social svg {
  width: 20px;
  height: 20px;
  fill: currentColor;
}

/* Copyright bar */
.rf-footer__copyright {
  max-width: 80rem;
  margin: 2.5rem auto 0;
  padding: 1.5rem 1rem;
  border-top: 1px solid var(--rf-slate);
  text-align: center;
  font-size: 0.875rem;
  color: var(--rf-slate-light);
  font-family: 'Lora', Georgia, serif;
}

/* ==========================================================================
   Hide default WP theme header/footer
   ========================================================================== */
.wp-site-blocks > header,
.wp-site-blocks > footer {
  display: none !important;
}

/* ==========================================================================
   Page Container
   ========================================================================== */
.woocommerce-page .wp-site-blocks {
  padding: 0;
}

.woocommerce-page .entry-content,
.woocommerce-page .wp-block-post-content {
  max-width: 80rem;
  margin: 0 auto;
  padding: 2.5rem 2rem;
}

@media (max-width: 767px) {
  .woocommerce-page .entry-content,
  .woocommerce-page .wp-block-post-content {
    padding: 1.5rem 1rem;
  }
}

/* ==========================================================================
   WooCommerce Checkout Form — Two-Column Layout
   ========================================================================== */

/* Page title */
.woocommerce-checkout h1,
.woocommerce-checkout .entry-title,
.woocommerce-checkout .wp-block-post-title {
  font-family: 'Cormorant Garamond', 'Georgia', serif;
  font-size: 2.25rem;
  font-weight: 600;
  color: var(--rf-charcoal);
  margin-bottom: 2.5rem;
  text-align: center;
}

/* Override TwentyTwentyFive/WooCommerce max-width constraints on checkout */
.woocommerce-checkout .wp-block-woocommerce-classic-shortcode,
.woocommerce-checkout .woocommerce {
  max-width: 100% !important;
  width: 100% !important;
}

/* Main checkout form: side-by-side on desktop */
.woocommerce-checkout form.checkout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
  align-items: start;
  max-width: 100%;
  width: 100%;
}

@media (min-width: 960px) {
  .woocommerce-checkout form.checkout {
    grid-template-columns: 1fr 360px;
    gap: 2.5rem;
  }
}

@media (min-width: 1200px) {
  .woocommerce-checkout form.checkout {
    grid-template-columns: 1fr 400px;
    gap: 3rem;
  }
}

/* Customer details (billing + shipping) — left column */
#customer_details {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

/* Billing / shipping columns stack inside the left panel */
.woocommerce-checkout .col2-set {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

/* Card wrapper for billing and shipping columns */
#customer_details .col-1,
#customer_details .col-2 {
  background-color: var(--rf-warm-white);
  border: 1.5px solid var(--rf-cream-dark);
  border-radius: 0.75rem;
  padding: 2rem 2.25rem;
  min-width: 0; /* prevent grid blowout */
}

/* Force billing/shipping fields to use FULL card width */
#customer_details .col-1 > *,
#customer_details .col-2 > * {
  max-width: 100% !important;
  width: 100% !important;
}

#customer_details .woocommerce-billing-fields__field-wrapper,
#customer_details .woocommerce-shipping-fields__field-wrapper,
#customer_details .woocommerce-additional-fields__field-wrapper {
  max-width: 100% !important;
  width: 100% !important;
}

/* Ensure individual form rows also stretch */
#customer_details .form-row {
  max-width: 100% !important;
}

/* Side-by-side first/last name fields */
#customer_details .form-row-first,
#customer_details .form-row-last {
  display: inline-block;
  width: 48% !important;
  vertical-align: top;
}

#customer_details .form-row-first {
  margin-right: 4%;
}

#customer_details .form-row-wide {
  width: 100% !important;
  clear: both;
}

/* Order review — right column, sticky on scroll */
#order_review_heading,
#order_review {
  grid-column: -1; /* push to right column */
}

@media (min-width: 960px) {
  #order_review_heading {
    grid-column: 2;
    grid-row: 1;
  }
  #order_review {
    grid-column: 2;
    grid-row: 2 / span 10;
    position: sticky;
    top: 5rem;
  }
  #customer_details {
    grid-column: 1;
    grid-row: 1 / span 10;
  }
}

/* Wrap order review in card styling */
#order_review {
  background-color: var(--rf-warm-white);
  border: 1.5px solid var(--rf-cream-dark);
  border-radius: 0.75rem;
  padding: 1.75rem;
}

/* Section headings */
.woocommerce-checkout h3 {
  font-family: 'Cormorant Garamond', 'Georgia', serif;
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--rf-charcoal);
  margin-bottom: 1.25rem;
  padding-bottom: 0.75rem;
  border-bottom: 2px solid var(--rf-cream-dark);
}

.woocommerce-checkout #order_review_heading {
  font-family: 'Cormorant Garamond', 'Georgia', serif;
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--rf-charcoal);
  margin-bottom: 0.5rem;
  padding-bottom: 0;
  border-bottom: none;
  letter-spacing: 0.02em;
}

/* Additional fields (order notes) — visual separator inside col-2 */
#customer_details .col-2 .woocommerce-additional-fields {
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1.5px solid var(--rf-cream-dark);
}

/* ==========================================================================
   Form Fields
   ========================================================================== */
.woocommerce-checkout .form-row {
  margin-bottom: 1.25rem;
}

.woocommerce-checkout label {
  display: block;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--rf-slate);
  margin-bottom: 0.375rem;
}

.woocommerce-checkout label .required {
  color: var(--rf-coral);
}

.woocommerce-checkout .input-text,
.woocommerce-checkout input[type="text"],
.woocommerce-checkout input[type="email"],
.woocommerce-checkout input[type="tel"],
.woocommerce-checkout input[type="number"],
.woocommerce-checkout input[type="password"],
.woocommerce-checkout textarea,
.woocommerce-checkout select,
.woocommerce-checkout .select2-container .select2-selection--single {
  width: 100%;
  padding: 0.75rem 1rem;
  font-family: 'Inter', sans-serif;
  font-size: 0.9375rem;
  color: var(--rf-charcoal);
  background-color: var(--rf-warm-white);
  border: 1.5px solid var(--rf-cream-dark);
  border-radius: 0.5rem;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  box-sizing: border-box;
  -webkit-appearance: none;
}

.woocommerce-checkout .input-text:focus,
.woocommerce-checkout input:focus,
.woocommerce-checkout textarea:focus,
.woocommerce-checkout select:focus {
  outline: none;
  border-color: var(--rf-coral);
  box-shadow: 0 0 0 3px rgba(232, 115, 74, 0.15);
}

/* Select2 dropdown styling */
.select2-container--default .select2-selection--single {
  height: auto !important;
  border: 1.5px solid var(--rf-cream-dark) !important;
  border-radius: 0.5rem !important;
  background-color: var(--rf-warm-white) !important;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
  padding: 0.75rem 1rem !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 0.9375rem !important;
  color: var(--rf-charcoal) !important;
  line-height: 1.4 !important;
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 100% !important;
  right: 0.75rem !important;
}

.select2-container--default .select2-results__option--highlighted[aria-selected] {
  background-color: var(--rf-coral) !important;
}

.select2-dropdown {
  border: 1.5px solid var(--rf-cream-dark) !important;
  border-radius: 0.5rem !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1) !important;
}

/* Checkbox/radio styling */
.woocommerce-checkout input[type="checkbox"],
.woocommerce-checkout input[type="radio"] {
  width: 1.125rem;
  height: 1.125rem;
  accent-color: var(--rf-coral);
  margin-right: 0.5rem;
  cursor: pointer;
}

/* Validation states */
.woocommerce-checkout .woocommerce-invalid .input-text,
.woocommerce-checkout .woocommerce-invalid input {
  border-color: #e53e3e;
  box-shadow: 0 0 0 3px rgba(229, 62, 62, 0.15);
}

.woocommerce-checkout .woocommerce-validated .input-text {
  border-color: #48bb78;
}

/* ==========================================================================
   Order Review Table
   ========================================================================== */
.woocommerce-checkout-review-order-table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 1.5rem;
  font-size: 0.9375rem;
}

.woocommerce-checkout-review-order-table th {
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  font-size: 0.8125rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--rf-slate);
  padding: 0.75rem 0;
  border-bottom: 2px solid var(--rf-cream-dark);
  text-align: left;
}

.woocommerce-checkout-review-order-table td {
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--rf-cream-dark);
  color: var(--rf-charcoal);
}

.woocommerce-checkout-review-order-table .cart_item td {
  vertical-align: middle;
}

.woocommerce-checkout-review-order-table .product-name {
  font-weight: 500;
  width: 70%;
}

.woocommerce-checkout-review-order-table .product-total {
  text-align: right;
  font-weight: 500;
  width: 30%;
  white-space: nowrap;
}

.woocommerce-checkout-review-order-table tfoot th {
  text-transform: none;
  font-size: 0.9375rem;
  font-weight: 500;
}

.woocommerce-checkout-review-order-table tfoot .order-total th,
.woocommerce-checkout-review-order-table tfoot .order-total td {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--rf-charcoal);
  border-top: 2px solid var(--rf-cream-dark);
  padding-top: 1rem;
}

.woocommerce-checkout-review-order-table tfoot .order-total .woocommerce-Price-amount {
  color: var(--rf-coral);
}

/* ==========================================================================
   Payment Methods
   ========================================================================== */
#payment {
  background-color: transparent;
  border: none;
  border-radius: 0;
  padding: 0;
  margin-top: 1.5rem;
  border-top: 1.5px solid var(--rf-cream-dark);
  padding-top: 1.5rem;
}

#payment .payment_methods {
  list-style: none;
  padding: 0;
  margin: 0 0 1.5rem;
  border-bottom: 1px solid var(--rf-cream-dark);
  padding-bottom: 1.5rem;
}

#payment .payment_methods li {
  padding: 1rem;
  margin-bottom: 0.5rem;
  border: 1.5px solid var(--rf-cream-dark);
  border-radius: 0.5rem;
  background-color: var(--rf-cream);
  transition: border-color 0.2s ease, background-color 0.2s ease;
}

#payment .payment_methods li.payment_method_sumup,
#payment .payment_methods li input[type="radio"]:checked ~ label {
  border-color: var(--rf-coral-light);
  background-color: rgba(232, 115, 74, 0.04);
}

#payment .payment_methods li:hover {
  border-color: var(--rf-coral-light);
}

#payment .payment_methods li label {
  font-weight: 500;
  color: var(--rf-charcoal);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0;
}

#payment .payment_methods li .payment_box {
  margin-top: 0.75rem;
  padding: 0.75rem;
  background-color: var(--rf-cream-dark);
  border-radius: 0.375rem;
  font-size: 0.875rem;
  color: var(--rf-slate);
}

/* ==========================================================================
   Place Order Button
   ========================================================================== */
#place_order {
  display: block;
  width: 100%;
  padding: 1rem 2rem;
  font-family: 'Inter', sans-serif;
  font-size: 1.0625rem;
  font-weight: 600;
  color: var(--rf-warm-white);
  background-color: var(--rf-coral);
  border: none;
  border-radius: 0.5rem;
  cursor: pointer;
  transition: background-color 0.2s ease, transform 0.15s ease;
  letter-spacing: 0.01em;
}

#place_order:hover {
  background-color: var(--rf-coral-dark);
  transform: translateY(-1px);
}

#place_order:active {
  transform: translateY(0);
}

#place_order:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}

/* ==========================================================================
   Terms & Conditions
   ========================================================================== */
.woocommerce-terms-and-conditions-wrapper {
  margin-bottom: 1.5rem;
}

.woocommerce-terms-and-conditions-wrapper .woocommerce-form__label {
  font-size: 0.875rem;
  color: var(--rf-slate);
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
}

.woocommerce-privacy-policy-text {
  font-size: 0.8125rem;
  color: var(--rf-slate-light);
  margin-bottom: 1rem;
}

.woocommerce-privacy-policy-text a {
  color: var(--rf-coral);
}

/* ==========================================================================
   Notices & Alerts
   ========================================================================== */
.woocommerce-notices-wrapper .woocommerce-message,
.woocommerce-checkout .woocommerce-info {
  background-color: var(--rf-warm-white);
  border: 1.5px solid var(--rf-cream-dark);
  border-left: 4px solid var(--rf-coral);
  padding: 1rem 1.25rem;
  border-radius: 0.5rem;
  margin-bottom: 1.5rem;
  font-size: 0.9375rem;
  color: var(--rf-charcoal);
}

.woocommerce-checkout .woocommerce-error {
  background-color: #fff5f5;
  border: 1.5px solid #fed7d7;
  border-left: 4px solid #e53e3e;
  padding: 1rem 1.25rem;
  border-radius: 0.5rem;
  margin-bottom: 1.5rem;
  color: #c53030;
  list-style: none;
}

.woocommerce-checkout .woocommerce-error li {
  margin-bottom: 0.25rem;
}

/* ==========================================================================
   Coupon Section
   ========================================================================== */
.woocommerce-checkout .checkout_coupon {
  background-color: var(--rf-warm-white);
  border: 1.5px solid var(--rf-cream-dark);
  border-radius: 0.5rem;
  padding: 1.25rem;
  margin-bottom: 1.5rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: center;
}

.woocommerce-checkout .checkout_coupon .input-text {
  flex: 1;
  min-width: 180px;
}

.woocommerce-checkout .checkout_coupon .button {
  padding: 0.75rem 1.5rem;
  font-family: 'Inter', sans-serif;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--rf-warm-white);
  background-color: var(--rf-slate);
  border: none;
  border-radius: 0.5rem;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.woocommerce-checkout .checkout_coupon .button:hover {
  background-color: var(--rf-slate-dark);
}

/* ==========================================================================
   Login Form on Checkout
   ========================================================================== */
.woocommerce-checkout .woocommerce-form-login-toggle .woocommerce-info {
  cursor: pointer;
}

.woocommerce-checkout .woocommerce-form-login {
  background-color: var(--rf-warm-white);
  border: 1.5px solid var(--rf-cream-dark);
  border-radius: 0.5rem;
  padding: 1.5rem;
  margin-bottom: 1.5rem;
}

.woocommerce-checkout .woocommerce-form-login .button {
  padding: 0.75rem 1.5rem;
  font-family: 'Inter', sans-serif;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--rf-warm-white);
  background-color: var(--rf-coral);
  border: none;
  border-radius: 0.5rem;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.woocommerce-checkout .woocommerce-form-login .button:hover {
  background-color: var(--rf-coral-dark);
}

/* ==========================================================================
   Shipping Methods
   ========================================================================== */
.woocommerce-checkout .woocommerce-shipping-methods {
  list-style: none;
  padding: 0;
  margin: 0;
}

.woocommerce-checkout .woocommerce-shipping-methods li {
  padding: 0.5rem 0;
}

.woocommerce-checkout .woocommerce-shipping-methods li label {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
  font-weight: 400;
  color: var(--rf-charcoal);
}

/* Free shipping highlight */
.woocommerce-checkout .shipping .woocommerce-free-shipping,
.woocommerce-checkout .woocommerce-shipping-methods .free_shipping label {
  color: #2f855a;
  font-weight: 500;
}

/* ==========================================================================
   Cart/Basket Page (if accessed)
   ========================================================================== */
.woocommerce-cart table.shop_table {
  width: 100%;
  border-collapse: collapse;
}

.woocommerce-cart table.shop_table th {
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  font-size: 0.8125rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--rf-slate);
  padding: 0.75rem;
  border-bottom: 2px solid var(--rf-cream-dark);
  text-align: left;
}

.woocommerce-cart table.shop_table td {
  padding: 1rem 0.75rem;
  border-bottom: 1px solid var(--rf-cream-dark);
  vertical-align: middle;
}

.woocommerce-cart .product-remove a {
  color: var(--rf-slate-light);
  font-size: 1.25rem;
  transition: color 0.2s ease;
}

.woocommerce-cart .product-remove a:hover {
  color: #e53e3e;
}

.woocommerce-cart .quantity .qty {
  width: 60px;
  padding: 0.5rem;
  text-align: center;
  border: 1.5px solid var(--rf-cream-dark);
  border-radius: 0.375rem;
}

.woocommerce-cart .button,
.woocommerce-cart .checkout-button {
  display: inline-block;
  padding: 0.75rem 1.5rem;
  font-family: 'Inter', sans-serif;
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--rf-warm-white);
  background-color: var(--rf-coral);
  border: none;
  border-radius: 0.5rem;
  cursor: pointer;
  transition: background-color 0.2s ease;
  text-decoration: none;
}

.woocommerce-cart .button:hover,
.woocommerce-cart .checkout-button:hover {
  background-color: var(--rf-coral-dark);
}

/* ==========================================================================
   SumUp Payment Gateway
   ========================================================================== */
.payment_method_sumup .payment_box {
  background-color: var(--rf-cream-dark) !important;
  padding: 1rem !important;
  border-radius: 0.375rem !important;
}

.payment_method_sumup .payment_box p {
  color: var(--rf-slate);
  margin-bottom: 0.75rem;
}

/* SumUp card form iframe */
.sumup-card-widget,
.payment_method_sumup iframe {
  border-radius: 0.375rem;
  overflow: hidden;
}

/* ==========================================================================
   WooCommerce General Buttons
   ========================================================================== */
.woocommerce button.button,
.woocommerce a.button,
.woocommerce input.button {
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  border-radius: 0.5rem;
  transition: background-color 0.2s ease, transform 0.15s ease;
}

.woocommerce button.button.alt,
.woocommerce a.button.alt,
.woocommerce input.button.alt {
  background-color: var(--rf-coral);
  color: var(--rf-warm-white);
  border: none;
}

.woocommerce button.button.alt:hover,
.woocommerce a.button.alt:hover,
.woocommerce input.button.alt:hover {
  background-color: var(--rf-coral-dark);
}

/* ==========================================================================
   Responsive Adjustments
   ========================================================================== */
@media (max-width: 959px) {
  .woocommerce-checkout form.checkout {
    grid-template-columns: 1fr;
  }

  #order_review_heading,
  #order_review,
  #customer_details {
    grid-column: 1;
    grid-row: auto;
    position: static;
  }
}

@media (max-width: 767px) {
  .woocommerce-checkout h1,
  .woocommerce-checkout .entry-title {
    font-size: 1.75rem;
  }

  .woocommerce-checkout h3,
  .woocommerce-checkout #order_review_heading {
    font-size: 1.25rem;
  }

  #customer_details .col-1,
  #customer_details .col-2,
  #order_review {
    padding: 1.25rem;
  }

  .rf-header__inner {
    padding: 0.5rem 0.75rem;
  }

  .rf-footer__inner {
    padding: 3rem 0.75rem 0;
  }
}

@media (max-width: 480px) {
  .woocommerce-checkout .form-row {
    margin-bottom: 1rem;
  }

  .woocommerce-checkout .input-text,
  .woocommerce-checkout input[type="text"],
  .woocommerce-checkout input[type="email"],
  .woocommerce-checkout input[type="tel"],
  .woocommerce-checkout select {
    padding: 0.625rem 0.875rem;
    font-size: 1rem; /* Prevent iOS zoom on focus */
  }

  #customer_details .col-1,
  #customer_details .col-2,
  #order_review {
    padding: 1rem;
    border-radius: 0.5rem;
  }
}

/* ==========================================================================
   Pay for Order Page (SumUp redirect flow)
   ========================================================================== */

/* Centre the entire WooCommerce block and constrain width */
.woocommerce-order-pay .wp-block-post-content,
.woocommerce-order-pay .entry-content {
  max-width: 560px !important;
  margin: 0 auto !important;
  padding-top: 2rem;
  padding-bottom: 3rem;
}

.woocommerce-order-pay .woocommerce,
.woocommerce-order-pay .wp-block-woocommerce-classic-shortcode {
  max-width: 100% !important;
}

/* Page title — hide the default "Pay for order" heading, we style the notice */
.woocommerce-order-pay h1,
.woocommerce-order-pay .entry-title,
.woocommerce-order-pay .wp-block-post-title {
  font-family: 'Cormorant Garamond', 'Georgia', serif;
  font-size: 1.75rem;
  font-weight: 600;
  color: var(--rf-charcoal);
  text-align: center;
  margin-bottom: 1.5rem;
}

/* Guest-order notice — soft, subtle banner matching Next.js info style */
.woocommerce-order-pay .woocommerce-info,
.woocommerce-order-pay .woocommerce-notices-wrapper .woocommerce-info {
  font-family: 'Inter', sans-serif;
  font-size: 0.8125rem;
  font-weight: 400;
  color: var(--rf-slate);
  background-color: var(--rf-warm-white);
  border: 1px solid var(--rf-cream-dark);
  border-left: 3px solid var(--rf-coral);
  border-radius: 0.625rem;
  padding: 0.875rem 1.25rem;
  margin-bottom: 1.5rem;
  line-height: 1.5;
}

.woocommerce-order-pay .woocommerce-info::before {
  color: var(--rf-coral);
}

/* Error notices */
.woocommerce-order-pay .woocommerce-error {
  font-family: 'Inter', sans-serif;
  font-size: 0.8125rem;
  background-color: #fef2f2;
  border: 1px solid #fecaca;
  border-left: 3px solid #ef4444;
  border-radius: 0.625rem;
  padding: 0.875rem 1.25rem;
  margin-bottom: 1.5rem;
  color: #991b1b;
  list-style: none;
}

/* ── Order review card ── */
.woocommerce-order-pay #order_review {
  max-width: 100%;
  margin: 0 auto;
  background-color: var(--rf-warm-white);
  border: 1px solid var(--rf-cream-dark);
  border-radius: 0.75rem;
  padding: 1.75rem 2rem;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

/* ── Table — match Next.js order summary sizing ── */
.woocommerce-order-pay table.shop_table {
  width: 100%;
  border-collapse: collapse;
  font-family: 'Inter', sans-serif;
  font-size: 0.875rem;
  margin-bottom: 0;
}

.woocommerce-order-pay table.shop_table th {
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--rf-slate-light);
  padding: 0 0 0.75rem;
  border-bottom: 1px solid var(--rf-cream-dark);
  text-align: left;
}

.woocommerce-order-pay table.shop_table td {
  font-family: 'Inter', sans-serif;
  font-size: 0.875rem;
  font-weight: 400;
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--rf-cream-dark);
  color: var(--rf-charcoal);
  vertical-align: middle;
}

.woocommerce-order-pay table.shop_table .product-name {
  font-weight: 500;
  color: var(--rf-charcoal);
}

.woocommerce-order-pay table.shop_table .product-quantity {
  color: var(--rf-slate-light);
}

.woocommerce-order-pay table.shop_table .product-total,
.woocommerce-order-pay table.shop_table td:last-child {
  text-align: right;
  font-weight: 500;
}

/* Tfoot rows — subtotal, total, payment method */
.woocommerce-order-pay table.shop_table tfoot th {
  font-family: 'Inter', sans-serif;
  font-size: 0.8125rem;
  font-weight: 500;
  text-transform: none;
  letter-spacing: 0;
  color: var(--rf-slate);
  padding: 0.625rem 0;
  border-bottom: 1px solid var(--rf-cream-dark);
}

.woocommerce-order-pay table.shop_table tfoot td {
  font-size: 0.875rem;
  font-weight: 500;
  padding: 0.625rem 0;
  border-bottom: 1px solid var(--rf-cream-dark);
}

/* Order total row — slightly larger */
.woocommerce-order-pay table.shop_table tfoot .order-total th {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--rf-charcoal);
  border-top: 1.5px solid var(--rf-cream-dark);
  border-bottom: none;
  padding-top: 0.875rem;
}

.woocommerce-order-pay table.shop_table tfoot .order-total td {
  font-size: 1.0625rem;
  font-weight: 700;
  color: var(--rf-charcoal);
  border-top: 1.5px solid var(--rf-cream-dark);
  border-bottom: none;
  padding-top: 0.875rem;
}

.woocommerce-order-pay table.shop_table tfoot .order-total .woocommerce-Price-amount {
  color: var(--rf-coral);
}

/* ── Payment section inside order-review card ── */
.woocommerce-order-pay #payment {
  background-color: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin-top: 1.25rem;
  border-top: 1px solid var(--rf-cream-dark) !important;
  padding-top: 1.25rem !important;
  box-shadow: none !important;
}

.woocommerce-order-pay #payment .payment_methods {
  list-style: none;
  padding: 0;
  margin: 0 0 1.25rem;
  border-bottom: none;
  padding-bottom: 0;
}

.woocommerce-order-pay #payment .payment_methods li {
  padding: 0.875rem 1rem;
  margin-bottom: 0;
  border: 1px solid var(--rf-cream-dark);
  border-radius: 0.5rem;
  background-color: var(--rf-cream);
}

.woocommerce-order-pay #payment .payment_methods li label {
  font-family: 'Inter', sans-serif;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--rf-charcoal);
}

.woocommerce-order-pay #payment .payment_methods li .payment_box {
  margin-top: 0.75rem;
  padding: 0.75rem;
  background-color: var(--rf-cream);
  border: 1px solid var(--rf-cream-dark);
  border-radius: 0.375rem;
  font-family: 'Inter', sans-serif;
  font-size: 0.8125rem;
  color: var(--rf-slate);
}

.woocommerce-order-pay #payment .payment_methods li .payment_box p {
  font-size: 0.8125rem;
  margin: 0 0 0.5rem;
  color: var(--rf-slate);
}

/* SumUp card widget */
.woocommerce-order-pay .sumup-card-widget,
.woocommerce-order-pay .payment_method_sumup iframe {
  border-radius: 0.5rem;
  overflow: hidden;
}

/* Place order / Pay button */
.woocommerce-order-pay #place_order {
  display: block;
  width: 100%;
  padding: 0.875rem 2rem;
  font-family: 'Inter', sans-serif;
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--rf-warm-white);
  background-color: var(--rf-coral);
  border: none;
  border-radius: 0.625rem;
  cursor: pointer;
  transition: background-color 0.2s ease, transform 0.15s ease;
  letter-spacing: 0.01em;
  margin-top: 0.5rem;
}

.woocommerce-order-pay #place_order:hover {
  background-color: var(--rf-coral-dark);
  transform: translateY(-1px);
}

/* Terms / privacy text */
.woocommerce-order-pay .woocommerce-terms-and-conditions-wrapper,
.woocommerce-order-pay .woocommerce-privacy-policy-text {
  font-family: 'Inter', sans-serif;
  font-size: 0.75rem;
  color: var(--rf-slate-light);
  line-height: 1.5;
}

/* Responsive */
@media (max-width: 480px) {
  .woocommerce-order-pay .wp-block-post-content,
  .woocommerce-order-pay .entry-content {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .woocommerce-order-pay #order_review {
    padding: 1.25rem;
  }
}

/* ==========================================================================
   Thank You / Order Received Page
   ========================================================================== */
.woocommerce-order-received .woocommerce {
  max-width: 700px !important;
  margin: 0 auto !important;
}

.woocommerce-order-received .woocommerce-thankyou-order-received {
  font-family: 'Cormorant Garamond', 'Georgia', serif;
  font-size: 1.75rem;
  font-weight: 600;
  color: var(--rf-charcoal);
  text-align: center;
  margin-bottom: 2rem;
  padding: 1.5rem;
  background-color: rgba(72, 187, 120, 0.08);
  border: 1.5px solid rgba(72, 187, 120, 0.2);
  border-radius: 0.75rem;
}

.woocommerce-order-received .woocommerce-order-details,
.woocommerce-order-received .woocommerce-order-overview,
.woocommerce-order-received .woocommerce-customer-details {
  background-color: var(--rf-warm-white);
  border: 1.5px solid var(--rf-cream-dark);
  border-radius: 0.75rem;
  padding: 1.75rem;
  margin-bottom: 1.5rem;
}

.woocommerce-order-received .woocommerce-order-overview {
  list-style: none;
  padding-left: 1.75rem;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 1rem;
}

.woocommerce-order-received .woocommerce-order-overview li {
  font-size: 0.875rem;
  color: var(--rf-slate);
}

.woocommerce-order-received .woocommerce-order-overview li strong {
  display: block;
  font-size: 1rem;
  color: var(--rf-charcoal);
  margin-top: 0.25rem;
}

.woocommerce-order-received table.shop_table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9375rem;
}

.woocommerce-order-received table.shop_table th {
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  font-size: 0.8125rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--rf-slate);
  padding: 0.75rem 0;
  border-bottom: 2px solid var(--rf-cream-dark);
  text-align: left;
}

.woocommerce-order-received table.shop_table td {
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--rf-cream-dark);
  color: var(--rf-charcoal);
}

/* "Continue Shopping" button on thank-you page */
.rf-continue-shopping {
  display: block;
  max-width: 280px;
  margin: 2rem auto 0;
  padding: 1rem 2rem;
  font-family: 'Inter', sans-serif;
  font-size: 1.0625rem;
  font-weight: 600;
  color: var(--rf-warm-white);
  background-color: var(--rf-coral);
  border: none;
  border-radius: 0.5rem;
  text-align: center;
  text-decoration: none;
  transition: background-color 0.2s ease, transform 0.15s ease;
  letter-spacing: 0.01em;
}

.rf-continue-shopping:hover {
  background-color: var(--rf-coral-dark);
  color: var(--rf-warm-white);
  transform: translateY(-1px);
}

.rf-continue-shopping:active {
  transform: translateY(0);
}

/* ==========================================================================
   Loading/Processing States
   ========================================================================== */
.woocommerce-checkout .blockUI.blockOverlay {
  background: rgba(250, 247, 242, 0.7) !important;
}

.woocommerce-checkout .blockUI.blockOverlay::before {
  border-color: var(--rf-coral) transparent transparent transparent !important;
}

/* ==========================================================================
   Print Styles
   ========================================================================== */
@media print {
  .rf-header,
  .rf-footer {
    display: none;
  }
}
