/* PS Hisb - Bootstrap-friendly responsive styles */
:root{
    --bg:#f4f6fa;
    --sidebar:#1f2937;
    --sidebar-hover:#374151;
    --accent:#22c55e;
    --accent-2:#0ea5e9;
    --sidebar-width:240px;
}
html,body{margin:0;padding:0;background:var(--bg);font-family:'Segoe UI',Roboto,sans-serif;overflow-x:hidden;max-width:100vw}
.min-width-0{min-width:0}
/* Universal safety: make sure media and embeds never push the page wider */
img,svg,canvas,video,iframe{max-width:100%;height:auto}

/* ---------- LOGIN ---------- */
.login-wrap{
    min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px;
    background:linear-gradient(135deg,#0ea5e9,#22c55e);
}
.login-card{
    background:#fff;border-radius:14px;padding:32px;width:100%;max-width:380px;
    box-shadow:0 20px 60px rgba(0,0,0,.18);
}
.login-card h1{margin:0 0 4px;font-size:24px;font-weight:700}
.login-card .sub{color:#64748b;margin-bottom:18px}

/* ---------- LAYOUT ---------- */
.layout{display:flex;min-height:100vh;position:relative;max-width:100vw;overflow-x:clip}

/* ----- Sidebar (desktop) ----- */
.sidebar{
    width:var(--sidebar-width);background:var(--sidebar);color:#cbd5e1;flex-shrink:0;
    display:flex;flex-direction:column;
    transition:transform .25s ease;
}
.brand{padding:18px 20px;border-bottom:1px solid #334155;display:flex;align-items:center;gap:10px}
.brand-mark{
    background:linear-gradient(135deg,#22c55e,#0ea5e9);color:#fff;width:34px;height:34px;
    display:inline-flex;align-items:center;justify-content:center;border-radius:8px;font-weight:700;flex-shrink:0;
}
.brand-text{font-weight:600;font-size:18px;color:#fff}

.sidebar .nav{padding:10px 0;overflow-y:auto;flex:1;flex-wrap:nowrap !important}
.sidebar .nav-group{margin:6px 0}
.sidebar .nav-group-title{
    padding:6px 18px;text-transform:uppercase;font-size:11px;letter-spacing:.06em;color:#94a3b8;
}
.sidebar .nav-link{
    display:block;padding:8px 22px;color:#cbd5e1;text-decoration:none;font-size:14px;
    border-left:3px solid transparent;
}
.sidebar .nav-link:hover{background:var(--sidebar-hover);color:#fff}
.sidebar .nav-link.active{background:var(--sidebar-hover);color:#fff;border-color:var(--accent)}
.sidebar .nav-link i{margin-right:6px;opacity:.85}
.sidebar .nav-link.top{font-weight:600}

.sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1040}
.sidebar-backdrop.show{display:block}

/* ---------- MAIN ---------- */
.main{flex:1;display:flex;flex-direction:column;min-width:0;max-width:100%}
.topbar{
    background:#fff;border-bottom:1px solid #e5e7eb;
    display:flex;justify-content:space-between;align-items:center;
    padding:8px 16px;gap:8px;flex-wrap:nowrap;
    position:sticky;top:0;z-index:1020;
}
.page-title{font-size:17px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-box{display:flex;align-items:center;gap:8px;flex-shrink:0}
.content{padding:16px;max-width:100%;min-width:0}
.content .card{max-width:100%}
.content .card .card-body{max-width:100%;min-width:0;overflow-x:hidden}
/* Tables get their OWN horizontal scrollbar inside .table-responsive instead of pushing the page */
.table-responsive{-webkit-overflow-scrolling:touch}

/* ---------- KPI tiles ---------- */
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.kpi{
    background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:16px;min-width:0;
    box-shadow:0 1px 2px rgba(0,0,0,.03);
}
.kpi .label{color:#64748b;font-size:12px;text-transform:uppercase;letter-spacing:.05em}
.kpi .value{font-size:24px;font-weight:700;margin-top:6px;word-break:break-all}
.kpi.green .value{color:#16a34a}
.kpi.blue  .value{color:#0ea5e9}
.kpi.amber .value{color:#d97706}
.kpi.red   .value{color:#dc2626}

/* ---------- DataTables tweaks ---------- */
.dataTables_wrapper{overflow-x:auto}
.dataTables_wrapper .row > div{min-width:0}
table.dataTable{width:100% !important}
table.dataTable thead{background:#f1f5f9}
table.dataTable tbody tr:hover{background:#f8fafc}
.dt-buttons{display:flex;flex-wrap:wrap;gap:4px}
.dt-buttons .btn{margin:0 !important}
.dataTables_filter{margin-top:4px}
.dataTables_filter input{width:auto;max-width:100%}
/* Responsive plugin parent indicator */
table.dataTable.dtr-inline.collapsed > tbody > tr > td.dtr-control:before{
    background-color:#0ea5e9
}

/* ---------- Misc ---------- */
.summary-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:6px;color:#64748b;font-size:13px}
.summary-row b{color:#0f172a}

/* ============================================================
   RESPONSIVE BREAKPOINTS
   ============================================================ */

/* Tablet and below */
@media (max-width: 991.98px){
    .kpi-row{grid-template-columns:repeat(2,1fr);gap:10px}
    .kpi .value{font-size:20px}
    .content{padding:12px}
}

/* Mobile: collapsible off-canvas sidebar */
@media (max-width: 767.98px){
    .sidebar{
        position:fixed;top:0;left:0;height:100vh;z-index:1050;
        transform:translateX(-100%);
        box-shadow:2px 0 16px rgba(0,0,0,.25);
        width:80vw;max-width:300px;
    }
    .sidebar.show{transform:translateX(0)}
    .main{width:100%}
    .page-title{font-size:15px}
    .kpi-row{grid-template-columns:1fr;gap:10px}
    .kpi{padding:12px}
    .kpi .value{font-size:18px}
    .content{padding:10px}
    .card-body{padding:12px}
    .modal-dialog{margin:8px}
    .form-label{font-size:13px;margin-bottom:2px}
    .dt-buttons{justify-content:flex-start}
    .dt-buttons .btn{font-size:12px;padding:3px 8px}
}

/* Very small phones */
@media (max-width: 480px){
    .user-box .badge{display:none !important}
    .topbar{padding:6px 10px}
    .brand{padding:14px 16px}
    .dt-buttons .btn span{display:inline}
}
