body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}body,html{font-family:Poppins,sans-serif;margin:0;padding:0}.intro-container{align-items:center;background:linear-gradient(180deg,#3e4e6a,#0830be);display:flex;flex-direction:column;justify-content:center;min-height:100vh;overflow:hidden;position:relative;text-align:center;width:100%}.intro-content{color:#fff;font-size:2rem;position:relative;text-shadow:3px 3px 3px rgba(0,0,0,.7);z-index:1}.star{-webkit-animation-iteration-count:infinite;animation-iteration-count:infinite;-webkit-animation-name:twinkle;animation-name:twinkle;-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out;background:#fff;border-radius:50%;box-shadow:0 0 6px hsla(0,0%,100%,.8);opacity:0;position:absolute}@-webkit-keyframes twinkle{0%,to{opacity:0;-webkit-transform:scale(.8);transform:scale(.8)}50%{opacity:1;-webkit-transform:scale(1.2);transform:scale(1.2)}}@keyframes twinkle{0%,to{opacity:0;-webkit-transform:scale(.8);transform:scale(.8)}50%{opacity:1;-webkit-transform:scale(1.2);transform:scale(1.2)}}:root{--primary-color:#3182ce;--secondary-color:#2c5282;--accent-color:#38a169;--background-light:#f7fafc;--border-color:#e2e8f0;--text-primary:#2d3748;--text-secondary:#4a5568;--timeline-line:#cbd5e0;--shadow-light:0 2px 8px rgba(0,0,0,.1);--shadow-medium:0 4px 20px rgba(0,0,0,.15)}p{font-size:.875rem;line-height:1.6;margin:0}.timeline-container{align-items:center;display:flex;flex-direction:column;min-height:100vh;padding:2rem;position:relative;text-align:center;width:100%}.timeline-container h2{color:#fff;font-size:2.5rem;font-weight:700;margin-bottom:2rem;position:relative;text-shadow:2px 2px 8px rgba(0,0,0,.5);z-index:1}.timeline-layout{display:flex;gap:2rem;height:calc(100vh - 200px);max-width:1400px;min-height:700px;width:100%}.timeline-sidebar{display:flex;flex:0 0 400px;flex-direction:column;overflow:hidden;padding:1.5rem;position:relative}.timeline-line-compact{background:linear-gradient(180deg,#3182ce,#38a169);background:linear-gradient(180deg,var(--primary-color) 0,var(--accent-color) 100%);border-radius:2px;box-shadow:0 0 8px rgba(49,130,206,.3);left:2rem;position:absolute;top:1.5rem;width:3px}.timeline-items-compact{display:flex;flex:1 1;flex-direction:column;gap:.75rem;margin-right:8px;overflow-y:auto;padding-left:3rem;position:relative;scrollbar-color:#3182ce transparent;scrollbar-color:var(--primary-color) transparent;scrollbar-width:thin}.timeline-items-compact::-webkit-scrollbar{width:6px}.timeline-items-compact::-webkit-scrollbar-track{background:transparent}.timeline-items-compact::-webkit-scrollbar-thumb{background:#3182ce;background:var(--primary-color);border-radius:3px}.timeline-item-compact{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:hsla(0,0%,100%,.8);border:2px solid transparent;border-radius:12px;cursor:pointer;flex-shrink:0;padding:.5rem;position:relative;transition:all .3s ease}.timeline-item-compact:hover{background:hsla(0,0%,100%,.9);box-shadow:0 2px 8px rgba(0,0,0,.1);-webkit-transform:translateX(4px);transform:translateX(4px)}.timeline-item-compact.selected{background:hsla(0,0%,100%,.95);border-color:#3182ce;border-color:var(--primary-color);box-shadow:0 4px 16px rgba(49,130,206,.3);-webkit-transform:translateX(8px);transform:translateX(8px)}.timeline-dot-compact{align-items:center;background:linear-gradient(135deg,#3182ce,#38a169);background:linear-gradient(135deg,var(--primary-color) 0,var(--accent-color) 100%);border:3px solid #fff;border-radius:50%;box-shadow:0 2px 8px rgba(0,0,0,.1);box-shadow:var(--shadow-light);display:flex;height:32px;justify-content:center;left:-2.25rem;position:absolute;top:.75rem;transition:all .3s ease;width:32px}.timeline-item-compact.selected .timeline-dot-compact{box-shadow:0 4px 16px rgba(49,130,206,.4);-webkit-transform:scale(1.15);transform:scale(1.15)}.timeline-year-compact{color:#fff;font-size:.55rem;font-weight:700;line-height:1;text-align:center}.timeline-card-compact{text-align:left}.timeline-period-compact{color:#3182ce;color:var(--primary-color);display:block;font-size:.7rem;font-weight:600;margin-bottom:.2rem}.timeline-title-compact{color:#2d3748;color:var(--text-primary);font-size:.85rem;font-weight:600;line-height:1.2;margin:0 0 .4rem}.timeline-tech-compact{display:flex;flex-wrap:wrap;gap:.2rem}.tech-badge-compact{background:#f7fafc;background:var(--background-light);border:1px solid #e2e8f0;border:1px solid var(--border-color);border-radius:6px;color:#4a5568;color:var(--text-secondary);font-size:.6rem;font-weight:500;padding:.1rem .4rem}.tech-more-compact{background:#3182ce;background:var(--primary-color);border-radius:6px;color:#fff;font-size:.6rem;font-weight:600;padding:.1rem .4rem}.timeline-details-panel{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:hsla(0,0%,100%,.95);border-radius:20px;box-shadow:0 4px 20px rgba(0,0,0,.15);box-shadow:var(--shadow-medium);flex:1 1;padding:2rem}.details-content,.timeline-details-panel{display:flex;flex-direction:column;overflow:hidden}.details-content{height:100%}.details-header{border-bottom:2px solid #e2e8f0;border-bottom:2px solid var(--border-color);flex-shrink:0;margin-bottom:1.5rem;padding-bottom:1rem;text-align:left}.details-period{color:#3182ce;color:var(--primary-color);display:block;font-size:.9rem;font-weight:600;margin-bottom:.4rem}.details-title{color:#2d3748;color:var(--text-primary);font-size:1.5rem;font-weight:700;line-height:1.2;margin:0}.details-body{flex:1 1;overflow-y:auto;scrollbar-color:#3182ce transparent;scrollbar-color:var(--primary-color) transparent;scrollbar-width:thin;text-align:left}.details-body::-webkit-scrollbar{width:6px}.details-body::-webkit-scrollbar-track{background:transparent}.details-body::-webkit-scrollbar-thumb{background:#3182ce;background:var(--primary-color);border-radius:3px}.tech-stack-full{flex-shrink:0;margin-bottom:1.5rem}.tech-label{color:#4a5568;color:var(--text-secondary);display:block;font-size:.9rem;font-weight:600;margin-bottom:.75rem}.tech-tags-grid{display:flex;flex-wrap:wrap;gap:.4rem}.tech-tag{background:linear-gradient(135deg,#3182ce,#38a169);background:linear-gradient(135deg,var(--primary-color),var(--accent-color));border-radius:10px;box-shadow:0 2px 4px rgba(0,0,0,.1);color:#fff;display:inline-block;font-size:.8rem;font-weight:500;padding:.4rem .8rem}.section-title{border-left:4px solid #3182ce;border-left:4px solid var(--primary-color);color:#2d3748;color:var(--text-primary);font-size:1rem;font-weight:600;margin:0 0 .75rem;padding-left:.75rem}.description-section{margin-bottom:1.5rem}.details-description{color:#4a5568;color:var(--text-secondary);font-size:.9rem;line-height:1.6;margin:0}.highlight-section{margin-bottom:1rem}.details-highlight{align-items:flex-start;background:linear-gradient(135deg,#f0fff4,#e6fffa);border-left:4px solid #38a169;border-left:4px solid var(--accent-color);border-radius:10px;box-shadow:0 2px 8px rgba(0,0,0,.05);display:flex;gap:.8rem;padding:1.2rem}.highlight-icon{flex-shrink:0;font-size:1.2rem}.highlight-text{color:#2d3748;color:var(--text-primary);font-size:.9rem;font-style:italic;font-weight:500;line-height:1.5;margin:0}@media screen and (max-width:1024px){.timeline-layout{flex-direction:column;gap:1.5rem;height:auto}.timeline-sidebar{flex:none;height:300px;order:2}.timeline-details-panel{flex:none;min-height:400px;order:1}.timeline-items-compact{display:flex;flex-direction:row;gap:.75rem;overflow-x:auto;padding-bottom:1rem;padding-left:0}.timeline-line-compact{display:none}.timeline-item-compact{flex:0 0 280px;padding:1rem}.timeline-dot-compact{margin-bottom:.75rem;position:static}}@media screen and (max-width:768px){.timeline-container{padding:1rem}.timeline-container h2{font-size:2rem;margin-bottom:1.5rem}.timeline-layout{gap:1rem}.timeline-sidebar{height:250px;padding:1rem}.timeline-details-panel{padding:1.5rem}.timeline-item-compact{flex:0 0 240px;padding:.75rem}.details-title{font-size:1.5rem}.details-header{margin-bottom:1.5rem;padding-bottom:1rem}}@media screen and (max-width:480px){.timeline-container{padding:.75rem}.timeline-sidebar{height:200px;padding:.75rem}.timeline-details-panel{padding:1rem}.timeline-item-compact{flex:0 0 200px;padding:.5rem}.timeline-title-compact{font-size:.8rem}.details-title{font-size:1.25rem}.tech-tag{font-size:.75rem;padding:.375rem .75rem}.details-highlight{flex-direction:column;gap:.75rem;padding:1rem}.highlight-icon{align-self:flex-start}}.cloud-container{background:linear-gradient(180deg,#0830be 50%,#3aaad9);height:100%;left:0;overflow:hidden;pointer-events:none;position:absolute;top:0;width:100%;z-index:-1}.cloud{-webkit-animation:moveClouds 30s linear;animation:moveClouds 30s linear;background:#fff;background:linear-gradient(180deg,#fff 5%,#f1f1f1);-webkit-filter:blur(1px);filter:blur(1px);opacity:.8;-webkit-transform:translateX(-200px);transform:translateX(-200px);-webkit-transform-origin:left center;transform-origin:left center}.cloud,.cloud:after,.cloud:before{border-radius:50%;position:absolute}.cloud:after,.cloud:before{background:#fff;content:"";height:60%;left:10%;top:-25%;width:60%}.cloud:after{height:50%;left:60%;top:10%;width:50%}@-webkit-keyframes moveClouds{0%{-webkit-transform:translateX(-200px);transform:translateX(-200px)}to{-webkit-transform:translateX(calc(100vw + 200px));transform:translateX(calc(100vw + 200px))}}@keyframes moveClouds{0%{-webkit-transform:translateX(-200px);transform:translateX(-200px)}to{-webkit-transform:translateX(calc(100vw + 200px));transform:translateX(calc(100vw + 200px))}}.cloud.small{height:48px;width:80px}.cloud.large{height:84px;width:140px}.cloud.layer1{z-index:-2}.cloud.layer2{-webkit-filter:blur(2px);filter:blur(2px);z-index:-1}@media (max-width:768px){.cloud.small{height:36px;width:60px}.cloud.large{height:60px;width:100px}}@media (prefers-reduced-motion:reduce){.cloud,.expand-button,.timeline-card,.timeline-dot{-webkit-animation:none!important;animation:none!important;transition:none!important}}.contact-container{align-items:center;background:linear-gradient(180deg,#3aaad9,#3330ef);display:flex;flex-direction:column;height:100vh;justify-content:center;overflow:hidden;position:relative;text-align:center;width:100%}.contact-container *{z-index:1}.contact-container h2{color:#fff;font-size:2.5rem;font-weight:600;margin-bottom:1rem;text-shadow:3px 3px 3px rgba(0,0,0,.7)}.contact-container ul{font-size:1.1rem;list-style:none;padding:0}.contact-container li{color:#fff;font-weight:300;font-weight:700;margin:.5rem 0;text-shadow:2px 2px 2px rgba(0,0,0,.5);transition:color .3s ease}.contact-container li:hover{color:var(--primary-color)}.resume-button{background-color:#3182ce;background-color:var(--primary-color,#3182ce);border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1rem;margin-top:1.5rem;padding:.75rem 1.5rem;transition:background-color .3s ease}.resume-button:hover{background-color:#2b6cb0}.wave{-webkit-animation:waveAnimation 1s forwards;animation:waveAnimation 1s forwards;background-color:#0400ff;border-radius:50% 50% 0 0;bottom:0;height:24em;left:0;pointer-events:none;position:absolute;-webkit-transform:translateX(-50%);transform:translateX(-50%);width:24em}@-webkit-keyframes waveAnimation{0%{-webkit-transform:translateY(100%) translateX(-50%);transform:translateY(100%) translateX(-50%)}40%{-webkit-transform:translateY(60%) translateX(-50%) scaleX(1.2);transform:translateY(60%) translateX(-50%) scaleX(1.2)}to{-webkit-transform:translateY(100%) translateX(-50%) scaleX(1.5);transform:translateY(100%) translateX(-50%) scaleX(1.5)}}@keyframes waveAnimation{0%{-webkit-transform:translateY(100%) translateX(-50%);transform:translateY(100%) translateX(-50%)}40%{-webkit-transform:translateY(60%) translateX(-50%) scaleX(1.2);transform:translateY(60%) translateX(-50%) scaleX(1.2)}to{-webkit-transform:translateY(100%) translateX(-50%) scaleX(1.5);transform:translateY(100%) translateX(-50%) scaleX(1.5)}}@media (max-width:768px){.wave{height:12em;width:12em}}@media (max-width:480px){.wave{height:8em;width:8em}}@media (prefers-reduced-motion:reduce){.wave{-webkit-animation:none;animation:none}}.glimmer-container{-webkit-animation:shiftGlimmers 60s linear infinite;animation:shiftGlimmers 60s linear infinite;height:100%;left:0;pointer-events:none;position:absolute;top:0;width:200%;z-index:0}.glimmer-set{height:100%;position:absolute;width:100%}.glimmer{color:#fff;font-size:16px;position:absolute}@-webkit-keyframes shiftGlimmers{0%{-webkit-transform:translateX(-50%);transform:translateX(-50%)}to{-webkit-transform:translateX(0);transform:translateX(0)}}@keyframes shiftGlimmers{0%{-webkit-transform:translateX(-50%);transform:translateX(-50%)}to{-webkit-transform:translateX(0);transform:translateX(0)}}@-webkit-keyframes flip{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}50%{-webkit-transform:rotate(180deg);transform:rotate(180deg)}to{-webkit-transform:rotate(0deg);transform:rotate(0deg)}}@keyframes flip{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}50%{-webkit-transform:rotate(180deg);transform:rotate(180deg)}to{-webkit-transform:rotate(0deg);transform:rotate(0deg)}}.app-container{overflow-x:hidden}.app-container,.section{min-height:100vh;width:100%}.section{align-items:center;box-sizing:border-box;display:flex;justify-content:center;position:relative}body,html{scroll-behavior:smooth}@media (max-width:768px){.section{min-height:100vh;padding:1rem 0}}@media (max-width:480px){.section{min-height:auto;padding:2rem 0}}.section-navigation{display:flex;flex-direction:column;gap:1rem;position:fixed;right:2rem;top:50%;-webkit-transform:translateY(-50%);transform:translateY(-50%);z-index:1000}.nav-dot{background:hsla(0,0%,100%,.5);border:2px solid hsla(0,0%,100%,.8);border-radius:50%;cursor:pointer;height:12px;transition:all .3s ease;width:12px}.nav-dot.active,.nav-dot:hover{background:hsla(0,0%,100%,.9);-webkit-transform:scale(1.2);transform:scale(1.2)}@media (max-width:768px){.section-navigation{bottom:2rem;flex-direction:row;right:50%;top:auto;-webkit-transform:translateX(50%);transform:translateX(50%)}}
/*# sourceMappingURL=main.922a16c6.css.map*/