:root{--bb-blue: #2F80ED;--bb-blue-deep: #1B5DC0;--bb-blue-light: #E3EFFD;--bb-blue-glow: #5B9DF5;--bb-yellow: #F2C94C;--bb-yellow-light: #FDF6E0;--bb-yellow-deep: #D4A82E;--bb-charcoal: #1F2937;--bb-green: #6FCF97;--bb-green-light: #E8F8EF;--bb-purple: #9B51E0;--bb-purple-light: #F0E5FA;--bb-coral: #F2994A;--bb-coral-light: #FDF0E3;--bb-red: #EB5757;--bb-red-light: #FDECEC;--bb-white: #FFFFFF;--bb-snow: #FAFBFC;--bb-light: #F3F5F7;--bb-mist: #E5E9EF;--bb-gray: #6B7B8D;--bb-gray-dark: #3D4F5F;--bb-radius: 20px;--bb-radius-sm: 12px;--bb-radius-xs: 8px;--bb-shadow-sm: 0 2px 12px rgba(31,41,55,.06);--bb-shadow: 0 4px 24px rgba(31,41,55,.08);--bb-shadow-lg: 0 12px 48px rgba(31,41,55,.12);--bb-shadow-xl: 0 24px 64px rgba(31,41,55,.16);--bb-transition: .3s cubic-bezier(.34, 1.56, .64, 1)}.bb-landing *{margin:0;padding:0;box-sizing:border-box}.bb-landing{font-family:Nunito,sans-serif;color:var(--bb-charcoal);background:var(--bb-white);overflow-x:hidden;line-height:1.65;-webkit-font-smoothing:antialiased}.bb-landing h1,.bb-landing h2,.bb-landing h3,.bb-landing h4{font-family:Fredoka,sans-serif;line-height:1.2}.bb-container{max-width:1180px;margin:0 auto;padding:0 24px}.bb-btn{display:inline-flex;align-items:center;gap:8px;padding:15px 34px;border-radius:60px;font-family:Fredoka,sans-serif;font-size:1.05rem;font-weight:600;text-decoration:none;border:none;cursor:pointer;transition:all var(--bb-transition);position:relative}.bb-btn:hover{transform:translateY(-2px) scale(1.02)}.bb-btn:active{transform:translateY(0) scale(.98)}.bb-btn-blue{background:var(--bb-blue);color:var(--bb-white);box-shadow:0 4px 20px #2f80ed59}.bb-btn-blue:hover{box-shadow:0 8px 32px #2f80ed73;background:var(--bb-blue-deep)}.bb-btn-yellow{background:var(--bb-yellow);color:var(--bb-charcoal);box-shadow:0 4px 20px #f2c94c66}.bb-btn-yellow:hover{box-shadow:0 8px 32px #f2c94c80}.bb-btn-outline{background:transparent;color:var(--bb-blue);border:2.5px solid var(--bb-blue)}.bb-btn-outline:hover{background:var(--bb-blue);color:var(--bb-white)}.bb-nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:#fff;backdrop-filter:none;-webkit-backdrop-filter:none;border-bottom:1px solid rgba(31,41,55,.06);transition:box-shadow .3s}.bb-nav.scrolled{box-shadow:0 2px 20px #1f293714}.bb-nav .bb-container{display:flex;align-items:center;justify-content:space-between;height:90px}.bb-nav-logo{display:flex;align-items:center;text-decoration:none;height:90px;overflow:hidden}.bb-nav-logo-img{height:120px;width:auto;-o-object-fit:contain;object-fit:contain;display:block}.bb-nav-links{display:flex;align-items:center;gap:28px;list-style:none}.bb-nav-links a{text-decoration:none;color:var(--bb-gray);font-weight:700;font-size:.9rem;transition:color .2s;letter-spacing:.01em}.bb-nav-links a:hover{color:var(--bb-blue)}.bb-nav-cta{display:flex;gap:10px;align-items:center}.bb-nav-cta .bb-btn{padding:10px 22px;font-size:.9rem}.bb-mobile-menu{display:none;background:none;border:none;cursor:pointer;padding:8px}.bb-mobile-menu svg{width:24px;height:24px;stroke:var(--bb-charcoal)}.bb-hero{padding:170px 0 110px;position:relative;background:linear-gradient(175deg,#edf4fe,#fefcf3 45%,#f0faf4);overflow:hidden}.bb-hero-orb{position:absolute;border-radius:50%;pointer-events:none}.bb-hero-orb-1{width:500px;height:500px;top:-180px;right:-120px;background:radial-gradient(circle,rgba(47,128,237,.08) 0%,transparent 70%)}.bb-hero-orb-2{width:400px;height:400px;bottom:-120px;left:-100px;background:radial-gradient(circle,rgba(242,201,76,.1) 0%,transparent 70%)}.bb-hero-orb-3{width:200px;height:200px;top:40%;left:45%;background:radial-gradient(circle,rgba(111,207,151,.06) 0%,transparent 70%)}.bb-hero .bb-container{position:relative;z-index:2}.bb-hero-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center}.bb-hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--bb-white);border:1.5px solid var(--bb-mist);border-radius:40px;padding:7px 18px 7px 8px;margin-bottom:20px;font-size:.82rem;font-weight:700;color:var(--bb-gray-dark);box-shadow:var(--bb-shadow-sm)}.bb-hero-badge-dot{width:8px;height:8px;border-radius:50%;background:var(--bb-green);animation:bb-pulse 2s ease-in-out infinite}@keyframes bb-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.5)}}.bb-hero-content h1{font-family:Nunito,sans-serif;font-size:3.5rem;font-weight:800;letter-spacing:-.025em;color:var(--bb-charcoal);line-height:1.12}.bb-hero-content h1 .highlight{background:linear-gradient(135deg,var(--bb-blue) 0%,var(--bb-blue-glow) 50%,var(--bb-yellow) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.bb-hero-content p{font-size:1.18rem;color:var(--bb-gray);margin:22px 0 34px;max-width:480px;line-height:1.75}.bb-hero-buttons{display:flex;gap:14px;flex-wrap:wrap;align-items:center}.bb-hero-subtext{font-size:.82rem;color:var(--bb-gray);margin-top:14px}.bb-hero-trust{display:flex;align-items:center;gap:20px;margin-top:36px;flex-wrap:wrap}.bb-trust-badge{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--bb-white);border-radius:10px;box-shadow:var(--bb-shadow-sm);font-size:.82rem;font-weight:700;color:var(--bb-gray-dark)}.bb-trust-badge svg{width:18px;height:18px;flex-shrink:0}.bb-hero-visual{position:relative;display:flex;justify-content:center}.bb-hero-card{background:var(--bb-white);border-radius:24px;padding:28px;box-shadow:var(--bb-shadow-xl);width:100%;max-width:440px;animation:bb-cardFloat 7s ease-in-out infinite}@keyframes bb-cardFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.bb-hc-header{display:flex;align-items:center;gap:12px;margin-bottom:18px}.bb-hc-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--bb-blue-light),var(--bb-yellow-light));display:flex;align-items:center;justify-content:center;font-size:1.2rem}.bb-hc-meta h4{font-size:.95rem;color:var(--bb-charcoal)}.bb-hc-meta span{font-size:.78rem;color:var(--bb-gray)}.bb-hc-game{background:linear-gradient(135deg,var(--bb-blue-light) 0%,var(--bb-purple-light) 100%);border-radius:16px;padding:22px}.bb-hc-game h3{font-size:1rem;margin-bottom:2px;color:var(--bb-charcoal)}.bb-hc-game p{font-size:.8rem;color:var(--bb-gray)}.bb-hc-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-top:14px}.bb-hc-cell{aspect-ratio:1;border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:Fredoka,sans-serif;font-weight:700;font-size:.95rem;color:var(--bb-charcoal);background:var(--bb-white);box-shadow:0 1px 4px #1f29370f;animation:bb-cellIn .4s cubic-bezier(.34,1.56,.64,1) both}.bb-hc-cell.found{background:var(--bb-yellow-light);color:var(--bb-yellow-deep);border:1.5px solid var(--bb-yellow)}@keyframes bb-cellIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.bb-hc-stats{display:flex;gap:10px;margin-top:14px}.bb-hc-stat{flex:1;background:var(--bb-snow);border-radius:10px;padding:10px;text-align:center}.bb-hc-stat .n{font-family:Fredoka,sans-serif;font-size:1.2rem;font-weight:700;color:var(--bb-blue)}.bb-hc-stat .l{font-size:.7rem;color:var(--bb-gray);font-weight:700;text-transform:uppercase;letter-spacing:.05em}.bb-hero-float{position:absolute;background:var(--bb-white);border-radius:12px;padding:8px 14px;box-shadow:var(--bb-shadow);display:flex;align-items:center;gap:6px;font-weight:700;font-size:.8rem;color:var(--bb-charcoal);z-index:5;white-space:nowrap}.bb-hero-float-1{top:20px;right:-30px;animation:bb-float1 5s ease-in-out infinite}.bb-hero-float-2{bottom:40px;left:-30px;animation:bb-float2 6s ease-in-out infinite}.bb-hero-float-3{top:50%;right:-40px;animation:bb-float1 7s ease-in-out infinite 1s}@keyframes bb-float1{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-8px) rotate(1.5deg)}}@keyframes bb-float2{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-6px) rotate(-1.5deg)}}.bb-section{padding:100px 0}.bb-section-label{font-family:Fredoka,sans-serif;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.14em;color:var(--bb-blue);margin-bottom:10px;display:inline-block}.bb-section-title{font-size:2.5rem;margin-bottom:14px;color:var(--bb-charcoal)}.bb-section-desc{font-size:1.1rem;color:var(--bb-gray);max-width:580px;line-height:1.75}.bb-section-header{text-align:center;margin-bottom:60px}.bb-section-header .bb-section-desc{margin:14px auto 0}.bb-fade-up{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}.bb-fade-up.visible{opacity:1;transform:translateY(0)}.bb-fade-up.d1{transition-delay:.1s}.bb-fade-up.d2{transition-delay:.2s}.bb-fade-up.d3{transition-delay:.3s}.bb-fade-up.d4{transition-delay:.4s}.bb-how-section{background:var(--bb-snow)}.bb-steps-row{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.bb-step-card{background:var(--bb-white);border-radius:var(--bb-radius);padding:32px 24px;text-align:center;position:relative;transition:all .4s cubic-bezier(.34,1.56,.64,1);box-shadow:var(--bb-shadow-sm)}.bb-step-card:hover{transform:translateY(-6px);box-shadow:var(--bb-shadow-lg)}.bb-step-num{width:48px;height:48px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-family:Fredoka,sans-serif;font-weight:700;font-size:1.2rem;color:var(--bb-white);margin-bottom:16px}.bb-step-card:nth-child(1) .bb-step-num{background:var(--bb-blue)}.bb-step-card:nth-child(2) .bb-step-num{background:var(--bb-yellow);color:var(--bb-charcoal)}.bb-step-card:nth-child(3) .bb-step-num{background:var(--bb-green)}.bb-step-card:nth-child(4) .bb-step-num{background:var(--bb-purple)}.bb-step-card h3{font-size:1.05rem;margin-bottom:8px}.bb-step-card p{font-size:.88rem;color:var(--bb-gray);line-height:1.6}.bb-step-card:after{content:"···";position:absolute;top:48px;right:-18px;color:var(--bb-mist);font-size:1.2rem;letter-spacing:2px;font-weight:900}.bb-step-card:last-child:after{display:none}.bb-games-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.bb-game-card{background:var(--bb-white);border-radius:var(--bb-radius);padding:30px 26px;border:1.5px solid var(--bb-light);position:relative;overflow:hidden;transition:all .4s cubic-bezier(.34,1.56,.64,1)}.bb-game-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;transition:height .3s}.bb-game-card:hover{transform:translateY(-5px);box-shadow:var(--bb-shadow-lg);border-color:transparent}.bb-game-card:hover:before{height:5px}.bb-game-card:nth-child(1):before{background:var(--bb-blue)}.bb-game-card:nth-child(2):before{background:var(--bb-yellow)}.bb-game-card:nth-child(3):before{background:var(--bb-green)}.bb-game-card:nth-child(4):before{background:var(--bb-purple)}.bb-game-card:nth-child(5):before{background:var(--bb-coral)}.bb-game-card:nth-child(6):before{background:var(--bb-blue-glow)}.bb-game-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:14px}.bb-game-card:nth-child(1) .bb-game-icon{background:var(--bb-blue-light)}.bb-game-card:nth-child(2) .bb-game-icon{background:var(--bb-yellow-light)}.bb-game-card:nth-child(3) .bb-game-icon{background:var(--bb-green-light)}.bb-game-card:nth-child(4) .bb-game-icon{background:var(--bb-purple-light)}.bb-game-card:nth-child(5) .bb-game-icon{background:var(--bb-coral-light)}.bb-game-card:nth-child(6) .bb-game-icon{background:var(--bb-blue-light)}.bb-game-card h3{font-size:1.05rem;margin-bottom:6px}.bb-game-card p{font-size:.86rem;color:var(--bb-gray);line-height:1.6}.bb-game-diff{display:flex;gap:5px;margin-top:14px}.bb-game-diff span{padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:800;letter-spacing:.02em}.bb-d-easy{background:var(--bb-green-light);color:#2d9f63}.bb-d-med{background:var(--bb-yellow-light);color:#c48b1a}.bb-d-hard{background:var(--bb-red-light);color:var(--bb-red)}.bb-diff-section{background:var(--bb-snow)}.bb-diff-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}.bb-diff-card{border-radius:var(--bb-radius);padding:40px 30px;text-align:center;position:relative;overflow:hidden;transition:all .4s cubic-bezier(.34,1.56,.64,1)}.bb-diff-card:hover{transform:translateY(-6px) scale(1.02)}.bb-diff-card.easy{background:linear-gradient(165deg,#e8f8ef,#f5fdf8);border:2px solid #C3ECDA}.bb-diff-card.medium{background:linear-gradient(165deg,#fdf6e0,#fffcf5);border:2px solid #F5E5A3}.bb-diff-card.hard{background:linear-gradient(165deg,#fdecec,#fef5f5);border:2px solid #F5C5C5}.bb-diff-card h3{font-size:1.4rem;margin-bottom:8px}.bb-diff-card.easy h3{color:#1e8a52}.bb-diff-card.medium h3{color:#b07a14}.bb-diff-card.hard h3{color:#c53030}.bb-diff-card p{font-size:.92rem;color:var(--bb-gray);line-height:1.65}.bb-diff-age{display:inline-block;margin-top:16px;padding:5px 16px;border-radius:20px;font-size:.82rem;font-weight:800}.bb-diff-card.easy .bb-diff-age{background:#c3ecda;color:#1e8a52}.bb-diff-card.medium .bb-diff-age{background:#f5e5a3;color:#b07a14}.bb-diff-card.hard .bb-diff-age{background:#f5c5c5;color:#c53030}.bb-diff-icon{font-size:2.8rem;margin-bottom:14px;display:block}.bb-journey-section{background:linear-gradient(175deg,#1a2332,#111827);color:var(--bb-white)}.bb-journey-section .bb-section-label{color:var(--bb-yellow)}.bb-journey-section .bb-section-title{color:var(--bb-white)}.bb-journey-section .bb-section-desc{color:#8896a8}.bb-journey-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}.bb-jf-list{display:flex;flex-direction:column;gap:18px}.bb-jf-item{display:flex;gap:14px;align-items:flex-start;background:#ffffff0a;border-radius:14px;padding:22px;border:1px solid rgba(255,255,255,.07);transition:all .3s}.bb-jf-item:hover{background:#ffffff12;border-color:#ffffff1f}.bb-jf-icon{width:44px;height:44px;border-radius:11px;display:flex;flex-shrink:0;align-items:center;justify-content:center;font-size:1.2rem}.bb-jf-item:nth-child(1) .bb-jf-icon{background:#2f80ed33}.bb-jf-item:nth-child(2) .bb-jf-icon{background:#f2c94c33}.bb-jf-item:nth-child(3) .bb-jf-icon{background:#6fcf9733}.bb-jf-item:nth-child(4) .bb-jf-icon{background:#9b51e033}.bb-jf-item h4{font-size:.98rem;margin-bottom:3px}.bb-jf-item p{font-size:.84rem;color:#7a8899;line-height:1.55}.bb-journey-demo{background:#ffffff08;border-radius:20px;padding:28px;border:1px solid rgba(255,255,255,.06)}.bb-jd-title{font-size:.95rem;margin-bottom:2px}.bb-jd-sub{font-size:.78rem;color:#5a6b7d;margin-bottom:18px}.bb-jd-chapter{display:flex;gap:14px;align-items:center;padding:13px 14px;border-radius:12px;margin-bottom:8px;transition:all .2s}.bb-jd-chapter:hover{background:#ffffff0a}.bb-jd-chapter.active{background:#2f80ed1f;border:1px solid rgba(47,128,237,.25)}.bb-jd-chapter.done{opacity:.7}.bb-ch-num{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:Fredoka,sans-serif;font-weight:700;font-size:.82rem;background:#ffffff14;color:#7a8899;flex-shrink:0}.bb-jd-chapter.active .bb-ch-num{background:var(--bb-blue);color:var(--bb-white)}.bb-jd-chapter.done .bb-ch-num{background:var(--bb-green);color:var(--bb-white);font-size:.7rem}.bb-ch-info h4{font-size:.88rem;color:var(--bb-white);font-weight:600}.bb-ch-info p{font-size:.75rem;color:#5a6b7d}.bb-ch-badge{margin-left:auto;font-size:.7rem;font-weight:800;padding:3px 10px;border-radius:20px;white-space:nowrap}.bb-ch-badge.done{background:#6fcf971f;color:var(--bb-green)}.bb-ch-badge.active{background:#2f80ed1f;color:var(--bb-blue-glow)}.bb-safety-section{background:var(--bb-snow)}.bb-safety-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}.bb-safety-card{background:var(--bb-white);border-radius:22px;padding:34px;box-shadow:var(--bb-shadow-lg)}.bb-safety-card h3{font-size:1.2rem;margin-bottom:22px;display:flex;align-items:center;gap:10px}.bb-safety-list{display:flex;flex-direction:column;gap:12px}.bb-safety-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:12px;background:var(--bb-snow);transition:all .25s}.bb-safety-item:hover{background:var(--bb-green-light)}.bb-safety-check{width:28px;height:28px;border-radius:50%;background:var(--bb-green);display:flex;align-items:center;justify-content:center;flex-shrink:0}.bb-safety-check svg{width:14px;height:14px;stroke:#fff;fill:none;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}.bb-safety-item span{font-weight:700;font-size:.9rem;color:var(--bb-charcoal)}.bb-safety-text{display:flex;flex-direction:column;gap:18px}.bb-safety-text p{font-size:1.02rem;color:var(--bb-gray);line-height:1.75}.bb-pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;max-width:940px;margin:0 auto}.bb-price-card{background:var(--bb-white);border-radius:var(--bb-radius);padding:34px 28px;border:2px solid var(--bb-light);text-align:center;position:relative;transition:all .4s cubic-bezier(.34,1.56,.64,1)}.bb-price-card:hover{transform:translateY(-5px);box-shadow:var(--bb-shadow-lg)}.bb-price-card.pop{border-color:var(--bb-blue);background:linear-gradient(180deg,var(--bb-blue-light) 0%,var(--bb-white) 35%)}.bb-price-card.pop:before{content:"Most Popular";position:absolute;top:-13px;left:50%;transform:translate(-50%);background:var(--bb-blue);color:var(--bb-white);padding:3px 18px;border-radius:20px;font-size:.75rem;font-weight:700;font-family:Fredoka,sans-serif}.bb-price-name{font-family:Fredoka,sans-serif;font-size:1.1rem;font-weight:600;margin-bottom:10px}.bb-price-amt{font-family:Fredoka,sans-serif;font-size:2.8rem;font-weight:700;color:var(--bb-charcoal)}.bb-price-amt span{font-size:.95rem;color:var(--bb-gray);font-weight:400}.bb-price-desc{font-size:.85rem;color:var(--bb-gray);margin:10px 0 22px}.bb-price-list{list-style:none;text-align:left;margin-bottom:24px}.bb-price-list li{padding:7px 0;font-size:.88rem;color:var(--bb-gray-dark);display:flex;align-items:center;gap:8px}.bb-price-list li:before{content:"✓";color:var(--bb-green);font-weight:800;font-size:.9rem}.bb-price-card .bb-btn{width:100%;justify-content:center}.bb-cta-section{background:linear-gradient(135deg,var(--bb-blue) 0%,var(--bb-blue-deep) 100%);color:var(--bb-white);text-align:center;padding:100px 0;position:relative;overflow:hidden}.bb-cta-orb-1{position:absolute;top:-80px;right:-80px;width:280px;height:280px;border-radius:50%;background:#f2c94c1f}.bb-cta-orb-2{position:absolute;bottom:-100px;left:-60px;width:350px;height:350px;border-radius:50%;background:#ffffff0a}.bb-cta-section .bb-container{position:relative;z-index:2}.bb-cta-section h2{font-size:2.6rem;margin-bottom:14px;font-family:Fredoka,sans-serif}.bb-cta-section p{font-size:1.15rem;opacity:.85;margin:0 auto 34px;max-width:520px}.bb-cta-section .bb-btn-yellow{font-size:1.15rem;padding:17px 44px}.bb-demo-section{padding:80px 0 100px;background:linear-gradient(175deg,#f7f9fc,#edf4fe 40%,#fefcf3);position:relative}.bb-demo-controls{display:flex;flex-direction:column;align-items:center;gap:16px;margin-bottom:40px}.bb-demo-tabs{display:flex;gap:8px;background:#fff;border-radius:14px;padding:5px;box-shadow:0 2px 12px #0000000f}.bb-demo-tab{display:flex;align-items:center;gap:7px;padding:11px 24px;border:none;border-radius:10px;font-family:Fredoka,sans-serif;font-weight:600;font-size:.95rem;background:transparent;color:#6b7280;cursor:pointer;transition:all .2s}.bb-demo-tab:hover{color:var(--bb-blue)}.bb-demo-tab.active{background:var(--bb-blue);color:#fff;box-shadow:0 4px 12px #2f80ed40}.bb-demo-topics{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.bb-demo-topic{padding:8px 18px;border:2px solid #e5e7eb;border-radius:30px;font-family:Nunito,sans-serif;font-weight:700;font-size:.85rem;background:#fff;color:#374151;cursor:pointer;transition:all .2s}.bb-demo-topic:hover{border-color:var(--bb-blue);color:var(--bb-blue)}.bb-demo-topic.active{border-color:var(--bb-blue);background:var(--bb-blue);color:#fff}.bb-demo-stage{max-width:720px;margin:0 auto}.bb-demo-cw-layout{display:flex;flex-direction:column;align-items:center}.bb-demo-cw-grid-wrap{background:#fff;border-radius:16px;padding:20px;box-shadow:0 4px 24px #00000014;display:inline-block;margin-bottom:24px}.bb-demo-cw-grid{display:grid;gap:2px;width:-moz-fit-content;width:fit-content}.bb-cw-cell{width:44px;height:44px;position:relative;border-radius:4px}.bb-cw-cell.blank{background:transparent}.bb-cw-cell.active{background:#fff;border:2px solid #d1d5db;cursor:pointer}.bb-cw-cell.active.highlighted{border-color:var(--bb-blue);background:#2f80ed0f}.bb-cw-cell-num{position:absolute;top:2px;left:3px;font-size:.6rem;font-weight:700;color:#374151;z-index:2;pointer-events:none;line-height:1}.bb-cw-cell-input{width:100%;height:100%;border:none;outline:none;background:transparent;text-align:center;font-family:Fredoka,sans-serif;font-size:1.15rem;font-weight:700;color:var(--bb-blue);text-transform:uppercase;cursor:pointer}.bb-cw-cell-input:focus{background:#2f80ed1a}.bb-demo-cw-clues{display:grid;grid-template-columns:1fr 1fr;gap:24px;background:#fff;border-radius:14px;padding:20px 24px;box-shadow:0 2px 12px #0000000d;margin-bottom:8px;width:100%;max-width:600px}.bb-demo-cw-clue-group h4{font-family:Fredoka,sans-serif;font-size:.9rem;font-weight:700;color:var(--bb-blue);margin-bottom:10px;text-transform:uppercase;letter-spacing:.05em}.bb-demo-cw-clue-item{font-size:.85rem;color:#4b5563;margin-bottom:6px;cursor:pointer;padding:4px 8px;border-radius:6px;transition:background .15s;line-height:1.5}.bb-demo-cw-clue-item:hover{background:#f3f4f6}.bb-demo-cw-clue-item.selected{background:#2f80ed1a;color:var(--bb-blue);font-weight:700}.bb-demo-cw-clue-item strong{color:#1f2937}.bb-demo-hint-btn{margin-top:8px;background:none;border:none;color:var(--bb-blue);font-family:Nunito,sans-serif;font-weight:700;font-size:.82rem;cursor:pointer;padding:0}.bb-demo-hint-btn:hover{text-decoration:underline}.bb-demo-hint-text{margin-top:8px;font-size:.85rem;color:#6b7280;font-style:italic}.bb-demo-submit{display:block;margin:0 auto;padding:14px 40px;border:none;border-radius:12px;background:var(--bb-blue);color:#fff;font-family:Fredoka,sans-serif;font-weight:700;font-size:1rem;cursor:pointer;transition:all .2s;box-shadow:0 4px 14px #2f80ed4d}.bb-demo-submit:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2f80ed59}.bb-demo-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}.bb-demo-results{background:#fff;border-radius:18px;padding:36px;box-shadow:0 4px 24px #0000000f}.bb-demo-results-header{text-align:center;margin-bottom:24px}.bb-demo-results-emoji{font-size:2.5rem;display:block;margin-bottom:8px}.bb-demo-results-header h3{font-family:Fredoka,sans-serif;font-size:1.3rem;color:#1f2937}.bb-demo-results-list{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}.bb-demo-result-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:10px;font-size:.9rem}.bb-demo-result-row.correct{background:#f0fdf4}.bb-demo-result-row.wrong{background:#fef2f2}.bb-demo-result-icon{font-size:1.1rem;flex-shrink:0}.bb-demo-result-clue{flex:1;color:#374151;font-weight:600}.bb-demo-result-answer{font-family:Fredoka,sans-serif;font-weight:700;color:#1f2937;font-size:.88rem}.bb-demo-sw-card{background:#fff;border-radius:18px;padding:36px;text-align:center;box-shadow:0 4px 24px #0000000f}.bb-demo-sw-progress{font-family:Fredoka,sans-serif;font-weight:600;font-size:.85rem;color:var(--bb-blue);margin-bottom:16px}.bb-demo-sw-prompt{font-weight:700;color:#1f2937;font-size:1.05rem;margin-bottom:24px;line-height:1.6}.bb-demo-sw-slots{display:flex;justify-content:center;gap:8px;margin-bottom:10px;flex-wrap:wrap}.bb-demo-sw-slot{width:44px;height:48px;border:2px dashed #d1d5db;border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:Fredoka,sans-serif;font-weight:700;font-size:1.1rem;color:var(--bb-blue);transition:all .2s}.bb-demo-sw-slot.filled{border-style:solid;border-color:var(--bb-blue);background:#2f80ed14}.bb-demo-clear{margin:10px auto 20px;background:none;border:none;color:#ef4444;font-family:Nunito,sans-serif;font-weight:700;font-size:.85rem;cursor:pointer}.bb-demo-sw-pool{display:flex;justify-content:center;gap:8px;margin-bottom:20px;flex-wrap:wrap}.bb-demo-sw-letter{width:48px;height:52px;border:2px solid var(--bb-blue);border-radius:12px;background:#fff;display:flex;align-items:center;justify-content:center;font-family:Fredoka,sans-serif;font-weight:700;font-size:1.15rem;color:var(--bb-blue);cursor:pointer;transition:all .15s}.bb-demo-sw-letter:hover:not(.used){background:#2f80ed14;transform:translateY(-2px)}.bb-demo-sw-letter.used{opacity:.25;cursor:default;border-color:#d1d5db;color:#d1d5db}@media(max-width:640px){.bb-demo-tabs{flex-direction:column;width:100%}.bb-demo-sw-slot{width:36px;height:40px;font-size:.95rem}.bb-demo-sw-letter{width:40px;height:44px;font-size:1rem}.bb-cw-cell{width:36px;height:36px}.bb-cw-cell-input{font-size:.95rem}.bb-demo-cw-clues{grid-template-columns:1fr}}.bb-footer{background:#fff;color:#64748b;padding:0;position:relative;overflow:hidden;border-top:1px solid #e5e7eb}.bb-footer-bg{position:absolute;inset:0;pointer-events:none;z-index:0}.bb-footer-bg canvas{width:100%;height:100%;display:none}.bb-footer-content{position:relative;z-index:2;padding:64px 0 28px}.bb-footer-top{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}.bb-footer-brand-text{display:flex;align-items:center;margin-bottom:12px}.bb-footer-logo-img{height:72px;width:auto;-o-object-fit:contain;object-fit:contain;display:block}.bb-footer-brand p{font-size:.88rem;line-height:1.7;max-width:280px;color:#64748b}.bb-footer-col h4{font-family:Fredoka,sans-serif;color:#1e293b;margin-bottom:14px;font-size:.95rem;font-weight:600}.bb-footer-col a{display:block;color:#64748b;text-decoration:none;font-size:.88rem;padding:3px 0;transition:color .2s}.bb-footer-col a:hover{color:#1e293b}.bb-footer-divider{height:1px;background:#e5e7eb;margin-bottom:24px}.bb-footer-bottom{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:#94a3b8}.bb-footer-bottom a{color:#64748b;text-decoration:none;transition:color .2s}.bb-footer-bottom a:hover{color:#1e293b}.bb-footer-legal{display:flex;gap:24px}.bb-mobile-overlay{position:fixed;inset:0;z-index:999;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:flex-end}.bb-mobile-panel{background:#fff;width:280px;padding:24px;display:flex;flex-direction:column;gap:16px;animation:bb-slideIn .3s ease}@keyframes bb-slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.bb-mobile-panel a{display:block;text-decoration:none;padding:12px 16px;border-radius:12px;font-family:Fredoka,sans-serif;font-weight:600;font-size:1rem;color:var(--bb-charcoal);transition:background .2s}.bb-mobile-panel a:hover{background:var(--bb-snow)}@media(max-width:1024px){.bb-hero-grid,.bb-journey-grid,.bb-safety-grid{grid-template-columns:1fr}.bb-hero-visual{order:-1}.bb-hero-content h1{font-size:2.8rem}.bb-steps-row{grid-template-columns:repeat(2,1fr)}.bb-step-card:after{display:none}.bb-footer-top{grid-template-columns:1fr 1fr}}@media(max-width:768px){.bb-hero-content h1{font-size:2.2rem}.bb-section-title{font-size:2rem}.bb-games-grid,.bb-diff-grid,.bb-pricing-grid{grid-template-columns:1fr;max-width:440px;margin-left:auto;margin-right:auto}.bb-steps-row{grid-template-columns:1fr;max-width:380px;margin:0 auto}.bb-footer-top{grid-template-columns:1fr}.bb-nav-links{display:none}.bb-mobile-menu{display:block}.bb-section{padding:70px 0}.bb-hero{padding:120px 0 80px}.bb-hero-float{display:none}}.bb-modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:bb-fadeIn .2s ease}@keyframes bb-fadeIn{0%{opacity:0}to{opacity:1}}.bb-modal{background:#fff;border-radius:24px;padding:40px;max-width:440px;width:90%;box-shadow:var(--bb-shadow-xl);animation:bb-modalIn .3s cubic-bezier(.34,1.56,.64,1)}@keyframes bb-modalIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.bb-modal h2{font-family:Fredoka,sans-serif;font-size:1.6rem;margin-bottom:8px;color:var(--bb-charcoal)}.bb-modal p{font-size:.95rem;color:var(--bb-gray);margin-bottom:24px;line-height:1.6}.bb-modal input{width:100%;padding:14px 18px;border-radius:12px;border:2px solid var(--bb-mist);font-family:Nunito,sans-serif;font-size:1rem;outline:none;transition:border-color .2s;margin-bottom:12px}.bb-modal input:focus{border-color:var(--bb-blue)}.bb-modal .bb-btn{width:100%;justify-content:center;margin-top:8px}.bb-modal-close{position:absolute;top:16px;right:16px;background:none;border:none;cursor:pointer;font-size:1.4rem;color:var(--bb-gray);padding:4px}.bb-modal-success{text-align:center}.bb-modal-success .check-icon{font-size:3rem;margin-bottom:12px;display:block}.db-container{min-height:100vh;background:#f8f9fc;font-family:Nunito,sans-serif}.db-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;background:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:10}.db-header-left{display:flex;align-items:center;gap:.5rem}.db-nav-logo{display:flex;align-items:center;height:50px;overflow:hidden;cursor:pointer}.db-nav-logo-img{height:140px;width:auto;-o-object-fit:contain;object-fit:contain;display:block}.db-hamburger{display:none;flex-direction:column;gap:4px;background:none;border:none;cursor:pointer;padding:4px}.db-hamburger span{display:block;width:20px;height:2.5px;background:#374151;border-radius:2px;transition:all .2s}.db-logo{display:none}.db-header-right{display:flex;align-items:center;gap:1rem}.db-user-name{font-weight:600;color:#374151}.db-content{display:flex;max-width:1280px;margin:0 auto;padding:2rem 1rem;gap:2rem}.db-sidebar{width:220px;flex-shrink:0}.db-sidebar h3{font-family:Fredoka,sans-serif;font-size:1rem;color:#374151;margin-bottom:.75rem;margin-top:0}.db-child-list{display:flex;flex-direction:column;gap:.5rem}.db-child-card{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;border:2px solid #e5e7eb;border-radius:12px;background:#fff;cursor:pointer;transition:all .2s;text-align:left;width:100%}.db-child-card:hover{border-color:#6c63ff}.db-child-card.active{border-color:#6c63ff;background:#f0effe}.db-child-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#6c63ff,#ff6584);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;flex-shrink:0}.db-child-name{font-weight:700;color:#1f2937;font-size:.9rem}.db-child-age{font-size:.75rem;color:#6b7280}.db-add-child-btn{padding:.6rem;border:2px dashed #d1d5db;border-radius:12px;background:transparent;color:#6c63ff;font-weight:600;cursor:pointer;transition:all .2s;font-size:.85rem}.db-add-child-btn:hover{border-color:#6c63ff;background:#f0effe}.db-nav{margin-top:1.5rem;display:flex;flex-direction:column;gap:.25rem}.db-nav-btn{display:flex;align-items:center;gap:.6rem;padding:.55rem .75rem;border:none;border-radius:10px;background:transparent;cursor:pointer;font-size:.85rem;font-weight:600;font-family:Nunito,sans-serif;color:#6b7280;transition:all .15s;width:100%;text-align:left}.db-nav-btn:hover{background:#f3f4f6;color:#374151}.db-nav-btn.active{background:#eeecff;color:#6c63ff}.db-main{flex:1;min-width:0}.db-welcome{display:flex;justify-content:center;padding-top:2rem}.db-welcome-card{background:#fff;border-radius:24px;padding:3rem;max-width:600px;text-align:center;box-shadow:0 4px 24px #6c63ff14;animation:dbCardAppear .5s cubic-bezier(.34,1.56,.64,1)}@keyframes dbCardAppear{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.db-welcome-brain{height:100px;margin-bottom:1.5rem;animation:dbBrainBounce 2s ease-in-out infinite}@keyframes dbBrainBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.db-welcome-card h2{font-family:Fredoka,sans-serif;font-size:1.8rem;color:#1f2937;margin:0 0 .75rem}.db-welcome-card>p{color:#6b7280;font-size:1rem;line-height:1.6;margin-bottom:2rem}.db-onboard-steps{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem;text-align:left}.db-onboard-step{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;border-radius:14px;background:#f8f9fc;border:2px solid transparent;transition:all .3s}.db-onboard-step.active{background:#f0effe;border-color:#6c63ff}.db-onboard-num{width:36px;height:36px;border-radius:50%;background:#e5e7eb;color:#6b7280;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1rem;flex-shrink:0}.db-onboard-step.active .db-onboard-num{background:linear-gradient(135deg,#6c63ff,#845ec2);color:#fff}.db-onboard-step h4{margin:0;font-size:.95rem;color:#1f2937}.db-onboard-step p{margin:.15rem 0 0;font-size:.82rem;color:#6b7280}.db-btn-gradient{background:linear-gradient(135deg,#6c63ff,#845ec2)!important;box-shadow:0 4px 14px #6c63ff4d;transition:all .25s cubic-bezier(.34,1.56,.64,1)!important}.db-btn-gradient:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6c63ff66}.db-overview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.db-overview-header h2{font-family:Fredoka,sans-serif;font-size:1.5rem;color:#1f2937;margin:0}.db-overview-subtitle{color:#6b7280;font-size:.9rem;margin:.25rem 0 0}.db-streak{background:linear-gradient(135deg,#ff9671,#ff6584);color:#fff;font-weight:700;font-size:.9rem;padding:.4rem 1rem;border-radius:20px}.db-level-bar{background:#fff;border-radius:16px;padding:1rem 1.25rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #0000000f}.db-level-info{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.db-level-badge{font-weight:800;color:#6c63ff;font-size:.9rem}.db-level-xp{font-size:.8rem;color:#6b7280}.db-level-track{height:10px;background:#e5e7eb;border-radius:5px;overflow:hidden}.db-level-fill{height:100%;background:linear-gradient(90deg,#6c63ff,#845ec2);border-radius:5px;transition:width .5s ease}.db-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.db-stat-card{background:#fff;border-radius:16px;padding:1.25rem;text-align:center;box-shadow:0 1px 3px #0000000f}.db-stat-icon{font-size:1.5rem;margin-bottom:.25rem}.db-stat-value{font-family:Fredoka,sans-serif;font-size:1.6rem;font-weight:700;color:#1f2937}.db-stat-label{font-size:.78rem;color:#6b7280;margin-top:.15rem}.db-insights{background:#fff;border-radius:16px;padding:1.25rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #0000000f}.db-insights h3{font-family:Fredoka,sans-serif;font-size:1.1rem;color:#1f2937;margin:0 0 .75rem}.db-insights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.db-insight-card{background:#f8f9fc;border-radius:12px;padding:1rem;display:flex;flex-direction:column;gap:.25rem}.db-insight-label{font-size:.75rem;color:#6b7280;text-transform:uppercase;font-weight:700;letter-spacing:.03em}.db-insight-value{font-weight:700;color:#1f2937;font-size:1rem}.db-insight-count{font-size:.8rem;color:#9ca3af}.db-quick-actions{margin-bottom:1.5rem}.db-quick-actions h3{font-family:Fredoka,sans-serif;font-size:1.1rem;color:#1f2937;margin:0 0 .75rem}.db-quick-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.db-quick-btn{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.25rem;background:#fff;border:2px solid #e5e7eb;border-radius:14px;cursor:pointer;font-weight:700;font-size:.9rem;color:#374151;font-family:Nunito,sans-serif;transition:all .2s}.db-quick-btn:hover{border-color:#6c63ff;background:#f8f7ff;transform:translateY(-2px)}.db-quick-btn span:first-child{font-size:1.5rem}.db-active-journeys,.db-recent{margin-bottom:1.5rem}.db-active-journeys h3,.db-recent h3{font-family:Fredoka,sans-serif;font-size:1.1rem;color:#1f2937;margin:0 0 .75rem}.db-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.db-section-header h2,.db-section-header h3{font-family:Fredoka,sans-serif;color:#1f2937;margin:0}.db-section-header h2{font-size:1.3rem}.db-journey-list{display:flex;flex-direction:column;gap:.75rem}.db-journey-card{background:#fff;border-radius:14px;padding:1.25rem;display:flex;align-items:center;justify-content:space-between;box-shadow:0 1px 3px #0000000f}.db-journey-info h3,.db-journey-info h4{margin:0 0 .2rem;font-size:1rem;color:#1f2937}.db-journey-subject{font-size:.82rem;color:#6b7280;margin:0 0 .25rem}.db-journey-next{font-size:.8rem;color:#845ec2;font-weight:600;margin:0 0 .5rem;font-style:italic}.db-journey-progress{display:flex;align-items:center;gap:.75rem}.db-progress-bar{width:120px;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.db-progress-fill{height:100%;background:linear-gradient(90deg,#6c63ff,#00c9a7);border-radius:4px;transition:width .3s}.db-progress-text{font-size:.78rem;color:#6b7280}.db-session-list{display:flex;flex-direction:column;gap:.5rem}.db-session-row{display:flex;align-items:center;justify-content:space-between;background:#fff;border-radius:10px;padding:.75rem 1rem;box-shadow:0 1px 2px #0000000a}.db-session-game{display:flex;align-items:center;gap:.6rem}.db-session-emoji{font-size:1.2rem}.db-session-type{font-weight:700;color:#1f2937;font-size:.85rem}.db-session-topic{color:#6b7280;font-size:.82rem}.db-session-stats{display:flex;align-items:center;gap:1rem}.db-session-score{font-weight:600;color:#374151;font-size:.85rem}.db-session-xp{color:#00c9a7;font-weight:600;font-size:.85rem}.db-session-difficulty{font-size:.7rem;font-weight:700;text-transform:uppercase;border-radius:6px;padding:2px 8px}.db-diff-easy{background:#d1fae5;color:#065f46}.db-diff-medium{background:#fef3c7;color:#92400e}.db-diff-hard{background:#fee2e2;color:#991b1b}.db-game-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.db-game-card{background:#fff;border:none;border-radius:16px;padding:0;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex;flex-direction:column;overflow:hidden;box-shadow:0 2px 8px #0000000f}.db-game-card:hover{transform:translateY(-6px);box-shadow:0 12px 32px #6c63ff26}.db-game-card-header{padding:2rem 1rem;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.db-game-card-header:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.3) 0%,transparent 60%);pointer-events:none}.db-game-emoji{font-size:3.5rem;filter:drop-shadow(0 4px 8px rgba(0,0,0,.15));position:relative;z-index:1}.db-game-card-body{padding:1rem 1.25rem 1.25rem;display:flex;flex-direction:column;gap:.25rem}.db-game-label{font-weight:700;color:#1f2937;font-size:1rem}.db-game-desc{font-size:.8rem;color:#6b7280;line-height:1.4}.db-tab-desc{color:#6b7280;font-size:.9rem;margin:.25rem 0 1.5rem}.db-empty-journeys{background:#fff;border-radius:16px;padding:3rem 2rem;text-align:center;box-shadow:0 1px 3px #0000000f}.db-empty-icon{font-size:3rem;margin-bottom:.5rem}.db-empty-journeys h3{font-family:Fredoka,sans-serif;font-size:1.3rem;color:#1f2937;margin:0 0 .5rem}.db-empty-journeys>p{color:#6b7280;max-width:400px;margin:0 auto 1.5rem}.db-empty-features{display:flex;justify-content:center;gap:1.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.db-empty-features>div{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:#374151;font-weight:600}.db-journey-cards{display:flex;flex-direction:column;gap:1rem}.db-journey-detail{background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000000f;overflow:hidden}.db-journey-detail.completed{border-left:4px solid #00C9A7}.db-journey-detail-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem;cursor:pointer;transition:background .15s}.db-journey-detail-header:hover{background:#fafafa}.db-journey-detail-info h3{font-family:Fredoka,sans-serif;font-size:1.1rem;color:#1f2937;margin:.25rem 0}.db-journey-status-badge{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.db-journey-status-badge[data-status=active]{color:#6c63ff}.db-journey-status-badge[data-status=completed]{color:#00c9a7}.db-journey-desc{font-size:.85rem;color:#6b7280;margin:.25rem 0 0;line-height:1.4}.db-journey-detail-meta{display:flex;align-items:center;gap:1rem}.db-journey-progress-ring{position:relative;width:50px;height:50px}.db-progress-ring-svg{width:100%;height:100%;transform:rotate(-90deg)}.db-progress-ring-bg{fill:none;stroke:#e5e7eb;stroke-width:3}.db-progress-ring-fill{fill:none;stroke:#6c63ff;stroke-width:3;stroke-linecap:round;transition:stroke-dasharray .4s ease}.db-progress-ring-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:#374151}.db-journey-expand{color:#9ca3af;font-size:.8rem}.db-chapter-map{padding:0 1.25rem 1.25rem;border-top:1px solid #f3f4f6}.db-chapter{display:flex;gap:1rem;padding:.75rem 0}.db-chapter.locked{opacity:.5}.db-chapter-connector{display:flex;flex-direction:column;align-items:center;width:36px;flex-shrink:0}.db-chapter-dot{width:32px;height:32px;border-radius:50%;border:3px solid #d1d5db;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;color:#6b7280;background:#fff;flex-shrink:0}.db-chapter-dot.complete{border-color:#00c9a7;color:#00c9a7;background:#d1fae5}.db-chapter-dot.current{border-color:#6c63ff;color:#6c63ff;background:#eeecff}.db-chapter-line{width:3px;flex:1;background:#e5e7eb;min-height:20px}.db-chapter-line.complete{background:#00c9a7}.db-chapter-content{flex:1;min-width:0}.db-chapter-header{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.db-chapter-header h4{margin:0;font-size:.95rem;color:#1f2937}.db-chapter-game-badge{font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:8px}.db-chapter-desc{font-size:.82rem;color:#6b7280;margin:.25rem 0}.db-chapter-narrative{font-size:.82rem;color:#845ec2;font-style:italic;margin:.25rem 0}.db-chapter-goals{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.35rem}.db-chapter-goal{font-size:.72rem;color:#374151;background:#f3f4f6;padding:2px 8px;border-radius:6px}.db-journey-action{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;border-top:1px solid #f3f4f6}.db-history-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.db-history-stat{background:#fff;border-radius:12px;padding:1rem;text-align:center;box-shadow:0 1px 2px #0000000a}.db-history-stat-label{display:block;font-size:.75rem;color:#6b7280}.db-history-stat-value{display:block;font-family:Fredoka,sans-serif;font-size:1.3rem;font-weight:700;color:#1f2937}.db-session-list-full .db-session-header-row{display:grid;grid-template-columns:1.5fr 1.5fr 1fr .7fr .7fr .8fr;gap:.5rem;padding:.5rem 1rem;font-size:.72rem;font-weight:700;text-transform:uppercase;color:#9ca3af;letter-spacing:.04em}.db-session-row-full{display:grid;grid-template-columns:1.5fr 1.5fr 1fr .7fr .7fr .8fr;gap:.5rem;align-items:center}.db-score-badge{font-size:.8rem;font-weight:600;padding:2px 8px;border-radius:6px}.db-score-badge.great{background:#d1fae5;color:#065f46}.db-score-badge.good{background:#fef3c7;color:#92400e}.db-score-badge.needs-work{background:#fee2e2;color:#991b1b}.db-session-date{font-size:.8rem;color:#9ca3af}.db-settings-tab h2{font-family:Fredoka,sans-serif;font-size:1.3rem;color:#1f2937;margin:0}.db-settings-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 1px 3px #0000000f;margin-bottom:1.25rem}.db-settings-card h3{font-family:Fredoka,sans-serif;font-size:1.05rem;color:#1f2937;margin:0 0 1rem}.db-settings-profile{display:flex;align-items:center;gap:1.5rem}.db-settings-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#6c63ff,#ff6584);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.6rem;flex-shrink:0}.db-settings-info{flex:1}.db-settings-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #f3f4f6}.db-settings-row:last-child{border-bottom:none}.db-settings-label{color:#6b7280;font-size:.85rem}.db-settings-value{font-weight:600;color:#1f2937;font-size:.85rem}.db-settings-actions{display:flex;gap:.75rem;margin-top:1rem}.db-settings-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.db-settings-stat{background:#f8f9fc;border-radius:10px;padding:.75rem;text-align:center}.db-settings-stat span{display:block;font-size:.75rem;color:#6b7280}.db-settings-stat strong{font-family:Fredoka,sans-serif;font-size:1.1rem;color:#1f2937}.db-games-tab h2,.db-journeys-tab h2,.db-history-tab h2{font-family:Fredoka,sans-serif;font-size:1.3rem;color:#1f2937;margin:0}.db-empty{background:#fff;border-radius:12px;padding:2rem;text-align:center;color:#6b7280;box-shadow:0 1px 3px #0000000f}.db-empty-state{background:#fff;border-radius:20px;padding:3rem 2rem;text-align:center;box-shadow:0 2px 12px #6c63ff0f;animation:dbCardAppear .4s ease}.db-empty-state-icon{font-size:3rem;margin-bottom:.75rem}.db-empty-state h3{font-family:Fredoka,sans-serif;font-size:1.3rem;color:#1f2937;margin:0 0 .5rem}.db-empty-state p{color:#6b7280;max-width:400px;margin:0 auto 1.5rem;font-size:.95rem;line-height:1.6}.db-empty-overview{background:linear-gradient(135deg,#f8f7ff,#f0f5ff);border-radius:20px;padding:3rem 2rem;text-align:center;border:2px dashed rgba(108,99,255,.2);animation:dbCardAppear .4s ease}.db-empty-overview-icon{font-size:3.5rem;margin-bottom:.5rem}.db-empty-overview h3{font-family:Fredoka,sans-serif;font-size:1.4rem;color:#1f2937;margin:0 0 .5rem}.db-empty-overview p{color:#6b7280;max-width:440px;margin:0 auto 1.5rem;font-size:.95rem;line-height:1.6}.db-empty-overview-actions{display:flex;flex-direction:column;align-items:center;gap:.5rem}.db-streak-area{display:flex;align-items:center;gap:.5rem}.db-streak-fire{display:inline-block;animation:dbFirePulse 1s ease-in-out infinite}@keyframes dbFirePulse{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.db-badges-section{background:#fff;border-radius:16px;padding:1.25rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #0000000f}.db-badges-section h3{font-family:Fredoka,sans-serif;font-size:1.1rem;color:#1f2937;margin:0 0 .75rem}.db-badges-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.75rem}.db-badge{display:flex;flex-direction:column;align-items:center;text-align:center;padding:.75rem .5rem;border-radius:12px;background:#f8f9fc;transition:all .2s;gap:.25rem}.db-badge.earned{background:linear-gradient(135deg,#f0effe,#e8faf5);border:1px solid rgba(108,99,255,.15)}.db-badge.locked{opacity:.4;filter:grayscale(.8)}.db-badge-icon{font-size:1.6rem}.db-badge-name{font-weight:700;font-size:.72rem;color:#1f2937}.db-badge-desc{font-size:.65rem;color:#6b7280;line-height:1.3}.db-btn{padding:.6rem 1.2rem;border-radius:10px;font-weight:700;font-size:.9rem;cursor:pointer;border:none;transition:all .2s;font-family:Nunito,sans-serif}.db-btn-primary{background:#6c63ff;color:#fff}.db-btn-primary:hover{background:#5a52e0}.db-btn-primary:disabled{opacity:.6;cursor:not-allowed}.db-btn-ghost{background:transparent;color:#6b7280}.db-btn-ghost:hover{color:#374151;background:#f3f4f6}.db-btn-danger{background:#fee2e2;color:#991b1b}.db-btn-danger:hover{background:#fecaca}.db-btn-sm{padding:.4rem .8rem;font-size:.82rem}.db-btn-lg{padding:.8rem 2rem;font-size:1rem}.db-modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100}.db-modal{background:#fff;border-radius:16px;padding:2rem;width:90%;max-width:440px;box-shadow:0 20px 60px #00000026;max-height:90vh;overflow-y:auto}.db-modal h2{font-family:Fredoka,sans-serif;margin:0 0 .5rem;color:#1f2937}.db-modal-desc{color:#6b7280;font-size:.85rem;margin-bottom:1.25rem}.db-form-group{margin-bottom:1rem}.db-form-group label{display:block;font-weight:600;margin-bottom:.3rem;font-size:.85rem;color:#374151}.db-form-group input{width:100%;padding:.6rem .8rem;border:2px solid #e5e7eb;border-radius:10px;font-size:.95rem;font-family:Nunito,sans-serif;transition:border-color .2s;box-sizing:border-box}.db-form-group input:focus{outline:none;border-color:#6c63ff}.db-form-hint{font-size:.75rem;color:#9ca3af;margin-top:.3rem;display:block}.db-modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem}.db-modal-wide{max-width:560px}.db-category-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.db-category-btn{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.6rem .3rem;border:2px solid #e5e7eb;border-radius:10px;background:#fff;cursor:pointer;font-size:.75rem;font-weight:700;font-family:Nunito,sans-serif;color:#374151;transition:all .2s}.db-category-btn:hover{border-color:#6c63ff}.db-category-btn.active{border-color:#6c63ff;background:#eeecff}.db-topic-grid{display:flex;flex-wrap:wrap;gap:.4rem}.db-topic-btn{padding:.4rem .75rem;border:2px solid #e5e7eb;border-radius:18px;background:#fff;cursor:pointer;font-size:.8rem;font-weight:600;font-family:Nunito,sans-serif;color:#374151;transition:all .2s}.db-topic-btn:hover{border-color:#6c63ff}.db-topic-btn.active{border-color:#6c63ff;background:#6c63ff;color:#fff}.db-error{color:#dc2626;font-size:.85rem;margin-top:.75rem}.db-journey-loading{display:flex;align-items:center;gap:12px;margin-top:1rem;padding:1rem 1.25rem;background:linear-gradient(135deg,#f0effe,#e8faf5);border-radius:12px;animation:journeyLoadPulse 2s ease-in-out infinite}.db-journey-loading p{font-size:.9rem;color:#4b5563;margin:0}.db-spinner{width:24px;height:24px;flex-shrink:0;border:3px solid #e5e7eb;border-top-color:#6c63ff;border-radius:50%;animation:spin .8s linear infinite}@keyframes journeyLoadPulse{0%,to{opacity:1}50%{opacity:.7}}.db-auth-prompt{text-align:center;padding:4rem 2rem}.db-auth-prompt h2{font-family:Fredoka,sans-serif;font-size:2rem;color:#1f2937}.db-auth-prompt p{color:#6b7280;margin-bottom:2rem}.db-loading{color:#6b7280;padding:1rem;text-align:center}@media(max-width:900px){.db-hamburger{display:flex}.db-content{flex-direction:column}.db-sidebar{display:none;width:100%}.db-sidebar.db-sidebar-open{display:block}.db-child-list{flex-direction:row;overflow-x:auto}.db-child-card{min-width:150px}.db-nav{flex-direction:row;overflow-x:auto;gap:.25rem;margin-top:1rem}.db-nav-btn{min-width:-moz-max-content;min-width:max-content}.db-stats-row,.db-game-grid,.db-history-summary,.db-quick-grid{grid-template-columns:repeat(2,1fr)}.db-session-row-full{grid-template-columns:1fr 1fr;gap:.3rem}.db-session-header-row{display:none}.db-settings-profile{flex-direction:column;text-align:center}.db-settings-stats{grid-template-columns:repeat(2,1fr)}.db-badges-grid{grid-template-columns:repeat(3,1fr)}.db-category-grid{grid-template-columns:repeat(2,1fr)}.db-header{padding:.75rem 1rem}.db-overview-header{flex-direction:column;align-items:flex-start;gap:.5rem}}@media(max-width:480px){.db-game-grid{grid-template-columns:1fr}.db-stats-row{grid-template-columns:repeat(2,1fr)}.db-quick-grid{grid-template-columns:1fr}.db-badges-grid{grid-template-columns:repeat(2,1fr)}.db-session-stats{flex-wrap:wrap;gap:.5rem}.db-welcome-card{padding:2rem 1.5rem}.db-onboard-steps{gap:.5rem}.db-footer-links{flex-direction:column;gap:.5rem}}.db-footer{background:#fff;color:#64748b;padding:2rem 0;margin-top:auto;border-top:1px solid #e5e7eb}.db-footer-inner{max-width:1280px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.5rem}.db-footer-logo{cursor:pointer;display:flex;align-items:center}.db-footer-logo-img{height:72px;width:auto;-o-object-fit:contain;object-fit:contain}.db-footer-links{display:flex;align-items:center;gap:1.5rem}.db-footer-links a{color:#64748b;text-decoration:none;font-size:.85rem;font-weight:600;cursor:pointer;transition:color .2s}.db-footer-links a:hover{color:#1e293b}.db-footer-copy{font-size:.78rem;color:#6b7280;margin:0}.db-alert{padding:.75rem 1rem;border-radius:10px;font-size:.9rem;font-weight:600;margin-bottom:1rem}.db-alert-success{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.db-alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.db-parents-list{display:flex;flex-direction:column;gap:.75rem}.db-parent-row{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.db-parent-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#6c63ff,#a78bfa);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;flex-shrink:0}.db-parent-info{flex:1}.db-parent-name{font-weight:700;color:#1e293b;font-size:.95rem}.db-parent-email{font-size:.85rem;color:#64748b}.db-empty-small{text-align:center;padding:2rem 1rem;color:#94a3b8;font-size:.9rem}.celebration-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:9999;pointer-events:none;overflow:hidden}.celebration-overlay.fade-out{animation:celebFadeOut .6s ease-out forwards}@keyframes celebFadeOut{0%{opacity:1}to{opacity:0}}.confetti-piece{position:absolute;width:10px;height:10px;top:50%;left:50%;border-radius:2px;animation:confettiBurst var(--duration) ease-out forwards;opacity:0}.confetti-piece:nth-child(odd){border-radius:50%}.confetti-piece:nth-child(3n){width:8px;height:14px;border-radius:1px}.confetti-piece:nth-child(5n){width:6px;height:6px}@keyframes confettiBurst{0%{opacity:1;transform:translate(0) rotate(0) scale(.5)}15%{opacity:1;transform:translate(var(--tx-mid),var(--ty-mid)) rotate(var(--rot-mid)) scale(1.2)}to{opacity:0;transform:translate(var(--tx),var(--ty)) rotate(var(--rot)) scale(.3)}}.celebration-character{position:fixed;bottom:-200px;left:50%;transform:translate(-50%);z-index:10000;pointer-events:none;animation:characterBounceIn .6s cubic-bezier(.34,1.56,.64,1) .15s forwards;display:flex;flex-direction:column;align-items:center;gap:8px}.celebration-character.fade-out{animation:characterBounceOut .5s ease-in forwards}@keyframes characterBounceIn{0%{bottom:-200px;transform:translate(-50%) scale(.5)}60%{bottom:110px;transform:translate(-50%) scale(1.1)}80%{bottom:90px;transform:translate(-50%) scale(.95)}to{bottom:100px;transform:translate(-50%) scale(1)}}@keyframes characterBounceOut{0%{bottom:100px;transform:translate(-50%) scale(1);opacity:1}to{bottom:-200px;transform:translate(-50%) scale(.5);opacity:0}}.celebration-speech{background:#fff;border-radius:20px;padding:12px 24px;font-family:Fredoka,sans-serif;font-weight:600;font-size:1.3rem;color:#1a1a2e;box-shadow:0 8px 32px #00000026;white-space:nowrap;position:relative;animation:speechPulse .8s ease-in-out .7s 2}.celebration-speech:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:0;height:0;border-left:12px solid transparent;border-right:12px solid transparent;border-top:12px solid white}@keyframes speechPulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.celebration-emoji{font-size:4.5rem;animation:emojiDance .5s ease-in-out .6s 3;filter:drop-shadow(0 4px 12px rgba(0,0,0,.2))}@keyframes emojiDance{0%,to{transform:rotate(0)}25%{transform:rotate(-15deg)}75%{transform:rotate(15deg)}}.star-burst{position:fixed;z-index:9998;pointer-events:none}.star-burst span{position:absolute;font-size:2rem;animation:starFloat var(--star-duration) ease-out forwards;opacity:0}@keyframes starFloat{0%{opacity:0;transform:translate(0) scale(.3)}20%{opacity:1;transform:translate(var(--sx),var(--sy)) scale(1)}to{opacity:0;transform:translate(calc(var(--sx) * 2),calc(var(--sy) * 2 - 60px)) scale(.5)}}.play-container{min-height:100vh;background:linear-gradient(160deg,#f0effe,#f0f7ff,#edfcf5 60%,#fef9f0);font-family:Nunito,sans-serif;display:flex;align-items:center;justify-content:center;padding:2rem 1rem}.play-back{background:none;border:none;color:#6b7280;font-weight:600;cursor:pointer;margin-bottom:1.5rem;font-size:.95rem;font-family:Nunito,sans-serif}.play-back:hover{color:#374151}.play-setup{width:100%;max-width:520px}.play-setup-top-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.play-setup-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.play-setup-emoji{font-size:3rem}.play-setup-header h1{font-family:Fredoka,sans-serif;font-size:2rem;margin:0}.play-form{background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:24px;padding:2rem;box-shadow:0 8px 40px #6c63ff14,0 2px 12px #0000000a;border:1px solid rgba(255,255,255,.6)}.play-form-group{margin-bottom:1.5rem}.play-form-group label{display:block;font-weight:700;margin-bottom:.5rem;color:#374151}.play-form-group input{width:100%;padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;font-family:Nunito,sans-serif;transition:border-color .2s;box-sizing:border-box}.play-form-group input:focus{outline:none;border-color:#6c63ff}.play-category-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem}.play-category-btn{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.75rem .5rem;border:2px solid rgba(229,231,235,.7);border-radius:14px;background:#ffffffb3;cursor:pointer;transition:all .25s cubic-bezier(.34,1.56,.64,1);font-family:Nunito,sans-serif}.play-category-btn:hover{border-color:#6c63ff;background:#f8f7ff;transform:translateY(-3px);box-shadow:0 6px 20px #6c63ff1f}.play-category-btn:active{transform:translateY(0) scale(.96)}.play-category-btn.active{border-color:#6c63ff;background:#eeecff;transform:translateY(-1px);box-shadow:0 4px 16px #6c63ff26}.play-category-emoji{font-size:1.5rem}.play-category-name{font-size:.78rem;font-weight:700;color:#374151}.play-topic-grid{display:flex;flex-wrap:wrap;gap:.5rem}.play-topic-btn{padding:.5rem .9rem;border:2px solid rgba(229,231,235,.7);border-radius:20px;background:#ffffffb3;cursor:pointer;font-size:.88rem;font-weight:600;font-family:Nunito,sans-serif;color:#374151;transition:all .25s cubic-bezier(.34,1.56,.64,1)}.play-topic-btn:hover{border-color:#6c63ff;background:#f8f7ff;transform:translateY(-2px);box-shadow:0 4px 14px #6c63ff1f}.play-topic-btn.active{border-color:#6c63ff;background:#6c63ff;color:#fff;box-shadow:0 4px 16px #6c63ff4d;transform:translateY(-1px)}.play-difficulty-row{display:flex;gap:.75rem}.play-diff-btn{flex:1;padding:.75rem;border:2px solid rgba(229,231,235,.7);border-radius:14px;background:#ffffffb3;cursor:pointer;font-weight:700;font-size:.9rem;font-family:Nunito,sans-serif;transition:all .25s cubic-bezier(.34,1.56,.64,1)}.play-diff-btn:hover{transform:translateY(-2px);box-shadow:0 4px 14px #00000014}.play-diff-btn.active{border-color:currentColor;transform:translateY(-2px) scale(1.02);box-shadow:0 4px 16px #0000001a}.play-diff-easy{color:#059669}.play-diff-easy.active{background:#d1fae5;border-color:#059669}.play-diff-medium{color:#d97706}.play-diff-medium.active{background:#fef3c7;border-color:#d97706}.play-diff-hard{color:#dc2626}.play-diff-hard.active{background:#fee2e2;border-color:#dc2626}.play-start-btn{width:100%;padding:1rem;border:none;border-radius:16px;color:#fff;font-size:1.1rem;font-weight:800;font-family:Nunito,sans-serif;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 6px 20px #00000026}.play-start-btn:hover:not(:disabled){transform:translateY(-3px) scale(1.02);box-shadow:0 10px 32px #0003}.play-start-btn:active:not(:disabled){transform:translateY(0) scale(.98)}.play-start-btn:disabled{opacity:.6;cursor:not-allowed}.play-loading{display:flex;align-items:center;justify-content:center;gap:.75rem}.play-spinner{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.play-error{color:#dc2626;text-align:center;margin-top:1rem;font-size:.9rem}.play-game{width:100%;max-width:900px}.play-game-header{text-align:center;margin-bottom:2rem}.play-game-header-row{display:flex;align-items:center;justify-content:center;gap:.75rem;position:relative}.play-mute-btn{position:absolute;right:0;top:50%;transform:translateY(-50%);background:#fffc;border:2px solid rgba(229,231,235,.7);border-radius:10px;padding:.4rem;cursor:pointer;color:#6b7280;display:flex;align-items:center;justify-content:center;transition:all .2s}.play-mute-btn:hover{border-color:#6c63ff;color:#6c63ff;background:#f8f7ff}.play-game-title{font-family:Fredoka,sans-serif;font-size:1.5rem;color:#1f2937;margin:0 0 .5rem}.play-game-instructions{color:#6b7280;margin:0 0 1rem}.play-progress-bar{width:100%;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;margin-bottom:.5rem}.play-progress-fill{height:100%;border-radius:4px;transition:width .3s}.play-progress-text{font-size:.85rem;color:#6b7280}.play-question-card{background:#ffffffe6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:24px;padding:2rem;box-shadow:0 8px 40px #6c63ff1a,0 2px 8px #0000000a;border:1px solid rgba(255,255,255,.7);position:relative;animation:cardAppear .4s cubic-bezier(.34,1.56,.64,1)}@keyframes cardAppear{0%{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.play-question-number{display:inline-block;color:#fff;font-weight:800;font-size:.85rem;padding:.3rem .8rem;border-radius:8px;margin-bottom:1rem}.play-question-prompt{font-size:1.15rem;font-weight:600;color:#1f2937;line-height:1.6;margin:0 0 .5rem}.play-question-points{font-size:.8rem;color:#9ca3af;margin-bottom:1.25rem}.play-options{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.play-option{padding:.9rem 1.2rem;border:2px solid rgba(229,231,235,.8);border-radius:14px;background:#ffffffb3;text-align:left;font-size:1rem;font-family:Nunito,sans-serif;cursor:pointer;transition:all .25s cubic-bezier(.34,1.56,.64,1);font-weight:500}.play-option:hover{border-color:#6c63ff;background:#f8f7ff;transform:translateY(-2px);box-shadow:0 6px 20px #6c63ff1f}.play-option.selected{border-color:#6c63ff;background:#eeecff;font-weight:700;transform:translateY(-1px);box-shadow:0 4px 16px #6c63ff26}.play-text-input{width:100%;padding:.9rem 1rem;border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;font-family:Nunito,sans-serif;margin-bottom:1.5rem;box-sizing:border-box}.play-text-input:focus{outline:none;border-color:#6c63ff}.play-hint-area{margin-bottom:1.25rem}.play-hint-btn{background:none;border:none;color:#6c63ff;font-weight:600;cursor:pointer;font-size:.9rem;font-family:Nunito,sans-serif}.play-hint{background:#fef3c7;padding:.75rem 1rem;border-radius:10px;font-size:.9rem;color:#92400e;margin:0}.play-next-btn{width:100%;padding:.9rem;border:none;border-radius:14px;color:#fff;font-size:1rem;font-weight:800;font-family:Nunito,sans-serif;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 4px 16px #00000026}.play-next-btn:hover:not(:disabled){transform:translateY(-2px) scale(1.02);box-shadow:0 8px 24px #0003}.play-next-btn:active:not(:disabled){transform:translateY(0) scale(.98)}.play-next-btn:disabled{opacity:.5;cursor:not-allowed}.play-results{width:100%;max-width:640px}.play-results-header{text-align:center;margin-bottom:2rem}.play-results-emoji{font-size:4.5rem;display:block;margin-bottom:.5rem;animation:resultEmojiPop .5s cubic-bezier(.34,1.56,.64,1)}@keyframes resultEmojiPop{0%{transform:scale(0);opacity:0}60%{transform:scale(1.3)}to{transform:scale(1);opacity:1}}.play-results-header h1{font-family:Fredoka,sans-serif;font-size:2rem;color:#1f2937;margin:0 0 .5rem}.play-results-score{font-size:1.2rem;font-weight:700;color:#374151}.play-results-xp{font-size:1.1rem;font-weight:800;color:#00c9a7;margin-top:.25rem}.play-results-pct{font-family:Fredoka,sans-serif;font-size:3rem;font-weight:700;margin-top:.5rem}.play-results-breakdown{background:#ffffffd9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:24px;padding:2rem;box-shadow:0 8px 40px #6c63ff14,0 2px 8px #0000000a;border:1px solid rgba(255,255,255,.6);margin-bottom:2rem}.play-results-breakdown h3{font-family:Fredoka,sans-serif;margin:0 0 1.25rem;color:#1f2937}.play-result-row{display:flex;gap:.75rem;padding:1rem;border-radius:12px;margin-bottom:.75rem}.play-result-row.correct{background:#f0fdf4}.play-result-row.incorrect{background:#fef2f2}.play-result-icon{font-size:1.2rem;flex-shrink:0;margin-top:2px}.play-result-details{flex:1}.play-result-answer{font-size:.95rem;color:#374151;margin-bottom:.3rem}.play-result-correct{color:#dc2626}.play-result-explanation{font-size:.85rem;color:#6b7280;line-height:1.5}.play-result-funfact{font-size:.82rem;color:#845ec2;background:#f5f3ff;padding:.5rem .75rem;border-radius:8px;margin-top:.4rem;line-height:1.4}.play-encouragement{background:linear-gradient(135deg,#f0effe,#e8faf5);border-radius:14px;padding:1.25rem 1.5rem;margin-bottom:1.5rem;font-size:1rem;color:#374151;line-height:1.6;font-weight:600;text-align:center}.play-results-actions{display:flex;gap:1rem;justify-content:center}.play-btn-outline{padding:.8rem 1.5rem;border:2px solid rgba(229,231,235,.8);border-radius:14px;background:#fffc;font-weight:700;font-size:1rem;font-family:Nunito,sans-serif;cursor:pointer;color:#374151;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.play-btn-outline:hover{border-color:#6c63ff;transform:translateY(-2px);box-shadow:0 6px 20px #6c63ff1a}.play-btn-outline:active{transform:translateY(0) scale(.98)}.ws-container{width:100%;max-width:900px}.ws-clues{background:#ffffffd9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:20px;padding:1.5rem;box-shadow:0 8px 32px #6c63ff0f,0 2px 8px #00000008;border:1px solid rgba(255,255,255,.6);margin-bottom:1.5rem}.ws-clues h3{font-family:Fredoka,sans-serif;margin:0 0 1rem;color:#1f2937}.ws-clue{display:flex;align-items:flex-start;gap:.6rem;padding:.6rem .75rem;border-radius:10px;margin-bottom:.4rem;transition:all .3s}.ws-clue.found{background:#f0fdf4;text-decoration:line-through;opacity:.7}.ws-clue-status{font-size:1.1rem;flex-shrink:0}.ws-clue-text{font-size:.95rem;font-weight:600;color:#374151}.ws-clue-hint{font-size:.8rem;color:#9ca3af;margin-top:2px}.ws-found-count{text-align:center;font-weight:800;color:#6c63ff;margin-top:.75rem;font-size:1rem}.ws-grid-wrapper{margin-bottom:1.5rem}.ws-grid{display:grid;gap:3px;max-width:500px;margin:0 auto;-moz-user-select:none;user-select:none;-webkit-user-select:none}.ws-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:#ffffffe6;border:2px solid rgba(229,231,235,.6);border-radius:8px;font-weight:800;font-size:.85rem;font-family:Fredoka,sans-serif;color:#374151;cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1)}.ws-cell:hover{background:#f0effe;transform:scale(1.08);box-shadow:0 3px 12px #6c63ff26}.ws-cell.selecting{transform:scale(1.15);z-index:2;box-shadow:0 4px 16px #6c63ff40}.ws-cell.found{font-weight:900;color:#047857;background:#ecfdf5}.ws-instructions{text-align:center;color:#9ca3af;font-size:.85rem;margin-top:.75rem}.ws-finish{max-width:400px;margin:0 auto;display:block}.match-container{width:100%;max-width:800px}.match-instructions{text-align:center;margin-bottom:1.5rem}.match-instructions p{color:#6b7280;margin:0 0 .5rem}.match-progress{font-weight:800;color:#6c63ff;font-size:1rem}.match-board{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.5rem}.match-column{flex:1;display:flex;flex-direction:column;gap:.6rem}.match-column-title{font-family:Fredoka,sans-serif;font-size:.9rem;color:#9ca3af;text-align:center;margin:0 0 .25rem;text-transform:uppercase;letter-spacing:.05em}.match-divider{display:flex;align-items:center;padding-top:2rem}.match-divider-line{width:2px;height:100%;min-height:200px;background:#e5e7eb;border-radius:1px}.match-card{padding:.85rem 1rem;border:2px solid rgba(229,231,235,.7);border-radius:14px;background:#ffffffd9;cursor:pointer;transition:all .25s cubic-bezier(.34,1.56,.64,1);font-size:.95rem;font-weight:600;color:#374151;text-align:center;box-shadow:0 2px 8px #0000000a}.match-card:hover:not(.matched):not(.used){transform:translateY(-3px);box-shadow:0 8px 24px #6c63ff26;border-color:#6c63ff4d}.match-card.selected{transform:scale(1.04) translateY(-2px);box-shadow:0 8px 28px #6c63ff33}.match-card.matched{cursor:pointer}.match-card.used{cursor:default}.match-card-text{display:block}.match-card-pair{display:block;font-size:.8rem;color:#059669;margin-top:.3rem;font-weight:700}.match-finish{max-width:400px;margin:0 auto;display:block}.scram-container{width:100%;max-width:600px}.scram-progress{text-align:center;font-size:.9rem;color:#6b7280;font-weight:600;margin-bottom:1rem}.scram-card{background:#ffffffe0;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:24px;padding:2rem;box-shadow:0 8px 40px #6c63ff14,0 2px 8px #0000000a;border:1px solid rgba(255,255,255,.6);animation:cardAppear .4s cubic-bezier(.34,1.56,.64,1)}.scram-prompt{font-size:1.1rem;font-weight:700;color:#1f2937;text-align:center;margin-bottom:1.5rem;line-height:1.5}.scram-answer-area{margin-bottom:1.5rem;text-align:center}.scram-answer-slots{display:flex;gap:6px;justify-content:center;flex-wrap:wrap;margin-bottom:.75rem}.scram-slot{width:44px;height:50px;border:2px dashed rgba(209,213,219,.8);border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:Fredoka,sans-serif;font-size:1.2rem;font-weight:700;color:#374151;transition:all .25s cubic-bezier(.34,1.56,.64,1);background:#ffffff80}.scram-slot.filled{border-style:solid;background:#ffffffe6;box-shadow:0 2px 8px #0000000f;transform:scale(1.05)}.scram-clear-btn{background:none;border:none;color:#dc2626;font-weight:700;font-size:.85rem;cursor:pointer;font-family:Nunito,sans-serif}.scram-letter-pool{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:1.5rem}.scram-letter{width:50px;height:54px;border:3px solid;border-radius:14px;background:#ffffffe6;font-family:Fredoka,sans-serif;font-size:1.3rem;font-weight:800;cursor:pointer;transition:all .25s cubic-bezier(.34,1.56,.64,1);display:flex;align-items:center;justify-content:center;box-shadow:0 3px 10px #0000000f}.scram-letter:hover:not(.used){transform:translateY(-4px) scale(1.08);box-shadow:0 8px 20px #6c63ff33}.scram-letter:active:not(.used){transform:translateY(0) scale(.95)}.scram-letter.used{opacity:.2;cursor:default;transform:scale(.85)}.scram-hint-area{margin-bottom:1.25rem}.scram-hint-btn{background:none;border:none;color:#6c63ff;font-weight:600;cursor:pointer;font-size:.9rem;font-family:Nunito,sans-serif}.scram-hint{background:#fef3c7;padding:.6rem .8rem;border-radius:8px;font-size:.85rem;color:#92400e;margin:0}.fib-container{width:100%;max-width:600px}.fib-progress{text-align:center;font-size:.9rem;color:#6b7280;font-weight:600;margin-bottom:1rem}.fib-card{background:#ffffffe0;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:24px;padding:2rem;box-shadow:0 8px 40px #6c63ff14,0 2px 8px #0000000a;border:1px solid rgba(255,255,255,.6);animation:cardAppear .4s cubic-bezier(.34,1.56,.64,1)}.fib-sentence{font-size:1.2rem;font-weight:600;color:#374151;line-height:1.8;text-align:center;margin-bottom:1.5rem}.fib-blank{display:inline-block;min-width:100px;padding:2px 12px;border-bottom:3px dashed #d1d5db;font-weight:800;transition:all .3s;margin:0 4px}.fib-blank.filled{border-bottom-style:solid;border-radius:6px;padding:4px 14px}.fib-word-bank{margin-bottom:1.5rem}.fib-word-bank h4{font-family:Fredoka,sans-serif;font-size:.9rem;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .75rem;text-align:center}.fib-words{display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap}.fib-word{padding:.6rem 1.2rem;border:2px solid rgba(229,231,235,.7);border-radius:30px;background:#ffffffd9;font-size:1rem;font-weight:700;font-family:Nunito,sans-serif;cursor:pointer;transition:all .25s cubic-bezier(.34,1.56,.64,1);color:#374151;box-shadow:0 2px 8px #0000000a}.fib-word:hover:not(.selected){border-color:#6c63ff;transform:translateY(-3px);box-shadow:0 6px 20px #6c63ff26}.fib-word.selected{transform:scale(1.08);box-shadow:0 4px 16px #6c63ff33}.fib-hint-area{margin-bottom:1.25rem}.cw-container{width:100%;max-width:700px}.cw-instructions{text-align:center;margin-bottom:1.5rem}.cw-instructions p{color:#6b7280;margin:0 0 .5rem}.cw-progress{font-weight:800;color:#6c63ff;font-size:1rem}.cw-clues-grid{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.cw-clue-card{display:flex;gap:.75rem;align-items:flex-start;padding:1rem 1.25rem;border:2px solid rgba(229,231,235,.7);border-radius:16px;background:#ffffffd9;cursor:pointer;transition:all .25s cubic-bezier(.34,1.56,.64,1);box-shadow:0 2px 8px #0000000a}.cw-clue-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6c63ff1a;border-color:#6c63ff33}.cw-clue-card.active{transform:translateY(-2px);box-shadow:0 8px 24px #6c63ff26}.cw-clue-card.answered{background:#f0fdf4cc}.cw-clue-number{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:8px;color:#fff;font-weight:800;font-size:.8rem;flex-shrink:0}.cw-clue-content{flex:1}.cw-clue-text{font-size:.95rem;font-weight:600;color:#374151;margin:0 0 .5rem;line-height:1.4}.cw-answer-row{display:flex;align-items:center;gap:.5rem}.cw-answer-input{flex:1;padding:.5rem .75rem;border:2px solid #e5e7eb;border-radius:8px;font-size:.95rem;font-family:Nunito,sans-serif;font-weight:600;transition:border-color .2s}.cw-answer-input:focus{outline:none;border-color:#6c63ff}.cw-check{color:#059669;font-weight:800;font-size:1.1rem}.cw-points{font-size:.8rem;color:#9ca3af;font-weight:600;flex-shrink:0}.cw-hint-area{margin-top:.4rem}.cw-hint-btn{background:none;border:none;color:#6c63ff;font-weight:600;cursor:pointer;font-size:.8rem;font-family:Nunito,sans-serif;padding:0}.cw-hint{background:#fef3c7;padding:.4rem .6rem;border-radius:6px;font-size:.8rem;color:#92400e;margin:.3rem 0 0}.cw-finish{max-width:400px;margin:0 auto;display:block}.trivia-container{width:100%;max-width:600px}.trivia-progress-bar{width:100%;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;margin-bottom:.5rem}.trivia-progress-fill{height:100%;border-radius:4px;transition:width .3s}.trivia-progress-text{font-size:.85rem;color:#6b7280;text-align:center;margin-bottom:1.5rem}.trivia-card{background:#ffffffe0;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:24px;padding:2rem;box-shadow:0 8px 40px #6c63ff14,0 2px 8px #0000000a;border:1px solid rgba(255,255,255,.6);position:relative;transition:all .3s}.trivia-card.enter{animation:slideIn .3s ease-out}.trivia-card.exit{animation:slideOut .2s ease-in}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes slideOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-20px)}}.trivia-q-badge{display:inline-block;color:#fff;font-weight:800;font-size:.85rem;padding:.3rem .8rem;border-radius:8px;margin-bottom:1rem}.trivia-prompt{font-size:1.15rem;font-weight:600;color:#1f2937;line-height:1.6;margin:0 0 .5rem}.trivia-points{font-size:.8rem;color:#9ca3af;margin-bottom:1.25rem}.trivia-options{display:flex;flex-direction:column;gap:.65rem;margin-bottom:1.5rem}.trivia-option{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;border:2px solid rgba(229,231,235,.7);border-radius:14px;background:#ffffffb3;text-align:left;font-size:1rem;font-family:Nunito,sans-serif;cursor:pointer;transition:all .25s cubic-bezier(.34,1.56,.64,1);font-weight:500}.trivia-option:hover{border-color:#6c63ff;background:#f8f7ff;transform:translate(6px);box-shadow:0 4px 16px #6c63ff1f}.trivia-option.selected{font-weight:700;transform:translate(4px);box-shadow:0 4px 12px #6c63ff1a}.trivia-option-letter{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:#f3f4f6;font-weight:800;font-size:.9rem;color:#6b7280;flex-shrink:0;transition:all .2s}.trivia-option-text{flex:1}.trivia-hint-area{margin-bottom:1.25rem}@media(max-width:768px){.play-container{padding:1rem;align-items:flex-start}.play-category-grid{grid-template-columns:repeat(2,1fr)}.play-difficulty-row,.play-results-actions{flex-direction:column}.play-game{max-width:100%}.match-board{flex-direction:column}.match-divider{display:none}.ws-grid{max-width:100%}.ws-cell{font-size:.7rem}.scram-letter{width:40px;height:44px;font-size:1.1rem}.scram-slot{width:36px;height:42px;font-size:1rem}}.jp-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#f8f7ff,#f0f9ff,#f0fdf4);font-family:Nunito,sans-serif}.jp-card{background:#ffffffe0;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:28px;padding:3rem;box-shadow:0 12px 48px #6c63ff14,0 4px 12px #0000000a;border:1px solid rgba(255,255,255,.6);text-align:center;max-width:500px}.jp-loading{display:flex;flex-direction:column;align-items:center;gap:1rem}.jp-spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top-color:#6c63ff;border-radius:50%;animation:jp-spin .8s linear infinite}.jp-spinner-sm{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:jp-spin .8s linear infinite;display:inline-block}@keyframes jp-spin{to{transform:rotate(360deg)}}.jp-narrative-wrapper{max-width:640px;width:100%;text-align:center}.jp-chapter-badge{display:inline-block;background:linear-gradient(135deg,#6c63ff,#845ec2);color:#fff;padding:.4rem 1.2rem;border-radius:20px;font-weight:800;font-size:.85rem;letter-spacing:.03em;margin-bottom:1rem}.jp-chapter-title{font-family:Fredoka,sans-serif;font-size:2rem;color:#1f2937;margin:0 0 .5rem;line-height:1.3}.jp-journey-title{color:#6b7280;font-size:.95rem;font-weight:600;margin-bottom:2rem}.jp-narrative-card{background:#ffffffe0;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:28px;padding:2.5rem 2rem;box-shadow:0 12px 48px #6c63ff1a,0 4px 12px #0000000a;border:1px solid rgba(255,255,255,.6);margin-bottom:1.5rem;text-align:left;position:relative;overflow:hidden;animation:jpCardAppear .5s cubic-bezier(.34,1.56,.64,1)}@keyframes jpCardAppear{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.jp-narrative-card:before{content:"📖";position:absolute;top:1.2rem;right:1.5rem;font-size:1.5rem;opacity:.3}.jp-narrative-text{font-size:1.15rem;line-height:1.8;color:#374151}.jp-narrative-sentence{opacity:0;transition:opacity .6s ease-in}.jp-narrative-sentence.visible{opacity:1}.jp-btn-text{background:none;border:none;color:#6c63ff;font-weight:700;font-size:.95rem;cursor:pointer;font-family:Nunito,sans-serif;margin-top:1rem;padding:.5rem 1rem;border-radius:8px;transition:background .2s}.jp-btn-text:hover{background:#f3f2ff}.jp-goals{background:#ffffffd9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:20px;padding:1.5rem 2rem;box-shadow:0 8px 32px #6c63ff0f,0 2px 8px #00000008;border:1px solid rgba(255,255,255,.5);margin-bottom:1.5rem;text-align:left}.jp-goals h3{font-family:Fredoka,sans-serif;color:#1f2937;margin:0 0 .75rem;font-size:1.05rem}.jp-goals ul{list-style:none;padding:0;margin:0}.jp-goals li{padding:.4rem 0;font-size:.95rem;color:#374151;display:flex;align-items:center;gap:.5rem}.jp-goals li:before{content:"🎯";font-size:.85rem}.jp-game-preview{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:1.5rem}.jp-game-type-badge{display:inline-flex;align-items:center;gap:.4rem;color:#fff;padding:.4rem 1rem;border-radius:12px;font-weight:800;font-size:.85rem}.jp-game-desc{color:#6b7280;font-size:.9rem;margin:0;text-align:center}.jp-btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.9rem 2rem;border:none;border-radius:16px;color:#fff;font-size:1.1rem;font-weight:800;font-family:Nunito,sans-serif;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);min-width:200px;box-shadow:0 6px 20px #00000026}.jp-btn-primary:hover:not(:disabled){transform:translateY(-3px) scale(1.03);box-shadow:0 10px 32px #0003}.jp-btn-primary:active:not(:disabled){transform:translateY(0) scale(.98)}.jp-btn-primary:disabled{opacity:.6;cursor:not-allowed}.jp-btn-start{width:100%;max-width:360px}.jp-btn-loading{display:flex;align-items:center;gap:.75rem}.jp-btn-secondary{padding:.7rem 1.5rem;border:2px solid #e5e7eb;border-radius:12px;background:#fff;font-weight:700;font-size:.95rem;font-family:Nunito,sans-serif;cursor:pointer;color:#374151}.jp-error{color:#dc2626;font-size:.9rem;margin-top:.75rem}.jp-playing-wrapper{max-width:900px;width:100%}.jp-playing-header{text-align:center;margin-bottom:2rem}.jp-playing-header-row{display:flex;align-items:center;justify-content:center;gap:.75rem;position:relative;margin-bottom:.75rem}.jp-mute-btn{position:absolute;right:0;top:50%;transform:translateY(-50%);background:#fffc;border:2px solid rgba(229,231,235,.7);border-radius:10px;padding:.4rem;cursor:pointer;color:#6b7280;display:flex;align-items:center;justify-content:center;transition:all .2s}.jp-mute-btn:hover{border-color:#6c63ff;color:#6c63ff;background:#f8f7ff}.jp-chapter-badge-sm{display:inline-block;background:#f3f4f6;color:#6b7280;padding:.3rem .8rem;border-radius:8px;font-weight:700;font-size:.8rem}.jp-playing-title{font-family:Fredoka,sans-serif;font-size:1.4rem;color:#1f2937;margin:0 0 .5rem}.jp-playing-instructions{color:#6b7280;font-size:.95rem;margin:0}.jp-reflection-wrapper{max-width:560px;width:100%;text-align:center}.jp-reflection-score{margin-bottom:1.5rem}.jp-score-emoji{font-size:3.5rem;margin-bottom:.5rem;animation:jpEmojiPop .5s cubic-bezier(.34,1.56,.64,1)}@keyframes jpEmojiPop{0%{transform:scale(0);opacity:0}60%{transform:scale(1.3)}to{transform:scale(1);opacity:1}}.jp-score-text{font-size:1.2rem;color:#374151;font-weight:600}.jp-score-xp{font-size:1.1rem;font-weight:800;margin-top:.25rem}.jp-encouragement{background:linear-gradient(135deg,#f0effe,#e8faf5);border-radius:14px;padding:1rem 1.5rem;margin-bottom:1.5rem;font-size:1rem;color:#374151;line-height:1.6;font-weight:600}.jp-reflection-card{background:#ffffffe0;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:24px;padding:2rem;box-shadow:0 12px 48px #6c63ff14,0 4px 12px #0000000a;border:1px solid rgba(255,255,255,.6);text-align:left;animation:jpCardAppear .5s cubic-bezier(.34,1.56,.64,1)}.jp-reflection-card h3{font-family:Fredoka,sans-serif;color:#1f2937;margin:0 0 .75rem}.jp-reflection-question{font-size:1.1rem;font-weight:600;color:#374151;line-height:1.6;margin:0 0 1rem}.jp-reflection-input{width:100%;padding:.8rem 1rem;border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;font-family:Nunito,sans-serif;resize:vertical;margin-bottom:1rem;box-sizing:border-box;transition:border-color .2s}.jp-reflection-input:focus{outline:none;border-color:#6c63ff}.jp-results-wrapper{max-width:640px;width:100%}.jp-results-header{text-align:center;margin-bottom:2rem}.jp-results-header h1{font-family:Fredoka,sans-serif;font-size:1.6rem;color:#1f2937;margin:.5rem 0 0}.jp-results-breakdown{background:#ffffffd9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:24px;padding:2rem;box-shadow:0 12px 48px #6c63ff14,0 4px 12px #0000000a;border:1px solid rgba(255,255,255,.6);margin-bottom:2rem}.jp-results-breakdown h3{font-family:Fredoka,sans-serif;margin:0 0 1.25rem;color:#1f2937}.jp-result-row{display:flex;gap:.75rem;padding:.75rem;border-radius:12px;margin-bottom:.5rem}.jp-result-row.correct{background:#f0fdf4}.jp-result-row.incorrect{background:#fffbeb}.jp-result-icon{font-size:1.1rem;flex-shrink:0}.jp-result-content{flex:1}.jp-correct-label{color:#059669;font-weight:700;font-size:.9rem}.jp-incorrect-label{color:#92400e;font-size:.9rem}.jp-result-explanation{font-size:.85rem;color:#6b7280;line-height:1.5;margin-top:.25rem}.jp-result-funfact{font-size:.82rem;color:#845ec2;background:#f5f3ff;padding:.5rem .75rem;border-radius:8px;margin-top:.4rem;line-height:1.4}.jp-btn-continue{width:100%;max-width:400px;display:block;margin:0 auto}.jp-complete{max-width:500px;text-align:center}.jp-complete-icon{font-size:5.5rem;margin-bottom:1rem;animation:jpEmojiPop .6s cubic-bezier(.34,1.56,.64,1)}.jp-complete h1{font-family:Fredoka,sans-serif;font-size:2.5rem;color:#1f2937;margin:0 0 .5rem}.jp-complete h2{font-family:Fredoka,sans-serif;font-size:1.2rem;color:#6c63ff;margin:0 0 1rem;font-weight:600}.jp-complete-text{color:#6b7280;font-size:1rem;line-height:1.6;margin-bottom:1.5rem}.jp-complete-stats{display:flex;justify-content:center;gap:2rem;margin-bottom:2rem}.jp-stat{display:flex;flex-direction:column;align-items:center}.jp-stat-value{font-family:Fredoka,sans-serif;font-size:2rem;font-weight:700;color:#6c63ff}.jp-stat-label{font-size:.85rem;color:#9ca3af;font-weight:600}@media(max-width:768px){.jp-container{padding:1rem;align-items:flex-start}.jp-chapter-title{font-size:1.5rem}.jp-narrative-card{padding:1.5rem 1.25rem}.jp-playing-wrapper{max-width:100%}}.auth-container{min-height:100vh;display:flex;font-family:Nunito,sans-serif}.auth-left{flex:1;background:linear-gradient(160deg,#6c63ff,#845ec2 40%,#5b4ae0);display:flex;align-items:center;justify-content:center;padding:3rem;position:relative;overflow:hidden}.auth-left:before{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:#ffffff0f;top:-80px;right:-80px}.auth-left:after{content:"";position:absolute;width:300px;height:300px;border-radius:50%;background:#ffffff0a;bottom:-60px;left:-60px}.auth-left-content{position:relative;z-index:1;max-width:440px;color:#fff}.auth-hero-brain{height:240px;margin-bottom:-1.5rem;margin-left:-2rem;animation:authBrainFloat 3s ease-in-out infinite;filter:drop-shadow(0 8px 24px rgba(0,0,0,.3))}@keyframes authBrainFloat{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-10px) rotate(3deg)}}.auth-hero-title{font-family:Fredoka,sans-serif;font-size:2.4rem;font-weight:700;line-height:1.2;margin:0 0 1rem;color:#fff}.auth-hero-desc{font-size:1.1rem;opacity:.85;line-height:1.6;margin:0 0 2.5rem}.auth-hero-features{display:flex;flex-direction:column;gap:.9rem}.auth-hero-feature{display:flex;align-items:center;gap:.75rem;font-size:1rem;font-weight:600;background:#ffffff1f;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:.7rem 1.2rem;border-radius:14px;border:1px solid rgba(255,255,255,.15);transition:all .3s cubic-bezier(.34,1.56,.64,1)}.auth-hero-feature:hover{background:#ffffff2e;transform:translate(6px)}.auth-hero-feature span:first-child{font-size:1.3rem}.auth-right{flex:1;display:flex;align-items:center;justify-content:center;padding:3rem 2rem;background:linear-gradient(160deg,#f8f7ff,#f0f5ff,#f0fdf4)}.auth-card{width:100%;max-width:420px;background:#ffffff8c;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-radius:28px;padding:2.5rem;box-shadow:0 16px 60px #6c63ff14,0 4px 16px #00000008;border:1px solid rgba(255,255,255,.45);animation:authCardAppear .5s cubic-bezier(.34,1.56,.64,1)}@keyframes authCardAppear{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.auth-card-header{text-align:center;margin-bottom:1.5rem}.auth-card-logo{height:64px;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);margin-bottom:1rem}.auth-card-logo:hover{transform:scale(1.08)}.auth-card h2{font-family:Fredoka,sans-serif;font-size:1.6rem;color:#1f2937;margin:0 0 .25rem}.auth-subtitle{color:#6b7280;margin:0;font-size:.95rem}.auth-form{text-align:left}.auth-field{margin-bottom:1.1rem}.auth-field label{display:block;font-weight:700;font-size:.9rem;color:#374151;margin-bottom:.35rem}.auth-field input{width:100%;padding:.75rem 1rem;border:2px solid rgba(229,231,235,.5);border-radius:14px;font-size:1rem;font-family:Nunito,sans-serif;transition:all .25s cubic-bezier(.34,1.56,.64,1);box-sizing:border-box;background:#ffffff80}.auth-field input:focus{outline:none;border-color:#6c63ff;box-shadow:0 0 0 4px #6c63ff1a;background:#fffc}.auth-error{color:#dc2626;font-size:.85rem;margin:0 0 .75rem;padding:.5rem .75rem;background:#fef2f2;border-radius:10px}.auth-btn{width:100%;padding:.85rem;border:none;border-radius:16px;background:linear-gradient(135deg,#6c63ff,#845ec2);color:#fff;font-size:1.05rem;font-weight:800;font-family:Nunito,sans-serif;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);margin-top:.5rem;box-shadow:0 6px 20px #6c63ff40}.auth-btn:hover:not(:disabled){transform:translateY(-2px) scale(1.02);box-shadow:0 10px 32px #6c63ff59}.auth-btn:active:not(:disabled){transform:translateY(0) scale(.98)}.auth-btn:disabled{opacity:.6;cursor:not-allowed}.auth-switch{margin-top:1.5rem;font-size:.9rem;color:#6b7280;text-align:center}.auth-switch a{color:#6c63ff;font-weight:700;text-decoration:none;transition:color .2s}.auth-switch a:hover{text-decoration:underline;color:#5a52e0}@media(max-width:900px){.auth-container{flex-direction:column}.auth-left{padding:2rem 1.5rem;min-height:auto}.auth-hero-brain{height:160px;margin-bottom:1rem}.auth-hero-title{font-size:1.6rem}.auth-hero-desc{margin-bottom:1.5rem}.auth-hero-features{gap:.5rem}.auth-hero-feature{font-size:.9rem;padding:.5rem .9rem}.auth-right{padding:2rem 1rem}.auth-card{padding:2rem 1.5rem}}@media(max-width:480px){.auth-left{padding:1.5rem 1rem}.auth-hero-title{font-size:1.4rem}.auth-hero-features{display:none}}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Nunito,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--font-mono);font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}*{--tw-border-opacity: 1;border-color:hsl(var(--border) / var(--tw-border-opacity, 1))}body{--tw-bg-opacity: 1;background-color:hsl(var(--background) / var(--tw-bg-opacity, 1));font-family:Nunito,sans-serif;--tw-text-opacity: 1;color:hsl(var(--foreground) / var(--tw-text-opacity, 1));-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.\!visible{visibility:visible!important}.visible{visibility:visible}.invisible{visibility:hidden}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.inset-x-0{left:0;right:0}.inset-y-0{top:0;bottom:0}.-bottom-12{bottom:-3rem}.-left-12{left:-3rem}.-right-12{right:-3rem}.-top-12{top:-3rem}.bottom-0{bottom:0}.left-0{left:0}.left-1{left:.25rem}.left-1\/2{left:50%}.left-2{left:.5rem}.left-\[50\%\]{left:50%}.right-0{right:0}.right-1{right:.25rem}.right-2{right:.5rem}.right-3{right:.75rem}.right-4{right:1rem}.top-0{top:0}.top-1\.5{top:.375rem}.top-1\/2{top:50%}.top-2{top:.5rem}.top-3\.5{top:.875rem}.top-4{top:1rem}.top-\[1px\]{top:1px}.top-\[50\%\]{top:50%}.top-\[60\%\]{top:60%}.top-full{top:100%}.z-10{z-index:10}.z-20{z-index:20}.z-50{z-index:50}.z-\[100\]{z-index:100}.z-\[1\]{z-index:1}.-mx-1{margin-left:-.25rem;margin-right:-.25rem}.mx-2{margin-left:.5rem;margin-right:.5rem}.mx-3\.5{margin-left:.875rem;margin-right:.875rem}.mx-4{margin-left:1rem;margin-right:1rem}.mx-auto{margin-left:auto;margin-right:auto}.my-0\.5{margin-top:.125rem;margin-bottom:.125rem}.my-1{margin-top:.25rem;margin-bottom:.25rem}.-ml-4{margin-left:-1rem}.-mt-4{margin-top:-1rem}.mb-1{margin-bottom:.25rem}.mb-4{margin-bottom:1rem}.ml-1{margin-left:.25rem}.ml-auto{margin-left:auto}.mr-2{margin-right:.5rem}.mt-1\.5{margin-top:.375rem}.mt-2{margin-top:.5rem}.mt-24{margin-top:6rem}.mt-4{margin-top:1rem}.mt-auto{margin-top:auto}.block{display:block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.aspect-square{aspect-ratio:1 / 1}.aspect-video{aspect-ratio:16 / 9}.size-4{width:1rem;height:1rem}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-12{height:3rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-7{height:1.75rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[1px\]{height:1px}.h-\[var\(--radix-navigation-menu-viewport-height\)\]{height:var(--radix-navigation-menu-viewport-height)}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-auto{height:auto}.h-full{height:100%}.h-px{height:1px}.h-svh{height:100svh}.max-h-\[--radix-context-menu-content-available-height\]{max-height:var(--radix-context-menu-content-available-height)}.max-h-\[--radix-select-content-available-height\]{max-height:var(--radix-select-content-available-height)}.max-h-\[300px\]{max-height:300px}.max-h-\[var\(--radix-dropdown-menu-content-available-height\)\]{max-height:var(--radix-dropdown-menu-content-available-height)}.max-h-screen{max-height:100vh}.min-h-0{min-height:0px}.min-h-10{min-height:2.5rem}.min-h-8{min-height:2rem}.min-h-9{min-height:2.25rem}.min-h-\[80px\]{min-height:80px}.min-h-screen{min-height:100vh}.min-h-svh{min-height:100svh}.w-0{width:0px}.w-1{width:.25rem}.w-10{width:2.5rem}.w-11{width:2.75rem}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-3\/4{width:75%}.w-4{width:1rem}.w-5{width:1.25rem}.w-64{width:16rem}.w-7{width:1.75rem}.w-72{width:18rem}.w-8{width:2rem}.w-9{width:2.25rem}.w-\[100px\]{width:100px}.w-\[1px\]{width:1px}.w-\[var\(--sidebar-width\)\]{width:var(--sidebar-width)}.w-auto{width:auto}.w-full{width:100%}.w-max{width:-moz-max-content;width:max-content}.w-px{width:1px}.min-w-0{min-width:0px}.min-w-10{min-width:2.5rem}.min-w-11{min-width:2.75rem}.min-w-5{min-width:1.25rem}.min-w-9{min-width:2.25rem}.min-w-\[12rem\]{min-width:12rem}.min-w-\[8rem\]{min-width:8rem}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.max-w-\[var\(--skeleton-width\)\]{max-width:var(--skeleton-width)}.max-w-lg{max-width:32rem}.max-w-max{max-width:-moz-max-content;max-width:max-content}.max-w-md{max-width:28rem}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.grow{flex-grow:1}.grow-0{flex-grow:0}.basis-full{flex-basis:100%}.caption-bottom{caption-side:bottom}.border-collapse{border-collapse:collapse}.origin-\[--radix-context-menu-content-transform-origin\]{transform-origin:var(--radix-context-menu-content-transform-origin)}.origin-\[--radix-dropdown-menu-content-transform-origin\]{transform-origin:var(--radix-dropdown-menu-content-transform-origin)}.origin-\[--radix-hover-card-content-transform-origin\]{transform-origin:var(--radix-hover-card-content-transform-origin)}.origin-\[--radix-menubar-content-transform-origin\]{transform-origin:var(--radix-menubar-content-transform-origin)}.origin-\[--radix-popover-content-transform-origin\]{transform-origin:var(--radix-popover-content-transform-origin)}.origin-\[--radix-select-content-transform-origin\]{transform-origin:var(--radix-select-content-transform-origin)}.origin-\[--radix-tooltip-content-transform-origin\]{transform-origin:var(--radix-tooltip-content-transform-origin)}.-translate-x-1\/2{--tw-translate-x: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-x-px{--tw-translate-x: -1px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-\[-50\%\]{--tw-translate-x: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-px{--tw-translate-x: 1px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-\[-50\%\]{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rotate-45{--tw-rotate: 45deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rotate-90{--tw-rotate: 90deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.touch-none{touch-action:none}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.resize{resize:both}.list-none{list-style-type:none}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.items-stretch{align-items:stretch}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-4{gap:1rem}.space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.25rem * var(--tw-space-x-reverse));margin-left:calc(.25rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(1rem * var(--tw-space-x-reverse));margin-left:calc(1rem * calc(1 - var(--tw-space-x-reverse)))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.375rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.375rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.whitespace-nowrap{white-space:nowrap}.break-words{overflow-wrap:break-word}.rounded-\[2px\]{border-radius:2px}.rounded-\[inherit\]{border-radius:inherit}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5625rem}.rounded-md{border-radius:.375rem}.rounded-sm{border-radius:.1875rem}.rounded-xl{border-radius:.75rem}.rounded-t-\[10px\]{border-top-left-radius:10px;border-top-right-radius:10px}.rounded-tl-sm{border-top-left-radius:.1875rem}.border{border-width:1px}.border-2{border-width:2px}.border-\[1\.5px\]{border-width:1.5px}.border-y{border-top-width:1px;border-bottom-width:1px}.border-b{border-bottom-width:1px}.border-l{border-left-width:1px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-\[--color-border\]{border-color:var(--color-border)}.border-border\/50{border-color:hsl(var(--border) / .5)}.border-card-border{--tw-border-opacity: 1;border-color:hsl(var(--card-border) / var(--tw-border-opacity, 1))}.border-destructive{--tw-border-opacity: 1;border-color:hsl(var(--destructive) / var(--tw-border-opacity, 1))}.border-destructive-border{border-color:var(--destructive-border)}.border-destructive\/50{border-color:hsl(var(--destructive) / .5)}.border-input{--tw-border-opacity: 1;border-color:hsl(var(--input) / var(--tw-border-opacity, 1))}.border-primary{--tw-border-opacity: 1;border-color:hsl(var(--primary) / var(--tw-border-opacity, 1))}.border-primary-border{border-color:var(--primary-border)}.border-secondary-border{border-color:var(--secondary-border)}.border-sidebar-border{--tw-border-opacity: 1;border-color:hsl(var(--sidebar-border) / var(--tw-border-opacity, 1))}.border-transparent{border-color:transparent}.border-l-transparent{border-left-color:transparent}.border-t-transparent{border-top-color:transparent}.bg-\[--color-bg\]{background-color:var(--color-bg)}.bg-accent{--tw-bg-opacity: 1;background-color:hsl(var(--accent) / var(--tw-bg-opacity, 1))}.bg-background{--tw-bg-opacity: 1;background-color:hsl(var(--background) / var(--tw-bg-opacity, 1))}.bg-black\/80{background-color:#000c}.bg-border{--tw-bg-opacity: 1;background-color:hsl(var(--border) / var(--tw-bg-opacity, 1))}.bg-card{--tw-bg-opacity: 1;background-color:hsl(var(--card) / var(--tw-bg-opacity, 1))}.bg-destructive{--tw-bg-opacity: 1;background-color:hsl(var(--destructive) / var(--tw-bg-opacity, 1))}.bg-foreground{--tw-bg-opacity: 1;background-color:hsl(var(--foreground) / var(--tw-bg-opacity, 1))}.bg-gray-50{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.bg-muted{--tw-bg-opacity: 1;background-color:hsl(var(--muted) / var(--tw-bg-opacity, 1))}.bg-muted\/50{background-color:hsl(var(--muted) / .5)}.bg-popover{--tw-bg-opacity: 1;background-color:hsl(var(--popover) / var(--tw-bg-opacity, 1))}.bg-primary{--tw-bg-opacity: 1;background-color:hsl(var(--primary) / var(--tw-bg-opacity, 1))}.bg-secondary{--tw-bg-opacity: 1;background-color:hsl(var(--secondary) / var(--tw-bg-opacity, 1))}.bg-sidebar{--tw-bg-opacity: 1;background-color:hsl(var(--sidebar) / var(--tw-bg-opacity, 1))}.bg-sidebar-border{--tw-bg-opacity: 1;background-color:hsl(var(--sidebar-border) / var(--tw-bg-opacity, 1))}.bg-transparent{background-color:transparent}.fill-current{fill:currentColor}.p-0{padding:0}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-\[1px\]{padding:1px}.px-1{padding-left:.25rem;padding-right:.25rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.pb-3{padding-bottom:.75rem}.pb-4{padding-bottom:1rem}.pl-2\.5{padding-left:.625rem}.pl-4{padding-left:1rem}.pl-8{padding-left:2rem}.pr-2{padding-right:.5rem}.pr-2\.5{padding-right:.625rem}.pr-8{padding-right:2rem}.pt-0{padding-top:0}.pt-1{padding-top:.25rem}.pt-3{padding-top:.75rem}.pt-4{padding-top:1rem}.pt-6{padding-top:1.5rem}.text-left{text-align:left}.text-center{text-align:center}.align-middle{vertical-align:middle}.font-mono{font-family:var(--font-mono)}.text-2xl{font-size:1.5rem;line-height:2rem}.text-\[0\.8rem\]{font-size:.8rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.capitalize{text-transform:capitalize}.tabular-nums{--tw-numeric-spacing: tabular-nums;font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.leading-none{line-height:1}.tracking-tight{letter-spacing:-.025em}.tracking-widest{letter-spacing:.1em}.text-accent-foreground{--tw-text-opacity: 1;color:hsl(var(--accent-foreground) / var(--tw-text-opacity, 1))}.text-card-foreground{--tw-text-opacity: 1;color:hsl(var(--card-foreground) / var(--tw-text-opacity, 1))}.text-current{color:currentColor}.text-destructive{--tw-text-opacity: 1;color:hsl(var(--destructive) / var(--tw-text-opacity, 1))}.text-destructive-foreground{--tw-text-opacity: 1;color:hsl(var(--destructive-foreground) / var(--tw-text-opacity, 1))}.text-foreground{--tw-text-opacity: 1;color:hsl(var(--foreground) / var(--tw-text-opacity, 1))}.text-foreground\/50{color:hsl(var(--foreground) / .5)}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.text-gray-900{--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity, 1))}.text-muted-foreground{--tw-text-opacity: 1;color:hsl(var(--muted-foreground) / var(--tw-text-opacity, 1))}.text-popover-foreground{--tw-text-opacity: 1;color:hsl(var(--popover-foreground) / var(--tw-text-opacity, 1))}.text-primary{--tw-text-opacity: 1;color:hsl(var(--primary) / var(--tw-text-opacity, 1))}.text-primary-foreground{--tw-text-opacity: 1;color:hsl(var(--primary-foreground) / var(--tw-text-opacity, 1))}.text-red-500{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity, 1))}.text-secondary-foreground{--tw-text-opacity: 1;color:hsl(var(--secondary-foreground) / var(--tw-text-opacity, 1))}.text-sidebar-foreground{--tw-text-opacity: 1;color:hsl(var(--sidebar-foreground) / var(--tw-text-opacity, 1))}.text-sidebar-foreground\/70{color:hsl(var(--sidebar-foreground) / .7)}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-90{opacity:.9}.shadow-\[0_0_0_1px_hsl\(var\(--sidebar-border\)\)\]{--tw-shadow: 0 0 0 1px hsl(var(--sidebar-border));--tw-shadow-colored: 0 0 0 1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-none{--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.outline-2{outline-width:2px}.outline-offset-2{outline-offset:2px}.outline-transparent{outline-color:transparent}.ring-0{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-2{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-ring{--tw-ring-opacity: 1;--tw-ring-color: hsl(var(--ring) / var(--tw-ring-opacity, 1))}.ring-sidebar-ring{--tw-ring-opacity: 1;--tw-ring-color: hsl(var(--sidebar-ring) / var(--tw-ring-opacity, 1))}.ring-offset-background{--tw-ring-offset-color: hsl(var(--background) / 1)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-\[left\,right\,width\]{transition-property:left,right,width;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-\[margin\,opacity\]{transition-property:margin,opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-\[width\,height\,padding\]{transition-property:width,height,padding;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-\[width\]{transition-property:width;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-1000{transition-duration:1s}.duration-200{transition-duration:.2s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-linear{transition-timing-function:linear}@keyframes enter{0%{opacity:var(--tw-enter-opacity, 1);transform:translate3d(var(--tw-enter-translate-x, 0),var(--tw-enter-translate-y, 0),0) scale3d(var(--tw-enter-scale, 1),var(--tw-enter-scale, 1),var(--tw-enter-scale, 1)) rotate(var(--tw-enter-rotate, 0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity, 1);transform:translate3d(var(--tw-exit-translate-x, 0),var(--tw-exit-translate-y, 0),0) scale3d(var(--tw-exit-scale, 1),var(--tw-exit-scale, 1),var(--tw-exit-scale, 1)) rotate(var(--tw-exit-rotate, 0))}}.animate-in{animation-name:enter;animation-duration:.15s;--tw-enter-opacity: initial;--tw-enter-scale: initial;--tw-enter-rotate: initial;--tw-enter-translate-x: initial;--tw-enter-translate-y: initial}.fade-in-0{--tw-enter-opacity: 0}.fade-in-80{--tw-enter-opacity: .8}.fade-out{--tw-exit-opacity: 0}.zoom-in-95{--tw-enter-scale: .95}.duration-1000{animation-duration:1s}.duration-200{animation-duration:.2s}.ease-in-out{animation-timing-function:cubic-bezier(.4,0,.2,1)}.ease-linear{animation-timing-function:linear}input[type=search]::-webkit-search-cancel-button{display:none}[contenteditable][data-placeholder]:empty:before{content:attr(data-placeholder);color:hsl(var(--muted-foreground));pointer-events:none}.border.toggle-elevate:before{inset:-1px}.hover-elevate:not(.no-default-hover-elevate),.active-elevate:not(.no-default-active-elevate),.hover-elevate-2:not(.no-default-hover-elevate),.active-elevate-2:not(.no-default-active-elevate){position:relative;z-index:0}.hover-elevate:not(.no-default-hover-elevate):after,.active-elevate:not(.no-default-active-elevate):after,.hover-elevate-2:not(.no-default-hover-elevate):after,.active-elevate-2:not(.no-default-active-elevate):after{content:"";pointer-events:none;position:absolute;inset:0;border-radius:inherit;z-index:999}.hover-elevate:hover:not(.no-default-hover-elevate):after,.active-elevate:active:not(.no-default-active-elevate):after{background-color:var(--elevate-1)}.hover-elevate-2:hover:not(.no-default-hover-elevate):after,.active-elevate-2:active:not(.no-default-active-elevate):after{background-color:var(--elevate-2)}.border.hover-elevate:not(.no-hover-interaction-elevate):after,.border.active-elevate:not(.no-active-interaction-elevate):after,.border.hover-elevate-2:not(.no-hover-interaction-elevate):after,.border.active-elevate-2:not(.no-active-interaction-elevate):after{inset:-1px}.\[border-color\:var\(--badge-outline\)\]{border-color:var(--badge-outline)}.\[border-color\:var\(--button-outline\)\]{border-color:var(--button-outline)}:root{--button-outline: rgba(0,0,0, .1);--badge-outline: rgba(0,0,0, .05);--opaque-button-border-intensity: -8;--elevate-1: rgba(0,0,0, .03);--elevate-2: rgba(0,0,0, .08);--background: 210 20% 98%;--foreground: 222 47% 11%;--border: 210 16% 93%;--card: 210 17% 96%;--card-foreground: 222 47% 11%;--card-border: 210 16% 91%;--sidebar: 210 17% 94%;--sidebar-foreground: 222 47% 11%;--sidebar-border: 210 16% 89%;--sidebar-primary: 207 90% 54%;--sidebar-primary-foreground: 0 0% 100%;--sidebar-accent: 210 17% 88%;--sidebar-accent-foreground: 222 47% 11%;--sidebar-ring: 207 90% 54%;--popover: 210 17% 92%;--popover-foreground: 222 47% 11%;--popover-border: 210 16% 87%;--primary: 207 90% 54%;--primary-foreground: 0 0% 100%;--secondary: 210 17% 87%;--secondary-foreground: 222 47% 11%;--muted: 210 16% 90%;--muted-foreground: 215 16% 47%;--accent: 210 14% 89%;--accent-foreground: 222 47% 11%;--destructive: 0 84% 60%;--destructive-foreground: 0 0% 100%;--input: 210 20% 80%;--ring: 207 90% 54%;--chart-1: 207 90% 54%;--chart-2: 45 93% 47%;--chart-3: 152 69% 31%;--chart-4: 271 76% 53%;--chart-5: 27 87% 67%;--font-sans: Open Sans, sans-serif;--font-serif: Georgia, serif;--font-mono: Menlo, monospace;--radius: .5rem;--shadow-2xs: 0px 2px 0px 0px hsl(210 20% 50% / 0);--shadow-xs: 0px 2px 0px 0px hsl(210 20% 50% / 0);--shadow-sm: 0px 2px 0px 0px hsl(210 20% 50% / 0), 0px 1px 2px -1px hsl(210 20% 50% / 0);--shadow: 0px 2px 0px 0px hsl(210 20% 50% / 0), 0px 1px 2px -1px hsl(210 20% 50% / 0);--shadow-md: 0px 2px 0px 0px hsl(210 20% 50% / 0), 0px 2px 4px -1px hsl(210 20% 50% / 0);--shadow-lg: 0px 2px 0px 0px hsl(210 20% 50% / 0), 0px 4px 6px -1px hsl(210 20% 50% / 0);--shadow-xl: 0px 2px 0px 0px hsl(210 20% 50% / 0), 0px 8px 10px -1px hsl(210 20% 50% / 0);--shadow-2xl: 0px 2px 0px 0px hsl(210 20% 50% / 0);--tracking-normal: 0em;--spacing: .25rem;--sidebar-primary-border: hsl(var(--sidebar-primary));--sidebar-primary-border: hsl(from hsl(var(--sidebar-primary)) h s calc(l + var(--opaque-button-border-intensity)) / alpha);--sidebar-accent-border: hsl(var(--sidebar-accent));--sidebar-accent-border: hsl(from hsl(var(--sidebar-accent)) h s calc(l + var(--opaque-button-border-intensity)) / alpha);--primary-border: hsl(var(--primary));--primary-border: hsl(from hsl(var(--primary)) h s calc(l + var(--opaque-button-border-intensity)) / alpha);--secondary-border: hsl(var(--secondary));--secondary-border: hsl(from hsl(var(--secondary)) h s calc(l + var(--opaque-button-border-intensity)) / alpha);--muted-border: hsl(var(--muted));--muted-border: hsl(from hsl(var(--muted)) h s calc(l + var(--opaque-button-border-intensity)) / alpha);--accent-border: hsl(var(--accent));--accent-border: hsl(from hsl(var(--accent)) h s calc(l + var(--opaque-button-border-intensity)) / alpha);--destructive-border: hsl(var(--destructive));--destructive-border: hsl(from hsl(var(--destructive)) h s calc(l + var(--opaque-button-border-intensity)) / alpha)}.dark{--button-outline: rgba(255,255,255, .1);--badge-outline: rgba(255,255,255, .05);--opaque-button-border-intensity: 9;--elevate-1: rgba(255,255,255, .04);--elevate-2: rgba(255,255,255, .09);--background: 222 47% 11%;--foreground: 210 20% 98%;--border: 215 25% 27%;--card: 220 39% 14%;--card-foreground: 210 20% 98%;--card-border: 218 35% 18%;--sidebar: 218 35% 17%;--sidebar-foreground: 210 20% 98%;--sidebar-border: 216 32% 21%;--sidebar-primary: 207 90% 54%;--sidebar-primary-foreground: 0 0% 100%;--sidebar-accent: 216 32% 22%;--sidebar-accent-foreground: 210 20% 98%;--sidebar-ring: 207 90% 54%;--popover: 216 32% 20%;--popover-foreground: 210 20% 98%;--popover-border: 215 30% 24%;--primary: 207 90% 54%;--primary-foreground: 0 0% 100%;--secondary: 215 30% 25%;--secondary-foreground: 210 20% 98%;--muted: 214 28% 23%;--muted-foreground: 217 10% 64%;--accent: 214 20% 24%;--accent-foreground: 210 20% 98%;--destructive: 0 84% 60%;--destructive-foreground: 0 0% 100%;--input: 215 20% 35%;--ring: 207 90% 54%;--chart-1: 207 90% 65%;--chart-2: 45 93% 62%;--chart-3: 152 69% 65%;--chart-4: 271 76% 70%;--chart-5: 27 87% 72%;--shadow-2xs: 0px 2px 0px 0px hsl(210 20% 50% / 0);--shadow-xs: 0px 2px 0px 0px hsl(210 20% 50% / 0);--shadow-sm: 0px 2px 0px 0px hsl(210 20% 50% / 0), 0px 1px 2px -1px hsl(210 20% 50% / 0);--shadow: 0px 2px 0px 0px hsl(210 20% 50% / 0), 0px 1px 2px -1px hsl(210 20% 50% / 0);--shadow-md: 0px 2px 0px 0px hsl(210 20% 50% / 0), 0px 2px 4px -1px hsl(210 20% 50% / 0);--shadow-lg: 0px 2px 0px 0px hsl(210 20% 50% / 0), 0px 4px 6px -1px hsl(210 20% 50% / 0);--shadow-xl: 0px 2px 0px 0px hsl(210 20% 50% / 0), 0px 8px 10px -1px hsl(210 20% 50% / 0);--shadow-2xl: 0px 2px 0px 0px hsl(210 20% 50% / 0);--sidebar-primary-border: hsl(var(--sidebar-primary));--sidebar-primary-border: hsl(from hsl(var(--sidebar-primary)) h s calc(l + var(--opaque-button-border-intensity)) / alpha);--sidebar-accent-border: hsl(var(--sidebar-accent));--sidebar-accent-border: hsl(from hsl(var(--sidebar-accent)) h s calc(l + var(--opaque-button-border-intensity)) / alpha);--primary-border: hsl(var(--primary));--primary-border: hsl(from hsl(var(--primary)) h s calc(l + var(--opaque-button-border-intensity)) / alpha);--secondary-border: hsl(var(--secondary));--secondary-border: hsl(from hsl(var(--secondary)) h s calc(l + var(--opaque-button-border-intensity)) / alpha);--muted-border: hsl(var(--muted));--muted-border: hsl(from hsl(var(--muted)) h s calc(l + var(--opaque-button-border-intensity)) / alpha);--accent-border: hsl(var(--accent));--accent-border: hsl(from hsl(var(--accent)) h s calc(l + var(--opaque-button-border-intensity)) / alpha);--destructive-border: hsl(var(--destructive));--destructive-border: hsl(from hsl(var(--destructive)) h s calc(l + var(--opaque-button-border-intensity)) / alpha)}.file\:border-0::file-selector-button{border-width:0px}.file\:bg-transparent::file-selector-button{background-color:transparent}.file\:text-sm::file-selector-button{font-size:.875rem;line-height:1.25rem}.file\:font-medium::file-selector-button{font-weight:500}.file\:text-foreground::file-selector-button{--tw-text-opacity: 1;color:hsl(var(--foreground) / var(--tw-text-opacity, 1))}.placeholder\:text-muted-foreground::-moz-placeholder{--tw-text-opacity: 1;color:hsl(var(--muted-foreground) / var(--tw-text-opacity, 1))}.placeholder\:text-muted-foreground::placeholder{--tw-text-opacity: 1;color:hsl(var(--muted-foreground) / var(--tw-text-opacity, 1))}.after\:pointer-events-none:after{content:var(--tw-content);pointer-events:none}.after\:absolute:after{content:var(--tw-content);position:absolute}.after\:-inset-2:after{content:var(--tw-content);inset:-.5rem}.after\:inset-0:after{content:var(--tw-content);inset:0}.after\:inset-y-0:after{content:var(--tw-content);top:0;bottom:0}.after\:left-1\/2:after{content:var(--tw-content);left:50%}.after\:block:after{content:var(--tw-content);display:block}.after\:w-1:after{content:var(--tw-content);width:.25rem}.after\:w-\[2px\]:after{content:var(--tw-content);width:2px}.after\:-translate-x-1\/2:after{content:var(--tw-content);--tw-translate-x: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.after\:rounded-full:after{content:var(--tw-content);border-radius:9999px}.after\:border:after{content:var(--tw-content);border-width:1px}.after\:border-black\/10:after{content:var(--tw-content);border-color:#0000001a}.after\:content-\[\'\'\]:after{--tw-content: "";content:var(--tw-content)}.after\:border.toggle-elevate:after:before{content:var(--tw-content);inset:-1px}.after\:border.hover-elevate:not(.no-hover-interaction-elevate):after:after,.after\:border.active-elevate:not(.no-active-interaction-elevate):after:after,.after\:border.hover-elevate-2:not(.no-hover-interaction-elevate):after:after,.after\:border.active-elevate-2:not(.no-active-interaction-elevate):after:after{content:var(--tw-content);inset:-1px}.first\:rounded-l-md:first-child{border-top-left-radius:.375rem;border-bottom-left-radius:.375rem}.first\:border-l:first-child{border-left-width:1px}.last\:rounded-r-md:last-child{border-top-right-radius:.375rem;border-bottom-right-radius:.375rem}.focus-within\:relative:focus-within{position:relative}.focus-within\:z-20:focus-within{z-index:20}.hover\:bg-accent:hover{--tw-bg-opacity: 1;background-color:hsl(var(--accent) / var(--tw-bg-opacity, 1))}.hover\:bg-muted:hover{--tw-bg-opacity: 1;background-color:hsl(var(--muted) / var(--tw-bg-opacity, 1))}.hover\:bg-muted\/50:hover{background-color:hsl(var(--muted) / .5)}.hover\:bg-primary:hover{--tw-bg-opacity: 1;background-color:hsl(var(--primary) / var(--tw-bg-opacity, 1))}.hover\:bg-secondary:hover{--tw-bg-opacity: 1;background-color:hsl(var(--secondary) / var(--tw-bg-opacity, 1))}.hover\:bg-sidebar-accent:hover{--tw-bg-opacity: 1;background-color:hsl(var(--sidebar-accent) / var(--tw-bg-opacity, 1))}.hover\:text-accent-foreground:hover{--tw-text-opacity: 1;color:hsl(var(--accent-foreground) / var(--tw-text-opacity, 1))}.hover\:text-foreground:hover{--tw-text-opacity: 1;color:hsl(var(--foreground) / var(--tw-text-opacity, 1))}.hover\:text-muted-foreground:hover{--tw-text-opacity: 1;color:hsl(var(--muted-foreground) / var(--tw-text-opacity, 1))}.hover\:text-primary-foreground:hover{--tw-text-opacity: 1;color:hsl(var(--primary-foreground) / var(--tw-text-opacity, 1))}.hover\:text-sidebar-accent-foreground:hover{--tw-text-opacity: 1;color:hsl(var(--sidebar-accent-foreground) / var(--tw-text-opacity, 1))}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}.hover\:shadow-\[0_0_0_1px_hsl\(var\(--sidebar-accent\)\)\]:hover{--tw-shadow: 0 0 0 1px hsl(var(--sidebar-accent));--tw-shadow-colored: 0 0 0 1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\:after\:bg-sidebar-border:hover:after{content:var(--tw-content);--tw-bg-opacity: 1;background-color:hsl(var(--sidebar-border) / var(--tw-bg-opacity, 1))}.focus\:bg-accent:focus{--tw-bg-opacity: 1;background-color:hsl(var(--accent) / var(--tw-bg-opacity, 1))}.focus\:bg-primary:focus{--tw-bg-opacity: 1;background-color:hsl(var(--primary) / var(--tw-bg-opacity, 1))}.focus\:text-accent-foreground:focus{--tw-text-opacity: 1;color:hsl(var(--accent-foreground) / var(--tw-text-opacity, 1))}.focus\:text-primary-foreground:focus{--tw-text-opacity: 1;color:hsl(var(--primary-foreground) / var(--tw-text-opacity, 1))}.focus\:opacity-100:focus{opacity:1}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-ring:focus{--tw-ring-opacity: 1;--tw-ring-color: hsl(var(--ring) / var(--tw-ring-opacity, 1))}.focus\:ring-offset-2:focus{--tw-ring-offset-width: 2px}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:ring-1:focus-visible{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus-visible\:ring-2:focus-visible{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus-visible\:ring-ring:focus-visible{--tw-ring-opacity: 1;--tw-ring-color: hsl(var(--ring) / var(--tw-ring-opacity, 1))}.focus-visible\:ring-offset-1:focus-visible{--tw-ring-offset-width: 1px}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width: 2px}.focus-visible\:ring-offset-background:focus-visible{--tw-ring-offset-color: hsl(var(--background) / 1)}.active\:bg-sidebar-accent:active{--tw-bg-opacity: 1;background-color:hsl(var(--sidebar-accent) / var(--tw-bg-opacity, 1))}.active\:text-sidebar-accent-foreground:active{--tw-text-opacity: 1;color:hsl(var(--sidebar-accent-foreground) / var(--tw-text-opacity, 1))}.active\:shadow-none:active{--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.group\/menu-item:focus-within .group-focus-within\/menu-item\:opacity-100{opacity:1}.group\/menu-item:hover .group-hover\/menu-item\:opacity-100,.group:hover .group-hover\:opacity-100{opacity:1}.group.destructive .group-\[\.destructive\]\:border-muted\/40{border-color:hsl(var(--muted) / .4)}.group.destructive .group-\[\.destructive\]\:text-red-300{--tw-text-opacity: 1;color:rgb(252 165 165 / var(--tw-text-opacity, 1))}.group.destructive .group-\[\.destructive\]\:hover\:border-destructive\/30:hover{border-color:hsl(var(--destructive) / .3)}.group.destructive .group-\[\.destructive\]\:hover\:bg-destructive:hover{--tw-bg-opacity: 1;background-color:hsl(var(--destructive) / var(--tw-bg-opacity, 1))}.group.destructive .group-\[\.destructive\]\:hover\:text-destructive-foreground:hover{--tw-text-opacity: 1;color:hsl(var(--destructive-foreground) / var(--tw-text-opacity, 1))}.group.destructive .group-\[\.destructive\]\:hover\:text-red-50:hover{--tw-text-opacity: 1;color:rgb(254 242 242 / var(--tw-text-opacity, 1))}.group.destructive .group-\[\.destructive\]\:focus\:ring-destructive:focus{--tw-ring-opacity: 1;--tw-ring-color: hsl(var(--destructive) / var(--tw-ring-opacity, 1))}.group.destructive .group-\[\.destructive\]\:focus\:ring-red-400:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(248 113 113 / var(--tw-ring-opacity, 1))}.group.destructive .group-\[\.destructive\]\:focus\:ring-offset-red-600:focus{--tw-ring-offset-color: #dc2626}.peer\/menu-button:hover~.peer-hover\/menu-button\:text-sidebar-accent-foreground{--tw-text-opacity: 1;color:hsl(var(--sidebar-accent-foreground) / var(--tw-text-opacity, 1))}.peer:disabled~.peer-disabled\:cursor-not-allowed{cursor:not-allowed}.peer:disabled~.peer-disabled\:opacity-70{opacity:.7}.has-\[\:disabled\]\:opacity-50:has(:disabled){opacity:.5}.aria-disabled\:pointer-events-none[aria-disabled=true]{pointer-events:none}.aria-disabled\:opacity-50[aria-disabled=true]{opacity:.5}.aria-selected\:bg-accent[aria-selected=true]{--tw-bg-opacity: 1;background-color:hsl(var(--accent) / var(--tw-bg-opacity, 1))}.aria-selected\:bg-accent\/50[aria-selected=true]{background-color:hsl(var(--accent) / .5)}.aria-selected\:text-accent-foreground[aria-selected=true]{--tw-text-opacity: 1;color:hsl(var(--accent-foreground) / var(--tw-text-opacity, 1))}.aria-selected\:text-muted-foreground[aria-selected=true]{--tw-text-opacity: 1;color:hsl(var(--muted-foreground) / var(--tw-text-opacity, 1))}.aria-selected\:opacity-100[aria-selected=true]{opacity:1}.data-\[disabled\=true\]\:pointer-events-none[data-disabled=true],.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[panel-group-direction\=vertical\]\:h-px[data-panel-group-direction=vertical]{height:1px}.data-\[panel-group-direction\=vertical\]\:w-full[data-panel-group-direction=vertical]{width:100%}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=left\]\:-translate-x-1[data-side=left]{--tw-translate-x: -.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=right\]\:translate-x-1[data-side=right]{--tw-translate-x: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=top\]\:-translate-y-1[data-side=top]{--tw-translate-y: -.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=checked\]\:translate-x-5[data-state=checked]{--tw-translate-x: 1.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=unchecked\]\:translate-x-0[data-state=unchecked],.data-\[swipe\=cancel\]\:translate-x-0[data-swipe=cancel]{--tw-translate-x: 0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[swipe\=end\]\:translate-x-\[var\(--radix-toast-swipe-end-x\)\][data-swipe=end]{--tw-translate-x: var(--radix-toast-swipe-end-x);transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[swipe\=move\]\:translate-x-\[var\(--radix-toast-swipe-move-x\)\][data-swipe=move]{--tw-translate-x: var(--radix-toast-swipe-move-x);transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes accordion-up{0%{height:var(--radix-accordion-content-height)}to{height:0}}.data-\[state\=closed\]\:animate-accordion-up[data-state=closed]{animation:accordion-up .2s ease-out}@keyframes accordion-down{0%{height:0}to{height:var(--radix-accordion-content-height)}}.data-\[state\=open\]\:animate-accordion-down[data-state=open]{animation:accordion-down .2s ease-out}.data-\[panel-group-direction\=vertical\]\:flex-col[data-panel-group-direction=vertical]{flex-direction:column}.data-\[active\=true\]\:bg-sidebar-accent[data-active=true]{--tw-bg-opacity: 1;background-color:hsl(var(--sidebar-accent) / var(--tw-bg-opacity, 1))}.data-\[selected\=\'true\'\]\:bg-accent[data-selected=true]{--tw-bg-opacity: 1;background-color:hsl(var(--accent) / var(--tw-bg-opacity, 1))}.data-\[state\=active\]\:bg-background[data-state=active]{--tw-bg-opacity: 1;background-color:hsl(var(--background) / var(--tw-bg-opacity, 1))}.data-\[state\=checked\]\:bg-primary[data-state=checked]{--tw-bg-opacity: 1;background-color:hsl(var(--primary) / var(--tw-bg-opacity, 1))}.data-\[state\=on\]\:bg-accent[data-state=on],.data-\[state\=open\]\:bg-accent[data-state=open]{--tw-bg-opacity: 1;background-color:hsl(var(--accent) / var(--tw-bg-opacity, 1))}.data-\[state\=open\]\:bg-accent\/50[data-state=open]{background-color:hsl(var(--accent) / .5)}.data-\[state\=open\]\:bg-secondary[data-state=open]{--tw-bg-opacity: 1;background-color:hsl(var(--secondary) / var(--tw-bg-opacity, 1))}.data-\[state\=selected\]\:bg-muted[data-state=selected]{--tw-bg-opacity: 1;background-color:hsl(var(--muted) / var(--tw-bg-opacity, 1))}.data-\[state\=unchecked\]\:bg-input[data-state=unchecked]{--tw-bg-opacity: 1;background-color:hsl(var(--input) / var(--tw-bg-opacity, 1))}.data-\[active\=true\]\:font-medium[data-active=true]{font-weight:500}.data-\[active\=true\]\:text-sidebar-accent-foreground[data-active=true]{--tw-text-opacity: 1;color:hsl(var(--sidebar-accent-foreground) / var(--tw-text-opacity, 1))}.data-\[placeholder\]\:text-muted-foreground[data-placeholder]{--tw-text-opacity: 1;color:hsl(var(--muted-foreground) / var(--tw-text-opacity, 1))}.data-\[selected\=true\]\:text-accent-foreground[data-selected=true]{--tw-text-opacity: 1;color:hsl(var(--accent-foreground) / var(--tw-text-opacity, 1))}.data-\[state\=active\]\:text-foreground[data-state=active]{--tw-text-opacity: 1;color:hsl(var(--foreground) / var(--tw-text-opacity, 1))}.data-\[state\=checked\]\:text-primary-foreground[data-state=checked]{--tw-text-opacity: 1;color:hsl(var(--primary-foreground) / var(--tw-text-opacity, 1))}.data-\[state\=on\]\:text-accent-foreground[data-state=on],.data-\[state\=open\]\:text-accent-foreground[data-state=open]{--tw-text-opacity: 1;color:hsl(var(--accent-foreground) / var(--tw-text-opacity, 1))}.data-\[state\=open\]\:text-muted-foreground[data-state=open]{--tw-text-opacity: 1;color:hsl(var(--muted-foreground) / var(--tw-text-opacity, 1))}.data-\[disabled\=true\]\:opacity-50[data-disabled=true],.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[state\=open\]\:opacity-100[data-state=open]{opacity:1}.data-\[state\=active\]\:shadow-sm[data-state=active]{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.data-\[swipe\=move\]\:transition-none[data-swipe=move]{transition-property:none}.data-\[state\=closed\]\:duration-300[data-state=closed]{transition-duration:.3s}.data-\[state\=open\]\:duration-500[data-state=open]{transition-duration:.5s}.data-\[motion\^\=from-\]\:animate-in[data-motion^=from-],.data-\[state\=open\]\:animate-in[data-state=open],.data-\[state\=visible\]\:animate-in[data-state=visible]{animation-name:enter;animation-duration:.15s;--tw-enter-opacity: initial;--tw-enter-scale: initial;--tw-enter-rotate: initial;--tw-enter-translate-x: initial;--tw-enter-translate-y: initial}.data-\[motion\^\=to-\]\:animate-out[data-motion^=to-],.data-\[state\=closed\]\:animate-out[data-state=closed],.data-\[state\=hidden\]\:animate-out[data-state=hidden],.data-\[swipe\=end\]\:animate-out[data-swipe=end]{animation-name:exit;animation-duration:.15s;--tw-exit-opacity: initial;--tw-exit-scale: initial;--tw-exit-rotate: initial;--tw-exit-translate-x: initial;--tw-exit-translate-y: initial}.data-\[motion\^\=from-\]\:fade-in[data-motion^=from-]{--tw-enter-opacity: 0}.data-\[motion\^\=to-\]\:fade-out[data-motion^=to-],.data-\[state\=closed\]\:fade-out-0[data-state=closed]{--tw-exit-opacity: 0}.data-\[state\=closed\]\:fade-out-80[data-state=closed]{--tw-exit-opacity: .8}.data-\[state\=hidden\]\:fade-out[data-state=hidden]{--tw-exit-opacity: 0}.data-\[state\=open\]\:fade-in-0[data-state=open],.data-\[state\=visible\]\:fade-in[data-state=visible]{--tw-enter-opacity: 0}.data-\[state\=closed\]\:zoom-out-95[data-state=closed]{--tw-exit-scale: .95}.data-\[state\=open\]\:zoom-in-90[data-state=open]{--tw-enter-scale: .9}.data-\[state\=open\]\:zoom-in-95[data-state=open]{--tw-enter-scale: .95}.data-\[motion\=from-end\]\:slide-in-from-right-52[data-motion=from-end]{--tw-enter-translate-x: 13rem}.data-\[motion\=from-start\]\:slide-in-from-left-52[data-motion=from-start]{--tw-enter-translate-x: -13rem}.data-\[motion\=to-end\]\:slide-out-to-right-52[data-motion=to-end]{--tw-exit-translate-x: 13rem}.data-\[motion\=to-start\]\:slide-out-to-left-52[data-motion=to-start]{--tw-exit-translate-x: -13rem}.data-\[side\=bottom\]\:slide-in-from-top-2[data-side=bottom]{--tw-enter-translate-y: -.5rem}.data-\[side\=left\]\:slide-in-from-right-2[data-side=left]{--tw-enter-translate-x: .5rem}.data-\[side\=right\]\:slide-in-from-left-2[data-side=right]{--tw-enter-translate-x: -.5rem}.data-\[side\=top\]\:slide-in-from-bottom-2[data-side=top]{--tw-enter-translate-y: .5rem}.data-\[state\=closed\]\:slide-out-to-bottom[data-state=closed]{--tw-exit-translate-y: 100%}.data-\[state\=closed\]\:slide-out-to-left[data-state=closed]{--tw-exit-translate-x: -100%}.data-\[state\=closed\]\:slide-out-to-left-1\/2[data-state=closed]{--tw-exit-translate-x: -50%}.data-\[state\=closed\]\:slide-out-to-right[data-state=closed],.data-\[state\=closed\]\:slide-out-to-right-full[data-state=closed]{--tw-exit-translate-x: 100%}.data-\[state\=closed\]\:slide-out-to-top[data-state=closed]{--tw-exit-translate-y: -100%}.data-\[state\=closed\]\:slide-out-to-top-\[48\%\][data-state=closed]{--tw-exit-translate-y: -48%}.data-\[state\=open\]\:slide-in-from-bottom[data-state=open]{--tw-enter-translate-y: 100%}.data-\[state\=open\]\:slide-in-from-left[data-state=open]{--tw-enter-translate-x: -100%}.data-\[state\=open\]\:slide-in-from-left-1\/2[data-state=open]{--tw-enter-translate-x: -50%}.data-\[state\=open\]\:slide-in-from-right[data-state=open]{--tw-enter-translate-x: 100%}.data-\[state\=open\]\:slide-in-from-top[data-state=open]{--tw-enter-translate-y: -100%}.data-\[state\=open\]\:slide-in-from-top-\[48\%\][data-state=open]{--tw-enter-translate-y: -48%}.data-\[state\=open\]\:slide-in-from-top-full[data-state=open]{--tw-enter-translate-y: -100%}.data-\[state\=closed\]\:duration-300[data-state=closed]{animation-duration:.3s}.data-\[state\=open\]\:duration-500[data-state=open]{animation-duration:.5s}.data-\[panel-group-direction\=vertical\]\:after\:left-0[data-panel-group-direction=vertical]:after{content:var(--tw-content);left:0}.data-\[panel-group-direction\=vertical\]\:after\:h-1[data-panel-group-direction=vertical]:after{content:var(--tw-content);height:.25rem}.data-\[panel-group-direction\=vertical\]\:after\:w-full[data-panel-group-direction=vertical]:after{content:var(--tw-content);width:100%}.data-\[panel-group-direction\=vertical\]\:after\:-translate-y-1\/2[data-panel-group-direction=vertical]:after{content:var(--tw-content);--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[panel-group-direction\=vertical\]\:after\:translate-x-0[data-panel-group-direction=vertical]:after{content:var(--tw-content);--tw-translate-x: 0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=open\]\:hover\:bg-accent:hover[data-state=open]{--tw-bg-opacity: 1;background-color:hsl(var(--accent) / var(--tw-bg-opacity, 1))}.data-\[state\=open\]\:hover\:bg-sidebar-accent:hover[data-state=open]{--tw-bg-opacity: 1;background-color:hsl(var(--sidebar-accent) / var(--tw-bg-opacity, 1))}.data-\[state\=open\]\:hover\:text-sidebar-accent-foreground:hover[data-state=open]{--tw-text-opacity: 1;color:hsl(var(--sidebar-accent-foreground) / var(--tw-text-opacity, 1))}.data-\[state\=open\]\:focus\:bg-accent:focus[data-state=open]{--tw-bg-opacity: 1;background-color:hsl(var(--accent) / var(--tw-bg-opacity, 1))}.group[data-collapsible=offcanvas] .group-data-\[collapsible\=offcanvas\]\:left-\[calc\(var\(--sidebar-width\)\*-1\)\]{left:calc(var(--sidebar-width) * -1)}.group[data-collapsible=offcanvas] .group-data-\[collapsible\=offcanvas\]\:right-\[calc\(var\(--sidebar-width\)\*-1\)\]{right:calc(var(--sidebar-width) * -1)}.group[data-side=left] .group-data-\[side\=left\]\:-right-4{right:-1rem}.group[data-side=right] .group-data-\[side\=right\]\:left-0{left:0}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:-mt-8{margin-top:-2rem}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:hidden{display:none}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:w-\[calc\(var\(--sidebar-width-icon\)\+var\(--spacing-4\)\)\]{width:calc(var(--sidebar-width-icon) + var(--spacing-4))}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:w-\[calc\(var\(--sidebar-width-icon\)\+var\(--spacing-4\)\+2px\)\]{width:calc(var(--sidebar-width-icon) + var(--spacing-4) + 2px)}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:w-\[var\(--sidebar-width-icon\)\]{width:var(--sidebar-width-icon)}.group[data-collapsible=offcanvas] .group-data-\[collapsible\=offcanvas\]\:w-0{width:0px}.group[data-collapsible=offcanvas] .group-data-\[collapsible\=offcanvas\]\:translate-x-0{--tw-translate-x: 0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group[data-side=right] .group-data-\[side\=right\]\:rotate-180,.group[data-state=open] .group-data-\[state\=open\]\:rotate-180{--tw-rotate: 180deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:overflow-hidden{overflow:hidden}.group[data-variant=floating] .group-data-\[variant\=floating\]\:rounded-lg{border-radius:.5625rem}.group[data-variant=floating] .group-data-\[variant\=floating\]\:border{border-width:1px}.group[data-side=left] .group-data-\[side\=left\]\:border-r{border-right-width:1px}.group[data-side=right] .group-data-\[side\=right\]\:border-l{border-left-width:1px}.group[data-variant=floating] .group-data-\[variant\=floating\]\:border-sidebar-border{--tw-border-opacity: 1;border-color:hsl(var(--sidebar-border) / var(--tw-border-opacity, 1))}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:opacity-0{opacity:0}.group[data-variant=floating] .group-data-\[variant\=floating\]\:shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.group[data-variant=floating] .group-data-\[variant\=floating\]\:border.toggle-elevate:before{inset:-1px}.group[data-variant=floating] .group-data-\[variant\=floating\]\:border.hover-elevate:not(.no-hover-interaction-elevate):after,.group[data-variant=floating] .group-data-\[variant\=floating\]\:border.active-elevate:not(.no-active-interaction-elevate):after,.group[data-variant=floating] .group-data-\[variant\=floating\]\:border.hover-elevate-2:not(.no-hover-interaction-elevate):after,.group[data-variant=floating] .group-data-\[variant\=floating\]\:border.active-elevate-2:not(.no-active-interaction-elevate):after{inset:-1px}.group[data-collapsible=offcanvas] .group-data-\[collapsible\=offcanvas\]\:after\:left-full:after{content:var(--tw-content);left:100%}.group[data-collapsible=offcanvas] .hover\:group-data-\[collapsible\=offcanvas\]\:bg-sidebar:hover{--tw-bg-opacity: 1;background-color:hsl(var(--sidebar) / var(--tw-bg-opacity, 1))}.peer\/menu-button[data-size=default]~.peer-data-\[size\=default\]\/menu-button\:top-1\.5{top:.375rem}.peer\/menu-button[data-size=lg]~.peer-data-\[size\=lg\]\/menu-button\:top-2\.5{top:.625rem}.peer\/menu-button[data-size=sm]~.peer-data-\[size\=sm\]\/menu-button\:top-1{top:.25rem}.peer\/menu-button[data-active=true]~.peer-data-\[active\=true\]\/menu-button\:text-sidebar-accent-foreground{--tw-text-opacity: 1;color:hsl(var(--sidebar-accent-foreground) / var(--tw-text-opacity, 1))}.dark\:border-destructive:is(.dark *){--tw-border-opacity: 1;border-color:hsl(var(--destructive) / var(--tw-border-opacity, 1))}.dark\:after\:border-white\/10:is(.dark *):after{content:var(--tw-content);border-color:#ffffff1a}@media(min-width:640px){.sm\:bottom-0{bottom:0}.sm\:right-0{right:0}.sm\:top-auto{top:auto}.sm\:mt-0{margin-top:0}.sm\:flex{display:flex}.sm\:max-w-sm{max-width:24rem}.sm\:flex-row{flex-direction:row}.sm\:flex-col{flex-direction:column}.sm\:justify-end{justify-content:flex-end}.sm\:gap-2\.5{gap:.625rem}.sm\:space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.5rem * var(--tw-space-x-reverse));margin-left:calc(.5rem * calc(1 - var(--tw-space-x-reverse)))}.sm\:space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(1rem * var(--tw-space-x-reverse));margin-left:calc(1rem * calc(1 - var(--tw-space-x-reverse)))}.sm\:space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(0px * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(0px * var(--tw-space-y-reverse))}.sm\:rounded-lg{border-radius:.5625rem}.sm\:text-left{text-align:left}.data-\[state\=open\]\:sm\:slide-in-from-bottom-full[data-state=open]{--tw-enter-translate-y: 100%}}@media(min-width:768px){.md\:absolute{position:absolute}.md\:block{display:block}.md\:flex{display:flex}.md\:w-\[var\(--radix-navigation-menu-viewport-width\)\]{width:var(--radix-navigation-menu-viewport-width)}.md\:w-auto{width:auto}.md\:max-w-\[420px\]{max-width:420px}.md\:text-sm{font-size:.875rem;line-height:1.25rem}.md\:opacity-0{opacity:0}.md\:after\:hidden:after{content:var(--tw-content);display:none}.peer[data-variant=inset]~.md\:peer-data-\[variant\=inset\]\:m-2{margin:.5rem}.peer[data-variant=inset]~.md\:peer-data-\[variant\=inset\]\:ml-0{margin-left:0}.peer[data-variant=inset][data-state=collapsed]~.md\:peer-data-\[variant\=inset\]\:peer-data-\[state\=collapsed\]\:ml-2{margin-left:.5rem}.peer[data-variant=inset]~.md\:peer-data-\[variant\=inset\]\:rounded-xl{border-radius:.75rem}.peer[data-variant=inset]~.md\:peer-data-\[variant\=inset\]\:shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}}.\[\&\:has\(\[aria-selected\]\)\]\:bg-accent:has([aria-selected]){--tw-bg-opacity: 1;background-color:hsl(var(--accent) / var(--tw-bg-opacity, 1))}.first\:\[\&\:has\(\[aria-selected\]\)\]\:rounded-l-md:has([aria-selected]):first-child{border-top-left-radius:.375rem;border-bottom-left-radius:.375rem}.last\:\[\&\:has\(\[aria-selected\]\)\]\:rounded-r-md:has([aria-selected]):last-child{border-top-right-radius:.375rem;border-bottom-right-radius:.375rem}.\[\&\:has\(\[aria-selected\]\.day-outside\)\]\:bg-accent\/50:has([aria-selected].day-outside){background-color:hsl(var(--accent) / .5)}.\[\&\:has\(\[aria-selected\]\.day-range-end\)\]\:rounded-r-md:has([aria-selected].day-range-end){border-top-right-radius:.375rem;border-bottom-right-radius:.375rem}.\[\&\:has\(\[role\=checkbox\]\)\]\:pr-0:has([role=checkbox]){padding-right:0}.\[\&\>button\]\:hidden>button{display:none}.\[\&\>span\:last-child\]\:truncate>span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.\[\&\>span\]\:line-clamp-1>span{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1}.\[\&\>svg\+div\]\:translate-y-\[-3px\]>svg+div{--tw-translate-y: -3px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.\[\&\>svg\]\:absolute>svg{position:absolute}.\[\&\>svg\]\:left-4>svg{left:1rem}.\[\&\>svg\]\:top-4>svg{top:1rem}.\[\&\>svg\]\:size-4>svg{width:1rem;height:1rem}.\[\&\>svg\]\:h-2\.5>svg{height:.625rem}.\[\&\>svg\]\:h-3>svg{height:.75rem}.\[\&\>svg\]\:h-3\.5>svg{height:.875rem}.\[\&\>svg\]\:h-4>svg{height:1rem}.\[\&\>svg\]\:w-2\.5>svg{width:.625rem}.\[\&\>svg\]\:w-3>svg{width:.75rem}.\[\&\>svg\]\:w-3\.5>svg{width:.875rem}.\[\&\>svg\]\:w-4>svg{width:1rem}.\[\&\>svg\]\:shrink-0>svg{flex-shrink:0}.\[\&\>svg\]\:text-destructive>svg{--tw-text-opacity: 1;color:hsl(var(--destructive) / var(--tw-text-opacity, 1))}.\[\&\>svg\]\:text-foreground>svg{--tw-text-opacity: 1;color:hsl(var(--foreground) / var(--tw-text-opacity, 1))}.\[\&\>svg\]\:text-muted-foreground>svg{--tw-text-opacity: 1;color:hsl(var(--muted-foreground) / var(--tw-text-opacity, 1))}.\[\&\>svg\]\:text-sidebar-accent-foreground>svg{--tw-text-opacity: 1;color:hsl(var(--sidebar-accent-foreground) / var(--tw-text-opacity, 1))}.\[\&\>svg\~\*\]\:pl-7>svg~*{padding-left:1.75rem}.\[\&\>tr\]\:last\:border-b-0:last-child>tr{border-bottom-width:0px}.\[\&\[data-panel-group-direction\=vertical\]\>div\]\:rotate-90[data-panel-group-direction=vertical]>div{--tw-rotate: 90deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.\[\&\[data-state\=open\]\>svg\]\:rotate-180[data-state=open]>svg{--tw-rotate: 180deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.\[\&_\.recharts-cartesian-axis-tick_text\]\:fill-muted-foreground .recharts-cartesian-axis-tick text{fill:hsl(var(--muted-foreground) / 1)}.\[\&_\.recharts-cartesian-grid_line\[stroke\=\'\#ccc\'\]\]\:stroke-border\/50 .recharts-cartesian-grid line[stroke="#ccc"]{stroke:hsl(var(--border) / .5)}.\[\&_\.recharts-curve\.recharts-tooltip-cursor\]\:stroke-border .recharts-curve.recharts-tooltip-cursor{stroke:hsl(var(--border) / 1)}.\[\&_\.recharts-dot\[stroke\=\'\#fff\'\]\]\:stroke-transparent .recharts-dot[stroke="#fff"]{stroke:transparent}.\[\&_\.recharts-layer\]\:outline-none .recharts-layer{outline:2px solid transparent;outline-offset:2px}.\[\&_\.recharts-polar-grid_\[stroke\=\'\#ccc\'\]\]\:stroke-border .recharts-polar-grid [stroke="#ccc"]{stroke:hsl(var(--border) / 1)}.\[\&_\.recharts-radial-bar-background-sector\]\:fill-muted .recharts-radial-bar-background-sector,.\[\&_\.recharts-rectangle\.recharts-tooltip-cursor\]\:fill-muted .recharts-rectangle.recharts-tooltip-cursor{fill:hsl(var(--muted) / 1)}.\[\&_\.recharts-reference-line_\[stroke\=\'\#ccc\'\]\]\:stroke-border .recharts-reference-line [stroke="#ccc"]{stroke:hsl(var(--border) / 1)}.\[\&_\.recharts-sector\[stroke\=\'\#fff\'\]\]\:stroke-transparent .recharts-sector[stroke="#fff"]{stroke:transparent}.\[\&_\.recharts-sector\]\:outline-none .recharts-sector,.\[\&_\.recharts-surface\]\:outline-none .recharts-surface{outline:2px solid transparent;outline-offset:2px}.\[\&_\[cmdk-group-heading\]\]\:px-2 [cmdk-group-heading]{padding-left:.5rem;padding-right:.5rem}.\[\&_\[cmdk-group-heading\]\]\:py-1\.5 [cmdk-group-heading]{padding-top:.375rem;padding-bottom:.375rem}.\[\&_\[cmdk-group-heading\]\]\:text-xs [cmdk-group-heading]{font-size:.75rem;line-height:1rem}.\[\&_\[cmdk-group-heading\]\]\:font-medium [cmdk-group-heading]{font-weight:500}.\[\&_\[cmdk-group-heading\]\]\:text-muted-foreground [cmdk-group-heading]{--tw-text-opacity: 1;color:hsl(var(--muted-foreground) / var(--tw-text-opacity, 1))}.\[\&_\[cmdk-group\]\:not\(\[hidden\]\)_\~\[cmdk-group\]\]\:pt-0 [cmdk-group]:not([hidden])~[cmdk-group]{padding-top:0}.\[\&_\[cmdk-group\]\]\:px-2 [cmdk-group]{padding-left:.5rem;padding-right:.5rem}.\[\&_\[cmdk-input-wrapper\]_svg\]\:h-5 [cmdk-input-wrapper] svg{height:1.25rem}.\[\&_\[cmdk-input-wrapper\]_svg\]\:w-5 [cmdk-input-wrapper] svg{width:1.25rem}.\[\&_\[cmdk-input\]\]\:h-12 [cmdk-input]{height:3rem}.\[\&_\[cmdk-item\]\]\:px-2 [cmdk-item]{padding-left:.5rem;padding-right:.5rem}.\[\&_\[cmdk-item\]\]\:py-3 [cmdk-item]{padding-top:.75rem;padding-bottom:.75rem}.\[\&_\[cmdk-item\]_svg\]\:h-5 [cmdk-item] svg{height:1.25rem}.\[\&_\[cmdk-item\]_svg\]\:w-5 [cmdk-item] svg{width:1.25rem}.\[\&_p\]\:leading-relaxed p{line-height:1.625}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{width:1rem;height:1rem}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_tr\:last-child\]\:border-0 tr:last-child{border-width:0px}.\[\&_tr\]\:border-b tr{border-bottom-width:1px}[data-side=left][data-collapsible=offcanvas] .\[\[data-side\=left\]\[data-collapsible\=offcanvas\]_\&\]\:-right-2{right:-.5rem}[data-side=left][data-state=collapsed] .\[\[data-side\=left\]\[data-state\=collapsed\]_\&\]\:cursor-e-resize{cursor:e-resize}[data-side=right][data-collapsible=offcanvas] .\[\[data-side\=right\]\[data-collapsible\=offcanvas\]_\&\]\:-left-2{left:-.5rem}[data-side=right][data-state=collapsed] .\[\[data-side\=right\]\[data-state\=collapsed\]_\&\]\:cursor-w-resize{cursor:w-resize}
