:root{--bg: #faf7f2;--card: #ffffff;--ink: #2b2b2b;--muted: #8a8175;--line: #e8e1d6;--accent: #e8896b;--accent-soft: #fbe9e3;--ok: #4f9d69;--ng: #c0654f;--ink-soft: #4f4840;--lp-papa: #5b7c9e;--lp-papa-ink: #3f5b76;--lp-papa-bg: #eef3f8;--lp-papa-line: #cadae8;--lp-mama: #c57b86;--lp-mama-ink: #9d5a66;--lp-mama-bg: #f8eef0;--lp-mama-line: #ead0d5;--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;--font-rounded: "Kiwi Maru", var(--font-mincho)}*{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}.sidebar-link{display:block;width:100%;margin-top:1.5rem;border:1px solid var(--line);background:var(--card);color:var(--ink);border-radius:10px;font-size:.85rem;text-align:center;padding:.55rem}.sidebar-link:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.back-to-top{display:block;width:100%;margin-top:.6rem;border:none;background:transparent;color:var(--muted);opacity:.6;font-size:.8rem;text-align:center;padding:.5rem}.back-to-top:hover{opacity:1;text-decoration:underline}.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}.logo-btn{display:inline-flex;align-items:center;border:none;background:transparent;padding:0;cursor:pointer;color:inherit}.topbar-logo-btn{display:none}.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-cell .name:not(.vertical){white-space:nowrap}.topbar{padding:.6rem .7rem;gap:.4rem}.topbar-title{display:none}.topbar-logo{display:block}.topbar-logo-btn{display:inline-flex}.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;min-width:0;border:1px solid var(--line);border-radius:10px;padding:.6rem .8rem;background:var(--card)}.add-row .btn{flex-shrink:0;white-space:nowrap}.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{margin-bottom:1rem}.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}.icon-btn{border:none;background:transparent;color:var(--muted);font-size:1rem;line-height:1;padding:.2rem .3rem;border-radius:6px}.icon-btn:hover{color:var(--accent);background:var(--accent-soft)}.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-preview{container-type:inline-size}.fullname-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem}@container (min-width: 560px){.fullname-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}.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-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)}.fav-star.me{box-shadow:0 0 0 2px var(--accent-soft)}.fav-star.readonly{opacity:.55;cursor:default}.role-btn{border:1px solid var(--line);background:var(--card);border-radius:999px;padding:.3rem .7rem;font-size:.8rem;color:var(--muted);white-space:nowrap}.role-btn.set{border-color:var(--accent);color:var(--accent);background:var(--accent-soft);font-weight:700}.role-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:50;padding:1rem}.role-modal{background:var(--card);border-radius:16px;padding:1.3rem;width:100%;max-width:320px;text-align:center}.role-modal-title{font-size:1.1rem;font-weight:700;margin:0 0 .3rem}.role-modal-sub{font-size:.8rem;color:var(--muted);margin:0 0 1rem}.role-options{display:flex;flex-direction:column;gap:.6rem}.role-option{display:flex;align-items:center;justify-content:center;gap:.4rem;border:1px solid var(--line);background:var(--card);border-radius:12px;padding:.7rem 1rem;font-size:1rem;font-weight:700;color:var(--ink)}.role-option.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.role-option-note{font-size:.7rem;font-weight:400;color:var(--muted)}.comments{margin-bottom:.3rem}.comment-list{list-style:none;margin:0 0 .6rem;padding:0;display:flex;flex-direction:column;gap:.4rem}.comment{display:flex;align-items:flex-start;gap:.5rem;font-size:.9rem}.comment-badge{flex-shrink:0;font-size:.7rem;font-weight:700;border-radius:999px;padding:.1rem .5rem;line-height:1.4}.comment-badge.self{background:#e6f0fb;color:#2f6db0}.comment-badge.partner{background:#fbe6ef;color:#b03f74}.comment-text{flex:1;white-space:pre-wrap;word-break:break-word}.comment-del{flex-shrink:0;border:none;background:transparent;color:var(--muted);font-size:.8rem;cursor:pointer;padding:0 .2rem}.comment-input{display:flex;gap:.4rem}.comment-input input{flex:1;border:1px solid var(--line);border-radius:10px;padding:.5rem .7rem;background:var(--card);font-size:.9rem}.comment-viewer-note{font-size:.8rem;color:var(--muted);margin:0}.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-chip.popular{border-color:var(--accent);background:var(--accent-soft)}.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}.lp{min-height:100vh;background:var(--bg);font-family:var(--font-rounded);--lp-body: 1.0625rem}.lp-section,.lp-final{max-width:560px;margin:0 auto;padding:3.4rem 1.4rem}.lp-hero{max-width:560px;margin:0 auto;padding:3.2rem 1.4rem 2.4rem;text-align:center;background:radial-gradient(120% 70% at 50% 0%,var(--accent-soft) 0%,var(--bg) 65%)}.lp-brand{margin-bottom:1.6rem}.lp-brand-logo{font-size:1.5rem}.lp-hero-title{font-family:var(--font-rounded);font-size:2.3rem;line-height:1.4;letter-spacing:.04em;margin:0 0 1.2rem;color:var(--ink)}.lp-hero-sub{color:var(--ink-soft);font-size:var(--lp-body);line-height:1.95;margin:0 0 2.1rem}.lp-demo{width:100%;max-width:340px;min-height:31.5rem;margin:0 auto 2rem;text-align:left;background:#fbf8f2;border:1px solid var(--line);border-radius:18px;padding:1rem .9rem 1.1rem}.lp-demo-field{display:flex;align-items:center;gap:.5rem;min-height:2.9rem;background:var(--card);border:1px solid var(--line);border-radius:11px;padding:.6rem .8rem;margin-bottom:.9rem}.lp-demo-tag{flex:none;font-size:.62rem;color:var(--muted);background:var(--accent-soft);border-radius:6px;padding:.12rem .45rem}.lp-demo-typed{font-size:1.05rem;color:var(--ink);letter-spacing:.12em;line-height:1.2}.lp-demo-cursor{display:inline-block;width:2px;height:1.1rem;background:var(--accent);vertical-align:-.18rem;margin-left:1px;animation:lp-demo-blink 1s steps(1) infinite}@keyframes lp-demo-blink{50%{opacity:0}}.lp-demo-grid{display:grid;grid-template-columns:1fr 1fr;gap:.55rem}.lp-demo-card{background:var(--card);border:1px dashed var(--line);border-radius:11px;padding:.55rem .4rem .7rem;text-align:center;opacity:0;transform:translateY(8px);transition:opacity .45s ease,transform .45s ease}.lp-demo-card.show{opacity:1;transform:none}.lp-demo-cap{display:block;font-size:.55rem;color:var(--muted);margin-bottom:.3rem}.lp-demo-kanji{writing-mode:vertical-rl;font-size:1.5rem;line-height:1.15;color:var(--ink);height:3.9rem;display:inline-block}.lp-demo-kanji.mincho{font-family:var(--font-mincho)}.lp-demo-kanji.gothic{font-family:var(--font-gothic)}.lp-demo-kanji.brush{font-family:var(--font-brush)}.lp-demo-kanji.textbook{font-family:var(--font-textbook)}.lp-demo-mean{font-size:.78rem;line-height:1.7;color:var(--muted);text-align:center;margin-top:.85rem;min-height:2.8rem;opacity:0;transition:opacity .45s ease}.lp-demo-mean.show{opacity:1}.lp-demo-react{margin-top:.7rem;min-height:4.4rem}.lp-demo-msg{display:flex;flex-direction:column;gap:.18rem;max-width:82%;margin-top:.5rem;opacity:0;transform:translateY(12px) scale(.98);transition:opacity .55s ease,transform .55s cubic-bezier(.2,.75,.25,1)}.lp-demo-msg.show{opacity:1;transform:none}.lp-demo-msg.papa{align-items:flex-end;margin-left:auto}.lp-demo-msg.mama{align-items:flex-start;margin-right:auto}.lp-demo-name{display:flex;align-items:center;gap:.12rem;font-size:.62rem;padding:0 .2rem}.lp-demo-msg.papa .lp-demo-name{color:var(--lp-papa)}.lp-demo-msg.mama .lp-demo-name{color:var(--lp-mama)}.lp-demo-star{color:var(--accent)}.lp-demo-bubble{position:relative;font-size:.8rem;line-height:1.3;padding:.45rem .7rem;border:1px solid;border-radius:14px;min-height:2.15rem;box-sizing:border-box}.lp-demo-msg.papa .lp-demo-bubble{color:var(--lp-papa-ink);background:var(--lp-papa-bg);border-color:var(--lp-papa-line);border-bottom-right-radius:4px}.lp-demo-msg.papa .lp-demo-bubble:after{content:"";position:absolute;right:-5px;bottom:7px;border-style:solid;border-width:5px 0 5px 6px;border-color:transparent transparent transparent var(--lp-papa-bg)}.lp-demo-msg.mama .lp-demo-bubble{color:var(--lp-mama-ink);background:var(--lp-mama-bg);border-color:var(--lp-mama-line);border-bottom-left-radius:4px}.lp-demo-msg.mama .lp-demo-bubble:after{content:"";position:absolute;left:-5px;bottom:7px;border-style:solid;border-width:5px 6px 5px 0;border-color:transparent var(--lp-mama-bg) transparent transparent}@media (prefers-reduced-motion: reduce){.lp-demo-cursor{animation:none}}.lp-cta{display:flex;flex-direction:column;gap:.7rem;max-width:320px;margin:0 auto}.lp-cta-main{width:100%;padding:.95rem 1rem;font-size:1.1rem;border-radius:14px}.lp-cta-sub{width:100%;padding:.8rem 1rem;font-size:1rem;border-radius:14px}.lp-resume{display:block;max-width:320px;margin:1rem auto 0;border:none;background:transparent;color:var(--muted);font-size:.875rem;text-align:center;text-decoration:underline;padding:.3rem}.lp-code{max-width:320px;margin:1rem auto 0;text-align:left;display:flex;flex-direction:column;gap:.6rem;padding:1rem;background:var(--card);border:1px solid var(--line);border-radius:14px}.lp-code-hint{font-size:.875rem;color:var(--muted);line-height:1.6;margin:0}.lp-code-input{width:100%;border:1px solid var(--line);border-radius:12px;padding:.75rem .85rem;background:var(--bg)}.lp-code-btn{width:100%;padding:.75rem 1rem;border-radius:12px}.lp-section-soft{background:var(--accent-soft);max-width:none;padding-left:1.4rem;padding-right:1.4rem;display:flex;flex-direction:column;align-items:center}.lp-section-soft>*{width:100%;max-width:560px}.lp-h2{font-size:1.7rem;letter-spacing:.03em;text-align:center;margin:0 0 2rem;color:var(--ink)}.lp-pains{display:flex;flex-direction:column;gap:1rem}.lp-pain{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.3rem;background:var(--card);border:1px solid var(--line);border-radius:14px;font-size:var(--lp-body);line-height:1.6}.lp-pain-icon{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:2.6rem;height:2.6rem;border-radius:12px;background:var(--accent-soft);color:var(--accent)}.lp-icon{display:block}.lp-step-icon{display:inline-flex;vertical-align:-.35em;margin-right:.35rem;color:var(--accent)}.lp-step-icon .lp-icon{width:22px;height:22px}@media (prefers-reduced-motion: no-preference){.lp-icon-sound{animation:lp-icon-pulse 2.6s ease-in-out infinite;transform-origin:center}@keyframes lp-icon-pulse{0%,to{transform:scale(1);opacity:.85}50%{transform:scale(1.1);opacity:1}}.lp-icon-sparkle{animation:lp-twinkle 3s ease-in-out infinite;transform-origin:center}@keyframes lp-twinkle{0%,to{transform:scale(1) rotate(0)}50%{transform:scale(1.1) rotate(6deg)}}}.lp-steps{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1.4rem}.lp-step{display:flex;gap:.9rem;align-items:flex-start}.lp-step-num{flex-shrink:0;width:2rem;height:2rem;border-radius:50%;background:var(--accent);color:#fff;font-weight:700;display:flex;align-items:center;justify-content:center}.lp-step-body{display:flex;flex-direction:column;gap:.25rem}.lp-step-title{font-weight:700;font-size:1.25rem}.lp-step-text{font-size:var(--lp-body);color:var(--ink-soft);line-height:1.85}.lp-features{display:grid;grid-template-columns:1fr;gap:.9rem}.lp-feature{padding:1.1rem 1.2rem;background:var(--card);border:1px solid var(--line);border-radius:14px;display:flex;flex-direction:column;gap:.4rem}.lp-feature-title{font-weight:700;font-size:1.25rem;color:var(--accent)}.lp-feature-text{font-size:var(--lp-body);color:var(--ink-soft);line-height:1.85}.lp-fdemo{width:100%;aspect-ratio:16 / 9;margin-bottom:.6rem;border:1px solid var(--line);border-radius:12px;background:radial-gradient(120% 90% at 50% 0%,#fff 0%,var(--accent-soft) 115%);overflow:hidden;display:flex;align-items:center;justify-content:center;padding:.7rem}.lp-fdemo-review{max-width:440px;margin-top:1.6rem}.lp-fd-fonts{display:grid;grid-template-columns:repeat(4,1fr);gap:.4rem;width:100%;height:100%}.lp-fd-ff{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;background:var(--card);border:1px solid var(--line);border-radius:9px}.lp-fd-ff-cap{font-size:.5rem;color:var(--muted)}.lp-fd-ff-kanji{writing-mode:vertical-rl;font-size:1.35rem;line-height:1.1;color:var(--ink)}.lp-fd-ff-kanji.mincho{font-family:var(--font-mincho)}.lp-fd-ff-kanji.gothic{font-family:var(--font-gothic)}.lp-fd-ff-kanji.brush{font-family:var(--font-brush)}.lp-fd-ff-kanji.textbook{font-family:var(--font-textbook)}.lp-fd-koseki{display:flex;flex-direction:column;align-items:center;gap:.7rem}.lp-fd-koseki-row{display:flex;gap:.5rem}.lp-fd-kc{position:relative;width:2.6rem;height:2.6rem;display:flex;align-items:center;justify-content:center;font-family:var(--font-mincho);font-size:1.5rem;color:var(--ink);background:var(--card);border:1px solid var(--line);border-radius:9px}.lp-fd-ok{position:absolute;right:-.35rem;top:-.35rem;width:1.15rem;height:1.15rem;border-radius:50%;background:var(--ok);color:#fff;font-size:.72rem;font-style:normal;display:flex;align-items:center;justify-content:center}.lp-fd-koseki-label{font-size:.78rem;font-weight:700;color:var(--ok)}.lp-fd-suggest{width:100%;max-width:240px;display:flex;flex-direction:column;gap:.5rem}.lp-fd-sgfield{display:flex;align-items:center;gap:.4rem;background:var(--card);border:1px solid var(--line);border-radius:9px;padding:.4rem .55rem}.lp-fd-sgtag{font-size:.55rem;color:var(--muted);background:var(--accent-soft);border-radius:5px;padding:.1rem .35rem}.lp-fd-sgtyped{font-size:.9rem;letter-spacing:.08em;color:var(--ink)}.lp-fd-sgchips{display:flex;flex-wrap:wrap;gap:.35rem}.lp-fd-sgchip{font-family:var(--font-mincho);font-size:.85rem;color:var(--ink);background:var(--card);border:1px solid var(--line);border-radius:7px;padding:.2rem .5rem}.lp-fd-share{display:flex;align-items:center;gap:.4rem}.lp-fd-phone{flex:none;width:2.6rem;height:3.6rem;border-radius:8px;background:var(--card);border:1px solid var(--line);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.35rem}.lp-fd-phone-line{width:1.5rem;height:.28rem;border-radius:3px;background:var(--accent-soft)}.lp-fd-phone-line.short{width:1rem}.lp-fd-share-link{position:relative;display:flex;align-items:center;justify-content:center;min-width:5.5rem;height:1.4rem}.lp-fd-share-word{font-size:.62rem;color:var(--accent);background:var(--card);border:1px solid var(--accent-soft);border-radius:20px;padding:.12rem .5rem;white-space:nowrap}.lp-fd-share-dot{position:absolute;left:0;width:.45rem;height:.45rem;border-radius:50%;background:var(--accent)}.lp-fd-review{width:100%;max-width:320px;display:flex;flex-direction:column;gap:.7rem}.lp-fd-rv-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;background:var(--card);border:1px solid var(--line);border-radius:10px;padding:.45rem .6rem}.lp-fd-rv-kanji{font-family:var(--font-mincho);font-size:1.15rem;color:var(--ink)}.lp-fd-rv-rate{display:flex;gap:.35rem}.lp-fd-rv-pill{display:inline-flex;align-items:center;gap:.15rem;font-size:.6rem;border-radius:20px;padding:.12rem .45rem;border:1px solid}.lp-fd-rv-pill.papa{color:var(--lp-papa);border-color:var(--lp-papa-line);background:var(--lp-papa-bg)}.lp-fd-rv-pill.mama{color:var(--lp-mama);border-color:var(--lp-mama-line);background:var(--lp-mama-bg)}.lp-fd-rv-pill svg{color:var(--accent)}.lp-fd-rv-msgs{display:flex;flex-direction:column;gap:.4rem}.lp-fd-rv-msg{max-width:80%;font-size:.7rem;line-height:1.3;padding:.35rem .55rem;border:1px solid;border-radius:12px}.lp-fd-rv-msg.papa{align-self:flex-end;color:var(--lp-papa-ink);background:var(--lp-papa-bg);border-color:var(--lp-papa-line);border-bottom-right-radius:4px}.lp-fd-rv-msg.mama{align-self:flex-start;color:var(--lp-mama-ink);background:var(--lp-mama-bg);border-color:var(--lp-mama-line);border-bottom-left-radius:4px}@media (prefers-reduced-motion: no-preference){.lp-fd-rv-msg{opacity:0;transform:translateY(6px);animation:lp-fd-chip 4s ease-in-out infinite}.lp-fd-rv-msg.mama{animation-delay:.5s}.lp-fd-ff{animation:lp-fd-hi 4s ease-in-out infinite}.lp-fd-ff:nth-child(2){animation-delay:1s}.lp-fd-ff:nth-child(3){animation-delay:2s}.lp-fd-ff:nth-child(4){animation-delay:3s}@keyframes lp-fd-hi{0%,25%,to{border-color:var(--line);transform:none}8%{border-color:var(--accent);transform:translateY(-3px)}}.lp-fd-ok{opacity:0;transform:scale(.5);animation:lp-fd-pop 3.6s ease-in-out infinite}.lp-fd-kc:nth-child(2) .lp-fd-ok{animation-delay:.35s}.lp-fd-kc:nth-child(3) .lp-fd-ok{animation-delay:.7s}@keyframes lp-fd-pop{0%,8%{opacity:0;transform:scale(.5)}20%,82%{opacity:1;transform:scale(1)}92%,to{opacity:0;transform:scale(.5)}}.lp-fd-sgchip{opacity:0;transform:translateY(6px);animation:lp-fd-chip 4s ease-in-out infinite}.lp-fd-sgchip:nth-child(2){animation-delay:.3s}.lp-fd-sgchip:nth-child(3){animation-delay:.6s}.lp-fd-sgchip:nth-child(4){animation-delay:.9s}@keyframes lp-fd-chip{0%,6%{opacity:0;transform:translateY(6px)}18%,85%{opacity:1;transform:none}95%,to{opacity:0;transform:translateY(6px)}}.lp-fd-share-dot{animation:lp-fd-travel 2.6s ease-in-out infinite}@keyframes lp-fd-travel{0%{left:0;opacity:0}15%{opacity:1}85%{opacity:1}to{left:calc(100% - .45rem);opacity:0}}}.lp-section-accent{text-align:center}.lp-statement-blob{position:relative;background:var(--accent-soft);border-radius:46% 54% 52% 48%/38% 40% 60% 62%;padding:3.4rem 3.2rem;margin:.5rem auto 0;max-width:560px}.lp-statement{font-family:var(--font-rounded);font-size:1.6rem;line-height:1.6;letter-spacing:.03em;margin:0 0 1.2rem;color:var(--ink)}.lp-statement-sub{font-size:var(--lp-body);color:var(--ink-soft);line-height:1.95;margin:0}.lp-assurances{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem 1rem}.lp-hero-assurances{margin:0 0 1.3rem}.lp-assurance{display:flex;align-items:center;gap:.4rem;font-size:.875rem;font-weight:700}.lp-assurance-check{color:var(--ok)}.lp-final{text-align:center;background:radial-gradient(120% 80% at 50% 100%,var(--accent-soft) 0%,var(--bg) 65%)}.lp-final-copy{font-family:var(--font-rounded);font-size:1.3rem;letter-spacing:.04em;margin:0 0 1.4rem}.lp-final .lp-cta-main{max-width:320px;margin:0 auto}.lp-footer{margin-top:2.6rem;opacity:.6}.lp-footer-logo{font-size:1.1rem}@media (min-width: 600px){.lp-features{grid-template-columns:1fr 1fr;gap:1.1rem}.lp-section-features{max-width:880px}.lp-section-accent{max-width:720px}.lp-statement-blob{max-width:620px;padding:4rem}.lp-section-features .lp-feature{padding:1.3rem 1.4rem}.lp-hero-title{font-size:2.7rem}.lp-h2{font-size:1.9rem}.lp-statement{font-size:1.8rem}}@media (min-width: 880px){.lp{--lp-body: 1.125rem}.lp-section,.lp-final{padding:4.8rem 1.4rem}.lp-hero{max-width:1040px;display:grid;grid-template-columns:1.05fr 1fr;gap:3.4rem;align-items:center;text-align:left;padding-top:5.5rem;padding-bottom:5rem}.lp-hero-title{font-size:3.2rem;line-height:1.35}.lp-h2{font-size:2.2rem;margin-bottom:2.6rem}.lp-statement{font-size:2.05rem}.lp-hero-sub,.lp-cta,.lp-code{margin-left:0;margin-right:0}.lp-hero-assurances{justify-content:flex-start}.lp-hero-copy .lp-resume{margin-left:0}.lp-hero-visual .lp-demo{margin:0 auto;max-width:380px}}.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}.name-suggest{margin-top:.9rem}.name-suggest-label{font-size:.75rem;color:var(--muted);margin:0 0 .5rem;letter-spacing:.04em}.name-suggest-row{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:.5rem}.name-suggest-tag{flex-shrink:0;font-size:.7rem;font-weight:700;color:var(--muted);padding-top:.35rem;width:2.8rem}.name-suggest-chips{display:flex;flex-wrap:wrap;gap:.35rem}.name-chip{border:1px solid var(--line);background:var(--card);color:var(--ink);border-radius:999px;padding:.3rem .7rem;font-size:.9rem}.name-chip:hover{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.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)}.ranking-page{min-height:100vh;background:var(--bg)}.ranking-head{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:.6rem;background:var(--bg);border-bottom:1px solid var(--line);padding:.7rem 1rem}.ranking-back{border:1px solid var(--line);background:var(--card);border-radius:8px;padding:.3rem .7rem;font-size:.85rem;color:var(--ink)}.ranking-title{font-size:1.05rem;margin:0}.ranking-body{max-width:560px;margin:0 auto;padding:1rem}.ranking-tabs{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:1rem}.ranking-tabgroup{display:inline-flex;border:1px solid var(--line);border-radius:999px;background:var(--card);overflow:hidden}.ranking-tab{border:none;background:transparent;color:var(--muted);padding:.4rem .9rem;font-size:.85rem}.ranking-tab.active{background:var(--accent-soft);color:var(--accent);font-weight:700}.ranking-list{list-style:none;margin:0;padding:0}.ranking-item{display:flex;align-items:baseline;gap:.8rem;padding:.55rem .3rem;border-bottom:1px solid var(--line)}.ranking-rank{flex-shrink:0;width:2rem;text-align:right;color:var(--muted);font-size:.85rem;font-weight:700}.ranking-name{font-size:1.15rem;font-weight:700}.ranking-name.kanji{font-family:var(--font-mincho);font-size:1.4rem}.ranking-yomi{color:var(--muted);font-size:.85rem}.ranking-source{margin-top:1.2rem;font-size:.75rem;color:var(--muted)}.ranking-source a{color:var(--accent)}.book-rec{margin:1.5rem 0 .5rem;border:1px solid var(--line);border-radius:14px;background:var(--card);padding:.9rem 1rem 1rem}.book-rec-pr{display:inline-block;font-size:.65rem;font-weight:700;letter-spacing:.04em;color:var(--muted);border:1px solid var(--line);border-radius:4px;padding:.05rem .35rem;margin-bottom:.7rem}.book-rec-body{display:flex;gap:.9rem;align-items:flex-start}.book-rec-cover{flex-shrink:0;width:88px;aspect-ratio:3 / 4.3;border-radius:6px;overflow:hidden;background:var(--accent-soft);border:1px solid var(--line);display:flex;align-items:center;justify-content:center}.book-rec-cover img{width:100%;height:100%;object-fit:cover;display:block}.book-rec-cover-fallback{font-family:var(--font-mincho);font-size:.6rem;line-height:1.4;color:var(--accent);padding:.4rem;text-align:center}.book-rec-main{min-width:0;flex:1}.book-rec-lead{margin:0 0 .2rem;font-size:.72rem;font-weight:700;color:var(--accent)}.book-rec-title{margin:0 0 .2rem;font-size:.95rem;line-height:1.4}.book-rec-byline{margin:0 0 .5rem;font-size:.72rem;color:var(--muted)}.book-rec-blurb{margin:0 0 .5rem;font-size:.82rem;line-height:1.6}.book-rec-stores{display:flex;flex-wrap:wrap;gap:.5rem}.book-rec-store{flex:1;min-width:120px;text-align:center;border:1px solid var(--line);border-radius:8px;background:var(--card);color:var(--ink);font-size:.82rem;font-weight:700;padding:.5rem .6rem;text-decoration:none}.book-rec-store:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.book-rec-affiliate-note{margin:.6rem 0 0;font-size:.68rem;line-height:1.6;color:var(--muted)}@media (max-width: 480px){.book-rec-body{flex-direction:column;align-items:center;text-align:center}.book-rec-stores{justify-content:center}}.site-footer{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--line)}.site-footer-links{display:flex;flex-wrap:wrap;gap:.5rem .9rem;justify-content:center}.site-footer-links button{border:none;background:transparent;color:var(--muted);font-size:.78rem;text-decoration:underline;padding:.2rem}.site-footer-links button:hover{color:var(--accent)}.legal-page{min-height:100vh;background:var(--bg)}.legal-head{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:.6rem;background:var(--bg);border-bottom:1px solid var(--line);padding:.7rem 1rem}.legal-back{border:1px solid var(--line);background:var(--card);border-radius:8px;padding:.3rem .7rem;font-size:.85rem;color:var(--ink)}.legal-title{font-size:1.05rem;margin:0}.legal-body{max-width:640px;margin:0 auto;padding:1.2rem 1rem 3rem;font-size:.9rem;line-height:1.8;color:var(--ink)}.legal-body p{margin:0 0 1rem}.legal-h2{font-size:1rem;margin:1.6rem 0 .5rem}.legal-dl{margin:0 0 1rem}.legal-dl dt{font-weight:700;font-size:.82rem;color:var(--muted);margin-top:.8rem}.legal-dl dd{margin:.1rem 0 0}.legal-body a{color:var(--accent)}.legal-contact-mail{font-size:1rem;font-weight:700}.legal-muted{font-size:.78rem;color:var(--muted)}.legal-disclosure{margin-top:2rem;padding-top:1rem;border-top:1px solid var(--line);font-size:.72rem;color:var(--muted)}
