:root{--bg:#f5f7fa;--ink:#1a2530;--muted:#6b7785;--panel:#ffffff;--line:#e2e8f0;--accent:#2563eb;--accent-hover:#1d4ed8;--accent-light:#dbeafe;--success:#059669;--success-light:#d1fae5;--warning:#d97706;--warning-light:#fef3c7;--danger:#dc2626;--danger-light:#fee2e2;--shadow:0 1px 4px rgba(0,0,0,0.08);--shadow-lg:0 4px 20px rgba(0,0,0,0.10);--radius:14px}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:Noto Sans TC,PingFang TC,Microsoft JhengHei,sans-serif;color:var(--ink);background:var(--bg);line-height:1.6}.container{max-width:1100px;margin:0 auto;padding:32px 20px 48px}.hero{text-align:center;margin-bottom:24px}.hero h1{margin:0 0 8px;font-size:clamp(1.7rem,3vw,2.4rem);color:var(--ink);letter-spacing:-.5px}.hero p{margin:0;color:var(--muted);font-size:.95rem}.notice{margin:0 0 20px;padding:12px 16px;border-radius:var(--radius);border:1px solid #bfdbfe;background:var(--accent-light);color:#1e40af;font-size:.88rem;line-height:1.65}.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.panel h2{margin:0 0 12px;font-size:1em;font-weight:700;color:var(--ink);padding-bottom:8px;border-bottom:1px solid var(--line)}.panel h3{margin:0 0 8px;font-size:.9em;font-weight:700;color:var(--muted)}.homeGrid{margin-bottom:16px}.homeGrid,.resultGrid{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px}.resultGrid{margin-top:16px}@media (max-width:700px){.homeGrid,.resultGrid{grid-template-columns:1fr}}.mainImage{width:100%;aspect-ratio:4/3;object-fit:contain;border-radius:10px;border:1px solid var(--line);background:#f8fafc;margin-top:10px}.previewLabel{display:block}.emptyPreview,.previewLabel{cursor:pointer;margin-top:10px}.emptyPreview{display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--muted);font-weight:600;text-align:center;background:#f8fafc;border:1.5px dashed var(--line);border-radius:10px;min-height:160px;transition:border-color .2s,background .2s}.emptyPreview:hover{border-color:var(--accent);background:var(--accent-light)}.emptyPreview:focus-within{outline:2px solid var(--accent);outline-offset:2px;border-radius:10px}.emptyIcon{position:relative;width:40px;height:34px;margin-bottom:10px;animation:iconFloat 2.2s ease-in-out infinite}.iconBox{position:absolute;left:4px;right:4px;bottom:2px;height:14px;border:2px solid var(--accent);border-radius:4px;background:rgba(37,99,235,.1)}.iconArrow{position:absolute;left:50%;bottom:10px;width:2px;height:16px;background:var(--accent);transform:translateX(-50%)}.iconArrow:before{content:"";position:absolute;left:50%;top:-6px;width:8px;height:8px;border-left:2px solid var(--accent);border-top:2px solid var(--accent);transform:translateX(-50%) rotate(45deg)}.emptyMain{font-size:1.05rem;font-weight:700;color:var(--ink)}.emptyOr{margin-top:4px;color:#94a3b8;font-size:.85rem}.emptySub{margin-top:4px;font-size:1.2rem;font-weight:700;color:var(--accent)}@keyframes iconFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.dropZone{margin-top:10px;border:1.5px dashed var(--line);border-radius:12px;padding:12px;background:#f8fafc;transition:border-color .2s,box-shadow .2s,background .2s}.dropZone:hover{box-shadow:0 0 0 4px rgba(37,99,235,.08)}.dropZone.dragging,.dropZone:hover{border-color:var(--accent);background:var(--accent-light)}.dropZone.dragging{box-shadow:0 0 0 4px rgba(37,99,235,.16)}.hiddenFileInput{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.controls{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px;align-items:center}button{border:none;border-radius:10px;padding:10px 18px;cursor:pointer;font-weight:600;font-size:.9rem;font-family:inherit;background:#e8edf4;color:var(--ink);transition:background .15s,transform .1s,box-shadow .15s}button:hover{background:#dce2ec}button:active{transform:scale(.97)}button.primary{background:var(--accent);color:#fff;box-shadow:0 2px 8px rgba(37,99,235,.25)}button.primary:hover{background:var(--accent-hover)}button.primary:active{box-shadow:none}button:disabled{opacity:.5;cursor:not-allowed;transform:none}button.danger{background:var(--danger)}button.danger:disabled{background:#aaa}button.secondary{background:#e8edf4;color:var(--ink)}button.secondary:hover{background:#dce2ec}.feedback-controls{display:flex;align-items:center;gap:12px;margin-top:14px}.feedback-done{color:var(--success);font-weight:700;font-size:.9rem;padding:10px 14px;background:var(--success-light);border-radius:10px}.hint{font-size:.88rem}.formatHint,.hint{margin:8px 0 0;color:var(--muted)}.formatHint{font-size:.8rem;text-align:center}.status{margin-top:10px;color:var(--muted);font-size:.88rem}.report{white-space:pre-wrap;line-height:1.75;font-size:.95rem}.siteFooter{margin-top:28px;padding-top:16px;border-top:1px solid var(--line);color:var(--muted);font-size:.85rem;line-height:1.6;text-align:center}.siteFooter p{margin:0}.mode-tabs{display:flex;gap:6px;margin-bottom:18px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:6px;box-shadow:var(--shadow)}.mode-tab{flex:1 1;border:none;border-radius:8px;padding:10px 16px;cursor:pointer;font-weight:600;font-size:.88rem;font-family:inherit;background:transparent;color:var(--muted);transition:background .15s,color .15s,box-shadow .15s}.mode-tab:hover{color:var(--ink);background:var(--bg)}.mode-tab.active{background:var(--accent);color:#fff;box-shadow:0 2px 8px rgba(37,99,235,.3)}.puppy-notice{background:var(--warning-light);border:1px solid #fcd34d;border-radius:10px;padding:10px 14px;font-size:.88em;color:#92400e;margin-bottom:16px}.puppy-notice strong{color:#92400e}.step-capture{display:flex;flex-direction:column;gap:12px}.step-header{background:linear-gradient(135deg,#3b82f6,#6366f1);color:white;border-radius:14px;padding:14px 20px;text-align:center}.step-num{font-size:.85em;opacity:.8;margin-bottom:4px}.step-title{font-size:1.15em;font-weight:700}.step-body{display:grid;grid-template-columns:1fr 220px;grid-gap:14px;gap:14px;align-items:start}.step-viewfinder{position:relative;border-radius:14px;overflow:hidden;background:#111;border:2px solid #333;min-height:220px}.step-live{position:relative;width:100%;aspect-ratio:4/3}.live-video{width:100%;height:100%;object-fit:contain;display:block;background:#000}.btn-shoot{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);background:rgba(37,99,235,.9);color:#fff;border:2px solid rgba(255,255,255,.6);border-radius:28px;padding:9px 26px;font-size:.92em;font-weight:700;cursor:pointer;z-index:10;font-family:inherit}.btn-shoot:active{transform:translateX(-50%) scale(.97)}.btn-shoot:disabled{opacity:.5;cursor:not-allowed}.step-preview{position:relative;width:100%;aspect-ratio:4/3}.step-preview img{width:100%;height:100%;object-fit:contain;display:block;background:#000}.btn-retake{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);background:rgba(220,38,38,.85);color:#fff;border:none;border-radius:20px;padding:7px 18px;font-size:.85em;font-weight:600;cursor:pointer;z-index:10;font-family:inherit}.btn-retake:active{background:rgba(220,38,38,1)}.step-cam-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:#aaa;font-size:.88rem;text-align:center;gap:10px}.cam-feedback{padding:8px 14px;border-radius:8px;font-size:.88em;font-weight:600;text-align:center}.cam-feedback.ok{background:var(--success-light);border:1px solid var(--success);color:var(--success)}.cam-feedback.error{background:var(--danger-light);border:1px solid var(--danger);color:var(--danger)}.step-guide-card{background:var(--panel);border:2px solid var(--line);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow)}.step-guide-card h4{margin:0 0 10px;font-size:.95em;font-weight:700;color:var(--ink);text-align:center}.step-guide-card ul{text-align:left;color:#475569;line-height:1.95;padding-left:18px;font-size:.86em;margin:0 0 14px}.step-progress{display:flex;justify-content:center;gap:8px;margin-top:8px}.dot{width:10px;height:10px;border-radius:50%;background:#cbd5e1;transition:background .3s}.dot.active{background:var(--accent)}.step-btn-row{display:flex;gap:10px}@media (max-width:640px){.step-body{grid-template-columns:1fr}.step-guide-card{display:none}}.feedback-textarea{width:100%;resize:vertical;font-size:.9rem;font-family:inherit;padding:10px;border:1px solid var(--line);border-radius:8px;background:#f8fafc;color:var(--ink);box-sizing:border-box}.feedback-textarea:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}.login-required-card{background:var(--panel);border:2px solid var(--accent);border-radius:var(--radius);padding:48px 32px;text-align:center;box-shadow:var(--shadow-lg);max-width:420px;margin:24px auto}.login-required-icon{font-size:3.5rem;margin-bottom:16px}.login-required-card h2{margin:0 0 12px;font-size:1.4rem;color:var(--ink)}.login-required-card p{margin:0 0 24px;color:var(--muted);font-size:.95rem;line-height:1.6}.hero-title-row{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}.auth-login-btn{background:var(--accent);color:white;border:none;border-radius:8px;padding:8px 16px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s;font-family:inherit}.auth-login-btn:hover{background:var(--accent-hover)}.auth-info{display:flex;align-items:center;gap:10px}.auth-username{font-size:.9rem;color:var(--muted);font-weight:500}.auth-logout-btn{background:transparent;color:var(--muted);border:1px solid var(--line);border-radius:6px;padding:5px 12px;font-size:.85rem;cursor:pointer;transition:all .2s;font-family:inherit}.auth-logout-btn:hover{background:var(--danger-light);color:var(--danger);border-color:var(--danger)}.auth-tabs{display:flex;gap:0;margin-bottom:20px;border-bottom:2px solid var(--line)}.auth-tab{flex:1 1;padding:10px 16px;background:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;font-size:.95rem;font-weight:600;color:var(--muted);cursor:pointer;transition:all .2s;font-family:inherit}.auth-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.auth-tab:hover:not(.active){color:var(--ink)}.auth-fields{gap:14px;margin-bottom:16px}.auth-fields,.auth-label{display:flex;flex-direction:column}.auth-label{gap:5px;font-size:.9rem;font-weight:600;color:var(--ink)}.auth-input{padding:10px 12px;border:1px solid var(--line);border-radius:8px;font-size:.95rem;font-family:inherit;color:var(--ink);background:#f8fafc;transition:border-color .2s,box-shadow .2s}.auth-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.auth-error{background:var(--danger-light);color:var(--danger);border:1px solid var(--danger);border-radius:8px}.auth-error,.auth-success{padding:10px 14px;font-size:.88rem;margin-bottom:14px;text-align:center}.auth-success{background:var(--success-light);color:var(--success);border:1px solid var(--success);border-radius:8px}.login-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:32px;max-width:420px;margin:24px auto;box-shadow:var(--shadow-lg)}.login-btn-row{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}.consent-modal{border:1px solid var(--line);border-radius:var(--radius);max-width:700px;margin:0 auto 32px;box-shadow:var(--shadow-lg)}.consent-header{background:var(--accent);color:white;padding:20px 24px}.consent-header h2{margin:0 0 4px;font-weight:700}.consent-body{padding:20px 24px;max-height:55vh;border-bottom:1px solid var(--line)}.consent-text{font-size:.85rem}.consent-footer{padding:20px 24px}.consent-checkbox input[type=checkbox]{width:18px;height:18px;margin-top:2px}.consent-btn-row{display:flex;gap:10px;justify-content:flex-end}.admin-page{min-height:100vh}.admin-tabs{display:flex;gap:4px;margin-bottom:24px;border-bottom:2px solid var(--line);padding-bottom:0}.admin-tabs button{border-radius:8px 8px 0 0;padding:10px 20px;cursor:pointer;font-weight:600;font-size:.95rem;background:transparent;color:var(--muted);margin-bottom:-2px;border:none;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.admin-tabs button:hover{color:var(--ink)}.admin-tabs button.active{color:var(--accent);border-bottom:2px solid var(--accent)}.users-section{margin-bottom:28px}.users-section-title{font-size:1rem;font-weight:700;color:var(--ink);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--line)}.users-table{width:100%;border-collapse:collapse;font-size:.88rem;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}.users-table th{background:#f8fafc;text-align:left;font-weight:700;color:var(--muted)}.users-table td,.users-table th{padding:10px 14px;border-bottom:1px solid var(--line)}.users-table td{color:var(--ink)}.users-table tr:last-child td{border-bottom:none}.users-table tr:hover td{background:#f8fafc}.role-badge,.status-badge{display:inline-block;padding:2px 8px;border-radius:6px;font-size:.8rem;font-weight:600}.role-badge.admin{background:var(--accent-light);color:var(--accent)}.role-badge.user{background:#f1f5f9;color:var(--muted)}.status-badge.active{background:var(--success-light);color:var(--success)}.status-badge.inactive{background:var(--danger-light);color:var(--danger)}.action-btn{padding:4px 10px;border-radius:6px;border:none;cursor:pointer;font-size:.82rem;font-weight:600;font-family:inherit;margin-right:6px;transition:all .15s}.action-btn.success{background:var(--success-light);color:var(--success)}.action-btn.success:hover{background:var(--success);color:white}.action-btn.danger{background:var(--danger-light);color:var(--danger)}.action-btn.danger:hover{background:var(--danger);color:white}.action-btn.warning{background:var(--warning-light);color:var(--warning)}.action-btn.warning:hover{background:var(--warning);color:white}.admin-login{max-width:400px;margin:80px auto;text-align:center;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:40px 32px}.admin-login h1{margin:0 0 12px;font-size:1.5rem}.admin-login p{color:var(--muted);margin:0 0 24px}.login-form{display:flex;flex-direction:column;gap:12px}.login-form input{padding:12px 16px;border:1px solid var(--line);border-radius:10px;font-size:1rem;font-family:inherit}.login-form button{padding:12px;border-radius:10px;border:none;cursor:pointer;font-weight:700;background:var(--accent);color:#fff}.login-error{background:var(--danger-light);color:var(--danger);border:1px solid var(--danger);border-radius:8px;padding:10px 14px;font-size:.88rem;text-align:center}.admin-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--line)}.admin-header h1{margin:0 0 4px;font-size:1.6rem}.admin-header p{margin:0;color:var(--muted)}.admin-header button{border:0;border-radius:8px;padding:8px 16px;cursor:pointer;font-weight:600;background:#e2e8ef;color:var(--ink)}.admin-filters{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.admin-filters button{border:1px solid var(--line);border-radius:8px;padding:8px 16px;cursor:pointer;font-weight:600;background:var(--panel);color:var(--muted);transition:all .2s}.admin-filters button:hover{border-color:var(--accent);color:var(--accent)}.admin-filters button.active{background:var(--accent);border-color:var(--accent);color:#fff}.empty,.loading{text-align:center;color:var(--muted);padding:60px 0;font-size:1.1rem}.fetch-error{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px;color:var(--danger);font-size:1rem}.fetch-error button{padding:8px 20px;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600}.adminGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-gap:16px;gap:16px}.imageCard{background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s}.imageCard:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.1)}.card-thumb{position:relative;width:100%;aspect-ratio:4/3;overflow:hidden;background:#f0ece4}.card-thumb img{width:100%;height:100%;object-fit:cover}.badge{position:absolute;top:8px;right:8px;padding:4px 8px;border-radius:6px;font-size:.75rem;font-weight:700;color:#fff}.badge-error{background:var(--danger)}.badge-selected{background:var(--success)}.card-no-img{width:100%;height:100%;justify-content:center;color:var(--muted);font-size:.85rem}.card-no-img,.dup-toolbar{display:flex;align-items:center}.dup-toolbar{gap:12px;margin-bottom:20px;flex-wrap:wrap}.dup-toolbar label{display:flex;align-items:center;gap:6px;font-size:.9rem}.dup-threshold-input{width:52px;padding:4px 8px;border:1px solid var(--line);border-radius:6px;font-size:.9rem;font-family:inherit;text-align:center}.dup-group{margin-bottom:28px}.dup-group-label{margin:0 0 10px;font-weight:700;font-size:.95rem}.dup-row{display:flex;gap:12px;flex-wrap:wrap}.dup-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden;width:200px;flex-shrink:0}.dup-card img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}.dup-time{margin:6px 10px 2px;font-size:.75rem;color:var(--muted)}.dup-report{margin:0 10px 6px;font-size:.8rem;font-weight:600;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dup-actions{display:flex;gap:6px;padding:0 10px 10px}.dup-actions button{flex:1 1;padding:6px 8px;font-size:.8rem;border-radius:6px}.card-info{padding:10px 12px}.card-time{margin:0 0 4px;font-size:.8rem;color:var(--muted)}.card-summary{margin:0;font-size:.9rem;font-weight:600;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:24px}.pagination button{border:1px solid var(--line);border-radius:8px;padding:8px 16px;cursor:pointer;font-weight:600;background:var(--panel);color:var(--ink)}.pagination button:disabled{opacity:.4;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:var(--panel);border-radius:16px;padding:24px;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;position:relative}.modal-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;border:none;background:#e2e8ef;font-size:1.4rem;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.modal h2{margin:0 0 16px;font-size:1.3rem}.modal-image{width:100%;max-height:400px;object-fit:contain;background:#f0ece4}.modal-image,.modal-meta{border-radius:10px;margin-bottom:16px}.modal-meta{background:#f8f7f4;padding:12px 16px}.modal-meta p{margin:4px 0;font-size:.9rem}.modal-report{border-top:1px solid var(--line);padding-top:16px}.modal-report h3{margin:0 0 8px;font-size:1rem}.modal-report p{margin:0;font-size:.95rem;line-height:1.7}.modal-wide{max-width:960px}.modal-images{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:10px;gap:10px;margin-bottom:16px}.modal-img-cell img{width:100%;aspect-ratio:4/3;object-fit:contain;border-radius:8px;background:#f0ece4;border:1px solid var(--line)}.modal-img-label{margin:0 0 6px;font-size:.82rem;font-weight:600;color:var(--muted);text-align:center}.modal-actions{display:flex;gap:10px;align-items:center;justify-content:flex-end;margin-top:16px;padding-top:16px;border-top:1px solid var(--line);flex-wrap:wrap}.action-msg{color:var(--danger);font-size:.9rem;margin-right:auto}button.select-btn{background:linear-gradient(120deg,var(--success),#34d399);color:#fff}button.select-btn:disabled{opacity:.6;cursor:not-allowed}.admin-link{color:var(--muted);font-size:.9rem;text-decoration:underline}.consent-overlay{position:fixed;inset:0;background:rgba(15,23,42,.6);display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.consent-modal{background:var(--panel);border-radius:16px;width:100%;max-width:680px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 64px rgba(0,0,0,.2)}.consent-header{padding:24px 28px 16px;border-bottom:1px solid var(--line);flex-shrink:0}.consent-header h2{margin:0 0 6px;font-size:1.2rem;color:var(--ink)}.consent-subtitle{margin:0;font-size:.88rem;color:var(--muted)}.consent-body{flex:1 1;overflow-y:auto;padding:20px 28px;background:#f8fafc}.consent-text{font-family:inherit;font-size:.9rem;line-height:1.8;color:var(--ink);white-space:pre-wrap;margin:0}.consent-footer{padding:20px 28px 24px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:14px;flex-shrink:0}.consent-checkbox{display:flex;align-items:flex-start;gap:10px;font-size:.9rem;color:var(--ink);cursor:pointer;line-height:1.5}.consent-checkbox input[type=checkbox]{margin-top:3px;width:16px;height:16px;cursor:pointer;accent-color:var(--accent);flex-shrink:0}.consent-btn{width:100%;padding:12px;font-size:1rem;border-radius:10px;border:none;cursor:pointer;font-weight:700;background:var(--accent);color:#fff;transition:background .2s}.consent-btn:disabled{opacity:.45;cursor:not-allowed;background:#94a3b8}button.danger{background:linear-gradient(120deg,var(--danger),#ef4444);color:#fff}.cam-panel{margin-top:10px}.cam-viewfinder{position:relative;border-radius:14px;overflow:hidden;background:#111;border:2px solid #d1d5db;min-height:200px}.cam-live-wrapper{position:relative;width:100%;aspect-ratio:4/3;touch-action:none}.cam-live{object-fit:contain;display:block;background:#000}.cam-live,.guide-svg{width:100%;height:100%}.guide-svg{position:absolute;top:0;left:0;pointer-events:none;z-index:5}.cam-shoot-btn{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);background:rgba(37,99,235,.9);color:#fff;border:2px solid rgba(255,255,255,.6);border-radius:28px;padding:9px 26px;font-size:.95em;font-weight:700;cursor:pointer;z-index:10;font-family:inherit;display:flex;align-items:center;gap:6px;white-space:nowrap}.cam-shoot-btn:active{transform:translateX(-50%) scale(.97)}.cam-shoot-btn:disabled{opacity:.5;cursor:not-allowed}.cam-retake-btn{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);background:rgba(220,38,38,.85);color:#fff;border:none;border-radius:20px;padding:7px 18px;font-size:.88em;font-weight:600;cursor:pointer;z-index:10;font-family:inherit}.cam-retake-btn:active{background:rgba(220,38,38,1)}.cam-preview-img{width:100%;aspect-ratio:4/3;object-fit:contain;display:block;background:#000}.cam-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:#aaa;font-size:.88rem;text-align:center;gap:10px}.cam-file-hidden{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.cam-zoom-bar{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:10px;padding:6px 12px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px}.cam-zoom-slider{width:140px;accent-color:#2563eb;cursor:pointer}.cam-zoom-label{font-size:.85em}.cam-zoom-val{font-size:.8em;font-weight:600;color:#2563eb;min-width:42px;text-align:right}.focus-ring{position:fixed;width:64px;height:64px;margin-left:-32px;margin-top:-32px;border:2px solid rgba(255,200,50,.9);border-radius:50%;pointer-events:none;z-index:20;animation:focusPulse .7s ease-out forwards}@keyframes focusPulse{0%{transform:scale(.5);opacity:1}60%{transform:scale(1.2);opacity:.6}to{transform:scale(1.5);opacity:0}}