*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #F4EDE6;--surface: #DED5CC;--surface2: #cfc5bb;--deep: #8A0515;--text: #2a0005;--muted: #8a6a60;--border: rgba(89, 0, 10, .12);--serif: "Playfair Display", Georgia, serif;--sans: "Inter", system-ui, sans-serif}body{background:var(--bg);color:var(--text);font-family:var(--sans);min-height:100vh;line-height:1.5;-webkit-font-smoothing:antialiased}.app-root{min-height:100vh}.header{padding:20px 40px;background:var(--deep);display:flex;align-items:center;justify-content:space-between;gap:10px}.page{max-width:880px;margin:0 auto;padding:44px 24px 80px}.header-left,.header-right{display:flex;align-items:center;gap:10px}.header-btn{padding:7px 14px;border-radius:8px;font-size:13px;font-family:var(--sans);font-weight:600;cursor:pointer;border:1px solid rgba(244,237,230,.35);background:transparent;color:var(--bg);transition:background .15s}.header-btn:hover{background:#f4ede61f}.header-btn--muted{border-color:transparent;opacity:.7}.header-btn--muted:hover{background:#f4ede61f;border-color:transparent;opacity:1}.header-user{font-size:13px;font-weight:500;color:#f4ede6b3;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-icon{width:32px;height:32px;border-radius:8px;background:#f4ede626;display:flex;align-items:center;justify-content:center;flex-shrink:0}.header-icon svg{width:16px;height:16px;stroke:var(--bg);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}.header-title{font-family:var(--serif);font-size:22px;font-weight:800;color:var(--bg);letter-spacing:-.3px}.titles-found{font-size:13px;color:var(--muted);margin-bottom:32px;padding:12px 16px;background:var(--surface);border-radius:10px;border:1px solid var(--border);display:flex;align-items:center;gap:8px}.titles-found strong{color:var(--deep);font-weight:700}.titles-dot{width:7px;height:7px;border-radius:50%;background:var(--deep);flex-shrink:0}.state-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;gap:20px}.state-icon-wrap{width:72px;height:72px;border-radius:20px;background:var(--surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center}.state-icon-wrap svg{width:32px;height:32px;stroke:var(--deep);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.state-screen h2{font-family:var(--serif);font-size:26px;font-weight:800;color:var(--text);line-height:1.25}.state-screen p{font-size:14px;color:var(--muted);max-width:380px;line-height:1.7}.quiz-wrapper{max-width:580px}.quiz-progress{display:flex;gap:6px;margin-bottom:36px}.quiz-progress-dot{height:3px;flex:1;border-radius:2px;background:var(--border);transition:background .3s}.quiz-progress-dot.active{background:var(--deep)}.quiz-progress-dot.done{background:var(--surface2)}.quiz-step{animation:fadeSlide .2s ease}@keyframes fadeSlide{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.quiz-question{font-family:var(--serif);font-size:24px;font-weight:800;color:var(--text);margin-bottom:6px;line-height:1.2}.quiz-hint{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:22px}.quiz-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:28px}.quiz-chip{padding:8px 14px;border-radius:9px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text);transition:background .15s,color .15s,border-color .15s;-webkit-user-select:none;user-select:none}.quiz-chip:hover{border-color:#59000a4d;background:var(--surface2)}.quiz-chip.selected{background:var(--deep);color:var(--bg);border-color:var(--deep);font-weight:600}.quiz-options{display:flex;flex-direction:column;gap:8px;margin-bottom:28px}.quiz-option{display:flex;align-items:center;gap:12px;padding:13px 16px;background:var(--surface);border:1.5px solid var(--border);border-radius:10px;cursor:pointer;transition:border-color .15s,background .15s;-webkit-user-select:none;user-select:none;font-size:14px;font-weight:500;color:var(--text);text-align:left}.quiz-option:hover{border-color:#59000a4d;background:var(--surface2)}.quiz-option.selected{border-color:var(--deep);background:#59000a12}.quiz-option input{accent-color:var(--deep);width:16px;height:16px;flex-shrink:0;cursor:pointer}.quiz-genre-group{margin-bottom:20px}.quiz-genre-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:10px}.quiz-next-btn{display:block;width:100%;padding:14px;background:var(--deep);color:var(--bg);border:none;border-radius:10px;font-size:14px;font-family:var(--sans);font-weight:700;cursor:pointer;transition:opacity .15s;letter-spacing:.01em}.quiz-next-btn:hover:not(:disabled){opacity:.88}.quiz-next-btn:disabled{opacity:.3;cursor:not-allowed}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:20px;text-align:center}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--deep);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen p{font-size:14px;color:var(--muted)}.loading-msg{animation:fadeSlide .4s ease}.results-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:32px;flex-wrap:wrap;gap:12px}.results-header h2{font-family:var(--serif);font-size:38px;font-weight:900;color:var(--text);line-height:1.1;margin-bottom:4px}.results-header-sub{font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}.results-count-badge{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--deep);border:none;border-radius:10px;flex-shrink:0}.results-count-dot{width:8px;height:8px;border-radius:50%;background:var(--bg);opacity:.7}.results-count-text{font-size:13px;font-weight:600;color:var(--bg)}.results-grid{display:flex;flex-direction:column;gap:12px}.top-pick-wrap{border:1px solid rgba(138,5,21,.18);border-radius:16px;overflow:hidden;margin-bottom:4px}.top-pick-banner{background:var(--deep);color:var(--bg);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:8px 20px;opacity:.9}.top-pick-body{background:var(--surface);padding:4px}.divider-row{display:flex;align-items:center;gap:14px;margin:16px 0}.divider-line{flex:1;height:1px;background:var(--border)}.divider-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--deep);white-space:nowrap;padding:4px 12px;border-radius:20px;background:#8a051514;border:1px solid rgba(138,5,21,.15)}.book-cover{flex-shrink:0;border-radius:8px;overflow:hidden;background:var(--surface2);display:flex;align-items:center;justify-content:center}.book-cover-initial{font-family:var(--serif);font-size:22px;font-weight:800;color:var(--deep);opacity:.4}.book-cover--loading{background:linear-gradient(90deg,var(--surface) 25%,var(--surface2) 50%,var(--surface) 75%);background-size:200% 100%;animation:shimmer 1.2s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.book-card{display:flex;gap:16px;padding:16px;border-radius:14px;border:1px solid var(--border);background:transparent;transition:background .2s,border-color .2s;cursor:default}.book-card:hover{background:var(--surface);border-color:#59000a2e}.book-card.featured{background:transparent;border:none}.book-card.featured:hover{background:transparent}.book-card-body{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:space-between;padding:2px 0}.book-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:8px}.book-card-main{display:flex;align-items:flex-start;gap:12px;margin-bottom:4px}.book-card-actions{display:flex;flex-direction:column;gap:5px;flex-shrink:0}.book-action-btn{border-radius:6px;font-size:10px;font-weight:600;font-family:var(--sans);padding:4px 10px;cursor:pointer;transition:opacity .15s;text-align:center;display:block;text-decoration:none}.book-action-btn:hover{opacity:.8}.book-action-btn--primary{background:var(--deep);color:var(--bg);border:none;width:100%}.book-action-btn--outline{background:transparent;color:var(--deep);border:1px solid rgba(138,5,21,.3);width:100%}.book-title{font-family:var(--serif);font-size:15px;font-weight:700;color:var(--text);line-height:1.3}.book-title.featured{font-size:17px}.book-author{font-size:12px;color:var(--muted);margin-top:2px}.match-badge{flex-shrink:0;display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;background:#59000a17}.match-star{width:10px;height:10px;fill:var(--deep);flex-shrink:0}.match-pct{font-size:11px;font-weight:700;color:var(--deep)}.book-why{font-size:12px;color:var(--muted);line-height:1.6;margin-top:8px;margin-bottom:10px}.book-genre-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px}.book-genre-tag{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;background:#8a051514;color:var(--deep);border:1px solid rgba(138,5,21,.15)}.error-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:14px;text-align:center}.error-screen h2{font-family:var(--serif);font-size:22px;font-weight:800;color:var(--text)}.error-screen p{font-size:14px;color:var(--muted);max-width:420px;line-height:1.6}.retry-btn{margin-top:8px;padding:11px 26px;background:var(--deep);color:var(--bg);border:none;border-radius:9px;font-size:14px;font-family:var(--sans);font-weight:600;cursor:pointer;transition:opacity .15s}.retry-btn:hover{opacity:.85}.save-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:28px;flex-wrap:wrap}.save-banner--saved{background:#59000a0f;border-color:#59000a33}.save-banner--saved span{font-size:13px;font-weight:600;color:var(--deep)}.save-banner-text{font-size:13px;color:var(--text);font-weight:500}.save-banner-error{font-size:12px;color:#c0392b}.save-btn{padding:8px 18px;border-radius:8px;font-size:13px;font-family:var(--sans);font-weight:700;cursor:pointer;border:none;background:var(--deep);color:var(--bg);transition:opacity .15s;white-space:nowrap;flex-shrink:0}.save-btn:hover:not(:disabled){opacity:.88}.save-btn:disabled{opacity:.4;cursor:not-allowed}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2a000573;display:flex;align-items:center;justify-content:center;z-index:100;padding:24px;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg);border:1px solid var(--border);border-radius:18px;padding:36px 32px 32px;width:100%;max-width:400px;position:relative;animation:slideUp .18s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.modal-close{position:absolute;top:16px;right:18px;background:none;border:none;font-size:22px;line-height:1;cursor:pointer;color:var(--muted);padding:2px 6px;border-radius:6px;transition:color .15s,background .15s}.modal-close:hover{color:var(--text);background:var(--surface)}.modal-title{font-family:var(--serif);font-size:22px;font-weight:800;color:var(--text);margin-bottom:24px;line-height:1.2}.modal-success p{font-size:14px;color:var(--muted);line-height:1.6}.modal-success strong{color:var(--text)}.auth-google-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:11px 16px;border-radius:10px;font-size:14px;font-family:var(--sans);font-weight:600;cursor:pointer;border:1.5px solid var(--border);background:var(--surface);color:var(--text);transition:background .15s,border-color .15s}.auth-google-btn:hover{background:var(--surface2);border-color:#59000a40}.auth-divider{display:flex;align-items:center;gap:12px;margin:18px 0}.auth-divider-line{flex:1;height:1px;background:var(--border)}.auth-divider-text{font-size:12px;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.modal-tabs{display:flex;gap:4px;margin-bottom:18px;background:var(--surface);border-radius:9px;padding:3px}.modal-tab-btn{flex:1;padding:8px;border-radius:7px;font-size:13px;font-family:var(--sans);font-weight:600;cursor:pointer;border:none;background:transparent;color:var(--muted);transition:background .15s,color .15s}.modal-tab-btn.active{background:var(--bg);color:var(--text);box-shadow:0 1px 3px #59000a1a}.auth-form{display:flex;flex-direction:column;gap:10px}.auth-input{width:100%;padding:11px 14px;border-radius:9px;border:1.5px solid var(--border);background:var(--surface);font-size:14px;font-family:var(--sans);color:var(--text);outline:none;transition:border-color .15s}.auth-input::placeholder{color:var(--muted)}.auth-input:focus{border-color:#59000a66;background:var(--bg)}.auth-error{font-size:12px;color:#c0392b;line-height:1.4}.saved-history-nav{display:flex;align-items:center;gap:20px;margin-bottom:36px}.saved-history-title{font-family:var(--serif);font-size:28px;font-weight:900;color:var(--text);line-height:1.1}.back-btn{padding:8px 14px;border-radius:8px;font-size:13px;font-family:var(--sans);font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text);transition:background .15s;flex-shrink:0}.back-btn:hover{background:var(--surface2)}.saved-list{margin-bottom:12px}.saved-list-meta-row{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.saved-list-date{font-size:13px;font-weight:700;color:var(--text)}.saved-list-pills{display:flex;gap:6px}.saved-list-pill{padding:3px 10px;border-radius:20px;font-size:11px;font-weight:500;background:var(--surface);color:var(--muted);border:1px solid var(--border)}.saved-list-divider{height:1px;background:var(--border);margin:36px 0}
