:root{--bd-bg-primary:#0f172a;--bd-bg-secondary:#1e293b;--bd-bg-tertiary:#334155;--bd-bg-elevated:#1e293b;--bd-text-primary:#f8fafc;--bd-text-secondary:#94a3b8;--bd-text-muted:#64748b;--bd-text-inverse:#0f172a;--bd-brand-primary:#22c55e;--bd-brand-hover:#16a34a;--bd-brand-muted:#22c55e20;--bd-success:#22c55e;--bd-warning:#f59e0b;--bd-error:#ef4444;--bd-info:#3b82f6;--bd-border-default:#334155;--bd-border-focus:#6366f1;--bd-font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--bd-font-mono:"JetBrains Mono", "Fira Code", Consolas, monospace;--bd-text-xs:.75rem;--bd-text-sm:.875rem;--bd-text-base:1rem;--bd-text-lg:1.125rem;--bd-text-xl:1.25rem;--bd-text-2xl:1.5rem;--bd-text-3xl:1.875rem;--bd-text-4xl:2.25rem;--bd-font-normal:400;--bd-font-medium:500;--bd-font-semibold:600;--bd-font-bold:700;--bd-space-0:0;--bd-space-1:.25rem;--bd-space-2:.5rem;--bd-space-3:.75rem;--bd-space-4:1rem;--bd-space-5:1.25rem;--bd-space-6:1.5rem;--bd-space-8:2rem;--bd-space-10:2.5rem;--bd-space-12:3rem;--bd-space-16:4rem;--bd-space-20:5rem;--bd-radius-none:0;--bd-radius-sm:.375rem;--bd-radius-md:.5rem;--bd-radius-lg:.75rem;--bd-radius-xl:1rem;--bd-radius-2xl:1.5rem;--bd-radius-full:9999px;--bd-shadow-sm:0 1px 2px #0000004d;--bd-shadow-md:0 4px 6px #0000004d;--bd-shadow-lg:0 10px 15px #0000004d;--bd-shadow-xl:0 20px 25px #0000004d;--bd-transition-fast:.1s ease;--bd-transition-normal:.15s ease;--bd-transition-slow:.3s ease;--bd-header-height:56px;--bd-sidebar-width:240px;--bd-max-content-width:1280px;--bd-z-dropdown:100;--bd-z-sticky:200;--bd-z-modal:300;--bd-z-popover:400;--bd-z-tooltip:500;--bg-primary:var(--bd-bg-primary);--bg-secondary:var(--bd-bg-secondary);--bg-tertiary:var(--bd-bg-tertiary);--bg-elevated:var(--bd-bg-elevated);--text-primary:var(--bd-text-primary);--text-secondary:var(--bd-text-secondary);--text-muted:var(--bd-text-muted);--text-inverse:var(--bd-text-inverse);--brand-primary:var(--bd-brand-primary);--brand-hover:var(--bd-brand-hover);--brand-muted:var(--bd-brand-muted);--success:var(--bd-success);--warning:var(--bd-warning);--error:var(--bd-error);--info:var(--bd-info);--border-default:var(--bd-border-default);--border-focus:var(--bd-border-focus);--font-sans:var(--bd-font-sans);--text-xs:var(--bd-text-xs);--text-sm:var(--bd-text-sm);--text-base:var(--bd-text-base);--text-lg:var(--bd-text-lg);--text-xl:var(--bd-text-xl);--text-2xl:var(--bd-text-2xl);--text-3xl:var(--bd-text-3xl);--font-normal:var(--bd-font-normal);--font-medium:var(--bd-font-medium);--font-semibold:var(--bd-font-semibold);--font-bold:var(--bd-font-bold);--space-1:var(--bd-space-1);--space-2:var(--bd-space-2);--space-3:var(--bd-space-3);--space-4:var(--bd-space-4);--space-5:var(--bd-space-5);--space-6:var(--bd-space-6);--space-8:var(--bd-space-8);--space-10:var(--bd-space-10);--space-12:var(--bd-space-12);--radius-sm:var(--bd-radius-sm);--radius-md:var(--bd-radius-md);--radius-lg:var(--bd-radius-lg);--radius-xl:var(--bd-radius-xl);--radius-full:var(--bd-radius-full);--shadow-sm:var(--bd-shadow-sm);--shadow-md:var(--bd-shadow-md);--shadow-lg:var(--bd-shadow-lg);--header-height:var(--bd-header-height);--sidebar-width:var(--bd-sidebar-width)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px}body{font-family:var(--bd-font-sans);background-color:var(--bd-bg-primary);color:var(--bd-text-primary);min-height:100vh;line-height:1.5}a{color:var(--bd-brand-primary);transition:color var(--bd-transition-fast);text-decoration:none}a:hover{text-decoration:underline}a:focus-visible{outline:2px solid var(--bd-border-focus);outline-offset:2px}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,textarea,select{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bd-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bd-bg-tertiary);border-radius:var(--bd-radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--bd-text-muted)}*{scrollbar-width:thin;scrollbar-color:var(--bd-bg-tertiary) var(--bd-bg-secondary)}.bd-sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.bd-truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.bd-btn{justify-content:center;align-items:center;gap:var(--bd-space-2);padding:var(--bd-space-2) var(--bd-space-4);font-size:var(--bd-text-sm);font-weight:var(--bd-font-medium);border-radius:var(--bd-radius-md);transition:all var(--bd-transition-normal);cursor:pointer;border:none;display:inline-flex}.bd-btn:focus-visible{outline:2px solid var(--bd-border-focus);outline-offset:2px}.bd-btn:disabled{opacity:.5;cursor:not-allowed}.bd-btn-primary{background-color:var(--bd-brand-primary);color:var(--bd-text-inverse)}.bd-btn-primary:hover:not(:disabled){background-color:var(--bd-brand-hover)}.bd-btn-secondary{background-color:var(--bd-bg-tertiary);color:var(--bd-text-primary)}.bd-btn-secondary:hover:not(:disabled){background-color:var(--bd-border-default)}.bd-btn-ghost{color:var(--bd-text-secondary);background-color:#0000}.bd-btn-ghost:hover:not(:disabled){background-color:var(--bd-bg-tertiary);color:var(--bd-text-primary)}.bd-btn-danger{background-color:var(--bd-error);color:#fff}.bd-btn-danger:hover:not(:disabled){background-color:#dc2626}.bd-btn-sm{padding:var(--bd-space-1) var(--bd-space-2);font-size:var(--bd-text-xs)}.bd-btn-lg{padding:var(--bd-space-3) var(--bd-space-6);font-size:var(--bd-text-base)}.bd-card{background-color:var(--bd-bg-secondary);border:1px solid var(--bd-border-default);border-radius:var(--bd-radius-lg);padding:var(--bd-space-4)}.bd-card-elevated{box-shadow:var(--bd-shadow-md)}.bd-input{width:100%;padding:var(--bd-space-2) var(--bd-space-3);background-color:var(--bd-bg-tertiary);border:1px solid var(--bd-border-default);border-radius:var(--bd-radius-md);color:var(--bd-text-primary);font-size:var(--bd-text-sm);transition:border-color var(--bd-transition-fast), box-shadow var(--bd-transition-fast)}.bd-input:focus{border-color:var(--bd-border-focus);outline:none;box-shadow:0 0 0 2px #6366f133}.bd-input::placeholder{color:var(--bd-text-muted)}.bd-input:disabled{opacity:.5;cursor:not-allowed}.bd-input-error{border-color:var(--bd-error)}.bd-input-error:focus{box-shadow:0 0 0 2px #ef444433}.bd-badge{padding:var(--bd-space-1) var(--bd-space-2);font-size:var(--bd-text-xs);font-weight:var(--bd-font-medium);border-radius:var(--bd-radius-full);background-color:var(--bd-bg-tertiary);color:var(--bd-text-secondary);align-items:center;display:inline-flex}.bd-badge-success{color:var(--bd-success);background-color:#22c55e33}.bd-badge-warning{color:var(--bd-warning);background-color:#f59e0b33}.bd-badge-error{color:var(--bd-error);background-color:#ef444433}.bd-badge-info{color:var(--bd-info);background-color:#3b82f633}.bd-empty-state{padding:var(--bd-space-12);text-align:center;color:var(--bd-text-muted);flex-direction:column;justify-content:center;align-items:center;display:flex}.bd-spinner{border:2px solid var(--bd-bg-tertiary);border-top-color:var(--bd-brand-primary);border-radius:50%;width:1.5rem;height:1.5rem;animation:.6s linear infinite bd-spin}.bd-spinner-sm{width:1rem;height:1rem}.bd-spinner-lg{width:2rem;height:2rem}@keyframes bd-spin{to{transform:rotate(360deg)}}.bd-overlay{z-index:var(--bd-z-modal);background-color:#0009;position:fixed;inset:0}.bd-modal{background-color:var(--bd-bg-secondary);border:1px solid var(--bd-border-default);border-radius:var(--bd-radius-xl);padding:var(--bd-space-6);max-width:90vw;max-height:90vh;z-index:calc(var(--bd-z-modal) + 1);box-shadow:var(--bd-shadow-xl);position:fixed;top:50%;left:50%;overflow:auto;transform:translate(-50%,-50%)}.btn{justify-content:center;align-items:center;gap:var(--bd-space-2);padding:var(--bd-space-2) var(--bd-space-4);font-size:var(--bd-text-sm);font-weight:var(--bd-font-medium);border-radius:var(--bd-radius-md);transition:all var(--bd-transition-normal);display:inline-flex}.btn-primary{background-color:var(--bd-brand-primary);color:var(--bd-text-inverse)}.btn-primary:hover{background-color:var(--bd-brand-hover)}.btn-secondary{background-color:var(--bd-bg-tertiary);color:var(--bd-text-primary)}.btn-secondary:hover{background-color:var(--bd-border-default)}.btn-ghost{color:var(--bd-text-secondary);background-color:#0000}.btn-ghost:hover{background-color:var(--bd-bg-tertiary);color:var(--bd-text-primary)}.card{background-color:var(--bd-bg-secondary);border:1px solid var(--bd-border-default);border-radius:var(--bd-radius-lg);padding:var(--bd-space-4)}.input{width:100%;padding:var(--bd-space-2) var(--bd-space-3);background-color:var(--bd-bg-tertiary);border:1px solid var(--bd-border-default);border-radius:var(--bd-radius-md);color:var(--bd-text-primary);font-size:var(--bd-text-sm)}.input:focus{border-color:var(--bd-border-focus);outline:none;box-shadow:0 0 0 2px #6366f133}.input::placeholder{color:var(--bd-text-muted)}.badge{padding:var(--bd-space-1) var(--bd-space-2);font-size:var(--bd-text-xs);font-weight:var(--bd-font-medium);border-radius:var(--bd-radius-full);background-color:var(--bd-bg-tertiary);color:var(--bd-text-secondary);align-items:center;display:inline-flex}.badge-success{color:var(--bd-success);background-color:#22c55e33}.badge-warning{color:var(--bd-warning);background-color:#f59e0b33}.badge-error{color:var(--bd-error);background-color:#ef444433}.badge-info{color:var(--bd-info);background-color:#3b82f633}.empty-state{padding:var(--bd-space-12);text-align:center;color:var(--bd-text-muted);flex-direction:column;justify-content:center;align-items:center;display:flex}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.bd-confirm-overlay{z-index:1100;background:#0009;justify-content:center;align-items:center;animation:.15s bd-fade-in;display:flex;position:fixed;inset:0}.bd-confirm-dialog{background:var(--bd-bg-primary,#0f172a);border:1px solid var(--bd-border-default,#334155);border-radius:var(--bd-radius-lg,.75rem);text-align:center;width:min(440px,90vw);padding:2rem 1.5rem 1.5rem;animation:.2s bd-slide-up}.bd-confirm-icon{border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:1rem;display:inline-flex}.bd-confirm-title{font-size:var(--bd-text-xl,1.25rem);font-weight:var(--bd-font-semibold,600);color:var(--bd-text-primary,#f8fafc);margin:0 0 .5rem}.bd-confirm-message{font-size:var(--bd-text-sm,.875rem);color:var(--bd-text-secondary,#94a3b8);margin:0 0 1.5rem;line-height:1.6}.bd-confirm-message strong{color:var(--bd-text-primary,#f8fafc)}.bd-confirm-actions{justify-content:center;gap:.75rem;display:flex}.bd-confirm-btn{min-width:120px;font-size:var(--bd-text-sm,.875rem);font-weight:var(--bd-font-medium,500);border-radius:var(--bd-radius-md,.5rem);cursor:pointer;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.5rem 1rem;transition:background .1s,opacity .1s;display:inline-flex}.bd-confirm-btn:disabled{opacity:.6;cursor:not-allowed}.bd-confirm-btn-cancel{background:var(--bd-bg-tertiary,#334155);color:var(--bd-text-primary,#f8fafc);border:1px solid var(--bd-border-default,#334155)}.bd-confirm-btn-cancel:hover:not(:disabled){background:var(--bd-bg-secondary,#1e293b)}.bd-confirm-btn-danger{background:var(--bd-confirm-accent,var(--bd-error,#ef4444));color:#fff}.bd-confirm-btn-danger:hover:not(:disabled){filter:brightness(.9)}.bd-confirm-btn-warning{background:var(--bd-confirm-accent,var(--bd-warning,#f59e0b));color:#fff}.bd-confirm-btn-warning:hover:not(:disabled){filter:brightness(.9)}.bd-confirm-btn-info{background:var(--bd-confirm-accent,var(--bd-info,#3b82f6));color:#fff}.bd-confirm-btn-info:hover:not(:disabled){filter:brightness(.9)}.bd-confirm-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.6s linear infinite bd-spin;display:inline-block}@keyframes bd-fade-in{0%{opacity:0}to{opacity:1}}@keyframes bd-slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.login-btn,.logout-btn{cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:all .2s}.login-btn{color:#fff;background:#ffffff26;border:1px solid #ffffff4d}.login-btn:hover{background:#ffffff40}.logout-btn{color:#ff8a8a;background:#dc354533;border:1px solid #dc35454d}.logout-btn:hover{background:#dc354559}.auth-status{align-items:center;gap:12px;display:flex}.user-profile{align-items:center;gap:8px;display:flex}.user-avatar{background:var(--bd-brand-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.75rem;font-weight:700;display:flex}.user-name{color:#ffffffe6;font-size:.85rem}.auth-callback-page{min-height:60vh;color:var(--bd-text-secondary);flex-direction:column;justify-content:center;align-items:center;display:flex}.auth-callback-page p{margin-top:16px;font-size:1.1rem}.user-menu{position:relative}.user-menu-trigger{color:#ffffffe6;cursor:pointer;background:#ffffff14;border:1px solid #fff3;border-radius:24px;align-items:center;gap:6px;padding:4px 8px;transition:all .2s;display:flex}.user-menu-trigger:hover{background:#ffffff26;border-color:#ffffff59}.user-menu-avatar{background:var(--bd-brand-primary);color:#fff;letter-spacing:.5px;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:.7rem;font-weight:700;display:flex}.user-menu-caret{color:#fff9;transition:transform .2s}.user-menu-trigger[aria-expanded=true] .user-menu-caret{transform:rotate(180deg)}.user-menu-dropdown{background:var(--bd-bg-secondary);border:1px solid var(--bd-border-default);min-width:220px;box-shadow:var(--bd-shadow-lg);z-index:200;border-radius:12px;animation:.15s userMenuFadeIn;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden}@keyframes userMenuFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.user-menu-email{color:var(--bd-text-muted);white-space:nowrap;text-overflow:ellipsis;padding:14px 16px 10px;font-size:.82rem;font-weight:500;overflow:hidden}.user-menu-divider{background:var(--bd-border-default);height:1px;margin:2px 0}.user-menu-item{width:100%;color:var(--bd-text-primary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:10px 16px;font-size:.88rem;transition:background .15s;display:flex}.user-menu-item:hover{background:var(--bd-bg-tertiary)}.user-menu-icon{text-align:center;width:20px;font-size:1rem}.user-menu-logout{color:var(--bd-error)}.user-menu-logout:hover{background:#ef44441a}@media (width<=480px){.book-library{padding:4px}.books-grid{grid-template-columns:1fr;gap:6px}.book-card{border-radius:6px;padding:4px}.book-title{font-size:1.05rem}.book-author{font-size:.95rem}.book-description{-webkit-line-clamp:5;font-size:.9rem}.search-container{max-width:100%;margin-bottom:10px}.search-input{border-radius:20px;padding:10px 35px 10px 10px;font-size:.95rem}.clear-search-btn{width:22px;height:22px;font-size:12px}}.book-library{max-width:1400px;margin:0 auto;padding:0 30px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.book-library h1{text-align:center;color:var(--bd-text-primary);margin-bottom:5px;font-size:2.5rem}.search-container{max-width:600px;margin:0 auto 20px;position:relative}.search-input{border:2px solid var(--bd-border-default);box-sizing:border-box;background:var(--bd-bg-tertiary);width:100%;color:var(--bd-text-primary);border-radius:30px;outline:none;padding:15px 50px 15px 20px;font-size:1.1rem;transition:border-color .3s,box-shadow .3s}.search-input:focus{border-color:var(--bd-brand-primary);box-shadow:0 0 10px #22c55e4d}.search-input::placeholder{color:var(--bd-text-muted)}.clear-search-btn{background:var(--bd-text-muted);cursor:pointer;color:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;transition:background-color .2s;display:flex;position:absolute;top:50%;right:15px;transform:translateY(-50%)}.clear-search-btn:hover{background:var(--bd-text-secondary)}.books-grid{grid-template-columns:repeat(3,1fr);gap:15px;display:grid}.row{flex-wrap:wrap;width:100%;display:flex}.col-4{flex:0 0 33.3333%;max-width:33.3333%}.col-8{flex:0 0 66.6667%;max-width:66.6667%}.book-card{background:var(--bd-bg-secondary);border:2px solid var(--bd-border-default);box-shadow:var(--bd-shadow-sm);cursor:pointer;border-radius:8px;transition:transform .3s,box-shadow .3s,border-color .3s;overflow:hidden}.book-card:hover{box-shadow:var(--bd-shadow-lg);border-color:var(--bd-brand-primary);transform:translateY(-3px)}.book-thumbnail{background:var(--bd-brand-primary);justify-content:center;align-items:center;width:100%;height:100%;min-height:100px;display:flex;overflow:hidden}.book-thumbnail img{object-fit:cover;width:100%;height:100%;transition:transform .3s}.book-card:hover .book-thumbnail img{transform:scale(1.05)}.thumbnail-placeholder{background:var(--bd-brand-primary);justify-content:center;align-items:center;width:100%;height:100%;display:flex}.thumbnail-placeholder span{font-size:2rem}.book-info{box-sizing:border-box;flex-direction:column;justify-content:center;height:100%;padding:10px;display:flex}.book-title{color:var(--bd-text-primary);margin:0 0 4px;font-size:1.3rem;line-height:1.2}.book-author{color:var(--bd-text-secondary);margin:0 0 6px;font-size:1.08rem;font-style:italic}.book-description{color:var(--bd-text-secondary);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0;font-size:1rem;line-height:1.4;display:-webkit-box;overflow:hidden}.loading-message,.error-message,.no-results{text-align:center;color:var(--bd-text-muted);padding:40px;font-size:1.2rem}.error-message{color:var(--bd-error)}.no-results{grid-column:1/-1}.no-results-container{text-align:center;grid-column:1/-1;padding:20px}.load-from-cloud{background:var(--bd-brand-primary);color:#fff;border-radius:12px;margin-top:20px;padding:20px}.load-from-cloud p{margin:0 0 15px;font-size:1.1rem}.load-cloud-btn{color:var(--bd-brand-primary);cursor:pointer;background:#fff;border:none;border-radius:25px;padding:12px 24px;font-size:1rem;font-weight:600;transition:transform .2s,box-shadow .2s}.load-cloud-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px #0003}@media (width<=1200px){.books-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.book-library{padding:15px}.book-library h1{font-size:1.8rem}.books-grid{grid-template-columns:1fr;gap:10px}.search-input{padding:12px 45px 12px 15px;font-size:1rem}}.library-section-heading{color:var(--bd-text-primary);margin:1.5rem 0 .75rem;font-size:1.2rem}.book-price{color:var(--bd-accent,#5cb85c);margin-top:.25rem;font-size:.9rem;font-weight:600;display:inline-block}.book-overview-card{background:var(--bd-bg-secondary);width:100%;box-shadow:var(--bd-shadow-md);border:1px solid var(--bd-border-default);border-radius:12px;margin-bottom:20px;display:flex;overflow:hidden}.book-cover-section{background:var(--bd-bg-tertiary);flex-direction:column;flex-shrink:0;align-items:center;gap:16px;width:30%;padding:20px;display:flex}.book-cover{object-fit:contain;background:#fff;border-radius:8px;height:500px;box-shadow:0 2px 8px #0003}.book-infographic{object-fit:contain;cursor:pointer;background:#fff;border-radius:8px;max-width:100%;max-height:300px;transition:transform .2s;box-shadow:0 2px 8px #00000026}.book-infographic:hover{transform:scale(1.02)}.book-author-info{text-align:center;margin-top:auto}.book-author-info p{color:var(--bd-text-secondary);margin:4px 0;font-size:14px;font-weight:500}.book-info-section{flex-direction:column;flex:1;padding:20px;display:flex;overflow-y:auto}.intro-video-container{background:var(--bd-bg-primary);border-radius:8px;height:0;margin-bottom:20px;padding-bottom:56.25%;position:relative;overflow:hidden}.intro-video-container iframe{border:none;width:100%;height:100%;position:absolute;top:0;left:0}.book-description{flex:1;margin-bottom:20px}.book-description p{color:var(--bd-text-secondary);text-align:justify;margin:0;font-size:16px;line-height:1.7}.amazon-link-section{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.amazon-link{color:#111;background:#f90;border-radius:6px;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:600;text-decoration:none;transition:background .2s,transform .2s;display:inline-flex}.amazon-link:hover{background:#e88a00;transform:translateY(-1px)}.affiliate-disclosure{color:var(--bd-text-muted);font-size:11px;font-style:italic}.keywords-section{color:var(--bd-text-secondary);margin-bottom:20px;font-size:14px;line-height:1.8}.keywords-label{color:var(--bd-text-primary);font-weight:600}.keyword-tag{color:var(--bd-brand-primary);cursor:help;transition:color .2s}.keyword-tag:hover{color:var(--bd-brand-hover);text-decoration:underline}.keyword-separator{color:var(--bd-text-muted)}.social-links{flex-wrap:wrap;gap:12px;margin-top:auto;display:flex}.social-links a{color:var(--bd-brand-primary);border:1px solid var(--bd-brand-primary);border-radius:20px;padding:8px 16px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s}.social-links a:hover{background:var(--bd-brand-primary);color:#fff;text-decoration:none;transform:translateY(-1px);box-shadow:0 2px 4px #22c55e4d}@media (width<=768px){.book-overview-card{flex-direction:column}.book-cover-section{flex-direction:row;justify-content:center;align-items:center;gap:20px;width:100%;padding:16px}.book-cover{width:200px;height:200px}.book-author-info{text-align:left;margin-top:0}.book-info-section{padding:16px}.book-description p{font-size:15px}.social-links{gap:8px}.social-links a{padding:6px 12px;font-size:13px}}@media (width<=480px){.book-cover-section{flex-direction:column;gap:12px}.book-cover{width:150px;height:150px}.book-description p{font-size:14px}}.infographic-modal{z-index:1000;cursor:pointer;background:#000000d9;justify-content:center;align-items:center;width:100%;height:100%;padding:20px;display:flex;position:fixed;top:0;left:0}.infographic-modal-content{cursor:default;justify-content:center;align-items:center;max-width:90vw;max-height:90vh;display:flex;position:relative}.infographic-modal-image{object-fit:contain;border-radius:8px;width:auto;max-width:100%;height:auto;max-height:90vh;box-shadow:0 8px 32px #00000080}.modal-close-btn{cursor:pointer;width:36px;height:36px;color:var(--bd-bg-primary);background:#ffffffe6;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:24px;line-height:1;transition:all .2s;display:flex;position:absolute;top:-40px;right:0}.modal-close-btn:hover{background:#fff;transform:scale(1.1)}.chapter-nav{background:var(--bd-bg-secondary);box-shadow:var(--bd-shadow-md);border-radius:12px;padding:16px;overflow-y:auto}.nav-title{color:var(--bd-text-primary);border-bottom:2px solid var(--bd-border-default);margin:0 0 16px;padding-bottom:12px;font-size:1rem}.nav-item{background:var(--bd-bg-tertiary);cursor:pointer;text-align:left;width:100%;color:var(--bd-text-primary);border:none;border-radius:8px;align-items:center;gap:10px;margin-bottom:5px;padding:12px;transition:all .2s;display:flex}.nav-item:hover{background:var(--bd-border-default)}.nav-item.active{background:var(--bd-brand-primary);color:#fff}.overview-btn .nav-icon{font-size:1.2rem}.overview-btn .nav-text{font-size:.9rem;font-weight:600}.chapters-divider{color:var(--bd-text-muted);text-transform:uppercase;letter-spacing:.5px;align-items:center;margin:16px 0 12px;display:flex}.chapters-divider span{background:var(--bd-bg-secondary);padding:0 8px}.chapters-divider:before,.chapters-divider:after{content:"";background:var(--bd-border-default);flex:1;height:1px}.chapters-list{flex-direction:column;gap:6px;display:flex}.chapter-btn{padding:10px 12px}.chapter-number{background:var(--bd-bg-tertiary);width:24px;height:24px;color:var(--bd-text-secondary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}.nav-item.active .chapter-number{color:#fff;background:#ffffff4d}.chapter-title{text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.85rem;line-height:1.3;display:-webkit-box;overflow:hidden}.no-chapters{color:var(--bd-text-muted);text-align:center;padding:20px;font-size:.9rem}.chapter-nav::-webkit-scrollbar{width:6px}.chapter-nav::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.chapter-nav::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.chapter-nav::-webkit-scrollbar-thumb:hover{background:#aaa}.chapter-view{background:var(--bd-bg-secondary);box-shadow:var(--bd-shadow-md);border-radius:12px;overflow:hidden}.chapter-view-header{background:var(--bd-bg-tertiary);border-bottom:1px solid var(--bd-border-default);align-items:center;gap:16px;padding:16px 24px;display:flex}.chapter-view-header .back-btn{border:1px solid var(--bd-border-default);background:var(--bd-bg-secondary);color:var(--bd-text-secondary);cursor:pointer;border-radius:8px;padding:8px 16px;font-size:14px;transition:all .2s}.chapter-view-header .back-btn:hover{background:var(--bd-border-default)}.chapter-breadcrumb{color:var(--bd-text-secondary);font-size:.9rem}.breadcrumb-separator{color:var(--bd-text-muted);margin:0 8px}.breadcrumb-chapter{color:var(--bd-text-primary);font-weight:500}.chapter-title-section{border-bottom:1px solid var(--bd-border-default);padding:20px 24px}.chapter-badge{background:var(--bd-brand-primary);color:#fff;border-radius:20px;margin-bottom:8px;padding:4px 12px;font-size:.8rem;font-weight:600;display:inline-block}.chapter-view-title{color:var(--bd-text-primary);margin:0;font-size:1.5rem}.chapter-tabs{background:var(--bd-bg-tertiary);border-bottom:2px solid var(--bd-border-default);gap:4px;padding:8px 24px;display:flex;overflow-x:auto}.chapter-tab{cursor:pointer;color:var(--bd-text-secondary);white-space:nowrap;background:0 0;border:none;border-radius:8px 8px 0 0;padding:10px 16px;font-size:.85rem;transition:all .2s}.chapter-tab:hover{background:var(--bd-border-default);color:var(--bd-text-primary)}.chapter-tab.active{background:var(--bd-bg-secondary);color:var(--bd-brand-primary);border-bottom:2px solid var(--bd-brand-primary);margin-bottom:-2px;font-weight:600}.chapter-tab-content{padding:24px}.tab-content-inner{max-width:100%}.overview-text{color:var(--bd-text-secondary);margin-bottom:24px;font-size:1rem;line-height:1.8}.prompts-section{margin-bottom:24px}.prompts-section h4{color:var(--bd-text-primary);margin-bottom:12px}.prompts-table{border-collapse:collapse;width:100%}.prompts-table tr{border-bottom:1px solid var(--bd-border-default)}.prompts-table tr:last-child{border-bottom:none}.prompt-text{color:var(--bd-text-secondary);padding:12px 16px 12px 0;font-size:.95rem;line-height:1.5}.prompt-links{white-space:nowrap;vertical-align:middle;padding:12px 0}.llm-link{border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;margin-left:8px;font-size:1.2rem;text-decoration:none;transition:background .2s,transform .2s;display:inline-flex}.llm-link:hover{background:var(--bd-bg-tertiary);transform:scale(1.1)}.ideamap-section{margin-bottom:24px}.ideamap-section h4{color:var(--bd-text-primary);margin-bottom:12px}.ideamap-image{border-radius:8px;max-width:100%;height:auto;box-shadow:0 2px 8px #0000001a}.ideamap-container{text-align:center;padding:20px}.ideamap-image-large{object-fit:contain;border-radius:8px;max-width:100%;max-height:80vh;box-shadow:0 4px 16px #00000026}.ideamap-placeholder{text-align:center;color:var(--bd-text-muted);padding:60px 20px}.ideamap-placeholder span{margin-bottom:16px;font-size:3rem;display:block}.ideamap-upload-section{border-top:1px solid var(--bd-border-default);flex-direction:column;align-items:center;gap:8px;margin-top:20px;padding-top:16px;display:flex}.ideamap-upload-btn{border:1px dashed var(--bd-brand-primary);background:var(--bd-bg-tertiary);color:var(--bd-brand-primary);cursor:pointer;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .2s}.ideamap-upload-btn:hover:not(:disabled){background:var(--bd-brand-primary);color:#fff}.ideamap-upload-btn:disabled{opacity:.6;cursor:not-allowed}.ideamap-upload-error{color:var(--bd-accent-red,#e53e3e);margin:0;font-size:13px}.imagemap-choose-dialog,.imagemap-generate-form,.imagemap-result-dialog{background:var(--bd-bg-secondary);border:1px solid var(--bd-border-default);border-radius:12px;max-width:560px;margin:0 auto;padding:24px}.imagemap-choose-dialog h4,.imagemap-generate-form h4,.imagemap-result-dialog h4{color:var(--bd-text-primary);margin:0 0 16px;font-size:18px}.imagemap-choose-options{gap:12px;margin-bottom:16px;display:flex}.imagemap-option-btn{border:1px solid var(--bd-border-default);background:var(--bd-bg-tertiary);color:var(--bd-text-primary);cursor:pointer;border-radius:8px;flex:1;padding:16px;font-size:15px;font-weight:500;transition:all .2s}.imagemap-option-btn:hover:not(:disabled){border-color:var(--bd-brand-primary);color:var(--bd-brand-primary)}.imagemap-option-btn:disabled{opacity:.6;cursor:not-allowed}.imagemap-label{color:var(--bd-text-secondary);margin-top:12px;margin-bottom:6px;font-size:13px;font-weight:600;display:block}.imagemap-select{border:1px solid var(--bd-border-default);background:var(--bd-bg-tertiary);width:100%;color:var(--bd-text-primary);border-radius:8px;margin-bottom:4px;padding:10px 12px;font-size:14px}.imagemap-textarea{border:1px solid var(--bd-border-default);background:var(--bd-bg-tertiary);width:100%;color:var(--bd-text-primary);resize:vertical;box-sizing:border-box;border-radius:8px;padding:10px 12px;font-family:inherit;font-size:14px}.imagemap-loading{color:var(--bd-text-muted);margin:4px 0;font-size:13px}.imagemap-form-actions{justify-content:flex-end;gap:12px;margin-top:16px;display:flex}.ideamap-back-btn{border:1px solid var(--bd-border-default);background:var(--bd-bg-tertiary);color:var(--bd-text-secondary);cursor:pointer;border-radius:8px;padding:8px 16px;font-size:14px;transition:all .2s}.ideamap-back-btn:hover{background:var(--bd-border-default)}.imagemap-result-text{white-space:pre-wrap;word-wrap:break-word;background:var(--bd-bg-tertiary);border:1px solid var(--bd-border-default);color:var(--bd-text-primary);border-radius:8px;max-height:300px;margin:0 0 16px;padding:16px;font-size:13px;overflow-y:auto}.imagemap-result-actions{gap:12px;margin-bottom:16px;display:flex}.llm-link-btn{border:1px solid var(--bd-border-default);background:var(--bd-bg-tertiary);color:var(--bd-text-primary);border-radius:8px;align-items:center;gap:6px;padding:10px 18px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.llm-link-btn:hover{border-color:var(--bd-brand-primary);color:var(--bd-brand-primary)}.application-section,.next-steps-section{background:var(--bd-bg-tertiary);border-left:4px solid var(--bd-brand-primary);border-radius:8px;margin-bottom:24px;padding:16px}.application-section h4,.next-steps-section h4{color:var(--bd-text-primary);margin-bottom:8px}.application-section p,.next-steps-section p{color:var(--bd-text-secondary);margin:0;line-height:1.6}.takeaways-list{flex-direction:column;gap:12px;display:flex}.takeaway-item{background:var(--bd-bg-tertiary);border-radius:8px;align-items:flex-start;gap:16px;padding:16px;display:flex}.takeaway-number{background:var(--bd-brand-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;font-weight:700;display:flex}.takeaway-text{color:var(--bd-text-secondary);margin:0;line-height:1.6}.quiz-container{flex-direction:column;gap:24px;display:flex}.quiz-question{background:var(--bd-bg-tertiary);border-radius:12px;padding:20px}.question-header{align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.question-number{background:var(--bd-brand-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.85rem;font-weight:700;display:flex}.question-text{color:var(--bd-text-primary);margin:0;padding-top:6px;font-size:1rem;line-height:1.5}.options-list{flex-direction:column;gap:8px;display:flex}.option-btn{border:2px solid var(--bd-border-default);background:var(--bd-bg-secondary);cursor:pointer;text-align:left;border-radius:8px;align-items:center;gap:12px;width:100%;padding:12px 16px;transition:all .2s;display:flex}.option-btn:hover:not(:disabled){border-color:var(--bd-brand-primary);background:#22c55e1a}.option-btn.correct{border-color:var(--bd-success);background:#22c55e26}.option-btn.incorrect{border-color:var(--bd-error);background:#ef444426}.option-btn:disabled{cursor:default}.option-key{background:var(--bd-bg-tertiary);width:28px;height:28px;color:var(--bd-text-secondary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;display:flex}.option-btn.correct .option-key{background:var(--bd-success);color:#fff}.option-btn.incorrect .option-key{background:var(--bd-error);color:#fff}.option-value{color:var(--bd-text-secondary);font-size:.95rem}.feedback{border-radius:8px;align-items:flex-start;gap:8px;margin-top:12px;padding:12px;font-size:.9rem;line-height:1.5;display:flex}.feedback.correct{color:var(--bd-success);background:#22c55e26}.feedback.incorrect{color:var(--bd-error);background:#ef444426}.feedback-icon{flex-shrink:0;font-size:1.1rem}.actions-list{flex-direction:column;gap:16px;display:flex}.action-item{background:var(--bd-bg-tertiary);border-radius:12px;overflow:hidden}.action-header{background:var(--bd-brand-primary);color:#fff;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.action-number{background:#ffffff4d;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:.85rem;font-weight:700;display:flex}.action-timeframe{background:#fff3;border-radius:20px;padding:4px 12px;font-size:.8rem}.action-content{padding:16px}.action-text{color:var(--bd-text-primary);margin:0 0 8px;font-size:.95rem;line-height:1.6}.action-outcome{color:var(--bd-text-secondary);margin:0;font-size:.9rem;line-height:1.5}.experts-list{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;display:grid}.expert-card{background:var(--bd-bg-tertiary);border:1px solid var(--bd-border-default);border-radius:12px;padding:20px}.expert-header{margin-bottom:8px}.expert-name{color:var(--bd-text-primary);margin:0;font-size:1.1rem}.expert-expertise{color:var(--bd-text-secondary);margin:0 0 12px;font-size:.9rem;line-height:1.5}.expert-resources h5{color:var(--bd-text-primary);margin:0 0 8px;font-size:.85rem}.resources-list{flex-direction:column;gap:8px;display:flex}.resource-link{background:var(--bd-bg-secondary);color:var(--bd-text-primary);border:1px solid var(--bd-border-default);border-radius:8px;align-items:center;gap:8px;padding:8px 12px;font-size:.85rem;text-decoration:none;transition:all .2s;display:flex}.resource-link:hover{border-color:var(--bd-brand-primary);color:var(--bd-brand-primary);transform:translate(4px)}.resource-icon{font-size:1.1rem}.resource-title{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.empty-message{text-align:center;color:var(--bd-text-muted);padding:40px 20px;font-size:1rem}@media (width<=768px){.chapter-tabs{gap:2px;padding:8px 12px}.chapter-tab{padding:8px 10px;font-size:.75rem}.chapter-tab-content{padding:16px}.experts-list{grid-template-columns:1fr}}.prompt-builder{background:var(--bd-bg-tertiary);border:1px solid var(--bd-border-default);border-radius:12px;margin-top:20px;padding:16px}.prompt-builder-title{color:var(--bd-text-primary);margin:0 0 16px;font-size:.95rem}.prompt-field{margin-bottom:12px}.prompt-field label{color:var(--bd-text-secondary);text-transform:uppercase;letter-spacing:.3px;align-items:center;gap:8px;margin-bottom:4px;font-size:.8rem;font-weight:600;display:flex}.prompt-input{border:1px solid var(--bd-border-default);background:var(--bd-bg-secondary);width:100%;color:var(--bd-text-primary);border-radius:6px;outline:none;padding:8px 12px;font-size:.85rem;transition:border-color .2s}.prompt-input:focus{border-color:var(--bd-brand-primary)}.prompt-textarea{border:1px solid var(--bd-border-default);resize:vertical;background:var(--bd-bg-secondary);width:100%;min-height:60px;max-height:120px;color:var(--bd-text-primary);border-radius:6px;outline:none;padding:8px 12px;font-family:inherit;font-size:.85rem;transition:border-color .2s}.prompt-textarea:focus{border-color:var(--bd-brand-primary)}.clear-keywords-btn{color:var(--bd-error);cursor:pointer;text-transform:lowercase;background:0 0;border:none;padding:0;font-size:.75rem}.clear-keywords-btn:hover{text-decoration:underline}.prompt-checkbox{margin-bottom:12px}.prompt-checkbox label{color:var(--bd-text-secondary);cursor:pointer;align-items:center;gap:8px;font-size:.85rem;display:flex}.prompt-checkbox input[type=checkbox]{cursor:pointer;width:16px;height:16px}.prompt-actions{gap:8px;display:flex}.llm-send-btn{cursor:pointer;border:none;border-radius:6px;flex:1;padding:8px 12px;font-size:.8rem;font-weight:600;transition:all .2s}.chatgpt-btn{color:#fff;background:#10a37f}.chatgpt-btn:hover{background:#0d8c6c}.grok-btn{color:#fff;background:#1d9bf0}.grok-btn:hover{background:#1a8cd8}.modal-backdrop{z-index:1000;background:#0009;justify-content:center;align-items:center;width:100%;height:100%;padding:20px;display:flex;position:fixed;top:0;left:0}.build-book-modal{background:var(--bd-bg-secondary);border-radius:16px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{border-bottom:1px solid var(--bd-border-default);justify-content:space-between;align-items:flex-start;padding:24px 24px 16px;display:flex}.modal-title-section{flex:1}.modal-title{color:var(--bd-text-primary);margin:0 0 4px;font-size:1.5rem}.modal-subtitle{color:var(--bd-text-secondary);margin:0;font-size:.9rem}.build-book-modal .modal-close-btn{background:var(--bd-bg-tertiary);cursor:pointer;width:36px;height:36px;color:var(--bd-text-secondary);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:20px;transition:all .2s;display:flex;position:static}.build-book-modal .modal-close-btn:hover{background:var(--bd-border-default);color:var(--bd-text-primary)}.modal-body{padding:24px}.auth-warning{border:1px solid var(--bd-warning);color:var(--bd-warning);background:#f59e0b26;border-radius:8px;margin-bottom:20px;padding:12px 16px;font-size:.9rem}.form-group{margin-bottom:20px}.form-label{color:var(--bd-text-primary);margin-bottom:6px;font-size:.9rem;font-weight:600;display:block}.required{color:var(--bd-error)}.optional-hint{color:var(--bd-text-muted);font-size:.85rem;font-weight:400}.form-input{border:1px solid var(--bd-border-default);background:var(--bd-bg-tertiary);width:100%;color:var(--bd-text-primary);border-radius:8px;outline:none;padding:10px 14px;font-size:.95rem;transition:border-color .2s}.form-input:focus{border-color:var(--bd-brand-primary);box-shadow:0 0 0 3px #22c55e26}.form-input:disabled{background:var(--bd-bg-primary);cursor:not-allowed}.form-hint{color:var(--bd-text-muted);margin:4px 0 0;font-size:.8rem}.modal-footer{border-top:1px solid var(--bd-border-default);justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.btn{cursor:pointer;border:none;border-radius:8px;padding:10px 24px;font-size:.95rem;font-weight:600;transition:all .2s}.btn-secondary{background:var(--bd-bg-tertiary);color:var(--bd-text-primary)}.btn-secondary:hover{background:var(--bd-border-default)}.btn-primary{background:var(--bd-brand-primary);color:#fff}.btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.build-error{color:var(--bd-error);background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;margin-bottom:16px;padding:12px 16px;font-size:.9rem}.build-progress{background:var(--bd-bg-tertiary);border:1px solid var(--bd-border-default);border-radius:10px;margin-top:20px;padding:16px}.progress-line{color:var(--bd-text-secondary);padding:4px 0;font-size:.85rem}.progress-spinner{border:3px solid var(--bd-border-default);border-top-color:var(--bd-brand-primary);border-radius:50%;width:20px;height:20px;margin-top:10px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.build-result{background:#22c55e1a;border:1px solid #22c55e4d;border-radius:10px;margin-top:20px;padding:16px}.result-header{color:var(--bd-success);margin-bottom:10px;font-size:1rem;font-weight:700}.result-stats{color:var(--bd-text-secondary);gap:16px;margin-bottom:12px;font-size:.85rem;display:flex}.result-agents{flex-wrap:wrap;gap:6px;margin-bottom:10px;display:flex}.agent-badge{border-radius:6px;padding:3px 8px;font-size:.75rem;font-weight:500}.agent-badge.success{color:var(--bd-success);background:#22c55e26}.agent-badge.failed{color:var(--bd-error);background:#ef444426}.result-folder{color:var(--bd-text-secondary);margin:8px 0 0;font-size:.85rem}.result-folder code{background:var(--bd-bg-tertiary);border-radius:4px;padding:2px 6px;font-size:.82rem}.build-accepted-text{color:#ccc;margin:12px 0}.build-accepted-hint{color:#aaa;margin:12px 0}.category-nav{padding:16px 0}.category-nav-title{text-transform:uppercase;letter-spacing:.1em;color:var(--bd-text-muted);margin:0 0 12px 16px;font-size:.75rem;font-weight:600}.category-list{margin:0;padding:0;list-style:none}.category-item{width:100%;color:var(--bd-text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:0;align-items:center;gap:12px;padding:12px 16px;font-size:.95rem;transition:background .2s,color .2s;display:flex}.category-item:hover{color:var(--bd-text-primary);background:#ffffff14}.category-item.active{color:var(--bd-brand-primary);border-left:3px solid var(--bd-brand-primary);background:#22c55e26;font-weight:600}.category-icon{text-align:center;width:24px;font-size:1.1rem}.category-label{white-space:nowrap}.author-dashboard{max-width:960px;color:var(--bd-text-primary);margin:0 auto;padding:2rem 1.5rem}.dashboard-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.dashboard-header h2{color:var(--bd-text-primary);margin:0;font-size:1.5rem}.create-book-btn{background:var(--bd-info);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:.6rem 1.2rem;font-size:.9rem;font-weight:500}.create-book-btn:hover{background:#2563eb}.auth-prompt{text-align:center;color:var(--bd-text-muted);padding:3rem}.profile-card{background:var(--bd-bg-secondary);border:1px solid var(--bd-border-default);border-radius:10px;align-items:flex-start;gap:1.5rem;margin-bottom:2rem;padding:1.5rem;display:flex}.profile-avatar img,.avatar-placeholder{object-fit:cover;border-radius:50%;width:72px;height:72px}.avatar-placeholder{background:var(--bd-info);color:#fff;justify-content:center;align-items:center;font-size:1.8rem;font-weight:600;display:flex}.profile-info{flex:1}.profile-info h3{color:var(--bd-text-primary);margin:0 0 .3rem;font-size:1.2rem}.profile-bio{color:var(--bd-text-secondary);margin:0 0 .5rem;font-size:.9rem}.edit-profile-btn{border:1px solid var(--bd-border-default);color:var(--bd-text-secondary);cursor:pointer;background:0 0;border-radius:4px;padding:.3rem .8rem;font-size:.8rem}.edit-profile-btn:hover{border-color:var(--bd-info);color:var(--bd-info)}.profile-edit-form{flex-direction:column;gap:.5rem;display:flex}.profile-input,.profile-textarea{border:1px solid var(--bd-border-default);background:var(--bd-bg-tertiary);color:var(--bd-text-primary);border-radius:4px;padding:.5rem;font-family:inherit;font-size:.9rem}.profile-input::placeholder,.profile-textarea::placeholder{color:var(--bd-text-muted)}.profile-textarea{resize:vertical}.profile-edit-actions{gap:.5rem;display:flex}.save-btn{background:var(--bd-info);color:#fff;cursor:pointer;border:none;border-radius:4px;padding:.4rem 1rem}.cancel-btn{border:1px solid var(--bd-border-default);color:var(--bd-text-secondary);cursor:pointer;background:0 0;border-radius:4px;padding:.4rem 1rem}.profile-stats{gap:2rem;margin-left:auto;display:flex}.stat{flex-direction:column;align-items:center;display:flex}.stat-value{color:var(--bd-info);font-size:1.5rem;font-weight:700}.stat-label{color:var(--bd-text-muted);text-transform:uppercase;font-size:.75rem}.books-section{margin-top:1rem}.books-section h3{color:var(--bd-text-primary);margin-bottom:1rem}.empty-state{text-align:center;color:var(--bd-text-muted);background:var(--bd-bg-secondary);border:1px solid var(--bd-border-default);border-radius:8px;padding:2rem}.empty-state p{margin-bottom:1rem}.books-table{border:1px solid var(--bd-border-default);border-radius:8px;overflow:hidden}.table-header,.table-row{grid-template-columns:2fr 1fr .8fr 1fr .8fr;align-items:center;padding:.7rem 1rem;font-size:.9rem;display:grid}.table-header{background:var(--bd-bg-secondary);text-transform:uppercase;color:var(--bd-text-muted);font-size:.8rem;font-weight:600}.table-row{border-top:1px solid var(--bd-border-default);color:var(--bd-text-primary)}.table-row:hover{background:var(--bd-bg-secondary)}.status-badge{color:#fff;text-transform:capitalize;border-radius:10px;padding:.15rem .5rem;font-size:.75rem;font-weight:500;display:inline-block}.action-btn{cursor:pointer;color:var(--bd-text-secondary);background:0 0;border:none;border-radius:4px;padding:.2rem .4rem;font-size:1rem}.action-btn:hover{background:var(--bd-bg-tertiary);color:var(--bd-text-primary)}.action-btn:disabled{opacity:.5;cursor:not-allowed}.publish-feedback{margin-left:.25rem;font-size:.75rem;display:inline-block}.publish-feedback.success{color:#5cb85c}.publish-feedback.error{color:#d9534f}.onboarding-overlay{z-index:10000;background:#0009;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.tour-tooltip{background:var(--bd-bg-secondary);border:1px solid var(--bd-border-default);border-radius:12px;width:90%;max-width:420px;padding:24px;animation:.3s slideUp;box-shadow:0 8px 32px #00000080}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.tour-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.tour-step-indicator{color:var(--bd-text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.tour-title{color:var(--bd-text-primary);margin:0 0 8px;font-size:1.2rem}.tour-content{color:var(--bd-text-secondary);margin:0 0 16px;font-size:.95rem;line-height:1.5}.tour-progress{justify-content:center;gap:6px;margin-bottom:16px;display:flex}.tour-dot{background:var(--bd-bg-tertiary);border-radius:50%;width:8px;height:8px;transition:background .2s}.tour-dot.active{background:var(--bd-brand-primary);transform:scale(1.2)}.tour-dot.completed{background:var(--bd-success)}.tour-actions{justify-content:flex-end;align-items:center;gap:8px;display:flex}.whats-new-panel{background:var(--bd-bg-secondary);border:1px solid var(--bd-border-default);border-radius:12px;width:90%;max-width:480px;padding:24px;animation:.3s slideUp;box-shadow:0 8px 32px #00000080}.whats-new-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.whats-new-header h2{color:var(--bd-text-primary);margin:0;font-size:1.3rem}.whats-new-list{flex-direction:column;gap:12px;margin-bottom:16px;display:flex}.whats-new-item{background:var(--bd-bg-tertiary);border-radius:8px;padding:12px 16px}.whats-new-item h3{color:var(--bd-text-primary);margin:0 0 4px;font-size:.95rem}.whats-new-item p{color:var(--bd-text-secondary);margin:0;font-size:.85rem;line-height:1.4}.whats-new-footer{justify-content:center;display:flex}.onboarding-close{color:var(--bd-text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;min-width:48px;min-height:48px;padding:4px 8px;font-size:1.4rem;line-height:1;display:flex}.onboarding-close:hover{color:var(--bd-text-primary);background:#ffffff1a}.onboarding-btn{cursor:pointer;border:none;border-radius:6px;min-width:48px;min-height:48px;padding:8px 20px;font-size:.9rem}.onboarding-btn.primary{background:var(--bd-brand-primary);color:var(--bd-text-primary)}.onboarding-btn.primary:hover{background:var(--bd-brand-hover)}.onboarding-btn.secondary{background:var(--bd-bg-tertiary);color:var(--bd-text-secondary)}.onboarding-btn.secondary:hover{background:var(--bd-bg-tertiary)}.onboarding-btn.link{color:var(--bd-text-muted);background:0 0;text-decoration:underline}.onboarding-btn.link:hover{color:var(--bd-text-secondary)}@media (width<=600px){.chapter-dropdown{background:var(--bd-bg-tertiary);border:1px solid var(--bd-border-default);width:100%;color:var(--bd-text-primary);border-radius:8px;margin-bottom:4px;padding:10px 8px;font-size:1rem}}@media (width<=480px){.app-header{padding:10px 6px}.header-content{flex-direction:column;gap:8px;padding:0 2px}.app-title{font-size:1.1rem}.book-id-input-group{flex-direction:column;gap:6px;max-width:100%}.book-id-input,.load-btn,.back-btn{border-radius:6px;padding:10px 12px;font-size:13px}.main-section,.right-section{min-width:0;padding:0}.app-body{gap:6px;padding:4px}.welcome-header h2{font-size:1.1rem}.welcome-header p{font-size:.95rem}.book-content,.home-library-section{border-radius:6px;padding:8px}}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{background:var(--bd-bg-primary);color:var(--bd-text-primary);box-shadow:var(--bd-shadow-lg);z-index:100;padding:16px 24px;position:sticky;top:0}.header-content{justify-content:space-between;align-items:center;gap:24px;max-width:1800px;margin:0 auto;display:flex}.app-title{white-space:nowrap;margin:0;font-size:1.5rem;font-weight:700}.site-icon{object-fit:contain;width:auto;height:40px}.welcome-logo{object-fit:contain;width:100%;max-width:400px;height:auto}.book-id-input-group{flex:1;gap:12px;max-width:700px;display:flex}.header-right{align-items:center;gap:16px;display:flex}.book-id-input{background:var(--bd-bg-tertiary);min-width:350px;color:var(--bd-text-primary);border:none;border-radius:8px;outline:none;flex:1;padding:12px 16px;font-size:14px;transition:box-shadow .2s}.book-id-input:focus{box-shadow:0 0 0 3px #22c55e66}.book-id-input::placeholder{color:var(--bd-text-muted)}.load-btn,.test-btn,.search-btn,.back-btn,.build-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:12px 24px;font-size:14px;font-weight:600;transition:all .2s}.load-btn{background:var(--bd-brand-primary);color:#fff}.load-btn:hover:not(:disabled){background:var(--bd-brand-hover)}.search-btn{background:var(--bd-info);color:#fff;padding:10px 16px;font-size:18px}.search-btn:hover{background:var(--bd-brand-hover)}.back-btn{background:var(--bd-bg-tertiary);color:#fff}.back-btn:hover{background:var(--bd-border-default)}.test-btn{background:var(--bd-success);color:#fff}.test-btn:hover:not(:disabled){background:var(--bd-brand-hover)}.build-btn{background:var(--bd-brand-primary);color:#fff}.build-btn:hover:not(:disabled){background:var(--bd-brand-hover);transform:translateY(-1px)}.load-btn:disabled,.test-btn:disabled,.build-btn:disabled{opacity:.6;cursor:not-allowed}.user-books-section{background:var(--bd-bg-secondary);border:1px solid var(--bd-border-default);border-radius:12px;margin-bottom:24px;padding:20px}.user-books-header{color:var(--bd-text-primary);margin:0 0 16px;font-size:1.3rem;font-weight:600}.user-books-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.library-body{background:var(--bd-bg-primary);flex:1;padding:20px;overflow-y:auto}.library-layout{flex:1;min-height:0;display:flex}.left-sidebar{background:var(--bd-bg-primary);width:240px;color:var(--bd-text-secondary);border-right:1px solid #ffffff0f;flex-direction:column;flex-shrink:0;display:flex;overflow-y:auto}.library-main{background:var(--bd-bg-primary);flex:1;min-width:0;padding:24px;overflow-y:auto}.welcome-banner{text-align:center;margin-bottom:24px}.welcome-banner>p{color:var(--bd-text-secondary);margin-top:12px;font-size:16px}.author-sidebar-section,.reader-sidebar-section{border-top:1px solid #ffffff0f;padding:16px}.sidebar-section-title{text-transform:uppercase;letter-spacing:.1em;color:var(--bd-text-muted);margin:0 0 8px;font-size:.75rem;font-weight:600}.sidebar-nav-btn{width:100%;color:var(--bd-text-secondary);text-align:left;cursor:pointer;background:0 0;border:none;border-radius:6px;margin-bottom:4px;padding:8px 12px;font-size:.88rem;transition:background .15s,color .15s;display:block}.sidebar-nav-btn:hover{color:var(--bd-text-primary);background:#ffffff14}.sidebar-nav-btn.active{color:var(--bd-brand-primary);background:#22c55e26;font-weight:600}.sidebar-info{color:var(--bd-text-muted);margin:0 0 12px;font-size:.85rem;line-height:1.4}.register-book-btn{background:var(--bd-brand-primary);color:#fff;cursor:pointer;border:none;border-radius:8px;width:100%;margin-top:8px;padding:10px 16px;font-size:.9rem;font-weight:600;transition:opacity .2s}.register-book-btn:hover:not(:disabled){opacity:.9}.register-book-btn:disabled{opacity:.5;cursor:not-allowed}.role-toggle{cursor:pointer;-webkit-user-select:none;user-select:none;background:#ffffff1a;border-radius:20px;align-items:center;gap:6px;padding:6px 14px;font-size:.85rem;transition:background .2s;display:flex}.role-toggle:hover{background:#ffffff2e}.role-option{color:#ffffff80;transition:color .2s}.role-option.active{color:#fff;font-weight:600}.role-divider{color:#ffffff4d}.app-body{flex:1;gap:20px;width:100%;max-width:1800px;margin:0 auto;padding:20px;display:flex}.main-section{flex:1;min-width:0;min-height:calc(100vh - 120px)}.right-section{flex:0 0 280px;width:280px;max-height:calc(100vh - 80px);position:sticky;top:80px;overflow-y:auto}.error-message{border:1px solid var(--bd-warning);color:var(--bd-warning);background:#f59e0b26;border-radius:8px;align-items:center;gap:12px;margin-bottom:20px;padding:16px 20px;display:flex}.error-icon{font-size:1.2rem}.loading-container{color:var(--bd-text-secondary);flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.loading-spinner{border:4px solid var(--bd-border-default);border-top-color:var(--bd-brand-primary);border-radius:50%;width:48px;height:48px;margin-bottom:16px;animation:1s linear infinite spin}.welcome-message{background:var(--bd-bg-secondary);text-align:center;box-shadow:var(--bd-shadow-md);border-radius:12px;padding:40px}.welcome-message h2{color:var(--bd-text-primary);margin-bottom:16px}.welcome-message>p{color:var(--bd-text-secondary);margin-bottom:24px;font-size:16px}.home-library-section{background:var(--bd-bg-secondary);box-shadow:var(--bd-shadow-md);border-radius:12px;padding:24px}.welcome-header{text-align:center;margin-bottom:24px}.welcome-header h2{color:var(--bd-text-primary);margin-bottom:8px}.welcome-header p{color:var(--bd-text-secondary);font-size:16px}.video-section{width:100%;padding:20px 0}.video-container{width:100%;height:0;padding-bottom:56.25%;position:relative;overflow:hidden}.video-container iframe{border:0;border-radius:8px;width:100%;height:100%;position:absolute;top:0;left:0}.book-content{background:var(--bd-bg-secondary);box-shadow:var(--bd-shadow-md);border-radius:12px;padding:24px}.book-title{color:var(--bd-text-primary);margin-bottom:8px;font-size:2rem}.book-author{color:var(--bd-text-secondary);margin-bottom:24px;font-size:1.1rem}.crossword-section{background:var(--bd-bg-tertiary);border-radius:8px;margin-top:24px;padding:20px}.crossword-layout{align-items:flex-start;gap:24px;display:flex}.crossword-image-container{flex:none;max-width:300px}.crossword-image-responsive{border-radius:8px;width:100%;height:auto;display:block}.crossword-info-container{flex:1;min-width:0}.crossword-info-container h3,.crossword-section h3{color:var(--bd-text-primary);margin:0 0 12px}.crossword-info{color:var(--bd-text-secondary);flex-direction:column;gap:8px;margin-bottom:16px;font-size:.9rem;display:flex}.open-puzzle-link-container{margin-bottom:12px}.open-puzzle-link{color:#fff;background-color:#007bff;border-radius:6px;padding:10px 20px;font-size:14px;font-weight:600;text-decoration:none;transition:background-color .2s;display:inline-block}.open-puzzle-link:hover{background-color:#0056b3}@media (width<=768px){.crossword-layout{flex-direction:column}.crossword-image-container{max-width:100%}}@media (width<=1200px){.header-content{flex-direction:column;gap:16px}.book-id-input-group{width:100%;max-width:100%}.right-section{flex:0 0 220px;width:220px}}@media (width<=768px){.app-body{flex-direction:column}.main-section{flex:1;max-width:100%}.right-section{flex:1;width:100%;max-width:100%;min-height:auto}}.app-footer{background-color:var(--bd-bg-secondary);border-top:1px solid var(--bd-border-default);text-align:center;margin-top:auto;padding:20px}.app-footer p{color:var(--bd-text-muted);margin:0;font-size:.9rem;line-height:1.6}.app-footer a{color:var(--bd-brand-primary);text-decoration:none;transition:color .2s}.app-footer a:hover{color:var(--bd-brand-hover);text-decoration:underline}@media (width<=600px){.app-footer{padding:15px 10px}.app-footer p{font-size:.85rem}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--bd-font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bd-bg-primary);color:var(--bd-text-primary);min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:focus-visible{outline:2px solid var(--bd-brand-primary);outline-offset:2px}button,[role=button],select,a{min-height:44px}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@media (prefers-contrast:high){.app{--border-color:#fff}button,.sidebar-nav-btn,.support-tab{border:1px solid #fff!important}.analytics-card,.support-panel,.faq-item,.ticket-row{border-color:#fff!important}}.skip-to-main{background:var(--bd-brand-primary);color:var(--bd-text-primary);z-index:100000;padding:8px 16px;transition:top .2s;position:absolute;top:-40px;left:0}.skip-to-main:focus{top:0}
