:root{--bg:#f5f7fb;--card:#fff;--text:#111827;--muted:#64748b;--line:#d9e0ea;--accent:#6d3888;--accent-dark:#5b2e72;--danger:#b91c1c}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,select,textarea{font:inherit}button{background:var(--accent);color:#fff;cursor:pointer;border:0;border-radius:8px;min-height:40px;padding:0 14px;font-weight:650;transition:background .18s,opacity .18s,transform .18s}button:hover{background:var(--accent-dark)}button:disabled{cursor:not-allowed;opacity:.55}button.secondary{color:#334155;border:1px solid var(--line);background:#fff}button.secondary:hover{background:#f8fafc}button.tiny{min-height:32px;padding:0 10px;font-size:12px}button.danger{color:var(--danger);background:#fff1f2;border:1px solid #fecdd3}button.danger:hover{background:#ffe4e6}input,select,textarea{border:1px solid var(--line);width:100%;min-height:40px;color:var(--text);background:#fff;border-radius:8px;outline:none;padding:8px 10px}textarea{resize:vertical;min-height:84px}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6d388824}.login-page{place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{border:1px solid var(--line);background:var(--card);border-radius:10px;width:min(440px,100%);padding:28px;box-shadow:0 18px 55px #0f172a14}.brand-mark{background:var(--accent);color:#fff;border-radius:8px;place-items:center;width:44px;height:44px;font-weight:800;display:grid}.login-card h1,.top-panel h1{letter-spacing:0;margin:14px 0 4px;font-size:30px;line-height:1.1}.login-card p,.muted{color:var(--muted)}.login-form{gap:14px;margin-top:24px;display:grid}.login-form span{color:#475569;margin-bottom:6px;font-size:13px;font-weight:650;display:block}.login-form button{width:100%}.error-message,.error-banner{color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:12px;font-size:14px}.planner-shell{width:min(1520px,100%);margin:0 auto;padding:24px}.top-panel{border:1px solid var(--line);background:var(--card);border-radius:10px;justify-content:space-between;align-items:center;gap:20px;padding:18px;display:flex;box-shadow:0 12px 32px #0f172a0f}.brand-block{align-items:center;gap:16px;min-width:0;display:flex}.brand-logo{flex:none;width:150px;max-width:34vw;height:auto}.eyebrow{color:var(--accent);text-transform:uppercase;margin:0;font-size:12px;font-weight:800}.top-panel h1,.top-panel p{margin-top:0}.toolbar{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.week-picker{border:1px solid var(--line);color:#475569;background:#fff;border-radius:8px;align-items:center;gap:8px;min-height:40px;padding:0 8px 0 12px;font-size:13px;font-weight:700;display:inline-flex}.week-picker input{width:142px;min-height:32px;box-shadow:none;border:0;padding:0}.week-picker input:focus{box-shadow:none}.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin:16px 0;display:grid}.stat-card{border:1px solid var(--line);background:var(--card);border-radius:10px;padding:16px}.stat-card span{color:var(--muted);font-size:13px;font-weight:650;display:block}.stat-card strong{margin-top:6px;font-size:26px;display:block}.planner-grid{grid-template-columns:360px minmax(0,1fr);gap:16px;display:grid}.side-panel,.main-panel,.overview-panel{border:1px solid var(--line);background:var(--card);border-radius:10px}.side-panel{align-self:start;padding:16px}.main-panel{min-width:0;padding:16px}.panel-section+.panel-section{border-top:1px solid var(--line);margin-top:22px;padding-top:18px}.section-heading,.day-header{justify-content:space-between;align-items:center;gap:14px;display:flex}.section-heading h2,.day-header h2,.overview-panel h2{margin:0;font-size:18px}.employee-add{grid-template-columns:1fr 1fr 84px;gap:8px;margin-top:14px;display:grid}.employee-add button{grid-column:1/-1}.employee-list,.role-list{gap:10px;margin-top:14px;display:grid}.employee-card{border:1px solid var(--line);background:#fbfdff;border-radius:8px;padding:12px}.employee-card.inactive{opacity:.58}.employee-card-top{grid-template-columns:12px 1fr;align-items:center;gap:8px;display:grid}.role-dot,.overview-name i{border-radius:999px;width:10px;height:10px;display:inline-block}.employee-fields{grid-template-columns:1fr 86px;gap:8px;margin-top:8px;display:grid}.balance-row,.check-row{color:#475569;justify-content:space-between;align-items:center;gap:8px;margin-top:8px;font-size:13px;display:flex}.check-row{justify-content:flex-start}.check-row input{width:16px;min-height:16px}.employee-actions{justify-content:space-between;align-items:center;gap:10px;margin-top:10px;display:flex}.negative{color:var(--danger)}.role-editor{grid-template-columns:44px 1fr;gap:8px;display:grid}.role-editor input[type=color]{padding:4px}.week-strip{grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin-bottom:16px;display:grid}.day-tab{color:#334155;border:1px solid var(--line);text-align:left;background:#f8fafc;align-content:center;justify-items:start;gap:5px;min-height:88px;display:grid}.day-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.day-tab.has-sick{border-color:#7f1d1d;box-shadow:inset 0 -4px #7f1d1d}.day-tab.active.has-sick{box-shadow:inset 0 -4px #ffffffa6}.day-tab span,.day-tab strong,.day-tab small{display:block}.day-tab small{opacity:.82}.target-input{color:var(--muted);grid-template-columns:110px 94px;align-items:center;gap:10px;font-size:13px;font-weight:650;display:grid}.schedule-table{margin-top:16px;overflow-x:auto}.schedule-head,.schedule-row{grid-template-columns:minmax(190px,1.15fr) 108px 108px 108px 108px 72px minmax(160px,1fr) 70px;align-items:center;gap:8px;min-width:980px;display:grid}.schedule-head{color:var(--muted);text-transform:uppercase;padding:0 0 8px;font-size:12px;font-weight:800}.schedule-row{border-top:1px solid #edf2f7;padding:8px 0}.schedule-row.sick-shift{color:#fff;background:#7f1d1d;border-top:0;border-radius:8px;margin-top:6px;padding:8px}.schedule-row.sick-shift input,.schedule-row.sick-shift select{color:#111827;background:#fff7f7;border-color:#fecaca}.schedule-row.sick-shift strong{color:#fff}.employee-select{border-left:5px solid;border-radius:8px;display:block}.employee-select select{border-left:0}.day-actions{gap:10px;margin-top:16px;display:flex}.day-actions select{max-width:280px}.overview-panel{margin-top:18px;padding:16px}.overview-table{margin-top:14px;overflow-x:auto}.overview-head,.overview-row{grid-template-columns:190px repeat(5,minmax(118px,1fr)) 88px 86px;gap:1px;min-width:980px;display:grid}.overview-head span,.overview-row>span,.overview-row>strong{background:#f8fafc;min-height:36px;padding:9px;font-size:13px}.overview-head span{color:var(--muted);text-transform:uppercase;font-size:12px;font-weight:800}.overview-name{align-items:center;gap:8px;font-weight:700;display:flex}.overview-cell{color:#334155;white-space:pre-wrap}.overview-cell.sick-cell{color:#fff;font-weight:800;background:#7f1d1d!important}.context-menu{z-index:1000;background:#fff;border:1px solid #cbd5e1;border-radius:8px;min-width:230px;padding:6px;display:grid;position:fixed;overflow:hidden;box-shadow:0 16px 44px #0f172a33}.context-menu button{color:#111827;text-align:left;width:100%;min-height:36px;box-shadow:none;background:#fff;border:0;border-radius:6px;justify-content:flex-start;padding:8px 10px}.context-menu button:hover:not(:disabled){background:#f1f5f9}.context-menu button:disabled{color:#94a3b8;cursor:not-allowed}.context-menu .danger-item{color:#991b1b}.context-menu .danger-item:hover:not(:disabled){background:#fef2f2}.viewer-shell{max-width:1240px}.viewer-overview{margin-top:16px}.viewer-overview-grid{grid-template-columns:210px repeat(5,minmax(130px,1fr));min-width:860px}.viewer-cell{min-height:44px}.mobile-roster{--mobile-scale:.92;display:none}.mobile-logo-row{min-height:calc(52px * var(--mobile-scale));padding:calc(10px * var(--mobile-scale)) 18px calc(9px * var(--mobile-scale));border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;gap:14px;display:flex}.mobile-logo-row img{width:calc(108px * var(--mobile-scale));max-width:38vw;height:auto}.mobile-logo-row div{color:#111827;font-size:calc(15px * var(--mobile-scale));text-align:center;flex:1;font-weight:750;line-height:1.2}.mobile-month-row{grid-template-columns:calc(42px * var(--mobile-scale)) 1fr calc(42px * var(--mobile-scale));padding:calc(12px * var(--mobile-scale)) 10px calc(8px * var(--mobile-scale));border-bottom:1px solid #e5e7eb;align-items:center;display:grid}.mobile-month-row h2{text-align:center;font-size:calc(23px * var(--mobile-scale));letter-spacing:0;margin:0;font-weight:800}.mobile-arrow{min-height:calc(38px * var(--mobile-scale));color:#0aa882;font-size:calc(36px * var(--mobile-scale));background:0 0;border:0;padding:0;line-height:1}.mobile-arrow:hover{background:0 0}.mobile-week-strip{padding:calc(6px * var(--mobile-scale)) 8px calc(8px * var(--mobile-scale));border-bottom:1px solid #e5e7eb;grid-template-columns:repeat(7,1fr);display:grid}.mobile-day{min-height:calc(66px * var(--mobile-scale));place-items:center;gap:calc(4px * var(--mobile-scale));color:#111827;background:0 0;border-radius:999px;padding:4px;display:grid}.mobile-day:hover{background:#f1f5f9}.mobile-day span{color:#6b7280;font-size:calc(14px * var(--mobile-scale));font-weight:600}.mobile-day strong{width:calc(42px * var(--mobile-scale));height:calc(42px * var(--mobile-scale));font-size:calc(22px * var(--mobile-scale));border-radius:999px;place-items:center;font-weight:500;display:grid}.mobile-day.has-shifts strong{box-shadow:inset 0 -4px #0aa882}.mobile-day.selected strong{color:#fff;box-shadow:none;background:#ef6358}.mobile-day.today:not(.selected) strong{background:#eef2f7}.mobile-day-title{padding:calc(18px * var(--mobile-scale)) 18px calc(16px * var(--mobile-scale));font-size:calc(22px * var(--mobile-scale));font-weight:500}.mobile-shift-list{display:grid}.mobile-shift{grid-template-columns:calc(62px * var(--mobile-scale)) calc(6px * var(--mobile-scale)) 1fr;gap:calc(12px * var(--mobile-scale));min-height:calc(90px * var(--mobile-scale));align-items:center;padding:0 18px;display:grid}.mobile-avatar{width:calc(52px * var(--mobile-scale));height:calc(52px * var(--mobile-scale));font-size:calc(18px * var(--mobile-scale));border-radius:999px;place-items:center;font-weight:800;display:grid}.mobile-role-bar{width:calc(6px * var(--mobile-scale));height:calc(64px * var(--mobile-scale));border-radius:999px}.mobile-shift-main{min-width:0;padding:calc(15px * var(--mobile-scale)) 0;border-bottom:1px solid #e5e7eb}.mobile-time{font-size:calc(24px * var(--mobile-scale));letter-spacing:0;font-weight:500}.mobile-person{margin-top:calc(4px * var(--mobile-scale));color:#111827;font-size:calc(18px * var(--mobile-scale));line-height:1.3}.mobile-person span{color:#a3a9b5}.mobile-empty{padding:calc(24px * var(--mobile-scale)) 0;color:#6b7280;font-size:calc(16px * var(--mobile-scale));border-top:1px solid #e5e7eb;margin:0 18px}.overview-col-alt{box-shadow:inset 3px 0 #94a3b8;background:#e7f0ff!important}@media (max-width:1180px){.planner-grid{grid-template-columns:1fr}.side-panel{order:2}}@media (max-width:840px){.planner-shell{padding:14px}.top-panel,.day-header{flex-direction:column;align-items:stretch}.brand-block{flex-direction:column;align-items:flex-start}.toolbar{justify-content:stretch}.toolbar button,.week-picker,.day-actions button,.day-actions select{width:100%;max-width:none}.week-picker input{width:100%}.stats-grid,.week-strip{grid-template-columns:1fr}.day-actions{flex-direction:column}}@media (max-width:720px){body{background:#fff}.viewer-shell{width:100%;padding:0}.viewer-shell .top-panel,.viewer-overview{display:none}.mobile-roster{display:block}}@media (max-width:420px){.mobile-time{font-size:22px}.mobile-person{font-size:17px}.mobile-shift{grid-template-columns:56px 5px 1fr;gap:10px;padding:0 14px}.mobile-avatar{width:48px;height:48px}}
