﻿/* ============ Admin + Employee back office ============ */
.app-shell{display:grid;grid-template-columns:248px 1fr;min-height:100dvh}
.sidebar{background:rgba(0,0,0,.32);backdrop-filter:blur(20px);border-right:1px solid var(--border);
  padding:22px 16px;display:flex;flex-direction:column;position:sticky;top:0;height:100dvh}
.sidebar .brand{display:flex;align-items:center;gap:10px;margin-bottom:24px;padding:0 6px}
.sidebar .brand img{width:38px;height:38px;border-radius:10px;object-fit:contain;background:var(--glass)}
.sidebar .brand .logo-fallback{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;
  background:var(--accent-soft);color:var(--accent);font-family:'Plus Jakarta Sans';font-weight:800}
.sidebar .brand b{font-family:'Plus Jakarta Sans';font-size:16px}
.nav-link{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:12px;color:var(--text-muted);
  text-decoration:none;font-size:14.5px;font-weight:500;margin-bottom:3px;transition:.18s}
.nav-link:hover{background:var(--glass);color:var(--text-primary)}
.nav-link.active{background:var(--accent-soft);color:var(--text-primary);border:1px solid var(--border)}
.nav-link .ico{width:20px;display:inline-flex;align-items:center;justify-content:center;flex:none;color:currentColor}
.nav-link .ico svg{width:19px;height:19px}
.sidebar .spacer{flex:1}
.sidebar .who{font-size:13px;color:var(--text-muted);padding:10px 6px;border-top:1px solid var(--border)}

.main{padding:26px 30px 60px;max-width:1280px;width:100%}
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;gap:14px;flex-wrap:wrap}
.topbar h1{font-size:26px;margin:0}
.topbar .actions{display:flex;gap:10px;flex-wrap:wrap}

/* Stat cards */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-bottom:20px}
.stat{padding:18px 20px}
.stat .label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}
.stat .num{font-size:34px;font-family:'Plus Jakarta Sans';font-weight:800;margin-top:6px;line-height:1}
.stat .sub{font-size:12px;color:var(--text-muted);margin-top:5px}
.stat.accent .num{color:var(--accent)}
.stat.green .num{color:var(--success)}
.stat.gold .num{color:var(--gold)}

/* Alert bar */
.alert-bar{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 18px;
  border-radius:14px;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.45);margin-bottom:18px;
  animation:alertPulse 2s ease-in-out infinite}
@keyframes alertPulse{0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,.0)}50%{box-shadow:0 0 24px 0 rgba(239,68,68,.3)}}

/* Layout columns */
.cols{display:grid;grid-template-columns:1fr 320px;gap:18px}
@media(max-width:980px){.cols{grid-template-columns:1fr}}

/* Tables */
.panel{padding:18px}
.panel h3{margin:0 0 14px;font-size:16px;font-family:'Plus Jakarta Sans'}
.table-wrap{overflow-x:auto;border-radius:14px}
table.data{width:100%;border-collapse:collapse;font-size:13.5px}
table.data th{text-align:left;padding:11px 12px;color:var(--text-muted);font-weight:600;
  border-bottom:1px solid var(--border);white-space:nowrap;font-size:12px;text-transform:uppercase;letter-spacing:.04em}
table.data td{padding:11px 12px;border-bottom:1px solid rgba(255,255,255,.05);vertical-align:middle}
table.data tr:hover td{background:var(--glass)}
.tphoto{width:38px;height:38px;border-radius:10px;object-fit:cover;background:var(--glass);
  display:grid;place-items:center;font-size:16px}
a.vlink{color:var(--accent);text-decoration:none;font-weight:600;cursor:pointer}
a.vlink:hover{text-decoration:underline}
.iconbtn{background:var(--glass);border:1px solid var(--border);border-radius:9px;width:32px;height:32px;
  cursor:pointer;font-size:14px;color:var(--text-primary);display:inline-grid;place-items:center;transition:.15s;vertical-align:middle}
.iconbtn svg{width:16px;height:16px}
.iconbtn:hover{background:var(--accent-soft);border-color:var(--accent)}
.iconbtn.ok{color:#6EE7B7}
.iconbtn.ok:hover{background:rgba(16,185,129,.18);border-color:var(--success)}
.iconbtn.danger{color:#FCA5A5}
.iconbtn.danger:hover{background:rgba(239,68,68,.18);border-color:var(--danger)}

/* Camera widget (reception entry) */
.camera-widget{margin:10px 0 6px}
.camera-stage{position:relative;width:100%;aspect-ratio:4/3;border-radius:var(--r-card);overflow:hidden;
  background:rgba(0,0,0,.35);border:1px solid var(--border);display:grid;place-items:center}
.camera-stage video,.camera-stage img{width:100%;height:100%;object-fit:cover}
.camera-stage .hint{position:absolute;color:var(--text-muted);font-size:14px;padding:20px;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:8px}
.camera-controls{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}

/* Approval cards */
.appr-card{padding:14px;border:1px solid var(--border);border-radius:14px;margin-bottom:12px;background:var(--glass)}
.appr-card:last-child{margin-bottom:0}
.appr-head{display:flex;gap:12px;align-items:flex-start}
.appr-head .tphoto{width:44px;height:44px;font-size:18px;flex:none}

/* Timeline */
.timeline{display:flex;flex-direction:column;gap:12px}
.tl-item{display:flex;gap:11px;font-size:13px}
.tl-dot{width:9px;height:9px;border-radius:50%;background:var(--accent);margin-top:5px;flex:none;
  box-shadow:0 0 0 4px var(--accent-soft)}
.tl-item .t{color:var(--text-muted);font-size:11px}

/* Employee activity */
.emp-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid rgba(255,255,255,.05);font-size:13.5px}
.emp-row .dot{width:8px;height:8px;border-radius:50%;background:var(--success)}
.emp-row .cnt{margin-left:auto;color:var(--text-muted);font-size:12px}

/* Filters */
.filters{display:flex;gap:10px;flex-wrap:wrap;align-items:end;margin-bottom:16px}
.filters .field{margin:0}
.filters .input{padding:10px 12px;font-size:14px}
.filters label{font-size:11px}

/* Pagination */
.pager{display:flex;gap:6px;justify-content:center;margin-top:18px;flex-wrap:wrap}
.pager a,.pager span{padding:8px 13px;border-radius:10px;border:1px solid var(--border);text-decoration:none;
  font-size:14px;background:var(--glass);color:var(--text-primary)}
.pager .cur{background:var(--accent);border-color:var(--accent)}
.pager .disabled{opacity:.4;pointer-events:none}

/* Login */
.login-wrap{min-height:100dvh;display:grid;place-items:center;padding:24px}
.login-card{width:100%;max-width:400px;padding:34px;text-align:center}
.login-card .logo-fallback{width:64px;height:64px;border-radius:18px;margin:0 auto 14px;display:grid;
  place-items:center;background:var(--accent-soft);color:var(--accent);font-family:'Plus Jakarta Sans';font-weight:800;font-size:30px}
.login-card h1{font-size:24px;margin:0 0 4px}
.login-card form{text-align:left;margin-top:20px}
.login-card .field{margin-bottom:14px}
@media(max-width:480px){
  .login-wrap{padding:14px;align-items:start;padding-top:6vh}
  .login-card{padding:24px 18px;border-radius:18px}
  .login-card h1{font-size:21px}
  .login-card .logo-fallback{width:54px;height:54px;font-size:26px}
}

/* Modal / drawer */
.drawer-back{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);z-index:80;
  opacity:0;pointer-events:none;transition:.25s}
.drawer-back.open{opacity:1;pointer-events:auto}
.drawer{position:fixed;right:0;top:0;height:100dvh;width:min(460px,94vw);background:var(--surface);
  border-left:1px solid var(--border);z-index:81;transform:translateX(100%);transition:transform .3s var(--ease);
  overflow-y:auto;padding:26px}
.drawer.open{transform:none}
.drawer .close{position:absolute;right:18px;top:16px;cursor:pointer;font-size:20px;color:var(--text-muted)}

/* Tabs (settings) */
.tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:20px;border-bottom:1px solid var(--border);padding-bottom:10px}
.tab{padding:9px 14px;border-radius:10px;cursor:pointer;font-size:14px;color:var(--text-muted);font-weight:500;
  display:inline-flex;align-items:center;gap:7px}
.tab svg{width:16px;height:16px}
.tab.active{background:var(--accent-soft);color:var(--text-primary)}
.tabpane{display:none;animation:fadeIn .25s}
.tabpane.active{display:block}
.setting-row{display:grid;grid-template-columns:240px 1fr;gap:18px;align-items:center;padding:13px 0;
  border-bottom:1px solid rgba(255,255,255,.05)}
.setting-row .k{font-size:14px}.setting-row .k small{display:block;color:var(--text-muted);font-size:12px;margin-top:2px}
@media(max-width:680px){.setting-row{grid-template-columns:1fr}}

/* color presets */
.presets{display:flex;gap:14px;flex-wrap:wrap}
.preset-item{display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;width:62px;transition:transform .15s}
.preset-item:hover{transform:translateY(-2px)}
.preset{width:44px;height:44px;border-radius:12px;border:2px solid var(--border);transition:.15s}
.preset-item:hover .preset{border-color:var(--accent);box-shadow:0 6px 16px var(--accent-soft)}
.preset-name{font-size:11px;color:var(--text-muted);text-align:center;line-height:1.2}
.color-field{display:flex;gap:10px;align-items:center}
.color-field input[type=color]{width:44px;height:38px;border:1px solid var(--border);border-radius:10px;background:none;padding:2px}

/* Toggle switch */
.switch{position:relative;width:48px;height:28px;display:inline-block}
.switch input{opacity:0;width:0;height:0}
.switch .sl{position:absolute;inset:0;background:rgba(255,255,255,.15);border-radius:50px;transition:.2s;cursor:pointer}
.switch .sl::before{content:"";position:absolute;width:22px;height:22px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s}
.switch input:checked + .sl{background:var(--accent)}
.switch input:checked + .sl::before{transform:translateX(20px)}

/* responsive two-column utility */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:600px){.two-col{grid-template-columns:1fr}}

/* mobile sidebar */
.menu-btn{display:none}
.sidebar-overlay{position:fixed;inset:0;background:rgba(15,23,42,.45);backdrop-filter:blur(2px);
  z-index:89;opacity:0;pointer-events:none;transition:opacity .25s}
.sidebar-overlay.open{opacity:1;pointer-events:auto}
@media(max-width:860px){
  .app-shell{grid-template-columns:1fr}
  .sidebar{position:fixed;left:0;top:0;z-index:90;transform:translateX(-100%);
    transition:transform .28s var(--ease);width:min(80vw,290px);box-shadow:0 0 50px rgba(0,0,0,.4)}
  .sidebar.open{transform:none}
  .menu-btn{display:inline-grid}
  .main{padding:16px 14px 60px}
  .topbar h1{font-size:21px}
  .topbar .actions{width:100%}
  .topbar .actions .btn{flex:1;justify-content:center;font-size:14px;padding:12px 14px}
  .drawer{width:100vw;padding:22px 18px}
  .stat .num{font-size:28px}
  .panel{padding:14px}
  table.data{font-size:13px}
  table.data th,table.data td{padding:9px 10px}
}
@media(max-width:560px){
  .filters{gap:8px}
  .filters .field{flex:1 1 46%;min-width:0}
}
/* bigger touch targets on touch devices */
@media(hover:none){
  .iconbtn{width:38px;height:38px}
  .nav-link{padding:13px 13px}
}
