/**
 * Axis Mental Health - Mobile Global Styles
 * 
 * Consolidated mobile CSS for better organization and maintainability
 * Classification: Global - affects all pages and components
 * 
 * Includes:
 * - Mobile responsiveness fixes
 * - iOS form compatibility  
 * - Mobile optimizations and utilities
 * - Touch target accessibility
 * - Typography mobile scaling
 */

/* ==========================================================================
   UTILITY CLASSES - Apply via Bricks Builder
   ========================================================================== */

/* Hide/Show by Breakpoint */
.hide-mobile {
    display: block;
}

@media (max-width: 767px) {
    .hide-mobile {
        display: none !important;
    }
}

.hide-desktop {
    display: none;
}

@media (min-width: 768px) {
    .hide-desktop {
        display: block !important;
    }
}

.show-mobile-only {
    display: none;
}

@media (max-width: 767px) {
    .show-mobile-only {
        display: block !important;
    }
}

/* ==========================================================================
   MOBILE LAYOUT & RESPONSIVE FIXES
   ========================================================================== */

@media (max-width: 767px) {

    /* Prevent horizontal scroll */
    html,
    body {
        overflow-x: hidden !important;
    }


    /* ==========================================================================
       HOMEPAGE MOBILE OPTIMIZATIONS
       ========================================================================== */

    /* TASK 1: Hide "I Also Specialize In" section on mobile homepage */
    body.page-id-2 .specializations-section:nth-of-type(2) {
        display: none !important;
    }

    /* TASK 3: Condense "How Therapy Works" section (moved from process-section.css) 
       Updated selectors for Bricks component structure - 2025-12-23 */
    .process-section .axis-card__body {
        display: none !important;
    }

    .process-section .axis-card {
        padding: var(--axis-space-4) var(--axis-space-3) !important;
        min-height: auto;
        row-gap: 0;
        column-gap: 6px;
    }

    .process-section .axis-card__number {
        font-size: 36px !important;
        /* margin-bottom: var(--axis-space-2) !important; */
        align-self: anchor-center;
        opacity: 0.4;
    }

    .process-section.axis-section {
        padding-top: var(--axis-space-8) !important;
        padding-bottom: var(--axis-space-8) !important;
    }

    /* TASK 4: Condense "Payment Options" section (moved from pricing-teaser-section.css)
       Updated selectors for Bricks component structure - 2025-12-23 */
    .insurance-section .axis-card__body {
        /* display: none !important; */
    }

    .insurance-section .axis-card {
        padding: var(--axis-space-5) !important;
    }

    .insurance-section .axis-grid-auto {
        /* gap: var(--axis-space-4) !important; */
        /* margin-bottom: var(--axis-space-6) !important; */
    }

    .insurance-section.axis-section {
        padding-top: var(--axis-space-8) !important;
        padding-bottom: var(--axis-space-8) !important;
    }

    /* TASK 5: Tighten section padding for mobile homepage */
    body.page-id-2 .axis-section {
        padding-top: var(--axis-space-8) !important;
        /* 32px instead of 40px */
        padding-bottom: var(--axis-space-8) !important;
    }

    /* Hero section - special case, needs more padding */
    body.page-id-2 .hero-section {
        padding-top: 100px !important;
        padding-bottom: var(--axis-space-10) !important;
    }

    /* TASK 8: Show only top 3 services on mobile homepage */
    .specializations-section .axis-grid-auto>div:nth-child(4) {
        display: none !important;
    }

    /* Tighten services section grid on mobile */
    .specializations-section .axis-grid-auto {
        gap: var(--axis-space-4) !important;
    }

    /* Reduce intro text margin */
    .specializations-section .section-intro-text {
        margin-bottom: var(--axis-space-6) !important;
    }
}

/* ==========================================================================
   HEADER & NAVIGATION MOBILE
   ========================================================================== */

/* Note: All header/navigation mobile styles have been moved to header-navigation.css
   for better organization and maintainability. */

/* ==========================================================================
   TYPOGRAPHY MOBILE SCALING
   ========================================================================== */

@media (max-width: 767px) {

    /* Section headings - reduce size for mobile */
    .section-heading,
    .brxe-heading.section-heading {
        font-size: clamp(24px, 6vw, 32px) !important;
        line-height: 1.2 !important;
        margin-bottom: var(--axis-space-6) !important;
    }

    /* Hero title mobile optimization */
    .hero-title,
    .hero-section h1 {
        /* font-size: clamp(32px, 8vw, 48px) !important; */
        /* line-height: 1.1 !important; */
        text-align: center !important;
        font-size: var(--axis-text-4xl);
    }

    /* Final CTA heading */
    .final-cta-section h2,
    .cta-heading {
        /* font-size: clamp(28px, 7vw, 40px) !important; */
        /* line-height: 1.2 !important; */
        text-align: center;
    }

    /* Card titles */
    .process-step h3 {
        font-size: var(--axis-text-xl) !important;
        line-height: 1.3 !important;
    }

    /* Body text improvements */
    .section-intro,
    .section-description {
        /* font-size: var(--axis-text-base) !important; */
        /* line-height: 1.6 !important; */
        margin-bottom: var(--axis-space-8) !important;
    }
}

/* ==========================================================================
   SECTION PADDING OPTIMIZATION
   ========================================================================== */

@media (max-width: 767px) {

    /* Reduce section padding - allow page overrides by removing !important from padding values */
    .axis-section {
        padding: var(--axis-space-10) var(--axis-space-4);
    }

    /* Hero section mobile spacing */
    .hero-section {
        padding: 100px var(--axis-space-4) var(--axis-space-8) var(--axis-space-6) !important;
        /* min-height: 60vh; */
        /* Reduce from full height */
    }

    .hero-section .content-wrap {
        /* margin-top: var(--axis-space-12); */
        padding: 0;
    }

    /* Welcome/booking section */
    .welcome-booking-section {
        /* padding: var(--axis-space-8) var(--axis-space-4); */
        /* margin-top: -56px; */
    }

    /* Final CTA section */
    .final-cta-section {
        padding: var(--axis-space-12) var(--axis-space-4);
    }

    /* Override container fixed width in final CTA */
    .final-cta-section .container,
    .final-cta-section .content-wrap {
        max-width: 100% !important;
        padding-left: var(--axis-space-4) !important;
        padding-right: var(--axis-space-4) !important;
    }

    /* Footer padding */
    .axis-footer {
        padding: var(--axis-space-10) var(--axis-space-4);
    }
}

/* ==========================================================================
   CARD GRID RESPONSIVE BEHAVIOR
   ========================================================================== */

@media (max-width: 767px) {

    /* Process steps - single column */
    .process-steps-grid {
        grid-template-columns: 1fr !important;
        gap: var(--axis-space-6) !important;
    }

    .process-step {
        padding: var(--axis-space-6) !important;
        text-align: center !important;
    }

    /* About section - stack image and content */
    .about-preview-wrapper {
        grid-template-columns: 1fr !important;
        gap: var(--axis-space-6) !important;
    }

    .about-preview-image {
        order: -1;
        /* Image first on mobile */
        max-width: 280px;
        margin: 0 auto;
        position: relative;
    }

    /* FIX: Show full bio content - remove destructive hiding */
    .about-bio {
        font-size: var(--axis-text-base) !important;
        line-height: 1.6 !important;
        margin-bottom: var(--axis-space-6) !important;
    }

    .about-bio p {
        margin-bottom: var(--axis-space-4) !important;
    }

    .about-bio p:first-of-type {
        font-size: var(--axis-text-base);
        font-weight: 600;
        color: var(--axis-dark);
        line-height: 1.4;
        margin-bottom: var(--axis-space-5);
    }

    /* Improve credentials badge mobile positioning */
    .credentials-badge-overlay {
        position: static !important;
        margin: var(--axis-space-4) auto 0 !important;
        max-width: 260px !important;
        text-align: center !important;
        padding: var(--axis-space-3) var(--axis-space-4) !important;
        font-size: 14px !important;
        line-height: 1.3 !important;
    }

    /* Improve bullet points visibility */
    .key-credibility-bullets {
        background: var(--axis-gray-50) !important;
        padding: var(--axis-space-5) !important;
        border-radius: var(--axis-radius-md) !important;
        margin: var(--axis-space-6) 0 !important;
        border-left: 3px solid var(--axis-primary) !important;
    }

    .key-credibility-bullets ul {
        margin: 0 !important;
        padding: 0 !important;
        list-style: none !important;
    }

    .key-credibility-bullets li {
        position: relative !important;
        padding-left: var(--axis-space-6) !important;
        margin-bottom: var(--axis-space-3) !important;
        font-size: var(--axis-text-base) !important;
        line-height: 1.5 !important;
        color: var(--axis-text-primary) !important;
    }

    .key-credibility-bullets li::before {
        content: "✓" !important;
        position: absolute !important;
        left: 0 !important;
        top: 0 !important;
        color: var(--axis-primary) !important;
        font-weight: bold !important;
        font-size: 16px !important;
    }

    .key-credibility-bullets li:last-child {
        margin-bottom: 0 !important;
    }

    /* Improve about section spacing */
    .about-preview-section {
        padding: var(--axis-space-8) var(--axis-space-4) !important;
    }

    .about-preview-content {
        gap: var(--axis-space-5) !important;
    }

    /* Enhance CTA section mobile layout */
    .about-cta-section {
        /* margin-top: var(--axis-space-8) !important; */
        text-align: center !important;
        /* padding: var(--axis-space-6) var(--axis-space-4) !important; */
        /* background: rgba(0, 136, 204, 0.03) !important; */
        /* border-radius: var(--axis-radius-md) !important; */
        /* border: 1px solid rgba(0, 136, 204, 0.1) !important; */
    }

    .about-cta-btn {
        width: 100% !important;
        margin-bottom: var(--axis-space-4) !important;
        font-size: 16px !important;
        /* Prevent iOS zoom */
        padding: var(--axis-space-4) var(--axis-space-6) !important;
    }

    .about-secondary-link {
        font-size: var(--axis-text-base) !important;
        /* opacity: 0.8 !important; */
    }

    /* Welcome booking content - stack vertically */
    .welcome-booking-content {
        grid-template-columns: 1fr !important;
        gap: var(--axis-space-6) !important;
    }

    .welcome-box {
        order: 1;
        margin-bottom: var(--axis-space-4);
    }

    .appointment-form-box {
        order: 2;
    }
}

/* ==========================================================================
   TOUCH TARGET ACCESSIBILITY
   ========================================================================== */

@media (max-width: 767px) {



    /* FAQ accordion touch targets */
    .faq-accordion .accordion-title-wrapper {
        padding: var(--axis-space-4) var(--axis-space-3) !important;
        min-height: 56px !important;
    }

    .faq-accordion .accordion-title {
        font-size: var(--axis-text-lg) !important;
        line-height: 1.3 !important;
        padding-right: var(--axis-space-10) !important;
        /* Space for icon */
    }

    .faq-accordion .accordion-content {
        padding: var(--axis-space-4) !important;
        font-size: var(--axis-text-base) !important;
        line-height: 1.6 !important;
    }

    /* Contact links in footer */
    .footer-contact-list a {
        min-height: 44px !important;
        display: inline-flex !important;
        align-items: center !important;
        padding: var(--axis-space-2) var(--axis-space-1) !important;
    }

    /* Social media icons */
    .social-icon-link {
        width: 48px !important;
        height: 48px !important;
        min-width: 48px !important;
        min-height: 48px !important;
    }
}

/* ==========================================================================
   FORM MOBILE ENHANCEMENTS
   ========================================================================== */

@media (max-width: 767px) {

    /* Appointment form layout */

    .appointment-form .form-group {
        width: 100% !important;
    }

    .appointment-form-box {
        padding: var(--axis-space-6) !important;
    }

    .appointment-form textarea {
        min-height: 120px !important;
    }

    /* Progressive form enhancements */

    .progressive-form.form-expanded {
        gap: var(--axis-space-4) !important;
    }

    .progressive-form .form-group {
        width: 100% !important;
        grid-column: 1 / -1 !important;
    }

    .progressive-form .initial-field,
    .progressive-form .expanded-field {
        width: 100% !important;
        grid-column: 1 / -1 !important;
    }

    .progressive-form .submit-button-wrapper {
        width: 100% !important;
        grid-column: 1 / -1 !important;
        /* margin-top: var(--axis-space-4) !important; */
    }

    .progressive-form textarea {
        min-height: 100px !important;
        resize: vertical !important;
    }

    .progressive-form .bricks-button {
        width: 100% !important;
        min-height: 48px !important;
        font-size: 16px !important;
        padding: var(--axis-space-4) var(--axis-space-6) !important;
        border-radius: var(--axis-radius-md) !important;
        text-transform: none !important;
        font-weight: 600 !important;
    }

    /* Contact form styling */
    .contact-form,
    .brxe-form.contact-form {
        padding: var(--axis-space-6) !important;
        background: var(--axis-white) !important;
        border-radius: var(--axis-radius-lg) !important;
        box-shadow: var(--axis-shadow-card) !important;
    }

    /* Form validation messages */
    .form-error,
    .form-success,
    .bricks-form-error,
    .bricks-form-success {
        font-size: 14px !important;
        padding: var(--axis-space-3) var(--axis-space-4) !important;
        margin-top: var(--axis-space-2) !important;
        border-radius: var(--axis-radius-sm) !important;
        line-height: 1.4 !important;
    }

    .form-error,
    .bricks-form-error {
        background: #fef2f2 !important;
        color: #dc2626 !important;
        border-left: 3px solid #dc2626 !important;
    }

    .form-success,
    .bricks-form-success {
        background: #f0f9ff !important;
        color: #0369a1 !important;
        border-left: 3px solid var(--axis-primary) !important;
    }

    /* Placeholder styling */
    input::placeholder,
    textarea::placeholder {
        color: #999999 !important;
        opacity: 1 !important;
        font-size: 15px !important;
    }

    input::-webkit-input-placeholder,
    textarea::-webkit-input-placeholder {
        color: #999999 !important;
        opacity: 1 !important;
    }

    input::-moz-placeholder,
    textarea::-moz-placeholder {
        color: #999999 !important;
        opacity: 1 !important;
    }

    input:-ms-input-placeholder,
    textarea:-ms-input-placeholder {
        color: #999999 !important;
        opacity: 1 !important;
    }

    /* Form loading states */
    .form-submitting .bricks-button,
    .progressive-form.submitting .bricks-button {
        opacity: 0.7 !important;
        pointer-events: none !important;
        position: relative !important;
    }

    .form-submitting .bricks-button::after,
    .progressive-form.submitting .bricks-button::after {
        content: '' !important;
        position: absolute !important;
        right: 16px !important;
        top: 50% !important;
        transform: translateY(-50%) !important;
        border: 2px solid white !important;
        border-top-color: transparent !important;
        border-radius: 50% !important;
        width: 16px !important;
        height: 16px !important;
        animation: button-spin 0.8s linear infinite !important;
    }

    @keyframes button-spin {
        to {
            transform: translateY(-50%) rotate(360deg);
        }
    }

    /* Form labels and accessibility */
    .form-group label,
    .brxe-form label {
        font-size: 15px !important;
        font-weight: 600 !important;
        color: var(--axis-dark) !important;
        margin-bottom: var(--axis-space-2) !important;
        display: block !important;
    }

    .form-group.required label::after,
    .brxe-form .required label::after {
        content: ' *' !important;
        color: #dc2626 !important;
        font-weight: bold !important;
    }

    /* Keyboard navigation improvements */
    .progressive-form input+input,
    .progressive-form input+textarea,
    .progressive-form textarea+.bricks-button {
        margin-top: var(--axis-space-1) !important;
    }

    .progressive-form .form-group {
        position: relative !important;
    }
}

/* ==========================================================================
   IMAGE RESPONSIVE BEHAVIOR
   ========================================================================== */

@media (max-width: 767px) {

    /* Hero background images */
    .hero-bg-image {
        object-fit: cover !important;
        object-position: center !important;
    }

    /* About section image */
    .about-image {
        width: 100% !important;
        max-width: 300px !important;
        height: auto !important;
        border-radius: var(--axis-radius-lg) !important;
        margin: 0 auto !important;
        display: block !important;
    }

    /* Credentials badge - responsive positioning */
    .credentials-badge-overlay {
        position: relative !important;
        bottom: auto !important;
        left: auto !important;
        margin-top: var(--axis-space-4) !important;
        max-width: 100% !important;
        text-align: center !important;
    }
}

/* ==========================================================================
   MOBILE INTERACTION IMPROVEMENTS
   ========================================================================== */

@media (max-width: 767px) {

    /* Reduce hover effects on mobile (performance) */
    .axis-card:hover,
    .process-step:hover {
        transform: none !important;
        box-shadow: var(--axis-shadow-card) !important;
    }

    /* Remove complex animations on mobile */
    .btn-primary::before,
    .bricks-button.btn-primary::before {
        display: none !important;
    }

    /* Simplify button hover states */
    .btn:hover,
    .bricks-button:hover {
        transform: none !important;
        box-shadow: var(--axis-shadow-sm);
    }

    /* Active state for better touch feedback */
    .btn:active,
    .bricks-button:active,
    button:active,
    a:active {
        transform: scale(0.98) !important;
        opacity: 0.8;
        transition: transform 0.1s ease, opacity 0.1s ease !important;
    }
}

/* ==========================================================================
   FOOTER MOBILE SIMPLIFICATION
   ========================================================================== */

@media (max-width: 767px) {

    /* Hide redundant/low-priority footer content */
    .footer-column.footer-nav,
    .footer-column.footer-brand .footer-description,
    .footer-contact-item:has(.ti-time),
    .footer-social-icons,
    .footer-follow-heading {
        display: none !important;
    }

    /* Single column layout */
    .footer-top-grid {
        grid-template-columns: 1fr !important;
        gap: var(--axis-space-6) !important;
    }

    /* Contact first (most important on mobile) */
    .footer-column.footer-contact {
        order: -1;
    }

    /* Simplify contact items */
    .footer-contact-list {
        gap: var(--axis-space-4) !important;
    }

    .footer-contact-item {
        padding: var(--axis-space-3);
        background: rgba(255, 255, 255, 0.05);
        border-radius: var(--axis-radius-md);
    }

    .footer-contact-item .contact-icon {
        width: 36px !important;
        height: 36px !important;
    }

    /* Legal section compact */
    .footer-column.footer-legal {
        padding-top: var(--axis-space-6);
        border-top: 1px solid rgba(255, 255, 255, 0.1);
    }

    .footer-legal-links {
        flex-direction: row !important;
        flex-wrap: wrap;
        gap: var(--axis-space-2) var(--axis-space-4) !important;
        justify-content: center;
    }

    .footer-legal-links .legal-link {
        display: inline-block;
    }

    /* Footer bottom single line */
    .footer-bottom {
        flex-direction: column !important;
        gap: var(--axis-space-2) !important;
        text-align: center;
    }

    .footer-copyright,
    .footer-credentials {
        font-size: 12px !important;
        width: 100% !important;
    }

    /* Hide long credentials text */
    .footer-credentials {
        display: none !important;
    }
}

/* ==========================================================================
   INSURANCE SECTION MOBILE OPTIMIZATION
   ========================================================================== */

@media (max-width: 767px) {

    /* Hide full insurance grid on mobile */
    .insurance-section .insurance-grid {
        display: none !important;
    }

    /* Hide FAQ link banner (too much text on mobile) */
    .insurance-section .faq-link-text {
        display: none !important;
    }

    /* Show compact mobile banner instead */
    .insurance-mobile-banner {
        display: block !important;
        background: linear-gradient(135deg, rgba(0, 136, 204, 0.06) 0%, rgba(0, 136, 204, 0.02) 100%);
        border: 1px solid rgba(0, 136, 204, 0.15);
        border-left: 4px solid var(--axis-primary);
        border-radius: var(--axis-radius-md);
        padding: var(--axis-space-6) var(--axis-space-4);
        text-align: center;
        font-size: 16px;
        line-height: 1.6;
        color: var(--axis-text-primary);
        max-width: 600px;
        margin: 0 auto;
    }

    .insurance-mobile-banner .icon {
        font-size: 32px;
        display: block;
        margin-bottom: var(--axis-space-3);
    }

    .insurance-mobile-banner .price-text {
        font-size: 18px;
        font-weight: 700;
        color: var(--axis-dark);
        margin-bottom: var(--axis-space-2);
        display: block;
    }

    .insurance-mobile-banner .details-link {
        color: var(--axis-primary);
        font-weight: 600;
        text-decoration: none;
        border-bottom: 1px solid transparent;
        transition: all 0.2s ease;
    }

    .insurance-mobile-banner .details-link:hover {
        color: #0077b3;
        border-bottom-color: #0077b3;
    }

    /* Keep CTA button visible but adjust sizing */
    .insurance-section .cta-primary-btn {
        max-width: 100%;
        margin-top: var(--axis-space-8);
        font-size: 16px;
        padding: 18px 32px;
    }
}

@media (min-width: 768px) {
    .insurance-mobile-banner {
        display: none !important;
    }
}

/* ==========================================================================
   FAQ MOBILE IMPROVEMENTS
   ========================================================================== */

@media (max-width: 767px) {
    .faq-accordion {
        margin-bottom: var(--axis-space-8) !important;
    }

    .faq-accordion .accordion-item {
        margin-bottom: var(--axis-space-3) !important;
        border-radius: var(--axis-radius-md) !important;
        background: rgba(0, 0, 0, 0.02);
    }
}

/* ==========================================================================
   ACCESSIBILITY & FOCUS STATES
   ========================================================================== */

@media (max-width: 767px) {

    /* Skip links */
    .skip-link {
        font-size: 16px !important;
        padding: var(--axis-space-4) var(--axis-space-6) !important;
        top: var(--axis-space-2) !important;
        left: var(--axis-space-2) !important;
    }
}

/* ==========================================================================
   REDUCED MOTION ACCESSIBILITY
   ========================================================================== */

@media (prefers-reduced-motion: reduce) {
    .insurance-mobile-banner .details-link {
        transition: none !important;
    }

    .btn-primary::before,
    .bricks-button.btn-primary::before,
    .btn:active,
    .bricks-button:active {
        animation: none !important;
        transition: none !important;
    }
}