/* ================================================================
   App Scaffold — Tabler Overrides
   Replicated from CFM 4 Linux layout style
   ================================================================ */

/* ── Table Text ───────────────────────────────────────────────── */
.table td, .table th { font-weight: 600; }

/* ── Responsive tables ────────────────────────────────────────── */
@media (max-width: 991.98px) {
    .table-responsive { overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .table-responsive > .table { min-width: 600px; }
    .page, .page-wrapper, .page-body, .container-xl { overflow-x: hidden; max-width: 100vw; }
}

/* ── Toggle switch colors ─────────────────────────────────────── */
.form-switch .form-check-input { background-color: #d63939; border-color: #d63939; }
.form-switch .form-check-input:checked { background-color: #008710; border-color: #008710; }
.form-check-input:focus { box-shadow: 0 0 0 0.25rem rgba(0, 135, 16, 0.25); border-color: #008710; }

/* ── Global Topbar ────────────────────────────────────────────── */
.app-topbar {
    position: fixed; top: 0; left: 0; right: 0;
    height: 3.5rem;
    background: linear-gradient(90deg, #003e17, #008710);
    z-index: 1040;
    box-shadow: 0 1px 4px rgba(0,0,0,0.15);
}
.app-topbar-inner {
    display: flex; align-items: center; justify-content: space-between;
    height: 100%; padding: 0 1rem;
}
.app-topbar-brand {
    display: flex; align-items: center; gap: 0.5rem;
    color: #fff; text-decoration: none; font-size: 1.25rem; font-weight: 700; letter-spacing: 0.5px;
}
.app-topbar-brand:hover { color: #fff; text-decoration: none; }
.app-topbar-brand svg { flex-shrink: 0; }
.app-topbar-hamburger {
    background: none; border: none; color: #fff; font-size: 1.5rem;
    padding: 0.25rem; cursor: pointer; margin-left: 0.75rem; line-height: 1;
}
.app-topbar-hamburger:hover { opacity: 0.8; }
.app-topbar-icon { color: rgba(255,255,255,0.7); text-decoration: none; line-height: 1; }
.app-topbar-icon:hover { color: #fff; text-decoration: none; }
.app-topbar-user {
    display: flex; align-items: center; gap: 0.75rem;
}
.app-topbar-user-link {
    display: flex; align-items: center; color: #fff !important; text-decoration: none; padding: 0; cursor: pointer;
}
.app-topbar-user-link:hover { color: rgba(255,255,255,0.9) !important; text-decoration: none; }
.app-topbar-avatar { background: rgba(255,255,255,0.2) !important; color: #fff !important; font-weight: 600; }
.app-topbar-username { font-weight: 500; font-size: 0.875rem; line-height: 1.2; }
.app-topbar-role { font-size: 0.75rem; opacity: 0.75; line-height: 1.2; }
.app-topbar .dropdown-item { display: flex; align-items: center; }

/* ── Search bar placeholder ───────────────────────────────────── */
.app-topbar input::placeholder { color: #fff !important; opacity: 0.6; }
.app-topbar input {
    background: rgba(255,255,255,0.12) !important;
    border: 1px solid rgba(255,255,255,0.15) !important;
    color: #fff !important; font-size: 0.82rem; height: 32px;
}

/* ── Content spacing below fixed topbar ───────────────────────── */
.page-wrapper { padding-top: 3.5rem; }

/* ── Sidebar top spacing below fixed topbar ──────────────────── */
@media (min-width: 992px) {
    .navbar-vertical { padding-top: 3.5rem !important; }
    .navbar-vertical .navbar-collapse { margin-top: 0.5rem; }
}

/* ── Footer ───────────────────────────────────────────────────── */
.app-footer {
    padding: 0.75rem 1rem;
    text-align: center; font-size: 0.8125rem;
    color: var(--tblr-secondary);
    background: var(--tblr-body-bg, #fff);
    border-top: 1px solid var(--tblr-border-color);
}
.app-footer a { color: var(--tblr-primary); text-decoration: none; font-weight: 500; }
.app-footer a:hover { text-decoration: underline; }

/* ── Sidebar scrollbar ────────────────────────────────────────── */
@media (min-width: 992px) {
    .navbar-vertical .navbar-collapse {
        scrollbar-width: thin;
        scrollbar-color: rgba(255,255,255,0.2) transparent;
    }
    .navbar-vertical .navbar-collapse::-webkit-scrollbar { width: 3px; }
    .navbar-vertical .navbar-collapse::-webkit-scrollbar-thumb {
        background: rgba(255,255,255,0.2); border-radius: 2px;
    }

    /* Sidebar transitions */
    .navbar-vertical { transition: width 0.25s ease; overflow: hidden !important; }
    .page-wrapper { transition: margin-left 0.25s ease; }

    /* Collapsed sidebar */
    body.sidebar-collapsed .navbar-vertical { width: 70px !important; min-width: 70px !important; }
    body.sidebar-collapsed .navbar-vertical ~ .page-wrapper { margin-left: 70px !important; }
    body.sidebar-collapsed .navbar-vertical .nav-link-title,
    body.sidebar-collapsed .navbar-vertical .navbar-nav > .nav-item > span { display: none !important; }
    body.sidebar-collapsed .navbar-vertical .nav-item.mt-2 {
        margin-top: 0.25rem !important; border-top: 1px solid rgba(255,255,255,0.1); padding-top: 0.25rem;
    }
    body.sidebar-collapsed .navbar-vertical .nav-link { justify-content: center; padding-left: 0; padding-right: 0; }
    body.sidebar-collapsed .navbar-vertical .nav-link-icon { margin: 0; font-size: 1.35rem; }

    /* Tooltip on hover when collapsed */
    body.sidebar-collapsed .navbar-vertical .nav-link { position: relative; }
    body.sidebar-collapsed .navbar-vertical .nav-item > .nav-link::after {
        content: attr(data-sidebar-title);
        position: absolute; left: 100%; top: 50%; transform: translateY(-50%);
        background: #1e293b; color: #fff; padding: 4px 10px; border-radius: 4px;
        font-size: 0.8125rem; white-space: nowrap; opacity: 0; pointer-events: none;
        transition: opacity 0.15s; margin-left: 8px; z-index: 1100;
    }
    body.sidebar-collapsed .navbar-vertical .nav-item > .nav-link:hover::after { opacity: 1; }
}

/* ── Sidebar edge handle ──────────────────────────────────────── */
.sidebar-edge-handle {
    position: fixed;
    top: 50%;
    left: 15rem;
    transform: translateY(-50%);
    width: 10px;
    height: 144px;
    cursor: pointer;
    z-index: 1050;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--tblr-navbar-bg, #1b2434);
    border-radius: 0 10px 10px 0;
    transition: left 0.25s ease, opacity 0.2s ease;
    opacity: 0.6;
    color: rgba(255,255,255,0.7);
    font-size: 0.75rem;
}
.sidebar-edge-handle:hover { opacity: 1; }
.sidebar-edge-handle i { transition: transform 0.25s ease; }
body.sidebar-collapsed .sidebar-edge-handle { left: 70px; }
body.sidebar-collapsed .sidebar-edge-handle i { transform: rotate(180deg); }

/* ── Active nav item indicator color ──────────────────────────── */
.navbar-expand-lg .nav-item.active:after { border-color: #008710 !important; }

/* ── Toast container ──────────────────────────────────────────── */
#toast-container { z-index: 1090 !important; }
