@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600&family=Lora:wght@600&display=swap');

/* ── Reset ───────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{height:100%}
body{font-family:'Outfit',sans-serif;font-size:14px;line-height:1.5;color:var(--text-primary);background:var(--bg-page);height:100%;transition:background .25s,color .25s}

/* ══════════════════════════════════════════════════════════
   LIGHT MODE (default)
   ══════════════════════════════════════════════════════════ */
:root{
  --blue:        #0d4f8b;
  --blue-l:      #dce9f7;
  --blue-d:      #083869;
  --green:       #2d6a1f;
  --green-l:     #e2f0d8;
  --amber:       #7a4400;
  --amber-l:     #fde8c7;
  --red:         #8b1a1a;
  --red-l:       #fde0e0;
  --gray:        #5a5850;
  --gray-l:      #eeece6;
  --sidebar-w:   220px;
  --hdr:         54px;
  --radius:      8px;
  --radius-lg:   12px;
  /* Semantic */
  --bg-page:     #f5f4f0;
  --bg-card:     #ffffff;
  --bg-surface:  #fafaf7;
  --bg-input:    #ffffff;
  --bg-sidebar:  #0d1f35;
  --bg-hover:    #f5f3ec;
  --border:      #dbd9d0;
  --border-soft: #f0ede6;
  --text-primary:#1a1a1a;
  --text-muted:  #5a5850;
  --text-hint:   #999691;
  --topbar-bg:   #ffffff;
  --shadow:      0 1px 3px rgba(0,0,0,.08);
  --shadow-md:   0 4px 12px rgba(0,0,0,.1);
}

/* ══════════════════════════════════════════════════════════
   DARK MODE
   ══════════════════════════════════════════════════════════ */
html[data-theme="dark"]{
  --bg-page:     #0f1117;
  --bg-card:     #1a1d26;
  --bg-surface:  #21242f;
  --bg-input:    #21242f;
  --bg-sidebar:  #080b12;
  --bg-hover:    #21242f;
  --border:      #2a2e3d;
  --border-soft: #1e2130;
  --text-primary:#dee0e8;
  --text-muted:  #7b7f96;
  --text-hint:   #4a4e62;
  --topbar-bg:   #1a1d26;
  --shadow:      0 1px 4px rgba(0,0,0,.5);
  --shadow-md:   0 4px 16px rgba(0,0,0,.6);
  /* Adjust accent fills for dark */
  --blue-l:      rgba(13,79,139,.25);
  --blue-d:      #79b8f5;
  --green-l:     rgba(45,106,31,.25);
  --green:       #6ecf7a;
  --amber-l:     rgba(122,68,0,.25);
  --amber:       #f0b45a;
  --red-l:       rgba(139,26,26,.25);
  --red:         #f08080;
  --gray-l:      rgba(90,88,80,.2);
  --gray:        #7b7f96;
}

/* ── Theme Toggle Button ─────────────────────────────────── */
.theme-toggle{width:36px;height:36px;border-radius:8px;border:1px solid var(--border);background:var(--bg-card);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s;flex-shrink:0}
.theme-toggle:hover{background:var(--bg-surface)}
.theme-toggle svg{width:16px;height:16px;stroke:var(--text-muted);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.icon-sun{display:none}
.icon-moon{display:block}
html[data-theme="dark"] .icon-sun{display:block}
html[data-theme="dark"] .icon-moon{display:none}

/* ── Layout ──────────────────────────────────────────────── */
.app-shell{display:flex;height:100vh;overflow:hidden}
.sidebar{width:var(--sidebar-w);background:var(--bg-sidebar);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;transition:background .25s}
.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden}
.topbar{height:var(--hdr);background:var(--topbar-bg);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:12px;flex-shrink:0;transition:background .25s}
.page-content{flex:1;overflow-y:auto;padding:24px;background:var(--bg-page);transition:background .25s}

/* ── Sidebar ─────────────────────────────────────────────── */
.sb-brand{padding:16px 18px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:10px}
.sb-brand-icon{width:34px;height:34px;background:var(--blue);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sb-brand-icon svg{width:18px;height:18px;stroke:white;fill:none}
.sb-brand-text{font-size:15px;font-weight:600;color:#fff}
.sb-brand-sub{font-size:10px;color:rgba(255,255,255,.4);margin-top:1px}
.sb-company{margin:10px;padding:10px 12px;background:rgba(255,255,255,.06);border-radius:var(--radius);border:1px solid rgba(255,255,255,.08)}
.sb-company-label{font-size:10px;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.05em}
.sb-company-name{font-size:12px;color:#fff;font-weight:500;margin-top:2px}
.sb-section{padding:12px 14px 3px;font-size:10px;color:rgba(255,255,255,.3);text-transform:uppercase;letter-spacing:.06em}
.sb-link{display:flex;align-items:center;gap:9px;padding:8px 14px;margin:1px 8px;border-radius:6px;color:rgba(255,255,255,.55);font-size:12.5px;cursor:pointer;text-decoration:none;transition:background .12s,color .12s}
.sb-link:hover{background:rgba(255,255,255,.07);color:#fff}
.sb-link.active{background:rgba(255,255,255,.12);color:#fff;font-weight:500}
.sb-link svg{width:14px;height:14px;stroke:currentColor;fill:none;flex-shrink:0;stroke-width:1.8}
.sb-badge{margin-left:auto;background:var(--blue);color:#fff;font-size:10px;padding:1px 6px;border-radius:10px;font-weight:500}
.sb-footer{padding:12px 14px;border-top:1px solid rgba(255,255,255,.08);margin-top:auto}
.sb-user-name{font-size:12px;color:#fff;font-weight:500}
.sb-user-role{font-size:10px;color:rgba(255,255,255,.4);margin-top:2px}

/* ── Topbar ──────────────────────────────────────────────── */
.topbar-title{font-size:16px;font-weight:600;flex:1;color:var(--text-primary)}
.topbar-right{display:flex;align-items:center;gap:8px;margin-left:auto}
.av{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0}

/* ── Buttons ─────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-card);font-family:'Outfit',sans-serif;font-size:13px;font-weight:500;cursor:pointer;text-decoration:none;color:var(--text-primary);transition:background .12s,border-color .12s}
.btn:hover{background:var(--bg-hover)}
.btn svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2}
.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue)}
.btn-primary:hover{background:var(--blue-d)}
.btn-success{background:var(--green);color:#fff;border-color:var(--green)}
.btn-danger{background:var(--red);color:#fff;border-color:var(--red)}
.btn-sm{padding:4px 10px;font-size:12px}
.btn-icon{padding:6px;border-radius:6px}

/* ── Cards ───────────────────────────────────────────────── */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);transition:background .25s,border-color .25s}
.card-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}
.card-title{font-size:14px;font-weight:600;color:var(--text-primary)}
.card-body{padding:18px}
.card-body-flush{padding:0}

/* ── Stat cards ──────────────────────────────────────────── */
.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;transition:background .25s}
.stat-label{font-size:11px;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}
.stat-value{font-size:26px;font-weight:600;line-height:1;color:var(--text-primary)}
.stat-delta{font-size:12px;margin-top:5px}
.delta-up{color:var(--green)}.delta-dn{color:var(--red)}.delta-neutral{color:var(--text-muted)}

/* ── Grid layouts ────────────────────────────────────────── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}
.gap-y{margin-bottom:18px}

/* ── Tables ──────────────────────────────────────────────── */
.table-wrap{overflow-x:auto}
table.rh-table{width:100%;border-collapse:collapse;font-size:13px}
table.rh-table th{text-align:left;padding:10px 14px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);white-space:nowrap;background:var(--bg-card)}
table.rh-table td{padding:11px 14px;border-bottom:1px solid var(--border-soft);vertical-align:middle;color:var(--text-primary)}
table.rh-table tr:last-child td{border-bottom:none}
table.rh-table tr:hover td{background:var(--bg-hover)}
.td-name{display:flex;align-items:center;gap:10px}

/* ── Badges ──────────────────────────────────────────────── */
.badge{display:inline-block;padding:3px 8px;border-radius:4px;font-size:11px;font-weight:500}
.badge-green{background:var(--green-l);color:var(--green)}
.badge-amber{background:var(--amber-l);color:var(--amber)}
.badge-red{background:var(--red-l);color:var(--red)}
.badge-blue{background:var(--blue-l);color:var(--blue-d)}
.badge-gray{background:var(--gray-l);color:var(--gray)}

/* ── Forms ───────────────────────────────────────────────── */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.field{display:flex;flex-direction:column;gap:5px}
.field label{font-size:12px;font-weight:500;color:var(--text-muted)}
.field input,.field select,.field textarea{padding:8px 12px;border-radius:var(--radius);border:1px solid var(--border);font-family:'Outfit',sans-serif;font-size:13px;color:var(--text-primary);background:var(--bg-input);transition:border-color .15s,background .25s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(13,79,139,.12)}
.field textarea{resize:vertical;min-height:80px}
.field-full{grid-column:1/-1}
.field-note{font-size:11px;color:var(--text-muted);margin-top:2px}

/* ── File upload zone ────────────────────────────────────── */
.upload-zone{border:2px dashed var(--border);border-radius:var(--radius-lg);padding:24px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s;background:var(--bg-surface)}
.upload-zone:hover,.upload-zone.drag-over{border-color:var(--blue);background:var(--blue-l)}
.upload-zone input[type=file]{display:none}
.upload-zone-icon{font-size:28px;margin-bottom:8px}
.upload-zone-label{font-size:13px;font-weight:500;color:var(--text-primary);margin-bottom:4px}
.upload-zone-hint{font-size:12px;color:var(--text-muted)}
.upload-file-list{margin-top:12px;display:flex;flex-direction:column;gap:6px}
.upload-file-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);font-size:12px}
.upload-file-name{font-weight:500;color:var(--text-primary)}
.upload-file-size{color:var(--text-muted)}
.upload-file-remove{cursor:pointer;color:var(--red);font-size:14px;padding:0 4px}

/* ── Alerts / Flash ──────────────────────────────────────── */
.alert{padding:10px 14px;border-radius:var(--radius);font-size:13px;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.alert-success{background:var(--green-l);color:var(--green);border:1px solid var(--green)}
.alert-error{background:var(--red-l);color:var(--red);border:1px solid var(--red)}
.alert-info{background:var(--blue-l);color:var(--blue-d);border:1px solid var(--blue)}
.alert-warning{background:var(--amber-l);color:var(--amber);border:1px solid var(--amber)}

/* ── Modal ───────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;display:flex;align-items:center;justify-content:center;padding:16px}
.modal-box{background:var(--bg-card);border-radius:var(--radius-lg);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-md);border:1px solid var(--border)}
.modal-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-title{font-size:15px;font-weight:600;color:var(--text-primary)}
.modal-body{padding:20px}
.modal-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end}

/* ── Search bar ──────────────────────────────────────────── */
.search-bar{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.search-input{flex:1;min-width:200px;padding:8px 12px;border-radius:var(--radius);border:1px solid var(--border);font-family:'Outfit',sans-serif;font-size:13px;background:var(--bg-input);color:var(--text-primary)}
.search-input:focus{outline:none;border-color:var(--blue)}

/* ── Progress ────────────────────────────────────────────── */
.progress-wrap{margin-bottom:10px}
.progress-label{display:flex;justify-content:space-between;font-size:12px;margin-bottom:4px;color:var(--text-muted)}
.progress-bar{height:6px;background:var(--gray-l);border-radius:3px;overflow:hidden}
.progress-fill{height:100%;border-radius:3px;background:var(--blue);transition:width .4s}

/* ── Tabs ────────────────────────────────────────────────── */
.tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:18px;gap:0}
.tab{padding:10px 18px;font-size:13px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;color:var(--text-muted);transition:color .12s,border-color .12s;text-decoration:none}
.tab:hover{color:var(--text-primary)}
.tab.active{color:var(--blue);border-bottom-color:var(--blue)}

/* ── Employee card ───────────────────────────────────────── */
.emp-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;cursor:pointer;transition:border-color .15s,box-shadow .15s}
.emp-card:hover{border-color:var(--blue);box-shadow:0 2px 8px rgba(13,79,139,.12)}
.emp-av{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;flex-shrink:0}

/* ── Org chart ───────────────────────────────────────────── */
.org-chart{overflow-x:auto;padding:20px 0}
.org-level{display:flex;justify-content:center;gap:16px;position:relative}
.org-node{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;text-align:center;min-width:120px;cursor:pointer;transition:border-color .15s}
.org-node:hover,.org-node.root{border-color:var(--blue)}
.org-node.root{background:var(--blue-l)}
.org-connector{height:24px;display:flex;justify-content:center}
.org-vline{width:1px;height:100%;background:var(--border)}
.org-hline{height:1px;background:var(--border);position:absolute;top:0}

/* ── Bulletin paie ───────────────────────────────────────── */
.payslip{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:10px}
.payslip-header{padding:12px 16px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;user-select:none}
.payslip-name{font-weight:600;font-size:13px;color:var(--text-primary)}
.payslip-body{padding:0 16px 14px;border-top:1px solid var(--border);display:none}
.payslip-row{display:flex;justify-content:space-between;padding:6px 0;font-size:13px;border-bottom:1px solid var(--border-soft);color:var(--text-primary)}
.payslip-row:last-child{border:none;font-weight:600}
.payslip-row.total{font-size:14px;color:var(--blue)}

/* ── Pagination ──────────────────────────────────────────── */
.pagination{display:flex;align-items:center;gap:4px;margin-top:16px}
.page-link{padding:5px 10px;border-radius:6px;border:1px solid var(--border);font-size:12px;cursor:pointer;text-decoration:none;color:var(--text-primary);background:var(--bg-card)}
.page-link:hover,.page-link.active{background:var(--blue);color:#fff;border-color:var(--blue)}

/* ── Login page ──────────────────────────────────────────── */
.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0d1f35 0%,#0d4f8b 100%);padding:20px}
.login-card{background:var(--bg-card);border-radius:16px;padding:40px;width:100%;max-width:420px;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:32px;justify-content:center}
.login-logo-icon{width:44px;height:44px;background:var(--blue);border-radius:10px;display:flex;align-items:center;justify-content:center}
.login-logo-icon svg{width:22px;height:22px;stroke:#fff;fill:none}
.login-logo-text{font-family:'Lora',serif;font-size:22px;color:var(--text-primary)}
.login-title{font-size:20px;font-weight:600;margin-bottom:6px;text-align:center;color:var(--text-primary)}
.login-sub{font-size:13px;color:var(--text-muted);text-align:center;margin-bottom:28px}

/* ── Responsive ──────────────────────────────────────────── */
@media(max-width:768px){
  .sidebar{display:none}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .form-grid,.form-grid-3{grid-template-columns:1fr}
}

/* ── Utils ───────────────────────────────────────────────── */
.text-muted{color:var(--text-muted)}
.text-blue{color:var(--blue)}
.text-green{color:var(--green)}
.text-red{color:var(--red)}
.text-center{text-align:center}
.text-right{text-align:right}
.fw-500{font-weight:500}
.fw-600{font-weight:600}
.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}
.mb-4{margin-bottom:4px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}
.d-flex{display:flex}.align-center{align-items:center}.gap-8{gap:8px}.gap-12{gap:12px}
.flex-1{flex:1}
.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.divider{border:none;border-top:1px solid var(--border);margin:16px 0}

/* ── Notification Bell & Dropdown ────────────────────────── */
.notif-bell { position: relative; cursor: pointer; }
.notif-badge { position: absolute; top: -4px; right: -4px; background: var(--red); color: #fff; border-radius: 50%; width: 18px; height: 18px; font-size: 10px; font-weight: 700; display: flex; align-items: center; justify-content: center; line-height: 1; pointer-events: none; }
.notif-dropdown { position: absolute; right: 0; top: calc(100% + 8px); width: 340px; background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); z-index: 400; max-height: 420px; overflow-y: auto; }
.notif-item { padding: 10px 14px; border-bottom: 1px solid var(--border-soft); display: flex; gap: 10px; align-items: flex-start; cursor: pointer; transition: background .1s; }
.notif-item:hover { background: var(--bg-hover); }
.notif-item.unread { background: var(--blue-l); }
.notif-icon { font-size: 18px; flex-shrink: 0; margin-top: 2px; }
.notif-title { font-size: 13px; font-weight: 600; color: var(--text-primary); }
.notif-msg { font-size: 12px; color: var(--text-muted); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 240px; }
.notif-time { font-size: 10px; color: var(--text-hint); margin-top: 3px; }
.notif-unread-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--blue); flex-shrink: 0; margin-top: 5px; }

/* ── Dark mode super admin specifics ─────────────────────── */
html[data-theme="dark"] .sa-sidebar,
html[data-theme="dark"] .sa-shell .sa-sidebar { background: var(--bg-sidebar) !important; }
html[data-theme="dark"] .sa-topbar { background: var(--topbar-bg) !important; border-color: var(--border) !important; }
html[data-theme="dark"] .sa-content { background: var(--bg-page) !important; }
html[data-theme="dark"] .stat-card,
html[data-theme="dark"] .card { background: var(--bg-card) !important; border-color: var(--border) !important; }
html[data-theme="dark"] .rh-table th { background: var(--bg-card) !important; color: var(--text-muted) !important; border-color: var(--border) !important; }
html[data-theme="dark"] .rh-table td { border-color: var(--border-soft) !important; color: var(--text-primary) !important; }
html[data-theme="dark"] .rh-table tr:hover td { background: var(--bg-hover) !important; }
html[data-theme="dark"] .btn:not(.btn-primary):not(.btn-success):not(.btn-danger) { background: var(--bg-card) !important; color: var(--text-primary) !important; border-color: var(--border) !important; }
html[data-theme="dark"] .field input,
html[data-theme="dark"] .field select,
html[data-theme="dark"] .field textarea,
html[data-theme="dark"] .search-input,
html[data-theme="dark"] .search-emp-input { background: var(--bg-input) !important; color: var(--text-primary) !important; border-color: var(--border) !important; }
html[data-theme="dark"] .modal-box { background: var(--bg-card) !important; border-color: var(--border) !important; }
html[data-theme="dark"] .modal-header,
html[data-theme="dark"] .modal-footer { border-color: var(--border) !important; }
html[data-theme="dark"] .payslip { background: var(--bg-card) !important; border-color: var(--border) !important; }
html[data-theme="dark"] .tabs { border-color: var(--border) !important; }
html[data-theme="dark"] .alert-info { background: var(--blue-l) !important; }
html[data-theme="dark"] .alert-warning { background: var(--amber-l) !important; }
html[data-theme="dark"] .alert-success { background: var(--green-l) !important; }
html[data-theme="dark"] .alert-error { background: var(--red-l) !important; }
html[data-theme="dark"] .notif-item.unread { background: var(--blue-l) !important; }
html[data-theme="dark"] .stat-value { color: var(--text-primary) !important; }
html[data-theme="dark"] .card-title { color: var(--text-primary) !important; }
html[data-theme="dark"] .topbar-title { color: var(--text-primary) !important; }
html[data-theme="dark"] .progress-bar { background: var(--gray-l) !important; }
html[data-theme="dark"] .payslip-row { color: var(--text-primary) !important; border-color: var(--border-soft) !important; }
html[data-theme="dark"] .search-emp-dropdown { background: var(--bg-card) !important; border-color: var(--border) !important; }
html[data-theme="dark"] .upload-zone { background: var(--bg-surface) !important; border-color: var(--border) !important; }
html[data-theme="dark"] .upload-file-item { background: var(--bg-card) !important; border-color: var(--border) !important; }
html[data-theme="dark"] .tenant-card { background: var(--bg-card) !important; border-color: var(--border) !important; }
