:root {
    --sidebar-width: 250px;
    --radius-lg: 1rem;
    --radius-md: 0.875rem;
}

html,
body {
    min-height: 100%;
}

body {
    overflow-x: hidden;
    background: #f8f9fa;
}

img {
    max-width: 100%;
    height: auto;
}

.table-responsive {
    -webkit-overflow-scrolling: touch;
}

.form-control,
.form-select,
textarea,
input,
select {
    max-width: 100%;
}

.btn {
    white-space: nowrap;
}

/* =========================
   AUTH PAGES
========================= */

.auth-wrapper {
    min-height: 100vh;
}

.auth-page-col {
    width: 100%;
    max-width: 560px;
}

.auth-card {
    width: 100%;
    border: 0;
    border-radius: var(--radius-lg);
}

.auth-card .form-control,
.auth-card .form-select,
.auth-card input,
.auth-card textarea {
    min-height: 48px;
    font-size: 0.95rem;
}

.auth-card textarea {
    min-height: 110px;
}

.auth-card .btn {
    min-height: 48px;
}

#timer-box a.btn-link {
    text-decoration: none;
}

/* =========================
   DASHBOARD LAYOUT
========================= */

.container-fluid.position-relative.bg-white.d-flex.p-0 {
    min-height: 100vh;
    align-items: stretch;
}

.sidebar {
    width: var(--sidebar-width);
    min-width: var(--sidebar-width);
    background: #fff;
    border-left: 1px solid #e9ecef;
}

.sidebar .navbar {
    position: sticky;
    top: 0;
    min-height: 100vh;
    padding-top: 1rem;
}

.content {
    flex: 1 1 auto;
    min-width: 0;
    background: #f8f9fa;
}

.page-wrapper {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.page-content {
    flex: 1 1 auto;
}

.page-content .bg-light.rounded,
.page-content .bg-white.rounded,
.page-content .rounded.shadow-sm,
.page-content .rounded {
    border-radius: var(--radius-lg) !important;
}

.page-content .form-control,
.page-content .form-select,
.page-content textarea,
.page-content input[type="text"],
.page-content input[type="number"],
.page-content input[type="email"],
.page-content input[type="password"],
.page-content input[type="file"] {
    min-height: 44px;
}

.page-content textarea {
    min-height: 110px;
}

.page-content .input-group .form-control {
    min-width: 0;
}

.page-content .table {
    margin-bottom: 0;
}

.page-content .table td,
.page-content .table th {
    vertical-align: middle;
}

.page-content .badge {
    white-space: nowrap;
}

.footer-wrapper footer {
    margin-top: auto;
}

@media (min-width: 1200px) {
    .page-content > .container-fluid,
    .page-content > .container {
        max-width: 1320px;
        margin: 0 auto;
    }
}

/* =========================
   TABLET & MOBILE
========================= */

@media (max-width: 991.98px) {
    body {
        font-size: 0.95rem;
    }

    .container-fluid.position-relative.bg-white.d-flex.p-0 {
        display: block !important;
    }

    .sidebar {
        width: 100%;
        min-width: 0;
        border-left: 0;
        border-bottom: 1px solid #e9ecef;
    }

    .sidebar .navbar {
        min-height: auto;
        position: static;
        padding: 0.75rem 1rem;
    }

    .sidebar .navbar-brand {
        margin: 0 0 0.75rem !important;
    }

    .sidebar .navbar-nav {
        display: flex;
        flex-direction: row;
        gap: 0.5rem;
        overflow-x: auto;
        white-space: nowrap;
        padding-bottom: 0.25rem;
    }

    .sidebar .navbar-nav .nav-link {
        width: auto;
        border: 1px solid #e9ecef;
        border-radius: 0.75rem;
        padding: 0.625rem 0.875rem;
        background: #fff;
    }

    .content {
        width: 100%;
    }

    .navbar.sticky-top {
        position: sticky;
        top: 0;
        z-index: 1020;
    }

    .page-content .container-fluid,
    .page-content .container {
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }

    .page-content .table {
        min-width: 700px;
    }

    .page-content .btn {
        min-height: 44px;
    }
}

@media (max-width: 767.98px) {
    .auth-wrapper {
        padding-top: 1rem;
        padding-bottom: 1rem;
    }

    .auth-card {
        border-radius: var(--radius-md);
        box-shadow: 0 0.25rem 0.75rem rgba(0, 0, 0, 0.08) !important;
    }

    .auth-card.p-4,
    .auth-card.p-5 {
        padding: 1rem !important;
    }

    .auth-card h4 {
        font-size: 1.15rem;
    }

    .auth-card .form-label,
    .auth-card small,
    .auth-card p {
        font-size: 0.9rem;
    }

    .page-content .container-fluid.pt-4.px-4,
    .page-content .container-fluid.pt-4.px-3,
    .page-content .container.py-5,
    .page-content .container-fluid.pt-4 {
        padding-top: 1rem !important;
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }

    .page-content .bg-light.rounded.p-4,
    .page-content .bg-white.rounded.p-4,
    .page-content .bg-light.rounded.p-5,
    .page-content .bg-white.rounded.p-5 {
        padding: 1rem !important;
    }

    .page-content h2 {
        font-size: 1.4rem;
    }

    .page-content h3 {
        font-size: 1.25rem;
    }

    .page-content h4,
    .page-content h5 {
        font-size: 1.1rem;
    }

    .page-content .d-flex.justify-content-between,
    .page-content .d-flex.justify-content-center.gap-2,
    .page-content .mb-3.d-flex.gap-2 {
        flex-wrap: wrap;
        gap: 0.75rem !important;
    }

    .page-content .d-flex.justify-content-between > .btn,
    .page-content .d-flex.justify-content-between > a,
    .page-content .d-flex.justify-content-center.gap-2 > .btn,
    .page-content .d-flex.justify-content-center.gap-2 > a,
    .page-content .mb-3.d-flex.gap-2 > .btn,
    .page-content .mb-3.d-flex.gap-2 > a {
        width: 100%;
    }

    .page-content .input-group {
        flex-wrap: wrap;
    }

    .page-content .input-group > .form-control,
    .page-content .input-group > .btn {
        width: 100%;
        border-radius: 0.75rem !important;
    }

    .page-content .card .position-absolute.badge {
        font-size: 0.75rem;
    }

    .page-content .nav-tabs {
        flex-wrap: nowrap;
        overflow-x: auto;
        white-space: nowrap;
    }

    .page-content .nav-tabs .nav-link {
        min-width: max-content;
    }
}

@media (max-width: 575.98px) {
    .page-content .table {
        min-width: 640px;
    }

    .page-content .list-group-item {
        padding-top: 0.85rem !important;
        padding-bottom: 0.85rem !important;
    }
}
/* =========================
   PUBLIC PAGES
========================= */

body.public-page {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    margin: 0;
    background-color: #f8f9fa;
}

.public-main {
    flex: 1 0 auto;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 2rem 1rem;
}

.public-main .card {
    width: 100%;
    max-width: 600px;
    border-radius: 1rem;
}

.public-footer {
    flex-shrink: 0;
}

.public-header h4 {
    font-size: 1.25rem;
}

@media (max-width: 767.98px) {
    .public-main {
        padding: 1rem;
        align-items: flex-start;
    }

    .public-main .card {
        max-width: 100%;
        border-radius: 0.875rem;
    }

    .public-main .card.p-4,
    .public-main .card.p-5 {
        padding: 1rem !important;
    }

    .public-header {
        margin-bottom: 1rem !important;
    }

    .public-header h4 {
        font-size: 1.05rem;
        text-align: center;
    }

    .public-header .btn {
        width: 100%;
    }
}

@media (min-width: 768px) {
    .public-main .card.p-4 {
        padding: 2rem !important;
    }

    .public-main .card.p-5 {
        padding: 3rem !important;
    }
}


.sidebar .nav-link,
.offcanvas .nav-link {
    color: #212529;
    border-radius: 0.75rem;
    margin-bottom: 0.35rem;
    padding: 0.75rem 1rem;
    transition: all 0.2s ease;
}

.sidebar .nav-link:hover,
.offcanvas .nav-link:hover {
    background: #f1f3f5;
    color: #0d6efd;
}

.sidebar .nav-link.active,
.offcanvas .nav-link.active {
    background: #e7f1ff;
    color: #0d6efd;
    font-weight: 700;
}

.offcanvas {
    width: 280px;
}

.offcanvas .offcanvas-header {
    border-bottom: 1px solid #e9ecef;
}

@media (max-width: 991.98px) {
    .content {
        width: 100%;
    }
}