/* ══════════════════════════════════════════════════
   RISHI PORTFOLIO  ·  Neon-Noir Cyberpunk OS Theme
   ══════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;600;700;900&family=Share+Tech+Mono&family=Exo+2:wght@300;400;500;600;700&display=swap');

/* ── Variables ─────────────────────────────────── */
:root{
  --bg:      #02040e;
  --bg2:     #050810;
  --panel:   #080d1c;
  --surf:    rgba(8,13,28,.94);
  --cyan:    #00e5ff;
  --cdim:    rgba(0,229,255,.13);
  --cglow:   0 0 8px rgba(0,229,255,.7),0 0 28px rgba(0,229,255,.22);
  --pink:    #ff2070;
  --pdim:    rgba(255,32,112,.13);
  --pglow:   0 0 8px rgba(255,32,112,.7),0 0 28px rgba(255,32,112,.22);
  --green:   #00ffaa;
  --gdim:    rgba(0,255,170,.13);
  --gglow:   0 0 8px rgba(0,255,170,.7),0 0 28px rgba(0,255,170,.22);
  --gold:    #ffd060;
  --red:     #ff3355;
  --tb:      #ddeeff;
  --tm:      #7a93b5;
  --td:      #2e4060;
  --bdr:     rgba(0,229,255,.13);
  --bdr2:    rgba(0,229,255,.26);
  --fhud:    'Orbitron',monospace;
  --fmono:   'Share Tech Mono',monospace;
  --fbody:   'Exo 2',sans-serif;
  --nav-h:   60px;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--tb);font-family:var(--fbody);overflow-x:hidden;cursor:none;min-height:100vh}
a{color:inherit;text-decoration:none;cursor:none}
button,input,textarea,select{font-family:inherit;cursor:none}
img{max-width:100%;display:block}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:var(--bdr2);border-radius:2px}
::selection{background:rgba(0,229,255,.25)}

/* ── Custom cursor ─────────────────────────────── */
#cur-dot{width:6px;height:6px;background:var(--cyan);border-radius:50%;position:fixed;z-index:99999;pointer-events:none;box-shadow:var(--cglow);transform:translate(-50%,-50%);transition:transform .05s}
#cur-ring{width:30px;height:30px;border:1.5px solid rgba(0,229,255,.5);border-radius:50%;position:fixed;z-index:99998;pointer-events:none;transform:translate(-50%,-50%);transition:width .2s,height .2s,border-color .2s}
#cur-ring.big{width:46px;height:46px;border-color:var(--cyan);box-shadow:var(--cglow)}

/* ── Background canvas ─────────────────────────── */
#bg-canvas{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.08}
.scanlines{position:fixed;inset:0;z-index:1;pointer-events:none;background:repeating-linear-gradient(to bottom,transparent 0,transparent 3px,rgba(0,0,0,.07) 3px,rgba(0,0,0,.07) 4px)}

/* ── Glass card ────────────────────────────────── */
.glass{background:var(--surf);border:1px solid var(--bdr);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px)}
.glass:hover{border-color:var(--bdr2)}
/* HUD corners */
.hc{position:absolute;width:11px;height:11px}
.hc.tl{top:0;left:0;border-top:2px solid var(--cyan);border-left:2px solid var(--cyan)}
.hc.tr{top:0;right:0;border-top:2px solid var(--cyan);border-right:2px solid var(--cyan)}
.hc.bl{bottom:0;left:0;border-bottom:2px solid var(--cyan);border-left:2px solid var(--cyan)}
.hc.br{bottom:0;right:0;border-bottom:2px solid var(--cyan);border-right:2px solid var(--cyan)}

/* ── Buttons ────────────────────────────────────── */
.btn{font-family:var(--fmono);font-size:.7rem;letter-spacing:2.5px;text-transform:uppercase;padding:12px 28px;border:1px solid;background:transparent;position:relative;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;transition:color .25s,box-shadow .25s,transform .15s;clip-path:polygon(9px 0,100% 0,100% calc(100% - 9px),calc(100% - 9px) 100%,0 100%,0 9px)}
.btn::before{content:'';position:absolute;inset:0;transform:translateX(-105%);transition:transform .28s ease;z-index:0}
.btn>span,.btn>svg{position:relative;z-index:1}
.btn:not(:disabled):hover::before{transform:translateX(0)}
.btn:not(:disabled):hover{transform:translateY(-2px)}
.btn:disabled{opacity:.45;pointer-events:none}
.btn-full{width:100%;clip-path:none;border-radius:2px}
.btn-cyan{color:var(--cyan);border-color:var(--cyan)}
.btn-cyan::before{background:var(--cyan)}
.btn-cyan:not(:disabled):hover{color:var(--bg);box-shadow:var(--cglow)}
.btn-pink{color:var(--pink);border-color:var(--pink)}
.btn-pink::before{background:var(--pink)}
.btn-pink:not(:disabled):hover{color:#fff;box-shadow:var(--pglow)}
.btn-green{color:var(--green);border-color:var(--green)}
.btn-green::before{background:var(--green)}
.btn-green:not(:disabled):hover{color:var(--bg);box-shadow:var(--gglow)}
.btn-ghost{color:var(--td);border-color:var(--bdr);clip-path:none;border-radius:2px}
.btn-ghost::before{background:var(--cdim)}
.btn-ghost:not(:disabled):hover{color:var(--cyan);border-color:var(--cyan)}
.btn-sm{padding:7px 16px;font-size:.6rem;letter-spacing:1.5px}
.bspin{width:11px;height:11px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .7s linear infinite;display:inline-block;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Form inputs ────────────────────────────────── */
.fg{display:flex;flex-direction:column;gap:5px}
.fl{font-family:var(--fmono);font-size:.58rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--td)}
.fi{background:rgba(0,229,255,.04);border:1px solid var(--bdr);color:var(--tb);padding:11px 14px;font-size:.92rem;outline:none;width:100%;transition:border-color .2s,box-shadow .2s,background .2s;border-radius:2px}
.fi:focus{border-color:var(--cyan);box-shadow:0 0 0 2px rgba(0,229,255,.1);background:rgba(0,229,255,.07)}
.fi::placeholder{color:var(--td)}
.fi-ta{min-height:106px;resize:vertical}

/* OTP grid */
.otp-row{display:flex;gap:9px;justify-content:center}
.otp-box{width:46px;height:54px;text-align:center;font-family:var(--fmono);font-size:1.45rem;font-weight:700;color:var(--cyan);background:rgba(0,229,255,.05);border:1px solid var(--bdr);outline:none;transition:border-color .2s,box-shadow .2s;border-radius:2px;caret-color:var(--cyan)}
.otp-box:focus{border-color:var(--cyan);box-shadow:var(--cglow)}
.otp-box.ok{border-color:rgba(0,229,255,.45);background:rgba(0,229,255,.07)}

/* Messages */
.msg{display:none;padding:9px 13px;font-family:var(--fmono);font-size:.66rem;letter-spacing:1px;border-left:2px solid;border-radius:0 2px 2px 0;margin-top:2px}
.msg-e{background:rgba(255,32,112,.08);border-color:var(--pink);color:var(--pink)}
.msg-s{background:rgba(0,255,170,.08);border-color:var(--green);color:var(--green)}
.msg-i{background:rgba(0,229,255,.08);border-color:var(--cyan);color:var(--cyan)}

/* Toast */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(80px);padding:10px 26px;font-family:var(--fmono);font-size:.66rem;letter-spacing:2px;text-transform:uppercase;z-index:99990;opacity:0;transition:all .35s cubic-bezier(.34,1.56,.64,1);white-space:nowrap;border-radius:2px;backdrop-filter:blur(14px);border:1px solid;pointer-events:none}
.toast.on{opacity:1;transform:translateX(-50%) translateY(0)}
.toast-ok{background:rgba(0,255,170,.1);border-color:var(--green);color:var(--green)}
.toast-err{background:rgba(255,32,112,.1);border-color:var(--pink);color:var(--pink)}
.toast-info{background:rgba(0,229,255,.1);border-color:var(--cyan);color:var(--cyan)}

/* Section headings */
.s-tag{font-family:var(--fmono);font-size:.64rem;letter-spacing:4px;text-transform:uppercase;color:var(--pink);margin-bottom:9px}
.s-title{font-family:var(--fhud);font-size:clamp(1.75rem,4.5vw,2.9rem);font-weight:700;letter-spacing:2px;background:linear-gradient(110deg,var(--cyan) 0%,var(--tb) 52%,var(--cyan) 100%);background-size:200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer 5s linear infinite}
@keyframes shimmer{to{background-position:200% center}}
.s-line{width:52px;height:2px;background:linear-gradient(90deg,var(--cyan),transparent);margin-top:13px;box-shadow:var(--cglow)}

/* Reveal animation */
.rv{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.rv.in{opacity:1;transform:translateY(0)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* ═══════════════════════════════════════
   NAVIGATION
═══════════════════════════════════════ */
#nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:400;padding:0 44px;display:flex;align-items:center;justify-content:space-between;background:rgba(2,4,14,.7);backdrop-filter:blur(24px);border-bottom:1px solid var(--bdr);transition:background .3s}
#nav.solid{background:rgba(2,4,14,.97)}
.nav-logo{font-family:var(--fhud);font-size:1.05rem;font-weight:700;color:var(--cyan);text-shadow:var(--cglow);letter-spacing:4px}
.nav-logo em{color:var(--pink);font-style:normal;text-shadow:var(--pglow)}
.nav-links{display:flex;gap:26px;list-style:none}
.nav-links a{font-family:var(--fmono);font-size:.6rem;letter-spacing:2px;text-transform:uppercase;color:var(--td);transition:color .2s;position:relative;padding-bottom:2px}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--cyan);transition:width .25s}
.nav-links a:hover{color:var(--cyan)}
.nav-links a:hover::after{width:100%}
.nav-r{display:flex;align-items:center;gap:11px}
.nav-pill{display:flex;align-items:center;gap:9px;padding:4px 13px 4px 5px;border:1px solid var(--bdr);border-radius:30px;transition:border-color .2s}
.nav-pill:hover{border-color:var(--bdr2)}
.av{width:27px;height:27px;border-radius:50%;border:1px solid var(--cyan);object-fit:cover;flex-shrink:0}
.av-pl{width:27px;height:27px;border-radius:50%;background:linear-gradient(135deg,var(--cyan),var(--pink));display:flex;align-items:center;justify-content:center;font-family:var(--fhud);font-size:.7rem;font-weight:700;color:var(--bg);flex-shrink:0}
.nav-em{font-family:var(--fmono);font-size:.58rem;color:var(--tm);letter-spacing:1px;max-width:148px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ham{display:none;flex-direction:column;gap:5px;padding:6px;background:none;border:none}
.ham span{display:block;width:21px;height:1.5px;background:var(--tm);transition:all .3s}
.mob-nav{display:none;position:fixed;top:var(--nav-h);left:0;right:0;z-index:399;background:rgba(2,4,14,.97);border-bottom:1px solid var(--bdr);backdrop-filter:blur(24px);flex-direction:column;padding:16px 22px;gap:13px}
.mob-nav.open{display:flex}
.mob-nav a{font-family:var(--fmono);font-size:.7rem;letter-spacing:2px;color:var(--tm);text-transform:uppercase;padding:8px 0;border-bottom:1px solid var(--bdr)}
.mob-nav a:hover{color:var(--cyan)}

/* ═══════════════════════════════════════
   HERO
═══════════════════════════════════════ */
#hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;position:relative;z-index:2;padding:calc(var(--nav-h)+40px) 24px 60px;overflow:hidden}
.orbit{position:absolute;border-radius:50%;border:1px solid;pointer-events:none;top:50%;left:50%}
.o1{width:560px;height:560px;border-color:rgba(0,229,255,.05);animation:ospin 44s linear infinite;transform:translate(-50%,-50%)}
.o2{width:400px;height:400px;border-color:rgba(255,32,112,.06);animation:ospin 28s linear infinite reverse;transform:translate(-50%,-50%)}
.o3{width:250px;height:250px;border-color:rgba(0,255,170,.08);animation:ospin 17s linear infinite;transform:translate(-50%,-50%)}
.odot{position:absolute;width:5px;height:5px;border-radius:50%;top:-2.5px;left:50%;transform:translateX(-50%)}
.o1 .odot{background:var(--cyan);box-shadow:var(--cglow)}
.o2 .odot{background:var(--pink);box-shadow:var(--pglow)}
.o3 .odot{background:var(--green);box-shadow:var(--gglow)}
@keyframes ospin{to{transform:translate(-50%,-50%) rotate(360deg)}}
.h-eyebrow{font-family:var(--fmono);font-size:.68rem;letter-spacing:5px;color:var(--green);text-transform:uppercase;opacity:0;animation:fu .8s ease .3s forwards}
.h-name{font-family:var(--fhud);font-size:clamp(72px,17vw,180px);font-weight:900;letter-spacing:16px;line-height:1;background:linear-gradient(140deg,var(--cyan) 0%,var(--pink) 48%,var(--green) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 55px rgba(0,229,255,.38));opacity:0;animation:fu .8s ease .55s forwards,glitch 10s ease-in-out 3s infinite}
@keyframes glitch{0%,86%,100%{transform:none;filter:drop-shadow(0 0 55px rgba(0,229,255,.38))}87%{transform:translate(-3px,1px) skewX(-2deg);filter:drop-shadow(-5px 0 var(--pink)) drop-shadow(3px 0 var(--cyan))}89%{transform:translate(3px,-1px) skewX(1deg);filter:drop-shadow(5px 0 var(--cyan)) drop-shadow(-3px 0 var(--pink))}91%{transform:none}93%{transform:translate(-1px,1px);filter:drop-shadow(2px 0 var(--green))}95%{transform:none;filter:drop-shadow(0 0 55px rgba(0,229,255,.38))}}
.h-sub{font-family:var(--fmono);font-size:clamp(.68rem,2.1vw,.95rem);letter-spacing:3px;color:var(--tm);margin:20px 0 38px;opacity:0;animation:fu .8s ease .8s forwards}
.h-sub .c1{color:var(--cyan)}.h-sub .c2{color:var(--pink)}.h-sub .c3{color:var(--green)}
.h-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;opacity:0;animation:fu .8s ease 1.05s forwards}
.scroll-cue{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:7px;font-family:var(--fmono);font-size:.55rem;letter-spacing:3px;color:var(--td);opacity:0;animation:fi 1s ease 1.7s forwards}
.scl{width:1px;height:44px;background:linear-gradient(to bottom,var(--cyan),transparent);animation:scrollpulse 2s ease-in-out infinite}
@keyframes fu{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fi{from{opacity:0}to{opacity:1}}
@keyframes scrollpulse{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ═══════════════════════════════════════
   SECTIONS
═══════════════════════════════════════ */
.section{position:relative;z-index:2;padding:96px 56px}
.section-alt{background:var(--panel)}
.section-hdr{margin-bottom:50px}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:68px;align-items:center}
.about-frame{max-width:360px;width:100%;aspect-ratio:1;position:relative}
.about-img-bg{width:100%;height:100%;background:linear-gradient(135deg,rgba(0,229,255,.07),rgba(255,32,112,.06));border:1px solid var(--bdr);display:flex;align-items:center;justify-content:center;font-size:6rem}
.about-chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:20px}
.chip{padding:6px 13px;border:1px solid var(--bdr);font-family:var(--fmono);font-size:.58rem;letter-spacing:2px;text-transform:uppercase;color:var(--td);transition:all .2s}
.chip:hover{border-color:var(--cyan);color:var(--cyan)}
.about-body h3{font-family:var(--fmono);font-size:.68rem;letter-spacing:4px;color:var(--cyan);text-transform:uppercase;margin-bottom:13px}
.about-body p{color:var(--tm);font-size:1rem;line-height:1.88;margin-bottom:13px}
.about-body strong{color:var(--tb)}

/* SKILLS */
.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(272px,1fr));gap:16px}
.skill-card{padding:20px 22px;position:relative;transition:transform .25s}
.skill-card:hover{transform:translateY(-3px)}
.sk-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:11px}
.sk-name{font-family:var(--fmono);font-size:.76rem;letter-spacing:2px;text-transform:uppercase;color:var(--tb)}
.sk-pct{font-family:var(--fmono);font-size:.72rem;font-weight:700}
.sk-track{height:3px;background:rgba(0,229,255,.07);border-radius:2px;overflow:hidden}
.sk-fill{height:100%;width:0;border-radius:2px;transition:width 1.3s cubic-bezier(.25,.46,.45,.94);position:relative}
.sk-fill::after{content:'';position:absolute;right:0;top:0;bottom:0;width:11px;background:rgba(255,255,255,.65);filter:blur(4px)}

/* PROJECTS */
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(305px,1fr));gap:22px}
.proj-card{position:relative;overflow:hidden;transition:transform .35s ease,box-shadow .35s ease;transform-style:preserve-3d}
.proj-card:hover{box-shadow:0 22px 64px rgba(0,0,0,.5),0 0 32px rgba(0,229,255,.07)}
.proj-thumb{width:100%;aspect-ratio:16/9;object-fit:cover;border-bottom:1px solid var(--bdr);filter:brightness(.82);transition:filter .3s}
.proj-card:hover .proj-thumb{filter:brightness(1) saturate(1.3)}
.proj-thumb-ph{width:100%;aspect-ratio:16/9;background:linear-gradient(135deg,rgba(0,229,255,.04),rgba(255,32,112,.04));border-bottom:1px solid var(--bdr);display:flex;align-items:center;justify-content:center;font-size:2.4rem;color:var(--td)}
.proj-body{padding:20px}
.proj-idx{font-family:var(--fmono);font-size:.56rem;letter-spacing:3px;color:var(--cyan);margin-bottom:5px}
.proj-title{font-family:var(--fhud);font-size:1rem;font-weight:600;color:var(--tb);letter-spacing:1px;margin-bottom:7px}
.proj-desc{font-size:.855rem;color:var(--tm);line-height:1.65;margin-bottom:14px}
.proj-link{font-family:var(--fmono);font-size:.62rem;letter-spacing:2px;color:var(--cyan);text-transform:uppercase;display:inline-flex;align-items:center;gap:5px;transition:text-shadow .2s}
.proj-link:hover{text-shadow:var(--cglow)}
.proj-tags{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:12px}
.proj-tag{font-family:var(--fmono);font-size:.54rem;letter-spacing:1.5px;padding:2px 7px;border:1px solid var(--bdr);color:var(--td);text-transform:uppercase}
.pl,.pe{grid-column:1/-1;text-align:center;padding:56px;font-family:var(--fmono);font-size:.76rem;letter-spacing:2px;color:var(--td)}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:68px;align-items:start}
.ci{display:flex;gap:13px;align-items:flex-start;margin-bottom:24px}
.ci-icon{width:37px;height:37px;border:1px solid var(--bdr);display:flex;align-items:center;justify-content:center;color:var(--cyan);font-size:.9rem;flex-shrink:0;background:var(--cdim);transition:box-shadow .2s}
.ci:hover .ci-icon{box-shadow:var(--cglow)}
.ci-lbl{font-family:var(--fmono);font-size:.56rem;letter-spacing:2px;color:var(--td);text-transform:uppercase;margin-bottom:3px}
.ci-val{font-size:.9rem;color:var(--tm)}
.social-row{display:flex;gap:8px;margin-top:26px}
.soc{width:37px;height:37px;border:1px solid var(--bdr);display:flex;align-items:center;justify-content:center;font-family:var(--fmono);font-size:.6rem;color:var(--td);transition:all .2s;text-transform:uppercase}
.soc:hover{border-color:var(--cyan);color:var(--cyan);box-shadow:var(--cglow)}
.cf-card{padding:28px;position:relative}
.cf{display:flex;flex-direction:column;gap:13px}

/* FOOTER */
footer{position:relative;z-index:2;border-top:1px solid var(--bdr);padding:28px 56px;display:flex;align-items:center;justify-content:space-between;background:var(--bg)}
.ft-logo{font-family:var(--fhud);font-size:.95rem;letter-spacing:4px;color:var(--td)}
.ft-copy{font-family:var(--fmono);font-size:.56rem;letter-spacing:2px;color:var(--td)}
.ft-links{display:flex;gap:16px}
.ft-links a{font-family:var(--fmono);font-size:.56rem;letter-spacing:2px;color:var(--td);text-transform:uppercase;transition:color .2s}
.ft-links a:hover{color:var(--cyan)}

/* ═══════════════════════════════════════
   LOGIN PAGE
═══════════════════════════════════════ */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative;z-index:2}
.login-card{width:100%;max-width:420px;padding:40px 34px;position:relative;animation:cardIn .65s cubic-bezier(.34,1.56,.64,1) forwards}
@keyframes cardIn{from{opacity:0;transform:scale(.93) translateY(14px)}to{opacity:1;transform:scale(1) translateY(0)}}
.login-logo{font-family:var(--fhud);font-size:2.3rem;font-weight:900;letter-spacing:8px;background:linear-gradient(135deg,var(--cyan),var(--pink));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 22px rgba(0,229,255,.35));margin-bottom:5px}
.login-sub{font-family:var(--fmono);font-size:.58rem;letter-spacing:3px;color:var(--td);text-transform:uppercase;margin-bottom:32px}
.auth-lbl{font-family:var(--fmono);font-size:.6rem;letter-spacing:3px;color:var(--cyan);text-transform:uppercase;margin-bottom:12px}
.divider{display:flex;align-items:center;gap:12px;margin:20px 0}
.div-l{flex:1;height:1px;background:var(--bdr)}
.div-t{font-family:var(--fmono);font-size:.56rem;letter-spacing:2px;color:var(--td);white-space:nowrap}
#otp-sect{display:none}
.otp-hint{font-family:var(--fmono);font-size:.62rem;letter-spacing:1px;color:var(--td);margin-bottom:14px}
.otp-hint strong{color:var(--tm)}
.resend-row{display:flex;align-items:center;justify-content:space-between;margin-top:9px}
.resend{font-family:var(--fmono);font-size:.58rem;letter-spacing:2px;color:var(--cyan);background:none;border:none;text-transform:uppercase;transition:text-shadow .2s;padding:0}
.resend:not(:disabled):hover{text-shadow:var(--cglow)}
.resend:disabled{color:var(--td)}
.resend-cd{font-family:var(--fmono);font-size:.58rem;color:var(--td);letter-spacing:1px}

/* ═══════════════════════════════════════
   DASHBOARD
═══════════════════════════════════════ */
.dash-page{min-height:100vh;padding:calc(var(--nav-h)+38px) 56px 56px;position:relative;z-index:2;max-width:940px;margin:0 auto}
.profile-card{padding:32px;position:relative;margin-bottom:22px}
.profile-hdr{display:flex;align-items:center;gap:18px;margin-bottom:26px;padding-bottom:20px;border-bottom:1px solid var(--bdr)}
.p-av-lg{width:76px;height:76px;border-radius:50%;border:2px solid var(--cyan);object-fit:cover;box-shadow:var(--cglow);flex-shrink:0}
.p-av-pl{width:76px;height:76px;border-radius:50%;background:linear-gradient(135deg,var(--cyan),var(--pink));display:flex;align-items:center;justify-content:center;font-family:var(--fhud);font-size:1.9rem;font-weight:700;color:var(--bg);flex-shrink:0;box-shadow:var(--cglow)}
.p-name{font-family:var(--fhud);font-size:1.35rem;font-weight:700;color:var(--tb);letter-spacing:2px;margin-bottom:3px}
.p-email{font-family:var(--fmono);font-size:.68rem;color:var(--tm);letter-spacing:1px;margin-bottom:7px}
.pbadge{font-family:var(--fmono);font-size:.54rem;letter-spacing:2px;padding:3px 9px;border:1px solid;text-transform:uppercase;display:inline-block}
.pb-admin{border-color:var(--pink);color:var(--pink);background:var(--pdim)}
.pb-user{border-color:var(--green);color:var(--green);background:var(--gdim)}
.p-fields{display:grid;grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:11px}
.pf{padding:12px 14px;background:rgba(0,229,255,.03);border:1px solid var(--bdr)}
.pf-l{font-family:var(--fmono);font-size:.54rem;letter-spacing:2px;color:var(--td);text-transform:uppercase;margin-bottom:5px}
.pf-v{font-size:.85rem;color:var(--tb);word-break:break-all}

/* ═══════════════════════════════════════
   ADMIN LAYOUT
═══════════════════════════════════════ */
.adm-layout{display:flex;min-height:100vh;padding-top:var(--nav-h)}
.adm-sidebar{width:230px;flex-shrink:0;background:rgba(5,8,16,.98);border-right:1px solid var(--bdr);display:flex;flex-direction:column;position:sticky;top:var(--nav-h);height:calc(100vh - var(--nav-h));overflow-y:auto}
.sb-hdr{padding:20px 18px;border-bottom:1px solid var(--bdr)}
.sb-name{font-family:var(--fhud);font-size:.82rem;color:var(--cyan);letter-spacing:2px;margin-bottom:3px}
.sb-role{font-family:var(--fmono);font-size:.54rem;color:var(--pink);letter-spacing:2px;text-transform:uppercase}
.sb-nav{flex:1;padding:10px 0}
.sb-item{display:flex;align-items:center;gap:10px;padding:11px 18px;font-family:var(--fmono);font-size:.6rem;letter-spacing:2px;text-transform:uppercase;color:var(--td);border-left:2px solid transparent;transition:all .2s;cursor:none}
.sb-item:hover{color:var(--tm);background:rgba(0,229,255,.03)}
.sb-item.on{color:var(--cyan);border-left-color:var(--cyan);background:rgba(0,229,255,.06)}
.sb-icon{font-size:.9rem;width:17px;flex-shrink:0}
.sb-foot{padding:14px 18px;border-top:1px solid var(--bdr);display:flex;flex-direction:column;gap:8px}
.sb-link{font-family:var(--fmono);font-size:.56rem;letter-spacing:2px;color:var(--td);text-transform:uppercase;transition:color .2s;display:block}
.sb-link:hover{color:var(--cyan)}
.adm-main{flex:1;padding:32px 36px;overflow-y:auto}
.adm-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}
.adm-title{font-family:var(--fhud);font-size:1.4rem;font-weight:700;color:var(--tb);letter-spacing:2px}
.adm-sec{display:none}
.adm-sec.on{display:block}
.stats-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(145px,1fr));gap:12px;margin-bottom:28px}
.stat-card{padding:19px;text-align:center;position:relative;transition:transform .2s}
.stat-card:hover{transform:translateY(-2px)}
.stat-num{font-family:var(--fhud);font-size:2.1rem;font-weight:700;line-height:1;margin-bottom:6px}
.stat-lbl{font-family:var(--fmono);font-size:.56rem;letter-spacing:2px;text-transform:uppercase;color:var(--td)}
/* Table */
.tbl-wrap{overflow-x:auto;border-radius:2px}
table{width:100%;border-collapse:collapse}
thead th{font-family:var(--fmono);font-size:.56rem;letter-spacing:2px;text-transform:uppercase;color:var(--td);padding:10px 12px;text-align:left;border-bottom:1px solid var(--bdr);white-space:nowrap}
tbody td{padding:12px 12px;font-size:.855rem;color:var(--tm);border-bottom:1px solid rgba(0,229,255,.05);vertical-align:middle}
tbody tr:hover td{background:rgba(0,229,255,.025)}
.ti{width:52px;height:34px;object-fit:cover;border:1px solid var(--bdr)}
.ti-ph{width:52px;height:34px;background:var(--cdim);border:1px solid var(--bdr);display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.ub{font-family:var(--fmono);font-size:.5rem;letter-spacing:1.5px;padding:3px 7px;border:1px solid;text-transform:uppercase;white-space:nowrap}
.ub-g{border-color:rgba(66,133,244,.5);color:#4285f4}
.ub-e{border-color:rgba(0,229,255,.4);color:var(--cyan)}
.act{display:flex;gap:5px}
.ab{font-family:var(--fmono);font-size:.56rem;letter-spacing:1.5px;text-transform:uppercase;padding:5px 11px;border:1px solid;background:none;transition:all .2s;white-space:nowrap}
.ab-c{color:var(--cyan);border-color:var(--cyan)}.ab-c:hover{background:var(--cdim)}
.ab-r{color:var(--red);border-color:var(--red)}.ab-r:hover{background:rgba(255,51,85,.1)}
.ab-g{color:var(--green);border-color:var(--green)}.ab-g:hover{background:var(--gdim)}
/* Modal */
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,.8);backdrop-filter:blur(10px);z-index:3000;display:none;align-items:center;justify-content:center;padding:24px}
.modal-ov.open{display:flex}
.modal-box{width:100%;max-width:500px;background:var(--panel);border:1px solid var(--bdr);padding:32px;position:relative;animation:slideUp .3s ease}
@keyframes slideUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.modal-title{font-family:var(--fhud);font-size:1.08rem;color:var(--cyan);letter-spacing:3px;margin-bottom:22px}
.modal-close{position:absolute;top:14px;right:14px;background:none;border:none;color:var(--td);font-size:1.05rem;transition:color .2s;padding:4px}
.modal-close:hover{color:var(--pink)}
.modal-form{display:flex;flex-direction:column;gap:12px}
.upload-zone{border:1px dashed var(--bdr2);padding:20px;text-align:center;transition:border-color .2s,background .2s;position:relative}
.upload-zone:hover{border-color:var(--cyan);background:var(--cdim)}
.upload-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:none}
.upload-lbl{font-family:var(--fmono);font-size:.62rem;letter-spacing:2px;color:var(--td);text-transform:uppercase;pointer-events:none}
.img-prev{max-width:100%;max-height:130px;object-fit:cover;margin-top:9px;border:1px solid var(--bdr);display:none}

/* ═══════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════ */
@media(max-width:900px){
  #nav{padding:0 18px}
  .nav-links,.nav-r .nav-pill,.nav-r .btn-sm{display:none}
  .ham{display:flex}
  .section{padding:76px 20px}
  .about-grid,.contact-grid{grid-template-columns:1fr}
  footer{padding:20px;flex-direction:column;gap:12px;text-align:center}
  .adm-sidebar{width:195px}
  .adm-main{padding:20px 16px}
  .dash-page{padding:calc(var(--nav-h)+22px) 18px 38px}
  .o1{width:280px;height:280px}.o2{width:200px;height:200px}.o3{width:130px;height:130px}
}
@media(max-width:620px){
  .login-card{padding:26px 18px}
  .otp-row{gap:7px}
  .otp-box{width:40px;height:48px;font-size:1.25rem}
  .proj-grid,.skills-grid{grid-template-columns:1fr}
  .p-fields{grid-template-columns:1fr}
  .adm-layout{flex-direction:column}
  .adm-sidebar{width:100%;height:auto;position:static;border-right:none;border-bottom:1px solid var(--bdr)}
  .sb-nav{display:flex;overflow-x:auto;padding:0}
  .sb-item{flex-direction:column;gap:3px;padding:10px 12px;font-size:.48rem;border-left:none;border-bottom:2px solid transparent;flex-shrink:0}
  .sb-item.on{border-bottom-color:var(--cyan);border-left-color:transparent}
  .sb-foot{display:none}
  .stats-row{grid-template-columns:1fr 1fr}
}
