:root{--bg: #17150f;--card: #221f17;--card2: #1b1810;--border: #38332a;--text: #f1ebda;--dim: #a8a08a;--accent: #a6bb6e;--purple: #e0a062;--orange: #e5a94f;--green: #8fbf7a;--red: #e1796a;--serif: "Playfair Display", Georgia, "Times New Roman", serif}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.55;-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit}code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85em}::-webkit-scrollbar{width:8px;height:6px}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.app{display:flex;flex-direction:column;min-height:100vh}.nav{display:flex;align-items:center;gap:16px;padding:10px 20px;background:var(--card2);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.nav .logo{font-weight:800;font-size:1.05rem;letter-spacing:.3px;background:linear-gradient(135deg,var(--accent),var(--purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;white-space:nowrap}.nav .links{display:flex;gap:4px}.nav .links a{color:var(--dim);text-decoration:none;font-size:.85rem;padding:6px 12px;border-radius:8px;cursor:pointer;white-space:nowrap}.nav .links a.active{color:var(--text);background:#ffffff0f}.nav .links a:hover{color:var(--text)}.nav .spacer{flex:1}.pill{font-size:.75rem;color:var(--dim);border:1px solid var(--border);padding:6px 12px;border-radius:20px;background:transparent;white-space:nowrap}.pill:hover{border-color:var(--accent);color:var(--text)}.main{flex:1}.page{max-width:820px;margin:0 auto;padding:28px 20px 80px}.page.narrow{max-width:460px}.h1{font-family:var(--serif);font-weight:700;font-size:1.7rem;line-height:1.2}.h1 .muted{color:var(--dim);font-weight:400;font-size:1.1rem}.lead{color:var(--dim);font-size:.92rem;margin-top:6px}.muted{color:var(--dim)}.card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:20px;margin-top:18px}.field{margin-bottom:16px}.field label{display:block;font-size:.8rem;color:var(--dim);margin-bottom:6px}.input{width:100%;background:var(--card2);border:1px solid var(--border);color:var(--text);border-radius:10px;padding:11px 12px;font-size:.95rem;outline:none}.input:focus{border-color:var(--accent)}select.input{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.btn{border:1px solid var(--border);background:var(--card2);color:var(--text);border-radius:10px;padding:10px 16px;font-size:.9rem;font-weight:600}.btn:hover{border-color:var(--accent)}.btn.primary{background:var(--accent);color:#17150f;border-color:var(--accent)}.btn.primary:hover{filter:brightness(1.06)}.btn.primary:disabled{opacity:.55;cursor:default;filter:none}.btn.lg{padding:13px 18px;font-size:1rem}.auth-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.auth-card{width:380px;max-width:90vw;margin:0}.auth-logo{font-weight:800;font-size:1.3rem;margin-bottom:4px;text-align:center}.auth-sub{color:var(--dim);font-size:.85rem;margin-bottom:18px;text-align:center}.auth-error{color:var(--red);font-size:.8rem;margin-top:12px;line-height:1.45}.auth-foot{color:var(--dim);font-size:.72rem;margin-top:18px;text-align:center;line-height:1.5}.auth-eye{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:transparent;border:none;font-size:1rem;padding:6px}.setup-card{margin-top:22px}.shift-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.shift-tile{display:flex;flex-direction:column;gap:2px;align-items:flex-start;background:var(--card2);border:1px solid var(--border);color:var(--text);border-radius:10px;padding:12px}.shift-tile.active{border-color:var(--accent);background:#a6bb6e1a}.shift-name{font-weight:700;font-size:.95rem}.shift-time{font-size:.72rem;color:var(--dim)}.checklist-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.progress-bar{height:6px;background:var(--card2);border-radius:4px;margin-top:18px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);transition:width .25s ease}.progress-meta{display:flex;align-items:center;gap:10px;font-size:.8rem;color:var(--dim);margin-top:8px}.flag-pill{background:#e1796a26;color:var(--red);border:1px solid rgba(225,121,106,.35);font-size:.72rem;padding:2px 9px;border-radius:12px;font-weight:600}.flag-text{color:var(--orange)}.section-card{padding:8px 18px 14px}.section-title{font-family:var(--serif);font-size:1.05rem;font-weight:700;padding:12px 0 6px}.task{display:flex;flex-direction:column;gap:8px;padding:12px 0;border-top:1px solid var(--border)}.task:first-of-type{border-top:none}.task-main{display:flex;align-items:flex-start;gap:10px;cursor:pointer}.task-main input[type=checkbox]{width:20px;height:20px;margin-top:2px;accent-color:var(--accent);flex-shrink:0;cursor:pointer}.task-label{font-size:.95rem}.task-done .task-label{color:var(--dim)}.task-flagged{background:#e1796a0f;margin:0 -18px;padding:12px 18px}.task-inputs{display:flex;gap:8px;padding-left:30px}.input.status{width:150px;flex-shrink:0}.input.note{flex:1}.input.status-low{color:var(--orange)}.input.status-out{color:var(--red)}.hint{font-size:.82rem;color:var(--dim);margin-bottom:14px}.submit-card{margin-top:22px}.input.initials{width:140px;text-transform:uppercase;letter-spacing:2px;font-weight:700}.done-card{text-align:center;padding:40px 24px;margin-top:40px}.done-check{width:64px;height:64px;border-radius:50%;margin:0 auto 16px;background:#8fbf7a26;color:var(--green);border:2px solid var(--green);display:flex;align-items:center;justify-content:center;font-size:1.8rem}.done-card .btn{margin-top:20px}.date-controls{display:flex;gap:8px;align-items:center}.date-controls .input{width:auto;padding:8px 10px}.flags-card{border-color:#e1796a66;background:#e1796a0d}.flag-row{padding:12px 0;border-top:1px solid var(--border)}.flag-row:first-of-type{border-top:none}.flag-row-main{display:flex;align-items:center;gap:10px}.flag-task{font-weight:600;font-size:.95rem}.flag-note{color:var(--text);font-size:.9rem;margin-top:4px;font-style:italic}.flag-meta{color:var(--dim);font-size:.76rem;margin-top:4px}.badge{font-size:.7rem;padding:2px 8px;border-radius:10px;font-weight:600;white-space:nowrap}.badge-low{background:#e0a0622e;color:var(--orange)}.badge-out{background:#e1796a2e;color:var(--red)}.badge-ok{background:#8fbf7a2e;color:var(--green)}.badge-na{background:#a8a08a2e;color:var(--dim)}.shift-status-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:18px}.status-tile{margin-top:0;padding:14px}.status-tile-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.status-tile.pending{opacity:.75}.dot{width:10px;height:10px;border-radius:50%}.dot.green{background:var(--green)}.dot.gray{background:var(--border)}.status-by{font-size:.82rem}.empty-card{color:var(--dim);text-align:center;padding:32px}.sub-row{border-top:1px solid var(--border)}.sub-row:first-of-type{border-top:none}.sub-summary{display:flex;align-items:center;gap:12px;width:100%;background:transparent;border:none;color:var(--text);padding:14px 0;text-align:left}.sub-caret{color:var(--dim);width:14px}.sub-title{font-weight:600;font-size:.95rem;flex:1}.sub-stats{display:flex;align-items:center;gap:10px;font-size:.8rem;color:var(--dim)}.sub-detail{padding:0 0 14px 26px}.detail-item{display:flex;align-items:center;gap:8px;padding:5px 0;font-size:.88rem;flex-wrap:wrap}.detail-item.flagged{color:var(--text)}.detail-check{color:var(--green);width:16px}.detail-item:not(.flagged) .detail-check{color:var(--dim)}.detail-label{color:var(--dim)}.detail-item.flagged .detail-label{color:var(--text)}.detail-note{font-style:italic;color:var(--orange)}.role-pill{font-size:.7rem;color:var(--accent);border:1px solid rgba(166,187,110,.4);padding:3px 10px;border-radius:20px;background:#a6bb6e14}.who{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text)}.who-avatar{width:26px;height:26px;border-radius:50%;background:var(--card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:var(--accent)}.picker{max-width:560px;margin:0 auto;padding:48px 20px 80px}.picker-head{text-align:center;margin-bottom:28px}.picker-logo{font-size:1.5rem;font-weight:800}.picker-label{font-size:.75rem;text-transform:uppercase;letter-spacing:1px;color:var(--dim);margin:22px 0 10px}.tile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.tile{display:flex;flex-direction:column;align-items:center;gap:10px;background:var(--card);border:1px solid var(--border);color:var(--text);border-radius:14px;padding:20px 12px}.tile:hover{border-color:var(--accent);transform:translateY(-1px)}.tile-mgr:hover{border-color:var(--purple)}.tile-avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--purple));color:#17150f;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.1rem}.tile-name{font-size:.92rem;font-weight:600}.pin-card{max-width:340px;margin:30px auto 0;text-align:center;position:relative}.pin-back{position:absolute;left:14px;top:14px;background:transparent;border:none;color:var(--dim);font-size:.82rem}.pin-back:hover{color:var(--text)}.pin-avatar{width:64px;height:64px;border-radius:50%;margin:6px auto 12px;background:linear-gradient(135deg,var(--accent),var(--purple));color:#17150f;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.3rem}.pin-name{font-weight:700;font-size:1.1rem}.pin-sub{color:var(--dim);font-size:.82rem;margin-bottom:18px}.pin-dots{display:flex;justify-content:center;gap:14px;margin-bottom:18px}.pin-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--border)}.pin-dot.filled{background:var(--accent);border-color:var(--accent)}.pin-dots.shake{animation:shake .35s}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:8px}.key{background:var(--card2);border:1px solid var(--border);color:var(--text);border-radius:12px;padding:16px 0;font-size:1.3rem;font-weight:600}.key:hover{border-color:var(--accent)}.key:active{background:var(--card)}.key-del{font-size:1.1rem;color:var(--dim)}.day-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px}.day-card{margin-top:0;display:flex;flex-direction:column;gap:10px}.day-card.current{border-color:var(--accent)}.day-card.assigned{box-shadow:inset 3px 0 0 var(--purple)}.day-card-head{display:flex;justify-content:space-between;align-items:flex-start}.day-shift{font-family:var(--serif);font-size:1.15rem;font-weight:700}.day-time{font-size:.76rem;color:var(--dim)}.now-pill{font-size:.68rem;font-weight:700;color:#17150f;background:var(--accent);padding:2px 8px;border-radius:10px}.assigned-tag{font-size:.76rem;color:var(--purple);font-weight:600}.day-status{font-size:.85rem}.day-status.done{color:var(--green)}.day-status.pending{color:var(--dim)}.day-btn{width:100%;margin-top:auto}.mine-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-top:1px solid var(--border)}.mine-row:first-of-type{border-top:none}.mine-shift{font-weight:600;font-size:.9rem;min-width:90px}.mine-meta{font-size:.82rem;color:var(--dim);flex:1}.subtabs{display:flex;gap:6px;margin-top:18px;border-bottom:1px solid var(--border)}.subtab{background:transparent;border:none;color:var(--dim);font-size:.9rem;font-weight:600;padding:10px 14px;border-bottom:2px solid transparent;margin-bottom:-1px}.subtab.active{color:var(--text);border-bottom-color:var(--accent)}.subtab:hover{color:var(--text)}.status-assigned{font-size:.8rem;color:var(--dim);margin-bottom:6px}.status-warn{font-size:.76rem;color:var(--orange);margin-top:6px}.roster-table{margin-top:8px}.roster-head,.roster-row{display:grid;grid-template-columns:2fr 1.1fr 1fr auto;gap:10px;align-items:center}.roster-head{font-size:.74rem;color:var(--dim);text-transform:uppercase;letter-spacing:.5px;padding:6px 0}.roster-row{padding:6px 0}.roster-row .input{padding:9px 10px}.roster-del{color:var(--red);border-color:#e1796a4d}.roster-del:hover{border-color:var(--red)}.roster-actions{display:flex;gap:10px;margin-top:16px}.save-ok{color:var(--green);font-size:.82rem;margin-top:12px}@media (max-width: 560px){.task-inputs{flex-direction:column;padding-left:30px}.input.status{width:100%}.shift-status-grid,.day-grid{grid-template-columns:1fr}.checklist-head{flex-direction:column}.h1{font-size:1.45rem}.nav{gap:10px;flex-wrap:wrap}.who .who-name,.roster-head{display:none}.roster-row{grid-template-columns:1fr 1fr;gap:8px}}
