/* RBC Leave Portal — Styles
   Extracted from index.html as part of file structure refactor
   Do not add inline styles to index.html — all styles belong here */
:root {
  --bg:#f4f1ec; --bg2:#ede9e2; --bg3:#e4dfd6;
  --panel:#ffffff; --navy:#13223a; --navy2:#1d3354;
  --blue:#1a5fd4; --blue-light:#e8f0fd;
  --gold:#c47f17; --gold-light:#fdf3e0;
  --green:#1a7a4a; --green-light:#e4f5ec;
  --red:#c0392b; --red-light:#fdecea;
  --amber:#b45309; --amber-light:#fef3c7;
  --purple:#5b21b6; --purple-light:#ede9fe;
  --teal:#0e7490; --teal-light:#e0f2fe;
  --text:#13223a; --text2:#4a5568; --text3:#8a9ab0;
  --border:#ddd8cf; --border2:#e8e4dd;
  --shadow:0 2px 12px rgba(19,34,58,0.08);
  --shadow-lg:0 8px 40px rgba(19,34,58,0.16);
}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;font-size:14px;}

/* ── TOP NAV ── */
.topnav{background:var(--navy);display:flex;align-items:center;padding:0 24px;height:58px;gap:18px;position:sticky;top:0;z-index:200;box-shadow:0 2px 16px rgba(0,0,0,0.22);}
.nav-logo{display:flex;align-items:center;gap:14px;margin-right:4px;flex-shrink:0;}
.nav-logo-img{height:26px;width:auto;filter:brightness(0) invert(1);flex-shrink:0;}
.nav-logo-divider{width:1px;height:28px;background:rgba(255,255,255,0.18);}
.nav-logo-text{font-family:'Syne',sans-serif;font-weight:700;font-size:13px;color:rgba(255,255,255,0.92);line-height:1.15;letter-spacing:0.2px;}
.nav-logo-sub{font-size:9px;color:rgba(255,255,255,0.38);letter-spacing:1.8px;text-transform:uppercase;font-weight:400;}
.nav-divider{width:1px;height:28px;background:rgba(255,255,255,0.1);flex-shrink:0;}
.nav-tabs{display:flex;gap:2px;}
.nav-tab{background:none;border:none;color:rgba(255,255,255,0.48);font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;padding:7px 14px;border-radius:6px;cursor:pointer;transition:all 0.15s;display:flex;align-items:center;gap:7px;white-space:nowrap;}
.nav-tab:hover{color:white;background:rgba(255,255,255,0.07);}
.nav-tab.active{color:white;background:rgba(255,255,255,0.12);}
.nav-tab .ndot{width:7px;height:7px;border-radius:50%;background:var(--gold);display:none;animation:pdot 2s infinite;}
.nav-tab.has-pending .ndot{display:block;}
@keyframes pdot{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.6;transform:scale(1.3);}}
.nav-spacer{flex:1;}
.mgr-login-btn{background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.18);color:rgba(255,255,255,0.78);font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;padding:7px 16px;border-radius:6px;cursor:pointer;transition:all 0.15s;display:flex;align-items:center;gap:7px;white-space:nowrap;letter-spacing:0.2px;}
.mgr-login-btn:hover{background:rgba(255,255,255,0.15);color:white;border-color:rgba(255,255,255,0.32);}
.mgr-login-btn .key-icon{font-size:13px;}
.nav-user-pill{display:flex;align-items:center;gap:10px;padding:5px 12px 5px 6px;border-radius:8px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);}
.nav-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-size:11px;font-weight:700;color:white;flex-shrink:0;}
.nav-user-name{color:white;font-size:13px;font-weight:500;line-height:1.2;}
.nav-user-role{color:rgba(255,255,255,0.38);font-size:10px;letter-spacing:0.4px;text-transform:uppercase;}
.logout-btn{background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.12);color:rgba(255,255,255,0.6);font-size:11px;font-weight:600;padding:5px 10px;border-radius:5px;cursor:pointer;transition:all 0.15s;white-space:nowrap;font-family:'DM Sans',sans-serif;}
.logout-btn:hover{background:rgba(192,57,43,0.2);border-color:rgba(192,57,43,0.4);color:#fca5a5;}

/* ── LOGIN MODAL ── */
.login-overlay{position:fixed;inset:0;background:rgba(10,20,40,0.65);z-index:500;display:none;align-items:center;justify-content:center;backdrop-filter:blur(6px);padding:20px;}
.login-overlay.open{display:flex;}
.login-box{background:white;border-radius:16px;box-shadow:var(--shadow-lg);width:100%;max-width:400px;overflow:hidden;animation:modalIn 0.22s cubic-bezier(.34,1.3,.64,1);}
.login-header{background:var(--navy);padding:32px 32px 26px;text-align:center;position:relative;}
.login-header-logo{height:20px;filter:brightness(0) invert(1);margin-bottom:20px;opacity:0.9;}
.login-lockicon{width:48px;height:48px;border-radius:12px;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.12);display:flex;align-items:center;justify-content:center;font-size:22px;margin:0 auto 16px;}
.login-title{font-family:'Syne',sans-serif;font-size:19px;font-weight:800;color:white;margin-bottom:5px;}
.login-sub{font-size:12px;color:rgba(255,255,255,0.4);letter-spacing:0.4px;}
.login-body{padding:28px 32px 32px;}
.login-field{margin-bottom:16px;}
.login-field label{display:block;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:6px;letter-spacing:0.2px;}
.login-field input{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:7px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:14px;padding:10px 13px;outline:none;transition:border-color .15s,box-shadow .15s;}
.login-field input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,95,212,0.12);background:white;}
.login-err{color:var(--red);font-size:12px;margin-top:10px;text-align:center;display:none;background:var(--red-light);padding:8px 12px;border-radius:6px;}
.login-err.show{display:block;}
.login-submit{width:100%;background:var(--blue);color:white;border:none;border-radius:8px;font-family:'Syne',sans-serif;font-size:14px;font-weight:700;letter-spacing:0.4px;padding:12px;cursor:pointer;transition:all .15s;margin-top:6px;box-shadow:0 2px 10px rgba(26,95,212,0.28);}
.login-submit:hover{background:#1550b8;transform:translateY(-1px);box-shadow:0 4px 16px rgba(26,95,212,0.35);}
.login-cancel{display:block;text-align:center;margin-top:14px;font-size:12px;color:var(--text3);cursor:pointer;transition:color .15s;}
.login-cancel:hover{color:var(--text2);}

/* ── LAYOUT ── */
.app{display:flex;min-height:calc(100vh - 58px);}
.sidebar{width:224px;flex-shrink:0;background:var(--panel);border-right:1px solid var(--border);padding:18px 0;display:flex;flex-direction:column;}
.sidebar-label{font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text3);padding:14px 20px 6px;}
.sidebar-item{display:flex;align-items:center;gap:10px;padding:9px 20px;cursor:pointer;color:var(--text2);font-size:13px;font-weight:500;border-left:3px solid transparent;transition:background .12s,color .12s;}
.sidebar-item:hover{background:var(--bg2);color:var(--text);}
.sidebar-item.active{background:var(--blue-light);color:var(--blue);border-left-color:var(--blue);font-weight:600;}
.sidebar-item .icon{width:16px;text-align:center;font-size:14px;flex-shrink:0;}
.sbadge{margin-left:auto;background:var(--red);color:white;font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px;font-family:'DM Mono',monospace;min-width:20px;text-align:center;}
.sidebar-divider{height:1px;background:var(--border2);margin:10px 16px;}
.main{flex:1;overflow-y:auto;overflow-x:hidden;}
.view{display:none;padding:28px 32px;animation:fadeIn 0.2s ease;}
/* CENTERED FORM — remove the next line to revert to left-aligned */
.view > .card{margin-left:auto;margin-right:auto;}
.view.active{display:block;}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@keyframes modalIn{from{opacity:0;transform:scale(.95) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}

/* ── PAGE HEADERS ── */
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:28px;gap:16px;}
.page-title{font-family:'Syne',sans-serif;font-size:22px;font-weight:800;color:var(--navy);margin-bottom:3px;}
.page-subtitle{color:var(--text3);font-size:13px;}

/* ── STAT CARDS ── */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;}
.stat-card{background:var(--panel);border:1px solid var(--border2);border-radius:10px;padding:18px 20px;box-shadow:var(--shadow);}
.stat-label{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);margin-bottom:8px;}
.stat-value{font-family:'Syne',sans-serif;font-size:28px;font-weight:800;color:var(--navy);line-height:1;margin-bottom:4px;}
.stat-sub{font-size:12px;color:var(--text3);}
.stat-card.hl{background:var(--navy);}
.stat-card.hl .stat-label{color:rgba(255,255,255,0.38);}
.stat-card.hl .stat-value{color:white;}
.stat-card.hl .stat-sub{color:rgba(255,255,255,0.38);}

/* ── CARDS ── */
.card{background:var(--panel);border:1px solid var(--border2);border-radius:10px;box-shadow:var(--shadow);overflow:hidden;margin-bottom:20px;}
.card:last-child{margin-bottom:0;}
.card-header{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;border-bottom:1px solid var(--border2);}
.card-title{font-family:'Syne',sans-serif;font-size:14px;font-weight:700;color:var(--navy);}
.card-body{padding:22px;}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.three-col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;}

/* ── FORM ── */
.form-section{margin-bottom:26px;}
.form-section-title{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text3);margin-bottom:14px;display:flex;align-items:center;gap:8px;}
.form-section-title::after{content:'';flex:1;height:1px;background:var(--border);}
.field{display:flex;flex-direction:column;gap:5px;}
.field label{font-size:12px;font-weight:600;color:var(--text2);}
input[type=text],input[type=email],input[type=date],input[type=password],input[type=number],select,textarea{background:var(--bg);border:1.5px solid var(--border);border-radius:7px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:14px;padding:9px 13px;transition:border-color .15s,box-shadow .15s;outline:none;width:100%;appearance:none;}
input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,95,212,0.1);background:white;}
input.err,select.err{border-color:var(--red);}
.err-msg{color:var(--red);font-size:11px;display:none;}
.err-msg.show{display:block;}
select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%238a9ab0'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;cursor:pointer;}
textarea{resize:vertical;min-height:82px;}
input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.5;}
.field-row{display:grid;gap:14px;margin-bottom:14px;}
.col2{grid-template-columns:1fr 1fr;}
.col3{grid-template-columns:1fr 1fr 1fr;}
.col1{grid-template-columns:1fr;}

/* Leave type buttons */
.leave-types{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
.leave-btn{background:var(--bg);border:1.5px solid var(--border);border-radius:8px;padding:14px 16px;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:12px;text-align:left;position:relative;}
.leave-btn:hover{border-color:var(--blue);background:var(--blue-light);}
.leave-btn.sel{border-color:var(--blue);background:var(--blue-light);box-shadow:0 0 0 3px rgba(26,95,212,0.1);}
.leave-btn.disabled{opacity:.4;cursor:not-allowed;pointer-events:none;}
.leave-btn-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.leave-btn-text strong{display:block;font-size:13px;font-weight:600;color:var(--navy);margin-bottom:2px;}
.leave-btn-text span{font-size:11px;color:var(--text3);}
.balance-tag{position:absolute;top:8px;right:10px;font-family:'DM Mono',monospace;font-size:10px;font-weight:700;padding:2px 7px;border-radius:4px;}
.btag-ok{background:var(--green-light);color:var(--green);}
.btag-low{background:var(--amber-light);color:var(--amber);}
.btag-zero{background:var(--red-light);color:var(--red);}

/* Days display */
.days-display{background:var(--blue-light);border:1.5px solid rgba(26,95,212,0.2);border-radius:8px;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;margin-top:4px;}
.days-display-label{font-size:12px;color:var(--blue);font-weight:500;}
.days-display-value{font-family:'Syne',sans-serif;font-size:22px;font-weight:800;color:var(--blue);}
.days-display.warn{background:var(--red-light);border-color:rgba(192,57,43,0.25);}
.days-display.warn .days-display-label,.days-display.warn .days-display-value{color:var(--red);}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 20px;border-radius:7px;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;border:none;white-space:nowrap;}
.btn-primary{background:var(--blue);color:white;box-shadow:0 2px 8px rgba(26,95,212,0.28);}
.btn-primary:hover{background:#1550b8;transform:translateY(-1px);}
.btn-primary:disabled{opacity:.55;cursor:not-allowed;transform:none;}
.btn-success{background:var(--green);color:white;}
.btn-success:hover{background:#156038;}
.btn-danger{background:var(--red);color:white;}
.btn-danger:hover{background:#a32b20;}
.btn-ghost{background:none;border:1.5px solid var(--border);color:var(--text2);}
.btn-ghost:hover{background:var(--bg2);}
.btn-purple{background:var(--purple);color:white;}
.btn-purple:hover{background:#4c1d95;}
.btn-sm{padding:6px 14px;font-size:12px;}

/* ── TABLES ── */
.req-table{width:100%;border-collapse:collapse;}
.req-table th{text-align:left;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);padding:10px 16px;border-bottom:1px solid var(--border);background:var(--bg);}
.req-table td{padding:12px 16px;border-bottom:1px solid var(--border2);vertical-align:middle;}
.req-table tr:last-child td{border-bottom:none;}
.req-table tbody tr:hover{background:var(--bg2);}

/* Pills & chips */
.status-pill{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;}
.status-pill::before{content:'';width:6px;height:6px;border-radius:50%;}
.pill-pending{background:var(--amber-light);color:var(--amber);}
.pill-pending::before{background:var(--amber);}
.pill-approved{background:var(--green-light);color:var(--green);}
.pill-approved::before{background:var(--green);}
.pill-denied{background:var(--red-light);color:var(--red);}
.pill-denied::before{background:var(--red);}
.leave-type-chip{display:inline-block;padding:3px 9px;border-radius:5px;font-size:11px;font-weight:600;}
.chip-vacation{background:var(--blue-light);color:var(--blue);}
.chip-sick{background:var(--red-light);color:var(--red);}
.chip-exempt{background:var(--purple-light);color:var(--purple);}
.chip-personal{background:var(--green-light);color:var(--green);}

/* Emp cell */
.emp-cell{display:flex;align-items:center;gap:10px;}
.emp-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:white;flex-shrink:0;}
.emp-name{font-weight:600;font-size:13px;}
.emp-dept{font-size:11px;color:var(--text3);}

/* Role badges */
.role-badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:12px;font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;}
.rb-supervisor{background:var(--blue-light);color:var(--blue);}
.rb-manager{background:var(--teal-light);color:var(--teal);}
.rb-director{background:var(--purple-light);color:var(--purple);}
.rb-hr{background:#fdf4ff;color:#7e22ce;}

/* ── APPROVAL MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(19,34,58,0.52);z-index:300;display:none;align-items:center;justify-content:center;backdrop-filter:blur(3px);padding:20px;}
.modal-overlay.open{display:flex;}
.modal{background:white;border-radius:14px;box-shadow:var(--shadow-lg);width:100%;max-width:520px;animation:modalIn .2s ease;overflow:hidden;}
.modal-header{padding:20px 26px 16px;border-bottom:1px solid var(--border2);display:flex;align-items:center;justify-content:space-between;}
.modal-title{font-family:'Syne',sans-serif;font-size:17px;font-weight:800;color:var(--navy);}
.modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--text3);padding:4px 6px;border-radius:4px;line-height:1;}
.modal-close:hover{background:var(--bg2);color:var(--text);}
.modal-body{padding:22px 26px;max-height:65vh;overflow-y:auto;}
.modal-footer{padding:16px 26px;border-top:1px solid var(--border2);display:flex;gap:10px;justify-content:flex-end;}
.rd-row{display:flex;justify-content:space-between;align-items:flex-start;padding:9px 0;border-bottom:1px solid var(--border2);}
.rd-row:last-of-type{border-bottom:none;}
.rd-label{font-size:12px;color:var(--text3);font-weight:500;flex-shrink:0;margin-right:16px;}
.rd-value{font-size:13px;font-weight:600;color:var(--navy);text-align:right;}

/* ── LEAVE BALANCES ── */
.bal-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;}
.bal-card{background:var(--bg);border:1.5px solid var(--border);border-radius:10px;padding:16px;}
.bal-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.bal-type{font-size:12px;font-weight:700;color:var(--text2);display:flex;align-items:center;gap:7px;}
.bal-bar{height:8px;background:var(--border);border-radius:4px;overflow:hidden;margin-bottom:8px;}
.bal-fill{height:100%;border-radius:4px;transition:width .6s ease;}
.bal-nums{display:flex;justify-content:space-between;font-size:11px;}

/* ── CALENDAR ── */
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;}
.cal-hcell{text-align:center;font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text3);padding:8px 0;}
.cal-cell{border-radius:6px;min-height:68px;padding:5px;background:var(--bg);border:1px solid var(--border2);position:relative;}
.cal-cell.other{opacity:.3;}
.cal-cell.today{border-color:var(--blue);background:var(--blue-light);}
.cal-date{font-size:11px;font-weight:600;color:var(--text2);margin-bottom:3px;}
.cal-cell.today .cal-date{color:var(--blue);font-weight:800;}
.cal-evt{font-size:10px;font-weight:600;padding:2px 5px;border-radius:3px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.cal-nav{display:flex;align-items:center;gap:12px;margin-bottom:16px;}
.cal-nav-btn{background:none;border:1.5px solid var(--border);border-radius:6px;width:30px;height:30px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--text2);transition:all .1s;}
.cal-nav-btn:hover{background:var(--bg2);}
.cal-month{font-family:'Syne',sans-serif;font-size:16px;font-weight:800;color:var(--navy);}

/* ── TOASTS ── */
.toast-container{position:fixed;top:68px;right:20px;z-index:400;display:flex;flex-direction:column;gap:8px;pointer-events:none;}
.toast{background:var(--navy);color:white;border-radius:10px;padding:13px 16px;box-shadow:var(--shadow-lg);display:flex;align-items:flex-start;gap:12px;max-width:340px;animation:toastIn .3s ease;pointer-events:all;border-left:4px solid var(--blue);}
.toast.success{border-left-color:var(--green);}
.toast.warning{border-left-color:var(--gold);}
.toast.error{border-left-color:var(--red);}
@keyframes toastIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
.toast-icon{font-size:16px;flex-shrink:0;margin-top:1px;}
.toast-text strong{display:block;font-size:13px;margin-bottom:2px;font-family:'Syne',sans-serif;}
.toast-text span{font-size:12px;color:rgba(255,255,255,0.58);}

/* ── SUCCESS ── */
.success-screen{text-align:center;padding:48px 28px;}
.success-ring{width:72px;height:72px;border-radius:50%;background:var(--green-light);border:2px solid var(--green);display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 20px;}
.success-title{font-family:'Syne',sans-serif;font-size:22px;font-weight:800;margin-bottom:8px;color:var(--navy);}
.success-ref{font-family:'DM Mono',monospace;font-size:13px;color:var(--blue);margin-bottom:16px;}
.success-body{color:var(--text2);line-height:1.6;margin-bottom:24px;font-size:13px;}
.email-preview{background:var(--bg);border:1px solid var(--border);border-radius:8px;text-align:left;padding:14px 16px;margin-bottom:18px;}
.eml-label{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);margin-bottom:10px;}
.eml-row{display:flex;gap:8px;margin-bottom:4px;font-size:12px;}
.eml-key{color:var(--text3);font-weight:600;width:54px;flex-shrink:0;}
.eml-div{border:none;border-top:1px solid var(--border);margin:8px 0;}
.eml-body{font-size:12px;color:var(--text2);line-height:1.6;}
.notif-sent{display:inline-flex;align-items:center;gap:5px;background:var(--green-light);color:var(--green);border:1px solid rgba(26,122,74,0.2);font-size:11px;font-weight:600;padding:4px 10px;border-radius:5px;}

/* ── EMP LOOKUP ── */
.emp-lookup-indicator{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:600;min-height:20px;margin-top:5px;}
.emp-lookup-indicator.found{color:var(--green);}
.emp-lookup-indicator.notfound{color:var(--red);}
.emp-lookup-indicator.looking{color:var(--text3);}
.lookup-spinner{width:12px;height:12px;border:2px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0;}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── HR BANNER ── */
.hr-banner{background:linear-gradient(135deg,#2e1065,#4c1d95);border-radius:10px;padding:20px 24px;margin-bottom:24px;display:flex;align-items:center;justify-content:space-between;gap:16px;}
.hr-banner-text strong{display:block;font-family:'Syne',sans-serif;font-size:15px;font-weight:800;color:white;margin-bottom:4px;}
.hr-banner-text span{font-size:12px;color:rgba(255,255,255,0.55);}
.hr-banner-badges{display:flex;gap:8px;flex-wrap:wrap;flex-shrink:0;}
.hr-badge{background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.18);color:rgba(255,255,255,0.88);font-size:11px;font-weight:600;padding:5px 12px;border-radius:20px;}

/* Notif feed */
.notif-feed{padding:0 14px;}
.notif-item{display:flex;gap:10px;padding:10px 0;border-bottom:1px solid var(--border2);cursor:pointer;}
.notif-item:last-child{border-bottom:none;}
.ndot2{width:7px;height:7px;border-radius:50%;background:var(--blue);flex-shrink:0;margin-top:5px;}
.ndot2.read{background:var(--border);}
.notif-msg{font-size:12px;color:var(--text2);line-height:1.4;}
.notif-time{font-size:10px;color:var(--text3);margin-top:2px;}

/* Empty state */
.empty-state{text-align:center;padding:48px 20px;color:var(--text3);}
.empty-state .ei{font-size:36px;margin-bottom:12px;}
.empty-state p{font-size:13px;line-height:1.6;}

/* Code block */
.code-block{background:var(--navy);color:#a5f3fc;padding:16px;border-radius:8px;font-size:12px;overflow-x:auto;font-family:'DM Mono',monospace;line-height:1.6;margin:12px 0;}

/* Responsive */
@media(max-width:900px){.sidebar{display:none;}.stat-row{grid-template-columns:1fr 1fr;}.two-col{grid-template-columns:1fr;}.three-col{grid-template-columns:1fr 1fr;}}
@media(max-width:600px){
html,body{overflow-x:hidden;}
.view{padding:18px 14px;}
.stat-row{grid-template-columns:1fr 1fr;}
.leave-types{grid-template-columns:1fr;}
.field-row.col3{grid-template-columns:1fr 1fr;}
.topnav{padding:0 12px;gap:8px;overflow:hidden;}
.nav-logo-text,.nav-logo-sub,.nav-logo-divider{display:none;}
.nav-logo-img{height:22px;}
.nav-divider{display:none;}
.nav-tab{padding:6px 8px;font-size:16px;}
.nav-tab-label{display:none;}
.mgr-login-btn{padding:6px 10px;font-size:0;gap:0;}
.mgr-login-btn .key-icon{font-size:16px;}
.nav-user-name,.nav-user-role{display:none;}
.nav-user-pill{padding:4px 6px;}
.logout-btn{font-size:11px;padding:5px 8px;}
}
/* ── Read-only auto-populated fields ── */
input[readonly]{background:var(--bg2);cursor:default;}
input[readonly]:focus{border-color:var(--border);box-shadow:none;background:var(--bg2);}
/* ── Language selector ── */
.lang-select-wrap{padding:10px 14px 4px}
.lang-select-label{font-size:10px;font-weight:600;color:var(--text3);letter-spacing:.5px;text-transform:uppercase;margin-bottom:4px}
.lang-select-drop{width:100%;padding:5px 8px;border:1px solid var(--border2);border-radius:6px;background:var(--bg2);font-size:12px;color:var(--text1);cursor:pointer}
/* ── RTL overrides (Arabic / Dari) ── */
.rtl-active .sidebar{border-right:none;border-left:1px solid var(--border2)}
.rtl-active .field input,.rtl-active .field textarea,.rtl-active .field select{direction:rtl;text-align:right}
.rtl-active .form-section-title,.rtl-active .page-title,.rtl-active .page-subtitle,.rtl-active .card-title{text-align:right}
.rtl-active .field label{display:block;text-align:right}
.rtl-active .leave-btn{flex-direction:row-reverse;text-align:right}
.rtl-active .leave-btn-text{text-align:right}
.rtl-active .days-display{flex-direction:row-reverse}
.rtl-active .emp-lookup-indicator{text-align:right}
.rtl-active .err-msg{text-align:right}
