@import"https://fonts.googleapis.com/css2?family=Rubik:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,400;1,500&display=swap";@import"https://fonts.googleapis.com/css2?family=Literata:ital,opsz,wght@0,7..72,400;0,7..72,500;0,7..72,600;0,7..72,700;1,7..72,400;1,7..72,500&display=swap";@import"https://fonts.googleapis.com/css2?family=Vazirmatn:wght@400;600;700;800&display=swap";@import"https://fonts.googleapis.com/css2?family=Noto+Naskh+Arabic:wght@400;500;600;700&display=swap";.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 20px;background:var(--surface-elevated, #fff);border-top:1.5px solid var(--border, #e5e7eb);box-shadow:0 -2px 12px #00000014;font-size:13px;animation:cookie-slide-up .3s ease-out}@keyframes cookie-slide-up{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.cookie-banner__text{margin:0;color:var(--text-light, #6b7280);line-height:1.4;flex:1}.cookie-banner__text a{color:var(--blue);text-decoration:underline}.cookie-banner__actions{display:flex;gap:8px;flex-shrink:0}.cookie-banner__btn{padding:8px 18px;border-radius:12px;border:none;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .15s}.cookie-banner__btn:hover{opacity:.85}.cookie-banner__btn--accept{background:var(--green, #58cc02);color:#fff}.cookie-banner__btn--decline{background:var(--surface, #f7f7f7);color:var(--text-light, #6b7280);border:1.5px solid var(--border, #e5e7eb)}[data-theme=dark] .cookie-banner{background:var(--surface-elevated);border-top-color:var(--border, #333)}.cookie-banner__link{background:none;border:none;padding:0;color:var(--blue);text-decoration:underline;font:inherit;cursor:pointer}.notif-fg-toast{position:fixed;bottom:calc(72px + env(safe-area-inset-bottom,0px));left:50%;transform:translate(-50%);z-index:9999;display:flex;align-items:center;gap:12px;min-width:280px;max-width:min(420px,calc(100vw - 32px));padding:12px 14px;background:var(--surface, #fff);border:1.5px solid var(--border, #e5e7eb);border-radius:var(--radius-lg, 16px);box-shadow:0 8px 32px #00000024;cursor:pointer;-webkit-user-select:none;user-select:none}.notif-fg-toast__icon{flex-shrink:0;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center}.notif-fg-toast__content{flex:1;min-width:0}.notif-fg-toast__title{font-size:.88rem;font-weight:600;color:var(--text, #333);margin:0 0 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-fg-toast__body{font-size:.8rem;color:var(--text-light, #888);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-fg-toast__close{flex-shrink:0;background:none;border:none;padding:4px;cursor:pointer;color:var(--text-light, #aaa);display:flex;align-items:center;border-radius:50%;transition:background .15s}.notif-fg-toast__close:hover{background:var(--border, #e5e7eb)}[data-theme=dark] .notif-fg-toast{box-shadow:0 8px 32px #00000073}.approval-dialog__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:220;background:#0f172a61;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:flex-end;justify-content:center;padding:16px}.approval-dialog{position:relative;width:min(100%,420px);background:var(--surface);border:1px solid var(--glass-border);border-radius:24px;box-shadow:0 24px 60px #0f172a2e;padding:24px;text-align:center}.approval-dialog__close{position:absolute;top:14px;right:14px;width:36px;height:36px;border:1px solid var(--border);border-radius:999px;background:var(--surface);display:inline-flex;align-items:center;justify-content:center;color:var(--text-light)}.approval-dialog__icon{width:44px;height:44px;border-radius:14px;background:color-mix(in srgb,var(--primary) 12%,var(--surface));color:var(--primary);display:inline-flex;align-items:center;justify-content:center;margin:0 auto 12px}.approval-dialog__title{font-size:20px;font-weight:600;color:var(--text);margin:0 0 6px}.approval-dialog__body{font-size:14px;line-height:1.5;color:var(--text-light);margin:0 0 16px}.approval-dialog__input{width:100%;height:48px;border:1px solid var(--border);border-radius:14px;background:var(--surface-elevated);color:var(--text);font-size:18px;font-family:var(--font);text-align:center;letter-spacing:.2em;padding:0 16px;outline:none;transition:border-color .15s}.approval-dialog__input:focus{border-color:var(--primary)}.approval-dialog__input--error{border-color:var(--red)}.approval-dialog__error{font-size:13px;color:var(--red);margin:6px 0 0}.approval-dialog__actions{display:flex;gap:10px;margin-top:16px}.discard-dialog__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-overlay);background:#0f172a61;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:flex-end;justify-content:center;padding:16px}.discard-dialog{position:relative;width:min(100%,420px);background:var(--surface);border:1px solid var(--glass-border);border-radius:24px;box-shadow:0 24px 60px #0f172a2e;padding:24px}.discard-dialog__close{position:absolute;top:14px;right:14px;width:36px;height:36px;border:1px solid var(--border);border-radius:999px;background:var(--surface);display:inline-flex;align-items:center;justify-content:center;color:var(--text-light)}.discard-dialog__title{font-size:22px;font-weight:600;color:var(--text);margin:0 0 8px}.discard-dialog__body{font-size:15px;line-height:1.55;color:var(--text-light);margin:0 0 20px}.discard-dialog__actions{display:flex;gap:10px}.discard-dialog__btn{flex:1;min-height:48px;border-radius:16px;font-size:15px;font-weight:600;border:1px solid var(--border);font-family:var(--font)}.discard-dialog__btn--ghost{background:var(--surface-elevated);color:var(--text)}.discard-dialog__btn--danger{background:color-mix(in srgb,var(--red) 14%,var(--surface));border-color:color-mix(in srgb,var(--red) 28%,var(--border));color:var(--red-dark)}.discard-dialog__btn--primary{background:color-mix(in srgb,var(--green) 14%,var(--surface));border-color:color-mix(in srgb,var(--green) 28%,var(--border));color:var(--green-dark)}.home-screen--tabbed{display:flex;flex-direction:column}.home-tabs{display:flex;gap:4px;padding:4px;margin:12px 20px 16px;position:relative;background:var(--tint-neutral);border-radius:14px;border:1.5px solid var(--border)}@media(max-width:767px){.home-tabs{margin:12px 0 16px}}.home-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;background:none;border:none;border-radius:10px;font-family:var(--font);font-size:15px;font-weight:600;color:var(--text-light);cursor:pointer;position:relative;z-index:1;transition:color .25s ease;-webkit-tap-highlight-color:transparent}.home-tab svg{flex-shrink:0;position:relative;z-index:1}.home-tab__icon--play{transform:translate(4px)}.home-tab span{position:relative;z-index:1}.home-tab:hover{color:var(--text)}.home-tab--active{color:var(--blue)}.home-tab__indicator{position:absolute;top:3px;right:3px;bottom:3px;left:3px;background:var(--surface);border:1.5px solid var(--border);border-radius:10px;box-shadow:0 2px 8px #0000001a;z-index:0;will-change:transform}[data-theme=dark] .home-tab__indicator{background:var(--surface-elevated);border-color:#ffffff1a;box-shadow:0 2px 8px #0006}.home-content{flex:1;padding:0 20px 40px;min-height:0;overflow:clip}@media(max-width:767px){.home-content{padding:0 0 40px}}.study-loading{text-align:center;padding:60px 20px;color:var(--text-light);font-size:16px;font-weight:600}.home-page__bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;background:var(--gradient-hero);pointer-events:none}.home-page{display:flex;justify-content:center;gap:0;min-height:100%;padding-bottom:env(safe-area-inset-bottom,0px)}.home-page__main{width:100%;max-width:520px;margin:0 auto;padding:8px 16px 40px;display:flex;flex-direction:column;gap:20px}.home-page--desktop{max-width:var(--max-width);margin:0 auto;padding:10px 20px 0;gap:40px}.home-page--desktop .home-page__main{flex:1;max-width:none;min-width:0;margin:0;padding:8px 0 40px;gap:24px}.home-page__sidebar{width:380px;flex-shrink:0;padding:8px 0 40px;display:flex;flex-direction:column;gap:20px;align-self:flex-start;position:relative}.home-page__sidebar:before{content:"";position:absolute;left:-20px;top:24px;bottom:56px;width:1px;background:linear-gradient(to bottom,transparent,var(--border) 15%,var(--border) 85%,transparent);opacity:.6}.greeting-header{display:flex;align-items:center;justify-content:space-between;padding:12px 0 4px}.greeting-header__title{font-size:1.75rem;font-weight:600;line-height:1.15;color:var(--text);margin:0;letter-spacing:-.02em}.greeting-header__stats{display:flex;gap:8px}.greeting-header__pill{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:20px;background:var(--surface);border:1.5px solid var(--border);box-shadow:var(--shadow-card);font-size:.8rem;font-weight:700;transition:border-color .2s,box-shadow .2s}.greeting-header__pill--streak:hover{border-color:var(--orange);box-shadow:0 2px 12px #ff960026}.greeting-header__pill--xp:hover{border-color:var(--amber, #f59e0b);box-shadow:0 2px 12px #ffb30026}.greeting-header__pill-icon--streak{color:var(--orange)}.greeting-header__pill-icon--xp{color:var(--amber, #f59e0b)}@keyframes flame-flicker{0%,to{transform:scale(1)}50%{transform:scale(1.12)}}.greeting-header__pill--streak svg{animation:flame-flicker 2s ease-in-out infinite}.greeting-header__pill-value{color:var(--text)}.continue-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;box-shadow:var(--shadow-card);transition:box-shadow .2s ease}.continue-card:hover{box-shadow:var(--shadow-card-hover)}.continue-card__gradient{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,var(--green),var(--green-dark, #46a302),var(--green));background-size:300% 300%;animation:gradient-shift 6s ease infinite}.continue-card__content{position:relative;z-index:1;display:flex;align-items:center;gap:16px;padding:24px}.continue-card__left{flex-shrink:0}.continue-card__progress-ring{position:relative;width:56px;height:56px;display:flex;align-items:center;justify-content:center}.continue-card__ring-svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;transform:rotate(-90deg)}.continue-card__ring-track{fill:none;stroke:#fff3;stroke-width:4}.continue-card__ring-fill{fill:none;stroke:#fff;stroke-width:4;stroke-linecap:round}.continue-card__play-icon{color:#fff;position:relative;z-index:1}.continue-card__body{flex:1;min-width:0}.continue-card__label{display:block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#ffffffbf;margin-bottom:3px}.continue-card__title{margin:0;font-size:1.15rem;font-weight:700;color:#fff;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.continue-card__progress-text{font-size:.75rem;font-weight:600;color:#ffffffb3;margin-top:2px}.continue-card__cta{flex-shrink:0;width:48px;height:48px;border-radius:16px;border:none;background:#fff;color:var(--green);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 var(--btn-3d-depth) 0 #00000026;transition:transform .1s,box-shadow .1s}.continue-card__cta:active{transform:translateY(var(--btn-3d-depth));box-shadow:0 0 #00000026}.continue-card__cta:disabled{opacity:.7;cursor:default}.continue-card--empty{background:var(--surface);border:1.5px solid var(--border);box-shadow:var(--shadow-card)}.continue-card--empty .continue-card__body{display:flex;flex-direction:column;align-items:center;text-align:center;padding:28px 16px;gap:8px}.continue-card--empty .continue-card__icon{color:var(--green);margin-bottom:4px}.continue-card--empty .continue-card__title{color:var(--text);font-size:1.1rem;white-space:normal}.continue-card--empty .continue-card__subtitle{margin:0;color:var(--text-secondary, var(--text-light));font-size:.85rem;line-height:1.4}.devotion-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;box-shadow:var(--shadow-card);transition:box-shadow .2s ease}.devotion-card:hover{box-shadow:var(--shadow-card-hover)}.devotion-card__gradient{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,var(--devotion-gradient-from, #f5f3ff),var(--devotion-gradient-to, #ede9fe))}.devotion-card__content{position:relative;z-index:1;padding:20px 24px;display:flex;flex-direction:column}.devotion-card__header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.devotion-card__label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--devotion-accent, var(--text-secondary))}.devotion-card__title{margin:0 0 4px;font-size:1.05rem;font-weight:700;color:var(--text);line-height:1.3}.devotion-card__passage{margin:0 0 14px;font-size:.85rem;color:var(--text-secondary, var(--text-light));font-style:italic}.devotion-card__footer{display:flex;align-items:center;justify-content:space-between}.devotion-card__stages{display:flex;gap:6px}.devotion-card__stage-dot{width:10px;height:10px;border-radius:50%;background:var(--devotion-accent, var(--text-tertiary));opacity:.3;transition:opacity .2s}.devotion-card__begin{font-size:.8rem;font-weight:600;color:var(--devotion-accent, var(--text-secondary));display:flex;align-items:center;gap:4px}.quests-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:20px 24px;box-shadow:var(--shadow-card);transition:box-shadow .2s ease}.quests-card:hover{box-shadow:var(--shadow-card-hover)}.quests-card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.quests-card__title{margin:0;font-size:.9rem;font-weight:700;color:var(--text)}.quests-card__summary{font-size:.75rem;font-weight:600;color:var(--text-secondary, var(--text-light))}.quests-card__summary strong{color:var(--green)}.quests-card__list{display:flex;flex-direction:column;gap:8px}.votd-card{position:relative;background:var(--surface);border:1.5px solid var(--border);border-left:4px solid var(--amber, #f59e0b);border-radius:var(--radius-lg);padding:24px 24px 20px;box-shadow:var(--shadow-card);overflow:hidden;transition:box-shadow .2s ease}.votd-card:hover{box-shadow:var(--shadow-card-hover)}.votd-card:before{content:"“";position:absolute;top:-8px;left:16px;font-family:var(--font-serif, "Literata", Georgia, serif);font-size:120px;line-height:1;color:var(--amber, #f59e0b);opacity:.07;pointer-events:none}.votd-card__content{position:relative;z-index:1}.votd-card__label{display:block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--amber, #f59e0b);margin-bottom:12px}.votd-card__text{margin:0 0 14px;font-family:var(--font-serif, "Literata", Georgia, serif);font-size:1.1rem;line-height:1.7;color:var(--text);font-style:italic;quotes:none}.votd-card__ref{display:block;font-family:var(--font-sans, "Rubik", sans-serif);font-size:.8rem;font-weight:600;font-variant:small-caps;color:var(--text-secondary, var(--text-light));font-style:normal}.votd-card__share{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary, var(--text-light));display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-card);transition:background .15s,box-shadow .15s}.votd-card__share:hover{background:var(--tint-orange);box-shadow:var(--shadow-card-hover)}.quick-actions__title{margin:0 0 12px;font-size:.9rem;font-weight:700;color:var(--text)}.quick-actions__grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(max-width:1023px){.quick-actions__grid{grid-template-columns:repeat(4,1fr);gap:10px}}.quick-actions__tile{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 12px;border-radius:var(--radius);border:1.5px solid var(--border);background:var(--surface);cursor:pointer;box-shadow:var(--shadow-card);transition:box-shadow .2s,transform .2s}.quick-actions__tile:hover{box-shadow:var(--shadow-card-hover)}.quick-actions__icon-wrap{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;transition:background .2s}.quick-actions__tile[data-tint=blue] .quick-actions__icon-wrap{background:var(--tint-blue);color:var(--blue)}.quick-actions__tile[data-tint=orange] .quick-actions__icon-wrap{background:var(--tint-orange);color:var(--orange)}.quick-actions__tile[data-tint=purple] .quick-actions__icon-wrap{background:var(--tint-purple);color:var(--purple)}.quick-actions__tile[data-tint=green] .quick-actions__icon-wrap{background:var(--tint-green);color:var(--green)}.quick-actions__label{font-size:.78rem;font-weight:600;color:var(--text);text-align:center}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.home-skeleton{border-radius:var(--radius-lg);background:linear-gradient(90deg,var(--bg-secondary, #f5f5f5) 25%,var(--border) 50%,var(--bg-secondary, #f5f5f5) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}.home-skeleton--hero{height:100px}.home-skeleton--card{height:120px}.home-skeleton--small{height:72px}[data-theme=dark] .continue-card__gradient{background:linear-gradient(135deg,#2d7a00,#1e5900,#2d7a00);background-size:300% 300%;animation:gradient-shift 6s ease infinite}[data-theme=dark] .continue-card__cta{background:#fffffff2}[data-theme=dark] .devotion-card__gradient{opacity:.85}[data-theme=dark] .votd-card{border-left-color:var(--amber, #f59e0b)}@media(min-width:1024px){.greeting-header__title{font-size:2rem}.continue-card__content{padding:28px}.quests-card{padding:22px 28px}.votd-card{padding:28px 28px 24px}}.home-hero{padding:calc(14px + var(--ion-safe-area-top, env(safe-area-inset-top, 0px))) 20px 14px;max-width:var(--max-width);margin:0 auto;z-index:50;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);border-bottom-left-radius:16px;border-bottom-right-radius:16px;transition:box-shadow .25s ease}.home-hero.scrolled{box-shadow:0 4px 20px #0000000f}[data-theme=dark] .home-hero.scrolled{box-shadow:0 4px 20px #0000004d}.hero-top-row{display:flex;align-items:center;justify-content:space-between}.app-brand{display:flex;align-items:center;gap:10px}.biblerific-logo{display:block;width:100%;height:auto;overflow:visible}.biblerific-logo--brand{max-width:115px}@media(min-width:768px){.biblerific-logo--brand{max-width:128px}}.biblerific-logo--login{max-width:180px;margin:0 auto 12px}.brand-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:var(--tint-blue)}.brand-name{font-size:22px;font-weight:600;color:var(--text);letter-spacing:-.5px}.hero-actions{display:flex;align-items:center;gap:8px;position:relative}.hero-stat{display:inline-flex;align-items:center;gap:5px;font-size:14px;font-weight:600;color:var(--text);background:var(--tint-yellow);border:1.5px solid var(--tint-yellow-border);border-radius:20px;padding:6px 14px;transition:transform .15s ease}.hero-stat:hover{transform:scale(1.04)}.theme-toggle{width:38px;height:38px;border:1.5px solid var(--border);border-radius:50%;background:var(--surface);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s,background .15s}.theme-toggle:hover{border-color:var(--blue);background:var(--surface-elevated)}.stats-trigger{display:inline-flex;align-items:center;gap:4px;-moz-appearance:none;appearance:none;-webkit-appearance:none;border:1.5px solid var(--tint-yellow-border);border-radius:20px;background:var(--tint-yellow);padding:0 12px;height:36px;font-size:13px;font-weight:600;color:var(--text);cursor:pointer;white-space:nowrap;transition:border-color .15s ease,background .15s ease,transform .15s ease}.stats-trigger:hover{transform:scale(1.04)}.stats-trigger:focus-visible{outline:2px solid var(--blue);outline-offset:2px}.stats-trigger__fire{color:#ff6b35;flex-shrink:0}.stats-trigger__star{color:#ffb300;flex-shrink:0}.stats-trigger__divider{opacity:.35;font-weight:400;margin:0 1px}.stats-trigger__level{margin-inline-start:3px;font-size:11px;color:var(--text-light);font-weight:600;letter-spacing:.3px}.notif-badge{position:absolute;top:4px;right:4px;width:8px;height:8px;border-radius:50%;background:var(--orange, #f59e0b);border:1.5px solid var(--surface, #fff)}.notif-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.notif-status{font-size:.85rem;color:var(--text-light, #888);font-weight:500}.notif-status--ready{color:var(--green, #58cc02);font-weight:600}.notif-status--error{color:var(--red, #ef4444);font-size:.8rem}.notif-action-btn{padding:5px 14px;border-radius:8px;border:1.5px solid var(--blue);background:transparent;color:var(--blue);font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s}.notif-action-btn:hover{background:var(--surface-elevated, #f0f0ff)}.notif-action-btn--danger{border-color:var(--red, #ef4444);color:var(--red, #ef4444)}.notif-action-btn--danger:hover{background:#ef444414}.notif-row__left{display:flex;align-items:center;gap:6px}.notif-progress-wrap{display:flex;align-items:center;gap:10px;width:100%}.notif-progress-bar{flex:1;height:6px;border-radius:3px;background:var(--border, #e5e7eb);overflow:hidden}.notif-progress-fill{height:100%;border-radius:3px;background:var(--blue);transition:width .4s ease}.notif-progress-text{font-size:.78rem;font-weight:600;color:var(--text, #333);min-width:32px;text-align:end;font-variant-numeric:tabular-nums}.notif-empty{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px 12px;text-align:center}.notif-empty__title{font-size:.92rem;font-weight:600;color:var(--text, #333);margin:4px 0 0}.notif-empty__subtitle{font-size:.8rem;color:var(--text-light, #999);line-height:1.4;margin:0}.notif-count-badge{position:absolute;top:-4px;right:-6px;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:var(--red, #ef4444);color:#fff;font-size:.65rem;font-weight:600;line-height:18px;text-align:center;font-variant-numeric:tabular-nums;pointer-events:none;border:1.5px solid var(--surface, #fff);z-index:2}.notif-popover{width:340px;padding:0;overflow:hidden;max-height:500px;overflow-y:auto}.notif-popover__header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 8px;border-bottom:1px solid var(--border, #e5e7eb)}.notif-popover__title{font-size:.9rem;font-weight:600;color:var(--text, #333)}.notif-preview-list{display:flex;flex-direction:column;overscroll-behavior:contain}.notif-preview-item{display:flex;align-items:flex-start;gap:10px;width:100%;text-align:start;padding:10px 14px;background:none;border:none;cursor:pointer;border-bottom:1px solid var(--border, #f0f0f0);transition:background .12s}.notif-preview-item:hover{background:var(--surface-elevated, #f9f9ff)}.notif-preview-item--unread{background:var(--surface-elevated, #f4f8ff)}.notif-preview-item__icon{flex-shrink:0;width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-top:1px}.notif-preview-item__content{flex:1;min-width:0}.notif-preview-item__title{font-size:.82rem;font-weight:600;color:var(--text, #333);margin:0 0 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-preview-item--unread .notif-preview-item__title{font-weight:600}.notif-preview-item__body{font-size:.76rem;color:var(--text-light, #777);margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.35}.notif-preview-item__meta{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:5px}.notif-preview-item__time{font-size:.7rem;color:var(--text-light, #aaa);font-variant-numeric:tabular-nums}.notif-preview-item__dot{width:7px;height:7px;border-radius:50%;background:var(--blue)}.notif-see-all-btn{display:flex;align-items:center;justify-content:center;gap:4px;width:100%;padding:10px 14px;background:none;border:none;border-top:1px solid var(--border, #e5e7eb);font-size:.8rem;font-weight:600;color:var(--blue);cursor:pointer;transition:background .12s}.notif-see-all-btn:hover{background:var(--surface-elevated, #f4f8ff)}.notif-category-pill{display:inline-flex;align-items:center;padding:2px 10px;border-radius:20px;font-size:.72rem;font-weight:600;letter-spacing:.02em;text-transform:uppercase}.notif-detail-card{position:fixed;top:10px;right:12px;width:400px;max-width:calc(100vw - 24px);background:var(--surface, #fff);border:1.5px solid var(--border, #e5e5e5);border-radius:var(--radius-lg, 16px);box-shadow:0 8px 32px #0000001f;z-index:500;padding:14px 16px 16px;display:flex;flex-direction:column;gap:6px}.notif-detail-card__header{display:flex;align-items:center;gap:8px}.notif-detail-card__icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.notif-detail-card__label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notif-detail-card__time{font-size:.68rem;color:var(--text-light, #aaa);margin-inline-start:auto;white-space:nowrap;flex-shrink:0}.notif-detail-card__close{width:30px;height:30px;border-radius:50%;background:var(--surface-elevated, #f0f0f0);border:1.5px solid var(--border, #e5e5e5);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text, #444);flex-shrink:0;margin-inline-start:8px;transition:background .15s,border-color .15s}.notif-detail-card__close:hover{background:var(--border, #ddd);border-color:var(--text-light, #aaa)}.notif-detail-card__title{font-size:.95rem;font-weight:600;color:var(--text, #222);margin:2px 0 0;line-height:1.35;overflow-wrap:break-word;word-break:break-word}.notif-detail-card__body{font-size:.85rem;color:var(--text-secondary, #555);line-height:1.5;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;overflow-wrap:break-word;word-break:break-word}.notif-detail-card__cta{display:flex;align-items:center;justify-content:center;gap:5px;width:100%;padding:9px 0;border-radius:10px;background:var(--blue);color:#fff;font-size:.85rem;font-weight:600;border:none;cursor:pointer;margin-top:4px;transition:opacity .15s}.notif-detail-card__cta:hover{opacity:.9}.settings-wrap{position:relative}.settings-trigger{width:44px;height:44px;border-radius:50%;border:1.5px solid var(--border);background:var(--surface);color:var(--text-light);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s,background .15s}.settings-trigger--sm{width:36px;height:36px}.settings-trigger:hover{border-color:var(--blue);color:var(--blue);background:var(--surface-elevated)}.settings-popover{position:absolute;right:0;top:calc(100% + 8px);min-width:312px;z-index:200;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 8px 32px #0000001f;padding:20px}.settings-section{padding:0 0 16px;margin-bottom:16px}.settings-section:last-child{margin-bottom:0;padding-bottom:0}.settings-section__title{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);margin-bottom:10px}.settings-group__header{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-light);padding:0 0 8px 4px;margin:0}.settings-group{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:16px}.settings-group__body{padding:0 16px}.settings-row{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--border);background:none;border-inline:none;border-top:none;width:100%;text-align:start;font-family:var(--font);color:var(--text)}.settings-row:last-child{border-bottom:none}.settings-row--nav{cursor:pointer;transition:background .15s}.settings-row--nav:hover{background:var(--tint-neutral)}.settings-row__icon-wrap{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff}.settings-row__body{flex:1;min-width:0;display:flex;flex-direction:column}.settings-row__label{font-size:14px;font-weight:500;color:var(--text);line-height:1.25}.settings-row__desc{font-size:12px;color:var(--text-light);margin-top:2px;line-height:1.3}.settings-row__control{flex-shrink:0;display:flex;align-items:center;gap:6px}.settings-row__chevron{color:var(--text-light);opacity:.5;flex-shrink:0}.settings-toggle{position:relative;width:48px;height:28px;border-radius:14px;border:2px solid var(--border);background:var(--tint-neutral);cursor:pointer;transition:background .25s ease,border-color .25s ease;padding:0;flex-shrink:0}.settings-toggle:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:var(--text-light);transition:transform .25s cubic-bezier(.4,0,.2,1),background .25s ease,width .2s ease,height .2s ease}.settings-toggle.on{background:var(--green);border-color:var(--green-dark)}.settings-toggle.on:after{transform:translate(20px);background:#fff;width:20px;height:20px;top:2px}.settings-toggle__check{position:absolute;top:50%;right:5px;transform:translateY(-50%);color:#fff;opacity:0;transition:opacity .2s ease;pointer-events:none;z-index:1}.settings-toggle.on .settings-toggle__check{opacity:1}.seg-picker{display:flex;gap:2px;background:var(--tint-neutral);border-radius:10px;padding:3px}.seg-picker__btn{flex:1;height:28px;font-size:12px;font-weight:600;font-family:var(--font);color:var(--text-light);background:transparent;border:none;border-radius:8px;cursor:pointer;transition:background .2s ease,color .2s ease,box-shadow .2s ease;padding:0 8px;white-space:nowrap}.seg-picker__btn:hover:not(.active){color:var(--text)}.seg-picker__btn.active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px #00000014}[data-theme=dark] .seg-picker__btn.active{box-shadow:0 1px 4px #0000004d}.inline-stepper{display:flex;align-items:center;gap:8px}.inline-stepper__btn{width:28px;height:28px;border-radius:8px;border:1.5px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:border-color .15s,background .15s;font-family:var(--font)}.inline-stepper__btn:hover:not(:disabled){border-color:var(--blue);background:var(--tint-neutral)}.inline-stepper__btn:disabled{opacity:.3;cursor:not-allowed}.inline-stepper__value{min-width:36px;text-align:center;font-size:13px;font-weight:500;color:var(--text)}.settings-all-btn{display:flex;align-items:center;justify-content:center;gap:4px;width:100%;margin-top:12px;padding:10px 0;background:var(--tint-neutral);border:none;border-radius:10px;font-size:13px;font-weight:600;font-family:var(--font);color:var(--blue);cursor:pointer;transition:background .15s,transform .15s}.settings-all-btn:hover{background:var(--surface-elevated);transform:scale(1.02)}.settings-all-btn--danger{color:var(--red, #ef4444)}.settings-popover .theme-picker{width:100%;justify-content:center}[data-theme=dark] .settings-popover{box-shadow:0 8px 32px #0006}@media(max-width:767px){.settings-popover{position:fixed;right:12px;left:12px;min-width:auto;top:60px;max-height:calc(100dvh - 80px);overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}}@media(min-width:768px){.settings-popover.help-popover{min-width:360px}}.theme-picker{display:flex;align-items:center;gap:6px;background:var(--surface);border:1.5px solid var(--border);border-radius:20px;padding:4px 6px}.theme-swatch{width:24px;height:24px;border-radius:50%;border:2px solid var(--border);cursor:pointer;position:relative;transition:border-color .2s ease,box-shadow .2s ease;padding:0;outline:none;background:none}.theme-swatch:focus-visible{box-shadow:0 0 0 2px var(--blue)}.theme-swatch:after{content:"";position:absolute;top:2px;right:2px;bottom:2px;left:2px;border-radius:50%;background:var(--swatch-color)}.theme-swatch__ring{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;border:2px solid var(--blue);pointer-events:none}.theme-swatch--auto:after{background:linear-gradient(135deg,#fff 50%,#121214 50%);transition:transform .4s cubic-bezier(.34,1.56,.64,1)}.theme-swatch--auto:hover:after{transform:rotate(15deg)}@media(prefers-reduced-motion:reduce){.theme-swatch--auto:after{transition:none}}[data-theme=dark] .theme-swatch{border-color:#444}.profile-bubble{width:36px;height:36px;border-radius:50%;overflow:hidden;border:2px solid var(--border);padding:0;background:var(--surface);cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:border-color .15s ease,outline .15s ease,transform .15s ease;outline:2px solid transparent;outline-offset:2px}.profile-bubble:hover{border-color:var(--blue);transform:scale(1.05)}.profile-bubble--open{border-color:var(--blue);outline:2px solid var(--blue)}.profile-bubble:focus-visible{outline:2px solid var(--blue)}.profile-bubble__img{width:100%;height:100%;object-fit:cover;display:block;border-radius:50%}.profile-bubble__initials{border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#fff;letter-spacing:.3px;flex-shrink:0;font-family:var(--font)}.profile-dropdown{position:absolute;right:0;top:calc(100% + 8px);z-index:200;min-width:240px;background:var(--surface);border:1.5px solid var(--border);border-radius:16px;padding:0;box-shadow:var(--shadow-card-hover);overflow:hidden}.profile-dropdown__header{display:flex;align-items:center;gap:12px;padding:16px 16px 14px;border-bottom:1px solid var(--border)}.profile-dropdown__avatar{flex-shrink:0;border-radius:50%;overflow:hidden;border:2px solid var(--border);width:48px;height:48px;display:flex;align-items:center;justify-content:center}.profile-dropdown__avatar-img{width:100%;height:100%;object-fit:cover;display:block;border-radius:50%}.profile-dropdown__identity{display:flex;flex-direction:column;gap:2px;min-width:0}.profile-dropdown__name{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-dropdown__email{font-size:12px;color:var(--text-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.profile-dropdown__provider{display:inline-flex;align-items:center;gap:4px;margin-top:3px;font-size:11px;font-weight:600;color:var(--text-light);background:var(--tint-neutral);border:1px solid var(--border);border-radius:20px;padding:2px 7px 2px 5px;width:fit-content}.profile-dropdown__provider-icon{width:12px;height:12px;flex-shrink:0;color:var(--text-light)}.profile-dropdown__footer{padding:8px;display:flex;flex-direction:column;gap:2px}.profile-dropdown__view-btn,.profile-dropdown__signout-btn{justify-content:flex-start;margin-top:0;gap:8px;padding:9px 12px;border-radius:10px;font-size:13px}.profile-dropdown__view-btn{color:var(--blue)}.profile-dropdown__signout-btn{color:#ff4b4b;background:transparent}.profile-dropdown__signout-btn:hover{background:var(--tint-red);transform:scale(1.02)}.profile-dropdown__view-btn>svg:last-child{margin-inline-start:auto}[data-theme=dark] .profile-dropdown{box-shadow:0 8px 32px #0006}[data-theme=dark] .profile-bubble{border-color:var(--glass-border)}[data-theme=dark] .profile-bubble:hover,[data-theme=dark] .profile-bubble--open{border-color:var(--blue)}@media(max-width:767px){.profile-dropdown{position:fixed;right:12px;left:12px;min-width:auto;top:60px;max-height:calc(100dvh - 80px);overflow-y:auto;overscroll-behavior:contain}}.profile-dropdown__mobile-section{padding:8px 12px;border-bottom:1px solid var(--border, #e5e7eb)}.profile-dropdown__mobile-notif-btn{display:flex;align-items:center;gap:10px;width:100%;padding:8px 4px;background:none;border:none;cursor:pointer;color:var(--text-primary, #111);font-size:14px;font-weight:500;text-align:start;border-radius:8px;transition:background .15s}.profile-dropdown__mobile-notif-btn:hover{background:var(--surface-hover, rgba(0, 0, 0, .05))}.profile-dropdown__mobile-icon-wrap{position:relative;display:flex;align-items:center;justify-content:center;width:28px;height:28px;flex-shrink:0}.profile-dropdown__notif-badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;padding:0 3px;background:#e53e3e;color:#fff;border-radius:99px;font-size:10px;font-weight:600;line-height:16px;text-align:center;border:1.5px solid var(--surface, #fff)}.profile-dropdown__mobile-label{flex:1}.profile-dropdown__mobile-chevron{color:var(--text-tertiary, #9ca3af)}.profile-dropdown__mobile-mark-read{width:100%;padding:4px 4px 6px;background:none;border:none;color:var(--blue, #3b82f6);font-size:12px;cursor:pointer;text-align:start}[data-theme=dark] .profile-dropdown__mobile-section{border-color:var(--glass-border)}[data-theme=dark] .profile-dropdown__mobile-notif-btn{color:var(--text-primary-dark, #f1f5f9)}[data-theme=dark] .profile-dropdown__mobile-notif-btn:hover{background:#ffffff0f}[data-theme=dark] .profile-dropdown__notif-badge{border-color:var(--surface-dark, #1e293b)}.profile-dropdown__mobile-settings{padding:8px 12px;border-bottom:1px solid var(--border, #e5e7eb)}[data-theme=dark] .profile-dropdown__mobile-settings{border-color:var(--glass-border)}.profile-dropdown__mobile-settings .profile-dropdown__section-title{display:flex;align-items:center;gap:4px}.profile-dropdown__mobile-settings .settings-group{margin-top:6px}.stats-popover{min-width:300px}@media(max-width:767px){.settings-popover.stats-popover{max-height:calc(100dvh - 80px);overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}}.stats-summary-row{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--text-light)}.stats-summary-row__icon{color:var(--blue);flex-shrink:0}.stats-summary-row__text strong{color:var(--text);font-weight:600}.stats-pills--popover{flex-direction:column;gap:6px;margin-bottom:0}.stats-quests--popover{display:block}.stats-quests--popover.stats-quests{margin-top:0;padding-top:0;border-top:none}.hero-title{font-size:28px;font-weight:600;color:var(--text);line-height:1.15;letter-spacing:-.5px}.stats-panel{padding:0 0 16px}.stats-pills{display:flex;gap:8px;margin-bottom:10px}.stat-pill{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface);border:1.5px solid var(--border);border-radius:16px;flex:1;min-width:0;box-shadow:var(--shadow-card);transition:border-color .2s ease,background .2s ease,box-shadow .2s ease}.stat-pill--streak:hover{border-color:#ff6b35;background:#fff3e8;box-shadow:0 2px 12px #ff6b351f}.stat-pill--xp:hover{border-color:#ffb300;background:#fff8e1;box-shadow:0 2px 12px #ffb3001f}.stat-pill--level:hover{border-color:var(--purple);background:#f3e5f5;box-shadow:0 2px 12px #ce82ff1f}[data-theme=dark] .stat-pill--streak:hover{background:#ff6b351a}[data-theme=dark] .stat-pill--xp:hover{background:#ffb3001a}[data-theme=dark] .stat-pill--level:hover{background:#ce82ff1a}.stat-pill__icon-wrap{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-pill__icon-wrap--streak{background:#fff3e8}.stat-pill__icon-wrap--xp{background:#fff8e1}.stat-pill__icon-wrap--level{background:#f3e5f5}[data-theme=dark] .stat-pill__icon-wrap--streak{background:#ff6b3526}[data-theme=dark] .stat-pill__icon-wrap--xp{background:#ffb30026}[data-theme=dark] .stat-pill__icon-wrap--level{background:#ce82ff26}.stat-pill__icon--streak{color:#ff6b35}.stat-pill__icon--xp{color:#ffb300}.stat-pill__icon--level{color:var(--purple)}.stat-pill__content{display:flex;flex-direction:column;line-height:1.1}.stat-pill__value{font-size:18px;font-weight:600;color:var(--text);animation:count-up .4s ease-out}.stat-pill__label{font-size:11px;font-weight:600;color:var(--text-light);text-transform:uppercase;letter-spacing:.5px}.stats-xp-bar{margin-bottom:10px}.stats-xp-bar__track{height:12px;background:var(--border);border-radius:6px;overflow:hidden;margin-bottom:4px;box-shadow:inset 0 1px 3px #0000000f}.stats-xp-bar__fill{height:100%;background:linear-gradient(90deg,var(--blue),var(--purple),var(--blue));background-size:200% 100%;border-radius:6px;will-change:width;animation:shimmer-sweep 3s ease-in-out infinite;position:relative}.stats-xp-bar__text{font-size:12px;font-weight:600;color:var(--text-light)}.quest-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface);border:1.5px solid var(--border);border-radius:14px;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.quest-row:hover{border-color:color-mix(in srgb,var(--quest-accent, var(--green)) 40%,transparent);box-shadow:0 2px 12px color-mix(in srgb,var(--quest-accent, var(--green)) 10%,transparent)}.quest-row--done{border-color:color-mix(in srgb,var(--green) 30%,transparent);background:color-mix(in srgb,var(--green) 4%,var(--surface))}.quest-row--done .quest-row__label{text-decoration:line-through;opacity:.55}.quest-row--done .quest-row__count{opacity:.55}.quest-row__icon-wrap{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--quest-bg);transition:background .2s ease,transform .2s ease}[data-theme=dark] .quest-row__icon-wrap{background:var(--quest-bg-dark)}.quest-row__icon{color:var(--quest-accent)}.quest-row__check{color:var(--green)}.quest-row--done .quest-row__icon-wrap{background:color-mix(in srgb,var(--green) 12%,transparent)}.quest-row__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.quest-row__label-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.quest-row__label{font-size:13.5px;font-weight:600;color:var(--text)}.quest-row__count{font-size:12px;font-weight:700;color:var(--text-light);white-space:nowrap;font-variant-numeric:tabular-nums}.quest-row__bar{width:100%;height:6px;background:var(--border);border-radius:3px;overflow:hidden}.quest-row__fill{height:100%;background:var(--quest-accent, var(--green));border-radius:3px;will-change:width;position:relative}.quest-row--done .quest-row__fill{background:var(--green)}.home-screen{max-width:var(--max-width);margin:0 auto;padding:0 20px 40px}.learn-path{position:relative;width:100%;min-height:400px;margin-top:8px}.learn-path__svg{position:absolute;top:0;left:0;pointer-events:none;z-index:0}.path-node{position:absolute;z-index:2;width:var(--node-size);height:var(--node-size);scroll-margin-top:72px}.path-node--active{z-index:3}.path-node__btn{width:var(--node-size);height:var(--node-size);border-radius:50%;border:3.5px solid var(--green);background:var(--surface);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;position:relative;box-shadow:var(--shadow-node);transition:border-color .3s ease,box-shadow .3s ease,background .3s ease,color .3s ease;-webkit-tap-highlight-color:transparent;will-change:transform;transform-origin:center center;backface-visibility:hidden;-webkit-font-smoothing:antialiased;color:var(--green-dark)}.path-node__btn--placeholder{opacity:0;width:var(--node-size);height:var(--node-size)}.path-node__btn:hover:not(:disabled){border-color:var(--blue);box-shadow:var(--shadow-node-hover)}.path-node__btn:active:not(:disabled){box-shadow:0 2px 0 var(--green-dark)}.path-node--locked .path-node__btn{border-color:var(--border);box-shadow:0 4px color-mix(in srgb,var(--border) 80%,transparent);cursor:not-allowed;opacity:.45;color:var(--text-light)}.path-node--completed .path-node__btn{border-color:var(--green);background:var(--gradient-green);color:#fff;box-shadow:0 6px 0 var(--green-dark),0 0 12px #58cc0233}.path-node--active .path-node__btn{border-color:var(--blue);color:var(--blue);animation:pulse-glow 2s ease-in-out infinite}.path-node__icon{display:flex;align-items:center;justify-content:center}.path-node__label{position:absolute;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:2px;width:max-content;max-width:min(50vw,300px);pointer-events:none;backface-visibility:hidden;-webkit-font-smoothing:antialiased}.path-node__label--right{inset-inline-start:calc(var(--node-size) + 12px);text-align:start}.path-node__label--left{inset-inline-end:calc(var(--node-size) + 12px);text-align:end}.path-node__title{font-size:15px;font-weight:600;color:var(--text);line-height:1.25}.path-node--locked .path-node__title{color:var(--text-light)}.path-node--expanded .path-node__btn{border-color:var(--blue);color:var(--blue);box-shadow:0 0 0 4px color-mix(in srgb,var(--blue) 18%,transparent),0 6px color-mix(in srgb,var(--blue) 60%,transparent);animation:pulse-glow 2s ease-in-out infinite}.sub-cluster{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:2}.sub-path-node{position:relative;width:var(--sub-node-size, 48px);height:var(--sub-node-size, 48px)}.sub-path-node__btn{width:var(--sub-node-size, 48px);height:var(--sub-node-size, 48px);border-radius:50%;border:2.5px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;pointer-events:auto;box-shadow:0 3px color-mix(in srgb,var(--border) 70%,transparent);transition:border-color .25s ease,box-shadow .25s ease,background .25s ease;-webkit-tap-highlight-color:transparent;will-change:transform;transform-origin:center;backface-visibility:hidden;color:var(--text-light)}.sub-path-node--unlocked .sub-path-node__btn{border-color:var(--blue);color:var(--blue);box-shadow:0 3px color-mix(in srgb,var(--blue) 50%,transparent)}.sub-path-node--unlocked .sub-path-node__btn:hover:not(:disabled){border-color:var(--blue);box-shadow:0 4px 12px color-mix(in srgb,var(--blue) 28%,transparent)}.sub-path-node--completed .sub-path-node__btn{border-color:var(--green);background:var(--gradient-green);color:#fff;box-shadow:0 4px 0 var(--green-dark),0 0 10px #58cc022e}.sub-path-node--locked .sub-path-node__btn{border-color:var(--border);opacity:.4;cursor:not-allowed}.sub-path-node__icon{display:flex;align-items:center;justify-content:center}.sub-path-node__label{width:max-content;max-width:min(50vw,260px)}.sub-path-node .path-node__label--right{inset-inline-start:calc(var(--sub-node-size, 48px) + 12px)}.sub-path-node .path-node__label--left{inset-inline-end:calc(var(--sub-node-size, 48px) + 12px)}.sub-path-node__label .path-node__title{font-size:13.5px;font-weight:600}.path-section{display:flex;align-items:center;gap:16px;z-index:1;padding:0 8px}.path-section__line{flex:1;height:2px;border-radius:1px;background:linear-gradient(90deg,transparent 0%,var(--border) 30%,var(--border) 70%,transparent 100%)}.path-section__label{font-size:13px;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:2.5px;white-space:nowrap;padding:6px 18px;background:var(--surface);border:1.5px solid var(--border);border-radius:20px;box-shadow:0 2px 8px #0000000f}.path-connector{display:none}.sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-bg);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:var(--z-overlay);display:flex;align-items:flex-end;justify-content:center}.sheet-container{width:100%;max-width:var(--max-width);max-height:88vh;max-height:88dvh;overflow-y:auto;background:var(--surface);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:12px 24px 32px;text-align:center;position:relative;box-shadow:0 -4px 32px #00000026}.sheet-handle{width:40px;height:4px;border-radius:2px;background:var(--border);margin:0 auto 16px}.sheet-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:50%;border:1.5px solid var(--border);background:var(--surface);color:var(--text-light);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.sheet-close:hover{border-color:var(--red);color:var(--red)}.sheet-icon{display:inline-flex;align-items:center;justify-content:center;margin-bottom:8px}.sheet-title{font-size:22px;font-weight:600;color:var(--text);margin-bottom:4px}.sheet-ref{font-size:16px;color:var(--blue);font-weight:600;margin-bottom:8px}.sheet-desc{font-size:14px;color:var(--text-light);line-height:1.5;margin-bottom:12px}.sheet-source{font-size:13px;color:var(--text-light);margin-bottom:24px;padding:10px 12px;background:var(--surface-elevated);border-radius:var(--radius-sm);border:1px solid var(--border)}.diff-check{color:var(--green);font-weight:600}.difficulty-select{margin-bottom:32px}.difficulty-select label{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-light);display:block;margin-bottom:12px}.difficulty-buttons{display:grid;grid-template-columns:1fr 1fr;gap:8px}.diff-btn{display:flex;flex-direction:column;align-items:center;padding:12px 8px 10px;border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;transition:all .15s}.diff-btn .diff-label{font-size:15px;font-weight:600}.diff-btn .diff-desc{font-size:10px;color:var(--text-light);margin-top:2px;font-weight:600}.diff-btn:hover{border-color:var(--blue)}.diff-btn.active.diff-easy{background:var(--tint-green);border-color:var(--green);color:var(--green-dark)}.diff-btn.active.diff-easy .diff-desc{color:var(--green-dark)}.diff-btn.active.diff-medium{background:var(--tint-blue);border-color:var(--blue);color:var(--blue-dark)}.diff-btn.active.diff-medium .diff-desc{color:var(--blue-dark)}.diff-btn.active.diff-hard{background:var(--tint-red);border-color:var(--red);color:var(--red-dark)}.diff-btn.active.diff-hard .diff-desc{color:var(--red-dark)}.diff-btn.active.diff-impossible{background:var(--tint-purple);border-color:var(--purple);color:#7b1fa2}.diff-btn.active.diff-impossible .diff-desc{color:#7b1fa2}.start-btn{width:100%;padding:16px;background:var(--green);color:#fff;border:none;border-radius:var(--radius);font-size:18px;font-weight:600;cursor:pointer;text-transform:uppercase;letter-spacing:1px;box-shadow:0 var(--btn-3d-depth) 0 var(--green-dark),var(--shadow-node);transition:transform .1s,box-shadow .1s,filter .15s;position:relative}.start-btn:hover{filter:brightness(1.06)}.start-btn:active{transform:translateY(var(--btn-3d-depth));box-shadow:0 0 0 var(--green-dark)}.card-count{margin-top:12px;font-size:14px;color:var(--text-light)}.course-unit{margin:0 20px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:24px 20px 20px}.course-unit__heading{font-size:18px;font-weight:600;color:var(--text);margin:0 0 16px}.lesson-start-sheet .sheet-hero{margin:-12px -24px 20px;padding:32px 24px 20px;background:var(--gradient-blue);border-radius:var(--radius-lg) var(--radius-lg) 0 0;position:relative;overflow:hidden}.lesson-start-sheet .sheet-hero:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:24px;background:var(--surface);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.lesson-start-sheet .sheet-hero .sheet-handle{background:#ffffff59}.lesson-start-sheet .sheet-hero .sheet-title{color:#fff;font-size:20px;text-shadow:0 1px 3px rgba(0,0,0,.15)}.lesson-start-sheet .sheet-hero .sheet-ref{color:#ffffffe6;font-size:15px}.lesson-start-sheet .sheet-hero .sheet-close{border-color:#ffffff4d;background:#ffffff26;color:#fff}.lesson-start-sheet .sheet-hero .sheet-close:hover{background:#ffffff4d;border-color:#ffffff80;color:#fff}.lesson-start-sheet .sheet-body{padding:0 0 4px}.lesson-start-sheet .sheet-desc{text-align:center;font-size:16px;font-weight:500;margin-bottom:20px}.unit-rows{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.unit-row{display:flex;align-items:center;gap:12px;padding:14px 16px;border:2px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;transition:border-color .2s,background .2s,box-shadow .2s;-webkit-tap-highlight-color:transparent;text-align:start;width:100%;position:relative}.unit-row:before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:4px;border-radius:0 4px 4px 0;background:var(--unit-accent, var(--blue));opacity:0;transition:opacity .2s}.unit-row:hover{border-color:color-mix(in srgb,var(--unit-accent, var(--blue)) 40%,var(--border));background:var(--surface-elevated)}.unit-row.selected{border-color:var(--unit-accent, var(--blue));background:var(--surface-elevated);box-shadow:var(--shadow-card)}.unit-row.selected:before{opacity:1}.unit-row.completed .unit-row__status{color:var(--green);font-weight:600}.unit-row__icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:36px;height:36px;border-radius:10px;background:color-mix(in srgb,var(--unit-accent, var(--blue)) 10%,transparent)}.unit-row__text{flex:1;display:flex;flex-direction:column;gap:2px}.unit-row__label{font-size:15px;font-weight:600;color:var(--text)}.unit-row__desc{font-size:11px;font-weight:600;color:var(--text-light)}.unit-row__status{font-size:18px;color:var(--text-light);flex-shrink:0;width:24px;text-align:center}.unit-meta{display:flex;align-items:center;justify-content:center;gap:12px;text-align:center;font-size:13px;color:var(--text-light);font-weight:600;margin-top:16px}.unit-meta__item{display:inline-flex;align-items:center;gap:5px;line-height:1;padding:6px 12px;border-radius:20px;background:var(--surface-elevated);border:1px solid var(--border)}.unit-meta__item svg{display:block}.unit-meta__dot{display:none}@media(max-width:480px){.hero-card{min-height:240px;padding:22px 20px}.hero-card__title{font-size:20px}.hero-title{font-size:24px}}@media(max-width:360px){.hero-card{flex:0 0 calc(100% - 8px);min-height:220px}}.sheet-community{display:inline-flex;align-items:center;gap:5px;font-family:var(--font);font-size:12px;font-weight:500;color:var(--text-secondary);margin-top:4px}.download-popup-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-overlay);background:#00000073;display:flex;align-items:center;justify-content:center;padding:20px}.download-popup{background:var(--surface, #fff);border-radius:var(--radius-lg, 16px);box-shadow:0 12px 40px #0003;padding:28px 24px;max-width:340px;width:100%;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px}.download-popup__icon{width:52px;height:52px;border-radius:50%;background:var(--surface-elevated, #f0f0ff);display:flex;align-items:center;justify-content:center;margin-bottom:4px}.download-popup__title{font-size:1.1rem;font-weight:600;color:var(--text, #333);margin:0}.download-popup__desc{font-size:.85rem;color:var(--text-light, #888);margin:0 0 8px;line-height:1.4}.download-popup__btn{width:100%;padding:10px 0;border-radius:10px;border:none;background:var(--blue);color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:opacity .15s}.download-popup__btn:hover{opacity:.9}.download-popup__skip{background:none;border:none;color:var(--text-light, #888);font-size:.82rem;cursor:pointer;padding:4px}.download-popup__skip:hover{color:var(--text, #333)}[data-theme=dark] .download-popup{box-shadow:0 12px 40px #00000080}.session-loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-overlay-elevated);display:flex;align-items:center;justify-content:center;background:#00000059;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.session-loading-overlay__card{display:flex;flex-direction:column;align-items:center;gap:16px;background:var(--card-bg, #fff);border-radius:20px;padding:36px 40px 32px;box-shadow:0 12px 48px #0000002e;min-width:220px;max-width:300px;text-align:center;position:relative;overflow:hidden}.session-loading-overlay__icon{width:56px;height:56px;border-radius:50%;background:var(--primary-light, #e0e7ff);color:var(--primary, #6366f1);display:flex;align-items:center;justify-content:center}.session-loading-overlay__icon--error{background:#fef2f2;color:#ef4444}.session-loading-overlay__shimmer{width:80%;height:4px;border-radius:2px;background:linear-gradient(90deg,var(--border, #e5e7eb) 25%,var(--primary-light, #c7d2fe) 50%,var(--border, #e5e7eb) 75%);background-size:200% 100%;animation:session-shimmer 1.4s ease-in-out infinite}@keyframes session-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.session-loading-overlay__text{font-size:.9rem;font-weight:500;color:var(--text, #1f2937);margin:0}.session-loading-overlay__text--error{color:#ef4444}.session-loading-overlay__retry{display:flex;align-items:center;gap:6px;padding:8px 20px;border:none;border-radius:12px;background:var(--primary, #6366f1);color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s}.session-loading-overlay__retry:hover{background:var(--primary-dark, #4f46e5)}.session-loading-overlay__cancel{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 20px;min-height:40px;border:1px solid var(--border, #e5e7eb);border-radius:12px;background:color-mix(in srgb,var(--surface, #ffffff) 92%,var(--border, #e5e7eb));color:var(--text, #1f2937);font-size:.82rem;font-weight:600;line-height:1;cursor:pointer;transition:border-color .15s,background .15s,color .15s}.session-loading-overlay__cancel:hover{border-color:color-mix(in srgb,var(--primary, #6366f1) 28%,var(--border, #e5e7eb));background:color-mix(in srgb,var(--primary-light, #e0e7ff) 55%,white 45%);color:var(--text, #1f2937)}.session-loading-overlay__cancel svg{flex:0 0 auto;color:currentColor}[data-theme=dark] .session-loading-overlay__cancel:hover{background:#ffffff14;color:#e5e7eb}[data-theme=dark] .session-loading-overlay__cancel{border-color:var(--glass-border);background:#ffffff0a;color:var(--text);box-shadow:0 8px 18px #0003}[data-theme=dark] .session-loading-overlay__card{background:linear-gradient(180deg,#ffffff08,#fff0 20%),linear-gradient(180deg,#121214f5,#0c0c0efa);border:1px solid var(--glass-border);box-shadow:0 12px 48px #00000073}[data-theme=dark] .session-loading-overlay{background:#04060c9e}[data-theme=dark] .session-loading-overlay__icon{background:#6366f126}[data-theme=dark] .session-loading-overlay__icon--error{background:#ef444426}[data-theme=dark] .session-loading-overlay__shimmer{background:linear-gradient(90deg,#ffffff0f 25%,#6366f152,#ffffff0f 75%);background-size:200% 100%}[data-theme=dark] .session-loading-overlay__text{color:var(--text)}[data-theme=dark] .session-loading-overlay__retry{background:linear-gradient(180deg,var(--blue) 0%,var(--blue-dark) 100%);box-shadow:0 8px 18px #00000047}[data-theme=dark] .session-loading-overlay__retry:hover{background:linear-gradient(180deg,color-mix(in srgb,var(--blue) 92%,white 8%) 0%,var(--blue-dark) 100%)}.stats-page{max-width:var(--max-width);margin:0 auto;padding:24px 16px 40px}.profile-page{max-width:var(--max-width);margin:0 auto;padding:0 0 40px;padding-top:var(--ion-safe-area-top, env(safe-area-inset-top, 0px))}.profile-page .stat-card-grid{margin:0 16px 20px}.profile-page .heatmap,.profile-page .achievement-wall,.profile-page .book-progress,.profile-page .deep-stats{margin-inline:16px}.profile-hero-wrap{position:relative}.profile-settings-btn{position:absolute;top:calc(var(--ion-safe-area-top, 0px) + 14px);right:14px;z-index:10;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:none;background:#0003;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s}.profile-banner-btn{right:58px}.profile-settings-btn:hover{background:#ffffff6b}.profile-settings-btn:focus-visible{outline:2px solid rgba(255,255,255,.9);outline-offset:2px}.profile-banner{width:100%;min-height:115px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding-top:calc(var(--ion-safe-area-top, 0px) + 12px);padding-bottom:0;position:relative;overflow:visible}.profile-banner__bg{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:0 0 24px 24px;overflow:hidden;z-index:0;box-shadow:inset 0 -20px 40px #0000001f}.profile-banner>*:not(.profile-banner__bg){position:relative;z-index:1}.profile-banner .profile-hero__avatar-wrap{position:relative;width:136px;height:136px;margin-bottom:-68px;z-index:2}.profile-hero{display:flex;flex-direction:column;align-items:center;margin-bottom:24px}.profile-hero__avatar-wrap{position:relative;width:136px;height:136px}.profile-hero__ring{position:absolute;top:0;right:0;bottom:0;left:0}.profile-hero__avatar-inner{position:absolute;top:14px;right:14px;bottom:14px;left:14px;border-radius:50%;overflow:hidden;box-shadow:0 0 0 3px #fff,0 4px 16px #0000002e}.profile-hero__photo{width:100%;height:100%;object-fit:cover;border-radius:50%}.profile-hero__initials{width:100%;height:100%;display:flex;align-items:center;justify-content:center;border-radius:50%;color:#fff;font-family:var(--font);font-weight:600;font-size:32px;letter-spacing:1px}.profile-hero__below{display:flex;flex-direction:column;align-items:center;gap:8px;padding:80px 16px 20px;width:100%;text-align:center}.profile-hero__name{margin:0;color:var(--text);font-family:var(--font);font-weight:600;font-size:24px;line-height:1.2}.profile-hero__level-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 14px;border-radius:20px;background:var(--gradient-gold);color:#fff;font-family:var(--font);font-weight:600;font-size:13px}.profile-hero__crown{flex-shrink:0}.profile-hero__xp-wrap{display:flex;flex-direction:column;align-items:center;gap:6px;width:100%;max-width:240px;margin-top:4px}.profile-hero__xp-bar{width:100%;height:8px;background:var(--border);border-radius:100px;overflow:hidden}.profile-hero__xp-fill{height:100%;background:linear-gradient(90deg,#ffca28,#ff8c00);border-radius:100px;min-width:3px}.profile-hero__xp-text{margin:0;font-family:var(--font);font-weight:600;font-size:12px;color:var(--text-light)}.stat-card-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.stat-card{display:flex;align-items:center;gap:12px;padding:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-card)}.stat-card__icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px}.stat-card__body{display:flex;flex-direction:column;gap:2px;min-width:0}.stat-card__value{font-family:var(--font);font-weight:600;font-size:20px;line-height:1.1;color:var(--text)}.stat-card__label{font-family:var(--font);font-weight:600;font-size:12px;color:var(--text-light);text-transform:uppercase;letter-spacing:.5px}.heatmap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px;margin-bottom:20px;box-shadow:var(--shadow-card)}.heatmap__header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}.heatmap__title{font-family:var(--font);font-weight:600;font-size:16px;color:var(--text)}.heatmap__subtitle{font-family:var(--font);font-weight:600;font-size:12px;color:var(--text-light)}.heatmap__day-labels{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:3px}.heatmap__day-label{font-family:var(--font);font-weight:600;font-size:10px;color:var(--text-light);display:flex;align-items:center;justify-content:center}.heatmap__grid{display:grid;grid-template-columns:repeat(7,1fr);grid-auto-flow:row;gap:3px}.heatmap__cell{width:100%;height:14px;border-radius:3px;animation:heatmapFadeIn .4s ease both}@keyframes heatmapFadeIn{0%{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}.heatmap__legend{display:flex;align-items:center;justify-content:flex-end;gap:4px;margin-top:8px}.heatmap__legend-label{font-family:var(--font);font-weight:600;font-size:10px;color:var(--text-light)}.heatmap__legend-cell{width:12px;height:12px;border-radius:2px}.achievement-wall{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:20px;box-shadow:var(--shadow-card)}.achievement-wall__header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px}.achievement-wall__title{font-family:var(--font);font-weight:600;font-size:16px;color:var(--text)}.achievement-wall__count{font-family:var(--font);font-weight:600;font-size:13px;color:var(--text-light)}.achievement-wall__scroll{display:flex;gap:12px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-top:8px;padding-bottom:4px;padding-inline:4px;scrollbar-width:none}.achievement-wall__scroll::-webkit-scrollbar{display:none}.achievement-badge{-moz-appearance:none;appearance:none;-webkit-appearance:none;background:none;border:none;padding:0;font-family:inherit;display:flex;flex-direction:column;align-items:center;gap:6px;flex-shrink:0;min-width:72px;cursor:pointer}.achievement-badge__icon-wrap{position:relative;display:flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:50%;background:var(--tint-neutral);border:2px solid var(--border);transition:box-shadow .2s,border-color .2s}.achievement-badge--unlocked .achievement-badge__icon-wrap{border-color:var(--rarity-color);box-shadow:0 0 12px color-mix(in srgb,var(--rarity-color) 40%,transparent)}.achievement-badge--unlocked .achievement-badge__icon{color:var(--rarity-color)}.achievement-badge--locked .achievement-badge__icon-wrap{opacity:.45;filter:grayscale(1)}.achievement-badge--locked .achievement-badge__icon{color:var(--text-light)}.achievement-badge__lock-overlay{position:absolute;bottom:-2px;right:-2px;width:20px;height:20px;border-radius:50%;background:var(--surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-light)}.achievement-badge__label{font-family:var(--font);font-weight:600;font-size:11px;color:var(--text);text-align:center;max-width:72px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.achievement-badge--locked .achievement-badge__label{color:var(--text-light)}.ach-popover-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-overlay-popover)}.ach-popover{position:fixed;z-index:calc(var(--z-overlay-popover) + 1);width:min(240px,calc(100vw - 16px));background:var(--surface);border:1px solid var(--border);border-top:4px solid var(--rarity-color, var(--border));border-radius:16px;box-shadow:0 8px 32px #0003,0 0 0 1px #ffffff0a;outline:none;overflow:visible;padding-bottom:2px}.ach-popover--above{transform-origin:bottom center}.ach-popover--below{transform-origin:top center}.ach-popover__icon-wrap{display:flex;align-items:center;justify-content:center;padding:16px 16px 8px}.ach-popover__icon{color:var(--rarity-color);filter:drop-shadow(0 0 8px color-mix(in srgb,var(--rarity-color) 55%,transparent))}.ach-popover__title{margin:0;padding:0 16px 8px;font-family:var(--font);font-weight:700;font-size:16px;color:var(--text);text-align:center;line-height:1.2}.ach-popover__pills{display:flex;gap:6px;justify-content:center;padding:0 16px 10px;flex-wrap:wrap}.ach-popover__rarity-pill{padding:3px 10px;border-radius:999px;font-family:var(--font);font-weight:600;font-size:11px;background:color-mix(in srgb,var(--rarity-color) 14%,transparent);color:var(--rarity-color);border:1px solid color-mix(in srgb,var(--rarity-color) 32%,transparent)}.ach-popover__status-pill{display:inline-flex;align-items:center;gap:3px;padding:3px 10px;border-radius:999px;font-family:var(--font);font-weight:600;font-size:11px}.ach-popover__status-pill--unlocked{background:#58cc021f;color:#58cc02;border:1px solid rgba(88,204,2,.28)}.ach-popover__status-pill--locked{background:var(--tint-neutral, rgba(128, 128, 128, .1));color:var(--text-light);border:1px solid var(--border)}.ach-popover__desc{margin:0;padding:0 16px 16px;font-family:var(--font);font-size:13px;line-height:1.5;color:var(--text-light);text-align:center;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.ach-popover__arrow{position:absolute;left:var(--arrow-left, 50%);transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent}.ach-popover--above .ach-popover__arrow{bottom:-8px;border-top:8px solid var(--surface)}.ach-popover--below .ach-popover__arrow{top:-8px;border-bottom:8px solid var(--rarity-color, var(--border))}.user-detail__achievement-badge{cursor:pointer}.achievement-celebration-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-overlay-elevated);display:flex;align-items:center;justify-content:center;background:#0000008c;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);will-change:opacity}.achievement-celebration-card{display:flex;flex-direction:column;align-items:center;gap:14px;width:min(360px,90vw);padding:32px 28px 24px;border-radius:20px;background:var(--surface-raised, var(--surface));box-shadow:0 24px 48px #0003,0 0 0 1px #ffffff0f;text-align:center;will-change:transform,opacity}.achievement-celebration__dots{display:flex;gap:6px;margin-bottom:2px}.achievement-celebration__dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:background .2s}.achievement-celebration__dot--active{background:var(--rarity-color, var(--primary))}.achievement-celebration__unlocked-label{font-family:var(--font);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:1.6px;color:var(--text-light)}.achievement-celebration__badge-wrap{position:relative;display:flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:50%;border:3px solid var(--rarity-color, #cd7f32);background:var(--tint-neutral);will-change:transform,opacity}.achievement-celebration__glow{position:absolute;top:-12px;right:-12px;bottom:-12px;left:-12px;border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--rarity-color, #cd7f32) 35%,transparent) 0%,transparent 70%);animation:achievement-glow-pulse 2s ease-in-out infinite;pointer-events:none}@keyframes achievement-glow-pulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}.achievement-celebration__icon{color:var(--rarity-color, #cd7f32)}.achievement-celebration__title{font-family:var(--font);font-weight:600;font-size:20px;color:var(--rarity-color, #cd7f32);margin:0;line-height:1.2}.achievement-celebration__desc{font-family:var(--font);font-weight:500;font-size:14px;color:var(--text-light);margin:0;line-height:1.4;max-width:260px}.achievement-celebration__rarity-tag{display:inline-block;padding:3px 12px;border-radius:100px;font-family:var(--font);font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:1.2px;color:var(--rarity-color, #cd7f32);background:color-mix(in srgb,var(--rarity-color, #cd7f32) 12%,transparent)}.achievement-celebration__cta{margin-top:8px;padding:12px 36px;border-radius:14px;border:none;font-family:var(--font);font-weight:600;font-size:15px;color:#fff;background:var(--rarity-color, var(--primary));cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .1s,opacity .1s}.achievement-celebration__cta:active{transform:scale(.96);opacity:.9}.achievement-celebration__cta:focus-visible{outline:2px solid var(--rarity-color, var(--primary));outline-offset:3px}.achievement-celebration__skip-all{margin-top:4px;padding:6px 12px;border:none;background:none;font-family:var(--font);font-weight:600;font-size:12px;color:var(--text-light);opacity:.7;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity .15s}.achievement-celebration__skip-all:hover,.achievement-celebration__skip-all:focus{opacity:1;text-decoration:underline}.achievement-celebration__skip-all:focus-visible{outline:2px solid var(--text-light);outline-offset:2px;border-radius:4px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media(prefers-reduced-motion:reduce){.achievement-celebration__glow{animation:none;opacity:.5}.achievement-celebration-overlay,.achievement-celebration-card{transition:none!important}}.banner-celebration-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-overlay-elevated);display:flex;align-items:center;justify-content:center;background:#0000008c;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);will-change:opacity}.banner-celebration-card{display:flex;flex-direction:column;align-items:center;gap:14px;width:min(360px,90vw);padding:32px 28px 24px;border-radius:20px;background:var(--surface-raised, var(--surface));box-shadow:0 24px 48px #0003,0 0 0 1px #ffffff0f;text-align:center;will-change:transform,opacity}.banner-celebration__dots{display:flex;gap:6px;margin-bottom:2px}.banner-celebration__dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:background .2s}.banner-celebration__dot--active{background:var(--banner-accent, var(--primary))}.banner-celebration__unlocked-label{font-family:var(--font);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:1.6px;color:var(--text-light)}.banner-celebration__preview-wrap{position:relative;display:flex;align-items:center;justify-content:center;will-change:transform,opacity}.banner-celebration__glow{position:absolute;top:-14px;right:-14px;bottom:-14px;left:-14px;border-radius:20px;background:radial-gradient(ellipse,color-mix(in srgb,var(--banner-accent, #cd7f32) 30%,transparent) 0%,transparent 70%);animation:achievement-glow-pulse 2s ease-in-out infinite;pointer-events:none}.banner-celebration__preview{width:260px;height:56px;border-radius:14px;background-size:200% 200%;box-shadow:0 4px 16px #0000002e,inset 0 1px #ffffff26}.banner-celebration__icon{position:absolute;color:#ffffffd9;filter:drop-shadow(0 1px 3px rgba(0,0,0,.3))}.banner-celebration__title{font-family:var(--font);font-weight:600;font-size:20px;color:var(--banner-accent, var(--text));margin:0;line-height:1.2}.banner-celebration__desc{font-family:var(--font);font-weight:500;font-size:14px;color:var(--text-light);margin:0;line-height:1.4;max-width:260px}.banner-celebration__category-tag{display:inline-block;padding:3px 12px;border-radius:100px;font-family:var(--font);font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:1.2px;color:var(--banner-accent, var(--text));background:color-mix(in srgb,var(--banner-accent, #888) 12%,transparent)}.banner-celebration__cta{margin-top:8px;padding:12px 36px;border-radius:14px;border:none;font-family:var(--font);font-weight:600;font-size:15px;color:#fff;background:var(--banner-accent, var(--primary));cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .1s,opacity .1s}.banner-celebration__cta:active{transform:scale(.96);opacity:.9}.banner-celebration__cta:focus-visible{outline:2px solid var(--banner-accent, var(--primary));outline-offset:3px}@media(prefers-reduced-motion:reduce){.banner-celebration__glow{animation:none;opacity:.5}.banner-celebration-overlay,.banner-celebration-card{transition:none!important}.banner-celebration__preview,[class*=banner-anim--]{animation:none!important}[class*=banner-anim--]:before,[class*=banner-anim--]:after{animation:none!important;display:none}}@keyframes banner-drift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes banner-breathe{0%,to{filter:brightness(1) saturate(1)}50%{filter:brightness(1.25) saturate(1.2)}}@keyframes banner-hue-cycle{0%{filter:hue-rotate(0deg) brightness(1)}50%{filter:hue-rotate(30deg) brightness(1.15)}to{filter:hue-rotate(0deg) brightness(1)}}@keyframes banner-shimmer-sweep{0%{transform:translate(-120%) skew(-15deg)}to{transform:translate(220%) skew(-15deg)}}@keyframes banner-aurora-blob-a{0%{transform:translate(-30%,-20%) scale(1);opacity:.7}33%{transform:translate(20%,10%) scale(1.4);opacity:1}66%{transform:translate(-10%,20%) scale(.9);opacity:.6}to{transform:translate(-30%,-20%) scale(1);opacity:.7}}@keyframes banner-aurora-blob-b{0%{transform:translate(30%,15%) scale(1.1);opacity:.6}33%{transform:translate(-20%,-10%) scale(.8);opacity:.9}66%{transform:translate(10%,-20%) scale(1.3);opacity:.7}to{transform:translate(30%,15%) scale(1.1);opacity:.6}}@keyframes banner-pulse-beat{0%,to{box-shadow:inset 0 0 30px #1a237e66,inset 0 0 60px #3f51b533;transform:scale(1);filter:brightness(1)}50%{box-shadow:inset 0 0 80px #1a237ee6,inset 0 0 120px #3f51b580;transform:scale(1.02);filter:brightness(1.35)}}@keyframes banner-gradient-flow{0%{background-position:0% 50%;filter:brightness(1)}25%{filter:brightness(1.1)}50%{background-position:100% 50%;filter:brightness(1)}75%{filter:brightness(1.1)}to{background-position:0% 50%;filter:brightness(1)}}@keyframes banner-wave-sway{0%{transform:translate(-5%) scaleY(1)}25%{transform:translate(3%) scaleY(1.08)}50%{transform:translate(5%) scaleY(1)}75%{transform:translate(-3%) scaleY(.95)}to{transform:translate(-5%) scaleY(1)}}@keyframes banner-prismatic-spin{0%{filter:hue-rotate(0deg) brightness(1.05)}to{filter:hue-rotate(360deg) brightness(1.05)}}@keyframes banner-northern-curtain-a{0%{transform:translate(-40%,-30%) rotate(0) scale(1);opacity:.8}25%{transform:translate(0) rotate(5deg) scale(1.3);opacity:1}50%{transform:translate(20%,-10%) rotate(-3deg) scale(1.1);opacity:.7}75%{transform:translate(-10%,10%) rotate(3deg) scale(1.4);opacity:.9}to{transform:translate(-40%,-30%) rotate(0) scale(1);opacity:.8}}@keyframes banner-northern-curtain-b{0%{transform:translate(40%,20%) rotate(0) scale(1.2);opacity:.6}25%{transform:translate(-10%,-15%) rotate(-5deg) scale(.9);opacity:.9}50%{transform:translate(-30%,5%) rotate(3deg) scale(1.3);opacity:.8}75%{transform:translate(15%,-20%) rotate(-2deg) scale(1);opacity:.7}to{transform:translate(40%,20%) rotate(0) scale(1.2);opacity:.6}}@keyframes banner-fire-flicker{0%,to{opacity:.4;transform:scaleY(1) translateY(0)}10%{opacity:.9}20%{opacity:.5;transform:scaleY(1.05) translateY(-2%)}30%{opacity:1}40%{opacity:.6;transform:scaleY(.98) translateY(0)}50%{opacity:.95;transform:scaleY(1.08) translateY(-3%)}60%{opacity:.5}70%{opacity:.85;transform:scaleY(1) translateY(-1%)}80%{opacity:1;transform:scaleY(1.03) translateY(-2%)}90%{opacity:.55;transform:scaleY(1) translateY(0)}}@keyframes banner-fire-glow{0%,to{filter:brightness(1) saturate(1.2)}30%{filter:brightness(1.3) saturate(1.6)}60%{filter:brightness(1.1) saturate(1.3)}80%{filter:brightness(1.4) saturate(1.5)}}@keyframes banner-cosmic-rotate{0%{transform:rotate(0) scale(1)}to{transform:rotate(360deg) scale(1)}}@keyframes banner-cosmic-nebula{0%,to{opacity:.4;transform:scale(1) rotate(0)}33%{opacity:.8;transform:scale(1.2) rotate(5deg)}66%{opacity:.5;transform:scale(.95) rotate(-3deg)}}@keyframes banner-cosmic-twinkle{0%,to{opacity:.3}50%{opacity:1}}@keyframes banner-holographic-flow{0%{filter:hue-rotate(0deg) brightness(1) saturate(1.3)}25%{filter:hue-rotate(60deg) brightness(1.15) saturate(1.5)}50%{filter:hue-rotate(120deg) brightness(1) saturate(1.2)}75%{filter:hue-rotate(180deg) brightness(1.1) saturate(1.4)}to{filter:hue-rotate(360deg) brightness(1) saturate(1.3)}}@keyframes banner-lava-glow{0%,to{filter:brightness(1) saturate(1.3)}25%{filter:brightness(1.35) saturate(1.7)}50%{filter:brightness(1.1) saturate(1.4)}75%{filter:brightness(1.4) saturate(1.6)}}@keyframes banner-lava-bubble{0%{transform:translateY(100%) scale(.5);opacity:0}20%{opacity:.8}50%{transform:translateY(-20%) scale(1);opacity:.6}to{transform:translateY(-100%) scale(.3);opacity:0}}@keyframes banner-diamond-sparkle-a{0%,to{opacity:0;transform:scale(.5) rotate(0)}50%{opacity:1;transform:scale(1.2) rotate(180deg)}}@keyframes banner-diamond-sparkle-b{0%,to{opacity:0;transform:scale(.3) rotate(45deg)}50%{opacity:1;transform:scale(1) rotate(225deg)}}@keyframes banner-celestial-orbit{0%{transform:rotate(0) translate(30%) rotate(0)}to{transform:rotate(360deg) translate(30%) rotate(-360deg)}}@keyframes banner-celestial-pulse{0%,to{opacity:.5;transform:scale(1);filter:brightness(1)}50%{opacity:.9;transform:scale(1.15);filter:brightness(1.3)}}@keyframes banner-divine-ray-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes banner-divine-glow-pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.15)}}.banner-anim--gold-drift{background-size:400% 400%;animation:banner-drift 6s ease-in-out infinite,banner-breathe 4s ease-in-out infinite}.banner-anim--royal-pulse{background-size:400% 400%;animation:banner-drift 7s ease-in-out infinite,banner-hue-cycle 8s ease-in-out infinite}.banner-anim--sunset-glow{background-size:400% 400%;animation:banner-drift 5s ease-in-out infinite,banner-breathe 3s ease-in-out infinite}.banner-anim--emerald-wave{background-size:400% 400%;animation:banner-drift 6s ease-in-out infinite,banner-hue-cycle 10s ease-in-out infinite}.banner-anim--midnight-drift{background-size:400% 400%;animation:banner-drift 8s ease-in-out infinite,banner-breathe 5s ease-in-out infinite}.banner-anim--ocean-flow{background-size:400% 400%;animation:banner-drift 5s ease-in-out infinite,banner-hue-cycle 12s ease-in-out infinite}.banner-anim--dawn-pulse{background-size:400% 400%;animation:banner-drift 6s ease-in-out infinite,banner-breathe 3.5s ease-in-out infinite}.banner-anim--shimmer{background-size:400% 100%;animation:banner-drift 3s linear infinite;overflow:hidden}.banner-anim--shimmer:after{content:"";position:absolute;top:0;left:0;width:60%;height:100%;border-radius:inherit;background:linear-gradient(105deg,transparent 0%,transparent 30%,rgba(255,255,255,.15) 40%,rgba(255,255,255,.5) 50%,rgba(255,255,255,.15) 60%,transparent 70%,transparent 100%);animation:banner-shimmer-sweep 2.5s ease-in-out infinite;will-change:transform;pointer-events:none}.banner-anim--aurora{overflow:hidden}.banner-anim--aurora:before,.banner-anim--aurora:after{content:"";position:absolute;width:200%;height:200%;border-radius:50%;pointer-events:none;filter:blur(30px);will-change:transform,opacity;mix-blend-mode:screen}.banner-anim--aurora:before{top:-50%;left:-50%;background:radial-gradient(ellipse,rgba(0,201,255,.8) 0%,rgba(146,254,157,.4) 40%,transparent 70%);animation:banner-aurora-blob-a 6s ease-in-out infinite}.banner-anim--aurora:after{bottom:-50%;right:-50%;background:radial-gradient(ellipse,rgba(102,126,234,.7) 0%,rgba(168,85,247,.4) 40%,transparent 70%);animation:banner-aurora-blob-b 8s ease-in-out infinite}.banner-anim--pulse-glow{animation:banner-pulse-beat 3s ease-in-out infinite;will-change:transform,filter}.banner-anim--gradient-shift{background-size:600% 600%;animation:banner-gradient-flow 5s ease infinite;will-change:background-position}.banner-anim--wave{background-size:300% 300%;animation:banner-drift 5s ease-in-out infinite;overflow:hidden}.banner-anim--wave:before{content:"";position:absolute;top:-20%;right:-20%;bottom:-20%;left:-20%;border-radius:inherit;background:linear-gradient(135deg,rgba(0,180,216,.5) 0%,rgba(144,224,239,.3) 50%,transparent 100%);animation:banner-wave-sway 4s ease-in-out infinite;will-change:transform;pointer-events:none}.banner-anim--wave:after{content:"";position:absolute;top:-10%;right:-10%;bottom:-10%;left:-10%;border-radius:inherit;background:linear-gradient(225deg,rgba(0,119,182,.4) 0%,rgba(72,202,228,.2) 50%,transparent 100%);animation:banner-wave-sway 6s ease-in-out infinite reverse;will-change:transform;pointer-events:none}.banner-anim--prismatic{background-size:300% 300%;animation:banner-prismatic-spin 4s linear infinite,banner-drift 6s ease-in-out infinite;will-change:filter}.banner-anim--northern-lights{overflow:hidden}.banner-anim--northern-lights:before,.banner-anim--northern-lights:after{content:"";position:absolute;width:160%;height:160%;border-radius:40%;pointer-events:none;filter:blur(25px);will-change:transform,opacity;mix-blend-mode:screen}.banner-anim--northern-lights:before{top:-40%;left:-30%;background:radial-gradient(ellipse,rgba(45,212,191,.9) 0%,rgba(16,185,129,.5) 30%,transparent 60%);animation:banner-northern-curtain-a 7s ease-in-out infinite}.banner-anim--northern-lights:after{bottom:-40%;right:-30%;background:radial-gradient(ellipse,rgba(59,130,246,.8) 0%,rgba(139,92,246,.4) 30%,transparent 60%);animation:banner-northern-curtain-b 9s ease-in-out infinite}.banner-anim--fire-ember{background-size:200% 200%;animation:banner-drift 4s ease-in-out infinite,banner-fire-glow 2s ease-in-out infinite;overflow:hidden;will-change:filter}.banner-anim--fire-ember:before{content:"";position:absolute;bottom:0;left:0;width:100%;height:80%;border-radius:inherit;background:linear-gradient(0deg,rgba(255,200,0,.6) 0%,rgba(255,140,0,.4) 30%,rgba(255,69,0,.2) 60%,transparent 100%);animation:banner-fire-flicker 1.5s ease-in-out infinite;will-change:transform,opacity;pointer-events:none}.banner-anim--fire-ember:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:60%;border-radius:inherit;background:linear-gradient(0deg,rgba(255,255,100,.4) 0%,rgba(255,165,0,.2) 40%,transparent 100%);animation:banner-fire-flicker 2s .5s ease-in-out infinite;will-change:transform,opacity;pointer-events:none}.banner-anim--cosmic{overflow:hidden}.banner-anim--cosmic:before{content:"";position:absolute;top:-50%;right:-50%;bottom:-50%;left:-50%;width:200%;height:200%;border-radius:0;background:radial-gradient(2px 2px at 10% 15%,#fff 50%,transparent 100%),radial-gradient(2px 2px at 25% 70%,rgba(255,255,255,.9) 50%,transparent 100%),radial-gradient(1px 1px at 40% 30%,#fff 50%,transparent 100%),radial-gradient(2px 2px at 55% 85%,rgba(255,255,255,.8) 50%,transparent 100%),radial-gradient(1px 1px at 70% 20%,rgba(255,255,255,.9) 50%,transparent 100%),radial-gradient(2px 2px at 85% 55%,#fff 50%,transparent 100%),radial-gradient(1px 1px at 95% 80%,rgba(255,255,255,.7) 50%,transparent 100%),radial-gradient(1px 1px at 15% 45%,rgba(255,255,255,.6) 50%,transparent 100%),radial-gradient(2px 2px at 60% 50%,rgba(255,255,255,.8) 50%,transparent 100%);animation:banner-cosmic-rotate 30s linear infinite;will-change:transform;pointer-events:none}.banner-anim--cosmic:after{content:"";position:absolute;top:-20%;right:-20%;bottom:-20%;left:-20%;border-radius:50%;background:radial-gradient(ellipse at 40% 50%,rgba(99,102,241,.6) 0%,rgba(168,85,247,.3) 30%,transparent 60%);animation:banner-cosmic-nebula 5s ease-in-out infinite;will-change:transform,opacity;pointer-events:none}.banner-anim--holographic{background-size:400% 400%;animation:banner-holographic-flow 6s linear infinite,banner-drift 4s ease-in-out infinite;overflow:hidden;will-change:filter}.banner-anim--holographic:after{content:"";position:absolute;top:0;left:0;width:50%;height:100%;border-radius:inherit;background:linear-gradient(105deg,transparent 30%,rgba(255,255,255,.35) 45%,rgba(255,255,255,.6) 50%,rgba(255,255,255,.35) 55%,transparent 70%);animation:banner-shimmer-sweep 3s ease-in-out infinite;will-change:transform;pointer-events:none}.banner-anim--lava-flow{background-size:300% 300%;animation:banner-drift 4s ease-in-out infinite,banner-lava-glow 2.5s ease-in-out infinite;overflow:hidden;will-change:filter}.banner-anim--lava-flow:before{content:"";position:absolute;bottom:0;left:10%;width:30%;height:100%;border-radius:50%;background:radial-gradient(ellipse,rgba(255,200,0,.5) 0%,transparent 60%);animation:banner-lava-bubble 3s ease-in-out infinite;will-change:transform,opacity;pointer-events:none}.banner-anim--lava-flow:after{content:"";position:absolute;bottom:0;left:55%;width:25%;height:100%;border-radius:50%;background:radial-gradient(ellipse,rgba(255,140,0,.4) 0%,transparent 60%);animation:banner-lava-bubble 4s 1.5s ease-in-out infinite;will-change:transform,opacity;pointer-events:none}.banner-anim--diamond-dust{overflow:hidden}.banner-anim--diamond-dust:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:radial-gradient(3px 3px at 15% 30%,#fff 50%,transparent 100%),radial-gradient(2px 2px at 40% 70%,rgba(255,255,255,.9) 50%,transparent 100%),radial-gradient(3px 3px at 65% 20%,#fff 50%,transparent 100%),radial-gradient(2px 2px at 85% 60%,rgba(255,255,255,.8) 50%,transparent 100%),radial-gradient(3px 3px at 30% 90%,rgba(255,255,255,.9) 50%,transparent 100%);animation:banner-diamond-sparkle-a 2s ease-in-out infinite;will-change:transform,opacity;pointer-events:none}.banner-anim--diamond-dust:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:radial-gradient(2px 2px at 25% 15%,#fff 50%,transparent 100%),radial-gradient(3px 3px at 55% 50%,rgba(255,255,255,.9) 50%,transparent 100%),radial-gradient(2px 2px at 75% 80%,#fff 50%,transparent 100%),radial-gradient(3px 3px at 90% 25%,rgba(255,255,255,.8) 50%,transparent 100%);animation:banner-diamond-sparkle-b 2.5s .8s ease-in-out infinite;will-change:transform,opacity;pointer-events:none}.banner-anim--celestial{overflow:hidden}.banner-anim--celestial:before{content:"";position:absolute;top:-10%;right:-10%;bottom:-10%;left:-10%;border-radius:50%;background:radial-gradient(ellipse at center,rgba(139,92,246,.7) 0%,rgba(99,102,241,.3) 30%,transparent 60%);animation:banner-celestial-pulse 4s ease-in-out infinite;will-change:transform,opacity;pointer-events:none}.banner-anim--celestial:after{content:"";position:absolute;width:40px;height:40px;top:calc(50% - 20px);left:calc(50% - 20px);border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.9) 0%,rgba(168,85,247,.5) 40%,transparent 70%);animation:banner-celestial-orbit 8s linear infinite;will-change:transform;pointer-events:none}.banner-anim--divine-light{overflow:hidden}.banner-anim--divine-light:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:conic-gradient(from 0deg at 50% 50%,transparent 0deg,rgba(255,215,0,.25) 20deg,transparent 40deg,rgba(255,215,0,.15) 80deg,transparent 100deg,rgba(255,215,0,.2) 140deg,transparent 160deg,rgba(255,215,0,.18) 200deg,transparent 220deg,rgba(255,215,0,.25) 260deg,transparent 280deg,rgba(255,215,0,.15) 320deg,transparent 340deg,rgba(255,215,0,.2) 360deg);animation:banner-divine-ray-spin 12s linear infinite;will-change:transform;pointer-events:none}.banner-anim--divine-light:after{content:"";position:absolute;top:10%;right:10%;bottom:10%;left:10%;border-radius:50%;background:radial-gradient(ellipse at 50% 50%,rgba(255,215,0,.7) 0%,rgba(255,183,77,.3) 40%,transparent 70%);animation:banner-divine-glow-pulse 3s ease-in-out infinite;will-change:transform,opacity;pointer-events:none}.banner-swatch[class*=banner-anim--]:before,.banner-swatch[class*=banner-anim--]:after{display:none}.banner-celebration__preview[class*=banner-anim--]:before,.banner-celebration__preview[class*=banner-anim--]:after{display:none}.banner-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-overlay);background:#00000073;display:flex;align-items:center;justify-content:center;padding:24px}.banner-picker-card{width:420px;max-width:100%;max-height:calc(100dvh - 48px);background:var(--surface, #fff);border:1.5px solid var(--border, #e5e5e5);border-radius:var(--radius-lg, 16px);box-shadow:0 8px 32px #0000002e;display:flex;flex-direction:column;overflow:hidden}.banner-picker-card__header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:1px solid var(--border, #e5e5e5)}.banner-picker-card__title{font-size:1rem;font-weight:600;margin:0}.banner-picker-card__close{background:none;border:none;padding:4px;cursor:pointer;color:var(--text-light, #aaa);display:flex;align-items:center;border-radius:50%;transition:background .15s}.banner-picker-card__close:hover{background:var(--border, #e5e7eb)}.banner-picker-card__body{padding:12px 16px 16px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.banner-picker-card__group-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-light, #888);margin:0 0 8px}.banner-picker-card__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:8px}.banner-swatch{aspect-ratio:16 / 9;border-radius:8px;border:2.5px solid transparent;cursor:pointer;position:relative;display:flex;align-items:center;justify-content:center;transition:border-color .15s,opacity .15s,transform .15s;outline:none}.banner-swatch:hover:not(.is-locked){transform:scale(1.06)}.banner-swatch:focus-visible{outline:2px solid var(--blue);outline-offset:2px}.banner-swatch.is-active{border-color:#fff;box-shadow:0 0 0 2px var(--blue, #1cb0f6)}.banner-swatch.is-locked{opacity:.4;cursor:not-allowed}.banner-swatch__check,.banner-swatch__lock{color:#fff;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}.profile-banner-edit{position:absolute;bottom:8px;right:8px;z-index:3;width:32px;height:32px;border-radius:50%;border:none;background:#00000073;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.profile-banner-edit:hover{background:#0009}.banner-settings-preview{width:40px;height:22px;border-radius:4px;flex-shrink:0}.deep-stats{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card)}.deep-stats__trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:16px;border:none;background:transparent;cursor:pointer;font-family:var(--font);font-weight:600;font-size:16px;color:var(--text);-webkit-tap-highlight-color:transparent}.deep-stats__trigger:active{background:var(--tint-neutral)}.deep-stats__trigger-text{text-align:start}.deep-stats__chevron{display:flex;align-items:center;color:var(--text-light)}.deep-stats__panel{overflow:hidden}.deep-stats__content{padding:0 16px 16px;display:flex;flex-direction:column;gap:8px}.deep-stat-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--tint-neutral);border-radius:var(--radius-sm)}.deep-stat-row__icon{display:flex;align-items:center;color:var(--text-light);flex-shrink:0}.deep-stat-row__label{flex:1;font-family:var(--font);font-weight:600;font-size:14px;color:var(--text)}.deep-stat-row__value{font-family:var(--font);font-weight:600;font-size:14px;color:var(--green)}.deep-stats__recent{margin-top:4px;display:flex;flex-direction:column;gap:6px}.deep-stats__recent-title{font-family:var(--font);font-weight:600;font-size:14px;color:var(--text);margin-bottom:2px}.recent-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:var(--tint-neutral);border-radius:var(--radius-sm)}.recent-item__info{display:flex;flex-direction:column;gap:1px}.recent-item__type{font-family:var(--font);font-weight:600;font-size:12px;color:var(--text-light);text-transform:uppercase;letter-spacing:.5px}.recent-item__slug{font-family:var(--font);font-weight:600;font-size:14px;color:var(--text)}.recent-item__meta{display:flex;flex-direction:column;align-items:flex-end;gap:1px}.recent-item__score{font-family:var(--font);font-weight:600;font-size:16px;color:var(--green)}.recent-item__date{font-family:var(--font);font-weight:600;font-size:12px;color:var(--text-light)}[data-theme=dark] .stat-card{background:var(--surface);border-color:var(--glass-border);box-shadow:var(--shadow-card)}[data-theme=dark] .heatmap{background:var(--surface);border-color:var(--glass-border);--heatmap-empty: var(--surface-elevated)}[data-theme=dark] .achievement-wall{background:var(--surface);border-color:var(--glass-border)}[data-theme=dark] .achievement-badge__icon-wrap{background:var(--surface-elevated);border-color:var(--glass-border)}[data-theme=dark] .achievement-badge__lock-overlay,[data-theme=dark] .deep-stats{background:var(--surface);border-color:var(--glass-border)}[data-theme=dark] .deep-stats__trigger:active,[data-theme=dark] .deep-stat-row,[data-theme=dark] .recent-item{background:var(--surface-elevated)}[data-theme=dark] .profile-banner{box-shadow:inset 0 -20px 40px #00000040}[data-theme=dark] .profile-hero__avatar-inner{box-shadow:0 0 0 3px var(--surface-elevated),0 4px 16px #0006}[data-theme=dark] .profile-hero__xp-bar{background:var(--surface-elevated)}.book-progress{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:20px;box-shadow:var(--shadow-card)}.book-progress__trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:16px;border:none;background:transparent;cursor:pointer;font-family:var(--font);font-weight:600;font-size:16px;color:var(--text);-webkit-tap-highlight-color:transparent}.book-progress__trigger:active{background:var(--tint-neutral)}.book-progress__trigger-text{display:flex;flex-direction:column;align-items:flex-start;gap:8px;text-align:start}.book-progress__trigger-count{font-size:12px;font-weight:600;color:var(--text-light)}.book-progress__chevron{display:flex;align-items:center;color:var(--text-light)}.book-progress__panel{overflow:hidden}.book-progress__content{padding:0 16px 16px;display:flex;flex-direction:column;gap:14px}.book-progress__filter{display:flex;gap:0;padding:3px;border-radius:var(--radius-sm);background:var(--tint-neutral)}.book-progress__filter-btn{flex:1;padding:8px 0;border:none;border-radius:calc(var(--radius-sm) - 2px);background:transparent;font-family:var(--font);font-size:13px;font-weight:600;color:var(--text-light);cursor:pointer;transition:background .2s ease,color .2s ease,box-shadow .2s ease;-webkit-tap-highlight-color:transparent}.book-progress__filter-btn--active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px #00000014}.book-progress__grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.book-progress__item{display:flex;flex-direction:column;gap:3px;padding:8px 10px;border-radius:var(--radius-sm);background:var(--tint-neutral);transition:opacity .2s ease}.book-progress__item--empty{opacity:.45}.book-progress__row{display:flex;justify-content:space-between;align-items:baseline;gap:4px}.book-progress__name{font-weight:600;font-size:12px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.book-progress__chapters{font-size:11px;font-weight:600;color:var(--text-light);white-space:nowrap;flex-shrink:0}.book-progress__bar{height:4px;border-radius:2px;background:var(--border);overflow:hidden}.book-progress__fill{height:100%;border-radius:2px;background:var(--gradient-green);transition:inline-size .3s ease}.book-progress__score{font-size:10px;color:var(--text-light);line-height:1.2}.book-progress__score--empty{font-style:italic}[data-theme=dark] .book-progress{box-shadow:none}[data-theme=dark] .book-progress__filter-btn--active{box-shadow:0 1px 3px #0000004d}@media(max-width:359px){.book-progress__grid{grid-template-columns:1fr}}.insights-glass-card{background:var(--glass-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:16px;box-shadow:var(--shadow-card);padding:16px;margin-block-end:12px}.insights-glass-card--hero{padding:20px 16px;position:relative;overflow:hidden}.insights-skeleton{background:var(--bg-secondary, rgba(128, 128, 128, .12))}.insights-section{padding:0 16px;margin-block-end:8px}.insights-section__header{display:flex;align-items:center;justify-content:space-between;margin-block-end:14px}.insights-section__title-group{display:flex;align-items:center;gap:6px}.insights-section__title-icon{color:var(--orange, #ff9600)}.insights-section__title{font-size:15px;font-weight:700;color:var(--text);letter-spacing:-.01em}.insights-section__refresh{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--glass-bg);border:1px solid var(--glass-border);padding:7px;color:var(--text-secondary);cursor:pointer;border-radius:10px;display:flex;align-items:center;justify-content:center;transition:background .15s}.insights-section__refresh:active{opacity:.6}.insights-empty{text-align:center;padding:32px 20px;display:flex;flex-direction:column;align-items:center;gap:8px}.insights-empty__icon{color:var(--orange, #ff9600);margin-block-end:4px}.insights-empty__title{font-size:17px;font-weight:700;color:var(--text);margin:0}.insights-empty__body{font-size:13px;color:var(--text-secondary);line-height:1.5;margin:0;max-width:260px}.insights-empty__pills{display:flex;gap:8px;margin-block-start:8px}.insights-empty__pill{width:40px;height:40px;border-radius:12px;background:var(--bg-secondary, rgba(128, 128, 128, .08));display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.insights-teaser{position:relative;border-radius:16px;overflow:hidden;padding:32px 20px;text-align:center;background:var(--glass-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(245,158,11,.25);box-shadow:var(--shadow-card),0 0 40px #f59e0b0f}.insights-teaser__blur-bg{position:absolute;top:0;right:0;bottom:0;left:0;filter:blur(8px);opacity:.4;pointer-events:none;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:900;color:var(--text)}.insights-teaser__content{position:relative;z-index:1}.insights-teaser__badge{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,#fcd34d,#d97706);color:#000;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:4px 10px;border-radius:20px;margin-block-end:12px}.insights-teaser__title{font-size:18px;font-weight:700;color:var(--text);margin:0 0 8px}.insights-teaser__body{font-size:13px;color:var(--text-secondary);margin:0 0 16px;line-height:1.5}.insights-teaser__cta{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:linear-gradient(135deg,#fcd34d,#d97706);color:#000;font-size:14px;font-weight:700;padding:10px 24px;border-radius:12px;cursor:pointer;box-shadow:0 4px 16px #d9770640}.insights-teaser__cta:active{opacity:.85;transform:scale(.97)}.composite-hero{display:flex;flex-direction:column;align-items:center;padding:4px 0}.composite-hero__gauge{position:relative;width:180px;height:180px}.composite-hero__glow{position:absolute;top:-20px;right:-20px;bottom:-20px;left:-20px;border-radius:50%;pointer-events:none;z-index:0}.composite-hero__gauge svg{display:block;position:relative;z-index:1}.composite-hero__score-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2}.composite-hero__score-value{font-size:42px;font-weight:800;line-height:1;color:var(--text);font-variant-numeric:tabular-nums}.composite-hero__score-unit{font-size:13px;color:var(--text-secondary);margin-block-start:2px;font-weight:500}.composite-hero__tier{margin-block-start:12px;font-size:13px;font-weight:700;padding:5px 16px;border-radius:20px;color:#fff;letter-spacing:.02em;box-shadow:0 2px 8px #00000026}.composite-hero__subtitle{font-size:12px;color:var(--text-secondary);margin-block-start:8px}.dimensions-breakdown{display:flex;flex-direction:column;gap:12px}.dimension-bar{display:flex;align-items:center;gap:12px}.dimension-bar__icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 8px #0000001a}.dimension-bar__icon svg{width:16px;height:16px;color:#fff}.dimension-bar__info{flex:1;min-width:0}.dimension-bar__header{display:flex;justify-content:space-between;align-items:baseline;margin-block-end:4px}.dimension-bar__label{font-size:13px;font-weight:600;color:var(--text)}.dimension-bar__value{font-size:13px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.dimension-bar__track{height:8px;border-radius:4px;background:var(--bg-secondary, rgba(128, 128, 128, .1));overflow:hidden}.dimension-bar__fill{height:100%;border-radius:4px}.books-studied{padding:16px}.books-studied__header{display:flex;align-items:center;gap:8px;margin-block-end:14px}.books-studied__header-icon{color:var(--ion-color-primary)}.books-studied__title{font-size:14px;font-weight:700;color:var(--text);flex:1}.books-studied__count{font-size:11px;font-weight:700;color:var(--text-secondary);background:var(--bg-secondary, rgba(128, 128, 128, .1));padding:2px 8px;border-radius:10px}.books-studied__list{display:flex;flex-direction:column;gap:2px}.book-row{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:none;display:flex;align-items:center;gap:10px;padding:10px 4px;border-radius:10px;cursor:pointer;transition:background .15s;text-align:start;width:100%}.book-row:hover{background:var(--bg-secondary, rgba(128, 128, 128, .05))}.book-row:active{background:var(--bg-secondary, rgba(128, 128, 128, .1))}.book-row__pip{width:6px;height:32px;border-radius:3px;flex-shrink:0}.book-row__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.book-row__name{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.book-row__meta{font-size:11px;color:var(--text-secondary);display:flex;align-items:center;gap:3px}.book-row__progress{display:flex;align-items:center;gap:8px;flex-shrink:0;width:110px}.book-row__bar{flex:1;height:6px;border-radius:3px;background:var(--bg-secondary, rgba(128, 128, 128, .1));overflow:hidden}.book-row__fill{height:100%;border-radius:3px}.book-row__pct{font-size:13px;font-weight:700;font-variant-numeric:tabular-nums;width:36px;text-align:end}.insight-detail{padding:20px 16px}.insight-detail__header{display:flex;align-items:center;gap:12px;margin-block-end:16px}.insight-detail__tier-badge{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:900;color:#fff;box-shadow:0 2px 8px #00000026}.insight-detail__name{font-size:18px;font-weight:700;color:var(--text)}.insight-detail__tier-label{font-size:13px;font-weight:600;margin-block-start:2px}.insight-detail__stat-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--glass-border)}.insight-detail__stat-label{font-size:13px;color:var(--text-secondary)}.insight-detail__stat-value{font-size:14px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.insight-detail__oia{display:flex;gap:8px;padding:14px 0}.insight-detail__oia-item{flex:1;text-align:center}.insight-detail__oia-bar-track{height:8px;border-radius:4px;background:var(--bg-secondary, rgba(128, 128, 128, .1));overflow:hidden;margin-block-end:4px}.insight-detail__oia-bar-fill{height:100%;border-radius:4px}.insight-detail__oia-label{font-size:10px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em}:root{--league-bronze: #cd7f32;--league-silver: #c0c0c0;--league-gold: #ffd700;--league-diamond: #b9f2ff}.leaderboard-page{margin:0 auto;padding:24px 16px 100px;padding-top:calc(24px + var(--ion-safe-area-top, env(safe-area-inset-top, 0px)))}.leaderboard-layout{display:flex;flex-direction:column;gap:0}.leaderboard-sidebar{display:contents}.leaderboard-sidebar__sticky,.leaderboard-main{display:flex;flex-direction:column}.leaderboard-main__controls{display:flex;flex-direction:column;gap:0;padding-bottom:8px;margin-bottom:4px}.leaderboard-main__content{flex:1}.league-header{display:flex;flex-direction:column;align-items:center;gap:14px;margin-bottom:24px}.league-badge{position:relative}.league-badge__shield{position:relative;width:72px;height:72px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:linear-gradient(135deg,var(--league-from, #cd7f32),var(--league-to, #a0522d));backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1.5px solid rgba(255,255,255,.2);box-shadow:0 6px 28px #0000002e,0 2px 8px #0000001a,inset 0 1px #ffffff26}.league-badge__shield svg{width:40px;height:40px}.league-badge__shield--pulse{animation:league-badge-pulse 2s ease-in-out infinite}@keyframes league-badge-pulse{0%,to{box-shadow:0 6px 28px #0000002e,0 2px 8px #0000001a,inset 0 1px #ffffff26}50%{box-shadow:0 6px 28px #0000002e,0 0 22px color-mix(in srgb,var(--league-color, #fff) 45%,transparent),0 2px 8px #0000001a,inset 0 1px #ffffff26}}.league-badge__shine{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;overflow:hidden;pointer-events:none}.league-badge__shine:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(105deg,transparent 30%,rgba(255,255,255,.4) 45%,transparent 55%);animation:shine-sweep 2s ease-in-out infinite}@keyframes shine-sweep{0%{transform:translate(-120%)}50%,to{transform:translate(120%)}}.league-header__text{text-align:center}.league-header__title-row{display:flex;align-items:center;justify-content:center;gap:8px}.league-header__title{font-size:1.5rem;font-weight:700;margin:0;letter-spacing:-.02em}.league-header__info-btn{background:var(--surface);border:1.5px solid var(--border);border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-light);transition:all .2s;-webkit-tap-highlight-color:transparent;box-shadow:0 1px 4px #0000000f}.league-header__info-btn:hover{background:var(--tint-neutral);color:var(--text);box-shadow:0 2px 8px #0000001a}.league-header__info-btn:active{transform:scale(.9)}.league-header__badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:var(--radius);font-size:.75rem;font-weight:600;margin-top:4px}.league-header__badge--promoted{background:#58cc0226;color:var(--green)}.league-header__badge--demoted{background:#ef44441a;color:var(--red, #ef4444)}.league-header__rank{margin:4px 0 0;font-size:.85rem;color:var(--text-light);font-weight:500}.leaderboard-section-divider{width:60px;height:2px;background:var(--border);border-radius:1px;margin:4px auto 16px;opacity:.5}@media(min-width:1024px){.leaderboard-section-divider{display:none}}.period-tabs{margin-bottom:8px;text-align:center}.period-tabs__track{display:inline-flex;gap:4px;padding:4px;border-radius:var(--radius);background:var(--surface)}.period-tabs__pill{position:relative;padding:8px 20px;border:none;border-radius:calc(var(--radius) - 2px);background:transparent;color:var(--text-light);font-family:inherit;font-weight:600;font-size:.85rem;cursor:pointer;z-index:1;transition:color .15s}.period-tabs__pill.active{color:var(--text)}.period-tabs__indicator{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:calc(var(--radius) - 2px);background:var(--bg);box-shadow:0 1px 3px #0000001a;z-index:-1}.period-tabs__label{position:relative;z-index:1}.period-tabs__countdown{margin:8px 0 0;font-size:.75rem;color:var(--text-light)}.podium{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;align-items:flex-end;margin-bottom:20px}.podium--solo{display:flex;justify-content:center;min-height:0}.podium__slot--empty{min-height:100px}.podium__card{display:flex;flex-direction:column;align-items:center;gap:4px;position:relative;padding:12px 8px 0;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;font-family:inherit;color:var(--text);transition:border-color .2s,box-shadow .2s,transform .2s}.podium__card:hover{border-color:var(--border);transform:translateY(-2px)}.podium__card--current.podium__card--rank-1{border-color:var(--green);box-shadow:0 0 16px #58cc0226}.podium__card--rank-1{box-shadow:0 4px 20px #ffd70033}.podium__card--rank-1:hover{box-shadow:0 6px 28px #ffd7004d}@keyframes podium-float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.podium__card--rank-1{animation:podium-float 3s ease-in-out infinite}.podium__medal{display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.podium__avatar-wrap{position:relative}.podium__avatar-img,.podium__avatar-initials{width:52px;height:52px;border-radius:50%;object-fit:cover}.podium__avatar-initials{display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:1rem}.podium__level{position:absolute;bottom:-4px;right:-4px;background:var(--surface);color:var(--text);font-size:.65rem;font-weight:600;padding:2px 6px;border-radius:999px;border:2px solid var(--bg)}.podium__name{font-size:.8rem;font-weight:600;max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.podium__xp{font-size:.7rem;color:var(--text-light);font-weight:600}.podium__pedestal{width:100%;border-radius:var(--radius) var(--radius) 0 0;display:flex;align-items:flex-end;justify-content:center;padding:8px 0;margin-top:4px;background:linear-gradient(180deg,var(--pedestal-color, rgba(0, 0, 0, .04)) 0%,transparent 100%)}.podium__rank-badge{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;transition:transform .2s ease}.podium__rank-badge--1{background:#f5c518}.podium__rank-badge--2{background:#b0b0b0}.podium__rank-badge--3{background:#cd7f32}.podium__card:hover .podium__rank-badge{transform:scale(1.08)}.podium__rank-number{font-size:.95rem;font-weight:800;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3);line-height:1;letter-spacing:-.02em}.podium--solo .podium__card{width:min(100%,240px);padding-bottom:16px}.podium--solo .podium__pedestal{width:auto;min-width:72px;height:auto!important;padding:10px 18px;margin-top:10px;border-radius:999px;align-items:center}.podium--solo .podium__rank-badge{width:32px;height:32px}.podium--solo .podium__rank-number{font-size:.85rem}.rank-list{display:grid;grid-template-columns:1fr 1fr;gap:8px;align-items:stretch}.rank-list>*{display:flex;flex-direction:column}@media(max-width:480px){.rank-list{grid-template-columns:1fr}}.rank-row{display:flex;align-items:center;gap:12px;padding:12px 16px;width:100%;flex:1;border-radius:var(--radius);background:var(--surface);cursor:pointer;border:1.5px solid var(--border);transition:border-color .15s,background .15s,box-shadow .15s}.rank-row:hover{border-color:var(--border);box-shadow:0 4px 12px #0000001a}.rank-row:active{box-shadow:0 2px 6px #00000014,0 0 0 2px #58cc021a}.rank-row--current{border-color:var(--green);box-shadow:0 0 12px #58cc0226}.rank-row--promote-zone{border-inline-start:3px solid rgba(88,204,2,.4);background:linear-gradient(90deg,rgba(88,204,2,.04) 0%,transparent 20%)}.rank-row--demote-zone{border-inline-start:3px solid rgba(239,68,68,.3);background:linear-gradient(90deg,rgba(239,68,68,.04) 0%,transparent 20%)}.rank-row__position{min-width:28px;text-align:center;font-weight:600;font-size:.85rem;color:var(--text-light)}.rank-row__position--top10{font-weight:600;color:var(--text)}.rank-row__avatar{flex-shrink:0}.rank-row__avatar-img,.rank-row__avatar-initials{width:40px;height:40px;border-radius:50%;object-fit:cover}.rank-row__avatar-initials{display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.85rem}.rank-row__info{flex:1;min-width:0;display:flex;align-items:center;gap:6px}.rank-row__name{font-weight:600;font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rank-row__level{font-size:.7rem;font-weight:600;padding:2px 6px;border-radius:999px;background:var(--bg);color:var(--text-light);flex-shrink:0}.rank-row__stats{display:flex;align-items:center;gap:8px;flex-shrink:0}.rank-row__xp{font-weight:600;font-size:.85rem;color:var(--green)}.rank-row__streak{display:inline-flex;align-items:center;gap:2px;font-size:.75rem;font-weight:600;color:#ff9600}.rank-row--skeleton{pointer-events:none}.skeleton-bone{border-radius:var(--radius);background:var(--border);animation:shimmer 1.5s infinite ease-in-out}@keyframes shimmer{0%,to{opacity:.4}50%{opacity:.8}}.skeleton-bone--rank{width:28px;height:16px}.skeleton-bone--avatar{width:40px;height:40px;border-radius:50%}.skeleton-bone--medal{width:28px;height:28px;border-radius:50%;margin-bottom:4px}.skeleton-bone--name{flex:1;height:16px;max-width:120px}.skeleton-bone--xp{width:60px;height:16px}.podium--skeleton{align-items:center}.podium__card--skeleton{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px 12px;pointer-events:none}.leaderboard-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:48px 16px;text-align:center}.leaderboard-empty__icon{color:var(--text-light);opacity:.5;margin-bottom:8px}.leaderboard-empty__text{font-weight:600;font-size:1rem;margin:0;color:var(--text)}.leaderboard-empty__subtext{font-size:.85rem;color:var(--text-light);margin:0}.leaderboard-empty__cta{margin-top:8px;padding:10px 24px;border-radius:var(--radius);border:none;background:var(--green);color:#fff;font-weight:600;font-family:inherit;font-size:.9rem;cursor:pointer}.leaderboard-child-optin{display:flex;align-items:center;gap:14px;padding:16px 20px;margin:0 0 12px;border-radius:var(--radius-lg, 16px);background:linear-gradient(135deg,#cd7f32,sienna);color:#fff;box-shadow:0 4px 16px #cd7f324d}.leaderboard-child-optin__icon{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#fff3}.leaderboard-child-optin__text{flex:1;min-width:0}.leaderboard-child-optin__text h3{margin:0 0 2px;font-size:1rem;font-weight:700;line-height:1.2}.leaderboard-child-optin__text p{margin:0;font-size:.8rem;opacity:.85;line-height:1.3}.leaderboard-child-optin__cta{flex-shrink:0;padding:10px 20px;border-radius:var(--radius, 12px);border:none;background:#fff;color:sienna;font-weight:700;font-family:inherit;font-size:.85rem;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;min-width:110px;text-align:center}.leaderboard-child-optin__cta:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.leaderboard-child-optin__cta:active:not(:disabled){transform:scale(.97)}.leaderboard-child-optin__cta:disabled{opacity:.7;cursor:not-allowed}.leaderboard-child-optin__spinner{display:inline-block;width:18px;height:18px;border:2.5px solid rgba(160,82,45,.3);border-top-color:sienna;border-radius:50%;animation:optin-spin .6s linear infinite;vertical-align:middle}@keyframes optin-spin{to{transform:rotate(360deg)}}@media(max-width:480px){.leaderboard-child-optin{flex-direction:column;text-align:center;gap:10px;padding:20px 16px}.leaderboard-child-optin__cta{width:100%}}.language-picker-card{position:fixed;top:10px;right:12px;width:400px;max-width:calc(100vw - 24px);background:var(--surface, #fff);border:1.5px solid var(--border, #e5e5e5);border-radius:var(--radius-lg, 16px);box-shadow:0 8px 32px #0000001f;z-index:calc(var(--z-overlay) + 1);padding:14px 16px 16px;display:flex;flex-direction:column;gap:6px}.language-picker-card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.language-picker-card__title{font-size:1rem;font-weight:600;margin:0}.language-picker-card__close{background:none;border:none;padding:4px;cursor:pointer;color:var(--text-light, #aaa);display:flex;align-items:center;border-radius:50%;transition:background .15s}.language-picker-card__close:hover{background:var(--border, #e5e7eb)}.language-picker-card__list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(2,1fr);gap:4px}.language-picker-card__option{display:flex;align-items:center;gap:10px;width:100%;padding:10px;border:none;border-radius:var(--radius-sm, 12px);background:transparent;color:var(--text);font-family:inherit;font-size:.95rem;cursor:pointer;transition:background .15s}.language-picker-card__option:hover,.language-picker-card__option.is-active{background:var(--tint-neutral)}.language-picker-card__flag{font-size:1.3rem;line-height:1}.language-picker-card__labels{display:flex;flex-direction:column;align-items:flex-start;flex:1;min-width:0}.language-picker-card__native{font-weight:600;font-size:.9rem}.language-picker-card__label{font-size:.75rem;opacity:.6}.language-picker-card__check{color:var(--blue);flex-shrink:0}[data-theme=dark] .language-picker-card{box-shadow:0 8px 32px #0006}.translation-picker__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:var(--z-overlay)}.translation-picker__viewport{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:calc(env(safe-area-inset-top,0px) + 16px) 16px calc(env(safe-area-inset-bottom,0px) + 16px);z-index:calc(var(--z-overlay) + 1);pointer-events:none}.translation-picker{position:relative;width:420px;max-width:100%;max-height:min(calc(100vh - 32px),calc(100dvh - 32px));background:var(--surface, #fff);border:1.5px solid var(--border, #e5e5e5);border-radius:var(--radius-lg, 16px);box-shadow:0 12px 48px #00000026;padding:16px;display:flex;flex-direction:column;gap:8px;pointer-events:auto}.translation-picker__header{display:flex;align-items:center;justify-content:space-between}.translation-picker__title{font-size:1rem;font-weight:600;margin:0}.translation-picker__close{background:none;border:none;padding:4px;cursor:pointer;color:var(--text-light, #aaa);display:flex;align-items:center;border-radius:50%;transition:background .15s}.translation-picker__close:hover{background:var(--border, #e5e7eb)}.translation-picker__search{display:flex;align-items:center;gap:8px;background:var(--tint-neutral, #f4f4f5);border-radius:var(--radius-sm, 12px);padding:8px 12px}.translation-picker__search-icon{color:var(--text-light, #aaa);flex-shrink:0}.translation-picker__search-input{flex:1;border:none;background:none;outline:none;font-family:inherit;font-size:.9rem;color:var(--text)}.translation-picker__search-input::placeholder{color:var(--text-light, #aaa)}.translation-picker__list{overflow-y:auto;max-height:50vh;display:flex;flex-direction:column;gap:2px;overscroll-behavior:contain}.translation-picker__loading{display:flex;justify-content:center;padding:24px 0}.translation-picker__group{display:flex;flex-direction:column;gap:1px}.translation-picker__group-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-light, #aaa);padding:10px 10px 4px}.translation-picker__option{display:flex;align-items:center;gap:10px;width:100%;padding:10px;border:none;border-radius:var(--radius-sm, 12px);background:transparent;color:var(--text);font-family:inherit;font-size:.9rem;cursor:pointer;transition:background .15s;text-align:start}.translation-picker__option:hover,.translation-picker__option.is-active{background:var(--tint-neutral)}.translation-picker__option-info{display:flex;flex-direction:column;flex:1;min-width:0}.translation-picker__abbr{font-weight:600;font-size:.85rem}.translation-picker__name{font-size:.75rem;opacity:.6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.translation-picker__check{color:var(--blue);flex-shrink:0}.translation-picker__empty{text-align:center;padding:20px;color:var(--text-light, #aaa);font-size:.9rem}[data-theme=dark] .translation-picker{box-shadow:0 12px 48px #00000073}[data-theme=dark] .translation-picker__backdrop{background:#00000080}.user-detail-sheet{position:fixed;bottom:0;left:0;right:0;max-height:85vh;background:var(--surface);border-radius:var(--radius) var(--radius) 0 0;padding:12px 20px 32px;z-index:calc(var(--z-overlay-elevated) + 1);overflow-y:auto;box-shadow:0 -4px 32px #00000026}.user-detail-sheet__handle{width:40px;height:4px;border-radius:999px;background:var(--border);margin:0 auto 16px}.user-detail__hero{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:20px}.user-detail__avatar-img,.user-detail__avatar-initials{width:80px;height:80px;border-radius:50%;object-fit:cover}.user-detail__avatar-initials{display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:1.5rem}.user-detail__name{font-size:1.25rem;font-weight:600;margin:0}.user-detail__badges{display:flex;gap:8px}.user-detail__level-pill,.user-detail__league-pill{padding:4px 12px;border-radius:999px;font-size:.75rem;font-weight:600}.user-detail__level-pill{background:var(--bg);color:var(--text)}.user-detail__last-active{font-size:.75rem;color:var(--text-light);margin:0}.user-detail__stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:20px}.user-detail__stat-cell{display:flex;flex-direction:column;align-items:center;gap:2px;padding:12px 8px;border-radius:var(--radius);background:var(--bg)}.user-detail__stat-icon{display:flex;align-items:center}.user-detail__stat-value{font-weight:600;font-size:1.1rem}.user-detail__stat-label{font-size:.7rem;color:var(--text-light);font-weight:600}.user-detail__achievements{margin-bottom:16px}.user-detail__section-title{font-size:.85rem;font-weight:600;margin:0 0 8px}.user-detail__achievement-row{display:flex;gap:8px;flex-wrap:wrap}.user-detail__achievement-badge{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--border);background:var(--bg);color:var(--text-light)}.user-detail__achievement-badge--bronze{border-color:var(--league-bronze);color:var(--league-bronze)}.user-detail__achievement-badge--silver{border-color:var(--league-silver);color:#888}.user-detail__achievement-badge--gold{border-color:var(--league-gold);color:var(--league-gold)}.user-detail__achievement-badge--diamond{border-color:var(--league-diamond);color:#00ced1}.rank-footer{position:fixed;bottom:calc(56px + env(safe-area-inset-bottom,0px));left:0;right:0;display:flex;align-items:center;gap:12px;padding:12px 20px;background:#ffffffd9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--border);z-index:100;cursor:pointer;border:none;font-family:inherit;color:var(--text);width:100%;max-width:100%}.rank-footer__position{min-width:36px;font-weight:600;font-size:1rem;color:var(--green)}.rank-footer__avatar{flex-shrink:0}.rank-footer__avatar-img,.rank-footer__avatar-initials{width:36px;height:36px;border-radius:50%;object-fit:cover}.rank-footer__avatar-initials{display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.8rem}.rank-footer__name{flex:1;font-weight:600;font-size:.9rem}.rank-footer__stats{display:flex;align-items:center;gap:8px}.rank-footer__xp{font-weight:600;font-size:.85rem;color:var(--green)}.rank-footer__streak{display:inline-flex;align-items:center;gap:2px;font-size:.75rem;font-weight:600;color:#ff9600}.leaderboard-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:var(--z-overlay-elevated)}@media(min-width:768px){.leaderboard-page{padding:32px 24px 100px;padding-top:calc(32px + var(--ion-safe-area-top, env(safe-area-inset-top, 0px)))}.podium{gap:16px}.podium__avatar-img,.podium__avatar-initials{width:64px;height:64px}.podium__name{font-size:.9rem;max-width:120px}.user-detail-sheet{max-width:480px;left:calc(50% - 240px);border-radius:var(--radius) var(--radius) 0 0;bottom:0;max-height:70vh}}@media(min-width:1024px){.leaderboard-page{max-width:1180px;padding:36px 32px 80px;padding-top:calc(36px + var(--ion-safe-area-top, env(safe-area-inset-top, 0px)))}.leaderboard-layout{display:grid;grid-template-columns:340px 1fr;gap:32px;align-items:start}.leaderboard-sidebar{display:block}.leaderboard-sidebar__sticky{position:sticky;top:calc(16px + var(--ion-safe-area-top, env(safe-area-inset-top, 0px)));padding:24px 20px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg, 24px);box-shadow:var(--shadow-card)}.leaderboard-main{min-width:0}.leaderboard-main__controls{position:sticky;top:calc(16px + var(--ion-safe-area-top, env(safe-area-inset-top, 0px)));z-index:10;background:var(--bg);padding:12px 0 4px;border-bottom:1px solid var(--border);margin-bottom:16px;border-radius:var(--radius) var(--radius) 0 0}.league-header{margin-bottom:20px}.league-badge__shield{width:88px;height:88px}.league-badge__shield svg{width:52px;height:52px}.league-header__title{font-size:1.25rem}.league-progression{max-width:100%}.league-ladder__node{max-width:100%;padding:10px 14px}.league-progress-bar{max-width:100%;padding:12px 14px 4px}.podium__card{padding:16px 12px 0}.rank-row{padding:14px 20px}}@media(min-width:1400px){.leaderboard-page{max-width:1280px}.leaderboard-layout{grid-template-columns:380px 1fr;gap:40px}}@media(min-width:1024px){[data-theme=dark] .leaderboard-sidebar__sticky{background:var(--surface);border-color:#ffffff0f;box-shadow:0 2px 20px #0000004d}[data-theme=dark] .leaderboard-main__controls{background:var(--bg);border-bottom-color:#ffffff0f}[data-theme=sepia] .leaderboard-sidebar__sticky{background:var(--surface)}[data-theme=sepia] .leaderboard-main__controls{background:var(--bg)}}[data-theme=dark] .league-header__info-btn{background:#ffffff0f;border-color:#ffffff1a;box-shadow:0 1px 4px #0003}[data-theme=dark] .league-header__info-btn:hover{background:#ffffff1a}[data-theme=dark] .rank-footer{background:#1e1e1ed9}[data-theme=sepia] .rank-footer{background:#f5eddcd9}[data-theme=gray] .rank-footer{background:#282828d9}.league-progression{margin:0 auto 8px;max-width:400px}.league-progression__toggle{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 20px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:inherit;font-size:.82rem;font-weight:600;letter-spacing:.01em;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .2s,box-shadow .2s}.league-progression__toggle:hover{box-shadow:var(--shadow-card)}.league-progression__toggle:active{transform:scale(.98)}.league-progression__toggle svg{transition:transform .3s cubic-bezier(.34,1.56,.64,1);color:var(--text-light)}.league-progression__toggle--open svg{transform:rotate(180deg)}.league-ladder{display:flex;flex-direction:column;align-items:center;gap:0;padding:20px 12px 8px}.league-ladder__node{display:flex;align-items:center;gap:14px;padding:12px 18px;border-radius:var(--radius);width:100%;max-width:360px;position:relative;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity .2s,background .2s,transform .15s;background:transparent;border:1.5px solid transparent;text-align:start;font:inherit;color:inherit}.league-ladder__node:active{transform:scale(.97)}.league-ladder__node--above{opacity:.4}.league-ladder__node--above:hover{opacity:.6;background:var(--tint-neutral, #fafafa)}.league-ladder__node--current{opacity:1;background:var(--surface);border-color:var(--border);box-shadow:var(--shadow-card)}.league-ladder__node--below{opacity:.65}.league-ladder__node--below:hover{opacity:.85;background:var(--tint-neutral, #fafafa)}.league-ladder__connector{width:2.5px;height:20px;margin:0 auto;border-radius:2px;background:linear-gradient(to bottom,var(--border),transparent);opacity:.6}.league-ladder__icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 8px #0000001f;position:relative}.league-ladder__node--current .league-ladder__icon:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;background:inherit;opacity:.2;filter:blur(8px);z-index:-1}.league-ladder__details{flex:1;min-width:0}.league-ladder__name{font-weight:700;font-size:.92rem;color:var(--text);line-height:1.3}.league-ladder__threshold{font-size:.74rem;color:var(--text-light);margin-top:2px;line-height:1.3}.league-ladder__current-tag{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;padding:3px 10px;border-radius:999px;flex-shrink:0}.league-ladder__info-icon{color:var(--text-light);flex-shrink:0;opacity:.5;transition:opacity .15s}.league-ladder__node:hover .league-ladder__info-icon{opacity:.8}.league-progress-bar{padding:16px 18px 6px;max-width:360px;margin:4px auto 0}.league-progress-bar__label{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px;font-size:.8rem}.league-progress-bar__text{color:var(--text-light);font-weight:500}.league-progress-bar__xp{font-weight:700;font-size:.82rem;color:var(--text);font-variant-numeric:tabular-nums}.league-progress-bar__track{height:12px;border-radius:6px;background:var(--border);overflow:hidden;position:relative;box-shadow:inset 0 1px 3px #0000000f}.league-progress-bar__fill{height:100%;border-radius:6px;min-width:6px;position:relative;box-shadow:0 1px 4px #00000026}.league-progress-bar__fill:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.35) 50%,transparent 100%);animation:progress-shimmer 2.5s ease-in-out infinite}@keyframes progress-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.league-progress-bar__ready{text-align:center;font-size:.78rem;font-weight:700;color:var(--green, #58cc02);margin-top:8px;letter-spacing:.01em}.league-progress-compact{display:flex;align-items:center;gap:8px;margin-top:8px;justify-content:center}.league-progress-compact__track{flex:1;height:7px;border-radius:4px;background:var(--border);overflow:hidden;max-width:130px;box-shadow:inset 0 1px 2px #0000000d}.league-progress-compact__fill{height:100%;border-radius:4px;min-width:3px;box-shadow:0 1px 3px #0000001a}.league-progress-compact__text{font-size:.72rem;color:var(--text-light);font-weight:600;white-space:nowrap;font-variant-numeric:tabular-nums}[dir=rtl] .league-progress-bar__fill:after{animation-direction:reverse}[data-theme=dark] .league-progression__toggle{background:var(--surface);border-color:#ffffff14}[data-theme=dark] .league-ladder__node--current{background:var(--surface);border-color:#ffffff14;box-shadow:0 2px 16px #00000059}[data-theme=dark] .league-ladder__node--above:hover,[data-theme=dark] .league-ladder__node--below:hover{background:#ffffff0a}[data-theme=dark] .league-progress-bar__track,[data-theme=dark] .league-progress-compact__track{background:#ffffff14;box-shadow:inset 0 1px 3px #0003}[data-theme=dark] .league-ladder__connector{background:linear-gradient(to bottom,rgba(255,255,255,.1),transparent)}[data-theme=sepia] .league-progression__toggle,[data-theme=gray] .league-progression__toggle{background:var(--surface)}.league-filter{display:flex;gap:8px;overflow-x:auto;padding:4px 4px 16px;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;justify-content:center;flex-wrap:wrap}.league-filter::-webkit-scrollbar{display:none}.league-filter__pill{display:flex;align-items:center;gap:7px;padding:8px 16px;border-radius:999px;border:1.5px solid var(--border);background:var(--surface);font-family:inherit;font-size:.8rem;font-weight:600;color:var(--text-light);cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .2s ease;-webkit-tap-highlight-color:transparent;box-shadow:0 1px 3px #0000000a}.league-filter__pill:hover{border-color:var(--text-light);box-shadow:0 2px 8px #00000014;transform:translateY(-1px)}.league-filter__pill:active{transform:scale(.96)}.league-filter__pill--active{border-color:transparent;color:#fff;box-shadow:0 3px 12px #00000026;font-weight:700}.league-filter__pill--active:hover{border-color:transparent;box-shadow:0 4px 16px #0003}.league-filter__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;box-shadow:0 0 4px currentColor}.league-filter__pill--active .league-filter__dot{background:#ffffffb3!important;box-shadow:0 0 6px #ffffff80}[data-theme=dark] .league-filter__pill{background:#ffffff0a;border-color:#ffffff14;box-shadow:0 1px 3px #0003}[data-theme=dark] .league-filter__pill:hover{border-color:#fff3;box-shadow:0 2px 8px #0000004d}[data-theme=dark] .league-filter__pill--active{border-color:transparent;box-shadow:0 3px 12px #00000059}[data-theme=sepia] .league-filter__pill,[data-theme=gray] .league-filter__pill{background:var(--surface)}.league-info-sheet{position:fixed;bottom:0;left:0;right:0;background:var(--bg, #fff);border-radius:28px 28px 0 0;padding:12px 20px 32px;padding-bottom:calc(32px + var(--ion-safe-area-bottom, env(safe-area-inset-bottom, 0px)));z-index:10001;max-height:88vh;overflow-y:auto;box-shadow:0 -8px 40px #00000024,0 -2px 12px #0000000f;overscroll-behavior:contain}@media(min-width:768px){.league-info-sheet{max-width:560px;left:calc(50% - 280px)}}.league-info-sheet__handle{width:36px;height:4px;background:var(--border);border-radius:2px;margin:0 auto 16px;opacity:.5}.league-info-sheet__header{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:20px}.league-info-sheet__trophy{color:var(--orange, #ff9600)}.league-info-sheet__title{font-size:1.1rem;font-weight:600;text-align:center;margin:0;color:var(--text);letter-spacing:-.01em}.league-info__ladder{position:relative}.league-info__track{position:absolute;left:10px;top:32px;bottom:32px;width:3px;border-radius:2px;background:linear-gradient(to bottom,#b9f2ff,gold 35%,silver 65%,#cd7f32);opacity:.35}.league-info__tiers{display:flex;flex-direction:column;gap:10px}.league-info__tier{display:flex;align-items:flex-start;gap:14px;padding:14px 16px;border-radius:var(--radius, 16px);background:var(--surface, #fff);border:1.5px solid var(--border, #e5e5e5);position:relative;transition:border-color .3s ease,box-shadow .3s ease,background .3s ease}.league-info__tier--focused{border-color:var(--tier-color);background:linear-gradient(135deg,color-mix(in srgb,var(--tier-from) 6%,var(--surface, #fff)),color-mix(in srgb,var(--tier-to) 4%,var(--surface, #fff)));box-shadow:0 0 0 1px var(--tier-color),0 4px 20px color-mix(in srgb,var(--tier-color) 20%,transparent),0 1px 4px #0000000f}.league-info__shield-wrap .league-badge__shield svg{width:24px;height:24px}.league-info__shield-wrap{position:relative;flex-shrink:0;width:56px;display:flex;align-items:center;justify-content:center}.league-info__track-dot{position:absolute;left:-6px;top:50%;transform:translateY(-50%);width:11px;height:11px;border-radius:50%;background:var(--tier-color);border:2.5px solid var(--bg, #fff);box-shadow:0 0 0 1px color-mix(in srgb,var(--tier-color) 30%,transparent);z-index:1}.league-info__tier--focused .league-info__track-dot{box-shadow:0 0 0 2px color-mix(in srgb,var(--tier-color) 40%,transparent),0 0 8px color-mix(in srgb,var(--tier-color) 30%,transparent)}.league-info__content{flex:1;min-width:0;padding-top:2px}.league-info__name{font-weight:700;font-size:1.05rem;margin:0 0 8px;color:var(--tier-color);display:flex;align-items:center;gap:8px;letter-spacing:-.01em}.league-info__you-badge{font-size:.6rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;background:var(--tier-color);color:#fff;padding:2px 7px;border-radius:6px;line-height:1.4}.league-info__rules{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px}.league-info__pill{display:inline-flex;align-items:center;gap:5px;font-size:.82rem;font-weight:600;padding:4px 10px;border-radius:8px;line-height:1.4;white-space:nowrap}.league-info__pill svg{flex-shrink:0}.league-info__pill--promote{background:color-mix(in srgb,var(--green, #58cc02) 12%,transparent);color:var(--green-dark, #46a302)}.league-info__pill--crown{background:linear-gradient(135deg,#ff96001f,#ffd70026);color:var(--orange, #ff9600)}.league-info__pill--maintain{background:color-mix(in srgb,var(--text-light, #777) 10%,transparent);color:var(--text-light, #777)}.league-info__pill--demote{background:color-mix(in srgb,var(--red, #ff4b4b) 10%,transparent);color:var(--red-dark, #ea2b2b)}.league-info__xp-bar{position:relative;height:6px;border-radius:3px;background:color-mix(in srgb,var(--border, #e5e5e5) 70%,transparent);overflow:hidden;margin-top:2px}.league-info__xp-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--tier-from),var(--tier-to));transition:width .6s ease}.league-info__xp-label{position:absolute;right:0;top:-15px;font-size:.62rem;font-weight:700;color:var(--text-light, #777);letter-spacing:.02em}[data-theme=dark] .league-info-sheet{background:var(--bg);box-shadow:0 -8px 40px #00000080,0 -2px 12px #0000004d}[data-theme=dark] .league-info__tier{border-color:#ffffff0f;background:#ffffff08}[data-theme=dark] .league-info__tier--focused{background:linear-gradient(135deg,color-mix(in srgb,var(--tier-from) 10%,rgba(255,255,255,.03)),color-mix(in srgb,var(--tier-to) 6%,rgba(255,255,255,.02)));border-color:color-mix(in srgb,var(--tier-color) 60%,transparent)}[data-theme=dark] .league-info__track{opacity:.25}[data-theme=dark] .league-info__track-dot{border-color:var(--bg, #121214)}[data-theme=dark] .league-info__pill--promote{background:#58cc021f}[data-theme=dark] .league-info__pill--maintain{background:#ffffff0f}[data-theme=dark] .league-info__pill--demote{background:#ff4b4b1a}[data-theme=dark] .league-info__pill--crown{background:#ff96001f}[data-theme=dark] .league-info__xp-bar{background:#ffffff0f}.nav-rail{position:fixed;top:0;inset-inline-start:0;bottom:0;width:200px;display:flex;flex-direction:column;align-items:stretch;background:#ffffffb8;backdrop-filter:blur(24px) saturate(1.6);-webkit-backdrop-filter:blur(24px) saturate(1.6);box-shadow:2px 0 20px #0000000a;z-index:100;padding:env(safe-area-inset-top,0px) 0 env(safe-area-inset-bottom,0px);overflow:hidden;transition:box-shadow .3s ease}.nav-rail--collapsed{width:68px}.nav-rail__brand{display:flex;align-items:center;justify-content:center;height:56px;flex-shrink:0;padding-inline:16px;overflow:hidden}.nav-rail__brand-text{font-family:var(--font);font-size:18px;font-weight:300;letter-spacing:-.02em;color:var(--text);white-space:nowrap;-webkit-user-select:none;user-select:none}.nav-rail__items{display:flex;flex-direction:column;gap:2px;padding:4px 8px;flex:1}.nav-rail__item{display:flex;flex-direction:row;align-items:center;gap:12px;padding:10px 12px;width:100%;background:none;border:none;border-radius:14px;cursor:pointer;color:var(--text-light);font-family:var(--font);font-size:14px;font-weight:500;letter-spacing:.005em;transition:color .2s ease,background .2s ease;-webkit-tap-highlight-color:transparent;position:relative;overflow:hidden}.nav-rail__item:hover{color:var(--text);background:#0000000a}.nav-rail__item--active{color:var(--green)}.nav-rail__item--active:hover{background:var(--tint-green, rgba(74, 222, 128, .08))}.nav-rail__pill{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--tint-green, rgba(74, 222, 128, .12));border-radius:14px;z-index:0}.nav-rail__icon-wrap{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;width:24px;height:24px;flex-shrink:0}.nav-rail__icon-wrap ion-icon{font-size:22px}.nav-rail__label{position:relative;z-index:1;line-height:1;white-space:nowrap;overflow:hidden}.nav-rail--collapsed .nav-rail__item{justify-content:center;padding:12px}.nav-rail--collapsed .nav-rail__items{padding:4px 6px}.nav-rail__toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;margin:8px auto 12px;background:none;border:1px solid var(--border);border-radius:10px;cursor:pointer;color:var(--text-light);font-size:18px;transition:background .2s ease,color .2s ease,transform .2s ease,border-color .2s ease;-webkit-tap-highlight-color:transparent;flex-shrink:0}.nav-rail__toggle:hover{background:#0000000a;color:var(--text);border-color:var(--text-light);transform:scale(1.08)}.nav-rail__toggle:active{transform:scale(.95)}[data-theme=dark] .nav-rail{background:#1c1c1ec7;box-shadow:2px 0 24px #00000040}[data-theme=dark] .nav-rail__item:hover{background:#ffffff0f}[data-theme=dark] .nav-rail__item--active:hover,[data-theme=dark] .nav-rail__pill{background:#4ade801a}[data-theme=dark] .nav-rail__toggle{border-color:#ffffff1a}[data-theme=dark] .nav-rail__toggle:hover{background:#ffffff14;border-color:#fff3}[data-theme=sepia] .nav-rail{background:#f7f1e3c7;box-shadow:2px 0 20px #78643c0f}[data-theme=sepia] .nav-rail__item:hover{background:#78643c0f}[data-theme=sepia] .nav-rail__toggle{border-color:#78643c26}[data-theme=sepia] .nav-rail__toggle:hover{background:#78643c14}.settings-page{max-width:var(--max-width);margin:0 auto;padding:24px 16px 80px}.settings-page__title{font-size:24px;font-weight:600;margin-bottom:20px;color:var(--text)}.settings-page .settings-group{margin-bottom:16px}.settings-page .settings-group__header{margin-top:20px}.settings-page .settings-group__header:first-of-type{margin-top:0}.settings-page .notif-row{padding:4px 0}.ufb-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-overlay);background:#00000073;display:flex;align-items:center;justify-content:center;padding:20px}.ufb-popup{background:var(--surface, #fff);border-radius:var(--radius-lg, 16px);box-shadow:0 12px 40px #0003;padding:24px 20px;max-width:380px;width:100%;display:flex;flex-direction:column;gap:16px}.ufb-header{display:flex;align-items:center;justify-content:space-between}.ufb-title{font-size:.95rem;font-weight:600;color:var(--text, #333)}.ufb-dots{display:flex;gap:6px}.ufb-dot{width:6px;height:6px;border-radius:50%;background:var(--border, #ddd);transition:background .15s}.ufb-dot--active{background:var(--blue)}.ufb-question{font-size:1rem;font-weight:600;color:var(--text, #333);margin:0;line-height:1.35}.ufb-emoji-row{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.ufb-emoji-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 12px;border-radius:12px;border:2px solid var(--border, #e0e0e0);background:var(--surface, #fff);cursor:pointer;transition:border-color .15s,background .15s;min-width:68px}.ufb-emoji-btn:hover{border-color:var(--blue)}.ufb-emoji-btn--active{border-color:var(--blue);background:var(--surface-elevated, #f0f0ff)}.ufb-emoji-icon{font-size:1.5rem}.ufb-emoji-label{font-size:.7rem;font-weight:600;color:var(--text-light, #888)}.ufb-star-row{display:flex;gap:4px;justify-content:center}.ufb-star-btn{background:none;border:none;cursor:pointer;padding:4px;line-height:0;transition:transform .1s}.ufb-star-btn:hover{transform:scale(1.15)}.ufb-pill-row{display:flex;flex-wrap:wrap;gap:8px}.ufb-pill{padding:8px 14px;border-radius:20px;border:2px solid var(--border, #e0e0e0);background:var(--surface, #fff);font-size:.85rem;font-weight:600;color:var(--text, #333);cursor:pointer;transition:border-color .15s,background .15s,color .15s}.ufb-pill:hover{border-color:var(--blue)}.ufb-pill--active{border-color:var(--blue);background:var(--blue);color:#fff}.ufb-input{width:100%;padding:10px 12px;border-radius:10px;border:2px solid var(--border, #e0e0e0);background:var(--surface, #fff);color:var(--text, #333);font-family:inherit;font-size:.9rem;resize:vertical;min-height:48px;outline:none;transition:border-color .15s;box-sizing:border-box}.ufb-input:focus{border-color:var(--blue)}.ufb-actions{display:flex;flex-direction:column;gap:6px;align-items:center}.ufb-submit{width:100%;padding:10px 0;border-radius:10px;border:none;background:var(--blue);color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:opacity .15s}.ufb-submit:hover{opacity:.9}.ufb-submit:disabled{opacity:.4;cursor:not-allowed}.ufb-skip{background:none;border:none;color:var(--text-light, #888);font-size:.82rem;cursor:pointer;padding:4px}.ufb-skip:hover{color:var(--text, #333)}.ufb-thanks{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px 0}.ufb-thanks p{font-size:1.1rem;font-weight:600;color:var(--text, #333);margin:0}[data-theme=dark] .ufb-popup{box-shadow:0 12px 40px #00000080}.difficulty-lever{min-width:200px;width:200px;padding:4px 0 8px}.difficulty-lever--disabled{opacity:.45;pointer-events:none}.difficulty-lever__track-wrap{position:relative;height:32px;display:flex;align-items:center}.difficulty-lever__track{position:absolute;left:0;right:0;height:6px;border-radius:3px;background:var(--surface-alt, rgba(128, 128, 128, .15))}.difficulty-lever__fill{position:absolute;left:0;height:6px;border-radius:3px;background:linear-gradient(90deg,var(--green, #22c55e),var(--orange, #f59e0b),var(--red, #ef4444));background-size:400% 100%;pointer-events:none}.difficulty-lever__input{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;margin:0;opacity:0;cursor:pointer;z-index:3}.difficulty-lever__input:disabled{cursor:not-allowed}.difficulty-lever__ticks{position:absolute;left:0;right:0;display:flex;justify-content:space-between;z-index:2;pointer-events:none}.difficulty-lever__tick{width:16px;height:16px;border-radius:50%;border:2px solid var(--surface-alt, rgba(128, 128, 128, .25));background:var(--surface, #fff);transition:transform .15s ease,border-color .15s ease,background .15s ease;cursor:pointer;pointer-events:auto;padding:0}.difficulty-lever__tick.active{transform:scale(1.3);border-color:var(--primary, #6366f1);background:var(--primary, #6366f1);box-shadow:0 0 0 3px #6366f140}.difficulty-lever__tick:not(.active):hover{border-color:var(--text-secondary, #888);transform:scale(1.1)}.difficulty-lever__labels{display:flex;justify-content:space-between;align-items:center;margin-top:6px;font-size:11px;color:var(--text-secondary, #888);gap:4px;white-space:nowrap}.difficulty-lever__label--current{font-weight:600;color:var(--text-primary, #222);font-size:12px}.session-ion-content{--background: linear-gradient(320deg, rgba(24, 144, 255, .11) 0%, transparent 30%), linear-gradient(40deg, rgba(88, 204, 2, .08) 4%, transparent 34%), linear-gradient(0deg, rgba(255, 255, 255, .52) 0%, rgba(255, 255, 255, 0) 28%), linear-gradient(0deg, #f4fbff 0%, #f8fcff 42%, #fefbf6 100%)}[data-theme=sepia] .session-ion-content{--background: linear-gradient(325deg, rgba(181, 132, 78, .14) 0%, transparent 32%), linear-gradient(45deg, rgba(235, 193, 120, .11) 8%, transparent 38%), linear-gradient(0deg, rgba(255, 248, 238, .4) 0%, rgba(255, 248, 238, 0) 26%), linear-gradient(0deg, #faf4e8 0%, #f6ede0 44%, #ede1cf 100%)}[data-theme=gray] .session-ion-content{--background: linear-gradient(320deg, rgba(91, 130, 168, .12) 0%, transparent 30%), linear-gradient(40deg, rgba(176, 184, 198, .16) 10%, transparent 40%), linear-gradient(0deg, rgba(255, 255, 255, .34) 0%, rgba(255, 255, 255, 0) 24%), linear-gradient(0deg, #f7f8fc 0%, #eef1f6 44%, #e5e9f1 100%)}[data-theme=dark] .session-ion-content{--background: linear-gradient(145deg, rgba(28, 176, 246, .08) 0%, transparent 26%), linear-gradient(225deg, rgba(88, 204, 2, .048) 6%, transparent 30%), linear-gradient(180deg, rgba(255, 255, 255, .018) 0%, rgba(255, 255, 255, 0) 18%), linear-gradient( 180deg, rgba(7, 9, 16, .985) 0%, rgba(10, 12, 21, .97) 28%, rgba(14, 14, 26, .94) 66%, rgba(14, 14, 26, .94) 100% )}[data-theme=dark] .study-loading,[data-theme=dark] .session-loading{color:color-mix(in srgb,var(--text-light) 88%,white 12%)}[data-theme=dark] .loading-spinner{border-color:#ffffff14;border-top-color:var(--blue);box-shadow:0 0 0 1px #ffffff05}.study-session{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;max-width:var(--max-width);margin:0 auto;width:100%;position:relative;z-index:2}.session-loading{display:flex;align-items:center;justify-content:center;gap:12px;min-height:100vh;min-height:100dvh;font-size:18px;color:var(--text-light)}.loading-spinner{width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse-glow{0%,to{box-shadow:0 6px 0 var(--blue-dark),0 0 #1cb0f666}50%{box-shadow:0 6px 0 var(--blue-dark),0 0 0 12px #1cb0f600}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes shimmer-sweep{0%{background-position:-200% center}to{background-position:200% center}}@keyframes gradient-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes heart-beat{0%,to{transform:scale(1)}15%{transform:scale(1.25)}30%{transform:scale(1)}45%{transform:scale(1.15)}60%{transform:scale(1)}}@keyframes slide-in-bottom{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes count-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.session-header{display:flex;align-items:center;gap:12px;padding:12px 16px;padding-top:calc(12px + var(--ion-safe-area-top, env(safe-area-inset-top, 0px)));position:sticky;top:0;background:var(--glass-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--glass-border);border-radius:0 0 20px 20px;z-index:10}.close-btn{width:44px;height:44px;border:1.5px solid var(--border);border-radius:50%;background:var(--surface);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-light);flex-shrink:0;transition:border-color .15s,color .15s,background .15s}.close-btn:hover{background:var(--tint-red);border-color:var(--red);color:var(--red)}.header-xp-badge{display:inline-flex;align-items:center;gap:4px;flex-shrink:0;padding:4px 10px;border-radius:20px;background:color-mix(in srgb,var(--amber) 12%,transparent)}.header-xp-badge__count{font-size:15px;font-weight:600;color:var(--amber)}.header-streak{display:inline-flex;align-items:center;gap:4px;flex-shrink:0;padding:4px 10px;border-radius:20px;background:color-mix(in srgb,var(--red) 12%,transparent)}.streak-icon{display:inline-flex;align-items:center}.streak-count{font-size:15px;font-weight:600;color:var(--red)}.session-body{flex:1;display:flex;flex-direction:column;padding:8px 16px 24px;padding-bottom:calc(24px + env(safe-area-inset-bottom,0px))}.header-xp{display:inline-flex;align-items:center;gap:4px;font-size:16px;font-weight:600;line-height:1;color:var(--orange);white-space:nowrap;flex-shrink:0}.header-xp svg{display:block}.milestone-banner{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;margin-bottom:12px;background:var(--tint-green);border-radius:var(--radius);font-size:15px;font-weight:600;color:var(--green-dark)}.card-category-label{display:inline-flex;align-items:center;gap:4px;padding:5px 14px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:15px;align-self:flex-start;position:relative;cursor:pointer;border:none;line-height:1;transition:filter .15s}.card-category-label:hover{filter:brightness(.95)}.card-category-label svg{display:block;flex-shrink:0}.cat-observation{background:var(--tint-blue);color:var(--blue-dark)}.cat-interpretation{background:var(--tint-orange);color:#e65100}.cat-application{background:var(--tint-green);color:var(--green-dark)}.cat-whole-book{background:#e8f0fa;color:#2d6cb8}.cat-passage-context{background:#e0f7f4;color:#008c7e}.cat-main-point{background:#fff3e0;color:#cc7a00}.cat-bible-horizon{background:#f0e8ff;color:#6d3fc4}[data-theme=dark] .cat-whole-book{background:#2d6cb826;color:#7fb8e8}[data-theme=dark] .cat-passage-context{background:#008c7e26;color:#5dd8c8}[data-theme=dark] .cat-main-point{background:#cc7a0026;color:#ffb74d}[data-theme=dark] .cat-bible-horizon{background:#6d3fc426;color:#b794f6}[data-theme=dark] .cat-interpretation{color:#ff9e80}.help-pill-wrap{position:relative;align-self:flex-start;margin-bottom:15px}.card-container{background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:20px;position:relative;flex:1;display:flex;flex-direction:column;box-shadow:var(--shadow-card)}.card-container[data-card-type=teaching]{flex:none}.stated-not-stated,.evidence-pick,.fill-in-blank,.matching-card,.cross-reference,.emoji-react,.highlight-text,.oia-sort,.scale-position,.sequence-order{flex:1;display:flex;flex-direction:column;justify-content:center;gap:12px;min-height:0}.card-question{font-size:24px;font-weight:600;line-height:1.35;margin-bottom:24px;color:var(--text)}.insight-card{overflow:hidden;margin-top:-8px;margin-bottom:20px}.insight-card__inner{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:14px;border:1px solid transparent;position:relative}.insight-card--orange .insight-card__inner{background:linear-gradient(135deg,#ff960014,#ffc8500a);border-color:#ff96002e}.insight-card--orange .insight-card__icon-ring{background:#ff96001f;color:var(--orange);box-shadow:0 0 0 3px #ff96000f}.insight-card--orange .insight-card__label{color:var(--orange)}.insight-card--blue .insight-card__inner{background:linear-gradient(135deg,#1cb0f614,#64c8ff0a);border-color:#1cb0f62e}.insight-card--blue .insight-card__icon-ring{background:#1cb0f61f;color:var(--blue);box-shadow:0 0 0 3px #1cb0f60f}.insight-card--blue .insight-card__label{color:var(--blue)}.insight-card__icon-ring{width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.insight-card__body{flex:1;min-width:0}.insight-card__label{display:block;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:3px}.insight-card__text{margin:0;font-family:var(--font-reading);font-size:.92rem;color:var(--text);line-height:1.55}[data-theme=dark] .insight-card--orange .insight-card__inner{background:linear-gradient(135deg,#ff96001a,#ffc85008);border-color:#ff960026}[data-theme=dark] .insight-card--blue .insight-card__inner{background:linear-gradient(135deg,#1cb0f61a,#64c8ff08);border-color:#1cb0f626}.hint-btn{background:#ff98001a;border:none;color:var(--orange);font-size:14px;font-weight:600;cursor:pointer;padding:10px 16px;margin-top:-12px;margin-bottom:16px;font-family:var(--font);border-radius:12px;transition:all .15s;display:inline-flex;align-items:center;gap:6px;min-height:44px}.hint-btn:hover:not(:disabled){background:#ff98002e}.hint-btn:disabled{opacity:.4;cursor:not-allowed}.hint-btn.hint-confirming{background:#ff980038;color:var(--red);animation:hint-pulse .6s ease-in-out}@keyframes hint-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.04)}}.passage-btn{min-width:44px;height:44px;border:1.5px solid var(--border);border-radius:999px;background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-light);flex-shrink:0;transition:border-color .15s,background .15s,box-shadow .15s,transform .15s;box-shadow:0 2px 10px #0f172a0f}.passage-btn:hover{border-color:var(--blue);color:var(--blue);background:var(--surface-elevated);transform:translateY(-1px)}.hint-toolbar-btn{min-width:44px;height:44px;border:1.5px solid var(--border);border-radius:999px;background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-light);flex-shrink:0;transition:border-color .15s,background .15s,color .15s,box-shadow .15s,transform .15s;box-shadow:0 2px 10px #0f172a0f}.hint-toolbar-btn:hover:not(:disabled){border-color:var(--orange);color:var(--orange);background:var(--surface-elevated);transform:translateY(-1px)}.hint-toolbar-btn--active{background:#ff98001f;color:var(--orange);border-color:var(--orange)}.hint-toolbar-btn--confirming{animation:hint-pulse .6s ease-in-out;border-color:var(--red);color:var(--red)}.hint-toolbar-btn:disabled{opacity:.35;cursor:not-allowed}.passage-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:var(--z-overlay)}.passage-sheet-wrap{position:fixed;bottom:0;left:0;right:0;z-index:calc(var(--z-overlay) + 1);display:flex;justify-content:center;pointer-events:none}.passage-sheet{width:100%;max-width:var(--max-width);height:60vh;background:var(--bg);border-radius:20px 20px 0 0;display:flex;flex-direction:column;box-shadow:0 -4px 24px #0003;border:1px solid var(--border);border-bottom:none;pointer-events:auto}.passage-drag-handle{width:40px;height:4px;background:var(--border);border-radius:2px;margin:10px auto 0;flex-shrink:0}.passage-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 8px;flex-shrink:0;gap:10px}.passage-header h3{font-size:22px;font-weight:600;color:var(--text);margin:0;flex:1;min-width:0}@media(max-width:480px){.passage-header h3{font-size:19px}}.translation-badge{font-size:13px;font-weight:600;color:var(--text-secondary, #888);vertical-align:middle;margin-inline-start:6px;opacity:.7}.passage-controls{display:flex;align-items:center;gap:4px;flex-shrink:0}.passage-body{padding:0 16px 24px;overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch;font-family:var(--font-reading)}.passage-body p{font-size:inherit;line-height:1.8;color:var(--text);white-space:pre-wrap;font-weight:400}.verse-num{font-size:.8em;vertical-align:inherit;line-height:0;color:var(--text-light);font-weight:600;margin-inline-end:2px;opacity:.55}.passage-html{font-family:var(--font-reading)}.passage-html p{display:inline;font-size:inherit;line-height:1.7;color:var(--text);white-space:normal;margin:0;font-weight:400}.passage-html f{display:none}.passage-html p sup{font-size:.75em;vertical-align:super;line-height:0;color:var(--text-light);font-weight:600;padding-inline-start:4px;padding-inline-end:2px;opacity:.55}.passage-html h4.chapter-heading{display:block;font-size:1em;font-weight:700;color:var(--primary);margin:20px 0 8px;padding-bottom:6px;border-bottom:1px solid var(--border);letter-spacing:.02em}.passage-html p.verse-highlight{background:color-mix(in srgb,var(--blue) 14%,transparent);border-radius:4px;padding:2px 4px;margin:-2px -4px;box-decoration-break:clone;-webkit-box-decoration-break:clone;transition:background .3s ease}.card-claim{font-size:16px;color:var(--text);font-style:italic;margin-bottom:16px;padding:12px;background:var(--tint-neutral);border-inline-start:3px solid var(--blue);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.check-btn{width:100%;padding:14px 40px;padding-bottom:calc(14px + env(safe-area-inset-bottom,0px));background:var(--green);color:#fff;border:none;border-radius:var(--radius);font-size:16px;font-weight:600;cursor:pointer;text-transform:uppercase;letter-spacing:1px;margin-top:auto;padding-top:14px;box-shadow:0 var(--btn-3d-depth) 0 var(--green-dark),var(--shadow-node);transition:transform .1s,box-shadow .1s,filter .15s;flex-shrink:0;min-height:48px}.check-btn:disabled{background:var(--border);box-shadow:0 var(--btn-3d-depth) 0 color-mix(in srgb,var(--border) 80%,#999);cursor:not-allowed;color:var(--text-light)}.check-btn:not(:disabled):hover{filter:brightness(1.06)}.check-btn:not(:disabled):active{transform:translateY(var(--btn-3d-depth));box-shadow:0 0 0 var(--green-dark)}.card-container[data-callback=true]:before{content:"Connecting...";display:flex;align-items:center;gap:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--orange);margin-bottom:8px}@media(max-width:480px){.card-container{padding:18px 16px}.card-question{font-size:20px;line-height:1.4;margin-bottom:20px}.stated-not-stated,.evidence-pick,.fill-in-blank,.matching-card,.cross-reference,.emoji-react,.highlight-text,.oia-sort,.scale-position,.sequence-order{gap:10px}.card-claim{font-size:15px;padding:10px;margin-bottom:12px}}.options-list{display:flex;flex-direction:column;gap:8px;overflow-y:auto;min-height:0;flex-shrink:1}.option-btn{display:flex;flex-direction:column;align-items:flex-start;padding:14px 16px;border:2px solid var(--border);border-bottom:4px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;text-align:start;transition:all .15s;font-size:15px;font-family:var(--font)}.option-btn:hover:not(:disabled){border-color:var(--blue);background:var(--surface)}.option-btn.selected{border-color:var(--blue);border-bottom-color:var(--blue);background:var(--tint-blue);box-shadow:none;animation:selectPulse .3s ease-out}@keyframes selectPulse{0%{box-shadow:0 0 0 1px var(--blue)}50%{box-shadow:0 0 0 6px rgba(var(--blue-rgb),.15)}to{box-shadow:0 0 0 1px var(--blue)}}.option-text{line-height:1.4}.option-ref{display:block;font-size:13px;color:var(--blue);margin-top:10px;font-weight:600}.option-ref__translation{font-size:11px;font-weight:500;opacity:.6}.option-text .verse-num{font-size:.75em;vertical-align:inherit;line-height:0;color:var(--blue);font-weight:700;margin-inline-end:2px;opacity:.7;font-family:var(--font)}.highlight-text__theme-badge{display:inline-flex;align-self:flex-start;padding:4px 12px;border-radius:20px;font-size:13px;font-weight:600;color:var(--blue-dark);background:rgba(var(--blue-rgb),.12);margin-bottom:4px}.highlight-text__selection-limit{display:inline-flex;align-self:flex-start;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;color:var(--text-light);background:color-mix(in srgb,var(--surface-elevated) 88%,transparent);margin-bottom:4px}.passage-words{margin-bottom:8px;line-height:2.2}.word{display:inline;padding:4px 6px;margin:2px 1px;border-radius:6px;cursor:pointer;transition:all .12s;font-size:17px;-webkit-user-select:none;user-select:none;-webkit-box-decoration-break:clone;box-decoration-break:clone;background:color-mix(in srgb,var(--text) 6%,transparent)}.word:hover{background:color-mix(in srgb,var(--blue) 15%,transparent)}.word.highlighted{background:var(--blue);color:#fff;box-shadow:0 2px 4px rgba(var(--blue-rgb),.3);outline:2px solid color-mix(in srgb,var(--blue) 24%,transparent)}.word.word-correct{background:var(--green);color:#fff;box-shadow:0 2px 4px #58cc024d}.word.word-incorrect{background:var(--red);color:#fff;box-shadow:0 2px 4px #ff4b4b4d;text-decoration:line-through;text-decoration-thickness:2px}.word.word-missed{background:transparent;color:var(--orange);outline:2px dashed var(--orange);outline-offset:-2px;animation:pulse-missed 1.2s ease-in-out infinite}@keyframes pulse-missed{0%,to{opacity:1}50%{opacity:.55}}.sequence-instruction{font-size:14px;color:var(--text-light);margin-bottom:12px}.sequence-items{display:flex;flex-direction:column;gap:8px}.sequence-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border:2px solid var(--border);border-bottom:4px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;text-align:start;font-size:15px;font-family:var(--font);position:relative;transition:border-color .15s,background-color .15s,box-shadow .15s}.sequence-item--review{border-color:var(--green);background:color-mix(in srgb,var(--green) 10%,var(--surface))}.sequence-item:hover:not(:disabled){border-color:var(--blue)}.sequence-item.ordered{border-color:var(--blue);background:var(--tint-blue)}.seq-number{width:28px;height:28px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0}.sequence-handle{display:inline-flex;flex-direction:column;gap:3px;opacity:.45}.sequence-handle span{display:block;width:12px;height:2px;border-radius:999px;background:currentColor}.statement-box{padding:16px;background:var(--tint-neutral);border-radius:var(--radius-sm);border:1px solid var(--border);margin-bottom:16px;font-size:17px;line-height:1.5;font-style:italic}.sns-instruction{font-size:14px;color:var(--text-light);margin-bottom:12px;text-align:center}.sns-buttons{display:flex;gap:12px}.sns-btn{flex:1;padding:16px;border:2px solid var(--border);border-bottom:4px solid var(--border);border-radius:var(--radius);background:var(--surface);font-size:16px;font-weight:600;font-family:var(--font);cursor:pointer;transition:all .15s}.sns-btn:hover:not(:disabled){border-color:var(--blue)}.sns-btn.selected:first-child{border-color:var(--green);background:var(--tint-green);color:var(--green-dark)}.sns-btn.selected:last-child{border-color:var(--red);background:var(--tint-red);color:var(--red-dark)}.oia-items{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.oia-item{display:flex;align-items:center;gap:10px;padding:18px 16px;border:2px solid var(--border);border-bottom:4px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;text-align:start;font-size:16px;font-family:var(--font);position:relative;transition:border-color .15s,background-color .15s,box-shadow .15s,opacity .15s;line-height:1.4}.oia-item:hover:not(:disabled){border-color:var(--purple)}.oia-item.active{border-color:var(--purple);background:var(--tint-purple);box-shadow:0 0 0 1px var(--purple)}.oia-item.assigned{opacity:.85}.oia-item--dimmed{opacity:.55}.oia-badge{width:24px;height:24px;border-radius:50%;color:#fff;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0}.oia-item__bucket-label{margin-inline-start:auto;font-size:12px;font-weight:600;color:var(--text-light);text-transform:uppercase;letter-spacing:.04em}.oia-buckets{display:flex;gap:8px;align-items:center;margin-bottom:12px;padding:12px;background:var(--tint-neutral);border-radius:var(--radius-sm);border:1px solid var(--border)}.bucket-prompt{font-size:13px;color:var(--text-light);font-weight:600;white-space:nowrap}.bucket-btn{flex:1;min-width:0;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:12px 10px;color:#fff;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;transition:transform .1s,box-shadow .15s,filter .15s;box-shadow:inset 0 -2px #0000001f}.bucket-btn:hover{filter:brightness(1.1)}.bucket-btn:active{transform:scale(.95)}.bucket-btn--ready{box-shadow:inset 0 -2px #0000001f,0 0 0 3px #ffffff24}.bucket-btn--filled{filter:saturate(1.08)}.bucket-btn__count{min-width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#ffffff2e;font-size:11px;font-weight:600;flex-shrink:0}@media(max-width:360px){.bucket-btn{font-size:11px;padding:8px 6px;gap:4px}}.sp-labels{display:flex;justify-content:space-between;align-items:flex-end;padding:0 4px;margin-bottom:6px}.sp-label{font-size:14px;font-weight:600;color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;max-width:45%;line-height:1.2}.sp-label--left{text-align:start;color:var(--blue)}.sp-label--right{text-align:end;color:var(--orange)}.sp-track-area{position:relative;height:72px;display:flex;align-items:center;cursor:grab;touch-action:none;user-select:none;-webkit-user-select:none}.sp-track-area--active{cursor:grabbing}.sp-track-area--disabled{cursor:default;opacity:.6;pointer-events:none}.sp-rail{position:relative;width:100%;height:14px;border-radius:7px;background:var(--border);overflow:visible;box-shadow:inset 0 2px 4px #00000014}.sp-tick{position:absolute;top:50%;transform:translate(-50%,-50%);width:2px;height:20px;border-radius:1px;background:#00000014;pointer-events:none;z-index:1}.sp-tick:first-child,.sp-tick:last-child{height:24px;width:3px;background:#0000001f}[data-theme=dark] .sp-tick{background:#ffffff1a}[data-theme=dark] .sp-tick:first-child,[data-theme=dark] .sp-tick:last-child{background:#ffffff26}.sp-fill{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:7px;background:linear-gradient(90deg,var(--blue) 0%,#6ec6f8 40%,var(--orange) 100%);box-shadow:0 1px 6px rgba(var(--blue-rgb),.25);will-change:width}.sp-thumb-wrapper{position:absolute;top:50%;z-index:10;display:flex;flex-direction:column;align-items:center;will-change:transform,left;pointer-events:none}.sp-bubble{position:absolute;bottom:calc(100% + 8px);white-space:nowrap;padding:6px 14px;border-radius:12px;background:var(--text);color:var(--bg);font-size:15px;font-weight:600;box-shadow:0 4px 16px #0000002e;pointer-events:none}.sp-bubble:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--text)}.sp-thumb{width:52px;height:52px;border-radius:50%;background:linear-gradient(145deg,#fff,#f0f0f0);box-shadow:0 4px #0000001a,0 6px 16px #0000001f,0 0 0 4px rgba(var(--blue-rgb),.15),inset 0 2px 4px #ffffffe6;display:flex;align-items:center;justify-content:center;transition:box-shadow .2s ease}.sp-track-area--active .sp-thumb{box-shadow:0 2px #00000014,0 8px 24px rgba(var(--blue-rgb),.3),0 0 0 6px rgba(var(--blue-rgb),.2),inset 0 2px 4px #ffffffe6}[data-theme=dark] .sp-thumb{background:linear-gradient(145deg,var(--surface-elevated) 0%,var(--surface) 100%);box-shadow:0 4px #0000004d,0 6px 16px #0006,0 0 0 4px rgba(var(--blue-rgb),.2),inset 0 1px 2px #ffffff14}[data-theme=dark] .sp-track-area--active .sp-thumb{box-shadow:0 2px #0003,0 8px 24px rgba(var(--blue-rgb),.35),0 0 0 6px rgba(var(--blue-rgb),.25),inset 0 1px 2px #ffffff14}.sp-thumb-inner{width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--blue-dark));box-shadow:0 2px 6px rgba(var(--blue-rgb),.35)}.sp-track-area--active .sp-thumb-inner{background:linear-gradient(135deg,var(--blue),color-mix(in srgb,var(--blue) 70%,white))}.sp-value{text-align:center;font-size:40px;font-weight:600;margin-top:8px;margin-bottom:4px;background:linear-gradient(90deg,var(--blue),var(--orange));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.fill-in-blank{text-align:center}.fill-sentence{font-size:18px;line-height:1.8;margin-bottom:24px;padding:16px;background:var(--tint-neutral);border-radius:var(--radius)}.fill-blank{display:inline-block;min-width:80px;padding:4px 12px;border-bottom:3px solid var(--blue);font-weight:600;color:var(--blue-dark);transition:all .2s}.fill-blank.filled{background:var(--tint-blue);border-radius:8px;border-bottom-color:transparent}.word-bank{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:24px}.word-chip{padding:10px 20px;border:2px solid var(--border);border-bottom:4px solid var(--border);border-radius:var(--radius);background:var(--surface);font-size:16px;font-weight:600;cursor:pointer;transition:all .15s}.word-chip:hover{border-color:var(--blue);transform:translateY(-1px)}.word-chip.selected{background:var(--blue);border-color:var(--blue);color:#fff}.emoji-react{text-align:center}.emoji-scenario{font-size:17px;line-height:1.6;margin-bottom:24px;padding:16px;background:var(--tint-yellow-strong);border-radius:var(--radius-sm);border:2px solid var(--tint-yellow-border)}.emoji-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}.emoji-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 16px;border:2px solid var(--border);border-bottom:4px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;transition:all .2s}.emoji-btn:hover{border-color:var(--orange)}.emoji-btn.selected{border-color:var(--orange);border-bottom-color:var(--orange);background:var(--tint-orange)}.emoji-icon{font-size:48px;line-height:1}.emoji-label{font-size:14px;font-weight:600;color:var(--text)}.matching-card{display:flex;flex-direction:column}.matching-headers{display:grid;grid-template-columns:1fr 1fr;gap:0 12px}.matching-header{padding:7px 12px;border-radius:999px;font-size:11px;font-weight:800;letter-spacing:.09em;text-transform:uppercase;text-align:center}.matching-header--cause{background:var(--tint-blue);color:var(--blue-dark, var(--blue));border:1.5px solid color-mix(in srgb,var(--blue) 28%,transparent)}.matching-header--effect{background:var(--tint-orange);color:color-mix(in srgb,var(--orange) 85%,#3a2000);border:1.5px solid color-mix(in srgb,var(--orange) 28%,transparent)}.matching-columns{display:grid;grid-template-columns:1fr 1fr;grid-auto-rows:auto;gap:8px 12px;margin-bottom:8px}.match-item{padding:12px 14px;border:2px solid var(--border);border-bottom:4px solid var(--border);border-radius:var(--radius);font-size:14px;font-weight:600;cursor:pointer;transition:border-color .15s,background-color .15s,box-shadow .15s,transform .12s;text-align:start;position:relative;display:flex;align-items:center;gap:10px;min-height:54px;line-height:1.35}.match-item-text{flex:1;min-width:0;word-break:break-word}.match-item.match-left{border-inline-start:4px solid var(--blue);background:var(--tint-blue)}.match-item.match-right{border-inline-end:4px solid var(--orange);background:var(--tint-orange)}.match-item:hover:not(.match-item--review):not(.matched){box-shadow:0 3px 10px #00000017;transform:translateY(-1px)}.match-item.active{background:var(--tint-blue-strong);border-color:var(--blue);box-shadow:0 0 0 3px color-mix(in srgb,var(--blue) 25%,transparent),0 4px 12px #1cb0f62e}.match-item.matched{background:var(--tint-green);border-color:var(--green);border-bottom-color:var(--green-dark);opacity:.92}.match-item.match-left.matched{border-inline-start-color:var(--green)}.match-item.match-right.matched{border-inline-end-color:var(--green)}.match-right--ready{border-color:color-mix(in srgb,var(--blue) 50%,var(--border));box-shadow:0 0 0 2px color-mix(in srgb,var(--blue) 20%,transparent)}.match-pair-badge{min-width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;font-size:12px;font-weight:800;flex-shrink:0;color:#fff;box-shadow:0 1px 4px #0003}.match-item--review{cursor:default}.matching-instruction{font-size:13px;color:var(--text-light);text-align:center;margin:0;padding:8px 14px;background:var(--tint-blue);border:1.5px solid color-mix(in srgb,var(--blue) 25%,var(--border));border-radius:var(--radius);overflow:hidden}.cross-reference{display:flex;flex-direction:column}.cross-ref-teaching{font-size:16px;line-height:1.6;margin-bottom:20px;padding:14px;background:var(--tint-purple);border-radius:var(--radius-sm);border-inline-start:4px solid var(--purple);font-style:italic}.cross-ref-option .cross-ref-book{display:block;font-size:13px;font-weight:600;color:var(--purple);margin-bottom:10px}.cross-ref-translation{font-size:11px;font-weight:500;opacity:.6;font-style:normal}.cross-ref-option .option-text .verse-num{font-size:.75em;vertical-align:inherit;line-height:0;color:var(--purple);font-weight:700;margin-inline-end:2px;opacity:.7;font-family:var(--font)}.screen-wrap{width:100%;min-height:100dvh}.doodle-card{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%}.doodle-prompt{text-align:center}.doodle-label{font-size:1.05rem;color:var(--text, #333)}.doodle-label strong{color:var(--primary, #6c63ff);text-transform:capitalize}.doodle-style-hint{font-size:1.1rem;color:var(--text-light, #888);margin-top:4px}.doodle-canvas-wrap{position:relative;width:100%;max-width:416px;aspect-ratio:13 / 10;border-radius:16px;overflow:hidden;border:2px solid var(--border, #e5e7eb);background:#fff;transition:border-color .2s}.doodle-canvas-wrap.checking{border-color:var(--primary, #6c63ff);opacity:.7}.doodle-canvas{width:100%;height:100%;display:block;touch-action:none;cursor:crosshair}.doodle-checking-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background:#fffc;font-size:.9rem;color:var(--primary, #6c63ff);font-weight:600}.doodle-toolbar{display:flex;gap:10px}.doodle-tool-btn{padding:6px 18px;border-radius:8px;border:1.5px solid var(--border, #e5e7eb);background:var(--surface, #fff);color:var(--text, #333);font-size:.85rem;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s}.doodle-tool-btn:hover:not(:disabled){border-color:var(--primary, #6c63ff);background:var(--surface-elevated, #f8f8ff)}.doodle-tool-btn:disabled{opacity:.4;cursor:not-allowed}.doodle-loading{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-light, #888);padding:8px 0}.doodle-error{text-align:center;color:var(--red, #ef4444);font-size:.85rem;padding:8px}.doodle-error-hint{color:var(--text-light, #888);font-size:.78rem;margin-top:4px}.doodle-inline-error{color:var(--orange, #f59e0b);font-size:.82rem;text-align:center}[data-theme=dark] .doodle-canvas-wrap{border-color:var(--border, #444);background:var(--surface)}[data-theme=dark] .doodle-checking-overlay{background:var(--glass-bg)}[data-theme=dark] .doodle-tool-btn{background:var(--surface, #1e1e32);border-color:var(--border, #444);color:var(--text, #e0e0e0)}.doodle-canvas-loading-placeholder{width:100%;max-width:416px;aspect-ratio:13 / 10;border-radius:16px;background:var(--surface, #f9f9f9);border:2px dashed var(--border, #e5e7eb)}[data-theme=dark] .doodle-canvas-loading-placeholder{background:var(--surface, #1e1e32);border-color:var(--border, #444)}.doodle-timer-wrap{position:absolute;top:8px;right:8px;z-index:2;pointer-events:none}.doodle-confidence-bar{width:100%;max-width:416px;height:6px;border-radius:3px;background:var(--border, #e5e7eb);overflow:hidden}.doodle-confidence-fill{height:100%;border-radius:3px;transition:width .5s ease,background-color .4s ease}.doodle-feedback-text{font-size:1rem;font-weight:600;text-align:center;min-height:1.2em;transition:color .4s ease}[data-theme=dark] .doodle-timer{background:#ffffff1a;color:var(--text, #e0e0e0)}[data-theme=dark] .doodle-timer.urgent{background:var(--red, #ff4b4b);color:#fff}[data-theme=dark] .doodle-confidence-bar{background:var(--border)}@media(max-width:480px){.doodle-canvas-wrap,.doodle-confidence-bar{max-width:100%}.doodle-canvas-wrap{aspect-ratio:1}}@media(min-width:481px)and (max-width:768px){.doodle-canvas-wrap,.doodle-confidence-bar{max-width:380px}}.card-timer{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;background:#0000000f;color:var(--text, #333);font-size:.82rem;font-weight:600;font-variant-numeric:tabular-nums;white-space:nowrap;pointer-events:none;transition:background .3s,color .3s}.card-timer-label{font-size:.78rem;font-weight:500;opacity:.75;margin-inline-end:1px;text-transform:uppercase;letter-spacing:.04em}.card-timer--urgent{background:var(--red, #ff4b4b);color:#fff;animation:card-timer-pulse .8s ease-in-out infinite}.card-timer--urgent .card-timer-label{opacity:.9}@keyframes card-timer-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.card-timer--bar{background:var(--surface);border:1.5px solid var(--border)}.card-timer--bar.card-timer--urgent{background:var(--red, #ff4b4b);border-color:transparent;color:#fff}[data-theme=dark] .card-timer{background:#ffffff1a}[data-theme=dark] .card-timer--bar{background:var(--surface)}.image-drop{display:flex;flex-direction:column;gap:12px;width:100%;isolation:isolate}.image-drop-instruction{font-size:13px;color:var(--text-light);text-align:center;margin:0}.image-drop-scene{position:relative;z-index:1;width:100%;aspect-ratio:4 / 3;border-radius:var(--radius);background-size:cover;background-position:center;background-repeat:no-repeat;overflow:hidden;box-shadow:var(--shadow)}.drop-zone{position:absolute;transform:translate(-50%,-50%);min-width:48px;min-height:48px;width:56px;height:56px;border-radius:50%;border:2.5px dashed var(--border);background:#fff6;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .2s,background .2s,transform .2s}.drop-zone--active{border-color:var(--blue);background:var(--tint-blue-strong);animation:zone-pulse 1.2s ease-in-out infinite}.drop-zone--filled{border-style:solid;border-color:var(--green);background:#58cc0226}@keyframes zone-pulse{0%,to{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.08)}}.drop-zone-label{font-size:10px;font-weight:600;color:var(--text);text-align:center;line-height:1.15;padding:2px;text-shadow:0 1px 2px rgba(255,255,255,.8);pointer-events:none}.drop-zone-img{width:80%;height:80%;object-fit:contain;border-radius:50%;pointer-events:none}.draggable-tray{position:relative;z-index:2;display:flex;gap:10px;padding:8px 4px;justify-content:center;flex-wrap:wrap}.draggable-item{position:relative;flex-shrink:0;width:68px;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:grab;user-select:none;-webkit-user-select:none;transition:opacity .2s}.draggable-item:active{cursor:grabbing}.draggable-item-img{width:60px;height:60px;border-radius:var(--radius-sm);object-fit:cover;box-shadow:0 1px 4px #00000026;transition:box-shadow .2s}.draggable-item--selected .draggable-item-img{box-shadow:0 0 0 3px rgba(var(--blue-rgb),.3)}.draggable-item--placed{opacity:.4;cursor:pointer}.drop-zone-remove{position:absolute;top:-4px;right:-4px;width:22px;height:22px;border-radius:50%;background:#0009;color:#fff;font-size:16px;font-weight:600;line-height:22px;text-align:center;pointer-events:none}.draggable-item-label{font-size:11px;font-weight:600;color:var(--text);text-align:center;line-height:1.2}@media(min-width:600px){.image-drop-scene{aspect-ratio:16 / 9}.drop-zone{width:64px;height:64px}.drop-zone-label{font-size:11px}.draggable-item-img{width:72px;height:72px}.draggable-item{width:80px}.draggable-item-label{font-size:12px}.image-drop-instruction{font-size:14px}}@media(min-width:1024px){.image-drop-scene{aspect-ratio:16 / 9}.drop-zone{width:72px;height:72px}.drop-zone-label{font-size:12px}.draggable-item-img{width:80px;height:80px}.draggable-item{width:88px}}@media(max-width:360px){.drop-zone{min-width:44px;min-height:44px;width:48px;height:48px}.draggable-item-img{width:52px;height:52px}.draggable-item{width:58px}.draggable-item-label{font-size:10px}}[data-theme=dark] .drop-zone{background:#ffffff1a;border-color:#ffffff40}[data-theme=dark] .drop-zone--active{background:var(--tint-blue-strong)}[data-theme=dark] .drop-zone--filled{background:#58cc0233}[data-theme=dark] .drop-zone-label{color:#e0e0e0;text-shadow:0 1px 2px rgba(0,0,0,.6)}[data-theme=dark] .draggable-item-img{box-shadow:0 1px 4px #0006}.path-planner{display:flex;flex-direction:column;gap:12px;width:100%;position:relative}.path-planner .check-btn{position:sticky;bottom:8px;z-index:10;align-self:stretch}.path-mission{background:var(--tint-yellow-strong);border:1.5px solid var(--tint-yellow-border);border-radius:var(--radius);padding:12px 14px;overflow:hidden}.path-mission-header{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#b45309;margin-bottom:8px}.path-mission-list{display:flex;flex-direction:column;gap:6px}.path-mission-item{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--text);padding:4px 0;transition:color .2s}.path-mission-item--done{color:var(--green-dark)}.path-mission-item--done .path-mission-check{color:var(--green)}.path-mission-check{flex-shrink:0;color:var(--text-light)}.path-legend{display:flex;flex-wrap:wrap;gap:6px}.path-legend-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;border:1.5px solid var(--border);background:var(--surface)}.path-legend-chip--start{color:var(--green-dark);border-color:var(--green);background:var(--tint-green)}.path-legend-chip--goal{color:#b45309;border-color:var(--amber);background:var(--tint-yellow-strong)}.path-legend-chip--manna{color:var(--blue-dark);border-color:var(--blue);background:var(--tint-blue)}.path-legend-chip--complaint{color:var(--red-dark);border-color:color-mix(in srgb,var(--red) 50%,var(--border));background:var(--tint-red)}.path-legend-chip--obstacle{color:var(--text-light);background:var(--tint-neutral)}.path-legend-chip--verse{color:#7c3aed;border-color:var(--purple);background:var(--tint-purple)}.path-legend-chip--event{color:#c2410c;border-color:var(--orange);background:var(--tint-orange)}.path-stats{display:flex;align-items:center;gap:10px;padding:8px 14px;background:var(--tint-neutral);border:1.5px solid var(--border);border-radius:var(--radius);font-size:14px;font-weight:600;color:var(--text)}.path-stats-right{display:flex;align-items:center;gap:8px;margin-inline-start:auto}.path-stat{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;background:var(--surface);border:1.5px solid var(--border);font-size:13px;font-weight:600}.path-stat--manna{color:var(--blue);border-color:color-mix(in srgb,var(--blue) 30%,var(--border));background:var(--tint-blue)}.path-undo-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;border:2px solid var(--border);background:var(--surface);color:var(--text-light);cursor:pointer;box-shadow:0 3px 0 0 var(--border);transition:background .12s,color .12s,transform .1s,box-shadow .1s;transform:translateY(0)}.path-undo-btn:hover{background:var(--tint-neutral);color:var(--text);transform:translateY(-1px);box-shadow:0 4px 0 0 var(--border)}.path-undo-btn:active{transform:translateY(2px);box-shadow:0 1px 0 0 var(--border)}.path-grid-wrapper{position:relative;width:100%;background:var(--tint-neutral);border:1.5px solid var(--border);border-radius:var(--radius);padding:10px}.path-grid{display:grid;gap:7px;width:100%}.path-tile{position:relative;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;border-radius:14px;border:2.5px solid var(--border);background:var(--surface);box-shadow:0 4px 0 0 var(--border),0 4px 8px #0000000f;cursor:pointer;transition:border-color .12s,background .12s,box-shadow .12s,transform .08s;transform:translateY(0);user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;min-width:48px;min-height:48px}.path-tile:active:not(:disabled){transform:translateY(3px);box-shadow:0 1px 0 0 var(--border),0 1px 2px #0000000a}.path-tile:disabled{cursor:default}.path-tile-icon{flex-shrink:0;filter:drop-shadow(0 1px 1px rgba(0,0,0,.1))}.path-tile-label{font-size:10px;font-weight:600;line-height:1.15;text-align:center;overflow:hidden;text-overflow:ellipsis;max-width:90%;color:inherit;letter-spacing:-.01em}.path-tile-step{position:absolute;top:2px;right:3px;min-width:16px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:var(--green);color:#fff;font-size:9px;font-weight:600;line-height:1;z-index:3;box-shadow:0 1px 2px #00000026;padding:0 3px}.path-tile-corner-badge{position:absolute;top:4px;left:4px;padding:2px 6px;border-radius:999px;background:#ffffffeb;color:var(--text);font-size:9px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;z-index:3}.path-tile--start .path-tile-corner-badge{background:var(--green);color:#fff;box-shadow:0 1px 4px #0003}.path-tile-next{position:absolute;bottom:5px;right:5px;color:var(--green-dark);opacity:.82}.path-tile--empty{background:var(--surface);border-color:var(--border)}.path-tile--start{background:var(--tint-green);border-color:var(--green);color:var(--green-dark);box-shadow:0 4px 0 0 var(--green-dark),0 0 0 4px color-mix(in srgb,var(--green) 18%,transparent);animation:path-pulse-start 2s ease-in-out infinite}.path-tile--goal{background:var(--tint-yellow-strong);border-color:var(--amber);color:#b45309;box-shadow:0 4px #d97706,0 0 12px color-mix(in srgb,var(--amber) 25%,transparent);animation:path-shimmer-goal 2.5s ease-in-out infinite}.path-tile--manna{background:var(--tint-blue);border-color:var(--blue);color:var(--blue-dark);box-shadow:0 4px 0 0 var(--blue-dark),0 4px 8px #0000000f}.path-tile--complaint{background:var(--tint-red);border-color:color-mix(in srgb,var(--red) 60%,var(--border));color:var(--red-dark);cursor:not-allowed;background-image:repeating-linear-gradient(-45deg,transparent,transparent 4px,color-mix(in srgb,var(--red) 12%,transparent) 4px,color-mix(in srgb,var(--red) 12%,transparent) 8px);box-shadow:0 4px color-mix(in srgb,var(--red) 35%,var(--border)),0 4px 8px #0000000f}.path-tile--obstacle{background:color-mix(in srgb,var(--border) 80%,var(--text));border-color:var(--text-light);color:var(--text-light);box-shadow:inset 0 3px 6px #00000026;cursor:not-allowed;opacity:.7}.path-tile--verse{background:var(--tint-purple);border-color:var(--purple);color:#7c3aed;box-shadow:0 4px #a855f7,0 4px 8px #0000000f}.path-tile--event{background:var(--tint-orange);border-color:var(--orange);color:#c2410c;box-shadow:0 4px #e67700,0 4px 8px #0000000f}.path-tile--selected{border-color:var(--green);background:color-mix(in srgb,var(--green) 22%,var(--surface));box-shadow:0 4px 0 0 var(--green-dark),0 4px 8px #0000000f}.path-tile--last{border-color:var(--green);background:color-mix(in srgb,var(--green) 28%,var(--surface));box-shadow:0 4px 0 0 var(--green-dark),0 0 0 5px color-mix(in srgb,var(--green) 22%,transparent);z-index:2}.path-tile--valid-move:not(:disabled){animation:path-valid-pulse 1.4s ease-in-out infinite;border-color:color-mix(in srgb,var(--green) 50%,transparent)}@keyframes path-pulse-start{0%,to{box-shadow:0 4px 0 0 var(--green-dark),0 0 0 4px color-mix(in srgb,var(--green) 18%,transparent)}50%{box-shadow:0 4px 0 0 var(--green-dark),0 0 0 8px color-mix(in srgb,var(--green) 10%,transparent)}}@keyframes path-shimmer-goal{0%,to{box-shadow:0 4px #d97706,0 0 12px color-mix(in srgb,var(--amber) 25%,transparent)}50%{box-shadow:0 4px #d97706,0 0 20px color-mix(in srgb,var(--amber) 40%,transparent),0 0 0 6px color-mix(in srgb,var(--amber) 12%,transparent)}}@keyframes path-valid-pulse{0%,to{border-color:color-mix(in srgb,var(--green) 25%,transparent);box-shadow:0 4px 0 0 var(--border),0 4px 8px #0000000f}50%{border-color:color-mix(in srgb,var(--green) 55%,transparent);box-shadow:0 4px 0 0 var(--border),0 0 8px color-mix(in srgb,var(--green) 15%,transparent)}}.path-trail{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}.path-verses-panel{background:var(--tint-purple);border:1.5px solid color-mix(in srgb,var(--purple) 30%,var(--border));border-radius:var(--radius);padding:12px 14px;overflow:hidden}.path-verses-header{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:#7c3aed;margin-bottom:8px}.path-verse-card{background:var(--surface);border:1.5px solid color-mix(in srgb,var(--purple) 20%,var(--border));border-radius:var(--radius-sm);padding:10px 12px;margin-bottom:6px;transition:border-color .3s,box-shadow .3s}.path-verse-card:last-child{margin-bottom:0}.path-verse-card--new{border-color:var(--purple);box-shadow:0 0 0 3px color-mix(in srgb,var(--purple) 15%,transparent)}.path-verse-ref{font-size:11px;font-weight:600;color:#7c3aed;display:block;margin-bottom:3px}.path-verse-text{font-size:13px;color:var(--text);margin:0;line-height:1.45;font-style:italic}@media(max-width:360px){.path-grid-wrapper{padding:6px}.path-grid{gap:5px}.path-tile{border-radius:10px;min-width:40px;min-height:40px}.path-tile-label{font-size:8px}}@media(min-width:600px){.path-grid-wrapper{padding:14px}.path-grid{gap:9px}.path-tile{border-radius:16px}.path-tile-label{font-size:11px}}[data-theme=dark] .path-mission{background:#f59e0b1a;border-color:#f59e0b40}[data-theme=dark] .path-mission-header{color:var(--amber)}[data-theme=dark] .path-legend-chip{background:var(--surface);border-color:var(--glass-border)}[data-theme=dark] .path-legend-chip--start{background:var(--tint-green);border-color:color-mix(in srgb,var(--green) 40%,transparent);color:var(--green)}[data-theme=dark] .path-legend-chip--goal{background:#f59e0b1f;border-color:color-mix(in srgb,var(--amber) 40%,transparent);color:var(--amber)}[data-theme=dark] .path-legend-chip--manna{background:var(--tint-blue);border-color:color-mix(in srgb,var(--blue) 40%,transparent);color:var(--blue)}[data-theme=dark] .path-legend-chip--complaint{background:var(--tint-red);border-color:color-mix(in srgb,var(--red) 40%,transparent);color:var(--red)}[data-theme=dark] .path-legend-chip--verse{background:var(--tint-purple);border-color:color-mix(in srgb,var(--purple) 40%,transparent);color:var(--purple)}[data-theme=dark] .path-legend-chip--event{background:var(--tint-orange);border-color:color-mix(in srgb,var(--orange) 40%,transparent);color:var(--orange)}[data-theme=dark] .path-tile-step{background:var(--green)}[data-theme=dark] .path-grid-wrapper,[data-theme=dark] .path-stats{background:#ffffff08;border-color:var(--glass-border)}[data-theme=dark] .path-stat{background:var(--surface);border-color:var(--glass-border)}[data-theme=dark] .path-tile{background:var(--surface);border-color:var(--glass-border);box-shadow:0 4px #00000059,0 4px 8px #00000026}[data-theme=dark] .path-tile:active:not(:disabled){box-shadow:0 1px #0000004d,0 1px 2px #0000001a}[data-theme=dark] .path-tile--start{background:var(--tint-green);border-color:var(--green);box-shadow:0 4px #00000059,0 0 0 4px color-mix(in srgb,var(--green) 15%,transparent)}[data-theme=dark] .path-tile--goal{background:#f59e0b26;border-color:var(--amber);color:var(--amber);box-shadow:0 4px #00000059,0 0 12px #f59e0b33}[data-theme=dark] .path-tile--manna{background:var(--tint-blue);border-color:var(--blue);color:var(--blue);box-shadow:0 4px #00000059}[data-theme=dark] .path-tile--complaint{background:var(--tint-red);border-color:color-mix(in srgb,var(--red) 50%,transparent);color:var(--red);box-shadow:0 4px #00000059}[data-theme=dark] .path-tile--obstacle{background:#ffffff0a;border-color:#ffffff14;color:var(--text-light);box-shadow:inset 0 3px 6px #0000004d}[data-theme=dark] .path-tile--verse{background:var(--tint-purple);border-color:var(--purple);color:var(--purple);box-shadow:0 4px #00000059}[data-theme=dark] .path-tile--event{background:var(--tint-orange);border-color:var(--orange);color:var(--orange);box-shadow:0 4px #00000059}[data-theme=dark] .path-tile--selected{background:color-mix(in srgb,var(--green) 18%,var(--surface));border-color:var(--green);box-shadow:0 4px #00000059}[data-theme=dark] .path-tile--last{background:color-mix(in srgb,var(--green) 22%,var(--surface));box-shadow:0 4px #00000059,0 0 0 5px color-mix(in srgb,var(--green) 18%,transparent)}[data-theme=dark] .path-verse-reveal{background:var(--surface);border-color:color-mix(in srgb,var(--purple) 25%,var(--glass-border))}[data-theme=dark] .path-verses-panel{background:var(--tint-purple);border-color:color-mix(in srgb,var(--purple) 25%,var(--glass-border))}[data-theme=dark] .path-verses-header{color:var(--purple)}[data-theme=dark] .path-verse-card{background:var(--surface);border-color:var(--glass-border)}[data-theme=dark] .path-verse-card--new{border-color:var(--purple);box-shadow:0 0 0 3px color-mix(in srgb,var(--purple) 12%,transparent)}[data-theme=dark] .path-verse-ref{color:var(--purple)}@media(prefers-reduced-motion:reduce){.path-tile--start,.path-tile--goal,.path-tile--valid-move:not(:disabled){animation:none}}.verse-mosaic{display:flex;flex-direction:column;gap:16px;text-align:center}.mosaic-reference{display:inline-block;align-self:center;padding:4px 14px;border-radius:100px;background:var(--tint-blue);color:var(--blue-dark);font-size:13px;font-weight:600;letter-spacing:.02em}.mosaic-answer-area{position:relative;min-height:96px;padding:14px;border:2px dashed var(--border);border-radius:var(--radius);background:linear-gradient(180deg,#fff9,#fff3),var(--tint-neutral);display:flex;flex-wrap:wrap;gap:8px;justify-content:center;align-content:flex-start;transition:border-color .2s,background-color .3s,box-shadow .2s;box-shadow:inset 0 1px #ffffff59}.mosaic-answer-area--empty{border-color:color-mix(in srgb,var(--blue) 12%,var(--border));box-shadow:inset 0 1px #ffffff73,0 0 0 1px color-mix(in srgb,var(--blue) 8%,transparent)}.mosaic-answer-area--correct{border-color:var(--green);background:var(--tint-green);border-style:solid}.mosaic-answer-area--review{border-style:solid;border-color:color-mix(in srgb,var(--green) 36%,var(--border));background:color-mix(in srgb,var(--green) 8%,var(--tint-neutral))}.mosaic-answer-list{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;align-content:flex-start;width:100%;min-height:68px}.mosaic-success-check{position:absolute;top:-12px;right:-12px;width:32px;height:32px;border-radius:50%;background:var(--green);color:#fff;font-size:18px;font-weight:600;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #58cc0266}.mosaic-tile{min-height:48px;padding:12px 16px;border:1px solid transparent;border-radius:12px;background:var(--surface);box-shadow:0 2px 0 0 var(--border),0 1px 3px #0000000f;font-size:15px;font-weight:600;font-family:var(--font);color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:manipulation;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:box-shadow .15s,background-color .15s;-webkit-tap-highlight-color:transparent}.mosaic-tile:hover:not(:disabled){box-shadow:0 3px 0 0 var(--blue),0 2px 6px #00000014}.mosaic-tile:active:not(:disabled){box-shadow:0 0 0 0 var(--border);transform:translateY(2px)}.mosaic-tile--placed{background:var(--blue);color:#fff;box-shadow:0 3px 0 0 var(--blue-dark, #1899d6),0 4px 14px rgba(var(--blue-rgb),.16)}.mosaic-tile--review{background:var(--green);box-shadow:0 2px 0 0 var(--green-dark),0 1px 3px #0000001f}.mosaic-tile__grip{display:inline-flex;flex-direction:column;gap:3px;opacity:.55;flex-shrink:0}.mosaic-tile__grip span{display:block;width:12px;height:2px;border-radius:999px;background:currentColor}.mosaic-tile--placed:hover:not(:disabled){box-shadow:0 3px 0 0 var(--blue-dark, #1899d6),0 8px 20px rgba(var(--blue-rgb),.18)}.mosaic-tile--ghost{visibility:hidden;pointer-events:none;height:0;min-height:0;padding:0;margin:0;border:none;box-shadow:none;overflow:hidden}.mosaic-tile-bank{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;padding:8px 0 4px;margin-bottom:8px}.mosaic-bonus{overflow:hidden;padding-top:16px;border-top:1px solid var(--border)}.mosaic-bonus-question{font-size:16px;font-weight:600;margin-bottom:12px;color:var(--text)}.mosaic-bonus-options{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.mosaic-bonus-option{padding:12px 16px;border:2px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:0 2px 0 0 var(--border);font-size:15px;font-weight:600;font-family:var(--font);color:var(--text);cursor:pointer;text-align:start;transition:border-color .15s,background-color .15s;-webkit-tap-highlight-color:transparent}.mosaic-bonus-option:hover:not(:disabled){border-color:var(--blue)}.mosaic-bonus-option--selected{border-color:var(--blue);background:var(--tint-blue);box-shadow:0 2px 0 0 var(--blue)}.mosaic-bonus-reveal{font-size:14px;line-height:1.6;padding:12px;border-radius:var(--radius-sm)}.mosaic-bonus-reveal--correct{background:var(--tint-green);color:var(--green-dark, #3b8c00)}.mosaic-bonus-reveal--incorrect{background:var(--tint-red);color:var(--red-dark, #c0392b)}[data-theme=dark] .mosaic-reference{background:color-mix(in srgb,var(--blue) 18%,var(--surface));color:var(--blue);border:1px solid color-mix(in srgb,var(--blue) 28%,transparent)}[data-theme=dark] .mosaic-answer-area{background:var(--surface);border-color:color-mix(in srgb,var(--blue) 18%,var(--border));box-shadow:inset 0 1px #ffffff0a,inset 0 0 0 1px #ffffff05}[data-theme=dark] .mosaic-answer-area--empty{border-color:color-mix(in srgb,var(--blue) 38%,var(--border));box-shadow:inset 0 1px #ffffff0a,0 0 0 1px color-mix(in srgb,var(--blue) 14%,transparent)}[data-theme=dark] .mosaic-answer-area--correct{background:color-mix(in srgb,var(--green) 12%,var(--surface));border-color:var(--green);box-shadow:inset 0 1px #58cc0212,0 0 14px #58cc0224}[data-theme=dark] .mosaic-answer-area--review{background:color-mix(in srgb,var(--green) 10%,var(--surface));border-color:color-mix(in srgb,var(--green) 45%,var(--border))}[data-theme=dark] .mosaic-tile{background:var(--surface-elevated);border-color:color-mix(in srgb,var(--border) 70%,transparent);box-shadow:0 2px #00000080,0 1px 4px #00000059}[data-theme=dark] .mosaic-tile:hover:not(:disabled){background:color-mix(in srgb,var(--surface-elevated) 78%,var(--blue) 22%);border-color:color-mix(in srgb,var(--blue) 45%,transparent);box-shadow:0 3px 0 0 var(--blue-dark),0 2px 8px rgba(var(--blue-rgb),.18)}[data-theme=dark] .mosaic-tile:active:not(:disabled){box-shadow:0 0 #00000080}[data-theme=dark] .mosaic-tile--placed{box-shadow:0 3px 0 0 var(--blue-dark),0 4px 18px rgba(var(--blue-rgb),.28)}[data-theme=dark] .mosaic-tile--placed:hover:not(:disabled){box-shadow:0 3px 0 0 var(--blue-dark),0 8px 24px rgba(var(--blue-rgb),.34)}[data-theme=dark] .mosaic-tile--review{box-shadow:0 2px 0 0 var(--green-dark),0 2px 8px #58cc0233}[data-theme=dark] .mosaic-bonus{border-top-color:var(--border)}[data-theme=dark] .mosaic-bonus-option{background:var(--surface-elevated);border-color:var(--border);box-shadow:0 2px #0006}[data-theme=dark] .mosaic-bonus-option--selected{background:color-mix(in srgb,var(--blue) 16%,var(--surface-elevated));border-color:var(--blue);box-shadow:0 2px 0 0 var(--blue-dark)}[data-theme=dark] .mosaic-bonus-reveal--correct{background:color-mix(in srgb,var(--green) 14%,var(--surface));color:#7ee83a}[data-theme=dark] .mosaic-bonus-reveal--incorrect{background:color-mix(in srgb,var(--red, #ff4b4b) 12%,var(--surface));color:#ff7070}@media(max-width:480px){.mosaic-tile{padding:10px 12px;font-size:14px}.mosaic-answer-area{min-height:64px;padding:10px;gap:6px}.mosaic-tile-bank{gap:6px}}@media(prefers-reduced-motion:reduce){.mosaic-tile{transition:none}.mosaic-success-check{animation:none}}.tap-choose-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:16px 0}.tap-choose-option{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:12px;border:2.5px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;position:relative;min-height:72px;transition:border-color .15s,filter .15s;font-family:var(--font);font-weight:600;font-size:14px}.tap-choose-option:hover:not(:disabled){border-color:var(--blue)}.tap-choose-option--selected{border-color:var(--blue);filter:drop-shadow(0 0 8px rgba(var(--blue-rgb),.3))}.tap-choose-option__img{width:100%;max-height:120px;object-fit:contain;border-radius:var(--radius-sm)}.tap-choose-option__label{color:var(--text)}.tap-choose-option__ring{position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border:3px solid var(--blue);border-radius:var(--radius);pointer-events:none}.word-build-clue{font-size:16px;color:var(--text-muted);margin-bottom:16px;text-align:center}.word-build-slots{display:flex;justify-content:center;gap:6px;margin-bottom:20px;cursor:pointer}.word-build-slot{width:44px;height:52px;border:2.5px dashed var(--border);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:600;color:var(--text);background:var(--surface)}.word-build-slot--filled{border-style:solid;border-color:var(--blue);background:color-mix(in srgb,var(--blue) 8%,var(--surface))}.word-build-tiles{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:25px}.word-build-tile{width:52px;height:52px;border:2.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);font-size:20px;font-weight:600;color:var(--text);cursor:pointer;font-family:var(--font);transition:border-color .15s,transform .1s}.word-build-tile:hover:not(:disabled){border-color:var(--blue)}.word-build-tile:disabled{opacity:.35;cursor:default}.word-build-tile--used{background:var(--surface-muted, rgba(255, 255, 255, .06));border-color:transparent;color:#fff3;opacity:.4;cursor:default}.flip-reveal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:16px 0}.flip-reveal-card{aspect-ratio:3 / 4;border:2.5px solid var(--border);border-radius:var(--radius);background:var(--surface-elevated);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:600;color:var(--text-muted);transition:border-color .2s,transform .2s;perspective:600px;font-family:var(--font)}.flip-reveal-card:hover:not(:disabled){border-color:var(--blue)}.flip-reveal-card--flipped{border-color:var(--blue)}.flip-reveal-card--matched{border-color:var(--green);background:color-mix(in srgb,var(--green) 8%,var(--surface));filter:drop-shadow(0 0 6px rgba(88,204,2,.3))}.flip-reveal-card__inner{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:8px;text-align:center;word-break:break-word}.flip-reveal-card__back{font-size:32px;color:var(--text-light)}.flip-reveal-card--flipped .flip-reveal-card__back,.flip-reveal-card--matched .flip-reveal-card__back{display:none}.flip-reveal-card__front{display:none;font-size:14px;font-weight:600;color:var(--text)}.flip-reveal-card--flipped .flip-reveal-card__front,.flip-reveal-card--matched .flip-reveal-card__front{display:flex;align-items:center;justify-content:center}.detective-grid{display:flex;flex-direction:column;gap:14px;width:100%}.detective-grid--error{text-align:center;color:var(--text-light);padding:24px}.dg-clue-panel{background:var(--tint-blue);border:1.5px solid var(--tint-blue-border, var(--border));border-radius:var(--radius);padding:12px 14px}.dg-clue-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.dg-clue-badge{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--blue-dark, #1e40af)}.dg-clue-reveal-btn{all:unset;cursor:pointer;font-size:14px;font-weight:600;color:var(--blue, #3b82f6);padding:4px 10px;border-radius:6px;background:var(--surface);border:1.5px solid var(--border);transition:background .15s,color .15s}.dg-clue-reveal-btn:hover{background:var(--blue, #3b82f6);color:#fff}.dg-clue-reveal-btn:disabled{opacity:.5;cursor:default}.dg-clue-list{display:flex;flex-direction:column;gap:6px}.dg-clue{display:flex;gap:6px;font-size:14px;font-weight:600;color:var(--text);line-height:1.4}.dg-clue--positive .dg-clue-number{color:var(--green-dark, #16a34a)}.dg-clue--negative .dg-clue-number{color:var(--red-dark, #dc2626)}.dg-clue-number{font-weight:600;flex-shrink:0}.dg-grid{display:grid;gap:2px;justify-content:center;align-items:center}.dg-col-header{display:flex;align-items:flex-end;justify-content:center;padding:4px 2px;min-height:48px;overflow:hidden;transition:border-color .3s,background .3s;border-radius:4px}.dg-col-header-text{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-light);text-align:center;writing-mode:vertical-rl;transform:rotate(180deg);line-height:1.2;max-height:80px;overflow:hidden;text-overflow:ellipsis}.dg-row-header{display:flex;align-items:center;font-size:12px;font-weight:600;color:var(--text);padding-inline-end:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100px;transition:border-color .3s,background .3s;border-radius:4px}.dg-header--highlight{background:#f59e0b2e;outline:2px solid var(--amber, #f59e0b);outline-offset:-1px}.dg-cell{all:unset;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:6px;border:1.5px solid var(--border);background:var(--surface);box-shadow:0 2px color-mix(in srgb,var(--border) 85%,transparent),0 2px 6px #0f172a0a;transition:background .15s,border-color .15s,box-shadow .15s,transform .15s;aspect-ratio:1;min-width:40px;min-height:40px}.dg-cell:hover:not(:disabled){border-color:var(--blue, #3b82f6);transform:translateY(-1px)}.dg-cell:disabled{cursor:default;opacity:.7}.dg-cell--marked{background:var(--tint-green, #dcfce7);border-color:var(--green, #22c55e);box-shadow:0 0 0 3px color-mix(in srgb,var(--green) 16%,transparent)}.dg-cell--eliminated{background:var(--tint-neutral, #f0f0f3);border-color:transparent}.dg-cell-icon{font-size:16px;font-weight:600;line-height:1}.dg-cell-icon--mark{color:var(--green-dark, #16a34a)}.dg-cell-icon--elim{color:var(--text-light);font-size:12px;opacity:.5}.dg-onboarding{background:var(--surface-raised, var(--surface));border:1.5px solid var(--border);border-radius:var(--radius);padding:8px 12px;font-size:12px;font-weight:600;color:var(--text-light);text-align:center;box-shadow:0 4px 12px #0000001a}.dg-progress{font-size:12px;font-weight:600;color:var(--text-light);text-align:center;text-transform:uppercase;letter-spacing:.06em}[data-theme=dark] .dg-clue-panel{background:#3b82f614;border-color:#3b82f633}[data-theme=dark] .dg-cell{background:var(--surface);border-color:var(--border)}[data-theme=dark] .dg-cell--marked{background:#22c55e26;border-color:var(--green)}[data-theme=dark] .dg-cell--eliminated{background:#ffffff0a}[data-theme=dark] .dg-header--highlight{background:#f59e0b1f}@media(max-width:479px){.dg-row-header{font-size:11px;max-width:72px}.dg-col-header-text{font-size:11px}.dg-cell{min-width:36px;min-height:36px}}.teaching-card{display:flex;flex-direction:column;gap:0}.teaching-card__content{background:color-mix(in srgb,var(--blue) 8%,var(--card-bg));border-inline-start:4px solid var(--blue);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.teaching-card__icon-row{display:flex;align-items:center;gap:8px;color:var(--blue);font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.teaching-card__label{color:var(--blue)}.teaching-card__body{font-family:var(--font-reading);font-size:16px;line-height:1.6;color:var(--text);margin:0}.teaching-card__refs{display:flex;flex-wrap:wrap;gap:6px}.teaching-card__ref-chip{background:color-mix(in srgb,var(--blue) 12%,var(--card-bg));color:var(--blue);font-size:14px;font-weight:600;padding:3px 10px 3px 0;border-radius:100px}.teaching-card__refs--interactive{gap:8px;margin-bottom:4px}.teaching-card__ref-chip--pulse{cursor:pointer;display:inline-flex;align-items:center;gap:6px;padding:11px 20px 11px 14px;border:1.5px solid color-mix(in srgb,var(--blue) 40%,transparent);border-radius:100px;background:color-mix(in srgb,var(--blue) 7%,var(--card-bg));box-shadow:0 0 0 4px color-mix(in srgb,var(--blue) 0%,transparent);color:var(--blue);font-size:15px;font-weight:600;font-family:var(--font);animation:chip-pulse 2.4s ease-in-out infinite;transition:background .15s,box-shadow .15s}.teaching-card__chip-icon{opacity:.7;flex-shrink:0}.teaching-card__ref-chip--expanded{display:inline-flex;align-items:center;padding:11px 20px;border:1.5px solid color-mix(in srgb,var(--blue) 25%,transparent);border-radius:100px;background:color-mix(in srgb,var(--blue) 12%,var(--card-bg));color:var(--blue);font-size:15px;font-weight:600;font-family:var(--font);opacity:.55;cursor:default}@keyframes chip-pulse{0%,to{box-shadow:0 0 color-mix(in srgb,var(--blue) 28%,transparent)}55%{box-shadow:0 0 0 7px color-mix(in srgb,var(--blue) 0%,transparent)}}.teaching-card__verse-panel{overflow:hidden}.teaching-card__verse-inner{background:var(--surface);border-bottom:1px solid color-mix(in srgb,var(--blue) 18%,var(--glass-border));padding-top:20px;padding-bottom:20px;margin-bottom:10px;display:flex;flex-direction:column;gap:10px;box-shadow:0 1px 4px color-mix(in srgb,var(--blue) 6%,transparent),0 0 0 3px color-mix(in srgb,var(--blue) 5%,transparent)}.teaching-card__verse-badge{display:inline-flex;align-self:flex-start;align-items:baseline;gap:5px;padding:3px 10px;border-radius:100px;background:color-mix(in srgb,var(--blue) 12%,var(--card-bg));color:var(--blue);font-size:14px;font-weight:700;font-family:var(--font);letter-spacing:.06em;text-transform:uppercase}.teaching-card__verse-translation{font-size:11px;font-weight:500;opacity:.6;letter-spacing:.04em}.teaching-card__verse-text{font-family:var(--font-reading);font-size:16px;line-height:1.75;color:var(--text);margin:0}.teaching-card__verse-text .verse-num{font-size:.75em;vertical-align:inherit;line-height:0;color:var(--blue);font-weight:700;margin-inline-end:3px;opacity:.6;font-family:var(--font)}.teaching-card__ref-translation{font-weight:400;opacity:.7}.teaching-card__continue-btn{background:var(--blue);box-shadow:0 var(--btn-3d-depth) 0 var(--blue-dark),var(--shadow-node);margin-top:16px}.keyword-hunt{display:flex;flex-direction:column;gap:16px}.keyword-hunt__progress{display:flex;align-items:center;gap:12px}.keyword-hunt__counter{font-size:13px;font-weight:600;color:var(--text-light);white-space:nowrap;min-width:70px}.keyword-hunt__bar{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden}.keyword-hunt__fill{height:100%;background:var(--orange);border-radius:3px;transform-origin:left}.keyword-hunt__passage{padding:20px 16px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);line-height:1.7;font-size:16px}.keyword-hunt__ref{display:block;margin-top:12px;font-size:12px;font-weight:600;color:var(--text-light);text-align:end}.keyword-hunt__hint{font-size:13px;color:var(--orange);text-align:center;margin:0}.context-reveal{display:flex;flex-direction:column;gap:16px}.context-reveal__verse{padding:20px 16px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);text-align:center}.context-reveal__quote{margin:0;font-size:18px;font-style:italic;line-height:1.6;color:var(--text)}.context-reveal__ref{display:block;margin-top:8px;font-size:12px;font-weight:600;color:var(--text-light);text-align:end}.context-reveal__reveal-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 20px;border:2px dashed var(--blue);border-radius:var(--radius);background:var(--tint-blue);color:var(--blue);font-size:15px;font-weight:600;cursor:pointer;font-family:var(--font);transition:background .15s}.context-reveal__reveal-btn:hover{background:color-mix(in srgb,var(--blue) 15%,var(--surface))}.context-reveal__reveal-icon{font-size:18px}.context-reveal__context{padding:16px;background:var(--tint-blue);border:1.5px solid color-mix(in srgb,var(--blue) 30%,var(--border));border-radius:var(--radius);overflow:hidden}.context-reveal__context-label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--blue);margin-bottom:8px}.context-reveal__context-text{margin:0;font-size:15px;line-height:1.6;color:var(--text)}.context-reveal__options{display:flex;flex-direction:column;gap:8px}.context-reveal__option{position:relative;padding:14px 16px;border:2px solid var(--border);border-bottom:4px solid var(--border);border-radius:var(--radius);background:var(--surface);font-size:15px;font-family:var(--font);font-weight:600;cursor:pointer;text-align:start;transition:border-color .15s,background .15s}.context-reveal__option:hover:not(:disabled){border-color:var(--blue)}.context-reveal__option--selected{border-color:var(--blue);background:var(--tint-blue)}.context-reveal__ring{position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border:3px solid var(--blue);border-radius:var(--radius);pointer-events:none}.wh-investigator{display:flex;flex-direction:column;gap:16px}.wh-investigator__passage{padding:20px 16px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius)}.wh-investigator__text{margin:0;font-size:16px;line-height:1.7;color:var(--text)}.wh-investigator__ref{display:block;margin-top:12px;font-size:12px;font-weight:600;color:var(--text-light);text-align:end}.wh-investigator__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.wh-investigator__tile{position:relative;display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 10px;border:2px solid var(--border);border-bottom:4px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;font-family:var(--font);transition:border-color .15s,background .15s}.wh-investigator__tile:hover:not(:disabled){border-color:var(--wh-color)}.wh-investigator__tile--selected{border-color:var(--wh-color);background:color-mix(in srgb,var(--wh-color) 10%,var(--surface))}.wh-investigator__icon{display:flex;align-items:center;justify-content:center;color:var(--wh-color);margin-bottom:2px}.wh-investigator__label{font-size:13px;font-weight:700;color:var(--wh-color);text-transform:uppercase;letter-spacing:.04em}.wh-investigator__hint{font-size:11px;font-weight:500;color:var(--text-light);text-align:center;line-height:1.3;margin-top:2px}.wh-investigator__answer{font-size:12px;font-weight:500;color:var(--text-light);text-align:center;line-height:1.3;margin-top:4px}.wh-investigator__ring{position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border:3px solid var(--wh-color);border-radius:var(--radius);pointer-events:none}.compare-contrast{display:flex;flex-direction:column;gap:16px}.compare-contrast__passages{display:grid;grid-template-columns:1fr 1fr;gap:10px}.compare-contrast__passage{padding:14px 12px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius)}.compare-contrast__passage-label{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--blue);color:#fff;font-size:12px;font-weight:700;margin-bottom:8px}.compare-contrast__passage-text{margin:0;font-size:14px;line-height:1.5;color:var(--text)}.compare-contrast__passage-ref{display:block;margin-top:8px;font-size:11px;font-weight:600;color:var(--text-light);text-align:end}.compare-contrast__buckets{display:flex;gap:8px;padding:10px;background:var(--tint-neutral);border-radius:var(--radius-sm);border:1px solid var(--border)}.compare-contrast__bucket{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:12px 10px;color:#fff;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:700;cursor:pointer;font-family:var(--font);transition:filter .15s,transform .15s}.compare-contrast__bucket--ready{filter:brightness(1.1);box-shadow:0 0 0 2px #ffffff4d inset}.compare-contrast__bucket-count{min-width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#ffffff40;font-size:11px;font-weight:700}.compare-contrast__statements{display:flex;flex-direction:column;gap:8px}.compare-contrast__item{display:flex;align-items:center;gap:10px;padding:14px 16px;border:2px solid var(--border);border-bottom:4px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;font-size:14px;font-weight:600;font-family:var(--font);text-align:start;line-height:1.4;transition:border-color .15s,background-color .15s,opacity .15s}.compare-contrast__item:hover:not(:disabled){border-color:var(--blue)}.compare-contrast__item.active{border-color:var(--purple);background:var(--tint-purple);box-shadow:0 0 0 1px var(--purple)}.compare-contrast__item.assigned{opacity:.85}.compare-contrast__badge{width:24px;height:24px;border-radius:50%;color:#fff;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cause-effect{display:flex;flex-direction:column;gap:16px}.cause-effect__columns{display:grid;grid-template-columns:1fr 1fr;gap:16px}.cause-effect__col{display:flex;flex-direction:column;gap:8px}.cause-effect__col-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;text-align:center;padding:6px 0;border-radius:var(--radius-sm)}.cause-effect__col-label--cause{color:var(--blue);background:var(--tint-blue)}.cause-effect__col-label--effect{color:var(--orange);background:var(--tint-orange)}.cause-effect__item{padding:12px 14px;border:2px solid var(--border);border-bottom:4px solid var(--border);border-radius:var(--radius);background:var(--surface);font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;text-align:start;line-height:1.4;transition:border-color .15s,background .15s,opacity .15s}.cause-effect__item--cause{border-inline-start:4px solid var(--blue)}.cause-effect__item--effect{border-inline-end:4px solid var(--orange)}.cause-effect__item:hover:not(:disabled){border-color:var(--blue)}.cause-effect__item.active{border-color:var(--blue);background:var(--tint-blue);box-shadow:0 0 0 3px color-mix(in srgb,var(--blue) 25%,transparent),0 4px 12px #3b82f626}.cause-effect__item.linked{opacity:.85}.cause-effect__pair-badge{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;font-size:11px;font-weight:700;color:#fff;margin-inline-end:6px;flex-shrink:0}.cause-effect__item--ready{border-color:color-mix(in srgb,var(--blue) 55%,var(--border));background:color-mix(in srgb,var(--blue) 8%,var(--surface))}.spotlight-find{display:flex;flex-direction:column;gap:16px}.spotlight-find__header{display:flex;align-items:center;gap:12px}.spotlight-find__counter{font-size:13px;font-weight:600;color:var(--text-light);white-space:nowrap;min-width:70px}.spotlight-find__timer{font-size:13px;font-weight:700;color:var(--red);min-width:32px;text-align:center}.spotlight-find__bar{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden}.spotlight-find__fill{height:100%;background:var(--purple);border-radius:3px;transform-origin:left}.spotlight-find__passage{position:relative;padding:24px 20px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);line-height:1.8;font-size:16px;cursor:crosshair;-webkit-user-select:none;user-select:none;overflow:hidden}.spotlight-find__text{margin:0;color:color-mix(in srgb,var(--text) 30%,transparent);transition:color .3s}.spotlight-find__passage--active .spotlight-find__text{mask-image:radial-gradient(circle 80px at var(--spot-x) var(--spot-y),black 0%,black 60%,transparent 100%);-webkit-mask-image:radial-gradient(circle 80px at var(--spot-x) var(--spot-y),black 0%,black 60%,transparent 100%);color:var(--text)}.spotlight-find__target{position:relative;cursor:pointer;border-radius:3px;transition:background .15s}.spotlight-find__target:hover{background:color-mix(in srgb,var(--purple) 15%,transparent)}.spotlight-find__target.is-found{color:var(--purple);font-weight:700;background:color-mix(in srgb,var(--purple) 12%,transparent);mask-image:none!important;-webkit-mask-image:none!important}.spotlight-find__glow{position:absolute;top:-2px;right:-4px;bottom:-2px;left:-4px;background:color-mix(in srgb,var(--purple) 20%,transparent);border-radius:4px;pointer-events:none;z-index:-1}.spotlight-find__ref{display:block;margin-top:12px;font-size:12px;font-weight:600;color:var(--text-light);text-align:end}.spotlight-find__hint{font-size:13px;color:var(--purple);text-align:center;margin:0}.repetition-insight{display:flex;flex-direction:column;gap:16px}.repetition-insight__passage{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.repetition-insight__text{font-size:15px;line-height:1.7;color:var(--text);margin:0}.repetition-insight__repeated{font-weight:700;color:var(--orange);background:color-mix(in srgb,var(--orange) 12%,transparent);border-radius:3px;padding:0 2px}.repetition-insight__ref{display:block;font-size:12px;color:var(--text-light);margin-top:8px;text-align:end}.repetition-insight__legend{display:flex;flex-wrap:wrap;gap:8px}.repetition-insight__tag{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-pill);background:color-mix(in srgb,var(--orange) 12%,transparent);color:var(--orange);font-size:12px;font-weight:700}.repetition-insight__tag-count{background:var(--orange);color:#fff;width:18px;height:18px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:700}.repetition-insight__options{display:flex;flex-direction:column;gap:8px}.repetition-insight__option{padding:14px 16px;border:2px solid var(--border);border-bottom:4px solid var(--border);border-radius:var(--radius);background:var(--surface);font-size:14px;font-weight:600;font-family:var(--font);cursor:pointer;text-align:start;line-height:1.4;transition:border-color .15s,background .15s}.repetition-insight__option:hover:not(:disabled){border-color:var(--orange)}.repetition-insight__option--selected{border-color:var(--orange);background:color-mix(in srgb,var(--orange) 8%,var(--surface))}.discovery-question{flex:1;display:flex;flex-direction:column;gap:12px}.discovery-question__badge{display:flex;align-items:center;gap:6px;color:var(--orange);font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.discovery-question__passage{background:color-mix(in srgb,var(--orange) 8%,var(--card-bg));border-inline-start:4px solid var(--orange);border-radius:var(--radius);padding:16px;font-family:var(--font-reading);font-size:16px;line-height:1.6;color:var(--text);margin-bottom:4px}.discovery-question__passage-ref{display:block;text-align:end;font-size:13px;font-weight:600;color:var(--orange);opacity:.8;margin-top:8px;font-family:var(--font)}.discovery-question__passage-translation{font-weight:500;opacity:.7}.reflection-card{flex:1;display:flex;flex-direction:column;gap:16px}.reflection-card__badge{display:inline-flex;align-items:center;gap:6px;padding:5px 12px 5px 10px;background:color-mix(in srgb,#8e44ad 10%,transparent);border:1.5px solid color-mix(in srgb,#8e44ad 28%,transparent);border-radius:20px;color:#8e44ad;font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.8px;width:fit-content}.reflection-card__choices{display:flex;flex-direction:column;gap:10px;margin-top:4px}.reflection-card__choice{width:100%;padding:16px 18px;border:2px solid var(--border);border-radius:var(--radius);background:var(--surface);font-family:var(--font);font-size:15px;font-weight:500;line-height:1.45;color:var(--text);cursor:pointer;text-align:left;display:flex;align-items:center;gap:14px;box-shadow:0 1px 4px #0000000d;transition:border-color .18s ease,background .18s ease,box-shadow .18s ease,transform .1s ease;-webkit-tap-highlight-color:transparent;position:relative}.reflection-card__choice:hover:not(:disabled){border-color:color-mix(in srgb,#8e44ad 45%,transparent);background:color-mix(in srgb,#8e44ad 4%,var(--surface));box-shadow:0 2px 8px #00000012}.reflection-card__choice--selected{border-color:#8e44ad;background:color-mix(in srgb,#8e44ad 7%,var(--card-bg));box-shadow:0 0 0 1px color-mix(in srgb,#8e44ad 40%,transparent),0 4px 16px color-mix(in srgb,#8e44ad 14%,transparent)}.reflection-card__radio{flex-shrink:0;width:22px;height:22px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;transition:border-color .18s ease,background .18s ease}.reflection-card__choice--selected .reflection-card__radio{border-color:#8e44ad;background:#8e44ad}.reflection-card__radio-dot{display:block;width:8px;height:8px;border-radius:50%;background:#fff}.reflection-card__choice-label{flex:1;min-width:0}.reflection-card__textarea-wrap{position:relative;margin-top:4px}.reflection-card__textarea{width:100%;min-height:110px;padding:16px;border:2px solid var(--border);border-radius:var(--radius);background:var(--surface);font-family:var(--font-reading);font-size:16px;line-height:1.65;color:var(--text);resize:vertical;transition:border-color .18s ease,box-shadow .18s ease;box-shadow:0 1px 4px #0000000d}.reflection-card__char-count{display:block;text-align:right;font-size:12px;color:var(--text-muted, #999);margin-top:4px}.reflection-card__textarea:focus{outline:none;border-color:#8e44ad;box-shadow:0 0 0 1px color-mix(in srgb,#8e44ad 35%,transparent),0 4px 16px color-mix(in srgb,#8e44ad 10%,transparent)}.interactive-verse-card{display:flex;flex-direction:column;gap:14px}.ivc__badge-row{display:flex;align-items:center;justify-content:space-between}.ivc__badge{display:inline-flex;align-items:center;gap:5px;padding:5px 11px 5px 8px;border-radius:999px;background:color-mix(in srgb,var(--blue) 12%,transparent);border:1px solid color-mix(in srgb,var(--blue) 22%,transparent);color:var(--blue);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.ivc__progress{font-size:12px;font-weight:600;color:var(--text-light);padding:4px 10px;border-radius:999px;background:color-mix(in srgb,var(--text-light) 10%,transparent);border:1px solid color-mix(in srgb,var(--text-light) 14%,transparent)}.ivc__progress--done{display:inline-flex;align-items:center;gap:4px;color:var(--green);background:color-mix(in srgb,var(--green) 12%,transparent);border-color:color-mix(in srgb,var(--green) 20%,transparent)}.ivc__verse-container{background:var(--tint-neutral);border:1.5px solid var(--border);border-radius:20px;padding:20px 20px 16px;display:flex;flex-direction:column;gap:14px;transition:border-color .3s ease,box-shadow .3s ease}.ivc__verse-container--completed{border-color:color-mix(in srgb,var(--green) 40%,var(--border));box-shadow:0 0 0 4px color-mix(in srgb,var(--green) 8%,transparent)}.ivc__ref-row{display:flex;justify-content:flex-end;padding-top:4px;border-top:1px solid var(--border)}.ivc__ref{font-size:13px;font-weight:600;color:var(--blue);opacity:.85;font-style:italic}.ivc__translation{font-weight:500;opacity:.75;font-style:normal}.ivc__hint{font-size:12px;font-weight:500;color:var(--text-light);text-align:center;margin:0;padding:0 8px;opacity:.75}[data-theme=dark] .ivc__verse-container{background:#ffffff08;border-color:var(--glass-border)}[data-theme=dark] .ivc__verse-container--completed{border-color:color-mix(in srgb,var(--green) 35%,var(--glass-border));box-shadow:0 0 0 4px color-mix(in srgb,var(--green) 10%,transparent)}[data-theme=dark] .ivc__ref-row{border-top-color:var(--glass-border)}.story-hook{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:260px;padding:32px 20px 24px;text-align:center;background:linear-gradient(160deg,#ff96000f,#1e1e500f);border-radius:16px}.story-hook__content{display:flex;flex-direction:column;gap:16px;max-width:360px}.story-hook__premise{font-family:var(--font-reading);font-size:22px;line-height:1.45;color:var(--text-primary);letter-spacing:-.01em}.story-hook__question{font-family:var(--font-reading);font-size:18px;font-style:italic;line-height:1.5;color:var(--text-secondary)}.story-hook__cta{margin-top:28px;padding:14px 32px;font-family:var(--font);font-size:16px;font-weight:700;color:#fff;background:var(--green);border:none;border-radius:14px;cursor:pointer;box-shadow:0 4px 14px #58cc0240;transition:box-shadow .2s}.story-hook__cta:disabled{opacity:.5;cursor:default}.story-hook__cta:active{box-shadow:0 2px 8px #58cc024d}.fun-fact{position:relative;display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 24px 20px;background:var(--glass-bg, rgba(255, 255, 255, .8));backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:20px;border:1px solid var(--glass-border, rgba(255, 255, 255, .3));text-align:center;cursor:pointer;overflow:hidden;min-height:200px}.fun-fact__timer-bar{position:absolute;top:0;left:0;right:0;height:3px;background:var(--bg-tertiary);overflow:hidden}.fun-fact__timer-fill{width:100%;height:100%;background:linear-gradient(90deg,var(--orange),var(--green));transform-origin:left;will-change:transform}.fun-fact__icon{display:flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:16px;background:color-mix(in srgb,var(--orange) 10%,var(--card-bg));color:var(--orange)}.fun-fact__text{font-family:var(--font-reading);font-size:18px;line-height:1.55;color:var(--text-primary);max-width:340px}.fun-fact__meta{display:flex;align-items:center;gap:8px}.fun-fact__category{font-family:var(--font);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--orange);background:color-mix(in srgb,var(--orange) 10%,var(--card-bg));padding:3px 8px;border-radius:6px}.fun-fact__source{font-family:var(--font);font-size:12px;font-style:italic;color:var(--text-tertiary)}.fun-fact__tap-hint{font-family:var(--font);font-size:12px;color:var(--text-muted);margin-top:4px}.boss-wrapper{position:relative;border:2px solid transparent;border-radius:18px;background-origin:border-box;background-clip:padding-box,border-box;background-image:linear-gradient(var(--card-bg),var(--card-bg)),linear-gradient(135deg,#8b5cf6,#d4a574,#8b5cf6);background-size:100% 100%,200% 200%;animation:boss-gradient-shift 3s ease-in-out infinite;box-shadow:0 0 16px #8b5cf614}@keyframes boss-gradient-shift{0%,to{background-position:0% 0%,0% 50%}50%{background-position:0% 0%,100% 50%}}.boss-wrapper__badge{position:absolute;top:-10px;right:16px;z-index:2;display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-family:var(--font);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#d4a574;background:var(--bg-primary);border:1px solid color-mix(in srgb,#d4a574 30%,transparent);border-radius:8px;box-shadow:0 2px 8px #d4a57426}.feedback-tray{position:fixed;bottom:0;left:0;right:0;padding:15px 24px 24px;padding-bottom:calc(24px + env(safe-area-inset-bottom,0px));border-radius:var(--radius-lg) var(--radius-lg) 0 0;z-index:100;max-width:var(--max-width);margin:0 auto;box-shadow:0 -8px 32px #0000001f;max-height:70vh;overflow-y:auto;will-change:transform}.feedback-tray--minimized{max-height:none;overflow:visible}.feedback-body{overflow:hidden}.feedback-tray.correct{background:var(--tint-correct);border-top:3px solid var(--green)}.feedback-tray.incorrect{background:#fff8e1;border-top:3px solid var(--amber)}.feedback-tray.discovery{background:#fff8e1;border-top:3px solid var(--orange)}[data-theme=dark] .feedback-tray.discovery{background:color-mix(in srgb,var(--orange) 10%,var(--surface-elevated))}[data-theme=dark] .feedback-tray.correct{background:var(--surface-elevated)}[data-theme=dark] .feedback-tray.incorrect{background:color-mix(in srgb,var(--amber) 10%,var(--surface-elevated))}[data-theme=dark] .feedback-collapse-chevron{background:#ffffff14}.feedback-header{display:flex;align-items:center;gap:10px;margin-bottom:10px;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.feedback-header h3{flex:1;min-width:0;font-size:22px;font-weight:600}.feedback-collapse-chevron{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;flex-shrink:0;transition:background .15s}.feedback-tray.correct .feedback-collapse-chevron{color:var(--green-dark);background:color-mix(in srgb,var(--green) 12%,transparent)}.feedback-tray.incorrect .feedback-collapse-chevron{color:#b45309;background:color-mix(in srgb,var(--amber) 12%,transparent)}.feedback-header:hover .feedback-collapse-chevron{background:color-mix(in srgb,currentColor 15%,transparent)}.feedback-header:active .feedback-collapse-chevron{background:color-mix(in srgb,currentColor 22%,transparent);transform:scale(.92)}.feedback-icon{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%}.feedback-tray.correct .feedback-icon{background:color-mix(in srgb,var(--green) 15%,transparent)}.feedback-tray.incorrect .feedback-icon{background:color-mix(in srgb,var(--amber) 15%,transparent)}.feedback-tray.correct .feedback-header h3{color:var(--green-dark)}.feedback-tray.incorrect .feedback-header h3{color:#b45309}.feedback-explanation{font-size:16px;line-height:1.5;margin-bottom:12px;color:var(--text)}.feedback-explanation--hint{font-size:15px;color:#92400e}[data-theme=dark] .feedback-explanation--hint{color:#fbbf24}.feedback-wrong-detail{margin-bottom:8px}.feedback-answer-panel{overflow:hidden}.feedback-answer-summary{font-family:var(--font-reading);margin-bottom:8px;font-size:14px;line-height:1.5;color:var(--text);padding:10px 12px;border-radius:14px;background:color-mix(in srgb,var(--surface) 65%,white);border:1px solid color-mix(in srgb,var(--amber) 18%,var(--border))}.feedback-show-answer-btn{display:inline-flex;align-items:center;gap:5px;background:#b453091a;border:none;color:#92400e;font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;padding:5px 12px;border-radius:16px;margin-bottom:8px;transition:background .15s}.feedback-show-answer-btn:hover{background:#b453092e}[data-theme=dark] .feedback-show-answer-btn{background:#fbbf241f;color:#fbbf24}.evidence-toggle-btn{background:var(--tint-blue);border:none;color:var(--blue-dark);font-size:14px;font-weight:600;cursor:pointer;padding:8px 16px;margin-bottom:8px;font-family:var(--font);border-radius:20px;transition:background .15s;display:inline-flex;align-items:center;gap:6px}.evidence-toggle-btn:hover{background:var(--tint-blue-strong)}.evidence-section-title{font-size:16px;font-weight:600;color:var(--text);margin:0 0 8px}.continue-btn{width:100%;padding:14px;border:none;border-radius:var(--radius);font-size:16px;font-weight:600;cursor:pointer;margin-top:12px;transition:transform .1s,box-shadow .1s,filter .15s;font-family:var(--font);text-transform:uppercase;letter-spacing:.5px;color:#fff}.continue-btn.continue-correct{background:var(--green);box-shadow:0 var(--btn-3d-depth) 0 var(--green-dark)}.continue-btn.continue-incorrect{background:var(--amber);box-shadow:0 var(--btn-3d-depth) 0 #b45309}.continue-btn:hover{filter:brightness(1.06)}.continue-btn:active{transform:translateY(var(--btn-3d-depth));box-shadow:none}.feedback-rewards{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap;will-change:transform}.feedback-rewards--study .first-try-badge,.feedback-rewards--study .xp-badge,.feedback-rewards--study .streak-badge{filter:saturate(.7);box-shadow:none}.first-try-badge{background:color-mix(in srgb,var(--green) 15%,rgba(255,255,255,.85));-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:var(--green-dark);font-size:13px;font-weight:700;padding:6px 14px;border-radius:24px;height:30px;display:inline-flex;align-items:center;gap:4px;border:1.5px solid color-mix(in srgb,var(--green) 35%,transparent);box-shadow:0 2px 8px color-mix(in srgb,var(--green) 25%,transparent);animation:firstTryPulse .6s ease-in-out .3s 1}@keyframes firstTryPulse{0%,to{transform:scale(1)}50%{transform:scale(1.06)}}.xp-badge{background:var(--gradient-gold);color:#5a3800;font-size:13px;font-weight:700;padding:6px 14px;border-radius:24px;height:30px;display:inline-flex;align-items:center;gap:4px;box-shadow:0 2px 8px #ffb3004d}.streak-badge{background:linear-gradient(135deg,#ff6b35,#ff4500);color:#fff;font-size:13px;font-weight:700;padding:6px 14px;border-radius:24px;height:30px;display:inline-flex;align-items:center;gap:2px;box-shadow:0 2px 8px #ff45004d}.streak-badge--hot{box-shadow:0 2px 8px #ff45004d,0 0 16px #ff450033}[data-theme=dark] .first-try-badge{background:color-mix(in srgb,var(--green) 20%,rgba(30,30,30,.85));border-color:color-mix(in srgb,var(--green) 40%,transparent);color:#86efac}[data-theme=dark] .xp-badge{background:linear-gradient(135deg,#ffb30040,#ff8f0040);color:#fcd34d}[data-theme=dark] .streak-badge{background:linear-gradient(135deg,#ff6b354d,#ff45004d);color:#fed7aa}.feedback-community-stat{display:inline-block;padding:4px 10px;font-family:var(--font);font-size:11px;font-weight:600;color:#fff;background:var(--blue);border-radius:8px;margin-top:4px}@media(prefers-reduced-motion:reduce){.first-try-badge{animation:none}}.evidence-view{margin:8px 0;padding:12px;background:var(--tint-neutral);border-radius:var(--radius-sm);max-height:160px;overflow-y:auto}.evidence-item{font-family:var(--font-reading);margin-bottom:8px}.evidence-item:last-child{margin-bottom:0}.evidence-ref{font-size:14px;font-weight:600;color:var(--blue-dark);display:block;margin-bottom:4px}.evidence-ref--clickable{display:inline-flex;align-items:center;gap:4px;background:none;border:none;padding:0;font:inherit;font-size:14px;font-weight:600;color:var(--blue-dark);cursor:pointer;text-decoration:underline;text-decoration-color:rgba(var(--blue-rgb),.3);text-underline-offset:2px;transition:color .15s,text-decoration-color .15s}.evidence-ref--clickable:hover{color:var(--blue);text-decoration-color:var(--blue)}.evidence-item--active{background:var(--tint-blue);border-radius:8px;padding:8px;margin-inline-start:-8px;margin-inline-end:-8px;border-inline-start:3px solid var(--blue)}.evidence-text{font-size:16px;line-height:1.5;color:var(--text);border-inline-start:3px solid var(--blue);padding-inline-start:12px;margin:0}.verse-peek{margin-bottom:8px}.verse-peek__toggle{display:inline-flex;align-items:center;gap:5px;background:var(--tint-blue);border:none;color:var(--blue-dark);font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;padding:5px 12px;border-radius:16px;transition:background .15s}.verse-peek__toggle:hover{background:var(--tint-blue-strong)}.verse-peek__content{overflow-y:auto;padding-top:6px;max-height:160px}.verse-peek__item{margin-bottom:6px}.verse-peek__ref{font-size:12px;font-weight:600;color:var(--blue-dark)}.verse-peek__text{margin:2px 0 0;font-size:13px;line-height:1.5;color:var(--muted);font-style:italic;padding-inline-start:8px;border-inline-start:2px solid var(--border)}.session-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.session-toolbar .help-pill-wrap{margin-bottom:0;align-self:center;min-width:0}.session-toolbar__right{display:flex;align-items:flex-start;gap:6px;flex-shrink:0}.toolbar-btn-wrap{display:flex;flex-direction:column;align-items:center;gap:2px}.toolbar-btn-label{font-size:10px;line-height:1;color:var(--text-light);opacity:.7;white-space:nowrap;pointer-events:none;-webkit-user-select:none;user-select:none}.help-pill-wrap .help-popover{position:absolute;top:calc(100% + 8px);left:0;z-index:100;min-width:280px}.help-pill-wrap .card-category-label{margin-bottom:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}@media(max-width:420px){.session-toolbar{gap:6px}.session-toolbar__right{gap:4px}.help-pill-wrap .card-category-label{padding:4px 10px;font-size:10px;letter-spacing:1px}.passage-btn{min-width:38px;height:38px}}.progress-bar{flex:1;height:12px;background:var(--border);border-radius:8px;overflow:hidden;position:relative;box-shadow:inset 0 1px 3px #00000014}.progress-fill{height:100%;background:var(--gradient-green);border-radius:8px;transition:width .4s ease;min-width:0;position:relative;overflow:hidden;box-shadow:0 1px 3px #4caf5059}.progress-fill:after{content:"";position:absolute;top:0;left:-50%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:progressShimmer 2s ease-in-out infinite}@keyframes progressShimmer{0%{left:-50%}to{left:150%}}.progress-text{display:none}.progress-bar--dots{display:flex;gap:6px;align-items:center;justify-content:center;height:auto;background:none;overflow:visible;box-shadow:none}.progress-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;transition:background .3s ease,box-shadow .3s ease}.progress-dot--pending{background:var(--border)}.progress-dot--active{background:var(--primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 25%,transparent)}.progress-dot--correct{background:var(--green);box-shadow:0 1px 3px #4caf5066}.progress-dot--wrong{background:var(--amber);box-shadow:0 1px 3px #f59e0b66}.progress-dot--learning{background:var(--blue);box-shadow:0 1px 3px rgba(var(--blue-rgb),.4)}.session-main{display:flex;flex-direction:column;flex:1;min-height:0}.session-main.session-split{flex-direction:row;gap:8px;align-items:stretch;overflow:hidden;padding:8px 16px 24px}.session-split .session-body{flex:1;min-width:0;overflow-y:auto;padding:0;border-radius:20px;background:var(--surface, #fff);border:2px solid var(--border, #e2e8f0)}@media(min-width:1024px){.study-session.pinned,.chapter-study.pinned{height:100dvh;max-height:100dvh;overflow:hidden;max-width:none}}.session-split .chapter-study__main{flex:1;min-width:0;overflow-y:auto;padding:16px;border-radius:20px;background:var(--surface, #fff);border:2px solid var(--border, #e2e8f0)}@media(min-width:1024px){.session-split .chapter-study__main{max-width:none;margin:0}}.pinned-passage-panel{background:var(--surface, #fff);border:2px solid var(--border, #e2e8f0);overflow:hidden;display:flex;flex-direction:column;position:relative}.pinned-passage-panel.side{border-radius:20px;flex-shrink:0;z-index:5;min-width:0}.pinned-passage-panel.bottom{position:fixed;bottom:0;left:0;right:0;border-bottom:none;border-radius:16px 16px 0 0;box-shadow:0 -4px 20px #00000014;z-index:15}.passage-btn--active{background:var(--blue-light, #f5faff)!important;color:var(--blue, #2563eb)!important;box-shadow:0 0 0 2px var(--blue, #2563eb)}.pin-btn-sheet{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:none;background:var(--blue-light, #dbeafe);color:var(--blue, #2563eb);cursor:pointer;transition:background .15s}.pin-btn-sheet:hover{background:var(--blue, #2563eb);color:#fff}.pin-btn-active{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:none;background:var(--blue, #2563eb);color:#fff;cursor:pointer;transition:background .15s}.pin-btn-active:hover{background:var(--red, #ef4444)}@media(hover:none){.pin-btn-active:hover{background:var(--blue, #2563eb)}}.resize-handle-v,.resize-handle-h{position:absolute;display:flex;align-items:center;justify-content:center;touch-action:none;z-index:6;-webkit-user-select:none;user-select:none}.resize-handle-v{top:0;left:-16px;width:24px;height:100%;cursor:col-resize}.resize-handle-h{top:-6px;left:0;right:0;height:12px;cursor:row-resize}.resize-handle-pill{border-radius:4px;background:var(--border, #cbd5e1);opacity:.7;transition:opacity .15s,background .15s}.resize-handle-v .resize-handle-pill{width:6px;height:48px}.resize-handle-h .resize-handle-pill{width:48px;height:6px}.resize-handle-v:hover .resize-handle-pill,.resize-handle-h:hover .resize-handle-pill{opacity:1;background:var(--blue, #2563eb)}.resize-handle-pill.snapped{opacity:1;background:var(--green, #22c55e);transform:scale(1.3);transition:opacity .1s,background .1s,transform .1s}@keyframes resize-pulse{0%,to{opacity:.7}50%{opacity:1}}.resize-handle-pill{animation:resize-pulse 1.5s ease-in-out .4s 2}@media(min-width:767px){.session-split .session-body{padding:15px 20px}.session-split .card-container{box-shadow:none;padding:0}}.session-split .feedback-tray{max-width:none;margin-inline:0}.walkthrough-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-overlay)}.walkthrough-spotlight{position:fixed;border-radius:var(--radius-sm);box-shadow:0 0 0 9999px #0009;pointer-events:none;z-index:calc(var(--z-overlay) + 1)}.walkthrough-tooltip{position:fixed;z-index:calc(var(--z-overlay) + 2);background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);padding:16px 18px 14px;width:min(320px,calc(100vw - 24px));overflow:visible;box-shadow:0 6px 24px #0000002e}.walkthrough-tooltip-inner{max-height:var(--walkthrough-max-height, none);overflow-x:visible;overflow-y:auto;scrollbar-gutter:stable}.walkthrough-tooltip--bottom:before{content:"";position:absolute;top:-7px;left:var(--walkthrough-arrow-x, 20px);width:12px;height:12px;background:var(--bg);border-top:1.5px solid var(--border);border-left:1.5px solid var(--border);transform:translate(-50%) rotate(45deg)}.walkthrough-tooltip--top:after{content:"";position:absolute;bottom:-7px;left:var(--walkthrough-arrow-x, 20px);width:12px;height:12px;background:var(--bg);border-bottom:1.5px solid var(--border);border-right:1.5px solid var(--border);transform:translate(-50%) rotate(45deg)}.walkthrough-title{font-size:1rem;font-weight:600;color:var(--text);margin:0 0 4px}.walkthrough-body{font-size:.95rem;font-weight:300;color:var(--text-dim);margin:0 0 14px;line-height:1.45}.walkthrough-footer{display:flex;align-items:center;justify-content:space-between;gap:12px}.walkthrough-dots{display:flex;gap:5px}.walkthrough-dot{width:7px;height:7px;border-radius:50%;background:var(--border);transition:background .15s}.walkthrough-dot--active{background:var(--blue)}.walkthrough-actions{display:flex;align-items:center;gap:10px}.walkthrough-skip{background:none;border:none;color:var(--text-dim);font-size:.82rem;font-weight:600;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:color .15s}.walkthrough-skip:hover{color:var(--text)}.walkthrough-btn{background:var(--green);color:#fff;border:none;font-size:.85rem;font-weight:600;padding:8px 18px;border-radius:var(--radius-sm);cursor:pointer;transition:opacity .15s}.walkthrough-btn:hover{background:var(--green-dark)}.walkthrough-btn:focus-visible,.walkthrough-skip:focus-visible{outline:2px solid var(--blue);outline-offset:2px}@media(prefers-reduced-motion:reduce){.walkthrough-spotlight,.walkthrough-tooltip{transition:none!important}}.reward-burst{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:110;display:flex;align-items:center;justify-content:center}.reward-burst__vignette{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at center,rgba(0,0,0,.18) 0%,rgba(0,0,0,.06) 40%,transparent 70%)}[data-theme=dark] .reward-burst__vignette{background:radial-gradient(circle at center,rgba(0,0,0,.35) 0%,rgba(0,0,0,.12) 40%,transparent 70%)}.reward-burst__sparkles{position:absolute;width:60px;height:60px}.reward-burst__spark{position:absolute;left:50%;top:50%;color:var(--amber);transform:translate(-50%,-50%) rotate(var(--spark-angle)) translateY(-24px);filter:drop-shadow(0 0 4px rgba(245,158,11,.6))}.reward-burst__stack{display:flex;flex-direction:column;align-items:center;gap:10px;z-index:1}.reward-burst__pill{display:flex;align-items:center;gap:8px;padding:10px 24px;border-radius:50px;font-weight:800;font-size:20px;letter-spacing:-.01em;text-transform:uppercase;line-height:1;color:#fff;will-change:transform}.reward-burst__pill--first-try{font-size:24px;padding:12px 28px;background:linear-gradient(135deg,#58cc02,#46a302);box-shadow:0 4px 16px #58cc0266,0 2px 4px #0000001a,inset 0 1px #ffffff40}.reward-burst__pill--first-try svg{color:#ffe066;filter:drop-shadow(0 1px 3px rgba(0,0,0,.2))}.reward-burst__pill--xp{background:linear-gradient(135deg,#ffb300,#ff8f00);box-shadow:0 4px 16px #ffb30066,0 2px 4px #0000001a,inset 0 1px #ffffff40}.reward-burst__pill--xp svg{color:#fff3cd;filter:drop-shadow(0 1px 3px rgba(0,0,0,.15))}.reward-burst__pill--streak{background:linear-gradient(135deg,#ff6b35,#e84300);box-shadow:0 4px 12px #ff450059,0 2px 4px #0000001a,inset 0 1px #fff3}.reward-burst__pill--streak svg{color:#ffe0b2;filter:drop-shadow(0 1px 3px rgba(0,0,0,.15))}.reward-burst__pill--hot{font-size:22px;padding:12px 26px;background:linear-gradient(135deg,#ff4500,#c20);box-shadow:0 4px 20px #ff450080,0 0 30px #ff450033,0 2px 4px #0000001a,inset 0 1px #fff3}.reward-burst__pill--hot svg{animation:fireFlicker .4s ease-in-out infinite alternate}@keyframes fireFlicker{0%{transform:scale(1) rotate(-4deg)}to{transform:scale(1.15) rotate(4deg)}}@media(prefers-reduced-motion:reduce){.reward-burst__sparkles,.reward-burst__vignette{display:none}.reward-burst__pill--hot svg{animation:none}}.combo-meter{position:relative;display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:14px;font-weight:600;line-height:1;-webkit-user-select:none;user-select:none}.combo-meter--warming{background:color-mix(in srgb,var(--amber) 15%,transparent);color:var(--amber)}.combo-meter--hot{background:linear-gradient(135deg,#ff6b352e,#ff45002e);color:#ff4500}.combo-meter--fire{background:linear-gradient(135deg,#ff450038,#dc262638);color:#dc2626;filter:drop-shadow(0 0 6px rgba(255,69,0,.3))}.combo-meter__icon{display:inline-flex}.combo-meter__count{min-width:14px;text-align:center}.combo-meter__unlock{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:4px;padding:3px 10px;font-family:var(--font);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;color:#fff;background:var(--orange);border-radius:8px;box-shadow:0 2px 8px #ff96004d}.round-transition{width:100%}.finish-screen{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;padding-top:calc(24px + var(--ion-safe-area-top, env(safe-area-inset-top, 0px)));background:radial-gradient(ellipse at 50% 20%,color-mix(in srgb,var(--blue) 8%,transparent) 0%,transparent 60%),radial-gradient(ellipse at 80% 80%,color-mix(in srgb,var(--green) 5%,transparent) 0%,transparent 50%);animation:finishBgShift 8s ease-in-out infinite alternate}.finish-screen--study{background:radial-gradient(ellipse at 50% 16%,color-mix(in srgb,var(--blue) 5%,transparent) 0%,transparent 56%),radial-gradient(ellipse at 82% 82%,color-mix(in srgb,var(--green) 4%,transparent) 0%,transparent 48%)}@keyframes finishBgShift{0%{background-position:50% 20%,80% 80%}to{background-position:40% 25%,70% 75%}}.finish-content{max-width:var(--max-width);width:100%;text-align:center}.finish-icon{display:inline-flex;align-items:center;justify-content:center;width:96px;height:96px;border-radius:50%;background:var(--gradient-gold);margin-bottom:20px;box-shadow:0 8px 32px #ffb30059,0 0 60px #ffb3001f;animation:iconPulse 3s ease-in-out 2.5s infinite}.finish-screen--study .finish-icon{background:linear-gradient(135deg,#2d6cb8,#1b9a90);box-shadow:0 8px 24px #2d6cb82e,0 0 32px #1b9a9014}@keyframes iconPulse{0%,to{box-shadow:0 8px 32px #ffb30059,0 0 60px #ffb3001f}50%{box-shadow:0 8px 36px #ffb30073,0 0 80px #ffb3002e}}.finish-content h1{font-size:28px;font-weight:600;margin-bottom:20px;line-height:1.3}.finish-stars{display:flex;justify-content:center;gap:12px;margin-bottom:20px}.finish-star{display:inline-flex;filter:drop-shadow(0 3px 8px rgba(255,179,0,.5))}.finish-ring-container{position:relative;display:inline-flex;align-items:center;justify-content:center;margin-bottom:16px}.finish-ring{display:block}.finish-ring circle{transition:stroke .3s}.finish-ring__inner{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.finish-ring__value{font-size:38px;font-weight:600;line-height:1;color:var(--text)}.finish-ring__label{font-size:12px;color:var(--text-light);font-weight:600;text-transform:uppercase;letter-spacing:.6px;margin-top:4px}.finish-new-best{position:absolute;top:-8px;right:-12px;background:var(--gradient-gold);color:#fff;font-size:11px;font-weight:600;padding:3px 10px;border-radius:100px;letter-spacing:.3px;box-shadow:0 2px 8px #ffb30059;z-index:1}.finish-screen--study .finish-new-best{background:linear-gradient(135deg,#2d6cb8,#1b9a90);box-shadow:0 2px 8px #2d6cb82e}.finish-badges{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;margin-bottom:12px}.finish-xp-badge{display:inline-flex;align-items:center;background:var(--gradient-gold);color:#fff;font-size:14px;font-weight:600;padding:6px 16px;border-radius:100px;letter-spacing:.3px;box-shadow:0 3px 12px #ffb3004d}.finish-streak-badge{display:inline-flex;align-items:center;gap:5px;background:var(--surface);border:1px solid var(--glass-border);color:var(--text);font-size:13px;font-weight:600;padding:5px 14px;border-radius:100px;box-shadow:var(--shadow-card)}.finish-stats{display:flex;flex-direction:column;gap:6px;margin-top:4px;margin-bottom:8px}.finish-stat-line{font-size:13px;color:var(--text-light);font-weight:600;display:inline-flex;align-items:center;gap:6px;justify-content:center}.finish-sections{width:100%;max-width:400px;margin:12px auto 0;display:flex;flex-direction:column;gap:8px}.finish-sections__title{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-light);margin:0 0 4px}.finish-section-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg-card, var(--surface));border-radius:var(--radius);border:1px solid var(--border);border-inline-start:3px solid var(--blue)}.finish-section-row__info{display:flex;flex-direction:column;gap:2px;flex:1;text-align:left;min-width:0}.finish-section-row__title{font-size:.85rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;margin-bottom:5px;text-overflow:ellipsis}.finish-section-row__range{font-size:.75rem;color:var(--text-light)}.finish-section-row__score{font-size:.9rem;font-weight:600;flex-shrink:0;margin-inline-start:12px}.finish-section-row__score--great{color:var(--green)}.finish-section-row__score--ok{color:var(--orange)}.finish-section-row__score--low{color:var(--red)}.finish-actions{display:flex;flex-direction:column;gap:30px;margin-top:20px}.finish-tertiary-row{display:flex;gap:12px;justify-content:center}.start-btn.start-btn--next{background:var(--green);box-shadow:0 var(--btn-3d-depth) 0 var(--green-dark);display:flex;align-items:center;justify-content:center;gap:8px}.start-btn.start-btn--retry{background:var(--blue);box-shadow:0 var(--btn-3d-depth) 0 var(--blue-dark)}.start-btn.start-btn--tertiary{background:transparent;color:var(--text-light);box-shadow:none;border:1.5px solid var(--border);display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:.85rem;padding:10px 20px;flex:1;max-width:180px}.start-btn.start-btn--tertiary:active{background:var(--tint-neutral)}.finish-teaser{width:100%;max-width:360px;margin:8px auto 0;padding-top:12px;border-top:1px solid var(--border-color);text-align:center}.finish-teaser__label{display:block;font-family:var(--font);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);margin-bottom:4px}.finish-teaser__text{font-family:var(--font-reading);font-size:15px;font-style:italic;line-height:1.5;color:var(--text-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.cookie-policy{max-width:680px;margin:0 auto;padding:20px 20px 60px}.cookie-policy__header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.cookie-policy__back{background:none;border:1.5px solid var(--border, #e5e7eb);border-radius:10px;padding:6px 14px;font-size:14px;font-weight:600;color:var(--text, #333);cursor:pointer;transition:background .15s}.cookie-policy__back:hover{background:var(--surface, #f7f7f7)}.cookie-policy__title{font-size:24px;font-weight:600;color:var(--text, #333);margin:0}.cookie-policy__updated{font-size:13px;color:var(--text-light, #6b7280);margin-bottom:24px}.cookie-policy__body h2{font-size:17px;font-weight:600;color:var(--text, #333);margin:28px 0 8px}.cookie-policy__body p,.cookie-policy__body li{font-size:14px;line-height:1.6;color:var(--text-light, #555);margin:0 0 10px}.cookie-policy__body ul{padding-inline-start:20px;margin:8px 0 16px}.cookie-policy__body a{color:var(--blue, #1cb0f6);text-decoration:underline}.cookie-policy__body code{background:var(--surface, #f0f0f0);padding:1px 5px;border-radius:4px;font-size:13px}.cookie-policy__table{width:100%;border-collapse:collapse;margin:12px 0 20px;font-size:13px}.cookie-policy__table th{text-align:start;padding:8px 10px;background:var(--surface, #f7f7f7);border-bottom:2px solid var(--border, #e5e7eb);font-weight:600;color:var(--text, #333)}.cookie-policy__table td{padding:8px 10px;border-bottom:1px solid var(--border, #e5e7eb);color:var(--text-light, #555)}.cookie-policy__actions{display:flex;gap:10px;margin-top:12px}[data-theme=dark] .cookie-policy__back{border-color:var(--border, #444)}[data-theme=dark] .cookie-policy__body code{background:var(--surface-elevated, #2a2a3e)}.login-ion-content{--background: linear-gradient(320deg, rgba(24, 144, 255, .11) 0%, transparent 30%), linear-gradient(40deg, rgba(88, 204, 2, .08) 4%, transparent 34%), linear-gradient(0deg, rgba(255, 255, 255, .52) 0%, rgba(255, 255, 255, 0) 28%), linear-gradient(0deg, #f4fbff 0%, #f8fcff 42%, #fefbf6 100%)}[data-theme=sepia] .login-ion-content{--background: linear-gradient(325deg, rgba(181, 132, 78, .14) 0%, transparent 32%), linear-gradient(45deg, rgba(235, 193, 120, .11) 8%, transparent 38%), linear-gradient(0deg, rgba(255, 248, 238, .4) 0%, rgba(255, 248, 238, 0) 26%), linear-gradient(0deg, #faf4e8 0%, #f6ede0 44%, #ede1cf 100%)}[data-theme=gray] .login-ion-content{--background: linear-gradient(320deg, rgba(91, 130, 168, .12) 0%, transparent 30%), linear-gradient(40deg, rgba(176, 184, 198, .16) 10%, transparent 40%), linear-gradient(0deg, rgba(255, 255, 255, .34) 0%, rgba(255, 255, 255, 0) 24%), linear-gradient(0deg, #f7f8fc 0%, #eef1f6 44%, #e5e9f1 100%)}[data-theme=dark] .login-ion-content{--background: linear-gradient(145deg, rgba(28, 176, 246, .08) 0%, transparent 26%), linear-gradient(225deg, rgba(88, 204, 2, .048) 6%, transparent 30%), linear-gradient(180deg, rgba(255, 255, 255, .018) 0%, rgba(255, 255, 255, 0) 18%), linear-gradient( 180deg, rgba(7, 9, 16, .985) 0%, rgba(10, 12, 21, .97) 28%, rgba(14, 14, 26, .94) 66%, rgba(14, 14, 26, .94) 100% )}.login-page{display:flex;align-items:center;justify-content:center;min-height:100%;padding:24px 16px;padding-top:calc(24px + var(--ion-safe-area-top, env(safe-area-inset-top, 0px)));position:relative}.login-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:70px 40px;position:relative;z-index:1}.login-card--intro{text-align:center}.login-title{font-size:28px;font-weight:600;color:var(--text);margin:0 0 4px}.login-subtitle{font-size:14px;color:var(--text-light);margin:0 0 28px}.login-heading{font-size:22px;font-weight:600;color:var(--text);margin:0 0 20px;text-align:center}.login-back{position:absolute;top:16px;left:16px;background:none;border:none;color:var(--text-light);cursor:pointer;padding:4px;border-radius:50%;display:flex}.login-back:hover{color:var(--text);background:var(--tint-neutral)}.login-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:14px;border:none;border-radius:var(--radius-sm);font-family:var(--font);font-size:15px;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s;margin-bottom:10px}.login-btn:active{transform:scale(.98)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-btn--google{background:#fff;color:#3c4043;border:1px solid var(--border)}[data-theme=dark] .login-btn--google{background:#2d2d3a;color:#e8eaed;border-color:#444}.login-btn--email{background:var(--tint-blue);color:var(--blue-dark)}.login-btn--register{background:var(--tint-green);color:var(--green-dark)}.login-btn--primary{background:var(--green);color:#fff}.login-btn--primary:hover:not(:disabled){background:var(--green-dark)}.login-divider{display:flex;align-items:center;gap:12px;margin:16px 0;color:var(--text-light);font-size:13px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border)}.login-field{display:flex;align-items:center;gap:10px;background:var(--tint-neutral);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:10px;color:var(--text-light);transition:border-color .15s}.login-field:focus-within{border-color:var(--blue)}.login-field input{flex:1;border:none;background:transparent;font-family:var(--font);font-size:15px;color:var(--text);outline:none;min-width:0}.login-field input::placeholder{color:var(--text-light)}.login-eye{background:none;border:none;color:var(--text-light);cursor:pointer;padding:2px;display:flex}.login-error{color:var(--red);font-size:13px;font-weight:600;text-align:center;margin:8px 0}.login-success{color:var(--green-dark);font-size:14px;font-weight:600;text-align:center;margin:12px 0}.login-link{background:none;border:none;color:var(--blue);font-family:var(--font);font-size:14px;font-weight:600;cursor:pointer;padding:0}.login-link:hover{text-decoration:underline}.login-footer{text-align:center;font-size:14px;color:var(--text-light);margin-top:16px}.profile-dropdown__profiles{padding:10px 8px 4px;border-bottom:1px solid var(--border)}.profile-dropdown__section-title{display:block;padding:0 8px 8px;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-light)}.profile-dropdown__profile-list{display:flex;flex-direction:column;gap:4px}.profile-dropdown__profile-btn{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;border:1px solid transparent;border-radius:12px;background:transparent;color:var(--text);cursor:pointer;transition:transform .12s ease,background .18s ease,border-color .18s ease}.profile-dropdown__profile-btn:hover{background:color-mix(in srgb,var(--blue) 10%,transparent);border-color:color-mix(in srgb,var(--blue) 24%,transparent);transform:translateY(-1px)}.profile-dropdown__profile-btn.is-active{background:color-mix(in srgb,var(--green) 14%,transparent);border-color:color-mix(in srgb,var(--green) 28%,transparent)}.profile-dropdown__profile-copy{display:flex;flex-direction:column;align-items:flex-start;gap:2px;min-width:0}.profile-dropdown__profile-copy span{font-size:12px;color:var(--text-light)}.profile-dropdown__profile-shield{margin-inline-start:auto;color:var(--blue)}.onboarding-page{position:relative;min-height:100%;display:flex;flex-direction:column;justify-content:center;padding:16px 16px 48px;padding-top:calc(8px + var(--ion-safe-area-top, env(safe-area-inset-top, 0px)));background:var(--bg)}.onboarding-page[data-step=welcome] .onboarding-backdrop--one{background:var(--tint-blue);width:420px;height:420px;top:-100px;right:-120px;filter:blur(60px);opacity:.7;animation:welcomeBackdropDrift 12s ease-in-out infinite alternate}.onboarding-page[data-step=welcome] .onboarding-backdrop--two{background:var(--tint-green);width:460px;height:460px;bottom:-80px;left:-120px;filter:blur(60px);opacity:.6;animation:welcomeBackdropDrift 15s ease-in-out 2s infinite alternate-reverse}.onboarding-page[data-step=welcome] .onboarding-backdrop--three{background:var(--tint-orange);width:300px;height:300px;top:40%;right:10%;filter:blur(50px);opacity:.35;animation:welcomeBackdropDrift 18s ease-in-out 4s infinite alternate}@keyframes welcomeBackdropDrift{0%{transform:translate(0) scale(1)}50%{transform:translate(15px,-10px) scale(1.05)}to{transform:translate(-10px,15px) scale(.98)}}.onboarding-page[data-step=goal] .onboarding-backdrop--one{background:var(--tint-green)}.onboarding-page[data-step=knowledge] .onboarding-backdrop--one{background:var(--tint-blue)}.onboarding-page[data-step=focus] .onboarding-backdrop--one{background:color-mix(in srgb,var(--tint-green) 60%,var(--tint-blue))}.onboarding-page[data-step=bible-study-method] .onboarding-backdrop--one{background:color-mix(in srgb,var(--tint-orange) 45%,var(--tint-blue))}.onboarding-page[data-step=bible-study-method] .onboarding-backdrop--two{background:var(--tint-green);opacity:.25}.onboarding-page[data-step=learn-modes] .onboarding-backdrop--one{background:color-mix(in srgb,var(--tint-orange) 50%,var(--tint-blue))}.onboarding-page[data-step=learn-modes] .onboarding-backdrop--two{background:var(--tint-green);opacity:.3}.onboarding-page[data-step=session] .onboarding-backdrop--one{background:var(--tint-neutral)}.onboarding-page[data-step=notifications] .onboarding-backdrop--one{background:color-mix(in srgb,var(--tint-blue) 55%,var(--tint-purple, color-mix(in srgb, #a855f7 12%, transparent)));opacity:.6}.onboarding-page[data-step=notifications] .onboarding-backdrop--two{background:color-mix(in srgb,var(--tint-purple, color-mix(in srgb, #a855f7 12%, transparent)) 60%,var(--tint-blue));opacity:.35}.onboarding-page[data-step=launch] .onboarding-backdrop--one{background:var(--tint-green);opacity:.6}.onboarding-page[data-step=launch] .onboarding-backdrop--two{background:var(--tint-blue);opacity:.4}.onboarding-backdrop{position:absolute;border-radius:999px;filter:blur(28px);opacity:.8;pointer-events:none}.onboarding-backdrop--one{top:-30px;right:-40px;width:180px;height:180px;background:var(--tint-blue)}.onboarding-backdrop--two{bottom:24px;left:-40px;width:220px;height:220px;background:var(--tint-green)}.onboarding-backdrop--three{top:50%;right:20%;width:0;height:0;background:transparent;opacity:0}.onboarding-shell{position:relative;z-index:1;width:100%;max-width:980px;margin:0 auto}@media(max-width:767px){.onboarding-shell{width:100%}.onboarding-page{padding:12px 12px 48px;padding-top:calc(8px + var(--ion-safe-area-top, env(safe-area-inset-top, 0px)))}}.onboarding-topbar{display:flex;align-items:center;gap:18px;justify-content:space-between;margin-bottom:18px}.onboarding-topbar__left{display:flex;align-items:center;gap:8px}.onboarding-nav-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border:1px solid var(--border);border-radius:999px;background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:var(--text);font-weight:600;cursor:pointer}.onboarding-progress{min-width:min(360px,100%);display:flex;flex-direction:column;gap:8px;align-items:flex-end}.onboarding-progress span{font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-light)}.onboarding-progress__bar{width:min(360px,100%);height:10px;padding:2px;border-radius:999px;background:var(--border)}.onboarding-progress__fill{height:100%;border-radius:inherit;background:var(--gradient-green);box-shadow:0 1px 3px #58cc0259;position:relative;overflow:hidden;transition:width .4s ease}.onboarding-progress__fill:after{content:"";position:absolute;top:0;left:-50%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.28),transparent);animation:progressShimmer 2s ease-in-out infinite}.onboarding-card{position:relative;padding:clamp(24px,4vw,40px);border-radius:var(--radius-lg);border:1px solid color-mix(in srgb,var(--border) 50%,transparent);background:color-mix(in srgb,var(--surface) 75%,transparent);backdrop-filter:blur(24px) saturate(1.4);-webkit-backdrop-filter:blur(24px) saturate(1.4);box-shadow:0 8px 48px #0000000f,0 0 0 1px #ffffff26,inset 0 1px #ffffff40;overflow:visible}[data-theme=dark] .onboarding-card{background:color-mix(in srgb,var(--surface) 60%,transparent);box-shadow:0 8px 48px #0000004d,0 0 0 1px #ffffff0f,inset 0 1px #ffffff0f}@media(max-width:767px){.onboarding-card{padding-top:40px}}.onboarding-step{display:flex;flex-direction:column;gap:24px}.onboarding-hero h1,.onboarding-step__header h2{margin:0 0 15px;font-size:30px;line-height:1.02;letter-spacing:-.04em;color:var(--text)}.onboarding-hero p,.onboarding-step__header p{margin:0;max-width:720px;font-size:16px;line-height:1.6;color:var(--text-light)}.onboarding-badge,.onboarding-kicker{display:inline-flex;width:fit-content;padding:6px 12px;border-radius:999px;background:var(--tint-neutral);color:var(--text-light);font-size:11px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;margin-bottom:10px}.onboarding-highlight-grid,.onboarding-choice-grid,.onboarding-style-grid{margin-top:20px;display:grid;gap:14px}.onboarding-highlight-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.onboarding-highlight-card,.onboarding-choice-card,.onboarding-style-card,.onboarding-child-card,.onboarding-toggle-card{border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-card)}.onboarding-highlight-card{display:flex;align-items:center;gap:12px;padding:18px;font-weight:600;color:var(--text)}.onboarding-choice-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.onboarding-choice-card,.onboarding-style-card,.onboarding-toggle-card,.onboarding-primary-btn,.onboarding-add-btn,.onboarding-icon-btn{transition:transform .14s ease,box-shadow .18s ease,border-color .18s ease,background .18s ease}.onboarding-choice-card,.onboarding-style-card,.onboarding-toggle-card{display:flex;align-items:flex-start;gap:14px;width:100%;padding:22px;background:var(--surface);cursor:pointer;text-align:start}.onboarding-choice-card:hover,.onboarding-style-card:hover,.onboarding-toggle-card:hover,.onboarding-primary-btn:hover,.onboarding-add-btn:hover,.onboarding-icon-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-card-hover)}.onboarding-choice-card strong,.onboarding-style-card strong,.onboarding-child-card strong{display:block;margin-bottom:4px;font-size:17px;color:var(--text)}.onboarding-choice-card span,.onboarding-style-card span{font-size:14px;line-height:1.45;color:var(--text-light)}.onboarding-style-card__body{flex:1;min-width:0}.onboarding-style-card__check{flex-shrink:0;align-self:center;color:var(--green);visibility:hidden;opacity:0;transition:opacity .18s ease,visibility .18s ease}.onboarding-style-card__check.is-visible{visibility:visible;opacity:1}.onboarding-choice-card.is-selected,.onboarding-style-card.is-selected,.onboarding-toggle-card.is-on{border-color:var(--green);background:var(--tint-green);box-shadow:0 0 0 1.5px var(--green),var(--shadow-card)}.onboarding-choice-card.is-maxed{opacity:.45;pointer-events:none}.onboarding-focus-card.is-maxed{opacity:.4;pointer-events:none;filter:grayscale(.3)}.onboarding-choice-hint{font-size:13px;color:var(--text-light);text-align:center;margin:0 0 4px}.onboarding-toggle-card{align-items:center}.onboarding-toggle-card strong{display:block;margin-bottom:3px;font-size:17px;font-weight:600;color:var(--text)}.onboarding-toggle-card>div>span{font-size:15px;line-height:1.45;color:var(--text-light)}.onboarding-choice-card__icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:52px;height:52px;border-radius:var(--radius-sm);background:var(--tint-orange, color-mix(in srgb, #f59e0b 12%, transparent));color:var(--orange-dark, #b45309);transition:background .18s ease,color .18s ease}.onboarding-choice-card.is-selected .onboarding-choice-card__icon{background:var(--tint-orange, color-mix(in srgb, #f59e0b 18%, transparent));color:var(--orange-dark, #b45309)}.onboarding-choice-card__body{flex:1;min-width:0}.onboarding-choice-card__check{flex-shrink:0;align-self:center;color:var(--green);visibility:hidden;opacity:0;transition:opacity .18s ease,visibility .18s ease}.onboarding-choice-card__check.is-visible{visibility:visible;opacity:1}.onboarding-field{display:flex;flex-direction:column;gap:10px}.onboarding-field>span{font-size:13px;font-weight:600;color:var(--text)}.onboarding-input-wrap,.onboarding-field input{width:100%;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text)}.onboarding-input-wrap{display:flex;align-items:center;gap:10px;padding:0 16px}.onboarding-input-wrap input,.onboarding-field input{padding:15px 16px;font:inherit;border:none;background:transparent;outline:none}.onboarding-child-list{display:grid;gap:14px}.onboarding-child-card{padding:18px}.onboarding-child-card__header{display:flex;align-items:center;justify-content:space-between;gap:12px}.onboarding-child-card__grid,.onboarding-passcode-grid{display:grid;gap:14px}.onboarding-passcode-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-items:end}.onboarding-info-note{display:flex;align-items:flex-start;gap:8px;padding:12px 14px;border-radius:10px;background:var(--accent-muted, rgba(var(--ion-color-primary-rgb, 56, 128, 255), .08));color:var(--text-secondary, #666);font-size:.85rem;line-height:1.45}.onboarding-info-note svg{flex-shrink:0;margin-top:1px;color:var(--ion-color-primary, #3880ff)}.onboarding-primary-btn,.onboarding-add-btn,.onboarding-icon-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;font:inherit}.onboarding-primary-btn{padding:14px 18px;border-radius:var(--radius);background:var(--gradient-green);color:#fff;font-weight:600;box-shadow:0 var(--btn-3d-depth) 0 var(--green-dark)}.onboarding-primary-btn:hover{transform:translateY(-2px);box-shadow:0 6px 0 var(--green-dark)}.onboarding-primary-btn:active{transform:translateY(2px);box-shadow:0 2px 0 var(--green-dark)}.onboarding-primary-btn{min-width:180px}.onboarding-add-btn{width:fit-content;padding:12px 16px;border-radius:var(--radius-sm);background:var(--tint-green);color:var(--green-dark);font-weight:600}.onboarding-icon-btn{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--tint-red);color:var(--red)}.onboarding-actions{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:28px;padding-top:20px;border-top:1px solid var(--border)}.onboarding-skip-btn{padding:10px 18px;border:none;border-radius:var(--radius);background:transparent;color:var(--text-light);font-family:inherit;font-weight:600;font-size:.85rem;cursor:pointer;transition:color .15s}.onboarding-skip-btn:hover{color:var(--text)}.onboarding-back-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 18px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font:inherit;font-weight:600;cursor:pointer;transition:transform .14s ease,box-shadow .18s ease,background .18s ease}.onboarding-back-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-card-hover)}.onboarding-actions__meta{font-size:13px;font-weight:600;color:var(--text-light)}.onboarding-error{margin:14px 0 0;padding:12px 14px;border-radius:var(--radius-sm);background:var(--tint-red);color:var(--red-dark);font-size:13px;font-weight:600}.onboarding-hero__logo{max-width:220px;margin:0 auto 16px}.onboarding-hero__icon-circle{display:flex;align-items:center;justify-content:center;width:72px;height:72px;margin:0 auto 16px;border-radius:999px;background:var(--tint-green);color:var(--green-dark)}.onboarding-hero__icon-circle--large{width:88px;height:88px}.onboarding-hero__icon{margin-bottom:8px}.onboarding-pill-row{display:flex;gap:10px;flex-wrap:wrap}.onboarding-pill{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1 1 0;min-width:150px;padding:18px 14px;border:1.5px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-card),0 var(--btn-3d-depth) 0 -1px var(--border);cursor:pointer;text-align:center;font:inherit;color:var(--text);transition:transform .18s ease,box-shadow .22s ease,border-color .22s ease,background .22s ease;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.onboarding-pill:hover{transform:translateY(-3px);box-shadow:var(--shadow-card-hover),0 calc(var(--btn-3d-depth) + 2px) 0 -1px var(--border)}.onboarding-pill:active{box-shadow:var(--shadow-card),0 1px 0 0 var(--border)}.onboarding-pill.is-selected{border-color:var(--green);background:var(--tint-green);box-shadow:0 0 0 1.5px var(--green),0 var(--btn-3d-depth) 0 -1px var(--green-dark),0 4px 18px color-mix(in srgb,var(--green) 18%,transparent)}.onboarding-pill:focus-visible{outline:2px solid var(--blue);outline-offset:3px}.onboarding-pill strong{font-size:17px;font-weight:700}.onboarding-pill span{font-size:14px;color:var(--text-light)}.onboarding-pill--compact{padding:14px 12px}.onboarding-diagnostic-cta{display:flex;align-items:center;gap:14px;width:100%;padding:18px 20px;border:1.5px solid color-mix(in srgb,var(--blue) 36%,transparent);border-radius:var(--radius-lg);background:linear-gradient(135deg,color-mix(in srgb,var(--blue) 8%,transparent),color-mix(in srgb,var(--blue) 14%,transparent));cursor:pointer;text-align:start;font:inherit;color:var(--text);box-shadow:0 2px 8px color-mix(in srgb,var(--blue) 12%,transparent),inset 0 1px #ffffff14;transition:transform .14s ease,background .18s ease,border-color .18s ease,box-shadow .18s ease}.onboarding-diagnostic-cta:hover{transform:translateY(-2px);border-color:var(--blue);background:linear-gradient(135deg,color-mix(in srgb,var(--blue) 12%,transparent),color-mix(in srgb,var(--blue) 20%,transparent));box-shadow:0 4px 16px color-mix(in srgb,var(--blue) 18%,transparent),inset 0 1px #ffffff1f}.onboarding-diagnostic-cta__icon-wrap{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:40px;height:40px;border-radius:12px;background:var(--blue);color:#fff;box-shadow:0 2px 6px color-mix(in srgb,var(--blue) 40%,transparent)}.onboarding-diagnostic-cta__body{flex:1;min-width:0}.onboarding-diagnostic-cta__body strong{display:block;margin-bottom:2px;font-size:15px;color:var(--text)}.onboarding-diagnostic-cta__body span{font-size:13px;color:var(--text-light)}.onboarding-diagnostic-cta__arrow{flex-shrink:0;color:var(--blue);opacity:.7;transition:opacity .18s ease}.onboarding-diagnostic-cta:hover .onboarding-diagnostic-cta__arrow{opacity:1}.onboarding-diagnostic{overflow:hidden;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--surface)}.onboarding-diagnostic__inner{padding:20px}.onboarding-diagnostic__progress{display:flex;gap:6px;justify-content:center;margin-bottom:16px}.onboarding-diagnostic__dot{width:10px;height:10px;border-radius:999px;background:var(--border);transition:background .2s ease}.onboarding-diagnostic__dot.is-active{background:var(--blue)}.onboarding-diagnostic__dot.is-done{background:var(--green)}.onboarding-diagnostic-done{display:flex;align-items:center;gap:8px;padding:14px 18px;border-radius:var(--radius-lg);background:var(--tint-green);font-weight:600;color:var(--green-dark)}.onboarding-focus-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:20px}.onboarding-focus-card{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;padding:28px 18px 22px;border-radius:var(--radius-lg);border:1.5px solid var(--border);background:var(--surface);cursor:pointer;font:inherit;color:var(--text);box-shadow:var(--shadow-card),0 var(--btn-3d-depth) 0 -1px var(--border);transition:transform .18s ease,box-shadow .22s ease,border-color .22s ease,background .22s ease;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.onboarding-focus-card[data-color=orange]{--fc-accent: var(--orange, #ff9600);--fc-accent-dark: var(--orange-dark, #b45309);--fc-tint: var(--tint-orange)}.onboarding-focus-card[data-color=purple]{--fc-accent: var(--purple, #a855f7);--fc-accent-dark: var(--purple-dark, #7e22ce);--fc-tint: var(--tint-purple, color-mix(in srgb, #a855f7 12%, transparent))}.onboarding-focus-card[data-color=blue]{--fc-accent: var(--blue, #1cb0f6);--fc-accent-dark: var(--blue-dark, #1480b6);--fc-tint: var(--tint-blue)}.onboarding-focus-card[data-color=green]{--fc-accent: var(--green, #58cc02);--fc-accent-dark: var(--green-dark, #46a302);--fc-tint: var(--tint-green)}.onboarding-focus-card__icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:64px;height:64px;border-radius:50%;background:var(--fc-tint);color:var(--fc-accent-dark);box-shadow:0 4px 14px color-mix(in srgb,var(--fc-accent) 16%,transparent),inset 0 -2px 4px color-mix(in srgb,var(--fc-accent) 8%,transparent);transition:transform .22s ease,box-shadow .22s ease,background .22s ease;position:relative;overflow:hidden}.onboarding-focus-card__icon:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.22) 50%,transparent 70%);background-size:200% 100%;animation:modeIconShimmer 3.5s ease-in-out infinite;pointer-events:none}.onboarding-focus-card__body{display:flex;flex-direction:column;gap:4px;min-width:0}.onboarding-focus-card__body strong{font-size:17px;font-weight:700;color:var(--text)}.onboarding-focus-card__body span{font-size:13px;line-height:1.45;color:var(--text-light)}.onboarding-focus-card__check{position:absolute;top:12px;right:12px;color:var(--fc-accent);display:flex}[dir=rtl] .onboarding-focus-card__check{right:auto;left:12px}.onboarding-focus-card:hover{border-color:color-mix(in srgb,var(--fc-accent) 40%,var(--border));box-shadow:0 8px 24px color-mix(in srgb,var(--fc-accent) 14%,transparent),0 calc(var(--btn-3d-depth) + 2px) 0 -1px color-mix(in srgb,var(--fc-accent) 20%,var(--border))}.onboarding-focus-card:hover .onboarding-focus-card__icon{transform:scale(1.08);box-shadow:0 6px 20px color-mix(in srgb,var(--fc-accent) 24%,transparent),inset 0 -2px 4px color-mix(in srgb,var(--fc-accent) 12%,transparent)}.onboarding-focus-card:active{box-shadow:var(--shadow-card),0 1px 0 0 var(--border)}.onboarding-focus-card.is-selected{border-color:var(--fc-accent);background:var(--fc-tint);box-shadow:0 0 0 1.5px var(--fc-accent),0 var(--btn-3d-depth) 0 -1px var(--fc-accent-dark),0 4px 18px color-mix(in srgb,var(--fc-accent) 18%,transparent)}.onboarding-focus-card.is-selected .onboarding-focus-card__icon{background:color-mix(in srgb,var(--fc-accent) 18%,transparent);box-shadow:0 4px 16px color-mix(in srgb,var(--fc-accent) 22%,transparent),inset 0 -2px 4px color-mix(in srgb,var(--fc-accent) 12%,transparent)}.onboarding-focus-card__feature-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 10px 3px 7px;border-radius:999px;background:linear-gradient(135deg,var(--child-color-1-from, #6366f1),var(--child-color-4-from, #ec4899));color:#fff;font-size:.68rem;font-weight:700;letter-spacing:.02em;line-height:1;white-space:nowrap;box-shadow:0 2px 8px color-mix(in srgb,var(--child-color-1-from, #6366f1) 30%,transparent);pointer-events:none}.onboarding-focus-card__feature-tag svg{flex-shrink:0;animation:featureTagSparkle 2.5s ease-in-out infinite}@keyframes featureTagSparkle{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}.onboarding-focus-divider{display:flex;align-items:center;gap:16px;margin:4px 0}.onboarding-focus-divider:before,.onboarding-focus-divider:after{content:"";flex:1;height:1px;background:var(--border)}.onboarding-focus-divider span{font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-light)}.onboarding-focus-recommended{position:relative;display:flex;align-items:center;gap:16px;width:100%;padding:22px 24px;border-radius:var(--radius-lg);border:1.5px solid color-mix(in srgb,var(--green) 32%,var(--border));background:linear-gradient(135deg,color-mix(in srgb,var(--green) 6%,var(--surface)),color-mix(in srgb,var(--green) 12%,var(--surface)));cursor:pointer;font:inherit;color:var(--text);text-align:start;box-shadow:0 2px 12px color-mix(in srgb,var(--green) 10%,transparent),0 var(--btn-3d-depth) 0 -1px color-mix(in srgb,var(--green) 18%,var(--border)),inset 0 1px #ffffff0f;transition:transform .18s ease,box-shadow .22s ease,border-color .22s ease,background .22s ease;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.onboarding-focus-recommended__badge{position:absolute;top:-10px;left:20px;padding:3px 12px;border-radius:999px;background:var(--gradient-green);color:#fff;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;box-shadow:0 2px 8px color-mix(in srgb,var(--green) 30%,transparent)}[dir=rtl] .onboarding-focus-recommended__badge{left:auto;right:20px}.onboarding-focus-recommended__icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:56px;height:56px;border-radius:50%;background:var(--tint-green);color:var(--green-dark);box-shadow:0 4px 14px color-mix(in srgb,var(--green) 16%,transparent),inset 0 -2px 4px color-mix(in srgb,var(--green) 8%,transparent);transition:transform .22s ease,box-shadow .22s ease;position:relative;overflow:hidden}@keyframes compassSway{0%,to{transform:rotate(-8deg)}50%{transform:rotate(8deg)}}.onboarding-focus-recommended__icon svg{animation:compassSway 4s ease-in-out infinite}.onboarding-focus-recommended__icon:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.22) 50%,transparent 70%);background-size:200% 100%;animation:modeIconShimmer 3.5s ease-in-out infinite;pointer-events:none}.onboarding-focus-recommended__body{flex:1;min-width:0}.onboarding-focus-recommended__body strong{display:block;margin-bottom:3px;font-size:18px;font-weight:700;color:var(--text)}.onboarding-focus-recommended__body span{font-size:14px;line-height:1.45;color:var(--text-light)}.onboarding-focus-recommended__check{flex-shrink:0;color:var(--green);display:flex}.onboarding-focus-recommended:hover{border-color:var(--green);box-shadow:0 8px 28px color-mix(in srgb,var(--green) 16%,transparent),0 calc(var(--btn-3d-depth) + 2px) 0 -1px color-mix(in srgb,var(--green) 24%,var(--border)),inset 0 1px #ffffff14}.onboarding-focus-recommended:hover .onboarding-focus-recommended__icon{transform:scale(1.06);box-shadow:0 6px 20px color-mix(in srgb,var(--green) 24%,transparent),inset 0 -2px 4px color-mix(in srgb,var(--green) 12%,transparent)}.onboarding-focus-recommended:active{box-shadow:0 1px 4px color-mix(in srgb,var(--green) 10%,transparent),0 1px color-mix(in srgb,var(--green) 18%,var(--border))}.onboarding-focus-recommended.is-selected{border-color:var(--green);background:linear-gradient(135deg,color-mix(in srgb,var(--green) 10%,var(--surface)),color-mix(in srgb,var(--green) 18%,var(--surface)));box-shadow:0 0 0 1.5px var(--green),0 var(--btn-3d-depth) 0 -1px var(--green-dark),0 4px 18px color-mix(in srgb,var(--green) 20%,transparent)}.onboarding-focus-recommended.is-selected .onboarding-focus-recommended__icon{background:color-mix(in srgb,var(--green) 20%,transparent)}.onboarding-focus-card:focus-visible,.onboarding-focus-recommended:focus-visible{outline:2px solid var(--blue);outline-offset:3px}.onboarding-modes-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;margin-top:24px}.onboarding-mode-card{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;padding:32px 24px 28px;border-radius:var(--radius-lg);border:1px solid var(--border);border-inline-start:4px solid var(--border);background:var(--surface);box-shadow:var(--shadow-card),0 4px 0 -1px var(--border);transition:border-color .22s ease,box-shadow .22s ease,background .22s ease,transform .22s ease;overflow:hidden}.onboarding-mode-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;opacity:.45;pointer-events:none;transition:opacity .22s ease}.onboarding-mode-card--play{border-inline-start-color:var(--orange, #ff9600)}.onboarding-mode-card--play:before{background:linear-gradient(135deg,color-mix(in srgb,var(--orange) 8%,transparent) 0%,transparent 60%)}.onboarding-mode-card--study{border-inline-start-color:var(--blue, #1cb0f6)}.onboarding-mode-card--study:before{background:linear-gradient(135deg,color-mix(in srgb,var(--blue) 8%,transparent) 0%,transparent 60%)}.onboarding-mode-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card-hover),0 8px 0 -2px var(--border)}.onboarding-mode-card--play:hover{border-color:color-mix(in srgb,var(--orange) 50%,var(--border));box-shadow:0 8px 28px color-mix(in srgb,var(--orange) 14%,transparent),0 8px 0 -2px color-mix(in srgb,var(--orange) 20%,var(--border))}.onboarding-mode-card--play:hover:before{opacity:.7}.onboarding-mode-card--study:hover{border-color:color-mix(in srgb,var(--blue) 50%,var(--border));box-shadow:0 8px 28px color-mix(in srgb,var(--blue) 14%,transparent),0 8px 0 -2px color-mix(in srgb,var(--blue) 20%,var(--border))}.onboarding-mode-card--study:hover:before{opacity:.7}.onboarding-mode-card__icon{position:relative;display:flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:50%;transition:background .22s ease,color .22s ease,box-shadow .22s ease,transform .22s ease}.onboarding-mode-card--play .onboarding-mode-card__icon{background:var(--tint-orange, color-mix(in srgb, #f59e0b 14%, transparent));color:var(--orange-dark, #b45309);box-shadow:0 4px 16px color-mix(in srgb,var(--orange) 18%,transparent),inset 0 -2px 4px color-mix(in srgb,var(--orange) 10%,transparent)}.onboarding-mode-card--study .onboarding-mode-card__icon{background:var(--tint-blue, color-mix(in srgb, #3b82f6 14%, transparent));color:var(--blue-dark, #1d4ed8);box-shadow:0 4px 16px color-mix(in srgb,var(--blue) 18%,transparent),inset 0 -2px 4px color-mix(in srgb,var(--blue) 10%,transparent)}.onboarding-mode-card__icon:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.25) 50%,transparent 70%);background-size:200% 100%;animation:modeIconShimmer 3s ease-in-out infinite;pointer-events:none}@keyframes modeIconShimmer{0%,to{background-position:200% 0}50%{background-position:-200% 0}}.onboarding-mode-card:hover .onboarding-mode-card__icon{transform:scale(1.08)}.onboarding-mode-card--play:hover .onboarding-mode-card__icon{box-shadow:0 6px 24px color-mix(in srgb,var(--orange) 28%,transparent),inset 0 -2px 4px color-mix(in srgb,var(--orange) 14%,transparent)}.onboarding-mode-card--study:hover .onboarding-mode-card__icon{box-shadow:0 6px 24px color-mix(in srgb,var(--blue) 28%,transparent),inset 0 -2px 4px color-mix(in srgb,var(--blue) 14%,transparent)}.onboarding-mode-card__title{margin:0;font-size:20px;font-weight:800;letter-spacing:-.01em;color:var(--text)}.onboarding-mode-card__desc{margin:0;font-size:14px;line-height:1.5;color:var(--text-light);max-width:260px}.onboarding-mode-card__bullets{list-style:none;display:flex;flex-direction:column;gap:6px;margin:6px 0 12px;padding:0;text-align:start;width:100%}.onboarding-mode-card__bullets li{position:relative;display:flex;align-items:center;gap:8px;padding:7px 12px;border-radius:var(--radius-sm);background:color-mix(in srgb,var(--border) 40%,transparent);font-size:13px;font-weight:500;line-height:1.4;color:var(--text);transition:background .18s ease}.onboarding-mode-card__bullets li:before{content:"";flex-shrink:0;width:6px;height:6px;border-radius:50%}.onboarding-mode-card--play .onboarding-mode-card__bullets li{background:color-mix(in srgb,var(--orange) 8%,transparent)}.onboarding-mode-card--play .onboarding-mode-card__bullets li:before{background:var(--orange, #ff9600)}.onboarding-mode-card--study .onboarding-mode-card__bullets li{background:color-mix(in srgb,var(--blue) 8%,transparent)}.onboarding-mode-card--study .onboarding-mode-card__bullets li:before{background:var(--blue, #1cb0f6)}.onboarding-mode-card:hover .onboarding-mode-card__bullets li{background:color-mix(in srgb,var(--border) 55%,transparent)}.onboarding-mode-card--play:hover .onboarding-mode-card__bullets li{background:color-mix(in srgb,var(--orange) 12%,transparent)}.onboarding-mode-card--study:hover .onboarding-mode-card__bullets li{background:color-mix(in srgb,var(--blue) 12%,transparent)}.onboarding-mode-card__cta{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:auto;padding:14px 24px;border:none;border-radius:var(--radius);font-size:15px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;cursor:pointer;position:relative;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;transition:transform .1s ease,box-shadow .1s ease,filter .15s ease}.onboarding-mode-card--play .onboarding-mode-card__cta{background:linear-gradient(135deg,var(--orange, #ff9600),#e68a00);color:#fff;box-shadow:0 var(--btn-3d-depth) 0 #b36b00,0 2px 8px color-mix(in srgb,var(--orange) 30%,transparent)}.onboarding-mode-card--study .onboarding-mode-card__cta{background:linear-gradient(135deg,var(--blue, #1cb0f6),#1899d6);color:#fff;box-shadow:0 var(--btn-3d-depth) 0 var(--blue-dark, #1480b6),0 2px 8px color-mix(in srgb,var(--blue) 30%,transparent)}.onboarding-mode-card__cta:hover{filter:brightness(1.06);transform:translateY(-1px)}.onboarding-mode-card__cta:active{transform:translateY(var(--btn-3d-depth));box-shadow:none}.onboarding-mode-card__cta:focus-visible{outline:2px solid var(--blue);outline-offset:4px}.onboarding-mode-card__cta:disabled{cursor:not-allowed;opacity:.55;filter:grayscale(.3)}.onboarding-mode-card.is-completed{border-color:var(--green);border-inline-start-color:var(--green);background:linear-gradient(135deg,var(--tint-green) 0%,color-mix(in srgb,var(--green) 6%,var(--surface)) 100%);box-shadow:0 0 0 1.5px var(--green),0 4px 0 -1px var(--green-dark),0 4px 20px color-mix(in srgb,var(--green) 16%,transparent)}.onboarding-mode-card.is-completed:before{background:linear-gradient(135deg,color-mix(in srgb,var(--green) 10%,transparent) 0%,transparent 60%)}.onboarding-mode-card__done{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%;margin-top:auto;padding:14px 16px;border-radius:var(--radius);background:linear-gradient(135deg,var(--green),var(--green-dark));color:#fff;font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;box-shadow:0 var(--btn-3d-depth) 0 color-mix(in srgb,var(--green-dark) 80%,#000),0 2px 12px color-mix(in srgb,var(--green) 30%,transparent);position:relative;overflow:hidden}.onboarding-mode-card__done:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.2) 50%,transparent 70%);background-size:200% 100%;animation:modeIconShimmer 3s ease-in-out infinite;pointer-events:none}.onboarding-mode-card__done-row{display:flex;align-items:center;gap:6px}.onboarding-mode-card__done-details{display:flex;align-items:center;gap:10px;font-size:13px;opacity:.92}.onboarding-mode-card__score{font-size:15px;font-weight:800;letter-spacing:.02em}.onboarding-mode-card__level{font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#fff;padding:3px 10px;border-radius:999px;background:#ffffff38;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.onboarding-step--welcome,.onboarding-step--launch{text-align:center;align-items:center;justify-content:center;min-height:280px}.onboarding-step--welcome{position:relative;min-height:360px}.onboarding-step--welcome .onboarding-hero{position:relative;z-index:2}.hero-scene__back,.hero-scene__front{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none}.hero-scene__back{z-index:0}[data-theme=dark] .hero-scene__back{opacity:.8}.hero-scene__front{z-index:1}.hero-scene__reduced.hero-scene__back{background:radial-gradient(ellipse 80% 60% at 50% 35%,rgba(255,150,0,.06) 0%,transparent 70%)}[data-theme=dark] .hero-scene__reduced.hero-scene__back{background:radial-gradient(ellipse 80% 60% at 50% 35%,rgba(255,179,0,.04) 0%,transparent 70%)}.hero-scene__reduced.hero-scene__front{background:radial-gradient(circle at 50% 30%,rgba(255,200,50,.03) 0%,transparent 50%)}@media(prefers-reduced-motion:reduce){.onboarding-page[data-step=welcome] .onboarding-backdrop--one,.onboarding-page[data-step=welcome] .onboarding-backdrop--two,.onboarding-page[data-step=welcome] .onboarding-backdrop--three{animation:none}}@media(max-width:767px){.onboarding-highlight-grid,.onboarding-choice-grid,.onboarding-modes-grid,.onboarding-focus-grid,.onboarding-passcode-grid{grid-template-columns:1fr}.onboarding-focus-card{flex-direction:row;flex-wrap:wrap;text-align:start;padding:18px;gap:14px}.onboarding-focus-card__feature-tag{width:100%;justify-content:center}.onboarding-focus-card__icon{width:52px;height:52px}.onboarding-focus-recommended{padding:18px 20px}.onboarding-actions{flex-direction:row;align-items:center;justify-content:center;padding-bottom:env(safe-area-inset-bottom,0px)}.onboarding-progress{align-items:stretch;flex:1;min-width:0}.onboarding-card{border-radius:var(--radius-lg)}.onboarding-hero h1,.onboarding-step__header h2{font-size:26px}}@media(prefers-reduced-motion:reduce){.onboarding-choice-card,.onboarding-style-card,.onboarding-toggle-card,.onboarding-mode-card,.onboarding-mode-card__cta,.onboarding-mode-card__icon,.onboarding-focus-card,.onboarding-focus-card__icon,.onboarding-focus-recommended,.onboarding-focus-recommended__icon,.onboarding-pill,.onboarding-primary-btn,.onboarding-add-btn,.onboarding-icon-btn,.profile-dropdown__profile-btn,.onboarding-family-empty__cta,.onboarding-family-child,.onboarding-family-child__remove,.onboarding-family-add,.onboarding-family-method__option,.onboarding-family-method__icon{transition:none}.onboarding-mode-card__icon:after,.onboarding-mode-card__done:after,.onboarding-focus-card__icon:after,.onboarding-focus-recommended__icon:after{animation:none}.onboarding-focus-recommended__icon svg,.onboarding-focus-card__feature-tag svg{animation:none}}[dir=rtl] .onboarding-nav-btn svg,[dir=rtl] .onboarding-primary-btn svg,[dir=rtl] .onboarding-diagnostic-cta__arrow{transform:scaleX(-1)}[dir=rtl] .onboarding-progress__fill:after{left:auto;right:-50%;animation:progressShimmerRtl 2s ease-in-out infinite}@keyframes progressShimmerRtl{0%{right:-50%}to{right:150%}}.onboarding-family-empty{display:flex;flex-direction:column;align-items:center;gap:16px;padding:28px 20px 24px;border-radius:var(--radius-lg, 16px);background:linear-gradient(135deg,color-mix(in srgb,var(--child-color-1-from, #6366f1) 7%,var(--surface)),color-mix(in srgb,var(--child-color-1-to, #8b5cf6) 6%,var(--surface)),color-mix(in srgb,var(--child-color-4-from, #ec4899) 4%,var(--surface)));border:1.5px solid color-mix(in srgb,var(--child-color-1-from, #6366f1) 14%,var(--border));text-align:center;position:relative;overflow:hidden}.onboarding-family-empty:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 120% 80% at 30% 20%,color-mix(in srgb,var(--child-color-1-from, #6366f1) 8%,transparent),transparent 60%),radial-gradient(ellipse 100% 80% at 70% 80%,color-mix(in srgb,var(--child-color-4-from, #ec4899) 6%,transparent),transparent 60%);pointer-events:none}.onboarding-family-empty__illustration{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center}.onboarding-family-empty__icon--main{display:flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--child-color-1-from, #6366f1),var(--child-color-1-to, #8b5cf6));color:#fff;box-shadow:0 4px 14px #6366f14d,0 0 0 4px #6366f114}.onboarding-family-empty__icon--accent{position:absolute;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--surface);box-shadow:0 2px 8px #00000014;color:var(--text-light)}.onboarding-family-empty__icon--tl{top:0;left:-2px;color:var(--amber, #f59e0b)}.onboarding-family-empty__icon--tr{top:2px;right:-4px;color:var(--child-color-1-from, #6366f1)}.onboarding-family-empty__icon--br{bottom:0;right:2px;color:var(--child-color-4-from, #ec4899)}.onboarding-family-empty__text{display:flex;flex-direction:column;gap:4px}.onboarding-family-empty__label{font-weight:700;font-size:1.05rem;color:var(--text)}.onboarding-family-empty__desc{font-size:.85rem;color:var(--text-light);line-height:1.45;max-width:280px}.onboarding-family-empty__benefits{display:flex;gap:16px;flex-wrap:wrap;justify-content:center}.onboarding-family-empty__benefits span{display:flex;align-items:center;gap:5px;font-size:.78rem;color:var(--text-light);font-weight:500}.onboarding-family-empty__benefits span svg{color:var(--child-color-1-from, #6366f1);flex-shrink:0}.onboarding-family-empty__cta{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 28px;border:none;border-radius:999px;background:linear-gradient(135deg,var(--child-color-1-from, #6366f1),var(--child-color-1-to, #8b5cf6));color:#fff;font-family:inherit;font-weight:700;font-size:.92rem;cursor:pointer;box-shadow:0 4px 14px #6366f159,0 1px 3px #0000001a;transition:box-shadow .2s,filter .2s}.onboarding-family-empty__cta:hover{box-shadow:0 6px 20px #6366f173,0 2px 6px #0000001f;filter:brightness(1.05)}.onboarding-family-empty__cta:active{filter:brightness(.97)}.onboarding-family-children{display:flex;flex-direction:column;gap:10px;margin-bottom:8px}.onboarding-family-child{display:flex;align-items:center;gap:10px;padding:12px;border:1.5px solid var(--border);border-radius:var(--radius);background:var(--surface);transition:border-color .15s,box-shadow .15s}.onboarding-family-child:focus-within{border-color:color-mix(in srgb,var(--child-badge-from, #6366f1) 50%,var(--border));box-shadow:0 0 0 3px color-mix(in srgb,var(--child-badge-from, #6366f1) 10%,transparent)}.onboarding-family-child:nth-child(1){--child-badge-from: var(--child-color-1-from, #6366f1);--child-badge-to: var(--child-color-1-to, #8b5cf6)}.onboarding-family-child:nth-child(2){--child-badge-from: var(--child-color-2-from, #10b981);--child-badge-to: var(--child-color-2-to, #059669)}.onboarding-family-child:nth-child(3){--child-badge-from: var(--child-color-3-from, #f59e0b);--child-badge-to: var(--child-color-3-to, #d97706)}.onboarding-family-child:nth-child(4){--child-badge-from: var(--child-color-4-from, #ec4899);--child-badge-to: var(--child-color-4-to, #db2777)}.onboarding-family-child:nth-child(5){--child-badge-from: var(--child-color-5-from, #14b8a6);--child-badge-to: var(--child-color-5-to, #0d9488)}.onboarding-family-child__number{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--child-badge-from, #6366f1),var(--child-badge-to, #8b5cf6));color:#fff;font-size:.75rem;font-weight:700;flex-shrink:0}.onboarding-family-child__fields{flex:1;display:flex;gap:8px;min-width:0}.onboarding-family-child__name,.onboarding-family-child__age{padding:8px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);font-family:inherit;font-size:.9rem;line-height:1.4;color:var(--text);outline:none;transition:border-color .15s;box-sizing:border-box}.onboarding-family-child__name{flex:1;min-width:0}.onboarding-family-child__name:focus,.onboarding-family-child__age:focus{border-color:var(--purple)}.onboarding-family-child__age{width:72px;flex-shrink:0;text-align:center;padding:8px 6px}.onboarding-family-child__age::-webkit-outer-spin-button,.onboarding-family-child__age::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.onboarding-family-child__age[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.onboarding-family-child__remove{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:50%;background:color-mix(in srgb,var(--red, #ef4444) 10%,transparent);color:var(--red, #ef4444);cursor:pointer;flex-shrink:0;transition:background .15s,color .15s}.onboarding-family-child__remove:hover{background:color-mix(in srgb,var(--red, #ef4444) 20%,transparent)}.onboarding-family-add{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px;border:2px dashed var(--border);border-radius:var(--radius);background:transparent;color:var(--text-light);font-family:inherit;font-weight:600;font-size:.85rem;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.onboarding-family-add:hover{border-color:var(--purple);color:var(--purple);background:color-mix(in srgb,var(--purple, #6366f1) 6%,transparent)}.onboarding-family-passcode{padding:16px;border:1.5px solid var(--border);border-radius:var(--radius);background:var(--tint-neutral);margin-top:0;overflow:hidden}.onboarding-family-passcode__header{display:flex;align-items:center;gap:8px;font-weight:600;font-size:.9rem;color:var(--text);margin-bottom:4px}.onboarding-family-passcode__hint{font-size:.8rem;color:var(--text-light);margin:0 0 12px}.onboarding-family-method{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.onboarding-family-method__option{display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--surface);cursor:pointer;font-family:inherit;color:var(--text);text-align:left;transition:border-color .18s,box-shadow .18s,background .18s}.onboarding-family-method__option:hover{border-color:color-mix(in srgb,var(--child-color-1-from, #6366f1) 40%,var(--border))}.onboarding-family-method__option.is-selected{border-color:var(--child-color-1-from, #6366f1);background:color-mix(in srgb,var(--child-color-1-from, #6366f1) 6%,var(--surface));box-shadow:0 0 0 1.5px var(--child-color-1-from, #6366f1)}.onboarding-family-method__icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:color-mix(in srgb,var(--child-color-1-from, #6366f1) 10%,transparent);color:var(--child-color-1-from, #6366f1);flex-shrink:0;transition:background .18s,color .18s}.onboarding-family-method__option.is-selected .onboarding-family-method__icon{background:linear-gradient(135deg,var(--child-color-1-from, #6366f1),var(--child-color-1-to, #8b5cf6));color:#fff}.onboarding-family-method__text{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.onboarding-family-method__text strong{font-size:.88rem;font-weight:700;color:var(--text)}.onboarding-family-method__text span{font-size:.78rem;color:var(--text-light);line-height:1.35}.onboarding-family-method__check{color:var(--child-color-1-from, #6366f1);flex-shrink:0;display:flex}.onboarding-family-passcode__input{display:block;width:100%;padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);font-family:inherit;font-size:.9rem;color:var(--text);outline:none;margin-bottom:8px;transition:border-color .15s;letter-spacing:.2em}.onboarding-family-passcode__input:focus{border-color:var(--purple)}.onboarding-family-passcode__input:last-child{margin-bottom:0}@keyframes notifBellRing{0%,to{transform:rotate(0)}10%{transform:rotate(14deg)}25%{transform:rotate(-11deg)}40%{transform:rotate(8deg)}55%{transform:rotate(-6deg)}70%{transform:rotate(3deg)}}@keyframes notifGlowBloom{0%,to{transform:scale(1);opacity:.5}50%{transform:scale(1.22);opacity:.8}}.onboarding-notif-hero{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;padding-bottom:4px}.onboarding-notif-hero h2{margin:0;font-size:30px;line-height:1.02;letter-spacing:-.04em;color:var(--text)}.onboarding-notif-hero p{margin:0;max-width:520px;font-size:16px;line-height:1.6;color:var(--text-light)}.onboarding-notif-hero__bell-wrap{position:relative;display:flex;align-items:center;justify-content:center;margin-bottom:8px;animation:notifBellRing 1.6s cubic-bezier(.36,.07,.19,.97) .5s both}.onboarding-notif-hero__glow{position:absolute;top:-24px;right:-24px;bottom:-24px;left:-24px;border-radius:50%;background:radial-gradient(circle at center,color-mix(in srgb,var(--purple, #a855f7) 30%,transparent) 0%,color-mix(in srgb,var(--blue) 18%,transparent) 50%,transparent 75%);pointer-events:none;animation:notifGlowBloom 3.2s ease-in-out infinite}.onboarding-notif-hero__bell{display:flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:50%;background:color-mix(in srgb,var(--purple, #a855f7) 14%,var(--tint-blue));color:var(--blue-dark, #1480b6);box-shadow:0 4px 20px color-mix(in srgb,var(--purple, #a855f7) 22%,transparent),inset 0 1px #ffffff40;position:relative;z-index:1}.onboarding-notif-master{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 18px;border-radius:var(--radius-lg);border:1.5px solid var(--border);background:color-mix(in srgb,var(--surface) 80%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:var(--shadow-card);transition:border-color .25s ease,background .25s ease,box-shadow .25s ease}.onboarding-notif-master.is-on{border-color:color-mix(in srgb,var(--green) 55%,transparent);background:color-mix(in srgb,var(--tint-green) 55%,var(--surface));box-shadow:0 0 0 1px color-mix(in srgb,var(--green) 28%,transparent),var(--shadow-card)}.onboarding-notif-master__body{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.onboarding-notif-master__icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:40px;height:40px;border-radius:12px;background:color-mix(in srgb,var(--purple, #a855f7) 14%,var(--tint-blue));color:var(--blue-dark, #1480b6);transition:background .25s ease,color .25s ease}.onboarding-notif-master.is-on .onboarding-notif-master__icon{background:var(--tint-green);color:var(--green-dark)}.onboarding-notif-master__copy{display:flex;flex-direction:column;gap:2px;min-width:0}.onboarding-notif-master__copy strong{display:block;font-size:16px;font-weight:700;color:var(--text)}.onboarding-notif-master__copy span{font-size:13px;line-height:1.45;color:var(--text-light)}.settings-toggle--lg{width:56px;height:32px;border-radius:16px}.settings-toggle--lg:after{width:22px;height:22px;top:3px;left:3px}.settings-toggle--lg.on:after{transform:translate(24px);width:24px;height:24px;top:2px}.onboarding-notif-types{overflow:hidden}.onboarding-notif-list{display:flex;flex-direction:column;gap:2px;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);background:color-mix(in srgb,var(--surface) 80%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.onboarding-notif-row{display:flex;align-items:center;gap:14px;padding:14px 18px;border-bottom:1px solid var(--border);background:transparent;transition:background .18s ease}.onboarding-notif-row:last-child{border-bottom:none}.onboarding-notif-row__icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:36px;height:36px;border-radius:10px;background:var(--tint-neutral);color:var(--text-light);transition:background .18s ease,color .18s ease}.onboarding-notif-row__icon[data-color=orange]{background:var(--tint-orange, color-mix(in srgb, #f59e0b 12%, transparent));color:var(--orange-dark, #b45309)}.onboarding-notif-row__icon[data-color=blue]{background:var(--tint-blue);color:var(--blue-dark, #1480b6)}.onboarding-notif-row__icon[data-color=green]{background:var(--tint-green);color:var(--green-dark)}.onboarding-notif-row__icon[data-color=purple]{background:color-mix(in srgb,#a855f7 12%,transparent);color:#7e22ce}.onboarding-notif-row__icon[data-color=brand]{background:var(--tint-green);color:var(--green-dark)}.onboarding-notif-row__copy{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.onboarding-notif-row__copy strong{display:block;font-size:15px;font-weight:600;color:var(--text)}.onboarding-notif-row__copy span{font-size:13px;line-height:1.45;color:var(--text-light)}.onboarding-notif-footer{display:flex;align-items:center;gap:5px;margin:2px auto 0;font-size:12px;color:var(--text-light);opacity:.75}@keyframes skeleton-sweep{0%{transform:translate(-150%)}to{transform:translate(150%)}}.skeleton-text{display:flex;flex-direction:column;gap:8px}.skeleton-text__line{height:1em;border-radius:4px;background:var(--border);position:relative;overflow:hidden}.skeleton-text__line:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.4) 50%,transparent 100%);animation:skeleton-sweep 1.5s linear infinite}.skeleton-text__line--last{width:60%}.bsm-step{display:flex;flex-direction:column;gap:var(--spacing-md, 16px)}.bsm-body{min-height:320px}.bsm-title{font-size:1.5rem;font-weight:700;line-height:1.25;text-align:center;color:var(--text);margin:0}.bsm-desc{font-size:.95rem;line-height:1.5;text-align:center;color:var(--text-light);margin:0;max-width:420px;margin-inline:auto}.bsm-dots{display:flex;justify-content:center;gap:8px;padding:4px 0 8px}.bsm-dots__dot{width:8px;height:8px;border-radius:50%;background:var(--border)}.bsm-sub{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md, 16px);padding:8px 0}.bsm-intro__icon{position:relative;margin-bottom:8px}.bsm-intro__icon-inner{position:relative;width:88px;height:88px;display:flex;align-items:center;justify-content:center;border-radius:24px;background:linear-gradient(135deg,color-mix(in srgb,var(--orange) 15%,transparent),color-mix(in srgb,var(--blue) 12%,transparent));color:var(--orange)}.bsm-intro__sparkle{position:absolute;color:var(--orange)}.bsm-intro__sparkle--1{top:-4px;right:-8px}.bsm-intro__sparkle--2{bottom:-2px;left:-10px;color:var(--blue)}.bsm-intro__sparkle--3{top:8px;left:-12px;color:var(--green)}.bsm-intro__preview{display:grid;grid-template-columns:repeat(2,auto);justify-content:center;gap:8px;margin-top:8px}.bsm-intro__preview-badge{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;font-size:.8rem;font-weight:600;border:1.5px dashed var(--border);color:var(--text-light)}.bsm-intro__preview-badge[data-color=orange]{border-color:color-mix(in srgb,var(--orange) 60%,transparent);color:color-mix(in srgb,var(--orange) 85%,#3c3c3c);background:color-mix(in srgb,var(--orange) 8%,transparent)}.bsm-intro__preview-badge[data-color=blue]{border-color:color-mix(in srgb,var(--blue) 60%,transparent);color:color-mix(in srgb,var(--blue) 85%,#3c3c3c);background:color-mix(in srgb,var(--blue) 8%,transparent)}.bsm-intro__preview-badge[data-color=purple]{border-color:color-mix(in srgb,var(--purple) 60%,transparent);color:color-mix(in srgb,var(--purple) 85%,#3c3c3c);background:color-mix(in srgb,var(--purple) 8%,transparent)}.bsm-intro__preview-badge[data-color=green]{border-color:color-mix(in srgb,var(--green) 60%,transparent);color:color-mix(in srgb,var(--green) 85%,#3c3c3c);background:color-mix(in srgb,var(--green) 8%,transparent)}.bsm-rule{align-items:stretch}.bsm-rule__header{display:flex;justify-content:center}.bsm-rule__badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;font-size:.82rem;font-weight:700;letter-spacing:.02em}.bsm-rule__badge[data-color=orange]{background:color-mix(in srgb,var(--orange) 14%,transparent);color:var(--orange)}.bsm-rule__badge[data-color=blue]{background:color-mix(in srgb,var(--blue) 14%,transparent);color:var(--blue)}.bsm-rule__badge[data-color=purple]{background:color-mix(in srgb,var(--purple) 14%,transparent);color:var(--purple)}.bsm-rule__badge[data-color=green]{background:color-mix(in srgb,var(--green) 14%,transparent);color:var(--green)}.bsm-rule__desc{font-size:1.1rem;line-height:1.5;color:var(--text-light);text-align:center;margin:0}.bsm-rule__instruction{font-size:.82rem;font-weight:600;color:var(--text);text-align:center;margin:0;padding:6px 12px;border-radius:8px;background:color-mix(in srgb,var(--blue) 8%,transparent)}.bsm-verse-card{background:var(--bg-secondary, var(--bg));border:1px solid var(--border);border-radius:16px;padding:20px;display:flex;flex-direction:column;gap:12px}.bsm-verse-card__ref{font-size:.78rem;font-weight:600;color:var(--text-light);text-align:end}.interactive-verse{font-size:1.05rem;line-height:1.85;color:var(--text);margin:0;font-family:var(--font-reading, Georgia, serif);font-weight:400}.interactive-verse__keyword{position:relative;display:inline;cursor:pointer;padding:2px 5px;border-radius:6px;transition:background .18s ease,box-shadow .18s ease;font-weight:600;font-size:1rem}.interactive-verse__keyword.is-tappable{background:color-mix(in srgb,var(--kw-color, var(--orange)) 14%,transparent);box-shadow:inset 0 0 0 1.5px color-mix(in srgb,var(--kw-color, var(--orange)) 38%,transparent)}.interactive-verse__keyword.is-tappable:hover{background:color-mix(in srgb,var(--kw-color, var(--orange)) 24%,transparent);box-shadow:inset 0 0 0 1.5px color-mix(in srgb,var(--kw-color, var(--orange)) 55%,transparent)}.interactive-verse__keyword.is-found{background:color-mix(in srgb,var(--kw-color, var(--orange)) 18%,transparent);box-shadow:inset 0 0 0 1.5px color-mix(in srgb,var(--kw-color, var(--orange)) 60%,transparent),0 0 0 3px color-mix(in srgb,var(--kw-color, var(--orange)) 10%,transparent);color:color-mix(in srgb,var(--kw-color, var(--orange)) 70%,var(--text))}.interactive-verse__keyword.is-mistake{background:color-mix(in srgb,var(--red) 12%,transparent);box-shadow:inset 0 0 0 1.5px color-mix(in srgb,var(--red) 40%,transparent);color:var(--red);opacity:.7;animation:kw-shake .4s ease}@keyframes kw-shake{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-3px)}80%{transform:translate(2px)}}.interactive-verse__glow{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:8px;opacity:.15;pointer-events:none;z-index:-1}.bsm-connection__arrow{width:100%;max-width:200px;height:40px;margin:4px auto;display:block}[dir=rtl] .bsm-connection__arrow{transform:scaleX(-1)}.bsm-rule__reveal{overflow:hidden}.bsm-rule__reveal-text{font-size:.9rem;line-height:1.55;color:var(--text);margin:0;padding:12px;border-radius:10px;background:color-mix(in srgb,var(--green) 8%,transparent);border-inline-start:3px solid var(--green)}.bsm-rule__extras{display:flex;flex-wrap:wrap;gap:10px;margin-top:15px}.bsm-rule__extra-pill{display:inline-block;font-size:.8rem;padding:5px 10px;border-radius:8px;background:var(--bg-secondary, var(--bg));color:var(--text-light);border:1px solid var(--border)}.bsm-observation__verse-line{padding-bottom:6px;border-bottom:1px solid color-mix(in srgb,var(--border) 50%,transparent);margin-bottom:6px}.bsm-observation__verse-line:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.bsm-observation__counter{display:flex;align-items:center;justify-content:space-between;padding-top:4px}.bsm-observation__count{font-size:.82rem;font-weight:600;color:var(--text-light);transition:color .3s}.bsm-observation__count.is-complete{color:var(--green)}.bsm-observation__dots{display:flex;gap:6px}.bsm-observation__dot{width:8px;height:8px;border-radius:50%;background:var(--border)}.bsm-structural__card{overflow:hidden}.bsm-structural__panel{display:flex;flex-direction:column;gap:8px}.bsm-structural__label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-light)}.bsm-structural__label--context{color:var(--purple)}.bsm-structural__verse{font-size:1rem;line-height:1.7;color:var(--text);margin:0}.bsm-structural__reveal-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border:2px solid var(--purple);border-radius:12px;background:color-mix(in srgb,var(--purple) 8%,transparent);color:var(--purple);font-weight:700;font-size:.88rem;cursor:pointer;margin-top:4px;transition:background .15s}.bsm-structural__reveal-btn:hover{background:color-mix(in srgb,var(--purple) 16%,transparent)}.bsm-investigation__verse{font-size:1rem;line-height:1.7;color:var(--text);margin:0}.bsm-investigation__markers{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.bsm-investigation__marker{display:flex;flex-direction:column;align-items:center;gap:4px;padding:18px 8px;border:1.5px solid var(--border);border-radius:12px;background:var(--bg);cursor:pointer;transition:border-color .2s,background .2s;text-align:center}.bsm-investigation__marker:not(.is-found):hover{border-color:var(--green);background:color-mix(in srgb,var(--green) 8%,transparent)}.bsm-investigation__marker.is-found{border-color:var(--green);background:color-mix(in srgb,var(--green) 10%,transparent);cursor:default}.bsm-investigation__marker-label{font-size:.82rem;font-weight:700;color:var(--green)}.bsm-investigation__marker-reveal{font-size:.9rem;line-height:1.35;color:var(--text-light);overflow:hidden}.bsm-investigation__progress{display:flex;align-items:center;gap:8px;justify-content:center;padding-top:4px}.bsm-investigation__ring{width:36px;height:36px}.bsm-investigation__progress-text{font-size:.82rem;font-weight:700;color:var(--text-light)}.bsm-complete{text-align:center}.bsm-complete__icon{color:var(--green)}.bsm-complete__badges{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;max-width:640px;margin:20px auto 16px}.bsm-complete__cta-text{font-size:.88rem;color:var(--text-light);margin:0}.toolkit-badge{display:flex;flex-direction:column;align-items:center;gap:10px;padding:22px 50px 18px;border-radius:20px;border:1.5px solid var(--border);background:var(--bg)}.toolkit-badge.is-unlocked{border-color:transparent}.toolkit-badge[data-color=orange].is-unlocked{background:color-mix(in srgb,var(--orange) 12%,var(--bg));box-shadow:0 0 16px color-mix(in srgb,var(--orange) 4%,transparent)}.toolkit-badge[data-color=blue].is-unlocked{background:color-mix(in srgb,var(--blue) 12%,var(--bg));box-shadow:0 0 16px color-mix(in srgb,var(--blue) 4%,transparent)}.toolkit-badge[data-color=purple].is-unlocked{background:color-mix(in srgb,var(--purple) 12%,var(--bg));box-shadow:0 0 16px color-mix(in srgb,var(--purple) 4%,transparent)}.toolkit-badge[data-color=green].is-unlocked{background:color-mix(in srgb,var(--green) 12%,var(--bg));box-shadow:0 0 16px color-mix(in srgb,var(--green) 4%,transparent)}.toolkit-badge__icon{display:flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:16px;background:color-mix(in srgb,var(--border) 50%,transparent)}.toolkit-badge.is-unlocked .toolkit-badge__icon{background:color-mix(in srgb,currentColor 15%,transparent)}.toolkit-badge[data-color=orange] .toolkit-badge__icon{color:var(--orange)}.toolkit-badge[data-color=blue] .toolkit-badge__icon{color:var(--blue)}.toolkit-badge[data-color=purple] .toolkit-badge__icon{color:var(--purple)}.toolkit-badge[data-color=green] .toolkit-badge__icon{color:var(--green)}.toolkit-badge__label{font-size:.82rem;font-weight:600;letter-spacing:.01em;color:var(--text-light);text-align:center;line-height:1.3}.toolkit-badge.is-unlocked .toolkit-badge__label{color:var(--text)}.bsm-verse-context{color:var(--text-light);border-radius:4px;padding:1px 3px;-webkit-box-decoration-break:clone;box-decoration-break:clone}.bsm-verse-highlight{background:none;color:var(--text)}[data-rule=structural] .bsm-verse-context{background:color-mix(in srgb,var(--purple) 14%,transparent);color:var(--text)}[data-rule=investigation] .bsm-verse-highlight{background:color-mix(in srgb,var(--green) 12%,transparent);border-radius:4px;padding:1px 3px;-webkit-box-decoration-break:clone;box-decoration-break:clone}:root[data-theme=dark] .bsm-rule__reveal-text{background:color-mix(in srgb,var(--green) 10%,var(--bg))}:root[data-theme=dark] .bsm-rule__extra-pill{background:color-mix(in srgb,var(--bg-secondary) 80%,var(--bg))}:root[data-theme=dark] .bsm-structural__reveal-btn{background:color-mix(in srgb,var(--purple) 12%,var(--bg))}@media(max-width:540px){.bsm-investigation__markers{grid-template-columns:repeat(2,1fr)}.bsm-complete__badges{grid-template-columns:repeat(2,1fr);gap:8px}.toolkit-badge{padding:18px 12px 14px}}@media(max-width:360px){.bsm-complete__badges{grid-template-columns:1fr;gap:8px}}@media(min-width:600px){.bsm-verse-card{padding:24px}.bsm-title{font-size:1.75rem}}@media(prefers-reduced-motion:reduce){.interactive-verse__keyword,.bsm-investigation__marker,.bsm-structural__reveal-btn{transition:none}}.family-delete-btn{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--tint-red);color:var(--red);display:inline-flex;align-items:center;justify-content:center;border:none;cursor:pointer;flex-shrink:0;transition:transform .14s ease}.family-delete-btn:hover{transform:translateY(-2px)}.family-delete-btn:disabled{opacity:.5;pointer-events:none}.family-settings-message{margin:14px 0 0;padding:12px 14px;border-radius:var(--radius-sm);background:var(--tint-red);color:var(--red-dark);font-size:13px;font-weight:600}.alpha-gate__content{--background: linear-gradient(320deg, rgba(24, 144, 255, .11) 0%, transparent 30%), linear-gradient(40deg, rgba(88, 204, 2, .08) 4%, transparent 34%), linear-gradient(0deg, rgba(255, 255, 255, .52) 0%, rgba(255, 255, 255, 0) 28%), linear-gradient(0deg, #f4fbff 0%, #f8fcff 42%, #fefbf6 100%)}[data-theme=sepia] .alpha-gate__content{--background: linear-gradient(325deg, rgba(181, 132, 78, .14) 0%, transparent 32%), linear-gradient(45deg, rgba(235, 193, 120, .11) 8%, transparent 38%), linear-gradient(0deg, rgba(255, 248, 238, .4) 0%, rgba(255, 248, 238, 0) 26%), linear-gradient(0deg, #faf4e8 0%, #f6ede0 44%, #ede1cf 100%)}[data-theme=gray] .alpha-gate__content{--background: linear-gradient(320deg, rgba(91, 130, 168, .12) 0%, transparent 30%), linear-gradient(40deg, rgba(176, 184, 198, .16) 10%, transparent 40%), linear-gradient(0deg, rgba(255, 255, 255, .34) 0%, rgba(255, 255, 255, 0) 24%), linear-gradient(0deg, #f7f8fc 0%, #eef1f6 44%, #e5e9f1 100%)}[data-theme=dark] .alpha-gate__content{--background: linear-gradient(145deg, rgba(28, 176, 246, .08) 0%, transparent 26%), linear-gradient(225deg, rgba(88, 204, 2, .048) 6%, transparent 30%), linear-gradient(180deg, rgba(255, 255, 255, .018) 0%, rgba(255, 255, 255, 0) 18%), linear-gradient( 180deg, rgba(7, 9, 16, .985) 0%, rgba(10, 12, 21, .97) 28%, rgba(14, 14, 26, .94) 66%, rgba(14, 14, 26, .94) 100% )}.alpha-gate__container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100%;padding:1.5rem;position:relative;z-index:1}.alpha-gate__card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.5rem 2rem;display:flex;flex-direction:column;align-items:center;text-align:center;gap:.75rem;position:relative}.alpha-gate__icon-wrap{display:flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:50%;background:var(--ion-color-primary, #58cc02);color:var(--ion-color-primary-contrast, #ffffff);margin-bottom:.25rem;box-shadow:0 4px 20px #58cc0240,0 0 0 6px #58cc0214}.alpha-gate__title{font-size:1.6rem;font-weight:700;color:var(--ion-text-color, #111111);margin:0}.alpha-gate__body{font-size:1rem;color:var(--ion-color-medium, #92949c);max-width:320px;margin:0;line-height:1.5}.alpha-gate__body--small{font-size:.875rem}.alpha-gate__body strong{color:var(--ion-text-color, #111111)}.alpha-gate__code-card{display:flex;flex-direction:column;align-items:center;gap:.75rem;width:100%;max-width:340px;padding:1.25rem 1.5rem;border-radius:20px;background:#ffffff8c;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.6);box-shadow:0 4px 24px #0000000a,0 1px 4px #00000005;margin-top:.25rem}[data-theme=sepia] .alpha-gate__code-card{background:#faf4e899;border-color:#d2bea066}[data-theme=gray] .alpha-gate__code-card{background:#eef1f699;border-color:#c8d2e080}[data-theme=dark] .alpha-gate__code-card{background:#14162299;border-color:#ffffff0f;box-shadow:0 4px 24px #0003,0 1px 4px #0000001a}.alpha-gate__code-label{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--ion-color-medium, #92949c)}.alpha-gate__code-input-wrap{width:100%}.alpha-gate__code-input{width:100%;padding:.875rem 1rem;border-radius:14px;border:2px solid var(--ion-border-color, #d9d9d9);background:var(--ion-background-color, #ffffff);font-family:SF Mono,Fira Code,Cascadia Code,Menlo,Consolas,monospace;font-size:1.25rem;font-weight:600;letter-spacing:4px;text-align:center;color:var(--ion-text-color, #111111);outline:none;transition:border-color .2s ease,box-shadow .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;box-sizing:border-box}.alpha-gate__code-input::placeholder{font-family:inherit;font-size:.85rem;font-weight:500;letter-spacing:1px;color:var(--ion-color-medium, #92949c);opacity:.6}.alpha-gate__code-input:focus{border-color:var(--ion-color-primary, #58cc02);box-shadow:0 0 0 3px #58cc021f}.alpha-gate__code-input--error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.alpha-gate__code-input--error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef444426}[data-theme=dark] .alpha-gate__code-input{background:#1e2030cc;border-color:#ffffff1a}[data-theme=dark] .alpha-gate__code-input:focus{border-color:var(--ion-color-primary, #58cc02);box-shadow:0 0 0 3px #58cc022e}.alpha-gate__code-error{font-size:.825rem;color:#ef4444;margin:0;overflow:hidden;line-height:1.4}.alpha-gate__divider{display:flex;align-items:center;width:100%;max-width:280px;gap:.75rem;margin:.25rem 0}.alpha-gate__divider:before,.alpha-gate__divider:after{content:"";flex:1;height:1px;background:var(--ion-border-color, #d9d9d9);opacity:.5}.alpha-gate__divider span{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:1px;color:var(--ion-color-medium, #92949c);flex-shrink:0}.alpha-gate__actions{display:flex;flex-direction:column;align-items:center;gap:.75rem;width:100%;max-width:280px}.alpha-gate__btn{width:100%;padding:.75rem 1.5rem;border-radius:14px;font-size:1rem;font-weight:600;cursor:pointer;border:none;transition:opacity .15s ease,transform .1s ease}.alpha-gate__btn:active:not(:disabled){transform:scale(.98)}.alpha-gate__btn:disabled{opacity:.5;cursor:not-allowed}.alpha-gate__btn--primary{background:var(--ion-color-primary, #58cc02);color:var(--ion-color-primary-contrast, #ffffff);box-shadow:0 2px 8px #58cc0233}.alpha-gate__btn--redeem{max-width:100%}.alpha-gate__btn--secondary{background:var(--tint-neutral, rgba(0, 0, 0, .04));color:var(--ion-text-color, #111111)}[data-theme=dark] .alpha-gate__btn--secondary{background:#ffffff0f}.alpha-gate__btn--ghost{background:transparent;color:var(--ion-color-medium, #92949c);font-weight:500;font-size:.875rem;padding:.5rem 1rem}:root{--ion-color-primary: #0054e9;--ion-color-primary-rgb: 0, 84, 233;--ion-color-primary-contrast: #fff;--ion-color-primary-contrast-rgb: 255, 255, 255;--ion-color-primary-shade: #004acd;--ion-color-primary-tint: #1a65eb;--ion-color-secondary: #0163aa;--ion-color-secondary-rgb: 1, 99, 170;--ion-color-secondary-contrast: #fff;--ion-color-secondary-contrast-rgb: 255, 255, 255;--ion-color-secondary-shade: #015796;--ion-color-secondary-tint: #1a73b3;--ion-color-tertiary: #6030ff;--ion-color-tertiary-rgb: 96, 48, 255;--ion-color-tertiary-contrast: #fff;--ion-color-tertiary-contrast-rgb: 255, 255, 255;--ion-color-tertiary-shade: #542ae0;--ion-color-tertiary-tint: #7045ff;--ion-color-success: #2dd55b;--ion-color-success-rgb: 45, 213, 91;--ion-color-success-contrast: #000;--ion-color-success-contrast-rgb: 0, 0, 0;--ion-color-success-shade: #28bb50;--ion-color-success-tint: #42d96b;--ion-color-warning: #ffc409;--ion-color-warning-rgb: 255, 196, 9;--ion-color-warning-contrast: #000;--ion-color-warning-contrast-rgb: 0, 0, 0;--ion-color-warning-shade: #e0ac08;--ion-color-warning-tint: #ffca22;--ion-color-danger: #c5000f;--ion-color-danger-rgb: 197, 0, 15;--ion-color-danger-contrast: #fff;--ion-color-danger-contrast-rgb: 255, 255, 255;--ion-color-danger-shade: #ad000d;--ion-color-danger-tint: #cb1a27;--ion-color-light: #f4f5f8;--ion-color-light-rgb: 244, 245, 248;--ion-color-light-contrast: #000;--ion-color-light-contrast-rgb: 0, 0, 0;--ion-color-light-shade: #d7d8da;--ion-color-light-tint: #f5f6f9;--ion-color-medium: #636469;--ion-color-medium-rgb: 99, 100, 105;--ion-color-medium-contrast: #fff;--ion-color-medium-contrast-rgb: 255, 255, 255;--ion-color-medium-shade: #57585c;--ion-color-medium-tint: #737478;--ion-color-dark: #222428;--ion-color-dark-rgb: 34, 36, 40;--ion-color-dark-contrast: #fff;--ion-color-dark-contrast-rgb: 255, 255, 255;--ion-color-dark-shade: #1e2023;--ion-color-dark-tint: #383a3e}html.ios{--ion-default-font: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Roboto", sans-serif}html.md{--ion-default-font: "Roboto", "Helvetica Neue", sans-serif}html{--ion-dynamic-font: -apple-system-body;--ion-font-family: var(--ion-default-font)}body{background:var(--ion-background-color);color:var(--ion-text-color)}body.backdrop-no-scroll{overflow:hidden}html.ios ion-modal.modal-card ion-header ion-toolbar:first-of-type,html.ios ion-modal.modal-sheet ion-header ion-toolbar:first-of-type,html.ios ion-modal ion-footer ion-toolbar:first-of-type,html.ios ion-footer.modal-footer-moving ion-toolbar:first-of-type{padding-top:6px}html.ios ion-modal.modal-card ion-header ion-toolbar:last-of-type,html.ios ion-modal.modal-sheet ion-header ion-toolbar:last-of-type{padding-bottom:6px}html.ios ion-modal ion-toolbar,html.ios .modal-footer-moving ion-toolbar{padding-right:calc(var(--ion-safe-area-right) + 8px);padding-left:calc(var(--ion-safe-area-left) + 8px)}@media screen and (min-width:768px){html.ios ion-modal.modal-card:first-of-type{--backdrop-opacity: .18}}ion-modal.modal-default.show-modal~ion-modal.modal-default{--backdrop-opacity: 0;--box-shadow: none}html.ios ion-modal.modal-card .ion-page{border-top-left-radius:var(--border-radius)}.ion-color-primary{--ion-color-base: var(--ion-color-primary, #0054e9) !important;--ion-color-base-rgb: var(--ion-color-primary-rgb, 0, 84, 233) !important;--ion-color-contrast: var(--ion-color-primary-contrast, #fff) !important;--ion-color-contrast-rgb: var(--ion-color-primary-contrast-rgb, 255, 255, 255) !important;--ion-color-shade: var(--ion-color-primary-shade, #004acd) !important;--ion-color-tint: var(--ion-color-primary-tint, #1a65eb) !important}.ion-color-secondary{--ion-color-base: var(--ion-color-secondary, #0163aa) !important;--ion-color-base-rgb: var(--ion-color-secondary-rgb, 1, 99, 170) !important;--ion-color-contrast: var(--ion-color-secondary-contrast, #fff) !important;--ion-color-contrast-rgb: var(--ion-color-secondary-contrast-rgb, 255, 255, 255) !important;--ion-color-shade: var(--ion-color-secondary-shade, #015796) !important;--ion-color-tint: var(--ion-color-secondary-tint, #1a73b3) !important}.ion-color-tertiary{--ion-color-base: var(--ion-color-tertiary, #6030ff) !important;--ion-color-base-rgb: var(--ion-color-tertiary-rgb, 96, 48, 255) !important;--ion-color-contrast: var(--ion-color-tertiary-contrast, #fff) !important;--ion-color-contrast-rgb: var(--ion-color-tertiary-contrast-rgb, 255, 255, 255) !important;--ion-color-shade: var(--ion-color-tertiary-shade, #542ae0) !important;--ion-color-tint: var(--ion-color-tertiary-tint, #7045ff) !important}.ion-color-success{--ion-color-base: var(--ion-color-success, #2dd55b) !important;--ion-color-base-rgb: var(--ion-color-success-rgb, 45, 213, 91) !important;--ion-color-contrast: var(--ion-color-success-contrast, #000) !important;--ion-color-contrast-rgb: var(--ion-color-success-contrast-rgb, 0, 0, 0) !important;--ion-color-shade: var(--ion-color-success-shade, #28bb50) !important;--ion-color-tint: var(--ion-color-success-tint, #42d96b) !important}.ion-color-warning{--ion-color-base: var(--ion-color-warning, #ffc409) !important;--ion-color-base-rgb: var(--ion-color-warning-rgb, 255, 196, 9) !important;--ion-color-contrast: var(--ion-color-warning-contrast, #000) !important;--ion-color-contrast-rgb: var(--ion-color-warning-contrast-rgb, 0, 0, 0) !important;--ion-color-shade: var(--ion-color-warning-shade, #e0ac08) !important;--ion-color-tint: var(--ion-color-warning-tint, #ffca22) !important}.ion-color-danger{--ion-color-base: var(--ion-color-danger, #c5000f) !important;--ion-color-base-rgb: var(--ion-color-danger-rgb, 197, 0, 15) !important;--ion-color-contrast: var(--ion-color-danger-contrast, #fff) !important;--ion-color-contrast-rgb: var(--ion-color-danger-contrast-rgb, 255, 255, 255) !important;--ion-color-shade: var(--ion-color-danger-shade, #ad000d) !important;--ion-color-tint: var(--ion-color-danger-tint, #cb1a27) !important}.ion-color-light{--ion-color-base: var(--ion-color-light, #f4f5f8) !important;--ion-color-base-rgb: var(--ion-color-light-rgb, 244, 245, 248) !important;--ion-color-contrast: var(--ion-color-light-contrast, #000) !important;--ion-color-contrast-rgb: var(--ion-color-light-contrast-rgb, 0, 0, 0) !important;--ion-color-shade: var(--ion-color-light-shade, #d7d8da) !important;--ion-color-tint: var(--ion-color-light-tint, #f5f6f9) !important}.ion-color-medium{--ion-color-base: var(--ion-color-medium, #636469) !important;--ion-color-base-rgb: var(--ion-color-medium-rgb, 99, 100, 105) !important;--ion-color-contrast: var(--ion-color-medium-contrast, #fff) !important;--ion-color-contrast-rgb: var(--ion-color-medium-contrast-rgb, 255, 255, 255) !important;--ion-color-shade: var(--ion-color-medium-shade, #57585c) !important;--ion-color-tint: var(--ion-color-medium-tint, #737478) !important}.ion-color-dark{--ion-color-base: var(--ion-color-dark, #222428) !important;--ion-color-base-rgb: var(--ion-color-dark-rgb, 34, 36, 40) !important;--ion-color-contrast: var(--ion-color-dark-contrast, #fff) !important;--ion-color-contrast-rgb: var(--ion-color-dark-contrast-rgb, 255, 255, 255) !important;--ion-color-shade: var(--ion-color-dark-shade, #1e2023) !important;--ion-color-tint: var(--ion-color-dark-tint, #383a3e) !important}.ion-page{left:0;right:0;top:0;bottom:0;display:flex;position:absolute;flex-direction:column;justify-content:space-between;contain:layout size style;z-index:0}.ion-page.ion-page-overlay-passthrough{pointer-events:none}ion-modal>.ion-page{position:relative;contain:layout style;height:100%}.split-pane-visible>.ion-page.split-pane-main{position:relative}ion-route,ion-route-redirect,ion-router,ion-select-option,ion-nav-controller,ion-menu-controller,ion-action-sheet-controller,ion-alert-controller,ion-loading-controller,ion-modal-controller,ion-picker-controller,ion-popover-controller,ion-toast-controller,.ion-page-hidden{display:none!important}.ion-page-invisible{opacity:0}.can-go-back>ion-header ion-back-button{display:block}html.plt-ios.plt-hybrid,html.plt-ios.plt-pwa{--ion-statusbar-padding: 20px}@supports (padding-top: 20px){html{--ion-safe-area-top: var(--ion-statusbar-padding)}}@supports (padding-top: env(safe-area-inset-top)){html{--ion-safe-area-top: var(--safe-area-inset-top, env(safe-area-inset-top));--ion-safe-area-bottom: var(--safe-area-inset-bottom, env(safe-area-inset-bottom));--ion-safe-area-left: var(--safe-area-inset-left, env(safe-area-inset-left));--ion-safe-area-right: var(--safe-area-inset-right, env(safe-area-inset-right))}}ion-card.ion-color .ion-inherit-color,ion-card-header.ion-color .ion-inherit-color{color:inherit}.menu-content{transform:translateZ(0)}.menu-content-open{cursor:pointer;touch-action:manipulation;pointer-events:none;overflow-y:hidden}.menu-content-open ion-content{--overflow: hidden}.menu-content-open .ion-content-scroll-host{overflow:hidden}.ios .menu-content-reveal{box-shadow:-8px 0 42px #00000014}[dir=rtl].ios .menu-content-reveal{box-shadow:8px 0 42px #00000014}.md .menu-content-reveal,.md .menu-content-push{box-shadow:4px 0 16px #0000002e}ion-accordion-group.accordion-group-expand-inset>ion-accordion:first-of-type{border-top-left-radius:8px;border-top-right-radius:8px}ion-accordion-group.accordion-group-expand-inset>ion-accordion:last-of-type{border-bottom-left-radius:8px;border-bottom-right-radius:8px}ion-accordion-group>ion-accordion:last-of-type ion-item[slot=header]{--border-width: 0px}ion-accordion.accordion-animated>[slot=header] .ion-accordion-toggle-icon{transition:.3s transform cubic-bezier(.25,.8,.5,1)}@media(prefers-reduced-motion:reduce){ion-accordion .ion-accordion-toggle-icon{transition:none!important}}ion-accordion.accordion-expanding>[slot=header] .ion-accordion-toggle-icon,ion-accordion.accordion-expanded>[slot=header] .ion-accordion-toggle-icon{transform:rotate(180deg)}ion-accordion-group.accordion-group-expand-inset.md>ion-accordion.accordion-previous ion-item[slot=header]{--border-width: 0px;--inner-border-width: 0px}ion-accordion-group.accordion-group-expand-inset.md>ion-accordion.accordion-expanding:first-of-type,ion-accordion-group.accordion-group-expand-inset.md>ion-accordion.accordion-expanded:first-of-type{margin-top:0}ion-input input::-webkit-date-and-time-value{text-align:start}.ion-datetime-button-overlay{--width: fit-content;--height: fit-content}.ion-datetime-button-overlay ion-datetime.datetime-grid{width:320px;min-height:320px}[ion-last-focus],header[tabindex="-1"]:focus,[role=banner][tabindex="-1"]:focus,main[tabindex="-1"]:focus,[role=main][tabindex="-1"]:focus,h1[tabindex="-1"]:focus,[role=heading][aria-level="1"][tabindex="-1"]:focus{outline:none}.popover-viewport:has(>ion-content){overflow:hidden}@supports not selector(:has(> ion-content)){.popover-viewport{overflow:hidden}}audio,canvas,progress,video{vertical-align:baseline}audio:not([controls]){display:none;height:0}b,strong{font-weight:700}img{max-width:100%}hr{height:1px;border-width:0;box-sizing:content-box}pre{overflow:auto}code,kbd,pre,samp{font-family:monospace,monospace;font-size:1em}label,input,select,textarea{font-family:inherit;line-height:normal}textarea{overflow:auto;height:auto;font:inherit;color:inherit}textarea::placeholder{padding-left:2px}form,input,optgroup,select{margin:0;font:inherit;color:inherit}html input[type=button],input[type=reset],input[type=submit]{cursor:pointer;-webkit-appearance:button}a,a div,a span,a ion-icon,a ion-label,button,button div,button span,button ion-icon,button ion-label,.ion-tappable,[tappable],[tappable] div,[tappable] span,[tappable] ion-icon,[tappable] ion-label,input,textarea{touch-action:manipulation}a ion-label,button ion-label{pointer-events:none}button{padding:0;border:0;border-radius:0;font-family:inherit;font-style:inherit;font-variant:inherit;line-height:1;text-transform:none;cursor:pointer;-webkit-appearance:button}[tappable]{cursor:pointer}a[disabled],button[disabled],html input[disabled]{cursor:default}button::-moz-focus-inner,input::-moz-focus-inner{padding:0;border:0}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{height:auto}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}table{border-collapse:collapse;border-spacing:0}td,th{padding:0}*{box-sizing:border-box;-webkit-tap-highlight-color:rgba(0,0,0,0);-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}html{width:100%;height:100%;-webkit-text-size-adjust:100%;text-size-adjust:100%}html.ion-ce body{display:block}html.plt-pwa{height:100vh}body{-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;margin:0;padding:0;position:fixed;width:100%;max-width:100%;height:100%;max-height:100%;transform:translateZ(0);text-rendering:optimizeLegibility;overflow:hidden;touch-action:manipulation;-webkit-user-drag:none;-ms-content-zooming:none;word-wrap:break-word;overscroll-behavior-y:none;-webkit-text-size-adjust:none;text-size-adjust:none}html{font-family:var(--ion-font-family)}@supports (-webkit-touch-callout: none){html{font:var(--ion-dynamic-font, 16px var(--ion-font-family))}}a{background-color:transparent;color:var(--ion-color-primary, #0054e9)}h1,h2,h3,h4,h5,h6{margin-top:16px;margin-bottom:10px;font-weight:500;line-height:1.2}h1{margin-top:20px;font-size:1.625rem}h2{margin-top:18px;font-size:1.5rem}h3{font-size:1.375rem}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}small{font-size:75%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sup{top:-.5em}sub{bottom:-.25em}:root{--ion-background-color: var(--bg);--ion-text-color: var(--text);--ion-font-family: var(--font);--ion-color-primary: #58cc02;--ion-color-primary-rgb: 88, 204, 2;--ion-color-primary-contrast: #ffffff;--ion-color-primary-shade: #46a302;--ion-color-primary-tint: #69d11b;--ion-color-secondary: #1cb0f6;--ion-color-secondary-rgb: 28, 176, 246;--ion-color-secondary-contrast: #ffffff;--ion-color-secondary-shade: #1899d6;--ion-color-secondary-tint: #33b8f7;--ion-color-danger: #ff4b4b;--ion-color-danger-rgb: 255, 75, 75;--ion-color-danger-contrast: #ffffff;--ion-color-danger-shade: #ea2b2b;--ion-color-danger-tint: #ff5d5d;--ion-color-warning: #ff9600;--ion-color-warning-rgb: 255, 150, 0;--ion-color-warning-contrast: #000000;--ion-color-warning-shade: #e08400;--ion-color-warning-tint: #ffa11a;--ion-card-background: var(--surface);--ion-item-background: var(--surface);--ion-toolbar-background: var(--glass-bg);--ion-tab-bar-background: var(--surface);--ion-border-color: var(--border);--ion-safe-area-top: max(env(safe-area-inset-top, 0px), var(--safe-area-inset-top, 0px));--ion-safe-area-bottom: max(env(safe-area-inset-bottom, 0px), var(--safe-area-inset-bottom, 0px));--ion-safe-area-left: max(env(safe-area-inset-left, 0px), var(--safe-area-inset-left, 0px));--ion-safe-area-right: max(env(safe-area-inset-right, 0px), var(--safe-area-inset-right, 0px))}[data-theme=sepia]{--ion-background-color: #f5f1eb}[data-theme=gray]{--ion-background-color: #f0f0f3;--ion-border-color: #dddde2}[data-theme=dark]{--ion-background-color: #121214;--ion-text-color: #f0ece6;--ion-card-background: #1c1c1e;--ion-item-background: #1c1c1e;--ion-toolbar-background: rgba(28, 28, 30, .85);--ion-tab-bar-background: #1c1c1e;--ion-border-color: #3a3a3c;--ion-color-secondary: #1cb0f6;--ion-color-secondary-rgb: 28, 176, 246;--ion-color-secondary-shade: #1899d6;--ion-color-secondary-tint: #33b8f7;--ion-color-secondary-contrast: #ffffff}[dir=rtl]{--font: "Rubik", "Vazirmatn", var(--ion-font-family, sans-serif);--font-reading: "Noto Naskh Arabic", "Vazirmatn", Georgia, serif}:root{color-scheme:light;--logo-color: #052225;--green: #58cc02;--green-dark: #46a302;--red: #ff4b4b;--red-dark: #ea2b2b;--blue: #1cb0f6;--blue-dark: #1899d6;--blue-rgb: 28, 176, 246;--orange: #ff9600;--amber: #f59e0b;--purple: #ce82ff;--accent: #1cb0f6;--accent-dark: #1899d6;--bg: #ffffff;--surface: #ffffff;--surface-elevated: #ffffff;--text: #3c3c3c;--text-light: #777777;--border: #e5e5e5;--radius: 16px;--radius-sm: 12px;--radius-lg: 24px;--shadow: 0 2px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .12);--font: "Rubik", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-reading: "Literata", Georgia, "Times New Roman", serif;--max-width: 520px;--overlay-bg: rgba(0, 0, 0, .45);--tint-blue: #e3f2fd;--tint-blue-strong: #bbdefb;--tint-orange: #fff3e0;--tint-green: #e8f5e9;--tint-yellow: #fff8e1;--tint-yellow-strong: #fff9e6;--tint-yellow-border: #ffe082;--tint-red: #ffebee;--tint-purple: #f3e5f5;--tint-neutral: #fafafa;--tint-correct: #d7f5dd;--tint-incorrect: #fddfe0;--glass-bg: rgba(255, 255, 255, .8);--glass-border: rgba(255, 255, 255, .5);--shadow-node: 0 6px 0 var(--green-dark);--shadow-node-hover: 0 6px 0 var(--blue-dark);--shadow-card: 0 2px 12px rgba(0, 0, 0, .06), 0 0 0 1px rgba(0, 0, 0, .03);--shadow-card-hover: 0 8px 24px rgba(0, 0, 0, .1), 0 0 0 1px rgba(0, 0, 0, .04);--node-size: 72px;--node-size-active: 80px;--sub-node-size: 48px;--path-color: var(--border);--path-color-done: var(--green);--gradient-hero: linear-gradient(135deg, #f8fbff 0%, #f0f7ff 50%, #f8f5ff 100%);--gradient-green: linear-gradient(135deg, #58cc02, #46a302);--gradient-blue: linear-gradient(135deg, #1cb0f6, #1899d6);--gradient-gold: linear-gradient(135deg, #ffb300, #ff8f00);--gradient-purple: linear-gradient(135deg, #ce82ff, #a855f7);--btn-3d-depth: 5px;--z-overlay: 1000;--z-overlay-elevated: 5000;--z-overlay-popover: 10000;--child-color-1-from: #6366f1;--child-color-1-to: #8b5cf6;--child-color-2-from: #10b981;--child-color-2-to: #059669;--child-color-3-from: #f59e0b;--child-color-3-to: #d97706;--child-color-4-from: #ec4899;--child-color-4-to: #db2777;--child-color-5-from: #14b8a6;--child-color-5-to: #0d9488}[data-theme=sepia]{--bg: #f5f1eb;--tint-neutral: #f0ece5}[data-theme=gray]{--bg: #f0f0f3;--border: #dddde2;--tint-neutral: #eaeaee}[data-theme=dark]{color-scheme:dark;--logo-color: #f0ece6;--bg: #121214;--surface: #1c1c1e;--surface-elevated: #2c2c2e;--text: #f0ece6;--text-light: #a09a90;--border: #3a3a3c;--blue: #1cb0f6;--blue-dark: #1899d6;--blue-rgb: 28, 176, 246;--accent: #d4a44a;--accent-dark: #b8892e;--shadow: 0 2px 8px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--overlay-bg: rgba(0, 0, 0, .65);--tint-blue: rgba(28, 176, 246, .15);--tint-blue-strong: rgba(28, 176, 246, .25);--tint-orange: rgba(255, 150, 0, .12);--tint-green: rgba(88, 204, 2, .12);--tint-yellow: rgba(255, 224, 130, .1);--tint-yellow-strong: rgba(255, 224, 130, .15);--tint-yellow-border: rgba(255, 224, 130, .3);--tint-red: rgba(255, 75, 75, .12);--tint-purple: rgba(206, 130, 255, .12);--tint-neutral: rgba(255, 255, 255, .05);--tint-correct: rgba(88, 204, 2, .18);--tint-incorrect: rgba(255, 75, 75, .18);--glass-bg: rgba(28, 28, 30, .85);--glass-border: rgba(255, 255, 255, .08);--shadow-node: 0 6px 0 rgba(0, 0, 0, .4);--shadow-node-hover: 0 6px 0 rgba(212, 164, 74, .6);--shadow-card: 0 2px 12px rgba(0, 0, 0, .2), 0 0 0 1px rgba(255, 255, 255, .04);--shadow-card-hover: 0 8px 24px rgba(0, 0, 0, .3), 0 0 0 1px rgba(255, 255, 255, .06);--gradient-hero: linear-gradient(135deg, #121214 0%, #1c1c1e 50%, #181820 100%);--child-color-1-from: #818cf8;--child-color-1-to: #a78bfa;--child-color-2-from: #34d399;--child-color-2-to: #10b981;--child-color-3-from: #fbbf24;--child-color-3-to: #f59e0b;--child-color-4-from: #f472b6;--child-color-4-to: #ec4899;--child-color-5-from: #2dd4bf;--child-color-5-to: #14b8a6}[data-theme=dark] .card-container{border-color:var(--glass-border)}[data-theme=dark] .finish-icon{box-shadow:0 8px 32px #00000080,0 0 60px #ffb30026}[data-theme=dark] .finish-streak-badge{background:var(--surface);border-color:var(--glass-border)}[data-theme=dark] .finish-new-best{box-shadow:0 2px 8px #0006}[data-theme=dark] .start-btn.start-btn--tertiary{border-color:var(--glass-border);color:var(--text-muted)}[data-theme=dark] .finish-section-row{background:var(--surface);border-color:var(--glass-border)}[data-theme=dark] .lesson-start-sheet .sheet-hero{background:var(--gradient-blue)}[data-theme=dark] .sheet-container{background:linear-gradient(180deg,#ffffff08,#fff0 18%),linear-gradient(180deg,var(--surface-elevated) 0%,var(--surface) 100%);border:1px solid var(--glass-border);box-shadow:0 -12px 40px #0000006b,0 0 0 1px #ffffff08;color:var(--text)}[data-theme=dark] .sheet-close{background:var(--surface-elevated);border-color:var(--glass-border);color:var(--text-light)}[data-theme=dark] .sheet-close:hover{background:color-mix(in srgb,var(--surface-elevated) 82%,var(--red) 18%);border-color:color-mix(in srgb,var(--glass-border) 65%,var(--red) 35%);color:#ff8f8f}[data-theme=dark] .sheet-source{background:color-mix(in srgb,var(--surface-elevated) 86%,transparent);border-color:var(--glass-border);color:var(--text-light)}[data-theme=dark] .lesson-start-sheet .sheet-hero:after{background:var(--surface)}[data-theme=dark] .lesson-start-sheet .sheet-body{color:var(--text)}[data-theme=dark] .lesson-start-sheet .sheet-desc{color:var(--text-light)}[data-theme=dark] .unit-row{border-color:var(--glass-border);background:linear-gradient(180deg,#ffffff09,#fff0),var(--surface);box-shadow:0 8px 20px #00000029}[data-theme=dark] .unit-row:hover{border-color:color-mix(in srgb,var(--blue) 40%,var(--glass-border));background:linear-gradient(180deg,#ffffff0d,#fff0),var(--surface-elevated);box-shadow:0 12px 28px #00000038}[data-theme=dark] .unit-row.selected{border-color:var(--unit-accent, var(--blue));background:linear-gradient(180deg,#ffffff0e,#fff0),var(--surface-elevated);box-shadow:0 0 0 1px color-mix(in srgb,var(--unit-accent, var(--blue)) 24%,transparent),0 14px 30px #0000003d}[data-theme=dark] .unit-row__label{color:var(--text)}[data-theme=dark] .unit-row__desc,[data-theme=dark] .unit-row__status,[data-theme=dark] .card-count{color:var(--text-light)}[data-theme=dark] .unit-meta__item{background:var(--surface);border-color:var(--glass-border)}[data-theme=dark] .cross-ref-teaching{background:#2a1a38}[data-theme=dark] .path-section__label{background:var(--surface);border-color:var(--glass-border);box-shadow:0 2px 8px #00000040}[data-theme=dark] .study-card,[data-theme=dark] .lesson-card-premium{border-color:var(--glass-border)}[data-theme=dark] .lesson-card-premium__progress-track{background:#ffffff0f}[data-theme=dark] .diff-btn-3d{box-shadow:0 4px 0 0 var(--btn-shadow),0 4px 8px #0000004d}[data-theme=dark] .section-header__count{border-color:var(--glass-border);background:var(--surface)}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .2s ease}.app{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}@media(max-width:360px){.card-question{font-size:20px}.lesson-grid{grid-template-columns:1fr}.matching-headers{display:none}.matching-columns{grid-template-columns:1fr;gap:8px}.emoji-grid{grid-template-columns:1fr}.session-header{padding:calc(12px + var(--ion-safe-area-top, env(safe-area-inset-top, 0px))) 12px 12px;gap:8px}.sp-label{font-size:12px}.sp-thumb{width:44px;height:44px}.sp-thumb-inner{width:16px;height:16px}.sp-value{font-size:34px}}@media(max-width:480px){.card-question{font-size:21px;margin-bottom:16px}.hero-title{font-size:22px}.session-body{padding:8px 12px 20px;padding-bottom:calc(20px + env(safe-area-inset-bottom,0px))}.options-list{gap:6px}.option-btn{padding:12px 14px}.statement-box{margin-bottom:12px;padding:14px}.sns-instruction{margin-bottom:8px}.insight-card{margin-bottom:14px}.insight-card__inner{padding:10px 12px}.path-node__label{max-width:min(38vw,180px)}.path-node__title{font-size:14px}}@media(min-width:600px){.card-question{font-size:25px}.session-header{padding:calc(16px + var(--ion-safe-area-top, env(safe-area-inset-top, 0px))) 20px 16px}.session-body{padding:12px 20px 24px;padding-bottom:calc(24px + env(safe-area-inset-bottom,0px))}.check-btn{padding:16px 44px;font-size:17px}.home-screen{padding-inline:20px}.matching-headers{gap:0 10px}.matching-columns{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:8px 10px}.match-item{min-width:0;min-height:48px;font-size:13px;padding:10px 11px}.match-pair-badge{min-width:22px;height:22px;font-size:11px}.sequence-item{padding:12px 14px}.oia-buckets{flex-wrap:wrap}.bucket-btn{min-width:calc(50% - 4px)}.discard-dialog{padding:20px;border-radius:20px}.discard-dialog__actions{flex-direction:column}}@media(min-width:768px){:root{--max-width: 760px}.card-question{font-size:26px;margin-bottom:28px}.session-header{padding:calc(20px + var(--ion-safe-area-top, env(safe-area-inset-top, 0px))) 24px 20px}.session-body{padding:16px 24px 28px}.card-container{background:var(--surface);padding:24px;border-radius:var(--radius-lg);box-shadow:var(--shadow)}.option-btn{padding:16px 20px;font-size:16px}.check-btn{padding:16px 48px;font-size:17px}.matching-columns{gap:10px 20px}.match-item{padding:14px 18px;font-size:15px}.emoji-grid{gap:16px}.feedback-tray{padding:20px 28px 28px;padding-bottom:calc(28px + env(safe-area-inset-bottom,0px))}.continue-btn{padding:16px;font-size:17px}.word-chip{padding:12px 24px;font-size:17px}.fill-sentence{font-size:20px}.hero-title{font-size:36px}.hero-sub{font-size:18px}.home-screen{padding-inline:24px}.hero-card{flex:0 0 calc(50% - 12px);min-height:280px}.hero-card__title{font-size:22px}.course-unit{max-width:640px;margin-inline:auto}.book-grid{grid-template-columns:repeat(4,1fr);gap:10px}.book-card__icon-wrap{width:42px;height:42px}.learn-path{max-width:600px;margin:0 auto}}@media(min-width:1024px){:root{--max-width: 960px}.card-question{font-size:28px;margin-bottom:32px}.session-header{padding:calc(24px + var(--ion-safe-area-top, env(safe-area-inset-top, 0px))) 32px 24px}.session-body{padding:24px 32px 32px}.card-container{padding:32px;box-shadow:var(--shadow-card-hover)}.option-btn{padding:18px 24px;font-size:17px}.check-btn{padding:18px 64px;font-size:18px;border-radius:var(--radius)}.matching-columns{gap:10px 24px}.match-item{padding:16px 20px;font-size:16px}.emoji-grid{gap:20px}.emoji-icon{font-size:56px}.feedback-tray{padding:20px 32px 32px;padding-bottom:calc(32px + env(safe-area-inset-bottom,0px));border-radius:var(--radius-lg) var(--radius-lg) 0 0}.continue-btn{padding:18px;font-size:18px}.word-chip{padding:14px 28px;font-size:18px}.fill-sentence{font-size:22px}.hero-title{font-size:42px}.hero-sub{font-size:20px}.lesson-grid{gap:20px}.home-screen{padding-inline:32px}.home-screen--tabbed{display:grid;grid-template-columns:1fr 300px;grid-template-rows:1fr;gap:0 28px;align-items:start}.home-screen--tabbed .home-hero{grid-column:1 / -1}.home-screen--tabbed .stats-panel{grid-column:2;grid-row:1;position:sticky;top:0;padding:12px 0 0;max-height:calc(100vh - 80px);max-height:calc(100dvh - 80px);overflow-y:auto}.home-screen--tabbed .stats-pills{flex-direction:column}.home-screen--tabbed .quests-card{margin-top:12px}.home-screen--tabbed .learn-sidebar{grid-column:2;grid-row:1;position:sticky;top:0;padding:12px 0 0;max-height:calc(100vh - 80px);max-height:calc(100dvh - 80px);overflow-y:auto;display:flex;flex-direction:column;gap:0}.home-screen--tabbed .learn-sidebar .stats-panel{position:static;grid-column:unset;grid-row:unset;max-height:none;overflow-y:visible;padding:0}.home-screen--tabbed .home-main-col{grid-column:1;grid-row:1}.home-screen--tabbed .home-tabs{z-index:40;padding-inline-start:0;background:var(--bg);margin-inline-start:0}.home-screen--tabbed .home-content{padding-inline-start:0}.home-screen:not(.home-screen--tabbed){display:grid;grid-template-columns:1fr 360px;grid-template-rows:auto auto auto 1fr;gap:0 28px;align-items:start}.home-screen:not(.home-screen--tabbed) .home-hero{grid-column:1 / -1}.hero-carousel{grid-column:1;grid-row:2;padding-inline:0;gap:20px}.pagination-dots{grid-column:1;grid-row:3}.course-unit{grid-column:2;grid-row:2 / 5;max-width:none;margin:8px 0 0;position:sticky;top:24px}.book-grid{grid-template-columns:repeat(5,1fr);gap:12px}.book-card{padding:16px 10px 14px}.book-card__icon-wrap{width:44px;height:44px}.book-card__name{font-size:14px}.book-group__title{font-size:16px}.learn-path__container{max-width:640px;margin:0 auto}.hero-card{flex:0 0 100%;min-height:300px}.hero-card__title{font-size:26px}.unit-row{padding:16px 20px}.unit-row__label{font-size:16px}.unit-row__desc{font-size:12px}}@media(min-width:1280px){:root{--max-width: 1080px}.card-container{padding:40px}.session-header{padding:calc(24px + var(--ion-safe-area-top, env(safe-area-inset-top, 0px))) 40px 24px}.session-body{padding:24px 40px 36px}.home-screen{grid-template-columns:1fr 400px;gap:0 36px}.hero-card{min-height:320px}.hero-card__title{font-size:28px}.course-unit{padding:28px 24px 24px}}@media(any-hover:hover){.hero-card{transition:transform .2s ease,box-shadow .2s ease}.hero-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #0000001f}.unit-row{transition:border-color .15s,background .15s,box-shadow .15s}.unit-row:hover{box-shadow:0 2px 8px #0000000f}}@media(max-height:500px){.session-header{padding:calc(8px + var(--ion-safe-area-top, env(safe-area-inset-top, 0px))) 16px 8px}.card-question{font-size:18px;margin-bottom:12px}.check-btn{padding:10px 32px}.statement-box{padding:10px;margin-bottom:8px}.sns-instruction{margin-bottom:6px;font-size:12px}.card-category-label{padding:2px 8px;font-size:10px}.milestone-banner{padding:6px 12px;margin-bottom:8px;font-size:13px}.insight-card{margin-bottom:12px;margin-top:-8px}.insight-card__inner{padding:10px;gap:8px}}:focus-visible{outline:3px solid var(--blue);outline-offset:2px;border-radius:inherit}.check-btn:focus-visible,.start-btn:focus-visible,.continue-btn:focus-visible{outline-offset:4px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.progress-fill:after{display:none}}.page-header-toolbar{--background: var(--surface, #fff);--border-width: 0;--min-height: 72px;padding-inline:6px}.page-header-title-wrap{padding-inline:8px}.page-header{display:flex;align-items:center;gap:8px;min-width:0}.page-header__title{margin:0;color:var(--text);font-size:clamp(1.5rem,4vw,1.9rem);font-weight:700;letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.page-header__badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;border-radius:11px;background:var(--blue, #1cb0f6);color:#fff;font-size:.7rem;font-weight:600;font-variant-numeric:tabular-nums;flex:0 0 auto}@media(max-width:480px){.page-header-toolbar{--min-height: 68px;padding-inline:2px}.page-header-title-wrap{padding-inline:4px 8px}.page-header__title{font-size:1.25rem}.page-header-toolbar ion-buttons[slot=start]{margin-inline-end:2px}}.app-tab-bar{--background: var(--surface);--border: var(--border);--color: var(--text-light);--color-selected: var(--green);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom,0px);position:relative;z-index:0}@media(min-width:1024px){ion-tabs{inset-inline-start:var(--nav-rail-width, 68px);width:auto}.app-tab-bar{display:none}}.app-tab-bar ion-tab-button{--color: var(--text-light);--color-selected: var(--green);font-family:var(--font);font-weight:600;font-size:11px}.bidi-isolate{unicode-bidi:isolate;direction:ltr}
