.book-card{display:flex;align-items:center;gap:16px;padding:16px;transition:background .2s;border-bottom:1px solid var(--border-color)}.book-card:hover{background:var(--bg-primary)}.book-cover-wrap{flex-shrink:0;width:64px;height:72px;border-radius:4px;overflow:hidden;border:1px solid var(--border-color);background:var(--bg-tertiary)}.book-cover-img{width:100%;height:100%;object-fit:contain}.book-cover-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary)}.fallback-emoji{font-size:1.75rem;opacity:.4}.book-card-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.book-category{font-size:.7rem;color:var(--text-secondary);padding:1px 8px;border:1px solid var(--border-color);border-radius:20px}.book-title{font-size:.95rem;font-weight:600;color:var(--text-primary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;transition:color .2s}.book-card:hover .book-title{color:var(--accent-primary)}.book-subtitle{font-size:.8rem;color:var(--text-secondary);line-height:1.3;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.book-meta{display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--text-secondary)}.dot{color:var(--border-color)}.book-rating{display:flex;gap:1px}.star-full,.star-half,.star-empty{display:block}.book-tags{display:flex;flex-wrap:wrap;gap:4px}.book-tag{font-size:.7rem;color:var(--text-secondary)}.book-arrow{flex-shrink:0;color:var(--text-tertiary);transition:color .2s}.book-card:hover .book-arrow{color:var(--accent-primary)}@media(max-width:768px){.book-card{padding:12px;gap:12px}.book-cover-wrap{width:52px;height:60px}.book-title{font-size:.9rem}}.category-filter{display:flex;flex-wrap:wrap;gap:6px}.category-chip{padding:4px 12px;border-radius:20px;font-size:.8rem;font-weight:500;color:var(--text-secondary);background:var(--bg-tertiary);border:1px solid transparent;transition:all .15s}.category-chip:hover{color:var(--text-primary)}.category-chip.active{background:var(--accent-light);color:var(--accent-primary);border-color:var(--accent-primary);font-weight:600}.home{flex:1}.home-content{max-width:var(--max-width);margin:0 auto;padding:24px 24px 80px;display:flex;flex-direction:column;gap:16px}.search-wrap{position:relative}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-tertiary);pointer-events:none}.search-input{width:100%;padding:8px 12px 8px 36px;border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;border:1px solid var(--border-color);transition:border-color .15s}.search-input:focus{border-color:var(--accent-primary);outline:none}.search-input::placeholder{color:var(--text-tertiary)}.reading-history{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:16px}.reading-history .section-title{display:flex;align-items:center;gap:8px;font-size:.85rem;font-weight:600;color:var(--text-primary);margin-bottom:12px}.history-list{display:flex;flex-direction:column;gap:8px}.history-item{position:relative;display:flex;align-items:center;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);transition:border-color .15s}.history-item:hover{border-color:var(--accent-primary)}.history-link{flex:1;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 40px 12px 12px;min-width:0}.history-remove{position:absolute;right:6px;top:6px;display:flex;align-items:center;justify-content:center;width:20px;height:20px;color:var(--text-tertiary);border-radius:4px;transition:color .15s,background .15s}.history-remove:hover{color:var(--text-primary);background:var(--bg-tertiary)}.history-info{display:flex;flex-direction:column;gap:2px;min-width:0}.history-book{font-size:.7rem;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-chapter{font-size:.85rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-progress{display:flex;align-items:center;gap:8px;flex-shrink:0}.progress-bar{width:120px;height:4px;background:var(--border-color);border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:var(--accent-primary);border-radius:2px;transition:width .2s}.progress-text{font-size:.7rem;font-weight:600;color:var(--text-tertiary);min-width:32px;text-align:right}.book-list{display:flex;flex-direction:column;gap:0}.home-status{display:flex;flex-direction:column;align-items:center;gap:8px;padding:64px 20px;text-align:center}.status-msg{font-size:.875rem;color:var(--text-tertiary)}.status-detail{font-size:.8rem;color:var(--text-tertiary)}.status-btn{margin-top:8px;padding:8px 16px;border-radius:var(--radius-sm);background:var(--accent-primary);color:#fff;font-size:.8rem;font-weight:500;transition:background .15s}.status-btn:hover{background:var(--accent-hover)}.loader{width:24px;height:24px;border:2px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .7s linear infinite}@media(max-width:768px){.home-content{padding:16px 16px 60px}.reading-history{padding:12px}.history-link{flex-direction:column;align-items:flex-start;gap:8px;padding:10px 36px 10px 12px}.history-progress{width:100%}.progress-bar{flex:1}.history-remove{right:10px;top:10px}}.header{position:sticky;top:0;z-index:100;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.header-inner{max-width:var(--max-width);margin:0 auto;padding:0 24px;height:var(--header-height);display:flex;align-items:center;justify-content:space-between}.header-left{display:flex;align-items:center;gap:24px}.header-nav{display:flex;align-items:center;gap:4px}.header-tab{font-size:.85rem;font-weight:500;color:var(--text-secondary);padding:4px 10px;border-radius:var(--radius-sm);transition:color .2s,background .15s}.header-tab:hover{color:var(--text-primary);background:var(--bg-tertiary)}.header-tab.active{color:var(--text-primary);font-weight:700}.header-logo{display:flex;align-items:center;gap:8px;font-size:.95rem;font-weight:600;color:var(--text-primary);transition:color .2s}.header-logo:hover{color:var(--accent-primary)}.logo-icon{flex-shrink:0;color:var(--text-secondary);display:flex;stroke-width:3;transition:color .2s}.header-logo:hover .logo-icon{color:var(--accent-primary)}.logo-text{font-size:.95rem;font-weight:1000;line-height:1}.theme-toggle{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-secondary);border:1px solid var(--border-color);transition:background .15s}.theme-toggle:hover{background:var(--bg-tertiary)}@media(max-width:768px){.header-inner{padding:0 16px}.header-left{gap:16px}.header-tab{font-size:.8rem;padding:4px 8px}}.footer{margin-top:auto;padding:24px 24px 32px;border-top:1px solid var(--border-color)}.footer-inner{max-width:var(--max-width);margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:12px}.footer-links{display:flex;align-items:center;gap:8px}.footer-link{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm);color:var(--text-tertiary);transition:color .2s}.footer-link:hover{color:var(--accent-primary)}.footer-copy{font-size:.75rem;color:var(--text-tertiary)}@media(max-width:768px){.footer{padding:20px 16px 28px}}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:-apple-system,BlinkMacSystemFont,Apple SD Gothic Neo,Pretendard,Roboto,Noto Sans KR,Segoe UI,Malgun Gothic,sans-serif;line-height:1.6;color:var(--text-primary);background-color:var(--bg-primary);transition:background-color .2s ease,color .2s ease}a{text-decoration:none;color:inherit}ul,ol{list-style:none}img{max-width:100%;display:block}button{cursor:pointer;border:none;background:none;font-family:inherit}input,textarea{font-family:inherit;border:none;outline:none}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.page-loading{position:fixed;top:var(--header-height);left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:var(--bg-primary);z-index:50}.loader-lg{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}.loading-text{font-size:.9rem;color:var(--text-secondary)}@keyframes spin{to{transform:rotate(360deg)}}:root{--bg-primary: #f6f8fa;--bg-secondary: #ffffff;--bg-tertiary: #eaeef2;--text-primary: #1f2328;--text-secondary: #656d76;--text-tertiary: #8b949e;--accent-primary: #6366f1;--accent-light: #eef2ff;--accent-hover: #4f46e5;--border-color: #d0d7de;--radius-sm: 6px;--radius-md: 6px;--radius-lg: 6px;--max-width: 1012px;--header-height: 48px;--yellow: #bf8700;--green: #1a7f37}[data-theme=dark]{--bg-primary: #0d1117;--bg-secondary: #161b22;--bg-tertiary: #21262d;--text-primary: #e6edf3;--text-secondary: #8b949e;--text-tertiary: #6e7681;--accent-primary: #818cf8;--accent-light: #1e1b4b;--accent-hover: #a5b4fc;--border-color: #30363d}.app{min-height:100vh;display:flex;flex-direction:column}
