:root{font-family:Roboto,sans-serif;--primary-color: #86F486;--secondary-color: #4CA84C;--tertiary-color: #f1aa70;--faded-background: rgba(255, 255, 255, .31);--primary-font-color: #f5f5f5;--secondary-font-color: #f5f5f5;--glass-background: rgba(255, 255, 255, .15);--glass-border: rgba(255, 255, 255, .3);--glass-shadow: 0 8px 32px rgba(0, 0, 0, .1);--glass-blur: blur(16px)}*{margin:0;padding:0;box-sizing:border-box}canvas{position:fixed;top:0;left:0}nav{position:fixed;top:0;left:50%;transform:translate(-50%);width:75%;display:flex;justify-content:space-around;align-items:center;z-index:1;background:rgba(134,244,134,.25);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-radius:50px;border:1px solid rgba(255,255,255,.4);box-shadow:var(--glass-shadow);margin:2rem auto;padding:1rem}main{display:flex;position:absolute;width:100%;justify-content:center;flex-direction:column}nav p{text-decoration:none;cursor:pointer;font-size:1.5em;border-radius:50px;padding:.5em;transition:.2s}nav p:hover{background:rgba(76,168,76,.4);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}nav p.active{background:rgba(255,255,255,.6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.nav-transitioning{position:relative}.nav-transitioning:after{content:"";position:absolute;bottom:5px;left:50%;transform:translate(-50%);width:20px;height:3px;background-color:var(--tertiary-color);border-radius:2px;animation:pulse .5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:translate(-50%) scale(1)}50%{opacity:.5;transform:translate(-50%) scale(1.2)}}.tabcontent{width:80%;grid-template-columns:repeat(12,1fr);grid-auto-rows:auto;margin:5rem auto}.tabcontent#about{display:none}.tabcontent#about .about-container{grid-column:6 / 13;display:flex;flex-direction:column;gap:2rem;margin:5rem 1rem}.tabcontent#about .about-photo{display:flex;justify-content:center}.tabcontent#about .about-photo img{width:200px;height:200px;border-radius:50%;object-fit:cover;border:2px solid var(--glass-border);box-shadow:var(--glass-shadow);transition:transform .3s ease}.tabcontent#about .about-photo img:hover{transform:scale(1.05)}.tabcontent#about .about-content{background:var(--glass-background);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);padding:2rem;border-radius:20px;border:1px solid var(--glass-border);box-shadow:var(--glass-shadow)}.tabcontent#about .about-content h1{color:var(--secondary-color);font-size:2rem;margin-bottom:1rem;text-align:center}.tabcontent#about .about-content h2{color:var(--secondary-color);font-size:1.3rem;margin-top:1.5rem;margin-bottom:.5rem;border-left:4px solid var(--primary-color);padding-left:.75rem}.tabcontent#about .about-content p{line-height:1.7;color:#1a1a1a;margin-bottom:1rem;text-align:justify}.tabcontent#about .about-content p.intro{font-size:1.1rem;font-weight:500;color:#1a1a1a}.tabcontent#projects{display:none;margin-top:8rem}.tabcontent .project{display:flex;flex-direction:column;margin:2rem 1rem;padding:0;border-radius:20px;grid-column:6 / 13;background:var(--glass-background);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}.tabcontent .project:hover{transform:translateY(-5px);box-shadow:0 12px 40px #0003;border:1px solid rgba(255,255,255,.5)}.tabcontent .project h2{padding:1.5rem 2rem .5rem;font-size:1.5rem;color:var(--secondary-color)}.tabcontent .project .project-media{width:100%;height:auto;overflow:hidden}.tabcontent .project .project-media img{width:100%;height:250px;object-fit:cover;transition:transform .3s ease}.tabcontent .project:hover .project-media img{transform:scale(1.05)}.tabcontent .project .project-details{padding:1.5rem 2rem 2rem}.tabcontent .project .description{line-height:1.7;color:#1a1a1a;margin-bottom:1.5rem}.tabcontent .project .tech-stack{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.tabcontent .project .tech-tag{background:rgba(134,244,134,.3);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(134,244,134,.4);color:#1a1a1a;padding:.3rem .8rem;border-radius:20px;font-size:.85rem;font-weight:500}.tabcontent .project .project-links{display:flex;gap:1rem;flex-wrap:wrap}.tabcontent .project .project-link{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;background:rgba(76,168,76,.6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(76,168,76,.4);color:#fff;text-decoration:none;border-radius:25px;font-weight:500;transition:all .3s ease}.tabcontent .project .project-link:hover{background:rgba(76,168,76,.8);border:1px solid rgba(76,168,76,.6);transform:translateY(-2px);box-shadow:0 4px 15px #4ca84c4d}.tabcontent #gallery-section{display:flex;flex-direction:column;width:100%;grid-column:1 / 13;justify-content:center;align-items:center;padding:3rem;margin-top:2rem;border-radius:30px;row-gap:2rem;background:var(--glass-background);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow)}.tabcontent #gallery-section h3{font-size:1.5rem;color:var(--secondary-color)}.tabcontent #gallery-section>p{text-align:center;color:#1a1a1a;max-width:600px}.gallery{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:1.5rem;width:100%}.gallery-content{position:relative;width:100%;border-radius:15px;overflow:hidden;background:var(--glass-background);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);transition:transform .3s ease}.gallery-content:hover{transform:scale(1.03);border:1px solid rgba(255,255,255,.5)}.gallery-content img{width:100%;height:180px;object-fit:cover;display:block}.gallery-content .gallery-label{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.7));color:#fff;padding:2rem 1rem 1rem;font-size:.9rem;text-align:center}.tabcontent .contact{display:flex;flex-direction:column;width:100%;grid-column:1 / 13;justify-content:center;align-items:center;margin:5rem 0;padding:3rem;border-radius:30px;row-gap:2rem;background:var(--glass-background);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow)}.tabcontent .contact>p{font-size:1.2rem;color:#1a1a1a}.tabcontent#contacts .contact ul{list-style-type:none;display:flex;flex-direction:column;gap:1rem}.tabcontent#contacts .contact ul li{text-align:center}.tabcontent#contacts .contact ul li a{color:var(--secondary-color);text-decoration:none;font-size:1.1rem;font-weight:500;padding:.5rem 1rem;border-radius:10px;transition:all .3s ease}.tabcontent#contacts .contact ul li a:hover{background:rgba(134,244,134,.3);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(134,244,134,.4)}.project-link[href="#"]{background:rgba(136,136,136,.4);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(136,136,136,.3);cursor:not-allowed;opacity:.7}.project-link[href="#"]:hover{background:rgba(136,136,136,.4);transform:none;box-shadow:none}.project-link[href="#"]:after{content:" (Coming Soon)";font-size:.75rem;opacity:.8}#loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#D7EAA2 0%,#86F486 100%);display:flex;justify-content:center;align-items:center;z-index:9999;transition:opacity .5s ease-out}#loading-overlay.fade-out{opacity:0;pointer-events:none}.loading-content{text-align:center;padding:2rem}.loading-spinner{width:60px;height:60px;border:4px solid rgba(255,255,255,.3);border-top-color:var(--secondary-color);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1.5rem}@keyframes spin{to{transform:rotate(360deg)}}.loading-title{color:var(--secondary-color);font-size:1.8rem;margin-bottom:1.5rem}.progress-container{width:280px;height:8px;background:rgba(255,255,255,.4);border-radius:4px;overflow:hidden;margin:0 auto 1rem}.progress-bar{height:100%;width:0%;background:var(--secondary-color);border-radius:4px;transition:width .3s ease}.loading-status{color:#1a1a1a;font-size:.95rem}#webgl-fallback{position:fixed;top:0;left:0;width:100%;padding:2rem;background:rgba(255,200,100,.95);z-index:1000;box-shadow:0 4px 20px #0000001a}.fallback-content{max-width:600px;margin:0 auto;text-align:center}.fallback-icon{font-size:3rem;margin-bottom:1rem}#webgl-fallback h2{color:#8b4513;margin-bottom:1rem}#webgl-fallback p{color:#1a1a1a;line-height:1.6}.fallback-suggestions{background:rgba(255,255,255,.5);border-radius:10px;padding:1rem;margin:1.5rem 0;text-align:left}.fallback-suggestions h3{color:#8b4513;margin-bottom:.5rem;font-size:1rem}.fallback-suggestions ul{margin-left:1.5rem}.fallback-suggestions li{color:#1a1a1a;margin:.3rem 0}.fallback-note{font-style:italic;font-size:.9rem;opacity:.8}@media screen and (max-width: 768px){nav{width:90%;padding:.75rem}nav p{font-size:1.1rem;padding:.4em}.tabcontent{width:95%;margin:4rem auto}.tabcontent#about .about-container{grid-column:1 / 13;margin:4rem .5rem}.tabcontent .project{grid-column:1 / 13;margin:1.5rem .5rem}.tabcontent#about .about-photo img{width:150px;height:150px}.tabcontent#about .about-content h1{font-size:1.6rem}.tabcontent#about .about-content h2{font-size:1.1rem}.gallery{grid-template-columns:repeat(2,1fr);grid-gap:1rem}.gallery-content img{height:150px}.tabcontent .project .project-media img{height:200px}.tabcontent .project .tech-stack,.tabcontent .project .project-links{justify-content:center}}@media screen and (max-width: 480px){nav{width:95%;flex-direction:column;gap:.5rem;padding:.75rem;border-radius:20px}nav p{font-size:1rem;width:100%;text-align:center}.tabcontent{margin:14rem auto 2rem}.tabcontent#projects{margin-top:14rem}.tabcontent#about .about-container{margin:1rem .25rem;gap:1rem}.tabcontent#about .about-content{padding:1.25rem}.tabcontent#about .about-content h1{font-size:1.4rem}.tabcontent#about .about-content p{font-size:.9rem;text-align:left}.tabcontent .project{margin:1rem .25rem}.tabcontent .project h2{font-size:1.25rem;padding:1rem 1rem .5rem}.tabcontent .project .project-details{padding:1rem}.tabcontent .project .project-media img{height:160px}.tabcontent .project .tech-tag{font-size:.75rem;padding:.25rem .6rem}.tabcontent .project .project-link{padding:.5rem 1rem;font-size:.9rem}.gallery{grid-template-columns:1fr}.gallery-content img{height:180px}.tabcontent #gallery-section{padding:1.5rem}.tabcontent .contact{padding:1.5rem;margin:3rem 0}.tabcontent .contact>p{font-size:1rem}.loading-title{font-size:1.4rem}.progress-container{width:220px}#webgl-fallback{padding:1rem}.fallback-icon{font-size:2rem}}@media screen and (max-width: 480px){canvas#bg{opacity:.3}main{z-index:2}.tabcontent#about .about-content,.tabcontent .project,.tabcontent #gallery-section,.tabcontent .contact{background:rgba(255,255,255,.85);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}nav p{padding:.75em 1em;min-height:44px;display:flex;align-items:center;justify-content:center}.tabcontent .project .project-link{min-height:44px;display:inline-flex;align-items:center}.tabcontent#contacts .contact ul li a{display:inline-block;padding:.75rem 1.25rem;min-height:44px}}#mobile-experience-warning{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#D7EAA2 0%,#86F486 100%);display:flex;justify-content:center;align-items:center;z-index:10000;transition:opacity .3s ease-out}#mobile-experience-warning.fade-out{opacity:0;pointer-events:none}.mobile-warning-content{text-align:center;padding:2rem;max-width:90%}.mobile-warning-icon{font-size:4rem;margin-bottom:1rem}.mobile-warning-content h2{color:var(--secondary-color);font-size:1.5rem;margin-bottom:1rem}.mobile-warning-content p{color:#1a1a1a;font-size:1rem;line-height:1.6;margin-bottom:.75rem}.mobile-warning-hint{font-size:.9rem!important;opacity:.8;font-style:italic}.mobile-warning-actions{margin-top:1.5rem;display:flex;flex-direction:column;gap:.75rem;align-items:center}.mobile-warning-btn{padding:.75rem 1.5rem;border-radius:25px;border:none;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;min-width:180px}.mobile-warning-btn.primary{background:var(--secondary-color);color:#fff}.mobile-warning-btn.primary:hover,.mobile-warning-btn.primary:active{background:#3a8a3a;transform:scale(1.02)}.content-toggle-button{position:fixed;bottom:20px;right:20px;padding:.75rem 1rem;border-radius:30px;border:none;background:rgba(76,168,76,.9);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;font-size:.9rem;font-weight:500;cursor:pointer;z-index:1000;display:flex;align-items:center;gap:.5rem;box-shadow:0 4px 15px #0003;transition:all .3s ease}.content-toggle-button:hover,.content-toggle-button:active{background:rgba(76,168,76,1);transform:scale(1.05)}.content-toggle-button.scene-visible{background:rgba(241,170,112,.9)}.content-toggle-button.scene-visible:hover,.content-toggle-button.scene-visible:active{background:rgba(241,170,112,1)}.toggle-icon{font-size:1.1rem}main.content-hidden{opacity:0;pointer-events:none;transition:opacity .3s ease}.control-hint{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:rgba(0,0,0,.7);color:#fff;padding:.75rem 1.25rem;border-radius:25px;display:flex;align-items:center;gap:.5rem;z-index:1001;font-size:.9rem;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);animation:slideUp .3s ease-out}.control-hint.fade-out{opacity:0;transition:opacity .5s ease-out}.control-hint-icon{font-size:1.2rem}.control-hint-text{white-space:nowrap}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.section-transition{transition:opacity .3s ease-out,transform .3s ease-out}.section-slide-out-left{opacity:0;transform:translate(-50px)}.section-slide-out-right{opacity:0;transform:translate(50px)}.section-slide-in-right{animation:slideInFromRight .3s ease-out forwards}.section-slide-in-left{animation:slideInFromLeft .3s ease-out forwards}@keyframes slideInFromRight{0%{opacity:0;transform:translate(50px)}to{opacity:1;transform:translate(0)}}@keyframes slideInFromLeft{0%{opacity:0;transform:translate(-50px)}to{opacity:1;transform:translate(0)}}.skills-section{grid-column:1 / 13;background:var(--glass-background);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:20px;padding:2rem;margin:2rem 0}.skills-section h3{color:var(--secondary-color);font-size:1.5rem;margin-bottom:1.5rem;text-align:center}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.skill-category{background:rgba(255,255,255,.2);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.3);border-radius:15px;padding:1.5rem}.skill-category h4{color:var(--secondary-color);font-size:1.1rem;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.skill-category-icon{font-size:1.3rem}.skill-list{display:flex;flex-wrap:wrap;gap:.5rem}.skill-tag{background:rgba(134,244,134,.3);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(134,244,134,.4);color:#1a1a1a;padding:.4rem .8rem;border-radius:20px;font-size:.85rem;font-weight:500;transition:all .2s ease}.skill-tag:hover{background:rgba(134,244,134,.5);transform:translateY(-2px)}.skill-bar-container{margin-bottom:1rem}.skill-bar-label{display:flex;justify-content:space-between;margin-bottom:.3rem;font-size:.9rem;color:#1a1a1a}.skill-bar{height:8px;background:rgba(255,255,255,.3);border-radius:4px;overflow:hidden}.skill-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));border-radius:4px;transition:width 1s ease-out}.experience-section{grid-column:1 / 13;background:var(--glass-background);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:20px;padding:2rem;margin:2rem 0}.experience-section h3{color:var(--secondary-color);font-size:1.5rem;margin-bottom:2rem;text-align:center}.timeline{position:relative;padding-left:30px}.timeline:before{content:"";position:absolute;left:8px;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--primary-color),var(--secondary-color));border-radius:2px}.timeline-item{position:relative;margin-bottom:2rem;padding-bottom:1rem}.timeline-item:last-child{margin-bottom:0}.timeline-item:before{content:"";position:absolute;left:-26px;top:5px;width:14px;height:14px;background:var(--secondary-color);border:3px solid var(--primary-color);border-radius:50%;z-index:1}.timeline-date{display:inline-block;background:rgba(134,244,134,.3);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(134,244,134,.4);color:var(--secondary-color);padding:.3rem .8rem;border-radius:15px;font-size:.85rem;font-weight:600;margin-bottom:.5rem}.timeline-content{background:rgba(255,255,255,.2);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.3);border-radius:15px;padding:1.25rem;transition:transform .2s ease,box-shadow .2s ease}.timeline-content:hover{transform:translate(5px);box-shadow:0 4px 15px #0000001a}.timeline-title{color:var(--secondary-color);font-size:1.1rem;font-weight:600;margin-bottom:.25rem}.timeline-company{color:#4a4a4a;font-size:.95rem;font-weight:500;margin-bottom:.5rem}.timeline-description{color:#1a1a1a;font-size:.9rem;line-height:1.6}.timeline-description ul{margin-top:.5rem;margin-left:1.25rem}.timeline-description li{margin-bottom:.25rem}.resume-download{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.5rem;background:rgba(76,168,76,.6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(76,168,76,.4);color:#fff;text-decoration:none;border-radius:25px;font-weight:500;font-size:1rem;transition:all .3s ease;cursor:pointer}.resume-download:hover:not(:disabled){background:rgba(76,168,76,.8);border:1px solid rgba(76,168,76,.6);transform:translateY(-2px);box-shadow:0 4px 15px #4ca84c4d}.resume-download:disabled{background:rgba(136,136,136,.4);border:1px solid rgba(136,136,136,.3);cursor:not-allowed;opacity:.7}.resume-download:disabled:after{content:" (Coming Soon)";font-size:.75rem;opacity:.8}.resume-download-icon{font-size:1.2rem}.resume-section{display:flex;justify-content:center;margin-top:1.5rem}.project-filter-container{grid-column:1 / 13;background:var(--glass-background);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:20px;padding:1.5rem;margin-bottom:1rem;display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.project-filter-label{color:var(--secondary-color);font-weight:600;margin-right:.5rem}.filter-btn{background:rgba(255,255,255,.3);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.4);color:#1a1a1a;padding:.4rem 1rem;border-radius:20px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.filter-btn:hover{background:rgba(134,244,134,.3);border-color:#86f48666}.filter-btn.active{background:rgba(76,168,76,.6);border-color:#4ca84c66;color:#fff}.project.filtered-out{display:none!important}.project.filter-match{animation:filterIn .3s ease-out forwards}@keyframes filterIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.no-filter-results{grid-column:1 / 13;text-align:center;padding:3rem;color:#666;font-style:italic}@media screen and (max-width: 768px){.skills-grid{grid-template-columns:1fr}.skill-category{padding:1rem}.timeline{padding-left:25px}.timeline-item:before{left:-21px;width:12px;height:12px}.timeline-content{padding:1rem}.project-filter-container{justify-content:center}}@media screen and (max-width: 480px){.skills-section,.experience-section{padding:1.25rem;margin:1rem 0}.skills-section h3,.experience-section h3{font-size:1.25rem}.skill-tag{font-size:.8rem;padding:.3rem .6rem}.timeline{padding-left:20px}.timeline:before{left:5px;width:2px}.timeline-item:before{left:-18px;width:10px;height:10px}.timeline-date{font-size:.8rem}.timeline-title{font-size:1rem}.timeline-company{font-size:.9rem}.timeline-description{font-size:.85rem}.filter-btn{font-size:.8rem;padding:.35rem .8rem}.resume-download{padding:.7rem 1.2rem;font-size:.9rem}}
