:root{--bg-primary: #0d1a2d;--bg-secondary: #132238;--bg-tertiary: #1a2d47;--bg-card: #152640;--bg-hover: #1e3654;--text-primary: #ffffff;--text-secondary: #e0e8f0;--text-muted: #a8b8c8;--accent-primary: #CFB53B;--accent-secondary: #e5c84a;--accent-glow: rgba(207, 181, 59, .3);--gold: #CFB53B;--gold-dark: #B8860B;--gold-light: #e5c84a;--gold-glow: rgba(207, 181, 59, .35);--warning: #ffd54f;--error: #ff8a8a;--success: #69f0ae;--border-color: #3a5070;--border-subtle: #2a3f5f;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .1);--shadow-md: 0 4px 16px rgba(0, 0, 0, .15);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .2);--shadow-glow: 0 0 24px var(--accent-glow);--font-sans: "Roboto", "Inter", system-ui, sans-serif;--font-mono: "Roboto Mono", "Fira Code", monospace;--transition-fast: .12s ease;--transition-normal: .2s ease;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px);--header-height: 3.75rem;--active-users-height: 0px;--nav-height: 4.5rem;--touch-target-min: 48px}body.has-active-users{--active-users-height: 2rem}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:17px;-webkit-tap-highlight-color:transparent;-webkit-text-size-adjust:100%;background:var(--bg-primary)}@media screen and (min-width: 360px) and (max-width: 480px) and (min-resolution: 2dppx){html{font-size:18px}}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;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 20% 0%,rgba(207,181,59,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 100%,rgba(207,181,59,.05) 0%,transparent 50%);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.25;letter-spacing:-.02em;color:var(--text-primary)}h1{font-size:clamp(1.5rem,4vw,2rem)}h2{font-size:clamp(1.25rem,3vw,1.5rem)}h3{font-size:clamp(1rem,2.5vw,1.25rem)}.mono{font-family:var(--font-mono);font-size:.875em}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:.75rem 1.25rem;min-height:var(--touch-target-min);font-family:var(--font-sans);font-size:1rem;font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-decoration:none;white-space:nowrap;touch-action:manipulation;-webkit-user-select:none;user-select:none}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:var(--gold);color:#1a1a1a;font-weight:700;box-shadow:0 2px 12px #cfb53b66}.btn-primary:hover:not(:disabled){background:var(--gold-light);box-shadow:0 4px 16px #cfb53b80}.btn-gold{background:var(--gold);color:#1a1a1a;font-weight:700;box-shadow:0 2px 12px #cfb53b66}.btn-gold:hover:not(:disabled){background:var(--gold-dark)}.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(--text-muted)}.btn-danger{background:var(--error);color:#fff}.btn-warning{background:var(--warning);color:#1a1a1a;font-weight:700}.btn-icon{width:44px;height:44px;padding:0;border-radius:var(--radius-full);flex-shrink:0}.btn-sm{padding:.4rem .75rem;font-size:.8rem}.btn-lg{padding:.875rem 1.5rem;font-size:1rem}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-md);transition:border-color var(--transition-normal),box-shadow var(--transition-normal)}.card:hover{border-color:var(--border-subtle)}.collapsible-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:var(--space-xs) 0;margin:calc(-1 * var(--space-xs)) 0;-webkit-user-select:none;user-select:none}.collapsible-header:hover{opacity:.8}.collapsible-header h3{margin:0}.collapsible-content{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border-color);animation:fadeIn .2s ease-out}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.form-group{margin-bottom:var(--space-lg)}.form-label{display:block;font-size:.8rem;font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-sm);text-transform:uppercase;letter-spacing:.05em}.form-input{width:100%;padding:.875rem 1rem;min-height:var(--touch-target-min);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(--gold);box-shadow:0 0 0 3px var(--gold-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='%23606070' 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:.2rem .5rem;font-size:.7rem;font-weight:600;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.03em}.badge-success{background:#4ade8033;color:var(--success)}.badge-warning{background:#cfb53b40;color:var(--gold)}.badge-error{background:#ff6b7a33;color:var(--error)}.badge-pending,.badge-muted{background:#60607026;color:var(--text-muted)}.badge-secondary{background:var(--bg-tertiary);color:var(--text-secondary)}.progress-bar{height:4px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--gold));border-radius:var(--radius-full);transition:width var(--transition-normal)}.upload-progress-container{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border-color)}.upload-progress-bar{height:6px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--space-sm)}.upload-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--gold));border-radius:var(--radius-full);transition:width .3s ease;box-shadow:0 0 8px var(--gold-glow)}.upload-progress-text{display:flex;justify-content:space-between;align-items:center;font-size:.75rem}.upload-progress-text span:first-child{font-weight:600;color:var(--accent-primary)}.container{width:100%;max-width:600px;margin:0 auto;padding:0 var(--space-md)}@media (min-width: 768px){.container{max-width:720px}}@media (min-width: 1024px){.container{max-width:900px}}.page{flex:1;padding:var(--space-md) 0;padding-top:calc(var(--header-height) + var(--active-users-height) + var(--safe-top) + var(--space-md));padding-bottom:calc(var(--nav-height) + var(--safe-bottom) + var(--space-xl));min-height:100dvh}.page-header{margin-bottom:var(--space-lg)}.page-title{margin-bottom:var(--space-xs)}.page-subtitle{color:var(--text-secondary);font-size:.9rem}.app-header{position:fixed;top:0;left:0;right:0;z-index:100;min-height:calc(var(--header-height) + var(--safe-top));background:var(--bg-secondary);border-bottom:2px solid var(--gold);padding-top:var(--safe-top);display:flex;flex-direction:column;align-items:center;box-shadow:0 2px 12px #0000004d}.app-header:before{content:"";position:fixed;top:0;left:0;right:0;height:var(--safe-top);background:var(--bg-primary);z-index:101}.app-header-content{width:100%;max-width:900px;display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);padding:var(--space-sm) var(--space-md)}.app-header-left,.app-header-right{display:flex;align-items:center;gap:var(--space-sm)}.version-sync-info{display:flex;flex-direction:column;align-items:flex-start;gap:.1rem}.app-version,.last-sync{font-size:.55rem;color:var(--text-muted);opacity:.8;white-space:nowrap}.active-users-indicator{display:flex;align-items:center;gap:.35rem;padding:.2rem .5rem;background:#22c55e26;border:1px solid rgba(34,197,94,.4);border-radius:.75rem;font-size:.6rem;color:#22c55e;cursor:help;margin-left:var(--space-xs);animation:pulse-glow 2s ease-in-out infinite}.active-users-dot{width:6px;height:6px;background:#22c55e;border-radius:50%;animation:pulse-dot 1.5s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.9)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 3px #22c55e4d}50%{box-shadow:0 0 6px #22c55e80}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.active-users-text{white-space:nowrap;max-width:180px;overflow:hidden;text-overflow:ellipsis}@media (max-width: 600px){.active-users-indicator{max-width:120px;font-size:.55rem;padding:.15rem .4rem}.active-users-text{max-width:90px}}.storage-indicator{display:flex;align-items:center;gap:.25rem;padding:.2rem .5rem;background:#3b82f61a;border:1px solid rgba(59,130,246,.3);border-radius:.75rem;font-size:.6rem;color:#60a5fa;cursor:help}.storage-indicator.warning{background:#fbbf2426;border-color:#fbbf2466;color:#fbbf24}.storage-indicator.critical{background:#ef444426;border-color:#ef444466;color:#ef4444;animation:pulse-glow-red 2s ease-in-out infinite}@keyframes pulse-glow-red{0%,to{box-shadow:0 0 3px #ef44444d}50%{box-shadow:0 0 6px #ef444480}}.storage-icon{font-size:.65rem}.storage-text{white-space:nowrap;font-weight:500}@media (max-width: 600px){.storage-indicator{padding:.15rem .35rem;font-size:.55rem}.storage-icon{font-size:.55rem}}.company-branding{display:flex;align-items:center;gap:var(--space-xs)}.company-logo{width:28px;height:28px;object-fit:contain;border-radius:var(--radius-sm)}.company-name{font-size:.75rem;font-weight:600;color:var(--text-primary);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 480px){.company-name{display:none}.company-logo{width:24px;height:24px}}.header-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:.25rem .5rem;font-size:.7rem;cursor:pointer;display:flex;align-items:center;gap:.25rem;color:var(--text-secondary);transition:all var(--transition-fast)}.header-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.header-btn:disabled{opacity:.5;cursor:not-allowed}.user-btn{max-width:100px}.user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-indicator{display:flex;align-items:center;gap:.25rem;font-size:.6rem;color:var(--text-muted)}.status-text{display:none}@media (min-width: 400px){.status-text{display:inline}}.notification-banners{position:fixed;top:calc(var(--header-height) + var(--active-users-height) + var(--safe-top));left:0;right:0;z-index:150;display:flex;flex-direction:column}.recovery-banner{position:relative;background:var(--bg-secondary);border-bottom:2px solid var(--warning);padding:var(--space-sm) var(--space-md);animation:slideDown .3s ease;box-shadow:0 4px 12px #00000080}@keyframes progressShine{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.recovery-content{max-width:900px;margin:0 auto;display:flex;align-items:center;gap:var(--space-sm)}.recovery-icon{font-size:1.25rem;flex-shrink:0}.recovery-text{flex:1;display:flex;flex-direction:column;gap:.125rem}.recovery-text strong{font-size:.85rem;color:var(--warning)}.recovery-text span{font-size:.7rem;color:var(--text-secondary)}.recovery-dismiss{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem .5rem;font-size:1rem;opacity:.7;transition:opacity var(--transition-fast)}.recovery-dismiss:hover{opacity:1}.recovery-retry{background:var(--warning);color:#1a1a1a;border:none;border-radius:var(--radius-sm);padding:.35rem .75rem;font-size:.75rem;font-weight:600;cursor:pointer;transition:opacity var(--transition-fast)}.recovery-retry:hover{opacity:.9}.recovery-progress{height:4px;background:#ffffff1a;border-radius:2px;margin-top:var(--space-sm);overflow:hidden}.recovery-progress-bar{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--gold));border-radius:2px;transition:width .3s ease;box-shadow:0 0 8px var(--gold-glow)}.nav-bottom{position:fixed;bottom:0;left:0;right:0;height:calc(var(--nav-height) + var(--safe-bottom) + 12px);background:var(--bg-secondary);border-top:2px solid var(--gold-dark);padding:var(--space-sm) var(--space-md);padding-bottom:calc(var(--space-md) + var(--safe-bottom) + 12px);display:flex;justify-content:space-around;align-items:flex-start;z-index:100;box-shadow:0 -4px 16px #0006}.nav-bottom:after{content:"";position:fixed;bottom:0;left:0;right:0;height:var(--safe-bottom);background:var(--bg-primary);z-index:101}.nav-item{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:var(--space-sm) var(--space-xs);min-height:var(--touch-target-min);color:var(--text-muted);text-decoration:none;font-size:.7rem;font-weight:600;transition:all var(--transition-fast);border-radius:var(--radius-md);min-width:0;flex:1;max-width:80px}.nav-item span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.nav-item svg{width:24px;height:24px;flex-shrink:0}.nav-item.active{color:var(--gold);background:var(--gold-glow)}.nav-item:hover:not(.active){color:var(--text-primary);background:var(--bg-hover)}@media (min-width: 500px){.nav-item{padding:var(--space-sm);font-size:.75rem;max-width:90px}.nav-item svg{width:26px;height:26px}}.photo-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-sm);margin-bottom:var(--space-md)}@media (min-width: 480px){.photo-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 768px){.photo-grid{grid-template-columns:repeat(4,1fr);gap:var(--space-md)}}.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);transform:translateY(-2px)}.photo-card:active{transform:translateY(0)}.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,.75) 0%,transparent 60%);display:flex;flex-direction:column;justify-content:flex-end;padding:var(--space-sm)}.photo-card-title{font-size:.75rem;font-weight:600;color:#fff;line-height:1.2}.photo-card-multi-header .photo-card-title{color:var(--text-primary);font-size:.85rem}.photo-card-status{position:absolute;top:var(--space-xs);right:var(--space-xs)}.camera-container{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;z-index:9999;display:flex;flex-direction:column}.camera-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.camera-info{position:absolute;top:0;left:0;right:0;padding:var(--space-md);padding-top:calc(var(--space-md) + var(--safe-top));background:linear-gradient(to bottom,rgba(0,0,0,.85) 0%,rgba(0,0,0,.5) 70%,transparent 100%);color:#fff;z-index:10}.camera-info h3{font-size:1rem;margin-bottom:.25rem}.camera-info p{font-size:.8rem;opacity:.8}.camera-controls{position:absolute;bottom:0;left:0;right:0;padding:var(--space-lg);padding-bottom:calc(var(--space-xl) + var(--safe-bottom));display:flex;justify-content:center;align-items:center;gap:var(--space-xl);background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.6) 60%,transparent 100%);z-index:10}.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);position:relative;flex-shrink:0}.capture-btn:hover{transform:scale(1.05)}.capture-btn:active,.capture-btn.capturing{transform:scale(.92)}.capture-btn.focusing{animation:focus-pulse-btn .5s ease-in-out infinite}.capture-btn .focus-ring{position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:50%;border:3px solid #4ade80;animation:focus-ring-pulse .6s ease-in-out infinite}@keyframes focus-pulse-btn{0%,to{transform:scale(1)}50%{transform:scale(.95)}}@keyframes focus-ring-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.5}}.camera-example-btn{position:absolute;top:calc(5rem + var(--safe-top));right:calc(var(--space-md) + var(--safe-right));z-index:10}.camera-example-btn .btn{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0009;border:1px solid rgba(255,255,255,.1);padding:var(--space-sm) var(--space-md);font-size:.75rem;white-space:nowrap}.camera-example-btn .btn.btn-primary{background:var(--gold);color:#1a1a1a;border:none;font-weight:700}.camera-right-btns{display:flex;gap:var(--space-sm)}.camera-right-btns .btn-icon{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.camera-right-btns .btn.btn-warning{background:var(--warning);color:var(--bg-primary);border:none}.camera-counter{position:absolute;top:calc(5rem + var(--safe-top));left:50%;transform:translate(-50%);background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-full);font-size:1.1rem;font-weight:600;color:var(--warning);z-index:10}.camera-counter .complete{color:var(--success)}.camera-zoom-indicator{position:absolute;top:calc(5rem + var(--safe-top));right:calc(5rem + var(--safe-right));background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full);font-size:.85rem;font-weight:600;color:var(--accent-primary);z-index:10}.camera-zoom-slider{position:absolute;bottom:calc(7rem + var(--safe-bottom));left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-sm);background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-full);z-index:10}.camera-zoom-slider .zoom-label{font-size:.7rem;color:#ffffffb3;min-width:1.5rem;text-align:center}.camera-zoom-slider .zoom-range{width:100px;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ffffff4d;border-radius:2px;outline:none}.camera-zoom-slider .zoom-range::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;background:var(--accent-primary);border-radius:50%;cursor:pointer}.camera-zoom-slider .zoom-range::-moz-range-thumb{width:16px;height:16px;background:var(--accent-primary);border-radius:50%;cursor:pointer;border:none}.camera-hint{position:absolute;bottom:calc(6.5rem + var(--safe-bottom));left:var(--space-md);right:var(--space-md);text-align:center;font-size:.75rem;color:#fff9;z-index:10}.focus-indicator{position:absolute;width:70px;height:70px;border:2px solid var(--accent-primary);border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;animation:focus-pulse .8s ease-out forwards;z-index:20}@keyframes focus-pulse{0%{opacity:1;transform:translate(-50%,-50%) scale(1.2)}50%{opacity:1;transform:translate(-50%,-50%) scale(.9)}to{opacity:0;transform:translate(-50%,-50%) scale(.8)}}.capture-notification{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:30;animation:capture-flash 1.2s ease-out forwards}.capture-notification-content{display:flex;align-items:center;gap:var(--space-sm);background:var(--accent-primary);color:#fff;padding:var(--space-md) var(--space-lg);border-radius:var(--radius-full);font-weight:600;font-size:1rem;box-shadow:0 8px 32px #001f3f66}.capture-notification-content svg{width:24px;height:24px}@keyframes capture-flash{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}15%{opacity:1;transform:translate(-50%,-50%) scale(1.05)}30%{transform:translate(-50%,-50%) scale(1)}80%{opacity:1}to{opacity:0}}.example-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:5;transition:opacity .15s ease}.example-overlay img{width:100%;height:100%;object-fit:contain}.example-opacity-slider{position:absolute;right:var(--space-md);top:50%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);z-index:50;background:#0009;padding:var(--space-sm) var(--space-xs);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.opacity-slider-vertical{writing-mode:vertical-lr;direction:rtl;width:8px;height:120px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;cursor:pointer}.opacity-slider-vertical::-webkit-slider-runnable-track{width:8px;height:120px;background:linear-gradient(to top,#fff3,#fffc);border-radius:4px}.opacity-slider-vertical::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;background:var(--accent-primary);border-radius:50%;cursor:pointer;border:2px solid white;box-shadow:0 2px 6px #0000004d;margin-left:-6px}.opacity-slider-vertical::-moz-range-track{width:8px;height:120px;background:linear-gradient(to top,#fff3,#fffc);border-radius:4px}.opacity-slider-vertical::-moz-range-thumb{width:20px;height:20px;background:var(--accent-primary);border-radius:50%;cursor:pointer;border:2px solid white;box-shadow:0 2px 6px #0000004d}.opacity-label{font-size:.65rem;color:#fff;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.5)}.landscape-badge{position:absolute;bottom:calc(7rem + var(--safe-bottom));right:var(--space-md);display:flex;align-items:center;gap:var(--space-xs);background:var(--accent-primary);color:var(--bg-primary);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full);font-size:.7rem;font-weight:600;z-index:10}@media (orientation: landscape) and (max-height: 500px){.camera-controls{position:absolute;bottom:auto;right:0;top:50%;left:auto;transform:translateY(-50%);flex-direction:column;padding:var(--space-md);padding-right:calc(var(--space-lg) + var(--safe-right));background:linear-gradient(to left,rgba(0,0,0,.9) 0%,transparent 100%);gap:var(--space-md)}.camera-info{top:auto;bottom:0;left:0;right:auto;max-width:280px;padding:var(--space-md);padding-left:calc(var(--space-md) + var(--safe-left));padding-bottom:calc(var(--space-md) + var(--safe-bottom));background:linear-gradient(to right,rgba(0,0,0,.9) 0%,transparent 100%)}.camera-counter,.camera-example-btn{top:calc(var(--space-md) + var(--safe-top))}.camera-right-btns{flex-direction:column}.camera-zoom-slider{bottom:auto;left:auto;right:calc(5rem + var(--safe-right));top:50%;transform:translateY(-50%);flex-direction:column;padding:var(--space-md) var(--space-sm)}.camera-zoom-slider .zoom-range{width:4px;height:80px;writing-mode:vertical-lr;direction:rtl}.camera-zoom-indicator{right:auto;left:calc(var(--space-md) + var(--safe-left))}.camera-hint{bottom:auto;top:calc(var(--space-md) + var(--safe-top));left:50%;right:auto;transform:translate(-50%);width:auto;white-space:nowrap}.capture-btn{width:60px;height:60px}.landscape-badge{bottom:auto;top:var(--space-md);right:50%;transform:translate(50%)}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-md)}.modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:min(400px,calc(100vw - 2rem));max-height:90vh;overflow-y:auto}.modal-header{padding:var(--space-md);border-bottom:1px solid var(--border-color)}.modal-body{padding:var(--space-md)}.modal-footer{padding:var(--space-md);border-top:1px solid var(--border-color);display:flex;gap:var(--space-sm);justify-content:flex-end;flex-wrap:wrap}.photo-preview-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e6;z-index:1000;display:flex;flex-direction:column;padding:var(--safe-top) 0 var(--safe-bottom) 0}.photo-preview-modal{display:flex;flex-direction:column;height:100%;width:100%;max-width:600px;margin:0 auto;justify-content:center}.photo-preview-content{max-height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch;background:var(--bg-primary);border-radius:var(--radius-lg)}.photo-preview-zoom-container{position:relative;width:100%;background:#000;display:flex;align-items:center;justify-content:center;max-height:60vh}.photo-preview-image{width:100%;height:auto;max-height:60vh;object-fit:contain;background:#000;display:block;transform-origin:center center;user-select:none;-webkit-user-select:none}.photo-preview-info{padding:var(--space-md);background:var(--bg-card)}.photo-preview-info h3{margin-bottom:var(--space-xs)}.photo-preview-buttons{display:flex;gap:var(--space-sm);justify-content:center;flex-wrap:wrap;margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border-color)}.photo-preview-buttons .btn{flex:1;min-width:70px;max-width:100px;padding:.6rem .5rem;font-size:.75rem}.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:var(--space-xl) var(--space-md);color:var(--text-secondary)}.empty-state svg{width:56px;height:56px;margin-bottom:var(--space-md);opacity:.4}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}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}.justify-center{justify-content:center}.gap-1{gap:var(--space-xs)}.gap-2{gap:var(--space-sm)}.gap-3{gap:var(--space-md)}.gap-4{gap:var(--space-lg)}.mt-2{margin-top:var(--space-sm)}.mt-4{margin-top:var(--space-md)}.mb-2{margin-bottom:var(--space-sm)}.mb-4{margin-bottom:var(--space-md)}.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%}.font-medium{font-weight:500}.pb-nav{padding-bottom:calc(var(--nav-height) + var(--safe-bottom) + var(--space-md))}.pb-nav-extra{padding-bottom:calc(var(--nav-height) + var(--safe-bottom) + var(--space-xl))}.mobile-browser-block{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:var(--space-lg);background:linear-gradient(135deg,#001f3f,#036,#00254d)}.mobile-browser-block-content{width:100%;max-width:380px;text-align:center;color:#fff}.mobile-browser-block-icon{font-size:4rem;margin-bottom:var(--space-md)}.mobile-browser-block h1{font-size:1.75rem;margin-bottom:var(--space-sm);color:#fff}.mobile-browser-block>.mobile-browser-block-content>p{color:#fffc;margin-bottom:var(--space-lg)}.install-instructions{background:#ffffff1a;border-radius:var(--radius-lg);padding:var(--space-md);text-align:left;margin-bottom:var(--space-lg)}.install-instructions h3{font-size:1rem;margin-bottom:var(--space-sm);color:#4ade80}.install-instructions ol{margin:0;padding-left:1.25rem;color:#ffffffe6}.install-instructions li{margin-bottom:var(--space-xs);line-height:1.5}.mobile-browser-block-note{font-size:.85rem;color:#fbbf24;background:#fbbf2426;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:1px solid rgba(251,191,36,.3)}.login-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:var(--space-lg);background:var(--bg-primary)}.login-container{width:100%;max-width:340px}.login-header{text-align:center;margin-bottom:var(--space-xl)}.login-icon{display:inline-flex;align-items:center;justify-content:center;width:88px;height:88px;background:linear-gradient(135deg,var(--gold) 0%,var(--gold-dark) 100%);border-radius:var(--radius-full);margin-bottom:var(--space-md);color:#1a1a1a;box-shadow:0 4px 20px #cfb53b80}.login-header h1{font-size:1.6rem;font-weight:700;color:var(--gold);margin-bottom:var(--space-sm)}.login-header p{color:var(--text-secondary);font-size:.85rem}.login-form{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg)}.login-error{background:#ff6b7a26;border:1px solid var(--error);color:var(--error);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:.85rem;margin-bottom:var(--space-md);text-align:center}.login-footer{text-align:center;margin-top:var(--space-lg);font-size:.75rem;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)}@media (min-width: 480px){.photo-card-multi{grid-column:span 3}}@media (min-width: 768px){.photo-card-multi{grid-column:span 4}}.photo-card-multi.captured,.photo-card-multi.complete{border-style:solid;border-color:var(--success)}.photo-card-multi.required:not(.captured):not(.complete){border-color:var(--warning);border-style:solid}.photo-card-multi.needs-more{border-color:var(--warning)!important;border-style:solid}.photo-card-multi-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);cursor:pointer;background:var(--bg-card);border-bottom:1px solid var(--border-subtle);gap:var(--space-sm)}.photo-card-multi-header:hover{background:var(--bg-hover)}.photo-card-multi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(64px,1fr));gap:var(--space-sm);padding:var(--space-sm)}.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:18px;height:18px;border-radius:50%;background:var(--error);color:#fff;border:none;font-size:12px;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:2px;color:var(--text-muted);background:transparent;font-size:.65rem}.photo-card-multi-thumb.add-more:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.photo-card-multi-empty{padding:var(--space-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted)}.photo-card-multi-empty:hover{background:var(--bg-hover);color:var(--text-secondary)}.photo-card-multi-preview{display:flex;gap:var(--space-xs);padding:var(--space-sm);overflow-x:auto;cursor:pointer}.photo-card-multi-preview:hover{background:var(--bg-hover)}.mini-thumb{width:44px;height:44px;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:.65rem;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)}.skip-toggle-btn{position:absolute;top:var(--space-xs);left:var(--space-xs);width:26px;height:26px;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}.photo-card.skipped,.photo-card-multi.skipped{border-style:solid;border-color:var(--text-muted);opacity:.5}.photo-card.skipped:hover,.photo-card-multi.skipped:hover{opacity:.7}.job-card-completed{opacity:.6;background:var(--bg-secondary)}.job-card-completed:hover{opacity:.8}.log-list{display:flex;flex-direction:column;gap:var(--space-md)}.admin-user-list{display:flex;flex-direction:column;gap:var(--space-lg)}.admin-user-card{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-lg);padding:0;overflow:hidden}.admin-user-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%);border-bottom:2px solid var(--border-color)}.admin-user-name-row{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.admin-user-icon{font-size:1.5rem}.admin-username{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:.5px}.admin-badge{font-size:.7rem;font-weight:600;padding:.25rem .6rem;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.5px}.admin-badge-super{background:linear-gradient(135deg,#cfb53b40,#b8860b40);color:var(--gold);border:1px solid var(--gold)}.admin-badge-admin{background:linear-gradient(135deg,#cfb53b26,#b8860b26);color:var(--gold);border:1px solid var(--gold-dark)}.admin-user-field{padding:var(--space-md);border-bottom:1px solid var(--border-color)}.admin-field-label{display:block;font-size:.75rem;font-weight:600;color:var(--text-muted);margin-bottom:var(--space-xs);text-transform:uppercase;letter-spacing:.5px}.admin-permissions{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-sm);padding:var(--space-md);background:var(--bg-primary)}.admin-permission-item{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);transition:background-color var(--transition-fast);font-size:.9rem}.admin-permission-item:hover{background:var(--bg-tertiary)}.admin-permission-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent-primary)}.admin-permission-item input[type=checkbox]:disabled{opacity:.5}.btn-sm{padding:.35rem .75rem;font-size:.75rem}.btn-danger{background:transparent;color:var(--error);border:1px solid var(--error)}.btn-danger:hover{background:#ff575726}.log-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;transition:border-color .2s}.log-card.log-card-expanded{border-color:var(--accent-primary)}.log-card-row{display:flex;align-items:center;padding:var(--space-sm) var(--space-md);cursor:pointer;gap:var(--space-md);min-height:48px}.log-card-row:hover{background:var(--bg-tertiary)}.log-card-row-main{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0;min-width:120px}.log-template-name{font-weight:600;font-size:.9rem;color:var(--text-primary)}.log-store-number{font-size:.75rem;color:var(--accent-primary);font-weight:500}.log-card-row-meta{display:flex;align-items:center;gap:var(--space-sm);flex:1;flex-wrap:wrap;font-size:.75rem;color:var(--text-muted)}.log-date{color:var(--text-secondary)}.log-time{opacity:.7}.log-submitter{color:var(--accent-secondary);font-weight:500}.log-photo-count{background:var(--bg-tertiary);padding:.15rem .4rem;border-radius:var(--radius-sm);font-size:.7rem;white-space:nowrap}.expand-icon{font-size:.6rem;color:var(--text-muted);flex-shrink:0;transition:transform .2s}.log-card.log-card-expanded .expand-icon{color:var(--accent-primary)}.log-card-details{border-top:1px solid var(--border-color);animation:slideDown .2s ease-out}.log-card-header{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--space-md);cursor:pointer;gap:var(--space-sm)}.log-card-header:hover{background:var(--bg-tertiary)}.log-card-title h3{font-size:.95rem;margin:0;line-height:1.3}.log-store{font-size:.7rem;color:var(--text-muted)}.log-card-meta{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.log-card-summary{padding:0 var(--space-md) var(--space-sm);border-bottom:1px solid var(--border-color)}.log-stat{display:flex;justify-content:space-between;align-items:center;padding:var(--space-xs) 0;font-size:.8rem;gap:var(--space-sm)}.log-stat-label{color:var(--text-muted)}.log-section{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border-color)}.log-section:last-child{border-bottom:none}.log-section-title{font-size:.7rem;color:var(--text-muted);margin:0 0 var(--space-sm) 0;text-transform:uppercase;letter-spacing:.5px}.log-badges{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.log-badge{display:inline-block;padding:.2rem .4rem;border-radius:var(--radius-sm);font-size:.6rem;font-weight:500}.log-badge-success{background:var(--success);color:var(--bg-primary)}.log-badge-muted{background:var(--bg-tertiary);color:var(--text-muted)}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.log-photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:var(--space-sm)}.log-photo-thumb{aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;background:var(--bg-tertiary);transition:transform .15s ease}.log-photo-thumb:hover{transform:scale(1.05)}.log-photo-thumb img{width:100%;height:100%;object-fit:cover}.log-photo-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);background:var(--bg-tertiary);gap:.25rem}.log-photo-label{position:absolute;bottom:0;left:0;right:0;padding:2px 4px;background:#000000b3;color:#fff;font-size:.55rem;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.log-photo-thumb{position:relative}.log-photo-img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-md)}.thumbnail-spinner{width:20px;height:20px;border:2px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}.log-card-selected{border-color:var(--gold)!important;background:#cfb53b14}.log-card-checkbox{padding:0 var(--space-sm);display:flex;align-items:center}.photo-viewer-modal{display:flex;flex-direction:column}.photo-viewer-container{position:relative;display:flex;align-items:center;justify-content:center;touch-action:none}.photo-viewer-controls{position:absolute;bottom:var(--space-md);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-xs);background:#000000b3;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.photo-viewer-controls button{width:32px;height:32px;border:none;background:#ffffff1a;color:#fff;border-radius:50%;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:background-color .15s}.photo-viewer-controls button:hover{background:#ffffff40}.photo-viewer-controls button.active{background:var(--accent-primary);color:var(--bg-primary)}.photo-viewer-controls .zoom-level{font-size:.75rem;color:#fffc;min-width:40px;text-align:center}.markup-container{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-primary);z-index:1000;display:flex;flex-direction:column}.markup-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);padding-top:calc(var(--space-sm) + var(--safe-top));background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-wrap:wrap}.markup-tools{display:flex;gap:var(--space-xs)}.markup-tool{width:40px;height:40px;border-radius:var(--radius-md);border:2px solid transparent;background:var(--bg-tertiary);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.markup-tool:hover{background:var(--bg-hover)}.markup-tool.active{border-color:var(--gold);background:#cfb53b26;color:var(--gold-dark)}.markup-colors{display:flex;gap:var(--space-xs)}.color-btn{width:26px;height:26px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform var(--transition-fast)}.color-btn:hover{transform:scale(1.1)}.color-btn.active{border-color:#fff;box-shadow:0 0 0 2px var(--bg-primary)}.markup-size-controls{display:flex;align-items:center;gap:var(--space-xs);margin-left:var(--space-sm);padding-left:var(--space-sm);border-left:1px solid var(--border-color)}.size-label{font-size:.7rem;color:var(--text-muted)}.size-btn{width:28px;height:28px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all var(--transition-fast)}.size-btn:hover{background:var(--bg-hover)}.size-btn.active{border-color:var(--accent-primary);background:var(--accent-glow);color:var(--accent-primary)}.markup-actions{display:flex;gap:var(--space-xs)}.markup-canvas-container{flex:1;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#f5f5f5;touch-action:none;position:relative}.markup-canvas-container canvas{touch-action:none;cursor:crosshair}.markup-zoom-controls{position:absolute;top:var(--space-md);right:var(--space-sm);display:flex;flex-direction:column;gap:var(--space-xs);background:#fffffff2;border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-xs);z-index:10;box-shadow:var(--shadow-md)}.markup-zoom-controls button{width:32px;height:32px;border:none;background:var(--bg-secondary);color:var(--text-primary);font-size:1.1rem;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center}.markup-zoom-controls button:hover{background:var(--bg-tertiary)}.markup-zoom-controls span{font-size:.65rem;color:var(--text-muted);text-align:center;padding:var(--space-xs) 0}.markup-selection-actions-toolbar{display:flex;gap:var(--space-sm);margin-left:auto;align-items:center}.markup-selection-actions-toolbar .btn{padding:var(--space-xs) var(--space-sm);font-size:.75rem;white-space:nowrap}.markup-selection-actions-toolbar .btn-sm{height:32px}.quick-units{display:flex;gap:var(--space-sm);margin-bottom:var(--space-md)}.quick-units button{flex:1;padding:var(--space-sm);border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;font-size:.85rem}.quick-units button:hover{background:var(--bg-hover);color:var(--text-primary)}.markup-input-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1001;padding:var(--space-md)}.markup-input-content{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-lg);width:100%;max-width:400px;box-sizing:border-box}.markup-input-content h4{margin-bottom:var(--space-md)}.markup-input-content input{width:100%;padding:var(--space-sm);border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-primary);font-size:1rem;margin-bottom:var(--space-md)}.markup-input-content input:focus{outline:none;border-color:var(--accent-primary)}.markup-input-actions{display:flex;gap:var(--space-sm);justify-content:flex-end;flex-wrap:wrap;margin-top:var(--space-sm)}.markup-input-actions .btn{flex:0 1 auto;min-width:80px;white-space:nowrap;padding:var(--space-sm) var(--space-md);font-size:.9rem}.markup-bottom-actions{display:flex;gap:var(--space-md);padding:var(--space-md);padding-bottom:calc(var(--space-md) + var(--safe-bottom));background:var(--bg-secondary);border-top:1px solid var(--border-color)}.markup-bottom-actions .btn{flex:1}.completed-section{background:#22c55e0d;border:1px solid rgba(34,197,94,.2);border-radius:var(--radius-md);padding:var(--space-md)}.completed-section summary{display:flex;align-items:center;gap:var(--space-sm);font-weight:500;-webkit-user-select:none;user-select:none}.completed-section summary::-webkit-details-marker{display:none}.completed-section summary:before{content:"▶";font-size:.7rem;transition:transform .2s}.completed-section[open] summary:before{transform:rotate(90deg)}.completed-section .photo-grid{opacity:.8}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-hover) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite}@keyframes progress-stripes{0%{background-position:1rem 0}to{background-position:0 0}}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.bg-primary{background-color:var(--bg-primary)}.bg-secondary{background-color:var(--bg-secondary)}.bg-surface{background-color:var(--bg-card)}.bg-primary-light{background-color:#001f3f14;border-color:var(--accent-primary)!important}.border-primary{border-color:var(--accent-primary)}.border-border{border-color:var(--border-color)}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:8px;border-radius:4px;background:var(--bg-tertiary);outline:none;transition:background .3s}input[type=range]:hover{background:var(--bg-hover)}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;background:var(--gold);cursor:pointer;box-shadow:0 2px 8px #cfb53b66;transition:all .2s ease}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 4px 12px #cfb53b99}input[type=range]::-webkit-slider-thumb:active{transform:scale(.95)}input[type=range]::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:var(--gold);cursor:pointer;border:none;box-shadow:0 2px 8px #cfb53b66;transition:all .2s ease}input[type=range]::-moz-range-thumb:hover{transform:scale(1.1);box-shadow:0 4px 12px #cfb53b99}input[type=range]::-moz-range-thumb:active{transform:scale(.95)}input[type=checkbox]{accent-color:var(--accent-primary);cursor:pointer}input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed}
