*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#08080a;
  --fg:#f5f2ed;
  --muted:#4a4a55;
  --border:#1c1c21;
  --surface:#101013;
  --glow:#7b6ef6;
  --glow2:#e879f9;
  --font-display:'Cabinet Grotesk',sans-serif;
  --font-serif:'Fraunces',serif;
  --font-mono:'Geist Mono',monospace;
}

html{scroll-behavior:smooth;overflow-x:hidden}
body{background:var(--bg);color:var(--fg);font-family:var(--font-display);overflow-x:hidden;cursor:none}

/* CURSOR */
#cur{position:fixed;width:8px;height:8px;background:var(--fg);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .15s,height .15s;mix-blend-mode:difference}
#cur-trail{position:fixed;width:36px;height:36px;border:1px solid rgba(123,110,246,.4);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:left .1s ease,top .1s ease,width .3s,height .3s,border-color .3s}
body.hovering #cur{width:16px;height:16px}
body.hovering #cur-trail{width:56px;height:56px;border-color:rgba(123,110,246,.7)}

/* MESH BG */
.mesh{position:fixed;inset:0;pointer-events:none;z-index:0;transition:transform .8s ease;
  background:
    radial-gradient(ellipse 55% 45% at 15% 15%,rgba(123,110,246,.13) 0%,transparent 65%),
    radial-gradient(ellipse 40% 40% at 85% 80%,rgba(232,121,249,.09) 0%,transparent 60%),
    radial-gradient(ellipse 30% 50% at 60% 30%,rgba(123,110,246,.05) 0%,transparent 60%);
}

/* TICKER */
.ticker-wrap{overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:.55rem 0;background:var(--surface);position:relative;z-index:10}
.ticker{display:flex;width:max-content;animation:ticker 30s linear infinite}
.ticker-item{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);padding:0 2.5rem;white-space:nowrap}
.ticker-item span{color:var(--glow)}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:500;padding:1.25rem 2.5rem;display:flex;align-items:center;justify-content:space-between;transition:background .4s,backdrop-filter .4s}
nav.stuck{background:rgba(8,8,10,.85);backdrop-filter:blur(24px);border-bottom:1px solid var(--border)}
.logo{font-weight:900;font-size:1rem;letter-spacing:-.04em;color:var(--fg);text-decoration:none;display:flex;align-items:center;gap:.5rem}
.logo-dot{width:7px;height:7px;border-radius:50%;background:var(--glow);box-shadow:0 0 10px var(--glow);animation:logoPulse 2s ease-in-out infinite}
@keyframes logoPulse{0%,100%{box-shadow:0 0 8px var(--glow)}50%{box-shadow:0 0 22px var(--glow),0 0 44px rgba(123,110,246,.3)}}
.nav-links{display:flex;gap:2rem;list-style:none}
.nav-links a{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color .2s}
.nav-links a:hover{color:var(--fg)}
.nav-cta{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;padding:.5rem 1.2rem;border:1px solid var(--border);border-radius:100px;color:var(--fg);text-decoration:none;transition:all .2s;cursor:none}
.nav-cta:hover{background:var(--fg);color:var(--bg);border-color:var(--fg)}

/* HERO */
.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:8rem 2rem 5rem;position:relative;z-index:10}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;padding:.4rem 1rem;border:1px solid rgba(123,110,246,.35);border-radius:100px;color:rgba(123,110,246,.9);background:rgba(123,110,246,.07);margin-bottom:2.5rem;opacity:0;animation:riseIn .8s .1s forwards}
.badge-dot{width:5px;height:5px;border-radius:50%;background:var(--glow);animation:blink 1.8s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}

.hero-headline{font-size:clamp(4rem,9vw,9rem);font-weight:900;letter-spacing:-.06em;line-height:.88;margin-bottom:2rem}
.line{display:block;overflow:hidden}
.line-inner{display:inline-block;animation:lineReveal .95s cubic-bezier(.16,1,.3,1) both}
.line:nth-child(1) .line-inner{animation-delay:.2s}
.line:nth-child(2) .line-inner{animation-delay:.38s}
.line:nth-child(3) .line-inner{animation-delay:.56s}
@keyframes lineReveal{from{transform:translateY(115%)}to{transform:translateY(0)}}
.hero-headline em{font-family:var(--font-serif);font-style:italic;font-weight:300;background:linear-gradient(135deg,var(--glow),var(--glow2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

.hero-sub{font-size:1.05rem;line-height:1.8;color:var(--muted);max-width:480px;margin:0 auto 3rem;opacity:0;animation:riseIn .8s .75s forwards}
.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;opacity:0;animation:riseIn .8s .9s forwards}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.07em;text-transform:uppercase;text-decoration:none;border-radius:100px;padding:.8rem 1.8rem;cursor:none;transition:all .25s;position:relative;overflow:hidden}
.btn::before{content:'';position:absolute;inset:0;background:var(--fg);border-radius:inherit;transform:scaleX(0);transform-origin:left;transition:transform .35s ease;z-index:0}
.btn:hover::before{transform:scaleX(1)}
.btn span{position:relative;z-index:1;transition:color .3s}
.btn-ghost{border:1px solid var(--border);color:var(--fg)}
.btn-ghost:hover span{color:var(--bg)}
.btn-filled{background:var(--fg);color:var(--bg)}
.btn-filled::before{background:rgba(0,0,0,.08)}
.btn-filled span{color:var(--bg)}

/* SCROLL HINT */
.scroll-hint{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.4rem;opacity:0;animation:riseIn .8s 1.1s forwards}
.scroll-hint p{font-family:var(--font-mono);font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--muted),transparent);animation:scrollAnim 1.6s ease-in-out infinite}
@keyframes scrollAnim{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* STATS */
.stats{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--border);position:relative;z-index:10}
.stat{padding:2.5rem 2rem;border-right:1px solid var(--border);transition:background .3s;cursor:default}
.stat:last-child{border-right:none}
.stat:hover{background:var(--surface)}
.stat-num{font-size:clamp(2rem,3.5vw,3rem);font-weight:900;letter-spacing:-.04em;background:linear-gradient(135deg,var(--fg) 40%,var(--muted));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.3rem}
.stat-label{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

/* SECTIONS */
.section{padding:8rem 2.5rem;position:relative;z-index:10}
.section-inner{max-width:1160px;margin:0 auto}
.eyebrow{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--glow);display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem}
.eyebrow::after{content:'';flex:0 0 28px;height:1px;background:var(--glow)}
.heading{font-size:clamp(2.5rem,5vw,4.5rem);font-weight:900;letter-spacing:-.04em;line-height:.95}
.heading em{font-family:var(--font-serif);font-style:italic;font-weight:300;color:var(--muted)}

/* ABOUT */
.about-layout{display:grid;grid-template-columns:1fr 1.1fr;gap:6rem;align-items:center;margin-top:5rem}
.about-copy p{font-size:1rem;line-height:1.85;color:var(--muted);margin-bottom:1.2rem}
.about-copy strong{color:var(--fg)}
.about-copy p:first-child{font-size:1.2rem;line-height:1.65;color:var(--fg);font-weight:500}
.skills-list{display:flex;flex-direction:column;gap:.5rem}
.skill-row{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border:1px solid var(--border);border-radius:8px;background:var(--surface);transition:all .25s;position:relative;overflow:hidden}
.skill-row::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(to bottom,var(--glow),var(--glow2));transform:scaleY(0);transition:transform .3s}
.skill-row:hover{border-color:rgba(123,110,246,.3);background:#13131a}
.skill-row:hover::before{transform:scaleY(1)}
.skill-name{font-size:.9rem;font-weight:600}
.skill-cat{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.08em;color:var(--muted)}

/* PROJECTS */
.projects-section{background:var(--surface);border-top:1px solid var(--border)}
.projects-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:4rem}
.project-list{display:flex;flex-direction:column}

.project-item{display:grid;grid-template-columns:70px 1fr auto;align-items:center;gap:2.5rem;padding:2rem 0;border-bottom:1px solid var(--border);text-decoration:none;color:var(--fg);transition:all .3s;cursor:none;position:relative;overflow:hidden}
.project-item::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(to right,var(--glow),var(--glow2));transform:scaleX(0);transform-origin:left;transition:transform .4s ease}
.project-item:hover::after{transform:scaleX(1)}
.project-item:hover .project-num{color:var(--fg)}
.project-item:hover .p-arrow{transform:rotate(0deg) scale(1.1);border-color:rgba(123,110,246,.5);color:var(--glow)}
.project-num{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.1em;color:var(--muted);transition:color .3s}
.project-title{font-size:clamp(1.4rem,2.5vw,2.1rem);font-weight:800;letter-spacing:-.04em;margin-bottom:.4rem;transition:letter-spacing .3s}
.project-item:hover .project-title{letter-spacing:-.02em}
.project-meta-row{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.05em;color:var(--muted);display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}
.tag-pill{padding:.2rem .6rem;border-radius:4px;background:rgba(123,110,246,.1);border:1px solid rgba(123,110,246,.2);color:var(--glow);font-size:.58rem;letter-spacing:.1em;text-transform:uppercase}
.tag-pill.soon{background:rgba(232,121,249,.08);border-color:rgba(232,121,249,.2);color:var(--glow2)}
.p-arrow{width:44px;height:44px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--muted);transform:rotate(-45deg);transition:all .3s;flex-shrink:0}

/* FEATURED */
.featured-card{margin-top:3rem;border:1px solid var(--border);border-radius:16px;padding:2.5rem 3rem;background:linear-gradient(135deg,rgba(123,110,246,.06),rgba(232,121,249,.03));display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;position:relative;overflow:hidden;transition:border-color .3s}
.featured-card::before{content:'FEATURED';position:absolute;top:1.5rem;right:1.5rem;font-family:var(--font-mono);font-size:.52rem;letter-spacing:.2em;padding:.3rem .7rem;border-radius:4px;background:rgba(123,110,246,.12);border:1px solid rgba(123,110,246,.3);color:var(--glow)}
.featured-card:hover{border-color:rgba(123,110,246,.3)}
.featured-title{font-size:2.2rem;font-weight:900;letter-spacing:-.04em;margin-bottom:.75rem}
.featured-desc{font-size:.93rem;line-height:1.75;color:var(--muted);margin-bottom:1.5rem}
.featured-stack{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem}
.stack-chip{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.06em;padding:.3rem .75rem;border-radius:100px;border:1px solid var(--border);color:var(--muted)}
.featured-visual{height:220px;border-radius:12px;background:linear-gradient(135deg,rgba(123,110,246,.15),rgba(232,121,249,.1));border:1px solid rgba(123,110,246,.2);display:flex;align-items:center;justify-content:center;font-size:3.5rem;position:relative;overflow:hidden}
.featured-visual::after{content:'';position:absolute;width:180px;height:180px;background:radial-gradient(circle,rgba(123,110,246,.25),transparent 70%);border-radius:50%;animation:float 4s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-14px) scale(1.06)}}

/* CONTACT */
.contact-section{text-align:center}
.contact-inner{max-width:620px;margin:0 auto}
.contact-title{font-size:clamp(3rem,6vw,5.5rem);font-weight:900;letter-spacing:-.05em;line-height:.95;margin:1.5rem 0}
.contact-title em{font-family:var(--font-serif);font-style:italic;font-weight:300;background:linear-gradient(135deg,var(--glow),var(--glow2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.contact-sub{color:var(--muted);line-height:1.7;margin-bottom:2.5rem;font-size:.97rem}
.contact-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:3rem}
.social-row{display:flex;gap:1.5rem;justify-content:center}
.social-link{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color .2s;cursor:none}
.social-link:hover{color:var(--fg)}

/* FOOTER */
footer{padding:1.5rem 2.5rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:relative;z-index:10}
footer p{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.08em;color:var(--muted)}
.footer-glow{width:80px;height:1px;background:linear-gradient(to right,var(--glow),var(--glow2))}

/* REVEAL */
.r{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.r.in{opacity:1;transform:none}
.r-d1{transition-delay:.1s}.r-d2{transition-delay:.2s}.r-d3{transition-delay:.3s}

@keyframes riseIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

/* RESPONSIVE */
@media(max-width:900px){
  nav{padding:1rem 1.5rem}
  .hero{padding:7rem 1.5rem 5rem}
  .stats{grid-template-columns:1fr 1fr}
  .stat{border-right:none;border-bottom:1px solid var(--border)}
  .about-layout{grid-template-columns:1fr;gap:3rem}
  .featured-card{grid-template-columns:1fr}
  .project-item{grid-template-columns:50px 1fr auto;gap:1.25rem}
  .section{padding:5rem 1.5rem}
  footer{flex-direction:column;gap:1rem;text-align:center}
}
@media(max-width:600px){
  .nav-links{display:none}
}