*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0a0a0f;--surface: #14141f;--surface-2: #1e1e2e;--border: #363650;--text: #e0e0e8;--text-dim: #c8c8d8;--accent: #818cf8;--accent-hover: #9299ff;--radius: 8px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh;overflow-x:hidden}#root{min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.header{padding:16px 32px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}.header-home-link{display:flex;align-items:center;gap:12px;cursor:pointer;text-decoration:none;color:inherit}.header-logo{width:32px;height:32px;object-fit:contain;border-radius:4px}.header h1{font-size:20px;font-weight:700;letter-spacing:-.02em}.subtitle{font-size:13px;color:var(--text-dim)}.header-right{margin-left:auto;display:flex;align-items:center;gap:12px}.lang-picker{position:relative}.lang-picker-btn{display:flex;align-items:center;gap:6px;padding:5px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text-dim);font-size:12px;cursor:pointer;transition:all .15s;white-space:nowrap}.lang-picker-btn:hover{border-color:var(--accent);color:var(--text)}.lang-picker-chevron{transition:transform .2s}.lang-picker-chevron.open{transform:rotate(180deg)}.lang-picker-dropdown{position:absolute;top:calc(100% + 4px);right:0;min-width:160px;max-height:320px;overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #0006;z-index:100;padding:4px}.lang-picker-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 10px;border:none;border-radius:4px;background:transparent;color:var(--text-dim);font-size:13px;cursor:pointer;transition:all .1s;text-align:left}.lang-picker-option:hover{background:var(--surface-2);color:var(--text)}.lang-picker-option.active{color:var(--accent);font-weight:600}.lang-picker-native{flex:1}.subscribe-section{margin-top:auto;padding-bottom:16px;text-align:center;width:100%}.subscribe-text{font-size:13px;color:#fff;margin-bottom:10px}.subscribe-input-group{display:flex;gap:8px;max-width:380px;margin:0 auto}.subscribe-input{flex:1;padding:8px 12px;border:1px solid rgba(255,255,255,.25);border-radius:var(--radius);background:#ffffff1a;color:#fff;font-size:13px}.subscribe-input::placeholder{color:#ffffff80}.subscribe-input:focus{outline:none;border-color:#ffffff80}.subscribe-btn{padding:8px 16px;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius);background:#ffffff26;color:#fff;font-size:13px;cursor:pointer;white-space:nowrap;transition:background .15s}.subscribe-btn:hover{background:#ffffff40}.subscribe-btn:disabled{opacity:.5;cursor:not-allowed}.subscribe-success{font-size:13px;color:#fff}.app-footer{padding:12px 32px;text-align:center;font-size:12px;color:var(--text-dim);opacity:.75;border-top:1px solid var(--border);flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:4px}.footer-main,.footer-meta{display:flex;justify-content:center;align-items:center;gap:6px}.footer-sep{opacity:.6}.footer-link{background:none;border:none;color:inherit;font:inherit;cursor:pointer;text-decoration:underline;text-decoration-color:transparent;transition:text-decoration-color .15s;padding:0}.footer-link:hover{text-decoration-color:currentColor}.privacy-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.privacy-modal{background:var(--bg);border:1px solid var(--border);border-radius:12px;max-width:640px;width:100%;max-height:80vh;overflow-y:auto;padding:32px}.privacy-modal h2{margin:0 0 4px;font-size:20px}.privacy-date{font-size:12px;color:var(--text-dim);margin:0 0 16px}.privacy-section{margin-top:16px}.privacy-section h3{font-size:14px;margin:0 0 4px}.privacy-section p{font-size:13px;line-height:1.6;color:var(--text-dim);margin:0}.privacy-modal>p{font-size:13px;line-height:1.6;color:var(--text-dim);margin:0}.privacy-close-btn{margin-top:24px;padding:8px 24px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-size:13px;cursor:pointer;width:100%}.privacy-close-btn:hover{border-color:var(--accent)}.changelog-entry{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border)}.changelog-entry:last-of-type{border-bottom:none}.changelog-entry-header{display:flex;align-items:center;gap:10px;margin-bottom:6px}.changelog-version{font-weight:700;font-size:14px;color:var(--accent)}.changelog-date{font-size:12px;color:var(--text-dim)}.changelog-content{font-size:13px;line-height:1.7;color:var(--text-dim);margin:0;white-space:pre-line}.main{flex:1;display:flex;overflow:hidden}.sidebar{width:360px;min-width:360px;border-right:1px solid var(--border);padding:24px;display:flex;flex-direction:column;gap:16px;overflow-y:auto}.content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;position:relative;overflow:auto}.control-panel{display:flex;flex-direction:column;gap:20px}.control-group{display:flex;flex-direction:column;gap:8px}.control-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);display:flex;justify-content:space-between;align-items:center}.control-value{font-weight:700;color:var(--accent);font-variant-numeric:tabular-nums}.type-buttons{display:flex;flex-direction:column;gap:4px}.type-btn{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text-dim);font-size:13px;cursor:pointer;transition:all .15s;text-align:left}.type-btn:hover{border-color:var(--accent);color:var(--text)}.type-btn.active{border-color:var(--accent);background:var(--accent);color:#fff}.slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;border-radius:3px;background:var(--surface-2);outline:none;cursor:pointer}.slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--accent);border:2px solid white;cursor:pointer;transition:transform .1s}.slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.slider-labels{display:flex;justify-content:space-between;font-size:12px;color:var(--text-dim)}.view-buttons{display:flex;gap:4px}.view-btn{flex:1;padding:8px 6px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text-dim);font-size:12px;cursor:pointer;transition:all .15s}.view-btn:hover{border-color:var(--accent);color:var(--text)}.view-btn.active{border-color:var(--accent);background:var(--accent);color:#fff}.uploader{border:2px dashed var(--border);border-radius:var(--radius);padding:48px 32px;text-align:center;cursor:pointer;transition:all .2s;width:100%;max-width:480px}.uploader:hover{border-color:var(--accent);background:#818cf80d}.uploader-content{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-dim)}.uploader-content p{font-size:14px}.uploader-hint{font-size:12px;opacity:.8}.canvas-container{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.canvas-container canvas{max-width:100%;max-height:calc(100vh - 140px);border-radius:var(--radius);object-fit:contain}.canvas-placeholder{position:absolute;color:var(--text-dim);font-size:14px}.compare-view{position:relative;width:100%;max-width:100%;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;touch-action:none}.compare-layer{position:relative}.compare-layer canvas{max-width:100%;max-height:calc(100vh - 140px);display:block;border-radius:var(--radius)}.compare-left{position:relative}.compare-right{position:absolute;top:0;left:0;width:100%;height:100%}.compare-right canvas{width:100%;height:100%;object-fit:contain}.compare-label{position:absolute;bottom:16px;padding:4px 12px;background:#000000b3;border-radius:4px;font-size:12px;font-weight:600;pointer-events:none}.compare-left .compare-label{left:16px}.compare-right .compare-label{right:16px}.compare-slider{position:absolute;top:0;bottom:0;width:4px;transform:translate(-50%);cursor:ew-resize;z-index:10}.compare-slider-line{position:absolute;top:0;bottom:0;left:50%;width:2px;transform:translate(-50%);background:#fff;box-shadow:0 0 4px #00000080}.compare-slider-handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:36px;height:36px;border-radius:50%;background:#fff;color:#333;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000004d}.image-actions{display:flex;gap:8px;margin-top:16px}.action-btn{padding:6px 16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text-dim);font-size:13px;cursor:pointer;transition:all .15s}.action-btn:hover{border-color:var(--accent);color:var(--text)}.share-btn{width:100%;padding:10px;border:1px solid var(--accent);border-radius:var(--radius);background:transparent;color:var(--accent);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.share-btn:hover{background:var(--accent);color:#fff}.test-flow{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;max-width:640px;margin:0 auto;width:100%}.welcome-screen{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 24px;width:100%}.welcome-screen:has(.home-landing){align-items:stretch}.welcome-card{max-width:520px;width:100%;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:40px 32px;display:flex;flex-direction:column;gap:20px}.welcome-card h2{font-size:24px;font-weight:700}.welcome-desc{color:var(--text-dim);font-size:14px;line-height:1.6}.calibration-section h3{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);margin-bottom:12px}.calibration-list{list-style:none;display:flex;flex-direction:column;gap:8px}.calibration-list li{font-size:13px;color:var(--text);padding-left:24px;position:relative}.calibration-list li:before{content:"";position:absolute;left:0;top:5px;width:12px;height:12px;border:1.5px solid var(--accent);border-radius:3px}.checkbox-label{display:flex;align-items:center;gap:10px;font-size:14px;cursor:pointer;padding:12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-2)}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent)}.start-btn{width:100%;padding:14px;border:none;border-radius:var(--radius);background:var(--accent);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .15s}.start-btn:hover:not(:disabled){background:var(--accent-hover)}.start-btn:disabled{opacity:.55;cursor:not-allowed}.previous-hint{font-size:12px;color:var(--text-dim);text-align:center}.home-landing{max-width:720px;width:100%;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:24px}.home-heading{font-size:28px;font-weight:700;text-align:center}.home-subheading{font-size:14px;color:var(--text-dim);text-align:center;line-height:1.6;max-width:480px}.home-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;width:100%}.home-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:28px 24px;display:flex;flex-direction:column;gap:14px;transition:border-color .15s}.home-card:hover{border-color:var(--accent)}.home-card-icon{color:var(--accent)}.home-card-title{font-size:18px;font-weight:700}.home-card-desc{font-size:13px;color:var(--text-dim);line-height:1.6;flex:1}.home-disclaimer{font-size:11px;color:var(--text-dim);opacity:.75;line-height:1.5;font-style:italic}.instructions-list{list-style:none;display:flex;flex-direction:column;gap:14px}.instructions-list li{display:flex;align-items:flex-start;gap:12px;font-size:14px;line-height:1.6;color:var(--text)}.instructions-num{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:var(--accent);color:#fff;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;margin-top:1px}.home-back-btn{width:100%;padding:10px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-dim);font-size:13px;cursor:pointer;transition:all .15s}.home-back-btn:hover{border-color:var(--accent);color:var(--text)}.session-input-group{display:flex;gap:8px}.session-input{flex:1;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-2);color:var(--text);font-size:13px;font-family:SF Mono,Menlo,Consolas,monospace;outline:none;transition:border-color .15s}.session-input:focus{border-color:var(--accent)}.session-input::placeholder{color:var(--text-dim);opacity:.7;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif}.load-btn{padding:10px 20px;border:none;border-radius:var(--radius);background:var(--accent);color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s;white-space:nowrap}.load-btn:hover:not(:disabled){background:var(--accent-hover)}.load-btn:disabled{opacity:.55;cursor:not-allowed}.load-error{font-size:12px;color:#ef4444;margin-top:-6px}@media(max-width:600px){.home-cards{grid-template-columns:1fr}}.trial-container{display:flex;flex-direction:column;align-items:center;gap:32px;padding:20px 0}.trial-instruction{font-size:16px;color:var(--text-dim);text-align:center;margin-bottom:-16px}.trial-hint{font-size:12px;color:var(--text-dim);opacity:.8;text-align:center}.odd-one-out-grid{display:grid;gap:16px;justify-items:center}.threshold-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;justify-items:center}.circle-btn{border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .1s,border-color .1s;width:80px;height:80px;outline:none}.circle-btn:hover{transform:scale(1.08);border-color:#ffffff4d}.circle-btn:active{transform:scale(.95)}.circle-btn.large{width:90px;height:90px}.cant-tell-btn{padding:10px 28px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-dim);font-size:14px;cursor:pointer;transition:all .15s}.cant-tell-btn:hover{border-color:var(--accent);color:var(--text);background:var(--surface-2)}.trial-actions{display:flex;gap:8px;align-items:center}.modifier-btn{padding:8px 16px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-dim);font-size:13px;cursor:pointer;transition:all .15s}.modifier-btn:hover{border-color:var(--accent);color:var(--text)}.modifier-btn.active{border-color:var(--accent);background:var(--accent);color:#fff}.modifier-btn.faint.active{border-color:#60a5fa;background:#60a5fa;color:#000}.faint-hint{font-size:12px;color:var(--text-dim);opacity:.85;text-align:center;margin-top:4px}.test-progress{width:100%;display:flex;flex-direction:column;gap:8px}.test-progress-header{display:flex;justify-content:space-between;font-size:13px}.test-progress-label{color:var(--text-dim);font-weight:600}.test-progress-count{color:var(--accent);font-variant-numeric:tabular-nums}.test-progress-bar{width:100%;height:4px;background:var(--surface-2);border-radius:2px;overflow:hidden}.test-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.progress-hint{text-align:center;font-size:11px;color:var(--text-dim);margin:4px 0 0}.test-results{width:100%;display:flex;justify-content:center}.results-card{max-width:680px;width:100%;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:40px 32px;display:flex;flex-direction:column;gap:16px}.results-card h2{font-size:24px;font-weight:700;margin-bottom:8px}.result-item{display:flex;justify-content:space-between;align-items:center}.result-label{font-size:13px;color:var(--text-dim);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.result-value{font-size:14px;font-weight:600}.type-value{color:var(--accent)}.result-description{font-size:13px;color:var(--text-dim);line-height:1.6;padding:12px;background:var(--surface-2);border-radius:var(--radius)}.severity-bar,.severity-bar-small{width:100%;height:8px;background:var(--surface-2);border-radius:4px;position:relative;overflow:hidden}.severity-bar-small{height:4px;margin-top:4px}.severity-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,#4ade80,#facc15,#ef4444);transition:width .5s ease}.severity-marker{position:absolute;top:-4px;width:4px;height:16px;background:#fff;border-radius:2px;transform:translate(-50%);box-shadow:0 1px 3px #0006}.severity-scale{display:flex;justify-content:space-between;font-size:12px;color:var(--text-dim)}.axis-profile{display:flex;flex-direction:column;gap:10px;padding:16px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.axis-profile>.result-label{margin-bottom:-4px}.axis-profile-hint{font-size:12px;color:var(--text-dim);opacity:.8}.axis-bar-row{display:flex;align-items:center;gap:10px}.axis-bar-row.primary{font-weight:600}.axis-bar-label{font-size:12px;width:120px;flex-shrink:0}.axis-bar-track{flex:1;height:8px;background:var(--surface-2);border-radius:4px;overflow:hidden}.axis-bar-fill{height:100%;border-radius:4px;transition:width .5s ease}.axis-bar-value{font-size:12px;color:var(--text-dim);width:50px;text-align:right;font-variant-numeric:tabular-nums;flex-shrink:0}.confidence-explanation{font-size:12px;color:var(--text-dim);line-height:1.6;margin-top:-4px}.low-confidence-warning{font-size:12px;color:#facc15;padding:8px 12px;background:#facc151a;border-radius:var(--radius);border:1px solid rgba(250,204,21,.2)}.result-stats{display:flex;justify-content:space-between;font-size:12px;color:var(--text-dim);padding-top:8px;border-top:1px solid var(--border)}.continue-btn{width:100%;padding:14px;border:none;border-radius:var(--radius);background:var(--accent);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .15s;margin-top:8px}.continue-btn:hover{background:var(--accent-hover)}.result-disclaimer{font-size:12px;color:var(--text-dim);text-align:center;opacity:.8}.header-feedback{font-size:12px;color:#fbbf24;text-decoration:none;padding:5px 12px;border:1px solid rgba(251,191,36,.4);border-radius:var(--radius);background:#fbbf2414;transition:all .15s;white-space:nowrap;font-weight:500}.header-feedback:hover{border-color:#fbbf24;color:#fde68a;background:#fbbf2426}.view-results-btn{width:100%;padding:10px;border:1px solid var(--accent);border-radius:var(--radius);background:transparent;color:var(--accent);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.view-results-btn:hover{background:var(--accent);color:#fff}.detail-session-id{margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.session-id-section{margin-top:16px;padding:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.session-id-row{display:flex;align-items:center;gap:8px;margin-top:6px}.session-id-code{flex:1;font-family:SF Mono,Menlo,Consolas,monospace;font-size:12px;padding:6px 10px;background:var(--bg);border:1px solid var(--border);border-radius:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;-webkit-user-select:all;user-select:all}.copy-btn{padding:6px 12px;border:1px solid var(--border);border-radius:4px;background:var(--surface);color:var(--text);font-size:12px;cursor:pointer;white-space:nowrap;transition:all .15s}.copy-btn:hover{border-color:var(--accent)}.session-id-hint{font-size:12px;color:var(--text-dim);margin-top:6px;line-height:1.4}.detected-info{display:flex;flex-direction:column;gap:8px;padding:12px;background:var(--surface-2);border-radius:var(--radius)}.detected-row{display:flex;justify-content:space-between;align-items:center;font-size:13px}.detected-key{color:var(--text-dim)}.detected-val{font-weight:600}.skip-test-btn{padding:6px 16px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-dim);font-size:12px;cursor:pointer;transition:all .15s}.skip-test-btn:hover{border-color:var(--accent);color:var(--text)}.sidebar-actions{display:flex;gap:8px;margin-top:4px}.sidebar-actions .view-results-btn,.sidebar-actions .retest-btn{flex:1}.retest-btn{width:100%;padding:10px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-dim);font-size:13px;cursor:pointer;transition:all .15s}.retest-btn:hover{border-color:var(--accent);color:var(--text)}.view-hint{font-size:12px;color:var(--text-dim);opacity:.8;line-height:1.4}.detected-info.compact{display:flex;flex-direction:column;gap:2px}.type-display{font-size:18px;font-weight:700}.type-hint{font-size:12px;color:var(--text-dim);opacity:.8}.detail-hint{font-size:12px;color:var(--text-dim);opacity:.8;line-height:1.4;margin:-4px 0 4px}.results-stages{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.stage-list{display:flex;flex-direction:column;gap:12px;margin-top:8px}.stage-item{display:flex;align-items:flex-start;gap:10px}.stage-dot{flex-shrink:0;width:10px;height:10px;border-radius:50%;margin-top:4px;background:var(--text-dim)}.stage-dot.done{background:var(--accent)}.stage-info{display:flex;flex-direction:column;gap:2px}.stage-name{font-size:13px;font-weight:600}.stage-detail{font-size:12px;color:var(--text-dim)}.go-back-btn{margin-top:8px;padding:8px 20px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-dim);font-size:13px;cursor:pointer;transition:all .15s}.go-back-btn:hover:not(:disabled){border-color:var(--accent);color:var(--text)}.go-back-btn:disabled{opacity:.45;cursor:not-allowed}.plate-test{display:flex;flex-direction:column;align-items:center;gap:20px;padding:16px 0}.plate-instruction{font-size:16px;color:var(--text-dim);text-align:center}.plate-hint{font-size:13px;color:var(--text-dim);opacity:.8}.ishihara-image-container{display:flex;justify-content:center;align-items:center;max-width:340px;width:100%}.ishihara-image{max-width:100%;max-height:340px;border-radius:12px;border:2px solid var(--border);object-fit:contain}.ishihara-input-display{font-size:32px;font-weight:700;min-height:48px;min-width:120px;text-align:center;color:var(--text);border-bottom:2px solid var(--border);padding:4px 16px}.ishihara-placeholder{font-size:16px;font-weight:400;color:var(--text-dim);opacity:.7}.ishihara-keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;max-width:240px;width:100%}.plate-number-btn{padding:14px 0;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-size:20px;font-weight:600;cursor:pointer;transition:all .15s}.plate-number-btn:hover{border-color:var(--accent);background:var(--surface-2)}.plate-number-btn:active{transform:scale(.95)}.plate-number-btn:disabled{opacity:.5;cursor:not-allowed}.ishihara-backspace{font-size:18px}.ishihara-confirm{background:var(--accent);border-color:var(--accent);font-size:14px}.ishihara-confirm:hover:not(:disabled){background:var(--accent-hover)}.ishihara-action-row{display:flex;gap:10px;max-width:320px;width:100%}.ishihara-cant-see-btn,.ishihara-submit-btn{flex:1;padding:14px 8px;border-radius:var(--radius);font-size:15px;font-weight:600;cursor:pointer;transition:all .15s}.ishihara-cant-see-btn{background:var(--surface-2);border:2px solid var(--border);color:var(--text)}.ishihara-cant-see-btn:hover{border-color:var(--accent);background:var(--surface)}.ishihara-submit-btn{background:var(--accent);border:2px solid var(--accent);color:#fff}.ishihara-submit-btn:hover:not(:disabled){background:var(--accent-hover)}.ishihara-submit-btn:disabled{opacity:.5;cursor:not-allowed}.plate-cant-see{margin-top:4px}.plate-stage-header{width:100%;text-align:center;padding-bottom:8px;border-bottom:1px solid var(--border);margin-bottom:8px}.plate-stage-label{font-size:14px;color:var(--text-dim);font-weight:600}.plate-stage-hint{font-size:12px;color:var(--text-dim);opacity:.85;margin-top:6px;line-height:1.5}.detected-axes{display:flex;flex-direction:column;gap:6px;margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}.detected-axis-row{display:flex;align-items:center;gap:8px;font-size:12px}.detected-axis-label{width:90px;flex-shrink:0;font-weight:600}.detected-axis-bar{flex:1;height:4px;background:var(--surface-2);border-radius:2px;overflow:hidden}.detected-axis-fill{height:100%;border-radius:2px;transition:width .3s ease}.detected-axis-val{width:30px;text-align:right;color:var(--text-dim);font-variant-numeric:tabular-nums}.detail-toggle-btn{width:100%;padding:8px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-dim);font-size:12px;cursor:pointer;transition:all .15s;margin-top:4px}.detail-toggle-btn:hover{border-color:var(--accent);color:var(--text)}.detail-panel{display:flex;flex-direction:column;gap:12px;padding:12px;background:var(--surface-2);border-radius:var(--radius);border:1px solid var(--border)}.detail-section-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim)}.detail-stages{display:flex;flex-direction:column;gap:6px}.detail-stage-item{display:flex;flex-direction:column;gap:2px;padding-left:12px;border-left:2px solid var(--accent)}.detail-stage-name{font-size:12px;font-weight:600}.detail-stage-info{font-size:12px;color:var(--text-dim)}.detail-stats{display:flex;justify-content:space-between;font-size:12px;color:var(--text-dim);padding-top:8px;border-top:1px solid var(--border)}.detail-disclaimer{font-size:11px;color:var(--text-dim);opacity:.75;text-align:center}.diagnosis-section{display:flex;flex-direction:column;gap:8px;padding:16px;background:var(--surface-2);border-radius:var(--radius);border:1px solid var(--border)}.diagnosis-badge{display:inline-block;padding:4px 12px;border-radius:4px;font-size:14px;font-weight:700;align-self:flex-start}.diagnosis-badge.normal{background:#4ade8026;color:#4ade80}.diagnosis-badge.anomalous{background:#facc1526;color:#facc15}.diagnosis-badge.dichromat{background:#ef444426;color:#ef4444}.compound-badge,.ambiguous-badge{display:inline-block;padding:3px 10px;border-radius:4px;font-size:12px;font-weight:600;align-self:flex-start}.compound-badge{background:#a855f726;color:#a855f7}.ambiguous-badge{background:#eab30826;color:#ca8a04}.diagnosis-explanation{font-size:12px;color:var(--text-dim);line-height:1.6}.axis-data-section{display:flex;flex-direction:column;gap:8px;padding:16px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.axis-data-table{width:100%;border-collapse:collapse;font-size:12px}.axis-data-table th{text-align:left;padding:6px 8px;font-size:12px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border)}.axis-data-table td{padding:8px;vertical-align:top}.axis-data-table .primary-row{background:var(--surface-2)}.mono-val{font-variant-numeric:tabular-nums;font-weight:600}.axis-sev-badge{font-weight:600;margin-right:4px}.axis-sev-pct{font-size:12px;color:var(--text-dim)}.clinical-note{font-size:12px;color:var(--text-dim);line-height:1.4}.differential-note{display:flex;flex-direction:column;gap:6px;padding:12px;background:var(--surface-2);border-radius:var(--radius);border-left:3px solid var(--accent)}.differential-note p{font-size:12px;color:var(--text);line-height:1.6}.methodology-toggle{width:100%;padding:8px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--text-dim);font-size:12px;cursor:pointer;transition:all .15s}.methodology-toggle:hover{border-color:var(--accent);color:var(--text)}.methodology-section{display:flex;flex-direction:column;gap:12px;padding:12px;background:var(--surface-2);border-radius:var(--radius);border:1px solid var(--border)}.methodology-item{font-size:12px;line-height:1.6}.methodology-item strong{display:block;font-size:12px;color:var(--text);margin-bottom:4px}.methodology-item p{color:var(--text-dim);margin:0}.sidebar-axis-row{display:flex;align-items:center;gap:8px;padding:2px 0;white-space:nowrap}.sidebar-axis-row.primary{font-weight:600}.sidebar-axis-label{font-size:12px;width:48px;flex-shrink:0;font-weight:600}.sidebar-axis-track{flex:1;min-width:80px;height:6px;background:var(--surface-2);border-radius:3px;overflow:hidden}.sidebar-axis-fill{height:100%;border-radius:3px;transition:width .3s ease}.sidebar-axis-val{font-size:12px;color:var(--text);width:32px;text-align:right;flex-shrink:0;font-family:SF Mono,Menlo,monospace}.sidebar-axis-severity{font-size:11px;color:var(--text-dim);text-align:right;flex-shrink:0;white-space:nowrap}.sidebar-axis-status{font-size:11px;color:var(--text-dim);opacity:.8;text-align:right;flex-shrink:0;white-space:nowrap}.axis-primary-badge{display:inline-block;margin-left:6px;padding:1px 6px;border-radius:3px;font-size:10px;font-weight:600;background:var(--accent);color:#fff;vertical-align:middle;text-transform:uppercase;letter-spacing:.04em}.axis-status-dim{color:var(--text-dim);opacity:.8;font-size:12px}.axis-secondary-note{font-size:12px;color:var(--text-dim);opacity:.8;line-height:1.5;margin-top:4px}.detail-diagnosis{padding:8px 0}.diagnosis-badge-sm{display:inline-block;padding:2px 8px;border-radius:4px;font-size:12px;font-weight:600}.diagnosis-badge-sm.normal{background:#166534;color:#86efac}.diagnosis-badge-sm.anomalous{background:#854d0e;color:#fde047}.diagnosis-badge-sm.dichromat{background:#991b1b;color:#fca5a5}.detail-diagnosis-explain{font-size:12px;color:var(--text-dim);margin-top:6px;line-height:1.5}.detail-axis-table{display:flex;flex-direction:column;gap:2px;margin:8px 0;font-size:12px}.detail-axis-header{display:grid;grid-template-columns:1fr 70px 80px;gap:4px;color:var(--text-dim);font-size:11px;text-transform:uppercase;padding-bottom:4px;border-bottom:1px solid var(--border)}.detail-axis-row{display:grid;grid-template-columns:1fr 70px 80px;gap:4px;padding:3px 0}.detail-axis-row.primary{font-weight:600}.detail-clinical-note{font-size:12px;color:var(--text-dim);padding-left:8px;border-left:2px solid;margin:4px 0}.detail-differential{margin:8px 0}.detail-differential p{font-size:12px;color:var(--text-dim);line-height:1.5}.mono-val{font-family:SF Mono,Menlo,monospace}.correction-preview{display:flex;flex-direction:column;gap:12px;padding:16px 0;border-top:1px solid var(--border)}.correction-preview-hint{font-size:12px;color:var(--text-dim);line-height:1.5}.correction-preview-images{display:flex;gap:12px;align-items:center;justify-content:center}.correction-preview-side{display:flex;flex-direction:column;align-items:center;gap:8px}.correction-preview-canvas{max-width:200px;max-height:200px;border-radius:8px;border:1px solid var(--border)}.correction-preview-divider{width:1px;height:180px;background:var(--border);flex-shrink:0}.correction-preview-label{font-size:12px;color:var(--text-dim);font-weight:600}.correction-preview-answer{font-size:12px;color:var(--text-dim);text-align:center}.correction-preview-triple{display:flex;gap:8px;align-items:center;justify-content:center}.correction-preview-triple .correction-preview-canvas{max-width:160px;max-height:160px}.correction-preview-triple .correction-preview-divider{height:140px}.feedback-widget{margin-top:24px;padding-top:20px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:12px}.feedback-title{font-size:15px;font-weight:600;text-align:center;color:var(--text-dim)}.feedback-rating-label{font-size:13px;color:var(--text-dim);text-align:center}.feedback-stars{display:flex;justify-content:center;gap:8px}.feedback-star{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:4px;border-radius:4px;transition:all .1s}.feedback-star:hover{transform:scale(1.15)}.feedback-star.active{color:#facc15}.feedback-comment{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:13px;font-family:inherit;resize:vertical;outline:none;transition:border-color .15s}.feedback-comment:focus{border-color:var(--accent)}.feedback-comment::placeholder{color:var(--text-dim);opacity:.7}.feedback-submit-btn{padding:10px;border:none;border-radius:var(--radius);background:var(--accent);color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.feedback-submit-btn:hover:not(:disabled){background:var(--accent-hover)}.feedback-submit-btn:disabled{opacity:.55;cursor:not-allowed}.feedback-thanks{font-size:14px;font-weight:600;text-align:center;padding:12px 0;color:var(--accent)}@media(max-width:768px){.main{flex-direction:column}.sidebar{width:100%;min-width:0;border-right:none;border-bottom:1px solid var(--border);max-height:40vh}}.lp{min-height:100vh;background:var(--bg);color:var(--text);overflow-x:hidden}.lp-nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:14px 0;transition:background .3s,border-color .3s;border-bottom:1px solid transparent}.lp-nav.scrolled{background:var(--bg);border-bottom-color:var(--border)}.lp-nav-inner{max-width:1140px;margin:0 auto;padding:0 32px;display:flex;align-items:center;gap:32px}.lp-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text);font-weight:700;font-size:18px;flex-shrink:0}.lp-logo img{width:28px;height:28px;border-radius:6px}.lp-nav-links{display:flex;gap:8px;margin-left:auto}.lp-nav-links button{background:none;border:none;color:var(--text-dim);font-size:14px;cursor:pointer;padding:6px 12px;border-radius:6px;transition:color .15s,background .15s}.lp-nav-links button:hover{color:var(--text);background:var(--surface)}.lp-nav-right{display:flex;align-items:center;gap:12px}.lp-nav-cta{padding:8px 20px;background:var(--accent);color:#fff;font-size:14px;font-weight:600;border-radius:8px;text-decoration:none;transition:background .15s;white-space:nowrap}.lp-nav-cta:hover{background:var(--accent-hover)}.lp-hero{position:relative;padding:160px 32px 100px;text-align:center;overflow:hidden}.lp-hero-glow{position:absolute;border-radius:50%;filter:blur(100px);pointer-events:none}.lp-hero-glow-1{width:500px;height:500px;background:#4f46e5;top:-180px;left:50%;transform:translate(-50%);opacity:.15;animation:lp-glow-float 10s ease-in-out infinite alternate}.lp-hero-glow-2{width:400px;height:400px;background:#7c3aed;top:-100px;right:-100px;opacity:.1;animation:lp-glow-float 12s ease-in-out infinite alternate-reverse}.lp-hero-glow-3{width:350px;height:350px;background:#2563eb;top:50px;left:-80px;opacity:.08;animation:lp-glow-float 14s ease-in-out infinite alternate}@keyframes lp-glow-float{0%{transform:translateY(0) scale(1)}to{transform:translateY(40px) scale(1.15)}}.lp-hero-content{position:relative;max-width:720px;margin:0 auto}.lp-hero-badge{display:inline-block;padding:6px 16px;border:1px solid var(--border);border-radius:100px;font-size:13px;color:var(--accent);font-weight:500;margin-bottom:28px;letter-spacing:.02em}.lp-hero-title{font-size:56px;font-weight:800;line-height:1.1;letter-spacing:-.03em;margin-bottom:24px}.lp-hero-word{display:inline-block;opacity:0;transform:translateY(24px) scale(.95);filter:blur(6px);animation:lp-word-appear .6s cubic-bezier(.16,1,.3,1) forwards}.lp-hero-word-1{animation-delay:.5s}.lp-hero-word-2{animation-delay:.75s}.lp-hero-word-3{animation-delay:1s}@keyframes lp-word-appear{to{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}}.lp-rainbow-text{background:linear-gradient(90deg,#f44,#f83,#fc0,#3c3,#39f,#93f,#f44);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:lp-word-appear .6s cubic-bezier(.16,1,.3,1) forwards,lp-rainbow-shift 4s linear 1.6s infinite}@keyframes lp-rainbow-shift{0%{background-position:0% center}to{background-position:200% center}}.lp-hero-subtitle{font-size:18px;line-height:1.7;color:var(--text-dim);max-width:560px;margin:0 auto 36px}.lp-hero-ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:48px}.lp-btn-primary{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;background:linear-gradient(135deg,#6366f1,#818cf8);color:#fff;font-size:16px;font-weight:600;border-radius:10px;text-decoration:none;border:none;cursor:pointer;transition:transform .15s,box-shadow .15s}.lp-btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 24px #6366f14d}.lp-btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;background:var(--surface);color:var(--text);font-size:16px;font-weight:600;border-radius:10px;border:1px solid var(--border);text-decoration:none;cursor:pointer;transition:border-color .15s,background .15s}.lp-btn-secondary:hover{border-color:var(--accent);background:var(--surface-2)}.lp-hero-stats{display:flex;justify-content:center;align-items:center;gap:32px}.lp-stat{display:flex;flex-direction:column;align-items:center;gap:4px}.lp-stat-num{font-size:28px;font-weight:800;color:var(--text);letter-spacing:-.02em}.lp-stat-label{font-size:13px;color:var(--text-dim)}.lp-stat-sep{width:1px;height:40px;background:var(--border)}.lp-section{padding:100px 32px}.lp-section-dark{background:var(--surface)}.lp-container{max-width:1080px;margin:0 auto}.lp-section-title{font-size:36px;font-weight:800;text-align:center;margin-bottom:12px;letter-spacing:-.02em}.lp-section-subtitle{font-size:16px;color:var(--text-dim);text-align:center;max-width:560px;margin:0 auto 48px;line-height:1.6}.reveal{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}.reveal.revealed{opacity:1;transform:translateY(0)}.lp-steps{display:flex;align-items:flex-start;gap:16px;justify-content:center}.lp-step{flex:1;max-width:280px;text-align:center;padding:32px 24px;border:1px solid var(--border);border-radius:16px;background:var(--surface);transition:border-color .2s,transform .2s}.lp-step:hover{border-color:var(--accent);transform:translateY(-4px)}.lp-step-num{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#818cf8);color:#fff;font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.lp-step h3{font-size:18px;font-weight:700;margin-bottom:10px}.lp-step p{font-size:14px;color:var(--text-dim);line-height:1.6}.lp-step-arrow{display:flex;align-items:center;padding-top:64px;color:var(--text-dim);flex-shrink:0}.lp-compare{display:flex;align-items:center;gap:20px;justify-content:center}.lp-compare-card{flex:1;max-width:480px;display:flex;flex-direction:column;align-items:center;gap:14px}.lp-compare-img-wrap{border-radius:12px;overflow:hidden;border:2px solid var(--border);transition:border-color .2s,transform .2s}.lp-compare-img-wrap:hover{border-color:var(--accent);transform:scale(1.02)}.lp-compare-img-wrap img{width:100%;display:block}.lp-compare-label{font-size:14px;font-weight:600;padding:6px 16px;border-radius:100px}.lp-compare-before{background:#1e1e2e;color:var(--text-dim)}.lp-compare-after{background:linear-gradient(135deg,#6366f1,#818cf8);color:#fff}.lp-compare-divider{flex-shrink:0;color:var(--accent);animation:lp-arrow-pulse 2s ease-in-out infinite}@keyframes lp-arrow-pulse{0%,to{transform:translate(0);opacity:.5}50%{transform:translate(6px);opacity:1}}.lp-compare-note{font-size:14px;color:var(--text-dim);text-align:center;margin-top:24px;max-width:600px;margin-left:auto;margin-right:auto;line-height:1.6}.lp-features-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.lp-feature-card{padding:32px 28px;border:1px solid var(--border);border-radius:16px;background:var(--surface);transition:border-color .2s,transform .2s}.lp-feature-card:hover{border-color:var(--accent);transform:translateY(-4px)}.lp-feature-icon{color:var(--accent);margin-bottom:16px}.lp-feature-card h3{font-size:18px;font-weight:700;margin-bottom:10px}.lp-feature-card p{font-size:14px;color:var(--text-dim);line-height:1.6}.lp-extension-showcase{display:flex;gap:48px;align-items:center}.lp-extension-images{display:flex;gap:16px;flex-shrink:0}.lp-extension-img-card{border-radius:16px;overflow:hidden;border:2px solid var(--border);transition:border-color .2s,transform .2s}.lp-extension-img-card:hover{border-color:var(--accent);transform:translateY(-4px)}.lp-extension-img-card img{width:240px;display:block}.lp-extension-features{display:flex;flex-direction:column;gap:16px}.lp-ext-feature{display:flex;align-items:center;gap:12px;font-size:15px;color:var(--text)}.lp-ext-feature svg{color:#4ade80;flex-shrink:0}.lp-ext-cta{margin-top:8px;align-self:flex-start}.lp-test-preview{display:flex;gap:48px;align-items:center}.lp-test-preview-img{position:relative;flex-shrink:0;width:340px;border-radius:16px;overflow:hidden;border:2px solid var(--border)}.lp-test-preview-img img{width:100%;display:block}.lp-test-preview-fade{position:absolute;bottom:0;left:0;right:0;height:120px;background:linear-gradient(to top,var(--bg) 0%,transparent 100%);pointer-events:none}.lp-test-preview-info{display:flex;flex-direction:column;gap:24px}.lp-preview-item{display:flex;gap:14px}.lp-preview-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);margin-top:7px;flex-shrink:0}.lp-preview-item strong{display:block;font-size:16px;font-weight:700;margin-bottom:4px}.lp-preview-item p{font-size:14px;color:var(--text-dim);line-height:1.6}.lp-testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.lp-testimonial-card{padding:28px 24px;border:1px solid var(--border);border-radius:16px;background:var(--bg);display:flex;flex-direction:column;gap:14px;transition:border-color .2s,transform .2s}.lp-testimonial-card:hover{border-color:var(--accent);transform:translateY(-2px)}.lp-quote-icon{color:var(--accent)}.lp-testimonial-quote{font-size:14px;line-height:1.7;color:var(--text);flex:1}.lp-testimonial-footer{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid var(--border)}.lp-testimonial-author{font-size:13px;font-weight:600;color:var(--text)}.lp-testimonial-context{font-size:12px;color:var(--accent);padding:2px 10px;border-radius:100px;background:#1e1b4b}.lp-desktop-section{text-align:center;background:linear-gradient(180deg,var(--surface) 0%,var(--bg) 100%)}.lp-desktop-badge{display:inline-block;padding:6px 16px;border-radius:100px;font-size:13px;font-weight:600;color:#c084fc;border:1px solid #7c3aed;margin-bottom:20px}.lp-desktop-features{display:flex;gap:40px;justify-content:center;margin-bottom:24px}.lp-desktop-feature{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;max-width:200px}.lp-desktop-feature-num{font-size:32px;font-weight:800;background:linear-gradient(135deg,#c084fc,#818cf8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.lp-desktop-feature span:last-child{font-size:14px;color:var(--text-dim);line-height:1.5}.lp-desktop-hint{font-size:14px;color:var(--text-dim)}.lp-subscribe-section{text-align:center}.lp-subscribe-hero{display:flex;flex-direction:column;align-items:center;gap:16px}.lp-subscribe-note{font-size:13px;color:var(--text-dim)}.lp-subscribe-form{display:flex;gap:10px;max-width:420px;width:100%}.lp-subscribe-form-lg{max-width:520px}.lp-subscribe-input{flex:1;padding:12px 16px;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--text);font-size:14px;outline:none;transition:border-color .15s}.lp-subscribe-input-lg{padding:16px 20px;font-size:16px;border-radius:12px}.lp-subscribe-input:focus{border-color:var(--accent)}.lp-subscribe-input::placeholder{color:var(--text-dim)}.lp-subscribe-btn{padding:12px 24px;background:linear-gradient(135deg,#6366f1,#818cf8);color:#fff;font-size:14px;font-weight:600;border:none;border-radius:10px;cursor:pointer;white-space:nowrap;transition:transform .15s,box-shadow .15s}.lp-subscribe-btn-lg{padding:16px 32px;font-size:16px;border-radius:12px}.lp-subscribe-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #6366f14d}.lp-subscribe-btn:disabled{opacity:.5;cursor:not-allowed}.lp-subscribe-thanks{font-size:15px;font-weight:600;color:#4ade80}.lp-subscribe-error{font-size:13px;color:#ef4444}.lp-footer{border-top:1px solid var(--border);padding:48px 32px 32px;background:var(--bg)}.lp-footer-inner{max-width:1080px;margin:0 auto;display:flex;justify-content:space-between;gap:48px}.lp-footer-brand{display:flex;align-items:flex-start;gap:12px}.lp-footer-brand img{width:32px;height:32px;border-radius:8px}.lp-footer-brand strong{display:block;font-size:15px}.lp-footer-brand span{font-size:13px;color:var(--text-dim)}.lp-footer-copyright{display:block;font-size:11px;color:var(--text-dim);opacity:.6;margin-top:6px}.lp-footer-links{display:flex;gap:64px}.lp-footer-col{display:flex;flex-direction:column;gap:10px}.lp-footer-col strong{font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);margin-bottom:4px}.lp-footer-col a,.lp-footer-col button{background:none;border:none;color:var(--text);font-size:14px;text-decoration:none;cursor:pointer;padding:0;text-align:left;transition:color .15s}.lp-footer-col a:hover,.lp-footer-col button:hover{color:var(--accent)}.lp-footer-dim{font-size:13px;color:var(--text-dim)}.lp-nav-signin{padding:8px 20px;border-radius:8px;border:1px solid var(--border);color:var(--text);font-size:14px;font-weight:500;text-decoration:none;transition:all .2s;white-space:nowrap}.lp-nav-signin:hover{border-color:var(--accent);color:var(--accent);background:#818cf814}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:24px}.auth-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px;display:flex;flex-direction:column;gap:20px}.auth-back{display:inline-flex;align-items:center;gap:6px;color:var(--text-dim);font-size:14px;text-decoration:none;transition:color .2s;align-self:flex-start}.auth-back:hover{color:var(--text)}.auth-logo{display:flex;justify-content:center}.auth-logo img{width:48px;height:48px;border-radius:12px}.auth-tabs{display:flex;gap:0;border-bottom:1px solid var(--border)}.auth-tab{flex:1;padding:10px 0;background:none;border:none;color:var(--text-dim);font-size:15px;font-weight:500;cursor:pointer;position:relative;transition:color .2s}.auth-tab:hover{color:var(--text)}.auth-tab.active{color:var(--accent)}.auth-tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--accent);border-radius:1px}.auth-form{display:flex;flex-direction:column;gap:12px}.auth-input{width:100%;padding:12px 14px;background:var(--bg);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:15px;outline:none;transition:border-color .2s;box-sizing:border-box}.auth-input:focus{border-color:var(--accent)}.auth-input::placeholder{color:var(--text-dim)}.auth-error{color:#ef4444;font-size:13px;margin:0}.auth-submit{width:100%;padding:12px;background:linear-gradient(135deg,var(--accent),#a78bfa);border:none;border-radius:10px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:opacity .2s}.auth-submit:hover{opacity:.9}.auth-submit:disabled{opacity:.5;cursor:not-allowed}.auth-divider{display:flex;align-items:center;gap:12px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-divider span{color:var(--text-dim);font-size:13px;white-space:nowrap}.auth-oauth{display:flex;flex-direction:column;gap:10px}.auth-oauth-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:11px;background:none;border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.auth-oauth-btn:hover{border-color:var(--text-dim);background:#ffffff08}.auth-confirmation{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px 0;text-align:center}.auth-confirmation h2{font-size:18px;color:var(--text);margin:0}.auth-confirmation-sub{color:var(--text-dim);font-size:14px;margin:0}.user-menu{position:relative}.user-menu-btn{display:flex;align-items:center;gap:8px;padding:6px 10px;background:none;border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;transition:all .2s;white-space:nowrap}.user-menu-btn:hover{border-color:var(--accent)}.user-menu-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover}.user-menu-initials{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent),#a78bfa);color:#fff;font-size:13px;font-weight:600}.user-menu-name{font-size:14px;max-width:120px;overflow:hidden;text-overflow:ellipsis}.user-menu-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:200px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:6px;z-index:100;box-shadow:0 8px 24px #0006}.user-menu-email{padding:8px 10px;font-size:12px;color:var(--text-dim);border-bottom:1px solid var(--border);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis}.user-menu-option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;background:none;border:none;border-radius:6px;color:var(--text);font-size:14px;cursor:pointer;transition:background .15s}.user-menu-option:hover{background:#ffffff0f}@media(max-width:900px){.lp-hero-title{font-size:40px}.lp-hero-subtitle{font-size:16px}.lp-steps{flex-direction:column;align-items:center}.lp-step-arrow{transform:rotate(90deg);padding-top:0}.lp-compare{flex-direction:column}.lp-compare-divider{transform:rotate(90deg)}.lp-features-grid{grid-template-columns:1fr}.lp-extension-showcase{flex-direction:column}.lp-extension-images{justify-content:center}.lp-test-preview{flex-direction:column}.lp-test-preview-img{width:100%;max-width:340px}.lp-testimonials{grid-template-columns:1fr}.lp-desktop-features{flex-direction:column;align-items:center;gap:24px}.lp-footer-inner{flex-direction:column;gap:32px}.lp-footer-links{gap:32px;flex-wrap:wrap}.lp-nav-links{display:none}.lp-hero-stats{flex-direction:column;gap:16px}.lp-stat-sep{width:40px;height:1px}.lp-section{padding:60px 20px}.lp-hero{padding:120px 20px 60px}.lp-section-title{font-size:28px}}@media(max-width:500px){.lp-hero-title{font-size:32px}.lp-hero-ctas{flex-direction:column;align-items:center}.lp-btn-primary,.lp-btn-secondary{width:100%;justify-content:center}.lp-extension-img-card img{width:160px}}
