.app-shell{min-height:100vh;display:flex;flex-direction:column;max-width:720px;margin:0 auto;padding:2rem 1.25rem 2.5rem}.app-shell--auth{max-width:440px;padding:1.5rem 1.25rem 2.5rem}.app-shell--auth .app-main{display:flex;flex-direction:column;justify-content:center;flex:1;min-height:0}.app-main{flex:1}.app-topbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem 1rem;padding-bottom:1.25rem;margin-bottom:.25rem;border-bottom:1px solid var(--border)}.app-topbar__brand{font-weight:700;font-size:.95rem;letter-spacing:-.02em;color:var(--text);text-decoration:none;line-height:1.3;max-width:min(200px,55vw)}.app-topbar__brand:hover{color:var(--accent)}.app-topbar__nav{display:flex;align-items:center;gap:.5rem;order:3;width:100%;justify-content:flex-start}@media (min-width: 520px){.app-topbar__nav{order:0;width:auto;flex:1;justify-content:center}}.app-topbar__nav-link{font-size:.9rem;font-weight:600;color:var(--muted);text-decoration:none;padding:.35rem .65rem;border-radius:8px;transition:color .15s,background .15s}.app-topbar__nav-link:hover{color:var(--text);background:var(--surface2)}.app-topbar__user{display:flex;align-items:center;gap:.65rem;min-width:0;margin-left:auto}@media (min-width: 520px){.app-topbar__user{margin-left:0}}.app-topbar__email{font-size:.8rem;color:var(--muted);max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (min-width: 520px){.app-topbar__email{max-width:200px}}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text);font-size:.85rem;font-weight:600;padding:.4rem .75rem;border-radius:8px;cursor:pointer;transition:border-color .15s,background .15s,color .15s}.btn-ghost:hover{border-color:var(--accent);color:var(--accent);background:#5b9fd414}.home-page{width:100%}.home-hero{margin-bottom:2rem}.home-hero__eyebrow{margin:0 0 .5rem;font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.home-hero__title{margin:0 0 .75rem;font-size:clamp(1.85rem,5vw,2.35rem);font-weight:700;letter-spacing:-.03em;line-height:1.15;color:var(--text)}.home-hero__lead{margin:0;font-size:1.05rem;line-height:1.55;color:var(--muted);max-width:42ch}.home-panel{background:var(--surface);border:1px solid var(--border);border-radius:calc(var(--radius) + 4px);padding:1.75rem 1.5rem;box-shadow:0 12px 30px -22px #12213d38}.home-panel__head{margin-bottom:1.5rem}.home-panel__title{margin:0 0 .5rem;font-size:1.15rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.home-panel__desc{margin:0;font-size:.9rem;line-height:1.5;color:var(--muted);max-width:48ch}.home-topic-form{gap:1.125rem;padding:0;background:transparent;border:none;border-radius:0}.home-topic-form .topic-label{font-size:.875rem}.home-topic-form .topic-input{border-radius:10px;padding:.75rem 1rem}.home-topic-form .topic-hint{font-size:.85rem}.home-topic-form .btn.primary{width:100%;margin-top:.25rem;padding:.8rem 1.25rem;font-size:1rem;border-radius:10px}.home-topic-form .form-error{padding:.65rem .85rem;border-radius:10px;background:#f871711a;border:1px solid rgba(248,113,113,.25)}.auth-page{width:100%}.auth-card{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:calc(var(--radius) + 4px);padding:2rem 1.75rem;box-shadow:0 12px 30px -22px #12213d3d}.auth-card__header{margin-bottom:1.75rem;text-align:center}.auth-eyebrow{margin:0 0 .5rem;font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.auth-title{margin:0 0 .5rem;font-size:clamp(1.5rem,4vw,1.75rem);font-weight:700;letter-spacing:-.03em;color:var(--text);line-height:1.2}.auth-subtitle{font-size:.95rem;line-height:1.5;color:var(--muted);max-width:32ch;margin:0 auto}.auth-form{display:flex;flex-direction:column;gap:1.125rem}.auth-field{display:flex;flex-direction:column;gap:.4rem}.auth-label{font-size:.875rem;font-weight:600;color:var(--text)}.auth-input{width:100%;padding:.7rem .9rem;border-radius:10px;border:1px solid var(--border);background:var(--surface2);color:var(--text);font-size:1rem;line-height:1.4;transition:border-color .15s ease,box-shadow .15s ease}.auth-input::placeholder{color:var(--muted);opacity:.75}.auth-input:hover:not(:disabled){border-color:#3a4a62}.auth-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #5b9fd438}.auth-input:disabled{opacity:.65;cursor:not-allowed}.auth-hint{margin:0;font-size:.8rem;color:var(--muted);line-height:1.4}.auth-error{margin:0;padding:.65rem .85rem;font-size:.875rem;line-height:1.45;color:var(--danger);background:#f871711a;border:1px solid rgba(248,113,113,.25);border-radius:10px}.auth-submit{width:100%;margin-top:.25rem;padding:.8rem 1.25rem;font-size:1rem;border-radius:10px}.auth-footer{margin:1.5rem 0 0;padding-top:1.25rem;border-top:1px solid var(--border);text-align:center;font-size:.9rem;color:var(--muted)}.auth-footer-link{font-weight:600;color:var(--accent);text-decoration:none}.auth-footer-link:hover{text-decoration:underline}@media (max-width: 380px){.auth-card{padding:1.5rem 1.25rem}}.page{animation:fade .35s ease}@keyframes fade{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.page-header{margin-bottom:2rem}.title{font-size:clamp(1.75rem,5vw,2.25rem);font-weight:700;letter-spacing:-.02em;margin:0 0 .5rem;background:linear-gradient(135deg,var(--text) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{color:var(--muted);margin:0 0 1rem;max-width:36ch}.nav-links{margin-top:.75rem}.topic-form{display:flex;flex-direction:column;gap:1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}.topic-label{font-weight:600}.topic-input{width:100%;padding:.85rem 1rem;border-radius:8px;border:1px solid var(--border);background:var(--surface2);color:var(--text);font-size:1rem}.topic-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #5b9fd433}.topic-input:disabled{opacity:.6}.topic-hint{font-size:.9rem;color:var(--muted);margin:0}.linkish{background:none;border:none;color:var(--accent);padding:0;font-size:inherit;text-decoration:underline;cursor:pointer}.linkish:disabled{opacity:.5;cursor:not-allowed}.form-error{color:var(--danger);margin:0;font-size:.95rem}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.25rem;border-radius:8px;font-weight:600;font-size:.95rem;border:none;text-decoration:none;transition:background .15s,transform .1s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{background:var(--accent);color:var(--bg)}.btn.primary:hover:not(:disabled){background:var(--accent-dim)}.btn.secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn.secondary:hover:not(:disabled){border-color:var(--accent)}.btn.small{padding:.45rem .85rem;font-size:.85rem}.back-link{display:inline-block;margin-bottom:1rem;color:var(--muted)}.back-link:hover{color:var(--accent)}.quiz-page__back{display:inline-flex;align-items:center;font-size:.9rem;font-weight:600;color:var(--muted);text-decoration:none;margin-bottom:1rem;transition:color .15s}.quiz-page__back:hover{color:var(--accent)}.quiz-page__header{margin-bottom:1.75rem}.quiz-page__headline{margin-top:.25rem}.quiz-page__topic{margin:0 0 .5rem;font-size:.8rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--accent);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.quiz-page__title{margin:0 0 .5rem;font-size:clamp(1.5rem,4vw,1.85rem);font-weight:700;letter-spacing:-.03em;color:var(--text);line-height:1.2}.quiz-page__lead{margin:0;font-size:.95rem;line-height:1.55;color:var(--muted);max-width:48ch}.quiz-page--state{max-width:36ch}.quiz-page__state-msg{margin:.5rem 0 0}.quiz-page__error{margin-top:1rem}.quiz-questions{display:flex;flex-direction:column;gap:1.25rem}.quiz-questions__item{scroll-margin-top:1rem}.question-card{background:var(--surface);border:1px solid var(--border);border-radius:calc(var(--radius) + 2px);padding:1.35rem 1.25rem;margin:0;box-shadow:0 10px 24px -18px #12213d2e;transition:border-color .15s,box-shadow .15s}.question-card--answered{border-color:#4ade8059;box-shadow:0 10px 24px -18px #12213d26,0 0 0 1px #4ade801f}.question-card__head{margin-bottom:1rem}.badge{font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:600}.question-text{font-size:1.08rem;font-weight:600;margin:0 0 1.1rem;line-height:1.45}@media (min-width: 480px){.question-text{font-size:1.12rem}}.options-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.65rem}.option-row{display:grid;grid-template-columns:auto 1fr;gap:.65rem .9rem;align-items:start;padding:.75rem .95rem;border-radius:10px;border:1px solid var(--border);background:var(--surface2);cursor:pointer;transition:border-color .15s,background .15s}.option-row:has(input:checked),.option-row.selected{border-color:var(--accent);background:#5b9fd414}.option-row input{grid-row:1 / 3;margin-top:.2rem;accent-color:var(--accent)}.option-label{font-weight:700;color:var(--accent)}.option-text{grid-column:2;color:var(--text)}.quiz-submit-bar{position:sticky;bottom:0;z-index:20;margin-top:2rem;padding-bottom:.25rem}.quiz-submit-bar__inner{display:flex;flex-direction:column;gap:1rem;padding:1.15rem 1.25rem;border:1px solid var(--border);border-radius:calc(var(--radius) + 4px);background:#fffffff0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 -6px 24px #12213d1f}@media (min-width: 520px){.quiz-submit-bar__inner{flex-direction:row;align-items:center;justify-content:space-between;gap:1.25rem}}.quiz-submit-bar__meta{display:flex;flex-direction:column;gap:.25rem;min-width:0}.quiz-progress{font-size:.95rem;color:var(--text)}.quiz-progress strong{font-variant-numeric:tabular-nums;color:var(--accent)}.quiz-progress__sep{color:var(--muted);font-weight:500}.quiz-progress__hint{font-size:.8rem;line-height:1.35}.quiz-progress__hint--ok{color:var(--success);font-weight:600}.quiz-submit-bar__btn{width:100%;min-height:2.75rem;font-size:1rem;border-radius:10px;padding-left:1.5rem;padding-right:1.5rem}@media (min-width: 520px){.quiz-submit-bar__btn{width:auto;min-width:11rem}}.result-page__back{display:inline-flex;align-items:center;font-size:.9rem;font-weight:600;color:var(--muted);text-decoration:none;margin-bottom:1rem;transition:color .15s}.result-page__back:hover{color:var(--accent)}.result-page__header{margin-bottom:1.5rem}.result-page__topic{margin:0 0 .5rem;font-size:.8rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--accent);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.result-page__title{margin:0 0 .5rem;font-size:clamp(1.5rem,4vw,1.85rem);font-weight:700;letter-spacing:-.03em;color:var(--text);line-height:1.2}.result-page__lead{margin:0;font-size:.95rem;line-height:1.55;color:var(--muted);max-width:48ch}.result-page--state{max-width:36ch}.result-page__state-msg{margin:.5rem 0 0}.result-score-card{text-align:center;padding:1.75rem 1.5rem;margin-bottom:1.5rem;border:1px solid var(--border);border-radius:calc(var(--radius) + 4px);background:var(--surface);box-shadow:0 12px 30px -22px #12213d38}.result-score-card__eyebrow{margin:0 0 .35rem;font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.result-score-card__value{margin:0 0 .5rem;font-size:clamp(2.75rem,8vw,3.75rem);font-weight:800;font-variant-numeric:tabular-nums;line-height:1;letter-spacing:-.03em}.result-score-card__num{color:var(--accent)}.result-score-card__slash{color:var(--muted);margin:0 .1em;font-weight:700}.result-score-card__total{color:var(--text)}.result-score-card__meta{margin:0;font-size:.9rem;color:var(--muted)}.result-score-card__pct{font-weight:700;color:var(--text)}.result-score-card__sep{margin:0 .35rem;opacity:.6}.result-score-card--high .result-score-card__num{color:var(--success)}.result-score-card--low .result-score-card__num{color:var(--danger)}.result-page__actions{display:flex;flex-direction:column;gap:.65rem;margin-bottom:2.25rem}.result-page__actions .btn{min-height:2.75rem;justify-content:center;border-radius:10px;padding-left:1.25rem;padding-right:1.25rem}@media (min-width: 420px){.result-page__actions{flex-direction:row;flex-wrap:wrap;align-items:center}}.result-page__review-head{margin-bottom:1.25rem}.result-page__review-title{margin:0 0 .35rem;font-size:1.1rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.result-page__review-desc{margin:0;font-size:.88rem;line-height:1.5;color:var(--muted);max-width:52ch}.result-page__cards{display:flex;flex-direction:column;gap:1.15rem}.section-title{font-size:1.1rem;margin:0 0 1rem;color:var(--muted)}.result-card{background:var(--surface);border:1px solid var(--border);border-radius:calc(var(--radius) + 2px);padding:1.35rem 1.25rem;margin:0;box-shadow:0 10px 24px -18px #12213d2e}.result-card--correct{border-color:#4ade8059;box-shadow:0 10px 24px -18px #12213d24,0 0 0 1px #4ade801a}.result-card--wrong{border-color:#f8717159;box-shadow:0 10px 24px -18px #12213d24,0 0 0 1px #f871711a}.result-card__top{display:flex;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.85rem}.result-card__q{text-transform:none;letter-spacing:.04em;color:var(--muted)}.tag{font-size:.75rem;font-weight:700;text-transform:uppercase;padding:.2rem .5rem;border-radius:4px}.tag.success{background:#4ade8026;color:var(--success)}.tag.danger{background:#f8717126;color:var(--danger)}.tag.warn{background:#fbbf2426;color:#fbbf24}.result-question{font-size:1.05rem;font-weight:600;margin:0 0 1.1rem;line-height:1.45}.result-answers{display:grid;gap:.85rem;margin-bottom:1.1rem}@media (min-width: 520px){.result-answers{grid-template-columns:1fr 1fr;gap:1rem}}.result-answer-block{padding:.75rem .85rem;border-radius:10px;background:var(--surface2);border:1px solid var(--border)}.result-answer-block__label{display:block;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:.45rem}.result-answer-block__body{display:flex;flex-wrap:wrap;align-items:baseline;gap:.45rem .65rem;font-size:.92rem;line-height:1.45}.result-option-pill{display:inline-flex;align-items:center;justify-content:center;min-width:1.75rem;height:1.75rem;padding:0 .4rem;font-size:.8rem;font-weight:700;border-radius:8px;background:#5b9fd426;color:var(--accent);border:1px solid rgba(91,159,212,.35)}.result-option-pill--correct{background:#4ade801f;color:var(--success);border-color:#4ade8059}.result-option-text{flex:1;min-width:0;color:var(--text)}.muted{color:var(--muted)}.explanation-box{background:var(--surface2);border-radius:10px;padding:1rem 1.05rem;font-size:.92rem;border:1px solid var(--border)}.explanation-box strong{color:var(--accent);display:block;margin-bottom:.4rem;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.explanation-box p{margin:0;color:var(--text);line-height:1.5}.history-list{list-style:none;margin:0;padding:0}.history-row{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.75rem}.history-topic{display:block;margin-bottom:.25rem}.history-date{font-size:.8rem}.history-side{display:flex;align-items:center;gap:.75rem}.score-pill{background:var(--surface2);padding:.35rem .65rem;border-radius:6px;border:1px solid var(--border);font-size:.9rem}:root{--bg: #f5f7fb;--surface: #ffffff;--surface2: #f3f6fc;--border: #d9e1ef;--text: #152238;--muted: #5e6f8a;--accent: #2f6fed;--accent-dim: #2458bd;--success: #1f9d55;--danger: #d14343;--radius: 12px;font-family:DM Sans,system-ui,sans-serif;line-height:1.5;color:var(--text);background:var(--bg)}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(ellipse 120% 80% at 50% -20%,#edf3ff 0%,var(--bg) 55%)}#root{min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer}input,textarea{font-family:inherit}.mono{font-family:JetBrains Mono,monospace}
