@import"https://fonts.googleapis.com/css2?family=Shippori+Mincho+B1:wght@600;700&family=Zen+Kaku+Gothic+New:wght@400;500;700&family=Zen+Old+Mincho:wght@600;700&display=swap";*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}:root{--font-body-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Noto Sans JP", Meiryo, sans-serif;--font-display-family: "Shippori Mincho B1", "Zen Old Mincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;--bg: #f7f2ea;--panel: #fffaf2;--text: #1c1a16;--muted: #6a6056;--border: #dbcab5;--accent: #7b2d26;--accent-strong: #5a1d1a;--accent-rgb: 123, 45, 38;--accent-strong-rgb: 90, 29, 26;--warm: #f97316;--focus-ring: 0 0 0 3px rgba(var(--accent-rgb), .28);--shadow-soft: 0 12px 30px rgba(29, 25, 23, .1);--shadow-strong: 0 18px 42px rgba(29, 25, 23, .16);--radius-sm: 10px;--radius-md: 14px;--radius-lg: 18px}body{margin:0;font-family:var(--font-body-family);color:var(--text);background:linear-gradient(0deg,#fff9,#fff9),radial-gradient(circle at 10% 10%,rgba(123,45,38,.09),transparent 38%),radial-gradient(circle at 90% 8%,rgba(15,118,110,.08),transparent 42%),repeating-linear-gradient(0deg,rgba(0,0,0,.035) 0,rgba(0,0,0,.035) 1px,transparent 1px,transparent 3px),linear-gradient(180deg,#fbf6ee 0%,var(--bg) 55%,#f3ecdf 100%);line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:var(--font-display-family);letter-spacing:.01em}a{color:inherit;text-decoration:none}img{display:block;max-width:100%;height:auto}button,input,select,textarea{font-family:inherit}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[role=button]:focus-visible{outline:2px solid rgba(var(--accent-rgb),.35);outline-offset:2px}.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:#fffdf7;border-bottom:1px solid var(--border)}.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:#4b5563;border-bottom:2px solid transparent}.nav-link.active{color:var(--text);border-color:var(--accent)}.panel{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);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:rgba(var(--accent-rgb),.12);border-color:rgba(var(--accent-rgb),.35)}.input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;background:#fffdf9}.input:focus{outline:none;border-color:var(--accent);box-shadow:var(--focus-ring)}.textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;resize:vertical;background:#fffdf9}.textarea:focus{outline:none;border-color:var(--accent);box-shadow:var(--focus-ring)}.button{border:1px solid var(--border);background:#fff7ed;color:var(--text);padding:8px 12px;font-size:14px;border-radius:var(--radius-sm);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.button.primary{background:linear-gradient(135deg,var(--accent),var(--accent-strong));border-color:transparent;color:#fff;box-shadow:0 8px 18px rgba(var(--accent-strong-rgb),.28)}.button-ghost{border-color:transparent;background:transparent;color:var(--accent)}.button-ghost:hover{background:rgba(var(--accent-rgb),.12)}.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:10px;font-size:14px;background:#fff}.grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px;padding:16px}@media (max-width: 1280px){.grid{grid-template-columns:repeat(4,1fr)}}@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:var(--radius-lg);background:#fffdf7;border:1px solid rgba(219,202,181,.9);box-shadow:0 14px 30px #1d19171f;display:flex;flex-direction:column;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.card-interactive{cursor:pointer}.card-interactive:hover{transform:translateY(-4px);box-shadow:var(--shadow-strong);border-color:rgba(var(--accent-rgb),.25)}.card-interactive:focus-visible{outline:3px solid rgba(var(--accent-rgb),.28);outline-offset:3px}.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:36px;height:36px;border-radius:999px;border:1px solid rgba(232,221,205,.9);background:#ffffffeb;box-shadow:0 8px 16px #0f172a1f}.heart-btn:focus-visible{outline:2px solid rgba(var(--accent-rgb),.35);outline-offset:2px}.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;font-family:var(--font-display-family);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:#fff4e6b3;border:1px solid rgba(232,221,205,.9);padding:3px 8px;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 10px;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:rgba(var(--accent-rgb),.08);border-color:rgba(var(--accent-rgb),.25)}.pill.active{background:linear-gradient(135deg,var(--accent),var(--accent-strong));border-color:transparent;color:#fff;box-shadow:0 8px 16px rgba(var(--accent-strong-rgb),.2)}.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:12px;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:rgba(var(--accent-rgb),.08)}.tab.active{color:var(--text);background:rgba(var(--accent-rgb),.14);border:1px solid rgba(var(--accent-rgb),.3)}.tab.active:after{display:none}.tab[disabled]{opacity:.6;cursor:default}.layout{display:grid;gap:24px;padding:32px 0}.book-tab-scroll{padding:4px 0 12px}.book-main{display:grid;gap:12px;padding:0 0 32px}.author-indicator{margin:0 0 10px;padding:8px 14px;background:rgba(var(--accent-rgb),.12);border:1px solid rgba(var(--accent-rgb),.3);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(var(--accent-rgb),.22);border-radius:14px;background:rgba(var(--accent-rgb),.08);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;min-width:0}.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);background:linear-gradient(180deg,#fffcf6cc,#fff8eed9)}.grid.shelf-grid{width:100%;max-width:100%;box-sizing:border-box;padding:20px 16px 28px;position:relative;background:linear-gradient(180deg,#fffcf6e6,#fff8eee6),repeating-linear-gradient(to bottom,rgba(132,92,58,.25) 0,rgba(132,92,58,.25) 4px,transparent 4px,transparent 180px);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:inset 0 1px #ffffffb3,var(--shadow-soft)}.shelf-carousel{position:relative;max-width:100%;overflow:hidden}.shelf-carousel-btn{position:absolute;top:50%;transform:translateY(-50%);border:1px solid rgba(214,196,174,.9);background:#fffdf7f2;box-shadow:0 10px 24px #1d19172e;width:34px;height:34px;border-radius:999px;display:none;align-items:center;justify-content:center;color:var(--muted);cursor:pointer;z-index:2;transition:transform .15s ease,box-shadow .15s ease,background-color .15s ease,color .15s ease}.shelf-carousel-btn:hover{background:#fff;color:var(--accent);box-shadow:0 12px 28px #1d191738}.shelf-carousel-btn:focus-visible{outline:2px solid rgba(var(--accent-rgb),.35);outline-offset:2px}.shelf-carousel-btn-prev{left:8px}.shelf-carousel-btn-next{right:8px}.grid.shelf-grid .card{position:relative;border-radius:12px;background:#fffdf9;border:1px solid rgba(214,196,174,.9);box-shadow:0 12px 18px #2c22182e}.grid.shelf-grid .card:before{content:"";position:absolute;top:0;bottom:0;left:0;width:10px;background:linear-gradient(180deg,#784a32b3,#5c3824b3);opacity:.45;z-index:1;pointer-events:none}.grid.shelf-grid .card-media{box-shadow:inset 0 -18px 18px #00000014}.grid.shelf-grid .card-body{border-top:1px solid rgba(214,196,174,.8);background:#fffaf4f2}@media (max-width: 1024px){.shelf-carousel-btn{display:inline-flex}.grid.shelf-grid{display:flex;gap:14px;padding:18px 38px 22px;border-radius:14px;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;scroll-padding-left:38px}.grid.shelf-grid::-webkit-scrollbar{display:none}.grid.shelf-grid .card{flex:0 0 200px;scroll-snap-align:start}.grid.shelf-grid .card:before{width:8px}}@media (max-width: 720px){.grid.shelf-grid{padding:14px 12px 18px;background:linear-gradient(180deg,#fffcf6f5,#fff8eef5),repeating-linear-gradient(to bottom,rgba(132,92,58,.22) 0,rgba(132,92,58,.22) 3px,transparent 3px,transparent 150px)}.grid.shelf-grid .card:before{width:6px}.grid.shelf-grid .card{flex-basis:170px}}.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;font-family:var(--font-display-family);letter-spacing:.06em}@media (max-width: 720px){.shelf-controls-scroll{height:46px;min-height:46px;padding:0 6px}.shelf-tab{font-size:13px;padding:0 12px}}.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:rgba(var(--accent-rgb),.08);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:rgba(var(--accent-rgb),.18);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 (max-width: 720px){.read-sort{width:100%;justify-content:flex-end;padding:0 12px}.read-sort-label{font-size:11px}.read-sort .select{font-size:12px;padding:6px 10px}}@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,rgba(var(--accent-rgb),.85),rgba(var(--accent-rgb),.45));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: 400px){.shelf-grid{grid-template-columns:1fr}}@media (max-width: 720px){.shelf-tab-group{padding:16px}.read-stats-card{flex:0 0 280px}}.detail-hero{position:relative;padding:28px 32px 32px;background:radial-gradient(circle at 18% 22%,rgba(var(--accent-rgb),.16),transparent 36%),radial-gradient(circle at 82% 12%,rgba(249,115,22,.18),transparent 32%),linear-gradient(135deg,#fff7ed,#fef3c7 55%,#fff7ed);border-radius:var(--radius-lg);overflow:hidden;isolation:isolate;box-shadow:var(--shadow-strong)}.detail-hero:before{content:"";position:absolute;top:12%;right:8%;bottom:12%;left:8%;background:radial-gradient(circle,rgba(255,255,255,.35) 0,transparent 42%);filter:blur(34px);z-index:0}.detail-layout{position:relative;z-index:1;display:grid;grid-template-columns:320px 1fr;gap:36px;align-items:start;max-width:1120px;margin-inline:auto;width:100%}.detail-left,.detail-right{padding-top:12px}.detail-left{display:block;position:relative}.detail-image-frame{position:relative;border-radius:var(--radius-lg);padding:16px;background:#ffffffd1;border:1px solid rgba(232,221,205,.9);box-shadow:var(--shadow-strong);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.detail-image{border-radius:12px;background-position:center;background-size:cover;background-repeat:no-repeat;box-shadow:inset 0 0 0 1px #0f172a0d}.detail-right{display:flex;flex-direction:column;gap:12px;color:var(--text)}.detail-kicker{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:rgba(var(--accent-rgb),.12);border:1px solid rgba(var(--accent-rgb),.2);color:var(--accent-strong);font-size:12px;letter-spacing:.08em;text-transform:uppercase;width:fit-content}.detail-breadcrumbs{color:var(--muted)}.detail-title{font-size:30px;margin:0;color:var(--text);letter-spacing:-.01em}.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:2px;padding:6px 0;color:var(--text)}.detail-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}.detail-actions .button{min-width:132px;width:auto;display:inline-flex;justify-content:center;align-items:center;text-align:center;white-space:nowrap;border-color:var(--border);background:#fffdf7;color:var(--text)}.detail-actions .button:hover{background:#fff4e6;border-color:rgba(var(--accent-rgb),.26)}.detail-actions .button.primary{background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:#fff;border:none}.detail-meta-lines{display:flex;flex-direction:column;gap:6px;max-width:340px;font-size:13px;color:var(--text)}.detail-meta-under{max-width:90%;margin:12px auto 0;text-align:left}.detail-meta-lines>div{display:flex;justify-content:flex-start;align-items:baseline;gap:6px}.detail-meta-value{color:var(--text);font-weight:600}.detail-price-value{font-size:20px;font-weight:700;color:var(--text)}.only-mobile{display:none}.only-desktop{display:block}.detail-links{margin-top:18px;display:grid;gap:16px}.detail-link-section{display:grid;gap:10px}.detail-link-title{display:inline-flex;align-items:center;gap:8px}.detail-link-list{display:flex;gap:10px;flex-wrap:wrap}.detail-link-list>.button{width:126px;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}.detail-chips{display:flex;flex-wrap:wrap;gap:10px;margin:4px 0 2px}.detail-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:12px;background:rgba(var(--accent-rgb),.12);border:1px solid rgba(var(--accent-rgb),.2);color:var(--text);font-size:13px}.detail-chip .chip-label{color:var(--accent-strong);font-weight:600}.detail-chip .chip-value{color:#111827;font-weight:700}.detail-floating-meta{position:absolute;bottom:14px;right:14px;display:flex;gap:8px;flex-wrap:wrap}.detail-floating-meta .badge{background:#ffffffe6;color:var(--text);border:1px solid rgba(226,232,240,.9);box-shadow:0 8px 18px #0f172a1f}.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:260px 1fr;gap:20px}.detail-title{font-size:24px}.detail-meta-lines{max-width:260px}}@media (min-width: 901px){.detail-hero{padding:28px 46px}.detail-layout{grid-template-columns:360px 1fr;gap:42px}.detail-left,.detail-right{padding-top:18px}}@media (max-width: 600px){.detail-hero{padding:22px 18px 26px;border-radius:14px}.detail-layout{grid-template-columns:1fr;gap:20px}.detail-actions{justify-content:flex-start}.detail-actions{gap:6px}.detail-actions .button{min-width:120px;width:auto;flex:1 1 140px;gap:6px}.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(50% - 6px)}.detail-image-frame{padding:12px}}@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:26px;font-weight:700;margin:0;color:var(--text);letter-spacing:.02em}.app-header{border-bottom:1px solid rgba(219,202,181,.9);border-top:1px solid rgba(219,202,181,.6);background:linear-gradient(180deg,#fffcf6f5,#f8f0e6e6);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:sticky;top:0;z-index:900;transition:transform .2s ease-in-out;will-change:transform}.app-header.header-floating{box-shadow:var(--shadow-strong)}.app-header.header-hidden{transform:translateY(-100%)}.app-header-inner{max-width:none;width:100%;padding:14px 22px;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:20px;font-weight:700;margin:0;letter-spacing:.08em;text-transform:uppercase;font-family:var(--font-display-family)}.nav-links{display:flex;align-items:center;gap:18px}.nav-link{color:var(--text);font-size:14px;text-decoration:none;padding:6px 10px;border-radius:999px;transition:background-color .15s ease,color .15s ease}.nav-link:hover{background:rgba(var(--accent-rgb),.12);color:var(--accent-strong)}.nav-link.active{background:rgba(var(--accent-rgb),.18);color:var(--accent-strong)}.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:rgba(var(--accent-rgb),.12)}.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:#fffdf9;border:1px solid rgba(232,221,205,.9);border-radius:14px;min-width:180px;box-shadow:var(--shadow-strong);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:10px;cursor:pointer}.user-menu-item:hover{background:rgba(var(--accent-rgb),.12)}.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:rgba(var(--accent-rgb),.12);border-color:rgba(var(--accent-rgb),.35);color:var(--accent-strong);transform:translateY(-1px);box-shadow:0 6px 14px rgba(var(--accent-strong-rgb),.18)}.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 rgba(219,202,181,.95);border-radius:14px;background:#fffcf6f2;box-shadow:var(--shadow-soft);position:relative;transition:border-color .2s ease,box-shadow .2s ease}.nav-search-form:focus-within{border-color:rgba(var(--accent-rgb),.5);box-shadow:0 14px 28px rgba(var(--accent-strong-rgb),.16)}.nav-search-genre{border:none;background:none;padding:6px 8px;font-size:14px;color:var(--muted);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:var(--text)}.nav-search-input:focus{outline:none}.nav-search-input::placeholder{color:#9ca3af}.nav-search-btn{border:none;background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:#fff;padding:0 14px;border-radius:0 12px 12px 0;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;font-weight:600;transition:background-color .2s;align-self:stretch}.nav-search-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--accent-strong),var(--accent))}.nav-search-btn:disabled{background:#9ca3af;cursor:not-allowed}.nav-search-btn .icon{width:16px;height:16px;color:#fff}.nav-search-btn-label{font-size:12px;letter-spacing:.04em}@media (max-width: 980px){.nav-search{max-width:360px}.nav-search-genre{min-width:72px;font-size:13px}.nav-search-input{font-size:13px}}@media (max-width: 720px){.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:rgba(var(--accent-rgb),.12)}@media (max-width: 720px){.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:#fffdf9;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 var(--border);border-radius:9999px;background:#fffdf9;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;gap:6px;font-weight:600;transition:background-color .2s;align-self:stretch}.overlay-search-btn:hover:not(:disabled){background:var(--accent-strong)}.overlay-search-btn:disabled{background:#9ca3af;cursor:not-allowed}.overlay-search-btn .icon{width:18px;height:18px;color:#fff}.overlay-search-btn-label{font-size:12px;letter-spacing:.04em}.search-suggestions{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fffdf9;border:1px solid var(--border);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:#f8efe4}.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:#f3e8d9;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:#f3e8d9;color:#6b7280}.search-clear-btn.hidden{visibility:hidden;pointer-events:none}@media (max-width: 720px){.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: 720px){.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:var(--accent-strong)}@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)}@media (max-width: 720px){.nav-search-btn-label,.overlay-search-btn-label{display:none}}@media (max-width: 980px){.app-header-inner{padding:10px 16px;gap:12px}.brand-title{font-size:18px;letter-spacing:.06em}.header-right{gap:6px}}@media (max-width: 720px){.app-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.brand-and-nav{gap:12px}.brand-title{font-size:16px}}@media (max-width: 480px){.app-header-inner{padding:10px 12px}.user-menu-trigger .user-avatar{width:28px;height:28px}}
