@import "https://fonts.googleapis.com/css2?family=Lora:wght@500;600;700&family=Source+Sans+3:wght@400;500;600;700;800&family=IBM+Plex+Mono:wght@400;500;600&display=swap";:root{--bg:#faf8f5;--surface:#fff;--surface-alt:#f5f1eb;--border:#e6dfd5;--border-light:#efe9e0;--text:#3b2e1e;--text-mid:#6b5c4a;--text-dim:#9a8b78;--text-faint:#bfb3a3;--accent:#8b5e34;--accent-light:#f7f0e7;--accent-text:#6d4520;--accent-dark:#5c3d1e;--warm:#f5ede2;--font-display:"Lora", Georgia, serif;--font-body:"Source Sans 3", -apple-system, sans-serif;--font-mono:"IBM Plex Mono", monospace;--radius:12px;--shadow-sm:0 1px 3px #3b2e1e0f;--shadow-md:0 4px 12px #3b2e1e14}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html{background:var(--bg)}body{background:var(--bg);color:var(--text);font-family:var(--font-body);-webkit-font-smoothing:antialiased}input,button{font-family:inherit}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.fade-in{animation:.3s fadeIn}.home-screen{flex-direction:column;max-width:540px;min-height:100dvh;margin:0 auto;display:flex}.home-header{text-align:center;padding:40px 20px 20px}.app-logo{align-items:center;gap:10px;display:flex}.logo-img{border-radius:10px;width:40px;height:40px}.app-title{font-family:var(--font-display);color:var(--text);letter-spacing:-.02em;font-size:32px;font-weight:700}.app-tagline{color:var(--text-dim);font-size:16px;font-weight:500}.search-section{flex-direction:column;gap:10px;padding:0 20px 12px;display:flex}.search-bar{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);flex:1;align-items:center;gap:8px;padding:0 14px;transition:border-color .2s;display:flex}.search-bar:focus-within{border-color:var(--accent)}.search-icon{opacity:.5;flex-shrink:0;font-size:16px}.search-input{color:var(--text);background:0 0;border:none;outline:none;flex:1;padding:14px 0;font-size:16px;font-weight:500}.search-input::placeholder{color:var(--text-faint)}.clear-btn{color:var(--text-faint);cursor:pointer;background:0 0;border:none;padding:4px;font-size:16px}.scan-btn{background:var(--accent);color:#fff;border-radius:var(--radius);cursor:pointer;white-space:nowrap;width:100%;box-shadow:var(--shadow-sm);border:none;justify-content:center;align-items:center;gap:6px;padding:12px 16px;font-size:15px;font-weight:700;transition:transform .15s,background .2s;display:flex}.scan-btn:active{background:var(--accent-text);transform:scale(.97)}.search-status{color:var(--text-dim);align-items:center;gap:8px;padding:12px 20px;font-size:14px;display:flex}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:16px;height:16px;animation:.7s linear infinite spin;display:inline-block}.search-results{flex-direction:column;gap:6px;padding:0 20px 12px;display:flex}.result-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);cursor:pointer;text-align:left;width:100%;box-shadow:var(--shadow-sm);font-family:var(--font-body);color:var(--text);align-items:center;gap:12px;padding:10px 12px;transition:all .15s;display:flex}.result-card:active{background:var(--surface-alt)}.result-cover-wrap{background:var(--surface-alt);border-radius:4px;flex-shrink:0;width:36px;height:52px;overflow:hidden}.result-cover{object-fit:cover;width:100%;height:100%}.result-cover-placeholder{justify-content:center;align-items:center;width:100%;height:100%;font-size:20px;display:flex}.result-info{flex:1;min-width:0}.result-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:700;overflow:hidden}.result-author{color:var(--text-dim);margin-top:1px;font-size:13px}.result-arrow{color:var(--text-faint);flex-shrink:0;font-size:18px}.error-banner{border-radius:var(--radius);color:#dc2626;background:#fef2f2;border:1px solid #fecaca;margin:0 20px 12px;padding:10px 14px;font-size:13px;font-weight:500}.pending-card{background:var(--surface);border:1.5px solid var(--accent);border-radius:var(--radius);margin:0 20px 16px;padding:16px;box-shadow:0 4px 16px #3b6b4f14}.pending-info{align-items:center;gap:12px;margin-bottom:14px;display:flex}.pending-cover{object-fit:cover;width:44px;height:66px;box-shadow:var(--shadow-sm);border-radius:4px;flex-shrink:0}.pending-title{color:var(--text);font-size:16px;font-weight:700}.pending-author{color:var(--text-dim);margin-top:2px;font-size:14px}.generate-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:10px;width:100%;padding:14px;font-size:16px;font-weight:700;transition:all .15s}.generate-btn:active{transform:scale(.98)}.generate-btn:disabled{background:var(--surface-alt);color:var(--text-dim);cursor:wait}.gen-loading{justify-content:center;align-items:center;gap:8px;display:flex}.demo-section{padding:8px 20px 20px}.demo-header{margin-bottom:10px}.demo-label{color:var(--text-faint);letter-spacing:.08em;text-transform:uppercase;font-size:12px;font-weight:700;font-family:var(--font-mono)}.demo-list{flex-direction:column;gap:6px;display:flex}.demo-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);cursor:pointer;text-align:left;width:100%;box-shadow:var(--shadow-sm);font-family:var(--font-body);color:var(--text);align-items:center;gap:12px;padding:10px 12px;transition:all .15s;display:flex}.demo-card:active{background:var(--surface-alt)}.demo-cover-wrap{background:var(--surface-alt);width:38px;height:56px;box-shadow:var(--shadow-sm);border-radius:4px;flex-shrink:0;overflow:hidden}.demo-cover{object-fit:cover;width:100%;height:100%}.demo-info{flex:1;min-width:0}.demo-title{text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:700;overflow:hidden}.demo-author{color:var(--text-dim);margin-top:1px;font-size:13px}.demo-badge{font-size:11px;font-weight:700;font-family:var(--font-mono);border-radius:20px;flex-shrink:0;padding:3px 9px}.home-footer{text-align:center;margin-top:auto;padding:24px 20px}.home-footer p{color:var(--text-faint);font-size:12px;font-style:italic}.scorecard-page{background:var(--bg);max-width:540px;min-height:100vh;margin:0 auto}.sc-nav{border-bottom:1px solid var(--border-light);z-index:10;-webkit-backdrop-filter:blur(12px);background:#faf9f6eb;align-items:center;padding:12px 18px;display:flex;position:sticky;top:0}.sc-back{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:4px 0;font-size:14px;font-weight:700}.sc-brand{color:var(--text-faint);font-size:11px;font-family:var(--font-mono);margin-left:auto}.sc-book-header{align-items:flex-start;gap:14px;padding:20px 18px 16px;display:flex}.sc-cover-wrap{background:var(--surface-alt);border-radius:8px;flex-shrink:0;width:80px;height:120px;overflow:hidden;box-shadow:0 4px 16px #0000001a}.sc-cover{object-fit:cover;width:100%;height:100%}.sc-meta{min-width:0}.sc-title{font-family:var(--font-display);color:var(--text);font-size:24px;font-weight:700;line-height:1.2}.sc-author{color:var(--text-dim);margin-top:4px;font-size:15px;font-weight:500}.sc-tags{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.sc-tag{color:var(--text-dim);background:var(--surface-alt);font-size:11px;font-family:var(--font-mono);border-radius:20px;padding:3px 10px;font-weight:500}.sc-tag.accent{color:var(--accent-text);background:var(--accent-light)}.sc-summary{padding:0 18px 14px}.sc-summary p{color:var(--text-dim);font-size:15px;font-style:italic;line-height:1.6}.sc-content{padding:0 18px 36px}.glance-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border-light);box-shadow:var(--shadow-sm);margin-bottom:18px;padding:16px}.glance-title{color:var(--text-faint);letter-spacing:.08em;text-transform:uppercase;font-size:11px;font-weight:700;font-family:var(--font-mono);margin-bottom:14px}.glance-rows{flex-direction:column;gap:9px;display:flex}.glance-row{align-items:center;gap:9px;display:flex}.gl-icon{text-align:center;width:22px;font-size:14px}.gl-label{color:var(--text-mid);flex-shrink:0;width:110px;font-size:14px;font-weight:600}.gl-sev{font-size:10px;font-weight:700;font-family:var(--font-mono);text-align:right;flex-shrink:0;width:70px}.heads-section{border-top:1px solid var(--border-light);margin-top:14px;padding-top:12px}.heads-title{color:var(--text-faint);letter-spacing:.06em;text-transform:uppercase;font-size:11px;font-weight:700;font-family:var(--font-mono);margin-bottom:10px}.head-item{align-items:flex-start;gap:8px;margin-bottom:8px;display:flex}.head-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px;margin-top:6px}.head-text{color:var(--text-mid);font-size:14px;line-height:1.5}.sev-track{background:#f0ece5;border-radius:4px;flex:1;height:8px;position:relative;overflow:hidden}.sev-fill{border-radius:4px;transition:width .8s cubic-bezier(.16,1,.3,1);position:absolute;top:0;bottom:0;left:0}.sev-tick{background:#0000000d;width:1px;position:absolute;top:0;bottom:0}.cat-section{opacity:0;margin-bottom:6px;animation:.4s forwards slideUp}.cat-head{background:var(--surface);cursor:pointer;box-shadow:var(--shadow-sm);border-left:3px solid;border-radius:10px 10px 0 0;justify-content:space-between;align-items:center;padding:12px 14px;transition:all .2s;display:flex}.cat-left{align-items:center;gap:8px;display:flex}.cat-icon{font-size:16px}.cat-name{color:var(--text);font-size:15px;font-weight:700}.cat-right{align-items:center;gap:8px;display:flex}.cat-badge{font-size:10px;font-weight:700;font-family:var(--font-mono);border-radius:20px;padding:2px 9px}.cat-chev{color:var(--text-faint);font-size:13px;transition:transform .2s}.cat-body{background:var(--surface);box-shadow:var(--shadow-sm);border-left:3px solid;border-radius:0 0 10px 10px;padding:4px 14px 8px}.sub-row{border-bottom:1px solid var(--border-light);opacity:0;padding:9px 0;animation:.3s forwards slideUp}.sub-inner{align-items:center;gap:8px;display:flex}.sub-label{color:var(--text-mid);flex-shrink:0;width:150px;font-size:13px;font-weight:600;line-height:1.3}.sub-sev{font-size:10px;font-weight:700;font-family:var(--font-mono);text-align:center;white-space:nowrap;border-radius:12px;flex-shrink:0;width:auto;padding:2px 8px}.sub-detail{color:var(--text-dim);margin-top:6px;padding-left:158px;font-size:13px;font-style:italic;line-height:1.5}.sub-count{font-family:var(--font-mono);font-size:11px;font-style:normal}.sc-breakdown-head{align-items:center;gap:10px;margin-bottom:10px;display:flex}.sc-section-label{color:var(--text-faint);letter-spacing:.08em;text-transform:uppercase;font-size:11px;font-weight:700;font-family:var(--font-mono)}.sc-line{background:var(--border-light);flex:1;height:1px}.sc-hint{color:var(--text-faint);font-size:10px;font-family:var(--font-mono)}.sc-legend{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border-light);margin-top:20px;padding:14px}.sc-legend-label{color:var(--text-faint);letter-spacing:.08em;text-transform:uppercase;font-size:10px;font-weight:700;font-family:var(--font-mono);margin-bottom:8px}.sc-legend-bar{display:flex}.sc-legend-seg{text-align:center;flex:1}.sc-legend-color{height:5px;margin-bottom:4px}.sc-disclaimer{color:var(--text-faint);text-align:center;margin-top:20px;font-size:12px;font-style:italic}.scanner-overlay{z-index:1000;background:#000;flex-direction:column;display:flex;position:fixed;inset:0}.scanner-header{z-index:10;justify-content:space-between;align-items:center;padding:16px 20px;display:flex;position:relative}.scanner-close{color:#fff;cursor:pointer;font-size:14px;font-family:var(--font-body);background:#ffffff26;border:none;border-radius:8px;padding:8px 16px;font-weight:600}.scanner-hint{color:#fff9;font-size:13px;font-family:var(--font-body);font-weight:600}.scanner-body{flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.scanner-native{width:100%;height:100%;position:relative}.scanner-video{object-fit:cover;width:100%;height:100%}.scanner-target{pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.scanner-frame{border:2px solid #3b6b4f99;border-radius:12px;width:75%;max-width:320px;height:120px;box-shadow:0 0 0 9999px #00000080}.scanner-viewport{width:100%;max-width:500px}.scanner-viewport video{border-radius:0!important}#barcode-reader-fallback{border:none!important}#barcode-reader-fallback__scan_region{background:0 0!important}#barcode-reader-fallback__dashboard,#barcode-reader-fallback__header_message{display:none!important}.scanner-loading{color:#ffffffb3;font-size:14px;font-family:var(--font-body);justify-content:center;align-items:center;gap:10px;display:flex;position:absolute;inset:0}.scanner-loading .spinner{border-color:#fff #fff3 #fff3}.scanner-error{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:40px;display:flex;position:absolute;inset:0}.scanner-error p{color:#fff9;font-size:14px;line-height:1.6;font-family:var(--font-body);margin-bottom:16px}.scanner-error-btn{background:var(--accent);color:#fff;cursor:pointer;font-size:14px;font-weight:700;font-family:var(--font-body);border:none;border-radius:10px;padding:12px 24px}.scanner-tip{text-align:center;padding:20px}.scanner-tip p{color:#ffffff4d;font-size:12px;font-family:var(--font-body)}.amazon-cta{padding:0 18px 14px}.amazon-cta-btn{text-align:center;color:#fff;width:100%;font-size:15px;font-weight:700;font-family:var(--font-body);border-radius:var(--radius);background:#e89830;padding:14px;text-decoration:none;transition:all .15s;display:block}.amazon-cta-btn:active{background:#d48820;transform:scale(.98)}.unable-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);text-align:center;box-shadow:var(--shadow-sm);padding:32px 24px}.unable-icon{margin-bottom:16px;font-size:40px}.unable-title{font-family:var(--font-display);color:var(--text);margin-bottom:10px;font-size:20px;font-weight:700}.unable-text{color:var(--text-dim);max-width:320px;margin-bottom:20px;margin-left:auto;margin-right:auto;font-size:15px;line-height:1.6}.unable-btn{background:var(--accent);color:#fff;cursor:pointer;font-size:16px;font-weight:700;font-family:var(--font-body);border:none;border-radius:10px;padding:14px 28px;transition:all .15s}.unable-btn:active{transform:scale(.98)}.unable-btn:disabled{background:var(--surface-alt);color:var(--text-dim);cursor:wait}.unable-confirmed{color:var(--accent-text);background:var(--accent-light);border-radius:10px;padding:12px 20px;font-size:15px;font-weight:600}.sc-share{background:var(--accent-light);border:1px solid var(--accent);color:var(--accent-text);cursor:pointer;font-size:13px;font-weight:700;font-family:var(--font-body);border-radius:20px;margin-left:auto;padding:6px 14px;transition:all .15s}.sc-share:active{background:var(--accent);color:#fff}.loading-screen{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.app-header-row{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.profile-btn{border:2px solid var(--border);background:var(--surface);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;padding:0;transition:border-color .2s;display:flex;overflow:hidden}.profile-btn:active{border-color:var(--accent)}.profile-avatar{object-fit:cover;border-radius:50%;width:100%;height:100%}.profile-initial{color:var(--accent);font-size:15px;font-weight:700;font-family:var(--font-body)}.signin-btn{background:var(--accent);color:#fff;cursor:pointer;font-size:13px;font-weight:700;font-family:var(--font-body);border:none;border-radius:20px;padding:8px 16px;transition:all .15s}.signin-btn:active{transform:scale(.97)}.family-screen{background:var(--bg);max-width:540px;min-height:100vh;margin:0 auto}.family-header{padding:20px}.family-user{align-items:center;gap:12px;display:flex}.family-avatar{object-fit:cover;border-radius:50%;width:44px;height:44px}.family-name{color:var(--text);font-size:16px;font-weight:700}.family-email{color:var(--text-dim);margin-top:2px;font-size:13px}.family-signout-btn{border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text-dim);cursor:pointer;font-size:15px;font-weight:600;font-family:var(--font-body);background:0 0;margin-top:24px;padding:14px;transition:all .15s}.family-signout-btn:active{background:var(--surface-alt)}.family-content{padding:0 20px 40px}.family-section-label{color:var(--text-faint);letter-spacing:.08em;text-transform:uppercase;font-size:12px;font-weight:700;font-family:var(--font-mono);margin-bottom:12px}.family-empty{text-align:center;padding:20px}.family-empty p{color:var(--text-dim);font-size:15px;line-height:1.6}.family-kids-list{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.family-kid-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.family-kid-name{color:var(--text);font-size:16px;font-weight:700}.family-kid-age{color:var(--text-dim);margin-top:2px;font-size:13px}.family-kid-remove{color:var(--text-faint);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:18px}.family-add-btn{border:2px dashed var(--border);border-radius:var(--radius);width:100%;color:var(--accent);cursor:pointer;font-size:15px;font-weight:700;font-family:var(--font-body);background:0 0;padding:14px;transition:all .15s}.family-add-btn:active{background:var(--accent-light)}.family-form{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px}.family-input{border:1.5px solid var(--border);width:100%;color:var(--text);background:var(--bg);font-size:16px;font-family:var(--font-body);border-radius:10px;outline:none;margin-bottom:10px;padding:12px 14px}.family-input:focus{border-color:var(--accent)}.family-date-row{gap:8px;margin-bottom:12px;display:flex}.family-select{border:1.5px solid var(--border);color:var(--text);background:var(--bg);font-size:15px;font-family:var(--font-body);appearance:auto;border-radius:10px;flex:1;padding:12px 10px}.family-form-actions{gap:8px;display:flex}.family-cancel-btn{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;font-size:15px;font-weight:600;font-family:var(--font-body);background:0 0;border-radius:10px;flex:1;padding:12px}.family-save-btn{background:var(--accent);color:#fff;cursor:pointer;font-size:15px;font-weight:700;font-family:var(--font-body);border:none;border-radius:10px;flex:1;padding:12px}.family-save-btn:disabled{background:var(--surface-alt);color:var(--text-dim)}.family-rating-section{border-top:1px solid var(--border-light);margin-top:20px;padding-top:16px}.family-rating-label{color:var(--text-faint);letter-spacing:.08em;text-transform:uppercase;font-size:12px;font-weight:700;font-family:var(--font-mono);margin-bottom:10px}.family-rating-kids{flex-direction:column;gap:8px;display:flex}.family-kid-btn{background:var(--surface);border:1px solid var(--border-light);cursor:pointer;text-align:left;width:100%;font-family:var(--font-body);border-radius:10px;align-items:center;gap:8px;padding:10px 14px;transition:all .15s;display:flex}.family-kid-btn:active{background:var(--surface-alt)}.family-kid-btn.rated{border-color:var(--accent);background:var(--accent-light)}.fk-name{color:var(--text);font-size:15px;font-weight:700}.fk-age{color:var(--text-dim);font-size:13px}.fk-rating{margin-left:auto;font-size:18px}.family-rating-options{justify-content:center;gap:8px;padding:8px 0 4px;display:flex}.rate-option{border:2px solid var(--border-light);cursor:pointer;background:0 0;border-radius:12px;padding:8px 16px;font-size:28px;transition:all .15s}.rate-option:active{background:var(--accent-light);border-color:var(--accent);transform:scale(1.1)}.family-signin-prompt{border:1px solid var(--border-light);border-radius:var(--radius);background:var(--surface);width:100%;color:var(--accent);cursor:pointer;font-size:14px;font-weight:600;font-family:var(--font-body);text-align:center;padding:14px;transition:all .15s}.family-signin-prompt:active{background:var(--accent-light)}.footer-link{color:var(--text-faint);margin-top:8px;font-size:12px;text-decoration:none;display:inline-block}.footer-link:hover{text-decoration:underline}.family-rating-hint{color:var(--text-dim);margin-bottom:10px;font-size:14px}.family-rating-prompt{text-align:center;padding:10px 0 4px}.rate-question{color:var(--text-mid);margin-bottom:8px;font-size:15px;font-weight:600}.filter-screen{background:var(--bg);max-width:540px;min-height:100vh;margin:0 auto}.filter-header{padding:20px 20px 10px}.filter-title{font-family:var(--font-display);color:var(--text);margin-bottom:8px;font-size:24px;font-weight:700}.filter-subtitle{color:var(--text-dim);font-size:14px;line-height:1.5}.filter-content{padding:10px 20px 40px}.filter-category{margin-bottom:24px}.filter-cat-header{border-bottom:1px solid var(--border-light);align-items:center;gap:8px;margin-bottom:12px;padding-bottom:8px;display:flex}.filter-cat-icon{font-size:18px}.filter-cat-label{color:var(--text);font-size:16px;font-weight:700}.filter-item{margin-bottom:16px}.filter-item-label{color:var(--text);margin-bottom:2px;font-size:15px;font-weight:700}.filter-item-desc{color:var(--text-dim);margin-bottom:8px;font-size:13px}.filter-options{gap:6px;display:flex}.filter-opt{border:1.5px solid var(--border);background:var(--surface);color:var(--text-mid);cursor:pointer;text-align:center;font-size:12px;font-weight:600;font-family:var(--font-body);border-radius:8px;flex:1;padding:8px 4px;transition:all .15s}.filter-opt:active{transform:scale(.97)}.filter-opt.active{border-width:2px}.filter-save-btn{border-radius:var(--radius);background:var(--accent);color:#fff;cursor:pointer;width:100%;font-size:16px;font-weight:700;font-family:var(--font-body);border:none;margin-top:12px;padding:16px;transition:all .15s}.filter-save-btn:active{transform:scale(.98)}.filter-save-btn:disabled{background:var(--surface-alt);color:var(--text-dim)}.filter-note{color:var(--text-faint);text-align:center;margin-top:16px;font-size:13px;font-style:italic;line-height:1.5}.family-filter-btn{border:1.5px solid var(--accent);border-radius:var(--radius);background:var(--accent-light);width:100%;color:var(--accent-text);cursor:pointer;font-size:15px;font-weight:700;font-family:var(--font-body);margin-top:20px;padding:14px;transition:all .15s}.family-filter-btn:active{background:var(--warm)}.fit-section{padding:0 18px 12px}.fit-pass{border-radius:var(--radius);background:#f0faf3;border:1px solid #c6f0d2;margin-bottom:8px;padding:10px 14px;font-size:14px}.fit-label{color:var(--text-dim)}.fit-names{color:#1a7a3a;font-weight:700}.fit-flag{margin-bottom:8px}.fit-flag-btn{text-align:left;border-radius:var(--radius);color:#92640d;cursor:pointer;width:100%;font-size:13px;font-weight:600;font-family:var(--font-body);background:#fef7ee;border:1px solid #f5e0c0;padding:10px 14px}.fit-flag-details{padding:8px 14px 4px}.fit-flag-item{color:var(--text-mid);align-items:center;gap:6px;margin-bottom:4px;font-size:13px;display:flex}.fit-flag-dot{color:#ea580c}.recommend-screen{background:var(--bg);max-width:540px;min-height:100vh;margin:0 auto}.recommend-header{padding:20px 20px 10px}.recommend-title{font-family:var(--font-display);color:var(--text);margin-bottom:4px;font-size:24px;font-weight:700}.recommend-subtitle{color:var(--text-dim);font-size:14px;line-height:1.4}.recommend-content{padding:10px 20px 40px}.recommend-loading{text-align:center;padding:40px 20px}.recommend-loading .spinner{margin-bottom:12px}.recommend-loading p{color:var(--text-dim);font-size:15px}.recommend-error{text-align:center;padding:40px 20px}.recommend-error p{color:#dc2626;margin-bottom:16px;font-size:15px}.recommend-retry-btn{background:var(--accent);color:#fff;cursor:pointer;font-size:15px;font-weight:700;font-family:var(--font-body);border:none;border-radius:10px;padding:12px 24px}.recommend-empty{text-align:center;padding:40px 20px}.recommend-empty p{color:var(--text-dim);font-size:15px;line-height:1.5}.recommend-list{flex-direction:column;gap:8px;display:flex}.recommend-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);cursor:pointer;text-align:left;width:100%;font-family:var(--font-body);color:var(--text);box-shadow:var(--shadow-sm);align-items:flex-start;gap:12px;padding:12px;transition:all .15s;display:flex}.recommend-card:active{background:var(--surface-alt)}.recommend-cover-wrap{background:var(--surface-alt);width:50px;height:75px;box-shadow:var(--shadow-sm);border-radius:4px;flex-shrink:0;overflow:hidden}.recommend-cover{object-fit:cover;width:100%;height:100%}.recommend-cover-placeholder{justify-content:center;align-items:center;width:100%;height:100%;font-size:24px;display:flex}.recommend-info{flex:1;min-width:0}.recommend-book-title{color:var(--text);margin-bottom:2px;font-size:15px;font-weight:700}.recommend-book-author{color:var(--text-dim);margin-bottom:6px;font-size:13px}.recommend-reason{color:var(--text-mid);font-size:13px;font-style:italic;line-height:1.4}.recommend-refresh-btn{border:1.5px solid var(--border);border-radius:var(--radius);background:var(--surface);width:100%;color:var(--text-mid);cursor:pointer;font-size:15px;font-weight:600;font-family:var(--font-body);margin-top:16px;padding:14px;transition:all .15s}.recommend-refresh-btn:active{background:var(--surface-alt)}.family-kid-actions{align-items:center;gap:8px;display:flex}.family-kid-recommend{background:var(--accent-light);border:1px solid var(--accent);color:var(--accent-text);cursor:pointer;font-size:12px;font-weight:700;font-family:var(--font-body);white-space:nowrap;border-radius:20px;padding:6px 12px;transition:all .15s}.family-kid-recommend:active{background:var(--accent);color:#fff}.fit-rated{flex-wrap:wrap;gap:6px;margin-bottom:8px;display:flex}.fit-rated-item{border-radius:var(--radius);color:var(--text-mid);background:#f5f0e7;border:1px solid #e6dbc8;padding:8px 14px;font-size:14px;font-weight:600}.recommend-limit{text-align:center;color:var(--text-dim);background:var(--surface-alt);border-radius:var(--radius);margin-top:16px;padding:14px;font-size:14px;font-style:italic}.sc-nav-right{align-items:center;gap:8px;margin-left:auto;display:flex}.sc-bookmark{border:1.5px solid var(--border);color:var(--text-mid);cursor:pointer;background:0 0;border-radius:20px;justify-content:center;align-items:center;padding:6px 10px;transition:all .15s;display:flex}.sc-bookmark:active{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.bookmark-overlay{z-index:999;background:#0000004d;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.bookmark-popup{background:var(--surface);border-radius:16px;width:100%;max-width:300px;padding:20px;box-shadow:0 12px 40px #00000026}.bookmark-popup-title{font-family:var(--font-display);color:var(--text);text-align:center;margin-bottom:12px;font-size:18px;font-weight:700}.bookmark-popup-list{flex-direction:column;gap:6px;display:flex}.bookmark-popup-item{background:var(--bg);border:1px solid var(--border-light);cursor:pointer;text-align:left;width:100%;font-family:var(--font-body);border-radius:10px;align-items:center;gap:8px;padding:12px 14px;transition:all .15s;display:flex}.bookmark-popup-item:active{background:var(--accent-light);border-color:var(--accent)}.bookmark-popup-name{color:var(--text);font-size:15px;font-weight:700}.bookmark-popup-age{color:var(--text-dim);font-size:13px}.bookmark-toast{border-radius:var(--radius);color:#1a7a3a;text-align:center;background:#f0faf3;border:1px solid #c6f0d2;margin:0 18px 8px;padding:10px 14px;font-size:14px;font-weight:600}.bookmarks-screen{background:var(--bg);max-width:540px;min-height:100vh;margin:0 auto}.bookmarks-header{padding:20px 20px 10px}.bookmarks-title{font-family:var(--font-display);color:var(--text);margin-bottom:4px;font-size:24px;font-weight:700}.bookmarks-subtitle{color:var(--text-dim);font-size:14px}.bookmarks-content{padding:10px 20px 40px}.bookmark-card{align-items:center;gap:0;display:flex}.bookmark-card-main{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius) 0 0 var(--radius);cursor:pointer;text-align:left;font-family:var(--font-body);color:var(--text);box-shadow:var(--shadow-sm);flex:1;align-items:flex-start;gap:12px;padding:12px;transition:all .15s;display:flex}.bookmark-card-main:active{background:var(--surface-alt)}.bookmark-remove{background:var(--surface);border:1px solid var(--border-light);border-radius:0 var(--radius) var(--radius) 0;color:var(--text-faint);cursor:pointer;border-left:none;align-self:stretch;align-items:center;padding:12px 14px;font-size:16px;transition:all .15s;display:flex}.bookmark-remove:active{color:#dc2626}.unable-error{color:#dc2626;text-align:center;margin-bottom:16px;font-size:14px}.sc-bookmark.bookmarked{color:var(--accent);border-color:var(--accent)}.bookmark-popup-item.already-saved{background:var(--accent-light);border-color:var(--accent);cursor:default}.bookmark-popup-saved{color:var(--accent);margin-left:auto}.fk-bookmark{color:var(--accent);flex-shrink:0;margin-left:4px}
