*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --bg:#080808;--bg2:#101010;--bg3:#161616;--bg4:#1c1c1c;
  --lime:#c8ff00;--lime2:#a0cc00;--lime-dim:rgba(200,255,0,0.08);
  --pink:#ff2d78;--cyan:#00f5ff;
  --white:#f0f0eb;--muted:#666;--muted2:#999;
  --border:#1e1e1e;--border2:#2a2a2a;
}
html{scroll-behavior:smooth;}
body{
  background:var(--bg);color:var(--white);
  font-family:'Outfit',sans-serif;font-size:16px;line-height:1.7;
  overflow-x:hidden;
  cursor:none;
}
/* Restore cursor on mobile where custom cursor doesn't make sense */
@media(max-width:768px){ body{ cursor:auto; } }

/* ─── ELEPHANT CURSOR ─── */
#elephant-cursor{
  position:fixed;top:0;left:0;pointer-events:none;z-index:99999;
  width:48px;height:48px;transform:translate(-50%,-50%);
  transition:transform 0.08s ease;
  will-change:transform;
}
#elephant-cursor svg{ width:100%;height:100%; }
#elephant-cursor.clicking{ transform:translate(-50%,-50%) scale(0.8); }
/* Hide on mobile */
@media(max-width:768px){ #elephant-cursor{ display:none; } }

/* ─── NAV ─── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 3rem;height:62px;
  border-bottom:1px solid var(--border);
  background:rgba(8,8,8,0.94);backdrop-filter:blur(18px);
}
.nav-logo{font-family:'Bebas Neue',sans-serif;font-size:1.6rem;letter-spacing:0.07em;color:var(--lime);text-decoration:none;}
.nav-links{list-style:none;display:flex;gap:2rem;}
.nav-links a{font-size:0.75rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color 0.2s;position:relative;}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:1.5px;background:var(--lime);transform:scaleX(0);transition:transform 0.2s;}
.nav-links a.active,.nav-links a:hover{color:var(--lime);}
.nav-links a.active::after,.nav-links a:hover::after{transform:scaleX(1);}
.nav-cta{background:var(--lime);color:#000;font-size:0.72rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;padding:8px 18px;border-radius:4px;text-decoration:none;transition:background 0.2s,transform 0.2s;}
.nav-cta:hover{background:var(--lime2);transform:translateY(-1px);}

/* ─── HERO ─── */
#hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:8rem 3rem 4rem;position:relative;overflow:hidden;}
.hero-glow{position:absolute;top:-250px;left:-150px;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(200,255,0,0.07) 0%,transparent 70%);pointer-events:none;}
.hero-glow2{position:absolute;bottom:-200px;right:-100px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(0,245,255,0.05) 0%,transparent 70%);pointer-events:none;}
.hero-grid{display:grid;grid-template-columns:1fr auto;gap:3rem;align-items:center;max-width:1100px;margin:0 auto;width:100%;}
.hero-left{animation:fadeUp 0.9s ease both;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:#141400;border:1px solid rgba(200,255,0,0.2);color:var(--lime);font-size:0.7rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;padding:6px 16px;border-radius:100px;margin-bottom:1.25rem;}
.hero-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--lime);animation:blink 1.5s infinite;}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:0.15;}}
.hero-name{font-family:'Bebas Neue',sans-serif;font-size:clamp(4.5rem,11vw,10rem);line-height:0.9;letter-spacing:0.01em;color:var(--white);}
.hero-name .accent{color:var(--lime);}
.hero-divider{display:flex;align-items:center;gap:1rem;margin:1.25rem 0;}
.hero-divider::before{content:'';display:block;width:40px;height:2px;background:var(--lime);}
.hero-role{font-size:0.85rem;font-weight:500;color:var(--muted2);letter-spacing:0.06em;text-transform:uppercase;}
.hero-sub{font-size:1rem;color:var(--muted);max-width:480px;line-height:1.85;margin-bottom:2.25rem;}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap;}
.hero-stats{display:flex;gap:3rem;margin-top:3.5rem;padding-top:2rem;border-top:1px solid var(--border);}
.stat-num{font-family:'Bebas Neue',sans-serif;font-size:2.6rem;color:var(--lime);line-height:1;}
.stat-lbl{font-size:0.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.08em;margin-top:2px;}

/* ─── AVATAR ─── */
.hero-avatar{animation:fadeUp 0.9s 0.2s ease both;flex-shrink:0;}
.avatar-ring{width:220px;height:220px;border-radius:50%;border:2px solid rgba(200,255,0,0.25);padding:6px;position:relative;animation:ring-spin 12s linear infinite;}
@keyframes ring-spin{0%{border-color:rgba(200,255,0,0.15) rgba(200,255,0,0.4) rgba(200,255,0,0.1) rgba(200,255,0,0.3);}100%{border-color:rgba(200,255,0,0.3) rgba(200,255,0,0.1) rgba(200,255,0,0.4) rgba(200,255,0,0.15);}}
.avatar-inner{width:100%;height:100%;border-radius:50%;background:linear-gradient(135deg,#1a2200,#0d1a00);border:1px solid rgba(200,255,0,0.1);display:flex;align-items:center;justify-content:center;overflow:hidden;font-family:'Bebas Neue',sans-serif;font-size:4.5rem;color:var(--lime);letter-spacing:0.05em;position:relative;}
.avatar-inner::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,rgba(200,255,0,0.08),transparent 60%);}

/* ─── TYPING ─── */
.typing-wrap{display:inline-flex;align-items:center;gap:4px;margin-bottom:0.5rem;}
.typing-label{font-size:0.75rem;color:var(--muted);letter-spacing:0.06em;text-transform:uppercase;}
#typing-text{color:var(--lime);font-weight:600;font-size:0.85rem;}
.cursor-blink{display:inline-block;width:2px;height:14px;background:var(--lime);margin-left:2px;animation:blink 0.8s infinite;}

/* ─── BUTTONS ─── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:6px;font-size:0.82rem;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;text-decoration:none;cursor:pointer;border:none;transition:all 0.2s;position:relative;overflow:hidden;font-family:'Outfit',sans-serif;}
.btn-lime{background:var(--lime);color:#000;}
.btn-lime:hover{background:var(--lime2);transform:translateY(-2px);}
.btn-ghost{background:transparent;color:var(--white);border:1px solid var(--border2);}
.btn-ghost:hover{border-color:var(--lime);color:var(--lime);}
.btn .ripple{position:absolute;border-radius:50%;background:rgba(255,255,255,0.25);transform:scale(0);animation:ripple-anim 0.55s linear;pointer-events:none;}
@keyframes ripple-anim{to{transform:scale(4);opacity:0;}}



/* ─── SHARED SECTION ─── */
section{padding:7rem 3rem;}
.section-inner{max-width:1100px;margin:0 auto;}
.section-tag{font-size:0.68rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--lime);margin-bottom:0.5rem;display:flex;align-items:center;gap:10px;}
.section-tag::before{content:'';display:block;width:20px;height:1.5px;background:var(--lime);}
.section-title{font-family:'Syne',sans-serif;font-size:clamp(2.2rem,4.5vw,3.5rem);font-weight:800;line-height:1.1;letter-spacing:-0.02em;margin-bottom:3rem;color:var(--white);}
.section-title em{font-style:italic;color:var(--lime);}

/* ─── ABOUT ─── */
#about{background:var(--bg2);}
.about-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:4rem;align-items:start;}
.about-body p{color:var(--muted2);margin-bottom:1rem;font-size:0.95rem;line-height:1.9;}
.about-body p strong{color:var(--white);}
.currently-panel{background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:1.6rem;}
.currently-panel h3{font-size:0.68rem;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;color:var(--muted);margin-bottom:1.25rem;display:flex;align-items:center;gap:10px;}
.currently-panel h3::after{content:'';flex:1;height:1px;background:var(--border);}
.c-item{display:flex;align-items:flex-start;gap:12px;margin-bottom:0.9rem;font-size:0.875rem;color:#aaa;}
.c-dot{width:7px;height:7px;border-radius:50%;background:var(--lime);margin-top:8px;flex-shrink:0;box-shadow:0 0 8px var(--lime);}

/* ─── WHAT I CAN DO ─── */
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;}
.service-card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:1.5rem 1.5rem 1.5rem 1.25rem;display:flex;align-items:flex-start;gap:14px;transition:all 0.25s;border-left:3px solid transparent;}
.service-card:hover{border-left-color:var(--lime);background:var(--bg3);transform:translateX(4px);}
.service-check{width:26px;height:26px;border-radius:6px;background:var(--lime-dim);border:1px solid rgba(200,255,0,0.2);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.service-check svg{width:13px;height:13px;}
.service-text p{font-size:0.9rem;font-weight:600;color:var(--white);margin-bottom:3px;}
.service-text span{font-size:0.78rem;color:var(--muted);}

/* ─── SKILLS ─── */
.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;}
.skill-card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:1.5rem;transition:border-color 0.2s,transform 0.2s;position:relative;overflow:hidden;}
.skill-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--lime),var(--cyan));transform:scaleX(0);transform-origin:left;transition:transform 0.35s ease;}
.skill-card:hover::before{transform:scaleX(1);}
.skill-card:hover{border-color:var(--border2);transform:translateY(-3px);}
.skill-cat{font-size:0.67rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--lime);margin-bottom:1.2rem;}
.skill-bar-row{margin-bottom:0.85rem;}
.skill-bar-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:5px;}
.skill-name{font-size:0.82rem;color:#ccc;font-weight:500;}
.skill-pct{font-size:0.72rem;color:var(--lime);font-weight:700;font-family:'Bebas Neue',sans-serif;letter-spacing:0.05em;}
.skill-track{height:4px;background:#1e1e1e;border-radius:2px;overflow:hidden;}
.skill-fill{height:100%;background:linear-gradient(90deg,var(--lime2),var(--lime));border-radius:2px;width:0%;transition:width 1.2s cubic-bezier(0.16,1,0.3,1);}

/* ─── DSA SECTION ─── */
#dsa{background:var(--bg);}
.dsa-top{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start;margin-bottom:3rem;}
.dsa-intro p{font-size:0.95rem;color:var(--muted2);line-height:1.9;margin-bottom:1rem;}
.dsa-intro p strong{color:var(--white);}
.dsa-stats-row{display:flex;gap:1.5rem;flex-wrap:wrap;margin-top:1.5rem;}
.dsa-stat{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:1rem 1.25rem;min-width:100px;text-align:center;}
.dsa-stat-num{font-family:'Bebas Neue',sans-serif;font-size:2rem;color:var(--lime);line-height:1;}
.dsa-stat-lbl{font-size:0.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.08em;margin-top:2px;}
.dsa-platforms{display:flex;flex-direction:column;gap:0.75rem;}
.platform-card{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:1.1rem 1.25rem;display:flex;align-items:center;gap:14px;text-decoration:none;transition:all 0.2s;border-left:3px solid transparent;}
.platform-card:hover{border-left-color:var(--lime);transform:translateX(4px);}
.plat-icon{width:38px;height:38px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:'Bebas Neue',sans-serif;font-size:0.85rem;font-weight:700;letter-spacing:0.04em;}
.plat-lc{background:#1a1a00;color:var(--lime);border:1px solid rgba(200,255,0,0.2);}
.plat-info{flex:1;}
.plat-name{font-size:0.9rem;font-weight:600;color:var(--white);margin-bottom:2px;}
.plat-sub{font-size:0.75rem;color:var(--muted2);}
.plat-arrow{color:var(--muted);font-size:1rem;transition:color 0.2s;}
.platform-card:hover .plat-arrow{color:var(--lime);}



/* ─── JOURNEY ─── */
#journey{background:var(--bg2);padding:6rem 0 5rem;overflow:hidden;}
.j-header{padding:0 3rem 3rem;max-width:1200px;margin:0 auto;display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:1rem;}
.j-step-counter{font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:0.14em;color:var(--lime);opacity:0.8;}
.j-track-outer{overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;cursor:grab;scrollbar-width:none;padding-bottom:2rem;}
.j-track-outer::-webkit-scrollbar{display:none;}
.j-track-outer:active{cursor:grabbing;}
.j-track{display:flex;width:max-content;padding:0 3rem;gap:1.5rem;align-items:stretch;}
.j-card{scroll-snap-align:start;width:300px;flex-shrink:0;background:var(--bg3);border:1.5px solid var(--border);border-radius:16px;padding:2rem 1.75rem;display:flex;flex-direction:column;gap:1rem;position:relative;cursor:pointer;transition:border-color 0.4s ease,transform 0.4s cubic-bezier(0.16,1,0.3,1),box-shadow 0.4s ease;}
.j-card:hover{transform:translateY(-4px);border-color:rgba(200,255,0,0.2);}
.j-card.j-active{border-color:var(--lime);background:linear-gradient(145deg,#141400 0%,var(--bg3) 100%);transform:translateY(-6px);box-shadow:0 20px 60px rgba(0,0,0,0.5),0 0 0 1px rgba(200,255,0,0.12);}
.j-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--lime),var(--cyan));border-radius:2px 2px 0 0;transform:scaleX(0);transition:transform 0.4s ease;}
.j-card.j-active::before{transform:scaleX(1);}
.j-top-row{display:flex;align-items:center;gap:0.75rem;flex-wrap:wrap;}
.j-year-pill{font-family:'Bebas Neue',sans-serif;font-size:0.85rem;letter-spacing:0.14em;background:var(--lime);color:#000;padding:4px 14px;border-radius:100px;flex-shrink:0;}
.j-chapter-lbl{font-size:0.65rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);}
.j-big-title{font-family:'Bebas Neue',sans-serif;font-size:2.4rem;line-height:1;letter-spacing:-0.01em;color:var(--white);transition:color 0.3s;}
.j-card.j-active .j-big-title{color:var(--lime);}
.j-big-title em{color:var(--lime);font-style:normal;}
.j-desc{font-size:0.825rem;color:#888;line-height:1.7;flex:1;transition:color 0.3s;}
.j-card.j-active .j-desc{color:var(--muted2);}
.j-skills{display:flex;flex-wrap:wrap;gap:5px;}
.j-skill{background:var(--bg);border:1px solid var(--border);color:#666;font-size:0.62rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;padding:3px 10px;border-radius:5px;transition:all 0.3s;}
.j-card.j-active .j-skill{border-color:rgba(200,255,0,0.25);color:#aaa;}
.j-nav-row{display:flex;align-items:center;gap:1rem;padding:1.5rem 3rem 0;max-width:1200px;margin:0 auto;}
.j-nav-btn{width:40px;height:40px;border-radius:50%;background:var(--bg3);border:1px solid var(--border2);color:var(--muted2);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 0.2s;flex-shrink:0;}
.j-nav-btn:hover{border-color:var(--lime);color:var(--lime);}
.j-nav-btn:disabled{opacity:0.25;cursor:default;pointer-events:none;}
.j-pips{display:flex;gap:6px;align-items:center;flex:1;}
.j-pip{height:3px;flex:1;border-radius:2px;background:var(--border2);max-width:60px;transition:background 0.4s,transform 0.3s;}
.j-pip.j-pip-done{background:rgba(200,255,0,0.35);}
.j-pip.j-pip-active{background:var(--lime);transform:scaleY(2.5);}
.j-pip-lbl{font-family:'Bebas Neue',sans-serif;font-size:1rem;color:var(--lime);letter-spacing:0.08em;flex-shrink:0;}
.j-scroll-hint{display:flex;align-items:center;gap:8px;padding:0 3rem 1.5rem;font-size:0.68rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);animation:hintPulse 2s ease-in-out infinite;}
@keyframes hintPulse{0%,100%{opacity:0.35;}50%{opacity:0.9;}}

/* ─── PROJECTS ZIGZAG ─── */
#projects{background:var(--bg);padding:7rem 3rem;}
.proj-zigzag{display:flex;flex-direction:column;gap:1.5rem;position:relative;padding:0.5rem 0;}

.pzz-row{
  display:grid;
  grid-template-columns:1fr 100px 1fr;
  align-items:center;
  min-height:120px;
}
.pzz-row.pzz-odd  > .pzz-card  {grid-column:1;grid-row:1;padding-right:1.5rem;}
.pzz-row.pzz-odd  > .pzz-mid   {grid-column:2;grid-row:1;}
.pzz-row.pzz-odd  > .pzz-empty {grid-column:3;grid-row:1;}
.pzz-row.pzz-even > .pzz-empty {grid-column:1;grid-row:1;}
.pzz-row.pzz-even > .pzz-mid   {grid-column:2;grid-row:1;}
.pzz-row.pzz-even > .pzz-card  {grid-column:3;grid-row:1;padding-left:1.5rem;}

.pzz-mid{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;position:relative;z-index:3;}

.pzz-eleph{display:flex;align-items:center;justify-content:center;width:70px;height:70px;}
.pzz-eleph svg{width:64px;height:auto;}

.pzz-eleph-lime svg{filter:drop-shadow(0 0 10px rgba(200,255,0,0.5));}
.pzz-eleph-cyan svg{filter:drop-shadow(0 0 10px rgba(0,245,255,0.5));}
.pzz-eleph-pink svg{filter:drop-shadow(0 0 10px rgba(255,45,120,0.5));}

.pzz-r1 .pzz-eleph svg{animation:pzf1 2.1s ease-in-out infinite;}
.pzz-r2 .pzz-eleph svg{animation:pzf1f 2.5s ease-in-out infinite 0.3s;}
.pzz-r3 .pzz-eleph svg{animation:pzf2 1.9s ease-in-out infinite 0.1s;}
.pzz-r4 .pzz-eleph svg{animation:pzf2f 2.7s ease-in-out infinite 0.5s;}
.pzz-r5 .pzz-eleph svg{animation:pzf3 2.2s ease-in-out infinite 0.2s;}

@keyframes pzf1{0%,100%{transform:translateY(0) rotate(-4deg);}50%{transform:translateY(-12px) rotate(4deg);}}
@keyframes pzf2{0%,100%{transform:translateY(-3px) rotate(2deg);}50%{transform:translateY(9px) rotate(-4deg);}}
@keyframes pzf3{0%,100%{transform:translateY(0) scale(1) rotate(0deg);}40%{transform:translateY(-10px) scale(1.06) rotate(-3deg);}70%{transform:translateY(4px) scale(0.97) rotate(2deg);}}
@keyframes pzf1f{0%,100%{transform:scaleX(-1) translateY(0) rotate(-4deg);}50%{transform:scaleX(-1) translateY(-12px) rotate(4deg);}}
@keyframes pzf2f{0%,100%{transform:scaleX(-1) translateY(-3px) rotate(2deg);}50%{transform:scaleX(-1) translateY(9px) rotate(-4deg);}}

.pzz-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;}
.pzz-dot-lime{background:var(--lime);box-shadow:0 0 12px var(--lime);}
.pzz-dot-cyan{background:var(--cyan);box-shadow:0 0 12px var(--cyan);}
.pzz-dot-pink{background:var(--pink);box-shadow:0 0 12px var(--pink);}

.proj-card-full{
  background:var(--bg3);border:1px solid var(--border);border-radius:14px;
  padding:1.75rem;position:relative;overflow:hidden;
  opacity:0;transform:translateX(-50px);
  transition:opacity 0.6s ease,transform 0.6s cubic-bezier(0.16,1,0.3,1),border-color 0.3s,box-shadow 0.3s;
}
.pzz-even .proj-card-full{transform:translateX(50px);}
.proj-card-full.pcf-vis{opacity:1;transform:translateX(0);}
.proj-card-full::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--lime),var(--cyan));transform:scaleX(0);transform-origin:left;transition:transform 0.4s ease;}
.proj-card-full:hover::before{transform:scaleX(1);}
.proj-card-full:hover{border-color:rgba(200,255,0,0.3);transform:translateY(-4px) !important;box-shadow:0 20px 60px rgba(0,0,0,0.5);}
.pcf-num{font-family:'Bebas Neue',sans-serif;font-size:3.5rem;line-height:1;letter-spacing:-0.02em;color:rgba(200,255,0,0.06);position:absolute;top:1rem;right:1.25rem;pointer-events:none;transition:color 0.3s;}
.proj-card-full:hover .pcf-num{color:rgba(200,255,0,0.12);}
.pcf-title{font-family:'Syne',sans-serif;font-size:1.2rem;font-weight:700;color:var(--white);margin-bottom:0.5rem;max-width:340px;transition:color 0.3s;}
.proj-card-full:hover .pcf-title{color:var(--lime);}
.pcf-desc{font-size:0.85rem;color:var(--muted2);line-height:1.7;margin-bottom:1rem;max-width:400px;}
.pcf-tags{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:1rem;}
.proj-tag{background:#141414;border:1px solid #222;color:#666;font-size:0.62rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;padding:3px 9px;border-radius:4px;transition:border-color 0.3s,color 0.3s;}
.proj-card-full:hover .proj-tag{border-color:rgba(200,255,0,0.2);color:#999;}
.pcf-actions{display:flex;gap:7px;flex-wrap:wrap;}

.proj-btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:7px;font-size:0.7rem;font-weight:700;letter-spacing:0.05em;text-transform:uppercase;text-decoration:none;transition:all 0.2s;cursor:pointer;border:none;font-family:'Outfit',sans-serif;}
.proj-btn-live{background:var(--lime);color:#000;}
.proj-btn-live:hover{background:var(--lime2);}
.proj-btn-code{background:transparent;color:var(--muted2);border:1px solid var(--border2);}
.proj-btn-code:hover{border-color:var(--lime);color:var(--lime);}
.proj-btn-modal{background:transparent;color:var(--muted2);border:1px solid var(--border2);}
.proj-btn-modal:hover{border-color:var(--cyan);color:var(--cyan);}

#proj-curve-svg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:visible;z-index:1;}

/* ─── MODAL ─── */
#modal-overlay{position:fixed;inset:0;z-index:5000;background:rgba(0,0,0,0.88);display:flex;align-items:center;justify-content:center;padding:2rem;opacity:0;visibility:hidden;transition:all 0.3s;backdrop-filter:blur(6px);}
#modal-overlay.open{opacity:1;visibility:visible;}
.modal{background:var(--bg3);border:1px solid var(--border2);border-radius:16px;padding:2.5rem;max-width:560px;width:100%;position:relative;transform:scale(0.92) translateY(20px);transition:transform 0.35s ease;max-height:85vh;overflow-y:auto;}
#modal-overlay.open .modal{transform:scale(1) translateY(0);}
.modal-close{position:absolute;top:1.25rem;right:1.25rem;width:34px;height:34px;border:1px solid var(--border2);border-radius:6px;background:none;color:var(--muted2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.2s;}
.modal-close:hover{border-color:var(--pink);color:var(--pink);}
.modal-num{font-family:'Bebas Neue',sans-serif;font-size:1rem;color:var(--lime);letter-spacing:0.1em;margin-bottom:4px;}
.modal-title{font-family:'Syne',sans-serif;font-size:1.6rem;font-weight:800;color:var(--white);margin-bottom:1.25rem;}
.modal-section{margin-bottom:1.25rem;}
.modal-section h4{font-size:0.68rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--lime);margin-bottom:0.6rem;display:flex;align-items:center;gap:8px;}
.modal-section h4::after{content:'';flex:1;height:1px;background:var(--border);}
.modal-section ul{list-style:none;display:flex;flex-direction:column;gap:6px;}
.modal-section ul li{font-size:0.875rem;color:var(--muted2);display:flex;align-items:flex-start;gap:8px;line-height:1.6;}
.modal-section ul li::before{content:'→';color:var(--lime);flex-shrink:0;}
.modal-tags{display:flex;flex-wrap:wrap;gap:6px;}
.modal-tag{background:#141414;border:1px solid #222;color:#aaa;font-size:0.75rem;padding:4px 12px;border-radius:6px;}

/* ─── RESUME ─── */
#resume{background:linear-gradient(135deg,#0d1a00 0%,var(--bg) 60%);position:relative;overflow:hidden;}
#resume::before{content:'RESUME';position:absolute;font-family:'Bebas Neue',sans-serif;font-size:20vw;color:rgba(255,255,255,0.015);top:50%;left:50%;transform:translate(-50%,-50%);white-space:nowrap;pointer-events:none;}
.resume-box{background:var(--bg2);border:1px solid #1f2e00;border-radius:16px;padding:3rem;display:flex;flex-direction:column;align-items:center;text-align:center;gap:1.5rem;max-width:580px;margin:0 auto;}
.resume-icon-ring{width:68px;height:68px;border-radius:50%;border:2px solid var(--lime);display:flex;align-items:center;justify-content:center;animation:pulse-glow 3s ease-in-out infinite;}
@keyframes pulse-glow{0%,100%{box-shadow:0 0 0 0 rgba(200,255,0,0.3);}50%{box-shadow:0 0 20px 6px rgba(200,255,0,0.1);}}
.resume-box p{color:var(--muted2);font-size:0.95rem;max-width:380px;line-height:1.8;}
.resume-btns{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;}

/* ─── CONTACT ─── */
#contact{background:var(--bg2);}
.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:4rem;align-items:start;}
.contact-links{display:flex;flex-direction:column;gap:0.75rem;margin-top:0.5rem;}
.c-link{display:flex;align-items:center;gap:14px;padding:1rem 1.25rem;background:var(--bg3);border:1px solid var(--border);border-radius:10px;text-decoration:none;color:var(--white);font-size:0.875rem;font-weight:500;transition:all 0.2s;}
.c-link:hover{border-color:var(--lime);color:var(--lime);}
.c-icon{width:36px;height:36px;background:var(--bg4);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.c-meta{display:flex;flex-direction:column;}
.c-sub{font-size:0.68rem;color:var(--muted);letter-spacing:0.06em;text-transform:uppercase;}
.c-val{font-size:0.82rem;color:#ccc;}
.form{display:flex;flex-direction:column;gap:0.875rem;}
.form input,.form textarea{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:0.9rem 1.1rem;font-family:'Outfit',sans-serif;font-size:0.9rem;color:var(--white);outline:none;transition:border-color 0.2s;resize:vertical;}
.form input:focus,.form textarea:focus{border-color:var(--lime);}
.form input::placeholder,.form textarea::placeholder{color:#333;}
.form textarea{min-height:130px;}
#form-status{font-size:0.82rem;font-weight:600;text-align:center;display:none;}
#form-status.ok{color:var(--lime);display:block;}
#form-status.err{color:var(--pink);display:block;}

/* ─── FOOTER ─── */
footer{border-top:1px solid var(--border);padding:2rem 3rem;display:flex;align-items:center;justify-content:space-between;background:var(--bg);}
.footer-logo{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;letter-spacing:0.06em;color:var(--lime);}
footer p{font-size:0.78rem;color:var(--muted);}

/* ─── REVEAL ─── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.7s ease,transform 0.7s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}

/* ─── HAMBURGER ─── */
.nav-hamburger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:40px;height:40px;background:transparent;border:1px solid var(--border2);border-radius:8px;cursor:pointer;padding:0;transition:border-color 0.2s;flex-shrink:0;}
.nav-hamburger:hover{border-color:var(--lime);}
.nav-hamburger span{display:block;width:18px;height:1.5px;background:var(--white);border-radius:2px;transition:transform 0.35s cubic-bezier(0.16,1,0.3,1),opacity 0.25s ease,background 0.2s;transform-origin:center;}
.nav-hamburger.active span:nth-child(1){transform:translateY(6.5px) rotate(45deg);background:var(--lime);}
.nav-hamburger.active span:nth-child(2){opacity:0;transform:scaleX(0);}
.nav-hamburger.active span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);background:var(--lime);}

/* ─── MOBILE NAV DRAWER ─── */
#mobile-nav{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999;display:flex;flex-direction:column;background:rgba(8,8,8,0.97);backdrop-filter:blur(20px);padding:80px 2rem 2rem;transform:translateX(100%);transition:transform 0.45s cubic-bezier(0.16,1,0.3,1);overflow-y:auto;}
#mobile-nav.open{transform:translateX(0);}
.mobile-nav-links{list-style:none;display:flex;flex-direction:column;gap:0;flex:1;}
.mobile-nav-links li{border-bottom:1px solid var(--border);opacity:0;transform:translateX(30px);transition:opacity 0.4s ease,transform 0.4s cubic-bezier(0.16,1,0.3,1);}
#mobile-nav.open .mobile-nav-links li:nth-child(1){opacity:1;transform:translateX(0);transition-delay:0.05s;}
#mobile-nav.open .mobile-nav-links li:nth-child(2){opacity:1;transform:translateX(0);transition-delay:0.1s;}
#mobile-nav.open .mobile-nav-links li:nth-child(3){opacity:1;transform:translateX(0);transition-delay:0.15s;}
#mobile-nav.open .mobile-nav-links li:nth-child(4){opacity:1;transform:translateX(0);transition-delay:0.2s;}
#mobile-nav.open .mobile-nav-links li:nth-child(5){opacity:1;transform:translateX(0);transition-delay:0.25s;}
#mobile-nav.open .mobile-nav-links li:nth-child(6){opacity:1;transform:translateX(0);transition-delay:0.3s;}
#mobile-nav.open .mobile-nav-links li:nth-child(7){opacity:1;transform:translateX(0);transition-delay:0.35s;}
.mobile-nav-links a{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 0;text-decoration:none;color:var(--muted2);font-family:'Syne',sans-serif;font-size:1.4rem;font-weight:700;letter-spacing:-0.01em;transition:color 0.2s,padding-left 0.2s;}
.mobile-nav-links a:hover,.mobile-nav-links a:active{color:var(--lime);padding-left:0.5rem;}
.mobile-nav-links a .m-arrow{font-size:1rem;color:var(--muted);transition:color 0.2s,transform 0.2s;}
.mobile-nav-links a:hover .m-arrow{color:var(--lime);transform:translateX(4px);}
.mobile-nav-links a .m-num{font-family:'Bebas Neue',sans-serif;font-size:0.75rem;color:var(--muted);letter-spacing:0.1em;margin-right:auto;padding-left:0.75rem;}
.mobile-nav-footer{padding-top:1.5rem;opacity:0;transform:translateY(12px);transition:opacity 0.4s ease 0.4s,transform 0.4s ease 0.4s;}
#mobile-nav.open .mobile-nav-footer{opacity:1;transform:translateY(0);}
.mobile-nav-footer a.btn{width:100%;justify-content:center;font-size:0.85rem;padding:15px;}
.mobile-nav-status{display:flex;align-items:center;gap:8px;margin-bottom:1rem;font-size:0.7rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--lime);}
.mobile-nav-status-dot{width:6px;height:6px;border-radius:50%;background:var(--lime);box-shadow:0 0 8px var(--lime);animation:blink 1.5s infinite;}

/* ═══════════════════════════════════════════
   RESPONSIVE — TABLET (≤900px)
   ═══════════════════════════════════════════ */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;}
  .hero-avatar{display:none;}
  .about-grid{grid-template-columns:1fr;gap:2.5rem;}
  .contact-grid{grid-template-columns:1fr;gap:2.5rem;}
  .dsa-top{grid-template-columns:1fr;gap:2rem;}
}

/* ═══════════════════════════════════════════
   RESPONSIVE — MOBILE (≤768px)
   ═══════════════════════════════════════════ */
@media(max-width:768px){
  html,body{overflow-x:hidden !important;}

  /* ── Nav ── */
  nav{padding:0 1.25rem !important;height:54px;}
  .nav-links{display:none !important;}
  .nav-cta{display:none !important;}
  .nav-hamburger{display:flex;}

  /* ── Sections ── */
  section{padding:4rem 1.25rem !important;}
  .section-inner{max-width:100% !important;width:100% !important;}
  .section-title{font-size:clamp(1.8rem,7vw,2.6rem) !important;margin-bottom:2rem !important;}

  /* ── Hero ── */
  #hero{padding:5rem 1.25rem 3rem !important;min-height:auto;}
  .hero-grid{grid-template-columns:1fr !important;gap:2rem;text-align:center;}
  .hero-avatar{display:flex !important;justify-content:center;order:-1;}
  .avatar-ring{width:130px !important;height:130px !important;}
  .hero-name{font-size:clamp(3.2rem,15vw,5.5rem) !important;}
  .hero-divider{justify-content:center;}
  .hero-sub{font-size:0.88rem !important;max-width:100%;}
  .hero-btns{justify-content:center;flex-wrap:wrap;gap:0.75rem;}
  .hero-stats{justify-content:center;gap:2rem;margin-top:2.5rem;}
  .typing-wrap{justify-content:center;}
  .hero-badge{font-size:0.6rem;padding:5px 12px;text-align:center;}

  /* ── About ── */
  .about-grid{grid-template-columns:1fr !important;gap:2rem !important;}
  .services-grid{grid-template-columns:1fr !important;gap:0.75rem !important;}

  /* ── Skills ── */
  .skills-grid{grid-template-columns:1fr !important;gap:1rem !important;}

  /* ── DSA ── */
  .dsa-top{grid-template-columns:1fr !important;gap:2rem !important;}
  .dsa-stats-row{gap:0.75rem;}

  /* ── Journey ── */
  #journey{padding:4rem 0 3rem !important;}
  .j-header{padding:0 1.25rem 2rem !important;flex-direction:column;align-items:flex-start;gap:0.4rem;}
  .j-scroll-hint{padding:0 1.25rem 1rem !important;}
  .j-track{padding:0 1.25rem !important;gap:1rem;}
  .j-card{width:260px !important;padding:1.5rem 1.25rem !important;}
  .j-big-title{font-size:2rem !important;}
  .j-nav-row{padding:1.25rem 1.25rem 0 !important;}

  /* ══════════════════════════════════════════
     PROJECTS — MOBILE VERTICAL TIMELINE
     Cards alternate left/right of a center spine
     ══════════════════════════════════════════ */
  #projects{padding:3.5rem 0.75rem !important;}

  /* Hide the desktop zigzag entirely */
  .proj-zigzag{display:none !important;}

  /* Show the mobile timeline (injected by JS) */
  .mob-timeline{
    display:block;
    position:relative;
    padding:0.5rem 0 2rem;
  }

  /* The vertical spine line */
  .mob-timeline-spine{
    position:absolute;
    left:50%;
    top:0; bottom:0;
    width:2px;
    background:linear-gradient(to bottom, var(--lime), var(--cyan) 55%, var(--pink));
    transform:translateX(-50%);
    z-index:0;
  }

  /* Each timeline item */
  .mob-tl-item{
    display:flex;
    align-items:flex-start;
    margin-bottom:1.75rem;
    position:relative;
  }
  /* odd items: card on left, node on right spine */
  .mob-tl-item:nth-child(odd){
    flex-direction:row;
    padding-right:calc(50% + 20px);
  }
  /* even items: card on right */
  .mob-tl-item:nth-child(even){
    flex-direction:row-reverse;
    padding-left:calc(50% + 20px);
  }

  /* The dot node on the spine */
  .mob-tl-node{
    position:absolute;
    left:50%;
    top:18px;
    transform:translateX(-50%);
    z-index:3;
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:3px;
  }
  .mob-tl-elephant{
    width:36px; height:36px;
    filter:drop-shadow(0 0 8px var(--lime));
  }
  .mob-tl-item:nth-child(3n+2) .mob-tl-elephant{filter:drop-shadow(0 0 8px var(--cyan));}
  .mob-tl-item:nth-child(3n+3) .mob-tl-elephant{filter:drop-shadow(0 0 8px var(--pink));}
  .mob-tl-dot{
    width:10px; height:10px; border-radius:50%;
    background:var(--lime);
    box-shadow:0 0 10px var(--lime);
    flex-shrink:0;
  }
  .mob-tl-item:nth-child(3n+2) .mob-tl-dot{background:var(--cyan);box-shadow:0 0 10px var(--cyan);}
  .mob-tl-item:nth-child(3n+3) .mob-tl-dot{background:var(--pink);box-shadow:0 0 10px var(--pink);}

  /* Connector arm from spine to card */
  .mob-tl-item:nth-child(odd) .mob-tl-arm{
    position:absolute;
    left:50%;right:auto;
    top:24px;
    width:calc(50% - 38px);
    height:1.5px;
    background:linear-gradient(to left, transparent, var(--lime));
    transform:none;
  }
  .mob-tl-item:nth-child(even) .mob-tl-arm{
    position:absolute;
    right:50%;left:auto;
    top:24px;
    width:calc(50% - 38px);
    height:1.5px;
    background:linear-gradient(to right, transparent, var(--cyan));
  }
  .mob-tl-item:nth-child(3n+3) .mob-tl-arm{
    background:linear-gradient(to left, transparent, var(--pink));
  }

  /* The mini card */
  .mob-tl-card{
    background:var(--bg3);
    border:1px solid var(--border);
    border-radius:10px;
    padding:0.85rem;
    width:100%;
    position:relative;
    overflow:hidden;
    transition:border-color 0.25s, transform 0.25s;
  }
  .mob-tl-card::before{
    content:'';position:absolute;top:0;left:0;right:0;height:2px;
    background:linear-gradient(90deg,var(--lime),var(--cyan));
    transform:scaleX(0);transform-origin:left;transition:transform 0.3s;
  }
  .mob-tl-card:hover::before{transform:scaleX(1);}
  .mob-tl-card:hover{border-color:rgba(200,255,0,0.3);transform:translateY(-2px);}
  .mob-tl-item:nth-child(even) .mob-tl-card::before{
    background:linear-gradient(90deg,var(--cyan),var(--lime));
  }

  .mob-tl-num{
    font-family:'Bebas Neue',sans-serif;
    font-size:2rem; line-height:1;
    color:rgba(200,255,0,0.07);
    position:absolute;top:0.4rem;right:0.6rem;
    pointer-events:none;
  }
  .mob-tl-title{
    font-family:'Syne',sans-serif;
    font-size:0.85rem;font-weight:700;
    color:var(--white);margin-bottom:0.3rem;
    padding-right:1.5rem;
  }
  .mob-tl-desc{
    font-size:0.72rem;color:var(--muted2);
    line-height:1.5;margin-bottom:0.6rem;
  }
  .mob-tl-tags{display:flex;flex-wrap:wrap;gap:3px;margin-bottom:0.6rem;}
  .mob-tl-tag{
    background:#141414;border:1px solid #222;
    color:#666;font-size:0.55rem;font-weight:700;
    letter-spacing:0.05em;text-transform:uppercase;
    padding:2px 6px;border-radius:3px;
  }
  .mob-tl-actions{display:flex;gap:4px;flex-wrap:wrap;}
  .mob-tl-btn{
    display:inline-flex;align-items:center;gap:3px;
    padding:4px 8px;border-radius:5px;
    font-size:0.58rem;font-weight:700;letter-spacing:0.04em;
    text-transform:uppercase;text-decoration:none;
    border:none;cursor:pointer;font-family:'Outfit',sans-serif;
    transition:all 0.2s;
  }
  .mob-tl-btn-live{background:var(--lime);color:#000;}
  .mob-tl-btn-live:hover{background:var(--lime2);}
  .mob-tl-btn-ghost{background:transparent;color:var(--muted2);border:1px solid var(--border2);}
  .mob-tl-btn-ghost:hover{border-color:var(--lime);color:var(--lime);}
  .mob-tl-btn-cyan:hover{border-color:var(--cyan);color:var(--cyan);}

  /* Entrance animation */
  .mob-tl-item{
    opacity:0;
    transition:opacity 0.5s ease, transform 0.5s cubic-bezier(0.16,1,0.3,1);
  }
  .mob-tl-item:nth-child(odd){transform:translateX(-24px);}
  .mob-tl-item:nth-child(even){transform:translateX(24px);}
  .mob-tl-item.tl-vis{opacity:1;transform:translateX(0) !important;}

  /* ── Resume ── */
  #resume{padding:4rem 1.25rem !important;}
  .resume-box{padding:2rem 1.5rem !important;}
  .resume-btns{flex-direction:column;align-items:stretch;gap:0.75rem;}
  .resume-btns .btn{justify-content:center;}

  /* ── Contact ── */
  #contact{padding:4rem 1.25rem !important;}
  .contact-grid{grid-template-columns:1fr !important;gap:2.5rem !important;}
  .c-val{font-size:0.72rem !important;word-break:break-all;}

  /* ── Modal ── */
  #modal-overlay{padding:0 !important;align-items:flex-end !important;}
  .modal{max-height:88vh !important;border-radius:20px 20px 0 0 !important;padding:2rem 1.5rem 2.5rem !important;width:100% !important;max-width:100% !important;}

  /* ── Footer ── */
  footer{flex-direction:column !important;text-align:center;gap:0.5rem;padding:2rem 1.25rem !important;}
}

/* ═══════════════════════════════════════════
   RESPONSIVE — SMALL MOBILE (≤480px)
   ═══════════════════════════════════════════ */
@media(max-width:480px){
  section{padding:3.5rem 1rem !important;}
  .hero-name{font-size:clamp(2.8rem,18vw,4.5rem) !important;}
  .j-card{width:230px !important;}
  .btn{padding:11px 18px;font-size:0.75rem;}
  .section-title{font-size:clamp(1.5rem,8vw,2rem) !important;}
  .dsa-stat-num{font-size:1.5rem !important;}
  .hero-badge{font-size:0.58rem;letter-spacing:0.08em;}
  .resume-box{padding:1.75rem 1.25rem !important;}
  .c-link{padding:0.85rem 1rem;}
  .c-val{font-size:0.7rem !important;}
}

@keyframes fadeUp{from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);}}