*{box-sizing:border-box}body{color:#333;background:#fafafa;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;font-size:16px;line-height:1.5}#root{min-height:100vh}h1{margin:0 0 16px;font-size:24px}.search-page{max-width:800px;margin:0 auto;padding:0 20px 20px}.search-page .loading-indicator{text-align:center;color:#666;padding:40px}.app{max-width:800px;margin:0 auto}.app>.hidden{display:none}.app-header{background:#fff;border-bottom:1px solid #ddd;justify-content:space-between;align-items:center;max-width:800px;margin:0 auto;padding:12px 20px;display:flex}.menu-bar{background:#f5f5f5;border-bottom:1px solid #ddd;max-width:800px;margin:0 auto}.menu-items{gap:20px;padding:10px 20px;display:flex}.menu-item{color:#666;border-radius:6px;padding:8px 16px;font-size:16px;text-decoration:none;transition:background .2s}.menu-item:hover{background:#e8e8e8}.menu-item.active{color:#fff;background:#4a90d9}.user-email{color:#666;font-size:14px}.logout-button{cursor:pointer;background:#f5f5f5;border:1px solid #ddd;border-radius:6px;padding:8px 16px;font-size:14px}.logout-button:hover{background:#e8e8e8}.compact-toggle{color:#666;cursor:pointer;align-items:center;gap:6px;font-size:14px;display:flex}.login-page{background:#f5f5f5;justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{text-align:center;background:#fff;border-radius:12px;padding:40px;box-shadow:0 2px 10px #0000001a}.login-card h1{margin:0 0 12px;font-size:28px}.login-card p{color:#666;margin:0 0 24px}.login-button{color:#fff;cursor:pointer;background:#4a90d9;border:none;border-radius:8px;padding:12px 24px;font-size:16px}.login-button:hover{background:#357abd}.loading-page{justify-content:center;align-items:center;min-height:100vh;display:flex}.search-bar-with-filters{max-width:800px;margin-left:auto;margin-right:auto;padding:15px 20px}.search-main{gap:10px;margin-bottom:15px;display:flex}.search-input{border:1px solid #ddd;border-radius:8px;flex:1;padding:12px 16px;font-size:16px}.search-button{color:#fff;cursor:pointer;background:#4a90d9;border:none;border-radius:8px;padding:12px 24px;font-size:16px}.search-button:hover{background:#357abd}.toggle-filters-button{color:#333;cursor:pointer;background:#f5f5f5;border:1px solid #ddd;border-radius:8px;padding:12px 16px;font-size:14px}.toggle-filters-button:hover{background:#e8e8e8}.filters{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.filter-group{align-items:center;gap:8px;display:flex}.filter-group.compact-filter{align-items:center;display:flex}.filter-group.compact-filter label{color:#666;cursor:pointer;white-space:nowrap;align-items:center;gap:6px;font-size:14px;display:flex}.filter-group.compact-filter input{cursor:pointer}.compact-toggle-row{margin-top:10px;padding:8px 0}.compact-toggle-floating{z-index:100;background:#fff;border:1px solid #ddd;border-radius:6px;align-items:center;gap:12px;padding:8px 16px;display:flex;position:fixed;top:80px;right:20px;box-shadow:0 2px 8px #00000026}.compact-toggle-floating:hover{box-shadow:0 4px 12px #0003}.results-count-floating{color:#666;font-size:13px}.back-to-top-button{cursor:pointer;background:#f5f5f5;border:1px solid #ddd;border-radius:4px;padding:4px 10px;font-size:13px}.back-to-top-button:hover{background:#eee}.filter-select,.filter-date{border:1px solid #ddd;border-radius:6px;min-width:100px;padding:8px 12px;font-size:14px}.filter-date{min-width:130px}.date-separator{color:#666;white-space:nowrap}.filter-group label{color:#666;font-size:14px}.results-header{margin-bottom:15px}.results-count{color:#666;font-size:14px}.results-list{flex-direction:column;gap:10px;display:flex}.book-card{cursor:pointer;border:1px solid #ddd;border-radius:8px;padding:15px;transition:background .2s,box-shadow .2s}.book-card:hover{background:#f9f9f9;box-shadow:0 2px 8px #0000001a}.book-card.highlighted{background:#e8f0fe;border-color:#4a90d9}.book-card.compact{padding:8px 15px}.book-card.compact h3{margin:0;font-size:14px}.book-card h3{margin:0 0 8px;font-size:18px}.book-authors,.book-format,.book-created{color:#666;margin:4px 0;font-size:14px}.book-title{color:#333;margin:4px 0;font-size:14px;font-style:italic;text-decoration:none}.book-title:any-link,.book-title:link,.book-title:visited,.book-title:hover,.book-title:active{color:#333;text-decoration:none}.more-button{cursor:pointer;background:#f5f5f5;border:1px solid #ddd;border-radius:8px;width:100%;margin-top:20px;padding:12px;font-size:16px;display:block}.more-button:hover:not(:disabled){background:#e8e8e8}.more-button:disabled{opacity:.6;cursor:not-allowed}.book-details-page{max-width:800px;margin:0 auto;padding:20px}.back-button{cursor:pointer;background:#f5f5f5;border:1px solid #ddd;border-radius:6px;margin-bottom:20px;padding:10px 20px;font-size:14px;display:inline-block}.back-button:hover{background:#e8e8e8}.book-details h1{margin:0 0 20px;font-size:24px}.book-details.swiping{transition:transform .2s ease-out}.book-details.swipe-left{opacity:.7;transform:translate(-20px)}.book-details.swipe-right{opacity:.7;transform:translate(20px)}.detail-row{margin:12px 0;font-size:14px}.detail-row strong{color:#666;width:120px;display:inline-block}.comments-section{border:1px solid #ddd;border-radius:6px;margin-top:20px;padding:12px}.comments-header{justify-content:space-between;align-items:center;display:flex}.comments-header details summary{cursor:pointer;color:#333;font-weight:600;list-style:none}.comments-header details summary::marker{display:none}.comments-header details summary:before{content:"▶ "}.comments-header details:not([open])+.comments-content,.comments-header details:not([open])~.comments-rendered,.comments-header details:not([open])~.comments-raw{display:none}.comments-header details[open] summary:before{content:"▼ "}.comments-header details:not([open])+.comments-content{display:none}.raw-toggle{cursor:pointer;color:#fff;background:#999;border:none;border-radius:4px;align-items:center;padding:4px 8px;font-size:14px;font-weight:500;display:flex}.raw-toggle.active{background:#4a90d9}.raw-toggle:hover{opacity:.85}.comments-rendered{margin-top:12px;line-height:1.6}.comments-rendered p{margin:0 0 12px}.comments-rendered b,.comments-rendered strong{font-weight:600}.comments-rendered i,.comments-rendered em{font-style:italic}.comments-raw{white-space:pre-wrap;word-wrap:break-word;background:#f5f5f5;border-radius:4px;margin-top:12px;padding:12px;font-family:monospace;font-size:13px;overflow-x:auto}.navigation-buttons{border-top:1px solid #ddd;justify-content:space-between;align-items:center;gap:15px;margin-top:30px;padding-top:20px;display:flex}.nav-position{order:2}.nav-button.prev{order:1}.nav-button.next{order:3}.nav-button{cursor:pointer;color:#333;background:#f5f5f5;border:1px solid #ddd;border-radius:6px;padding:10px 20px;font-size:14px;text-decoration:none;display:inline-block}.nav-button:hover:not(:disabled){background:#e8e8e8}.nav-button.prev,.nav-button.next{color:#4a90d9;cursor:pointer;background:#f5f5f5;border:1px solid #ddd;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;padding:10px 14px;font-size:18px;line-height:1;text-decoration:none;display:flex}.nav-button.prev:hover,.nav-button.next:hover{color:#357abd;background:#e8e8e8}.nav-position{color:#666;font-size:14px}.admin-page{max-width:800px;margin:0 auto;padding:20px}.admin-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:15px;margin-bottom:30px;display:flex}.admin-header h1{margin:0}.admin-button{color:#fff;cursor:pointer;background:#f59e0b;border:none;border-radius:4px;padding:8px 16px;font-weight:700}.admin-section{background:#f9fafb;border-radius:8px;margin-bottom:40px;padding:20px}.admin-section h2{margin-top:0}.admin-form{flex-wrap:wrap;gap:10px;margin-bottom:20px;display:flex}.admin-form input,.admin-form select{border:1px solid #d1d5db;border-radius:4px;flex:1;min-width:150px;padding:8px 12px}.admin-form button{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:4px;padding:8px 16px}.admin-table{border-collapse:collapse;width:100%;display:block;overflow-x:auto}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid #e5e7eb;padding:12px}.admin-table th{background:#f3f4f6;font-weight:600}.api-key-id{font-family:monospace;font-size:12px}.admin-table button{cursor:pointer;border:none;border-radius:4px;margin-right:8px;padding:4px 8px;font-size:12px}.admin-table button:first-of-type{color:#fff;background:#f59e0b}.admin-table button:last-of-type{color:#fff;background:#ef4444}@media (width<=768px){.app-header{flex-wrap:wrap;gap:10px;padding:10px 12px}.user-email{order:-1;width:100%;font-size:12px}.compact-toggle{font-size:12px}.search-page{padding:12px}.search-main{flex-direction:column;gap:8px}.search-input{box-sizing:border-box;width:100%}.search-button{width:100%}.filters{flex-direction:column;align-items:stretch}.filter-group{width:100%}.filter-group:first-child{align-items:center;display:flex}.filter-select,.filter-date{box-sizing:border-box;width:100%}.date-separator{text-align:center;padding:4px 0}.filter-group:first-child .filter-select{width:100%}.results-list{gap:8px}.book-card{padding:12px}.book-card h3{font-size:16px}.book-authors,.book-format,.book-created{font-size:12px}.more-button{padding:10px;font-size:14px}.book-details-page{padding:12px}.detail-row{font-size:12px}.detail-row strong{width:80px}.navigation-buttons{flex-wrap:wrap;justify-content:center;gap:10px;padding-top:15px}.nav-button{flex:none}.admin-page{padding:12px}.admin-header{flex-direction:column;align-items:flex-start;gap:10px}.admin-form{flex-direction:column}.admin-form input,.admin-form select,.admin-form button{width:100%;min-width:unset}.admin-table{display:block;overflow-x:auto}.admin-table th,.admin-table td{padding:8px;font-size:12px}}@media (width<=480px){.app-header{flex-direction:column;align-items:stretch}.logout-button,.admin-button{width:100%;margin-top:8px}.login-card{margin:20px;padding:24px}.login-card h1{font-size:22px}.search-input{padding:10px 12px;font-size:14px}.search-button{padding:10px 16px;font-size:14px}.book-card.compact h3{font-size:13px}.book-details h1{font-size:18px}}.status-success{color:#10b981;font-weight:700}.status-error{color:#ef4444;font-weight:700}.status-in_progress{color:#f59e0b;font-weight:700}.status-pending{color:#6b7280}.load-more-button{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:4px;margin-bottom:16px;padding:8px 16px}.load-more-button:disabled{cursor:not-allowed;background:#9ca3af}
