body{margin:0;padding:0}:root{--primary: #ffffff;--primary-deep: #e2e8f0;--acc: #4ade80;--acc-bright: #34eb7a;--warm-grad: linear-gradient(135deg, #4ade80, #34eb7a);--warm-grad-subtle: linear-gradient(135deg, rgba(255, 255, 255, .1), rgba(255, 255, 255, .05));--bg-white: #0a0a0a;--bg-soft: #000000;--glass-bg: rgba(255, 255, 255, .03);--glass-border: rgba(255, 255, 255, .2);--glass-inner-glow: rgba(255, 255, 255, .05);--text: #ffffff;--text-muted: #94a3b8;--success: #4ade80;--error: #ef4444;--skeleton-bg: rgba(255, 255, 255, .05);--skeleton-highlight: rgba(255, 255, 255, .1)}html,body{margin:0;padding:0;min-height:100vh;overflow-x:hidden;overflow-y:auto!important;-webkit-overflow-scrolling:touch}@keyframes shimmer{0%{transform:translate(-150%)}to{transform:translate(150%)}}@keyframes skeleton-pulse{0%,to{opacity:.55;filter:blur(0px)}50%{opacity:.85;filter:blur(.5px)}}@keyframes skeleton-glow{0%,to{box-shadow:0 0 15px #4ade800d}50%{box-shadow:0 0 35px #4ade8033}}.skeleton-shimmer{position:relative;overflow:hidden;background:var(--skeleton-bg);animation:skeleton-pulse 2s ease-in-out infinite}.skeleton-shimmer:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,var(--skeleton-highlight),transparent);animation:shimmer 1.5s infinite}*{box-sizing:border-box;margin:0;padding:0;font-family:Outfit,sans-serif}body{background-color:var(--bg-white);color:var(--text);min-height:100vh;display:flex;justify-content:center;align-items:flex-start;overflow-x:hidden;overflow-y:auto;padding:40px 20px}html{overflow-x:hidden;overflow-y:auto}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#0000000d}::-webkit-scrollbar-thumb{background:#4ade8033;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#4ade8066}.background-blobs{position:fixed;top:0;left:0;width:100%;height:100%;z-index:-1;background:#000}.background-blobs:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");opacity:.15;pointer-events:none}.blob{position:absolute;border-radius:50%;opacity:.18;animation:move 30s infinite alternate cubic-bezier(.445,.05,.55,.95);will-change:transform}.blob1{width:600px;height:600px;top:10%;right:15%;background:radial-gradient(circle at 30% 30%,#4ade80,#0d522c 70%,#000);box-shadow:0 0 120px #4ade8066;opacity:.8;filter:blur(40px)}.blob2{width:700px;height:700px;bottom:0%;left:20%;background:radial-gradient(circle at 30% 30%,#1ecb5d,#166534 70%,#000);box-shadow:0 0 140px #05966980;opacity:.85;filter:blur(60px)}.blob3{width:400px;height:400px;top:40%;left:5%;background:radial-gradient(circle at 30% 30%,#34eb7a,#0d522c 70%,#000);box-shadow:0 0 80px #34d3994d;opacity:.7;filter:blur(30px)}@keyframes move{0%{transform:translate(0) rotate(0)}to{transform:translate(120px,120px) rotate(45deg)}}.floating-bubbles{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;overflow:hidden}.bubble{position:absolute;background:#ffffff14;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:50%;border:1px solid rgba(255,255,255,.15);will-change:transform;box-shadow:0 8px 32px #0000000d,inset 0 0 0 1px #ffffff1a;animation:float-bubble 25s infinite linear}@keyframes float-bubble{0%{transform:translateY(0) rotate(0)}50%{transform:translateY(-40px) rotate(180deg);opacity:.8}to{transform:translateY(0) rotate(360deg)}}.bubble.b2{animation-duration:35s;animation-direction:reverse}.bubble.b3{animation-duration:18s}.bubble.b4{animation-duration:40s}button,.btn,.btn-capture-manual,.zoom-pt-btn,svg text{user-select:none;-webkit-user-select:none;touch-action:manipulation;-webkit-touch-callout:none}.app-boot-loader{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0a0a;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;z-index:9999}.boot-spinner{width:52px;height:52px;border-radius:50%;border:3px solid rgba(74,222,128,.2);border-top-color:#4ade80;animation:bootSpin .8s linear infinite;will-change:transform}@keyframes bootSpin{to{transform:rotate(360deg)}}.boot-text{color:#ffffff80;font-family:Outfit,sans-serif;font-size:.95rem;letter-spacing:.04em}.app-root{width:100%;min-height:100dvh;display:flex;justify-content:center;align-items:center}@media (orientation: landscape) and (max-height: 450px){.app-root,.app-container{height:auto!important;min-height:100dvh!important;overflow-y:auto!important}}.app-root.phase-editing{overflow-y:visible!important;display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:flex-start!important;padding-top:20px;padding-bottom:20px}body.is-editing{overflow-y:auto!important}.app-container{width:100%;max-width:1100px;position:relative;z-index:10;transition:max-width .4s ease}.orientation-warning{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-soft);z-index:10000;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px;color:#fff}.warning-content{display:flex;flex-direction:column;align-items:center;gap:24px;max-width:320px}.rotate-icon{color:var(--acc);animation:rotate-wait 2s infinite ease-in-out}@keyframes rotate-wait{0%{transform:rotate(0)}25%{transform:rotate(90deg)}50%{transform:rotate(90deg)}75%{transform:rotate(0)}to{transform:rotate(0)}}.orientation-warning h2{font-size:2rem;font-weight:800;background:var(--warm-grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin:0}.orientation-warning p{color:var(--text-muted);font-size:1.1rem;margin:0;line-height:1.6}@media (min-width: 1600px){.app-container{max-width:1850px}.logo h1{font-size:3.2rem}.image_logo img{width:80px;height:80px}.main-card{padding:1rem}.operator-image-hull{height:68vh!important;max-height:850px!important}.operator-layout{flex-direction:row!important;flex-wrap:wrap!important;align-items:flex-start!important;gap:16px!important}.view-toggle-btn-group{width:100%!important;justify-content:center!important;margin-bottom:24px!important}.operator-layout>div.operator-image-hull{flex:2;height:50vh}.operator-controls-sidebar{flex:1;display:flex;flex-direction:column;gap:20px}.operator-controls-row{flex-direction:column!important;align-items:stretch!important}.operator-controls-row .control-section{max-width:100%!important}.live-pd-badge{padding:12px 28px;font-size:1.1rem}.live-pd-badge strong{font-size:1.8rem}.btn{padding:20px 40px;font-size:1.2rem}.actual-pd-input-group input{padding:32px 32px 32px 80px;font-size:3.5rem}.title-grad{font-size:4.2rem}.subtitle{font-size:1.1rem;max-width:500px}.param-label{font-size:1rem}.param-value,.live-stat strong{font-size:1.2rem}.live-stat.accent strong{font-size:1.6rem}.start-screen-hull{max-width:800px!important}.camera-rig{max-width:1000px!important}.result-container{max-width:1200px!important;margin:0 auto!important;gap:3rem!important}.pd-value-large{font-size:8rem!important}.pd-chip-label{font-size:1.2rem!important;letter-spacing:4px!important}}header{text-align:center}.header-corner{position:absolute;top:32px;left:48px;text-align:left!important;z-index:100}.app-root.phase-editing .header-corner{position:absolute;top:40px;left:40px;text-align:left!important;display:flex!important;justify-content:flex-start!important;width:auto!important}.app-root.phase-editing .header-corner .logo,.header-corner .logo{justify-content:flex-start!important}.logo{display:flex;align-items:center;justify-content:center;gap:12px}.image_logo img{width:60px;height:60px;filter:drop-shadow(0 0 15px rgba(74,222,128,.5)) brightness(1.1) contrast(1.1);transition:transform .4s cubic-bezier(.175,.885,.32,1.275)}.image_logo:hover img{transform:scale(1.08) rotate(5deg)}.logo svg{filter:drop-shadow(0 0 18px rgba(74,222,128,.5))}.logo h1{font-size:2.2rem;font-weight:800;letter-spacing:-1px;margin:0;line-height:1;background:linear-gradient(to bottom,#fff,#e2e8f0);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 20px rgba(74,222,128,.15))}.logo h1 span{background:linear-gradient(135deg,#4ade80,#34eb7a);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:800;margin-left:2px}.subtitle{color:var(--text-muted);font-size:.85rem;font-weight:500;letter-spacing:4px;text-transform:uppercase}.glass{background:linear-gradient(145deg,#ffffff14,#ffffff03);backdrop-filter:blur(32px) saturate(160%);-webkit-backdrop-filter:blur(32px) saturate(160%);border-top:1px solid rgba(255,255,255,.25);border-left:1px solid rgba(255,255,255,.15);border-bottom:1px solid rgba(255,255,255,.03);border-right:1px solid rgba(255,255,255,.05);border-radius:40px;box-shadow:0 30px 60px #00000080,inset 0 1px 2px #ffffff26,inset 0 -1px 2px #0003;position:relative;overflow:hidden}.glass:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 35%,transparent 65%,rgba(255,255,255,.03) 100%);pointer-events:none;z-index:1}.glass-vibe{background:linear-gradient(145deg,#ffffff0d,#ffffff01);backdrop-filter:blur(40px) saturate(180%);-webkit-backdrop-filter:blur(40px) saturate(180%);border-top:1px solid rgba(255,255,255,.4);border-left:1px solid rgba(255,255,255,.2);border-bottom:1px solid rgba(255,255,255,.02);border-right:1px solid rgba(255,255,255,.05);border-radius:48px;box-shadow:0 40px 100px -10px #000000e6,0 0 60px #4ade8026,inset 0 1px 2px #fff6,inset 0 -1px 2px #00000080;transition:all .6s cubic-bezier(.34,1.56,.64,1);position:relative;padding:32px;animation:float-vibe 6s ease-in-out infinite}.glass-vibe:before{content:"";position:absolute;top:0;left:0;right:0;height:1.5px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.8),transparent);pointer-events:none;z-index:10}.glass-vibe:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:48px;box-shadow:inset 0 0 40px #ffffff0d;pointer-events:none;background:linear-gradient(135deg,rgba(255,255,255,.08) 0%,transparent 30%,transparent 70%,rgba(255,255,255,.02) 100%)}.glass-vibe-inner{position:relative;z-index:2;border-radius:32px;overflow:hidden;border-top:1px solid rgba(255,255,255,.35);border-left:1px solid rgba(255,255,255,.15);border-bottom:1px solid rgba(255,255,255,.05);border-right:1px solid rgba(255,255,255,.05);box-shadow:0 20px 50px #0009}.main-card{padding:2rem;display:flex;flex-direction:column;max-height:100%;overflow-y:auto}.upload-section{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;border:1.5px dashed var(--glass-border);border-radius:30px;padding:4rem 2rem;transition:all .4s cubic-bezier(.175,.885,.32,1.275);cursor:pointer;background:#4ade8005;text-align:center}.upload-section:hover,.upload-section.highlight{border-color:var(--primary);background:#4ade800a;transform:translateY(-5px);box-shadow:0 15px 40px -10px #4ade801a}.upload-icon{width:100px;height:100px;background:linear-gradient(135deg,#4ade801a,#ffb3470d);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--primary);margin-bottom:2rem;border:1px solid var(--glass-border);box-shadow:0 0 40px #4ade801a}.upload-section p{font-size:1.4rem;font-weight:500;margin-bottom:2.5rem;width:100%;color:var(--text)}.upload-section p span{background:var(--warm-grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;text-decoration:underline;text-underline-offset:4px}.instructions{display:flex;flex-wrap:wrap;gap:30px;margin-top:1rem;justify-content:center;width:100%}.inst-item{display:flex;align-items:center;gap:10px;color:var(--text-muted);font-size:.85rem;white-space:nowrap}.inst-item svg{color:var(--acc);opacity:.7}.btn-group{display:flex;flex-wrap:wrap;gap:16px;width:100%;max-width:500px;justify-content:center;margin-bottom:3rem}.btn{flex:1;padding:16px 30px;border-radius:16px;font-weight:700;font-size:1rem;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .25s ease;cursor:pointer;border:none;outline:none;min-width:160px}.btn-primary{background:var(--warm-grad);color:#fff;box-shadow:0 12px 30px -4px #4ade8066;position:relative;overflow:hidden;border-radius:20px}.btn-primary:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.1),transparent);border-radius:inherit}.btn-primary:hover{filter:brightness(1.05);box-shadow:0 16px 36px -4px #4ade8080;transform:translateY(-2px)}.btn-secondary{background:#ffffff4d;color:var(--text);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px}.btn-secondary:hover{background:#fff9;border-color:#fffc;color:var(--primary-deep)}.result-container{display:flex;flex-direction:column;gap:24px;max-height:100%;overflow-y:auto!important;-webkit-overflow-scrolling:touch;padding:10px}.result-actions{display:flex;flex-direction:column;align-items:center;gap:14px}.result-btn-download{padding:16px 40px;font-size:1.1rem;display:flex;align-items:center;gap:10px}.result-btn-row{display:flex;gap:12px;justify-content:center}.result-btn-row .btn{padding:10px 24px;display:flex;align-items:center;gap:8px;opacity:.85}.main-pd-display{text-align:center;padding:3rem;width:100%;display:flex;flex-direction:column;justify-content:center;align-items:center}.pd-chip-label{display:block;font-size:.8rem;text-transform:uppercase;letter-spacing:5px;font-weight:800;margin-bottom:4px;color:var(--text-muted);opacity:.8}.pd-value-large{font-size:5.5rem;font-weight:900;line-height:1;color:var(--text);text-shadow:0 4px 12px rgba(74,222,128,.15);letter-spacing:-2px}.pd-unit{font-size:2.5rem;font-weight:300;margin-left:10px;color:var(--text-muted)}.result-layout{display:grid;grid-template-columns:1.4fr .6fr;gap:30px}.image-preview-hull{border-radius:28px;overflow:hidden;border:1px solid rgba(74,222,128,.12);background:#000;box-shadow:inset 0 0 60px #4ade800d,0 0 0 1px #ffffff08;height:480px;position:relative}.image-preview-hull img{width:100%;height:100%;object-fit:contain}.detection-overlay-badge{position:absolute;top:18px;right:18px;background:#00e6761f;border:1px solid rgba(0,230,118,.4);padding:7px 14px;border-radius:10px;font-size:.78rem;font-weight:600;color:var(--success);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center}.stats-sidebar{display:flex;flex-direction:column;gap:20px}.stat-group{display:flex;flex-direction:column;gap:10px}.stat-group h3{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:2.5px;color:var(--text-muted);margin-bottom:6px;padding-left:2px}.stat-item{background:#ffffff59;padding:18px 22px;border-radius:24px;border:1px solid var(--glass-border);display:flex;flex-direction:column;transition:all .3s cubic-bezier(.19,1,.22,1);box-shadow:0 8px 32px #00000008;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:relative;overflow:hidden}.stat-item:before{content:"";position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);animation:glass-shine 4s infinite linear}@keyframes glass-shine{0%{left:-100%}35%,to{left:200%}}.stat-item:hover{transform:translateY(-4px) scale(1.02);background:#ffffff80;border-color:var(--primary)}.stat-progress-bar{width:100%;height:8px;background:#2d1a0a0f;border-radius:10px;margin-top:14px;overflow:hidden}.stat-progress-fill{height:100%;background:var(--warm-grad);border-radius:inherit;box-shadow:0 0 10px #4ade804d}.stat-item.highlight{background:linear-gradient(135deg,#4ade800d,#ffb34705);border-color:var(--primary);box-shadow:0 4px 20px -4px #4ade801a}.stat-header{display:flex;align-items:center;gap:10px;margin-bottom:14px;color:var(--text-muted)}.stat-header svg{color:var(--acc);opacity:.7}.stat-header span{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:1.5px}.stat-big{font-size:2.2rem;font-weight:800;background:var(--warm-grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1}.stat-item-small{background:#fff;padding:14px 18px;border-radius:14px;border:1px solid var(--glass-border);display:flex;justify-content:space-between;align-items:center;font-size:.85rem;box-shadow:0 2px 8px #00000003}.meta-label{color:var(--text-muted);font-weight:500}.meta-value{color:var(--text);font-weight:600;font-family:Outfit,sans-serif}.action-buttons{display:flex;gap:16px;justify-content:center}.camera-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-white);display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.camera-rig{width:100%;max-width:640px;padding:36px;display:flex;flex-direction:column;gap:28px;margin:0 auto}.viewfinder-hull{width:100%;aspect-ratio:16/9;min-height:320px;background:#000;border-radius:28px;overflow:hidden;position:relative;border:1px solid var(--primary);box-shadow:0 0 80px #4ade801a,0 0 0 1px #4ade800d;transition:all .5s ease}.viewfinder-hull video{width:100%;height:100%;object-fit:cover}.step-title{text-align:center;margin-top:20px;color:var(--text);font-size:1.8rem;font-weight:700}@media (max-width: 768px){.step-title{font-size:1.4rem;margin-top:14px}}@media (max-width: 480px){.step-title{font-size:1.1rem;margin-top:10px}}.scanner-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.scanner-line{position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(to right,transparent,var(--primary),transparent);box-shadow:0 0 12px var(--primary),0 0 30px #4ade804d;animation:scan 3s infinite alternate cubic-bezier(.4,0,.2,1);opacity:.7}@keyframes scan{0%{top:10%}to{top:90%}}.guide-rect{position:absolute;top:45%;left:50%;transform:translate(-50%,-50%);height:50%;aspect-ratio:1;border-radius:16px;z-index:10;border:none;background:transparent}.corner{position:absolute;width:45px;height:45px;border-color:var(--acc);border-style:solid;transition:all .3s ease;border-width:0;opacity:.9}.guide-rect[data-state=good] .corner{border-color:#30d158;filter:drop-shadow(0 0 10px rgba(48,209,88,.6))}.corner.top-left{top:0;left:0;border-top-width:8px;border-left-width:8px;border-top-left-radius:20px}.corner.top-right{top:0;right:0;border-top-width:8px;border-right-width:8px;border-top-right-radius:20px}.corner.bottom-left{bottom:0;left:0;border-bottom-width:8px;border-left-width:8px;border-bottom-left-radius:20px}.corner.bottom-right{bottom:0;right:0;border-bottom-width:8px;border-right-width:8px;border-bottom-right-radius:20px}.guide-rect-outer{position:absolute;top:45%;left:50%;transform:translate(-50%,-50%);height:35%;width:63%;aspect-ratio:1.05;border-radius:24px;z-index:9;border:4px solid rgba(48,209,88,.5);background:transparent;pointer-events:none;transition:all .3s ease}.guide-rect-outer[data-state=good]{border-color:#30d158;filter:drop-shadow(0 0 12px rgba(48,209,88,.4))}.guide-rect-outer .vertical-line{position:absolute;top:25%;bottom:25%;width:2px;background-color:#30d15880;transition:all .3s ease}.guide-rect-outer[data-state=good] .vertical-line{background-color:#30d158;box-shadow:0 0 8px #30d15866}.guide-rect-outer .vertical-line.left{left:calc(45% - 175.5px)}.guide-rect-outer .vertical-line.right{right:calc(45% - 175.5px)}.direction-arrow{position:absolute;top:50%;display:flex;gap:-24px;color:var(--primary);z-index:20}.direction-arrow svg{width:70px;height:70px;opacity:0;filter:drop-shadow(0 0 12px rgba(74,222,128,.8))}.direction-arrow.arrow-right{right:5%;transform:translateY(-50%)}.direction-arrow.arrow-right svg{animation:chevronRight 1.6s infinite}.direction-arrow.arrow-right svg:nth-child(1){animation-delay:0s}.direction-arrow.arrow-right svg:nth-child(2){animation-delay:.15s}.direction-arrow.arrow-right svg:nth-child(3){animation-delay:.3s}.direction-arrow.arrow-left{left:5%;transform:translateY(-50%)}.direction-arrow.arrow-left svg{animation:chevronLeft 1.6s infinite}.direction-arrow.arrow-left svg:nth-child(3){animation-delay:0s}.direction-arrow.arrow-left svg:nth-child(2){animation-delay:.15s}.direction-arrow.arrow-left svg:nth-child(1){animation-delay:.3s}@keyframes chevronRight{0%{opacity:0;transform:translate(-15px)}40%{opacity:1;transform:translate(0)}80%{opacity:0;transform:translate(15px)}to{opacity:0;transform:translate(15px)}}@keyframes chevronLeft{0%{opacity:0;transform:translate(15px)}40%{opacity:1;transform:translate(0)}80%{opacity:0;transform:translate(-15px)}to{opacity:0;transform:translate(-15px)}}.camera-controls{display:flex;gap:16px;justify-content:center}.orientation-hud{position:absolute;bottom:18px;right:18px;display:flex;align-items:center;gap:8px;padding:9px 16px;border-radius:50px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);font-family:Outfit,sans-serif;font-size:.85rem;font-weight:700;z-index:20;transition:background .35s ease,border-color .35s ease,box-shadow .35s ease;border:1px solid transparent;pointer-events:none}.orientation-hud[data-state=detecting]{background:#fff6;border-color:var(--glass-border);color:var(--text-muted)}.orientation-hud[data-state=good]{background:#30d15826;border-color:#30d15866;color:#30d158;box-shadow:0 0 20px #30d15826}.orientation-hud[data-state=warn]{background:#4ade8026;border-color:#4ade8066;color:var(--primary);box-shadow:0 0 20px #4ade8026;animation:warnPulse 1.4s ease-in-out infinite}@keyframes warnPulse{0%,to{box-shadow:0 0 16px #4ade802e,inset 0 0 10px #4ade8012}50%{box-shadow:0 0 28px #4ade8059,inset 0 0 16px #4ade8024}}.orientation-icon{font-size:1.1rem}.orientation-angles{font-size:.72rem;font-weight:600;opacity:.65;margin-left:4px;letter-spacing:.3px}.btn-primary:disabled{background:linear-gradient(135deg,#e2e8f0,#cbd5e1)!important;box-shadow:none!important;cursor:not-allowed;opacity:.8;transform:none!important;color:var(--text-muted)}.loading-hull{height:400px;display:flex;flex-direction:column;align-items:center;justify-content:center}.loading-hull h3{font-size:1.4rem;font-weight:600;color:var(--text)}.loader-pulse{position:relative;width:120px;height:120px;display:flex;align-items:center;justify-content:center;margin-bottom:2rem}.pulse-circle{position:absolute;width:100%;height:100%;border-radius:50%;background:radial-gradient(circle,var(--primary),var(--acc));opacity:.12;animation:pulse 2s infinite ease-out}.pulse-center{background:var(--warm-grad);width:44px;height:44px;border-radius:50%;position:relative;z-index:2;display:flex;align-items:center;justify-content:center;box-shadow:0 0 30px #4ade8066}@keyframes pulse{0%{transform:scale(.5);opacity:.4}to{transform:scale(2.2);opacity:0}}.viewfinder-skeleton{width:100%;height:100%;background:#000;position:absolute;top:0;left:0;z-index:50;overflow:hidden}.skeleton-vf-box{position:absolute;top:55%;left:50%;transform:translate(-50%,-50%);height:52%;aspect-ratio:.65;border-radius:20px;background:linear-gradient(145deg,#4ade800a,#4ade8014);border:1px solid rgba(74,222,128,.18);box-shadow:inset 0 0 30px #00000026,0 15px 30px #00000014;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.skeleton-vf-text-wrap{position:absolute;bottom:12%;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;width:100%}.skeleton-vf-text{border-radius:4px;background:#4ade801a}.skeleton-hud{position:absolute;bottom:18px;right:18px;width:160px;height:48px;border-radius:50px;background:#0006;border:1px solid rgba(74,222,128,.3);z-index:10;display:flex;align-items:center;padding:0 16px;gap:10px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);animation:skeleton-glow 3s infinite ease-in-out}.skeleton-hud-icon{width:24px;height:24px;border-radius:50%;background:#4ade8033}.skeleton-hud-line{flex:1;height:10px;border-radius:5px;background:#4ade8026}.skeleton-title{position:absolute;top:20px;left:50%;transform:translate(-50%);width:200px;height:32px;border-radius:10px;background:#ffffff1f;z-index:10}.skeleton-vf-corners{position:absolute;top:0;left:0;right:0;bottom:0;border:2px solid rgba(74,222,128,.35);border-radius:20px;opacity:.9}.viewfinder-loader{position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;background:#0000004d;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.vf-scan-line{position:absolute;left:0;right:0;top:0;height:2px;background:linear-gradient(90deg,transparent 0%,var(--primary) 20%,var(--acc) 50%,var(--primary) 80%,transparent 100%);box-shadow:0 0 10px #4ade80e6,0 0 28px #4ade8080,0 4px 20px #4ade8033;animation:vf-scan 2s ease-in-out infinite}@keyframes vf-scan{0%{top:0%;opacity:0}8%{opacity:1}92%{opacity:1}to{top:100%;opacity:0}}@keyframes animate-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-spin{animation:animate-spin 1.5s linear infinite}.vf-loader-text{position:absolute;bottom:24px;left:50%;transform:translate(-50%);font-size:.85rem;font-weight:600;letter-spacing:.08em;color:var(--acc);opacity:.8;white-space:nowrap}footer{text-align:center;margin-top:3.5rem;color:#fff3;font-size:.8rem;letter-spacing:2px;text-transform:uppercase}.text-gradient{background:var(--green-grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.hidden{display:none}@media (max-width: 1024px){.result-layout{grid-template-columns:1fr;gap:1.5rem}.pd-value-large{font-size:clamp(3.5rem,12vw,5.5rem)}.operator-image-hull{height:55vh}}@media (max-width: 768px){.app-root{padding:20px 12px;display:block;width:100%}header{margin-bottom:1rem}.logo h1{font-size:clamp(1.4rem,6vw,1.8rem);letter-spacing:-.5px}.image_logo img{height:50px!important;width:50px!important}.subtitle{font-size:.6rem;letter-spacing:1px;white-space:normal;text-align:center;max-width:90%;margin:0 auto}.main-card{padding:.5rem;border-radius:24px;border:none;background:transparent;box-shadow:none}.glass-vibe{padding:8px;border-radius:28px}.viewfinder-hull{aspect-ratio:10/16;height:72vh;min-height:480px;border-radius:24px;box-shadow:0 0 40px #4ade801a}.scanner-overlay h2{font-size:1.2rem!important;margin-top:15px!important}.orientation-hud{bottom:10px;right:10px;padding:5px 10px;font-size:.7rem}.action-buttons{flex-direction:column;gap:12px;width:100%}.action-buttons .btn{width:100%;height:56px}.main-pd-display{padding:1.2rem;border-radius:20px}.pd-value-large{font-size:clamp(3rem,15vw,4.5rem)}.image-preview-hull{height:60vh;min-height:340px}.result-container{gap:1.2rem}.result-btn-download{padding:14px 28px;font-size:1rem;width:100%;justify-content:center}.result-btn-row{width:100%}.result-btn-row .btn{flex:1;justify-content:center}}@media (max-width: 414px){.logo h1{font-size:1.8rem}.pd-value-large{font-size:3.2rem}.viewfinder-hull{height:65vh}.stat-big{font-size:1.5rem}.subtitle{display:none}}.operator-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;padding:12px 18px;background:#0000006b;border:1px solid rgba(74,222,128,.15);border-radius:18px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);gap:12px}.operator-badge{display:flex;align-items:center;gap:10px;color:#4ade80;font-size:.74rem;font-weight:800;letter-spacing:2.5px;text-transform:uppercase}.operator-badge:before{content:"";width:8px;height:8px;border-radius:50%;background:#4ade80;box-shadow:0 0 8px #4ade80,0 0 16px #4ade8066;flex-shrink:0;animation:opDotPulse 1.8s ease-in-out infinite}@keyframes opDotPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.6)}}.live-pd-badge{display:flex;align-items:center;gap:8px;background:#4ade8012;border:1px solid rgba(74,222,128,.22);color:var(--text-muted);padding:8px 20px;border-radius:50px;font-size:.82rem;font-weight:500;white-space:nowrap}.live-pd-badge strong{background:var(--warm-grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-size:1.2rem;font-weight:900;margin-left:4px;filter:drop-shadow(0 0 10px rgba(74,222,128,.4))}.operator-layout{display:flex;flex-direction:row;gap:24px;width:100%;height:auto;min-height:calc(100dvh - 120px);max-width:1450px;margin:0 auto;overflow:visible}@media (max-width: 1024px){.operator-layout{flex-direction:column;height:auto;overflow-y:auto;padding-bottom:40px}}.operator-primary-col{flex:1.3;display:flex;flex-direction:column;gap:16px;overflow:hidden}.operator-sidebar{flex:.7;display:flex;flex-direction:column;height:100%;overflow-y:auto!important;-webkit-overflow-scrolling:touch;padding-right:8px}.view-selector-hull{display:flex;justify-content:center;padding:4px;background:#ffffff0d;border-radius:14px;border:1px solid rgba(255,255,255,.1);width:fit-content;margin:0 auto}.view-selector-inner{display:flex;gap:4px}.view-pill{padding:8px 20px;border-radius:10px;border:none;background:transparent;color:var(--text-muted);font-size:.85rem;font-weight:700;cursor:pointer;transition:all .3s ease}.view-pill.active{background:var(--warm-grad);color:#fff;box-shadow:0 4px 12px #4ade8033}.sidebar-card{background:#ffffff0a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;border:1px solid rgba(255,255,255,.1);padding:24px;display:flex;flex-direction:column;gap:20px;height:100%}.sidebar-title{font-size:1.1rem;font-weight:800;color:#fff;margin:0;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:12px}.metrics-preview{display:flex;flex-direction:column;gap:12px}.metric-row{display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.metric-row span{color:var(--text-muted);font-weight:600}.metric-row strong{font-weight:800}.sidebar-actions-stack{display:flex;flex-direction:column;gap:10px}.btn-sidebar{display:flex;align-items:center;justify-content:center;gap:10px;padding:14px;border-radius:16px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.btn-sidebar:hover{background:#ffffff1f;border-color:var(--primary);transform:translate(4px)}.sidebar-footer{margin-top:auto;padding-top:12px}.generate-final-btn{width:100%;background:linear-gradient(135deg,var(--primary) 0%,#0d9488 100%);color:#fff;border:none;border-radius:16px;padding:16px;font-size:1rem;font-weight:800;cursor:pointer;display:flex!important;align-items:center;justify-content:center;gap:10px;box-shadow:0 10px 30px #14b8a64d;transition:all .3s cubic-bezier(.175,.885,.32,1.275)}.generate-final-btn:hover{transform:translateY(-2px);box-shadow:0 15px 40px #14b8a680;filter:brightness(1.1)}.operator-image-hull{border-radius:32px;overflow:hidden;background:#000;height:65vh;min-height:400px;max-height:850px;width:100%;border-top:1px solid rgba(74,222,128,.3);border-left:1px solid rgba(255,255,255,.15);border-bottom:1px solid rgba(255,255,255,.05);border-right:1px solid rgba(255,255,255,.05);box-shadow:0 30px 60px #0009,0 0 40px #4ade801a,inset 0 1px 1px #ffffff1a;position:relative;transition:height .4s ease}.operator-controls-row{display:flex;justify-content:center;align-items:start}.operator-controls-row .control-section{width:100%;max-width:500px}.operator-overlay-wrap{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#000}.operator-base-img{width:100%;height:100%;object-fit:contain;display:block}.zoom-active-fullscreen .operator-base-img{object-fit:cover!important}.operator-svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;touch-action:none}.control-section{background:linear-gradient(145deg,#ffffff0d,#ffffff03);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid rgba(255,255,255,.2);border-left:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.02);border-right:1px solid rgba(255,255,255,.02);border-radius:24px;padding:24px;height:100%;box-shadow:0 15px 30px #0000004d,inset 0 1px 1px #ffffff1a}.control-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:3px;color:var(--text-muted);margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.05)}.point-row{display:flex;align-items:center;gap:12px;margin-bottom:14px;padding:10px 12px;background:#ffffff05;border-radius:12px;border:1px solid rgba(255,255,255,.04);transition:border-color .2s}.point-row:last-child{margin-bottom:0}.point-row:hover{border-color:#ffffff14}.point-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;box-shadow:0 0 6px currentColor}.point-label{font-size:.88rem;font-weight:700;color:#fffc;width:56px;flex-shrink:0}.coord-inputs{display:flex;gap:8px;flex:1}.coord-inputs label{display:flex;align-items:center;gap:5px;font-size:.75rem;font-weight:600;color:var(--text-muted);flex:1;text-transform:uppercase;letter-spacing:.5px}.coord-input{width:100%;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:6px 8px;color:#fff;font-size:.85rem;font-family:Outfit,sans-serif;font-weight:600;text-align:right;outline:none;transition:all .2s}.coord-input:focus{border-color:#1a6fff80;background:#1a6fff14;box-shadow:0 0 0 2px #1a6fff1a}.coord-input::-webkit-inner-spin-button,.coord-input::-webkit-outer-spin-button{-webkit-appearance:none;-moz-appearance:none;appearance:none}.param-row{margin-bottom:20px}.param-row:last-of-type{margin-bottom:0}.param-label{display:flex;justify-content:space-between;align-items:center;font-size:.82rem;color:var(--text-muted);margin-bottom:10px;font-weight:500}.param-value{color:var(--primary);font-weight:700;font-size:.95rem;background:var(--warm-grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.param-slider{width:100%;height:5px;background:#ffffff14;border-radius:5px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.param-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--warm-grad);cursor:grab;box-shadow:0 0 10px #4ade8080;border:2px solid rgba(255,255,255,.15)}.param-slider::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.15)}.live-stats{margin-top:20px;display:flex;flex-direction:column;gap:10px;padding-top:16px;border-top:1px solid rgba(255,255,255,.06)}.live-stat{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;padding:6px 0}.live-stat span{color:var(--text-muted);font-weight:500}.live-stat strong{color:#ffffffe6;font-weight:700;font-size:.95rem}.live-stat.accent{border-top:1px solid rgba(26,111,255,.15);padding-top:10px;margin-top:4px}.live-stat.accent span{color:#ffffffb3;font-weight:600;font-size:.9rem}.live-stat.accent strong{background:var(--green-grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-size:1.15rem}.operator-actions{display:flex;align-items:center;justify-content:space-between;gap:6px;padding:6px 12px;background:#0000007a;border:1px solid rgba(255,255,255,.06);border-radius:20px;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px)}.operator-actions .btn{padding:10px 18px;font-size:.85rem;min-width:110px;flex:0;border-radius:12px}.btn-reset-op{background:linear-gradient(135deg,#4ade8026,#ff46321a);color:#4ade80;border:1.5px solid rgba(74,222,128,.42);position:relative;overflow:hidden;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.btn-reset-op:before{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:inherit;background:conic-gradient(from 0deg,transparent 40%,rgba(74,222,128,.5) 58%,transparent 70%);animation:resetRingSpin 3s linear infinite paused;opacity:0;transition:opacity .3s ease;pointer-events:none}.btn-reset-op:after{content:"";position:absolute;top:2px;right:2px;bottom:2px;left:2px;border-radius:12px;background:linear-gradient(135deg,rgba(74,222,128,.07),transparent);pointer-events:none}.btn-reset-op:hover{background:linear-gradient(135deg,#4ade8047,#ff46322e);border-color:#4ade80b8;color:#34eb7a;box-shadow:0 0 20px #4ade8047,0 8px 24px -4px #ff463238,inset 0 1px #ffc85026;transform:translateY(-2px)}.btn-reset-op:hover:before{animation-play-state:running;opacity:1}.btn-reset-op:active{transform:scale(.97) translateY(0)}@keyframes resetRingSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.btn-cancel-op{background:#ff3c3c0f;color:#ffffff8c;border:1px solid rgba(255,255,255,.08);transition:all .22s ease}.btn-cancel-op:hover{background:#ff3c3c24;border-color:#ff3c3c66;color:#ff7070;transform:translateY(-1px)}.operator-actions .btn-primary{margin-left:auto;box-shadow:0 6px 22px -4px #4ade8085}.operator-actions .btn-primary:hover{box-shadow:0 10px 30px -4px #4ade80b3;transform:translateY(-2px)}@media (max-width: 900px){.operator-image-hull{height:55vh;min-height:320px}.operator-controls-row{grid-template-columns:1fr}.operator-actions{flex-wrap:wrap;justify-content:center}.operator-actions .btn{flex:1;min-width:0}.operator-actions .btn-primary{margin-left:0}}@media (max-width: 480px){.operator-header{padding:10px 12px;gap:8px}.operator-badge{font-size:.65rem;letter-spacing:1.5px}.live-pd-badge{padding:6px 12px;font-size:.75rem;width:100%;justify-content:center}.operator-image-hull{height:50vh;min-height:250px}.operator-actions{padding:10px;gap:8px}.operator-actions .btn{padding:10px 14px;font-size:.82rem}.zoom-point-selector{gap:8px}.zoom-pt-btn{padding:8px 16px;font-size:.85rem;border-radius:12px}}.side-metrics-group{margin-top:24px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1)}.side-metrics-group h3{font-size:.8rem;letter-spacing:2px;color:var(--acc);margin-bottom:16px;text-transform:uppercase;font-weight:700}.side-metric-pair{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.side-metric-card{background:#ffffff08;padding:12px;border-radius:12px;border:1px solid rgba(255,255,255,.05)}.side-label{display:block;font-size:.7rem;color:var(--text-muted);margin-bottom:6px;font-weight:600}.side-val{font-size:.8rem;color:#fff;margin-bottom:4px}.side-val span{font-weight:700;color:var(--acc)}.side-previews{display:flex;gap:12px}.side-thumb{flex:1;max-width:140px;border-radius:10px;overflow:hidden;position:relative;border:1px solid rgba(255,255,255,.08);padding:4px;background:#ffffff05}.side-thumb img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:6px}.side-thumb span{display:block;text-align:center;font-size:.65rem;margin-top:6px;color:var(--text-muted);font-weight:600}.zoom-banner{position:absolute;bottom:14px;left:50%;transform:translate(-50%);background:#13bd2c80;border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border-radius:14px;padding:10px 18px;display:flex;align-items:center;gap:14px;font-size:.85rem;color:#34eb7a;white-space:nowrap;z-index:20;box-shadow:0 10px 30px #0000001a}.zoom-banner strong{color:var(--primary)}.zoom-exit-btn{background:var(--warm-grad);border:none;color:#fff;padding:6px 14px;border-radius:8px;font-size:.78rem;font-weight:700;cursor:pointer;transition:all .2s ease}.zoom-exit-btn:hover{filter:brightness(1.1)}.zoom-portal-overlay{position:fixed!important;top:0!important;right:0!important;bottom:0!important;left:0!important;width:100dvw!important;height:100dvh!important;z-index:100000!important;background:#000;touch-action:none!important;display:flex;align-items:center;justify-content:center}.zoom-portal-overlay .operator-image-hull.zoom-active-fullscreen{position:relative!important;width:100%!important;height:100%!important;min-height:100%!important;max-width:none!important;max-height:none!important;background:#000!important;z-index:99!important;border-radius:0!important;border:none!important;margin:0!important}.zoom-active .main-card.glass,.zoom-active .motion-editing-wrap,.zoom-active .app-container,.zoom-active .operator-primary-col,.zoom-active .operator-layout,.zoom-active .operator-image-hull:not(.zoom-active-fullscreen){backdrop-filter:none!important;-webkit-backdrop-filter:none!important;transform:none!important;filter:none!important;perspective:none!important;contain:none!important;will-change:auto!important;clip-path:none!important;animation:none!important;transition:none!important;overflow:visible!important}body.zoom-active-lock{overflow:hidden!important;position:fixed;width:100%}.zoom-active-fullscreen .zoom-banner{position:absolute!important;bottom:0!important;left:0!important;right:0!important;transform:none!important;width:100%!important;padding:24px!important;border-radius:32px 32px 0 0!important;font-size:1.1rem!important;box-shadow:0 -10px 40px #00000080!important;background:#13bd2cf2!important;-webkit-backdrop-filter:blur(20px)!important;backdrop-filter:blur(20px)!important;display:flex!important;align-items:center!important;justify-content:space-between!important;border:none!important;z-index:100001!important;cursor:default!important}.capture-missing-msg{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(circle at center,#10b9810d,#0006);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);color:#fff;gap:20px;text-align:center;padding:40px;z-index:10;border-radius:inherit;overflow:hidden}.capture-missing-msg:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#ffffff1a,#ffffff05);opacity:.1;pointer-events:none}.capture-missing-msg svg{color:#10b981;opacity:.8!important;filter:drop-shadow(0 0 15px rgba(16,185,129,.4));animation:pulse-gentle 3s ease-in-out infinite}.capture-missing-msg h3{font-size:1.4rem;font-weight:800;background:linear-gradient(to bottom,#fff,#fff9);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin:0;letter-spacing:-.02em}.capture-missing-msg p{font-size:.95rem;max-width:240px;line-height:1.6;opacity:.5;color:#fff;margin:0}@keyframes pulse-gentle{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.05);opacity:1}}@media (max-width: 600px){.zoom-active-fullscreen .zoom-banner{padding:16px 20px!important;flex-wrap:nowrap!important;gap:12px!important}}.zoom-active-fullscreen .zoom-exit-btn{font-size:1.15rem!important;padding:14px 28px!important;border-radius:12px!important}.zoom-point-selector{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:10px 4px;animation:fadeInDown .3s ease}.zoom-point-selector>span{font-size:.78rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:1.5px}.zoom-pt-btn{background:#ffffff0a;border:1.5px solid;border-radius:10px;padding:5px 14px;font-size:.82rem;font-weight:700;cursor:pointer;transition:all .2s ease;font-family:Outfit,sans-serif}.zoom-pt-btn:hover{background:#ffffff1a;transform:translateY(-1px)}.zoom-pt-btn.active{background:#ffffff1f;box-shadow:0 0 12px #ffffff1a}@keyframes svgPulse{0%{transform:scale(.9);opacity:.4}50%{transform:scale(1.15);opacity:.25}to{transform:scale(.9);opacity:.4}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.guidance-text[data-state=good]{color:#1b5e20;background:#fffc}.guidance-text[data-state=warn]{color:var(--acc)}.bottom-controls{position:absolute;bottom:0;left:0;width:100%;padding:0 16px 16px;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:9999;pointer-events:none}.bottom-controls .distance-meter-hull{pointer-events:auto}@media (max-width: 932px) and (orientation: landscape){.bottom-controls{bottom:6px;padding-bottom:6px;gap:4px}}.capture-session-layout{display:flex;gap:32px;align-items:center;width:100%}@media (max-width: 1000px){.capture-session-layout{flex-direction:column;gap:24px}}.capture-sidebar{flex-shrink:0;display:flex;flex-direction:column;justify-content:center;min-width:320px}@media (max-width: 768px){.capture-sidebar{min-width:unset;width:100%;padding:0 16px}}.capture-actions{display:flex;flex-direction:column;gap:20px;align-items:center;pointer-events:auto}.btn-capture-manual{position:relative;background:var(--warm-grad);color:#fff;border:none;padding:14px 28px;border-radius:50px;font-weight:700;display:flex;align-items:center;gap:10px;cursor:pointer;pointer-events:auto;box-shadow:0 10px 25px #4ade8066,0 0 0 5px #ffffff1a;z-index:100;transition:all .3s cubic-bezier(.175,.885,.32,1.275);font-size:.9rem;letter-spacing:.5px;text-transform:uppercase;pointer-events:all}.btn-capture-manual:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 15px 35px #4ade8099,0 0 0 8px #ffffff26;filter:brightness(1.1)}.btn-capture-manual:active{transform:scale(.95)}.btn-capture-manual svg{animation:pulse-camera 2s infinite}@keyframes pulse-camera{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.btn-flip-camera{display:flex;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;width:50px;height:50px;border-radius:50%;align-items:center;justify-content:center;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;pointer-events:auto}@media (max-width: 1400px){.btn-flip-camera{display:flex}}.btn-flip-camera:hover{background:#fff3;transform:rotate(45deg)}.btn-flip-camera:active{transform:scale(.9)}@media (max-width: 768px){.btn-capture-manual{padding:8px 18px;font-size:.75rem}.guidance-text{font-size:.8rem;padding:6px 12px;letter-spacing:.5px;width:90%;white-space:normal}}.guidance-text{position:relative;font-size:1rem;color:#fff;z-index:80;text-align:center;white-space:nowrap;pointer-events:none;padding:8px 16px;background:#0009;border-radius:12px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);box-shadow:0 10px 30px #0000004d;text-transform:uppercase;font-weight:700;letter-spacing:1.2px}.capture-heading{text-align:center;margin-top:16px;color:#fff;font-size:1.4rem;font-weight:800;text-transform:uppercase;letter-spacing:1px}@media (max-width: 768px){.capture-heading{font-size:1.1rem;margin-top:12px}}.step-badge{display:inline-block;padding:6px 14px;background:#4ade8026!important;color:#34eb7a!important;border:1px solid rgba(74,222,128,.3)!important;border-radius:50px;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;margin:12px auto;width:fit-content}@media (max-width: 480px){.step-badge{font-size:.65rem;padding:4px 10px}}.start-screen-hull{max-width:500px;margin:0 auto;width:100%;max-height:100%;overflow-y:auto!important;-webkit-overflow-scrolling:touch}.welcome-vibe{display:flex;flex-direction:column;align-items:center;text-align:center;padding:48px!important}.icon-badge{width:80px;height:80px;background:#ffd60a1a;border-radius:24px;display:flex;align-items:center;justify-content:center;margin-bottom:24px;border:1px solid rgba(255,214,10,.2);box-shadow:0 8px 32px #0000004d}.title-grad{font-size:2.6rem;font-weight:900;margin-bottom:14px;background:linear-gradient(135deg,#fff,#34eb7a);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 4px 15px rgba(52,235,122,.15));letter-spacing:-1px}.subtitle{font-size:.8rem;font-weight:700;color:#ffffff80;text-transform:uppercase;letter-spacing:3px;max-width:320px;line-height:1.5}.actual-pd-input-group{width:100%;margin-top:40px;display:flex;flex-direction:column;gap:14px}.actual-pd-input-group label{font-size:.75rem;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:2px;text-align:left;padding-left:4px}.input-wrap{position:relative;width:100%}.actual-pd-input-group input{width:100%;background:#0000004d!important;border:1.5px solid rgba(255,255,255,.1);border-radius:20px;padding:22px 22px 22px 60px;font-size:2rem;font-weight:900;color:#fff;outline:none;transition:all .4s cubic-bezier(.19,1,.22,1);box-shadow:inset 0 2px 4px #0000004d;text-shadow:0 0 15px rgba(52,235,122,.2)}.actual-pd-input-group input::placeholder{color:#ffffff26;font-size:1.2rem;font-weight:600;letter-spacing:1px}.actual-pd-input-group input:focus{border-color:#34eb7a;background:#00000080!important;box-shadow:0 0 0 4px #34eb7a1a,0 0 25px #34eb7a33;transform:scale(1.02)}.input-icon{position:absolute;left:24px;top:50%;transform:translateY(-50%);color:#34eb7a;filter:drop-shadow(0 0 8px rgba(52,235,122,.5))}.start-btn{margin-top:24px;height:72px;font-size:1.25rem!important;font-weight:800!important;border-radius:22px!important;text-transform:uppercase;letter-spacing:1.5px;box-shadow:0 15px 35px #34eb7a59;transition:all .3s cubic-bezier(.175,.885,.32,1.275)!important}.start-btn:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 20px 45px #34eb7a73}.info-tray{margin-top:40px;display:flex;justify-content:center}.info-item{display:flex;align-items:center;gap:10px;color:#fff6;font-size:.85rem;background:#ffffff08;padding:10px 20px;border-radius:14px;border:1px solid rgba(255,255,255,.05)}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;margin:0}input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.start-error-msg{margin-top:20px;color:#ff4d4d;font-size:.85rem;font-weight:700;background:#ff4d4d1a;padding:14px 20px;border-radius:16px;display:flex;align-items:center;gap:12px;border:1px solid rgba(255,77,77,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:startErrorShake .4s cubic-bezier(.36,.07,.19,.97) both}@keyframes startErrorShake{10%,90%{transform:translate3d(-1px,0,0)}20%,80%{transform:translate3d(2px,0,0)}30%,50%,70%{transform:translate3d(-4px,0,0)}40%,60%{transform:translate3d(4px,0,0)}}.toast-container{position:fixed;top:24px;left:50%;transform:translate(-50%);z-index:10000;pointer-events:none;width:100%;max-width:420px;padding:0 20px}.toast-vibe{background:#141414cc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.15);border-radius:18px;padding:16px 20px;display:flex;align-items:center;gap:14px;color:#fff;box-shadow:0 15px 35px #0006;pointer-events:all}.toast-icon-wrap{width:32px;height:32px;background:#ff4d4d26;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.toast-content{flex:1}.toast-title{font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:#ff4d4d;margin-bottom:2px}.toast-msg{font-size:.9rem;font-weight:600;color:#ffffffe6;line-height:1.4}@media (max-width: 992px){.app-container{max-width:100%;padding:0 10px}}@media (max-width: 768px){.header-corner{top:15px;left:15px}.logo h1{font-size:1.6rem!important}.image_logo img{width:42px!important;height:42px!important}.main-card{padding:1rem!important;border-radius:24px!important}.operator-image-hull{height:60vh!important;min-height:480px!important;border-radius:24px!important}.viewfinder-hull{border-radius:18px!important}.btn{padding:12px 20px!important;font-size:.9rem!important}}@media (max-width: 480px){.header-corner{top:10px;left:10px}.logo h1{font-size:1.3rem!important}.image_logo img{width:32px!important;height:32px!important}.welcome-vibe{padding:24px!important}.title-grad{font-size:2.2rem!important}.actual-pd-input-group input{padding:16px 16px 16px 50px!important;font-size:1.8rem!important}.operator-actions{flex-direction:row!important;gap:8px!important}.operator-actions .btn{width:auto!important;flex:1}}@media (orientation: landscape){.header-corner{top:10px!important;left:10px!important;transform:scale(.75);transform-origin:top left;z-index:100}.main-card{height:96vh;display:flex;flex-direction:column;padding:8px!important}.operator-layout,.capture-session-layout,.review-session-layout{flex-direction:row!important;grid-template-columns:1.3fr .7fr!important;gap:20px!important;height:100%!important}.operator-primary-col,.glass-vibe-inner{height:100%!important;flex:1!important}.operator-image-hull,.viewfinder-hull{height:100%!important;max-height:none!important}.operator-sidebar,.capture-sidebar,.review-sidebar{width:280px!important;flex-shrink:0!important;height:100%!important;overflow-y:auto!important;padding-right:4px}.main-card{height:96vh;padding:10px!important}.capture-session-layout{grid-template-columns:1.4fr .6fr!important;gap:12px!important}.capture-sidebar{width:220px!important;padding:0 10px!important}.btn-capture-manual{padding:12px!important;font-size:.85rem!important}.title-grad{font-size:1.4rem!important}}.orientation-guard-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999999;background:#000;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px;color:#fff;overflow-y:auto}.orientation-guard-icon{width:100px;height:100px;background:#10b9811a;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:28px;flex-shrink:0;border:1.5px solid rgba(16,185,129,.3);box-shadow:0 0 50px #10b9811a}.orientation-guard-icon svg{color:#10b981;animation:rotate-device 3s infinite ease-in-out}@keyframes rotate-device{0%{transform:rotate(0)}25%{transform:rotate(90deg)}75%{transform:rotate(90deg)}to{transform:rotate(0)}}.orientation-guard-overlay h2{font-size:clamp(1.4rem,5vw,2rem);font-weight:800;margin-bottom:12px;background:linear-gradient(to right,#fff,#fff9);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.orientation-guard-overlay p{opacity:.6;max-width:300px;line-height:1.6;font-size:clamp(.9rem,3vw,1.1rem)}.distance-meter-hull{margin:10px 0;padding:16px 24px;background:#0f172a99!important;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:24px!important;box-shadow:0 12px 40px #0000004d;width:100%}@media (max-width: 932px) and (orientation: landscape){.distance-meter-hull{padding:8px 12px;margin:5px 0;transform:scale(.85);background:#0f172acc!important}.meter-track{margin:18px 0 8px}.meter-status-txt{font-size:.75rem;margin-top:8px}.meter-labels{font-size:.55rem;margin-bottom:-10px}}.meter-track{position:relative;height:6px;background:#ffffff14;border-radius:10px;margin:24px 0 12px}.meter-zone-perfect{position:absolute;top:50%;left:35%;width:30%;height:14px;transform:translateY(-50%);background:#34eb7a26;border:1px solid rgba(52,235,122,.6);border-radius:4px;z-index:1;box-shadow:0 0 15px #34eb7a33}.meter-pointer{position:absolute;top:50%;width:4px;height:24px;background:#fff;border-radius:2px;transform:translate(-50%,-50%);z-index:5;transition:left .4s cubic-bezier(.2,0,0,1);box-shadow:0 0 12px #fffc,0 0 25px #ffffff4d}.meter-pointer.is-perfect{background:#34eb7a;box-shadow:0 0 20px #34eb7a;height:30px}.meter-labels{display:flex;justify-content:space-between;margin-bottom:-15px;font-size:.65rem;font-weight:800;letter-spacing:1px;color:#fff6;text-transform:uppercase}.meter-status-txt{text-align:center;margin-top:10px;font-size:.85rem;font-weight:900;letter-spacing:.5px;text-transform:uppercase;min-height:1.2em;white-space:nowrap}.review-card{width:100%;max-width:820px;margin:0 auto;background:#ffffff08;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:28px;border:1px solid rgba(255,255,255,.1);overflow:visible}.review-session-layout{display:flex;gap:32px;align-items:center;width:100%;padding:32px}@media (max-width: 1000px){.review-session-layout{flex-direction:column-reverse;gap:24px}}.review-inner-scroller{width:100%;height:100%;display:flex;flex-direction:column;padding:24px;gap:20px;overflow-y:auto!important;align-items:center;-webkit-overflow-scrolling:touch}@media (max-height: 450px){.review-inner-scroller{padding:12px;gap:12px}}.review-sidebar{flex-shrink:0;display:flex;flex-direction:column;justify-content:center;gap:16px;width:200px}.operator-layout-scroller{flex:1;width:100%;display:flex;flex-direction:column;padding:24px;gap:24px;overflow-y:auto!important;height:100%;scrollbar-width:thin;scrollbar-color:var(--primary) transparent}@media (max-width: 1000px){.operator-layout-scroller{height:auto;overflow-y:visible}}@media (min-width: 1024px){.operator-layout-scroller{padding:20px;overflow:visible}.review-card{overflow:visible}}.review-card::-webkit-scrollbar,.operator-layout-scroller::-webkit-scrollbar{width:6px}.review-card::-webkit-scrollbar-track,.operator-layout-scroller::-webkit-scrollbar-track{background:#ffffff0d}.review-card::-webkit-scrollbar-thumb,.operator-layout-scroller::-webkit-scrollbar-thumb{background:var(--primary);border-radius:10px}@media (max-width: 768px){.review-card{border-radius:20px;overflow:visible}.operator-layout-scroller{padding:10px;gap:12px;overflow:visible}}.capture-session-layout.tri-panel,.review-session-layout.tri-panel{display:flex!important;flex-direction:row!important;justify-content:space-between;align-items:stretch;width:100vw!important;height:100vh!important;position:fixed;top:0;right:0;bottom:0;left:0;z-index:99999;background:#000;overflow:hidden}.capture-side-panel{width:80px;flex:0 0 80px;display:flex;flex-direction:column;justify-content:center;align-items:center;background:#0f172afa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid rgba(255,255,255,.1);padding:20px 0;z-index:10}.capture-side-panel.right{width:130px;flex:0 0 130px;border-right:none;border-left:2px solid var(--primary);background:linear-gradient(to bottom,#0d94881a,#0f172a)}.viewfinder-main{flex:1!important;height:100%;position:relative;background:#000;display:flex;justify-content:center;align-items:center;min-width:0}.viewfinder-container{width:100%;height:100%;position:relative;overflow:visible}.panel-inner{display:flex;flex-direction:column;gap:24px;width:100%;align-items:center}.panel-group{display:flex;flex-direction:column;align-items:center;gap:6px;width:100%}.panel-label{font-size:.55rem;font-weight:800;color:var(--primary);letter-spacing:1px;text-transform:uppercase;opacity:.7}.panel-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:10px;width:60px;height:60px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;cursor:pointer;transition:all .2s ease}.panel-btn span{font-size:.5rem;font-weight:800;margin-top:4px}.btn-capture-professional{background:none;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:8px}.capture-icon-ring{width:80px;height:80px;background:#fff;border:8px solid rgba(22,163,74,.4);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--primary);box-shadow:0 0 30px #00000080,inset 0 0 10px #0003;position:relative}.capture-icon-ring:before{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border:2px solid rgba(0,0,0,.1);border-radius:50%}.capture-btn-label{font-size:.7rem;font-weight:900;color:#fff;text-transform:uppercase}@media (max-width: 932px) and (orientation: landscape){.capture-session-layout.tri-panel,.review-session-layout.tri-panel{height:100vh;border-radius:0}.capture-side-panel{width:70px;flex:0 0 70px}.capture-side-panel.right{width:90px;flex:0 0 90px}.panel-btn{width:50px;height:50px;padding:4px}.capture-icon-ring{width:50px;height:50px;border-width:2px}.capture-icon-ring svg{width:22px;height:22px}.capture-btn-label{font-size:.55rem;width:80px}.panel-inner{gap:10px}}@media (orientation: portrait){body{padding:0!important;align-items:flex-start}.app-root{flex-direction:column!important;justify-content:flex-start!important;align-items:stretch!important;padding:0!important;min-height:100dvh;overflow-y:auto!important;overflow-x:hidden!important}.header-corner,.app-root.phase-editing .header-corner{position:relative!important;top:auto!important;left:auto!important;padding:20px 20px 10px!important;transform:none!important;text-align:left!important;z-index:100;width:100%;box-sizing:border-box}.header-corner .logo,.app-root.phase-editing .header-corner .logo{justify-content:flex-start!important}.app-container{padding:0 12px 60px!important;max-width:100%!important;width:100%!important}.main-card{max-height:none!important;height:auto!important;overflow-y:visible!important;overflow-x:hidden!important;padding:12px!important;background:transparent!important;box-shadow:none!important;border:none!important;border-radius:0!important}.operator-layout{flex-direction:column!important;height:auto!important;overflow:visible!important;padding-bottom:40px;gap:16px!important}.operator-primary-col{overflow:visible!important;height:auto!important;flex:none!important;width:100%!important}.operator-sidebar{width:100%!important;height:auto!important;overflow-y:visible!important;flex:none!important;padding-right:0!important}.sidebar-card{height:auto!important}.glass-vibe-inner{overflow:visible!important;height:auto!important;flex:none!important}.capture-session-layout{flex-direction:column!important;overflow-y:visible!important;align-items:stretch!important;padding:0!important;gap:20px!important}.capture-sidebar{min-width:unset!important;width:100%!important}.review-session-layout{flex-direction:column!important;overflow-y:visible!important;padding:12px!important;gap:16px!important}.review-sidebar{width:100%!important;flex-shrink:1!important}.operator-image-hull{height:auto!important;min-height:220px!important;max-height:55vh!important}.image-preview-hull{height:auto!important;max-height:55vh!important;min-height:220px!important}.start-screen-hull{max-width:100%!important;padding:0 4px}.action-buttons{flex-direction:column!important;width:100%!important}.action-buttons .btn{width:100%!important}}@media (orientation: portrait){.capture-session-layout.tri-panel,.review-session-layout.tri-panel{flex-direction:column!important}.capture-side-panel{width:100%!important;flex:0 0 64px!important;flex-direction:row!important;justify-content:space-around!important;border-right:none!important;border-bottom:1px solid rgba(255,255,255,.1);padding:0 16px!important}.capture-side-panel.right{width:100%!important;flex:0 0 72px!important;flex-direction:row!important;justify-content:space-around!important;border-left:none!important;border-top:2px solid var(--primary)}.viewfinder-main{flex:1!important;width:100%!important;height:auto!important}.panel-inner{flex-direction:row!important;gap:12px!important}}@media (orientation: portrait) and (max-width: 480px){.viewfinder-hull{height:56vw!important;min-height:220px!important;aspect-ratio:unset!important}.glass-vibe{padding:8px!important;border-radius:24px!important}.logo h1{font-size:1.4rem!important}.image_logo img{width:44px!important;height:44px!important}}@media (orientation: portrait) and (min-width: 481px) and (max-width: 1024px){.viewfinder-hull{height:auto!important;aspect-ratio:4/3!important;min-height:300px!important;max-height:60vh!important}.app-container{padding:0 24px 60px!important}.main-card{padding:16px!important}}@media (orientation: portrait) and (min-width: 1025px){.viewfinder-hull{height:auto!important;aspect-ratio:16/9!important;max-height:55vh!important}.app-container{padding:0 40px 60px!important;max-width:900px!important}}@media (max-width: 1000px){.review-sidebar{width:100%!important}}html,body{overscroll-behavior-y:contain}.distance-meter-side{display:flex;flex-direction:row;align-items:center;gap:6px;width:100%;justify-content:center;padding:8px 0}.dms-bar{position:relative;width:8px;height:120px;background:#ffffff1a;border-radius:10px;overflow:visible;flex-shrink:0}.dms-zone-perfect{position:absolute;left:50%;top:30%;height:30%;width:100%;transform:translate(-50%);background:#34eb7a40;border:1px solid rgba(52,235,122,.6);border-radius:4px}.dms-pointer{position:absolute;left:50%;width:18px;height:6px;border-radius:3px;transform:translate(-50%,-50%);box-shadow:0 0 8px currentColor;transition:top .4s cubic-bezier(.2,0,0,1);z-index:5}.dms-labels{display:flex;flex-direction:column;justify-content:space-between;height:120px;font-size:.45rem;font-weight:800;color:#ffffff80;letter-spacing:.5px;text-transform:uppercase}.dms-status{font-size:.55rem;font-weight:900;text-align:center;letter-spacing:.5px;writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);max-height:80px;overflow:hidden}.capture-action-box{display:flex;flex-direction:column;align-items:center;gap:10px}.fullscreen-camera-shell{position:fixed;top:0;right:0;bottom:0;left:0;width:100dvw;height:100dvh;background:#000;z-index:99999;overflow:hidden;display:flex;align-items:center;justify-content:center}.fullscreen-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.fsc-ar-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:10}.fsc-step-badge{position:absolute;top:18px;left:50%;transform:translate(-50%);background:#0000008c;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.18);border-radius:50px;padding:7px 20px;font-size:.72rem;font-weight:800;color:#fff;text-transform:uppercase;letter-spacing:1.5px;white-space:nowrap;box-shadow:0 4px 20px #0006}.fsc-guide{display:none}.fsc-corner-wrap{position:absolute;top:48%;left:50%;transform:translate(-50%,-50%);height:50%;width:55%;pointer-events:none}.fsc-corner-wrap .corner{border-color:var(--acc)}.fsc-guidance-wrap{position:absolute;bottom:15px;left:50%;transform:translate(-50%);display:flex;justify-content:center;pointer-events:none}.fsc-left-hud{position:absolute;left:0;top:0;bottom:0;width:90px;display:flex;align-items:center;justify-content:center;z-index:20;background:#00000073;backdrop-filter:blur(24px) saturate(160%);-webkit-backdrop-filter:blur(24px) saturate(160%);border-right:1px solid rgba(255,255,255,.08);pointer-events:none}.fsc-hud-btn-group{display:flex;flex-direction:column;gap:18px;align-items:center;pointer-events:auto}.fsc-hud-btn{display:flex;flex-direction:column;align-items:center;gap:5px;background:#ffffff08;border:1.5px solid rgba(255,255,255,.1);border-radius:16px;padding:12px 10px 8px;width:64px;color:#fff;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1)}.fsc-hud-btn span{font-size:.5rem;font-weight:900;letter-spacing:1px;text-transform:uppercase;opacity:.65}.fsc-hud-btn:hover{background:#ffffff1a;border-color:#ffffff4d;transform:translateY(-2px);box-shadow:0 8px 20px #0000004d}.fsc-hud-btn:active{transform:scale(.94)}.fsc-right-hud{position:absolute;right:0;top:0;bottom:0;width:110px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;z-index:20;background:#00000073;backdrop-filter:blur(24px) saturate(160%);-webkit-backdrop-filter:blur(24px) saturate(160%);border-left:1px solid rgba(255,255,255,.08);padding:20px 0;pointer-events:auto}.fsc-distance-meter-horizontal{display:flex;align-items:center;gap:12px;background:#00000073;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:8px 20px;border-radius:100px;border:1px solid rgba(255,255,255,.12);box-shadow:0 10px 40px #00000080;pointer-events:auto}@media (max-width: 900px) and (orientation: landscape){.fsc-distance-meter-horizontal{padding:4px 12px;gap:6px;transform:scale(.75);background:#0009}.fsc-guidance-wrap{bottom:5px}.fsc-dm-h-bar{width:140px;height:4px}.fsc-dm-h-label{font-size:.55rem}.fsc-dm-h-status{font-size:.8rem}}.fsc-dm-h-label{font-size:.65rem;font-weight:900;color:#ffffff80;text-transform:uppercase;letter-spacing:1.5px}.fsc-dm-h-bar{position:relative;width:200px;height:6px;background:#ffffff1a;border-radius:10px}.fsc-dm-h-zone-perfect{position:absolute;top:50%;left:31%;width:39%;height:100%;transform:translateY(-50%);background:#34eb7a33;border:1px solid rgba(52,235,122,.5);border-radius:4px}.fsc-dm-h-pointer{position:absolute;top:50%;width:6px;height:18px;border-radius:3px;transform:translate(-50%,-50%);transition:left .4s cubic-bezier(.2,0,0,1);z-index:5}.fsc-dm-h-status{font-size:1.1rem;font-weight:900;width:24px;text-align:center}.fsc-distance-meter{display:flex;flex-direction:column;align-items:center;gap:6px}.fsc-dm-label-top,.fsc-dm-label-bot{font-size:.48rem;font-weight:900;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px}.fsc-dm-bar{position:relative;width:6px;height:100px;background:#ffffff1a;border-radius:10px;overflow:visible}.fsc-dm-zone-perfect{position:absolute;left:50%;top:28%;height:32%;width:100%;transform:translate(-50%);background:#34eb7a40;border:1px solid rgba(52,235,122,.6);border-radius:4px;box-shadow:0 0 10px #34eb7a33}.fsc-dm-pointer{position:absolute;left:50%;width:16px;height:5px;border-radius:3px;transform:translate(-50%,-50%);transition:top .4s cubic-bezier(.2,0,0,1);z-index:5}.fsc-dm-status{font-size:1rem;font-weight:900;text-align:center;line-height:1}.fsc-capture-btn{background:#ffffff0d;border:1.5px solid rgba(255,255,255,.15);border-radius:24px;padding:16px 12px 12px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:8px;transition:all .2s cubic-bezier(.4,0,.2,1)}.fsc-capture-btn:active{transform:scale(.92);background:#000000b3}.fsc-capture-btn:hover{background:#ffffff1f;border-color:#fff6;transform:translateY(-4px);box-shadow:0 12px 30px #0006}.fsc-capture-ring{width:68px;height:68px;background:#fff;border:6px solid rgba(22,163,74,.5);border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;box-shadow:0 0 0 3px #ffffff26,0 8px 24px #00000080,0 0 30px #4ade8026;transition:all .2s ease}.fsc-capture-ring:before{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border:2px solid rgba(0,0,0,.08);border-radius:50%}.fsc-capture-btn:hover .fsc-capture-ring{box-shadow:0 0 0 5px #ffffff40,0 10px 32px #0009,0 0 50px #4ade8059;border-color:#4ade80cc;transform:scale(1.04)}.fsc-capture-label{font-size:.5rem;font-weight:900;color:#ffffffa6;text-transform:uppercase;letter-spacing:1px}.fsc-skip-btn{background:#ffffff14;border:1.5px solid rgba(255,255,255,.15);color:#fffc;border-radius:24px;padding:8px 18px;font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:all .2s ease}.fsc-skip-btn:hover{background:#000000b3;border-color:#fff3;color:#fff}@media (orientation: portrait){.fsc-left-hud{top:auto;bottom:0;left:0;right:0;width:100%;height:84px;flex-direction:row;background:#0009;backdrop-filter:blur(24px) saturate(160%);-webkit-backdrop-filter:blur(24px) saturate(160%);border-top:1px solid rgba(255,255,255,.1);justify-content:flex-start;padding:0 24px;gap:16px}.fsc-hud-btn-group{flex-direction:row;gap:12px}.fsc-right-hud{top:0;right:0;left:0;bottom:auto;width:100%;height:auto;flex-direction:row;justify-content:flex-end;background:#00000073;backdrop-filter:blur(24px) saturate(160%);-webkit-backdrop-filter:blur(24px) saturate(160%);border-bottom:1px solid rgba(255,255,255,.08);padding:16px 20px 32px;gap:16px}.fsc-distance-meter{flex-direction:row;align-items:center;gap:6px}.fsc-dm-label-top{order:1}.fsc-dm-bar{order:2;width:80px;height:6px}.fsc-dm-zone-perfect{top:50%;left:28%;width:32%;height:100%;transform:translateY(-50%)}.fsc-dm-pointer{top:50%;height:16px;width:5px;transform:translate(-50%,-50%);transition:left .4s cubic-bezier(.2,0,0,1);left:attr(style)}.fsc-dm-label-bot{order:3}.fsc-dm-status{font-size:.75rem;order:4}.fsc-guidance-wrap{bottom:90px}.fsc-step-badge{top:14px}}@media (orientation: landscape) and (max-height: 500px){.fsc-left-hud{width:64px}.fsc-hud-btn{width:50px;padding:8px 6px 6px;border-radius:10px}.fsc-right-hud{width:76px;gap:12px}.fsc-capture-ring{width:56px;height:56px;border-width:5px}.fsc-dm-bar{height:70px}.fsc-step-badge{font-size:.6rem;padding:5px 14px;top:10px}.fsc-guidance-wrap{bottom:80px}}.loading-portal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);z-index:10000;display:flex;align-items:center;justify-content:center;padding:24px}.loading-card{width:100%;max-width:420px;padding:40px!important;display:flex!important;flex-direction:column!important;align-items:center!important;text-align:center!important;gap:24px!important}.loading-spinner-wrap{position:relative;display:flex;align-items:center;justify-content:center}.animate-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner-glow{position:absolute;top:-15px;right:-15px;bottom:-15px;left:-15px;background:radial-gradient(circle,rgba(52,235,122,.2) 0%,transparent 70%);filter:blur(10px);animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{transform:scale(.85);opacity:.4}50%{transform:scale(1.1);opacity:.8}}.premium-loader{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center}.loader-ring{position:absolute;border-radius:50%;border:2px solid transparent;border-top-color:var(--acc)}.loader-ring.one{width:80px;height:80px;border-top-color:var(--acc);animation:rotate-premium 2s linear infinite}.loader-ring.two{width:56px;height:56px;border-top-color:var(--acc-bright);animation:rotate-premium 1.5s linear infinite reverse}.loader-ring.three{width:32px;height:32px;border-top-color:#fff;animation:rotate-premium 1s linear infinite}.loader-core{width:10px;height:10px;background:var(--acc-bright);border-radius:50%;box-shadow:0 0 20px var(--acc-bright),0 0 40px #34eb7a66;animation:pulse-core 1.5s ease-in-out infinite}@keyframes rotate-premium{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse-core{0%,to{transform:scale(1);opacity:1;filter:brightness(1)}50%{transform:scale(1.3);opacity:.8;filter:brightness(1.2)}}.loading-content{display:flex;flex-direction:column;gap:8px}.loading-title{font-size:1.4rem;font-weight:800;color:#fff;letter-spacing:-.5px;margin:0}.loading-msg{color:#fff9;font-size:.95rem;margin:0;line-height:1.5}.camera-setup-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:50;pointer-events:none}.camera-setup-msg{display:flex;align-items:center;gap:12px;margin-top:32px;padding:12px 24px;background:#ffffff0d;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:100px;border:1px solid rgba(255,255,255,.1);box-shadow:0 10px 40px #0000004d}.camera-setup-msg span{color:#ffffffb3;font-size:.9rem;font-weight:600;letter-spacing:.5px}.setup-dot{width:8px;height:8px;background:#34eb7a;border-radius:50%;box-shadow:0 0 10px #34eb7a}.setup-dot.pulse{animation:setup-pulse 1.5s ease-out infinite}@keyframes setup-pulse{0%{transform:scale(1);opacity:1;box-shadow:0 0 #34eb7ab3}70%{transform:scale(1.2);opacity:.8;box-shadow:0 0 0 10px #34eb7a00}to{transform:scale(1);opacity:.6;box-shadow:0 0 #34eb7a00}}.mobile-fab-action{position:fixed;bottom:24px;right:24px;background:var(--warm-grad);color:#fff;border:none;border-radius:50px;padding:12px 28px;display:flex!important;align-items:center;gap:10px;font-weight:800;font-size:1rem;box-shadow:0 8px 32px #4ade8066;z-index:1000;animation:fabIn .5s cubic-bezier(.175,.885,.32,1.275)}@keyframes fabIn{0%{transform:scale(.5) translateY(40px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.desktop-hidden{display:none!important}@media (max-width: 1024px){.desktop-hidden{display:flex!important}.operator-sidebar{padding-bottom:100px}.operator-layout{height:auto!important;min-height:unset!important;gap:20px;padding-bottom:80px}.sidebar-card{height:auto!important}}.review-letterbox{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#000;z-index:5;padding:40px}.review-canvas-container{position:relative;max-width:100%;max-height:100%;box-shadow:0 0 50px #00000080;display:flex;align-items:center;justify-content:center}.review-image-fit{display:block;max-width:100%;max-height:100%;width:auto;height:auto;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.review-svg-layer{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}
