@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=Inter:wght@300;400;500;600;700&display=swap";.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1.2rem 0;transition:all .4s cubic-bezier(.4,0,.2,1);background:transparent}.navbar.scrolled{background:rgba(5,5,8,.85);backdrop-filter:blur(24px) saturate(1.8);-webkit-backdrop-filter:blur(24px) saturate(1.8);border-bottom:1px solid rgba(99,102,241,.12);box-shadow:0 4px 24px #0006;padding:.9rem 0}.navbar-container{max-width:1300px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.logo{font-family:Space Grotesk,sans-serif;font-size:1.35rem;font-weight:700;letter-spacing:-.03em;color:var(--text-color);text-decoration:none;cursor:pointer;display:flex;align-items:center;gap:.05rem;transition:var(--transition);white-space:nowrap}.logo-text{background:linear-gradient(135deg,#f1f5f9 0%,#a5b4fc 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.logo-dot{color:var(--accent-1);font-size:2rem;line-height:1}.logo:hover .logo-text{background:linear-gradient(135deg,var(--accent-1),var(--accent-2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav-links{display:flex;gap:.25rem;list-style:none;align-items:center}.nav-link{color:var(--text-color-light);text-decoration:none;font-weight:500;font-size:.93rem;cursor:pointer;position:relative;padding:.5rem .9rem;border-radius:8px;transition:var(--transition);display:flex;align-items:center;gap:.5rem;letter-spacing:.01em}.nav-link:hover{color:var(--text-color);background:rgba(255,255,255,.05)}.nav-link.active{color:var(--accent-1);font-weight:600}.nav-indicator{position:absolute;bottom:2px;left:8px;right:8px;height:2px;background:var(--gradient-primary);border-radius:1px}.nav-resume-btn{display:flex;align-items:center;gap:.5rem;padding:.55rem 1.25rem;border-radius:10px;background:var(--gradient-primary);color:#fff;font-size:.87rem;font-weight:600;letter-spacing:.02em;text-decoration:none;transition:var(--transition);box-shadow:0 0 18px #6366f159;margin-left:.75rem;white-space:nowrap;border:1px solid rgba(255,255,255,.1)}.nav-resume-btn:hover{transform:translateY(-2px);box-shadow:0 0 32px #6366f18c;filter:brightness(1.1)}.menu-icon{display:none;cursor:pointer;padding:.5rem;border-radius:8px;transition:var(--transition)}.menu-icon:hover{background:rgba(255,255,255,.06)}.hamburger{width:24px;height:18px;position:relative;display:flex;flex-direction:column;justify-content:space-between}.hamburger span{width:100%;height:2px;background:var(--text-color);border-radius:1px;transition:all .3s cubic-bezier(.4,0,.2,1);transform-origin:center}.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}.hamburger.active span:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}@media (max-width: 768px){.menu-icon{display:block}.nav-links{position:fixed;top:72px;left:0;right:0;background:rgba(5,5,10,.97);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);flex-direction:column;align-items:center;padding:2rem 0 2.5rem;gap:.4rem;transform:translateY(-150%);transition:all .4s cubic-bezier(.4,0,.2,1);border-bottom:1px solid rgba(99,102,241,.15);box-shadow:0 16px 48px #0009}.nav-links.active{transform:translateY(0)}.nav-link{font-size:1.05rem;padding:.75rem 2rem;border-radius:10px;width:200px;text-align:center;justify-content:center}.nav-link:hover{background:rgba(99,102,241,.08)}.nav-resume-btn{margin-left:0;margin-top:.5rem;padding:.75rem 2rem;width:200px;justify-content:center}.nav-indicator{display:none}}@media (max-width: 480px){.navbar-container{padding:0 1.2rem}.logo{font-size:1.5rem}.nav-links{top:65px}}.hero{min-height:100vh;padding:8rem 2rem 5rem;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);position:relative;overflow:hidden}.hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 60% at 20% 30%,rgba(99,102,241,.18),transparent 65%),radial-gradient(ellipse 60% 50% at 80% 70%,rgba(139,92,246,.12),transparent 65%),radial-gradient(ellipse 40% 40% at 50% 10%,rgba(6,182,212,.07),transparent 60%);z-index:1;animation:backgroundShift 22s ease-in-out infinite}.hero-grid-bg{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(rgba(99,102,241,.18) 1px,transparent 1px);background-size:38px 38px;z-index:1;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 30%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 30%,transparent 100%)}.floating-particles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:2}.particle{position:absolute;background:var(--accent-1);border-radius:50%;pointer-events:none}.hero-content{display:flex;flex-direction:row;justify-content:space-between;align-items:center;gap:5rem;max-width:1300px;width:100%;position:relative;z-index:3;margin:0 auto}.hero-text{flex:1;max-width:580px}.hero-badge{display:inline-flex;align-items:center;gap:.55rem;padding:.45rem 1.1rem;border-radius:100px;background:rgba(99,102,241,.1);border:1px solid rgba(99,102,241,.25);color:#a5b4fc;font-size:.82rem;font-weight:500;letter-spacing:.03em;margin-bottom:1.6rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.badge-dot{width:7px;height:7px;border-radius:50%;background:#4ade80;box-shadow:0 0 8px #4ade80b3;animation:pulse-badge 2s ease-in-out infinite}@keyframes pulse-badge{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}.hero-text h1{font-family:Space Grotesk,sans-serif;font-size:4.2rem;font-weight:700;color:var(--text-color);margin-bottom:1.2rem;line-height:1.1;letter-spacing:-.03em}.highlight{background:linear-gradient(135deg,#a5b4fc 0%,#818cf8 40%,#c4b5fd 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative;display:inline-block}.hero-typewriter-wrapper{font-size:1.45rem;font-weight:500;color:var(--text-color-light);margin-bottom:1.5rem;min-height:2.4rem;letter-spacing:.01em}.typewriter-prefix{color:var(--text-muted)}.typewriter{color:var(--accent-1);font-weight:600}.cursor{display:inline-block;margin-left:2px;animation:blink 1s infinite;color:var(--accent-1)}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-description{font-size:1.08rem;line-height:1.78;color:var(--text-color-light);margin-bottom:2.4rem;max-width:520px}.hero-cta{display:flex;gap:.85rem;flex-wrap:wrap;margin-bottom:2.2rem}.primary-btn,.secondary-btn,.resume-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.85rem 1.8rem;border-radius:12px;font-weight:600;font-size:.95rem;text-decoration:none;transition:var(--transition);letter-spacing:.01em;white-space:nowrap}.primary-btn{background:var(--gradient-primary);color:#fff;box-shadow:0 4px 20px #6366f159;border:1px solid rgba(255,255,255,.1)}.primary-btn:hover{transform:translateY(-3px);box-shadow:0 8px 30px #6366f180;filter:brightness(1.08)}.resume-btn{background:rgba(99,102,241,.1);color:#a5b4fc;border:1px solid rgba(99,102,241,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.resume-btn:hover{background:rgba(99,102,241,.2);border-color:#6366f180;transform:translateY(-3px);color:#c4b5fd}.secondary-btn{background:transparent;color:var(--text-color-light);border:1px solid rgba(255,255,255,.12)}.secondary-btn:hover{background:rgba(255,255,255,.05);color:var(--text-color);border-color:#fff3;transform:translateY(-3px)}.hero-socials{display:flex;align-items:center;gap:.8rem}.social-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;color:var(--text-color-light);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);transition:var(--transition)}.social-icon:hover{color:var(--accent-1);background:rgba(99,102,241,.1);border-color:#6366f140;transform:translateY(-2px)}.social-divider{width:1px;height:20px;background:rgba(255,255,255,.1);margin:0 .3rem}.social-label{font-size:.82rem;color:var(--text-muted);font-weight:400;letter-spacing:.02em}.hero-image{position:relative;flex-shrink:0}.profile-image-wrapper{position:relative;width:380px;height:380px}.profile-rings{position:absolute;top:-20px;right:-20px;bottom:-20px;left:-20px}.ring{position:absolute;border-radius:50%;border:1px solid rgba(99,102,241,.2)}.ring-1{top:0;right:0;bottom:0;left:0;animation:spin-slow 20s linear infinite}.ring-2{top:12px;right:12px;bottom:12px;left:12px;border-color:#8b5cf626;animation:spin-slow 28s linear infinite reverse}@keyframes spin-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.profile-image{width:380px;height:380px;border-radius:50%;overflow:hidden;border:3px solid rgba(99,102,241,.4);box-shadow:0 0 40px #6366f140,0 0 80px #6366f11a,inset 0 0 30px #6366f10d;position:relative;z-index:2}.profile-image img{width:100%;height:100%;object-fit:cover}.profile-glow{position:absolute;top:-30px;right:-30px;bottom:-30px;left:-30px;border-radius:50%;background:radial-gradient(circle,rgba(99,102,241,.25),transparent 70%);pointer-events:none;z-index:1}.stat-card{position:absolute;background:rgba(10,10,20,.9);border:1px solid rgba(99,102,241,.22);border-radius:14px;padding:.9rem 1.3rem;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:flex;flex-direction:column;align-items:center;gap:.25rem;box-shadow:0 8px 24px #00000059,0 0 20px #6366f11a;animation:float 4s ease-in-out infinite;z-index:3}.stat-card-left{left:-55px;top:62%;animation-delay:0s}.stat-card-right{right:-55px;top:12%;animation-delay:2s}.stat-number{font-family:Space Grotesk,sans-serif;font-size:1.5rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}.stat-label{font-size:.7rem;color:var(--text-muted);font-weight:500;white-space:nowrap;letter-spacing:.04em;text-transform:uppercase}.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.6rem;z-index:3}.scroll-indicator{width:26px;height:42px;border:1.5px solid rgba(255,255,255,.2);border-radius:13px;display:flex;align-items:flex-start;justify-content:center;padding-top:7px}.scroll-dot{width:4px;height:7px;border-radius:2px;background:var(--accent-1)}.hero-scroll span{color:var(--text-muted);font-size:.72rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase}@media (max-width: 1024px){.hero-content{flex-direction:column-reverse;text-align:center;gap:3.5rem}.hero-text{max-width:100%}.hero-cta,.hero-socials{justify-content:center}.hero-badge{margin:0 auto 1.6rem}.hero-description{margin:0 auto 2.4rem}.hero-text h1{font-size:3.4rem}.profile-image-wrapper,.profile-image{width:300px;height:300px}.stat-card-left{left:-15px;top:65%}.stat-card-right{right:-15px;top:5%}}@media (max-width: 600px){.hero{padding:6rem 1.5rem 4rem}.hero-text h1{font-size:2.8rem}.hero-typewriter-wrapper{font-size:1.2rem}.profile-image-wrapper,.profile-image{width:250px;height:250px}.hero-cta{flex-direction:column;align-items:center}.primary-btn,.secondary-btn,.resume-btn{width:100%;max-width:260px;justify-content:center}.stat-card{display:none}}.about{padding:var(--section-padding);background:var(--bg-secondary);position:relative;overflow:hidden}.about:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 65% 55% at 10% 40%,rgba(99,102,241,.14),transparent 60%),radial-gradient(ellipse 55% 50% at 90% 60%,rgba(139,92,246,.1),transparent 60%),radial-gradient(ellipse 40% 40% at 55% 15%,rgba(6,182,212,.06),transparent 55%);z-index:0;pointer-events:none;animation:backgroundShift 20s ease-in-out infinite}.about:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(rgba(99,102,241,.15) 1px,transparent 1px);background-size:38px 38px;z-index:0;pointer-events:none;mask-image:radial-gradient(ellipse 85% 85% at 50% 50%,black 20%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 85% 85% at 50% 50%,black 20%,transparent 100%)}.about-content{max-width:1100px;margin:0 auto;display:flex;flex-direction:column;gap:4rem;position:relative;z-index:2;text-align:center;padding:0 2rem}.about-header{text-align:center}.about .section-title{margin-bottom:1rem}.about-text{max-width:760px;margin:0 auto}.about-text p{font-size:1.12rem;line-height:1.85;color:var(--text-color-light);margin-bottom:1.4rem}.about-text p:last-child{margin-bottom:0}.about-text strong{color:var(--text-color);font-weight:600}.about-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:1.5rem}.about-card{background:var(--card-bg);border:1px solid var(--border);padding:2.2rem 1.8rem;border-radius:20px;text-align:center;transition:var(--transition);position:relative;overflow:hidden;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.about-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient-primary);opacity:0;transition:var(--transition)}.about-card:hover{background:var(--card-bg-hover);border-color:var(--border-accent);transform:translateY(-6px);box-shadow:0 20px 40px #0000004d,0 0 30px #6366f114}.about-card:hover:before{opacity:1}.card-icon{width:58px;height:58px;background:rgba(99,102,241,.1);border:1px solid rgba(99,102,241,.2);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;color:var(--accent-1);margin:0 auto 1.4rem;transition:var(--transition)}.about-card:hover .card-icon{background:var(--gradient-primary);color:#fff;border-color:transparent;transform:scale(1.1) rotate(5deg);box-shadow:0 8px 20px #6366f159}.about-card h3{font-family:Space Grotesk,sans-serif;font-size:1.25rem;font-weight:600;color:var(--text-color);margin-bottom:.8rem;letter-spacing:-.02em}.about-card p{color:var(--text-color-light);line-height:1.7;font-size:.95rem}@media (max-width: 768px){.about-content{gap:3rem}.about-text p{font-size:1.05rem}.about-cards{grid-template-columns:1fr;max-width:420px;margin:0 auto}.about-card{padding:1.8rem 1.5rem}}.skills{padding:var(--section-padding);background:var(--bg-primary);position:relative;overflow:hidden;text-align:center}.skills:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 70% 55% at 80% 20%,rgba(99,102,241,.14),transparent 60%),radial-gradient(ellipse 55% 50% at 20% 80%,rgba(139,92,246,.1),transparent 60%),radial-gradient(ellipse 40% 40% at 50% 50%,rgba(6,182,212,.05),transparent 55%);z-index:0;pointer-events:none;animation:backgroundShift 24s ease-in-out infinite}.skills:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(rgba(99,102,241,.15) 1px,transparent 1px);background-size:38px 38px;z-index:0;pointer-events:none;mask-image:radial-gradient(ellipse 85% 85% at 50% 50%,black 20%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 85% 85% at 50% 50%,black 20%,transparent 100%)}.skills .section-title,.skills .section-subtitle{position:relative;z-index:2}.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1.5rem;margin-top:3.5rem;position:relative;z-index:2;max-width:1200px;margin-left:auto;margin-right:auto;padding:0 2rem}.skill-category{background:var(--card-bg);border:1px solid var(--border);padding:1.8rem;border-radius:18px;transition:var(--transition);position:relative;overflow:hidden;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.skill-category:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient-primary);opacity:0;transition:var(--transition)}.skill-category:hover{background:var(--card-bg-hover);border-color:var(--border-accent);transform:translateY(-5px);box-shadow:0 16px 36px #00000040,0 0 24px #6366f112}.skill-category:hover:before{opacity:1}.category-icon{font-size:1.8rem;color:var(--accent-1);margin-bottom:1.2rem;display:inline-flex;align-items:center;justify-content:center;width:50px;height:50px;background:rgba(99,102,241,.1);border:1px solid rgba(99,102,241,.2);border-radius:13px;transition:var(--transition)}.skill-category:hover .category-icon{background:var(--gradient-primary);color:#fff;border-color:transparent;transform:scale(1.08)}.skill-category h3{font-family:Space Grotesk,sans-serif;font-size:1.05rem;font-weight:600;color:var(--text-color);margin-bottom:1.2rem;letter-spacing:-.01em}.skill-category ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:.5rem}.skill-category li{color:var(--text-color-light);display:flex;align-items:center;gap:.7rem;font-size:.9rem;padding:.3rem 0;border-bottom:1px solid rgba(255,255,255,.04);transition:var(--transition)}.skill-category li:last-child{border-bottom:none}.skill-category li:hover{color:var(--accent-1);padding-left:.3rem}.skill-category li:before{content:"";width:5px;height:5px;border-radius:50%;background:var(--accent-1);flex-shrink:0;opacity:.7}@media (max-width: 768px){.skills-grid{grid-template-columns:1fr 1fr;gap:1rem;padding:0 1rem}}@media (max-width: 520px){.skills-grid{grid-template-columns:1fr}.skill-category{padding:1.4rem}}.projects{padding:var(--section-padding);background:var(--bg-primary);position:relative;overflow:hidden}.projects:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 70% 55% at 15% 30%,rgba(99,102,241,.14),transparent 60%),radial-gradient(ellipse 55% 50% at 85% 70%,rgba(139,92,246,.1),transparent 60%),radial-gradient(ellipse 40% 40% at 50% 50%,rgba(6,182,212,.05),transparent 60%);z-index:0;pointer-events:none;animation:backgroundShift 26s ease-in-out infinite}.projects:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(rgba(99,102,241,.13) 1px,transparent 1px);background-size:40px 40px;z-index:0;pointer-events:none;mask-image:radial-gradient(ellipse 85% 85% at 50% 50%,black 20%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 85% 85% at 50% 50%,black 20%,transparent 100%)}.projects-inner{max-width:1280px;margin:0 auto;padding:0 2rem;position:relative;z-index:2}.projects-header{text-align:center;margin-bottom:5rem}.projects-eyebrow{font-size:.78rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-1);margin-bottom:1rem}.projects-header h2{font-family:Space Grotesk,sans-serif;font-size:3.2rem;font-weight:700;letter-spacing:-.03em;color:var(--text-color);margin-bottom:1.2rem;background:linear-gradient(135deg,var(--text-color) 0%,#a5b4fc 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.projects-subhead{font-size:1.08rem;color:var(--text-color-light);max-width:560px;margin:0 auto 2.5rem;line-height:1.7}.section-divider{width:60px;height:3px;background:var(--gradient-primary);margin:0 auto;border-radius:2px}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:1.8rem}.project-card{background:var(--card-bg);border:1px solid var(--border);border-radius:22px;padding:0 0 1.8rem;display:flex;flex-direction:column;gap:0;transition:var(--transition);position:relative;overflow:hidden;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.project-card:hover{background:rgba(255,255,255,.04);border-color:rgba(var(--color-from),.35);box-shadow:0 24px 60px #00000059,0 0 40px #6366f114}.card-accent-bar{height:3px;background:linear-gradient(90deg,var(--color-from),var(--color-to));border-radius:22px 22px 0 0;opacity:0;transition:opacity .35s ease;margin-bottom:0}.project-card:hover .card-accent-bar{opacity:1}.card-header{display:flex;align-items:center;justify-content:space-between;padding:1.6rem 1.8rem 0;margin-bottom:1rem}.card-number{font-family:Space Grotesk,sans-serif;font-size:2.8rem;font-weight:700;letter-spacing:-.05em;line-height:1;background:linear-gradient(135deg,var(--color-from),var(--color-to));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;opacity:.25;transition:opacity .35s ease}.project-card:hover .card-number{opacity:.55}.card-status-badge{font-size:.72rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:.35rem .85rem;border-radius:100px}.card-status-badge[data-status=Completed]{background:rgba(74,222,128,.1);color:#4ade80;border:1px solid rgba(74,222,128,.25)}.card-status-badge[data-status="In Progress"]{background:rgba(251,191,36,.1);color:#fbbf24;border:1px solid rgba(251,191,36,.25)}.card-title-block{padding:0 1.8rem;margin-bottom:1rem}.card-title{font-family:Space Grotesk,sans-serif;font-size:1.45rem;font-weight:700;color:var(--text-color);letter-spacing:-.02em;margin-bottom:.3rem;line-height:1.25}.card-subtitle{font-size:.85rem;color:var(--accent-1);font-weight:500;letter-spacing:.01em}.card-description{padding:0 1.8rem;font-size:.9rem;line-height:1.72;color:var(--text-color-light);margin-bottom:1.4rem;flex-grow:1}.card-features{padding:0 1.8rem;margin-bottom:1.5rem}.card-features ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:.55rem}.card-features li{display:flex;align-items:flex-start;gap:.65rem;font-size:.86rem;color:var(--text-color-light);line-height:1.5}.feat-dot{width:5px;height:5px;border-radius:50%;background:linear-gradient(135deg,var(--color-from),var(--color-to));flex-shrink:0;margin-top:5px}.card-tech-row{display:flex;flex-wrap:wrap;gap:.45rem;padding:0 1.8rem;margin-bottom:1rem}.tech-icon-chip{width:34px;height:34px;border-radius:9px;background:rgba(255,255,255,.05);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-color-light);transition:var(--transition);font-size:.75rem;font-weight:600}.project-card:hover .tech-icon-chip{border-color:rgba(var(--color-from),.3);color:var(--text-color)}.tech-icon-chip.more{font-size:.68rem;color:var(--text-muted)}.card-tags{display:flex;flex-wrap:wrap;gap:.5rem;padding:0 1.8rem;margin-bottom:1.6rem}.tech-tag{font-size:.76rem;font-weight:500;padding:.3rem .75rem;border-radius:100px;background:rgba(99,102,241,.07);color:var(--text-color-light);border:1px solid rgba(99,102,241,.15);transition:var(--transition);letter-spacing:.01em}.tech-tag:hover{background:rgba(99,102,241,.14);color:#a5b4fc;border-color:#6366f14d}.tech-tag.more{color:var(--accent-1);background:rgba(99,102,241,.08)}.card-footer{padding:1.2rem 1.8rem 0;display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--border);margin-top:auto}.card-period{font-size:.78rem;color:var(--text-muted);font-weight:500;letter-spacing:.02em}.card-links{display:flex;gap:.6rem}.card-link{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .95rem;border-radius:9px;font-size:.82rem;font-weight:600;text-decoration:none;background:rgba(255,255,255,.05);color:var(--text-color-light);border:1px solid var(--border);transition:var(--transition);letter-spacing:.01em}.card-link:hover{background:rgba(255,255,255,.09);color:var(--text-color);border-color:#ffffff26;transform:translateY(-2px)}.card-link.primary{background:var(--gradient-primary);color:#fff;border-color:transparent;box-shadow:0 4px 14px #6366f14d}.card-link.primary:hover{filter:brightness(1.12);box-shadow:0 6px 20px #6366f173}@media (max-width: 900px){.projects-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.4rem}.projects-header h2{font-size:2.6rem}}@media (max-width: 640px){.projects{padding:4rem 0}.projects-inner{padding:0 1rem}.projects-grid{grid-template-columns:1fr;gap:1.2rem}.projects-header{margin-bottom:3.5rem}.projects-header h2,.card-number{font-size:2.2rem}.card-title{font-size:1.3rem}}.contact{padding:var(--section-padding);background:var(--bg-secondary);position:relative;overflow:hidden;text-align:center}.contact:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 65% 55% at 25% 25%,rgba(99,102,241,.13),transparent 60%),radial-gradient(ellipse 50% 50% at 80% 80%,rgba(139,92,246,.09),transparent 60%),radial-gradient(ellipse 40% 40% at 55% 50%,rgba(6,182,212,.05),transparent 60%);z-index:0;pointer-events:none;animation:backgroundShift 22s ease-in-out infinite}.contact:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(rgba(99,102,241,.13) 1px,transparent 1px);background-size:38px 38px;z-index:0;pointer-events:none;mask-image:radial-gradient(ellipse 85% 85% at 50% 50%,black 20%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 85% 85% at 50% 50%,black 20%,transparent 100%)}.contact .section-title,.contact .section-subtitle{position:relative;z-index:2}.contact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;max-width:1100px;margin:3.5rem auto 0;padding:0 2rem;position:relative;z-index:2}.contact-card{background:var(--card-bg);border:1px solid var(--border);border-radius:18px;overflow:hidden;transition:var(--transition);position:relative;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.contact-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient-primary);opacity:0;transition:var(--transition)}.contact-card:hover{background:var(--card-bg-hover);border-color:var(--border-accent);transform:translateY(-6px);box-shadow:0 20px 40px #0000004d,0 0 30px #6366f114}.contact-card:hover:before{opacity:1}.contact-link{display:flex;flex-direction:column;align-items:center;padding:2.2rem 1.5rem;text-decoration:none;color:inherit;width:100%;height:100%}.contact-icon{width:56px;height:56px;background:rgba(99,102,241,.1);border:1px solid rgba(99,102,241,.2);border-radius:15px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--accent-1);margin-bottom:1.4rem;transition:var(--transition)}.contact-card:hover .contact-icon{background:var(--gradient-primary);color:#fff;border-color:transparent;transform:scale(1.1) rotate(5deg);box-shadow:0 8px 20px #6366f159}.contact-details{text-align:center}.contact-details h3{font-family:Space Grotesk,sans-serif;font-size:1rem;font-weight:600;color:var(--text-color);margin-bottom:.5rem;letter-spacing:-.01em}.contact-details span{color:var(--text-color-light);font-size:.88rem}.contact-message{text-align:center;max-width:580px;margin:4.5rem auto 0;position:relative;z-index:2;padding:2.5rem;background:rgba(99,102,241,.05);border:1px solid rgba(99,102,241,.15);border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.contact-message p{font-size:1.1rem;line-height:1.75;color:var(--text-color-light)}@media (max-width: 1000px){.contact-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.contact-grid{grid-template-columns:1fr;padding:0 1rem;max-width:400px;margin-left:auto;margin-right:auto}.contact-message{margin:3rem 1rem 0;padding:2rem 1.5rem}.contact-message p{font-size:1rem}}.footer{background:var(--bg-primary);border-top:1px solid var(--border);padding:3rem 0 2rem;position:relative;overflow:hidden}.footer:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:300px;height:1px;background:var(--gradient-primary);opacity:.5}.footer-content{max-width:1100px;margin:0 auto;padding:0 2rem;display:flex;flex-direction:column;align-items:center;gap:2rem}.footer-logo{text-align:center}.footer-logo h3{font-family:Space Grotesk,sans-serif;font-size:2rem;font-weight:700;letter-spacing:-.04em;margin-bottom:.5rem;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.footer-logo p{color:var(--text-muted);font-size:.9rem;letter-spacing:.02em}.footer-social{display:flex;gap:1rem}.footer-social a{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:10px;color:var(--text-color-light);background:rgba(255,255,255,.04);border:1px solid var(--border);font-size:1.15rem;transition:var(--transition)}.footer-social a:hover{color:var(--accent-1);background:rgba(99,102,241,.1);border-color:#6366f140;transform:translateY(-3px);box-shadow:0 8px 20px #6366f133}.footer-bottom{text-align:center;padding-top:2rem;border-top:1px solid var(--border);width:100%}.footer-bottom p{color:var(--text-muted);font-size:.83rem;letter-spacing:.02em}@media (max-width: 768px){.footer{padding:2.5rem 0 1.5rem}.footer-logo h3{font-size:1.7rem}}.chat-section{padding:var(--section-padding);background:var(--bg-secondary);position:relative;overflow:hidden}.chat-section:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 60% 50% at 50% 30%,rgba(99,102,241,.12),transparent 60%),radial-gradient(ellipse 50% 45% at 15% 75%,rgba(139,92,246,.09),transparent 60%),radial-gradient(ellipse 40% 40% at 85% 20%,rgba(6,182,212,.05),transparent 60%);z-index:0;pointer-events:none;animation:backgroundShift 28s ease-in-out infinite}.chat-section:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(rgba(99,102,241,.12) 1px,transparent 1px);background-size:38px 38px;z-index:0;pointer-events:none;mask-image:radial-gradient(ellipse 85% 85% at 50% 50%,black 20%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 85% 85% at 50% 50%,black 20%,transparent 100%)}.chat-section .section-title,.chat-section .section-subtitle{position:relative;z-index:2}.chat-container{max-width:860px;width:90%;margin:1rem auto;background:var(--card-bg);border:1px solid var(--border);border-radius:20px;box-shadow:0 16px 48px #0000004d;display:flex;flex-direction:column;height:500px;min-height:500px;max-height:500px;position:relative;overflow:hidden;opacity:0;transform:translateY(20px);animation:slideUp .6s ease-out forwards;z-index:2;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.chat-header{padding:.8rem 1.2rem;height:52px;border-bottom:1px solid var(--border);text-align:center;background:rgba(99,102,241,.05);border-radius:20px 20px 0 0;flex-shrink:0;display:flex;align-items:center;justify-content:center}.chat-header h2{margin:0;color:var(--text-color);font-family:Space Grotesk,sans-serif;font-size:1.1rem;font-weight:600;letter-spacing:-.01em}.messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem;scroll-behavior:smooth;overflow-x:hidden;min-height:0}.messages::-webkit-scrollbar{width:4px}.messages::-webkit-scrollbar-track{background:transparent}.messages::-webkit-scrollbar-thumb{background:var(--border-accent);border-radius:2px}.message{display:flex;opacity:0;animation:fadeIn .3s ease forwards}.message.user{justify-content:flex-end}.message-content{max-width:80%;padding:.75rem 1rem;border-radius:14px;font-size:.92rem;line-height:1.5}.user .message-content{background:var(--gradient-primary);color:#fff;border-radius:14px 14px 4px;box-shadow:0 4px 12px #6366f14d}.assistant .message-content{background:rgba(255,255,255,.05);color:var(--text-color);border:1px solid var(--border);border-radius:14px 14px 14px 4px}.message-content.loading{display:flex;gap:.4rem;padding:1rem;min-width:60px;justify-content:center}.message-content.loading span{width:7px;height:7px;background:var(--accent-1);border-radius:50%;animation:bounce 1s infinite}.message-content.loading span:nth-child(2){animation-delay:.2s}.message-content.loading span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.input-container{height:64px;padding:.6rem .8rem;border-top:1px solid var(--border);display:flex;gap:.6rem;background:rgba(255,255,255,.02);border-radius:0 0 20px 20px;flex-shrink:0;align-items:center}.input-container input{flex:1;padding:.65rem 1.1rem;border:1px solid var(--border);border-radius:10px;background:rgba(255,255,255,.04);color:var(--text-color);font-size:.93rem;font-family:Inter,sans-serif;transition:var(--transition);outline:none}.input-container input:focus{border-color:var(--accent-1);box-shadow:0 0 0 3px var(--accent-glow);background:rgba(99,102,241,.04)}.input-container input::placeholder{color:var(--text-muted)}.input-container button{padding:.65rem 1.3rem;background:var(--gradient-primary);color:#fff;border:none;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;transition:var(--transition);white-space:nowrap;box-shadow:0 0 16px #6366f14d}.input-container button:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 0 24px #6366f173}.input-container button:disabled{opacity:.5;cursor:not-allowed}.message.error .message-content{background:rgba(239,68,68,.08);color:#f87171;border:1px solid rgba(239,68,68,.2);text-align:center;margin:0 auto}@media (max-width: 768px){.chat-container{width:95%;height:380px;min-height:380px;max-height:380px}.chat-header h2{font-size:1rem}}@media (prefers-reduced-motion: reduce){.chat-container{animation:none;opacity:1;transform:none}}body,html,#root{margin:0;padding:0;width:100%;min-height:100%}.app{min-height:100vh;background:var(--bg-primary);color:var(--text-color)}main{width:100%}.chat-box{width:90%;max-width:600px;height:600px;margin:2rem auto;padding:20px;background-color:var(--bg-tertiary);border-radius:16px;overflow-y:auto;box-shadow:0 4px 24px #0000004d;border:1px solid var(--border)}.chat-container{display:flex;flex-direction:column;height:100%}.messages{flex:1;overflow-y:auto;padding:10px}.input-container{display:flex;gap:10px;padding:10px 0}input[type=text]{flex:1;padding:10px 16px;border-radius:10px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-color);font-family:Inter,sans-serif;font-size:.95rem;outline:none;transition:var(--transition)}input[type=text]:focus{border-color:var(--accent-1);box-shadow:0 0 0 3px var(--accent-glow)}button{padding:10px 20px;border-radius:10px;border:none;background:var(--gradient-primary);color:#fff;cursor:pointer;font-family:Inter,sans-serif;font-weight:600;transition:var(--transition)}button:hover{filter:brightness(1.1);transform:translateY(-1px)}:root{--bg-primary: #050508;--bg-secondary: #0b0b14;--bg-tertiary: #111120;--card-bg: rgba(255, 255, 255, .025);--card-bg-hover: rgba(255, 255, 255, .05);--primary-color: #050508;--secondary-color: #6366f1;--accent-color: #818cf8;--background-color: #050508;--card-background: #0f0f1a;--accent-1: #6366f1;--accent-2: #8b5cf6;--accent-cyan: #06b6d4;--accent-glow: rgba(99, 102, 241, .2);--accent-glow-strong: rgba(99, 102, 241, .35);--gradient-primary: linear-gradient(135deg, #6366f1, #8b5cf6);--gradient-secondary: linear-gradient(135deg, #8b5cf6, #06b6d4);--gradient-text: linear-gradient(135deg, #a5b4fc, #818cf8, #c4b5fd);--gradient-bg: linear-gradient(135deg, rgba(99, 102, 241, .08), rgba(139, 92, 246, .08));--text-color: #f1f5f9;--text-color-light: #94a3b8;--text-muted: #64748b;--border: rgba(255, 255, 255, .06);--border-accent: rgba(99, 102, 241, .25);--section-padding: 7rem 0;--container-max: 1300px;--transition: all .3s cubic-bezier(.4, 0, .2, 1);--transition-slow: all .5s cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Inter,sans-serif;background:var(--bg-primary);color:var(--text-color);line-height:1.6;margin:0;padding:0;overflow-x:hidden;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-family:Space Grotesk,sans-serif;letter-spacing:-.02em}#root{min-height:100vh;background:var(--bg-primary)}img{max-width:100%;height:auto}a{text-decoration:none;color:inherit}ul{list-style:none}.container{max-width:var(--container-max);width:100%;margin:0 auto;padding:0 2rem}section{width:100%;position:relative}.section-title{font-family:Space Grotesk,sans-serif;font-size:2.8rem;font-weight:700;text-align:center;margin-bottom:1rem;color:var(--text-color);letter-spacing:-.03em;position:relative;display:block;width:100%}.section-title:after{content:"";position:absolute;bottom:-12px;left:50%;transform:translate(-50%);width:48px;height:3px;background:var(--gradient-primary);border-radius:2px}.section-subtitle{font-size:1.1rem;text-align:center;margin-bottom:3rem;color:var(--text-color-light);font-weight:400}@keyframes backgroundShift{0%,to{transform:translate(0) translateY(0) scale(1)}25%{transform:translate(-20px) translateY(-10px) scale(1.05)}50%{transform:translate(20px) translateY(10px) scale(.95)}75%{transform:translate(-10px) translateY(20px) scale(1.02)}}@keyframes backgroundPattern{0%{transform:translate(-100%) rotate(0)}to{transform:translate(100%) rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px var(--accent-glow)}50%{box-shadow:0 0 40px var(--accent-glow-strong)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--accent-1);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent-2)}.noise-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");pointer-events:none;z-index:0}@media (max-width: 768px){.section-title{font-size:2.2rem}.section-subtitle{font-size:1rem}}
