﻿
/* ----------------------------------- */
/*   Responsive Layout for Phones      */
/*   (Grouped: General / Nav / Tables) */
/* ----------------------------------- */

/* ---------------------------------------------------------------- */
/* 4-column layout for VIN detail buttons                           */
/* Applies between 946px and 1580px                                 */
/* ---------------------------------------------------------------- */
@media (max-width: 1580px) and (min-width: 946px) {
    .options-container,
    .options-container.generated-only {
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        gap: 1rem 0.5rem;
    }

        .options-container .filter-container,
        .options-container.generated-only .filter-container {
            margin: 0 !important;
            grid-row: auto;
            grid-column: auto;
        }

            .options-container .filter-container select {
                min-width: 25%;
                max-width: 50%;
            }

            .options-container .filter-container.reset-filters,
            .options-container.generated-only .filter-container.reset-filters {
                grid-column: 3 / 3;
                grid-row: 1;
            }

        .options-container .inner-tab-container,
        .options-container.generated-only .inner-tab-container {
            grid-column: 3 / 5;
            grid-row: 1;
            padding-left: 0.5rem;
            margin-bottom: 0.25rem;
        }
}

/* ---------------------------------------------------------------- */
/* Adjust "reset-filters" placement between 946px and 1045px        */
/* ---------------------------------------------------------------- */
@media (max-width: 1045px) and (min-width: 946px) {
    .options-container .filter-container.reset-filters,
    .options-container.generated-only .filter-container.reset-filters {
        grid-column: 4;
        grid-row: 2;
    }
}

/* ======= GENERAL MOBILE LAYOUT ======= */
/* Applies at 945px and below */
@media (max-width: 945px) {
    html, body {
        font-size: 0.9375rem !important;
        margin: 0 !important;
        padding: 0 !important;
        overflow-x: hidden !important;
    }

    .wrapper {
        max-width: 100vw !important;
        margin: 0.75rem auto !important;
        padding: 0 0.25rem !important;
    }

    .section {
        padding: 0.875rem 0.25rem !important;
        border-radius: 0 !important;
        box-shadow: none !important;
    }

    .login-form input,
    .login-form button {
        font-size: 1rem !important;
        padding: 0.6875rem 0.4375rem !important;
        width: 100% !important;
    }

    .header-container,
    header {
        padding: 0.1875rem 0.125rem !important;
    }

    .header-title {
        font-size: 1.1rem !important;
    }

    #infoContainer {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        padding: 5px 20px !important;
        gap: 0.25rem !important;
    }

    .report-description {
        position: static !important;
        width: 100% !important;
        order: 2 !important;
        margin: 0 !important;
        font-size: 14px !important;
    }

    #middleInfo {
        order: 1 !important;
        margin: 0 !important;
        text-align: center !important;
    }

    .user-menu-wrapper {
        position: absolute !important;
        top: 50% !important;
        right: 20px !important;
        transform: translateY(-50%) !important;
    }

    .dataviewer-page {
        height: calc(100vh - 5rem);
    }
}

/* ======= NAV PAGE GRID - MOBILE ======= */
/* Applies at 945px and below */
@media (max-width: 945px) {
    .nav-container {
        display: grid;
        grid-template-columns: repeat(auto-fit, 4.6em);
        justify-content: center;
        gap: 0.75rem;
        padding: .5rem 0;
        width: 100%;
        box-sizing: border-box;
    }

    .nav-button {
        width: 4.5rem;
        height: 5rem;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: flex-start;
        padding-top: -.5rem;
        gap: 0.25rem;
        box-sizing: border-box;
    }

        .nav-button img {
            width: 1.5rem;
            height: auto;
        }

        .nav-button .button-text {
            font-size: 0.7rem;
            line-height: 1.2;
            text-align: center;
            white-space: normal;
            word-break: break-word;
            margin-top: -1.25rem;
            padding: 0 0.25rem;
        }
}

/* === OPTIONS CONTAINER – MOBILE (≤945px) === */
@media (max-width: 945px) {
    .inner-tab-container {
        margin: 0;
    }

    .options-container {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: .5rem;
        padding: 0.75rem;
        box-sizing: border-box;
        max-height: 12rem;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15) !important;
    }

        .options-container .filter-container {
            display: flex;
            flex-direction: column;
            gap: 0.2rem;
            margin: 0;
        }

            .options-container .filter-container label {
                margin: 0;
                font-weight: bold;
            }

            .options-container .filter-container select {
                width: 100%;
                max-height: 5rem;
                overflow-y: auto;
            }

            .options-container .filter-container .checkbox-group {
                width: 100%;
                max-height: 5rem;
                overflow-y: auto;
                margin-top: 0.2rem;
            }

            .options-container .filter-container > div,
            .options-container .filter-container button {
                width: 100%;
                padding-top: 0.3rem;
                padding-bottom: 0.3rem;
                font-size: 0.9rem;
                box-sizing: border-box;
                margin: 0;
                margin-top: .2rem;
                border-radius: .8rem;
            }

            .options-container .filter-container.reset-filters {
                grid-column: 1 / -1;
                min-height: 1rem;
            }

                .options-container .filter-container.reset-filters button {
                    padding-top: .6rem;
                    border-radius: 1rem;
                }

        .options-container .inner-tab-container {
            grid-column: 1 / -1;
            display: flex;
            flex-wrap: wrap;
            gap: 0.5rem;
            justify-content: center;
            grid-row: 1 !important;
            grid-column: 1 / -1 !important;
        }

            .options-container .inner-tab-container .inner-tab {
                flex: 1 1 auto;
                min-width: 5rem;
                text-align: center;
                padding: 0.5rem;
                font-size: 0.9rem;
                box-sizing: border-box;
            }

        .options-container .filter-container select,
        .options-container .filter-container .checkbox-group {
            width: 100% !important;
            max-width: 100% !important;
            box-sizing: border-box;
        }

    .vin-meta {
        width: 100%;
        text-align: center;
    }

    #js-vin-rowcount {
        text-align: center !important;
        display: inline-block;
        width: 100%;
    }

    .label-group {
        align-items: flex-start;
    }
}

/* === REPORT TABS: full-width below filters on mobile === */
/* Applies at 945px and below */
@media (max-width: 945px) {
    .options-container.generated-only .inner-tab-container {
        flex-direction: row !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 0.5rem !important;
        padding-top: 5px;
    }

    .options-container.generated-only .btn-download {
        width: auto !important;
        padding: 0.25rem 0.5rem !important;
        display: inline-flex !important;
        align-items: center;
    }

        .options-container.generated-only .btn-download > span {
            display: none !important;
        }

        .options-container.generated-only .btn-download::after {
            content: "XL";
            margin-left: 0.25rem;
            font-size: 0.9rem;
        }

    .options-container.generated-only #js-vin-generated-date {
        display: inline-block !important;
        margin: 0 !important;
        font-size: 0.85rem;
        line-height: 1.2;
    }

    div.options-container.generated-only {
        padding: 0 !important;
    }

    .otd-selections-wrapper {
        max-width: 100%;
    }
}

/* === SIDEBAR → BOTTOM NAV BAR (scrollable) - MOBILE === */
/* Applies at 945px and below */
@media (max-width: 945px) {
    .sidebar,
    .sidebar.slide-in,
    .sidebar.slide-in.show {
        position: fixed !important;
        top: auto !important;
        bottom: 0 !important;
        left: 0 !important;
        width: 100% !important;
        height: 5rem !important;
        transform: none !important;
        opacity: 1 !important;
        padding: 0.5rem 0 !important;
        background-color: #f4f4f4 !important;
        box-shadow: 0 -1px 5px rgba(0,0,0,0.1) !important;
        z-index: 1000 !important;
    }

        .sidebar nav {
            display: flex !important;
            flex-direction: row !important;
            flex-wrap: nowrap !important;
            overflow-x: auto !important;
            -webkit-overflow-scrolling: touch !important;
            padding: 0 0.5rem !important;
            box-sizing: border-box !important;
        }

            .sidebar nav a {
                flex: 0 0 auto !important;
                width: 5rem !important;
                margin: 0 0.25rem !important;
                padding: 0.5rem 0 !important;
                text-align: center !important;
                font-size: 0.75rem !important;
                white-space: nowrap !important;
                color: #003366 !important;
            }

                .sidebar nav a img {
                    width: 1.25rem !important;
                    height: auto !important;
                    margin-bottom: 0.25rem !important;
                }

    .content-container,
    .main-container {
        margin-left: 0 !important;
        margin-bottom: 4rem !important;
    }
}

/* ======= TABLES: horizontal scroll - MOBILE ======= */
/* Applies at 945px and below */
@media (max-width: 945px) {
    .wholesale-wrapper,
    .vin-summary-wrapper {
        margin: 0 !important;
    }

    .excel-table.wholesale,
    .vin-summary,
    .vin-detail,
    .excel-table.vin-pulsereport {
        font-size: 0.97rem !important;
        width: 99vw !important;
        overflow-x: auto !important;
        display: block !important;
    }

        .excel-table.wholesale th,
        .excel-table.wholesale td,
        .vin-summary th,
        .vin-summary td,
        .vin-detail th,
        .vin-detail td,
        .excel-table.vin-pulsereport th,
        .excel-table.vin-pulsereport td {
            padding: 0.375rem 0.125rem !important;
            min-width: 2.5rem !important;
            max-width: 90vw !important;
        }

    .filter-container.reset-filters {
        margin-top: 15px !important;
    }
}

/* === SINGLE COLUMN ON PHONES (≤430px) === */
@media (max-width: 430px) {
    .options-container {
        grid-template-columns: 1fr;
    }

    .nav-container {
        grid-template-columns: 1fr !important;
    }

    .label-group {
        align-items: flex-start;
    }

    .filter-container.reset-filters {
        margin-top: 15px !important;
    }
}

/* ----------------------------------------------------------- */
/*   End responsive Layout for Phones                          */
/* ----------------------------------------------------------- */


/* Hide submenus on mobile - they're not needed in bottom nav */
@media (max-width: 945px) {
    .sidebar .submenu {
        display: none;
    }

    .sidebar .submenu-arrow {
        display: none;
    }
}

/* ===== NAVIGATION PAGE DROPDOWN STYLES ===== */
/* Navigation button wrapper for dropdown positioning */
.nav-button-wrapper {
    position: relative;
    display: inline-block;
}

    .nav-button-wrapper .dropdown-arrow {
        font-size: 12px;
        margin-top: 4px;
        opacity: 0.7;
        transition: transform 0.2s ease;
    }

    .nav-button-wrapper.has-dropdown:hover .dropdown-arrow {
        transform: rotate(180deg);
    }

/* Navigation dropdown styling */
.nav-dropdown {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    min-width: 160px;
    background: #fff;
    border: 1px solid #ccc;
    border-radius: 0.5rem;
    box-shadow: 0 0.125rem 0.5rem rgba(0,0,0,0.15);
    z-index: 1000;
    padding: 0.5rem 0;
    display: flex;
    flex-direction: column;
    gap: 0;
    opacity: 0;
    visibility: hidden;
    transform: translateX(-50%) translateY(-10px);
    transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.2s ease;
    pointer-events: none;
    margin-top: 0; /* Remove the gap that was causing hover issues */
}

/* Create an invisible bridge to connect button and dropdown */
.nav-button-wrapper.has-dropdown::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    height: 4px; /* Small bridge to maintain hover */
    background: transparent;
    z-index: 999;
}

/* Show dropdown on hover */
.nav-button-wrapper:hover .nav-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
    pointer-events: auto;
}

/* Dropdown items */
.nav-dropdown .dropdown-link {
    display: block;
    width: 100%;
    text-align: center;
    background: none;
    border: none;
    padding: 8px 16px;
    font-size: 14px;
    cursor: pointer;
    color: #222;
    text-decoration: none;
    transition: background 0.18s;
    white-space: nowrap;
}

    .nav-dropdown .dropdown-link:hover {
        background: #f0f0f0;
        color: #003366;
    }

/* Hide nav dropdowns on mobile */
@media (max-width: 945px) {
    .nav-dropdown {
        display: none;
    }

    .nav-button-wrapper .dropdown-arrow {
        display: none;
    }

    .nav-button-wrapper.has-dropdown::after {
        display: none;
    }
}
