@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-inline-label{margin-top:.5rem;display:flex;align-items:center;gap:.5rem;font-size:.7rem}.debug-error{color:#ff6b6b;font-size:.8rem}.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-brand);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-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}[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-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}[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-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}html,body{width:100%;height:100vh;height:100dvh;overflow: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}#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;left: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:all .2s}@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;left: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}@media(max-width:767px)and (prefers-reduced-motion:reduce){*{backdrop-filter:none!important;-webkit-backdrop-filter:none!important}}.landing{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:32px;max-width:640px;width:100%;min-height:100vh;min-height:100dvh;padding:calc(80px + env(safe-area-inset-top,0px)) 24px calc(80px + env(safe-area-inset-bottom,0px))}.landing__logo,.landing__greeting,.landing__subtitle,.landing__card,#btn-begin,.landing__waitlist-link{opacity:0;animation:fadeInUp .8s ease forwards}.landing__logo{animation-delay:0s}.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-surface);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}.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}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--color-accent);color:var(--color-cta-text, #fff);border:none;border-radius:50px;padding:16px 40px;font-family:var(--font-body);font-size:1rem;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);width:100%;max-width:320px}@media(hover:hover){.btn-primary:hover{filter:brightness(1.1);box-shadow:0 6px 32px var(--color-accent-glow)}}.btn-primary:active{transform:translateY(2px);transition:transform .1s cubic-bezier(.4,0,.2,1)}.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{flex-shrink:0;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;width:100%;opacity:0;animation:fadeInUp .6s ease forwards;position:relative;z-index:10}.session__header-left{justify-self:start;display:flex;align-items:center}.session__back-btn{background:transparent;border:none;color:var(--color-text-muted);font-size:1.2rem;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;transition:color var(--transition-fast),transform var(--transition-fast)}@media(hover:hover){.session__back-btn:hover{color:var(--color-text);transform:translate(-4px)}}.session__exercise-name{font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--color-text-muted);font-weight:500;opacity:.7;justify-self:center;text-align:center}.session__audio-controls{justify-self:end;display:flex;gap:8px;align-items:center;position:relative}.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 cubic-bezier(.4,0,.2,1)}@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 cubic-bezier(.175,.885,.32,1.275);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%,rgba(0,0,0,0) 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 cubic-bezier(.4,0,.2,1)}.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:.5}.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}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:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);align-items:center;justify-content:center;opacity:0;z-index:10000;transition:opacity .5s cubic-bezier(.4,0,.2,1);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 cubic-bezier(.4,0,.2,1)}.pairing-overlay.is-closing-slow .pairing-panel{transition:transform 1.2s cubic-bezier(.4,0,.2,1),opacity 1.2s cubic-bezier(.4,0,.2,1)}.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 cubic-bezier(.4,0,.2,1),opacity .5s cubic-bezier(.4,0,.2,1);box-shadow:0 16px 40px #0006}.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-brand);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:12px;animation:pairingSuccessPop .35s cubic-bezier(.2,.8,.3,1.2)}.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:#ff6b6b;margin:12px 0 0;min-height:0}.pairing-error:empty{display:none}.pairing-chip{display:flex;align-items:center;gap:12px;padding:16px;background:#ffffff0a;border:1px solid var(--color-surface-border);border-radius:var(--radius-sm)}[data-mode=light] .pairing-chip{background:#0000000a}.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-brand);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:#ff6b6b80;background:#ff6b6b14}[data-mode=light] .pairing-chip.is-confirming-unpair{background:#ff6b6b1f}.pairing-chip.is-confirming-unpair .pairing-chip__action--unpair{color:#fff;background:#ff6b6b}@media(hover:hover){.pairing-chip.is-confirming-unpair .pairing-chip__action--unpair:hover{background:#ff4d4d;color:#fff}}.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-brand);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-brand);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:.5}.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%)}.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:32px 16px;z-index:1}.complete__buttons-section{position:fixed;top:50%;left:50%;z-index:21;display:flex;flex-direction:column;align-items:stretch;gap:12px;flex:0 0 300px;width:min(260px,calc(100% - 48px));height:300px;max-height:80dvh;padding:20px 16px;background:transparent;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;transform:translate(-50%,-50%) scale(0);transform-origin:center center;opacity:0;visibility:hidden;transition:transform .4s cubic-bezier(.2,.8,.2,1),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 cubic-bezier(.2,.8,.2,1),opacity .25s ease,visibility 0s linear 0s}.complete__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;background:#0009;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:8px 12px}.complete__toggle{display:flex;align-items:center;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:transform var(--transition-fast)}.complete__toggle:active{transform:translateY(2px);transition:transform .1s cubic-bezier(.4,0,.2,1)}.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:26px;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 #0003}.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-brand);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;animation:fadeInUp .6s ease forwards}.complete__actions>button:active{transform:translateY(2px)!important;transition:transform .1s cubic-bezier(.4,0,.2,1)}.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 cubic-bezier(.4,0,.2,1);cursor:pointer;touch-action:pan-x;-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none;animation:complete__card-spin 2s cubic-bezier(.25,.1,.25,1) .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:1.3rem;font-weight:600;color:#1a1a2e;text-shadow:0 1px 3px rgba(235,235,235,.5);line-height:1.3;margin-bottom:4px}[data-mode=dark] .complete__card-overlay-title{color:#d9d9d9;text-shadow:0 1px 3px rgba(0,0,0,.5)}.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 rgba(0,0,0,.5)}.complete__session-badge{position:absolute;top:12px;right:12px;z-index:2;padding:4px 12px;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 rgba(0,0,0,.3)}.complete__trigger{margin-top:32px;display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;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 #00000026;animation:complete__trigger-reveal .5s cubic-bezier(.2,.8,.2,1) 1.2s backwards;transition:transform var(--transition-fast),filter 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)}}.complete__trigger:active{transform:translateY(2px);transition:transform .1s cubic-bezier(.4,0,.2,1)}.complete__card-category{font-size:.75rem;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:12px}.complete__card-description{font-size:.9rem;font-weight:400;line-height:1.65;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:12px;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:12px;width:100%}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-surface-border);border-radius:50px;padding:14px 32px;font-family:var(--font-body);font-size:.9rem;font-weight:500;letter-spacing:.03em;cursor:pointer;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 #00000026}}.btn-secondary:active{transform:translateY(2px);transition:transform .1s cubic-bezier(.4,0,.2,1)}#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 cubic-bezier(.16,1,.3,1),transform .5s cubic-bezier(.16,1,.3,1)}@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 cubic-bezier(.2,.8,.2,1) 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:12px 24px;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:12px;padding:12px;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:12px 16px}.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(32px + 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)}.footer-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}.footer-links{display:flex;align-items:center;justify-content:center;gap:12px}.app-footer p{font-size:.75rem;color:var(--color-text-muted);letter-spacing:.05em;opacity:.6;margin:0}.footer-divider{font-size:.75rem;color:var(--color-text-muted);letter-spacing:.05em;opacity:.6}.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:all var(--transition-fast);-moz-appearance:none;appearance:none;-webkit-appearance:none;outline:none;min-height:44px;display:inline-flex;align-items:center}.footer-info-btn:focus-visible{outline:2px solid var(--color-brand);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__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 #0000004d;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:12px 16px;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}@media(hover:hover){.lang-picker__item:hover{background:#ffffff14;color:var(--color-text)}}.footer-nav-toggle{display:none;background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-full);color:var(--color-text-muted);font-size:1.25rem;padding:8px;cursor:pointer;align-items:center;justify-content:center;transition:all var(--transition-fast);line-height:1;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}@media(hover:hover){.footer-nav-toggle:hover{opacity:1;color:var(--color-text)}}@media(max-width:640px){.footer-nav-toggle{display:flex;width:100%;max-width:240px;height:36px;padding:0 16px;border-radius:var(--radius-full);font-size:.85rem;gap:.4rem}.footer-links{display:flex;flex-direction:column;align-items:center;gap:0;width:100%;max-width:240px;margin-left:auto;margin-right:auto;overflow:hidden;max-height:0;opacity:0;pointer-events:none;background:var(--color-surface);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid transparent;border-radius:var(--radius-md);padding:0 16px;margin-bottom:0;transition:max-height .5s cubic-bezier(.4,0,.2,1),opacity .5s cubic-bezier(.4,0,.2,1),border-color .5s cubic-bezier(.4,0,.2,1),padding .5s cubic-bezier(.4,0,.2,1),margin-bottom .5s cubic-bezier(.4,0,.2,1)}.footer-links.open{max-height:min(320px,50vh);overflow:hidden;opacity:1;pointer-events:auto;border-color:var(--color-surface-border);padding:8px 16px;margin-bottom:6px;transition:max-height .5s cubic-bezier(.4,0,.2,1),opacity .5s cubic-bezier(.4,0,.2,1),border-color .5s cubic-bezier(.4,0,.2,1),padding .5s cubic-bezier(.4,0,.2,1),margin-bottom .5s cubic-bezier(.4,0,.2,1)}.footer-links .footer-divider{display:none}.footer-links .footer-info-btn,.footer-links .sign-in-btn{display:flex;align-items:center;justify-content:center;width:100%;min-height:44px;padding:10px 0;font-size:.85rem}.footer-links .lang-picker{width:100%}.footer-links .user-menu-container{display:block;width:100%}}@media(orientation:landscape)and (max-height:500px){.footer-nav-toggle{display:flex;position:absolute;left:16px;bottom:calc(8px + env(safe-area-inset-bottom,0px))}.footer-links{display:flex;flex-direction:column;align-items:flex-start;gap:0;position:absolute;left:16px;bottom:calc(48px + env(safe-area-inset-bottom,0px));overflow:hidden;max-height:0;opacity:0;pointer-events:none;background:var(--color-surface);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid transparent;border-radius:var(--radius-md);padding:0 24px;transition:max-height .5s cubic-bezier(.4,0,.2,1),opacity .5s cubic-bezier(.4,0,.2,1),border-color .5s cubic-bezier(.4,0,.2,1),padding .5s cubic-bezier(.4,0,.2,1)}.footer-links.open{max-height:min(280px,70vh);overflow:hidden;opacity:1;pointer-events:auto;border-color:var(--color-surface-border);padding:8px 24px;transition:max-height .5s cubic-bezier(.4,0,.2,1),opacity .5s cubic-bezier(.4,0,.2,1),border-color .5s cubic-bezier(.4,0,.2,1),padding .5s cubic-bezier(.4,0,.2,1)}.footer-links .footer-divider{display:none}.footer-links .footer-info-btn,.footer-links .sign-in-btn{display:flex;align-items:center;justify-content:flex-start;width:100%;min-height:36px;padding:6px 0;font-size:.8rem}.footer-links .lang-picker{width:100%}.footer-links .user-menu-container{display:block;width:100%}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.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 cubic-bezier(.4,0,.2,1);animation:modalFadeIn .5s cubic-bezier(.4,0,.2,1)}.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 #00000080;transition:transform .5s cubic-bezier(.4,0,.2,1),opacity .5s cubic-bezier(.4,0,.2,1);animation:modalSlideUp .5s cubic-bezier(.4,0,.2,1)}.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:all .2s;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 cubic-bezier(.4,0,.2,1)}.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:1.25rem}.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:all .2s}.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-brand);outline-offset:-1px}.auth-error{color:#ff6b6b;font-size:.8125rem;background:#ff6b6b1a;border:1px solid rgba(255,107,107,.2);padding:.75rem;border-radius:var(--radius-sm);margin-bottom:1rem;text-align:center}.auth-error.success{color:#6bff8a;background:#6bff8a1a;border-color:#6bff8a33}.auth-submit-btn{width:100%;background-color:var(--color-brand);color:#fff;border:none;border-radius:var(--radius-md);padding:.875rem;font-size:1rem;font-weight:500;cursor:pointer;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 cubic-bezier(.4,0,.2,1)}.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:50px;padding:14px 24px;color:var(--color-text);font-family:inherit;font-size:1rem;transition:all .2s}.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-brand);outline-offset:-1px}.auth-interest__btn{background:var(--color-accent);color:var(--color-cta-text, #fff);border:none;border-radius:50px;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 cubic-bezier(.4,0,.2,1)}.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:#6bff8a;background:#6bff8a1a;border:1px solid rgba(107,255,138,.2)}.auth-interest__msg.error{color:#ff6b6b;background:#ff6b6b1a;border:1px solid rgba(255,107,107,.2)}.auth-interest__msg.info{color:#7eb8ff;background:#7eb8ff1a;border:1px solid rgba(126,184,255,.2)}.user-menu-container{display:inline-flex;align-items:center;gap:12px}.user-menu-container:empty{display:none}.footer-info-btn--danger{color:#ff6b6b}@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:all .2s;text-decoration:none}@media(hover:hover){.sign-in-btn:hover{opacity:1;color:var(--color-text)}}.footer-divider--user{display:inline}.profile{position:relative;z-index:1;width:100%;max-width:900px;margin:0 auto;padding:1.5rem;height:100vh;height:100dvh;overflow-y:auto;-webkit-overflow-scrolling:touch}.profile__layout{display:flex;flex-direction:column;gap:2rem;width:100%}.profile__column-side,.profile__column-main{width:100%;min-width:0}@media(min-width:768px){.profile__layout{flex-direction:row;align-items:flex-start}.profile__column-side{flex:0 0 300px}.profile__column-main{flex:1;min-width:0}}.profile__header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.profile__back{background:none;border:none;color:var(--color-text-muted);font-size:1.25rem;cursor:pointer;padding:.5rem;transition:color .2s}@media(hover:hover){.profile__back:hover{color:var(--color-text)}}.profile__title{font-family:var(--font-display);font-size:1.5rem;font-weight:500;color:var(--color-text)}.profile__user{text-align:center;margin-bottom:2rem}.profile__avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid var(--color-brand);margin-bottom:.75rem}.profile__avatar--initials{display:flex;align-items:center;justify-content:center;background:var(--color-brand);color:#fff;font-size:2rem;font-weight:600;margin:0 auto .75rem}.profile__name{font-family:var(--font-display);font-size:1.5rem;color:var(--color-text);margin-bottom:.25rem}.profile__email{font-size:.875rem;color:var(--color-text-muted)}.profile__stats{display:flex;gap:1rem;margin-bottom:2rem}.stat-card{flex:1;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1rem;text-align:center}.stat-card__value{font-family:var(--font-display);font-size:1.75rem;font-weight:500;color:var(--color-text)}.stat-card__label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:.25rem}.profile__section{margin-bottom:2rem}.profile__section-title{display:flex;align-items:center;gap:.5rem;font-family:var(--font-body);font-size:.875rem;font-weight:600;color:var(--color-text);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem}.profile__section-title svg{color:var(--color-brand)}.profile__section-title .badge{margin-left:auto;font-size:.75rem;color:var(--color-text-muted);font-weight:400}.achievements-grid{display:flex;flex-wrap:wrap;gap:.75rem}.achievement-badge{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:80px;transition:all .2s}.achievement-badge.locked{opacity:.4;filter:grayscale(1)}.achievement-badge.unlocked{border-color:var(--color-brand)}.achievement-badge__icon{font-size:1.5rem}.achievement-badge__name{font-size:.625rem;color:var(--color-text-muted);text-align:center}.library-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}@media(max-width:400px){.library-grid{grid-template-columns:repeat(3,1fr)}}.library-grid-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.75rem .5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;min-height:80px;font:inherit;color:inherit;text-align:center;width:100%}@media(hover:hover){.library-grid-item:hover{background:var(--color-surface-hover);border-color:var(--color-brand);transform:translateY(-2px)}}.library-grid-item.locked{opacity:.5}@media(hover:hover){.library-grid-item.locked:hover{opacity:.7}}.library-grid-item__icon{font-size:1.25rem;color:var(--color-text-muted);margin-bottom:.25rem}.library-grid-item.unlocked .library-grid-item__icon{color:var(--color-brand)}.library-grid-item__name{font-size:.6875rem;color:var(--color-text);text-align:center;line-height:1.2;max-width:100%;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}.library-grid-item__duration{font-size:.625rem;color:var(--color-text-muted);margin-top:.125rem}.library-grid-item.tier-locked{opacity:.35;cursor:default;border-style:dashed}@media(hover:hover){.library-grid-item.tier-locked:hover{transform:none;opacity:.4;border-color:var(--color-border);background:var(--color-surface)}}.library-grid-item__lock-label{font-size:.5625rem;color:var(--color-text-muted);text-align:center;text-transform:uppercase;letter-spacing:.04em;margin-top:.25rem}.referral-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1rem}.referral-code-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.referral-code-label{font-size:.75rem;color:var(--color-text-muted);white-space:nowrap}.referral-code-value{font-family:SF Mono,Fira Code,monospace;font-size:1rem;font-weight:600;color:var(--color-brand);letter-spacing:.1em;flex:1}.referral-copy-btn{background:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);padding:.375rem .5rem;cursor:pointer;transition:all .2s;font-size:.875rem}@media(hover:hover){.referral-copy-btn:hover{color:var(--color-brand);border-color:var(--color-brand)}}.referral-stats{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:var(--color-text-muted);margin-bottom:.75rem}.referral-next{color:var(--color-brand);font-weight:500}.referral-themes-list{display:flex;flex-direction:column;gap:.5rem}.referral-theme-item{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;padding:.375rem 0;border-bottom:1px solid rgba(255,255,255,.04)}.referral-theme-item:last-child{border-bottom:none}.referral-theme-icon{font-size:.875rem;width:1.25rem;text-align:center}.referral-theme-name{flex:1;color:var(--color-text)}.referral-theme-item.locked .referral-theme-name{color:var(--color-text-muted)}.referral-theme-req{font-size:.6875rem;color:var(--color-text-muted)}.referral-theme-item.unlocked .referral-theme-req{color:var(--color-brand)}.session-calendar{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1rem}.calendar-date-header{font-family:var(--font-body);font-size:.875rem;color:var(--color-text);margin-bottom:.75rem;font-weight:500;text-align:left}.calendar-header{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px}.calendar-weekday{text-align:center;font-size:.625rem;color:var(--color-text-muted);font-weight:500}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-day{aspect-ratio:1;border-radius:2px;background:var(--color-surface-hover)}.calendar-day.empty{background:transparent}.calendar-day.has-session{background:var(--color-brand)}.calendar-day.today{outline:2px solid var(--color-text-muted);outline-offset:1px}.calendar-day.has-session.today{outline-color:var(--color-brand)}.empty-state{text-align:center;color:var(--color-text-muted);font-size:.875rem;padding:1.5rem}.profile__actions{margin-top:2rem;padding-bottom:2rem}.profile__new-session{width:100%;background-color:var(--color-brand);color:#fff;border:none;border-radius:var(--radius-md);padding:1rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}@media(hover:hover){.profile__new-session:hover{background-color:#5c6bc0;transform:translateY(-1px)}}.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 #0000004d;opacity:0;transition:all .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:12px;z-index:9999;box-shadow:0 8px 32px #0006;font-family:var(--font-body);font-size:.95rem;animation:slideUpFade .4s cubic-bezier(.16,1,.3,1) forwards}.pwa-update-btn{background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-full);padding:8px 16px;font-family:var(--font-body);font-size:.85rem;font-weight:500;cursor:pointer;transition:all 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, rgba(20, 20, 35, .95));-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid var(--color-border, rgba(255, 255, 255, .1));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, rgba(255, 255, 255, .7));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, 6px);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, #7c6aef);color:#fff}.consent-banner__btn--decline{background:transparent;color:var(--color-text-muted, rgba(255, 255, 255, .7));border:1px solid var(--color-border, rgba(255, 255, 255, .15))}@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:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);align-items:center;justify-content:center;opacity:0;z-index:10000;transition:opacity .5s cubic-bezier(.4,0,.2,1);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 cubic-bezier(.4,0,.2,1),opacity .5s cubic-bezier(.4,0,.2,1);box-shadow:0 16px 40px #0006}.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:-12px;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}@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:12px}.info-panel__link{display:flex;align-items:center;gap:12px;color:var(--color-text);text-decoration:none;font-size:.95rem;padding:12px 16px;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)}}.info-panel__feedback h3{font-size:1rem;font-weight:500;margin-bottom:12px;color:var(--color-text)}.info-panel__feedback form{display:flex;flex-direction:column;gap:12px}.info-panel__feedback input,.info-panel__feedback textarea{width:100%;padding:12px;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-brand);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:12px;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),html:has(.landing) body{overflow:visible!important;height:auto!important;min-height:100vh;min-height:100dvh}html:has(.landing) #app{height:auto!important;min-height:100vh;min-height:100dvh;overflow-y:visible!important}html:has(.landing) body:before{content:"";position:fixed;top:0;left:0;width:100%;height: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}html:has(.landing) #landing-logo-header{display:flex}.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__links{display:inline-flex;gap:16px;margin-top:24px}.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}}[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}}
