/* ============================================================
   HARSH SAINI — Portfolio | style.css
   Mobile + Desktop Fully Responsive
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --bg:#03040a;--bg2:#070b14;
  --neon:#00ffe7;--neon2:#7b5cfa;--neon3:#ff2d78;
  --white:#f0f4ff;--muted:#8892b0;
  --glass:rgba(255,255,255,0.04);
  --glassb:rgba(0,255,231,0.15);
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{font-family:'Space Grotesk',sans-serif;background:var(--bg);color:var(--white);overflow-x:hidden;cursor:none;}
@media(max-width:768px){body{cursor:auto;}}

/* ── LOADER ── */
#loader{position:fixed;inset:0;z-index:10000;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;transition:opacity 0.9s ease,visibility 0.9s ease;}
#loader.hide{opacity:0;visibility:hidden;pointer-events:none;}
.loader-glitch{font-family:'Orbitron',monospace;font-size:clamp(2.5rem,10vw,4.5rem);font-weight:900;color:var(--neon);position:relative;text-shadow:0 0 40px rgba(0,255,231,0.9);animation:glitchLoop 2.5s infinite;}
.loader-glitch::before,.loader-glitch::after{content:'HS.';position:absolute;top:0;left:0;font-family:'Orbitron',monospace;font-size:clamp(2.5rem,10vw,4.5rem);font-weight:900;}
.loader-glitch::before{color:var(--neon3);clip-path:polygon(0 0,100% 0,100% 40%,0 40%);animation:glitchTop 2s infinite;}
.loader-glitch::after{color:var(--neon2);clip-path:polygon(0 60%,100% 60%,100% 100%,0 100%);animation:glitchBot 2s infinite;}
@keyframes glitchTop{0%,88%{transform:translate(0);opacity:0;}90%{transform:translate(-5px,2px);opacity:1;}93%{transform:translate(5px,-2px);opacity:1;}95%{transform:translate(0);opacity:0;}}
@keyframes glitchBot{0%,84%{transform:translate(0);opacity:0;}86%{transform:translate(5px,3px);opacity:1;}89%{transform:translate(-4px,-1px);opacity:1;}91%{transform:translate(0);opacity:0;}}
@keyframes glitchLoop{0%,87%{text-shadow:0 0 40px rgba(0,255,231,0.9);}88%{text-shadow:-5px 0 var(--neon3),5px 0 var(--neon2),0 0 40px rgba(0,255,231,0.9);}92%{text-shadow:0 0 40px rgba(0,255,231,0.9);}}
.loader-sub{font-size:clamp(0.6rem,2.5vw,0.72rem);letter-spacing:0.25em;text-transform:uppercase;color:var(--muted);}
.l-prog{width:min(280px,80vw);}
.l-bg{height:2px;background:rgba(255,255,255,0.06);border-radius:2px;overflow:hidden;position:relative;margin-bottom:0.6rem;}
.l-fill{height:100%;width:0%;border-radius:2px;background:linear-gradient(90deg,var(--neon),var(--neon2),var(--neon3));box-shadow:0 0 12px var(--neon);}
.l-glow{position:absolute;top:-4px;right:0;width:24px;height:10px;background:var(--neon);filter:blur(6px);opacity:0.9;}
.l-row{display:flex;justify-content:space-between;font-family:'Orbitron',monospace;font-size:0.68rem;color:var(--neon);letter-spacing:0.1em;}
.l-dots{display:flex;gap:10px;}
.l-dots span{width:6px;height:6px;border-radius:50%;animation:dotB 1.2s ease-in-out infinite;}
.l-dots span:nth-child(1){background:var(--neon);}
.l-dots span:nth-child(2){background:var(--neon2);animation-delay:0.2s;}
.l-dots span:nth-child(3){background:var(--neon3);animation-delay:0.4s;}
@keyframes dotB{0%,80%,100%{transform:scale(0.5);opacity:0.3;}40%{transform:scale(1.5);opacity:1;box-shadow:0 0 12px currentColor;}}

/* ── CURSOR (desktop only) ── */
#cur,#curR{display:none;}
@media(hover:hover) and (pointer:fine){
  #cur{display:block;position:fixed;width:10px;height:10px;background:var(--neon);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);box-shadow:0 0 10px var(--neon),0 0 20px var(--neon);transition:transform 0.1s,width 0.2s,height 0.2s;}
  #curR{display:block;position:fixed;width:38px;height:38px;border:1.5px solid rgba(0,255,231,0.5);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:left 0.1s,top 0.1s,width 0.2s,height 0.2s,border-color 0.2s;}
  #cur.h{width:5px;height:5px;}
  #curR.h{width:54px;height:54px;border-color:var(--neon);box-shadow:0 0 20px rgba(0,255,231,0.3);}
  body{cursor:none;}
}
#canvas{position:fixed;inset:0;z-index:0;pointer-events:none;}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:1rem 5vw;background:rgba(3,4,10,0.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(0,255,231,0.08);transform:translateY(-100%);animation:navDrop 0.7s 2.4s cubic-bezier(0.16,1,0.3,1) forwards;}
@keyframes navDrop{to{transform:translateY(0);}}
.logo{font-family:'Orbitron',monospace;font-size:1rem;font-weight:700;color:var(--neon);text-decoration:none;text-shadow:0 0 20px var(--neon);letter-spacing:0.1em;}
.nav-links{list-style:none;display:flex;gap:2rem;align-items:center;}
.nav-links a{font-size:0.78rem;font-weight:500;color:var(--muted);text-decoration:none;letter-spacing:0.07em;text-transform:uppercase;transition:color 0.2s;position:relative;}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-3px;width:0;height:1px;background:var(--neon);transition:width 0.3s;}
.nav-links a:hover{color:var(--neon);}
.nav-links a:hover::after{width:100%;}
.ncta{border:1px solid var(--neon)!important;color:var(--neon)!important;padding:0.4rem 1rem;border-radius:6px;}
.ncta::after{display:none!important;}
.ncta:hover{background:rgba(0,255,231,0.1)!important;}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px;z-index:101;}
.hamburger span{display:block;width:24px;height:2px;background:var(--neon);border-radius:2px;transition:all 0.3s;}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}

/* Mobile nav drawer */
.mobile-nav{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(3,4,10,0.97);backdrop-filter:blur(20px);z-index:99;flex-direction:column;align-items:center;justify-content:center;gap:2.5rem;opacity:0;transition:opacity 0.3s;}
.mobile-nav.open{opacity:1;}
.mobile-nav a{font-family:'Orbitron',monospace;font-size:1.4rem;font-weight:700;color:var(--muted);text-decoration:none;letter-spacing:0.1em;text-transform:uppercase;transition:color 0.2s,text-shadow 0.2s;}
.mobile-nav a:hover,.mobile-nav a:active{color:var(--neon);text-shadow:0 0 20px var(--neon);}

@media(max-width:768px){
  .nav-links{display:none;}
  .hamburger{display:flex;}
  .mobile-nav{display:flex;}
}

/* ── HERO ── */
#hero{min-height:100svh;display:flex;align-items:center;padding:0 5vw;position:relative;z-index:1;overflow:hidden;padding-top:70px;}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;width:100%;max-width:1200px;margin:0 auto;}
.hero-left{opacity:0;animation:fromL 1s 2.7s cubic-bezier(0.16,1,0.3,1) forwards;}
.hero-right{opacity:0;animation:fromR 1s 2.9s cubic-bezier(0.16,1,0.3,1) forwards;}
@keyframes fromL{from{opacity:0;transform:translateX(-60px);}to{opacity:1;transform:none;}}
@keyframes fromR{from{opacity:0;transform:translateX(60px);}to{opacity:1;transform:none;}}

.hgreet{font-size:0.78rem;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;color:var(--neon);margin-bottom:1.2rem;display:flex;align-items:center;gap:10px;}
.hgreet::before{content:'';width:32px;height:1px;background:var(--neon);box-shadow:0 0 10px var(--neon);}
.hname{font-family:'Orbitron',monospace;font-size:clamp(1.9rem,5vw,4.2rem);font-weight:900;line-height:1.05;letter-spacing:-0.02em;margin-bottom:0.8rem;background:linear-gradient(135deg,#fff 0%,var(--neon) 50%,var(--neon2) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative;}
.hname::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.18) 50%,transparent);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;animation:shimmer 3s 5s infinite;}
@keyframes shimmer{0%{background-position:200% 0;}100%{background-position:-200% 0;}}
.htyped{font-size:clamp(1rem,3vw,1.4rem);font-weight:500;color:var(--muted);margin-bottom:1.5rem;min-height:2rem;}
.ttext{color:var(--neon);}
.tcur{color:var(--neon);animation:blink 0.7s infinite;}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:0;}}
.hdesc{font-size:clamp(0.85rem,2vw,1rem);color:var(--muted);line-height:1.8;max-width:480px;margin-bottom:2rem;font-weight:300;}
.hdesc strong{color:var(--white);font-weight:500;}
.hbtns{display:flex;gap:0.75rem;flex-wrap:wrap;margin-bottom:2.5rem;}
.btn-neon{display:inline-flex;align-items:center;gap:8px;background:var(--neon);color:#03040a;padding:0.75rem 1.6rem;border-radius:8px;font-weight:700;font-size:0.85rem;letter-spacing:0.02em;text-decoration:none;border:none;cursor:pointer;font-family:'Space Grotesk',sans-serif;position:relative;overflow:hidden;transition:box-shadow 0.2s,transform 0.2s;-webkit-tap-highlight-color:transparent;}
.btn-neon::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.3),transparent);transition:left 0.4s;}
.btn-neon:hover{box-shadow:0 0 30px rgba(0,255,231,0.5),0 0 60px rgba(0,255,231,0.15);transform:translateY(-2px);}
.btn-neon:hover::before{left:100%;}
.btn-neon:active{transform:scale(0.97);}
.btn-outline{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--white);padding:0.75rem 1.6rem;border-radius:8px;font-weight:500;font-size:0.85rem;text-decoration:none;cursor:pointer;font-family:'Space Grotesk',sans-serif;border:1px solid rgba(255,255,255,0.18);transition:border-color 0.2s,background 0.2s,transform 0.2s;-webkit-tap-highlight-color:transparent;}
.btn-outline:hover{border-color:rgba(0,255,231,0.5);background:rgba(0,255,231,0.06);transform:translateY(-2px);}
.btn-outline:active{transform:scale(0.97);}
.hstats{display:flex;gap:2rem;flex-wrap:wrap;padding-top:1.8rem;border-top:1px solid rgba(255,255,255,0.07);}
.snum{font-family:'Orbitron',monospace;font-size:clamp(1.4rem,4vw,1.9rem);font-weight:700;color:var(--neon);line-height:1;text-shadow:0 0 20px rgba(0,255,231,0.4);}
.slbl{font-size:0.7rem;color:var(--muted);margin-top:4px;letter-spacing:0.04em;}

/* ── PHOTO SCENE ── */
.photo-scene{position:relative;width:clamp(240px,38vw,360px);height:clamp(240px,38vw,360px);margin:0 auto;transition:transform 0.15s ease-out;}
.ring-pulse{position:absolute;inset:-24px;border-radius:50%;border:1px solid rgba(0,255,231,0.08);animation:ringP 2.5s ease-in-out infinite;}
.ring-pulse2{position:absolute;inset:-44px;border-radius:50%;border:1px solid rgba(123,92,250,0.06);animation:ringP 2.5s 1.2s ease-in-out infinite;}
@keyframes ringP{0%,100%{transform:scale(1);opacity:0.5;}50%{transform:scale(1.05);opacity:0.1;}}
.ring-dash{position:absolute;inset:-12px;border-radius:50%;border:1.5px dashed rgba(0,255,231,0.2);animation:sCCW 14s linear infinite;}
.ring-arc{position:absolute;inset:-5px;border-radius:50%;border:3px solid transparent;border-top-color:var(--neon);border-right-color:var(--neon2);filter:drop-shadow(0 0 6px var(--neon));animation:sCW 2.5s linear infinite;}
.ring-arc2{position:absolute;inset:-18px;border-radius:50%;border:2px solid transparent;border-bottom-color:var(--neon3);border-left-color:var(--neon2);animation:sCCW 5s linear infinite;}
@keyframes sCW{to{transform:rotate(360deg);}}
@keyframes sCCW{to{transform:rotate(-360deg);}}
.hex-svg{position:absolute;inset:-28px;animation:sCW 25s linear infinite;}
.photo-circle{position:absolute;inset:0;border-radius:50%;overflow:hidden;border:3px solid rgba(0,255,231,0.22);box-shadow:0 0 40px rgba(0,255,231,0.1),0 0 80px rgba(0,255,231,0.05),inset 0 0 30px rgba(0,255,231,0.04);}
.photo-circle img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;}
.scan{position:absolute;inset:0;border-radius:50%;background:linear-gradient(180deg,transparent 0%,rgba(0,255,231,0.08) 50%,transparent 100%);animation:scanD 3s ease-in-out infinite;pointer-events:none;}
@keyframes scanD{0%{transform:translateY(-100%);opacity:0;}20%{opacity:1;}80%{opacity:1;}100%{transform:translateY(100%);opacity:0;}}
.photo-holo{position:absolute;inset:0;border-radius:50%;background:linear-gradient(135deg,rgba(0,255,231,0.04),transparent 50%,rgba(123,92,250,0.04));animation:holoS 4s ease-in-out infinite;pointer-events:none;}
@keyframes holoS{0%,100%{opacity:0.3;}50%{opacity:0.8;}}
.orbit1{position:absolute;inset:-42px;border-radius:50%;animation:sCW 5s linear infinite;pointer-events:none;}
.od1{position:absolute;top:0;left:50%;transform:translateX(-50%) translateY(-50%);width:9px;height:9px;border-radius:50%;background:var(--neon);box-shadow:0 0 14px var(--neon),0 0 28px var(--neon);}
.orbit2{position:absolute;inset:-42px;border-radius:50%;animation:sCCW 8s linear infinite;pointer-events:none;}
.od2{position:absolute;bottom:0;right:8%;width:7px;height:7px;border-radius:50%;background:var(--neon2);box-shadow:0 0 12px var(--neon2);}
.orbit3{position:absolute;inset:-42px;border-radius:50%;animation:sCW 13s linear infinite;pointer-events:none;}
.od3{position:absolute;top:30%;right:0;width:5px;height:5px;border-radius:50%;background:var(--neon3);box-shadow:0 0 10px var(--neon3);}
.bracket{position:absolute;width:18px;height:18px;}
.br-tl{top:5px;left:5px;border-top:2px solid var(--neon);border-left:2px solid var(--neon);}
.br-tr{top:5px;right:5px;border-top:2px solid var(--neon);border-right:2px solid var(--neon);}
.br-bl{bottom:5px;left:5px;border-bottom:2px solid var(--neon);border-left:2px solid var(--neon);}
.br-br{bottom:5px;right:5px;border-bottom:2px solid var(--neon);border-right:2px solid var(--neon);}
.fbadge{position:absolute;background:rgba(7,11,20,0.92);border:1px solid var(--glassb);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:12px;padding:0.55rem 0.85rem;font-size:0.72rem;font-weight:500;display:flex;align-items:center;gap:7px;white-space:nowrap;z-index:10;}
.fb1{top:-10px;left:-50px;animation:floatA 3.5s ease-in-out infinite;}
.fb2{bottom:-10px;right:-45px;animation:floatB 3.5s ease-in-out infinite 1.8s;}
@keyframes floatA{0%,100%{transform:translateY(0) rotate(-2deg);}50%{transform:translateY(-10px) rotate(2deg);}}
@keyframes floatB{0%,100%{transform:translateY(0) rotate(1deg);}50%{transform:translateY(-8px) rotate(-2deg);}}
.fbdot{width:7px;height:7px;border-radius:50%;background:var(--neon);box-shadow:0 0 8px var(--neon);animation:ping 2s infinite;}
@keyframes ping{0%,100%{opacity:1;}50%{opacity:0.3;}}

/* ── SECTIONS ── */
section:not(#hero){padding:5rem 5vw;position:relative;z-index:1;}
.stag{display:inline-flex;align-items:center;gap:10px;font-size:0.7rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--neon);margin-bottom:0.8rem;}
.stag::before{content:'';width:28px;height:1px;background:var(--neon);box-shadow:0 0 8px var(--neon);}
.stitle{font-family:'Orbitron',monospace;font-size:clamp(1.5rem,4vw,2.8rem);font-weight:700;letter-spacing:-0.01em;margin-bottom:0.8rem;line-height:1.2;}
.ssub{color:var(--muted);font-size:0.9rem;max-width:500px;font-weight:300;line-height:1.7;}
.sh{margin-bottom:3rem;}

/* ABOUT */
#about{background:var(--bg2);}
.about-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:4rem;align-items:start;}
.ap{color:var(--muted);font-size:0.9rem;line-height:1.85;font-weight:300;margin-bottom:1rem;}
.ap strong{color:var(--white);font-weight:500;}
.icards{display:flex;flex-direction:column;gap:0.7rem;}
.icard{background:var(--glass);border:1px solid rgba(255,255,255,0.06);border-radius:10px;padding:0.85rem 1rem;display:flex;justify-content:space-between;align-items:center;transition:border-color 0.3s,transform 0.3s;position:relative;overflow:hidden;}
.icard::before{content:'';position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(90deg,rgba(0,255,231,0.07),transparent);transition:width 0.3s;}
.icard:hover{border-color:rgba(0,255,231,0.25);transform:translateX(6px);}
.icard:hover::before{width:100%;}
.ik{font-size:0.68rem;color:var(--muted);letter-spacing:0.06em;text-transform:uppercase;}
.iv{font-size:0.8rem;color:var(--white);font-weight:500;text-align:right;}

/* EXPERIENCE */
#experience{background:var(--bg);}
.etl{display:flex;flex-direction:column;position:relative;}
.etl::before{content:'';position:absolute;left:0;top:0;bottom:0;width:1px;background:linear-gradient(to bottom,var(--neon),transparent);opacity:0.3;}
.ecard{background:var(--glass);border:1px solid rgba(255,255,255,0.06);border-radius:14px;padding:1.5rem 1.5rem 1.5rem 2rem;margin-left:1.8rem;margin-bottom:1.2rem;position:relative;transition:border-color 0.3s,transform 0.3s;overflow:hidden;}
.ecard::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,255,231,0.03),transparent 60%);opacity:0;transition:opacity 0.3s;}
.ecard:hover{border-color:rgba(0,255,231,0.22);transform:translateX(5px);}
.ecard:hover::after{opacity:1;}
.ecard::before{content:'';position:absolute;left:-2.4rem;top:1.8rem;width:9px;height:9px;border-radius:50%;background:var(--neon);box-shadow:0 0 12px var(--neon);}
.eh{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:0.25rem;flex-wrap:wrap;gap:0.5rem;}
.er{font-size:0.95rem;font-weight:600;color:var(--white);}
.ed{font-size:0.68rem;color:var(--neon);font-weight:500;background:rgba(0,255,231,0.08);border:1px solid rgba(0,255,231,0.15);padding:0.2rem 0.6rem;border-radius:100px;white-space:nowrap;}
.ec{font-size:0.78rem;color:var(--muted);margin-bottom:0.8rem;}
.eul{list-style:none;display:flex;flex-direction:column;gap:0.45rem;}
.eul li{font-size:0.82rem;color:var(--muted);font-weight:300;padding-left:1.1rem;position:relative;line-height:1.6;}
.eul li::before{content:'▸';position:absolute;left:0;color:var(--neon);font-size:0.65rem;top:3px;}

/* SKILLS */
#skills{background:var(--bg2);}
.sgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.2rem;}
.sglass{background:var(--glass);border:1px solid rgba(255,255,255,0.06);border-radius:14px;padding:1.5rem;transition:border-color 0.3s,transform 0.3s,box-shadow 0.3s;position:relative;overflow:hidden;}
.sglass::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--neon),transparent);opacity:0;transition:opacity 0.3s;}
.sglass::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,rgba(0,255,231,0.05),transparent 60%);opacity:0;transition:opacity 0.3s;}
.sglass:hover{border-color:rgba(0,255,231,0.22);transform:translateY(-5px);box-shadow:0 20px 40px rgba(0,0,0,0.4),0 0 25px rgba(0,255,231,0.06);}
.sglass:hover::before,.sglass:hover::after{opacity:1;}
.sgi{font-size:1.8rem;margin-bottom:0.8rem;display:inline-block;filter:drop-shadow(0 0 6px rgba(0,255,231,0.4));transition:transform 0.3s;}
.sglass:hover .sgi{transform:scale(1.15) rotate(-6deg);}
.sgt{font-size:0.9rem;font-weight:600;margin-bottom:1rem;color:var(--white);}
.sbr{margin-bottom:0.6rem;}
.sbl{display:flex;justify-content:space-between;font-size:0.72rem;color:var(--muted);margin-bottom:0.25rem;}
.sbt{height:3px;background:rgba(255,255,255,0.06);border-radius:2px;overflow:hidden;}
.sbf{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--neon),var(--neon2));box-shadow:0 0 8px rgba(0,255,231,0.3);transform:scaleX(0);transform-origin:left;transition:transform 1.3s cubic-bezier(0.16,1,0.3,1);}
.chips{display:flex;flex-wrap:wrap;gap:0.4rem;margin-top:0.8rem;}
.chip{font-size:0.68rem;color:var(--muted);border:1px solid rgba(255,255,255,0.08);padding:0.22rem 0.55rem;border-radius:5px;transition:color 0.2s,border-color 0.2s;}
.chip:hover,.chip:active{color:var(--neon);border-color:rgba(0,255,231,0.3);}

/* PROJECTS */
#projects{background:var(--bg);}
.pgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.2rem;}
.pglass{background:var(--glass);border:1px solid rgba(255,255,255,0.06);border-radius:18px;padding:1.6rem;display:flex;flex-direction:column;gap:0.85rem;transition:border-color 0.3s,transform 0.3s,box-shadow 0.3s;position:relative;overflow:hidden;}
.pglass::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(0,255,231,0.07),transparent 55%);opacity:0;transition:opacity 0.3s;}
.pglass:hover{border-color:rgba(0,255,231,0.28);transform:translateY(-6px);box-shadow:0 24px 50px rgba(0,0,0,0.4),0 0 30px rgba(0,255,231,0.06);}
.pglass:hover::before{opacity:1;}
.pglass:active{transform:scale(0.98);}
.ptop{display:flex;justify-content:space-between;align-items:center;}
.pnum{font-family:'Orbitron',monospace;font-size:0.68rem;color:var(--neon);opacity:0.5;letter-spacing:0.1em;}
.pbadges{display:flex;gap:5px;}
.pb{font-size:0.62rem;font-weight:600;letter-spacing:0.05em;text-transform:uppercase;padding:0.18rem 0.55rem;border-radius:100px;}
.pb-an{background:rgba(0,255,231,0.1);color:var(--neon);border:1px solid rgba(0,255,231,0.2);}
.pb-py{background:rgba(123,92,250,0.1);color:#b39dfa;border:1px solid rgba(123,92,250,0.2);}
.pb-bi{background:rgba(255,200,80,0.1);color:#ffd060;border:1px solid rgba(255,200,80,0.2);}
.pb-au{background:rgba(255,45,120,0.1);color:#ff9a9a;border:1px solid rgba(255,45,120,0.2);}
.pn{font-size:0.97rem;font-weight:600;color:var(--white);line-height:1.3;}
.pd{font-size:0.8rem;color:var(--muted);line-height:1.65;font-weight:300;}
.ptools{display:flex;flex-wrap:wrap;gap:0.35rem;margin-top:auto;}
.ptool{font-size:0.65rem;color:var(--muted);border:1px solid rgba(255,255,255,0.07);padding:0.18rem 0.5rem;border-radius:4px;}
.plink{display:inline-flex;align-items:center;gap:5px;font-size:0.75rem;color:var(--neon);font-weight:500;opacity:0;transform:translateY(5px);transition:opacity 0.2s,transform 0.2s;text-decoration:none;}
.pglass:hover .plink{opacity:1;transform:translateY(0);}

/* CONTACT */
#contact{background:var(--bg2);}
.cgrid{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;}
.cpills{display:flex;flex-direction:column;gap:0.85rem;}
.cpill{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:0.85rem;text-decoration:none;border:1px solid rgba(255,255,255,0.07);border-radius:10px;padding:0.75rem 1rem;background:var(--glass);transition:border-color 0.2s,color 0.2s,transform 0.2s;position:relative;overflow:hidden;-webkit-tap-highlight-color:transparent;}
.cpill::before{content:'';position:absolute;left:-100%;top:0;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(0,255,231,0.05),transparent);transition:left 0.5s;}
.cpill:hover,.cpill:active{color:var(--neon);border-color:rgba(0,255,231,0.28);transform:translateX(5px);}
.cpill:hover::before{left:100%;}
.cpi{width:34px;height:34px;border-radius:7px;background:rgba(0,255,231,0.08);border:1px solid rgba(0,255,231,0.12);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background 0.2s;}
.cpill:hover .cpi,.cpill:active .cpi{background:rgba(0,255,231,0.18);}
.cform{display:flex;flex-direction:column;gap:0.9rem;}
.crow{display:grid;grid-template-columns:1fr 1fr;gap:0.9rem;}
.cg{display:flex;flex-direction:column;gap:0.35rem;}
.cg label{font-size:0.7rem;font-weight:500;color:var(--muted);letter-spacing:0.07em;text-transform:uppercase;}
.cg input,.cg textarea{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.08);border-radius:9px;padding:0.75rem 0.9rem;color:var(--white);font-family:'Space Grotesk',sans-serif;font-size:0.88rem;outline:none;transition:border-color 0.2s,box-shadow 0.2s;resize:none;-webkit-appearance:none;}
.cg input::placeholder,.cg textarea::placeholder{color:rgba(136,146,176,0.4);}
.cg input:focus,.cg textarea:focus{border-color:rgba(0,255,231,0.4);box-shadow:0 0 0 3px rgba(0,255,231,0.06);}
.cg textarea{min-height:110px;}
#cok{display:none;font-size:0.8rem;color:var(--neon);background:rgba(0,255,231,0.06);border:1px solid rgba(0,255,231,0.2);border-radius:7px;padding:0.7rem 0.9rem;}

footer{position:relative;z-index:1;padding:1.5rem 5vw;border-top:1px solid rgba(255,255,255,0.05);display:flex;justify-content:space-between;align-items:center;font-size:0.72rem;color:var(--muted);flex-wrap:wrap;gap:0.8rem;}
footer a{color:var(--muted);text-decoration:none;transition:color 0.2s;}
footer a:hover{color:var(--neon);}

/* ── SCROLL REVEAL ── */
.reveal{opacity:0;transition:opacity 0.8s cubic-bezier(0.16,1,0.3,1),transform 0.8s cubic-bezier(0.16,1,0.3,1);transform:translateY(40px);}
.reveal.left{transform:translateX(-40px);}
.reveal.right{transform:translateX(40px);}
.reveal.scale{transform:scale(0.9);}
.reveal.up{opacity:1;transform:none;}
.d1{transition-delay:0.07s;}.d2{transition-delay:0.14s;}.d3{transition-delay:0.21s;}.d4{transition-delay:0.28s;}

/* ═══════════════════════════════════════
   MOBILE RESPONSIVE BREAKPOINTS
═══════════════════════════════════════ */
@media(max-width:768px){
  /* HERO */
  #hero{padding-top:80px;padding-bottom:3rem;min-height:auto;}
  .hero-inner{grid-template-columns:1fr;gap:2.5rem;text-align:center;}
  .hero-left{order:2;}
  .hero-right{order:1;}
  .hgreet{justify-content:center;}
  .hdesc{margin:0 auto 1.8rem;}
  .hbtns{justify-content:center;}
  .hstats{justify-content:center;gap:1.5rem;}
  .photo-scene{width:220px;height:220px;}
  .fb1{left:-40px;font-size:0.65rem;padding:0.45rem 0.7rem;}
  .fb2{right:-35px;font-size:0.65rem;padding:0.45rem 0.7rem;}

  /* ABOUT */
  .about-grid{grid-template-columns:1fr;gap:2rem;}
  .iv{text-align:left;}

  /* EXPERIENCE */
  .ecard{margin-left:1.4rem;padding:1.2rem 1.2rem 1.2rem 1.5rem;}
  .ecard::before{left:-2rem;top:1.5rem;}

  /* SKILLS */
  .sgrid{grid-template-columns:1fr;}

  /* PROJECTS */
  .pgrid{grid-template-columns:1fr;}
  .pglass:hover{transform:none;}
  .plink{opacity:1;transform:none;}

  /* CONTACT */
  .cgrid{grid-template-columns:1fr;gap:2rem;}
  .crow{grid-template-columns:1fr;}

  /* SECTIONS */
  section:not(#hero){padding:3.5rem 5vw;}
}

@media(max-width:400px){
  .photo-scene{width:190px;height:190px;}
  .fb1,.fb2{display:none;}
  .hstats{gap:1rem;}
  .snum{font-size:1.3rem;}
}

::-webkit-scrollbar{width:3px;}
::-webkit-scrollbar-track{background:var(--bg);}
::-webkit-scrollbar-thumb{background:rgba(0,255,231,0.2);border-radius:2px;}
