/* ============================================================
   AniPack — styles.css v4 (imágenes locales)
   ============================================================ */

:root {
  --bg:        #0a0a0f;
  --bg-card:   #12121a;
  --bg-card2:  #1a1a28;
  --border:    rgba(255,255,255,0.07);
  --text:      #e8e8f0;
  --muted:     #7070a0;
  --accent:    #ff3d6e;
  --accent2:   #ffd84d;
  --accent3:   #6c63ff;
  --teal:      #00e5c8;
  --font-disp: 'Bangers', cursive;
  --font-body: 'Nunito', sans-serif;
  --radius:    16px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--bg); color: var(--text);
  font-family: var(--font-body); font-size: 1rem;
  line-height: 1.6; overflow-x: hidden;
}

.noise {
  position: fixed; inset: 0; z-index: 999; 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.025;
}

a { text-decoration: none; color: inherit; }
ul { list-style: none; }
.container { max-width: 1200px; margin-inline: auto; padding-inline: clamp(1.25rem,4vw,3rem); }

.section-label { font-size:.72rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--teal); margin-bottom:.75rem; }
.section-title { font-family:var(--font-disp); font-size:clamp(2.4rem,5vw,3.6rem); line-height:1.05; letter-spacing:.02em; color:var(--text); margin-bottom:1.25rem; }
.section-sub   { font-size:1.05rem; color:var(--muted); max-width:520px; line-height:1.7; }

/* ── NAV ── */
.nav {
  display:flex; align-items:center; justify-content:space-between;
  padding:1.5rem clamp(1.25rem,4vw,3rem); position:relative; z-index:10;
}
.logo { font-family:var(--font-disp); font-size:2rem; letter-spacing:.04em; }
.logo span { color:var(--accent); }
.nav-links { display:flex; gap:2rem; align-items:center; font-weight:600; font-size:.9rem; }
.nav-links a { color:var(--muted); transition:color .2s; }
.nav-links a:hover { color:var(--text); }
.btn-nav { background:var(--accent); color:#fff !important; padding:.5rem 1.25rem; border-radius:50px; transition:opacity .2s, transform .15s !important; }
.btn-nav:hover { opacity:.9; transform:translateY(-1px); }

/* ── HERO ── */
.hero {
  min-height:100vh; position:relative; overflow:hidden;
  display:flex; flex-direction:column;
  background:radial-gradient(ellipse 90% 60% at 60% 50%, #1a0a2e 0%, var(--bg) 65%);
}
.hero::before {
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(108,99,255,.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(108,99,255,.07) 1px, transparent 1px);
  background-size:60px 60px; pointer-events:none;
}
.hero-content { position:relative; z-index:3; padding:5rem clamp(1.25rem,4vw,3rem) 4rem; max-width:680px; }
.hero-eyebrow { font-size:.8rem; font-weight:700; letter-spacing:.15em; text-transform:uppercase; color:var(--accent2); margin-bottom:1.25rem; animation:fadeUp .6s ease both; }
.hero-title   { font-family:var(--font-disp); font-size:clamp(3rem,7vw,5.5rem); line-height:1; letter-spacing:.03em; margin-bottom:1.5rem; animation:fadeUp .6s .1s ease both; }
.hero-title em { font-style:normal; background:linear-gradient(135deg,var(--accent) 0%,var(--accent2) 100%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.hero-sub  { font-size:1.1rem; color:var(--muted); max-width:500px; margin-bottom:2.5rem; animation:fadeUp .6s .2s ease both; }
.hero-btns { display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:3.5rem; animation:fadeUp .6s .3s ease both; }

.btn-primary {
  display:inline-block;
  background:linear-gradient(135deg,var(--accent),#ff7043); color:#fff;
  font-family:var(--font-body); font-weight:800; font-size:1rem;
  padding:.85rem 2rem; border-radius:50px;
  transition:transform .2s, box-shadow .2s;
  box-shadow:0 0 30px rgba(255,61,110,.35);
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 40px rgba(255,61,110,.5); }
.btn-ghost { border:1.5px solid var(--border); color:var(--muted); font-weight:700; font-size:.95rem; padding:.85rem 2rem; border-radius:50px; transition:border-color .2s,color .2s; }
.btn-ghost:hover { border-color:var(--text); color:var(--text); }

.hero-stats { display:flex; align-items:center; gap:2rem; animation:fadeUp .6s .4s ease both; }
.stat { display:flex; flex-direction:column; }
.stat-num   { font-family:var(--font-disp); font-size:1.8rem; color:var(--text); letter-spacing:.04em; }
.stat-label { font-size:.78rem; color:var(--muted); font-weight:700; text-transform:uppercase; letter-spacing:.1em; }
.stat-divider { width:1px; height:40px; background:var(--border); }

.hero-scroll-hint {
  position:absolute; bottom:2rem; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:.4rem;
  color:var(--muted); font-size:.72rem; font-weight:700; letter-spacing:.15em; text-transform:uppercase; z-index:5;
}
.scroll-arrow { width:20px; height:20px; border-right:2px solid var(--muted); border-bottom:2px solid var(--muted); transform:rotate(45deg); animation:bounce 1.5s infinite; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━
   FLOATING CARDS
   ━━━━━━━━━━━━━━━━━━━━━━━━ */
.floating-cards {
  position:absolute; right:clamp(2rem,8vw,7rem); top:50%; transform:translateY(-42%);
  z-index:2; width:360px; height:540px; pointer-events:none;
}

.fcard {
  position:absolute; width:155px; height:235px;
  border-radius:14px; overflow:hidden;
  display:flex; flex-direction:column;
  animation:floatCard 6s ease-in-out infinite;
}

.fcard-shine {
  position:absolute; inset:0; z-index:4; pointer-events:none;
  background:linear-gradient(135deg,rgba(255,255,255,.18) 0%,transparent 45%,rgba(255,255,255,.05) 100%);
}

/* Image fills the card top, transparent PNG floats on the bg gradient */
.fcard-imgwrap {
  position: absolute;
  top: 0; left: 0; right: 0;
  bottom: 52px;
  overflow: hidden;
}
.fcard-imgwrap img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}

.fcard-img-real {
  width:100%; height:100%;
  object-fit:contain; object-position:bottom center;
  display:block;
  filter:drop-shadow(0 4px 18px rgba(0,0,0,.75));
}

.fcard-footer {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: .45rem .65rem .6rem;
  z-index: 5;
  display: flex; flex-direction: column; gap: .08rem;
  background: rgba(0,0,0,.75);
  backdrop-filter: blur(6px);
}
.fcard-badge { font-size:.56rem; font-weight:800; text-transform:uppercase; letter-spacing:.08em; padding:.12rem .5rem; border-radius:20px; width:fit-content; margin-bottom:.08rem; }
.legendary { background:rgba(246,173,85,.22); color:#f6ad55; }
.mythic    { background:rgba(0,229,200,.18);  color:var(--teal); }
.epic      { background:rgba(183,148,244,.2); color:#b794f4; }
.rare      { background:rgba(99,179,237,.2);  color:#63b3ed; }
.fcard-name   { font-weight:800; font-size:.78rem; color:var(--text); }
.fcard-series { font-size:.6rem; color:var(--muted); }

.fcard--1 { background:linear-gradient(170deg,#1b1b40,#0e0e20); border:1.5px solid rgba(246,173,85,.3); top:15px;  left:75px;  --rot:-7deg; animation-delay:0s;   box-shadow:0 0 35px rgba(246,173,85,.2); }
.fcard--2 { background:linear-gradient(170deg,#1a1430,#0e0a20); border:1.5px solid rgba(0,229,200,.25);  top:105px; left:190px; --rot: 6deg; animation-delay:1s;   box-shadow:0 0 30px rgba(0,229,200,.18); }
.fcard--3 { background:linear-gradient(170deg,#1e1428,#100c1e); border:1.5px solid rgba(183,148,244,.3); top:270px; left:55px;  --rot:-4deg; animation-delay:2s;   box-shadow:0 0 28px rgba(183,148,244,.2); }
.fcard--4 { background:linear-gradient(170deg,#0e1828,#0a1020); border:1.5px solid rgba(99,179,237,.3);  top:325px; left:195px; --rot: 9deg; animation-delay:.5s;  box-shadow:0 0 25px rgba(99,179,237,.18); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━
   ENVELOPE SECTION
   ━━━━━━━━━━━━━━━━━━━━━━━━ */
.envelope-section {
  padding:7rem 0; position:relative;
  background:linear-gradient(180deg,var(--bg) 0%,#0d0d1a 100%);
}
.envelope-section::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,var(--accent),transparent); }

.envelope-stage {
  display:flex; align-items:center; gap:15rem;
  margin-top:3.5rem; flex-wrap:wrap; justify-content:center;
  max-width: 1000px;
  margin-left: auto;
  margin-right: auto;
}


.env-checkbox { display:none; }
.envelope-wrap { position:relative; width:300px; height:400px; flex-shrink:0; }

.envelope { display:block; width:300px; height:200px; position:absolute; top:0; left:0; cursor:pointer; transition:transform .3s; }
.envelope:hover { transform:scale(1.03); }

.env-body {
  position:absolute; inset:0;
  background:linear-gradient(145deg,#1e1040,#2a1560);
  border-radius:14px; border:1.5px solid rgba(108,99,255,.45);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.45rem;
  box-shadow:0 0 50px rgba(108,99,255,.25), inset 0 1px 0 rgba(255,255,255,.1);
  overflow:hidden;
}
.env-body::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(255,255,255,.07) 0%,transparent 60%); }
.env-logo { font-family:var(--font-disp); font-size:2.2rem; letter-spacing:.08em; color:#fff; position:relative; z-index:1; }
.env-logo span { color:var(--accent); }
.env-stars { font-size:.9rem; color:var(--accent2); letter-spacing:.35em; position:relative; z-index:1; }
.env-hint  { font-size:.7rem; font-weight:700; text-transform:uppercase; letter-spacing:.12em; color:var(--muted); position:relative; z-index:1; animation:pulseMuted 2s ease-in-out infinite; transition:opacity .3s; }

.env-flap {
  position:absolute; top:0; left:0; right:0; height:100px;
  background:linear-gradient(170deg,#2a1868,#1a0e48);
  clip-path:polygon(0 0,100% 0,50% 100%);
  border-radius:14px 14px 0 0;
  transform-origin:top center;
  transition:transform .55s cubic-bezier(.23,1,.32,1);
  z-index:4; border:1.5px solid rgba(108,99,255,.3);
  box-shadow:0 4px 20px rgba(0,0,0,.4);
}

.env-checkbox:checked ~ .envelope .env-flap { transform:perspective(600px) rotateX(-180deg); }
.env-checkbox:checked ~ .envelope .env-hint { opacity:0; }
.env-checkbox:checked ~ .envelope            { transform:scale(.93) translateY(10px); }

/* ── Spill cards ── */
.spill-cards {
  position:absolute; bottom:0; left:50%; transform:translateX(-50%);
  width:360px; height:200px; pointer-events:none;
}

.spill-card {
  position:absolute; width:92px; height:138px;
  border-radius:10px; overflow:hidden;
  display:flex; flex-direction:column;
  opacity:0; transform:translateY(20px);
  transition:opacity .4s, transform .55s cubic-bezier(.23,1,.32,1);
  box-shadow:0 10px 35px rgba(0,0,0,.65);
}

.spill-imgwrap {
  position: absolute;
  inset: 0;
  bottom: 36px;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  overflow: hidden;
}
.spill-imgwrap img {
  width:100%; height:100%;
  object-fit:contain; object-position:bottom center;
  display:block;
  filter:drop-shadow(0 2px 8px rgba(0,0,0,.6));
}

.spill-info {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 3;
  padding:.28rem .4rem;
  background:rgba(0,0,0,.88);
  display:flex;
  flex-direction:column;
  gap:.04rem;
  flex-shrink:0;
}
.spill-rarity { font-size:.5rem; font-weight:800; text-transform:uppercase; letter-spacing:.07em; }
.spill-name   { font-size:.6rem; font-weight:700; color:var(--text); }

.legendary-txt { color:#f6ad55; }
.mythic-txt    { color:var(--teal); }
.epic-txt      { color:#b794f4; }
.rare-txt      { color:#63b3ed; }
.uncommon-txt  { color:#68d391; }

.spill-1 { bottom:0; left:0;    background:linear-gradient(160deg,#281808,#180c04); border:1.5px solid rgba(246,173,85,.35); }
.spill-2 { bottom:0; left:66px; background:linear-gradient(160deg,#0e1828,#080f1a); border:1.5px solid rgba(0,229,200,.3); }
.spill-3 { bottom:0; left:132px; background:linear-gradient(160deg,#1a1030,#100820); border:1.5px solid rgba(183,148,244,.3); }
.spill-4 { bottom:0; left:198px; background:linear-gradient(160deg,#0e1828,#080f1a); border:1.5px solid rgba(99,179,237,.3); }
.spill-5 { bottom:0; left:264px; background:linear-gradient(160deg,#1e1428,#100c1e); border:1.5px solid rgba(183,148,244,.25); }

.env-checkbox:checked ~ .spill-cards { pointer-events:auto; }
.env-checkbox:checked ~ .spill-cards .spill-1 { opacity:1; transform:translateY(-220px) translateX(-58px) rotate(-21deg); transition-delay:.22s; }
.env-checkbox:checked ~ .spill-cards .spill-2 { opacity:1; transform:translateY(-235px) translateX(-16px) rotate(-8deg);  transition-delay:.30s; }
.env-checkbox:checked ~ .spill-cards .spill-3 { opacity:1; transform:translateY(-240px) translateX( 26px) rotate( 0deg);  transition-delay:.38s; }
.env-checkbox:checked ~ .spill-cards .spill-4 { opacity:1; transform:translateY(-228px) translateX( 68px) rotate( 9deg);  transition-delay:.46s; }
.env-checkbox:checked ~ .spill-cards .spill-5 { opacity:1; transform:translateY(-212px) translateX(110px) rotate(20deg);  transition-delay:.54s; }

/* Pack sidebar */
.envelope-desc { width:380px; flex-shrink:0; font-size:1.15rem; }
.pack-type { display:flex; align-items:center; gap:1rem; background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:1rem 1.25rem; margin-bottom:1.5rem; }
.pack-icon { font-size:2.2rem; }
.pack-type strong { display:block; font-size:1rem; font-weight:800; }
.pack-type span   { font-size:.78rem; color:var(--muted); }
.pack-odds { display:flex; flex-direction:column; gap:.65rem; }
.pack-odds li { display:flex; align-items:center; gap:.75rem; font-size:.88rem; color:var(--muted); font-weight:600; }
.dot { width:10px; height:10px; border-radius:50%; flex-shrink:0; }
.glow-gold { background:#f6ad55; box-shadow:0 0 8px rgba(246,173,85,.6); }
.glow-teal { background:var(--teal); box-shadow:0 0 8px rgba(0,229,200,.6); }

/* ── HOW ── */
.how { padding:7rem 0; background:var(--bg); position:relative; }
.how::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,var(--accent3),transparent); }
.steps { display:flex; align-items:flex-start; gap:1rem; margin-top:3.5rem; flex-wrap:wrap; }
.step { flex:1; min-width:220px; background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:2rem 1.75rem; position:relative; transition:transform .25s, border-color .25s; }
.step:hover { transform:translateY(-4px); border-color:rgba(108,99,255,.4); }
.step-num  { font-family:var(--font-disp); font-size:3.5rem; line-height:1; color:rgba(255,255,255,.05); position:absolute; top:1rem; right:1.25rem; }
.step-icon { font-size:2.2rem; margin-bottom:1rem; }
.step h3   { font-family:var(--font-disp); font-size:1.6rem; letter-spacing:.04em; margin-bottom:.6rem; }
.step p    { font-size:.92rem; color:var(--muted); line-height:1.65; }
.step-arrow { font-size:2rem; color:var(--border); align-self:center; flex-shrink:0; padding-top:1rem; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━
   COLLECTION — IMAGE CARDS
   ━━━━━━━━━━━━━━━━━━━━━━━━ */
.collection { padding:7rem 0; background:linear-gradient(180deg,var(--bg) 0%,#0e0e18 100%); }
.series-grid { display:flex; flex-wrap:wrap; gap:.6rem; margin:2rem 0 3rem; }
.series-tag { background:var(--bg-card2); border:1px solid var(--border); border-radius:50px; padding:.4rem 1rem; font-size:.82rem; font-weight:700; color:var(--muted); transition:color .2s,border-color .2s; cursor:default; }
.series-tag:hover { color:var(--text); border-color:var(--accent3); }

.img-card-gallery { display:flex; gap:1.25rem; flex-wrap:wrap; justify-content:center; margin-top:1.5rem; }

.img-card {
  width:172px; border-radius:16px; overflow:hidden;
  display:flex; flex-direction:column;
  cursor:default; transition:transform .3s, box-shadow .3s, border-color .3s;
}
.img-card:hover { transform:translateY(-10px) rotate(-1deg); }

.img-card-top {
  position:relative; height:220px; overflow:hidden;
  display:flex; align-items:flex-end; justify-content:center;
  padding-bottom:6px;
  /* subtle inner glow so the character "sits" on something */
  background: radial-gradient(ellipse 80% 60% at 50% 100%, rgba(255,255,255,0.04) 0%, transparent 70%);
}
.img-card-top img {
  width:100%; height:100%;
  object-fit:contain; object-position:bottom center;
  display:block; position:relative; z-index:1;
  transition:transform .4s;
  filter:drop-shadow(0 6px 22px rgba(0,0,0,.85));
  /* ensure image always tries to load at full size */
  min-height:100%;
}
.img-card:hover .img-card-top img { transform:scale(1.07) translateY(-4px); }

.secret-overlay {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  z-index: 2;
}

.ic-badge { position:absolute; top:.55rem; left:.55rem; z-index:3; font-size:.58rem; font-weight:800; text-transform:uppercase; letter-spacing:.08em; padding:.2rem .6rem; border-radius:20px; backdrop-filter:blur(4px); }
.legendary-badge { background:rgba(246,173,85,.25); color:#f6ad55; border:1px solid rgba(246,173,85,.4); }
.mythic-badge    { background:rgba(0,229,200,.2);  color:var(--teal); border:1px solid rgba(0,229,200,.35); }
.epic-badge      { background:rgba(183,148,244,.2);color:#b794f4; border:1px solid rgba(183,148,244,.35); }
.rare-badge      { background:rgba(99,179,237,.2); color:#63b3ed; border:1px solid rgba(99,179,237,.35); }

.img-card-bottom { padding:.8rem .9rem; }
.img-card-bottom strong { display:block; font-size:.88rem; font-weight:800; margin-bottom:.1rem; }
.img-card-bottom span   { font-size:.72rem; color:var(--muted); }

.ic-legendary { background:linear-gradient(160deg,#281808,#180c04); border:1.5px solid rgba(246,173,85,.3); }
.ic-legendary:hover { box-shadow:0 16px 50px rgba(246,173,85,.32); border-color:rgba(246,173,85,.55); }

.ic-mythic { background:linear-gradient(160deg,#0a1e20,#05131a); border:1.5px solid rgba(0,229,200,.25); }
.ic-mythic:hover { box-shadow:0 16px 50px rgba(0,229,200,.3); border-color:rgba(0,229,200,.5); }

.ic-epic { background:linear-gradient(160deg,#1a1030,#0d0820); border:1.5px solid rgba(183,148,244,.25); }
.ic-epic:hover { box-shadow:0 16px 50px rgba(183,148,244,.3); border-color:rgba(183,148,244,.5); }

.ic-rare { background:linear-gradient(160deg,#0a1828,#050f1c); border:1.5px solid rgba(99,179,237,.25); }
.ic-rare:hover { box-shadow:0 16px 50px rgba(99,179,237,.3); border-color:rgba(99,179,237,.5); }

/* ── RARITIES ── */
.rarities { padding:7rem 0; background:var(--bg); }
.rarity-table { display:flex; flex-direction:column; gap:.85rem; margin-top:3rem; }
.rarity-row { display:grid; grid-template-columns:2.5rem 120px 65px 1fr 1fr; align-items:center; gap:1.25rem; padding:1.1rem 1.5rem; background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); transition:background .2s,border-color .2s; }
.rarity-row:hover { background:var(--bg-card2); border-color:rgba(255,255,255,.12); }
.rarity-icon   { font-size:1.3rem; text-align:center; }
.rarity-name   { font-weight:800; font-size:.95rem; }
.rarity-chance { font-family:var(--font-disp); font-size:1.3rem; color:var(--muted); }
.rarity-bar    { background:rgba(255,255,255,.06); border-radius:50px; height:6px; overflow:hidden; }
.rarity-fill   { height:100%; border-radius:50px; }
.rarity-desc   { font-size:.83rem; color:var(--muted); }
.mythic-row    { border-color:rgba(0,229,200,.25); background:linear-gradient(90deg,rgba(0,229,200,.04),transparent); }
.mythic-fill   { background:linear-gradient(90deg,var(--teal),var(--accent3)); }
.mythic-glow   { color:var(--teal) !important; text-shadow:0 0 12px var(--teal); animation:mythicPulse 2s ease-in-out infinite; }

/* ── TESTIMONIALS ── */
.testimonials { padding:7rem 0; background:linear-gradient(180deg,var(--bg) 0%,#0e0e1a 100%); }
.testi-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1.25rem; margin-top:3rem; }
.testi-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:2rem; transition:transform .25s; }
.testi-card:hover { transform:translateY(-3px); }
.testi-card.featured { border-color:rgba(255,61,110,.3); background:linear-gradient(145deg,var(--bg-card),#1a0d14); position:relative; }
.testi-card.featured::before { content:'🔥 Popular'; position:absolute; top:-.6rem; left:1.5rem; background:var(--accent); color:#fff; font-size:.65rem; font-weight:800; padding:.2rem .7rem; border-radius:20px; letter-spacing:.05em; text-transform:uppercase; }
.testi-card p { font-size:.95rem; color:var(--muted); line-height:1.7; margin-bottom:1.5rem; font-style:italic; }
.testi-author { display:flex; align-items:center; gap:.75rem; }
.testi-avatar { width:40px; height:40px; border-radius:50%; background:var(--bg-card2); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; font-size:1.2rem; flex-shrink:0; }
.testi-author strong { display:block; font-size:.88rem; font-weight:800; }
.testi-author span   { font-size:.72rem; color:var(--muted); }

/* ── CTA ── */
.cta-section { padding:8rem 0; position:relative; overflow:hidden; background:radial-gradient(ellipse 80% 60% at 50% 50%,#1a0a2e 0%,var(--bg) 70%); }
.cta-bg-pattern { position:absolute; inset:0; background-image:radial-gradient(circle,rgba(108,99,255,.12) 1px,transparent 1px); background-size:30px 30px; pointer-events:none; }
.cta-inner { position:relative; z-index:1; text-align:center; }
.cta-tag   { display:inline-block; background:rgba(108,99,255,.15); border:1px solid rgba(108,99,255,.3); color:#a78bfa; font-size:.8rem; font-weight:800; text-transform:uppercase; letter-spacing:.1em; padding:.4rem 1.25rem; border-radius:50px; margin-bottom:1.5rem; }
.cta-title { font-family:var(--font-disp); font-size:clamp(2.8rem,6vw,5rem); line-height:1.05; letter-spacing:.03em; margin-bottom:1.25rem; }
.cta-sub   { font-size:1.05rem; color:var(--muted); max-width:480px; margin:0 auto 2.5rem; line-height:1.7; }
.cta-form  { display:flex; gap:.75rem; max-width:480px; margin:0 auto 1rem; flex-wrap:wrap; justify-content:center; }
.cta-input { flex:1; min-width:200px; background:var(--bg-card); border:1.5px solid var(--border); border-radius:50px; padding:.85rem 1.5rem; color:var(--text); font-family:var(--font-body); font-size:.95rem; outline:none; transition:border-color .2s; }
.cta-input:focus { border-color:var(--accent3); }
.cta-input::placeholder { color:var(--muted); }
.btn-cta { background:linear-gradient(135deg,var(--accent),var(--accent2)); color:#fff; font-family:var(--font-body); font-weight:800; font-size:1rem; padding:.85rem 2rem; border-radius:50px; border:none; cursor:pointer; transition:transform .2s,box-shadow .2s; box-shadow:0 0 40px rgba(255,61,110,.3); }
.btn-cta:hover { transform:translateY(-2px); box-shadow:0 8px 50px rgba(255,61,110,.5); }
.cta-fine { font-size:.77rem; color:var(--muted); margin-top:.5rem; }

/* ── FOOTER ── */
.footer { border-top:1px solid var(--border); padding:3rem 0; background:var(--bg); }
.footer-inner { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1.5rem; }
.footer-logo { font-family:var(--font-disp); font-size:1.6rem; letter-spacing:.04em; }
.footer-logo span { color:var(--accent); }
.footer-copy { font-size:.78rem; color:var(--muted); line-height:1.6; text-align:center; }
.footer-links { display:flex; gap:1.5rem; }
.footer-links a { font-size:.82rem; font-weight:700; color:var(--muted); transition:color .2s; }
.footer-links a:hover { color:var(--text); }

/* ── KEYFRAMES ── */
@keyframes fadeUp     { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }
@keyframes floatCard  { 0%,100%{transform:translateY(0) rotate(var(--rot,0deg))} 50%{transform:translateY(-14px) rotate(var(--rot,0deg))} }
@keyframes bounce     { 0%,100%{transform:rotate(45deg) translateY(0)} 50%{transform:rotate(45deg) translateY(5px)} }
@keyframes mythicPulse{ 0%,100%{text-shadow:0 0 10px var(--teal)} 50%{text-shadow:0 0 25px var(--teal),0 0 50px rgba(0,229,200,.4)} }
@keyframes pulseMuted { 0%,100%{opacity:1} 50%{opacity:.45} }

/* ── RESPONSIVE ── */
@media (max-width:900px) {
  .floating-cards { display:none; }
  .hero-content   { max-width:100%; }
  .rarity-row     { grid-template-columns:2rem 100px 50px 1fr; }
  .rarity-row .rarity-desc { display:none; }
  .envelope-stage {
  display:flex; align-items:center; gap:5rem;
  margin-top:3.5rem; flex-wrap:wrap; justify-content:center;
  padding-left: 200px;
}
}
@media (max-width:640px) {
  .nav-links  { display:none; }
  .steps      { flex-direction:column; }
  .step-arrow { align-self:center; transform:rotate(90deg); }
  .footer-inner { flex-direction:column; text-align:center; }
  .hero-stats { gap:1rem; }
  .rarity-row { grid-template-columns:2rem 85px 42px 1fr; gap:.6rem; padding:.85rem .9rem; }
  .img-card   { width:145px; }
  .img-card-top { height:185px; }
  .img-card-gallery { gap:.85rem; }
}