*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6;margin:0;padding:0}a{color:inherit;text-decoration:none}img{height:auto;max-width:100%}.App{background-color:var(--bg-primary);display:flex;flex-direction:column;min-height:100vh;width:100%}.App>div:not(.navbar):not(.footer),.App>main{flex:1 1}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-card);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--border-color)}::selection{background:var(--accent-primary);color:var(--text-primary)}::-moz-selection{background:var(--accent-primary);color:var(--text-primary)}@media (min-width:1400px){body{font-size:17px}::-webkit-scrollbar{width:12px}}@media (min-width:1600px){body{font-size:18px}}@media (min-width:1920px){body{font-size:19px;line-height:1.65}::-webkit-scrollbar{width:14px}::-webkit-scrollbar-thumb{border-radius:7px}}@media (min-width:2560px){body{font-size:20px;line-height:1.7}::-webkit-scrollbar{width:16px}::-webkit-scrollbar-thumb{border-radius:8px}}:root{--bg-card-hover:#222d45;--shadow-lg:0 20px 40px -10px #3b82f633}.home{background:var(--bg-primary);color:var(--text-primary);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh;overflow-x:hidden;width:100%}.hero{align-items:center;background:radial-gradient(ellipse at 20% 20%,#3b82f626 0,#0000 50%),radial-gradient(ellipse at 80% 80%,#60a5fa1a 0,#0000 50%),var(--bg-primary);display:flex;justify-content:center;min-height:calc(100vh - 70px);padding:calc(70px + clamp(2rem, 5vw, 4rem)) clamp(2rem,5vw,4rem) clamp(2rem,5vw,4rem)}.hero-content{grid-gap:clamp(2rem,5vw,4rem);align-items:center;display:grid;gap:clamp(2rem,5vw,4rem);grid-template-columns:1fr 1fr;max-width:1200px;width:100%}.hero-text{display:flex;flex-direction:column;gap:clamp(.5rem,2vw,1rem)}.greeting{color:var(--text-secondary);font-size:clamp(1rem,2.5vw,1.25rem);font-weight:400}.name{-webkit-text-fill-color:#0000;background:var(--accent-gradient);-webkit-background-clip:text;background-clip:text;font-size:clamp(2rem,6vw,4rem);font-weight:700;line-height:1.1;margin:0}.role{align-items:center;color:var(--text-secondary);display:flex;flex-wrap:wrap;font-size:clamp(1.25rem,3vw,1.75rem);gap:.5rem;min-height:2.5rem}.typewriter{color:var(--accent-secondary);font-weight:600}.tagline{color:var(--text-muted);font-size:clamp(1rem,2vw,1.125rem);line-height:1.6;margin:clamp(.5rem,2vw,1rem) 0;max-width:500px}.cta-section{display:flex;flex-wrap:wrap;gap:1rem;margin-top:clamp(1rem,3vw,1.5rem)}.github-btn,.resume-btn{align-items:center;border-radius:50px;box-shadow:var(--shadow-md);display:inline-flex;font-size:clamp(.9rem,2vw,1rem);font-weight:600;gap:.75rem;padding:clamp(.75rem,2vw,1rem) clamp(1.5rem,3vw,2rem);text-decoration:none;transition:var(--transition)}.github-btn{background:var(--accent-gradient);color:var(--bg-primary)}.github-btn:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}.resume-btn{background:#0000;border:2px solid var(--accent-primary);color:var(--accent-secondary)}.resume-btn:hover{background:var(--accent-gradient);border-color:#0000;box-shadow:var(--shadow-lg);color:var(--bg-primary);transform:translateY(-3px)}.github-btn svg,.resume-btn svg{font-size:1.25rem}.hero-image{align-items:center;display:flex;justify-content:center}.image-wrapper{height:clamp(250px,38vw,450px);position:relative;width:clamp(200px,30vw,350px)}.image-wrapper:before{background:var(--accent-gradient);border-radius:20px;content:"";filter:blur(20px);inset:-10px;opacity:.6;position:absolute;z-index:0}.image-wrapper img{border:3px solid var(--border-color);border-radius:16px;height:100%;object-fit:cover;position:relative;width:100%;z-index:1}.section-header{margin-bottom:clamp(2rem,5vw,3rem);text-align:center}.section-header h2{-webkit-text-fill-color:#0000;background:var(--accent-gradient);-webkit-background-clip:text;background-clip:text;font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;margin-bottom:1rem}.section-header p{color:var(--text-secondary);font-size:clamp(.95rem,2vw,1.1rem);line-height:1.7;margin:0 auto;max-width:700px}.section-header .highlight{color:var(--accent-secondary);font-weight:600}.skills{background:var(--bg-secondary);padding:clamp(3rem,8vw,6rem) clamp(1rem,5vw,4rem)}.skills-grid{grid-gap:clamp(1rem,3vw,1.5rem);display:grid;gap:clamp(1rem,3vw,1.5rem);grid-template-columns:repeat(auto-fit,minmax(min(100%,320px),1fr));margin:0 auto;max-width:1200px}.skill-category{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:clamp(1.25rem,3vw,1.75rem);transition:var(--transition)}.skill-category:hover{background:var(--bg-card-hover);border-color:var(--accent-primary);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.category-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;gap:.75rem;margin-bottom:clamp(1rem,2.5vw,1.25rem);padding-bottom:clamp(.75rem,2vw,1rem)}.category-header h3{color:var(--text-primary);font-size:clamp(1rem,2.5vw,1.15rem);font-weight:600;margin:0}.category-icon{color:var(--accent-secondary);font-size:clamp(1.1rem,2.5vw,1.35rem)}.skill-tags{display:flex;flex-wrap:wrap;gap:.5rem}.skill-tag{align-items:center;background:#3b82f626;border:1px solid #3b82f64d;border-radius:20px;color:var(--accent-secondary);display:inline-flex;font-size:clamp(.75rem,1.8vw,.85rem);gap:.4rem;padding:.4rem .75rem;transition:var(--transition)}.skill-tag:hover{background:#3b82f640;border-color:var(--accent-primary);transform:scale(1.05)}.skill-icon{font-size:clamp(.7rem,1.5vw,.8rem)}.certifications{background:var(--bg-primary);padding:clamp(3rem,8vw,6rem) clamp(1rem,5vw,4rem)}.cert-grid{grid-gap:clamp(1.5rem,4vw,2rem);display:grid;gap:clamp(1.5rem,4vw,2rem);grid-template-columns:repeat(auto-fit,minmax(min(100%,400px),1fr));margin:0 auto;max-width:1000px}.cert-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;cursor:pointer;overflow:hidden;position:relative;transition:var(--transition)}.cert-card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.cert-card:focus{outline:2px solid var(--accent-primary);outline-offset:2px}.cert-card img{aspect-ratio:4/3;background:#fff;display:block;height:auto;object-fit:contain;padding:1rem;transition:var(--transition);width:100%}.cert-overlay{align-items:center;background:#0a0f1ad9;display:flex;inset:0;justify-content:center;opacity:0;position:absolute;transition:var(--transition)}.cert-card:hover .cert-overlay{opacity:1}.cert-overlay span{background:#3b82f633;border:2px solid var(--accent-primary);border-radius:50px;color:var(--text-primary);font-size:1.125rem;font-weight:600;padding:.75rem 1.5rem}.cert-hint{color:var(--text-muted)!important;font-size:clamp(.8rem,1.8vw,.9rem)!important;margin-top:.5rem!important}.modal-overlay{align-items:center;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0a0f1af2;display:flex;inset:0;justify-content:center;padding:clamp(1rem,3vw,2rem);position:fixed;z-index:2000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{align-items:center;animation:scaleIn .3s ease;background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;display:flex;flex-direction:column;max-height:90vh;max-width:900px;overflow:hidden;padding:clamp(1.5rem,4vw,2.5rem);position:relative;width:100%}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.modal-close{align-items:center;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:50%;color:var(--text-primary);cursor:pointer;display:flex;font-size:1.75rem;height:44px;justify-content:center;line-height:1;position:absolute;right:1rem;top:1rem;transition:var(--transition);width:44px;z-index:10}.modal-close:hover{background:var(--accent-primary);border-color:var(--accent-primary);color:var(--bg-primary);transform:rotate(90deg)}.modal-title{color:var(--text-primary);font-size:clamp(1.125rem,3vw,1.5rem);font-weight:600;margin-bottom:clamp(1rem,3vw,1.5rem);padding-right:3rem;text-align:center}.modal-image{background:#fff;border-radius:12px;max-height:calc(90vh - 200px);object-fit:contain;width:100%}.modal-link{align-items:center;background:#0000;border:2px solid var(--accent-primary);border-radius:50px;color:var(--accent-secondary);display:inline-flex;font-size:clamp(.875rem,2vw,1rem);font-weight:600;gap:.75rem;margin-top:clamp(1rem,3vw,1.5rem);padding:.75rem 1.5rem;text-decoration:none;transition:var(--transition)}.modal-link:hover{background:var(--accent-gradient);border-color:#0000;box-shadow:var(--shadow-md);color:var(--bg-primary);transform:translateY(-2px)}.modal-link svg{font-size:.9rem}@media (max-width:900px){.hero-content{gap:2rem;grid-template-columns:1fr;text-align:center}.hero-text{align-items:center;order:2}.hero-image{order:1}.role{justify-content:center}.tagline{margin-left:auto;margin-right:auto}.cta-section{justify-content:center}.image-wrapper{height:clamp(220px,50vw,350px);width:clamp(180px,40vw,280px)}}@media (max-width:600px){.hero{min-height:auto;padding-bottom:3rem;padding-top:calc(60px + 2rem)}.cert-grid,.skills-grid{grid-template-columns:1fr}.cert-card img{padding:.5rem}.modal-content{border-radius:16px;padding:1rem}.modal-close{font-size:1.5rem;height:36px;right:.75rem;top:.75rem;width:36px}.modal-title{font-size:1rem;margin-bottom:1rem;padding-right:2.5rem}.modal-image{border-radius:8px}.modal-link{font-size:.875rem;padding:.6rem 1.25rem}}@media (max-width:400px){.cta-section{flex-direction:column;width:100%}.github-btn,.resume-btn{justify-content:center;width:100%}.skill-tag{font-size:.75rem;padding:.35rem .6rem}.image-wrapper{height:220px;width:180px}}@media (min-width:1400px){.hero-content{gap:6rem;max-width:1400px}.name{font-size:4.5rem}.role{font-size:2rem}.greeting{font-size:1.35rem}.tagline{font-size:1.25rem;max-width:550px}.image-wrapper{height:480px;width:380px}.skills-grid{gap:2rem;grid-template-columns:repeat(3,1fr);max-width:1400px}.cert-grid{gap:2.5rem;max-width:1100px}.section-header h2{font-size:3rem}.section-header p{font-size:1.2rem;max-width:800px}}@media (min-width:1600px){.hero{padding:calc(70px + 6rem) 8rem 6rem}.hero-content{gap:8rem;max-width:1500px}.name{font-size:5rem}.image-wrapper{height:520px;width:420px}.skills{padding:8rem 6rem}.skills-grid{gap:2.5rem;max-width:1500px}.skill-category{padding:2rem}.certifications{padding:8rem 6rem}.cert-grid{max-width:1200px}.modal-content{max-width:1000px}}@media (min-width:1920px){.hero{padding:calc(70px + 8rem) 10rem 8rem}.hero-content{max-width:1600px}.name{font-size:5.5rem}.role{font-size:2.25rem}.greeting{font-size:1.5rem}.tagline{font-size:1.35rem;max-width:600px}.image-wrapper{height:560px;width:450px}.github-btn,.resume-btn{font-size:1.125rem;padding:1.25rem 2.5rem}.skills{padding:10rem 8rem}.skills-grid{max-width:1700px}.skill-category{border-radius:20px;padding:2.5rem}.category-header h3{font-size:1.35rem}.skill-tag{font-size:.95rem;padding:.5rem 1rem}.certifications{padding:10rem 8rem}.cert-grid{max-width:1300px}.cert-card{border-radius:20px}.section-header{margin-bottom:4rem}.section-header h2{font-size:3.5rem}.section-header p{font-size:1.35rem}}@media (min-width:2560px){.hero-content{max-width:1800px}.name{font-size:6rem}.image-wrapper{height:620px;width:500px}.skills-grid{max-width:1900px}.cert-grid{max-width:1500px}}.projects{align-items:center;background:var(--bg-primary);display:flex;flex-direction:column;min-height:calc(100vh - 70px);padding-bottom:clamp(3rem,8vw,6rem);padding-top:100px;width:100%}.projects h1{-webkit-text-fill-color:#0000;background:var(--accent-gradient);-webkit-background-clip:text;background-clip:text;font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;margin-bottom:clamp(2rem,5vw,3rem);text-align:center}.projectList{grid-gap:clamp(1.5rem,4vw,2rem);display:grid;gap:clamp(1.5rem,4vw,2rem);grid-template-columns:repeat(auto-fit,minmax(min(100%,320px),1fr));max-width:1200px;padding:0 clamp(1rem,5vw,4rem);place-items:center;width:100%}.projectItem{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;cursor:pointer;max-width:350px;overflow:hidden;transition:var(--transition);width:100%}.projectItem:hover{background:var(--bg-card-hover);border-color:var(--accent-primary);box-shadow:var(--shadow-lg);transform:translateY(-6px)}.projectItem .bgImage{background-position:50%;background-repeat:no-repeat;background-size:cover;border-bottom:1px solid var(--border-color);height:200px;transition:var(--transition);width:100%}.projectItem:hover .bgImage{border-color:var(--accent-primary)}.projectItem h1{-webkit-text-fill-color:unset;background:none;-webkit-background-clip:unset;background-clip:initial;color:var(--text-primary);font-size:clamp(1rem,2.5vw,1.125rem);font-weight:600;margin:0;padding:1rem 1.25rem;text-align:center}@media only screen and (max-width:1300px){.projectList{grid-template-columns:repeat(2,1fr)}}@media only screen and (max-width:768px){.projects{padding-top:90px}.projectList{grid-template-columns:1fr}.projectItem{max-width:400px}}@media only screen and (max-width:600px){.projects{padding-top:80px}}@media only screen and (max-width:450px){.projects{padding-top:75px}.projectItem{max-width:100%}.projectItem .bgImage{height:180px}}@media only screen and (min-width:1400px){.projects{padding-bottom:8rem;padding-top:120px}.projects h1{font-size:3rem;margin-bottom:4rem}.projectList{gap:2.5rem;grid-template-columns:repeat(3,1fr);max-width:1400px}.projectItem{max-width:400px}.projectItem .bgImage{height:240px}.projectItem h1{font-size:1.25rem;padding:1.25rem 1.5rem}}@media only screen and (min-width:1600px){.projects{padding-bottom:10rem;padding-top:140px}.projects h1{font-size:3.25rem}.projectList{gap:3rem;max-width:1500px}.projectItem{border-radius:20px;max-width:440px}.projectItem .bgImage{border-top-left-radius:20px;border-top-right-radius:20px;height:260px}.projectItem h1{font-size:1.35rem}}@media only screen and (min-width:1920px){.projects{padding-top:160px}.projects h1{font-size:3.5rem}.projectList{max-width:1700px}.projectItem{max-width:480px}.projectItem .bgImage{height:280px}.projectItem h1{font-size:1.5rem;padding:1.5rem 1.75rem}}@media only screen and (min-width:2560px){.projectList{max-width:1900px}.projectItem{max-width:520px}.projectItem .bgImage{height:300px}}.vertical-timeline *{-webkit-box-sizing:border-box;box-sizing:border-box}.vertical-timeline{margin:0 auto;max-width:1170px;padding:2em 0;position:relative;width:95%}.vertical-timeline:after{clear:both;content:"";display:table}.vertical-timeline:before{background:var(--line-color);content:"";height:100%;left:18px;position:absolute;top:0;width:4px}.vertical-timeline.vertical-timeline--one-column-right:before{left:auto;right:18px}@media only screen and (min-width:1170px){.vertical-timeline.vertical-timeline--two-columns{width:90%}.vertical-timeline.vertical-timeline--two-columns:before{left:50%;margin-left:-2px}}.vertical-timeline-element{margin:2em 0;position:relative}.vertical-timeline-element>div{min-height:1px}.vertical-timeline-element:after{clear:both;content:"";display:table}.vertical-timeline-element:first-child{margin-top:0}.vertical-timeline-element:last-child{margin-bottom:0}@media only screen and (min-width:1170px){.vertical-timeline-element{margin:4em 0}.vertical-timeline-element:first-child{margin-top:0}.vertical-timeline-element:last-child{margin-bottom:0}}.vertical-timeline-element-icon{border-radius:50%;-webkit-box-shadow:0 0 0 4px #fff,inset 0 2px 0 #00000014,0 3px 0 4px #0000000d;box-shadow:0 0 0 4px #fff,inset 0 2px 0 #00000014,0 3px 0 4px #0000000d;height:40px;left:0;position:absolute;top:0;width:40px}.vertical-timeline--one-column-right .vertical-timeline-element-icon{left:auto;right:0}.vertical-timeline-element-icon svg{display:block;height:24px;left:50%;margin-left:-12px;margin-top:-12px;position:relative;top:50%;width:24px}@media only screen and (min-width:1170px){.vertical-timeline--two-columns .vertical-timeline-element-icon{height:60px;left:50%;margin-left:-30px;width:60px}}.vertical-timeline-element-icon{-webkit-backface-visibility:hidden;-webkit-transform:translateZ(0)}.vertical-timeline--animate .vertical-timeline-element-icon.is-hidden{visibility:hidden}.vertical-timeline--animate .vertical-timeline-element-icon.bounce-in{-webkit-animation:cd-bounce-1 .6s;animation:cd-bounce-1 .6s;visibility:visible}@-webkit-keyframes cd-bounce-1{0%{opacity:0;-webkit-transform:scale(.5)}60%{opacity:1;-webkit-transform:scale(1.2)}to{-webkit-transform:scale(1)}}@keyframes cd-bounce-1{0%{opacity:0;-webkit-transform:scale(.5);transform:scale(.5)}60%{opacity:1;-webkit-transform:scale(1.2);transform:scale(1.2)}to{-webkit-transform:scale(1);transform:scale(1)}}.vertical-timeline-element-content{background:#fff;border-radius:.25em;-webkit-box-shadow:0 3px 0 #ddd;box-shadow:0 3px 0 #ddd;margin-left:60px;padding:1em;position:relative}.vertical-timeline--one-column-right .vertical-timeline-element-content{margin-left:0;margin-right:60px}.vertical-timeline-element--no-children .vertical-timeline-element-content{background:0 0;-webkit-box-shadow:none;box-shadow:none}.vertical-timeline-element-content:after{clear:both;content:"";display:table}.vertical-timeline-element-content h2{color:#303e49}.vertical-timeline-element-content .vertical-timeline-element-date,.vertical-timeline-element-content p{font-size:13px;font-size:.8125rem;font-weight:500}.vertical-timeline-element-content .vertical-timeline-element-date{display:inline-block}.vertical-timeline-element-content p{line-height:1.6;margin:1em 0 0}.vertical-timeline-element-subtitle,.vertical-timeline-element-title{margin:0}.vertical-timeline-element-content .vertical-timeline-element-date{float:left;opacity:.7;padding:.8em 0}.vertical-timeline-element-content-arrow{border:7px solid #0000;border-right-color:#fff;content:"";height:0;position:absolute;right:100%;top:16px;width:0}.vertical-timeline--one-column-right .vertical-timeline-element-content-arrow{border:7px solid #0000;border-left-color:#fff;content:"";height:0;left:100%;position:absolute;right:auto;top:16px;width:0}.vertical-timeline--one-column-right .vertical-timeline-element-content:before{border-left:7px solid #fff;border-right:initial;left:100%}.vertical-timeline-element--no-children .vertical-timeline-element-content-arrow,.vertical-timeline-element--no-children .vertical-timeline-element-content:before{display:none}@media only screen and (min-width:768px){.vertical-timeline-element-content h2{font-size:20px;font-size:1.25rem}.vertical-timeline-element-content p{font-size:16px;font-size:1rem}.vertical-timeline-element-content .vertical-timeline-element-date{font-size:14px;font-size:.875rem}}@media only screen and (min-width:1170px){.vertical-timeline--two-columns .vertical-timeline-element-content{margin-left:0;padding:1.5em;width:44%}.vertical-timeline--two-columns .vertical-timeline-element-content-arrow{left:100%;top:24px;-webkit-transform:rotate(180deg);transform:rotate(180deg)}.vertical-timeline--two-columns .vertical-timeline-element-content .vertical-timeline-element-date{font-size:16px;font-size:1rem;left:124%;position:absolute;top:6px;width:100%}.vertical-timeline--two-columns .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content,.vertical-timeline--two-columns .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content{float:right}.vertical-timeline--two-columns .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content-arrow,.vertical-timeline--two-columns .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content-arrow{left:auto;right:100%;top:24px;-webkit-transform:rotate(0);transform:rotate(0)}.vertical-timeline--one-column-right .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content-arrow,.vertical-timeline--one-column-right .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content-arrow{left:100%;right:auto;top:24px;-webkit-transform:rotate(0);transform:rotate(0)}.vertical-timeline--two-columns .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content .vertical-timeline-element-date,.vertical-timeline--two-columns .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content .vertical-timeline-element-date{left:auto;right:124%;text-align:right}}.vertical-timeline--animate .vertical-timeline-element-content.is-hidden{visibility:hidden}.vertical-timeline--animate .vertical-timeline-element-content.bounce-in{-webkit-animation:cd-bounce-2 .6s;animation:cd-bounce-2 .6s;visibility:visible}@media only screen and (min-width:1170px){.vertical-timeline--two-columns.vertical-timeline--animate .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content.bounce-in,.vertical-timeline--two-columns.vertical-timeline--animate .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content.bounce-in{-webkit-animation:cd-bounce-2-inverse .6s;animation:cd-bounce-2-inverse .6s}}@media only screen and (max-width:1169px){.vertical-timeline--animate .vertical-timeline-element-content.bounce-in{-webkit-animation:cd-bounce-2-inverse .6s;animation:cd-bounce-2-inverse .6s;visibility:visible}}@-webkit-keyframes cd-bounce-2{0%{opacity:0;-webkit-transform:translateX(-100px)}60%{opacity:1;-webkit-transform:translateX(20px)}to{-webkit-transform:translateX(0)}}@keyframes cd-bounce-2{0%{opacity:0;-webkit-transform:translateX(-100px);transform:translateX(-100px)}60%{opacity:1;-webkit-transform:translateX(20px);transform:translateX(20px)}to{-webkit-transform:translateX(0);transform:translateX(0)}}@-webkit-keyframes cd-bounce-2-inverse{0%{opacity:0;-webkit-transform:translateX(100px)}60%{opacity:1;-webkit-transform:translateX(-20px)}to{-webkit-transform:translateX(0)}}@keyframes cd-bounce-2-inverse{0%{opacity:0;-webkit-transform:translateX(100px);transform:translateX(100px)}60%{opacity:1;-webkit-transform:translateX(-20px);transform:translateX(-20px)}to{-webkit-transform:translateX(0);transform:translateX(0)}}.experience{background:var(--bg-primary);min-height:100vh;padding-bottom:clamp(3rem,8vw,6rem);padding-top:100px}.vertical-timeline{padding:0 clamp(1rem,3vw,2rem)}.vertical-timeline:before{background:var(--border-color)!important}.vertical-timeline-element-content{background:var(--bg-card)!important;border:1px solid var(--border-color)!important;border-radius:12px!important;box-shadow:var(--shadow-md)!important;padding:clamp(1.25rem,3vw,1.75rem)!important;transition:var(--transition)!important}.vertical-timeline-element-content:hover{background:var(--bg-card-hover)!important;border-color:var(--accent-primary)!important;transform:translateY(-2px)}.vertical-timeline-element-content-arrow{border-right-color:var(--bg-card)!important}.vertical-timeline-element-date{color:var(--text-secondary)!important;font-size:clamp(.875rem,2vw,1rem)!important;font-weight:500!important}.vertical-timeline-element-title{color:var(--text-primary)!important;font-size:clamp(1rem,2.5vw,1.25rem)!important;font-weight:600!important;margin-bottom:.5rem!important}.vertical-timeline-element-content p{color:var(--text-secondary)!important;font-size:clamp(.875rem,2vw,1rem)!important;line-height:1.7!important;margin:0!important}.vertical-timeline-element-icon{box-shadow:0 0 0 4px var(--bg-card),0 0 0 8px var(--border-color)!important}@media only screen and (min-width:1170px){.vertical-timeline-element-date{padding:0!important}}@media only screen and (max-width:768px){.experience{padding-top:90px}.vertical-timeline-element-content{padding:1rem!important}}@media only screen and (max-width:600px){.experience{padding-top:80px}}@media only screen and (max-width:450px){.experience{padding-top:75px}}@media only screen and (min-width:1400px){.experience{padding-bottom:8rem;padding-top:120px}.vertical-timeline{margin:0 auto;max-width:1200px}.vertical-timeline-element-content{padding:2rem!important}.vertical-timeline-element-title{font-size:1.35rem!important}.vertical-timeline-element-content p{font-size:1.05rem!important}}@media only screen and (min-width:1600px){.experience{padding-bottom:10rem;padding-top:140px}.vertical-timeline{max-width:1300px}.vertical-timeline-element-content{border-radius:16px!important;padding:2.25rem!important}.vertical-timeline-element-title{font-size:1.5rem!important}.vertical-timeline-element-content p{font-size:1.1rem!important;line-height:1.8!important}.vertical-timeline-element-date{font-size:1.1rem!important}}@media only screen and (min-width:1920px){.experience{padding-top:160px}.vertical-timeline{max-width:1400px}.vertical-timeline-element-content{border-radius:20px!important;padding:2.5rem!important}.vertical-timeline-element-title{font-size:1.6rem!important}.vertical-timeline-element-content p{font-size:1.15rem!important}}@media only screen and (min-width:2560px){.vertical-timeline{max-width:1600px}}:root{--navbar-height:70px;--navbar-height-scrolled:60px;--transition:all 0.3s cubic-bezier(0.4,0,0.2,1)}.navbar{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#0a0f1ad9;border-bottom:1px solid #0000;height:var(--navbar-height);left:0;position:fixed;right:0;top:0;transition:var(--transition);z-index:1000}.navbar.scrolled{background:#0a0f1afa;border-bottom-color:var(--border-color);box-shadow:var(--shadow-md);height:var(--navbar-height-scrolled)}.navbar-container{align-items:center;display:flex;height:100%;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 clamp(1rem,4vw,3rem)}.logo{z-index:1001}.logo a{-webkit-text-fill-color:#0000;background:var(--accent-gradient);-webkit-background-clip:text;background-clip:text;font-size:clamp(1.5rem,4vw,1.75rem);font-weight:800;letter-spacing:-.5px;text-decoration:none;transition:var(--transition)}.logo a:hover{opacity:.85;transform:scale(1.02)}.nav-links{align-items:center;display:flex;gap:clamp(.25rem,2vw,1.5rem)}.nav-links a{border-radius:8px;color:var(--text-secondary);font-size:clamp(.875rem,1.5vw,1rem);font-weight:500;padding:.5rem clamp(.5rem,1.5vw,1rem);position:relative;text-decoration:none;transition:var(--transition);white-space:nowrap}.nav-links a:after{background:var(--accent-gradient);border-radius:2px;bottom:0;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%);transition:var(--transition);width:0}.nav-links a:hover{color:var(--text-primary)}.nav-links a:hover:after{width:70%}.nav-links a.active{color:var(--accent-secondary)}.nav-links a.active:after{width:70%}.toggle-button{align-items:center;background:#0000;border:1px solid #0000;border-radius:10px;color:var(--text-primary);cursor:pointer;display:none;height:44px;justify-content:center;transition:var(--transition);width:44px;z-index:1001}.toggle-button:hover{background:var(--bg-card);border-color:var(--border-color)}.toggle-button:active{transform:scale(.95)}.toggle-button svg{font-size:1.5rem;transition:var(--transition)}.nav-overlay{display:none}@media (min-width:1200px){.nav-links{gap:2rem}.nav-links a{font-size:1rem;padding:.5rem 1rem}}@media (max-width:900px){.nav-links{gap:.5rem}.nav-links a{font-size:.9rem;padding:.5rem .75rem}}@media (max-width:768px){:root{--navbar-height:65px;--navbar-height-scrolled:60px}.toggle-button{display:flex}.nav-links{align-items:stretch;background:var(--bg-primary);border-left:1px solid var(--border-color);box-shadow:-10px 0 30px #00000080;flex-direction:column;gap:0;height:100vh;height:100dvh;justify-content:flex-start;overflow-y:auto;padding:calc(var(--navbar-height) + 2rem) 0 2rem;position:fixed;right:-100%;top:0;transition:right .4s cubic-bezier(.4,0,.2,1);width:min(300px,80vw)}.nav-links.active{right:0}.nav-links a{border-bottom:1px solid var(--border-color);border-radius:0;font-size:1.125rem;padding:1.25rem 2rem;text-align:left;width:100%}.nav-links a:first-child{border-top:1px solid var(--border-color)}.nav-links a:after{display:none}.nav-links a.active,.nav-links a:hover{background:var(--bg-card);color:var(--accent-secondary)}.nav-overlay{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#0a0f1acc;display:block;inset:0;opacity:0;position:fixed;transition:var(--transition);visibility:hidden;z-index:999}.nav-overlay.active{opacity:1;visibility:visible}.navbar.open .toggle-button{color:var(--accent-secondary)}}@media (max-width:600px){:root{--navbar-height:60px;--navbar-height-scrolled:55px}.navbar-container{padding:0 1rem}.logo a{font-size:1.5rem}.toggle-button{height:40px;width:40px}.toggle-button svg{font-size:1.35rem}.nav-links{padding-top:calc(var(--navbar-height) + 1.5rem);width:min(280px,85vw)}.nav-links a{font-size:1.05rem;padding:1.1rem 1.5rem}}@media (max-width:400px){:root{--navbar-height:56px;--navbar-height-scrolled:52px}.navbar-container{padding:0 .75rem}.logo a{font-size:1.35rem}.toggle-button{border-radius:8px;height:38px;width:38px}.toggle-button svg{font-size:1.25rem}.nav-links{border-left:none;padding-top:calc(var(--navbar-height) + 1rem);width:100%}.nav-links a{font-size:1rem;padding:1rem 1.25rem}}@media (max-width:320px){.navbar-container{padding:0 .5rem}.logo a{font-size:1.25rem}.toggle-button{height:36px;width:36px}.nav-links a{font-size:.95rem;padding:.9rem 1rem}}@media (max-width:768px) and (max-height:500px){.nav-links{padding-bottom:1rem;padding-top:calc(var(--navbar-height) + .5rem)}.nav-links a{font-size:.95rem;padding:.75rem 1.5rem}}@media (min-width:1400px){:root{--navbar-height:80px;--navbar-height-scrolled:70px}.navbar-container{max-width:1400px;padding:0 4rem}.logo a{font-size:2rem}.nav-links{gap:2.5rem}.nav-links a{font-size:1.05rem;padding:.6rem 1.25rem}}@media (min-width:1600px){:root{--navbar-height:85px;--navbar-height-scrolled:75px}.navbar-container{max-width:1500px;padding:0 5rem}.logo a{font-size:2.15rem}.nav-links{gap:3rem}.nav-links a{font-size:1.1rem;padding:.65rem 1.35rem}}@media (min-width:1920px){:root{--navbar-height:90px;--navbar-height-scrolled:80px}.navbar-container{max-width:1700px;padding:0 6rem}.logo a{font-size:2.25rem}.nav-links{gap:3.5rem}.nav-links a{font-size:1.15rem;padding:.7rem 1.5rem}}@media (min-width:2560px){:root{--navbar-height:100px;--navbar-height-scrolled:90px}.navbar-container{max-width:1900px;padding:0 8rem}.logo a{font-size:2.5rem}.nav-links{gap:4rem}.nav-links a{font-size:1.25rem;padding:.75rem 1.75rem}}@media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.navbar{border-bottom-width:.5px}}@media (prefers-reduced-motion:reduce){.nav-links,.nav-links a,.nav-overlay,.navbar,.toggle-button{transition:none}}@media print{.navbar{display:none}}:root{--bg-primary:#0a0f1a;--bg-secondary:#111827;--bg-card:#1a2235;--accent-primary:#3b82f6;--accent-secondary:#60a5fa;--accent-gradient:linear-gradient(135deg,#3b82f6,#60a5fa 50%,#93c5fd);--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--border-color:#2d3a52;--shadow-sm:0 4px 6px -1px #0000004d;--shadow-md:0 10px 25px -5px #0006;--transition:all 0.3s ease}.footer{background:var(--bg-secondary);border-top:1px solid var(--border-color);justify-content:center;margin-top:auto;padding:clamp(2rem,5vw,3rem) clamp(1rem,5vw,4rem)}.footer,.footer-content{align-items:center;display:flex;flex-direction:column;width:100%}.footer-content{gap:1.5rem;max-width:1200px}.footer-brand{-webkit-text-fill-color:#0000;background:var(--accent-gradient);-webkit-background-clip:text;background-clip:text;font-size:clamp(1.25rem,3vw,1.5rem);font-weight:700;text-decoration:none;transition:var(--transition)}.footer-brand:hover{opacity:.8}.socialMedia{gap:clamp(1rem,3vw,1.5rem)}.socialMedia,.socialMedia a{align-items:center;display:flex}.socialMedia a{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;color:var(--text-secondary);height:clamp(48px,8vw,56px);justify-content:center;text-decoration:none;transition:var(--transition);width:clamp(48px,8vw,56px)}.socialMedia a:hover{background:var(--bg-primary);border-color:var(--accent-primary);box-shadow:0 10px 25px -5px #3b82f640;color:var(--accent-secondary);transform:translateY(-4px)}.socialMedia svg{font-size:clamp(1.5rem,4vw,1.75rem)}.footer-divider{background:var(--border-color);height:1px;margin:.5rem 0;max-width:200px;width:100%}.footer p{color:var(--text-muted);font-size:clamp(.75rem,2vw,.875rem);line-height:1.6;margin:0;text-align:center}.footer p a{color:var(--accent-secondary);text-decoration:none;transition:var(--transition)}.footer p a:hover{color:var(--text-primary);text-decoration:underline}.footer-links{display:flex;flex-wrap:wrap;gap:clamp(1rem,3vw,2rem);justify-content:center}.footer-links a{color:var(--text-secondary);font-size:clamp(.875rem,2vw,.9375rem);font-weight:500;position:relative;text-decoration:none;transition:var(--transition)}.footer-links a:after{background:var(--accent-gradient);border-radius:2px;bottom:-4px;content:"";height:2px;left:0;position:absolute;transition:var(--transition);width:0}.footer-links a:hover{color:var(--text-primary)}.footer-links a:hover:after{width:100%}@media only screen and (max-width:600px){.footer{padding:2rem 1rem}.socialMedia{gap:.75rem}.socialMedia a{border-radius:10px;height:44px;width:44px}.footer-links{gap:1rem}}@media only screen and (max-width:400px){.footer-links{align-items:center;flex-direction:column;gap:.75rem}}@media only screen and (min-width:1400px){.footer{padding:4rem}.footer-content{gap:2rem;max-width:1400px}.footer-brand{font-size:1.75rem}.footer-links{gap:3rem}.footer-links a{font-size:1rem}.socialMedia a{border-radius:14px;height:60px;width:60px}.socialMedia svg{font-size:1.85rem}.footer p{font-size:.95rem}}@media only screen and (min-width:1600px){.footer{padding:5rem 6rem}.footer-content{gap:2.5rem;max-width:1500px}.footer-brand{font-size:2rem}.footer-links a{font-size:1.05rem}.socialMedia{gap:1.5rem}.socialMedia a{height:64px;width:64px}.socialMedia svg{font-size:2rem}.footer p{font-size:1rem}.footer-divider{max-width:250px}}@media only screen and (min-width:1920px){.footer{padding:6rem 8rem}.footer-content{max-width:1700px}.footer-brand{font-size:2.25rem}.footer-links{gap:4rem}.footer-links a{font-size:1.1rem}.socialMedia a{border-radius:16px;height:68px;width:68px}.socialMedia svg{font-size:2.15rem}.footer p{font-size:1.05rem}}@media only screen and (min-width:2560px){.footer-content{max-width:1900px}.socialMedia a{height:72px;width:72px}.socialMedia svg{font-size:2.25rem}}.project{align-items:center;background:var(--bg-primary);display:flex;flex-direction:column;min-height:calc(100vh - 70px);padding-bottom:clamp(3rem,8vw,6rem);padding-top:100px;width:100%}.project h1{-webkit-text-fill-color:#0000;background:var(--accent-gradient);-webkit-background-clip:text;background-clip:text;font-size:clamp(1.5rem,4vw,2.25rem);font-weight:700;margin:0 0 clamp(1.5rem,4vw,2rem);padding:0 clamp(1rem,5vw,2rem);text-align:center}.project img{border:1px solid var(--border-color);border-radius:16px;box-shadow:var(--shadow-md);height:auto;max-width:700px;transition:var(--transition);width:90%}.project img:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-lg)}.project p{color:var(--text-secondary);font-size:clamp(1rem,2.5vw,1.125rem);line-height:1.8;margin:clamp(1rem,3vw,1.5rem) 0;max-width:800px;padding:0 clamp(1rem,5vw,2rem);text-align:center}.project p b{color:var(--accent-secondary);font-weight:600}.project .skills-list{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;max-width:800px;padding:0 clamp(1rem,5vw,2rem)}.project .skill-badge{align-items:center;background:#3b82f626;border:1px solid #3b82f64d;border-radius:25px;color:var(--accent-secondary);display:inline-flex;font-size:clamp(.8rem,2vw,.9rem);gap:.4rem;padding:.5rem 1rem;transition:var(--transition)}.project .skill-badge:hover{background:#3b82f640;border-color:var(--accent-primary);transform:scale(1.05)}.icons{display:flex;flex-wrap:wrap;gap:clamp(1rem,3vw,1.5rem);justify-content:center;margin:clamp(1rem,3vw,1.5rem) 0}.icons svg{color:var(--text-secondary);font-size:clamp(2rem,5vw,3rem);transition:var(--transition)}.icons svg:hover{color:var(--accent-secondary);transform:translateY(-4px)}.project .about-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;margin-top:clamp(1.5rem,4vw,2rem);max-width:900px;padding:clamp(2rem,5vw,3rem) clamp(1rem,5vw,2rem);width:100%}.project .about-section h2{color:var(--text-primary);font-size:clamp(1.25rem,3vw,1.5rem);font-weight:600;margin-bottom:1rem;text-align:center}.project .about-section p{padding:0;text-align:left}@media only screen and (max-width:768px){.project{padding-top:90px}.project img{border-radius:12px;width:95%}}@media only screen and (max-width:600px){.project{padding-top:80px}}@media only screen and (max-width:450px){.project{padding-top:75px}.project img{border-left:none;border-radius:0;border-right:none;width:100%}.project .about-section{border-radius:12px;margin:clamp(1.5rem,4vw,2rem) 1rem 0;width:calc(100% - 2rem)}}
/*# sourceMappingURL=main.5e04ea0c.css.map*/