/* ===============================
   Responsive CSS
   Only responsive fixes
================================ */

/* Tablets */
@media (max-width: 992px) {
    .hero {
        padding: 60px 15px;
        text-align: center;
    }

    .hero h1 {
        font-size: 2.4rem;
        line-height: 1.2;
    }

    .hero p {
        font-size: 1rem;
    }

    .business-card {
        margin-bottom: 20px;
    }

    .business-card img {
        width: 100%;
        height: 200px;
        object-fit: cover;
    }
}

/* Mobile */
@media (max-width: 768px) {
    body {
        overflow-x: hidden;
    }

    .container {
        max-width: 100%;
        padding-left: 15px;
        padding-right: 15px;
    }

    .hero {
        padding: 50px 15px;
        min-height: auto;
        text-align: center;
    }

    .hero h1 {
        font-size: 2rem;
        line-height: 1.25;
        word-break: break-word;
    }

    .hero p {
        font-size: 0.95rem;
        line-height: 1.6;
    }

    .hero .btn,
    .btn {
        width: 100%;
        margin-bottom: 10px;
    }

    .business-card {
        width: 100%;
        margin-bottom: 18px;
    }

    .business-card img {
        width: 100%;
        height: 180px;
        object-fit: cover;
        display: block;
    }

    .row {
        margin-left: 0;
        margin-right: 0;
    }

    [class*="col-"] {
        padding-left: 8px;
        padding-right: 8px;
    }

    .card {
        margin-bottom: 15px;
    }

    table {
        width: 100%;
        display: block;
        overflow-x: auto;
        white-space: nowrap;
    }

    img {
        max-width: 100%;
        height: auto;
    }
}

/* Small mobile */
@media (max-width: 576px) {
    .hero {
        padding: 40px 12px;
    }

    .hero h1 {
        font-size: 1.7rem;
    }

    .hero p {
        font-size: 0.9rem;
    }

    .business-card img {
        height: 160px;
    }

    h1 {
        font-size: 1.8rem;
    }

    h2 {
        font-size: 1.5rem;
    }

    h3 {
        font-size: 1.25rem;
    }

    .navbar-brand {
        font-size: 1.1rem;
    }

    .form-control,
    .form-select,
    .btn {
        font-size: 0.95rem;
    }
}

/* Extra small mobile */
@media (max-width: 400px) {
    .hero h1 {
        font-size: 1.5rem;
    }

    .business-card img {
        height: 145px;
    }

    .container {
        padding-left: 10px;
        padding-right: 10px;
    }
}
/* ===============================
   Admin Sidebar Responsive Fix
================================ */

/* Desktop / Laptop */
.admin-layout,
.dashboard-layout {
    display: flex;
    width: 100%;
    min-height: 100vh;
}

.admin-sidebar,
.sidebar {
    width: 260px;
    min-width: 260px;
    height: 100vh;
    position: sticky;
    top: 0;
    left: 0;
    display: block;
    overflow-y: auto;
    z-index: 1000;
}

.admin-main,
.main-content,
.dashboard-content {
    flex: 1;
    width: calc(100% - 260px);
    min-height: 100vh;
    overflow-x: hidden;
}

/* Tablet and Mobile */
@media (max-width: 768px) {
    .admin-layout,
    .dashboard-layout {
        display: block;
        width: 100%;
    }

    .admin-sidebar,
    .sidebar {
        width: 100%;
        min-width: 100%;
        height: auto;
        position: relative;
        display: block !important;
        overflow: visible;
        z-index: 9999;
    }

    .admin-sidebar ul,
    .sidebar ul {
        display: flex;
        flex-wrap: nowrap;
        overflow-x: auto;
        gap: 8px;
        padding: 10px;
        margin: 0;
        list-style: none;
    }

    .admin-sidebar li,
    .sidebar li {
        flex: 0 0 auto;
    }

    .admin-sidebar a,
    .sidebar a {
        display: block;
        white-space: nowrap;
        padding: 10px 14px;
        border-radius: 8px;
    }

    .admin-main,
    .main-content,
    .dashboard-content {
        width: 100%;
        margin-left: 0 !important;
        padding: 15px;
    }
}

/* Small Mobile */
@media (max-width: 576px) {
    .admin-sidebar,
    .sidebar {
        display: block !important;
    }

    .admin-sidebar ul,
    .sidebar ul {
        overflow-x: auto;
        scrollbar-width: thin;
    }

    .admin-main,
    .main-content,
    .dashboard-content {
        padding: 12px;
    }
}