:root,[data-theme=light]{color-scheme:light;--bg:#fafaf7;--surface:#fffdf8;--surface2:#f3f4f6;--surface3:#e5e7eb;--text:#111827;--muted:#4b5563;--border:#e6e8eb;--primary:#2563eb;--primaryText:#fff;--danger:#b91c1c;--warning:#b45309;--success:#15803d;--grade-bg:var(--surface2);--grade-text:var(--text);--grade-1-border:#cbd5e1;--grade-2-border:#94a3b8;--grade-3-border:#64748b;--grade-4-border:var(--primary);--link:#2563eb;--focus:#2563eb;--shadow:0 2px 8px rgba(0,0,0,.06);--overlay:rgba(15,23,42,.45);--onSurface:var(--text);--dangerMuted:#7f1d1d;--dangerMutedBg:transparent;--dangerMutedBorder:color-mix(in srgb,var(--danger) 35%,var(--border))}[data-theme=dark]{color-scheme:dark;--bg:#0b1220;--surface:#111a2b;--surface2:#16223a;--surface3:#22304a;--text:#e5e7eb;--muted:#9ca3af;--border:#1f2a44;--primary:#60a5fa;--primaryText:#0b1220;--danger:#fca5a5;--warning:#fcd34d;--success:#86efac;--grade-bg:var(--surface2);--grade-text:var(--text);--grade-1-border:#2b3a5a;--grade-2-border:#3b4a6a;--grade-3-border:#4b5a7a;--grade-4-border:var(--primary);--link:#60a5fa;--focus:#60a5fa;--shadow:0 8px 18px rgba(0,0,0,.55);--overlay:rgba(0,0,0,.55);--onSurface:var(--text);--dangerMuted:color-mix(in srgb,var(--danger) 70%,var(--muted));--dangerMutedBg:transparent;--dangerMutedBorder:color-mix(in srgb,var(--danger) 25%,var(--border))}*{box-sizing:border-box}:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;--top-chrome-offset:0px;--bottom-chrome-offset:78px;--page-max-width:720px;--page-pad-inline:20px;--page-gap:16px;--page-pad-top:calc(env(safe-area-inset-top) + var(--top-chrome-offset) + 16px);--page-pad-bottom:calc(env(safe-area-inset-bottom) + var(--bottom-chrome-offset) + 16px)}body{margin:0;background:var(--bg);color:var(--text);min-height:100vh;min-height:100svh;min-height:100dvh;-webkit-font-smoothing:antialiased;padding:0}@media (min-width:900px){:root{--top-chrome-offset:64px;--bottom-chrome-offset:0px}}.page{max-width:var(--page-max-width);margin:0 auto;padding:var(--page-pad-top) var(--page-pad-inline) var(--page-pad-bottom);display:flex;flex-direction:column;gap:var(--page-gap);color:var(--text);min-height:100vh;min-height:100svh;min-height:100dvh}.page__title{font-size:20px;font-weight:800;line-height:1.2;margin:0}.page__section{border:1px solid var(--border);border-radius:12px;padding:18px}.auth-grid{display:grid;grid-template-columns:1fr;gap:var(--page-gap)}.auth-stack{display:grid;gap:12px}.auth-tabs{display:flex;gap:8px}.auth-stack-cards{display:block}.auth-card{position:relative;height:auto;transition:opacity .16s ease,box-shadow .16s ease}.auth-card__body{display:grid;gap:16px}.auth-card--inactive{z-index:1;opacity:0;pointer-events:none;display:none}.auth-card--active{z-index:3;opacity:1}.auth-tab{display:inline-flex;flex:1 1 0;align-items:center;justify-content:center;padding:10px 14px;border-radius:8px;border:1px solid var(--border);background:var(--surface2);color:var(--muted);font-size:12px;font-weight:700;letter-spacing:.02em;box-shadow:var(--shadow);text-transform:uppercase;cursor:pointer;appearance:none;font:inherit}.auth-tab--active{background:var(--primary);color:var(--primaryText);border-color:var(--primary);box-shadow:0 10px 18px rgba(0,0,0,.12)}.auth-tab:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.auth-card--login{--stack-index:0}.auth-card--register{--stack-index:1}.auth-card--reset{--stack-index:2}@media (min-width:880px){.auth-grid{grid-template-columns:1fr 1fr;align-items:start}}.brand-header{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--border);background:var(--surface);border-radius:16px;box-shadow:var(--shadow)}.brand-header__logo{width:40px;height:40px;border-radius:10px}.brand-header__text{display:grid;gap:2px}.brand-header__name{font-weight:900;letter-spacing:-.02em}.brand-header__meta{font-size:12px;color:var(--muted);font-weight:700}.srs-actions{margin-top:12px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;align-items:center;width:100%}.srs-grades{margin-top:14px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}@media (max-width:360px){:root{--page-pad-inline:12px;--bottom-chrome-offset:72px}}@media (max-width:480px){:root{--bottom-chrome-offset:72px;--page-pad-inline:14px;--page-gap:14px}.page__section{padding:14px}.srs-actions{gap:10px}.srs-grades{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}}.checkbox{width:18px;height:18px;accent-color:var(--primary)}.menu-chip{display:inline-flex;align-items:center;gap:6px;padding:10px 12px;border-radius:999px;border:1px solid var(--border);background:var(--surface2);color:var(--text);font-weight:600;text-decoration:none;transition:background .12s ease,border-color .12s ease,color .12s ease}.menu-chip:focus-visible,.menu-chip:hover{background:var(--surface3);border-color:var(--focus);color:var(--text);outline:none}.menu-chip--button{cursor:pointer}.app-shell{max-width:720px;margin:0 auto;padding:16px 18px 32px;display:flex;flex-direction:column;gap:18px}@media (max-width:480px){.app-shell{padding:12px 8px 24px}}.app-header{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:16px;box-shadow:var(--shadow);position:sticky;top:calc(env(safe-area-inset-top) + var(--top-chrome-offset) + 12px);z-index:10;backdrop-filter:blur(4px)}.app-title{margin:0 0 4px;font-size:1.35rem;font-weight:700;letter-spacing:-.01em}.app-subtitle{margin:0;color:var(--muted);font-size:.95rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:16px;box-shadow:var(--shadow)}.card h2{margin-top:0;margin-bottom:8px;font-size:1.05rem}.section-description{margin-top:0;color:var(--muted);font-size:.95rem}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.label{font-weight:600;font-size:.95rem}.input,.select,.textarea{width:100%;padding:12px;font-size:1rem;border:1px solid var(--border);border-radius:12px;background:var(--surface);color:var(--text);min-height:44px}.select{min-height:58px}.input:focus,.select:focus,.textarea:focus{outline:2px solid var(--focus);outline-offset:2px;border-color:var(--focus)}.helper{color:var(--muted);font-size:.9rem}.login-failed-attempts{margin-left:auto;font-size:.8rem;color:var(--warning);text-align:right}.error{color:var(--danger);font-size:.9rem}.button{appearance:none;border:none;cursor:pointer;border-radius:12px;padding:12px 16px;font-weight:700;font-size:1rem;background:var(--primary);color:var(--primaryText);min-height:44px;display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;transition:transform .12s ease,box-shadow .12s ease}.button:focus-visible{outline:2px solid var(--focus);outline-offset:3px}.button:active{transform:translateY(1px)}.button.secondary{background:transparent;color:var(--primary);border:1px solid color-mix(in srgb,var(--primary) 45%,var(--border))}.button.ghost{background:transparent;color:var(--text);border:1px solid var(--border)}.button.danger-subtle{background:transparent;color:var(--dangerMuted);border:1px solid var(--dangerMutedBorder)}.button.danger-subtle:focus-visible,.button.danger-subtle:hover{border-color:color-mix(in srgb,var(--danger) 45%,var(--border))}.button:disabled{opacity:.65;cursor:not-allowed}.stack{display:flex;flex-direction:column;gap:12px}.horizontal{display:flex;gap:10px;flex-wrap:wrap}.badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;color:var(--text);border:1px solid var(--border)}.badge,.code-block{font-size:.9rem;background:var(--surface2)}.code-block{border-radius:12px;padding:12px;overflow-x:auto;border:1px solid var(--border)}.notice{background:var(--surface2);border-radius:12px;padding:12px;border:1px dashed var(--border)}.modal-backdrop{position:fixed;inset:0;background:var(--overlay);display:flex;align-items:center;justify-content:center;z-index:50;padding:16px}.modal{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:16px;padding:20px;min-width:320px;width:min(520px,100%);box-shadow:var(--shadow)}.modal__title{margin:0 0 8px;font-size:1.25rem}.modal__body{margin:0 0 12px;color:var(--muted)}.modal__actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.top-nav{display:none}.top-nav__brand{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text);text-decoration:none;font-weight:900;box-shadow:var(--shadow)}.top-nav__brand-logo{width:22px;height:22px;border-radius:6px}.top-nav__brand-text{font-size:13px;letter-spacing:-.01em}.top-nav__item{text-decoration:none;color:var(--muted);font-weight:700;font-size:13px;padding:8px 10px;border-radius:999px;border:1px solid var(--border);background:var(--surface2);transition:background .12s ease,border-color .12s ease,color .12s ease}.top-nav__item:focus-visible,.top-nav__item:hover{background:var(--surface3);border-color:var(--focus);color:var(--text);outline:none}.top-nav__item.is-active{color:var(--primaryText);background:var(--primary);border-color:var(--primary)}.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:60;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:6px;padding:10px 10px calc(env(safe-area-inset-bottom) + 10px);background:color-mix(in srgb,var(--surface) 92%,transparent);border-top:1px solid var(--border);backdrop-filter:blur(10px)}.bottom-nav__item{display:grid;justify-items:center;gap:2px;text-decoration:none;padding:8px 6px;border-radius:14px;color:var(--muted);border:1px solid transparent}.bottom-nav__item:focus-visible,.bottom-nav__item:hover{background:var(--surface2);border-color:var(--border);outline:none}.bottom-nav__item.is-active{color:var(--text);background:var(--surface2);border-color:var(--border)}.bottom-nav__icon{font-size:18px;line-height:1}.bottom-nav__label{font-size:11px;font-weight:700;line-height:1.1}@media (min-width:900px){.bottom-nav{display:none}.top-nav{position:fixed;top:calc(env(safe-area-inset-top) + 10px);right:12px;z-index:60;display:flex;gap:8px;padding:10px 12px;background:color-mix(in srgb,var(--surface) 92%,transparent);border:1px solid var(--border);border-radius:999px;backdrop-filter:blur(10px);box-shadow:var(--shadow)}}.settings-header{display:flex;align-items:center;gap:10px}.settings-grid{display:grid;gap:12px}.settings-grid--spaced{margin-top:12px}@media (min-width:700px){.settings-grid{grid-template-columns:1fr 1fr;align-items:start}}.settings-card{border:1px solid var(--border);border-radius:14px;background:var(--surface);padding:14px;display:grid;gap:10px}.settings-label{font-size:12px;color:var(--muted);font-weight:700}.settings-title{font-size:14px;font-weight:900}.settings-check{display:flex;gap:10px;align-items:center;font-size:13px}.settings-muted{font-size:12px;color:var(--muted)}.settings-error{font-size:12px;color:var(--danger);margin-top:6px}.settings-limits{display:grid;gap:10px}.settings-primary,.settings-secondary{border-radius:12px;padding:11px 14px;font-weight:800;border:1px solid var(--border);cursor:pointer}.settings-primary{background:var(--primary);border-color:var(--primary);color:var(--primaryText)}.settings-secondary{background:var(--surface2);color:var(--text)}.settings-primary:disabled,.settings-secondary:disabled{opacity:.6;cursor:not-allowed}.settings-footer{margin-top:10px;font-size:12px;color:var(--muted)}.settings-footer a{color:inherit}.settings-select{width:100%;border:1px solid var(--border);border-radius:12px;background:var(--surface);color:var(--text);font-size:14px}.settings-select--lg{min-height:36px;padding:14px}.settings-select--lg:focus-visible{outline:2px solid var(--focus);outline-offset:2px;border-color:var(--focus)}.settings-row{display:flex;gap:12px;align-items:stretch}.settings-card--half{flex:1 1 0;min-width:0}@media (max-width:420px){.settings-row{flex-direction:column}}.theme-toggle{display:inline-flex;align-items:center;gap:10px;padding:10px 12px;border-radius:14px;border:1px solid var(--border);background:var(--surface2);color:var(--text);cursor:pointer;user-select:none}.theme-toggle:hover{background:var(--surface3)}.theme-toggle:focus-visible{outline:3px solid var(--focus);outline-offset:2px}.theme-toggle__icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:10px;background:var(--surface);border:1px solid var(--border)}.theme-toggle__text{font-weight:600;white-space:nowrap}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-reduced-data:reduce){.app-header,.card,.shadow{box-shadow:none}}