:root{--bg: #0e0e10;--bg-card: #18181b;--bg-input: #0a0a0c;--fg: #efeff1;--fg-muted: #adadb8;--accent: #6366f1;--accent-hover: #7c7feb;--border: #2a2a30;--error: #ef4444;--admin: #f59e0b;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Pretendard,Apple SD Gothic Neo,Malgun Gothic,system-ui,sans-serif;color-scheme:dark}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100vh}body{background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.center{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem}.muted{color:var(--fg-muted);font-size:.875rem}.error{color:var(--error);font-size:.875rem}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1rem}.auth-form{background:var(--bg-card);padding:2rem;border-radius:12px;width:100%;max-width:360px;display:flex;flex-direction:column;gap:1rem}.auth-form h1{font-size:1.5rem;margin-bottom:.25rem}.auth-logo{display:block;width:60%;max-width:220px;height:auto;margin:0 auto .5rem}.auth-form label{display:flex;flex-direction:column;gap:.375rem;font-size:.875rem;color:var(--fg-muted)}.auth-form label.checkbox{flex-direction:row;align-items:center;gap:.5rem;color:var(--fg)}.auth-form input[type=text],.auth-form input[type=password],.auth-form input:not([type]){background:var(--bg-input);color:var(--fg);border:1px solid var(--border);padding:.625rem;border-radius:6px;font-size:.95rem;font-family:inherit}.auth-form input:focus{outline:2px solid var(--accent);outline-offset:-1px;border-color:transparent}.auth-form button{background:var(--accent);color:#fff;border:none;padding:.75rem;border-radius:6px;font-size:.95rem;cursor:pointer;font-weight:500;transition:background .15s}.auth-form button:hover:not(:disabled){background:var(--accent-hover)}.auth-form button:disabled{opacity:.6;cursor:not-allowed}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-bar{position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:var(--bg);border-bottom:1px solid var(--border)}.menu-button{background:none;border:1px solid transparent;color:var(--fg);font-size:1.5rem;line-height:1;padding:.25rem .625rem;border-radius:6px;cursor:pointer}.menu-button:hover{background:var(--bg-card)}.app-title{font-size:1.0625rem;font-weight:600}.app-logo{height:32px;width:auto;display:block}.app-logo-link{display:inline-flex;align-items:center;border-radius:6px;padding:2px 4px;transition:opacity .12s ease}.app-logo-link:hover{opacity:.8}.app-logo-link:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.app-main{flex:1}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:50}.sidebar-backdrop.visible{opacity:1;pointer-events:auto}.sidebar{position:fixed;top:0;bottom:0;left:0;width:260px;max-width:80vw;height:100dvh;background:var(--bg-card);border-right:1px solid var(--border);z-index:51;transform:translate(-100%);transition:transform .22s ease;display:flex;flex-direction:column;overflow:hidden}.sidebar.open{transform:translate(0)}.sidebar-header{padding:1.25rem 1.25rem 1rem;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-header h2{font-size:1.25rem;font-weight:600}.sidebar-logo{display:block;width:70%;max-width:160px;height:auto;margin:0 auto}.sidebar-user{margin-top:.5rem;display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:var(--fg-muted)}.sidebar-nav{flex:1;display:flex;flex-direction:column;padding:.5rem;gap:.125rem;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.sidebar-item{display:flex;align-items:center;gap:.75rem;padding:.625rem .875rem;border-radius:6px;color:var(--fg);text-decoration:none;background:none;border:none;font:inherit;text-align:left;cursor:pointer}.sidebar-item:hover{background:#ffffff0d}.sidebar-item.active{background:#6366f126;color:var(--accent)}.sidebar-icon{font-size:1rem;width:1.5rem;text-align:center}.sidebar-footer{padding:.5rem;border-top:1px solid var(--border);flex-shrink:0}.sidebar-item.logout{color:var(--fg-muted)}.sidebar-version{display:block;text-align:center;padding:.375rem .5rem;margin-top:.25rem;font-size:.75rem;font-variant-numeric:tabular-nums;color:var(--fg-muted);text-decoration:none;border-radius:.375rem;transition:background .12s ease,color .12s ease}.sidebar-version:hover{background:#ffffff0d;color:var(--fg)}.changelog-page{max-width:56rem;margin:0 auto;padding:1rem 1.25rem}.changelog-page .back{margin-bottom:.5rem;display:inline-block}.changelog-page h1{font-size:1.5rem;margin:0 0 .25rem}.changelog-list{list-style:none;margin:1.5rem 0 0;padding:0;display:flex;flex-direction:column;gap:1.25rem}.changelog-entry{border:1px solid var(--border);border-radius:.5rem;padding:1rem 1.25rem;background:var(--bg-card, transparent)}.changelog-entry.current{border-color:#6366f180;box-shadow:0 0 0 1px #6366f140 inset}.changelog-entry-header{display:flex;align-items:baseline;gap:.625rem;flex-wrap:wrap}.changelog-version{font-size:1.125rem;font-weight:600;font-variant-numeric:tabular-nums}.changelog-date{font-size:.8125rem;font-variant-numeric:tabular-nums}.changelog-current-tag{background:#6366f126;color:var(--accent);border:1px solid rgba(99,102,241,.4)}.changelog-summary{margin:.5rem 0 .75rem;color:var(--fg);font-size:.9375rem}.changelog-section{margin-top:.875rem}.changelog-kind{display:inline-block;font-size:.75rem;font-weight:600;padding:.0625rem .5rem;border-radius:.25rem;background:#ffffff0d;border:1px solid var(--border);margin:0 0 .375rem}.changelog-kind.kind-added{background:#22c55e1f;border-color:#22c55e66;color:#22c55e}.changelog-kind.kind-changed{background:#6366f11f;border-color:#6366f166;color:var(--accent)}.changelog-kind.kind-fixed{background:#f59e0b1f;border-color:#f59e0b66;color:#f59e0b}.changelog-kind.kind-internal{color:var(--fg-muted)}.changelog-kind.kind-milestone{background:linear-gradient(90deg,#f59e0b2e,#6366f12e);border-color:#f59e0b80;color:#f59e0b}.changelog-items{margin:0;padding-left:1.25rem;display:flex;flex-direction:column;gap:.25rem}.changelog-items li{font-size:.9375rem;line-height:1.5}.changelog-items li>p{margin:0}.changelog-footer{margin-top:2rem;text-align:center;font-size:.875rem}.book-list-page{max-width:1400px;margin:0 auto;padding:1rem}.page-header{display:flex;align-items:baseline;gap:1rem;padding:.5rem 0 1rem;border-bottom:1px solid var(--border);margin-bottom:1rem}.page-header h2{font-size:1.375rem;font-weight:600}.btn-link{background:none;border:none;color:var(--accent);cursor:pointer;font-size:inherit;padding:0}.btn-link:hover{color:var(--accent-hover)}.controls{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;padding:.25rem 0 1rem}.controls .sort-toggle{background:var(--bg-card);color:var(--fg);border:1px solid var(--border);padding:.5rem .75rem;border-radius:6px;font-family:inherit;font-size:.875rem;cursor:pointer}.controls .sort-toggle:hover{background:#ffffff0a}.controls select{background:var(--bg-card);color:var(--fg);border:1px solid var(--border);padding:.5rem;border-radius:6px;font-family:inherit;font-size:.875rem}.view-toggle{display:inline-flex;border:1px solid var(--border);border-radius:6px;overflow:hidden}.view-toggle-btn{background:var(--bg-card);color:var(--fg);border:none;padding:.5rem .75rem;font-family:inherit;font-size:.8125rem;cursor:pointer;border-right:1px solid var(--border)}.view-toggle-btn:last-child{border-right:none}.view-toggle-btn.active{background:var(--accent);color:#fff}.book-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.book-card{background:var(--bg-card);border-radius:8px;overflow:hidden;display:flex;flex-direction:column;text-decoration:none;color:inherit;transition:transform .15s ease,box-shadow .15s ease}.clickable{cursor:pointer}.clickable:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.book-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0006}.series-index{color:var(--fg-muted);font-weight:400;margin-right:.125rem}.book-card .cover{aspect-ratio:2 / 3;background:var(--bg);overflow:hidden}.book-card .cover img{width:100%;height:100%;object-fit:cover;display:block}.book-card .cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--fg-muted);font-size:.75rem}.book-card .info{padding:.75rem;display:flex;flex-direction:column;gap:.25rem}.book-card .title{font-size:.875rem;font-weight:500;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.book-card .author,.book-card .series{font-size:.75rem}.book-card .badges{display:flex;gap:.25rem;align-items:center;flex-wrap:nowrap;overflow:hidden;white-space:nowrap;min-width:0;margin-top:.25rem;font-size:.75rem}.book-card .badges>*{flex-shrink:0}.badge{background:var(--bg);border:1px solid var(--border);padding:.125rem .375rem;border-radius:4px;font-size:.6875rem;color:var(--fg-muted)}.badge.admin{background:transparent;border-color:var(--admin);color:var(--admin);margin-left:.375rem}.badge.tag-badge{background:#6366f114;border-color:#6366f166;color:#b3b5f1;text-decoration:none}.badge.tag-badge:hover{background:#6366f12e;text-decoration:none}.badge.muted-badge{border-color:var(--border);color:var(--fg-muted)}.searchbar{display:flex;flex-direction:column;gap:.5rem;padding:.625rem 0}.searchbar-row{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.searchbar-input{flex:1 1 16rem;min-width:12rem;padding:.5rem .75rem;background:var(--bg-input);color:var(--fg);border:1px solid var(--border);border-radius:6px;font-family:inherit;font-size:.9375rem}.searchbar-input:focus{outline:1px solid var(--accent);border-color:var(--accent)}.searchbar select{padding:.5rem .625rem;background:var(--bg-input);color:var(--fg);border:1px solid var(--border);border-radius:6px;font-family:inherit;font-size:.875rem}.searchbar-toggle{padding:.5rem .75rem;background:var(--bg-card);color:var(--fg);border:1px solid var(--border);border-radius:6px;font-family:inherit;font-size:.8125rem;cursor:pointer;white-space:nowrap}.searchbar-toggle:hover:not(:disabled){background:#ffffff0a;border-color:var(--accent);color:var(--accent)}.searchbar-toggle:disabled{opacity:.5;cursor:not-allowed}.searchbar-toggle[aria-expanded=true]{border-color:var(--accent);color:var(--accent)}.searchbar-advanced-row{padding-left:.25rem}.tag-multiselect{position:relative;width:100%}.tag-multiselect-row{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem;padding:.375rem .5rem;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;min-height:2.25rem;cursor:text}.tag-multiselect-row:focus-within{outline:1px solid var(--accent);border-color:var(--accent)}.tag-chip{display:inline-flex;align-items:center;gap:.25rem;background:#6366f126;border:1px solid rgba(99,102,241,.4);color:#b3b5f1;padding:.125rem .25rem .125rem .5rem;border-radius:4px;font-size:.8125rem;line-height:1.3}.tag-chip-remove{background:none;border:none;color:inherit;cursor:pointer;font-size:1rem;line-height:1;padding:0 .125rem;border-radius:3px;font-family:inherit}.tag-chip-remove:hover{background:#ffffff1a}.tag-multiselect-input{flex:1 1 8rem;min-width:6rem;background:transparent;border:0;outline:none;color:var(--fg);font-family:inherit;font-size:.875rem;padding:.25rem 0}.tag-multiselect-dropdown{position:absolute;top:calc(100% + .25rem);left:0;right:0;z-index:20;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;max-height:16rem;overflow-y:auto;display:flex;flex-direction:column;box-shadow:0 6px 18px #0006}.tag-multiselect-option{background:none;border:0;text-align:left;padding:.5rem .75rem;color:var(--fg);font-family:inherit;font-size:.875rem;cursor:pointer}.tag-multiselect-option:hover{background:#6366f12e}.rating-filter{display:inline-flex;align-items:center;gap:.75rem;flex-wrap:wrap;padding:.375rem .625rem;background:var(--bg-input);border:1px solid var(--border);border-radius:6px}.rating-filter-label{color:var(--fg-muted);font-size:.8125rem}.rating-range{display:inline-flex;align-items:center;gap:.5rem;flex-wrap:wrap}.rating-range-side{display:inline-flex;align-items:center;gap:.375rem}.rating-range-tag{font-size:.75rem;color:var(--fg-muted);min-width:1.75rem}.rating-range-sep{color:var(--fg-muted);font-size:.875rem}.rating-range-clear{width:1.25rem;height:1.25rem;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);background:transparent;color:var(--fg-muted);border-radius:999px;cursor:pointer;font-size:.875rem;line-height:1;font-family:inherit;padding:0}.rating-range-clear:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.rating-range-clear:disabled{opacity:.25;cursor:not-allowed}.rating-filter-unrated{display:inline-flex;align-items:center;gap:.375rem;font-size:.8125rem;color:var(--fg-muted);cursor:pointer;padding-left:.25rem;border-left:1px solid var(--border)}.rating-filter-unrated input[type=checkbox]{accent-color:var(--accent);cursor:pointer}.badge.concluded-ongoing{background:#22c55e1f;border-color:#22c55e66;color:#4ade80}.badge.concluded-completed{background:#38bdf81a;border-color:#38bdf866;color:#7dd3fc}.badge.concluded-dropped{background:#ef44441a;border-color:#ef444466;color:#f87171}.badge.concluded-unknown{border-color:var(--border);color:var(--fg-muted)}.badge.section-badge{background:#f59e0b14;border-color:#f59e0b59;color:#fbbf24}.tag-cloud{display:flex;flex-wrap:wrap;gap:.5rem}.tag-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .875rem;background:var(--bg-card);border:1px solid var(--border);border-radius:999px;text-decoration:none;color:inherit;font-size:.875rem;transition:border-color .15s,transform .15s}.tag-chip:hover{border-color:var(--accent);transform:translateY(-1px)}.tag-chip .name{font-weight:500}.tag-chip .count{font-size:.75rem}.tag-chip .added{font-size:.6875rem;font-variant-numeric:tabular-nums;border-left:1px solid var(--border);padding-left:.5rem}.pagination{display:flex;justify-content:center;gap:.5rem;align-items:center;padding:2rem 0;flex-wrap:wrap}.pagination button{background:var(--bg-card);color:var(--fg);border:1px solid var(--border);padding:.5rem .875rem;border-radius:6px;cursor:pointer;font-family:inherit;font-size:.875rem}.pagination button:hover:not(:disabled){border-color:var(--accent)}.pagination button:disabled{opacity:.5;cursor:not-allowed}.book-list{display:flex;flex-direction:column;gap:.5rem}.book-row-list{display:flex;gap:1rem;background:var(--bg-card);border-radius:8px;padding:.625rem;color:inherit;transition:background .15s}.book-row-list:hover{background:#ffffff0a}.book-row-list .cover{flex-shrink:0;width:60px;height:90px;background:var(--bg);border-radius:4px;overflow:hidden}.book-row-list .cover img{width:100%;height:100%;object-fit:cover}.book-row-list .cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--fg-muted);font-size:.625rem}.book-row-list .info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.book-row-list .title{font-size:.9375rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.book-row-list .author,.book-row-list .series{font-size:.75rem}.book-row-list .badges{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;margin-top:auto}.book-row-list .badges .row-activity{margin-left:auto}.book-dense{border:1px solid var(--border);border-radius:6px;overflow-x:auto}.book-row-dense{display:grid;grid-template-columns:minmax(240px,2.4fr) minmax(140px,1.2fr) minmax(70px,.5fr) minmax(80px,.5fr) minmax(160px,1.4fr) minmax(80px,.6fr) minmax(80px,.6fr);gap:1rem;min-width:940px;padding:.5rem .875rem;color:inherit;border-bottom:1px solid var(--border);font-size:.8125rem;align-items:start}.book-row-dense:last-child{border-bottom:none}.book-row-dense:hover{background:#ffffff0a}.book-row-dense .title,.book-row-dense .author{word-break:break-word;overflow-wrap:anywhere}.book-row-dense .tags{display:flex;flex-wrap:wrap;gap:.25rem}.book-row-dense .formats{font-size:.75rem;color:var(--fg-muted)}.book-row-dense .added,.added-date{font-size:.75rem;font-variant-numeric:tabular-nums;white-space:nowrap}.book-detail-page{max-width:1100px;margin:0 auto;padding:1rem}.book-detail-page .back{margin-bottom:1rem;display:inline-block}.detail-layout{display:grid;grid-template-columns:280px 1fr;gap:2rem}.detail-cover{background:var(--bg-card);border-radius:8px;overflow:hidden;aspect-ratio:2 / 3;align-self:start}.detail-cover img{width:100%;height:100%;object-fit:cover}.detail-cover .cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--fg-muted)}.detail-info{display:flex;flex-direction:column;gap:.875rem}.detail-title{font-size:1.625rem;font-weight:600;line-height:1.3}.detail-title-row{display:flex;align-items:baseline;flex-wrap:wrap;gap:.5rem .625rem}.edition-badges{display:inline-flex;flex-wrap:wrap;gap:.25rem;vertical-align:middle;margin-left:.375rem}.badge.edition-badge{background:#a855f71f;border-color:#a855f766;color:#d8b4fe}.detail-row{display:flex;gap:.875rem;font-size:.9375rem}.detail-row .label{color:var(--fg-muted);min-width:70px}.detail-row .tags{display:flex;gap:.25rem;flex-wrap:wrap}.link{color:var(--accent);text-decoration:none}.link:hover{text-decoration:underline}.detail-actions{display:flex;gap:.625rem;flex-wrap:wrap;padding:.5rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin:.5rem 0}.btn-primary{background:var(--accent);color:#fff;border:none;padding:.625rem 1.25rem;border-radius:6px;font-family:inherit;font-size:.9375rem;font-weight:500;cursor:pointer}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-card);color:var(--fg);border:1px solid var(--border);padding:.625rem 1rem;border-radius:6px;font-size:.875rem;text-decoration:none;cursor:pointer;display:inline-flex;align-items:center;gap:.375rem}.btn-secondary:hover{border-color:var(--accent)}.detail-description h3{font-size:1rem;font-weight:600;margin-bottom:.5rem;color:var(--fg-muted)}.description-body{font-size:.9375rem;line-height:1.65;color:var(--fg)}.description-body p{margin-bottom:.75rem}@media (max-width: 700px){.detail-layout{grid-template-columns:1fr}.detail-cover{max-width:220px;margin:0 auto}}.work-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.work-card{background:var(--bg-card);border-radius:8px;overflow:hidden;display:flex;flex-direction:column;text-decoration:none;color:inherit;transition:transform .15s ease,box-shadow .15s ease}.work-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0006}.work-card .cover{aspect-ratio:2 / 3;background:var(--bg);overflow:hidden}.work-card .cover img{width:100%;height:100%;object-fit:cover;display:block}.work-card .cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--fg-muted);font-size:.75rem}.work-card .info{padding:.75rem;display:flex;flex-direction:column;gap:.25rem}.work-card .title{font-size:.875rem;font-weight:500;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.work-card .meta{display:flex;gap:.375rem;align-items:center;font-size:.75rem;flex-wrap:nowrap;overflow:hidden;white-space:nowrap;min-width:0}.work-card .meta>*{flex-shrink:0}.work-card .meta-secondary,.work-card .author{font-size:.75rem}.badge.type-badge{background:#6366f126;border-color:var(--accent);color:var(--accent);font-weight:500}.work-list{display:flex;flex-direction:column;gap:.5rem}.work-row-list{display:flex;gap:1rem;background:var(--bg-card);border-radius:8px;padding:.625rem;color:inherit;transition:background .15s}.work-row-list:hover{background:#ffffff0a}.work-row-list .cover{flex-shrink:0;width:60px;height:90px;background:var(--bg);border-radius:4px;overflow:hidden}.work-row-list .cover img{width:100%;height:100%;object-fit:cover}.work-row-list .cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--fg-muted);font-size:.625rem}.work-row-list .info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.work-row-list .title{font-size:.9375rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.work-row-list .author{font-size:.75rem}.work-row-list .meta{display:flex;gap:.375rem;align-items:center;font-size:.75rem;margin-top:auto}.work-row-list .badges{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;margin-top:auto}.work-row-list .badges .row-activity{margin-left:auto}.work-dense{border:1px solid var(--border);border-radius:6px;overflow-x:auto}.work-row-dense{display:grid;grid-template-columns:minmax(220px,2.2fr) minmax(80px,.6fr) minmax(70px,.5fr) minmax(140px,1.2fr) minmax(70px,.5fr) minmax(80px,.5fr) minmax(140px,1.2fr) minmax(80px,.6fr);gap:1rem;min-width:1020px;padding:.5rem .875rem;text-decoration:none;color:inherit;border-bottom:1px solid var(--border);font-size:.8125rem;align-items:start}.work-row-dense:last-child{border-bottom:none}.work-row-dense:hover{background:#ffffff0a}.work-row-dense .title,.work-row-dense .author{word-break:break-word;overflow-wrap:anywhere}.work-row-dense .tags{display:flex;flex-wrap:wrap;gap:.25rem;font-size:.75rem}.work-row-dense .added{font-size:.75rem;font-variant-numeric:tabular-nums;white-space:nowrap}.author-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.author-card{background:var(--bg-card);border-radius:8px;padding:1rem;text-decoration:none;color:inherit;display:flex;flex-direction:column;gap:.375rem;transition:background .15s}.author-card:hover{background:#ffffff0a}.author-card .name{font-size:1rem;font-weight:500}.author-card .meta{font-size:.8125rem}.author-list{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:6px;overflow:hidden}.author-row{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;text-decoration:none;color:inherit;border-bottom:1px solid var(--border);transition:background .1s ease}.author-row:last-child{border-bottom:none}.author-row:hover{background:#ffffff0a}.author-row .name{font-size:.9375rem;font-weight:500;flex:1;min-width:0}.author-dense{border:1px solid var(--border);border-radius:6px;overflow:hidden}.author-row-dense{display:grid;grid-template-columns:1fr minmax(80px,.5fr) 80px minmax(80px,.6fr);gap:1rem;padding:.4rem .875rem;text-decoration:none;color:inherit;border-bottom:1px solid var(--border);font-size:.8125rem;align-items:center}.author-row-dense:last-child{border-bottom:none}.author-row-dense:hover{background:#ffffff0a}.author-row-dense .name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.author-row-dense .count{text-align:right;font-size:.75rem}.author-row-dense .added{font-size:.75rem;font-variant-numeric:tabular-nums;white-space:nowrap;text-align:right}.entity-header{display:grid;grid-template-columns:220px 1fr;gap:1.5rem;padding:1rem 0 1.5rem;border-bottom:1px solid var(--border);margin-bottom:1rem}.entity-cover{background:var(--bg-card);border-radius:8px;overflow:hidden;aspect-ratio:2 / 3;align-self:start}.entity-cover img{width:100%;height:100%;object-fit:cover}.entity-cover .cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--fg-muted)}.entity-info{display:flex;flex-direction:column;gap:.625rem}.entity-info-noimage{grid-column:1 / -1}.entity-type{margin-bottom:.125rem}.entity-title{font-size:1.625rem;font-weight:600;line-height:1.3}.entity-meta{font-size:.875rem}.entity-row{display:flex;gap:.75rem;font-size:.9375rem}.entity-row .label{color:var(--fg-muted);min-width:60px}.entity-description{font-size:.9375rem;line-height:1.6;margin-top:.5rem}@media (max-width: 700px){.entity-header{grid-template-columns:1fr}.entity-cover{max-width:200px;margin:0 auto}}.tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:1rem}.tab{background:none;border:none;color:var(--fg-muted);font-family:inherit;font-size:.9375rem;padding:.75rem 1.25rem;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.tab:hover{color:var(--fg)}.tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:500}.placeholder-page{max-width:800px;margin:4rem auto;padding:2rem;text-align:center}.placeholder-page h2{font-size:1.5rem;margin-bottom:1rem}.reader{background:#000;color:#ddd;min-height:100dvh;height:100dvh;overflow:hidden}.reader-topbar{position:fixed;top:0;left:0;right:0;z-index:10;display:flex;align-items:center;gap:1.25rem;padding:1rem 1.25rem;background:#000000d9;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border-bottom:1px solid var(--border);opacity:1;transition:opacity .25s ease;flex-wrap:wrap;row-gap:.375rem}.reader-topbar.hidden{opacity:0;pointer-events:none}.reader-topbar .btn-link{font-size:1rem;padding:.375rem .5rem}.reader-topbar .title{font-size:1.0625rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;color:#ddd}.paged-reader{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100dvh}.paged-reader .page-area{width:100%;height:100%;display:flex;align-items:center;justify-content:center;cursor:pointer;user-select:none;-webkit-user-select:none;touch-action:pinch-zoom}.paged-reader .page-area.single .page-image{max-width:100%;max-height:100dvh;width:auto;height:auto;object-fit:contain;display:block;-webkit-user-drag:none}.paged-reader .page-area.dual .page-image{max-width:50%;max-height:100dvh;width:auto;height:auto;object-fit:contain;display:block;-webkit-user-drag:none}.paged-reader .spread{display:flex;width:100%;align-items:center;justify-content:center;gap:2px}.paged-reader .spread.rtl{flex-direction:row-reverse}.paged-reader .spread.ltr{flex-direction:row}.page-indicator .settings-toggle{font-size:.75rem;padding:.3rem .55rem;margin-left:.25rem}.page-indicator .mode-select{background:transparent;color:#ddd;border:1px solid var(--border);padding:.3rem .4rem;border-radius:4px;font-family:inherit;font-size:.75rem;margin-left:.25rem;cursor:pointer}.page-indicator .mode-select:hover{border-color:var(--accent)}.page-indicator.webtoon-controls{bottom:auto;top:auto;right:1rem;left:auto;transform:none;border-radius:16px;border-bottom:1px solid var(--border);bottom:1rem;font-size:.75rem;padding:.375rem .75rem}.page-indicator{position:fixed;bottom:0;left:50%;transform:translate(-50%);z-index:10;display:flex;gap:.75rem;align-items:center;background:#000000d9;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);padding:.5rem 1rem;border-radius:8px 8px 0 0;border:1px solid var(--border);border-bottom:none;font-size:.875rem;opacity:1;transition:opacity .25s ease}.page-indicator.hidden{opacity:0;pointer-events:none}.page-indicator button{background:transparent;color:#ddd;border:1px solid var(--border);padding:.375rem .75rem;border-radius:4px;cursor:pointer;font-family:inherit;font-size:.8125rem}.page-indicator button:hover:not(:disabled){border-color:var(--accent)}.page-indicator button:disabled{opacity:.4;cursor:not-allowed}@media (max-width: 700px){.page-indicator{gap:.375rem;padding:.375rem .625rem;flex-wrap:wrap;justify-content:center;max-width:calc(100% - .5rem)}.page-indicator button,.page-indicator .settings-toggle,.page-indicator .mode-select{padding:.25rem .5rem;font-size:.75rem;white-space:nowrap;flex-shrink:0}.page-indicator span{white-space:nowrap}}.reader-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:2rem;color:var(--error);text-align:center}.reader-error-detail{color:var(--fg-muted);font-size:.75rem;word-break:break-all;max-width:600px}.pdf-page-area{background:#1a1a1a}.pdf-page-area .react-pdf__Document{display:flex;justify-content:center;align-items:center;gap:4px;width:100%;height:100%}.pdf-page-area.two .react-pdf__Document{flex-direction:row;flex-wrap:nowrap}.pdf-page-area .react-pdf__Page{background:transparent!important;display:flex;align-items:center;justify-content:center}.pdf-page-area canvas{max-width:100%;max-height:100dvh;width:auto!important;height:auto!important;display:block}.epub-reader{position:relative;height:100dvh}.epub-area{position:absolute;top:0;right:0;bottom:0;left:0;background:#f5f5f0;margin:0 auto;max-width:1800px;overflow:hidden}.epub-tap-left,.epub-tap-center,.epub-tap-right{position:absolute;top:0;bottom:0;z-index:5;cursor:pointer}.epub-tap-left{left:0;width:30%}.epub-tap-center{left:30%;width:40%}.epub-tap-right{right:0;width:30%}.webtoon-reader{display:flex;flex-direction:column;align-items:center;height:100dvh;overflow-y:auto}.webtoon-page{width:100%;max-width:800px;display:flex;justify-content:center}.webtoon-image{max-width:100%;width:auto;height:auto;display:block;-webkit-user-drag:none}.webtoon-indicator{position:fixed;bottom:1rem;right:1rem;background:#000c;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);padding:.375rem .75rem;border-radius:16px;font-size:.75rem;border:1px solid var(--border)}@media (max-width: 600px){.book-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}.book-card .info{padding:.5rem}.book-card .title{font-size:.8125rem}.topbar h1{font-size:1.0625rem}}@media (max-width: 700px){.reader-topbar{gap:.375rem;padding:.5rem .625rem;row-gap:.25rem}.reader-topbar .btn-link{font-size:.875rem;padding:.25rem .375rem;flex-shrink:0}.reader-topbar-logo img{height:20px}.reader-topbar .title{display:none}.reader-topbar-actions{margin-left:auto;gap:.125rem;flex-wrap:wrap;justify-content:flex-end}.topbar-icon{padding:.25rem .5rem;font-size:.8125rem;flex-shrink:0;white-space:nowrap}.topbar-icon-num{font-size:.75rem}}@media (max-width: 380px){.reader-topbar{gap:.25rem}.reader-topbar-logo{display:none}.topbar-icon{padding:.25rem .375rem;font-size:.75rem}}.star-rating{display:inline-flex;gap:.0625em;-webkit-user-select:none;user-select:none;line-height:1}.star-slot{position:relative;display:inline-block;width:1em;height:1em}.star-bg,.star-fg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;font-family:"Apple Color Emoji","Segoe UI Emoji",system-ui,sans-serif;display:inline-block}.star-bg{color:var(--border)}.star-fg{color:var(--admin);overflow:hidden;white-space:nowrap}.star-fg.fill-empty{width:0}.star-fg.fill-half{width:50%}.star-fg.fill-full{width:100%}.star-zone{position:absolute;top:0;bottom:0;width:50%;background:transparent;border:0;cursor:pointer;padding:0;margin:0}.star-zone-left{left:0}.star-zone-right{right:0}.star-rating[data-interactive=true] .star-slot:hover{transform:scale(1.05)}.rating-inline{display:inline-flex;align-items:center;line-height:1}.book-card .rating-inline,.work-card .rating-inline,.author-card .rating-inline{margin-top:.125rem}.review-badge{display:inline-flex;align-items:center;justify-content:center;font-size:1rem;line-height:1;color:var(--accent)}.row-activity{display:inline-flex;align-items:center;gap:.375rem}.book-card .row-activity,.work-card .row-activity,.author-card .row-activity{margin-top:.125rem}.book-row-dense .rating,.work-row-dense .rating{display:inline-flex}.target-rating{display:flex;flex-direction:column;gap:.5rem;padding:.875rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:8px}.target-rating-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.target-rating-numeric{font-variant-numeric:tabular-nums;font-size:.9375rem;color:var(--fg);min-width:3rem}.target-rating-public{display:flex;align-items:center;gap:.4rem;font-size:.875rem;color:var(--fg-muted);cursor:pointer}.target-rating-public input[type=checkbox]{accent-color:var(--accent);cursor:pointer}.target-rating-ref{display:flex;justify-content:space-between;align-items:baseline;font-size:.875rem;padding-top:.25rem;border-top:1px dashed var(--border)}.target-rating-others{font-size:.875rem}.target-rating-others summary{color:var(--fg-muted);cursor:pointer;padding:.25rem 0}.target-rating-others ul{list-style:none;display:flex;flex-direction:column;gap:.375rem;padding-top:.375rem}.target-rating-others li{display:flex;align-items:center;gap:.5rem}.target-rating-others .username{min-width:6rem;color:var(--fg)}.target-rating-error{margin-top:.25rem}.target-review{display:flex;flex-direction:column;gap:.625rem;padding:.875rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:8px}.target-review-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-wrap:wrap}.target-review-header h3{font-size:1rem;font-weight:600}.target-review-actions{display:flex;gap:.5rem;flex-wrap:wrap}.target-review-textarea{width:100%;min-height:8rem;padding:.625rem;background:var(--bg-input);color:var(--fg);border:1px solid var(--border);border-radius:6px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.875rem;resize:vertical}.target-review-textarea:focus{outline:1px solid var(--accent);border-color:var(--accent)}.target-review-body{font-size:.9375rem;line-height:1.55;word-break:break-word}.target-review-body>*:first-child{margin-top:0}.target-review-body>*:last-child{margin-bottom:0}.target-review-body h1,.target-review-body h2,.target-review-body h3,.target-review-body h4,.target-review-body h5,.target-review-body h6{font-weight:600;line-height:1.3;margin:.75rem 0 .375rem}.target-review-body h1{font-size:1.25rem}.target-review-body h2{font-size:1.125rem}.target-review-body h3{font-size:1rem}.target-review-body h4,.target-review-body h5,.target-review-body h6{font-size:.9375rem}.target-review-body p{margin:.375rem 0}.target-review-body ul,.target-review-body ol{margin:.375rem 0;padding-left:1.5rem}.target-review-body li{margin:.125rem 0}.target-review-body li>p{margin:0}.target-review-body hr{border:0;border-top:1px solid var(--border);margin:.75rem 0}.target-review-body blockquote{border-left:3px solid var(--border);padding-left:.75rem;margin:.5rem 0;color:var(--fg-muted)}.target-review-body code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.875em;background:var(--bg-input);padding:.125em .3em;border-radius:4px}.target-review-body pre{background:var(--bg-input);padding:.625rem .75rem;border-radius:6px;overflow-x:auto;margin:.5rem 0}.target-review-body pre code{background:none;padding:0;font-size:.875em}.target-review-body a{color:var(--accent);text-decoration:none}.target-review-body a:hover{text-decoration:underline}.target-review-body strong{font-weight:600}.target-review-body em{font-style:italic}.target-review-body img{max-width:100%;height:auto;border-radius:4px}.target-review-meta{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--fg-muted)}.target-review-others{font-size:.875rem}.target-review-others-list{display:flex;flex-direction:column;gap:.625rem;padding-top:.5rem}.target-review-others-item{border-top:1px dashed var(--border);padding-top:.5rem}.target-review-others-item .username{font-weight:500;color:var(--fg)}.spoiler-tag{font-size:.75rem;padding:.0625rem .375rem;border-radius:.25rem;background:#f59e0b26;color:#f59e0b;border:1px solid rgba(245,158,11,.4);font-weight:500}.spoiler-veil{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1.25rem 1rem;margin:.375rem 0;background:repeating-linear-gradient(45deg,#f59e0b14,#f59e0b14 10px,#f59e0b29 10px,#f59e0b29 20px);border:1px dashed rgba(245,158,11,.5);border-radius:.5rem;color:var(--fg);font-size:.9375rem;font-weight:500;cursor:pointer;transition:background .12s ease,border-color .12s ease}.spoiler-veil:hover{background:repeating-linear-gradient(45deg,#f59e0b24,#f59e0b24 10px,#f59e0b38 10px,#f59e0b38 20px);border-color:#f59e0bbf}.spoiler-collapse{font-size:.75rem;margin-top:.25rem}.admin-page{max-width:64rem;margin:0 auto;padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.admin-page h1{font-size:1.375rem;font-weight:600}.admin-tabs{display:flex;gap:.5rem;border-bottom:1px solid var(--border)}.admin-tab{padding:.5rem .875rem;background:transparent;color:var(--fg-muted);border:0;border-bottom:2px solid transparent;cursor:pointer;font-family:inherit;font-size:.9375rem}.admin-tab[data-active=true]{color:var(--fg);border-bottom-color:var(--accent)}.orphan-table{width:100%;border-collapse:collapse;font-size:.875rem}.orphan-table th,.orphan-table td{padding:.5rem .625rem;text-align:left;border-bottom:1px solid var(--border);vertical-align:top}.orphan-table th{color:var(--fg-muted);font-weight:500}.orphan-table .actions{display:flex;gap:.375rem;flex-wrap:wrap}.orphan-payload{max-width:22rem;white-space:pre-wrap;word-break:break-word}.me-activity-page{max-width:56rem;margin:0 auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.me-activity-page h1{font-size:1.375rem;font-weight:600}.me-tabs{display:flex;gap:.5rem;border-bottom:1px solid var(--border)}.me-tab{padding:.5rem .875rem;background:transparent;color:var(--fg-muted);border:0;border-bottom:2px solid transparent;cursor:pointer;font-family:inherit;font-size:.9375rem}.me-tab[data-active=true]{color:var(--fg);border-bottom-color:var(--accent)}.me-target-filter{display:flex;flex-wrap:wrap;gap:.375rem}.me-target-chip{padding:.25rem .625rem;background:transparent;color:var(--fg-muted);border:1px solid var(--border);border-radius:999px;cursor:pointer;font-family:inherit;font-size:.8125rem}.me-target-chip[data-active=true]{background:var(--accent);color:var(--bg);border-color:var(--accent)}.me-list{display:flex;flex-direction:column;gap:.75rem}.me-row{display:flex;gap:.875rem;padding:.75rem;background:var(--surface);border:1px solid var(--border);border-radius:.5rem}.me-row.orphan{opacity:.65}.me-row-cover{flex:0 0 4rem;width:4rem;height:5.5rem;background:var(--bg);border-radius:.25rem;overflow:hidden;display:flex;align-items:center;justify-content:center}.me-row-cover img{width:100%;height:100%;object-fit:cover}.me-row-cover.placeholder{color:var(--fg-muted);font-size:.75rem}.me-row-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:.5rem}.me-row-head{display:flex;justify-content:space-between;gap:.75rem;align-items:baseline;flex-wrap:wrap}.me-row-title{font-weight:500;font-size:1rem;word-break:break-word}.me-row-meta{font-size:.75rem;white-space:nowrap}.me-row-rating,.me-row-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.me-row-score{font-variant-numeric:tabular-nums;color:var(--fg-muted);font-size:.875rem}.me-row-public{display:flex;align-items:center;gap:.25rem;font-size:.8125rem;color:var(--fg-muted);cursor:pointer}.me-row-body{font-size:.9375rem;max-height:12rem;overflow:auto}.pager{display:flex;justify-content:center;align-items:center;gap:1rem;padding:1rem 0}.book-card .cover,.work-card .cover,.me-reading-cover{position:relative}.book-row-list,.book-row-dense,.work-row-list,.work-row-dense,.me-reading-row,.me-reading-row-dense{position:relative;isolation:isolate}.row-progress{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:0;border-radius:inherit}.row-progress-fill{height:100%;background:#f59e0b17;transition:width .2s ease}.row-progress.done .row-progress-fill{background:#16a34a1c}.book-row-list>*:not(.row-progress):not(.read-toggle),.book-row-dense>*:not(.row-progress):not(.read-toggle),.work-row-list>*:not(.row-progress):not(.read-toggle),.work-row-dense>*:not(.row-progress):not(.read-toggle),.me-reading-row>*:not(.row-progress):not(.read-toggle),.me-reading-row-dense>*:not(.row-progress):not(.read-toggle){position:relative;z-index:1}.book-card .cover .row-progress,.work-card .cover .row-progress,.me-reading-cover .row-progress{border-radius:0}.read-toggle{position:absolute;top:.375rem;right:.375rem;z-index:5;width:1.5rem;height:1.5rem;padding:0;border:0;border-radius:50%;background:#00000073;color:#ffffff8c;font-size:.875rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.read-toggle:hover{background:#000000b3;color:var(--fg)}.read-toggle.partial{color:#f59e0bd9}.read-toggle.done{color:#22c55ef2;background:#0009}.read-toggle:disabled{opacity:.4;cursor:wait}.cover-toggle{display:contents}.read-toggle-btn{display:inline-flex;align-items:center;gap:.375rem}.read-toggle-btn.done{background:#22c55e2e;color:var(--fg);border-color:#22c55e66}.reader-topbar-logo{display:inline-flex;align-items:center;flex-shrink:0;border-radius:4px;padding:2px 4px;transition:opacity .12s ease}.reader-topbar-logo img{height:24px;width:auto;display:block}.reader-topbar-logo:hover{opacity:.8}.reader-topbar-logo:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.reader-topbar-actions{display:flex;gap:.25rem;align-items:center;margin-left:auto;flex-shrink:0}.topbar-icon{display:inline-flex;align-items:center;gap:.25rem;padding:.375rem .625rem;background:transparent;color:#ffffffa6;border:0;border-radius:.375rem;cursor:pointer;font-family:inherit;font-size:.875rem;white-space:nowrap}.topbar-icon:hover:not(:disabled){background:#ffffff14;color:#fff}.topbar-icon:disabled{opacity:.35;cursor:not-allowed}.topbar-icon.active{color:#f59e0b}.topbar-icon-num{font-size:.8125rem;font-variant-numeric:tabular-nums}.reader-topbar .title{min-width:0}.reader-panel-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:20}.reader-side-panel{position:fixed;top:0;right:0;bottom:0;width:min(420px,90vw);background:var(--bg, #111);border-left:1px solid var(--border);z-index:21;display:flex;flex-direction:column;box-shadow:-8px 0 24px #0006;animation:reader-panel-slide-in .18s ease-out}@keyframes reader-panel-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.reader-panel-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border);flex-shrink:0}.reader-panel-header h3{font-size:1.0625rem;font-weight:500;margin:0}.reader-panel-body{flex:1;overflow-y:auto;padding:1rem 1.25rem}.series-info-link{display:block;padding:.5rem .75rem;margin-bottom:.5rem;background:#6366f11a;color:var(--accent);border:1px solid rgba(99,102,241,.3);border-radius:.375rem;text-decoration:none;font-size:.875rem;text-align:center;transition:background .12s}.series-info-link:hover{background:#6366f12e}.series-jump-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.25rem}.series-jump-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.625rem .75rem;background:transparent;color:var(--fg);border:1px solid transparent;border-radius:.375rem;cursor:pointer;font-family:inherit;font-size:.9375rem;text-align:left;transition:background .12s,border-color .12s}.series-jump-item:hover:not(:disabled){background:#ffffff0d;border-color:var(--border)}.series-jump-item.current{background:#f59e0b1a;cursor:default}.series-jump-index{flex-shrink:0;font-variant-numeric:tabular-nums;color:var(--fg-muted);min-width:2.5rem}.series-jump-title{flex:1;word-break:break-word}.series-jump-current-tag{font-size:.75rem;flex-shrink:0}.bookmark-badge{font-size:.875rem;line-height:1}.bookmark-panel,.bookmark-section{display:flex;flex-direction:column;gap:.75rem}.jump-panel{display:flex;flex-direction:column;gap:1rem}.jump-current{font-size:.875rem}.jump-current strong{color:var(--fg)}.jump-row{display:flex;gap:.5rem}.jump-row .btn-primary{flex:1}.jump-specific{display:flex;flex-direction:column;gap:.375rem;padding-top:.75rem;border-top:1px solid var(--border)}.jump-specific-label{font-size:.8125rem;color:var(--muted)}.jump-specific-row{display:flex;gap:.5rem}.jump-specific-row input{flex:1;padding:.5rem .625rem;background:var(--bg);color:var(--fg);border:1px solid var(--border);border-radius:.375rem;font-family:inherit;font-size:.9375rem}.jump-specific-row input:focus{outline:1px solid var(--accent)}.jump-hint{font-size:.8125rem}.bookmark-section{margin-top:1.5rem}.bookmark-section h3{font-size:1rem;font-weight:500;margin:0 0 .25rem}.bookmark-add{display:flex;gap:.5rem}.bookmark-add input{flex:1;padding:.5rem .625rem;background:var(--bg);color:var(--fg);border:1px solid var(--border);border-radius:.375rem;font-family:inherit;font-size:.9375rem}.bookmark-add input:focus{outline:1px solid var(--accent)}.bookmark-hint{font-size:.8125rem}.bookmark-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.375rem}.bookmark-item{display:flex;gap:.375rem;align-items:center;padding:.375rem .5rem;background:var(--surface, transparent);border:1px solid var(--border);border-radius:.375rem}.bookmark-item input{flex:1;padding:.375rem .5rem;background:var(--bg);color:var(--fg);border:1px solid var(--border);border-radius:.25rem;font-family:inherit}.bookmark-jump{flex:1;display:flex;flex-direction:column;gap:.125rem;background:transparent;border:0;color:var(--fg);font-family:inherit;text-align:left;padding:.25rem .375rem;cursor:pointer;border-radius:.25rem}.bookmark-jump:hover{background:#ffffff0a}.bookmark-name{font-size:.9375rem;word-break:break-word}.bookmark-meta{font-size:.75rem}.curations-page,.curation-detail-page{max-width:64rem;margin:0 auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.curation-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.curation-search{flex:1;max-width:28rem;padding:.5rem .75rem;background:var(--bg);color:var(--fg);border:1px solid var(--border);border-radius:.375rem;font-family:inherit;font-size:.9375rem}.curation-search:focus{outline:1px solid var(--accent)}.curation-list{display:flex;flex-direction:column;gap:.5rem}.curation-row-list{display:flex;gap:.875rem;padding:.625rem .75rem;background:var(--surface);border:1px solid var(--border);border-radius:.5rem;text-decoration:none;color:inherit;transition:background .15s}.curation-row-list:hover{background:#ffffff0a}.curation-row-thumb{flex-shrink:0;width:3.5rem;height:5rem;background:var(--bg);border-radius:.25rem;overflow:hidden;display:flex;align-items:center;justify-content:center}.curation-row-thumb img{width:100%;height:100%;object-fit:cover}.curation-row-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.curation-row-title-line{display:flex;gap:.375rem;align-items:baseline;flex-wrap:wrap}.curation-row-title{font-size:1rem;font-weight:500;word-break:break-word}.curation-row-desc{margin:0;font-size:.8125rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.curation-row-meta{font-size:.75rem;display:flex;gap:.25rem;flex-wrap:wrap}.curation-dense{border:1px solid var(--border);border-radius:.5rem;overflow:hidden}.curation-row-dense{display:grid;grid-template-columns:minmax(220px,3fr) minmax(80px,.6fr) minmax(120px,1fr) minmax(100px,.8fr);gap:.75rem;padding:.5rem .75rem;border-bottom:1px solid var(--border);text-decoration:none;color:inherit;font-size:.875rem;align-items:center;transition:background .12s}.curation-row-dense:hover{background:#ffffff0a}.curation-row-dense:last-child{border-bottom:0}.curation-row-dense-title{display:flex;gap:.375rem;align-items:baseline;word-break:break-word;font-weight:500}.curation-row-dense-count,.curation-row-dense-owner,.curation-row-dense-date{font-size:.8125rem}.sidebar-section-label{padding:.875rem .875rem .25rem;font-size:.6875rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.auth-heading{font-size:1.125rem;font-weight:500;text-align:center;margin:0 0 .5rem}.auth-footer{font-size:.8125rem;text-align:center;margin-top:.5rem}.auth-footer a{color:var(--accent)}.form-hint{display:block;font-size:.75rem;margin-top:.25rem;font-weight:400}.admin-section-title{font-size:1rem;font-weight:500;margin-top:1rem;margin-bottom:.5rem}.invite-create{background:var(--surface);border:1px solid var(--border);border-radius:.5rem;padding:1rem;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.invite-create .btn-primary{align-self:flex-start}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.rating-chip-list{display:flex;flex-wrap:wrap;gap:.375rem}.rating-chip{padding:.25rem .625rem;background:transparent;color:var(--fg-muted);border:1px solid var(--border);border-radius:999px;cursor:pointer;font-family:inherit;font-size:.8125rem}.rating-chip:hover:not(:disabled){border-color:var(--accent)}.rating-chip.on{background:var(--accent);color:var(--bg);border-color:var(--accent);font-weight:500}.user-rows{display:flex;flex-direction:column;gap:.625rem}.user-row{background:var(--surface);border:1px solid var(--border);border-radius:.5rem;padding:.875rem 1rem;display:flex;flex-direction:column;gap:.625rem}.user-row-head{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.user-row-name{font-size:1rem;font-weight:500}.user-row-name-input{font-size:1rem;padding:.25rem .5rem;background:var(--bg);color:var(--fg);border:1px solid var(--border);border-radius:.25rem;font-family:inherit;min-width:12rem}.user-row-name-input[aria-invalid=true]{border-color:var(--error, #ef4444)}.user-row-meta{font-size:.75rem;margin-left:auto}.user-row-actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.me-account-page{max-width:40rem;margin:0 auto;padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.me-account-page h1{font-size:1.375rem;font-weight:600}.me-account-section{background:var(--surface);border:1px solid var(--border);border-radius:.5rem;padding:1rem 1.25rem}.me-account-section h2{font-size:1rem;font-weight:500;margin:0 0 .75rem}.me-account-info{display:grid;grid-template-columns:7rem 1fr;gap:.5rem .75rem;margin:0}.me-account-info dt{color:var(--fg-muted);font-size:.8125rem}.me-account-info dd{margin:0;word-break:break-word}.me-account-form{display:flex;flex-direction:column;gap:.5rem}.me-account-form .btn-primary{align-self:flex-start;margin-top:.5rem}.me-account-msg{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);padding:.5rem .75rem;border-radius:.375rem}.me-account-toggle{display:flex;align-items:flex-start;gap:.625rem;cursor:pointer;font-size:.9375rem}.me-account-toggle input[type=checkbox]{margin-top:.25rem;flex-shrink:0}.me-account-toggle-hint{display:block;font-size:.8125rem;margin-top:.125rem}.curation-card{display:flex;flex-direction:column;background:var(--bg-card, var(--surface));border:1px solid var(--border);border-radius:.5rem;overflow:hidden;text-decoration:none;color:inherit;transition:transform .15s,box-shadow .15s}.curation-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0006}.curation-card-covers{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr);gap:1px;background:var(--border);aspect-ratio:4 / 3}.curation-card-covers img{width:100%;height:100%;object-fit:cover;display:block}.curation-card-covers img:only-child{grid-column:1 / -1;grid-row:1 / -1}.curation-card-empty{grid-column:1 / -1;grid-row:1 / -1;display:flex;align-items:center;justify-content:center;background:var(--bg);font-size:.8125rem}.curation-card-body{padding:.75rem .875rem;display:flex;flex-direction:column;gap:.375rem}.curation-card-title-row{display:flex;gap:.375rem;align-items:baseline}.curation-card-title{font-size:1rem;font-weight:500;margin:0;flex:1;word-break:break-word}.curation-card-desc{font-size:.8125rem;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.curation-card-meta{font-size:.75rem;display:flex;gap:.25rem}.badge.curation-private{background:#6366f12e;color:var(--fg)}.curation-header{display:flex;flex-direction:column;gap:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.curation-header-row{display:flex;align-items:baseline;gap:.5rem;flex-wrap:wrap}.curation-header h1{font-size:1.5rem;font-weight:600;margin:0}.curation-header-meta{font-size:.875rem}.curation-description{margin:.5rem 0 0;word-break:break-word}.curation-header-edit{background:var(--surface);padding:1rem;border:1px solid var(--border);border-radius:.5rem;border-bottom:1px solid var(--border)}.curation-header-edit-actions{display:flex;gap:.5rem;align-items:center}.form-row{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.625rem}.form-row>span:first-child{font-size:.8125rem;color:var(--fg-muted)}.form-row input[type=text],.form-row textarea{padding:.5rem .625rem;background:var(--bg);color:var(--fg);border:1px solid var(--border);border-radius:.375rem;font-family:inherit;font-size:.9375rem}.form-row input:focus,.form-row textarea:focus{outline:1px solid var(--accent)}.form-row textarea{resize:vertical;min-height:4rem}.form-row-inline{flex-direction:row;align-items:center;gap:.5rem}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(480px,90vw);max-height:86vh;background:var(--bg);border:1px solid var(--border);border-radius:.5rem;z-index:30;display:flex;flex-direction:column;box-shadow:0 20px 50px #00000080}.modal-header,.modal-footer{padding:.875rem 1rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}.modal-header h3{margin:0;font-size:1.0625rem;font-weight:500}.modal-footer{border-bottom:0;border-top:1px solid var(--border);justify-content:flex-end;gap:.5rem}.modal-body{padding:1rem;overflow-y:auto}.curation-item-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.curation-item{display:flex;gap:.75rem;padding:.625rem;background:var(--surface);border:1px solid var(--border);border-radius:.5rem}.curation-item.orphan,.curation-item.inaccessible{opacity:.6}.curation-item-cover{flex-shrink:0;width:3rem;height:4.25rem;background:var(--bg);border-radius:.25rem;overflow:hidden;display:flex;align-items:center;justify-content:center}.curation-item-cover img{width:100%;height:100%;object-fit:cover}.curation-item-cover .cover-placeholder{font-size:.6875rem;color:var(--fg-muted)}.curation-item-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.curation-item-head{display:flex;flex-wrap:wrap;gap:.375rem;align-items:baseline}.curation-item-title{font-size:.9375rem;font-weight:500;word-break:break-word}.curation-item-note{margin:0;font-size:.8125rem;color:var(--fg-muted);white-space:pre-wrap}.curation-item-actions{display:flex;flex-direction:column;gap:.125rem;align-items:flex-end}.curation-item-actions .btn-link{padding:.25rem .375rem;font-size:.8125rem}.curation-add-section{padding:.75rem 0}.curation-add-box{background:var(--surface);border:1px solid var(--border);border-radius:.5rem;padding:.75rem;display:flex;flex-direction:column;gap:.5rem}.curation-add-head{display:flex;gap:.5rem}.curation-add-head input{flex:1;padding:.5rem .625rem;background:var(--bg);color:var(--fg);border:1px solid var(--border);border-radius:.375rem;font-family:inherit;font-size:.9375rem}.curation-add-results{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.25rem;max-height:22rem;overflow-y:auto}.curation-add-result{display:flex;gap:.5rem;align-items:center;width:100%;padding:.375rem .5rem;background:transparent;color:var(--fg);border:1px solid transparent;border-radius:.375rem;cursor:pointer;font-family:inherit;text-align:left}.curation-add-result:hover:not(:disabled){background:#ffffff0a;border-color:var(--border)}.curation-add-result img,.curation-add-result .cover-placeholder.small{flex-shrink:0;width:2.25rem;height:3.25rem;object-fit:cover;background:var(--bg);border-radius:.25rem;display:flex;align-items:center;justify-content:center;font-size:.625rem;color:var(--fg-muted)}.curation-add-result-info{flex:1;display:flex;flex-wrap:wrap;gap:.375rem;align-items:baseline;min-width:0}.curation-add-result-name{font-size:.9375rem;word-break:break-word}.markdown-editor{display:flex;flex-direction:column;gap:.5rem}.markdown-editor-preview{border-top:1px dashed var(--border);padding-top:.5rem}.markdown-editor-label{font-size:.75rem;margin-bottom:.25rem}.me-reading-page{max-width:56rem;margin:0 auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.me-reading-list{display:flex;flex-direction:column;gap:.75rem}.me-reading-row{display:flex;gap:.875rem;padding:.75rem;background:var(--surface);border:1px solid var(--border);border-radius:.5rem}.me-reading-cover{position:relative;flex:0 0 4rem;width:4rem;height:5.5rem;background:var(--bg);border-radius:.25rem;overflow:hidden;display:flex;align-items:center;justify-content:center}.me-reading-cover img{width:100%;height:100%;object-fit:cover}.me-reading-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:.375rem}.me-reading-head{display:flex;justify-content:space-between;gap:.75rem;align-items:baseline;flex-wrap:wrap}.me-reading-title{font-weight:500;font-size:1rem;word-break:break-word}.me-reading-date{font-size:.75rem;white-space:nowrap}.me-reading-series,.me-reading-meta{font-size:.875rem}.me-reading-meta{display:flex;align-items:center;gap:.5rem}.me-reading-actions{display:flex;gap:.5rem;margin-top:.25rem;flex-wrap:wrap}.me-reading-row-actions{align-self:center;flex-shrink:0;margin-top:0}.me-reading-dense{border:1px solid var(--border);border-radius:.5rem;overflow:hidden}.me-reading-row-dense{display:grid;grid-template-columns:minmax(220px,2.4fr) minmax(140px,1.2fr) minmax(60px,.4fr) minmax(60px,.4fr) minmax(90px,.6fr) minmax(140px,.9fr);gap:.75rem;padding:.5rem .75rem;border-bottom:1px solid var(--border);font-size:.875rem;align-items:center;cursor:pointer;transition:background .12s}.me-reading-row-dense:hover{background:#ffffff0a}.me-reading-row-dense:last-child{border-bottom:0}.me-reading-row-dense .title{word-break:break-word;font-weight:500}.me-reading-row-dense .actions{display:flex;gap:.375rem;justify-content:flex-end}.me-reading-row-dense .actions .btn-primary,.me-reading-row-dense .actions .btn-link{padding:.25rem .5rem;font-size:.8125rem}
