/*
 * Custom Overrides CSS
 * File: custom-overrides.css
 * Purpose: Handle stubborn plugin conflicts and edge cases not covered by inline CSS
 * Load Order: This file loads at priority 999, after child theme but before final inline CSS
 */

/* =============================================================================
   1. GLOBAL TYPOGRAPHY AND LAYOUT OVERRIDES
   ============================================================================= */

/* Basic body and font settings */
body {
    font-family: 'Inter', sans-serif !important; /* Ensure 'Inter' is loaded if used */
    color: #333 !important;
    line-height: 1.6 !important;
    overflow-x: hidden !important;
    margin-top: 0 !important; /* No admin bar spacing needed */
}

/* Headings */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--heading-font-font-family) !important;
    color: var(--heading-color) !important;
    font-weight: var(--heading-font-weight, 700) !important;
}

/* Body text */
p, li, a, span {
    font-family: var(--body-font-font-family) !important;
    color: var(--text-color) !important;
}

/* Links */
a {
    color: var(--link-color) !important;
    text-decoration: none !important;
}

a:hover {
    color: var(--link-hover-color) !important;
    text-decoration: underline !important;
}

/* General button styles */
.button,
button,
input[type="button"],
input[type="submit"],
.wp-block-button__link {
    background-color: var(--primaryButtonBackgroundColor) !important;
    color: var(--primaryButtonTextColor) !important;
    border-radius: var(--primary-button-rounded-border-top-left-radius) !important;
    padding: var(--primary-button-padding-y) var(--primary-button-padding-x) !important;
    font-family: var(--heading-font-font-family) !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: .05em !important;
    border: var(--primary-button-stroke) solid transparent !important;
    font-size: 1rem !important;
    line-height: 1.2 !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
}

.button:hover,
button:hover,
input[type="button"]:hover,
input[type="submit"]:hover,
.wp-block-button__link:hover {
    background-color: var(--primaryButtonHoverBackgroundColor) !important;
    color: var(--primaryButtonHoverTextColor) !important;
    border-color: var(--primaryButtonHoverBorderColor) !important;
}

/* Form elements */
input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
textarea,
select {
    border: 1px solid var(--border-color, #ccc) !important;
    padding: var(--input-padding-y, .5em) var(--input-padding-x, .8em) !important;
    border-radius: var(--input-border-radius, 4px) !important;
    font-family: var(--body-font-font-family) !important;
    color: var(--text-color) !important;
    background-color: var(--input-background-color, #fff) !important;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="range"]:focus,
input[type="date"]:focus,
input[type="month"]:focus,
input[type="week"]:focus,
input[type="time"]:focus,
input[type="datetime"]:focus,
input[type="datetime-local"]:focus,
textarea:focus,
select:focus {
    border-color: var(--primaryButtonBackgroundColor) !important;
    box-shadow: 0 0 0 1px var(--primaryButtonBackgroundColor) !important;
    outline: none !important;
}

/* Block editor specific alignments */
.alignwide {
    margin-left: auto !important;
    margin-right: auto !important;
    max-width: var(--alignwide-width, 1000px) !important; /* Adjust as needed */
}

.alignfull {
    width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    max-width: none !important;
}

/* Images */
img {
    max-width: 100% !important;
    height: auto !important;
    display: block !important; /* Removes extra space below images */
}

/* General Layout Fixes */
.wp-site-blocks {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
}
main {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}
.wp-column {
    width: 100% !important;
    max-width: 100% !important;
    flex-basis: 100% !important;
    overflow-x: hidden !important;
}
html, body {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
}

/* =============================================================================
   2. WOOCOMMERCE SPECIFIC OVERRIDES
   ============================================================================= */

/* Fix WooCommerce checkout and cart button inconsistencies */
.woocommerce-cart .wc-proceed-to-checkout .checkout-button,
.woocommerce-checkout .place-order .button,
.woocommerce form.checkout #place_order,
.woocommerce #payment #place_order,
.woocommerce-page #payment #place_order {
    background-color: var(--primaryButtonBackgroundColor) !important;
    color: var(--primaryButtonTextColor) !important;
    border-radius: var(--primary-button-rounded-border-top-left-radius) !important;
    padding: var(--primary-button-padding-y) var(--primary-button-padding-x) !important;
    font-family: var(--heading-font-font-family) !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: .05em !important;
    border: var(--primary-button-stroke) solid transparent !important;
    font-size: 1rem !important;
    line-height: 1.2 !important;
}

/* WooCommerce quantity buttons and form elements */
.woocommerce .quantity .qty,
.woocommerce-page .quantity .qty {
    border-radius: var(--primary-button-rounded-border-top-left-radius) !important;
    border: 1px solid var(--border-color, #ccc) !important; /* Adjusted to use a more generic var or fallback */
    padding: var(--primary-button-padding-y, .5em) var(--primary-button-padding-x, .8em) !important;
    font-size: 1rem !important;
    line-height: 1.2 !important;
}

/* WooCommerce notices (success, info, error) */
.woocommerce-message, .woocommerce-info, .woocommerce-error {
    border-left-color: var(--primaryButtonBackgroundColor) !important; /* Example for message/info */
    background-color: var(--alert-background-color, #f8f8f8) !important;
    color: var(--text-color, #333) !important;
    font-family: var(--body-font-font-family) !important;
}
.woocommerce-error {
    border-left-color: var(--error-color, #ff0000) !important; /* Example for error */
}

/* WooCommerce input fields focus style */
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
    border-color: var(--primaryButtonBackgroundColor) !important;
    box-shadow: 0 0 0 1px var(--primaryButtonBackgroundColor) !important;
}

/* WooCommerce product grid alignment */
.woocommerce ul.products li.product {
    text-align: center !important;
}

/* Fix for WooCommerce specific button with inline style not respecting primary color */
button[style*="background-color: rgb(255, 255, 255)"],
button[style*="background"] {
    background-color: var(--primaryButtonBackgroundColor) !important;
}

/* Fix for pseudo-elements that might interfere with WooCommerce buttons */
.button::before,
.button::after,
.woocommerce .button::before,
.woocommerce .button::after {
    display: none !important;
}

/* =============================================================================
   3. CREDIT CARD TOOL RESULTS STYLING (PHP Output - Stacking Sections)
   ============================================================================= */

.recommendations-section {
    margin-top: 40px !important;
    padding: 30px !important;
    background: white !important;
    border-radius: 12px !important;
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1) !important;
    animation: fadeIn 0.8s ease-out !important;
    display: block !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

.recommendations-section h2 {
    text-align: center !important;
    color: #0056b3 !important;
    font-size: 2.2rem !important;
    margin-bottom: 30px !important;
    width: 100% !important;
}

.education-box {
    background: linear-gradient(135deg, #e6ffe6 0%, #d4ffd4 100%) !important;
    border: 1px solid #27ae60 !important;
    border-radius: 10px !important;
    padding: 20px !important;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05) !important;
    color: #333 !important;
    margin-top: 20px !important;
    margin-bottom: 30px !important;
    width: 100% !important;
    max-width: 800px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.education-box h3 {
    color: #27ae60 !important;
    margin-top: 0 !important;
    margin-bottom: 15px !important;
    font-size: 1.6rem !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
}

.education-box h3::before {
    content: "💡" !important;
    margin-right: 10px !important;
    font-size: 1.5em !important;
    line-height: 1 !important;
}

.education-box p {
    margin-bottom: 15px !important;
    line-height: 1.6 !important;
    text-align: left !important;
}

.education-list {
    list-style-type: disc !important;
    padding-left: 25px !important;
    margin: 0 !important;
    text-align: left !important;
}

.education-list li {
    margin-bottom: 8px !important;
    line-height: 1.4 !important;
    color: #555 !important;
}

.credit-card-list {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)) !important;
    gap: 25px !important;
    margin-top: 20px !important;
    margin-bottom: 30px !important;
    padding: 0 !important;
    width: 100% !important;
}

.credit-card-item {
    background: linear-gradient(145deg, #f9f9f9, #e9e9e9) !important;
    border: 1px solid #ddd !important;
    border-radius: 10px !important;
    padding: 25px !important;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08) !important;
    transition: transform 0.3s ease, box-shadow 0.3s ease !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    width: 100% !important;
    max-width: 450px !important;
    box-sizing: border-box !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.credit-card-item:hover {
    transform: translateY(-5px) !important;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.12) !important;
}

.credit-card-item .card-header {
    margin-bottom: 15px !important;
    padding-bottom: 10px !important;
    border-bottom: 1px dashed #ccc !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
}

/* FIX: Ensure H3 is consistently styled across all cards with high specificity */
body .credit-card-item .card-header h3 {
    font-size: 1.8rem !important;
    color: #0056b3 !important;
    margin: 0 0 5px 0 !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    word-break: break-word !important;
}

.credit-card-item .issuer {
    font-size: 0.95rem !important;
    color: #555 !important;
    margin-bottom: 8px !important;
}

.credit-card-item .welcome-bonus {
    background-color: #e8f0fe !important;
    border-left: 5px solid #3498db !important;
    padding: 8px 12px !important;
    border-radius: 6px !important;
    font-weight: 600 !important;
    color: #0056b3 !important;
    font-size: 0.9rem !important;
    margin-top: 5px !important;
}

.credit-card-item .card-details {
    flex-grow: 1 !important;
    margin-bottom: 20px !important;
    font-size: 0.95rem !important;
    line-height: 1.6 !important;
    color: #444 !important;
}

.credit-card-item .card-details ul {
    list-style-type: none !important;
    padding: 0 !important;
    margin: 15px 0 !important;
}

.credit-card-item .card-details ul li {
    margin-bottom: 5px !important;
    line-height: 1.4 !important;
}

.credit-card-item .recommendation-reason {
    font-style: italic !important;
    color: #666 !important;
    margin-bottom: 15px !important;
    line-height: 1.5 !important;
    border-top: 1px dotted #e0e0e0 !important;
    padding-top: 15px !important;
}

.credit-card-item .benefit-tags {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    margin-top: 15px !important;
    margin-bottom: 15px !important;
}

.credit-card-item .benefit-tag {
    background-color: #e0f2f7 !important;
    color: #2196f3 !important;
    padding: 6px 12px !important;
    border-radius: 20px !important;
    font-size: 0.85rem !important;
    font-weight: 500 !important;
    white-space: nowrap !important;
}

.credit-card-item .pros-cons {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 15px !important;
    margin-top: 15px !important;
    margin-bottom: 15px !important;
}

.credit-card-item .pros-cons > div {
    flex: 1 1 calc(50% - 7.5px) !important;
    box-sizing: border-box !important;
    min-width: 200px !important;
}

.credit-card-item .pros-cons h4 {
    font-size: 1.05rem !important;
    margin-top: 0 !important;
    margin-bottom: 8px !important;
}

.credit-card-item .pros-cons ul {
    list-style-type: disc !important;
    padding-left: 20px !important;
    margin: 0 !important;
}

.credit-card-item .pros-cons ul li {
    margin-bottom: 5px !important;
    line-height: 1.4 !important;
    color: #555 !important;
}

.credit-card-item .pros-cons > div:first-child {
    background-color: #f0fff0 !important;
    border: 1px solid #28a745 !important;
    border-radius: 8px !important;
    padding: 15px !important;
}

.credit-card-item .pros-cons > div:first-child h4 {
    color: #28a745 !important;
}

.credit-card-item .pros-cons > div:last-child {
    background-color: #fff0f0 !important;
    border: 1px solid #dc3545 !important;
    border-radius: 8px !important;
    padding: 15px !important;
}

.credit-card-item .pros-cons > div:last-child h4 {
    color: #dc3545 !important;
}

.credit-card-item .apply-button {
    display: block !important;
    width: 100% !important;
    padding: 12px 20px !important;
    background: #3498db !important;
    color: white !important;
    text-align: center !important;
    border-radius: 8px !important;
    text-decoration: none !important;
    font-size: 1.1rem !important;
    font-weight: bold !important;
    transition: background 0.3s ease !important;
    margin-top: auto !important;
}

.credit-card-item .apply-button:hover {
    background: #2980b9 !important;
}

.disclaimer {
    background-color: #fff8e1 !important;
    border: 1px solid #ffcc00 !important;
    border-left: 5px solid #ffcc00 !important;
    border-radius: 8px !important;
    padding: 15px 20px !important;
    margin-top: 30px !important;
    margin-bottom: 30px !important;
    font-size: 0.9rem !important;
    color: #666 !important;
    line-height: 1.5 !important;
    max-width: 800px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.disclaimer strong {
    color: #e67e22 !important;
}

/* =============================================================================
   4. CREDIT CARD TOOL GENERAL STRUCTURE (from previous CSS)
   ============================================================================= */

.credit-card-tool-container {
    background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%) !important;
    padding: 30px !important;
    margin: 40px auto !important;
    max-width: 1200px !important;
    border-radius: 12px !important;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.15) !important;
    font-family: Arial, sans-serif !important;
    color: #333 !important;
}
.tool-header {
    text-align: center !important;
    margin-bottom: 30px !important;
}

.tool-header h1 {
    color: #0056b3 !important;
    font-size: 2.5rem !important;
    margin-bottom: 10px !important;
}

.tool-header p {
    font-size: 1.1rem !important;
    color: #555 !important;
    line-height: 1.6 !important;
}

.form-container {
    background: white !important;
    padding: 30px !important;
    border-radius: 10px !important;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1) !important;
    margin-bottom: 30px !important;
}
.form-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
    gap: 20px !important;
    margin-bottom: 20px !important;
}
.form-group label {
    display: block !important;
    margin-bottom: 8px !important;
    font-weight: bold !important;
    color: #333 !important;
}

.form-group small {
    display: block !important;
    margin-top: 5px !important;
    font-size: 0.85rem !important;
    color: #6c757d !important;
}
input[type="number"],
select {
    width: 100% !important;
    padding: 12px 15px !important;
    border: 1px solid #ced4da !important;
    border-radius: 6px !important;
    font-size: 1rem !important;
    box-sizing: border-box !important;
    transition: border-color 0.2s ease-in-out, box-shadow 0.2s ease-in-out !important;
    background-color: #f8f9fa !important;
    color: #495057 !important;
}

input[type="number"]:focus,
select:focus {
    border-color: #80bdff !important;
    outline: 0 !important;
    box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25) !important;
}

.search-btn {
    width: 100% !important;
    padding: 15px !important;
    background: #3498db !important;
    color: white !important;
    border: none !important;
    border-radius: 8px !important;
    font-size: 1.2rem !important;
    font-weight: bold !important;
    cursor: pointer !important;
    transition: background 0.3s ease !important;
}
.search-btn:hover {
    background: #2980b9 !important;
}
.loading.show {
    display: flex !important;
}
.loading {
    display: none ;
    text-align: center !important;
    margin-top: 30px !important;
    color: #555 !important;
    font-size: 1.1rem !important;
}

.spinner {
    border: 4px solid rgba(0, 0, 0, 0.1) !important;
    border-left-color: #3498db !important;
    border-radius: 50% !important;
    width: 40px !important;
    height: 40px !important;
    animation: spin 1s linear infinite !important;
    margin: 0 auto 10px auto !important;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* Ensure credit card tool form elements align with site design */
.credit-card-tool-container input,
.credit-card-tool-container select,
.credit-card-tool-container button {
    font-family: var(--body-font-font-family) !important;
}

.credit-card-tool-container button[type="submit"] {
    background-color: var(--primaryButtonBackgroundColor) !important;
    color: var(--primaryButtonTextColor) !important;
    font-family: var(--heading-font-font-family) !important;
    text-transform: uppercase !important;
}

/* =============================================================================
   5. TUTOR LMS SPECIFIC OVERRIDES
   ============================================================================= */

/* Example: Tutor LMS button styling */
.tutor-btn {
    background-color: var(--primaryButtonBackgroundColor) !important;
    color: var(--primaryButtonTextColor) !important;
    border-radius: var(--primary-button-rounded-border-top-left-radius) !important;
    padding: var(--primary-button-padding-y) var(--primary-button-padding-x) !important;
    font-family: var(--heading-font-font-family) !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: .05em !important;
    border: var(--primary-button-stroke) solid transparent !important;
    font-size: 1rem !important;
    line-height: 1.2 !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
}

.tutor-btn:hover {
    background-color: var(--primaryButtonHoverBackgroundColor) !important;
    color: var(--primaryButtonHoverTextColor) !important;
    border-color: var(--primaryButtonHoverBorderColor) !important;
}

/* Ensure tutor form elements match site design */
.tutor-form-control {
    border: 1px solid var(--border-color, #ccc) !important;
    padding: var(--input-padding-y, .5em) var(--input-padding-x, .8em) !important;
    border-radius: var(--input-border-radius, 4px) !important;
    font-family: var(--body-font-font-family) !important;
    color: var(--text-color) !important;
    background-color: var(--input-background-color, #fff) !important;
}

.tutor-form-control:focus {
    border-color: var(--primaryButtonBackgroundColor) !important;
    box-shadow: 0 0 0 1px var(--primaryButtonBackgroundColor) !important;
    outline: none !important;
}

/* =============================================================================
   6. NAVIGATION FIXES
   ============================================================================= */

/* Header Positioning */
header.wp-block-template-part,
.site-header {
    position: relative !important;
    z-index: 10000 !important;
    background-color: #f5f5f5 !important;
    width: 100% !important;
    margin-top: 0 !important;
    padding: 1rem 0 !important;
}

/* Ensure the main navigation text is a darker color on this new background */
.wp-block-navigation-item__label {
    color: #333333 !important; /* Dark gray for contrast against light smoke gray */
}

/* Also ensure hover state has good contrast */
.wp-block-navigation-item:hover .wp-block-navigation-item__label,
.wp-block-navigation-item.current-menu-item .wp-block-navigation-item__label {
    color: #0073aa !important; /* Example: a blue for hover/active, or keep it dark gray */
}

/* Dropdown/Submenu Styling */
.wp-block-navigation-item {
    position: relative !important;
    z-index: 1 !important;
}

.wp-block-navigation__submenu-container {
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    z-index: 10000 !important;
    transform: translateZ(0) !important;
    background-color: white !important;
    border: 1px solid #ddd !important;
    border-radius: 8px !important;
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15) !important;
    min-width: 220px !important;
    padding: 0.5rem 0 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transform: translateY(-10px) !important;
    transition: all 0.3s ease !important;
}

.wp-block-navigation-item:hover, .wp-block-navigation-item.is-open {
    z-index: 9999 !important;
}

.wp-block-navigation-item:hover .wp-block-navigation__submenu-container {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateY(0) !important;
}

.wp-block-navigation__submenu-container .wp-block-navigation-item__content {
    display: block !important;
    padding: 0.75rem 1rem !important;
    color: #333 !important;
    border-radius: 0 !important;
}

.wp-block-navigation__submenu-container .wp-block-navigation-item__content:hover {
    background-color: #f8f9fa !important;
    color: #0073aa !important;
}

/* Navigation Accessibility */
.wp-block-navigation__responsive-container-open:focus,
.wp-block-navigation__responsive-container-close:focus,
.wp-block-navigation-item__content:focus {
    outline: 2px solid #0073aa !important;
    outline-offset: 2px !important;
}

/* Submenu Toggle Button (if present) */
.wp-block-navigation-submenu__toggle {
    background-color: transparent !important;
    border: none !important;
    padding: 0 !important;
    margin-left: 0.5rem !important;
}

.wp-block-navigation__submenu-icon {
    width: 0.6em !important;
    height: 0.6em !important;
    fill: currentColor !important;
}

/* =============================================================================
   7. HOMEPAGE CUSTOM BLOCK STYLES (Moved from Inline HTML)
   ============================================================================= */

/* Container for consistent width */
.container {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 0 1rem !important;
}

/* Hero Section Styling */
.hero-section {
    position: relative !important;
    height: 80vh !important; /* Adjust as needed */
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: white !important;
    text-align: center !important;
    overflow: hidden !important;
    background: linear-gradient(to right, #1a2a6c, #b21f1f, #fdbb2d) !important;
}

.hero-section .container {
    position: relative !important;
    z-index: 1 !important;
    background-color: rgba(0, 0, 0, 0.5) !important; /* Overlay for text readability */
    padding: 2rem !important;
    border-radius: 1rem !important;
}

.hero-section h1 {
    font-size: 3.5rem !important;
    font-weight: bold !important;
    margin-bottom: 1rem !important;
    line-height: 1.2 !important;
}

.hero-section p {
    font-size: 1.5rem !important;
    margin-bottom: 2rem !important;
}

/* Section General Styling */
section {
    padding: 4rem 0 !important;
    text-align: center !important;
}

section h2 {
    font-size: 2.5rem !important;
    font-weight: bold !important;
    margin-bottom: 1.5rem !important;
    color: #1a2a6c !important;
}

.section-subtitle {
    font-size: 1.2rem !important;
    color: #555 !important;
    margin-bottom: 3rem !important;
    max-width: 800px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Homepage Button Styling */
.button.primary {
    background-color: #007bff !important; /* Blue */
    color: white !important;
}

.button.primary:hover {
    background-color: #0056b3 !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 8px rgba(0, 0, 0, 0.15) !important;
}

/* Update secondary button styles for better contrast */
.button.secondary {
    background-color: #343a40 !important; /* Darker gray for better contrast */
    color: white !important;
    border: 1px solid #343a40 !important; /* Adding border for definition */
}

.button.secondary:hover {
    background-color: #23272b !important; /* Even darker on hover */
    color: white !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 8px rgba(0, 0, 0, 0.15) !important;
}



/* =============================================================================
   8. UTILITY AND PERFORMANCE OPTIMIZATIONS
   ============================================================================= */

/* Ensure smooth transitions don't cause layout shifts */
.button,
.woocommerce .button,
.tutor-btn {
    will-change: transform, box-shadow !important;
}

/* Stream button styles (from snippet, assuming these are general utility buttons) */
.stream-btn-primary {
    background: #007bff !important;
    color: white !important;
}
.stream-btn-primary:hover {
    background: #0056b3 !important;
}

.stream-btn-secondary {
    background: #6c757d !important;
    color: white !important;
}
.stream-btn-secondary:hover {
    background: #545b62 !important;
}

.stream-btn-success {
    background: #28a745 !important;
    color: white !important;
}
.stream-btn-success:hover {
    background: #218838 !important;
}

.stream-btn-danger {
    background: #dc3545 !important;
    color: white !important;
}
.stream-btn-danger:hover {
    background: #c82333 !important;
}

.stream-btn-warning {
    background: #ffc107 !important;
    color: #212529 !important;
}
.stream-btn-warning:hover {
    background: #e0a800 !important;
}

/* Chat Input Styling */
#chat-input {
    flex: 1 !important;
    padding: 8px !important;
    border: 1px solid #333 !important;
    border-radius: 4px !important;
    background: #222 !important;
    color: white !important;
    margin-right: 10px !important;
    font-size: 14px !important;
    visibility: inherit !important; /* Ensure visibility */
}

/* =============================================================================
   9. PRINT STYLES
   ============================================================================= */

@media print {
    .button,
    .woocommerce .button,
    .tutor-btn {
        display: none !important; /* Hide buttons when printing */
    }
    /* Add more print-specific styles here if needed */
}

/* =============================================================================
   10. RESPONSIVE ADJUSTMENTS
   ============================================================================= */

@media screen and (max-width: 768px) {
    /* Credit Card Tool Container */
    .credit-card-tool-container {
        padding: 20px !important;
        margin: 20px auto !important;
    }

    .tool-header h1 {
        font-size: 2rem !important;
    }

    .form-container {
        padding: 20px !important;
    }

    .form-grid {
        grid-template-columns: 1fr !important; /* Stack inputs on small screens */
    }

    .recommendation-item {
        padding: 15px !important;
    }

    .card-header {
        flex-direction: column !important;
        align-items: flex-start !important;
    }

    .credit-badge {
        margin-top: 10px !important;
    }

    .card-details {
        flex-direction: column !important;
        align-items: flex-start !important;
    }

    .detail-item {
        text-align: left !important;
        margin-bottom: 10px !important;
    }

    .pros-cons {
        flex-direction: column !important;
    }

    /* Wordpress Theme Overrides Responsive adjustments (MINOR ADJUSTMENTS) */
    .card-recommendation {
        padding: 20px !important; /* Slightly less padding on mobile */
    }

    .card-header {
        flex-direction: column !important;
        align-items: center !important;
        text-align: center !important;
    }

    .card-title-group {
        margin-right: 0 !important;
        margin-bottom: 10px !important; /* Space between title group and badge on mobile */
    }

    .credit-badge {
        margin-top: 10px !important;
        margin-left: 0 !important;
    }

    .card-details,
    .pros-cons {
        grid-template-columns: 1fr !important;
    }

    /* Mobile Navigation */
    /* 1. Keep desktop navigation hidden on mobile */
    .wp-block-navigation__container:not(.wp-block-navigation__responsive-container) {
        display: none !important;
    }

    /* 2. Simple, functional hamburger button */
    .wp-block-navigation__responsive-container-open {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        background: #f0f0f0 !important;
        border: 2px solid #333 !important;
        border-radius: 4px !important;
        cursor: pointer !important;
        padding: 8px !important;
        width: 40px !important;
        height: 40px !important;
        color: #333 !important;
    }

    .wp-block-navigation__responsive-container-open:hover {
        background: #e0e0e0 !important;
    }

    .wp-block-navigation__responsive-container-open svg {
        width: 20px !important;
        height: 20px !important;
        fill: #333 !important;
    }

    /* 3. Clean, functional mobile menu overlay */
    .wp-block-navigation__responsive-container {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        background-color: white !important;
        z-index: 999999 !important;
        padding: 60px 20px 20px 20px !important;
        overflow-y: auto !important;
        box-shadow: 0 0 20px rgba(0, 0, 0, 0.3) !important;
    }

    /* 4. Clear, visible close button */
    .wp-block-navigation__responsive-container-close {
        position: absolute !important;
        top: 15px !important;
        right: 15px !important;
        background: #f0f0f0 !important;
        border: 2px solid #333 !important;
        border-radius: 4px !important;
        color: #333 !important;
        font-size: 18px !important;
        cursor: pointer !important;
        padding: 8px !important;
        width: 40px !important;
        height: 40px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
    }

    .wp-block-navigation__responsive-container-close:hover {
        background: #e0e0e0 !important;
    }

    .wp-block-navigation__responsive-container-close svg {
        width: 20px !important;
        height: 20px !important;
        fill: #333 !important;
    }

    /* 5. Functional, visible menu items */
    .wp-block-navigation__responsive-container .wp-block-navigation__container {
        display: block !important;
        width: 100% !important;
        max-width: none !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    .wp-block-navigation__responsive-container .wp-block-navigation-item {
        display: block !important;
        width: 100% !important;
        margin: 0 0 1px 0 !important;
        padding: 0 !important;
    }

    .wp-block-navigation__responsive-container .wp-block-navigation-item__content {
        display: block !important;
        width: 100% !important;
        padding: 15px 20px !important;
        color: #333 !important;
        background: #f8f8f8 !important;
        border: 1px solid #ddd !important;
        border-radius: 4px !important;
        text-decoration: none !important;
        font-size: 16px !important;
        font-weight: 500 !important;
        text-align: left !important;
        box-sizing: border-box !important;
        margin-bottom: 5px !important;
    }

    .wp-block-navigation__responsive-container .wp-block-navigation-item__content:hover {
        background: #e8e8e8 !important;
        color: #0073aa !important;
        border-color: #0073aa !important;
    }

    /* 6. Current page styling */
    .wp-block-navigation__responsive-container .wp-block-navigation-item.current-menu-item .wp-block-navigation-item__content {
        background: #0073aa !important;
        color: white !important;
        border-color: #0073aa !important;
    }

    /* 7. Add some breathing room at top */
    .wp-block-navigation__responsive-container .wp-block-navigation__container::before {
        content: "Navigation Menu" !important;
        display: block !important;
        font-size: 18px !important;
        font-weight: bold !important;
        color: #333 !important;
        margin-bottom: 20px !important;
        padding-bottom: 10px !important;
        border-bottom: 2px solid #ddd !important;
        text-align: center !important;
    }

    /* 8. Ensure site logo/title stays visible on mobile */
    header.wp-block-template-part {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        padding: 15px 20px !important;
        background: #f5f5f5 !important;
    }

    /* Keep logo/site title visible */
    .wp-block-site-title, .wp-block-site-logo {
        display: block !important;
        flex: none !important;
        margin: 0 !important;
    }
    .wp-block-site-title a, .wp-block-site-logo a {
        color: #333 !important;
        text-decoration: none !important;
        font-size: 18px !important;
        font-weight: bold !important;
    }

    /* Position hamburger menu to the right */
    .wp-block-navigation {
        margin-left: auto !important;
        flex: none !important;
    }

    /* 9. Make sure menu items are actually clickable */
    .wp-block-navigation__responsive-container .wp-block-navigation-item__content {
        pointer-events: auto !important;
        cursor: pointer !important;
        position: relative !important;
        z-index: 1000000 !important;
    }

    
    /* 11. Prevent body scroll when menu is open */
    body:has(.wp-block-navigation__responsive-container) {
        overflow: hidden !important;
    }

    /* Fallback for browsers that don't support :has() */
    body.mobile-menu-open {
        overflow: hidden !important;
    }
}

@media screen and (min-width: 769px) {
    /* Desktop Navigation */
    /* Hide mobile elements on desktop */
    .wp-block-navigation__responsive-container-open,
    .wp-block-navigation__responsive-container-close {
        display: none !important;
    }

    /* Desktop navigation styling */
    .wp-block-navigation__container {
        display: flex !important;
        align-items: center !important;
        gap: 2rem !important;
    }

    .wp-block-navigation-item__content {
        color: #333 !important;
        text-decoration: none !important;
        padding: 0.5rem 1rem !important;
        transition: color 0.3s ease !important;
        border-radius: 4px !important;
    }

    .wp-block-navigation-item__content:hover {
        color: #0073aa !important;
        background-color: rgba(0, 115, 170, 0.1) !important;
    }
}
/* Ensure header always appears on top */
header.wp-block-template-part,
.site-header,
header.site-header {
    z-index: 9999 !important;
}

/* Ensure submenus are not covered */
.wp-block-navigation__submenu-container {
    z-index: 9999 !important;
}

/* Force navigation buttons to be clickable on Tutor pages */
body.tutor-frontend .wp-block-navigation-submenu__toggle,
body.tutor-frontend .wp-block-navigation__submenu-icon,
body.tutor-frontend .wp-block-navigation-item__content {
    pointer-events: auto !important;
    cursor: pointer !important;
    z-index: 999999 !important;
}

/* Ensure submenu containers can be shown */
body.tutor-frontend .wp-block-navigation__submenu-container {
    pointer-events: auto !important;
    z-index: 999999 !important;
}

/* Ensure submenu containers are properly positioned */
body.tutor-frontend .wp-block-navigation__submenu-container {
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    z-index: 999999 !important;
    background: white !important;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1) !important;
    border: 1px solid #ddd !important;
    min-width: 200px !important;
}

/* Initially hide all submenus */
body.tutor-frontend .wp-block-navigation__submenu-container {
    display: block !important;
    visibility: hidden !important;
    opacity: 0 !important;
    transition: opacity 0.3s ease, transform 0.3s ease !important;
    transform: translateY(-10px) !important;
}

body.tutor-frontend .wp-block-navigation-item:hover .wp-block-navigation__submenu-container,
body.tutor-frontend .wp-block-navigation-item.is-open .wp-block-navigation__submenu-container {
    visibility: visible !important;
    opacity: 1 !important;
    transform: translateY(0) !important;
}

/* High-specificity selector for secondary buttons */
html body .button.secondary,
html body button.secondary,
html body input[type="button"].secondary,
html body input[type="submit"].secondary,
html body .wp-block-button__link.secondary {
    background-color: #343a40 !important; /* Darker gray */
    color: white !important;
    border: 1px solid #343a40 !important;
}

html body .button.secondary:hover,
html body button.secondary:hover,
html body input[type="button"].secondary:hover,
html body input[type="submit"].secondary:hover,
html body .wp-block-button__link.secondary:hover {
    background-color: #23272b !important;
    color: white !important;
    border-color: #23272b !important;
}
.button.secondary,
button.secondary,
input[type="button"].secondary,
input[type="submit"].secondary,
.wp-block-button__link.secondary {
    --primaryButtonBackgroundColor: #343a40 !important;
    --primaryButtonTextColor: white !important;
    --primaryButtonHoverBackgroundColor: #23272b !important;
    --primaryButtonHoverTextColor: white !important;
}
/* Target anchor buttons with secondary class */
html body a.button.secondary {
    color: #000000 !important; /* Black text */
    background-color: #f8f9fa !important; /* Light background */
    border: 1px solid #dee2e6 !important; /* Light border */
}

html body a.button.secondary:hover {
    color: #000000 !important;
    background-color: #e9ecef !important;
    border-color: #dee2e6 !important;
}
/* For buttons that need dark text */
html body a.button.dark-text {
    color: #000000 !important;
    text-shadow: none !important;
}

html body a.button.dark-text:hover {
    color: #000000 !important;
}
/* Add this to your CSS file */
html body .container .state-section .state-content .state-resource-card a.button,
html body a.button[href^="http"] {
    color: white !important;
    background-color: #e74c3c !important;
}

html body .container .state-section .state-content .state-resource-card a.button:hover,
html body a.button[href^="http"]:hover {
    color: white !important;
    background-color: #c0392b !important;
}
/* Override Tutor LMS CSS variables */
:root {
    --tutor-color-primary: #007cba;
    --tutor-color-primary-hover: #005a87;
    --tutor-color-text: #000000;
}

/* Then apply to buttons */
.tutor-btn-primary {
    background-color: var(--tutor-color-primary) !important;
    color: #ffffff !important;
}

html body .tutor-btn:hover,
html body a.tutor-btn:hover {
    color: #000000 !important;
}

/* Specific styling for primary buttons */
html body .tutor-btn-primary {
    background-color: #007cba !important; /* WordPress blue */
    color: #ffffff !important; /* White text on blue background */
    border-color: #007cba !important;
}

html body .tutor-btn-primary:hover {
    background-color: #005a87 !important;
    color: #ffffff !important;
}
/* ============================================================================= 
   BUTTON TEXT VISIBILITY FIX - ADD THIS AT THE END OF YOUR CSS FILE
   ============================================================================= */

/* 1. Reset the global button text color override that's causing problems */
.button, button, .wp-block-button__link {
    color: inherit !important; /* Remove the forced white color */
}

/* 2. Target specific button types with appropriate colors */
/* Primary buttons - blue with white text */
.button.primary,
.wp-block-button__link.primary,
html body a.button.primary {
    background-color: #007bff !important;
    color: #ffffff !important;
    border-color: #007bff !important;
}

/* Secondary buttons - dark gray with white text */
.button.secondary,
.wp-block-button__link.secondary,
html body a.button.secondary {
    background-color: #343a40 !important;
    color: #ffffff !important;
    border-color: #343a40 !important;
}

/* 3. Fix for state resource cards in government resources page */
html body .state-resource-card a.button {
    background-color: #e74c3c !important;
    color: #ffffff !important;
}

html body .state-resource-card a.button:hover {
    background-color: #c0392b !important;
    color: #ffffff !important;
}

/* 4. Fix for Tutor LMS buttons */
html body a.tutor-btn.tutor-btn-primary,
html body .tutor-btn.tutor-btn-primary {
    background-color: #007cba !important;
    color: #ffffff !important;
}

html body a.tutor-btn.tutor-btn-primary:hover,
html body .tutor-btn.tutor-btn-primary:hover {
    background-color: #005a87 !important;
    color: #ffffff !important;
}

/* 5. Fix for Credit Card Tool - remove conflicting styles */
.credit-card-tool-container .button,
.credit-card-tool-container button,
.credit-card-tool-container input[type="button"],
.credit-card-tool-container input[type="submit"] {
    /* Reset to default styling */
    background-color: initial;
    color: initial;
    border-radius: initial;
    padding: initial;
    font-family: initial;
    font-weight: initial;
    text-transform: initial;
    letter-spacing: initial;
    border: initial;
    font-size: initial;
    line-height: initial;
}

/* 6. Ensure federal buttons in government resources page have white text */
html body .federal-button {
    color: #ffffff !important;
}

body.tutor-frontend .wp-site-blocks,
body.tutor-frontend main,
body.tutor-frontend .wp-block-group,
body.tutor-frontend .wp-block-column,
body.tutor-frontend .tutor-wrap,
body.tutor-frontend .tutor-container,
body.tutor-frontend .tutor-single-course,
body.tutor-frontend .tutor-dashboard {
    overflow: visible !important;
    position: relative !important;
    z-index: auto !important;
}

.wp-block-navigation__submenu-container {
    z-index: 9999 !important;
}

/* Allow dropdowns to overflow on Tutor LMS pages */
body.tutor-frontend html,
body.tutor-frontend body,
body.tutor-frontend .wp-site-blocks,
body.tutor-frontend main,
body.tutor-frontend .wp-block-group,
body.tutor-frontend .wp-block-column {
  overflow: visible !important;
}

/* Ensure header doesn't clip dropdown */
body.tutor-frontend .site-header,
body.tutor-frontend header.wp-block-template-part {
  overflow: visible !important;
  position: relative !important;
  z-index: 10000 !important;
}

/* Allow full dropdown visibility */
body.tutor-frontend .wp-block-navigation__submenu-container {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  transform: none !important;
  position: absolute !important;
  z-index: 10001 !important;
}

/* FIX for submenu clipping inside Tutor LMS */
body.tutor-frontend .tutor-wrap {
    overflow: visible !important;
    position: relative !important;
    z-index: auto !important;
}

body.tutor-frontend .wp-block-navigation__submenu-container {
    opacity: 0 !important;
    visibility: hidden !important;
    transform: translateY(-10px) !important;
    transition: all 0.3s ease !important;
}

body.tutor-frontend .wp-block-navigation-item:hover .wp-block-navigation__submenu-container {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateY(0) !important;
}

/* Fix submenu clipping inside Tutor LMS pages */
body.tutor-frontend .tutor-wrap,
body.tutor-frontend .tutor-container,
body.tutor-frontend .tutor-frontend-course-wrap,
body.tutor-frontend main,
body.tutor-frontend .wp-block-group,
body.tutor-frontend .wp-block-column {
  overflow: visible !important;
  position: relative !important;
  z-index: auto !important;
}

/* Force the submenu to display correctly */
body.tutor-frontend .wp-block-navigation__submenu-container {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  transform: translateY(-10px) !important;
  transition: all 0.3s ease !important;
}

body.tutor-frontend .wp-block-navigation-item:hover .wp-block-navigation__submenu-container,
body.tutor-frontend .wp-block-navigation-item:focus-within .wp-block-navigation__submenu-container {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  transform: translateY(0) !important;
  z-index: 999999 !important;
}

/* Force display of game grid */
.financial-ties-container .game-grid {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 10px !important;
    margin-bottom: 25px !important;
    background: white !important;
    padding: 20px !important;
    border-radius: 10px !important;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1) !important;
    opacity: 1 !important;
    visibility: visible !important;
}

.financial-ties-container .term-card {
    background: #f8f9fa !important;
    border: 2px solid #e9ecef !important;
    border-radius: 8px !important;
    padding: 15px 8px !important;
    text-align: center !important;
    cursor: pointer !important;
    font-weight: 500 !important;
    color: #333 !important;
    transition: all 0.2s ease !important;
    user-select: none !important;
    min-height: 60px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 0.9rem !important;
    line-height: 1.2 !important;
}

/* Financial Ties Game CSS Fixes */
.financial-ties-container .game-grid {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 10px !important;
    margin-bottom: 25px !important;
    background: white !important;
    padding: 20px !important;
    border-radius: 10px !important;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1) !important;
    opacity: 1 !important;
    visibility: visible !important;
}

.financial-ties-container .term-card {
    background: #f8f9fa !important;
    border: 2px solid #e9ecef !important;
    border-radius: 8px !important;
    padding: 15px 8px !important;
    text-align: center !important;
    cursor: pointer !important;
    font-weight: 500 !important;
    color: #333 !important;
    transition: all 0.2s ease !important;
    user-select: none !important;
    min-height: 60px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 0.9rem !important;
    line-height: 1.2 !important;
}

.financial-ties-container .term-card.selected {
    background: #007bff !important;
    color: white !important;
    border-color: #007bff !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2) !important;
}

.financial-ties-container .term-card.correct {
    background: #28a745 !important;
    color: white !important;
    border-color: #28a745 !important;
    cursor: default !important;
}

.financial-ties-container .term-card.incorrect {
    background: #dc3545 !important;
    color: white !important;
    border-color: #dc3545 !important;
    animation: shake 0.5s !important;
}

@keyframes shake {
    0%, 100% { transform: translateX(0); }
    25% { transform: translateX(-5px); }
    75% { transform: translateX(5px); }
}

.financial-ties-container #gameArea {
    display: block !important;
}

.financial-ties-container .mistake-dot {
    width: 12px !important;
    height: 12px !important;
    border-radius: 50% !important;
    background: #e2e8f0 !important;
    border: 2px solid #cbd5e0 !important;
    display: inline-block !important;
    margin: 0 4px !important;
}

.financial-ties-container .mistake-dot.used {
    background: #dc3545 !important;
    border-color: #dc3545 !important;
}

/* =============================================================================
   11. LOAN CALCULATOR SPECIFIC FIXES
   ============================================================================= */

/* Override global text color for loan calculator elements */
.ile-calculator,
.ile-calculator p,
.ile-calculator li,
.ile-calculator span,
.ile-calculator div {
    color: #000000 !important; /* Force black text for all calculator elements */
}

/* Ensure form labels are visible */
.ile-calculator .ile-form-group label {
    color: #000000 !important;
    font-weight: 600 !important;
}

/* Ensure result labels are visible */
.ile-calculator .ile-result-label {
    color: #000000 !important;
}

/* Ensure result values are visible with appropriate emphasis */
.ile-calculator .ile-result-value {
    color: #0a3815 !important; /* Dark green for emphasis */
    font-weight: 700 !important;
}

/* Fix regulatory highlights section - CRITICAL FIX */
.ile-calculator .ile-regulations,
.ile-calculator .regulations-info p,
.ile-calculator .regulations-info li,
.ile-calculator .regulations-info span,
.ile-calculator .regulations-info div {
    color: #000000 !important; /* Force black text for regulatory content */
}

.ile-calculator .regulations-info p strong,
.ile-calculator .regulations-info li strong {
    color: #0a3815 !important; /* Dark green for emphasis */
}

/* Fix educational content */
.ile-calculator .educational-summary,
.ile-calculator .ile-education-section p,
.ile-calculator .ile-education-section li,
.ile-calculator .ile-education-section span {
    color: #000000 !important;
}

/* Fix payment schedule text */
.ile-calculator .ile-schedule-table td {
    color: #000000 !important;
}

/* Fix early payoff calculator results */
.ile-calculator #payoff-results,
.ile-calculator #payoff-results p,
.ile-calculator #payoff-results span,
.ile-calculator #payoff-results div {
    color: #000000 !important;
}

/* Fix disclaimer text - CRITICAL FIX */
.ile-calculator .ile-disclaimer,
.ile-calculator .ile-disclaimer p,
.ile-calculator .ile-disclaimer span {
    color: #000000 !important; /* Force black text for disclaimer */
    background-color: #f1f3f4 !important; /* Ensure background is light */
}

.ile-calculator .ile-disclaimer strong {
    color: #000000 !important;
    font-weight: bold !important;
}

/* Fix section headings */
.ile-calculator h3,
.ile-calculator h4 {
    color: #1a73e8 !important; /* Blue for headings */
}

/* Fix warnings section */
.ile-calculator .ile-warnings li {
    color: #7a4500 !important; /* Dark orange/brown */
}

/* BUTTON TEXT FIXES - CRITICAL */

/* Fix main calculate button */
.ile-calculator .ile-calculate-btn {
    color: #ffffff !important; /* Force white text */
    background: #1a73e8 !important; /* Force blue background */
}

.ile-calculator .ile-calculate-btn:hover {
    color: #ffffff !important; /* Keep white text on hover */
    background: #1557b0 !important; /* Darker blue on hover */
}

/* Fix early payoff button */
.ile-calculator #calculate-payoff,
.ile-calculator button[id="calculate-payoff"] {
    color: #ffffff !important; /* Force white text */
    background: #673ab7 !important; /* Purple background to match section */
}

.ile-calculator #calculate-payoff:hover,
.ile-calculator button[id="calculate-payoff"]:hover {
    color: #ffffff !important; /* Keep white text on hover */
    background: #5e35b1 !important; /* Darker purple on hover */
}

/* Fix show/hide payment schedule button */
.ile-calculator #view-schedule-btn,
.ile-calculator button[id="view-schedule-btn"] {
    color: #ffffff !important; /* Force white text */
    background: #4285f4 !important; /* Blue background to match section */
}

.ile-calculator #view-schedule-btn:hover,
.ile-calculator button[id="view-schedule-btn"]:hover {
    color: #ffffff !important; /* Keep white text on hover */
    background: #3367d6 !important; /* Darker blue on hover */
}

/* Fix any secondary buttons */
.ile-calculator .ile-secondary-btn {
    color: #1a73e8 !important; /* Blue text */
    background: #f1f3f4 !important; /* Light gray background */
}

.ile-calculator .ile-secondary-btn:hover {
    color: #174ea6 !important; /* Darker blue on hover */
    background: #e8eaed !important; /* Slightly darker gray on hover */
}

/* Fix text buttons */
.ile-calculator .ile-text-btn {
    color: #1a73e8 !important; /* Blue text */
}

.ile-calculator .ile-text-btn:hover {
    color: #174ea6 !important; /* Darker blue on hover */
}

/* Ensure all buttons have proper contrast */
.ile-calculator button,
.ile-calculator .button,
.ile-calculator input[type="button"],
.ile-calculator input[type="submit"] {
    color: #ffffff !important; /* Default to white text for all buttons */
    background-color: #1a73e8 !important; /* Default to blue background */
}

/* Fix for any other buttons that might be in the calculator */
.ile-calculator button:not(.ile-calculate-btn):not(#calculate-payoff):not(#view-schedule-btn):not(.ile-secondary-btn):not(.ile-text-btn) {
    color: #ffffff !important; /* Force white text */
    background: #1a73e8 !important; /* Force blue background */
}

/* Ensure all interactive elements have visible focus states */
.ile-calculator button:focus,
.ile-calculator input:focus,
.ile-calculator select:focus {
    outline: 2px solid #1a73e8 !important;
    outline-offset: 2px !important;
}


