:root{--bg:#eaf0f6;--topbar:#0f6fa4;--topbar-dark:#0a547d;--sidebar-bg:#f4f6f8;--sidebar-border:#d2d8de;--card:#fff;--text:#1d2a36;--muted:#5f7385;--border:#dbe3ea;--slot-on:#1d96cf;--slot-off:#edf3f8}*{box-sizing:border-box}body{margin:0;font-family:IBM Plex Sans,Avenir Next,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text)}main{max-width:100%;margin:0;padding:0}.login-shell{min-height:100vh;display:grid;place-items:center;padding:26px;background:#eceff4}.login-layout{width:min(1200px,100%);grid-template-columns:1fr minmax(420px,440px);grid-gap:54px;gap:54px}.login-layout,.login-visual{display:grid;align-items:center}.login-visual{grid-gap:0;gap:0}.login-hero-wrap{width:min(680px,100%);height:auto;aspect-ratio:718/835;overflow:hidden;border-radius:8px;position:relative}.login-hero{width:100%;height:100%;display:block;object-fit:contain;object-position:center}.login-card{width:100%;text-align:center;border-radius:18px;padding:30px 26px;border:1px solid #dbe3ea;box-shadow:0 18px 38px rgba(14,36,54,.08)}.login-logo{width:min(290px,88%);height:auto;display:block;margin:0 auto 18px}.login-card h2{font-size:42px;line-height:1.1;margin:4px 0 22px;color:#122034;font-weight:800}.login-card form{display:grid;grid-gap:12px;gap:12px}.login-card form input{height:52px;border-radius:10px;border:1px solid #cfd9e2;padding:0 16px;font-size:21px;color:#18263a;background:#fff}.login-card form button{margin-top:6px;height:52px;border-radius:10px;background:linear-gradient(95deg,#1f6e3f,#2a874c);border:1px solid #1f6e3f;color:#fff;font-size:24px;font-weight:800;letter-spacing:.6px}.login-card form button:hover{transform:none;box-shadow:none;filter:brightness(.98)}h1,h2,h3,p{margin:0 0 10px}.small{color:var(--muted);font-size:12px}.app-shell{min-height:100vh}.topbar{height:68px;background:linear-gradient(110deg,var(--topbar),var(--topbar-dark));color:#fff;justify-content:space-between;padding:0 20px;border-bottom:1px solid rgba(0,0,0,.08);position:-webkit-sticky;position:sticky;top:0;z-index:40}.brand-wrap,.topbar{display:flex;align-items:center}.brand-wrap{gap:10px}.brand-logo{width:40px;height:40px;border-radius:10px;background:hsla(0,0%,100%,.2);border:1px solid hsla(0,0%,100%,.35);color:#fff;font-weight:800;display:inline-flex;align-items:center;justify-content:center;letter-spacing:.6px}.brand-title{font-size:22px;font-weight:700;letter-spacing:.3px}.brand-sub{font-size:11px;opacity:.9;margin-top:2px}.topbar-meta{display:flex;gap:8px;align-items:center}.top-pill{background:hsla(0,0%,100%,.16);border:1px solid hsla(0,0%,100%,.3);border-radius:8px;min-height:36px;min-width:84px;padding:0 12px;display:inline-flex;align-items:center;justify-content:center;font-weight:600}.top-pill.icon-btn{min-width:42px;padding:0;cursor:pointer}.top-pill.user{min-width:180px;justify-content:flex-start;cursor:pointer}.user-menu-wrap{position:relative}.user-menu{position:absolute;right:0;top:44px;background:#fff;border:1px solid #cfdbe6;border-radius:8px;min-width:160px;box-shadow:0 8px 20px rgba(12,36,54,.15);z-index:80;padding:4px}.user-menu-profile{display:grid;grid-gap:2px;gap:2px;padding:8px 9px;border-bottom:1px solid #e0e8ef;margin-bottom:4px}.user-menu-profile strong{font-size:12px;color:#16384f}.user-menu-profile span{font-size:11px;color:#5d7285}.user-menu-item{width:100%;height:36px;border-radius:6px;border:1px solid transparent;background:#f4f8fb;color:#17384f;text-align:left;padding:0 10px;font-weight:600}.user-menu-item:hover{transform:none;box-shadow:none;background:#e8f1f8}.app-main{display:grid;grid-template-columns:280px minmax(0,1fr);min-height:calc(100vh - 68px);transition:grid-template-columns .2s ease;position:relative}.app-main.sidebar-collapsed{grid-template-columns:86px minmax(0,1fr)}.sidebar{background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);padding:16px 0;position:-webkit-sticky;position:sticky;top:68px;align-self:start;height:calc(100vh - 68px);overflow:auto}.sidebar-head{padding:0 16px 10px;border-bottom:1px solid var(--sidebar-border)}.app-main.sidebar-collapsed .side-btn span:last-child,.app-main.sidebar-collapsed .side-group-head span:first-child,.app-main.sidebar-collapsed .sidebar-head .small,.app-main.sidebar-collapsed .sidebar-head h2{display:none}.app-main.sidebar-collapsed .side-group-head{justify-content:center}.app-main.sidebar-collapsed .side-btn{justify-content:center;padding:0}.sidebar-menu{display:flex;flex-direction:column;padding:10px 8px;gap:8px}.side-group{border:1px solid #d8e1e8;background:#fff;border-radius:8px;padding:6px}.side-group-head{width:100%;height:34px;border-radius:6px;border:1px solid transparent;background:#eef3f7;color:#2d4a60;display:flex;align-items:center;justify-content:space-between;font-weight:700;font-size:12px;padding:0 9px}.side-group-head:hover{transform:none;box-shadow:none;background:#e4edf4}.side-group-head.active{background:#d9eaf5;color:#113954}.side-btn{height:42px;border-radius:8px;border:1px solid transparent;text-align:left;padding:0 12px;background:transparent;color:#2a3e50;font-weight:600;display:flex;align-items:center;gap:10px;position:relative;width:100%;margin-top:5px}.side-btn:hover{background:#e8eef4;transform:none;box-shadow:none}.side-btn.active{background:linear-gradient(120deg,#0f7ab3,#0c638f);color:#fff;box-shadow:inset 4px 0 0 #083f5d}.side-icon{width:24px;height:24px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;letter-spacing:.4px;border:1px solid #a9bbc9;background:#eaf1f6;color:#2f4b62}.side-btn.active .side-icon{border-color:hsla(0,0%,100%,.45);background:hsla(0,0%,100%,.2);color:#fff}.side-btn.muted{opacity:.55;cursor:not-allowed}.side-btn.muted:hover{transform:none;box-shadow:none;background:transparent}.content-area{padding:18px}.sidebar-edge-toggle{position:absolute;top:14px;left:280px;transform:translateX(-50%);width:34px;height:34px;border-radius:999px;border:1px solid #c6d5e1;background:#f3f8fc;color:#1c4863;font-weight:800;z-index:35;box-shadow:0 2px 8px rgba(16,52,78,.2)}.app-main.sidebar-collapsed .sidebar-edge-toggle{left:86px}.sidebar-edge-toggle:hover{transform:translateX(-50%);box-shadow:0 3px 10px rgba(16,52,78,.24);background:#e8f1f8}.page-head{border-left:4px solid #0f7ab3}.card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:12px;box-shadow:0 2px 8px rgba(20,40,60,.06)}.sticky-panel{position:-webkit-sticky;position:sticky;top:80px;z-index:20}form{display:grid;grid-gap:10px;gap:10px}button,input,select{height:38px;border-radius:7px;border:1px solid var(--border);padding:0 10px}button{background:linear-gradient(120deg,#0f7ab3,#0c638f);color:#fff;border:none;font-weight:600;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}button:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(15,122,179,.24)}button.secondary{background:#1e4e69}button.light{background:#f2f7fb;color:#1f4258;border:1px solid #ccdae5}.row{grid-gap:10px;grid-template-columns:repeat(2,minmax(0,1fr))}.row,.row3{display:grid;gap:10px}.row3{grid-gap:10px;grid-template-columns:repeat(3,minmax(0,1fr))}.field{display:grid;grid-gap:6px;gap:6px}.field-label{font-size:12px;font-weight:700;color:#2b4c64}.date-cell{position:relative;height:38px;border:1px solid var(--border);border-radius:7px;background:#fff;overflow:hidden;cursor:pointer}.date-cell input{width:100%;height:100%;border:0;border-radius:0;background:transparent}.date-cell.empty input{color:transparent}.date-cell.empty input::-webkit-datetime-edit{color:transparent}.date-cell.empty input::-moz-datetime-edit{color:transparent}.date-cell:focus-within{outline:2px solid #7ab6d7;outline-offset:1px}.date-cell.disabled{background:#f3f6f9;cursor:not-allowed}.date-placeholder{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#8a98a7;font-size:14px;pointer-events:none}.toolbar{display:flex;gap:8px;flex-wrap:wrap}.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:10px;gap:10px}.kpi{border:1px solid var(--border);border-radius:10px;padding:10px;background:#f7fbff;display:grid;grid-gap:4px;gap:4px}.kpi strong{font-size:18px;color:#123c59}.tabs{display:flex;gap:8px;flex-wrap:wrap}.tab-btn{background:#edf3f8;color:#1e3548;border:1px solid var(--border)}.tab-btn.active{background:linear-gradient(120deg,#0f7ab3,#0c638f);color:#fff}.chips{display:flex;gap:8px;flex-wrap:wrap}.chip{height:38px;min-width:62px;border:1px solid #ccdae5;border-radius:999px;padding:0 14px;background:#f2f7fb;color:#24475e;font-size:13px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;text-align:center;box-shadow:none;transform:none}.chip.active{background:linear-gradient(120deg,#0f7ab3,#0c638f);border-color:#0a547d;color:#fff}.chip:hover{background:#e8f1f8;box-shadow:none;transform:none}.chip.active:hover{background:linear-gradient(120deg,#0f7ab3,#0c638f);box-shadow:none;transform:none}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse}td,th{border-bottom:1px solid var(--border);text-align:left;padding:7px;font-size:13px}.requirements-grid{overflow:auto}.requirements-grid table td input{width:64px;height:30px}.sheet{overflow:auto;border:1px solid var(--border);border-radius:10px}.shift-table{width:max-content;min-width:100%}.shift-table td,.shift-table th{border:1px solid var(--border);padding:3px;font-size:11px}.slot-cell{width:16px;min-width:16px;height:16px;background:var(--slot-off);cursor:cell}.slot-cell.on{background:#0f7ab3}.slot-cell.preview{background:#76c8ec}.mini-toolbar{gap:4px}.mini-toolbar button{height:26px;min-width:46px;padding:0 6px;font-size:11px}.day-title{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.ai-chat{display:grid;grid-gap:8px;gap:8px}.ai-msg{border:1px solid var(--border);border-radius:8px;padding:10px}.ai-msg.user{background:#f2f7fb}.ai-msg.assistant{background:#fff}.ai-msg pre{margin:6px 0 0;white-space:pre-wrap;font-family:inherit;font-size:13px;color:#29445b}@media (max-width:1100px){.login-layout{grid-template-columns:1fr;gap:18px}.login-visual{justify-items:center;text-align:center}.login-hero-wrap{width:min(620px,100%)}.login-card{max-width:560px;justify-self:center}}@media (max-width:760px){.login-shell{padding:12px}.login-visual{display:none}.login-layout{grid-template-columns:1fr}.login-card{padding:20px 14px;border-radius:14px}.login-card h2{font-size:34px}.login-card form input{font-size:18px;height:48px}.login-card form button{height:48px;font-size:21px}}@media (max-width:1100px){.app-main{grid-template-columns:1fr}.sidebar-edge-toggle{display:none}.sidebar{border-right:none;border-bottom:1px solid var(--sidebar-border);position:static;height:auto}.sidebar-menu{flex-direction:row;overflow:auto;padding-bottom:4px}.side-btn{white-space:nowrap}.sticky-panel{position:static}}@media (max-width:900px){.kpi-grid,.row,.row3{grid-template-columns:1fr}.topbar{padding:0 12px}.brand-title{font-size:19px}.topbar-meta{gap:6px}.top-pill{min-width:auto;padding:0 8px;font-size:12px}.top-pill.user{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}