.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}:root{--color-bg-primary: #0a0f1c;--color-bg-secondary: #111827;--color-bg-card: #1e293b;--color-bg-card-hover: #334155;--color-border: #334155;--color-border-subtle: #1e293b;--color-accent: #3b82f6;--color-accent-light: #38bdf8;--color-accent-dark: #6366f1;--color-accent-glow: rgba(56, 189, 248, .4);--color-text-primary: #f1f5f9;--color-text-secondary: #94a3b8;--color-text-muted: #8b9bb5;--color-success: #22c55e;--color-warning: #f59e0b;--color-error: #ef4444;--font-sans: "Space Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "Fira Code", "Consolas", monospace;--text-xs: clamp(.75rem, .7rem + .25vw, .875rem);--text-sm: clamp(.875rem, .8rem + .35vw, 1rem);--text-base: clamp(1rem, .9rem + .5vw, 1.125rem);--text-lg: clamp(1.125rem, 1rem + .6vw, 1.25rem);--text-xl: clamp(1.25rem, 1.1rem + .75vw, 1.5rem);--text-2xl: clamp(1.5rem, 1.25rem + 1.25vw, 2rem);--text-3xl: clamp(1.875rem, 1.5rem + 1.875vw, 2.5rem);--text-4xl: clamp(2.25rem, 1.75rem + 2.5vw, 3.5rem);--text-5xl: clamp(3rem, 2rem + 5vw, 5rem);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--space-4xl: 6rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -2px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5), 0 4px 6px -4px rgba(0, 0, 0, .4);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .5), 0 8px 10px -6px rgba(0, 0, 0, .4);--shadow-glow: 0 0 20px var(--color-accent-glow);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .35s ease;--transition-spring: .5s cubic-bezier(.34, 1.56, .64, 1);--container-max: 1200px;--header-height: 4rem}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:1.6;color:var(--color-text-primary);background-color:var(--color-bg-primary);min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(59,130,246,.15),transparent),radial-gradient(ellipse 60% 40% at 100% 0%,rgba(99,102,241,.1),transparent);pointer-events:none;z-index:-1}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2;color:var(--color-text-primary)}h1{font-size:var(--text-5xl)}h2{font-size:var(--text-4xl)}h3{font-size:var(--text-3xl)}h4{font-size:var(--text-2xl)}h5{font-size:var(--text-xl)}h6{font-size:var(--text-lg)}p{color:var(--color-text-secondary);max-width:65ch}a{color:var(--color-accent-light);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent)}code,pre{font-family:var(--font-mono)}.container{width:100%;max-width:var(--container-max);margin:0 auto;padding:0 var(--space-lg)}.section{padding:var(--space-3xl) 0;scroll-margin-top:calc(var(--header-height) + var(--space-md))}.section-compact{padding:var(--space-xl) 0;scroll-margin-top:calc(var(--header-height) + var(--space-md))}.section-title{font-size:var(--text-3xl);margin-bottom:var(--space-2xl);position:relative;display:inline-block}.section-title:after{content:"";position:absolute;bottom:-.5rem;left:0;width:3rem;height:3px;background:linear-gradient(90deg,var(--color-accent),var(--color-accent-light));border-radius:var(--radius-full)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all var(--transition-base);text-decoration:none}.btn-primary{background:linear-gradient(135deg,var(--color-accent),var(--color-accent-dark));color:#fff;box-shadow:var(--shadow-md),0 0 0 0 var(--color-accent-glow)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),var(--shadow-glow);color:#fff}.btn-secondary{background:transparent;color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-bg-card);border-color:var(--color-accent);color:var(--color-accent-light)}.card{background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-base)}.card:hover{background:var(--color-bg-card-hover);border-color:var(--color-border);transform:translateY(-4px);box-shadow:var(--shadow-xl)}.card-glass{background:#1e293b99;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1)}.badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);font-size:var(--text-xs);font-weight:500;border-radius:var(--radius-full);background:var(--color-bg-card);color:var(--color-text-secondary);border:1px solid var(--color-border-subtle)}.badge-accent{background:#3b82f626;color:var(--color-accent-light);border-color:#3b82f64d}.badge-success{background:#22c55e26;color:var(--color-success);border-color:#22c55e4d}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}.animate-fade-in{animation:fadeIn var(--transition-slow) forwards}.animate-slide-up{animation:slideUp var(--transition-slow) forwards}.animate-float{animation:float 3s ease-in-out infinite}.stagger-animation>*{opacity:0;animation:slideUp .5s ease forwards}.stagger-animation>*:nth-child(1){animation-delay:.1s}.stagger-animation>*:nth-child(2){animation-delay:.2s}.stagger-animation>*:nth-child(3){animation-delay:.3s}.stagger-animation>*:nth-child(4){animation-delay:.4s}.stagger-animation>*:nth-child(5){animation-delay:.5s}.stagger-animation>*:nth-child(6){animation-delay:.6s}.no-transition,.no-transition>*{transition:none!important}.js-reveal-ready [data-reveal]{opacity:0;transform:translateY(24px);transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1s cubic-bezier(.16,1,.3,1)}.js-reveal-ready [data-reveal].revealed{opacity:1;transform:translateY(0)}.js-reveal-ready [data-reveal-children]>*{opacity:0;transform:translate(-20px);transition:opacity .9s ease,transform .9s ease}.js-reveal-ready [data-reveal-children].revealed>*{opacity:1;transform:translate(0)}.js-reveal-ready [data-reveal-children].revealed>*:nth-child(1){transition-delay:.1s}.js-reveal-ready [data-reveal-children].revealed>*:nth-child(2){transition-delay:.2s}.js-reveal-ready [data-reveal-children].revealed>*:nth-child(3){transition-delay:.3s}.js-reveal-ready [data-reveal-children].revealed>*:nth-child(4){transition-delay:.4s}.js-reveal-ready [data-reveal-children].revealed>*:nth-child(5){transition-delay:.5s}.js-reveal-ready [data-reveal-children].revealed>*:nth-child(6){transition-delay:.6s}.js-reveal-ready [data-reveal-children].revealed>*:nth-child(7){transition-delay:.7s}.js-reveal-ready [data-reveal-children].revealed>*:nth-child(8){transition-delay:.8s}@media(prefers-reduced-motion:reduce){.js-reveal-ready [data-reveal],.js-reveal-ready [data-reveal-children]>*{opacity:1;transform:none;transition:none}}@media(max-width:768px){.container{padding:0 var(--space-xl)}.section{padding:var(--space-2xl) 0}.section-title{margin-bottom:var(--space-xl)}.hide-mobile{display:none!important}}@media(max-width:480px){.container{padding:0 var(--space-md)}}@media(min-width:769px){.hide-desktop{display:none!important}}::selection{background:var(--color-accent);color:#fff}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-accent)}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.skip-link{position:absolute;top:-100%;left:0;background:var(--color-accent);color:#fff;padding:var(--space-sm) var(--space-md);z-index:100;transition:top var(--transition-fast)}.skip-link:focus{top:0}.app-card{position:relative;display:flex;flex-direction:column;border-radius:var(--radius-xl);overflow:hidden;text-decoration:none;background:var(--color-bg-card);border:1px solid var(--color-border-subtle);transition:transform var(--transition-base),border-color var(--transition-base),box-shadow var(--transition-base);height:320px}.app-card:hover{transform:translateY(-4px);border-color:var(--color-accent);box-shadow:0 20px 40px #0006,0 0 0 1px var(--color-accent)}.app-banner{position:relative;height:140px;overflow:hidden}.banner-img{width:100%;height:100%;object-fit:cover}.banner-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 0%,rgba(15,23,42,.3) 40%,var(--color-bg-card) 100%)}.app-content{flex:1;display:flex;gap:var(--space-md);padding:var(--space-lg);margin-top:-40px;position:relative;z-index:1}.app-icon{flex-shrink:0;width:72px;height:72px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 4px 12px #0006;border:2px solid var(--color-bg-card);background:var(--color-bg-card)}.app-icon img{width:100%;height:100%;object-fit:cover}.app-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-xs)}.app-category{font-size:var(--text-xs);font-weight:500;color:var(--color-accent-light);text-transform:uppercase;letter-spacing:.5px}.app-name{font-size:var(--text-lg);font-weight:700;color:var(--color-text-primary);line-height:1.2;margin:0}.app-description{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin:var(--space-xs) 0}.app-meta{display:flex;align-items:center;gap:var(--space-lg);margin-top:auto;position:absolute;right:15px;bottom:15px}.app-rating{display:flex;align-items:center;gap:var(--space-xs)}.stars{display:flex;gap:2px}.star{width:14px;height:14px}.star.filled{fill:#fbbf24}.star.half{fill:#fbbf24;opacity:.6}.star.empty{fill:var(--color-text-muted);opacity:.4}.rating-value{font-size:var(--text-sm);font-weight:600;color:var(--color-text-secondary)}.app-downloads{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--text-sm);color:var(--color-text-muted)}.download-icon{width:14px;height:14px;fill:currentColor}.beta-badge{position:absolute;top:var(--space-md);right:var(--space-md);padding:var(--space-xs) var(--space-sm);background:#ffe196b3;border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:700;color:#1e293b;letter-spacing:.5px;z-index:10}.beta-placeholder{font-size:var(--text-lg);font-weight:600;color:var(--color-text-muted)}.play-badge{position:absolute;bottom:var(--space-md);left:var(--space-md);display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:#22c55e26;border:1px solid rgba(34,197,94,.3);border-radius:var(--radius-md);font-size:var(--text-xs);font-weight:500;color:var(--color-success);opacity:0;transform:translateY(4px);transition:all var(--transition-fast)}.app-card:hover .play-badge{opacity:1;transform:translateY(0)}.play-icon{width:14px;height:14px;fill:currentColor}@media(max-width:1154px){.app-card{height:auto;min-height:280px}}@media(max-width:770px){.app-card{height:auto;min-height:auto}.app-banner{height:120px}.app-meta{position:relative;right:auto;bottom:auto;margin-top:var(--space-sm)}.play-badge{opacity:1;transform:translateY(0)}}@media(max-width:480px){.app-icon{width:56px;height:56px}.app-banner{height:100px}.app-content{padding:var(--space-md);gap:var(--space-sm)}.app-name{font-size:var(--text-base)}}.repo-card{display:flex;flex-direction:column;padding:var(--space-lg);background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);text-decoration:none;transition:all var(--transition-base);height:100%}.repo-card:hover{background:var(--color-bg-card-hover);border-color:var(--color-accent);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.repo-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md)}.repo-icon{color:var(--color-text-muted)}.repo-name{font-size:var(--text-lg);font-weight:600;color:var(--color-text-primary);font-family:var(--font-mono)}.repo-description{flex:1;font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.5;margin-bottom:var(--space-lg)}.repo-tags{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-lg)}.repo-tag{padding:var(--space-xs) var(--space-sm);font-size:var(--text-xs);font-weight:500;font-family:var(--font-mono);background:#3b82f61a;color:var(--color-accent-light);border-radius:var(--radius-sm);border:1px solid rgba(59,130,246,.2)}.repo-footer{margin-top:auto}.view-link{display:inline-flex;align-items:center;gap:var(--space-xs);font-size:var(--text-sm);font-weight:500;color:var(--color-accent-light);transition:gap var(--transition-fast)}.repo-card:hover .view-link{gap:var(--space-sm)}@media(max-width:480px){.repo-card{padding:var(--space-md)}.repo-name{font-size:var(--text-base);word-break:break-word}}.header{position:fixed;top:0;left:0;right:0;z-index:50;background:#0a0f1ccc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border-subtle);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.nav{display:flex;align-items:center;justify-content:space-between;height:var(--header-height)}.nav-logo{display:flex;align-items:center;font-family:var(--font-mono);font-size:var(--text-lg);font-weight:700;color:var(--color-text-primary);text-decoration:none}.logo-text{color:var(--color-text-primary)}.logo-dot{color:var(--color-accent)}.nav-links{display:flex;gap:var(--space-xl);list-style:none}.nav-link{position:relative;color:var(--color-text-secondary);font-size:var(--text-sm);font-weight:500;text-decoration:none;transition:color var(--transition-fast)}.nav-link:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--color-accent);transition:width var(--transition-base)}.nav-link:hover{color:var(--color-text-primary)}.nav-link:hover:after{width:100%}.nav-actions{display:flex;align-items:center;gap:var(--space-md)}.nav-toggle{display:none;width:44px;height:44px;background:transparent;border:none;cursor:pointer;padding:10px;-webkit-tap-highlight-color:transparent}.hamburger,.hamburger:before,.hamburger:after{display:block;width:24px;height:2px;background:var(--color-text-primary);border-radius:2px;transition:all var(--transition-base)}.hamburger{position:relative}.hamburger:before,.hamburger:after{content:"";position:absolute;left:0}.hamburger:before{top:-7px}.hamburger:after{top:7px}.mobile-menu{position:fixed;top:var(--header-height);left:0;right:0;bottom:0;background:var(--color-bg-primary);padding:var(--space-2xl) var(--space-lg);padding-bottom:calc(var(--space-2xl) + env(safe-area-inset-bottom));transform:translateY(-20px);opacity:0;visibility:hidden;transition:transform var(--transition-base),opacity var(--transition-base),visibility var(--transition-base);z-index:999;overflow-y:auto;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;justify-content:center}.mobile-menu.open{transform:translateY(0);opacity:1;visibility:visible}.mobile-menu-links{display:flex;flex-direction:column;gap:0;list-style:none;max-width:320px;width:100%;margin:0 auto}.mobile-menu-links li{opacity:0;transform:translate(-20px);transition:opacity .3s ease,transform .3s ease}.mobile-menu.open .mobile-menu-links li{opacity:1;transform:translate(0)}.mobile-menu.open .mobile-menu-links li:nth-child(1){transition-delay:60ms}.mobile-menu.open .mobile-menu-links li:nth-child(2){transition-delay:.12s}.mobile-menu.open .mobile-menu-links li:nth-child(3){transition-delay:.18s}.mobile-menu.open .mobile-menu-links li:nth-child(4){transition-delay:.24s}.mobile-menu.open .mobile-menu-links li:nth-child(5){transition-delay:.3s}.mobile-menu.open .mobile-menu-links li:nth-child(6){transition-delay:.36s}.mobile-menu.open .mobile-menu-links li:nth-child(7){transition-delay:.42s}.mobile-menu.closing .mobile-menu-links li{opacity:0;transform:translate(-20px)}.mobile-menu.closing .mobile-menu-links li:nth-child(7){transition-delay:0ms}.mobile-menu.closing .mobile-menu-links li:nth-child(6){transition-delay:50ms}.mobile-menu.closing .mobile-menu-links li:nth-child(5){transition-delay:.1s}.mobile-menu.closing .mobile-menu-links li:nth-child(4){transition-delay:.15s}.mobile-menu.closing .mobile-menu-links li:nth-child(3){transition-delay:.2s}.mobile-menu.closing .mobile-menu-links li:nth-child(2){transition-delay:.25s}.mobile-menu.closing .mobile-menu-links li:nth-child(1){transition-delay:.3s}.mobile-menu.closing{transform:translateY(0);opacity:1;visibility:visible}.mobile-link{display:flex;align-items:center;padding:var(--space-lg) var(--space-md);min-height:48px;color:var(--color-text-secondary);font-size:var(--text-xl);font-weight:500;text-decoration:none;border-bottom:1px solid var(--color-border-subtle);transition:color var(--transition-fast),background var(--transition-fast),padding-left var(--transition-fast);border-radius:var(--radius-md);border-bottom-left-radius:0;border-bottom-right-radius:0;-webkit-tap-highlight-color:transparent}.mobile-menu-links li:last-child .mobile-link{border-bottom:none}.mobile-link:hover,.mobile-link:active{color:var(--color-accent-light);background:#3b82f614;padding-left:var(--space-lg)}.nav-toggle[aria-expanded=true] .hamburger{background:transparent}.nav-toggle[aria-expanded=true] .hamburger:before{top:0;transform:rotate(45deg)}.nav-toggle[aria-expanded=true] .hamburger:after{top:0;transform:rotate(-45deg)}@media(max-width:768px){.nav-links{display:none}.nav-toggle{display:flex;align-items:center;justify-content:center}}@media(max-width:480px){.mobile-link{font-size:var(--text-lg);padding:var(--space-md) var(--space-md)}.mobile-menu{padding:var(--space-xl) var(--space-md);padding-bottom:calc(var(--space-xl) + env(safe-area-inset-bottom))}}.footer{margin-top:auto;padding:var(--space-3xl) 0 var(--space-xl);padding-bottom:calc(var(--space-xl) + env(safe-area-inset-bottom));background:var(--color-bg-secondary);border-top:1px solid var(--color-border-subtle)}.footer-content{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xl)}.footer-brand{display:flex;flex-direction:column;gap:var(--space-xs)}.footer-logo{font-family:var(--font-mono);font-size:var(--text-xl);font-weight:700;color:var(--color-text-primary)}.footer-logo .accent{color:var(--color-accent)}.footer-tagline{font-size:var(--text-sm);color:var(--color-text-muted)}.footer-links{display:flex;gap:var(--space-lg)}.footer-links a{color:var(--color-text-muted);transition:color var(--transition-fast),transform var(--transition-fast)}.footer-links a:hover{color:var(--color-accent);transform:translateY(-2px)}.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-lg);border-top:1px solid var(--color-border-subtle);font-size:var(--text-sm);color:var(--color-text-muted)}.footer-built{font-family:var(--font-mono);font-size:var(--text-xs)}@media(max-width:768px){.footer{padding:var(--space-2xl) 0 var(--space-lg);padding-bottom:calc(var(--space-lg) + env(safe-area-inset-bottom))}.footer-content{flex-direction:column;gap:var(--space-lg);text-align:center}.footer-bottom{flex-direction:column;gap:var(--space-sm);text-align:center}.footer-links a{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}}.logo3d-wrapper{position:relative;width:100%;max-width:500px;aspect-ratio:1}.logo3d-container{width:100%;height:100%;border-radius:var(--radius-xl);overflow:hidden;background:radial-gradient(circle,var(--color-bg-primary) 0%,var(--color-bg-primary) 40%,transparent 70%)}.logo3d-container canvas{display:block;opacity:0;transform:scale(.85);transition:opacity .8s ease-out,transform .8s ease-out}.logo3d-container.loaded canvas{opacity:1;transform:scale(1)}.logo3d-fallback{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:var(--color-bg-card);border-radius:var(--radius-xl)}.fallback-text{font-family:var(--font-mono);font-size:var(--text-5xl);font-weight:800;background:linear-gradient(135deg,var(--color-accent),var(--color-accent-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@media(max-width:968px){.logo3d-wrapper{max-width:350px}}@media(max-width:768px){.logo3d-wrapper{max-width:280px}}.speech-bubble-wrap{position:absolute;top:2%;right:-30px;z-index:10;width:210px;opacity:0;scale:.85;transition:opacity .6s ease,scale .5s cubic-bezier(.34,1.56,.64,1),top .4s ease,right .4s ease,width .4s ease;pointer-events:none;will-change:transform}.speech-bubble-wrap.speech-visible{opacity:1;scale:1;pointer-events:auto}.speech-bubble-wrap.speech-collapsed{top:12%;right:30%;width:auto}.speech-toolbar{display:flex;gap:4px;justify-content:flex-end;margin-bottom:4px}.speech-tool-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border:none;border-radius:var(--radius-sm);background:#1e293b99;color:var(--color-text-muted);cursor:pointer;transition:color var(--transition-fast),background var(--transition-fast);padding:0}.speech-tool-btn:hover{color:var(--color-accent-light);background:#3b82f626}.speech-collapsed .speech-tool-btn{width:30px;height:30px;background:#1e293bbf}.speech-bubble{background:#1e293be0;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(59,130,246,.25);border-radius:var(--radius-lg);padding:10px 14px;cursor:pointer;position:relative;transition:border-color var(--transition-fast),opacity .25s ease}.speech-bubble.speech-hidden{opacity:0;pointer-events:none;visibility:hidden}.speech-bubble:hover{border-color:#3b82f680}.speech-tail{position:absolute;bottom:-7px;left:22px;width:14px;height:14px;background:#1e293be0;border-right:1px solid rgba(59,130,246,.25);border-bottom:1px solid rgba(59,130,246,.25);transform:rotate(45deg);border-radius:0 0 3px}.speech-label{font-size:.65rem;font-weight:700;color:var(--color-accent-light);text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:3px}.speech-text{font-size:.78rem;line-height:1.45;color:var(--color-text-primary);margin:0;max-width:100%;word-wrap:break-word;max-height:200px;overflow:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1)}.speech-cursor{color:var(--color-accent-light);animation:speechBlink .5s step-end infinite;font-weight:300}@keyframes speechBlink{50%{opacity:0}}.speech-form{margin-top:0;max-height:0;opacity:0;overflow:hidden;transform:translateY(-6px);transition:max-height .3s cubic-bezier(.4,0,.2,1),opacity .25s ease,transform .25s ease,margin-top .3s ease;pointer-events:none}.speech-form.speech-form-visible{max-height:50px;margin-top:8px;opacity:1;transform:translateY(0);pointer-events:auto}.speech-input{width:100%;background:#0f172ad9;border:1px solid rgba(59,130,246,.3);border-radius:var(--radius-md);padding:7px 10px;font-size:.75rem;font-family:var(--font-sans);color:var(--color-text-primary);outline:none;transition:border-color var(--transition-fast)}.speech-input:focus{border-color:var(--color-accent)}.speech-input::placeholder{color:var(--color-text-muted)}.speech-input:disabled{opacity:.5;cursor:not-allowed}.speech-bubble-collapsed{cursor:pointer}.speech-text-collapsed{max-height:2.4em;overflow:hidden}.speech-bubble-collapsed:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2.2em;background:linear-gradient(to bottom,transparent 0%,rgba(30,41,59,.95) 80%);border-radius:0 0 var(--radius-lg) var(--radius-lg);pointer-events:none;opacity:1;transition:opacity .3s ease}.speech-bubble:not(.speech-bubble-collapsed):after{content:"";position:absolute;bottom:0;left:0;right:0;height:0;opacity:0;transition:opacity .3s ease}@media(max-width:968px){.speech-bubble-wrap{width:190px;right:-20px}}@media(max-width:768px){.speech-bubble-wrap{width:170px;right:-10px;top:-5px}.speech-bubble{padding:8px 11px}.speech-text{font-size:.72rem}}.particles-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:-1;pointer-events:none;opacity:0;animation:particlesFadeIn .8s ease-out .3s forwards}@keyframes particlesFadeIn{to{opacity:1}}
