@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,700;0,900;1,100;1,300;1,400;1,500;1,700;1,900&display=swap";:root{--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #e2e8f0;--text-primary: #364f6b;--text-secondary: #6b7280;--border-color: #e2e8f0;--shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--header-bg: rgba(255, 255, 255, .8);--header-backdrop: blur(10px)}[data-theme=dark]{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--border-color: #475569;--shadow: 0 10px 15px -3px rgba(0, 0, 0, .3), 0 4px 6px -2px rgba(0, 0, 0, .2);--header-bg: rgba(15, 23, 42, .8);--header-backdrop: blur(10px)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,Roboto,-apple-system,BlinkMacSystemFont,sans-serif;font-size:1rem;line-height:1.5;color:var(--text-primary);background-color:var(--bg-primary);transition:color .25s ease-in-out,background-color .25s ease-in-out;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh}@media screen and (max-width: 768px){#root{width:100vw}}::-moz-selection{background:rgba(63,193,201,.7);color:#fff}::selection{background:rgba(63,193,201,.7);color:#fff}[data-theme=dark] ::-moz-selection,[data-theme=dark] ::selection{background:rgba(252,81,133,.8);color:#fff}button{padding:0;background-color:transparent;border:0;cursor:pointer;font-family:inherit;transition:all .15s ease-in-out}button:focus-visible{outline:2px solid #3fc1c9;outline-offset:2px}a{color:#3fc1c9;text-decoration:none;transition:color .15s ease-in-out}a:hover{color:#2a9ba3}a:focus-visible{outline:2px solid #3fc1c9;outline-offset:2px;border-radius:.25rem}[data-theme=dark] a{color:#3fc1c9}[data-theme=dark] a:hover{color:#67ced4}.container{max-width:1200px;margin:0 auto;padding:0 1rem}@media screen and (max-width: 768px){.container{padding:0 1rem}}@media screen and (max-width: 450px){.container{padding:0 .75rem}}.content{max-width:800px;margin:0 auto}.section-padding{padding:5rem 0}@media screen and (max-width: 768px){.section-padding{padding:4rem 0}}@media screen and (max-width: 450px){.section-padding{padding:3rem 0}}.text-gradient{background:linear-gradient(135deg,#3fc1c9,#fc5185);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.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}.header-container{position:fixed;top:0;left:0;right:0;z-index:1030;background:var(--header-bg);backdrop-filter:var(--header-backdrop);-webkit-backdrop-filter:var(--header-backdrop);border-bottom:1px solid var(--border-color);transition:all .25s ease-in-out}.header{display:flex;align-items:center;justify-content:space-between;height:4rem;max-width:1200px;margin:0 auto;padding:0 1.5rem}@media screen and (max-width: 768px){.header{display:none}}.mobile-nav{display:none;align-items:center;justify-content:space-between;height:3.5rem;padding:0 1rem}@media screen and (max-width: 768px){.mobile-nav{display:flex}}.nav-brand .brand-link{font-size:1.25rem;font-weight:700;color:var(--text-primary);text-decoration:none;background:linear-gradient(135deg,#3fc1c9,#fc5185);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;transition:opacity .15s ease-in-out}.nav-brand .brand-link:hover{opacity:.8}.nav-brand .brand-link:focus-visible{outline:2px solid #3fc1c9;outline-offset:.25rem;border-radius:.25rem}.desktop-nav{display:flex;align-items:center;gap:2rem}.nav-link{font-size:1rem;font-weight:500;color:var(--text-secondary);background:none;border:none;padding:.5rem .75rem;border-radius:.5rem;cursor:pointer;transition:all .15s ease-in-out;position:relative}.nav-link:hover{color:var(--text-primary);background-color:#3fc1c91a}.nav-link:focus-visible{outline:2px solid #3fc1c9;outline-offset:2px}.header-actions,.mobile-actions{display:flex;align-items:center;gap:1rem}.theme-toggle{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:9999px;background:none;border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;transition:all .15s ease-in-out}.theme-toggle:hover{background-color:var(--bg-secondary);color:var(--text-primary);border-color:#3fc1c9}.theme-toggle:focus-visible{outline:2px solid #3fc1c9;outline-offset:2px}.theme-toggle.mobile{width:2.25rem;height:2.25rem}.theme-icon{width:1.25rem;height:1.25rem}.hamburger{display:flex;flex-direction:column;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;background:none;border:none;cursor:pointer;z-index:1050;gap:.25rem;transition:all .15s ease-in-out}.hamburger:hover{background-color:rgba(var(--text-primary),.1);border-radius:.5rem}.hamburger:focus-visible{outline:2px solid #3fc1c9;outline-offset:2px;border-radius:.5rem}.hamburger div{width:1.25rem;height:2px;background-color:var(--text-primary);border-radius:1px;transition:all .25s ease-in-out cubic-bezier(.4,0,.2,1);transform-origin:center}.hamburger.active .line1{transform:translateY(.375rem) rotate(45deg)}.hamburger.active .line2{opacity:0;transform:scaleX(0)}.hamburger.active .line3{transform:translateY(-.375rem) rotate(-45deg)}.mobile-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-primary);border:1px solid var(--border-color);border-top:none;border-radius:0 0 .75rem .75rem;padding:1rem;box-shadow:var(--shadow);opacity:0;visibility:hidden;transform:translateY(-1rem);transition:all .25s ease-in-out cubic-bezier(0,0,.2,1);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.mobile-dropdown.active{opacity:1;visibility:visible;transform:translateY(0)}@media screen and (min-width: 768px){.mobile-dropdown{display:none}}.mobile-nav-link{display:block;width:100%;text-align:left;font-size:1.125rem;font-weight:500;color:var(--text-primary);background:none;border:none;padding:.75rem 1rem;margin:.25rem 0;border-radius:.5rem;cursor:pointer;opacity:0;transform:translate(-1rem);transition:all .15s ease-in-out}.mobile-dropdown.active .mobile-nav-link{opacity:1;transform:translate(0)}.mobile-nav-link:hover{background-color:#3fc1c91a;color:#3fc1c9;transform:translate(.25rem)}.mobile-nav-link:focus-visible{outline:2px solid #3fc1c9;outline-offset:2px}.mobile-nav-link:active{transform:scale(.98)}@media (prefers-reduced-motion: reduce){.hamburger,.hamburger div,.mobile-dropdown,.mobile-nav-link{transition:none}}@media screen and (max-width: 450px){.mobile-nav{padding:0 .75rem}.mobile-dropdown{margin:0 -.75rem;border-radius:0;border-left:none;border-right:none}.mobile-nav-link{font-size:1rem;padding:.75rem}}.hero-section{min-height:100vh;padding-top:4rem;display:flex;align-items:center;position:relative;background:var(--bg-primary)}@media screen and (max-width: 768px){.hero-section{padding-top:5.5rem;min-height:calc(100vh - 3.5rem)}}.hero-content{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}@media screen and (max-width: 1024px){.hero-content{grid-template-columns:1fr;gap:4rem;text-align:center}}.hero-text{max-width:none}@media screen and (max-width: 1024px){.hero-text{max-width:800px;margin:0 auto}}.hero-intro{margin-bottom:2rem}.greeting{font-size:1.125rem;color:var(--text-secondary);font-weight:500;display:block;margin-bottom:.5rem}@media screen and (max-width: 450px){.greeting{font-size:1rem}}.hero-name{font-size:clamp(3rem,8vw,5rem);font-weight:700;line-height:1.25;margin:0 0 .5rem}.hero-name .text-gradient{background:linear-gradient(135deg,#3fc1c9,#fc5185);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-title{font-size:clamp(1.5rem,4vw,2.25rem);font-weight:600;color:var(--text-primary);margin:0}.hero-description{margin:2rem 0}.hero-description p{font-size:1.125rem;line-height:1.75;color:var(--text-secondary);margin:0 0 1rem}.hero-description p:last-child{margin-bottom:0}@media screen and (max-width: 450px){.hero-description p{font-size:1rem}}.tech-highlight{font-weight:600;color:#3fc1c9;position:relative;display:inline-block}.animate-in{animation:fadeInUp .6s cubic-bezier(0,0,.2,1)}.hero-subtitle{max-width:90%}@media screen and (max-width: 1024px){.hero-subtitle{max-width:100%}}.hero-actions{display:flex;gap:1rem;margin-top:2.5rem}@media screen and (max-width: 450px){.hero-actions{flex-direction:column;align-items:center;gap:.75rem}}@media screen and (max-width: 1024px){.hero-actions{justify-content:center}}.btn-primary,.btn-secondary{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;border-radius:.75rem;transition:all .25s ease-in-out;cursor:pointer;text-decoration:none;border:none}@media screen and (max-width: 450px){.btn-primary,.btn-secondary{padding:.75rem 1.25rem;font-size:.875rem}}.btn-primary svg,.btn-secondary svg{width:1.125rem;height:1.125rem;transition:transform .15s ease-in-out}.btn-primary:hover svg,.btn-secondary:hover svg{transform:scale(1.1)}.btn-primary{background:linear-gradient(135deg,#3fc1c9,#fc5185);color:#fff;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.btn-primary:hover{color:#fff;transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;filter:brightness(1.1)}.btn-primary:active{transform:translateY(0)}.btn-primary:focus-visible{outline:2px solid white;outline-offset:2px}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);box-shadow:0 0 0 1px var(--border-color)}.btn-secondary:hover{background:var(--text-primary);color:var(--bg-primary);box-shadow:0 0 0 1px var(--text-primary);transform:translateY(-1px)}.btn-secondary:focus-visible{outline:2px solid #3fc1c9;outline-offset:2px}.btn-secondary:active{transform:translateY(0)}.hero-visual{position:relative;display:flex;justify-content:center;align-items:center}@media screen and (max-width: 1024px){.hero-visual{order:-1;margin-bottom:2rem}}.hero-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:1rem;padding:1.5rem;box-shadow:var(--shadow);max-width:400px;position:relative;z-index:2}@media screen and (max-width: 450px){.hero-card{max-width:300px;padding:1rem}}.code-snippet{background:var(--bg-primary);border-radius:.75rem;overflow:hidden;font-family:Fira Code,Monaco,Cascadia Code,monospace}.code-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.code-dots{display:flex;gap:.5rem}.dot{width:12px;height:12px;border-radius:50%}.dot.red{background:#ff5f56}.dot.yellow{background:#ffbd2e}.dot.green{background:#27ca3f}.code-title{font-size:.875rem;color:var(--text-secondary);font-weight:500}.code-content{padding:1rem;font-size:.875rem;line-height:1.6}@media screen and (max-width: 450px){.code-content{padding:.75rem;font-size:.75rem}}.code-line{margin:.25rem 0}.code-indent{padding-left:1rem}.code-double-indent{padding-left:2rem}.code-keyword{color:#c792ea}.code-variable{color:#82aaff}.code-operator{color:#89ddff}.code-property{color:#ffcb6b}.code-string{color:#c3e88d}.code-bracket,.code-colon,.code-comma{color:var(--text-secondary)}[data-theme=dark] .code-keyword{color:#bb9af7}[data-theme=dark] .code-variable{color:#7aa2f7}[data-theme=dark] .code-operator{color:#2ac3de}[data-theme=dark] .code-property{color:#e0af68}[data-theme=dark] .code-string{color:#9ece6a}.floating-elements{position:absolute;width:100%;height:100%;pointer-events:none;z-index:1}.floating-icon{position:absolute;font-size:2rem;animation:float 6s ease-in-out infinite}@media screen and (max-width: 450px){.floating-icon{font-size:1.5rem}}.floating-icon.react{top:10%;right:-10%;animation-delay:0s}.floating-icon.node{top:70%;right:10%;animation-delay:1.5s}.floating-icon.java{top:20%;left:-15%;animation-delay:3s}.floating-icon.cloud{bottom:10%;left:5%;animation-delay:4.5s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0) rotate(0)}33%{transform:translateY(-10px) rotate(5deg)}66%{transform:translateY(5px) rotate(-5deg)}}.about-section{background:var(--bg-secondary);padding:5rem 0}@media screen and (max-width: 768px){.about-section{padding:4rem 0}}@media screen and (max-width: 450px){.about-section{padding:3rem 0}}.section-header h2{font-size:2.25rem;font-weight:700;color:var(--text-primary);margin:0 0 1rem}@media screen and (max-width: 450px){.section-header h2{font-size:1.875rem}}@media screen and (max-width: 450px){.section-header p{font-size:1rem}}.about-content{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}@media screen and (max-width: 1024px){.about-content{grid-template-columns:1fr;gap:3rem}}.about-text{max-width:none}@media screen and (max-width: 1024px){.about-text{order:2}}.about-intro{margin-bottom:2.5rem}.about-intro p{font-size:1.125rem;line-height:1.75;color:var(--text-primary);margin:0}.about-intro p strong{color:#3fc1c9;font-weight:600}@media screen and (max-width: 450px){.about-intro p{font-size:1rem}}.about-details{margin-bottom:3rem}.detail-item{margin-bottom:2rem}.detail-item:last-child{margin-bottom:0}.detail-item h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0 0 .75rem;display:flex;align-items:center;gap:.5rem}@media screen and (max-width: 450px){.detail-item h3{font-size:1.125rem}}.detail-item p{font-size:1rem;line-height:1.75;color:var(--text-secondary);margin:0}.about-highlights{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}@media screen and (max-width: 450px){.about-highlights{gap:1rem}}.highlight{text-align:center;padding:1.5rem 1rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:.75rem}@media screen and (max-width: 450px){.highlight{padding:1rem .75rem}}.highlight-number{display:block;font-size:1.875rem;font-weight:700;background:linear-gradient(135deg,#3fc1c9,#fc5185);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}@media screen and (max-width: 450px){.highlight-number{font-size:1.5rem}}.highlight-label{display:block;font-size:.875rem;color:var(--text-secondary);font-weight:500}@media screen and (max-width: 450px){.highlight-label{font-size:.75rem}}.about-visual{display:flex;justify-content:center;align-items:center}@media screen and (max-width: 1024px){.about-visual{order:1}}.profile-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:1rem;padding:2rem;box-shadow:var(--shadow);max-width:350px;width:100%;text-align:center}@media screen and (max-width: 450px){.profile-card{max-width:280px;padding:1.5rem}}.profile-image-container{position:relative;margin-bottom:1.5rem}.profile-image{width:120px;height:120px;margin:0 auto 1rem;position:relative}@media screen and (max-width: 450px){.profile-image{width:100px;height:100px}}.image-placeholder{width:100%;height:100%;border-radius:50%;background:linear-gradient(135deg,#3fc1c9,#fc5185);display:flex;align-items:center;justify-content:center;font-size:3rem}@media screen and (max-width: 450px){.image-placeholder{font-size:2.5rem}}.status-indicator{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.status-dot{width:8px;height:8px;border-radius:50%;background:#22c55e;animation:pulse 2s infinite}.profile-info h3{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem}@media screen and (max-width: 450px){.profile-info h3{font-size:1.25rem}}.profile-info p{font-size:1rem;color:var(--text-secondary);margin:0 0 1.5rem}@media screen and (max-width: 450px){.profile-info p{font-size:.875rem}}.profile-tags{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem}.tag{display:inline-block;background:rgba(63,193,201,.1);color:#3fc1c9;font-size:.75rem;font-weight:500;padding:.25rem .75rem;border-radius:9999px;border:1px solid rgba(63,193,201,.2)}@media screen and (max-width: 450px){.tag{font-size:.75rem;padding:.25rem .5rem}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.skills-section{background:var(--bg-primary);padding:5rem 0}@media screen and (max-width: 768px){.skills-section{padding:4rem 0}}@media screen and (max-width: 450px){.skills-section{padding:3rem 0}}.section-header{text-align:center;margin-bottom:4rem}.section-header h2{font-size:clamp(2rem,5vw,3rem);font-weight:700;color:var(--text-primary);margin:0 0 1rem}.section-header p{font-size:1.125rem;color:var(--text-secondary);max-width:600px;margin:0 auto}.skills-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:3rem;margin-bottom:4rem}@media screen and (max-width: 450px){.skills-container{grid-template-columns:1fr;gap:2rem}}.skill-category{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:1rem;padding:2rem;position:relative;overflow:visible;min-height:400px;display:flex;flex-direction:column;align-items:center}.skill-category:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#3fc1c9,#fc5185);border-radius:1rem 1rem 0 0}.skill-category:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:60px;height:60px;background:linear-gradient(135deg,#3fc1c9,#fc5185);border-radius:50%;box-shadow:0 0 20px #3fc1c94d;z-index:1}@media screen and (max-width: 450px){.skill-category{padding:1.5rem;min-height:300px}.skill-category:after{width:40px;height:40px}}.category-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0 0 1.5rem;text-align:center;position:relative;z-index:2}@media screen and (max-width: 450px){.category-title{font-size:1.125rem;margin-bottom:1rem}}.floating-skills{position:relative;width:300px;height:300px;display:flex;justify-content:center;align-items:center;flex:1}@media screen and (max-width: 450px){.floating-skills{width:250px;height:250px}}.orbiting-skill{position:absolute;display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:.75rem;box-shadow:var(--shadow);cursor:pointer;transition:all .25s ease-in-out;z-index:3;width:60px;height:80px;top:50%;left:50%;margin-top:-40px;margin-left:-30px;transform:rotate(var(--orbit-angle)) translateY(-140px) rotate(calc(-1 * var(--orbit-angle)));animation:spin 20s infinite linear}.orbiting-skill:hover{transform:rotate(var(--orbit-angle)) translateY(-140px) rotate(calc(-1 * var(--orbit-angle))) scale(1.2);box-shadow:0 10px 30px #3fc1c94d;border-color:#3fc1c9;z-index:10;animation-play-state:paused}@media screen and (max-width: 450px){.orbiting-skill{padding:.25rem;width:50px;height:70px;margin-top:-35px;margin-left:-25px;transform:rotate(var(--orbit-angle)) translateY(-110px) rotate(calc(-1 * var(--orbit-angle)))}.orbiting-skill:hover{transform:rotate(var(--orbit-angle)) translateY(-110px) rotate(calc(-1 * var(--orbit-angle))) scale(1.15)}}.skill-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center}.skill-icon img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(2px 2px 4px rgba(0,0,0,.1));transition:filter .15s ease-in-out}@media screen and (max-width: 450px){.skill-icon{width:30px;height:30px}}.orbiting-skill:hover .skill-icon img{filter:drop-shadow(2px 2px 8px rgba(63,193,201,.4))}.skill-name{font-size:.75rem;font-weight:500;color:var(--text-primary);text-align:center;white-space:nowrap}@media screen and (max-width: 450px){.skill-name{font-size:9px}}.skills-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-top:4rem}@media screen and (max-width: 450px){.skills-summary{grid-template-columns:1fr;gap:1.5rem}}.summary-item{text-align:center;padding:1.5rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:1rem;transition:all .25s ease-in-out;position:relative;overflow:hidden}.summary-item:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(63,193,201,.1),transparent);transition:left .5s}.summary-item:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:#3fc1c94d}.summary-item:hover:before{left:100%}@media screen and (max-width: 450px){.summary-item{padding:1.25rem}}.summary-icon{font-size:3rem;margin-bottom:1rem;filter:drop-shadow(2px 2px 4px rgba(0,0,0,.1));position:relative;z-index:2}@media screen and (max-width: 450px){.summary-icon{font-size:2.5rem;margin-bottom:.75rem}}.summary-item h4{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0 0 .75rem;position:relative;z-index:2}@media screen and (max-width: 450px){.summary-item h4{font-size:1.125rem}}.summary-item p{font-size:1rem;color:var(--text-secondary);line-height:1.75;margin:0;position:relative;z-index:2}@media screen and (max-width: 450px){.summary-item p{font-size:.875rem}}@keyframes spin{0%{transform:rotate(calc(var(--orbit-angle) + 0deg)) translateY(-140px) rotate(calc(-1 * (var(--orbit-angle) + 0deg)))}to{transform:rotate(calc(var(--orbit-angle) + 360deg)) translateY(-140px) rotate(calc(-1 * (var(--orbit-angle) + 360deg)))}}@media screen and (max-width: 450px){@keyframes spin{0%{transform:rotate(calc(var(--orbit-angle) + 0deg)) translateY(-110px) rotate(calc(-1 * (var(--orbit-angle) + 0deg)))}to{transform:rotate(calc(var(--orbit-angle) + 360deg)) translateY(-110px) rotate(calc(-1 * (var(--orbit-angle) + 360deg)))}}}.skill-category:hover .orbiting-skill{animation-play-state:paused}.orbiting-skill:nth-child(1){animation-delay:0s}.orbiting-skill:nth-child(2){animation-delay:-2s}.orbiting-skill:nth-child(3){animation-delay:-4s}.orbiting-skill:nth-child(4){animation-delay:-6s}.orbiting-skill:nth-child(5){animation-delay:-8s}.orbiting-skill:nth-child(6){animation-delay:-10s}.orbiting-skill:nth-child(7){animation-delay:-12s}.orbiting-skill:nth-child(8){animation-delay:-14s}.orbiting-skill:nth-child(9){animation-delay:-16s}@keyframes pulse{0%,to{box-shadow:0 0 20px #3fc1c94d}50%{box-shadow:0 0 30px #3fc1c999}}.skill-category:after{animation:pulse 3s infinite ease-in-out}[data-theme=dark] .orbiting-skill{box-shadow:0 4px 12px #0006}[data-theme=dark] .orbiting-skill:hover{box-shadow:0 10px 30px #3fc1c966}[data-theme=dark] .skill-icon img{filter:drop-shadow(2px 2px 6px rgba(0,0,0,.3))}[data-theme=dark] .orbiting-skill:hover .skill-icon img{filter:drop-shadow(2px 2px 8px rgba(63,193,201,.5))}[data-theme=dark] .skill-category:after{box-shadow:0 0 25px #3fc1c966}.projects-section{background:var(--bg-secondary);padding:5rem 0}@media screen and (max-width: 768px){.projects-section{padding:4rem 0}}@media screen and (max-width: 450px){.projects-section{padding:3rem 0}}.projects-filter{display:flex;justify-content:center;gap:.75rem;margin-bottom:4rem;flex-wrap:wrap}@media screen and (max-width: 450px){.projects-filter{gap:.5rem;margin-bottom:3rem}}.filter-btn{padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:var(--text-secondary);background:var(--bg-primary);border:none;border-radius:9999px;cursor:pointer;transition:all .15s ease-in-out}.filter-btn:hover{color:var(--text-primary);background:var(--bg-tertiary)}.filter-btn:focus-visible{outline:2px solid #3fc1c9;outline-offset:2px}.filter-btn.active{color:#fff;background:linear-gradient(135deg,#3fc1c9,#fc5185)}.filter-btn.active:hover{color:#fff;filter:brightness(1.1)}@media screen and (max-width: 450px){.filter-btn{padding:.5rem .75rem;font-size:.75rem}}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem}@media screen and (max-width: 450px){.projects-grid{grid-template-columns:1fr;gap:1.5rem}}.project-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:1rem;padding:1.5rem;transition:all .25s ease-in-out;display:flex;flex-direction:column;height:100%}.project-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#3fc1c94d}@media screen and (max-width: 450px){.project-card{padding:1.25rem}}.project-header{margin-bottom:1rem}.project-status{display:flex;justify-content:space-between;align-items:center}.status-badge{font-size:.75rem;font-weight:500;padding:.25rem .5rem;border-radius:.25rem;text-transform:uppercase;letter-spacing:.5px}.status-badge.status-completed{background:rgba(34,197,94,.1);color:#16a34a}.status-badge.status-progress{background:rgba(251,191,36,.1);color:#d97706}.status-badge.status-planned{background:rgba(156,163,175,.1);color:#6b7280}.project-category{font-size:.75rem;color:var(--text-secondary);font-weight:500}.project-content{flex:1;margin-bottom:1.5rem}.project-content h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0 0 .75rem;line-height:1.25}@media screen and (max-width: 450px){.project-content h3{font-size:1.125rem}}.project-description{font-size:1rem;color:var(--text-secondary);line-height:1.75;margin:0 0 1rem}@media screen and (max-width: 450px){.project-description{font-size:.875rem}}.project-tech{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.tech-tag{font-size:.75rem;font-weight:500;color:#3fc1c9;background:rgba(63,193,201,.1);padding:.25rem .5rem;border-radius:.25rem;border:1px solid rgba(63,193,201,.2)}.tech-more{font-size:.75rem;color:var(--text-secondary);font-weight:500}.project-actions{display:flex;justify-content:space-between;align-items:center;margin-top:auto}.btn-details{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.5rem;cursor:pointer;transition:all .15s ease-in-out}.btn-details:hover{background:var(--bg-tertiary);border-color:#3fc1c9;color:#3fc1c9}.project-links{display:flex;gap:.5rem}.project-link{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.5rem;transition:all .15s ease-in-out}.project-link:hover{color:#3fc1c9;background:rgba(63,193,201,.1);border-color:#3fc1c9;transform:translateY(-1px)}.project-link svg{width:1.25rem;height:1.25rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;z-index:1050;padding:1rem}.project-modal{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:1rem;max-width:600px;max-height:80vh;width:100%;overflow-y:auto;animation:modalAppear .25s ease-in-out cubic-bezier(0,0,.2,1)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 0}.modal-header h3{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0}@media screen and (max-width: 450px){.modal-header h3{font-size:1.25rem}}.modal-close{width:2.5rem;height:2.5rem;background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;border-radius:.5rem;transition:all .15s ease-in-out}.modal-close:hover{color:var(--text-primary);background:var(--bg-secondary)}.modal-content{padding:1.5rem}@media screen and (max-width: 450px){.modal-content{padding:1.25rem}}.project-meta{display:flex;gap:1rem;align-items:center;margin-bottom:1.5rem}.project-long-description{font-size:1rem;color:var(--text-secondary);line-height:1.75;margin-bottom:1.5rem}.project-features{margin-bottom:1.5rem}.project-features h4{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}.project-features ul{margin:0;padding-left:1.25rem}.project-features ul li{font-size:.875rem;color:var(--text-secondary);line-height:1.75;margin-bottom:.5rem}.project-features ul li:last-child{margin-bottom:0}.project-tech-full{margin-bottom:2rem}.project-tech-full h4{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}.tech-tags{display:flex;flex-wrap:wrap;gap:.5rem}.modal-actions{display:flex;gap:1rem;justify-content:center}@media screen and (max-width: 450px){.modal-actions{flex-direction:column;gap:.75rem}}@keyframes modalAppear{0%{opacity:0;transform:scale(.9) translateY(2rem)}to{opacity:1;transform:scale(1) translateY(0)}}@media screen and (max-width: 450px){.projects-grid{grid-template-columns:1fr}.project-actions{flex-direction:column;gap:.75rem;align-items:stretch}.btn-details,.project-links{justify-content:center}}.contact-section{background:var(--bg-primary);padding:5rem 0}@media screen and (max-width: 768px){.contact-section{padding:4rem 0}}@media screen and (max-width: 450px){.contact-section{padding:3rem 0}}.contact-content{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}@media screen and (max-width: 1024px){.contact-content{grid-template-columns:1fr;gap:3rem}}@media screen and (max-width: 1024px){.contact-info{order:2}}.contact-intro{margin-bottom:2.5rem}.contact-intro h3{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}@media screen and (max-width: 450px){.contact-intro h3{font-size:1.25rem}}.contact-intro p{font-size:1rem;color:var(--text-secondary);line-height:1.75;margin:0}.contact-details{margin-bottom:3rem}.contact-item{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}.contact-item:last-child{margin-bottom:0}.contact-icon{display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;background:rgba(63,193,201,.1);color:#3fc1c9;border-radius:.75rem;flex-shrink:0}.contact-icon svg{width:1.25rem;height:1.25rem}@media screen and (max-width: 450px){.contact-icon{width:2.5rem;height:2.5rem}.contact-icon svg{width:1rem;height:1rem}}.contact-text{flex:1;padding-top:.5rem}.contact-label{display:block;font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.contact-value{font-size:1rem;color:var(--text-secondary);text-decoration:none;transition:color .15s ease-in-out}.contact-value[href]:hover{color:#3fc1c9}@media screen and (max-width: 450px){.contact-value{font-size:.875rem}}.social-links h4{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}.social-icons{display:flex;gap:1rem}.social-link{display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:.75rem;transition:all .25s ease-in-out}.social-link:hover{background:var(--hover-color);color:#fff;border-color:var(--hover-color);transform:translateY(-2px)}.social-link svg{width:1.25rem;height:1.25rem}@media screen and (max-width: 450px){.social-link{width:2.5rem;height:2.5rem}.social-link svg{width:1rem;height:1rem}}@media screen and (max-width: 1024px){.contact-form-container{order:1}}.contact-form{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:1rem;padding:2rem}@media screen and (max-width: 450px){.contact-form{padding:1.5rem}}.form-group{margin-bottom:1.5rem}.form-group:last-child{margin-bottom:0}label{display:block;font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}input,textarea{width:100%;padding:.75rem 1rem;font-size:1rem;font-family:inherit;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:.75rem;transition:all .15s ease-in-out;resize:vertical}input:focus,textarea:focus{outline:none;border-color:#3fc1c9;box-shadow:0 0 0 3px #3fc1c91a}input::placeholder,textarea::placeholder{color:var(--text-secondary)}input.error,textarea.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}@media screen and (max-width: 450px){input,textarea{padding:.75rem;font-size:.875rem}}textarea{min-height:120px;max-height:300px}.submit-btn{width:100%;padding:1rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#3fc1c9,#fc5185);border:none;border-radius:.75rem;cursor:pointer;transition:all .25s ease-in-out;position:relative;overflow:hidden}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.submit-btn:active:not(:disabled){transform:translateY(0)}.submit-btn:disabled{opacity:.7;cursor:not-allowed}.submit-btn.submitting:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:loading-shimmer 1.5s infinite}@media screen and (max-width: 450px){.submit-btn{padding:.75rem 1.25rem;font-size:.875rem}}.error-message{display:block;font-size:.75rem;color:#ef4444;margin-top:.5rem;font-weight:500}.success-message{background:rgba(34,197,94,.1);color:#16a34a;padding:1rem;border-radius:.75rem;font-size:.875rem;font-weight:500;text-align:center;margin-top:1rem;border:1px solid rgba(34,197,94,.2)}.form-group .error-message{background:rgba(239,68,68,.1);color:#dc2626;padding:1rem;border-radius:.75rem;font-size:.875rem;font-weight:500;text-align:center;margin-top:1rem;border:1px solid rgba(239,68,68,.2)}@keyframes loading-shimmer{0%{left:-100%}to{left:100%}}.contact-form input:focus,.contact-form textarea:focus{outline:2px solid #3fc1c9;outline-offset:2px}[data-theme=dark] .social-link:hover{color:#fff}[data-theme=dark] input::placeholder,[data-theme=dark] textarea::placeholder{color:var(--text-secondary);opacity:.7}@media screen and (max-width: 450px){.contact-content{gap:2rem}.contact-item{gap:.75rem;margin-bottom:1.25rem}.social-icons{gap:.75rem}}
