*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0b0b0b;--bg2:#111;--bg3:#181818;--accent:#c8ff33;--accent-dim:#c8ff331f;--text:#f0ede8;--text-muted:#888880;--text-dim:#555550;--border:#f0ede814;--border-accent:#c8ff334d;--radius:4px;--transition:.3s cubic-bezier(.25, .46, .45, .94)}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);cursor:none;font-family:DM Sans,sans-serif;font-size:16px;line-height:1.6;overflow-x:hidden}.cursor{background:var(--accent);pointer-events:none;z-index:9999;mix-blend-mode:difference;border-radius:50%;width:10px;height:10px;transition:transform .1s,width .2s,height .2s,opacity .2s;position:fixed;transform:translate(-50%,-50%)}.cursor-ring{pointer-events:none;z-index:9998;border:1px solid #c8ff3380;border-radius:50%;width:36px;height:36px;transition:transform .15s,width .2s,height .2s;position:fixed;transform:translate(-50%,-50%)}.cursor.hover{width:6px;height:6px}.cursor-ring.hover{border-color:var(--accent);width:56px;height:56px}body:before{content:"";pointer-events:none;z-index:1000;opacity:.6;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");position:fixed;inset:0}nav{z-index:100;border-bottom:1px solid #0000;justify-content:space-between;align-items:center;padding:24px 48px;transition:border-color .3s,-webkit-backdrop-filter .3s,backdrop-filter .3s,background .3s;display:flex;position:fixed;top:0;left:0;right:0}nav.scrolled{border-color:var(--border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#0b0b0bcc}.nav-logo{letter-spacing:-.02em;color:var(--text);font-family:Syne,sans-serif;font-size:18px;font-weight:800;text-decoration:none}.nav-logo span{color:var(--accent)}.nav-links{gap:40px;list-style:none;display:flex}.nav-links a{letter-spacing:.08em;color:var(--text-muted);text-transform:uppercase;transition:color var(--transition);font-family:DM Mono,monospace;font-size:12px;text-decoration:none}.nav-links a:hover{color:var(--accent)}.nav-cta{letter-spacing:.06em;color:var(--bg);background:var(--accent);border-radius:var(--radius);transition:opacity var(--transition), transform var(--transition);padding:10px 20px;font-family:DM Mono,monospace;font-size:12px;font-weight:500;text-decoration:none}.nav-cta:hover{opacity:.85;transform:translateY(-1px)}#hero{flex-direction:column;justify-content:flex-end;min-height:100vh;padding:0 48px 80px;display:flex;position:relative;overflow:hidden}.hero-bg-text{color:#0000;-webkit-text-stroke:1px #f0ede80a;white-space:nowrap;pointer-events:none;-webkit-user-select:none;user-select:none;letter-spacing:-.04em;font-family:Syne,sans-serif;font-size:clamp(120px,20vw,260px);font-weight:800;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.hero-badge{letter-spacing:.1em;color:var(--accent);text-transform:uppercase;opacity:0;align-items:center;gap:8px;margin-bottom:32px;font-family:DM Mono,monospace;font-size:12px;animation:.7s .2s forwards fadeUp;display:inline-flex}.hero-badge:before{content:"";background:var(--accent);width:24px;height:1px}.hero-name{letter-spacing:-.04em;color:var(--text);opacity:0;margin-bottom:32px;font-family:Syne,sans-serif;font-size:clamp(52px,8vw,110px);font-weight:800;line-height:.92;animation:.7s .35s forwards fadeUp}.hero-name em{color:var(--accent);font-style:normal}.hero-bottom{opacity:0;justify-content:space-between;align-items:flex-end;gap:40px;animation:.7s .5s forwards fadeUp;display:flex}.hero-desc{max-width:420px;color:var(--text-muted);font-size:16px;line-height:1.7}.hero-desc strong{color:var(--text);font-weight:500}.hero-stats{flex-shrink:0;gap:48px;display:flex}.stat-item{text-align:right}.stat-num{color:var(--text);font-family:Syne,sans-serif;font-size:36px;font-weight:700;line-height:1}.stat-num span{color:var(--accent)}.stat-label{letter-spacing:.08em;color:var(--text-dim);text-transform:uppercase;margin-top:4px;font-family:DM Mono,monospace;font-size:11px}.scroll-hint{opacity:0;flex-direction:column;align-items:center;gap:8px;animation:1s 1.2s forwards fadeIn;display:flex;position:absolute;bottom:32px;left:50%;transform:translate(-50%)}.scroll-hint span{letter-spacing:.12em;color:var(--text-dim);text-transform:uppercase;font-family:DM Mono,monospace;font-size:10px}.scroll-line{background:linear-gradient(to bottom, var(--accent), transparent);width:1px;height:48px;animation:2s infinite scrollPulse}@keyframes scrollPulse{0%,to{opacity:.3}50%{opacity:1}}section{padding:120px 48px}.section-label{letter-spacing:.14em;color:var(--accent);text-transform:uppercase;align-items:center;gap:16px;margin-bottom:60px;font-family:DM Mono,monospace;font-size:11px;display:flex}.section-label:after{content:"";background:var(--accent);opacity:.4;flex:1;max-width:80px;height:1px}.section-title{letter-spacing:-.03em;color:var(--text);font-family:Syne,sans-serif;font-size:clamp(36px,5vw,64px);font-weight:800;line-height:1}#about{background:var(--bg2)}.about-grid{grid-template-columns:1fr 1fr;align-items:start;gap:80px;display:grid}.about-left .section-title{margin-bottom:32px}.about-text{color:var(--text-muted);margin-bottom:48px;font-size:17px;line-height:1.8}.about-text strong{color:var(--text);font-weight:500}.about-links{flex-wrap:wrap;gap:16px;display:flex}.link-pill{border:1px solid var(--border);color:var(--text-muted);transition:border-color var(--transition), color var(--transition), background var(--transition);border-radius:100px;align-items:center;gap:8px;padding:10px 18px;font-family:DM Mono,monospace;font-size:12px;text-decoration:none;display:inline-flex}.link-pill:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.link-pill svg{width:14px;height:14px}.about-right{padding-top:80px}.info-table{border-top:1px solid var(--border)}.info-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 0;display:flex}.info-key{letter-spacing:.1em;color:var(--text-dim);text-transform:uppercase;font-family:DM Mono,monospace;font-size:11px}.info-val{color:var(--text);text-align:right;font-size:14px}.info-val .highlight{color:var(--accent);font-family:DM Mono,monospace}#skills{position:relative}.skills-grid{grid-template-columns:repeat(3,1fr);gap:2px;margin-top:60px;display:grid}.skill-card{background:var(--bg2);transition:background var(--transition);padding:36px 32px;position:relative;overflow:hidden}.skill-card:before{content:"";background:var(--accent);transform-origin:0;height:2px;transition:transform var(--transition);position:absolute;bottom:0;left:0;right:0;transform:scaleX(0)}.skill-card:hover{background:var(--bg3)}.skill-card:hover:before{transform:scaleX(1)}.skill-icon{margin-bottom:16px;font-size:28px}.skill-name{color:var(--text);margin-bottom:8px;font-family:Syne,sans-serif;font-size:18px;font-weight:700}.skill-desc{color:var(--text-muted);font-size:13px;line-height:1.6}.skill-tags{flex-wrap:wrap;gap:6px;margin-top:16px;display:flex}.skill-tag{letter-spacing:.06em;color:var(--accent);background:#c8ff3314;border-radius:2px;padding:4px 10px;font-family:DM Mono,monospace;font-size:10px}#projects{background:var(--bg2)}.projects-header{justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:60px;display:flex}.projects-header .section-title{margin:0}.projects-sub{color:var(--text-muted);text-align:right;max-width:320px;font-size:15px}.projects-grid{grid-template-columns:1fr 1fr;gap:2px;display:grid}.project-card{background:var(--bg3);transition:background var(--transition);flex-direction:column;padding:48px 40px;display:flex;position:relative;overflow:hidden}.project-card:after{content:"";background:var(--accent);transform-origin:0;height:2px;transition:transform .4s cubic-bezier(.25,.46,.45,.94);position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.project-card:hover{background:#1a1a1a}.project-card:hover:after{transform:scaleX(1)}.project-num{letter-spacing:.12em;color:var(--text-dim);margin-bottom:24px;font-family:DM Mono,monospace;font-size:11px}.project-title{letter-spacing:-.02em;color:var(--text);margin-bottom:12px;font-family:Syne,sans-serif;font-size:26px;font-weight:800;line-height:1.1}.project-desc{color:var(--text-muted);flex:1;margin-bottom:28px;font-size:14px;line-height:1.7}.project-stack{flex-wrap:wrap;gap:6px;margin-bottom:32px;display:flex}.stack-tag{letter-spacing:.05em;border:1px solid var(--border);color:var(--text-muted);border-radius:2px;padding:5px 10px;font-family:DM Mono,monospace;font-size:10px}.project-actions{gap:12px;margin-top:auto;display:flex}.btn-live{background:var(--accent);color:var(--bg);letter-spacing:.06em;border-radius:var(--radius);transition:opacity var(--transition), transform var(--transition);align-items:center;gap:8px;padding:12px 24px;font-family:DM Mono,monospace;font-size:12px;font-weight:500;text-decoration:none;display:inline-flex}.btn-live:hover{opacity:.85;transform:translateY(-1px)}.btn-gh{border:1px solid var(--border);color:var(--text-muted);letter-spacing:.06em;border-radius:var(--radius);transition:border-color var(--transition), color var(--transition);align-items:center;gap:8px;padding:12px 20px;font-family:DM Mono,monospace;font-size:12px;text-decoration:none;display:inline-flex}.btn-gh:hover{border-color:var(--text-muted);color:var(--text)}.btn-live svg,.btn-gh svg{flex-shrink:0;width:14px;height:14px}.project-card.featured{grid-column:span 2;grid-template-columns:1fr 1fr;align-items:center;gap:60px;display:grid}.project-card.featured .project-right{flex-direction:column;gap:0;display:flex}.project-preview{background:var(--bg2);border:1px solid var(--border);border-radius:8px;justify-content:center;align-items:center;height:220px;display:flex;position:relative;overflow:hidden}.preview-dots{gap:6px;display:flex;position:absolute;top:12px;left:16px}.preview-dot{border-radius:50%;width:8px;height:8px}.preview-dot:first-child{background:#ff5f57}.preview-dot:nth-child(2){background:#febc2e}.preview-dot:nth-child(3){background:#28c840}.preview-content{color:var(--text-dim);text-align:center;font-family:DM Mono,monospace;font-size:12px;line-height:2}.preview-content .accent{color:var(--accent)}#learning{position:relative}.learning-grid{grid-template-columns:repeat(2,1fr);gap:40px;margin-top:60px;display:grid}.learning-item{align-items:flex-start;gap:24px;display:flex}.learning-num{color:var(--accent);opacity:.3;flex-shrink:0;width:56px;font-family:Syne,sans-serif;font-size:48px;font-weight:800;line-height:1}.learning-title{color:var(--text);margin-bottom:8px;font-family:Syne,sans-serif;font-size:20px;font-weight:700}.learning-desc{color:var(--text-muted);font-size:14px;line-height:1.7}#contact{background:var(--bg2);text-align:center}.contact-inner{max-width:700px;margin:0 auto}.contact-inner .section-label{justify-content:center}.contact-inner .section-label:after{display:none}.contact-inner .section-label:before{content:"";flex:unset;background:var(--accent);opacity:.4;width:80px;max-width:80px;height:1px}.contact-title{letter-spacing:-.04em;color:var(--text);margin:24px 0 20px;font-family:Syne,sans-serif;font-size:clamp(40px,6vw,80px);font-weight:800;line-height:1}.contact-title em{color:var(--accent);font-style:normal}.contact-sub{color:var(--text-muted);margin-bottom:48px;font-size:16px;line-height:1.7}.contact-email{color:var(--text);border-bottom:2px solid var(--accent);transition:color var(--transition);letter-spacing:-.01em;margin-bottom:48px;padding-bottom:4px;font-family:Syne,sans-serif;font-size:clamp(18px,3vw,28px);font-weight:700;text-decoration:none;display:inline-block}.contact-email:hover{color:var(--accent)}.contact-socials{flex-wrap:wrap;justify-content:center;gap:16px;display:flex}.social-btn{border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);letter-spacing:.04em;transition:border-color var(--transition), color var(--transition), background var(--transition);align-items:center;gap:10px;padding:14px 28px;font-family:DM Mono,monospace;font-size:13px;text-decoration:none;display:inline-flex}.social-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.social-btn svg{width:16px;height:16px}footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding:32px 48px;display:flex}.footer-copy{letter-spacing:.08em;color:var(--text-dim);font-family:DM Mono,monospace;font-size:11px}.footer-stack{letter-spacing:.06em;color:var(--text-dim);font-family:DM Mono,monospace;font-size:11px}.footer-stack span{color:var(--accent)}@keyframes fadeUp{0%{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.reveal{opacity:0;transition:opacity .7s cubic-bezier(.25,.46,.45,.94),transform .7s cubic-bezier(.25,.46,.45,.94);transform:translateY(40px)}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}.reveal-delay-4{transition-delay:.4s}.marquee-wrap{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg);padding:16px 0;overflow:hidden}.marquee-track{white-space:nowrap;gap:0;animation:20s linear infinite marquee;display:flex}.marquee-item{letter-spacing:.1em;color:var(--text-dim);text-transform:uppercase;align-items:center;gap:24px;padding:0 32px;font-family:DM Mono,monospace;font-size:12px;display:inline-flex}.marquee-dot{background:var(--accent);border-radius:50%;flex-shrink:0;width:4px;height:4px}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}@media (max-width:900px){nav{padding:20px 24px}.nav-links{display:none}section{padding:80px 24px}#hero{padding:0 24px 64px}.hero-bottom{flex-direction:column;align-items:flex-start}.hero-stats{justify-content:flex-start}.about-grid{grid-template-columns:1fr;gap:40px}.about-right{padding-top:0}.skills-grid,.projects-grid{grid-template-columns:1fr}.project-card.featured{grid-column:span 1;grid-template-columns:1fr}.learning-grid{grid-template-columns:1fr}footer{text-align:center;flex-direction:column;gap:12px}body{cursor:auto}.cursor,.cursor-ring{display:none}.projects-header{flex-direction:column;align-items:flex-start}.projects-sub{text-align:left}}
