: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}}
