:root{--bg-primary:#f2efe8;--bg-surface:#f9f6f0;--bg-surface-hover:#ebe5d9;--bg-elevated:#f9f6f0;--border:#dedbd3;--border-light:#d4cfc4;--accent:#e0a206;--accent-hover:#f9b710;--accent-dim:#d6b45c;--accent-glow:#fbca5126;--text-primary:#1f242e;--text-secondary:#4c5567;--text-muted:#656e81;--text-dim:#818898}@media (prefers-color-scheme:dark){:root{--bg-primary:#14181f;--bg-surface:#1f242d;--bg-surface-hover:#262b36;--bg-elevated:#2a303c;--border:#303541;--border-light:#3d4452;--accent:#fbca51;--accent-hover:#fbd574;--accent-dim:#a38129;--accent-glow:#fbca5126;--text-primary:#e7e9ef;--text-secondary:#adb4c2;--text-muted:#7e889a;--text-dim:#575e6b}}:root{--correct:#47d181;--correct-bg:#47d1811a;--error:#e05252;--error-bg:#e052521a;--focus-ring:#4ca6ff;--font-reading:"Lora", Georgia, "Times New Roman", serif;--font-ui:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--fs-xs:.75rem;--fs-sm:.875rem;--fs-base:1rem;--fs-lg:1.125rem;--fs-xl:1.25rem;--fs-2xl:1.5rem;--fs-3xl:2rem;--fs-word:clamp(3.5rem, 5vw, 5.5rem);--fw-light:300;--fw-regular:400;--fw-medium:500;--fw-semibold:600;--fw-bold:700;--lh-tight:1.2;--lh-normal:1.5;--lh-relaxed:1.7;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #00000059;--shadow-lg:0 8px 32px #0006;--shadow-glow:0 0 20px var(--accent-glow);--transition-fast:.1s ease-out;--transition-base:.2s ease;--transition-slow:.4s ease;--transition-spring:.3s cubic-bezier(.34, 1.56, .64, 1)}*,: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(--font-ui);font-weight:var(--fw-regular);line-height:var(--lh-normal);color:var(--text-primary);background-color:var(--bg-primary);height:100vh;overflow:hidden}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(at 20%,#fbca5108 0%,#0000 60%),radial-gradient(at 80% 20%,#4ca6ff05 0%,#0000 50%);position:fixed;inset:0}#root{z-index:1;flex-direction:column;min-height:100vh;display:flex;position:relative}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}::selection{background:var(--accent);color:var(--bg-primary)}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes slideOut{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-16px)scale(.95)}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-3px)}80%{transform:translate(2px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes progressFill{0%{transform:scaleX(0)}}@keyframes greenFlash{0%{background-color:#0000}30%{background-color:var(--correct-bg)}to{background-color:#0000}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.btn{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);font-family:var(--font-ui);font-size:var(--fs-sm);font-weight:var(--fw-semibold);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;-webkit-user-select:none;user-select:none;border:1px solid #0000;line-height:1;text-decoration:none;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent);color:var(--bg-primary);border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);box-shadow:var(--shadow-glow)}.btn-secondary{background:var(--bg-surface);color:var(--text-primary);border-color:var(--border)}.btn-secondary:hover{background:var(--bg-surface-hover);border-color:var(--border-light)}.btn-ghost{color:var(--text-secondary);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--bg-surface);color:var(--text-primary)}.btn-lg{padding:var(--space-md) var(--space-xl);font-size:var(--fs-base);border-radius:var(--radius-lg)}.btn-icon{border-radius:var(--radius-md);width:40px;height:40px;padding:0}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-sm)}.card-elevated{background:var(--bg-elevated);box-shadow:var(--shadow-md)}.glass{-webkit-backdrop-filter:blur(20px);background:#1f242db3;border:1px solid #4149584d}.shortcuts-guide{justify-content:center;align-items:center;gap:var(--space-xl);padding:var(--space-xl) 0;opacity:.5;transition:opacity var(--transition-base);flex-wrap:wrap;margin-top:auto;display:flex}.shortcuts-guide:hover{opacity:1}.shortcut{align-items:center;gap:var(--space-sm);font-family:var(--font-ui);font-size:var(--fs-xs);color:var(--text-muted);display:flex}kbd{font-family:var(--font-ui);font-size:var(--fs-xs);color:var(--text-secondary);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:2px 6px;line-height:1.2;display:inline-block;box-shadow:0 1px 1px #0000004d}.app-container{width:100%;min-height:100vh;padding:0 var(--space-2xl);flex-direction:column;display:flex}.app-container.mobile{padding:0 var(--space-md)}.app-container.mobile-active{height:100dvh;position:fixed;inset:0;overflow:hidden}.app-container.mobile-active .header,.app-container.mobile-active .stats-bar,.app-container.mobile-active .progress-bar-label{display:none}.app-container.mobile-active .progress-bar-container{padding:var(--space-xs) 0;flex-shrink:0}.app-container.mobile-active .progress-bar-track-wrapper{border-radius:var(--radius-md);height:32px}.app-container.mobile-active .progress-bar-track-wrapper:hover{height:32px}.app-container.mobile-active .typing-echo-container{flex-shrink:0;order:1;margin-top:0;padding-bottom:0}.app-container.mobile-active .rsvp-zone{min-height:0;padding-top:var(--space-2xl);flex:1;order:2;align-items:flex-start;padding-bottom:0}.mobile-exit-btn{top:var(--space-sm);right:var(--space-sm);z-index:500;-webkit-backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:var(--radius-full);width:36px;height:36px;color:var(--text-muted);font-size:var(--fs-sm);cursor:pointer;transition:all var(--transition-base);background:#1f242dd9;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed}.mobile-exit-btn:hover,.mobile-exit-btn:active{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-light)}.app-container.mobile-active>div[style]{display:none!important}@media (width<=768px){body{overflow:auto}.typing-echo-container{height:50px;margin:var(--space-sm) 0}.typing-echo,.typing-echo-char{font-size:var(--fs-lg)}}.header{padding:var(--space-lg) 0;border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;animation:.4s fadeInDown;display:flex;position:relative}.header-left{gap:var(--space-xs);flex-direction:column;display:flex}.header-brand-container{align-items:center;gap:var(--space-sm);display:flex}.header-brand-logo{border-radius:var(--radius-sm);object-fit:contain;width:auto;height:36px}.header-brand{font-family:var(--font-reading);font-size:var(--fs-xl);font-weight:var(--fw-bold);color:var(--accent);letter-spacing:-.02em}.header-book-title{font-family:var(--font-reading);font-size:var(--fs-lg);font-weight:var(--fw-medium);color:var(--text-primary)}.header-chapter{font-size:var(--fs-sm);color:var(--text-muted);font-weight:var(--fw-regular)}.header-right{align-items:center;gap:var(--space-sm);display:flex}.auth-overlay{-webkit-backdrop-filter:blur(24px);z-index:1000;background:#08090dbf;justify-content:center;align-items:center;animation:.25s fadeIn;display:flex;position:fixed;inset:0}.auth-modal{border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(40px);background:#1d212b8c;border:1px solid #5973a61f;width:100%;max-width:420px;padding:2.5rem 2.25rem 2rem;animation:.42s cubic-bezier(.34,1.44,.64,1) glassSlideIn;position:relative;overflow:hidden;box-shadow:0 0 0 1px #5973a60f,0 24px 64px #0000008c,0 4px 16px #0000004d,inset 0 1px #ffffff0f}.auth-modal:before{content:"";background:linear-gradient(90deg,#0000 0%,#fbca5159 40%,#4ca6ff33 70%,#0000 100%);height:1px;position:absolute;top:0;left:0;right:0}.auth-modal:after{content:"";pointer-events:none;z-index:0;background:radial-gradient(at 20% 0,#fbca510d 0%,#0000 60%),radial-gradient(at 80% 100%,#4ca6ff0a 0%,#0000 50%);position:absolute;inset:0}.auth-header{z-index:1;margin-bottom:var(--space-xl);justify-content:space-between;align-items:flex-start;display:flex;position:relative}.auth-header-text{gap:var(--space-xs);flex-direction:column;display:flex}.auth-eyebrow{align-items:center;gap:var(--space-xs);font-size:var(--fs-xs);font-weight:var(--fw-semibold);letter-spacing:.1em;text-transform:uppercase;color:var(--accent);opacity:.9;display:inline-flex}.auth-eyebrow-dot{background:var(--accent);width:6px;height:6px;box-shadow:0 0 8px var(--accent);border-radius:50%;animation:2s infinite pulse}.auth-header h2{font-family:var(--font-reading);font-size:1.75rem;font-weight:var(--fw-bold);color:var(--text-primary);letter-spacing:-.02em;line-height:var(--lh-tight);margin:0}.btn-close{z-index:1;border-radius:var(--radius-md);width:32px;height:32px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-base);background:#29303d99;border:1px solid #525f7a40;flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;font-size:.9rem;display:flex;position:relative}.btn-close:hover{color:var(--text-primary);background:#394356cc;border-color:#66779959}.auth-form{z-index:1;gap:var(--space-md);flex-direction:column;display:flex;position:relative}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{font-size:var(--fs-xs);font-weight:var(--fw-semibold);letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.auth-input{border-radius:var(--radius-md);padding:.7rem var(--space-md);color:var(--text-primary);font-family:var(--font-ui);font-size:var(--fs-base);transition:border-color var(--transition-base), box-shadow var(--transition-base), background var(--transition-base);background:#14181f80;border:1px solid #47536b33}.auth-input::placeholder{color:var(--text-dim)}.auth-input:focus{background:#181d25b3;border-color:#fbca5173;outline:none;box-shadow:0 0 0 3px #fbca5114,0 1px 4px #0000004d}.auth-error{align-items:center;gap:var(--space-sm);color:var(--error);font-size:var(--fs-sm);background:var(--error-bg);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:1px solid #e0525233;animation:.2s fadeInUp;display:flex}.auth-submit{margin-top:var(--space-sm);width:100%;padding:var(--space-md) var(--space-xl);font-size:var(--fs-base);border-radius:var(--radius-lg);background:linear-gradient(135deg, var(--accent), #fcd983);color:var(--bg-primary);transition:all var(--transition-base);border-color:#0000;position:relative;overflow:hidden;box-shadow:0 4px 20px #fbca5159}.auth-submit:hover{transform:translateY(-1px);box-shadow:0 8px 28px #fbca5173}.auth-submit:after{content:"";pointer-events:none;background:linear-gradient(#ffffff1f 0%,#0000 100%);position:absolute;inset:0}.auth-footer{z-index:1;margin-top:var(--space-lg);text-align:center;padding-top:var(--space-md);border-top:1px solid #47536b26;position:relative}.auth-footer .btn-ghost{font-size:var(--fs-sm);color:var(--text-muted);transition:color var(--transition-base)}.auth-footer .btn-ghost:hover{color:var(--accent);background:0 0}.auth-user{align-items:center;gap:var(--space-md);display:flex}.auth-email{font-size:var(--fs-sm);color:var(--text-secondary)}@keyframes glassSlideIn{0%{opacity:0;filter:blur(4px);transform:translateY(16px)scale(.97)}to{opacity:1;filter:blur();transform:translateY(0)scale(1)}}.btn-sm{padding:var(--space-xs) var(--space-sm);font-size:var(--fs-sm)}.progress-bar-container{width:100%;padding:var(--space-md) 0 var(--space-sm);animation:.5s fadeIn}.progress-bar-label{margin-bottom:var(--space-xs);font-size:var(--fs-xs);color:var(--text-muted);font-weight:var(--fw-medium);text-transform:uppercase;letter-spacing:.05em;justify-content:space-between;align-items:center;display:flex}.progress-bar-track-wrapper{background:var(--surface);border-radius:var(--radius-md);height:24px;margin-top:var(--space-xs);position:relative;overflow:hidden}.progress-bar-sparkline{pointer-events:none;z-index:1;width:100%;height:100%;position:absolute;top:0;left:0}.progress-bar-slider{opacity:0;cursor:pointer;z-index:10;width:100%;height:100%;position:absolute;top:0;left:0}.progress-bar-fill-overlay{background:var(--accent);border-radius:var(--radius-md);z-index:5;pointer-events:none;opacity:.15;height:100%;transition:width .3s cubic-bezier(.4,0,.2,1);position:absolute;top:0;left:0}.progress-bar-sparkline path{filter:drop-shadow(0 0 2px var(--accent))}.progress-bar-track-wrapper:hover{height:28px}.sparkline-wrapper{cursor:crosshair;width:100%;height:100%;position:relative}.sparkline-svg{width:100%;height:100%;position:absolute;top:0;left:0;overflow:visible}.sparkline-hover-line{pointer-events:none;background-color:#6c799366;width:1px;position:absolute;top:0;bottom:0}.sparkline-hover-dot{width:10px;height:10px;box-shadow:0 0 0 3px var(--bg-surface,#fff);pointer-events:none;z-index:2;border-radius:50%;position:absolute;transform:translate(-50%,-50%)}.sparkline-tooltip{-webkit-backdrop-filter:blur(10px);color:var(--text-primary,#fff);border-radius:var(--radius-sm,6px);white-space:nowrap;pointer-events:none;z-index:3;box-shadow:var(--shadow-sm);background:#1f242de6;border:1px solid #41495866;padding:4px 8px;font-size:.75rem;font-weight:500;transition:top .1s,left .1s;position:absolute}.rsvp-zone{min-height:200px;padding:var(--space-2xl) 0;flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.rsvp-orp-marker{pointer-events:none;z-index:0;width:1px;position:absolute;top:0;bottom:0;left:50%}.rsvp-orp-marker:before,.rsvp-orp-marker:after{content:"";background:var(--accent-dim);opacity:.5;width:1px;height:10px;position:absolute;left:0}.rsvp-orp-marker:before{top:12px}.rsvp-orp-marker:after{bottom:12px}.rsvp-context-row{z-index:1;width:100%;font-size:var(--fs-word);align-items:center;height:2.5em;line-height:1;display:flex;position:relative}.rsvp-context-row.shake{animation:.3s shake}.rsvp-half{align-items:center;width:50%;height:100%;display:flex;overflow:hidden}.rsvp-half-left{justify-content:flex-end;padding-right:0}.rsvp-half-right{justify-content:flex-start;padding-left:0}.rsvp-word-orp{font-family:var(--font-reading);font-weight:var(--fw-bold);color:var(--accent);-webkit-user-select:none;user-select:none;white-space:pre;flex-shrink:0;line-height:1}.rsvp-word-rest{font-family:var(--font-reading);font-weight:var(--fw-medium);color:var(--text-primary);letter-spacing:.02em;-webkit-user-select:none;user-select:none;white-space:pre;flex-shrink:0;line-height:1}.rsvp-punctuation{color:var(--text-muted);font-weight:var(--fw-regular)}.rsvp-context{flex-shrink:1;align-items:center;gap:.35em;min-width:0;height:100%;display:flex;overflow:hidden}.rsvp-context-prev{justify-content:flex-end;margin-right:.35em}.rsvp-context-next{justify-content:flex-start;margin-left:.35em}.rsvp-context-word{font-family:var(--font-reading);font-weight:var(--fw-regular);white-space:nowrap;-webkit-user-select:none;user-select:none;line-height:1;transition:opacity .12s}.rsvp-context-word.rsvp-context-1{color:var(--text-muted);opacity:.5}.rsvp-context-word.rsvp-context-2{color:var(--text-dim);opacity:.3}.rsvp-context-word.rsvp-context-3{color:var(--text-dim);opacity:.15;filter:blur(.5px)}.rsvp-context-word.rsvp-context-4{color:var(--text-dim);opacity:.08;filter:blur(1px)}.rsvp-context-word.rsvp-context-5{color:var(--text-dim);opacity:.04;filter:blur(1.5px)}.rsvp-idle{align-items:center;gap:var(--space-lg);flex-direction:column;animation:.6s fadeIn;display:flex}.rsvp-idle-prompt{font-family:var(--font-reading);font-size:var(--fs-2xl);color:var(--text-secondary);text-align:center;font-style:italic}.rsvp-idle-hint{font-size:var(--fs-sm);color:var(--text-dim);animation:2s ease-in-out infinite pulse}.rsvp-paused-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-lg);z-index:10;background:#14181fd9;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:absolute;inset:0}.rsvp-paused-text{font-family:var(--font-ui);font-size:var(--fs-xl);color:var(--text-muted);font-weight:var(--fw-semibold);letter-spacing:.1em;text-transform:uppercase}.mobile-hidden-input{opacity:0;pointer-events:none;z-index:-1;border:none;width:1px;height:1px;margin:0;padding:0;position:absolute;top:0;left:0}@media (width<=768px){.rsvp-zone{min-height:100px;padding:var(--space-md) 0}.rsvp-context-row{height:2em;font-size:clamp(1.8rem,8vw,2.8rem)}.rsvp-context-word.rsvp-context-1{opacity:.7}.rsvp-context-word.rsvp-context-2{opacity:.45}.rsvp-context-word.rsvp-context-3,.rsvp-context-word.rsvp-context-4,.rsvp-context-word.rsvp-context-5{display:none}.rsvp-idle-prompt{font-size:var(--fs-lg)}.rsvp-idle-hint{font-size:var(--fs-xs)}}.typing-echo-container{height:80px;margin:var(--space-md) 0;justify-content:center;align-items:center;display:flex}.typing-echo{font-family:var(--font-reading);font-size:var(--fs-2xl);font-weight:var(--fw-regular);letter-spacing:.04em;align-items:center;gap:1px;min-width:2ch;display:inline-flex;position:relative}.typing-echo-char{white-space:pre;transition:color var(--transition-fast);display:inline-block}.typing-echo-char.correct{color:var(--correct)}.typing-echo-char.error{color:var(--error);text-underline-offset:4px;-webkit-text-decoration:underline wavy;text-decoration:underline wavy}.typing-echo-cursor{background:var(--accent);border-radius:var(--radius-full);vertical-align:middle;width:2px;height:1.2em;margin-left:1px;animation:.8s ease-in-out infinite pulse;display:inline-block}.typing-echo-placeholder{color:var(--text-dim);font-size:var(--fs-sm);font-family:var(--font-ui);font-style:italic}.typing-echo-flash{border-radius:var(--radius-md);padding:var(--space-xs) var(--space-sm);animation:.4s greenFlash}.typing-echo-space-hint{color:var(--accent);font-size:var(--fs-lg);font-weight:var(--fw-semibold);vertical-align:middle;opacity:.8;margin-left:4px;animation:.6s ease-in-out infinite pulse;display:inline-block}.stats-bar{justify-content:center;align-items:center;gap:var(--space-2xl);padding:var(--space-md) 0;border-top:1px solid var(--border);flex-wrap:wrap;animation:.4s .2s both fadeInUp;display:flex}.stat-item{align-items:baseline;gap:var(--space-sm);transition:all var(--transition-base);flex-direction:row;display:flex}.stat-value{font-family:var(--font-ui);font-size:var(--fs-lg);font-weight:var(--fw-bold);color:var(--text-primary);transition:color var(--transition-fast);line-height:1}.stat-value.highlight{color:var(--accent)}.stat-label{font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.stat-value.bumped{animation:.2s scaleIn}@media (width<=480px){.stats-bar{gap:var(--space-md);justify-content:space-around}}.results-overlay{-webkit-backdrop-filter:blur(24px);z-index:100;background:#08090dbf;justify-content:center;align-items:center;animation:.25s fadeIn;display:flex;position:fixed;inset:0}.results-modal{border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(40px);background:#1d212b8c;border:1px solid #5973a61f;flex-direction:row;gap:0;width:100%;max-width:820px;animation:.42s cubic-bezier(.34,1.44,.64,1) glassSlideIn;display:flex;position:relative;overflow:hidden;box-shadow:0 0 0 1px #5973a60f,0 24px 64px #0000008c,0 4px 16px #0000004d,inset 0 1px #ffffff0f}.results-modal:before{content:"";background:linear-gradient(90deg,#0000 0%,#fbca514d 40%,#4ca6ff33 70%,#0000 100%);height:1px;position:absolute;top:0;left:0;right:0}.results-modal:after{content:"";pointer-events:none;z-index:0;background:radial-gradient(at 15%,#fbca510a 0%,#0000 55%),radial-gradient(at 85% 20%,#4ca6ff0a 0%,#0000 50%);position:absolute;inset:0}.results-left{z-index:1;border-right:1px solid #5973a61a;flex-direction:column;flex:0 0 52%;justify-content:center;padding:3rem 2.5rem 3rem 3rem;display:flex;position:relative}.results-right{z-index:1;justify-content:center;gap:var(--space-md);flex-direction:column;flex:0 0 48%;padding:3rem 3rem 3rem 2.5rem;display:flex;position:relative}.results-header{margin-bottom:var(--space-xl)}.results-eyebrow{align-items:center;gap:var(--space-xs);font-size:var(--fs-xs);font-weight:var(--fw-semibold);letter-spacing:.1em;text-transform:uppercase;color:var(--accent);opacity:.9;margin-bottom:var(--space-sm);display:inline-flex}.results-eyebrow-dot{background:var(--accent);width:6px;height:6px;box-shadow:0 0 8px var(--accent);border-radius:50%;animation:2s infinite pulse}.results-title{font-family:var(--font-reading);font-size:2.25rem;font-weight:var(--fw-bold);color:var(--text-primary);line-height:var(--lh-tight);margin-bottom:var(--space-sm);letter-spacing:-.02em}.results-subtitle{font-size:var(--fs-sm);color:var(--text-muted);line-height:var(--lh-relaxed);max-width:28ch}.results-book-progress{margin-bottom:var(--space-2xl)}.results-book-progress-label{font-size:var(--fs-xs);color:var(--text-muted);margin-bottom:var(--space-xs);justify-content:space-between;display:flex}.results-book-progress-label span:last-child{color:var(--accent);font-weight:var(--fw-semibold)}.results-book-progress-track{border-radius:var(--radius-full);background:#3d475c80;height:4px;overflow:hidden}.results-book-progress-fill{border-radius:var(--radius-full);background:linear-gradient(90deg, var(--accent-dim), var(--accent));height:100%;box-shadow:0 0 8px var(--accent-glow);animation:.8s cubic-bezier(.22,1,.36,1) both progressFill}.results-actions{gap:var(--space-sm);flex-direction:column;display:flex}.results-actions .btn-primary{padding:var(--space-md) var(--space-xl);font-size:var(--fs-base);border-radius:var(--radius-lg);background:linear-gradient(135deg, var(--accent), #fcd983);transition:all var(--transition-base);border-color:#0000;position:relative;overflow:hidden;box-shadow:0 4px 20px #fbca5159}.results-actions .btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 28px #fbca5173}.results-actions .btn-primary:after{content:"";pointer-events:none;background:linear-gradient(#ffffff1f 0%,#0000 100%);position:absolute;inset:0}.results-secondary-actions{gap:var(--space-sm);display:flex}.results-secondary-actions .btn{padding:var(--space-sm) var(--space-md);font-size:var(--fs-sm);border-radius:var(--radius-md);flex:1}.results-secondary-actions .btn-secondary{color:var(--text-secondary);transition:all var(--transition-base);background:#29303d99;border-color:#525f7a4d}.results-secondary-actions .btn-secondary:hover{color:var(--text-primary);background:#333c4dcc;border-color:#6796}.results-secondary-actions .btn-ghost{color:var(--text-muted);transition:all var(--transition-base);background:0 0;border-color:#0000}.results-secondary-actions .btn-ghost:hover{color:var(--text-secondary);background:#29303d66}.results-stats-label{font-size:var(--fs-xs);font-weight:var(--fw-semibold);letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim);margin-bottom:var(--space-sm)}.results-stats{gap:var(--space-sm);grid-template-columns:1fr 1fr;display:grid}.results-stat{padding:var(--space-md) var(--space-md);border-radius:var(--radius-lg);transition:border-color var(--transition-base);background:#14181f80;border:1px solid #47536b26;flex-direction:column;gap:4px;animation:.4s both fadeInUp;display:flex}.results-stat:hover{border-color:#66779940}.results-stat:first-child{animation-delay:80ms}.results-stat:nth-child(2){animation-delay:.14s}.results-stat:nth-child(3){animation-delay:.2s}.results-stat:nth-child(4){animation-delay:.26s}.results-stat-value{font-size:var(--fs-2xl);font-weight:var(--fw-bold);color:var(--text-primary);letter-spacing:-.02em;line-height:1}.results-stat-value.accent{color:var(--accent)}.results-stat-value.success{color:var(--correct)}.results-stat-label{font-size:var(--fs-xs);font-weight:var(--fw-medium);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.results-gauge-section{align-items:center;gap:var(--space-lg);padding:var(--space-md);border-radius:var(--radius-lg);background:#14181f80;border:1px solid #47536b26;animation:.4s .3s both fadeInUp;display:flex}.results-gauge{flex-shrink:0;width:88px;height:88px;position:relative}.results-gauge svg{width:100%;height:100%;transform:rotate(-90deg)}.results-gauge-track{fill:none;stroke:#3d475c80;stroke-width:7px}.results-gauge-fill{fill:none;stroke:var(--correct);stroke-width:7px;stroke-linecap:round;filter:drop-shadow(0 0 4px #47d18180);transition:stroke-dashoffset 1.2s cubic-bezier(.22,1,.36,1)}.results-gauge-text{flex-direction:column;justify-content:center;align-items:center;gap:1px;display:flex;position:absolute;inset:0}.results-gauge-pct{font-size:var(--fs-lg);font-weight:var(--fw-bold);color:var(--text-primary);line-height:1}.results-gauge-sub{font-size:9px;font-weight:var(--fw-semibold);letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted)}.results-gauge-detail{flex:1}.results-gauge-detail-title{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-primary);margin-bottom:2px}.results-gauge-detail-sub{font-size:var(--fs-xs);color:var(--text-muted)}.results-words{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:#14181f66;border:1px solid #47536b1f;justify-content:space-between;align-items:center;animation:.4s .36s both fadeInUp;display:flex}.results-words-label{font-size:var(--fs-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:var(--fw-semibold)}.results-words-value{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-secondary)}.book-selector-page.split-layout{background:var(--bg-primary);flex-direction:row;justify-content:flex-start;align-items:stretch;animation:.5s fadeIn;display:flex;position:fixed;inset:0;overflow:hidden}.sidebar{background:var(--bg-surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:320px;height:100%;display:flex}.sidebar-header{padding:var(--space-2xl) var(--space-xl) var(--space-xl);border-bottom:1px solid var(--border)}.brand-container{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xs);display:flex}.sidebar-header .brand-logo{border-radius:var(--radius-sm);object-fit:contain;width:auto;height:36px}.sidebar-header .brand{font-family:var(--font-reading);font-size:var(--fs-3xl);font-weight:var(--fw-bold);color:var(--accent);letter-spacing:-.02em}.sidebar-header .tagline{font-size:var(--fs-sm);color:var(--text-muted);font-family:var(--font-reading);margin-bottom:var(--space-md);font-style:italic}.sidebar-search{width:100%;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-ui);font-size:var(--fs-sm)}.sidebar-search:focus{border-color:var(--accent);outline:none}.sidebar-content{padding:var(--space-xl);gap:var(--space-xl);flex-direction:column;flex:1;min-height:0;display:flex}.sidebar-section{gap:var(--space-sm);flex-direction:column;display:flex}.section-title{font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--space-xs)}.sidebar-list{flex:1;min-height:0}.saved-books-list{flex-direction:column;gap:4px;max-height:40vh;display:flex;overflow-y:auto}.sidebar-item{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-base);background:0 0;border:1px solid #0000;justify-content:space-between;align-items:center;display:flex}.sidebar-item:hover{background:var(--bg-surface-hover);transform:translateY(-2px)}.sidebar-item:active{transform:translateY(0)scale(.98)}.sidebar-item.active{background:var(--accent-glow);border-color:var(--accent-dim)}.sidebar-list:hover .sidebar-item:not(:hover),.sidebar-list-container:hover .sidebar-item:not(:hover){opacity:.4}.sidebar-item .item-info{flex:1;min-width:0}.sidebar-item .item-title{font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sidebar-item .item-meta{font-size:var(--fs-xs);color:var(--text-muted);margin-top:2px}.sidebar-item .item-delete{color:var(--text-dim);cursor:pointer;border-radius:var(--radius-sm);font-size:var(--fs-sm);opacity:0;transition:opacity var(--transition-fast), color var(--transition-fast);background:0 0;border:none;padding:4px}.sidebar-item:hover .item-delete{opacity:1}.sidebar-item .item-delete:hover{color:var(--error)}.main-pane{padding:var(--space-xl);background:var(--bg-primary);flex-direction:column;flex:1;justify-content:center;align-items:center;min-height:0;display:flex;position:relative;overflow:hidden}.landing-hero{text-align:center;max-width:600px;animation:slideUp var(--transition-slow);flex-direction:column;justify-content:center;align-items:center;display:flex}.landing-brand-container{justify-content:center;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-lg);flex-direction:column;display:flex}.landing-logo{border-radius:var(--radius-md);object-fit:contain;width:auto;height:350px}.landing-title{font-family:var(--font-reading);font-size:clamp(3rem,6vw,5rem);font-weight:var(--fw-bold);color:var(--text-primary);letter-spacing:-.02em;background:linear-gradient(135deg, var(--text-primary) 0%, var(--accent) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text}.landing-subtitle{font-family:var(--font-ui);font-size:var(--fs-lg);line-height:var(--lh-relaxed);color:var(--text-secondary);margin-bottom:var(--space-2xl)}.landing-subtitle strong{color:var(--text-primary);font-weight:var(--fw-semibold)}.landing-instruction{font-family:var(--font-ui);font-size:var(--fs-sm);color:var(--accent);text-transform:uppercase;letter-spacing:.1em;font-weight:var(--fw-semibold);animation:2s infinite pulse}.active-book-detail{width:100%;animation:slideUp var(--transition-slow)}.book-hero{max-width:700px;margin:0 auto var(--space-xl)}.book-title{font-family:var(--font-reading);font-size:clamp(2rem,4vw,3.5rem);font-weight:var(--fw-bold);color:var(--text-primary);margin-bottom:var(--space-sm);line-height:var(--lh-tight)}.book-author{font-size:var(--fs-lg);color:var(--accent);font-family:var(--font-ui)}.book-chapters{font-size:var(--fs-sm);color:var(--text-muted);font-family:var(--font-ui);margin-top:var(--space-xs)}.book-synopsis{max-width:700px;margin:0 auto var(--space-xl);font-family:var(--font-reading);font-size:var(--fs-base);line-height:var(--lh-relaxed);color:var(--text-secondary);border-left:4px solid var(--border-light);padding-left:var(--space-lg)}.book-actions{flex-direction:column;align-items:center;width:100%;display:flex}.start-reading-btn{bottom:var(--space-2xl);right:var(--space-2xl);z-index:100;font-size:var(--fs-base);padding:.75rem 1.5rem;animation:.5s fadeIn;position:absolute}.typing-prompt{padding:var(--space-md) 0;background:0 0;border:none;width:100%}.typing-prompt-hint{font-size:var(--fs-sm);color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--space-lg);text-align:center}.shortcuts-guide.home-footer{bottom:var(--space-md);pointer-events:none;width:100%;margin:0;padding:0;position:absolute;left:50%;transform:translate(-50%)}.typing-prompt-words{font-family:var(--font-reading);font-size:var(--fs-2xl);line-height:var(--lh-relaxed);flex-wrap:wrap;justify-content:center;gap:0;display:flex}.prompt-word{color:var(--text-muted);transition:color var(--transition-fast)}.prompt-word.past{color:var(--text-primary);opacity:.5}.prompt-word.current{color:var(--text-primary)}.prompt-word.current span{transition:color 50ms}.prompt-word.current .correct{color:var(--correct)}.prompt-word.current .incorrect{color:var(--error);text-decoration:underline;-webkit-text-decoration-color:var(--error);text-decoration-color:var(--error)}.prompt-space{width:.5em;display:inline-block}.prompt-space.current{position:relative}.prompt-space.current:after{content:"";background-color:var(--accent);width:100%;height:2px;animation:1s infinite pulse;position:absolute;bottom:0;left:0}.error-message{color:var(--error);background:var(--error-bg);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);margin-bottom:var(--space-lg);font-size:var(--fs-sm)}.transition-out{opacity:0;pointer-events:none;transition:opacity .5s,transform .5s;transform:scale(1.02)}@media (width<=768px){.book-selector-page.split-layout{flex-direction:column;height:100%;min-height:100dvh;position:relative;overflow:hidden auto}.main-pane{width:100%;min-height:auto;padding:var(--space-xl) var(--space-md) var(--space-md);order:1;justify-content:flex-start;align-items:flex-start;overflow:visible}.sidebar{border-right:none;border-top:1px solid var(--border);order:2;width:100%;height:auto}.sidebar-header{padding:var(--space-lg) var(--space-md)}.sidebar-content{padding:var(--space-md) var(--space-md) 120px}.landing-hero{text-align:left;max-width:100%;padding-top:var(--space-lg);align-items:flex-start}.landing-title{font-size:clamp(2.5rem,10vw,4rem)}.landing-subtitle{font-size:var(--fs-base)}.active-book-detail{width:100%}.book-hero{margin-bottom:var(--space-md)}.book-title{font-size:clamp(1.6rem,7vw,2.5rem)}.main-pane>div[style]{top:var(--space-sm);right:var(--space-sm)}.start-reading-btn{bottom:var(--space-lg);width:calc(100% - var(--space-2xl));text-align:center;z-index:200;justify-content:center;max-width:400px;position:fixed;left:50%;right:auto;transform:translate(-50%);box-shadow:0 4px 24px #fbca5140}.shortcuts-guide.home-footer,.typing-prompt.rsvp-style{display:none}.sidebar-item .item-delete{opacity:.6}.book-stats-preview{flex-wrap:wrap}.sidebar-list-container{min-height:500px}}@keyframes mobileWarnFadeIn{0%{opacity:0}to{opacity:1}}@keyframes mobileWarnSlideUp{0%{opacity:0;transform:translateY(28px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes mobileIconFloat{0%,to{transform:translateY(0)rotate(-2deg)}50%{transform:translateY(-8px)rotate(2deg)}}.mobile-warning-overlay{z-index:9999;padding:var(--space-lg);-webkit-backdrop-filter:blur(6px);background:radial-gradient(at 30% 20%,#fbca510f 0%,#0000 55%),radial-gradient(at 80% 80%,#4ca6ff0a 0%,#0000 50%),#0c0e12f5;justify-content:center;align-items:center;animation:.4s both mobileWarnFadeIn;display:flex;position:fixed;inset:0}.mobile-warning-card{width:100%;max-width:400px;padding:var(--space-2xl) var(--space-xl);text-align:center;border-radius:var(--radius-xl);background:var(--bg-surface);box-shadow:var(--shadow-lg), 0 0 0 1px #fbca5114, inset 0 1px 0 #ffffff0a;border:1px solid #41495880;animation:.5s cubic-bezier(.34,1.56,.64,1) .2s both mobileWarnSlideUp;position:relative}.mobile-warning-card:before{content:"";background:linear-gradient(90deg, transparent, var(--accent), transparent);border-radius:var(--radius-full);width:60%;height:1px;position:absolute;top:0;left:50%;transform:translate(-50%)}.mobile-warning-icon{margin-bottom:var(--space-lg);filter:drop-shadow(0 0 12px #fbca5166);font-size:3rem;animation:3.5s ease-in-out infinite mobileIconFloat;display:inline-block}.mobile-warning-title{font-family:var(--font-ui);font-size:var(--fs-xl);font-weight:var(--fw-bold);color:var(--text-primary);margin-bottom:var(--space-sm);letter-spacing:-.02em}.mobile-warning-title span{color:var(--accent)}.mobile-warning-body{font-family:var(--font-ui);font-size:var(--fs-sm);color:var(--text-secondary);line-height:var(--lh-relaxed);margin-bottom:var(--space-xl)}.mobile-warning-features{gap:var(--space-sm);margin-bottom:var(--space-xl);text-align:left;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);flex-direction:column;display:flex}.mobile-warning-feature{align-items:center;gap:var(--space-sm);font-size:var(--fs-xs);color:var(--text-muted);display:flex}.mobile-warning-feature-icon{opacity:.8;flex-shrink:0;font-size:.85rem}.mobile-warning-actions{gap:var(--space-sm);flex-direction:column;display:flex}.btn-mobile-proceed{width:100%;padding:var(--space-md) var(--space-lg);font-size:var(--fs-sm);font-weight:var(--fw-semibold);font-family:var(--font-ui);border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-muted);cursor:pointer;transition:all var(--transition-base);letter-spacing:.01em}.btn-mobile-proceed:hover{background:var(--bg-surface-hover);color:var(--text-secondary);border-color:var(--border-light)}.btn-mobile-proceed:active{transform:scale(.98)}.admin-page{background:var(--bg-primary);z-index:1;flex-direction:row;align-items:stretch;animation:.4s fadeIn;display:flex;position:fixed;inset:0;overflow:hidden}.admin-sidebar{-webkit-backdrop-filter:blur(24px);background:#1f242da6;border-right:1px solid #4149584d;flex-direction:column;flex-shrink:0;width:280px;height:100%;display:flex;box-shadow:inset 0 1px #ffffff0a}.admin-sidebar-header{padding:var(--space-xl) var(--space-lg) var(--space-lg);border-bottom:1px solid var(--border);gap:var(--space-md);flex-direction:column;display:flex}.admin-sidebar-header h2{font-family:var(--font-reading);font-size:var(--fs-xl);font-weight:var(--fw-bold);color:var(--accent);letter-spacing:-.02em;margin:0}.admin-sidebar-search{width:100%;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text-primary);font-family:var(--font-ui);font-size:var(--fs-sm);transition:border-color var(--transition-base), box-shadow var(--transition-base), background var(--transition-base);background:#14181f80}.admin-sidebar-search::placeholder{color:var(--text-dim)}.admin-sidebar-search:focus{background:#181d25b3;border-color:#fbca5173;outline:none;box-shadow:0 0 0 3px #fbca5114}.admin-add-book-btn{justify-content:center;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-sm) var(--space-md);font-family:var(--font-ui);font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--accent);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-base);background:#fbca510f;border:1px dashed #fbca5140;display:flex}.admin-add-book-btn:hover{background:#fbca511f;border-color:#fbca5173;box-shadow:0 0 12px #fbca5114}.admin-add-book-btn:active{transform:scale(.97)}.admin-brand-row{align-items:center;gap:var(--space-sm);display:flex}.admin-brand{font-family:var(--font-reading);font-size:var(--fs-xl);font-weight:var(--fw-bold);color:var(--accent);letter-spacing:-.02em;margin:0}.admin-tagline{font-size:var(--fs-xs);color:var(--text-muted);margin:0}.admin-sidebar-nav{padding:var(--space-sm) var(--space-sm) 0;gap:2px;display:flex}.admin-nav-btn{padding:var(--space-sm) var(--space-md);font-family:var(--font-ui);font-size:var(--fs-xs);font-weight:var(--fw-medium);color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-base);text-align:center;background:0 0;border:1px solid #0000;flex:1}.admin-nav-btn:hover{color:var(--text-primary);background:var(--bg-surface-hover)}.admin-nav-btn.active{color:var(--accent);background:var(--accent-glow);border-color:var(--accent-dim)}.admin-sidebar>.admin-sidebar-search,.admin-sidebar>.admin-add-book-btn{margin:var(--space-sm) var(--space-sm) 0;width:calc(100% - var(--space-md))}.admin-login-header{margin-bottom:var(--space-lg)}.admin-eyebrow{align-items:center;gap:var(--space-sm);font-size:var(--fs-xs);font-weight:var(--fw-semibold);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:var(--space-sm);display:flex}.admin-eyebrow-dot{background:var(--accent);border-radius:50%;width:8px;height:8px;animation:2s infinite pulse}.admin-login-subtitle{font-size:var(--fs-sm);color:var(--text-muted);margin-top:var(--space-xs)}.admin-login-error{align-items:center;gap:var(--space-sm);color:var(--error);font-size:var(--fs-sm);background:var(--error-bg);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:1px solid #e0525233;animation:.4s shake;display:flex}.admin-login-submit{margin-top:var(--space-sm);width:100%}.admin-editor-header{justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.admin-editor-header h2{font-family:var(--font-reading);font-size:var(--fs-2xl);font-weight:var(--fw-bold);color:var(--text-primary);margin:0}.admin-editor-fields{gap:var(--space-lg);flex-direction:column;display:flex}.admin-field-row{gap:var(--space-md);display:flex}.admin-field-row>.admin-field{flex:1}.admin-field-hint{font-weight:var(--fw-regular);text-transform:none;letter-spacing:normal;color:var(--text-dim);font-size:var(--fs-xs);margin-top:2px;display:block}.admin-meta-chip{align-items:center;gap:var(--space-xs);font-size:var(--fs-xs);font-weight:var(--fw-medium);color:var(--text-secondary);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-full);padding:3px 10px;display:inline-flex}.admin-loading-state{justify-content:center;align-items:center;gap:var(--space-md);padding:var(--space-3xl);color:var(--text-muted);flex-direction:column;flex:1;animation:.3s fadeIn;display:flex}.admin-loading-state .admin-spinner{border-width:3px;width:32px;height:32px}.admin-empty-list{padding:var(--space-lg) var(--space-md);text-align:center;font-size:var(--fs-sm);color:var(--text-dim)}.admin-empty-icon{margin-bottom:var(--space-md);font-size:3rem;animation:3s infinite float}.admin-section-title{font-size:var(--fs-sm);font-weight:var(--fw-semibold);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:0}.admin-script-info{flex:1}.admin-script-name{font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--text-primary)}.admin-script-desc{font-size:var(--fs-xs);color:var(--text-muted);margin-top:2px}.admin-script-list{gap:var(--space-sm);flex-direction:column;display:flex}.admin-book-list{min-height:0;padding:var(--space-md) var(--space-sm);flex:1}.admin-book-item{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-base), border-color var(--transition-base), box-shadow var(--transition-base);background:0 0;border:1px solid #0000;border-left-width:3px;justify-content:space-between;align-items:center;display:flex}.admin-book-item:hover{background:var(--bg-surface-hover)}.admin-book-item.active{background:var(--accent-glow);border-left-color:var(--accent);border-color:var(--accent-dim);border-left-color:var(--accent)}.admin-book-item.is-disabled{opacity:.45;filter:grayscale(80%)}.admin-book-item.is-disabled:hover{opacity:.7}.admin-book-item.is-disabled.active{opacity:.9;filter:grayscale(40%)}.admin-book-item .book-item-title{font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;line-height:var(--lh-tight);overflow:hidden}.admin-book-item .book-item-author{font-size:var(--fs-xs);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;overflow:hidden}.admin-book-item.active .book-item-title{color:var(--accent)}.admin-main{background:var(--bg-primary);flex-direction:column;flex:1;min-height:0;display:flex;position:relative;overflow-y:auto}.admin-header-actions{z-index:10;justify-content:flex-end;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);background:#14181fcc;display:flex;position:sticky;top:0}.admin-editor{width:100%;max-width:800px;padding:var(--space-2xl) var(--space-xl);gap:var(--space-lg);flex-direction:column;margin:0 auto;animation:.35s fadeInUp;display:flex}.admin-field{flex-direction:column;gap:6px;display:flex}.admin-field label{font-size:var(--fs-xs);font-weight:var(--fw-semibold);letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.admin-field input,.admin-field textarea{border-radius:var(--radius-md);padding:.7rem var(--space-md);color:var(--text-primary);font-family:var(--font-ui);font-size:var(--fs-base);transition:border-color var(--transition-base), box-shadow var(--transition-base), background var(--transition-base);background:#14181f80;border:1px solid #47536b33}.admin-field input::placeholder,.admin-field textarea::placeholder{color:var(--text-dim)}.admin-field input:focus,.admin-field textarea:focus{background:#181d25b3;border-color:#fbca5173;outline:none;box-shadow:0 0 0 3px #fbca5114,0 1px 4px #0000004d}.admin-field textarea{resize:vertical;min-height:100px;line-height:var(--lh-relaxed)}textarea.admin-text-editor{font-family:JetBrains Mono,Fira Code,Cascadia Code,SF Mono,Consolas,monospace;font-size:var(--fs-sm);line-height:var(--lh-relaxed);border-radius:var(--radius-md);min-height:65vh;padding:var(--space-md);color:var(--text-primary);resize:vertical;tab-size:4;transition:border-color var(--transition-base), box-shadow var(--transition-slow), background var(--transition-base);background:#10131899;border:1px solid #47536b33}textarea.admin-text-editor::placeholder{color:var(--text-dim)}textarea.admin-text-editor:focus{background:#12151ccc;border-color:#fbca5159;outline:none;box-shadow:0 0 0 3px #fbca510f,inset 0 0 30px #fbca5108,0 2px 8px #0000004d}.admin-meta-row{align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.admin-meta-row .admin-field{flex:1;min-width:180px}.admin-actions{align-items:center;gap:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border);display:flex}.admin-delete-btn{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);font-family:var(--font-ui);font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--error);background:var(--error-bg);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);border:1px solid #e0525233;margin-left:auto;line-height:1;display:inline-flex}.admin-delete-btn:hover{background:#e0525233;border-color:#e0525266;box-shadow:0 0 12px #e052521a}.admin-delete-btn:active{transform:scale(.97)}.admin-empty-state{text-align:center;padding:var(--space-3xl);color:var(--text-muted);flex-direction:column;flex:1;justify-content:center;align-items:center;animation:.5s fadeIn;display:flex}.admin-empty-state h3{font-family:var(--font-reading);font-size:var(--fs-2xl);font-weight:var(--fw-bold);color:var(--text-secondary);margin-bottom:var(--space-sm)}.admin-empty-state p{font-size:var(--fs-sm);color:var(--text-muted);max-width:320px;line-height:var(--lh-relaxed)}.admin-login-overlay{-webkit-backdrop-filter:blur(24px);z-index:1000;background:#08090dcc;justify-content:center;align-items:center;animation:.25s fadeIn;display:flex;position:fixed;inset:0}.admin-login-modal{border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(40px);width:100%;max-width:400px;padding:var(--space-2xl);background:#1d212b8c;border:1px solid #5973a61f;animation:.35s cubic-bezier(.34,1.56,.64,1) scaleIn;position:relative;overflow:hidden;box-shadow:0 0 0 1px #5973a60f,0 24px 64px #0000008c,0 4px 16px #0000004d,inset 0 1px #ffffff0f}.admin-login-modal:before{content:"";background:linear-gradient(90deg,#0000 0%,#fbca5159 40%,#4ca6ff33 70%,#0000 100%);height:1px;position:absolute;top:0;left:0;right:0}.admin-login-modal h2{font-family:var(--font-reading);font-size:var(--fs-2xl);font-weight:var(--fw-bold);color:var(--text-primary);margin-bottom:var(--space-xl);letter-spacing:-.02em}.admin-login-form{gap:var(--space-md);flex-direction:column;display:flex}.admin-login-form input{border-radius:var(--radius-md);padding:.7rem var(--space-md);color:var(--text-primary);font-family:var(--font-ui);font-size:var(--fs-base);transition:border-color var(--transition-base), box-shadow var(--transition-base), background var(--transition-base);background:#14181f80;border:1px solid #47536b33}.admin-login-form input::placeholder{color:var(--text-dim)}.admin-login-form input:focus{background:#181d25b3;border-color:#fbca5173;outline:none;box-shadow:0 0 0 3px #fbca5114,0 1px 4px #0000004d}.admin-login-form .auth-error{align-items:center;gap:var(--space-sm);color:var(--error);font-size:var(--fs-sm);background:var(--error-bg);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:1px solid #e0525233;animation:.4s shake;display:flex}.admin-toast{bottom:var(--space-xl);right:var(--space-xl);z-index:2000;min-width:280px;max-width:420px;padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);font-family:var(--font-ui);font-size:var(--fs-sm);font-weight:var(--fw-medium);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-light);pointer-events:auto;background:#262b36d9;animation:.35s cubic-bezier(.34,1.56,.64,1) toastSlideIn;position:fixed;box-shadow:0 8px 32px #0006,0 2px 8px #0003}.admin-toast.toast-success{color:var(--correct);border-left:3px solid var(--correct);background:#15281dd9}.admin-toast.toast-error{color:var(--error);border-left:3px solid var(--error);background:#281515d9}.admin-toast.toast-exit{animation:.3s forwards toastSlideOut}@keyframes toastSlideIn{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes toastSlideOut{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(10px)scale(.95)}}.admin-scripts-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);gap:var(--space-lg);flex-direction:column;width:100%;max-width:800px;margin:0 auto;animation:.3s fadeInUp;display:flex}.admin-scripts-header{gap:var(--space-xs);border-bottom:1px solid var(--border);padding-bottom:var(--space-md);flex-direction:column;display:flex}.admin-scripts-header .admin-section-title{margin:0}.admin-section-subtitle{font-size:var(--fs-sm);color:var(--text-dim);margin:0}.admin-script-target-selector{gap:var(--space-sm);padding:var(--space-md);border-radius:var(--radius-md);border:1px dashed var(--border-light);background:#14181f4d;flex-direction:column;display:flex}.admin-script-target-selector h4{font-size:var(--fs-xs);font-weight:var(--fw-semibold);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:0 0 var(--space-xs) 0}.admin-radio-group{gap:var(--space-lg);display:flex}.admin-radio{align-items:center;gap:var(--space-xs);font-size:var(--fs-sm);color:var(--text-secondary);cursor:pointer;transition:color var(--transition-base);display:flex}.admin-radio:hover{color:var(--text-primary)}.admin-radio input{accent-color:var(--accent);cursor:pointer}.admin-target-list{margin-top:var(--space-sm);border:1px solid var(--border);border-radius:var(--radius-sm);background:#10131899;flex-direction:column;gap:2px;max-height:240px;padding:2px;display:flex;overflow-y:auto}.admin-target-item{align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-base);display:flex}.admin-target-item:hover{background:var(--bg-surface-hover)}.admin-target-item.is-disabled{opacity:.45;filter:grayscale(80%)}.admin-target-item.is-disabled:hover{opacity:.7}.admin-target-item input{accent-color:var(--accent);cursor:pointer}.admin-target-info{flex-direction:column;display:flex}.admin-target-title{font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--text-primary)}.admin-target-author{font-size:var(--fs-xs);color:var(--text-muted)}.admin-script-item{justify-content:space-between;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color var(--transition-base);background:#14181f66;display:flex}.admin-script-item:hover{border-color:var(--border-light)}.admin-script-item span{font-size:var(--fs-sm);color:var(--text-secondary);font-weight:var(--fw-medium)}.admin-script-output{font-family:JetBrains Mono,Fira Code,Cascadia Code,SF Mono,Consolas,monospace;font-size:var(--fs-xs);line-height:var(--lh-relaxed);color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--space-md);white-space:pre-wrap;word-break:break-word;background:#10131899;max-height:240px;overflow-y:auto}.admin-badge{align-items:center;gap:var(--space-xs);font-family:var(--font-ui);font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius-full);white-space:nowrap;background:#2a303c99;padding:2px 8px;line-height:1.5;display:inline-flex}.admin-spinner{border:2px solid #41495866;border-top-color:var(--accent);border-radius:50%;width:18px;height:18px;animation:.6s linear infinite adminSpin;display:inline-block}.admin-spinner.spinner-lg{border-width:3px;width:32px;height:32px}@keyframes adminSpin{to{transform:rotate(360deg)}}.admin-recipe-builder{gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);border:1px dashed var(--border-light);background:#14181f4d;flex-direction:column;display:flex}.admin-recipe-builder h4{font-size:var(--fs-xs);font-weight:var(--fw-semibold);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:0}.admin-recipe-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.admin-recipe-group{gap:var(--space-xs);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);border:1px solid var(--border);background:#181d2580;flex-direction:column;display:flex}.admin-recipe-group h5{font-size:var(--fs-xs);font-weight:var(--fw-medium);color:var(--accent);margin:0 0 var(--space-xs) 0;border-bottom:1px solid var(--border-light);padding-bottom:4px}.admin-recipe-item{align-items:center;gap:var(--space-xs);font-size:var(--fs-sm);color:var(--text-secondary);cursor:pointer;transition:color var(--transition-base);display:flex}.admin-recipe-item:hover{color:var(--text-primary)}.admin-recipe-item input{accent-color:var(--accent);cursor:pointer}@media (width<=900px){.admin-page{flex-direction:column}.admin-sidebar{border-right:none;border-bottom:1px solid var(--border);width:100%;height:auto;max-height:40vh}.admin-editor{padding:var(--space-xl) var(--space-md)}.admin-meta-row{flex-direction:column}.admin-meta-row .admin-field{min-width:0}.admin-toast{left:var(--space-md);right:var(--space-md);bottom:var(--space-md);min-width:0}}.profile-dashboard{width:100vw;height:100vh;color:var(--text-primary);z-index:100;background-color:#0000;flex-direction:column;display:flex;position:absolute;top:0;left:0;overflow-y:auto}.profile-header{padding:var(--space-md) var(--space-xl);-webkit-backdrop-filter:blur(20px);z-index:10;background-color:#1f242d99;border-bottom:1px solid #41495833;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.profile-header h1{margin:0;font-size:1.5rem;font-weight:600}.profile-content{padding:var(--space-xl);width:100%;max-width:1200px;margin:0 auto}.profile-alert{align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);margin-bottom:var(--space-xl);-webkit-backdrop-filter:blur(20px);box-shadow:var(--shadow-md);background:#1f242d99;border:1px solid #4149584d;font-weight:500;animation:.4s cubic-bezier(.34,1.56,.64,1) slideDown;display:flex}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.profile-alert-icon{flex-shrink:0;justify-content:center;align-items:center;display:flex}.profile-alert-text{flex-grow:1}.profile-alert-close{color:inherit;opacity:.6;cursor:pointer;padding:var(--space-xs);transition:opacity var(--transition-base);background:0 0;border:none;justify-content:center;align-items:center;font-size:1.1rem;display:flex}.profile-alert-close:hover{opacity:1}.profile-alert.error{border-left:4px solid var(--error);color:#f28c8c}.profile-alert.error .profile-alert-icon{color:var(--error)}.profile-alert.success{border-left:4px solid var(--correct);color:#99e6b9}.profile-alert.success .profile-alert-icon{color:var(--correct)}.profile-grid{gap:var(--space-xl);grid-template-columns:1fr 2fr;display:grid}.profile-section{-webkit-backdrop-filter:blur(16px);box-shadow:var(--shadow-md);border-radius:var(--radius-xl);padding:var(--space-xl);background:#1f242d66;border:1px solid #41495833}.profile-section h2{margin-top:0;margin-bottom:var(--space-lg);color:var(--accent);padding-bottom:var(--space-sm);border-bottom:1px solid #41495833;font-size:1.25rem;font-weight:600}.profile-section h3{margin-top:0;margin-bottom:var(--space-sm);font-size:1rem;font-weight:500}.mt-xl{margin-top:var(--space-xl)!important}.account-info{margin-bottom:var(--space-xl);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);background:#1f242d80;border:1px solid #41495833;box-shadow:inset 0 2px 4px #0000001a}.account-info p{margin:0 0 var(--space-sm) 0}.verification-status{align-items:center;gap:var(--space-md);font-size:.9rem;display:flex}.verified{color:#4dff88;font-weight:600}.unverified{color:#fa0;font-weight:600}.profile-form{margin-bottom:var(--space-xl)}.profile-form .form-group{margin-bottom:var(--space-md)}.profile-form input{border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:all var(--transition-base);background:#15181e80;border:1px solid #4149584d;padding:.85rem 1.2rem;font-size:1rem}.profile-form input:focus{border-color:var(--accent);outline:none}.logout-container{margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid #41495833}.logout-btn{color:#ff4d4d;width:100%}.logout-btn:hover{color:#ff4d4d;background-color:#ff3c3c1a}.global-stats-grid{gap:var(--space-md);margin-bottom:var(--space-xl);grid-template-columns:repeat(3,1fr);display:grid}.stat-card{padding:var(--space-xl) var(--space-lg);border-radius:var(--radius-lg);text-align:center;transition:transform var(--transition-base), box-shadow var(--transition-base);background:#1f242d80;border:1px solid #41495833;box-shadow:inset 0 2px 4px #0000001a}.stat-card:hover{box-shadow:var(--shadow-sm), inset 0 2px 4px #0000001a;border-color:#5761754d;transform:translateY(-2px)}.stat-value{color:var(--accent);margin-bottom:var(--space-xs);font-size:2rem;font-weight:700}.stat-value small{opacity:.8;font-size:1rem;font-weight:500}.stat-label{text-transform:uppercase;letter-spacing:.05em;opacity:.7;font-size:.85rem}.no-books-msg{opacity:.7;font-style:italic}.book-stats-list{gap:var(--space-md);flex-direction:column;display:flex}.book-stat-item{border-radius:var(--radius-lg);padding:var(--space-xl);transition:transform var(--transition-base), box-shadow var(--transition-base);background:#1f242d80;border:1px solid #41495833}.book-stat-item:hover{box-shadow:var(--shadow-sm);border-color:#5761754d;transform:translateY(-2px)}.book-stat-header{margin-bottom:var(--space-md);padding-bottom:var(--space-md);border-bottom:1px solid #41495833;justify-content:space-between;align-items:center;display:flex}.book-stat-header h3{color:var(--text-primary);margin:0;font-size:1.25rem;font-weight:600}.book-stat-progress-container{align-items:flex-end;gap:var(--space-xs);flex-direction:column;display:flex}.book-stat-progress{opacity:.8;background-color:#3f485a4d;border-radius:1rem;padding:.25rem .75rem;font-size:.9rem}.profile-book-progress-bar{border-radius:var(--radius-full);background:#4149584d;width:100%;height:4px;margin-top:4px;overflow:hidden}.profile-book-progress-fill{background:var(--accent);border-radius:var(--radius-full);height:100%;transition:width var(--transition-slow)}.book-stat-details{gap:var(--space-lg);grid-template-columns:1fr 2fr;display:grid}.book-stat-metrics{gap:var(--space-sm);flex-direction:column;font-size:.95rem;display:flex}.book-stat-metrics strong{opacity:.7;margin-right:.5rem}.book-stat-graph{flex-direction:column;display:flex}.graph-label{text-transform:uppercase;letter-spacing:.05em;opacity:.6;margin-bottom:var(--space-sm);font-size:.8rem}.profile-sparkline{width:100%;height:60px;margin-top:auto}@media (width<=768px){.profile-grid,.global-stats-grid,.book-stat-details{grid-template-columns:1fr}}.how-it-works-page{background-color:var(--bg-primary);height:100vh;color:var(--text-primary);flex-direction:column;display:flex;position:relative;overflow-y:auto}.how-it-works-page:before{content:"";z-index:0;pointer-events:none;background:radial-gradient(circle at 15%,#fbca5114,#0000 25%),radial-gradient(circle at 85% 30%,#5189fb0d,#0000 25%);width:100%;height:100%;position:fixed;top:0;left:0}.how-it-works-header{padding:var(--space-md) var(--space-xl);-webkit-backdrop-filter:blur(24px);z-index:10;background:#14181f99;border-bottom:1px solid #3d475c66;align-items:center;display:flex;position:sticky;top:0;box-shadow:0 4px 30px #0000001a}.how-it-works-brand-container{align-items:center;gap:var(--space-sm);display:flex;position:absolute;left:50%;transform:translate(-50%)}.how-it-works-brand-logo{border-radius:var(--radius-sm);object-fit:contain;width:auto;height:36px}.how-it-works-brand{color:var(--text-primary);font-size:1.5rem;font-weight:700;font-family:var(--font-reading);margin:0}.how-it-works-content{width:100%;max-width:1400px;padding:var(--space-3xl) var(--space-2xl);z-index:1;flex:1;margin:0 auto;position:relative}.blog-post{-webkit-backdrop-filter:blur(16px);padding:var(--space-3xl);border-radius:var(--radius-xl);background:#1f242d66;border:1px solid #525f7a33;box-shadow:0 8px 32px #0003}.post-title{margin-bottom:var(--space-sm);background:linear-gradient(135deg,#fff 0%,#a0a5b0 100%);-webkit-text-fill-color:transparent;color:#0000;letter-spacing:-.03em;-webkit-background-clip:text;background-clip:text;font-size:3.5rem;font-weight:800;line-height:1.1}.post-meta{color:var(--accent);margin-bottom:var(--space-3xl);font-size:1.25rem;font-weight:500;line-height:1.6}.post-grid{gap:var(--space-3xl);margin-top:var(--space-2xl);grid-template-columns:repeat(auto-fit,minmax(450px,1fr));display:grid}.post-section h2{margin-bottom:var(--space-lg);color:var(--text-primary);align-items:center;gap:var(--space-sm);font-size:1.75rem;font-weight:700;display:flex}.post-section h2:before{content:"";background:var(--accent);width:12px;height:12px;box-shadow:0 0 10px var(--accent-glow);border-radius:50%;display:block}.post-section p{color:var(--text-secondary);margin-bottom:var(--space-lg);font-size:1.15rem;line-height:1.8}.post-section ul{margin-bottom:var(--space-lg);padding-left:0;list-style-type:none}.post-section li{color:var(--text-secondary);margin-bottom:var(--space-md);padding-left:var(--space-xl);font-size:1.15rem;line-height:1.8;position:relative}.post-section li:before{content:"✦";color:var(--accent);position:absolute;top:0;left:0}.post-section strong{color:var(--text-primary);font-weight:600}.keyboard-shortcut{border-radius:var(--radius-lg);color:var(--text-primary);background:#15181e80;border:1px solid #525f7a33;align-items:center;gap:.75rem;margin-bottom:.5rem;padding:.75rem 1.25rem;font-size:1.1rem;display:inline-flex}.keyboard-shortcut kbd{font-weight:700;font-family:var(--font-ui);color:#fff;letter-spacing:.05em;text-transform:uppercase;background:linear-gradient(#343c4bcc 0%,#1f242dcc 100%);border:1px solid #525f7a80;border-radius:6px;padding:.3rem .6rem;font-size:.85rem;transform:translateY(-2px);box-shadow:0 4px #15181e,0 5px 10px #0000004d}.getting-started-section{text-align:center;max-width:800px;margin:0 auto}.getting-started-section h2{justify-content:center}.getting-started-section h2:before{display:none}.cta-container{margin-top:var(--space-2xl);justify-content:center;display:flex}@media (width<=768px){.how-it-works-content{padding:var(--space-xl) var(--space-md)}.post-grid{gap:var(--space-2xl);grid-template-columns:1fr}.how-it-works-header{padding:var(--space-md)}.blog-post{padding:var(--space-xl) var(--space-lg);border-radius:var(--radius-lg)}.post-title{font-size:2.2rem}}.settings-overlay{-webkit-backdrop-filter:blur(8px);z-index:1000;padding:var(--space-md);animation:fadeIn var(--transition-base);background:#0a0c0f99;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.settings-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:480px;max-height:90vh;animation:slideUp var(--transition-spring);flex-direction:column;display:flex;overflow-y:auto}.settings-header{padding:var(--space-lg);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.settings-title{font-size:var(--fs-xl);font-weight:var(--fw-bold);margin:0}.settings-close-btn{color:var(--text-muted);font-size:var(--fs-lg);cursor:pointer;padding:var(--space-xs);border-radius:var(--radius-sm);transition:all var(--transition-base);background:0 0;border:none}.settings-close-btn:hover{color:var(--text-primary);background:var(--bg-surface-hover)}.settings-body{padding:var(--space-lg);gap:var(--space-xl);flex-direction:column;display:flex}.setting-group{gap:var(--space-sm);flex-direction:column;display:flex}.setting-label{font-weight:var(--fw-semibold);font-size:var(--fs-base);color:var(--text-primary);justify-content:space-between;align-items:center;display:flex}.setting-description{font-size:var(--fs-sm);color:var(--text-muted);margin-bottom:var(--space-xs)}.setting-control{gap:var(--space-sm);display:flex}.setting-select,.setting-input{width:100%;padding:var(--space-sm);background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);font-family:var(--font-ui);font-size:var(--fs-sm)}.setting-select:focus,.setting-input:focus{outline:2px solid var(--focus-ring);border-color:#0000}.setting-range{width:100%;accent-color:var(--accent)}.toggle-switch{width:44px;height:24px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background-color:var(--bg-primary);border:1px solid var(--border);border-radius:24px;transition:all .3s;position:absolute;inset:0}.toggle-slider:before{content:"";background-color:var(--text-muted);border-radius:50%;width:18px;height:18px;transition:all .3s;position:absolute;bottom:2px;left:2px}input:checked+.toggle-slider{background-color:var(--accent);border-color:var(--accent)}input:focus+.toggle-slider{box-shadow:0 0 1px var(--accent)}input:checked+.toggle-slider:before{background-color:var(--bg-primary);transform:translate(20px)}
