@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800;900&family=Nunito+Sans:wght@400;500;600;700&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --dark:#0E1A2B;--dark2:#152236;--dark3:#1C2E46;
  --orange:#E8461A;--orangeD:#C03A14;--orangeL:#FF6340;
  --white:#fff;--off:#F5F6F8;--g100:#EDEEF2;--g200:#D5D7DF;--g400:#8C909E;--g600:#555A68;
  --danger:#C0392B;--success:#1B7A48;
  --ff:'Nunito Sans',sans-serif;--fh:'Nunito',sans-serif;
}
body{font-family:var(--ff);background:var(--off);color:var(--dark);min-height:100vh}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:10px 20px;font-family:var(--fh);font-size:13px;font-weight:800;cursor:pointer;border:none;transition:all .15s;border-radius:5px;letter-spacing:.3px}
.btn-orange{background:var(--orange);color:#fff}.btn-orange:hover{background:var(--orangeD)}
.btn-dark{background:var(--dark);color:#fff}.btn-dark:hover{background:var(--dark3)}
.btn-ghost{background:transparent;color:var(--dark);border:2px solid var(--g200)}.btn-ghost:hover{border-color:var(--orange);color:var(--orange)}
.btn-gw{background:transparent;color:rgba(255,255,255,.75);border:1.5px solid rgba(255,255,255,.2);border-radius:5px}.btn-gw:hover{background:rgba(255,255,255,.08);color:#fff}
.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{opacity:.88}
.btn-sm{padding:6px 13px;font-size:12px}
.btn-full{width:100%;padding:13px 0;font-size:14px}

/* SETUP */
#setup-screen{min-height:100vh;background:var(--dark);display:flex;align-items:center;justify-content:center;padding:48px;flex-direction:column}
.setup-box{background:#fff;border-radius:9px;border-top:5px solid var(--orange);width:580px;max-width:95vw;padding:40px;box-shadow:0 24px 80px rgba(0,0,0,.5)}
.setup-logo{width:160px;filter:brightness(0) invert(1);margin-bottom:24px}

/* LOGIN */
#login-screen{min-height:100vh;display:none;position:relative;align-items:center;justify-content:center;background:#0E1A2B}
#login-screen.vis{display:flex}
.login-bg{position:absolute;inset:0;background-image:url('https://prodcalimaticfd-duczddazh5awejgt.z01.azurefd.net/company-1/CM_02dfcc9c-9863-4f1b-a007-41c23d5981df.jpg');background-size:cover;background-position:center;background-repeat:no-repeat}
.login-bg::after{content:'';position:absolute;inset:0;background:rgba(10,18,32,.58)}
.login-card{position:relative;z-index:2;background:#fff;border-radius:14px;width:440px;max-width:94vw;padding:44px 42px 38px;box-shadow:0 28px 80px rgba(0,0,0,.5);text-align:center}
.login-card-logo{width:148px;margin:0 auto 18px;display:block}
.login-card-tag{font-family:var(--fh);font-size:10px;font-weight:800;letter-spacing:3px;text-transform:uppercase;color:var(--orange);margin-bottom:4px}
.login-card-title{font-family:var(--fh);font-size:22px;font-weight:900;color:var(--dark);margin-bottom:6px}
.login-card-sub{font-size:12px;color:var(--g400);line-height:1.6;margin-bottom:26px}
.login-divider{height:1px;background:var(--g100);margin:0 -42px 26px}
.login-card .field{text-align:left}
.login-card .field input{background:#FAFAFA}
.login-note{margin-top:20px;font-size:11px;color:var(--g400);text-align:center;line-height:1.65;border-top:1px solid var(--g100);padding-top:16px}

/* FIELDS */
.field{margin-bottom:18px;width:100%}
.field label{display:block;font-size:10px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;color:var(--g600);margin-bottom:6px}
.field input,.field select,.form-row input,.form-row select{width:100%;padding:11px 14px;border:2px solid var(--g200);border-radius:5px;font-family:var(--ff);font-size:14px;color:var(--dark);outline:none;transition:border-color .15s;background:#fff}
.field input:focus,.field select:focus,.form-row input:focus,.form-row select:focus{border-color:var(--orange)}
.form-row{margin-bottom:16px}
.form-row label{display:block;font-size:10px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;color:var(--g600);margin-bottom:6px}
.login-note{margin-top:22px;font-size:12px;color:var(--g400);text-align:center;line-height:1.6;border-top:1px solid var(--g100);padding-top:18px}

/* APP */
#app-screen{display:none;flex-direction:column;min-height:100vh}

/* TOPBAR */
#topbar{background:var(--dark);height:64px;display:flex;align-items:center;padding:0 28px;gap:18px;position:sticky;top:0;z-index:100;border-bottom:3px solid var(--orange);box-shadow:0 2px 20px rgba(0,0,0,.45)}
.tb-logo{height:34px;filter:brightness(0) invert(1)}
.tb-sep{width:1px;height:28px;background:rgba(255,255,255,.13);flex-shrink:0}
.tb-label{font-family:var(--fh);font-size:14px;font-weight:700;color:rgba(255,255,255,.65)}

/* CAMPUS DROPDOWN */
.campus-wrap{position:relative;display:flex;align-items:center}
.campus-btn{display:flex;align-items:center;gap:6px;padding:5px 10px;background:rgba(255,255,255,.07);border:1.5px solid rgba(255,255,255,.12);border-radius:5px;cursor:pointer;transition:all .15s;color:#fff;font-family:var(--fh);font-size:12px;font-weight:800;letter-spacing:.3px;user-select:none}
.campus-btn:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.22)}
.campus-chevron{width:12px;height:12px;opacity:.6;transition:transform .2s}
.campus-btn.open .campus-chevron{transform:rotate(180deg)}
.campus-menu{position:absolute;top:calc(100% + 8px);left:0;background:#1C2E46;border:1.5px solid rgba(255,255,255,.1);border-radius:7px;min-width:220px;box-shadow:0 12px 40px rgba(0,0,0,.5);z-index:300;overflow:hidden;display:none}
.campus-menu.open{display:block;animation:fadeDown .15s ease}
@keyframes fadeDown{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.campus-menu-header{padding:8px 14px 6px;font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--g400);font-weight:800;font-family:var(--fh)}
.campus-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background .12s;font-family:var(--fh);font-size:13px;font-weight:700;color:rgba(255,255,255,.85)}
.campus-item:hover{background:rgba(255,255,255,.06)}
.campus-item.selected{color:var(--orange)}
.campus-item-dot{width:7px;height:7px;border-radius:50%;background:var(--g400);flex-shrink:0}
.campus-item.selected .campus-item-dot{background:var(--orange)}
.campus-item-tag{margin-left:auto;font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--orange);font-weight:900;background:rgba(232,70,26,.15);padding:2px 7px;border-radius:3px}
.campus-divider{height:1px;background:rgba(255,255,255,.06);margin:4px 0}
.tb-user{display:flex;align-items:center;gap:10px}
.av-name{font-size:13px;font-weight:800;color:#fff;font-family:var(--fh);line-height:1.2}
.rchip{display:inline-block;padding:2px 9px;font-size:9px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;border-radius:3px;font-family:var(--fh);background:rgba(255,255,255,.12);color:rgba(255,255,255,.7)}

/* SIDEBAR */
.layout{display:flex;flex:1}
.sidebar{width:230px;background:var(--dark2);min-height:calc(100vh - 64px);padding:24px 0;flex-shrink:0;position:sticky;top:64px;height:calc(100vh - 64px);overflow-y:auto}
.sb-sec{padding:0 12px;margin-bottom:24px}
.sb-lbl{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--g400);font-weight:800;font-family:var(--fh);padding:0 8px;margin-bottom:8px}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 14px;font-size:13px;font-weight:700;color:rgba(255,255,255,.6);cursor:pointer;transition:all .15s;border-left:3px solid transparent;border-radius:0 4px 4px 0;margin-bottom:2px;font-family:var(--fh)}
.nav-item:hover{color:#fff;background:rgba(255,255,255,.05)}
.nav-item.active{color:var(--orange);border-left-color:var(--orange);background:rgba(232,70,26,.09)}
.sb-ver{padding:20px;font-size:9px;color:rgba(255,255,255,.18);font-family:var(--fh);font-weight:800;letter-spacing:1.5px;text-transform:uppercase}

/* MAIN */
.main{flex:1;padding:32px 36px;max-width:1200px}
.view{display:none}.view.active{display:block}
.phdr{margin-bottom:26px}
.phdr h1{font-family:var(--fh);font-size:24px;font-weight:900;color:var(--dark)}
.phdr p{font-size:13px;color:var(--g600);margin-top:4px;line-height:1.5}
.phdr-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:26px;flex-wrap:wrap}
.breadcrumb{font-size:12px;color:var(--g400);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.bc-link{cursor:pointer;color:var(--orange);font-weight:800}.bc-link:hover{opacity:.75}

/* STATS */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:28px}
.stat-card{background:#fff;border:1.5px solid var(--g200);padding:20px 22px;border-radius:7px;transition:all .15s}
.stat-card.clickable{cursor:pointer}.stat-card.clickable:hover{border-color:var(--orange)}
.stat-card.active-filter{border-color:var(--orange);box-shadow:0 0 0 3px rgba(232,70,26,.1)}
.stat-val{font-family:var(--fh);font-size:28px;font-weight:900;color:var(--dark)}
.stat-lbl{font-size:10px;color:var(--g400);letter-spacing:1px;margin-top:3px;font-weight:700}

/* CLASS GRID */
.class-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(238px,1fr));gap:16px}
.class-card{background:#fff;border:1.5px solid var(--g200);border-radius:7px;overflow:hidden;transition:all .2s}
.class-card:hover{border-color:var(--orange);box-shadow:0 6px 24px rgba(0,0,0,.1);transform:translateY(-2px)}
.cc-top{position:relative;height:110px;background:var(--dark);overflow:hidden;cursor:pointer}
.cc-top img{width:100%;height:100%;object-fit:cover;display:block}
.cc-top-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(14,26,43,.5) 0%,rgba(14,26,43,.15) 100%)}
.cc-meta{position:absolute;bottom:8px;right:10px;font-size:11px;color:rgba(255,255,255,.55);font-weight:700;font-family:var(--fh)}
.cc-cam-btn{position:absolute;top:8px;right:8px;background:rgba(0,0,0,.45);border:none;border-radius:6px;cursor:pointer;padding:5px 7px;color:#fff;display:flex;align-items:center;gap:4px;font-size:10px;font-weight:800;font-family:var(--fh);transition:background .15s;z-index:2}
.cc-cam-btn:hover{background:rgba(232,70,26,.8)}
.cc-body{padding:14px 20px 18px;cursor:pointer}
.cc-name{font-family:var(--fh);font-size:14px;font-weight:800;color:var(--dark);line-height:1.3}
.cc-sub{font-size:12px;color:var(--g400);margin-top:4px}

/* TABLE */
.table-wrap{background:#fff;border:1.5px solid var(--g200);border-radius:7px;overflow:hidden}
.table-toolbar{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1.5px solid var(--g100)}
.search-input{flex:1;padding:9px 14px;border:1.5px solid var(--g200);border-radius:5px;font-family:var(--ff);font-size:13px;outline:none;color:var(--dark);transition:border-color .15s}
.search-input:focus{border-color:var(--orange)}
.tbl-count{font-size:12px;color:var(--g400);font-weight:700;white-space:nowrap}
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:9px;letter-spacing:1.8px;text-transform:uppercase;color:var(--g400);font-weight:800;font-family:var(--fh);padding:11px 18px;border-bottom:1.5px solid var(--g100);background:var(--off)}
td{padding:12px 18px;font-size:13px;border-bottom:1px solid var(--g100);color:var(--dark);vertical-align:middle}
tr:last-child td{border-bottom:none}
tbody tr:hover td{background:#FFF7F5}
.file-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:3px;font-family:var(--fh);font-size:10px;font-weight:900;color:#fff;letter-spacing:.5px;white-space:nowrap}
.fnc{display:flex;align-items:center;gap:10px;font-weight:700}
.upc{color:var(--g600)}
.tsc{font-size:12px;color:var(--g400);font-weight:700;white-space:nowrap}
.ac{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.empty-state{padding:56px;text-align:center;color:var(--g400);font-family:var(--fh);font-weight:700;font-size:14px}

/* LOGIN INFO CELL */
.login-info-cell{line-height:1.4}
.login-time{font-size:12px;font-weight:700;color:var(--dark)}
.login-ip{font-size:11px;color:var(--g400);font-family:monospace;margin-top:2px}
.login-never{font-size:12px;color:var(--g400);font-style:italic}

/* ROLE DROPDOWN in table */
.role-select{font-family:var(--fh);font-size:11px;font-weight:800;border:1.5px solid var(--g200);border-radius:4px;padding:5px 8px;outline:none;cursor:pointer;transition:all .15s;background:#fff;letter-spacing:.3px}
.role-select:focus{border-color:var(--orange)}

/* ALERTS */
.alert{padding:12px 16px;font-size:13px;margin-bottom:18px;border-left:4px solid;border-radius:5px;font-weight:700}
.alert-success{background:#E8F5E9;border-color:var(--success);color:var(--success)}
.alert-error{background:#FDEDEC;border-color:var(--danger);color:var(--danger)}
.alert-info{background:#FFF3EF;border-color:var(--orange);color:var(--orangeD)}

/* FLASH */
#flash-msg{position:fixed;top:80px;right:24px;z-index:500;min-width:280px;max-width:380px;padding:12px 18px;border-radius:6px;font-family:var(--fh);font-weight:800;font-size:13px;border-left:5px solid;display:none;box-shadow:0 8px 32px rgba(0,0,0,.15);animation:slideIn .2s ease}
@keyframes slideIn{from{transform:translateX(20px);opacity:0}to{transform:none;opacity:1}}

/* MODALS */
.modal-header{padding:24px 28px 0;display:flex;align-items:flex-start;justify-content:space-between}
.modal-header h2{font-family:var(--fh);font-size:18px;font-weight:900;color:var(--dark)}
.modal-close{background:none;border:none;font-size:22px;cursor:pointer;color:var(--g400);line-height:1;padding:0 4px}.modal-close:hover{color:var(--orange)}
.modal-body{padding:20px 28px 12px}
.modal-footer{padding:12px 28px 24px;display:flex;gap:10px;justify-content:flex-end}
.form-err{color:var(--danger);font-size:13px;font-weight:700;margin-top:6px;padding:8px 12px;background:#FDEDEC;border-radius:4px;border-left:3px solid var(--danger);display:none}

/* UPLOAD ZONE */
.upload-zone{border:2px dashed var(--g200);border-radius:7px;padding:36px 24px;text-align:center;cursor:pointer;transition:all .15s}
.upload-zone:hover,.upload-zone.drag-over{border-color:var(--orange);background:#FFF3EF}
.upload-zone strong{font-size:14px;color:var(--dark);font-family:var(--fh);font-weight:800;display:block;margin-top:8px}
.upload-zone p{font-size:13px;color:var(--g600);margin-top:6px;line-height:1.5}

.obar{height:3px;background:linear-gradient(90deg,var(--orange),var(--orangeL));border-radius:2px;margin:26px 0}
.section-label{font-family:var(--fh);font-size:16px;font-weight:900;color:var(--dark);margin-bottom:14px}

/* ACTIVITY LOG TABLE */
.log-table-wrap{background:#fff;border:1.5px solid var(--g200);border-radius:7px;overflow:hidden;margin-top:0}

/* ── MODAL STYLES ── */
.moverlay{display:none;position:fixed !important;top:0 !important;left:0 !important;right:0 !important;bottom:0 !important;width:100% !important;height:100% !important;
  background:rgba(14,26,43,.55);backdrop-filter:blur(3px);
  z-index:9999 !important;align-items:center;justify-content:center}
.moverlay.vis{display:flex !important}
.mcard{background:#fff;border-radius:12px;border-top:5px solid #E8461A;
  width:560px;max-width:92vw;max-height:86vh;overflow-y:auto;
  box-shadow:0 20px 60px rgba(0,0,0,.35);position:relative}
.mcard.sm{width:460px}
.mhdr{display:flex;align-items:center;justify-content:space-between;padding:26px 30px 0}
.mhdr h2{font-family:Nunito,sans-serif;font-size:19px;font-weight:900;color:#0E1A2B;margin:0}
.mhdr button{background:none;border:none;font-size:24px;cursor:pointer;color:#8C909E;line-height:1;padding:2px 6px;border-radius:4px}
.mhdr button:hover{color:#E8461A}
.mbody{padding:22px 30px 6px}
.mftr{padding:14px 30px 28px;display:flex;gap:10px;justify-content:flex-end}