@charset "UTF-8";.skip-link{position:absolute;top:-40px;left:0;padding:8px 16px;background:var(--color-accent);color:#fff;z-index:10000;text-decoration:none;font-size:.875rem}.skip-link:focus{top:0}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}.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}.text-nowrap{white-space:nowrap}.hidden{display:none!important}.hidden-btn{opacity:0;pointer-events:none;transform:translateY(8px);transition:opacity .5s ease,transform .5s ease}.debug-clear-btn{margin-top:.25rem}.debug-custom-exercise{margin-top:.5rem;display:flex;flex-direction:column;gap:.35rem}.debug-input{background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:.4rem .5rem;font-size:.8rem;font-family:inherit}.debug-input:focus{outline:none;border-color:var(--color-brand)}.debug-input:focus-visible{outline:2px solid var(--color-focus);outline-offset:-1px}.debug-input-sm{width:3.5rem}.debug-duration-row{display:flex;align-items:center;gap:.35rem}.debug-duration-label{font-size:.75rem;color:var(--color-text-muted)}.icon{display:inline-block;width:1em;height:1em;fill:currentColor;vertical-align:-.125em}:root{color-scheme:light dark;--color-bg: #0f0c24;--color-brand: #7986cb;--color-brand-glow: rgba(121, 134, 203, .4);--color-brand-secondary: #4A5494;--color-pure-white: #E3DFDF;--color-pure-black: #1F1E1F;--font-display: "Noto Serif", Georgia, serif;--font-body: "Inter", -apple-system, sans-serif;--radius-sm: 12px;--radius-md: 20px;--radius-lg: 28px;--radius-full: 9999px;--transition-fast: .2s ease;--transition-med: .4s ease;--transition-slow: .8s ease;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--space-4xl: 96px;--ease-standard: cubic-bezier(.4, 0, .2, 1);--ease-emphasized: cubic-bezier(.2, .8, .3, 1.2);--ease-decelerate: cubic-bezier(0, 0, .2, 1);--ease-accelerate: cubic-bezier(.4, 0, 1, 1);--duration-instant: .1s;--duration-quick: .2s;--duration-base: .4s;--duration-slow: .8s;--color-on-accent: #ffffff;--splash-logo: #e0daf0;--color-warning: #d97706;--focus-color-tier-0: #0E1A2B;--focus-color-tier-mid: #1B3A5C;--focus-color-tier-high: #3A8B89;--focus-color-tier-peak: #4FB8B5;--page-padding-x: var(--space-lg);--header-height: 80px;--ease-out-quint: cubic-bezier(.16, 1, .3, 1);--ease-out-back: cubic-bezier(.2, .8, .2, 1)}[data-mode=dark]{--color-bg: #0f0c24;--color-surface: rgba(255, 255, 255, .03);--color-surface-hover: rgba(255, 255, 255, .08);--color-surface-border: rgba(255, 255, 255, .1);--color-border: rgba(255, 255, 255, .1);--color-chip-tint: rgba(255, 255, 255, .04);--color-text: var(--color-pure-white);--color-text-muted: rgba(227, 223, 223, .7);--color-text-faint: rgba(227, 223, 223, .7);--color-accent: var(--color-brand);--color-accent-glow: var(--color-brand-glow);--gradient-start: #080614;--gradient-mid: #0d0a2a;--gradient-end: #15102e;--color-overlay-light: rgba(255, 255, 255, .08);--color-overlay-medium: rgba(0, 0, 0, .3);--color-overlay-dark: rgba(0, 0, 0, .6);--color-focus: var(--color-brand);--color-cta-edge: var(--color-brand);--color-danger: #ff6b6b;--color-success: #6bff8a}[data-mode=light]{--color-bg: #d9d6d2;--color-surface: rgba(0, 0, 0, .03);--color-surface-hover: rgba(0, 0, 0, .08);--color-surface-border: rgba(0, 0, 0, .1);--color-border: rgba(0, 0, 0, .1);--color-chip-tint: rgba(0, 0, 0, .04);--color-text: var(--color-pure-black);--color-text-muted: rgba(31, 30, 31, .82);--color-text-faint: rgba(31, 30, 31, .75);--color-accent: var(--color-brand);--color-accent-glow: var(--color-brand-glow);--gradient-start: #c3c1bd;--gradient-mid: #d0ceca;--gradient-end: #d9d6d2;--color-overlay-light: rgba(0, 0, 0, .08);--color-overlay-medium: rgba(0, 0, 0, .3);--color-overlay-dark: rgba(0, 0, 0, .6);--color-focus: #5b68ad;--color-cta-edge: var(--color-brand-secondary);--color-danger: #a51c1c;--color-success: #14532d;--focus-color-tier-0: #C8D5E2;--focus-color-tier-mid: #6B8FB5;--focus-color-tier-high: #2E7976;--focus-color-tier-peak: #1F8C89}html,body{width:100%;height:100vh;height:100dvh;overflow-x:hidden;font-family:var(--font-body);font-weight:400;color:var(--color-text);background-color:var(--color-bg);transition:background-color 3s ease-in-out;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}html{overflow-y:scroll;overscroll-behavior-y:none}body{overflow-y:hidden}#bg-canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;opacity:0;background:var(--color-bg);transition:opacity 3s ease-in-out}#bg-canvas.fade-in{opacity:1}#bg-canvas.fade-in-session{opacity:1;transition:opacity .5s ease-in-out}#bg-canvas.fade-out{opacity:0;transition:opacity .2s ease-in-out}#bg-canvas canvas{position:fixed;top:0;left:0;width:100%;height:100%;display:block;background:transparent}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.debug-panel{position:fixed;bottom:2rem;right:2rem;background-color:var(--color-surface);border:1px solid var(--color-brand);border-radius:var(--radius-md);padding:1.5rem;width:250px;max-height:calc(100vh - 4rem);overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;touch-action:pan-y;box-shadow:0 10px 30px #00000080;z-index:9999;font-family:Inter,sans-serif;display:none}.debug-panel .debug-file-input,.debug-panel .debug-input:not(.debug-input-sm){width:100%;max-width:100%}.debug-panel .debug-file-input{font-size:.75rem;color:var(--color-text-muted)}.debug-panel.open{display:block}.debug-title{color:var(--color-brand);font-size:1rem;margin-bottom:1.5rem;text-transform:uppercase;letter-spacing:.1em;display:flex;align-items:center;gap:.5rem}.debug-section{margin-bottom:1rem}.debug-section label{display:block;font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.debug-btn-group{display:flex;gap:.5rem}.debug-btn{background:#ffffff0d;color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:.5rem .75rem;font-size:.875rem;cursor:pointer;flex:1;transition:background-color var(--duration-quick) var(--ease-standard),border-color var(--duration-quick) var(--ease-standard),color var(--duration-quick) var(--ease-standard)}@media(hover:hover){.debug-btn:hover{background:color-mix(in srgb,var(--color-brand) 25%,transparent);border-color:var(--color-brand)}.debug-btn.active:hover{background:color-mix(in srgb,var(--color-brand) 80%,transparent);color:#fff;border-color:var(--color-brand)}}.debug-btn.active{background:var(--color-brand);color:#fff;border-color:var(--color-brand)}.debug-select{width:100%;background:#ffffff0d;color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:.5rem;font-size:.875rem;font-family:inherit;cursor:pointer}.debug-select option{background:var(--color-bg);color:var(--color-text)}.debug-actions{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:.5rem}.debug-btn-danger{background:#ff6b6b1a;color:#ff6b6b;border-color:#ff6b6b4d;margin-top:.5rem}@media(hover:hover){.debug-btn-danger:hover{background:#ff6b6b;color:#fff;border-color:#ff6b6b}}.debug-btn-skip{background:#6ba5ff1a;color:#6ba5ff;border-color:#6ba5ff4d}@media(hover:hover){.debug-btn-skip:hover{background:#6ba5ff;color:#fff;border-color:#6ba5ff}}.debug-dashboard label{display:flex;align-items:center;gap:.4rem}.debug-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.debug-stat-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-sm);padding:.6rem .5rem;text-align:center;transition:background .2s}@media(hover:hover){.debug-stat-card:hover{background:#ffffff14}}.debug-stat-value{font-family:var(--font-body);font-size:1.4rem;font-weight:500;color:var(--color-text);line-height:1.2;opacity:.3;transition:opacity .4s ease}.debug-stat-value.loaded{opacity:1}.debug-stat-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin-top:.2rem}@media(max-width:640px){.debug-panel{padding:.75rem;width:200px;bottom:1rem;right:1rem;max-height:calc(100vh - 2rem)}.debug-title{font-size:.75rem;margin-bottom:.75rem}.debug-section{margin-bottom:.5rem}.debug-section label{font-size:.65rem;margin-bottom:.25rem}.debug-btn{padding:.3rem .5rem;font-size:.75rem}.debug-select,.debug-input{padding:.3rem;font-size:.75rem}.debug-stats-grid{grid-template-columns:1fr 1fr;gap:.3rem}.debug-stat-card{padding:.35rem .25rem}.debug-stat-value{font-size:.85rem}.debug-stat-label{font-size:.5rem}.debug-actions{margin-top:.75rem;padding-top:.5rem}}@media(min-width:768px){.debug-panel{width:min(560px,calc(100vw - 4rem));max-height:none;overflow-y:visible}.debug-panel.open{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);column-gap:1.5rem;align-content:start}.debug-title,.debug-dashboard,.debug-actions{grid-column:1 / -1}.debug-stats-grid{grid-template-columns:repeat(5,1fr)}.debug-actions{flex-direction:row;flex-wrap:wrap}.debug-actions .debug-btn{flex:1;min-width:0}}#app{position:relative;z-index:1;width:100%;height:100%;min-height:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0;overflow-y:auto;scrollbar-gutter:stable}@media(max-width:767px)and (prefers-reduced-motion:reduce){*{backdrop-filter:none!important;-webkit-backdrop-filter:none!important}}.splash{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:var(--color-bg, #0f0c24);transition:opacity .5s ease}.splash.fade-out{opacity:0;pointer-events:none}.splash.fade-in{opacity:0}.splash.fade-in.visible{opacity:1}.splash__logo{width:clamp(275px,59vw,431px);aspect-ratio:820 / 128;background-color:var(--splash-logo, #e0daf0);-webkit-mask-image:url(/asset/meditation-everyday-logo-inline.svg);mask-image:url(/asset/meditation-everyday-logo-inline.svg);-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;animation:splash-breathe 2s ease-in-out infinite}@keyframes splash-breathe{0%,to{opacity:.4}50%{opacity:1}}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);background:var(--color-brand-secondary);color:var(--color-on-accent);border:none;border-radius:var(--radius-full);padding:var(--space-md) var(--space-2xl);font-family:var(--font-body);font-size:1rem;font-weight:600;letter-spacing:.04em;cursor:pointer;min-height:44px;transition:transform var(--transition-fast),filter var(--transition-fast),box-shadow var(--transition-fast);box-shadow:0 0 0 1px var(--color-cta-edge),0 4px 24px var(--color-accent-glow);width:100%;max-width:320px}@media(hover:hover){.btn-primary:hover{filter:brightness(1.1);box-shadow:0 0 0 1px var(--color-cta-edge),0 6px 32px var(--color-accent-glow)}}.btn-primary:active{transform:translateY(2px);transition:transform .1s var(--ease-standard)}.btn-primary:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px}.btn-primary--compact{padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);box-shadow:0 0 0 1px var(--color-cta-edge);width:auto;max-width:none}@media(hover:hover){.btn-primary--compact:hover{filter:brightness(1.1);box-shadow:0 0 0 1px var(--color-cta-edge)}}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-surface-border);border-radius:var(--radius-full);padding:var(--space-md) var(--space-2xl);font-family:var(--font-body);font-size:1rem;font-weight:600;letter-spacing:.04em;cursor:pointer;min-height:44px;width:100%;max-width:320px;transition:transform var(--transition-fast),filter var(--transition-fast),box-shadow var(--transition-fast);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}@media(hover:hover){.btn-secondary:hover{filter:brightness(1.1);box-shadow:0 4px 20px var(--color-overlay-light)}}.btn-secondary:active{transform:translateY(2px);transition:transform .1s var(--ease-standard)}[data-mode=light] .btn-secondary{border-color:var(--color-overlay-medium)}.landing{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:32px;max-width:640px;width:100%;min-height:100dvh;padding:calc(var(--header-height) + env(safe-area-inset-top,0px)) var(--page-padding-x) calc(var(--header-height) + env(safe-area-inset-bottom,0px))}.landing__greeting,.landing__subtitle,.landing__card,#btn-begin,.landing__waitlist-link{opacity:0;animation:fadeInUp .8s ease forwards}.landing__logo{opacity:0;animation:fadeInOpacity .8s ease forwards}@keyframes fadeInOpacity{0%{opacity:0}to{opacity:1}}.landing__greeting{animation-delay:.1s}.landing__subtitle{animation-delay:.2s}.landing__card{animation-delay:.35s}#btn-begin{animation-delay:.5s}.landing__waitlist-link{animation-delay:.5s;text-decoration:none}.landing__logo-container{position:fixed;top:0;left:0;width:100%;display:flex;justify-content:center;align-items:center;padding:calc(16px + env(safe-area-inset-top,0px)) 16px 40px;z-index:6;pointer-events:none}.landing__logo{width:clamp(150px,26vw,225px);aspect-ratio:820 / 128;background-color:currentColor;-webkit-mask-image:url(/asset/meditation-everyday-logo-inline.svg);mask-image:url(/asset/meditation-everyday-logo-inline.svg);-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;flex-shrink:0}.landing__greeting{font-family:var(--font-display);font-size:2.6rem;font-weight:500;letter-spacing:.02em;line-height:1.15;color:var(--color-text)}.landing__subtitle{font-size:1rem;color:var(--color-text-muted);font-weight:400;letter-spacing:.04em;margin-top:-16px}.landing__card{background:var(--color-bg);border-radius:var(--radius-md);padding:28px 24px;width:100%;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);text-align:left;transition:transform var(--transition-med),box-shadow var(--transition-med),max-height .4s ease;position:relative}.landing__reload-btn{position:absolute;bottom:28px;right:24px;background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;padding:0;height:44px;width:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:opacity var(--transition-fast);opacity:.6;z-index:2;font-size:.85rem}@media(hover:hover){.landing__reload-btn:hover{opacity:1}}.landing__reload-btn.rotating svg{animation:spin .6s ease-in-out}.landing__content{display:flex;flex-direction:column;gap:16px;min-height:200px;justify-content:center}.landing__content.fade-out .landing__card-category{animation:fadeOutContent .3s ease forwards 0s}.landing__content.fade-out .landing__card-name{animation:fadeOutContent .3s ease forwards .05s}.landing__content.fade-out .landing__card-description{animation:fadeOutContent .3s ease forwards .1s}.landing__content.fade-out .landing__card-meta{animation:fadeOutContent .3s ease forwards .15s}.landing__content.fade-in .landing__card-category{animation:fadeInContent .4s ease forwards 0s;opacity:0}.landing__content.fade-in .landing__card-name{animation:fadeInContent .4s ease forwards .1s;opacity:0}.landing__content.fade-in .landing__card-description{animation:fadeInContent .4s ease forwards .2s;opacity:0}.landing__content.fade-in .landing__card-meta{animation:fadeInContent .4s ease forwards .3s;opacity:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeInContent{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOutContent{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-4px)}}@media(hover:hover){.landing__card:hover{transform:translateY(-2px);box-shadow:0 8px 40px var(--color-accent-glow)}}.landing__card-category{font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--color-accent);font-weight:600;margin-bottom:8px;text-align:left}.landing__card-body{display:flex;flex-direction:column;gap:5px}.landing__card-name{font-family:var(--font-display);font-size:1.6rem;font-weight:500;margin-bottom:0;line-height:1.2;text-align:left}.landing__card-description{font-size:.9rem;color:var(--color-card-desc, var(--color-text-muted));line-height:1.65;margin-bottom:24px;font-weight:400;text-align:left}.landing__card-meta{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--color-text-muted);font-weight:400}.landing__meta-duration{display:flex;align-items:center;gap:6px}.landing__meta-features{display:flex;align-items:center;gap:14px}.landing__card-meta svg{width:14px;height:14px;opacity:.7}.landing__meta-separator{color:var(--color-text-muted);opacity:.4;margin:0 2px;font-size:.85rem}.about-interest-panel{text-align:center;margin-top:100px;display:none}.about-interest-panel .auth-interest__form--stacked{display:flex;flex-direction:column;align-items:center;gap:1.5rem;max-width:400px;margin:0 auto}.about-interest-panel .auth-interest__form--stacked input{width:100%;text-align:center}.about-interest-panel .auth-interest__form--stacked .auth-interest__btn{width:auto}.session{display:flex;flex-direction:column;align-items:center;text-align:center;width:100%;height:100%;padding:24px;animation:fadeIn .6s ease forwards;overflow:hidden;touch-action:none;position:relative}#app:has(.session){overflow-y:hidden}.session__countdown-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:200;pointer-events:none}.session__countdown-number{font-family:var(--font-display);font-size:4rem;font-weight:300;color:var(--color-text-muted);opacity:0;animation:countdownPulse 1s ease forwards}@keyframes countdownPulse{0%{opacity:0;transform:scale(.6)}30%{opacity:1;transform:scale(1)}80%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.3)}}.session:before,.session:after{content:"";position:fixed;left:0;right:0;height:clamp(80px,15vh,160px);pointer-events:none;z-index:0}.session:before{top:0;background:linear-gradient(to bottom,var(--color-bg) 0%,transparent 100%)}.session:after{bottom:0;background:linear-gradient(to top,var(--color-bg) 0%,transparent 100%)}.session__header{display:none}.session__exercise-name{font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--color-text-muted);font-weight:500;opacity:.7;text-align:center}.session__settings-btn,.session__audio-btn{background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;transition:color var(--transition-fast),transform var(--transition-fast),opacity var(--transition-fast)}.session__settings-btn svg,.session__audio-btn svg{pointer-events:none}.session__settings-btn:active,.session__audio-btn:active{transform:translateY(2px);transition:transform .1s var(--ease-standard)}@media(hover:hover){.session__settings-btn:hover,.session__audio-btn:hover{transform:translateY(-2px)}}.session__audio-btn.muted{opacity:.3}.session__settings-panel{position:absolute;top:calc(100% + 4px);right:50%;transform:translate(50%) translateY(-10px) scale(.95);background:transparent;border:none;border-radius:var(--radius-full);padding:4px;width:auto;box-shadow:none;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:4px;opacity:0;pointer-events:none;transform-origin:top center;transition:opacity .3s ease,transform .3s var(--ease-out-back);z-index:100}.session__settings-panel.is-visible{opacity:1;transform:translate(50%) translateY(0) scale(1);pointer-events:auto}.session__content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;position:relative;z-index:1;opacity:0;animation:fadeInUp .6s ease forwards;animation-delay:.2s}.session__content:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:200vw;height:100vh;max-width:1200px;max-height:800px;background:radial-gradient(ellipse at center,var(--color-bg) 0%,var(--color-bg) 20%,transparent 70%);border-radius:50%;pointer-events:none;z-index:-1;opacity:.85}.session__instruction{font-family:var(--font-display);font-size:1.5rem;color:var(--color-text);max-width:420px;line-height:1.5;text-wrap:balance;min-height:3em;font-weight:400;margin:0 auto}.instruction-line{display:block;opacity:1;transform:translateY(0);transition:opacity .6s ease calc(var(--i, 0) * .12s),transform .6s ease calc(var(--i, 0) * .12s);will-change:opacity,transform}.session__instruction.fading .instruction-line{opacity:0;transform:translateY(-6px)}.session__instruction.fading-in .instruction-line{opacity:0;transform:translateY(8px);transition:none}.session__instruction strong{font-weight:600}.session__instruction em{font-style:italic}.session__progress-dots{display:flex;align-items:center;justify-content:center;gap:10px;padding:50vh 50vw;margin:-50vh -50vw}.session__dot-slot{width:7px;height:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.session__dot{width:7px;height:7px;border-radius:50%;background:var(--color-text);opacity:.8}.session__footer{position:absolute;bottom:calc(120px + env(safe-area-inset-bottom,0px));left:0;right:0;display:flex;flex-direction:column;align-items:center;gap:16px;opacity:0;animation:fadeInUp .6s ease forwards;animation-delay:.5s;z-index:1}.session__timer-container{display:flex;flex-direction:column;align-items:center;gap:4px;position:relative;z-index:1}.session__timer-container:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:200px;height:120px;border-radius:50%;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);-webkit-mask-image:radial-gradient(ellipse at center,black 10%,transparent 70%);mask-image:radial-gradient(ellipse at center,black 10%,transparent 70%);background:radial-gradient(ellipse at center,var(--color-bg) 0%,transparent 70%);z-index:-1;pointer-events:none}.session__finish-btn{padding:10px 60px;font-size:.95rem;min-height:44px;margin:0;position:relative;z-index:2;width:auto;max-width:none;transform:translateY(0);transition:opacity .5s ease,transform .5s var(--ease-standard)}.session__finish-btn.hidden-btn{transform:translateY(8px)}.session__timer-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);opacity:.55}.session__timer{font-family:var(--font-body);font-variant-numeric:tabular-nums;font-feature-settings:"tnum";font-size:.9rem;font-weight:400;letter-spacing:.05em;color:var(--color-text-muted);opacity:.6}.session__audio-fab{position:relative;display:inline-flex;align-items:center;pointer-events:auto;touch-action:manipulation}.session__audio-fab .session__settings-btn{background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;padding:8px;min-height:44px;min-width:44px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-md);font-size:1.4rem;line-height:1}.session__audio-fab .session__settings-btn svg{width:22px;height:22px}.session__audio-fab .session__settings-panel{position:absolute;top:calc(100% + 4px);bottom:auto;right:0;left:auto;transform:translateY(-10px) scale(.95);transform-origin:top right}.session__audio-fab .session__settings-panel.is-visible{transform:translateY(0) scale(1)}body.pairing-open{overflow:hidden}.pairing-overlay{border:none;padding:0;margin:0;position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;max-width:none;max-height:none;background:color-mix(in srgb,var(--color-bg) 55%,transparent);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);align-items:center;justify-content:center;opacity:0;z-index:10000;transition:opacity .5s var(--ease-standard);outline:none}.pairing-overlay[open]{display:flex}.pairing-overlay.visible{opacity:1}.pairing-overlay::backdrop{background:transparent}.pairing-overlay.is-closing-slow{transition:opacity 1.2s var(--ease-standard)}.pairing-overlay.is-closing-slow .pairing-panel{transition:transform 1.2s var(--ease-standard),opacity 1.2s var(--ease-standard)}.pairing-panel{background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);padding:24px 32px;width:calc(100% - 48px);max-width:400px;transform:translateY(20px);opacity:0;transition:transform .5s var(--ease-standard),opacity .5s var(--ease-standard);box-shadow:0 16px 40px var(--color-overlay-dark)}.pairing-overlay.visible .pairing-panel{transform:translateY(0);opacity:1}.pairing-panel__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.pairing-panel__title{font-family:var(--font-display);font-size:1.25rem;font-weight:600;color:var(--color-text);line-height:1.2;margin:0}.pairing-panel__close-btn{background:transparent;border:none;color:var(--color-text-muted);font-size:1.2rem;cursor:pointer;transition:color var(--transition-fast, .2s ease);-webkit-tap-highlight-color:transparent;min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center}.pairing-panel__close-btn:focus:not(:focus-visible){outline:none}.pairing-panel__close-btn:focus-visible{outline:2px solid var(--color-focus);outline-offset:-1px}@media(hover:hover){.pairing-panel__close-btn:hover{color:var(--color-text)}}.pairing-panel__content{display:flex;flex-direction:column;gap:16px}.pairing-panel__privacy{font-family:var(--font-body);font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-text-muted);margin:0}.btn-primary.is-loading{display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:default;opacity:.75}.pairing-cta__spinner{display:inline-block;width:14px;height:14px;border-radius:50%;border:2px solid currentColor;border-top-color:transparent;animation:pairingSpin .8s linear infinite}@keyframes pairingSpin{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){.pairing-cta__spinner{animation:none}}.pairing-success{align-items:center;justify-content:center;text-align:center;padding:32px 16px;min-height:140px}.pairing-success__icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:50%;background:#7986cb26;color:var(--color-brand);margin-bottom:var(--space-md);animation:pairingSuccessPop .35s var(--ease-emphasized)}.pairing-success__icon svg{width:28px;height:28px}.pairing-success__message{font-family:var(--font-body);font-size:1rem;font-weight:500;color:var(--color-text);margin:0}@keyframes pairingSuccessPop{0%{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}@media(prefers-reduced-motion:reduce){.pairing-success__icon{animation:none}}.pairing-error{font-family:var(--font-body);font-size:.875rem;font-weight:400;line-height:1.5;color:var(--color-danger);margin:var(--space-md) 0 0 0;min-height:0}.pairing-error:empty{display:none}.pairing-chip{display:flex;align-items:center;gap:var(--space-sm);padding:16px;background:var(--color-chip-tint);border:1px solid var(--color-surface-border);border-radius:var(--radius-sm)}.pairing-chip__heart-wrap{position:relative;width:32px;height:32px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center}.pairing-chip__heart{display:inline-flex;align-items:center;justify-content:flex-start;width:16px;height:16px;color:var(--color-brand);filter:drop-shadow(0 0 4px var(--color-brand-glow));overflow:visible}.pairing-chip__heart svg{width:16px;height:16px;flex-shrink:0}.pairing-chip__bpm-overlay{position:absolute;right:-4px;bottom:-4px;font-family:var(--font-body);font-size:.625rem;font-weight:400;font-variant-numeric:tabular-nums;color:var(--color-text);background:var(--color-surface);border-radius:6px;padding:1px 3px;line-height:1}.pairing-chip__name{flex:1;font-family:var(--font-body);font-size:.875rem;font-weight:400;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pairing-chip.is-reconnecting,.pairing-chip.is-stale{opacity:.7}.pairing-chip.is-reconnecting .pairing-chip__heart,.pairing-chip.is-stale .pairing-chip__heart{color:var(--color-text-muted);filter:none}.pairing-chip.is-reconnecting .pairing-chip__heart{animation:pairingChipPulse 1.2s ease-in-out infinite}.pairing-chip.is-reconnecting .pairing-chip__name,.pairing-chip.is-stale .pairing-chip__name{color:var(--color-text-muted)}.pairing-chip.is-reconnecting .pairing-chip__bpm-overlay,.pairing-chip.is-stale .pairing-chip__bpm-overlay{display:none}.pairing-chip.is-reconnecting .pairing-chip__heart svg,.pairing-chip.is-stale .pairing-chip__heart svg{width:18px;height:16px}@keyframes pairingChipPulse{0%,to{opacity:.4}50%{opacity:1}}@media(prefers-reduced-motion:reduce){.pairing-chip.is-reconnecting .pairing-chip__heart{animation:none}}.pairing-chip__actions{display:inline-flex;align-items:center;gap:4px;flex-shrink:0;margin-left:auto}.pairing-chip__action{flex-shrink:0;background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;transition:color var(--transition-fast, .2s ease),background var(--transition-fast, .2s ease);-webkit-tap-highlight-color:transparent;border-radius:var(--radius-sm);padding:0}.pairing-chip__action svg{width:20px;height:20px;pointer-events:none}.pairing-chip__action:focus-visible{outline:2px solid var(--color-focus);outline-offset:-1px}@media(hover:hover){.pairing-chip__action:hover{color:var(--color-brand)}}.pairing-chip__action--refresh{display:none}.pairing-chip.is-stale .pairing-chip__action--refresh,.pairing-chip.is-reconnecting .pairing-chip__action--refresh{display:inline-flex}.pairing-chip.is-reconnecting .pairing-chip__action--refresh{color:var(--color-text-muted)}.pairing-chip.is-confirming-unpair{border-color:color-mix(in srgb,var(--color-danger) 50%,transparent);background:color-mix(in srgb,var(--color-danger) 8%,transparent)}[data-mode=light] .pairing-chip.is-confirming-unpair{background:color-mix(in srgb,var(--color-danger) 12%,transparent)}.pairing-chip.is-confirming-unpair .pairing-chip__action--unpair{color:var(--color-on-accent);background:var(--color-danger)}@media(hover:hover){.pairing-chip.is-confirming-unpair .pairing-chip__action--unpair:hover{background:#ff4d4d;color:var(--color-on-accent)}}.pairing-repair-link{background:transparent;border:none;color:var(--color-text-muted);font-family:var(--font-body);font-size:.875rem;font-weight:400;cursor:pointer;padding:0;text-decoration:none;align-self:flex-start}.pairing-repair-link:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px;border-radius:2px}@media(hover:hover){.pairing-repair-link:hover{color:var(--color-text);text-decoration:underline}}.heart-badge{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-height:44px;padding:0 8px;background:transparent;border:none;cursor:pointer;font-family:var(--font-body);color:var(--color-text);-webkit-tap-highlight-color:transparent;transform-origin:center;transition:opacity var(--transition-fast, .2s ease);animation:heartBadgeEnter .22s ease-out}.heart-badge[data-admin=false]{cursor:default}.heart-badge[data-admin=false] .heart-badge__bpm{display:none}.heart-badge:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px;border-radius:var(--radius-sm)}.heart-badge__icon{display:inline-flex;align-items:center;justify-content:flex-start;width:20px;height:20px;color:var(--color-brand);filter:drop-shadow(0 0 6px var(--color-brand-glow));transform-origin:center;animation:cardiacPulse 1s ease-in-out infinite;overflow:visible}.heart-badge__icon svg{width:20px;height:20px;flex-shrink:0}.heart-badge__bpm{font-size:.75rem;font-weight:400;font-variant-numeric:tabular-nums;line-height:1.2;color:var(--color-text)}.heart-badge[data-state=stale]{opacity:.55}.heart-badge[data-state=stale] .heart-badge__icon{color:var(--color-text-muted);filter:none;animation:none}.heart-badge[data-state=stale] .heart-badge__icon svg{width:22.5px;height:20px}.heart-badge[data-state=stale] .heart-badge__bpm{display:none}.heart-badge.is-exiting{animation:heartBadgeExit .2s ease-out forwards;pointer-events:none}.heart-badge.is-exiting .heart-badge__icon{animation-play-state:paused}@keyframes cardiacPulse{0%{transform:scale(1)}14%{transform:scale(1.25)}28%{transform:scale(1)}42%{transform:scale(1.12)}70%{transform:scale(1)}to{transform:scale(1)}}@keyframes heartBadgeExit{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.92)}}@keyframes heartBadgeEnter{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@media(prefers-reduced-motion:reduce){.heart-badge{animation:none}.heart-badge__icon{animation:none;transform:scale(1)}.heart-badge.is-exiting{animation:none;opacity:0}.pairing-overlay,.pairing-panel{transition:none}}#app:has(.complete){justify-content:flex-start;overflow:hidden}#app:has(.complete):before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-bg);z-index:0;animation:fadeIn .8s ease forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.complete{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;width:100%;gap:100px;animation:fadeIn .6s ease forwards .1s;opacity:0;z-index:1;background:linear-gradient(160deg,var(--color-bg) 0%,color-mix(in srgb,var(--color-bg),var(--color-accent) 8%) 50%,var(--color-bg) 100%);overflow:hidden;overscroll-behavior:none;touch-action:none}.complete:before{content:"";position:absolute;top:-108px;right:-108px;bottom:-108px;left:-108px;background-image:url(/asset/background-pattern.svg);background-size:108px 108px;background-repeat:repeat;opacity:.08;filter:brightness(0);animation:complete__tile-pan 60s linear infinite;pointer-events:none;will-change:transform;z-index:0}[data-mode=dark] .complete:before{opacity:.06;filter:brightness(0) invert(1)}@keyframes complete__tile-pan{0%{transform:translate(0)}to{transform:translate(-108px,-108px)}}.complete__card-section{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;min-height:100dvh;position:relative;padding:calc(var(--header-height) + env(safe-area-inset-top,0px)) var(--page-padding-x) calc(var(--header-height) + env(safe-area-inset-bottom,0px));z-index:1}.complete__buttons-section{position:fixed;top:50%;left:50%;z-index:102;display:flex;flex-direction:column;align-items:stretch;gap:var(--space-sm);flex:0 0 340px;width:min(340px,calc(100% - 48px));height:300px;max-height:80dvh;padding:20px 16px;background:transparent;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;transform:translate(-50%,-50%) scale(0);transform-origin:center center;opacity:0;visibility:hidden;transition:transform .4s var(--ease-out-back),opacity .25s ease,visibility 0s linear .4s}body:has(.complete--panel-open) .complete__buttons-section{transform:translate(-50%,-50%) scale(1);opacity:1;visibility:visible;transition:transform .4s var(--ease-out-back),opacity .25s ease,visibility 0s linear 0s}.complete__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:101;background:color-mix(in srgb,var(--color-bg) 55%,transparent);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);opacity:0;visibility:hidden;transition:opacity .3s ease,visibility 0s linear .3s}body:has(.complete--panel-open) .complete__backdrop{opacity:1;visibility:visible;transition:opacity .3s ease,visibility 0s linear 0s}.complete__video-preview{width:calc(100% - 32px);margin:0 auto;border-radius:var(--radius-sm);overflow:hidden;opacity:0;animation:fadeInUp .6s ease forwards .45s;border:1px solid var(--color-surface-border);background:var(--color-surface)}.complete__video-preview video{width:100%;max-height:35vh;object-fit:contain;display:block;border-radius:var(--radius-md)}.complete__export-options{width:100%;max-width:320px;margin-bottom:20px;opacity:0;animation:fadeInUp .6s ease forwards .3s;display:flex;flex-direction:column;gap:6px;background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-sm);padding:var(--space-sm) var(--space-sm)}.complete__toggle{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;-webkit-user-select:none;user-select:none;transition:transform var(--transition-fast)}.complete__toggle:active{transform:translateY(2px);transition:transform .1s var(--ease-standard)}.complete__toggle input[type=checkbox]{opacity:0;width:0;height:0;position:absolute}.complete__toggle-slider{position:relative;width:48px;height:26px;background:var(--color-surface-hover);border-radius:var(--radius-lg);transition:background .3s ease;border:1px solid var(--color-border)}.complete__toggle-slider:before{content:"";position:absolute;width:20px;height:20px;border-radius:50%;background:#fff;top:2px;left:2px;transition:transform .3s ease,background .3s ease;box-shadow:0 2px 4px var(--color-overlay-medium)}.complete__toggle input[type=checkbox]:checked+.complete__toggle-slider{background:var(--color-brand);border-color:var(--color-brand)}.complete__toggle input[type=checkbox]:checked+.complete__toggle-slider:before{transform:translate(22px)}.complete__toggle input[type=checkbox]:focus-visible+.complete__toggle-slider{outline:2px solid var(--color-focus);outline-offset:2px}@media(hover:hover){.complete__toggle:hover .complete__toggle-slider{background:var(--color-border)}.complete__toggle:hover input[type=checkbox]:checked+.complete__toggle-slider{background:var(--color-brand-hover, var(--color-brand))}}.complete__toggle-label{font-size:.875rem;color:var(--color-text-muted);transition:color .2s ease;letter-spacing:.02em}@media(hover:hover){.complete__toggle:hover .complete__toggle-label{color:var(--color-text)}}.complete__actions{display:flex;flex-direction:column;gap:10px;width:100%;max-width:320px;padding:0 20px}.complete__actions>button{opacity:0;transform:translateY(8px);transition:opacity .4s var(--ease-standard),transform .4s var(--ease-standard)}body:has(.complete--panel-open) .complete__actions>button{opacity:1;transform:translateY(0)}body:has(.complete--panel-open) .complete__actions>button:nth-child(1){transition-delay:.1s}body:has(.complete--panel-open) .complete__actions>button:nth-child(2){transition-delay:.22s}body:has(.complete--panel-open) .complete__actions>button:nth-child(3){transition-delay:.34s}body:has(.complete--panel-open) .complete__actions>button:nth-child(4){transition-delay:.46s}body:has(.complete--panel-open) .complete__actions>button:nth-child(5){transition-delay:.58s}body:has(.complete--panel-open) .complete__actions>button:nth-child(6){transition-delay:.7s}.complete__actions>button:active{transform:translateY(2px)!important;transition:transform .1s var(--ease-standard)}@media(min-width:900px){.complete__actions>button{opacity:0;transform:none;transition:none;animation:fadeInUp .6s ease forwards}.complete__actions>button:nth-child(1){animation-delay:1.4s}.complete__actions>button:nth-child(2){animation-delay:1.55s}.complete__actions>button:nth-child(3){animation-delay:1.7s}.complete__actions>button:nth-child(4){animation-delay:1.85s}}.complete__card-scene{perspective:1000px;width:100%;max-width:280px;animation:fadeInUp .8s ease both .2s;opacity:0}@media(prefers-reduced-motion:reduce){.complete__card-scene{animation:fadeIn .6s ease both .2s!important}}.complete__card-gyro{transform-style:preserve-3d}.complete__card{position:relative;width:100%;aspect-ratio:3 / 4;padding:10px;border-radius:var(--radius-sm);background-color:var(--card-bg, #BDBBD1);background-size:cover;background-position:center;box-shadow:0 0 24px #6450a080,0 0 48px #6450a040;transform-style:preserve-3d;transition:transform .7s var(--ease-standard);cursor:pointer;touch-action:none;-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none;animation:complete__card-spin 2s var(--ease-standard) .3s both}@keyframes complete__card-spin{0%{transform:rotateY(-360deg)}to{transform:rotateY(0)}}[data-mode=dark] .complete__card{background-color:var(--card-bg, #4A4482);box-shadow:0 0 24px #a08cff99,0 0 48px #a08cff4d}.complete__card.is-flipped{transform:rotateY(180deg)}.complete__card-face{position:absolute;top:10px;right:10px;bottom:10px;left:10px;border-radius:calc(var(--radius-sm) - 4px);overflow:hidden;backface-visibility:hidden;-webkit-backface-visibility:hidden}.complete__card-artwork{width:100%;height:100%;object-fit:cover;display:block;-webkit-touch-callout:none;-webkit-user-drag:none;-webkit-user-select:none;user-select:none;pointer-events:none}.complete__card-face--front{transform:translateZ(1px)}.complete__card-face--back{transform:rotateY(180deg) translateZ(1px);overflow-y:auto;-webkit-overflow-scrolling:touch;background:var(--color-bg);padding:20px 16px;text-align:left}.complete__card-glare-frame{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;backface-visibility:hidden;-webkit-backface-visibility:hidden;clip-path:inset(0 round var(--radius-sm))}.complete__card-glare-frame--front{transform:translateZ(2px)}.complete__card-glare-frame--back{transform:rotateY(180deg) translateZ(2px)}.complete__card-glare-clip{position:absolute;top:0;right:0;bottom:0;left:0}.complete__card-glare-strip{position:absolute;top:-50%;left:-150%;width:400%;height:200%;background:linear-gradient(105deg,transparent 0%,transparent 37%,rgba(255,255,255,.7) 38.5%,rgba(255,255,255,.9) 39.5%,rgba(255,255,255,.7) 41%,transparent 42.5%,transparent 57.5%,rgba(255,255,255,.7) 59%,rgba(255,255,255,.9) 60.5%,rgba(255,255,255,.7) 61.5%,transparent 63%,transparent 100%);opacity:.35;will-change:transform;pointer-events:none}@media(prefers-reduced-motion:reduce){.complete__card-glare-strip{display:none}}.complete__card-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;display:flex;flex-direction:column;justify-content:space-between;align-items:center;pointer-events:none}.complete__card-overlay-top{width:100%;text-align:center;background:linear-gradient(to bottom,rgba(217,214,210,.5) 0%,transparent 100%);padding:20px 16px 10%}[data-mode=dark] .complete__card-overlay-top{background:linear-gradient(to bottom,rgba(10,10,20,.5) 0%,transparent 100%)}.complete__card-logo{width:clamp(96px,56%,160px);opacity:.9;filter:brightness(0)}[data-mode=dark] .complete__card-logo{filter:brightness(0) invert(1)}.complete__card-overlay-bottom{width:100%;text-align:center;background:linear-gradient(to top,rgba(217,214,210,.6) 0%,transparent 100%);padding:30px 16px 20px}[data-mode=dark] .complete__card-overlay-bottom{background:linear-gradient(to top,rgba(10,10,20,.6) 0%,transparent 100%)}.complete__card-overlay-title{font-family:var(--font-display);font-size:1rem;font-weight:600;color:#1a1a2e;text-shadow:0 1px 3px rgba(235,235,235,.5);line-height:1.3;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}[data-mode=dark] .complete__card-overlay-title{color:#d9d9d9;text-shadow:0 1px 3px var(--color-overlay-dark)}.complete__card-overlay-meta{font-size:.95rem;font-weight:400;color:#1a1a2eb3;text-shadow:0 1px 2px rgba(235,235,235,.5)}[data-mode=dark] .complete__card-overlay-meta{color:#ffffffb3;text-shadow:0 1px 2px var(--color-overlay-dark)}.complete__session-badge{position:absolute;top:var(--space-sm);right:var(--space-sm);z-index:2;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full);background:#ffffff2e;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.25);font-size:.75rem;font-weight:600;color:#fff;letter-spacing:.06em;text-shadow:0 1px 2px var(--color-overlay-medium)}.complete__trigger{margin-top:var(--space-xl);display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;min-width:44px;min-height:44px;border-radius:var(--radius-full);background:var(--color-surface);border:1px solid var(--color-surface-border);color:var(--color-text);cursor:pointer;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:0 4px 16px var(--color-overlay-light);animation:complete__trigger-reveal .5s var(--ease-out-back) 1.2s backwards;transition:transform var(--transition-fast),filter var(--transition-fast),box-shadow var(--transition-fast);-webkit-tap-highlight-color:transparent}@keyframes complete__trigger-reveal{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@media(hover:hover){.complete__trigger:hover{filter:brightness(1.1);box-shadow:0 4px 20px var(--color-overlay-light)}}@keyframes complete__trigger-press{0%{transform:none;box-shadow:0 4px 16px var(--color-overlay-light)}50%{transform:translateY(2px) scale(.92);box-shadow:0 1px 3px var(--color-overlay-light)}to{transform:none;box-shadow:0 4px 16px var(--color-overlay-light)}}.complete__trigger:active{animation:complete__trigger-press .22s var(--ease-standard)}.complete__trigger:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px}.complete__card-category{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.14em;color:var(--color-accent);margin-bottom:8px}.complete__card-name{font-family:var(--font-display);font-size:1.6rem;font-weight:400;line-height:1.2;margin-bottom:var(--space-lg)}.complete__card-description{font-size:.9rem;font-weight:400;line-height:1.25;color:var(--color-text-muted);margin-bottom:16px}.complete__card-meta{display:flex;align-items:center;gap:8px;font-size:.75rem;color:var(--color-text-muted);margin-bottom:16px;justify-content:flex-start}.complete__card-meta .icon{width:14px;height:14px}.complete__read-more{display:inline-block;font-size:.9rem;font-weight:400;font-family:inherit;color:var(--color-accent);text-decoration:underline;text-underline-offset:3px;cursor:pointer;margin-top:4px;background:transparent;border:0;padding:0}.complete__read-more:hover{color:var(--color-text)}.complete__read-more:disabled{cursor:default;opacity:.6}@property --float-amplitude{syntax: "<length>"; inherits: false; initial-value: 24px;}@keyframes complete__float{0%,to{transform:translateY(0)}50%{transform:translateY(calc(var(--float-amplitude) * -1))}}.complete__card-floater{width:100%;transform-style:preserve-3d;--float-amplitude: 24px;animation:complete__float 4s ease-in-out infinite;animation-delay:1s;will-change:transform;transition:--float-amplitude 1.5s ease}.complete__card-floater--no-float{--float-amplitude: 0px;will-change:auto}.complete__admin-group{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);width:100%;padding:16px 20px 0;max-width:320px;border-top:1px solid var(--color-surface-border);opacity:0;animation:fadeInUp .8s ease forwards 2.1s}.complete__admin-group .complete__export-options{margin-bottom:0;align-items:center}.complete__admin-actions{display:flex;flex-direction:column;gap:var(--space-sm);width:100%}.complete__buttons-section .btn-secondary{padding-left:var(--space-lg);padding-right:var(--space-lg)}#app{transition:opacity .4s ease,transform .4s ease}#app.page-exit{opacity:0;transform:translateY(6px) scale(.99);pointer-events:none}#app.page-enter{opacity:0;transform:translateY(-8px)}#app.page-enter-active{opacity:1;transform:translateY(0);transition:opacity .5s var(--ease-out-quint),transform .5s var(--ease-out-quint)}@media(prefers-reduced-motion:reduce){#app.page-exit,#app.page-enter,#app.page-enter-active{transform:none}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@media(min-width:600px){.landing__greeting{font-size:3.4rem}.landing__card{padding:36px 32px}.session__instruction{font-size:1.75rem;max-width:500px}.session__dot-slot,.session__dot{width:9px;height:9px}.session__progress-dots{gap:16px}}@media(min-width:900px){.landing__greeting{font-size:4rem}.session__instruction{font-size:2rem;max-width:560px}.complete{flex-direction:row;align-items:center;justify-content:center;height:100dvh;gap:72px;padding:0 32px}.complete__card-section{min-height:0;flex:0 0 auto;width:auto;padding:0}.complete__card-scene{max-width:360px;width:360px}.complete__trigger,.complete__backdrop{display:none}.complete__buttons-section{position:static;top:auto;left:auto;bottom:auto;flex:0 0 300px;width:300px;height:auto;align-self:center;justify-content:center;padding:24px 0;overflow:visible;max-height:100dvh;background:transparent;border-radius:0;box-shadow:none;transform:none;visibility:visible;opacity:1;transition:none;animation:complete__buttons-reveal 1.5s var(--ease-out-back) 1s both}}@keyframes complete__buttons-reveal{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media(max-height:600px){.complete__card-section{min-height:100dvh;padding:16px}.complete__card-scene{max-width:calc((100dvh - 100px)*.75)}.complete__actions{gap:8px}.btn-secondary{padding:var(--space-sm) var(--space-lg);font-size:.85rem}}@media(max-width:767px)and (max-height:600px){.complete__buttons-section{height:236px}}@media(prefers-reduced-motion:reduce){.complete__card{transition:none;animation:none}.complete__card-floater{animation:none}}@media(orientation:landscape)and (max-height:500px){.landing{gap:var(--space-sm);padding:var(--space-sm);padding-bottom:calc(32px + env(safe-area-inset-bottom,0px))}.app-footer{padding:8px 16px}.app-footer p{font-size:.7rem}.landing__logo-container{padding:8px 16px}.landing__logo{width:clamp(97px,19vw,150px)}.landing__greeting{font-size:1.5rem;margin-top:32px}.landing__subtitle{font-size:.85rem}.landing__card{padding:var(--space-sm) var(--space-md)}.landing__content{min-height:auto;gap:8px}.landing__card-body{font-size:.9rem}.btn-primary{padding:10px 24px;font-size:.9rem}}.unsupported-screen{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:10002;background:var(--color-bg);flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:24px;padding:24px}.unsupported-screen__logo{width:clamp(150px,26vw,225px);aspect-ratio:820 / 128;background-color:currentColor;-webkit-mask-image:url(/asset/meditation-everyday-logo-inline.svg);mask-image:url(/asset/meditation-everyday-logo-inline.svg);-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center}.unsupported-screen p{font-family:var(--font-display);font-size:1rem;color:var(--color-text-muted);line-height:1.6;max-width:420px;letter-spacing:.02em}@media(orientation:landscape)and (max-height:500px){.unsupported-screen{display:flex}}.app-copyright{position:fixed;bottom:0;left:0;right:0;text-align:center;padding:clamp(60px,6vh,120px) 20px calc(24px + env(safe-area-inset-bottom,0px));z-index:9;pointer-events:none;background:linear-gradient(to top,var(--color-bg) 40%,transparent 100%)}.app-copyright p{font-size:.75rem;color:var(--color-text-muted);letter-spacing:.05em;opacity:.4;margin:0}.app-footer{position:fixed;bottom:0;width:100%;padding:0 20px calc(60px + env(safe-area-inset-bottom,0px));text-align:center;z-index:10;opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s ease}.app-footer.fade-in{opacity:1;transform:translateY(0)}@media(max-width:767px){.app-footer{display:none}}.app-footer p{font-size:.75rem;color:var(--color-text-muted);letter-spacing:.05em;opacity:.6;margin:0}.footer-info-btn{background:none;border:none;padding:0;font-family:inherit;font-size:.85rem;color:var(--color-text-muted);text-decoration:none;cursor:pointer;transition:color var(--transition-fast),opacity var(--transition-fast);-moz-appearance:none;appearance:none;-webkit-appearance:none;outline:none;min-height:44px;display:inline-flex;align-items:center}body:not([data-admin]) [data-admin-only]{display:none}.footer-info-btn:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px}@media(hover:hover){.footer-info-btn:hover{opacity:1;color:var(--color-text)}}.lang-picker{position:relative;display:inline-flex}.lang-picker__trigger{cursor:pointer}.lang-picker__trigger:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px}.lang-picker__list{display:none;position:fixed;transform:translate(-50%);background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-md);padding:4px;min-width:140px;box-shadow:0 10px 30px var(--color-overlay-medium);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:110}.lang-picker__list.open{display:flex;flex-direction:column}.lang-picker__item{background:none;border:none;color:var(--color-text-muted);font-family:inherit;font-size:.85rem;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);cursor:pointer;text-align:center;transition:background .15s ease,color .15s ease}.lang-picker__item--active{color:var(--color-text);font-weight:500}.lang-picker__item:focus-visible{outline:2px solid var(--color-focus);outline-offset:-2px}@media(hover:hover){.lang-picker__item:hover{background:var(--color-overlay-light);color:var(--color-text)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@keyframes appHeaderMountIn{0%{opacity:0;transform:translate3d(0,-100%,0)}to{opacity:1;transform:translateZ(0)}}.app-header{position:fixed;top:0;left:0;right:0;z-index:104;animation:appHeaderMountIn .32s var(--ease-out-quint) both;background:transparent;transition:background .2s ease,backdrop-filter .2s ease,border-color .2s ease;border-bottom:1px solid transparent;transform:translateZ(0);-webkit-transform:translateZ(0)}.app-header__inner{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;gap:16px;position:relative}.app-header__center{flex:1 1 auto;display:grid;grid-template-columns:1fr;place-items:center;min-width:0;min-height:44px}.app-header__right{flex:0 0 auto;display:grid;grid-template-columns:1fr;place-items:center end;min-width:44px}.app-header__right-item--landing,.app-header__right-item--complete,.app-header__right-item--profile{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:flex-end}#app-header-right-user>.user-menu-container{display:flex;align-items:center;justify-content:flex-end}.app-header__center .app-header__center-item,.app-header__right .app-header__right-item{grid-row:1;grid-column:1}.app-header__session-title,.app-header__profile-title{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:1rem;letter-spacing:.02em;color:var(--color-text);font-weight:500;text-align:center;font-family:var(--font-display)}.app-header__logo-row{display:flex;justify-content:center;align-items:center}.app-header__logo{display:inline-flex;align-items:center;min-height:44px;text-decoration:none}.app-header__logo img{height:28px;width:auto;aspect-ratio:auto}.app-header__logo-img--wordmark{display:block;height:28px;width:auto;aspect-ratio:820 / 128;background-color:var(--color-text);-webkit-mask-image:url(/asset/meditation-everyday-logo-inline.svg);mask-image:url(/asset/meditation-everyday-logo-inline.svg);-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center}.app-header__logo-img--icon{display:block;height:32px;width:32px}.app-header__nav{display:flex;align-items:center;gap:16px}.app-header__nav-link{background:transparent;border:none;color:var(--color-text-muted);font-size:.875rem;font-weight:400;padding:8px 16px;min-height:44px;cursor:pointer;text-decoration:none;border-radius:var(--radius-md);transition:color .2s ease,text-decoration-color .2s ease}.app-header__nav-link:hover,.app-header__nav-link:focus-visible{color:var(--color-text);text-decoration:underline;text-underline-offset:3px}.app-header__nav-link:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px}.app-header__hamburger{background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;padding:8px;min-height:44px;min-width:44px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-md);line-height:1}.app-header__hamburger .icon{width:22px;height:22px}.app-header__nav{display:none}.app-header__hamburger:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px}.app-header__panel{position:fixed;top:0;left:0;bottom:0;width:auto;max-width:min(260px,80vw);align-self:flex-start;z-index:102;display:flex;flex-direction:column;align-items:stretch;gap:var(--space-md);overflow-y:auto;opacity:0;pointer-events:none;transform:translate(-100%);background:transparent;padding:calc(var(--header-height) + 8px) 16px 16px 32px;transition:transform .4s var(--ease-standard),opacity .4s var(--ease-standard)}.app-header__panel.open{opacity:1;pointer-events:auto;transform:translate(0)}.app-header__panel-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:101;background:color-mix(in srgb,var(--color-bg) 55%,transparent);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);opacity:0;pointer-events:none;transition:opacity .4s var(--ease-standard)}body:has(.app-header__panel.open) .app-header__panel-backdrop{opacity:1;pointer-events:auto}@media(max-width:767px){.app-header__panel{padding-left:16px}}.app-header__panel>*{width:100%;display:flex;align-items:center;justify-content:flex-start;opacity:0;transform:translate(-120%)}.app-header__panel .lang-picker{display:flex;width:100%}.app-header__panel .lang-picker__trigger{width:100%}.app-header__panel .footer-info-btn,.app-header__panel .sign-in-btn{width:100%;min-height:44px;padding:10px var(--space-md);justify-content:flex-start;background:var(--color-bg);border:1px solid var(--color-surface-border);border-radius:var(--radius-full);color:var(--color-text);transition:opacity .3s var(--ease-standard),transform .3s var(--ease-standard),background var(--transition-fast),filter var(--transition-fast)}@media(hover:hover){.app-header__panel .footer-info-btn:hover,.app-header__panel .sign-in-btn:hover{filter:brightness(1.1)}}.app-header__panel-user,.app-header__panel-signin{display:flex;flex-direction:column;align-items:stretch;gap:var(--space-md)}.app-header__panel-lang:empty,.app-header__panel-signin:empty,.app-header__panel-user:empty,.app-header__panel-debug:empty{display:none}.app-header__panel-link{display:block;width:100%;background:var(--color-bg);border:1px solid var(--color-surface-border);border-radius:var(--radius-full);color:var(--color-text);font-size:.875rem;text-align:left;padding:var(--space-sm) var(--space-md);min-height:44px;cursor:pointer;transition:background var(--transition-fast),filter var(--transition-fast)}.app-header__panel-link:hover,.app-header__panel-link:focus-visible{color:var(--color-text)}.app-header__panel-link:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px}[data-mode=light] .app-header__panel .footer-info-btn,[data-mode=light] .app-header__panel .sign-in-btn,[data-mode=light] .app-header__panel-link{border-color:var(--color-overlay-medium)}.app-header__panel>.app-header__panel-lang,.app-header__panel>.app-header__panel-signin,.app-header__panel>.app-header__panel-user,.app-header__panel>.app-header__panel-debug{opacity:1;transform:none}.app-header__panel-lang>*:nth-child(n),.app-header__panel-signin>*:nth-child(n),.app-header__panel-user>*:nth-child(n),.app-header__panel-debug>*:nth-child(n){opacity:0;transform:translate(-120%)}.app-header__panel>*:nth-child(n),.app-header__panel-lang>*:nth-child(n),.app-header__panel-signin>*:nth-child(n),.app-header__panel-user>*:nth-child(n),.app-header__panel-debug>*:nth-child(n){transition:opacity .43s var(--ease-standard),transform .43s var(--ease-standard);transition-delay:calc((var(--stagger-index, 1) - 1) * .01s)}.app-header__panel.open>*:nth-child(n),.app-header__panel.open .app-header__panel-lang>*:nth-child(n),.app-header__panel.open .app-header__panel-signin>*:nth-child(n),.app-header__panel.open .app-header__panel-user>*:nth-child(n),.app-header__panel.open .app-header__panel-debug>*:nth-child(n){opacity:1;transform:translate(0);transition:opacity .3s var(--ease-standard),transform .3s var(--ease-standard);transition-delay:calc((var(--stagger-index, 1) - 1) * .05s + .05s)}.app-header__panel>.app-header__panel-lang,.app-header__panel>.app-header__panel-signin,.app-header__panel>.app-header__panel-user,.app-header__panel>.app-header__panel-debug,.app-header__panel.open>.app-header__panel-lang,.app-header__panel.open>.app-header__panel-signin,.app-header__panel.open>.app-header__panel-user,.app-header__panel.open>.app-header__panel-debug{opacity:1;transform:none;transition:none;transition-delay:0s}@media(prefers-reduced-motion:reduce){.app-header__panel>*:nth-child(n),.app-header__panel.open>*:nth-child(n),.app-header__panel-lang>*:nth-child(n),.app-header__panel-signin>*:nth-child(n),.app-header__panel-user>*:nth-child(n),.app-header__panel-debug>*:nth-child(n),.app-header__panel.open .app-header__panel-lang>*:nth-child(n),.app-header__panel.open .app-header__panel-signin>*:nth-child(n),.app-header__panel.open .app-header__panel-user>*:nth-child(n),.app-header__panel.open .app-header__panel-debug>*:nth-child(n){transition:none;transition-delay:0s}.app-header__panel.open>*:nth-child(n),.app-header__panel.open .app-header__panel-lang>*:nth-child(n),.app-header__panel.open .app-header__panel-signin>*:nth-child(n),.app-header__panel.open .app-header__panel-user>*:nth-child(n),.app-header__panel.open .app-header__panel-debug>*:nth-child(n){opacity:1;transform:none}}@media(max-width:767px){:root{--header-height: 60px}.app-header__inner{padding:var(--space-sm) var(--space-md)}.app-header__logo-row{justify-content:flex-start}}body[data-screen=landing] #landing-logo-header,body[data-screen=session] #user-menu-container{display:none}.auth-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#06060ce6;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);will-change:opacity;display:flex;align-items:center;justify-content:center;z-index:10000;opacity:1;transition:opacity .5s var(--ease-standard);animation:modalFadeIn .5s var(--ease-standard)}.auth-modal-overlay.closing{opacity:0;pointer-events:none}.auth-modal-overlay.closing .auth-modal-content{transform:translateY(20px);opacity:0}.auth-modal-content{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:2rem;width:90%;max-width:400px;position:relative;box-shadow:0 20px 40px var(--color-overlay-dark);transition:transform .5s var(--ease-standard),opacity .5s var(--ease-standard);animation:modalSlideUp .5s var(--ease-standard)}.auth-modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:var(--color-text-muted);font-size:1.25rem;cursor:pointer;transition:color .2s;padding:.5rem}@media(hover:hover){.auth-modal-close:hover{color:var(--color-text)}}.auth-tabs{display:flex;gap:0;margin-bottom:1.5rem;border-bottom:1px solid var(--color-border)}.auth-tab{flex:1;padding:.75rem 1rem;background:none;border:none;color:var(--color-text-muted);font-family:inherit;font-size:1rem;font-weight:500;cursor:pointer;transition:color var(--transition-fast),border-bottom-color var(--transition-fast);border-bottom:2px solid transparent;margin-bottom:-1px}@media(hover:hover){.auth-tab:hover{color:var(--color-text)}}.auth-tab.active{color:var(--color-brand);border-bottom-color:var(--color-brand)}.auth-oauth{margin-bottom:1.5rem}.auth-google-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.875rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family:inherit;font-size:.9375rem;cursor:pointer;transition:transform .2s ease}@media(hover:hover){.auth-google-btn:hover{transform:translateY(-2px)}}.auth-google-btn:active{transform:translateY(2px);transition:transform .1s var(--ease-standard)}.auth-divider{display:flex;align-items:center;margin:1.5rem 0;color:var(--color-text-muted);font-size:.8125rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.auth-divider span{padding:0 1rem}.auth-form .form-group{margin-bottom:var(--space-md)}.auth-form label{display:block;color:var(--color-text-muted);font-size:.8125rem;margin-bottom:.5rem;letter-spacing:.03em}.auth-form input{width:100%;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.75rem 1rem;color:var(--color-text);font-family:inherit;font-size:1rem;transition:border-color var(--transition-fast),background-color var(--transition-fast)}.auth-form input:focus{outline:none;border-color:var(--color-brand);background:var(--color-surface-hover)}.auth-form input:focus-visible{outline:2px solid var(--color-focus);outline-offset:-1px}.auth-error{color:var(--color-danger);font-size:.8125rem;background:color-mix(in srgb,var(--color-danger) 10%,transparent);border:1px solid color-mix(in srgb,var(--color-danger) 20%,transparent);padding:.75rem;border-radius:var(--radius-sm);margin-bottom:1rem;text-align:center}.auth-error.success{color:var(--color-success);background:color-mix(in srgb,var(--color-success) 10%,transparent);border-color:color-mix(in srgb,var(--color-success) 20%,transparent)}.auth-submit-btn{width:100%;background-color:var(--color-brand-secondary);color:var(--color-on-accent);border:none;border-radius:var(--radius-md);padding:.875rem;font-size:1rem;font-weight:500;cursor:pointer;box-shadow:0 0 0 1px var(--color-cta-edge),0 4px 24px var(--color-accent-glow);transition:transform .2s ease}@media(hover:hover){.auth-submit-btn:hover:not(:disabled){transform:translateY(-2px)}}.auth-submit-btn:active:not(:disabled){transform:translateY(2px);transition:transform .1s var(--ease-standard)}.auth-submit-btn:disabled{opacity:.7;cursor:not-allowed}.auth-modal-title{color:var(--color-text);font-family:var(--font-display);font-size:1.5rem;font-weight:500;margin-bottom:1.5rem;text-align:center}.about-interest-panel .auth-interest__title{font-family:var(--font-display);font-size:1.5rem;font-weight:500;line-height:1.2;color:var(--color-text);margin-bottom:.5rem}.auth-interest__desc{color:var(--color-text-muted);font-size:1rem;line-height:1.7;margin-bottom:1.5rem}.auth-interest__form{display:flex;gap:.5rem}.auth-interest__form input{flex:1;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:14px 24px;color:var(--color-text);font-family:inherit;font-size:1rem;transition:border-color var(--transition-fast),background-color var(--transition-fast)}.auth-interest__form input:focus{outline:none;border-color:var(--color-brand);background:var(--color-surface-hover)}.auth-interest__form input:focus-visible{outline:2px solid var(--color-focus);outline-offset:-1px}.auth-interest__btn{background:var(--color-accent);color:var(--color-cta-text, var(--color-on-accent));border:none;border-radius:var(--radius-full);padding:10px 28px;font-family:var(--font-body);font-size:.85rem;font-weight:600;letter-spacing:.04em;cursor:pointer;transition:transform var(--transition-fast),filter var(--transition-fast),box-shadow var(--transition-fast);box-shadow:0 4px 24px var(--color-accent-glow);white-space:nowrap}@media(hover:hover){.auth-interest__btn:hover:not(:disabled){filter:brightness(1.1);box-shadow:0 6px 32px var(--color-accent-glow)}}.auth-interest__btn:active:not(:disabled){transform:translateY(2px);transition:transform .1s var(--ease-standard)}.auth-interest__btn:disabled{opacity:.7;cursor:not-allowed}.auth-interest__msg{font-size:.9rem;padding:.75rem 1rem;border-radius:var(--radius-md);margin-top:.75rem;text-align:center}.auth-interest__msg.success{color:var(--color-success);background:color-mix(in srgb,var(--color-success) 10%,transparent);border:1px solid color-mix(in srgb,var(--color-success) 20%,transparent)}.auth-interest__msg.error{color:var(--color-danger);background:color-mix(in srgb,var(--color-danger) 10%,transparent);border:1px solid color-mix(in srgb,var(--color-danger) 20%,transparent)}.auth-interest__msg.info{color:#7eb8ff;background:#7eb8ff1a;border:1px solid rgba(126,184,255,.2)}.auth-turnstile{margin-top:var(--space-md);margin-bottom:var(--space-md);display:flex;justify-content:center}.user-menu-container{display:inline-flex;align-items:center;gap:var(--space-sm)}.user-menu-container:empty{display:none}.footer-info-btn--danger{color:var(--color-danger)}@media(hover:hover){.footer-info-btn--danger:hover{color:#ff8a8a}}.sign-in-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;background:none;border:none;color:var(--color-text-muted);font-family:inherit;font-size:.85rem;cursor:pointer;transition:color var(--transition-fast),opacity var(--transition-fast);text-decoration:none}@media(hover:hover){.sign-in-btn:hover{opacity:1;color:var(--color-text)}}.sign-in-btn--icon{min-width:44px;min-height:44px;padding:var(--space-xs);gap:0;font-size:0;line-height:1}.sign-in-btn--icon .icon{width:24px;height:24px;display:block}.user-menu-btn{background:transparent;border:0;padding:0;cursor:pointer;color:var(--color-text);font-family:inherit}.user-menu-btn:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px}.user-menu-btn--avatar{min-width:44px;min-height:44px;width:44px;height:44px;border-radius:var(--radius-full);overflow:hidden;display:inline-flex;align-items:center;justify-content:center;background:var(--color-surface)}.user-menu-btn__avatar-img{width:100%;height:100%;object-fit:cover;display:block}.user-menu-btn__avatar-initials{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--color-text);text-transform:uppercase;line-height:1}.footer-divider--user{display:inline}.auth-pills{display:flex;gap:var(--space-xs);margin-bottom:var(--space-sm)}.auth-pill{flex:1;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-md);background:transparent;border:1px solid var(--color-border);color:var(--color-text-muted);font-family:var(--font-body);cursor:pointer;transition:background var(--duration-quick) var(--ease-standard),color var(--duration-quick) var(--ease-standard),border-color var(--duration-quick) var(--ease-standard)}.auth-pill:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px}.auth-pill--active{background:var(--color-surface);color:var(--color-text);border-color:var(--color-text)}.auth-modal__prompt{color:var(--color-text-muted);font-size:.875rem;line-height:1.5;margin-bottom:var(--space-md);text-align:center}body[data-screen=profile]{overflow-y:visible;overflow-x:clip;height:auto;min-height:100dvh}body[data-screen=profile] #app.page-enter,body[data-screen=profile] #app.page-enter-active,body[data-screen=profile] #app.page-exit{transform:none}body[data-screen=profile] #app{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;height:auto;min-height:100dvh;overflow:visible;padding:0}.profile--v4{display:flex;flex-direction:column;min-height:100dvh;width:100%;--copyright-strip-height: 28px;padding-top:var(--header-height);background:var(--color-bg);color:var(--color-text);font-family:var(--font-body)}.profile__layout{display:grid;grid-template-columns:minmax(0,1fr);gap:16px;padding:16px var(--page-padding-x) calc(124px + env(safe-area-inset-bottom,0px))}.profile__sidebar-wrap{display:block}.profile__user{display:flex;flex-direction:column;align-items:flex-start;gap:8px;padding:16px 0;border-bottom:1px solid var(--color-surface-border);margin-bottom:16px}.profile__avatar{width:72px;height:72px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-accent),#5a6ab3);display:flex;align-items:center;justify-content:center;color:var(--color-on-accent);font-family:var(--font-display);font-size:1.6rem;font-weight:600}.profile__user-name{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--color-text)}.profile__user-email{font-size:.85rem;color:var(--color-text-muted)}.profile__main{display:flex}.profile__pane{flex:1;min-width:0;display:flex;flex-direction:column;gap:16px;transition:opacity .2s ease,transform .2s ease}.profile__pane--switching{opacity:0;transform:translateY(4px)}@media(prefers-reduced-motion:reduce){.profile__pane{transition:none}.profile__pane--switching{transform:none}}.profile__pane-error{padding:var(--space-md);color:var(--color-danger);text-align:center;font-size:.875rem}.profile__tablist{position:fixed;bottom:calc(env(safe-area-inset-bottom,0px) + var(--copyright-strip-height));left:0;right:0;height:64px;margin-bottom:16px;display:flex;flex-direction:row;justify-content:space-around;align-items:center;background:var(--color-surface);border-top:1px solid var(--color-surface-border);border-bottom:1px solid var(--color-surface-border);z-index:99}.profile__tab{flex:1;min-height:44px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px 0;background:transparent;border:0;color:var(--color-text-muted);font-family:var(--font-body);font-size:.7rem;font-weight:400;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:color var(--transition-fast)}.profile__tab:hover{color:var(--color-text)}.profile__tab--active{color:var(--color-accent);font-weight:600}.profile__tab:focus-visible,.profile [role=tab]:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px}.profile__tab-icon{display:inline-flex;align-items:center;justify-content:center;font-size:1.2rem;line-height:1}.profile__tab-label{font-size:.7rem}@media(max-width:767px){.profile__tab-label{display:none}}@media(min-width:768px)and (max-width:1023px){.profile__layout{grid-template-columns:72px minmax(0,640px);gap:24px;padding:32px var(--page-padding-x) 48px;max-width:768px;margin:0 auto}.profile__sidebar-wrap{display:block;position:sticky;top:calc(var(--header-height) + 32px);align-self:start;max-height:calc(100dvh - var(--header-height) - 32px);overflow-y:auto}.profile__tablist{position:static;flex-direction:column;justify-content:flex-start;height:auto;width:72px;border-top:0;background:transparent;padding:0;margin-bottom:0}.profile__tab{flex:0 0 auto;min-height:56px;position:relative}.profile__tab-label{position:absolute;left:100%;margin-left:8px;padding:4px 8px;background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-sm);opacity:0;pointer-events:none;transition:opacity var(--transition-fast);white-space:nowrap}.profile__tab:hover .profile__tab-label,.profile__tab:focus-within .profile__tab-label{opacity:1}}@media(min-width:1024px){.profile__layout{grid-template-columns:240px minmax(0,640px);gap:32px;padding:48px var(--page-padding-x) 64px;max-width:912px;margin:0 auto}.profile__sidebar-wrap{display:block;position:sticky;top:calc(var(--header-height) + 48px);align-self:start;max-height:calc(100dvh - var(--header-height) - 64px);overflow-y:auto;width:240px;min-width:240px;max-width:240px}.profile__main{min-width:0}.profile__tablist{position:static;flex-direction:column;align-items:stretch;justify-content:flex-start;height:auto;width:100%;padding:0;border-top:0;background:transparent;margin-bottom:0}.profile__tab{flex-direction:row;justify-content:flex-start;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);min-height:44px;border-left:2px solid transparent;text-align:left}.profile__tab--active{border-left-color:var(--color-accent);background:var(--color-surface-hover)}.profile__tab-label{text-transform:none;letter-spacing:0;font-size:.9rem}}.card{background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-md);padding:24px}.stat-card{background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-md);padding:16px;display:flex;flex-direction:column;gap:4px}.stat-card__value{font-family:var(--font-display);font-size:2.2rem;font-weight:600;line-height:1;color:var(--color-text)}.stat-card__label{font-size:.7rem;font-weight:400;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.big-num{font-family:var(--font-display);font-size:2.2rem;font-weight:600;line-height:1}.h{font-family:var(--font-display);font-size:1.25rem;font-weight:600;line-height:1.2}.label{font-size:.7rem;font-weight:400;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.cta-card{background:linear-gradient(135deg,var(--color-accent),#5a6ab3);color:var(--color-on-accent);border-radius:var(--radius-lg);padding:24px}.btn-secondary:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px}.btn-primary--on-tinted:focus-visible,.btn-secondary--on-tinted:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px;box-shadow:0 0 0 4px var(--color-pure-black)}.share-code__copy.btn-secondary{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);min-height:0;width:auto;max-width:none;font-size:.9rem;font-weight:500;letter-spacing:normal;backdrop-filter:none;-webkit-backdrop-filter:none}.bar{height:6px;background:var(--color-surface-hover);border-radius:var(--radius-full);overflow:hidden}.bar>i{display:block;height:100%;background:var(--color-accent)}.profile__empty-state{text-align:center;padding:0 16px 48px}.profile__empty-state__inner{display:flex;flex-direction:column;align-items:center;gap:16px}.profile__empty-state__inner .profile__empty-body{margin-bottom:8px}.profile__empty-heading{font-family:var(--font-display);font-size:1.25rem;font-weight:600;color:var(--color-text);margin-bottom:8px}.profile__empty-body{color:var(--color-text-muted);font-size:.9rem}@keyframes profile-block-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.profile__pane>[data-pane]>*{animation:profile-block-in .3s var(--ease-out-quint) both}.profile__pane>[data-pane]>*:nth-child(1){animation-delay:0ms}.profile__pane>[data-pane]>*:nth-child(2){animation-delay:50ms}.profile__pane>[data-pane]>*:nth-child(3){animation-delay:.1s}@media(prefers-reduced-motion:reduce){.profile__pane>[data-pane]>*{animation:none}}.profile__glance{display:flex;flex-direction:column;gap:16px}.glance-tier{display:flex;flex-direction:column;gap:8px}.glance-tier__value{font-family:var(--font-display);font-size:3rem;font-weight:600;line-height:1;color:var(--color-text)}.glance-tier__label{color:var(--color-text-muted);font-size:.9rem}.glance-tier__progress{font-size:.8rem;color:var(--color-text-muted)}.glance-stats{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm)}.glance-stats>.stat-card{height:100%}.glance-continue{display:flex;flex-direction:column;gap:8px}.glance-continue__eyebrow{color:var(--color-bg)}.glance-continue__title{color:var(--color-on-accent)}.glance-continue__cta{align-self:flex-start;background:var(--color-pure-white);color:var(--color-brand-secondary)}.profile__practice{display:flex;flex-direction:column;gap:16px}.practice-continue{display:flex;flex-direction:column;gap:8px}.practice-continue__eyebrow{color:var(--color-bg)}.practice-continue__title{color:var(--color-on-accent)}.practice-continue__meta{color:#ffffffd9}.practice-continue__cta{align-self:flex-start;background:var(--color-pure-white);color:var(--color-brand-secondary)}.practice-library{display:flex;flex-direction:column;gap:var(--space-md)}.practice-library__header{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.practice-library__count{color:var(--color-text-muted)}.profile__reflect{display:flex;flex-direction:column;gap:24px}.profile__reflect--loading{padding:24px}.reflect-section{display:flex;flex-direction:column;gap:var(--space-sm)}.reflect-insight{color:var(--color-text-muted);font-style:italic}.most-practiced{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.most-practiced__item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-sm)}.most-practiced__count{color:var(--color-text-muted)}.reflect-longest{display:flex;flex-direction:column;gap:4px}.reflect-longest__value{font-size:1.4rem}.chart{width:100%;max-width:320px}.chart-bar{fill:color-mix(in srgb,var(--color-accent) 70%,transparent);transition:fill var(--transition-fast)}.chart-bar-label{fill:var(--color-text-muted);font-size:10px;text-transform:uppercase}.chart-dot{fill:var(--color-surface-hover);stroke:var(--color-surface-border);stroke-width:1}.chart-dot--sat{fill:color-mix(in srgb,var(--color-accent) 60%,transparent);stroke:none}.chart-dot--today{fill:var(--color-accent);stroke:none}.chart-dot--empty{fill:var(--color-surface);stroke:var(--color-surface-border)}.achievements-grid{display:grid;grid-template-columns:1fr;gap:var(--space-sm)}@media(min-width:768px){.achievements-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.achievement-card{display:flex;align-items:center;justify-content:normal;gap:var(--space-sm);min-height:130px;background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-md);padding:16px}.achievement-card.locked{opacity:.55}.achievement-card__desc{flex:1;min-width:0;padding:10px 5px;font-size:.85rem;color:var(--color-text-muted);line-height:1.4}.achievement-badge{flex:0 0 auto;min-width:96px;min-height:96px;max-width:96px;max-height:96px;align-content:center;background:var(--color-surface-hover, var(--color-surface));border:1px solid var(--color-surface-border);border-radius:var(--radius-sm);padding:10px var(--space-sm);text-align:center}.achievement-badge.unlocked{border-color:var(--color-accent)}.achievement-badge.locked{opacity:1}.achievement-badge__icon{font-size:1.5rem;margin-bottom:4px}.achievement-badge__name{font-size:.8rem;color:var(--color-text)}.collect-next{display:flex;flex-direction:column;gap:8px;margin-bottom:32px}.collect-next__title{color:var(--color-text)}.collect-next__desc{color:var(--color-text-muted);font-size:.85rem}.collect-library{display:flex;flex-direction:column;gap:var(--space-sm)}.collect-library__header{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.collect-library__count{color:var(--color-text-muted)}.library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-sm)}.library-grid-item{background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-md);padding:16px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:border-color var(--transition-fast);min-height:44px;text-align:center}.library-grid-item.unlocked:hover{border-color:var(--color-accent)}.library-grid-item.locked{opacity:.55;cursor:default}.library-grid-item__icon{font-size:1rem;color:var(--color-text-muted)}.library-grid-item__name{font-size:.85rem;color:var(--color-text);text-align:center}.library-grid-item__duration{font-size:.7rem;color:var(--color-text-muted)}.library-grid-item__lock-label{font-size:.65rem;color:var(--color-text-faint)}.profile__share{display:flex;flex-direction:column;gap:16px}.share-hero{display:flex;flex-direction:column;gap:8px}.share-hero__headline{color:var(--color-text)}.share-hero__subhead{color:var(--color-text-muted)}.share-code{display:flex;flex-direction:column;gap:var(--space-sm)}.share-code__value{display:flex;align-items:center;gap:var(--space-sm)}.share-code__copy{display:inline-flex;align-items:center;gap:8px}.share-code__error{color:var(--color-danger);font-size:.8rem;margin-top:8px}.share-channels{display:flex;flex-direction:column;gap:var(--space-sm)}.share-channels__cta{display:inline-flex;align-items:center;gap:8px;align-self:flex-start}.share-invites-card{gap:8px}.share-invites-card__value{font-family:var(--font-display);font-size:2.5rem;line-height:1;margin:4px 0 8px}.share-invites-card__subhead{color:var(--color-text-muted);font-size:.9rem;line-height:1.4;margin:0}.achievement-toast{position:fixed;bottom:2rem;left:50%;transform:translate(-50%) translateY(100px);display:flex;align-items:center;gap:.75rem;background:var(--color-surface);border:1px solid var(--color-brand);border-radius:var(--radius-md);padding:1rem 1.5rem;box-shadow:0 10px 30px var(--color-overlay-medium);opacity:0;transition:transform .3s ease,opacity .3s ease;z-index:10001}.achievement-toast.show{transform:translate(-50%) translateY(0);opacity:1}.achievement-toast__icon{font-size:2rem}.achievement-toast__content{display:flex;flex-direction:column}.achievement-toast__title{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.achievement-toast__name{font-family:var(--font-display);font-size:1.125rem;color:var(--color-text);font-weight:500}.pwa-update-toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:var(--color-surface);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--color-surface-border);color:var(--color-text);padding:16px 20px;border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:stretch;text-align:center;gap:var(--space-sm);z-index:9999;box-shadow:0 8px 32px var(--color-overlay-dark);font-family:var(--font-body);font-size:.95rem;animation:slideUpFade .4s var(--ease-out-quint) forwards}.pwa-update-btn{background:var(--color-accent);color:var(--color-on-accent);border:none;border-radius:var(--radius-full);padding:8px 16px;font-family:var(--font-body);font-size:.85rem;font-weight:500;cursor:pointer;transition:transform var(--transition-fast),filter var(--transition-fast),box-shadow var(--transition-fast)}@media(hover:hover){.pwa-update-btn:hover{transform:translateY(-1px);filter:brightness(1.1);box-shadow:0 4px 12px var(--color-accent-glow)}}@keyframes slideUpFade{0%{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%)}}.consent-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;padding:1rem 1.25rem;background:var(--color-surface);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap;animation:slideUp .3s ease-out}.consent-banner__text{font-size:.8rem;color:var(--color-text-muted);margin:0;flex:1;min-width:200px}.consent-banner__actions{display:flex;gap:.5rem;flex-shrink:0}.consent-banner__btn{padding:.4rem 1rem;border-radius:var(--radius-sm);font-size:.8rem;font-weight:500;cursor:pointer;border:none;transition:opacity .2s ease}@media(hover:hover){.consent-banner__btn:hover{opacity:.85}}.consent-banner__btn--accept{background:var(--color-brand);color:var(--color-on-accent)}.consent-banner__btn--decline{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.info-overlay{border:none;padding:0;margin:0;position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;max-width:none;max-height:none;background:color-mix(in srgb,var(--color-bg) 55%,transparent);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);align-items:center;justify-content:center;opacity:0;z-index:10000;transition:opacity .5s var(--ease-standard);outline:none}.info-overlay[open]{display:flex}.info-overlay.visible{opacity:1}.info-overlay::backdrop{background:transparent}.info-panel{background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);padding:24px 32px;width:calc(100% - 48px);max-width:400px;transform:translateY(20px);opacity:0;transition:transform .5s var(--ease-standard),opacity .5s var(--ease-standard);box-shadow:0 16px 40px var(--color-overlay-medium)}.info-overlay.visible .info-panel{transform:translateY(0);opacity:1}.info-panel__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.info-panel__title{font-family:var(--font-display);font-size:1.5rem;color:var(--color-text);font-weight:500}.info-panel__updated{font-size:.75rem;color:var(--color-text-faint);margin-top:calc(var(--space-sm) * -1);margin-bottom:20px}.info-panel__close-btn{background:transparent;border:none;color:var(--color-text-muted);font-size:1.2rem;cursor:pointer;transition:color var(--transition-fast);-webkit-tap-highlight-color:transparent;min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center}.info-panel__close-btn:focus:not(:focus-visible){outline:none}.info-panel__close-btn:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px}@media(hover:hover){.info-panel__close-btn:hover{color:var(--color-text)}}.info-panel__content{display:flex;flex-direction:column;gap:20px}.info-panel__desc{font-size:.95rem;color:var(--color-text-muted);line-height:1.5}.info-panel__links{display:flex;flex-direction:column;gap:var(--space-sm)}.info-panel__link{display:flex;align-items:center;gap:var(--space-sm);color:var(--color-text);text-decoration:none;font-size:.95rem;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);background:var(--color-surface);border:1px solid var(--color-surface-border);transition:background var(--transition-fast),transform var(--transition-fast)}.info-panel__link svg{color:var(--color-accent);font-size:1.1rem}@media(hover:hover){.info-panel__link:hover{background:var(--color-surface-hover);transform:translateY(-2px)}}#submit-feedback{margin-top:var(--space-md)}.info-panel__feedback h3{font-size:1rem;font-weight:500;margin-bottom:var(--space-md);color:var(--color-text)}.info-panel__feedback form{display:flex;flex-direction:column;gap:var(--space-sm)}.info-panel__feedback input,.info-panel__feedback textarea{width:100%;padding:var(--space-md);border-radius:var(--radius-sm);border:1px solid var(--color-surface-border);background:var(--color-surface);color:var(--color-text);font-family:var(--font-body);font-size:1rem;outline:none;transition:border-color var(--transition-fast)}.info-panel__feedback input:focus,.info-panel__feedback textarea:focus{border-color:var(--color-accent)}.info-panel__feedback input:focus-visible,.info-panel__feedback textarea:focus-visible{outline:2px solid var(--color-focus);outline-offset:-1px}.info-panel__feedback textarea{resize:vertical;min-height:80px}.info-panel__feedback input::placeholder,.info-panel__feedback textarea::placeholder{color:var(--color-text-muted);opacity:1;-webkit-text-fill-color:var(--color-text-muted)}.btn-small{padding:10px 24px;font-size:.9rem}.legal-panel{max-width:460px;max-height:70vh;display:flex;flex-direction:column;overflow:hidden}.legal-panel__content{display:flex;flex-direction:column;gap:var(--space-sm);flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.legal-panel__content h3{font-family:var(--font-display);font-size:1.2rem;font-weight:500;color:var(--color-text);margin-top:16px}.legal-panel__content h3:first-child{margin-top:0}.legal-panel__content h4{font-size:.95rem;font-weight:500;color:var(--color-text);margin-top:8px}.legal-panel__content p{font-size:.85rem;line-height:1.6;color:var(--color-text-muted)}html:has(.landing) body,html:has(.about-page) body,html:has(.faq-page) body{overflow-y:visible!important;height:auto!important;min-height:100vh;min-height:100dvh}html:has(.landing) #app,html:has(.about-page) #app,html:has(.faq-page) #app{height:auto!important;min-height:100vh;min-height:100dvh;overflow-y:visible!important}body:before{content:"";position:fixed;top:0;left:0;right:0;padding:calc(32px + env(safe-area-inset-top,0px)) 20px clamp(60px,6vh,120px);z-index:5;pointer-events:none;background:linear-gradient(to bottom,var(--color-bg) 40%,transparent 100%)}#app:not(:has(.landing))~.about-content{display:none}#landing-logo-header{display:none;transition:opacity .4s ease}html:has(.landing) #landing-logo-header{display:flex}html:has(.landing) body[data-screen=landing] #landing-logo-header{display:none}html:has(#app.page-exit) #landing-logo-header{opacity:0}@media(prefers-reduced-motion:reduce){#landing-logo-header{transition:none}}.about-content{position:relative;z-index:1;max-width:800px;margin:0 auto;padding:96px 24px 180px;display:flex;flex-direction:column;gap:96px}.about-section h2{font-family:var(--font-display);font-size:2rem;font-weight:500;line-height:1.2;color:var(--color-text);margin-bottom:16px}.about-section p{font-size:1rem;line-height:1.7;margin-bottom:16px}.about-section p:last-child{margin-bottom:0}.about-features{display:flex;flex-direction:column;gap:32px;margin-top:24px}.about-feature{display:flex;gap:24px;align-items:flex-start}.about-feature__label{font-family:var(--font-display);font-size:2rem;font-weight:500;line-height:1;color:var(--color-accent);flex-shrink:0;min-width:48px}.about-feature__content h3{font-size:1.125rem;font-weight:500;color:var(--color-text);margin-bottom:8px}.about-feature__content p{font-size:1rem;line-height:1.7;color:var(--color-text-muted);margin-bottom:0}.about-section--cta{text-align:center;padding:48px 0}.about-social__heading{font-family:var(--font-display);font-size:1.25rem;font-weight:500;color:var(--color-text);margin-bottom:0;margin-top:72px;text-align:left}.about-social__links{display:inline-flex;gap:16px;margin-top:0}.about-social__links a{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;color:var(--color-text-muted);transition:color .2s ease}.about-social__links a:hover{color:var(--color-text)}.about-section--cta .btn-primary{display:inline-block;text-decoration:none;max-width:320px}@media(max-width:640px){.about-content{gap:72px}.about-feature{flex-direction:column;gap:8px}.about-feature__label{font-size:1.5rem}}.about-page{position:relative;z-index:1}.about-page__header{max-width:800px;margin:0 auto;padding:var(--space-4xl) var(--space-lg) 0;text-align:center}.about-page__title{font-family:var(--font-display);font-size:2.5rem;font-weight:500;line-height:1.2;color:var(--color-text);margin:0 0 var(--space-md)}.about-page__intro{font-size:1.125rem;line-height:1.7;color:var(--color-text-muted);margin:0}[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .6s ease-out,transform .6s ease-out;will-change:opacity,transform}[data-reveal].revealed{opacity:1;transform:none}@media(prefers-reduced-motion:reduce){[data-reveal]{opacity:1;transform:none;transition:none}}.faq-page{position:relative;z-index:1}.faq-page__header{max-width:800px;margin:0 auto;padding:var(--space-4xl) var(--space-lg) 0;text-align:center}.faq-page__title{font-family:var(--font-display);font-size:2.5rem;font-weight:500;line-height:1.2;color:var(--color-text);margin:0 0 var(--space-md)}.faq-page__intro{font-size:1.125rem;line-height:1.7;color:var(--color-text-muted);max-width:540px;margin:0 auto}.faq-list{position:relative;z-index:1;max-width:800px;margin:0 auto;padding:var(--space-2xl) var(--space-lg) 180px;display:flex;flex-direction:column;gap:var(--space-md)}.faq-entry{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);overflow:hidden}.faq-entry__question{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-md) var(--space-lg);cursor:pointer;color:var(--color-text);font-family:var(--font-display);font-size:1.125rem;line-height:1.4;list-style:none}.faq-entry__question::-webkit-details-marker{display:none}.faq-entry__question:after{content:"+";flex:0 0 auto;color:var(--color-text-muted);transition:transform var(--duration-quick) var(--ease-standard)}.faq-entry[open] .faq-entry__question:after{transform:rotate(45deg)}@supports (interpolate-size: allow-keywords){.faq-entry::details-content{height:0;overflow:hidden;transition:height var(--duration-quick) var(--ease-standard),content-visibility var(--duration-quick) allow-discrete}.faq-entry[open]::details-content{height:auto}}@media(prefers-reduced-motion:reduce){.faq-entry__question:after{transition:none}@supports (interpolate-size: allow-keywords){.faq-entry::details-content{transition:none}}}.faq-entry__answer{padding:0 var(--space-lg) var(--space-lg);color:var(--color-text)}.faq-entry__answer p{font-size:1rem;line-height:1.7;color:var(--color-text-muted);margin:0 0 var(--space-md)}.faq-entry__answer p:last-child{margin-bottom:0}@media(max-width:640px){.faq-page__title{font-size:2rem}.faq-list{gap:var(--space-sm)}}.tempo-onboarding{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;border:0;padding:0;background:transparent;color:var(--color-text);font-family:var(--font-body);width:100%;height:100%;max-width:none;max-height:none}.tempo-onboarding::backdrop{background:var(--color-overlay-dark);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.tempo-onboarding__card{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:calc(100% - 48px);max-width:400px;padding:var(--space-lg) var(--space-xl);background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);box-shadow:0 16px 40px var(--color-overlay-dark);display:flex;flex-direction:column;align-items:center;gap:var(--space-md)}.tempo-onboarding__heading,.tempo-onboarding__body{align-self:stretch}.tempo-onboarding__heading{font-family:var(--font-display);font-size:1.5rem;line-height:1.3;color:var(--color-text);margin:0}.tempo-onboarding__body{font-family:var(--font-body);font-size:1rem;line-height:1.5;color:var(--color-text-muted);margin:0}.tempo-onboarding-spotlight{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;pointer-events:none}.tempo-onboarding-spotlight__scrim{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--color-overlay-dark);pointer-events:auto;mask:radial-gradient(circle at var(--cutout-x, 50%) var(--cutout-y, 50%),transparent var(--cutout-r, 32px),black calc(var(--cutout-r, 32px) + 1px));-webkit-mask:radial-gradient(circle at var(--cutout-x, 50%) var(--cutout-y, 50%),transparent var(--cutout-r, 32px),black calc(var(--cutout-r, 32px) + 1px));transition:opacity var(--duration-base) var(--ease-standard)}.tempo-onboarding-spotlight__cutout{position:absolute;pointer-events:none;border-radius:var(--radius-full)}.tempo-onboarding-spotlight__caption{position:absolute;top:calc(var(--cutout-y, 50%) + var(--cutout-r, 32px) + var(--space-lg));left:50%;transform:translate(-50%);max-width:min(420px,calc(100vw - var(--space-xl)));padding:var(--space-md) var(--space-lg);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family:var(--font-body);pointer-events:auto}.tempo-coach-mark{position:fixed;bottom:var(--space-4xl);left:50%;transform:translate(-50%);padding:var(--space-sm) var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text);font-family:var(--font-body);font-size:.875rem;z-index:99;opacity:1;transition:opacity var(--duration-base) var(--ease-standard)}.tempo-coach-mark.is-fading{opacity:0}.tempo-coach-mark__message{margin:0}.tempo-debrief{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;border:0;padding:0;background:transparent;color:var(--color-text);font-family:var(--font-body);width:100%;height:100%;max-width:none;max-height:none}.tempo-debrief::backdrop{background:var(--color-overlay-dark)}.tempo-debrief__card{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(420px,calc(100vw - var(--space-xl)));padding:var(--space-xl);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;gap:var(--space-md)}.tempo-debrief__heading,.tempo-debrief__body{align-self:stretch}.tempo-debrief__heading{font-family:var(--font-display);font-size:1.5rem;line-height:1.3;color:var(--color-text);margin:0}.tempo-debrief__body{font-family:var(--font-body);font-size:1rem;line-height:1.5;color:var(--color-text-muted);margin:0}.tempo-help-icon{position:fixed;top:var(--space-md);right:var(--space-3xl);width:var(--space-xl);height:var(--space-xl);border-radius:var(--radius-full);background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);cursor:pointer;z-index:99;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-body);font-size:1rem;padding:0;transition:background-color var(--duration-quick) var(--ease-standard),border-color var(--duration-quick) var(--ease-standard)}.tempo-help-icon[hidden]{display:none}.tempo-help-icon__glyph{font-weight:600;line-height:1}[data-sensor-lost=true]{color:var(--color-warning);transition:color var(--duration-base) var(--ease-standard)}.tempo-sensor-lost-toast{position:fixed;bottom:var(--space-xl);left:50%;transform:translate(-50%);display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);color:var(--color-text);border:1px solid var(--color-warning);border-radius:var(--radius-md);z-index:99}.tempo-sensor-lost-toast__retry{margin-left:var(--space-sm)}.heart-badge[data-tempo-active=true]{display:none}
