:root{--bg-dark:#121212;--bg-darker:#0a0a0a;--text-main:#e0e0e0;--text-muted:#a0a0a0;--accent-glow:#ffffff1a;--border-subtle:#ffffff26;--border-hover:#ffffff4d;--card-bg:#ffffff08;--card-bg-hover:#ffffff0d}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background-color:var(--bg-dark);color:var(--text-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,sans-serif;line-height:1.6;overflow-x:hidden}a{color:inherit;text-decoration:none}ul{list-style:none}.heading-xl{letter-spacing:-.02em;font-size:clamp(3rem,8vw,5.5rem);font-weight:800;line-height:1.1}.heading-lg{font-size:clamp(2rem,5vw,3.5rem);font-weight:700;line-height:1.2}.heading-md{font-size:clamp(1.5rem,3vw,2.25rem);font-weight:600}.heading-sm{font-size:1.25rem;font-weight:500}.text-gradient{background:linear-gradient(90deg,#fff,#a0a0a0);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.glass-panel{background:var(--card-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-subtle);border-radius:16px;transition:all .3s}.glass-panel:hover{background:var(--card-bg-hover);border-color:var(--border-hover);box-shadow:0 8px 32px var(--accent-glow)}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 2rem}.section{padding:6rem 0}.grid{gap:2rem;display:grid}.app-container{flex-direction:column;min-height:100vh;display:flex}.main-content{flex-grow:1}.navbar{z-index:100;background:0 0;width:100%;padding:1.5rem 0;transition:all .3s;position:fixed;top:0;left:0}.navbar.scrolled{-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle);background:#121212d9;padding:1rem 0;box-shadow:0 4px 30px #00000080}.nav-container{justify-content:space-between;align-items:center;display:flex}.nav-logo{flex-direction:column;line-height:1;display:flex}.logo-text{letter-spacing:-.05em;color:var(--text-main);font-size:1.5rem;font-weight:800}.logo-accent{letter-spacing:.2em;color:var(--text-muted);font-size:.8rem;font-weight:500}.nav-links{gap:2rem;display:flex}.nav-link{color:var(--text-muted);font-size:.95rem;font-weight:500;transition:color .3s,text-shadow .3s;position:relative}.nav-link:hover{color:var(--text-main);text-shadow:0 0 8px var(--accent-glow)}.nav-link:after{content:"";background:var(--text-main);width:0;height:1px;box-shadow:0 0 8px var(--text-main);transition:width .3s;position:absolute;bottom:-4px;left:0}.nav-link:hover:after{width:100%}.mobile-toggle{color:var(--text-main);cursor:pointer;background:0 0;border:none;display:none}.mobile-menu{-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-subtle);background:#121212f2;flex-direction:column;width:100%;padding:1rem 0;display:flex;position:absolute;top:100%;left:0}.mobile-nav-link{border-bottom:1px solid #ffffff0d;padding:1rem 2rem;font-weight:500}.mobile-nav-link:last-child{border-bottom:none}@media (width<=768px){.desktop-only{display:none}.mobile-toggle{display:block}}@media (width>=769px){.mobile-only{display:none!important}}.hero-section{justify-content:center;align-items:center;min-height:100vh;padding-top:80px;display:flex;position:relative;overflow:hidden}.hero-container{z-index:2;text-align:center;flex-direction:column;align-items:center;display:flex;position:relative}.hero-content{flex-direction:column;align-items:center;max-width:800px;display:flex}.badge{border:1px solid var(--border-hover);letter-spacing:.1em;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:var(--text-muted);background:#ffffff0d;border-radius:20px;margin-bottom:2rem;padding:.5rem 1rem;font-size:.8rem;font-weight:600;display:inline-block}.hero-title{margin-bottom:1.5rem}.hero-subtitle{color:var(--text-muted);margin-bottom:3rem;font-size:clamp(1rem,2vw,1.25rem);line-height:1.8}.highlight{color:var(--text-main);font-weight:600}.cta-button{background:var(--text-main);color:var(--bg-dark);border-radius:30px;align-items:center;gap:.75rem;padding:1rem 2rem;font-weight:600;transition:all .3s;display:inline-flex;box-shadow:0 4px 20px #ffffff26}.cta-button:hover{background:#fff;transform:translateY(-2px);box-shadow:0 8px 30px #ffffff40}.cta-icon{animation:2s infinite bounce}.hero-glow{z-index:1;pointer-events:none;background:radial-gradient(circle,#ffffff08 0%,#12121200 70%);width:60vw;height:60vw;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(4px)}60%{transform:translateY(2px)}}.section-header{text-align:center;margin-bottom:4rem}.section-subtitle{color:var(--text-muted);margin-top:1rem;font-size:1.1rem}.vault-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;display:grid}.media-card{flex-direction:column;gap:1rem;display:flex}.video-card{grid-row:span 2}.media-placeholder{aspect-ratio:1;background:#ffffff05;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:1rem;width:100%;display:flex;position:relative;overflow:hidden}.video-card .media-placeholder{aspect-ratio:9/16}.video-icon,.image-icon{color:var(--text-muted);opacity:.5;transition:all .3s}.image-icon{font-size:3rem}.media-placeholder:hover .video-icon,.media-placeholder:hover .image-icon{opacity:1;color:var(--text-main);transform:scale(1.1)}.placeholder-text{color:var(--text-muted);letter-spacing:.1em;opacity:.5;font-size:.8rem;font-weight:600}.media-info{padding:0 .5rem}.media-actions{gap:1rem;margin-bottom:.5rem;display:flex}.action{color:var(--text-main);cursor:pointer;align-items:center;gap:.25rem;font-size:.9rem;font-weight:500;transition:color .2s;display:flex}.action:hover{color:var(--text-muted)}.media-caption{color:var(--text-muted);font-size:.95rem;line-height:1.4}.flex-zone-section{background:linear-gradient(#0000,#ffffff03 50%,#0000)}.flex-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2.5rem;display:grid}.flex-card{flex-direction:column;height:100%;display:flex;overflow:hidden}.flex-card-image-wrapper{aspect-ratio:16/9;border-bottom:1px solid var(--border-subtle);background:#0000004d;width:100%;position:relative;overflow:hidden}.flex-card-placeholder{width:100%;height:100%;color:var(--text-muted);letter-spacing:.1em;opacity:.6;justify-content:center;align-items:center;font-size:.8rem;font-weight:600;display:flex;position:absolute;top:0;left:0}.flex-card-content{flex-direction:column;flex-grow:1;padding:2rem;display:flex}.icon-wrapper{border:1px solid var(--border-subtle);background:#ffffff0d;border-radius:12px;justify-content:center;align-items:center;width:60px;height:60px;margin-bottom:1.5rem;display:flex}.flex-card h3{color:var(--text-main);margin-bottom:1rem}.flex-card p{color:var(--text-muted);font-size:.95rem;line-height:1.6}.resource-grid{flex-direction:column;gap:1.5rem;max-width:800px;margin:0 auto;display:flex}.resource-card{cursor:pointer;color:inherit;align-items:center;gap:1.5rem;padding:1.5rem 2rem;text-decoration:none;display:flex;position:relative;overflow:hidden}.resource-card:before{content:"";background:var(--text-main);transform-origin:bottom;width:4px;height:100%;transition:transform .3s;position:absolute;top:0;left:0;transform:scaleY(0)}.resource-card:hover:before{transform:scaleY(1)}.resource-icon{color:var(--text-main);background:#ffffff0d;border-radius:50%;justify-content:center;align-items:center;padding:1rem;display:flex}.resource-content{flex-grow:1}.resource-content h3{color:var(--text-main);margin-bottom:.25rem;transition:color .3s}.resource-content p{color:var(--text-muted);margin:0;font-size:.95rem}.resource-arrow{color:var(--text-muted);opacity:.5;transition:all .3s}.resource-card:hover .resource-arrow{color:var(--text-main);opacity:1;transform:translate(4px)translateY(-4px)}@media (width<=600px){.resource-card{flex-direction:column;align-items:flex-start;gap:1rem;padding:1.5rem}.resource-arrow{position:absolute;top:1.5rem;right:1.5rem}}.directory-section{position:relative}.directory-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:2rem;padding-bottom:4rem;display:grid}.student-card{text-align:center;flex-direction:column;align-items:center;padding:2rem 1rem;transition:all .3s;display:flex}.student-card:hover{transform:translateY(-5px)}.interactive-card{cursor:pointer}.student-image-wrapper{background:linear-gradient(135deg, var(--text-main), transparent);border-radius:50%;width:100px;height:100px;margin-bottom:1.5rem;padding:4px;position:relative}.student-image{object-fit:cover;background:var(--bg-dark);border-radius:50%;width:100%;height:100%}.student-image-placeholder{background:var(--bg-darker);width:100%;height:100%;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;display:flex}.placeholder-icon{opacity:.5}.student-name{color:var(--text-main);word-break:break-word;margin-bottom:.5rem;font-size:1.1rem;font-weight:700}.student-role{color:var(--text-muted);letter-spacing:.05em;margin-bottom:1.5rem;font-size:.85rem;font-weight:500}.student-socials{justify-content:center;gap:1rem;margin-top:auto;display:flex}.social-icon{color:var(--text-muted);background:#ffffff0d;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:all .3s;display:flex}.social-icon:hover{color:var(--text-main);background:#ffffff1a;transform:scale(1.1)}@media (width<=500px){.directory-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.student-card{padding:1.5rem .5rem}.student-image-wrapper{width:80px;height:80px}}.modal-backdrop{-webkit-backdrop-filter:blur(8px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;width:100vw;height:100vh;padding:1rem;display:flex;position:fixed;top:0;left:0}.modal-content{border:1px solid var(--border-hover);width:100%;max-width:600px;max-height:90vh;box-shadow:0 20px 50px #00000080, 0 0 20px var(--accent-glow);background:#121212f2;border-radius:20px;padding:2.5rem;position:relative;overflow-y:auto}.modal-content::-webkit-scrollbar{width:8px}.modal-content::-webkit-scrollbar-track{background:0 0}.modal-content::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:4px}.modal-content::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}.modal-close{color:var(--text-muted);cursor:pointer;background:#ffffff0d;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:all .3s;display:flex;position:absolute;top:1.5rem;right:1.5rem}.modal-close:hover{color:var(--text-main);background:#ffffff1a;transform:rotate(90deg)}.modal-header{border-bottom:1px solid var(--border-subtle);align-items:center;gap:2rem;margin-bottom:2rem;padding-bottom:2rem;display:flex}.modal-image-wrapper{background:linear-gradient(135deg, var(--text-main), transparent);border-radius:50%;flex-shrink:0;width:120px;height:120px;padding:4px}.modal-image,.modal-image-placeholder{object-fit:cover;background:var(--bg-darker);border-radius:50%;width:100%;height:100%}.modal-image-placeholder{color:var(--text-muted);opacity:.5;justify-content:center;align-items:center;display:flex}.modal-title-area{flex-direction:column;gap:.5rem;display:flex}.modal-title-area h2{color:var(--text-main);margin:0}.modal-nickname{color:var(--text-muted);font-size:1.1rem;font-style:italic}.meme-gpa-badge{color:var(--text-main);background:#ffffff1a;border:1px solid #fff3;border-radius:20px;align-items:center;gap:.5rem;width:fit-content;margin-top:.5rem;padding:.4rem 1rem;font-size:.9rem;font-weight:600;display:inline-flex}.badge-label{color:var(--text-muted);font-weight:400}.modal-body{flex-direction:column;gap:2rem;display:flex}.section-title{color:var(--text-main);margin-bottom:1rem;font-size:1.2rem;font-weight:600}.info-section p{color:var(--text-muted);line-height:1.6}.student-quote{border-left:2px solid var(--border-hover);color:var(--text-main);margin-top:1rem;padding-left:1rem;font-size:1.05rem;font-style:italic}.fact-box{border:1px dashed var(--border-hover);color:var(--text-main);background:#ffffff08;border-radius:12px;padding:1.2rem;font-size:.95rem}.section-subtitle{margin-top:-.5rem;margin-bottom:1rem;font-size:.85rem!important}.media-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;display:grid}.media-placeholder-box{aspect-ratio:9/16;text-align:center;color:var(--text-muted);cursor:pointer;background:#0006;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;padding:1rem;font-size:.85rem;transition:all .3s;display:flex}.media-placeholder-box:hover{color:var(--text-main);border-color:var(--text-main)}.media-icon{opacity:.7;margin-bottom:.5rem}.media-tag{letter-spacing:.05em;color:var(--text-main);font-size:.75rem;font-weight:600}@media (width<=600px){.modal-content{padding:1.5rem}.modal-header{text-align:center;flex-direction:column;gap:1rem}.meme-gpa-badge{margin:.5rem auto 0}.modal-close{top:1rem;right:1rem}}.journey-section{position:relative;overflow:hidden}.timeline-container{max-width:900px;margin:4rem auto;padding:2rem 0;position:relative}.timeline-track{z-index:1;width:2px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.timeline-track-glow{background:var(--text-main);width:100%;height:66%;box-shadow:0 0 10px var(--text-main), 0 0 20px var(--text-main);position:absolute;top:0;left:0}.timeline-track-dashed{background:0 0;background-image:linear-gradient(to bottom, var(--border-hover) 50%, transparent 50%);opacity:.5;background-size:2px 12px;width:100%;height:50%;position:absolute;top:50%;left:0}.timeline-nodes{z-index:2;flex-direction:column;gap:4rem;display:flex;position:relative}.timeline-node{width:100%;display:flex;position:relative}.timeline-node.left{justify-content:flex-start}.timeline-node.right{justify-content:flex-end}.timeline-dot{background:var(--bg-dark);border:2px solid var(--text-main);width:20px;height:20px;box-shadow:0 0 10px var(--accent-glow);color:var(--text-muted);z-index:3;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:2rem;left:50%;transform:translate(-50%,-50%)}.timeline-node.locked .timeline-dot{border-color:var(--text-muted);box-shadow:none;background:var(--bg-darker)}.dot-inner{background:var(--text-main);border-radius:50%;width:8px;height:8px}.timeline-card{width:calc(50% - 3rem);padding:1.5rem;transition:all .3s}.timeline-node.locked .timeline-card{opacity:.5;filter:grayscale(.8);border-color:#ffffff0d}.timeline-node.locked .timeline-card:hover{opacity:.8;filter:grayscale(.2)}.timeline-node.current .timeline-card{border-color:var(--text-main);background:#ffffff0d;box-shadow:0 0 20px #ffffff1a}.timeline-node.current .timeline-dot{box-shadow:0 0 20px var(--text-main);background:var(--text-main);transform:translate(-50%,-50%)scale(1.3)}.timeline-node.current .dot-inner{background:var(--bg-dark)}.timeline-date{color:var(--text-muted);border:1px solid var(--border-subtle);background:#ffffff0d;border-radius:20px;align-items:center;gap:.4rem;margin-bottom:1.5rem;padding:.3rem .8rem;font-size:.85rem;display:inline-flex}.gallery-container{border-radius:8px;width:100%;margin-bottom:1.5rem;position:relative;overflow:hidden}.gallery-container:after{content:"";pointer-events:none;z-index:1;background:linear-gradient(270deg,#121212cc 0%,#0000 100%);width:30px;position:absolute;top:0;bottom:0;right:0}.gallery-container:before{content:"";pointer-events:none;z-index:1;background:linear-gradient(90deg,#121212cc 0%,#0000 100%);width:30px;position:absolute;top:0;bottom:0;left:0}.gallery-nav-buttons{z-index:5;pointer-events:none;opacity:0;justify-content:space-between;width:100%;padding:0 .5rem;transition:opacity .3s;display:flex;position:absolute;top:50%;left:0;transform:translateY(-50%)}.gallery-container:hover .gallery-nav-buttons{opacity:1}.gallery-nav{pointer-events:auto;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid var(--border-subtle);color:var(--text-main);cursor:pointer;background:#121212b3;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.gallery-nav:hover{background:var(--text-main);color:var(--bg-dark);transform:scale(1.1)}.gallery-scroll{scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;gap:.5rem;display:flex;overflow-x:auto}.gallery-scroll::-webkit-scrollbar{display:none}.gallery-item-wrapper{aspect-ratio:16/9;scroll-snap-align:center;border:1px solid var(--border-subtle);background:var(--bg-darker);border-radius:8px;flex:0 0 100%;position:relative;overflow:hidden}.gallery-image{object-fit:cover;width:100%;height:100%;transition:transform .5s}.gallery-item-wrapper:hover .gallery-image{transform:scale(1.05)}.image-fallback{width:100%;height:100%;color:var(--text-muted);letter-spacing:.1em;justify-content:center;align-items:center;font-size:.8rem;display:none;position:absolute;top:0;left:0}.timeline-year{margin-bottom:.5rem;font-size:1.2rem;font-weight:700}.timeline-title{color:var(--text-main);margin-bottom:.5rem;font-size:1.05rem;font-weight:500}.timeline-text{color:var(--text-muted);font-size:.95rem;line-height:1.6}.timeline-outro{text-align:center;background:radial-gradient(circle,#ffffff08 0%,#0000 70%);margin-top:6rem;padding:3rem}.outro-text{color:var(--text-main);max-width:600px;text-shadow:0 0 20px var(--accent-glow);margin:0 auto;font-size:clamp(1.2rem,3vw,1.8rem);font-weight:600;line-height:1.5}@media (width<=768px){.timeline-track,.timeline-dot{left:1.5rem}.timeline-node,.timeline-node.left{justify-content:flex-end}.timeline-card{width:calc(100% - 4rem)}}.footer{border-top:1px solid var(--border-subtle);background:var(--bg-darker);text-align:center;margin-top:4rem;padding:3rem 0}.footer-content{flex-direction:column;align-items:center;gap:1rem;display:flex}.footer-text{color:var(--text-muted);font-size:.95rem}.footer-link{color:var(--text-main);letter-spacing:.05em;font-size:1rem;font-weight:600;transition:all .3s;display:inline-block;position:relative}.footer-link:after{content:"";background-color:var(--text-main);transform-origin:100% 100%;width:100%;height:1px;transition:transform .3s ease-out;position:absolute;bottom:-4px;left:0;transform:scaleX(0)}.footer-link:hover{text-shadow:0 0 8px var(--accent-glow)}.footer-link:hover:after{transform-origin:0 100%;transform:scaleX(1)}
