:root{--color-primary:#0891b2;--color-primary-light:#22d3ee;--color-primary-dark:#0e7490;--color-primary-bg:#ecfeff;--color-bg:#f8fafc;--color-surface:#fff;--color-surface-alt:#f1f5f9;--color-border:#e2e8f0;--color-text:#0f172a;--color-text-secondary:#64748b;--color-text-muted:#94a3b8;--color-success:#16a34a;--color-warning:#d97706;--color-error:#dc2626;--color-clinical-bg:#1e1e2e;--color-clinical-surface:#2a2a3c;--color-clinical-text:#e2e8f0;--font-sans:"Inter", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-full:9999px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--transition-fast:.15s ease;--transition-base:.25s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);overscroll-behavior-y:none;-webkit-overflow-scrolling:touch;min-height:100vh;line-height:1.5}body.case-locked{width:100%;height:100%;position:fixed;inset:0;overflow:hidden}html:has(body.case-locked){width:100%;height:100%;position:fixed;inset:0;overflow:hidden}body.case-locked #root{height:100%;overflow:hidden}a{color:inherit}img,video{max-width:100%;display:block}main.case-fullscreen{height:100dvh;overflow:hidden;max-width:none!important;padding:0!important}.btn{justify-content:center;align-items:center;gap:var(--space-2);font-family:var(--font-sans);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast), box-shadow var(--transition-fast);white-space:nowrap;border:none;font-weight:600;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-sm{font-size:var(--text-sm);padding:var(--space-2) var(--space-4)}.btn-md{font-size:var(--text-base);padding:var(--space-3) var(--space-5)}.btn-lg{font-size:var(--text-base);padding:var(--space-3) var(--space-8)}.btn-block{width:100%}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark)}.btn-saved{color:#fff;background:#16a34a}.btn-saved:hover:not(:disabled){background:#15803d}.btn-outline{color:var(--color-primary);border:1px solid var(--color-primary);background:0 0}.btn-outline:hover:not(:disabled){background:var(--color-primary-bg)}.loading-screen{justify-content:center;align-items:center;min-height:60vh;display:flex}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:36px;height:36px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.navbar{background:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:100;position:sticky;top:0}.navbar-inner{max-width:1200px;padding:var(--space-3) var(--space-4);justify-content:space-between;align-items:center;margin:0 auto;display:flex}.navbar-brand{align-items:center;gap:var(--space-2);color:var(--color-text);font-weight:700;font-size:var(--text-lg);text-decoration:none;display:flex}.brand-icon{font-size:var(--text-xl)}.navbar-links{align-items:center;gap:var(--space-4);display:flex}.nav-link{color:var(--color-text-secondary);font-size:var(--text-sm);transition:color var(--transition-fast);font-weight:500;text-decoration:none}.nav-link:hover{color:var(--color-primary)}.nav-admin{color:var(--color-warning);font-weight:600}.nav-user{color:var(--color-text-secondary);font-size:var(--text-sm)}@media (width<=600px){.brand-text{font-size:var(--text-sm)}.nav-user{display:none}}.landing{max-width:960px;padding:var(--space-8) var(--space-4);margin:0 auto}.hero{text-align:center;padding:var(--space-16) 0 var(--space-12)}.hero h1{font-size:clamp(var(--text-2xl), 5vw, var(--text-3xl));color:var(--color-text);margin-bottom:var(--space-4);line-height:1.2}.hero-subtitle{font-size:var(--text-lg);color:var(--color-text-secondary);max-width:600px;margin:0 auto var(--space-8);line-height:1.6}.hero-actions{gap:var(--space-4);flex-wrap:wrap;justify-content:center;display:flex}.features{gap:var(--space-6);padding:var(--space-8) 0;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));display:grid}.feature-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);text-align:center}.feature-icon{margin-bottom:var(--space-3);font-size:2rem}.feature-card h3{font-size:var(--text-lg);margin-bottom:var(--space-2);color:var(--color-text)}.feature-card p{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.5}.landing-footer{text-align:center;padding-top:var(--space-12);color:var(--color-text-muted);font-size:var(--text-sm)}.landing-footer a{color:var(--color-primary);text-decoration:none}.landing-footer a:hover{text-decoration:underline}.auth-page{padding:var(--space-12) var(--space-4);justify-content:center;align-items:flex-start;min-height:calc(100vh - 60px);display:flex}.auth-form{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-8);width:100%;max-width:420px;box-shadow:var(--shadow-md)}.auth-form h2{font-size:var(--text-2xl);margin-bottom:var(--space-2);color:var(--color-text)}.auth-subtitle{color:var(--color-text-secondary);font-size:var(--text-sm);margin-bottom:var(--space-6)}.auth-form label{font-size:var(--text-sm);color:var(--color-text);margin-bottom:var(--space-4);font-weight:500;display:block}.label-optional{color:var(--color-text-muted);font-weight:400}.auth-form input{width:100%;margin-top:var(--space-1);padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--color-text);background:var(--color-bg);transition:border-color var(--transition-fast);box-sizing:border-box;display:block}.auth-form input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #0891b226}.auth-error{color:var(--color-error);border-radius:var(--radius-md);padding:var(--space-3);font-size:var(--text-sm);margin-bottom:var(--space-4);background:#fef2f2;border:1px solid #fecaca}.auth-switch{text-align:center;font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-4)}.auth-switch a{color:var(--color-primary);font-weight:500;text-decoration:none}.auth-switch a:hover{text-decoration:underline}.cases-page{max-width:1100px;padding:var(--space-8) var(--space-4);margin:0 auto}.cases-header{margin-bottom:var(--space-6)}.cases-header h1{font-size:var(--text-2xl);margin-bottom:var(--space-2)}.cases-header p{color:var(--color-text-secondary);font-size:var(--text-base)}.cases-filters{gap:var(--space-2);margin-bottom:var(--space-6);flex-wrap:wrap;display:flex}.filter-chip{padding:var(--space-2) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-surface);color:var(--color-text-secondary);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast)}.filter-chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.filter-chip.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.cases-grid{gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.case-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-base), transform var(--transition-base);overflow:hidden}.case-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.case-thumb{background:var(--color-surface-alt);justify-content:center;align-items:center;height:160px;display:flex;position:relative}.case-thumb img{object-fit:cover;width:100%;height:100%}.case-thumb-placeholder{opacity:.25;font-size:3rem}.case-difficulty{top:var(--space-2);right:var(--space-2);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);color:#fff;text-transform:capitalize;font-weight:600;position:absolute}.case-body{padding:var(--space-4)}.case-category{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-primary);font-weight:600}.case-title{font-size:var(--text-lg);margin:var(--space-1) 0 var(--space-2);color:var(--color-text)}.case-patient{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-4)}.talking-head{width:100%}.avatar-scene{aspect-ratio:16/10;border-radius:var(--radius-lg);width:100%;box-shadow:var(--shadow-lg);border:2px solid var(--color-border);background:#1a1a2e;transition:border-color .3s;position:relative;overflow:hidden}.avatar-scene.speaking{border-color:var(--color-primary)}.face-video{object-fit:cover;object-position:center 20%;pointer-events:none;width:100%;height:100%;transition:opacity .25s;position:absolute;inset:0}.video-visible{opacity:1}.video-hidden{opacity:0}.face-img{object-fit:cover;object-position:center 20%;width:100%;height:100%;position:absolute;inset:0}.audio-wave-bar{z-index:5;pointer-events:none;background:#0000004d;border-radius:14px;align-items:flex-end;gap:3px;height:28px;padding:4px 8px;display:flex;position:absolute;bottom:36px;left:50%;transform:translate(-50%)}.wave-bar{background:var(--color-primary);opacity:.9;border-radius:2px;width:3px;height:4px;animation:.5s ease-in-out infinite alternate wave-bounce}@keyframes wave-bounce{0%{height:4px}to{height:22px}}.avatar-name-bar{padding:var(--space-2) var(--space-3);align-items:center;gap:var(--space-2);z-index:10;background:linear-gradient(#0000,#0009);display:flex;position:absolute;bottom:0;left:0;right:0}.avatar-name{font-size:var(--text-sm);color:#fff;text-shadow:0 1px 3px #00000080;font-weight:600}.speaking-dot{background:var(--color-primary);border-radius:50%;width:8px;height:8px;animation:1s ease-in-out infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}.avatar-placeholder{width:100%;height:100%;color:var(--color-primary);background:var(--color-primary-bg);justify-content:center;align-items:center;font-size:4rem;font-weight:700;display:flex}@media (width<=600px){.avatar-scene{aspect-ratio:16/9;border-radius:var(--radius-md)}}.chat-window{flex-direction:column;flex:1;gap:6px;padding:8px 10px;display:flex;overflow-y:auto}.chat-bubble{border-radius:var(--radius-lg);max-width:82%;padding:6px 10px;font-size:12px;line-height:1.45}.chat-bubble.user{background:var(--color-primary);color:#fff;align-self:flex-end}.chat-bubble.assistant{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);align-self:flex-start}.chat-role{opacity:.65;margin-bottom:2px;font-size:10px;font-weight:600;display:block}.typing-indicator{padding:var(--space-1) 0;gap:4px;display:flex}.typing-indicator span{background:var(--color-text-muted);border-radius:50%;width:8px;height:8px;animation:1.2s infinite typingBounce}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}@media (width<=600px){.chat-bubble{max-width:90%}}.chat-input{gap:var(--space-2);padding:var(--space-3) var(--space-4);border-top:1px solid var(--color-border);background:var(--color-surface);display:flex}.chat-input input{padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:16px;font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);flex:1}.chat-input input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #0891b226}.quick-scroll-row{-webkit-overflow-scrolling:touch;scrollbar-width:none;background:#fff;border-bottom:1px solid #e8eaed;flex-shrink:0;gap:7px;padding:8px 14px;display:flex;overflow-x:auto}.quick-scroll-row::-webkit-scrollbar{display:none}.quick-pill{color:#5a6a7a;white-space:nowrap;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#fff;border:1.5px solid #d0d8e4;border-radius:20px;flex-shrink:0;align-items:center;gap:4px;padding:6px 12px;font-size:12px;font-weight:600;transition:all .12s;display:flex}.quick-pill:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.quick-pill.asked{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.quick-pill:disabled{opacity:.45;cursor:not-allowed}.history-section{background:#f4f6f8;flex-direction:column;height:100%;display:flex;overflow:hidden}.history-left{flex-direction:column;flex-shrink:0;display:flex}.history-right{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.history-notes-btn{background:var(--color-primary);color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;letter-spacing:.02em;border:none;border-radius:0;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px;font-size:14px;font-weight:700;transition:opacity .15s;display:flex}.history-notes-btn:active{opacity:.88}.history-notes-desktop{display:none}.history-notes-mobile{flex-shrink:0;display:block}.history-patient{background:#1a1a2e;flex-shrink:0;height:22dvh;min-height:150px;max-height:220px;position:relative;overflow:hidden}.history-patient .talking-head{height:100%}.history-patient .avatar-scene{aspect-ratio:auto;border-radius:0;height:100%}.history-patient .face-video,.history-patient .face-img{object-fit:cover;width:100%;height:100%}.history-patient .avatar-name-bar{display:none}.live-badge{color:#fff;letter-spacing:.06em;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000008c;border-radius:20px;align-items:center;gap:5px;padding:4px 8px;font-size:10px;font-weight:800;display:flex;position:absolute;top:10px;left:12px}.live-dot{background:#f44;border-radius:50%;width:6px;height:6px;animation:1.5s infinite livePulse}@keyframes livePulse{0%,to{opacity:1}50%{opacity:.4}}.patient-overlay{background:linear-gradient(#0000,#000000bf);flex-direction:column;gap:2px;padding:14px 12px 8px;display:flex;position:absolute;bottom:0;left:0;right:0}.overlay-name{color:#fff;font-size:12px;font-weight:700}.overlay-quote{color:#ffffffd9;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:11px;font-style:italic;line-height:1.3;display:-webkit-box;overflow:hidden}@media (width>=600px){.patient-overlay{padding:20px 14px 12px}.overlay-name{font-size:13px}.overlay-quote{-webkit-line-clamp:unset;font-size:12px;line-height:1.4}}.conversation-label{color:#8a9aaa;text-transform:uppercase;letter-spacing:.06em;flex-shrink:0;padding:4px 14px 2px;font-size:10px;font-weight:700}@media (width>=600px){.conversation-label{padding:8px 14px 4px;font-size:11px}}.history-chat-area{background:#f4f6f8;flex:1;min-height:0;overflow-y:auto}.history-input-area{background:#fff;border-top:1px solid #e8eaed;flex-shrink:0}@media (width>=600px){.history-section{flex-direction:row}.history-left{border-right:1px solid #e0e4e8;flex-shrink:0;width:280px;overflow:hidden}.history-patient{flex:1;height:auto;min-height:0;max-height:none}.history-notes-desktop{flex-shrink:0;display:block}.history-notes-desktop .history-notes-btn{border-top:1px solid #ffffff26;border-radius:0}.history-notes-mobile{display:none}.history-right{flex:1;min-width:0}}@media (width>=900px){.history-left{width:340px}}@media (width>=1200px){.history-left{width:400px}}.slitlamp-sim{flex-direction:column;width:100%;height:100%;display:flex}.illum-bar{background:linear-gradient(#1a1a28 0%,#0f0f1a 100%);border-bottom:1px solid #ffffff14;flex-direction:column;flex-shrink:0;gap:1px;padding:2px 10px 5px;display:flex}.illum-bar-bottom{background:linear-gradient(#0f0f1a 0%,#1a1a28 100%);border-top:1px solid #ffffff14;border-bottom:none}.illum-scale-label{letter-spacing:.2em;color:#ffffff2e;text-transform:uppercase;justify-content:center;align-items:center;gap:6px;font-size:7px;font-weight:900;display:flex}.illum-scale-line{background:linear-gradient(90deg,#0000,#ffffff0f,#0000);flex:1;height:1px}.illum-dial{align-items:center;gap:0;display:flex}.illum-notch{background:#ffffff14;flex-shrink:0;width:1px;height:16px}.illum-tab{cursor:pointer;-webkit-tap-highlight-color:transparent;background:#ffffff05;border:1px solid #ffffff0f;border-radius:5px;flex-direction:column;flex:1;align-items:center;gap:3px;margin:0 1px;padding:5px 3px;transition:all .15s cubic-bezier(.2,.6,.3,1);display:flex}.illum-tab:active{background:#ffffff0d;transform:translateY(1px)}.illum-tab.dim{opacity:.15;pointer-events:none}.illum-led{background:#ffffff1a;border:1.5px solid #ffffff26;border-radius:50%;width:6px;height:6px;transition:all .25s}.illum-tab.active{background:#4ade801f;border-color:#4ade8066;box-shadow:0 0 12px #4ade8040,inset 0 1px #ffffff14}.illum-tab.active .illum-led{background:#4ade80;border-color:#5ee88f;box-shadow:0 0 10px #4ade80cc,inset 0 1px 2px #ffffff80}.illum-tab-name{letter-spacing:.05em;color:#ffffff40;font-size:9px;font-weight:700;transition:color .15s}.illum-tab.active .illum-tab-name{color:#fffffff2;font-weight:800}.slitlamp-viewport{background:#000;flex:1;justify-content:center;align-items:center;width:100%;min-height:0;display:flex;position:relative;overflow:hidden}.slitlamp-loader{color:#ffffffc7;letter-spacing:.06em;text-transform:uppercase;z-index:2;background:#0009;flex-direction:column;justify-content:center;align-items:center;gap:14px;font-size:11px;font-weight:600;display:flex;position:absolute;inset:0}.slitlamp-spinner{border:2.5px solid #ffffff1f;border-top-color:#ffffffd9;border-radius:50%;width:28px;height:28px;animation:.85s linear infinite slitlampSpin}@keyframes slitlampSpin{to{transform:rotate(360deg)}}.slitlamp-progress{background:#ffffff1a;border-radius:2px;width:60%;max-width:220px;height:4px;overflow:hidden}.slitlamp-progress-fill{background:#4ade80e6;border-radius:2px;height:100%;transition:width .15s}.slitlamp-error-overlay{letter-spacing:.04em;color:#ffe066;z-index:3;pointer-events:none;background:#0009;border-radius:999px;padding:4px 10px;font-size:10px;font-weight:700;position:absolute;top:8px;left:50%;transform:translate(-50%)}.slitlamp-video{object-fit:contain;pointer-events:none;width:100%;height:100%;display:block}.slitlamp-text-fallback{text-align:center;color:#ffffff8c;padding:24px;font-size:13px;line-height:1.6}.slitlamp-label{color:#fff;margin-bottom:8px;font-size:14px;font-weight:700}.slitlamp-hint{opacity:.4;margin-top:10px;font-size:10px;font-style:italic}.scrub-strip{background:linear-gradient(#0d0d18 0%,#0a0a14 100%);border-top:1px solid #ffffff0f;flex-shrink:0}.scrub-zone{cursor:ew-resize;touch-action:none;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;width:100%;max-width:320px;margin:0 auto;padding:10px 12px 0;display:flex}.scrub-inactive{opacity:.35;cursor:default}.scrub-marker{letter-spacing:.06em;color:#ffffff4d;white-space:nowrap;flex-shrink:0;align-items:center;gap:3px;font-size:9px;font-weight:800;display:flex}.scrub-marker svg{color:#ffffff38}.strip-track{background:linear-gradient(#ffffff12 0%,#0e0e16 6%,#090910 50%,#0c0c14 94%,#ffffff08 100%);border:1px solid #ffffff1a;border-radius:9px;flex:1;height:18px;position:relative;box-shadow:inset 0 3px 8px #000000bf,inset 0 1px #ffffff0f,0 2px 6px #0006,0 1px #ffffff08}.strip-track:before{content:"";background:#ffffff0a;border-radius:1px;height:1px;position:absolute;top:50%;left:10%;right:10%;transform:translateY(-50%)}.strip-fill{display:none}.strip-thumb{pointer-events:none;filter:drop-shadow(0 -1px 3px #0006)drop-shadow(0 2px 4px #00000080);flex-direction:column;align-items:center;width:18px;margin-bottom:-3px;display:flex;position:absolute;bottom:50%;transform:translate(-50%)}.jstick-dome{background:radial-gradient(at 38% 28%,#f8f8fa,#c8c8d4 55%,#8888a0 100%);border-radius:50% 50% 40% 40%/75% 75% 35% 35%;width:10px;height:6px;box-shadow:inset 0 1px 2px #ffffffb3,inset 0 -1px 1px #0003}.jstick-grip{background:linear-gradient(90deg,#0e0e10 0%,#2a2a2e 30%,#323236 50%,#2a2a2e 70%,#0e0e10 100%);flex-direction:column;justify-content:space-evenly;align-items:center;width:9px;height:10px;padding:1.5px 0;display:flex;box-shadow:inset 1.5px 0 3px #0009,inset -1.5px 0 3px #0009}.jstick-knurl{background:linear-gradient(90deg,#0000 0%,#ffffff1f 30%,#ffffff2e 50%,#ffffff1f 70%,#0000 100%);border-radius:1px;width:6px;height:1px;display:block}.jstick-base{clip-path:polygon(15% 0%,85% 0%,100% 100%,0% 100%);background:linear-gradient(90deg,#909098 0%,#d0d0d8 25%,#e8e8ee 50%,#d0d0d8 75%,#909098 100%);width:14px;height:5px;box-shadow:inset 0 -1px #0003}@media (width>=600px){.illum-bar{gap:2px;padding:3px 16px 6px}.illum-tab{border-width:1.5px;padding:6px 5px}.illum-tab:active{transform:translateY(2px)}.illum-tab-name{font-size:10px;font-weight:700}.illum-scale-label{gap:8px;font-size:8px}.scrub-zone{max-width:460px;margin:0 auto;padding:11px 14px 0}.scrub-marker{gap:5px;font-size:10px}.strip-track{border-radius:10px;height:20px}.strip-thumb{width:19px}.jstick-dome{width:11px;height:7px}.jstick-grip{width:10px;height:11px}.jstick-knurl{width:7px}.jstick-base{width:15px;height:6px}}@media (width>=900px){.illum-tab-name{font-size:11px}.illum-dial{gap:2px}.scrub-zone{max-width:500px;padding:12px 16px 0}.strip-thumb{width:20px}.jstick-dome{width:12px;height:7px}.jstick-grip{width:11px;height:12px}.jstick-knurl{width:8px}.jstick-base{width:16px;height:6px}}.image-viewer{flex-direction:column;align-items:center;gap:8px;width:100%;height:100%;min-height:0;display:flex}.image-viewer-controls{background:#0a0a12d9;border:1px solid #fff3;border-radius:999px;flex-shrink:0;align-self:center;align-items:center;gap:6px;padding:4px 6px;display:inline-flex}.image-viewer-controls button{color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#ffffff1f;border:1px solid #ffffff47;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:16px;font-weight:700;line-height:1;transition:background .15s,transform .1s;display:flex}.image-viewer-controls button:hover{background:#fff3}.image-viewer-controls button:active{transform:scale(.94)}.image-viewer-controls span{color:#fff;text-align:center;letter-spacing:.02em;min-width:38px;font-size:11px;font-weight:600}.image-viewer-container{border-radius:var(--radius-md);-webkit-user-select:none;user-select:none;touch-action:none;-ms-touch-action:none;-webkit-touch-callout:none;overscroll-behavior:contain;flex:1;justify-content:center;align-items:center;width:100%;min-height:0;display:flex;position:relative;overflow:hidden}.image-viewer-img{object-fit:contain;transform-origin:50%;pointer-events:none;width:100%;height:100%}.image-viewer-fallback{text-align:center;max-width:500px;line-height:1.6}.image-viewer-desc{font-size:var(--text-base)}.image-viewer-hint{margin-top:var(--space-4);font-size:var(--text-xs);opacity:.5;font-style:italic}.eye-exam-canvas{background:#0f0f18;border-radius:10px;flex-direction:column;width:100%;height:100%;min-height:0;display:flex;overflow:hidden}.eec-tool-bar{background:linear-gradient(#1a1a28 0%,#0f0f1a 100%);border-bottom:1px solid #ffffff14;flex-shrink:0;gap:6px;padding:8px 10px;display:flex}.eec-tool-btn{cursor:pointer;color:#ffffff80;letter-spacing:.04em;-webkit-tap-highlight-color:transparent;background:#ffffff08;border:1px solid #ffffff14;border-radius:5px;flex:1;justify-content:center;align-items:center;gap:8px;padding:8px 12px;font-family:inherit;font-size:12px;font-weight:700;transition:all .15s;display:flex}.eec-tool-btn:active{transform:translateY(1px)}.eec-tool-btn.active{color:#fff;background:#4ade801f;border-color:#4ade8066;box-shadow:0 0 12px #4ade8033,inset 0 1px #ffffff14}.eec-led{background:#ffffff1f;border:1.5px solid #ffffff2e;border-radius:50%;width:6px;height:6px;transition:all .25s}.eec-tool-btn.active .eec-led{background:#4ade80;border-color:#5ee88f;box-shadow:0 0 8px #4ade80b3}.eec-viewport{cursor:none;touch-action:none;background:#151e2e;flex:1;justify-content:center;align-items:center;min-height:0;display:flex;position:relative;overflow:hidden}.eec-layer{pointer-events:none;max-width:100%;max-height:100%;display:block;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.eec-layer-top{pointer-events:auto}.eec-layer-glow{mix-blend-mode:screen}.eec-brightness-strip{background:linear-gradient(#0d0d18 0%,#0a0a14 100%);border-top:1px solid #ffffff0f;flex-shrink:0;align-items:center;gap:6px;padding:10px 12px;display:flex}.eec-brightness-label{letter-spacing:.15em;color:#ffffff38;text-transform:uppercase;margin-right:4px;font-size:9px;font-weight:900}.eec-brightness-btn{cursor:pointer;color:#fff6;letter-spacing:.04em;-webkit-tap-highlight-color:transparent;background:#ffffff05;border:1px solid #ffffff14;border-radius:4px;align-items:center;gap:5px;padding:5px 12px;font-family:inherit;font-size:11px;font-weight:700;transition:all .15s;display:flex}.eec-brightness-btn:active{transform:translateY(1px)}.eec-brightness-btn.active{color:#fffffff2;background:#4ade801a;border-color:#4ade8059}.eec-brightness-symbol{font-size:13px;line-height:1}.exam-section{background:#e9ecf1;flex-direction:column;gap:8px;height:100%;padding:10px 12px;display:flex;overflow:hidden}.exam-controls{flex-direction:column;flex-shrink:0;gap:8px;display:flex}.exam-viewport{background:#151e2e;border:1px solid #00000038;border-radius:14px;flex-direction:column;flex:1;align-items:stretch;min-height:0;display:flex;overflow:hidden;box-shadow:0 4px 20px #0000002e,0 1px 4px #0000001f,inset 0 1px #ffffff0a}.exam-notes-btn{background:var(--color-primary);color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;letter-spacing:.02em;border:none;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;gap:8px;width:100%;padding:11px;font-size:13px;font-weight:700;transition:opacity .15s,transform .1s;display:flex}.exam-notes-btn:active{opacity:.88;transform:scale(.98)}.exam-metric-row{grid-template-columns:1fr 1fr;gap:7px;display:grid}.exam-metric-card{background:#fff;border:1px solid #00000014;border-radius:11px;flex-direction:column;gap:4px;padding:8px 10px;display:flex;box-shadow:0 2px 8px #00000012,0 1px 2px #0000000d}.em-hdr{letter-spacing:.06em;color:#8a9aaa;text-transform:uppercase;align-items:center;gap:4px;font-size:7px;font-weight:800;display:flex}.em-hdr svg{flex-shrink:0}.em-vals{justify-content:center;align-items:center;display:flex}.em-col{flex-direction:column;flex:1;align-items:center;display:flex}.em-eye{color:var(--color-primary);text-transform:uppercase;letter-spacing:.06em;font-size:8px;font-weight:800}.em-num{color:#1a2030;letter-spacing:-.4px;font-size:18px;font-weight:800;line-height:1.1}.em-unit{color:#8a9aaa;font-size:7.5px;font-weight:600;line-height:1.2}.em-divider{background:#e0e8ee;flex-shrink:0;width:1px;height:20px;margin:0 6px}.exam-section-label{letter-spacing:.12em;color:#9aabb8;text-align:center;text-transform:uppercase;font-size:9px;font-weight:800}.exam-view-tabs{gap:5px;display:flex}.exam-view-tab{cursor:pointer;-webkit-tap-highlight-color:transparent;color:#6a7a8a;white-space:nowrap;background:#fff;border:1.5px solid #00000017;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:5px;padding:8px 6px;font-size:10px;font-weight:700;transition:background .15s,color .15s,border-color .15s,box-shadow .15s;display:flex;box-shadow:0 1px 4px #00000012,0 0 #0000}.exam-view-tab.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary);box-shadow:0 3px 10px rgba(var(--color-primary-rgb,0, 150, 136), .35), 0 1px 3px #0000001f}.exam-finding-text{color:#ffffff8c;text-align:center;flex:1;align-items:center;max-width:260px;margin:auto;padding:24px;font-size:13px;line-height:1.6;display:flex}.exam-pupils-view{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:24px;display:flex}@media (width>=600px){.exam-section{grid-template:"controls viewport"1fr"controls notes"/200px 1fr;gap:12px;padding:14px 16px;display:grid}.exam-controls{grid-area:controls;overflow-y:auto}.exam-section-label{text-align:left}.exam-view-tabs{flex-direction:column;gap:5px}.exam-view-tab{flex:unset;justify-content:flex-start;width:100%;padding:10px 12px;font-size:12px}.exam-viewport{flex:unset;grid-area:viewport}.exam-notes-btn{grid-area:notes;padding:11px;font-size:13px}}@media (width>=900px){.exam-section{grid-template-columns:240px 1fr;gap:16px;padding:18px 20px}.em-num{font-size:20px}.exam-view-tab{border-radius:12px;gap:10px;padding:13px 16px;font-size:14px}.exam-view-tab svg{width:16px;height:16px}.exam-notes-btn{border-radius:12px;padding:13px;font-size:14px}}@media (width>=1200px){.exam-section{grid-template-columns:270px 1fr;gap:20px;padding:22px 26px}.exam-view-tab{border-radius:13px;padding:16px 20px;font-size:15px}.exam-view-tab svg{width:18px;height:18px}.exam-notes-btn{border-radius:13px;padding:15px;font-size:15px}}.oct-viewer{align-items:center;gap:var(--space-3);flex-direction:column;width:100%;display:flex}.oct-viewport{aspect-ratio:16/10;border-radius:var(--radius-md);background:#000;justify-content:center;align-items:center;width:100%;max-width:700px;display:flex;overflow:hidden}.oct-video{object-fit:contain;pointer-events:none;width:100%;height:100%}.oct-controls{align-items:center;gap:var(--space-3);width:100%;max-width:700px;padding:0 var(--space-2);display:flex}.oct-step-btn{border-radius:var(--radius-md);width:36px;height:36px;color:var(--color-clinical-text);font-size:var(--text-lg);cursor:pointer;transition:background var(--transition-fast);background:#ffffff14;border:1px solid #fff3;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.oct-step-btn:hover{background:#ffffff26}.oct-step-btn:active{background:var(--color-primary);color:#fff}.oct-slider{appearance:none;cursor:pointer;background:#ffffff26;border-radius:3px;outline:none;flex:1;height:6px}.oct-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--color-primary);cursor:pointer;border:2px solid #fff;border-radius:50%;width:18px;height:18px}.oct-slider::-moz-range-thumb{background:var(--color-primary);cursor:pointer;border:2px solid #fff;border-radius:50%;width:18px;height:18px}.oct-description{font-size:var(--text-xs);color:#ffffff80;text-align:center}.oct-text-fallback{padding:var(--space-6);text-align:center;color:var(--color-clinical-text);line-height:1.6}.vf-viewer{flex-direction:column;width:100%;height:100%;min-height:0;display:flex}.vf-images{flex:1;justify-content:center;align-items:stretch;gap:10px;min-height:0;padding:8px 10px;display:flex}.vf-eye-panel{flex-direction:column;gap:4px;min-height:0;display:flex}.vf-eye-label{letter-spacing:.08em;text-transform:uppercase;color:#ffffff73;text-align:center;flex-shrink:0;font-size:10px;font-weight:800}.vf-zoom-bar{background:#ffffff0f;border:1px solid #ffffff24;border-radius:999px;flex-shrink:0;align-self:center;align-items:center;gap:6px;padding:3px 6px;display:inline-flex}.vf-zoom-bar button{color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#ffffff1a;border:1px solid #ffffff40;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:14px;font-weight:700;line-height:1;display:flex}.vf-zoom-bar button:hover{background:#ffffff2e}.vf-zoom-bar button:active{transform:scale(.94)}.vf-zoom-bar span{color:#ffffffd9;text-align:center;letter-spacing:.02em;min-width:32px;font-size:10px;font-weight:600}.vf-portrait{aspect-ratio:210/297;background:#fff;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden;box-shadow:0 2px 12px #0006}.vf-img{object-fit:contain;width:100%;height:100%;display:block}.vf-missing{color:#00000059;font-size:12px}.vf-images--both .vf-eye-panel{flex:1;min-width:0;max-width:320px;overflow:hidden}.vf-images--both .vf-portrait{flex:none;width:100%;height:auto;max-height:100%}.vf-images--od,.vf-images--os{align-items:stretch}.vf-images--od .vf-eye-panel,.vf-images--os .vf-eye-panel{flex:none;width:auto;height:100%}.vf-images--od .vf-portrait,.vf-images--os .vf-portrait{flex:none;width:auto;max-width:min(95vw,460px);height:100%}.vf-desc{color:#fff6;text-align:center;flex-shrink:0;padding:4px 12px 8px;font-size:11px}.vf-empty{text-align:center;color:#ffffff73;flex-direction:column;justify-content:center;align-items:center;gap:8px;height:100%;padding:28px 24px;font-size:13px;line-height:1.7;display:flex}.invest-section{background:#e9ecf1;flex-direction:column;gap:8px;height:100%;padding:10px 12px;display:flex;overflow:hidden}.invest-controls{flex-direction:column;flex-shrink:0;gap:8px;display:flex}.invest-section-label{letter-spacing:.12em;color:#9aabb8;text-align:center;text-transform:uppercase;font-size:9px;font-weight:800}.invest-test-tabs{gap:5px;display:flex}.invest-test-tab{cursor:pointer;-webkit-tap-highlight-color:transparent;color:#6a7a8a;white-space:nowrap;background:#fff;border:1.5px solid #00000017;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:5px;padding:8px 4px;font-size:9px;font-weight:700;transition:background .15s,color .15s,border-color .15s,box-shadow .15s;display:flex;box-shadow:0 1px 4px #00000012}.invest-test-tab.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary);box-shadow:0 3px 10px #0096884d,0 1px 3px #0000001f}.invest-test-tab svg{flex-shrink:0;width:14px;height:14px}.invest-viewer{background:#151e2e;border:1px solid #00000038;border-radius:14px;flex:1;justify-content:center;align-items:center;min-height:0;display:flex;overflow:hidden;box-shadow:0 4px 20px #0000002e,0 1px 4px #0000001f,inset 0 1px #ffffff0a}.invest-normal-text{text-align:center;color:#ffffff8c;flex-direction:column;align-items:center;max-width:380px;padding:28px 24px;font-size:13px;line-height:1.7;display:flex}.invest-eye-wrap{flex-direction:column;width:100%;height:100%;min-height:0;display:flex}.invest-eye-toggle{flex-shrink:0;gap:6px;padding:8px 12px 4px;display:flex}.eye-toggle-btn{color:#ffffffb3;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#ffffff14;border:1.5px solid #ffffff38;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:1px;padding:5px 16px;line-height:1;transition:all .15s;display:flex}.eye-btn-main{letter-spacing:.05em;font-size:12px;font-weight:800}.eye-btn-sub{letter-spacing:.04em;opacity:.7;font-size:9px;font-weight:500}.eye-toggle-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff;box-shadow:0 2px 8px #00968866}.eye-toggle-btn.active .eye-btn-sub{opacity:.85}.invest-eye-viewer{flex:1;min-height:0;padding:6px 8px 8px;display:flex}@media (width>=600px){.invest-section{grid-template:"controls viewer"1fr/200px 1fr;gap:12px;padding:14px 16px;display:grid}.invest-controls{grid-area:controls;overflow-y:auto}.invest-section-label{text-align:left}.invest-test-tabs{flex-direction:column;gap:5px}.invest-test-tab{flex:unset;justify-content:flex-start;gap:8px;width:100%;padding:10px 12px;font-size:12px}.invest-test-tab svg{width:15px;height:15px}.invest-viewer{flex:unset;grid-area:viewer}}@media (width>=900px){.invest-section{grid-template-columns:240px 1fr;gap:16px;padding:18px 20px}.invest-test-tab{border-radius:12px;gap:10px;padding:13px 16px;font-size:14px}.invest-test-tab svg{width:16px;height:16px}}@media (width>=1200px){.invest-section{grid-template-columns:270px 1fr;gap:20px;padding:22px 26px}.invest-test-tab{border-radius:13px;padding:16px 20px;font-size:15px}.invest-test-tab svg{width:18px;height:18px}}.discussion-layout{height:100%;display:flex;overflow:hidden}.discussion-main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.discussion-header{border-bottom:1px solid var(--color-border);background:var(--color-surface);flex-shrink:0;padding:9px 14px}.discussion-ai-badge{background:var(--color-primary-bg);color:var(--color-primary);border-radius:var(--radius-sm);font-size:var(--text-xs);letter-spacing:.01em;align-items:center;gap:5px;padding:3px 9px;font-weight:700;display:inline-flex}.discussion-chat-area{flex:1;min-height:0;overflow-y:auto}.discussion-input-area{border-top:1px solid var(--color-border);background:var(--color-surface);flex-shrink:0}.discussion-notes-panel{border-left:1px solid var(--color-border);background:#fafbfc;flex-direction:column;flex-shrink:0;width:264px;display:flex;overflow:hidden}.dnp-header{color:#4a5568;letter-spacing:.03em;text-transform:uppercase;border-bottom:1px solid var(--color-border);background:var(--color-surface);flex-shrink:0;align-items:center;gap:7px;padding:10px 13px;font-size:12px;font-weight:700;display:flex}.dnp-body{flex-direction:column;flex:1;gap:12px;padding:12px;display:flex;overflow-y:auto}.dnp-ai-summary{background:#f0f8f8;border:1px solid #c8e4e4;border-radius:8px;flex-direction:column;gap:5px;padding:9px 11px;display:flex}.dnp-ai-label{text-transform:uppercase;letter-spacing:.07em;color:#5a8a8a;align-items:center;gap:5px;font-size:9px;font-weight:800;display:flex}.ai-chip{background:var(--color-primary);color:#fff;letter-spacing:.04em;border-radius:3px;padding:2px 5px;font-size:8px;font-weight:900}.dnp-ai-text{color:#3a5050;white-space:pre-line;margin:0;font-size:11.5px;line-height:1.6}.dnp-bullets{flex-direction:column;gap:5px;margin:0;padding:0;list-style:none;display:flex}.dnp-bullets li{color:#2a3040;align-items:flex-start;gap:7px;font-size:13px;line-height:1.4;display:flex}.dnp-bullets li:before{content:"•";color:var(--color-primary);flex-shrink:0;font-size:16px;line-height:1.2}.dnp-bullets li span{flex:1}.dnp-delete{color:#c0c8d0;cursor:pointer;background:0 0;border:none;flex-shrink:0;margin-top:1px;padding:0 2px;font-size:15px;line-height:1}.dnp-delete:hover{color:#e05a5a}.dnp-empty{color:#a0aab4;text-align:center;margin:0;padding:8px 4px;font-size:12px;line-height:1.6}.dnp-footer{border-top:1px solid var(--color-border);background:var(--color-surface);flex-shrink:0;gap:6px;padding:9px 10px;display:flex}.dnp-input{color:#1a2030;background:#fafbfc;border:1.5px solid #e0e4e8;border-radius:8px;outline:none;flex:1;min-width:0;padding:7px 10px;font-family:inherit;font-size:13px;transition:border-color .15s}.dnp-input:focus{border-color:var(--color-primary);background:#fff}.dnp-input::placeholder{color:#b0bac5}.dnp-add-btn{background:var(--color-primary);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:7px 12px;font-size:12px;font-weight:700;transition:opacity .15s}.dnp-add-btn:disabled{opacity:.35;cursor:default}@media (width<=560px){.discussion-layout{flex-direction:column}.discussion-notes-panel{border-left:none;border-bottom:1px solid var(--color-border);width:100%;max-height:200px}}.notes-backdrop{z-index:90;background:#0000004d;animation:.2s fadeIn;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.notes-popup{z-index:100;background:#fff;border-radius:20px 20px 0 0;flex-direction:column;max-height:82vh;transition:transform .3s cubic-bezier(.32,.72,0,1);display:flex;position:fixed;bottom:0;left:0;right:0;overflow:hidden;transform:translateY(100%);box-shadow:0 -4px 32px #00000024,0 -1px #0000000f}.notes-popup.open{transform:translateY(0)}@media (width>=600px){.notes-popup{border-radius:20px 20px 0 0;width:min(520px,96vw);bottom:0;left:50%;right:auto;transform:translate(-50%)translateY(100%)}.notes-popup.open{transform:translate(-50%)translateY(0)}}.notes-popup-header{border-bottom:1px solid #eef0f2;flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px 12px;display:flex}.notes-popup-header:before{content:none}.notes-popup:before{content:"";background:#d8dde2;border-radius:2px;flex-shrink:0;width:36px;height:4px;margin:10px auto 0;display:block}.notes-popup-title{color:#1a2030;align-items:center;gap:7px;font-size:15px;font-weight:700;display:flex}.notes-close-x{cursor:pointer;color:#5a6470;background:#f0f2f4;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;transition:background .15s;display:flex}.notes-close-x:hover{background:#e4e8ec}.notes-popup-body{flex-direction:column;flex:1;gap:14px;padding:14px 16px 20px;display:flex;overflow-y:auto}.notes-ai-summary{background:#f0f8f8;border:1px solid #c8e4e4;border-radius:10px;flex-direction:column;flex-shrink:0;gap:6px;padding:10px 12px;display:flex}.notes-ai-label{text-transform:uppercase;letter-spacing:.06em;color:#5a8a8a;align-items:center;gap:6px;font-size:10px;font-weight:700;display:flex}.ai-chip{background:var(--color-primary);color:#fff;border-radius:4px;padding:2px 5px;font-size:9px;font-weight:800}.notes-ai-text{color:#3a5050;white-space:pre-line;font-size:12px;line-height:1.6}.notes-bullets{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.notes-bullets li{color:#2a3040;align-items:center;gap:8px;font-size:14px;display:flex}.notes-bullets li:before{content:"•";color:var(--color-primary);flex-shrink:0;font-size:18px}.notes-bullets li span{flex:1}.note-delete{color:#c0c8d0;cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:2px 4px;font-size:16px;line-height:1}.note-delete:hover{color:#e05a5a}.notes-input-row{gap:8px;margin-top:auto;padding-top:4px;display:flex}.notes-quick-input{color:#1a2030;background:#fafbfc;border:1.5px solid #e0e4e8;border-radius:10px;outline:none;flex:1;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .15s}.notes-quick-input:focus{border-color:var(--color-primary);background:#fff}.notes-quick-input::placeholder{color:#b0bac5}.notes-add-btn{background:var(--color-primary);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:10px;padding:10px 16px;font-size:13px;font-weight:700;transition:opacity .15s}.notes-add-btn:disabled{opacity:.4;cursor:default}.case-app{height:100dvh;height:var(--app-vh,100dvh);padding-bottom:env(safe-area-inset-bottom);padding-top:env(safe-area-inset-top);overscroll-behavior:contain;background:#f4f6f8;flex-direction:column;display:flex;position:fixed;inset:0;overflow:hidden}.case-not-found{text-align:center;padding:4rem 2rem}.case-topbar{background:#fff;border-bottom:1px solid #e8eaed;flex-shrink:0;align-items:center;gap:10px;padding:10px 14px;display:flex}.back-btn{cursor:pointer;color:#5a6470;background:0 0;border:none;border-radius:6px;flex-shrink:0;align-items:center;padding:4px;display:flex}.back-btn:hover{background:#f0f2f4}.topbar-avatar{object-fit:cover;border:2px solid var(--color-primary);border-radius:50%;flex-shrink:0;width:34px;height:34px}.topbar-patient{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.topbar-name{color:#1a2030;white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:700;overflow:hidden}.topbar-sub{color:#8a9aaa;font-size:12px}.topbar-step-badge{background:var(--color-primary);color:#fff;white-space:nowrap;border-radius:20px;flex-shrink:0;align-items:center;gap:5px;padding:5px 9px;font-size:11px;font-weight:700;display:flex}.case-body{flex:1;min-height:0;display:flex;overflow:hidden}.case-main{flex:1;min-height:0;overflow:hidden}.notes-fab{right:16px;bottom:calc(68px + env(safe-area-inset-bottom));background:var(--color-primary);color:#fff;cursor:pointer;z-index:50;border:none;border-radius:22px;align-items:center;gap:6px;padding:9px 16px;font-size:13px;font-weight:700;transition:transform .15s,box-shadow .15s;display:flex;position:fixed;box-shadow:0 3px 14px #56949673}.notes-fab:hover{transform:translateY(-1px);box-shadow:0 5px 18px #5694968c}.step-nav{z-index:40;height:58px;padding:0 8px;padding-bottom:env(safe-area-inset-bottom);box-sizing:content-box;background:#fff;border-top:1px solid #e8eaed;flex-shrink:0;justify-content:center;align-items:center;gap:0;display:flex}.step-btn{cursor:pointer;color:#b0bac5;-webkit-tap-highlight-color:transparent;background:0 0;border:none;align-items:center;gap:5px;padding:6px;font-size:11px;font-weight:600;transition:color .15s;display:flex;position:relative}.step-btn.active,.step-btn.done{color:var(--color-primary)}.step-btn.active .step-label{border-bottom:2px solid var(--color-primary);padding-bottom:1px}.step-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.step-num{border:1.5px solid;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:10px;font-weight:700;display:flex}.step-btn.active .step-num{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.step-label{white-space:nowrap}.step-arrow{color:#d0d8e0;pointer-events:none;margin:0 2px;font-size:12px}.admin-subnav{margin-bottom:var(--space-6);border-bottom:1px solid var(--color-border);gap:2px;padding-bottom:0;display:flex}.admin-subnav-tab{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);color:var(--color-text-secondary);transition:color var(--transition-fast), border-color var(--transition-fast);border-bottom:2px solid #0000;margin-bottom:-1px;font-weight:500;text-decoration:none;display:inline-flex}.admin-subnav-tab:hover{color:var(--color-text)}.admin-subnav-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.admin-cases{max-width:1100px;padding:var(--space-8) var(--space-4);margin:0 auto}.admin-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:flex-start;display:flex}.admin-header h1{font-size:var(--text-2xl);margin-bottom:var(--space-1)}.admin-header p{color:var(--color-text-secondary);font-size:var(--text-sm)}.admin-error{color:var(--color-error);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);margin-bottom:var(--space-4);background:#fef2f2;border:1px solid #fecaca}.admin-empty{text-align:center;padding:var(--space-16);color:var(--color-text-secondary)}.admin-table{border-collapse:collapse;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;overflow:hidden}.admin-table th,.admin-table td{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-sm);border-bottom:1px solid var(--color-border)}.admin-table th{background:var(--color-surface-alt);color:var(--color-text-secondary);font-weight:600;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em}.case-link{color:var(--color-text);font-weight:500;text-decoration:none}.case-link:hover{color:var(--color-primary)}.difficulty-badge{border-radius:var(--radius-full);font-size:var(--text-xs);color:#fff;text-transform:capitalize;padding:2px 10px;font-weight:600;display:inline-block}.difficulty-badge.easy{background:var(--color-success)}.difficulty-badge.moderate{background:var(--color-warning)}.difficulty-badge.hard{background:var(--color-error)}.status-toggle{border-radius:var(--radius-full);font-size:var(--text-xs);cursor:pointer;transition:all var(--transition-fast);border:none;padding:2px 10px;font-weight:600}.status-toggle.published{color:var(--color-success);background:#dcfce7}.status-toggle.draft{color:var(--color-text-muted);background:#f1f5f9}.action-btns{gap:var(--space-2);display:flex}.btn-danger{background:var(--color-error);color:#fff;border:none}.btn-danger:hover{background:#b91c1c}@media (width<=768px){.admin-table th:nth-child(2),.admin-table td:nth-child(2),.admin-table th:nth-child(3),.admin-table td:nth-child(3){display:none}}.avatar-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));display:grid}.avatar-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);flex-direction:column;display:flex;overflow:hidden}.avatar-card-img{aspect-ratio:3/4;background:var(--color-surface-alt);position:relative;overflow:hidden}.avatar-card-img img{object-fit:cover;width:100%;height:100%;display:block}.avatar-card-placeholder{width:100%;height:100%;font-size:var(--text-sm);color:var(--color-text-muted);justify-content:center;align-items:center;display:flex}.avatar-local-badge{top:var(--space-2);left:var(--space-2);color:#fff;font-size:var(--text-xs);border-radius:var(--radius-full);pointer-events:none;background:#000000a6;padding:2px 8px;position:absolute}.avatar-card-body{padding:var(--space-3) var(--space-3) var(--space-2);flex:1}.avatar-card-label{font-weight:600;font-size:var(--text-sm);color:var(--color-text);margin:0 0 2px}.avatar-card-meta{font-size:var(--text-xs);color:var(--color-text-secondary);margin:0}.avatar-card-actions{padding:var(--space-2) var(--space-3) var(--space-3);gap:var(--space-2);display:flex}.file-upload-wrapper{margin-bottom:var(--space-3)}.file-upload-label{font-size:var(--text-sm);margin-bottom:var(--space-1);color:var(--color-text);font-weight:500;display:block}.file-dropzone{border:2px dashed var(--color-border);border-radius:var(--radius-md);padding:var(--space-6);text-align:center;cursor:pointer;color:var(--color-text-muted);font-size:var(--text-sm);transition:all var(--transition-fast)}.file-dropzone:hover,.file-dropzone.drag-over{border-color:var(--color-primary);background:var(--color-primary-bg);color:var(--color-primary)}.upload-progress{align-items:center;gap:var(--space-2);flex-direction:column;display:flex}.progress-bar{background:var(--color-primary);border-radius:3px;align-self:stretch;width:0;height:6px;transition:width .2s}.file-preview{align-items:center;gap:var(--space-3);padding:var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-alt);display:flex}.file-preview-img{object-fit:cover;border-radius:var(--radius-sm);width:80px;height:60px}.file-preview-video{object-fit:cover;border-radius:var(--radius-sm);width:120px;height:80px}.file-preview-link{color:var(--color-primary);font-size:var(--text-sm)}.avatar-picker-loading{color:var(--color-text-secondary);font-size:var(--text-sm);padding:var(--space-4) 0}.avatar-picker-empty{align-items:center;gap:var(--space-3);border:1px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--space-8);text-align:center;color:var(--color-text-secondary);font-size:var(--text-sm);flex-direction:column;display:flex}.avatar-picker-grid{gap:var(--space-3);margin-bottom:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(130px,1fr));display:grid}.avatar-picker-card{border:2px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);cursor:pointer;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);text-align:left;flex-direction:column;align-items:stretch;padding:0;display:flex;overflow:hidden}.avatar-picker-card:hover{border-color:var(--color-primary);box-shadow:0 0 0 3px color-mix(in srgb, var(--color-primary) 15%, transparent)}.avatar-picker-card.selected{border-color:var(--color-primary);box-shadow:0 0 0 3px color-mix(in srgb, var(--color-primary) 20%, transparent)}.avatar-picker-img{aspect-ratio:3/4;background:var(--color-surface-alt);position:relative;overflow:hidden}.avatar-picker-img img{object-fit:cover;width:100%;height:100%;display:block}.avatar-picker-placeholder{width:100%;height:100%;font-size:var(--text-xs);color:var(--color-text-muted);justify-content:center;align-items:center;display:flex}.avatar-picker-check{top:var(--space-2);right:var(--space-2);filter:drop-shadow(0 1px 3px #00000059);line-height:0;position:absolute}.avatar-picker-info{padding:var(--space-2) var(--space-2) var(--space-3);flex-direction:column;gap:2px;display:flex}.avatar-picker-label{font-size:var(--text-sm);color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.avatar-picker-meta{font-size:var(--text-xs);color:var(--color-text-secondary)}.avatar-picker-footer{gap:var(--space-5);margin-top:var(--space-1);display:flex}.avatar-picker-link{font-size:var(--text-xs);color:var(--color-primary);text-decoration:none}.avatar-picker-link:hover{text-decoration:underline}.vte{margin-top:var(--space-2);background:#0000000a;border:1px solid #00000014;border-radius:8px;flex-direction:column;gap:10px;padding:12px;display:flex}.vte-preview{aspect-ratio:16/9;cursor:pointer;background:#000;border-radius:6px;width:100%;max-width:340px;position:relative;overflow:hidden}.vte-video{object-fit:contain;width:100%;height:100%;display:block}.vte-play-btn{color:#fff;cursor:pointer;background:#000000a6;border:1px solid #ffffff4d;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;transition:background .12s;display:flex;position:absolute;bottom:6px;left:6px}.vte-play-btn:hover{background:#000000d9}.vte-mode-badge{letter-spacing:.08em;text-transform:uppercase;color:#4ade80;pointer-events:none;background:#4ade8026;border:1px solid #4ade8073;border-radius:10px;padding:2px 7px;font-size:10px;font-weight:700;position:absolute;top:6px;right:6px}.vte-timeline{touch-action:none;-webkit-user-select:none;user-select:none;cursor:pointer;max-width:520px;height:34px;position:relative}.vte-track-bg{pointer-events:auto;background:#0000001f;border-radius:4px;height:8px;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.vte-track-selected{pointer-events:none;background:#4ade808c;border:1px solid #4ade80e6;border-radius:4px;height:8px;position:absolute;top:50%;transform:translateY(-50%)}.vte-playhead{pointer-events:none;background:#fff;border-radius:1px;width:2px;height:22px;position:absolute;top:50%;transform:translate(-1px,-50%);box-shadow:0 0 0 1px #00000073}.vte-handle{cursor:ew-resize;touch-action:none;flex-direction:column;justify-content:center;align-items:center;width:22px;margin-left:-11px;display:flex;position:absolute;top:0;bottom:0}.vte-handle-stem{background:#1f2937;border-radius:1px;width:2px;height:100%}.vte-handle-grip{background:#1f2937;border:1.5px solid #f3f4f6;border-radius:3px;width:12px;height:20px;position:absolute;top:50%;transform:translateY(-50%);box-shadow:0 1px 3px #00000059}.vte-handle-start .vte-handle-grip{background:#059669;border-color:#ecfdf5}.vte-handle-end .vte-handle-grip{background:#dc2626;border-color:#fef2f2}.vte-handle.dragging .vte-handle-grip{box-shadow:0 0 0 3px #4ade8059,0 1px 3px #0006}.vte-handle:hover .vte-handle-grip{filter:brightness(1.15)}.vte-controls{font-size:var(--text-sm,13px);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.vte-times{color:var(--color-text-secondary,#6b7280);gap:14px;font-family:SF Mono,Menlo,monospace;font-size:12px;display:flex}.vte-times strong{color:var(--color-text,#111);margin-right:4px;font-family:inherit;font-weight:700}.vte-duration-out{opacity:.8}.vte-actions{align-items:center;gap:12px;display:flex}.vte-reverse{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;font-size:13px;display:flex}.vte-reverse input{cursor:pointer}.vte-reset{cursor:pointer;background:#fff;border:1px solid #00000026;border-radius:4px;padding:4px 10px;font-family:inherit;font-size:12px}.vte-reset:hover{background:#f3f4f6}.vte-hint{color:var(--color-text-secondary,#6b7280);margin:0;font-size:11px;line-height:1.5}.vte-hint em{background:#0000000a;border-radius:3px;padding:1px 5px;font-style:normal}.vte-scrub-section{color:#ffffffd1;background:linear-gradient(#1a1a28 0%,#0f0f1a 100%);border-radius:6px;max-width:420px;margin-top:4px;padding:10px 12px 12px}.vte-scrub-label{letter-spacing:.14em;text-transform:uppercase;color:#fff6;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;font-size:9px;font-weight:900;display:flex}.vte-scrub-badge{letter-spacing:.08em;color:#4ade80;background:#4ade801f;border:1px solid #4ade8059;border-radius:10px;padding:1px 8px;font-size:9px}.vte-scrub-zone{cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;padding:8px 2px;display:flex}.vte-scrub-zone:active{cursor:grabbing}.vte-scrub-edge-label{text-align:center;letter-spacing:.05em;color:#ffffff8c;flex-shrink:0;width:22px;font-family:SF Mono,Menlo,monospace;font-size:11px;font-weight:800}.vte-scrub-track{background:#ffffff14;border:1px solid #ffffff0d;border-radius:2px;flex:1;height:4px;position:relative}.vte-scrub-fill{pointer-events:none;background:linear-gradient(90deg,#4ade8066,#4ade80bf);border-radius:2px;position:absolute;top:0;bottom:0;left:0}.vte-scrub-thumb{pointer-events:none;width:18px;height:28px;position:absolute;top:50%;transform:translate(-50%,-50%)}.vte-jstick-dome{background:radial-gradient(at 50% 30%,#777e8a 0%,#3a3f48 70%,#1b1e23 100%);border-radius:7px 7px 2px 2px;width:14px;height:10px;position:absolute;top:0;left:50%;transform:translate(-50%);box-shadow:0 1px 2px #00000080}.vte-jstick-grip{background:linear-gradient(90deg,#2a2d33,#4d525a,#2a2d33);border-radius:1px;width:8px;height:14px;position:absolute;top:7px;left:50%;transform:translate(-50%)}.vte-jstick-base{background:radial-gradient(at 50% 20%,#4d525a 0%,#1b1e23 100%);border-radius:3px;width:18px;height:7px;position:absolute;bottom:0;left:50%;transform:translate(-50%);box-shadow:0 1px 2px #0009}.phe{background:#0000000a;border:1px solid #00000014;border-radius:8px;flex-direction:column;gap:10px;padding:12px 14px;display:flex}.phe-toolbar{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.phe-btn{cursor:pointer;background:#fff;border:1px solid #00000026;border-radius:5px;padding:5px 12px;font-family:inherit;font-size:12.5px;font-weight:600;transition:all .12s}.phe-btn:hover:not(:disabled){background:#f3f4f6}.phe-btn:disabled{opacity:.5;cursor:not-allowed}.phe-btn-primary{color:#0a0a14;background:#4ade80;border-color:#22c55e}.phe-btn-primary:hover:not(:disabled){color:#fff;background:#22c55e}.phe-btn-ghost{background:0 0}.phe-status-confirmed{color:#166534;margin-left:4px;font-size:12px;font-weight:600}.phe-error,.phe-warning{border-radius:5px;padding:6px 10px;font-size:12.5px}.phe-error{color:#991b1b;background:#dc26261f;border:1px solid #dc262666}.phe-warning{color:#92400e;background:#f59e0b1f;border:1px solid #f59e0b66}.phe-empty-hint{color:var(--color-text-secondary,#6b7280);margin:0;font-size:13px;line-height:1.55}.phe-section-title{letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-secondary,#6b7280);border-bottom:1px solid #0000001a;margin-top:6px;padding-bottom:3px;font-size:11px;font-weight:800}.phe-sheet{border-collapse:collapse;table-layout:fixed;letter-spacing:-.005em;background:#fff;border:1px solid #9ca3af;width:100%;font-family:Inter Tight,Arial Narrow,Helvetica Neue Condensed,Roboto Condensed,system-ui,sans-serif;font-size:10px;font-stretch:80%}.phe-sheet thead th{text-transform:uppercase;letter-spacing:.03em;color:#374151;text-align:left;background:#eef1f5;border:1px solid #9ca3af;padding:1px 3px;font-size:9px;font-weight:700}.phe-sheet tbody th,.phe-sheet tbody td{vertical-align:middle;border:1px solid #cbd5e1;min-width:0;padding:1px 3px}.phe-sheet tbody th.phe-row-label{color:#1f2937;text-align:left;white-space:nowrap;background:#f8fafc;font-size:10.5px;font-weight:700}.phe-sheet tbody tr:nth-child(2n) td,.phe-sheet tbody tr:nth-child(2n) th.phe-row-label{background:#fafbfc}.phe-col-block{width:110px}.phe-col-notes{width:34%}.phe-td-empty{background-image:repeating-linear-gradient(135deg,#0000 0 5px,#0000000a 5px 6px);background:#f3f4f6!important}.phe-mini-label{color:#6b7280;text-transform:uppercase;letter-spacing:.04em;margin-bottom:0;font-size:8px;line-height:1.1;display:block}.phe-input,.phe-sheet input.phe-input,.phe-sheet textarea.phe-input,.phe-sheet select.phe-input{letter-spacing:-.005em;box-sizing:border-box;-webkit-text-size-adjust:none;-moz-text-size-adjust:none;text-size-adjust:none;background:0 0;border:1px solid #0000;border-radius:0;width:100%;min-width:0;padding:0 3px;font-family:Arial Narrow,Inter Tight,Helvetica Neue Condensed,Roboto Condensed,system-ui,sans-serif;font-size:9px;font-stretch:80%;line-height:1.4}.phe-input:hover{background:#fefce8}.phe-input:focus{z-index:2;background:#fff;border-color:#22c55e;outline:none;position:relative;box-shadow:0 0 0 2px #22c55e4d}.phe-sheet select.phe-input{appearance:auto;padding-right:12px}.phe-notes-cell{position:relative}.phe-notes-cell .phe-input{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.phe-popover{z-index:30;background:#1f2937;border:1px solid #0f172a;border-radius:4px;min-width:240px;max-width:380px;padding:6px;display:none;position:absolute;top:calc(100% + 2px);left:4px;box-shadow:0 8px 22px #00000052}.phe-notes-cell:hover>.phe-popover,.phe-notes-cell:focus-within>.phe-popover{display:block}.phe-popover-textarea{letter-spacing:0;color:#f9fafb;resize:vertical;box-sizing:border-box;background:#0f172a;border:1px solid #334155;border-radius:3px;width:100%;min-height:54px;max-height:160px;padding:5px 7px;font-family:inherit;font-size:11.5px;font-stretch:100%;line-height:1.45}.phe-popover-textarea:focus{border-color:#22c55e;outline:none;box-shadow:0 0 0 2px #22c55e59}.phe-popover-label{letter-spacing:.06em;text-transform:uppercase;color:#9ca3af;margin-bottom:4px;font-size:9px;font-weight:700;display:block}.phe-list{flex-direction:column;gap:2px;display:flex}.phe-list-row{align-items:center;gap:4px;display:flex}.phe-list-row .phe-input{flex:1;min-width:0}.phe-list-remove,.phe-list-add{cursor:pointer;width:20px;height:20px;color:var(--color-text-secondary,#6b7280);background:#fff;border:1px solid #00000026;border-radius:3px;flex-shrink:0;font-size:12px;font-weight:700;line-height:1}.phe-list-remove:hover{color:#dc2626;background:#dc26261a;border-color:#dc262666}.phe-list-add{color:#22c55e}.phe-list-add:hover:not(:disabled){background:#22c55e1a;border-color:#22c55e80}.phe-list-add:disabled{opacity:.35;cursor:not-allowed}.phe-confirm-row{justify-content:flex-end;padding-top:4px;display:flex}.phe-btn-confirm{color:#0a0a14;background:#4ade80;border-color:#22c55e;padding:8px 20px;font-size:13px;font-weight:700}.phe-btn-confirm:hover{color:#fff;background:#22c55e}.phe-btn-confirmed{color:#166534;background:#22c55e1f;border:1.5px solid #22c55e;padding:8px 20px;font-size:13px;font-weight:600}.phe-btn-confirmed:hover{background:#22c55e33}.case-editor{max-width:900px;padding:var(--space-6) var(--space-4) var(--space-16);margin:0 auto}.editor-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.editor-header h1{font-size:var(--text-2xl)}.editor-actions{gap:var(--space-2);display:flex}.admin-success{color:var(--color-success);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);margin-bottom:var(--space-4);background:#f0fdf4;border:1px solid #bbf7d0}.admin-info{color:var(--color-warning);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);margin-bottom:var(--space-4);background:#fffbeb;border:1px solid #fde68a;line-height:1.5}.editor-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-6)}.editor-section h2{font-size:var(--text-lg);margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border)}.section-desc{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:calc(-1 * var(--space-2));margin-bottom:var(--space-4);line-height:1.6}.field{font-size:var(--text-sm);color:var(--color-text);margin-bottom:var(--space-4);font-weight:500;display:block}.field input,.field select,.field textarea{width:100%;margin-top:var(--space-1);padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);font-family:var(--font-sans);color:var(--color-text);background:var(--color-bg);box-sizing:border-box;display:block}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #0891b226}.field textarea{resize:vertical;line-height:1.5}.field-row{gap:var(--space-4);flex-wrap:wrap;display:flex}.field-row .field{flex:1;min-width:120px}.field-row .field-sm{flex:0 0 120px}.finding-group{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-4)}.finding-group legend{font-weight:600;font-size:var(--text-sm);padding:0 var(--space-2);color:var(--color-text)}.mode-toggle{gap:var(--space-2);margin-bottom:var(--space-3);display:flex}.mode-btn{padding:var(--space-1) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-surface);color:var(--color-text-secondary);font-size:var(--text-xs);cursor:pointer;transition:all var(--transition-fast);font-weight:500}.mode-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.editor-bottom-bar{background:var(--color-surface);border-top:1px solid var(--color-border);padding:var(--space-3) var(--space-4);justify-content:flex-end;gap:var(--space-2);z-index:50;display:flex;position:fixed;bottom:0;left:0;right:0}@media (width<=600px){.editor-header{flex-direction:column;align-items:flex-start}.field-row .field-sm{flex:1}}.eye-align{gap:var(--space-3);flex-direction:column;display:flex}.eye-align-toolbar{align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.eye-align-place-btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-secondary);font-size:var(--text-xs);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;font-weight:500;display:inline-flex}.eye-align-place-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.eye-align-place-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.eye-align-cancel-btn{padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:var(--text-xs);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);background:0 0}.eye-align-cancel-btn:hover{border-color:var(--color-error);color:var(--color-error)}.eye-align-drag-hint{font-size:var(--text-xs);color:var(--color-text-muted);font-style:italic}.eye-align-canvas-wrap{border-radius:var(--radius-md);background:#0d1622;border:1px solid #1e2d40;width:100%;position:relative;overflow:hidden}.eye-align-canvas{width:100%;display:block}.eye-align-badge{top:var(--space-2);right:var(--space-2);padding:2px var(--space-2);border-radius:var(--radius-full);letter-spacing:.06em;text-transform:uppercase;color:#22d3eebf;pointer-events:none;-webkit-user-select:none;user-select:none;background:#0891b22e;border:1px solid #0891b24d;font-size:10px;font-weight:600;position:absolute}.eye-align-controls{gap:var(--space-3);flex-direction:column;display:flex}.eye-align-group{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);background:var(--color-bg)}.eye-align-group-header{align-items:baseline;gap:var(--space-3);margin-bottom:var(--space-3);flex-wrap:wrap;display:flex}.eye-align-group-title{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.07em;color:var(--color-text);white-space:nowrap;font-weight:700}.eye-align-group-hint{font-size:var(--text-xs);color:var(--color-text-muted);line-height:1.4}.eye-align-row{align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);cursor:default;grid-template-columns:148px 1fr 56px;display:grid}.eye-align-row:last-child{margin-bottom:0}.eye-align-label{font-size:var(--text-xs);color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.eye-align-range{cursor:pointer;width:100%;accent-color:var(--color-primary);appearance:none;background:0 0;height:4px}.eye-align-range::-webkit-slider-runnable-track{background:var(--color-border);border-radius:2px;height:4px}.eye-align-range::-webkit-slider-thumb{appearance:none;background:var(--color-primary);border:2px solid var(--color-surface);width:14px;height:14px;transition:background var(--transition-fast), transform var(--transition-fast);border-radius:50%;margin-top:-5px;box-shadow:0 1px 3px #0000002e}.eye-align-range::-webkit-slider-thumb:hover{background:var(--color-primary-dark);transform:scale(1.18)}.eye-align-range::-moz-range-track{background:var(--color-border);border-radius:2px;height:4px}.eye-align-range::-moz-range-thumb{background:var(--color-primary);border:2px solid var(--color-surface);width:14px;height:14px;transition:background var(--transition-fast), transform var(--transition-fast);border-radius:50%;box-shadow:0 1px 3px #0000002e}.eye-align-range:focus{outline:none}.eye-align-range:focus-visible::-webkit-slider-thumb{box-shadow:0 0 0 3px #0891b240}.eye-align-val{font-size:var(--text-xs);font-family:var(--font-mono);color:var(--color-text-secondary);text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}.eye-align-reset{padding:var(--space-1) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-muted);font-size:var(--text-xs);font-family:var(--font-sans);cursor:pointer;transition:border-color var(--transition-fast), color var(--transition-fast);background:0 0;align-self:flex-start}.eye-align-reset:hover{border-color:var(--color-primary);color:var(--color-primary)}@media (width<=520px){.eye-align-row{grid-template-columns:110px 1fr 48px}}
