/* ============================================================
   services-pricing-responsive.css
   Responsive styles for Services & Pricing Page
   ============================================================ */

/* ---- Tablet: 992px and below ---- */
@media (max-width: 992px) {

    .sp-hero-section {
        min-height: 720px;
        padding: 120px 24px 105px;
    }

    .sp-hero-title {
        font-size: clamp(48px, 11vw, 84px);
    }

    .sp-hero-subtitle {
        max-width: 620px;
    }

    .sp-rate-marquee-track {
        animation-duration: 24s;
    }

    .sp-rate-marquee-group span {
        font-size: 13px;
        padding: 10px 18px;
    }

    .sp-services-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .sp-intro-grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .sp-intro-image img {
        height: 320px;
    }

    .sp-intro-heading {
        font-size: 28px;
    }

    .sp-section-heading {
        font-size: 30px;
    }

    .sp-hospitality-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .sp-cleaning-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .sp-why-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .sp-lower-fees-section .sp-why-grid {
        grid-template-columns: repeat(2, 1fr);
        max-width: 720px;
    }

    .sp-direct-grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .sp-direct-list {
        grid-template-columns: repeat(2, 1fr);
    }

    .sp-why-owners-list {
        max-width: 100%;
    }

    .sp-why-owner-item {
        grid-template-columns: 1fr;
        gap: 16px;
        padding: 22px;
    }

    .sp-why-owner-left {
        align-items: flex-start;
    }

    .sp-invest-number {
        font-size: 80px;
    }

    .sp-investment-box {
        padding: 40px 40px;
    }

    .sp-cta-heading {
        font-size: 36px;
    }
}

/* ---- Mobile: 768px and below ---- */
@media (max-width: 768px) {

    .sp-hero-section {
        min-height: 640px;
        padding: 100px 20px 96px;
    }

    .sp-hero-eyebrow {
        font-size: 11px;
        letter-spacing: 4px;
        margin-bottom: 18px;
    }

    .sp-hero-title {
        font-size: clamp(44px, 15vw, 64px);
        line-height: 1;
        margin-bottom: 20px;
    }

    .sp-hero-subtitle {
        font-size: 16px;
    }

    .sp-hero-buttons {
        gap: 14px;
        margin-top: 30px;
    }

    .sp-hero-btn {
        width: min(100%, 300px);
        min-width: 0;
        min-height: 52px;
        font-size: 12px;
        letter-spacing: 1.5px;
        padding: 14px 20px;
    }

    .sp-rate-marquee {
        padding: 8px 0;
    }

    .sp-rate-marquee::before,
    .sp-rate-marquee::after {
        width: 44px;
    }

    .sp-container {
        padding: 0 20px;
    }

    .sp-intro-section,
    .sp-services-section,
    .sp-investment-section,
    .sp-why-section,
    .sp-cleaning-section,
    .sp-direct-section,
    .sp-hospitality-section {
        padding: 50px 0;
    }

    .sp-cta-section {
        padding: 60px 0;
    }

    .sp-section-heading {
        font-size: 26px;
        margin-bottom: 24px;
    }

    .sp-intro-heading {
        font-size: 26px;
    }

    .sp-services-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .sp-hospitality-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .sp-hospitality-card {
        min-height: 0;
        padding: 22px;
    }

    .sp-cleaning-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .sp-why-grid {
        grid-template-columns: 1fr 1fr;
        gap: 12px;
    }

    .sp-platform-badges {
        grid-template-columns: repeat(2, 1fr);
        gap: 28px 18px;
        margin: 38px auto 34px;
    }

    .sp-platform-badge {
        min-width: 0;
    }

    .sp-why-owner-right p {
        font-size: 14px;
    }

    .sp-invest-number {
        font-size: 70px;
    }

    .sp-investment-box {
        padding: 30px 24px;
    }

    .sp-cta-heading {
        font-size: 28px;
    }

    .sp-cta-buttons {
        flex-direction: column;
        align-items: center;
    }

    .sp-cta-buttons .sp-btn {
        width: 260px;
        text-align: center;
    }

    .sp-direct-list {
        grid-template-columns: 1fr;
        max-width: 520px;
    }

    .sp-intro-stats {
        flex-wrap: wrap;
        gap: 16px;
    }

    .sp-services-tagline {
        padding: 20px 24px;
    }

    .sp-lower-fees-heading {
        font-size: 24px;
    }

    .sp-why-grid {
        grid-template-columns: 1fr;
    }

    .sp-lower-fees-section {
        padding: 50px 20px;
    }

    .sp-lower-fees-section .sp-lower-fees-heading {
        font-size: 28px;
    }

    .sp-lower-fees-section .sp-lower-fees-sub {
        font-size: 15px;
        margin-bottom: 30px;
    }

    .sp-lower-fees-section .sp-why-grid {
        grid-template-columns: 1fr;
        gap: 14px;
        margin-bottom: 34px;
    }

    .sp-lower-fees-section .sp-why-item {
        min-height: 68px;
        padding: 16px;
    }

    .sp-lower-fees-section .sp-invest-footer-text {
        font-size: 16px;
        padding: 22px 20px;
    }
}

/* ---- Small Mobile: 480px and below ---- */
@media (max-width: 480px) {

    .sp-hero-section {
        min-height: 590px;
        padding: 90px 18px 88px;
    }

    .sp-hero-title {
        font-size: clamp(40px, 16vw, 54px);
    }

    .sp-hero-scroll {
        bottom: 26px;
    }

    .sp-lower-fees-section .sp-lower-fees-heading {
        font-size: 24px;
    }

    .sp-platform-badges {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .sp-platform-name {
        font-size: 28px;
    }

    .sp-platform-note {
        font-size: 16px;
    }

    .sp-hospitality-card {
        grid-template-columns: 1fr;
    }

    .sp-hospitality-card h4 {
        font-size: 16px;
    }

    .sp-section-heading {
        font-size: 22px;
    }

    .sp-intro-heading {
        font-size: 22px;
    }

    .sp-invest-number {
        font-size: 60px;
    }

    .sp-cta-heading {
        font-size: 24px;
    }

    .sp-label {
        font-size: 10px;
        letter-spacing: 2px;
    }

    .sp-btn {
        font-size: 12px;
        padding: 12px 24px;
        letter-spacing: 1.5px;
    }

    .sp-intro-image img {
        height: 240px;
    }
}
