/*
 * Responsive / Mobile & Tablet compatibility
 * Additive rules only - does not change existing layout structure.
 * Breakpoints: 576px (phone), 768px (tablet), 992px (desktop)
 */

/* Prevent horizontal overflow on all pages */
html {
    overflow-x: hidden;
    -webkit-text-size-adjust: 100%;
}

body {
    overflow-x: hidden;
}

/* Images and video don't overflow container */
img, video {
    max-width: 100%;
    height: auto;
}

/* Touch-friendly tap highlight (does not change appearance) */
a, button, [role="button"], input[type="submit"], input[type="button"] {
    -webkit-tap-highlight-color: rgba(0, 168, 156, 0.15);
}

/* ========== Modals: fit small screens ========== */
@media (max-width: 575.98px) {
    .modal-dialog {
        max-width: calc(100vw - 1rem);
        margin: 0.5rem auto;
    }
    .modal-content {
        border-radius: 10px;
    }
    .modal-header,
    .modal-footer {
        padding: 1rem;
    }
    .modal-body {
        padding: 1rem;
    }
}

@media (min-width: 576px) and (max-width: 767.98px) {
    .modal-dialog {
        max-width: 90%;
        margin: 1rem auto;
    }
}

/* ========== Touch targets (min 44px) on mobile/tablet ========== */
@media (max-width: 991.98px) {
    /* Navbar toggler and top bar icons */
    .navbar-toggler,
    .navbar .navbar-menu-wrapper .navbar-toggler-right {
        min-width: 44px;
        min-height: 44px;
        padding: 0.5rem;
    }
    .topbar-icon-button,
    .navbar-nav-right .nav-item.dropdown .nav-link.count-indicator {
        min-width: 44px;
        min-height: 44px;
    }
    /* Sidebar nav links (when visible) */
    .sidebar .nav .nav-item .nav-link {
        min-height: 44px;
        padding-top: 0.75rem;
        padding-bottom: 0.75rem;
        display: flex;
        align-items: center;
    }
    /* Dropdown items in topbar */
    .navbar-dropdown .dropdown-item {
        min-height: 44px;
        padding: 0.75rem 1rem;
        display: flex;
        align-items: center;
    }
    /* Primary action buttons in content */
    .content-wrapper .btn-primary,
    .content-wrapper .btn-danger,
    .content-wrapper .btn-success {
        min-height: 44px;
        padding: 0.5rem 1rem;
    }
}

@media (max-width: 767.98px) {
    /* Content area padding */
    .content-wrapper {
        padding-left: 1rem;
        padding-right: 1rem;
    }
    /* Cards */
    .card-body {
        padding: 1rem;
    }
    /* Table scroll */
    .table-responsive {
        -webkit-overflow-scrolling: touch;
        overflow-x: auto;
    }
}

@media (max-width: 575.98px) {
    .content-wrapper {
        padding-left: 0.75rem;
        padding-right: 0.75rem;
    }
    .card-body {
        padding: 0.75rem;
    }
    /* Small buttons: keep tappable */
    .btn-sm {
        min-height: 40px;
        padding: 0.4rem 0.75rem;
    }
}

/* ========== Tables: scroll on small screens ========== */
@media (max-width: 991.98px) {
    .table-responsive {
        display: block;
        width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
}

/* ========== Forms: full width inputs on mobile ========== */
@media (max-width: 575.98px) {
    .content-wrapper .form-control,
    .content-wrapper .form-select,
    .content-wrapper select.form-control {
        font-size: 16px; /* avoids zoom on focus on iOS */
    }
}

/* ========== Dashboard main panel ========== */
@media (max-width: 991.98px) {
    .page-body-wrapper {
        padding-top: 60px; /* space for fixed navbar */
    }
}

/* ========== Toast on small screens ========== */
@media (max-width: 575.98px) {
    .toast-container,
    .app-toast {
        max-width: calc(100vw - 2rem);
        min-width: 0;
    }
}
