:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;overflow-x:hidden}#root{min-height:100vh}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-header{background-color:#2c3e50;color:#fff;padding:1rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a;flex-wrap:wrap;gap:1rem}.header-left{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.app-title{margin:0;font-size:1.25rem;font-weight:600}.status-indicator{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.status-dot.online{background-color:#2ecc71}.status-dot.offline{background-color:#e74c3c}.status-text{font-weight:500}.sync-controls{display:flex;gap:.5rem;align-items:center}.sync-button{padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:all .2s;white-space:nowrap}.push-button{background-color:#3498db}.push-button:hover:not(:disabled){background-color:#2980b9}.pull-button{background-color:#27ae60}.pull-button:hover:not(:disabled){background-color:#229954}.sync-button:disabled{background-color:#95a5a6;cursor:not-allowed;opacity:.6}.sync-status{padding:.75rem 1rem;font-size:.875rem;text-align:center;display:flex;justify-content:center;align-items:center;gap:.5rem}.sync-status-syncing{background-color:#3498db;color:#fff}.sync-status-success{background-color:#27ae60;color:#fff}.sync-status-error{background-color:#e74c3c;color:#fff}.sync-time{font-size:.75rem;opacity:.9}.sync-info-panel{background-color:#ecf0f1;border-bottom:1px solid #bdc3c7;padding:.75rem 1rem;font-size:.8125rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.5rem}.sync-info-row{display:flex;gap:.5rem;align-items:center}.sync-info-label{font-weight:600;color:#7f8c8d;min-width:70px}.sync-info-value{color:#2c3e50;font-family:Courier New,monospace;font-size:.75rem}.sync-message-syncing{color:#3498db;font-weight:500}.sync-message-success{color:#27ae60;font-weight:500}.sync-message-error{color:#e74c3c;font-weight:500}.sync-conflict-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center}.conflict-overlay{position:absolute;inset:0;background-color:#00000080}.conflict-dialog{position:relative;background:#fff;border-radius:8px;padding:2rem;max-width:500px;width:90%;box-shadow:0 4px 12px #0000004d;z-index:1001}.conflict-dialog h3{margin-top:0;color:#e67e22;font-size:1.25rem}.conflict-details{background-color:#f8f9fa;padding:1rem;border-radius:4px;margin:1rem 0;font-size:.875rem}.conflict-details div{margin:.5rem 0}.conflict-warning{color:#c0392b;font-weight:500;padding:1rem;background-color:#fef5e7;border-left:4px solid #e67e22;border-radius:4px}.conflict-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.conflict-cancel,.conflict-confirm{padding:.75rem 1.5rem;font-size:1rem;font-weight:500;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.conflict-cancel{background-color:#ecf0f1;color:#2c3e50}.conflict-cancel:hover{background-color:#d5dbdb}.conflict-confirm{background-color:#e74c3c;color:#fff}.conflict-confirm:hover{background-color:#c0392b}.app-main{flex:1;padding:1rem;max-width:1200px;width:100%;margin:0 auto;box-sizing:border-box}*{box-sizing:border-box}body{margin:0;overflow-x:hidden}@media(max-width:640px){.app-header{flex-direction:column;gap:.5rem;align-items:flex-start}.header-left{width:100%}.sync-controls{width:100%;flex-direction:column}.sync-button{width:100%}.app-title{font-size:1.125rem}.app-main{padding:.75rem}.conflict-dialog{padding:1.5rem}.conflict-actions{flex-direction:column}.conflict-cancel,.conflict-confirm{width:100%}}.book-list-page{max-width:100%}.book-list-page h2{margin-top:0;margin-bottom:1rem;font-size:1.75rem;color:#2c3e50}.book-list-page p{margin-bottom:1.5rem;line-height:1.6;color:#555}.add-book-button{padding:.75rem 1.5rem;font-size:1rem;font-weight:500;color:#fff;background-color:#3498db;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.add-book-button:hover:not(:disabled){background-color:#2980b9}.add-book-button:disabled{background-color:#95a5a6;cursor:not-allowed;opacity:.6}.add-book-form{background-color:#f8f9fa;padding:1.5rem;border-radius:8px;margin-bottom:2rem;border:1px solid #dee2e6}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#2c3e50}.form-group input{width:100%;padding:.75rem;font-size:1rem;border:1px solid #ced4da;border-radius:4px;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.form-actions{display:flex;gap:.5rem;margin-top:1.5rem}.submit-button,.cancel-button{padding:.75rem 1.5rem;font-size:1rem;font-weight:500;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.submit-button{color:#fff;background-color:#27ae60}.submit-button:hover:not(:disabled){background-color:#229954}.submit-button:disabled{background-color:#95a5a6;cursor:not-allowed;opacity:.6}.cancel-button{color:#2c3e50;background-color:#ecf0f1}.cancel-button:hover{background-color:#d5dbdb}.books-list{margin-top:2rem}.book-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;margin-bottom:.75rem;background-color:#fff;border:1px solid #dee2e6;border-radius:6px;transition:box-shadow .2s}.book-item:hover{box-shadow:0 2px 4px #0000001a}.book-info{flex:1;min-width:0}.book-title{margin:0 0 .25rem;font-size:1.125rem;font-weight:600;color:#2c3e50;word-wrap:break-word}.book-author{margin:0;font-size:.9rem;color:#7f8c8d}.delete-button{padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#fff;background-color:#e74c3c;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s;flex-shrink:0;margin-left:1rem}.delete-button:hover{background-color:#c0392b}.loading,.empty-state{padding:2rem;text-align:center;color:#7f8c8d;font-style:italic}@media(max-width:640px){.book-list-page h2{font-size:1.5rem}.add-book-button{width:100%;padding:.875rem}.add-book-form{padding:1rem}.form-actions{flex-direction:column}.submit-button,.cancel-button{width:100%}.book-item{flex-direction:column;align-items:stretch;gap:1rem}.delete-button{margin-left:0;width:100%}}
