:root{--accent: #2337ff;--accent-dark: #000d8a;--black: 15, 18, 25;--gray: 96, 115, 159;--gray-light: 229, 233, 240;--gray-dark: 34, 41, 57;--gray-gradient: rgba(var(--gray-light), 50%), #fff;--box-shadow: 0 2px 6px rgba(var(--gray), 25%), 0 8px 24px rgba(var(--gray), 33%), 0 16px 32px rgba(var(--gray), 33%)}@font-face{font-family:Atkinson;src:url(/fonts/atkinson-regular.woff) format("woff");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Atkinson;src:url(/fonts/atkinson-bold.woff) format("woff");font-weight:700;font-style:normal;font-display:swap}html{scroll-behavior:smooth}body{font-family:Atkinson,sans-serif;margin:0;padding:0;text-align:left;background:linear-gradient(180deg,#1a1625,#0f0f1a 30%,#0a0a12 70%,#05050a);min-height:100vh;word-wrap:break-word;overflow-wrap:break-word;color:rgb(var(--gray-dark));font-size:20px;line-height:1.7}main{width:720px;max-width:calc(100% - 2em);margin:auto;padding:3em 1em}h1,h2,h3,h4,h5,h6{margin:0 0 .5rem;color:rgb(var(--black));line-height:1.2}h1{font-size:3.052em}h2{font-size:2.441em}h3{font-size:1.953em}h4{font-size:1.563em}h5{font-size:1.25em}strong,b{font-weight:700}a,a:hover{color:var(--accent)}p{margin-bottom:1em;color:#fff}.prose p{margin-bottom:2em}textarea{width:100%;font-size:16px}input{font-size:16px}table{width:100%}img{max-width:100%;height:auto;border-radius:8px}code{padding:2px 5px;background-color:rgb(var(--gray-light));border-radius:2px}pre{padding:1.5em;border-radius:8px}pre>code{all:unset}blockquote{border-left:4px solid var(--accent);padding:0 0 0 20px;margin:0;font-size:1.333em}hr{border:none;border-top:1px solid rgb(var(--gray-light))}@media(max-width:720px){body{font-size:18px}main{padding:1em}}.sr-only{border:0;padding:0;margin:0;position:absolute!important;height:1px;width:1px;overflow:hidden;clip:rect(1px 1px 1px 1px);clip:rect(1px,1px,1px,1px);clip-path:inset(50%);white-space:nowrap}html{scrollbar-width:none;background-color:#110f10}html::-webkit-scrollbar{display:none}.tech-badge{display:inline-block;padding:.4rem .8rem;border-radius:20px;font-size:.85rem;font-weight:500;transition:all .3s ease;border:1px solid transparent;cursor:default}.tech-badge--primary{background:linear-gradient(135deg,#8a2be233,#9d4edd33);color:#c77dff;border-color:#8a2be24d}.tech-badge--secondary{background:linear-gradient(135deg,#ff8c0033,#ffa50033);color:orange;border-color:#ff8c004d}.tech-badge--warning{background:linear-gradient(135deg,#ffd70033,#ff03);color:gold;border-color:#ffd7004d}.tech-badge:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.tech-badge--primary:hover{box-shadow:0 4px 12px #8a2be24d}.tech-badge--secondary:hover{box-shadow:0 4px 12px #ff8c004d}.tech-badge--warning:hover{box-shadow:0 4px 12px #ffd7004d}.main-image-container{height:100vh;overflow:hidden;position:relative}.main-image{width:100%;height:100%;object-fit:cover;border-radius:0}.overlay{position:absolute;inset:0;z-index:1}.hero-overlay{display:flex;align-items:center;justify-content:center;background:#0006;padding:2rem;animation:fadeIn 1.5s ease-out}.hero-container{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:1200px;width:100%;animation:slideUp 1.2s ease-out .3s both}.hero-title{position:static;top:auto;transform:none;width:100%;text-align:center;margin:0 0 .2rem;padding:0;font-size:clamp(2.5rem,8vw,4.5rem);font-weight:700;letter-spacing:.06em;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.7);transition:all .3s ease}.hero-title:hover{transform:scale(1.01);text-shadow:0 0 15px rgba(255,255,255,.4),0 4px 12px rgba(0,0,0,.8)}.hero-subtitle{font-size:clamp(1.1rem,3vw,1.5rem);color:#ffffffe6;margin:.2rem 0;padding:0;font-weight:300;letter-spacing:.02em;text-shadow:0 1px 4px rgba(0,0,0,.8);animation:fadeInUp 1.5s ease-out .8s both;transition:all .3s ease}.hero-subtitle:hover{color:#fff;transform:translateY(-2px)}.hero-social-links{display:flex;justify-content:center;gap:1.5rem;margin-top:.5rem;animation:fadeInUp 1.8s ease-out 1.2s both}.hero-social-link{text-decoration:none;color:#fffc;transition:all .4s cubic-bezier(.4,0,.2,1);padding:.8rem;border-radius:50%;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center}.hero-social-link:hover{color:#fff;background:#fff3;transform:translateY(-4px) scale(1.1);box-shadow:0 10px 20px #0000004d;border-color:#fff6}.hero-social-icon{width:1.5rem;height:1.5rem;transition:all .3s ease}.hero-social-icon--github{width:1.65rem;height:1.65rem}@media(max-width:768px){.hero-overlay{padding:1rem}.hero-social-links{gap:1rem}.hero-social-link{padding:.6rem}.hero-social-icon{width:1.2rem;height:1.2rem}.hero-social-icon--github{width:1.32rem;height:1.32rem}}@media(max-width:480px){.hero-overlay{padding:.5rem}.hero-social-links{gap:.8rem}.hero-social-link{padding:.5rem}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.hero-overlay,.hero-container,.hero-title,.hero-subtitle,.hero-social-links,.hero-social-link{animation:none}.hero-title:hover,.hero-subtitle:hover,.hero-social-link:hover{transform:none}}@font-face{font-family:Oswald Variable;font-style:normal;font-display:swap;font-weight:200 700;src:url(/_astro/oswald-cyrillic-ext-wght-normal.DLWmRmaW.woff2) format("woff2-variations");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Oswald Variable;font-style:normal;font-display:swap;font-weight:200 700;src:url(/_astro/oswald-cyrillic-wght-normal.C8sJyxwB.woff2) format("woff2-variations");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Oswald Variable;font-style:normal;font-display:swap;font-weight:200 700;src:url(/_astro/oswald-vietnamese-wght-normal.Tdf5mmdl.woff2) format("woff2-variations");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Oswald Variable;font-style:normal;font-display:swap;font-weight:200 700;src:url(/_astro/oswald-latin-ext-wght-normal.Dj_1K-Kw.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Oswald Variable;font-style:normal;font-display:swap;font-weight:200 700;src:url(/_astro/oswald-latin-wght-normal.CzS3kehr.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}.about-section{color:#f2f2f2;min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:2rem;position:relative}.about-container{max-width:1100px;margin:0 auto;position:relative;z-index:1;padding:2rem}.about-content{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:3rem;margin-top:2rem}.about-photo-container{position:relative;width:220px;height:220px;margin:0 auto;display:flex;align-items:center;justify-content:center}.about-photo-container:before{content:"";position:absolute;width:250px;height:250px;border-radius:50%;border:2px solid rgba(255,107,0,.5);animation:pulse 3s infinite ease-in-out;z-index:0}.about-photo-container:after{content:"";position:absolute;width:290px;height:290px;border-radius:50%;border:1px solid rgba(255,215,0,.4);animation:pulse 3s infinite ease-in-out reverse;z-index:0}.about-photo{width:220px;height:220px;border-radius:50%;object-fit:cover;border:3px solid rgba(138,43,226,.8);box-shadow:0 0 15px #8a2be266;position:relative;z-index:1}@keyframes pulse{0%,to{transform:scale(1);opacity:.7}50%{transform:scale(1.05);opacity:1}}.about-text{flex:1 1 400px;max-width:600px}.about-title{font-size:3rem;font-weight:700;background:linear-gradient(135deg,#FFD700,var(--gold),var(--medium-violet));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:3rem;text-shadow:0 2px 4px rgba(255,215,0,.2);letter-spacing:-.02em;text-align:center}.about-text p{line-height:1.6;margin-bottom:1rem;text-align:justify}.skills-section,.languages-section{margin:2rem 0}.skills-section h3,.languages-section h3{font-size:1.3rem;color:var(--text-light-purple);margin-bottom:1rem;font-weight:600}.tech-badges,.language-badges{display:flex;flex-wrap:wrap;gap:.8rem;margin-bottom:1.5rem}.resume-button-container{text-align:center;margin-top:2rem;width:100%}.about-resume-btn{display:inline-block;color:#fff;padding:.75rem 1.5rem;border-radius:8px;text-decoration:none;transition:all .3s ease;font-weight:500;background:linear-gradient(135deg,#6a4c93,#9d4edd);box-shadow:0 4px 15px #9d4edd4d}.about-resume-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #9d4edd66;background:linear-gradient(135deg,#5a3b7c,#8b42d3);color:#fff}@media(max-width:1024px){.about-container{padding:1.5rem}.about-content{gap:2.5rem}}@media(max-width:768px){.about-section{padding:1.5rem;min-height:auto}.about-container{padding:1rem}.about-content{gap:2rem;margin-top:1.5rem}.about-title{font-size:2.5rem;margin-bottom:2rem}}@media(max-width:640px){.about-photo-container{width:180px;height:180px}.about-photo-container:before{width:200px;height:200px}.about-photo-container:after{width:220px;height:220px}.about-photo{width:180px;height:180px}.tech-badges,.language-badges{gap:.6rem}}@media(max-width:480px){.about-section{padding:1rem}.about-title{font-size:2rem}.about-photo-container{width:150px;height:150px}.about-photo-container:before{width:170px;height:170px}.about-photo-container:after{width:195px;height:195px}.about-photo{width:150px;height:150px}.about-content{gap:1.5rem}.resume-button-container{margin-top:1.5rem;margin-bottom:1.5rem}}.professional-section{background:transparent;padding:2rem 3rem;min-height:100vh;display:flex;flex-direction:column;justify-content:center}.professional-header{margin-bottom:2rem}.professional-title{text-align:center;font-weight:700;background:linear-gradient(135deg,#6a1b9a,#8e24aa,#ab47bc 60%,#ce93d8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:1rem}.professional-subtitle{text-align:center;font-size:1.5rem;font-weight:500;color:var(--light-violet);margin-bottom:2.5rem;opacity:.95}.experience-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2.5rem}.experience-card{border-radius:16px;padding:1.5rem;border:2px solid transparent;transition:all .3s ease;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--bg-dark-primary),var(--bg-dark-secondary));color:#fff}.experience-card:hover{transform:translateY(-5px);box-shadow:0 15px 30px #8a2be24d}.experience-card.highlighted{border-color:var(--medium-violet);box-shadow:0 15px 30px #9370db99;transform:translateY(-5px)}.experience-header{margin-bottom:.5rem}.experience-meta{display:flex;flex-direction:column;gap:.25rem;margin-top:.5rem}.experience-location,.experience-team{font-size:.9rem;opacity:.8}.experience-meta-inline{display:grid;grid-template-columns:1fr 1fr;gap:1rem;align-items:center}.experience-location{justify-self:start}.experience-team{justify-self:end}.experience-description{font-size:1.1rem;margin-bottom:.75rem}.experience-company{font-size:1.4rem;font-weight:700;margin-bottom:.25rem;font-weight:600}.experience-role{font-size:1.25rem;margin-bottom:.5rem;font-weight:700;color:#c77dff}.experience-duration{font-size:.9rem}.achievements-title{font-size:1.1rem;font-weight:700;margin-bottom:.5rem;margin-top:.5rem;color:#c77dff}.achievements-list{list-style:none;padding:0;margin-bottom:.75rem}.achievements-list li{margin-bottom:.25rem;padding-left:1.5rem;position:relative}.achievements-list li:before{content:"▸";position:absolute;left:0;font-weight:700}.technologies{display:flex;flex-wrap:wrap;gap:.5rem}@media(max-width:768px){.professional-section{margin-top:3rem;padding:3rem 1rem}.professional-title{font-size:2rem}.experience-grid{grid-template-columns:1fr;gap:2rem;padding:1rem 0}.experience-card{padding:1rem;margin:0;width:100%;max-width:100%;box-sizing:border-box}.experience-card .meta-info{padding:.75rem 1rem;margin-bottom:.5rem}.experience-card .meta-info.grid-layout{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}}@media(max-width:480px){.professional-title{font-size:2rem}.professional-subtitle{font-size:1.15rem;margin:0}.experience-card{padding:.9rem}.experience-card .meta-info{padding:.5rem .75rem;margin-bottom:.5rem}.experience-card .meta-info.grid-layout{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}}@media(max-width:400px){.professional-title{font-size:1.75rem}.professional-subtitle{font-size:1.05rem}.experience-company{font-size:1.25rem}.experience-role{font-size:1.15rem}}.meta-info{padding:1.5rem 2rem;background:#ffffff08;border-radius:12px;border:1px solid rgba(255,255,255,.08);margin-bottom:1rem}.meta-info.grid-layout{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}.meta-info.inline-layout{display:flex;flex-wrap:nowrap;gap:1rem;justify-content:space-between}.meta-item{display:flex;align-items:center;gap:.4rem;color:#e0e0e0;font-size:.85rem;font-weight:500;min-width:0}.meta-info.inline-layout .meta-item{gap:.3rem;font-size:.8rem;flex-shrink:0}.meta-info.inline-layout .meta-icon-svg{width:16px;height:16px}.meta-icon-svg{width:18px;height:18px;color:var(--medium-violet);transition:color .3s ease}.meta-item .meta-icon-svg{color:var(--medium-violet)}.meta-item:hover .meta-icon-svg{transform:scale(1.1);transition:transform .2s ease}.meta-text{font-weight:500;word-wrap:break-word;overflow-wrap:break-word;line-height:1.3}@media(max-width:768px){.meta-info.grid-layout{grid-template-columns:1fr;gap:1rem}.meta-info.inline-layout{flex-direction:column;gap:1rem}.meta-info{padding:1.2rem}.meta-item{font-size:.85rem}}.meta-info.professional{background:#ffffff0d;border:1px solid rgba(255,255,255,.1)}.meta-info.projects{background:#ffffff08;border:1px solid rgba(255,255,255,.08)}:root{--deep-purple: #4B0082;--blue-violet: #8A2BE2;--medium-violet: #9370DB;--light-violet: #BA55D3;--dark-orange: #FF8C00;--orange: #FFA500;--gold: #FFD700;--bright-yellow: #FFFF00;--light-cream: #FFF8DC;--light-yellow: #FFFACD;--text-light-purple: #C8A2E8;--text-medium-purple: #DDA0DD;--text-light: #E6E6FA;--text-yellow: #FFE55C;--text-light-yellow: #FFFF99;--breakpoint-sm: 480px;--breakpoint-md: 640px;--breakpoint-lg: 768px;--breakpoint-xl: 1024px;--breakpoint-2xl: 1280px;--text-gray: #D3D3D3;--text-dark: #8B4513;--bg-dark-primary: rgba(30, 30, 45, .98);--bg-dark-secondary: rgba(40, 35, 50, .98);--bg-card-primary: rgba(30, 30, 45, .95);--bg-card-secondary: rgba(40, 35, 50, .95)}.gradient-purple-deep{background:linear-gradient(135deg,var(--deep-purple),#6A0DAD,var(--blue-violet))}.gradient-purple-medium{background:linear-gradient(135deg,var(--blue-violet),var(--medium-violet),var(--light-violet))}.gradient-orange-gold{background:linear-gradient(135deg,var(--dark-orange),var(--orange),var(--gold))}.gradient-gold-bright{background:linear-gradient(135deg,var(--gold),var(--bright-yellow),var(--light-cream))}.gradient-sunset-text{background:linear-gradient(135deg,#FF6B35,#F7931E,var(--gold));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.gradient-purple-text{background:linear-gradient(135deg,#9d4edd,#c77dff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.shadow-purple{box-shadow:0 20px 25px -5px #4b008280,0 10px 10px -5px #8a2be266}.shadow-orange{box-shadow:0 20px 25px -5px #ff8c0080,0 10px 10px -5px #ffd70066}.shadow-gold{box-shadow:0 20px 25px -5px #ffd70099,0 10px 10px -5px #ffff0080}.shadow-card{box-shadow:0 10px 15px -3px #0006,0 4px 6px -2px #0003}.shadow-elevated{box-shadow:0 20px 25px -5px #8a2be266,0 10px 10px -5px #ff8c004d}.btn-gradient-primary{background:linear-gradient(135deg,#9d4edd,#c77dff);color:#fff;border:none;border-radius:20px;font-weight:500;cursor:pointer;transition:all .3s ease;text-decoration:none}.btn-gradient-primary:hover{background:linear-gradient(135deg,#8b42d3,#b56fff);transform:translateY(-2px);box-shadow:0 5px 15px #9d4edd66}.btn-gradient-sunset{background:linear-gradient(135deg,#FF6B35,#F7931E,var(--gold));color:#fff;border:none;border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 10px 15px -3px #ff6b3566}.btn-gradient-sunset:hover:not(:disabled){background:linear-gradient(135deg,#e55a2b,#e8841a,#e6c200)}.card-base{background:linear-gradient(135deg,var(--bg-card-primary),var(--bg-card-secondary));border-radius:1rem;transition:all .3s ease}.card-interactive{cursor:pointer}.card-interactive:hover{transform:translateY(-2px)}.badge-base{display:inline-block;padding:.25rem .75rem;font-size:.875rem;font-weight:600;border-radius:9999px;margin-bottom:.75rem}.tech-tag{background:linear-gradient(135deg,#ff6b35,#f7931e);color:#fff;font-size:.8rem;padding:.25rem .75rem;border-radius:20px;font-weight:500}.title-large{font-size:2.5rem;font-weight:700;margin-bottom:2.5rem;text-align:center}.title-medium{font-size:1.5rem;font-weight:700;color:var(--text-light);margin-bottom:.5rem}.subtitle-medium{font-size:1.25rem;font-weight:500;margin-bottom:1rem}.text-description{color:var(--text-gray);line-height:1.6;font-size:1rem}.container-base{width:100%;max-width:1400px;margin:0 auto;padding:4rem 3rem;box-sizing:border-box}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;justify-content:space-between;align-items:center}.grid-auto-fit{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}@media(max-width:768px){.container-base{padding:.75rem .75rem 3rem;margin:0;max-width:100vw;overflow-x:hidden}.title-large{font-size:2rem}.title-medium{font-size:1.25rem}.subtitle-medium{font-size:1rem}.text-description{font-size:.875rem}.grid-auto-fit{grid-template-columns:1fr}}@media(max-width:480px){.title-medium{font-size:1.125rem}.subtitle-medium{font-size:.875rem}.text-description{font-size:.8rem}}.timeline-container{width:100%;max-width:1600px;margin:0 auto;padding:2rem 3rem;box-sizing:border-box;min-height:90vh;display:flex;flex-direction:column}.timeline-header{text-align:center;margin-bottom:2rem}.timeline-title{font-size:3rem;font-weight:700;background:linear-gradient(135deg,#ff6b35,#f7931e,gold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:1rem;text-shadow:0 2px 4px rgba(255,107,53,.2);letter-spacing:-.02em}.timeline-subtitle{color:var(--text-dark);font-size:1.5rem;font-weight:500}.stepper-container{position:relative;width:100%;box-sizing:border-box;height:60vh;display:flex;align-items:center}.stepper-wrapper{position:relative;width:100%}.progress-line{position:absolute;top:5rem;left:0;right:0;height:6px;background:linear-gradient(to right,#4b008233,#8a2be233,#ff8c0033,#ff03);border-radius:3px}.progress-fill{position:absolute;top:5rem;left:0;height:6px;background:linear-gradient(to right,var(--deep-purple),var(--blue-violet),var(--dark-orange),var(--bright-yellow));border-radius:3px;transition:none;box-shadow:0 0 20px #ffd70080}.steps-list{display:flex;justify-content:space-between;align-items:flex-start;position:relative}.step-item{display:flex;flex-direction:column;align-items:center;flex:1;position:relative}.step-circle{position:relative;z-index:10;width:5rem;height:5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;transition:all .3s ease;cursor:pointer;margin-bottom:1.5rem;border:none;outline:none}.step-circle:hover{transform:scale(1.05)}.step-circle.step-0.active{background:linear-gradient(135deg,var(--deep-purple),#6A0DAD,var(--blue-violet));color:#fff;box-shadow:0 20px 25px -5px #4b008280,0 10px 10px -5px #8a2be266;border:4px solid rgba(138,43,226,.5)}.step-circle.step-0.completed{background:linear-gradient(135deg,#301934,var(--deep-purple));color:#fff;box-shadow:0 10px 15px -3px #4b008266}.step-circle.step-0.inactive{background:linear-gradient(135deg,#4b00821a,#8a2be21a);color:var(--deep-purple);border:4px solid rgba(138,43,226,.3)}.step-circle.step-0.inactive:hover{border-color:#8a2be299;background:linear-gradient(135deg,#4b008233,#8a2be233)}.step-circle.step-1.active{background:linear-gradient(135deg,#ba55d3,plum,#e6e6fa);color:#fff;box-shadow:0 20px 25px -5px #ba55d380,0 10px 10px -5px #dda0dd66;border:4px solid rgba(186,85,211,.5)}.step-circle.step-1.completed{background:linear-gradient(135deg,#9370db,#ba55d3);color:#fff;box-shadow:0 10px 15px -3px #ba55d366}.step-circle.step-1.inactive{background:linear-gradient(135deg,#ba55d31a,#dda0dd1a);color:#ba55d3;border:4px solid rgba(186,85,211,.3)}.step-circle.step-1.inactive:hover{border-color:#ba55d399;background:linear-gradient(135deg,#ba55d333,#dda0dd33)}.step-circle.step-2.active{background:linear-gradient(135deg,var(--dark-orange),var(--orange),var(--gold));color:#fff;box-shadow:0 20px 25px -5px #ff8c0080,0 10px 10px -5px #ffd70066;border:4px solid rgba(255,215,0,.5)}.step-circle.step-2.completed{background:linear-gradient(135deg,#DAA520,var(--dark-orange));color:#fff;box-shadow:0 10px 15px -3px #ff8c0066}.step-circle.step-2.inactive{background:linear-gradient(135deg,#ff8c001a,#ffd7001a);color:var(--dark-orange);border:4px solid rgba(255,215,0,.3)}.step-circle.step-2.inactive:hover{border-color:#ffd70099;background:linear-gradient(135deg,#ff8c0033,#ffd70033)}.step-labels{text-align:center;margin-bottom:1rem}.step-year,.step-title,.step-subtitle{transition:color .3s ease}.step-year{font-size:1.125rem;font-weight:500;margin-bottom:.5rem}.step-title{font-size:1.125rem;font-weight:700;margin-bottom:.5rem}.step-subtitle{font-size:1rem}.step-item.step-0 .step-year.active{color:#a064ca;font-weight:600}.step-item.step-0 .step-year.inactive{color:#6a0dad}.step-item.step-0 .step-title.active{color:#a064ca;text-shadow:0 1px 2px rgba(75,0,130,.2)}.step-item.step-0 .step-title.inactive{color:#8a2be2}.step-item.step-0 .step-subtitle.active{color:#a064ca}.step-item.step-0 .step-subtitle.inactive{color:#8a2be2cc}.step-item.step-1 .step-year.active{color:#d392e3;font-weight:600}.step-item.step-1 .step-year.inactive{color:#ba55d3}.step-item.step-1 .step-title.active{color:#d392e3;text-shadow:0 1px 2px rgba(186,85,211,.3)}.step-item.step-1 .step-title.inactive{color:#ba55d3}.step-item.step-1 .step-subtitle.active{color:#d392e3}.step-item.step-1 .step-subtitle.inactive{color:#ba55d3cc}.step-item.step-2 .step-year.active{color:var(--text-yellow);font-weight:600}.step-item.step-2 .step-year.inactive{color:var(--gold)}.step-item.step-2 .step-title.active{color:var(--light-cream);text-shadow:0 1px 2px rgba(255,215,0,.3)}.step-item.step-2 .step-title.inactive{color:var(--text-yellow)}.step-item.step-2 .step-subtitle.active{color:var(--light-yellow)}.step-item.step-2 .step-subtitle.inactive{color:#ffe55ccc}.step-details{position:absolute;top:100%;left:50%;transform:translate(-50%);width:380px;opacity:0;visibility:hidden;transition:all .3s ease;z-index:20}.step-details.active{opacity:1;visibility:visible}.details-card{background:linear-gradient(135deg,var(--bg-dark-primary),var(--bg-dark-secondary));border-radius:1rem;padding:2rem;box-shadow:0 12px 35px #00000080;border:3px solid;position:relative}.details-card:before{content:"";position:absolute;top:-8px;left:50%;transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent}.step-item.step-0 .details-card{border-color:#8a2be299}.step-item.step-0 .details-card:before{border-bottom:8px solid rgba(138,43,226,.6)}.step-item.step-1 .details-card{border-color:#ba55d399}.step-item.step-1 .details-card:before{border-bottom:8px solid rgba(186,85,211,.6)}.step-item.step-2 .details-card{border-color:#ffd70099}.step-item.step-2 .details-card:before{border-bottom:8px solid rgba(255,215,0,.6)}.details-year-badge{display:inline-block;padding:.25rem .5rem;font-size:.75rem;font-weight:600;border-radius:9999px;margin-bottom:.75rem;max-width:100%;box-sizing:border-box}.step-item.step-0 .details-year-badge{background:linear-gradient(135deg,#4b00824d,#8a2be24d);color:var(--text-light-purple);border:1px solid rgba(138,43,226,.5)}.step-item.step-1 .details-year-badge{background:linear-gradient(135deg,#8a2be24d,#ba55d34d);color:var(--text-medium-purple);border:1px solid rgba(186,85,211,.5)}.step-item.step-2 .details-year-badge{background:linear-gradient(135deg,#ff8c004d,#ffd7004d);color:var(--gold);border:1px solid rgba(255,215,0,.5)}.details-title{font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.details-subtitle{font-size:1.25rem;font-weight:500;margin-bottom:1rem}.step-item.step-0 .details-title{color:#8a2be2}.step-item.step-0 .details-subtitle{color:#8a2be2cc}.step-item.step-1 .details-title{color:#ba55d3}.step-item.step-1 .details-subtitle{color:#ba55d3cc}.step-item.step-2 .details-title,.step-item.step-2 .details-subtitle{color:var(--text-yellow)}.details-description{color:var(--text-gray);line-height:1.6;font-size:1rem;text-align:justify}.internship-links{margin-top:1.5rem;padding-top:1rem;border-top:1px solid rgba(199,125,255,.3);display:flex;flex-direction:column;gap:.5rem}.links-title{font-size:.9rem;color:var(--medium-violet);font-weight:600;margin-bottom:.75rem}.step-item.step-0 .links-title{color:var(--medium-violet)}.step-item.step-1 .links-title{color:var(--light-violet)}.step-item.step-2 .links-title{color:var(--gold)}.internship-link{display:block;width:100%;padding:.5rem 1rem;background:linear-gradient(135deg,var(--blue-violet),var(--medium-violet));color:#fff;border:none;border-radius:20px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .3s ease;text-decoration:none;text-align:center;box-sizing:border-box}.internship-link:hover{background:linear-gradient(135deg,var(--deep-purple),var(--blue-violet));transform:translateY(-2px);box-shadow:0 5px 15px #8a2be266}.step-item.step-0 .internship-link{background:linear-gradient(135deg,var(--blue-violet),var(--medium-violet))}.step-item.step-0 .internship-link:hover{background:linear-gradient(135deg,var(--deep-purple),var(--blue-violet));box-shadow:0 5px 15px #8a2be266}.step-item.step-1 .internship-link{background:linear-gradient(135deg,var(--blue-violet),var(--medium-violet));color:#fff;border:1px solid var(--medium-violet)}.step-item.step-1 .internship-link:hover{background:linear-gradient(135deg,var(--medium-violet),var(--light-violet));color:#fff;border-color:var(--light-violet);box-shadow:0 5px 15px #ba55d366}.step-item.step-2 .internship-link{background:var(--dark-orange);color:#fff;border:1px solid var(--dark-orange)}.step-item.step-2 .internship-link:hover{background:var(--gold);color:#2d2d2d;border-color:var(--gold);box-shadow:0 5px 15px #ffd7004d}@media(max-width:768px){.timeline-title{font-size:2.5rem}.timeline-container{padding:.75rem .75rem 3rem;margin:0;max-width:100vw;overflow-x:hidden}.timeline-header{margin-bottom:2rem}.timeline-subtitle{font-size:1.05rem;margin:0}.stepper-container{position:relative;padding:0;width:100%;max-width:100%;overflow-x:hidden;height:auto;display:block}.stepper-wrapper{position:static}.progress-line,.progress-fill{display:none}.steps-list{flex-direction:column;align-items:stretch;gap:1.5rem;padding:0;width:100%;box-sizing:border-box}.step-item{flex-direction:column;align-items:stretch;position:relative;width:100%;box-sizing:border-box}.step-circle,.step-labels{display:none}.step-details{position:static;width:100%;margin-top:0;transform:none;opacity:1!important;visibility:visible!important;box-sizing:border-box}.details-card{padding:1rem;margin:0;position:relative;border-width:3px;width:100%;box-sizing:border-box;max-width:100%}.details-card:before{display:none}.details-title{font-size:1.25rem}.details-subtitle{font-size:1rem}.details-description{font-size:1.4rem;line-height:1.6}.details-title{font-size:1.35rem}.internship-link{font-size:1.05rem;padding:.4rem .8rem}.details-subtitle,.links-title{font-size:1.2rem}}@media(max-width:480px){.timeline-title{font-size:2rem}.details-card{padding:.875rem}.details-description{font-size:1.1rem}.timeline-container{padding:1rem}.links-title{font-size:1.1rem}.internship-link{font-size:.95rem}}@media(max-width:380px){.timeline-subtitle{font-size:.95rem}}.projects-section{padding:4rem 2rem;position:relative;overflow:hidden}.projects-header{margin-bottom:2rem}.projects-section:before{content:"";position:absolute;inset:0;pointer-events:none}.projects-container{max-width:1400px;margin:0 auto;position:relative;z-index:1}.projects-title{font-size:3rem;font-weight:700;text-align:center;margin-bottom:1rem;background:linear-gradient(135deg,#4a148c,#6a1b9a,#7b1fa2 60%,#8e24aa);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 2px 4px rgba(138,43,226,.2);letter-spacing:-.02em}.projects-subtitle{text-align:center;font-size:1.5rem;font-weight:500;color:var(--light-violet);margin-bottom:2.5rem;opacity:.95}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));grid-auto-rows:1fr;gap:2.5rem;padding:1rem 0}.project-card{background:#ffffff0d;border-radius:20px;overflow:hidden;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;display:flex;flex-direction:column;height:100%}.project-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 20px 40px #8a2be233,0 10px 20px #ff6b351a;border-color:#8a2be24d}.project-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#8a2be2,#ff6b35,gold);opacity:0;transition:opacity .3s ease}.project-card:hover:before{opacity:1}.project-link{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:8px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#fff;text-decoration:none;transition:all .3s ease;flex-shrink:0}.project-link:hover{transform:translateY(-2px);background:#8a2be24d;border-color:#8a2be2;box-shadow:0 4px 12px #8a2be24d;color:#fff}.project-content{padding:1rem;display:flex;flex-direction:column;flex:1}.project-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1rem;gap:1rem}.project-title-section{flex:1}.project-title{font-size:1.4rem;font-weight:700;color:#fff;margin:0 0 .25rem;line-height:1.3}.project-category{color:#c77dff;font-size:1.1rem;font-weight:500;margin:0;opacity:.9}.project-description{color:#e0e0e0;line-height:1.6;margin-bottom:1.5rem;text-align:justify;font-size:1.1rem;flex:1}.project-technologies{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:auto}@media(max-width:768px){.projects-section{padding:3rem 1rem}.projects-title{font-size:2.5rem}.projects-grid{grid-template-columns:1fr;gap:2rem;padding:1rem 0}.project-card{margin:0;width:100%;max-width:100%}.project-header{flex-direction:row;align-items:flex-start;gap:.75rem}.project-title{font-size:1.2rem}.project-card .meta-info{display:flex;flex-direction:row;gap:1rem;justify-content:space-between;padding:.75rem 1rem;margin-bottom:.75rem}}@media(max-width:480px){.projects-title{font-size:2rem}.projects-subtitle{font-size:1.05rem;margin:0}.project-content{padding:1rem}.project-link{width:36px;height:36px}.project-card .meta-info{display:flex;flex-direction:row;gap:.75rem;justify-content:space-between;padding:.75rem;margin-bottom:.5rem;font-size:1.05rem}}.project-card{animation:fadeInUp .6s ease-out forwards}.project-card:nth-child(1){animation-delay:.1s}.project-card:nth-child(2){animation-delay:.2s}.project-card:nth-child(3){animation-delay:.3s}.project-card:nth-child(4){animation-delay:.4s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
