/* ═══════════════════════════════════════════════════════════
   CyberOath EMS — Professional LMS Theme
   Link in HTML: <link rel="stylesheet" href="style.css">
═══════════════════════════════════════════════════════════ */

/* ROOT VARS & RESET - Professional LMS Theme */
:root{
  --bg:#f5f7fa; --bg2:#ffffff; --panel:#ffffff; --panel2:#f8fafb;
  --border:#e0e8f0; --border2:#d0dce9;
  --primary:#2563eb; --primary-light:#3b82f6; --primary-dark:#1e40af;
  --success:#10b981; --warning:#f59e0b; --danger:#ef4444;
  --info:#06b6d4; --purple:#8b5cf6;
  --text:#1f2937; --text2:#4b5563; --text3:#9ca3af;
  --font-main: -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue", sans-serif;
  --shadow: 0 1px 3px rgba(0,0,0,0.08), 0 1px 2px rgba(0,0,0,0.05);
  --shadow-md: 0 4px 6px rgba(0,0,0,0.1), 0 2px 4px rgba(0,0,0,0.06);
  --shadow-lg: 0 10px 25px rgba(0,0,0,0.1), 0 5px 10px rgba(0,0,0,0.05);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--font-main);min-height:100vh;overflow-x:hidden;line-height:1.6}

/* grid bg */
body::before{content:"";position:fixed;inset:0;
  background-image:linear-gradient(rgba(37,99,235,.02) 1px,transparent 1px),
  linear-gradient(90deg,rgba(37,99,235,.02) 1px,transparent 1px);
  background-size:50px 50px;pointer-events:none;z-index:0;opacity:0.5}

/* LANDING */
#landing{position:fixed;inset:0;z-index:2000;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f7fa 0%,#e8ecf5 100%);background-attachment:fixed;}
#landing::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 80% 80% at 50% 30%,rgba(37,99,235,.06) 0%,transparent 70%);pointer-events:none}
.land-logo{margin-bottom:40px;text-align:center;position:relative}
.land-logo img{height:80px;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(37,99,235,.15))}
.land-logo p{font-family:var(--font-main);font-size:14px;color:var(--text);letter-spacing:1px;margin-top:16px;text-transform:uppercase;font-weight:600;font-weight:300}
.land-tagline{font-family:var(--font-main);font-size:28px;color:var(--text);letter-spacing:0.5px;margin-bottom:60px;text-transform:none;font-weight:600}
.role-cards{display:flex;gap:28px;position:relative;z-index:1}
.role-card{width:280px;padding:40px 32px;background:var(--panel);border:1px solid var(--border);border-radius:12px;text-align:center;cursor:pointer;transition:all .3s;position:relative;overflow:hidden;box-shadow:var(--shadow-md)}
.role-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;transition:opacity .3s}
.role-card:nth-child(1)::before{background:linear-gradient(90deg,var(--primary),var(--info))}
.role-card:nth-child(2)::before{background:linear-gradient(90deg,var(--purple),var(--danger))}
.role-card:hover{transform:translateY(-8px);border-color:var(--primary);box-shadow:0 12px 32px rgba(37,99,235,.15)}
.role-card-icon{font-size:56px;margin-bottom:16px;display:block}
.role-card-title{font-family:var(--font-main);font-size:20px;font-weight:700;letter-spacing:0px;text-transform:uppercase;margin-bottom:12px}
.role-card:nth-child(1) .role-card-title{color:var(--primary)}
.role-card:nth-child(2) .role-card-title{color:var(--purple)}
.role-card-desc{font-family:var(--font-main);font-size:13px;color:var(--text3);letter-spacing:0px;line-height:1.7}

/* LOGIN MODAL */
#loginModal{display:none;position:fixed;inset:0;z-index:2100;align-items:center;justify-content:center;background:rgba(0,0,0,.4);backdrop-filter:blur(6px)}
#loginModal.open{display:flex}
.login-box{width:420px;background:var(--panel);border-radius:12px;position:relative;overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid var(--border)}
.login-box::before{content:"";position:absolute;top:0;left:0;right:0;height:3px}
.login-box:nth-of-type(1)::before{background:linear-gradient(90deg,var(--primary),var(--info))}
.login-box.emp-login::before{background:linear-gradient(90deg,var(--primary),var(--info))}
.login-box.adm-login::before{background:linear-gradient(90deg,var(--purple),var(--danger))}
.lb-head{padding:32px 28px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:16px;background:linear-gradient(135deg,rgba(37,99,235,.02),rgba(139,92,246,.02))}
.lb-icon{font-size:32px}
.lb-title{font-family:var(--font-main);font-size:22px;font-weight:700;letter-spacing:0px;text-transform:capitalize}
.login-box.emp-login .lb-title{color:var(--primary)}
.login-box.adm-login .lb-title{color:var(--purple)}
.lb-body{padding:28px}
.fg{margin-bottom:18px}
.pw-wrap,.time-wrap{position:relative;display:flex;align-items:center}
.pw-wrap input,.time-wrap input{padding-right:84px}
.pw-toggle,.time-trigger,.time-clear{position:absolute;top:50%;transform:translateY(-50%);border:none;background:transparent;font-size:16px;cursor:pointer;color:var(--text3);padding:8px;line-height:1;border-radius:4px;transition:all .2s}
.pw-toggle{right:8px}
.time-trigger{right:34px}
.time-clear{right:8px}
.pw-toggle:hover,.time-trigger:hover,.time-clear:hover{background:rgba(37,99,235,.1);color:var(--primary)}
.fg label{display:block;font-family:var(--font-main);font-size:12px;color:var(--text2);letter-spacing:0.5px;text-transform:capitalize;margin-bottom:8px;font-weight:600}
.fg input,.fg select{width:100%;padding:12px 14px;background:var(--bg2);border:1.5px solid var(--border);border-radius:6px;color:var(--text);font-family:var(--font-main);font-size:14px;outline:none;transition:all .2s}
.fg input:focus,.fg select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.login-box.adm-login .fg input:focus{border-color:var(--purple);box-shadow:0 0 0 3px rgba(139,92,246,.1)}
.btn-submit{width:100%;padding:12px;border-radius:6px;font-family:var(--font-main);font-size:15px;font-weight:700;letter-spacing:0px;text-transform:uppercase;cursor:pointer;transition:all .2s;border:none;margin-top:8px;font-size:14px}
.emp-submit{background:linear-gradient(135deg,var(--primary),var(--primary-light));color:white}
.emp-submit:hover{background:linear-gradient(135deg,var(--primary-dark),var(--primary));box-shadow:0 4px 12px rgba(37,99,235,.3);transform:translateY(-2px)}
.adm-submit{background:linear-gradient(135deg,var(--purple),#a78bfa);color:white}
.adm-submit:hover{background:linear-gradient(135deg,#7c3aed,var(--purple));box-shadow:0 4px 12px rgba(139,92,246,.3);transform:translateY(-2px)}
.lb-hint{padding:14px 28px 20px;font-family:var(--font-main);font-size:12px;color:var(--text3);line-height:1.8}
.lb-back{padding:14px 28px 20px;display:flex;justify-content:center}
.lb-back button{background:none;border:none;color:var(--text3);font-family:var(--font-main);font-size:13px;cursor:pointer;letter-spacing:0px;transition:all .2s}
.lb-back button:hover{color:var(--primary)}

/* APP SHELL */
#app{display:none;position:relative;z-index:1}

/* TOPBAR */
.topbar{position:fixed;top:0;left:0;right:0;height:64px;background:var(--panel);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;z-index:100;box-shadow:var(--shadow-md);gap:16px}
.topbar::after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--primary),transparent);opacity:0.3}
.tb-logo img{height:36px;object-fit:contain}
.tb-divider{width:1px;height:28px;background:var(--border)}
.tb-role-badge{padding:6px 14px;border-radius:6px;font-family:var(--font-main);font-size:11px;font-weight:700;letter-spacing:0.5px;text-transform:uppercase}
.tb-role-badge.emp{background:linear-gradient(135deg,rgba(16,185,129,.1),rgba(6,182,212,.1));color:var(--success);border:1px solid rgba(16,185,129,.2)}
.tb-role-badge.adm{background:linear-gradient(135deg,rgba(139,92,246,.1),rgba(236,72,153,.1));color:var(--purple);border:1px solid rgba(139,92,246,.2)}
.tb-nav{flex:1;display:flex;justify-content:center;gap:2px}
.nb{padding:8px 18px;background:transparent;border:1px solid transparent;border-radius:6px;color:var(--text3);font-family:var(--font-main);font-size:13px;font-weight:600;letter-spacing:0px;text-transform:capitalize;cursor:pointer;transition:all .2s}
.nb:hover{color:var(--text);border-color:var(--border);background:rgba(37,99,235,.04)}
.nb.on{background:linear-gradient(135deg,rgba(16,185,129,.1),rgba(6,182,212,.1));color:var(--success);border-color:rgba(16,185,129,.3)}
.nb.on-blue{background:linear-gradient(135deg,rgba(139,92,246,.1),rgba(236,72,153,.1));color:var(--purple);border-color:rgba(139,92,246,.3)}
.tb-right{display:flex;align-items:center;gap:12px}
.notif-wrap{position:relative}
.notif-btn{width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;position:relative;border:1px solid var(--border);border-radius:10px;background:rgba(37,99,235,.04);color:var(--text);cursor:pointer;transition:all .2s;box-shadow:var(--shadow)}
.notif-btn:hover,.notif-wrap.open .notif-btn{border-color:rgba(37,99,235,.3);background:linear-gradient(135deg,rgba(37,99,235,.08),rgba(6,182,212,.08));color:var(--primary);transform:translateY(-1px)}
.notif-btn svg{width:20px;height:20px}
.notif-badge{position:absolute;top:-5px;right:-5px;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:linear-gradient(135deg,#ef4444,#f97316);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 18px rgba(239,68,68,.35)}
.notif-badge.hide{display:none}
.notif-panel{display:none;position:absolute;top:calc(100% + 12px);right:0;width:min(360px,calc(100vw - 24px));max-height:460px;background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,250,251,.98));border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:0 18px 48px rgba(15,23,42,.14);backdrop-filter:blur(14px)}
.notif-wrap.open .notif-panel{display:block}
.notif-head{padding:18px 18px 14px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:12px;background:linear-gradient(135deg,rgba(37,99,235,.05),rgba(139,92,246,.05))}
.notif-title{font-size:15px;font-weight:700;color:var(--text)}
.notif-sub{font-size:12px;color:var(--text3);margin-top:4px;line-height:1.5}
.notif-clear{padding:8px 12px;border:1px solid var(--border);border-radius:8px;background:rgba(255,255,255,.7);color:var(--text2);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}
.notif-clear:hover:not(:disabled){border-color:var(--primary);background:rgba(37,99,235,.08);color:var(--primary)}
.notif-clear:disabled{opacity:.45;cursor:not-allowed}
.notif-list{max-height:380px;overflow-y:auto;padding:8px}
.notif-empty{min-height:220px;display:flex;align-items:center;justify-content:center;padding:24px;text-align:center;color:var(--text3);font-size:15px;line-height:1.7}
.notif-item{width:100%;display:block;position:relative;margin-bottom:6px;padding:14px 14px 14px 16px;border:1px solid transparent;border-radius:12px;background:transparent;text-align:left;cursor:pointer;transition:all .2s}
.notif-item:last-child{margin-bottom:0}
.notif-item:hover{border-color:rgba(37,99,235,.16);background:rgba(37,99,235,.05);transform:translateY(-1px)}
.notif-item.unread{border-color:rgba(37,99,235,.2);background:linear-gradient(135deg,rgba(37,99,235,.08),rgba(6,182,212,.06))}
.notif-item.unread::before{content:"";position:absolute;left:8px;top:18px;width:8px;height:8px;border-radius:50%;background:var(--danger);box-shadow:0 0 0 4px rgba(239,68,68,.08)}
.notif-item-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-left:10px}
.notif-item-msg{margin-top:6px;padding-left:10px;color:var(--text);font-size:13px;line-height:1.5}
.notif-item-time{font-size:11px;color:var(--text3);white-space:nowrap}
.notif-item-type{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}
.notif-item-type.clockin{background:rgba(16,185,129,.12);color:var(--success)}
.notif-item-type.clockout{background:rgba(6,182,212,.12);color:var(--info)}
.notif-item-type.task{background:rgba(37,99,235,.12);color:var(--primary)}
.notif-item-type.log{background:rgba(245,158,11,.14);color:var(--warning)}
.notif-item-type.chat{background:rgba(139,92,246,.12);color:var(--purple)}
.tb-user{display:flex;align-items:center;gap:12px;padding:8px 14px;background:rgba(37,99,235,.04);border:1px solid var(--border);border-radius:8px}
.tb-user>div{min-width:0}
.tb-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--info));display:flex;align-items:center;justify-content:center;font-family:var(--font-main);font-size:13px;font-weight:700;color:white;box-shadow:var(--shadow)}
.tb-uname{font-size:13px;font-weight:600;color:var(--text);font-family:var(--font-main);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tb-urole{font-size:11px;color:var(--text3);font-family:var(--font-main);letter-spacing:0px}
.btn-logout{padding:8px 14px;background:transparent;border:1.5px solid var(--danger);border-radius:6px;color:var(--danger);font-family:var(--font-main);font-size:11px;letter-spacing:0px;cursor:pointer;transition:all .2s;font-weight:600}
.btn-logout:hover{background:rgba(239,68,68,.1);transform:translateY(-2px)}

/* DB STATUS */
.db-status{display:none !important;align-items:center;gap:6px;font-family:var(--font-main);font-size:11px;padding:6px 12px;border-radius:6px;border:1px solid;letter-spacing:0px;font-weight:600}
.db-status.online{color:var(--success);border-color:rgba(16,185,129,.2);background:rgba(16,185,129,.05)}
.db-status.offline{color:var(--warning);border-color:rgba(245,158,11,.2);background:rgba(245,158,11,.05)}
.db-dot{width:6px;height:6px;border-radius:50%;animation:blink 2s infinite}
.db-status.online .db-dot{background:var(--success)}
.db-status.offline .db-dot{background:var(--warning)}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.4}}

/* CONTENT */
.main{padding-top:64px;min-height:100vh;background:var(--bg)}
.page{display:none;padding:32px 28px;animation:fadeUp .3s ease}
.page.on{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* PAGE HEADER */
.ph{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:32px;padding-bottom:20px;border-bottom:2px solid var(--border)}
.ph-title{font-family:var(--font-main);font-size:28px;font-weight:700;letter-spacing:0px;color:var(--text);text-transform:capitalize}
.ph-title span{color:var(--primary)}
.ph-title span.blue{color:var(--primary)}
.ph-sub{font-family:var(--font-main);font-size:13px;color:var(--text3);letter-spacing:0px;margin-top:6px;font-weight:500}

/* STAT CARDS */
.sg{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:32px}
.sc{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:24px;position:relative;overflow:hidden;transition:all .3s;box-shadow:var(--shadow)}
.sc::before{content:"";position:absolute;top:0;left:0;right:0;height:4px}
.sc.g::before{background:linear-gradient(90deg,var(--success),var(--info))}
.sc.t::before{background:linear-gradient(90deg,var(--info),var(--primary))}
.sc.r::before{background:linear-gradient(90deg,var(--danger),var(--warning))}
.sc.a::before{background:linear-gradient(90deg,var(--warning),var(--danger))}
.sc.b::before{background:linear-gradient(90deg,var(--primary),var(--purple))}
.sc:hover{transform:translateY(-4px);border-color:var(--primary);box-shadow:var(--shadow-lg)}
.sc-icon{font-size:28px;margin-bottom:12px;display:inline-block}
.sc-val{font-family:var(--font-main);font-size:32px;font-weight:700;line-height:1;margin-bottom:6px;letter-spacing:-1px}
.sc.g .sc-val{color:var(--success)}.sc.t .sc-val{color:var(--info)}
.sc.r .sc-val{color:var(--danger)}.sc.a .sc-val{color:var(--warning)}.sc.b .sc-val{color:var(--primary)}
.sc-lbl{font-family:var(--font-main);font-size:13px;color:var(--text3);letter-spacing:0px;font-weight:600;text-transform:capitalize}

/* PANELS */
.panel{background:var(--panel);border:1px solid var(--border);border-radius:10px;overflow:hidden;margin-bottom:24px;box-shadow:var(--shadow)}
.phead{padding:18px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,rgba(37,99,235,.03),rgba(139,92,246,.03))}
.ptitle{font-family:var(--font-main);font-size:15px;font-weight:700;letter-spacing:0px;color:var(--text);text-transform:capitalize;display:flex;align-items:center;gap:10px}
.ptitle::before{content:"";width:3px;height:16px;background:var(--primary);display:inline-block;border-radius:2px}
.ptitle.blue-bar::before{background:var(--primary)}
.pbody{padding:24px}

/* TABLES */
.dt{width:100%;border-collapse:collapse}
.dt th{padding:12px 16px;text-align:left;font-family:var(--font-main);font-size:12px;color:var(--text2);letter-spacing:0.5px;text-transform:uppercase;border-bottom:2px solid var(--border);background:linear-gradient(135deg,rgba(37,99,235,.03),rgba(139,92,246,.03));font-weight:700}
.dt td{padding:14px 16px;font-size:14px;border-bottom:1px solid var(--border);color:var(--text2);vertical-align:middle}
.dt tr:hover td{background:rgba(37,99,235,.03)}
.dt tr:last-child td{border-bottom:none}

/* BADGES */
.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:4px;font-family:var(--font-main);font-size:11px;letter-spacing:0px;text-transform:capitalize;font-weight:600}
.badge::before{content:"";width:6px;height:6px;border-radius:50%}
.bg{background:rgba(16,185,129,.1);color:var(--success);border:1px solid rgba(16,185,129,.2)}.bg::before{background:var(--success)}
.bt{background:rgba(6,182,212,.1);color:var(--info);border:1px solid rgba(6,182,212,.2)}.bt::before{background:var(--info)}
.br{background:rgba(239,68,68,.1);color:var(--danger);border:1px solid rgba(239,68,68,.2)}.br::before{background:var(--danger)}
.ba{background:rgba(245,158,11,.1);color:var(--warning);border:1px solid rgba(245,158,11,.2)}.ba::before{background:var(--warning)}
.bb{background:rgba(37,99,235,.1);color:var(--primary);border:1px solid rgba(37,99,235,.2)}.bb::before{background:var(--primary)}

/* BUTTONS */
.btn{padding:10px 16px;border-radius:6px;font-family:var(--font-main);font-size:13px;font-weight:600;letter-spacing:0px;text-transform:capitalize;cursor:pointer;transition:all .2s;border:none;display:inline-flex;align-items:center;gap:6px;box-shadow:var(--shadow)}
.btn-g{background:linear-gradient(135deg,var(--success),var(--info));color:white}
.btn-g:hover{background:linear-gradient(135deg,#059669,#0891b2);box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.btn-b{background:linear-gradient(135deg,var(--primary),var(--purple));color:white}
.btn-b:hover{background:linear-gradient(135deg,#1e40af,#7c3aed);box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.btn-a{background:linear-gradient(135deg,var(--warning),var(--danger));color:white}
.btn-a:hover{background:linear-gradient(135deg,#d97706,#dc2626);box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.btn-r{background:linear-gradient(135deg,var(--danger),#f87171);color:white}
.btn-r:hover{background:linear-gradient(135deg,#991b1b,#b91c1c);box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.btn-ghost{background:transparent;border:1.5px solid var(--border);color:var(--text2)}
.btn-ghost:hover{background:rgba(37,99,235,.06);border-color:var(--primary);color:var(--text)}

/* FORMS */
.field{width:100%;padding:12px 14px;background:var(--bg2);border:1.5px solid var(--border);border-radius:6px;color:var(--text);font-family:var(--font-main);font-size:14px;outline:none;transition:all .2s}
.field:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.field-lbl{display:block;font-family:var(--font-main);font-size:12px;color:var(--text2);letter-spacing:0.5px;text-transform:capitalize;margin-bottom:6px;font-weight:600}
.word-count{font-size:11px;color:var(--text3);margin-left:8px;font-weight:normal;text-transform:none;letter-spacing:0px}
.fgroup{margin-bottom:16px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.frow3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
textarea.field{resize:vertical;min-height:75px;font-family:var(--font-main)}

.date-wrap{display:flex;align-items:center;gap:6px;position:relative}
.date-btn{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border:1.5px solid var(--border);background:var(--bg2);color:var(--text);border-radius:6px;cursor:pointer;font-size:16px;line-height:1;transition:all .2s}
.date-btn::before{content:'📅';}
.date-btn:hover{background:rgba(37,99,235,.08);border-color:var(--primary)}
.date-wrap .field{flex:1}
.date-wrap input[type="date"]::-webkit-calendar-picker-indicator{opacity:0;display:none}
.date-popover{position:fixed;z-index:5000;width:246px;background:#fff;border:1px solid #b9b9b9;border-radius:0;box-shadow:0 12px 28px rgba(15,23,42,.22);padding:14px 12px 12px;color:#111;font-family:Arial,"Segoe UI",sans-serif}
.date-pop-head{display:grid;grid-template-columns:1fr 34px 34px;align-items:center;gap:4px;margin-bottom:14px}
.date-month-label{justify-self:start;border:0;background:transparent;color:#000;font-size:14px;font-weight:700;cursor:pointer;padding:2px 0}
.date-month-label::after{content:"";display:inline-block;margin-left:4px;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid #111;vertical-align:middle}
.date-month-btn{width:28px;height:28px;border:0;background:transparent;color:#1f2937;font-size:25px;line-height:1;cursor:pointer;font-weight:300}
.date-month-btn:hover,.date-month-label:hover{color:var(--primary)}
.date-weekdays,.date-days{display:grid;grid-template-columns:repeat(7,1fr);text-align:center}
.date-weekdays{margin-bottom:6px}
.date-weekdays span{font-size:14px;color:#000;line-height:24px;font-weight:400}
.date-day{width:30px;height:30px;margin:1px auto;border:0;background:transparent;border-radius:0;color:#111;font-size:14px;line-height:30px;text-align:center;cursor:pointer}
.date-day.muted{color:#aeb6bf}
.date-day.today{box-shadow:inset 0 0 0 1px rgba(37,99,235,.35)}
.date-day.selected{background:#0b7cff;color:#fff;font-weight:700;box-shadow:inset 0 0 0 2px #005fcc}
.date-day:not(:disabled):hover{background:#e8f1ff;color:#0b4ea2}
.date-day.selected:hover{background:#0b7cff;color:#fff}
.date-day:disabled{color:#d5dbe3;cursor:not-allowed}
.date-pop-foot{display:flex;justify-content:space-between;margin-top:12px;padding:0 12px 2px}
.date-pop-foot button{border:0;background:transparent;color:#06f;font-size:14px;cursor:pointer;padding:4px 0}
.date-pop-foot button:hover{text-decoration:underline}

.cal-nav-wrapper{margin-bottom:20px}
.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;padding:0 4px}
.cal-nav span{font-family:var(--font-main);font-size:20px;font-weight:700;color:var(--text);letter-spacing:0px}
.cal-legend{padding:10px 14px;background:linear-gradient(135deg,rgba(37,99,235,.05),rgba(139,92,246,.05));border:1px solid var(--border);border-radius:6px;font-family:var(--font-main);font-size:11px;color:var(--text3);letter-spacing:0px;text-align:center}
.cal-grid-head{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;font-family:var(--font-main);font-size:13px;font-weight:700;color:var(--text2);margin-bottom:12px;padding:10px 0;border-bottom:2px solid var(--border);letter-spacing:0px}
.cal-grid-head span.sunday { color: var(--danger); font-weight:700; }
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}
.cal-cell{min-height:100px;border:1.5px solid var(--border);border-radius:8px;padding:12px;font-family:var(--font-main);font-size:12px;background:var(--panel);color:var(--text2);cursor:pointer;transition:all .3s;position:relative;overflow:hidden;box-shadow:var(--shadow)}
.cal-cell:hover{transform:translateY(-4px);border-color:var(--primary);box-shadow:var(--shadow-lg)}
.cal-cell.empty{background:transparent;border:0;cursor:default;box-shadow:none}
.cal-cell.empty:hover{transform:none;box-shadow:none;border-color:transparent}
.cal-cell.leave{background:linear-gradient(135deg,rgba(245,158,11,.05),rgba(139,92,246,.05));border-color:rgba(245,158,11,.3)}
.cal-cell.leave:hover{border-color:var(--warning);box-shadow:var(--shadow-lg)}
.cal-cell.sunday{background:linear-gradient(135deg,rgba(239,68,68,.04),rgba(249,115,115,.04));border-color:rgba(239,68,68,.25)}
.cal-cell.sunday:hover{border-color:var(--danger);box-shadow:var(--shadow-lg)}
.cal-num{font-weight:700;color:var(--text);font-size:14px;margin-bottom:6px}
.cal-num.sunday{color:var(--danger)}
.cal-day{font-size:11px;color:var(--text3);margin-top:4px;line-height:1.4}
.cal-day.sunday{color:var(--text3)}
.cal-day-sunday{font-size:11px;color:var(--text3);margin-top:4px;line-height:1.4}
.cal-sunday-badge{font-size:10px;color:var(--danger);background:rgba(239,68,68,.08);padding:4px 6px;border-radius:4px;margin:4px 0;font-weight:700;letter-spacing:0px;text-align:center;border:1px solid rgba(239,68,68,.15)}
.cal-leave{font-size:11px;color:var(--warning);margin-top:4px;font-weight:600}
.cal-tasks{font-size:11px;color:var(--primary);margin-top:4px}
.cal-hours{font-size:11px;color:var(--success);margin-top:4px;font-weight:600}

/* GRID HELPERS */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}
.flex-b{display:flex;align-items:center;justify-content:space-between}
.flex-g{display:flex;align-items:center;gap:10px}
.mb3{margin-bottom:12px}
.mb4{margin-bottom:16px}
.tag{display:inline-block;padding:2px 7px;background:rgba(0,255,136,.07);border:1px solid rgba(0,255,136,.14);border-radius:2px;font-family:var(--font-main);font-size:9px;color:var(--green);letter-spacing:1px;margin:2px}

/* SEARCH */
.srch{flex:1;padding:9px 14px;background:var(--panel);border:1px solid var(--border2);border-radius:3px;color:var(--text);font-family:var(--font-main);font-size:12px;outline:none}
.srch:focus{border-color:var(--green)}
.srch::placeholder{color:var(--text3)}
.sbar{display:flex;gap:10px;margin-bottom:16px;align-items:center}

/* PROGRESS */
.prog{height:5px;background:var(--bg2);border-radius:3px;overflow:hidden}
.prog-fill{height:100%;border-radius:3px;transition:width .5s}
.pf-g{background:var(--green)}.pf-t{background:var(--teal)}.pf-a{background:var(--amber)}

/* INFO ROW */
.ir{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid rgba(22,48,32,.2);font-size:12px}
.ir:last-child{border-bottom:none}
.ik{color:var(--text3);font-family:var(--font-main);font-size:10px;letter-spacing:1px}
.iv{color:var(--text)}

/* CLOCK PAGE */
.clock-card{background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(244,247,255,.99));border:1px solid rgba(59,130,246,.14);border-radius:24px;padding:40px 32px;text-align:center;position:relative;overflow:hidden;margin-bottom:20px;box-shadow:0 18px 70px rgba(15,23,42,.08)}
.clock-card::before{content:"";position:absolute;top:0;left:20px;right:20px;height:3px;background:linear-gradient(90deg,rgba(59,130,246,.15),rgba(139,92,246,.6),rgba(59,130,246,.15));border-radius:999px}
.clock-card::after{content:"";position:absolute;top:18%;left:50%;width:420px;height:420px;transform:translateX(-50%);background:radial-gradient(circle at center,rgba(59,130,246,.08),transparent 60%);pointer-events:none}
.clk-emp{font-family:var(--font-main);font-size:22px;font-weight:700;color:var(--text);letter-spacing:0.5px;margin-bottom:4px}
.clk-role{font-family:var(--font-main);font-size:11px;color:var(--text3);letter-spacing:2px;text-transform:uppercase;margin-bottom:18px}
.ring-wrap{width:250px;height:250px;margin:0 auto 18px;position:relative;display:flex;align-items:center;justify-content:center}
.ring-spin{position:absolute;inset:0;border-radius:50%;border:3px solid transparent;border-top-color:rgba(59,130,246,.85);border-right-color:rgba(59,130,246,.25);transition:all .5s}
.ring-spin.running{animation:rspin 2.5s linear infinite;box-shadow:0 0 30px rgba(59,130,246,.18)}
.ring-spin.done{border-top-color:rgba(16,185,129,.85);border-right-color:rgba(16,185,129,.25);box-shadow:0 0 30px rgba(16,185,129,.18)}
@keyframes rspin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.ring-mid{position:absolute;inset:16px;border-radius:50%;border:1px dashed rgba(59,130,246,.18)}
.ring-in{position:absolute;inset:24px;border-radius:50%;border:1px solid rgba(59,130,246,.12);background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(6px)}
.wall-time{font-family:'Share Tech Mono',monospace;font-size:34px;color:#111;letter-spacing:2px;text-shadow:none;line-height:1}
.wall-ampm{font-family:var(--font-main);font-size:12px;color:var(--text3);letter-spacing:2px;margin-top:6px}
.wall-date{font-family:var(--font-main);font-size:11px;color:var(--text3);letter-spacing:1px;margin-top:8px;text-transform:uppercase}
.sess-wrap{margin:4px 0 24px;position:relative;z-index:1}
.sess-lbl{font-family:var(--font-main);font-size:10px;color:var(--text3);letter-spacing:2px;text-transform:uppercase;margin-bottom:8px}
.sess-timer{font-family:'Share Tech Mono',monospace;font-size:52px;font-weight:700;letter-spacing:4px;line-height:1;transition:all .5s}
.sess-timer.idle{color:rgba(15,23,42,.35)}
.sess-timer.running{color:#111;text-shadow:0 0 40px rgba(59,130,246,.25);animation:tglow 2s ease-in-out infinite}
.sess-timer.done{color:var(--success);text-shadow:0 0 30px rgba(16,185,129,.2)}
@keyframes tglow{0%,100%{text-shadow:0 0 20px rgba(59,130,246,.25)}50%{text-shadow:0 0 38px rgba(59,130,246,.45)}}
.spulse{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;border-radius:999px;font-family:var(--font-main);font-size:11px;letter-spacing:1px;text-transform:uppercase;margin-bottom:18px;position:relative;z-index:1}
.spulse.in{background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.18);color:var(--primary)}
.spulse.out{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.18);color:var(--danger)}
.spulse.done{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.18);color:var(--success)}
.sdot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.spulse.in .sdot{background:var(--primary);animation:blink 1.5s infinite}
.spulse.out .sdot{background:var(--danger)}
.spulse.done .sdot{background:var(--success)}
.clk-btns{display:flex;gap:16px;justify-content:center;margin-top:24px;position:relative;z-index:1;flex-wrap:wrap}
.btn-clk{padding:14px 42px;border-radius:12px;font-family:var(--font-main);font-size:14px;font-weight:700;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:all .25s;border:1px solid}
.btn-ci{background:linear-gradient(135deg,rgba(59,130,246,.18),rgba(139,92,246,.12));border-color:rgba(59,130,246,.35);color:var(--primary)}
.btn-ci:not(:disabled):hover{box-shadow:0 12px 30px rgba(59,130,246,.16);transform:translateY(-2px);background:linear-gradient(135deg,rgba(59,130,246,.25),rgba(139,92,246,.18))}
.btn-ci:not(:disabled){animation:gblink 4s ease-in-out infinite}
@keyframes gblink{0%,100%{box-shadow:0 0 6px rgba(59,130,246,.12)}50%{box-shadow:0 0 18px rgba(59,130,246,.24)}}
.btn-co{background:linear-gradient(135deg,rgba(239,68,68,.12),rgba(245,158,11,.12));border-color:rgba(239,68,68,.28);color:var(--danger)}
.btn-co:not(:disabled):hover{box-shadow:0 12px 30px rgba(239,68,68,.16);transform:translateY(-2px);background:linear-gradient(135deg,rgba(239,68,68,.18),rgba(245,158,11,.14))}
.btn-co:not(:disabled){animation:rblink 4s ease-in-out infinite}
@keyframes rblink{0%,100%{box-shadow:0 0 6px rgba(239,68,68,.12)}50%{box-shadow:0 0 18px rgba(239,68,68,.22)}}
.btn-clk:disabled{opacity:.28;cursor:not-allowed;pointer-events:none;animation:none}
.today-row{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;margin-top:22px;padding-top:22px;border-top:1px solid rgba(59,130,246,.12);position:relative;z-index:1}
.tri{flex:1;min-width:110px;background:rgba(255,255,255,.85);border:1px solid rgba(59,130,246,.08);border-radius:12px;padding:16px}
.tri-lbl{font-family:var(--font-main);font-size:9px;color:var(--text3);letter-spacing:2px;text-transform:uppercase;margin-bottom:8px}
.tri-val{font-family:'Share Tech Mono',monospace;font-size:20px;font-weight:700;color:var(--text);line-height:1}

/* TASK CARDS */
.task-card{background:var(--panel2);border:1px solid var(--border2);border-radius:4px;padding:14px 16px;margin-bottom:10px;transition:all .2s;position:relative}
.task-card:hover{border-color:var(--border)}
.task-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:3px 0 0 3px}
.task-card.pri-Critical::before{background:var(--red)}
.task-card.pri-High::before{background:var(--amber)}
.task-card.pri-Medium::before{background:var(--teal)}
.task-card.pri-Low::before{background:var(--green)}
.tc-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}
.tc-title{font-size:13px;font-weight:600;color:var(--text);font-family:var(--font-main);letter-spacing:1px}
.tc-meta{font-family:var(--font-main);font-size:10px;color:var(--text3);margin-top:4px}
.tc-desc{font-size:12px;color:var(--text2);line-height:1.5;margin:6px 0 10px}
.tc-foot{display:flex;justify-content:space-between;align-items:center}
.tc-status-btns{display:flex;gap:6px}
.mini-btn{padding:4px 10px;border-radius:2px;font-family:var(--font-main);font-size:9px;letter-spacing:1px;cursor:pointer;transition:all .2s;border:1px solid}
.mb-todo{background:rgba(0,180,255,.08);border-color:rgba(0,180,255,.25);color:var(--blue)}
.mb-prog{background:rgba(255,170,0,.08);border-color:rgba(255,170,0,.25);color:var(--amber)}
.mb-done{background:rgba(0,255,136,.08);border-color:rgba(0,255,136,.25);color:var(--green)}
.mini-btn.sel{box-shadow:0 0 0 1px rgba(255,255,255,.5);font-weight:700;}
.mb-todo:hover,.mb-prog:hover,.mb-done:hover{opacity:.8}
.mini-btn:disabled{opacity:.35;cursor:not-allowed;pointer-events:none;}

/* LOG BOOK */
.log-entry{padding:14px 16px;background:var(--panel2);border:1px solid var(--border);border-radius:8px;margin-bottom:12px;display:grid;grid-template-columns:100px 1fr auto;gap:14px;align-items:start;box-shadow:var(--shadow)}
.le-time{font-family:var(--font-main);font-size:11px;color:var(--text3)}
.le-type{font-size:12px;color:var(--success);font-family:var(--font-main);letter-spacing:0px;margin-bottom:4px;font-weight:600}
.le-desc{font-size:13px;color:var(--text2);line-height:1.6}

/* MODALS */
.moverlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:800;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.moverlay.open{display:flex}
.mbox{background:var(--panel);border:1px solid var(--border);border-radius:12px;width:560px;max-width:92vw;max-height:88vh;overflow-y:auto;position:relative;box-shadow:var(--shadow-lg);animation:slideUp .3s ease}
.mbox::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--info))}
.mbox.red-top::before{background:linear-gradient(90deg,var(--danger),var(--warning))}
.mbox.blue-top::before{background:linear-gradient(90deg,var(--primary),var(--purple))}
.mhead{padding:22px 28px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,rgba(37,99,235,.02),rgba(139,92,246,.02))}
.mtitle{font-family:var(--font-main);font-size:18px;font-weight:700;letter-spacing:0px;text-transform:capitalize;color:var(--text)}
.mclose{width:32px;height:32px;background:transparent;border:1.5px solid var(--border);border-radius:6px;color:var(--text3);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.mclose:hover{border-color:var(--danger);color:var(--danger);background:rgba(239,68,68,.05)}
.mbody{padding:28px}
.mfoot{padding:18px 28px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:12px;background:linear-gradient(135deg,rgba(37,99,235,.01),rgba(139,92,246,.01))}

/* EARLY LEAVE */
.el-times{display:flex;gap:14px;margin-bottom:18px}
.elt{flex:1;padding:14px;background:var(--bg2);border:1.5px solid var(--border);border-radius:8px;text-align:center;box-shadow:var(--shadow)}
.elt.warn{border-color:rgba(245,158,11,.4);background:rgba(245,158,11,.04)}
.elt.danger{border-color:rgba(239,68,68,.4);background:rgba(239,68,68,.04)}
.elt-lbl{font-family:var(--font-main);font-size:11px;color:var(--text3);letter-spacing:0.5px;text-transform:capitalize;margin-bottom:6px;font-weight:600}
.elt-val{font-family:var(--font-main);font-size:22px;font-weight:700}
.elt-sub{font-family:var(--font-main);font-size:11px;color:var(--amber);font-weight:700;margin-top:6px;line-height:1.25}
.el-deficit{text-align:center;padding:12px;background:rgba(239,68,68,.05);border:1px solid rgba(239,68,68,.2);border-radius:6px;margin-bottom:18px;font-family:var(--font-main);font-size:13px;color:var(--danger);letter-spacing:0px;font-weight:600}
.reason-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
.rc{padding:11px 12px;background:var(--bg2);border:1.5px solid var(--border);border-radius:6px;font-family:var(--font-main);font-size:12px;color:var(--text2);cursor:pointer;transition:all .2s;text-align:center;letter-spacing:0px;font-weight:500}
.rc:hover{border-color:var(--warning);color:var(--warning);background:rgba(245,158,11,.06)}
.rc.sel{border-color:var(--danger);color:var(--danger);background:rgba(239,68,68,.08)}

/* LEAVE REQUEST */
.lr-types{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:16px}
.lt{padding:12px 10px;background:var(--bg2);border:1.5px solid var(--border);border-radius:6px;font-family:var(--font-main);font-size:12px;color:var(--text2);cursor:pointer;transition:all .2s;text-align:center;font-weight:500}
.lt:hover{border-color:var(--primary);color:var(--primary);background:rgba(37,99,235,.06)}
.lt.sel{border-color:var(--success);color:var(--success);background:rgba(16,185,129,.08)}

/* TOAST */
.toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column-reverse;align-items:flex-end;gap:10px;z-index:9999;pointer-events:none}
.toast{position:relative;padding:14px 20px;background:rgba(255,255,255,.98);border:1.5px solid rgba(148,163,184,.18);border-radius:8px;font-family:var(--font-main);font-size:13px;letter-spacing:0px;animation:slideIn .3s ease;max-width:320px;line-height:1.5;box-shadow:var(--shadow-lg);font-weight:500;pointer-events:auto;opacity:1;transition:opacity .3s ease;color:var(--text)}
.toast.s{border-color:rgba(16,185,129,.45);color:var(--success);background:rgba(16,185,129,.15)}
.toast.e{border-color:rgba(239,68,68,.45);color:var(--danger);background:rgba(239,68,68,.15)}
.toast.i{border-color:rgba(6,182,212,.45);color:var(--info);background:rgba(6,182,212,.15)}
.toast.w{border-color:rgba(245,158,11,.45);color:var(--warning);background:rgba(245,158,11,.15)}
.toast.fade-out{opacity:0}
@keyframes slideIn{from{transform:translateX(120%);opacity:0}to{transform:translateX(0);opacity:1}}

/* SCROLLBAR */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:linear-gradient(135deg,var(--primary),var(--purple));border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,var(--primary-dark),#7c3aed)}

/* CHAT */
.chat-btn{background:rgba(139,92,246,.05)}
.chat-btn:hover{color:var(--purple)}
.chat-modal-box{width:75vw;max-width:75vw;height:75vh;max-height:75vh;overflow:hidden;display:flex;flex-direction:column}
.chat-modal-body{padding:0;height:auto;flex:1;min-height:0}
.chat-modal-actions{display:flex;align-items:center;gap:10px}
.chat-shell{display:grid;grid-template-columns:320px 1fr;height:100%;min-height:0;max-height:none;overflow:hidden}
.chat-sidebar{border-right:1px solid var(--border);background:linear-gradient(180deg,rgba(248,250,252,.98),rgba(241,245,249,.98));display:flex;flex-direction:column;min-width:0;min-height:0;height:100%}
.chat-sidebar-top{padding:18px;border-bottom:1px solid var(--border)}
.chat-sidebar-content{flex:1;min-height:0;padding:12px 14px 20px;overflow-y:auto;display:flex;flex-direction:column;gap:16px;scrollbar-gutter:stable}
.chat-side-section{display:flex;flex-direction:column;gap:8px}
.chat-side-title{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text3);padding:0 6px}
.chat-thread-item,.chat-user-item{width:100%;display:flex;align-items:center;gap:12px;padding:12px;border:1px solid transparent;border-radius:16px;background:transparent;text-align:left;cursor:pointer;transition:all .2s;overflow:hidden}
.chat-thread-item:hover,.chat-user-item:hover{border-color:rgba(37,99,235,.18);background:rgba(37,99,235,.05);transform:translateY(-1px)}
.chat-thread-item.active{border-color:rgba(37,99,235,.25);background:linear-gradient(135deg,rgba(37,99,235,.08),rgba(139,92,246,.08))}
.chat-thread-item.unread{border-color:rgba(139,92,246,.22);background:linear-gradient(135deg,rgba(139,92,246,.08),rgba(59,130,246,.06))}
.chat-thread-avatar{width:44px;height:44px;border-radius:16px;background:linear-gradient(135deg,var(--primary),var(--info));color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;flex-shrink:0;box-shadow:var(--shadow)}
.chat-thread-avatar.group{background:linear-gradient(135deg,var(--purple),#ec4899)}
.chat-thread-avatar.admin{background:linear-gradient(135deg,var(--purple),#f43f5e)}
.chat-thread-copy{min-width:0;flex:1}
.chat-thread-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.chat-thread-name{font-size:13px;font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.chat-thread-time{font-size:10px;color:var(--text3);white-space:nowrap}
.chat-thread-sub{margin-top:4px;font-size:12px;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.chat-main{display:flex;flex-direction:column;min-width:0;min-height:0;height:100%;background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,250,252,.98))}
.chat-thread-head{padding:20px 24px;border-bottom:1px solid var(--border);background:linear-gradient(135deg,rgba(37,99,235,.05),rgba(139,92,246,.05))}
.chat-thread-head-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.chat-thread-title{font-size:18px;font-weight:700;color:var(--text)}
.chat-thread-subhead{margin-top:6px;font-size:12px;color:var(--text3);line-height:1.6}
.chat-thread-tools{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.chat-head-btn{padding:8px 12px;font-size:12px;white-space:nowrap}
.chat-messages{flex:1;min-height:0;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:12px;background:radial-gradient(circle at top right,rgba(139,92,246,.06),transparent 30%),linear-gradient(180deg,rgba(255,255,255,.96),rgba(244,247,255,.96));scrollbar-gutter:stable}
.chat-msg-row{display:flex}
.chat-msg-row.mine{justify-content:flex-end}
.chat-msg-row.other{justify-content:flex-start}
.chat-msg-bubble{max-width:min(78%,620px);padding:12px 14px;border-radius:18px;background:#fff;border:1px solid var(--border);box-shadow:var(--shadow)}
.chat-msg-row.mine .chat-msg-bubble{background:linear-gradient(135deg,var(--primary),var(--purple));border-color:transparent;color:#fff;border-bottom-right-radius:6px}
.chat-msg-row.other .chat-msg-bubble{border-bottom-left-radius:6px}
.chat-msg-sender{margin-bottom:6px;font-size:11px;font-weight:700;color:var(--purple)}
.chat-msg-row.mine .chat-msg-sender{color:rgba(255,255,255,.88)}
.chat-msg-text{font-size:14px;line-height:1.6;white-space:pre-wrap;word-break:break-word}
.chat-msg-time{margin-top:8px;font-size:10px;color:var(--text3);text-align:right}
.chat-msg-row.mine .chat-msg-time{color:rgba(255,255,255,.78)}
.chat-compose{padding:18px 24px;border-top:1px solid var(--border);display:flex;gap:12px;align-items:flex-end;background:#fff;flex-shrink:0}
.chat-compose .field{min-height:54px;max-height:140px;resize:vertical}
.chat-compose .btn{height:46px;flex-shrink:0}
.chat-empty-state{min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--text3);padding:32px;line-height:1.7}
.chat-empty-icon{width:92px;height:92px;margin:0 auto 16px;position:relative;border-radius:28px;background:linear-gradient(135deg,rgba(37,99,235,.08),rgba(139,92,246,.12));border:1px solid rgba(37,99,235,.14);box-shadow:0 14px 32px rgba(37,99,235,.08);font-size:0;color:var(--primary)}
.chat-empty-icon::before{content:"";position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);width:40px;height:28px;border:3px solid currentColor;border-radius:14px;background:rgba(255,255,255,.92);box-sizing:border-box}
.chat-empty-icon::after{content:"";position:absolute;left:50%;top:58%;width:12px;height:12px;transform:translateX(-17px) rotate(45deg);border-left:3px solid currentColor;border-bottom:3px solid currentColor;background:rgba(255,255,255,.92);box-sizing:border-box}
.chat-empty-small{padding:12px;color:var(--text3);font-size:12px;border:1px dashed var(--border);border-radius:12px;background:rgba(255,255,255,.55)}
.chat-group-users{display:grid;grid-template-columns:1fr 1fr;gap:10px;max-height:320px;overflow-y:auto;padding-right:4px}
.chat-group-user{display:flex;align-items:center;gap:10px;padding:12px;border:1px solid var(--border);border-radius:12px;background:rgba(37,99,235,.03);cursor:pointer}
.chat-group-user input{margin:0}
.chat-group-user:has(input:disabled){opacity:.72;cursor:not-allowed}
.chat-group-user strong{display:block;font-size:13px;color:var(--text)}
.chat-group-user small{display:block;font-size:11px;color:var(--text3);margin-top:3px}
.chat-group-user-avatar{width:34px;height:34px;border-radius:12px;background:linear-gradient(135deg,var(--primary),var(--info));color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.chat-group-user-avatar.admin{background:linear-gradient(135deg,var(--purple),#f43f5e)}
.chat-sidebar-content::-webkit-scrollbar,.chat-messages::-webkit-scrollbar,.chat-group-users::-webkit-scrollbar{width:8px}
.chat-sidebar-content::-webkit-scrollbar-track,.chat-messages::-webkit-scrollbar-track,.chat-group-users::-webkit-scrollbar-track{background:rgba(148,163,184,.12);border-radius:999px}
.chat-sidebar-content::-webkit-scrollbar-thumb,.chat-messages::-webkit-scrollbar-thumb,.chat-group-users::-webkit-scrollbar-thumb{background:linear-gradient(180deg,rgba(37,99,235,.7),rgba(139,92,246,.75));border-radius:999px}
.chat-sidebar-content::-webkit-scrollbar-thumb:hover,.chat-messages::-webkit-scrollbar-thumb:hover,.chat-group-users::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,rgba(30,64,175,.9),rgba(124,58,237,.9))}

/* RESPONSIVE */
@media(max-width:900px){
  .tb-nav{display:none}
  .page{padding:26px 20px}
  .ph{gap:18px;flex-wrap:wrap}
  .sg{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
  .g2,.g3{grid-template-columns:1fr}
  .frow3{grid-template-columns:1fr 1fr}
  .panel{overflow-x:auto}
  .dt{min-width:680px}
  .role-cards{gap:16px}
  .clock-card{padding:34px 24px}
  .mbox{max-width:94vw}
  .chat-modal-box{width:92vw;max-width:92vw;height:84vh;max-height:84vh}
  .chat-shell{grid-template-columns:1fr}
  .chat-sidebar{max-height:270px;border-right:none;border-bottom:1px solid var(--border)}
  .chat-group-users{grid-template-columns:1fr}
  .chat-thread-head-row{flex-direction:column}
  .chat-thread-tools{justify-content:flex-start}
}

@media(max-width:600px){
  html{scroll-padding-top:58px}
  body{font-size:14px}
  body::before{background-size:34px 34px}
  #landing{padding:24px 16px;justify-content:flex-start;padding-top:70px}
  .land-logo{margin-bottom:24px}
  .land-logo img{height:58px}
  .land-logo p{font-size:11px;margin-top:10px}
  .land-tagline{font-size:21px;text-align:center;margin-bottom:32px;line-height:1.25}
  .role-cards{width:100%;flex-direction:column;gap:12px}
  .role-card{width:100%;padding:28px 22px}
  .role-card-icon{font-size:42px;margin-bottom:12px}
  .role-card-title{font-size:17px}
  #loginModal{padding:14px;align-items:flex-start;padding-top:42px;overflow-y:auto}
  .login-box{width:100%;max-width:420px}
  .lb-head{padding:24px 20px 18px}
  .lb-title{font-size:19px}
  .lb-body{padding:22px 20px}
  .lb-hint,.lb-back{padding-left:20px;padding-right:20px}

  .topbar{height:58px;padding:0 10px;gap:8px}
  .main{padding-top:58px}
  .tb-logo img{height:28px;max-width:92px}
  .tb-divider{display:none}
  .tb-role-badge{padding:5px 8px;font-size:9px;white-space:nowrap}
  .tb-right{gap:6px;margin-left:auto}
  .notif-btn{width:36px;height:36px;border-radius:9px}
  .notif-btn svg{width:18px;height:18px}
  .notif-badge{top:-4px;right:-4px;min-width:18px;height:18px;font-size:10px}
  .tb-user{padding:5px 6px;gap:7px}
  .tb-avatar{width:28px;height:28px;font-size:11px}
  .tb-uname{max-width:72px;font-size:12px}
  .tb-urole,.db-status{display:none}
  .btn-logout{min-width:36px;height:36px;padding:0 8px;display:inline-flex;align-items:center;justify-content:center}
  .notif-panel{position:fixed;top:66px;right:10px;left:10px;width:auto;max-height:calc(100dvh - 78px);border-radius:12px}
  .notif-head{padding:14px}
  .notif-list{max-height:calc(100dvh - 190px)}
  .notif-empty{min-height:150px}

  .page{padding:18px 12px}
  .ph{flex-direction:column;align-items:stretch;margin-bottom:20px;padding-bottom:14px;gap:12px}
  .ph-title{font-size:22px;line-height:1.2}
  .ph-sub{font-size:11px;line-height:1.4}
  .ph>.btn,.ph>button{width:100%;justify-content:center}
  .sg{grid-template-columns:1fr;gap:12px;margin-bottom:18px}
  .sc{padding:16px;border-radius:8px}
  .sc-icon{font-size:22px;margin-bottom:8px}
  .sc-val{font-size:27px;letter-spacing:0}
  .sc-lbl{font-size:12px}
  .panel{border-radius:8px;margin-bottom:16px;overflow-x:auto}
  .phead{padding:14px 16px;gap:12px;flex-wrap:wrap;align-items:flex-start}
  .phead .btn,.phead select,.phead .field{width:auto;max-width:100%}
  .ptitle{font-size:14px}
  .pbody{padding:16px}
  .dt{min-width:640px}
  .dt th{padding:10px 12px;font-size:10px}
  .dt td{padding:11px 12px;font-size:12px}
  .badge{font-size:10px;padding:4px 8px}
  .btn{min-height:38px;padding:9px 12px;justify-content:center;white-space:normal}
  .field{min-height:42px;font-size:14px}
  .frow,.frow3,.g2,.g3{grid-template-columns:1fr;gap:12px}
  .sbar{flex-direction:column;align-items:stretch}
  .sbar .srch,.sbar .field,.sbar select{width:100% !important}
  .flex-b{align-items:flex-start;gap:8px;flex-wrap:wrap}
  .flex-g{flex-wrap:wrap}
  .ir{gap:12px;align-items:flex-start}
  .iv{word-break:break-word;text-align:right}

  .clock-card{padding:24px 14px;border-radius:16px}
  .clock-card::after{width:260px;height:260px}
  .clk-emp{font-size:18px;line-height:1.25}
  .clk-role{font-size:10px;margin-bottom:14px;line-height:1.4}
  .ring-wrap{width:205px;height:205px;margin-bottom:14px}
  .ring-mid{inset:12px}
  .ring-in{inset:20px}
  .wall-time{font-size:27px;letter-spacing:1px}
  .sess-wrap{margin-bottom:18px}
  .sess-timer{font-size:37px;letter-spacing:1px}
  .spulse{font-size:10px;padding:7px 12px;line-height:1.35}
  .clk-btns{gap:10px;margin-top:18px}
  .btn-clk{width:100%;padding:13px 16px;font-size:12px;letter-spacing:1px}
  .today-row{gap:10px;margin-top:18px;padding-top:16px}
  .tri{min-width:calc(50% - 6px);padding:12px}
  .tri-val{font-size:17px}

  .cal-nav{gap:10px}
  .cal-nav span{font-size:16px;text-align:center;line-height:1.3}
  .cal-nav .btn{min-width:44px;padding:8px 10px}
  .cal-legend{font-size:10px;line-height:1.5}
  .cal-grid{gap:5px}
  .cal-grid-head{font-size:11px;margin-bottom:8px;padding:8px 0}
  .cal-cell{min-height:64px;padding:6px;border-radius:6px;font-size:10px}
  .cal-num{font-size:12px;margin-bottom:4px}
  .cal-day,.cal-day-sunday,.cal-leave,.cal-tasks,.cal-hours{font-size:9px;line-height:1.25}
  .cal-sunday-badge{font-size:8px;padding:3px 4px}

  .task-card{padding:13px 12px}
  .tc-head,.tc-foot{gap:10px;flex-wrap:wrap}
  .tc-title{font-size:12px;letter-spacing:0}
  .tc-status-btns{width:100%;display:grid;grid-template-columns:repeat(3,minmax(0,1fr))}
  .mini-btn{padding:7px 6px;font-size:9px;letter-spacing:0}
  .log-entry{grid-template-columns:1fr;gap:8px}
  .le-time{display:flex;gap:8px;flex-wrap:wrap}

  .moverlay{align-items:flex-end;padding:0}
  .mbox,.mbox[style]{width:100vw !important;max-width:100vw;max-height:92dvh;border-radius:14px 14px 0 0}
  .mhead{padding:16px 18px}
  .mtitle{font-size:16px}
  .mclose{width:34px;height:34px}
  .mbody{padding:18px}
  .mfoot{position:sticky;bottom:0;padding:14px 18px;gap:10px;flex-wrap:wrap}
  .mfoot .btn{flex:1;min-width:130px}
  .el-times{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:14px}
  .elt{min-width:0;padding:10px 6px;border-radius:7px}
  .elt-lbl{font-size:10px;margin-bottom:5px}
  .elt-val{font-size:17px;line-height:1.25;overflow-wrap:anywhere}
  .elt-sub{font-size:10px;line-height:1.25}
  .el-deficit{padding:10px;font-size:12px;margin-bottom:14px}
  .reason-grid,.lr-types{grid-template-columns:1fr;gap:8px}
  .rc,.lt{padding:12px 10px;font-size:12px}
  .date-popover{left:12px !important;right:12px;width:auto;max-width:calc(100vw - 24px)}

  .toast-container{left:12px;right:12px;bottom:12px;align-items:stretch}
  .toast{max-width:none;width:100%}
  .chat-modal-box{width:100vw;max-width:100vw;height:100dvh;max-height:100dvh;border-radius:0}
  .chat-shell{min-height:0;max-height:none}
  .chat-sidebar{max-height:36dvh}
  .chat-sidebar-top{padding:14px}
  .chat-sidebar-content{padding:10px}
  .chat-thread-item,.chat-user-item{padding:10px;border-radius:12px}
  .chat-thread-avatar{width:38px;height:38px;border-radius:12px}
  .chat-thread-head{padding:16px}
  .chat-thread-title{font-size:16px}
  .chat-messages{padding:14px}
  .chat-msg-bubble{max-width:92%;padding:10px 12px}
  .chat-compose{padding:12px;flex-direction:column;gap:10px}
  .chat-compose .field{width:100%;min-height:48px}
  .chat-compose .btn{width:100%}
}

@media(max-width:420px){
  .tb-logo img{max-width:76px;height:25px}
  .tb-role-badge{font-size:8px;padding:4px 6px}
  .tb-user{padding:4px}
  .tb-uname{display:none}
  .notif-btn,.btn-logout{width:34px;height:34px;min-width:34px}
  .ph-title{font-size:20px}
  .sc{padding:14px}
  .ring-wrap{width:180px;height:180px}
  .wall-time{font-size:23px}
  .sess-timer{font-size:32px}
  .tri{min-width:100%}
  .el-times{gap:6px}
  .elt{padding:8px 4px}
  .elt-val{font-size:15px}
  .elt-sub{font-size:9px}
  .mfoot .btn{min-width:100%;width:100%}
  .cal-grid{gap:3px}
  .cal-cell{min-height:56px;padding:4px 3px}
  .cal-day,.cal-day-sunday,.cal-leave,.cal-tasks{display:none}
  .tc-status-btns{grid-template-columns:1fr}
}
