:root{--primary: #3b4d9b;--primary-dark: #2d3a7a;--primary-light: #4f63b8;--primary-rgb: 59, 77, 155;--accent: #5c6bc0;--accent-dark: #3f51b5;--accent-light: #7986cb;--success: #10b981;--warning: #f59e0b;--error: #ef4444;--info: #3b82f6;--text-primary: #1a1a2e;--text-secondary: #475569;--text-muted: #94a3b8;--text-light: #cbd5e1;--bg-primary: #f0f2f8;--bg-secondary: #e8ebf4;--bg-tertiary: #f8f9fd;--surface: #ffffff;--surface-elevated: #fafbff;--surface-card: #f8f9fd;--border-color: #c5cfe0;--border-light: #e2e8f0;--shadow-sm: 0 2px 8px rgba(59, 77, 155, .08);--shadow-md: 0 4px 16px rgba(59, 77, 155, .12);--shadow-lg: 0 8px 32px rgba(59, 77, 155, .16);--shadow-xl: 0 20px 60px rgba(59, 77, 155, .2);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 32px;--spacing-xs: 8px;--spacing-sm: 12px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px}[data-theme=dark]{--primary: #5c6bc0;--primary-dark: #4f63b8;--primary-light: #7986cb;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--text-light: #64748b;--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #1e293b;--surface: #1e293b;--surface-elevated: #334155;--surface-card: #263247;--border-color: #334155;--border-light: #475569;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 60px rgba(0, 0, 0, .6)}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;overflow-x:hidden;min-height:100vh;transition:background-color .3s ease,color .3s ease}::selection{background:rgba(var(--primary-rgb),.2);color:var(--text-primary)}*:focus-visible{outline:3px solid var(--primary);outline-offset:2px;border-radius:4px}.theme-toggle{position:fixed;top:20px;right:20px;z-index:3000;animation:slideDownFade .6s cubic-bezier(.34,1.56,.64,1) .2s backwards}.theme-toggle-btn{display:flex;align-items:center;gap:10px;padding:12px 20px;background:var(--surface);border:2px solid var(--primary);border-radius:var(--radius-md);font-size:.95rem;font-weight:600;color:var(--text-primary);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-family:inherit;box-shadow:var(--shadow-md)}.theme-toggle-btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);background:var(--surface-elevated)}.theme-toggle-btn:active{transform:translateY(-1px)}.theme-toggle-icon{font-size:1.3rem;animation:iconRotate .5s ease}@keyframes iconRotate{0%{transform:rotate(-180deg);opacity:0}to{transform:rotate(0);opacity:1}}.auth-background{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;background:var(--bg-primary);overflow:hidden;transition:background .3s ease}.auth-background:before{content:"";position:absolute;width:200%;height:200%;background:radial-gradient(circle at 15% 50%,rgba(var(--primary-rgb),.08) 0%,transparent 50%),radial-gradient(circle at 85% 30%,rgba(var(--primary-rgb),.06) 0%,transparent 50%),radial-gradient(circle at 50% 80%,rgba(var(--primary-rgb),.05) 0%,transparent 50%);animation:backgroundDrift 25s ease-in-out infinite}@keyframes backgroundDrift{0%,to{transform:translate(0) rotate(0)}33%{transform:translate(30px,-30px) rotate(1deg)}66%{transform:translate(-20px,20px) rotate(-1deg)}}.gradient-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.25;animation:floatOrb 20s ease-in-out infinite;pointer-events:none}.gradient-orb:nth-child(1){width:500px;height:500px;background:radial-gradient(circle,rgba(var(--primary-rgb),.3) 0%,transparent 70%);top:-10%;left:-10%;animation-duration:22s;animation-delay:0s}.gradient-orb:nth-child(2){width:400px;height:400px;background:radial-gradient(circle,rgba(92,107,192,.25) 0%,transparent 70%);bottom:-10%;right:-10%;animation-duration:18s;animation-delay:-8s}.gradient-orb:nth-child(3){width:350px;height:350px;background:radial-gradient(circle,rgba(79,99,184,.2) 0%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);animation-duration:25s;animation-delay:-15s}@keyframes floatOrb{0%,to{transform:translate(0) scale(1)}25%{transform:translate(40px,-40px) scale(1.1)}50%{transform:translate(-30px,50px) scale(.9)}75%{transform:translate(50px,30px) scale(1.05)}}.particles{position:absolute;width:100%;height:100%;overflow:hidden;pointer-events:none}.particle{position:absolute;width:6px;height:6px;background:var(--primary);border-radius:50%;opacity:0;box-shadow:0 0 12px rgba(var(--primary-rgb),.5);animation:particleFloat 12s infinite ease-in-out}.particle:nth-child(1){left:10%;animation-delay:0s;animation-duration:14s}.particle:nth-child(2){left:20%;animation-delay:-2s;animation-duration:16s}.particle:nth-child(3){left:30%;animation-delay:-4s;animation-duration:12s}.particle:nth-child(4){left:40%;animation-delay:-6s;animation-duration:15s}.particle:nth-child(5){left:50%;animation-delay:-8s;animation-duration:13s}.particle:nth-child(6){left:60%;animation-delay:-3s;animation-duration:17s}.particle:nth-child(7){left:70%;animation-delay:-5s;animation-duration:14s}.particle:nth-child(8){left:80%;animation-delay:-7s;animation-duration:16s}.particle:nth-child(9){left:90%;animation-delay:-9s;animation-duration:15s}.particle:nth-child(10){left:95%;animation-delay:-1s;animation-duration:18s}.particle:nth-child(11){left:5%;animation-delay:-3s;animation-duration:17s}.particle:nth-child(12){left:15%;animation-delay:-7s;animation-duration:14s}.particle:nth-child(13){left:25%;animation-delay:-1s;animation-duration:19s}.particle:nth-child(14){left:35%;animation-delay:-5s;animation-duration:16s}.particle:nth-child(15){left:45%;animation-delay:-9s;animation-duration:18s}.particle:nth-child(16){left:55%;animation-delay:-4s;animation-duration:20s}.particle:nth-child(17){left:65%;animation-delay:-6s;animation-duration:15s}.particle:nth-child(18){left:75%;animation-delay:-2s;animation-duration:22s}.particle:nth-child(19){left:85%;animation-delay:-8s;animation-duration:17s}.particle:nth-child(20){left:95%;animation-delay:-10s;animation-duration:19s}.particle:nth-child(21){left:12%;animation-delay:-3s;animation-duration:21s}.particle:nth-child(22){left:28%;animation-delay:-6s;animation-duration:18s}.particle:nth-child(23){left:42%;animation-delay:-2s;animation-duration:23s}.particle:nth-child(24){left:58%;animation-delay:-7s;animation-duration:20s}.particle:nth-child(25){left:72%;animation-delay:-4s;animation-duration:24s}.particle:nth-child(26){left:88%;animation-delay:-1s;animation-duration:22s}.particle:nth-child(27){left:33%;animation-delay:-8s;animation-duration:19s}.particle:nth-child(28){left:67%;animation-delay:-5s;animation-duration:21s}.particle:nth-child(29){left:49%;animation-delay:-9s;animation-duration:17s}.particle:nth-child(30){left:91%;animation-delay:-3s;animation-duration:25s}@keyframes particleFloat{0%{transform:translateY(110vh) translate(0) scale(0) rotate(0);opacity:0}10%{opacity:.6}90%{opacity:.6}to{transform:translateY(-10vh) translate(120px) scale(1.5) rotate(360deg);opacity:0}}.auth-page{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:60px 20px;z-index:1}.auth-page.login-page{animation:pageEnter .8s cubic-bezier(.34,1.56,.64,1)}.login-container{font-size:22px;width:100%;max-width:1250px;display:grid;grid-template-columns:1.4fr 1fr;gap:0;background:var(--surface);border:4px solid var(--primary);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-xl);animation:containerZoomIn .9s cubic-bezier(.34,1.56,.64,1) .1s backwards;position:relative}.login-container:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:4px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.8),transparent);animation:shimmerSlide 3s ease-in-out infinite;z-index:10}@keyframes shimmerSlide{0%{left:-100%}50%,to{left:200%}}.login-hero{padding:70px 60px;background:var(--surface-card);border-right:4px solid var(--primary);display:flex;flex-direction:column;justify-content:center;animation:slideInLeft .8s cubic-bezier(.34,1.56,.64,1) .2s backwards;position:relative;overflow:hidden}.login-hero:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:repeating-linear-gradient(45deg,transparent,transparent 60px,rgba(var(--primary-rgb),.02) 60px,rgba(var(--primary-rgb),.02) 61px);pointer-events:none}.login-hero-content{position:relative;z-index:1}.login-title{font-size:3.75rem;font-weight:900;line-height:1.1;margin-bottom:20px;color:var(--text-primary);letter-spacing:-.02em;animation:fadeInUp .8s cubic-bezier(.34,1.56,.64,1) .3s backwards}.login-subtitle{font-size:1.3rem;line-height:1.75;color:var(--text-secondary);margin-bottom:50px;animation:fadeInUp .8s cubic-bezier(.34,1.56,.64,1) .4s backwards;max-width:90%}.login-features{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}.login-feature{padding:32px 20px;background:var(--surface);border:3px solid var(--primary);border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;text-align:center;transition:all .4s cubic-bezier(.34,1.56,.64,1);animation:fadeInUp .6s cubic-bezier(.34,1.56,.64,1) backwards;position:relative;overflow:hidden}.login-feature:nth-child(1){animation-delay:.5s}.login-feature:nth-child(2){animation-delay:.6s}.login-feature:nth-child(3){animation-delay:.7s}.login-feature:nth-child(4){animation-delay:.8s}.login-feature:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,rgba(var(--primary-rgb),.05),rgba(var(--primary-rgb),.02));opacity:0;transition:opacity .4s ease}.login-feature:hover{transform:translateY(-8px) scale(1.02);box-shadow:var(--shadow-lg);border-color:var(--accent)}.login-feature:hover:before{opacity:1}.login-feature-icon{font-size:3.5rem;margin-bottom:16px;display:block;position:relative;z-index:1;filter:grayscale(.2);transition:all .4s ease}.login-feature:hover .login-feature-icon{transform:scale(1.15) rotate(5deg);filter:grayscale(0)}.login-feature strong{display:block;font-size:1.3rem;margin-bottom:8px;color:var(--text-primary);font-weight:700;position:relative;z-index:1}.login-feature span{font-size:.9rem;color:var(--text-secondary);line-height:1.6;position:relative;z-index:1}.login-card{padding:70px 55px;background:var(--surface);display:flex;flex-direction:column;justify-content:center;animation:slideInRight .8s cubic-bezier(.34,1.56,.64,1) .3s backwards;position:relative}.form-header{text-align:center;margin-bottom:40px}.form-header h2{font-size:3rem;font-weight:800;color:var(--text-primary);margin-bottom:10px;letter-spacing:-.01em}.form-header p{font-size:1.1rem;color:var(--text-secondary)}.auth-form,.form{display:flex;flex-direction:column;gap:24px}.form-group,label{animation:fadeInUp .5s cubic-bezier(.34,1.56,.64,1) backwards}.form-group:nth-child(1),label:nth-child(1){animation-delay:.1s}.form-group:nth-child(2),label:nth-child(2){animation-delay:.2s}.form-group:nth-child(3),label:nth-child(3){animation-delay:.3s}.form-group:nth-child(4),label:nth-child(4){animation-delay:.4s}.form-group:nth-child(5),label:nth-child(5){animation-delay:.5s}.form-label,.label-text{display:block;font-size:1.1rem;font-weight:700;color:var(--text-primary);margin-bottom:10px;letter-spacing:.01em}.form-input-wrapper{position:relative}.form-input,input[type=text],input[type=email],input[type=password],input[type=number],input[type=tel],select{width:100%;padding:16px 20px;background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;font-family:inherit;transition:all .3s cubic-bezier(.4,0,.2,1);outline:none}select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='14' height='9' viewBox='0 0 14 9' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L7 7.5L13 1.5' stroke='%233b4d9b' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:50px}.form-input::placeholder,input::placeholder{color:var(--text-muted)}.form-input:hover:not(:focus),input:hover:not(:focus),select:hover:not(:focus){border-color:var(--primary-light);background:var(--surface)}.form-input:focus,input:focus,select:focus{border-color:var(--primary);background:var(--surface);box-shadow:0 0 0 4px rgba(var(--primary-rgb),.12),var(--shadow-md);transform:translateY(-2px)}input[aria-invalid=true],select[aria-invalid=true]{border-color:var(--error);background:#ef444408}.field-error{color:var(--error);font-size:.875rem;margin-top:8px;display:flex;align-items:center;gap:6px;font-weight:600;animation:errorShake .5s ease}.field-error:before{content:"⚠";font-size:1.1rem}@keyframes errorShake{0%,to{transform:translate(0)}20%,60%{transform:translate(-8px)}40%,80%{transform:translate(8px)}}.btn,.btn-primary,.btn-secondary{padding:17px 36px;border:none;border-radius:var(--radius-md);font-size:1.05rem;font-weight:700;font-family:inherit;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden;outline:none;letter-spacing:.02em}.btn:before,.btn-primary:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#fff6;transform:translate(-50%,-50%);transition:width .6s ease,height .6s ease}.btn:active:before,.btn-primary:active:before{width:400px;height:400px}.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);color:#fff;box-shadow:var(--shadow-md);position:relative}.btn-primary:hover:not(:disabled){transform:translateY(-3px);box-shadow:var(--shadow-lg)}.btn-primary:active:not(:disabled){transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-secondary{background:rgba(var(--primary-rgb),.08);color:var(--primary-dark);border:2px solid rgba(var(--primary-rgb),.2)}.btn-secondary:hover{background:rgba(var(--primary-rgb),.15);border-color:var(--primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.btn-loading{position:relative;color:transparent;pointer-events:none}.btn-loading:after{content:"";position:absolute;top:50%;left:50%;width:22px;height:22px;margin:-11px 0 0 -11px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:buttonSpin .7s linear infinite}@keyframes buttonSpin{to{transform:rotate(360deg)}}.form-actions,.form-row{display:flex;gap:16px;margin-top:16px;animation:fadeInUp .5s cubic-bezier(.34,1.56,.64,1) .6s backwards;align-items:center}.form-footer{text-align:center;margin-top:28px;color:var(--text-secondary);font-size:.95rem;animation:fadeIn .8s ease .7s backwards}.form-footer a{color:var(--primary);text-decoration:none;font-weight:700;transition:all .2s ease;position:relative}.form-footer a:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--primary);transition:width .3s ease}.form-footer a:hover{color:var(--primary-dark)}.form-footer a:hover:after{width:100%}.auth-page.signup-page{animation:pageEnter .8s cubic-bezier(.34,1.56,.64,1)}.signup-container{width:100%;max-width:1200px;animation:containerZoomIn .9s cubic-bezier(.34,1.56,.64,1) .1s backwards}.signup-card{background:var(--surface);border:4px solid var(--primary);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-xl);display:grid;grid-template-columns:1fr 1fr;position:relative}.signup-card:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:4px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.8),transparent);animation:shimmerSlide 3s ease-in-out infinite;z-index:10}.signup-info{padding:70px 60px;background:var(--surface-card);border-right:4px solid var(--primary);display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}.signup-info:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:repeating-linear-gradient(45deg,transparent,transparent 60px,rgba(var(--primary-rgb),.02) 60px,rgba(var(--primary-rgb),.02) 61px);pointer-events:none}.signup-info-content{position:relative;z-index:1}.signup-logo{width:65px;height:65px;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:30px;margin-bottom:36px;box-shadow:var(--shadow-md);animation:logoFloat 3s ease-in-out infinite}.signup-logo img{width:100%;height:100%;object-fit:contain}@keyframes logoFloat{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-12px) rotate(3deg)}}.signup-title{font-size:3rem;font-weight:900;line-height:1.15;margin-bottom:20px;color:var(--text-primary);letter-spacing:-.02em;animation:fadeInUp .8s cubic-bezier(.34,1.56,.64,1) .3s backwards}.signup-subtitle{font-size:1.15rem;line-height:1.75;color:var(--text-secondary);margin-bottom:45px;animation:fadeInUp .8s cubic-bezier(.34,1.56,.64,1) .4s backwards}.signup-features{display:flex;flex-direction:column;gap:20px}.signup-feature{display:flex;align-items:center;gap:18px;padding:24px;background:var(--surface);border:3px solid var(--primary);border-radius:var(--radius-lg);transition:all .4s cubic-bezier(.34,1.56,.64,1);animation:slideInLeft .6s cubic-bezier(.34,1.56,.64,1) backwards;position:relative;overflow:hidden}.signup-feature:nth-child(1){animation-delay:.5s}.signup-feature:nth-child(2){animation-delay:.6s}.signup-feature:nth-child(3){animation-delay:.7s}.signup-feature:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(var(--primary-rgb),.05),transparent);transition:left .5s ease}.signup-feature:hover{transform:translate(10px);box-shadow:var(--shadow-md);border-color:var(--accent)}.signup-feature:hover:before{left:100%}.signup-feature-icon{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,rgba(var(--primary-rgb),.12),rgba(var(--primary-rgb),.18));display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0;transition:transform .4s ease}.signup-feature:hover .signup-feature-icon{transform:scale(1.1) rotate(5deg)}.signup-feature-text strong{display:block;font-size:1.1rem;margin-bottom:6px;color:var(--text-primary);font-weight:700}.signup-feature-text span{font-size:.95rem;color:var(--text-secondary);line-height:1.6}.signup-form-section{padding:70px 60px;display:flex;flex-direction:column;justify-content:center;background:var(--surface);animation:fadeInUp .8s cubic-bezier(.34,1.56,.64,1) .4s backwards}.demographics-page,.test-page{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:90px 20px 60px;z-index:1;animation:pageEnter .8s cubic-bezier(.34,1.56,.64,1)}.demographics-container,.test-container{width:100%;max-width:900px;animation:containerZoomIn .9s cubic-bezier(.34,1.56,.64,1) .1s backwards}.card,.test-card{background:var(--surface);border:4px solid var(--primary);border-radius:var(--radius-xl);padding:65px 55px;box-shadow:var(--shadow-xl);position:relative;overflow:hidden;animation:fadeInUp .8s cubic-bezier(.34,1.56,.64,1) .2s backwards}.card:before,.test-card:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:4px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.8),transparent);animation:shimmerSlide 3s ease-in-out infinite;z-index:10}.card-title{font-size:2.75rem;font-weight:900;margin-bottom:16px;color:var(--text-primary);letter-spacing:-.02em;position:relative;display:inline-block}.card-title:after{content:"";position:absolute;bottom:-10px;left:0;width:90px;height:5px;background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:3px;animation:slideInLeft .6s cubic-bezier(.34,1.56,.64,1) .4s backwards}.card-subtitle{font-size:1.1rem;color:var(--text-secondary);margin-bottom:45px;margin-top:24px;line-height:1.7;animation:fadeIn .8s ease .5s backwards}.test-header{margin-bottom:40px}.test-number{display:inline-block;padding:10px 24px;background:rgba(var(--primary-rgb),.12);border:2px solid var(--primary);border-radius:50px;font-size:.875rem;font-weight:700;color:var(--primary-dark);margin-bottom:24px;animation:badgePulse 2.5s ease-in-out infinite;letter-spacing:.05em;text-transform:uppercase}@keyframes badgePulse{0%,to{transform:scale(1);box-shadow:0 0 rgba(var(--primary-rgb),.4)}50%{transform:scale(1.05);box-shadow:0 0 0 8px rgba(var(--primary-rgb),0)}}.test-title{font-size:2.5rem;font-weight:900;margin-bottom:16px;color:var(--text-primary);letter-spacing:-.01em}.test-description{font-size:1.25rem;color:var(--text-secondary);line-height:1.75}.test-content{margin-bottom:36px}.saved-badge{padding:14px 28px;background:linear-gradient(135deg,#10b9811f,#0596691f);color:var(--success);border:3px solid rgba(16,185,129,.4);border-radius:var(--radius-md);font-weight:700;font-size:1rem;animation:successBounce .6s cubic-bezier(.68,-.55,.265,1.55);display:flex;align-items:center;gap:10px}.saved-badge:before{content:"✓";font-size:1.3rem}@keyframes successBounce{0%{opacity:0;transform:scale(.5) rotate(-10deg)}50%{transform:scale(1.1) rotate(5deg)}to{opacity:1;transform:scale(1) rotate(0)}}.app-header{position:fixed;top:0;left:0;right:0;height:75px;background:#ffffffd9;-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);border-bottom:2px solid var(--primary);z-index:2000;display:flex;align-items:center;justify-content:space-between;padding:0 50px;box-shadow:var(--shadow-md);animation:slideDownFade .6s cubic-bezier(.34,1.56,.64,1)}[data-theme=dark] .app-header{background:#1e293bd9}.app-logo{display:flex;align-items:center;gap:14px;font-size:1.3rem;font-weight:800;color:var(--text-primary);text-decoration:none;transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.app-logo:hover{transform:scale(1.05)}.logo-icon{width:45px;height:45px;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;box-shadow:var(--shadow-sm)}.user-section{display:flex;align-items:center;gap:18px}.user-info{display:flex;align-items:center;gap:14px;padding:10px 20px;background:rgba(var(--primary-rgb),.08);border:2px solid rgba(var(--primary-rgb),.2);border-radius:var(--radius-md);transition:all .3s ease}.user-info:hover{background:rgba(var(--primary-rgb),.12);border-color:var(--primary);transform:translateY(-2px)}.user-avatar{width:40px;height:40px;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.95rem;box-shadow:0 4px 12px rgba(var(--primary-rgb),.3)}.user-name{font-weight:700;color:var(--text-primary);font-size:1rem}.btn-logout{padding:11px 22px;background:#ef44441a;color:var(--error);border:2px solid rgba(239,68,68,.3);border-radius:var(--radius-md);font-size:.95rem;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);font-family:inherit}.btn-logout:hover{background:#ef44442e;border-color:var(--error);transform:translateY(-2px)}.btn-logout:active{transform:translateY(0)}.page-with-header{padding-top:75px}.page-navigation{display:flex;justify-content:space-between;gap:18px;margin-top:36px;animation:fadeInUp .6s cubic-bezier(.34,1.56,.64,1) .7s backwards}.btn-nav{padding:17px 36px;border:none;border-radius:var(--radius-md);font-size:1.05rem;font-weight:700;font-family:inherit;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex;align-items:center;gap:12px;position:relative;overflow:hidden}.btn-next{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;box-shadow:var(--shadow-md);margin-left:auto}.btn-next:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.btn-next:after{content:"→";font-size:1.3rem;transition:transform .3s ease}.btn-next:hover:after{transform:translate(5px)}.btn-prev{background:rgba(var(--primary-rgb),.08);color:var(--primary-dark);border:2px solid rgba(var(--primary-rgb),.2)}.btn-prev:before{content:"←";font-size:1.3rem;margin-right:4px;transition:transform .3s ease}.btn-prev:hover{background:rgba(var(--primary-rgb),.15);border-color:var(--primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.btn-prev:hover:before{transform:translate(-5px)}.progress-bar-container{width:100%;margin-bottom:50px;animation:fadeInUp .6s cubic-bezier(.34,1.56,.64,1) .2s backwards}.progress-bar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.progress-bar-info{display:flex;align-items:center;gap:14px}.progress-bar-label{font-size:.875rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em}.progress-bar-current{font-size:.95rem;font-weight:800;color:var(--text-primary);padding:6px 16px;background:rgba(var(--primary-rgb),.12);border-radius:50px;border:2px solid rgba(var(--primary-rgb),.2)}.progress-bar-percentage{font-size:1.75rem;font-weight:900;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.03em}.progress-bar-track{position:relative;width:100%;height:10px;background:rgba(var(--primary-rgb),.1);border-radius:50px;overflow:hidden;margin-bottom:28px;box-shadow:inset 0 2px 4px #00000014}.progress-bar-fill{position:relative;height:100%;background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:50px;transition:width .8s cubic-bezier(.34,1.56,.64,1);box-shadow:0 0 16px rgba(var(--primary-rgb),.5);overflow:hidden}.progress-bar-shine{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.6) 50%,transparent 100%);animation:progressShine 2s ease-in-out infinite}@keyframes progressShine{0%{left:-100%}50%,to{left:100%}}.progress-bar-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}.progress-step{display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center;transition:all .4s cubic-bezier(.34,1.56,.64,1)}.progress-step-marker{width:45px;height:45px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1rem;transition:all .4s cubic-bezier(.34,1.56,.64,1);position:relative}.progress-step.pending .progress-step-marker{background:rgba(var(--primary-rgb),.08);border:3px solid rgba(var(--primary-rgb),.2);color:var(--text-muted)}.progress-step.active .progress-step-marker{background:linear-gradient(135deg,var(--primary),var(--accent));border:3px solid transparent;color:#fff;transform:scale(1.2);box-shadow:0 6px 16px rgba(var(--primary-rgb),.4),0 0 0 4px rgba(var(--primary-rgb),.15);animation:stepPulse 2s ease-in-out infinite}.progress-step.completed .progress-step-marker{background:linear-gradient(135deg,var(--success),#059669);border:3px solid transparent;color:#fff;box-shadow:0 6px 16px #10b98166}@keyframes stepPulse{0%,to{box-shadow:0 6px 16px rgba(var(--primary-rgb),.4),0 0 0 4px rgba(var(--primary-rgb),.15)}50%{box-shadow:0 8px 20px rgba(var(--primary-rgb),.5),0 0 0 8px rgba(var(--primary-rgb),.2)}}.progress-step-check{width:22px;height:22px;stroke-width:3.5;animation:checkPop .5s cubic-bezier(.68,-.55,.265,1.55)}@keyframes checkPop{0%{transform:scale(0) rotate(-45deg);opacity:0}50%{transform:scale(1.3) rotate(10deg)}to{transform:scale(1) rotate(0);opacity:1}}.progress-step-label{font-size:.8rem;font-weight:700;color:var(--text-secondary);transition:color .3s ease}.progress-step.active .progress-step-label{color:var(--primary-dark);font-weight:800}.progress-step.completed .progress-step-label{color:var(--success);font-weight:800}.test-timer{width:100%;background:var(--surface);border:3px solid var(--primary);border-radius:var(--radius-lg);padding:22px 28px;margin-bottom:36px;display:flex;align-items:center;gap:18px;position:relative;overflow:hidden;box-shadow:var(--shadow-md);animation:fadeInUp .6s cubic-bezier(.34,1.56,.64,1) .3s backwards;transition:all .4s ease}.test-timer.good{border-color:var(--success);background:#10b9810a}.test-timer.warning{border-color:var(--warning);background:#f59e0b0f;animation:warningPulse 2s ease-in-out infinite}.test-timer.danger{border-color:var(--error);background:#ef444414;animation:dangerPulse 1s ease-in-out infinite}@keyframes warningPulse{0%,to{box-shadow:var(--shadow-md),0 0 #f59e0b66}50%{box-shadow:var(--shadow-lg),0 0 0 8px #f59e0b00}}@keyframes dangerPulse{0%,to{box-shadow:var(--shadow-md),0 0 #ef444499}50%{box-shadow:var(--shadow-lg),0 0 0 12px #ef444400}}.timer-icon{font-size:2.25rem;line-height:1;animation:iconBob 2s ease-in-out infinite}.test-timer.danger .timer-icon{animation:iconShake .5s ease-in-out infinite}@keyframes iconBob{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes iconShake{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(-4px) rotate(-8deg)}75%{transform:translate(4px) rotate(8deg)}}.timer-content{flex:1;display:flex;flex-direction:column;gap:5px}.timer-label{font-size:.8rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em}.timer-display{font-size:2.25rem;font-weight:900;font-variant-numeric:tabular-nums;letter-spacing:.01em;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.test-timer.warning .timer-display{background:linear-gradient(135deg,#f59e0b,#ef4444);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.test-timer.danger .timer-display{background:linear-gradient(135deg,#ef4444,#dc2626);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.timer-bar-wrapper{position:absolute;bottom:0;left:0;right:0;height:5px;background:#0000000f;overflow:hidden}.timer-bar-fill{height:100%;background:linear-gradient(90deg,var(--success),#059669);transition:width 1s linear}.test-timer.warning .timer-bar-fill{background:linear-gradient(90deg,#f59e0b,#ef4444)}.test-timer.danger .timer-bar-fill{background:linear-gradient(90deg,#ef4444,#dc2626)}.custom-notification{position:fixed;top:100px;right:50px;max-width:450px;background:var(--surface);border:3px solid var(--error);border-radius:var(--radius-lg);padding:22px;display:flex;align-items:flex-start;gap:18px;box-shadow:var(--shadow-xl);z-index:3000;opacity:0;transform:translate(calc(100% + 70px));transition:all .5s cubic-bezier(.34,1.56,.64,1);pointer-events:none}.custom-notification.show{opacity:1;transform:translate(0);pointer-events:all;animation:notificationShake .5s ease .5s}@keyframes notificationShake{0%,to{transform:translate(0)}25%,75%{transform:translate(-10px)}50%{transform:translate(10px)}}.notification-icon{font-size:2rem;flex-shrink:0;animation:iconPulse 2s ease-in-out infinite}@keyframes iconPulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.notification-content{flex:1;display:flex;flex-direction:column;gap:8px}.notification-title{font-size:1.05rem;font-weight:800;color:var(--error)}.notification-message{font-size:.95rem;color:var(--text-secondary);line-height:1.6}.notification-close{background:transparent;border:none;color:var(--text-muted);font-size:1.4rem;cursor:pointer;padding:4px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .3s ease;flex-shrink:0}.notification-close:hover{background:#ef44441f;color:var(--error);transform:rotate(90deg)}.language-selector-auth,.language-selector-header{position:fixed;top:95px;right:20px;z-index:2500;animation:slideDownFade .6s cubic-bezier(.34,1.56,.64,1) .3s backwards}.language-btn{display:flex;align-items:center;gap:12px;padding:12px 22px;background:var(--surface);border:2px solid var(--primary);border-radius:var(--radius-md);font-size:.95rem;font-weight:700;color:var(--text-primary);cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);font-family:inherit;box-shadow:var(--shadow-md)}.language-btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--accent)}.language-btn-icon{font-size:1.3rem}.language-btn-arrow{font-size:.85rem;transition:transform .3s ease}.language-btn.open .language-btn-arrow{transform:rotate(180deg)}.language-dropdown{position:absolute;top:calc(100% + 10px);right:0;min-width:220px;background:var(--surface);border:2px solid var(--primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(-15px);transition:all .4s cubic-bezier(.34,1.56,.64,1);overflow:hidden;max-height:450px;overflow-y:auto}.language-dropdown.open{opacity:1;visibility:visible;transform:translateY(0)}.language-option{display:flex;align-items:center;gap:14px;padding:16px 20px;cursor:pointer;transition:all .3s ease;border:none;background:transparent;width:100%;text-align:left;font-family:inherit;font-size:.95rem;color:var(--text-primary);font-weight:600}.language-option:hover{background:rgba(var(--primary-rgb),.1)}.language-option.active{background:rgba(var(--primary-rgb),.15);color:var(--primary-dark);font-weight:800}.language-option:not(:last-child){border-bottom:1px solid var(--border-light)}.language-option-flag{font-size:1.4rem;line-height:1}.language-option-text{flex:1}.language-option-check{color:var(--primary);font-size:1.1rem;opacity:0;transition:opacity .3s ease}.language-option.active .language-option-check{opacity:1}.language-dropdown::-webkit-scrollbar{width:7px}.language-dropdown::-webkit-scrollbar-track{background:rgba(var(--primary-rgb),.05);border-radius:10px}.language-dropdown::-webkit-scrollbar-thumb{background:rgba(var(--primary-rgb),.3);border-radius:10px}.language-dropdown::-webkit-scrollbar-thumb:hover{background:rgba(var(--primary-rgb),.5)}.doctor-admin-page{padding:28px;font-family:inherit;background:var(--bg-primary);min-height:100vh;color:var(--text-primary);transition:background .3s ease}.doctor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px}.doctor-header h1{font-size:2.5rem;font-weight:900;color:var(--text-primary);letter-spacing:-.02em}.doctor-header button.btn{padding:12px 24px;border:none;border-radius:var(--radius-md);background:var(--error);color:#fff;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:var(--shadow-sm)}.doctor-header button.btn:hover{background:#dc2626;transform:translateY(-2px);box-shadow:var(--shadow-md)}.doctor-controls{display:flex;gap:16px;align-items:center;margin-bottom:28px;flex-wrap:wrap}.form-select{width:auto;padding:12px 18px;border-radius:var(--radius-md);border:2px solid var(--border-color);background:var(--surface);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;color:var(--text-primary)}.form-select:hover{border-color:var(--primary)}.refresh-btn{padding:12px 28px!important;width:auto!important;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;font-weight:700;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:var(--shadow-md)}.refresh-btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.doctor-main{display:grid;grid-template-columns:450px 1fr;gap:28px}.patient-list{height:calc(100vh - 240px);overflow-y:auto}.patient-list .card{padding:28px}.patient-list .card h2{margin-bottom:20px;font-size:1.5rem;font-weight:800;color:var(--text-primary)}.patient-row{background:var(--surface);margin-bottom:14px;padding:18px;border-radius:var(--radius-md);border:2px solid var(--border-light);display:flex;justify-content:space-between;align-items:center;transition:all .3s cubic-bezier(.34,1.56,.64,1);cursor:pointer}.patient-row:hover{background:rgba(var(--primary-rgb),.05);border-color:var(--primary);transform:translate(5px);box-shadow:var(--shadow-sm)}.patient-row div:first-child{flex:1}.patient-details .card{min-height:calc(100vh - 240px);padding:32px}.patient-details h2{font-size:1.8rem;font-weight:900;margin-bottom:8px;color:var(--text-primary)}.patient-details h3{margin-top:24px;margin-bottom:14px;font-size:1.3rem;font-weight:800;color:var(--text-primary)}.patient-details table{width:100%;border-collapse:collapse}.patient-details table th,.patient-details table td{padding:14px 8px;font-size:.95rem;text-align:left}.patient-details table th{font-weight:800;border-bottom:3px solid var(--primary);color:var(--text-primary)}.patient-details table td{border-bottom:1px solid var(--border-light);color:var(--text-secondary)}.random-chart{background:linear-gradient(180deg,var(--surface),var(--surface-card));border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px;margin-top:20px}.score-pill{background:#6b21a81f;color:#5b21b6;font-weight:800;padding:8px 14px;border-radius:999px;font-size:.875rem;display:inline-block}@keyframes pageEnter{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes containerZoomIn{0%{opacity:0;transform:scale(.94) translateY(30px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-50px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(50px)}to{opacity:1;transform:translate(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDownFade{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:1200px){.login-container{grid-template-columns:1fr;max-width:650px}.login-hero{border-right:none;border-bottom:4px solid var(--primary);padding:60px 50px}.login-title{font-size:3rem}.signup-card{grid-template-columns:1fr}.signup-info{border-right:none;border-bottom:4px solid var(--primary);padding:60px 50px}.doctor-main{grid-template-columns:1fr}.patient-list{height:auto;max-height:500px}}@media(max-width:768px){:root{font-size:15px}.theme-toggle{top:15px;right:15px}.theme-toggle-btn{padding:10px 16px;font-size:.9rem}.login-hero,.login-card,.signup-info,.signup-form-section{padding:45px 35px}.login-title{font-size:2.5rem}.login-subtitle{font-size:1rem}.login-features{grid-template-columns:1fr;gap:14px}.login-feature{padding:24px 20px}.signup-title{font-size:2.25rem}.card,.test-card{padding:45px 35px}.card-title{font-size:2.25rem}.test-title{font-size:2rem}.app-header{padding:0 25px;height:65px}.app-logo{font-size:1.15rem}.logo-icon{width:38px;height:38px;font-size:19px}.user-name{display:none}.page-with-header{padding-top:65px}.language-selector-auth{top:80px}.progress-bar-steps{gap:10px}.progress-step-marker{width:40px;height:40px;font-size:.9rem}.progress-step-label{font-size:.75rem}.test-timer{padding:18px 22px}.timer-display{font-size:1.9rem}.custom-notification{top:85px;right:25px;left:25px;max-width:none}.doctor-admin-page{padding:20px}.doctor-header h1{font-size:2rem}}@media(max-width:480px){.auth-page,.demographics-page,.test-page{padding:30px 16px}.login-hero,.login-card,.signup-info,.signup-form-section,.card,.test-card{padding:35px 28px}.login-title{font-size:2rem}.login-subtitle{font-size:.95rem}.login-feature-icon{font-size:2.5rem}.signup-title{font-size:1.85rem}.signup-subtitle{font-size:1rem}.signup-feature{padding:18px}.card-title{font-size:1.9rem}.test-title,.form-header h2{font-size:1.75rem}.btn,.btn-primary,.btn-secondary,.btn-nav{padding:15px 28px;font-size:1rem}.form-row,.page-navigation{flex-direction:column}.btn-next{margin-left:0;order:-1}.saved-badge{width:100%;justify-content:center}.app-header{padding:0 16px;height:60px}.btn-logout{padding:9px 16px;font-size:.85rem}.page-with-header{padding-top:60px}.progress-bar-header{flex-direction:column;align-items:flex-start;gap:12px}.progress-bar-percentage{align-self:flex-end;font-size:1.5rem}.progress-bar-steps{gap:8px}.progress-step-marker{width:36px;height:36px;font-size:.85rem}.progress-step-label{font-size:.7rem}.test-timer{padding:16px 18px}.timer-icon{font-size:1.75rem}.timer-display{font-size:1.65rem}.custom-notification{top:75px;right:16px;left:16px;padding:18px}.language-selector-auth{top:75px;right:16px}.language-btn{padding:10px 16px}.language-btn-text{display:none}.doctor-admin-page{padding:16px}}@media(max-width:380px){.progress-step-label,.timer-label{display:none}.login-feature strong{font-size:.9rem}.login-feature span{font-size:.8rem}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@media print{.theme-toggle,.language-selector-auth,.language-selector-header,.app-header,.page-navigation,.btn-logout,.custom-notification{display:none!important}body{background:#fff;color:#000}.card,.test-card,.login-card,.signup-card{border:2px solid black;box-shadow:none}}@media(prefers-contrast:high){:root{--border-color: #000;--border-light: #000}[data-theme=dark]{--border-color: #fff;--border-light: #fff}.btn-primary,.btn-secondary,input,select{border:3px solid currentColor}}@media(prefers-color-scheme:dark){[data-theme=dark]{--bg-primary: #000000;--bg-secondary: #0a0a0a}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mt-1{margin-top:var(--spacing-xs)}.mt-2{margin-top:var(--spacing-sm)}.mt-3{margin-top:var(--spacing-md)}.mt-4{margin-top:var(--spacing-lg)}.mb-1{margin-bottom:var(--spacing-xs)}.mb-2{margin-bottom:var(--spacing-sm)}.mb-3{margin-bottom:var(--spacing-md)}.mb-4{margin-bottom:var(--spacing-lg)}.hidden{display:none!important}.visible{display:block!important}.role-options{display:flex;gap:12px;align-items:stretch;margin-top:8px}.role-option{flex:1;cursor:pointer;border-radius:10px;transition:all .18s ease}.role-option .role-card{padding:14px;border-radius:10px;border:1px solid rgba(255,255,255,.06);background:#ffffff05}.role-option .role-title{font-weight:600;font-size:15px}.role-option .role-desc{font-size:12px;opacity:.85;margin-top:6px}.role-option.selected .role-card{transform:translateY(-4px);box-shadow:0 10px 30px #02061759;border-color:#007bff38}.role-option.doctor-option .role-badge{background:linear-gradient(135deg,#007bff,#0046d5);color:#fff;padding:6px 8px;border-radius:8px;font-weight:700;font-size:12px;display:inline-block}.role-option.doctor-option.selected .role-card{border-color:#007bff;box-shadow:0 8px 30px #007bff38;transform:translateY(-4px) scale(1.02)}.btn-doctor{background:linear-gradient(135deg,#06f,#0046d5);color:#fff;border:none;padding:11px 18px;border-radius:10px;box-shadow:0 8px 20px #0066ff2e;transition:transform .12s ease,box-shadow .12s ease;font-weight:700}.btn-doctor:hover{transform:translateY(-3px);box-shadow:0 14px 34px #0066ff42}.btn-loading{opacity:.75;pointer-events:none}@media(max-width:768px){.login-container,.signup-card{grid-template-columns:1fr}.login-hero,.signup-info{display:none}.login-card,.signup-form{padding:30px 20px}.login-title{font-size:2.2rem}.test-card{padding:20px 14px}.test-container{padding:60px 10px}.nav-header .container{padding:0 16px}.home-hero h1{font-size:2.5rem}.home-features{grid-template-columns:1fr}.app-header{padding:10px 16px;gap:8px}.app-logo img{height:48px!important}.app-logo span{font-size:1.25rem}.user-name{display:none}.btn-logout{padding:8px 16px;font-size:.9rem}}
