:root{--paper: #FFFEF9;--ink: #2C1810;--ink-light: #6B5D54;--border: #D4C5B9;--hover: #F5F0EA}*{margin:0;padding:0;box-sizing:border-box}html{overflow-x:hidden;width:100%}body{font-family:Lora,serif;background:var(--paper);color:var(--ink);line-height:1.6;min-height:100vh;overflow-x:hidden;width:100%}h1,h2,h3,h4,h5,h6{font-family:"Source Serif 4",serif;font-weight:600;line-height:1.2}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}a{color:var(--ink);text-decoration:underline;cursor:pointer}a:hover{color:var(--ink-light)}#loadingScreen{display:flex;align-items:center;justify-content:center;min-height:100vh;font-family:"Source Serif 4",serif}.error-message{background:#fef2f2;color:#dc2626;padding:1rem;border:1px solid #fca5a5;border-radius:3px;margin-bottom:1rem;font-size:.9rem}.text-center{text-align:center}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}button,a,.btn,[onclick]{touch-action:manipulation}button,.btn{-webkit-user-select:none;user-select:none}.welcome-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;text-align:center;padding:2rem}.welcome-screen h2{margin-bottom:1rem}.welcome-screen p{color:var(--ink-light);margin-bottom:2rem;max-width:400px;margin-left:auto;margin-right:auto}.loading{display:flex;align-items:center;justify-content:center;min-height:100vh}#app{min-height:100vh;display:flex;flex-direction:column}.header,#header{background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;flex-shrink:0}.header-content{max-width:1400px;margin:0 auto;padding:1.5rem 2rem;display:flex;justify-content:space-between;align-items:center}.logo{font-family:"Source Serif 4",serif;font-size:1.5rem;font-weight:600;cursor:pointer}.logo span{font-weight:400}#headerTitle{font-family:"Source Serif 4",serif;font-size:1.5rem;margin:0;cursor:pointer}#headerActions,.user-controls{display:flex;gap:1rem;align-items:center}.container{max-width:1400px;margin:0 auto;padding:2rem;overflow-x:hidden;width:100%}.books-list{display:flex;flex-direction:column;gap:1.5rem}.header-avatar,.profile-avatar-small{width:40px;height:40px;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-family:"Source Serif 4",serif;font-weight:600;font-size:1rem;cursor:pointer;position:relative;transition:transform .2s;overflow:hidden}.header-avatar:hover,.profile-avatar-small:hover{transform:scale(1.05)}.header-avatar img,.profile-avatar-small img{width:100%;height:100%;border-radius:50%;object-fit:cover}.user-dropdown-menu{position:absolute;top:calc(100% + .5rem);right:0;background:#fff;border:1px solid var(--border);box-shadow:0 4px 12px #0000001a;min-width:200px;z-index:1000}.user-dropdown-header{padding:1rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.75rem}.user-dropdown-name{font-family:"Source Serif 4",serif;font-weight:600;font-size:.95rem}.user-dropdown-item{display:block;width:100%;padding:.75rem 1rem;cursor:pointer;transition:background .2s;font-family:"Source Serif 4",serif;background:none;border:none;text-align:left;font-size:.95rem;color:var(--ink)}.user-dropdown-item:hover{background:var(--hover)}.user-dropdown-divider{height:1px;background:var(--border);margin:.25rem 0}.back-btn{margin-bottom:2rem}@media (max-width: 768px){.container,.header-content{padding:1rem}.logo,#headerTitle{font-size:1.2rem}.header,#header{position:sticky;top:0;left:0;right:0;-webkit-backface-visibility:hidden;backface-visibility:hidden}}.btn{font-family:"Source Serif 4",serif;padding:.75rem 1.5rem;border:1px solid var(--ink);background:#fff;color:var(--ink);cursor:pointer;transition:all .2s;font-size:1rem;border-radius:0}.btn:hover,.btn-primary{background:var(--ink);color:#fff}.btn-primary:hover{background:var(--ink-light);border-color:var(--ink-light)}.modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;z-index:1000;align-items:center;justify-content:center;will-change:opacity}.modal.active{display:flex}.modal-content{will-change:transform}.modal-content{background:var(--paper);padding:3rem 2rem 2rem;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;border:1px solid var(--ink);position:relative}.modal-close{position:absolute;top:.5rem;right:.5rem;background:var(--paper);border:2px solid var(--ink);font-size:2rem;line-height:1;font-weight:400;cursor:pointer;color:var(--ink);width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s;z-index:100;box-shadow:0 2px 8px #0000001a}.modal-close:hover{background:var(--ink);color:#fff;border-color:var(--ink)}.modal-content h3{margin-bottom:1rem;font-size:1.3rem;font-weight:600}.modal-buttons{display:flex;gap:1rem;margin-top:1.5rem;justify-content:flex-end}.form-group{display:flex;flex-direction:column;margin-bottom:1rem}label{font-family:"Source Serif 4",serif;font-size:.9rem;margin-bottom:.5rem;color:var(--ink-light)}input[type=text],input[type=email],input[type=password],input[type=number],input[type=url],textarea,select{font-family:Lora,serif;padding:.75rem;border:1px solid var(--border);background:#fff;font-size:1rem;transition:border-color .2s}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--ink)}textarea{resize:vertical;min-height:100px}.profile-avatar-large{width:120px;height:120px;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-family:"Source Serif 4",serif;font-weight:600;font-size:3rem;margin:0 auto;position:relative;overflow:hidden}.profile-avatar-large img{width:100%;height:100%;object-fit:cover}.auth-toggle{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border);font-family:"Source Serif 4",serif;font-size:.9rem}.auth-toggle a{color:var(--ink);text-decoration:underline;cursor:pointer}.auth-toggle a:hover{color:var(--ink-light)}@media (max-width: 768px){.modal-content{padding:2.5rem 1.5rem 1.5rem;width:95%}.modal-buttons{flex-direction:column}.btn{width:100%;min-height:44px;display:inline-flex;align-items:center;justify-content:center}}.book-card{background:#fff;border:1px solid var(--border);padding:2rem;cursor:pointer;transition:background .2s;display:grid;grid-template-columns:180px 1fr;gap:2rem}.book-card:hover{background:var(--hover)}.book-cover{width:180px;height:260px;background:var(--hover);display:flex;align-items:center;justify-content:center;font-size:4rem;overflow:hidden;flex-shrink:0}.book-cover img{width:100%;height:100%;object-fit:cover}.book-info h3{margin-bottom:.5rem}.book-meta{color:var(--ink-light);margin-bottom:1rem;font-size:.95rem}.book-description{color:var(--ink-light);margin-top:.5rem;line-height:1.6}.book-header{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--border)}.page-navigation{background:#fff;border:1px solid var(--border);padding:1.5rem;margin-bottom:2rem}.page-nav-header{font-family:"Source Serif 4",serif;font-weight:600;margin-bottom:1rem;font-size:1.1rem}.page-controls{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.slider-container{flex:1;min-width:300px;position:relative}.page-slider{width:100%;height:24px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;cursor:pointer;position:relative;z-index:2;margin:0;padding:0;touch-action:pan-x}.page-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:3px;height:24px;border-radius:1px;background:var(--ink);cursor:pointer;border:none;box-shadow:0 1px 3px #0000004d}.page-slider::-moz-range-thumb{width:3px;height:24px;border-radius:1px;background:var(--ink);cursor:pointer;border:none;box-shadow:0 1px 3px #0000004d}@media (max-width: 768px){.page-slider{height:44px}.page-slider::-webkit-slider-thumb{width:16px;height:32px;border-radius:4px}.page-slider::-moz-range-thumb{width:16px;height:32px;border-radius:4px}}.page-slider::-webkit-slider-runnable-track{height:8px;background:transparent}.page-slider::-moz-range-track{height:8px;background:transparent}.slider-track{display:flex;height:8px;margin-top:-16px;border-radius:0;overflow:hidden;position:relative;z-index:1;pointer-events:none}.slider-track-segment{height:100%;pointer-events:none}.page-input-group{display:flex;gap:.5rem;align-items:center}.page-input-group input{width:80px}.current-page-display{font-family:"Source Serif 4",serif;font-weight:600;font-size:1.1rem}.current-chapter-label{color:var(--ink-light);font-size:.9rem;margin-top:.25rem}.page-status-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-top:1rem}.page-status-info{flex:1;min-width:0}.btn-mark-read{flex-shrink:0;white-space:nowrap}.page-markers{position:relative;height:16px;margin-top:.5rem;pointer-events:none}.page-marker{position:absolute;width:2px;height:16px;bottom:0;transform:translate(-50%);cursor:pointer;pointer-events:auto}.page-marker.marker-comment{background:var(--ink-light)}.page-marker.marker-note{background:#f59e0b}.page-marker.marker-question{background:#3b82f6}.reading-progress-section{background:#fff;border:1px solid var(--border);padding:1.5rem;margin-bottom:2rem}.reading-progress-header{display:flex;justify-content:space-between;align-items:center}.reading-progress-title{font-family:"Source Serif 4",serif;font-weight:600;font-size:1.1rem}.chapter-selector{background:#fff;border:1px solid var(--border);padding:1.5rem;margin-bottom:2rem}.chapter-selector-header{font-family:"Source Serif 4",serif;font-weight:600;margin-bottom:1rem;font-size:1.1rem}.chapter-buttons{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.chapter-btn{padding:1rem;border:1px solid var(--border);background:#fff;font-family:Lora,serif;font-size:1rem;cursor:pointer;transition:all .2s;text-align:left;display:flex;flex-direction:column;gap:.25rem}.chapter-btn:hover{background:var(--hover)}.chapter-btn.active{border-color:var(--ink);border-width:2px}.chapter-btn-title{font-weight:600}.chapter-btn-pages{font-family:"Source Serif 4",serif;font-size:.85rem;color:var(--ink-light)}.chapter-view{background:#fff;border:1px solid var(--border);padding:2rem}.chapter-title{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:1px solid var(--border);margin-bottom:2rem;font-family:"Source Serif 4",serif;font-size:1.3rem;font-weight:600}.chapter-title .page-range{font-size:.9rem;font-weight:400;color:var(--ink-light)}.timeline-entry{margin-bottom:1.5rem}.timeline-date{font-family:"Source Serif 4",serif;font-weight:600;margin-bottom:.75rem}.timeline-activity{padding:.5rem 0 .5rem 1.75rem;font-size:.9rem;color:var(--ink);position:relative;border-left:2px solid var(--border);margin-left:.6rem;list-style:none}.timeline-activity:before{display:none}.timeline-activity::marker{display:none}.timeline-activity:last-child{border-left-color:transparent}.timeline-activity-icon{position:absolute;left:-.85rem;top:.4rem;background:#fff;padding:0 .1rem}.timeline-activity-link{cursor:pointer;transition:color .2s}.timeline-activity-link:hover{color:var(--ink);text-decoration:underline}.timeline-activity-text{color:var(--ink-light);font-style:italic;display:block;margin-top:.25rem;padding-left:0}.book-detail-header{display:grid;grid-template-columns:220px 1fr;gap:2rem;margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--border)}.book-detail-cover{width:220px;height:320px;background:var(--hover);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.book-detail-cover img{width:100%;height:100%;object-fit:cover}.book-detail-emoji{font-size:4rem}.book-detail-info{min-width:0;overflow:hidden}.book-detail-info h2{margin-bottom:.5rem}.book-detail-title-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.5rem;flex-wrap:wrap}.book-detail-title{font-size:2rem;margin:0;font-weight:600;word-wrap:break-word;overflow-wrap:break-word}.btn-export{flex-shrink:0}.book-detail-description{line-height:1.8;margin-bottom:1rem;color:var(--ink-light)}.book-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:1rem;margin-top:1.5rem}.book-stat-label{font-size:.85rem;color:var(--ink-light);margin-bottom:.25rem}.book-stat-value{font-size:1.1rem;font-weight:600;display:flex;align-items:center}.book-stat-placeholder{color:var(--ink-light)}.book-detail-actions{display:flex;gap:1rem;margin-top:1.5rem;flex-wrap:wrap}@media (max-width: 768px){.book-card{grid-template-columns:1fr;gap:1rem}.book-cover{width:100%;height:300px}.book-header{grid-template-columns:1fr}.slider-container{min-width:100%}.page-controls{flex-direction:column;align-items:stretch}.page-input-group{justify-content:center}.book-detail-header{grid-template-columns:1fr;gap:1.5rem;text-align:center}.book-detail-cover{width:180px;height:260px;margin:0 auto}.book-detail-title-row{flex-direction:column;align-items:center;gap:.75rem}.book-detail-title{font-size:1.5rem;text-align:center}.book-detail-description{text-align:left}.book-stats-grid{grid-template-columns:repeat(3,1fr);gap:.75rem;text-align:center}.book-stat-value{justify-content:center}.chapter-title{flex-direction:column;text-align:center;gap:.5rem}.chapter-view,.page-navigation,.chapter-selector,.reading-progress-section{padding:1rem}.page-status-row{flex-direction:column;align-items:stretch;gap:.75rem}.page-status-info{text-align:center}.btn-mark-read{width:100%}}.chapter-btn,.filter-btn{min-height:44px}.page-input-group .btn{min-height:44px;min-width:44px}} @media (max-width: 480px){.book-detail-cover{width:140px;height:200px}.book-detail-title{font-size:1.3rem}.book-stats-grid{grid-template-columns:repeat(2,1fr)}.chapter-buttons{grid-template-columns:1fr}.slider-container{min-width:unset;width:100%}}.comment-form{background:var(--hover);border:1px solid var(--border);padding:1.5rem;margin-top:2rem}.comment-form textarea{width:100%;min-height:100px;margin-bottom:1rem}.comment-category-selector{display:flex;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.category-option{display:flex;align-items:center;gap:.5rem}.category-option input[type=radio]{cursor:pointer}.category-option label{cursor:pointer;font-family:"Source Serif 4",serif;font-size:.9rem;margin-bottom:0;color:var(--ink)}.comment-type-selector{display:flex;gap:.5rem;margin-bottom:1rem}.comment-type-btn{font-family:"Source Serif 4",serif;padding:.5rem 1rem;border:1px solid var(--border);background:#fff;cursor:pointer;transition:all .2s;font-size:.9rem}.comment-type-btn.active{background:var(--ink);color:#fff;border-color:var(--ink)}.comment-type-btn:not(.active):hover{background:var(--hover)}.comments-section{margin-top:2rem}.comments-section h3{margin-bottom:1rem;font-size:1.2rem}.comment{background:#fff;border:1px solid var(--border);padding:1.5rem;margin-bottom:1rem;position:relative}.comment-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;font-size:.9rem;color:var(--ink-light)}.comment-text{line-height:1.6;white-space:pre-wrap}.comment-type-badge{display:inline-block;padding:.2rem .5rem;border-radius:3px;font-size:.75rem;font-family:"Source Serif 4",serif;font-weight:600;margin-right:.5rem}.badge-comment{background:#f3f4f6;color:#374151}.badge-note{background:#fef3c7;color:#92400e}.badge-question{background:#dbeafe;color:#1e40af}.comment-badge{display:inline-block;padding:.25rem .5rem;border-radius:3px;font-size:.75rem;font-family:"Source Serif 4",serif;font-weight:600;margin-left:.5rem}.comment-badge.note{background:#fef3c7;color:#92400e}.comment-badge.question{background:#dbeafe;color:#1e40af}.comment-badge.general{background:#f3f4f6;color:#374151}.comment-avatar{width:40px;height:40px;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-family:"Source Serif 4",serif;font-weight:600;flex-shrink:0}.comment-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.comment-meta{flex:1}.comment-author{font-family:"Source Serif 4",serif;font-weight:600;margin-bottom:.25rem}.comment-info{font-size:.85rem;color:var(--ink-light)}.comment-actions{margin-top:1rem;display:flex;gap:.5rem}.comment-actions button{font-family:"Source Serif 4",serif;padding:.5rem 1rem;border:1px solid var(--border);background:#fff;cursor:pointer;font-size:.85rem;transition:all .2s}.comment-actions button:hover{background:var(--hover)}.comment-actions .delete-btn{border-color:#dc2626;color:#dc2626}.comment-actions .delete-btn:hover{background:#dc2626;color:#fff}.mention{color:#2563eb;background:#eff6ff;padding:.1rem .3rem;border-radius:3px;font-weight:600}.spoiler{position:relative;cursor:pointer}.spoiler>*:not(.spoiler-badge){filter:blur(8px);-webkit-user-select:none;user-select:none;pointer-events:none}.spoiler:before{content:"Spoiler - Click to reveal";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000e6;color:#fff;padding:.5rem 1rem;border-radius:3px;font-family:"Source Serif 4",serif;font-size:.9rem;font-weight:600;white-space:nowrap;z-index:10;pointer-events:none}.spoiler-revealed>*{filter:none!important;-webkit-user-select:auto!important;user-select:auto!important;pointer-events:auto!important}.spoiler-revealed:before{display:none}.timeline-section{margin-bottom:2rem}.timeline-section h3{margin-bottom:1rem;font-size:1.2rem}.timeline{border-left:2px solid var(--border);padding-left:1.5rem}.timeline-activity{position:relative;padding-bottom:1rem;font-size:.9rem;color:var(--ink-light)}.timeline-activity:before{content:"";position:absolute;left:-1.65rem;top:.4rem;width:.5rem;height:.5rem;background:var(--ink);border-radius:50%}.timeline-preview{display:inline;font-style:italic}.filter-buttons{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.filter-btn{font-family:"Source Serif 4",serif;padding:.5rem 1rem;border:1px solid var(--border);background:#fff;cursor:pointer;transition:all .2s;font-size:.9rem}.filter-btn.active{background:var(--ink);color:#fff;border-color:var(--ink)}.filter-btn:not(.active):hover{background:var(--hover)}@media (max-width: 768px){.comment-form,.comment{padding:1rem}.comment-category-selector,.comment-header{flex-direction:column;gap:.5rem}.filter-buttons{width:100%}.filter-btn{flex:1;text-align:center}}
