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