*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #000000;--green: rgb(80, 220, 130);--blue: rgb(100, 160, 255);--cyan: rgb(100, 240, 180);--red: rgb(215, 95, 95);--dim: rgba(255, 255, 255, .3);--muted: rgba(255, 255, 255, .65);--text: #e0e0e8;--mono: "Fira Code", monospace;--sans: "Inter", -apple-system, BlinkMacSystemFont, sans-serif}html{width:100%;background:var(--bg);scroll-behavior:smooth}body{width:100%;min-height:100%;background:var(--bg);color:var(--text);font-family:var(--mono);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}#root{width:100%;min-height:100%}canvas{display:block}.c-green{color:var(--green)}.c-blue{color:var(--blue)}.c-cyan{color:var(--cyan)}.c-red{color:var(--red)}.c-dim{color:var(--dim)}.c-white{color:#fff;font-weight:700}.blink{animation:blink-cursor 1s step-end infinite;color:var(--green)}@keyframes blink-cursor{0%,to{opacity:1}50%{opacity:0}}.hero{position:relative;width:100%;height:100vh;overflow:hidden}.hero canvas{position:absolute;top:0;right:0;bottom:0;left:0}.scroll-hint{position:absolute;bottom:32px;left:50%;transform:translate(-50%);z-index:10;color:var(--text);opacity:0;animation:hint-fade-in 2s ease 3s both,bounce 2s ease infinite 3s;transition:opacity .6s ease}.scroll-hint--hidden{opacity:0!important;animation:none;pointer-events:none}@keyframes hint-fade-in{0%{opacity:0}to{opacity:.4}}@keyframes bounce{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(-8px)}}.portfolio{position:relative;overflow-x:hidden;background:radial-gradient(circle,#0e0e0e 1px,transparent 1px);background-size:18px 21px}.portfolio:before{content:"";position:absolute;top:-100px;left:0;right:0;height:100px;background:linear-gradient(to bottom,transparent,var(--bg));pointer-events:none;z-index:5}.mouse-glow{position:fixed;top:0;left:0;pointer-events:none;z-index:2;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(80,180,130,.09) 0%,rgba(60,150,120,.04) 30%,rgba(40,100,90,.015) 60%,transparent 100%);opacity:0;will-change:transform;mix-blend-mode:screen}.intro{max-width:800px;margin:0 auto;padding:140px 24px 0;text-align:center}.intro-name{font-family:var(--sans);font-size:clamp(32px,5vw,48px);font-weight:700;color:#fff;letter-spacing:1px;margin-bottom:12px}.intro-role{font-family:var(--mono);font-size:clamp(14px,2.5vw,18px);color:var(--green);letter-spacing:3px;text-transform:uppercase;margin-bottom:32px}.intro-pitch{font-family:var(--sans);font-size:clamp(15px,2vw,18px);color:var(--muted);line-height:1.8;max-width:520px;margin:0 auto}@media(max-width:640px){.intro{padding:80px 20px 0}}.section{padding:100px 24px;max-width:800px;margin:0 auto}@media(max-width:1024px){.section{padding:80px 24px}}@media(max-width:640px){.section{padding:64px 16px}}.section-head{font-family:var(--mono);font-size:clamp(14px,2vw,16px);letter-spacing:2px;margin-bottom:48px;overflow:hidden;white-space:nowrap}.ascii-divider{text-align:center;font-family:var(--mono);font-size:13px;padding:0 24px;letter-spacing:4px}.terminal-block{font-family:var(--mono);font-size:13px;line-height:1.7;color:var(--muted);margin-bottom:28px;padding:0;white-space:pre-wrap;word-break:break-word;overflow-x:auto}.terminal-block:last-child{margin-bottom:0}.project{margin-top:56px;padding:24px;border-radius:8px;border:1px solid transparent;transition:border-color .3s,background .3s}@media(max-width:640px){.project{margin-top:64px;padding:16px}}@media(hover:hover){.project:hover{border-color:#50dc821f;background:#50dc8205}}.project-header{display:flex;align-items:center;gap:16px;margin-bottom:32px;padding-bottom:20px;border-bottom:1px solid var(--dim)}.project-icon{width:52px;height:52px;border-radius:12px;box-shadow:0 0 20px #7c3aed33,0 0 60px #7c3aed14}.project-title-block{display:flex;flex-direction:column;gap:4px}.project-name{font-family:var(--sans);font-size:clamp(22px,3.5vw,28px);font-weight:700;color:#fff;letter-spacing:.5px}.project-meta{display:flex;align-items:center;gap:6px;font-size:12px;flex-wrap:wrap}.status-dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.project-body{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}@media(max-width:1024px){.project-body{gap:32px}}@media(max-width:640px){.project-body{grid-template-columns:1fr;gap:28px}}.project-desc{display:flex;flex-direction:column}.project-link{display:inline-block;font-family:var(--mono);font-size:13px;color:var(--green);text-decoration:none;margin-top:28px;padding:8px 0;transition:color .2s,letter-spacing .3s}.project-link:hover{color:var(--cyan);letter-spacing:1px}.project-screenshots{display:grid;grid-template-columns:1fr 1fr;gap:10px}.project-screenshots img{width:100%;border-radius:8px;border:1px solid rgba(255,255,255,.12);box-shadow:0 4px 24px #0006;transition:border-color .3s,box-shadow .3s,transform .3s;object-fit:cover;cursor:pointer}.project-screenshots img:first-child{grid-column:1 / -1}.project-screenshots--mobile{grid-template-columns:1fr 1fr 1fr;align-items:start}.project-screenshots--mobile img{max-height:420px;object-fit:contain}.project-screenshots--mobile img:first-child{grid-column:auto}@media(hover:hover){.project-screenshots img:hover{box-shadow:0 4px 24px #0006,0 0 30px #50dc821f;transform:translateY(-2px)}}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:lightbox-in .2s ease}@keyframes lightbox-in{0%{opacity:0}to{opacity:1}}.lightbox-frame{max-width:90vw;max-height:90vh;display:flex;flex-direction:column;font-family:var(--mono);font-size:13px;animation:lightbox-frame-in .25s ease}@keyframes lightbox-frame-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.lightbox-titlebar{display:flex;align-items:center;padding:8px 0;white-space:nowrap}.lightbox-close{margin-left:auto;background:none;border:none;font-family:var(--mono);font-size:14px;cursor:pointer;padding:0 4px;transition:opacity .2s}.lightbox-close:hover{opacity:.7}.lightbox-body{border-left:1px solid var(--dim);border-right:1px solid var(--dim);padding:2px;display:flex;align-items:center;justify-content:center;overflow:hidden}.lightbox-body img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:4px}.lightbox-footer{padding:8px 0;white-space:nowrap}.about-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:2px;background:var(--dim)}@media(max-width:1024px)and (min-width:641px){.about-grid{grid-template-columns:1fr 1fr}.about-card:last-child{grid-column:1 / -1}}@media(max-width:640px){.about-grid{grid-template-columns:1fr}}.about-card{font-family:var(--mono);font-size:13px;line-height:1.7;color:var(--muted);padding:28px;background:var(--bg);min-width:0;transition:background .3s}.about-card-title{text-align:center;margin-bottom:4px}.about-card-sep{display:block;text-align:center;color:var(--dim);margin-bottom:16px}.about-card-body{white-space:pre-wrap;word-break:break-word}@media(hover:hover){.about-card:hover{background:#55af7808}}.footer{padding:100px 24px;max-width:800px;margin:0 auto}@media(max-width:640px){.footer{padding:64px 16px}}.contact-box{display:inline-flex;flex-direction:column;gap:12px;margin-top:32px;padding:24px 32px;border:1px solid var(--dim)}.contact-inline{font-family:var(--mono);font-size:13px;color:var(--green);text-decoration:none;transition:color .2s}.contact-inline:hover{color:var(--cyan)}.footer-sig{font-family:var(--mono);font-size:12px;color:var(--dim);margin-top:56px;line-height:1.8;white-space:pre-wrap;word-break:break-word;overflow-x:auto}.reveal{opacity:0;transform:translateY(16px);transition:opacity .25s ease,transform .35s ease}.reveal.visible{opacity:1;transform:translateY(0)}.portfolio-scanlines{position:fixed;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.03) 2px,rgba(0,0,0,.03) 4px);pointer-events:none;z-index:100}
