@import"https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@400;500;700&display=swap";@import"https://fonts.googleapis.com/icon?family=Material+Icons";.optin-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.optin-dialog{background:var(--color-surface);color:var(--color-text-primary);border-radius:var(--radius-lg);padding:var(--spacing-lg);max-width:560px;width:100%;box-shadow:0 20px 60px #0000004d}.optin-dialog h2{margin-top:0;margin-bottom:var(--spacing-md)}.optin-dialog p,.optin-dialog ul{font-size:var(--font-size-sm);line-height:1.6;margin:var(--spacing-sm) 0}.optin-dialog ul{padding-left:1.25em}.optin-dialog li{margin-bottom:var(--spacing-xs)}.optin-note{font-size:var(--font-size-xs);color:var(--color-text-secondary);border-top:1px solid var(--color-border, rgba(0, 0, 0, .1));padding-top:var(--spacing-sm)}.optin-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.pool-histogram{margin-top:var(--spacing-md);padding:var(--spacing-md);background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm)}.pool-histogram__title{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin:0 0 var(--spacing-sm);font-weight:500;letter-spacing:.04em}.pool-histogram__rows{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--spacing-xs)}.pool-histogram__row{display:grid;grid-template-columns:5em 3em 1fr 3em;gap:var(--spacing-sm);align-items:center}.pool-histogram__label{color:var(--color-text-primary);font-variation-settings:"wght" 540}.pool-histogram__count{font-weight:600;text-align:right;font-variant-numeric:tabular-nums}.pool-histogram__bar-track{height:8px;background:var(--color-surface-variant);border-radius:4px;overflow:hidden}.pool-histogram__bar{height:100%;border-radius:4px;transition:width .2s ease}.pool-histogram__row--main .pool-histogram__bar{background:var(--color-success)}.pool-histogram__row--mock .pool-histogram__bar{background:var(--color-info)}.pool-histogram__row--ai .pool-histogram__bar{background:var(--color-warning)}.pool-histogram__pct{font-size:var(--font-size-xs);color:var(--color-text-quiet);font-variant-numeric:tabular-nums;text-align:right}.pool-histogram__total{margin:var(--spacing-sm) 0 0;font-size:var(--font-size-xs);color:var(--color-text-secondary);text-align:center}@media(max-width:640px){.pool-histogram{padding:var(--spacing-sm)}.pool-histogram__row{grid-template-columns:1fr auto;grid-template-areas:"label count" "bar   pct";row-gap:4px}.pool-histogram__label{grid-area:label}.pool-histogram__count{grid-area:count}.pool-histogram__bar-track{grid-area:bar}.pool-histogram__pct{grid-area:pct;min-width:3em}}.home-page{max-width:900px;margin:0 auto}.hero-section{text-align:center;padding:var(--spacing-xl) 0}.hero-section h1{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);font-size:var(--font-size-3xl);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.hero-icon{color:var(--color-primary)}.hero-subtitle{font-size:var(--font-size-lg);color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.stats-badges{display:flex;justify-content:center;gap:var(--spacing-sm);flex-wrap:wrap}.badge-button{border:0;font:inherit;cursor:pointer;transition:transform var(--transition-fast),filter var(--transition-fast),box-shadow var(--transition-fast)}.badge-button:hover{transform:translateY(-1px);filter:brightness(.95);box-shadow:var(--shadow-1)}.badge-button:active{transform:translateY(0);filter:brightness(.9)}.badge-button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.resume-hint{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-md);background:var(--color-info-bg, var(--color-surface));border-left:3px solid var(--color-info, var(--color-primary));font-size:var(--font-size-sm)}.resume-hint__text{flex:1;color:var(--color-text-primary)}.resume-hint__cta{flex-shrink:0;font-weight:600;color:var(--color-primary)}.practice-pool-tip{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);margin-bottom:var(--spacing-lg);background:var(--color-warning-bg);border-left:4px solid var(--color-warning);transition:background-color .2s ease,border-color .2s ease}.practice-pool-tip--enabled{background:var(--color-success-bg);border-left-color:var(--color-success)}.practice-pool-tip__icon{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-warning);color:var(--color-on-primary);border-radius:var(--radius-full);transition:background-color .2s ease}.practice-pool-tip--enabled .practice-pool-tip__icon{background:var(--color-success)}.practice-pool-tip__icon .material-icons{font-size:24px}.practice-pool-tip__body{flex:1;min-width:0}.practice-pool-tip__title{font-size:var(--font-size-lg);font-weight:600;margin:0 0 var(--spacing-xs);color:var(--color-text-primary)}.practice-pool-tip__desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0 0 var(--spacing-md);line-height:1.6}.practice-pool-tip__cta{font-size:var(--font-size-sm);margin-top:var(--spacing-md)}.practice-pool-tip__details{margin:var(--spacing-md) 0 0}.practice-pool-tip__details-summary{display:inline-flex;align-items:center;gap:var(--spacing-xs);cursor:pointer;font-size:var(--font-size-sm);font-weight:500;color:var(--color-primary);-webkit-user-select:none;user-select:none;list-style:none;padding:var(--spacing-xs) 0}.practice-pool-tip__details-summary::-webkit-details-marker{display:none}.practice-pool-tip__details-summary:hover{text-decoration:underline}.practice-pool-tip__details-summary:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-sm)}.practice-pool-tip__details-summary:before{content:"▸";display:inline-block;font-size:.85em;transition:transform .15s ease}.practice-pool-tip__details[open]>.practice-pool-tip__details-summary:before{transform:rotate(90deg)}@media(prefers-reduced-motion:reduce){.practice-pool-tip__details-summary:before{transition:none}}.practice-pool-tip__details-content{margin-top:var(--spacing-sm)}@media(max-width:640px){.resume-hint{flex-wrap:wrap}.resume-hint__cta{margin-left:auto}.practice-pool-tip{flex-direction:column;padding:var(--spacing-md)}.practice-pool-tip__icon{width:40px;height:40px}.practice-pool-tip__cta{width:100%;justify-content:center}.hero-subtitle{font-size:var(--font-size-base)}.stats-badges{gap:var(--spacing-xs)}.config-grid{grid-template-columns:1fr;gap:var(--spacing-md)}.config-section{margin-bottom:var(--spacing-lg)}.start-btn{padding:var(--spacing-sm);font-size:var(--font-size-base)}.info-cards{grid-template-columns:1fr}}.config-section{margin-bottom:var(--spacing-xl)}.config-section h2{font-size:var(--font-size-xl);font-weight:600;margin-bottom:var(--spacing-lg);color:var(--color-text-primary)}.config-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.config-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.config-item label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary)}.config-item select,.config-item input[type=number]{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);font-size:var(--font-size-base);transition:border-color var(--transition-fast)}.config-item select:focus,.config-item input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #2e7d3233}.config-item input[aria-invalid=true]{border-color:var(--color-error, #d32f2f)}.config-item__hint{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin:0;min-height:1em}.config-item__hint--error{color:var(--color-error, #d32f2f)}.checkbox-item label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:var(--font-size-base);color:var(--color-text-primary)}.checkbox-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary)}.start-btn{width:100%;padding:var(--spacing-md);font-size:var(--font-size-lg)}.info-section{margin-bottom:var(--spacing-xl)}.info-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-md)}.info-card h3{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-lg);font-weight:600;color:var(--color-primary);margin-bottom:var(--spacing-sm)}.info-title{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.info-card ul{list-style:none;padding:0}.info-card li{position:relative;padding-left:var(--spacing-lg);margin-bottom:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-primary)}.info-card li:before{content:"•";position:absolute;left:var(--spacing-sm);color:var(--color-primary)}@media(max-width:768px){.hero-section h1{font-size:var(--font-size-2xl)}.hero-subtitle{font-size:var(--font-size-base)}.config-grid{grid-template-columns:1fr}}.source-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:2px 8px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:500;line-height:1.4;vertical-align:middle}.source-badge .badge-text{white-space:nowrap}.source-badge.tone-mock{background:var(--color-info-bg, #e0f2fe);color:var(--color-info-fg, #0369a1)}.source-badge.tone-ai{background:var(--color-warning-bg, #fef3c7);color:var(--color-warning-fg, #92400e);border:1px solid var(--color-warning-fg, #92400e)}[data-theme=dark] .source-badge.tone-mock{background:#3b82f626;color:#93c5fd}[data-theme=dark] .source-badge.tone-ai{background:#f59e0b26;color:#fbbf24;border-color:#f59e0b66}.flag-chip{display:inline-block;padding:0 6px;border-radius:var(--radius-sm, 4px);font-size:.85em;background:#00000014}.flag-time_sensitive{background:#ef444426;color:#b91c1c}.flag-ambiguous{background:#a855f726;color:#6b21a8}.flag-low_confidence{background:#6b728026;color:#4b5563}.source-banner{display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-md);border-radius:var(--radius-sm);border-left:4px solid;align-items:flex-start}.source-banner--mock{background:var(--color-info-bg);border-left-color:var(--color-info);color:var(--color-text-primary)}.source-banner--ai{background:var(--color-warning-bg);border-left-color:var(--color-warning);color:var(--color-text-primary)}.source-banner--flagged{border-left-color:var(--color-error);background:var(--color-error-bg)}.source-banner__icon{font-size:22px;flex-shrink:0;margin-top:2px}.source-banner--mock .source-banner__icon{color:var(--color-info)}.source-banner--ai .source-banner__icon{color:var(--color-warning)}.source-banner--flagged .source-banner__icon{color:var(--color-error)}.source-banner__body{flex:1;min-width:0}.source-banner__label{font-weight:600;font-size:var(--font-size-sm);display:block;line-height:1.4}.source-banner__hint{font-size:var(--font-size-xs);color:var(--color-text-secondary);line-height:1.55;margin:var(--spacing-xs) 0 0}.source-banner__sources{color:var(--color-text-quiet)}.source-banner__flags{list-style:none;margin:var(--spacing-sm) 0 0;padding:0;display:flex;flex-direction:column;gap:var(--spacing-xs)}.source-banner__flag{display:flex;gap:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--color-error);align-items:flex-start;line-height:1.55}.source-banner__flag .material-icons.sm{font-size:16px;flex-shrink:0;margin-top:1px}@media(max-width:640px){.source-banner{padding:var(--spacing-sm);gap:var(--spacing-xs)}.source-banner__icon{font-size:20px}.source-banner__label{font-size:var(--font-size-xs)}.source-banner__hint{font-size:.78rem;line-height:1.5}}.question-card{max-width:800px;margin:0 auto}.question-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-divider)}.question-number{font-size:var(--font-size-lg);font-weight:500;color:var(--color-text-secondary)}.question-stat-chip{font-size:var(--font-size-xs);color:var(--color-text-secondary);background:var(--color-surface-variant);padding:2px 8px;border-radius:var(--radius-sm);white-space:nowrap;margin-left:auto}.question-stat-chip__count{margin-left:2px;opacity:.75}.question-feedback-link{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;margin-left:auto;border-radius:var(--radius-sm);color:var(--color-text-secondary);text-decoration:none;transition:background-color var(--transition-fast),color var(--transition-fast)}.question-feedback-link:hover{background:var(--color-divider);color:var(--color-text-primary)}.question-feedback-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.subject-tag{font-size:var(--font-size-xs)}.subject-1{background:#1976d21f;color:#1976d2}.subject-2{background:#9c27b01f;color:#9c27b0}.question-stem{margin-bottom:var(--spacing-lg)}.question-stem p{font-size:var(--font-size-lg);line-height:1.8;color:var(--color-text-primary)}.question-options{display:flex;flex-direction:column;gap:var(--spacing-sm)}.option-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-surface-variant);border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast) var(--easing-standard)}.option-item:hover:not(.correct):not(.incorrect){background:#2e7d3214;border-color:var(--color-primary)}.option-item input[type=radio]{position:absolute;opacity:0;width:0;height:0}.option-item input[type=radio]:focus-visible+.option-key{outline:2px solid var(--color-primary);outline-offset:2px}.option-item input[type=radio]:checked+.option-key{background:var(--color-primary);color:var(--color-on-primary)}.option-item.selected{background:#2e7d321f;border-color:var(--color-primary)}.option-item.correct{background:var(--color-success-bg);border-color:var(--color-success);cursor:default}.option-item.correct .option-key{background:var(--color-success);color:#fff}.option-item.correct .option-icon{color:var(--color-success)}.option-item.incorrect{background:var(--color-error-bg);border-color:var(--color-error);cursor:default}.option-item.incorrect .option-key{background:var(--color-error);color:#fff}.option-item.incorrect .option-icon{color:var(--color-error)}.option-item:has(input:disabled){cursor:default}.option-item:has(input:disabled):not(.correct):not(.incorrect):hover{background:var(--color-surface-variant);border-color:transparent}.option-key{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-full);font-weight:500;font-size:var(--font-size-sm);flex-shrink:0;transition:all var(--transition-fast) var(--easing-standard)}.option-text{flex:1;font-size:var(--font-size-base);line-height:1.5}.option-icon{margin-left:auto;font-size:24px}.no-answer-notice{display:flex;align-items:center;gap:var(--spacing-sm);margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-warning-bg);border-radius:var(--radius-sm);color:var(--color-warning);font-size:var(--font-size-sm)}.ai-section{margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--color-divider)}.ai-explain-btn{display:inline-flex;align-items:center;gap:var(--spacing-xs)}.ai-loading{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-surface-variant);border-radius:var(--radius-md);color:var(--color-text-secondary)}.ai-loading .material-icons.rotating{animation:spin 1s linear infinite}.ai-response{background:var(--color-surface-variant);border-radius:var(--radius-md);overflow:hidden}.ai-response-header{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-primary);color:var(--color-on-primary);font-weight:500}.ai-response-header .confidence-badge{margin-left:auto;padding:2px 8px;background:#fff3;border-radius:var(--radius-full);font-size:var(--font-size-xs)}.ai-response-content{padding:var(--spacing-md);line-height:1.8}.ai-response-content p{margin-bottom:var(--spacing-sm)}.ai-response-content p:last-child{margin-bottom:0}.ai-response-content p:empty{display:none}.ai-response-content strong{font-weight:700;color:var(--color-text-primary)}.ai-response-content code{background:var(--color-surface);padding:.1em .4em;border-radius:4px;font-family:Consolas,Monaco,monospace;font-size:.9em}.ai-response-content em{font-style:italic}.ai-response-error{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);color:var(--color-error)}.ai-response.error .ai-response-header{background:var(--color-error)}@media(max-width:768px){.question-stem p{font-size:var(--font-size-base)}.option-item{padding:var(--spacing-sm) var(--spacing-md)}.option-key{width:28px;height:28px;font-size:var(--font-size-xs)}.option-text,.ai-response-content{font-size:var(--font-size-sm)}}.question-sources{margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface-variant);border-radius:var(--radius-md);border-left:3px solid var(--color-info-fg, #0369a1)}.question-sources-header{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.question-sources-list{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:var(--spacing-xs) var(--spacing-md)}.source-link{font-size:var(--font-size-xs);color:var(--color-text-primary);text-decoration:none;border-bottom:1px dashed currentColor;transition:color .15s ease}.source-link:hover{color:var(--color-info-fg, #0369a1)}[data-theme=dark] .question-sources{background:#3b82f614;border-left-color:var(--color-info-fg-dark, #93c5fd)}@media(max-width:640px){.question-card{padding:var(--spacing-md)}.question-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}.question-stem p{font-size:var(--font-size-sm);line-height:1.6}.option-item{padding:var(--spacing-md);min-height:48px}.option-key{width:32px;height:32px;flex-shrink:0}.question-actions{flex-direction:column;gap:var(--spacing-sm)}.question-actions .btn{width:100%}.ai-response-content{font-size:var(--font-size-sm)}.question-sources{font-size:var(--font-size-xs)}}.option-text__redundant{opacity:.45;font-weight:400;margin-right:.05em}.option-item.correct .option-text__redundant,.option-item.incorrect .option-text__redundant{opacity:.6}.quiz-page{max-width:800px;margin:0 auto}.quiz-progress{margin-bottom:var(--spacing-lg)}.progress-info{display:flex;justify-content:space-between;align-items:center;font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-xs);gap:var(--spacing-md);flex-wrap:wrap}.progress-info__right{display:inline-flex;align-items:center;gap:var(--spacing-md)}.quiz-abort-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);font:inherit;font-size:var(--font-size-sm);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.quiz-abort-btn:hover{border-color:var(--color-error, #d32f2f);color:var(--color-error, #d32f2f)}.quiz-abort-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.quiz-abort-dialog-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(--spacing-md)}.quiz-abort-dialog{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--spacing-lg);max-width:480px;width:100%;box-shadow:var(--shadow-2)}.quiz-abort-dialog h2{font-size:var(--font-size-lg);font-weight:600;margin:0 0 var(--spacing-sm);color:var(--color-text-primary)}.quiz-abort-dialog p{margin:0 0 var(--spacing-lg);color:var(--color-text-secondary);line-height:1.6}.quiz-abort-dialog__actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm)}.quiz-navigation{display:flex;justify-content:space-between;align-items:center;margin-top:var(--spacing-lg);gap:var(--spacing-md)}.nav-center{flex:1;text-align:center}.hint-text{font-size:var(--font-size-sm);color:var(--color-text-secondary)}@media(max-width:768px){.quiz-navigation{flex-wrap:wrap}.quiz-navigation .btn{flex:1;min-width:120px}.nav-center{order:-1;width:100%;margin-bottom:var(--spacing-sm)}}@media(max-width:640px){.quiz-abort-dialog__actions{flex-direction:column-reverse}.quiz-abort-dialog__actions .btn{width:100%}.quiz-page{padding:0 var(--spacing-sm)}.quiz-navigation{flex-direction:column;gap:var(--spacing-sm)}.quiz-navigation .btn{width:100%;flex:none}.nav-center{order:0;width:100%;margin-bottom:0}.progress-info{font-size:var(--font-size-sm)}.hint-text{font-size:var(--font-size-xs)}}.source-breakdown{margin:var(--spacing-lg) 0;padding:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.source-breakdown__title{font-size:var(--font-size-base);font-weight:600;margin:0 0 var(--spacing-sm);color:var(--color-text-primary)}.source-breakdown__rows{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.source-breakdown__row{display:grid;grid-template-columns:6em 5em 1fr 4em auto;gap:var(--spacing-sm);align-items:center;font-size:var(--font-size-sm)}.source-breakdown__label{font-variation-settings:"wght" 540;color:var(--color-text-primary)}.source-breakdown__count{font-variant-numeric:tabular-nums;color:var(--color-text-secondary);text-align:right}.source-breakdown__bar-track{height:10px;background:var(--color-surface-variant);border-radius:5px;overflow:hidden}.source-breakdown__bar{height:100%;border-radius:5px;transition:width .22s ease}.source-breakdown__row--main .source-breakdown__bar{background:var(--color-success)}.source-breakdown__row--mock .source-breakdown__bar{background:var(--color-info)}.source-breakdown__row--ai .source-breakdown__bar{background:var(--color-warning)}.source-breakdown__row--low .source-breakdown__bar{background:var(--color-error)}.source-breakdown__pct{font-variant-numeric:tabular-nums;font-weight:600;text-align:right;color:var(--color-text-primary)}.source-breakdown__note{font-size:var(--font-size-xs);color:var(--color-error)}.source-breakdown__hint{font-size:var(--font-size-xs);color:var(--color-text-secondary);line-height:1.55;margin:var(--spacing-md) 0 0;padding-top:var(--spacing-sm);border-top:1px dashed var(--color-border)}@media(max-width:640px){.source-breakdown{padding:var(--spacing-sm)}.source-breakdown__row{grid-template-columns:1fr auto;grid-template-areas:"label count" "bar pct" "note note";row-gap:4px}.source-breakdown__label{grid-area:label}.source-breakdown__count{grid-area:count;text-align:right}.source-breakdown__bar-track{grid-area:bar;height:8px}.source-breakdown__pct{grid-area:pct;min-width:3em}.source-breakdown__note{grid-area:note;font-size:.7rem}.source-breakdown__title{font-size:var(--font-size-sm)}}.result-page{max-width:800px;margin:0 auto}.score-section{text-align:center;padding:var(--spacing-xl);margin-bottom:var(--spacing-lg)}.score-icon{margin-bottom:var(--spacing-md)}.score-icon .material-icons{font-size:64px}.score-value{font-size:72px;font-weight:700;line-height:1;margin:0}.score-label{font-size:var(--font-size-xl);color:var(--color-text-secondary);margin:var(--spacing-xs) 0}.score-comment{font-size:var(--font-size-lg);font-weight:500;margin-top:var(--spacing-sm)}.score-section.excellent{background:linear-gradient(135deg,#fff8e1,#fffde7)}.score-section.excellent .score-icon .material-icons{color:#ffc107}.score-section.excellent .score-value,.score-section.excellent .score-comment{color:#f57c00}.score-section.good{background:linear-gradient(135deg,#e8f5e9,#f1f8e9)}.score-section.good .score-icon .material-icons,.score-section.good .score-value,.score-section.good .score-comment{color:var(--color-success)}.score-section.pass{background:linear-gradient(135deg,#e3f2fd,#e8eaf6)}.score-section.pass .score-icon .material-icons,.score-section.pass .score-value,.score-section.pass .score-comment{color:var(--color-info)}.score-section.fail{background:linear-gradient(135deg,#ffebee,#fce4ec)}.score-section.fail .score-icon .material-icons,.score-section.fail .score-value,.score-section.fail .score-comment{color:var(--color-error)}.stats-section{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.stat-item{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-md);background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-1)}.stat-item .material-icons{font-size:32px;margin-bottom:var(--spacing-xs)}.stat-item .stat-value{font-size:var(--font-size-xl);font-weight:700}.stat-item .stat-label{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.stat-item.correct .material-icons,.stat-item.correct .stat-value{color:var(--color-success)}.stat-item.wrong .material-icons,.stat-item.wrong .stat-value{color:var(--color-error)}.stat-item.total .material-icons{color:var(--color-info)}.stat-item.time .material-icons{color:var(--color-warning)}.ai-disclaimer{background:var(--color-surface-variant);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--spacing-md);margin-bottom:var(--spacing-md);font-size:var(--font-size-sm)}.ai-disclaimer-header{display:flex;align-items:center;gap:var(--spacing-xs);font-weight:600;color:var(--color-info);margin-bottom:var(--spacing-sm)}.ai-disclaimer-header .material-icons{font-size:20px}.ai-disclaimer-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--spacing-xs)}.ai-disclaimer-list li{display:flex;align-items:flex-start;gap:var(--spacing-xs);color:var(--color-text-secondary);line-height:1.5}.ai-disclaimer-list li .material-icons{font-size:16px;margin-top:2px;flex-shrink:0}.ai-disclaimer-list li .material-icons.sm{color:var(--color-text-muted)}.weak-section{margin-bottom:var(--spacing-lg)}.weak-section h2{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-lg);color:var(--color-warning);margin-bottom:var(--spacing-xs)}.weak-section__hint{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.weak-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--spacing-xs)}.weak-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--color-surface-variant);border-radius:var(--radius-sm);border-left:3px solid var(--color-warning)}.weak-rank{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);min-width:28px}.weak-stem{flex:1;font-size:var(--font-size-sm);margin:0;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.weak-rate{font-size:var(--font-size-sm);font-weight:600;color:var(--color-error);white-space:nowrap}.weak-rate__count{margin-left:4px;font-weight:400;font-size:var(--font-size-xs);color:var(--color-text-secondary)}.wrong-section{margin-bottom:var(--spacing-lg)}.wrong-section h2{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-lg);color:var(--color-error);margin-bottom:var(--spacing-md)}.wrong-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.wrong-item{display:flex;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-surface-variant);border-radius:var(--radius-sm);border-left:4px solid var(--color-error)}.wrong-number{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);min-width:40px}.wrong-content{flex:1}.wrong-stem-row{display:flex;align-items:flex-start;gap:var(--spacing-sm)}.wrong-stem{flex:1;font-size:var(--font-size-sm);margin-bottom:var(--spacing-sm);line-height:1.6}.wrong-feedback-link.question-feedback-link{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;flex-shrink:0;border-radius:var(--radius-sm);color:var(--color-text-secondary);text-decoration:none;transition:background-color var(--transition-fast),color var(--transition-fast)}.wrong-feedback-link.question-feedback-link:hover{background:var(--color-divider);color:var(--color-text-primary)}.wrong-feedback-link.question-feedback-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.wrong-answers{display:flex;gap:var(--spacing-lg);font-size:var(--font-size-sm)}.text-error{color:var(--color-error)}.text-success{color:var(--color-success)}.action-section{display:flex;justify-content:center;gap:var(--spacing-md);flex-wrap:wrap}.wrong-ai-section{margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px dashed var(--color-divider)}.ai-buttons{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;margin-bottom:var(--spacing-sm)}.btn-small{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:4px 12px;font-size:var(--font-size-xs);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.btn-small.btn-ai:hover{background:var(--color-primary);color:var(--color-on-primary);border-color:var(--color-primary)}.btn-small.btn-generate{border-color:var(--accent-50);color:var(--accent-50)}.btn-small.btn-generate:hover{background:var(--accent-50);color:#fff;border-color:var(--accent-50)}.ai-loading-inline{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--color-text-secondary)}.ai-loading-inline .rotating{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ai-response-inline{margin-top:var(--spacing-xs);padding:var(--spacing-sm);background:var(--color-surface);border-radius:var(--radius-sm);border:1px solid var(--color-primary)}.ai-response-inline .ai-content{font-size:var(--font-size-sm);line-height:1.7}.ai-response-inline .ai-content p{margin-bottom:var(--spacing-xs)}.ai-response-inline .ai-content p:last-child{margin-bottom:0}.ai-response-inline .ai-content p:empty{display:none}.ai-response-inline.error{border-color:var(--color-error)}.ai-response-inline .ai-error{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-error)}.ai-response-header-inline{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);font-weight:500;color:var(--color-primary);margin-bottom:var(--spacing-xs)}.ai-response-header-inline .material-icons{font-size:16px}.confidence-inline{margin-left:auto;font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:400}.confidence-warning{margin-left:auto;font-size:var(--font-size-xs);color:var(--color-warning)}.ai-response-inline.generated{border-color:var(--accent-50)}.ai-response-inline.generated .ai-response-header-inline{color:var(--accent-50)}.generated-content{background:var(--color-surface-variant);padding:var(--spacing-sm);border-radius:var(--radius-sm);margin-top:var(--spacing-xs)}.ai-response-inline.streaming{border-style:dashed;opacity:.9}.ai-response-inline.streaming .ai-content{min-height:60px}.btn-small.btn-bank{border-color:var(--color-info);color:var(--color-info)}.btn-small.btn-bank:hover{background:var(--color-info);color:#fff;border-color:var(--color-info)}.bank-similar-section{margin-top:var(--spacing-sm);padding:var(--spacing-sm);background:var(--color-surface);border-radius:var(--radius-sm);border:1px solid var(--color-info)}.bank-similar-header{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);font-weight:500;color:var(--color-info);margin-bottom:var(--spacing-sm)}.bank-similar-header .material-icons{font-size:16px}.bank-similar-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.bank-similar-item{display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--color-surface-variant);border-radius:var(--radius-sm)}.similar-index{font-size:var(--font-size-sm);font-weight:600;color:var(--color-info);min-width:24px}.similar-content{flex:1}.similar-stem{font-size:var(--font-size-sm);line-height:1.5;margin:0 0 var(--spacing-xs) 0}.similar-meta{display:flex;gap:var(--spacing-md);font-size:var(--font-size-xs)}.similar-subject{color:var(--color-text-secondary);background:var(--color-surface);padding:2px 8px;border-radius:var(--radius-sm)}.similar-answer{color:var(--color-success);font-weight:500}.no-similar{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:center;padding:var(--spacing-md)}@media(max-width:768px){.stats-section{grid-template-columns:repeat(2,1fr)}.score-value{font-size:56px}.wrong-answers{flex-direction:column;gap:var(--spacing-xs)}.action-section{flex-direction:column}.action-section .btn{width:100%}}@media(max-width:640px){.score-section{padding:var(--spacing-lg)}.score-icon .material-icons,.score-value{font-size:48px}.stats-section{grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}.stat-item{padding:var(--spacing-sm)}.stat-item .material-icons{font-size:24px}.wrong-item{padding:var(--spacing-sm);gap:var(--spacing-sm)}.wrong-answers{flex-direction:column;gap:.25rem}.ai-buttons{gap:var(--spacing-xs)}.btn-small{padding:6px 10px}.action-section{flex-direction:column;gap:var(--spacing-sm)}.action-section .btn{width:100%}}.settings-page{max-width:600px;margin:0 auto}.settings-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg)}.settings-header h1{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-2xl);margin:0}.settings-back-btn{display:inline-flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);white-space:nowrap}.settings-section{margin-bottom:var(--spacing-lg)}.settings-section h2{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-md);color:var(--color-text-primary)}.setting-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) 0;border-bottom:1px solid var(--color-divider)}.setting-item:last-child{border-bottom:none}.setting-info{display:flex;align-items:flex-start;gap:var(--spacing-md)}.setting-info .material-icons{color:var(--color-primary);margin-top:2px}.setting-title{font-weight:500;margin:0 0 var(--spacing-xs)}.setting-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.toggle-switch{position:relative;display:inline-block;width:52px;height:28px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--neutral-70);border-radius:var(--radius-full);transition:background-color var(--transition-fast)}.toggle-slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;bottom:3px;background-color:#fff;border-radius:var(--radius-full);transition:transform var(--transition-fast);box-shadow:var(--shadow-1)}.toggle-switch input:checked+.toggle-slider{background-color:var(--color-primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.toggle-switch input:focus-visible+.toggle-slider{outline:2px solid var(--color-primary);outline-offset:2px}.setting-item select{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);font-size:var(--font-size-sm);min-width:150px}.about-section p{margin:var(--spacing-xs) 0;font-size:var(--font-size-sm)}.about-section .disclaimer{color:var(--color-text-secondary);font-style:italic;margin-top:var(--spacing-md)}.about-links{display:flex;gap:var(--spacing-lg);margin-top:var(--spacing-md)}.about-links a{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm)}@media(max-width:640px){.settings-page{padding:0 var(--spacing-sm)}.settings-page h1{font-size:var(--font-size-2xl)}.settings-page h2{font-size:var(--font-size-lg)}.setting-item{padding:var(--spacing-sm) 0}.setting-item select,.setting-item input[type=number]{width:100%}.settings-header{flex-wrap:wrap;gap:var(--spacing-sm)}.settings-back-btn{width:100%;justify-content:center}}@media(max-width:480px){.setting-item{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.setting-item select,.toggle-switch{align-self:flex-end}}.settings-confirm-dialog-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(--spacing-md)}.settings-confirm-dialog{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--spacing-lg);max-width:480px;width:100%;box-shadow:var(--shadow-2)}.settings-confirm-dialog h2{font-size:var(--font-size-lg);font-weight:600;margin:0 0 var(--spacing-sm);color:var(--color-text-primary)}.settings-confirm-dialog p{margin:0 0 var(--spacing-lg);color:var(--color-text-secondary);line-height:1.6}.settings-confirm-dialog__actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm)}@media(max-width:640px){.settings-confirm-dialog__actions{flex-direction:column-reverse}.settings-confirm-dialog__actions .btn{width:100%}}.app-header{background:var(--color-surface);border-bottom:1px solid var(--color-divider);position:sticky;top:0;z-index:100;box-shadow:var(--shadow-1)}.header-container{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;padding:var(--spacing-sm) var(--spacing-md)}.header-logo{display:flex;align-items:center;gap:var(--spacing-sm);background:none;border:none;cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);transition:background-color var(--transition-fast)}.header-logo:hover{background:#2e7d3214}.header-logo .material-icons{color:var(--color-primary)}.logo-text{display:flex;flex-direction:column;align-items:flex-start}.logo-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary);line-height:1.2}.logo-subtitle{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.header-actions{display:flex;align-items:center;gap:var(--spacing-xs)}.icon-btn{width:40px;height:40px;padding:0;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.icon-btn svg{width:24px;height:24px}@media(max-width:640px){.header-container{padding:var(--spacing-xs) var(--spacing-sm);min-height:56px}.logo-subtitle{display:none}.logo-title{font-size:var(--font-size-base)}.header-actions{gap:0}.icon-btn{width:44px;height:44px}}@media(max-width:480px){.logo-text{display:none}}.visitor-counter{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-surface-variant);border-radius:var(--radius-full);font-size:var(--font-size-xs);color:var(--color-text-secondary)}.visitor-counter .count{font-weight:600;color:var(--color-text-primary)}.visitor-counter .label{color:var(--color-text-secondary)}.visitor-counter.loading{opacity:.7}.visitor-counter .counter-icon{font-size:1em}.visitor-counter.fallback{opacity:.8}.error-boundary{max-width:720px;margin:var(--spacing-xl) auto;padding:var(--spacing-lg);background:var(--color-error-bg);border-left:4px solid var(--color-error)}.error-boundary__header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.error-boundary__icon{font-size:32px;color:var(--color-error)}.error-boundary__title{font-size:var(--font-size-xl);font-weight:600;margin:0;color:var(--color-text-primary)}.error-boundary__message{font-size:var(--font-size-base);line-height:1.6;color:var(--color-text-secondary);margin:0 0 var(--spacing-md)}.error-boundary__message a{color:var(--color-primary);text-decoration:underline}.error-boundary__actions{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);flex-wrap:wrap}.error-boundary__details{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm)}.error-boundary__details-summary{cursor:pointer;font-weight:500;color:var(--color-text-secondary);padding:var(--spacing-xs) 0}.error-boundary__stack{margin:var(--spacing-sm) 0 0;white-space:pre-wrap;word-break:break-word;font-family:ui-monospace,SF Mono,Menlo,Monaco,Consolas,monospace;font-size:var(--font-size-xs);line-height:1.5;color:var(--color-text-secondary);max-height:320px;overflow:auto}@media(max-width:640px){.error-boundary{margin:var(--spacing-md);padding:var(--spacing-md)}.error-boundary__actions .btn{width:100%}}.app{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1;padding:var(--spacing-lg) var(--spacing-md);max-width:1200px;width:100%;margin:0 auto}.app-footer{background:var(--color-surface);border-top:1px solid var(--color-divider);padding:var(--spacing-lg) var(--spacing-md);text-align:center;margin-top:auto}.app-footer .footer-links{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:var(--spacing-sm)}.app-footer .footer-links a{display:inline-flex;align-items:center;gap:var(--spacing-xs)}.app-footer .footer-links .divider{color:var(--color-text-secondary)}.app-footer .copyright{margin-top:var(--spacing-sm);font-size:var(--font-size-xs);color:var(--color-text-secondary)}@media(max-width:768px){.main-content{padding:var(--spacing-md) var(--spacing-sm)}}:root{--primary-10: #002204;--primary-20: #003a0a;--primary-30: #005313;--primary-40: #006d1d;--primary-50: #2e7d32;--primary-60: #4caf50;--primary-70: #81c784;--primary-80: #a5d6a7;--primary-90: #c8e6c9;--primary-95: #e8f5e9;--color-primary: var(--primary-50);--color-primary-dark: var(--primary-40);--color-primary-light: var(--primary-70);--color-on-primary: #ffffff;--secondary-50: #1976d2;--secondary-60: #2196f3;--secondary-80: #90caf9;--accent-50: #ff9800;--accent-60: #ffb74d;--color-success: #4caf50;--color-success-bg: rgba(76, 175, 80, .12);--color-warning: #ff9800;--color-warning-bg: rgba(255, 152, 0, .12);--color-error: #f44336;--color-error-bg: rgba(244, 67, 54, .12);--color-info: #2196f3;--color-info-bg: rgba(33, 150, 243, .12);--neutral-0: #000000;--neutral-10: #1c1b1f;--neutral-20: #313033;--neutral-30: #484649;--neutral-40: #605d62;--neutral-50: #79767a;--neutral-60: #938f94;--neutral-70: #aeaaae;--neutral-80: #c9c5ca;--neutral-90: #e6e1e5;--neutral-95: #f4eff4;--neutral-100: #ffffff;--color-background: #f5f7fa;--color-surface: #ffffff;--color-surface-variant: #f4eff4;--color-text-primary: rgba(0, 0, 0, .87);--color-text-secondary: rgba(0, 0, 0, .6);--color-text-disabled: rgba(0, 0, 0, .38);--color-text-on-dark: #ffffff;--color-divider: rgba(0, 0, 0, .12);--color-border: rgba(0, 0, 0, .12);--shadow-1: 0 1px 3px rgba(0, 0, 0, .12), 0 1px 2px rgba(0, 0, 0, .24);--shadow-2: 0 3px 6px rgba(0, 0, 0, .15), 0 2px 4px rgba(0, 0, 0, .12);--shadow-3: 0 10px 20px rgba(0, 0, 0, .15), 0 3px 6px rgba(0, 0, 0, .1);--shadow-4: 0 15px 25px rgba(0, 0, 0, .15), 0 5px 10px rgba(0, 0, 0, .05);--radius-xs: 4px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-xxl: 48px;--font-family: "Noto Sans TC", "Roboto", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: 12px;--font-size-sm: 14px;--font-size-base: 16px;--font-size-lg: 18px;--font-size-xl: 20px;--font-size-2xl: 24px;--font-size-3xl: 32px;--transition-fast: .15s;--transition-normal: .25s;--transition-slow: .4s;--easing-standard: cubic-bezier(.4, 0, .2, 1);--easing-decelerate: cubic-bezier(0, 0, .2, 1);--easing-accelerate: cubic-bezier(.4, 0, 1, 1)}[data-theme=dark]{--color-primary: var(--primary-70);--color-primary-dark: var(--primary-60);--color-primary-light: var(--primary-80);--color-on-primary: var(--neutral-10);--color-background: #121212;--color-surface: #1e1e1e;--color-surface-variant: #2d2d2d;--color-text-primary: rgba(255, 255, 255, .87);--color-text-secondary: rgba(255, 255, 255, .6);--color-text-disabled: rgba(255, 255, 255, .38);--color-divider: rgba(255, 255, 255, .12);--color-border: rgba(255, 255, 255, .12);--shadow-1: 0 1px 3px rgba(0, 0, 0, .4), 0 1px 2px rgba(0, 0, 0, .5);--shadow-2: 0 3px 6px rgba(0, 0, 0, .4), 0 2px 4px rgba(0, 0, 0, .3)}[data-high-contrast=true]{--color-text-primary: #000000;--color-text-secondary: #000000;--color-background: #ffffff;--color-surface: #ffffff;--color-border: #000000;--color-divider: #000000}[data-theme=dark][data-high-contrast=true]{--color-text-primary: #ffffff;--color-text-secondary: #ffffff;--color-background: #000000;--color-surface: #000000;--color-border: #ffffff;--color-divider: #ffffff}[data-cvd-mode=protanopia]{--color-success: #1976d2;--color-success-bg: rgba(25, 118, 210, .12);--color-error: #e65100;--color-error-bg: rgba(230, 81, 0, .12)}[data-cvd-mode=deuteranopia]{--color-success: #0288d1;--color-success-bg: rgba(2, 136, 209, .12);--color-error: #d84315;--color-error-bg: rgba(216, 67, 21, .12)}[data-cvd-mode=tritanopia]{--color-success: #00897b;--color-success-bg: rgba(0, 137, 123, .12);--color-error: #c62828;--color-error-bg: rgba(198, 40, 40, .12)}[data-font-size=large]{--font-size-xs: 14px;--font-size-sm: 16px;--font-size-base: 18px;--font-size-lg: 20px;--font-size-xl: 24px;--font-size-2xl: 28px;--font-size-3xl: 36px}[data-font-size=xlarge]{--font-size-xs: 16px;--font-size-sm: 18px;--font-size-base: 20px;--font-size-lg: 24px;--font-size-xl: 28px;--font-size-2xl: 32px;--font-size-3xl: 40px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.6;color:var(--color-text-primary);background-color:var(--color-background);min-height:100vh;transition:background-color var(--transition-normal) var(--easing-standard),color var(--transition-normal) var(--easing-standard)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast) var(--easing-standard)}a:hover{color:var(--color-primary-dark);text-decoration:underline}a:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none}button:disabled{cursor:not-allowed;opacity:.5}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.skip-link{position:absolute;top:-100%;left:0;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-primary);color:var(--color-on-primary);z-index:9999;transition:top var(--transition-fast)}.skip-link:focus{top:0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-surface-variant);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb{background:var(--neutral-60);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--neutral-50)}[data-theme=dark] ::-webkit-scrollbar-thumb{background:var(--neutral-50)}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:var(--neutral-60)}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.card{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-1);padding:var(--spacing-lg);transition:box-shadow var(--transition-normal) var(--easing-standard),transform var(--transition-normal) var(--easing-standard)}.card:hover{box-shadow:var(--shadow-2)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-full);font-weight:500;font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.5px;transition:all var(--transition-fast) var(--easing-standard);min-height:40px}.btn-primary{background:var(--color-primary);color:var(--color-on-primary)}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark);box-shadow:var(--shadow-2)}.btn-secondary{background:transparent;color:var(--color-primary);border:1px solid var(--color-primary)}.btn-secondary:hover:not(:disabled){background:#2e7d3214}.btn-text{background:transparent;color:var(--color-primary);padding:var(--spacing-sm)}.btn-text:hover:not(:disabled){background:#2e7d3214}.material-icons{font-size:24px;vertical-align:middle}.material-icons.sm{font-size:18px}.material-icons.lg{font-size:36px}.progress-bar{width:100%;height:8px;background:var(--color-surface-variant);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;background:var(--color-primary);border-radius:var(--radius-full);transition:width var(--transition-normal) var(--easing-standard)}.badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:500}.badge-success{background:var(--color-success-bg);color:var(--color-success)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning)}.badge-error{background:var(--color-error-bg);color:var(--color-error)}.badge-info{background:var(--color-info-bg);color:var(--color-info)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fade-in{animation:fadeIn var(--transition-normal) var(--easing-standard)}.animate-slide-up{animation:slideUp var(--transition-normal) var(--easing-standard)}@media(max-width:768px){.container{padding:0 var(--spacing-sm)}.card{padding:var(--spacing-md)}}@media(max-width:640px){button,.btn,[role=button],a.btn{min-height:44px}.card{padding:var(--spacing-md) var(--spacing-sm)}input[type=text],input[type=number],input[type=email],select,textarea{font-size:max(16px,var(--font-size-base))}}
