*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,SF Pro Text,Helvetica,Arial,sans-serif;background:#f2f2f7;min-height:100vh;display:flex;justify-content:center}#root{width:100%;max-width:430px;min-height:100vh;background:#fff;display:flex;flex-direction:column}:root{--teal: #50a2ad;--red: #d64040;--green: #0f6e56;--bg: #ffffff;--bg2: #f2f2f7;--border: #e0e0e0;--text: #1a1a1a;--muted: #6b6b6b}input,select,textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px;color:var(--text);background:var(--bg2);outline:none;font-family:inherit}input:focus,select:focus{border-color:var(--teal);background:#fff}button{cursor:pointer;font-family:inherit}.btn-primary{width:100%;padding:13px;background:var(--teal);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600}.btn-secondary{padding:8px 14px;background:var(--bg2);color:var(--text);border:1px solid var(--border);border-radius:8px;font-size:13px;font-weight:500}.btn-teal{padding:8px 14px;background:var(--teal);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:500}.btn-red{padding:8px 14px;background:#fcebeb;color:#a32d2d;border:1px solid #f09595;border-radius:8px;font-size:13px;font-weight:500}.card{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:14px 16px;margin:0 16px}.section-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;padding:0 16px;margin-bottom:6px}.list-card{background:var(--bg);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin:0 16px}.list-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border)}.list-item:last-child{border-bottom:none}.badge{display:inline-block;font-size:11px;padding:3px 9px;border-radius:20px;font-weight:500}.badge-green{background:#d4f0e8;color:#0f6e56}.badge-amber{background:#faeeda;color:#854f0b}.badge-blue{background:#e6f1fb;color:#185fa5}.badge-teal{background:#50a2ad26;color:#2d7a85}.success-box{background:#d4f0e8;border:1px solid #5dcaa5;border-radius:10px;padding:10px 14px;font-size:13px;color:#085041;text-align:center;margin:0 16px}.alert-box{background:#faeeda;border:1px solid #fac775;border-radius:10px;padding:10px 14px;font-size:12px;color:#854f0b;margin:0 16px;line-height:1.6}.avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}.screen{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:12px;padding:14px 0 20px;background:var(--bg2)}.top-bar{background:var(--teal);padding:calc(10px + env(safe-area-inset-top,0px)) 18px 14px;color:#fff;flex-shrink:0}.top-bar-sub{font-size:11px;opacity:.65;text-transform:uppercase;letter-spacing:.05em}.top-bar-title{font-size:18px;font-weight:600}.bottom-nav{background:var(--bg);border-top:1px solid var(--border);display:flex;flex-shrink:0;padding:6px 0 calc(10px + env(safe-area-inset-bottom,0px))}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:2px 0;cursor:pointer}.nav-item .icon{font-size:18px;line-height:1.3}.nav-item .label{font-size:9px;color:var(--muted)}.nav-item.active .label{color:var(--teal);font-weight:600}.login-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 24px;gap:14px;background:var(--bg)}.login-logo{width:68px;height:68px;background:var(--teal);border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:32px}.login-title{font-size:22px;font-weight:700;color:var(--teal)}.login-form{width:100%;display:flex;flex-direction:column;gap:10px}.error-text{color:var(--red);font-size:13px;text-align:center}.fg{display:flex;flex-direction:column;gap:5px}.fl{font-size:12px;font-weight:500;color:var(--muted)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:0 16px}.stat-card{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:12px 14px}.stat-label{font-size:11px;color:var(--muted);margin-bottom:2px}.stat-value{font-size:24px;font-weight:600;color:var(--text)}.shift-row{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid var(--border)}.shift-row:last-child{border-bottom:none}.day-dot{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0}.day-dot.work{background:var(--teal);color:#fff}.day-dot.today{background:#3a8a94;color:#fff}.day-dot.off{background:var(--bg2);color:var(--muted)}.clock-ring{width:120px;height:120px;border-radius:50%;border:5px solid var(--teal);display:flex;flex-direction:column;align-items:center;justify-content:center;margin:0 auto}.progress-bar{height:5px;background:var(--bg2);border-radius:3px;overflow:hidden;margin-top:6px}.progress-fill{height:100%;border-radius:3px;background:var(--teal)}
