*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}:root{--font-body-family: "Helvetica Neue", Arial, "Hiragino Sans", Meiryo, sans-serif}body{margin:0;font-family:var(--font-body-family);color:#111;background:#f5f6f8;line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:var(--font-body-family)}a{color:inherit;text-decoration:none}img{display:block;max-width:100%;height:auto}.container{width:calc(100% - 16px);margin-inline:auto}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.topnav{position:sticky;top:0;z-index:20;background:#fff;border-bottom:1px solid #e5e7eb}.nav-inner{display:flex;gap:16px;align-items:center;height:56px}.nav-link{display:inline-flex;align-items:center;height:56px;padding-inline:8px;color:#374151;border-bottom:2px solid transparent}.nav-link.active{color:#111418;border-color:#2563eb}:root{--bg: #f5f6f8;--panel: #ffffff;--text: #111418;--muted: #6b7280;--border: #e5e7eb;--accent: #2563eb}.panel{background:var(--panel);border:1px solid var(--border);border-radius:10px;box-shadow:0 1px 2px #1114180a;padding-left:0;padding-right:0}.panel+.panel{margin-top:16px}.panel-body{padding:16px}.panel-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;letter-spacing:.02em;color:var(--text);margin:0 0 12px;text-transform:uppercase}.filter-list{list-style:none;padding:0;margin:0}.filter-item{display:flex;justify-content:space-between;align-items:center;padding:8px 4px;color:var(--text);font-size:14px;border-bottom:1px solid var(--border)}.filter-item:last-child{border-bottom:0}.filter-count{color:var(--muted);font-variant-numeric:tabular-nums}.filter-item.clickable{cursor:pointer;transition:background-color .15s ease,border-color .15s ease}.filter-item.clickable:hover{background:#f8fafc}.filter-item.active{background:#eef2ff;border-color:#c7d2fe}.input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px}.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2563eb26}.textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px;resize:vertical}.textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2563eb26}.button{border:1px solid var(--border);background:#f8fafc;color:var(--text);padding:8px 12px;font-size:14px;border-radius:8px;cursor:pointer}.button.primary{background:var(--accent);border-color:var(--accent);color:#fff}.button-ghost{border-color:transparent;background:transparent;color:var(--accent)}.button-ghost:hover{background:#2563eb14}.button:disabled{opacity:.6;cursor:default}.btn-amazon{background:#f90;border-color:#f90;color:#fff}.btn-amazon:hover{background:#e68a00;border-color:#e68a00}.btn-rakuten{background:#bf0000;border-color:#bf0000;color:#fff}.btn-rakuten:hover{background:#a60000;border-color:#a60000}.btn-junkudo{background:#1b745e;border-color:#1b745e;color:#fff}.btn-junkudo:hover{background:#16634f;border-color:#16634f}.btn-kinokuniya{background:#004191;border-color:#004191;color:#fff}.btn-kinokuniya:hover{background:#003775;border-color:#003775}.btn-miraiya{background:#222;border-color:#222;color:#fff}.btn-miraiya:hover{background:#111;border-color:#111}.btn-kumazawa{background:#774635;border-color:#774635;color:#fff}.btn-kumazawa:hover{background:#633829;border-color:#633829}.main-header{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between;padding:12px 16px}.sort{display:inline-flex;align-items:center;gap:8px}.select{padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px;background:#fff}.grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;padding:16px}@media (max-width: 1200px){.grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 900px){.grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.grid{grid-template-columns:1fr}}.card{overflow:hidden;border-radius:10px;background:var(--panel);border:1px solid var(--border);box-shadow:0 1px 2px #1114180a;display:flex;flex-direction:column}.card-media{position:relative;width:100%;aspect-ratio:3 / 4;background:#e5e7eb;overflow:hidden}.card-media>img{display:block;width:100%;height:100%;object-fit:cover}.bookmark-read{position:absolute;top:0;right:6px;background:url(/bookmark.svg) no-repeat center / contain;color:#fff;font-weight:700;width:clamp(44px,16%,84px);aspect-ratio:64 / 112;height:auto;font-size:clamp(10px,1.2vw,13px);padding:0 6px;display:flex;align-items:center;justify-content:center;text-align:center;letter-spacing:.5px;line-height:1.1;text-shadow:0 1px 1px rgba(0,0,0,.2);z-index:1;pointer-events:none}.heart-btn{position:absolute;right:8px;left:auto;bottom:8px;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:999px;border:1px solid var(--border);background:#ffffffe6;box-shadow:0 1px 2px #11141814}.heart-btn:hover{background:#fff}.heart-btn.active{border-color:#f9a8d4;background:#fffffff2}.card-body{padding:10px 12px;display:flex;flex-direction:column}.card-title{font-size:14px;font-weight:700;color:var(--text);line-height:1.3;margin:0;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-meta{margin-top:6px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}.badge{font-size:11px;color:var(--muted);background:#f1f5f9;border:1px solid var(--border);padding:2px 6px;border-radius:999px}.badge-author{cursor:pointer;transition:background-color .15s ease,color .15s ease,border-color .15s ease}.badge-author:hover{background:#e2e8f0;color:var(--text);border-color:#cbd5e1}.card-actions{margin-top:auto;display:flex;gap:8px;justify-content:flex-end}.pill{font-size:12px;padding:4px 8px;border-radius:999px;border:1px solid var(--border);background:#f8fafc;color:#374151;cursor:pointer;transition:background-color .15s ease,color .15s ease,border-color .15s ease}.pill:hover{background:#eef2f7}.pill.active{background:var(--accent);border-color:var(--accent);color:#fff}.pill-danger{background:#fee2e2;border-color:#fecaca;color:#b91c1c}.pill-danger:hover{background:#fecaca}.loadmore{display:flex;justify-content:center;padding:0 16px 24px}.error{color:#b91c1c;background:#fee2e2;border:1px solid #fecaca;border-radius:10px;padding:10px 12px;margin:8px 16px;font-size:13px}.icon{width:16px;height:16px;color:var(--muted)}input.page-input::-webkit-outer-spin-button,input.page-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input.page-input{-moz-appearance:textfield}.view-toggle .button[aria-pressed=true] .icon{color:#fff}.view-toggle .button[aria-pressed=false] .icon{color:#9ca3af}@media (max-width: 480px){.bookmark-read{top:2px;right:2px;width:clamp(28px,14%,56px);font-size:clamp(8px,1.1vw,11px);line-height:1.1}}.subheader{padding:0 16px;margin:8px 0 0}.tabs{display:flex;align-items:center;gap:4px;border-bottom:1px solid var(--border);overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none}.tabs::-webkit-scrollbar{display:none}.tab{position:relative;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;color:var(--muted);font-size:14px;font-weight:700;padding:10px 12px;cursor:pointer;white-space:nowrap;border-radius:8px}.tab:hover{color:var(--text);background:#f8fafc}.tab.active{color:var(--text);background:#eef2ff;border:1px solid #c7d2fe}.tab.active:after{display:none}.tab[disabled]{opacity:.6;cursor:default}.layout{display:grid;gap:24px;padding:24px 0}.book-tab-scroll{padding:4px 0 12px}.book-main{display:grid;gap:12px;padding:0 0 24px}.author-indicator{margin:0 0 10px;padding:8px 12px;background:#eef2ff;border:1px solid #c7d2fe;color:var(--text);border-radius:9999px;font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:8px}.author-indicator-close{margin-left:auto;border:none;background:transparent;color:#6b7280;width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:9999px;cursor:pointer}.author-indicator-close:hover{background:#e5e7eb;color:#111827}@media (max-width: 600px){.grid.mode-list .card{display:flex;flex-direction:row;gap:12px;align-items:flex-start}.grid.mode-list .card-media{width:80px;min-width:80px;flex:0 0 80px;aspect-ratio:3 / 4;height:auto}.grid.mode-list .card-body{padding:0;flex:1 1 auto;display:flex;flex-direction:column}.grid.mode-list .card-title{font-size:14px;margin-bottom:4px;-webkit-line-clamp:2;line-clamp:2}.grid.mode-list .card-meta{gap:6px;margin-top:6px}.grid.mode-list .bookmark-read{top:2px;right:2px;width:24px;font-size:8px;line-height:1.05}}@media (max-width: 600px){.grid.mode-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.rating-stars{position:relative;display:inline-block;line-height:0}.rating-stars .stars-base,.rating-stars .stars-fill{display:flex;gap:2px}.rating-stars .stars-base .star{color:#d1d5db}.rating-stars .stars-fill{position:absolute;top:0;left:0;overflow:hidden;white-space:nowrap}.read-log-summary{margin-top:16px;padding:16px 18px;border:1px solid rgba(37,99,235,.18);border-radius:14px;background:#2563eb0f;display:grid;gap:12px;position:relative}.read-log-row{display:flex;justify-content:space-between;gap:12px;font-size:14px;align-items:center}.read-log-label{font-weight:600;color:#0f172ab3}.read-log-value{font-weight:600;color:var(--text)}.read-log-memo{margin:0;font-size:14px;line-height:1.6;color:var(--text);white-space:pre-wrap}.read-log-memo.is-empty{color:var(--muted);font-style:italic}.read-log-edit{position:absolute;bottom:12px;right:12px;border:none;background:#ffffffd9;width:32px;height:32px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;color:var(--muted);box-shadow:0 2px 4px #0f172a1f;cursor:pointer;transition:background-color .15s ease,color .15s ease}.read-log-edit:hover{background:#fff;color:var(--accent)}.read-log-edit:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.read-log-links{display:flex;gap:8px}.read-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:24px;z-index:999}.read-modal{width:min(680px,100%);background:#fff;border-radius:18px;box-shadow:0 24px 60px -32px #0f172a99;overflow:hidden}.read-modal-header{padding:20px 24px 12px;border-bottom:1px solid var(--border)}.read-modal-header h2{margin:0;font-size:18px}.read-modal-body{display:flex;flex-direction:column;gap:16px;padding:18px 24px 24px}.read-modal-book{display:flex;gap:16px;align-items:center;padding:12px 0 4px}.read-modal-book img,.read-modal-book-placeholder{width:72px;height:108px;border-radius:10px;object-fit:cover;background:#e5e7eb;flex-shrink:0}.read-modal-book-placeholder{display:flex;align-items:center;justify-content:center;color:#9ca3af;font-size:12px}.read-modal-book-meta{display:flex;flex-direction:column;gap:4px;color:var(--text)}.read-modal-book-label{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.read-modal-book-title{margin:0;font-size:16px;font-weight:700;line-height:1.4}.read-modal-toggle{display:inline-flex;align-items:center;gap:10px;font-size:14px;color:var(--text);-webkit-user-select:none;user-select:none}.read-modal-toggle input{width:18px;height:18px}.read-modal-field{display:flex;flex-direction:column;gap:6px;font-size:14px;color:var(--text)}.read-modal-field>span{font-weight:600}.read-modal-error{color:#dc2626;font-size:13px}.read-modal-actions{display:flex;justify-content:flex-end;gap:12px}.read-log-panel{padding:24px;display:grid;gap:24px}.read-log-header{display:flex;flex-direction:column;gap:8px}.read-log-header h1{margin:0;font-size:24px}.read-log-book{display:flex;flex-direction:column;gap:4px;color:var(--muted)}.read-log-book-title{font-weight:700;color:var(--text)}.read-log-book-author{font-size:13px}.read-log-content dl{margin:0;display:grid;gap:12px}.read-log-content .read-log-row{align-items:flex-start}.read-log-content dt{font-weight:600;color:var(--muted);min-width:80px}.read-log-content dd{margin:0;flex:1 1 auto;white-space:pre-wrap;color:var(--text)}.read-log-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:12px}.read-log-empty{display:grid;gap:16px;justify-items:flex-start}@media (max-width: 600px){.read-modal{border-radius:12px}.read-modal-body{padding:16px}.read-modal-book{gap:12px}.read-modal-book img,.read-modal-book-placeholder{width:64px;height:96px}.read-log-panel{padding:16px}}.shelf-panel{display:grid;gap:12px}.shelf-controls-scroll{display:flex;gap:16px;align-items:center;overflow-x:auto;overflow-y:hidden;margin:0;min-height:50px;height:50px;border-bottom:1px solid var(--border)}.grid.shelf-grid{padding:0}.shelf-controls-scroll::-webkit-scrollbar{height:6px}.grid.books-grid{padding:0}.shelf-controls-scroll::-webkit-scrollbar-thumb{background:#0f172a33;border-radius:999px}.shelf-tab-group{display:inline-flex;gap:0;flex:0 0 auto;height:50px;align-items:center}.shelf-tab{position:relative;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:transparent;font-size:15px;font-weight:600;color:var(--muted);padding:0 16px;cursor:pointer;transition:color .2s ease}.shelf-tab:hover,.shelf-tab:focus-visible{color:var(--text)}.shelf-tab.is-active{color:var(--text)}.shelf-tab.is-active:after{content:"";position:absolute;left:16px;right:16px;bottom:-1px;height:2px;background:var(--accent)}.read-stats-inline{display:none}.read-stats-inline.open{display:flex;flex-direction:column;gap:18px;margin-top:20px;padding:18px 0;border-top:1px solid rgba(148,163,184,.25)}.read-stats-block{display:flex;flex-direction:column;gap:12px}.read-stats-block-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}@media (min-width: 1024px){.read-stats-block-header{flex-wrap:nowrap}.read-stats-range-toggle{margin-left:auto}}.read-stats-range-toggle{display:inline-flex;border:1px solid var(--border);border-radius:999px;overflow:hidden;background:#fff}.read-stats-range-toggle>button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:transparent;padding:6px 12px;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;transition:background-color .15s ease,color .15s ease}.read-stats-range-toggle>button.is-active{background:var(--accent);color:#fff}.read-stats-range-toggle>button:not(.is-active):hover{background:#2563eb14;color:var(--text)}.stats-toggle{display:flex}.stats-toggle-desktop{display:none}.stats-chart-shell{display:grid;grid-template-columns:40px minmax(0,1fr) 40px;align-items:center;gap:8px;justify-content:center}.stats-chart-shell .chart-wrapper{margin:0 auto}.stats-nav-mobile{display:inline-flex}.stats-nav{border:none;background:#94a3b833;width:32px;height:32px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;color:var(--muted);cursor:pointer;transition:background-color .15s ease,color .15s ease}.stats-nav:hover:not(:disabled){background:#2563eb2e;color:var(--accent)}.stats-nav:disabled{opacity:.4;cursor:default}.pie-shell{display:grid;gap:12px;justify-items:center}.pie-shell .read-stats-pie{width:100%}.pie-next{display:none}.chart-wrapper,.read-stats-pie{max-width:700px;width:100%}.read-sort{display:inline-flex;align-items:center;gap:8px;padding:0 16px;justify-self:end}.read-sort-label{font-size:12px;color:var(--muted);font-weight:600}@media (min-width: 1024px){.stats-toggle-mobile{display:none}.stats-toggle-desktop{display:flex;align-items:center;gap:8px}.stats-toggle-desktop .stats-nav{width:32px;height:32px}.stats-toggle-desktop .read-stats-range-toggle{margin-left:auto}.pie-shell{display:inline-flex;align-items:center;gap:12px}.pie-shell .read-stats-pie{margin:0}.pie-shell .stats-nav{position:static}.pie-next{display:inline-flex}.stats-nav-mobile{display:none}}.read-stats-row{display:grid;gap:24px}.read-stats-block-chart,.read-stats-block-pie{min-width:0}.read-stats-block-pie{display:flex;flex-direction:column;align-items:flex-start;gap:20px;justify-content:flex-start;height:100%;text-align:left;position:relative}@media (min-width: 1024px){.read-stats-row{grid-template-columns:minmax(0,1.2fr) minmax(360px,1fr);align-items:stretch}}.read-stats-block h3{margin:0;font-size:13px;font-weight:600;color:var(--muted)}.read-stats-axis{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);padding:0 4px}.read-stats-chart{display:inline-flex;gap:12px;align-items:flex-end}.read-stats-bar{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:32px;color:var(--muted)}.read-stats-bar-fill{width:100%;min-height:4px;border-radius:6px;background:linear-gradient(180deg,#2563ebd9,#2563eb73);display:flex;align-items:flex-end;justify-content:center;padding-bottom:4px}.read-stats-bar-value{font-size:10px;font-weight:600;color:#fff;background:#0f172a59;padding:2px 4px;border-radius:999px}.read-stats-bar-label{font-size:11px}.shelf-count-line{display:flex;justify-content:space-between;align-items:baseline;font-size:14px;padding-top:4px;color:var(--muted)}.shelf-count-label{font-weight:600;color:var(--text)}.shelf-count-value{font-weight:600}.read-stats-page{display:grid;gap:20px;margin-top:16px}.read-stats-summary{display:inline-flex;gap:18px;align-items:center}.read-stats-summary-item{display:flex;flex-direction:column;gap:4px}.summary-label{font-size:12px;color:var(--muted)}.summary-value{font-size:18px;color:var(--text)}.read-stats-pie{display:flex;flex-direction:column;align-items:center;gap:20px;width:100%;flex:1 1 auto;align-self:center;justify-content:center}.read-stats-pie-visual{width:clamp(240px,70vw,360px);height:clamp(240px,70vw,360px);border-radius:50%;display:flex;align-items:center;justify-content:center}@media (min-width: 1024px){.read-stats-pie-visual{width:clamp(360px,42vw,540px);height:clamp(360px,42vw,540px)}}.read-stats-pie-svg{width:100%;height:100%}.read-stats-legend{list-style:none;margin:0;padding:0;display:grid;gap:6px;min-width:180px;justify-items:start;width:100%;align-self:stretch}.read-stats-legend li{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text);justify-content:flex-start}.legend-dot{width:10px;height:10px;border-radius:50%}.legend-name{flex:1 1 auto}.legend-value{color:var(--muted)}.read-stats-empty{margin:0;font-size:14px;color:var(--muted)}@media (max-width: 600px){.shelf-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 720px){.shelf-tab-group{padding:16px}.read-stats-card{flex:0 0 280px}}.detail-hero{padding:20px 24px}.detail-layout{display:grid;grid-template-columns:320px 1fr;gap:32px;align-items:start;max-width:1024px;margin-inline:auto;width:100%}.detail-left,.detail-right{padding-top:12px}.detail-left{display:block;position:relative}.detail-image{border-radius:8px;background-position:center;background-size:cover;background-repeat:no-repeat}.detail-right{display:flex;flex-direction:column;gap:8px}.detail-breadcrumbs{color:var(--muted)}.detail-title{font-size:28px;margin:0}.detail-authors{color:var(--text);display:flex;flex-wrap:wrap;align-items:center;gap:6px}.detail-authors .author-sep{color:var(--muted)}.author-link{background:none;border:none;color:var(--accent);text-decoration:underline;cursor:pointer;padding:0;font:inherit}.author-link:hover{opacity:.85}.detail-price{margin-top:4px;padding:6px 0}.detail-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}.detail-actions .button{min-width:120px;width:auto;display:inline-flex;justify-content:center;align-items:center;text-align:center;white-space:nowrap}.detail-meta-lines{display:flex;flex-direction:column;gap:4px;max-width:320px;font-size:13px}.detail-meta-under{max-width:80%;margin:8px auto 0;text-align:left}.detail-meta-lines>div{display:flex;justify-content:flex-start;align-items:baseline;gap:0}.detail-meta-value{color:#111418}.detail-price-value{font-size:18px;font-weight:700;color:var(--text)}.only-mobile{display:none}.only-desktop{display:block}.detail-links{margin-top:16px;display:grid;gap:16px}.detail-link-section{display:grid;gap:8px}.detail-link-title{display:inline-flex;align-items:center;gap:8px}.detail-link-list{display:flex;gap:8px;flex-wrap:wrap}.detail-link-list>.button{width:120px;display:inline-flex;justify-content:center;align-items:center;text-align:center}.desc-toggle{border:none;background:none;color:var(--accent);text-decoration:underline;cursor:pointer;font:inherit;padding:0;margin:0 0 8px}.desc-collapsible{cursor:pointer}.detail-link-heading{font-size:16px;font-weight:600;margin:6px 0 4px;color:var(--muted);display:inline-flex;align-items:center;gap:8px}.detail-link-heading .icon{color:var(--muted);width:18px;height:18px}.read-stats-year-summary{display:grid;gap:4px;justify-items:center;margin-bottom:16px;font-size:16px;color:var(--text)}.year-count{font-size:20px;font-weight:700}@media (max-width: 900px){.detail-layout{grid-template-columns:280px 1fr;gap:20px}.detail-title{font-size:24px}.detail-meta-lines{max-width:280px}}@media (min-width: 901px){.detail-hero{padding:24px 40px}.detail-layout{grid-template-columns:380px 1fr;gap:40px}.detail-left,.detail-right{padding-top:18px}}@media (max-width: 600px){.detail-layout{grid-template-columns:1fr}.detail-actions{justify-content:flex-start}.detail-actions{gap:4px}.detail-actions .button{min-width:120px;width:auto;flex:1 1 120px;gap:4px}.detail-meta-lines{max-width:none}.detail-links{gap:14px}.detail-link-heading{font-size:15px}.detail-price-value{font-size:17px}.only-mobile{display:block}.only-desktop{display:none}.detail-link-list{justify-content:flex-start;gap:8px}.detail-link-list>.button{flex:1 1 calc(33.333% - 2px)}}@media (max-width: 600px){.desc-toggle{display:none}}.recent-section{padding:12px 16px 8px}.recent-title{display:inline-flex;align-items:center;gap:8px;color:var(--text);font-size:20px;font-weight:700;margin:0 0 10px}.recent-list{display:flex;gap:12px;flex-wrap:nowrap;align-items:stretch;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scroll-snap-type:x proximity}.recent-item{display:flex;flex-direction:column;width:120px;text-decoration:none;color:inherit;border:1px solid var(--border);border-radius:10px;background:#fff;box-shadow:0 1px 2px #1114180a;transition:opacity .2s ease;flex:0 0 auto;scroll-snap-align:start;position:relative}.recent-item:hover{opacity:.85}.recent-thumb{width:100%;aspect-ratio:3 / 4;border-top-left-radius:10px;border-top-right-radius:10px;overflow:hidden}.recent-thumb img{width:100%;height:100%;object-fit:cover;display:block}.recent-name{padding:6px 8px 8px;font-size:12px;line-height:1.35;color:var(--text);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.recent-remove{position:absolute;top:6px;right:6px;width:24px;height:24px;border:none;border-radius:999px;background:#ffffffeb;color:var(--muted);display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0f172a2e;cursor:pointer;transition:transform .15s ease,opacity .15s ease}.recent-remove:hover{opacity:.85;transform:scale(1.05)}.recent-remove:focus{outline:2px solid var(--border-strong);outline-offset:1px}.detail-actions .icon{flex-shrink:0}#root{width:100%}.header{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid var(--border)}.header-title{font-size:24px;font-weight:700;margin:0;color:var(--text)}.app-header{border-bottom:1px solid var(--border);background:#fff;position:sticky;top:0;z-index:900;transition:transform .2s ease-in-out;will-change:transform}.app-header.header-floating{box-shadow:0 4px 12px #0000000f}.app-header.header-hidden{transform:translateY(-100%)}.app-header-inner{max-width:none;width:100%;padding:10px 16px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px}.brand-and-nav{display:flex;align-items:center;gap:24px;flex:1 1 auto}.brand{display:flex;align-items:center;gap:8px;color:var(--text)}.brand-icon{display:inline-flex;width:16px;height:16px;color:var(--text)}.brand-title{font-size:18px;font-weight:700;margin:0}.nav-links{display:flex;align-items:center;gap:18px}.nav-link{color:var(--text);font-size:14px;text-decoration:none;padding:6px 2px;border-bottom:2px solid transparent}.nav-link.active{border-bottom-color:var(--accent);color:var(--accent)}.header-right{display:flex;gap:8px;align-items:center;margin-left:auto}.user-menu-wrap{position:relative}.user-menu-trigger{border:none;background:transparent;color:var(--text);padding:6px;border-radius:9999px;cursor:pointer}.user-menu-trigger:hover{background:#0000000d}.user-menu-trigger .user-avatar{width:32px;height:32px;border-radius:9999px;display:block}.user-menu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid var(--border);border-radius:10px;min-width:180px;box-shadow:0 12px 28px #0000001f;z-index:1100;padding:6px;opacity:0;transform:translateY(-4px);pointer-events:none;transition:opacity .15s ease,transform .15s ease}.user-menu.open{opacity:1;transform:translateY(0);pointer-events:auto}.user-menu-item{width:100%;display:flex;align-items:center;gap:8px;padding:10px;border:none;background:transparent;color:var(--text);border-radius:8px;cursor:pointer}.user-menu-item:hover{background:#f3f4f6}.header-right .nav-link.active{border-bottom-color:transparent;color:var(--accent)}.badge-author{cursor:pointer;transition:all .2s ease;border:1px solid transparent}.badge-author:hover{background-color:#f0f8ff;border-color:#06c;color:#06c;transform:translateY(-1px);box-shadow:0 2px 4px #06c3}.nav-search{flex:1;max-width:500px;margin-right:16px}.nav-search-form{display:flex;align-items:center;gap:8px;padding:4px;border:1px solid #d1d5db;border-radius:9999px;background:#fff;position:relative}.nav-search-genre{border:none;background:none;padding:6px 8px;font-size:14px;color:#374151;cursor:pointer;min-width:80px}.nav-search-genre:focus{outline:none}.nav-search-input{flex:1;border:none;background:none;padding:6px 8px;font-size:14px;color:#374151}.nav-search-input:focus{outline:none}.nav-search-input::placeholder{color:#9ca3af}.nav-search-btn{border:none;background:var(--accent);color:#fff;padding:0 12px;border-radius:0 9999px 9999px 0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s;align-self:stretch}.nav-search-btn:hover:not(:disabled){background:#2563eb}.nav-search-btn:disabled{background:#9ca3af;cursor:not-allowed}.nav-search-btn .icon{width:16px;height:16px;color:#fff}@media (max-width: 600px){.nav-search{display:none}}.mobile-search-btn{display:none;border:none;background:none;color:var(--text);padding:6px;cursor:pointer;border-radius:4px;transition:background-color .2s}.mobile-search-btn:hover{background:#0000000d}@media (max-width: 600px){.mobile-search-btn{display:flex;align-items:center;justify-content:center}}.search-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding:0}.search-overlay-content{width:calc(100% - 4px);max-width:600px;margin:0 2px 2px;background:#fff;border-radius:8px;padding:16px;box-shadow:0 4px 20px #00000026}.overlay-search-form{display:flex;align-items:center;gap:8px;padding:4px;border:1px solid #d1d5db;border-radius:9999px;background:#fff;width:100%;box-sizing:border-box;position:relative}.overlay-search-genre{border:none;background:none;padding:6px 8px;font-size:14px;color:#374151;cursor:pointer;min-width:80px}.overlay-search-genre:focus{outline:none}.overlay-search-input{flex:1 1 auto;border:none;background:none;padding:8px 12px;font-size:16px;color:#374151;min-width:0}.overlay-search-input:focus{outline:none}.overlay-search-input::placeholder{color:#9ca3af}.overlay-search-btn{border:none;background:var(--accent);color:#fff;padding:0 14px;border-radius:0 9999px 9999px 0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s;align-self:stretch}.overlay-search-btn:hover:not(:disabled){background:#2563eb}.overlay-search-btn:disabled{background:#9ca3af;cursor:not-allowed}.overlay-search-btn .icon{width:18px;height:18px;color:#fff}.search-suggestions{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 8px 24px #00000014;padding:6px 0;list-style:none;margin:0;max-height:280px;overflow-y:auto;z-index:1200}.search-suggestion-item{padding:10px 12px;font-size:14px;color:#111827;cursor:pointer;display:flex;align-items:center;gap:8px}.search-suggestion-item:hover{background:#f3f4f6}.suggestion-remove{margin-left:auto;border:none;background:transparent;color:#9ca3af;width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:9999px}.suggestion-remove:hover{background:#e5e7eb;color:#6b7280}.search-clear-btn{border:none;background:transparent;color:#9ca3af;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:9999px;cursor:pointer}.search-clear-btn:hover{background:#f3f4f6;color:#6b7280}.search-clear-btn.hidden{visibility:hidden;pointer-events:none}@media (max-width: 600px){.overlay-search-form{grid-template-columns:minmax(80px,2fr) minmax(0,8fr) auto}.overlay-search-btn,.search-clear-btn{min-width:36px;height:36px}.input-with-clear{position:relative;width:100%}.input-with-clear .overlay-search-input{padding-right:40px}.input-with-clear .search-clear-btn{position:absolute;right:6px;top:50%;transform:translateY(-50%);min-width:28px;height:28px}}@media (max-width: 600px){.overlay-search-form{display:grid;grid-template-columns:minmax(80px,2fr) minmax(0,8fr) auto;grid-column-gap:8px;grid-row-gap:8px;align-items:center}.overlay-search-genre{width:100%;max-width:100%}.overlay-search-input{width:100%;min-width:0}.overlay-search-btn{justify-self:end}}.legal-page{padding:32px 16px 64px;display:flex;justify-content:center}.legal-container{width:min(960px,100%);background:#fff;border:1px solid var(--border);border-radius:16px;padding:32px;box-shadow:0 12px 32px #0f172a14}.legal-title{font-size:28px;margin-bottom:8px;color:var(--text)}.legal-updated{color:var(--muted);margin-bottom:24px;font-size:14px}.legal-section{margin-bottom:24px}.legal-section h2{font-size:20px;margin-bottom:12px;color:var(--text)}.legal-section p{line-height:1.7;color:var(--text)}.legal-list{margin:0;padding-left:20px;line-height:1.7;color:var(--text)}.legal-contact{font-weight:600}.legal-contact a{color:var(--accent);text-decoration:underline}.legal-contact a:hover{color:#1d4ed8}@media (max-width: 600px){.legal-container{padding:24px 20px;border-radius:12px}.legal-title{font-size:24px}}.footer{text-align:center;color:var(--muted);font-size:12px;padding:24px 16px;display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.footer a{color:var(--muted);text-decoration:underline}.footer a:hover{color:var(--text)}.footer-divider{color:var(--border)}
