:root{--bg: #0a0f1e;--accent: #1766ff;--highlight: #00e5a0;--surface: #111733;--surface-2: #161d3d;--border: #232a4d;--text: #e8ecf8;--text-dim: #8b93b5;--danger: #ff5d6c;--radius: 14px;--shadow: 0 10px 40px rgba(0, 0, 0, .45);color-scheme:dark;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:radial-gradient(1200px 600px at 80% -10%,rgba(23,102,255,.18),transparent 60%),radial-gradient(900px 500px at -10% 110%,rgba(0,229,160,.12),transparent 55%),var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}button{font:inherit;cursor:pointer;border:none;border-radius:10px;transition:transform .05s ease,filter .15s ease,background .15s ease,border-color .15s ease,color .15s ease}button:active{transform:translateY(1px)}button:disabled{opacity:.55;cursor:not-allowed}input,select{font:inherit;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:11px 13px;outline:none;transition:border-color .15s ease,box-shadow .15s ease}input:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1766ff40}.btn-primary{background:var(--accent);color:#fff;padding:11px 18px;font-weight:600}.btn-primary:hover:not(:disabled){filter:brightness(1.1)}.btn-ghost{background:transparent;color:var(--text-dim);border:1px solid var(--border);padding:9px 14px}.btn-ghost:hover{color:var(--text);border-color:var(--accent)}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}.login-card{width:100%;max-width:400px;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:34px 30px;color:#0a0f1e}.brand{display:flex;align-items:center;gap:10px}.login-card .brand-logo{height:40px;width:auto;display:block}.login-card h1{font-size:22px;margin:22px 0 4px;color:#0a0f1e}.login-card p.sub{color:#5b6480;margin:0 0 22px;font-size:14px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:13px;color:var(--text-dim)}.login-card .field label{color:#5b6480}.login-card input{background:#f4f6fb;color:#0a0f1e;border-color:#dfe4f0}.login-card .btn-primary{width:100%;margin-top:6px}.login-card .banner.error{background:#ffe9eb;border:1px solid #ffc4ca;color:#b3261e}.topbar{background:#fff;border-bottom:1px solid #e6e9f2;box-shadow:0 2px 16px #050a1940;position:sticky;top:0;z-index:5;padding:14px 0}.topbar-inner{max-width:1100px;margin:0 auto;padding:0 28px;display:flex;align-items:center;justify-content:space-between;gap:16px}.brand-logo{height:42px;width:auto;display:block}.topbar-right{display:flex;align-items:center;gap:4px}.topbar .user{color:#5b6480;font-size:14px;margin-right:10px}.topbar .btn-ghost{color:#4a5573;border-color:#d8dcea}.topbar .btn-ghost:hover{color:var(--accent);border-color:var(--accent)}.container{max-width:1080px;margin:0 auto;padding:30px 28px 48px}.page-title{font-size:26px;font-weight:800;margin:6px 0 4px}.page-sub{color:var(--text-dim);margin:0 0 24px}.controls{display:flex;flex-wrap:wrap;align-items:flex-end;gap:14px;margin-bottom:22px}.controls .field{margin-bottom:0}.summary{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.card{background:linear-gradient(180deg,var(--surface),var(--surface-2));border:1px solid var(--border);border-radius:var(--radius);padding:20px}.card .label{color:var(--text-dim);font-size:13px;text-transform:uppercase;letter-spacing:.6px}.card .value{font-size:30px;font-weight:800;margin-top:10px}.card .value.accent{color:var(--accent)}.billing-select{width:100%;margin-top:10px;font-size:18px;font-weight:700;padding:10px 12px}.avatar{border-radius:50%;object-fit:cover;background:#1a2244;flex:none;display:block}.avatar-fallback{display:inline-flex;align-items:center;justify-content:center;font-weight:700;color:#04122c;background:linear-gradient(135deg,var(--accent),var(--highlight))}.table-wrap{background:linear-gradient(180deg,var(--surface),var(--surface-2));border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}table{width:100%;border-collapse:collapse}thead th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.6px;color:var(--text-dim);padding:14px 18px;border-bottom:1px solid var(--border);background:#ffffff05}tbody td{padding:13px 18px;border-bottom:1px solid var(--border);font-size:15px}tbody tr:last-child td{border-bottom:none}tbody tr.clickable{cursor:pointer;transition:background .12s ease}tbody tr.clickable:hover{background:#1766ff14}.num{text-align:right;font-variant-numeric:tabular-nums}.role{color:var(--text-dim)}.cell-name{display:flex;align-items:center;gap:12px}.cell-name .nm{font-weight:600}tfoot td{padding:16px 18px;font-weight:800;border-top:2px solid var(--border);background:#1766ff0f}.banner{padding:12px 16px;border-radius:10px;font-size:14px;margin-bottom:18px}.banner.error{background:#ff5d6c1f;border:1px solid var(--danger);color:#ffb3ba}.empty,.muted{color:var(--text-dim)}.empty{padding:40px;text-align:center}.spinner-row td{padding:40px;text-align:center;color:var(--text-dim)}.hire-cta{display:flex;justify-content:center;margin:30px 0 6px}.btn-hire{display:inline-flex;align-items:center;gap:9px;background:linear-gradient(135deg,var(--accent),var(--highlight));color:#04122c;font-weight:800;font-size:16px;padding:14px 28px;border-radius:12px;text-decoration:none;box-shadow:0 8px 28px #1766ff4d;transition:transform .08s ease,filter .15s ease}.btn-hire:hover{filter:brightness(1.07);transform:translateY(-1px)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;padding:20px;background:#04081499;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:grid;place-items:center}.modal{position:relative;width:100%;max-width:420px;background:linear-gradient(180deg,var(--surface),var(--surface-2));border:1px solid var(--border);border-radius:18px;padding:30px 28px 24px;box-shadow:var(--shadow)}.modal-close{position:absolute;top:12px;right:14px;background:transparent;color:var(--text-dim);font-size:24px;line-height:1;padding:4px 8px}.modal-close:hover{color:var(--text)}.prof{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px}.prof-name{font-size:21px;font-weight:800;margin-top:4px}.role-badge{font-size:12px;font-weight:600;letter-spacing:.4px;color:var(--highlight);background:#00e5a01f;border:1px solid rgba(0,229,160,.35);border-radius:999px;padding:4px 12px}.meta{margin-top:22px;border-top:1px solid var(--border);padding-top:16px;display:grid;gap:12px}.meta-row{display:flex;justify-content:space-between;gap:16px;font-size:14px}.meta-k{color:var(--text-dim)}.meta-v{font-weight:600;text-align:right;word-break:break-word}.meta-v a{color:var(--accent);text-decoration:none}.meta-v a:hover{text-decoration:underline}.brand-admin{display:flex;align-items:center;gap:12px}.admin-pill{font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:#fff;background:var(--accent);border-radius:999px;padding:3px 10px}.billing-value{color:var(--highlight)}.tabs{display:flex;gap:8px;margin-bottom:20px}.tab{background:transparent;border:1px solid var(--border);color:var(--text-dim);padding:9px 18px;border-radius:10px;font-weight:600}.tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.tab:hover:not(.active){color:var(--text)}.banner.ok{background:#00e5a01f;border:1px solid rgba(0,229,160,.4);color:#9affd9}.panel{background:linear-gradient(180deg,var(--surface),var(--surface-2));border:1px solid var(--border);border-radius:var(--radius);padding:22px;margin-bottom:22px}.panel-title{font-size:17px;font-weight:700;margin:0 0 16px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:16px}.assign-label{font-size:13px;color:var(--text-dim);display:block;margin-bottom:8px}.chip-grid{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.chip{background:var(--bg);border:1px solid var(--border);color:var(--text-dim);padding:7px 12px;border-radius:999px;font-size:13px}.chip.on{background:#1766ff26;border-color:var(--accent);color:#cfe0ff}.chip:hover{border-color:var(--accent)}.client-row{border-top:1px solid var(--border);padding:14px 0}.client-row:first-of-type{border-top:none}.client-head{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.client-email{font-weight:600}.client-controls{display:flex;gap:10px;align-items:center}.assigned-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.mini-chip{font-size:12px;color:var(--text-dim);background:var(--bg);border:1px solid var(--border);border-radius:999px;padding:3px 10px}.spec-list{display:flex;flex-direction:column}.spec-row{display:flex;align-items:center;gap:14px;padding:14px 0;border-top:1px solid var(--border)}.spec-row:first-child{border-top:none}.spec-main{flex:1;min-width:160px}.spec-name{font-weight:600}.spec-sub{color:var(--text-dim);font-size:13px;margin-top:2px}.spec-actions{display:flex;gap:16px;align-items:flex-end;flex-wrap:wrap}.mini-label{font-size:12px;color:var(--text-dim)}.mini-label input{display:block;margin-top:4px}.upload-btn{align-self:flex-end;background:transparent;border:1px solid var(--border);color:var(--text-dim);padding:10px 14px;border-radius:10px;cursor:pointer;font-size:13px}.upload-btn:hover{border-color:var(--accent);color:var(--text)}.panel-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.panel-head .panel-title{margin:0}.sync-btn{display:inline-flex;align-items:center;gap:6px}.btn-danger{background:transparent;color:var(--danger);border:1px solid rgba(255,93,108,.4);padding:9px 14px}.btn-danger:hover{background:#ff5d6c1f;border-color:var(--danger)}.spin{display:inline-block;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.muted-inline{color:var(--text-dim);font-weight:400;font-size:13px}.assign-editor{margin-top:10px}.assign-edit-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:9px 0;border-top:1px dashed var(--border)}.assign-edit-row .nm{min-width:150px;font-weight:600}.assign-edit-row select,.assign-edit-row input{padding:7px 10px}.assign-edit-row .hrs{width:92px}.btn-sm{padding:6px 10px;font-size:13px}.week{background:linear-gradient(180deg,var(--surface),var(--surface-2));border:1px solid var(--border);border-radius:var(--radius);padding:22px;margin-top:22px}.week-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}.week-nav{display:flex;align-items:center;gap:10px}.week-nav .btn-ghost{padding:6px 12px}.week-label{color:var(--text-dim);font-size:14px;min-width:180px;text-align:center}.week-scroll{overflow-x:auto}.week-grid{min-width:640px}.week-row{display:grid;grid-template-columns:150px repeat(7,1fr) 90px;align-items:center;gap:6px;padding:5px 0}.week-row.head{color:var(--text-dim);font-size:11px;text-align:center;padding-bottom:8px}.week-name{font-weight:600;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-right:8px}.day-head{line-height:1.25}.day{height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}.day.present{background:#00e5a0d9;color:#04122c}.day.absent{background:#ff5d6ccc;color:#2a0307}.day.future{background:var(--bg);border:1px dashed var(--border);color:var(--text-dim)}.week-total{text-align:right;font-variant-numeric:tabular-nums;font-weight:700;padding-left:8px}.week-legend{color:var(--text-dim);font-size:12px;margin:14px 0 0;display:flex;align-items:center;flex-wrap:wrap;gap:2px}.week-legend .dot{display:inline-block;width:12px;height:12px;border-radius:4px;margin:0 4px;vertical-align:middle}.week-legend .dot.present{background:#00e5a0d9}.week-legend .dot.absent{background:#ff5d6ccc}.week-legend .dot.future{background:var(--bg);border:1px dashed var(--border)}@media (max-width: 640px){.summary{grid-template-columns:1fr}.role-col,.hired-col,.hiretype-col,.lastlogin-col{display:none}.form-grid{grid-template-columns:1fr}}
