.library-container{padding:0 var(--spacing-xl)}.library-header{display:flex;justify-content:flex-end;margin-bottom:var(--spacing-2xl)}.view-toggle{display:inline-flex;border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden}.view-toggle button{background:transparent;border:none;padding:6px 10px;color:var(--color-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.875rem;transition:color var(--transition-fast),background var(--transition-fast)}.view-toggle button+button{border-left:1px solid var(--color-border)}.view-toggle button:hover{color:var(--color-primary)}.view-toggle button.active{background:var(--color-primary);color:var(--color-surface)}.book-section{margin-bottom:var(--spacing-3xl)}.book-section h2{display:flex;align-items:baseline;gap:var(--spacing-sm);font-family:var(--font-sans);font-weight:500;text-transform:uppercase;letter-spacing:.12em;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border-light)}.book-section h2,.book-section h2 .status-count{font-size:var(--text-xs);color:var(--color-muted)}.book-section h2 .status-count{font-weight:400;text-transform:none;letter-spacing:0}.section-icon{display:none}.book-section.year-section{scroll-margin-top:calc(var(--navbar-height) + var(--spacing-lg))}.book-section.year-section .collapsible-header{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;display:flex;align-items:baseline;gap:var(--spacing-sm);transition:color var(--transition-fast)}.book-section.year-section .collapsible-header:hover{color:var(--color-primary)}.book-section.year-section .collapse-icon{font-size:.75em;color:var(--color-muted);transition:transform var(--transition-fast)}.book-section.year-section.collapsed .collapsible-header{margin-bottom:0;border-bottom:none;padding-bottom:0}.book-section.year-section.collapsed h2{border-bottom:none;padding-bottom:var(--spacing-sm);margin-bottom:0}.book-section.year-section .section-subtitle{font-size:.85em;color:var(--color-muted);font-weight:400;text-transform:none;letter-spacing:0}.book-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--spacing-2xl) var(--spacing-xl)}.book-item{display:flex;flex-direction:column;align-items:flex-start;text-align:left}.book-cover-wrapper{position:relative;width:100%;aspect-ratio:2/3;border-radius:var(--radius-sm);overflow:visible;box-shadow:var(--shadow-md);transition:transform var(--transition-fast);margin-bottom:var(--spacing-md)}.book-cover-wrapper>img,.book-cover-wrapper>span{border-radius:var(--radius-sm);overflow:hidden}.book-cover-wrapper:hover{transform:translateY(-2px)}.book-item h3{font-size:var(--text-sm);font-weight:500;color:var(--color-primary);margin:0 0 2px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.book-item p{font-size:var(--text-xs);color:var(--color-muted);margin:0}.book-meta-row{display:inline-flex;align-items:center;gap:8px;margin-top:4px}.book-meta-icon{font-size:.7rem;color:var(--color-muted);opacity:.85}.highlight-badge{position:absolute;top:-6px;right:-6px;background:var(--color-surface);color:var(--color-primary);padding:3px 8px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;border:1px solid var(--color-border);display:inline-flex;align-items:center;gap:4px;text-decoration:none;transition:transform var(--transition-fast),border-color var(--transition-fast);z-index:10}.highlight-badge:hover{border-color:var(--color-primary)}.highlight-badge svg{color:var(--color-muted);font-size:.75em}.highlight-badge .audio-icon,.highlight-badge .favorite-star,.highlight-badge .reread-icon{display:none}.status-badge{position:absolute;top:-6px;right:-6px;background:var(--color-surface);color:var(--color-muted);padding:4px 6px;border-radius:var(--radius-full);border:1px solid var(--color-border);z-index:10;display:inline-flex;align-items:center;gap:4px;font-size:var(--text-xs)}.book-list-container{overflow-x:auto}.library-table{width:100%;border-collapse:collapse;table-layout:fixed}.library-table td,.library-table th{padding:var(--spacing-md);text-align:left;border-bottom:1px solid var(--color-border-light);vertical-align:middle}.library-table td:first-child,.library-table th:first-child{width:60%}.library-table td:nth-child(2),.library-table th:nth-child(2){width:25%}.library-table td:nth-child(3),.library-table th:nth-child(3){width:15%}.library-table th:first-child:nth-last-child(2){width:70%}.library-table th:nth-child(2):last-child{width:30%}.library-table th{font-size:var(--text-xs);font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--color-muted);background:transparent}.library-table th:hover{cursor:pointer;color:var(--color-primary)}.library-table td{font-size:var(--text-sm);color:var(--color-secondary)}.library-table tbody tr:hover{background:var(--color-border-light)}.book-title-with-icons{display:inline-flex;align-items:center;flex-wrap:wrap;gap:0}.book-title-text{color:var(--color-primary);font-weight:500}.list-audio-icon,.list-favorite-icon,.list-reread-icon{color:var(--color-muted);margin-left:6px;font-size:.7em;flex-shrink:0}.header-icon{margin-left:var(--spacing-xs);color:var(--color-muted);font-size:.75em;vertical-align:middle}.active-sort{color:var(--color-primary)}.reread-icon{font-size:.65rem;opacity:.7}@media (max-width:768px){.library-container{padding:0 var(--spacing-md)}.book-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:var(--spacing-xl) var(--spacing-md)}}@media (max-width:480px){.book-grid{grid-template-columns:repeat(2,1fr)}}.book-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);animation:modalFadeIn .2s ease-out}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.book-modal{background:var(--color-surface);border-radius:var(--radius-lg);max-width:560px;width:100%;max-height:85vh;overflow-y:auto;position:relative;box-shadow:0 25px 50px -12px rgba(0,0,0,.25);animation:modalSlideUp .25s ease-out}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.book-modal-close{position:absolute;top:var(--spacing-md);right:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-muted);transition:color var(--transition-fast),border-color var(--transition-fast);z-index:10;font-size:.8rem}.book-modal-close:hover{color:var(--color-primary);border-color:var(--color-primary)}.book-modal-content{display:flex;flex-direction:row;align-items:flex-start;padding:var(--spacing-xl);gap:var(--spacing-xl)}.book-modal-cover{position:relative;width:140px;min-width:140px;height:210px;flex-shrink:0;border-radius:var(--radius-sm);overflow:hidden;box-shadow:var(--shadow-lg)}.book-modal-details{text-align:left;width:100%;min-width:0}.book-modal-title{font-family:var(--font-serif);font-size:var(--text-xl);font-weight:500;color:var(--color-primary);margin:0 0 .2rem;line-height:1.3;letter-spacing:-.01em;padding-right:var(--spacing-xl)}.book-modal-author{font-size:var(--text-sm);color:var(--color-muted);margin:0 0 var(--spacing-md)}.book-modal-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.book-modal-badge{display:inline-flex;align-items:center;gap:.3rem;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;padding:3px 0;background:transparent;color:var(--color-muted);font-weight:500}.book-modal-badge+.book-modal-badge{border-left:1px solid var(--color-border);padding-left:var(--spacing-sm)}.book-modal-badge.favorite{color:var(--color-accent)}.book-modal-badge svg{font-size:.85em}.book-modal-review{font-family:var(--font-serif);font-size:var(--text-base);font-style:italic;color:var(--color-secondary);line-height:1.7;margin:0 0 var(--spacing-lg);padding:0 0 0 var(--spacing-md);border-left:2px solid var(--color-border)}.book-modal-highlights-link{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .9rem;background:transparent;color:var(--color-primary);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500;text-decoration:none;transition:border-color var(--transition-fast),background var(--transition-fast)}.book-modal-highlights-link:hover{border-color:var(--color-primary);background:var(--color-border-light)}@media (max-width:540px){.book-modal{max-width:calc(100vw - 2rem);max-height:90vh}.book-modal-content{flex-direction:column;align-items:center;padding:var(--spacing-lg);gap:var(--spacing-lg)}.book-modal-cover{width:120px;min-width:120px;height:180px}.book-modal-details{text-align:center}.book-modal-title{font-size:var(--text-lg);padding-right:0}.book-modal-meta{justify-content:center}.book-modal-badge+.book-modal-badge{padding-left:var(--spacing-sm)}.book-modal-review{text-align:left}.book-modal-highlights-link{display:flex;justify-content:center}}