    .directory-hero-container {
        z-index: 10;
    }

    .directory-hero-text {
        padding: 20px 50px 10px 50px !important;
    }

    .directory-hero-title {
        margin-bottom: 0 !important;
    }

    .directory-page-offset {
        margin-top: -50px !important;
    }

    .directory-sticky-card {
        top: 100px;
        border: 1px solid rgba(79, 163, 247, 0.14);
        border-radius: 22px;
        overflow: hidden;
        background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
        box-shadow: 0 18px 45px rgba(15, 23, 42, 0.08);
    }

    .directory-filter-body {
        max-height: calc(100vh - 200px);
        overflow-y: auto;
        padding: 0.85rem 0.85rem 1rem !important;
        background: linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
        scrollbar-width: thin;
        scrollbar-color: rgba(79, 163, 247, 0.6) transparent;
    }

    .directory-state-select-container {
        position: relative;
    }

    .directory-filter-scroll {
        max-height: 200px;
        overflow-y: auto;
        padding: 0.35rem;
        border: 1px solid rgba(148, 163, 184, 0.18);
        border-radius: 16px;
        background: linear-gradient(180deg, #f8fbff 0%, #ffffff 100%);
        box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.04);
        scrollbar-width: thin;
        scrollbar-color: rgba(79, 163, 247, 0.55) transparent;
    }

    .directory-sticky-card .card-header {
        padding: 0.8rem 0.95rem;
        background: linear-gradient(135deg, #f7fbff 0%, #edf5ff 100%);
        border-bottom: 1px solid rgba(79, 163, 247, 0.14);
    }

    .directory-sticky-card .card-header h6 {
        display: flex;
        align-items: center;
        gap: 0.55rem;
        font-size: 0.96rem;
        font-weight: 700;
        color: #1e293b;
    }

    .directory-sticky-card .card-header h6 i {
        width: 1.7rem;
        height: 1.7rem;
        border-radius: 10px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        color: var(--primary-blue);
        background: rgba(79, 163, 247, 0.14);
        box-shadow: inset 0 0 0 1px rgba(79, 163, 247, 0.08);
    }

    #filterForm > .mb-3,
    .mobile-filter-form > .mb-3 {
        margin-bottom: 1rem !important;
    }

    #filterForm .form-label.small.fw-semibold,
    .mobile-filter-section-title {
        display: inline-flex;
        align-items: center;
        gap: 0.4rem;
        margin-bottom: 0.55rem !important;
        font-size: 0.72rem !important;
        font-weight: 700 !important;
        letter-spacing: 0.03em;
        text-transform: none;
        color: #64748b;
    }

    #filterForm .form-control,
    #filterForm .form-select,
    .mobile-filter-form .form-control,
    .mobile-filter-form .form-select {
        min-height: 40px;
        border-radius: 12px;
        border: 1px solid rgba(148, 163, 184, 0.35);
        background: #ffffff;
        box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
        padding: 0.55rem 0.8rem;
        font-size: 0.9rem;
        transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
    }

    #filterForm .form-control:focus,
    #filterForm .form-select:focus,
    .mobile-filter-form .form-control:focus,
    .mobile-filter-form .form-select:focus {
        border-color: rgba(79, 163, 247, 0.75);
        box-shadow: 0 0 0 0.2rem rgba(79, 163, 247, 0.14);
        transform: translateY(-1px);
    }

    #filterForm .form-check,
    .mobile-filter-form .form-check {
        display: flex;
        align-items: flex-start;
        gap: 0.55rem;
        padding-left: 0;
        margin-bottom: 0.45rem;
    }

    #filterForm .form-check:last-child,
    .mobile-filter-form .form-check:last-child {
        margin-bottom: 0;
    }

    #filterForm .form-check-input,
    .mobile-filter-form .form-check-input {
        float: none;
        flex-shrink: 0;
        width: 0.96rem;
        height: 0.96rem;
        margin: 0.72rem 0 0;
        border-radius: 6px;
        border: 1.5px solid rgba(148, 163, 184, 0.55);
        box-shadow: none;
    }

    #filterForm .form-check-input:focus,
    .mobile-filter-form .form-check-input:focus {
        box-shadow: 0 0 0 0.2rem rgba(79, 163, 247, 0.16);
    }

    #filterForm .form-check-input:checked,
    .mobile-filter-form .form-check-input:checked {
        background-color: var(--primary-blue);
        border-color: var(--primary-blue);
    }

    #filterForm .form-check-label,
    .mobile-filter-form .form-check-label {
        flex: 1;
        min-width: 0;
        display: flex;
        align-items: flex-start;
        gap: 0.6rem;
        padding: 0.48rem 0.58rem;
        border-radius: 12px;
        border: 1px solid rgba(148, 163, 184, 0.16);
        background: #ffffff;
        color: #334155;
        line-height: 1.35;
        font-weight: 500;
        font-size: 0.9rem;
        box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
        transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, color 0.18s ease;
        cursor: pointer;
    }

    #filterForm .form-check-label:hover,
    .mobile-filter-form .form-check-label:hover {
        transform: translateX(2px);
        border-color: rgba(79, 163, 247, 0.28);
        background: linear-gradient(135deg, #f8fbff 0%, #ffffff 100%);
        box-shadow: 0 8px 20px rgba(79, 163, 247, 0.08);
    }

    #filterForm .form-check-input:checked + .form-check-label,
    .mobile-filter-form .form-check-input:checked + .form-check-label {
        color: #1e3a5f;
        border-color: rgba(79, 163, 247, 0.3);
        background: linear-gradient(135deg, rgba(79, 163, 247, 0.14) 0%, rgba(255, 217, 102, 0.14) 100%);
        box-shadow: 0 10px 24px rgba(79, 163, 247, 0.12);
    }

    #filterForm .form-check-label i,
    .mobile-filter-form .form-check-label i {
        width: 1.42rem;
        height: 1.42rem;
        margin: 0 !important;
        border-radius: 9px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        color: var(--primary-blue) !important;
        background: rgba(79, 163, 247, 0.12);
        box-shadow: inset 0 0 0 1px rgba(79, 163, 247, 0.08);
        font-size: 0.82rem;
    }

    #filterForm .form-check-label small,
    .mobile-filter-form .form-check-label small {
        color: inherit;
        font-size: 0.94em;
        line-height: inherit;
    }

    #filterForm .d-grid.gap-2 {
        gap: 0.55rem !important;
        margin-top: 0.95rem;
    }

    #filterForm .btn,
    .mobile-filter-actions .btn {
        border-radius: 999px;
        font-weight: 700;
        letter-spacing: 0.01em;
        min-height: 42px;
        font-size: 0.88rem;
    }

    #filterForm .btn-primary,
    .mobile-filter-actions .btn-primary {
        border: none;
        background: linear-gradient(135deg, var(--primary-blue) 0%, #2e7bd6 100%);
        box-shadow: 0 14px 26px rgba(79, 163, 247, 0.22);
    }

    #filterForm .btn-primary:hover,
    .mobile-filter-actions .btn-primary:hover {
        transform: translateY(-1px);
        box-shadow: 0 16px 28px rgba(79, 163, 247, 0.26);
    }

    #filterForm .btn-outline-secondary,
    .mobile-filter-actions .btn-outline-secondary {
        color: #64748b;
        border-color: rgba(148, 163, 184, 0.45);
        background: #ffffff;
    }

    #filterForm .btn-outline-secondary:hover,
    .mobile-filter-actions .btn-outline-secondary:hover {
        color: #334155;
        border-color: rgba(79, 163, 247, 0.34);
        background: #f8fbff;
    }

    .directory-filter-body::-webkit-scrollbar,
    .directory-filter-scroll::-webkit-scrollbar,
    .mobile-filter-scroll::-webkit-scrollbar {
        width: 8px;
    }

    .directory-filter-body::-webkit-scrollbar-thumb,
    .directory-filter-scroll::-webkit-scrollbar-thumb,
    .mobile-filter-scroll::-webkit-scrollbar-thumb {
        background: rgba(79, 163, 247, 0.55);
        border-radius: 999px;
    }

    .directory-filter-body::-webkit-scrollbar-track,
    .directory-filter-scroll::-webkit-scrollbar-track,
    .mobile-filter-scroll::-webkit-scrollbar-track {
        background: transparent;
    }

    @media (max-width: 991.98px) {
        .mobile-filter-bar {
            position: sticky;
            top: 65px;
            z-index: 1030;
            display: flex;
            gap: 0.4rem;
            margin-top: -50px;
            padding: 0.45rem 0.4rem 0.55rem;
            background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(248, 250, 252, 0.92) 100%);
            backdrop-filter: blur(10px);
            border-bottom: 1px solid rgba(148, 163, 184, 0.2);
        }

        .mobile-filter-button {
            flex: 1;
            border-radius: 999px;
            border: 1px solid rgba(148, 163, 184, 0.38);
            background: #ffffff;
            color: #475569;
            font-size: 0.76rem;
            font-weight: 700;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: 0.3rem;
            padding: 0.48rem 0.48rem;
            box-shadow: 0 8px 18px rgba(15, 23, 42, 0.06);
            transition: all 0.2s ease;
        }

        .mobile-filter-button i {
            font-size: 0.8rem;
        }

        .mobile-filter-button.active {
            border-color: rgba(79, 163, 247, 0.45);
            color: var(--primary-blue);
            background: linear-gradient(135deg, rgba(79, 163, 247, 0.14) 0%, rgba(255, 217, 102, 0.14) 100%);
        }

        .mobile-filter-button .filter-indicator {
            width: 8px;
            height: 8px;
            border-radius: 999px;
            background: var(--primary-blue);
            display: inline-block;
            box-shadow: 0 0 0 4px rgba(79, 163, 247, 0.12);
        }

        .mobile-filter-overlay {
            position: fixed;
            inset: 0;
            background: rgba(15, 23, 42, 0.32);
            backdrop-filter: blur(2px);
            z-index: 1040;
            opacity: 0;
            pointer-events: none;
            transition: opacity 0.25s ease;
        }

        .mobile-filter-overlay.active {
            opacity: 1;
            pointer-events: auto;
        }

        .mobile-filter-panel {
            position: fixed;
            left: 10px;
            right: 10px;
            bottom: 8px;
            z-index: 1050;
            max-width: 420px;
            margin: 0 auto;
            max-height: 76vh;
            overflow-y: auto;
            padding-bottom: calc(0.85rem + env(safe-area-inset-bottom, 0px));
            background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
            border-radius: 22px;
            box-shadow: 0 -18px 36px rgba(15, 23, 42, 0.2);
            transition: transform 0.25s ease;
        }

        .mobile-filter-panel.collapse {
            display: block;
            height: auto !important;
            transform: translateY(100%);
        }

        .mobile-filter-panel.collapse.show {
            transform: translateY(0);
        }

        .mobile-filter-panel.collapsing {
            height: auto !important;
            transform: translateY(100%);
        }

        .mobile-filter-panel.collapsing.show {
            transform: translateY(0);
        }

        .mobile-filter-panel-body {
            padding: 0.95rem 0.9rem 1.15rem;
        }

        .mobile-filter-panel-body > .d-flex:first-child {
            padding-bottom: 0.72rem;
            margin-bottom: 0.8rem !important;
            border-bottom: 1px solid rgba(148, 163, 184, 0.2);
        }

        .mobile-filter-panel-body h5 {
            font-size: 0.95rem;
            font-weight: 700;
            color: #1e293b;
        }

        .mobile-filter-panel .btn-close {
            padding: 0.42rem !important;
            border-radius: 999px;
            background-color: rgba(148, 163, 184, 0.12);
            opacity: 0.85;
        }

        .mobile-filter-scroll {
            max-height: 205px;
            overflow-y: auto;
            padding: 0.3rem;
            border: 1px solid rgba(148, 163, 184, 0.18);
            border-radius: 15px;
            background: linear-gradient(180deg, #f8fbff 0%, #ffffff 100%);
            box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.04);
        }

        .mobile-filter-actions {
            display: flex;
            gap: 0.55rem;
            margin-top: 1rem;
        }

        .mobile-filter-actions .btn {
            flex: 1;
            min-height: 40px;
            font-size: 0.82rem;
        }

        .mobile-filter-form .form-check {
            gap: 0.45rem;
            margin-bottom: 0.38rem;
        }

        .mobile-filter-form .form-check-input {
            width: 0.9rem;
            height: 0.9rem;
            margin-top: 0.66rem;
        }

        .mobile-filter-form .form-check-label {
            gap: 0.55rem;
            padding: 0.42rem 0.5rem;
            font-size: 0.83rem;
            line-height: 1.3;
            border-radius: 11px;
        }

        .mobile-filter-form .form-check-label i {
            width: 1.32rem;
            height: 1.32rem;
            font-size: 0.76rem;
            border-radius: 8px;
        }

        .mobile-filter-form .form-control,
        .mobile-filter-form .form-select {
            min-height: 38px;
            padding: 0.5rem 0.75rem;
            font-size: 0.84rem;
        }

        body.mobile-filter-open {
            overflow: hidden;
        }
    }

    .directory-fade-in-card {
        animation: fadeInUp 0.35s ease backwards;
    }

    .directory-rating-star {
        font-size: 0.9rem;
    }

    .directory-rating-value {
        font-size: 1.4rem;
        line-height: 1;
        font-weight: 700;
    }

    .school-rating-score-horizontal .smarttag-score-label {
        font-size: 0.75rem;
        font-weight: 700;
    }

    .directory-rating-scale {
        font-size: 1rem;
    }

    .directory-review-tooltip-trigger {
        cursor: default;
    }

    /* Force the interest modal to fit the viewport without page scrolling */
    .interest-modal-compact .modal-dialog {
        max-width: min(680px, calc(100vw - 18px)) !important;
        margin: 0.45rem auto !important;
    }

    .interest-modal-compact .modal-content {
        display: flex;
        flex-direction: column;
        border-radius: 10px !important;
        min-height: min(380px, calc(100vh - 20px)) !important;
    }

    .interest-modal-compact .modal-header,
    .interest-modal-compact .modal-body,
    .interest-modal-compact .modal-footer {
        padding: 0.45rem 0.58rem !important;
    }

    .interest-modal-compact .modal-body {
        display: flex;
        flex: 1 1 auto;
        min-height: 0;
    }

    .interest-modal-compact .modal-header {
        align-items: flex-start;
        padding: 0.72rem 0.7rem 0.52rem !important;
    }

    .interest-modal-compact .modal-title {
        max-width: calc(100% - 1.75rem);
        margin: 0 !important;
        font-size: 0.9rem !important;
        line-height: 1.2 !important;
        white-space: normal;
        overflow: visible;
        text-overflow: clip;
        word-break: break-word;
    }

    .interest-modal-compact .btn-close {
        transform: scale(0.72);
        transform-origin: center;
        margin: 0 0 0 0.25rem !important;
        padding: 0.2rem !important;
    }

    .interest-modal-compact .interest-form {
        display: flex;
        flex: 1 1 auto;
        flex-direction: column;
        min-height: 0;
        font-size: 0.72rem;
    }

    .interest-modal-compact .interest-form-grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        grid-template-rows: auto auto minmax(104px, 1fr);
        gap: 0.4rem 0.58rem;
        flex: 1 1 auto;
        min-height: 0;
        width: 100%;
    }

    .interest-modal-compact .interest-field,
    .interest-modal-compact .interest-form-footer {
        margin: 0 !important;
        min-width: 0;
    }

    .interest-modal-compact .interest-field-full,
    .interest-modal-compact .interest-form-footer {
        grid-column: 1 / -1;
    }

    .interest-modal-compact .interest-field-full {
        display: flex;
        flex-direction: column;
        min-height: 0;
    }

    .interest-modal-compact .interest-form .form-label {
        margin-bottom: 0.14rem !important;
        font-size: 0.71rem !important;
        line-height: 1.1 !important;
    }

    .interest-modal-compact .interest-form .form-control {
        min-height: 29px !important;
        padding: 0.18rem 0.44rem !important;
        font-size: 0.71rem !important;
        line-height: 1.15 !important;
        border-radius: 0.42rem !important;
    }

    .interest-modal-compact .interest-form textarea.form-control {
        flex: 1 1 auto;
        min-height: 88px !important;
        resize: none;
    }

    .interest-modal-compact .interest-form .form-control::placeholder {
        font-size: 0.68rem;
    }

    .interest-modal-compact .interest-form small,
    .interest-modal-compact .interest-form .text-muted,
    .interest-modal-compact .interest-form .form-text {
        display: block;
        margin-top: 0.1rem;
        font-size: 0.6rem !important;
        line-height: 1.15 !important;
    }

    .interest-modal-compact .interest-form-footer,
    .interest-modal-compact .modal-footer {
        gap: 0.26rem;
        justify-content: flex-end;
        flex-wrap: wrap;
    }

    .interest-modal-compact .interest-form-footer {
        margin-top: 0.4rem !important;
        padding-top: 0.14rem !important;
    }

    .interest-modal-compact .modal-footer .btn {
        margin: 0 !important;
        padding: 0.2rem 0.42rem !important;
        font-size: 0.62rem !important;
        line-height: 1.1 !important;
        border-radius: 0.38rem !important;
        white-space: normal !important;
        text-align: center;
    }

    @media (max-width: 575.98px) {
        .interest-modal-compact .modal-dialog {
            max-width: calc(100vw - 10px) !important;
            margin: 0.3rem auto !important;
        }

        .interest-modal-compact .interest-form {
            min-height: auto;
        }

        .interest-modal-compact .interest-form-grid {
            grid-template-columns: 1fr;
            grid-template-rows: auto;
            gap: 0.34rem;
        }

        .interest-modal-compact .interest-field-full,
        .interest-modal-compact .interest-form-footer {
            grid-column: auto;
        }
    }

    /* School Rating Display - Modern Design */
    .school-rating-display {
        padding: 0.75rem 1rem;
        background: linear-gradient(135deg, rgba(79, 163, 247, 0.08), rgba(255, 217, 102, 0.08));
        border-radius: 12px;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
    }

    .school-rating-score .rating-number {
        font-size: 1.75rem;
        font-weight: 700;
        color: var(--primary-blue);
        line-height: 1;
        text-shadow: 0 2px 4px rgba(79, 163, 247, 0.15);
    }

    .school-rating-stars {
        line-height: 1;
    }

    .school-rating-stars i {
        font-size: 1rem;
        margin: 0 1px;
        filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.1));
    }

    .school-rating-display .text-muted {
        font-size: 0.85rem;
        font-weight: 500;
    }

    /* Heart Icon Button */
    .school-card-heart-btn {
        width: 36px;
        height: 36px;
        border-radius: 50%;
        background: linear-gradient(135deg, #ffd700 0%, #ffb347 50%, #ff9800 100%);
        border: none;
        color: #2c3e50;
        font-size: 16px;
        cursor: pointer;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        z-index: 5;
        box-shadow: 0 2px 12px rgba(255, 193, 7, 0.5), 0 0 20px rgba(255, 193, 7, 0.3);
        transition: all 0.3s ease;
    }

    .school-card-heart-btn:hover {
        background: linear-gradient(135deg, #ffed4e 0%, #ffd54f 50%, #ffb300 100%);
        color: #1a252f;
        transform: scale(1.15);
        box-shadow: 0 4px 16px rgba(255, 193, 7, 0.6), 0 0 30px rgba(255, 193, 7, 0.4);
    }

    .school-card-heart-btn:active {
        transform: scale(0.95);
        box-shadow: 0 2px 8px rgba(255, 193, 7, 0.4), 0 0 15px rgba(255, 193, 7, 0.3);
    }

    /* School Card Labels */
    .school-card-labels {
        display: flex;
        flex-wrap: wrap;
        gap: 4px;
        margin-bottom: 8px;
    }

    .school-card-labels .badge {
        font-size: 0.75rem;
        padding: 4px 8px;
        font-weight: 500;
    }

    /* Horizontal School Container Styles (Agoda-style) */
    .school-container-horizontal {
        transition: var(--transition);
    }

    .school-container-link {
        text-decoration: none !important;
        color: inherit !important;
    }

    .school-container-link:hover {
        text-decoration: none !important;
        color: inherit !important;
    }

    .school-container-card:hover,
    .school-container-card:focus-within {
        transform: translateY(-5px);
        box-shadow: var(--shadow-lg) !important;
    }

    .school-container-card {
        position: relative;
        transition: var(--transition);
        cursor: pointer;
    }

    .school-container-card .school-container-link::after {
        z-index: 1;
    }

    .school-image-wrapper {
        overflow: hidden;
        border-radius: var(--border-radius) 0 0 var(--border-radius);
        height: 360px;
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: center;
        background: linear-gradient(135deg, #f3f4f6 0%, #e5e7eb 100%);
    }

    .school-image-horizontal {
        transition: transform 0.3s ease;
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center;
    }

    .school-container-horizontal:hover .school-image-horizontal {
        transform: scale(1.05);
    }

    .school-collection-btn {
        transition: all 0.3s ease;
        z-index: 10;
        position: relative;
    }

    .school-collection-btn:hover {
        transform: scale(1.1);
        background-color: rgba(255, 255, 255, 0.9) !important;
    }

    /* Prevent clicks on buttons from triggering container link */
    .school-collection-btn,
    .im-interested-btn,
    .reviews-count-text {
        position: relative;
        z-index: 5;
    }

    .school-container-card .directory-card-actions,
    .school-container-card .directory-card-actions .directory-action-link,
    .school-container-card .directory-review-tooltip-trigger {
        position: relative;
        z-index: 5;
    }

    .school-container-card .school-card-middle-footer {
        position: relative;
        z-index: 5;
    }

    .school-container-link .school-collection-btn,
    .school-container-link .im-interested-btn {
        pointer-events: auto;
    }

    .school-collection-btn.active .fas.fa-heart {
        color: #dc3545 !important;
    }

    .school-rating-score-horizontal {
        text-align: right;
    }

    .rating-number-large {
        color: var(--primary-orange) !important;
        font-size: 2rem !important;
        line-height: 1 !important;
        font-weight: 700 !important;
    }

    .reviews-count-container {
        display: flex;
        align-items: center;
        justify-content: flex-end;
        gap: 0.25rem;
    }

    .reviews-count-text {
        font-size: 0.75rem !important;
        transition: color 0.2s ease;
        white-space: nowrap;
        cursor: pointer;
        text-decoration: none;
        color: #6c757d !important;
    }

    .reviews-count-text:hover {
        color: #495057 !important;
    }

    .reviews-count-text i {
        font-size: 0.7rem;
    }

    /* Review Tooltip - Detailed Breakdown with Progress Bars (2-Column Layout) */
    .review-tooltip {
        position: fixed;
        background: white;
        border: 1px solid #e0e0e0;
        border-radius: 8px;
        padding: 12px;
        box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15), 0 2px 8px rgba(0, 0, 0, 0.1);
        z-index: 9999;
        min-width: 280px;
        max-width: 320px;
        display: none;
    }

    .review-tooltip::after {
        content: '';
        position: absolute;
        bottom: -8px;
        left: 50%;
        transform: translateX(-50%);
        width: 0;
        height: 0;
        border-left: 8px solid transparent;
        border-right: 8px solid transparent;
        border-top: 8px solid white;
        filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.1));
    }

    .review-tooltip.show {
        display: block;
        animation: tooltipFadeIn 0.2s ease;
    }

    @keyframes tooltipFadeIn {
        from {
            opacity: 0;
            transform: translateY(-5px);
        }
        to {
            opacity: 1;
            transform: translateY(0);
        }
    }

    .review-tooltip-header {
        font-weight: 600;
        margin-bottom: 10px;
        color: #333;
        font-size: 0.85rem;
        padding-bottom: 6px;
        border-bottom: 1px solid #e0e0e0;
    }

    .review-tooltip-content {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 10px 12px;
    }

    .review-tooltip-category {
        margin-bottom: 0;
    }

    .review-tooltip-category-label {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-bottom: 4px;
        font-size: 0.75rem;
        color: #555;
    }

    .review-tooltip-category-name {
        font-weight: 500;
        display: flex;
        align-items: center;
        gap: 4px;
    }

    .review-tooltip-category-name i {
        font-size: 0.65rem;
    }

    .review-tooltip-category-score {
        font-weight: 600;
        color: var(--primary-blue);
        font-size: 0.8rem;
    }

    .review-tooltip-bar-container {
        position: relative;
        height: 6px;
        background-color: #e9ecef;
        border-radius: 3px;
        overflow: visible;
    }

    .review-tooltip-bar {
        height: 100%;
        background: linear-gradient(90deg, var(--primary-blue) 0%, #5a9fd8 100%);
        border-radius: 3px;
        transition: width 0.3s ease;
    }

    .review-tooltip-marker {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        width: 0;
        height: 0;
        border-left: 3px solid transparent;
        border-right: 3px solid transparent;
        border-top: 5px solid #333;
        margin-left: -3px;
    }

    .review-tooltip-footer {
        margin-top: 10px;
        padding-top: 8px;
        border-top: 1px solid #e0e0e0;
        font-size: 0.7rem;
        color: #666;
        text-align: center;
        grid-column: 1 / -1;
    }

    .review-tooltip-footer i {
        font-size: 0.65rem;
        margin-right: 4px;
    }

    .im-interested-btn {
        transition: all 0.2s ease;
        font-size: 0.95rem;
    }

    .im-interested-btn:hover {
        color: var(--primary-orange) !important;
        transform: translateX(5px);
    }

    /* ── 3-Column Card Layout ── */

    /* Special Label - 3D Ribbon from behind card */
    .special-label-ribbon-container {
        position: absolute;
        top: 18px;
        left: -2px;
        z-index: 20;
        pointer-events: none;
    }

    .special-label-ribbon-body {
        display: inline-flex;
        align-items: center;
        gap: 3px;
        background: linear-gradient(135deg, #1e88e5 0%, #1565c0 100%);
        color: #fff;
        padding: 4px 20px 4px 8px;
        font-size: 0.58rem;
        font-weight: 700;
        letter-spacing: 0.04em;
        white-space: nowrap;
        clip-path: polygon(0 0, calc(100% - 12px) 0, 100% 50%, calc(100% - 12px) 100%, 0 100%);
        filter: drop-shadow(0 3px 6px rgba(0, 0, 0, 0.45)) drop-shadow(1px 1px 0 rgba(0, 0, 0, 0.2));
        pointer-events: auto;
        cursor: default;
    }

    .special-label-ribbon-body i {
        font-size: 0.52rem;
        flex-shrink: 0;
    }

    .special-label-ribbon-text {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    /* Dark fold triangle at bottom-left — suggests ribbon wraps behind the card */
    .special-label-ribbon-fold {
        position: absolute;
        top: 100%;
        left: 0;
        width: 0;
        height: 0;
        border-top: 4px solid #0d3a8a;
        border-right: 4px solid transparent;
    }

    /* New to SmartTag — right-side green ribbon (mirrors the left blue ribbon) */
    .new-to-smarttag-ribbon-container {
        position: absolute;
        top: 18px;
        right: -2px;
        z-index: 20;
        pointer-events: none;
    }

    .new-to-smarttag-ribbon-body {
        display: inline-flex;
        align-items: center;
        gap: 3px;
        background: linear-gradient(135deg, #2e7d32 0%, #1b5e20 100%);
        color: #fff;
        padding: 4px 8px 4px 20px;
        font-size: 0.58rem;
        font-weight: 700;
        letter-spacing: 0.04em;
        white-space: nowrap;
        clip-path: polygon(12px 0, 100% 0, 100% 100%, 12px 100%, 0 50%);
        filter: drop-shadow(0 3px 6px rgba(0, 0, 0, 0.45)) drop-shadow(-1px 1px 0 rgba(0, 0, 0, 0.2));
        pointer-events: auto;
        cursor: default;
    }

    .new-to-smarttag-ribbon-body i {
        font-size: 0.52rem;
        flex-shrink: 0;
    }

    /* Dark fold triangle at bottom-right — mirrors the left ribbon's fold */
    .new-to-smarttag-ribbon-fold {
        position: absolute;
        top: 100%;
        right: 0;
        width: 0;
        height: 0;
        border-top: 4px solid #0a3d0a;
        border-left: 4px solid transparent;
    }

    /* Right rating panel */
    .directory-right-panel {
        background: linear-gradient(180deg, rgba(248, 250, 252, 0.6) 0%, #fff 100%);
    }

    @media (min-width: 768px) {
        .directory-right-panel {
            border-left: 1px solid rgba(0, 0, 0, 0.08) !important;
        }

        /* Fixed-size image column — always fixed, never stretches to card height */
        .school-card-img-col {
            flex: 0 0 240px !important;
            width: 240px !important;
            max-width: 240px !important;
            align-self: flex-start !important;
        }

        .school-card-3col .school-image-wrapper {
            width: 240px;
            height: 250px !important;
            min-height: 250px !important;
            max-height: 250px !important;
        }

        /* Right panel — fixed narrower width */
        .school-card-3col .directory-right-panel {
            flex: 0 0 calc(25% - 15px) !important;
            width: calc(25% - 15px) !important;
            max-width: calc(25% - 15px) !important;
        }

        /* Middle col — fills remaining space between image and right panel */
        .school-card-3col .school-card-middle-col {
            flex: 1 1 0 !important;
            width: auto !important;
            max-width: none !important;
            min-width: 0;
        }
    }

    /* Bottom footer (Suggest Edit / Own Business) */
    .directory-card-bottom-footer {
        position: relative;
        z-index: 5;
    }

    /* I'm Interested — bottom center of right panel */
    .school-card-3col .directory-card-actions {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 100%;
    }

    /* Rating score — always right-aligned in right panel */
    .school-card-3col .school-rating-score-horizontal {
        text-align: right;
        width: 100%;
    }

    /* Override global absolute-positioning of heart button inside the right panel — keep it in flex flow */
    .school-card-3col .directory-right-panel .school-card-heart-btn.school-collection-btn {
        position: relative !important;
        top: auto !important;
        right: auto !important;
        width: 36px !important;
        height: 36px !important;
        flex-shrink: 0 !important;
    }

    /* ── Image Slider ── */
    .school-image-slider {
        overflow: hidden;
    }

    /* Nav buttons — hidden by default, fade in on hover */
    .slider-nav {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        z-index: 8;
        width: 32px;
        height: 32px;
        border-radius: 50%;
        border: none;
        background: rgba(255, 255, 255, 0.88);
        color: #1e293b;
        font-size: 0.75rem;
        display: flex;
        align-items: center;
        justify-content: center;
        cursor: pointer;
        opacity: 0.7;
        transition: opacity 0.2s ease, background 0.2s ease, transform 0.2s ease;
        box-shadow: 0 2px 8px rgba(0,0,0,0.22);
        pointer-events: auto;
    }

    .slider-prev { left: 8px; }
    .slider-next { right: 8px; }

    .school-image-slider:hover .slider-nav {
        opacity: 1;
    }

    .slider-nav:hover {
        background: #fff;
        transform: translateY(-50%) scale(1.1);
    }

    .slider-nav:disabled {
        opacity: 0.3 !important;
        cursor: default;
    }

    /* Counter badge — Agoda-style bottom-left */
    .slider-counter {
        position: absolute;
        bottom: 10px;
        right: 10px;
        background: rgba(0,0,0,0.52);
        color: #fff;
        font-size: 0.65rem;
        font-weight: 600;
        padding: 2px 7px;
        border-radius: 12px;
        z-index: 8;
        pointer-events: none;
        letter-spacing: 0.02em;
    }

    /* Smooth image transition on slide */
    .school-image-slider .school-image-horizontal {
        transition: opacity 0.2s ease, transform 0.3s ease;
    }

    .school-image-slider .school-image-horizontal.slider-fading {
        opacity: 0;
    }

    /* iPad Mini and iPad Air specific fixes (768px - 1024px) */
    @media (min-width: 768px) and (max-width: 1024px) {
        /* Ensure mobile filter bar displays correctly on iPad */
        .mobile-filter-bar {
            position: sticky;
            top: 65px;
            z-index: 1030;
            background: #ffffff;
            margin-top: -50px;
            padding: 0.5rem 0.5rem 0.6rem;
            display: flex;
            gap: 0.5rem;
            border-bottom: 1px solid rgba(148, 163, 184, 0.25);
        }

        .mobile-filter-button {
            flex: 1;
            border-radius: 999px;
            border: 1px solid rgba(148, 163, 184, 0.45);
            background: #ffffff;
            font-size: 0.85rem;
            font-weight: 600;
            color: #475569;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: 0.4rem;
            padding: 0.5rem 0.6rem;
        }

        .mobile-filter-button i {
            font-size: 0.9rem;
        }

        .mobile-filter-button.active {
            border-color: var(--primary-blue);
            color: var(--primary-blue);
            background: rgba(79, 163, 247, 0.12);
        }

        /* Ensure school containers fill full width on iPad */
        .school-container-horizontal {
            width: 100% !important;
            max-width: 100% !important;
        }
        
        .school-container-card {
            width: 100% !important;
            max-width: 100% !important;
        }
        
        .school-list-horizontal {
            width: 100% !important;
            max-width: 100% !important;
        }
        
        /* Ensure container padding doesn't cause overflow */
        .container {
            padding-left: 1rem !important;
            padding-right: 1rem !important;
        }
        
        /* Ensure buttons stay in one row on iPad */
        .school-container-card .d-flex.justify-content-between.gap-3 {
            flex-wrap: nowrap !important;
            gap: 0.5rem !important;
        }
        
        .school-container-card .d-flex.gap-3.flex-wrap {
            flex-wrap: nowrap !important;
            gap: 0.5rem !important;
        }
        
        /* Override flex-wrap class on iPad */
        .school-container-card .flex-wrap {
            flex-wrap: nowrap !important;
        }
        
        /* Ensure button links don't wrap */
        .school-container-card .btn-link {
            white-space: nowrap !important;
            flex-shrink: 0 !important;
        }
        
        /* Ensure button container fills width */
        .school-container-card .mt-auto.pt-3.border-top > div {
            flex-wrap: nowrap !important;
            width: 100% !important;
        }
    }

    @media (max-width: 767.98px) {
        /* Directory page - mobile phones only (not iPad) */
        .directory-header-section {
            padding: 30px 0 40px !important;
            min-height: 150px !important;
        }
        
        .hero-text-container {
            padding: 20px 25px !important;
        }
        
        .hero-title {
            font-size: 1.25rem !important;
        }
        
        .hero-title i {
            font-size: 1.1rem !important;
        }
        
        .page-content {
            padding-top: 80px !important;
        }
        
        .container {
            padding-left: 0.75rem !important;
            padding-right: 0.75rem !important;
        }
        
        /* School cards - vertical layout for mobile phones (like before) */
        .school-container-horizontal .row {
            flex-direction: column !important; /* Vertical layout for mobile phones */
            margin-left: 0 !important;
            margin-right: 0 !important;
        }
        
        /* Force columns to full width for vertical layout on mobile */
        .school-container-horizontal .col-md-4,
        .school-container-horizontal .col-lg-3,
        .school-container-horizontal .col-md-8,
        .school-container-horizontal .col-lg-9,
        .school-container-horizontal .col-md-3,
        .school-container-horizontal .col-md-5,
        .school-container-horizontal .col-lg-5,
        .school-container-horizontal .col-lg-6,
        .school-container-horizontal .school-card-img-col,
        .school-container-horizontal .school-card-middle-col {
            flex: 0 0 100% !important;
            max-width: 100% !important;
            width: 100% !important;
            padding-left: 0 !important;
            padding-right: 0 !important;
            margin-left: 0 !important;
            margin-right: 0 !important;
        }

        /* Right panel — no left border on mobile, top border instead */
        .directory-right-panel {
            border-left: none !important;
            border-top: 1px solid rgba(0, 0, 0, 0.08);
        }

        /* Ribbons hidden on mobile (too small to be useful) */
        .special-label-ribbon-container,
        .new-to-smarttag-ribbon-container {
            display: none;
        }
        
        /* Ensure card itself fills full width and has no extra margins */
        .school-container-card.card {
            margin-left: 0 !important;
            margin-right: 0 !important;
            width: 100% !important;
            max-width: 100% !important;
        }
        
        /* Ensure row has no gutters on mobile */
        .school-container-horizontal .row.g-0 {
            margin-left: 0 !important;
            margin-right: 0 !important;
        }
        
        /* Ensure school containers fill full width on mobile */
        .school-container-horizontal {
            width: 100% !important;
            max-width: 100% !important;
            margin-left: 0 !important;
            margin-right: 0 !important;
        }
        
        .school-container-card {
            width: 100% !important;
            max-width: 100% !important;
            margin-bottom: 0.75rem !important;
            margin-left: 0 !important;
            margin-right: 0 !important;
        }
        
        .school-list-horizontal {
            width: 100% !important;
            max-width: 100% !important;
            margin-left: 0 !important;
            margin-right: 0 !important;
        }
        
        .school-image-wrapper {
            border-radius: var(--border-radius) var(--border-radius) 0 0 !important; /* Top rounded corners for vertical layout */
            height: 200px !important; /* Restored original height */
            min-height: 200px !important;
            max-height: 200px !important;
            width: 100% !important;
            margin-left: 0 !important;
            margin-right: 0 !important;
        }
        
        /* Ensure card body fills full width */
        .school-container-card .card-body {
            width: 100% !important;
            max-width: 100% !important;
            padding: 0.75rem !important;
            box-sizing: border-box !important;
        }
        
        /* Ensure buttons stay in one row and fill width */
        .school-container-card .d-flex.justify-content-between.gap-3 {
            width: 100% !important;
            flex-wrap: nowrap !important;
            gap: 0.5rem !important;
            margin-left: 0 !important;
            margin-right: 0 !important;
        }
        
        .school-container-card .d-flex.gap-3.flex-wrap {
            width: 100% !important;
            flex-wrap: nowrap !important;
            gap: 0.5rem !important;
            margin-left: 0 !important;
            margin-right: 0 !important;
        }
        
        /* Ensure button links don't wrap and fill available space */
        .school-container-card .btn-link {
            white-space: nowrap !important;
            flex-shrink: 0 !important;
        }
        
        /* Remove any margins that might cause blank space */
        .school-container-card .mt-auto.pt-3.border-top {
            width: 100% !important;
            margin-left: 0 !important;
            margin-right: 0 !important;
            padding-left: 0.75rem !important;
            padding-right: 0.75rem !important;
        }
        
        /* Ensure all content inside card body fills width */
        .school-container-card .card-body > * {
            width: 100% !important;
            max-width: 100% !important;
            box-sizing: border-box !important;
        }
        
        .school-container-card .card-body .d-flex {
            width: 100% !important;
            max-width: 100% !important;
        }
        
        /* Override flex-wrap class on mobile - force buttons to stay in one row */
        .school-container-card .flex-wrap {
            flex-wrap: nowrap !important;
        }
        
        /* Ensure nested flex containers also fill width */
        .school-container-card .card-body .d-flex.justify-content-between {
            width: 100% !important;
            max-width: 100% !important;
        }
        
        /* Make sure the inner button container also doesn't wrap */
        .school-container-card .card-body .d-flex.gap-3 {
            flex-wrap: nowrap !important;
        }

        .school-container-card .directory-card-actions > .d-flex {
            justify-content: flex-start !important;
            align-items: center !important;
            gap: 0.4rem !important;
        }

        .school-container-card .directory-card-actions > .d-flex > .btn-link,
        .school-container-card .directory-card-actions > .d-flex > .d-flex {
            flex: 0 1 auto !important;
            min-width: 0 !important;
        }

        .school-container-card .directory-card-actions > .d-flex > .d-flex {
            width: auto !important;
            max-width: none !important;
            gap: 0.4rem !important;
        }

        .school-container-card .directory-card-actions .btn-link {
            flex-shrink: 1 !important;
        }
        
        .school-image-horizontal {
            height: 100% !important;
            object-fit: cover !important;
        }
        
        .school-container-card h5,
        .school-container-card h6 {
            font-size: 0.75rem !important; /* Restored original size */
            margin-bottom: 0.5rem !important; /* Restored original margin */
        }
        
        .school-container-card .card-body {
            padding: 0.75rem !important; /* Restored original padding */
        }
        
        .school-rating-score-horizontal {
            text-align: left;
            margin-top: 0.5rem !important; /* Restored original margin */
        }
        
        .school-rating-display {
            text-align: center !important;
            padding: 0.5rem 0.75rem !important; /* Restored original padding */
        }
        
        .school-rating-display .d-flex {
            justify-content: center !important;
        }
        
        .school-rating-score .rating-number {
            font-size: 1.1rem !important; /* Restored original size */
        }
        
        .school-rating-stars i {
            font-size: 0.7rem !important; /* Restored original size */
        }
        
        .school-rating-display .text-muted {
            font-size: 0.65rem !important; /* Restored original size */
        }
        
        .school-card-heart-btn {
            width: 28px !important;
            height: 28px !important;
            font-size: 0.75rem !important;
        }
        
        .school-card-labels .badge {
            font-size: 0.6rem !important; /* Restored original size */
            padding: 0.2rem 0.4rem !important; /* Restored original padding */
        }
        
        .reviews-count-text {
            font-size: 0.6rem !important; /* Restored original size */
        }
        
        .reviews-count-text i {
            font-size: 0.55rem !important; /* Restored original size */
        }
        
        .rating-number-large {
            font-size: 1.25rem !important; /* Restored original size */
        }
        
        /* Filter buttons and controls */
        .btn {
            font-size: 0.7rem !important;
            padding: 0.35rem 0.6rem !important;
        }
        
        .btn i {
            font-size: 0.65rem !important;
        }
        
        .form-control,
        .form-select {
            font-size: 0.7rem !important;
            padding: 0.35rem 0.6rem !important;
        }
        
        /* Ensure state select dropdown opens downward */
        .state-select-dropdown {
            position: relative;
        }
        
        /* Temporarily add space below when select is focused */
        .state-select-container.dropdown-open {
            padding-bottom: 350px !important;
            margin-bottom: 0 !important;
            transition: padding-bottom 0.1s ease;
        }
        
        .state-select-container.dropdown-open + .mb-3 {
            margin-top: -330px !important;
            transition: margin-top 0.1s ease;
        }
        
        /* Page title and headings */
        h1, h2, h3, h4, h5, h6 {
            font-size: 0.9rem !important;
        }
        
        .page-title {
            font-size: 1rem !important;
        }
        
        /* Cards */
        .card {
            margin-bottom: 0.75rem !important;
        }
        
        .card-header {
            padding: 0.75rem !important;
            font-size: 0.75rem !important;
        }
        
        .card-body {
            padding: 0.75rem !important;
        }
        
        /* Found schools count - smaller and move down */
        .d-flex.justify-content-between.align-items-center.mb-4 p.text-muted.fw-semibold {
            font-size: 0.65rem !important;
            margin-top: 0.5rem !important;
            margin-bottom: 0.5rem !important;
            flex: 0 0 auto;
        }
        
        .d-flex.justify-content-between.align-items-center.mb-4 p.text-muted.fw-semibold i {
            font-size: 0.6rem !important;
        }
        
        .d-flex.justify-content-between.align-items-center.mb-4 p.text-muted.fw-semibold .text-primary {
            font-size: 0.65rem !important;
        }
        
        /* Mobile search bar styling - positioned on the right */
        .d-flex.justify-content-between.align-items-center.mb-4 .mobile-search-wrapper {
            flex: 0 0 auto;
            margin-left: auto;
            position: relative;
        }
        
        .mobile-search-form {
            display: flex;
            align-items: center;
        }
        
        .mobile-search-input-group {
            display: flex;
            align-items: center;
            flex-wrap: nowrap;
            background: #fff;
            border-radius: 20px;
            border: 1px solid #dee2e6;
            overflow: hidden;
            box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
            transition: all 0.3s ease;
            height: 28px;
        }
        
        .mobile-search-input-group:focus-within {
            border-color: var(--primary-blue, #4fa3f7);
            box-shadow: 0 2px 8px rgba(79, 163, 247, 0.2);
        }
        
        .mobile-search-input {
            border: none !important;
            border-radius: 0 !important;
            font-size: 0.65rem !important;
            padding: 0.25rem 0.5rem !important;
            height: 28px !important;
            min-width: 100px;
            max-width: 160px;
            background: transparent !important;
            box-shadow: none !important;
            line-height: 1.2 !important;
        }
        
        .mobile-search-input::placeholder {
            font-size: 0.6rem !important;
            color: #6c757d !important;
            opacity: 0.7 !important;
        }
        
        .mobile-search-input:focus {
            border: none !important;
            box-shadow: none !important;
            outline: none !important;
        }
        
        .mobile-search-btn {
            border: none !important;
            border-radius: 0 !important;
            background: var(--primary-blue, #4fa3f7) !important;
            color: #fff !important;
            font-size: 0.65rem !important;
            padding: 0.25rem 0.5rem !important;
            height: 28px !important;
            min-width: 28px;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: background 0.3s ease;
        }
        
        .mobile-search-btn:hover,
        .mobile-search-btn:focus {
            background: var(--primary-blue-dark, #3d8fd6) !important;
            color: #fff !important;
        }
        
        .mobile-search-btn:active {
            background: var(--primary-blue-darker, #2d7bb5) !important;
        }
        
        /* Ensure search suggestions appear directly below search bar with no gap */
        .mobile-search-wrapper + *,
        .mobile-search-form + * {
            margin-top: 0 !important;
        }
        
        /* If there's a search suggestion dropdown, position it directly below */
        .mobile-search-wrapper .dropdown-menu,
        .mobile-search-form .dropdown-menu {
            margin-top: 0 !important;
            border-top-left-radius: 0 !important;
            border-top-right-radius: 0 !important;
            border-top: none !important;
        }
        
        /* School container - smaller with proportional content */
        .school-container-card {
            margin-bottom: 0.6rem !important;
        }
        
        .school-container-card .card-body {
            padding: 0.6rem !important;
        }
        
        .school-container-card h5 {
            font-size: 0.7rem !important;
            margin-bottom: 0.4rem !important;
        }
        
        .school-container-card .text-muted,
        .school-container-card small {
            font-size: 0.6rem !important;
        }
        
        .school-container-card .text-muted i {
            font-size: 0.55rem !important;
        }
        
        /* Keep vertical layout on smaller mobile screens too */
        .school-container-horizontal .row {
            flex-direction: column !important; /* Vertical layout for very small screens too */
            margin-left: 0 !important;
            margin-right: 0 !important;
        }
        
        /* Force columns to full width for very small screens */
        .school-container-horizontal .col-md-4,
        .school-container-horizontal .col-lg-3,
        .school-container-horizontal .col-md-8,
        .school-container-horizontal .col-lg-9,
        .school-container-horizontal .col-md-3,
        .school-container-horizontal .col-md-5,
        .school-container-horizontal .col-lg-5,
        .school-container-horizontal .col-lg-6,
        .school-container-horizontal .school-card-img-col,
        .school-container-horizontal .school-card-middle-col {
            flex: 0 0 100% !important;
            max-width: 100% !important;
            width: 100% !important;
            padding-left: 0 !important;
            padding-right: 0 !important;
            margin-left: 0 !important;
            margin-right: 0 !important;
        }
        
        .school-image-wrapper {
            border-radius: var(--border-radius) var(--border-radius) 0 0 !important; /* Top rounded corners for vertical layout */
            height: 180px !important;
            min-height: 180px !important;
            max-height: 180px !important;
            width: 100% !important;
            margin-left: 0 !important;
            margin-right: 0 !important;
        }
        
        .school-image-horizontal {
            height: 100% !important;
            object-fit: cover !important;
        }
        
        .school-container-card .badge {
            font-size: 0.55rem !important;
            padding: 0.15rem 0.35rem !important;
        }
        
        .school-container-card .badge i {
            font-size: 0.5rem !important;
        }
        
        .rating-number-large {
            font-size: 1.1rem !important;
        }
        
        .school-container-card .text-muted[style*="font-size: 1rem"] {
            font-size: 0.55rem !important;
        }
        
        .school-container-card .btn {
            font-size: 0.6rem !important;
            padding: 0.3rem 0.5rem !important;
        }
        
        .school-container-card .btn i {
            font-size: 0.55rem !important;
        }
        
        .school-container-card .border-top {
            margin-top: 0.5rem !important;
            padding-top: 0.5rem !important;
        }
        
        .school-container-card .school-rating-display {
            padding: 0.4rem 0.6rem !important;
        }
        
        .school-container-card .school-rating-score .rating-number {
            font-size: 0.95rem !important;
        }
        
        .school-container-card .school-rating-stars i {
            font-size: 0.6rem !important;
        }
    }

    /* Very small mobile screens (max-width: 576px) - keep vertical layout */
    @media (max-width: 576px) {
        /* Keep vertical layout for very small screens */
        .school-container-horizontal .row {
            flex-direction: column !important;
        }
        
        .school-image-wrapper {
            height: 180px !important; /* Slightly smaller for very small screens */
            min-height: 180px !important;
            max-height: 180px !important;
        }
        
        /* Reduce padding on very small screens to fit content better */
        .school-container-card .card-body {
            padding: 0.6rem !important;
        }
        
        .school-container-card h5 {
            font-size: 0.7rem !important;
            margin-bottom: 0.4rem !important;
        }
        
        .school-container-card .text-muted {
            font-size: 0.6rem !important;
        }
        
        /* Make buttons smaller on very small screens */
        .school-container-card .btn-link {
            font-size: 0.6rem !important;
            padding: 0.3rem 0.5rem !important;
        }
        
        .school-container-card .btn-link i {
            font-size: 0.55rem !important;
        }

        .school-container-card .directory-card-actions {
            padding-left: 0.5rem !important;
            padding-right: 0.5rem !important;
        }

        .school-container-card .directory-card-actions > .d-flex,
        .school-container-card .directory-card-actions > .d-flex > .d-flex {
            gap: 0.28rem !important;
        }

        .school-container-card .directory-card-actions .btn-link {
            font-size: 0.5rem !important;
            letter-spacing: -0.01em;
        }

        .school-container-card .directory-card-actions .btn-link i {
            font-size: 0.46rem !important;
            margin-right: 0.12rem !important;
        }
    }

    .review-card {
        display: inline-flex;
        width: 100%;
        margin-bottom: 20px;
        background: white;
        border-radius: 12px;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
        overflow: hidden;
        transition: transform 0.3s ease, box-shadow 0.3s ease;
        break-inside: avoid;
        -webkit-column-break-inside: avoid;
        column-break-inside: avoid;
        flex-direction: column;
    }

    /* Reviews Masonry Layout (3-Column) - Dianping Style */
    .reviews-masonry {
        column-count: 3;
        column-gap: 24px;
        margin-top: 30px;
    }

    .reviews-section {
        background-color: #f8f9fa;
    }
    </style>
