/* ═══ RWA HRMS — Concept A: Navy & Gold ═══ */
:root{--navy-dark:#0f172a;--navy-mid:#1e293b;--navy-light:#334155;--gold:#f59e0b;--gold-light:#fbbf24;--gold-dim:#b45309;--bg-page:#f1f5f9;--bg-card:#fff;--text-primary:#0f172a;--text-secondary:#64748b;--text-muted:#94a3b8;--success:#059669;--success-bg:#dcfce7;--danger:#dc2626;--danger-bg:#fee2e2;--warning:#d97706;--warning-bg:#fef3c7;--info:#7c3aed;--info-bg:#ede9fe;--border:#e2e8f0;--shadow-sm:0 1px 3px rgba(15,23,42,.06);--shadow-md:0 4px 12px rgba(15,23,42,.08);--radius:12px;--radius-sm:8px}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Plus Jakarta Sans',-apple-system,sans-serif;background:#1e293b;display:flex;justify-content:center;align-items:center;min-height:100vh;color:var(--text-primary)}
.phone-frame{width:390px;height:844px;border-radius:40px;overflow:hidden;box-shadow:0 25px 80px rgba(0,0,0,.4);border:6px solid #1a1a2e;position:relative}
.app{width:100%;height:100%;display:flex;flex-direction:column;background:var(--bg-page);position:relative}

/* ═══ TOP BAR ═══ */
.top-bar{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:linear-gradient(135deg,var(--navy-dark),var(--navy-mid));flex-shrink:0}
.top-bar-left{display:flex;align-items:center;gap:8px}
.top-bar-right{display:flex;align-items:center;gap:12px}
.logo-text{color:#fff;font-weight:800;font-size:16px;letter-spacing:-.3px}
.page-title{color:#fff;font-weight:700;font-size:16px}
.back-btn{color:var(--gold);text-decoration:none;font-size:24px;font-weight:300;line-height:1;padding:0 4px}
.notif-btn{position:relative;background:none;border:none;cursor:pointer;color:var(--gold);padding:4px}
.notif-dot{position:absolute;top:2px;right:2px;width:8px;height:8px;background:var(--danger);border-radius:50%;border:2px solid var(--navy-dark)}
.avatar-ring{width:32px;height:32px;border-radius:50%;border:2px solid var(--gold);display:flex;align-items:center;justify-content:center}
.avatar{width:26px;height:26px;border-radius:50%;background:var(--navy-light);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}

/* ═══ HERO HEADER (Home) ═══ */
.hero-header{background:linear-gradient(160deg,var(--navy-dark) 0%,var(--navy-mid) 60%,#2d3a4f 100%);padding:16px 20px 28px;text-align:center;border-radius:0 0 24px 24px;position:relative}
.hero-top-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.hero-top-right{display:flex;align-items:center;gap:12px}
.hero-greeting{color:#fff;font-size:22px;font-weight:800;margin-bottom:4px}
.hero-dept{color:rgba(255,255,255,.55);font-size:12px;font-weight:500;margin-bottom:20px}
.checkin-circle{display:flex;justify-content:center;margin-bottom:8px}
.checkin-ring{width:80px;height:80px;border-radius:50%;border:3px solid var(--gold);background:rgba(245,158,11,.12);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;transition:transform .2s}
.checkin-ring:active{transform:scale(.95)}
.checkin-ring span{color:var(--gold);font-size:9px;font-weight:800;letter-spacing:.5px}
.checkin-label{color:var(--gold);font-size:12px;font-weight:600}

/* ═══ PAGE CONTENT ═══ */
.page-content{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}
.page-content-pad{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:16px}

/* ═══ SECTION TITLES ═══ */
.section-title{font-size:13px;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}
.section-title-icon{font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;display:flex;align-items:center;gap:6px}
.count-badge{font-size:10px;background:#e2e8f0;color:var(--text-secondary);padding:1px 7px;border-radius:10px}
.page-sub{font-size:12px;color:var(--text-secondary)}

/* ═══ QUICK LINKS GRID ═══ */
.ql-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:24px}
.ql-card{background:var(--bg-card);border-radius:var(--radius);padding:16px 8px;display:flex;flex-direction:column;align-items:center;gap:10px;text-decoration:none;color:var(--text-primary);box-shadow:var(--shadow-sm);transition:transform .15s;font-size:11px;font-weight:600;text-align:center}
.ql-card:active{transform:scale(.96)}
.ql-icon-box{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* ═══ PENDING REQUESTS ═══ */
.pending-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}
.pending-row{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}
.pending-row:last-child{border-bottom:none}
.pending-left{display:flex;align-items:center;gap:10px}
.pending-bar{width:3px;height:32px;border-radius:2px;flex-shrink:0}
.pending-type{font-size:13px;font-weight:600;display:block}
.pending-desc{font-size:11px;color:var(--text-secondary);display:block;margin-top:2px}

/* ═══ BADGES ═══ */
.badge{font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;white-space:nowrap}
.badge-approved{background:var(--success-bg);color:var(--success)}
.badge-pending{background:var(--warning-bg);color:var(--warning)}
.badge-rejected{background:var(--danger-bg);color:var(--danger)}

/* ═══ GOLD BUTTON ═══ */
.gold-btn{background:var(--gold);color:#fff;border:none;padding:8px 14px;border-radius:var(--radius-sm);font-size:12px;font-weight:700;cursor:pointer;transition:background .2s;font-family:inherit}
.gold-btn:active{background:var(--gold-dim)}

/* ═══ LEAVES ═══ */
.balance-scroll{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px;margin-bottom:24px;-webkit-overflow-scrolling:touch}
.balance-scroll::-webkit-scrollbar{display:none}
.balance-card{min-width:140px;background:var(--bg-card);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);border-left:4px solid;flex-shrink:0}
.bal-type{font-size:11px;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.3px}
.bal-num{font-size:28px;font-weight:800;color:var(--text-primary);margin:6px 0 2px}
.bal-alloc{font-size:11px;color:var(--text-muted)}
.leave-list{display:flex;flex-direction:column;gap:8px}
.leave-item{display:flex;align-items:center;gap:12px;background:var(--bg-card);border-radius:var(--radius-sm);padding:14px 16px;box-shadow:var(--shadow-sm)}
.leave-badge{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0}
.leave-info{flex:1;display:flex;flex-direction:column;gap:2px}
.leave-dates{font-size:13px;font-weight:600}
.leave-days{font-size:11px;color:var(--text-secondary)}

/* ═══ EXPENSES ═══ */
.expense-summary{display:flex;gap:10px;margin-bottom:24px}
.exp-sum-card{flex:1;background:var(--bg-card);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);border-left:4px solid}
.exp-label{font-size:11px;color:var(--text-secondary);font-weight:600;text-transform:uppercase}
.exp-amount{font-size:22px;font-weight:800;margin-top:4px}
.expense-list{display:flex;flex-direction:column;gap:8px}
.exp-item{display:flex;align-items:center;gap:12px;background:var(--bg-card);border-radius:var(--radius-sm);padding:14px 16px;box-shadow:var(--shadow-sm)}
.exp-info{flex:1;display:flex;flex-direction:column;gap:2px}
.exp-title{font-size:13px;font-weight:600}
.exp-date{font-size:11px;color:var(--text-secondary)}
.exp-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.exp-amt{font-size:14px;font-weight:700;color:var(--gold-dim)}

/* ═══ SALARY ═══ */
.salary-hero{background:var(--bg-card);border-radius:var(--radius);padding:24px 20px;box-shadow:var(--shadow-md);margin-bottom:16px;text-align:center}
.sal-month{font-size:14px;font-weight:600;color:var(--text-secondary);margin-bottom:8px;display:flex;align-items:center;justify-content:center;gap:8px}
.sal-net{font-size:36px;font-weight:800;color:var(--gold-dim)}
.sal-label{font-size:12px;color:var(--text-muted);margin-bottom:16px}
.sal-split{display:flex;gap:12px;border-top:1px solid var(--border);padding-top:14px}
.sal-gross,.sal-ded{flex:1;display:flex;flex-direction:column;gap:2px;font-size:12px;font-weight:600}
.sal-gross span:first-child,.sal-ded span:first-child{color:var(--text-muted);font-size:11px}
.sal-gross span:last-child{color:var(--success);font-size:15px;font-weight:700}
.sal-ded span:last-child{color:var(--danger);font-size:15px;font-weight:700}
.sal-breakdown{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:24px}
.sal-row{display:flex;justify-content:space-between;padding:12px 16px;font-size:13px;border-bottom:1px solid var(--border)}
.sal-row:last-child{border-bottom:none}
.sal-row span:first-child{color:var(--text-secondary)}
.sal-row span:last-child{font-weight:600;color:var(--text-primary)}
.sal-row.ded span:last-child{color:var(--danger)}
.prev-slips{display:flex;flex-direction:column;gap:8px}
.prev-slip{display:flex;align-items:center;gap:12px;background:var(--bg-card);border-radius:var(--radius-sm);padding:14px 16px;box-shadow:var(--shadow-sm);font-size:13px;font-weight:500}
.prev-amt{margin-left:auto;font-weight:700;color:var(--gold-dim);margin-right:8px}

/* ═══ MY TEAM ═══ */
.metrics-section{margin-bottom:24px}
.metrics-label{font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;display:flex;align-items:center;gap:6px}
.metrics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}
.metric-card{display:flex;flex-direction:column;align-items:center;padding:14px 4px;border-radius:var(--radius);background:var(--bg-card);border:2px solid var(--border);box-shadow:var(--shadow-sm);cursor:pointer;transition:all .2s}
.metric-card:active,.metric-card.mc-active{border-color:var(--navy-dark);box-shadow:var(--shadow-md)}
.mc-num{font-size:22px;font-weight:800}
.mc-label{font-size:10px;font-weight:600;color:var(--text-muted);margin-top:2px;text-transform:uppercase}
.stat-mini{background:var(--bg-card);border-radius:var(--radius);padding:12px 8px;box-shadow:var(--shadow-sm);text-align:center}
.stat-num{font-size:20px;font-weight:800;display:block}
.stat-lbl{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase}
.team-list{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}
.team-card{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.team-card.reportee{background:#eff6ff}
.team-card.colleague{background:#f8fafc}
.tc-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}
.tc-info{flex:1;min-width:0}
.tc-name{font-size:13px;font-weight:600;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tc-role{font-size:11px;color:var(--text-secondary);display:block}
.tc-action{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;font-size:14px;flex-shrink:0;transition:opacity .15s}
.tc-action:active{opacity:.7}
.tc-action.green{background:#dcfce7}
.tc-action.blue{background:#dbeafe}
.tc-id{font-size:10px;color:var(--text-muted);flex-shrink:0}

/* ═══ CALENDAR ═══ */
.cal-nav{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:16px}
.cal-month{font-size:16px;font-weight:700;color:var(--text-primary)}
.cal-arrow{background:none;border:1px solid var(--border);border-radius:8px;width:32px;height:32px;font-size:18px;cursor:pointer;color:var(--gold);display:flex;align-items:center;justify-content:center}
.calendar-card{background:var(--bg-card);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);margin-bottom:12px}
.cal-header{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;margin-bottom:8px}
.cal-header span{font-size:11px;font-weight:700;color:var(--text-muted)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;gap:6px}
.cal-day,.cal-empty{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;margin:auto;color:var(--text-secondary)}
.cal-day.present{background:var(--success);color:#fff}
.cal-day.absent{background:var(--danger);color:#fff}
.cal-day.halfday{background:var(--warning);color:#fff}
.cal-day.leave{background:var(--info);color:#fff}
.cal-day.holiday{background:#e2e8f0;color:var(--text-muted)}
.cal-day.today{background:var(--gold);color:#fff;box-shadow:0 0 0 3px rgba(245,158,11,.3)}
.cal-legend{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:8px}
.cal-legend span{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--text-secondary);font-weight:500}
.cal-legend i{width:10px;height:10px;border-radius:50%;display:inline-block}

/* ═══ REQUEST CARDS ═══ */
.req-list{display:flex;flex-direction:column;gap:10px}
.req-card{background:var(--bg-card);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm)}
.req-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.req-type{font-size:13px;font-weight:700;color:var(--text-primary)}
.req-dates{font-size:12px;color:var(--text-secondary);margin-bottom:4px}
.req-meta{font-size:11px;color:var(--text-muted);margin-bottom:4px}
.req-reason{font-size:12px;color:var(--text-secondary);font-style:italic;padding-top:6px;border-top:1px solid var(--border)}

/* ═══ FORMS ═══ */
.form-card{background:var(--bg-card);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm)}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.3px}
.form-input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:inherit;color:var(--text-primary);background:var(--bg-page);transition:border-color .2s}
.form-input:focus{outline:none;border-color:var(--gold)}
.form-row{display:flex;gap:10px}
.form-row .form-group{flex:1}
textarea.form-input{resize:vertical}
select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.submit-btn{width:100%;padding:12px;border:none;border-radius:var(--radius-sm);background:var(--navy-dark);color:#fff;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;transition:background .2s}
.submit-btn:active{background:var(--navy-light)}
.upload-box{border:2px dashed var(--border);border-radius:var(--radius-sm);padding:24px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;color:var(--text-muted);font-size:12px;transition:border-color .2s}
.upload-box:hover{border-color:var(--gold)}
.toggle-row{display:flex;align-items:center;gap:8px}
.toggle-label{font-size:12px;color:var(--text-secondary)}
.toggle{width:40px;height:22px;border-radius:11px;background:#cbd5e1;position:relative;cursor:pointer}
.toggle::after{content:'';position:absolute;left:2px;top:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .2s}
.toggle.on{background:var(--gold)}
.toggle.on::after{transform:translateX(18px)}

/* ═══ SHIFTS ═══ */
.shift-list{display:flex;flex-direction:column;gap:10px}
.shift-card{background:var(--bg-card);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-sm)}
.shift-top{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.shift-detail{display:flex;align-items:center;justify-content:space-between;padding-top:10px;border-top:1px solid var(--border)}
.shift-tag{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--text-primary)}

/* ═══ TEAM ATTENDANCE ═══ */
.ta-list{display:flex;flex-direction:column;gap:8px}
.ta-card{display:flex;align-items:center;gap:10px;background:var(--bg-card);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-sm)}
.ta-info{flex:1;min-width:0}
.ta-stats{display:flex;gap:6px;flex-shrink:0}
.ta-stat{font-size:11px;font-weight:700;padding:2px 8px;border-radius:6px}
.ta-stat.g{background:var(--success-bg);color:var(--success)}
.ta-stat.r{background:var(--danger-bg);color:var(--danger)}
.ta-stat.y{background:var(--info-bg);color:var(--info)}

/* ═══ MINI STICKY HEADER ═══ */
.mini-header{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:linear-gradient(135deg,var(--navy-dark),var(--navy-mid));position:absolute;top:0;left:0;right:0;z-index:20;transform:translateY(-100%);opacity:0;transition:transform .25s ease,opacity .25s ease;pointer-events:none}
.mini-header.mini-visible{transform:translateY(0);opacity:1;pointer-events:auto}
.mini-left{display:flex;flex-direction:column;gap:1px}
.mini-name{color:#fff;font-size:14px;font-weight:700}
.mini-dept{color:rgba(255,255,255,.5);font-size:10px}
.mini-checkin{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:20px;border:2px solid var(--gold);background:rgba(245,158,11,.1);color:var(--gold);font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .2s}
.mini-checkin:active{transform:scale(.95)}
.mini-checkin.checkout{background:var(--danger);border-color:var(--danger);color:#fff}
.checkin-ring.checked-in{border-color:#34d399;background:rgba(52,211,153,.15)}
.checkin-ring.checked-in span{color:#34d399}
.checkin-ring.checked-in svg{stroke:#34d399}
.notif-btn{text-decoration:none}
.avatar-ring{text-decoration:none}

/* ═══ TABS ═══ */
.tabs-row{display:flex;background:var(--bg-card);border-radius:var(--radius);padding:4px;margin-bottom:12px;box-shadow:var(--shadow-sm)}
.tab{flex:1;padding:10px;border:none;background:transparent;border-radius:var(--radius-sm);font-size:12px;font-weight:600;color:var(--text-secondary);cursor:pointer;font-family:inherit;transition:all .2s}
.tab.active{background:var(--navy-dark);color:#fff;box-shadow:var(--shadow-sm)}
.tab-panel{display:none}
.tab-panel.active{display:block}

/* ═══ BOTTOM NAV ═══ */
.bottom-nav{display:flex;align-items:flex-end;justify-content:space-around;padding:8px 0 14px;background:var(--navy-dark);flex-shrink:0;border-top:1px solid rgba(255,255,255,.08);position:relative}
.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;background:none;border:none;cursor:pointer;color:rgba(255,255,255,.4);font-size:10px;font-weight:500;padding:4px 12px;transition:color .2s;position:relative;text-decoration:none}
.nav-item.active{color:var(--gold)}
.nav-item.active::after{content:'';position:absolute;top:-8px;left:50%;transform:translateX(-50%);width:20px;height:3px;border-radius:2px;background:var(--gold)}
.nav-item span{margin-top:2px}
/* Center My Team pop-out */
.nav-item.nav-center{margin-top:-22px;color:rgba(255,255,255,.4)}
.nav-item.nav-center.active{color:var(--gold)}
.nav-item.nav-center.active::after{display:none}
.nav-center-ring{width:52px;height:52px;border-radius:50%;border:3px solid var(--gold);background:var(--navy-dark);display:flex;align-items:center;justify-content:center;box-shadow:0 -4px 12px rgba(245,158,11,.25);transition:transform .2s}
.nav-item.nav-center:active .nav-center-ring{transform:scale(.92)}
.nav-item.nav-center.active .nav-center-ring{background:var(--gold);border-color:var(--gold-light)}
.nav-item.nav-center.active .nav-center-ring svg{stroke:#fff}

/* ═══ PROFILE PAGE ═══ */
.profile-header{text-align:center;padding:30px 20px 24px;background:linear-gradient(160deg,var(--navy-dark),var(--navy-mid));border-radius:0 0 24px 24px}
.profile-avatar-lg{width:72px;height:72px;border-radius:50%;border:3px solid var(--gold);background:var(--navy-light);color:#fff;font-size:26px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 12px}
.profile-name{color:#fff;font-size:18px;font-weight:700}
.profile-id{color:rgba(255,255,255,.5);font-size:12px;margin-top:4px}
.profile-info{margin-top:16px;display:flex;justify-content:center;gap:24px}
.profile-stat{text-align:center}
.profile-stat-num{color:var(--gold);font-size:18px;font-weight:800;display:block}
.profile-stat-label{color:rgba(255,255,255,.5);font-size:10px;text-transform:uppercase}
.info-section{background:var(--bg-card);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);margin-bottom:12px}
.info-section-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;margin-bottom:12px;letter-spacing:.5px}
.info-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px}
.info-row:last-child{border-bottom:none}
.info-label{color:var(--text-secondary)}
.info-value{color:var(--text-primary);font-weight:600}

/* ═══ NOTIFICATIONS ═══ */
.notif-list{display:flex;flex-direction:column;gap:8px}
.notif-card{display:flex;gap:12px;background:var(--bg-card);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-sm)}
.notif-card.unread{border-left:3px solid var(--gold)}
.notif-icon-circle{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px}
.notif-body{flex:1;min-width:0}
.notif-title{font-size:13px;font-weight:600;color:var(--text-primary);display:block}
.notif-msg{font-size:11px;color:var(--text-secondary);display:block;margin-top:2px}
.notif-time{font-size:10px;color:var(--text-muted);display:block;margin-top:4px}

/* ═══ TOAST NOTIFICATIONS ═══ */
.toast{position:absolute;bottom:80px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--navy-dark);color:#fff;padding:12px 20px;border-radius:12px;font-size:13px;font-weight:600;box-shadow:0 8px 24px rgba(0,0,0,.3);z-index:100;opacity:0;transition:all .3s ease;pointer-events:none;white-space:nowrap;max-width:90%}
.toast.toast-show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ═══ DETAIL PAGE ═══ */
.detail-header{background:var(--bg-card);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm);margin-bottom:12px}
.detail-title{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:4px}
.detail-subtitle{font-size:12px;color:var(--text-secondary);margin-bottom:16px}
.detail-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border);font-size:13px}
.detail-row:last-child{border-bottom:none}
.detail-label{color:var(--text-secondary)}
.detail-value{color:var(--text-primary);font-weight:600;text-align:right;max-width:55%}
.detail-reason{background:var(--bg-page);border-radius:var(--radius-sm);padding:12px;margin-top:12px;font-size:12px;color:var(--text-secondary);line-height:1.6;font-style:italic}
.action-footer{display:flex;gap:10px;padding:16px;background:var(--bg-card);border-top:1px solid var(--border);flex-shrink:0}
.btn-approve{flex:1;padding:14px;border:none;border-radius:var(--radius-sm);background:var(--success);color:#fff;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s}
.btn-approve:active{transform:scale(.97);background:#047857}
.btn-reject{flex:1;padding:14px;border:2px solid var(--danger);border-radius:var(--radius-sm);background:transparent;color:var(--danger);font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s}
.btn-reject:active{transform:scale(.97);background:var(--danger-bg)}
.btn-cancel{width:100%;padding:14px;border:2px solid var(--danger);border-radius:var(--radius-sm);background:transparent;color:var(--danger);font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s}

/* ═══ LOAN DASHBOARD ═══ */
.loan-summary{background:var(--bg-card);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm);margin-bottom:16px}
.loan-outstanding{font-size:28px;font-weight:800;color:var(--gold-dim)}
.loan-label{font-size:12px;color:var(--text-muted);margin-bottom:4px}
.loan-row{display:flex;gap:16px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}
.loan-stat{flex:1;display:flex;flex-direction:column;gap:2px}
.loan-stat-label{font-size:11px;color:var(--text-muted)}
.loan-stat-val{font-size:15px;font-weight:700}
.loan-list{display:flex;flex-direction:column;gap:10px}
.loan-card{background:var(--bg-card);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);cursor:pointer;transition:box-shadow .2s}
.loan-card:active{box-shadow:var(--shadow-md)}
.loan-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.loan-name{font-size:14px;font-weight:600}
.loan-detail{font-size:12px;color:var(--text-secondary)}
.loan-emi{font-size:12px;color:var(--text-muted);text-align:right;margin-top:2px}
.loan-schedule{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}
.emi-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);font-size:12px}
.emi-row:last-child{border-bottom:none}
.emi-month{color:var(--text-secondary)}
.emi-amt{font-weight:600}
.badge-paid{background:var(--success-bg);color:var(--success);font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px}
.badge-due{background:var(--warning-bg);color:var(--warning);font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px}
.badge-active{background:#dbeafe;color:#2563eb;font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px}

/* ═══ FLOATING ACTION BUTTON ═══ */
.fab{position:absolute;bottom:72px;right:16px;width:48px;height:48px;border-radius:50%;background:var(--gold);color:#fff;border:none;font-size:24px;font-weight:300;cursor:pointer;box-shadow:0 4px 16px rgba(245,158,11,.4);display:flex;align-items:center;justify-content:center;z-index:10;transition:transform .2s}
.fab:active{transform:scale(.9)}

/* ═══ HOLIDAY CHIPS ═══ */
.holiday-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.holiday-chip{padding:6px 12px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid var(--border);background:var(--bg-page);color:var(--text-secondary);cursor:pointer;transition:all .2s}
.holiday-chip.selected{background:var(--info-bg);border-color:var(--info);color:var(--info)}

/* ═══ CHECKBOX ROW ═══ */
.check-row{display:flex;align-items:center;gap:10px;padding:4px 0}
.check-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--gold);cursor:pointer}
.check-row label{font-size:13px;font-weight:500;color:var(--text-primary);cursor:pointer}

/* ═══ INFO BANNER ═══ */
.info-banner{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--radius-sm);font-size:12px;font-weight:500;margin-bottom:12px}
.info-banner.gold{background:var(--warning-bg);color:var(--warning);border:1px solid #fde68a}
.info-banner.green{background:var(--success-bg);color:var(--success);border:1px solid #bbf7d0}
.info-banner.blue{background:#dbeafe;color:#2563eb;border:1px solid #bfdbfe}

/* ═══ SHIFT BADGES INLINE ═══ */
.shift-badges{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}
.shift-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600}
.shift-badge.active{background:var(--success-bg);color:var(--success);border:1px solid #bbf7d0}
.shift-badge.default{background:#dbeafe;color:#2563eb;border:1px solid #bfdbfe}
.shift-badge.none{background:#f1f5f9;color:var(--text-muted);border:1px solid var(--border)}

/* ═══ INLINE ASSIGN FORM ═══ */
.assign-form{background:#eff6ff;border-bottom:1px solid #bfdbfe;padding:16px}
.assign-form-title{font-size:13px;font-weight:700;color:#1e40af;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}
.assign-close{background:none;border:none;color:#1e40af;cursor:pointer;font-size:16px;padding:4px}

/* ═══ SALARY COMPONENTS ═══ */
.salary-hero{background:linear-gradient(135deg,var(--navy-dark),var(--navy-mid));border-radius:var(--radius);padding:24px 20px;text-align:center;margin-bottom:16px;box-shadow:var(--shadow-md)}
.sal-month{font-size:14px;color:rgba(255,255,255,.6);font-weight:600;margin-bottom:4px;display:flex;align-items:center;justify-content:center;gap:8px}
.sal-net{font-size:36px;font-weight:800;color:var(--gold);margin:4px 0}
.sal-label{font-size:11px;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:1px;margin-bottom:16px}
.sal-split{display:flex;gap:16px;justify-content:center;padding-top:14px;border-top:1px solid rgba(255,255,255,.1)}
.sal-split>div{text-align:center}
.sal-split span{display:block}
.sal-gross span:first-child,.sal-ded span:first-child{font-size:10px;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.3px}
.sal-gross span:last-child{font-size:16px;font-weight:700;color:var(--success)}
.sal-ded span:last-child{font-size:16px;font-weight:700;color:#f87171}
.sal-breakdown{background:var(--bg-card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:16px}
.sal-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);font-size:13px;font-weight:500}
.sal-row:last-child{border-bottom:none}
.sal-row.ded{color:var(--danger)}
.prev-slips{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.prev-slip{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-sm);font-size:13px;font-weight:500;gap:8px}
.prev-amt{font-weight:700;color:var(--gold-dim)}

/* ═══ DETAIL PAGES ═══ */
.detail-header{background:var(--bg-card);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);margin-bottom:16px}
.detail-title{font-size:18px;font-weight:800;color:var(--text-primary)}
.detail-subtitle{font-size:12px;color:var(--text-secondary);margin-bottom:12px}
.detail-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px}
.detail-row:last-of-type{border-bottom:none}
.detail-label{color:var(--text-secondary);font-weight:500}
.detail-value{font-weight:600;color:var(--text-primary);text-align:right}
.detail-reason{margin-top:12px;padding:12px;background:var(--bg-page);border-radius:var(--radius-sm);font-size:12px;color:var(--text-secondary);line-height:1.6;border-left:3px solid var(--gold)}

/* ═══ FORM CARDS ═══ */
.form-card{background:var(--bg-card);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm)}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.3px}
.form-row{display:flex;gap:12px}
.form-row .form-group{flex:1}
.upload-box{border:2px dashed var(--border);border-radius:var(--radius-sm);padding:20px;text-align:center;cursor:pointer;transition:border-color .2s;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-muted);font-size:12px}
.upload-box:hover{border-color:var(--gold)}

/* ═══ TOGGLE SWITCH ═══ */
.toggle{width:42px;height:24px;border-radius:12px;background:#d1d5db;position:relative;cursor:pointer;transition:background .3s;flex-shrink:0}
.toggle::after{content:'';position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .3s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.toggle.on{background:var(--gold)}
.toggle.on::after{transform:translateX(18px)}

/* ═══ ACTION FOOTER ═══ */
.action-footer{display:flex;gap:12px;padding:12px 16px;background:var(--bg-card);border-top:1px solid var(--border);flex-shrink:0}
.btn-reject{flex:1;padding:12px;border:2px solid var(--danger);border-radius:var(--radius-sm);background:transparent;color:var(--danger);font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s}
.btn-reject:active{background:var(--danger-bg)}
.btn-approve{flex:1;padding:12px;border:none;border-radius:var(--radius-sm);background:var(--success);color:#fff;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s}
.btn-approve:active{opacity:.85}
.btn-cancel{flex:1;padding:12px;border:2px solid var(--danger);border-radius:var(--radius-sm);background:transparent;color:var(--danger);font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:6px}

/* ═══ TOAST NOTIFICATION ═══ */
.toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--navy-dark);color:#fff;padding:10px 20px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;box-shadow:var(--shadow-md);opacity:0;transition:all .3s;z-index:100;white-space:nowrap}
.toast-show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ═══ NOTIFICATIONS ═══ */
.notif-list{display:flex;flex-direction:column;gap:8px}
.notif-card{display:flex;gap:12px;padding:12px;background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:all .2s;border-left:3px solid transparent}
.notif-card.unread{border-left-color:var(--gold);background:linear-gradient(135deg,#fffbeb,var(--bg-card))}
.notif-icon-circle{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.notif-body{display:flex;flex-direction:column;gap:2px;flex:1}
.notif-title{font-size:13px;font-weight:700;color:var(--text-primary)}
.notif-msg{font-size:12px;color:var(--text-secondary);line-height:1.4}
.notif-time{font-size:10px;color:var(--text-muted);margin-top:2px}

/* ═══ LOGIN / AUTH PAGES ═══ */
.auth-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100%;padding:32px 24px;background:linear-gradient(180deg,var(--navy-dark) 0%,var(--navy-mid) 50%,#334155 100%)}
.auth-logo{font-size:28px;font-weight:800;color:#fff;margin-bottom:8px}
.auth-subtitle{font-size:13px;color:rgba(255,255,255,.5);margin-bottom:32px}
.auth-card{width:100%;background:var(--bg-card);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-md)}

/* ═══ PROFILE ═══ */
.profile-header{background:linear-gradient(135deg,var(--navy-dark),var(--navy-mid));padding:24px 20px;text-align:center;flex-shrink:0}
.profile-avatar-lg{width:72px;height:72px;border-radius:50%;background:var(--gold);color:var(--navy-dark);font-size:28px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;border:3px solid rgba(255,255,255,.2)}
.profile-name{font-size:20px;font-weight:800;color:#fff;margin-bottom:4px}
.profile-id{font-size:12px;color:rgba(255,255,255,.5);margin-bottom:16px}
.profile-info{display:flex;justify-content:center;gap:24px}
.profile-stat{text-align:center}
.profile-stat-num{font-size:18px;font-weight:800;color:var(--gold);display:block}
.profile-stat-label{font-size:10px;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.5px}
