@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Libre+Baskerville:ital,wght@0,400;0,700;1,400&display=swap');
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

/* Themes */
.theme-light{--bg:#FFFBEB;--bg2:#FEF3C7;--text:#292524;--text2:#78716C;--text3:#A8A29E;--border:#E7E5E4;--accent:#D97706;--accent2:#10B981;--surface:#FFFFFF;--sidebar-bg:#FEF3C7}
.theme-sepia{--bg:#F5E6CC;--bg2:#EBD5B3;--text:#3E2C1C;--text2:#6B5744;--text3:#8B7355;--border:#D4C4A8;--accent:#92400E;--accent2:#10B981;--surface:#F9EDDA;--sidebar-bg:#EBD5B3}
.theme-dark{--bg:#1C1917;--bg2:#292524;--text:#E7E5E4;--text2:#A8A29E;--text3:#78716C;--border:#44403C;--accent:#F59E0B;--accent2:#34D399;--surface:#292524;--sidebar-bg:#292524}
.theme-oled{--bg:#000000;--bg2:#0A0A0A;--text:#E5E5E5;--text2:#737373;--text3:#525252;--border:#262626;--accent:#FBBF24;--accent2:#34D399;--surface:#0A0A0A;--sidebar-bg:#0A0A0A}

:root{--font-ui:'Inter',system-ui,sans-serif;--font-reading:'Libre Baskerville',Georgia,serif;--radius:8px;--tr:.2s ease}
body{font-family:var(--font-ui);background:var(--bg);color:var(--text);min-height:100vh;transition:background .3s,color .3s}

/* Drop zone */
.drop-overlay{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}
.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:64px 40px;text-align:center;cursor:pointer;transition:var(--tr);max-width:500px;width:100%;background:var(--surface)}
.drop-zone:hover,.drop-zone.dragover{border-color:var(--accent);background:rgba(217,119,6,.04)}
.drop-zone__icon{font-size:3rem;margin-bottom:16px}
.drop-zone__title{font-size:1.8rem;font-weight:700;color:var(--text);margin-bottom:8px}
.drop-zone__text{font-size:1rem;color:var(--text2);margin-bottom:6px}
.drop-zone__hint{font-size:.82rem;color:var(--text3)}

/* Reader layout */
.reader{display:grid;grid-template-rows:auto 1fr auto;min-height:100vh}

/* Top bar */
.top-bar{display:flex;align-items:center;gap:12px;padding:10px 20px;background:var(--surface);border-bottom:1px solid var(--border);z-index:10}
.book-title{flex:1;font-size:.9rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.top-actions{display:flex;gap:4px}
.icon-btn{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:6px 8px;border-radius:var(--radius);color:var(--text2);transition:var(--tr)}
.icon-btn:hover{background:var(--bg2);color:var(--text)}

/* Search bar */
.search-bar{display:flex;align-items:center;gap:8px;padding:8px 20px;background:var(--bg2);border-bottom:1px solid var(--border)}
.search-input{flex:1;padding:8px 12px;font-family:var(--font-ui);font-size:.85rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);outline:none}
.search-input:focus{border-color:var(--accent)}
.search-count{font-size:.78rem;color:var(--text3);white-space:nowrap}

/* Sidebar */
.sidebar{position:fixed;top:0;left:0;bottom:0;width:280px;background:var(--sidebar-bg);border-right:1px solid var(--border);z-index:20;transform:translateX(-100%);transition:transform .3s ease;overflow-y:auto;padding-top:8px}
.sidebar.open{transform:translateX(0)}
.sidebar-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:8px}
.sidebar-tab{flex:1;padding:10px;font-family:var(--font-ui);font-size:.82rem;font-weight:600;background:none;border:none;color:var(--text2);cursor:pointer;border-bottom:2px solid transparent;transition:var(--tr)}
.sidebar-tab:hover{color:var(--text)}
.sidebar-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.sidebar-content{padding:8px 16px}
.toc-item{padding:8px 10px;font-size:.85rem;color:var(--text2);cursor:pointer;border-radius:var(--radius);transition:var(--tr);margin-bottom:2px}
.toc-item:hover{background:var(--bg2);color:var(--text)}
.toc-item.active{color:var(--accent);font-weight:600;background:rgba(217,119,6,.08)}
.bm-item{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;font-size:.82rem;cursor:pointer;border-radius:var(--radius);transition:var(--tr);margin-bottom:2px;color:var(--text2)}
.bm-item:hover{background:var(--bg2)}
.bm-item .note{font-size:.75rem;color:var(--text3)}
.bm-item .remove{background:none;border:none;color:var(--text3);cursor:pointer;font-size:.85rem}.bm-item .remove:hover{color:#EF4444}

/* Content */
.content-area{max-width:720px;margin:0 auto;padding:40px 24px 60px;min-height:calc(100vh - 120px);transition:max-width .3s}
.content-area.two-col{max-width:960px;column-count:2;column-gap:40px}
.chapter-content{font-family:var(--font-reading);font-size:18px;line-height:1.8;color:var(--text)}
.chapter-content p{margin-bottom:1em}
.chapter-content h1,.chapter-content h2,.chapter-content h3{font-family:var(--font-ui);margin:1.5em 0 .5em;color:var(--text)}
.chapter-content img{max-width:100%;height:auto;border-radius:var(--radius)}
.chapter-content a{color:var(--accent);text-decoration:underline}

/* Bottom bar */
.bottom-bar{display:flex;align-items:center;gap:12px;padding:10px 20px;background:var(--surface);border-top:1px solid var(--border)}
.nav-btn{padding:8px 16px;font-family:var(--font-ui);font-size:.82rem;font-weight:600;background:none;border:1px solid var(--border);border-radius:var(--radius);color:var(--text2);cursor:pointer;transition:var(--tr)}
.nav-btn:hover{border-color:var(--accent);color:var(--accent)}
.progress-info{flex:1;display:flex;align-items:center;gap:10px}
.progress-bar-container{flex:1;height:4px;background:var(--bg2);border-radius:2px;overflow:hidden}
.progress-bar{height:100%;background:var(--accent);border-radius:2px;transition:width .3s;width:0%}
.progress-text{font-size:.78rem;color:var(--text3);min-width:36px;text-align:right}

/* Settings */
.settings-panel{position:fixed;top:50px;right:20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;width:280px;z-index:25;box-shadow:0 8px 30px rgba(0,0,0,.15)}
.settings-panel h3{font-size:.95rem;font-weight:700;margin-bottom:16px}
.setting-group{margin-bottom:14px}
.setting-group label{display:block;font-size:.78rem;font-weight:600;color:var(--text2);margin-bottom:6px}
.theme-buttons{display:flex;gap:8px}
.theme-btn{width:40px;height:40px;border-radius:var(--radius);border:2px solid var(--border);background:var(--surface);cursor:pointer;font-size:1.1rem;transition:var(--tr)}
.theme-btn:hover{border-color:var(--accent)}
.slider{-webkit-appearance:none;appearance:none;width:100%;height:4px;background:var(--bg2);border-radius:2px;outline:none}
.slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer}
.select{padding:8px 12px;font-family:var(--font-ui);font-size:.85rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);outline:none;width:100%}

/* Sidebar overlay */
.sidebar-overlay{position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:15;display:none}
.sidebar-overlay.visible{display:block}

/* Toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);padding:10px 20px;background:var(--surface);border:1px solid var(--accent);border-radius:var(--radius);color:var(--text);font-size:.85rem;font-weight:500;z-index:100;opacity:0;transition:all .3s ease;pointer-events:none}
.toast.visible{opacity:1;transform:translateX(-50%) translateY(0)}

@media(max-width:640px){
  .content-area{padding:24px 16px 48px}
  .content-area.two-col{column-count:1}
  .sidebar{width:260px}
  .settings-panel{right:10px;left:10px;width:auto}
}
::selection{background:var(--accent);color:var(--bg)}
