@charset "UTF-8";*,*: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}:root{color-scheme:light dark;--color-brand: #7986cb;--color-brand-glow: rgba(121, 134, 203, .4);--color-pure-white: #E3DFDF;--color-pure-black: #1F1E1F;--font-display: "Cormorant Garamond", 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-theme=dark]{--color-bg: #0a0a1a;--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, .6);--color-text-faint: rgba(227, 223, 223, .3);--color-accent: var(--color-brand);--color-accent-glow: var(--color-brand-glow);--gradient-start: #080614;--gradient-mid: #0d0a2a;--gradient-end: #15102e}[data-theme=light]{--color-bg: #f5f5f7;--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, .6);--color-text-faint: rgba(31, 30, 31, .3);--color-accent: var(--color-brand);--color-accent-glow: var(--color-brand-glow);--gradient-start: #e0e0e0;--gradient-mid: #f0f0f0;--gradient-end: #ffffff}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);background-image:linear-gradient(to bottom,var(--gradient-end),var(--gradient-mid),var(--gradient-start));-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;animation:fadeIn .75s ease-in-out forwards}#bg-canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;opacity:0;background:var(--color-bg);transition:opacity 2s 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}.admin-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;animation:modalFadeIn .3s ease-out forwards}.admin-modal-content{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:2.5rem;width:90%;max-width:400px;position:relative;box-shadow:0 20px 40px #00000080;transform:translateY(20px);animation:modalSlideUp .4s cubic-bezier(.16,1,.3,1) forwards}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.admin-modal-close{position:absolute;top:1.5rem;right:1.5rem;background:none;border:none;color:var(--color-text-dim);font-size:1.25rem;cursor:pointer;transition:color .2s;padding:.5rem}.admin-modal-close:hover{color:var(--color-text)}.admin-modal-title{color:var(--color-text);font-family:Cormorant Garamond,serif;font-size:1.75rem;margin-bottom:2rem;text-align:center;font-weight:500}.admin-form .form-group{margin-bottom:1.5rem}.admin-form label{display:block;color:var(--color-text-dim);font-size:.875rem;margin-bottom:.5rem;letter-spacing:.05em;text-transform:uppercase}.admin-form input{width:100%;background:#ffffff08;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.875rem 1rem;color:var(--color-text);font-family:inherit;font-size:1rem;transition:all .2s}.admin-form input:focus{outline:none;border-color:var(--color-brand);background:#ffffff0f}.admin-error{color:#ff6b6b;font-size:.875rem;background:#ff6b6b1a;border:1px solid rgba(255,107,107,.2);padding:.75rem;border-radius:var(--radius-md);margin-bottom:1.5rem;text-align:center}.admin-submit-btn{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;letter-spacing:.05em}.admin-submit-btn:hover:not(:disabled){background-color:#5c6bc0;transform:translateY(-1px)}.admin-submit-btn:disabled{opacity:.7;cursor:not-allowed}.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;box-shadow:0 10px 30px #00000080;z-index:9999;font-family:Inter,sans-serif;display:none}.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-dim);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}.debug-btn:hover{background:var(--color-brand);color:#fff;border-color:var(--color-brand)}.debug-btn.active{background:var(--color-brand);color:#fff;border-color:var(--color-brand);opacity:1}.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)}.debug-btn-danger{background:#ff6b6b1a;color:#ff6b6b;border-color:#ff6b6b4d}.debug-btn-danger:hover{background:#ff6b6b;color:#fff;border-color:#ff6b6b}.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}.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}.debug-toggle-btn{position:fixed;bottom:1.5rem;right:1.5rem;width:40px;height:40px;border-radius:50%;background:var(--color-surface);border:1px solid var(--color-surface-border);color:var(--color-brand);font-size:1rem;cursor:pointer;z-index:9998;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 4px 12px #0000004d;transition:all var(--transition-fast)}.debug-toggle-btn:hover{color:#fff;background:var(--color-brand);border-color:var(--color-brand)}@media(max-width:640px){.debug-panel{padding:.75rem;width:200px;bottom:1rem;left:1rem}.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{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}.debug-toggle-btn{width:36px;height:36px;font-size:.85rem;bottom:1rem;right:1rem}}#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}.landing{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:32px;max-width:640px;width:100%;padding:24px;padding-bottom:calc(80px + env(safe-area-inset-bottom,0px))}.landing__logo,.landing__greeting,.landing__subtitle,.landing__card,#btn-begin{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__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 12px;z-index:2;pointer-events:none}.landing__logo{width:clamp(160px,28vw,240px);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(24px);-webkit-backdrop-filter:blur(24px);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:20px;width:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:opacity var(--transition-fast);opacity:.6;z-index:2;font-size:.85rem}.landing__reload-btn:hover{opacity:1}.landing__reload-btn.rotating i{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)}}.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 i{font-size:14px;opacity:.7}.landing__meta-separator{color:var(--color-text-muted);opacity:.4;margin:0 2px;font-size:.85rem}.landing__card-meta svg{width:14px;height:14px;opacity:.7}.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:all var(--transition-fast);box-shadow:0 4px 24px var(--color-accent-glow);width:100%;max-width:320px}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 32px var(--color-accent-glow);filter:brightness(1.1)}.btn-primary:active{transform:scale(.97)}.session{display:flex;flex-direction:column;align-items:center;text-align:center;width:100%;height:100%;padding:24px;padding-bottom:calc(80px + env(safe-area-inset-bottom,0px));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:absolute;left:0;right:0;height: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)}.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 i,.session__audio-btn i{pointer-events:none}.session__settings-btn:hover,.session__settings-btn:active,.session__audio-btn:hover,.session__audio-btn:active{color:var(--color-text);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;min-height:3em;font-weight:400;margin:0 auto;opacity:1;transition:opacity .75s ease,transform .75s ease;will-change:opacity,transform;transform:translateY(0)}.session__instruction.hidden-initial{opacity:0;transition:opacity .8s ease}.session__instruction.fading{opacity:0;transform:translateY(-8px);transition:opacity .75s ease,transform .75s ease}.session__instruction.fading-in{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}.session__dot{width:7px;height:7px;border-radius:50%;background:var(--color-text);opacity:.8;transition:all .5s ease;border:none;outline:none;box-shadow:none}.session__dot.shrinking{transform:scale(calc(1 - var(--shrink-progress, 0) * .7));opacity:calc(1 - var(--shrink-progress, 0) * .6)}.session__dot.shrunk{transform:scale(.3);opacity:.4}.session__footer{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:16px;padding-bottom:24px;opacity:0;animation:fadeInUp .6s ease forwards;animation-delay:.5s;position:relative;z-index:1;width:100%}.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 20px;font-size:.95rem;min-height:44px;margin:0;position:relative;z-index:2}.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}#app:has(.complete):before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-bg);z-index:0;animation:fadeIn .6s ease forwards}.complete{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:28px;max-width:640px;width:calc(100% - 48px);max-height:100%;margin:24px;margin-bottom:calc(80px + env(safe-area-inset-bottom,0px));animation:fadeIn .8s ease forwards;z-index:1;background:var(--color-surface);border-radius:var(--radius-md);padding:32px 24px;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);box-shadow:0 8px 32px #0000001a}.complete__icon{font-size:3rem;animation:pulse 2s ease-in-out infinite;opacity:0;animation:fadeInUp .6s ease forwards 0ms,pulse 2s ease-in-out infinite .6s}.complete__title{font-family:var(--font-display);font-size:2.2rem;font-weight:500;line-height:1.2;opacity:0;animation:fadeInUp .6s ease forwards .15s}.complete__subtitle{font-size:.95rem;color:var(--color-text-muted);line-height:1.6;margin-top:-12px;font-weight:400;opacity:0;animation:fadeInUp .6s ease forwards .3s}.complete__subtitle strong{color:var(--color-text);font-weight:600}.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__actions{display:flex;flex-direction:column;gap:12px;width:100%;max-width:320px;opacity:0;animation:fadeInUp .6s ease forwards .6s}.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:all var(--transition-fast);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.btn-secondary:hover{background:var(--color-accent);color:var(--color-cta-text, #fff);border-color:var(--color-accent);transform:translateY(-1px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.85}}@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{width:9px;height:9px}.session__progress-dots{gap:16px}.complete__title{font-size:2.6rem}}@media(min-width:900px){.landing__greeting{font-size:4rem}.session__instruction{font-size:2rem;max-width:560px}}@media(max-height:750px){.complete{gap:16px;overflow-y:auto;justify-content:flex-start;padding:16px 0}.complete__icon{font-size:2rem}.complete__title{font-size:1.6rem}.complete__subtitle{font-size:.85rem;margin-top:-8px}.complete__video-preview{max-height:30vh}.complete__video-preview video{max-height:30vh;object-fit:cover}.complete__actions{gap:8px}.btn-primary,.btn-secondary{padding:12px 24px;font-size:.85rem}}@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(100px,20vw,160px)}.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}}.app-footer{position:absolute;bottom:0;width:100%;padding:16px 20px;text-align:center;z-index:10}.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}.footer-info-btn:hover{opacity:1;color:var(--color-text)}select.footer-info-btn{text-align:center;text-align-last:center;appearance:none;-webkit-appearance:none;-moz-appearance:none;background:transparent;outline:none}.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.1rem;width:40px;height:40px;cursor:pointer;align-items:center;justify-content:center;transition:all var(--transition-fast);line-height:1;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.footer-nav-toggle:hover{opacity:1;color:var(--color-text)}@media(max-width:640px){.footer-nav-toggle{display:flex;width:100%;height:36px;border-radius:var(--radius-full);font-size:.85rem;gap:.4rem}.footer-links{display:none;flex-direction:column;align-items:center;gap:0;width:100%;overflow:hidden;max-height:0;transition:max-height .35s ease,opacity .3s ease;opacity:0}.footer-links.open{display:flex;max-height:min(320px,50vh);overflow-y:auto;opacity:1;width:100%;background:var(--color-surface);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--color-surface-border);border-radius:var(--radius-md);padding:8px 16px;margin-bottom:6px}.footer-links .footer-divider{display:none}.footer-links .footer-info-btn,.footer-links .user-menu-container{display:flex;align-items:center;justify-content:center;width:100%;min-height:44px;padding:10px 0;font-size:.85rem}}@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:none;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;transition:max-height .35s ease,opacity .3s ease;opacity:0}.footer-links.open{display:flex;max-height:min(280px,70vh);overflow-y:auto;opacity:1;background:var(--color-surface);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--color-surface-border);border-radius:var(--radius-md);padding:8px 24px}.footer-links .footer-divider{display:none}.footer-links .footer-info-btn,.footer-links .user-menu-container{display:flex;align-items:center;justify-content:flex-start;width:100%;min-height:36px;padding:6px 0;font-size:.8rem}}.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;animation:modalFadeIn .3s ease-out forwards}.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;animation:modalSlideUp .4s cubic-bezier(.16,1,.3,1) forwards}.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}.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}.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:#ffffff0d;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family:inherit;font-size:.9375rem;cursor:pointer;transition:all .2s}.auth-google-btn:hover{background:#ffffff1a;border-color:var(--color-text-muted)}.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:#ffffff08;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:#ffffff0f}.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:all .2s ease}.auth-submit-btn:hover:not(:disabled){background-color:#5c6bc0;transform:translateY(-1px)}.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}.auth-interest{margin-top:1.5rem}.auth-interest__divider{height:1px;background:var(--color-border);margin-bottom:1.25rem}.auth-interest__title{color:var(--color-text);font-size:.9375rem;font-weight:500;margin-bottom:.25rem}.auth-interest__desc{color:var(--color-text-muted);font-size:.8125rem;margin-bottom:.75rem;line-height:1.4}.auth-interest__form{display:flex;gap:.5rem}.auth-interest__form input{flex:1;background:#ffffff08;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.625rem .75rem;color:var(--color-text);font-family:inherit;font-size:.875rem;transition:all .2s}.auth-interest__form input:focus{outline:none;border-color:var(--color-brand);background:#ffffff0f}.auth-interest__btn{background-color:var(--color-brand);color:#fff;border:none;border-radius:var(--radius-md);padding:.625rem 1rem;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.auth-interest__btn:hover:not(:disabled){background-color:#5c6bc0}.auth-interest__btn:disabled{opacity:.7;cursor:not-allowed}.auth-interest__msg{font-size:.8125rem;padding:.625rem .75rem;border-radius:var(--radius-sm);margin-top:.5rem;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}.user-menu{position:relative;display:inline-flex}.user-menu__trigger{background:none;border:none;cursor:pointer;padding:0}.user-menu__avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;border:2px solid var(--color-border);transition:border-color .2s}.user-menu__avatar--initials{display:flex;align-items:center;justify-content:center;background:var(--color-brand);color:#fff;font-size:.75rem;font-weight:600}.user-menu__trigger:hover .user-menu__avatar{border-color:var(--color-brand)}.user-menu__dropdown{position:absolute;bottom:100%;right:0;margin-bottom:.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:180px;box-shadow:0 10px 30px #0000004d;opacity:0;visibility:hidden;transform:translateY(10px);transition:all .2s ease;z-index:100}.user-menu__dropdown.open{opacity:1;visibility:visible;transform:translateY(0)}.user-menu__header{padding:.75rem 1rem;border-bottom:1px solid var(--color-border)}.user-menu__name{display:block;color:var(--color-text);font-weight:500;font-size:.875rem}.user-menu__email{display:block;color:var(--color-text-muted);font-size:.75rem;margin-top:.125rem;overflow:hidden;text-overflow:ellipsis}.user-menu__divider{height:1px;background:var(--color-border)}.user-menu__item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.625rem 1rem;background:none;border:none;color:var(--color-text);font-family:inherit;font-size:.875rem;text-align:left;cursor:pointer;transition:background .2s}.user-menu__item:hover{background:var(--color-surface-hover)}.user-menu__item--danger{color:#ff6b6b}.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}.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}.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 i{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}.library-grid-item:hover{background:var(--color-surface-hover);border-color:var(--color-brand);transform:translateY(-2px)}.library-grid-item.locked{opacity:.5}.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}.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}.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}.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(24px);-webkit-backdrop-filter:blur(24px);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)}.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%)}}.info-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.info-overlay.open{opacity:1;visibility:visible}.info-panel{background:var(--color-surface);border:1px solid var(--color-surface-border);border-radius:var(--radius-lg);padding:24px 32px;width:100%;max-width:400px;transform:translateY(20px);transition:transform .3s ease;box-shadow:0 16px 40px #0006}.info-overlay.open .info-panel{transform:translateY(0)}.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)}.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:#ffffff0d;border:1px solid var(--color-surface-border);transition:background var(--transition-fast),transform var(--transition-fast)}.info-panel__link i{color:var(--color-accent);font-size:1.1rem}.info-panel__link:hover{background:#ffffff1a;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:#0003;color:var(--color-text);font-family:var(--font-body);font-size:.9rem;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 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}.info-panel__privacy{margin-top:8px;padding-top:16px;border-top:1px solid var(--color-surface-border);text-align:center}.privacy-notice{font-size:.8rem;color:var(--color-text-faint);line-height:1.4;margin-bottom:8px}.btn-link{background:transparent;border:none;color:var(--color-text-muted);font-size:.8rem;cursor:pointer;text-decoration:underline;padding:4px 8px;transition:color var(--transition-fast)}.btn-link:hover{color:var(--color-text)}
