/* ===== CURSOR ===== */
*{cursor:none!important}
.cursor-dot{width:5px;height:5px;background:#fff;border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:100000;transform:translate(-50%,-50%);transition:width .2s,height .2s}
.cursor-ring{width:34px;height:34px;border:1px solid rgba(255,255,255,.35);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:99999;transform:translate(-50%,-50%);transition:width .3s,height .3s,border-color .3s}
.cursor-dot.hov{width:8px;height:8px}
.cursor-ring.hov{width:58px;height:58px;border-color:rgba(255,255,255,.12)}

/* ===== SCROLL PROGRESS ===== */
.scroll-bar{position:fixed;top:0;left:0;height:1px;background:rgba(255,255,255,.5);z-index:99998;width:0%;pointer-events:none}

/* ===== LOADER ===== */
.page-loader{position:fixed;inset:0;background:#000;z-index:999999;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .9s ease,visibility .9s ease}
.page-loader.out{opacity:0;visibility:hidden;pointer-events:none}
.loader-word{display:flex;gap:.4rem;font-family:'Inter',sans-serif;font-size:clamp(1.2rem,4vw,2.2rem);letter-spacing:10px;font-weight:300;color:#fff;text-transform:uppercase}
.loader-word span{display:inline-block;opacity:0;transform:translateY(20px);animation:ltr .7s cubic-bezier(.16,1,.3,1) forwards}
@keyframes ltr{to{opacity:1;transform:translateY(0)}}
.loader-bar-wrap{width:200px;height:1px;background:#111;margin-top:2rem;overflow:hidden}
.loader-bar{height:1px;background:rgba(255,255,255,.4);width:0%;animation:lbar 1.6s ease forwards}
@keyframes lbar{to{width:100%}}

/* ===== PAGE TRANSITION ===== */
.page-curtain{position:fixed;inset:0;background:#000;z-index:99997;transform:translateY(100%);transition:transform .55s cubic-bezier(.76,0,.24,1);pointer-events:none}
.page-curtain.in{transform:translateY(0);pointer-events:all}
.page-curtain.out{transform:translateY(-100%)}

/* ===== HAMBURGER ===== */
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:4px}
.hamburger span{display:block;width:22px;height:1px;background:#fff;transition:transform .3s,opacity .3s}
.hamburger.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* ===== MOBILE MENU ===== */
.mob-menu{display:none;position:fixed;inset:0;background:#000;z-index:9998;flex-direction:column;justify-content:center;padding:2rem 2.5rem;transform:translateX(-100%);transition:transform .6s cubic-bezier(.76,0,.24,1)}
.mob-menu.open{transform:translateX(0)}
.mob-menu a{font-size:clamp(1.8rem,7vw,3.5rem);font-weight:300;letter-spacing:-1px;color:#fff;text-decoration:none;border-bottom:1px solid #111;padding:1.2rem 0;display:block;opacity:0;transform:translateX(-15px);transition:opacity .4s,transform .4s,color .3s}
.mob-menu.open a{opacity:1;transform:translateX(0)}
.mob-menu.open a:nth-child(1){transition-delay:.08s}
.mob-menu.open a:nth-child(2){transition-delay:.13s}
.mob-menu.open a:nth-child(3){transition-delay:.18s}
.mob-menu.open a:nth-child(4){transition-delay:.23s}
.mob-menu.open a:nth-child(5){transition-delay:.28s}
.mob-menu.open a:nth-child(6){transition-delay:.33s}
.mob-menu.open a:nth-child(7){transition-delay:.38s}
.mob-menu.open a:nth-child(8){transition-delay:.43s}
.mob-menu.open a:nth-child(9){transition-delay:.48s}
.mob-menu a:hover{color:rgba(255,255,255,.35)}

@media(max-width:768px){
  .hamburger{display:flex}
  .mob-menu{display:flex}
  .nav-desktop{display:none!important}
}
