/*
 * Optimized Responsive Control CSS
 * Breakpoints: 768px (mobile), 769px-1024px (tablet)
 */

/* Default (>768px): Show PC, hide SP */
.pc-version { display: block !important; }
.sp-version {
    display: none !important;
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
}

/* Tablet adjustments (769px - 1024px) */
@media (min-width: 769px) and (max-width: 1024px) {
    /* Header optimization for tablet */
    .pc-version .header-truck-icon {
        width: 60px !important;
        height: 40px !important;
    }

    .header-logo-section {
        margin-right: 10px;
    }

    .pc-version .header-brand-name {
        font-size: 20px !important;
    }

    .pc-version .header-service-type {
        font-size: 10px !important;
        padding: 3px 10px !important;
    }

    .pc-version .header-area-badge {
        padding: 6px 10px !important;
    }

    .pc-version .header-area-text {
        font-size: 12px !important;
    }

    .pc-version .header-phone-box,
    .pc-version .header-email-box {
        padding: 10px 16px !important;
        gap: 8px !important;
    }

    .pc-version .header-phone-icon,
    .pc-version .header-email-icon {
        width: 24px !important;
        height: 24px !important;
    }

    .pc-version .header-phone-number {
        font-size: 18px !important;
    }

    .pc-version .header-phone-hours,
    .pc-version .header-email-subtitle {
        font-size: 10px !important;
    }

    .pc-version .header-email-title {
        font-size: 14px !important;
    }

    .pc-version .nav-item {
        padding: 12px 8px !important;
        font-size: 13px !important;
    }

    .pc-version .header-container {
        padding: 0 16px !important;
    }

    /* Hero section - Prevent text clipping */
    .pc-version .hero-text {
        left: 20px !important;
        transform: none !important;
        width: 90% !important;
        max-width: 500px !important;
    }

    .pc-version .hero-title {
        font-size: 45px !important;
        letter-spacing: 5px !important;
    }

    .pc-version .hero-subtitle {
        font-size: 20px !important;
        letter-spacing: 4px !important;
    }

    .pc-version .info-box {
        left: 30px !important;
        transform: translateX(0) !important;
        width: 95% !important;
        max-width: 420px !important;
    }

    .pc-version .info-text {
        width: 280px !important;
        font-size: 14px !important;
    }

    /* Hero background - Align to right edge */
    .pc-version .coverage-cta-section {
        background-position: right center !important;
    }

    /* Trouble section - Reposition image to avoid overlap */
    .pc-version .trouble-img {
        position: static !important;
        display: block !important;
        margin: 0 auto 20px auto !important;
        width: 70px !important;
        height: 134px !important;
    }

    .pc-version .trouble-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        max-width: 560px !important;
        margin: 0 auto 48px auto !important;
        gap: 20px !important;
    }

    .pc-version .trouble-card {
        width: 100% !important;
        max-width: 260px !important;
        margin: 0 auto !important;
    }

    /* Footer - Map layout like area section */
    .pc-version .footer-area {
        max-width: 95% !important;
        padding: 32px 30px 40px !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
    }

    .pc-version .here-wrapper {
        position: static !important;
        width: 220px !important;
        height: 220px !important;
        margin: 20px auto 30px auto !important;
        display: block !important;
        order: 0 !important;
    }

    .pc-version .ttl-13 {
        order: -1 !important;
        margin-bottom: 20px !important;
    }

    .pc-version .txt-133 {
        max-width: 100% !important;
        padding-right: 0 !important;
        order: 1 !important;
        text-align: center !important;
    }

    .pc-version .txt-134 {
        max-width: 100% !important;
        padding-right: 0 !important;
        order: 2 !important;
        text-align: center !important;
    }

    .pc-version .map-circle {
        width: 110px !important;
        height: 110px !important;
        top: 205px !important;
    }

    /* Accordion fixes - Ensure buttons are clickable */
    .pc-version .item-btn {
        cursor: pointer !important;
        pointer-events: auto !important;
        position: relative !important;
        z-index: 10 !important;
    }

    .pc-version .faq-question {
        cursor: pointer !important;
        pointer-events: auto !important;
        position: relative !important;
        z-index: 10 !important;
    }

    /* Ensure accordion content transitions work */
    .pc-version .item-detail-content {
        transition: max-height 0.4s ease, opacity 0.4s ease !important;
    }

    .pc-version .faq-answer {
        transition: max-height 0.4s ease, opacity 0.4s ease !important;
    }
}

/* Mobile (≤768px): Hide PC, show SP */
@media (max-width: 768px) {
    .pc-version { display: none !important; }
    .sp-version {
        display: block !important;
        width: 100%;
        max-width: 100%;
        overflow-x: hidden;
    }
    body {
        padding-top: 0;
        margin: 0;
    }
    html {
        -webkit-text-size-adjust: 100%;
        overflow-x: hidden;
        max-width: 100%;
        margin: 0;
        padding: 0;
    }
}

/* Print: Show both versions */
@media print {
    .pc-version, .sp-version { display: block !important; }
}

/* Tablet portrait (401px - 785px) - SP version adjustments */
@media (min-width: 500px) and (max-width: 785px) {
    /* ① Hero section - Narrow the yellow card */
    .hero-bg-sp {
        height: 155%;
    }

    .hero-content-sp {
        top: 12%;
    }

    .sp-version .hero-card-wrapper-sp {
        max-width: 400px !important;
        margin: 0 auto !important;
        padding: 0 20px !important;
    }

    .sp-version .yellow-info-card-sp {
        max-width: 100% !important;
    }

    /* ② Step section - Center area card */
    .sp-version .step-area-card-sp {
        max-width: 320px !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }

    .step-phone-btn-sp .step-btn-content-sp {
        color: white;
        text-align: center;
    }

    /* ② Step section - Adjust button width to match hero buttons */
    .sp-version .step-btn-sp {
        max-width: 370px !important;
        margin-left: auto !important;
        margin-right: auto !important;
        text-align: center;
    }

    /* ③ Step section - Center text for Step2-5 with left-aligned line breaks */
    .sp-version .step-card-sp {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        width: 90%;
        margin: 0 auto;
    }

    .sp-version .step-lead-sp {
        text-align: left !important;
        width: fit-content !important;
        max-width: 100% !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }

    .sp-version .step-detail-sp {
        text-align: left !important;
        width: fit-content !important;
        max-width: 100% !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }

    .sp-version .step-content-wrapper-sp {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
    }

    .step1-highlight-bg-sp {
        left: auto;
    }

    .estimate-highlight-wrapper-sp {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
    }

    .estimate-highlight-bg-sp {
        left: 90px;
    }

    .estimate-final-wrapper-sp {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
    }

    .estimate-final-highlight-sp {
        left: auto;
    }

    .sp-version .step-content-text-sp {
        text-align: left !important;
        width: fit-content !important;
        max-width: 100% !important;
    }

    .sp-version .step-content-desc-sp {
        text-align: left !important;
        width: fit-content !important;
        max-width: 100% !important;
    }

    .sp-version .step-simple-content-sp {
        align-items: center !important;
    }

    .sp-version .step-simple-title-sp {
        text-align: left !important;
        width: fit-content !important;
        max-width: 100% !important;
    }

    .sp-version .step-simple-desc-sp {
        text-align: left !important;
        width: fit-content !important;
        max-width: 100% !important;
    }

    .step-content-highlight-sp {
        left: 100px;
    }

    .step5-content-wrapper-sp {
        left: 135px;
    }

    /* ④ Service section - Narrow and center service cards */
    .sp-version .services-list-sp {
        max-width: 400px !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }

    .sp-version .service-card-sp {
        max-width: 100% !important;
    }

    /* ④ Option section - Narrow and center option cards */
    .sp-version .option-section-sp {
        max-width: 400px !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }

    .sp-version .option-card-sp {
        max-width: 100% !important;
    }

    /* Pricing section - Truckpack cards width 50% */
    .sp-version .truckpack-cards-sp {
        margin-left: auto !important;
        margin-right: auto !important;
    }

    .feature-card-sp {
        width: 90%;
        margin: 0 auto;
    }

    .category-items-grid-sp {
        justify-content: space-evenly;
    }

    .item-expand-btn-sp {
        width: 200px;
        height: 40px;
        font-size: 14px;
    }

    .area-accordion-sp {
        max-width: 85%;
    }

    .qa-contact-btn-sp {
        width: 75%;
    }

    .form-section-sp {
        padding: 0px 40px;
    }
}
