@import "https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800&display=swap";html,body{width:100%;overflow-x:hidden}#root{width:100%}.header{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:100;background:#fdfcf8f2;border-bottom:1px solid #ddd8c4;justify-content:space-between;align-items:center;width:100%;padding:2rem 6%;transition:box-shadow .3s;display:flex;position:fixed;top:0;left:0}.header:hover{box-shadow:0 4px 20px #0000000f}.logo{color:var(--text);cursor:pointer;white-space:nowrap;align-items:center;gap:1.2rem;font-size:2.4rem;font-weight:800;transition:all .3s;display:flex}.logo:hover{transform:scale(1.05)}.logo-circle{background:var(--text);width:4rem;height:4rem;color:var(--bg);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.8rem;font-weight:700;display:flex}.logo .accent{color:var(--accent)}.navbar{align-items:center;gap:2.5rem;display:flex}.navbar a{color:var(--text);cursor:pointer;white-space:nowrap;border-bottom:3px solid #0000;padding-bottom:2px;font-size:1.5rem;font-weight:500;transition:all .3s}.navbar a:hover,.navbar a.active{color:var(--accent);border-bottom-color:var(--accent)}.menu-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;font-size:3rem;display:none}.mobile-nav{background:var(--bg);border-left:2px solid var(--accent);z-index:200;flex-direction:column;gap:3rem;width:60%;max-width:280px;height:100vh;padding:8rem 3rem;transition:transform .35s;display:none;position:fixed;top:0;right:0;transform:translate(100%)}.mobile-nav.open{transform:translate(0)}.mobile-nav a{color:var(--text);cursor:pointer;font-size:2rem;font-weight:500;transition:color .2s}.mobile-nav a:hover,.mobile-nav a.active{color:var(--accent)}.close-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;font-size:2.8rem;position:absolute;top:2rem;right:2rem}.overlay{z-index:150;background:#00000059;display:none;position:fixed;inset:0}.overlay.open{display:block}@media (width<=768px){.navbar{display:none}.menu-btn{display:block}.mobile-nav{display:flex}}.home{justify-content:center;align-items:center;gap:6rem;min-height:100vh;padding-top:12rem;display:flex;position:relative;overflow:hidden}.home-rectangle{background:var(--main);z-index:0;border-radius:10% 0 0 10%;width:32%;height:100%;animation:1s forwards slideInRight;position:absolute;top:0;right:0}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.home-content{z-index:1;flex:1;max-width:580px;animation:.8s forwards fadeInUp;position:relative}@keyframes fadeInUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.badge-tag{background:var(--light);color:var(--accent);letter-spacing:3px;text-transform:uppercase;border:1px solid #c8d4ca;border-radius:3rem;margin-bottom:1.5rem;padding:.8rem 2rem;font-size:1.2rem;font-weight:500;animation:.8s .2s both fadeInUp;display:inline-block}.home-content h3{font-size:2.8rem;font-weight:700;animation:.8s .3s both fadeInUp}.home-content h1{font-size:clamp(5rem,7vw,8rem);font-weight:800;line-height:1.1;animation:.8s .4s both fadeInUp}.home-content h1 .accent{color:var(--accent)}.home-content>p{color:#555;max-width:500px;margin:1.5rem 0 2rem;font-size:1.7rem;line-height:1.7;animation:.8s .5s both fadeInUp}.home-img-wrap{z-index:1;flex-shrink:0;animation:.8s .3s both fadeInUp;position:relative}.home-img{border:10px solid var(--main);border-radius:50%;transition:transform .4s;display:inline-block}.home-img:hover{transform:scale(1.03)}.home-img img{border:25px solid #fff;border-radius:50%;width:28vw;min-width:200px;max-width:360px}.home-img-mobile{display:none}.social-icons{flex-wrap:wrap;align-items:center;animation:.8s .6s both fadeInUp;display:flex}.social-icons a{border:2px solid var(--accent);width:4.5rem;height:4.5rem;color:var(--accent);border-radius:50%;justify-content:center;align-items:center;margin:2rem 1rem 2rem 0;font-size:2.5rem;transition:all .3s;display:inline-flex}.social-icons a:hover{color:#fff;background:var(--accent);transform:scale(1.2)translateY(-4px)}.home-btns{animation:.8s .7s both fadeInUp}@media (width<=991px){.home{text-align:center;flex-direction:column;gap:2rem;padding-top:12rem;padding-bottom:6rem}.home-rectangle{width:50%;height:55%;top:unset;border-bottom-left-radius:50%;bottom:0}.home-img-wrap{display:none}.home-img-mobile{justify-content:center;margin:1.5rem 0;display:flex}.home-img-mobile .home-img img{width:50vw;max-width:260px}.home-content{max-width:100%}.home-content>p{margin-left:auto;margin-right:auto}.social-icons{justify-content:center}.home-btns{flex-wrap:wrap;justify-content:center;display:flex}}@media (width<=480px){.home-img-mobile .home-img img{width:65vw}.badge-tag{padding:.6rem 1.4rem;font-size:1rem}}.about{background:var(--mist);justify-content:center;align-items:center;gap:8rem;min-height:100vh;display:flex;position:relative;overflow:hidden}.about-rectangle{background:var(--main);z-index:0;border-radius:0 10% 10% 0;width:28%;height:100%;position:absolute;left:0}.about-img{border:10px solid var(--accent);z-index:1;border-radius:50%;flex-shrink:0;transition:transform .4s;position:relative}.about-img:hover{transform:scale(1.03)}.about-img img{border:25px solid #fff;border-radius:50%;width:25vw;min-width:180px;max-width:320px}.about-content{z-index:1;max-width:550px;position:relative}.about-title{margin-bottom:1.5rem;font-family:Georgia,serif;font-size:clamp(2.8rem,4vw,4.5rem)}.about-content p{color:#444;margin-bottom:2rem;font-size:1.6rem;line-height:1.8}.about-stats{border-top:1px solid #b3c4b8;border-bottom:1px solid #b3c4b8;flex-wrap:wrap;gap:3rem;margin-bottom:2.5rem;padding:2rem 0;display:flex}.about-stats h3{font-size:3rem;font-weight:800}.about-stats h3 .accent{color:var(--accent)}.about-stats p{color:#666;text-transform:uppercase;letter-spacing:1px;font-size:1.3rem}@media (width<=991px){.about{text-align:center;flex-direction:column;gap:3rem}.about-rectangle{display:none}.about-img img{width:50vw;max-width:280px}.about-stats{justify-content:center}.section-divider{margin-left:auto;margin-right:auto}}@media (width<=480px){.about-img img{width:70vw}}.projects{background:var(--light)}.projects-grid{grid-template-columns:repeat(3,1fr);gap:2.5rem;width:100%;margin-bottom:4rem;display:grid}.project-card{background:#fff;border:1px solid #ddd8c4;border-radius:1.6rem;flex-direction:column;transition:all .35s;display:flex;overflow:hidden}.project-card:hover{border-color:var(--main);transform:translateY(-8px);box-shadow:0 24px 60px #697c7040}.project-img{aspect-ratio:16/10;position:relative;overflow:hidden}.project-img img{object-fit:cover;width:100%;height:100%;transition:transform .5s}.project-card:hover .project-img img{transform:scale(1.08)}.project-overlay{opacity:0;background:#697c70e0;justify-content:center;align-items:center;gap:1.5rem;transition:opacity .3s;display:flex;position:absolute;inset:0}.project-card:hover .project-overlay{opacity:1}.overlay-btn{cursor:pointer;border:none;border-radius:10rem;align-items:center;gap:.6rem;padding:.9rem 2rem;font-family:Poppins,sans-serif;font-size:1.3rem;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.overlay-btn-demo{color:var(--accent);background:#fff}.overlay-btn-demo:hover{background:var(--bg);transform:translateY(-2px)}.overlay-btn-github{color:#fff;background:0 0;border:2px solid #fff!important}.overlay-btn-github:hover{color:var(--accent);background:#fff;transform:translateY(-2px)}.overlay-btn-disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.project-body{flex-direction:column;flex:1;padding:2rem;display:flex}.project-tags{flex-wrap:wrap;gap:.8rem;margin-bottom:1rem;display:flex}.tag{background:var(--light);color:var(--accent);border:1px solid #c8d4ca;border-radius:10rem;padding:.3rem 1rem;font-size:1.1rem;transition:all .2s}.project-card:hover .tag{background:var(--accent);color:#fff;border-color:var(--accent)}.project-title{margin-bottom:.8rem;font-size:1.8rem;font-weight:700}.project-desc{color:#666;flex:1;font-size:1.4rem;line-height:1.7}.project-links-row{flex-wrap:wrap;gap:1.2rem;margin-top:1.8rem;display:flex}.project-link-btn{cursor:pointer;border:none;border-radius:10rem;align-items:center;gap:.5rem;padding:.7rem 1.6rem;font-family:Poppins,sans-serif;font-size:1.3rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.project-link-btn.demo{background:var(--accent);color:#fff}.project-link-btn.demo:hover{background:var(--main);transform:translateY(-2px)}.project-link-btn.github{background:var(--light);color:var(--text);border:1px solid #c8d4ca!important}.project-link-btn.github:hover{background:var(--text);color:#fff;transform:translateY(-2px)}.project-link-btn.disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.pagination{justify-content:center;align-items:center;gap:1rem;margin-top:1rem;display:flex}.page-btn{border:2px solid var(--accent);width:4.2rem;height:4.2rem;color:var(--accent);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;font-family:Poppins,sans-serif;font-size:1.6rem;font-weight:700;transition:all .3s;display:flex}.page-btn:hover{background:var(--accent);color:#fff;transform:translateY(-2px)}.page-btn.active{background:var(--accent);color:#fff;box-shadow:0 4px 15px #697c7066}.page-arrow{color:var(--accent);cursor:pointer;background:0 0;border:none;align-items:center;padding:.5rem;font-size:2rem;transition:all .2s;display:flex}.page-arrow:hover{color:var(--text)}.page-arrow:disabled{opacity:.3;cursor:not-allowed}.page-info{color:#888;margin:0 1rem;font-size:1.4rem}@media (width<=1200px){.projects-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.projects-grid{grid-template-columns:1fr}}.skills{background:#f8f6f2}.skills-groups{flex-direction:column;gap:4rem;display:flex}.skill-group-header{align-items:center;gap:1.2rem;margin-bottom:2rem;display:flex}.skill-group-header i{color:var(--accent);font-size:2.4rem}.skill-group-title{color:var(--text);font-size:2rem;font-weight:700}.skill-group-line{background:#ddd8c4;flex:1;height:1px}.skills-grid{grid-template-columns:repeat(4,1fr);gap:1.8rem;display:grid}.skill-card{border:2px solid var(--main);text-align:center;cursor:default;background:#fff;border-radius:1.2rem;flex-direction:column;align-items:center;gap:1rem;padding:2.5rem 1.5rem;transition:all .3s;display:flex}.skill-card i{font-size:4rem;transition:transform .3s}.skill-card p{color:#444;font-size:1.5rem;font-weight:600}.skill-card:hover{border-color:var(--accent);background:var(--light);transform:translateY(-8px);box-shadow:0 14px 30px #697c7040}.skill-card:hover i{transform:scale(1.15)rotate(-5deg)}@media (width<=1200px){.skills-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=991px){.skills-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=480px){.skills-grid{grid-template-columns:repeat(2,1fr)}}.education{background:var(--bg)}.timeline{max-width:900px;margin-top:1rem;padding-left:3rem;position:relative}.timeline:before{content:"";background:linear-gradient(to bottom, var(--main), var(--accent));border-radius:2px;width:2px;height:100%;position:absolute;top:0;left:0}.timeline-item{padding:0 0 4.5rem 3rem;position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-dot{background:var(--accent);border:3px solid var(--bg);width:2rem;height:2rem;box-shadow:0 0 0 3px var(--main);border-radius:50%;transition:transform .3s;position:absolute;top:.4rem;left:-1rem}.timeline-item:hover .timeline-dot{transform:scale(1.3)}.timeline-content{background:#fff;border:1px solid #e0ddd5;border-radius:1.2rem;padding:2.5rem;transition:all .3s}.timeline-item:hover .timeline-content{border-color:var(--main);transform:translate(6px);box-shadow:0 10px 30px #697c7026}.timeline-top{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.8rem;margin-bottom:1rem;display:flex}.timeline-year{color:var(--accent);letter-spacing:.1em;text-transform:uppercase;background:var(--light);border-radius:2rem;padding:.4rem 1.2rem;font-size:1.2rem;font-weight:600;display:inline-block}.timeline-gpa{color:#fff;background:var(--accent);border-radius:2rem;padding:.4rem 1.2rem;font-size:1.2rem;font-weight:700}.timeline-degree{color:var(--text);margin-bottom:.5rem;font-size:1.9rem;font-weight:700}.timeline-school{color:var(--main);align-items:center;gap:.6rem;margin-bottom:1rem;font-size:1.5rem;font-weight:600;display:flex}.timeline-school:before{content:"*";font-size:1.4rem}.timeline-desc{color:#666;font-size:1.4rem;line-height:1.7}.courses-section{margin-top:6rem}.courses-header{margin-bottom:2.5rem}.courses-header h3{margin-bottom:.5rem;font-family:Georgia,serif;font-size:2.8rem;font-weight:700}.courses-header p{color:#888;font-size:1.5rem}.courses-grid{grid-template-columns:repeat(3,1fr);gap:2rem;display:grid}.course-card{background:#fff;border:1px solid #e0ddd5;border-radius:1.2rem;flex-direction:column;gap:1.2rem;padding:2rem;transition:all .3s;display:flex}.course-card:hover{border-color:var(--main);transform:translateY(-4px);box-shadow:0 8px 24px #697c7026}.course-icon{background:var(--light);border-radius:1rem;flex-shrink:0;justify-content:center;align-items:center;width:5rem;height:5rem;display:flex}.course-icon i{font-size:3rem}.course-info h4{color:var(--text);margin-bottom:.3rem;font-size:1.6rem;font-weight:700;line-height:1.4}.course-platform{color:var(--accent);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.5rem;font-size:1.1rem;font-weight:600;display:block}.course-desc{color:#666;font-size:1.3rem;line-height:1.6}.platforms-section{margin-top:4rem}.platforms-title{color:var(--text);align-items:center;gap:1rem;margin-bottom:1.5rem;font-size:2rem;font-weight:700;display:flex}.platforms-title:after{content:"";background:#ddd8c4;flex:1;height:1px}.platforms-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:600px;display:grid}.platform-card{border:2px solid var(--main);text-align:center;background:#fff;border-radius:1.2rem;flex-direction:column;align-items:center;gap:.8rem;padding:2rem 1.5rem;transition:all .3s;display:flex}.platform-card:hover{border-color:var(--accent);background:var(--light);transform:translateY(-5px);box-shadow:0 10px 25px #697c7033}.platform-icon i{font-size:3.5rem}.platform-name{color:var(--text);font-size:1.4rem;font-weight:700}.platform-desc{color:#888;font-size:1.1rem}@media (width<=1200px){.courses-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.courses-grid{grid-template-columns:1fr}.timeline,.timeline-item{padding-left:2rem}.platforms-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=480px){.timeline-degree{font-size:1.7rem}}.contact{color:#fff;background:#1a1a1a;flex-wrap:wrap;justify-content:center;align-items:flex-start;gap:8rem;display:flex}.contact .section-label{color:var(--main)}.contact-title{color:#fff;margin-bottom:1.5rem;font-family:Georgia,serif;font-size:clamp(3.5rem,5vw,5.5rem);line-height:1.2}.contact .section-divider{background:var(--main)}.contact-info p{color:#ffffff8c;max-width:420px;margin-bottom:3rem;font-size:1.5rem;line-height:1.8}.contact-links{flex-direction:column;gap:2rem;display:flex}.contact-link{color:#ffffffa6;align-items:center;gap:1.5rem;font-size:1.5rem;transition:all .2s;display:flex}.contact-link:hover{color:var(--main);transform:translate(6px)}.contact-icon{background:#ffffff14;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:3.8rem;height:3.8rem;font-size:1.8rem;transition:all .2s;display:flex}.contact-link:hover .contact-icon{color:var(--main);background:#98aa9d33}.contact-form{flex-direction:column;flex:1;gap:1.5rem;width:100%;min-width:320px;max-width:600px;display:flex}.contact-form input,.contact-form textarea{color:#fff;resize:vertical;background:#ffffff12;border:1px solid #ffffff1f;border-radius:.6rem;outline:none;width:100%;padding:1.8rem 2rem;font-family:Poppins,sans-serif;font-size:1.5rem;transition:all .3s}.contact-form input::placeholder,.contact-form textarea::placeholder{color:#ffffff4d}.contact-form input:focus,.contact-form textarea:focus{border-color:var(--main);background:#ffffff1a}.btn-send{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:.6rem;align-self:flex-start;padding:1.2rem 2.8rem;font-family:Poppins,sans-serif;font-size:1.5rem;font-weight:600;transition:all .3s}.btn-send:hover{background:var(--main);transform:translateY(-2px);box-shadow:0 6px 20px #697c7066}.btn-send:disabled{opacity:.6;cursor:not-allowed;transform:none}.form-msg{border-radius:.6rem;padding:1rem 1.5rem;font-size:1.4rem}.form-msg.success{color:var(--main);border:1px solid var(--main);background:#98aa9d33}.form-msg.error{color:#ff8080;background:#ff646426;border:1px solid #ff6060}@media (width<=991px){.contact{flex-direction:column;align-items:center;gap:4rem}.contact-links{align-items:center}.contact-form{min-width:unset;width:100%;max-width:500px}}@media (width<=768px){.contact{padding:6rem 5%}}@media (width<=480px){.contact-title{font-size:3.5rem}}footer{background:#111;border-top:1px solid #ffffff0f;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;width:100%;padding:2rem 6%;display:flex}.footer-logo{color:var(--main);font-family:Georgia,serif;font-size:2.2rem;font-weight:700}footer p{color:#fff6;font-size:1.4rem}.footer-socials{gap:1.5rem;display:flex}.footer-socials a{color:#fff6;font-size:2.2rem;transition:all .2s}.footer-socials a:hover{color:var(--main);transform:translateY(-3px)}@media (width<=768px){footer{text-align:center;flex-direction:column}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--main:#98aa9d;--mist:#b3c9d6;--bg:#fdfcf8;--text:#2d3536;--accent:#697c70;--light:#e8ede9}html{scroll-behavior:smooth;width:100%;font-size:62.5%;overflow-x:hidden}body{background:var(--bg);color:var(--text);width:100%;font-family:Poppins,sans-serif;overflow-x:hidden}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}section{width:100%;padding:10rem 6%}.section-label{letter-spacing:3px;text-transform:uppercase;color:var(--main);margin-bottom:1rem;font-size:1.2rem;font-weight:500;display:block}.section-divider{background:var(--accent);width:50px;height:2px;margin-bottom:2.5rem}.sec-title{margin-bottom:1.5rem;font-family:Georgia,serif;font-size:clamp(4rem,5vw,7rem);font-weight:700;line-height:1.2}.btn{background:var(--accent);color:#fff;border:2px solid var(--accent);cursor:pointer;border-radius:4rem;margin-right:1rem;padding:1rem 2.8rem;font-family:Poppins,sans-serif;font-size:1.6rem;font-weight:600;transition:all .3s;display:inline-block}.btn:hover{color:var(--accent);background:0 0;transform:translateY(-2px);box-shadow:0 6px 20px #697c704d}.btn-outline{color:var(--accent);background:0 0}.btn-outline:hover{background:var(--accent);color:#fff}@media (width<=480px){section{padding:8rem 5%}}
