:root{--color-white: #FFFFFF;--color-bg: #F8FAFC;--color-blue-50: #EFF6FF;--color-blue-100: #DBEAFE;--color-blue-200: #BFDBFE;--color-blue-300: #93C5FD;--color-blue-400: #60A5FA;--color-blue-500: #3B82F6;--color-blue-600: #2563EB;--color-blue-700: #1D4ED8;--color-blue-800: #1E40AF;--color-blue-900: #1E3A8A;--color-navy: #0F172A;--color-gray-50: #F8FAFC;--color-gray-100: #F1F5F9;--color-gray-200: #E2E8F0;--color-gray-300: #CBD5E1;--color-gray-400: #94A3B8;--color-gray-500: #64748B;--color-gray-600: #475569;--color-gray-700: #334155;--color-gray-800: #1E293B;--color-gray-900: #0F172A;--font-primary: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -4px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .08), 0 8px 10px -6px rgba(0, 0, 0, .04);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .15);--shadow-blue: 0 4px 14px rgba(37, 99, 235, .25);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--transition-spring: .5s cubic-bezier(.34, 1.56, .64, 1);--z-bg: -1;--z-content: 1;--z-header: 100;--z-modal: 200}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-primary);color:var(--color-navy);background:var(--color-white);line-height:1.6;overflow-x:hidden}a{text-decoration:none;color:inherit;transition:color var(--transition-fast)}img{max-width:100%;display:block}ul,ol{list-style:none}#particles-canvas{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:var(--z-bg);pointer-events:none}.container{max-width:1200px;margin:0 auto;padding:0 24px}.heading-xl{font-size:clamp(2.5rem,6vw,4.5rem);font-weight:800;line-height:1.08;letter-spacing:-.03em}.heading-lg{font-size:clamp(2rem,4vw,3rem);font-weight:700;line-height:1.15;letter-spacing:-.025em}.heading-md{font-size:clamp(1.5rem,3vw,2rem);font-weight:600;line-height:1.2;letter-spacing:-.02em}.heading-sm{font-size:clamp(1.1rem,2vw,1.35rem);font-weight:600;line-height:1.3}.text-body{font-size:1rem;line-height:1.7;color:var(--color-gray-600)}.text-sm{font-size:.875rem;line-height:1.6;color:var(--color-gray-500)}.text-blue{color:var(--color-blue-600)}.text-gray{color:var(--color-gray-400)}.navbar{position:fixed;top:0;left:0;right:0;z-index:var(--z-header);padding:16px 0;transition:all var(--transition-base);background:#fff0}.navbar.scrolled{background:#ffffffd9;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);box-shadow:0 1px 3px #0000000f;padding:10px 0}.nav-content{display:flex;align-items:center;justify-content:space-between}.logo{display:flex;align-items:center;gap:8px;font-size:1.5rem;font-weight:800;letter-spacing:-.02em;text-decoration:none;color:inherit}.nav-logo-img{height:48px;width:auto;object-fit:contain}.loader-logo-img{height:64px;width:auto;object-fit:contain}.footer-logo-img{height:48px;width:auto;object-fit:contain}.logo-text{display:flex;align-items:center}.logo .accent{color:var(--color-blue-600)}.nav-links{display:flex;align-items:center;gap:32px}.nav-links a{font-size:.9rem;font-weight:500;color:var(--color-gray-600);position:relative;padding:4px 0}.nav-links a:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--color-blue-600);transition:width var(--transition-base);border-radius:2px}.nav-links a:hover{color:var(--color-blue-600)}.nav-links a:hover:after{width:100%}.nav-links .btn{padding:8px 20px!important;color:#fff!important;border-radius:var(--radius-full);display:inline-flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem;transition:all var(--transition-base)}.nav-links .btn:after{display:none!important}.nav-links .btn:hover{color:#fff!important;background:var(--color-blue-700)!important;transform:translateY(-1px);box-shadow:var(--shadow-blue)}.lang-switcher{display:flex;align-items:center;gap:2px;background:var(--color-gray-100);border-radius:var(--radius-full);padding:3px}.lang-btn{border:none;background:transparent;font-family:var(--font-primary);font-size:.75rem;font-weight:600;padding:6px 12px;border-radius:var(--radius-full);cursor:pointer;color:var(--color-gray-500);transition:all var(--transition-fast);text-transform:uppercase;letter-spacing:.05em}.lang-btn.active{background:var(--color-blue-600);color:#fff;box-shadow:var(--shadow-blue)}.lang-btn:hover:not(.active){color:var(--color-navy);background:var(--color-gray-200)}.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px;z-index:300}.hamburger span{display:block;width:24px;height:2px;background:var(--color-navy);border-radius:2px;transition:all var(--transition-base)}.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-primary);font-weight:600;font-size:.9rem;padding:12px 28px;border-radius:var(--radius-full);border:none;cursor:pointer;transition:all var(--transition-base);white-space:nowrap}.btn-primary{background:var(--color-blue-600);color:#fff;box-shadow:var(--shadow-blue)}.btn-primary:hover{background:var(--color-blue-700);box-shadow:0 6px 20px #2563eb59;transform:translateY(-2px)}.btn-secondary{background:var(--color-gray-100);color:var(--color-navy);border:1px solid var(--color-gray-200)}.btn-secondary:hover{background:var(--color-gray-200);transform:translateY(-2px)}.btn-large{padding:16px 36px;font-size:1rem}.btn-outline{background:transparent;color:var(--color-blue-600);border:2px solid var(--color-blue-600)}.btn-outline:hover{background:var(--color-blue-600);color:#fff;transform:translateY(-2px)}.section{padding:120px 0;position:relative;z-index:var(--z-content)}.section-label{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:var(--color-blue-600);margin-bottom:12px}.section-title{font-size:clamp(2rem,4vw,3rem);font-weight:700;line-height:1.15;letter-spacing:-.025em;margin-bottom:16px}.section-subtitle{font-size:1.1rem;color:var(--color-gray-500);max-width:560px;line-height:1.7}.section-header{text-align:center;margin-bottom:64px}.section-header .section-subtitle{margin:0 auto}.hero{min-height:100vh;display:flex;align-items:center;position:relative;padding-top:80px;z-index:var(--z-content);overflow:hidden}.hero-content{position:relative;z-index:2;max-width:720px;margin:0 auto;text-align:center;display:flex;flex-direction:column;align-items:center}.hero-content:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:140%;height:140%;background:radial-gradient(circle,#fffffff2,#fff9 40%,#fff0 70%);z-index:-1;pointer-events:none}.hero-label{display:inline-flex;align-items:center;gap:8px;background:var(--color-blue-50);border:1px solid var(--color-blue-200);color:var(--color-blue-700);font-size:.8rem;font-weight:600;padding:6px 16px;border-radius:var(--radius-full);margin-bottom:24px;letter-spacing:.03em}.hero-label .dot{width:6px;height:6px;background:var(--color-blue-500);border-radius:50%;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.5)}}.hero-title{font-size:clamp(3rem,7vw,5rem);font-weight:800;line-height:1.15;letter-spacing:-.04em;margin-bottom:24px;min-height:3.8em;text-align:center}#hero-typewriter{display:inline}.hero-cursor{display:inline-block;width:4px;height:.9em;margin-left:4px;vertical-align:baseline;background:linear-gradient(180deg,#4285f4,#34a853,#fbbc05,#ea4335,#8e4ec6);border-radius:2px;animation:cursor-blink 1s step-end infinite;font-size:inherit}@keyframes cursor-blink{0%,to{opacity:1}50%{opacity:0}}.hero-description{font-size:1.15rem;color:var(--color-gray-500);line-height:1.8;margin-bottom:40px;max-width:580px;text-align:center}.hero-actions{display:flex;gap:16px;flex-wrap:wrap;justify-content:center}.hero-stats{display:flex;gap:48px;margin-top:64px;padding-top:32px;border-top:1px solid var(--color-gray-200);justify-content:center}.stat-item .stat-value{font-size:2rem;font-weight:800;color:var(--color-blue-600);letter-spacing:-.02em}.stat-item .stat-label{font-size:.85rem;color:var(--color-gray-400);margin-top:4px}.hero-visual{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(550px,90vw);height:min(550px,90vw);z-index:1;pointer-events:none;display:flex;justify-content:center;align-items:center;opacity:.85}.sphere-glow{position:absolute;width:100%;height:100%;background:radial-gradient(circle,rgba(37,99,235,.08) 0%,transparent 70%);border-radius:50%;animation:sphere-breathe 6s ease-in-out infinite}@keyframes sphere-breathe{0%,to{transform:scale(1);opacity:.6}50%{transform:scale(1.15);opacity:1}}.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.project-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--color-white);border:1px solid var(--color-gray-200);transition:all var(--transition-slow);cursor:pointer;transform-style:preserve-3d;will-change:transform}.project-card:hover{border-color:var(--color-blue-200)}.project-card-image{width:100%;height:220px;object-fit:cover;transition:transform var(--transition-slow)}.project-card:hover .project-card-image{transform:scale(1.05)}.project-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,23,42,.8) 0%,transparent 50%);opacity:0;transition:opacity var(--transition-base);display:flex;align-items:flex-end;padding:24px}.project-card:hover .project-card-overlay{opacity:1}.project-card-info{padding:20px}.project-card-tag{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-blue-600);margin-bottom:8px}.project-card-title{font-size:1.1rem;font-weight:600;color:var(--color-navy);margin-bottom:4px}.project-card-desc{font-size:.85rem;color:var(--color-gray-500);line-height:1.5}.services-section{background:var(--color-gray-50)}.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}.service-card{background:var(--color-white);border-radius:var(--radius-lg);padding:36px 28px;border:1px solid var(--color-gray-200);transition:all var(--transition-slow);position:relative;overflow:hidden}.service-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--color-blue-500),var(--color-blue-300));transform:scaleX(0);transform-origin:left;transition:transform var(--transition-slow)}.service-card:hover:before{transform:scaleX(1)}.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-xl);border-color:var(--color-blue-100)}.service-icon{width:56px;height:56px;border-radius:var(--radius-md);background:var(--color-blue-50);display:flex;align-items:center;justify-content:center;margin-bottom:20px;transition:all var(--transition-base)}.service-card:hover .service-icon{background:var(--color-blue-600)}.service-icon svg{width:28px;height:28px;stroke:var(--color-blue-600);transition:stroke var(--transition-base)}.service-card:hover .service-icon svg{stroke:#fff}.service-title{font-size:1.15rem;font-weight:600;margin-bottom:10px;color:var(--color-navy)}.service-desc{font-size:.9rem;color:var(--color-gray-500);line-height:1.6}.code-section{background:var(--color-navy);overflow:hidden;position:relative}.code-section .section-label{color:var(--color-blue-400)}.code-section .section-title{color:#fff}.code-showcase-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;perspective:1200px}.code-block-float{background:#1e293bf2;border:1px solid rgba(148,163,184,.15);border-radius:var(--radius-md);overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all var(--transition-slow);animation:code-float 6s ease-in-out infinite;box-shadow:0 8px 32px #0000004d,0 0 60px #3b82f60d}.code-block-float:nth-child(2){animation-delay:-2s}.code-block-float:nth-child(3){animation-delay:-4s}@keyframes code-float{0%,to{transform:translateY(0) rotateX(0)}50%{transform:translateY(-12px) rotateX(1deg)}}.code-block-float:hover{transform:translateY(-8px) scale(1.02)!important;box-shadow:0 12px 40px #0006,0 0 80px #3b82f61f;border-color:#3b82f64d}.code-block-header{display:flex;align-items:center;gap:6px;padding:10px 14px;background:#0f172a99;border-bottom:1px solid rgba(148,163,184,.1)}.code-dot{width:10px;height:10px;border-radius:50%}.code-dot.red{background:#ff5f57}.code-dot.yellow{background:#ffbd2e}.code-dot.green{background:#28c840}.code-filename{font-family:var(--font-mono);font-size:.7rem;color:var(--color-gray-400);margin-left:8px}.code-content{padding:16px 18px;margin:0;font-family:JetBrains Mono,Fira Code,Cascadia Code,monospace;font-size:.75rem;line-height:1.7;color:#e2e8f0;overflow-x:auto;white-space:pre}.code-content code{font-family:inherit}.code-keyword{color:#c084fc}.code-func{color:#60a5fa}.code-param{color:#fb923c}.code-str{color:#34d399}.code-num{color:#fbbf24}.code-comment{color:#64748b;font-style:italic}.typing-container{display:flex;align-items:center;gap:12px;margin-top:48px;padding:16px 24px;background:#1e293bcc;border:1px solid rgba(148,163,184,.1);border-radius:var(--radius-md);max-width:600px;margin-left:auto;margin-right:auto}.typing-prompt{color:#34d399;font-family:JetBrains Mono,monospace;font-weight:700;font-size:1rem}.typing-text{color:#e2e8f0;font-family:JetBrains Mono,monospace;font-size:.9rem;white-space:nowrap}.typing-cursor{color:var(--color-blue-400);font-family:JetBrains Mono,monospace;font-size:1.1rem;animation:blink-cursor 1s step-end infinite}@keyframes blink-cursor{0%,to{opacity:1}50%{opacity:0}}@media(max-width:768px){.code-showcase-grid{grid-template-columns:1fr}}.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.news-card{background:var(--color-white);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-gray-200);transition:all var(--transition-slow)}.news-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.news-card-image{width:100%;height:180px;object-fit:cover}.news-card-body{padding:20px}.news-card-date{font-size:.75rem;color:var(--color-gray-400);font-weight:500;margin-bottom:8px}.news-card-title{font-size:1.05rem;font-weight:600;margin-bottom:8px;color:var(--color-navy);line-height:1.4}.news-card-excerpt{font-size:.85rem;color:var(--color-gray-500);line-height:1.6}.blog-section{background:var(--color-gray-50)}.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.blog-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;position:relative;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;display:flex;flex-direction:column}.blog-card:hover{transform:translateY(-5px);border-color:#ffffff26;box-shadow:0 10px 30px #0003}.blog-card-image{width:100%;height:200px;object-fit:cover;border-bottom:1px solid var(--border-color)}.blog-card-content-wrapper{padding:30px;flex:1;display:flex;flex-direction:column}.blog-card-category{display:inline-flex;align-items:center;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-blue-600);background:var(--color-blue-50);padding:4px 10px;border-radius:var(--radius-full);margin-bottom:16px;width:fit-content}.blog-card-title{font-size:1.15rem;font-weight:600;color:var(--color-navy);margin-bottom:12px;line-height:1.4}.blog-card-excerpt{font-size:.875rem;color:var(--color-gray-500);line-height:1.7;flex:1}.blog-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:20px;padding-top:16px;border-top:1px solid var(--color-gray-100)}.blog-card-date{font-size:.8rem;color:var(--color-gray-400)}.blog-card-link{font-size:.85rem;font-weight:600;color:var(--color-blue-600);display:inline-flex;align-items:center;gap:4px;transition:gap var(--transition-fast)}.blog-card-link:hover{gap:8px}.site-footer{background:var(--color-navy);color:#fff;padding:80px 0 32px}.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}.footer-brand .logo{color:#fff;margin-bottom:16px}.footer-logo-img{height:36px;width:auto;border-radius:6px;object-fit:contain}.footer-desc{font-size:.9rem;color:var(--color-gray-400);line-height:1.7;max-width:300px}.footer-heading{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-gray-400);margin-bottom:20px}.footer-links{display:flex;flex-direction:column;gap:12px}.footer-links a{font-size:.9rem;color:var(--color-gray-300);transition:color var(--transition-fast)}.footer-links a:hover{color:var(--color-blue-400)}.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;align-items:center}.footer-copyright{font-size:.8rem;color:var(--color-gray-500)}.footer-socials{display:flex;gap:16px}.footer-socials a{width:36px;height:36px;border-radius:50%;background:#ffffff14;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.footer-socials a:hover{background:var(--color-blue-600);transform:translateY(-2px)}.footer-socials svg{width:16px;height:16px;fill:var(--color-gray-400)}.footer-socials a:hover svg{fill:#fff}.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}.reveal-delay-4{transition-delay:.4s}.mobile-menu{position:fixed;top:0;left:0;width:100%;height:100vh;background:#fffffffa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:150;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;opacity:0;pointer-events:none;transition:opacity var(--transition-base)}.mobile-menu.open{opacity:1;pointer-events:all}.mobile-menu a{font-size:1.5rem;font-weight:600;color:var(--color-navy);transition:color var(--transition-fast)}.mobile-menu a:hover{color:var(--color-blue-600)}@media(max-width:1024px){.services-grid,.projects-grid{grid-template-columns:repeat(2,1fr)}.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}@media(max-width:768px){.section{padding:80px 0}.nav-links{display:none}.hamburger{display:flex}.projects-grid,.news-grid,.blog-grid,.services-grid{grid-template-columns:1fr}.hero-stats{gap:24px;flex-wrap:wrap}.footer-grid{grid-template-columns:1fr;gap:32px}.footer-bottom{flex-direction:column;gap:16px;text-align:center}.hero-title{font-size:clamp(2.2rem,8vw,3.5rem);min-height:4.8em}}@media(max-width:480px){.container{padding:0 16px}.hero-title{min-height:5.5em}.hero-actions{flex-direction:column}.hero-actions .btn{width:100%}.hero-stats{flex-direction:column;gap:16px}}.custom-cursor{position:fixed;width:20px;height:20px;border:2px solid var(--color-blue-500);border-radius:50%;pointer-events:none;z-index:9999;transition:transform .15s ease-out,opacity .15s;transform:translate(-50%,-50%);mix-blend-mode:difference}.custom-cursor.hover{transform:translate(-50%,-50%) scale(2);background:#2563eb1a}.cursor-dot{position:fixed;width:5px;height:5px;background:var(--color-blue-600);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%)}.loader{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--color-white);display:flex;align-items:center;justify-content:center;z-index:10000;transition:opacity .6s ease,visibility .6s ease}#loaderCanvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:2}.loader.hidden{opacity:0;visibility:hidden}.loader-content{text-align:center}.loader-logo{font-size:2rem;font-weight:800;letter-spacing:-.02em;animation:loader-pulse 1.5s ease-in-out infinite;display:flex;align-items:center;gap:12px;flex-direction:column}.loader-logo-img{height:70px;width:auto;border-radius:8px;object-fit:contain}@keyframes loader-pulse{0%,to{opacity:.3}50%{opacity:1}}::selection{background:var(--color-blue-100);color:var(--color-blue-900)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--color-gray-100)}::-webkit-scrollbar-thumb{background:var(--color-blue-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-blue-500)}.service-shape-canvas{display:block;width:120px;height:120px;margin:0 auto 8px;pointer-events:none}.service-card{text-align:center}#hero-globe-canvas{position:absolute;right:0;top:50%;transform:translateY(-50%);pointer-events:none;opacity:.7}.card-shine{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:5;opacity:0;transition:opacity .3s ease;border-radius:inherit}.gradient-blob{pointer-events:none;z-index:0}.services-section>.container,#news>.container{position:relative;z-index:1}.tech-stack-section{padding:80px 0;overflow:hidden;position:relative}.tech-stack-section:before{content:"";position:absolute;top:15%;left:-5%;width:350px;height:350px;border-radius:50%;background:radial-gradient(circle,rgba(66,133,244,.06) 0%,transparent 70%);filter:blur(30px);animation:tech-float-1 12s ease-in-out infinite alternate;pointer-events:none}.tech-stack-section:after{content:"";position:absolute;bottom:10%;right:-3%;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(142,78,198,.06) 0%,transparent 70%);filter:blur(25px);animation:tech-float-2 10s ease-in-out infinite alternate;pointer-events:none}@keyframes tech-float-1{0%{transform:translate(0) scale(1)}to{transform:translate(30px,-20px) scale(1.15)}}@keyframes tech-float-2{0%{transform:translate(0) scale(1)}to{transform:translate(-20px,15px) scale(1.1)}}.tech-tabs{display:flex;justify-content:center;gap:10px;margin-bottom:48px;flex-wrap:wrap;position:relative;z-index:1}.tech-tab{padding:10px 24px;border-radius:var(--radius-full);border:1.5px solid var(--color-gray-200);background:var(--color-white);color:var(--color-gray-600);font-size:.9rem;font-weight:500;font-family:var(--font-primary);cursor:pointer;transition:all var(--transition-base);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.tech-tab:hover{border-color:var(--color-blue-300);color:var(--color-blue-600);background:var(--color-blue-50);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb1a}.tech-tab.active{background:var(--color-blue-600);color:#fff;border-color:var(--color-blue-600);box-shadow:var(--shadow-blue);transform:translateY(-2px)}.tech-scroll-container{position:relative;width:100vw;margin-left:calc(-50vw + 50%)}.tech-scroll-container:before,.tech-scroll-container:after{content:"";position:absolute;top:0;bottom:0;width:150px;z-index:2;pointer-events:none}.tech-scroll-container:before{left:0;background:linear-gradient(to right,var(--color-bg),transparent)}.tech-scroll-container:after{right:0;background:linear-gradient(to left,var(--color-bg),transparent)}.tech-scroll-row{overflow:hidden;padding:10px 0;margin-bottom:20px}.tech-scroll-track{display:flex;gap:20px;width:max-content;padding-left:0;animation:tech-scroll-left 30s linear infinite}.tech-scroll-row[data-direction=right] .tech-scroll-track{animation:tech-scroll-right 32s linear infinite}.tech-item{flex-shrink:0;width:140px;height:140px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#ffffffd9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(226,232,240,.6);border-radius:var(--radius-lg);transition:all .4s cubic-bezier(.23,1,.32,1);cursor:default;box-shadow:0 2px 8px #0000000a;position:relative;overflow:hidden}.tech-item:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:conic-gradient(from 180deg,transparent 0deg,rgba(66,133,244,.08) 60deg,rgba(142,78,198,.06) 120deg,transparent 180deg,rgba(6,182,212,.06) 240deg,rgba(37,99,235,.08) 300deg,transparent 360deg);opacity:0;transition:opacity .5s ease;animation:tech-glow-spin 6s linear infinite;pointer-events:none}.tech-item:hover:before{opacity:1}@keyframes tech-glow-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tech-item:hover{transform:translateY(-8px) scale(1.06);box-shadow:0 12px 24px #2563eb1f,0 4px 8px #0000000f;border-color:#4285f44d;background:#fffffff2}.tech-item img{width:50px;height:50px;object-fit:contain;transition:all .4s cubic-bezier(.23,1,.32,1);position:relative;z-index:1}.tech-item:hover img{transform:scale(1.15) translateY(-2px);filter:drop-shadow(0 4px 8px rgba(0,0,0,.1))}.tech-item span{font-size:.8rem;font-weight:600;color:var(--color-gray-700);text-align:center;position:relative;z-index:1}.tech-item.hidden{display:none}@keyframes tech-scroll-left{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes tech-scroll-right{0%{transform:translate(-50%)}to{transform:translate(0)}}.tech-scroll-row:hover .tech-scroll-track{animation-play-state:paused}.tech-3d-shape{position:absolute;pointer-events:none;z-index:0}@media(max-width:768px){.tech-item{width:100px;height:100px;gap:8px}.tech-item img{width:36px;height:36px}.tech-item span{font-size:.7rem}.tech-tabs{gap:6px}.tech-tab{padding:8px 16px;font-size:.8rem}.tech-scroll-container:before,.tech-scroll-container:after{width:40px}.tech-stack-section:before,.tech-stack-section:after{display:none}}
