*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-stroke:0}body{font-family:var(--font-main);background-color:var(--bg-background);color:var(--text-main);line-height:1.6;overflow-x:hidden;min-height:100vh;transition:background-color 0.3s ease,color 0.3s ease;text-rendering:optimizeLegibility;font-feature-settings:"kern" 1}h1,h2,h3,h4,h5,h6{font-family:var(--font-main);font-weight:400;line-height:1.2;color:var(--text-main);margin-bottom:1rem;font-synthesis:none;-webkit-font-smoothing:antialiased}h1.display-hero{font-size:3rem;letter-spacing:-0.01em}@media (min-width:768px){h1.display-hero{font-size:3.5rem}}@media (min-width:1024px){h1.display-hero{font-size:56px;line-height:1.1}}h2{font-size:24px;font-weight:700}@media (min-width:768px){h2{font-size:32px}}h3{font-size:20px;font-weight:700}p{margin-bottom:1.5rem;color:var(--text-muted)}p.body-large{font-size:18px;font-weight:400}a{text-decoration:none;color:inherit;transition:var(--transition-smooth)}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 24px}@media (min-width:1024px){.container{padding:0 80px}}.text-center{text-align:center}.text-secondary{color:var(--color-primary)}.hidden{display:none}.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;border-radius:12px;font-family:var(--font-main);font-weight:700;font-size:14px;cursor:pointer;transition:var(--transition-smooth);border:none;gap:8px;letter-spacing:0.1px}.btn-primary{background-color:var(--color-primary);color:var(--color-on-primary);box-shadow:0px 4px 12px rgba(255,61,134,0.25)}.btn-primary:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0px 8px 16px rgba(255,61,134,0.35)}.btn-outline{background:transparent;border:1px solid var(--color-primary);color:var(--color-primary)}.btn-outline:hover{background-color:var(--color-primary-container)}.btn-nav{padding:10px 20px;border-radius:50px;border:1px solid var(--color-primary);color:var(--color-primary);font-size:14px;font-weight:600;height:40px}.btn-nav:hover{background-color:var(--color-primary);color:var(--color-on-primary)}.btn-icon{width:40px;height:40px;border-radius:50%;border:1px solid var(--border-color);background:transparent;color:var(--text-main);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition-smooth)}.btn-icon:hover{background:var(--bg-surface-low);color:var(--color-primary);border-color:var(--color-primary)}.bento-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:32px;position:relative;overflow:hidden;transition:var(--transition-smooth);display:flex;flex-direction:column}.bento-card:hover{box-shadow:0px 12px 32px rgba(0,0,0,0.08);transform:translateY(-2px);border-color:var(--color-primary)}.main-header{position:sticky;top:0;z-index:100;height:var(--header-height);background:var(--bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color);display:flex;align-items:center;transition:background-color 0.3s ease,border-color 0.3s ease}.header-content{display:flex;justify-content:space-between;align-items:center;width:100%}.main-nav-links{display:none;gap:32px;margin-left:40px;font-family:var(--font-ui);font-weight:500}@media (min-width:1024px){.main-nav-links{display:flex}}.nav-link{color:var(--text-main);transition:var(--transition-smooth)}.nav-link:hover{color:var(--color-primary)}.brand-logo{font-family:var(--font-main);font-weight:700;font-size:24px;color:var(--text-main);display:flex;align-items:center;gap:8px}.hero-section{padding:60px 0;min-height:85vh;display:flex;align-items:center;position:relative;overflow:hidden}.hero-bg-accent{position:absolute;top:-10%;right:-10%;width:50vw;height:50vw;background:radial-gradient(circle,var(--color-primary) 0%,rgba(0,0,0,0) 70%);opacity:0.15;z-index:-1;pointer-events:none}.hero-grid{display:grid;grid-template-columns:1fr;gap:40px;align-items:center}@media (min-width:1024px){.hero-grid{grid-template-columns:1fr 1fr;gap:80px}}.floating-mockup{animation:float 6s ease-in-out infinite}.floating-mockup-slow{animation:float 8s ease-in-out infinite}@keyframes float{0%,100%{transform:translateY(0px)}50%{transform:translateY(-20px)}}.hero-visuals{position:relative;height:500px;display:flex;align-items:center;justify-content:center;margin-top:40px}@media (min-width:768px){.hero-visuals{height:600px;margin-top:0}}@media (min-width:1024px){.hero-visuals{height:650px}}.hero-visuals .floating-mockup-slow{position:absolute;width:240px;height:auto;z-index:1;left:50%;top:0%;transform:translate(-50%,-50%)}.hero-visuals .floating-mockup{position:absolute;width:260px;height:auto;z-index:2;left:20%;top:0%;transform:translate(-70%,-50%);filter:drop-shadow(0 20px 40px rgba(0,0,0,0.15))}@media (max-width:767px){.hero-visuals{}}@media (min-width:768px) and (max-width:1023px){.hero-visuals .floating-mockup-slow{width:220px;transform:translate(-25%,-50%)}.hero-visuals .floating-mockup{width:240px;transform:translate(-75%,-50%)}}@media (min-width:1024px){.hero-visuals .floating-mockup-slow{width:280px;transform:translate(-20%,-50%)}.hero-visuals .floating-mockup{width:300px;transform:translate(-80%,-50%)}}.bento-grid-v2{display:grid;grid-template-columns:1fr;gap:24px}@media (min-width:1024px){.bento-grid-v2{grid-template-columns:repeat(3,1fr);grid-template-rows:auto auto;gap:24px;grid-template-areas:"chat pulse pulse" "rituals rituals third-slot"}.area-chat{grid-area:chat}.area-pulse{grid-area:pulse}.area-dash{grid-area:rituals}.area-third-slot{grid-area:third-slot;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-xl);display:flex;flex-direction:column;position:relative;z-index:1}}.checkin-subtitle{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:12px;margin-top:24px;display:block;text-align:left;width:100%;padding-left:8px}.pill-badge{display:inline-flex;align-self:flex-start;font-family:var(--font-ui);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:0.5px;color:var(--color-primary);background:var(--color-primary-container);padding:6px 12px;border-radius:var(--radius-full);margin-bottom:24px;box-shadow:0px 0px 6px rgba(255,61,134,0.15);border:1px solid rgba(255,61,134,0.08)}.emoji-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px;width:100%;max-width:480px;margin-left:auto;margin-right:auto;padding:0 8px}.emoji-btn{width:100%;height:96px;aspect-ratio:1;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:16px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:default;transition:all 0.2s ease;text-align:center}.emoji-btn span{font-size:30px;line-height:1;margin-bottom:4px}.emoji-btn div{font-size:12px;font-weight:600;color:var(--text-muted)}.emoji-btn.selected{background:#E8F5E9;border:2px solid #4CAF50;box-shadow:0 4px 12px rgba(76,175,80,0.3);transform:none}.emoji-btn.selected span,.emoji-btn.selected div{color:#388E3C;font-weight:700}.tags-cloud{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;width:100%;max-width:480px;margin-left:auto;margin-right:auto;margin-top:32px;padding:0 8px}.tag-chip{padding:8px 16px;border-radius:50px;background:var(--bg-surface-low);color:var(--text-muted);font-size:14px;font-weight:500;border:1px solid var(--border-color);transition:all 0.2s ease;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;min-height:36px}.tag-chip.active{background:#FFFFFF;color:#151515;border-color:#FFFFFF;box-shadow:0 2px 8px rgba(0,0,0,0.1)}[data-theme="dark"] .tag-chip.active{background:#FFFFFF;color:#000000}.chat-container{gap:8px;margin-top:24px;padding-bottom:8px;display:flex;flex-direction:column}.chat-bubble{max-width:85%;padding:12px 16px;font-size:14px;position:relative;box-shadow:0 4px 12px rgba(0,0,0,0.05);line-height:1.4}.chat-left{align-self:flex-start;background:var(--gradient-chat-pink);border-radius:16px 16px 16px 0;color:white;font-weight:500}.chat-right{align-self:flex-end;background:var(--gradient-chat-emerald);border-radius:16px 16px 0 16px;color:white;font-weight:500}.bento-wide-content{display:flex;flex-direction:column;height:100%}@media (min-width:768px){.bento-wide-content{flex-direction:row;align-items:center;gap:40px}.bento-text-side{flex:1;padding-right:20px}.bento-visual-side{flex:1;height:100%;position:relative;overflow:hidden;mask-image:linear-gradient(to bottom,transparent,black 10%,black 90%,transparent);-webkit-mask-image:linear-gradient(to bottom,transparent,black 10%,black 90%,transparent)}}.scroll-container{height:280px;overflow:hidden;position:relative}.scroll-content{display:flex;flex-direction:column;gap:16px;animation:scroll-vertical 15s linear infinite}.scroll-content:hover{animation-play-state:paused}@keyframes scroll-vertical{0%{transform:translateY(0)}100%{transform:translateY(-50%)}}.ritual-card{background:white;border-radius:16px;padding:16px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 8px rgba(0,0,0,0.05);border:1px solid rgba(0,0,0,0.05);min-height:72px}.ritual-orange{background:var(--color-ritual-orange)}.ritual-purple{background:var(--color-ritual-purple)}.ritual-blue{background:var(--color-ritual-blue)}.ritual-green{background:var(--color-ritual-green)}.ritual-pink{background:var(--color-ritual-pink)}.ritual-grey{background:var(--color-ritual-grey)}.ritual-info{display:flex;align-items:center;gap:12px}.ritual-icon{width:40px;height:40px;background:rgba(255,255,255,0.6);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px}.ritual-tag{background:white;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:700;box-shadow:0 2px 4px rgba(0,0,0,0.05)}.stat-bar{width:12%;background:var(--color-primary-container);border-radius:4px 4px 0 0;transition:height 1s ease-out;position:relative;z-index:1}.stat-bar.active{background:var(--color-primary);box-shadow:0 0 12px rgba(255,61,134,0.3)}.stat-bar:hover{background:var(--color-primary);opacity:0.8}.main-footer{background-color:var(--bg-surface);color:var(--text-main);padding-top:80px;padding-bottom:40px;border-top:1px solid var(--border-color);transition:background-color 0.3s ease,color 0.3s ease}@media (max-width:767px){.main-footer{padding-top:48px;padding-bottom:32px}}.footer-grid{display:grid;grid-template-columns:1fr;gap:48px}@media (max-width:767px){.footer-grid{grid-template-columns:repeat(3,1fr);gap:32px 12px}.footer-col.col-brand{grid-column:1 / -1;margin-bottom:16px}}@media (max-width:480px){.footer-grid{gap:32px 8px}}@media (min-width:768px){.footer-grid{grid-template-columns:repeat(4,1fr)}}@media (min-width:1024px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr}}.footer-heading{font-family:var(--font-ui);color:var(--text-main);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:24px;opacity:0.9}@media (max-width:767px){.footer-heading{font-size:10px;margin-bottom:16px;letter-spacing:0.5px}}.footer-links{list-style:none;padding:0;margin:0}.footer-links li{margin-bottom:16px}@media (max-width:767px){.footer-links li{margin-bottom:12px}}.footer-links a{color:var(--text-muted);font-size:14px;text-decoration:none;transition:color 0.2s ease}@media (max-width:767px){.footer-links a{font-size:12px;line-height:1.4}}.footer-links a:hover{color:var(--color-primary)}.footer-mission{color:var(--text-muted);font-size:14px;line-height:1.6;margin-bottom:32px;max-width:320px}@media (max-width:767px){.footer-mission{font-size:14px;margin-bottom:24px;text-align:left}}.footer-logo span{color:var(--color-primary) !important}.store-badges{display:flex;gap:12px;flex-wrap:wrap}@media (max-width:767px){.store-badges{flex-direction:column;gap:8px}}.store-badge{background:transparent;border:1px solid var(--border-color);color:var(--text-main);border-radius:8px;padding:8px 12px;display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all 0.2s}@media (max-width:767px){.store-badge{padding:10px 14px;font-size:14px;justify-content:center}}.store-badge:hover{background:var(--bg-surface-low);border-color:var(--color-primary)}.hiring-badge{background:var(--color-primary);color:white;font-size:9px;padding:2px 6px;border-radius:4px;margin-left:6px;font-weight:700;vertical-align:middle}.footer-bottom{margin-top:64px;padding-top:32px;border-top:1px solid var(--border-color);display:flex;flex-direction:column;align-items:center;gap:24px}@media (max-width:767px){.footer-bottom{margin-top:40px;padding-top:24px;gap:20px;text-align:center}}@media (min-width:768px){.footer-bottom{flex-direction:row;justify-content:space-between}}.copyright{color:var(--text-muted);font-size:14px}@media (max-width:767px){.copyright{font-size:13px;line-height:1.6}}.social-links{display:flex;gap:16px}@media (max-width:767px){.social-links{gap:12px}}.social-icon{width:40px;height:40px;background:transparent;border:1px solid var(--border-color);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all 0.2s}.social-icon:hover{background:var(--color-primary);color:white;border-color:var(--color-primary)}@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-split-screen{display:grid;min-height:100vh;grid-template-columns:1fr;position:relative;z-index:1}@media (min-width:1024px){.auth-split-screen{grid-template-columns:1fr 1fr}}.auth-art-side{background-color:var(--bg-surface-low);position:relative;display:none;overflow:hidden}@media (min-width:1024px){.auth-art-side{display:flex}}.auth-form-side{display:flex;align-items:center;justify-content:center;padding:24px;background-color:var(--bg-background);min-height:100vh}.auth-container{width:100%;max-width:420px;padding:20px;background:transparent}.form-group{margin-bottom:24px;text-align:left}.form-label{display:block;margin-bottom:8px;font-size:14px;font-weight:700;color:var(--text-main);font-family:var(--font-main)}.form-input{width:100%;height:56px;padding:0 16px;border-radius:12px;border:1px solid var(--border-color);background:var(--bg-surface);font-family:var(--font-main);font-size:16px;color:var(--text-main);transition:all 0.2s ease}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px rgba(255,61,134,0.1);background:var(--bg-background)}.form-input::placeholder{color:var(--text-muted);opacity:0.7}a{transition:color 0.2s ease}a:hover{color:var(--color-primary)}.legal-page-wrapper{padding:60px 24px 100px;max-width:900px;margin:0 auto}@media (min-width:768px){.legal-page-wrapper{padding:60px 40px 100px}}@media (min-width:1024px){.legal-page-wrapper{padding:60px 0 100px}}.legal-header{text-align:center;margin-bottom:60px;padding-bottom:40px;border-bottom:1px solid var(--border-color)}.legal-header h1{font-size:32px;margin-bottom:16px;color:var(--text-main)}@media (min-width:768px){.legal-header h1{font-size:42px}}.legal-meta{display:flex;gap:24px;justify-content:center;flex-wrap:wrap;margin-top:24px;font-size:14px;color:var(--text-muted)}.legal-meta-item{display:flex;align-items:center;gap:6px}.legal-toc{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:32px;margin-bottom:60px}.legal-toc h2{font-size:20px;margin-bottom:24px;color:var(--text-main)}.legal-toc-list{list-style:none;padding:0;margin:0}.legal-toc-list li{margin-bottom:12px}.legal-toc-list a{color:var(--text-muted);font-size:15px;font-weight:500;display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;transition:var(--transition-smooth)}.legal-toc-list a:hover{background:var(--bg-surface-low);color:var(--color-primary)}.legal-section{margin-bottom:60px}.legal-section h2{font-size:28px;margin-bottom:24px;color:var(--text-main);padding-bottom:16px;border-bottom:2px solid var(--color-primary);display:inline-block}.legal-section h3{font-size:20px;margin-top:32px;margin-bottom:16px;color:var(--text-main)}.legal-section p{font-size:16px;line-height:1.8;color:var(--text-main);margin-bottom:16px}.legal-article{margin-bottom:40px;padding:24px;background:var(--bg-surface);border-left:3px solid var(--color-primary);border-radius:0 var(--radius-md) var(--radius-md) 0}.legal-article-number{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:0.5px;color:var(--color-primary);margin-bottom:8px;display:block}.legal-article h3{margin-top:0;font-size:18px}.legal-accordion{margin-bottom:16px;border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;background:var(--bg-surface);transition:var(--transition-smooth)}.legal-accordion:hover{border-color:var(--color-primary)}.legal-accordion-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;cursor:pointer;user-select:none;transition:var(--transition-smooth)}.legal-accordion-header:hover{background:var(--bg-surface-low)}.legal-accordion-title{font-size:16px;font-weight:700;color:var(--text-main);margin:0}.legal-accordion-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:var(--color-primary);transition:transform 0.3s ease}.legal-accordion.active .legal-accordion-icon{transform:rotate(180deg)}.legal-accordion-content{max-height:0;overflow:hidden;transition:max-height 0.3s ease}.legal-accordion.active .legal-accordion-content{max-height:2000px}.legal-accordion-body{padding:0 24px 24px 24px}.legal-accordion-body p{font-size:15px;line-height:1.7;color:var(--text-muted)}.legal-highlight{background:var(--color-primary-container);border-left:4px solid var(--color-primary);border-radius:var(--radius-md);padding:20px 24px;margin:32px 0}.legal-highlight-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:700;color:var(--color-primary);margin-bottom:12px}.legal-highlight p{color:var(--text-main);margin-bottom:8px}.legal-highlight p:last-child{margin-bottom:0}.legal-list{list-style:none;padding:0;margin:24px 0}.legal-list li{position:relative;padding-left:32px;margin-bottom:12px;color:var(--text-main);line-height:1.7}.legal-list li::before{content:"•";position:absolute;left:12px;color:var(--color-primary);font-weight:700;font-size:18px}.legal-list-ordered{counter-reset:legal-counter;list-style:none;padding:0;margin:24px 0}.legal-list-ordered li{position:relative;padding-left:40px;margin-bottom:16px;color:var(--text-main);line-height:1.7;counter-increment:legal-counter}.legal-list-ordered li::before{content:counter(legal-counter) ".";position:absolute;left:0;color:var(--color-primary);font-weight:700;font-size:16px}.legal-table{width:100%;border-collapse:collapse;margin:32px 0;background:var(--bg-surface);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-color)}.legal-table thead{background:var(--bg-surface-low)}.legal-table th{padding:16px 20px;text-align:left;font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;color:var(--text-main);border-bottom:2px solid var(--border-color)}.legal-table td{padding:16px 20px;border-bottom:1px solid var(--border-color);color:var(--text-main);font-size:15px}.legal-table tr:last-child td{border-bottom:none}.legal-section a{color:var(--color-primary);text-decoration:underline;font-weight:600}.legal-section a:hover{text-decoration:none}.legal-update-notice{background:var(--bg-surface-low);border-radius:var(--radius-md);padding:16px 20px;text-align:center;font-size:14px;color:var(--text-muted);margin-top:60px}.legal-back-button{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:var(--radius-md);background:var(--bg-surface);border:1px solid var(--border-color);color:var(--text-main);font-weight:600;font-size:14px;transition:var(--transition-smooth);margin-bottom:40px}.legal-back-button:hover{background:var(--color-primary);color:white;border-color:var(--color-primary);transform:translateX(-4px)}@media (max-width:767px){.legal-page-wrapper{padding:40px 24px 60px}.legal-toc{padding:20px 16px}.legal-article{padding:16px}.legal-accordion-header{padding:16px 18px}.legal-table{font-size:13px}.legal-table th,.legal-table td{padding:12px 14px}}.mobile-menu-btn{display:flex;flex-direction:column;justify-content:center;align-items:center;width:40px;height:40px;background:transparent;border:1px solid var(--border-color);border-radius:8px;cursor:pointer;gap:5px;transition:var(--transition-smooth);padding:0}.mobile-menu-btn:hover{background:var(--bg-surface-low);border-color:var(--color-primary)}.hamburger-line{width:20px;height:2px;background:var(--text-main);border-radius:2px;transition:all 0.3s ease}.mobile-menu-btn.active .hamburger-line:nth-child(1){transform:translateY(7px) rotate(45deg)}.mobile-menu-btn.active .hamburger-line:nth-child(2){opacity:0}.mobile-menu-btn.active .hamburger-line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}@media (min-width:1024px){.mobile-menu-btn{display:none}}.mobile-menu{position:fixed;top:0;left:0;width:100%;height:100vh;background:rgba(0,0,0,0.5);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:200;opacity:0;visibility:hidden;transition:opacity 0.3s ease,visibility 0.3s ease}.mobile-menu.active{opacity:1;visibility:visible}.mobile-menu-content{position:absolute;top:0;right:0;width:85%;max-width:400px;height:100vh;background:var(--bg-background);box-shadow:-4px 0 24px rgba(0,0,0,0.15);transform:translateX(100%);transition:transform 0.3s cubic-bezier(0.4,0,0.2,1);display:flex;flex-direction:column;overflow-y:auto}.mobile-menu.active .mobile-menu-content{transform:translateX(0)}.mobile-nav{padding:80px 24px 24px 24px;flex:1;display:flex;flex-direction:column;gap:8px}.mobile-nav-link{display:flex;align-items:center;gap:16px;padding:16px 20px;border-radius:var(--radius-md);background:var(--bg-surface);border:1px solid var(--border-color);color:var(--text-main);font-size:16px;font-weight:600;transition:var(--transition-smooth)}.mobile-nav-link:hover{background:var(--color-primary-container);border-color:var(--color-primary);color:var(--color-primary)}.mobile-nav-link i{font-size:24px;color:var(--color-primary)}.mobile-menu-footer{padding:24px;border-top:1px solid var(--border-color);background:var(--bg-surface)}@media (min-width:1024px){.mobile-menu{display:none}}.header-actions{display:flex;align-items:center;gap:12px}@media (max-width:1023px){.header-actions .btn-nav{display:none}}.header-logo{height:32px;width:auto}@media (min-width:768px){.header-logo{height:36px}}