/* ═══════════════════════════════════════════════════════════════
   THP-GHANA ATTENDANCE SYSTEM — Stylesheet
   
   TABLE OF CONTENTS:
   1. Theme Variables & Base
   2. Background & Decorations
   3. Theme Toggle
   4. Sync Bar & Setup Banner
   5. Views & Layout
   6. Login Panel
   7. QR Landing
   8. App Shell (Sidebar, Main, Panels)
   9. Stats, Charts & Data Display
   10. Clock Box & Session
   11. Forms & Input Fields
   12. Tables & Cards
   13. Badges & Buttons
   14. Staff Grid & Avatars
   15. QR Code Sections
   16. Leave Management
   17. Mobile Navigation
   18. Toasts & Utilities
   19. Modals & Overlays
═══════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════
   THEME VARIABLES
═══════════════════════════════════════════════ */
:root {
  --navy:#2D3592; --navy2:#1a2070; --teal:#3DBFB8; --gold:#F5A623;
  --green:#22c55e; --red:#ef4444; --blue:#3b82f6; --purple:#818cf8;
  --shadow:0 24px 64px rgba(0,0,0,0.55);
}
[data-theme="dark"] {
  --bg:#0c1118; --surf:#111827; --surf2:#1a2438; --surf3:#0f1623;
  --border:rgba(255,255,255,0.07); --border2:rgba(255,255,255,0.04);
  --text:#eef2ff; --text2:#94a3b8; --text3:#475569;
  --card-bg:#111827; --input-bg:#0c1118;
  --orb1:rgba(45,53,146,.22); --orb2:rgba(61,191,184,.14);
}
[data-theme="light"] {
  --bg:#f0f4ff; --surf:#ffffff; --surf2:#f1f5f9; --surf3:#e8eef8;
  --border:rgba(0,0,0,0.08); --border2:rgba(0,0,0,0.04);
  --text:#1e2340; --text2:#475569; --text3:#94a3b8;
  --card-bg:#ffffff; --input-bg:#f8faff;
  --orb1:rgba(45,53,146,.08); --orb2:rgba(61,191,184,.07);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:'Outfit',sans-serif;
  background:var(--bg);
  color:var(--text);
  min-height:100vh;
  overflow-x:hidden;
  transition:background .3s,color .3s;
}

/* ── BACKGROUND ── */
#bg{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 55% 45% at 10% 10%, var(--orb1) 0%,transparent 70%),
    radial-gradient(ellipse 45% 55% at 90% 90%, var(--orb2) 0%,transparent 70%),
    var(--bg);
  transition:background .3s;
}
[data-theme="dark"] #bg::after{
  content:'';position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);
  background-size:60px 60px;
}
.orb{position:fixed;border-radius:50%;filter:blur(80px);pointer-events:none;z-index:0;animation:drift 14s ease-in-out infinite alternate;}
.orb-1{width:380px;height:380px;top:-100px;left:-100px;background:rgba(45,53,146,.16);animation-delay:0s;}
.orb-2{width:280px;height:280px;bottom:-80px;right:-80px;background:rgba(61,191,184,.1);animation-delay:-6s;}
.orb-3{width:180px;height:180px;top:45%;left:58%;background:rgba(245,166,35,.06);animation-delay:-10s;}
@keyframes drift{from{transform:translate(0,0) scale(1)}to{transform:translate(28px,18px) scale(1.08)}}

/* ── THEME TOGGLE ── */
.theme-btn{
  position:fixed;bottom:1.2rem;right:1.2rem;z-index:9999;
  width:40px;height:40px;border-radius:50%;
  background:var(--surf);border:1px solid var(--border);
  color:var(--text2);font-size:1.1rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;box-shadow:0 4px 12px rgba(0,0,0,.2);
}
.theme-btn:hover{transform:scale(1.1);border-color:var(--teal);}
@media(max-width:768px){
  .theme-btn{bottom:1.2rem;right:1.2rem;width:38px;height:38px;font-size:1rem;z-index:9999;}
}

/* ── SYNC BAR ── */
/* ── LOADING OVERLAY ── */
#loading-overlay{
  position:fixed;inset:0;z-index:10000;
  display:none;flex-direction:column;align-items:center;justify-content:center;gap:1.2rem;
  background:var(--bg);
  transition:opacity .4s ease;
}
#loading-overlay.active{display:flex;}
#loading-overlay.fade-out{opacity:0;pointer-events:none;}
.lo-ring{
  position:relative;width:56px;height:56px;
  display:flex;align-items:center;justify-content:center;
}
.lo-spinner{
  position:absolute;inset:0;border-radius:50%;
  border:2.5px solid rgba(45,53,146,.12);
  border-top-color:#2D3592;
  border-right-color:#3DBFB8;
  animation:loSpin .65s linear infinite;
}
.lo-logo{
  width:34px;height:34px;border-radius:8px;object-fit:cover;
  position:relative;z-index:1;
}
.lo-text{font-size:.78rem;color:var(--text2);font-weight:500;letter-spacing:.2px;}
@keyframes loSpin{to{transform:rotate(-360deg);}}

/* ── SETUP BANNER ── */
#setup-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:8000;
  background:rgba(29,40,110,.97);border-top:1px solid rgba(255,255,255,.1);
  padding:.85rem 1.4rem;display:flex;align-items:center;gap:.9rem;flex-wrap:wrap;
}
#setup-banner p{font-size:.83rem;color:rgba(255,255,255,.78);flex:1;min-width:160px;}
#setup-banner input{flex:1;min-width:190px;background:rgba(0,0,0,.38);border:1px solid rgba(255,255,255,.18);border-radius:8px;padding:.48rem .85rem;color:#fff;font-family:'Outfit',sans-serif;font-size:.83rem;outline:none;}
#setup-banner input:focus{border-color:var(--teal);}
.btn-banner-save{padding:.48rem 1rem;border-radius:8px;background:var(--teal);border:none;color:#0c1118;font-family:'Outfit',sans-serif;font-weight:700;font-size:.82rem;cursor:pointer;}
.btn-banner-dis {padding:.48rem .85rem;border-radius:8px;background:transparent;border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.55);font-family:'Outfit',sans-serif;font-size:.8rem;cursor:pointer;}

/* ── VIEWS ── */
.view{display:none;position:relative;z-index:1;}
.view.active{display:block;}
#login-view.active,#qr-landing-view.active{display:flex;}
#login-view,#qr-landing-view{min-height:100vh;align-items:center;justify-content:center;padding:1.5rem;}

/* ═══════════════════════════════════════════════
   NEW UNIFIED LOGIN
═══════════════════════════════════════════════ */
.lc-wrap{
  display:grid;grid-template-columns:1.05fr 1fr;
  max-width:900px;width:100%;min-height:580px;
  border-radius:32px;overflow:hidden;
  box-shadow:0 40px 100px rgba(0,0,0,.55);
  animation:cardUp .55s cubic-bezier(.16,1,.3,1) both;
}
@keyframes cardUp{from{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}

/* ── Left panel ── */
.lc-left{
  background:linear-gradient(145deg,#1a2070 0%,#2D3592 45%,#0d1340 100%);
  padding:3rem 2.5rem;display:flex;flex-direction:column;justify-content:center;
  position:relative;overflow:hidden;
}
.lc-blob{position:absolute;border-radius:50%;filter:blur(55px);pointer-events:none;}
.lc-blob-1{width:260px;height:260px;top:-80px;right:-80px;background:rgba(61,191,184,.18);}
.lc-blob-2{width:180px;height:180px;bottom:-60px;left:-40px;background:rgba(245,166,35,.13);}
.lc-blob-3{width:120px;height:120px;top:50%;left:60%;background:rgba(129,140,248,.1);}
.lc-left-inner{position:relative;z-index:1;}
.lc-logo{width:80px;height:auto;margin-bottom:1.1rem;filter:drop-shadow(0 4px 16px rgba(0,0,0,.4));animation:logoPop .6s cubic-bezier(.16,1,.3,1) both;}
@keyframes logoPop{from{opacity:0;transform:scale(.75)}to{opacity:1;transform:scale(1)}}
.lc-tagline{font-family:'Playfair Display',serif;font-size:.92rem;font-weight:700;color:var(--teal);letter-spacing:.06em;margin-bottom:.6rem;opacity:.9;}
.lc-rule{width:36px;height:2px;background:linear-gradient(90deg,var(--teal),transparent);border-radius:2px;margin-bottom:.75rem;}
.lc-title{font-family:'Playfair Display',serif;font-size:2rem;font-weight:800;color:#fff;line-height:1.15;margin-bottom:.75rem;}
.lc-title span{color:var(--teal);}
.lc-desc{font-size:.78rem;color:rgba(255,255,255,.42);line-height:1.75;margin-bottom:1.8rem;max-width:230px;}
.lc-pills{display:flex;flex-direction:column;gap:.42rem;}
.lc-pill{display:flex;align-items:center;gap:9px;font-size:.75rem;color:rgba(255,255,255,.55);padding:.4rem .75rem;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:50px;}
.lc-pill:nth-child(1){animation:.4s .1s slideL ease both}
.lc-pill:nth-child(2){animation:.4s .2s slideL ease both}
.lc-pill:nth-child(3){animation:.4s .3s slideL ease both}
.lc-pill:nth-child(4){animation:.4s .4s slideL ease both}
@keyframes slideL{from{opacity:0;transform:translateX(-14px)}to{opacity:1;transform:translateX(0)}}

/* ── Right panel ── */
.lc-right{
  background:var(--surf);
  display:flex;align-items:center;justify-content:center;
  padding:2.8rem 2.4rem;
}
.lc-form-wrap{width:100%;max-width:340px;}
.lc-form-logo{display:none;}
.lc-form-title{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:800;color:var(--text);margin-bottom:.2rem;}
.lc-form-sub{font-size:.78rem;color:var(--text2);margin-bottom:1.8rem;}
.lc-field{margin-bottom:1.1rem;}
.lc-field label{display:block;font-size:.68rem;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.42rem;}
.lc-input-wrap{display:flex;align-items:center;background:var(--input-bg);border:1.5px solid var(--border);border-radius:12px;padding:0 .9rem;transition:border-color .2s,box-shadow .2s;}
.lc-input-wrap:focus-within{border-color:var(--teal);box-shadow:0 0 0 3px rgba(61,191,184,.12);}
.lc-icon{font-size:.9rem;margin-right:.5rem;opacity:.5;flex-shrink:0;}
.lc-input-wrap input{flex:1;background:transparent;border:none;outline:none;padding:.78rem 0;font-family:'Outfit',sans-serif;font-size:.9rem;color:var(--text);}
.lc-input-wrap input::placeholder{color:var(--text3);}
.lc-eye{background:none;border:none;cursor:pointer;padding:.4rem;color:var(--text3);font-size:.85rem;transition:color .2s;flex-shrink:0;}
.lc-eye:hover{color:var(--teal);}
.lc-err{min-height:18px;font-size:.78rem;color:var(--red);margin-bottom:.6rem;font-weight:500;}
.lc-btn{
  width:100%;padding:.9rem 1.5rem;
  background:linear-gradient(135deg,#2D3592,#4555d4);
  border:none;border-radius:12px;color:#fff;
  font-family:'Outfit',sans-serif;font-weight:700;font-size:.95rem;
  cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.6rem;
  transition:transform .15s,box-shadow .2s,opacity .2s;
  box-shadow:0 6px 24px rgba(45,53,146,.35);
  margin-top:.4rem;
}
.lc-btn:hover{transform:translateY(-2px);box-shadow:0 10px 32px rgba(45,53,146,.45);}
.lc-btn:active{transform:translateY(0);}
.lc-btn.loading{opacity:.7;pointer-events:none;}
.lc-foot{margin-top:1.6rem;text-align:center;font-size:.67rem;color:var(--text3);}

@keyframes errShake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-6px)}40%,80%{transform:translateX(6px)}}

/* Mobile */
@media(max-width:680px){
  .lc-wrap{grid-template-columns:1fr;border-radius:20px;}
  .lc-left{display:none;}
  .lc-right{padding:2.4rem 1.8rem;}
  .lc-form-logo{display:flex;justify-content:center;margin-bottom:1.2rem;}
  .lc-form-logo img{width:60px;height:auto;}
  .lc-form-title{text-align:center;}
  .lc-form-sub{text-align:center;}
}

/* ═══════════════════════════════════════════════
   QR LANDING
═══════════════════════════════════════════════ */
.qr-card{background:var(--surf);border:1px solid var(--border);border-radius:24px;padding:2.4rem 2rem;max-width:400px;width:100%;text-align:center;box-shadow:var(--shadow);animation:cardUp .45s ease both;}
.qr-card img.qr-logo{width:60px;height:auto;margin-bottom:.9rem;}
.big-clock{font-family:'Playfair Display',serif;font-size:2.5rem;font-weight:700;color:var(--teal);line-height:1;}
.qr-date-lbl{color:var(--text2);font-size:.76rem;margin:5px 0 1.4rem;}
.qr-msg{min-height:22px;margin-top:.9rem;font-size:.83rem;}

/* ═══════════════════════════════════════════════
   APP SHELL
═══════════════════════════════════════════════ */
/* ── APP SHELL ── */
.shell{display:flex;min-height:100vh;}

.sidebar{
  width:250px;background:var(--surf);border-right:1px solid var(--border);
  display:flex;flex-direction:column;padding:1.4rem 1.1rem;
  position:fixed;top:0;left:0;height:100vh;z-index:200;
  transition:transform .28s cubic-bezier(.4,0,.2,1),background .3s;
  overflow-y:auto;
}

/* ── Duplicate definitions removed — canonical rules are in sections below ── */
.sb-logo{display:flex;align-items:center;gap:10px;padding-bottom:1.2rem;border-bottom:1px solid var(--border);margin-bottom:1.4rem;}
.sb-logo img{width:38px;height:auto;}
.sb-brand{font-family:'Playfair Display',serif;font-size:.94rem;font-weight:700;line-height:1.2;color:var(--text);}
.sb-brand small{font-family:'Outfit',sans-serif;font-size:.65rem;color:var(--teal);font-weight:400;display:block;}
.nav-lbl{font-size:.64rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text3);margin:1rem 0 .35rem .45rem;}
.nav-item{
  display:flex;align-items:center;gap:9px;padding:.58rem .8rem;
  border-radius:10px;color:var(--text2);font-size:.85rem;font-weight:500;
  cursor:pointer;transition:all .18s;border:none;background:transparent;width:100%;text-align:left;margin-bottom:1px;
}
.nav-item .ico{font-size:.95rem;width:20px;text-align:center;flex-shrink:0;}
.nav-item:hover{background:var(--surf2);color:var(--text);}
.nav-item.active{background:rgba(45,53,146,.22);color:var(--purple);border-left:3px solid var(--navy);padding-left:calc(.8rem - 3px);}
[data-theme="light"] .nav-item.active{background:rgba(45,53,146,.09);color:var(--navy);}

/* ── NOTIFICATION BADGE (Facebook-style) ── */
.nav-item{position:relative;}
.notif-badge{
  display:none;position:absolute;
  top:4px;right:6px;
  min-width:18px;height:18px;
  background:#ef4444;color:#fff;
  border-radius:9px;font-size:.62rem;font-weight:700;
  align-items:center;justify-content:center;
  padding:0 4px;line-height:1;
  box-shadow:0 1px 4px rgba(239,68,68,.55);
  animation:badgePop .25s cubic-bezier(.34,1.56,.64,1) both;
}
.notif-badge.show{display:inline-flex;}
@keyframes badgePop{from{transform:scale(0)}to{transform:scale(1)}}
/* Mobile tab badge */
.mob-tab{position:relative;}
.mob-notif{
  display:none;position:absolute;
  top:2px;right:calc(50% - 16px);
  min-width:16px;height:16px;
  background:#ef4444;color:#fff;
  border-radius:8px;font-size:.58rem;font-weight:700;
  align-items:center;justify-content:center;
  padding:0 3px;line-height:1;
  box-shadow:0 1px 4px rgba(239,68,68,.55);
  animation:badgePop .25s cubic-bezier(.34,1.56,.64,1) both;
}
.mob-notif.show{display:inline-flex;}
.sb-bottom{margin-top:auto;padding-top:1rem;}
.sync-pill{display:flex;align-items:center;gap:6px;padding:.36rem .65rem;border-radius:8px;font-size:.7rem;margin-bottom:.55rem;font-weight:500;transition:all .2s;}
.sync-pill.live   {background:rgba(34,197,94,.1); color:var(--green);}
.sync-pill.no-url {background:var(--surf2);        color:var(--text3);}
.user-chip{background:var(--surf2);border-radius:11px;padding:.75rem;display:flex;align-items:center;gap:9px;margin-bottom:.65rem;}
.u-av{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.82rem;color:#fff;flex-shrink:0;font-family:'Outfit',sans-serif;}
.u-name{font-size:.82rem;font-weight:600;line-height:1.3;color:var(--text);}
.u-role{font-size:.65rem;color:var(--teal);}
.btn-logout{width:100%;padding:.54rem;border:1px solid var(--border);background:transparent;color:var(--text2);border-radius:9px;font-family:'Outfit',sans-serif;font-size:.8rem;cursor:pointer;transition:all .2s;}
.btn-logout:hover{border-color:var(--red);color:var(--red);}

.main{margin-left:250px;flex:1;padding:2rem;min-width:0;}
.panel{display:none;animation:fadeUp .26s ease both;}
.panel.active{display:block;}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.pg-hdr{margin-bottom:1.6rem;}
.pg-hdr h2{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:700;color:var(--text);}
.pg-hdr p{color:var(--text2);font-size:.84rem;margin-top:3px;}

/* ── STATS GRID ── */
.stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.9rem;margin-bottom:1.6rem;}
.stat{background:var(--surf);border:1px solid var(--border);border-radius:15px;padding:1.1rem;position:relative;overflow:hidden;transition:background .3s;}
.stat::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--navy),var(--teal));}
.stat-lbl{font-size:.68rem;color:var(--text2);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.4rem;}
.stat-val{font-family:'Playfair Display',serif;font-size:1.9rem;font-weight:700;}
.stat-val.g{color:var(--green)}.stat-val.a{color:var(--gold)}.stat-val.r{color:var(--red)}.stat-val.t{color:var(--teal)}.stat-val.p{color:var(--purple)}
.stat-sub{font-size:.68rem;color:var(--text3);margin-top:2px;}

/* ── CLOCK BOX ── */
.clock-box{
  background:var(--surf);border:1px solid var(--border);border-radius:18px;padding:1.8rem;
  margin-bottom:1.4rem;display:flex;flex-wrap:wrap;gap:1.4rem;align-items:center;
  background-image:linear-gradient(135deg,rgba(45,53,146,.14) 0%,transparent 55%);
  transition:background .3s;
}
.time-display{font-family:'Playfair Display',serif;font-size:2.6rem;font-weight:700;color:var(--teal);line-height:1;}
.date-display{color:var(--text2);font-size:.8rem;margin-top:4px;}
.clock-right{margin-left:auto;display:flex;flex-direction:column;gap:.7rem;align-items:flex-end;flex-wrap:wrap;}
.sess-badge{display:inline-flex;align-items:center;gap:6px;padding:.3rem .8rem;border-radius:20px;font-size:.74rem;font-weight:600;}
.sess-on {background:rgba(34,197,94,.12); color:var(--green);}
.sess-off{background:var(--surf2);        color:var(--text2);}
.dot{width:7px;height:7px;border-radius:50%;background:currentColor;animation:blink 1.6s infinite;}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}
.ctrl-row{display:flex;gap:.65rem;flex-wrap:wrap;align-items:center;}
.dept-sel{
  background:var(--input-bg);border:1.5px solid var(--border);border-radius:9px;
  padding:.65rem .9rem;color:var(--text);font-family:'Outfit',sans-serif;font-size:.85rem;
  outline:none;min-width:165px;transition:border-color .2s;
}
.dept-sel:focus{border-color:var(--teal);}
.dept-sel option{background:var(--surf);}
.btn-in,.btn-out{padding:.64rem 1.2rem;border-radius:9px;font-family:'Outfit',sans-serif;font-weight:600;font-size:.85rem;cursor:pointer;transition:all .2s;}
.btn-in {background:rgba(34,197,94,.12); border:1px solid rgba(34,197,94,.28); color:var(--green);}
.btn-out{background:rgba(239,68,68,.1);  border:1px solid rgba(239,68,68,.28); color:var(--red);}
.btn-in:hover:not(:disabled) {background:rgba(34,197,94,.22);}
.btn-out:hover:not(:disabled){background:rgba(239,68,68,.2);}
button:disabled{opacity:.32;cursor:not-allowed;}

/* ── EARLY EXIT ── */
.early-box{background:rgba(245,166,35,.06);border:1px solid rgba(245,166,35,.2);border-radius:15px;padding:1.4rem;margin-bottom:1.4rem;}
.early-box h4{font-family:'Playfair Display',serif;color:var(--gold);margin-bottom:.35rem;}
.early-box p{color:var(--text2);font-size:.84rem;margin-bottom:.9rem;}

/* ═══════════════════════════════════════════════
   AVATAR SYSTEM
═══════════════════════════════════════════════ */
.av{
  width:40px;height:40px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-weight:700;font-size:.88rem;color:#fff;
  flex-shrink:0;font-family:'Outfit',sans-serif;
}
.av-lg{width:52px;height:52px;font-size:1.1rem;}
.av-sm{width:30px;height:30px;font-size:.7rem;}

/* ═══════════════════════════════════════════════
   CARDS & TABLES
═══════════════════════════════════════════════ */
.tcard{background:var(--surf);border:1px solid var(--border);border-radius:17px;overflow:hidden;margin-bottom:1.4rem;transition:background .3s;}
.tcard-hdr{padding:1rem 1.3rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.65rem;}
.tcard-hdr h4{font-family:'Playfair Display',serif;font-size:.97rem;color:var(--text);}
.t-btns{display:flex;gap:.4rem;flex-wrap:wrap;}
.filter-bar{padding:.85rem 1.3rem;border-bottom:1px solid var(--border);display:flex;gap:.6rem;flex-wrap:wrap;align-items:center;}
.filter-group{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;}
.filter-label{font-size:.72rem;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;}
.filter-chips{display:flex;gap:.35rem;flex-wrap:wrap;}
.chip{padding:.28rem .75rem;border-radius:20px;font-size:.72rem;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--surf2);color:var(--text2);transition:all .18s;}
.chip:hover{border-color:var(--teal);color:var(--teal);}
.chip.active{background:var(--teal);border-color:var(--teal);color:#fff;}
.chip.chip-all.active{background:var(--navy);border-color:var(--navy);}
.filter-divider{width:1px;height:22px;background:var(--border);margin:0 .3rem;}
.fi-wrap{display:flex;align-items:center;gap:.4rem;background:var(--surf2);border:1px solid var(--border);border-radius:8px;padding:.28rem .65rem;}
.fi-wrap svg{width:14px!important;height:14px!important;min-width:14px;flex-shrink:0;color:var(--text3);}
.fi-wrap input,.fi-wrap select{background:transparent;border:none;outline:none;color:var(--text);font-size:.8rem;font-family:inherit;min-width:0;}
th.sortable{cursor:pointer;user-select:none;white-space:nowrap;}
th.sortable::after{content:'↕';margin-left:.35rem;opacity:.3;font-size:.75em;}
th.sort-asc::after{content:'↑';opacity:1;color:var(--teal);}
th.sort-desc::after{content:'↓';opacity:1;color:var(--teal);}
th.sortable:hover{color:var(--teal);}
.results-bar{padding:.4rem 1.3rem;font-size:.73rem;color:var(--text3);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}
.results-bar strong{color:var(--teal);}
.clear-btn{font-size:.72rem;color:var(--text3);cursor:pointer;padding:.2rem .55rem;border-radius:6px;border:1px solid var(--border);background:transparent;transition:all .15s;}
.clear-btn:hover{color:var(--red);border-color:var(--red);}
.fi{background:var(--input-bg);border:1.5px solid var(--border);border-radius:8px;padding:.4rem .68rem;color:var(--text);font-size:.78rem;font-family:'Outfit',sans-serif;outline:none;transition:border-color .2s;}
.fi:focus{border-color:var(--teal);}
.scr{overflow-x:auto;}
table{width:100%;border-collapse:collapse;}
thead tr{border-bottom:1px solid var(--border);}
th{padding:.62rem 1rem;text-align:left;font-size:.65rem;text-transform:uppercase;letter-spacing:.09em;color:var(--text2);font-weight:600;}
td{padding:.72rem 1rem;font-size:.83rem;border-bottom:1px solid var(--border2);color:var(--text);}
tr:last-child td{border-bottom:none;}
tr:hover td{background:rgba(255,255,255,.014);}
[data-theme="light"] tr:hover td{background:rgba(0,0,0,.018);}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:.22rem .58rem;border-radius:18px;font-size:.7rem;font-weight:600;}
.b-ok    {background:rgba(34,197,94,.12); color:var(--green);}
.b-early {background:rgba(245,166,35,.12);color:var(--gold);}
.b-active{background:rgba(61,191,184,.12);color:var(--teal);}
.b-warn  {background:rgba(245,166,35,.12);color:var(--gold);}
.b-err   {background:rgba(239,68,68,.1);  color:var(--red);}
.b-info  {background:rgba(59,130,246,.1); color:var(--blue);}
.b-purple{background:rgba(129,140,248,.1);color:var(--purple);}

/* ── BUTTONS ── */
.bsm{padding:.38rem .78rem;border-radius:8px;font-size:.76rem;font-family:'Outfit',sans-serif;font-weight:600;cursor:pointer;transition:all .2s;}
.bsm-navy  {background:rgba(45,53,146,.16); border:1px solid rgba(45,53,146,.3);  color:var(--purple);}
.bsm-teal  {background:rgba(61,191,184,.12);border:1px solid rgba(61,191,184,.28);color:var(--teal);}
.bsm-gold  {background:rgba(245,166,35,.1); border:1px solid rgba(245,166,35,.25);color:var(--gold);}
.bsm-green {background:rgba(34,197,94,.1);  border:1px solid rgba(34,197,94,.25); color:var(--green);}
.bsm-red   {background:rgba(239,68,68,.1);  border:1px solid rgba(239,68,68,.22); color:var(--red);}
.bsm-navy:hover  {background:rgba(45,53,146,.28);}
.bsm-teal:hover  {background:rgba(61,191,184,.22);}
.bsm-gold:hover  {background:rgba(245,166,35,.2);}
.bsm-green:hover {background:rgba(34,197,94,.2);}
.bsm-red:hover   {background:rgba(239,68,68,.18);}

.btn-add{padding:.65rem 1.3rem;background:linear-gradient(135deg,var(--navy),#3f4ec0);border:none;border-radius:9px;color:#fff;font-family:'Outfit',sans-serif;font-weight:700;font-size:.85rem;cursor:pointer;margin-top:.9rem;transition:opacity .2s;}
.btn-add:hover{opacity:.86;}
.btn-teal{padding:.65rem 1.3rem;border-radius:9px;background:var(--teal);border:none;color:#0c1118;font-family:'Outfit',sans-serif;font-weight:700;font-size:.85rem;cursor:pointer;transition:all .2s;}
.btn-teal:hover{opacity:.85;transform:translateY(-1px);}

/* ── ADD CARD ── */
.add-card{background:var(--surf);border:1px solid var(--border);border-radius:16px;padding:1.5rem;margin-bottom:1.3rem;transition:background .3s;}
.add-card h4{font-family:'Playfair Display',serif;margin-bottom:1.1rem;color:var(--text);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.9rem;}
@media(max-width:560px){.form-row{grid-template-columns:1fr;}}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.9rem;}
@media(max-width:700px){.form-row-3{grid-template-columns:1fr 1fr;}}
@media(max-width:460px){.form-row-3{grid-template-columns:1fr;}}

/* ── STAFF GRID ── */
.staff-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(215px,1fr));gap:.9rem;margin-bottom:1.4rem;}
.scard{background:var(--surf);border:1px solid var(--border);border-radius:15px;padding:1.1rem;display:flex;flex-direction:column;gap:.6rem;transition:background .3s;}
.scard-top{display:flex;align-items:center;gap:9px;}
.s-info{flex:1;min-width:0;}
.s-name{font-weight:600;font-size:.87rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text);}
.s-id  {font-size:.7rem;color:var(--text2);}
.s-meta{display:flex;gap:.4rem;flex-wrap:wrap;align-items:center;}
.s-unit{font-size:.68rem;color:var(--teal);background:rgba(61,191,184,.1);border-radius:18px;padding:.16rem .55rem;display:inline-block;}
.s-role-badge{font-size:.68rem;border-radius:18px;padding:.16rem .55rem;display:inline-block;}
.role-admin  {background:rgba(239,68,68,.1);   color:var(--red);}
.role-manager{background:rgba(245,166,35,.1);  color:var(--gold);}
.role-country_leader{background:rgba(225,29,72,.1);color:#e11d48;}
.role-staff  {background:rgba(61,191,184,.1);  color:var(--teal);}
.scard-btns{display:flex;gap:.38rem;flex-wrap:wrap;}
.btn-edit{padding:.32rem .62rem;border-radius:7px;background:rgba(129,140,248,.1);border:1px solid rgba(129,140,248,.2);color:var(--purple);font-size:.7rem;cursor:pointer;font-family:'Outfit',sans-serif;transition:all .2s;}
.btn-del {padding:.32rem .62rem;border-radius:7px;background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.18);color:var(--red);   font-size:.7rem;cursor:pointer;font-family:'Outfit',sans-serif;transition:all .2s;}

/* ── CHARTS ── */
.charts{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem;margin-bottom:1.4rem;}
@media(max-width:720px){.charts{grid-template-columns:1fr;}}
.ccrd{background:var(--surf);border:1px solid var(--border);border-radius:16px;padding:1.3rem;transition:background .3s;}
.ccrd h4{font-family:'Playfair Display',serif;font-size:.93rem;margin-bottom:1.1rem;color:var(--text);}
.bar-row{display:flex;align-items:center;gap:8px;margin-bottom:.5rem;}
.bar-lbl{font-size:.72rem;color:var(--text2);width:88px;flex-shrink:0;}
.bar-trk{flex:1;height:7px;background:var(--surf2);border-radius:4px;overflow:hidden;}
.bar-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--navy),var(--teal));transition:width .9s ease;}
.bar-n{font-size:.72rem;font-weight:600;width:24px;text-align:right;color:var(--text);}
.donut-wrap{display:flex;align-items:center;gap:1.3rem;flex-wrap:wrap;}
.lgd-item{display:flex;align-items:center;gap:6px;font-size:.76rem;margin-bottom:.3rem;color:var(--text);}
.lgd-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}

/* ── QR ── */
.qr-hero{background:linear-gradient(135deg,var(--navy) 0%,var(--navy2) 100%);border-radius:18px;padding:2.2rem;display:flex;flex-wrap:wrap;gap:1.8rem;align-items:center;margin-bottom:1.4rem;position:relative;overflow:hidden;}
.qr-hero::before{content:'';position:absolute;top:-70px;right:-70px;width:220px;height:220px;background:radial-gradient(circle,rgba(61,191,184,.22),transparent 70%);border-radius:50%;}
.qr-frame{background:#fff;border-radius:13px;padding:13px;flex-shrink:0;position:relative;z-index:1;}
.qr-info{position:relative;z-index:1;}
.qr-info h3{font-family:'Playfair Display',serif;font-size:1.28rem;color:#fff;margin-bottom:.45rem;}
.qr-info p{color:rgba(255,255,255,.52);font-size:.83rem;line-height:1.68;max-width:290px;}
.qr-url{margin-top:.85rem;background:rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.1);border-radius:7px;padding:.5rem .85rem;font-family:monospace;font-size:.7rem;color:var(--teal);word-break:break-all;}
.btn-white{margin-top:.9rem;padding:.55rem 1.1rem;border-radius:9px;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.1);color:#fff;font-family:'Outfit',sans-serif;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;}
.btn-white:hover{background:rgba(255,255,255,.2);}

/* entrance */
.ent-wrap{background:linear-gradient(140deg,#0d1340 0%,var(--navy) 45%,#164a47 100%);border-radius:22px;padding:2.8rem 2rem;text-align:center;position:relative;overflow:hidden;margin-bottom:1.4rem;}
.ent-wrap::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 26px,rgba(255,255,255,.014) 26px,rgba(255,255,255,.014) 27px);}
.ent-inner{position:relative;z-index:1;}
.ent-inner h3{font-family:'Playfair Display',serif;font-size:1.48rem;color:#fff;margin-bottom:.45rem;}
.ent-inner p{color:rgba(255,255,255,.48);margin-bottom:1.8rem;font-size:.86rem;}
.ent-frame{background:#fff;border-radius:16px;padding:16px;display:inline-block;box-shadow:0 18px 45px rgba(0,0,0,.42);}
.ent-url{display:inline-block;margin-top:1.4rem;background:rgba(0,0,0,.38);border:1px solid rgba(255,255,255,.1);border-radius:9px;padding:.6rem 1.1rem;font-family:monospace;font-size:.76rem;color:var(--teal);word-break:break-all;max-width:460px;}
.ent-btns{display:flex;gap:.8rem;justify-content:center;margin-top:1.3rem;flex-wrap:wrap;}
.btn-ghost{padding:.65rem 1.3rem;border-radius:9px;background:transparent;border:1px solid rgba(255,255,255,.22);color:#fff;font-family:'Outfit',sans-serif;font-weight:600;font-size:.85rem;cursor:pointer;transition:all .2s;}
.btn-ghost:hover{background:rgba(255,255,255,.1);}

/* url bar */
.url-bar{background:var(--surf);border:1px solid var(--border);border-radius:13px;padding:1rem 1.3rem;display:flex;align-items:center;gap:.85rem;flex-wrap:wrap;margin-bottom:1.3rem;}
.url-bar label{font-size:.72rem;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;}
.url-bar input{flex:1;background:var(--input-bg);border:1.5px solid var(--border);border-radius:8px;padding:.54rem .85rem;color:var(--text);font-family:monospace;font-size:.82rem;outline:none;min-width:180px;}
.url-bar input:focus{border-color:var(--teal);}
.btn-gen{padding:.54rem 1rem;border-radius:8px;background:rgba(61,191,184,.12);border:1px solid rgba(61,191,184,.26);color:var(--teal);font-family:'Outfit',sans-serif;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;}
.btn-gen:hover{background:rgba(61,191,184,.22);}

/* ── LEAVE ── */
.leave-types{display:grid;grid-template-columns:repeat(auto-fill,minmax(145px,1fr));gap:.8rem;margin-bottom:1.4rem;}
.ltype-card{
  background:var(--surf);border:1px solid var(--border);border-radius:14px;padding:1.1rem;
  text-align:center;cursor:pointer;transition:all .22s;
}
.ltype-card:hover,.ltype-card.sel{border-color:var(--teal);background:rgba(61,191,184,.07);}
.ltype-icon{font-size:1.6rem;margin-bottom:.5rem;}
.ltype-name{font-size:.8rem;font-weight:600;color:var(--text);margin-bottom:.2rem;}
.ltype-days{font-size:.68rem;color:var(--text2);}

/* leave status */
.lstatus-pending {color:var(--gold);}
.lstatus-approved{color:var(--green);}
.lstatus-rejected{color:var(--red);}



/* ── MODAL ── */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:500;opacity:0;pointer-events:none;transition:opacity .22s;padding:1rem;}
.overlay.open{opacity:1;pointer-events:all;}
.modal{background:var(--surf);border:1px solid var(--border);border-radius:19px;padding:1.8rem;width:100%;max-width:420px;transform:scale(.94);transition:transform .22s;max-height:90vh;overflow-y:auto;}
.overlay.open .modal{transform:scale(1);}
.modal h3{font-family:'Playfair Display',serif;margin-bottom:1.1rem;color:var(--text);}
.modal-foot{display:flex;gap:.65rem;justify-content:flex-end;margin-top:1.3rem;}
.btn-cancel{padding:.55rem 1rem;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text2);font-family:'Outfit',sans-serif;font-size:.83rem;cursor:pointer;}

/* ── GUIDE ── */
.guide{background:var(--surf);border:1px solid var(--border);border-radius:15px;padding:1.3rem;margin-bottom:1.3rem;}
.guide h4{font-family:'Playfair Display',serif;margin-bottom:.9rem;color:var(--text);}
.g-step{display:flex;gap:11px;margin-bottom:.85rem;}
.g-num{width:24px;height:24px;border-radius:50%;flex-shrink:0;background:rgba(61,191,184,.14);border:1px solid rgba(61,191,184,.28);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:var(--teal);}
.g-txt{font-size:.84rem;color:var(--text2);line-height:1.65;padding-top:2px;}
.g-txt strong{color:var(--text);}
code{background:var(--surf2);padding:2px 5px;border-radius:4px;font-size:.76rem;color:var(--teal);}

/* ── TOPBAR (mobile) ── */
.topbar{display:none;align-items:center;justify-content:space-between;padding:.9rem 1.3rem;background:var(--surf);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:150;}
.topbar img{height:28px;}
.menu-btn{background:transparent;border:none;color:var(--text);font-size:1.2rem;cursor:pointer;}
@media(max-width:768px){.sidebar{transform:translateX(-100%);}.sidebar.open{transform:translateX(0);}.main{margin-left:0;}.topbar{display:flex;}}

/* ── MOBILE TOP HEADER + NAV ── */
.mob-nav{display:none;position:fixed;top:0;left:0;right:0;z-index:300;
  background:var(--surf);border-bottom:1px solid var(--border);
  box-shadow:0 2px 12px rgba(0,0,0,.15);}
.mob-header{display:flex;align-items:center;justify-content:space-between;
  padding:.6rem 1rem .4rem;}
.mob-header-left{display:flex;align-items:center;gap:.6rem;}
.mob-hav{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-size:.8rem;font-weight:700;color:#fff;flex-shrink:0;}
.mob-hname{font-size:.82rem;font-weight:600;color:var(--text);line-height:1.2;}
.mob-hrole{font-size:.68rem;color:var(--text3);}
.mob-signout{background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.25);
  color:#ef4444;border-radius:8px;padding:.28rem .7rem;font-size:.72rem;
  font-weight:600;cursor:pointer;font-family:'Outfit',sans-serif;white-space:nowrap;}
.mob-signout:hover{background:rgba(239,68,68,.22);}
.mob-tabs{display:flex;border-top:1px solid var(--border);}
.mob-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:.42rem .3rem .4rem;border:none;background:transparent;
  color:var(--text3);font-size:.6rem;font-weight:500;font-family:'Outfit',sans-serif;
  cursor:pointer;position:relative;transition:color .18s;}
.mob-tab .mico{font-size:1.05rem;line-height:1;}
.mob-tab.active{color:var(--teal);}
.mob-tab.active::after{content:'';position:absolute;bottom:0;left:20%;right:20%;
  height:2px;background:var(--teal);border-radius:2px 2px 0 0;}
@media(max-width:768px){
  .mob-nav{display:block;}
  .topbar{display:none!important;}
  .sidebar{display:none!important;}
  /* mob-nav header ~52px + tabs ~46px = ~98px — add a little breathing room */
  .main{
    margin-left:0 !important;
    padding:1.2rem 1rem;
    padding-top:106px;
    padding-bottom:1.5rem;
    box-sizing:border-box;
  }
  #toasts{bottom:1.4rem;}
  /* Tighter spacing on mobile */
  .pg-hdr{margin-bottom:1rem;}
  .pg-hdr h2{font-size:1.25rem;}
  .stats{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.6rem;margin-bottom:1rem;}
  .stat{padding:.8rem;}
  .stat-val{font-size:1.5rem;}
  .charts{grid-template-columns:1fr;gap:.8rem;margin-bottom:1rem;}
  .add-card{padding:1rem;}
  .form-row{grid-template-columns:1fr;}
  .tcard-hdr{flex-direction:column;align-items:flex-start;}
  .filter-bar{gap:.5rem;}
  .staff-grid{grid-template-columns:1fr 1fr;gap:.65rem;}
}

/* ── TOASTS ── */
#toasts{position:fixed;bottom:1.6rem;right:1.6rem;z-index:9999;display:flex;flex-direction:column;gap:.4rem;}
.toast{background:var(--surf2);border:1px solid var(--border);border-radius:11px;padding:.65rem 1rem;font-size:.83rem;display:flex;align-items:center;gap:7px;min-width:200px;animation:toastIn .26s ease both;box-shadow:0 8px 22px rgba(0,0,0,.38);}
@keyframes toastIn{from{opacity:0;transform:translateX(34px)}to{opacity:1;transform:translateX(0)}}
.toast.ok {border-color:rgba(34,197,94,.3);}
.toast.err{border-color:rgba(239,68,68,.32);}
.toast.info{border-color:rgba(59,130,246,.3);}

.empty{text-align:center;padding:2.2rem;color:var(--text2);font-size:.86rem;}
.empty-ico{font-size:2rem;margin-bottom:.6rem;}

/* ── UPLOAD BOX ── */
.upload-box{border:2px dashed var(--border);border-radius:12px;padding:1.4rem;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;}
.upload-box:hover{border-color:var(--teal);background:rgba(61,191,184,.04);}
.upload-ico{font-size:1.8rem;margin-bottom:.4rem;}
.upload-txt{font-size:.82rem;color:var(--text2);line-height:1.6;}

/* ── LEAVE TYPE GENDER GATING ── */
.ltype-card.ltype-hidden{display:none;}
.ltype-card .ltype-gender-tag{font-size:.62rem;padding:.15rem .4rem;border-radius:20px;margin-top:.2rem;}

/* ── TWO-STAGE APPROVAL BADGES ── */
.stage-badge{display:inline-flex;align-items:center;gap:.3rem;font-size:.7rem;padding:.2rem .55rem;border-radius:20px;font-weight:600;}
.stage-pend{background:rgba(245,166,35,.15);color:#b97a00;}
.stage-ok{background:rgba(34,197,94,.15);color:#166534;}
.stage-rej{background:rgba(239,68,68,.15);color:#991b1b;}

/* ── UNIT DISPLAY ── */
.unit-display{
  background:var(--surf2);border:1px solid var(--border);border-radius:10px;
  padding:.65rem 1rem;font-size:.9rem;font-weight:600;color:var(--teal);
  margin-bottom:.8rem;display:flex;align-items:center;gap:.5rem;
}
.unit-display::before{content:'🏢';font-size:1rem;}

/* ── CHANGE PASSWORD NOTICE ── */
.chpw-notice{
  display:flex;align-items:flex-start;gap:.8rem;
  background:rgba(245,166,35,.08);border:1px solid rgba(245,166,35,.25);
  border-radius:12px;padding:1rem;margin-bottom:1.2rem;
}
.chpw-notice>span{font-size:1.4rem;flex-shrink:0;}
.chpw-notice strong{display:block;font-size:.85rem;color:var(--gold);margin-bottom:.25rem;}
.chpw-notice p{font-size:.78rem;color:var(--text2);margin:0;line-height:1.6;}
.leave-bal{background:var(--surf);border:1px solid var(--border);border-radius:15px;padding:1.2rem;margin-bottom:1.3rem;}
.leave-bal h4{font-family:'Playfair Display',serif;font-size:.95rem;margin-bottom:1rem;color:var(--text);}
.bal-row{display:flex;align-items:center;gap:9px;margin-bottom:.7rem;}
.bal-icon{font-size:1rem;width:22px;text-align:center;}
.bal-info{flex:1;}
.bal-lbl{font-size:.75rem;font-weight:600;color:var(--text);margin-bottom:3px;}
.bal-trk{height:6px;background:var(--surf2);border-radius:3px;overflow:hidden;}
.bal-fill{height:100%;border-radius:3px;transition:width .8s ease;}
.bal-num{font-size:.72rem;color:var(--text2);white-space:nowrap;}
