:root{--bg-primary:#000;--bg-secondary:#111;--bg-card:#1a1a1a;--text-primary:#fff;--text-secondary:#a0a0a0;--text-muted:#666;--accent:#fff;--border-color:#333;--font-sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--glass-bg:var(--bg-card);--glass-border:1px solid var(--border-color);--text-color:var(--text-primary);--cr-blue-glow:#fff;--cr-yellow-glow:#fff}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#000;background-color:var(--bg-primary);color:#fff;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-family:var(--font-sans);font-size:16px;line-height:1.6;margin:0;min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;margin:0}p{margin:0 0 1rem}a{color:#fff;color:var(--text-primary);text-decoration:underline}a:hover{text-decoration:none}code{background:#111;background:var(--bg-secondary);border-radius:3px;font-family:SF Mono,Consolas,Monaco,Courier New,monospace;font-size:.9em;padding:.1em .3em}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#000;background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:#333;background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#666;background:var(--text-muted)}.app-container{display:flex;min-height:100vh;padding-top:60px}.content{align-items:center;display:flex;flex-direction:column;flex-grow:1;padding:var(--space-8) var(--space-4);width:100%}.app-container.with-sidebar .content{margin-left:200px}@media (max-width:768px){.content{padding:var(--space-4)}.app-container.with-sidebar .content{margin-left:0}}.navbar{background:var(--bg-primary);border-bottom:1px solid var(--border-color);height:60px;left:0;position:fixed;top:0;width:100%;z-index:1000}.navbar-container{height:100%;justify-content:space-between;margin:0 auto;max-width:1000px;padding:0 var(--space-4)}.navbar-container,.navbar-logo{align-items:center;display:flex}.navbar-logo{text-decoration:none}.navbar-logo img{height:32px}.navbar-links{display:flex;gap:var(--space-6)}.nav-link{border-bottom:2px solid #0000;color:var(--text-secondary);font-size:.9rem;padding:var(--space-2) 0;text-decoration:none;transition:all .2s}.nav-link.active,.nav-link:hover{color:var(--text-primary)}.nav-link.active{border-bottom-color:var(--text-primary)}.mute-button{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:1.25rem;padding:var(--space-2)}.mute-button:hover{color:var(--text-primary)}.resource-display-container{display:none}@media (max-width:768px){.navbar-links{gap:var(--space-4)}.nav-link{font-size:.85rem}}@media (max-width:480px){.navbar-links{gap:var(--space-3)}}.back-to-home-container{border-top:1px solid var(--border-color);margin-top:var(--space-12);padding-top:var(--space-6);text-align:center;width:100%}.back-to-home-btn{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;color:var(--text-primary);display:inline-block;font-size:.95rem;padding:var(--space-3) var(--space-6);text-decoration:none;transition:all .2s ease}.back-to-home-btn:hover{background-color:var(--text-primary);border-color:var(--text-primary);color:var(--bg-primary);text-decoration:none;transform:translateY(-2px)}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;height:calc(100vh - 60px);left:0;overflow-y:auto;padding:var(--space-6) var(--space-4);position:fixed;top:60px;width:200px;z-index:900}.sidebar.collapsed{padding:var(--space-6) var(--space-2);width:50px}.sidebar-toggle{align-self:flex-end;background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:1.25rem;margin-bottom:var(--space-4);padding:var(--space-1)}.sidebar-toggle:hover{color:var(--text-primary)}.sidebar-header{margin-bottom:var(--space-6)}.sidebar-header h2{color:var(--text-primary);font-size:.85rem;font-weight:600;letter-spacing:.05em;margin:0;text-transform:uppercase}.sidebar-nav{display:flex;flex-direction:column;gap:var(--space-1)}.sidebar-link{border-radius:4px;color:var(--text-secondary);font-size:.9rem;padding:var(--space-2) var(--space-3);text-decoration:none;transition:all .2s}.sidebar-link.active,.sidebar-link:hover{background:var(--bg-card);color:var(--text-primary)}.sidebar-link.active{font-weight:500}.sidebar.collapsed .sidebar-link{padding:var(--space-2);text-align:center}.link-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width:768px){.sidebar{display:none}}.page{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);margin:0 auto;max-width:700px;padding:var(--space-8);pointer-events:auto;width:100%}.page-header{border-bottom:1px solid var(--border-color);margin-bottom:var(--space-8);padding-bottom:var(--space-6)}.page-header h1{font-size:2rem;font-weight:600}.page section{margin-bottom:var(--space-8)}.page h2{font-size:1.5rem;font-weight:600;margin-bottom:var(--space-4)}.page h3{font-size:1.1rem;font-weight:600;margin-bottom:var(--space-3);margin-top:var(--space-6)}.page h3,.page p,.page ul{color:var(--text-secondary)}.page p,.page ul{line-height:1.7}.page ul{padding-left:1.5rem}.page li{margin-bottom:var(--space-2)}.page a{color:var(--text-primary)}.page-image{border:1px solid var(--border-color);border-radius:4px;height:auto;margin:var(--space-6) 0;max-width:100%}.figure-caption{color:var(--text-muted);font-size:.9rem;font-style:italic;margin-top:var(--space-2);text-align:center}.blog-list{list-style:none;margin:0;padding:0}.blog-list li{margin-bottom:var(--space-2)}.blog-list li a{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);display:block;padding:var(--space-4);text-decoration:none;transition:background .2s}.blog-list li a:hover{background:var(--bg-card)}.featured-post{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;margin-bottom:var(--space-6);padding:var(--space-5)}.featured-post h3{color:var(--text-muted);font-size:.8rem;letter-spacing:.05em;margin:0 0 var(--space-3);text-transform:uppercase}.featured-link{align-items:center;color:var(--text-primary);display:flex;font-size:1.25rem;font-weight:600;justify-content:space-between;text-decoration:none}.featured-link:hover{text-decoration:underline}.post-date{color:var(--text-muted);font-size:.85rem;font-weight:400}.recent-header{color:var(--text-muted);font-size:1rem;font-weight:500;margin-bottom:var(--space-4)}.highlight{background:var(--bg-secondary);border-left:3px solid var(--text-primary);margin:var(--space-6) 0;padding:var(--space-4)}@media (max-width:768px){.page{border-radius:4px;margin:0 var(--space-3);padding:var(--space-5)}.page-header h1{font-size:1.5rem}}.project-links{display:flex;flex-wrap:wrap;gap:var(--space-4);margin-bottom:var(--space-6)}.project-link-btn{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);display:inline-flex;font-weight:500;gap:var(--space-2);padding:.8rem 1.5rem;text-decoration:none;transition:all .2s ease}.project-link-btn:hover{background:var(--bg-card);border-color:var(--text-secondary);box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.slideshow-container{border-radius:8px;box-shadow:0 4px 6px #0000001a;margin:2rem auto;max-width:800px;overflow:hidden;position:relative}.slideshow-wrapper{position:relative;width:100%}.slide{animation:fade .5s ease-in-out;display:none}.slide img,.slide.active{display:block}.slide img{height:auto;width:100%}.caption{background:#f9f9f9;color:#666;font-style:italic;margin-top:.5rem;padding:0 1rem 1rem;text-align:center}.next,.prev{background-color:#0000004d;border:none;border-radius:0 3px 3px 0;color:#fff;cursor:pointer;font-size:18px;font-weight:700;margin-top:-22px;padding:16px;position:absolute;top:50%;transition:.6s ease;-webkit-user-select:none;user-select:none;width:auto}.next{border-radius:3px 0 0 3px;right:0}.next:hover,.prev:hover{background-color:#000c}.dots-container{background:#f1f1f1;padding:10px;text-align:center}.dot{background-color:#bbb;border-radius:50%;cursor:pointer;display:inline-block;height:10px;margin:0 4px;transition:background-color .6s ease;width:10px}.active,.dot:hover{background-color:#717171}@keyframes fade{0%{opacity:.4}to{opacity:1}}.home-scroll{margin:0 auto;max-width:700px;width:100%}.hero-section{display:flex;flex-direction:column;justify-content:center;min-height:60vh;padding:var(--space-12) var(--space-4);text-align:center}.profile-pic{border-radius:50%;box-shadow:0 4px 12px #0000004d;display:block;height:100px;margin:0 auto var(--space-6);object-fit:cover;width:100px}.hero-section h1{font-size:2.5rem;margin-bottom:var(--space-4)}.hero-section p{color:var(--text-secondary);font-size:1.1rem;margin:0 auto var(--space-4);max-width:500px}.scroll-hint{animation:bounce 2s infinite;color:var(--text-muted);font-size:.9rem;margin-top:var(--space-8)}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(8px)}}.scroll-section{border-top:1px solid var(--border-color);padding:var(--space-12) var(--space-4)}.scroll-section h2{color:var(--text-primary);font-size:1.5rem;margin-bottom:var(--space-6)}.section-content{display:flex;flex-direction:column;gap:var(--space-4)}.section-link{color:var(--text-muted);display:inline-block;font-size:.9rem;margin-top:var(--space-6)}.section-link:hover{color:var(--text-primary)}.item-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;color:inherit;display:block;padding:var(--space-5);text-decoration:none;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.item-card.clickable:hover{border-color:var(--text-muted);box-shadow:0 4px 12px #0006;transform:translateY(-2px)}.item-card h3{color:var(--text-primary);font-size:1.1rem;margin-bottom:var(--space-2)}.item-card p{color:var(--text-secondary);font-size:.95rem;margin:0}.item-subtitle{color:var(--text-muted);font-size:.9rem;margin-bottom:var(--space-3)}.item-date{color:var(--text-muted);font-size:.8rem}.item-card.compact{align-items:center;display:flex;gap:var(--space-4);padding:var(--space-3) var(--space-4)}.module-code{color:var(--text-primary);font-weight:600;min-width:80px}.module-name{color:var(--text-secondary);flex:1 1}.module-grade{color:var(--text-muted);font-size:.9rem}.module-group{margin-bottom:var(--space-6)}.module-group h4{color:var(--text-muted);font-size:.85rem;letter-spacing:.05em;margin-bottom:var(--space-3);text-transform:uppercase}.funzone-cta{border-top:1px solid var(--border-color);padding:var(--space-12) var(--space-4);text-align:center}.funzone-cta a{color:var(--text-muted);font-size:.9rem}.funzone-cta a:hover{color:var(--text-primary)}.loading{color:var(--text-muted);padding:var(--space-8);text-align:center}@media (max-width:768px){.hero-section{min-height:50vh;padding:var(--space-8) var(--space-4)}.hero-section h1{font-size:2rem}.scroll-section{padding:var(--space-8) var(--space-4)}.item-card.compact{flex-wrap:wrap}.module-name{margin-top:var(--space-1);order:3;width:100%}}.contact-page{margin:0 auto;max-width:500px;text-align:center}.contact-intro{color:var(--text-secondary);font-size:1.1rem;margin-bottom:var(--space-10)}.contact-links{display:flex;flex-wrap:wrap;gap:var(--space-8);justify-content:center}.contact-link{align-items:center;border-radius:8px;color:var(--text-secondary);display:flex;flex-direction:column;gap:var(--space-2);min-width:80px;padding:var(--space-4);text-decoration:none;transition:all .2s ease}.contact-link:hover{background:var(--bg-card);color:var(--text-primary)}.contact-link svg{transition:transform .2s ease}.contact-link:hover svg{transform:scale(1.1)}.contact-link span{font-size:.85rem;font-weight:500}@media (max-width:480px){.contact-links{gap:var(--space-4)}.contact-link{padding:var(--space-3)}}.slot-machine{align-items:center;background:#fff;border-radius:16px;box-shadow:0 10px 25px #0000004d;box-sizing:border-box;display:flex;flex-direction:column;font-family:system-ui,-apple-system,BlinkMacSystemFont,sans-serif;gap:1rem;max-width:400px;padding:2rem;pointer-events:auto;position:relative;width:100%}.slot-machine-header{color:#333;font-size:1.5rem;font-weight:600;margin-bottom:1rem}.slot-machine-description{color:#666;font-size:1rem;margin-bottom:1rem}.reels{background:#222;border-radius:8px;box-shadow:0 4px 12px #00000080;display:flex;gap:.75rem;padding:.75rem 1rem}.reel{align-items:center;background:#111;border:2px solid #555;border-radius:6px;color:#fff;display:flex;font-size:2.5rem;height:70px;justify-content:center;width:70px}.reels--spinning .reel{animation:pulse .2s linear infinite}.machine-interface{gap:0;padding-right:20px}.lever-container,.machine-interface{align-items:center;display:flex;position:relative}.lever-container{cursor:pointer;flex-direction:column;height:120px;justify-content:flex-end;margin-left:-5px;width:40px;z-index:5}.cost-label{align-items:center;background:#f5f5f5;border:1px solid #ddd;border-radius:6px;bottom:-25px;box-shadow:0 1px 3px #0000001a;color:#888;display:flex;font-size:.8rem;font-weight:700;gap:2px;left:50%;padding:2px 6px;pointer-events:none;position:absolute;transform:translateX(-50%);white-space:nowrap}.cost-icon{display:block;height:14px;object-fit:contain;width:14px}.lever-container:hover .lever-knob{box-shadow:0 0 15px #ff572299;filter:brightness(1.2)}.lever-base{background:linear-gradient(90deg,#333,#666,#333);border:1px solid #222;border-radius:0 10px 10px 0;bottom:20px;box-shadow:2px 2px 5px #00000080;height:40px;left:0;position:absolute;width:20px}.lever-arm{height:100%;position:relative;transform-origin:0 80%;transition:transform .3s cubic-bezier(.68,-.55,.27,1.55);width:100%}.lever-arm--pulled{pointer-events:none;transform:rotateX(180deg) scaleY(.8);transition:transform .1s ease-in}.lever-stick{background:linear-gradient(90deg,#ccc,#fff,#999);border-radius:4px;bottom:30px;box-shadow:1px 1px 3px #0000004d;height:70px;left:10px;position:absolute;width:8px}.lever-knob{background:radial-gradient(circle at 30% 30%,#ff5722,#bf360c);border-radius:50%;box-shadow:0 4px 6px #0006,inset 0 -2px 5px #0003;cursor:pointer;height:32px;left:-2px;position:absolute;top:5px;width:32px}.slot-machine button{display:none}.message{padding:.5rem 1rem}.fun-fact-list{border-top:1px solid #eee;margin-top:1rem;padding-top:1rem;text-align:left;width:100%}.fun-fact-list h3{color:#888;font-size:.9rem;letter-spacing:1px;margin-bottom:.5rem;text-transform:uppercase}.fun-fact-list ul{display:flex;flex-direction:column;gap:.5rem;list-style:none;margin:0;max-height:150px;overflow-y:auto;padding:0}.fun-fact-item{animation:slideDown .3s ease-out;background:#f9f9f9;border:1px solid #eee;border-radius:8px;color:#444;font-size:.95rem;padding:.8rem}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%{transform:translateY(0)}50%{transform:translateY(-4px)}to{transform:translateY(0)}}.tik-tac-toe{align-items:center;background:#fff;border-radius:16px;box-shadow:0 10px 25px #0000004d;box-sizing:border-box;display:flex;flex-direction:column;font-family:system-ui,-apple-system,BlinkMacSystemFont,sans-serif;gap:1rem;max-width:400px;padding:2rem;pointer-events:auto;position:relative;width:100%}.tik-tac-toe-header{color:#333;font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.tik-tac-toe-description{color:#666;font-size:1rem;margin-bottom:1rem;text-align:center}.board{background:#222;border-radius:12px;box-shadow:0 4px 12px #00000080;flex-direction:column;margin-bottom:1rem;padding:1rem}.board,.row{display:flex;gap:.75rem}.square{align-items:center;background:#111;border:2px solid #444;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:2.5rem;height:80px;justify-content:center;line-height:1;padding:0;transition:all .2s ease;width:80px}.square:hover:not(:disabled){background:#1a1a1a;border-color:#ff5722;transform:scale(1.05)}.square--x{color:#4cc9f0;text-shadow:0 0 10px #4cc9f080}.square--o{color:#f72585;text-shadow:0 0 10px #f7258580}.message{border-radius:8px;box-sizing:border-box;font-weight:500;min-height:1.5rem;padding:.75rem 1rem;text-align:center;transition:all .3s ease;width:100%}.message--neutral{background-color:#f5f5f5;color:#666}.message--success{background-color:#e8f5e9;border:1px solid #c8e6c9;color:#2e7d32}.message--failure{background-color:#ffebee;border:1px solid #ffcdd2;color:#c62828}.reset-btn{background:#222;border:none;border-radius:8px;box-shadow:0 4px 6px #0000001a;color:#fff;cursor:pointer;font-weight:600;margin-top:1rem;padding:.75rem 1.5rem;transition:all .2s ease}.reset-btn:hover{background:#444;box-shadow:0 6px 12px #00000026;transform:translateY(-2px)}.reset-btn:active{transform:translateY(0)}
/*# sourceMappingURL=main.fad0fa19.css.map*/