*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0a0a0f;--bg2:#0f0f14;--bg3:#141419;
  --accent:#4d9fff;--text:#ede9e0;
  --muted:#52556a;--muted2:#242430;--border:rgba(255,255,255,0.06);
  --fd:'Bebas Neue',sans-serif;--fb:'DM Sans',sans-serif;--fm:'DM Mono',monospace;
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--fb);overflow-x:hidden;cursor:none}
#cur{width:8px;height:8px;background:#fff;border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);mix-blend-mode:difference}
#cur-ring{width:28px;height:28px;border:1px solid rgba(255,255,255,.15);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9998;transform:translate(-50%,-50%)}
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.6rem 3.5rem;
  border-bottom:1px solid transparent;
  transition:background .4s,border-color .4s,backdrop-filter .4s,box-shadow .4s;
  background:transparent;
}
nav.scrolled{
  background:rgba(8,8,12,.55);
  border-color:rgba(255,255,255,.06);
  backdrop-filter:blur(28px) saturate(160%);
  -webkit-backdrop-filter:blur(28px) saturate(160%);
  box-shadow:0 1px 60px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.04);
}
.nav-logo{
  font-family:var(--fd);
  font-size:1.6rem;font-weight:400;
  color:var(--accent);
  letter-spacing:.12em;
  line-height:1;
  text-transform:uppercase;
}
.nav-links{display:flex;gap:2.5rem}
.nav-links a{font-family:var(--fm);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(235,235,240,.55);text-decoration:none;transition:color .2s}
.nav-links a:hover{color:#fff}
.nav-cta{
  font-family:var(--fm);font-size:.62rem;letter-spacing:.18em;
  text-transform:uppercase;color:rgba(255,255,255,.7);
  background:transparent;
  border:1px solid rgba(255,255,255,.18);
  padding:.55rem 1.4rem;cursor:none;
  transition:color .25s,border-color .25s,box-shadow .25s,background .25s;
  border-radius:1px;
}
.nav-cta:hover{
  color:#fff;border-color:var(--accent);
  box-shadow:0 0 20px rgba(77,159,255,.2);
  background:rgba(77,159,255,.06);
}
#hero{position:relative;width:100%;height:100vh;display:grid;grid-template-columns:1fr 1fr;align-items:center;overflow:hidden}
#bg-canvas{position:absolute;inset:0;z-index:1;pointer-events:none}
#trail-canvas{position:absolute;inset:0;z-index:2;pointer-events:none}
.hero-left{position:relative;z-index:10;padding:0 0 0 4rem}
.hero-tag{font-family:var(--fm);font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem}
.hero-tag span{display:block;width:2rem;height:1px;background:var(--accent)}
h1{font-family:var(--fd);font-size:clamp(5rem,9vw,8.5rem);line-height:.9;letter-spacing:.02em;margin-bottom:1.8rem}
h1 .dim{color:rgba(255,255,255,.1)}
.hero-desc{max-width:400px;font-family:var(--fm);font-size:.78rem;font-weight:300;color:rgba(235,235,240,.55);line-height:1.95;margin-bottom:2.5rem}
.hero-btns{display:flex;gap:1rem}
.btn-p{font-family:var(--fm);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:#000;background:var(--accent);border:none;padding:.8rem 1.8rem;cursor:none;transition:.2s}
.btn-p:hover{background:#fff}
.btn-g{font-family:var(--fm);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(235,235,240,.55);background:transparent;border:1px solid rgba(255,255,255,.1);padding:.8rem 1.8rem;cursor:none;transition:.2s}
.btn-g:hover{border-color:rgba(255,255,255,.28);color:#fff}
.hero-right{position:relative;z-index:10;display:flex;align-items:center;justify-content:center;height:100vh}
#robot-wrap{position:relative;display:flex;align-items:center;justify-content:center}
#robot-wrap::after{content:'';position:absolute;bottom:-8px;left:50%;transform:translateX(-50%);width:140px;height:16px;border-radius:50%;background:rgba(60,120,255,.12);filter:blur(10px);pointer-events:none}
.sec{padding:4rem 4rem;max-width:1400px;margin:0 auto}
.slabel{font-family:var(--fm);font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem;display:flex;align-items:center;gap:.75rem}
.slabel span{display:block;width:1.5rem;height:1px;background:var(--accent)}
h2{font-family:var(--fd);font-size:clamp(2.5rem,5vw,5rem);line-height:.95;letter-spacing:.02em;margin-bottom:2rem}
.ag{display:grid;grid-template-columns:1.2fr 1fr;gap:6rem;align-items:start}
.at p{font-family:var(--fm);font-size:.78rem;font-weight:300;color:rgba(235,235,240,.55);line-height:2;margin-bottom:1.1rem}
.at p strong{color:var(--text);font-weight:500}
.sh{font-family:var(--fm);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin:2rem 0 .75rem}
.sg{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border)}
.si{
  background:var(--bg);
  padding:1.4rem 2rem;
  font-family:var(--fm);font-size:.74rem;letter-spacing:.08em;
  color:rgba(255,255,255,.4);
  transition:color .25s,background .25s,box-shadow .25s;
  position:relative;cursor:default;
  overflow:hidden;
}
.si::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 50%,rgba(77,159,255,.10),transparent 75%);
  opacity:0;transition:opacity .3s;
}
.si::after{
  content:'';position:absolute;
  inset:0;border:1px solid transparent;
  transition:border-color .25s;
}
.si:hover{
  background:rgba(77,159,255,.06);
  color:#fff;
  box-shadow:inset 0 0 30px rgba(77,159,255,.08), 0 0 20px rgba(77,159,255,.08);
}
.si:hover::before{opacity:1}
.si:hover::after{border-color:rgba(77,159,255,.25)}
.sw{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border)}
.sc{background:var(--bg);padding:2.5rem 2rem}
.sn{font-family:var(--fd);font-size:4.5rem;color:var(--accent);line-height:1;margin-bottom:.4rem}
.sl{font-family:var(--fm);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
#work{background:var(--bg2)}
.wh{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:4rem}
.wh h2{margin-bottom:0}
.wl{font-family:var(--fm);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color .2s}
.wl:hover{color:var(--accent)}
.pg{
  display:flex;gap:2rem;
  overflow-x:auto;overflow-y:visible;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding-bottom:1.5rem;
  scrollbar-width:none;
}
.pg::-webkit-scrollbar{display:none}
.pg::after{content:'';flex-shrink:0;width:2rem}
.pc{
  background:var(--bg2);padding:2.5rem;
  position:relative;overflow:hidden;
  transition:background .3s,transform .3s,box-shadow .3s;
  scroll-snap-align:start;
  flex-shrink:0;
  border:1px solid var(--border);
  border-radius:2px;
}
.pc::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:transparent;transition:.4s}
.pc:hover{background:var(--bg3);transform:translateY(-4px);box-shadow:0 20px 60px rgba(0,0,0,.4)}
.pc:hover::before{background:var(--accent)}
.pc.ft{width:min(700px,80vw);flex-shrink:0}
.pc:not(.ft){width:min(420px,75vw)}
.pn{font-family:var(--fm);font-size:.58rem;letter-spacing:.2em;color:var(--muted2);margin-bottom:1.5rem}
.pt{font-family:var(--fd);font-size:2rem;letter-spacing:.04em;margin-bottom:1rem}
.pd{font-family:var(--fm);font-size:.75rem;font-weight:300;color:rgba(235,235,240,.48);line-height:1.95;margin-bottom:2rem}
.ptags{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:2rem}
.tg{font-family:var(--fm);font-size:.6rem;letter-spacing:.1em;padding:.22rem .65rem;border:1px solid rgba(232,255,71,.15);color:rgba(232,255,71,.5);background:rgba(232,255,71,.04)}
.pl{font-family:var(--fm);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);text-decoration:none;display:inline-flex;align-items:center;gap:.4rem;transition:color .2s}
.pl::after{content:'->'}
.pl:hover{color:var(--accent)}
.pv{background:var(--bg);min-height:220px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border)}
.pvl{font-family:var(--fm);font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted2)}
.fl{font-family:var(--fm);font-size:.58rem;letter-spacing:.15em;text-transform:uppercase;color:#000;background:#1a5cff;display:inline-block;padding:.28rem .65rem;margin-bottom:1.25rem}
.el{margin-top:1.5rem}
.er{
  display:grid;grid-template-columns:200px 1fr;gap:4rem;
  padding:2.5rem 2rem;
  border-top:1px solid var(--border);
  position:relative;
  transition:border-color .3s, background .3s, box-shadow .3s;
  margin:0 -2rem;
}
.er::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:2px;
  background:var(--accent);opacity:0;
  transition:opacity .3s;
}
.er:hover{
  border-color:rgba(77,159,255,.35);
  background:rgba(77,159,255,.03);
  box-shadow:inset 0 0 60px rgba(77,159,255,.04), 0 0 0 1px rgba(77,159,255,.08);
}
.er:hover::before{opacity:1}
.edate{font-family:var(--fm);font-size:.66rem;letter-spacing:.08em;color:var(--muted);margin-bottom:.4rem}
.etype{font-family:var(--fm);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted2)}
.etitle{font-family:var(--fd);font-size:1.6rem;letter-spacing:.04em;margin-bottom:.3rem}
.eco{font-family:var(--fm);font-size:.73rem;color:var(--accent);margin-bottom:.9rem}
.edesc{font-family:var(--fm);font-size:.75rem;font-weight:300;color:rgba(235,235,240,.48);line-height:1.95}
#contact{background:var(--bg2);border-top:1px solid var(--border)}
.ci{max-width:1400px;margin:0 auto;padding:4rem 4rem;display:grid;grid-template-columns:1fr 1fr;gap:8rem;align-items:start}
.cb{font-family:var(--fd);font-size:clamp(3rem,6vw,6rem);line-height:.9;letter-spacing:.02em;margin-bottom:2rem}
.cb em{color:var(--accent);font-style:normal}
.ce{display:block;font-family:var(--fm);font-size:.9rem;color:var(--text);text-decoration:none;border-bottom:1px solid var(--muted2);padding-bottom:1rem;margin-bottom:2rem;transition:.2s}
.ce:hover{color:var(--accent);border-color:var(--accent)}
.soc{display:flex;gap:2rem}
.soc a{font-family:var(--fm);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color .2s}
.soc a:hover{color:var(--accent)}
.cn{font-family:var(--fm);font-size:.78rem;font-weight:300;color:rgba(235,235,240,.48);line-height:2}
.cn strong{color:var(--text);font-weight:500}
footer{padding:2rem 4rem;border-top:1px solid var(--border);display:flex;justify-content:space-between}
.ftt{font-family:var(--fm);font-size:.6rem;letter-spacing:.08em;color:var(--muted2)}
.rev{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.25,.46,.45,.94),transform .7s cubic-bezier(.25,.46,.45,.94)}
.rev.vis{opacity:1;transform:translateY(0)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}


/* ===== TECH TICKER ===== */
.ticker-wrap{
  width:100%;overflow:hidden;background:rgba(10,10,15,.98);
  border-top:1px solid rgba(77,159,255,.12);
  border-bottom:1px solid rgba(77,159,255,.12);
  padding:.75rem 0;position:relative;z-index:20;
}
.ticker-wrap::before,.ticker-wrap::after{
  content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none;
}
.ticker-wrap::before{left:0;background:linear-gradient(90deg,rgba(3,5,14,1),transparent)}
.ticker-wrap::after{right:0;background:linear-gradient(270deg,rgba(3,5,14,1),transparent)}
.ticker-track{
  display:flex;width:max-content;
  animation:ticker-scroll 28s linear infinite;
}
.ticker-track:hover{animation-play-state:paused}
@keyframes ticker-scroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.ticker-item{
  display:flex;align-items:center;gap:.5rem;
  padding:0 2rem;white-space:nowrap;
  font-family:'DM Mono',monospace;font-size:.72rem;
  letter-spacing:.12em;text-transform:uppercase;
  color:rgba(235,235,240,.5);
  transition:color .2s;
}
.ticker-item:hover{color:rgba(77,159,255,.9)}
.ticker-dot{
  width:5px;height:5px;border-radius:50%;
  background:rgba(77,159,255,.5);flex-shrink:0;
}


/* TYPING CURSOR */
#type-cursor{
  display:inline-block;color:var(--accent);
  animation:blink .8s step-end infinite;
  font-weight:300;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}


/* Full width skills */
.skills-full{
  margin-top:3rem;
  width:100%;
}
.sg{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:1px;
  background:var(--border);
  border:1px solid var(--border);
  width:100%;
}
/* ===== PROJECTS SLIDESHOW ===== */
.projects-slider{
  display:flex;gap:0;overflow-x:auto;overflow-y:visible;
  scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
  scrollbar-width:none;cursor:grab;
}
.projects-slider:active{cursor:grabbing}
.projects-slider::-webkit-scrollbar{display:none}
.proj-card{
  min-width:min(780px,88vw);
  background:var(--bg2);
  border-right:1px solid var(--border);
  padding:3rem;
  scroll-snap-align:start;
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
  transition:background .3s;
  flex-shrink:0;
}
.proj-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:transparent;transition:background .4s;
}
.proj-card:hover{background:var(--bg3)}
.proj-card:hover::before{background:var(--accent)}
.proj-card-label{
  display:inline-block;
  font-family:var(--fm);font-size:.6rem;letter-spacing:.15em;
  text-transform:uppercase;color:#000;background:var(--accent);
  padding:.28rem .7rem;margin-bottom:1.25rem;
}
.proj-card-num{
  font-family:var(--fm);font-size:.6rem;letter-spacing:.2em;
  color:var(--muted2);margin-bottom:1.5rem;
}
.proj-card-title{
  font-family:var(--fd);font-size:clamp(1.8rem,3vw,2.8rem);
  letter-spacing:.04em;margin-bottom:1rem;line-height:1;
}
.proj-card-desc{
  font-family:var(--fm);font-size:.75rem;font-weight:300;
  color:rgba(255,255,255,.38);line-height:1.9;margin-bottom:1.5rem;
  max-width:580px;
}
.proj-card-tags{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:1.5rem}
.proj-card-btns{display:flex;gap:.75rem;align-items:center;margin-bottom:2rem}
.proj-scroll-hint{
  display:flex;align-items:center;gap:.75rem;
  margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border);
}
.proj-scroll-hint span{
  font-family:var(--fm);font-size:.6rem;letter-spacing:.15em;
  text-transform:uppercase;color:var(--muted);
}
.proj-counter{
  font-family:var(--fm);font-size:.6rem;letter-spacing:.1em;
  color:var(--muted);margin-left:auto;
}


/* ===== MOBILE RESPONSIVE ===== */
@media (max-width: 768px) {

  /* NAV */
  nav { padding: 1rem 1.25rem; }
  .nav-links { display: none !important; }
  .nav-logo { font-size: 1.2rem; }
  nav > div:last-child { gap: .75rem; }

  /* HERO */
  #hero { grid-template-columns: 1fr; grid-template-rows: auto auto; min-height: 100vh; padding: 5rem 1.5rem 2rem; }
  .hero-left { padding: 0; text-align: center; z-index: 10; }
  h1 { font-size: clamp(3.5rem,15vw,5rem); margin-bottom: 1rem; }
  .hero-desc { font-size: .75rem; margin: 0 auto 1.5rem; max-width: 100%; }
  .hero-btns { justify-content: center; flex-wrap: wrap; }
  .hero-right { height: 320px; order: -1; }
  #robot-svg { width: 180px; height: auto; }
  #robot-wrap::after { display: none; }
  /* Hero badges */
  .hero-left > div:last-child { justify-content: center; }

  /* SECTIONS */
  .sec { padding: 3rem 1.25rem; }

  /* ABOUT */
  .ag { grid-template-columns: 1fr; gap: 2rem; }
  .sw { grid-template-columns: 1fr 1fr; }
  .sn { font-size: 3rem; }

  /* TECH STACK */
  div[style*="grid-template-columns:repeat(3,1fr)"] { grid-template-columns: 1fr !important; }

  /* PROJECTS SLIDER */
  .proj-card { min-width: 88vw !important; padding: 1.5rem; }
  .proj-card-title { font-size: 1.4rem; }

  /* GITHUB STATS */
  div[style*="grid-template-columns:repeat(5,1fr)"] { grid-template-columns: 1fr 1fr !important; }
  div[style*="grid-template-columns:repeat(3,1fr)"] { grid-template-columns: 1fr !important; }

  /* EXPERIENCE */
  .er { grid-template-columns: 1fr; gap: 0.5rem; }
  .edate { font-size: .65rem; }

  /* EDUCATION TABLE */
  div[style*="grid-template-columns:1fr 2fr"] { grid-template-columns: 1fr !important; }
  table { font-size: .7rem; }

  /* CERTIFICATIONS */
  div[style*="grid-template-columns:1fr 1fr 1fr"] { grid-template-columns: 1fr !important; }

  /* CONTACT */
  .ci { grid-template-columns: 1fr; gap: 2rem; padding: 3rem 1.25rem; }
  .cb { font-size: 2.5rem; }
  .soc { flex-wrap: wrap; gap: 1rem; }

  /* FOOTER */
  footer { padding: 1.5rem 1.25rem; flex-direction: column; gap: 1rem; text-align: center; }
  footer > div:nth-child(2) { flex-wrap: wrap; justify-content: center; }

  /* WORK HEADER */
  .wh { flex-direction: column; gap: 1rem; align-items: flex-start; }

  /* TICKER */
  .ticker-wrap { display: none; }

  /* STATS GRID */
  div[style*="grid-template-columns:1fr 1fr 1fr 1fr"] { grid-template-columns: 1fr 1fr !important; }

  /* HIDE cursor on mobile */
  #cur, #cur-ring { display: none; }
  body { cursor: auto; }

  /* BUTTONS */
  .btn-p, .btn-g { padding: .7rem 1.2rem; font-size: .65rem; }

  /* WORK SECTION padding */
  #work .sec { padding-left: 0 !important; padding-right: 0 !important; }
  #work > div > div:first-child { padding: 2rem 1.25rem 1rem !important; }
  #work > div > div:last-child { padding: 0 1.25rem 2rem !important; }

  /* HERO TAG */
  .hero-tag { justify-content: center; }
}

@media (max-width: 480px) {
  h1 { font-size: clamp(2.8rem,13vw,4rem); }
  .proj-card { min-width: 92vw !important; }
  .sw { grid-template-columns: 1fr 1fr; }
}