:root{--color-bg:#f5f7fa;--color-surface:#fff;--color-text:#15202b;--color-muted:#5c6b7a;--color-border:#d6dde4;--color-primary:#0b6cf2;--color-primary-hover:#0857c4;--color-primary-text:#fff;--color-correct:#1f7a3a;--color-correct-bg:#e6f6ec;--color-incorrect:#b3261e;--color-incorrect-bg:#fdecea;--color-selected-bg:#e3eeff;--color-selected-border:#0b6cf2;--radius-md:12px;--radius-lg:16px;--shadow-sm:0 1px 2px #0f172a0f;--shadow-md:0 4px 12px #0f172a14;color:var(--color-text);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;font-family:-apple-system,BlinkMacSystemFont,Hiragino Sans,Noto Sans JP,Yu Gothic,Meiryo,system-ui,sans-serif;line-height:1.6}*{box-sizing:border-box}html,body{background-color:var(--color-bg);min-height:100dvh;margin:0;padding:0}body{font-size:16px}#root{flex-direction:column;min-height:100dvh;display:flex}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit;font-size:16px}button:disabled{cursor:not-allowed}a{color:var(--color-primary);text-decoration:none}h1,h2,h3{margin:0;font-weight:700;line-height:1.4}p{margin:0}.app-shell{flex-direction:column;flex:1;gap:16px;width:100%;max-width:720px;margin:0 auto;padding:16px;display:flex}.app-header{padding:8px 4px 0}.app-header__title{color:var(--color-muted);letter-spacing:.04em;font-size:18px;font-weight:600}.home{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:stretch;gap:24px;padding:16px 4px;display:flex}.home__hero{flex-direction:column;gap:12px;display:flex}.home__app-name{color:var(--color-text);font-size:28px;font-weight:800}.home__tagline{color:var(--color-muted);font-size:16px}.home__actions{flex-direction:column;align-items:stretch;gap:12px;display:flex}.home__history-link{text-decoration:none}.home__category-picker{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);text-align:left;flex-direction:column;gap:8px;margin:0;padding:16px 12px;display:flex}.home__category-legend{color:var(--color-muted);letter-spacing:.04em;padding:0 4px;font-size:14px;font-weight:700}.home__category-desc{color:var(--color-muted);padding:0 4px 4px;font-size:12px;line-height:1.5}.home__category-options{flex-direction:column;gap:8px;display:flex}.category-radio{border-radius:var(--radius-md);background-color:var(--color-surface);border:2px solid var(--color-border);min-height:48px;color:var(--color-text);cursor:pointer;align-items:center;gap:12px;padding:8px 12px;font-size:15px;transition:background-color 50ms,border-color 50ms;display:flex}.category-radio--checked{background-color:var(--color-selected-bg);border-color:var(--color-selected-border);color:var(--color-text)}.category-radio__input{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute}.category-radio__label{flex:1;font-weight:600}.category-radio__count{color:var(--color-muted);flex-shrink:0;font-size:12px;font-weight:600}.category-radio--checked .category-radio__count{color:var(--color-primary)}.home__error{color:var(--color-incorrect);background-color:var(--color-incorrect-bg);border:1px solid var(--color-incorrect);border-radius:var(--radius-md);text-align:left;padding:12px;font-size:14px;font-weight:600;line-height:1.5}.home__notice{color:var(--color-text);background-color:var(--color-selected-bg);border:1px solid var(--color-selected-border);border-radius:var(--radius-md);text-align:center;padding:12px;font-size:14px;font-weight:700;line-height:1.5}.button-primary{background-color:var(--color-primary);color:var(--color-primary-text);border-radius:var(--radius-lg);width:100%;min-height:56px;box-shadow:var(--shadow-md);justify-content:center;align-items:center;padding:16px 24px;font-size:18px;font-weight:700;transition:background-color 50ms,transform 50ms;display:inline-flex}@media (hover:hover) and (pointer:fine){.button-primary:hover:not(:disabled){background-color:var(--color-primary-hover)}}.button-primary:active:not(:disabled){transform:translateY(1px)}.button-primary:disabled{box-shadow:none;background-color:#9bb4d6}.button-secondary{background-color:var(--color-surface);color:var(--color-primary);border:2px solid var(--color-primary);border-radius:var(--radius-lg);justify-content:center;align-items:center;width:100%;min-height:56px;padding:14px 24px;font-size:16px;font-weight:700;text-decoration:none;transition:background-color 50ms,border-color 50ms;display:inline-flex}.button-secondary:disabled{color:#9bb4d6;cursor:not-allowed;border-color:#d6dde4}@media (hover:hover) and (pointer:fine){.button-secondary:hover:not(:disabled){background-color:var(--color-selected-bg)}}.button-secondary:active:not(:disabled){background-color:var(--color-selected-bg)}.quiz{flex-direction:column;gap:16px;display:flex}.quiz__card{background-color:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);padding:20px 16px}.quiz__question{color:var(--color-text);white-space:pre-wrap;font-size:17px;font-weight:600;line-height:1.7}.choices{flex-direction:column;gap:10px;display:flex}.choice{border-radius:var(--radius-md);background-color:var(--color-surface);border:2px solid var(--color-border);text-align:left;width:100%;min-height:56px;color:var(--color-text);align-items:center;gap:12px;padding:12px 16px;font-size:16px;transition:background-color 50ms,border-color 50ms;display:flex}.choice:active:not(:disabled){background-color:var(--color-selected-bg)}.choice--selected{background-color:var(--color-selected-bg);border-color:var(--color-selected-border)}.choice--correct{background-color:var(--color-correct-bg);border-color:var(--color-correct)}.choice--incorrect{background-color:var(--color-incorrect-bg);border-color:var(--color-incorrect)}.choice__label{background-color:var(--color-bg);border:1px solid var(--color-border);width:28px;height:28px;color:var(--color-muted);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:inline-flex}.choice--selected .choice__label,.choice--correct .choice__label,.choice--incorrect .choice__label{background-color:var(--color-surface);color:inherit;border-color:currentColor}.choice--correct{color:var(--color-correct)}.choice--incorrect{color:var(--color-incorrect)}.choice__text{white-space:pre-wrap;flex:1}.choices__helper{color:var(--color-muted);padding:0 4px 4px;font-size:13px;font-weight:600}.numeric-field{flex-direction:column;gap:8px;display:flex}.numeric-field__label{color:var(--color-muted);letter-spacing:.02em;font-size:14px;font-weight:700}.numeric-field__input-wrapper{background-color:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-md);align-items:center;gap:8px;min-height:56px;padding:8px 12px;transition:border-color .12s;display:flex}.numeric-field__input-wrapper:focus-within{border-color:var(--color-selected-border)}.numeric-field__input{color:var(--color-text);font-variant-numeric:tabular-nums;background:0 0;border:none;outline:none;flex:1;min-width:0;padding:8px 0;font-family:inherit;font-size:18px;font-weight:600}.numeric-field__input:disabled{color:var(--color-muted);cursor:not-allowed}.numeric-field__unit{color:var(--color-muted);flex-shrink:0;font-size:16px;font-weight:600}.result{border-radius:var(--radius-md);border:1px solid var(--color-border);background-color:var(--color-surface);flex-direction:column;gap:12px;padding:16px;display:flex}.result--correct{background-color:var(--color-correct-bg);border-color:var(--color-correct)}.result--incorrect{background-color:var(--color-incorrect-bg);border-color:var(--color-incorrect)}.result__verdict{font-size:22px;font-weight:800}.result--correct .result__verdict{color:var(--color-correct)}.result--incorrect .result__verdict{color:var(--color-incorrect)}.result__correct-answer{color:var(--color-text);font-size:15px}.result__correct-answer strong{font-weight:700}.result__explanation-title{color:var(--color-muted);letter-spacing:.04em;font-size:14px;font-weight:700}.result__explanation-body{color:var(--color-text);white-space:pre-wrap;font-size:15px;line-height:1.7}.back-link{color:var(--color-muted);align-self:flex-start;align-items:center;gap:6px;min-height:44px;padding:8px 4px;font-size:14px;display:inline-flex}.quiz__progress{color:var(--color-muted);letter-spacing:.02em;padding:4px 4px 0;font-size:14px;font-weight:600}.quiz__mode-badge{background-color:var(--color-selected-bg);color:var(--color-primary);border:1px solid var(--color-selected-border);letter-spacing:.04em;border-radius:999px;align-self:flex-start;align-items:center;padding:4px 12px;font-size:12px;font-weight:800;display:inline-flex}.result-page{flex-direction:column;flex:1;gap:20px;padding:16px 4px;display:flex}.result-page__title{color:var(--color-text);text-align:center;outline:none;font-size:24px;font-weight:800}.result-page__lead{color:var(--color-muted);text-align:center;font-size:15px}.result-summary{background-color:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);flex-direction:column;gap:12px;padding:20px 16px;display:flex}.result-summary__row{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.result-summary__label{color:var(--color-muted);font-size:14px;font-weight:600}.result-summary__value{color:var(--color-text);font-variant-numeric:tabular-nums;font-size:22px;font-weight:800}.result-summary__value--accent{color:var(--color-primary);font-size:28px}.result-page__retry{text-decoration:none}.result-page__home-link{align-self:center}.history-page{flex-direction:column;flex:1;gap:16px;padding:4px 4px 16px;display:flex}.history-page__title{color:var(--color-text);text-align:left;outline:none;font-size:24px;font-weight:800}.history-page__lead{color:var(--color-muted);font-size:14px;line-height:1.6}.history-summary{background-color:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);flex-direction:column;gap:12px;padding:20px 16px;display:flex}.history-summary__row{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.history-summary__label{color:var(--color-muted);font-size:14px;font-weight:600}.history-summary__value{color:var(--color-text);font-variant-numeric:tabular-nums;font-size:22px;font-weight:800}.history-summary__value--accent{color:var(--color-primary);font-size:28px}.history-page__reset{margin-top:4px}.history-by-category{background-color:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);flex-direction:column;gap:12px;padding:16px 12px;display:flex}.history-by-category__title{color:var(--color-text);letter-spacing:.02em;padding:0 4px;font-size:16px;font-weight:700}.history-by-category__table{border-collapse:collapse;font-variant-numeric:tabular-nums;width:100%}.history-by-category__table th,.history-by-category__table td{border-bottom:1px solid var(--color-border);padding:8px 6px;font-size:14px}.history-by-category__table thead th{color:var(--color-muted);text-transform:uppercase;letter-spacing:.04em;text-align:right;border-bottom:2px solid var(--color-border);font-size:12px;font-weight:700}.history-by-category__th-cat{text-align:left!important}.history-by-category__cat{text-align:left;color:var(--color-text);font-weight:600}.history-by-category__num{text-align:right;color:var(--color-text);font-weight:600}.history-by-category__num--accent{color:var(--color-primary)}.history-by-category__row:last-child th,.history-by-category__row:last-child td{border-bottom:none}.quiz__empty{background-color:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);text-align:center;flex-direction:column;gap:16px;padding:32px 16px;display:flex}.quiz__empty-title{color:var(--color-text);outline:none;font-size:20px;font-weight:800}.quiz__empty-lead{color:var(--color-muted);font-size:14px;line-height:1.7}.login-page{flex-direction:column;flex:1;justify-content:center;align-items:center;min-height:60vh;padding:24px 16px;display:flex}.login-page__card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:400px;box-shadow:var(--shadow-md);text-align:center;flex-direction:column;gap:20px;padding:32px 24px;display:flex}.login-page__title{color:var(--color-text);font-size:24px;font-weight:800}.login-page__subtitle{color:var(--color-muted);font-size:16px;font-weight:600}.login-form{text-align:left;flex-direction:column;gap:16px;display:flex}.login-form__field{flex-direction:column;gap:6px;display:flex}.login-form__label{color:var(--color-text);font-size:14px;font-weight:700}.login-form__input{border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg);color:var(--color-text);outline:none;min-height:48px;padding:12px 14px;font-family:inherit;font-size:16px;transition:border-color .12s}.login-form__input:focus{border-color:var(--color-primary)}.login-form__error{color:var(--color-incorrect);background-color:var(--color-incorrect-bg);border:1px solid var(--color-incorrect);border-radius:var(--radius-md);text-align:center;padding:10px 12px;font-size:14px;font-weight:600;line-height:1.5}.login-form__submit{margin-top:4px}.home__user-bar{justify-content:flex-end;align-items:center;gap:12px;padding:4px 0;display:flex}.home__user-name{color:var(--color-text);font-size:14px;font-weight:600}.button-logout{color:var(--color-muted);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;background-color:#0000;justify-content:center;align-items:center;min-height:36px;padding:6px 14px;font-family:inherit;font-size:13px;font-weight:600;transition:background-color .1s;display:inline-flex}@media (hover:hover) and (pointer:fine){.button-logout:hover{background-color:var(--color-bg)}}.button-logout:active{background-color:var(--color-bg)}.auth-loading{flex:1;justify-content:center;align-items:center;padding:48px 16px;display:flex}.auth-loading__text{color:var(--color-muted);font-size:16px;font-weight:600}.home__admin-section{border-top:1px solid var(--color-border);flex-direction:column;align-items:stretch;margin-top:8px;padding-top:16px;display:flex}.home__admin-link{text-decoration:none}.admin{flex-direction:column;gap:16px;padding:16px 4px;display:flex}.admin__header{justify-content:space-between;align-items:center;gap:12px;display:flex}.admin__title{color:var(--color-text);font-size:24px;font-weight:800}.admin__back-link-inline{color:var(--color-primary);white-space:nowrap;font-size:14px;font-weight:600;text-decoration:none}.admin__back-link-inline:hover{text-decoration:underline}.admin__section-title{color:var(--color-text);margin-top:4px;font-size:18px;font-weight:700}.admin__loading{color:var(--color-muted);text-align:center;padding:24px;font-size:16px;font-weight:600}.admin__error{color:var(--color-incorrect);background-color:var(--color-incorrect-bg);border:1px solid var(--color-incorrect);border-radius:var(--radius-md);padding:12px;font-size:14px;font-weight:600;line-height:1.5}.admin__forbidden{color:var(--color-incorrect);background-color:var(--color-incorrect-bg);border:1px solid var(--color-incorrect);border-radius:var(--radius-md);text-align:center;padding:16px;font-size:16px;font-weight:700;line-height:1.5}.admin__table-wrap{-webkit-overflow-scrolling:touch;border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface);overflow-x:auto}.admin__table{border-collapse:collapse;width:100%;font-size:14px}.admin__th{text-align:left;color:var(--color-muted);letter-spacing:.04em;border-bottom:2px solid var(--color-border);white-space:nowrap;padding:10px 8px;font-size:12px;font-weight:700}.admin__th--action{text-align:center;width:60px}.admin__row{border-bottom:1px solid var(--color-border)}.admin__row:last-child{border-bottom:none}.admin__td{color:var(--color-text);vertical-align:middle;padding:10px 8px;font-size:14px}.admin__td--date{color:var(--color-muted);white-space:nowrap;font-size:13px}.admin__td--action{text-align:center}.admin__role-badge{white-space:nowrap;border-radius:9999px;padding:2px 8px;font-size:12px;font-weight:700;display:inline-block}.admin__role-badge--admin{color:#92400e;background-color:#fef3c7}.admin__role-badge--user{background-color:var(--color-selected-bg);color:var(--color-primary)}.admin__self-label{color:var(--color-muted);font-size:12px;font-weight:600}.button-danger-sm{color:var(--color-incorrect);border:1px solid var(--color-incorrect);border-radius:var(--radius-md);cursor:pointer;background-color:#0000;justify-content:center;align-items:center;min-height:32px;padding:4px 12px;font-size:13px;font-weight:700;transition:background-color .1s;display:inline-flex}@media (hover:hover) and (pointer:fine){.button-danger-sm:hover{background-color:var(--color-incorrect-bg)}}.button-danger-sm:active{background-color:var(--color-incorrect-bg)}.admin__add-button{margin-top:8px}.admin__form-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-top:8px;padding:20px 16px}.admin__form-title{color:var(--color-text);margin-bottom:12px;font-size:16px;font-weight:700}.admin__form{flex-direction:column;gap:12px;display:flex}.admin__form-field{flex-direction:column;gap:4px;display:flex}.admin__form-label{color:var(--color-muted);font-size:14px;font-weight:700}.admin__form-input{border:2px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);background-color:var(--color-surface);min-height:44px;padding:10px 12px;font-family:inherit;font-size:16px}.admin__form-input:focus{border-color:var(--color-primary);outline:none}.admin__form-select{border:2px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);background-color:var(--color-surface);appearance:auto;min-height:44px;padding:10px 12px;font-family:inherit;font-size:16px}.admin__form-select:focus{border-color:var(--color-primary);outline:none}.admin__form-error{color:var(--color-incorrect);background-color:var(--color-incorrect-bg);border:1px solid var(--color-incorrect);border-radius:var(--radius-md);padding:10px;font-size:14px;font-weight:600}.admin__form-actions{flex-direction:column;gap:8px;margin-top:4px;display:flex}.admin__tabs{border-bottom:2px solid var(--color-border);-webkit-overflow-scrolling:touch;gap:4px;margin-top:-4px;margin-bottom:4px;display:flex;overflow-x:auto}.admin__tab{color:var(--color-muted);white-space:nowrap;border-bottom:3px solid #0000;flex:none;align-items:center;min-height:44px;margin-bottom:-2px;padding:10px 16px;font-size:14px;font-weight:700;text-decoration:none;transition:color .1s,border-color .1s;display:inline-flex}.admin__tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}@media (hover:hover) and (pointer:fine){.admin__tab:hover{color:var(--color-primary)}}.admin__lead{color:var(--color-muted);margin-top:-4px;font-size:14px;line-height:1.6}.admin__breadcrumbs{margin-top:-4px}.admin__breadcrumb-link{color:var(--color-primary);font-size:14px;font-weight:600;text-decoration:none}.admin__breadcrumb-link:hover{text-decoration:underline}.admin__th--num{text-align:right;white-space:nowrap}.admin__td--num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}.admin__td--accent{color:var(--color-primary);font-weight:700}.admin__progress-user-link{color:var(--color-primary);flex-wrap:wrap;align-items:baseline;gap:2px;min-height:28px;padding:4px 0;font-weight:700;text-decoration:none;display:inline-flex}.admin__progress-user-link:hover{text-decoration:underline}.admin__progress-user-name{color:var(--color-primary)}.admin__progress-user-id{color:var(--color-muted);font-size:12px;font-weight:600}.admin__empty{color:var(--color-muted);text-align:center;background-color:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius-md);padding:16px;font-size:14px}@media (width<=380px){.app-shell{padding:12px}.quiz__card{padding:16px 12px}.home__app-name{font-size:24px}.result-page__title{font-size:22px}.result-summary__value{font-size:20px}.result-summary__value--accent{font-size:26px}.history-page__title{font-size:22px}.history-summary__value{font-size:20px}.history-summary__value--accent{font-size:26px}.history-by-category__table th,.history-by-category__table td{padding:6px 4px;font-size:13px}.history-by-category__title{font-size:15px}.category-radio{font-size:14px}.admin__table{font-size:13px}.admin__th,.admin__td{padding:8px 4px}.admin__title{font-size:20px}.admin__tab{padding:10px 12px;font-size:13px}.admin__progress-user-id{font-size:11px}}.home__role-badge{vertical-align:middle;border-radius:999px;margin-left:8px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.home__role-badge--admin{color:#fff;background-color:#c62828}.home__role-badge--super{color:#fff;background-color:#6a1b9a}.home__vocab-section{background-color:#f3e5f5;border:1px dashed #6a1b9a;border-radius:8px;margin-top:16px;padding:12px}.home__vocab-link{text-align:center;color:#fff;background-color:#6a1b9a;border:none;font-weight:700;display:block}.home__vocab-link:active{background-color:#4a148c}.home__vocab-hint{color:#4a148c;text-align:center;margin:8px 0 0;font-size:12px}.admin__role-badge--super{color:#fff;background-color:#6a1b9a}.vocab-home{max-width:720px;margin:0 auto;padding:16px}.vocab-home__header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.vocab-home__title{color:#4a148c;margin:0;font-size:24px}.vocab-home__back-link-inline{color:#555;font-size:14px;text-decoration:underline}.vocab-home__forbidden{color:#c62828;text-align:center;background:#ffebee;border-radius:8px;padding:12px}.vocab-home__back-link{text-align:center;margin-top:16px;display:block}.vocab-home__lead{color:#555;margin:8px 0 16px}.vocab-home__legend{margin-bottom:8px;font-size:15px;font-weight:700}.vocab-home__hint{color:#888;font-size:14px}.vocab-home__direction,.vocab-home__categories{border:1px solid #ddd;border-radius:8px;margin-bottom:20px;padding:12px}.vocab-home__direction-options{flex-wrap:wrap;gap:8px;display:flex}.vocab-radio{cursor:pointer;background-color:#fafafa;border:1px solid #aaa;border-radius:999px;align-items:center;padding:8px 14px;display:inline-flex}.vocab-radio--checked{color:#fff;background-color:#6a1b9a;border-color:#6a1b9a}.vocab-radio__input{display:none}.vocab-radio__label{font-size:14px;font-weight:600}.vocab-home__category-actions{gap:8px;margin-bottom:12px;display:flex}.button-small{padding:6px 12px;font-size:12px}.vocab-home__category-list{grid-template-columns:1fr 1fr;gap:8px;display:grid}@media (width<=480px){.vocab-home__category-list{grid-template-columns:1fr}}.vocab-checkbox{cursor:pointer;background-color:#fafafa;border:1px solid #bbb;border-radius:8px;justify-content:space-between;align-items:center;min-height:44px;padding:10px 12px;display:flex}.vocab-checkbox--checked{background-color:#ede7f6;border-color:#6a1b9a}.vocab-checkbox__input{margin-right:8px}.vocab-checkbox__label{flex:1;font-size:14px}.vocab-checkbox__count{color:#555;font-size:12px}.vocab-home__summary{background-color:#f3e5f5;border-radius:6px;margin:12px 0;padding:8px 12px;font-size:14px}.vocab-home__actions{text-align:center}.vocab-home__start-button{background-color:#6a1b9a;width:100%;max-width:320px}.vocab-home__start-button:active:not(:disabled){background-color:#4a148c}.vocab-home__start-button:disabled{background-color:#bbb}.vocab-session{max-width:720px;margin:0 auto;padding:16px}.vocab-session__header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.vocab-session__title{color:#4a148c;margin:0;font-size:22px}.vocab-session__back-link-inline{color:#555;font-size:13px;text-decoration:underline}.vocab-session__forbidden,.vocab-session__empty{color:#c62828;text-align:center;background:#ffebee;border-radius:8px;padding:12px}.vocab-session__back-link{text-align:center;margin-top:16px;display:block}.vocab-session__loading{text-align:center;color:#888;padding:24px}.vocab-session__meta{color:#555;flex-wrap:wrap;gap:12px;margin:8px 0 16px;font-size:13px;display:flex}.vocab-session__meta-item{background:#f3e5f5;border-radius:999px;padding:4px 10px}.vocab-card{text-align:center;cursor:pointer;-webkit-user-select:none;user-select:none;background-color:#fff;border:2px solid #6a1b9a;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;min-height:220px;padding:32px 16px;transition:background-color .15s;display:flex}.vocab-card--front{background-color:#f3e5f5}.vocab-card--front:active{background-color:#e1bee7}.vocab-card--flipped{cursor:default;background-color:#fff}.vocab-card__hint{color:#888;margin:0 0 12px;font-size:12px}.vocab-card__sub{color:#888;margin:0 0 12px;font-size:14px}.vocab-card__main{color:#4a148c;word-break:break-word;margin:0;font-size:24px;font-weight:700}.vocab-card__main--answer{color:#1b5e20;font-size:28px}.vocab-session__eval{grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:16px;display:grid}.vocab-eval-button{cursor:pointer;background-color:#fff;border:2px solid;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:4px;min-height:70px;padding:14px 4px;font-weight:700;transition:transform 50ms;display:flex}.vocab-eval-button:active:not(:disabled){transform:scale(.97)}.vocab-eval-button:disabled{opacity:.6;cursor:not-allowed}.vocab-eval-button--wrong{color:#c62828;border-color:#c62828}.vocab-eval-button--correct{color:#2e7d32;border-color:#2e7d32}.vocab-eval-button--both{color:#6a1b9a;background-color:#f3e5f5;border-color:#6a1b9a}.vocab-eval-button__icon{font-size:22px;line-height:1}.vocab-eval-button__label{font-size:12px}.vocab-session__counter{text-align:right;color:#888;margin-top:16px;font-size:12px}.vocab-session__complete-card{text-align:center;background:#f3e5f5;border:2px solid #6a1b9a;border-radius:12px;margin-top:16px;padding:24px 16px}.vocab-session__complete-title{color:#4a148c;margin:0 0 12px;font-size:20px}.vocab-session__complete-line{margin:6px 0;font-size:15px}.vocab-session__complete-meta{color:#555;margin-top:12px;font-size:12px}.vocab-session__complete-actions{flex-direction:column;align-items:stretch;gap:8px;margin-top:16px;display:flex}.vocab-home__mode{border:1px solid #ddd;border-radius:8px;margin-bottom:16px;padding:12px}.vocab-home__mode-options{flex-wrap:wrap;gap:8px;display:flex}.vocab-home__mode-cta{background:#faf5ff;border:1px dashed #b39ddb;border-radius:8px;margin-bottom:16px;padding:14px 12px}.vocab-home__mode-desc{color:#333;margin:0 0 10px;font-size:14px;line-height:1.6}.vocab-checkbox__progress{flex-direction:column;align-items:stretch;gap:4px;min-width:130px;margin-left:auto;display:flex}.vocab-checkbox__progress-text{color:#555;text-align:right;font-size:11px}.vocab-progressbar{background:#e9e1f3;border-radius:3px;width:100%;height:6px;display:block;position:relative;overflow:hidden}.vocab-progressbar__fill{background:linear-gradient(90deg,#9c27b0 0%,#6a1b9a 100%);border-radius:3px;height:100%;transition:width .24s;display:block}.vocab-progressbar__fill--full{background:linear-gradient(90deg,#4caf50 0%,#2e7d32 100%)}.vocab-progressbar--session{height:8px;margin:8px 0 4px}.vocab-session__category-mastery{color:#555;margin:4px 0 12px;font-size:12px}.vocab-home__settings{border:1px solid #ddd;border-radius:8px;margin-top:16px;padding:12px}.vocab-toggle{cursor:pointer;align-items:center;gap:8px;padding:8px 0;font-size:14px;display:flex}.vocab-toggle input[type=checkbox]{width:18px;height:18px;margin:0}.vocab-toggle__state{border-radius:12px;margin-left:auto;padding:2px 8px;font-size:11px;font-weight:700}.vocab-toggle__state.is-on{color:#1b5e20;background:#c8e6c9}.vocab-toggle__state.is-off{color:#777;background:#eee}.vocab-speak-button{color:#6a1b9a;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#fff;border:1.5px solid #6a1b9a;border-radius:22px;align-items:center;gap:6px;min-height:40px;margin-top:12px;padding:8px 14px;font-size:14px;font-weight:600;display:inline-flex}.vocab-speak-button:active{background:#f3e5f5}.vocab-speak-button__label{font-size:13px}@keyframes vocab-confetti-fall{0%{opacity:.9;transform:translateY(-20vh)rotate(0)}to{transform:translateY(110vh) rotate(var(--vocab-confetti-rotate,360deg));opacity:.6}}.vocab-card{position:relative}.vocab-timer{letter-spacing:.04em;color:#4a148c;text-align:center;background-color:#ffffffd9;border:1px solid #ce93d8;border-radius:4px;min-width:56px;padding:2px 8px;font-family:SF Mono,Menlo,Consolas,Courier New,monospace;font-size:14px;font-weight:700;position:absolute;top:8px;left:50%;transform:translate(-50%)}.vocab-timer--running{animation:1.2s ease-in-out infinite vocab-timer-pulse}.vocab-timer--stopped{color:#e65100;background-color:#fff3e0;border-color:#ffb74d}@keyframes vocab-timer-pulse{0%,to{box-shadow:0 0 #6a1b9a00}50%{box-shadow:0 0 0 4px #6a1b9a14}}.vocab-prev-badge{color:#666;white-space:nowrap;background-color:#fff;border:1px solid #ccc;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:600;position:absolute;top:8px;right:8px}.vocab-prev-badge--none{color:#888;background-color:#f5f5f5;border-color:#ddd}.vocab-prev-badge--wrong{color:#c62828;background-color:#ffebee;border-color:#ef9a9a}.vocab-prev-badge--correct{color:#1565c0;background-color:#e3f2fd;border-color:#90caf9}.vocab-prev-badge--both{color:#2e7d32;background-color:#e8f5e9;border-color:#a5d6a7}.vocab-feedback{text-align:center;color:#e65100;background-color:#fffde7;border:2px solid #fbc02d;border-radius:8px;margin-top:12px;padding:10px 14px;font-size:16px;font-weight:700;animation:.25s ease-out vocab-feedback-pop}@keyframes vocab-feedback-pop{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}
