@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--color-bg:#f5f0e8;--color-surface:#fff;--color-surface-2:#f0ebe0;--color-surface-hover:#ede7da;--color-border:#e2d9cc;--color-border-light:#ede8df;--color-text:#1a1a1a;--color-text-muted:#6b6461;--color-text-subtle:#a09890;--color-primary:#7c5cbf;--color-primary-dark:#6248a8;--color-primary-light:#7c5cbf1a;--color-primary-glow:#7c5cbf2e;--color-teal:#2bbfb0;--color-teal-light:#2bbfb01f;--color-coral:#e8694a;--color-coral-light:#e8694a1f;--color-green:#4caf88;--color-green-light:#4caf881f;--color-success:#4caf88;--color-danger:#e8694a;--radius:14px;--radius-sm:8px;--radius-lg:22px;--shadow:0 2px 12px #00000012, 0 1px 4px #0000000a;--shadow-sm:0 1px 4px #0000000f;--shadow-md:0 4px 24px #00000017, 0 2px 8px #0000000d;--shadow-lg:0 8px 40px #0000001f, 0 4px 12px #0000000f;--shadow-purple:0 4px 20px #7c5cbf40;--font-sans:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-serif:Georgia, "Times New Roman", serif;--max-width:1140px;font-family:var(--font-sans);color:var(--color-text);background:var(--color-bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0}#root{flex-direction:column;display:flex}h1,h2,h3{color:var(--color-text);letter-spacing:-.025em;font-weight:800;line-height:1.2}h1{margin:0 0 .5rem;font-size:2rem}h2{letter-spacing:-.02em;margin:0 0 .4rem;font-size:1.4rem}h3{letter-spacing:-.01em;margin:0 0 .35rem;font-size:1.05rem;font-weight:700}p{margin:0}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;display:block}button{font-family:inherit}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 24px}.page{flex:1;padding:40px 0 80px}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow)}.btn{border-radius:var(--radius-sm);cursor:pointer;letter-spacing:.005em;border:1.5px solid #0000;justify-content:center;align-items:center;gap:8px;padding:10px 22px;font-family:inherit;font-size:.9rem;font-weight:600;line-height:1.2;text-decoration:none;transition:background .18s,color .18s,border-color .18s,box-shadow .18s,transform .14s;display:inline-flex}.btn:disabled{opacity:.42;cursor:not-allowed}.btn:not(:disabled):active{transform:translateY(1px)}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark);border-color:var(--color-primary-dark);box-shadow:var(--shadow-purple);transform:translateY(-1px)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.btn-danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn-danger:hover:not(:disabled){background:#d05030;border-color:#d05030;transform:translateY(-1px);box-shadow:0 4px 14px #e8694a59}.btn-success{color:#fff;background:#2e8a60;border-color:#2e8a60}.btn-success:hover:not(:disabled){background:#236e4d;border-color:#236e4d;transform:translateY(-1px);box-shadow:0 4px 14px #2e8a6059}.btn-block{width:100%}.btn-sm{padding:7px 15px;font-size:.82rem}.field{margin-bottom:18px}.field label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:7px;font-size:.72rem;font-weight:700;display:block}.field input,.field select,.field textarea{border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);width:100%;color:var(--color-text);padding:11px 14px;font-family:inherit;font-size:.95rem;transition:border-color .15s,box-shadow .15s}.field input::placeholder,.field textarea::placeholder{color:var(--color-text-subtle)}.field select option{background:var(--color-surface);color:var(--color-text)}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light);outline:none}.field-row{gap:12px;display:flex}.field-row .field{flex:1}.field-error{color:var(--color-danger);margin-top:6px;font-size:.85rem}.helper-text{color:var(--color-text-muted);font-size:.9rem}.state-message{text-align:center;color:var(--color-text-muted);padding:72px 16px;font-size:1rem}.badge{background:var(--color-primary-light);color:var(--color-primary);letter-spacing:.05em;text-transform:uppercase;border-radius:999px;align-items:center;gap:4px;padding:3px 9px;font-size:.67rem;font-weight:700;display:inline-flex}.link-button{color:var(--color-text-muted);text-align:center;cursor:pointer;background:0 0;border:none;width:100%;margin-top:20px;padding:4px;font-family:inherit;font-size:.88rem;transition:color .15s;display:block}.link-button--small{text-align:right;width:auto;color:var(--color-primary);margin-top:7px;padding:0;font-size:.8rem}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--color-surface-2)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#c4b9ac}@media (width<=640px){.container{padding:0 16px}.page{padding:24px 0 56px}h1{font-size:1.65rem}.field-row{flex-direction:column;gap:0}}.lang-switcher{border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);display:inline-flex;overflow:hidden}.lang-switcher__btn{color:var(--color-text-muted);cursor:pointer;letter-spacing:.06em;background:0 0;border:none;padding:5px 11px;font-family:inherit;font-size:.78rem;font-weight:700;transition:background .14s,color .14s}.lang-switcher__btn:hover:not(.lang-switcher__btn--active){background:var(--color-surface-2);color:var(--color-text)}.lang-switcher__btn--active{background:var(--color-primary);color:#fff}.avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;line-height:1;display:inline-flex}.navbar{border-bottom:1px solid var(--color-border-light);-webkit-backdrop-filter:blur(12px);z-index:100;background:#fffffff0;position:sticky;top:0;box-shadow:0 1px 6px #0000000d}.navbar__inner{justify-content:space-between;align-items:center;height:60px;display:flex}.navbar__brand{color:var(--color-text);letter-spacing:-.025em;align-items:center;gap:8px;font-size:1.08rem;font-weight:800;transition:color .15s;display:flex}.navbar__logo{border-radius:6px}.navbar__brand:hover{color:var(--color-primary);text-decoration:none}.navbar__actions{align-items:center;gap:10px;display:flex}.navbar__vocab-link{color:var(--color-text-muted);font-size:.85rem;font-weight:600;text-decoration:none;transition:color .12s}.navbar__vocab-link:hover{color:var(--color-primary);text-decoration:none}.login-page{background:radial-gradient(70% 55% at 50% -5%,#7c5cbf12 0%,#0000 65%);justify-content:center;align-items:center;min-height:calc(100vh - 60px);padding:28px 0 52px;display:flex}.login-card{width:100%;max-width:420px;box-shadow:var(--shadow-md);margin:0 auto;padding:44px 40px 36px}.login-card__logo{text-align:center;margin-bottom:14px;font-size:2.8rem;line-height:1}.login-card h1{text-align:center;letter-spacing:-.03em;margin:0 0 6px;font-size:1.7rem}.login-card__subtitle{text-align:center;color:var(--color-text-muted);margin-bottom:30px;font-size:.88rem}.login-card .field{margin-bottom:16px}.link-button{width:100%;color:var(--color-text-muted);text-align:center;cursor:pointer;background:0 0;border:none;margin-top:20px;padding:4px;font-family:inherit;font-size:.88rem;transition:color .15s;display:block}.link-button:hover{color:var(--color-primary)}.link-button--small{text-align:right;width:auto;color:var(--color-primary);margin-top:7px;padding:0;font-size:.8rem;display:block}.link-button--small:hover{color:var(--color-primary-dark)}.login-card__message{text-align:center;color:var(--color-text-muted);padding:14px 0 24px;line-height:1.65}.login-card__divider{background:var(--color-border);height:1px;margin:20px -40px}.book-card{flex-direction:column;transition:transform .22s,box-shadow .22s;display:flex;overflow:hidden}.book-card:hover{transform:translateY(-6px);box-shadow:0 14px 44px #0000001c,0 4px 14px #0000000f}.book-card__cover{aspect-ratio:2/3;background:var(--color-surface-2);border-radius:var(--radius) var(--radius) 0 0;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.book-card__cover img{object-fit:cover;width:100%;height:100%;transition:transform .32s}.book-card:hover .book-card__cover img{transform:scale(1.06)}.book-card__cover-placeholder{color:var(--color-primary);opacity:.18;font-size:3.5rem;font-weight:800;font-family:var(--font-serif);-webkit-user-select:none;user-select:none}.book-card__body{background:var(--color-surface);border-top:1px solid var(--color-border);flex-direction:column;flex:1;gap:6px;padding:12px 13px 15px;display:flex}.book-card__tags{flex-wrap:wrap;gap:4px;display:flex}.book-card__tag{text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;text-overflow:ellipsis;border-radius:999px;max-width:110px;padding:2px 7px;font-size:.6rem;font-weight:700;overflow:hidden}.book-card__tag--purple{color:#6248a8;background:#7c5cbf1f}.book-card__tag--teal{color:#1a9688;background:#2bbfb021}.book-card__tag--coral{color:#c04a2a;background:#e8694a1f}.book-card__tag--green{color:#2e8a60;background:#4caf881f}.book-card__title{color:var(--color-text);-webkit-line-clamp:2;letter-spacing:-.01em;-webkit-box-orient:vertical;margin:0;font-size:.88rem;font-weight:700;line-height:1.35;display:-webkit-box;overflow:hidden}.book-card__author{color:var(--color-text-muted);-webkit-line-clamp:1;-webkit-box-orient:vertical;margin:0 0 4px;font-size:.75rem;display:-webkit-box;overflow:hidden}.book-card__live-badge{color:#2e8a60;-webkit-backdrop-filter:blur(6px);letter-spacing:.03em;background:#ffffffeb;border:1px solid #4caf8847;border-radius:999px;align-items:center;gap:5px;padding:3px 9px;font-size:.67rem;font-weight:700;display:inline-flex;position:absolute;bottom:8px;left:8px;box-shadow:0 2px 8px #00000012}.book-card__live-badge:before{content:"";background:var(--color-success);border-radius:50%;flex-shrink:0;width:6px;height:6px;animation:2s ease-in-out infinite live-pulse-card}@keyframes live-pulse-card{0%,to{opacity:1}50%{opacity:.3}}.bsm-overlay{-webkit-backdrop-filter:blur(4px);z-index:200;background:#1a1a1a7a;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.bsm-panel{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md), 0 24px 64px #00000029;flex-direction:column;width:100%;max-width:560px;max-height:88vh;display:flex;overflow:hidden}.bsm-header{border-bottom:1px solid var(--color-border);flex-shrink:0;align-items:center;gap:14px;padding:20px 20px 18px;display:flex}.bsm-cover{object-fit:cover;border-radius:var(--radius-sm);width:40px;height:60px;box-shadow:var(--shadow-sm);flex-shrink:0}.bsm-header__info{flex:1;min-width:0}.bsm-title{color:var(--color-text);letter-spacing:-.02em;white-space:nowrap;text-overflow:ellipsis;margin:0 0 3px;font-size:1rem;font-weight:800;overflow:hidden}.bsm-author{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.78rem;overflow:hidden}.bsm-close{color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;flex-shrink:0;padding:4px 6px;font-size:.85rem;line-height:1;transition:background .12s,color .12s}.bsm-close:hover{background:var(--color-surface-2);color:var(--color-text)}.bsm-body{flex:1;padding:18px 20px 20px;overflow-y:auto}.bsm-state{text-align:center;color:var(--color-text-muted);margin:0;padding:24px 0;font-size:.9rem}.bsm-section-label{text-transform:uppercase;letter-spacing:.09em;color:var(--color-text-muted);margin:0 0 12px;font-size:.67rem;font-weight:700}.bsm-list{flex-direction:column;gap:8px;margin:0 0 16px;padding:0;list-style:none;display:flex}.bsm-row{border:1.5px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);box-shadow:var(--shadow-sm);align-items:center;gap:12px;padding:14px 16px;transition:border-color .15s,box-shadow .15s,transform .15s;display:flex}.bsm-row:hover{border-color:var(--color-primary);transform:translateY(-1px);box-shadow:0 4px 16px #7c5cbf1a}.bsm-row__main{flex:1;min-width:0}.bsm-row__top{align-items:center;gap:7px;margin-bottom:4px;display:flex}.bsm-row__name{color:var(--color-text);letter-spacing:-.01em;white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;font-weight:700;overflow:hidden}.bsm-row__meta{color:var(--color-text-muted);flex-wrap:wrap;align-items:center;gap:4px;margin:0;font-size:.76rem;display:flex}.bsm-status{letter-spacing:.04em;white-space:nowrap;border-radius:999px;flex-shrink:0;align-items:center;gap:4px;padding:2px 8px;font-size:.67rem;font-weight:700;display:inline-flex}.bsm-status.status-badge--live{color:#2e8a60;background:#4caf881f}.bsm-status.status-badge--live:before{content:"";background:currentColor;border-radius:50%;width:5px;height:5px;animation:2s ease-in-out infinite bsm-pulse;display:inline-block}.bsm-status.status-badge--waiting{background:var(--color-primary-light);color:var(--color-primary)}.bsm-status.status-badge--soon{color:#1a9688;background:#2bbfb01f}@keyframes bsm-pulse{0%,to{opacity:1}50%{opacity:.35}}.pace-badge{letter-spacing:.03em;white-space:nowrap;border-radius:999px;align-items:center;padding:1px 7px;font-size:.68rem;font-weight:700;display:inline-flex}.pace-badge--relaxed{color:#1a9688;background:#2bbfb01f}.pace-badge--normal{color:#2e8a60;background:#4caf881f}.pace-badge--fast{color:#c04a2a;background:#e8694a1f}.bsm-footer{border-top:1px solid var(--color-border);margin-top:4px;padding-top:16px}.bsm-goal-badge{color:var(--color-primary);background:var(--color-primary-light);border-radius:999px;margin-top:2px;padding:2px 8px;font-size:.68rem;font-weight:700;display:inline-block}.bsm-no-session{color:var(--color-text-subtle);white-space:nowrap;flex-shrink:0;font-size:.75rem}.bsm-empty{text-align:center;flex-direction:column;align-items:center;gap:6px;padding:32px 16px 8px;display:flex}.bsm-empty__text{color:var(--color-text);margin:0;font-size:.95rem;font-weight:600}.bsm-empty__sub{color:var(--color-text-muted);margin:0 0 14px;font-size:.85rem}.library-page h1{background:linear-gradient(130deg, var(--color-text) 15%, var(--color-primary) 100%);-webkit-text-fill-color:transparent;letter-spacing:-.04em;-webkit-background-clip:text;background-clip:text;margin-bottom:4px;font-size:2.5rem;font-weight:800;display:inline-block}.featured-section{border:1.5px solid var(--color-border);border-radius:var(--radius);background:linear-gradient(135deg,#7c5cbf0f 0%,#c9a84c0f 100%);margin:24px 0 8px;padding:24px}.featured-section__title{text-transform:uppercase;letter-spacing:.06em;color:var(--color-primary);margin:0 0 16px;font-size:1rem;font-weight:800}.featured-grid{grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:20px;display:grid}.collection-section{margin:20px 0 8px}.collection-section__header{justify-content:space-between;align-items:baseline;margin-bottom:12px;display:flex}.collection-section__title{color:var(--color-text);letter-spacing:-.02em;margin:0;font-size:1.1rem;font-weight:800}.collection-section__see-all{cursor:pointer;color:var(--color-primary);background:0 0;border:none;padding:0;font-family:inherit;font-size:.82rem;font-weight:600;transition:opacity .15s}.collection-section__see-all:hover{opacity:.7}.collection-scroll{scrollbar-width:thin;-ms-overflow-style:none;gap:16px;padding-bottom:8px;display:flex;overflow-x:auto}.collection-scroll::-webkit-scrollbar{height:4px}.collection-scroll::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:2px}.collection-scroll__item{flex-shrink:0;width:185px}.book-lang-toggle{border:1.5px solid var(--color-border);background:var(--color-surface);box-shadow:var(--shadow-sm);border-radius:999px;gap:0;margin:18px 0 0;display:inline-flex;overflow:hidden}.book-lang-btn{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;padding:7px 20px;font-family:inherit;font-size:.84rem;font-weight:600;line-height:1;transition:background .15s,color .15s}.book-lang-btn:hover:not(.book-lang-btn--active){background:var(--color-primary-light);color:var(--color-primary)}.book-lang-btn--active{background:var(--color-primary);color:#fff}.library-search-wrapper{max-width:560px;margin:22px 0 10px;position:relative}.library-search-wrapper:before{content:"🔍";pointer-events:none;opacity:.4;z-index:1;font-size:.84rem;position:absolute;top:50%;left:18px;transform:translateY(-50%)}.library-search{border:1.5px solid var(--color-border);background:var(--color-surface);width:100%;color:var(--color-text);box-shadow:var(--shadow-sm);border-radius:999px;padding:13px 20px 13px 46px;font-family:inherit;font-size:.95rem;transition:border-color .18s,box-shadow .18s}.library-search::placeholder{color:var(--color-text-subtle)}.library-search:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light);outline:none}.library-live-banner{color:#2e8a60;background:var(--color-green-light);border:1px solid #4caf8840;border-radius:999px;align-items:center;gap:8px;margin:14px 0 26px;padding:6px 14px;font-size:.82rem;font-weight:700;display:inline-flex}.library-live-banner:before{content:"";background:var(--color-success);border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:2s ease-in-out infinite live-pulse}@keyframes live-pulse{0%,to{opacity:1;box-shadow:0 0 #4caf8880}50%{opacity:.7;box-shadow:0 0 0 5px #4caf8800}}.genre-bar{margin:14px 0 8px;position:relative}.genre-bar:after{content:"";background:linear-gradient(to left, var(--color-bg) 30%, transparent);pointer-events:none;z-index:1;width:48px;position:absolute;top:0;bottom:4px;right:0}.genre-bar__scroll{scrollbar-width:none;-ms-overflow-style:none;gap:7px;padding-bottom:6px;padding-right:48px;display:flex;overflow-x:auto}.genre-bar__scroll::-webkit-scrollbar{display:none}.genre-pill{cursor:pointer;border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);white-space:nowrap;letter-spacing:-.005em;border-radius:999px;flex-shrink:0;padding:7px 16px;font-family:inherit;font-size:.84rem;font-weight:600;line-height:1;transition:border-color .15s,background .15s,color .15s,transform .14s,box-shadow .15s}.genre-pill:hover:not(.genre-pill--active){border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light);transform:translateY(-1px)}.genre-pill--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff;box-shadow:0 2px 10px #7c5cbf4d}.genre-pill--active:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark);transform:translateY(-1px)}.library-grid{grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:20px;margin:10px 0 40px;display:grid}.library-tr-growth{color:var(--color-text-subtle);max-width:560px;margin:4px 0 24px;font-size:.88rem;line-height:1.6}.library-pagination{justify-content:center;align-items:center;gap:16px;margin-top:8px;display:flex}.create-session-card{max-width:580px;margin:16px auto;padding:36px 40px}.selected-book{border-bottom:1px solid var(--color-border);margin-bottom:26px;padding-bottom:26px}.selected-book__label{text-transform:uppercase;letter-spacing:.09em;color:var(--color-text-muted);margin-bottom:12px;font-size:.7rem;font-weight:700;display:block}.selected-book__row{align-items:center;gap:14px;display:flex}.selected-book__cover{object-fit:cover;border-radius:var(--radius-sm);width:52px;height:78px;box-shadow:var(--shadow-sm);flex-shrink:0}.selected-book__title{color:var(--color-text);letter-spacing:-.01em;margin:0 0 4px;font-size:.95rem;font-weight:700}.pace-field{margin-bottom:26px}.pace-field__label{text-transform:uppercase;letter-spacing:.09em;color:var(--color-text-muted);margin-bottom:5px;font-size:.7rem;font-weight:700;display:block}.pace-field__hint{color:var(--color-text-muted);margin:0 0 14px;font-size:.82rem}.pace-picker{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.pace-option{border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);cursor:pointer;text-align:center;padding:14px 10px 12px;font-family:inherit;transition:border-color .15s,background .15s,box-shadow .15s,transform .14s}.pace-option:hover:not(.pace-option--active){border-color:var(--color-primary);background:var(--color-primary-light);transform:translateY(-1px)}.pace-option--active{border-color:var(--color-primary);background:var(--color-primary-light);box-shadow:0 0 0 1px var(--color-primary), 0 2px 10px #7c5cbf26}.pace-option__icon{margin-bottom:6px;font-size:1.5rem;line-height:1;display:block}.pace-option__label{color:var(--color-text);letter-spacing:-.01em;margin:0 0 3px;font-family:inherit;font-size:.82rem;font-weight:700}.pace-option--active .pace-option__label{color:var(--color-primary)}.pace-option__desc{color:var(--color-text-muted);margin:0;font-family:inherit;font-size:.7rem}.theme-field{margin-bottom:26px}.theme-field__label{text-transform:uppercase;letter-spacing:.09em;color:var(--color-text-muted);margin-bottom:5px;font-size:.7rem;font-weight:700;display:block}.theme-field__hint{color:var(--color-text-muted);margin:0 0 14px;font-size:.82rem}.theme-grid{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.theme-card{border:2px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;background:var(--color-surface);text-align:left;padding:0;transition:border-color .15s,box-shadow .15s,transform .14s;overflow:hidden}.theme-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.theme-card--selected{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary), 0 4px 14px #7c5cbf33}.theme-card__preview{flex-direction:column;justify-content:center;gap:5px;height:56px;padding:10px 12px;display:flex}.theme-card__line{border-radius:999px;height:3px}.theme-card__footer{background:var(--color-surface-2);border-top:1px solid var(--color-border);align-items:center;gap:6px;padding:7px 9px;display:flex}.theme-card__dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.theme-card__name{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:.67rem;font-weight:700;font-family:var(--font-sans);letter-spacing:-.01em;overflow:hidden}.session-created-header{text-align:center;padding:4px 0 24px}.session-created-icon{text-align:center;margin-bottom:12px;font-size:3rem;line-height:1;display:block}.share-link-row{gap:10px;margin:14px 0 24px;display:flex}.share-link-row input{border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font-sans);background:var(--color-surface-2);color:var(--color-text-muted);flex:1;min-width:0;padding:11px 14px;font-size:.85rem}.create-group-card{max-width:520px}.join-group-card{text-align:center;flex-direction:column;align-items:center;gap:20px;max-width:440px;margin:60px auto;padding:40px 36px;display:flex}.join-group__cover-wrap{border-radius:var(--radius-sm);background:var(--color-surface-2);flex-shrink:0;width:110px;height:148px;overflow:hidden}.join-group__cover{object-fit:cover;width:100%;height:100%;display:block}.join-group__info{flex-direction:column;gap:6px;display:flex}.join-group__title{letter-spacing:-.02em;color:var(--color-text);margin:0;font-size:1.35rem;font-weight:800}.join-group__meta{color:var(--color-text-muted);margin:0;font-size:.875rem;line-height:1.5}.join-group__actions{flex-direction:column;align-items:center;gap:12px;width:100%;display:flex}.join-group__status{color:var(--color-text-muted);margin:0;font-size:.875rem}.join-group__status--info{color:var(--color-primary);font-weight:600}.progress-bar{margin-bottom:1.5rem}.progress-bar__label{color:var(--room-text-muted,var(--color-text-muted));letter-spacing:.08em;text-transform:uppercase;margin-bottom:7px;font-size:.7rem;font-weight:700}.progress-bar__track{background:var(--room-border,var(--color-border));border-radius:999px;height:4px;overflow:hidden}.progress-bar__fill{background:var(--room-accent,var(--color-primary));height:100%;box-shadow:0 0 8px var(--room-accent,#7c5cbf66);border-radius:999px;transition:width .4s}.participant-list__title{color:var(--room-text-muted,var(--color-text-muted));text-transform:uppercase;letter-spacing:.09em;margin:0 0 12px;font-size:.7rem;font-weight:700}.participant-list__items{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.participant{border-radius:var(--radius-sm);border:1.5px solid #0000;align-items:center;gap:10px;padding:8px 10px;transition:background .14s;display:flex}.participant--active{background:var(--room-accent-subtle,#7c5cbf14);border-color:var(--room-accent,var(--color-primary))}.participant__info{flex:1;min-width:0}.participant__name{color:var(--room-text,var(--color-text));flex-wrap:wrap;align-items:center;gap:6px;font-size:.87rem;font-weight:600;display:flex}.participant__tag{color:var(--room-text-muted,var(--color-text-muted));font-size:.8rem;font-weight:400}.participant__badge{padding:1px 6px;font-size:.6rem}.participant__status{color:var(--room-accent,var(--color-primary));text-transform:uppercase;letter-spacing:.07em;margin-top:2px;font-size:.65rem;font-weight:700}.mic-indicator{opacity:.18;flex-shrink:0;font-size:.95rem;transition:opacity .15s}.mic-indicator--on{opacity:1}.participant--offline{opacity:.5}.presence-dot{background:var(--color-border,#ccc);border-radius:50%;flex-shrink:0;width:8px;height:8px;transition:background .2s}.presence-dot--online{background:#34c77a}.participant__page{color:var(--room-text-muted,var(--color-text-muted));margin-top:1px;font-size:.65rem}.participant__page--offline{font-style:italic}.participant__streak{color:var(--room-text-muted,var(--color-text-muted));white-space:nowrap;letter-spacing:-.01em;flex-shrink:0;font-size:.75rem;font-weight:700}.video-tile{border-radius:var(--radius-sm,6px);background:var(--color-bg);border:1px solid var(--color-border);flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:100px;height:78px;display:flex;position:relative;overflow:hidden}.video-tile__video{object-fit:cover;width:100%;height:100%;display:block}.video-tile__video--mirror{transform:scaleX(-1)}.video-tile__avatar{background:var(--color-surface);justify-content:center;align-items:center;width:100%;height:100%;display:flex}.video-tile__label{color:#fff;white-space:nowrap;text-overflow:ellipsis;text-align:center;-webkit-backdrop-filter:blur(2px);background:#00000073;padding:2px 4px;font-size:.62rem;font-weight:600;position:absolute;bottom:0;left:0;right:0;overflow:hidden}.cam-strip{margin-bottom:0;padding:8px 10px}.cam-strip--collapsed{padding-bottom:8px}.cam-strip__header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.cam-strip--collapsed .cam-strip__header{margin-bottom:0}.cam-strip__label{color:var(--color-text-muted);letter-spacing:.02em;font-size:.72rem;font-weight:700}.cam-strip__collapse-btn{cursor:pointer;width:20px;height:20px;color:var(--color-text-muted);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:0;transition:background .12s,color .12s;display:flex}.cam-strip__collapse-btn:hover{background:var(--color-border);color:var(--color-text)}.cam-strip__tiles{flex-wrap:wrap;gap:6px;display:flex}.notes-panel{padding:18px}.notes-panel__header{justify-content:space-between;align-items:baseline;gap:.5rem;margin-bottom:10px;display:flex}.notes-panel__header label{color:var(--room-text-muted,var(--color-text-muted));text-transform:uppercase;letter-spacing:.09em;cursor:pointer;font-size:.7rem;font-weight:700}.notes-panel__status{color:var(--room-accent,var(--color-primary));font-size:.75rem}.notes-panel textarea{border:1.5px solid var(--room-border,var(--color-border));border-radius:var(--radius-sm);background:var(--room-surface-2,var(--color-surface-2));width:100%;color:var(--room-text,var(--color-text));resize:vertical;min-height:90px;padding:11px 13px;font-family:inherit;font-size:.9rem;line-height:1.6;transition:border-color .15s,box-shadow .15s}.notes-panel textarea::placeholder{color:var(--room-text-muted,var(--color-text-muted));opacity:.65}.notes-panel textarea:focus{border-color:var(--room-accent,var(--color-primary));box-shadow:0 0 0 3px var(--room-accent-subtle,var(--color-primary-light));outline:none}.word-popup{z-index:200;border:1px solid var(--color-border);border-radius:var(--radius);background:#fff;width:300px;position:fixed;overflow:hidden;box-shadow:0 12px 40px #00000024,0 4px 12px #00000012}.word-popup__header{border-bottom:1px solid var(--color-border);background:#7c5cbf0d;align-items:baseline;gap:6px;padding:12px 14px 10px;display:flex}.word-popup__word{color:var(--color-primary);letter-spacing:-.01em;flex:1;min-width:0;font-size:1rem;font-weight:800}.word-popup__phonetic{color:var(--color-text-muted);flex-shrink:0;font-size:.76rem}.word-popup__close{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0 0 0 8px;font-size:.8rem;line-height:1;transition:color .12s}.word-popup__close:hover{color:var(--color-primary)}.word-popup__loading{color:var(--color-text-muted);text-align:center;margin:0;padding:16px 14px;font-size:.85rem}.word-popup__body{flex-direction:column;gap:9px;max-height:280px;padding:12px 14px;display:flex;overflow-y:auto}.word-popup__translation{background:var(--color-primary-light);border-radius:var(--radius-sm);border:1px solid #7c5cbf33;align-items:baseline;gap:8px;padding:8px 11px;display:flex}.word-popup__translation-text{color:var(--color-primary);font-size:.95rem;font-weight:700}.word-popup__tag{text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-muted);white-space:nowrap;flex-shrink:0;font-size:.62rem;font-weight:700}.word-popup__def-row{align-items:baseline;gap:8px;display:flex}.word-popup__def{color:var(--color-text);margin:0;font-size:.875rem;line-height:1.5}.word-popup__example{color:var(--color-text-muted);font-style:italic}.word-popup__save-btn{border-radius:var(--radius-sm);border:1px solid var(--color-primary);color:var(--color-primary);cursor:pointer;white-space:nowrap;background:0 0;flex-shrink:0;margin-left:auto;padding:3px 8px;font-size:.7rem;font-weight:600;line-height:1.4;transition:background .12s,color .12s}.word-popup__save-btn:hover:not(:disabled){background:var(--color-primary);color:#fff}.word-popup__save-btn--saved{color:#22c55e;cursor:default;border-color:#22c55e}.word-popup__save-btn:disabled:not(.word-popup__save-btn--saved){border-color:var(--color-text-muted);color:var(--color-text-muted);cursor:default}.highlight-panel{flex-direction:row;flex-shrink:0;align-items:flex-start;display:flex}.highlight-panel__tab{border:1.5px solid var(--room-border,var(--color-border));border-radius:var(--radius-sm) 0 0 var(--radius-sm);background:var(--room-surface,var(--color-surface));width:32px;min-height:72px;color:var(--room-text-muted,var(--color-text-muted));cursor:pointer;border-right:none;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:12px 0;transition:background .15s,color .15s;display:flex;position:sticky;top:80px}.highlight-panel__tab:hover{background:var(--room-accent-subtle,#7c5cbf14);color:var(--room-accent,var(--color-primary))}.highlight-panel__badge{background:var(--room-accent,var(--color-primary));color:#fff;border-radius:10px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 3px;font-size:.58rem;font-weight:700;line-height:1;display:flex}.highlight-panel__body{border:1.5px solid var(--room-border,var(--color-border));border-radius:0 var(--radius-sm) var(--radius-sm) 0;background:var(--room-surface,var(--color-surface));flex-direction:column;width:248px;max-height:calc(100vh - 140px);display:flex;position:sticky;top:80px;overflow:hidden}.highlight-panel__header{border-bottom:1px solid var(--room-border,var(--color-border));flex-shrink:0;padding:12px 14px 8px}.highlight-panel__title{text-transform:uppercase;letter-spacing:.09em;color:var(--room-text-muted,var(--color-text-muted));margin:0;font-size:.7rem;font-weight:700}.highlight-panel__cards{flex-direction:column;flex:1;gap:6px;padding:8px;display:flex;overflow-y:auto}.highlight-panel__empty{color:var(--room-text-muted,var(--color-text-muted));text-align:center;margin:0;padding:24px 8px;font-size:.8rem;line-height:1.5}.highlight-card{border:1.5px solid var(--room-border,var(--color-border));border-radius:var(--radius-sm);transition:border-color .15s;overflow:hidden}.highlight-card--open{border-color:var(--room-accent,var(--color-primary))}.highlight-card__header{cursor:pointer;background:var(--room-surface,var(--color-surface));align-items:center;gap:6px;min-height:36px;padding:8px 10px;display:flex}.highlight-card__label{min-width:0;color:var(--room-text,var(--color-text));text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.78rem;font-weight:600;line-height:1.3;overflow:hidden}.highlight-card__label--editable{cursor:text}.highlight-card__label--editable:hover{color:var(--room-accent,var(--color-primary));text-underline-offset:2px;text-decoration:underline}.highlight-card__label-input{border:1px solid var(--room-accent,var(--color-primary));background:var(--room-surface,var(--color-surface));min-width:0;color:var(--room-text,var(--color-text));border-radius:3px;outline:none;flex:1;padding:1px 5px;font-family:inherit;font-size:.78rem;font-weight:600}.highlight-card__shared{color:var(--room-accent,var(--color-primary));opacity:.75;flex-shrink:0;align-items:center;display:flex}.highlight-card__chevron{cursor:pointer;color:var(--room-text-muted,var(--color-text-muted));background:0 0;border:none;flex-shrink:0;padding:2px 0;font-size:.5rem;line-height:1}.highlight-card__body{border-top:1px solid var(--room-border,var(--color-border));background:var(--room-surface,var(--color-surface));padding:0 10px 10px}.highlight-card__quote{color:var(--room-text,var(--color-text));border-left:2px solid var(--room-accent,var(--color-primary));margin:8px 0 6px;padding-left:8px;font-size:.76rem;font-style:italic;line-height:1.5}.highlight-card__note{color:var(--room-text,var(--color-text));margin:6px 0 4px;font-size:.78rem;line-height:1.5}.highlight-card__meta{color:var(--room-text-muted,var(--color-text-muted));margin:4px 0 0;font-size:.65rem}.highlight-card__delete{cursor:pointer;color:var(--room-text-muted,var(--color-text-muted));opacity:0;background:0 0;border:none;border-radius:3px;flex-shrink:0;align-items:center;padding:2px 3px;transition:color .12s,background .12s;display:flex}.highlight-card:hover .highlight-card__delete,.highlight-card__delete--active{opacity:1}.highlight-card__delete:hover,.highlight-card__delete--active{color:#ef4444;background:#ef444414}.highlight-card__confirm{padding:10px 0 4px}.highlight-card__confirm-text{color:var(--room-text,var(--color-text));margin:0 0 8px;font-size:.76rem;font-weight:600}.highlight-card__confirm-actions{gap:6px;display:flex}.highlight-card__confirm-yes{color:#fff;border-radius:var(--radius-sm);cursor:pointer;background:#ef4444;border:none;padding:4px 10px;font-size:.72rem;font-weight:600;transition:background .12s}.highlight-card__confirm-yes:hover{background:#dc2626}.highlight-card__confirm-cancel{border:1.5px solid var(--room-border,var(--color-border));border-radius:var(--radius-sm);cursor:pointer;color:var(--room-text-muted,var(--color-text-muted));background:0 0;padding:4px 10px;font-size:.72rem;font-weight:600;transition:border-color .12s,color .12s}.highlight-card__confirm-cancel:hover{border-color:var(--room-text-muted,var(--color-text-muted));color:var(--room-text,var(--color-text))}@media (width<=900px){.highlight-panel{display:none}}.selection-popup{z-index:400;background:var(--color-surface,#fff);border:1.5px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:8px 10px;position:fixed;transform:translate(-50%)}.selection-popup--editing{min-width:280px;max-width:320px;padding:12px 14px}.selection-popup__preview{color:var(--color-text-muted);border-left:2px solid var(--color-primary);margin:0 0 10px;padding-left:8px;font-size:.78rem;font-style:italic;line-height:1.45}.selection-popup__textarea{box-sizing:border-box;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface-2,#f5f5f0);width:100%;color:var(--color-text);resize:vertical;min-height:64px;padding:8px 10px;font-family:inherit;font-size:.85rem}.selection-popup__textarea:focus{border-color:var(--color-primary);outline:none}.selection-popup__share-label{color:var(--color-text);cursor:pointer;align-items:center;gap:7px;margin:8px 0 10px;font-size:.82rem;display:flex}.selection-popup__actions{justify-content:flex-end;gap:8px;display:flex}.reading-room-page{background:var(--room-bg,var(--color-bg));transition:background .35s}.reading-room-page .card{background:var(--room-surface,var(--color-surface));border-color:var(--room-border,var(--color-border))}.reading-room-page h1,.reading-room-page h2,.reading-room-page h3{color:var(--room-text,var(--color-text))}.reading-room-page .helper-text,.reading-room-page .state-message{color:var(--room-text-muted,var(--color-text-muted))}.reading-room-page .badge{background:var(--room-accent-subtle,var(--color-primary-light));color:var(--room-accent,var(--color-primary))}.reading-room{padding:36px 0 72px}.reading-room__header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:1.5rem;display:flex}.reading-room__header h1{margin:0 0 4px;font-size:1.7rem}.reading-room__header-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.join-card,.state-card{text-align:center;flex-direction:column;align-items:center;gap:16px;padding:56px 36px;display:flex}.join-card h1{margin:0}.comment-banner{background:var(--room-accent-subtle,#7c5cbf14);color:var(--room-accent,var(--color-primary));border-left:3px solid var(--room-accent,var(--color-primary));border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin-bottom:1.5rem;padding:12px 16px;font-size:.92rem;line-height:1.55}.reading-room__canvas{align-items:flex-start;display:flex}.reading-room__canvas>.reading-room__layout{flex:1;min-width:0}.reading-room__layout{grid-template-columns:1fr 300px;align-items:start;gap:20px;display:grid}.reading-room__main{flex-direction:column;gap:16px;min-width:0;display:flex}.reading-room__side{flex-direction:column;gap:16px;display:flex}.translate-toolbar{align-items:center;gap:10px;display:flex}.translate-lang-label{opacity:.55;flex-shrink:0;font-size:1rem;line-height:1}.translate-lang-select{border:1.5px solid var(--room-border,var(--color-border));border-radius:var(--radius-sm);background:var(--room-surface,var(--color-surface));color:var(--room-text,var(--color-text));cursor:pointer;padding:7px 11px;font-family:inherit;font-size:.875rem;transition:border-color .15s}.translate-lang-select option{background:var(--room-surface,var(--color-surface));color:var(--room-text,var(--color-text))}.translate-lang-select:focus{border-color:var(--room-accent,var(--color-primary));outline:none}.reading-text{background:var(--room-surface,var(--color-surface));border-color:var(--room-border,var(--color-border));box-shadow:var(--room-card-glow,none);padding:2rem;transition:box-shadow .35s;position:relative}.reading-text p{font-family:var(--room-font,Georgia, serif);font-size:var(--room-font-size,19px);line-height:var(--room-line-height,1.85);color:var(--room-text,#2c2c2c);white-space:pre-wrap;max-width:650px;margin:0 auto}.reading-text p+p{text-indent:2em;margin-top:0}.reading-word{cursor:pointer;border-radius:3px;transition:background .12s}.reading-word:hover{background:var(--room-accent-subtle,#7c5cbf1a)}.reading-controls{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.turn-indicator{color:var(--room-text-muted,var(--color-text-muted));margin:0;font-size:.9rem;font-weight:600}.turn-indicator--active{color:var(--room-accent,var(--color-primary))}.reading-controls__actions{flex-wrap:wrap;gap:8px;display:flex}.cam-controls{align-items:center;gap:8px;margin-top:12px;display:flex}.cam-toggle-btn{border:1.5px solid var(--room-border,var(--color-border));background:var(--room-surface,var(--color-surface));color:var(--room-text-muted,var(--color-text-muted));cursor:pointer;border-radius:999px;align-items:center;gap:6px;padding:6px 12px;font-family:inherit;font-size:.78rem;font-weight:600;line-height:1;transition:border-color .15s,color .15s,background .15s;display:inline-flex}.cam-toggle-btn:hover{border-color:var(--room-accent,var(--color-primary));color:var(--room-accent,var(--color-primary))}.cam-toggle-btn--on{border-color:var(--room-accent,var(--color-primary));background:var(--room-accent,var(--color-primary));color:#fff}.cam-toggle-btn--on:hover{opacity:.88;color:#fff}.cam-toggle-btn__label{white-space:nowrap}.reading-room-page .btn-primary{background:var(--room-accent,var(--color-primary));border-color:var(--room-accent,var(--color-primary));color:#fff}.reading-room-page .btn-primary:hover:not(:disabled){background:var(--room-accent-dark,var(--color-primary-dark));border-color:var(--room-accent-dark,var(--color-primary-dark));box-shadow:0 4px 16px var(--room-accent-subtle,#7c5cbf4d)}.reading-room-page .btn-secondary{border-color:var(--room-border,var(--color-border));color:var(--room-text,var(--color-text));background:var(--room-surface,transparent)}.reading-room-page .btn-secondary:hover:not(:disabled){background:var(--room-accent-subtle,#7c5cbf14);border-color:var(--room-accent,var(--color-primary));color:var(--room-accent,var(--color-primary))}.admin-comment-form{flex-direction:column;gap:10px;padding:18px;display:flex}.admin-comment-form label{color:var(--room-text-muted,var(--color-text-muted));text-transform:uppercase;letter-spacing:.09em;font-size:.7rem;font-weight:700}.admin-comment-form textarea{border:1.5px solid var(--room-border,var(--color-border));border-radius:var(--radius-sm);background:var(--room-surface-2,var(--color-surface-2));width:100%;color:var(--room-text,var(--color-text));resize:vertical;padding:10px 12px;font-family:inherit;font-size:.9rem}.admin-comment-form textarea::placeholder{color:var(--room-text-muted,var(--color-text-muted))}.admin-comment-form textarea:focus{border-color:var(--room-accent,var(--color-primary));outline:none}.admin-comment-form button{align-self:flex-end}.end-dialog-overlay{-webkit-backdrop-filter:blur(4px);z-index:300;background:#1a1a1a80;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.end-dialog{border-radius:var(--radius);box-shadow:var(--shadow-md);background:#fff;width:100%;max-width:400px;padding:32px}.end-dialog h2{color:var(--color-text);letter-spacing:-.02em;margin:0 0 10px;font-size:1.2rem;font-weight:800}.end-dialog p{color:var(--color-text-muted);margin:0 0 24px;font-size:.9rem;line-height:1.55}.end-dialog__actions{justify-content:flex-end;gap:10px;display:flex}.invite-popup-wrapper{position:relative}.invite-popup{background:var(--color-surface,#fff);border:1.5px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-md);z-index:200;width:320px;padding:16px;position:absolute;top:calc(100% + 8px);right:0}.invite-popup__label{text-transform:uppercase;letter-spacing:.09em;color:var(--color-text-muted);margin:0 0 10px;font-size:.72rem;font-weight:700}.invite-popup__row{gap:8px;display:flex}.invite-popup__link{border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface-2,#f5f5f0);min-width:0;color:var(--color-text);flex:1;padding:7px 10px;font-family:inherit;font-size:.78rem}.page-browser{justify-content:space-between;align-items:center;gap:12px;display:flex}.page-browser__label{color:var(--room-text-muted,var(--color-text-muted));flex:1;justify-content:center;align-items:center;gap:10px;font-size:.85rem;display:flex}.page-browser__sync-btn{cursor:pointer;color:var(--room-accent,var(--color-primary));text-underline-offset:2px;background:0 0;border:none;padding:0;font-family:inherit;font-size:.75rem;text-decoration:underline}.group-desc-card{padding:12px 14px}.group-desc__header{justify-content:space-between;align-items:center;margin-bottom:7px;display:flex}.group-desc__title{text-transform:uppercase;letter-spacing:.09em;color:var(--room-text-muted,var(--color-text-muted));font-size:.68rem;font-weight:700}.group-desc__edit-btn{cursor:pointer;color:var(--room-text-muted,var(--color-text-muted));background:0 0;border:none;border-radius:4px;align-items:center;padding:3px 5px;transition:color .12s,background .12s;display:flex}.group-desc__edit-btn:hover{color:var(--room-accent,var(--color-primary));background:var(--room-accent-subtle,var(--color-primary-light))}.group-desc__text{color:var(--room-text,var(--color-text));white-space:pre-wrap;word-break:break-word;margin:0;font-size:.83rem;line-height:1.6}.group-desc__empty{color:var(--room-text-muted,var(--color-text-muted));margin:0;font-size:.83rem;font-style:italic}.group-desc__textarea{resize:vertical;border:1.5px solid var(--room-border,var(--color-border));border-radius:var(--radius-sm);background:var(--room-surface,var(--color-surface));width:100%;color:var(--room-text,var(--color-text));box-sizing:border-box;outline:none;padding:7px 10px;font-family:inherit;font-size:.83rem;line-height:1.55;transition:border-color .15s}.group-desc__textarea:focus{border-color:var(--room-accent,var(--color-primary))}.group-desc__actions{gap:6px;margin-top:8px;display:flex}.goal-card{flex-direction:column;gap:10px;padding:14px 16px;display:flex}.goal__header{justify-content:space-between;align-items:baseline;display:flex}.goal__title{text-transform:uppercase;letter-spacing:.08em;color:var(--room-text-muted,var(--color-text-muted));font-size:.72rem;font-weight:700}.goal__date{color:var(--room-text,var(--color-text));font-size:.82rem;font-weight:700}.goal__bar-track{background:var(--room-border,var(--color-border));border-radius:3px;height:6px;overflow:hidden}.goal__bar-fill{background:var(--room-accent,var(--color-primary));border-radius:3px;height:100%;transition:width .4s}.goal__stats{color:var(--room-text-muted,var(--color-text-muted));justify-content:space-between;font-size:.75rem;display:flex}.goal__badge{border-radius:999px;align-self:flex-start;padding:3px 10px;font-size:.72rem;font-weight:700;display:inline-block}.goal__badge--on-track,.goal__badge--done{color:#2e8a60;background:#2e8a601a}.goal__badge--behind{color:#b8860b;background:#d2961e1f}.goal__badge--expired{color:#c0392b;background:#c83c3c1a}.goal__clear-btn{cursor:pointer;color:var(--room-text-muted,var(--color-text-muted));text-underline-offset:2px;background:0 0;border:none;align-self:flex-end;padding:0;font-family:inherit;font-size:.72rem;text-decoration:underline}.goal__picker{flex-direction:column;gap:8px;display:flex}.goal__picker-label{color:var(--room-text,var(--color-text));font-size:.78rem;font-weight:700}.goal__date-input{border:1.5px solid var(--room-border,var(--color-border));border-radius:var(--radius-sm);background:var(--room-surface,var(--color-surface));color:var(--room-text,var(--color-text));padding:7px 10px;font-family:inherit;font-size:.84rem}.goal__date-input:focus{border-color:var(--room-accent,var(--color-primary));outline:none}.goal__picker-actions{gap:6px;display:flex}.page-lock-card{padding:14px 16px}.page-lock-row{align-items:center;gap:12px;display:flex}.page-lock__info{flex:1;min-width:0}.page-lock__label{color:var(--room-text,var(--color-text));margin:0;font-size:.8rem;font-weight:700}.page-lock__hint{color:var(--room-text-muted,var(--color-text-muted));margin:2px 0 0;font-size:.7rem;line-height:1.4}.page-lock__toggle{background:var(--color-border,#ddd);cursor:pointer;border:none;border-radius:10px;flex-shrink:0;width:36px;height:20px;padding:0;transition:background .2s;position:relative}.page-lock__toggle--on{background:var(--room-accent,var(--color-primary))}.page-lock__thumb{pointer-events:none;background:#fff;border-radius:50%;width:14px;height:14px;transition:left .2s;display:block;position:absolute;top:3px;left:3px}.page-lock__toggle--on .page-lock__thumb{left:19px}.reaction-overlay{pointer-events:none;position:absolute;inset:0;overflow:hidden}.reaction-float{-webkit-user-select:none;user-select:none;font-size:1.85rem;line-height:1;animation:2s ease-out forwards reactionFloat;position:absolute;bottom:0}@keyframes reactionFloat{0%{opacity:0;transform:translateY(0)scale(.5)}12%{opacity:1;transform:translateY(-22px)scale(1.25)}75%{opacity:.85}to{opacity:0;transform:translateY(-230px)scale(.8)}}.applause-btn{background:var(--room-accent-subtle,#7c5cbf1a);border:2px solid var(--room-accent,var(--color-primary));cursor:pointer;border-radius:999px;margin-left:8px;padding:6px 14px;font-size:1.5rem;line-height:1;transition:transform .15s,box-shadow .15s}.applause-btn:hover{box-shadow:0 2px 12px var(--room-accent-subtle,#7c5cbf40);transform:scale(1.18)}.applause-btn:active{transform:scale(.9)}.reading-text--applause-glow{transition:box-shadow .3s;box-shadow:0 0 30px #ffc10759,0 0 60px #ffc10726}.applause-notes{z-index:10;pointer-events:none;justify-content:center;gap:10px;display:flex;position:absolute;top:12px;left:0;right:0}.applause-note{color:var(--room-accent,var(--color-primary));background:var(--room-accent-subtle,#7c5cbf1a);border-radius:999px;padding:4px 12px;font-size:.82rem;font-weight:700;animation:2.5s forwards applauseNoteFade}@keyframes applauseNoteFade{0%{opacity:0;transform:translateY(6px)}15%{opacity:1;transform:translateY(0)}70%{opacity:1}to{opacity:0;transform:translateY(-8px)}}.reaction-bar{justify-content:center;align-items:center;gap:4px;padding:6px 12px;display:flex}.reaction-btn{cursor:pointer;background:0 0;border:1.5px solid #0000;border-radius:8px;padding:4px 7px;font-size:1.3rem;line-height:1;transition:transform .12s,background .12s}.reaction-btn:hover{background:var(--room-accent-subtle,#7c5cbf1a);transform:scale(1.3)}.reaction-btn:active{transform:scale(.88)}.side-panel-card{padding:0;overflow:hidden}.side-tabs{border-bottom:1.5px solid var(--room-border,var(--color-border));display:flex}.side-tab{cursor:pointer;color:var(--room-text-muted,var(--color-text-muted));background:0 0;border:none;border-bottom:2px solid #0000;flex:1;margin-bottom:-1.5px;padding:10px 0;font-family:inherit;font-size:.78rem;font-weight:600;transition:color .14s,background .14s}.side-tab--active{color:var(--room-accent,var(--color-primary));border-bottom-color:var(--room-accent,var(--color-primary))}.side-tab:hover:not(.side-tab--active){color:var(--room-text,var(--color-text));background:var(--room-accent-subtle,#7c5cbf0d)}.side-panel-participants{padding:16px}.chat-panel{flex-direction:column;height:380px;display:flex}.chat-messages{flex-direction:column;flex:1;gap:10px;padding:12px 14px;display:flex;overflow-y:auto}.chat-empty{color:var(--room-text-muted,var(--color-text-muted));text-align:center;margin:0;padding:32px 8px;font-size:.8rem;line-height:1.5}.chat-message{flex-direction:column;gap:2px;max-width:92%;display:flex}.chat-message--own{align-self:flex-end;align-items:flex-end}.chat-message__header{align-items:baseline;gap:6px;display:flex}.chat-message__name{color:var(--room-accent,var(--color-primary));font-size:.68rem;font-weight:700}.chat-message__time{color:var(--room-text-muted,var(--color-text-muted));font-size:.62rem}.chat-message__text{color:var(--room-text,var(--color-text));word-break:break-word;background:var(--room-accent-subtle,#7c5cbf12);border-radius:var(--radius-sm);margin:0;padding:6px 10px;font-size:.84rem;line-height:1.45}.chat-message--own .chat-message__text{background:var(--room-accent,var(--color-primary));color:#fff}.chat-input-form{border-top:1.5px solid var(--room-border,var(--color-border));flex-shrink:0;gap:6px;padding:10px 12px;display:flex}.chat-input{border:1.5px solid var(--room-border,var(--color-border));border-radius:var(--radius-sm);background:var(--room-surface-2,var(--color-surface-2,#f5f5f0));min-width:0;color:var(--room-text,var(--color-text));flex:1;padding:6px 10px;font-family:inherit;font-size:.84rem}.chat-input::placeholder{color:var(--room-text-muted,var(--color-text-muted))}.chat-input:focus{border-color:var(--room-accent,var(--color-primary));outline:none}@media (width<=900px){.reading-room__layout{grid-template-columns:1fr}.reading-text{padding:24px 22px}}.completion-prompt{border:2px solid var(--room-accent,var(--color-primary));text-align:center;flex-direction:column;align-items:center;gap:14px;margin-top:14px;padding:22px 24px;display:flex}.completion-prompt__text{color:var(--room-text,var(--color-text));margin:0;font-size:.93rem}.celebration-overlay{z-index:200;background:#0009;justify-content:center;align-items:center;animation:.25s cel-fade;display:flex;position:fixed;inset:0}@keyframes cel-fade{0%{opacity:0}to{opacity:1}}.celebration-modal{background:var(--color-surface);border-radius:calc(var(--radius) * 2);text-align:center;width:90vw;max-width:420px;padding:48px 40px;animation:.35s cubic-bezier(.34,1.56,.64,1) cel-pop;box-shadow:0 20px 60px #00000038}@keyframes cel-pop{0%{opacity:0;transform:scale(.82)}to{opacity:1;transform:scale(1)}}.celebration-emoji{margin:0 0 16px;font-size:3.5rem}.celebration-title{color:var(--color-text);letter-spacing:-.03em;margin:0 0 8px;font-size:1.5rem;font-weight:800}.celebration-subtitle{color:var(--color-text-muted);margin:0 0 28px;font-size:.9rem}.celebration-actions{justify-content:center;gap:10px;display:flex}.vocab-header{justify-content:space-between;align-items:baseline;margin-top:40px;margin-bottom:32px;display:flex}.vocab-title{letter-spacing:-.03em;color:var(--color-text);margin:0;font-size:1.6rem;font-weight:800}.vocab-state{color:var(--color-text-muted);text-align:center;margin-top:64px;font-size:.95rem}.vocab-state--empty{max-width:380px;margin-left:auto;margin-right:auto;line-height:1.6}.vocab-section{margin-bottom:40px}.vocab-section__title{color:var(--color-text);border-bottom:2px solid var(--color-border);align-items:center;gap:10px;margin:0 0 14px;padding-bottom:10px;font-size:1rem;font-weight:700;display:flex}.vocab-count{background:var(--color-primary-light);color:var(--color-primary);border-radius:20px;padding:2px 8px;font-size:.75rem;font-weight:600}.vocab-cards{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;display:grid}.vocab-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);flex-direction:column;gap:5px;padding:14px 36px 12px 14px;transition:box-shadow .12s;display:flex;position:relative}.vocab-card:hover{box-shadow:0 4px 16px #0000000f}.vocab-card__main{flex-wrap:wrap;align-items:center;gap:7px;display:flex}.vocab-card__word{color:var(--color-primary);font-size:1rem;font-weight:700}.vocab-card__arrow{color:var(--color-text-muted);font-size:.8rem}.vocab-card__translation{color:var(--color-text);font-size:.95rem;font-weight:600}.vocab-card__book{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.73rem;font-style:italic;overflow:hidden}.vocab-card__delete{width:22px;height:22px;color:var(--color-text-muted);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:.6rem;transition:background .12s,color .12s;display:flex;position:absolute;top:8px;right:8px}.vocab-card:hover .vocab-card__delete{opacity:1}.vocab-card__delete:hover{color:#ef4444;background:#ef44441a}.profile-page{padding:40px 0 64px}.profile-state{color:var(--color-text-muted);text-align:center;margin-top:64px;font-size:.95rem}.profile-header{align-items:center;gap:20px;margin-bottom:32px;display:flex}.profile-header__info{min-width:0}.profile-name{letter-spacing:-.03em;color:var(--color-text);margin:0 0 4px;font-size:1.55rem;font-weight:800}.profile-since{color:var(--color-text-muted);margin:0;font-size:.82rem}.profile-stats{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:40px;display:grid}.profile-stat{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);text-align:center;flex-direction:column;align-items:center;gap:5px;padding:18px 12px;display:flex}.profile-stat__value{color:var(--color-primary);letter-spacing:-.04em;font-size:2rem;font-weight:800;line-height:1}.profile-stat__label{text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-muted);font-size:.7rem;font-weight:700}.profile-section__title{color:var(--color-text);border-bottom:2px solid var(--color-border);margin:0 0 14px;padding-bottom:10px;font-size:1rem;font-weight:700}.profile-groups{flex-direction:column;gap:8px;display:flex}.profile-group-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);align-items:center;gap:14px;padding:13px 16px;transition:box-shadow .12s;display:flex}.profile-group-card:hover{box-shadow:0 3px 12px #0000000f}.profile-group-card__icon{flex-shrink:0;font-size:1.3rem;line-height:1}.profile-group-card__info{flex:1;min-width:0}.profile-group-card__book{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;margin:0 0 3px;font-size:.9rem;font-weight:700;overflow:hidden}.profile-group-card__streak{color:var(--color-text-muted);margin:0;font-size:.77rem}.profile-group-card__streak-value{color:var(--color-text);font-weight:700}.profile-group-card__sep{opacity:.5;margin:0 2px}.profile-empty{color:var(--color-text-muted);text-align:center;margin:0;padding:36px 0;font-size:.88rem}.profile-certs{flex-direction:column;gap:8px;display:flex}.profile-cert-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);align-items:center;gap:14px;padding:14px 16px;transition:box-shadow .12s;display:flex}.profile-cert-card:hover{box-shadow:0 3px 12px #0000000f}.profile-cert-card__badge{flex-shrink:0;font-size:1.6rem;line-height:1}.profile-cert-card__info{flex:1;min-width:0}.profile-cert-card__title{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;margin:0 0 2px;font-size:.92rem;font-weight:700;overflow:hidden}.profile-cert-card__meta{color:var(--color-text-muted);margin:0 0 2px;font-size:.78rem}.profile-cert-card__date{color:var(--color-text-muted);margin:0;font-size:.72rem}@media (width<=480px){.profile-stats{grid-template-columns:repeat(3,1fr);gap:8px}.profile-stat{padding:14px 8px}.profile-stat__value{font-size:1.5rem}}.discover-page h1{background:linear-gradient(130deg, var(--color-text) 15%, var(--color-primary) 100%);-webkit-text-fill-color:transparent;letter-spacing:-.04em;-webkit-background-clip:text;background-clip:text;margin-bottom:4px;font-size:2.5rem;font-weight:800;display:inline-block}.discover-toolbar{flex-wrap:wrap;align-items:center;gap:14px;margin:22px 0 28px;display:flex}.discover-sort{align-items:center;gap:6px;display:flex}.discover-sort__label{color:var(--color-text-muted);font-size:.82rem;font-weight:600}.discover-sort-btn{cursor:pointer;border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);border-radius:999px;padding:6px 16px;font-family:inherit;font-size:.82rem;font-weight:600;line-height:1;transition:background .15s,color .15s,border-color .15s}.discover-sort-btn:hover:not(.discover-sort-btn--active){border-color:var(--color-primary);color:var(--color-primary)}.discover-sort-btn--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.discover-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px;padding-bottom:64px;display:grid}.discover-empty{text-align:center;margin-top:60px}.discover-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:inherit;flex-direction:column;text-decoration:none;transition:box-shadow .15s,transform .15s;display:flex;overflow:hidden}.discover-card:hover{transform:translateY(-3px);box-shadow:0 8px 28px #0000001a}.discover-card__cover{background:var(--color-border);flex-shrink:0;height:190px;position:relative;overflow:hidden}.discover-card__img{object-fit:cover;width:100%;height:100%;display:block}.discover-card__cover-placeholder{opacity:.25;justify-content:center;align-items:center;width:100%;height:100%;font-size:3rem;display:flex}.discover-card__lang-badge{color:#fff;letter-spacing:.07em;-webkit-backdrop-filter:blur(4px);background:#0000008c;border-radius:999px;padding:3px 7px;font-size:.62rem;font-weight:800;position:absolute;top:8px;right:8px}.discover-card__body{flex-direction:column;flex:1;gap:3px;padding:14px 14px 16px;display:flex}.discover-card__title{color:var(--color-text);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.88rem;font-weight:700;line-height:1.35;display:-webkit-box;overflow:hidden}.discover-card__host{color:var(--color-text-muted);margin:2px 0 0;font-size:.74rem}.discover-card__meta{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.discover-card__members,.discover-card__page{color:var(--color-text-muted);background:var(--color-bg);border:1px solid var(--color-border);border-radius:999px;padding:2px 8px;font-size:.72rem;font-weight:600}.discover-card__join{color:var(--color-primary);margin-top:auto;padding-top:10px;font-size:.78rem;font-weight:700}@media (width<=600px){.discover-page h1{font-size:1.9rem}.discover-grid{grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:12px}.discover-toolbar{gap:10px}}.settings-page{padding:48px 0 80px}.settings-container{flex-direction:column;gap:20px;max-width:700px;display:flex}.settings-hero{margin-bottom:4px}.settings-hero__title{letter-spacing:-.035em;color:var(--color-text);margin:0 0 8px;font-size:2.3rem;font-weight:800}.settings-hero__subtitle{color:var(--color-text-muted);max-width:54ch;margin:0 0 18px;font-size:1rem;line-height:1.55}.settings-hero__rule{background:linear-gradient(90deg, var(--color-primary), #7c5cbf00);border-radius:999px;width:76px;height:3px;display:block}.settings-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:26px 30px 30px}.settings-card__head{border-bottom:1px solid var(--color-border-light);align-items:center;gap:14px;margin-bottom:22px;padding-bottom:18px;display:flex}.settings-card__icon{background:linear-gradient(150deg, #fff, var(--color-surface-2));border:1px solid var(--color-border-light);width:44px;height:44px;box-shadow:var(--shadow-sm);border-radius:13px;flex-shrink:0;place-items:center;font-size:1.2rem;line-height:1;display:grid}.settings-card__heading{min-width:0}.settings-card__title{letter-spacing:-.01em;color:var(--color-text);margin:0 0 3px;font-size:1.02rem;font-weight:700}.settings-card__hint{color:var(--color-text-muted);margin:0;font-size:.83rem;line-height:1.45}.settings-pill-group{flex-wrap:wrap;gap:10px;display:flex}.settings-pill{border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;border-radius:999px;padding:9px 22px;font-family:inherit;font-size:.88rem;font-weight:600;transition:background .2s,color .2s,border-color .2s,box-shadow .2s,transform .16s}.settings-pill:hover{border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-1px)}.settings-pill--active,.settings-pill--active:hover{background:var(--color-primary);border-color:var(--color-primary);color:#fff;box-shadow:var(--shadow-purple);transform:translateY(-1px)}.settings-pill:active{transform:translateY(0)}.settings-name-form{align-items:stretch;gap:12px;display:flex}.settings-name-input{border:1.5px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface-2);min-width:0;color:var(--color-text);outline:none;flex:1;padding:12px 18px;font-family:inherit;font-size:.95rem;transition:background .18s,border-color .18s,box-shadow .18s}.settings-name-input::placeholder{color:var(--color-text-subtle)}.settings-name-input:focus{background:var(--color-surface);border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.settings-name-form .settings-save-btn{border-radius:var(--radius);flex-shrink:0;padding-inline:26px}.settings-device-list{flex-direction:column;display:flex}.settings-device-row{justify-content:space-between;align-items:center;gap:12px;padding:14px 0;display:flex}.settings-device-row+.settings-device-row{border-top:1px solid var(--color-border-light)}.settings-device-row:first-child{padding-top:2px}.settings-device-row:last-child{padding-bottom:2px}.settings-device-label{color:var(--color-text);font-size:.92rem;font-weight:500}.settings-badge{background:var(--color-surface-2);color:var(--color-text-muted);border:1px solid var(--color-border-light);border-radius:999px;align-items:center;gap:7px;padding:6px 14px 6px 11px;font-size:.8rem;font-weight:600;display:inline-flex}.settings-badge__dot{background:var(--color-text-subtle);border-radius:50%;width:7px;height:7px;box-shadow:0 0 0 3px #a098902e}.settings-badge--on{background:var(--color-primary-light);color:var(--color-primary-dark);border-color:#7c5cbf38}.settings-badge--on .settings-badge__dot{background:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-glow)}.settings-theme-grid{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.settings-theme-card{border:2px solid var(--color-border-light);background:var(--color-surface);cursor:pointer;border-radius:18px;flex-direction:column;gap:10px;padding:10px 10px 13px;font-family:inherit;transition:transform .18s,box-shadow .18s,border-color .18s;display:flex}.settings-theme-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border);transform:translateY(-4px)}.settings-theme-card--active,.settings-theme-card--active:hover{border-color:var(--color-primary);box-shadow:0 0 0 4px var(--color-primary-light), var(--shadow-md)}.settings-theme-card__preview{background:var(--swatch-bg,#f5f0e8);border:1px solid #0000000d;border-radius:12px;place-items:center;height:84px;display:grid;position:relative;overflow:hidden}.settings-theme-card__page{background:var(--swatch-surface,#fff);border-radius:7px;flex-direction:column;gap:5px;width:58%;height:66%;padding:9px 9px 0;display:flex;box-shadow:0 3px 9px #00000024}.settings-theme-card__bar{background:var(--swatch-accent,#7c5cbf);border-radius:999px;width:44%;height:5px}.settings-theme-card__line{background:var(--swatch-muted,#6b6461);opacity:.42;border-radius:999px;height:3px}.settings-theme-card__line--short{width:64%}.settings-theme-card__check{background:var(--color-primary);color:#fff;opacity:0;border-radius:50%;place-items:center;width:22px;height:22px;transition:opacity .18s,transform .18s;display:grid;position:absolute;top:7px;right:7px;transform:scale(.5);box-shadow:0 2px 7px #7c5cbf80}.settings-theme-card--active .settings-theme-card__check{opacity:1;transform:scale(1)}.settings-theme-card__name{letter-spacing:-.005em;color:var(--color-text);text-align:center;font-size:.82rem;font-weight:600}@media (width<=640px){.settings-page{padding:28px 0 60px}.settings-card{padding:22px 20px 24px}.settings-hero__title{font-size:1.9rem}.settings-theme-grid{grid-template-columns:repeat(2,1fr)}.settings-name-form{flex-direction:column;align-items:stretch}.settings-name-form .settings-save-btn{width:100%}}
