:root{font-family:Arial,sans-serif;line-height:1.5}body{margin:0;background-color:transparent}.container{position:relative;width:100%;height:100%;overflow:hidden}::-webkit-scrollbar{display:none}::selection{background-color:#add8e6;color:inherit}:root.dark ::selection{background-color:gray;color:inherit}.container{position:relative;height:100dvh;width:100%}.mobile-app1-container{height:100vh;width:100%;overflow-y:auto;background:radial-gradient(circle at top right,#fff,#add8e6,#89cff0);color:#000;transition:background-color .3s ease,color .3s ease;-webkit-overflow-scrolling:touch}.dark .mobile-app1-container{background-color:#1a1a1a;color:#fff}@media (max-width: 768px){.app1-overlay{mask-image:none!important;-webkit-mask-image:none!important;background:#fff!important;transition:background-color .3s ease,color .3s ease;will-change:scroll-position}.mobile-app1-container,.app1-scrollable{scroll-behavior:auto}.dark .app1-overlay{background:#1a1a1a!important;color:#fff}.dark .project-card{background:#0003;color:#fff}.dark .tech-section{background-color:#2a2a2a;color:#fff}.dark .quote-container{background-color:#0003;color:#fff}.dark .github-link{color:#fff;background:#ffffff1a}.dark .tech-card{background:#0003}.peek-circle,.app2-container{display:none!important}}.profile-image{width:150px;height:150px;border-radius:50%;object-fit:cover;border:4px solid rgba(255,255,255,.2)}@media (max-width: 768px){.intro-title{font-size:2rem;line-height:1.2}.intro-subtitle{font-size:1.5rem}.intro-description{font-size:1rem;padding:0 .5rem;margin-bottom:2rem;line-height:1.6}.intro-section{flex-direction:column;padding:1rem 0!important;min-height:auto}.intro-content-side{width:100%;padding:1rem;min-height:80vh;display:flex;align-items:center}.intro-quote-side{display:none}.intro-section .content-wrapper{text-align:center;width:100%;max-width:100%}.profile-title-container{flex-direction:column;align-items:center;text-align:center;gap:0rem}.profile-image{width:120px;height:120px;margin-bottom:1rem}}@media (max-width: 480px){.intro-title{font-size:1.75rem}.intro-description{font-size:.9rem}.profile-image{width:100px;height:100px}}.project-section{display:flex;flex-direction:column;overflow:hidden}.project-info,.project-display-container{width:100%;display:flex;flex-direction:column;align-self:flex-start}.project-info{height:80dvh;overflow-y:auto;overflow-x:hidden;padding:1rem;border-radius:20px;order:2;background-color:#ffffff1a;box-shadow:0 15px 25px #0000004d}.project-display-container{height:auto;order:1}.project-model-view{width:100%;height:50vh;min-height:300px;position:relative;overflow:visible}.project-model-view canvas{width:100%!important;height:100%!important;max-width:100%;max-height:100%;object-fit:contain}.project-carousel-container{width:75dvw;height:auto;overflow-x:auto;display:flex;align-items:center;position:relative;margin-bottom:1rem;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;transform:translate(-2rem)}.dark .project-info{background-color:#23231c80;box-shadow:0 15px 25px #313131e6}@media screen and (max-width: 768px){.project-section{padding:.5rem;gap:.5rem}.project-info{max-height:40vh;padding:.5rem;width:95%}.project-model-view{min-height:30%;max-height:50%;height:40%;position:relative}.project-carousel-container{width:100dvw;height:auto;margin-bottom:.5rem}}@media screen and (min-width: 769px) and (max-width: 1024px){.project-section{padding:.75rem}.project-info{max-height:50dvh;width:95%}.project-model-view{min-height:40%;max-height:50%;height:45%}.project-carousel-container{width:100dvw}}@media screen and (min-width: 1025px){.project-section{flex-direction:row;padding:1rem;gap:1rem}.project-info{order:1;width:25%;max-height:100%;margin-right:1rem}.project-display-container{order:2;width:calc(75% - 1rem);flex-direction:column}.project-carousel-container{height:15%;margin-bottom:1rem}.project-model-view{height:85%;max-height:none}}@media screen and (max-width: 480px){.project-section{padding:.25rem}.project-info{max-height:30vh}.project-model-view{min-height:25vh;max-height:40vh}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tech-stack-section{position:relative;overflow:hidden;padding:4rem 2rem!important}.dark .tech-section{background-color:#2a2a2a;color:#fff}.dark .cert-section{background:#0003;color:#fff}@media (max-width: 768px){.tech-container{padding:1rem;min-height:auto}.tech-grid{grid-template-columns:1fr;gap:1rem}.card-header h3{font-size:1.125rem}.card-content{padding-left:1rem;font-size:.9rem}.card-content p{margin-bottom:.25rem}.cert-section{display:none}.tech-stack-section{padding:2rem 1rem!important;min-height:auto}.tech-section{margin-top:2rem;padding:1.5rem}.section-title{font-size:1.5rem;margin-bottom:1.5rem}.tech-card{padding:1rem}}@media (max-width: 480px){.tech-stack-section{padding:1rem .5rem!important}.tech-section{padding:1rem;border-radius:.75rem}.card-header h3{font-size:1rem}.card-content{font-size:.85rem;padding-left:.5rem}}.app1-container{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100vh;overflow:hidden}.app1-scrollable{height:100vh;overflow-y:auto;position:relative;z-index:1}.app1-overlay{position:relative;background:radial-gradient(circle at top right,#fff,#add8e6,#89cff0);color:#000;mask-image:radial-gradient(circle at var(--x) var(--y),transparent var(--circle-size),black 0px);-webkit-mask-image:radial-gradient(circle at var(--x) var(--y),transparent var(--circle-size),black 0px)}.hoverable{position:relative;z-index:2}.peek-circle{position:fixed;width:100px;height:100px;border-radius:50%;border:0 solid white;pointer-events:none;z-index:10}.app1-container .section{min-height:100vh;scroll-snap-align:start;display:flex;align-items:center;justify-content:center;padding:2rem}.section-title{font-size:2rem;font-weight:700;text-align:center;margin-bottom:2rem}@media (max-width: 768px){.app1-container .section{scroll-snap-align:none}.app1-scrollable{scroll-behavior:auto;-webkit-overflow-scrolling:auto}.section-title{font-size:1.75rem}}.dark .app1-overlay{background:radial-gradient(circle at top right,#2a2a2a,#1a1a1a);color:#fff}.dark .navigation-bar{background-color:#0000004d}.dark .github-icon svg{fill:#ffffffb3}.dark .dot.active{background:#d3d3d3}.navigation-bar{position:fixed;top:1rem;left:50%;transform:translate(-50%);z-index:5;padding:.35rem 1.5rem;border-radius:35px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background-color:#00c8fa1a;box-shadow:0 4px 6px #0000001a;display:flex;align-items:center;gap:1.5rem;max-width:90%;width:auto;overflow:hidden}.progress-bar{position:absolute;left:0;top:0;height:100%;background-color:#ffffff4d;z-index:-1;transition:width .3s ease-out;border-radius:35px}.dark .progress-bar{background-color:#fff3}.navigation-bar button,.navigation-bar a{color:#000000b3;text-decoration:none;background:none;border:none;font-size:1rem;cursor:pointer;transition:color .3s ease;padding:.25rem .5rem;z-index:1}.navigation-bar button:hover,.navigation-bar a:hover{color:#000}.github-icon svg{width:1.5rem;height:1.5rem;fill:currentColor}.dark .navigation-bar button,.dark .navigation-bar a{color:#ffffffb3}.dark .navigation-bar button:hover,.dark .navigation-bar a:hover{color:#fff}@media (max-width: 640px){.navigation-bar{padding:.2rem 1rem;gap:1rem;top:.5rem}.navigation-bar button,.navigation-bar a{font-size:.875rem;padding:.2rem .4rem}.github-icon svg{width:1.25rem;height:1.25rem}}@media (max-width: 380px){.navigation-bar{padding:.15rem .75rem;gap:.5rem}.navigation-bar button,.navigation-bar a{font-size:.75rem;padding:.15rem .3rem}}.overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:1rem;z-index:6}.contact-modal{background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:1rem;padding:2rem;max-width:42rem;width:100%;position:relative}.dark .contact-modal{background:#1e1e1ee6;color:#fff}.success-modal{background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:1rem;padding:2rem;max-width:24rem;width:100%;position:relative;text-align:center}.dark .success-modal{background:#1e1e1ee6;color:#fff}.close-button{position:absolute;top:1rem;right:1rem;background:none;border:none;cursor:pointer;padding:.5rem}.close-button svg{width:1.5rem;height:1.5rem;stroke:#0009;transition:stroke .3s ease}.dark .close-button svg{stroke:#fff9}.close-button:hover svg{stroke:#000000e6}.dark .close-button:hover svg{stroke:#ffffffe6}.modal-header{text-align:center;margin-bottom:2rem}.modal-header h2{font-size:1.5rem;font-weight:700;margin:0 0 .5rem}.modal-header p{margin:0;color:#0009}.dark .modal-header p{color:#fff9}.error-alert{display:flex;align-items:center;gap:.5rem;background:#ff00001a;padding:1rem;border-radius:.5rem;margin-bottom:1.5rem}.dark .error-alert{background:#f003}.error-alert svg{width:1rem;height:1rem;flex-shrink:0}.contact-form{display:flex;flex-direction:column;gap:1.5rem}.form-row{display:flex;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.25rem;flex:1}.form-group label{font-size:.875rem;font-weight:500}.form-group input,.form-group textarea{padding:.75rem 1rem;border:1px solid rgba(0,0,0,.2);border-radius:.5rem;background:#ffffff80;transition:all .3s ease}.dark .form-group input,.dark .form-group textarea{border:1px solid rgba(255,255,255,.2);background:#32323280;color:#fff}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#0000004d;background:#fffc}.dark .form-group input:focus,.dark .form-group textarea:focus{border-color:#ffffff4d;background:#3c3c3ccc}.form-group textarea{resize:none;min-height:12rem}.submit-button{display:flex;align-items:center;justify-content:center;gap:.5rem;background:#000c;color:#fff;padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .3s ease}.dark .submit-button{background:#fffc;color:#000}.submit-button:hover:not(:disabled){background:#000000e6}.dark .submit-button:hover:not(:disabled){background:#ffffffe6}.submit-button:disabled{opacity:.5;cursor:not-allowed}.send-icon{width:1rem;height:1rem}.success-content{display:flex;flex-direction:column;align-items:center}.success-icon{width:4rem;height:4rem;stroke:#10b981;margin-bottom:1rem}.success-content h2{font-size:1.5rem;font-weight:700;margin:0 0 .5rem}.success-content p{margin:0;color:#0009}.dark .success-content p{color:#fff9}.hidden-iframe{display:none}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.contact-modal,.success-modal{animation:slideUp .5s cubic-bezier(.36,.66,.04,1) forwards;transform-origin:center;opacity:0}@keyframes overlayFadeIn{0%{background:#0000}to{background:#00000080}}.dark @keyframes overlayFadeIn{from{background:#0000}to{background:#000000b3}}.overlay{animation:overlayFadeIn .3s ease-out forwards}@media (max-width: 640px){.contact-modal{padding:1.5rem}.form-row{flex-direction:column}.form-group textarea{min-height:10rem}.modal-header h2{font-size:1.25rem}}.social-icons-container{display:flex;gap:1.5rem;margin-top:2rem;align-items:center;justify-content:center;opacity:0}.social-icon-link{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:50%;background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .3s ease;opacity:0;position:relative;overflow:hidden;border:none}.social-icon{width:1.25rem;height:1.25rem;transition:transform .3s ease}.animate-slide-up{animation:slideUp .6s ease forwards}.animate-pop{animation:pop .5s ease forwards;animation-delay:var(--delay)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pop{0%{opacity:0;transform:scale(0)}70%{opacity:1;transform:scale(1.1)}to{opacity:1;transform:scale(1)}}@media (max-width: 768px){.social-icons-container{gap:1rem}.social-icon-link{width:2rem;height:2rem}.social-icon{width:1rem;height:1rem}}.project-carousel{display:flex;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;z-index:5;cursor:grab;pointer-events:auto;scroll-behavior:smooth;transition:opacity .3s ease;padding-bottom:1%}.project-carousel.transitioning{pointer-events:none;opacity:.9}.project-carousel::-webkit-scrollbar{display:none}.project-carousel:active{cursor:grabbing}.project-carousel .project-card{flex:0 0 auto;width:20%;height:10%;background:#ffffff26;border-color:#ffffff59;z-index:6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:12px;padding:1%;margin:0 5px;cursor:pointer;transition:all .4s cubic-bezier(.175,.885,.32,1.275);transform:translateY(0);-webkit-user-select:none;user-select:none;overflow:hidden}.project-carousel .project-card.active{background:#add8e6e6;transform:translateY(8px);transition:all .5s cubic-bezier(.175,.885,.32,1.275)}.project-carousel .project-card:hover:not(.active){transform:translateY(8px);transition:transform .3s ease}.project-carousel .project-title{font-size:1.1rem;font-weight:600;margin-bottom:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-carousel .project-summary{font-size:.8rem;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4}@media (max-width: 1024px){.project-carousel{padding:15px}.project-carousel .project-card{width:220px;height:140px}.project-carousel .project-card.active{transform:translateY(15px) scale(1.05);background:#add8e6e6}}.dark .project-carousel .project-card.active{background:#1a1a024d;box-shadow:0 4px 15px #0000001a}@media (max-width: 768px){.project-carousel{position:relative;bottom:auto;padding:10px;margin-top:10px}.project-carousel .project-card{width:180px;height:130px;padding:12px;background:#add8e6e6}.dark .project-carousel .project-card{background:#ffffff26}.project-carousel .project-card.active{transform:translateY(15px) scale(1.05);background:#ffffff26}.project-carousel .project-title{font-size:.95rem;margin-bottom:8px}.project-carousel .project-summary{font-size:.75rem;margin-bottom:10px}}@media (max-width: 480px){.project-carousel .project-card{width:160px;height:120px;padding:10px}}.project-details{width:100%;height:100%;position:relative;z-index:2;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column}.details-title{font-size:1.5rem;-webkit-background-clip:text;background-clip:text}.details-content{display:flex;flex-direction:column;gap:1.5rem;flex:1}.details-summary{flex:1}.details-summary h3{font-size:1.25rem;font-weight:600}.details-summary p{font-size:1rem;line-height:1.6;margin-bottom:1.5rem}.links-container{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}.link-button{display:flex;align-items:center;gap:.5rem;background:#ffffff1f;border-radius:6px;padding:.5rem 1rem;font-size:.85rem;font-weight:500;text-decoration:none;color:inherit;border:1px solid rgba(255,255,255,.2);transition:all .3s ease}.link-button:hover{background:#fff3;transform:translateY(-2px);box-shadow:0 2px 8px #0000001a}.tags-container{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.details-tag{background:#ffffff1f;border-radius:4px;padding:.4rem .8rem;font-size:.85rem;font-weight:500;border:1px solid rgba(255,255,255,.2);transition:all .3s ease}.details-tag:hover{background:#fff3;transform:translateY(-2px);box-shadow:0 2px 8px #0000001a}.details-features ul{list-style-type:none;padding:0;margin:0}.details-features li{position:relative;padding-left:1.5rem;margin-bottom:.75rem;font-size:.95rem}.details-features li:before{content:"→";position:absolute;left:0}@media (min-width: 769px) and (max-width: 1024px){.project-details{padding:1.5rem;width:85vw;overflow-x:hidden}.details-title{font-size:1.75rem;margin-bottom:1.25rem}}@media (max-width: 768px){.project-details{padding:1.25rem;height:auto;max-height:100%;width:90%}.details-title{font-size:1.5rem;margin-bottom:1rem}.details-summary h3{font-size:1.1rem}.details-features li{font-size:.9rem;margin-bottom:.5rem}.links-container{gap:.5rem}.link-button{padding:.4rem .8rem;font-size:.8rem}}.intro-section .content-wrapper{display:flex;flex-direction:column;align-items:center;text-align:left;z-index:4}.intro-title{font-size:3rem;font-weight:700;vertical-align:middle}.intro-description{font-size:1.25rem;max-width:42rem;margin-bottom:3rem;padding:0 1rem}.intro-section{display:flex;min-height:100vh;padding:0!important;overflow:hidden}.intro-content-side,.intro-quote-side{width:50%;display:flex;align-items:center;justify-content:center;padding:2rem}.profile-title-container{display:flex;align-items:center;gap:2rem}.profile-image{width:150px;height:150px;border-radius:50%;object-fit:cover;border:4px solid rgba(0,0,0,.1)}@media (max-width: 768px){.intro-title{font-size:2.5rem}.intro-description{font-size:1rem}.intro-section{flex-direction:column}.intro-content-side{width:100%;padding:1rem}.intro-quote-side{display:none}.intro-section .content-wrapper{text-align:center}.profile-title-container{flex-direction:column;align-items:center;text-align:center;gap:0rem}}.project-section,.tech-stack-section{position:relative;overflow:hidden;padding:4rem 2rem!important}.tech-container{min-height:100vh;padding:2rem}.content-wrapper{display:flex;gap:2rem;margin:0 auto}.tech-section{flex:0 0 70%;background-color:#cfe8f1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:1rem;padding:2rem;margin-top:8rem;box-shadow:0 15px 25px #0000004d;transition:transform .3s ease,background-color .9s ease,box-shadow .9s ease}.tech-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}.tech-card{background:#ffffff0d;border-radius:.5rem;padding:1.5rem}.card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.card-header svg{width:1.5rem;height:1.5rem}.card-header h3{font-size:1.25rem;font-weight:600}.card-content{padding-left:2rem}.card-content p{margin-bottom:.5rem}.cert-section{flex:0 0 20%;background:#ffffff1a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:1rem;padding:1rem;margin-top:8rem;box-shadow:0 15px 25px #0000004d;height:fit-content;transition:transform .3s ease,background-color .9s ease,box-shadow .9s ease}.cert-carousel{position:relative;width:100%;height:300px;margin-bottom:1rem}.cert-card{position:relative;width:100%;height:250px;border-radius:.5rem;overflow:hidden;cursor:pointer;opacity:1;transition:opacity .3s ease-in-out}.cert-card.transitioning{opacity:.5;transition:opacity .3s ease-in-out}.cert-card img{width:100%;height:100%;object-fit:contain}.skills-overlay{position:absolute;background-color:#fff;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;padding:1rem;overflow-y:auto}.skills-overlay h3{font-size:1.125rem;font-weight:600;margin-bottom:1rem;text-align:center}.skills-container{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;padding-bottom:.5rem}.skill-tag{background:#60a5fa80;padding:.25rem .75rem;border-radius:9999px;font-size:.875rem}.carousel-dots{display:flex;justify-content:center;gap:.5rem;position:absolute;bottom:0;left:0;right:0}.dot{width:.5rem;height:.5rem;border-radius:50%;background:#ffffff4d;border:none;padding:0;cursor:pointer;transition:background-color .3s ease}.dot.active{background:#60a5fa}@media (max-width: 768px){.tech-stack-section{padding:2rem 1rem!important}.tech-container{padding:1rem}.tech-grid{grid-template-columns:1fr}.section-title{font-size:1.75rem}.card-header h3{font-size:1.125rem}.cert-section{display:none}}@media (max-width: 1024px){.content-wrapper{flex-direction:column}.tech-section,.cert-section{flex:1}}.dark .tech-section{background-color:#2a2a2a}.dark .cert-section{background:#0003}.dark .cert-section:hover{background-color:#2a2a2a}.dark .skills-overlay{background-color:#151515;color:#fff}.dark .skill-tag{background:#3a3a3a80;color:#fff}.app2-container{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100vh;background-color:#fff;color:#333;overflow-y:auto;z-index:-1}.app2-container .section{min-height:100vh;scroll-snap-align:start;display:flex;align-items:center;justify-content:center;padding:2rem}@media (max-width: 768px){.app2-container .section{scroll-snap-align:none}.app2-container{scroll-behavior:auto;-webkit-overflow-scrolling:auto}}.dark .app2-container{background-color:#1a1a1a;color:#fff}.shader-background{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;opacity:0;transition:opacity 1.5s ease-in-out;animation:shader-fade-in 2s forwards}@keyframes shader-fade-in{0%{opacity:0;transform:scale(1)}to{opacity:.7;transform:scale(1)}}
