/* ================================================
   BASE — Reset, Variáveis, Tipografia, Keyframes
   ================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --ink:#0f0014;
  --ink2:#2a0040;
  --ink3:#4a1a60;
  --amethyst:#7c3aed;
  --amethyst2:#6d28d9;
  --amethyst3:#a78bfa;
  --champagne:#e8d5b7;
  --gold:#c9a84c;
  --gold2:#f0d060;
  --cream:#fdf8f0;
  --surface:#1a0028;
  --surface2:#240035;
  --surface3:#300048;
  --mist:rgba(255,255,255,0.06);
  --mistb:rgba(255,255,255,0.1);
  --border:rgba(200,160,255,0.12);
  --borderh:rgba(200,160,255,0.28);
  --text:#f0e8ff;
  --text2:#c8b0e0;
  --text3:#9070a8;
  --wpp:#25d366;
  --r:18px;
  --rs:10px;
}

html{
  scroll-behavior:smooth;
  scrollbar-width:thin;
  scrollbar-color:var(--amethyst) var(--ink);
}

::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--ink)}
::-webkit-scrollbar-thumb{background:var(--amethyst);border-radius:3px}

body{
  font-family:'Outfit',sans-serif;
  background:var(--ink);
  color:var(--text);
  overflow-x:hidden;
  cursor:none;
}

a{text-decoration:none;color:inherit}

/* ── CURSOR ── */
#cur{
  position:fixed;width:10px;height:10px;
  background:var(--amethyst3);border-radius:50%;
  pointer-events:none;z-index:99999;
  transform:translate(-50%,-50%);
  transition:width .2s,height .2s,background .2s;
  mix-blend-mode:difference;
}
#cur2{
  position:fixed;width:36px;height:36px;
  border:1px solid rgba(167,139,250,0.5);border-radius:50%;
  pointer-events:none;z-index:99998;
  transform:translate(-50%,-50%);
  transition:transform .08s linear,width .25s,height .25s,opacity .25s;
  opacity:0.5;
}
body:hover #cur,body:hover #cur2{opacity:1}

/* ── GRAIN OVERLAY ── */
body::before{
  content:'';position:fixed;inset:0;z-index:9998;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  opacity:0.028;
  animation:grain 0.8s steps(2) infinite;
}

/* ── KEYFRAMES ── */
@keyframes grain{
  0%,100%{transform:translate(0,0)}
  10%{transform:translate(-2%,-1%)}
  20%{transform:translate(2%,1%)}
  30%{transform:translate(-1%,2%)}
  40%{transform:translate(1%,-2%)}
  50%{transform:translate(-2%,2%)}
  60%{transform:translate(2%,-1%)}
  70%{transform:translate(-1%,1%)}
  80%{transform:translate(1%,2%)}
  90%{transform:translate(-2%,-2%)}
}

@keyframes twinkle{
  0%,100%{opacity:var(--op,.2)}
  50%{opacity:0.7}
}

@keyframes pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.4;transform:scale(.7)}
}

@keyframes blobFloat{
  0%,100%{transform:translate(-50%,-50%) scale(1)}
  33%{transform:translate(-52%,-48%) scale(1.04)}
  66%{transform:translate(-48%,-52%) scale(0.97)}
}

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

@keyframes scrollAnim{
  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}
}

@keyframes ticker{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

@keyframes ring{
  0%,100%{transform:scale(1);opacity:.5}
  50%{transform:scale(1.15);opacity:0}
}

@keyframes blink{
  0%,100%{opacity:1}
  50%{opacity:.3}
}
