:root{--bg: #060807;--bg-soft: #0c1110;--bg-grad: radial-gradient(ellipse at 50% 0%, #0a1410 0%, #060807 65%);--card: rgba(14, 18, 16, .62);--card-strong: #0e1614;--card-border: rgba(0, 255, 136, .16);--text: #e8eee6;--text-soft: #b8c0b4;--muted: #7c8c80;--line: rgba(0, 255, 136, .12);--accent: #00ff88;--accent-2: #f4b400;--accent-3: #66d0a0;--accent-warn: #f4b400;--accent-danger: #ff4747;--radius: 18px;--radius-sm: 10px;--shadow-card: 0 24px 60px rgba(0, 0, 0, .62), 0 0 0 1px rgba(0, 255, 136, .03);--shadow-glow: 0 0 60px rgba(0, 255, 136, .1);--transition: .3s cubic-bezier(.4, 0, .2, 1);--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--font-mono: "JetBrains Mono", "Fira Code", "Courier New", monospace;--font-display: "Space Grotesk", system-ui, sans-serif;--font-sans: "Manrope", system-ui, -apple-system, sans-serif}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:auto}body{font-family:var(--font-sans);font-weight:400;line-height:1.65;color:var(--text);background:var(--bg);background-image:var(--bg-grad);background-attachment:fixed;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;letter-spacing:-.005em}a{color:inherit}body.has-custom-cursor,body.has-custom-cursor *{cursor:none!important}::selection{background:#00ff8852;color:#0a0908}html.lenis,html.lenis body{height:auto}.lenis.lenis-smooth{scroll-behavior:auto!important}.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}.lenis.lenis-stopped{overflow:clip}.cursor-ring{position:fixed;top:0;left:0;width:36px;height:36px;border:1.5px solid rgba(0,255,136,.7);border-radius:50%;pointer-events:none;z-index:99999;opacity:0;mix-blend-mode:difference;transition:width .25s var(--ease-out-expo),height .25s var(--ease-out-expo),border-color .25s var(--transition),background .25s var(--transition),opacity .2s ease;display:flex;align-items:center;justify-content:center}.cursor-ring .crosshair-h,.cursor-ring .crosshair-v{position:absolute;background:#00ff88d9;pointer-events:none}.cursor-ring .crosshair-h{width:6px;height:1px;left:50%;top:50%;transform:translate(-50%,-50%)}.cursor-ring .crosshair-v{width:1px;height:6px;left:50%;top:50%;transform:translate(-50%,-50%)}.cursor-ring.cursor-active{width:64px;height:64px;border-color:#00ff88f2;background:#00ff880f;box-shadow:0 0 30px #00ff8826,inset 0 0 20px #00ff8814}.cursor-ring.cursor-active .crosshair-h{width:12px}.cursor-ring.cursor-active .crosshair-v{height:12px}.cursor-dot{position:fixed;top:0;left:0;width:5px;height:5px;background:var(--accent);border-radius:50%;pointer-events:none;z-index:99999;opacity:0;box-shadow:0 0 10px var(--accent);transition:opacity .2s ease}.status-bar{position:fixed;top:0;left:0;width:100%;z-index:1000;pointer-events:none;font-family:var(--font-mono)}.status-bar-progress{height:1px;background:linear-gradient(90deg,var(--accent),var(--accent-2),var(--accent-3));box-shadow:0 0 8px #00ff8880;transition:width .05s linear;width:0}.status-bar-row{display:flex;justify-content:space-between;gap:1rem;padding:6px 16px;font-size:.66rem;color:#7d8db3cc;letter-spacing:.12em;background:linear-gradient(180deg,#0a0908cc,#0a090800)}.status-cell{display:inline-flex;align-items:center;gap:6px}.status-bar .status-dot{width:6px;height:6px;background:var(--accent);border-radius:50%;box-shadow:0 0 8px var(--accent);animation:pulse-dot 2s ease-in-out infinite}.scene3d-fixed{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;transition:opacity .18s linear}.scene3d-fixed canvas{width:100%!important;height:100%!important}#particle-canvas{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;opacity:.5}.grain-overlay{position:fixed;top:-50%;right:-50%;bottom:-50%;left:-50%;width:200%;height:200%;z-index:9998;pointer-events:none;mix-blend-mode:overlay;image-rendering:pixelated;opacity:.07}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,255,136,.012) 2px,rgba(0,255,136,.012) 4px);pointer-events:none;z-index:9997}.hud-corner{position:fixed;width:48px;height:48px;z-index:10;pointer-events:none;opacity:.18;transition:opacity .5s ease}.hud-corner--tl{top:28px;left:12px;border-top:1px solid var(--accent);border-left:1px solid var(--accent)}.hud-corner--tr{top:28px;right:12px;border-top:1px solid var(--accent);border-right:1px solid var(--accent)}.hud-corner--bl{bottom:12px;left:12px;border-bottom:1px solid var(--accent);border-left:1px solid var(--accent)}.hud-corner--br{bottom:12px;right:12px;border-bottom:1px solid var(--accent);border-right:1px solid var(--accent)}.container{width:min(1240px,92vw);margin:0 auto;position:relative;z-index:2}.navbar{position:sticky;top:22px;z-index:999;background:transparent}.nav-container{height:60px;display:flex;justify-content:space-between;align-items:center;padding:0 18px;border-radius:999px;border:1px solid rgba(0,255,136,.12);background:#0a09088c;backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4)}.brand{text-decoration:none;font-family:var(--font-mono);font-weight:600;font-size:.86rem;letter-spacing:.04em;display:inline-flex;align-items:center;gap:.6rem;transition:opacity var(--transition);text-transform:uppercase}.brand:hover{opacity:.85}.brand-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px var(--accent),0 0 30px #00ff8859;animation:pulse-dot 2.5s ease-in-out infinite}@keyframes pulse-dot{0%,to{box-shadow:0 0 12px var(--accent),0 0 30px #00ff884d}50%{box-shadow:0 0 22px var(--accent),0 0 56px #00ff888c}}.nav-menu{list-style:none;display:flex;gap:1.4rem}.nav-link{text-decoration:none;color:var(--muted);font-family:var(--font-mono);font-size:.74rem;font-weight:500;position:relative;padding:4px 0;transition:color var(--transition);letter-spacing:.1em;text-transform:uppercase}.nav-link:before{content:"";position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--accent);transition:width var(--transition);box-shadow:0 0 8px var(--accent)}.nav-link:hover:before,.nav-link.active:before{width:100%}.nav-link:hover,.nav-link.active{color:var(--accent)}.hamburger{display:none;border:1px solid var(--line);border-radius:8px;width:38px;height:38px;background:transparent;align-items:center;justify-content:center;cursor:pointer;transition:border-color var(--transition)}.hamburger:hover{border-color:var(--accent)}.hamburger .bar{width:16px;height:1.5px;background:var(--text);position:relative}.hamburger .bar:before,.hamburger .bar:after{content:"";position:absolute;left:0;width:16px;height:1.5px;background:var(--text)}.hamburger .bar:before{top:-5px}.hamburger .bar:after{top:5px}main{min-height:80vh;position:relative;z-index:1;padding-bottom:40px}.reveal{opacity:0;transform:translateY(36px);transition:opacity .9s var(--ease-out-expo),transform .9s var(--ease-out-expo)}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-stagger>*:nth-child(1){transition-delay:0s}.reveal-stagger>*:nth-child(2){transition-delay:.08s}.reveal-stagger>*:nth-child(3){transition-delay:.16s}.reveal-stagger>*:nth-child(4){transition-delay:.24s}.reveal-stagger>*:nth-child(5){transition-delay:.32s}.reveal-stagger>*:nth-child(6){transition-delay:.4s}.hero-cinema{min-height:100vh;position:relative}.hero-cinema-grid{display:flex;flex-direction:column;justify-content:space-between;min-height:100vh;padding:clamp(110px,13vh,150px) 0 4vh;gap:2rem;width:100%;position:relative}.hero-cinema-top{display:flex;flex-direction:column;align-items:center;gap:1.5rem;width:100%;max-width:100%;text-align:center}.hero-cinema-bottom{display:flex;flex-direction:column;align-items:center;gap:1.6rem;text-align:center}.hero-kicker{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:.74rem;letter-spacing:.18em;color:var(--accent);text-transform:uppercase;font-weight:500;width:max-content;padding:7px 14px;border:1px solid rgba(0,255,136,.22);border-radius:999px;background:#00ff880a;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.hero-kicker svg{width:13px;height:13px}.hero-kicker-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);animation:pulse-dot 2s ease-in-out infinite}.hero-display{font-family:var(--font-display);font-weight:700;font-size:clamp(2.6rem,10.5vw,9.5rem);line-height:.92;letter-spacing:-.055em;margin:0;display:block;width:100%;text-align:center;filter:drop-shadow(0 0 50px rgba(0,255,136,.14))}.hero-display-line{display:block;text-align:center;background:linear-gradient(120deg,#fff,#f4b400 55%,#0f8);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.hero-display-line--shift{background:linear-gradient(120deg,#0f8,#f4b400 55%,#fff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 60px rgba(0,255,136,.32))}.scramble{font-variant-ligatures:none;font-feature-settings:"tnum"}.hero-tagline{max-width:70ch;font-size:clamp(1rem,1.4vw,1.18rem);line-height:1.6;color:var(--text-soft);margin:.5rem auto 0;font-weight:400;text-align:center}.text-accent{color:var(--accent);font-weight:500}.glitch{position:relative;display:inline-block}.glitch:before,.glitch:after{content:attr(data-text);position:absolute;top:0;left:0;width:100%;overflow:hidden;pointer-events:none}.glitch:before{animation:glitch-top 3s infinite linear alternate-reverse;clip-path:inset(0 0 65% 0);color:var(--accent);opacity:.85;text-shadow:-1px 0 var(--accent)}.glitch:after{animation:glitch-bottom 2.4s infinite linear alternate-reverse;clip-path:inset(60% 0 0 0);color:var(--accent-2);opacity:.8;text-shadow:1px 0 var(--accent-2)}@keyframes glitch-top{0%{transform:translate(0)}20%{transform:translate(-2px,2px)}40%{transform:translate(-3px,-2px)}60%{transform:translate(2px,1px)}80%{transform:translate(2px,-2px)}to{transform:translate(0)}}@keyframes glitch-bottom{0%{transform:translate(0)}20%{transform:translate(2px,-2px)}40%{transform:translate(3px,1px)}60%{transform:translate(-2px,-2px)}80%{transform:translate(-2px,2px)}to{transform:translate(0)}}.hero-cta-row{display:flex;gap:.9rem;flex-wrap:wrap;margin-top:.5rem;justify-content:center}.hero-meta-row{display:flex;gap:2.4rem;margin-top:1.4rem;padding-top:1.4rem;border-top:1px solid var(--line);flex-wrap:wrap;justify-content:center}.hero-meta{display:flex;flex-direction:column;gap:4px}.meta-num{font-family:var(--font-mono);font-size:1.7rem;font-weight:600;color:var(--accent);letter-spacing:-.02em;line-height:1}.meta-label{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}.hero-scroll-hint{display:flex;flex-direction:column;align-items:center;gap:10px;font-family:var(--font-mono);font-size:.64rem;letter-spacing:.3em;color:var(--muted)}.scroll-line{width:1px;height:60px;background:linear-gradient(180deg,var(--accent) 0%,transparent 100%);position:relative;overflow:hidden}.scroll-line:after{content:"";position:absolute;top:-30px;left:0;width:100%;height:30px;background:var(--accent);box-shadow:0 0 8px var(--accent);animation:scroll-pulse 2.4s ease-in-out infinite}@keyframes scroll-pulse{0%{top:-30px}to{top:60px}}.magnetic{display:inline-block;will-change:transform}.section{padding:80px 0;position:relative}.section-cinema{background:linear-gradient(180deg,#0a090800,#0a09088c 12%,#0a0908d9);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.section-cinema:first-of-type{background:linear-gradient(180deg,#0a090800,#0a090880 15%,#0a0908eb)}.section-head{display:grid;grid-template-columns:auto 1fr;align-items:baseline;gap:18px 24px;margin-bottom:30px}.section-num{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.2em;color:var(--accent);position:relative;padding-right:18px;text-transform:uppercase}.section-num:after{content:"";position:absolute;right:0;top:50%;width:1px;height:18px;background:var(--accent);transform:translateY(-50%);opacity:.5}.section-display{font-family:var(--font-display);font-weight:700;font-size:clamp(2rem,5vw,3.6rem);line-height:1;letter-spacing:-.04em;color:var(--text);display:flex;align-items:center;gap:14px;background:linear-gradient(180deg,#fff,#b8b4ae);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.section-display svg{width:.7em;height:.7em;color:var(--accent);flex-shrink:0;filter:drop-shadow(0 0 10px rgba(0,255,136,.4));-webkit-text-fill-color:var(--accent)}.section-lead{grid-column:2;color:var(--muted);font-size:1rem;margin:0;max-width:70ch}.section-lead code{font-family:var(--font-mono);font-size:.92em;background:#00ff8814;border:1px solid rgba(0,255,136,.2);border-radius:4px;padding:1px 6px;color:var(--accent)}.section-title{margin-bottom:8px;font-size:clamp(1.4rem,2.4vw,1.9rem);display:flex;align-items:center;gap:12px}.section-title svg{width:24px;height:24px;color:var(--accent);filter:drop-shadow(0 0 6px rgba(0,255,136,.5))}.hero{padding:96px 0 56px;position:relative}.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:1.6rem;align-items:stretch}.hero-grid-widget{grid-template-columns:1.2fr 1fr;min-height:380px}.hero-widget-stage{position:relative;border-radius:var(--radius);background:radial-gradient(circle at center,rgba(0,255,136,.07),transparent 65%),linear-gradient(180deg,#f4b4000a,#0000),var(--card-strong);border:1px solid rgba(0,255,136,.2);overflow:hidden;box-shadow:var(--shadow-card),0 0 80px #00ff8814,inset 0 1px #00ff8814;min-height:360px}.hero-widget{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.hero-widget canvas{width:100%!important;height:100%!important}.widget-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:2;background:linear-gradient(180deg,transparent 70%,rgba(10,9,8,.5) 100%)}.widget-label{position:absolute;bottom:14px;left:16px;font-family:var(--font-mono);font-size:.68rem;color:var(--accent);letter-spacing:.1em;text-transform:uppercase;padding:5px 11px;border:1px solid rgba(0,255,136,.25);border-radius:999px;background:#0a090880;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.widget-label:before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);margin-right:8px;vertical-align:middle;animation:pulse-dot 2s ease-in-out infinite}.hero-title{font-family:var(--font-display);font-size:clamp(1.85rem,3.6vw,2.9rem);line-height:1.1;letter-spacing:-.03em;background:linear-gradient(180deg,#fff,#b8b4ae);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:18px}.kicker{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(0,255,136,.22);border-radius:999px;padding:7px 14px;color:var(--accent);font-size:.74rem;font-family:var(--font-mono);font-weight:500;margin-bottom:18px;background:#00ff880a;letter-spacing:.16em;text-transform:uppercase}.kicker svg{width:13px;height:13px}.hero-stats{display:flex;gap:1.6rem;margin-top:26px;padding-top:22px;border-top:1px solid var(--line);flex-wrap:wrap}.hero-stat{display:flex;flex-direction:column;gap:3px}.hero-stat strong{font-family:var(--font-mono);font-size:1.6rem;font-weight:600;color:var(--accent);letter-spacing:-.02em;line-height:1}.hero-stat span{font-size:.7rem;color:var(--muted);font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase}h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;letter-spacing:-.025em;line-height:1.15}h1{font-size:clamp(2rem,4.2vw,3.4rem);margin-bottom:16px}h2{font-size:clamp(1.4rem,2.4vw,1.9rem)}h3{font-size:1.18rem;margin-bottom:10px}h4{font-size:1rem;margin-bottom:8px}.lead{color:var(--text-soft);max-width:64ch;line-height:1.75;font-size:1.02rem}.lead strong{color:var(--accent);font-weight:600}.typing-cursor{display:inline-block;width:3px;height:1em;background:var(--accent);margin-left:3px;vertical-align:text-bottom;animation:blink-cursor .7s step-end infinite;box-shadow:0 0 10px var(--accent)}@keyframes blink-cursor{0%,to{opacity:1}50%{opacity:0}}.btn-row{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:28px;align-items:center}.btn{display:inline-flex;align-items:center;gap:10px;text-decoration:none;border-radius:999px;padding:13px 24px;font-family:var(--font-mono);font-weight:600;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;border:1px solid transparent;transition:transform var(--transition),box-shadow var(--transition),background var(--transition),border-color var(--transition);cursor:pointer;position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.2) 50%,transparent 70%);transform:translate(-100%);transition:transform .7s ease}.btn:hover:before{transform:translate(100%)}.btn:hover{transform:translateY(-1px)}.btn-arrow{display:inline-block;transition:transform var(--transition);font-family:var(--font-mono)}.btn:hover .btn-arrow{transform:translate(3px)}.btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#0a0908;box-shadow:0 4px 24px #00ff8840,inset 0 0 0 1px #ffffff2e}.btn.primary:hover{box-shadow:0 8px 36px #00ff8873,inset 0 0 0 1px #ffffff47}.btn.secondary{border-color:var(--line);color:var(--text);background:#ffffff06;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.btn.secondary:hover{border-color:var(--accent);box-shadow:0 8px 30px #00ff881f;color:var(--accent)}.grid{display:grid;gap:1.2rem}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.tilt-card{perspective:1200px;position:relative;display:block}.tilt-card-inner{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-card);transition:transform .4s var(--ease-out-expo),border-color var(--transition),box-shadow var(--transition);transform:rotateX(var(--tilt-x, 0deg)) rotateY(var(--tilt-y, 0deg));transform-style:preserve-3d;position:relative;overflow:hidden;height:100%;backdrop-filter:blur(14px) saturate(1.2);-webkit-backdrop-filter:blur(14px) saturate(1.2)}.tilt-card-inner:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius);opacity:0;background:radial-gradient(600px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),rgba(0,255,136,.12),transparent 40%);transition:opacity var(--transition);pointer-events:none}.tilt-card-inner:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius);opacity:0;background:linear-gradient(var(--shimmer-angle, 105deg),transparent 30%,rgba(0,255,136,.06) 45%,rgba(244,180,0,.05) 55%,transparent 70%);background-size:200% 200%;background-position:var(--shimmer-pos, 0% 50%);transition:opacity var(--transition);pointer-events:none;mix-blend-mode:screen}.tilt-card:hover .tilt-card-inner:before{opacity:1}.tilt-card:hover .tilt-card-inner:after{opacity:1}.tilt-card:hover .tilt-card-inner{border-color:#00ff884d;box-shadow:0 28px 80px #000000a6,0 0 60px #00ff8814}.tilt-card-inner>*{transform:translateZ(20px)}.tilt-card.highlight .tilt-card-inner{background:linear-gradient(150deg,#00ff880f,#8888880d,#f4b4000a),var(--card-strong);border-color:#00ff882e}.card-icon{width:44px;height:44px;border-radius:12px;background:#00ff8814;border:1px solid rgba(0,255,136,.2);display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--accent);box-shadow:0 0 16px #00ff881a}.card-icon svg{width:20px;height:20px}.card-icon.purple{background:#f4b40014;border-color:#f4b40033;color:var(--accent-3);box-shadow:0 0 16px #f4b4001a}.card-icon.blue{background:#88888814;border-color:#8883;color:var(--accent-2);box-shadow:0 0 16px #8888881a}.tilt-card-inner h2,.tilt-card-inner h3{margin-bottom:10px}.tilt-card-inner p{color:var(--text-soft);line-height:1.7}.fyp-section{position:relative;padding:84px 0}.fyp-section:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 50% 50% at 30% 0%,rgba(244,180,0,.08),transparent),radial-gradient(ellipse 50% 50% at 70% 100%,rgba(0,255,136,.08),transparent);pointer-events:none;z-index:-1}.fyp-kicker{background:#f4b4000f;border-color:#f4b40040;color:var(--accent-3)}.fyp-title{font-family:var(--font-display);font-weight:700;font-size:clamp(2.4rem,5.5vw,4.2rem);letter-spacing:-.04em;margin-bottom:8px;background:linear-gradient(120deg,var(--accent) 0%,var(--accent-2) 50%,var(--accent-3) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 30px rgba(244,180,0,.2))}.fyp-tagline{font-size:clamp(1rem,1.6vw,1.2rem);color:var(--text-soft);max-width:60ch;margin-bottom:32px;line-height:1.6}.fyp-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:1.4rem;align-items:stretch}.fyp-side{display:flex;flex-direction:column;gap:1.2rem}.fyp-overview .tilt-card-inner{display:flex;flex-direction:column}.fyp-stack{display:flex;gap:8px;flex-wrap:wrap;margin:22px 0}.fyp-meta{margin-top:auto;padding-top:22px;border-top:1px solid var(--line);display:grid;gap:12px}.fyp-meta>div{display:grid;grid-template-columns:110px 1fr;gap:12px;align-items:baseline}.meta-label{font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}.meta-value{color:var(--text-soft);font-size:.92rem}.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:14px}.stat{border-left:2px solid var(--accent);padding:4px 0 4px 12px}.stat-value{font-family:var(--font-mono);font-weight:700;font-size:1.6rem;color:var(--text);line-height:1.1;letter-spacing:-.02em}.stat-unit{font-family:var(--font-mono);font-size:.7rem;color:var(--accent);letter-spacing:.1em;text-transform:uppercase;margin-top:2px}.stat-label{font-size:.78rem;color:var(--muted);margin-top:4px}.arch-list{list-style:none;display:flex;flex-direction:column;gap:14px;margin-top:14px}.arch-list li{display:grid;grid-template-columns:36px 1fr;gap:12px;align-items:start;padding:10px 12px;border:1px solid var(--line);border-radius:12px;background:#ffffff05;transition:border-color var(--transition),background var(--transition)}.arch-list li:hover{border-color:#00ff8840;background:#00ff8808}.arch-list li svg{width:18px;height:18px;color:var(--accent);margin-top:2px}.arch-list li>div{display:flex;flex-direction:column;gap:2px}.arch-list li strong{font-size:.92rem;color:var(--text)}.arch-list li span{font-size:.82rem;color:var(--muted);font-family:var(--font-mono);letter-spacing:.01em}.project-featured .tilt-card-inner{background:linear-gradient(135deg,#f4b40012,#00ff880a),var(--card-strong);border-color:#f4b40040;padding:40px}.featured-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:2rem;align-items:start}.featured-title{font-size:clamp(1.6rem,2.6vw,2.1rem);margin:12px 0 14px;letter-spacing:-.025em}.featured-desc{color:var(--text-soft);line-height:1.75;margin-bottom:18px}.featured-side{display:flex;flex-direction:column;gap:14px;padding-left:24px;border-left:1px solid rgba(244,180,0,.2)}.featured-stat{display:flex;flex-direction:column;gap:2px}.featured-stat .stat-number{font-family:var(--font-mono);font-weight:700;font-size:1.9rem;color:var(--accent);letter-spacing:-.02em;line-height:1}.featured-stat .stat-text{font-size:.84rem;color:var(--muted);font-family:var(--font-mono)}.status-badge{display:inline-flex;align-items:center;gap:6px;font-size:.7rem;font-family:var(--font-mono);font-weight:500;margin-top:14px;color:var(--accent);letter-spacing:.1em;text-transform:uppercase}.status-badge:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent);animation:pulse-dot 2s ease-in-out infinite}.status-badge.featured{color:var(--accent-3)}.status-badge.featured:before{background:var(--accent-3);box-shadow:0 0 10px var(--accent-3)}.status-badge.progress{color:var(--accent-2)}.status-badge.progress:before{background:var(--accent-2);box-shadow:0 0 10px var(--accent-2)}.tag-row{margin-top:16px;display:flex;gap:6px;flex-wrap:wrap}.tag{border:1px solid var(--line);border-radius:999px;font-size:.7rem;font-family:var(--font-mono);font-weight:500;color:var(--accent);padding:4px 11px;background:#00ff880a;transition:background var(--transition),border-color var(--transition),box-shadow var(--transition),color var(--transition);letter-spacing:.04em;text-transform:uppercase}.tag:hover{background:#00ff881a;border-color:#00ff8859;box-shadow:0 0 12px #00ff8826}.meta{margin-top:12px;color:#6b7a9e;font-size:.82rem;font-family:var(--font-mono);letter-spacing:.01em}.list{list-style:none;display:grid;gap:10px}.list li{padding-left:22px;position:relative;color:var(--text-soft);line-height:1.6}.list li:before{content:">";position:absolute;left:0;color:var(--accent);font-family:var(--font-mono);font-weight:700}.timeline-item{border-left:2px solid var(--line);padding-left:18px;margin-bottom:18px;transition:border-color var(--transition);position:relative}.timeline-item:before{content:"";position:absolute;left:-5px;top:8px;width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px var(--accent);opacity:0;transition:opacity var(--transition)}.timeline-item:hover{border-left-color:var(--accent)}.timeline-item:hover:before{opacity:1}.timeline-item h4{margin-bottom:4px}.timeline-item p{color:var(--text-soft)}.timeline-item:last-child{margin-bottom:0}.terminal-widget{background:#0a0e1aeb;border:1px solid rgba(0,255,136,.18);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card),0 0 50px #00ff880f,inset 0 1px #00ff880f;font-family:var(--font-mono);font-size:.82rem;line-height:1.6;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.terminal-bar{display:flex;align-items:center;gap:6px;padding:10px 14px;background:#0a0908;border-bottom:1px solid rgba(0,255,136,.18)}.terminal-dot{width:11px;height:11px;border-radius:50%}.terminal-dot.red{background:#ff5f57;box-shadow:0 0 6px #ff5f5780}.terminal-dot.yellow{background:#febc2e;box-shadow:0 0 6px #febc2e80}.terminal-dot.green{background:#28c840;box-shadow:0 0 6px #28c84080}.terminal-title{margin-left:10px;color:#6b7a9e;font-size:.76rem;letter-spacing:.02em}.terminal-body{padding:16px;max-height:360px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(0,255,136,.25) transparent}.terminal-body::-webkit-scrollbar{width:4px}.terminal-body::-webkit-scrollbar-track{background:transparent}.terminal-body::-webkit-scrollbar-thumb{background:#00ff8840;border-radius:2px}.terminal-line{white-space:pre-wrap;word-break:break-word}.terminal-prompt{color:var(--accent);font-weight:700}.terminal-cmd{color:var(--text)}.terminal-output{color:var(--text-soft);padding-left:4px;margin-bottom:8px}.terminal-output.success{color:var(--accent)}.terminal-output.error{color:#ff6b6b}.terminal-output.info{color:var(--accent-2)}.terminal-cursor{color:var(--accent);animation:blink-terminal .8s step-end infinite}@keyframes blink-terminal{0%,to{opacity:1}50%{opacity:0}}.terminal-input-line{display:flex;align-items:center;gap:0;margin-top:4px}.terminal-input{background:transparent;border:none;color:var(--text);font-family:var(--font-mono);font-size:.82rem;outline:none;flex:1;caret-color:var(--accent)}.terminal-input::placeholder{color:#8494b866}.terminal-ascii{color:var(--accent);opacity:.92;line-height:1.2;margin-bottom:8px;font-family:var(--font-mono)}.footer{border-top:1px solid var(--line);padding:36px 0 44px;color:var(--muted);font-size:.86rem;position:relative;z-index:2;background:#0a0908b3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.footer-row{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}.footer a{color:var(--text);text-decoration:none;transition:color var(--transition)}.footer a:hover{color:var(--accent)}.footer-brand{font-family:var(--font-mono);font-size:.76rem;color:#00ff8873;margin-top:4px;letter-spacing:.08em;text-transform:uppercase}@media(max-width:980px){.hero-grid,.grid.two,.grid.three,.fyp-grid,.featured-grid{grid-template-columns:1fr}.hero-display{font-size:clamp(2.6rem,13vw,5.4rem)}.featured-side{padding-left:0;padding-top:22px;border-left:none;border-top:1px solid rgba(244,180,0,.2)}.stat-grid{grid-template-columns:1fr}.hamburger{display:inline-flex}.nav-menu{position:absolute;top:70px;right:0;width:min(280px,88vw);padding:16px;border:1px solid var(--line);border-radius:18px;background:#0a0908f5;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);display:none;flex-direction:column;gap:.9rem}.nav-menu.open{display:flex;animation:slideDown .25s ease-out}.hud-corner,.hero-scroll-hint{display:none}}@media(max-width:600px){.hero{padding:64px 0 36px}.section{padding:48px 0}.tilt-card-inner{padding:22px}.project-featured .tilt-card-inner{padding:26px}.hero-meta-row{gap:1rem}.meta-num{font-size:1.3rem}.nav-container{padding:0 14px}.navbar{top:12px}.grain-overlay{display:none}.status-bar-row{padding:4px 10px;font-size:.6rem}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation:none!important;transition-duration:.01ms!important}.reveal{opacity:1;transform:none}.tilt-card-inner{transform:none!important}.scene3d-fixed,.grain-overlay{display:none}}@media print{#particle-canvas,.scene3d-fixed,.hud-corner,.grain-overlay,.cursor-ring,.cursor-dot,.status-bar{display:none}body{background:#fff;color:#000}}
