@import url(https://fonts.googleapis.com/css?family=Roboto:100,300,400&display=swap);*{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#fdf5df;--bg-secondary:#f8f0d0;--text-primary:#2a2a2a;--text-secondary:#5a5a5a;--accent-color:#5ebec4;--accent-secondary:#f92c85;--border-color:#e8dcc0;--shadow:0 2px 10px #5ebec433;--transition:all 0.3s ease;--code-bg:#f8f0d0;--code-text:#2a2a2a;--success-color:#5ebec4;--warning-color:#f92c85;--error-color:#f92c85}[data-theme=dark]{--bg-primary:#2a2a2a;--bg-secondary:#3a3a3a;--text-primary:#fdf5df;--text-secondary:#b8b8b8;--accent-color:#5ebec4;--accent-secondary:#f92c85;--border-color:#4a4a4a;--shadow:0 2px 10px #5ebec44d;--code-bg:#3a3a3a;--code-text:#fdf5df;--success-color:#5ebec4;--warning-color:#f92c85;--error-color:#f92c85}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fdf5df;background-color:var(--bg-primary);background-image:url('data:image/svg+xml;utf8,<svg width="80" height="80" viewBox="0 0 80 80" fill="none" xmlns="http://www.w3.org/2000/svg"><rect x="10" y="10" width="30" height="10" rx="3" fill="rgba%2894,190,196,0.09%29"/><circle cx="60" cy="20" r="3" fill="rgba%2894,190,196,0.09%29"/><rect x="50" y="50" width="20" height="8" rx="2" fill="rgba%2894,190,196,0.09%29"/><circle cx="20" cy="60" r="2" fill="rgba%2894,190,196,0.09%29"/><line x1="10" y1="10" x2="70" y2="70" stroke="rgba%2894,190,196,0.09%29" stroke-width="1.5"/><line x1="70" y1="10" x2="10" y2="70" stroke="rgba%2894,190,196,0.09%29" stroke-width="1.5"/><rect x="30" y="30" width="18" height="18" rx="4" stroke="rgba%2894,190,196,0.09%29" stroke-width="1.2"/></svg>');color:#2a2a2a;color:var(--text-primary);font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,Source Code Pro,Menlo,Consolas,DejaVu Sans Mono,Courier New,monospace;line-height:1.6;transition:all .3s ease;transition:var(--transition)}[data-theme=dark] body,body{background-attachment:fixed;background-repeat:repeat;background-size:160px 160px}[data-theme=dark] body{background-image:url('data:image/svg+xml;utf8,<svg width="80" height="80" viewBox="0 0 80 80" fill="none" xmlns="http://www.w3.org/2000/svg"><rect x="10" y="10" width="30" height="10" rx="3" fill="rgba%2894,190,196,0.06%29"/><circle cx="60" cy="20" r="3" fill="rgba%2894,190,196,0.06%29"/><rect x="50" y="50" width="20" height="8" rx="2" fill="rgba%2894,190,196,0.06%29"/><circle cx="20" cy="60" r="2" fill="rgba%2894,190,196,0.06%29"/><line x1="10" y1="10" x2="70" y2="70" stroke="rgba%2894,190,196,0.06%29" stroke-width="1.5"/><line x1="70" y1="10" x2="10" y2="70" stroke="rgba%2894,190,196,0.06%29" stroke-width="1.5"/><rect x="30" y="30" width="18" height="18" rx="4" stroke="rgba%2894,190,196,0.06%29" stroke-width="1.2"/></svg>')}html{scroll-behavior:smooth}.container{margin:0 auto;max-width:1000px;padding:0 15px}.section{align-items:center;display:flex;min-height:80vh;padding:50px 0}.section-title{color:#2a2a2a;color:var(--text-primary);font-size:2rem;font-weight:700;margin-bottom:1.5rem;position:relative;text-align:center}.section-title:before{color:#5ebec4;color:var(--accent-color);content:"//";font-weight:400;margin-right:1rem}.section-subtitle{color:#5a5a5a;color:var(--text-secondary);font-size:1rem;margin-bottom:2rem;text-align:center}.btn{border:none;border-radius:6px;cursor:pointer;display:inline-block;font-family:inherit;font-size:.9rem;font-weight:600;padding:10px 20px;text-decoration:none;transition:all .3s ease;transition:var(--transition)}.btn-primary{background-color:#5ebec4;background-color:var(--accent-color);border:1px solid #5ebec4;border:1px solid var(--accent-color);color:#fff}.btn-primary:hover{background-color:initial;color:#5ebec4;color:var(--accent-color);transform:translateY(-2px)}.btn-primary:hover,.card{box-shadow:0 2px 10px #5ebec433;box-shadow:var(--shadow)}.card{background-color:#f8f0d0;background-color:var(--bg-secondary);border:1px solid #e8dcc0;border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;transition:all .3s ease;transition:var(--transition)}.card:hover{border-color:#5ebec4;border-color:var(--accent-color);box-shadow:0 4px 20px #5ebec44d;transform:translateY(-5px)}.code-block{background-color:#f8f0d0;border:1px solid #e8dcc0;color:#2a2a2a;color:var(--code-text);overflow-x:auto;padding:1rem}.code-comment{color:#5a5a5a;color:var(--text-secondary);font-style:italic}.code-keyword{color:#5ebec4;color:var(--accent-color);font-weight:600}.code-string{color:#f92c85;color:var(--accent-secondary)}.code-number{color:#5ebec4;color:var(--accent-color)}@media (max-width:768px){.section{min-height:70vh;padding:40px 0}.section-title{font-size:1.5rem}.container{padding:0 10px}}.navbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:var(--bg-primary);border-bottom:1px solid var(--border-color);left:0;position:fixed;right:0;top:0;transition:var(--transition);z-index:1000}.navbar .container{align-items:center;display:flex;justify-content:space-between;padding:1rem 20px}.nav-brand h2{color:var(--accent-color);font-family:SF Mono,Monaco,Inconsolata,monospace;font-weight:700;margin:0}.nav-menu{align-items:center;display:flex;gap:2rem}.nav-link{color:var(--text-primary);font-family:SF Mono,Monaco,Inconsolata,monospace;font-size:.9rem;font-weight:500;letter-spacing:.5px;position:relative;text-decoration:none;text-transform:uppercase;transition:var(--transition)}.nav-link:hover{color:var(--accent-color)}.nav-link:after{background-color:var(--accent-color);bottom:-5px;content:"";height:2px;left:0;position:absolute;transition:var(--transition);width:0}.nav-link:hover:after{width:100%}.nav-actions{align-items:center;display:flex;gap:1rem}.theme-toggle{background:none;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:1.2rem;padding:.5rem;transition:var(--transition)}.theme-toggle:hover{background-color:var(--accent-color);border-color:var(--accent-color);color:#fff}.hamburger{background:none;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);cursor:pointer;display:none;font-size:1.2rem;padding:.5rem;transition:var(--transition)}.hamburger:hover{background-color:var(--accent-color);border-color:var(--accent-color);color:#fff}@media (max-width:768px){.hamburger{display:block}.nav-menu{background-color:var(--bg-primary);border-bottom:1px solid var(--border-color);flex-direction:column;gap:1.5rem;left:0;opacity:0;padding:2rem;position:fixed;right:0;top:70px;transform:translateY(-100%);transition:var(--transition);visibility:hidden}.nav-menu.active{opacity:1;transform:translateY(0);visibility:visible}.nav-link{font-size:1rem;padding:.5rem 0}}.about-content{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr}.code-header{font-size:1.2rem}.hero-title{align-items:center;color:var(--text-primary);display:flex;flex-wrap:wrap;font-family:SF Mono,Monaco,Inconsolata,monospace;font-size:2.5rem;font-weight:600;gap:.5rem;line-height:1.2;margin-bottom:1rem}.hero-subtitle{font-size:1.5rem;font-weight:500;margin-bottom:1.5rem}.hero-description,.hero-subtitle{color:var(--text-secondary);font-family:SF Mono,Monaco,Inconsolata,monospace}.hero-description{font-size:1.1rem;line-height:1.7;margin-bottom:2rem}.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}.btn-secondary{align-items:center;background-color:initial;border:2px solid var(--border-color);color:var(--text-primary);display:flex;gap:.5rem}.btn-secondary:hover{background-color:var(--bg-secondary);border-color:var(--accent-secondary);color:var(--accent-secondary)}.social-links{display:flex;gap:1rem}.social-links a{align-items:center;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);display:flex;font-size:1.2rem;height:45px;justify-content:center;text-decoration:none;transition:var(--transition);width:45px}.social-links a:hover{background-color:var(--accent-color);border-color:var(--accent-color);color:#fff;transform:translateY(-2px)}.about-image{align-items:flex-start;height:100%;padding-top:1rem;width:100%}.about-image,.image-container{display:flex;justify-content:center}.image-container{align-items:center;border:2px solid var(--border-color);border-radius:8px;box-shadow:var(--shadow);height:300px;overflow:hidden;position:relative;transform:translateY(-10px);transition:var(--transition);width:300px}.image-container:hover{border-color:var(--accent-color);box-shadow:0 4px 20px #5ebec44d;transform:translateY(-15px)}.profile-image{height:100%;object-fit:cover;transition:var(--transition);width:100%}.image-container:hover .profile-image{transform:scale(1.05)}.code-block{font-size:.9rem;line-height:1.6;margin-bottom:2rem;padding:1.5rem}.code-block div{margin-bottom:.5rem}@media (max-width:768px){.about-content{gap:2rem;grid-template-columns:1fr;text-align:left}.hero-title{font-size:2rem}.hero-subtitle{font-size:1.3rem}.hero-actions,.social-links{justify-content:flex-start}.about-image{padding-top:.5rem}.image-container{height:250px;transform:translateY(-5px);width:250px}.image-container:hover{transform:translateY(-10px)}.code-block{font-size:.8rem;padding:1rem}}.education-timeline{margin:0 auto;max-width:700px;position:relative}.education-timeline:before{background-color:var(--accent-color);bottom:0;content:"";left:50%;position:absolute;top:0;transform:translateX(-50%);width:2px}.education-item{margin-bottom:2rem;position:relative}.timeline-marker{background-color:var(--accent-color);border-radius:50%;height:16px;left:50%;position:absolute;top:1.5rem;transform:translateX(-50%);width:16px;z-index:2}.education-card{margin-left:58%;padding:1.2rem;position:relative;width:42%}.education-item:nth-child(2n) .education-card{margin-left:0;margin-right:58%}.education-header{align-items:center;display:flex;gap:.8rem;margin-bottom:.8rem}.education-icon{align-items:center;background-color:var(--accent-color);border-radius:6px;color:#fff;display:flex;flex-shrink:0;font-size:1rem;height:40px;justify-content:center;width:40px}.education-info h3{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin-bottom:.3rem}.education-info p{color:var(--text-secondary);font-size:.9rem}.education-details{display:flex;flex-wrap:wrap;gap:.8rem;margin-bottom:.8rem}.detail-item{align-items:center;color:var(--text-secondary);display:flex;font-size:.8rem;gap:.4rem}.detail-item svg,.gpa{color:var(--accent-color)}.gpa{font-weight:600}.education-description{color:var(--text-secondary);font-size:.85rem;line-height:1.5}@media (max-width:768px){.education-timeline:before,.timeline-marker{left:15px}.education-card{margin-left:40px;padding:1rem;width:calc(100% - 40px)}.education-item:nth-child(2n) .education-card{margin-left:40px;margin-right:0}.education-header{flex-direction:column;gap:.5rem;text-align:center}.education-details{justify-content:center}}.skills-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(3,1fr);margin-top:1.5rem}.skill-category{padding:1.5rem;transition:var(--transition)}.category-header{align-items:center;display:flex;gap:1rem;margin-bottom:1.2rem}.category-icon{align-items:center;background-color:var(--accent-color);border-radius:6px;color:#fff;display:flex;flex-shrink:0;font-size:1.2rem;height:45px;justify-content:center;width:45px}.category-title{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin:0}.skills-list{display:flex;flex-wrap:wrap;gap:.6rem}.skill-item{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;padding:.4rem .8rem;transition:var(--transition)}.skill-item:hover{background-color:var(--accent-color);border-color:var(--accent-color);transform:translateY(-2px)}.skill-name{color:var(--text-primary);font-size:.8rem;font-weight:500;transition:var(--transition)}.skill-item:hover .skill-name{color:#fff}@media (max-width:768px){.skills-grid{gap:1rem;grid-template-columns:1fr}.skill-category{padding:1.2rem}.category-header{flex-direction:column;gap:.5rem;text-align:center}.skills-list{justify-content:center}}.certificates-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr);margin-top:1rem}.certificate-card{overflow:hidden;transition:var(--transition)}.certificate-image{border-radius:8px 8px 0 0;height:150px;overflow:hidden;position:relative}.certificate-image img{height:100%;object-fit:cover;transition:var(--transition);width:100%}.certificate-overlay{align-items:center;background:#5ebec4cc;bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:var(--transition)}.certificate-card:hover .certificate-overlay{opacity:1}.certificate-icon{color:#fff;font-size:2.5rem}.certificate-content{padding:1rem}.certificate-title{color:var(--text-primary);font-size:1rem;font-weight:600;margin-bottom:.4rem}.certificate-issuer{color:var(--accent-color);font-weight:500;margin-bottom:.6rem}.certificate-meta{display:flex;gap:1rem;margin-bottom:.6rem}.meta-item{align-items:center;color:var(--text-secondary);display:flex;font-size:.8rem;gap:.5rem}.meta-item svg{color:var(--accent-color)}.certificate-description{color:var(--text-secondary);font-size:.85rem;line-height:1.4;margin-bottom:1rem}.certificate-link{align-items:center;color:var(--accent-color);display:flex;font-weight:500;gap:.5rem;text-decoration:none;transition:var(--transition)}.certificate-link:hover{color:var(--text-primary)}.certificate-card:hover{transform:translateY(-3px)}.certificate-card:hover .certificate-image img{transform:scale(1.05)}@media (max-width:768px){.certificates-grid{gap:.8rem;grid-template-columns:1fr}.certificate-content{padding:.8rem}.certificate-title{font-size:.9rem}.certificate-image{height:140px}}.projects-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:1.5rem}.project-card{border:1px solid var(--border-color);overflow:hidden;position:relative;transition:var(--transition)}.project-card.featured{border:2px solid var(--accent-color)}.project-image{height:200px;overflow:hidden;padding-top:2.2rem;position:relative}.project-image img{height:100%;object-fit:cover;transition:var(--transition);width:100%}.project-overlay{align-items:center;background:#fdf5dfe6;bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:var(--transition)}.project-card:hover .project-overlay{opacity:1}.project-links{display:flex;gap:1rem}.project-links a{align-items:center;background-color:var(--accent-color);border:1px solid var(--accent-color);border-radius:6px;color:#fff;display:flex;font-size:1.1rem;height:45px;justify-content:center;text-decoration:none;transition:var(--transition);width:45px}.project-links a:hover{background-color:initial;color:var(--accent-color);transform:scale(1.1)}.featured-badge{background-color:var(--accent-secondary);color:#fff;font-size:.7rem;font-weight:600;gap:.4rem;padding:.4rem .8rem;right:.8rem;top:.8rem}.featured-badge,.project-category{align-items:center;border-radius:6px;display:flex;font-family:SF Mono,Monaco,Inconsolata,monospace;position:absolute}.project-category{background-color:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);font-size:.6rem;font-weight:500;gap:.3rem;left:.3rem;padding:.3rem .6rem;text-transform:uppercase;top:.3rem}.project-category svg{color:var(--accent-color);font-size:.7rem}.project-content{margin-top:1.5rem;padding:1.2rem}.project-title{color:var(--text-primary);font-family:SF Mono,Monaco,Inconsolata,monospace;font-size:1.1rem;font-weight:600;margin-bottom:.8rem;margin-top:.5rem}.project-description{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin-bottom:1.2rem}.project-technologies{display:flex;flex-wrap:wrap;gap:.4rem}.tech-tag{background-color:var(--code-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--code-text);font-family:SF Mono,Monaco,Inconsolata,monospace;font-size:.7rem;font-weight:500;padding:.2rem .6rem;transition:var(--transition)}.tech-tag:hover{background-color:var(--accent-color);border-color:var(--accent-color);color:#fff}.project-card:hover{border-color:var(--accent-color);transform:translateY(-3px)}.project-card:hover .project-image img{transform:scale(1.05)}@media (max-width:768px){.projects-grid{gap:1rem;grid-template-columns:1fr}.project-content{padding:1rem}.project-title{font-size:1rem}.project-image{height:180px}.project-category{font-size:.5rem;padding:.2rem .5rem}}.contact-content{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:1fr 1fr;margin-top:1.5rem}.code-header{font-size:1.1rem}.code-header,.contact-info h3{font-family:SF Mono,Monaco,Inconsolata,monospace;margin-bottom:1rem}.contact-info h3{color:var(--text-primary);font-size:1.5rem;font-weight:600}.contact-info p{color:var(--text-secondary);font-size:1rem;line-height:1.6;margin-bottom:1.5rem}.contact-details{display:flex;flex-direction:column;gap:1.2rem}.contact-item{gap:1rem}.contact-icon,.contact-item{align-items:center;display:flex}.contact-icon{background-color:var(--accent-color);border:1px solid var(--accent-color);border-radius:6px;color:#fff;flex-shrink:0;font-size:1.1rem;height:45px;justify-content:center;width:45px}.contact-text h4{color:var(--text-primary);font-family:SF Mono,Monaco,Inconsolata,monospace;font-size:1rem;font-weight:600;margin-bottom:.3rem}.contact-text p{color:var(--text-secondary);font-size:.9rem;margin:0}.contact-form-container{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:var(--shadow);padding:1.5rem}.form-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem}.form-icon{color:var(--accent-color);font-size:1.3rem}.form-header h3{color:var(--text-primary);font-family:SF Mono,Monaco,Inconsolata,monospace;font-size:1.3rem;font-weight:600;margin:0}.contact-form{gap:1.2rem}.contact-form,.form-group{display:flex;flex-direction:column}.form-group input,.form-group textarea{background-color:var(--bg-primary);border:2px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-family:inherit;font-size:.9rem;padding:.8rem;transition:var(--transition)}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #5ebec41a;outline:none}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-secondary)}.submit-btn{align-items:center;display:flex;font-family:SF Mono,Monaco,Inconsolata,monospace;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;margin-top:.8rem;padding:.8rem 1.5rem}.submit-btn:hover{box-shadow:0 4px 15px #5ebec44d;transform:translateY(-2px)}.code-block{background-color:var(--code-bg);border:1px solid var(--border-color);border-radius:6px;font-family:SF Mono,Monaco,Inconsolata,monospace;font-size:.8rem;line-height:1.5;margin-bottom:1.5rem;padding:1.2rem}.code-block div{margin-bottom:.4rem}.code-block div:last-child{margin-bottom:0}@media (max-width:768px){.contact-content{gap:1.5rem;grid-template-columns:1fr}.contact-info{text-align:left}.contact-item{justify-content:flex-start}.contact-form-container{padding:1.2rem}.contact-info h3{font-size:1.3rem}.contact-info p{font-size:.9rem}.code-block{font-size:.7rem;padding:1rem}}.loading-screen{align-items:center;background-color:var(--bg-primary);display:flex;font-family:Roboto,sans-serif;font-size:1rem;height:100vh;justify-content:center;left:0;line-height:1.5;overflow:hidden;position:fixed;top:0;width:100vw;z-index:9999}#container{position:relative;transform:scale(.725)}.divider{background:var(--bg-primary);height:15px;left:200px;position:absolute;top:65px;width:50px;z-index:2}.loading-text{font-size:3.75rem;font-weight:300;margin:0;position:relative;white-space:nowrap}.loading-text:before{animation:dotMove 1.8s cubic-bezier(.25,.25,.75,.75) infinite;background:var(--text-primary);border-radius:50%;content:"";height:6px;left:115px;position:absolute;top:40px;width:6px;z-index:1}.loading-text .letter{color:var(--text-primary);display:inline-block;letter-spacing:8px;position:relative}.loading-text .letter:first-child{transform:scaleY(1.275);transform-origin:100% 70%}.loading-text .letter:first-child:before{animation:lineStretch 1.8s cubic-bezier(.25,.25,.75,.75) infinite;background:var(--bg-primary);content:"";height:36px;left:0;position:absolute;top:22px;transform-origin:100% 0;width:14px}.loading-text .letter:nth-child(5){animation:letterStretch 1.8s cubic-bezier(.25,.23,.73,.75) infinite;transform-origin:100% 70%}.loading-text .letter:nth-child(5):before{background:var(--bg-primary);content:"";height:15px;left:2px;position:absolute;top:15px;width:9px}@keyframes dotMove{0%,to{transform:rotate(180deg) translate(-110px,-10px) rotate(-180deg)}50%{transform:rotate(0deg) translate(-111px,10px) rotate(0deg)}}@keyframes letterStretch{0%,to{transform:scaleY(.35);transform-origin:100% 75%}28%,8%{transform:scaleY(2.125);transform-origin:100% 67%}37%{transform:scaleY(.875);transform-origin:100% 75%}46%{transform:scaleY(1.03);transform-origin:100% 75%}50%,97%{transform:scale(1);transform-origin:100% 75%}}@keyframes lineStretch{0%,45%,70%,to{transform:scaleY(.125)}49%{transform:scaleY(.75)}50%{transform:scaleY(.875)}53%{transform:scaleY(.5)}60%{transform:scaleY(0)}68%{transform:scaleY(.18)}}@media (min-width:48rem){#container{transform:scale(.725rem)}}@media (min-width:62rem){#container{transform:scale(.85)}}.portfolio-subtitle{color:var(--text-secondary);font-size:1.2rem;font-weight:300;letter-spacing:2px;margin-top:20px;opacity:.8;text-align:center}.App{min-height:100vh}main{padding-top:80px}@media (max-width:768px){main{padding-top:70px}}
/*# sourceMappingURL=main.380898e4.css.map*/