/* ==========================================================================
   CRITICAL: Override WooCommerce Purple Branding
   MUST load after woocommerce.css - Version 20260127v10
   ========================================================================== */

/* Force all WooCommerce CSS variables to brand colors */
:root,
:root:root,
html,
body,
body.woocommerce-checkout {
    --woocommerce: #2D5530 !important;
    --wc-primary: #2D5530 !important;
    --wc-primary-text: #FFFFFF !important;
    --wc-secondary: #FAF9F6 !important;
    --wc-secondary-text: #2C2E30 !important;
    --wc-highlight: #D4A373 !important;
    --wc-content-bg: #fdfcf8 !important;
    --wp--preset--color--vivid-purple: #fdfcf8 !important;
}

/* ==========================================================================
   HELCIM PAYMENT GATEWAY - REMOVE ALL PURPLE/BRAND COLORS
   ========================================================================== */

/* Target ALL possible payment box containers */
.woocommerce-checkout #payment,
.woocommerce-checkout #payment ul.payment_methods,
.woocommerce-checkout #payment div.payment_box,
.woocommerce-checkout #payment .wc_payment_method,
.woocommerce-checkout .payment_method_helcimjs,
.woocommerce-checkout .payment_method_helcimjs .payment_box,
.woocommerce-checkout fieldset#wc-helcimjs-cc-form,
.woocommerce-checkout .wc-credit-card-form,
.woocommerce-checkout .wc-payment-form,
.woocommerce-checkout #helcimResults,
body #payment .payment_box,
body .payment_method_helcimjs .payment_box,
body fieldset#wc-helcimjs-cc-form {
    background: #fdfcf8 !important;
    background-color: #fdfcf8 !important;
    border: 1px solid #E5E2DB !important;
}

/* Payment box ::before pseudo-element (arrow/pointer) */
.woocommerce-checkout #payment div.payment_box::before,
.woocommerce-checkout .payment_method_helcimjs .payment_box::before,
body #payment div.payment_box::before {
    border-bottom-color: #fdfcf8 !important;
    border-color: transparent transparent #fdfcf8 transparent !important;
}

/* All form inputs in payment section */
.woocommerce-checkout #payment input[type="text"],
.woocommerce-checkout #payment input[type="tel"],
.woocommerce-checkout #payment input[type="number"],
.woocommerce-checkout #payment select,
.woocommerce-checkout #cardNumber,
.woocommerce-checkout #cardCVV,
.woocommerce-checkout #cardExpiryMonth,
.woocommerce-checkout #cardExpiryYear,
.woocommerce-checkout #cardHolderName,
.woocommerce-checkout #cardHolderAddress,
.woocommerce-checkout #cardHolderPostalCode,
body #cardNumber,
body #cardCVV,
body #cardExpiryMonth,
body #cardExpiryYear {
    background: #FFFFFF !important;
    background-color: #FFFFFF !important;
    border: 1px solid #E5E2DB !important;
    border-radius: 8px !important;
    padding: 12px !important;
    font-family: 'Inter', -apple-system, sans-serif !important;
    font-size: 1rem !important;
    color: #2C2E30 !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

/* CVV field can be narrower */
.woocommerce-checkout #cardCVV,
body #cardCVV {
    width: auto !important;
    min-width: 80px !important;
    max-width: 120px !important;
}

/* Focus states - brand green */
.woocommerce-checkout #payment input:focus,
.woocommerce-checkout #payment select:focus,
.woocommerce-checkout #cardNumber:focus,
.woocommerce-checkout #cardCVV:focus,
.woocommerce-checkout #cardExpiryMonth:focus,
.woocommerce-checkout #cardExpiryYear:focus {
    border-color: #2D5530 !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(45, 85, 48, 0.15) !important;
}

/* Labels */
.woocommerce-checkout #payment label,
.woocommerce-checkout .payment_method_helcimjs label,
.woocommerce-checkout .wc-credit-card-form label {
    font-family: 'Inter', -apple-system, sans-serif !important;
    font-size: 0.875rem !important;
    font-weight: 500 !important;
    color: #2C2E30 !important;
}

}

/* Override any elements with purple/violet inline styles */
.woocommerce-checkout [style*="purple"],
.woocommerce-checkout [style*="Purple"],
.woocommerce-checkout [style*="#9b51e0"],
.woocommerce-checkout [style*="#720eec"],
.woocommerce-checkout [style*="#800080"],
.woocommerce-checkout [style*="rgb(155"],
.woocommerce-checkout [style*="rgb(114"],
.woocommerce-checkout .has-vivid-purple-background-color,
.woocommerce-checkout .has-vivid-purple-color {
    background: #fdfcf8 !important;
    background-color: #fdfcf8 !important;
    color: #2C2E30 !important;
}

/* Place Order button - brand green */
.woocommerce-checkout #place_order,
.woocommerce-checkout button#place_order,
body #place_order {
    background: #2D5530 !important;
    background-color: #2D5530 !important;
    color: #FFFFFF !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 16px 32px !important;
    font-family: 'Inter', -apple-system, sans-serif !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    transition: background 0.2s ease !important;
}

.woocommerce-checkout #place_order:hover,
body #place_order:hover {
    background: #1E3A21 !important;
    background-color: #1E3A21 !important;
}

/**
 * Farmhouse Pet Supply - WooCommerce Bespoke Styles
 * Using native CSS Grid and design tokens
 * Responsive best practices - fluid widths and relative units
 */

/* ==========================================================================
   CART PAGE
   ========================================================================== */

.fps-cart {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: var(--space-xl) var(--gutter-mobile);
}

@media (min-width: 768px) {
    .fps-cart {
        padding: var(--space-3xl) var(--gutter-asymmetric);
    }
}

/* Cart Layout - CSS Grid */
.fps-cart__layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-2xl);
}

@media (min-width: 1024px) {
    .fps-cart__layout {
        grid-template-columns: 1fr minmax(280px, 32%);
        gap: var(--space-3xl);
        align-items: start;
    }
}

/* Cart Items Column */
.fps-cart__items {
    display: flex;
    flex-direction: column;
    gap: var(--space-lg);
}

.fps-cart__items-header {
    padding-bottom: var(--space-md);
    border-bottom: 1px solid var(--color-border);
}

.fps-cart__count {
    font-family: var(--font-body);
    font-size: 0.875rem;
    color: var(--color-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* Individual Cart Item */
.fps-cart__item {
    display: grid;
    grid-template-columns: clamp(80px, 20vw, 100px) 1fr;
    gap: var(--space-lg);
    padding: var(--space-lg) 0;
    border-bottom: 1px solid var(--color-border);
}

@media (min-width: 640px) {
    .fps-cart__item {
        grid-template-columns: clamp(100px, 15vw, 120px) 1fr;
    }
}

.fps-cart__item-image {
    aspect-ratio: 1;
    border-radius: var(--radius-md);
    overflow: hidden;
    background: var(--color-canvas);
}

.fps-cart__item-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.fps-cart__item-image a {
    display: block;
}

.fps-cart__item-details {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: var(--space-md);
}

.fps-cart__item-name {
    font-family: var(--font-display);
    font-size: 1.125rem;
    font-weight: 500;
    color: var(--color-charcoal);
    margin: 0;
    line-height: 1.3;
}

.fps-cart__item-name a {
    color: inherit;
    text-decoration: none;
}

.fps-cart__item-name a:hover {
    color: var(--color-forest);
}

.fps-cart__item-unit-price {
    font-size: 0.875rem;
    color: var(--color-muted);
    margin-top: var(--space-xs);
}

.fps-cart__item-controls {
    display: flex;
    align-items: center;
    gap: var(--space-lg);
    flex-wrap: wrap;
}

.fps-cart__item-quantity .quantity {
    display: flex;
    align-items: center;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
}

.fps-cart__item-quantity .qty {
    width: 3.5rem;
    height: 2.5rem;
    border: none;
    text-align: center;
    font-family: var(--font-body);
    font-size: 1rem;
    background: var(--color-white);
    -moz-appearance: textfield;
}

.fps-cart__item-quantity .qty::-webkit-outer-spin-button,
.fps-cart__item-quantity .qty::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.fps-cart__item-subtotal {
    font-family: var(--font-body);
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-charcoal);
}

.fps-cart__item-remove {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    color: var(--color-muted);
    transition: color 0.2s ease;
    margin-left: auto;
}

.fps-cart__item-remove:hover {
    color: #dc2626;
}

/* Cart Actions */
.fps-cart__actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: var(--space-lg);
    gap: var(--space-md);
    flex-wrap: wrap;
}

.fps-cart__continue {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    font-family: var(--font-body);
    font-size: 0.875rem;
    color: var(--color-muted);
    text-decoration: none;
    transition: color 0.2s ease;
}

.fps-cart__continue:hover {
    color: var(--color-forest);
}

.fps-cart__update {
    padding: var(--space-sm) var(--space-lg);
    background: transparent;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--color-charcoal);
    cursor: pointer;
    transition: all 0.2s ease;
}

.fps-cart__update:hover {
    border-color: var(--color-charcoal);
    background: var(--color-charcoal);
    color: var(--color-white);
}

/* Order Summary */
.fps-cart__summary {
    position: sticky;
    top: var(--space-xl);
}

.fps-cart__summary-inner {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-xl);
}

.fps-cart__summary-title {
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--color-charcoal);
    margin: 0 0 var(--space-lg);
    padding-bottom: var(--space-md);
    border-bottom: 1px solid var(--color-border);
}

.fps-cart__summary-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-sm) 0;
    font-family: var(--font-body);
    font-size: 0.9375rem;
    color: var(--color-charcoal);
}

.fps-cart__summary-row--discount {
    color: var(--color-forest);
}

.fps-cart__summary-row--total {
    padding-top: var(--space-md);
    margin-top: var(--space-sm);
    border-top: 1px solid var(--color-border);
    font-size: 1.125rem;
    font-weight: 600;
}

.fps-cart__summary-shipping {
    padding: var(--space-sm) 0;
}

.fps-cart__summary-shipping .woocommerce-shipping-totals td {
    padding: var(--space-xs) 0;
}

/* Coupon */
.fps-cart__coupon {
    display: flex;
    gap: var(--space-sm);
    margin-top: var(--space-lg);
    padding-top: var(--space-lg);
    border-top: 1px solid var(--color-border);
}

.fps-cart__coupon-input {
    flex: 1;
    padding: var(--space-sm) var(--space-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-size: 0.875rem;
}

.fps-cart__coupon-input:focus {
    outline: none;
    border-color: var(--color-forest);
}

.fps-cart__coupon-btn {
    padding: var(--space-sm) var(--space-lg);
    background: var(--color-forest);
    color: var(--color-white);
    border: none;
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-size: 0.875rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s ease;
}

.fps-cart__coupon-btn:hover {
    background: var(--color-forest-dark);
}

/* Checkout Button */
.fps-cart__checkout {
    margin-top: var(--space-lg);
}

.fps-cart__checkout-btn {
    display: block;
    width: 100%;
    padding: var(--space-md) var(--space-lg);
    background: var(--color-forest);
    color: var(--color-white);
    border: none;
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-size: 1rem;
    font-weight: 700;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    transition: background 0.2s ease;
}

.fps-cart__checkout-btn:hover {
    background: var(--color-forest-dark);
    color: var(--color-white);
}

/* Trust Badges */
.fps-cart__trust {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    margin-top: var(--space-lg);
    padding-top: var(--space-lg);
    border-top: 1px solid var(--color-border);
}

.fps-cart__trust-item {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    font-family: var(--font-body);
    font-size: 0.8125rem;
    color: var(--color-muted);
}

.fps-cart__trust-item svg {
    color: var(--color-forest);
    flex-shrink: 0;
}

/* Empty Cart */
.fps-cart--empty {
    min-height: 50vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

.fps-cart__empty-state {
    text-align: center;
    max-width: 25rem;
}

.fps-cart__empty-icon {
    color: var(--color-border);
    margin-bottom: var(--space-lg);
}

.fps-cart__empty-title {
    font-family: var(--font-display);
    font-size: 1.75rem;
    font-weight: 600;
    color: var(--color-charcoal);
    margin: 0 0 var(--space-md);
}

.fps-cart__empty-text {
    font-family: var(--font-body);
    font-size: 1rem;
    color: var(--color-muted);
    margin: 0 0 var(--space-xl);
    line-height: 1.6;
}

.fps-cart__empty-btn {
    display: inline-block;
    padding: var(--space-md) var(--space-2xl);
    background: var(--color-forest);
    color: var(--color-white);
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-size: 1rem;
    font-weight: 600;
    text-decoration: none;
    transition: background 0.2s ease;
}

.fps-cart__empty-btn:hover {
    background: var(--color-forest-dark);
    color: var(--color-white);
}

/* ==========================================================================
   CHECKOUT PAGE
   ========================================================================== */

.fps-checkout {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: var(--space-xl) var(--gutter-mobile);
}

@media (min-width: 768px) {
    .fps-checkout {
        padding: var(--space-3xl) var(--gutter-asymmetric);
    }
}

/* Checkout Layout - CSS Grid */
.fps-checkout__layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-2xl);
}

@media (min-width: 1024px) {
    .fps-checkout__layout {
        grid-template-columns: 1fr minmax(300px, 32%);
        gap: var(--space-3xl);
        align-items: start;
    }
}

/* Checkout Sections */
.fps-checkout__section {
    margin-bottom: var(--space-2xl);
}

.fps-checkout__section-title {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--color-charcoal);
    margin: 0 0 var(--space-lg);
}

.fps-checkout__section-number {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    background: var(--color-forest);
    color: var(--color-white);
    border-radius: 50%;
    font-family: var(--font-body);
    font-size: 0.875rem;
    font-weight: 600;
    flex-shrink: 0;
}

.fps-checkout__section-content {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-xl);
}

.fps-checkout__login-prompt {
    font-family: var(--font-body);
    font-size: 0.875rem;
    color: var(--color-muted);
    margin-bottom: var(--space-lg);
}

.fps-checkout__login-prompt a {
    color: var(--color-forest);
    text-decoration: underline;
}

/* Form Fields */
.fps-checkout .form-row {
    margin-bottom: var(--space-md);
}

.fps-checkout .form-row label {
    display: block;
    font-family: var(--font-body);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--color-charcoal);
    margin-bottom: var(--space-xs);
}

.fps-checkout .form-row .required {
    color: #dc2626;
}

.fps-checkout .form-row input[type="text"],
.fps-checkout .form-row input[type="email"],
.fps-checkout .form-row input[type="tel"],
.fps-checkout .form-row input[type="password"],
.fps-checkout .form-row select,
.fps-checkout .form-row textarea {
    width: 100%;
    padding: var(--space-sm) var(--space-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-size: 1rem;
    color: var(--color-charcoal);
    background: var(--color-white);
    transition: border-color 0.2s ease;
}

.fps-checkout .form-row input:focus,
.fps-checkout .form-row select:focus,
.fps-checkout .form-row textarea:focus {
    outline: none;
    border-color: var(--color-forest);
}

.fps-checkout .form-row-first,
.fps-checkout .form-row-last {
    width: 100%;
}

/* Billing/Shipping fields - single column layout */
.fps-checkout__fields {
    display: block !important;
}

/* Let WooCommerce billing wrapper handle its own grid */
.woocommerce-billing-fields__field-wrapper,
.woocommerce-shipping-fields__field-wrapper {
    display: block !important;
}

/* First/Last name side by side on desktop */
@media (min-width: 640px) {
    .woocommerce-billing-fields__field-wrapper,
    .woocommerce-shipping-fields__field-wrapper {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 1rem !important;
    }
    
    .woocommerce-billing-fields__field-wrapper .form-row-wide,
    .woocommerce-shipping-fields__field-wrapper .form-row-wide {
        grid-column: 1 / -1 !important;
    }
}


/* Shipping Methods */
.fps-checkout__shipping-methods .woocommerce-shipping-methods {
    list-style: none;
    padding: 0;
    margin: 0;
}

.fps-checkout__shipping-methods .woocommerce-shipping-methods li {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-sm);
    cursor: pointer;
    transition: border-color 0.2s ease;
}

.fps-checkout__shipping-methods .woocommerce-shipping-methods li:hover {
    border-color: var(--color-forest);
}

.fps-checkout__shipping-methods .woocommerce-shipping-methods li label {
    flex: 1;
    cursor: pointer;
    font-family: var(--font-body);
}

/* Payment Methods */
.fps-checkout .wc_payment_methods {
    list-style: none;
    padding: 0;
    margin: 0;
}

.fps-checkout .wc_payment_method {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-sm);
    overflow: hidden;
}

.fps-checkout .wc_payment_method > label {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-md);
    cursor: pointer;
    font-family: var(--font-body);
    font-weight: 500;
}

.fps-checkout .wc_payment_method .payment_box {
    padding: var(--space-md);
    background: #fdfcf8;
    border-top: 1px solid var(--color-border);
}

/* Place Order Button */
.fps-checkout #place_order {
    width: 100%;
    padding: var(--space-md) var(--space-lg);
    background: var(--color-forest);
    color: var(--color-white);
    border: none;
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    font-size: 1rem;
    font-weight: 700;
    cursor: pointer;
    transition: background 0.2s ease;
    margin-top: var(--space-lg);
}

.fps-checkout #place_order:hover {
    background: var(--color-forest-dark);
}

/* Order Summary Sidebar */
.fps-checkout__sidebar {
    position: sticky;
    top: var(--space-xl);
}

.fps-checkout__summary {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-xl);
}

.fps-checkout__summary-title {
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--color-charcoal);
    margin: 0 0 var(--space-lg);
    padding-bottom: var(--space-md);
    border-bottom: 1px solid var(--color-border);
}

.fps-checkout__summary-items {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    margin-bottom: var(--space-lg);
    padding-bottom: var(--space-lg);
    border-bottom: 1px solid var(--color-border);
}

.fps-checkout__summary-item {
    display: grid;
    grid-template-columns: 3.5rem 1fr auto;
    gap: var(--space-md);
    align-items: center;
}

.fps-checkout__summary-item-image {
    position: relative;
    border-radius: var(--radius-sm);
    overflow: hidden;
    background: var(--color-canvas);
}

.fps-checkout__summary-item-image img {
    width: 100%;
    height: auto;
    display: block;
}

.fps-checkout__summary-item-qty {
    position: absolute;
    top: -0.375rem;
    right: -0.375rem;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1.25rem;
    height: 1.25rem;
    background: var(--color-forest);
    color: var(--color-white);
    border-radius: 50%;
    font-size: 0.75rem;
    font-weight: 600;
}

.fps-checkout__summary-item-name {
    font-family: var(--font-body);
    font-size: 0.875rem;
    color: var(--color-charcoal);
}

.fps-checkout__summary-item-price {
    font-family: var(--font-body);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--color-charcoal);
}

.fps-checkout__summary-totals {
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
}

.fps-checkout__summary-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-xs) 0;
    font-family: var(--font-body);
    font-size: 0.9375rem;
    color: var(--color-charcoal);
}

.fps-checkout__summary-row--discount {
    color: var(--color-forest);
}

.fps-checkout__summary-row--total {
    padding-top: var(--space-md);
    margin-top: var(--space-sm);
    border-top: 1px solid var(--color-border);
    font-size: 1.125rem;
    font-weight: 600;
}

.fps-checkout__trust {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    margin-top: var(--space-lg);
    padding-top: var(--space-lg);
    border-top: 1px solid var(--color-border);
}

.fps-checkout__trust-item {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    font-family: var(--font-body);
    font-size: 0.8125rem;
    color: var(--color-muted);
}

.fps-checkout__trust-item svg {
    color: var(--color-forest);
    flex-shrink: 0;
}

/* ==========================================================================
   WOOCOMMERCE OVERRIDES
   ========================================================================== */

/* Hide default WooCommerce table styling on cart only */
.woocommerce-cart .shop_table {
    display: none;
}

/* Hide the WooCommerce order review table visually but keep in DOM for JS sync */
.woocommerce-checkout .woocommerce-checkout-review-order-table {
    position: absolute !important;
    left: -9999px !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
}

/* Order summary sidebar totals styling */
.fps-checkout__summary-totals {
    border-top: 1px solid var(--color-border, #E5E2DB);
    padding-top: 1rem;
    margin-top: 1rem;
}

.fps-checkout__summary-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.5rem 0;
    font-size: 0.9375rem;
    color: var(--color-charcoal, #2C2E30);
}

.fps-checkout__summary-row--tax {
    color: var(--color-muted, #6B7280);
    font-size: 0.875rem;
}

.fps-checkout__summary-row--muted {
    color: var(--color-muted, #6B7280);
    font-size: 0.875rem;
    font-style: italic;
}

/* Account creation section on checkout */
.fps-checkout__account-fields {
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--color-border, #E5E2DB);
}

.fps-checkout__account-fields .create-account {
    margin-bottom: 0;
}

.fps-checkout__account-fields .create-account > p.form-row {
    margin-bottom: 1rem;
}

.fps-checkout__account-fields label.checkbox {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    cursor: pointer;
    font-size: 0.9375rem;
    color: var(--color-charcoal, #2C2E30);
}

.fps-checkout__account-fields label.checkbox input[type="checkbox"] {
    width: 20px;
    height: 20px;
    accent-color: var(--color-forest, #2D5530);
    cursor: pointer;
}

.fps-checkout__account-fields .create-account > div {
    display: none;
}

.fps-checkout__account-fields .create-account.show-fields > div,
.woocommerce-account-fields:has(#createaccount:checked) .create-account > div,
.fps-checkout__account-fields .create-account--required > div {
    display: block !important;
}

/* Required account notice */
.fps-checkout__account-required-notice {
    background: var(--color-cream, #FAF9F6);
    border: 1px solid var(--color-border, #E5E2DB);
    border-left: 4px solid var(--color-forest, #2D5530);
    padding: 1rem 1.25rem;
    border-radius: 6px;
    margin-bottom: 1rem;
    font-size: 0.9375rem;
    line-height: 1.5;
}

.fps-checkout__account-required-notice strong {
    color: var(--color-forest, #2D5530);
}

.fps-checkout__account-required-notice small {
    color: var(--color-muted, #6B7280);
}

.fps-checkout__summary-row--total {
    border-top: 2px solid var(--color-charcoal, #2C2E30);
    margin-top: 0.5rem;
    padding-top: 0.75rem;
    font-weight: 700;
    font-size: 1.125rem;
}

.fps-checkout__summary-row--total span:last-child {
    color: var(--color-forest, #2D5530);
}

/* Override shipping calculator in cart */
.fps-cart .woocommerce-shipping-calculator {
    margin-top: var(--space-md);
}

.fps-cart .shipping-calculator-button {
    font-size: 0.8125rem;
    color: var(--color-forest);
    text-decoration: underline;
}

/* Notices */
.woocommerce-cart .woocommerce-message,
.woocommerce-cart .woocommerce-info,
.woocommerce-cart .woocommerce-error,
.woocommerce-checkout .woocommerce-message,
.woocommerce-checkout .woocommerce-info,
.woocommerce-checkout .woocommerce-error {
    padding: var(--space-md) var(--space-lg);
    margin-bottom: var(--space-lg);
    border-radius: var(--radius-md);
    font-family: var(--font-body);
    border-left: 4px solid var(--color-forest);
    background: rgba(45, 85, 48, 0.05);
}

.woocommerce-cart .woocommerce-error,
.woocommerce-checkout .woocommerce-error {
    border-left-color: #dc2626;
    background: rgba(220, 38, 38, 0.05);
}

/* Select2 overrides for country/state selectors */
.fps-checkout .select2-container--default .select2-selection--single {
    height: auto;
    padding: var(--space-sm) var(--space-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
}

.fps-checkout .select2-container--default .select2-selection--single .select2-selection__rendered {
    line-height: 1.5;
    padding: 0;
}

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

/* ==========================================================================
   CART VIDEO HERO
   Premium background video header for cart page
   ========================================================================== */

.cart-hero {
    position: relative;
    width: 100%;
    height: clamp(250px, 30vh, 280px);
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

@media (min-width: 768px) {
    .cart-hero {
        height: clamp(280px, 35vh, 340px);
    }
}

@media (min-width: 1024px) {
    .cart-hero {
        height: clamp(340px, 40vh, 400px);
    }
}

/* Media Container */
.cart-hero__media {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
}

/* Video Element */
.cart-hero__video {
    position: absolute;
    top: 50%;
    left: 50%;
    min-width: 100%;
    min-height: 100%;
    width: auto;
    height: auto;
    transform: translate(-50%, -50%);
    object-fit: cover;
    z-index: 1;
}

/* Fallback Image */
.cart-hero__fallback {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    z-index: 0;
}

/* Dark Overlay */
.cart-hero__overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.3) 0%, rgba(0, 0, 0, 0.5) 100%);
    z-index: 2;
}

/* Text Content */
.cart-hero__content {
    position: relative;
    z-index: 3;
    text-align: center;
    padding: var(--space-xl);
}

.cart-hero__title {
    font-family: var(--font-display);
    font-size: clamp(2.5rem, 8vw, 5rem);
    font-weight: 700;
    color: var(--color-white);
    margin: 0;
    letter-spacing: -0.02em;
    line-height: 1;
    text-shadow: 0 2px 20px rgba(0, 0, 0, 0.3);
}

/* Accessibility */
@media (prefers-reduced-motion: reduce) {
    .cart-hero__video {
        display: none;
    }
    .cart-hero__fallback {
        z-index: 1;
    }
}

.cart-hero__video {
    opacity: 1;
    transition: opacity 0.5s ease;
}

/* =====================================================
   FIX WOOCOMMERCE NOTICES (Returning customer, Coupon)
   Hide broken icon characters
   ===================================================== */

/* Hide the WooCommerce icon font characters in notices */
.woocommerce-info::before,
.woocommerce-message::before,
.woocommerce-error::before,
.woocommerce-notice::before {
    display: none !important;
    content: none !important;
}

/* Style the notices cleanly */
.woocommerce-info,
.woocommerce-message,
.woocommerce-notice {
    background: var(--color-canvas, #FAF9F6) !important;
    border: 1px solid var(--color-border, #E5E2DB) !important;
    border-left: 4px solid var(--color-forest, #2D5530) !important;
    border-radius: var(--radius-md, 8px) !important;
    padding: var(--space-lg, 1.5rem) !important;
    margin-bottom: var(--space-lg, 1.5rem) !important;
    color: var(--color-charcoal, #2C2E30) !important;
    font-family: var(--font-body, 'Inter', sans-serif) !important;
    font-size: 0.95rem !important;
    line-height: 1.6 !important;
}

.woocommerce-info a,
.woocommerce-message a,
.woocommerce-notice a {
    color: var(--color-forest, #2D5530) !important;
    font-weight: 600 !important;
    text-decoration: underline !important;
}

.woocommerce-info a:hover,
.woocommerce-message a:hover,
.woocommerce-notice a:hover {
    color: var(--color-forest-dark, #1E3A21) !important;
}

.woocommerce-error {
    border-left-color: #dc2626 !important;
}

/* =====================================================
   FIX PAYMENT SECTION - REMOVE NESTED BORDERS
   Clean up multiple border layers around credit card form
   ===================================================== */

/* Remove outer container border - let section content handle it */
.fps-checkout__section-content .woocommerce-checkout-payment,
.fps-checkout .woocommerce-checkout-payment,
#order_review .woocommerce-checkout-payment {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    border-radius: 0 !important;
}

/* Payment method item - single clean border */
.fps-checkout .wc_payment_method,
.woocommerce-checkout-payment .wc_payment_method,
#payment .wc_payment_method {
    border: 1px solid var(--color-border, #E5E2DB) !important;
    border-radius: var(--radius-md, 8px) !important;
    margin-bottom: var(--space-md, 1rem) !important;
    overflow: hidden !important;
    background: var(--color-white, #FFFFFF) !important;
}

/* Payment box inside - NO additional border, just background */
.fps-checkout .wc_payment_method .payment_box,
.woocommerce-checkout-payment .wc_payment_method .payment_box,
#payment .payment_box {
    background: #fdfcf8 !important;
    border: none !important;
    border-top: 1px solid var(--color-border, #E5E2DB) !important;
    padding: var(--space-lg, 1.5rem) !important;
    margin: 0 !important;
}

/* Remove the arrow/pointer on payment box */
#payment div.payment_box::before,
.wc_payment_method .payment_box::before {
    display: none !important;
}

/* Credit card form fieldset - NO border */
fieldset#wc-helcimjs-cc-form,
.wc-credit-card-form,
.wc-payment-form {
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
}

/* Form rows inside payment - clean spacing, no extra borders */
#payment .form-row,
.payment_box .form-row,
.wc-credit-card-form .form-row {
    border: none !important;
    margin-bottom: var(--space-md, 1rem) !important;
    padding: 0 !important;
}

/* Inputs should have single border */
#payment input[type="text"],
#payment input[type="tel"],
#payment select,
.payment_box input[type="text"],
.payment_box input[type="tel"],
.payment_box select {
    border: 1px solid var(--color-border, #E5E2DB) !important;
    border-radius: var(--radius-md, 8px) !important;
    padding: var(--space-md, 1rem) !important;
    background: var(--color-white, #FFFFFF) !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

#payment input:focus,
#payment select:focus,
.payment_box input:focus,
.payment_box select:focus {
    border-color: var(--color-forest, #2D5530) !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(45, 85, 48, 0.1) !important;
}

/* =====================================================
   COMPLETE PAYMENT SECTION BORDER FIX
   Remove ALL nested borders - only section-content has border
   ===================================================== */

/* The section-content is the ONLY container with a border */
/* Remove ALL borders from everything inside it */

/* Main payment wrapper - NO border */
.fps-checkout__section-content .woocommerce-checkout-payment,
.fps-checkout__section-content #payment,
.fps-checkout .woocommerce-checkout-payment,
.fps-checkout #payment,
#order_review,
.woocommerce-checkout-review-order {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* Payment methods list - NO border */
.fps-checkout__section-content .wc_payment_methods,
.fps-checkout .wc_payment_methods,
#payment .wc_payment_methods,
#payment ul.payment_methods,
ul.wc_payment_methods {
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    list-style: none !important;
}

/* Individual payment method - minimal styling */
.fps-checkout__section-content .wc_payment_method,
.fps-checkout .wc_payment_method,
#payment .wc_payment_method,
li.wc_payment_method {
    border: none !important;
    border-bottom: 1px solid var(--color-border, #E5E2DB) !important;
    border-radius: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
}

.fps-checkout__section-content .wc_payment_method:last-child,
.fps-checkout .wc_payment_method:last-child,
#payment .wc_payment_method:last-child {
    border-bottom: none !important;
}

/* Payment method label */
.fps-checkout__section-content .wc_payment_method > label,
.fps-checkout .wc_payment_method > label,
#payment .wc_payment_method > label {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    padding: 1rem 0 !important;
    cursor: pointer !important;
    font-weight: 500 !important;
    border: none !important;
}

/* Payment box (credit card form container) - NO border */
.fps-checkout__section-content .payment_box,
.fps-checkout .payment_box,
#payment .payment_box,
div.payment_box {
    background: var(--color-canvas, #FAF9F6) !important;
    border: none !important;
    border-radius: var(--radius-md, 8px) !important;
    padding: 1.5rem !important;
    margin: 0.5rem 0 1rem !important;
}

/* Remove the arrow pointer */
.payment_box::before,
#payment .payment_box::before,
div.payment_box::before {
    display: none !important;
    content: none !important;
}

/* Credit card form fieldset - NO border */
fieldset,
fieldset#wc-helcimjs-cc-form,
.wc-credit-card-form,
.wc-payment-form {
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    min-width: 0 !important;
}

/* Form rows - NO border */
.payment_box .form-row,
#payment .form-row,
.wc-credit-card-form .form-row,
.wc-payment-form .form-row,
p.form-row {
    border: none !important;
    padding: 0 !important;
    margin-bottom: 1rem !important;
}

/* Input fields - single clean border */
.payment_box input[type="text"],
.payment_box input[type="tel"],
.payment_box input[type="number"],
.payment_box select,
#payment input[type="text"],
#payment input[type="tel"],
#payment input[type="number"],
#payment select,
#cardNumber,
#cardCVV,
#cardExpiryMonth,
#cardExpiryYear {
    border: 1px solid var(--color-border, #E5E2DB) !important;
    border-radius: 8px !important;
    padding: 12px 16px !important;
    background: #FFFFFF !important;
    width: 100% !important;
    box-sizing: border-box !important;
    font-size: 1rem !important;
}

.payment_box input:focus,
.payment_box select:focus,
#payment input:focus,
#payment select:focus {
    border-color: var(--color-forest, #2D5530) !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(45, 85, 48, 0.1) !important;
}

/* Place order button area */
#payment .place-order,
.woocommerce-checkout-payment .place-order {
    border: none !important;
    padding: 1rem 0 0 !important;
    margin: 0 !important;
    background: transparent !important;
}

/* =====================================================
   PROFESSIONAL PAYMENT SECTION - v16
   Clean, trustworthy credit card form design
   ===================================================== */

/* Reset all payment containers - let section handle outer styling */
.fps-checkout__section-content #order_review,
.fps-checkout__section-content .woocommerce-checkout-review-order,
#payment,
#payment .wc_payment_methods {
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

#payment .wc_payment_methods {
    list-style: none !important;
    margin-bottom: 1rem !important;
}

/* Payment method card - single clean container */
#payment .wc_payment_method,
.fps-checkout .wc_payment_method {
    background: #FFFFFF !important;
    border: 2px solid var(--color-border, #E5E2DB) !important;
    border-radius: 12px !important;
    margin-bottom: 0.75rem !important;
    overflow: hidden !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04) !important;
}

/* Selected payment method - green border */
#payment .wc_payment_method.payment_method_helcimjs,
#payment .wc_payment_method:has(input:checked) {
    border-color: var(--color-forest, #2D5530) !important;
}

/* Payment method header/label - FLEX layout for proper alignment */
#payment .wc_payment_method > label,
.fps-checkout .wc_payment_method > label {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: flex-start !important;
    flex-wrap: nowrap !important;
    gap: 12px !important;
    padding: 16px 20px !important;
    margin: 0 !important;
    cursor: pointer !important;
    background: #FFFFFF !important;
    border: none !important;
    font-family: 'Inter', -apple-system, sans-serif !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    color: var(--color-charcoal, #2C2E30) !important;
    line-height: 1.4 !important;
}

/* Radio button styling */
#payment .wc_payment_method > label input[type="radio"] {
    flex-shrink: 0 !important;
    width: 20px !important;
    height: 20px !important;
    margin: 0 !important;
    accent-color: var(--color-forest, #2D5530) !important;
}

/* ============================================
   HELCIM LOGO - Show prominently in label
   ============================================ */
#payment .wc_payment_method > label img,
.fps-checkout .wc_payment_method > label img,
.payment_method_helcimjs > label img,
#payment img[src*="helcim"],
#payment img[alt*="Helcim"],
#payment img[alt*="helcim"],
img.helcim-logo,
img[src*="helcim_checkout_logo"] {
    display: inline-block !important;
    visibility: visible !important;
    opacity: 1 !important;
    height: 24px !important;
    max-height: 24px !important;
    width: auto !important;
    max-width: 100px !important;
    flex-shrink: 0 !important;
    margin-left: auto !important;
    position: static !important;
    left: auto !important;
    top: auto !important;
    clip: auto !important;
    overflow: visible !important;
}

/* Credit card form container - subtle background */
#payment .payment_box,
.fps-checkout .wc_payment_method .payment_box {
    background: #FAFAF8 !important;
    border: none !important;
    border-top: 1px solid var(--color-border, #E5E2DB) !important;
    padding: 24px 20px !important;
    margin: 0 !important;
}

/* Remove arrow pointer */
#payment .payment_box::before,
#payment div.payment_box::before {
    display: none !important;
    content: none !important;
}

/* Fieldset reset */
#payment fieldset,
#payment fieldset#wc-helcimjs-cc-form,
#payment .wc-credit-card-form,
#payment .wc-payment-form {
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    min-width: 0 !important;
    background: transparent !important;
}

/* Form row layout */
#payment .payment_box .form-row,
#payment .payment_box p.form-row {
    margin: 0 0 16px !important;
    padding: 0 !important;
    border: none !important;
}

#payment .payment_box .form-row:last-child {
    margin-bottom: 0 !important;
}

/* Form labels - consistent styling */
#payment .payment_box label {
    display: block !important;
    font-family: 'Inter', -apple-system, sans-serif !important;
    font-size: 0.875rem !important;
    font-weight: 600 !important;
    color: var(--color-charcoal, #2C2E30) !important;
    margin-bottom: 6px !important;
    text-align: left !important;
}

#payment .payment_box label .required {
    color: #DC2626 !important;
}

/* Input fields - professional styling */
#payment .payment_box input[type="text"],
#payment .payment_box input[type="tel"],
#payment .payment_box input[type="number"],
#payment .payment_box select,
#payment #cardNumber,
#payment #cardCVV,
#payment #cardExpiryMonth,
#payment #cardExpiryYear,
#payment #cardHolderName,
#payment #cardHolderAddress,
#payment #cardHolderPostalCode {
    display: block !important;
    width: 100% !important;
    padding: 14px 16px !important;
    border: 2px solid var(--color-border, #E5E2DB) !important;
    border-radius: 8px !important;
    background: #FFFFFF !important;
    font-family: 'Inter', -apple-system, sans-serif !important;
    font-size: 1rem !important;
    color: var(--color-charcoal, #2C2E30) !important;
    line-height: 1.4 !important;
    box-sizing: border-box !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    transition: border-color 0.15s ease, box-shadow 0.15s ease !important;
}

#payment .payment_box input:focus,
#payment .payment_box select:focus {
    border-color: var(--color-forest, #2D5530) !important;
    outline: none !important;
    box-shadow: 0 0 0 4px rgba(45, 85, 48, 0.12) !important;
}

#payment .payment_box input::placeholder {
    color: #9CA3AF !important;
}

/* Expiry/CVV inline layout */
#payment .payment_box .form-row-first,
#payment .payment_box .form-row-last {
    display: inline-block !important;
    width: calc(50% - 8px) !important;
    vertical-align: top !important;
    float: none !important;
}

#payment .payment_box .form-row-first {
    margin-right: 16px !important;
}

/* Select dropdown styling */
#payment .payment_box select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%232C2E30' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 16px center !important;
    padding-right: 44px !important;
}

/* Security message - professional trust indicator */
#payment .payment_box::after {
    content: "🔒 Secure payment powered by Helcim" !important;
    display: block !important;
    margin-top: 20px !important;
    padding-top: 16px !important;
    border-top: 1px solid var(--color-border, #E5E2DB) !important;
    font-family: 'Inter', -apple-system, sans-serif !important;
    font-size: 0.8125rem !important;
    font-weight: 500 !important;
    color: var(--color-muted, #6B7280) !important;
    text-align: center !important;
    letter-spacing: 0.01em !important;
}

/* Place Order button - prominent CTA */
#payment #place_order {
    display: block !important;
    width: 100% !important;
    padding: 18px 32px !important;
    margin-top: 20px !important;
    background: var(--color-forest, #2D5530) !important;
    color: #FFFFFF !important;
    border: none !important;
    border-radius: 10px !important;
    font-family: 'Inter', -apple-system, sans-serif !important;
    font-size: 1.125rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.01em !important;
    cursor: pointer !important;
    transition: background 0.2s ease, transform 0.1s ease !important;
    box-shadow: 0 2px 8px rgba(45, 85, 48, 0.25) !important;
}

#payment #place_order:hover {
    background: var(--color-forest-dark, #1E3A21) !important;
    box-shadow: 0 4px 12px rgba(45, 85, 48, 0.35) !important;
}

#payment #place_order:active {
    transform: scale(0.98) !important;
}

/* Terms and privacy */
#payment .woocommerce-terms-and-conditions-wrapper {
    margin: 16px 0 !important;
    padding: 0 !important;
}

#payment .woocommerce-privacy-policy-text {
    font-size: 0.8125rem !important;
    color: var(--color-muted, #6B7280) !important;
    line-height: 1.5 !important;
    text-align: left !important;
}

/* =====================================================
   BILLING/SHIPPING FIELDS - FULL WIDTH FIX (v17)
   Ensure fields take full width of container
   ===================================================== */

/* Main fields container - single column */
.fps-checkout__fields,
.fps-checkout__section-content .fps-checkout__fields {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
}

/* WooCommerce billing/shipping containers - full width */
.woocommerce-billing-fields,
.woocommerce-shipping-fields,
.woocommerce-additional-fields,
.fps-checkout__fields > div {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
}

/* Billing fields wrapper - handle its own grid for name fields */
.woocommerce-billing-fields__field-wrapper,
.woocommerce-shipping-fields__field-wrapper {
    display: block !important;
    width: 100% !important;
}

@media (min-width: 640px) {
    .woocommerce-billing-fields__field-wrapper,
    .woocommerce-shipping-fields__field-wrapper {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 1rem !important;
        width: 100% !important;
    }
    
    /* Full width fields span both columns */
    .woocommerce-billing-fields__field-wrapper .form-row-wide,
    .woocommerce-shipping-fields__field-wrapper .form-row-wide,
    .woocommerce-billing-fields__field-wrapper #billing_company_field,
    .woocommerce-billing-fields__field-wrapper #billing_address_1_field,
    .woocommerce-billing-fields__field-wrapper #billing_address_2_field,
    .woocommerce-billing-fields__field-wrapper #billing_city_field,
    .woocommerce-billing-fields__field-wrapper #billing_postcode_field,
    .woocommerce-billing-fields__field-wrapper #billing_country_field,
    .woocommerce-billing-fields__field-wrapper #billing_state_field {
        grid-column: 1 / -1 !important;
    }
    
    /* First/last name stay side by side */
    .woocommerce-billing-fields__field-wrapper #billing_first_name_field,
    .woocommerce-billing-fields__field-wrapper #billing_last_name_field {
        grid-column: auto !important;
    }
}

/* =====================================================
   FORM FIELD WIDTH FIX (v18)
   Override WooCommerce default narrow field widths
   ===================================================== */

/* All form rows in checkout - full width by default */
.fps-checkout .form-row,
.fps-checkout p.form-row,
.woocommerce-billing-fields .form-row,
.woocommerce-shipping-fields .form-row,
.woocommerce-billing-fields__field-wrapper .form-row,
.woocommerce-shipping-fields__field-wrapper .form-row,
.woocommerce-billing-fields__field-wrapper > p,
.woocommerce-shipping-fields__field-wrapper > p {
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
    clear: both !important;
    margin-right: 0 !important;
    margin-left: 0 !important;
    box-sizing: border-box !important;
}

/* Override WooCommerce form-row-first and form-row-last */
.fps-checkout .form-row-first,
.fps-checkout .form-row-last,
.woocommerce-billing-fields .form-row-first,
.woocommerce-billing-fields .form-row-last,
.woocommerce-shipping-fields .form-row-first,
.woocommerce-shipping-fields .form-row-last,
.woocommerce-billing-fields__field-wrapper .form-row-first,
.woocommerce-billing-fields__field-wrapper .form-row-last,
.woocommerce-shipping-fields__field-wrapper .form-row-first,
.woocommerce-shipping-fields__field-wrapper .form-row-last,
#billing_first_name_field,
#billing_last_name_field,
#shipping_first_name_field,
#shipping_last_name_field {
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
    clear: none !important;
    margin-right: 0 !important;
    box-sizing: border-box !important;
}

/* Inputs inside form rows - always full width */
.fps-checkout .form-row input[type="text"],
.fps-checkout .form-row input[type="email"],
.fps-checkout .form-row input[type="tel"],
.fps-checkout .form-row input[type="password"],
.fps-checkout .form-row select,
.fps-checkout .form-row textarea,
.woocommerce-billing-fields input[type="text"],
.woocommerce-billing-fields input[type="email"],
.woocommerce-billing-fields input[type="tel"],
.woocommerce-billing-fields select,
.woocommerce-shipping-fields input[type="text"],
.woocommerce-shipping-fields input[type="tel"],
.woocommerce-shipping-fields select {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
}

/* Shipping fields - same treatment */
.woocommerce-shipping-fields__field-wrapper #shipping_first_name_field,
.woocommerce-shipping-fields__field-wrapper #shipping_last_name_field,
.woocommerce-shipping-fields__field-wrapper #shipping_company_field,
.woocommerce-shipping-fields__field-wrapper #shipping_address_1_field,
.woocommerce-shipping-fields__field-wrapper #shipping_address_2_field,
.woocommerce-shipping-fields__field-wrapper #shipping_city_field,
.woocommerce-shipping-fields__field-wrapper #shipping_postcode_field,
.woocommerce-shipping-fields__field-wrapper #shipping_country_field,
.woocommerce-shipping-fields__field-wrapper #shipping_state_field {
    width: 100% !important;
    float: none !important;
}

/* Grid layout for name fields on desktop */
@media (min-width: 640px) {
    .woocommerce-billing-fields__field-wrapper,
    .woocommerce-shipping-fields__field-wrapper {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 1rem !important;
        width: 100% !important;
    }
    
    /* First name and last name - side by side, each taking full grid cell */
    #billing_first_name_field,
    #billing_last_name_field,
    #shipping_first_name_field,
    #shipping_last_name_field {
        grid-column: span 1 !important;
        width: 100% !important;
    }
    
    /* All other fields - full width across both columns */
    #billing_company_field,
    #billing_country_field,
    #billing_address_1_field,
    #billing_address_2_field,
    #billing_city_field,
    #billing_state_field,
    #billing_postcode_field,
    #shipping_company_field,
    #shipping_country_field,
    #shipping_address_1_field,
    #shipping_address_2_field,
    #shipping_city_field,
    #shipping_state_field,
    #shipping_postcode_field,
    .woocommerce-billing-fields__field-wrapper .form-row-wide,
    .woocommerce-shipping-fields__field-wrapper .form-row-wide {
        grid-column: 1 / -1 !important;
        width: 100% !important;
    }
}

/* =====================================================
   TRUST SIGNALS - Order Summary Sidebar
   ===================================================== */

.fps-checkout__trust {
    margin-top: 1.25rem !important;
    padding-top: 1rem !important;
    border-top: 1px solid var(--color-border, #E5E2DB) !important;
}

.fps-checkout__trust-item {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    font-size: 0.8125rem !important;
    color: var(--color-muted, #6B7280) !important;
    margin-bottom: 0.5rem !important;
}

.fps-checkout__trust-item:last-child {
    margin-bottom: 0 !important;
}

.fps-checkout__trust-item svg {
    flex-shrink: 0 !important;
    color: var(--color-forest, #2D5530) !important;
    stroke: var(--color-forest, #2D5530) !important;
}

.fps-checkout__trust-item a {
    color: var(--color-forest, #2D5530) !important;
    text-decoration: none !important;
    transition: color 0.2s ease !important;
}

.fps-checkout__trust-item a:hover {
    color: var(--color-forest-dark, #1E3A21) !important;
    text-decoration: underline !important;
}

/* =====================================================
   SAME AS BILLING CHECKBOX
   ===================================================== */

.fps-checkout__same-as-billing {
    margin-bottom: 1.5rem !important;
    padding-bottom: 1.5rem !important;
    border-bottom: 1px solid var(--color-border, #E5E2DB) !important;
}

.fps-checkout__checkbox-label {
    display: flex !important;
    align-items: center !important;
    gap: 0.75rem !important;
    cursor: pointer !important;
    font-family: 'Inter', -apple-system, sans-serif !important;
    font-size: 1rem !important;
    font-weight: 500 !important;
    color: var(--color-charcoal, #2C2E30) !important;
}

.fps-checkout__checkbox-label input[type="checkbox"] {
    width: 20px !important;
    height: 20px !important;
    accent-color: var(--color-forest, #2D5530) !important;
    cursor: pointer !important;
}

.fps-checkout__shipping-fields {
    margin-top: 1.5rem !important;
    padding-top: 1.5rem !important;
    border-top: 1px solid var(--color-border, #E5E2DB) !important;
}

/* Shipping methods within step 3 */
.fps-checkout__section-content .fps-checkout__shipping-methods {
    margin-top: 1.5rem !important;
}

/* ==========================================================================
   ORDER CONFIRMATION / THANK YOU PAGE
   ========================================================================== */

/* Order received page container */
.woocommerce-order-received .woocommerce {
    max-width: 900px;
    margin: 0 auto;
    padding: 2rem 1rem;
}

/* Order confirmation message */
.woocommerce-order-received .woocommerce-notice--success,
.woocommerce-order-received .woocommerce-thankyou-order-received {
    text-align: center;
    padding: 1.5rem;
    margin-bottom: 2rem;
    color: var(--color-forest, #2D5530);
    font-size: 1.125rem;
}

/* Order overview list - payment method, order number, etc. */
.woocommerce-order-overview {
    list-style: none;
    padding: 0;
    margin: 0 0 2rem 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 2rem;
    text-align: center;
}

.woocommerce-order-overview li {
    margin: 0;
    padding: 0;
}

.woocommerce-order-overview li strong {
    display: block;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-charcoal-light, #6B6B6B);
    margin-bottom: 0.25rem;
}

/* Order details section */
.woocommerce-order-received .woocommerce-order-details {
    margin-bottom: 2rem;
}

/* Order details heading */
.woocommerce-order-received .woocommerce-order-details h2,
.woocommerce-order-received section > h2 {
    font-size: 24px !important;
    font-weight: 600;
    color: var(--color-charcoal, #2C2E30);
    margin: 0 0 1rem 0;
}

/* Order details table */
.woocommerce-order-received .woocommerce-table--order-details {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 1.5rem;
}

.woocommerce-order-received .woocommerce-table--order-details th,
.woocommerce-order-received .woocommerce-table--order-details td {
    padding: 1rem;
    text-align: left;
    border-bottom: 1px solid var(--color-border, #E5E2DB);
    font-size: 16px;
    line-height: 1.5;
}

.woocommerce-order-received .woocommerce-table--order-details thead th {
    background-color: var(--color-cream, #FAF9F6);
    font-weight: 600;
    color: var(--color-charcoal, #2C2E30);
}

.woocommerce-order-received .woocommerce-table--order-details tfoot th,
.woocommerce-order-received .woocommerce-table--order-details tfoot td {
    font-weight: 600;
}

/* Customer details section - Billing & Shipping Addresses */
.woocommerce-customer-details {
    margin-top: 2rem;
    clear: both;
}

/* Two column layout for addresses - clean grid, no boxes */
.woocommerce-columns--addresses,
.col2-set.addresses,
.woocommerce-customer-details section {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 3rem !important;
    margin-bottom: 2rem;
    float: none !important;
    width: 100% !important;
}

@media (max-width: 768px) {
    .woocommerce-columns--addresses,
    .col2-set.addresses,
    .woocommerce-customer-details section {
        grid-template-columns: 1fr !important;
        gap: 2rem !important;
    }
}

/* Address column styling - NO boxes, clean layout */
.woocommerce-column--billing-address,
.woocommerce-column--shipping-address,
.col2-set .col-1,
.col2-set .col-2,
.woocommerce-customer-details .woocommerce-column {
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
    float: none !important;
    width: 100% !important;
    margin: 0 !important;
}

/* Address title - 24px as requested */
.woocommerce-column__title,
.woocommerce-customer-details h2,
.woocommerce-customer-details .woocommerce-column h2 {
    font-size: 24px !important;
    font-weight: 600 !important;
    color: var(--color-charcoal, #2C2E30) !important;
    margin: 0 0 1rem 0 !important;
    padding: 0 !important;
    border: none !important;
}

/* Address content - 16px with 1.5 line-height as requested */
.woocommerce-customer-details address {
    font-style: normal !important;
    font-size: 16px !important;
    line-height: 1.5 !important;
    color: var(--color-charcoal, #2C2E30) !important;
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
}

/* Phone and email in address - no extra borders */
.woocommerce-customer-details--phone,
.woocommerce-customer-details--email {
    margin-top: 0.5rem;
    padding: 0;
    border: none;
    font-size: 16px;
    line-height: 1.5;
}

/* Single column layout when no shipping */
.woocommerce-customer-details > h2:first-child {
    font-size: 24px !important;
    font-weight: 600;
    color: var(--color-charcoal, #2C2E30);
    margin: 0 0 1rem 0;
}

.woocommerce-customer-details > address {
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    font-size: 16px !important;
    line-height: 1.5 !important;
}

/* ==========================================================================
   MY ACCOUNT PAGE
   Using same design tokens as cart/checkout for brand consistency
   ========================================================================== */

.fps-account {
    max-width: var(--container-max, 1200px);
    margin: 0 auto;
    padding: var(--space-xl, 1.5rem) var(--gutter-mobile, 1rem);
}

@media (min-width: 768px) {
    .fps-account {
        padding: var(--space-3xl, 3rem) var(--gutter-asymmetric, 2rem);
    }
}

/* Account Layout - CSS Grid matching cart/checkout pattern */
.fps-account__layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-2xl, 2rem);
}

@media (min-width: 1024px) {
    .fps-account__layout {
        grid-template-columns: 280px 1fr;
        gap: var(--space-3xl, 3rem);
        align-items: start;
    }
}

/* Sidebar */
.fps-account__sidebar {
    position: sticky;
    top: var(--space-xl, 1.5rem);
}

.fps-account__nav {
    background: var(--color-canvas, #FAF9F6);
    border: 1px solid var(--color-border, #E5E2DB);
    border-radius: var(--radius-lg, 12px);
    overflow: hidden;
}

/* Nav Header - User Info */
.fps-account__nav-header {
    display: flex;
    align-items: center;
    gap: var(--space-md, 1rem);
    padding: var(--space-lg, 1.5rem);
    border-bottom: 1px solid var(--color-border, #E5E2DB);
    background: var(--color-white, #FFFFFF);
}

.fps-account__nav-avatar {
    flex-shrink: 0;
}

.fps-account__nav-avatar img {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
}

.fps-account__nav-user {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.fps-account__nav-greeting {
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.75rem;
    color: var(--color-muted, #6B7280);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.fps-account__nav-name {
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-charcoal, #2C2E30);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Nav List */
.fps-account__nav-list {
    list-style: none;
    padding: var(--space-sm, 0.5rem);
    margin: 0;
}

.fps-account__nav-item {
    margin: 0;
}

.fps-account__nav-link {
    display: flex;
    align-items: center;
    gap: var(--space-md, 1rem);
    padding: var(--space-md, 1rem) var(--space-lg, 1.5rem);
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.9375rem;
    font-weight: 500;
    color: var(--color-charcoal, #2C2E30);
    text-decoration: none;
    border-radius: var(--radius-md, 8px);
    transition: all 0.2s ease;
}

.fps-account__nav-link:hover {
    background: var(--color-white, #FFFFFF);
    color: var(--color-forest, #2D5530);
}

.fps-account__nav-link svg {
    flex-shrink: 0;
    color: var(--color-muted, #6B7280);
    transition: color 0.2s ease;
}

.fps-account__nav-link:hover svg {
    color: var(--color-forest, #2D5530);
}

/* Active nav item */
.fps-account__nav-item.is-active .fps-account__nav-link,
.fps-account__nav-item--active .fps-account__nav-link {
    background: var(--color-forest, #2D5530);
    color: var(--color-white, #FFFFFF);
}

.fps-account__nav-item.is-active .fps-account__nav-link svg,
.fps-account__nav-item--active .fps-account__nav-link svg {
    color: var(--color-white, #FFFFFF);
}

/* Logout link special styling */
.fps-account__nav-item--customer-logout .fps-account__nav-link {
    margin-top: var(--space-sm, 0.5rem);
    border-top: 1px solid var(--color-border, #E5E2DB);
    border-radius: 0 0 var(--radius-md, 8px) var(--radius-md, 8px);
    padding-top: var(--space-lg, 1.5rem);
}

/* Main Content Area */
.fps-account__content {
    min-width: 0;
}

/* Content Header */
.fps-account__header {
    margin-bottom: var(--space-xl, 1.5rem);
}

.fps-account__title {
    font-family: var(--font-display, 'Lora', serif);
    font-size: 1.75rem;
    font-weight: 600;
    color: var(--color-charcoal, #2C2E30);
    margin: 0;
}

.fps-account__subtitle {
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 1rem;
    color: var(--color-muted, #6B7280);
    margin: var(--space-sm, 0.5rem) 0 0;
}

/* Dashboard Quick Links */
.fps-account__quick-links {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md, 1rem);
    margin-bottom: var(--space-2xl, 2rem);
}

@media (min-width: 640px) {
    .fps-account__quick-links {
        grid-template-columns: repeat(4, 1fr);
    }
}

.fps-account__quick-link {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--space-sm, 0.5rem);
    padding: var(--space-lg, 1.5rem);
    background: var(--color-white, #FFFFFF);
    border: 1px solid var(--color-border, #E5E2DB);
    border-radius: var(--radius-lg, 12px);
    text-decoration: none;
    transition: all 0.2s ease;
}

.fps-account__quick-link:hover {
    border-color: var(--color-forest, #2D5530);
    box-shadow: 0 4px 12px rgba(45, 85, 48, 0.1);
    transform: translateY(-2px);
}

.fps-account__quick-link-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    background: var(--color-canvas, #FAF9F6);
    border-radius: 50%;
    color: var(--color-forest, #2D5530);
}

.fps-account__quick-link-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.fps-account__quick-link-title {
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--color-charcoal, #2C2E30);
}

.fps-account__quick-link-desc {
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.8125rem;
    color: var(--color-muted, #6B7280);
}

/* Recent Orders Section */
.fps-account__recent-orders {
    background: var(--color-white, #FFFFFF);
    border: 1px solid var(--color-border, #E5E2DB);
    border-radius: var(--radius-lg, 12px);
    padding: var(--space-xl, 1.5rem);
}

.fps-account__section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-lg, 1.5rem);
    padding-bottom: var(--space-md, 1rem);
    border-bottom: 1px solid var(--color-border, #E5E2DB);
}

.fps-account__section-title {
    font-family: var(--font-display, 'Lora', serif);
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--color-charcoal, #2C2E30);
    margin: 0;
}

.fps-account__section-link {
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--color-forest, #2D5530);
    text-decoration: none;
}

.fps-account__section-link:hover {
    text-decoration: underline;
}

/* Order Cards */
.fps-account__orders-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-md, 1rem);
}

.fps-account__order-card {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm, 0.5rem);
    padding: var(--space-md, 1rem);
    background: var(--color-canvas, #FAF9F6);
    border-radius: var(--radius-md, 8px);
}

.fps-account__order-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.fps-account__order-number {
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--color-charcoal, #2C2E30);
}

.fps-account__order-status {
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.75rem;
    font-weight: 500;
    padding: 4px 10px;
    border-radius: 100px;
    text-transform: capitalize;
}

.fps-account__order-status--processing {
    background: rgba(45, 85, 48, 0.1);
    color: var(--color-forest, #2D5530);
}

.fps-account__order-status--completed {
    background: rgba(45, 85, 48, 0.15);
    color: var(--color-forest, #2D5530);
}

.fps-account__order-status--on-hold {
    background: rgba(234, 179, 8, 0.15);
    color: #b45309;
}

.fps-account__order-status--pending {
    background: rgba(107, 114, 128, 0.15);
    color: var(--color-muted, #6B7280);
}

.fps-account__order-status--cancelled,
.fps-account__order-status--failed {
    background: rgba(220, 38, 38, 0.1);
    color: #dc2626;
}

.fps-account__order-details {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.875rem;
    color: var(--color-muted, #6B7280);
}

.fps-account__order-view {
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--color-forest, #2D5530);
    text-decoration: none;
    align-self: flex-start;
}

.fps-account__order-view:hover {
    text-decoration: underline;
}

/* ==========================================================================
   ORDERS PAGE
   ========================================================================== */

.fps-account__orders {
    background: var(--color-white, #FFFFFF);
    border: 1px solid var(--color-border, #E5E2DB);
    border-radius: var(--radius-lg, 12px);
    padding: var(--space-xl, 1.5rem);
}

.fps-account__orders .fps-account__header {
    padding-bottom: var(--space-lg, 1.5rem);
    border-bottom: 1px solid var(--color-border, #E5E2DB);
}

/* Orders Table */
.fps-account__orders-table-wrap {
    overflow-x: auto;
    margin-top: var(--space-lg, 1.5rem);
}

.fps-account__orders-table {
    width: 100%;
    border-collapse: collapse;
}

.fps-account__orders-th {
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-muted, #6B7280);
    text-align: left;
    padding: var(--space-sm, 0.5rem) var(--space-md, 1rem);
    border-bottom: 1px solid var(--color-border, #E5E2DB);
}

.fps-account__orders-row {
    border-bottom: 1px solid var(--color-border, #E5E2DB);
}

.fps-account__orders-row:last-child {
    border-bottom: none;
}

.fps-account__orders-td {
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.9375rem;
    color: var(--color-charcoal, #2C2E30);
    padding: var(--space-md, 1rem);
    vertical-align: middle;
}

.fps-account__order-link {
    font-weight: 600;
    color: var(--color-forest, #2D5530);
    text-decoration: none;
}

.fps-account__order-link:hover {
    text-decoration: underline;
}

/* Status Badges */
.fps-account__status-badge {
    display: inline-block;
    font-size: 0.75rem;
    font-weight: 500;
    padding: 4px 10px;
    border-radius: 100px;
    text-transform: capitalize;
}

.fps-account__status-badge--processing {
    background: rgba(45, 85, 48, 0.1);
    color: var(--color-forest, #2D5530);
}

.fps-account__status-badge--completed {
    background: rgba(45, 85, 48, 0.15);
    color: var(--color-forest, #2D5530);
}

.fps-account__status-badge--on-hold {
    background: rgba(234, 179, 8, 0.15);
    color: #b45309;
}

.fps-account__status-badge--pending {
    background: rgba(107, 114, 128, 0.15);
    color: var(--color-muted, #6B7280);
}

.fps-account__status-badge--cancelled,
.fps-account__status-badge--failed {
    background: rgba(220, 38, 38, 0.1);
    color: #dc2626;
}

/* Action Buttons */
.fps-account__action-btn {
    display: inline-block;
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.8125rem;
    font-weight: 500;
    padding: 6px 12px;
    border-radius: var(--radius-md, 8px);
    text-decoration: none;
    margin-right: 6px;
    transition: all 0.2s ease;
}

.fps-account__action-btn--view {
    background: var(--color-forest, #2D5530);
    color: var(--color-white, #FFFFFF);
}

.fps-account__action-btn--view:hover {
    background: var(--color-forest-dark, #1E3A21);
    color: var(--color-white, #FFFFFF);
}

.fps-account__action-btn--pay {
    background: #EAB308;
    color: #1F2937;
}

.fps-account__action-btn--pay:hover {
    background: #CA8A04;
}

.fps-account__action-btn--cancel {
    background: transparent;
    color: #dc2626;
    border: 1px solid #dc2626;
}

.fps-account__action-btn--cancel:hover {
    background: #dc2626;
    color: var(--color-white, #FFFFFF);
}

/* Pagination */
.fps-account__pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--space-md, 1rem);
    margin-top: var(--space-xl, 1.5rem);
    padding-top: var(--space-lg, 1.5rem);
    border-top: 1px solid var(--color-border, #E5E2DB);
}

.fps-account__pagination-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs, 0.25rem);
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--color-forest, #2D5530);
    text-decoration: none;
    padding: 8px 12px;
    border: 1px solid var(--color-border, #E5E2DB);
    border-radius: var(--radius-md, 8px);
    transition: all 0.2s ease;
}

.fps-account__pagination-btn:hover {
    border-color: var(--color-forest, #2D5530);
    background: var(--color-canvas, #FAF9F6);
}

.fps-account__pagination-info {
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.875rem;
    color: var(--color-muted, #6B7280);
}

/* Empty State */
.fps-account__empty {
    text-align: center;
    padding: var(--space-3xl, 3rem) var(--space-xl, 1.5rem);
}

.fps-account__empty-icon {
    color: var(--color-border, #E5E2DB);
    margin-bottom: var(--space-lg, 1.5rem);
}

.fps-account__empty-title {
    font-family: var(--font-display, 'Lora', serif);
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--color-charcoal, #2C2E30);
    margin: 0 0 var(--space-sm, 0.5rem);
}

.fps-account__empty-text {
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 1rem;
    color: var(--color-muted, #6B7280);
    margin: 0 0 var(--space-xl, 1.5rem);
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
}

.fps-account__empty-btn {
    display: inline-block;
    padding: var(--space-md, 1rem) var(--space-2xl, 2rem);
    background: var(--color-forest, #2D5530);
    color: var(--color-white, #FFFFFF);
    border-radius: var(--radius-md, 8px);
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 1rem;
    font-weight: 600;
    text-decoration: none;
    transition: background 0.2s ease;
}

.fps-account__empty-btn:hover {
    background: var(--color-forest-dark, #1E3A21);
    color: var(--color-white, #FFFFFF);
}

/* ==========================================================================
   LOGIN PAGE
   ========================================================================== */

.fps-login {
    max-width: var(--container-max, 1200px);
    margin: 0 auto;
    padding: var(--space-3xl, 3rem) var(--gutter-mobile, 1rem);
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 60vh;
}

.fps-login__container {
    width: 100%;
    max-width: 420px;
    background: var(--color-white, #FFFFFF);
    border: 1px solid var(--color-border, #E5E2DB);
    border-radius: var(--radius-lg, 12px);
    padding: var(--space-2xl, 2rem);
}

@media (min-width: 640px) {
    .fps-login__container {
        padding: var(--space-3xl, 3rem);
    }
}

.fps-login__header {
    text-align: center;
    margin-bottom: var(--space-xl, 1.5rem);
}

.fps-login__title {
    font-family: var(--font-display, 'Lora', serif);
    font-size: 1.75rem;
    font-weight: 600;
    color: var(--color-charcoal, #2C2E30);
    margin: 0 0 var(--space-sm, 0.5rem);
}

.fps-login__subtitle {
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.9375rem;
    color: var(--color-muted, #6B7280);
    margin: 0;
    line-height: 1.5;
}

/* Login Form */
.fps-login__form {
    display: flex;
    flex-direction: column;
    gap: var(--space-md, 1rem);
}

.fps-login__field {
    display: flex;
    flex-direction: column;
    gap: var(--space-xs, 0.25rem);
}

.fps-login__label {
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--color-charcoal, #2C2E30);
}

.fps-login__label .required {
    color: #dc2626;
}

.fps-login__input {
    width: 100%;
    padding: var(--space-md, 1rem);
    border: 1px solid var(--color-border, #E5E2DB);
    border-radius: var(--radius-md, 8px);
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 1rem;
    color: var(--color-charcoal, #2C2E30);
    background: var(--color-white, #FFFFFF);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    box-sizing: border-box;
}

.fps-login__input:focus {
    outline: none;
    border-color: var(--color-forest, #2D5530);
    box-shadow: 0 0 0 3px rgba(45, 85, 48, 0.1);
}

.fps-login__options {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: var(--space-sm, 0.5rem) 0;
}

.fps-login__remember {
    display: flex;
    align-items: center;
    gap: var(--space-sm, 0.5rem);
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.875rem;
    color: var(--color-charcoal, #2C2E30);
    cursor: pointer;
}

.fps-login__checkbox {
    width: 18px;
    height: 18px;
    accent-color: var(--color-forest, #2D5530);
    cursor: pointer;
}

.fps-login__forgot {
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.875rem;
    color: var(--color-forest, #2D5530);
    text-decoration: none;
}

.fps-login__forgot:hover {
    text-decoration: underline;
}

.fps-login__submit {
    width: 100%;
    padding: var(--space-md, 1rem) var(--space-lg, 1.5rem);
    background: var(--color-forest, #2D5530);
    color: var(--color-white, #FFFFFF);
    border: none;
    border-radius: var(--radius-md, 8px);
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s ease;
    margin-top: var(--space-sm, 0.5rem);
}

.fps-login__submit:hover {
    background: var(--color-forest-dark, #1E3A21);
}

/* Divider */
.fps-login__divider {
    display: flex;
    align-items: center;
    margin: var(--space-xl, 1.5rem) 0;
}

.fps-login__divider::before,
.fps-login__divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--color-border, #E5E2DB);
}

.fps-login__divider span {
    padding: 0 var(--space-md, 1rem);
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.8125rem;
    color: var(--color-muted, #6B7280);
    text-transform: lowercase;
}

/* Register Prompt */
.fps-login__register-prompt {
    text-align: center;
}

.fps-login__register-prompt p {
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.9375rem;
    color: var(--color-muted, #6B7280);
    margin: 0 0 var(--space-sm, 0.5rem);
}

.fps-login__register-link {
    display: inline-block;
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--color-forest, #2D5530);
    text-decoration: none;
}

.fps-login__register-link:hover {
    text-decoration: underline;
}

/* Trust Badge */
.fps-login__trust {
    display: flex;
    justify-content: center;
    margin-top: var(--space-xl, 1.5rem);
    padding-top: var(--space-lg, 1.5rem);
    border-top: 1px solid var(--color-border, #E5E2DB);
}

.fps-login__trust-item {
    display: flex;
    align-items: center;
    gap: var(--space-sm, 0.5rem);
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.8125rem;
    color: var(--color-muted, #6B7280);
}

.fps-login__trust-item svg {
    color: var(--color-forest, #2D5530);
}

/* ==========================================================================
   RESPONSIVE MOBILE TABLE
   ========================================================================== */

@media (max-width: 768px) {
    .fps-account__orders-table thead {
        display: none;
    }

    .fps-account__orders-table,
    .fps-account__orders-table tbody,
    .fps-account__orders-table tr,
    .fps-account__orders-table td {
        display: block;
        width: 100%;
    }

    .fps-account__orders-row {
        padding: var(--space-md, 1rem) 0;
        margin-bottom: var(--space-md, 1rem);
    }

    .fps-account__orders-td {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: var(--space-xs, 0.25rem) 0;
        border: none;
    }

    .fps-account__orders-td::before {
        content: attr(data-label);
        font-weight: 600;
        font-size: 0.8125rem;
        color: var(--color-muted, #6B7280);
        text-transform: uppercase;
        letter-spacing: 0.03em;
    }

    .fps-account__orders-td--actions {
        flex-wrap: wrap;
        gap: var(--space-sm, 0.5rem);
        justify-content: flex-end;
        padding-top: var(--space-sm, 0.5rem);
    }

    .fps-account__orders-td--actions::before {
        flex-basis: 100%;
    }
}

/* ==========================================================================
   MY ACCOUNT - CONTENT FORMS (Edit Account, Edit Address, etc.)
   ========================================================================== */

/* Wrap WooCommerce default content in the account card style */
.fps-account__content .woocommerce-MyAccount-content {
    background: var(--color-white, #FFFFFF);
    border: 1px solid var(--color-border, #E5E2DB);
    border-radius: var(--radius-lg, 12px);
    padding: var(--space-xl, 1.5rem);
}

/* Content page titles */
.fps-account__content .woocommerce-MyAccount-content > h2,
.fps-account__content .woocommerce-MyAccount-content > h3 {
    font-family: var(--font-display, 'Lora', serif);
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--color-charcoal, #2C2E30);
    margin: 0 0 var(--space-lg, 1.5rem);
    padding-bottom: var(--space-md, 1rem);
    border-bottom: 1px solid var(--color-border, #E5E2DB);
}

/* Form rows in account content */
.fps-account__content .woocommerce-form-row,
.fps-account__content .form-row {
    margin-bottom: var(--space-md, 1rem);
}

.fps-account__content .woocommerce-form-row label,
.fps-account__content .form-row label {
    display: block;
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--color-charcoal, #2C2E30);
    margin-bottom: var(--space-xs, 0.25rem);
}

.fps-account__content .woocommerce-form-row .required,
.fps-account__content .form-row .required {
    color: #dc2626;
}

/* Form inputs */
.fps-account__content input[type="text"],
.fps-account__content input[type="email"],
.fps-account__content input[type="password"],
.fps-account__content input[type="tel"],
.fps-account__content select,
.fps-account__content textarea {
    width: 100%;
    padding: var(--space-md, 1rem);
    border: 1px solid var(--color-border, #E5E2DB);
    border-radius: var(--radius-md, 8px);
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 1rem;
    color: var(--color-charcoal, #2C2E30);
    background: var(--color-white, #FFFFFF);
    box-sizing: border-box;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.fps-account__content input:focus,
.fps-account__content select:focus,
.fps-account__content textarea:focus {
    outline: none;
    border-color: var(--color-forest, #2D5530);
    box-shadow: 0 0 0 3px rgba(45, 85, 48, 0.1);
}

/* Save/Submit buttons */
.fps-account__content button[type="submit"],
.fps-account__content .button,
.fps-account__content .woocommerce-Button {
    display: inline-block;
    padding: var(--space-md, 1rem) var(--space-xl, 1.5rem);
    background: var(--color-forest, #2D5530);
    color: var(--color-white, #FFFFFF);
    border: none;
    border-radius: var(--radius-md, 8px);
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s ease;
    text-decoration: none;
}

.fps-account__content button[type="submit"]:hover,
.fps-account__content .button:hover,
.fps-account__content .woocommerce-Button:hover {
    background: var(--color-forest-dark, #1E3A21);
    color: var(--color-white, #FFFFFF);
}

/* Edit Address - Two column layout */
.fps-account__content .woocommerce-Addresses,
.fps-account__content .u-columns {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-xl, 1.5rem);
}

@media (min-width: 768px) {
    .fps-account__content .woocommerce-Addresses,
    .fps-account__content .u-columns {
        grid-template-columns: 1fr 1fr;
    }
}

.fps-account__content .woocommerce-Address,
.fps-account__content .u-column1,
.fps-account__content .u-column2 {
    background: var(--color-canvas, #FAF9F6);
    padding: var(--space-lg, 1.5rem);
    border-radius: var(--radius-md, 8px);
    width: auto !important;
    float: none !important;
}

.fps-account__content .woocommerce-Address-title {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-md, 1rem);
    padding-bottom: var(--space-sm, 0.5rem);
    border-bottom: 1px solid var(--color-border, #E5E2DB);
}

.fps-account__content .woocommerce-Address-title h3 {
    font-family: var(--font-display, 'Lora', serif);
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--color-charcoal, #2C2E30);
    margin: 0;
}

.fps-account__content .woocommerce-Address-title .edit {
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--color-forest, #2D5530);
    text-decoration: none;
}

.fps-account__content .woocommerce-Address-title .edit:hover {
    text-decoration: underline;
}

.fps-account__content address {
    font-style: normal;
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: 0.9375rem;
    line-height: 1.7;
    color: var(--color-charcoal, #2C2E30);
}

/* Downloads page - same card style */
.fps-account__content .woocommerce-table--order-downloads {
    width: 100%;
    border-collapse: collapse;
}

.fps-account__content .woocommerce-table--order-downloads th,
.fps-account__content .woocommerce-table--order-downloads td {
    padding: var(--space-md, 1rem);
    text-align: left;
    border-bottom: 1px solid var(--color-border, #E5E2DB);
    font-family: var(--font-body, 'Inter', sans-serif);
}

.fps-account__content .woocommerce-table--order-downloads th {
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-muted, #6B7280);
}

/* View Order page */
.fps-account__content .woocommerce-order-details {
    margin-bottom: var(--space-xl, 1.5rem);
}

.fps-account__content .woocommerce-order-details__title {
    font-family: var(--font-display, 'Lora', serif);
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--color-charcoal, #2C2E30);
    margin: 0 0 var(--space-md, 1rem);
}

.fps-account__content .woocommerce-table--order-details {
    width: 100%;
    border-collapse: collapse;
}

.fps-account__content .woocommerce-table--order-details th,
.fps-account__content .woocommerce-table--order-details td {
    padding: var(--space-md, 1rem);
    text-align: left;
    border-bottom: 1px solid var(--color-border, #E5E2DB);
    font-family: var(--font-body, 'Inter', sans-serif);
}

.fps-account__content .woocommerce-table--order-details thead th {
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-muted, #6B7280);
    background: var(--color-canvas, #FAF9F6);
}

.fps-account__content .woocommerce-table--order-details tfoot th {
    text-align: right;
}

/* Fieldset legend */
.fps-account__content fieldset {
    border: none;
    padding: 0;
    margin: var(--space-xl, 1.5rem) 0 0;
}

.fps-account__content legend {
    font-family: var(--font-display, 'Lora', serif);
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--color-charcoal, #2C2E30);
    padding: 0;
    margin-bottom: var(--space-md, 1rem);
}

/* Password change section in account details */
.fps-account__content .woocommerce-form-row--wide {
    grid-column: 1 / -1;
}

/* Notices within content */
.fps-account__content .woocommerce-message,
.fps-account__content .woocommerce-info,
.fps-account__content .woocommerce-error {
    padding: var(--space-md, 1rem) var(--space-lg, 1.5rem);
    margin-bottom: var(--space-lg, 1.5rem);
    border-radius: var(--radius-md, 8px);
    font-family: var(--font-body, 'Inter', sans-serif);
    border-left: 4px solid var(--color-forest, #2D5530);
    background: rgba(45, 85, 48, 0.05);
}

.fps-account__content .woocommerce-error {
    border-left-color: #dc2626;
    background: rgba(220, 38, 38, 0.05);
}

/* Hide default WooCommerce table borders */
.fps-account__content table {
    border: none;
}

/* ==========================================================================
   MY ACCOUNT - OVERRIDE PROSE-CONTAINER CONSTRAINTS
   The page.php template wraps content in prose-container (700px max-width)
   We need to break out of this for WooCommerce My Account pages
   ========================================================================== */

/* When fps-login or fps-account is inside prose-container, remove constraints */
.prose-container:has(.fps-login),
.prose-container:has(.fps-account),
.prose-container:has(.woocommerce-MyAccount-navigation) {
    max-width: none !important;
    padding: 0 !important;
    font-family: inherit !important;
    font-size: inherit !important;
    line-height: inherit !important;
}

/* Also target the parent section for proper spacing */
.page-content:has(.fps-login),
.page-content:has(.fps-account) {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

/* Hide the page hero for My Account when logged in - dashboard has its own header */
body.woocommerce-account.logged-in .page-hero {
    display: none;
}

/* Keep page hero for login page */
body.woocommerce-account:not(.logged-in) .page-hero--simple {
    margin-bottom: var(--space-lg, 1.5rem);
}

/* Fallback for browsers that don't support :has() */
@supports not selector(:has(*)) {
    .woocommerce-account .prose-container {
        max-width: none !important;
        padding: 0 !important;
    }
    
    .woocommerce-account .page-content {
        padding-top: 0 !important;
        padding-bottom: 0 !important;
    }
}

/* ==========================================================================
   MY ACCOUNT - UNIVERSAL OVERRIDES (No :has() dependency)
   ========================================================================== */

/* Override prose-container on ALL WooCommerce account pages */
body.woocommerce-account .prose-container {
    max-width: 1200px !important;
    padding: 0 !important;
    font-family: var(--font-body, 'Inter', sans-serif) !important;
    font-size: 1rem !important;
    line-height: 1.5 !important;
    color: var(--color-charcoal, #2C2E30) !important;
}

/* Override container-premium on account pages for full width */
body.woocommerce-account .container-premium {
    max-width: 1200px !important;
}

/* Remove page hero padding/margin issues */
body.woocommerce-account .page-hero--simple {
    padding-bottom: 0 !important;
    margin-bottom: 0 !important;
}

body.woocommerce-account .page-content.section-premium {
    padding-top: var(--space-xl, 1.5rem) !important;
}

/* Ensure fps-account takes full available width */
.fps-account {
    width: 100% !important;
    max-width: 1200px !important;
}

/* Ensure fps-login container is properly centered */
.fps-login {
    width: 100% !important;
}

/* Fix WooCommerce default My Account navigation if our custom one isn't loading */
body.woocommerce-account .woocommerce-MyAccount-navigation {
    background: var(--color-canvas, #FAF9F6);
    border: 1px solid var(--color-border, #E5E2DB);
    border-radius: var(--radius-lg, 12px);
    overflow: hidden;
    padding: var(--space-sm, 0.5rem);
}

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

body.woocommerce-account .woocommerce-MyAccount-navigation li {
    margin: 0;
}

body.woocommerce-account .woocommerce-MyAccount-navigation a {
    display: block;
    padding: var(--space-md, 1rem) var(--space-lg, 1.5rem);
    color: var(--color-charcoal, #2C2E30);
    text-decoration: none;
    border-radius: var(--radius-md, 8px);
    transition: all 0.2s ease;
}

body.woocommerce-account .woocommerce-MyAccount-navigation a:hover {
    background: var(--color-white, #FFFFFF);
    color: var(--color-forest, #2D5530);
}

body.woocommerce-account .woocommerce-MyAccount-navigation .is-active a {
    background: var(--color-forest, #2D5530);
    color: var(--color-white, #FFFFFF);
}

/* Ensure WooCommerce content area is styled if our template doesn't load */
body.woocommerce-account .woocommerce-MyAccount-content {
    background: var(--color-white, #FFFFFF);
    border: 1px solid var(--color-border, #E5E2DB);
    border-radius: var(--radius-lg, 12px);
    padding: var(--space-xl, 1.5rem);
}

/* ==========================================================================
   MY ACCOUNT - FORCE STYLES (High Specificity)
   These rules use high specificity to override any conflicting styles
   ========================================================================== */

/* Login page - force card styling */
body.woocommerce-account .woocommerce .fps-login {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 3rem 1rem !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    min-height: 50vh !important;
}

body.woocommerce-account .woocommerce .fps-login__container {
    width: 100% !important;
    max-width: 420px !important;
    background: #FFFFFF !important;
    border: 1px solid #E5E2DB !important;
    border-radius: 12px !important;
    padding: 2rem !important;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08) !important;
}

@media (min-width: 640px) {
    body.woocommerce-account .woocommerce .fps-login__container {
        padding: 3rem !important;
    }
}

body.woocommerce-account .woocommerce .fps-login__header {
    text-align: center !important;
    margin-bottom: 1.5rem !important;
}

body.woocommerce-account .woocommerce .fps-login__title {
    font-family: 'Lora', serif !important;
    font-size: 1.75rem !important;
    font-weight: 600 !important;
    color: #2C2E30 !important;
    margin: 0 0 0.5rem !important;
}

body.woocommerce-account .woocommerce .fps-login__subtitle {
    font-family: 'Inter', sans-serif !important;
    font-size: 0.9375rem !important;
    color: #6B7280 !important;
    margin: 0 !important;
    line-height: 1.5 !important;
}

body.woocommerce-account .woocommerce .fps-login__form {
    display: flex !important;
    flex-direction: column !important;
    gap: 1rem !important;
}

body.woocommerce-account .woocommerce .fps-login__field {
    display: flex !important;
    flex-direction: column !important;
    gap: 0.25rem !important;
}

body.woocommerce-account .woocommerce .fps-login__label {
    font-family: 'Inter', sans-serif !important;
    font-size: 0.875rem !important;
    font-weight: 500 !important;
    color: #2C2E30 !important;
}

body.woocommerce-account .woocommerce .fps-login__input {
    width: 100% !important;
    padding: 1rem !important;
    border: 1px solid #E5E2DB !important;
    border-radius: 8px !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 1rem !important;
    color: #2C2E30 !important;
    background: #FFFFFF !important;
    box-sizing: border-box !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
}

body.woocommerce-account .woocommerce .fps-login__input:focus {
    outline: none !important;
    border-color: #2D5530 !important;
    box-shadow: 0 0 0 3px rgba(45, 85, 48, 0.1) !important;
}

body.woocommerce-account .woocommerce .fps-login__options {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin: 0.5rem 0 !important;
}

body.woocommerce-account .woocommerce .fps-login__remember {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 0.875rem !important;
    color: #2C2E30 !important;
    cursor: pointer !important;
}

body.woocommerce-account .woocommerce .fps-login__forgot {
    font-family: 'Inter', sans-serif !important;
    font-size: 0.875rem !important;
    color: #2D5530 !important;
    text-decoration: none !important;
}

body.woocommerce-account .woocommerce .fps-login__forgot:hover {
    text-decoration: underline !important;
}

body.woocommerce-account .woocommerce .fps-login__submit {
    width: 100% !important;
    padding: 1rem 1.5rem !important;
    background: #2D5530 !important;
    color: #FFFFFF !important;
    border: none !important;
    border-radius: 8px !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: background 0.2s ease !important;
    margin-top: 0.5rem !important;
}

body.woocommerce-account .woocommerce .fps-login__submit:hover {
    background: #1E3A21 !important;
}

body.woocommerce-account .woocommerce .fps-login__divider {
    display: flex !important;
    align-items: center !important;
    margin: 1.5rem 0 !important;
}

body.woocommerce-account .woocommerce .fps-login__divider::before,
body.woocommerce-account .woocommerce .fps-login__divider::after {
    content: '' !important;
    flex: 1 !important;
    height: 1px !important;
    background: #E5E2DB !important;
}

body.woocommerce-account .woocommerce .fps-login__divider span {
    padding: 0 1rem !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 0.8125rem !important;
    color: #6B7280 !important;
}

body.woocommerce-account .woocommerce .fps-login__register-prompt {
    text-align: center !important;
}

body.woocommerce-account .woocommerce .fps-login__register-prompt p {
    font-family: 'Inter', sans-serif !important;
    font-size: 0.9375rem !important;
    color: #6B7280 !important;
    margin: 0 0 0.5rem !important;
}

body.woocommerce-account .woocommerce .fps-login__register-link {
    font-family: 'Inter', sans-serif !important;
    font-size: 0.9375rem !important;
    font-weight: 600 !important;
    color: #2D5530 !important;
    text-decoration: none !important;
}

body.woocommerce-account .woocommerce .fps-login__register-link:hover {
    text-decoration: underline !important;
}

body.woocommerce-account .woocommerce .fps-login__trust {
    display: flex !important;
    justify-content: center !important;
    margin-top: 1.5rem !important;
    padding-top: 1.5rem !important;
    border-top: 1px solid #E5E2DB !important;
}

body.woocommerce-account .woocommerce .fps-login__trust-item {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 0.8125rem !important;
    color: #6B7280 !important;
}

body.woocommerce-account .woocommerce .fps-login__trust-item svg {
    color: #2D5530 !important;
}
