@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap";.theme-toggle{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;transition:all var(--transition-base);font-size:20px}.theme-toggle:hover{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary);transform:rotate(15deg)}.nav{position:fixed;top:0;left:0;right:0;z-index:var(--z-sticky);padding:var(--space-4) 0;transition:all var(--transition-base)}.nav-scrolled{background:#09090be6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--color-border-light);padding:var(--space-3) 0}[data-theme=light] .nav-scrolled{background:#ffffffe6}.nav-container{display:flex;align-items:center;justify-content:space-between}.nav-logo{font-family:var(--font-sans);font-size:var(--text-base);font-weight:600;color:var(--color-text);text-decoration:none;letter-spacing:-.01em;transition:all var(--transition-fast)}@media(max-width:480px){.nav-logo{font-size:var(--text-sm)}}.nav-logo:hover{color:var(--color-primary)}.nav-logo-bracket{color:var(--color-primary);font-weight:400}.nav-links{display:flex;gap:var(--space-8)}@media(max-width:968px){.nav-links{display:none}}.nav-link{position:relative;color:var(--color-text-secondary);font-size:var(--text-xs);font-weight:500;text-decoration:none;transition:color var(--transition-fast);padding:var(--space-2) 0}.nav-link:before{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--color-primary);transition:width var(--transition-base);border-radius:var(--radius-full)}.nav-link:hover{color:var(--color-text)}.nav-link:hover:before{width:100%}.nav-actions{display:flex;align-items:center;gap:var(--space-3)}@media(max-width:480px){.nav-actions{gap:var(--space-2)}}.nav-mobile-toggle{display:none;align-items:center;justify-content:center;width:40px;height:40px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent}@media(max-width:480px){.nav-mobile-toggle{width:36px;height:36px}}.nav-mobile-toggle:hover,.nav-mobile-toggle:active{border-color:var(--color-primary);color:var(--color-primary)}@media(max-width:968px){.nav-mobile-toggle{display:flex}}.mobile-menu{position:fixed;inset:0;z-index:var(--z-overlay);background:var(--color-bg);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6)}.mobile-menu:before{content:"";position:absolute;top:20%;left:50%;transform:translate(-50%);width:300px;height:300px;background:radial-gradient(circle,var(--color-primary-glow) 0%,transparent 70%);filter:blur(80px);opacity:.3}.mobile-menu-content{position:relative;display:flex;flex-direction:column;gap:var(--space-6);text-align:center;width:100%;max-width:300px}.mobile-menu-link{display:flex;align-items:center;justify-content:center;gap:var(--space-3);font-family:var(--font-sans);font-size:var(--text-lg);font-weight:600;color:var(--color-text);text-decoration:none;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent}.mobile-menu-link:hover,.mobile-menu-link:active{color:var(--color-primary);background:var(--color-bg-card)}.mobile-menu-link .mono{font-size:var(--text-xs);color:var(--color-primary);opacity:.7}[data-theme=light] .nav-scrolled{box-shadow:0 1px 3px #0000000f}[data-theme=light] .nav-mobile-toggle{background:var(--color-surface)}[data-theme=light] .mobile-menu:before{opacity:.15}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-family:var(--font-sans);font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:6px 12px;font-size:11px}.btn-md{padding:8px 18px;font-size:12px}.btn-lg{padding:10px 22px;font-size:13px}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px)}.btn-secondary{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-bg-card);border-color:var(--color-text-muted)}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--color-bg-card);color:var(--color-text)}.btn-icon{display:flex;align-items:center}[data-theme=light] .btn-primary{box-shadow:0 1px 2px #0000001a}[data-theme=light] .btn-primary:hover:not(:disabled){box-shadow:0 2px 6px #1d6fd140}[data-theme=light] .btn-secondary{background:var(--color-bg-elevated)}[data-theme=light] .btn-secondary:hover:not(:disabled){background:var(--color-surface);border-color:var(--color-border)}[data-theme=light] .btn-ghost:hover:not(:disabled){background:var(--color-surface)}.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:120px var(--space-4) var(--space-16)}@media(max-width:768px){.hero{min-height:calc(100vh - 60px);padding:100px var(--space-4) var(--space-12)}}.hero-texture{position:absolute;inset:0;opacity:.4;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:180px 180px;mix-blend-mode:overlay}[data-theme=light] .hero-texture{opacity:.25;mix-blend-mode:multiply}.hero-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none}.hero-gradient{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}.hero-gradient-1{top:25%;left:50%;transform:translate(-50%);width:550px;height:550px;background:radial-gradient(circle,var(--color-primary-glow) 0%,transparent 65%)}.hero-gradient-2{top:10%;right:5%;width:350px;height:350px;background:radial-gradient(circle,rgba(88,166,255,.2) 0%,transparent 60%)}.hero-gradient-3{bottom:15%;left:5%;width:300px;height:300px;background:radial-gradient(circle,rgba(139,92,246,.15) 0%,transparent 60%)}@media(max-width:768px){.hero-gradient-1{width:350px;height:350px}.hero-gradient-2{width:200px;height:200px}.hero-gradient-3{width:180px;height:180px}}.hero-float-item{position:absolute;color:var(--color-primary);pointer-events:none;-webkit-user-select:none;user-select:none}.hero-float-icon{font-size:1.4rem;display:flex;align-items:center;justify-content:center}.hero-float-text{font-family:var(--font-mono);font-size:.875rem;font-weight:600;letter-spacing:.02em}@media(max-width:768px){.hero-float-icon{font-size:1.1rem}.hero-float-text{font-size:.75rem}}@media(max-width:480px){.hero-float-item{opacity:.15!important}.hero-float-icon{font-size:.9rem}.hero-float-text{font-size:.65rem}}.hero-content{position:relative;z-index:1;text-align:center;display:flex;flex-direction:column;align-items:center;padding:0 var(--space-4)}.hero-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--text-xs);color:var(--color-text-secondary);margin-bottom:var(--space-10)}@media(max-width:480px){.hero-badge{font-size:10px;padding:6px 12px;margin-bottom:var(--space-8)}}.hero-badge-dot{width:6px;height:6px;background:var(--color-success);border-radius:50%;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.hero-greeting{font-size:var(--text-lg);color:var(--color-text-secondary);margin-bottom:var(--space-3)}@media(max-width:480px){.hero-greeting{font-size:var(--text-base);margin-bottom:var(--space-2)}}.hero-name{font-size:4rem;font-weight:700;line-height:1.1;margin-bottom:var(--space-4);letter-spacing:-.03em;color:var(--color-text)}@media(max-width:768px){.hero-name{font-size:3rem}}@media(max-width:480px){.hero-name{font-size:2.25rem;margin-bottom:var(--space-3)}}.hero-title{font-size:var(--text-2xl);font-weight:500;line-height:1.3;margin-bottom:var(--space-8);color:var(--color-text)}@media(max-width:768px){.hero-title{font-size:var(--text-xl);margin-bottom:var(--space-6)}}@media(max-width:480px){.hero-title{font-size:var(--text-lg);margin-bottom:var(--space-5)}}.hero-description{font-size:var(--text-base);color:var(--color-text-secondary);line-height:1.7;margin-bottom:var(--space-10);max-width:500px}@media(max-width:768px){.hero-description{margin-bottom:var(--space-8)}}@media(max-width:480px){.hero-description{font-size:var(--text-sm);max-width:100%;margin-bottom:var(--space-6)}}.hero-actions{display:flex;justify-content:center}.section-wrapper{padding:var(--space-16) 0;position:relative;overflow:hidden}@media(max-width:768px){.section-wrapper{padding:var(--space-12) 0}}@media(max-width:480px){.section-wrapper{padding:var(--space-10) 0}}.section-dark{background:var(--color-bg-elevated)}.section-dark:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:600px;height:300px;background:radial-gradient(ellipse,var(--color-primary-glow) 0%,transparent 70%);filter:blur(100px);opacity:.1;pointer-events:none}@media(max-width:768px){.section-dark:before{width:400px;height:200px}}.section-header{margin-bottom:var(--space-10);text-align:center}@media(max-width:768px){.section-header{margin-bottom:var(--space-8)}}.section-title{font-family:var(--font-sans);font-size:var(--text-2xl);font-weight:600;margin-bottom:var(--space-3);display:inline-flex;align-items:center;gap:var(--space-3);letter-spacing:-.01em}@media(max-width:768px){.section-title{font-size:var(--text-xl)}}@media(max-width:480px){.section-title{font-size:var(--text-lg)}}.section-title-hash{color:var(--color-primary);font-size:.8em;opacity:.6}.section-subtitle{font-size:var(--text-sm);color:var(--color-text-muted);max-width:400px;margin:0 auto}@media(max-width:480px){.section-subtitle{font-size:var(--text-xs);max-width:100%;padding:0 var(--space-2)}}[data-theme=light] .section-dark{background:var(--color-surface)}[data-theme=light] .section-dark:before{opacity:.15}[data-theme=light] .section-subtitle{color:var(--color-text-secondary)}.about-bento{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:auto auto auto;gap:var(--space-5)}@media(max-width:1024px){.about-bento{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.about-bento{grid-template-columns:1fr}}.bento-card{position:relative;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-8);overflow:hidden;transition:all var(--transition-base)}.bento-card:hover{border-color:var(--color-primary)}.bento-main{grid-column:span 2;display:flex;align-items:center;min-height:200px}.bento-glow{position:absolute;top:-50%;left:-20%;width:60%;height:200%;background:radial-gradient(circle,var(--color-primary-glow) 0%,transparent 60%);filter:blur(60px);opacity:.3;pointer-events:none}.bento-intro{position:relative;font-size:var(--text-xl);font-weight:500;line-height:1.6;color:var(--color-text);margin:0}@media(max-width:768px){.bento-intro{font-size:var(--text-lg)}}.bento-specialty{cursor:pointer}.bento-specialty:hover .bento-icon{background:var(--color-primary);color:var(--color-bg);box-shadow:0 0 30px var(--color-primary-glow)}.bento-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--color-surface);border-radius:var(--radius-lg);color:var(--color-primary);font-size:28px;margin-bottom:var(--space-5);transition:all var(--transition-base)}.bento-specialty h3{font-family:var(--font-sans);font-size:var(--text-lg);font-weight:600;margin-bottom:var(--space-3);color:var(--color-text)}.bento-specialty p{font-size:var(--text-base);color:var(--color-text-secondary);margin:0;line-height:1.6}.bento-code{grid-column:span 2;grid-row:span 2;background:var(--color-bg-elevated);padding:0;overflow:hidden}@media(max-width:1024px){.bento-code{grid-column:span 2;grid-row:span 1}}.code-header{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-5);background:var(--color-bg-card);border-bottom:1px solid var(--color-border)}.code-dot{width:12px;height:12px;border-radius:50%}.code-dot-red{background:#ff5f57}.code-dot-yellow{background:#febc2e}.code-dot-green{background:#28c840}.code-title{margin-left:auto;font-size:var(--text-xs);color:var(--color-text-muted)}.code-content{padding:var(--space-6);font-size:var(--text-sm);line-height:1.8;color:var(--color-text-secondary);overflow-x:auto;margin:0}.code-keyword{color:#a78bfa}.code-function{color:var(--color-primary)}.code-class{color:#fbbf24}.code-string{color:#34d399}.bento-stats{grid-column:span 2;display:flex;align-items:center;justify-content:center;gap:var(--space-10);background:linear-gradient(135deg,var(--color-bg-card) 0%,var(--color-bg-elevated) 100%)}@media(max-width:640px){.bento-stats{grid-column:span 1;gap:var(--space-6)}}.stat-item{display:flex;flex-direction:column;align-items:center;text-align:center}.stat-number{font-family:var(--font-sans);font-size:var(--text-3xl);font-weight:700;color:var(--color-primary);line-height:1;margin-bottom:var(--space-2)}.stat-label{font-size:var(--text-sm);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.1em}.stat-divider{width:1px;height:60px;background:var(--color-border)}.text-primary{color:var(--color-primary)}.services-container{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}@media(max-width:1024px){.services-container{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.services-container{grid-template-columns:1fr}}.service-card{position:relative;padding:1px;border-radius:var(--radius-xl);background:var(--color-border);transition:all var(--transition-base)}.service-card:hover{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-hover))}.service-card-inner{position:relative;height:100%;padding:var(--space-8);background:var(--color-bg-card);border-radius:calc(var(--radius-xl) - 1px);overflow:hidden}.service-border{position:absolute;inset:-2px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-hover),var(--color-primary));background-size:200% 200%;border-radius:var(--radius-xl);opacity:0;z-index:-1;transition:opacity var(--transition-base);animation:gradientShift 3s ease infinite}.service-card:hover .service-border{opacity:1}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.service-number{position:absolute;top:var(--space-6);right:var(--space-6);font-size:var(--text-3xl);font-weight:500;color:var(--color-surface);opacity:.5;line-height:1}.service-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-light);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-primary);font-size:24px;margin-bottom:var(--space-6);transition:all var(--transition-base)}.service-card:hover .service-icon{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-bg);box-shadow:0 0 40px var(--color-primary-glow)}.service-title{font-family:var(--font-sans);font-size:var(--text-xl);font-weight:600;margin-bottom:var(--space-5);color:var(--color-text);letter-spacing:-.01em}.service-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-4)}.service-list li{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-base);color:var(--color-text-secondary);transition:color var(--transition-fast)}.service-card:hover .service-list li{color:var(--color-text)}.service-list-icon{flex-shrink:0;color:var(--color-primary);font-size:14px;transition:transform var(--transition-fast)}.service-card:hover .service-list-icon{transform:translate(3px)}.service-glow{position:absolute;top:-50%;left:-50%;width:100%;height:100%;background:radial-gradient(circle,var(--color-primary-glow) 0%,transparent 60%);filter:blur(60px);opacity:0;transition:opacity var(--transition-slow);pointer-events:none}.service-card:hover .service-glow{opacity:.4}.portfolio-featured{display:flex;flex-direction:column;gap:var(--space-5)}.portfolio-subtitle{font-size:var(--text-sm);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.2em;margin-top:var(--space-16);margin-bottom:var(--space-8)}.portfolio-others{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-5)}@media(max-width:768px){.portfolio-others{grid-template-columns:1fr}}.project-card{position:relative;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-base)}.project-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--color-primary);transform:scaleX(0);transform-origin:left;transition:transform var(--transition-base)}.project-card:hover{border-color:var(--color-primary);box-shadow:0 20px 60px #0006}.project-card:hover:before{transform:scaleX(1)}.project-card.expanded{border-color:var(--color-primary)}.project-card.expanded:before{transform:scaleX(1)}.project-card-compact .project-header-content{padding:var(--space-4) 0}.project-card-compact .project-name{font-size:var(--text-xl)}.project-card-compact .project-summary{font-size:var(--text-sm)}.project-header{width:100%;display:flex;align-items:flex-start;justify-content:space-between;padding:var(--space-8);background:transparent;border:none;cursor:pointer;text-align:left;color:inherit;gap:var(--space-5);transition:background var(--transition-fast)}.project-header:hover{background:var(--color-bg-elevated)}.project-header-content{flex:1;min-width:0}.project-industry{display:inline-block;font-size:var(--text-xs);color:var(--color-primary);text-transform:uppercase;letter-spacing:.15em;margin-bottom:var(--space-3);padding:var(--space-1) var(--space-3);background:var(--color-primary-light);border-radius:var(--radius-sm)}.project-name{font-family:var(--font-sans);font-size:var(--text-xl);font-weight:600;color:var(--color-text);margin-bottom:var(--space-3);line-height:1.3;letter-spacing:-.01em}.project-summary{font-size:var(--text-base);color:var(--color-text-secondary);line-height:1.6;margin:0}.project-toggle{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:20px;margin-top:var(--space-1);transition:all var(--transition-fast)}.project-card:hover .project-toggle{border-color:var(--color-primary);color:var(--color-primary)}.project-details{overflow:hidden}.project-details-content{padding:0 var(--space-8) var(--space-8);border-top:1px solid var(--color-border);padding-top:var(--space-8)}.project-section{margin-bottom:var(--space-8)}.project-section:last-of-type{margin-bottom:var(--space-5)}.project-section h4{font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;color:var(--color-text);margin-bottom:var(--space-3);text-transform:uppercase;letter-spacing:.1em}.project-section p{font-size:var(--text-base);color:var(--color-text-secondary);line-height:1.7;margin:0}.project-tech{display:flex;flex-wrap:wrap;gap:var(--space-2)}.tech-tag{display:inline-block;padding:var(--space-2) var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text-secondary);transition:all var(--transition-fast)}.tech-tag:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.project-link{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);background:var(--color-primary);color:var(--color-bg);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;text-decoration:none;transition:all var(--transition-base);margin-top:var(--space-3);text-transform:uppercase;letter-spacing:.05em}.project-link:hover{background:var(--color-primary-hover);transform:translateY(-2px);box-shadow:0 10px 30px var(--color-primary-glow);color:var(--color-bg)}.project-link svg{font-size:16px}.tech-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}@media(max-width:1024px){.tech-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.tech-grid{grid-template-columns:1fr;gap:var(--space-3)}}.tech-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);transition:all var(--transition-base)}@media(max-width:480px){.tech-card{padding:var(--space-4)}}.tech-card:hover{border-color:var(--color-primary);box-shadow:0 0 20px #2680eb14}.tech-card-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border)}.tech-card-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--color-primary-light);border-radius:var(--radius-md);color:var(--color-primary);font-size:16px;flex-shrink:0}@media(max-width:480px){.tech-card-icon{width:28px;height:28px;font-size:14px}}.tech-card-title{font-family:var(--font-sans);font-size:var(--text-xs);font-weight:600;color:var(--color-text);margin:0}.tech-card-items{display:flex;flex-wrap:wrap;gap:6px}.tech-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-full);cursor:default;transition:all var(--transition-fast)}@media(max-width:480px){.tech-pill{padding:5px 8px;gap:4px}}.tech-pill:hover{border-color:var(--color-primary);background:var(--color-bg-card-hover)}.tech-pill-primary{background:var(--color-primary-light);border-color:#2680eb40}.tech-pill-primary:hover{background:#2680eb26;border-color:var(--color-primary)}.tech-pill-primary .tech-pill-icon{color:var(--color-primary)}.tech-pill-icon{display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--color-text-muted);transition:color var(--transition-fast)}@media(max-width:480px){.tech-pill-icon{font-size:11px}}.tech-pill:hover .tech-pill-icon{color:var(--color-primary)}.tech-pill-name{font-size:11px;font-weight:500;color:var(--color-text-secondary);white-space:nowrap}@media(max-width:480px){.tech-pill-name{font-size:10px}}.tech-pill:hover .tech-pill-name,.tech-pill-primary .tech-pill-name{color:var(--color-text)}[data-theme=light] .tech-card{box-shadow:var(--shadow-sm)}[data-theme=light] .tech-card:hover{box-shadow:0 4px 20px #1d6fd11f}[data-theme=light] .tech-pill{background:var(--color-surface)}[data-theme=light] .tech-pill-primary{background:#1d6fd11a;border-color:#1d6fd14d}[data-theme=light] .tech-pill-primary:hover{background:#1d6fd126}.testimonials-container{display:flex;align-items:center;gap:var(--space-4);max-width:800px;margin:0 auto}@media(max-width:768px){.testimonials-container{flex-direction:column;gap:var(--space-6)}}.testimonial-nav{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text);font-size:24px;cursor:pointer;transition:all var(--transition-base)}.testimonial-nav:hover{border-color:var(--color-primary);color:var(--color-primary);transform:scale(1.05)}@media(max-width:768px){.testimonial-nav{display:none}}.testimonial-content{flex:1;min-width:0;overflow:hidden}.testimonial-card{padding:var(--space-8);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-align:center}.testimonial-rating{display:flex;justify-content:center;gap:var(--space-1);margin-bottom:var(--space-6)}.testimonial-rating svg{font-size:20px}.star-filled{color:#fbbf24}.star-empty{color:var(--color-border)}.testimonial-quote{font-size:var(--text-lg);color:var(--color-text);line-height:1.8;margin:0 0 var(--space-6);font-style:italic}@media(max-width:640px){.testimonial-quote{font-size:var(--text-base)}}.testimonial-author{display:flex;align-items:center;justify-content:center;gap:var(--space-4);margin-bottom:var(--space-4)}.testimonial-avatar{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-primary);color:#fff;border-radius:var(--radius-full);font-weight:600;font-size:var(--text-lg)}.testimonial-author-info{display:flex;flex-direction:column;text-align:left}.testimonial-name{color:var(--color-text);font-weight:600}.testimonial-role{font-size:var(--text-sm);color:var(--color-text-secondary)}.testimonial-company{font-size:var(--text-xs);color:var(--color-text-muted)}.testimonial-project{display:inline-block;padding:var(--space-2) var(--space-4);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-xs);color:var(--color-text-muted)}.testimonial-dots{display:flex;justify-content:center;gap:var(--space-2);margin-top:var(--space-6)}.testimonial-dot{width:10px;height:10px;border-radius:var(--radius-full);background:var(--color-border);border:none;cursor:pointer;transition:all var(--transition-base);padding:0}.testimonial-dot:hover{background:var(--color-text-muted)}.testimonial-dot.active{background:var(--color-primary);width:24px}.contact-container{display:grid;grid-template-columns:1fr 1.2fr;gap:var(--space-12);align-items:start}@media(max-width:968px){.contact-container{grid-template-columns:1fr;gap:var(--space-8)}}.contact-info{max-width:400px}@media(max-width:968px){.contact-info{max-width:none}}.contact-info-title{font-family:var(--font-sans);font-size:var(--text-xl);font-weight:600;color:var(--color-text);margin-bottom:var(--space-4)}@media(max-width:480px){.contact-info-title{font-size:var(--text-lg)}}.contact-info-text{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.7;margin-bottom:var(--space-6)}.contact-details{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-5);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--space-6)}.contact-detail-item{display:flex;justify-content:space-between;align-items:center}.contact-detail-label{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.contact-detail-value{font-size:var(--text-sm);color:var(--color-text);font-weight:500}.contact-social-label{display:block;font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-3)}.contact-social-links{display:flex;flex-wrap:wrap;gap:var(--space-2)}.contact-social-link{padding:6px 12px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-xs);font-weight:500;color:var(--color-text-secondary);text-decoration:none;transition:all var(--transition-base)}.contact-social-link:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.contact-form{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6)}@media(max-width:480px){.contact-form{padding:var(--space-5)}}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}@media(max-width:480px){.form-row{grid-template-columns:1fr}}.form-group{margin-bottom:var(--space-4)}.form-label{display:block;font-size:var(--text-xs);color:var(--color-text-muted);margin-bottom:var(--space-2)}.form-input{width:100%;padding:var(--space-3);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);color:var(--color-text);transition:all var(--transition-fast);outline:none}.form-input::placeholder{color:var(--color-text-muted)}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.form-textarea{resize:vertical;min-height:100px}.form-submit{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all var(--transition-base)}.form-submit:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px)}.form-submit:disabled{opacity:.6;cursor:not-allowed}.form-message{margin-top:var(--space-4);padding:var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);text-align:center}.form-success{background:#22c55e1a;color:var(--color-success);border:1px solid rgba(34,197,94,.2)}.form-error{background:#ef44441a;color:var(--color-error);border:1px solid rgba(239,68,68,.2)}@media(max-width:480px){.form-input{padding:10px 12px;font-size:var(--text-xs)}.form-submit{width:100%}}[data-theme=light] .contact-form{box-shadow:var(--shadow-md)}[data-theme=light] .contact-details{box-shadow:var(--shadow-sm)}[data-theme=light] .form-input{background:#fff}[data-theme=light] .form-input:focus{box-shadow:0 0 0 3px #1d6fd126}[data-theme=light] .contact-social-link{background:var(--color-surface)}[data-theme=light] .contact-social-link:hover{background:#1d6fd11a}.footer{position:relative;background:var(--color-bg-elevated);border-top:1px solid var(--color-border);padding:var(--space-16) 0 var(--space-8);overflow:hidden}.footer:before{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:600px;height:300px;background:radial-gradient(ellipse,var(--color-primary-glow) 0%,transparent 70%);filter:blur(100px);opacity:.1;pointer-events:none}.footer-container{position:relative;max-width:var(--max-width);margin:0 auto;padding:0 var(--space-8)}.footer-main{display:grid;grid-template-columns:1fr 2fr;gap:var(--space-16);margin-bottom:var(--space-12)}@media(max-width:968px){.footer-main{grid-template-columns:1fr;gap:var(--space-10)}}.footer-brand{max-width:320px}.footer-logo{display:inline-block;font-family:var(--font-sans);font-size:var(--text-xl);font-weight:600;color:var(--color-primary);margin-bottom:var(--space-4)}.footer-tagline{font-size:var(--text-base);color:var(--color-text-secondary);line-height:1.7;margin:0}.footer-nav{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-10)}@media(max-width:640px){.footer-nav{grid-template-columns:1fr 1fr;gap:var(--space-8)}}.footer-nav-title{font-size:var(--text-sm);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.15em;margin-bottom:var(--space-5)}.footer-nav-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-4)}.footer-nav-list a{font-size:var(--text-base);color:var(--color-text-secondary);text-decoration:none;transition:all var(--transition-fast)}.footer-nav-list a:hover{color:var(--color-primary);padding-left:var(--space-2)}.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-8);border-top:1px solid var(--color-border)}@media(max-width:640px){.footer-bottom{flex-direction:column;gap:var(--space-3);text-align:center}}.footer-copyright,.footer-credit{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}:root{--color-primary: #2680EB;--color-primary-hover: #1a6dd4;--color-primary-light: rgba(38, 128, 235, .1);--color-primary-glow: rgba(38, 128, 235, .25);--color-bg: #09090B;--color-bg-elevated: #0C0C0F;--color-bg-card: #111114;--color-bg-card-hover: #16161A;--color-surface: #1A1A1F;--color-text: #FAFAFA;--color-text-secondary: #A1A1AA;--color-text-muted: #71717A;--color-border: #27272A;--color-border-light: #1F1F23;--color-success: #22C55E;--color-warning: #EAB308;--color-error: #EF4444;--font-sans: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "IBM Plex Mono", "SF Mono", monospace;--text-xs: .75rem;--text-sm: .8125rem;--text-base: .9375rem;--text-lg: 1.0625rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--max-width: 1200px;--section-padding: var(--space-20);--section-padding-mobile: var(--space-12);--radius-sm: 4px;--radius-md: 6px;--radius-lg: 10px;--radius-xl: 14px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .25);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .3);--shadow-glow: 0 0 40px var(--color-primary-glow);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-overlay: 300;--z-modal: 400}[data-theme=light]{--color-bg: #FAFBFC;--color-bg-elevated: #FFFFFF;--color-bg-card: #FFFFFF;--color-bg-card-hover: #F3F4F6;--color-surface: #F0F1F3;--color-text: #0F172A;--color-text-secondary: #475569;--color-text-muted: #94A3B8;--color-border: #D1D5DB;--color-border-light: #E5E7EB;--color-primary: #1D6FD1;--color-primary-hover: #1559B3;--color-primary-light: rgba(29, 111, 209, .08);--color-primary-glow: rgba(29, 111, 209, .2);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .12);--shadow-glow: 0 0 40px rgba(29, 111, 209, .2)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:1.6;color:var(--color-text);background-color:var(--color-bg);transition:background-color var(--transition-base),color var(--transition-base);overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-sans);font-weight:600;line-height:1.3;color:var(--color-text)}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}@media(max-width:768px){h1{font-size:var(--text-2xl)}h2{font-size:var(--text-xl)}h3{font-size:var(--text-lg)}h4{font-size:var(--text-base)}}@media(max-width:480px){h1{font-size:var(--text-xl)}h2{font-size:var(--text-lg)}h3{font-size:var(--text-base)}}p{color:var(--color-text-secondary);margin-bottom:var(--space-4)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}strong{font-weight:600;color:var(--color-text)}code,pre{font-family:var(--font-mono)}::selection{background-color:var(--color-primary);color:#fff}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 var(--space-6)}@media(max-width:768px){.container{padding:0 var(--space-5)}}@media(max-width:480px){.container{padding:0 var(--space-4)}}.section{padding:var(--section-padding) 0}@media(max-width:768px){.section{padding:var(--section-padding-mobile) 0}}.text-gradient{background:linear-gradient(135deg,var(--color-primary) 0%,#58a6ff 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}[data-theme=light] .text-gradient{background:linear-gradient(135deg,#1d6fd1,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.mono{font-family:var(--font-mono)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media(hover:none)and (pointer:coarse){button,a,input,select,textarea{min-height:44px}}
