/**
 * DoctorBookly — Homepage mobile polish (loads last; desktop unchanged)
 */

/* ── Hero ── */
@media (max-width: 768px) {
    .hero {
        padding: 22px 14px 12px !important;
        background: linear-gradient(165deg, #ecfdf5 0%, #e0f2fe 48%, #f0fdfa 100%) !important;
    }

    .hero-content {
        padding: 0 !important;
        max-width: 100% !important;
    }

    .hero h1,
    .hero-title-animated {
        font-size: clamp(22px, 5.5vw, 32px) !important;
        line-height: 1.15 !important;
        margin-bottom: 8px !important;
        padding: 0 4px !important;
        display: block !important;
    }

    .hero-title-line {
        white-space: nowrap !important;
    }

    .hero-subtitle {
        font-size: 14px !important;
        line-height: 1.45 !important;
        color: #475569 !important;
        margin-bottom: 14px !important;
        padding: 0 8px !important;
        max-width: 20rem !important;
        font-weight: 600 !important;
    }

    .hero-subtitle strong {
        color: #0f766e;
        font-weight: 800;
    }
}

/* ── Search card ── */
@media (max-width: 768px) {
    .search-box-wrapper {
        margin: 0 auto 8px !important;
        padding: 0 4px !important;
        max-width: 100% !important;
    }

    .search-box {
        padding: 12px 12px 10px !important;
        border-radius: 18px !important;
        gap: 8px !important;
        border: 1px solid rgba(226, 232, 240, 0.9) !important;
        box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04), 0 10px 32px -12px rgba(13, 148, 136, 0.14) !important;
        background: #fff !important;
    }

    .hero-registry-head {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 6px !important;
        margin-bottom: 6px !important;
        padding-bottom: 8px !important;
        border-bottom: 1px solid #eef2f6 !important;
    }

    .hero-swap-ai-btn {
        padding: 9px 12px !important;
        font-size: 12px !important;
        border-radius: 12px !important;
    }

    .hero-swap-ai-btn__label {
        font-size: 12px !important;
    }

    .hero-swap-ai-btn__sub {
        font-size: 10px !important;
    }

    .hero-mode-panel--registry {
        display: flex !important;
        flex-direction: column !important;
        gap: 8px !important;
    }

    .hero-registry-head__title {
        justify-content: center !important;
        font-size: 14px !important;
        font-weight: 700 !important;
        color: #0f766e !important;
    }

    .hero-registry-head__text {
        max-width: none !important;
    }

    .hero-swap-ai-btn {
        width: 100% !important;
        justify-content: center !important;
        padding: 11px 14px !important;
        border-radius: 14px !important;
        font-size: 13px !important;
        background: linear-gradient(135deg, #2563eb 0%, #4f46e5 50%, #0d9488 100%) !important;
        box-shadow: 0 6px 18px rgba(37, 99, 235, 0.22) !important;
    }

    .hero-search-box .search-box-top,
    .search-box-top {
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 0 !important;
        margin-bottom: 12px !important;
        overflow: visible !important;
        position: relative !important;
        z-index: 210 !important;
        flex-shrink: 0 !important;
    }

    .hero-search-box .search-tabs,
    .search-tabs {
        display: flex !important;
        flex-wrap: nowrap !important;
        grid-template-columns: unset !important;
        gap: 6px !important;
        overflow-x: auto !important;
        overflow-y: visible !important;
        -webkit-overflow-scrolling: touch !important;
        scrollbar-width: none !important;
        padding: 6px 4px 8px !important;
        width: 100% !important;
        min-height: 40px !important;
        background: #f8fafc !important;
        border: 1px solid #e2e8f0 !important;
        border-radius: 14px !important;
        box-shadow: none !important;
        position: relative !important;
        z-index: 211 !important;
    }

    .hero-search-box .search-tabs::-webkit-scrollbar,
    .search-tabs::-webkit-scrollbar {
        display: none !important;
    }

    .hero-search-box .search-tab,
    .search-tab {
        flex: 0 0 auto !important;
        width: auto !important;
        min-width: 0 !important;
        max-width: none !important;
        white-space: nowrap !important;
        padding: 8px 12px !important;
        font-size: 11px !important;
        border-radius: 999px !important;
        border: 1px solid #e2e8f0 !important;
        background: #fff !important;
        color: #64748b !important;
        font-weight: 700 !important;
        min-height: 34px !important;
        display: inline-flex !important;
        align-items: center !important;
        gap: 5px !important;
    }

    .hero-search-box .search-tab.active,
    .search-tab.active {
        background: linear-gradient(135deg, #0d9488, #059669) !important;
        border-color: transparent !important;
        color: #fff !important;
        box-shadow: 0 4px 12px rgba(13, 148, 136, 0.28) !important;
    }

    .hero-search-box .search-tab.active i,
    .search-tab.active i {
        color: #fff !important;
    }

    .hero-field-label {
        display: block !important;
        font-size: 10px !important;
        font-weight: 800 !important;
        color: #64748b !important;
        text-transform: uppercase !important;
        letter-spacing: 0.05em !important;
        margin-bottom: 5px !important;
    }

    .search-inputs {
        gap: 8px !important;
        margin-top: 0 !important;
        margin-bottom: 8px !important;
        position: relative !important;
        z-index: 1 !important;
    }

    .hero-field-label {
        margin-bottom: 4px !important;
        font-size: 9px !important;
    }

    .search-actions-row {
        gap: 6px !important;
    }

    #nearbyBtnMobile,
    .search-actions-row .nearby-btn,
    .search-btn-mobile,
    .search-actions-row .search-btn-mobile {
        min-height: 42px !important;
        padding: 10px 8px !important;
        font-size: 12px !important;
        border-radius: 11px !important;
    }

    .search-field {
        position: relative !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
        padding: 0 !important;
        margin: 0 !important;
        background: transparent !important;
        border: none !important;
        box-shadow: none !important;
        min-height: unset !important;
    }

    .hero-field-label {
        position: static !important;
        width: auto !important;
        height: auto !important;
        margin: 0 0 5px 3px !important;
        padding: 0 !important;
        overflow: visible !important;
        clip: auto !important;
        clip-path: none !important;
        white-space: nowrap !important;
        font-size: 10px !important;
        font-weight: 800 !important;
        text-transform: uppercase !important;
        letter-spacing: 0.06em !important;
        color: #64748b !important;
    }

    .search-field .field-icon {
        display: none !important;
    }

    .search-field .search-input,
    .search-input {
        width: 100% !important;
        padding: 12px 40px 12px 14px !important;
        font-size: 14px !important;
        min-height: 46px !important;
        border: 1px solid #dbe5ef !important;
        border-radius: 12px !important;
        background: #f8fafc !important;
        box-sizing: border-box !important;
        line-height: 1.35 !important;
    }

    .search-field .hero-input-clear {
        bottom: 7px !important;
        top: auto !important;
        transform: none !important;
    }

    .search-field .search-input:focus,
    .search-input:focus {
        border-color: #0d9488 !important;
        background: #fff !important;
        box-shadow: 0 0 0 3px rgba(13, 148, 136, 0.12) !important;
    }

    .search-actions-row {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 8px !important;
    }

    #nearbyBtnMobile,
    .search-actions-row .nearby-btn {
        background: #fff !important;
        color: #0f766e !important;
        border: 1.5px solid #99f6e4 !important;
        padding: 13px 10px !important;
        border-radius: 12px !important;
        font-size: 13px !important;
        font-weight: 700 !important;
        min-height: 46px !important;
    }

    .search-btn-mobile,
    .search-actions-row .search-btn-mobile {
        background: linear-gradient(135deg, #0d9488, #059669) !important;
        color: #fff !important;
        padding: 13px 10px !important;
        border-radius: 12px !important;
        font-size: 13px !important;
        font-weight: 700 !important;
        min-height: 46px !important;
        box-shadow: 0 4px 14px rgba(13, 148, 136, 0.28) !important;
    }
}

/* ── AI mode — compact, professional “AI mood”, no empty gap ── */
@media (max-width: 768px) {
    .search-box:has(.hero-mode--ai),
    .search-box:has(.hero-search-box.hero-mode--ai) {
        padding: 14px 14px 12px !important;
        gap: 6px !important;
        background: linear-gradient(165deg, #ffffff 0%, #f0fdfa 42%, #eff6ff 100%) !important;
        border: 1px solid rgba(153, 246, 228, 0.55) !important;
        box-shadow: 0 8px 28px rgba(37, 99, 235, 0.08), 0 2px 8px rgba(13, 148, 136, 0.06) !important;
    }

    .hero-mode--ai .hero-mode-panel--ai {
        display: flex !important;
        flex-direction: column !important;
        gap: 8px !important;
    }

    .hero-mode--ai .hero-ai-head {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 6px !important;
        margin-bottom: 0 !important;
        padding-bottom: 8px !important;
        border-bottom: 1px solid rgba(226, 232, 240, 0.85) !important;
    }

    .hero-mode--ai .hero-ai-head__brand {
        flex: 0 0 auto !important;
    }

    .hero-mode--ai .hero-ai-head__title {
        font-size: 14px !important;
        justify-content: flex-start !important;
    }

    .hero-mode--ai .hero-ai-head__title i {
        width: 28px !important;
        height: 28px !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        border-radius: 9px !important;
        background: linear-gradient(135deg, #ecfdf5, #dbeafe) !important;
        font-size: 13px !important;
    }

    .hero-mode--ai .hero-ai-head__tagline {
        font-size: 11px !important;
        line-height: 1.4 !important;
        max-width: none !important;
        margin: 0 !important;
    }

    .hero-mode--ai .hero-swap-registry-btn {
        width: 100% !important;
        justify-content: center !important;
        margin-top: 0 !important;
        padding: 8px 12px !important;
        font-size: 12px !important;
        border-radius: 12px !important;
        order: 2 !important;
    }

    .hero-search-box.hero-mode--ai .dbk-ai-terminal--minimal {
        padding: 0 !important;
        margin: 0 !important;
        border: none !important;
        box-shadow: none !important;
        background: transparent !important;
        border-radius: 0 !important;
    }

    .hero-search-box.hero-mode--ai #dbkAiChat:empty,
    .hero-search-box.hero-mode--ai #dbkAiChat:not(:has(*)) {
        display: none !important;
        margin: 0 !important;
        padding: 0 !important;
        min-height: 0 !important;
        max-height: 0 !important;
        overflow: hidden !important;
    }

    .hero-search-box.hero-mode--ai #dbkAiAfterAnswer[hidden],
    .hero-search-box.hero-mode--ai #dbkAiFollowUp[hidden],
    .hero-search-box.hero-mode--ai #dbkAiModerationBanner[hidden] {
        display: none !important;
        margin: 0 !important;
        padding: 0 !important;
        min-height: 0 !important;
    }

    .hero-search-box.hero-mode--ai .dbk-ai-hints--minimal {
        margin-top: 8px !important;
        padding: 0 !important;
    }

    .hero-search-box.hero-mode--ai .dbk-ai-query-wrap--minimal {
        min-height: 0 !important;
        padding: 0.5rem 0.45rem 0.5rem 0.7rem !important;
        background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%) !important;
        border-color: #99f6e4 !important;
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9), 0 2px 10px rgba(13, 148, 136, 0.07) !important;
    }

    .hero-search-box.hero-mode--ai .dbk-ai-terminal__input--minimal {
        min-height: 42px !important;
        font-size: 14px !important;
    }

    .hero-search-box.hero-mode--ai .dbk-ai-icon-btn--send {
        background: linear-gradient(135deg, #2563eb, #0d9488) !important;
        color: #fff !important;
    }

    .hero-search-box.hero-mode--ai .dbk-ai-terms-bar {
        margin-top: 4px !important;
        padding-top: 0 !important;
    }
}

/* ── Services + platform highlights — one continuous app grid ── */
@media (max-width: 768px) {
    /* Kill empty expandable row (index.php forces #serviceExpandable visible) */
    div.services > #serviceExpandable,
    div.services > #serviceExpandable[style],
    div.services > div.service-expandable,
    div.services > div.service-expandable[style],
    div.services > .service-expand-btn,
    div.services > #serviceExpandBtn {
        display: none !important;
        height: 0 !important;
        min-height: 0 !important;
        max-height: 0 !important;
        margin: 0 !important;
        padding: 0 !important;
        overflow: hidden !important;
        visibility: hidden !important;
        pointer-events: none !important;
        border: none !important;
    }

    .services,
    div.services,
    section .services {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        grid-auto-flow: row !important;
        gap: 10px !important;
        padding: 0 14px 8px !important;
        margin: 6px auto 0 !important;
        flex-direction: unset !important;
        flex-wrap: unset !important;
        background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%) !important;
    }

    .services > a,
    .services > a.service-card {
        display: flex !important;
        height: 100% !important;
    }

    .service-card,
    .services > a > .service-card,
    .services > a .service-card,
    .services > a.service-card {
        width: 100% !important;
        min-height: 118px !important;
        padding: 14px 8px 12px !important;
        border-radius: 16px !important;
        border: 1px solid #e8eef4 !important;
        box-shadow: 0 2px 8px rgba(15, 23, 42, 0.05) !important;
        background: #fff !important;
        transition: transform 0.22s ease, box-shadow 0.22s ease !important;
    }

    .service-card:active,
    .platform-stat-card:active {
        transform: scale(0.98) !important;
        box-shadow: 0 1px 4px rgba(15, 23, 42, 0.06) !important;
    }

    .service-icon {
        width: 46px !important;
        height: 46px !important;
        margin: 0 auto 8px !important;
        font-size: 19px !important;
        border-radius: 13px !important;
    }

    .service-name {
        font-size: 12px !important;
        margin-bottom: 6px !important;
        line-height: 1.25 !important;
    }

    .service-count {
        font-size: 10px !important;
        padding: 4px 8px !important;
    }

    .service-expand-btn,
    .service-expandable {
        display: none !important;
    }

    .platform-stats-section {
        padding: 0 0 16px !important;
        margin: 0 !important;
        background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%) !important;
        border: none !important;
        border-top: none !important;
    }

    .platform-stats-section .container {
        padding: 0 14px !important;
        max-width: 100% !important;
    }

    .platform-stat-grid {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 10px !important;
        max-width: 100% !important;
    }

    .platform-stat-card,
    .platform-stat-card--link {
        min-height: 118px !important;
        padding: 14px 8px 12px !important;
        border-radius: 16px !important;
        border: 1px solid #e8eef4 !important;
        box-shadow: 0 2px 8px rgba(15, 23, 42, 0.05) !important;
        background: #fff !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        text-align: center !important;
    }

    .platform-stat-card__icon {
        width: 46px !important;
        height: 46px !important;
        margin: 0 auto 8px !important;
        font-size: 19px !important;
        border-radius: 13px !important;
    }

    .platform-stat-card__value {
        font-size: 1.25rem !important;
        margin: 0 0 2px !important;
        line-height: 1.1 !important;
    }

    .platform-stat-card__title {
        font-size: 0.72rem !important;
        font-weight: 700 !important;
        line-height: 1.25 !important;
        margin: 0 0 4px !important;
        display: -webkit-box !important;
        -webkit-line-clamp: 2 !important;
        -webkit-box-orient: vertical !important;
        overflow: hidden !important;
        max-width: 100% !important;
    }

    .platform-stat-card__label {
        font-size: 0.58rem !important;
        margin-top: auto !important;
        line-height: 1.2 !important;
        letter-spacing: 0.05em !important;
    }
}

/* ── Downstream sections — tighter app rhythm ── */
@media (max-width: 768px) {
    #symptoms-diseases,
    .symptoms-diseases-section,
    .dbk-mr-section,
    .dbk-health-utils,
    .vitamins-minerals-section,
    .health-calculator-tools-section,
    #medical-qa-news,
    .qa-news-combined-section,
    .health-awareness-tips-section {
        padding-top: 24px !important;
        padding-bottom: 24px !important;
    }

    #symptoms-diseases .container,
    .symptoms-diseases-section .container,
    .dbk-mr-section__container,
    .dbk-health-utils .container,
    .vitamins-minerals-section .container {
        padding-left: 14px !important;
        padding-right: 14px !important;
    }

    #symptoms-diseases .symptoms-diseases-wrapper {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
    }

    .health-awareness-tips-section {
        padding-top: 20px !important;
        padding-bottom: 20px !important;
    }

    .hub-tips-card {
        min-height: 0 !important;
        padding: 14px 14px 0 !important;
        border-radius: 18px !important;
    }

    .hub-tips-carousel {
        min-height: 240px !important;
        height: 240px !important;
        max-height: 240px !important;
    }

    /* Medical resources quick links — no empty grid cell */
    .dbk-mr-quick {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 8px !important;
        justify-content: stretch !important;
    }

    .dbk-mr-quick a {
        justify-content: flex-start !important;
        text-align: left !important;
        border-radius: 12px !important;
        padding: 10px 12px !important;
        font-size: 0.72rem !important;
        line-height: 1.3 !important;
    }

    .dbk-mr-quick a:last-child:nth-child(odd) {
        grid-column: 1 / -1 !important;
    }

    .dbk-mr-world-grid {
        gap: 8px !important;
    }

    .dbk-mr-world-stat {
        border-radius: 12px !important;
        padding: 10px 12px !important;
    }

    /* Vitamins — compact cards */
    .vitamins-minerals-section {
        padding-top: 24px !important;
        padding-bottom: 24px !important;
    }

    .vitamins-header h2 {
        font-size: 1.35rem !important;
    }

    .vitamins-search-bar {
        padding: 12px !important;
        border-radius: 16px !important;
    }

    .vitamins-grid {
        gap: 12px !important;
        padding: 0 14px !important;
    }

    .vitamin-card {
        border-radius: 14px !important;
        padding: 12px 10px !important;
        box-shadow: 0 2px 8px rgba(15, 23, 42, 0.05) !important;
    }

    #medical-qa-news .qa-news-grid {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
    }

    #medical-qa-news .qa-news-trust {
        flex-wrap: wrap !important;
        gap: 6px !important;
    }

    /* Health awareness modal — app-style sheet */
    .health-tip-modal.active {
        padding: 12px !important;
        align-items: center !important;
        background: rgba(15, 23, 42, 0.72) !important;
        backdrop-filter: blur(4px);
    }

    .health-tip-modal-content {
        background: #fff !important;
        border-radius: 18px !important;
        padding: 8px !important;
        max-width: min(94vw, 400px) !important;
        max-height: 88vh !important;
        overflow: hidden !important;
        box-shadow: 0 20px 50px rgba(0, 0, 0, 0.35) !important;
    }

    .health-tip-modal-image,
    .health-tip-modal-image img {
        border-radius: 12px !important;
        max-height: 78vh !important;
        width: 100% !important;
        object-fit: contain !important;
    }

    .health-tip-modal-close {
        top: 10px !important;
        right: 10px !important;
        width: 38px !important;
        height: 38px !important;
        background: rgba(15, 23, 42, 0.75) !important;
        border: 2px solid rgba(255, 255, 255, 0.9) !important;
    }

    .hub-tips-carousel {
        border-radius: 14px !important;
    }

    .dbk-hu-tabs {
        overflow-x: auto !important;
        flex-wrap: nowrap !important;
        scrollbar-width: none !important;
        gap: 6px !important;
        padding-bottom: 4px !important;
    }

    .dbk-hu-tab {
        flex: 0 0 auto !important;
        font-size: 0.72rem !important;
        padding: 8px 12px !important;
        border-radius: 999px !important;
    }
}

@media (max-width: 480px) {
    .hero-search-box .search-tab,
    .search-tab {
        min-width: 0 !important;
        max-width: none !important;
        flex: 0 0 auto !important;
    }
}

@media (max-width: 380px) {
    .hero-search-box .search-tab,
    .search-tab {
        padding: 7px 9px !important;
        font-size: 10px !important;
        min-width: 0 !important;
        max-width: none !important;
    }

    .platform-stat-card__title {
        font-size: 0.68rem !important;
    }
}

@media (prefers-reduced-motion: reduce) {
    .service-card:active,
    .platform-stat-card:active {
        transform: none !important;
    }
}
