:root{--bg-primary:#fff;--bg-secondary:#f8f9fa;--text-primary:#1a1b26;--text-secondary:#4a5568;--accent:#2563eb;--code-bg:#fff;--code-text:#333;--code-line-number:#237893;--code-comment:green;--code-string:#a31515;--code-keyword:#00f;--code-function:#795e26;--code-variable:#001080;--code-number:#098658;--code-property:#0070c1;--code-punctuation:#000;--code-operator:#000;--code-tab-bg:#f3f3f3;--code-tab-active:#fff;--code-tab-border:#e4e4e4;--code-header-bg:#f3f3f3}[data-theme=dark]{--bg-primary:#0a0b14;--bg-secondary:#1a1b26;--text-primary:#fff;--text-secondary:#8892b0;--accent:#00ffa3;--code-bg:#0d1117;--code-text:#d4d4d4;--code-line-number:#858585;--code-comment:#6a9955;--code-string:#ce9178;--code-keyword:#569cd6;--code-function:#dcdcaa;--code-variable:#9cdcfe;--code-number:#b5cea8;--code-property:#4fc1ff;--code-punctuation:#d4d4d4;--code-operator:#d4d4d4;--code-tab-bg:#21262d;--code-tab-active:#0d1117;--code-tab-border:#30363d;--code-header-bg:#161b22}*{scroll-behavior:smooth;transition:background-color .3s ease,color .3s ease,border-color .3s ease}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;background-color:var(--bg-primary);color:#1a1b26;color:var(--text-primary);font-family:Monaco,Menlo,Ubuntu Mono,Consolas,source-code-pro,monospace;margin:0}.App{min-height:100vh}.content{margin-top:2rem}.HomePage{display:flex;min-height:100vh;padding:0}#root,.HomePage,body,html{box-sizing:border-box;max-width:100vw;overflow-x:hidden!important;width:100vw}nav{align-items:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:rgba(var(--bg-primary-rgb),.85);display:flex;justify-content:space-between;left:0;padding:1rem 2rem;position:fixed;right:0;top:0;transform:translateY(0);transition:all .3s ease;width:100%;z-index:1000}nav.scrolled{background:var(--bg-primary);box-shadow:0 4px 20px #0000001a;padding:.7rem 2rem}.nav-container{align-items:center;display:flex;justify-content:space-between;max-width:1400px;width:100%}.content-wrapper{box-sizing:border-box;margin:0 auto;max-width:1400px;max-width:100vw;overflow-x:hidden;padding:5rem 2rem 1rem;width:100%}.main-content{align-items:center;display:flex;min-height:calc(100vh - 200px);padding:2rem 0}.hero-content{flex:0 0 45%;max-width:600px}.logo{animation:fadeIn .5s ease-out forwards;color:var(--text-primary);font-size:1.5rem!important;font-weight:500;opacity:0}@media (max-width:900px){.logo{font-size:1.1rem!important}}@media (max-width:401px){.logo{font-size:.9rem!important}}.logo span{color:var(--accent)}.nav-right{align-items:center}.nav-links,.nav-right{display:flex;gap:1.5rem}.nav-links a{animation:fadeIn .5s ease-out forwards;color:var(--text-primary);font-size:1.1rem;font-weight:500;opacity:0;text-decoration:none}.nav-links a:first-child{animation-delay:.1s}.nav-links a:nth-child(2){animation-delay:.2s}.nav-links a:nth-child(3){animation-delay:.3s}.nav-links a:nth-child(4){animation-delay:.4s}.nav-links a:nth-child(5){animation-delay:.5s}.nav-links a:hover{color:var(--accent);opacity:1}.hello{animation-delay:.2s;color:var(--accent);font-size:2rem;font-weight:500;margin-bottom:1rem}.name{animation-delay:.4s;font-size:3.5rem;font-weight:600;margin:.5rem 0}.name,.role{line-height:1.2}.role{animation-delay:.6s;font-size:2.5rem;font-weight:500;margin:1rem 0 1.5rem}.description{animation-delay:.8s;color:var(--text-secondary);font-size:1.1rem;line-height:1.6;margin:1.5rem 0;max-width:540px}.social-links{animation-delay:1s;gap:1.5rem;margin:2rem 0}.social-links a{color:var(--text-secondary);font-size:1.5rem;transition:all .2s}.social-links a:hover{color:var(--accent);transform:translateY(-2px)}.buttons{animation-delay:1.2s;display:flex;gap:1.5rem;margin-top:2rem}.btn{border-radius:6px;font-size:1rem;font-weight:500;letter-spacing:.5px;padding:.8rem 2rem;text-decoration:none;transition:all .2s}.btn-primary{background:var(--accent);color:var(--bg-primary)}.btn-secondary{border:1px solid var(--accent);color:var(--accent)}.btn:hover{box-shadow:0 5px 15px #00ffa333;transform:translateY(-2px)}.code-section{animation:slideInRight .8s ease-out .4s forwards;display:flex;flex:0 0 55%;justify-content:flex-end;opacity:0;padding-left:2rem}.code-preview{background:var(--code-bg);border:1px solid var(--code-tab-border);border-radius:8px;box-shadow:0 4px 20px #0000001a;display:flex;flex-direction:column;max-width:550px;min-width:0;overflow:hidden;width:100%}@media (max-width:900px){.code-preview{max-width:98vw;min-width:0}}.code-header{background:var(--code-header-bg);border-bottom:1px solid var(--code-tab-border);display:flex;gap:0;padding:0}.code-tab{align-items:center;background:var(--code-tab-bg);border-right:1px solid var(--code-tab-border);color:var(--text-secondary);cursor:pointer;display:flex;font-size:13px;gap:8px;min-width:100px;padding:8px 16px;position:relative}.code-tab.active{background:var(--code-tab-active);color:var(--text-primary)}.code-tab.active:after{background:var(--code-tab-active);bottom:-1px;content:"";height:1px;left:0;position:absolute;right:0}.code-content{background:var(--code-bg);flex-grow:1;font-family:Consolas,Monaco,monospace;font-size:14px;line-height:20px;min-height:300px;overflow-y:auto;padding:0;position:relative}.line-numbers{background:var(--code-bg);border-right:1px solid var(--code-tab-border);bottom:0;left:0;padding:12px 0;position:absolute;top:0;-webkit-user-select:none;user-select:none;width:50px}.line-numbers span{color:var(--code-line-number);display:block;font-size:14px;height:20px;line-height:20px;padding:0 12px 0 0;text-align:right}.code-lines{margin-left:50px;padding:12px 16px}.code-line{color:var(--code-text);height:20px;padding:0;white-space:pre}.comment{color:var(--code-comment)}.keyword{color:var(--code-keyword)}.string{color:var(--code-string)}.number{color:var(--code-number)}.function{color:var(--code-function)}.variable{color:var(--code-variable)}.property{color:var(--code-property)}.punctuation{color:var(--code-punctuation)}.operator{color:var(--code-operator)}.theme-toggle{align-items:center;animation:fadeIn .5s ease-out .6s forwards;background:#0000;border:2px solid var(--text-secondary);border-radius:50%;color:var(--text-primary);cursor:pointer;display:flex;height:40px;justify-content:center;opacity:0;padding:.5rem;transition:all .3s ease;width:40px}.theme-toggle:hover{background:var(--accent);border-color:var(--accent);color:var(--bg-primary);transform:rotate(1turn)}.theme-icon{color:currentColor;height:20px!important;width:20px!important}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-content>*{animation:slideUpFade .7s ease-out forwards;opacity:0}*{transition:background-color .3s ease,color .3s ease,border-color .3s ease,opacity .3s ease,transform .3s ease}.typing-text{display:inline}.cursor{animation:blink .7s infinite;background-color:var(--text-primary);display:inline-block;height:1em;margin-left:2px;vertical-align:middle;width:3px}.about-section{margin:6rem 0;opacity:1!important;position:relative;transform:none!important;transition:none!important;will-change:auto!important}.about-section:after,.about-section:before{display:none!important}.contact-section:after,.contact-section:before{content:none!important;display:none!important}#about,#contact,#education,#projects,#roadmap,#skills{scroll-margin-top:5rem}.about-section .about-image-card,.about-section .about-text,.about-section .section-title,.about-section .skills-categories{opacity:1!important;transform:none!important;transition:none!important}.about-section[data-visible=true] .skill-item{animation:popIn .5s cubic-bezier(.4,0,.2,1) forwards}.about-section[data-visible=true] .skill-item:first-child{animation-delay:.5s}.about-section[data-visible=true] .skill-item:nth-child(3){animation-delay:.6s}.about-section[data-visible=true] .skill-item:nth-child(5){animation-delay:.7s}.about-section[data-visible=true] .skill-item:nth-child(7){animation-delay:.8s}@keyframes slideUpAndFade{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleInAndFade{0%{opacity:0;transform:scale(.9) translateY(30px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes popIn{0%{opacity:0;transform:scale(.8)}70%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.about-container{align-items:center;display:flex;gap:4rem;margin-top:3rem}.about-content{background:var(--bg-secondary);border:1px solid #ffffff1a;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:2rem}.about-content,.about-image-card{flex:1 1;opacity:1!important;transform:none!important;transition:none!important}.about-image-card{max-width:500px}.about-section.visible .about-content,.about-section.visible .about-image-card{opacity:1;transform:translateY(0)}.about-card{align-items:center;background:var(--bg-secondary);border-radius:16px;box-shadow:0 4px 20px #0000001a;display:flex;flex-wrap:wrap;gap:4rem;padding:2rem}@media (max-width:900px){.about-card{flex-direction:column;gap:1.5rem;padding:1rem}.about-image-card{margin:0 auto;max-width:320px;width:100%}}.image-container{background:var(--bg-secondary);border-radius:8px;box-shadow:0 4px 20px #00000026;overflow:hidden;padding-top:100%;position:relative;width:100%}.profile-image{height:100%;left:0;object-fit:cover;position:absolute;top:0;transition:transform .3s ease;width:100%}.image-container:hover .profile-image{transform:scale(1.05)}.section-title{align-items:center;display:flex;font-size:2rem;gap:.5rem;justify-content:center;margin-bottom:2rem;text-align:center;width:100%}.angle-bracket{color:var(--accent);font-family:Monaco,monospace}.about-text{color:var(--text-secondary);font-family:Monaco,Menlo,monospace;font-size:1.1rem;line-height:1.8;margin-bottom:2rem}.skills-categories{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}@media (max-width:900px){.skills-categories{align-items:stretch!important;display:flex!important;flex-direction:column!important;gap:.7rem!important;width:100%!important}.skill-item{box-sizing:border-box;display:block!important;margin:0!important;text-align:left!important;width:100%!important}}.skill-item{color:var(--accent);font-size:1.1rem;font-weight:500;transition:all .2s}.skill-item:hover{transform:translateY(-2px)}.separator{color:var(--text-secondary);opacity:.5}.projects-section{animation:slideUpFade .7s ease-out forwards;margin:6rem 0;opacity:0;position:relative;transform:translateY(40px)}.projects-section:after,.projects-section:before{display:none!important}.projects-container{grid-gap:2.5rem;display:grid;gap:2.5rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));margin-top:3rem;perspective:1000px}.project-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-secondary);border:1px solid #ffffff1a;border-radius:16px;box-shadow:0 4px 20px #0000001a;overflow:hidden;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1)}.project-card:hover{box-shadow:0 20px 40px #0003;transform:translateY(-10px) rotateX(5deg)}.project-card:before{background:linear-gradient(45deg,#0000,rgba(var(--accent-rgb),.1));bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .4s ease}.project-card:hover:before{opacity:1}.project-image{height:240px;overflow:hidden;position:relative;width:100%}.project-image:after{background:linear-gradient(to bottom,#0000 0,var(--bg-secondary) 100%);bottom:0;content:"";left:0;opacity:.3;position:absolute;right:0;top:0}.project-image img{height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.4,0,.2,1);width:100%}.project-card:hover .project-image img{transform:scale(1.1) translateY(-5px)}.project-content{padding:2rem;position:relative;z-index:1}.project-content h3{color:var(--text-primary);display:inline-block;font-size:1.6rem;margin-bottom:1rem;position:relative}.project-content h3:after{background:var(--accent);bottom:-5px;content:"";height:3px;left:0;position:absolute;transition:width .3s ease;width:40%}.project-card:hover .project-content h3:after{width:100%}.project-description{color:var(--text-secondary);font-family:Monaco,monospace;font-size:1.1rem;line-height:1.6;margin-bottom:1.5rem}.project-tech{color:var(--accent);display:flex;flex-wrap:wrap;font-size:.95rem;gap:.5rem;margin-bottom:2rem}.project-tech:before{content:"{ ";opacity:.7}.project-tech:after{content:" }";opacity:.7}.project-links{display:flex!important;gap:1.5rem;opacity:1!important;transform:none!important;transition:all .4s ease}.project-card .btn{transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1)}.project-card:hover .btn{box-shadow:0 5px 15px #00ffa333;transform:translateY(-2px) scale(1.05)}.education-section{animation:slideUpFade .7s ease-out forwards;margin:8rem 0;opacity:0;position:relative;transform:translateY(40px)}.education-section:before{background:linear-gradient(to bottom,#0000,var(--accent),#0000);bottom:0;content:"";left:50%;position:absolute;top:0;width:2px}@media (max-width:900px){.education-section:before{display:none!important}}.education-container{margin-left:auto;margin-right:auto;margin-top:4rem;max-width:1200px;position:relative}.education-card{animation:slideUpFade .7s ease-out forwards;margin:2rem 0;opacity:0;position:relative;width:calc(50% - 30px)}.education-card:nth-child(odd){margin-left:auto;padding-left:3rem}.education-card:nth-child(2n){margin-right:auto;padding-right:3rem;text-align:right}.education-card:before{background:var(--accent);border-radius:50%;content:"";height:20px;position:absolute;top:50%;transform:translateY(-50%);width:20px}.education-card:nth-child(odd):before{left:-10px}.education-card:nth-child(2n):before{right:-10px}.education-card:after{background:var(--accent);content:"";height:2px;position:absolute;top:50%;transform:translateY(-50%);width:30px}.education-card:nth-child(odd):after{left:0}.education-card:nth-child(2n):after{right:0}.education-content{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-secondary);border:1px solid #ffffff1a;border-radius:16px;box-shadow:0 4px 20px #0000001a;padding:2rem;transition:all .4s cubic-bezier(.4,0,.2,1)}.education-card:hover .education-content{box-shadow:0 8px 30px #00000026;transform:scale(1.05)}.education-year{background:rgba(var(--accent-rgb),.1);border-radius:20px;color:var(--accent);display:inline-block;font-size:1.2rem;font-weight:600;margin-bottom:1rem;padding:.5rem 1rem}.education-content h3{color:var(--text-primary);display:inline-block;font-size:1.5rem;margin:1rem 0;position:relative}.education-content .degree{color:var(--text-secondary);font-family:Monaco,monospace;font-size:1.1rem}@keyframes slideIn{0%{opacity:0;transform:translateX(-100px)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(100px)}to{opacity:1;transform:translateX(0)}}.education-card:nth-child(odd){animation:slideIn .7s ease-out forwards;animation-delay:calc(var(--delay)*.2s)}.education-card:nth-child(2n){animation:slideInRight .7s ease-out forwards;animation-delay:calc(var(--delay)*.2s)}@media (max-width:768px){.education-section:before{left:20px}.education-card{margin-left:50px!important;padding-left:2rem!important;padding-right:0!important;text-align:left!important;width:calc(100% - 50px)}.education-card:before{left:-40px!important;right:auto!important}.education-card:after{left:-20px!important;right:auto!important}}@media (max-width:900px){.education-card:after,.education-card:before{content:none!important;display:none!important}.education-card{box-sizing:border-box;left:0!important;margin-left:0!important;margin-right:0!important;padding-left:0!important;padding-right:0!important;right:0!important;text-align:center!important;width:100%!important}}@media (max-width:768px){.projects-container{grid-template-columns:1fr}.education-card{flex-direction:column;gap:1rem;padding:1.5rem}.education-year{flex:none}}.hamburger{align-items:center;background:none;border:none;cursor:pointer;display:none;flex-direction:column;height:40px;justify-content:center;position:relative;transition:all .3s;width:40px;z-index:1002}.hamburger .bar{background:var(--text-primary);border-radius:2px;height:3px;margin:4px 0;transition:all .4s cubic-bezier(.4,0,.2,1);width:26px}.hamburger.open .bar:first-child{transform:translateY(7px) rotate(45deg)}.hamburger.open .bar:nth-child(2){opacity:0}.hamburger.open .bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}@media (max-width:900px){nav{padding:1rem}nav.scrolled{padding:.7rem 1rem}.nav-right{align-items:center;display:flex;position:relative}.hamburger{margin-left:auto;position:relative;right:0;z-index:1002}.nav-container{padding-right:50px;position:relative}.nav-links{align-items:flex-start;background:var(--bg-primary);box-shadow:-2px 0 24px #0000001f;flex-direction:column;gap:2rem;height:100vh;justify-content:flex-start;max-width:320px;opacity:0;padding:5rem 2rem 2rem;pointer-events:none;position:fixed;right:0;top:0;transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.2,1),opacity .3s;width:70vw;z-index:1001}.nav-links.open{opacity:1;pointer-events:auto;transform:translateX(0)}.nav-links a{animation:none;border-bottom:1px solid #eee1;border-bottom:1px solid var(--border-color,#eee1);font-size:1.3rem;opacity:1;padding:.5rem 0;width:100%}.nav-theme-toggle{display:flex!important}.theme-toggle:not(.nav-theme-toggle){display:none!important}.nav-right{gap:.5rem}.hamburger{display:flex}.nav-links,.nav-links a,.nav-theme-toggle{align-items:center!important;text-align:center!important}.nav-links a,.nav-theme-toggle{justify-content:center!important;margin:0 auto!important;width:100%!important}.nav-theme-toggle{align-items:center!important;animation:none!important;background:#eaeaea;background:var(--bg-secondary,#eaeaea);border:none!important;border-radius:16px!important;box-shadow:0 2px 8px #00000012;display:flex!important;height:28px!important;justify-content:center!important;margin:1.2rem auto 0!important;opacity:1!important;padding:0!important;position:relative;transition:background .3s;width:48px!important}.nav-theme-toggle .toggle-bg{background:#d1d1d6;border-radius:16px;height:100%;left:0;position:absolute;top:0;transition:background .3s;width:100%;z-index:1}.nav-theme-toggle.dark{background:#00ffa3;background:var(--accent,#00ffa3)}.nav-theme-toggle .toggle-slider{align-items:center;background:#fff;background:var(--bg-primary,#fff);border-radius:50%;box-shadow:0 1px 4px #0000001a;color:var(--accent);display:flex;font-size:1.1rem;height:22px;justify-content:center;left:3px;position:absolute;top:3px;transition:left .3s,background .3s;width:22px;z-index:2}.nav-theme-toggle.dark .toggle-slider{background:#00ffa3;background:var(--accent,#00ffa3);color:#fff;left:23px}.nav-theme-toggle .toggle-icon{align-items:center;display:flex;font-size:1.1rem;justify-content:center;pointer-events:none;transition:color .3s;z-index:3}}@media (min-width:901px){.hamburger{display:none!important}.nav-links{background:none;box-shadow:none;flex-direction:row;gap:1.5rem;height:auto;opacity:1;padding:0;pointer-events:auto;position:static;transform:none;width:auto}.nav-theme-toggle{display:none!important}}@media (max-width:900px){.main-content{align-items:stretch;flex-direction:column;gap:2.5rem;margin-top:3rem;padding:1.5rem 0}.code-section,.hero-content{flex:1 1 100%;max-width:100%;padding:0}.hero-content{margin:0 auto;text-align:center}.hero-content,.hero-content .buttons{align-items:center;justify-content:center}.hero-content .buttons{display:flex;flex-direction:column;gap:1rem;width:100%}.contact-section button,.contact-section form,.contact-section input,.contact-section textarea{box-sizing:border-box;min-width:0!important;width:100%!important}.about-content{align-self:stretch!important;box-sizing:border-box;flex:1 1 100%!important;margin:0!important;max-width:100%!important;padding:1rem!important;width:100%!important}}@media (max-width:600px){.content-wrapper{padding:.5rem}.hero-content .name{font-size:2.1rem}.role{font-size:1.3rem}.section-title{font-size:1.2rem}.about-container{flex-direction:column;gap:2rem}.about-content,.about-image-card{max-width:100%;padding:1rem}.about-section,.education-section,.projects-section{margin:3rem 0}}@media (max-width:401px){.content-wrapper{padding:.2rem .1rem}.logo{font-size:.9rem!important}.nav-links{gap:1.2rem;max-width:100vw;padding:4rem .5rem 1rem;width:100vw}.nav-links a{font-size:1.05rem;padding:.4rem 0}.main-content{gap:1.2rem;padding:.5rem 0}.hero-content .name{font-size:1.3rem}.role{font-size:.9rem}.section-title{font-size:.95rem}.about-content,.about-image-card{padding:.5rem}.about-text,.education-content .degree,.project-description{font-size:.9rem}.btn{font-size:.85rem;padding:.5rem 1.1rem}.code-preview{max-width:98vw;min-width:0}.code-header{min-width:0}.line-numbers{font-size:11px;width:30px}.code-lines{font-size:11px;margin-left:30px;padding:8px 4px}.profile-image{border-radius:6px}}@media (min-width:901px){.section-title{justify-content:flex-start;text-align:left}}.about-section,.contact-section,.education-section,.projects-section{opacity:1!important;transform:none!important;transition:none!important;will-change:auto!important}.skills-section{background-color:var(--bg-primary);color:var(--text-primary);padding:4rem 2rem}.skills-header{margin-bottom:3rem;opacity:0;text-align:center;transform:translateY(20px)}.skills-header.animate-in{animation:slideUpFade .6s ease forwards}.skills-header .tag{animation:slideUpFade .6s ease forwards;animation-delay:.2s;color:var(--accent);display:inline-block;font-family:Fira Code,monospace;font-size:1.2rem;opacity:0;transform:translateY(20px)}.skills-header h2{animation:slideUpFade .6s ease forwards;animation-delay:.4s;color:var(--text-primary);font-size:2.5rem;margin:1rem 0}.skills-header h2,.skills-header p{opacity:0;transform:translateY(20px)}.skills-header p{animation:slideUpFade .6s ease forwards;animation-delay:.6s;color:var(--text-secondary);font-size:1.1rem}.main-skills{display:flex;gap:2rem;justify-content:center;margin-bottom:3rem}.main-skills .skill-card,.tech-grid .skill-card{opacity:0;transform:translateY(40px)}.main-skills .skill-card.animate-in,.tech-grid .skill-card.animate-in{animation:slideUpFade .6s ease forwards}.skill-card.main{align-items:center;background-color:var(--bg-secondary);border-radius:8px;display:flex;flex-direction:column;gap:1rem;min-width:180px;padding:1.5rem;position:relative}.skill-card.main svg{font-size:3rem;margin-bottom:.5rem}.skill-card.main .skill-name{color:var(--text-primary);font-size:1.1rem;font-weight:500;margin-bottom:.5rem}.progress-container{background-color:#ffffff1a;height:8px;overflow:hidden;width:100%}.progress-bar,.progress-container{border-radius:4px;position:relative}.progress-bar{height:100%;opacity:0;transform:scaleX(0);transform-origin:left;transition:width 1s ease-in-out}.skill-card.animate-in .progress-bar{animation:progressGrow 1s ease forwards;animation-delay:.4s}.progress-text{color:var(--text-secondary);font-size:.8rem;position:absolute;right:0;top:-20px}.tech-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));padding:1rem}.skill-card{background-color:var(--bg-secondary);border-radius:12px;padding:2rem;text-align:center;transition:transform .3s ease}.skill-card:hover{transform:translateY(-5px)}.skill-icon{align-items:center;display:flex;height:3.75rem;justify-content:center;margin:0 auto 1rem;width:3.75rem}.skill-icon svg{font-size:3rem}.svg-wrapper{align-items:center;display:flex;height:100%;justify-content:center;width:100%}.skill-card h3{color:var(--text-primary);font-size:1.2rem;margin-bottom:1rem}.skill-card p{color:var(--text-secondary);font-size:.9rem;line-height:1.4}.api-svg-icon{fill:currentColor;display:inline-block;height:3.75rem!important;max-height:100%;max-width:100%;vertical-align:middle;width:3.75rem!important}@keyframes slideUpFade{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes progressGrow{0%{opacity:0;transform:scaleX(0)}to{opacity:1;transform:scaleX(1)}}.roadmap-section{background-color:var(--bg-secondary);padding:4rem 2rem}.stats-container{grid-gap:2rem;background-color:var(--bg-primary);border-radius:12px;display:grid;gap:2rem;grid-template-columns:repeat(4,1fr);margin:0 auto;max-width:1200px;padding:3rem}.stat-item{opacity:0;text-align:center;transform:translateY(20px)}.stat-item.animate-in{animation:fadeInUp .6s ease forwards}.stat-value{color:var(--accent);display:block;font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.stat-label{color:var(--text-primary);display:flex;flex-direction:column;font-size:1.1rem}.stat-sublabel{color:var(--text-secondary);font-size:.9rem}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.stats-container{grid-template-columns:repeat(2,1fr);padding:2rem}}@media (max-width:480px){.stats-container{grid-template-columns:1fr}}.contact-section{background-color:var(--bg-primary);color:var(--text-primary);opacity:0;padding:6rem 2rem;position:relative;transform:translateY(40px);transition:all .8s cubic-bezier(.4,0,.2,1)}.contact-section:before{content:"<contact>";top:-20px}.contact-section:after,.contact-section:before{color:var(--accent);font-family:Monaco,monospace;font-size:.9rem;left:0;opacity:.5;position:absolute}.contact-section:after{bottom:-20px;content:"</contact>"}.contact-section.visible{opacity:1;transform:translateY(0)}.contact-content{grid-gap:4rem;display:grid;gap:4rem;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1200px;opacity:0;transform:translateY(30px);transition:all .6s cubic-bezier(.4,0,.2,1);transition-delay:.2s}.contact-section.visible .contact-content{opacity:1;transform:translateY(0)}.contact-left{display:flex;flex-direction:column;opacity:0;transform:translateX(-30px);transition:all .6s cubic-bezier(.4,0,.2,1);transition-delay:.4s}.contact-section.visible .contact-left{opacity:1;transform:translateX(0)}.contact-left .tag{color:var(--accent);font-family:Monaco,monospace;font-size:1.1rem;margin-bottom:1rem;opacity:.9}.contact-left h2{color:var(--text-primary);font-size:3.5rem;font-weight:600;line-height:1.2;margin:0}.contact-left p{color:var(--text-secondary);font-size:3.5rem;font-weight:500;line-height:1.2;margin-bottom:.3rem;margin-top:.2rem}.contact-left .accent{color:var(--accent);font-weight:600}.contact-info{margin:1.5rem 0;opacity:0;transform:translateY(20px);transition:all .6s cubic-bezier(.4,0,.2,1);transition-delay:.6s}.contact-section.visible .contact-info{opacity:1;transform:translateY(0)}.info-item{align-items:center;color:var(--text-secondary);display:flex;font-size:1rem;margin:1.5rem 0;opacity:0;transform:translateX(-20px);transition:all .6s cubic-bezier(.4,0,.2,1)}.contact-section.visible .info-item:first-child{opacity:1;transform:translateX(0);transition-delay:.7s}.contact-section.visible .info-item:nth-child(2){opacity:1;transform:translateX(0);transition-delay:.8s}.contact-section.visible .info-item:nth-child(3){opacity:1;transform:translateX(0);transition-delay:.9s}.info-icon{color:var(--accent);font-size:1.2rem;min-width:24px}.info-item span{margin-left:1rem;opacity:.9}.social-links{display:flex;gap:1rem;margin-top:2rem;opacity:0;transform:translateY(20px);transition:all .6s cubic-bezier(.4,0,.2,1);transition-delay:1s}.contact-section.visible .social-links{opacity:1;transform:translateY(0)}.social-link{align-items:center;background-color:var(--bg-secondary);border-radius:50%;color:var(--text-primary);display:flex;height:40px;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);width:40px}.social-link:hover{background-color:var(--accent);color:var(--bg-primary);transform:translateY(-3px)}.contact-right{opacity:0;transform:translateX(30px);transition:all .6s cubic-bezier(.4,0,.2,1);transition-delay:.4s}.contact-section.visible .contact-right{opacity:1;transform:translateX(0)}.contact-right form{display:flex;flex-direction:column;gap:1.5rem}.form-row{grid-gap:3.5rem;display:grid;gap:3.5rem;grid-template-columns:1fr 1fr;margin-bottom:1.5rem;opacity:0;transform:translateY(20px);transition:all .6s cubic-bezier(.4,0,.2,1);transition-delay:.6s}.contact-section.visible .form-row{opacity:1;transform:translateY(0)}.form-row input,textarea{background-color:var(--bg-secondary);border:1px solid #ffffff1a;border-radius:8px;color:var(--text-primary);font-size:1rem;margin-bottom:.5rem;padding:1.2rem;transition:all .3s ease;width:100%}.form-row input:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px rgba(var(--accent-rgb),.1);outline:none}textarea{height:150px;margin-bottom:1.5rem;opacity:0;resize:none;transform:translateY(20px);transition:all .6s cubic-bezier(.4,0,.2,1);transition-delay:.8s}.contact-section.visible textarea{opacity:1;transform:translateY(0)}.send-message-btn{background-color:var(--accent);border:none;border-radius:8px;color:var(--bg-primary);cursor:pointer;font-size:1rem;opacity:0;padding:1rem 2rem;transform:translateY(20px);transition:all .3s cubic-bezier(.4,0,.2,1);transition-delay:1s;width:fit-content}.contact-section.visible .send-message-btn{opacity:1;transform:translateY(0)}.send-message-btn:hover{background-color:var(--accent);box-shadow:0 5px 15px rgba(var(--accent-rgb),.2);transform:translateX(5px)}.verified-animation{animation:none;background:none;border-radius:0;box-shadow:none;flex-direction:column;height:auto;left:50%;position:fixed;top:50%;transform:translate(-50%,-50%);width:auto;z-index:10000}.verified-animation,.verified-animation .icon{align-items:center;display:flex;justify-content:center}.verified-animation .icon{animation:iconPopIn .5s cubic-bezier(.4,0,.2,1);background:#1e293bf2;border-radius:50%;box-shadow:0 8px 32px #0000002e;font-size:4rem;height:120px;width:120px}.verified-animation.success .icon{animation:tickDraw .7s cubic-bezier(.4,0,.2,1),iconPopIn .5s cubic-bezier(.4,0,.2,1);color:#4ade80}.verified-animation.error .icon{animation:xDraw .7s cubic-bezier(.4,0,.2,1),iconPopIn .5s cubic-bezier(.4,0,.2,1);color:#ef4444}.verified-animation .notif-text{background:none;color:#fff;display:block;font-size:1.08rem;line-height:1.4;margin-top:1.3rem;max-width:260px;text-align:center;white-space:pre-line;word-break:break-word}@keyframes verifiedPopIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.7)}80%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes iconPopIn{0%{opacity:0;transform:scale(.7)}80%{opacity:1;transform:scale(1.1)}to{opacity:1;transform:scale(1)}}@keyframes tickDraw{0%{opacity:0;transform:scale(.7) rotate(-20deg)}60%{opacity:1;transform:scale(1.1) rotate(10deg)}to{opacity:1;transform:scale(1) rotate(0deg)}}@keyframes xDraw{0%{opacity:0;transform:scale(.7) rotate(20deg)}60%{opacity:1;transform:scale(1.1) rotate(-10deg)}to{opacity:1;transform:scale(1) rotate(0deg)}}.notification{display:none!important}@media (max-width:768px){.contact-content{gap:3rem;grid-template-columns:1fr}.contact-left h2{font-size:2.5rem}.contact-left p{font-size:1.5rem}.form-row{grid-template-columns:1fr}}@media (max-width:600px){.contact-section{padding:2.5rem .5rem}.contact-content{gap:2rem;grid-template-columns:1fr;padding:0}.contact-left{align-items:flex-start;padding:0 .5rem;text-align:left}.contact-left h2,.contact-left p{font-size:2rem;line-height:1.2}.contact-info,.info-item{margin:1rem 0}.info-item{font-size:.95rem}.contact-right{padding:0 .5rem}.form-row{flex-direction:column;gap:.7rem}.form-row input{width:100%}.form-row input,textarea{font-size:1rem;padding:.7rem 1rem}textarea{min-height:110px}.send-message-btn{font-size:1rem;margin-top:.7rem;padding:.7rem 1.2rem;width:100%}.notification{animation:slideInNotifMobile .6s cubic-bezier(.4,0,.2,1);border-radius:7px;bottom:auto;font-size:1rem;left:auto;max-width:90vw;min-width:220px;padding:.9rem 1.2rem .9rem 1rem;right:1.2rem;top:1.2rem}}@media (max-width:400px){.contact-section{padding:.5rem}.contact-content{padding:0}.contact-left h2,.contact-left p{font-size:1rem}.contact-left .tag,.contact-left h2,.contact-left p{margin-left:auto;margin-right:auto;text-align:center;width:100%}.contact-left .tag{display:block}.contact-info{margin-left:auto;margin-right:auto;text-align:center;width:100%}.info-item,.social-links{justify-content:center}.social-links{display:flex;gap:1.2rem;margin-left:auto;margin-right:auto;width:100%}.form-row{flex-direction:column;gap:.3rem}.form-row input{width:100%}.form-row input,textarea{font-size:.9rem;padding:.7rem 1rem}textarea{min-height:70px}.send-message-btn{border-radius:5px;font-size:.9rem;margin-top:.3rem;max-width:100%;padding:.7rem 1rem;width:100%}}@media (max-width:332px){.contact-section{padding:.3rem .1rem}.contact-content{padding:0}.contact-left h2,.contact-left p{font-size:.85rem}.contact-left .tag,.contact-left h2,.contact-left p{margin-left:auto;margin-right:auto;text-align:center;width:100%}.contact-left .tag{display:block}.contact-info{margin-left:auto;margin-right:auto;text-align:center;width:100%}.info-item{font-size:.85rem;justify-content:center}.social-links{display:flex;gap:.8rem;justify-content:center;margin-left:auto;margin-right:auto;width:100%}.form-row{flex-direction:column;gap:.2rem}.form-row input,textarea{border-radius:4px;box-sizing:border-box;font-size:.85rem;margin:0;max-width:100%;min-width:0;padding:.5rem .7rem;width:100%}textarea{min-height:55px}.send-message-btn{border-radius:4px;font-size:.85rem;margin-top:.2rem;max-width:100%;padding:.5rem .7rem;width:100%}}@media (max-width:600px){.form-row input,textarea{font-size:16px!important}}@media (max-width:400px){.form-row input,textarea{font-size:16px!important}}@media (max-width:332px){.form-row input,textarea{font-size:16px!important}}.contact-content,.contact-left,.contact-right,.contact-section,.form-row input,.send-message-btn,.social-link,textarea{transition:all .3s ease,transform .6s cubic-bezier(.4,0,.2,1),opacity .6s cubic-bezier(.4,0,.2,1)}
/*# sourceMappingURL=main.3e1b8b91.css.map*/