/**
 * DoctorBookly — /pages/labs listing cards (responsive polish)
 * Loaded after inline labs.php styles.
 */

.grid-labs .offer-content {
    min-height: 0;
}

.grid-labs .offer-content .lab-pricing-box,
.grid-labs .offer-content .offer-pricing-box {
    margin-top: auto;
}

/* Desktop / laptop — 3 cards per row, buttons below pricing box */
@media (min-width: 1024px) {
    .grid-labs {
        align-items: stretch;
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }
}

@media (min-width: 768px) {
    .grid-labs .offer-card {
        height: 100%;
    }

    .grid-labs .offer-image {
        height: 140px;
        min-height: 140px;
        max-height: 140px;
    }

    .grid-labs .lab-card-image-btn,
    .grid-labs .lab-card-image-btn img {
        min-height: 140px;
        max-height: 140px;
    }

    .grid-labs .offer-desc {
        -webkit-line-clamp: 2;
    }

    .grid-labs .lab-tests-grid .lab-test-chip:nth-child(n+5) {
        display: none;
    }

    .grid-labs .lab-pricing-box,
    .grid-labs .offer-pricing-box {
        flex-direction: column !important;
    }

    .grid-labs .offer-cta-row {
        flex-direction: column;
        gap: 8px;
        margin-top: auto;
    }

    .grid-labs .offer-cta-row .btn-book-lab,
    .grid-labs .offer-cta-row .btn-primary,
    .grid-labs .offer-cta-row .btn-lab-wa-prefill,
    .grid-labs .offer-cta-row .btn-lab-wa-secondary,
    .grid-labs .offer-cta-row .btn-lab-website {
        width: 100%;
        flex: 1 1 auto;
        min-height: 42px;
        font-size: 13px;
    }
}

@media (max-width: 1023px) and (min-width: 768px) {
    .grid-labs {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 767px) {
    .labs-page {
        padding-bottom: 24px;
    }

    .hero-labs {
        padding: 24px 14px 52px !important;
    }

    .hero-labs h1 {
        font-size: 1.35rem !important;
        margin-bottom: 6px !important;
    }

    .hero-labs-desc {
        font-size: 14px !important;
    }

    .labs-search-bar-container {
        padding: 12px 12px 10px !important;
        margin: -36px 10px 14px !important;
        width: calc(100% - 20px) !important;
        border-radius: 14px !important;
    }

    .labs-search-bar-main {
        gap: 8px !important;
        margin-bottom: 8px !important;
    }

    .labs-search-input-wrap input,
    .labs-search-input-wrap select {
        padding: 10px 12px 10px 40px !important;
        font-size: 15px !important;
    }

    .labs-trust-strip {
        margin-bottom: 8px !important;
    }

    .labs-results-header {
        margin-bottom: 10px !important;
    }

    .labs-results-count {
        font-size: 14px !important;
    }

    .grid-labs {
        gap: 10px !important;
        padding: 0 10px !important;
    }

    .grid-labs .offer-card {
        border-radius: 12px !important;
    }

    .grid-labs .offer-image {
        height: 96px !important;
        min-height: 96px !important;
        max-height: 96px !important;
    }

    .grid-labs .lab-card-image-btn,
    .grid-labs .lab-card-image-btn img {
        min-height: 96px !important;
        max-height: 96px !important;
    }

    .grid-labs .offer-content {
        padding: 8px 10px 10px !important;
    }

    .grid-labs .offer-title {
        font-size: 0.95rem !important;
        margin-bottom: 2px !important;
        line-height: 1.2 !important;
    }

    .grid-labs .offer-clinic-line {
        font-size: 10px !important;
        margin-bottom: 4px !important;
    }

    .grid-labs .lab-home-collection-tag {
        font-size: 9px !important;
        padding: 3px 6px !important;
        margin-bottom: 4px !important;
    }

    .grid-labs .offer-desc {
        font-size: 11px !important;
        line-height: 1.35 !important;
        -webkit-line-clamp: 1 !important;
        margin-bottom: 2px !important;
    }

    .grid-labs a.view-full-details {
        font-size: 10px !important;
        margin-bottom: 4px !important;
    }

    .grid-labs .lab-tests-panel {
        padding: 6px 6px 5px !important;
        margin-bottom: 6px !important;
        border-radius: 8px !important;
    }

    .grid-labs .lab-tests-panel-head {
        margin-bottom: 4px !important;
    }

    .grid-labs .lab-tests-panel-title {
        font-size: 11px !important;
    }

    .grid-labs .lab-tests-count {
        font-size: 9px !important;
        padding: 1px 5px !important;
    }

    .grid-labs .lab-tests-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
        gap: 4px !important;
    }

    .grid-labs .lab-tests-grid .lab-test-chip:nth-child(n+5) {
        display: none !important;
    }

    .grid-labs .lab-test-chip {
        min-height: 26px !important;
        padding: 3px 2px !important;
    }

    .grid-labs .lab-test-chip-name {
        font-size: 9px !important;
        -webkit-line-clamp: 1 !important;
    }

    .grid-labs .lab-tests-more-btn {
        min-height: 28px !important;
        padding: 4px 6px !important;
        margin-top: 4px !important;
        font-size: 10px !important;
    }

    .grid-labs .offer-pricing-box,
    .grid-labs .lab-pricing-box {
        padding: 5px 8px !important;
        margin-bottom: 6px !important;
    }

    .grid-labs .offer-cta-row {
        flex-direction: column !important;
        gap: 5px !important;
    }

    .grid-labs .offer-cta-row .btn-primary,
    .grid-labs .offer-cta-row .btn-lab-wa-prefill,
    .grid-labs .offer-cta-row .btn-lab-wa-secondary,
    .grid-labs .offer-cta-row .btn-lab-website {
        width: 100% !important;
        min-height: 36px !important;
        padding: 6px 5px !important;
        font-size: 11px !important;
        border-radius: 8px !important;
    }

    .grid-labs .discount-badge {
        font-size: 7px !important;
        padding: 2px 6px !important;
    }

    .grid-labs .lab-flag-report-btn {
        width: 22px !important;
        height: 22px !important;
    }
}

@media (max-width: 380px) {
    .grid-labs .lab-tests-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }

    .grid-labs .offer-image {
        height: 88px !important;
        min-height: 88px !important;
        max-height: 88px !important;
    }
}

@media (prefers-reduced-motion: reduce) {
    .grid-labs .offer-card,
    .grid-labs .offer-card:hover {
        transition: none;
        transform: none;
    }
}
