*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --s1:#0d0f11;--s2:#111416;--s3:#181c20;--s4:#1e2329;--s5:#232a32;
  --s6:#2d3740;--s7:#38434e;--s9:#556170;--s11:#97a3ae;--s12:#eceef0;
  --accent:#5685cb;--green:#79b75f;--red:#e5484d;--orange:#f97316;
}
html,body{height:100%;background:var(--s1);color:var(--s12);font-family:'Inter',sans-serif;}
#root{height:100%;display:flex;flex-direction:column;}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--s2)}::-webkit-scrollbar-thumb{background:var(--s6);border-radius:3px}

/* Shared */
.lbl{font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--s9)}
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:7px;border:none;cursor:pointer;font-family:'Inter',sans-serif;font-size:13px;font-weight:500;transition:background .15s,border-color .15s}
.btn-p{background:var(--accent);color:#fff}.btn-p:hover{background:#4a76bb}.btn-p:disabled{opacity:.45;cursor:not-allowed}
.btn-o{background:transparent;color:var(--s11);border:1px solid var(--s6)}.btn-o:hover{background:var(--s3);border-color:var(--s7);color:var(--s12)}
.btn-d{background:transparent;color:var(--red);border:1px solid rgba(229,72,77,.3)}.btn-d:hover{background:rgba(229,72,77,.1)}
.btn-sm{padding:6px 12px;font-size:12px}
.bico{padding:7px;border-radius:7px;background:transparent;border:1px solid var(--s6);color:var(--s11);cursor:pointer;display:inline-flex;align-items:center;transition:background .15s}.bico:hover{background:var(--s3);color:var(--s12)}
input,select,textarea{background:var(--s3);border:1px solid var(--s6);border-radius:7px;color:var(--s12);font-family:'Inter',sans-serif;font-size:13px;padding:9px 12px;outline:none;transition:border-color .15s;width:100%}
input:focus,select:focus,textarea:focus{border-color:var(--accent)}
input::placeholder,textarea::placeholder{color:var(--s9)}
input.err{border-color:var(--red)}
select option{background:var(--s3)}
.fg{display:flex;flex-direction:column;gap:5px}
.fg label{font-size:11px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--s9)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:12px}

.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:100px;font-size:11px;font-weight:600;letter-spacing:.06em}
.b-in{background:rgba(121,183,95,.15);color:var(--green);border:1px solid rgba(121,183,95,.3)}
.b-out{background:rgba(86,133,203,.12);color:var(--accent);border:1px solid rgba(86,133,203,.25)}
.b-dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.b-admin{background:rgba(86,133,203,.12);color:var(--accent);border:1px solid rgba(86,133,203,.25)}
.b-role{background:rgba(121,183,95,.1);color:var(--green);border:1px solid rgba(121,183,95,.25)}

/* Login */
.login-screen{position:fixed;inset:0;z-index:200;background:var(--s1);display:flex;align-items:center;justify-content:center;background-image:radial-gradient(ellipse 70% 50% at 50% 30%,rgba(86,133,203,.07) 0%,transparent 70%);animation:fadein .3s ease}
.login-card{width:390px;background:var(--s2);border:1px solid var(--s6);border-radius:14px;box-shadow:0 32px 80px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.04);padding:40px 36px 36px;display:flex;flex-direction:column;gap:26px;animation:modal-in .25s ease}
.login-hdr{display:flex;flex-direction:column;align-items:center;gap:14px}
.login-logo{height:38px}
.login-title{font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:22px;letter-spacing:.1em;text-transform:uppercase;text-align:center}
.login-title span{color:var(--accent)}
.login-sub{font-size:12px;color:var(--s9);letter-spacing:.05em;text-align:center;margin-top:2px}
.login-form{display:flex;flex-direction:column;gap:14px}
.login-btn{width:100%;padding:11px;font-size:14px;font-weight:600;justify-content:center;letter-spacing:.04em}
.login-err{display:flex;align-items:center;gap:7px;background:rgba(229,72,77,.1);border:1px solid rgba(229,72,77,.3);border-radius:7px;padding:10px 12px;font-size:12px;color:var(--red)}
.login-hint{text-align:center;font-size:11px;color:var(--s9);line-height:1.7}
.login-hint code{font-family:'JetBrains Mono',monospace;color:var(--s11);background:var(--s3);padding:1px 5px;border-radius:4px;font-size:10px}
.pwrap{position:relative}.pwrap input{padding-right:38px}
.ptoggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);cursor:pointer;color:var(--s9);background:none;border:none;display:flex;align-items:center;padding:2px}.ptoggle:hover{color:var(--s11)}

/* Topbar */
.topbar{display:flex;align-items:center;background:var(--s2);border-bottom:1px solid var(--s6);padding:0 24px;height:56px;flex-shrink:0}
.topbar-logo{display:flex;align-items:center;gap:10px;margin-right:32px}
.topbar-logo img{height:26px}
.app-name{font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:17px;letter-spacing:.08em;text-transform:uppercase;color:var(--s11)}
.app-name span{color:var(--accent)}
.tabs{display:flex;gap:2px;align-items:center;height:100%}
.tab{display:flex;align-items:center;gap:7px;padding:0 16px;height:100%;font-size:13px;font-weight:500;color:var(--s11);cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s,background .15s;user-select:none}
.tab:hover{color:var(--s12);background:rgba(255,255,255,.03)}
.tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.clock{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--s11)}
.uchip{display:flex;align-items:center;gap:8px;padding:5px 10px 5px 6px;background:var(--s3);border:1px solid var(--s6);border-radius:100px}
.uavatar{width:24px;height:24px;border-radius:50%;background:rgba(86,133,203,.2);border:1px solid rgba(86,133,203,.3);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--accent)}
.uname{font-size:12px;font-weight:500;color:var(--s12)}
.urole{font-size:10px;color:var(--s9);text-transform:uppercase;letter-spacing:.1em}

/* Main */
.main{flex:1;overflow:hidden;display:flex;flex-direction:column}

/* Attendance */
.att-layout{display:grid;grid-template-columns:340px 1fr;height:100%;overflow:hidden}
.cam-panel{border-right:1px solid var(--s6);background:var(--s2);display:flex;flex-direction:column;padding:20px;gap:16px;overflow-y:auto}
.cam-feed{position:relative;background:var(--s1);border:1px solid var(--s6);border-radius:10px;overflow:hidden;aspect-ratio:4/3;width:100%}
.cam-feed video,.cam-feed canvas{width:100%;height:100%;object-fit:cover;display:block;transform:scaleX(-1)}
.cam-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;background:var(--s1);color:var(--s9);font-size:13px}
.rec-ind{position:absolute;top:10px;right:10px;display:flex;align-items:center;gap:5px;background:rgba(229,72,77,.15);border:1px solid rgba(229,72,77,.4);border-radius:100px;padding:3px 10px;font-size:11px;font-weight:700;letter-spacing:.1em;color:var(--red)}
.rec-dot{width:6px;height:6px;border-radius:50%;background:var(--red);animation:pulse-red 1.2s infinite}
@keyframes pulse-red{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(229,72,77,.7)}50%{opacity:.6;box-shadow:0 0 8px 3px rgba(229,72,77,.4)}}
.rec-panel{display:flex;flex-direction:column;overflow:hidden}
.rec-hdr{padding:16px 20px;border-bottom:1px solid var(--s6);display:flex;align-items:center;gap:12px;flex-shrink:0}
.rec-hdr h2{font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:20px;letter-spacing:.04em;text-transform:uppercase;flex:1}
.rec-list{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:6px}
.rec-row{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--s3);border-radius:8px;border:1px solid var(--s6);transition:background .12s}
.rec-row:hover{background:var(--s4)}
.rthumb{width:40px;height:40px;border-radius:6px;object-fit:cover;border:1px solid var(--s6);flex-shrink:0}
.rthumb-ph{width:40px;height:40px;border-radius:6px;background:var(--s5);border:1px solid var(--s6);display:flex;align-items:center;justify-content:center;color:var(--s9);flex-shrink:0}
.rinfo{flex:1;min-width:0}
.rname{font-size:13px;font-weight:600}
.rdni{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--s9);margin-top:1px}
.rtime{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--s11);white-space:nowrap}

/* Toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--s3);border:1px solid var(--s6);border-radius:8px;padding:12px 20px;font-size:13px;color:var(--s12);display:flex;align-items:center;gap:8px;box-shadow:0 8px 32px rgba(0,0,0,.5);z-index:999;animation:toast-in .2s ease}
@keyframes toast-in{from{opacity:0;transform:translateX(-50%) translateY(10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* Modal */
.mbdrop{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:100;display:flex;align-items:center;justify-content:center;animation:fadein .15s ease}
@keyframes fadein{from{opacity:0}to{opacity:1}}
.modal{background:var(--s2);border:1px solid var(--s6);border-radius:12px;box-shadow:0 32px 80px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.04);width:500px;max-width:95vw;max-height:90vh;overflow-y:auto;animation:modal-in .18s ease}
@keyframes modal-in{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.mhdr{padding:20px 24px 0;display:flex;align-items:center;justify-content:space-between}
.mhdr h3{font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:20px;text-transform:uppercase;letter-spacing:.05em}
.mbody{padding:20px 24px;display:flex;flex-direction:column;gap:14px}
.mftr{padding:0 24px 20px;display:flex;gap:8px;justify-content:flex-end}

/* Admin / Sub-tabs */
.adm-layout{display:flex;flex-direction:column;height:100%;overflow:hidden}
.adm-hdr{padding:16px 24px;border-bottom:1px solid var(--s6);display:flex;align-items:center;gap:12px;flex-shrink:0}
.adm-hdr h2{font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:20px;letter-spacing:.04em;text-transform:uppercase;flex:1}
.sub-tabs{display:flex;border-bottom:1px solid var(--s6);padding:0 24px;flex-shrink:0;gap:2px}
.sub-tab{padding:10px 16px;font-size:13px;font-weight:500;color:var(--s9);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s;display:flex;align-items:center;gap:6px}
.sub-tab:hover{color:var(--s12)}
.sub-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.tbl-wrap{flex:1;overflow-y:auto;padding:16px 24px}
table{width:100%;border-collapse:collapse}
thead th{text-align:left;padding:10px 12px;font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--s9);border-bottom:1px solid var(--s6)}
tbody tr{border-bottom:1px solid var(--s6);transition:background .1s}
tbody tr:hover{background:var(--s3)}
tbody td{padding:10px 12px;font-size:13px;vertical-align:middle}
.eavatar{width:34px;height:34px;border-radius:50%;object-fit:cover;border:1px solid var(--s6)}
.eavatar-ph{width:34px;height:34px;border-radius:50%;background:var(--s5);border:1px solid var(--s6);display:flex;align-items:center;justify-content:center;color:var(--s9);font-size:13px;font-weight:600}
.tdact{display:flex;gap:6px;justify-content:flex-end}
.avatar-ul{display:flex;align-items:center;gap:12px}
.av-prev{width:56px;height:56px;border-radius:50%;object-fit:cover;border:2px solid var(--s6)}
.av-ph{width:56px;height:56px;border-radius:50%;background:var(--s4);border:2px dashed var(--s6);display:flex;align-items:center;justify-content:center;color:var(--s9);cursor:pointer;transition:border-color .15s}
.av-ph:hover{border-color:var(--accent)}

/* Historial */
.hist-layout{display:flex;flex-direction:column;height:100%;overflow:hidden}
.hist-hdr{padding:16px 24px;border-bottom:1px solid var(--s6);display:flex;align-items:center;gap:12px;flex-shrink:0;flex-wrap:wrap}
.hist-hdr h2{font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:20px;letter-spacing:.04em;text-transform:uppercase}
.hist-filters{display:flex;gap:8px;align-items:center;flex:1;flex-wrap:wrap}
.hist-content{flex:1;overflow-y:auto;padding:16px 24px}
.hgrp{margin-bottom:20px}
.hgrp-title{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:16px;text-transform:uppercase;letter-spacing:.06em;color:var(--s11);margin-bottom:8px;display:flex;align-items:center;gap:8px}
.hgrp-title::after{content:'';flex:1;height:1px;background:var(--s6)}
.hrow{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--s3);border-radius:8px;border:1px solid var(--s6);margin-bottom:5px}
.hthumb{width:36px;height:36px;border-radius:6px;object-fit:cover;border:1px solid var(--s6)}
.hthumb-ph{width:36px;height:36px;border-radius:6px;background:var(--s5);border:1px solid var(--s6);display:flex;align-items:center;justify-content:center;color:var(--s9)}
.hinfo{flex:1;min-width:0}
.hname{font-size:13px;font-weight:600}
.hdni{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--s9)}
.htime{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--s11)}

/* Roles & Permissions */
.perm-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:4px}
.perm-item{display:flex;align-items:center;gap:10px;padding:9px 12px;background:var(--s3);border-radius:7px;border:1px solid var(--s6);cursor:pointer;user-select:none;transition:border-color .15s}
.perm-item:hover{border-color:var(--s7)}
.perm-item.checked{border-color:rgba(86,133,203,.35);background:rgba(86,133,203,.07)}
.perm-check{width:16px;height:16px;border-radius:4px;border:1px solid var(--s7);background:var(--s4);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,border-color .15s}
.perm-item.checked .perm-check{background:var(--accent);border-color:var(--accent)}
.perm-label{font-size:12px;font-weight:500;color:var(--s11);line-height:1.3}
.perm-item.checked .perm-label{color:var(--s12)}
.role-card{background:var(--s3);border:1px solid var(--s6);border-radius:10px;padding:16px;margin-bottom:10px}
.role-card-hdr{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.role-name-input{font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:transparent;border:none;border-bottom:1px solid transparent;padding:0 0 2px;border-radius:0;width:auto;min-width:120px;flex:1}
.role-name-input:focus{border-bottom-color:var(--accent);outline:none}
.role-admin-tag{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);background:rgba(86,133,203,.12);border:1px solid rgba(86,133,203,.25);padding:2px 8px;border-radius:100px}

/* Reports */
.rep-layout{display:flex;flex-direction:column;height:100%;overflow:hidden}
.rep-hdr{padding:16px 24px;border-bottom:1px solid var(--s6);display:flex;align-items:center;gap:12px;flex-shrink:0;flex-wrap:wrap}
.rep-hdr h2{font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:20px;letter-spacing:.04em;text-transform:uppercase}
.rep-filters{display:flex;gap:8px;align-items:center;flex:1;flex-wrap:wrap}
.rep-content{flex:1;overflow-y:auto;padding:0}
.rep-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--s6);border-bottom:1px solid var(--s6)}
.rep-stat{background:var(--s2);padding:16px 24px;display:flex;flex-direction:column;gap:3px}
.rep-stat-val{font-family:'Barlow Condensed',sans-serif;font-size:28px;font-weight:800;color:var(--s12)}
.rep-stat-lbl{font-size:11px;color:var(--s9);letter-spacing:.12em;text-transform:uppercase}
.rep-table-wrap{padding:16px 24px;flex:1}
.rep-table{width:100%;border-collapse:collapse}
.rep-table thead th{text-align:left;padding:10px 12px;font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--s9);border-bottom:1px solid var(--s6)}
.rep-table tbody tr{border-bottom:1px solid var(--s6);transition:background .1s}
.rep-table tbody tr:hover{background:var(--s3)}
.rep-table tbody td{padding:10px 12px;font-size:13px;vertical-align:middle}
.rep-table tfoot td{padding:10px 12px;font-size:13px;border-top:2px solid var(--s6);font-weight:600}
.hours-pill{font-family:'JetBrains Mono',monospace;font-size:12px;background:rgba(86,133,203,.1);color:var(--accent);border:1px solid rgba(86,133,203,.25);padding:2px 8px;border-radius:100px}
.hours-zero{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--s9)}

.seg-ctrl{display:flex;background:var(--s3);border-radius:7px;border:1px solid var(--s6);overflow:hidden}
.seg-btn{padding:6px 14px;font-size:12px;font-weight:500;color:var(--s11);cursor:pointer;border:none;background:transparent;transition:background .15s,color .15s;white-space:nowrap}
.seg-btn.active{background:var(--s5);color:var(--s12)}
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:60px 20px;color:var(--s9)}
.empty p{font-size:14px}

/* Responsive */
@media (max-width: 900px) {
  .rep-summary { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 768px) {
  .topbar { padding: 0 12px; height: 52px; flex-wrap: nowrap; gap: 0; overflow: hidden; }
  .topbar-logo { margin-right: 12px; }
  .topbar-logo .app-name { display: none; }
  .tabs { flex: 1; overflow-x: auto; scrollbar-width: none; }
  .tabs::-webkit-scrollbar { display: none; }
  .tab { padding: 0 10px; font-size: 12px; gap: 5px; white-space: nowrap; }
  .clock { display: none; }
  .uchip .uname, .uchip .urole { display: none; }
  .uchip { padding: 5px 6px; }

  .att-layout { grid-template-columns: 1fr; grid-template-rows: auto 1fr; }
  .cam-panel { border-right: none; border-bottom: 1px solid var(--s6); padding: 14px; gap: 12px; overflow-y: visible; }
  .cam-feed { max-width: 340px; margin: 0 auto; }

  .rec-hdr { flex-wrap: wrap; gap: 8px; padding: 12px; }
  .rec-hdr h2 { font-size: 16px; }

  .frow { grid-template-columns: 1fr; }

  .adm-hdr { flex-wrap: wrap; padding: 12px 16px; gap: 8px; }
  .adm-hdr h2 { flex: 0 0 100%; }
  .sub-tabs { padding: 0 12px; overflow-x: auto; }
  .tbl-wrap { padding: 12px 16px; }

  .hist-hdr { padding: 12px 16px; gap: 8px; }
  .hist-hdr h2 { flex: 0 0 100%; }
  .hist-filters { flex-wrap: wrap; }
  .hist-content { padding: 12px 16px; }
  .hrow { flex-wrap: wrap; gap: 8px; }
  .htime { font-size: 11px; }

  .rep-hdr { padding: 12px 16px; gap: 8px; }
  .rep-hdr h2 { flex: 0 0 100%; }
  .rep-filters { flex-wrap: wrap; }
  .rep-summary { grid-template-columns: 1fr 1fr; }
  .rep-stat { padding: 12px 16px; }
  .rep-stat-val { font-size: 22px; }

  .modal { width: 95vw; }
  .login-card { width: 95vw; padding: 28px 20px 24px; }

  .tbl-wrap table thead th:nth-child(5),
  .tbl-wrap table thead th:nth-child(6),
  .tbl-wrap table tbody td:nth-child(5),
  .tbl-wrap table tbody td:nth-child(6) { display: none; }

  .rep-table thead th:nth-child(3),
  .rep-table thead th:nth-child(4),
  .rep-table tbody td:nth-child(3),
  .rep-table tbody td:nth-child(4) { display: none; }
}

@media (max-width: 480px) {
  .tab { padding: 0 8px; font-size: 11px; }
  .tab span:first-child { display: none; }
  .topbar-logo img { height: 22px; }
  .rec-row { flex-wrap: wrap; }
  .role-card { padding: 12px; }
  .perm-grid { grid-template-columns: 1fr; }
  .rep-summary { grid-template-columns: 1fr 1fr; gap: 1px; }
  .seg-btn { padding: 6px 10px; font-size: 11px; }
  .hist-hdr, .adm-hdr, .rep-hdr, .rec-hdr { padding: 10px 12px; }
}
