:root{--paper:#f6f7f9;--paper2:#fff;--ink:#181b1f;--ink2:#596170;--ink3:#98a0ac;--line:#e7e9ed;--line2:#f1f2f5;--accent:#0284c7;--accent-soft:#e0f2fe;--pos:#1f8a70;--neg:#d1453b;--warn:#b8860b;--shadow:0 1px 2px #14171c0d,0 1px 3px #14171c0a}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--paper);color:var(--ink);-webkit-font-smoothing:antialiased;font-family:Pretendard,Pretendard Variable,-apple-system,system-ui,sans-serif}button,input,select,textarea{font-family:inherit}button,a{-webkit-tap-highlight-color:transparent;touch-action:manipulation}a{color:inherit}.app{max-width:1180px;min-height:100%;margin:0 auto}header.bar{z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);background:#ffffffd1;position:sticky;top:0}.bar-in{flex-wrap:wrap;align-items:center;gap:14px;padding:10px 20px;display:flex}.brand{flex-direction:column;align-items:center;gap:2px;display:flex}.brand .kick{letter-spacing:.08em;text-transform:uppercase;color:#06b6d4;font-size:16px;font-weight:900}.brand h1{letter-spacing:-.02em;text-align:center;font-size:17px;font-weight:700}.daily-bar{border-top:1px solid var(--line2);align-items:center;gap:8px;padding:5px 20px 7px;display:flex}.daily-text{color:var(--accent);white-space:nowrap;font-size:11px;font-weight:700}.daily-sep{color:var(--ink3);font-size:11px}.daily-store{white-space:nowrap;font-size:11px;font-weight:800}.daily-role-icon{white-space:nowrap;font-size:13px;line-height:1}.daily-who{color:var(--ink);white-space:nowrap;font-size:11px;font-weight:700}.daily-role{color:var(--ink2);white-space:nowrap;font-size:11px;font-weight:600}.nav{background:var(--paper2);border:1px solid var(--line);border-radius:999px;align-items:center;gap:2px;padding:4px;display:inline-flex}.nav a{color:var(--ink2);border-radius:999px;align-items:center;padding:8px 14px;font-size:13px;font-weight:600;text-decoration:none;display:flex}.nav a.on{background:var(--ink);color:var(--paper)}.nav-icon,.nav-short{display:none}.nav-full{display:inline}.spacer{flex:1}.who{color:var(--ink2);align-items:center;gap:10px;font-size:12.5px;display:flex}.who b{color:var(--ink);font-weight:700}.rolechip{color:var(--accent);background:var(--accent-soft);border-radius:999px;margin-left:4px;padding:2px 9px;font-size:11px;font-weight:600;display:inline-block}.logout{color:var(--accent);background:var(--accent-soft);border:1px solid var(--accent);cursor:pointer;white-space:nowrap;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:600}main{padding:22px 20px 60px}.bottom-nav{display:none}.card{background:var(--paper2);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:14px;margin-bottom:14px;padding:20px}.card h2{align-items:center;gap:8px;margin-bottom:3px;font-size:16px;font-weight:700;display:flex}.card .sub{color:var(--ink3);margin-bottom:16px;font-size:12.5px}.row{flex-wrap:wrap;align-items:flex-end;gap:12px;display:flex}.num{font-variant-numeric:tabular-nums}.field{flex-direction:column;gap:5px;display:flex}.field label{color:var(--ink2);font-size:12px;font-weight:600}.field input,.field select,.field textarea{background:var(--paper2);border:1px solid var(--line);color:var(--ink);border-radius:9px;width:100%;padding:10px 12px;font-size:14px;transition:border-color .12s}.field input:hover,.field textarea:hover,.field select:hover{border-color:var(--ink3)}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--accent);outline:none}.grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px;display:grid}.btn{color:var(--paper);background:var(--ink);cursor:pointer;border:none;border-radius:10px;padding:12px 22px;font-size:14px;font-weight:600}.btn:hover{background:var(--accent)}.btn.block{width:100%}.btn.ghost{background:var(--paper2);color:var(--ink2);border:1px solid var(--line)}.hint{color:var(--ink3);font-size:12px}table{border-collapse:collapse;width:100%;font-size:13px}th,td{text-align:right;border-bottom:1px solid var(--line2);white-space:nowrap;padding:9px 10px}th{color:var(--ink3);font-size:11.5px;font-weight:600}th:first-child,td:first-child{text-align:left;font-weight:600}tr.total td{border-top:2px solid var(--accent);background:var(--paper);font-weight:800}.g{color:var(--pos)}.b{color:var(--neg)}.m{color:var(--ink3)}table.sched th,table.sched td{text-align:center;min-width:34px;padding:6px 4px;font-size:12px}table.sched th.sun{color:var(--neg)}.sched .cell{cursor:default}.sched .cell.edit{cursor:pointer}.sched .cell.edit:hover{background:var(--accent-soft)}.sched .cell.work{color:var(--ink);font-weight:600}.sched .cell.off{color:var(--ink3)}.sched .cell.off_req{color:var(--accent)}.sched .cell.annual,.sched .cell.monthly{color:var(--warn);font-size:11px}.posdot{vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:5px;display:inline-block}.posdot.hall{background:var(--accent)}.posdot.kitchen{background:var(--pos)}.posdot.pt{background:var(--warn)}.sched .ptrow td{background:var(--accent-soft)}.sched .deptrow td{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:5px 8px;font-size:12px}.sched .cell .hin{text-align:center;border:1px solid var(--accent);border-radius:6px;width:40px;padding:3px 2px;font-family:inherit;font-size:12px}.xbtn{color:var(--ink3);cursor:pointer;background:0 0;border:none;margin-left:7px;font-size:14px;font-weight:700}.xbtn:hover{color:var(--neg)}.acctbtn{border:1px solid var(--line);background:var(--paper2);color:var(--accent);cursor:pointer;border-radius:6px;margin-left:7px;padding:1px 6px;font-size:10.5px;font-weight:600}.acctbtn:hover{border-color:var(--accent)}.sched .cell.pending{box-shadow:inset 0 0 0 2px var(--warn)}.sched .cell.flex{color:#0369a1;background:#e0f2fe;font-weight:600}.sched .cell.special{color:#7c3aed;background:#f3e8ff;font-weight:600}.sched .cell.day-acked{background:#22c55e1f}.sched td{position:relative}.ack-mark{color:var(--pos);cursor:pointer;z-index:2;font-size:8px;font-weight:800;line-height:1;position:absolute;top:1px;right:2px}.segbtn{background:var(--paper2);color:var(--ink2);cursor:pointer;border:none;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:600}.segbtn[data-on=true]{background:var(--ink);color:var(--paper)}.calgrid{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.calhd{text-align:center;padding-bottom:2px;font-size:11.5px;font-weight:600}.calcell{border:1px solid var(--line2);background:var(--paper);border-radius:9px;flex-direction:column;gap:4px;min-height:56px;padding:6px;display:flex}.calcell.wk{min-height:78px}.calcell[data-today=true]{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}.calcell .cd{font-variant-numeric:tabular-nums;font-size:12.5px;font-weight:600}.calsp{text-align:center;background:var(--accent-soft);color:var(--accent);border-radius:6px;padding:2px 5px;font-size:11.5px;font-weight:600}.calsp.annual,.calsp.monthly{color:var(--warn);background:#faeeda}.calsp.off{background:var(--line);color:var(--ink2)}.calsp.work{background:var(--line2);color:var(--ink2);font-weight:500}.calsp.work.done{color:var(--pos);background:#e1f5ee;font-weight:700}.modal-bg{z-index:200;background:#14171c66;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--paper2);border:1px solid var(--line);width:100%;max-width:340px;box-shadow:var(--shadow);border-radius:14px;padding:22px 24px}.impbar{background:var(--ink);color:var(--paper);flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;padding:8px 14px;font-size:13px;display:flex}.impbar b{color:#fff}.impbar button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:999px;margin-left:6px;padding:5px 13px;font-family:inherit;font-size:12px;font-weight:600}.orgline{flex-direction:column;gap:6px;margin-top:8px;display:flex}.orgchip{border:1px solid var(--line);background:var(--paper);border-radius:10px;width:fit-content;padding:8px 12px;font-size:13.5px;display:inline-block}.orgchip.up{border-left:3px solid var(--ink3)}.orgme{border-top:1px dashed var(--line);margin-top:8px;padding-top:8px}.orgchip.me{border:1.5px solid var(--accent);background:var(--accent-soft)}.grouphd{color:var(--ink2);border-bottom:1px solid var(--line2);margin-bottom:8px;padding-bottom:5px;font-size:13px;font-weight:700}.empgrid{flex-direction:column;gap:8px;display:flex}.empcard{border:1px solid var(--line);background:var(--paper2);border-radius:10px;padding:8px 12px}.emprow{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.empname{min-width:84px;font-weight:700}.storedot{border-radius:3px;flex:none;width:11px;height:11px;display:inline-block}.rolesel{border:1px solid var(--line);background:var(--paper);border-radius:7px;padding:5px 8px;font-family:inherit;font-size:12.5px}.empbtns{gap:4px;display:flex}.empbtns button{border:1px solid var(--line);background:var(--paper);color:var(--ink2);cursor:pointer;border-radius:7px;padding:5px 10px;font-family:inherit;font-size:14px;font-weight:600}.empbtns button:hover{border-color:var(--ink3);color:var(--ink)}.notebox{border-top:1px solid var(--line2);margin-top:10px;padding-top:10px}.subbox{border:1px solid var(--line2);background:var(--paper);border-radius:12px;padding:14px 16px}.subbox-t{color:var(--accent);margin-bottom:10px;font-size:13px;font-weight:700}.kpis{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;display:grid}.kpi{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:15px}.kpi h3{color:var(--ink3);margin-bottom:7px;font-size:12px;font-weight:600}.kpi .v{font-size:22px;font-weight:800}.kpi .s{color:var(--ink2);margin-top:3px;font-size:12px}.login-wrap{justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:var(--paper2);border:1px solid var(--line);width:100%;max-width:360px;box-shadow:var(--shadow);border-radius:20px;padding:30px 26px}.login-card .logo{letter-spacing:.1em;text-transform:uppercase;color:#06b6d4;font-size:18px;font-weight:900}.login-card h1{margin:4px 0 22px;font-size:22px;font-weight:700}.login-card .field{margin-bottom:14px}.err{color:var(--neg);margin-top:10px;font-size:13px}.toast{background:var(--ink);color:var(--paper);box-shadow:var(--shadow);z-index:99;border-radius:999px;padding:12px 22px;font-size:13.5px;font-weight:600;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}@media (width<=640px){.bar-in{flex-wrap:nowrap;justify-content:center;padding:8px 14px;position:relative}.brand{flex-direction:row;justify-content:center;align-items:center;gap:8px}.brand .kick,.brand h1{font-size:13px}.logout{padding:5px 10px;font-size:11px}.daily-bar{gap:5px;padding:3px 14px 5px;overflow:hidden}.daily-text{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:10px;overflow:hidden}.daily-sep,.daily-store,.daily-role-icon,.daily-who,.daily-role{flex-shrink:0;font-size:10px}.nav{display:none}.bottom-nav{z-index:100;border-top:1px solid var(--line);-webkit-backdrop-filter:blur(14px);padding:5px 0 calc(5px + env(safe-area-inset-bottom));background:#fffffff5;justify-content:space-around;align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav a{color:var(--ink3);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;padding:2px 0;text-decoration:none;display:flex}.bottom-nav a.on{color:var(--accent)}.bnav-icon{flex-shrink:0;display:block}.bnav-label{font-size:10px;font-weight:600;line-height:1}main{padding:10px 10px calc(66px + env(safe-area-inset-bottom))}.card{border-radius:10px;margin-bottom:8px;padding:12px}.card h2{gap:6px;margin-bottom:2px;font-size:13px}.card .sub{margin-bottom:10px;font-size:11px}body{font-size:12px}.field{gap:3px}.field label{font-size:12px}.hint,.m{font-size:11px}.subbox{padding:10px 12px}.subbox-t{margin-bottom:6px;font-size:12px}.rolechip{padding:1px 7px;font-size:10px}.btn{padding:8px 14px;font-size:12px}.btn.ghost{padding:7px 12px}.field input,.field select,.field textarea{padding:5px 8px;font-size:12px}.grid{grid-template-columns:1fr;gap:8px}.row{gap:6px}table{font-size:11px}th,td{padding:6px 5px}th{font-size:10.5px}.kpis{grid-template-columns:repeat(2,1fr);gap:6px}.kpi{padding:10px}.kpi h3{margin-bottom:4px;font-size:11px}.kpi .v{font-size:18px}.kpi .s{font-size:10px}table.sched th,table.sched td{min-width:26px;padding:4px 2px;font-size:11px}.sched .cell .hin{width:32px;font-size:16px}.ack-mark{font-size:7px}.calgrid{gap:3px}.calcell{border-radius:6px;gap:2px;min-height:40px;padding:3px}.calcell.wk{min-height:56px}.calsp{padding:1px 3px;font-size:10px}.calcell .cd{font-size:11px}.calhd{font-size:10.5px}.orgchip{padding:6px 10px;font-size:12px}.orgme{margin-top:6px;padding-top:6px}.grouphd{margin-bottom:6px;font-size:12px}.emprow{gap:5px}.empbtns{flex-wrap:wrap;gap:3px}.empbtns button{padding:4px 7px;font-size:11px}.rolesel{padding:3px 5px;font-size:11px}.empname{min-width:52px;font-size:12px}.toast{bottom:calc(66px + env(safe-area-inset-bottom) + 8px);text-align:center;max-width:90vw;padding:10px 18px;font-size:12px}.login-card{border-radius:16px;padding:24px 18px}}.header-actions{flex-shrink:0;align-items:center;gap:8px;margin-left:auto;display:flex}.feedback-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#ef4444;border:1px solid #dc2626;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:600;transition:background .12s,border-color .12s}.feedback-btn:hover{background:#dc2626;border-color:#b91c1c}.notif-wrap{position:relative}.notif-bell{cursor:pointer;background:#fef08a;border:1px solid #facc15;border-radius:999px;padding:5px 8px;font-size:18px;line-height:1;transition:background .12s;position:relative}.notif-bell:hover{background:#fde047}.notif-badge{color:#fff;border:2px solid var(--paper2);background:#ef4444;border-radius:999px;justify-content:center;align-items:center;min-width:17px;height:17px;padding:0 3px;font-size:10px;font-weight:700;line-height:1;display:flex;position:absolute;top:-2px;right:-4px}.notif-panel{background:var(--paper2);border:1px solid var(--line);z-index:200;border-radius:14px;width:300px;max-height:420px;position:absolute;top:calc(100% + 8px);right:0;overflow-y:auto;box-shadow:0 4px 20px #0000001f}.notif-panel-header{border-bottom:1px solid var(--line2);padding:10px 14px 8px;font-size:13px;font-weight:700}.notif-section-title{color:var(--ink3);text-transform:uppercase;letter-spacing:.04em;padding:6px 14px 2px;font-size:11px;font-weight:600}.notif-row{border-bottom:1px solid var(--line2);color:var(--ink);align-items:flex-start;gap:8px;padding:9px 14px;font-size:13px;text-decoration:none;display:flex}.notif-row:last-child{border-bottom:none}.notif-row.muted{color:var(--ink3);font-size:12px}.notif-row-link:hover{background:var(--paper)}.notif-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px;margin-top:4px}.notif-dot.orange{background:#f97316}.notif-dot.blue{background:var(--accent)}.notif-read-btn{color:var(--ink3);border:1px solid var(--line);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;flex-shrink:0;padding:2px 7px;font-size:11px;font-weight:600;transition:border-color .1s,color .1s}.notif-read-btn:hover{border-color:var(--ink3);color:var(--ink)}.modal-overlay{z-index:300;background:#0006;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-card{background:var(--paper2);border-radius:16px;width:100%;padding:20px 22px;box-shadow:0 8px 32px #0000002e}@media (width<=640px){.header-actions{gap:4px;margin-left:0;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.feedback-btn{display:none}.notif-bell{padding:3px 5px;font-size:18px}.notif-panel{width:260px;right:-10px}}
