*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --white:#f0f4f8;
  --dim:#8ba0b0;
  --accent:#ff6b2b;
  --accent2:#ffb347;
  --blue:#38bdf8;
  --dark:#080c10;
  --dark2:#0d1520;
  --card:#0f1a26;
  --border:rgba(255,255,255,0.06);
  --glow-orange:0 0 40px rgba(255,107,43,0.4);
}
html{scroll-behavior:smooth}
body{
  font-family:'Outfit',sans-serif;
  background:var(--dark);
  color:var(--white);
  overflow-x:hidden;
  cursor:none;
}
#cur,#cur2{position:fixed;border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%)}
#cur{width:8px;height:8px;background:var(--accent);box-shadow:0 0 16px var(--accent),0 0 40px rgba(255,107,43,0.5);}
#cur2{width:36px;height:36px;border:1px solid rgba(255,107,43,0.4);}
#canvas{position:fixed;inset:0;z-index:0;opacity:.65}
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;justify-content:space-between;align-items:center;
  padding:24px 64px;
}
nav::before{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(8,12,16,.9),transparent);pointer-events:none}
.logo{font-family:'Bebas Neue',cursive;font-size:1.6rem;letter-spacing:4px;color:var(--white);position:relative;z-index:1}
.logo span{color:var(--accent)}
.nav-r{display:flex;gap:36px;align-items:center;position:relative;z-index:1}
.nav-r a{font-family:'Fira Code',monospace;font-size:.72rem;color:var(--dim);text-decoration:none;letter-spacing:2px;transition:color .3s;position:relative}
.nav-r a::before{content:'';position:absolute;bottom:-3px;left:0;right:0;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.nav-r a:hover{color:var(--white)}
.nav-r a:hover::before{transform:scaleX(1)}
.nav-cta{padding:10px 24px;border:1px solid var(--accent);color:var(--accent)!important;transition:background .3s,color .3s!important;cursor:none}
.nav-cta:hover{background:var(--accent)!important;color:var(--dark)!important}
.nav-cta::before{display:none!important}

/* HERO */
#hero{position:relative;z-index:2;min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:0 64px;padding-top:100px}
.hero-chip{display:inline-flex;align-items:center;gap:8px;padding:6px 16px;border:1px solid rgba(255,107,43,.3);background:rgba(255,107,43,.07);font-family:'Fira Code',monospace;font-size:.7rem;color:var(--accent);letter-spacing:2px;margin-bottom:32px;opacity:0;animation:up .7s .1s forwards}
.hero-chip .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:blink 1.5s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.hero-h1{font-family:'Bebas Neue',cursive;font-size:clamp(5rem,13vw,12rem);line-height:.88;letter-spacing:-1px;margin-bottom:32px;opacity:0;animation:up .8s .25s forwards}
.hero-h1 .line1{display:block;color:var(--white)}
.hero-h1 .line2{display:block;background:linear-gradient(100deg,var(--accent),var(--accent2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero-bottom{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:40px;opacity:0;animation:up .8s .5s forwards}
.hero-desc{max-width:440px;color:var(--dim);font-size:1rem;line-height:1.75;font-weight:300}
.hero-desc strong{color:var(--white);font-weight:500}
.hero-actions{display:flex;flex-direction:column;align-items:flex-end;gap:16px}
.big-btn{display:flex;align-items:center;gap:12px;padding:18px 40px;background:var(--accent);color:var(--dark);font-family:'Bebas Neue',cursive;font-size:1.1rem;letter-spacing:3px;text-decoration:none;cursor:none;position:relative;overflow:hidden;transition:transform .3s,box-shadow .3s}
.big-btn::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transform:translateX(-100%);transition:transform .5s}
.big-btn:hover{transform:translateY(-3px);box-shadow:var(--glow-orange)}
.big-btn:hover::before{transform:translateX(100%)}
.hero-scroll-wrap{display:flex;align-items:center;gap:8px;font-family:'Fira Code',monospace;font-size:.65rem;color:var(--dim);letter-spacing:2px}
.hero-scroll-line{width:1px;height:50px;background:linear-gradient(to bottom,var(--accent),transparent);animation:grow 2s ease-in-out infinite}
@keyframes grow{0%,100%{height:50px;opacity:1}50%{height:30px;opacity:.4}}

/* MARQUEE */
.mwrap{position:relative;z-index:2;border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden;padding:14px 0;background:rgba(255,107,43,.04)}
.mtrack{display:flex;white-space:nowrap;animation:marquee 22s linear infinite}
.mitem{font-family:'Bebas Neue',cursive;font-size:1rem;letter-spacing:4px;color:var(--dim);padding:0 28px;display:inline-flex;align-items:center;gap:28px}
.mitem .sep{color:var(--accent);font-size:1.1rem}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* SECTIONS */
.section{position:relative;z-index:2;padding:120px 64px}
.s-label{font-family:'Fira Code',monospace;font-size:.68rem;color:var(--accent);letter-spacing:4px;text-transform:uppercase;display:flex;align-items:center;gap:10px;margin-bottom:16px}
.s-label::after{content:'';flex:1;max-width:60px;height:1px;background:var(--accent);opacity:.5}
.s-title{font-family:'Bebas Neue',cursive;font-size:clamp(2.5rem,5vw,4.5rem);letter-spacing:1px;line-height:1;margin-bottom:16px}

/* ABOUT */
#about{display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:start}
.about-p{color:var(--dim);line-height:1.8;margin-bottom:16px;font-size:.97rem}
.about-p strong{color:var(--white);font-weight:500}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;margin-top:48px;border:1px solid var(--border);background:var(--border)}
.ag-cell{background:var(--card);padding:28px 24px;position:relative;overflow:hidden;transition:background .3s}
.ag-cell:hover{background:#111f2e}
.ag-num{font-family:'Bebas Neue',cursive;font-size:2.8rem;color:var(--accent);line-height:1;margin-bottom:4px}
.ag-label{font-family:'Fira Code',monospace;font-size:.65rem;color:var(--dim);letter-spacing:2px;text-transform:uppercase}
.ag-cell::before{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent2));transform:scaleX(0);transition:transform .4s}
.ag-cell:hover::before{transform:scaleX(1)}
.terminal{background:#060b10;border:1px solid var(--border);font-family:'Fira Code',monospace;font-size:.78rem;overflow:hidden}
.t-bar{padding:12px 16px;background:#0a1219;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
.t-dot{width:10px;height:10px;border-radius:50%}
.t-title{font-size:.65rem;color:var(--dim);letter-spacing:2px;margin-left:8px}
.t-body{padding:24px;line-height:2;color:#7aa8b8}
.t-body .kw{color:#ff6b2b}.t-body .fn{color:#38bdf8}.t-body .str{color:#86efac}.t-body .cm{color:#2a4a56;font-style:italic}.t-body .num{color:#fbbf24}
.t-cur{display:inline-block;width:2px;height:1em;background:var(--accent);vertical-align:text-bottom;animation:blink 1s step-end infinite}

/* SKILLS */
#skills{background:var(--dark2)}
.skills-top{display:grid;grid-template-columns:1fr 2fr;gap:80px;align-items:start;margin-bottom:80px}
.skills-desc{color:var(--dim);line-height:1.8;font-size:.95rem}
.skills-board{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border)}
.sk-cell{background:var(--card);padding:32px 24px;transition:background .3s,transform .3s;position:relative;overflow:hidden;cursor:default}
.sk-cell:hover{background:#111f2e;transform:scale(1.02);z-index:2}
.sk-icon{font-size:1.8rem;margin-bottom:14px;display:block}
.sk-name{font-family:'Bebas Neue',cursive;font-size:1.1rem;letter-spacing:2px;color:var(--white);margin-bottom:12px}
.sk-bar-wrap{height:2px;background:rgba(255,255,255,.06);border-radius:2px;overflow:hidden}
.sk-bar{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));width:0;transition:width 1.4s cubic-bezier(.16,1,.3,1)}
.sk-pct{font-family:'Fira Code',monospace;font-size:.6rem;color:var(--dim);letter-spacing:1px;margin-top:6px}

/* PROJECTS */
.proj-intro{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:end;margin-bottom:72px}
.proj-note{color:var(--dim);line-height:1.8;font-size:.95rem;max-width:400px}
.proj-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border:1px solid var(--border)}
.proj-card{background:var(--card);padding:40px;position:relative;overflow:hidden;transition:background .4s;display:flex;flex-direction:column}
.proj-card:hover{background:#0d1e2e}
.proj-card:hover .proj-arrow{transform:translate(4px,-4px);color:var(--accent)}
.proj-card:hover .pc-glow{opacity:1}
.pc-glow{position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:0;transition:opacity .4s}
.pc-n{font-family:'Bebas Neue',cursive;font-size:4rem;color:rgba(255,107,43,.08);line-height:1;margin-bottom:16px;transition:color .3s}
.proj-card:hover .pc-n{color:rgba(255,107,43,.18)}
.pc-name{font-family:'Bebas Neue',cursive;font-size:1.5rem;letter-spacing:2px;color:var(--white);margin-bottom:14px}
.pc-desc{color:var(--dim);font-size:.88rem;line-height:1.7;flex:1;margin-bottom:24px}
.pc-footer{display:flex;justify-content:space-between;align-items:center}
.pc-tags{display:flex;gap:8px;flex-wrap:wrap}
.pc-tag{font-family:'Fira Code',monospace;font-size:.58rem;padding:3px 8px;border:1px solid rgba(255,107,43,.2);color:var(--dim);letter-spacing:1px;transition:border-color .3s,color .3s}
.proj-card:hover .pc-tag{border-color:rgba(255,107,43,.4);color:var(--accent)}
.proj-arrow{font-size:1.2rem;color:var(--dim);text-decoration:none;cursor:none;transition:transform .3s,color .3s;display:inline-block}
.proj-card.featured{grid-column:span 2;flex-direction:row;gap:60px;align-items:center}
.proj-card.featured .pc-n{font-size:6rem;margin-bottom:0;flex-shrink:0}

/* CONTACT */
#contact{background:var(--dark2)}
.contact-inner{max-width:900px;margin:0 auto;text-align:center}
.contact-big{font-family:'Bebas Neue',cursive;font-size:clamp(3rem,8vw,7rem);line-height:.9;letter-spacing:-1px;margin:32px 0}
.contact-big .acc{background:linear-gradient(100deg,var(--accent),var(--accent2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.contact-sub{color:var(--dim);font-size:1rem;line-height:1.7;max-width:480px;margin:0 auto 56px}
.contact-cards{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.cc{display:flex;align-items:center;gap:12px;padding:18px 32px;border:1px solid var(--border);background:var(--card);text-decoration:none;color:var(--dim);font-family:'Fira Code',monospace;font-size:.75rem;letter-spacing:1px;cursor:none;transition:border-color .3s,color .3s,transform .3s,box-shadow .3s}
.cc:hover{border-color:var(--accent);color:var(--white);transform:translateY(-4px);box-shadow:0 8px 30px rgba(255,107,43,.2)}
.cc-icon{font-size:1rem}

footer{position:relative;z-index:2;border-top:1px solid var(--border);padding:28px 64px;display:flex;justify-content:space-between;align-items:center}
.ft{font-family:'Fira Code',monospace;font-size:.65rem;color:var(--dim);letter-spacing:1px}
.fl{font-family:'Bebas Neue',cursive;font-size:1.2rem;letter-spacing:4px;color:var(--white)}
.fl span{color:var(--accent)}

@keyframes up{from{opacity:0;transform:translateY(36px)}to{opacity:1;transform:translateY(0)}}
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s,transform .9s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

@media(max-width:900px){
  nav{padding:20px 24px}
  .nav-r a:not(.nav-cta){display:none}
  .section{padding:80px 24px}
  #about{grid-template-columns:1fr;gap:40px}
  .skills-top{grid-template-columns:1fr;gap:24px}
  .skills-board{grid-template-columns:repeat(2,1fr)}
  .proj-intro{grid-template-columns:1fr;gap:24px}
  .proj-grid{grid-template-columns:1fr}
  .proj-card.featured{grid-column:span 1;flex-direction:column;gap:0}
  #hero{padding:0 24px;padding-top:100px}
  footer{padding:24px;flex-direction:column;gap:8px;text-align:center}
}