*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html,body{width:100%;height:100%;overflow:hidden;background:#050816;font-family:'Sora',sans-serif;-webkit-font-smoothing:antialiased}
::selection{background:rgba(100,140,220,0.3);color:#fff}
canvas#bg{position:fixed;inset:0;z-index:0}

/* ── Panels ── */

.panel{
  position:fixed;z-index:50;
  background:rgba(8,12,30,0.92);backdrop-filter:blur(40px) saturate(1.3);
  border:1px solid rgba(80,130,220,0.07);border-radius:20px;
  opacity:0;pointer-events:none;
  transform:translate(-50%,-50%) scale(0.2);
  transition:opacity .65s cubic-bezier(.16,1,.3,1),transform .65s cubic-bezier(.16,1,.3,1);
  overflow:hidden;
  width:min(540px,90vw);max-height:82vh;
  top:50%;left:50%;
}
.panel.open{opacity:1;pointer-events:auto;transform:translate(-50%,-50%) scale(1)}

/* Scrollable variant — fixed viewport height, internal scroll */
.panel--scroll{display:flex;flex-direction:column;height:72vh;max-height:72vh}
.panel--scroll .ph{flex-shrink:0;padding:40px 40px 0;position:relative;z-index:2}
.panel--scroll .pi{flex:1;overflow-y:auto;padding:12px 40px 40px;scrollbar-width:thin;scrollbar-color:rgba(100,140,220,0.15) transparent}
.panel--scroll .pi::-webkit-scrollbar{width:3px}
.panel--scroll .pi::-webkit-scrollbar-thumb{background:rgba(100,140,220,0.15);border-radius:2px}
.panel--scroll .pf{position:absolute;bottom:0;left:0;right:0;height:48px;background:linear-gradient(to top,rgba(8,12,30,0.92),transparent);pointer-events:none;z-index:3;border-radius:0 0 20px 20px}

/* Staggered children reveal */
.panel .pi>*,.panel .ph>*{
  opacity:0;transform:translateY(12px);
  transition:opacity .45s ease,transform .45s ease;
}
.panel.open .pi>*,.panel.open .ph>*{opacity:1;transform:translateY(0)}

.pcl{position:absolute;top:18px;right:18px;width:30px;height:30px;border-radius:50%;border:1px solid rgba(255,255,255,0.06);background:transparent;color:rgba(255,255,255,0.35);font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;z-index:10}
.pcl:hover{border-color:rgba(100,140,220,0.3);color:#fff}
.pi{padding:40px;height:100%;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(100,140,220,0.15) transparent}
.pi::-webkit-scrollbar{width:3px}
.pi::-webkit-scrollbar-thumb{background:rgba(100,140,220,0.15);border-radius:2px}
.pl{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:rgba(100,140,220,0.45);margin-bottom:20px;font-weight:500}
.pt{font-family:'Cormorant Garamond',serif;font-size:30px;color:rgba(255,255,255,0.9);margin-bottom:28px;line-height:1.15;font-weight:300;letter-spacing:-0.3px}

/* ── Experience ── */

.ei{padding:22px 0;border-bottom:1px solid rgba(255,255,255,0.03)}
.ei:last-child{border:none}
.et{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:5px;flex-wrap:wrap;gap:8px}
.ec{font-size:15px;font-weight:500;color:rgba(230,235,245,0.9);letter-spacing:-0.2px}
.ed{font-size:10px;font-family:'JetBrains Mono',monospace;color:rgba(100,140,220,0.35);font-weight:300}
.er{font-size:12px;color:rgba(255,255,255,0.3);margin-bottom:12px;font-weight:300}
.eb{list-style:none;display:flex;flex-direction:column;gap:7px}
.eb li{font-size:12px;color:rgba(255,255,255,0.45);line-height:1.6;padding-left:12px;position:relative;font-weight:300}
.eb li::before{content:'';position:absolute;left:0;top:8px;width:3px;height:3px;border-radius:50%;background:rgba(100,140,220,0.3)}
.etg{display:flex;flex-wrap:wrap;gap:5px;margin-top:12px}
.etg span{font-size:9px;font-family:'JetBrains Mono',monospace;padding:3px 9px;border-radius:8px;background:rgba(100,140,220,0.05);color:rgba(100,140,220,0.45);border:1px solid rgba(100,140,220,0.06);font-weight:300}

/* ── Projects ── */

.pc{padding:20px;border-radius:14px;background:rgba(255,255,255,0.015);border:1px solid rgba(255,255,255,0.03);margin-bottom:14px;transition:all .35s}
.pc:hover{border-color:rgba(100,140,220,0.08);background:rgba(100,140,220,0.02)}
.pn{font-size:16px;font-weight:500;color:rgba(230,235,245,0.85);margin-bottom:3px;letter-spacing:-0.2px}
.ps{font-size:9px;font-family:'JetBrains Mono',monospace;color:rgba(100,140,220,0.3);margin-bottom:12px;font-weight:300}
.pd{list-style:none}
.pd li{font-size:11.5px;color:rgba(255,255,255,0.4);line-height:1.6;padding-left:11px;position:relative;margin-bottom:5px;font-weight:300}
.pd li::before{content:'›';position:absolute;left:0;color:rgba(100,140,220,0.3);font-size:11px}
.pm{display:inline-block;margin-top:12px;font-size:10px;font-family:'JetBrains Mono',monospace;padding:4px 12px;border-radius:10px;background:rgba(100,220,180,0.06);color:rgba(100,220,180,0.5);border:1px solid rgba(100,220,180,0.06);font-weight:300}

/* ── Skills ── */

.ss{margin-bottom:28px}.ss:last-child{margin:0}
.sc{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:rgba(120,150,220,0.35);margin-bottom:14px;font-weight:500;padding-bottom:8px;border-bottom:1px solid rgba(100,140,220,0.05)}
.sg{display:flex;flex-wrap:wrap;gap:8px}
.sp{display:inline-flex;align-items:center;gap:8px;font-size:12px;padding:8px 16px;border-radius:10px;background:rgba(255,255,255,0.018);border:1px solid rgba(255,255,255,0.04);color:rgba(255,255,255,0.4);transition:all .35s;cursor:default;font-weight:300}
.sp i{font-size:15px;color:rgba(140,175,240,0.45);transition:color .35s}
.sp:hover{border-color:rgba(100,140,220,0.18);color:rgba(180,200,245,0.75);background:rgba(100,140,220,0.04)}
.sp:hover i{color:rgba(160,190,255,0.8)}

/* ── About ── */

.at{font-size:13.5px;color:rgba(255,255,255,0.4);line-height:1.8;margin-bottom:22px;font-weight:300}
.as{display:flex;gap:16px;flex-wrap:wrap}
.st{text-align:center;flex:1;min-width:80px;padding:18px 10px;border-radius:14px;background:rgba(100,140,220,0.03);border:1px solid rgba(100,140,220,0.04)}
.sv{font-size:20px;font-weight:400;color:rgba(140,175,240,0.65);font-family:'JetBrains Mono',monospace}
.sl{font-size:9px;color:rgba(255,255,255,0.2);margin-top:6px;text-transform:uppercase;letter-spacing:1.5px;font-weight:400}

/* ── Contact ── */

.cl{display:flex;align-items:center;gap:14px;padding:16px;border-radius:14px;border:1px solid rgba(255,255,255,0.03);background:rgba(255,255,255,0.015);margin-bottom:8px;text-decoration:none;color:rgba(255,255,255,0.5);transition:all .35s}
.cl:hover{border-color:rgba(100,140,220,0.1);background:rgba(100,140,220,0.03);color:rgba(255,255,255,0.8);transform:translateX(3px)}
.ci{width:36px;height:36px;border-radius:10px;background:rgba(100,140,220,0.06);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ci svg{width:15px;height:15px;stroke:rgba(100,140,220,0.45);fill:none;stroke-width:1.5}
.cn{font-size:13px;font-weight:400}
.cv{font-size:10px;color:rgba(255,255,255,0.2);font-family:'JetBrains Mono',monospace;font-weight:300}

/* ── Hint tooltip ── */

.nh{position:fixed;z-index:40;background:rgba(8,12,30,0.85);backdrop-filter:blur(20px);border:1px solid rgba(80,130,220,0.08);border-radius:12px;padding:12px 18px;pointer-events:none;opacity:0;transition:opacity .3s;white-space:nowrap}
.nhn{font-size:12px;font-weight:400;color:rgba(230,235,245,0.8);letter-spacing:-0.2px}
.nhs{font-size:9.5px;color:rgba(100,140,220,0.4);margin-top:3px;font-weight:300}

/* ── Identity block ── */

#identity{position:fixed;z-index:10;pointer-events:none;text-align:center;transition:opacity .6s}
#id-ey{font-size:9px;letter-spacing:4px;text-transform:uppercase;color:rgba(120,160,240,0.5);margin-bottom:12px;font-weight:400}
#id-nm{font-family:'Cormorant Garamond',serif;font-size:clamp(40px,5.5vw,64px);color:rgba(170,155,240,0.92);letter-spacing:-1px;line-height:0.92;margin-bottom:12px;font-weight:300}
#id-nm em{font-style:italic;color:rgba(170,155,240,0.92)}
#id-su{font-size:12px;color:rgba(255,255,255,0.38);font-weight:300;max-width:340px;margin:0 auto;line-height:1.6;letter-spacing:0.2px}

/* ── Chrome ── */



#rs{position:fixed;top:24px;right:28px;z-index:60;font-family:'Cormorant Garamond',serif;font-size:20px;color:rgba(255,255,255,0.5);letter-spacing:-0.5px;font-weight:300;text-decoration:none;transition:color .3s}
#rs span{color:rgba(160,140,230,0.5);font-style:italic;transition:color .3s}
#rs:hover{color:rgba(255,255,255,0.8)}
#rs:hover span{color:rgba(160,140,230,0.8)}

#ins{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:60;font-size:10px;color:rgba(255,255,255,0.12);letter-spacing:1px;transition:opacity .6s;font-weight:300}

/* ── Reduced-motion fallback ── */

@media(prefers-reduced-motion:reduce){
  .panel{transition-duration:.25s}
  .panel .pi>*{transition-duration:.2s}
}
