@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;600;700;800&display=swap');

/* ===========================
   THEME — NEON LIMACITY 2.0
   =========================== */
:root{
  --bg:#050712;
  --bg-soft:#090b1c;
  --card:#0d1023;
  --muted:#9eb2e8;
  --text:#f4f6ff;
  --pill:#10152e;
  --border:#262f55;
  --primary:#ff4fb5;
  --primary-2:#38e1ff;
  --primary-alt:#8fff5c;
  --glow:0 18px 40px rgba(56,225,255,.24);
}

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

html,body{
  min-height:100%;
  background:
    radial-gradient(1100px 700px at 0% 0%, #1b1540 0%, transparent 60%),
    radial-gradient(900px 650px at 100% 0%, #281135 0%, transparent 60%),
    radial-gradient(1200px 800px at 50% 120%, #051018 0%, #050712 60%),
    linear-gradient(160deg,#050712 0%,#050712 100%);
  color:var(--text);
  font-family:Poppins,system-ui,Segoe UI,Roboto,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;
}

a{
  color:#c7d4ff;
  text-decoration:none;
  transition:opacity .18s ease, color .18s ease;
}
a:hover{opacity:.9;color:#ffffff}

/* ===========================
   LAYOUT
   =========================== */
.container{
  max-width:1180px;
  margin:0 auto;
  padding:18px 16px 36px;
}

/* ===========================
   HEADER + NAV
   =========================== */
header.sticky{
  position:sticky;
  top:0;
  z-index:50;
  background:
    linear-gradient(180deg,rgba(5,7,18,.94),rgba(5,7,18,.86));
  backdrop-filter:blur(14px) saturate(130%);
  border-bottom:1px solid rgba(255,255,255,.09);
  box-shadow:0 10px 35px rgba(0,0,0,.7);
}

.nav{
  display:flex;
  align-items:center;
  gap:16px;
  justify-content:space-between;
  min-height:62px;
}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
}
.brand img{
  width:42px;
  height:42px;
  object-fit:contain;
  filter:drop-shadow(0 0 14px rgba(56,225,255,.9));
}
.brand .text{
  font-weight:800;
  letter-spacing:.6px;
  font-size:1.05rem;
  text-transform:uppercase;
}
.brand .text span{
  background:linear-gradient(120deg,var(--primary-2),var(--primary));
  -webkit-background-clip:text;
  color:transparent;
}

/* nav pills */
.menu{
  display:flex;
  gap:8px;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
}

.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:9px 16px;
  border-radius:999px;
  background:radial-gradient(circle at 0 0,#1a2142 0, #0b0f23 55%);
  border:1px solid rgba(118,138,220,.65);
  color:var(--text);
  font-size:.9rem;
  box-shadow:0 0 0 1px rgba(0,0,0,.5), var(--glow);
  position:relative;
  overflow:hidden;
  cursor:pointer;
  transition:
    background .18s ease,
    transform .18s ease,
    box-shadow .18s ease,
    border-color .18s ease,
    color .18s ease;
}
.pill::before{
  content:"";
  position:absolute;
  inset:-40%;
  background:radial-gradient(circle at 0 0,rgba(255,255,255,.18),transparent 55%);
  opacity:0;
  transform:translateX(-40%);
  transition:opacity .25s ease, transform .25s ease;
}
.pill:hover{
  transform:translateY(-1px);
  box-shadow:0 18px 40px rgba(0,0,0,.6),0 0 30px rgba(56,225,255,.4);
  border-color:var(--primary-2);
}
.pill:hover::before{
  opacity:1;
  transform:translateX(0);
}

.pill.primary{
  background:linear-gradient(130deg,var(--primary-2),var(--primary));
  border:none;
  color:#05050c;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.05em;
  box-shadow:0 0 22px rgba(56,225,255,.7),0 0 22px rgba(255,79,181,.8);
}
.pill.primary:hover{
  transform:translateY(-2px) scale(1.02);
}

.pill.ghost{
  background:transparent;
  border:1px solid rgba(136,152,219,.55);
  box-shadow:none;
}
.pill.small{padding:6px 12px;font-size:.8rem}

/* Slot auth */
.menu { display:flex; align-items:center; gap:12px; }
#authSlot { margin-left:auto; display:flex; align-items:center; gap:12px; }

/* ===========================
   HERO
   =========================== */
.hero{
  border-radius:26px;
  overflow:hidden;
  margin-top:18px;
  position:relative;
  background:
    radial-gradient(circle at 0 0,rgba(56,225,255,.18),transparent 55%),
    radial-gradient(circle at 100% 0,rgba(255,79,181,.18),transparent 55%),
    linear-gradient(160deg,#060817 0%,#070a1b 50%,#050712 100%),
    url('/assets/img/hero.jpg') center/cover no-repeat;
  min-height:420px;
  display:flex;
  align-items:center;
  box-shadow:0 30px 80px rgba(0,0,0,.9);
  border:1px solid rgba(255,255,255,.06);
}
.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 30% 0,rgba(255,255,255,.22),transparent 60%);
  mix-blend-mode:soft-light;
  opacity:.8;
}
.hero-inner{
  padding:44px 46px;
  position:relative;
  z-index:1;
  max-width:640px;
}

.badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 11px;
  border-radius:999px;
  background:rgba(8,12,30,.9);
  border:1px solid rgba(255,255,255,.22);
  font-size:11px;
  color:#e1ebff;
  text-transform:uppercase;
  letter-spacing:.12em;
}
.badge::before{
  content:"●";
  font-size:8px;
  color:var(--primary-alt);
}

.hero h1{
  font-size:clamp(32px, 4.4vw, 44px);
  margin:10px 0 6px 0;
  line-height:1.1;
  text-shadow:0 0 25px rgba(0,0,0,.9);
}
.hero h1 span{
  background:linear-gradient(120deg,var(--primary-2),var(--primary));
  -webkit-background-clip:text;
  color:transparent;
}
.hero p{
  color:#cbd6ff;
  max-width:760px;
  margin:0 0 10px 0;
  opacity:.93;
}

.cta{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:12px;
}

/* ===========================
   SECTIONS + CARDS
   =========================== */
.section{
  margin:38px 0;
}
.section h2{
  font-size:1.9rem;
  margin:0 0 10px 0;
}
.section h2 span{
  background:linear-gradient(120deg,var(--primary-2),var(--primary));
  -webkit-background-clip:text;
  color:transparent;
}
.section > p{
  color:var(--muted);
  max-width:620px;
  font-size:.95rem;
}

.grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:16px;
}

.card{
  position:relative;
  background:radial-gradient(circle at 0 0,#191f40 0,#0a0d21 55%);
  border:1px solid rgba(123,146,232,.55);
  border-radius:18px;
  padding:16px;
  box-shadow:0 20px 55px rgba(0,0,0,.8);
  overflow:hidden;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.card::before{
  content:"";
  position:absolute;
  inset:-40%;
  background:
    radial-gradient(circle at 0 0,rgba(255,255,255,.13),transparent 55%);
  opacity:0;
  transform:translateX(-30%);
  transition:opacity .28s ease, transform .28s ease;
}
.card:hover{
  transform:translateY(-4px);
  box-shadow:0 26px 70px rgba(0,0,0,.9), 0 0 30px rgba(56,225,255,.4);
  border-color:var(--primary-2);
}
.card:hover::before{
  opacity:1;
  transform:translateX(0);
}

.card .cover{
  width:100%;
  height:160px;
  object-fit:cover;
  border-radius:14px;
  margin-bottom:12px;
  box-shadow:0 0 24px rgba(0,0,0,.7);
}

/* generic list layout */
.list{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:16px;
}

/* ===========================
   FOOTER
   =========================== */
.footer{
  margin-top:40px;
  padding:24px 0 18px;
  border-top:1px solid rgba(255,255,255,.06);
  color:var(--muted);
  font-size:13px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:space-between;
}
.footer span strong{color:#ffffff}

/* ===========================
   TYPO
   =========================== */
h1,h2,h3,strong{color:#f8f7ff}
.small{font-size:12px;color:var(--muted)}

/* ===========================
   FORMS (LOGIN/REGISTER)
   =========================== */
.auth{
  max-width:420px;
  margin:40px auto;
  padding:22px 20px 26px;
  background:radial-gradient(circle at 0 0,#191f40 0,#0a0d21 55%);
  border-radius:18px;
  border:1px solid rgba(118,138,220,.7);
  box-shadow:0 24px 60px rgba(0,0,0,.9);
}

label{
  display:block;
  margin:10px 0 6px;
  font-size:.9rem;
}
input,textarea{
  width:100%;
  padding:11px 12px;
  border-radius:12px;
  border:1px solid rgba(118,138,220,.7);
  background:rgba(5,7,20,.9);
  color:var(--text);
  font-size:.9rem;
  outline:none;
  transition:border-color .16s ease, box-shadow .16s ease, background .16s ease;
}
input:focus,textarea:focus{
  border-color:var(--primary-2);
  box-shadow:0 0 0 1px rgba(56,225,255,.6);
  background:#050716;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 16px;
  border-radius:12px;
  border:1px solid rgba(118,138,220,.8);
  background:radial-gradient(circle at 0 0,#181f3d 0,#070b1b 55%);
  color:var(--text);
  font-size:.9rem;
  cursor:pointer;
  gap:6px;
  transition:
    background .18s ease,
    transform .12s ease,
    box-shadow .18s ease,
    border-color .18s ease;
}
.btn.primary{
  background:linear-gradient(130deg,var(--primary-2),var(--primary));
  border:none;
  color:#05050c;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.06em;
  box-shadow:0 0 24px rgba(56,225,255,.9), 0 0 24px rgba(255,79,181,.9);
}
.btn:hover{
  transform:translateY(-1px);
  box-shadow:0 16px 40px rgba(0,0,0,.9);
}
.btn.primary:hover{
  transform:translateY(-2px) scale(1.02);
}
.btn:active{transform:translateY(1px) scale(.99);}
#btnRedeem:active{transform:scale(.98);}

/* Spinner para botones */
.spin{
  width:16px;
  height:16px;
  border:2px solid rgba(255,255,255,.25);
  border-top-color:#fff;
  border-radius:50%;
  display:inline-block;
  margin-left:8px;
  animation:sp .8s linear infinite;
  vertical-align:middle;
}
@keyframes sp{to{transform:rotate(360deg);}}

/* ===========================
   BANNER TEXT SLIDER
   =========================== */
.lc-banner{
  width:100%;
  margin:12px 0 8px;
  padding:0;
  background:transparent;
}

.lc-fade-x{
  -webkit-mask-image:linear-gradient(90deg,transparent 0%,#000 12%,#000 88%,transparent 100%);
  mask-image:linear-gradient(90deg,transparent 0%,#000 12%,#000 88%,transparent 100%);
}

/* slides */
.lc-text-slider .swiper-wrapper{
  gap:0 !important;
}
.lc-text-slider .swiper-slide{
  width:auto !important;
  margin:0 !important;
}
.lc-text-slider .swiper-slide p{
  margin:0 !important;
  padding:0 !important;
  display:inline-block;
  white-space:nowrap;
  line-height:1;
  letter-spacing:0;
  word-spacing:0;
  font-weight:inherit;
}
/* separador frases */
.lc-text-slider .swiper-slide p::after{
  content:"  •  ";
  opacity:.35;
  font-weight:800;
  font-size:.9em;
}
.lc-text-slider .swiper-slide:last-child p::after{content:"";}

/* tamaños */
.lc-text-slider p{
  text-transform:uppercase;
  font-weight:800;
  line-height:1;
  white-space:nowrap;
  letter-spacing:.6px;
  font-size:clamp(28px, 9vw, 150px);
}

/* stroke fila 1 */
.lc-stroke{
  color:transparent;
  -webkit-text-stroke:2px rgba(255,255,255,.6);
  text-shadow:
    0 0 24px rgba(56,225,255,.4),
    0 0 12px rgba(255,79,181,.4);
}
/* stroke fila 2 */
.lc-stroke-2{
  color:transparent;
  -webkit-text-stroke:2px #ffffff;
  text-shadow:
    0 0 18px rgba(255,0,102,.25),
    0 0 10px rgba(0,153,255,.3);
}

/* colores filas */
.lc-text-slider:not(.invert) .swiper-slide p{
  color:#51f4ff;
}
.lc-text-slider.invert .swiper-slide p{
  color:#ff6ae0;
}

.lc-text-slider:hover{cursor:default;}

/* ===========================
   USER CHIP + DROPDOWN
   =========================== */
.relative{position:relative}

.userchip{
  display:flex;
  align-items:center;
  gap:.5rem;
  padding:.4rem .95rem;
  border-radius:999px;
  background:linear-gradient(130deg,#4a54e8,#c850c0);
  color:#fff;
  font-weight:700;
  cursor:pointer;
  user-select:none;
  box-shadow:0 10px 30px rgba(0,0,0,.45);
}
.userchip img,
.userchip .avatar{
  width:28px;
  height:28px;
  border-radius:50%;
  background:#ffffff22;
  display:grid;
  place-items:center;
  font-size:.8rem;
  font-weight:800;
  object-fit:cover;
}
.userchip .caret{opacity:.8;font-size:.7rem;}

/* ===========================
   FIX DROPDOWN PERFIL
   =========================== */

.dropdown {
  position: absolute;
  right: 0;
  margin-top: .7rem;

  min-width: 200px;

  background: rgba(10,14,30,0.95);
  padding: 0;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.07);
  backdrop-filter: blur(12px);

  box-shadow: 0 15px 55px rgba(0,0,0,.55);

  display: none;
  overflow: hidden;
  z-index: 9999;
}

.dropdown.open { 
  display: block; 
}

/* items */
.dropdown a,
.dropdown button {
  display: flex;
  align-items: center;
  gap: 10px;

  width: 100%;
  padding: .85rem 1rem;

  color: #e8edff;
  background: transparent;

  border: 0;
  text-align: left;
  font-size: .95rem;

  white-space: nowrap;  
  cursor: pointer;
  transition: background .15s ease;
}

.dropdown a:hover,
.dropdown button:hover {
  background: rgba(255,255,255,0.08);
}

.badge{
  background:#ff7bc8;
  color:#fff;
  padding:.1rem .45rem;
  border-radius:999px;
  font-size:.7rem;
  margin-left:.35rem;
}

/* perfil avatar específico */
.profile-box{position:relative;display:inline-block;}
.profile-box .avatar{
  width:40px;
  height:40px;
  border-radius:50%;
  cursor:pointer;
  object-fit:cover;
}

/* ===========================
   STAFF COLORS
   =========================== */
.staff-card.altos-mandos{
  background:radial-gradient(circle at 0 0,#3c164f 0,#150a24 55%);
  border-color:#a05bff;
}
.staff-card.staff-operativo{
  background:radial-gradient(circle at 0 0,#142c4a 0,#0b1020 55%);
  border-color:#3d86ff;
}

/* ===========================
   REWARD OVERLAY
   =========================== */
.rw-overlay{
  position:fixed;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,.55);
  backdrop-filter:blur(7px);
  z-index:60;
}
.rw-card{
  position:relative;
  width:min(420px,92vw);
  border-radius:22px;
  padding:28px 24px;
  background:radial-gradient(120% 120% at 0% 0%,#182238 0%,#0e1422 60%,#070a15 100%);
  box-shadow:0 24px 70px rgba(0,0,0,.85), inset 0 0 0 1px rgba(255,255,255,.07);
  transform:scale(.9);
  animation:rw-pop .36s ease forwards;
}
@keyframes rw-pop{to{transform:scale(1);}}

.rw-light{
  position:absolute;
  inset:-2px;
  background:conic-gradient(from 0deg,#ffd166,#06d6a0,#4cc9f0,#b5179e,#ffd166);
  filter:blur(8px);
  opacity:.3;
  border-radius:24px;
  z-index:0;
  animation:rw-rotate 4s linear infinite;
}
@keyframes rw-rotate{to{transform:rotate(360deg);}}

.rw-content{
  position:relative;
  z-index:1;
  text-align:center;
}
.rw-title{
  font-weight:700;
  font-size:1.1rem;
  opacity:.9;
  margin-bottom:8px;
}
.rw-name{
  font-weight:800;
  font-size:1.6rem;
  letter-spacing:.3px;
  margin-bottom:16px;
}

/* Confetti canvas */
.confetti-canvas{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:55;
}

/* ===========================
   HISTORIAL (OCULTO)
   =========================== */
#historySection{display:none !important;}

/* ===========================
   TIENDA — GTA EDITION
   =========================== */
.tienda-container{
  padding-bottom:2.4rem;
}

.store-hero{
  text-align:center;
  margin:2.2rem auto 1.1rem;
}
.store-hero h1{
  font-size:2.35rem;
  margin-bottom:.4rem;
  color:#ffe96d;
  text-shadow:0 0 14px rgba(255,233,109,.8),0 0 22px rgba(0,0,0,.9);
}
.store-hero p{
  opacity:.88;
  max-width:640px;
  margin:0 auto;
  font-size:.97rem;
  color:#e4e4e4;
}

.buy-status{
  text-align:center;
  font-size:.85rem;
  min-height:1.2em;
  margin-top:1rem;
  opacity:.9;
  color:#9dffaf;
}

/* grid packs */
.store-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
  gap:1.6rem;
  max-width:1000px;
  margin:2rem auto;
  padding:0 1rem 2.4rem;
}

/* tarjetas packs */
.pack-card{
  background:radial-gradient(circle at 0 0,#252317 0,#050505 55%);
  border-radius:18px;
  padding:1rem 1rem 1.3rem;
  box-shadow:0 0 18px rgba(0,255,0,.2),0 22px 50px rgba(0,0,0,.85);
  border:1px solid rgba(0,255,0,.22);
  text-align:center;
  transition:all .22s ease;
  transform:translateY(0);
}
.pack-card:hover{
  transform:translateY(-6px) scale(1.02);
  box-shadow:0 0 30px rgba(0,255,0,.34),0 26px 70px rgba(0,0,0,.95);
  border-color:rgba(0,255,0,.5);
}

/* imagen pack */
.pack-card img{
  max-width:100%;
  display:block;
  margin:0 auto .8rem;
  border-radius:14px;
  filter:drop-shadow(0 0 22px rgba(0,255,0,.25));
}

/* nombre pack */
.pack-name{
  font-size:1.25rem;
  font-weight:800;
  margin-bottom:.25rem;
  color:#fbe388;
  text-shadow:0 0 10px rgba(255,229,120,.7);
}

/* descripción / coins */
.pack-coins{
  font-size:.95rem;
  opacity:.92;
  margin-bottom:.4rem;
  color:#dfdfdf;
}

/* precio */
.pack-price{
  font-size:1.18rem;
  font-weight:800;
  color:#ffe064;
  margin-bottom:.6rem;
  text-shadow:0 0 12px rgba(255,210,0,.6);
}

/* nota */
.pack-note{
  font-size:.8rem;
  opacity:.78;
  margin-bottom:.8rem;
  color:#bdbdbd;
}

/* botón comprar */
.btn-buy{
  display:inline-block;
  padding:.65rem 1.5rem;
  border-radius:999px;
  border:none;
  cursor:pointer;
  font-weight:900;
  background:linear-gradient(135deg,#f7c400,#fff494);
  color:#171717;
  text-transform:uppercase;
  letter-spacing:.07em;
  font-size:.9rem;
  box-shadow:
    0 0 18px rgba(255,213,0,.7),
    0 0 6px rgba(0,0,0,.9) inset;
  transition:all .18s ease;
}
.btn-buy:hover{
  box-shadow:
    0 0 26px rgba(255,240,0,.92),
    0 0 10px rgba(0,0,0,1) inset;
  transform:translateY(-2px) scale(1.03);
}
.btn-buy[disabled]{
  opacity:.6;
  cursor:default;
  transform:none;
}

/* Footer tienda */
.tienda-footer{
  padding:1.5rem 1rem 2rem;
  text-align:center;
  opacity:.65;
  font-size:.8rem;
  margin-top:1rem;
  color:#bbb;
}

/* Pack personalizado */
.custom-input-box input{
  width:100%;
  padding:.6rem;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.16);
  background:#101010;
  color:#fff;
  text-align:center;
  font-size:1rem;
  margin:.5rem 0 1rem;
}
.custom-price{
  font-size:1rem;
  color:#ffe073;
  font-weight:700;
  margin-bottom:1rem;
}

/* ===========================
   RASPADITA — NEW LOOK
   =========================== */
.scratch-shell{
  max-width:560px;
  margin-top:12px;
}
#scratchContainer{
  position:relative;
  border-radius:22px;
  overflow:hidden;
  height:260px;
  background:
    radial-gradient(circle at 10% 0%,#fff7df 0,transparent 55%),
    radial-gradient(circle at 90% 100%,#ffe18a 0,transparent 55%),
    linear-gradient(135deg,#6b5b2b,#f7d47b,#b88735);
  box-shadow:
    0 0 25px rgba(0,0,0,.7),
    0 0 35px rgba(0,255,0,.2);
  border:1px solid rgba(255,245,200,.6);
}
#scratchContainer::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    repeating-linear-gradient(
      45deg,
      rgba(255,255,255,0.45),
      rgba(255,255,255,0.45) 4px,
      rgba(255,255,255,0.08) 4px,
      rgba(255,255,255,0.08) 8px
    );
  mix-blend-mode:soft-light;
  pointer-events:none;
}
#scratchCanvas{
  width:100%;
  height:100%;
  display:block;
}

/* compra tickets */
.tickets-shop{
  margin:1rem 0;
  max-width:300px;
}
.tickets-shop label{
  display:block;
  margin-bottom:.3rem;
  color:#eee;
}
.tickets-row{
  display:flex;
  gap:.5rem;
}
.tickets-row input{
  width:80px;
  padding:.5rem;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.15);
  background:#111;
  color:#fff;
  text-align:center;
}
.tickets-hint{
  display:block;
  margin-top:.3rem;
  opacity:.8;
  font-size:.85rem;
}

/* ===========================
   TIENDA — MODAL PREMIUM
   =========================== */
.btn-ver{
  background:#2f32ff;
  color:white;
  padding:.4rem .8rem;
  border-radius:8px;
  cursor:pointer;
  border:none;
  font-weight:600;
  transition:background .18s ease, transform .12s ease, box-shadow .18s ease;
}
.btn-ver:hover{
  background:#4d50ff;
  box-shadow:0 12px 26px rgba(0,0,0,.6);
  transform:translateY(-1px);
}

/* backdrop */
.modal-backdrop{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  backdrop-filter:blur(14px);
  background:rgba(1,2,10,.78);
  z-index:9999;
  animation:fadeIn .2s ease forwards;
}
@keyframes fadeIn{
  from{opacity:0;}
  to{opacity:1;}
}

.modal{
  width:95%;
  max-width:480px;
  background:#080812;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 26px 70px rgba(0,0,0,.92);
  animation:popIn .25s ease;
  position:relative;
  border:1px solid rgba(255,255,255,.08);
}
@keyframes popIn{
  0%{transform:scale(.82);opacity:0;}
  100%{transform:scale(1);opacity:1;}
}

/* close */
.modal-close{
  position:absolute;
  top:14px;
  right:14px;
  width:36px;
  height:36px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,.7);
  backdrop-filter:blur(6px);
  color:#fff;
  font-size:20px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.26);
  cursor:pointer;
  transition:.15s ease;
}
.modal-close:hover{
  background:rgba(255,255,255,.1);
  border-color:rgba(255,255,255,.6);
}

/* image */
.modal-img-box{
  position:relative;
  width:100%;
  height:280px;
  overflow:hidden;
}
.modal-img-box img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.modal-tier{
  position:absolute;
  bottom:12px;
  left:12px;
  background:rgba(0,0,0,.55);
  padding:6px 12px;
  font-size:13px;
  border-radius:8px;
  color:#fff;
  text-transform:uppercase;
  font-weight:800;
  letter-spacing:.5px;
}

/* body */
.modal-body{
  padding:20px;
  color:#fff;
}
.modal-title{
  margin:0 0 12px 0;
  font-size:1.4rem;
  font-weight:800;
}
.modal-desc{
  margin:0 0 16px 0;
  opacity:.9;
  line-height:1.4;
}
.modal-price-box{margin-bottom:20px;}
.modal-price{
  font-size:1.7rem;
  font-weight:800;
}
.modal-currency{
  font-size:1rem;
  margin-left:4px;
  opacity:.8;
}

/* buy button */
.modal-buy-btn{
  width:100%;
  background:linear-gradient(130deg,#4a4cff,#6a6dff);
  padding:12px;
  font-size:16px;
  color:#fff;
  border:none;
  border-radius:10px;
  cursor:pointer;
  font-weight:700;
  letter-spacing:.05em;
  text-transform:uppercase;
  transition:.16s ease;
  box-shadow:0 14px 40px rgba(0,0,0,.9);
}
.modal-buy-btn:hover{
  opacity:.9;
  transform:translateY(-1px);
}

/* ===========================
   RESPONSIVE TWEAKS
   =========================== */
@media (max-width:768px){
  .nav{gap:10px;}
  .hero-inner{padding:30px 22px;}
  .hero{min-height:360px;}
  .store-grid{margin-top:1.5rem;}
  .auth{margin-top:26px;}
}
@media (max-width:480px){
  .nav{flex-wrap:wrap;}
  .brand .text{font-size:.95rem;}
  .hero-inner{padding:26px 18px;}
}


/* FIX: overlays bloqueando inputs */
.card::before,
.card::after,
.auth::before,
.auth::after {
    pointer-events: none !important;
}

/* FIX: inputs encima de todo */
input, textarea, select {
    position: relative;
    z-index: 20 !important;
    pointer-events: auto !important;
}

/* ================================
   NAVBAR BRAND — NEON LIMACITY RP
   ================================ */
.brand-title {
  font-weight: 800;
  font-size: 1.25rem;
  letter-spacing: .8px;
  text-transform: uppercase;

  background: linear-gradient(120deg, #38e1ff, #ff4fb5);
  -webkit-background-clip: text;
  color: transparent;

  text-shadow:
    0 0 12px rgba(56,225,255,.45),
    0 0 18px rgba(255,79,181,.35);
}

/* parte “LIMA” tono celeste más fuerte */
.brand-title span {
  background: linear-gradient(120deg, #51f4ff, #38e1ff);
  -webkit-background-clip: text;
  color: transparent;
}
