:root{--bg: #faf7f2;--card: #ffffff;--ink: #2b2b2b;--muted: #8a8175;--line: #e8e1d6;--accent: #e8896b;--accent-soft: #fbe9e3;--ok: #4f9d69;--ng: #c0654f;--font-mincho: "Noto Serif JP", serif;--font-gothic: "Noto Sans JP", sans-serif;--font-brush: "Yuji Syuku", serif;--font-textbook: "Klee One", "Zen Kaku Gothic New", sans-serif}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font-gothic);line-height:1.6;-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer}input,select{font-family:inherit;font-size:1rem}.layout{display:flex;min-height:100vh}.sidebar{width:280px;flex-shrink:0;background:#fffdf9;border-right:1px solid var(--line);padding:1rem .9rem 2rem;overflow-y:auto;height:100vh;position:sticky;top:0}.sidebar-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;font-size:1.05rem;letter-spacing:.04em}.drawer-close{display:none;border:none;background:transparent;font-size:1.1rem;color:var(--muted)}.sidebar-block{margin-bottom:1rem}.sidebar-block .section-label{margin:0 0 .35rem}.sidebar-block select{width:100%;border:1px solid var(--line);border-radius:8px;padding:.4rem .5rem;background:var(--card)}.surname-row{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.surname-row input{border:1px solid var(--line);border-radius:8px;padding:.4rem .6rem;width:6rem;background:var(--card)}.candidate-nav{list-style:none;margin:.5rem 0 0;padding:0}.candidate-nav li{margin-bottom:.3rem}.nav-empty{color:var(--muted);font-size:.85rem;padding:.5rem .2rem}.nav-item{width:100%;display:flex;align-items:center;justify-content:space-between;gap:.5rem;border:1px solid transparent;border-radius:10px;background:transparent;padding:.55rem .7rem;text-align:left}.nav-item:hover{background:var(--accent-soft)}.nav-item.active{background:var(--accent-soft);border-color:var(--accent)}.nav-hira{font-size:1.15rem;font-weight:700;letter-spacing:.05em}.nav-meta{display:flex;gap:.5rem;align-items:center;font-size:.72rem;color:var(--muted)}.nav-score{color:var(--accent);font-weight:700}.main{flex:1;min-width:0;padding-bottom:4rem}.main-body{max-width:760px;margin:0 auto;padding:1rem 1rem 0}.topbar{position:sticky;top:0;z-index:10;background:var(--bg);padding:.7rem 1rem;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:.6rem}.menu-btn{display:none;border:1px solid var(--line);background:var(--card);border-radius:8px;font-size:1.1rem;padding:.25rem .6rem}.topbar-title{display:flex;align-items:baseline;gap:.5rem}.topbar-logo{display:none;font-family:var(--font-brush);font-size:1.3rem;letter-spacing:.08em;color:var(--ink)}.logo{display:inline-flex;align-items:baseline;color:var(--ink);white-space:nowrap;line-height:1}.logo-namae{font-family:var(--font-mincho);font-weight:700;letter-spacing:.04em}.logo-kurabe{font-family:var(--font-mincho);font-weight:700;display:inline-block;transform:scaleX(.82);transform-origin:left center;letter-spacing:.02em;margin-left:.08em}.logo-sidebar{font-size:1.35rem}.topbar-hira{font-size:1.35rem;font-weight:700;letter-spacing:.05em}.topbar-romaji{color:var(--muted);font-size:.9rem}.backdrop{display:none}@media (max-width: 768px){.sidebar{position:fixed;top:0;left:0;z-index:30;height:100vh;transform:translate(-100%);transition:transform .22s ease;box-shadow:2px 0 12px #0000001f}.sidebar.open{transform:translate(0)}.drawer-close{display:block}.menu-btn{display:inline-block}.backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;background:#00000059}.fullname-grid{grid-template-columns:1fr}.fullname-cell .name:not(.vertical){white-space:nowrap}.topbar{padding:.6rem .7rem;gap:.4rem}.topbar-title{display:none}.topbar-logo{display:block}.share-btn{padding:.3rem .7rem;font-size:.8rem}.col-reading{display:none}.char-table{font-size:.8rem}.char-table th,.char-table td{padding:.3rem}.font-cell .glyph{font-size:2rem}}.add-row{display:flex;gap:.5rem;margin-bottom:1.25rem}.add-row input{flex:1;border:1px solid var(--line);border-radius:10px;padding:.6rem .8rem;background:var(--card)}.btn{border:none;border-radius:10px;padding:.6rem 1rem;background:var(--accent);color:#fff;font-weight:700}.btn.ghost{background:transparent;color:var(--accent);border:1px solid var(--accent)}.btn.small{padding:.3rem .6rem;font-size:.8rem;border-radius:8px}.btn:disabled{opacity:.5;cursor:default}.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:1rem 1.1rem;margin-bottom:1rem;box-shadow:0 1px 2px #00000008}.card-head{display:flex;align-items:baseline;gap:.6rem;flex-wrap:wrap}.card-head .hira{font-size:1.5rem;font-weight:700;letter-spacing:.05em}.card-head .romaji{color:var(--muted);font-size:.95rem}.card-head .spacer{flex:1}.section-label{font-size:.75rem;color:var(--muted);margin:1rem 0 .4rem;letter-spacing:.05em}.meta-row{display:flex;flex-wrap:wrap;gap:1rem 2rem;align-items:flex-start;margin:.9rem 0;padding-bottom:.9rem;border-bottom:1px solid var(--line)}.meta-item{display:flex;flex-direction:column;gap:.35rem}.meta-item .section-label{margin:0}.romaji-edit{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.romaji-edit input{border:1px solid var(--line);border-radius:8px;padding:.3rem .5rem}.eval-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.stars{display:inline-flex;gap:2px}.stars button{border:none;background:transparent;font-size:1.3rem;line-height:1;color:var(--line);padding:0}.stars button.on{color:var(--accent)}.eval-name{font-size:.8rem;color:var(--muted);width:3.5rem}.font-compare{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.6rem}.font-cell{border:1px dashed var(--line);border-radius:10px;padding:.6rem;text-align:center;background:#fffdf9}.font-cell .tag{font-size:.7rem;color:var(--muted);display:block;margin-bottom:.3rem}.font-cell .glyph{font-size:2.4rem;line-height:1.3}.glyph.mincho{font-family:var(--font-mincho)}.glyph.gothic{font-family:var(--font-gothic)}.glyph.brush{font-family:var(--font-brush)}.glyph.textbook{font-family:var(--font-textbook)}.preview-controls{display:flex;gap:.5rem;margin-bottom:.5rem}.toggle-pill{border:1px solid var(--line);background:var(--card);border-radius:999px;padding:.25rem .7rem;font-size:.8rem;color:var(--muted)}.toggle-pill.active{background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}.fullname-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:.6rem}.fullname-cell{border:1px dashed var(--line);border-radius:10px;padding:.8rem;text-align:center;background:#fffdf9;min-height:120px;display:flex;flex-direction:column;align-items:center;justify-content:center}.fullname-cell .tag{font-size:.7rem;color:var(--muted);margin-bottom:.5rem}.fullname-cell .name{font-size:1.9rem;letter-spacing:.05em;line-height:1.2;min-height:calc(var(--name-len, 4) * 1.2em);display:flex;align-items:center;justify-content:center}.fullname-cell .name.vertical{writing-mode:vertical-rl;text-orientation:upright}.variation-bar{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin:1rem 0 .5rem}.variation-sort{font-size:.78rem;padding:.25rem .4rem;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink)}.variation-index{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.9rem;padding-bottom:.9rem;border-bottom:1px solid var(--line)}.variation-index-item{display:inline-flex;align-items:center;gap:.25rem;padding:.3rem .6rem;border:1px solid var(--line);border-radius:999px;background:#fff;color:var(--ink);font-family:var(--font-mincho);font-size:1rem;line-height:1.2;cursor:pointer;transition:background .15s,border-color .15s}.variation-index-item:hover{background:var(--accent-soft);border-color:var(--accent)}.variation-index-fav{font-family:var(--font-gothic);font-size:.7rem;color:var(--accent)}.variation{border:1px solid var(--line);border-radius:12px;padding:.8rem;margin-bottom:.8rem;background:#fffdfb}.variation-head{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;flex-wrap:wrap}.variation-head .kanji{font-size:1.6rem;font-family:var(--font-mincho)}.fav-stars{display:inline-flex;gap:.3rem}.fav-star{display:inline-flex;align-items:center;gap:1px;border:1px solid var(--line);background:var(--card);border-radius:999px;padding:.15rem .5rem;font-size:.95rem;color:var(--line)}.fav-star .fav-who{font-size:.7rem;color:var(--muted)}.fav-star.on{color:var(--accent);border-color:var(--accent)}.fav-star.on .fav-who{color:var(--accent)}.kebab{position:relative}.kebab-btn{border:1px solid var(--line);background:var(--card);border-radius:8px;font-size:1.1rem;line-height:1;padding:.15rem .55rem;color:var(--muted)}.kebab-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:15}.kebab-menu{position:absolute;right:0;top:calc(100% + 4px);z-index:16;background:var(--card);border:1px solid var(--line);border-radius:10px;box-shadow:0 6px 20px #0000001f;overflow:hidden;min-width:6rem}.kebab-menu button{display:block;width:100%;text-align:left;border:none;background:transparent;padding:.55rem .9rem;font-size:.9rem;color:var(--ink)}.kebab-menu button:hover{background:var(--accent-soft)}.kebab-menu button.danger{color:var(--ng)}.kanji-edit{font-size:1.3rem;font-family:var(--font-mincho);border:1px solid var(--accent);border-radius:8px;padding:.2rem .5rem;width:8rem}.badge{font-size:.7rem;padding:.1rem .5rem;border-radius:999px;font-weight:700}.badge.ok{background:#e7f3ec;color:var(--ok)}.badge.ng{background:#f8e6e2;color:var(--ng)}.badge.unknown{background:#eee;color:var(--muted)}.char-table{width:100%;border-collapse:collapse;font-size:.85rem}.char-table th,.char-table td{text-align:left;padding:.35rem .4rem;border-bottom:1px solid var(--line);vertical-align:top}.char-table th{color:var(--muted);font-weight:500;font-size:.75rem}.char-table .c{font-size:1.3rem;font-family:var(--font-mincho)}.meaning-ja{color:var(--ink)}.meaning-en{color:var(--muted);font-size:.8rem}.meaning-missing{color:var(--muted);font-size:.8rem;font-style:italic}.fab{position:fixed;right:1.2rem;bottom:1.2rem;z-index:25;width:3.4rem;height:3.4rem;border-radius:50%;border:none;background:var(--accent);color:#fff;font-size:1.9rem;line-height:1;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px #00000038}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;background:#00000059;display:flex;align-items:flex-end;justify-content:center;animation:sheet-fade-in .2s ease}.sheet-backdrop.closing{animation:sheet-fade-out .2s ease forwards}.sheet{background:var(--card);width:100%;max-width:640px;border-radius:16px 16px 0 0;padding:.5rem 1.1rem 1.6rem;max-height:85vh;overflow-y:auto;box-shadow:0 -6px 24px #0000002e;animation:sheet-slide-up .24s cubic-bezier(.2,.8,.2,1)}.sheet.closing{animation:sheet-slide-down .22s ease forwards}@keyframes sheet-fade-in{0%{opacity:0}to{opacity:1}}@keyframes sheet-fade-out{0%{opacity:1}to{opacity:0}}@keyframes sheet-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes sheet-slide-down{0%{transform:translateY(0)}to{transform:translateY(100%)}}@media (prefers-reduced-motion: reduce){.sheet-backdrop,.sheet-backdrop.closing,.sheet,.sheet.closing{animation:none}}.more-btn{display:block;margin:.8rem auto 0;border:none;background:transparent;color:var(--muted);font-size:.85rem;text-decoration:underline;padding:.3rem .6rem}.sheet-handle{width:40px;height:4px;border-radius:2px;background:var(--line);margin:.3rem auto .7rem}.sheet-head{display:flex;align-items:center;gap:.5rem;margin-bottom:.6rem}.sheet-head .drawer-close{display:block}.suggest-grid{display:flex;flex-wrap:wrap;gap:.5rem}.suggest-chip{display:flex;align-items:center;gap:.3rem;border:1px solid var(--line);background:var(--card);border-radius:10px;padding:.45rem .75rem}.suggest-chip:hover{background:var(--accent-soft);border-color:var(--accent)}.suggest-chip.added{opacity:.5}.suggest-kanji{font-family:var(--font-mincho);font-size:1.3rem}.suggest-check{color:var(--ok);font-weight:700}.empty{text-align:center;color:var(--muted);padding:3rem 1rem}.title-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:radial-gradient(120% 80% at 50% 0%,var(--accent-soft) 0%,var(--bg) 60%)}.title-card{width:100%;max-width:380px;text-align:center}.title-logo{font-family:var(--font-brush);font-size:2.8rem;margin:0;letter-spacing:.12em;color:var(--ink)}.title-sub{color:var(--muted);font-size:.9rem;margin:.4rem 0 2rem}.title-actions{display:flex;flex-direction:column;gap:.8rem}.title-btn{width:100%;padding:.85rem 1rem;font-size:1.05rem;border-radius:12px}.title-hint{font-size:.8rem;color:var(--muted);margin:0 0 .2rem;line-height:1.6}.title-input{width:100%;border:1px solid var(--line);border-radius:12px;padding:.8rem .9rem;background:var(--card)}.title-link{border:none;background:transparent;color:var(--muted);font-size:.85rem;text-decoration:underline;padding:.3rem}.onboard{max-width:420px;margin:1.5rem auto 0}.onboard-title{font-size:1.15rem;text-align:center;margin:0 0 1.5rem;letter-spacing:.04em}.onboard-step{border:1px solid var(--line);border-radius:14px;padding:1rem 1.1rem;margin-bottom:1rem;background:var(--card)}.onboard-step.active{border-color:var(--accent);box-shadow:0 2px 10px #e8896b1f}.onboard-step.done{opacity:.85}.onboard-step-head{display:flex;align-items:center;gap:.5rem;font-weight:700;margin-bottom:.8rem}.onboard-num{display:inline-flex;align-items:center;justify-content:center;width:1.6rem;height:1.6rem;border-radius:50%;background:var(--accent);color:#fff;font-size:.9rem}.onboard-fields{display:flex;flex-direction:column;gap:.5rem}.onboard-fields input{border:1px solid var(--line);border-radius:10px;padding:.65rem .8rem;background:#fffdfb}.onboard-btn{width:100%;margin-top:.8rem;padding:.7rem}.share-btn{border:1px solid var(--accent);background:var(--accent);color:#fff;border-radius:999px;padding:.35rem .9rem;font-size:.85rem;font-weight:700}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;background:#00000059;display:flex;align-items:center;justify-content:center;padding:1.5rem}.modal{background:var(--card);border-radius:14px;padding:1.1rem 1.2rem 1.3rem;width:100%;max-width:360px;box-shadow:0 8px 30px #0000002e}.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.6rem;font-size:1.05rem}.modal .drawer-close{display:block}.sync-help{font-size:.8rem;color:var(--muted);margin:.2rem 0 .7rem;line-height:1.6}.sync-code-box{display:flex;align-items:center;gap:.4rem;background:var(--accent-soft);border-radius:8px;padding:.5rem .6rem}.sync-code{flex:1;font-size:.95rem;word-break:break-all;color:var(--ink)}.invite-text{width:100%;border:1px solid var(--line);border-radius:10px;padding:.7rem .8rem;background:#fffdfb;font-family:inherit;font-size:.85rem;line-height:1.6;color:var(--ink);resize:vertical;margin-bottom:.7rem}.muted{color:var(--muted)}.row-end{display:flex;justify-content:flex-end;gap:.5rem}.loading{font-size:.8rem;color:var(--accent)}
