*{margin:0;padding:0;border:0;font-size:100%;box-sizing:border-box}html,body,#root{height:100%;width:100%;margin:0;padding:0;font-family:Arial,Helvetica,sans-serif;color:#fff;font-size:18px;line-height:1.5;background:linear-gradient(180deg,#0a0e27,#000);flex:1;overflow:hidden}canvas,.r3f{position:absolute;top:0;left:0;width:100%;height:100%}h1,h2,h3,h4,h5,h6{font-family:inherit;font-weight:600;margin-bottom:24px}h1{font-size:clamp(1.5rem,5vw,1rem);font-weight:800}h2{font-size:clamp(1.5rem,5vw,1rem);text-align:center;margin:5px 0 20px;border-bottom:2px solid #fff;text-shadow:1px 1px 2px rgba(0,0,0,.5)}h3{font-size:clamp(1.25rem,4vw,.75rem);line-height:1em;margin:0%}h4{font-size:clamp(.9rem,2.5vw + .5rem,1.05rem);line-height:1.3;margin:.5em 0}h5,h6{font-size:1em;font-weight:700;margin-bottom:0}p{margin:.8em 0;font-size:clamp(.75rem,2.5vw,1rem)}a{color:gold;text-decoration:underline}a:hover{color:#ff4500}button,.backButton{padding:10px 20px;border:none;background-color:#85c1e9;color:#fff;border-radius:8px;cursor:pointer;font-size:1rem;box-shadow:0 4px 8px #0000004d;transition:transform .4s ease;will-change:transform;touch-action:manipulation;-webkit-tap-highlight-color:transparent}button:hover,.backButton:hover,.projectCard:hover,.mediaButton:hover{transform:scale(1.05);box-shadow:0 4px 8px #00000080}.subInformation{font-style:italic;color:#bbb}.centerElements{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px}.educationContainer{display:grid;grid-template-columns:1fr auto;align-items:center}.educationImage{max-width:80px;width:clamp(60px,8vw,80px);height:auto;display:block;justify-self:center}@media (max-width: 768px){.container{width:95vw;height:80vh;padding:1.5%}h1,h2{font-size:clamp(1.2rem,4vw + .5rem,1.4em)}.carouselContainer{gap:5px}}@media (max-width: 480px){.container{width:95vw;height:85vh;padding:1%}h1,h2{font-size:clamp(1rem,5vw + .5rem,1.2em)}.carouselContainer{gap:3px}}@media screen and (max-width: 768px),screen and (max-height: 700px){canvas,.r3f{width:100%;height:100%;padding-right:0;overflow:auto;touch-action:none}}.loading-screen{position:fixed;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;background:linear-gradient(135deg,#0a1631,#1b4e80);z-index:10;opacity:1;transition:opacity 1s ease-in-out}.loading-screen.fade-out{opacity:0;pointer-events:none}.loading-text{font-size:1.75rem;font-family:GameFont,sans-serif;letter-spacing:3px;margin-bottom:10px;text-shadow:0 0 5px rgba(0,188,212,.6)}.arcade-icon{width:60px;height:auto;animation:bounce 1.5s infinite ease-in-out,pulse 2s infinite alternate ease-in-out;filter:drop-shadow(0 0 8px rgba(0,188,212,.4));margin:25px 0}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse{0%{filter:drop-shadow(0 0 8px rgba(0,188,212,.45))}to{filter:drop-shadow(0 0 18px rgba(0,188,212,.65))}}.progress-bar{width:25%;height:20px;background:#1b4e80;border:2px solid #0a1631;border-radius:5px;overflow:hidden;margin-top:20px;box-shadow:0 0 5px #00bcd499}.progress-fill{height:100%;background:linear-gradient(135deg,#00e5ff,#007bb8);box-shadow:inset 0 0 4px #00000080;transition:width .3s ease}.title-image{width:clamp(150px,60vw,500px);height:auto;pointer-events:none;-webkit-user-select:none;user-select:none;opacity:0;transition:opacity .5s ease-in-out}.title-image.fade-in{opacity:1}.projectGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px;margin-bottom:20px}.projectCard{background-color:#fff3;padding:0%;border-radius:5px;text-align:center;height:280px;display:flex;flex-direction:column;justify-content:space-between;cursor:pointer;transition:all .3s ease}.projectCard:before{content:"";position:absolute;bottom:0;left:0;width:0%;height:4px;background:gold;transition:width .3s ease}.projectCard:hover:before{width:100%}.projectImage{width:100%;height:70%;background-color:#85c1e9;border-radius:5px;background-size:cover;background-position:center;margin-bottom:10px}.projectCardTextContainer{display:flex;flex-direction:column;padding:0% 0% 2%;max-height:clamp(70px,10vw,110px);overflow:hidden;white-space:nowrap}.bonusList,.tagList{max-width:800px;padding:0;margin:0 auto;color:#e0e0e0;font-weight:700;font-size:clamp(.7rem,1vw + .5rem,1em)}.bonusList{display:grid;grid-template-columns:repeat(2,1fr);justify-content:center;gap:10px;list-style-type:none;text-align:center}.bonusList li{display:flex;align-items:center;justify-content:flex-start;gap:10px;width:100%;padding:5px 0}.bonusList li:before{content:"•";min-width:1em;margin-right:5px;color:gold;text-align:center}.bonusList li:hover,.tagList span:hover{color:#fff;text-shadow:0 0 5px rgba(255,255,255,.2)}.tagList{display:flex;justify-content:space-between;flex-wrap:wrap;overflow:hidden;letter-spacing:.4px;border-radius:10px}.tagList span{flex-grow:1;flex-basis:0;padding:5px 10px;white-space:nowrap;min-width:80px}.tabs{display:flex;justify-content:space-around;margin-bottom:10px;gap:10px;padding:5px;align-items:center}.tab{flex:1 1 auto;padding:.5vw;max-width:150px;font-size:clamp(.8rem,1.8vw,1rem);text-align:center;font-weight:700;background-color:#001f3fb3;border-radius:8px;box-shadow:0 4px 8px #001f3fb3;transform:scale(1);transition:transform .3s ease,background-color .3s ease}.tab:hover{background-color:#6daedb}.active-tab{background-color:#85c1e9}.content{padding:10px;background-color:#ffffff26;border-radius:10px;box-shadow:inset 0 2px 4px #0000001a;margin-bottom:5px;transition:opacity .3s ease-in-out,transform .3s ease-in-out}.fade-in{opacity:1}.fade-out{opacity:0}.custom-scrollbar::-webkit-scrollbar{width:8px}.custom-scrollbar::-webkit-scrollbar-thumb{background-color:#85c1e9;border-radius:10px}.custom-scrollbar::-webkit-scrollbar-track{background-color:#001f3fd9}.custom-scrollbar::-webkit-scrollbar-button{display:none}.ui-container{position:absolute;top:0;left:50%;transform:translate(-50%);width:100%;height:100%;z-index:8;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;overflow:hidden;padding:20px;pointer-events:none;-webkit-user-select:none;user-select:none;touch-action:none}.container{position:relative;background-color:#001f3fd9;width:100%;max-width:850px;height:calc(100vh - 50px);max-height:1050px;overflow-y:auto;margin:1vh auto .5vh;padding:1%;border-radius:12px;box-shadow:0 8px 16px #0006;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);opacity:0;transition:all .3s ease-out;touch-action:auto;overflow-x:hidden}.fade-container{opacity:0;pointer-events:none;transition:opacity .75s ease-out}.fade-container.visible{opacity:1;pointer-events:auto}.carouselContainer{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;max-width:100%;height:auto;overflow:hidden}.carouselButton{font-size:clamp(1.5rem,3vw,2.5rem);background:transparent;border:none;padding:0 5px}.carouselMedia{flex:1;width:60%;max-width:60%;display:flex;justify-content:center;position:relative;aspect-ratio:16 / 9;height:100%}.carouselEmbed{width:100%;height:100%;border:none;object-fit:fill;border-radius:8px}img.carouselImage{width:100%;max-width:100%;height:auto;box-shadow:0 4px 10px #0000001a;margin:0 auto;display:block;object-fit:fill;border-radius:8px}.mediaButtons{display:flex;justify-content:center;margin-top:10px}.mediaButton{background:none;border:2px solid transparent;cursor:pointer;margin:0 5px;padding:0;border-radius:5px;width:clamp(40px,8vw,50px);aspect-ratio:1 / 1;overflow:hidden}.mediaButton.active{background-color:#007bff;border-color:#ff4500}.mediaIcon{width:100%;height:100%;object-fit:cover;border-radius:5px}.videoThumbnail{position:relative;width:100%;height:100%;overflow:hidden}.videoThumbnail img{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(1.3);width:auto;height:120%;object-fit:cover}.playButton{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:clamp(18px,4vw,22px);border-radius:50%;padding:5px}
