/* ================================================================
   DTTASA LEAVE CENTRE — Obsidian Command Design Language
   ================================================================ */
:root {
  --void:#0c1109; --deep:#111a0e; --base:#172213; --lift:#1e2e1b;
  --panel:rgba(255,255,255,0.10); --panel2:rgba(255,255,255,0.23);
  --border:rgba(255,255,255,0.21); --bord2:rgba(255,255,255,0.30);
  --gold:#f0c832; --gold2:#f7d94e; --gdim:rgba(212,175,55,0.12);
  --gglow:rgba(212,175,55,0.3); --gsoft:rgba(212,175,55,0.055);
  --green:#4cd657; --gndim:rgba(67,177,75,0.12); --gnsoft:rgba(67,177,75,0.055);
  --red:#ff4848; --rdim:rgba(232,64,64,0.12);
  --text:#f2f7ee; --t2:rgba(242,247,238,0.88); --t3:rgba(242,247,238,0.62);
  --mono:'IBM Plex Mono',monospace; --disp:'Cinzel',serif; --body:'DM Sans',sans-serif;
  --hdh:66px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html,body{width:100%;min-height:100%;background:var(--void);color:var(--text);font-family:var(--body);font-size:15px;-webkit-font-smoothing:antialiased;}
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background:radial-gradient(ellipse at 12% 0%,rgba(67,177,75,0.04) 0%,transparent 52%),
             radial-gradient(ellipse at 88% 100%,rgba(212,175,55,0.04) 0%,transparent 52%),
             repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,0.025) 2px,rgba(0,0,0,0.025) 4px);}

/* ── LOGIN OVERLAY ── */
#login-overlay{position:fixed;inset:0;background:#050905;z-index:9999999;display:flex;align-items:center;justify-content:center;padding:20px;}
.login-card{width:100%;max-width:420px;background:var(--lift);border:1px solid rgba(212,175,55,.28);border-radius:24px;padding:44px 36px;text-align:center;position:relative;overflow:hidden;animation:lcIn .9s cubic-bezier(.16,1,.3,1) both;box-shadow:0 32px 80px rgba(0,0,0,.65),0 0 80px rgba(212,175,55,.05);}
@keyframes lcIn{from{opacity:0;transform:translateY(26px) scale(.96);filter:blur(8px);}to{opacity:1;transform:translateY(0) scale(1);filter:blur(0);}}
.login-card::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:180px;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);}
.login-brand{font-family:var(--disp);font-size:34px;font-weight:900;letter-spacing:10px;background:linear-gradient(135deg,var(--green) 0%,var(--gold) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:5px;}
.login-sub{font-size:8.5px;letter-spacing:4px;color:var(--gold);opacity:.6;text-transform:uppercase;margin-bottom:32px;}
#login-err{color:var(--red);font-size:11px;margin-bottom:13px;display:none;background:rgba(232,64,64,.08);border:1px solid rgba(232,64,64,.2);border-radius:8px;padding:8px 11px;}
.gi{width:100%;background:rgba(0,0,0,.32);border:1px solid var(--border);border-radius:10px;color:var(--text);padding:11px 13px;font-size:13px;outline:none;font-family:var(--body);transition:border-color .25s,box-shadow .25s;margin-bottom:12px;}
.gi:focus{border-color:rgba(212,175,55,.4);box-shadow:0 0 0 3px rgba(212,175,55,.08);}
.gi-ta{min-height:90px;resize:vertical;}
select.gi option{background:#0b130a;}
.btn{border:none;padding:13px 26px;border-radius:50px;font-weight:800;font-size:10px;letter-spacing:2px;cursor:pointer;text-transform:uppercase;transition:all .35s cubic-bezier(.175,.885,.32,1.275);position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:7px;}
.btn::after{content:'';position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:rgba(255,255,255,.12);transform:translate(-50%,-50%);transition:width .4s,height .4s;}
.btn:active::after{width:220px;height:220px;}
.btn-green{background:var(--green);color:#fff;box-shadow:0 6px 18px rgba(67,177,75,.28);}
.btn-green:hover{transform:scale(1.04) translateY(-2px);box-shadow:0 12px 26px rgba(67,177,75,.44);}
.btn-gold{background:var(--gold);color:var(--deep);box-shadow:0 6px 18px rgba(212,175,55,.24);}
.btn-gold:hover{background:var(--gold2);transform:scale(1.04) translateY(-2px);box-shadow:0 12px 26px rgba(212,175,55,.4);}
.btn-red{background:var(--red);color:#fff;}
.btn-red:hover{transform:scale(1.04) translateY(-2px);box-shadow:0 12px 26px rgba(232,64,64,.4);}
.btn-outline{background:transparent;border:1px solid var(--bord2);color:var(--t2);padding:9px 16px;font-size:9px;border-radius:9px;}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);}
.btn-full{width:100%;border-radius:12px;padding:15px;font-size:11.5px;justify-content:center;}
.btn-sm{padding:9px 16px;font-size:9px;border-radius:8px;}
.btn-proc{opacity:.7;cursor:not-allowed!important;pointer-events:none;}
.spin-ico{display:inline-block;width:11px;height:11px;border:2px solid rgba(255,255,255,.2);border-top-color:currentColor;border-radius:50%;animation:spin .7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* ── TOAST ── */
#toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);background:rgba(5,9,5,.98);border:1px solid var(--gold);border-left:4px solid var(--gold);padding:13px 20px;border-radius:8px;display:flex;align-items:center;gap:11px;font-size:12px;font-weight:600;z-index:600000;min-width:280px;max-width:460px;box-shadow:0 12px 40px rgba(0,0,0,.55);backdrop-filter:blur(16px);transition:transform .45s cubic-bezier(.175,.885,.32,1.275),opacity .45s;opacity:0;}
#toast.show{transform:translateX(-50%) translateY(0);opacity:1;}
#toast.error{border-color:var(--red);border-left-color:var(--red);}
#toast i{flex-shrink:0;}
#toast:not(.error) i{color:var(--gold);}
#toast.error i{color:var(--red);}

/* ── NAV TAB BAR ── */
#lv-nav{position:sticky;top:var(--hdh);z-index:490;background:rgba(5,9,5,.92);border-bottom:1px solid var(--border);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;align-items:stretch;overflow-x:auto;scrollbar-width:none;}
#lv-nav::-webkit-scrollbar{display:none;}
.lv-nav-item{display:flex;align-items:center;gap:7px;padding:13px 18px;font-size:11px;font-weight:800;letter-spacing:1.5px;color:var(--t3);text-transform:uppercase;cursor:pointer;white-space:nowrap;border-bottom:2px solid transparent;transition:color .2s,border-color .2s;flex-shrink:0;}
.lv-nav-item:hover{color:var(--t2);}
.lv-nav-item.active{color:var(--gold);border-bottom-color:var(--gold);}
.lv-nav-item i{font-size:12px;}
.lv-nav-badge{background:var(--red);color:#fff;font-size:9px;font-weight:900;min-width:16px;height:16px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;padding:0 4px;margin-left:2px;}
/* view panels */
.lv-view{display:none;}
.lv-view.active{display:block;animation:cvIn .4s cubic-bezier(.16,1,.3,1) both;}
@media(max-width:540px){
  .lv-nav-item{padding:11px 13px;font-size:10px;letter-spacing:1px;}
  .lv-nav-item span{display:none;}
  .lv-nav-item i{font-size:14px;}
}
/* ── HEADER ── */
#lv-hdr{height:var(--hdh);display:flex;align-items:center;justify-content:space-between;padding:0 28px;background:rgba(0,0,0,.58);border-bottom:1px solid var(--border);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);position:sticky;top:0;z-index:500;flex-shrink:0;animation:hdrDrop .7s cubic-bezier(.16,1,.3,1) both;}
@keyframes hdrDrop{from{transform:translateY(-100%);opacity:0;}to{transform:translateY(0);opacity:1;}}
#lv-hdr::after{content:'';position:absolute;inset:0;pointer-events:none;background:linear-gradient(90deg,transparent 0%,rgba(212,175,55,.04) 50%,transparent 100%);background-size:250% 100%;animation:hdrScan 7s linear infinite;}
@keyframes hdrScan{from{background-position:250% 0;}to{background-position:-250% 0;}}
.hdr-left{display:flex;align-items:center;gap:12px;}
.back-btn{display:flex;align-items:center;gap:7px;padding:8px 14px;border-radius:9px;background:var(--panel2);border:1px solid var(--border);color:var(--t2);font-size:10px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;transition:all .25s;}
.back-btn:hover{border-color:var(--gold);color:var(--gold);background:var(--gdim);}
.brand{display:flex;flex-direction:row;align-items:center;gap:10px;}
.brand-text{display:flex;flex-direction:column;gap:1px;}
.brand-logo{font-family:var(--disp);font-size:22px;font-weight:900;letter-spacing:7px;line-height:1;background:linear-gradient(135deg,var(--green) 0%,var(--gold) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.brand-sub{font-size:9px;letter-spacing:3px;color:var(--gold);opacity:.55;text-transform:uppercase;}
.page-title-pill{display:flex;align-items:center;gap:7px;background:var(--gdim);border:1px solid rgba(212,175,55,.22);padding:5px 14px;border-radius:20px;font-size:10px;font-weight:800;color:var(--gold);letter-spacing:1.5px;text-transform:uppercase;}
.hdr-right{display:flex;align-items:center;gap:10px;}
.hdr-clock{font-family:var(--mono);font-size:14px;font-weight:700;color:var(--gold);border:1px solid rgba(212,175,55,.28);padding:7px 14px;border-radius:8px;background:var(--gdim);letter-spacing:2px;white-space:nowrap;}
.hdr-user-chip{display:flex;align-items:center;gap:7px;padding:6px 13px;border-radius:9px;background:var(--panel2);border:1px solid var(--border);font-size:12px;font-weight:700;color:var(--t2);white-space:nowrap;letter-spacing:.3px;}
.hdr-user-chip i{color:var(--gold);font-size:11px;}
.hdr-icon-btn{position:relative;width:36px;height:36px;border-radius:50%;background:var(--panel);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--t2);font-size:14px;cursor:pointer;transition:background .2s,color .2s,box-shadow .2s;}
.hdr-icon-btn:hover{background:var(--gdim);color:var(--gold);box-shadow:0 0 14px var(--gglow);}
.hdr-icon-badge{position:absolute;top:-4px;right:-4px;background:var(--red);color:#fff;font-size:9px;font-weight:700;min-width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0 3px;}
.hdr-notif-wrap{position:relative;}
.hdr-notif-dd{position:fixed;top:var(--hdh);right:10px;width:308px;background:#0d150c;border:1px solid var(--border);border-radius:13px;box-shadow:0 18px 52px rgba(0,0,0,.75);display:none;z-index:99999;overflow:hidden;}
.hdr-notif-dd.open{display:block;animation:ddIn .2s ease both;}
@keyframes ddIn{from{opacity:0;transform:translateY(-7px);}to{opacity:1;transform:none;}}
.hdr-notif-hdr{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}
.hdr-notif-clear{font-size:11px;color:var(--t3);cursor:pointer;background:none;border:none;transition:color .2s;}
.hdr-notif-clear:hover{color:var(--gold);}
.hdr-notif-list{max-height:280px;overflow-y:auto;}
.hdr-notif-item{padding:10px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s;display:flex;gap:9px;align-items:flex-start;}
.hdr-notif-item:hover{background:var(--panel);}
.hdr-notif-item.unread{background:rgba(212,175,55,.04);}
.hdr-ni-icon{width:28px;height:28px;border-radius:50%;background:var(--gdim);display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:11px;flex-shrink:0;}
.hdr-ni-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px;}
.hdr-ni-msg{font-size:12px;color:var(--t3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:210px;}
.hdr-ni-time{font-size:11px;color:var(--t3);margin-top:2px;}
.hdr-notif-empty{padding:22px;text-align:center;color:var(--t3);font-size:12px;}

/* ── MAIN ── */
#lv-main{padding:32px 30px 80px;position:relative;z-index:1;}

/* ── SECTION LABEL ── */
.mlbl{font-size:11px;font-weight:800;letter-spacing:2.5px;color:var(--gold);text-transform:uppercase;margin-bottom:14px;display:flex;align-items:center;gap:8px;}
.mlbl::after{content:'';flex:1;height:1px;background:var(--border);}

/* ── GLASS ── */
.glass{background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:22px;position:relative;overflow:hidden;transition:border-color .3s;}
.glass::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.055),transparent);}
.glass:hover{border-color:var(--bord2);}
.glass-gold{border-color:rgba(212,175,55,.18);background:linear-gradient(135deg,var(--gsoft) 0%,var(--panel) 65%);}

/* ── OVERVIEW SECTION ── */
.overview-grid{display:grid;grid-template-columns:auto 1fr;gap:28px;align-items:start;margin-bottom:28px;}
.ring-wrap{display:flex;flex-direction:column;align-items:center;gap:12px;flex-shrink:0;}
.ring-container{position:relative;width:180px;height:180px;}
.ring-container svg{transform:rotate(-90deg);}
.ring-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.ring-pct{font-family:var(--mono);font-size:30px;font-weight:700;color:var(--gold);line-height:1;}
.ring-lbl{font-size:10px;color:var(--t3);letter-spacing:1px;text-transform:uppercase;margin-top:3px;}
.ring-sub{font-size:10px;color:var(--t3);text-align:center;letter-spacing:.5px;}
.ring-sub span{color:var(--gold);font-family:var(--mono);font-weight:700;}
.stat-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;}
.stat-card{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:18px;transition:all .3s cubic-bezier(.16,1,.3,1);animation:scIn .7s cubic-bezier(.16,1,.3,1) both;}
.stat-card:hover{transform:translateY(-3px);border-color:rgba(212,175,55,.25);box-shadow:0 10px 28px rgba(0,0,0,.28);}
@keyframes scIn{from{opacity:0;transform:translateY(18px) scale(.97);}to{opacity:1;transform:translateY(0) scale(1);}}
.stat-card:nth-child(1){animation-delay:.1s}.stat-card:nth-child(2){animation-delay:.18s}.stat-card:nth-child(3){animation-delay:.26s}.stat-card:nth-child(4){animation-delay:.34s}
.sc-icon{font-size:16px;margin-bottom:10px;}
.sc-label{font-size:10px;font-weight:800;letter-spacing:1.5px;color:var(--t3);text-transform:uppercase;margin-bottom:6px;}
.sc-val{font-family:var(--mono);font-size:24px;font-weight:700;line-height:1;}
.sc-sub{font-size:11px;color:var(--t3);margin-top:4px;}
.owed-strip{border-radius:12px;padding:14px 20px;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px;flex-wrap:wrap;}
.owed-strip.net-debt{background:linear-gradient(135deg,rgba(232,64,64,.06),rgba(232,64,64,.02));border:1px solid rgba(232,64,64,.18);}
.owed-strip.net-credit{background:linear-gradient(135deg,rgba(67,177,75,.06),rgba(67,177,75,.02));border:1px solid rgba(67,177,75,.18);}
.owed-strip.net-clear{background:var(--panel);border:1px solid var(--border);}
.owed-strip-left{display:flex;align-items:center;gap:12px;}
.owed-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;}
.owed-text .ot{font-size:12px;font-weight:700;}
.owed-text .os{font-size:11px;color:var(--t3);margin-top:2px;}
.owed-components{margin-top:4px;display:flex;align-items:center;}
.hours-acc-panel{margin-bottom:24px;border:1px solid var(--border);border-radius:12px;background:var(--panel);overflow:hidden;}
.hours-acc-summary{display:flex;align-items:center;gap:6px;padding:13px 18px;font-size:12px;font-weight:700;letter-spacing:1px;cursor:pointer;list-style:none;color:var(--t2);}
.hours-acc-summary::-webkit-details-marker{display:none;}
.hours-acc-arrow{margin-left:auto;font-size:11px;color:var(--t3);transition:transform .25s cubic-bezier(.16,1,.3,1);}
details[open] .hours-acc-arrow{transform:rotate(180deg);}
.hours-acc-body{padding:0 16px 16px;}
.has-title{font-size:11px;font-weight:700;color:var(--t3);letter-spacing:1px;text-transform:uppercase;margin-bottom:10px;display:flex;align-items:center;gap:6px;}
.has-subtitle{font-size:9px;font-weight:400;letter-spacing:0;color:var(--t3);text-transform:none;margin-left:4px;}
.owed-val{font-family:var(--mono);font-size:22px;font-weight:700;}
.req-leave-btn{display:flex;align-items:center;gap:8px;margin-bottom:28px;flex-wrap:wrap;}

/* ── CALENDAR ── */
.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.cal-month{font-family:var(--disp);font-size:16px;font-weight:700;letter-spacing:2px;color:var(--gold);}
.cal-arrow{width:32px;height:32px;border-radius:8px;background:var(--panel2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--t2);transition:all .2s;}
.cal-arrow:hover{border-color:var(--gold);color:var(--gold);}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;}
.cal-dow{text-align:center;font-size:10px;font-weight:800;letter-spacing:1.5px;color:var(--t3);text-transform:uppercase;padding:8px 0;}
.cal-day{min-height:62px;border-radius:9px;background:rgba(0,0,0,.18);border:1px solid var(--border);padding:6px;transition:all .2s;cursor:default;position:relative;}
.cal-day:hover{border-color:rgba(212,175,55,.2);}
.cal-day.today{border-color:rgba(212,175,55,.4);background:rgba(212,175,55,.04);}
.cal-day.empty{background:transparent;border-color:transparent;}
.cal-day-num{font-size:11px;font-weight:700;color:var(--t2);margin-bottom:4px;font-family:var(--mono);}
.cal-day.today .cal-day-num{color:var(--gold);}
.cal-pip{width:100%;font-size:9px;font-weight:700;border-radius:4px;padding:2px 4px;margin-bottom:2px;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;letter-spacing:.3px;}
.cal-ph{display:flex;align-items:center;gap:3px;font-size:9px;color:var(--gold);font-weight:700;background:rgba(212,175,55,.1);border:1px solid rgba(212,175,55,.2);border-radius:4px;padding:2px 4px;margin-bottom:2px;}
.cal-legend{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px;}
.cal-leg-item{display:flex;align-items:center;gap:5px;font-size:10px;color:var(--t2);}
.cal-leg-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}

/* ── MY REQUESTS TABLE ── */
.req-filter-tabs{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap;}
.rtab{padding:7px 14px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--t3);font-size:10px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;cursor:pointer;transition:all .2s;}
.rtab.active{background:var(--gdim);border-color:rgba(212,175,55,.3);color:var(--gold);}
.rtab:hover:not(.active){border-color:rgba(212,175,55,.2);color:var(--t2);}
.dtbl{width:100%;border-collapse:collapse;font-size:12px;}
.dtbl thead tr{background:rgba(0,0,0,.3);border-bottom:1px solid var(--border);}
.dtbl th{padding:12px 14px;text-align:left;font-size:11px;font-weight:800;letter-spacing:1.5px;color:var(--gold);text-transform:uppercase;white-space:nowrap;}
.dtbl td{padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.03);vertical-align:middle;}
.dtbl tbody tr:hover{background:rgba(255,255,255,.02);}
.dtbl tbody tr:last-child td{border-bottom:none;}
.status-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:9px;font-weight:800;letter-spacing:1px;text-transform:uppercase;}
.sb-pending{background:rgba(212,175,55,.12);color:var(--gold);border:1px solid rgba(212,175,55,.3);}
.sb-approved{background:rgba(67,177,75,.12);color:var(--green);border:1px solid rgba(67,177,75,.3);}
.sb-declined{background:rgba(232,64,64,.12);color:var(--red);border:1px solid rgba(232,64,64,.3);}
.sb-cancelled{background:rgba(255,255,255,.06);color:var(--t3);border:1px solid rgba(255,255,255,.1);}
.sb-escalated{background:rgba(255,140,0,.12);color:#FF8C00;border:1px solid rgba(255,140,0,.3);}
.tbl-empty{text-align:center;padding:40px;color:var(--t3);font-size:12px;}

/* ── LEAVE GUIDE ACCORDION ── */
.acc-item{border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:8px;transition:border-color .2s;}
.acc-item.open{border-color:rgba(212,175,55,.22);}
.acc-hdr{display:flex;align-items:center;gap:12px;padding:14px 16px;cursor:pointer;background:var(--panel);transition:background .2s;}
.acc-hdr:hover{background:var(--panel2);}
.acc-type-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.acc-name{font-size:13px;font-weight:700;flex:1;}
.acc-code{font-family:var(--mono);font-size:10px;color:var(--t3);letter-spacing:1px;}
.acc-arrow{color:var(--t3);transition:transform .3s;font-size:11px;}
.acc-item.open .acc-arrow{transform:rotate(180deg);}
.acc-body{display:none;padding:16px;border-top:1px solid var(--border);background:rgba(0,0,0,.12);}
.acc-item.open .acc-body{display:block;animation:accOpen .25s ease;}
@keyframes accOpen{from{opacity:0;transform:translateY(-6px);}to{opacity:1;transform:translateY(0);}}
.acc-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px;}
.acc-info-item label{font-size:9px;font-weight:800;letter-spacing:1.5px;color:var(--t3);text-transform:uppercase;display:block;margin-bottom:3px;}
.acc-info-item p{font-size:12px;color:var(--text);}

/* ── ADMIN PANEL ── */
.admin-tabs{display:flex;gap:6px;margin-bottom:20px;flex-wrap:wrap;}
.atab{padding:8px 16px;border-radius:9px;border:1px solid var(--border);background:transparent;color:var(--t3);font-size:10px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;cursor:pointer;transition:all .2s;}
.atab.active{background:var(--gdim);border-color:rgba(212,175,55,.3);color:var(--gold);}
.atab:hover:not(.active){color:var(--t2);}
.admin-sub{display:none;}
.admin-sub.active{display:block;animation:cvIn .4s cubic-bezier(.16,1,.3,1) both;}
@keyframes cvIn{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);}}
.approval-card{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:18px;margin-bottom:12px;transition:border-color .25s;animation:scIn .6s cubic-bezier(.16,1,.3,1) both;}
.approval-card:hover{border-color:rgba(212,175,55,.18);}
.appr-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px;flex-wrap:wrap;}
.appr-name{font-size:14px;font-weight:700;margin-bottom:2px;}
.appr-meta{font-size:11px;color:var(--t3);letter-spacing:.4px;}
.appr-type-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:20px;font-size:10px;font-weight:800;letter-spacing:.8px;}
.appr-dates{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px;background:rgba(0,0,0,.2);border-radius:10px;padding:12px;}
.appr-date-item label{font-size:9px;color:var(--t3);letter-spacing:1.5px;text-transform:uppercase;font-weight:800;display:block;margin-bottom:3px;}
.appr-date-item p{font-size:12px;font-family:var(--mono);font-weight:700;}
.appr-actions{display:flex;gap:8px;flex-wrap:wrap;}
.appr-empty{text-align:center;padding:50px 20px;color:var(--t3);}
.appr-empty i{font-size:32px;margin-bottom:12px;display:block;color:rgba(212,175,55,.2);}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.ig label{display:block;font-size:8.5px;font-weight:800;letter-spacing:2px;color:var(--gold);text-transform:uppercase;margin-bottom:5px;}
.settings-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border);}
.settings-row:last-child{border-bottom:none;}
.settings-row .sr-left .sr-title{font-size:13px;font-weight:600;}
.settings-row .sr-left .sr-desc{font-size:11px;color:var(--t3);margin-top:2px;}
.toggle-switch{position:relative;width:42px;height:24px;cursor:pointer;}
.toggle-switch input{opacity:0;width:0;height:0;}
.toggle-track{position:absolute;inset:0;background:rgba(255,255,255,.08);border:1px solid var(--border);border-radius:12px;transition:all .3s;}
.toggle-thumb{position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:var(--t3);transition:all .3s;}
.toggle-switch input:checked + .toggle-track{background:var(--gndim);border-color:rgba(67,177,75,.4);}
.toggle-switch input:checked ~ .toggle-thumb{left:21px;background:var(--green);}

/* ── MODALS ── */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.88);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);z-index:100000;display:none;align-items:center;justify-content:center;padding:16px;}
.modal-bg.show{display:flex;}
.modal-box{width:100%;max-width:560px;background:var(--lift);border:1px solid var(--bord2);border-radius:22px;padding:32px;box-shadow:0 40px 80px rgba(0,0,0,.6);animation:mpop .4s cubic-bezier(.175,.885,.32,1.275);max-height:calc(100dvh - 32px);overflow-y:auto;}
.modal-box.modal-lg{max-width:700px;}
@keyframes mpop{from{transform:scale(.88);opacity:0;}to{transform:scale(1);opacity:1;}}
.modal-box::before{content:'';display:block;width:120px;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:0 auto 24px;}
.modal-title{font-family:var(--disp);font-size:16px;font-weight:700;letter-spacing:3px;text-align:center;margin-bottom:6px;}
.modal-sub{font-size:11px;color:var(--t3);text-align:center;letter-spacing:.5px;margin-bottom:24px;}
.modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:50%;background:var(--panel2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--t3);font-size:12px;transition:all .2s;}
.modal-close:hover{border-color:var(--red);color:var(--red);}
.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:22px;padding-top:18px;border-top:1px solid var(--border);}
.wz-pane .modal-footer{position:sticky;bottom:-32px;background:var(--lift);margin:0 -32px -32px;padding:18px 32px 32px;z-index:2;}

/* ── WIZARD ── */
.wizard-steps{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:28px;}
.wz-step{display:flex;flex-direction:column;align-items:center;gap:5px;position:relative;}
.wz-dot{width:32px;height:32px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:var(--t3);transition:all .35s;background:var(--panel2);}
.wz-step.active .wz-dot{border-color:var(--gold);color:var(--gold);background:var(--gdim);box-shadow:0 0 14px rgba(212,175,55,.2);}
.wz-step.done .wz-dot{border-color:var(--green);color:var(--green);background:var(--gndim);}
.wz-label{font-size:9px;font-weight:800;letter-spacing:1.2px;color:var(--t3);text-transform:uppercase;}
.wz-step.active .wz-label{color:var(--gold);}
.wz-line{width:60px;height:2px;background:var(--border);margin-bottom:20px;transition:background .35s;}
.wz-line.done{background:rgba(67,177,75,.4);}
.wz-pane{display:none;}
.wz-pane.active{display:block;animation:cvIn .3s ease both;}

/* Leave type selection grid */
.lt-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
.lt-card{padding:14px;border-radius:12px;border:1px solid var(--border);background:var(--panel);cursor:pointer;transition:all .25s;display:flex;align-items:center;gap:11px;}
.lt-card:hover{border-color:rgba(212,175,55,.2);transform:translateY(-1px);}
.lt-card.selected{border-color:var(--gold);background:var(--gdim);box-shadow:0 0 14px rgba(212,175,55,.08);}
.lt-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;}
.lt-name{font-size:12px;font-weight:700;margin-bottom:1px;}
.lt-code{font-size:9px;color:var(--t3);font-family:var(--mono);letter-spacing:1px;}
.lt-desc{font-size:11px;color:var(--t3);line-height:1.55;margin-top:10px;padding:12px;background:rgba(0,0,0,.2);border-radius:9px;border:1px solid var(--border);}
.hours-calc{background:var(--gdim);border:1px solid rgba(212,175,55,.25);border-radius:11px;padding:14px 16px;margin-top:14px;}
.hc-row{display:flex;justify-content:space-between;align-items:center;font-size:12px;padding:3px 0;}
.hc-row .hk{color:var(--t2);}
.hc-row .hv{font-family:var(--mono);font-weight:700;color:var(--gold);}
.hc-row.warn .hv{color:var(--red);}
.confirm-summary{background:rgba(0,0,0,.2);border:1px solid var(--border);border-radius:12px;padding:16px;}
.cs-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:12px;}
.cs-row:last-child{border-bottom:none;}
.cs-row .ck{color:var(--t3);}
.cs-row .cv{font-weight:700;}

/* ── SKEL ── */
.skel{background:linear-gradient(90deg,rgba(255,255,255,.04) 25%,rgba(255,255,255,.08) 50%,rgba(255,255,255,.04) 75%);background-size:400% 100%;animation:shim 1.5s infinite;border-radius:7px;}
@keyframes shim{from{background-position:100% 0;}to{background-position:-100% 0;}}

/* ── SECTION SPACING ── */
.lv-section{margin-bottom:36px;animation:cvIn .5s cubic-bezier(.16,1,.3,1) both;}

/* ── MOBILE ── */
@media(max-width:820px){
  #lv-main{padding:20px 16px 60px;}
  .overview-grid{grid-template-columns:1fr;}
  .ring-wrap{flex-direction:row;justify-content:center;}
  .stat-cards{grid-template-columns:repeat(2,1fr);}
  .form-grid{grid-template-columns:1fr;}
  .hdr-clock{display:none;}
  .brand-sub{display:none;}
  .page-title-pill{display:none;}
  .appr-dates{grid-template-columns:1fr 1fr;}
  .acc-grid{grid-template-columns:1fr;}
}
@media(max-width:540px){
  #lv-hdr{padding:0 14px;height:56px;}
  #lv-main{padding:14px 10px 60px;}
  .back-btn span{display:none;}
  .brand-logo{font-size:18px;letter-spacing:5px;}
  .stat-cards{grid-template-columns:1fr;}
  .ring-container{width:150px;height:150px;}
  .ring-pct{font-size:24px;}
  .lt-grid{grid-template-columns:1fr;}
  .appr-dates{grid-template-columns:1fr;}
  .modal-box{padding:22px 16px;}
  .wz-pane .modal-footer{bottom:-22px;margin:0 -16px -22px;padding:14px 16px 22px;}
  .wz-line{width:36px;}
  #toast{left:10px;right:10px;transform:translateY(80px);min-width:unset;width:auto;max-width:none;}
  #toast.show{transform:translateY(0);}
  .hdr-notif-dd{width:calc(100vw - 16px);right:-50px;}
  .dtbl th,.dtbl td{padding:9px 8px;}
  .dtbl{font-size:11px;}
}
@media(max-width:400px){
  .stat-cards{grid-template-columns:1fr;}
  .admin-tabs{gap:4px;}
  .atab{padding:6px 10px;font-size:9px;}
}

/* ── HR ANALYTICS ── */
.analytics-alert{border-radius:12px;padding:16px 18px;margin-bottom:14px;}
.analytics-alert.danger{background:rgba(232,64,64,.06);border:1px solid rgba(232,64,64,.2);}
.analytics-alert.warn{background:rgba(255,140,0,.06);border:1px solid rgba(255,140,0,.2);}
.analytics-alert.ok{background:rgba(67,177,75,.06);border:1px solid rgba(67,177,75,.2);}
.analytics-alert-title{font-size:11px;font-weight:800;letter-spacing:2px;text-transform:uppercase;margin-bottom:10px;}
.analytics-charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;}
.sl-bar-wrap{margin-bottom:14px;}
.sl-bar-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px;}
.sl-bar-track{height:7px;background:rgba(255,255,255,.06);border-radius:10px;overflow:hidden;}
.sl-bar-fill{height:100%;border-radius:10px;transition:width 1.2s cubic-bezier(.16,1,.3,1);}
.flag-chip{display:inline-flex;align-items:center;gap:4px;background:rgba(232,64,64,.15);color:var(--red);border:1px solid rgba(232,64,64,.3);border-radius:10px;padding:2px 8px;font-size:9px;font-weight:800;letter-spacing:.8px;margin-left:8px;}
.warn-chip{display:inline-flex;align-items:center;gap:4px;background:rgba(255,140,0,.15);color:#FF8C00;border:1px solid rgba(255,140,0,.3);border-radius:10px;padding:2px 8px;font-size:9px;font-weight:800;letter-spacing:.8px;margin-left:8px;}
.chart-box{position:relative;padding:20px;height:280px;}
@media(max-width:820px){
  .analytics-charts-grid{grid-template-columns:1fr;}
}
/* ── LIGHT THEME ── */
[data-theme="light"]{--void:#ffffff;--deep:#f4f6f4;--base:#e8ede8;--lift:#dce4dc;--panel:rgba(4,80,30,0.05);--panel2:rgba(4,80,30,0.09);--border:rgba(4,80,30,0.16);--bord2:rgba(4,80,30,0.26);--gold:#04501e;--gold2:#065a23;--gdim:rgba(4,80,30,0.10);--gglow:rgba(4,80,30,0.22);--gsoft:rgba(4,80,30,0.04);--green:#43b14b;--gndim:rgba(67,177,75,0.12);--gnsoft:rgba(67,177,75,0.05);--red:#c42020;--rdim:rgba(196,32,32,0.10);--text:#000000;--t2:rgba(0,0,0,0.80);--t3:rgba(0,0,0,0.52);}
[data-theme="light"] body{background:#ffffff;}[data-theme="light"] body::before{display:none;}
[data-theme="light"] #lv-hdr{background:rgba(255,255,255,0.96)!important;border-color:rgba(4,80,30,0.14)!important;}
[data-theme="light"] .glass,[data-theme="light"] .lv-section{background:rgba(255,255,255,0.88)!important;border-color:rgba(4,80,30,0.13)!important;}
[data-theme="light"] input.gi,[data-theme="light"] textarea.gi,[data-theme="light"] select.gi{background:rgba(255,255,255,0.85)!important;border-color:rgba(4,80,30,0.20)!important;color:#000!important;}
[data-theme="light"] .btn-green{background:#43b14b;}[data-theme="light"] .btn-gold{background:#04501e;color:#fff;}
/* TEST MODE BANNER */
#test-mode-banner{display:none;position:fixed;top:0;left:0;right:0;height:36px;z-index:999999;background:linear-gradient(90deg,rgba(160,0,0,.97),rgba(220,40,40,.97));border-bottom:2px solid rgba(255,100,100,.5);align-items:center;justify-content:center;gap:12px;font-size:10px;font-weight:900;letter-spacing:2px;color:#fff;text-transform:uppercase;backdrop-filter:blur(10px);}
#test-mode-banner.show{display:flex;animation:tmBIn .45s cubic-bezier(.16,1,.3,1) both;}
@keyframes tmBIn{from{transform:translateY(-100%);opacity:0;}to{transform:translateY(0);opacity:1;}}
.test-toggle-btn{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.45);color:#fff;padding:4px 14px;border-radius:20px;cursor:pointer;font-size:9px;font-weight:900;letter-spacing:1.5px;white-space:nowrap;transition:background .2s,transform .2s;}
.test-toggle-btn:hover{background:rgba(255,255,255,.32);transform:scale(1.05);}
/* MAINTENANCE BANNER */
#maint-banner{display:none;position:fixed;top:0;left:0;right:0;height:36px;z-index:999998;background:linear-gradient(90deg,rgba(180,120,0,.97),rgba(220,160,0,.97));border-bottom:2px solid rgba(255,200,50,.5);align-items:center;justify-content:center;gap:12px;font-size:10px;font-weight:900;letter-spacing:2px;color:#fff;text-transform:uppercase;backdrop-filter:blur(10px);}
#maint-banner.show{display:flex;animation:tmBIn .45s cubic-bezier(.16,1,.3,1) both;}
.maint-toggle-btn{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.45);color:#fff;padding:4px 14px;border-radius:20px;cursor:pointer;font-size:9px;font-weight:900;letter-spacing:1.5px;white-space:nowrap;transition:background .2s,transform .2s;}
.maint-toggle-btn:hover{background:rgba(255,255,255,.32);transform:scale(1.05);}
/* MAINTENANCE OVERLAY (blocks non-SA) */
#maint-overlay{display:none;position:fixed;inset:0;z-index:999997;background:rgba(5,9,5,.96);align-items:center;justify-content:center;flex-direction:column;gap:16px;color:#fff;text-align:center;padding:32px;}
#maint-overlay.show{display:flex;}
#maint-overlay i{font-size:48px;color:var(--gold);margin-bottom:8px;}
#maint-overlay h2{font-family:var(--disp);font-size:28px;letter-spacing:4px;margin:0;}
#maint-overlay p{color:rgba(255,255,255,.6);font-size:13px;max-width:440px;line-height:1.7;}
/* Layout push when banners active */
body.test-mode #root{margin-top:36px;}
body.maint-mode.test-mode #root{margin-top:72px;}
body.maint-mode:not(.test-mode) #root{margin-top:36px;}

/* ── LEAVE — extra mobile fixes ── */
@media(max-width:820px){
  #lv-hdr{padding:0 18px;}
  .notif-dd{width:280px;}
}
@media(max-width:540px){
  .modal-box,.wz-box{max-width:calc(100vw - 24px)!important;padding:20px 16px!important;border-radius:14px!important;}
  .cal-grid{grid-template-columns:repeat(7,1fr);font-size:10px;}
  .cal-day{min-height:32px;font-size:9px;padding:2px;}
  .notif-dd{width:calc(100vw - 32px);right:-8px;}
  .lv-balance-strip,.balance-row{flex-wrap:wrap;gap:8px;}
  .stat-card{min-width:0;flex:1 1 calc(50% - 8px);}
}
@media(max-width:400px){
  .cal-grid{font-size:8px;}
  .cal-day{min-height:28px;padding:1px;}
  .stat-card{flex:1 1 100%;}
  #lv-hdr{padding:0 12px;}
  .lv-nav-item{padding:0 10px;font-size:9px;}
}
/* ── Touch targets + table scroll ── */
@media(max-width:640px){
  .btn,.btn-green,.btn-gold,.btn-red,.btn-outline{min-height:44px;}
  .rota-scroll,.table-scroll,.dtbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
}
