@import"https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;1,400&family=Lato:wght@300;400;700&display=swap";:root{--cream: #fdf8f4;--blush: #f5ede6;--rose: #d4896a;--rose-dark: #b86e52;--brown: #4a3728;--brown-light: #9b7860;--gold: #c9a98a;--white: #ffffff;--shadow: 0 4px 24px rgba(74,55,40,.1);--radius: 16px;--font-display: "Cormorant Garamond", Georgia, serif;--font-body: "Lato", system-ui, sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--cream);color:var(--brown);font-family:var(--font-body);min-height:100dvh;-webkit-font-smoothing:antialiased}#root{min-height:100vh}.page{max-width:480px;margin:0 auto;padding:20px 20px 24px;min-height:100dvh;height:100dvh;display:flex;flex-direction:column;gap:16px;box-sizing:border-box;overflow-y:auto}.home-page{justify-content:space-between}.home-top{display:flex;justify-content:flex-end}.home-hero{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:10px;padding:32px 0}.rings-icon{font-size:56px;filter:drop-shadow(0 2px 8px rgba(212,137,106,.3))}.couple-names{font-family:var(--font-display);font-size:clamp(32px,8vw,48px);font-weight:600;color:var(--brown);line-height:1.1}.wedding-date{font-family:var(--font-display);font-size:20px;color:var(--rose);letter-spacing:2px}.tagline{font-size:15px;color:var(--brown-light);font-style:italic;margin-top:4px}.home-actions{display:flex;flex-direction:column;gap:12px}.btn-primary{background:var(--rose);color:var(--white);border:none;border-radius:50px;padding:16px 32px;font-family:var(--font-body);font-size:16px;font-weight:700;letter-spacing:.5px;cursor:pointer;transition:background .2s,transform .1s;width:100%;box-shadow:0 4px 16px #d4896a4d}.btn-primary:hover{background:var(--rose-dark)}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{background:#ccc;box-shadow:none;cursor:default}.btn-secondary{background:var(--blush);color:var(--brown);border:1.5px solid var(--gold);border-radius:50px;padding:14px 28px;font-family:var(--font-body);font-size:15px;font-weight:600;cursor:pointer;transition:background .2s;width:100%}.btn-secondary:hover{background:var(--gold);color:var(--white)}.btn-danger{background:transparent;color:#c0392b;border:1.5px solid #c0392b;border-radius:50px;padding:12px 24px;font-size:14px;font-weight:600;cursor:pointer;width:100%}.btn-back{background:none;border:none;color:var(--brown-light);font-size:15px;cursor:pointer;padding:4px 0;text-align:left;width:fit-content}.btn-back:hover{color:var(--brown)}.btn-small{background:var(--rose);color:#fff;border:none;border-radius:20px;padding:4px 14px;font-size:13px;cursor:pointer;margin-left:12px}.btn-icon{background:var(--blush);border:1px solid var(--gold);border-radius:20px;padding:8px 16px;font-size:14px;cursor:pointer;color:var(--brown)}.btn-row{display:flex;gap:10px}.btn-row .btn-primary,.btn-row .btn-secondary{width:auto;flex:1}.btn-col{display:flex;flex-direction:column;gap:12px}.lang-btn{background:var(--blush);border:1px solid var(--gold);border-radius:20px;padding:8px 16px;font-size:14px;cursor:pointer;color:var(--brown)}.lang-dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:#fff;border:1px solid var(--gold);border-radius:12px;box-shadow:var(--shadow);z-index:100;overflow:hidden;min-width:150px}.lang-option{display:block;width:100%;background:none;border:none;padding:10px 16px;text-align:left;font-size:14px;cursor:pointer;color:var(--brown)}.lang-option:hover{background:var(--blush)}.lang-option.active{font-weight:700;background:var(--blush)}.layout-cards{display:flex;gap:14px}.layout-card{flex:1;background:#fff;border:2px solid var(--gold);border-radius:var(--radius);padding:20px 12px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:10px;font-family:var(--font-body);color:var(--brown);transition:border-color .2s,box-shadow .2s}.layout-card.selected{border-color:var(--rose);box-shadow:0 0 0 3px #d4896a33}.layout-card strong{font-size:15px}.layout-card span{font-size:12px;color:var(--brown-light)}.layout-preview{width:60px;height:80px;display:flex;align-items:center;justify-content:center}.lp-strip{display:flex;flex-direction:column;gap:3px;width:36px}.lp-strip div{height:20px;background:var(--blush);border:1px solid var(--gold);border-radius:2px}.lp-grid{display:grid;grid-template-columns:1fr 1fr;gap:3px;width:46px}.lp-grid div{height:20px;background:var(--blush);border:1px solid var(--gold);border-radius:2px}.camera-page{padding:12px 16px;gap:8px;height:100dvh;max-height:100dvh;overflow:hidden;justify-content:flex-start}.camera-top{display:flex;justify-content:space-between;align-items:center}.video-wrap{position:relative;border-radius:var(--radius);overflow:hidden;background:#000;flex:1 1 auto;min-height:0;aspect-ratio:unset}.video-wrap video{width:100%;height:100%;object-fit:cover}.video-feed{width:100%;height:100%;object-fit:cover;display:block}.countdown-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:96px;color:#fff;text-shadow:0 0 30px rgba(0,0,0,.8);background:#00000026;animation:pop .4s ease}.countdown-overlay.flash{font-size:72px}@keyframes pop{0%{transform:scale(1.4);opacity:0}to{transform:scale(1);opacity:1}}.photo-thumbs{display:flex;gap:6px;justify-content:center;flex-wrap:nowrap;flex-shrink:0}.thumb{width:60px;height:45px;border-radius:8px;border:2px solid var(--gold);overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--blush);color:var(--brown-light);font-size:18px;font-family:var(--font-display)}.thumb.taken{border-color:var(--rose)}.thumb img{width:100%;height:100%;object-fit:cover}.btn-shoot{margin-top:0;flex-shrink:0}.message-input{width:100%;border:1.5px solid var(--gold);border-radius:var(--radius);padding:14px 16px;font-family:var(--font-body);font-size:16px;color:var(--brown);background:#fff;resize:none;outline:none}.message-input:focus{border-color:var(--rose)}.collage-preview{width:100%;border-radius:var(--radius);box-shadow:var(--shadow)}.drop-zone{border:2px dashed var(--gold);border-radius:var(--radius);padding:40px 20px;text-align:center;cursor:pointer;background:#fff;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--brown-light);transition:border-color .2s,background .2s}.drop-zone:hover{border-color:var(--rose);background:var(--blush)}.drop-zone span{font-size:40px}.drop-zone p{font-size:16px;color:var(--brown);font-weight:600}.drop-zone small{font-size:13px}.upload-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.upload-thumb{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;background:var(--blush)}.upload-thumb img{width:100%;height:100%;object-fit:cover}.thumb-status{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:24px;background:#ffffffb3}.upload-done{text-align:center;display:flex;flex-direction:column;gap:12px;align-items:center}.upload-done p{font-size:18px;color:var(--rose);font-family:var(--font-display);font-weight:600}.display-wall{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0a0a;overflow:hidden;cursor:pointer}.display-slide{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;transition:opacity 1.2s ease;display:flex;align-items:center;justify-content:center}.display-slide.active{opacity:1}.display-slide img{width:100%;height:100%;object-fit:contain}.display-brand{position:fixed;bottom:0;left:0;right:0;z-index:10;padding:20px 40px;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 100%);display:flex;justify-content:space-between;align-items:flex-end;color:#fff;font-family:var(--font-display);font-size:28px;font-weight:600}.display-date{font-size:20px;font-weight:400;opacity:.85}.display-waiting{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;gap:16px;text-align:center}.display-waiting h2{font-family:var(--font-display);font-size:48px}.display-waiting p{color:#fff9;font-size:18px}.display-login{background:#0a0a0a;align-items:center;justify-content:center;min-height:100dvh}.display-login-box{background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius);padding:40px;text-align:center;display:flex;flex-direction:column;gap:14px;color:#fff;width:100%;max-width:360px}.display-login-box h2{font-family:var(--font-display);font-size:28px}.admin-login{align-items:center;justify-content:center;min-height:100dvh}.admin-login-box{background:#fff;border-radius:var(--radius);padding:40px;text-align:center;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow);width:100%;max-width:360px}.admin-page{max-width:580px;padding-bottom:60px}.admin-header{display:flex;justify-content:space-between;align-items:center}.admin-section{background:#fff;border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;gap:10px;box-shadow:0 2px 12px #4a372812}.admin-section h3{font-family:var(--font-display);font-size:20px;margin-bottom:4px}.admin-section label{font-size:13px;color:var(--brown-light);font-weight:600;letter-spacing:.3px}.admin-section a{color:var(--rose);font-size:12px;text-decoration:none}.admin-actions{display:flex;flex-direction:column;gap:10px}.locked-banner{background:#fff3cd;border:1px solid #ffc107;border-radius:10px;padding:12px 16px;font-size:14px;display:flex;align-items:center}.input{width:100%;border:1.5px solid var(--gold);border-radius:10px;padding:12px 14px;font-family:var(--font-body);font-size:15px;color:var(--brown);background:var(--cream);outline:none;transition:border-color .2s}.input:focus{border-color:var(--rose);background:#fff}.input.input-error{border-color:#e74c3c}.input:disabled{opacity:.5}.error-msg{color:#e74c3c;font-size:13px}h2{font-family:var(--font-display);font-size:28px;font-weight:600;color:var(--brown)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--cream)}::-webkit-scrollbar-thumb{background:var(--gold);border-radius:3px}.lp-single{display:flex;align-items:center;justify-content:center;width:46px;height:60px}.lp-single div{width:36px;height:50px;background:var(--blush);border:1px solid var(--gold);border-radius:2px}.camera-error{background:#fff3cd;border:1px solid #ffc107;border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;gap:10px;text-align:center;color:var(--brown)}.camera-error p{font-weight:600}.camera-error small{font-size:12px;color:var(--brown-light);word-break:break-word}.layout-cards{display:flex;gap:10px}.layout-cards .layout-card{padding:14px 8px}.camera-hint-box{background:#fff;border-radius:10px;padding:16px;text-align:left;display:flex;flex-direction:column;gap:8px}.camera-hint-box strong{font-size:15px;color:var(--brown)}.camera-hint-box p{font-size:13px;color:var(--brown-light);line-height:1.6}.admin-page-wrap{max-width:620px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;background:var(--cream)}.admin-topbar{display:flex;justify-content:space-between;align-items:center;padding:20px 20px 0;gap:12px;flex-wrap:wrap}.admin-topbar h2{font-family:var(--font-display);font-size:24px;margin:0}.admin-subtitle{font-size:13px;color:var(--brown-light);font-style:italic}.admin-tabs{display:flex;gap:4px;padding:16px 20px 0;overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-tab{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 14px;background:#fff;border:1.5px solid var(--gold);border-radius:12px 12px 0 0;font-size:12px;font-weight:600;color:var(--brown-light);cursor:pointer;transition:all .15s;border-bottom:none}.admin-tab span:first-child{font-size:18px}.admin-tab.active{background:#fff;border-color:var(--rose);color:var(--rose);border-bottom:2px solid white;margin-bottom:-2px;z-index:1}.admin-content{flex:1;padding:0 20px 40px;display:flex;flex-direction:column;gap:0}.admin-section{background:#fff;border:1.5px solid var(--gold);border-radius:0 12px 12px;padding:24px 20px;display:flex;flex-direction:column;gap:8px}.section-header{margin-bottom:8px}.section-header h3{font-family:var(--font-display);font-size:22px;margin-bottom:4px}.section-header p{font-size:14px;color:var(--brown-light)}.field-label{font-size:13px;font-weight:700;color:var(--brown);letter-spacing:.3px;margin-top:4px}.field-hint{font-size:12px;color:var(--brown-light);line-height:1.5;margin-top:-4px}.field-hint a{color:var(--rose);text-decoration:none}.field-hint code{background:var(--blush);padding:1px 4px;border-radius:3px;font-size:11px}.field-divider{height:1px;background:var(--blush);margin:8px 0}.logo-preview-wrap{display:flex;flex-direction:column;gap:8px}.logo-preview{max-height:64px;max-width:200px;border-radius:8px;border:1px solid var(--gold);object-fit:contain;background:var(--blush);padding:4px}.btn-upload{display:flex;flex-direction:column;align-items:center;gap:4px;border:2px dashed var(--gold);border-radius:12px;padding:24px;background:var(--blush);cursor:pointer;color:var(--brown-light);font-size:14px;font-weight:600;transition:border-color .2s,background .2s}.btn-upload:hover{border-color:var(--rose);background:#fef0e9}.btn-upload small{font-size:12px;font-weight:400}.branding-preview-box{background:var(--blush);border-radius:10px;padding:14px;border:1px solid var(--gold);margin-top:4px}.branding-preview-label{font-size:11px;color:var(--brown-light);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.branding-preview{display:flex;align-items:center;gap:12px}.countdown-display{font-family:var(--font-display);font-size:36px;font-weight:600;color:var(--rose);text-align:center;padding:8px 0}.range-input{width:100%;accent-color:var(--rose);height:6px;cursor:pointer}.range-labels{display:flex;justify-content:space-between;font-size:11px;color:var(--brown-light)}.range-labels .active{color:var(--rose);font-weight:700}.info-box{background:#f0f7ff;border:1px solid #b8d4f0;border-radius:10px;padding:14px;font-size:13px;color:#2c5282;line-height:1.6}.info-box code{background:#00000014;padding:2px 6px;border-radius:4px;font-size:12px}.info-box-warn{background:#fffbeb;border-color:#f6c142;color:#7d5a00}.info-box ol{margin-top:4px}.info-box code{background:#0000000f}.display-link-box{display:flex;align-items:center;gap:8px;flex-wrap:wrap;background:var(--blush);border-radius:10px;padding:12px 14px;font-size:13px}.display-link-box code{flex:1;font-size:12px;word-break:break-all}.qr-preview-wrap{display:flex;flex-direction:column;align-items:center;gap:8px;background:var(--blush);border-radius:16px;padding:24px;border:1px solid var(--gold);margin-top:8px;text-align:center}.qr-preview{width:200px;height:200px;border-radius:8px}.qr-label{font-family:var(--font-display);font-size:20px;font-weight:600}.status-badge{padding:10px 14px;border-radius:8px;font-size:14px;font-weight:600}.status-locked{background:#fff3cd;color:#7d5a00;border:1px solid #f6c142}.admin-login{align-items:center;justify-content:center}.admin-login-box{background:#fff;border-radius:var(--radius);padding:40px 32px;text-align:center;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow);width:100%;max-width:380px}.admin-hint-box{background:var(--blush);border-radius:10px;padding:12px 14px;font-size:13px;color:var(--brown-light);text-align:left;line-height:1.7}.admin-hint-box code{background:#fff;padding:2px 6px;border-radius:4px;font-weight:700}.btn-save{margin-top:16px;border-radius:12px!important}.btn-small-danger{background:#fee2e2!important;color:#c0392b!important;border:1px solid #fca5a5!important}.btn-small-warn{background:#d1fae5!important;color:#065f46!important;border:1px solid #6ee7b7!important}.home-logo{max-height:56px;max-width:180px;object-fit:contain;margin-bottom:4px}.home-actions{display:flex;flex-direction:column;gap:10px}.home-card{display:flex;flex-direction:row;align-items:center;background:#fff;border:1.5px solid var(--gold);border-radius:var(--radius);padding:16px 20px;cursor:pointer;text-align:left;transition:all .15s;box-shadow:0 2px 8px #4a37280f;gap:14px;width:100%}.home-card:hover{border-color:var(--rose);box-shadow:0 4px 16px #d4896a2e;transform:translateY(-1px)}.home-card-secondary{background:var(--blush)}.home-card-icon{font-size:28px;flex:0 0 auto}.home-card-text{display:flex;flex-direction:column;gap:2px;flex:1}.challenge-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;overflow-y:auto;flex:1 1 0;min-height:0;align-content:start;padding-bottom:4px}.challenge-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:#fff;border:1.5px solid var(--gold);border-radius:12px;padding:12px 6px;cursor:pointer;transition:all .15s;width:100%}.challenge-btn:hover{border-color:var(--rose);background:var(--blush)}.challenge-btn.selected{border-color:var(--rose);background:#fef0e9;box-shadow:0 0 0 3px #d4896a33}.challenge-emoji{font-size:26px}.challenge-label{font-size:11px;font-weight:600;color:var(--brown);text-align:center;line-height:1.3}.challenge-badge{background:var(--blush);border:1px solid var(--gold);border-radius:20px;padding:6px 14px;font-size:14px;font-weight:600;color:var(--brown)}.gallery-page{gap:12px}.gallery-header{display:flex;align-items:center;gap:12px}.gallery-header h2{margin:0}.gallery-tabs{display:flex;gap:8px}.gallery-tab{flex:1;padding:10px;background:#fff;border:1.5px solid var(--gold);border-radius:10px;font-size:14px;font-weight:600;color:var(--brown-light);cursor:pointer;transition:all .15s}.gallery-tab.active{border-color:var(--rose);color:var(--rose);background:#fef0e9}.gallery-loading,.gallery-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:var(--brown-light);gap:12px;text-align:center}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.photo-tile{position:relative;aspect-ratio:1;overflow:hidden;border-radius:6px;cursor:pointer;background:var(--blush)}.photo-tile img{width:100%;height:100%;object-fit:cover;transition:transform .2s}.photo-tile:hover img{transform:scale(1.05)}.photo-challenge-badge{position:absolute;top:4px;left:4px;font-size:16px;background:#ffffffd9;border-radius:50%;width:26px;height:26px;display:flex;align-items:center;justify-content:center}.photo-rating-bar{position:absolute;bottom:0;left:0;right:0;background:#0000008c;padding:3px 6px;display:flex;gap:6px;font-size:11px;color:#fff}.ranking-page{display:flex;flex-direction:column;gap:16px}.ranking-category{background:#fff;border-radius:var(--radius);padding:16px;box-shadow:0 2px 8px #4a372812}.ranking-cat-title{font-family:var(--font-display);font-size:20px;margin-bottom:12px}.ranking-empty{font-size:13px;color:var(--brown-light)}.ranking-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--blush);cursor:pointer}.ranking-item:last-child{border-bottom:none}.ranking-medal{font-size:22px;flex:0 0 auto}.ranking-thumb{width:52px;height:52px;border-radius:8px;object-fit:cover;flex:0 0 auto}.ranking-thumb-missing{background:var(--blush);display:flex;align-items:center;justify-content:center;color:var(--brown-light);font-size:20px}.ranking-info{display:flex;flex-direction:column;gap:2px}.ranking-count{font-size:18px;font-weight:700;color:var(--brown)}.ranking-challenge{font-size:18px}.photo-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;z-index:200;display:flex;align-items:center;justify-content:center;padding:16px}.photo-modal-inner{background:#fff;border-radius:var(--radius);overflow:hidden;max-width:500px;width:100%;max-height:90vh;display:flex;flex-direction:column}.photo-modal-close{position:absolute;top:16px;right:16px;background:#0009;border:none;color:#fff;font-size:18px;border-radius:50%;width:36px;height:36px;cursor:pointer;z-index:10}.photo-modal-img{width:100%;max-height:55vh;object-fit:contain;background:#111}.photo-modal-actions{display:flex;gap:0;border-top:1px solid var(--blush)}.rate-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 8px;background:none;border:none;border-right:1px solid var(--blush);cursor:pointer;transition:background .15s}.rate-btn:last-child{border-right:none}.rate-btn:hover{background:var(--blush)}.rate-btn.voted{background:#fef0e9}.rate-icon{font-size:24px}.rate-label{font-size:11px;color:var(--brown-light)}.rate-count{font-size:13px;font-weight:700;color:var(--rose)}.pw-reveal-row{display:flex;gap:8px;align-items:center}.pw-reveal-row .input{flex:1}.pw-eye{flex:0 0 auto;background:var(--blush);border:1px solid var(--gold);border-radius:10px;padding:10px 12px;cursor:pointer;font-size:16px}.home-card-title{font-size:17px;font-weight:700;color:var(--brown)}.home-card-desc{font-size:13px;color:var(--brown-light);margin-top:2px}.drive-connected-box{display:flex;align-items:center;gap:12px;background:#e8f5e9;border:1.5px solid #66bb6a;border-radius:12px;padding:14px 16px}.drive-connected-icon{font-size:24px;flex:0 0 auto}.drive-connected-info{flex:1;display:flex;flex-direction:column;gap:2px}.drive-connected-info strong{font-size:14px;color:#2e7d32}.drive-connected-info span{font-size:12px;color:#388e3c}.drive-disconnected-box{display:flex;flex-direction:column;align-items:center;gap:10px;background:var(--blush);border:2px dashed var(--gold);border-radius:14px;padding:24px 20px;text-align:center}.drive-disconnected-box p{font-size:14px;color:var(--brown-light)}.btn-google{display:flex;align-items:center;justify-content:center;background:#fff;border:1.5px solid #dadce0;border-radius:50px;padding:12px 24px;font-size:15px;font-weight:600;color:#3c4043;cursor:pointer;transition:box-shadow .2s,background .2s;box-shadow:0 1px 4px #00000026;width:100%;max-width:320px}.btn-google:hover{background:#f8f9fa;box-shadow:0 2px 8px #0003}.btn-google:disabled{opacity:.5;cursor:default}.zoom-btns{display:flex;gap:8px;justify-content:center;flex-shrink:0}.zoom-btn{background:#00000073;color:#fff;border:1.5px solid rgba(255,255,255,.3);border-radius:20px;padding:6px 14px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.zoom-btn:hover{background:#000000a6}.zoom-btn.active{background:var(--rose);border-color:var(--rose);color:#fff}.video-feed[data-facing=user]{transform:scaleX(-1)}.video-feed[data-facing=environment]{transform:none}.cam-controls{display:flex;flex-direction:column;gap:6px;flex-shrink:0;padding:0 8px;width:100%}.cam-controls-row{display:flex;align-items:center;justify-content:center;gap:8px;width:100%}.zoom-track-wrap{width:70%}.torch-btn{flex:0 0 auto;height:36px;padding:0 16px;border-radius:20px;background:#00000073;border:1.5px solid rgba(255,255,255,.4);font-size:14px;font-weight:600;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background .2s;white-space:nowrap}.torch-btn.on{background:#ffc80080;border-color:gold;color:#fff}.zoom-track-wrap{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.zoom-track{position:relative;width:100%}.zoom-range{width:100%;height:8px;accent-color:var(--rose);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ffffff40;border-radius:3px;outline:none}.zoom-range::-webkit-slider-thumb{-webkit-appearance:none;width:36px;height:36px;border-radius:50%;background:var(--rose);cursor:pointer;border:3px solid white;box-shadow:0 2px 10px #00000080}.zoom-range:active::-webkit-slider-thumb{width:48px;height:48px}.zoom-range::-moz-range-thumb{width:36px;height:36px;border-radius:50%;background:var(--rose);border:3px solid white}.zoom-range::-moz-range-thumb{width:26px;height:26px;border-radius:50%;background:var(--rose);cursor:pointer;border:2px solid white}.zoom-slider-outer{position:relative;width:100%;height:44px;display:flex;align-items:center}.zoom-rail{position:absolute;left:22px;right:22px;height:6px;background:#ffffff40;border-radius:3px;pointer-events:none}.zoom-rail-fill{position:absolute;left:0;height:100%;background:var(--rose);border-radius:3px;pointer-events:none;transition:width .05s}.zoom-snap-tick{position:absolute;top:50%;transform:translate(-50%,-50%);width:4px;height:12px;background:#ffffff80;border-radius:2px;pointer-events:none}.zoom-snap-tick.at-snap{background:#fff}.zoom-knob{position:absolute;width:44px;height:44px;border-radius:50%;background:var(--rose);border:3px solid white;box-shadow:0 2px 10px #00000080;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#fff;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;transition:width .15s,height .15s,font-size .15s;transform:translate(-50%);z-index:2}.zoom-knob.dragging{width:54px;height:54px;font-size:13px;box-shadow:0 4px 16px #0009}.zoom-input-hidden{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;opacity:0;cursor:grab;height:100%;margin:0}.zoom-btns-wrap{display:flex;align-items:center;gap:10px;justify-content:center}.zoom-step-btn{width:44px;height:44px;border-radius:50%;background:#00000073;border:2px solid rgba(255,255,255,.4);color:#fff;font-size:22px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,transform .1s;flex-shrink:0;line-height:1}.zoom-step-btn:active{transform:scale(.9);background:var(--rose)}.zoom-step-btn:disabled{opacity:.3;cursor:default}.zoom-val-badge{min-width:52px;text-align:center;font-size:16px;font-weight:800;color:#fff;background:var(--rose);border-radius:20px;padding:6px 12px;text-shadow:none}
