@import "https://fonts.googleapis.com/css2?family=Share+Tech+Mono&family=Orbitron:wght@400;700&display=swap";body{margin:0;padding:0}#root{min-height:100vh}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--green:#0f8;--green-dim:#00ff8880;--green-faint:#00ff8814;--green-border:#0f83;--bg:#000}body{background:var(--bg);color:var(--green);font-family:Share Tech Mono,monospace;font-size:15px;line-height:1.7;overflow-x:hidden}body:after{content:"";pointer-events:none;z-index:999;background:repeating-linear-gradient(0deg,#0000,#0000 2px,#00000012 2px 4px);position:fixed;inset:0}main{padding-top:56px}section{border-bottom:1px solid var(--green-border);padding:80px 8vw}footer{color:#00ff884d;justify-content:space-between;padding:20px 8vw;font-size:11px;display:flex}.hero{flex-direction:column;justify-content:center;align-items:flex-start;min-height:100vh;display:flex}.hero-label{color:var(--green-dim);letter-spacing:3px;margin-bottom:16px;font-size:12px}.hero-name{letter-spacing:4px;margin-bottom:16px;font-family:Orbitron,monospace;font-size:clamp(48px,8vw,96px);font-weight:700;line-height:1.1;animation:5s infinite glitch}.hero-role{color:var(--green-dim);letter-spacing:2px;margin-bottom:32px;font-size:15px}.hero-desc{color:#00ff88b3;max-width:600px;margin-bottom:40px;font-size:15px;line-height:1.9}.hero-desc span{color:var(--green)}.hero-buttons{flex-wrap:wrap;gap:12px;display:flex}.btn{border:1px solid var(--green-border);color:var(--green-dim);letter-spacing:2px;padding:12px 28px;font-family:Share Tech Mono,monospace;font-size:13px;text-decoration:none;transition:all .2s;display:inline-block}.btn:hover{background:var(--green-faint);color:var(--green);border-color:var(--green)}.cursor{animation:1s step-end infinite blink}@keyframes blink{50%{opacity:0}}@keyframes glitch{0%,92%,to{text-shadow:none}93%{text-shadow:-2px 0 #f05,2px 0 #0ff}95%{text-shadow:2px 0 #f05,-2px 0 #0ff}97%{text-shadow:none}}.section-header{color:var(--green-dim);letter-spacing:3px;align-items:center;gap:12px;margin-bottom:40px;font-size:11px;display:flex}.section-header:after{content:"";background:var(--green-border);flex:1;height:1px}.projects-grid{grid-template-columns:repeat(auto-fit,minmax(340px,1fr));align-items:start;gap:24px;display:grid}.card{border:1px solid var(--green-border);background:var(--green-faint);padding:24px;transition:border-color .2s;position:relative}.card:hover{border-color:var(--green)}.card:before{content:"";background:var(--green);width:3px;height:100%;position:absolute;top:0;left:0}.card-wip{opacity:.45;border-style:dashed}.card-award{letter-spacing:2px;color:var(--green);border:1px solid var(--green-border);background:var(--green-faint);margin-bottom:10px;padding:3px 8px;font-size:10px;display:inline-block}.card-title{letter-spacing:1px;margin-bottom:4px;font-family:Orbitron,monospace;font-size:14px}.card-subtitle{color:var(--green-dim);letter-spacing:1px;margin-bottom:10px;font-size:12px}.card-desc{color:#00ff88a6;margin-bottom:16px;font-size:13px;line-height:1.8}.tags{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.tag{border:1px solid var(--green-border);color:var(--green-dim);background:var(--green-faint);padding:3px 10px;font-size:11px}.status{align-items:center;gap:6px;font-size:12px;display:flex}.status-live{color:var(--green)}.status-live a{color:var(--green);text-decoration:none}.status-live a:hover{text-decoration:underline}.status-pending{color:#fa0}.status-hardware{color:#0cf}.status-wip{color:var(--green-dim)}.dot{background:var(--green);border-radius:50%;width:7px;height:7px;animation:1.5s ease-in-out infinite pulse;display:inline-block}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.skill-groups{grid-template-columns:repeat(2,1fr);gap:40px 60px;display:grid}.skill-group{margin-bottom:8px}.skill-category{letter-spacing:3px;color:var(--green);border-bottom:1px solid var(--green-border);margin-bottom:16px;padding-bottom:6px;font-size:10px}.skill-item{margin-bottom:14px}.skill-label{color:var(--green-dim);justify-content:space-between;margin-bottom:6px;font-size:13px;display:flex}.skill-track{background:var(--green-border);height:3px}.skill-fill{background:var(--green);height:100%}.timeline{flex-direction:column;gap:0;max-width:900px;display:flex}.timeline-item{grid-template-columns:56px 1fr;gap:0 24px;padding-bottom:28px;display:grid;position:relative}.timeline-item:before{content:"";background:var(--green-border);width:1px;position:absolute;top:24px;bottom:0;left:26px}.timeline-item:last-child:before{display:none}.timeline-year{color:var(--green-dim);text-align:right;letter-spacing:1px;padding-top:6px;font-size:11px}.timeline-content{border:1px solid var(--green-border);background:var(--green-faint);padding:16px 20px;position:relative}.timeline-content:before{content:"";background:var(--green);width:3px;height:100%;position:absolute;top:0;left:0}.badge{letter-spacing:2px;border:1px solid;margin-bottom:10px;padding:2px 8px;font-size:10px;display:inline-block}.badge-gold{color:gold;background:#ffd7000d;border-color:#ffd7004d}.badge-silver{color:silver;background:#c0c0c00d;border-color:#c0c0c04d}.badge-media{color:#0cf;background:#00ccff0d;border-color:#00ccff4d}.timeline-title{letter-spacing:1px;color:var(--green);margin-bottom:4px;font-family:Orbitron,monospace;font-size:13px}.timeline-host{color:var(--green-dim);letter-spacing:1px;margin-bottom:8px;font-size:12px}.timeline-desc{color:#00ff88a6;font-size:13px;line-height:1.8}.about-text{color:#00ff88b3;text-align:left;max-width:780px;font-size:15px;line-height:2}.about-text span{color:var(--green)}.contact-list{max-width:700px;list-style:none}.contact-list li{border-bottom:1px solid var(--green-border);align-items:center;gap:32px;padding:16px 0;font-size:14px;display:flex}.contact-list li span{color:var(--green-dim);letter-spacing:2px;min-width:100px;font-size:12px}.contact-list a{color:var(--green);text-decoration:none}.contact-list a:hover{text-decoration:underline}.topbar{border-bottom:1px solid var(--green-border);z-index:100;color:var(--green-dim);background:#000000eb;justify-content:space-between;align-items:center;padding:12px 32px;font-size:13px;display:flex;position:fixed;top:0;left:0;right:0}.topbar-dot{background:var(--green);border-radius:50%;width:8px;height:8px;margin-right:8px;animation:1.5s ease-in-out infinite pulse;display:inline-block}.topbar nav{gap:32px;display:flex}.topbar nav a{color:var(--green-dim);letter-spacing:2px;font-size:12px;text-decoration:none;transition:color .2s}.topbar nav a:hover{color:var(--green)}
