:root{--beige: #fffdf4;--surface: #fdfcf8;--accent: #e02021;--accent-hover: #c11b1c;--accent-on-dark: #ff4747;--accent-muted: rgba(224, 32, 33, .12);--black: #000;--white: #fff;--text-primary: rgba(0, 0, 0, .88);--text-secondary: rgba(0, 0, 0, .68);--text-muted: rgba(0, 0, 0, .5);--text-faint: rgba(0, 0, 0, .36);--border-soft: rgba(0, 0, 0, .07);--border-medium: rgba(0, 0, 0, .14);--border-accent: rgba(224, 32, 33, .25);--font-workhorse: "TT Interphases", "TT Interphases Pro", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-emphasis: "Source Serif Pro", Georgia, serif;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 999px;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 2rem;--text-4xl: 2.5rem;--hit-target: 48px;--btn-min-height: 38px;--transition-fast: .18s ease;--transition-base: .24s ease;--shadow-card: none;--shadow-card-hover: 0 18px 36px -20px rgba(0, 0, 0, .18);--focus-ring: 0 0 0 3px rgba(224, 32, 33, .28);--status-success: #257a3e;--status-success-bg: rgba(37, 122, 62, .1);--status-warning: #8a5b00;--status-warning-bg: rgba(138, 91, 0, .1);--status-info: #2f6675;--status-info-bg: rgba(47, 102, 117, .1);--status-danger: var(--accent);--status-danger-bg: var(--accent-muted);--primary: var(--accent);--primary-hover: var(--accent-hover);--primary-light: var(--accent-muted);--primary-lighter: var(--surface);--bg-primary: var(--beige);--bg-secondary: var(--surface);--bg-card: var(--surface);--bg-hover: rgba(0, 0, 0, .035);--gray-50: var(--surface);--gray-100: rgba(0, 0, 0, .04);--gray-200: rgba(0, 0, 0, .08);--gray-300: rgba(0, 0, 0, .14);--gray-400: rgba(0, 0, 0, .28);--gray-500: rgba(0, 0, 0, .45);--gray-600: rgba(0, 0, 0, .62);--gray-700: rgba(0, 0, 0, .74);--gray-800: rgba(0, 0, 0, .84);--gray-900: rgba(0, 0, 0, .9)}[data-theme=high-contrast]{--beige: #fff;--surface: #fff;--accent: #9b0000;--accent-hover: #690000;--accent-muted: rgba(155, 0, 0, .16);--text-primary: #000;--text-secondary: #111;--text-muted: #222;--border-soft: #000;--border-medium: #000;--border-accent: #000;--shadow-card: none;--shadow-card-hover: none;--focus-ring: 0 0 0 3px #000, 0 0 0 6px var(--accent)}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.001ms!important}}:root{font-family:var(--font-workhorse, "TT Interphases", "TT Interphases Pro", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);line-height:1.5;font-weight:400;color-scheme:light;color:var(--text-primary, rgba(0, 0, 0, .88));background-color:var(--beige, #fffdf4);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;min-width:320px;min-height:100vh;background:var(--beige, #fffdf4)}#root{width:100%}:root{--primary: #E53E3E;--primary-hover: #C53030;--primary-light: #FED7D7;--primary-lighter: #FFF5F5;--gray-50: #F8F9FA;--gray-100: #F1F3F5;--gray-200: #E9ECEF;--gray-300: #DEE2E6;--gray-400: #CED4DA;--gray-500: #ADB5BD;--gray-600: #6C757D;--gray-700: #495057;--gray-800: #343A40;--gray-900: #212529;--bg-primary: #FFFFFF;--bg-secondary: #F8F9FA;--bg-card: #FFFFFF;--bg-hover: #F8F9FA;--text-primary: #212529;--text-secondary: #6C757D;--text-muted: #ADB5BD;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--shadow-card: 0 2px 8px rgba(0, 0, 0, .06);--radius-sm: 6px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 2rem;--text-4xl: 2.5rem;--transition-fast: all .15s ease;--transition-base: all .2s ease;--transition-slow: all .3s ease;--accent-pink-bg: #FFCBCA;--accent-pink-fg: #F66067;--accent-green-bg: #E7FBE2;--accent-green-fg: #6FD17C;--accent-blue-bg: #DFF1FD;--accent-blue-fg: #62A9C1;--accent-beige-bg: #F5F5DC;--accent-beige-fg: #8B7355;--shadow-card: 0 4px 20px rgba(0, 0, 0, .08);--shadow-card-hover: 0 8px 30px rgba(0, 0, 0, .12);--radius-card: 20px;--focus-ring: 0 0 0 3px rgba(229, 62, 62, .35)}[data-theme=high-contrast]{--primary: #9B2C2C;--primary-hover: #7B1F1F;--primary-light: #FFFFFF;--primary-lighter:#FFFFFF;--gray-900: #000000;--gray-800: #1a1a1a;--gray-700: #262626;--gray-600: #3f3f3f;--gray-500: #4d4d4d;--gray-400: #525252;--gray-300: #6b6b6b;--gray-200: #6b6b6b;--bg-primary: #FFFFFF;--bg-secondary: #FFFFFF;--bg-card: #FFFFFF;--bg-hover: #F0F0F0;--text-primary: #000000;--text-secondary: #1a1a1a;--text-muted: #3f3f3f;--shadow-sm: none;--shadow-md: none;--shadow-lg: none;--shadow-card: none;--shadow-card-hover: none;--focus-ring: 0 0 0 4px #000000, 0 0 0 6px var(--primary)}[data-theme=high-contrast] body{background-color:#fff}[data-theme=high-contrast] a{text-decoration:underline}[data-theme=high-contrast] .metric-card,[data-theme=high-contrast] .tests-widget,[data-theme=high-contrast] .upcoming-appointment-widget,[data-theme=high-contrast] .resources-widget,[data-theme=high-contrast] .stat-card,[data-theme=high-contrast] .card,[data-theme=high-contrast] .test-card,[data-theme=high-contrast] .form-container{border:2px solid #000000}:focus-visible{outline:none;box-shadow:var(--focus-ring)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;color:var(--text-primary);line-height:1.6;font-size:16px}.app{min-height:100vh;display:flex;flex-direction:column}.navbar{background:#fff;border-bottom:1px solid #FFE0E0;height:64px;display:flex;align-items:center;position:sticky;top:0;z-index:1000;box-shadow:0 2px 4px #e53e3e0d}.navbar-content{max-width:1400px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;width:100%}.navbar-left{display:flex;align-items:center}.theme-toggle-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--gray-200);background:var(--bg-card);color:var(--text-secondary);border-radius:var(--radius-full);cursor:pointer;transition:var(--transition-base)}.theme-toggle-btn:hover{background:var(--gray-50);color:var(--primary);border-color:var(--gray-300)}[data-theme=high-contrast] .theme-toggle-btn{border:2px solid #000000;color:#000}.logo{font-size:24px;font-weight:700;display:flex;align-items:center;text-decoration:none;cursor:pointer}.logo-stryde{color:var(--text-primary)}.logo-health{color:var(--primary);margin-left:6px}.navbar-center{display:flex;align-items:center;gap:2rem}.nav-tabs{display:flex;align-items:center;gap:.5rem}.nav-tab{padding:.5rem 1rem;border:none;background:none;color:var(--text-secondary);font-size:var(--text-base);font-weight:500;cursor:pointer;transition:var(--transition-base);position:relative}.nav-tab:hover{color:var(--text-primary)}.nav-tab.active{background:var(--primary);color:#fff;border-radius:var(--radius-md);box-shadow:0 2px 8px #e53e3e33}.mode-toggle{display:flex;gap:.5rem;margin-bottom:2rem;justify-content:center}.mode-btn{padding:.5rem 1.5rem;border:none;background:none;color:var(--text-secondary);font-size:var(--text-base);font-weight:500;cursor:pointer;transition:var(--transition-base);border-radius:var(--radius-md)}.mode-btn:hover{color:var(--text-primary);background:var(--gray-50)}.mode-btn.active{background:var(--primary);color:#fff}.navbar-right{display:flex;align-items:center;gap:1rem}.sign-out-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:none;border:1px solid var(--gray-300);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:var(--transition-base)}.sign-out-btn:hover{background:var(--gray-50);color:var(--text-primary);border-color:var(--gray-400)}.sign-out-icon{font-size:16px;transform:rotate(45deg)}.dashboard-container{max-width:1400px;margin:0 auto;padding:2rem;width:100%}.welcome-section{text-align:left;margin-bottom:3rem;padding:2rem;background:#fff;border-radius:var(--radius-xl);position:relative}.welcome-title{font-size:var(--text-4xl);font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.hospital-info{font-size:var(--text-lg);color:var(--text-secondary);font-weight:400}.overview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;padding:1.5rem;background:#fff5f5;border-radius:var(--radius-lg);border-left:4px solid var(--primary)}.section-title{font-size:var(--text-3xl);font-weight:700;color:var(--text-primary)}.onboard-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-lg);font-size:var(--text-base);font-weight:600;cursor:pointer;transition:var(--transition-base)}.onboard-btn:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:3rem}.stat-card{background:#fff5f5;padding:2rem;border-radius:var(--radius-xl);box-shadow:var(--shadow-card);border:1px solid #FFE0E0;transition:var(--transition-base);position:relative;overflow:hidden;text-align:left}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-decoration{position:absolute;top:-40px;right:-40px;width:120px;height:120px;background:var(--primary);border-radius:50%;opacity:.1}.stat-value{font-size:var(--text-4xl);font-weight:700;color:var(--primary);line-height:1;margin-bottom:.5rem}.stat-label{font-size:var(--text-base);color:var(--text-secondary);font-weight:500}.patient-table-container{background:snow;border-radius:var(--radius-xl);box-shadow:var(--shadow-card);overflow:hidden;border:1px solid #FFE8E8}.patient-table{width:100%;border-collapse:collapse}.patient-table thead{background:#fff5f5;border-bottom:1px solid #FFE0E0}.patient-table th{padding:1rem 1.5rem;text-align:left;font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.patient-table tbody tr{border-bottom:1px solid var(--gray-100);transition:var(--transition-base)}.patient-table tbody tr:hover{background:#fff5f5}.patient-table tbody tr:last-child{border-bottom:none}.patient-table td{padding:1.25rem 1.5rem;color:var(--text-primary);font-size:var(--text-base)}.patient-actions{display:flex;gap:.75rem;align-items:center}.action-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:1px solid var(--gray-300);background:#fff;border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:var(--transition-base)}.action-btn:hover{background:var(--gray-50);border-color:var(--gray-400)}.action-btn.primary{background:var(--primary);color:#fff;border-color:var(--primary)}.action-btn.primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:1.5rem;margin-bottom:2rem}.card{background:snow;border-radius:var(--radius-xl);padding:1.5rem;box-shadow:var(--shadow-card);border:1px solid #FFE8E8;transition:var(--transition-base);position:relative;overflow:hidden}.card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #e53e3e1a,0 8px 24px #00000014;border-color:#ffd0d0}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary) 0%,#FF6B6B 100%);opacity:0;transition:opacity .3s ease}.card:hover:before{opacity:1}.card-header{margin-bottom:1.5rem}.card-title{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.card-icon{font-size:24px}.card-body{display:flex;flex-direction:column;gap:1rem}.info-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid var(--gray-100)}.info-row:last-child{border-bottom:none;padding-bottom:0}.info-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.info-value{font-size:var(--text-base);color:var(--text-primary);font-weight:500}.status-badge{padding:.25rem .75rem;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-active{background:#d4edda;color:#155724}.status-pending{background:#fff3cd;color:#856404}.status-completed{background:#ffe0e0;color:var(--primary);border:1px solid #FFD0D0}.tests-section{margin-top:2rem}.section-header{margin-bottom:1.5rem}.test-grid{display:flex;flex-direction:column;gap:1rem}.test-card{background:snow;border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-card);border:1px solid #FFE8E8;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;transition:var(--transition-base);position:relative;overflow:hidden}.test-card:after{content:"";position:absolute;top:-30px;right:-30px;width:80px;height:80px;background:var(--primary);border-radius:50%;opacity:.05}.test-card:hover{transform:translate(4px);box-shadow:var(--shadow-md)}.test-info{flex:1}.test-name{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.test-description{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:.5rem}.test-meta{display:flex;gap:1.5rem;align-items:center;flex-wrap:wrap}.test-detail{font-size:var(--text-sm);color:var(--text-secondary)}.test-detail strong{font-weight:600;color:var(--text-primary)}.test-actions{display:flex;gap:.75rem}.btn{padding:.45rem 1.25rem;border-radius:var(--radius-md);font-weight:600;font-size:var(--text-base);cursor:pointer;transition:var(--transition-base);border:none;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;text-decoration:none}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 4px 12px #e53e3e33}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:#fff5f5;color:var(--primary);border:1px solid #FFE0E0}.btn-secondary:hover{background:var(--gray-50);border-color:var(--gray-400)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.form-container{max-width:480px;margin:3rem auto;background:snow;border-radius:var(--radius-xl);padding:2.5rem;box-shadow:0 8px 24px #e53e3e14;border:1px solid #FFE8E8;position:relative;overflow:hidden}.form-container:after{content:"";position:absolute;bottom:-60px;right:-60px;width:200px;height:200px;background:var(--primary);border-radius:50%;opacity:.03}.form-header{text-align:center;margin-bottom:2rem}.form-title{font-size:var(--text-3xl);font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.form-subtitle{color:var(--text-secondary);font-size:var(--text-base)}.form-group{margin-bottom:1.5rem}.form-label{display:block;margin-bottom:.5rem;font-weight:500;font-size:var(--text-sm);color:var(--text-primary)}.form-input{width:100%;padding:.75rem 1rem;border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--text-base);transition:var(--transition-base);background:#fff}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #e53e3e1a}.form-input:hover{border-color:var(--gray-400)}.pre-filled{background:#f0fff4!important;border-color:#48bb78!important}.pre-filled-indicator{color:#48bb78;font-size:var(--text-xs);font-weight:600;margin-left:.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.error-message{background:#fed7d7;border:1px solid #FC8181;color:#c53030;padding:.75rem 1rem;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem}.success-message{background:#d4edda;border:1px solid #C3E6CB;color:#155724;padding:.75rem 1rem;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem}.dev-seed-panel{margin-bottom:1.25rem;padding:.75rem 1rem;background:var(--primary-lighter);border:1px dashed var(--primary);border-radius:var(--radius-md);display:flex;align-items:center;gap:.75rem;font-size:var(--text-sm)}.dev-seed-label{font-size:var(--text-xs);font-weight:700;color:var(--primary);letter-spacing:.1em}.dev-seed-btn{margin-left:auto;background:var(--primary);color:#fff;border:none;padding:.4rem .85rem;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:var(--transition-base)}.dev-seed-btn:hover{background:var(--primary-hover)}.portal-type{font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);letter-spacing:.02em}.switch-mode{margin-top:1.5rem;text-align:center;color:var(--text-secondary);font-size:var(--text-sm)}.link-button{background:none;border:none;padding:0;color:var(--primary);font-size:inherit;font-weight:600;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.link-button:hover{color:var(--primary-hover)}.invitation-required-notice{margin-top:1.5rem;padding:1rem 1.25rem;background:var(--primary-lighter);border:1px solid var(--primary-light);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);line-height:1.6}.invitation-required-notice p{margin:0}.invitation-required-notice p+p{margin-top:.5rem}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;padding:3rem}.loading-spinner{width:48px;height:48px;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1.5rem}.loading-spinner.small{width:24px;height:24px;border-width:2px;margin-bottom:.75rem}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--text-secondary);font-weight:500;font-size:var(--text-base)}.test-container{width:100%;margin:0;padding:2rem;min-height:100vh;background:#fff;display:flex;flex-direction:column;justify-content:center}.test-header{background:#fff;border:none;box-shadow:none;padding:1rem 0;margin-bottom:2rem;text-align:left}.test-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.test-category{color:var(--text-secondary);font-size:.9rem;font-weight:400}.test-progress{margin-top:2rem;padding-top:1rem;border-top:none}.progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;font-size:var(--text-sm);color:var(--text-secondary)}.progress-bar{width:100%;height:8px;background:var(--gray-200);border-radius:var(--radius-full);overflow:hidden;position:relative;margin-top:1rem}.progress-fill{height:100%;background:var(--primary);transition:width .3s ease}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.625rem;font-weight:600;color:var(--text-primary);text-shadow:0 0 2px white}.question-container{background:snow;border-radius:var(--radius-xl);padding:2.5rem;margin-bottom:2rem;box-shadow:var(--shadow-card);border:1px solid #FFE8E8;position:relative;overflow:hidden}.question-header{margin-bottom:2rem}.question-text{font-size:var(--text-xl);font-weight:600;color:var(--text-primary);line-height:1.6}.options-container{display:flex;flex-direction:column;gap:1rem}.text-options{gap:1rem}.image-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.option-button{padding:1rem 1.5rem;border:1px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s ease;font-size:1rem;color:var(--text-primary);text-align:left;width:100%;display:flex;align-items:center;margin:.5rem 0}.option-button:hover{background:#f8f9fa;border-color:#ccc}.option-button:active{background:#e9ecef}.option-text{font-size:var(--text-base);font-weight:500}.option-image-container{display:flex;flex-direction:column;align-items:center;gap:.75rem;width:100%}.option-image-container img{max-width:100%;height:120px;object-fit:contain;border-radius:var(--radius-md)}.question-counter{display:flex;justify-content:center;margin-top:2rem}.counter-dots{display:flex;gap:.5rem}.counter-dot{width:8px;height:8px;border-radius:50%;background:#ffe0e0;transition:var(--transition-base)}.counter-dot.completed{background:var(--primary);width:12px}.counter-dot.current{background:var(--primary);width:24px;border-radius:4px}.counter-dot.upcoming{background:#ffe0e0}.test-navigation{display:flex;justify-content:space-between;align-items:center;margin-top:2rem}.nav-btn{padding:.75rem 1.5rem;border-radius:var(--radius-md);font-weight:600;font-size:var(--text-base);cursor:pointer;transition:var(--transition-base);border:1px solid var(--gray-300);background:#fff;color:var(--text-primary)}.nav-btn:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-400)}.nav-btn:disabled{opacity:.5;cursor:not-allowed}.test-instructions{background:#fff5f5;border-left:4px solid var(--primary);padding:1.5rem;border-radius:var(--radius-lg);margin-bottom:2rem}.test-instructions h3{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.test-instructions p{color:var(--text-secondary);line-height:1.6}.completion-container,.test-complete{text-align:center;padding:4rem 2rem;background:snow;border-radius:var(--radius-xl);box-shadow:var(--shadow-card);border:1px solid #FFE8E8;position:relative;overflow:hidden}.completion-content{position:relative;z-index:1}.checkmark-circle{width:80px;height:80px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 2rem;box-shadow:0 4px 12px #e53e3e4d}.checkmark{font-size:40px;color:#fff;font-weight:700}.complete-icon{width:80px;height:80px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 2rem;font-size:40px;color:#fff}.complete-title{font-size:var(--text-2xl);font-weight:700;color:var(--text-primary);margin-bottom:1rem}.complete-message{font-size:var(--text-lg);color:var(--text-secondary);margin-bottom:2rem}@media (max-width: 768px){.navbar-content{padding:0 1rem}.navbar-center{display:none}.dashboard-container{padding:1rem}.welcome-title{font-size:var(--text-3xl)}.section-title{font-size:var(--text-2xl)}.dashboard-grid,.stats-grid{grid-template-columns:1fr}.patient-table-container{overflow-x:auto}.form-container{margin:2rem 1rem;padding:2rem}.form-row{grid-template-columns:1fr}.test-card{flex-direction:column;align-items:flex-start}.test-actions{width:100%;margin-top:1rem}.btn{width:100%}}@media (max-width: 480px){.logo{font-size:20px}.sign-out-btn span:not(.sign-out-icon){display:none}.overview-header{flex-direction:column;gap:1rem;align-items:flex-start}.onboard-btn{width:100%}.patient-table th,.patient-table td{padding:.75rem}.action-btn span{display:none}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-primary{color:var(--primary)}.text-muted{color:var(--text-secondary)}.mt-1{margin-top:var(--space-sm)}.mt-2{margin-top:var(--space-md)}.mt-3{margin-top:var(--space-lg)}.mt-4{margin-top:var(--space-xl)}.mb-1{margin-bottom:var(--space-sm)}.mb-2{margin-bottom:var(--space-md)}.mb-3{margin-bottom:var(--space-lg)}.mb-4{margin-bottom:var(--space-xl)}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-column{display:flex;flex-direction:column}.flex-1{flex:1}.gap-1{gap:var(--space-sm)}.gap-2{gap:var(--space-md)}.gap-3{gap:var(--space-lg)}.gap-4{gap:var(--space-xl)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.card,.stat-card,.test-card{animation:fadeInUp .5s ease;animation-fill-mode:both}.card:nth-child(1),.stat-card:nth-child(1),.test-card:nth-child(1){animation-delay:.1s}.card:nth-child(2),.stat-card:nth-child(2),.test-card:nth-child(2){animation-delay:.15s}.card:nth-child(3),.stat-card:nth-child(3),.test-card:nth-child(3){animation-delay:.2s}.card:nth-child(4),.test-card:nth-child(4){animation-delay:.25s}.layout-with-sidebar{display:flex;flex:1}.sidebar{width:80px;background:#fff;border-right:1px solid #FFE0E0;display:flex;flex-direction:column;position:sticky;top:64px;height:calc(100vh - 64px);z-index:100;justify-content:space-between}.sidebar-nav{display:flex;flex-direction:column;padding:2rem 0;gap:.5rem;flex:1;justify-content:center;align-items:center}.sidebar-bottom{display:flex;flex-direction:column;padding:1.5rem 0;align-items:center}.sidebar-item{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border:none;background:none;color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-base);position:relative}.sidebar-item:hover{background:#fff5f5;color:var(--primary)}.sidebar-item.active{background:var(--primary);color:#fff;box-shadow:0 2px 8px #e53e3e33}.sidebar-item.active:after{content:"";position:absolute;right:-1px;top:50%;transform:translateY(-50%);width:3px;height:24px;background:var(--primary);border-radius:2px 0 0 2px}.sidebar-logout{opacity:.7}.sidebar-logout:hover{opacity:1;background:#fee2e2;color:#dc2626}.layout-with-sidebar .main-content{flex:1;overflow-x:auto}.metric-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin:2rem 0}.metric-card{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #00000014;border:1px solid #F1F3F5;transition:var(--transition-base);position:relative;min-height:210px}.metric-card:hover{transform:translateY(-2px);box-shadow:0 8px 30px #0000001f}.metric-header{display:flex;align-items:center;gap:.5rem;margin-bottom:3rem}.metric-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.incomplete-tests .metric-icon{background:#ffcbca;color:#f66067}.completed-tests .metric-icon{background:#e7fbe2;color:#6fd17c}.upcoming-appointment .metric-icon{background:#dff1fd;color:#62a9c1}.metric-label{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.metric-main{display:flex;align-items:baseline;gap:.75rem}.metric-value{font-size:3rem;font-weight:600;color:var(--text-primary);line-height:1;letter-spacing:-.02em}.metric-status{font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);text-transform:lowercase}.tests-widget{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #00000014;border:1px solid #F1F3F5;margin-top:2rem}.tests-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.tests-icon{width:48px;height:48px;background:beige;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#8b7355}.tests-icon-pending{background:var(--accent-muted);color:var(--accent)}.tests-title h3{font-size:var(--text-xl);font-weight:700;color:var(--text-primary);margin:0}.tests-subtitle{font-size:var(--text-sm);color:var(--text-secondary)}.tests-list{display:flex;flex-direction:column;gap:.5rem}.test-checkbox{flex-shrink:0}.checkbox-unchecked{width:20px;height:20px;border:2px solid #E5E7EB;border-radius:4px;background:#fff}.checkbox-checked{width:20px;height:20px;background:#f66067;border-radius:4px;display:flex;align-items:center;justify-content:center;color:#fff}.test-item{display:grid;grid-template-columns:auto 2fr 1fr auto;align-items:center;gap:1rem;padding:.75rem 0;border-bottom:none}.test-details{display:contents}.test-name{font-size:var(--text-base);font-weight:500;color:var(--text-primary);line-height:1.2;margin:0}.test-item.completed .test-name{color:var(--text-secondary)}.test-tag{padding:.25rem .75rem;border-radius:12px;font-size:var(--text-xs);font-weight:600;line-height:1;margin:0;background:#dff1fd;color:#62a9c1;justify-self:start;text-transform:uppercase;letter-spacing:.06em}.test-start-btn{background:#f66067;color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:var(--transition-base);line-height:1.2;display:flex;align-items:center;gap:.25rem}.test-start-btn:hover{background:#e55055}.test-complete{background:var(--text-secondary);color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;font-size:var(--text-sm);font-weight:500;line-height:1.2;display:flex;align-items:center;gap:.25rem}.see-all-container{display:flex;justify-content:center;margin-top:1rem;padding-top:1rem;border-top:1px solid #F1F3F5}.see-all-btn{background:none;border:1px solid #E5E7EB;color:var(--text-secondary);padding:.5rem 1rem;border-radius:8px;font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:var(--transition-base)}.see-all-btn:hover{background:var(--bg-hover);border-color:var(--text-secondary)}.profile-info-list{display:flex;flex-direction:column;gap:1rem}.profile-info-item{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;border-bottom:1px solid #F1F3F5}.profile-info-item:last-child{border-bottom:none}.profile-label{font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.profile-value{font-size:var(--text-base);color:var(--text-secondary);text-align:right}.profile-cards-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:2rem;margin-top:2rem}.profile-cards-container .tests-widget{margin-top:0}.dashboard-top-section{display:flex;gap:2rem;align-items:flex-start;margin-bottom:2rem}.dashboard-bottom-section{display:flex;gap:2rem;align-items:flex-start}.dashboard-top-section .metric-cards{flex:2;margin:0}.dashboard-bottom-section .tests-widget{flex:2;margin-top:0}.upcoming-appointment-widget{flex:1;background:#fff;border-radius:20px;border:1px solid #F1F3F5;box-shadow:0 4px 20px #00000014;padding:2rem;height:210px}.upcoming-appointment-widget .widget-header{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1rem}.upcoming-appointment-widget .header-icon{background-color:beige;border-radius:50%;padding:.5rem;display:flex;align-items:center;justify-content:center;color:#8b7355;width:32px;height:32px}.upcoming-appointment-widget .header-text h3{margin:0;font-size:1.125rem;font-weight:600;color:#111827}.upcoming-appointment-widget .header-subtitle{margin:.25rem 0 0;font-size:.875rem;color:#6b7280}.appointment-content{display:flex;align-items:center;gap:1rem;margin-top:.5rem}.upcoming-appointment-widget .date-badge{background-color:#dff1fd;border-radius:12px;padding:.75rem;text-align:center;min-width:70px;flex-shrink:0}.upcoming-appointment-widget .date-month{font-size:.75rem;color:#62a9c1;font-weight:600;text-transform:uppercase;margin-bottom:.25rem}.upcoming-appointment-widget .date-day{font-size:1.25rem;font-weight:700;color:#62a9c1;margin-bottom:.125rem}.upcoming-appointment-widget .date-year{font-size:.875rem;color:#6b7280}.upcoming-appointment-widget .appointment-info{flex:1}.upcoming-appointment-widget .appointment-time{font-size:1rem;color:#111827;margin-bottom:.25rem}.upcoming-appointment-widget .appointment-doctor{font-size:.9rem;color:#374151;margin-bottom:.125rem}.upcoming-appointment-widget .appointment-type{font-size:.8rem;color:#6b7280}.appointment-date{display:flex;flex-direction:column;align-items:center;background:#dff1fd;border-radius:12px;padding:1rem;min-width:80px}.appointment-day{font-size:1.25rem;font-weight:700;color:#62a9c1}.appointment-year{font-size:.875rem;color:var(--text-secondary)}.appointment-details{flex:1}.appointment-time{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.appointment-doctor{font-size:.95rem;color:var(--text-secondary);margin-bottom:.25rem}.appointment-type{font-size:.875rem;color:var(--text-muted)}.resources-widget{flex:1;background:#fff;border-radius:20px;border:1px solid #F1F3F5;box-shadow:0 4px 20px #00000014;padding:2rem}.resources-content{margin-top:1rem}.resource-video{width:100%;border-radius:12px;background:#000;outline:none}.resource-video-placeholder{min-height:180px;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:var(--accent-muted);color:var(--text-secondary);font-size:var(--text-sm);font-weight:600;text-align:center}.video-description{margin-top:1rem;padding:.5rem 0}.video-description h4{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem}.video-description p{font-size:.875rem;color:var(--text-secondary);line-height:1.4;margin:0}.latest-assessment .metric-icon{background:#dff1fd;color:#62a9c1}.back-btn{background:#fff;color:var(--primary, #E53E3E);border:2px solid var(--primary, #E53E3E);padding:.5rem 1rem;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.5rem;font-family:var(--font-family, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif)}.back-btn:hover{background:var(--primary, #E53E3E);color:#fff;transform:translateY(-1px);box-shadow:0 2px 8px #e53e3e33}@media (max-width: 1024px){.dashboard-top-section,.dashboard-bottom-section{flex-direction:column}.upcoming-appointment-widget,.resources-widget,.dashboard-top-section .metric-cards,.dashboard-bottom-section .tests-widget{flex:none}}:root{--beige: #fffdf4;--surface: #fdfcf8;--accent: #e02021;--accent-hover: #c11b1c;--accent-on-dark: #ff4747;--accent-muted: rgba(224, 32, 33, .12);--black: #000;--white: #fff;--text-primary: rgba(0, 0, 0, .88);--text-secondary: rgba(0, 0, 0, .68);--text-muted: rgba(0, 0, 0, .5);--border-soft: rgba(0, 0, 0, .07);--border-medium: rgba(0, 0, 0, .14);--border-accent: rgba(224, 32, 33, .25);--font-workhorse: "TT Interphases", "TT Interphases Pro", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 999px;--hit-target: 48px;--btn-min-height: 38px;--shadow-card: none;--shadow-card-hover: 0 18px 36px -20px rgba(0, 0, 0, .18);--focus-ring: 0 0 0 3px rgba(224, 32, 33, .28);--primary: var(--accent);--primary-hover: var(--accent-hover);--primary-light: var(--accent-muted);--primary-lighter: var(--surface);--bg-primary: var(--beige);--bg-secondary: var(--surface);--bg-card: var(--surface);--bg-hover: rgba(0, 0, 0, .035)}html,body,#root,.app{background:var(--beige);color:var(--text-primary);font-family:var(--font-workhorse)}body{min-width:320px;font-size:16px}.navbar{height:68px;background:var(--beige);border-bottom:1px solid var(--border-soft);box-shadow:none}.navbar-content{max-width:1440px;padding:0 clamp(1rem,3vw,2.5rem)}.logo{color:var(--text-primary);font-size:1.45rem;font-weight:600;letter-spacing:0}.logo-mark{width:32px;height:32px;margin-right:10px;border-radius:50%;object-fit:cover}.logo-health,.text-primary{color:var(--accent)}.portal-type,.navbar-email{color:var(--text-secondary);font-size:.95rem;font-weight:500}.theme-toggle-btn,.sidebar-item{min-width:var(--hit-target);min-height:var(--hit-target);border:1.5px solid var(--border-medium);border-radius:var(--radius-full);background:transparent;color:var(--text-secondary);box-shadow:none}.theme-toggle-btn:hover,.sidebar-item:hover{background:var(--accent-muted);border-color:var(--border-accent);color:var(--accent)}.theme-toggle-btn[data-theme-mode=high-contrast]{font-weight:700}.layout-with-sidebar{background:var(--beige)}.sidebar{width:84px;background:var(--beige);border-right:1px solid var(--border-soft);top:68px;height:calc(100vh - 68px)}.sidebar-nav{gap:.75rem}.sidebar-item.active{background:var(--accent);color:var(--white);border-color:var(--accent);box-shadow:none}.sidebar-item.active:after,.stat-decoration,.card:before,.test-card:after,.form-container:after{display:none}.sidebar-logout:hover{background:var(--accent-muted);color:var(--accent)}.sidebar{width:132px}.sidebar .sidebar-logout{width:auto;min-width:104px;padding:0 1rem;gap:.5rem;border-color:var(--accent);color:var(--accent);font-weight:700;opacity:1}.sidebar .sidebar-logout:focus-visible,.metric-card-action:focus-visible,.completed-result-item:focus-visible{outline:none;box-shadow:var(--focus-ring)}.metric-card-action{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;text-align:left;font:inherit;cursor:pointer}.metric-card-action .metric-main,.metric-card-action .metric-header{pointer-events:none}.tests-section-label{margin:.75rem 0 .25rem;color:var(--text-secondary);font-size:var(--text-sm);font-weight:700;letter-spacing:.04em;text-transform:uppercase}.tests-pending-panel{border:1px solid var(--border-accent);border-left:4px solid var(--accent);border-radius:var(--radius-lg);background:var(--beige);padding:1rem 1.25rem 1.25rem}.tests-completed-panel{margin-top:1.5rem;border:1px solid var(--border-soft);border-radius:var(--radius-lg);background:var(--surface);padding:1rem 1.25rem 1.25rem}.tests-section-heading{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.tests-section-heading h4{margin:0;font-size:var(--text-sm);font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}.tests-section-heading-muted h4{color:var(--text-secondary)}.tests-count-badge,.tests-completed-count{display:inline-flex;align-items:center;justify-content:center;min-width:1.5rem;height:1.5rem;padding:0 .45rem;border-radius:var(--radius-full);background:var(--accent);color:var(--white);font-size:var(--text-xs);font-weight:700;line-height:1}.tests-completed-count{background:var(--text-muted)}.tests-pending-list,.tests-completed-list{display:flex;flex-direction:column;gap:.75rem}.tests-pending-item{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1rem;border:1px solid var(--border-soft);border-radius:var(--radius-md);background:var(--white)}.tests-pending-item-body{display:flex;flex-direction:column;gap:.35rem;min-width:0;flex:1}.tests-pending-name{font-size:var(--text-base);font-weight:600;color:var(--text-primary);line-height:1.3}.tests-pending-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem}.tests-status-chip{display:inline-flex;align-items:center;padding:.2rem .55rem;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;letter-spacing:.03em;text-transform:uppercase}.tests-status-chip.in-progress{background:var(--status-warning-bg);color:var(--status-warning)}.tests-status-chip.not-started{background:var(--status-info-bg);color:var(--status-info)}.tests-category-chip{display:inline-flex;align-items:center;padding:.2rem .55rem;border-radius:var(--radius-full);background:var(--accent-muted);color:var(--accent);font-size:var(--text-xs);font-weight:600;letter-spacing:.04em;text-transform:uppercase}.tests-progress{display:flex;flex-direction:column;gap:.25rem;margin-top:.15rem;max-width:14rem}.tests-progress-bar{height:6px;border-radius:var(--radius-full);background:var(--border-soft);overflow:hidden}.tests-progress-fill{height:100%;border-radius:inherit;background:var(--accent)}.tests-progress-label{font-size:var(--text-xs);color:var(--text-secondary);font-weight:500}.tests-pending-action{flex-shrink:0;align-self:center;background:var(--accent);color:var(--white);border:none;padding:.55rem 1rem;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:var(--transition-base);line-height:1.2;display:inline-flex;align-items:center;gap:.35rem;min-height:var(--btn-min-height)}.tests-pending-action:hover{background:var(--accent-hover)}.tests-pending-empty,.tests-completed-empty{padding:1.25rem .5rem;text-align:center}.tests-completed-item{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:.75rem 1rem;width:100%;padding:.85rem 1rem;border:1px solid var(--border-soft);border-radius:var(--radius-md);background:transparent;color:inherit;font:inherit;text-align:left;cursor:pointer;transition:background var(--transition-fast)}.tests-completed-item:hover{background:#00000008}.tests-completed-item:focus-visible{outline:none;box-shadow:var(--focus-ring)}.tests-completed-item-body{display:flex;align-items:flex-start;gap:.65rem;min-width:0}.tests-completed-icon{flex-shrink:0;width:22px;height:22px;border-radius:50%;background:var(--status-success-bg);color:var(--status-success);display:inline-flex;align-items:center;justify-content:center;margin-top:.1rem}.tests-completed-details{display:flex;flex-direction:column;gap:.15rem;min-width:0}.tests-completed-name{font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);line-height:1.3}.tests-completed-meta{font-size:var(--text-xs);color:var(--text-muted)}.tests-completed-score{display:flex;flex-direction:column;align-items:flex-end;gap:.1rem}.tests-completed-score-label{font-size:var(--text-xs);font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted)}.tests-completed-score-value{font-size:var(--text-lg);font-weight:700;color:var(--text-primary);line-height:1}.tests-completed-view{display:inline-flex;align-items:center;gap:.25rem;padding:.35rem .65rem;border:1px solid var(--border-medium);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--text-xs);font-weight:600;pointer-events:none}.completed-section-label{margin-top:1.5rem}.completed-empty-state{border-top:1px solid var(--border-soft)}.completed-result-item{width:100%;border:0;border-top:1px solid var(--border-soft);background:transparent;color:inherit;font:inherit;text-align:left;cursor:pointer;grid-template-columns:auto 2fr auto auto}.completed-result-item:hover{background:var(--bg-hover)}.completed-result-score{color:var(--text-primary);font-size:var(--text-lg);font-weight:700;justify-self:end}.completed-result-action{pointer-events:none}.result-detail-page{display:flex;flex-direction:column;gap:1.25rem}.result-detail-card,.result-support-card,.result-stat-card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius-xl);box-shadow:none}.result-detail-card{padding:clamp(1.25rem,3vw,2rem)}.result-hero-card{display:flex;align-items:center;justify-content:space-between;gap:1.5rem}.result-title-group{display:flex;align-items:center;gap:1rem}.result-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:var(--radius-full);background:var(--accent-muted);color:var(--accent)}.result-eyebrow{margin:0 0 .35rem;color:var(--text-secondary);font-size:var(--text-sm);font-weight:700;letter-spacing:.04em;text-transform:uppercase}.result-detail-card h1,.result-detail-card h2,.result-support-card h3,.domain-summary-row h3{margin:0;color:var(--text-primary);font-weight:600;letter-spacing:0}.result-detail-card h1{font-size:clamp(2rem,4vw,3rem)}.result-detail-card h2{margin-bottom:1rem;font-size:clamp(1.5rem,3vw,2rem)}.result-muted{margin:.4rem 0 0;color:var(--text-secondary);font-size:var(--text-base);line-height:1.5}.result-score-panel{min-width:180px;padding:1rem 1.25rem;border:1px solid var(--border-accent);border-radius:var(--radius-lg);background:var(--accent-muted);color:var(--accent);text-align:center}.result-score-value,.result-stat-value{display:block;color:var(--text-primary);font-size:clamp(2rem,4vw,3rem);font-weight:700;line-height:1}.result-score-label,.result-stat-label{display:block;margin-top:.5rem;color:var(--text-secondary);font-size:var(--text-base);font-weight:600}.result-stat-grid,.result-support-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.result-stat-card,.result-support-card{padding:1.25rem}.result-stat-card{color:var(--accent)}.result-stat-card svg{margin-bottom:1rem}.result-pill-list{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0 0;padding:0;list-style:none}.result-pill-list li{padding:.5rem .85rem;border:1px solid var(--border-accent);border-radius:var(--radius-full);background:var(--accent-muted);color:var(--accent);font-weight:700}.domain-summary-list{display:flex;flex-direction:column;gap:.75rem}.domain-summary-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 0;border-top:1px solid var(--border-soft)}.domain-summary-row:first-child{border-top:0}.domain-score{min-width:76px;color:var(--text-primary);font-size:var(--text-xl);font-weight:700;text-align:right}.main-content{background:var(--beige)}.dashboard-container{max-width:1440px;padding:clamp(1.25rem,3vw,2.5rem)}.welcome-section{margin-bottom:2rem;padding:0;background:transparent;border-radius:0}.welcome-title,.form-title,.section-title{color:var(--text-primary);font-weight:400;letter-spacing:-.02em}.welcome-title{font-size:clamp(2rem,4vw,3.25rem)}.dashboard-top-section,.dashboard-bottom-section{gap:1.5rem}.metric-card,.tests-widget,.upcoming-appointment-widget,.resources-widget,.card,.test-card,.form-container,.question-container,.completion-container,.test-complete{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius-xl);box-shadow:none}.metric-card,.tests-widget,.upcoming-appointment-widget,.resources-widget{padding:clamp(1.25rem,2.4vw,2rem)}.metric-card:hover,.tests-widget:hover,.resources-widget:hover,.upcoming-appointment-widget:hover,.card:hover,.test-card:hover{transform:translateY(-3px);border-color:var(--border-accent);box-shadow:var(--shadow-card-hover)}.metric-card{min-height:190px}.metric-cards{gap:1rem}.metric-header,.tests-header,.upcoming-appointment-widget .widget-header{margin-bottom:1.5rem}.metric-icon,.tests-icon,.upcoming-appointment-widget .header-icon{width:44px;height:44px;border-radius:var(--radius-full);background:var(--accent-muted);color:var(--accent)}.incomplete-tests .metric-icon,.completed-tests .metric-icon,.latest-assessment .metric-icon,.upcoming-appointment .metric-icon,.tests-icon{background:var(--accent-muted);color:var(--accent)}.metric-label,.tests-title h3,.upcoming-appointment-widget .header-text h3,.video-description h4,.profile-label{color:var(--text-primary);font-weight:600}.metric-value{color:var(--text-primary);font-size:clamp(2.25rem,5vw,3rem);font-weight:400;letter-spacing:-.02em}.metric-status,.tests-subtitle,.upcoming-appointment-widget .header-subtitle,.video-description p,.profile-value,.test-tag,.no-appointment{color:var(--text-secondary)}.test-item{min-height:56px;border-top:1px solid var(--border-soft)}.tests-empty-state{padding:2rem;text-align:center}.tests-empty-title{margin-bottom:.5rem;color:var(--text-primary);font-size:var(--text-lg);font-weight:600}.tests-empty-copy{color:var(--text-secondary)}.test-item:first-child{border-top:0}.test-tag,.status-badge{background:var(--accent-muted);color:var(--accent);border:1px solid var(--border-accent);border-radius:var(--radius-full)}.checkbox-checked,.test-start-btn,.test-complete,.btn-primary,.action-btn.primary,.onboard-btn,.dev-seed-btn,.dev-demo-btn,.timer-button,.navigator-button{background:var(--accent);color:var(--white);border:1.5px solid var(--accent);border-radius:var(--radius-full);box-shadow:none}.test-start-btn,.test-complete,.see-all-btn,.dev-seed-btn,.dev-demo-btn{min-height:var(--hit-target);padding:.75rem 1.25rem;font-size:var(--text-base);font-weight:600}.btn,.nav-btn,.back-btn,.button-primary,.button-secondary,.warning-actions .btn-secondary,.navigator-actions .btn-secondary{min-height:var(--hit-target);border-radius:var(--radius-full);border-width:1.5px;font-weight:600;letter-spacing:.01em}.btn-primary:hover,.test-start-btn:hover,.dev-seed-btn:hover,.dev-demo-btn:hover,.action-btn.primary:hover,.onboard-btn:hover,.back-btn:hover{background:var(--accent-hover);border-color:var(--accent-hover);color:var(--white);box-shadow:none;transform:translateY(-1px)}.btn-secondary,.see-all-btn,.back-btn,.nav-btn,.action-btn,.button-secondary,.warning-actions .btn-secondary,.navigator-actions .btn-secondary{background:transparent;color:var(--accent);border:1.5px solid var(--accent);box-shadow:none}.btn-secondary:hover,.see-all-btn:hover,.nav-btn:hover:not(:disabled),.button-secondary:hover,.warning-actions .btn-secondary:hover,.navigator-actions .btn-secondary:hover{background:var(--accent);color:var(--white);border-color:var(--accent);box-shadow:none}.nav-tabs{padding:.25rem;gap:.25rem;border:1px solid var(--border-soft);border-radius:var(--radius-full);background:var(--beige)}.auth-mode-tabs{justify-content:center;margin-bottom:2rem}.nav-tab{min-height:44px;padding:.65rem 1.25rem;border:1.5px solid transparent;border-radius:var(--radius-full);color:var(--text-secondary);font-size:var(--text-base)}.nav-tab.active{background:var(--accent);color:var(--white);border-color:var(--accent);border-radius:var(--radius-full);box-shadow:none}.form-container{max-width:560px;margin:clamp(2rem,6vw,4rem) auto;padding:clamp(1.5rem,4vw,2.5rem)}.form-title{font-size:clamp(2rem,4vw,2.75rem)}.form-subtitle{color:var(--text-secondary);font-size:var(--text-lg);line-height:1.5}.form-label{color:var(--text-primary);font-size:var(--text-base);font-weight:600}.form-input,.text-input,.text-area{min-height:var(--hit-target);background:var(--beige);border:1.5px solid var(--border-medium);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem}.form-input:focus,.text-input:focus,.text-area:focus{border-color:var(--accent);box-shadow:var(--focus-ring)}.pre-filled{background:var(--surface)!important;border-color:var(--border-accent)!important}.pre-filled-indicator{color:var(--accent);font-size:var(--text-sm)}.error-message,.success-message,.invitation-required-notice,.test-instructions,.dev-seed-panel,.invitation-banner{background:var(--surface);border:1px solid var(--border-accent);border-radius:var(--radius-lg);color:var(--text-primary)}.error-message{color:var(--accent)}.success-message{color:var(--status-success);border-color:#257a3e40}.invitation-banner{margin-bottom:2rem}.invitation-banner-title{margin-bottom:.5rem;color:var(--text-primary);font-size:var(--text-lg);font-weight:600}.invitation-banner-copy{margin-bottom:1rem;color:var(--text-secondary)}.invitation-banner-meta{color:var(--text-secondary);font-size:var(--text-sm)}.dev-seed-panel{border-style:dashed}.dev-seed-label{color:var(--accent);letter-spacing:.12em}.dev-demo-entry{margin-top:3rem;text-align:center}.link-button{color:var(--accent)}.profile-cards-container{grid-template-columns:repeat(auto-fit,minmax(min(100%,360px),1fr))}.profile-info-item{min-height:56px;border-bottom:1px solid var(--border-soft)}.resource-video{border-radius:var(--radius-md)}.loading-container{background:var(--beige);color:var(--text-secondary)}.loading-spinner{border-color:var(--border-soft);border-top-color:var(--accent)}.status-active{background:var(--status-success-bg);color:var(--status-success)}.status-pending{background:var(--status-warning-bg);color:var(--status-warning)}.status-completed{background:var(--accent-muted);color:var(--accent);border-color:var(--border-accent)}[data-theme=high-contrast] .metric-card,[data-theme=high-contrast] .tests-widget,[data-theme=high-contrast] .upcoming-appointment-widget,[data-theme=high-contrast] .resources-widget,[data-theme=high-contrast] .card,[data-theme=high-contrast] .test-card,[data-theme=high-contrast] .form-container,[data-theme=high-contrast] .sidebar,[data-theme=high-contrast] .navbar{border:2px solid var(--black)}@media (max-width: 1024px){.dashboard-top-section,.dashboard-bottom-section{gap:1.25rem}.dashboard-top-section .metric-cards,.dashboard-bottom-section .tests-widget,.upcoming-appointment-widget,.resources-widget{width:100%}}@media (max-width: 768px){.navbar{height:auto;min-height:68px}.navbar-content{gap:.75rem;padding:.75rem 1rem}.navbar-right{gap:.5rem}.navbar-email{display:none}.layout-with-sidebar{flex-direction:column}.sidebar{position:sticky;top:0;width:100%;height:auto;border-right:0;border-bottom:1px solid var(--border-soft);z-index:900}.sidebar-nav,.sidebar-bottom{flex-direction:row;justify-content:center;padding:.75rem}.metric-cards{grid-template-columns:1fr}.test-item{grid-template-columns:auto 1fr;align-items:start}.tests-pending-item{flex-direction:column;align-items:stretch}.tests-pending-action{width:100%;justify-content:center}.tests-completed-item{grid-template-columns:1fr;gap:.65rem}.tests-completed-score{flex-direction:row;align-items:baseline;gap:.35rem}.tests-completed-view{justify-self:start}.test-start-btn,.test-complete,.test-tag,.completed-result-score,.completed-result-action{grid-column:2;justify-self:start}.completed-result-item{grid-template-columns:auto 1fr}.result-hero-card,.domain-summary-row{align-items:flex-start;flex-direction:column}.result-title-group{align-items:flex-start}.result-score-panel{width:100%}.form-container{margin:1.25rem}.btn{width:100%}}.toast-viewport{position:fixed;top:var(--space-lg, 1.5rem);right:var(--space-lg, 1.5rem);z-index:9999;display:flex;flex-direction:column;gap:var(--space-sm, .5rem);width:min(380px,calc(100vw - 2 * var(--space-lg, 1.5rem)));pointer-events:none}.toast-viewport[data-position=top-left]{right:auto;left:var(--space-lg, 1.5rem)}.toast-viewport[data-position=bottom-right]{top:auto;bottom:var(--space-lg, 1.5rem)}.toast-viewport[data-position=bottom-left]{top:auto;bottom:var(--space-lg, 1.5rem);right:auto;left:var(--space-lg, 1.5rem)}.toast{pointer-events:auto;display:flex;align-items:flex-start;gap:var(--space-sm, .5rem);padding:var(--space-md, 1rem);background:#efebdf;background:color-mix(in srgb,var(--beige, #fffdf4) 90%,#000);border:1px solid #c2beb0;border:1px solid color-mix(in srgb,var(--beige, #fffdf4) 74%,#000);border-radius:6px;box-shadow:var(--shadow-card-hover, 0 18px 36px -20px rgba(0, 0, 0, .18));font-family:var(--font-workhorse, var(--font-sans, system-ui, sans-serif));color:var(--text-primary, rgba(0, 0, 0, .88));animation:toast-in var(--transition-base, .24s ease);transform-origin:top right}.toast[data-state=exit]{animation:toast-out var(--transition-fast, .18s ease) forwards}.toast[data-variant=success]{border-left-color:var(--status-success, var(--success, #257a3e))}.toast[data-variant=error]{border-left-color:var(--status-danger, var(--accent, #e02021))}.toast[data-variant=warning]{border-left-color:var(--status-warning, var(--warning, #8a5b00))}.toast[data-variant=info]{border-left-color:var(--status-info, var(--info, #2f6675))}.toast-icon{flex-shrink:0;width:20px;height:20px;display:grid;place-items:center;margin-top:2px}.toast[data-variant=success] .toast-icon{color:var(--status-success, var(--success, #257a3e))}.toast[data-variant=error] .toast-icon{color:var(--status-danger, var(--accent, #e02021))}.toast[data-variant=warning] .toast-icon{color:var(--status-warning, var(--warning, #8a5b00))}.toast[data-variant=info] .toast-icon{color:var(--status-info, var(--info, #2f6675))}.toast-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.toast-title{font-size:var(--text-sm, .875rem);font-weight:600;line-height:1.35;color:var(--text-primary, rgba(0, 0, 0, .88))}.toast-description{font-size:var(--text-sm, .875rem);line-height:1.45;color:var(--text-secondary, rgba(0, 0, 0, .68));word-wrap:break-word}.toast-action{margin-top:var(--space-sm, .5rem);align-self:flex-start;background:transparent;border:1px solid var(--border-medium, rgba(0, 0, 0, .14));color:var(--text-primary, rgba(0, 0, 0, .88));font-family:inherit;font-size:var(--text-sm, .875rem);font-weight:500;padding:6px 12px;border-radius:var(--radius-sm, 8px);cursor:pointer;transition:background .18s ease,border-color .18s ease}.toast-action:hover{background:var(--bg-hover, rgba(0, 0, 0, .035));border-color:var(--text-primary, rgba(0, 0, 0, .88))}.toast-close{flex-shrink:0;background:transparent;border:none;padding:4px;margin:-4px -4px 0 0;border-radius:var(--radius-sm, 8px);color:var(--text-muted, rgba(0, 0, 0, .5));cursor:pointer;display:grid;place-items:center;transition:color .18s ease,background .18s ease}.toast-close:hover{color:var(--text-primary, rgba(0, 0, 0, .88));background:var(--bg-hover, rgba(0, 0, 0, .035))}@keyframes toast-in{0%{opacity:0;transform:translateY(-8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toast-out{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(20px)}}.stryde-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.25rem;padding:3rem}.stryde-loading--fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;min-height:100vh;background:var(--beige, var(--surface, #fffdf4));z-index:9998}.stryde-loading__mark{position:relative;display:grid;place-items:center}.stryde-loading__ring{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;animation:stryde-loading-spin 1.4s linear infinite}.stryde-loading__track{fill:none;stroke:var(--border-soft, rgba(0, 0, 0, .08));stroke-width:5}.stryde-loading__arc{fill:none;stroke:var(--accent, #e02021);stroke-width:5;stroke-linecap:round;stroke-dasharray:1 282.7;stroke-dashoffset:0;animation:stryde-loading-dash 1.6s ease-in-out infinite}.stryde-loading__logo{position:relative;width:56%;height:56%;object-fit:contain;animation:stryde-loading-pulse 1.6s ease-in-out infinite}.stryde-loading__text{margin:0;font-family:var(--font-workhorse, var(--font-sans, system-ui, sans-serif));font-size:var(--text-sm, .9rem);font-weight:600;letter-spacing:.04em;color:var(--text-secondary, rgba(0, 0, 0, .6))}.stryde-loading__text:after{content:"";display:inline-block;width:1.2em;text-align:left;animation:stryde-loading-dots 1.4s steps(1,end) infinite}.stryde-loading__sr{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes stryde-loading-spin{to{transform:rotate(360deg)}}@keyframes stryde-loading-dash{0%{stroke-dasharray:1 282.7;stroke-dashoffset:0}50%{stroke-dasharray:140 282.7;stroke-dashoffset:-40}to{stroke-dasharray:1 282.7;stroke-dashoffset:-282.7}}@keyframes stryde-loading-pulse{0%,to{transform:scale(.93);opacity:.85}50%{transform:scale(1);opacity:1}}@keyframes stryde-loading-dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}}@media (prefers-reduced-motion: reduce){.stryde-loading__ring,.stryde-loading__arc,.stryde-loading__logo,.stryde-loading__text:after{animation:none}.stryde-loading__arc{stroke-dasharray:70 282.7}}.test-instructions-component{max-width:800px;margin:0 auto;padding:2rem;min-height:100vh;background:#fff;display:flex;flex-direction:column;justify-content:center}.instructions-container{background:#fff;border-radius:12px;padding:3rem;box-shadow:0 2px 16px #0000000d;text-align:center}.instructions-title{color:var(--text-primary, #212529);font-size:1.5rem;font-weight:600;margin-bottom:2rem;text-align:center}.test-info{display:flex;justify-content:center;gap:2rem;margin-bottom:2rem;padding:1.5rem;background:#f8f9fa;border-radius:8px}.info-item{text-align:center}.info-label{display:block;font-size:.875rem;color:var(--text-secondary, #6C757D);margin-bottom:.25rem;font-weight:400}.info-value{font-size:1.125rem;font-weight:600;color:var(--text-primary, #212529)}.instructions-content{margin:30px 0;font-size:1.1rem;line-height:1.8;color:var(--text-primary, #333)}.instructions-list{list-style-position:inside;margin:20px 0}.instructions-list li{margin:10px 0;padding-left:10px}.instructions-confirm{margin:30px 0;padding:20px;background:#f0f8ff;border-radius:8px;border:1px solid #b3d9ff}.ready-checkbox{display:flex;align-items:center;font-size:1rem;color:var(--text-primary, #333);cursor:pointer}.ready-checkbox input[type=checkbox]{width:20px;height:20px;margin-right:12px;cursor:pointer}.ready-checkbox span{-webkit-user-select:none;user-select:none}.instructions-actions{display:flex;gap:15px;justify-content:center}.instructions-actions button{padding:12px 30px;font-size:1rem;font-weight:500;border-radius:8px;border:none;cursor:pointer;transition:all .3s ease;font-family:var(--font-family, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif)}.instructions-actions .button-primary{background:var(--primary-color, #E53E3E);color:#fff}.instructions-actions .button-primary:hover:not(:disabled){background:var(--primary-dark, #C53030);transform:translateY(-2px);box-shadow:0 4px 12px #4caf504d}.instructions-actions .button-primary:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.instructions-actions .button-secondary{background:#fff;color:var(--primary-color, #E53E3E);border:2px solid var(--primary-color, #E53E3E)}.instructions-actions .button-secondary:hover{background:var(--primary-color, #E53E3E);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #4caf5033}.test-component{padding:20px;font-family:var(--font-family, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif)}.test-question-header{margin-top:0;margin-bottom:2rem;text-align:left}.test-question-header h3{color:var(--text-secondary, #6C757D);font-size:1rem;font-weight:400;margin-bottom:1rem;text-align:left;line-height:1.4}.test-instructions{color:var(--text-secondary, #6c757d);font-size:1rem;line-height:1.5}.test-question-content{margin-bottom:20px}.stimulus-container{margin:30px 0;text-align:center}.stimulus-image{max-width:400px;max-height:400px;border:2px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 8px #0000001a}.image-placeholder{display:inline-block;width:400px;height:300px;background:#f5f5f5;border:2px dashed #ccc;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#999}.question-text,.question-prompt{margin:3rem 0;text-align:center}.question-text p,.question-prompt p,.prompt-text{font-size:2rem;font-weight:700;color:var(--text-primary, #212529);line-height:1.4;text-align:center;margin-bottom:2rem}.question-prompt h4{color:var(--primary-color, #2c3e50);margin-bottom:10px}.semantic-cue{background:#fff3cd;border:1px solid #ffc107;border-radius:6px;padding:15px;margin:20px 0}.cue-label{font-weight:700;color:#856404;margin-bottom:5px}.cue-text{color:#856404}.answer-input{margin:20px 0}.text-input,.text-area{width:100%;padding:12px 16px;font-size:1rem;font-family:var(--font-family, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif);border:2px solid #e0e0e0;border-radius:8px;background:#fff;transition:all .3s ease;box-sizing:border-box}.text-input:focus,.text-area:focus{outline:none;border-color:var(--primary-color, #E53E3E);box-shadow:0 0 0 3px #4caf501a}.text-input::placeholder,.text-area::placeholder{color:#999}.text-area{min-height:120px;resize:vertical;line-height:1.5}.character-count{text-align:right;font-size:.85rem;color:#999;margin-top:5px}.test-actions{display:flex;gap:10px;margin-top:30px;flex-wrap:wrap}.button-primary,.button-secondary{padding:12px 24px;font-size:1rem;font-weight:500;border-radius:8px;border:none;cursor:pointer;transition:all .3s ease;font-family:var(--font-family, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif)}.button-primary{background:var(--primary-color, #E53E3E);color:#fff}.button-primary:hover:not(:disabled){background:var(--primary-dark, #C53030);transform:translateY(-2px);box-shadow:0 4px 12px #4caf504d}.button-primary:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.button-secondary{background:#fff;color:var(--primary-color, #E53E3E);border:2px solid var(--primary-color, #E53E3E)}.button-secondary:hover:not(:disabled){background:var(--primary-color, #E53E3E);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #4caf5033}.button-secondary:disabled{border-color:#ccc;color:#ccc;cursor:not-allowed;opacity:.6}.answer-submitted{background:#f8f9fa;border-radius:8px;padding:20px;margin-top:20px}.submission-message{font-size:1.1rem;color:var(--text-primary, #333);margin-bottom:10px}.submission-message strong{color:var(--primary-color, #E53E3E)}.cue-note{color:#ff6b6b;font-style:italic;margin-top:10px}.scoring-criteria-preview{background:#f8f9fa;border-radius:8px;padding:20px;margin:20px 0}.scoring-criteria-preview h4{color:var(--primary-color, #2c3e50);margin-bottom:15px}.scoring-criteria-preview ul{list-style:none;padding:0}.scoring-criteria-preview li{padding:8px 0;color:var(--text-primary, #333)}.scoring-criteria-preview strong{color:var(--primary-color, #2c3e50)}.scoring-results{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:20px;margin-top:20px}.scoring-results h4,.scoring-results h5{color:var(--primary-color, #2c3e50);margin-bottom:15px}.score-breakdown{margin:15px 0}.score-item{display:flex;justify-content:space-between;padding:8px;background:#f8f9fa;border-radius:4px;margin-bottom:8px}.criterion-name{font-weight:500;color:var(--text-primary, #333)}.score-value{font-weight:700}.score-value.correct{color:#e53e3e}.score-value.incorrect{color:#dc3545}.feedback{margin-top:20px;padding-top:15px;border-top:1px solid #e0e0e0}.feedback h5{margin-bottom:10px}.total-score{font-size:1.2rem;font-weight:700;color:var(--primary-color, #2c3e50);margin-top:20px;padding:15px;background:#f0f8ff;border-radius:8px;text-align:center}.error-message,.grading-error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24;padding:15px;border-radius:8px;margin:20px 0}.test-status{background:#f8f9fa;border-radius:8px;padding:20px;margin:20px 0;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}.status-item{display:flex;flex-direction:column}.status-label{font-size:.9rem;color:#6c757d;margin-bottom:5px}.status-value{font-size:1.1rem;font-weight:500;color:var(--text-primary, #333)}.canvas-container{margin:30px 0;text-align:center}.canvas-container canvas{border:2px solid #e0e0e0;border-radius:8px;background:#fff;box-shadow:0 2px 8px #0000001a;cursor:pointer;max-width:100%;height:auto}.submission-summary{background:#f8f9fa;border-radius:8px;padding:20px;margin-bottom:20px}.submission-summary h4{color:var(--primary-color, #2c3e50);margin-bottom:15px}.submission-summary p{margin:8px 0;color:var(--text-primary, #333)}.penalty{color:#ff6b6b;font-style:italic}.score-preview{margin-top:15px;padding-top:15px;border-top:1px solid #e0e0e0}.score-preview p{margin:5px 0}.test-question-footer{margin-top:30px;padding-top:20px;border-top:1px solid #e0e0e0;text-align:center}.points-display{font-size:1rem;color:#6c757d;font-weight:500}@media (max-width: 768px){.test-actions{flex-direction:column}.button-primary,.button-secondary{width:100%}.stimulus-image{max-width:100%}.canvas-container canvas{max-width:100%;height:auto}}.completion-warning{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.warning-content{background:#fff;border-radius:12px;padding:30px;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 8px 32px #0003}.warning-content h3{color:#dc3545;margin-bottom:20px;font-size:1.5rem;text-align:center}.warning-content p{color:var(--text-primary, #333);font-size:1.1rem;line-height:1.6;margin-bottom:15px;text-align:center}.skipped-questions-list{margin:25px 0;padding:20px;background:#f8f9fa;border-radius:8px;border:1px solid #e0e0e0}.skipped-questions-list h4{color:var(--primary-color, #2c3e50);margin-bottom:15px;font-size:1.2rem}.skipped-questions-list ul{list-style:none;padding:0;margin:0}.skipped-questions-list li{margin-bottom:10px}.skipped-question-link{background:#fff;border:2px solid var(--primary-color, #E53E3E);color:var(--primary-color, #E53E3E);padding:12px 16px;border-radius:8px;cursor:pointer;transition:all .3s ease;font-size:1rem;font-weight:500;width:100%;text-align:left;font-family:var(--font-family, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif)}.skipped-question-link:hover{background:var(--primary-color, #E53E3E);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #4caf5033}.warning-actions{display:flex;justify-content:center;margin-top:25px;gap:15px}.warning-actions .btn-secondary{background:#fff;color:var(--primary-color, #E53E3E);border:2px solid var(--primary-color, #E53E3E);padding:12px 24px;font-size:1rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .3s ease;font-family:var(--font-family, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif)}.warning-actions .btn-secondary:hover{background:var(--primary-color, #E53E3E);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #4caf5033}.test-progress{display:flex;align-items:center;gap:15px}.navigator-button{background:var(--primary-color, #E53E3E);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;font-family:var(--font-family, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif)}.navigator-button:hover{background:var(--primary-dark, #C53030);transform:translateY(-1px);box-shadow:0 2px 8px #4caf504d}.progress-bar{flex:1;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden;min-width:100px}.progress-fill{height:100%;background:var(--accent);border-radius:4px;transition:width .3s ease}.question-text p,.question-prompt p,.prompt-text,.question-prompt h4{font-size:2.2rem!important;font-weight:700!important;color:var(--text-primary, #212529)!important;line-height:1.4!important;text-align:center!important;margin-bottom:2rem!important;margin-top:0!important}.test-component{padding:0 2rem 2rem!important;background:#fff!important;border:none!important;box-shadow:none!important;max-width:800px!important;margin:0 auto!important}.test-question-content{background:#fff!important;border:none!important;box-shadow:none!important;padding:0!important;margin-bottom:2rem!important}.test-question-header{margin-bottom:1rem!important}.test-question-header h3{font-size:.9rem!important;font-weight:400!important;color:var(--text-secondary, #6c757d)!important;margin-bottom:.5rem!important;text-align:left!important}.test-component .test-progress{border-top:none!important;background:#fff!important;padding:0!important;margin-top:0!important;order:0!important}.test-options{display:flex!important;flex-direction:column!important;gap:.5rem!important;margin:2rem 0!important}.option-button{background:#fff!important;border:1px solid #e0e0e0!important;border-radius:8px!important;padding:1rem 1.5rem!important;transition:all .2s ease!important;text-align:left!important;font-size:1rem!important;margin:.25rem 0!important}.option-button:hover{background:#f8f9fa!important;border-color:#ccc!important;transform:none!important;box-shadow:none!important}.test-container,.test-wrapper,.test-content{background:#fff!important}.test-runner{padding:0 2rem!important;background:#fff!important}.test-runner .test-header,.test-runner .test-content,.test-runner .test-progress,.naming-test,.naming-test .test-header{border:none!important;border-top:none!important;border-bottom:none!important;background:#fff!important}.stimulus-container{border:2px solid #e0e0e0!important;border-radius:8px!important;box-shadow:0 2px 8px #0000001a!important;background:#fff!important;padding:20px!important;margin:2rem auto!important;display:inline-block!important}.stimulus-image{border:none!important;border-radius:0!important;box-shadow:none!important;background:transparent!important;max-width:300px!important;max-height:300px!important;display:block!important}.test-subsection{font-size:.9rem!important;font-weight:400!important;color:var(--text-secondary, #6c757d)!important;margin:0!important;text-align:left!important}.test-timer{position:absolute!important;top:150px!important;right:2rem!important;background:#fff!important;border:1px solid #e0e0e0!important;border-radius:12px!important;padding:1rem!important;box-shadow:0 2px 8px #0000001a!important;z-index:10!important;min-width:140px!important}.timer-display{display:flex!important;align-items:center!important;gap:.5rem!important}.timer-icon{font-size:1.2rem!important;opacity:.8!important}.timer-content{display:flex!important;flex-direction:column!important;align-items:flex-start!important}.timer-value{font-size:1.1rem!important;font-weight:600!important;color:var(--text-primary, #212529)!important;line-height:1!important}.timer-label{font-size:.75rem!important;color:var(--text-secondary, #6c757d)!important;text-transform:uppercase!important;letter-spacing:.5px!important;margin-top:2px!important}.test-timer.warning{border-color:#ffc107!important;background:#fff9e6!important}.test-timer.timeout{border-color:#dc3545!important;background:#ffebee!important}.timer-warning,.timer-timeout{margin-top:.5rem!important;font-size:.75rem!important;text-align:center!important}.timer-controls{margin-top:.75rem!important;text-align:center!important}.timer-button{background:var(--primary, #E53E3E)!important;color:#fff!important;border:none!important;padding:.5rem 1rem!important;border-radius:6px!important;font-size:.8rem!important;font-weight:500!important;cursor:pointer!important;transition:all .2s ease!important;text-transform:uppercase!important;letter-spacing:.5px!important}.timer-button:hover{background:var(--primary-hover, #C53030)!important;transform:translateY(-1px)!important}.timer-button.start{background:#e53e3e!important}.timer-button.start:hover{background:#c53030!important}.timer-button.pause{background:#ffc107!important;color:#212529!important}.timer-button.pause:hover{background:#e0a800!important}.timer-button.reset{background:#6c757d!important}.timer-button.reset:hover{background:#5a6268!important}.test-actions{display:flex!important;justify-content:center!important;align-items:center!important;flex-wrap:wrap!important}.main-actions{display:flex!important;gap:1rem!important;align-items:center!important}.cue-button{position:relative!important;display:inline-flex!important;align-items:center!important;gap:.5rem!important;cursor:pointer!important;transition:all .3s ease!important}.cue-button:hover{background:#f8f9fa!important;border-color:#adb5bd!important;transform:translateY(-2px)!important;box-shadow:0 4px 8px #00000026!important}.cue-button:after{content:attr(data-hint)!important;position:absolute!important;bottom:100%!important;left:50%!important;transform:translate(-50%)!important;background:#2c3e50!important;color:#fff!important;padding:.75rem 1rem!important;border-radius:6px!important;font-size:.8rem!important;white-space:nowrap!important;opacity:0!important;visibility:hidden!important;transition:all .3s ease!important;margin-bottom:.5rem!important;max-width:250px!important;white-space:normal!important;text-align:center!important;z-index:1000!important}.cue-button:hover:after{opacity:1!important;visibility:visible!important}.cue-button:before{content:""!important;position:absolute!important;bottom:100%!important;left:50%!important;transform:translate(-50%)!important;border:6px solid transparent!important;border-top-color:#2c3e50!important;opacity:0!important;visibility:hidden!important;transition:all .3s ease!important;z-index:1001!important}.cue-button:hover:before{opacity:1!important;visibility:visible!important}.test-header{display:flex!important;justify-content:space-between!important;align-items:center!important;padding:2rem 1rem 0!important;margin-bottom:2rem!important;border:none!important;background:#fff!important}.test-title{font-size:1.25rem!important;font-weight:600!important;color:var(--text-primary, #212529)!important;margin:0!important}.section-info{display:flex!important;flex-direction:column!important;align-items:flex-end!important;gap:.25rem!important}.section-title{font-size:.9rem!important;font-weight:400!important;color:var(--text-secondary, #6c757d)!important;margin:0!important}.subsection-title{font-size:.8rem!important;font-weight:400!important;color:var(--text-secondary, #6c757d)!important;margin:0!important}.clock-drawing-test .task-instructions{background:#fff!important;padding:1rem!important;border:none!important;margin-bottom:1.5rem!important;text-align:center!important}.clock-drawing-test .task-instructions p{font-size:1.1rem!important;font-weight:500!important;color:var(--text-primary, #2c3e50)!important;margin:.5rem 0!important}.test-runner,.test-container,.test-wrapper,.test-content,.test-component,.test-question-content,.naming-test,.naming-test .test-header,.clock-drawing-test .task-instructions{background:var(--beige)!important;color:var(--text-primary)!important;box-shadow:none!important}.test-component{max-width:920px!important;padding:clamp(1rem,3vw,2rem)!important}.instructions-container,.test-question-content,.stimulus-container,.canvas-container,.submission-summary,.scoring-criteria-preview,.scoring-results,.test-status,.answer-submitted,.warning-content,.skipped-questions-list{background:var(--surface)!important;border:1px solid var(--border-soft)!important;border-radius:var(--radius-xl)!important;box-shadow:none!important}.instructions-container,.test-question-content{padding:clamp(1.25rem,3vw,2.5rem)!important}.instructions-title,.test-title,.question-text p,.question-prompt p,.prompt-text,.question-prompt h4{color:var(--text-primary)!important;font-family:var(--font-workhorse)!important;font-weight:400!important;letter-spacing:-.02em!important}.question-text p,.question-prompt p,.prompt-text,.question-prompt h4{font-size:clamp(1.8rem,4vw,2.6rem)!important;line-height:1.25!important}.test-question-header h3,.test-subsection,.section-title,.subsection-title,.info-label,.character-count,.timer-label,.points-display,.cue-label{color:var(--text-secondary)!important}.info-value,.timer-value,.status-value{color:var(--text-primary)!important}.instructions-list li,.instructions-content,.test-instructions,.semantic-cue,.cue-text,.feedback,.submission-message{color:var(--text-secondary)!important}.ready-checkbox{min-height:var(--hit-target)}.ready-checkbox input[type=checkbox]{width:22px;height:22px;accent-color:var(--accent)}.button-primary,.instructions-actions .button-primary,.timer-button,.timer-button.start,.navigator-button{min-height:var(--btn-min-height)!important;padding-block:.4rem!important;background:var(--accent)!important;color:var(--white)!important;border:1.5px solid var(--accent)!important;border-radius:var(--radius-full)!important;box-shadow:none!important;font-weight:600!important}.button-primary:hover:not(:disabled),.instructions-actions .button-primary:hover:not(:disabled),.timer-button:hover,.timer-button.start:hover,.navigator-button:hover{background:var(--accent-hover)!important;border-color:var(--accent-hover)!important;transform:translateY(-1px)!important;box-shadow:none!important}.button-secondary,.instructions-actions .button-secondary,.warning-actions .btn-secondary,.skipped-question-link,.cue-button{min-height:var(--btn-min-height)!important;padding-block:.4rem!important;background:transparent!important;color:var(--accent)!important;border:1.5px solid var(--accent)!important;border-radius:var(--radius-full)!important;box-shadow:none!important;font-weight:600!important}.button-secondary:hover:not(:disabled),.instructions-actions .button-secondary:hover,.warning-actions .btn-secondary:hover,.skipped-question-link:hover,.cue-button:hover{background:var(--accent)!important;color:var(--white)!important;border-color:var(--accent)!important;transform:translateY(-1px)!important;box-shadow:none!important}.text-input,.text-area,.answer-input,.option-button{min-height:var(--hit-target)!important;background:var(--beige)!important;border:1.5px solid var(--border-medium)!important;border-radius:var(--radius-md)!important;color:var(--text-primary)!important;font-size:1rem!important}.option-button{padding:1rem 1.25rem!important}.option-button:hover{background:var(--surface)!important;border-color:var(--border-accent)!important}.text-input:focus,.text-area:focus,.option-button:focus-visible{border-color:var(--accent)!important;box-shadow:var(--focus-ring)!important;outline:none!important}.stimulus-container{padding:clamp(1rem,3vw,1.5rem)!important}.stimulus-image{border-radius:var(--radius-md)!important}.test-header{background:var(--beige)!important}.test-progress{background:transparent!important;padding:1rem 0!important}.progress-bar{background:#00000014!important}.progress-fill{background:var(--accent)!important}.warning-content h3,.score-value.incorrect,.penalty{color:var(--accent)!important}.score-value.correct,.submission-message strong,.total-score{color:var(--status-success)!important}.test-timer.warning,.timer-button.pause,.timer-button.pause:hover{background:var(--status-warning-bg)!important;color:var(--status-warning)!important;border-color:#8a5b0040!important}.test-timer.timeout{background:var(--accent-muted)!important;color:var(--accent)!important;border-color:var(--border-accent)!important}.cue-button:after{background:var(--black)!important;color:var(--white)!important}.cue-button:before{border-top-color:var(--black)!important}@media (max-width: 768px){.test-component,.test-runner{padding-inline:1rem!important}.test-header{align-items:flex-start!important;flex-direction:column!important;gap:.75rem!important}.section-info{align-items:flex-start!important}.test-timer{position:static!important;width:100%!important;margin-bottom:1rem!important}.main-actions,.test-actions,.warning-actions,.instructions-actions{flex-direction:column!important;width:100%!important}.button-primary,.button-secondary,.warning-actions .btn-secondary{width:100%!important}}.test-runner .btn,.test-runner .btn-primary,.test-runner .btn-secondary,.test-runner .btn-warning,.test-runner .btn-danger{min-height:var(--btn-min-height)!important;padding:.4rem 1.25rem!important;border-radius:var(--radius-full)!important;border:1.5px solid transparent!important;box-shadow:none!important;font-family:var(--font-workhorse)!important;font-size:1rem!important;font-weight:600!important;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),transform var(--transition-fast)!important}.test-runner .btn-primary,.test-runner .btn.btn-primary,.test-runner .btn-danger,.test-runner .btn.btn-danger{background:var(--accent)!important;border-color:var(--accent)!important;color:var(--white)!important}.test-runner .btn-primary:hover:not(:disabled),.test-runner .btn.btn-primary:hover:not(:disabled),.test-runner .btn-danger:hover:not(:disabled),.test-runner .btn.btn-danger:hover:not(:disabled){background:var(--accent-hover)!important;border-color:var(--accent-hover)!important;transform:translateY(-1px)!important}.test-runner .btn-secondary,.test-runner .btn.btn-secondary{background:transparent!important;border-color:var(--accent)!important;color:var(--accent)!important}.test-runner .btn-secondary:hover:not(:disabled),.test-runner .btn.btn-secondary:hover:not(:disabled){background:var(--accent)!important;color:var(--white)!important;transform:translateY(-1px)!important}.test-runner .btn-warning,.test-runner .btn.btn-warning{background:var(--status-warning-bg)!important;border-color:#8a5b0040!important;color:var(--status-warning)!important}.test-runner .btn-warning:hover:not(:disabled),.test-runner .btn.btn-warning:hover:not(:disabled){background:var(--status-warning)!important;color:var(--white)!important;transform:translateY(-1px)!important}.test-runner .btn:disabled,.test-runner .btn-primary:disabled,.test-runner .btn-secondary:disabled{background:#00000014!important;border-color:transparent!important;color:var(--text-faint)!important;cursor:not-allowed!important}.test-runner .btn-primary.btn-submit,.test-runner .answer-actions .btn-primary,.test-runner .main-actions .btn-primary,.test-runner .question-actions .btn-primary,.test-runner .two-pane-actions>.btn-primary:not(.start-btn):not(.add-btn):not(.speech-btn),.test-runner .two-pane-actions .main-actions .btn-primary{min-height:calc(var(--hit-target) + 8px)!important;padding:.875rem 2.5rem!important;font-size:var(--text-lg)!important}.test-runner .answer-actions .btn-primary,.test-runner .main-actions .btn-primary{flex:1 1 0!important;max-width:320px!important}.test-runner .answer-section,.test-runner .writing-area,.test-runner .speech-recognition-section{display:flex!important;flex-direction:column!important;align-items:stretch!important;gap:var(--space-md)!important;width:100%!important}.test-runner .answer-actions{display:flex!important;justify-content:center!important;align-items:center!important;gap:var(--space-md)!important;width:100%!important}.test-runner .card,.test-runner .target-section,.test-runner .design-section,.test-runner .palette-section,.test-runner .word-list-container,.test-runner .input-section,.test-runner .task-instructions,.test-runner .speech-recognition-section,.test-runner .reading-text-container,.test-runner .writing-area,.test-runner .scoring-criteria,.test-runner .trail-canvas-container,.test-runner .clock-container,.test-runner .progress-display,.test-runner .progress-indicator,.test-runner .progress-stats .stat-item,.test-runner .current-target,.test-runner .time-display>*,.test-runner .accuracy-indicator{background:var(--surface)!important;border:1px solid var(--border-soft)!important;border-radius:var(--radius-xl)!important;box-shadow:none!important}.test-runner .question-prompt p,.test-runner .question-prompt h4{color:var(--text-primary)!important;font-family:var(--font-workhorse)!important;font-weight:400!important;letter-spacing:0!important}.test-runner .answer-input,.test-runner .word-input,.test-runner .writing-textarea,.test-runner .recognition-word{min-height:var(--hit-target)!important;background:var(--beige)!important;border:1.5px solid var(--border-medium)!important;border-radius:var(--radius-md)!important;color:var(--text-primary)!important}.test-runner .answer-input:focus,.test-runner .word-input:focus,.test-runner .writing-textarea:focus,.test-runner .recognition-word:focus-visible{border-color:var(--accent)!important;box-shadow:var(--focus-ring)!important;outline:none!important}.test-runner .ai-review-notice{max-width:760px;margin:0 auto 1rem;padding:1rem 1.25rem;min-height:var(--hit-target, 48px);display:flex;align-items:center;border:1.5px solid var(--border-accent);border-radius:var(--radius-lg);background:var(--surface);color:var(--text-primary);font-size:max(1rem,var(--text-base));line-height:1.5}.app:has(.test-runner){height:100dvh;display:flex;flex-direction:column;overflow:hidden}.app:has(.test-runner) .navbar{flex:0 0 auto}.app:has(.test-runner) .main-content{flex:1 1 auto;min-height:0;padding:0;display:flex;overflow:hidden}.app:has(.test-runner) .main-content>*{flex:1 1 auto;min-height:0;width:100%;display:flex}.test-runner{flex:1 1 auto!important;min-height:0!important;width:100%!important;display:flex!important;flex-direction:column!important;overflow:hidden!important;padding:0!important}.test-runner .test-header{flex:0 0 auto!important;margin:0!important;padding:var(--space-sm) clamp(1rem,3vw,2.5rem)!important}.test-runner>.test-content{flex:1 1 auto!important;min-height:0!important;display:flex!important;flex-direction:column!important;overflow-y:auto!important;padding:var(--space-sm) clamp(1rem,3vw,2.5rem)!important}.test-runner>.test-content>*{width:100%;max-width:860px;margin-left:auto!important;margin-right:auto!important}.test-runner>.test-content>.two-pane{max-width:min(1400px,100%)}.test-runner>.test-content>.ai-review-notice{flex:0 0 auto}.test-runner>.test-content:has(>.base-question){overflow:hidden!important}.test-runner>.test-content>.base-question{flex:1 1 auto;min-height:0;height:100%;display:flex;flex-direction:column}.test-runner .base-question>.question-header,.test-runner .base-question>.instructions{flex:0 0 auto!important;margin:0 0 var(--space-sm) 0!important}.test-runner .base-question>.question-content{flex:1 1 auto!important;min-height:0!important;overflow-y:auto!important;display:flex!important;flex-direction:column!important;gap:var(--space-md)!important;padding:var(--space-xs) 0!important}.test-runner .base-question>.question-actions{flex:0 0 auto!important;margin:0!important;padding:var(--space-sm) 0 var(--space-xs)!important}.test-runner .question-text,.test-runner .question-prompt{margin:0!important}.test-runner .question-text p,.test-runner .question-prompt p,.test-runner .prompt-text,.test-runner .question-prompt h4{font-size:clamp(1.35rem,2.8vw,2rem)!important;line-height:1.3!important;margin:0 0 var(--space-sm) 0!important}.test-runner .instructions{font-size:max(1rem,var(--text-base))!important}.test-runner .instructions p{margin:0!important}.test-runner .stimulus-container{margin:var(--space-xs) auto!important;padding:var(--space-sm)!important}.test-runner .stimulus-image{max-height:min(40vh,320px)!important;max-width:100%!important;width:auto!important;height:auto!important;object-fit:contain!important}.test-runner .answer-input{margin:var(--space-sm) 0 0 0!important}.test-runner .answer-section .answer-input,.test-runner .writing-area .writing-textarea{margin:0!important}.test-runner .text-area,.test-runner .composition-textarea{min-height:clamp(72px,12vh,120px)!important;resize:none!important}.test-runner>.test-header{display:grid!important;grid-template-columns:1fr auto 1fr!important;align-items:center!important;gap:var(--space-md)!important}.test-runner>.test-header-title,.test-runner>.test-header>h2{justify-self:start!important;min-width:0!important;margin:0!important;overflow-wrap:anywhere!important;line-height:1.2!important}.test-runner .test-exit-button{justify-self:center!important;flex:0 0 auto!important;min-height:var(--hit-target)!important;padding:.625rem 1.25rem!important;font-size:var(--text-base)!important;white-space:nowrap!important}.test-runner>.test-header>.test-progress{justify-self:end!important;flex:0 1 480px!important;min-width:240px!important;max-width:100%!important;width:100%!important;margin:0!important;padding:0!important;order:0!important;background:transparent!important;border-top:none!important;display:flex!important;flex-direction:row!important;align-items:center!important;gap:var(--space-md)!important}.test-runner>.test-header>.test-progress>span,.test-runner>.test-header>.test-progress>.test-progress-label{flex:0 0 auto;white-space:nowrap;font-size:var(--text-base);line-height:1;color:var(--text-secondary)}.test-runner>.test-header>.test-progress>.progress-bar{flex:1 1 120px;min-width:80px;height:8px;margin:0;align-self:center}.test-runner>.test-header>.test-progress>.navigator-button{flex:0 0 auto;margin:0;align-self:center}.test-runner .test-timer{position:static!important;inset:auto!important;z-index:auto!important;width:fit-content!important;min-width:0!important;max-width:100%!important;margin:0 auto var(--space-sm)!important;padding:.75rem 1rem!important}.test-runner .naming-test>.test-header{display:flex!important;justify-content:center!important;align-items:center!important;margin:0 0 var(--space-sm)!important;padding:0!important;border:0!important;background:transparent!important}@media (max-width: 900px){.test-runner>.test-header{grid-template-columns:1fr!important;justify-items:center!important}.test-runner>.test-header-title,.test-runner>.test-header>h2{justify-self:stretch!important;text-align:center!important}.test-runner .test-exit-button{justify-self:center!important}.test-runner>.test-header>.test-progress{justify-self:stretch!important;flex:0 0 auto!important;min-width:0!important;width:100%!important}}.test-runner .test-timer{background:transparent!important;border:none!important;box-shadow:none!important;padding:0!important;margin:0 auto var(--space-sm)!important;width:fit-content!important;min-width:0!important}.test-runner .stimulus-container{display:block!important;width:fit-content!important;max-width:100%!important;margin-inline:auto!important;text-align:center!important}.test-runner .stimulus-image{display:block!important;margin-inline:auto!important}.test-runner .test-actions,.test-runner .main-actions{display:flex!important;justify-content:center!important;align-items:center!important;gap:1rem!important}.test-runner .main-actions .btn,.test-runner .answer-actions .btn{min-width:160px!important}.test-runner .test-progress{display:flex!important;flex-direction:row!important;align-items:center!important;flex-wrap:nowrap!important;gap:var(--space-md)!important;padding:0!important;margin:0!important}@media (max-width: 768px){.test-runner .main-actions .btn,.test-runner .answer-actions .btn{min-width:0!important}}.test-runner .two-pane{display:flex;flex-direction:column;gap:var(--space-sm)}.test-runner .two-pane-timer{flex:0 0 auto;display:flex;justify-content:center}.test-runner .two-pane-prompt{flex:0 0 auto;text-align:center}.test-runner .two-pane-grid{display:flex;flex-direction:column;gap:clamp(1rem,2.5vw,2rem)}.test-runner .two-pane-task,.test-runner .two-pane-answer{display:flex;flex-direction:column;gap:var(--space-md);min-width:0}.test-runner .two-pane-actions{flex:0 0 auto;padding-top:var(--space-sm);justify-content:center;align-items:center;gap:var(--space-md)}.test-runner .two-pane--stacked .two-pane-grid{flex-direction:column!important;align-items:center!important;justify-content:flex-start!important}.test-runner .two-pane--stacked .two-pane-answer{align-items:center!important;width:100%;max-width:480px;margin-inline:auto}.test-runner .two-pane--stacked .answer-section,.test-runner .two-pane--stacked .cue-section,.test-runner .two-pane--stacked .feedback-section,.test-runner .two-pane--stacked .writing-area,.test-runner .two-pane--stacked .speech-recognition-section{width:100%;max-width:400px;margin-inline:auto}.test-runner .two-pane--stacked .answer-input{width:100%;text-align:center}.test-runner .two-pane--stacked .two-pane-actions{align-items:center!important}.test-runner .category-fluency-test .two-pane-actions .start-btn{min-height:var(--hit-target);padding:.875rem 2rem;font-size:var(--text-lg)}@media (min-width: 1024px){.test-runner .two-pane{height:100%;min-height:0}.test-runner .two-pane-grid{flex:1 1 auto;min-height:0;flex-direction:row;align-items:center;justify-content:center}.test-runner .two-pane-task{flex:0 1 340px}.test-runner .two-pane-answer{flex:1 1 auto}.test-runner .two-pane-task,.test-runner .two-pane-answer{min-height:0;max-height:100%;overflow-y:auto}.test-runner .two-pane--stacked .two-pane-grid{flex-direction:column!important;align-items:center!important;flex:0 1 auto}.test-runner .two-pane--stacked .two-pane-answer{flex:0 1 auto;max-height:none;overflow:visible}}.test-instructions-component{background:var(--beige)!important;min-height:100vh;padding:clamp(1rem,3vw,2rem)!important}.instructions-eyebrow{margin:0 0 var(--space-sm);font-size:var(--text-sm);font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-family:var(--font-workhorse)}.test-info,.instructions-confirm{background:var(--beige)!important;border:1.5px solid var(--border-soft)!important;border-radius:var(--radius-lg)!important}.instructions-content,.instructions-list li{font-size:var(--text-base)!important;line-height:1.6!important}.info-label,.ready-checkbox{font-size:var(--text-base)!important}.test-runner>.test-header{background:var(--beige)!important;border-bottom:1.5px solid var(--border-soft)}.test-runner>.test-header-title,.test-runner>.test-header>h2{font-family:var(--font-workhorse)!important;font-size:var(--text-xl)!important;font-weight:600!important;letter-spacing:-.02em;color:var(--text-primary)!important}.test-runner>.test-header>.test-progress>.test-progress-label{flex:0 0 auto;white-space:nowrap;font-size:var(--text-base);line-height:1;color:var(--text-secondary);font-family:var(--font-workhorse);font-weight:500}.test-runner>.test-header>.test-progress>.progress-bar{border-radius:var(--radius-full)!important}.test-runner>.test-header>.test-progress>.progress-fill{background:var(--accent)!important;border-radius:var(--radius-full)!important}.test-runner .navigator-button{min-height:var(--hit-target)!important;padding:.625rem 1.25rem!important;font-size:var(--text-base)!important;font-family:var(--font-workhorse)!important;letter-spacing:.01em}.completion-warning{background:#00000080!important}.warning-content{background:var(--surface)!important;border:1.5px solid var(--border-soft)!important;border-radius:var(--radius-xl)!important;box-shadow:none!important;padding:clamp(1.25rem,3vw,2rem)!important}.warning-content h3{color:var(--accent)!important;font-family:var(--font-workhorse)!important;font-size:var(--text-2xl)!important;font-weight:600!important}.warning-content p,.warning-content li{font-size:var(--text-base)!important;line-height:1.6!important;color:var(--text-primary)!important}.skipped-questions-list{background:var(--beige)!important;border:1.5px solid var(--border-soft)!important;border-radius:var(--radius-lg)!important}.skipped-questions-list h4{font-size:var(--text-lg)!important;color:var(--text-primary)!important}.skipped-question-link{min-height:var(--hit-target)!important;font-size:var(--text-base)!important;border-radius:var(--radius-full)!important;display:flex!important;align-items:center!important;justify-content:space-between!important;gap:var(--space-md)!important}.question-status-pill{flex:0 0 auto;padding:.25rem .65rem;border-radius:var(--radius-full);border:1px solid currentColor;font-size:var(--text-sm);font-weight:700;line-height:1}.question-status-pill--skipped{color:var(--accent)}.question-status-pill--unanswered{color:var(--status-warning)}.skipped-question-link:hover .question-status-pill{color:var(--white)}.warning-actions{flex-wrap:wrap;gap:var(--space-md)!important}.warning-actions .btn-secondary,.warning-actions .btn-warning,.warning-actions .btn-danger{min-height:var(--hit-target)!important;font-size:var(--text-base)!important}@media (max-width: 768px){.test-runner>.test-header>.test-progress{flex-wrap:wrap!important}.test-runner>.test-header>.test-progress>.progress-bar{order:3;flex:1 1 100%;min-width:0!important}.test-runner .navigator-button{margin-left:auto}}.test-runner>.test-header>.test-progress .theme-toggle-btn{flex:0 0 auto;width:var(--hit-target);height:var(--hit-target);min-width:var(--hit-target);min-height:var(--hit-target)}.instructions-container{position:relative}.instructions-toolbar{display:flex;justify-content:flex-end;margin-bottom:var(--space-sm)}.instructions-toolbar .theme-toggle-btn{width:var(--hit-target);height:var(--hit-target);min-width:var(--hit-target);min-height:var(--hit-target)}.test-runner.loading,.test-runner.error{position:relative;padding-top:calc(var(--hit-target) + var(--space-md))}.test-runner-utilities{position:absolute;top:var(--space-sm);right:clamp(1rem,3vw,2.5rem)}.test-runner-utilities .theme-toggle-btn{width:var(--hit-target);height:var(--hit-target);min-width:var(--hit-target);min-height:var(--hit-target)}[data-theme=high-contrast] .test-runner,[data-theme=high-contrast] .test-instructions-component{background:var(--beige)!important;color:var(--text-primary)!important}[data-theme=high-contrast] .test-runner .test-header{background:var(--beige)!important;border-bottom:2px solid #000!important}[data-theme=high-contrast] .test-runner>.test-content{background:var(--beige)!important}[data-theme=high-contrast] .test-runner .answer-input,[data-theme=high-contrast] .test-runner .word-input,[data-theme=high-contrast] .test-runner .writing-textarea,[data-theme=high-contrast] .test-runner .text-input,[data-theme=high-contrast] .test-runner .text-area,[data-theme=high-contrast] .test-runner .recognition-word,[data-theme=high-contrast] .test-runner .composition-textarea{background:#fff!important;color:#000!important;border:2px solid #000!important;box-shadow:none!important}[data-theme=high-contrast] .test-runner .answer-input:focus,[data-theme=high-contrast] .test-runner .word-input:focus,[data-theme=high-contrast] .test-runner .writing-textarea:focus,[data-theme=high-contrast] .test-runner .recognition-word:focus-visible{outline:none!important;box-shadow:var(--focus-ring)!important;border-color:#000!important}[data-theme=high-contrast] .test-runner .btn,[data-theme=high-contrast] .test-runner .btn-primary,[data-theme=high-contrast] .test-runner .btn-secondary,[data-theme=high-contrast] .test-runner .btn-warning,[data-theme=high-contrast] .test-runner .btn-danger,[data-theme=high-contrast] .test-runner .button-primary,[data-theme=high-contrast] .test-runner .button-secondary,[data-theme=high-contrast] .test-runner .cue-button,[data-theme=high-contrast] .test-runner .navigator-button,[data-theme=high-contrast] .test-instructions-component .button-primary,[data-theme=high-contrast] .test-instructions-component .button-secondary{box-shadow:none!important;border:2px solid #000!important}[data-theme=high-contrast] .test-runner .btn-primary,[data-theme=high-contrast] .test-runner .btn.btn-primary,[data-theme=high-contrast] .test-runner .button-primary,[data-theme=high-contrast] .test-instructions-component .button-primary{background:var(--accent)!important;border-color:#000!important;color:#fff!important}[data-theme=high-contrast] .test-runner .btn-secondary,[data-theme=high-contrast] .test-runner .btn.btn-secondary,[data-theme=high-contrast] .test-runner .button-secondary,[data-theme=high-contrast] .test-runner .test-exit-button,[data-theme=high-contrast] .test-instructions-component .button-secondary{background:#fff!important;border-color:#000!important;color:#000!important}[data-theme=high-contrast] .test-runner .stimulus-container,[data-theme=high-contrast] .test-runner .writing-area,[data-theme=high-contrast] .test-runner .speech-recognition-section,[data-theme=high-contrast] .test-runner .reading-text-container,[data-theme=high-contrast] .test-runner .two-pane-task,[data-theme=high-contrast] .test-runner .word-list-container,[data-theme=high-contrast] .test-runner .input-section,[data-theme=high-contrast] .test-runner .task-instructions,[data-theme=high-contrast] .test-runner .trail-canvas-container,[data-theme=high-contrast] .test-runner .clock-container,[data-theme=high-contrast] .test-runner .card,[data-theme=high-contrast] .test-runner .target-section,[data-theme=high-contrast] .test-runner .design-section,[data-theme=high-contrast] .test-runner .palette-section,[data-theme=high-contrast] .test-runner .scoring-criteria,[data-theme=high-contrast] .test-instructions-component .instructions-container,[data-theme=high-contrast] .test-instructions-component .test-info{background:#fff!important;border:2px solid #000!important;box-shadow:none!important}[data-theme=high-contrast] .test-runner .progress-bar,[data-theme=high-contrast] .test-runner>.test-header>.test-progress>.progress-bar{background:#fff!important;border:2px solid #000!important}[data-theme=high-contrast] .test-runner .progress-fill,[data-theme=high-contrast] .test-runner>.test-header>.test-progress>.progress-fill{background:var(--accent)!important}[data-theme=high-contrast] .test-runner .theme-toggle-btn,[data-theme=high-contrast] .test-instructions-component .theme-toggle-btn,[data-theme=high-contrast] .test-runner-utilities .theme-toggle-btn{border:2px solid #000!important;background:#fff!important;color:#000!important;box-shadow:none!important}[data-theme=high-contrast] .test-runner .warning-content,[data-theme=high-contrast] .test-runner .completion-warning .warning-content{background:#fff!important;border:2px solid #000!important;box-shadow:none!important;color:#000!important}[data-theme=high-contrast] .test-runner .ai-review-notice{background:#fff!important;border:2px solid #000!important;color:#000!important}[data-theme=high-contrast] .test-runner .feedback-message,[data-theme=high-contrast] .test-runner .feedback-message.correct,[data-theme=high-contrast] .test-runner .feedback-message.incorrect,[data-theme=high-contrast] .test-runner .speech-feedback,[data-theme=high-contrast] .test-runner .speech-feedback.correct,[data-theme=high-contrast] .test-runner .speech-feedback.incorrect{background:#fff!important;border:2px solid #000!important;color:#000!important;box-shadow:none!important}[data-theme=high-contrast] .test-runner .feedback-message.correct,[data-theme=high-contrast] .test-runner .speech-feedback.correct{border-left:6px solid var(--status-success)!important}[data-theme=high-contrast] .test-runner .feedback-message.incorrect,[data-theme=high-contrast] .test-runner .speech-feedback.incorrect{border-left:6px solid var(--status-danger)!important}[data-theme=high-contrast] .test-runner .semantic-cue,[data-theme=high-contrast] .test-runner .writing-tips,[data-theme=high-contrast] .test-runner .example-response{background:#fff!important;border:2px solid #000!important;color:#000!important;box-shadow:none!important}[data-theme=high-contrast] .test-runner .cue-header,[data-theme=high-contrast] .test-runner .cue-note{color:#000!important}[data-theme=high-contrast] .test-runner .option-button{background:#fff!important;border:2px solid #000!important;color:#000!important}[data-theme=high-contrast] .test-runner .option-button:hover,[data-theme=high-contrast] .test-runner .option-button.selected{background:var(--accent)!important;color:#fff!important;border-color:#000!important}[data-theme=high-contrast] .test-runner .test-timer,[data-theme=high-contrast] .test-runner .test-timer.warning,[data-theme=high-contrast] .test-runner .test-timer.critical{background:#fff!important;border:2px solid #000!important;color:#000!important;box-shadow:none!important}[data-theme=high-contrast] .test-runner .question-prompt h4,[data-theme=high-contrast] .test-runner .question-text,[data-theme=high-contrast] .test-runner .instructions-title,[data-theme=high-contrast] .test-instructions-component .instructions-title,[data-theme=high-contrast] .test-runner .test-header-title{color:#000!important}[data-theme=high-contrast] .test-runner .skipped-question-link{border:2px solid #000!important;background:#fff!important;color:#000!important}[data-theme=high-contrast] .test-runner .skipped-question-link:hover{background:var(--accent)!important;color:#fff!important}[data-theme=high-contrast] .test-runner .question-status-pill{border:2px solid currentColor!important;color:#000!important}[data-theme=high-contrast] .test-runner .skipped-question-link:hover .question-status-pill{color:#fff!important}.test-runner>.test-header{display:flex!important;flex-direction:column!important;align-items:stretch!important;gap:var(--space-sm)!important}.test-runner .test-header-main{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:var(--space-md);width:100%}.test-runner .test-header-actions{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:var(--space-sm);min-width:0}.test-runner .question-progress-summary{flex:0 1 auto;color:var(--text-secondary);font-family:var(--font-workhorse);font-size:var(--text-base);font-weight:600;line-height:1.2;text-align:right;white-space:nowrap}.test-runner .test-skip-button,.test-runner .test-exit-button,.test-runner .navigator-button{flex:0 0 auto;min-height:var(--hit-target)!important;padding:.625rem 1.1rem!important;line-height:1!important;white-space:nowrap!important}.test-runner>.test-header>.test-progress{display:flex!important;flex-direction:column!important;align-items:stretch!important;gap:var(--space-xs)!important;width:100%!important;min-width:0!important;flex:0 0 auto!important}.test-runner .test-progress-copy{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-md);min-width:0}.test-runner .test-progress-count,.test-runner .test-progress-context{color:var(--text-secondary);font-family:var(--font-workhorse);font-size:var(--text-sm);font-weight:500;line-height:1.2}.test-runner>.test-header>.test-progress>.progress-bar{position:relative!important;flex:0 0 auto!important;width:100%!important;height:18px!important;min-width:0!important;overflow:hidden!important;border-radius:var(--radius-full)!important}.test-runner>.test-header>.test-progress>.progress-bar>.progress-fill{position:absolute!important;inset:0 auto 0 0!important;height:100%!important;border-radius:var(--radius-full)!important}.test-runner .progress-bar-value{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;display:flex;align-items:center;justify-content:center;color:var(--white);font-family:var(--font-workhorse);font-size:.75rem;font-weight:700;line-height:1;text-shadow:0 1px 2px rgba(0,0,0,.65);pointer-events:none}@media (max-width: 900px){.test-runner .test-header-main{grid-template-columns:1fr;justify-items:stretch}.test-runner .test-header-actions{justify-content:center}.test-runner .question-progress-summary{flex-basis:100%;text-align:center;white-space:normal}}@media (max-width: 520px){.test-runner .test-header-actions>button{flex:1 1 140px}.test-runner .test-progress-copy{flex-direction:column;align-items:center;gap:.25rem;text-align:center}.test-runner .test-progress-context{text-align:center}}[data-theme=high-contrast] .test-runner .test-skip-button{border:2px solid #000!important;background:#fff!important;color:#000!important}[data-theme=high-contrast] .test-runner .test-skip-button:hover{background:var(--accent)!important;color:#fff!important}[data-theme=high-contrast] .test-runner .progress-bar-value,[data-theme=high-contrast] .test-runner .question-progress-summary,[data-theme=high-contrast] .test-runner .test-progress-count,[data-theme=high-contrast] .test-runner .test-progress-context{color:#000!important}.question-navigator-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-md)}.question-navigator{background:var(--surface);border:1.5px solid var(--border-soft);border-radius:var(--radius-xl);width:min(900px,100%);max-height:min(90vh,900px);overflow:hidden;display:flex;flex-direction:column;box-shadow:none;font-family:var(--font-workhorse)}.navigator-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-md);padding:var(--space-lg) var(--space-xl);border-bottom:1.5px solid var(--border-soft);background:var(--surface)}.navigator-header__text{display:flex;flex-direction:column;gap:var(--space-xs)}.navigator-eyebrow{margin:0;font-size:var(--text-sm);font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}.navigator-header h3{margin:0;font-size:var(--text-2xl);font-weight:600;color:var(--text-primary);letter-spacing:-.02em}.close-button{flex-shrink:0;min-width:var(--hit-target);min-height:var(--hit-target);display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1.5px solid var(--border-medium);border-radius:var(--radius-full);color:var(--text-secondary);font-size:var(--text-xl);line-height:1;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.close-button:hover{background:var(--accent-muted);border-color:var(--border-accent);color:var(--accent)}.close-button:focus-visible{outline:none;box-shadow:var(--focus-ring)}.progress-summary{padding:var(--space-lg) var(--space-xl);background:var(--beige);border-bottom:1.5px solid var(--border-soft)}.progress-summary .progress-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-md);margin-bottom:var(--space-md)}.progress-summary .stat-item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-xs)}.progress-summary .stat-label{font-size:var(--text-base);color:var(--text-secondary);font-weight:500}.progress-summary .stat-value{font-size:var(--text-xl);font-weight:600;color:var(--text-primary)}.progress-summary .stat-value.completed{color:var(--status-success)}.progress-summary .stat-value.skipped{color:var(--status-warning)}.progress-summary .stat-value.pending{color:var(--text-secondary)}.progress-bar-container{margin-top:var(--space-sm)}.progress-bar-container .progress-bar{width:100%;height:8px;background:#00000014;border-radius:var(--radius-full);overflow:hidden}.progress-bar-container .progress-fill{height:100%;background:var(--accent);border-radius:var(--radius-full);transition:width .3s ease}.sections-container{padding:var(--space-lg) var(--space-xl);overflow-y:auto;flex:1 1 auto;min-height:0}.section-group{margin-bottom:var(--space-xl)}.section-group:last-child{margin-bottom:0}.section-header{display:flex;justify-content:space-between;align-items:baseline;gap:var(--space-md);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1.5px solid var(--border-soft)}.section-header h4{margin:0;font-size:var(--text-lg);font-weight:600;color:var(--text-primary)}.section-progress{font-size:var(--text-base);color:var(--text-secondary);white-space:nowrap}.questions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-md)}.question-button{display:flex;align-items:center;gap:var(--space-sm);min-height:var(--hit-target);padding:var(--space-md);border:1.5px solid var(--border-soft);border-radius:var(--radius-md);background:var(--beige);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast);text-align:left;font-family:var(--font-workhorse);font-size:var(--text-base);color:var(--text-primary)}.question-button:hover:not(.disabled){border-color:var(--border-accent);transform:translateY(-1px)}.question-button:focus-visible{outline:none;box-shadow:var(--focus-ring)}.question-button.completed{background:var(--status-success-bg);border-color:#257a3e40}.question-button.skipped{background:var(--status-warning-bg);border-color:#8a5b0040}.question-button.current{background:var(--accent-muted);border-color:var(--accent);box-shadow:var(--focus-ring)}.question-button.pending{background:var(--beige)}.question-button.disabled{opacity:.55;cursor:not-allowed}.status-marker{width:10px;height:10px;border-radius:50%;flex-shrink:0;background:var(--gray-400)}.status-marker--completed{background:var(--status-success)}.status-marker--skipped{background:var(--status-warning)}.status-marker--current{background:var(--accent);box-shadow:0 0 0 3px var(--accent-muted)}.status-marker--pending{background:var(--gray-300)}.question-number{font-weight:600;color:var(--text-primary);min-width:2rem;flex-shrink:0}.question-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-secondary)}.question-button.current .question-title{color:var(--text-primary)}.navigator-legend{padding:var(--space-lg) var(--space-xl);background:var(--beige);border-top:1.5px solid var(--border-soft)}.navigator-legend h5{margin:0 0 var(--space-md);font-size:var(--text-base);font-weight:600;color:var(--text-primary)}.legend-items{display:flex;flex-wrap:wrap;gap:var(--space-md) var(--space-lg)}.legend-item{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--text-base);color:var(--text-secondary)}.navigator-actions{padding:var(--space-lg) var(--space-xl);border-top:1.5px solid var(--border-soft);text-align:center;background:var(--surface)}.navigator-actions .btn-secondary{min-height:var(--hit-target);min-width:180px;padding:.75rem 1.5rem;background:transparent;color:var(--accent);border:1.5px solid var(--accent);border-radius:var(--radius-full);font-family:var(--font-workhorse);font-size:var(--text-base);font-weight:600;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),transform var(--transition-fast)}.navigator-actions .btn-secondary:hover{background:var(--accent);color:var(--white);transform:translateY(-1px)}@media (max-width: 768px){.question-navigator-overlay{padding:var(--space-sm)}.navigator-header,.progress-summary,.sections-container,.navigator-legend,.navigator-actions{padding-inline:var(--space-lg)}.progress-summary .progress-stats{grid-template-columns:repeat(2,1fr)}.questions-grid{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start;gap:var(--space-xs)}.navigator-actions .btn-secondary{width:100%}}@media (max-width: 480px){.progress-summary .progress-stats{grid-template-columns:1fr}}@media (prefers-reduced-motion: reduce){.question-button,.navigator-actions .btn-secondary,.progress-bar-container .progress-fill{transition:none}}[data-theme=high-contrast] .question-navigator-overlay{background:#000000bf}[data-theme=high-contrast] .question-navigator{background:#fff;border:2px solid #000;box-shadow:none}[data-theme=high-contrast] .navigator-header,[data-theme=high-contrast] .progress-summary,[data-theme=high-contrast] .sections-container,[data-theme=high-contrast] .navigator-legend,[data-theme=high-contrast] .navigator-actions{border-color:#000}[data-theme=high-contrast] .question-button{border:2px solid #000;background:#fff;color:#000;box-shadow:none}[data-theme=high-contrast] .question-button.completed{border-color:var(--status-success)}[data-theme=high-contrast] .question-button.skipped{border-color:var(--status-warning)}[data-theme=high-contrast] .question-button.current{border-color:var(--accent);border-width:3px}[data-theme=high-contrast] .progress-bar-container{background:#fff;border:2px solid #000}[data-theme=high-contrast] .progress-bar-container .progress-fill{background:var(--accent)}[data-theme=high-contrast] .navigator-actions .btn-secondary{border:2px solid #000;background:#fff;color:#000;box-shadow:none}.trainer-score-panel,.trainer-rubric-panel{background:var(--surface);border:1.5px solid var(--border-soft);border-radius:var(--radius-lg);padding:var(--space-lg)}.trainer-score-panel__loading{padding:var(--space-xl);text-align:center;color:var(--text-secondary)}.trainer-score-panel__spinner{display:inline-block;width:40px;height:40px;border:3px solid var(--gray-200);border-top-color:var(--accent);border-radius:50%;animation:trainer-spin 1s linear infinite;margin-bottom:var(--space-md)}.trainer-score-panel__loading-text{font-size:var(--text-base)}.trainer-score-panel__header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:var(--space-md);gap:var(--space-md)}.trainer-score-panel__value{font-size:var(--text-4xl);font-weight:600;line-height:1;color:var(--text-primary)}.trainer-score-panel__label{font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin-top:var(--space-xs)}.trainer-score-panel__badge{padding:.5rem 1rem;border-radius:var(--radius-md);background:var(--gray-100);border:1.5px solid var(--border-medium);font-size:var(--text-base);font-weight:600;color:var(--text-primary);white-space:nowrap}.trainer-score-panel__progress{height:8px;width:100%;background:var(--gray-200);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--space-lg)}.trainer-score-panel__progress-fill{height:100%;background:var(--accent);transition:width .3s ease}.trainer-score-panel__feedback{display:flex;flex-direction:column;gap:.75rem}.trainer-score-panel__feedback-item{display:flex;align-items:flex-start;gap:.75rem;font-size:var(--text-base);line-height:1.5;color:var(--text-primary)}.trainer-score-panel__feedback-dot{display:inline-block;width:6px;height:6px;background:var(--accent);border-radius:50%;margin-top:.55rem;flex-shrink:0}.trainer-rubric-panel__title{font-size:var(--text-lg);font-weight:600;margin:0 0 var(--space-md);color:var(--text-primary)}.trainer-rubric-panel__list{font-size:var(--text-base);padding-left:1.5rem;line-height:1.8;margin:0;color:var(--text-primary)}.trainer-rubric-panel__footer{font-size:var(--text-base);color:var(--text-secondary);margin:var(--space-md) 0 0;line-height:1.5}@keyframes trainer-spin{to{transform:rotate(360deg)}}[data-theme=high-contrast] .trainer-score-panel,[data-theme=high-contrast] .trainer-rubric-panel{background:#fff;border:2px solid #000;box-shadow:none}[data-theme=high-contrast] .trainer-score-panel__badge{background:#fff;border:2px solid #000;color:#000}[data-theme=high-contrast] .trainer-score-panel__progress{background:#fff;border:2px solid #000}[data-theme=high-contrast] .trainer-score-panel__progress-fill{background:var(--accent)}.functional-ordering{display:flex;flex-direction:column;gap:var(--space-xl);max-width:960px;margin:0 auto;width:100%}.functional-ordering__intro{display:flex;flex-direction:column;gap:var(--space-md)}.functional-ordering__title{font-size:var(--text-2xl);font-weight:600;margin:0;color:var(--text-primary)}.functional-ordering__subtitle{font-size:var(--text-base);color:var(--text-secondary);margin:0;line-height:1.5}.functional-ordering__step{display:flex;flex-direction:column;gap:var(--space-md)}.functional-ordering__step-label{font-size:var(--text-sm);font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin:0}.functional-ordering__step-title{font-size:var(--text-xl);font-weight:600;margin:0;color:var(--text-primary)}.functional-ordering__step-hint{font-size:var(--text-base);color:var(--text-secondary);margin:0;line-height:1.5}.functional-ordering__panel{background:var(--surface);border:1.5px solid var(--border-soft);border-radius:var(--radius-lg);padding:var(--space-lg)}.selection-display__header{text-align:center;margin-bottom:var(--space-lg)}.selection-display__eyebrow{font-size:var(--text-sm);font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin:0 0 var(--space-sm)}.selection-display__title{font-size:clamp(1.5rem,3vw,var(--text-3xl));font-weight:400;letter-spacing:-.02em;margin:0 0 var(--space-xs);color:var(--text-primary)}.selection-display__subtitle{font-size:var(--text-base);color:var(--text-secondary);margin:0}.selection-display__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--space-md)}.selection-item{display:flex;flex-direction:column;align-items:stretch;width:100%;min-height:var(--hit-target);padding:var(--space-md);background:var(--beige);border:1.5px solid var(--border-medium);border-radius:var(--radius-md);text-align:left;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast);font-family:var(--font-workhorse)}.selection-item:hover{background:var(--surface);border-color:var(--border-accent)}.selection-item:focus-visible{outline:none;box-shadow:var(--focus-ring)}.selection-item--selected{background:var(--accent-muted);border-color:var(--accent)}.selection-item__row{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-md);width:100%}.selection-item__name{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0}.selection-item__meta{font-size:var(--text-base);color:var(--text-secondary);margin:var(--space-xs) 0 0}.selection-item__value{font-size:var(--text-base);font-weight:600;color:var(--text-primary);white-space:nowrap}.selection-item__footer{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);margin-top:var(--space-md)}.selection-item__tags{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-top:var(--space-md)}.selection-item__tag{font-size:var(--text-sm);padding:.25rem .625rem;border-radius:var(--radius-full);background:var(--surface);color:var(--text-secondary);border:1px solid var(--border-soft)}.selection-item--selected .selection-item__tag{background:var(--beige);border-color:var(--border-accent)}.speech-panel__actions{display:flex;flex-wrap:wrap;gap:var(--space-md);margin-bottom:var(--space-lg)}.speech-panel__actions .btn{min-height:var(--hit-target);padding:.75rem 1.5rem;font-size:var(--text-base)}.speech-panel__actions .btn-secondary{min-height:var(--btn-min-height)}.speech-panel__status{display:inline-flex;align-items:center;gap:var(--space-sm);padding:.5rem 1rem;border-radius:var(--radius-full);background:var(--beige);border:1.5px solid var(--border-medium);font-size:var(--text-base);color:var(--text-secondary);margin-bottom:var(--space-md)}.speech-panel__status-dot{width:8px;height:8px;border-radius:50%;background:var(--gray-400);flex-shrink:0}.speech-panel__status-dot--listening{background:var(--status-success);animation:ordering-pulse 2s ease-in-out infinite}.speech-panel__transcript-label{display:block;font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);font-weight:600;margin-bottom:var(--space-sm)}.speech-panel__textarea,.speech-panel__transcript{width:100%;min-height:96px;padding:var(--space-md);background:var(--beige);border:1.5px solid var(--border-medium);border-radius:var(--radius-md);font-size:var(--text-base);line-height:1.6;color:var(--text-primary);font-family:var(--font-workhorse)}.speech-panel__textarea{resize:vertical}.speech-panel__transcript--empty{color:var(--text-muted)}.speech-panel__transcript-note{font-size:var(--text-base);color:var(--text-secondary);margin:var(--space-sm) 0 0}.functional-ordering__tip{margin-top:var(--space-lg);padding:var(--space-md);background:var(--beige);border-radius:var(--radius-md);border:1.5px solid var(--border-soft);font-size:var(--text-base);color:var(--text-secondary);line-height:1.5}.functional-ordering__tip-title{font-weight:600;color:var(--text-primary);margin:0 0 var(--space-sm)}.functional-ordering__tip p{margin:0}.functional-ordering__submit{display:flex;justify-content:center;margin-top:var(--space-lg)}.functional-ordering__submit .btn{min-height:var(--hit-target);padding:.875rem 2rem;font-size:var(--text-lg)}.alert-banner{padding:var(--space-md);border-radius:var(--radius-md);font-size:var(--text-base);line-height:1.5;border:1.5px solid transparent}.alert-banner--warning{background:var(--status-warning-bg);border-color:#8a5b0040;color:var(--status-warning)}.alert-banner--error{background:var(--status-danger-bg);border-color:var(--border-accent);color:var(--accent)}.functional-ordering--embedded{gap:var(--space-lg)}.test-runner>.test-content>.functional-ordering--embedded{flex:1 1 auto;max-width:min(1320px,100%);min-height:0;height:100%}.functional-ordering--embedded .functional-ordering__step-title{font-size:var(--text-lg)}.functional-ordering--embedded .selection-display__grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.functional-ordering__two-pane,.functional-ordering__pane{min-width:0}.functional-ordering__two-pane,.functional-ordering__pane{display:flex;flex-direction:column;gap:var(--space-lg)}.phone-ordering__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.phone-ordering__header .speech-panel__status{flex:0 0 auto;margin-bottom:0}@keyframes ordering-pulse{0%,to{opacity:1}50%{opacity:.45}}@media (max-width: 768px){.selection-display__grid{grid-template-columns:1fr}.speech-panel__actions{flex-direction:column}.speech-panel__actions .btn{width:100%}.trainer-score-panel__header{flex-direction:column;align-items:flex-start}}@media (min-width: 1024px){.functional-ordering--embedded{gap:var(--space-md)}.functional-ordering--embedded .question-prompt{flex:0 0 auto;margin-bottom:0!important}.functional-ordering--embedded.phone-ordering .phone-ordering__header{flex:0 0 auto;padding-inline:var(--space-md)}.functional-ordering--embedded .functional-ordering__two-pane{flex:1 1 auto;min-height:0;display:grid;grid-template-columns:minmax(320px,.95fr) minmax(360px,1.05fr);align-items:stretch;gap:clamp(1rem,2vw,1.5rem);overflow:hidden}.functional-ordering--embedded .functional-ordering__pane{min-height:0;overflow-y:auto;padding-right:.25rem}.functional-ordering--embedded .functional-ordering__panel{padding:var(--space-md)}.functional-ordering--embedded .selection-display__header{margin-bottom:var(--space-md)}.functional-ordering--embedded .selection-display__grid{grid-template-columns:1fr;gap:var(--space-sm)}.functional-ordering--embedded .selection-item{padding:var(--space-sm) var(--space-md)}.functional-ordering--embedded .selection-item__name{font-size:var(--text-base)}.functional-ordering--embedded .selection-item__meta,.functional-ordering--embedded .selection-item__value{font-size:var(--text-sm)}.functional-ordering--embedded .speech-panel__actions{margin-bottom:var(--space-md)}.functional-ordering--embedded .speech-panel__textarea,.functional-ordering--embedded .speech-panel__transcript{min-height:84px}}@media (prefers-reduced-motion: reduce){.speech-panel__status-dot--listening{animation:none}.selection-item{transition:none}}[data-theme=high-contrast] .functional-ordering .selection-item{background:#fff;border:2px solid #000;color:#000;box-shadow:none}[data-theme=high-contrast] .functional-ordering .selection-item--selected{background:var(--accent);color:#fff;border-color:#000}[data-theme=high-contrast] .functional-ordering .speech-panel,[data-theme=high-contrast] .functional-ordering .selection-display{background:#fff;border:2px solid #000;box-shadow:none}[data-theme=high-contrast] .functional-ordering .speech-panel__transcript,[data-theme=high-contrast] .functional-ordering .selection-display__summary{background:#fff;border:2px solid #000;color:#000}[data-theme=high-contrast] .functional-ordering .btn{border:2px solid #000!important;box-shadow:none!important}.ticket-options{display:flex;flex-direction:column;gap:var(--space-lg)}.ticket-options__hint{font-size:var(--text-base);color:var(--text-secondary);margin:0;line-height:1.5}.ticket-options__section-label{font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);font-weight:600;margin:0 0 var(--space-md)}.ticket-options__rows{display:flex;flex-direction:column;gap:var(--space-md)}.ticket-row{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);padding:var(--space-md);border:1.5px solid var(--border-medium);border-radius:var(--radius-md);background:var(--beige)}.ticket-row__label{font-size:var(--text-base);font-weight:600;color:var(--text-primary);text-transform:capitalize}.ticket-counter{display:inline-flex;align-items:center;gap:var(--space-sm)}.ticket-counter__btn{min-width:var(--hit-target);min-height:var(--hit-target);padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:var(--text-xl);line-height:1}.ticket-counter__value{min-width:2ch;text-align:center;font-size:var(--text-lg);font-weight:600;color:var(--text-primary)}.ticket-options__summary{display:flex;justify-content:space-between;flex-wrap:wrap;gap:var(--space-sm);font-size:var(--text-base);color:var(--text-secondary)}.ticket-options__summary strong{color:var(--text-primary)}.option-chips{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.option-chip{min-height:var(--hit-target);padding:.5rem 1rem;background:var(--beige);border:1.5px solid var(--border-medium);border-radius:var(--radius-full);font-family:var(--font-workhorse);font-size:var(--text-base);font-weight:600;color:var(--text-primary);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);text-transform:capitalize}.option-chip:hover{border-color:var(--border-accent)}.option-chip:focus-visible{outline:none;box-shadow:var(--focus-ring)}.option-chip--selected{background:var(--accent-muted);border-color:var(--accent);color:var(--text-primary)}.order-summary{margin-top:var(--space-md)}.order-summary__title{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin:0 0 var(--space-sm)}.order-summary__body{font-size:var(--text-base);color:var(--text-secondary);line-height:1.6;margin:0}.ticket-options--empty{font-size:var(--text-base);color:var(--text-muted);text-align:center;padding:var(--space-lg)}.stryde-logo{display:inline-flex;align-items:center;line-height:0;border:none;background:none;padding:0}.stryde-logo--clickable{cursor:pointer}.stryde-logo img{width:auto;object-fit:contain;display:block}.stryde-logo--sm img{height:24px}.stryde-logo--md img{height:36px}.stryde-logo--lg img{height:40px}.stryde-logo--xl img{height:56px}@media (max-width: 768px){.stryde-logo--md img{height:30px}.stryde-logo--xl img{height:44px}}
