*,:before,:after{box-sizing:border-box}*{margin:0}html,body{height:100%}body{-webkit-font-smoothing:antialiased;line-height:1.5}img,picture,svg{max-width:100%;display:block}input,button,textarea,select{font:inherit;color:inherit}button{cursor:pointer}ul{padding:0;list-style:none}a{color:inherit}:root{--color-bg:#f6f7f9;--color-surface:#fff;--color-border:#e2e5ea;--color-text:#1c2024;--color-muted:#6b7280;--color-primary:#2563eb;--color-primary-text:#fff;--color-danger:#dc2626;--color-danger-text:#fff;--color-accent:#eef2ff;--radius:12px;--radius-sm:8px;--space:16px;--shadow:0 1px 3px #00000014, 0 1px 2px #0000000a;--font-base:"Hiragino Sans", "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--max-width:720px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}@media (prefers-color-scheme:dark){:root{--color-bg:#15171b;--color-surface:#1f2228;--color-border:#333842;--color-text:#e7e9ee;--color-muted:#9aa1ad;--color-primary:#3b82f6;--color-accent:#232838;--shadow:0 1px 3px #0006;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}}body{font-family:var(--font-base);background:var(--color-bg);color:var(--color-text)}#app{min-height:100%}ruby rt{color:var(--color-muted);font-size:.55em}.app-header{z-index:10;background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:env(safe-area-inset-top) 0 0;position:sticky;top:0}.app-header__bar{max-width:var(--max-width);align-items:center;gap:var(--space);padding:12px var(--space);margin:0 auto;display:flex}.app-header__title{margin-right:auto;font-size:1.1rem;font-weight:700}.nav{gap:4px;display:flex}.nav a{border-radius:var(--radius-sm);color:var(--color-muted);padding:6px 12px;font-size:.9rem;text-decoration:none}.nav a.is-active{background:var(--color-accent);color:var(--color-primary);font-weight:600}main{max-width:var(--max-width);padding:var(--space);padding-bottom:calc(var(--space) + env(safe-area-inset-bottom));margin:0 auto}.btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);justify-content:center;align-items:center;gap:6px;padding:9px 16px;font-size:.92rem;font-weight:500;text-decoration:none;transition:filter .12s;display:inline-flex}.btn:hover{filter:brightness(.97)}.btn--primary{background:var(--color-primary);color:var(--color-primary-text);border-color:#0000}.btn--danger{background:var(--color-danger);color:var(--color-danger-text);border-color:#0000}.btn--ghost{color:var(--color-muted);background:0 0;border-color:#0000}.btn--block{width:100%}.btn:disabled{opacity:.5;cursor:default}.field{margin-bottom:var(--space)}.field label{color:var(--color-muted);margin-bottom:6px;font-size:.85rem;font-weight:600;display:block}.input,.textarea,.select{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);width:100%;padding:10px 12px}.input:focus,.textarea:focus,.select:focus{outline:2px solid var(--color-primary);outline-offset:-1px}.textarea{resize:vertical;min-height:72px}.form-actions{gap:8px;margin-top:8px;display:flex}.field-hint{color:var(--color-muted);margin-top:4px;font-size:.78rem}.form-error{color:var(--color-danger);margin-bottom:var(--space);font-size:.88rem}.toolbar{margin-bottom:var(--space);flex-wrap:wrap;gap:8px;display:flex}.toolbar .input{flex:1;min-width:160px}.card-list{flex-direction:column;gap:10px;display:flex}.vocab-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px var(--space);align-items:flex-start;gap:var(--space);display:flex}.vocab-item__body{flex:1;min-width:0}.vocab-item__word{font-size:1.5rem;font-weight:700;line-height:1.4}.vocab-item__meaning{color:var(--color-text)}.vocab-item__meta{color:var(--color-muted);flex-wrap:wrap;gap:8px;margin-top:4px;font-size:.78rem;display:flex}.tag{background:var(--color-accent);color:var(--color-primary);border-radius:999px;padding:1px 8px;font-size:.72rem}.vocab-item__actions{flex-direction:column;gap:6px;display:flex}.empty{text-align:center;padding:48px var(--space);color:var(--color-muted)}.empty h2{color:var(--color-text);margin-bottom:8px}.empty p{margin-bottom:var(--space)}.empty__actions{flex-direction:column;gap:8px;max-width:280px;margin:0 auto;display:flex}.study{align-items:center;gap:var(--space);flex-direction:column;display:flex}.study__progress{color:var(--color-muted);font-size:.85rem}.flashcard{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);width:100%;min-height:280px;box-shadow:var(--shadow);text-align:center;padding:32px var(--space);flex-direction:column;justify-content:center;align-items:center;gap:14px;display:flex}.flashcard__word{font-size:2.6rem;font-weight:700;line-height:1.4}.flashcard__reading{color:var(--color-muted);font-size:1.4rem}.flashcard__meaning{font-size:1.3rem}.flashcard__example{color:var(--color-muted);font-size:1.05rem}.flashcard__hint{color:var(--color-muted);font-size:.8rem}.study__controls{gap:8px;width:100%;display:flex}.study__controls .btn{flex:1}.install-banner{background:var(--color-accent);border:1px solid var(--color-border);border-radius:var(--radius-sm);margin-top:var(--space);align-items:center;gap:8px;padding:10px 12px;font-size:.88rem;display:flex}.install-banner__text{flex:1}.install-banner__close{color:var(--color-muted);background:0 0;border:none;font-size:1.1rem;line-height:1}.confirm-dialog{border-radius:var(--radius);background:var(--color-surface);width:calc(100% - 32px);max-width:360px;color:var(--color-text);border:none;margin:0;padding:24px;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 12px 40px #00000040}.confirm-dialog::backdrop{background:#00000073}.confirm-dialog__title{margin-bottom:8px;font-size:1.1rem}.confirm-dialog__message{color:var(--color-muted);margin-bottom:var(--space)}.confirm-dialog__actions{justify-content:flex-end;gap:8px;display:flex}.sr-only{clip:rect(0 0 0 0);width:1px;height:1px;position:absolute;overflow:hidden}
