@import "https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;1,9..144,400&family=Inter:wght@300;400;500;600;700&display=swap";*{box-sizing:border-box;margin:0;padding:0}@font-face{font-family:Sloan;src:url(/fonts/Sloan.otf)format("opentype");font-weight:400;font-style:normal;font-display:block;size-adjust:100%;ascent-override:100%;descent-override:0%;line-gap-override:0%}:root{--bg-primary:#fff;--bg-secondary:#f9fafb;--bg-tertiary:#f3f4f6;--bg-accent:#eef2ff;--text-primary:#111827;--text-secondary:#4b5563;--text-muted:#9ca3af;--accent-primary:#4f46e5;--accent-hover:#4338ca;--accent-soft:#818cf8;--accent-danger:#ef4444;--accent-success:#10b981;--border-light:#e5e7eb;--text-inverted:#fff;--radius-sm:8px;--radius-md:16px;--radius-lg:32px;--radius-xl:48px;--radius-full:9999px;--font-body:"Inter", -apple-system, sans-serif;--font-display:"Inter", -apple-system, sans-serif;--font-optotype:"Sloan", "Courier New", monospace;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a}body:before{content:"";pointer-events:none;z-index:9999;opacity:.05;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 600 600' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");width:100%;height:100%;position:fixed;top:0;left:0}body:after{content:"";pointer-events:none;z-index:9998;background:radial-gradient(circle,#fff0 0%,#00000005 100%);position:fixed;inset:0}body{font-family:var(--font-body);background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;flex-direction:column;width:100%;min-height:100vh;line-height:1.5;display:flex;overflow-x:hidden}body.exam-mode{color:#000;background-color:#fff}.home-page{flex-direction:column;gap:4rem;width:100%;max-width:1100px;margin:0 auto;padding:.5rem 2rem 8rem;display:flex}.clinical-badge{color:var(--accent-primary);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.08em;background:#fff;border:1px solid #4f46e533;align-items:center;gap:.5rem;width:fit-content;margin-bottom:-1rem;padding:.5rem 1rem;font-size:.75rem;font-weight:700;display:inline-flex;box-shadow:0 4px 12px #4f46e514}.hero-container{grid-template-columns:1fr 1fr;align-items:center;gap:4rem;width:100%;display:grid}@media (width<=850px){.hero-container{grid-template-columns:1fr;gap:2rem}}.hero-section{text-align:left;flex-direction:column;gap:1.25rem;display:flex}@media (width<=600px){.hero-section{text-align:center}}.hero-title{letter-spacing:-.04em;color:var(--text-primary);margin:0;font-size:clamp(2rem,8vw,3.5rem);font-weight:800;line-height:1}.hero-title span{color:var(--accent-primary)}.hero-subtitle{color:var(--text-secondary);max-width:480px;margin:0;font-size:1.1rem;line-height:1.6}.hero-image-free{justify-content:center;align-items:center;width:100%;transition:transform .5s cubic-bezier(.4,0,.2,1);display:flex;position:relative}.hero-image-free:before{content:"";z-index:-1;filter:blur(40px);background:radial-gradient(circle,#4f46e51a 0%,#4f46e500 70%);width:80%;height:80%;position:absolute}.hero-image{object-fit:contain;filter:drop-shadow(0 20px 40px #00000014);width:100%;max-width:350px;height:auto;transition:all .5s;display:block}.hero-image-free:hover{transform:translateY(-5px)}.hero-image-free:hover .hero-image{filter:drop-shadow(0 25px 50px #0000001f)}.cards-container{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;display:grid}.action-card{border-radius:var(--radius-lg);flex-direction:column;gap:1rem;padding:1.5rem;transition:transform .2s;display:flex}.action-card.white{border:1px solid var(--border-light);box-shadow:var(--shadow-sm);background:#fff}.action-card.grey{background:var(--bg-secondary)}.card-icon{background:var(--bg-accent);width:40px;height:40px;color:var(--accent-primary);border-radius:8px;justify-content:center;align-items:center;display:flex}.card-image-box{border-radius:var(--radius-md);background:var(--bg-secondary);justify-content:center;align-items:center;width:100%;height:140px;margin-bottom:.5rem;padding:.5rem;display:flex;overflow:hidden}.card-image{object-fit:contain;width:100%;height:100%;transition:transform .3s}.action-card:hover .card-image{transform:scale(1.05)}.action-card h3{margin:0;font-size:1.25rem;font-weight:700}.action-card p{color:var(--text-secondary);margin:0;font-size:.9rem;line-height:1.4}.card-footer{color:var(--accent-primary);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;align-items:center;gap:.5rem;font-size:.9rem;font-weight:700;display:flex}.calibrate-panel{background:var(--bg-accent);border-radius:var(--radius-lg);justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.calibrate-content h3{color:var(--accent-primary);margin-bottom:.5rem;font-size:1.1rem}.calibrate-content p{color:var(--text-secondary);max-width:240px;margin:0;font-size:.85rem;line-height:1.4}.calibrate-icon-box{justify-content:center;align-items:center;width:140px;height:90px;display:flex}.endorsement-section{margin-top:1rem}.endorsement-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.75rem;font-size:.65rem;font-weight:800}.endorsement-text{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.95rem;font-weight:500}.badge-grid{flex-wrap:wrap;justify-content:center;align-items:center;gap:2.5rem;display:flex}.info-badge{color:var(--text-muted);text-transform:uppercase;align-items:center;gap:.5rem;font-size:.75rem;font-weight:700;display:flex}.bottom-nav{border-top:1px solid var(--border-light);z-index:100;background:#fff;justify-content:space-around;padding:.75rem 0 1.5rem;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{color:var(--text-muted);text-transform:uppercase;cursor:pointer;flex-direction:column;align-items:center;gap:.25rem;font-size:.6rem;font-weight:700;display:flex}.nav-item.active{color:var(--accent-primary)}.nav-item-icon{border-radius:var(--radius-md);padding:.4rem 1.2rem}.nav-item.active .nav-item-icon{background:var(--bg-accent)}.fab{background:var(--accent-primary);color:#fff;width:56px;height:56px;box-shadow:var(--shadow-lg);cursor:pointer;z-index:90;border-radius:16px;justify-content:center;align-items:center;display:flex;position:fixed;bottom:5.5rem;right:1.5rem}.container{width:100%;max-width:1100px;margin:0 auto;padding:0 2rem}.glass-panel{background:var(--bg-glass);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-glass)}.card{background:var(--bg-secondary);border-radius:var(--radius-md);box-shadow:var(--shadow-md);border:1px solid var(--border-light);padding:2rem;transition:transform .2s,box-shadow .2s}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn{border-radius:var(--radius-full);cursor:pointer;font-size:.95rem;font-weight:600;font-family:var(--font-sans);border:none;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex}.btn:active{transform:scale(.98)}.btn-primary{background-color:var(--accent-primary);color:var(--text-inverted)}.btn-primary:hover{background-color:var(--accent-hover);transform:translateY(-1px)}.btn-secondary{color:var(--text-primary);border:2px solid var(--border-light);background-color:#0000}.btn-secondary:hover{border-color:var(--accent-primary);color:var(--accent-primary);background-color:#2563eb0d}.btn-danger{background-color:var(--accent-danger);color:var(--text-inverted)}.btn-danger:hover{background-color:#dc2626}.btn-icon-only{border-radius:50%;padding:.75rem}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.01em;font-weight:600;line-height:1.15}h1{letter-spacing:-.025em;margin-bottom:1rem;font-size:2.5rem;font-weight:700}h2{margin-bottom:1rem;font-size:2rem;font-weight:600}h3{font-size:1.35rem;font-weight:500}p{font-family:var(--font-body);color:var(--text-secondary);margin-bottom:1.5rem;font-size:1.05rem;line-height:1.7}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.5s forwards fadeIn}@keyframes pulse{0%{transform:scale(1);box-shadow:0 0 #2563eb66}70%{transform:scale(1.05);box-shadow:0 0 0 10px #2563eb00}to{transform:scale(1);box-shadow:0 0 #2563eb00}}.animate-pulse-btn{animation:2s infinite pulse}.input-group{margin-bottom:1.5rem}.input-label{color:var(--text-primary);margin-bottom:.5rem;font-size:.9rem;font-weight:500;display:block}.input-field{width:100%;font-size:1rem;font-family:var(--font-sans);border:1px solid var(--border-light);border-radius:var(--radius-md);background-color:var(--bg-secondary);color:var(--text-primary);padding:.75rem 1rem;transition:all .2s}.input-field:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--border-focus);outline:none}.flex-center{justify-content:center;align-items:center;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;display:grid}.navbar{z-index:100;padding:.75rem 0;position:sticky;top:0;-webkit-backdrop-filter:blur(20px)!important;background:#ffffffb3!important;border-top:none!important;border-left:none!important;border-right:none!important;border-radius:0!important;box-shadow:0 4px 30px #00000008!important}.nav-content{justify-content:space-between;align-items:center;display:flex}.nav-logo{color:var(--text-primary);align-items:center;gap:.75rem;font-size:1.25rem;font-weight:700;text-decoration:none;display:flex}.nav-logo span{color:var(--accent-primary)}.optotype-display{justify-content:center;align-items:center;width:100%;height:45vh;display:flex;position:relative;overflow:hidden}.optotype{font-family:var(--font-optotype);text-align:center;-webkit-user-select:none;user-select:none;font-size-adjust:.72;justify-content:center;align-items:center;font-weight:700;line-height:1;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background-color:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background-color:var(--bg-modal);border-radius:var(--radius-lg);width:100%;max-width:500px;box-shadow:var(--shadow-glass);border:1px solid var(--border-light);opacity:0;padding:2.5rem;animation:.3s forwards fadeIn;transform:translateY(20px)}.credit-card-overlay{border:2px dashed var(--accent-primary);writing-mode:vertical-rl;text-orientation:mixed;background-color:#2563eb33;border-radius:8px;justify-content:center;align-items:center;width:53.98mm;height:85.6mm;margin:0 auto;transition:all .1s;display:flex;position:relative}.distance-hud{border-radius:var(--radius-full);z-index:50;align-items:center;gap:1rem;padding:1rem 1.5rem;font-size:1.1rem;font-weight:600;display:flex;position:fixed;top:1.5rem;right:1.5rem}.status-indicator{background-color:#94a3b8;border-radius:50%;width:12px;height:12px}.status-indicator.active{background-color:var(--accent-success);box-shadow:0 0 0 4px #10b98133}.status-indicator.warning{background-color:#f59e0b;box-shadow:0 0 0 4px #f59e0b33}.status-indicator.error{background-color:var(--accent-danger);box-shadow:0 0 0 4px #ef444433}.calib-page{min-height:100vh;padding:1.5rem 1rem}.calib-progress-bar{background:var(--border-light);border-radius:999px;max-width:800px;height:4px;margin:0 auto 1.5rem;overflow:hidden}.calib-progress-fill{background:var(--accent-primary);border-radius:999px;height:100%;transition:width .4s}.calib-card{max-width:800px;margin:0 auto}.calib-title{align-items:center;gap:.75rem;margin-bottom:.75rem;font-size:1.75rem;display:flex}.calib-section{background:var(--bg-primary);border-radius:var(--radius-md);text-align:center;margin:1.5rem 0;padding:1.5rem}.calib-nav{justify-content:space-between;align-items:center;gap:1rem;margin-top:2rem;display:flex}.calib-error{color:var(--accent-danger);background:#ef444414;border-radius:8px;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem;font-size:.95rem;display:flex}.calib-slider{accent-color:var(--accent-primary);flex:1}.slider-row{justify-content:center;align-items:center;gap:1rem;display:flex}.mode-grid{grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:1rem;display:grid}.mode-card{cursor:pointer;text-align:center;padding:1.5rem;transition:transform .2s,box-shadow .2s;position:relative}.mode-card--primary{border:2px solid var(--accent-primary);box-shadow:var(--shadow-lg)}.mode-icon{color:var(--text-secondary);justify-content:center;margin-bottom:.75rem;display:flex}.mode-icon--primary{color:var(--accent-primary)}.mode-badge{background:var(--accent-primary);color:#fff;border-radius:999px;margin-top:.75rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-block}.camera-layout{grid-template-columns:1fr 1fr;align-items:flex-start;gap:1.5rem;display:grid}.video-wrapper{aspect-ratio:4/3;background:#000;border-radius:12px;width:100%;position:relative;overflow:hidden}.video-overlay{color:#fff;background:#0009;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;font-size:.9rem;display:flex;position:absolute;inset:0}.loading-spinner{border:3px solid #fff3;border-top-color:#fff;border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.face-detected-badge{color:#fff;white-space:nowrap;background:#10b981d9;border-radius:999px;padding:.3rem .85rem;font-size:.8rem;font-weight:600;position:absolute;bottom:.75rem;left:50%;transform:translate(-50%)}.instruction-list{color:var(--text-primary);flex-direction:column;gap:.75rem;margin:0;padding-left:1.25rem;font-size:.95rem;display:flex}.instruction-list li.tip{color:var(--accent-primary);margin-left:-1.25rem;font-weight:600;list-style:none}.success-badge{color:var(--accent-success);background:#10b9811a;border-radius:8px;margin-top:1rem;padding:.75rem 1rem;font-size:.95rem;font-weight:600}.sync-progress{flex:1;justify-content:flex-end;align-items:center;gap:.75rem;display:flex}.sync-bar{background:var(--border-light);border-radius:999px;flex:1;max-width:180px;height:10px;overflow:hidden}.sync-fill{background:var(--accent-primary);border-radius:999px;height:100%;transition:width .1s linear}.optotype-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-top:1rem;display:grid}.optotype-card{cursor:pointer;text-align:center;padding:1.5rem 1rem}.optotype-preview{font-size:3rem;font-weight:700;font-family:var(--font-optotype);color:var(--accent-primary);margin-bottom:.75rem;line-height:1}@media (width<=640px){.calib-page{padding:1rem .75rem}.calib-card{padding:1.25rem}.calib-title{gap:.5rem;font-size:1.35rem}h1{font-size:1.75rem}.mode-grid{grid-template-columns:1fr;gap:1rem}.mode-card{padding:1.25rem}.camera-layout{grid-template-columns:1fr;gap:1rem}.calib-nav{flex-direction:column-reverse;align-items:stretch}.calib-nav .btn,.sync-progress{justify-content:center;width:100%}.sync-bar{flex:1;max-width:none}.optotype-display{height:45vh}.btn{min-height:48px}.optotype-grid{grid-template-columns:1fr 1fr 1fr;gap:.75rem}.optotype-card{padding:1rem .5rem}.optotype-card h3{font-size:.85rem}.optotype-preview{font-size:2.25rem}.exam-top-hud{flex-wrap:wrap;gap:.5rem;padding:.5rem .75rem;font-size:.85rem}.webcam-hud{width:100px!important;font-size:.7rem!important;top:.5rem!important;right:.5rem!important}.exam-header-container{gap:.5rem;width:100%;flex-direction:column!important;align-items:stretch!important;padding:.5rem!important}.exam-header-info{flex-wrap:wrap;justify-content:center!important;gap:.75rem!important;width:100%!important;font-size:.8rem!important}.exam-header-info span{flex-shrink:1;min-width:0!important}.exam-header-right{justify-content:center!important;width:100%!important}}@media (width>=768px){.home-page{gap:4rem;max-width:1100px;padding:1.5rem 2rem}.clinical-badge{margin-bottom:-2rem}.hero-section{position:relative}.hero-container{grid-area:hero-full;grid-template-columns:1fr 1fr;align-items:center;gap:4rem;display:grid}.hero-image-free{max-width:500px;margin-left:auto}.hero-title{font-size:4rem;line-height:1.1}.hero-subtitle{max-width:480px;font-size:1.25rem}.cards-container{flex-direction:row;grid-area:cards;align-items:stretch}.action-card{flex:1}.calibrate-panel{grid-area:calib;margin-top:2rem}.endorsement-section{text-align:center;flex-direction:column;grid-area:endors;align-items:center;display:flex}.badge-grid{justify-content:center}.bottom-nav,.fab{display:none}}.near-exam-container{background-color:var(--bg-primary);width:100%;max-width:500px;min-height:100vh;color:var(--text-primary);flex-direction:column;margin:0 auto;display:flex}.exam-header{border-bottom:1px solid var(--border-light);z-index:10;background:#fff;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex;position:sticky;top:0}.back-button{background:var(--bg-secondary);cursor:pointer;width:40px;height:40px;color:var(--text-primary);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.header-title{font-size:1.1rem;font-weight:700}.header-spacer{width:40px}.exam-main{flex-direction:column;flex:1;padding:2rem 1.5rem;display:flex}.intro-step{text-align:center;flex-direction:column;align-items:center;gap:1.5rem;display:flex}.icon-circle{background:var(--bg-accent);width:80px;height:80px;color:var(--accent-primary);border-radius:50%;justify-content:center;align-items:center;margin-bottom:.5rem;display:flex}.instruction-box{text-align:left;flex-direction:column;gap:1rem;width:100%;margin:1.5rem 0;display:flex}.instruction-item{background:var(--bg-secondary);border-radius:var(--radius-md);align-items:flex-start;gap:1rem;padding:1rem;display:flex}.instruction-num{background:var(--accent-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:.75rem;font-weight:800;display:flex}.instruction-item p{margin:0;font-size:.9rem;line-height:1.4}.testing-step{flex-direction:column;gap:2rem;height:100%;display:flex}.test-instruction{text-align:center;color:var(--text-secondary);font-size:1.1rem;font-weight:600}.jaeger-display-card{border:2px solid var(--border-light);border-radius:var(--radius-lg);min-height:300px;box-shadow:var(--shadow-sm);background:#fff;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:2rem;display:flex;position:relative}.jaeger-tag{background:var(--bg-accent);color:var(--accent-primary);border-radius:999px;padding:.2rem .6rem;font-size:.7rem;font-weight:800;position:absolute;top:1rem;right:1.5rem}.exam-actions{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.results-step{text-align:center;flex-direction:column;align-items:center;gap:2rem;display:flex}.result-badge{color:#10b981;margin-top:1rem}.result-score-card{background:var(--bg-accent);border-radius:var(--radius-lg);flex-direction:column;gap:.5rem;width:100%;padding:2rem;display:flex}.score-label{text-transform:uppercase;color:var(--accent-primary);letter-spacing:.05em;font-size:.8rem;font-weight:700}.score-value{color:var(--text-primary);font-size:4rem;font-weight:800;line-height:1}.score-detail{color:var(--text-secondary);font-size:1rem;font-weight:600}.result-info{background:var(--bg-secondary);border-radius:var(--radius-md);text-align:left;width:100%;padding:1.5rem}.info-header{align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.9rem;font-weight:700;display:flex}.result-info p{color:var(--text-secondary);margin:0;font-size:.9rem}.actions-vertical{flex-direction:column;gap:.75rem;width:100%;display:flex}.full-width{width:100%}.mt-4{margin-top:1rem}.btn-ghost{color:var(--text-muted);background:0 0;font-size:.85rem;font-weight:600}.progress-bar-container{background:var(--bg-tertiary);border-radius:999px;width:100%;height:6px;overflow:hidden}.progress-bar-fill{background:var(--accent-primary);height:100%;transition:width .3s}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleUp{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.animate-slide-up{animation:.4s forwards slideUp}.animate-scale-up{animation:.4s forwards scaleUp}.footer-image-container{justify-content:center;align-items:flex-start;width:100%;margin-top:4rem;display:flex;overflow:hidden}.footer-brand-image{object-fit:cover;object-position:top center;opacity:.9;filter:drop-shadow(0 -10px 20px #0000000d);width:100%;max-width:800px;height:380px;transition:all .5s}.footer-brand-image:hover{opacity:1;transform:translateY(-5px)}.calibrate-image{object-fit:contain;width:100%;height:100%;transition:transform .4s}.calibrate-panel:hover .calibrate-image{transform:scale(1.1)}.colorblind-box{justify-content:center!important;align-items:center!important;height:140px!important;display:flex!important}.colorblind-img{object-fit:contain!important;width:60%!important;height:auto!important}.endorsement-logo{object-fit:contain;filter:grayscale()opacity(.6);width:auto;height:55px;transition:all .3s}.endorsement-logo:hover{filter:grayscale(0)opacity()}.hero-disclaimer{color:var(--text-muted);max-width:440px;margin-top:-.5rem;font-size:.8rem;font-style:italic;line-height:1.4}@media (width<=640px){.hero-container{text-align:center;flex-direction:column;gap:2rem;padding:1rem 0;display:flex}.hero-title{font-size:2.2rem!important}.hero-subtitle{margin:0 auto 1.5rem;font-size:1rem}.hero-image{margin:0 auto;max-width:300px!important}.cards-container{grid-template-columns:1fr;gap:1.5rem}.endorsement-logo{height:40px}.badge-grid{justify-content:center;gap:1.5rem}.footer-brand-image{margin:0 auto;width:100%!important;height:180px!important}.footer-image-container{margin-top:2rem}}
