:root{--bg-primary: #0d0d12;--bg-secondary: #16161d;--bg-tertiary: #1e1e28;--bg-card: #1a1a24;--bg-hover: #252532;--text-primary: #f0f0f5;--text-secondary: #9898a8;--text-muted: #5c5c6d;--accent-primary: #00d4aa;--accent-secondary: #00b894;--accent-glow: rgba(0, 212, 170, .15);--warning: #ffc107;--error: #ff5757;--success: #00d4aa;--border-color: #2a2a38;--border-subtle: #1f1f2a;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-full: 9999px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 20px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .5);--shadow-glow: 0 0 30px var(--accent-glow);--font-sans: "Outfit", system-ui, sans-serif;--font-mono: "JetBrains Mono", monospace;--transition-fast: .15s ease;--transition-normal: .25s ease}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.5;min-height:100dvh;overflow-x:hidden;-webkit-font-smoothing:antialiased}body:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 80%,var(--accent-glow) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(0,100,200,.08) 0%,transparent 50%),linear-gradient(180deg,var(--bg-primary) 0%,var(--bg-secondary) 100%);pointer-events:none;z-index:-1}#root{min-height:100dvh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;letter-spacing:-.02em}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}.mono{font-family:var(--font-mono);font-size:.9em}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.25rem;font-family:var(--font-sans);font-size:.95rem;font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent-primary);color:var(--bg-primary);box-shadow:var(--shadow-glow)}.btn-primary:hover:not(:disabled){background:var(--accent-secondary);transform:translateY(-1px)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--accent-primary)}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover:not(:disabled){opacity:.9}.btn-icon{width:44px;height:44px;padding:0;border-radius:var(--radius-full)}.btn-lg{padding:1rem 2rem;font-size:1.1rem}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.25rem;transition:all var(--transition-normal)}.card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-glow)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.form-group{margin-bottom:1.25rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:.5rem}.form-input{width:100%;padding:.75rem 1rem;font-family:var(--font-sans);font-size:1rem;color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-glow)}.form-input::placeholder{color:var(--text-muted)}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239898a8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.5rem}.badge{display:inline-flex;align-items:center;padding:.25rem .625rem;font-size:.75rem;font-weight:500;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em}.badge-success{background:#00d4aa26;color:var(--success)}.badge-warning{background:#ffc10726;color:var(--warning)}.badge-error{background:#ff575726;color:var(--error)}.badge-pending{background:#9898a826;color:var(--text-secondary)}.progress-bar{height:6px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));border-radius:var(--radius-full);transition:width var(--transition-normal)}.container{width:100%;max-width:480px;margin:0 auto;padding:0 1rem}.page{flex:1;padding:1.5rem 0}.page-header{margin-bottom:1.5rem}.page-title{margin-bottom:.25rem}.page-subtitle{color:var(--text-secondary);font-size:.95rem}.nav-bottom{position:fixed;bottom:0;left:0;right:0;background:var(--bg-card);border-top:1px solid var(--border-color);padding:.5rem 1rem;padding-bottom:calc(.5rem + env(safe-area-inset-bottom));display:flex;justify-content:space-around;z-index:100}.nav-item{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem 1rem;color:var(--text-muted);text-decoration:none;font-size:.75rem;font-weight:500;transition:all var(--transition-fast);border-radius:var(--radius-md)}.nav-item.active,.nav-item:hover{color:var(--accent-primary)}.nav-item svg{width:24px;height:24px}.photo-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1rem}.photo-card{aspect-ratio:4/3;border-radius:var(--radius-md);overflow:hidden;position:relative;background:var(--bg-tertiary);border:2px dashed var(--border-color);cursor:pointer;transition:all var(--transition-fast)}.photo-card.captured{border-style:solid;border-color:var(--success)}.photo-card.required:not(.captured){border-color:var(--warning)}.photo-card:hover{border-color:var(--accent-primary)}.photo-card img{width:100%;height:100%;object-fit:cover}.photo-card-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 50%);display:flex;flex-direction:column;justify-content:flex-end;padding:.75rem}.photo-card-title{font-size:.75rem;font-weight:500;color:#fff}.photo-card-status{position:absolute;top:.5rem;right:.5rem}.camera-container{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;z-index:1000;display:flex;flex-direction:column}.camera-video{flex:1;object-fit:cover;width:100%}.camera-controls{position:absolute;bottom:0;left:0;right:0;padding:1.5rem;padding-bottom:calc(1.5rem + env(safe-area-inset-bottom));display:flex;justify-content:space-around;align-items:center;background:linear-gradient(to top,rgba(0,0,0,.8) 0%,transparent 100%)}.capture-btn{width:72px;height:72px;border-radius:50%;background:#fff;border:4px solid rgba(255,255,255,.3);cursor:pointer;transition:all var(--transition-fast)}.capture-btn:hover{transform:scale(1.05)}.capture-btn:active{transform:scale(.95)}.camera-info{position:absolute;top:0;left:0;right:0;padding:1rem;padding-top:calc(1rem + env(safe-area-inset-top));background:linear-gradient(to bottom,rgba(0,0,0,.6) 0%,transparent 100%);color:#fff}.example-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.3}.example-overlay img{width:100%;height:100%;object-fit:contain}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem}.modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:400px;max-height:90vh;overflow-y:auto}.modal-header{padding:1.25rem;border-bottom:1px solid var(--border-color)}.modal-body{padding:1.25rem}.modal-footer{padding:1.25rem;border-top:1px solid var(--border-color);display:flex;gap:.75rem;justify-content:flex-end}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.status-dot.online{background:var(--success);box-shadow:0 0 8px var(--success)}.status-dot.offline{background:var(--text-muted)}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.empty-state svg{width:64px;height:64px;margin-bottom:1rem;opacity:.5}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.fade-in{animation:fadeIn var(--transition-normal) ease-out}.slide-up{animation:slideUp var(--transition-normal) ease-out}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-muted{color:var(--text-secondary)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-error{color:var(--error)}.w-full{width:100%}.pb-nav{padding-bottom:calc(7rem + env(safe-area-inset-bottom))}.login-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}.login-container{width:100%;max-width:360px}.login-header{text-align:center;margin-bottom:2rem}.login-icon{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;background:var(--accent-glow);border-radius:var(--radius-full);margin-bottom:1.25rem;color:var(--accent-primary)}.login-header h1{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.login-header p{color:var(--text-secondary);font-size:.9rem}.login-form{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem}.login-error{background:#ff57571a;border:1px solid var(--error);color:var(--error);padding:.75rem 1rem;border-radius:var(--radius-md);font-size:.85rem;margin-bottom:1rem;text-align:center}.login-footer{text-align:center;margin-top:1.5rem;font-size:.8rem;color:var(--text-muted)}.photo-card-multi{grid-column:span 2;border-radius:var(--radius-md);background:var(--bg-tertiary);border:2px dashed var(--border-color);overflow:hidden;transition:all var(--transition-fast)}.photo-card-multi.captured{border-style:solid;border-color:var(--success)}.photo-card-multi.required:not(.captured){border-color:var(--warning)}.photo-card-multi-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;cursor:pointer;background:var(--bg-card);border-bottom:1px solid var(--border-subtle)}.photo-card-multi-header:hover{background:var(--bg-hover)}.photo-card-multi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;padding:.75rem}.photo-card-multi-thumb{aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;position:relative;cursor:pointer;background:var(--bg-secondary)}.photo-card-multi-thumb img{width:100%;height:100%;object-fit:cover}.photo-card-multi-thumb .delete-btn{position:absolute;top:2px;right:2px;width:20px;height:20px;border-radius:50%;background:var(--error);color:#fff;border:none;font-size:14px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast)}.photo-card-multi-thumb:hover .delete-btn{opacity:1}.photo-card-multi-thumb.add-more{border:2px dashed var(--border-color);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;color:var(--text-muted);background:transparent}.photo-card-multi-thumb.add-more:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.photo-card-multi-empty{padding:2rem;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer}.photo-card-multi-empty:hover{background:var(--bg-hover)}.photo-card-multi-preview{display:flex;gap:.375rem;padding:.75rem;overflow-x:auto;cursor:pointer}.photo-card-multi-preview:hover{background:var(--bg-hover)}.mini-thumb{width:48px;height:48px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0;background:var(--bg-secondary)}.mini-thumb img{width:100%;height:100%;object-fit:cover}.mini-thumb.more{display:flex;align-items:center;justify-content:center;font-size:.7rem;color:var(--text-muted);background:var(--bg-tertiary)}.mini-thumb.add{display:flex;align-items:center;justify-content:center;border:2px dashed var(--border-color);background:transparent;color:var(--text-muted)}.mini-thumb.add:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.badge-secondary{background:var(--bg-tertiary);color:var(--text-secondary)}.badge-muted{background:#5c5c6d33;color:var(--text-muted)}.skip-toggle-btn{position:absolute;top:.5rem;left:.5rem;width:28px;height:28px;border-radius:50%;background:#0009;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all var(--transition-fast);z-index:5}.photo-card:hover .skip-toggle-btn,.photo-card.skipped .skip-toggle-btn{opacity:1}.skip-toggle-btn:hover{background:#000c;color:var(--text-primary)}.photo-card.skipped{border-style:solid;border-color:var(--text-muted);opacity:.6;background:var(--bg-secondary)}.photo-card.skipped:hover{opacity:.8}.photo-card-multi.skipped{border-style:solid;border-color:var(--text-muted);opacity:.6;background:var(--bg-secondary)}.job-card-completed{opacity:.7;background:var(--bg-secondary)}.job-card-completed:hover{opacity:.85}.app-header{position:fixed;top:0;left:0;right:0;z-index:100;background:var(--bg-card);border-bottom:1px solid var(--border-color);padding:.5rem 1rem;padding-top:calc(.5rem + env(safe-area-inset-top))}.app-header-content{max-width:480px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:.5rem}.app-header-left,.app-header-right{display:flex;align-items:center;gap:.5rem}.app-version{font-size:.65rem;color:var(--text-muted);font-family:var(--font-mono);background:var(--bg-tertiary);padding:.2rem .4rem;border-radius:var(--radius-sm)}.header-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:.3rem .6rem;font-size:.7rem;cursor:pointer;display:flex;align-items:center;gap:.3rem;color:var(--text-secondary);transition:all var(--transition-fast)}.header-btn:hover{background:var(--bg-hover);border-color:var(--accent-primary);color:var(--text-primary)}.header-btn:disabled{opacity:.5;cursor:not-allowed}.user-btn{max-width:120px}.user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-indicator{display:flex;align-items:center;gap:.3rem;font-size:.65rem;color:var(--text-muted)}.status-text{display:none}@media (min-width: 400px){.status-text{display:inline}}.page{flex:1;padding:1.5rem 0;padding-top:calc(4rem + env(safe-area-inset-top));min-height:100vh;overflow-y:auto}
