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}@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:100vh;display:flex;justify-content:center;align-items:center}.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}.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}.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:grid;grid-template-columns:1.3fr .7fr;gap:24px;width:100%;max-width:1450px;margin:0 auto}@media (max-width: 1024px){.operator-layout{grid-template-columns:1fr;gap:16px}}.operator-primary-col{display:flex;flex-direction:column;gap:16px}.operator-sidebar{display:flex;flex-direction:column}.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:12px;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:#fff;font-size:.88rem;font-weight:700;cursor:pointer;transition:all .2s ease}.btn-sidebar:hover{background:#ffffff1a}.sidebar-footer{margin-top:auto;padding-top:12px}.generate-final-btn{width:100%;padding:16px!important;font-size:1rem!important;border-radius:16px!important}.operator-image-hull{border-radius:32px;overflow:hidden;background:#000;height:65vh;min-height:350px;max-height:800px;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}.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}.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-active-fullscreen{position:fixed!important;top:0!important;right:0!important;bottom:0!important;left:0!important;width:100vw!important;height:100vh!important;max-width:none!important;max-height:none!important;background:#000!important;z-index:99999!important;border-radius:0!important;border:none!important}.zoom-active .main-card.glass,.zoom-active .motion-editing-wrap,.zoom-active .app-container,.zoom-active .operator-primary-col,.zoom-active .operator-layout{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}.zoom-active-fullscreen .zoom-banner{bottom:80px!important;padding:16px 36px!important;border-radius:20px!important;font-size:1.25rem!important;box-shadow:0 15px 40px #0006!important;background:#13bd2cb3}.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(.8);opacity:.5}60%{transform:scale(1.3);opacity:.2}to{transform:scale(1.6);opacity:0}}@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:24px;top:auto;left:0;width:100%;display:flex;flex-direction:column;align-items:center;gap:12px;z-index:100;pointer-events:none}.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}.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%}.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:45vh!important;min-height:300px!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:column;gap:12px}.operator-actions .btn{width:100%}}@media (max-height: 600px) and (orientation: landscape){.operator-image-hull{height:60vh!important;min-height:200px!important}.app-root{padding:10px 0}}.distance-meter-hull{margin:16px 0;padding:0 20px}.meter-track{position:relative;height:12px;background:#ffffff1a;border-radius:20px;overflow:visible;border:1px solid rgba(255,255,255,.05)}.meter-zone-perfect{position:absolute;top:-4px;bottom:-4px;left:31%;right:31%;background:#34eb7a40;border:2px solid #34eb7a;border-radius:4px;z-index:1;box-shadow:0 0 15px #34eb7a66}.meter-pointer{position:absolute;top:50%;width:24px;height:24px;background:#fff;border:4px solid var(--primary);border-radius:50%;transform:translate(-50%,-50%);z-index:5;transition:left .5s cubic-bezier(.18,.89,.32,1.28);box-shadow:0 0 20px var(--primary)}.meter-labels{display:flex;justify-content:space-between;margin-top:12px;font-size:.75rem;font-weight:700;color:var(--text-muted)}.meter-status-txt{text-align:center;margin-top:8px;font-size:1rem;font-weight:800;text-transform:uppercase;letter-spacing:1px}.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-sidebar{flex-shrink:0;display:flex;flex-direction:column;justify-content:center;gap:16px;width:200px}.operator-layout-scroller{width:100%;display:flex;flex-direction:column;padding:16px;gap:16px;overflow: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}}
