:root{
  --bg:#f5f7fb; --panel:#ffffff; --ink:#111827; --muted:#667085; --line:#e5eaf2;
  --nav:#0b1730; --nav2:#111f3d; --blue:#145cff; --green:#067647; --green-bg:#dcfaea;
  --soft-blue:#eaf1ff; --amber:#b54708; --amber-bg:#fff2d6; --red:#b42318; --red-bg:#ffe8e6;
  --grey-bg:#f2f4f7; --shadow:0 14px 35px rgba(16,24,40,.08); --radius:20px;
}
*{box-sizing:border-box} body{margin:0;background:var(--bg);color:var(--ink);font-family:Inter,Segoe UI,Arial,sans-serif;font-size:16px;line-height:1.45} a{text-decoration:none;color:inherit}
.shell{min-height:100vh;width:100%;display:grid;grid-template-columns:260px minmax(0,1fr)}
/* ── Sidebar: three-section flex layout ── */
.sidebar{background:var(--nav);color:white;position:sticky;top:0;height:100vh;overflow:hidden;display:flex;flex-direction:column;}
.sidebar-header{flex-shrink:0;padding:24px 18px 0;}
.sidebar-nav{flex:1;overflow-y:auto;padding:0 18px 8px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.12) transparent;}
.sidebar-nav::-webkit-scrollbar{width:4px;}
.sidebar-nav::-webkit-scrollbar-track{background:transparent;}
.sidebar-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:2px;}
.sidebar-footer{flex-shrink:0;padding:12px 18px 20px;border-top:1px solid rgba(255,255,255,.1);}
/* Brand / logo */
.brand{display:flex;align-items:center;gap:12px;margin-bottom:28px;}.logo{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,#1563ff,#31d0a3);display:grid;place-items:center;font-weight:900;font-size:18px;color:#fff;flex-shrink:0;}.brand strong{display:block;font-size:17px;color:#fff;}.brand span{font-size:12px;color:#aab7d4;}
/* Navigation links */
.nav{display:grid;gap:8px;}.nav a{display:block;padding:13px 14px;border-radius:12px;color:#d8e2ff;font-weight:750;font-size:14px;}.nav a:hover,.nav a.active{background:rgba(255,255,255,.13);color:#fff;}
/* User profile button (footer) */
.user-profile-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border-radius:14px;background:transparent;border:1px solid rgba(255,255,255,.12);cursor:pointer;text-align:left;transition:background .15s;}
.user-profile-btn:hover{background:rgba(255,255,255,.08);}
.user-info{flex:1;min-width:0;}
.user-info strong{display:block;color:#fff;font-size:13px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.user-info span{font-size:11px;color:#aab7d4;display:block;}
.dropdown-chevron{color:#aab7d4;font-size:12px;flex-shrink:0;transition:transform .2s;line-height:1;}
.sidebar-footer.open .dropdown-chevron{transform:rotate(180deg);}
/* User dropdown menu */
.user-dropdown{display:none;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:12px;margin-top:8px;overflow:hidden;}
.user-dropdown.show{display:block;}
.user-dropdown .dropdown-item{display:block;width:100%;padding:11px 14px;color:#d8e2ff;font-size:13px;font-weight:700;background:transparent;border:none;cursor:pointer;text-align:left;font-family:inherit;}
.user-dropdown .dropdown-item:hover{background:rgba(255,255,255,.1);color:#fff;}
/* Legacy: keep for backward compat */
.user-chip{border:1px solid rgba(255,255,255,.15);border-radius:16px;padding:14px;color:#cbd7f3;font-size:12px;}
.main{padding:34px 38px;width:100%;min-width:0;overflow-x:hidden;}.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:24px}.topbar h1{font-size:32px;line-height:1.1;margin:0 0 8px}.sub{color:var(--muted);margin:0}.actions{display:flex;gap:10px;flex-wrap:wrap}.btn{border:1px solid var(--line);background:#fff;padding:12px 16px;border-radius:12px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.btn.primary{background:var(--blue);border-color:var(--blue);color:#fff}.btn.success{background:#079455;border-color:#079455;color:#fff}.btn.danger{background:#fff4f3;border-color:#ffd2cf;color:var(--red)}
.grid{display:grid;gap:18px}.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);min-width:0}.card h2{font-size:20px;margin:0 0 10px}.card h3{font-size:17px;margin:0 0 8px}.metric{font-size:38px;font-weight:900;line-height:1;margin:14px 0 6px}.label{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:900}.pill{display:inline-flex;align-items:center;border-radius:999px;padding:6px 11px;font-size:12px;font-weight:900;white-space:nowrap}.green{background:var(--green-bg);color:var(--green)}.blue{background:var(--soft-blue);color:#175cd3}.amber{background:var(--amber-bg);color:var(--amber)}.red{background:var(--red-bg);color:var(--red)}.gray{background:var(--grey-bg);color:#475467}
.table-wrap{overflow:auto}.table{width:100%;border-collapse:collapse;font-size:14px}.table th{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.05em;text-align:left}.table th,.table td{padding:13px 12px;border-bottom:1px solid var(--line);vertical-align:top}.table tr:last-child td{border-bottom:0}
.bucket-card{display:flex;flex-direction:column;gap:10px}.bucket-card .bucket-action{border-top:1px solid var(--line);padding-top:12px;margin-top:auto;color:#344054;font-size:14px}.mini-list{display:grid;gap:10px;margin-top:12px}.mini-row{display:flex;justify-content:space-between;gap:12px;border:1px solid var(--line);border-radius:14px;padding:13px;background:#fff}.score{font-weight:900;color:#175cd3}.progress{height:9px;background:#edf2f7;border-radius:99px;overflow:hidden}.bar{height:100%;background:var(--blue);border-radius:99px}.timeline{display:grid;gap:14px}.step{display:grid;grid-template-columns:38px 1fr auto;gap:14px;align-items:flex-start;border:1px solid var(--line);background:#fff;border-radius:16px;padding:16px}.num{width:38px;height:38px;border-radius:50%;background:var(--soft-blue);color:#175cd3;display:grid;place-items:center;font-weight:900}
.slot-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}.slot{border:1px solid var(--line);border-radius:16px;background:#fff;padding:16px;margin-top:12px}.slot strong{font-size:18px}.rule-list{margin:10px 0 18px}.pipeline-board{display:grid;grid-template-columns:repeat(4,minmax(230px,1fr));gap:18px;align-items:start}.stage h2{margin:0 0 12px}.candidate-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:15px;margin-bottom:12px}.candidate-card .top{display:flex;justify-content:space-between;gap:10px;align-items:center}.candidate-card p{margin:8px 0 0;color:var(--muted);font-size:13px}.message-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.template-card{border:1px solid var(--line);background:#fff;border-radius:16px;padding:16px;margin-top:14px}.template-head{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-bottom:10px}.template-card textarea{width:100%;min-height:110px;border:1px solid #d0d7e2;border-radius:12px;padding:12px;font:14px/1.45 Inter,Segoe UI,Arial,sans-serif;color:var(--ink);background:#fbfcff;resize:vertical}.template-actions{display:flex;gap:10px;margin-top:10px}.summary-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:18px}.summary-item{background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px}.summary-item strong{font-size:26px;display:block}
.login-page{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}.login-hero{background:var(--nav);color:#fff;padding:54px;display:flex;flex-direction:column;justify-content:space-between}.login-hero h1{font-size:44px;line-height:1.08;max-width:720px}.login-card-wrap{display:grid;place-items:center;padding:40px}.login-card{max-width:460px;width:100%;background:#fff;border:1px solid var(--line);border-radius:24px;padding:30px;box-shadow:var(--shadow)}.field{display:grid;gap:8px;margin:14px 0}.field label{font-weight:800;font-size:13px}.field input,.field select{padding:13px 14px;border:1px solid var(--line);border-radius:12px;font-size:15px;width:100%}.hint{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:14px;padding:14px;color:var(--muted);font-size:13px;margin-top:16px}.role-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:16px 0}.role-card{border:1px solid var(--line);border-radius:14px;padding:14px;background:#fff}.role-card span{font-size:12px;color:var(--muted)}
/* User avatar circle (initials) */
.avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#1563ff,#31d0a3);display:grid;place-items:center;font-weight:900;font-size:14px;color:#fff;flex-shrink:0;}
/* Logout button styled as nav link */
.nav-logout{display:block;width:100%;padding:13px 14px;border-radius:12px;color:#d8e2ff;font-weight:750;font-size:14px;background:transparent;border:none;cursor:pointer;text-align:left;}.nav-logout:hover{background:rgba(255,255,255,.13);color:#fff;}
/* Input validation error state */
.field input.input-error,.field select.input-error{border-color:var(--red);background:var(--red-bg)}
/* Utility */
.hidden{display:none!important;}
/* Small button variant */
.btn.sm{padding:6px 12px;font-size:13px;border-radius:8px;}
/* Tab bar */
.tab-wrap{display:flex;gap:8px;background:#f1f5f9;border-radius:18px;padding:6px;width:fit-content;}
.tab-btn{height:42px;padding:0 20px;border-radius:14px;border:0;background:transparent;color:var(--muted);font-weight:900;font-size:14px;cursor:pointer;transition:.15s;}
.tab-btn.active{background:#fff;color:var(--blue);box-shadow:0 6px 18px rgba(15,23,42,.08);}
.tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:20px;border-radius:10px;background:#e2e8f0;color:var(--muted);font-size:11px;font-weight:900;margin-left:6px;padding:0 5px;}
.tab-btn.active .tab-count{background:var(--soft-blue);color:var(--blue);}
/* Status badges */
.status-badge{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;font-size:12px;font-weight:900;}
.status-badge.pending{background:var(--amber-bg);color:var(--amber);}
.status-badge.approved{background:var(--green-bg);color:var(--green);}
.status-badge.rejected{background:var(--red-bg);color:var(--red);}
.status-badge.closed{background:#f1f5f9;color:#64748b;}
/* Tab + toolbar row */
.tab-toolbar-row{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;padding-bottom:0;}
/* Table toolbar (search — right-aligned) */
.table-toolbar{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:16px 22px 14px;flex-wrap:wrap;}
.table-search input{padding:10px 14px;border:1px solid var(--line);border-radius:12px;font-size:14px;width:280px;font-family:inherit;}
.table-search input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(20,92,255,.08);}
/* Sortable columns */
.table th.sortable{cursor:pointer;user-select:none;}
.table th.sortable:hover{color:var(--blue);}
.table th.sort-active{color:var(--blue);}
/* Pagination footer: three-column bar */
.pagination-footer{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 22px;border-top:1px solid var(--line);flex-wrap:wrap;}
.pf-info{font-size:13px;color:var(--muted);font-weight:700;white-space:nowrap;min-width:160px;}
.pf-size{display:flex;align-items:center;gap:8px;}
.pf-size label{font-size:13px;color:var(--muted);font-weight:700;white-space:nowrap;}
.page-size-select{padding:7px 10px;border:1px solid var(--line);border-radius:8px;font-size:13px;font-weight:700;background:#fff;color:var(--ink);cursor:pointer;font-family:inherit;}
.page-size-select:focus{outline:none;border-color:var(--blue);}
.pf-btns{display:flex;gap:4px;align-items:center;flex-wrap:wrap;}
/* Page buttons */
.page-btn{height:34px;min-width:34px;padding:0 10px;border-radius:10px;border:1px solid var(--line);background:#fff;color:var(--ink);font-weight:800;font-size:13px;cursor:pointer;transition:background .12s,color .12s;}
.page-btn:hover:not(:disabled):not(.active){background:var(--soft-blue);border-color:var(--blue);color:var(--blue);}
.page-btn.active{background:var(--blue);border-color:var(--blue);color:#fff;}
.page-btn:disabled{opacity:.35;cursor:not-allowed;}
.page-ellipsis{padding:0 4px;color:var(--muted);font-size:13px;font-weight:700;line-height:34px;}
/* Legacy aliases kept for any other usage */
.pagination-wrap{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-top:1px solid var(--line);}
.pagination-info{font-size:13px;color:var(--muted);font-weight:700;}
.pagination-btns{display:flex;gap:6px;}
/* Modal overlay */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;}
.modal-overlay.hidden{display:none!important;}
.modal-box{background:#fff;border-radius:var(--radius);padding:28px;width:min(100%,500px);box-shadow:var(--shadow);}
.modal-box h3{margin:0 0 8px;font-size:20px;font-weight:900;}
.modal-box p{margin:0 0 16px;color:var(--muted);font-size:14px;}
.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px;}
/* Spinner */
.spinner{width:28px;height:28px;border:3px solid var(--line);border-top-color:var(--blue);border-radius:50%;animation:bj-spin .7s linear infinite;display:inline-block;}
@keyframes bj-spin{to{transform:rotate(360deg)}}
/* Toast notification */
.toast{position:fixed;bottom:28px;right:28px;background:var(--nav);color:#fff;padding:14px 20px;border-radius:14px;font-size:14px;font-weight:800;z-index:2000;transform:translateY(100px);opacity:0;transition:.35s ease;pointer-events:none;max-width:360px;}
.toast.show{transform:translateY(0);opacity:1;}
@media(max-width:1180px){.cols-4,.pipeline-board{grid-template-columns:repeat(2,minmax(0,1fr))}.cols-3,.slot-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.summary-strip{grid-template-columns:repeat(3,1fr)}}
@media(max-width:800px){.shell,.login-page{display:block}.sidebar{position:relative;width:auto;height:auto;max-height:none;overflow:visible;display:block;}.sidebar-nav{overflow:visible;}.main{padding:24px 16px}.topbar{display:block}.actions{margin-top:14px}.cols-2,.cols-3,.cols-4,.slot-grid,.message-grid,.pipeline-board,.summary-strip{grid-template-columns:1fr}.step{grid-template-columns:38px 1fr}.step .pill{grid-column:2}.login-hero{padding:30px}.login-hero h1{font-size:32px}.login-card-wrap{padding:22px}.role-cards{grid-template-columns:1fr}}

/* ============================================================
   Job Details Popup / Custom Modal
   ============================================================ */
@keyframes modalIn{from{opacity:0;transform:translateY(10px) scale(0.98)}to{opacity:1;transform:translateY(0) scale(1)}}
.custom-modal-backdrop{position:fixed;inset:0;background:rgba(5,15,32,0.58);backdrop-filter:blur(10px);z-index:1060;display:none;align-items:center;justify-content:center;padding:22px;}
.custom-modal-backdrop.show{display:flex;}
.custom-modal{width:min(100%,520px);max-height:92vh;overflow:auto;background:#fff;border-radius:30px;border:1px solid rgba(0,0,0,0.08);box-shadow:0 24px 64px rgba(11,23,48,.18),0 4px 16px rgba(11,23,48,.08);padding:24px;animation:modalIn 0.18s ease-out;}
.custom-modal-head{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:18px;}
.custom-modal-head h2{margin:0;font-size:20px;font-weight:900;}
.custom-modal-head p{margin:4px 0 0;font-size:13px;color:var(--muted);}
.close-btn{width:42px;height:42px;border-radius:14px;border:1px solid var(--line);background:#fff;color:#334155;font-size:24px;cursor:pointer;display:grid;place-items:center;flex-shrink:0;}
.close-btn:hover{background:var(--grey-bg);}
/* Details modal size override */
.details-modal .custom-modal{width:min(100%,720px);overflow:hidden;display:flex;flex-direction:column;padding:0;}
.details-modal .custom-modal .custom-modal-head{padding:24px 24px 0;flex-shrink:0;}
.details-modal #detailModalContent{overflow-y:auto;flex:1;min-height:0;padding:0 24px 24px;}
/* Section layout */
.details-section{margin-bottom:22px;}
.details-section-title{font-size:13px;font-weight:900;text-transform:uppercase;letter-spacing:0.06em;color:var(--muted);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--line);}
.details-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.details-field{background:#f8fafc;border:1px solid var(--line);border-radius:12px;padding:10px 14px;}
.details-field.full-width{grid-column:1/-1;}
.details-field .field-label{font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:0.05em;color:var(--muted);margin-bottom:4px;}
.details-field .field-value{font-size:14px;font-weight:750;color:var(--ink);line-height:1.5;}
.details-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px;}
.details-tag{padding:3px 10px;border-radius:8px;background:var(--soft-blue);color:var(--blue);font-size:12px;font-weight:800;}
/* Admin action bar inside details modal */
.modal-action-bar{display:flex;gap:10px;margin-top:22px;padding:18px 24px 24px;border-top:1px solid var(--line);justify-content:flex-end;}
.modal-action-bar .btn-approve{height:44px;padding:0 20px;border-radius:14px;border:0;background:#dcfce7;color:#15803d;font-weight:900;font-size:14px;cursor:pointer;display:inline-flex;align-items:center;gap:7px;}
.modal-action-bar .btn-approve:hover{background:#bbf7d0;}
.modal-action-bar .btn-reject{height:44px;padding:0 20px;border-radius:14px;border:0;background:#fff1f2;color:#be123c;font-weight:900;font-size:14px;cursor:pointer;display:inline-flex;align-items:center;gap:7px;}
.modal-action-bar .btn-reject:hover{background:#ffe4e6;}
/* Map location link inside details popup */
.map-location-link{color:var(--blue);font-weight:800;text-decoration:none;font-size:14px;}
.map-location-link:hover{text-decoration:underline;}
@media(max-width:600px){.details-grid{grid-template-columns:1fr;}.details-field.full-width{grid-column:1;}}
