/**
 * FabricLab Customers - Addresses Module
 * @version 3.4.0
 * Styles for my-address.php, form-edit-address.php, and form-edit-account.php
 * CHANGED: Stronger toggle selectors, password feedback container styles
 */

/* ==========================================================================
   My Addresses Page
   ========================================================================== */
.fl-addresses-page { max-width: 1150px; margin: 0 auto; }
.fl-addresses-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.fl-addresses-grid.fl-addresses-cols-1 { grid-template-columns: 1fr; max-width: 560px; }
@media (max-width: 768px) { .fl-addresses-grid { grid-template-columns: 1fr; } }

/* ==========================================================================
   Address Card
   ========================================================================== */
.fl-address-card { 
    background: white; 
    border-radius: 12px; 
    box-shadow: 0 1px 3px rgba(0,0,0,0.1); 
    overflow: hidden; 
    display: flex; 
    flex-direction: column; 
}

.fl-address-card-header { 
    display: flex; 
    align-items: center; 
    gap: 12px; 
    padding: 20px 24px; 
    border-bottom: 1px solid #f3f4f6; 
    background: white;
}

.fl-address-card-icon { 
    width: 28px; 
    height: 28px; 
    border-radius: 50%; 
    background: linear-gradient(135deg, #f97316, #ec4899); 
    display: flex; 
    align-items: center; 
    justify-content: center;
    flex-shrink: 0;
}
.fl-address-card-icon svg { width: 14px; height: 14px; color: white; }

.fl-address-card-title { 
    font-size: 18px; 
    font-weight: 600; 
    color: #1f2937; 
    margin: 0; 
}

.fl-address-card-body { flex: 1; padding: 24px; }

/* Address Content - Labeled Fields */
.fl-address-content { font-size: 14px; color: #1f2937; line-height: 1.6; }

.fl-address-field { display: flex; padding: 10px 0; border-bottom: 1px dashed #e5e7eb; }
.fl-address-field:last-child { border-bottom: none; }
.fl-address-label { flex: 0 0 120px; font-size: 13px; font-weight: 500; color: #6b7280; padding-right: 16px; }
.fl-address-value { flex: 1; font-size: 14px; font-weight: 500; color: #1f2937; }
.fl-address-field-address .fl-address-value { font-weight: 600; }

@media (max-width: 480px) {
    .fl-address-field { flex-direction: column; gap: 4px; }
    .fl-address-label { flex: none; font-size: 12px; }
}

/* Empty State */
.fl-address-empty { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 20px 0; min-height: 120px; }
.fl-address-empty-icon { width: 48px; height: 48px; background: #f3f4f6; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin-bottom: 12px; }
.fl-address-empty-icon svg { width: 24px; height: 24px; color: #9ca3af; }
.fl-address-empty p { font-size: 14px; color: #6b7280; margin: 0; }

/* Footer - Button Style */
.fl-address-card-footer { padding: 16px 24px; border-top: 1px solid #e5e7eb; background: #f9fafb; display: flex; justify-content: flex-end; }
.fl-address-btn { display: inline-flex; align-items: center; gap: 8px; padding: 10px 20px; font-size: 14px; font-weight: 600; background: white; color: #f97316; border: 1px solid #e5e7eb; border-radius: 6px; text-decoration: none; transition: background 0.2s, color 0.2s, border-color 0.2s; cursor: pointer; }
.fl-address-btn svg { width: 16px; height: 16px; flex-shrink: 0; }
.fl-address-btn:hover { background: #f97316; color: white; border-color: #f97316; }

/* ==========================================================================
   Edit Address Page and Edit Account Page - FULL WIDTH
   ========================================================================== */
.fl-edit-address-page,
.fl-edit-account-page { max-width: 1150px; margin: 0 auto; }

/* ==========================================================================
   Info Box - Alert Component (used on both pages)
   ========================================================================== */
.fl-info-box {
    display: flex;
    padding: 18px 20px;
    background: #eff6ff;
    border: 1px solid #93c5fd;
    border-radius: 12px;
    margin-bottom: 24px;
    align-items: flex-start;
    gap: 14px;
}

.fl-info-box-icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    background: linear-gradient(135deg, #3b82f6, #2563eb);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.fl-info-box-icon svg {
    width: 20px;
    height: 20px;
    color: white;
}

.fl-info-box-content { flex: 1; }

.fl-info-box-title {
    font-size: 15px;
    font-weight: 600;
    color: #1e40af;
    margin: 0 0 4px 0;
}

.fl-info-box-text {
    font-size: 14px;
    color: #1e40af;
    line-height: 1.5;
    margin: 0;
}

/* ==========================================================================
   WooCommerce Alerts - GLOBAL on account pages
   Big icons (38px), dashed separator between multiple errors
   ========================================================================== */
body.woocommerce-account .woocommerce-notices-wrapper .woocommerce-error,
body.woocommerce-account .woocommerce-notices-wrapper .woocommerce-message,
body.woocommerce-account .woocommerce-notices-wrapper .woocommerce-info,
body.woocommerce-account .woocommerce > .woocommerce-error,
body.woocommerce-account .woocommerce > .woocommerce-message,
body.woocommerce-account .woocommerce > .woocommerce-info,
body.woocommerce-account ul.woocommerce-error,
body.woocommerce-account div.woocommerce-message,
body.woocommerce-account div.woocommerce-info,
.fl-edit-address-page .woocommerce-error,
.fl-edit-address-page .woocommerce-message,
.fl-edit-address-page .woocommerce-info,
.fl-edit-account-page .woocommerce-error,
.fl-edit-account-page .woocommerce-message,
.fl-edit-account-page .woocommerce-info {
    display: block !important;
    padding: 18px 24px 18px 72px !important;
    border-radius: 12px !important;
    margin: 0 0 20px 0 !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    list-style: none !important;
    position: relative !important;
    box-shadow: none !important;
    max-width: 1150px !important;
}

body.woocommerce-account .woocommerce-error::before,
body.woocommerce-account .woocommerce-message::before,
body.woocommerce-account .woocommerce-info::before {
    display: none !important;
    content: none !important;
}

/* Alert icons - BIG size (38px) */
body.woocommerce-account .woocommerce-error::after,
body.woocommerce-account .woocommerce-message::after,
body.woocommerce-account .woocommerce-info::after {
    content: "" !important;
    position: absolute !important;
    left: 20px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 38px !important;
    height: 38px !important;
    background-size: contain !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
}

/* ERROR - Red styling */
body.woocommerce-account .woocommerce-error,
body.woocommerce-account ul.woocommerce-error {
    background: #fef2f2 !important;
    border: 1px solid #fca5a5 !important;
    color: #991b1b !important;
}

body.woocommerce-account .woocommerce-error::after {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23dc2626' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3ccircle cx='12' cy='12' r='10'/%3e%3cline x1='15' y1='9' x2='9' y2='15'/%3e%3cline x1='9' y1='9' x2='15' y2='15'/%3e%3c/svg%3e") !important;
}

/* SUCCESS - Green styling */
body.woocommerce-account .woocommerce-message,
body.woocommerce-account div.woocommerce-message {
    background: #d1fae5 !important;
    border: 1px solid #6ee7b7 !important;
    color: #065f46 !important;
}

body.woocommerce-account .woocommerce-message::after {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23059669' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='M22 11.08V12a10 10 0 1 1-5.93-9.14'/%3e%3cpolyline points='22 4 12 14.01 9 11.01'/%3e%3c/svg%3e") !important;
}

/* INFO - Blue styling */
body.woocommerce-account .woocommerce-info,
body.woocommerce-account div.woocommerce-info {
    background: #eff6ff !important;
    border: 1px solid #93c5fd !important;
    color: #1e40af !important;
}

body.woocommerce-account .woocommerce-info::after {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232563eb' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3ccircle cx='12' cy='12' r='10'/%3e%3cline x1='12' y1='16' x2='12' y2='12'/%3e%3cline x1='12' y1='8' x2='12.01' y2='8'/%3e%3c/svg%3e") !important;
}

/* Alert list items - with dashed separator between errors */
body.woocommerce-account .woocommerce-error li,
body.woocommerce-account .woocommerce-message li,
body.woocommerce-account .woocommerce-info li {
    list-style: none !important;
    padding: 8px 0 !important;
    margin: 0 !important;
    display: block !important;
    border-bottom: 1px dashed rgba(0,0,0,0.15) !important;
}

body.woocommerce-account .woocommerce-error li:first-child,
body.woocommerce-account .woocommerce-message li:first-child,
body.woocommerce-account .woocommerce-info li:first-child {
    padding-top: 0 !important;
}

body.woocommerce-account .woocommerce-error li:last-child,
body.woocommerce-account .woocommerce-message li:last-child,
body.woocommerce-account .woocommerce-info li:last-child {
    padding-bottom: 0 !important;
    border-bottom: none !important;
}

/* ==========================================================================
   Customer Type Toggle
   ========================================================================== */
.fl-edit-address-page .fl-form-card .fl-customer-type-toggle {
    display: flex !important;
    background: #f3f4f6 !important;
    border-radius: 10px !important;
    padding: 4px !important;
    margin-bottom: 20px !important;
}

.fl-edit-address-page .fl-form-card .fl-customer-type-toggle .fl-customer-type-btn {
    flex: 1 !important;
    padding: 12px 20px !important;
    background: transparent !important;
    border: none !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    color: #4b5563 !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    font-family: inherit !important;
    transition: all 0.2s !important;
    box-shadow: none !important;
}

.fl-edit-address-page .fl-form-card .fl-customer-type-toggle .fl-customer-type-btn svg {
    width: 20px !important;
    height: 20px !important;
    color: #6b7280 !important;
}

.fl-edit-address-page .fl-form-card .fl-customer-type-toggle .fl-customer-type-btn:hover:not(.active) {
    color: #1f2937 !important;
    background: transparent !important;
}

.fl-edit-address-page .fl-form-card .fl-customer-type-toggle .fl-customer-type-btn:hover:not(.active) svg {
    color: #374151 !important;
}

.fl-edit-address-page .fl-form-card .fl-customer-type-toggle .fl-customer-type-btn.active {
    background: #f97316 !important;
    color: white !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.1) !important;
}

.fl-edit-address-page .fl-form-card .fl-customer-type-toggle .fl-customer-type-btn.active svg {
    color: white !important;
}

/* ==========================================================================
   Company Fields Section
   ========================================================================== */
.fl-edit-address-page .fl-company-fields {
    margin-bottom: 24px !important;
    padding-bottom: 24px !important;
    border-bottom: 1px dashed #d1d5db !important;
}

.fl-edit-address-page .fl-company-alert {
    display: flex !important;
    padding: 14px 16px !important;
    background: #fef3c7 !important;
    border: 1px solid #fcd34d !important;
    border-radius: 8px !important;
    margin-bottom: 20px !important;
    align-items: flex-start !important;
    gap: 12px !important;
}

.fl-company-alert-icon { flex-shrink: 0; color: #f59e0b; margin-top: 2px; }
.fl-company-alert-icon svg { width: 18px; height: 18px; }
.fl-company-alert-content { flex: 1; }
.fl-company-alert-title { font-size: 14px; font-weight: 600; color: #111827; margin-bottom: 4px; }
.fl-company-alert-text { font-size: 13px; color: #374151; line-height: 1.5; }

/* ==========================================================================
   Form Card
   ========================================================================== */
.fl-form-card { background: white; border-radius: 12px; box-shadow: 0 1px 3px rgba(0,0,0,0.1); overflow: hidden; margin-bottom: 24px; }
.fl-form-card-header { display: flex; align-items: center; gap: 12px; padding: 20px 24px; border-bottom: 1px solid #f3f4f6; background: white; }
.fl-form-card-icon { width: 28px; height: 28px; border-radius: 50%; background: linear-gradient(135deg, #f97316, #ec4899); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.fl-form-card-icon svg { width: 14px; height: 14px; color: white; }
.fl-form-card-title-wrap { flex: 1; }
.fl-form-card-title { font-size: 18px; font-weight: 600; color: #111827; margin: 0; }
.fl-form-card-subtitle { font-size: 14px; color: #6b7280; margin: 4px 0 0 0; }
.fl-form-card-body { padding: 32px; }

/* Form Actions Card - special body without extra padding */
.fl-form-card-body.fl-form-actions-body {
    padding: 24px 32px;
}

.fl-form-card-body.fl-form-actions-body .fl-form-actions {
    margin-top: 0 !important;
    padding-top: 0 !important;
    border-top: none !important;
}

/* ==========================================================================
   Form Grid - 2 columns (shared for both address and account pages)
   ========================================================================== */
.fl-edit-address-page .fl-form-grid,
.fl-edit-account-page .fl-form-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 16px !important;
}

.fl-edit-address-page .fl-form-grid.fl-form-grid-single,
.fl-edit-account-page .fl-form-grid.fl-form-grid-single {
    grid-template-columns: 1fr !important;
}

@media (max-width: 600px) {
    .fl-edit-address-page .fl-form-grid,
    .fl-edit-account-page .fl-form-grid {
        grid-template-columns: 1fr !important;
    }
}

.fl-edit-address-page .fl-form-group,
.fl-edit-account-page .fl-form-group { 
    display: flex !important; 
    flex-direction: column !important; 
    gap: 6px !important; 
}

.fl-edit-address-page .fl-form-label,
.fl-edit-account-page .fl-form-label { 
    font-size: 13px !important; 
    font-weight: 500 !important; 
    color: #374151 !important; 
}

.fl-edit-address-page .fl-form-label .required,
.fl-edit-account-page .fl-form-label .required { 
    color: #f97316 !important; 
}

.fl-edit-address-page .fl-form-input,
.fl-edit-account-page .fl-form-input {
    width: 100% !important;
    padding: 12px 16px !important;
    font-size: 14px !important;
    border: 1px solid #d1d5db !important;
    border-radius: 8px !important;
    background: white !important;
    transition: border-color 0.2s, box-shadow 0.2s !important;
    box-sizing: border-box !important;
    font-family: inherit !important;
}

.fl-edit-address-page .fl-form-input:focus,
.fl-edit-account-page .fl-form-input:focus {
    outline: none !important;
    border-color: #f97316 !important;
    box-shadow: 0 0 0 3px #ffedd5 !important;
}

/* Field note under inputs */
.fl-edit-address-page .fl-field-note,
.fl-edit-account-page .fl-field-note {
    font-size: 12px;
    color: #6b7280;
    margin: 4px 0 0 0;
    line-height: 1.4;
}

/* ==========================================================================
   Password Field with Toggle - ALWAYS DARK GRAY
   ========================================================================== */
.fl-edit-account-page .fl-password-wrapper {
    position: relative;
    display: flex;
    align-items: center;
}

.fl-edit-account-page .fl-password-wrapper .fl-form-input {
    padding-right: 48px !important;
}

/* Password toggle button - ALWAYS dark gray, NO color change, NO background change */
.fl-edit-account-page .fl-password-toggle,
.fl-edit-account-page .fl-password-wrapper .fl-password-toggle,
.fl-edit-account-page .fl-password-wrapper button.fl-password-toggle,
body.woocommerce-account .fl-edit-account-page .fl-password-toggle {
    position: absolute !important;
    right: 12px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    background: none !important;
    background-color: transparent !important;
    border: none !important;
    padding: 4px !important;
    cursor: pointer !important;
    color: #6b7280 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 4px !important;
    z-index: 5 !important;
}

.fl-edit-account-page .fl-password-toggle:hover,
.fl-edit-account-page .fl-password-wrapper .fl-password-toggle:hover,
body.woocommerce-account .fl-edit-account-page .fl-password-toggle:hover {
    color: #4b5563 !important;
    background: none !important;
    background-color: transparent !important;
}

.fl-edit-account-page .fl-password-toggle:focus,
.fl-edit-account-page .fl-password-wrapper .fl-password-toggle:focus,
body.woocommerce-account .fl-edit-account-page .fl-password-toggle:focus {
    outline: none !important;
    color: #6b7280 !important;
    background: none !important;
    background-color: transparent !important;
}

.fl-edit-account-page .fl-password-toggle:active,
.fl-edit-account-page .fl-password-wrapper .fl-password-toggle:active,
body.woocommerce-account .fl-edit-account-page .fl-password-toggle:active {
    color: #6b7280 !important;
    background: none !important;
    background-color: transparent !important;
}

.fl-edit-account-page .fl-password-toggle svg,
.fl-edit-account-page .fl-password-wrapper .fl-password-toggle svg {
    width: 20px !important;
    height: 20px !important;
    color: inherit !important;
}

/* ==========================================================================
   Password Feedback Container - holds WooCommerce strength meter
   ========================================================================== */
.fl-edit-account-page .fl-password-fields-container {
    display: block;
}

.fl-edit-account-page .fl-password-feedback {
    display: block;
    width: 100%;
    margin-top: 16px;
}

/* ==========================================================================
   WooCommerce Password Strength Meter - FULL WIDTH below grid
   ========================================================================== */
.fl-edit-account-page .fl-password-feedback .woocommerce-password-strength,
.fl-edit-account-page .woocommerce-password-strength,
body.woocommerce-account .woocommerce-password-strength {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    margin-top: 0 !important;
    margin-bottom: 8px !important;
    padding: 12px 16px !important;
    border-radius: 8px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    text-align: left !important;
    box-sizing: border-box !important;
    clear: both !important;
    /* Reset any absolute positioning */
    top: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    transform: none !important;
}

/* Password strength colors */
.fl-edit-account-page .woocommerce-password-strength.short,
.fl-edit-account-page .fl-password-feedback .woocommerce-password-strength.short,
body.woocommerce-account .woocommerce-password-strength.short {
    background: #fef2f2 !important;
    border: 1px solid #fca5a5 !important;
    color: #991b1b !important;
}

.fl-edit-account-page .woocommerce-password-strength.bad,
.fl-edit-account-page .fl-password-feedback .woocommerce-password-strength.bad,
body.woocommerce-account .woocommerce-password-strength.bad {
    background: #fef2f2 !important;
    border: 1px solid #fca5a5 !important;
    color: #991b1b !important;
}

.fl-edit-account-page .woocommerce-password-strength.good,
.fl-edit-account-page .fl-password-feedback .woocommerce-password-strength.good,
body.woocommerce-account .woocommerce-password-strength.good {
    background: #fef3c7 !important;
    border: 1px solid #fcd34d !important;
    color: #92400e !important;
}

.fl-edit-account-page .woocommerce-password-strength.strong,
.fl-edit-account-page .fl-password-feedback .woocommerce-password-strength.strong,
body.woocommerce-account .woocommerce-password-strength.strong {
    background: #d1fae5 !important;
    border: 1px solid #6ee7b7 !important;
    color: #065f46 !important;
}

/* Password hint text that comes with strength meter - full width below */
.fl-edit-account-page .fl-password-feedback .woocommerce-password-hint,
.fl-edit-account-page .woocommerce-password-hint,
body.woocommerce-account .woocommerce-password-hint {
    display: block !important;
    width: 100% !important;
    margin-top: 0 !important;
    padding: 10px 14px !important;
    font-size: 12px !important;
    color: #6b7280 !important;
    line-height: 1.5 !important;
    background: #f9fafb !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 8px !important;
    box-sizing: border-box !important;
}

/* ==========================================================================
   WooCommerce Form Fields - 2 Column Grid (Address form)
   ========================================================================== */
.fl-edit-address-page .fl-address-form .woocommerce-address-fields__field-wrapper,
.fl-edit-address-page .fl-form-fields-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 16px !important;
}

.fl-edit-address-page .fl-address-form .form-row-wide {
    grid-column: span 2 !important;
    width: 100% !important;
    float: none !important;
    clear: both !important;
}

.fl-edit-address-page .fl-address-form .form-row-first {
    grid-column: 1 !important;
    width: 100% !important;
    float: none !important;
}

.fl-edit-address-page .fl-address-form .form-row-last {
    grid-column: 2 !important;
    width: 100% !important;
    float: none !important;
}

@media (max-width: 600px) {
    .fl-edit-address-page .fl-address-form .woocommerce-address-fields__field-wrapper,
    .fl-edit-address-page .fl-form-fields-grid {
        grid-template-columns: 1fr !important;
    }
    .fl-edit-address-page .fl-address-form .form-row-wide,
    .fl-edit-address-page .fl-address-form .form-row-first,
    .fl-edit-address-page .fl-address-form .form-row-last {
        grid-column: span 1 !important;
    }
}

/* ==========================================================================
   Country field displayed as text
   ========================================================================== */
.fl-edit-address-page .fl-address-form .form-row#billing_country_field strong,
.fl-edit-address-page .fl-address-form .form-row#shipping_country_field strong {
    display: block !important;
    padding: 12px 16px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    border: 1px solid #d1d5db !important;
    border-radius: 8px !important;
    background: #f9fafb !important;
    color: #111827 !important;
    line-height: 1.5 !important;
}

/* ==========================================================================
   Form Row and Input Styling
   ========================================================================== */
.fl-edit-address-page .fl-address-form .form-row {
    margin-bottom: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    position: relative !important;
}

.fl-edit-address-page .fl-address-form .form-row::before,
.fl-edit-address-page .fl-address-form .form-row::after {
    display: none !important;
    content: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    width: 0 !important;
    height: 0 !important;
}

.fl-edit-address-page .fl-address-form .form-row label {
    display: block !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    color: #374151 !important;
    margin-bottom: 6px !important;
}

.fl-edit-address-page .fl-address-form .form-row label .required {
    color: #f97316 !important;
}

.fl-edit-address-page .fl-address-form .form-row input.input-text,
.fl-edit-address-page .fl-address-form .form-row input[type="text"],
.fl-edit-address-page .fl-address-form .form-row input[type="email"],
.fl-edit-address-page .fl-address-form .form-row input[type="tel"],
.fl-edit-address-page .fl-address-form .form-row textarea,
.fl-edit-address-page .fl-address-form .form-row select {
    width: 100% !important;
    padding: 12px 16px !important;
    font-size: 14px !important;
    border: 1px solid #d1d5db !important;
    border-radius: 8px !important;
    background: white !important;
    transition: border-color 0.2s, box-shadow 0.2s !important;
    box-sizing: border-box !important;
    font-family: inherit !important;
    height: auto !important;
    line-height: 1.5 !important;
}

.fl-edit-address-page .fl-address-form .form-row input.input-text:focus,
.fl-edit-address-page .fl-address-form .form-row input[type="text"]:focus,
.fl-edit-address-page .fl-address-form .form-row input[type="email"]:focus,
.fl-edit-address-page .fl-address-form .form-row input[type="tel"]:focus,
.fl-edit-address-page .fl-address-form .form-row textarea:focus,
.fl-edit-address-page .fl-address-form .form-row select:focus {
    outline: none !important;
    border-color: #f97316 !important;
    box-shadow: 0 0 0 3px #ffedd5 !important;
}

/* ==========================================================================
   Select2 and Theme Select Container Overrides
   ========================================================================== */

/* HIDE THEME'S SELECT ARROW */
body.woocommerce-account .select_container::after,
body.woocommerce-account .select_container::before,
.fl-edit-address-page .select_container::after,
.fl-edit-address-page .select_container::before {
    display: none !important;
    content: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    width: 0 !important;
    height: 0 !important;
    font-size: 0 !important;
}

/* Container */
body.woocommerce-account .select2-container {
    width: 100% !important;
}

/* Main Select2 box */
body.woocommerce-account .select2-container--default .select2-selection--single {
    height: 48px !important;
    border: 1px solid #d1d5db !important;
    border-radius: 8px !important;
    background: white !important;
    background-image: none !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    position: relative !important;
}

/* KILL ::before on selection */
body.woocommerce-account .select2-container .select2-selection--single::before,
body.woocommerce-account .select2-container--default .select2-selection--single::before {
    display: none !important;
    content: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    width: 0 !important;
    height: 0 !important;
    background: none !important;
    background-image: none !important;
}

/* Text inside Select2 */
body.woocommerce-account .select2-container--default .select2-selection--single .select2-selection__rendered {
    line-height: 48px !important;
    padding-left: 16px !important;
    padding-right: 40px !important;
    font-size: 14px !important;
    color: #111827 !important;
}

/* HIDE Select2 arrow container completely */
body.woocommerce-account .select2-container--default .select2-selection--single .select2-selection__arrow,
body.woocommerce-account .select2-selection--single .select2-selection__arrow,
.select2-container--default .select2-selection--single .select2-selection__arrow {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    width: 0 !important;
    height: 0 !important;
    position: absolute !important;
    right: -9999px !important;
    top: -9999px !important;
    overflow: hidden !important;
    clip: rect(0,0,0,0) !important;
}

/* HIDE the b element inside arrow */
body.woocommerce-account .select2-selection__arrow b,
body.woocommerce-account .select2-container--default .select2-selection--single .select2-selection__arrow b,
.select2-selection__arrow b {
    display: none !important;
    visibility: hidden !important;
    border: none !important;
    border-color: transparent !important;
    width: 0 !important;
    height: 0 !important;
}

/* HIDE any SVG inside Select2 */
body.woocommerce-account .select2-selection--single svg,
body.woocommerce-account .select2-selection__arrow svg {
    display: none !important;
    visibility: hidden !important;
    width: 0 !important;
    height: 0 !important;
}

/* OUR single custom dropdown arrow */
body.woocommerce-account .select2-container--default .select2-selection--single::after {
    content: "" !important;
    display: block !important;
    position: absolute !important;
    right: 14px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 16px !important;
    height: 16px !important;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'/%3e%3c/svg%3e") !important;
    background-size: contain !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    pointer-events: none !important;
    z-index: 10 !important;
}

/* Focus state */
body.woocommerce-account .select2-container--default.select2-container--open .select2-selection--single,
body.woocommerce-account .select2-container--default.select2-container--focus .select2-selection--single {
    border-color: #f97316 !important;
    box-shadow: 0 0 0 3px #ffedd5 !important;
}

/* Dropdown panel */
.select2-container--default .select2-dropdown {
    border: 1px solid #d1d5db !important;
    border-radius: 8px !important;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
    margin-top: 4px !important;
}

.select2-container--default .select2-results__option {
    padding: 10px 16px !important;
    font-size: 14px !important;
}

.select2-container--default .select2-results__option--highlighted[aria-selected],
.select2-container--default .select2-results__option--highlighted[data-selected] {
    background-color: #f97316 !important;
    color: white !important;
}

.select2-container--default .select2-search--dropdown .select2-search__field {
    padding: 10px 12px !important;
    border: 1px solid #d1d5db !important;
    border-radius: 6px !important;
    font-size: 14px !important;
}

.select2-container--default .select2-search--dropdown .select2-search__field:focus {
    outline: none !important;
    border-color: #f97316 !important;
}

/* ==========================================================================
   Native Select Styling (when Select2 not active)
   ========================================================================== */
.fl-edit-address-page .fl-address-form select:not(.select2-hidden-accessible) {
    appearance: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e") !important;
    background-position: right 12px center !important;
    background-repeat: no-repeat !important;
    background-size: 20px !important;
    padding-right: 40px !important;
}

/* ==========================================================================
   Form Actions - Checkout Style Buttons (shared for both pages)
   ========================================================================== */
.fl-edit-address-page .fl-form-actions,
.fl-edit-account-page .fl-form-actions { 
    display: flex !important; 
    gap: 12px !important; 
    margin-top: 24px !important; 
    padding-top: 24px !important; 
    border-top: 1px solid #e5e7eb !important; 
}

.fl-edit-address-page .fl-btn-checkout-primary,
.fl-edit-account-page .fl-btn-checkout-primary { 
    display: inline-flex !important; 
    align-items: center !important; 
    justify-content: center !important; 
    gap: 8px !important; 
    padding: 14px 28px !important; 
    font-size: 15px !important; 
    font-weight: 600 !important; 
    background: linear-gradient(135deg, #f97316 0%, #ea580c 100%) !important; 
    color: white !important; 
    border: none !important; 
    border-radius: 8px !important; 
    cursor: pointer !important; 
    transition: all 0.2s ease !important; 
    text-decoration: none !important; 
    font-family: inherit !important;
    line-height: 1.5 !important;
}

.fl-edit-address-page .fl-btn-checkout-primary:hover,
.fl-edit-account-page .fl-btn-checkout-primary:hover { 
    box-shadow: 0 4px 12px rgba(249, 115, 22, 0.4) !important; 
    background: linear-gradient(135deg, #ea580c 0%, #dc2626 100%) !important; 
    color: white !important; 
}

.fl-edit-address-page .fl-btn-checkout-primary svg,
.fl-edit-account-page .fl-btn-checkout-primary svg { 
    width: 18px !important; 
    height: 18px !important; 
}

.fl-edit-address-page .fl-btn-checkout-secondary,
.fl-edit-account-page .fl-btn-checkout-secondary { 
    display: inline-flex !important; 
    align-items: center !important; 
    justify-content: center !important; 
    gap: 8px !important; 
    padding: 14px 28px !important; 
    font-size: 15px !important; 
    font-weight: 600 !important; 
    background: #f3f4f6 !important; 
    color: #374151 !important; 
    border: none !important; 
    border-radius: 8px !important; 
    cursor: pointer !important; 
    transition: all 0.2s ease !important; 
    text-decoration: none !important; 
    font-family: inherit !important;
    line-height: 1.5 !important;
}

.fl-edit-address-page .fl-btn-checkout-secondary:hover,
.fl-edit-account-page .fl-btn-checkout-secondary:hover { 
    background: #e5e7eb !important; 
    color: #1f2937 !important; 
}

.fl-edit-address-page .fl-btn-checkout-secondary svg,
.fl-edit-account-page .fl-btn-checkout-secondary svg { 
    width: 18px !important; 
    height: 18px !important; 
}

@media (max-width: 480px) {
    .fl-edit-address-page .fl-form-actions,
    .fl-edit-account-page .fl-form-actions { 
        flex-direction: column !important; 
    }
    .fl-edit-address-page .fl-form-actions .fl-btn-checkout-primary,
    .fl-edit-address-page .fl-form-actions .fl-btn-checkout-secondary,
    .fl-edit-account-page .fl-form-actions .fl-btn-checkout-primary,
    .fl-edit-account-page .fl-form-actions .fl-btn-checkout-secondary { 
        width: 100% !important; 
    }
}

/* ==========================================================================
   Field validation errors - Red border on invalid fields
   ========================================================================== */
/* WooCommerce invalid class on form-row */
.fl-edit-address-page .fl-address-form .woocommerce-invalid input.input-text,
.fl-edit-address-page .fl-address-form .woocommerce-invalid input[type="text"],
.fl-edit-address-page .fl-address-form .woocommerce-invalid select {
    border-color: #ef4444 !important;
    background-color: #fef2f2 !important;
}

/* WooCommerce invalid for Select2 */
.fl-edit-address-page .fl-address-form .woocommerce-invalid .select2-selection--single {
    border-color: #ef4444 !important;
    background-color: #fef2f2 !important;
}

/* Our custom fl-field-error class - for inputs */
.fl-edit-address-page input.fl-field-error,
.fl-edit-address-page select.fl-field-error,
.fl-edit-address-page .fl-form-input.fl-field-error,
.fl-edit-account-page input.fl-field-error,
.fl-edit-account-page select.fl-field-error,
.fl-edit-account-page .fl-form-input.fl-field-error,
body.woocommerce-account input.fl-field-error,
body.woocommerce-account select.fl-field-error {
    border-color: #ef4444 !important;
    background-color: #fef2f2 !important;
}

/* fl-field-error for Select2 */
.fl-edit-address-page .select2-selection--single.fl-field-error,
.fl-edit-account-page .select2-selection--single.fl-field-error,
body.woocommerce-account .select2-selection--single.fl-field-error {
    border-color: #ef4444 !important;
    background-color: #fef2f2 !important;
}
