:root{--brand: #ffe817;--brand-dark: #d4b800;--brand-light: #fffce8;--brand-glow: rgba(255, 232, 23, .35);--surface: #ffffff;--surface-2: #fafafa;--bg-app: #f4f4f5;--text: #0a0a0a;--text-secondary: #525252;--text-muted: #737373;--border: #e5e5e5;--error: #dc2626;--error-bg: #fef2f2;--success: #15803d;--success-bg: #f0fdf4;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .12);--radius: 14px;--radius-sm: 10px;--radius-pill: 999px;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}body{margin:0;background:var(--bg-app);color:var(--text);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}.app{min-height:100dvh;display:flex;flex-direction:column;max-width:480px;margin:0 auto;background:var(--bg-app);box-shadow:0 0 0 1px var(--border)}.header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;background:var(--brand);color:var(--text);border-bottom:2px solid var(--text)}.header-brand{display:flex;align-items:center;gap:12px;min-width:0}.header-logo{width:44px;height:44px;object-fit:contain;flex-shrink:0}.brand{font-weight:800;font-size:1rem;letter-spacing:-.02em;line-height:1.2}.sub{font-size:.8rem;color:var(--text-secondary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.btn-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:2px solid var(--text);border-radius:var(--radius-sm);background:#ffffff80;color:var(--text);cursor:pointer;flex-shrink:0}.main{flex:1;padding:18px 18px 88px}.page-title{margin:0 0 16px;font-size:1.35rem;font-weight:800;letter-spacing:-.03em}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;display:flex;background:var(--surface);border-top:1px solid var(--border);box-shadow:0 -4px 20px #0000000f;z-index:100;padding-bottom:env(safe-area-inset-bottom,0)}.bottom-nav a{position:relative;flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 4px 12px;text-decoration:none;color:var(--text-muted);font-size:.68rem;font-weight:600;letter-spacing:.02em;text-transform:uppercase}.bottom-nav a svg{opacity:.55}.bottom-nav a.active{color:var(--text)}.bottom-nav a.active svg{opacity:1}.bottom-nav a.active:before{content:"";position:absolute;top:0;width:32px;height:3px;background:var(--brand);border-radius:0 0 4px 4px}.card{background:var(--surface);border-radius:var(--radius);padding:18px;margin-bottom:14px;box-shadow:var(--shadow-sm);border:1px solid var(--border)}.card-title{margin:0 0 4px;font-size:1.05rem;font-weight:700}.card-sub{margin:0;color:var(--text-muted);font-size:.85rem}.btn-primary,.btn-secondary,.btn-ghost,.btn-text{border:none;border-radius:var(--radius-sm);padding:14px 20px;font-size:.95rem;font-family:inherit;cursor:pointer;width:100%;margin-top:10px;font-weight:700;transition:transform .1s,box-shadow .15s}.btn-primary:active:not(:disabled),.btn-secondary:active:not(:disabled){transform:scale(.98)}.btn-primary{background:linear-gradient(135deg,#1a1a1a,#333);color:var(--brand);box-shadow:var(--shadow-md);border:2px solid var(--text)}.btn-secondary{background:var(--surface);border:2px solid var(--text);color:var(--text)}.btn-ghost{background:transparent;border:2px dashed var(--border);color:var(--text-secondary);font-weight:600}.btn-text{background:transparent;color:var(--text-muted);font-weight:600;width:auto;margin-top:0;padding:8px 12px}.btn-lg{padding:16px 24px;font-size:1rem;border-radius:var(--radius)}.btn-primary:disabled,.btn-secondary:disabled{opacity:.55;cursor:wait}.row-btns{display:flex;gap:10px}.row-btns button{flex:1;margin-top:0}.alert{padding:12px 14px;border-radius:var(--radius-sm);font-size:.88rem;font-weight:500;margin-bottom:14px}.alert-error{background:var(--error-bg);color:var(--error);border:1px solid #fecaca}.alert-success{background:var(--success-bg);color:var(--success);border:1px solid #bbf7d0}.alert-info{background:var(--brand-light);color:var(--text);border:1px solid var(--brand-dark);font-size:.82rem}.muted{color:var(--text-muted);font-size:.88rem}.login-page{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 20px;background:var(--brand);max-width:480px;margin:0 auto}.login-logo-wrap{text-align:center;margin-bottom:28px}.login-logo{width:min(200px,65vw);height:auto;display:block;margin:0 auto 8px;filter:drop-shadow(0 4px 12px rgba(0,0,0,.1))}.login-tagline{margin:0;font-size:.75rem;font-weight:500;letter-spacing:.12em;text-transform:lowercase;color:var(--text-secondary)}.login-card{background:var(--surface);border-radius:16px;width:100%;max-width:380px;box-shadow:var(--shadow-lg);overflow:hidden}.login-card-header{padding:22px 24px 8px;text-align:center}.login-card-header h1{margin:0;font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--brand-dark)}.login-card-header p{margin:6px 0 0;font-size:.85rem;color:var(--text-muted)}.login-form{padding:16px 24px 24px}.field{margin-bottom:14px}.field-label{display:block;font-size:.75rem;font-weight:600;color:var(--text-secondary);margin-bottom:6px;letter-spacing:.04em;text-transform:uppercase}.input-wrap{display:flex;align-items:center;gap:10px;border:1.5px solid #d4d4d4;border-radius:var(--radius-sm);padding:0 14px;background:var(--surface-2);transition:border-color .15s,box-shadow .15s}.input-wrap:focus-within{border-color:var(--brand-dark);box-shadow:0 0 0 3px var(--brand-glow);background:var(--surface)}.input-icon{color:var(--brand-dark);display:flex;flex-shrink:0}.input-wrap input{flex:1;border:none;background:transparent;padding:14px 0;font-size:1rem;font-family:inherit;color:var(--text);min-width:0}.input-wrap input:focus{outline:none}.input-wrap input::placeholder{color:#a3a3a3}.input-toggle{background:none;border:none;padding:4px;cursor:pointer;color:var(--text-muted);display:flex}.login-form .btn-primary{margin-top:8px;padding:15px;font-size:1rem;text-transform:uppercase;letter-spacing:.06em}.login-footer{padding:0 24px 20px;text-align:center}.hint{font-size:.78rem;color:var(--text-muted);margin:0;line-height:1.5}.hint strong{color:var(--text);font-weight:600}.status-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius-pill);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:12px}.status-pill.on{background:var(--text);color:var(--brand)}.status-pill.off{background:var(--brand-light);color:var(--text);border:1.5px solid var(--brand-dark)}.zone-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.zone-chip{display:inline-flex;align-items:center;gap:5px;padding:6px 10px;background:var(--brand-light);border:1px solid var(--brand-dark);border-radius:var(--radius-pill);font-size:.75rem;font-weight:600}.shift-info{margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}.shift-time{font-size:.95rem;margin:0 0 10px}.action-block{margin-top:4px}.photo-step .req-list{margin:10px 0 0;padding:0;list-style:none}.photo-step .req-list li{padding:8px 12px;background:var(--brand-light);border-radius:var(--radius-sm);margin-bottom:6px;font-size:.85rem;font-weight:600}.photo-step .req-list li:before{content:"✓ ";color:var(--brand-dark)}.photo-title{display:flex;align-items:center;gap:8px}.camera,.preview{width:100%;border-radius:var(--radius);background:#111;margin:14px 0;max-height:340px;object-fit:cover;border:2px solid var(--text)}body.camera-open{overflow:hidden}.sr-only-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.camera-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9998;display:flex;flex-direction:column;background:#0a0a0a;color:#fff;max-width:480px;margin:0 auto;padding-bottom:calc(110px + env(safe-area-inset-bottom,0))}.camera-overlay-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 8px;padding-top:calc(12px + env(safe-area-inset-top,0));flex-shrink:0;background:#0a0a0a}.camera-close{border:none;background:#ffffff26;color:#fff;font:inherit;font-weight:700;font-size:.9rem;padding:10px 16px;border-radius:var(--radius-pill);cursor:pointer;min-height:44px}.camera-close-spacer{width:60px}.camera-overlay-title{display:flex;align-items:center;gap:8px;font-weight:700;font-size:.95rem}.camera-overlay-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0 18px 12px}.camera-overlay-hint{margin:0 0 12px;font-size:.88rem;color:#ffffffd9;text-align:center;line-height:1.45}.camera-req-list{margin:0 0 16px;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px}.camera-req-list li{padding:10px 14px;background:#ffe8171f;border:1px solid rgba(255,232,23,.5);border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;color:var(--brand)}.camera-req-list li:before{content:"✓ "}.camera-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;min-height:220px;padding:24px 16px;border:2px dashed rgba(255,232,23,.45);border-radius:var(--radius);text-align:center;color:#ffffffe6}.camera-placeholder svg{width:48px;height:48px;opacity:.9}.camera-placeholder p{margin:0;font-weight:700;font-size:1rem}.camera-placeholder-sub{font-weight:500!important;font-size:.85rem!important;color:#ffffffa6!important}.camera-preview-img{width:100%;max-height:50vh;object-fit:contain;border-radius:var(--radius);border:2px solid var(--brand);background:#111;display:block}.camera-bar{position:fixed;left:0;right:0;bottom:0;z-index:9999;max-width:480px;margin:0 auto;padding:14px 18px calc(14px + env(safe-area-inset-bottom,0));background:#0a0a0a;border-top:3px solid var(--brand);box-shadow:0 -8px 32px #00000073}.camera-bar-btn{margin-top:0!important;min-height:56px;font-size:1.05rem!important;letter-spacing:.04em;background:var(--brand)!important;color:var(--text)!important;border-color:var(--text)!important}.camera-bar-btns{width:100%}.camera-bar-btns .btn-primary,.camera-bar-btns .btn-secondary{margin-top:0;min-height:52px}.camera-bar-btns .btn-secondary{background:#ffffff1f;color:#fff;border-color:#fff6}.camera-bar-btns .btn-primary{background:var(--brand)!important;color:var(--text)!important}.camera-alert{margin:0 0 12px;padding:12px 14px;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;line-height:1.45}.camera-alert-error{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.thumb{width:56px;height:56px;object-fit:cover;border-radius:var(--radius-sm);border:2px solid var(--brand-dark)}.hours-hero{background:linear-gradient(145deg,var(--brand) 0%,#fff176 100%);border:2px solid var(--text);border-radius:var(--radius);padding:24px 20px;text-align:center;margin-bottom:14px;box-shadow:var(--shadow-md)}.hours-hero-label{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);margin:0 0 4px}.hours-hero-value{font-size:2rem;font-weight:800;letter-spacing:-.04em;margin:0}.stats{display:grid;grid-template-columns:1fr 1fr;gap:10px}.stat{background:var(--surface);padding:16px;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.stat-label{display:block;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:4px}.stat-value{font-weight:800;font-size:1.15rem;letter-spacing:-.02em}.history-list{list-style:none;padding:0;margin:0}.history-item{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px}.history-date{font-weight:700;font-size:.92rem}.history-duration{font-size:.85rem;color:var(--text-muted);margin-top:2px}.badge{display:inline-flex;padding:3px 10px;border-radius:var(--radius-pill);font-size:.7rem;font-weight:700;text-transform:uppercase;background:var(--text);color:var(--brand)}.admin-section-title{margin:0 0 12px;font-size:.9rem;font-weight:700}.admin-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border);gap:12px}.admin-row:last-child{border-bottom:none;padding-bottom:0}.admin-name{font-weight:700;font-size:.92rem}.admin-meta{font-size:.8rem;color:var(--text-muted);margin-top:2px}.history-zones{font-size:.8rem;color:var(--text-secondary);margin-top:4px}.history-missing{font-size:.78rem;color:var(--error);margin-top:4px;font-weight:600}.badge-ok{background:var(--success);color:#fff}.badge-warn{background:#f59e0b;color:#000}.integration-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.chip{padding:6px 12px;border-radius:var(--radius-pill);font-size:.75rem;font-weight:700;border:1px solid var(--border);background:var(--surface)}.chip.on{background:var(--brand-light);border-color:var(--brand-dark)}.chip.off{color:var(--text-muted)}.admin-warn{font-size:.78rem;color:var(--error);margin-top:4px;font-weight:600}.admin-hint{margin:0 0 12px;font-size:.82rem}.psid-row{display:flex;flex-direction:column;gap:8px;padding:12px 0;border-bottom:1px solid var(--border)}@media (min-width: 400px){.psid-row{flex-direction:row;align-items:center;justify-content:space-between}}.psid-input{width:100%;max-width:220px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font:inherit;font-size:.85rem}.empty-state{text-align:center;padding:32px 16px;color:var(--text-muted)}.loading{text-align:center;padding:40px;color:var(--text-muted)}.center{text-align:center;padding:40px}.hours-page .page-title{margin:0}.hours-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px;flex-wrap:wrap}.month-picker{display:flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-pill);padding:4px 6px}.month-nav{border:none;background:var(--brand-light);color:var(--text);width:32px;height:32px;border-radius:50%;font-size:1.2rem;line-height:1;cursor:pointer;font-weight:700}.month-label{position:relative;font-weight:700;font-size:.88rem;padding:0 6px;min-width:72px;text-align:center}.month-label input[type=month]{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer;width:100%}.week-label{font-weight:700;font-size:.82rem;padding:0 4px;white-space:nowrap}.hours-tabs{display:flex;gap:8px;margin-bottom:14px;overflow-x:auto;padding-bottom:2px}.hours-tab{flex:1;min-width:0;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);border-radius:var(--radius-pill);padding:10px 8px;font:inherit;font-size:.78rem;font-weight:700;cursor:pointer;white-space:nowrap}.hours-tab.active{background:var(--brand);border-color:var(--text);color:var(--text)}.cal-panel{padding:14px}.cal-summary{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:10px}.cal-summary-2{max-width:100%}.cal-summary>div{background:var(--brand-light);border:1px solid var(--brand-dark);border-radius:var(--radius-sm);padding:10px 8px;text-align:center}.cal-summary-label{display:block;font-size:.68rem;font-weight:700;text-transform:uppercase;color:var(--text-muted);margin-bottom:4px}.cal-summary strong{font-size:1rem}.cal-grid-month{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.cal-grid-week{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.cal-week-col{display:flex;flex-direction:column;gap:4px}.cal-head{text-align:center;font-size:.72rem;font-weight:800;color:var(--text-muted);padding:4px 0}.cal-cell{aspect-ratio:1;min-height:44px;border-radius:8px;border:1px solid var(--border);background:var(--surface);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;padding:2px;position:relative}.cal-day{position:absolute;top:3px;left:5px;font-size:.62rem;font-weight:700;color:var(--text-muted)}.cal-value{font-size:1rem;font-weight:800;line-height:1;margin-top:6px}.cal-sub{font-size:.58rem;color:var(--text-secondary);font-weight:600}.cal-outside{opacity:.3;background:var(--surface-2)}.cal-outside .cal-value{visibility:hidden}.cal-worked{background:var(--brand);border-color:var(--text);color:var(--text)}.cal-worked .cal-day{color:var(--text-secondary)}.cal-today{background:var(--brand-light);border-color:var(--text);border-width:2px;color:var(--text)}.cal-empty,.cal-future{background:var(--surface);border-color:var(--border);color:var(--text-muted)}.cal-is-today{box-shadow:0 0 0 2px var(--text)}.cal-dash{font-size:.75rem!important;font-weight:600!important;opacity:.35}.cal-hint{margin:0 0 12px;font-size:.78rem;color:var(--text-muted);line-height:1.4}
