/**
 * 모바일 우측 하단 플로팅 퀵 메뉴 (768px 이하만)
 * PC .quick-side-menu 와 클래스 분리
 */

.mobile-floating-menu {
    display: none;
}

@media (max-width: 768px) {
    .mobile-floating-menu {
        display: block;
    }
}

@media (min-width: 769px) {
    .mobile-floating-menu {
        display: none !important;
    }
}

.mobile-floating-dim {
    position: fixed;
    inset: 0;
    z-index: 9400;
    background: rgba(0, 0, 0, 0.45);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.28s ease, visibility 0.28s ease;
}

.mobile-floating-menu.is-open .mobile-floating-dim {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

@media (max-width: 768px) {
    /*
     * 토글은 우하단 고정, 리스트는 토글 “위”에만 겹치지 않게 절대 배치
     * --mf-toggle-size: 토글 .mobile-floating-toggle 과 동일 (56px)
     */
    .mobile-floating-stack {
        --mf-toggle-size: 56px;
        --mf-toggle-list-gap: 14px;

        position: fixed;
        right: 16px;
        left: auto;
        bottom: calc(84px + env(safe-area-inset-bottom, 0px));
        z-index: 9500;
        width: auto;
        max-width: none;
        display: flex;
        flex-direction: column;
        align-items: flex-end;
    }

    /* 한 열 max-content → 가장 긴 라벨(예: 최근본차량) 폭에 맞춰 4개 pills 동일 너비 */
    .mobile-floating-list {
        position: absolute;
        right: 0;
        left: auto;
        bottom: calc(var(--mf-toggle-size) + var(--mf-toggle-list-gap));
        display: grid;
        grid-template-columns: max-content;
        row-gap: 12px;
        width: max-content;
        max-width: calc(100vw - 32px);
        align-items: stretch;
        list-style: none;
        margin: 0;
        padding: 0;
        box-sizing: border-box;
    }

    .mobile-floating-menu:not(.is-open) .mobile-floating-list {
        pointer-events: none;
    }

    .mobile-floating-menu.is-open .mobile-floating-list {
        pointer-events: auto;
    }

    /* 좌측 아이콘·숫자 배지 28px 슬롯 통일 → 라벨 시작선 정렬 (베이스 크기와 동일) */
    .mobile-floating-menu .mobile-floating-item {
        display: flex;
        align-items: center;
    }

    .mobile-floating-menu .mobile-floating-icon svg,
    .mobile-floating-menu .mobile-floating-icon img {
        width: 24px;
        height: 24px;
        display: block;
    }

    .mobile-floating-menu .mobile-floating-label {
        margin-left: 0;
        padding-left: 0;
        min-width: 0;
        transform: none;
    }
}

.mobile-floating-item {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 16px;
    min-height: 48px;
    padding: 10px 18px 10px 14px;
    border: none;
    background: #fff;
    color: #111;
    text-decoration: none;
    font-size: 0.9375rem;
    font-weight: 600;
    line-height: 1.3;
    cursor: pointer;
    box-sizing: border-box;
    border-radius: 999px;
    box-shadow: 0 6px 24px rgba(0, 0, 0, 0.12);
    text-align: left;
    width: 100%;
    min-width: 0;
    white-space: nowrap;
    transform: translateY(14px);
    opacity: 0;
    transition:
        transform 0.38s cubic-bezier(0.22, 1, 0.36, 1),
        opacity 0.38s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.2s ease;
}

.mobile-floating-item:hover,
.mobile-floating-item:focus-visible {
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.16);
    outline: none;
}

.mobile-floating-item:focus-visible {
    box-shadow: 0 0 0 2px #fff, 0 0 0 4px var(--primary, #276ee1);
}

.mobile-floating-icon {
    flex: 0 0 28px;
    width: 28px;
    height: 28px;
    min-width: 28px;
    min-height: 28px;
    box-sizing: border-box;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--primary, #276ee1);
}

.mobile-floating-icon svg,
.mobile-floating-icon img {
    width: 24px;
    height: 24px;
    display: block;
}

.mobile-floating-label {
    flex: 0 0 auto;
    white-space: nowrap;
}

.mobile-floating-count-wrap {
    flex: 0 0 28px;
    width: 28px;
    height: 28px;
    min-width: 28px;
    min-height: 28px;
    box-sizing: border-box;
    padding: 0;
    border-radius: 50%;
    background: var(--primary, #276ee1);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    font-weight: 700;
    line-height: 1;
}

.mobile-floating-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 0;
    font-size: inherit;
    font-weight: inherit;
    line-height: 1;
}

.mobile-floating-count-wrap.is-empty {
    visibility: hidden;
    pointer-events: none;
}

.mobile-floating-toggle {
    width: 56px;
    height: 56px;
    min-width: 56px;
    min-height: 56px;
    border-radius: 50%;
    border: none;
    padding: 0;
    background: var(--primary, #276ee1);
    color: #fff;
    cursor: pointer;
    box-shadow: 0 6px 20px rgba(39, 110, 225, 0.45);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.mobile-floating-toggle:hover {
    transform: scale(1.04);
}

.mobile-floating-toggle:active {
    transform: scale(0.98);
}

.mobile-floating-toggle:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px rgba(39, 110, 225, 0.45);
}

.mobile-floating-toggle__label,
.mobile-floating-toggle__close {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity 0.22s ease, transform 0.22s ease;
}

.mobile-floating-toggle__label {
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.15;
    text-align: center;
    padding: 0 6px;
    opacity: 1;
    transform: scale(1);
}

.mobile-floating-toggle__close {
    opacity: 0;
    transform: rotate(-90deg) scale(0.6);
    pointer-events: none;
}

.mobile-floating-toggle__close svg {
    width: 22px;
    height: 22px;
    display: block;
}

.mobile-floating-menu.is-open .mobile-floating-toggle__label {
    opacity: 0;
    transform: scale(0.85);
    pointer-events: none;
}

.mobile-floating-menu.is-open .mobile-floating-toggle__close {
    opacity: 1;
    transform: rotate(0) scale(1);
    pointer-events: auto;
}

/* 열림: 아래(버튼에 가까운 항목)부터 짧은 딜레이 — 이용후기 → … → 예약조회 */
.mobile-floating-menu.is-open .mobile-floating-item:nth-child(4) {
    transition-delay: 0.05s;
}
.mobile-floating-menu.is-open .mobile-floating-item:nth-child(3) {
    transition-delay: 0.1s;
}
.mobile-floating-menu.is-open .mobile-floating-item:nth-child(2) {
    transition-delay: 0.15s;
}
.mobile-floating-menu.is-open .mobile-floating-item:nth-child(1) {
    transition-delay: 0.22s;
}

.mobile-floating-menu.is-open .mobile-floating-item {
    transform: translateY(0);
    opacity: 1;
}

.mobile-floating-menu:not(.is-open) .mobile-floating-item {
    transition-delay: 0s !important;
}

/*
 * 최근본차량 모달 (#recent-viewed-root) — 768px 이하만 2열 그리드
 * PC·태블릿(recent-viewed.css)은 미디어쿼리 밖에서 유지
 */
@media (max-width: 768px) {
    #recent-viewed-root .recent-viewed__box {
        width: min(92vw, 420px);
        max-width: min(92vw, 420px);
    }

    #recent-viewed-root .recent-viewed__list {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 12px;
        align-items: stretch;
    }

    #recent-viewed-root .recent-viewed__item {
        display: flex;
        width: 100%;
        min-width: 0;
        max-width: none;
        flex-basis: auto;
        box-sizing: border-box;
        border-bottom: none;
    }

    #recent-viewed-root .recent-viewed__item:last-child {
        border-bottom: none;
    }

    #recent-viewed-root .recent-viewed__row-main {
        width: 100%;
        min-width: 0;
        flex: 1 1 auto;
    }

    /* recent-viewed.css @640px thumb width:100% 등이 그리드 셀을 넓게 쓰도록 */
    #recent-viewed-root .recent-viewed__thumb-wrap {
        max-width: 100%;
    }

    #recent-viewed-root .recent-viewed__info {
        min-width: 0;
        flex: 1 1 auto;
    }
}
