/* ── RESET ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:"Poppins",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font-family:inherit}
ul{list-style:none}

/* ── VARIABLES ── */
:root{
  --bg:#0d0620;
  --surface:rgba(18,8,42,0.6);
  --surface-2:rgba(24,12,54,0.5);
  --surface-3:rgba(34,16,68,0.45);
  --glass:rgba(22,10,50,0.65);
  --border:rgba(138,11,210,0.18);
  --border-h:rgba(178,75,240,0.38);
  --accent:#8A0BD2;
  --accent-soft:#b44bf0;
  --accent-bright:#9b2de0;
  --accent-glow:rgba(138,11,210,0.4);
  --orange:#f97316;
  --green:#22c55e;
  --green-soft:#4ade80;
  --text:#f0eaff;
  --text-soft:#d4c8f0;
  --muted:#9b8ec4;
  --radius:16px;
  --radius-sm:12px;
  --radius-lg:24px;
  --ease:cubic-bezier(.4,0,.2,1);
}

/* ── BODY ── */
body{
  background:var(--bg);
  background-image:
    radial-gradient(ellipse 90% 70% at 12% 18%,rgba(138,11,210,0.5) 0%,transparent 55%),
    radial-gradient(ellipse 75% 55% at 88% 22%,rgba(155,45,224,0.4) 0%,transparent 52%),
    radial-gradient(ellipse 100% 80% at 50% 85%,rgba(138,11,210,0.35) 0%,transparent 58%),
    radial-gradient(ellipse 65% 45% at 72% 68%,rgba(180,75,240,0.3) 0%,transparent 48%),
    radial-gradient(ellipse 55% 50% at 25% 55%,rgba(120,20,200,0.25) 0%,transparent 45%),
    linear-gradient(155deg,#24085a 0%,#180845 25%,#110630 50%,#0d0620 100%);
  background-attachment:fixed;
  color:var(--text);
  overflow-x:hidden;
}

/* ── ANIMATIONS ── */
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.55}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}

/* ============================================
   INFO BAR (marquee)
   ============================================ */
@keyframes scrollInfoBar{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.info-bar{
  overflow:hidden;white-space:nowrap;
  background:linear-gradient(90deg,#1a0535 0%,rgba(138,11,210,0.35) 30%,rgba(249,115,22,0.18) 70%,#1a0535 100%);
  border-bottom:1px solid rgba(138,11,210,0.25);
  position:relative;
}
.info-bar::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent 0%,rgba(138,11,210,0.08) 50%,transparent 100%);
  pointer-events:none;
}
.info-bar-content{
  display:inline-block;
  padding:.55rem 0;
  font-size:.85rem;
  color:rgba(255,255,255,0.88);
  animation:scrollInfoBar 20s linear infinite;
}
.info-bar-content:hover{animation-play-state:paused}
.info-bar-text{display:inline-block;padding:0 2rem}
.info-bar-text strong{color:#f59e0b;font-weight:700}

/* ============================================
   NAVBAR
   ============================================ */
.nav{
  position:sticky;top:0;z-index:100;
  background:linear-gradient(135deg,rgba(26,5,53,0.92) 0%,rgba(48,12,90,0.88) 50%,rgba(26,5,53,0.92) 100%);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid rgba(138,11,210,0.25);
  box-shadow:0 4px 24px rgba(138,11,210,0.1),0 1px 0 rgba(138,11,210,0.15) inset;
}
.nav-inner{
  width:95%;max-width:1600px;margin:0 auto;
  padding:.85rem 0;
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
  flex-wrap:wrap;
}
.nav-brand{
  display:flex;align-items:center;gap:.6rem;
  font-weight:600;font-size:1.1rem;color:var(--text);
  text-decoration:none;transition:all .3s;
}
.nav-brand:hover{opacity:.9}
.nav-brand img{width:40px;height:40px}

.nav-links{display:flex;align-items:center;gap:1rem;font-size:.95rem}
.nav-links a{
  padding:.35rem .9rem;border-radius:999px;
  color:var(--muted);font-weight:500;
  transition:all .25s;text-decoration:none;
}
.nav-links a:hover,
.nav-links a.is-active{
  background:rgba(124,58,237,0.28);color:var(--text);
}
.nav-toggle{
  display:none;
  padding:.35rem .8rem;border-radius:999px;
  border:1px solid var(--border);
  color:var(--text);font-size:1.1rem;
  transition:all .3s;background:transparent;cursor:pointer;
}
.nav-toggle:hover{background:rgba(138,11,210,.12);border-color:var(--accent)}

/* ── Botones genéricos ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.35rem;
  padding:.55rem 1.25rem;border:none;border-radius:999px;
  font-size:.95rem;font-weight:600;cursor:pointer;
  transition:all .25s;white-space:nowrap;
  position:relative;overflow:hidden;
}
.btn-primary{
  background:linear-gradient(135deg,var(--accent),var(--accent-soft));
  color:#fff;
  box-shadow:0 4px 16px rgba(138,11,210,0.15);
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 32px rgba(124,58,237,0.35),0 4px 12px rgba(124,58,237,0.2);
}
.btn-outline{
  background:transparent;
  border:1px solid var(--border-h);
  color:var(--text-soft);
}
.btn-outline:hover{
  background:rgba(138,11,210,0.12);
  border-color:var(--accent);color:#fff;
  transform:translateY(-2px);
}

/* loop-glow */
@keyframes glowLoop{
  0%{box-shadow:0 4px 16px rgba(124,58,237,0.2)}
  50%{box-shadow:0 4px 24px rgba(167,139,250,0.45),0 0 60px rgba(124,58,237,0.15)}
  100%{box-shadow:0 4px 16px rgba(124,58,237,0.2)}
}
.loop-glow{animation:glowLoop 4s ease-in-out infinite}

/* ── Botón usuario logueado — naranja ── */
.btn.is-logged-in,
.btn-primary.is-logged-in,
button.is-logged-in,
#loginBtn.is-logged-in,
#loginButton.is-logged-in,
[data-login-btn].is-logged-in{
  background:linear-gradient(135deg,#ff6b00,#ff8f3d)!important;
  box-shadow:0 4px 16px rgba(255,107,0,0.25),0 2px 6px rgba(255,107,0,0.15)!important;
  border-color:transparent!important;
  animation:none!important;
}
.btn.is-logged-in:hover,
.btn-primary.is-logged-in:hover,
button.is-logged-in:hover,
#loginBtn.is-logged-in:hover,
#loginButton.is-logged-in:hover,
[data-login-btn].is-logged-in:hover{
  background:linear-gradient(135deg,#ff8000,#ffa65d)!important;
  box-shadow:0 8px 24px rgba(255,107,0,0.35),0 4px 10px rgba(255,107,0,0.2)!important;
  transform:translateY(-2px);
}
.btn.is-logged-in i,
button.is-logged-in i{margin-right:.35rem}

/* ── Navbar móvil ── */
@media(max-width:768px){
  .nav-toggle{display:block}
  .nav-inner{width:90%;padding:.7rem 0}
  .nav-links{
    position:fixed;top:56px;left:0;right:0;
    background:linear-gradient(135deg,rgba(26,5,53,0.97),rgba(48,12,90,0.94));
    backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);
    flex-direction:column;padding:1.25rem;gap:.6rem;
    border-bottom:1px solid rgba(138,11,210,0.25);
    box-shadow:0 12px 40px rgba(138,11,210,0.12);
    transform:translateY(-110%);opacity:0;visibility:hidden;
    transition:all .35s var(--ease);
  }
  .nav-links.is-open{transform:translateY(0);opacity:1;visibility:visible}
  .nav-links a{width:100%;text-align:center;padding:.75rem 1rem;font-size:1rem}
  .nav-links .btn{width:100%;margin-top:.4rem}
}

/* ============================================
   HERO
   ============================================ */
.hero{
  position:relative;
  overflow:hidden;
  padding:3rem 0 2.5rem;
}
.hero-inner{
  width:95%;max-width:1600px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:2.5rem;
  flex-wrap:wrap;
}
.hero-content{flex:1;min-width:300px}
.hero-particles{
  position:absolute;inset:0;pointer-events:none;overflow:hidden;
}
@keyframes floatUp{
  0%{transform:translateY(0) scale(1);opacity:0}
  10%{opacity:1}
  90%{opacity:1}
  100%{transform:translateY(-100vh) scale(.5);opacity:0}
}
.hero-particle{
  position:absolute;border-radius:50%;
  animation:floatUp linear infinite;
}

/* Pill */
.hero-pill{
  display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(138,11,210,0.15);
  border:1px solid rgba(138,11,210,0.3);
  border-radius:999px;padding:.4rem 1rem;
  font-size:.8rem;color:var(--accent-soft);margin-bottom:1rem;
}
.hero-pill-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--green);
  animation:pulse 2s infinite;
}

/* Title */
.hero-title{
  font-size:clamp(1.8rem,4vw,3rem);font-weight:800;
  line-height:1.15;margin-bottom:.8rem;
  color:var(--text);
}
.hero-title span{
  background:linear-gradient(135deg,var(--accent-soft),var(--orange));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.hero-typing-cursor{
  display:inline-block;width:2px;height:1em;
  background:var(--accent-soft);margin-left:2px;
  animation:pulse 1s step-end infinite;
  vertical-align:text-bottom;
}

.hero-subtitle{
  font-size:1.05rem;color:var(--muted);
  max-width:520px;margin-bottom:1.5rem;line-height:1.6;
}

.hero-actions{display:flex;gap:.8rem;flex-wrap:wrap;margin-bottom:1.5rem}
.hero-actions .btn{gap:.5rem}
.hero-actions .btn img{width:18px;height:18px;filter:brightness(0) invert(1)}

/* Feature pills */
.hero-features{display:flex;gap:.6rem;flex-wrap:wrap}
.hero-feature{
  display:inline-flex;align-items:center;gap:.35rem;
  font-size:.75rem;color:var(--muted);
  background:rgba(138,11,210,0.08);
  border:1px solid rgba(138,11,210,0.15);
  border-radius:999px;padding:.3rem .75rem;
}
.hero-feature img{width:14px;height:14px;opacity:.8;filter:brightness(0) invert(1)}

/* Logo section */
.hero-logo-section{
  display:flex;flex-direction:column;align-items:center;gap:1.2rem;
  flex-shrink:0;
}
.hero-logo-img{
  width:clamp(180px,25vw,320px);
  height:auto;
  filter:drop-shadow(0 0 40px rgba(138,11,210,0.3));
  animation:pulse 4s ease-in-out infinite;
}
.hero-stats{
  display:flex;gap:1.2rem;
}
.hero-stat{
  display:flex;flex-direction:column;align-items:center;gap:.15rem;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  padding:.6rem .9rem;min-width:72px;
  transition:all .3s;
}
.hero-stat:hover{
  border-color:var(--border-h);
  transform:translateY(-2px);
}
.hero-stat img{width:20px;height:20px;opacity:.85;filter:brightness(0) invert(1) sepia(1) saturate(5) hue-rotate(250deg)}
.hero-stat strong{font-size:1rem;color:var(--text)}
.hero-stat span{font-size:.65rem;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}

@media(max-width:768px){
  .hero-inner{flex-direction:column;text-align:center;gap:1.5rem}
  .hero-content{min-width:auto}
  .hero-subtitle{margin-left:auto;margin-right:auto}
  .hero-actions{justify-content:center}
  .hero-features{justify-content:center}
  .hero-logo-img{width:180px}
  .hero-stats{gap:.6rem}
}

/* ============================================
   LAYOUT PRINCIPAL (single column — no sidebars)
   ============================================ */
.layout{
  width:95%;max-width:1600px;margin:1.5rem auto;
}

/* ============================================
   CATÁLOGO CENTER
   ============================================ */
.content-center{min-width:0}

.catalog-header{
  display:flex;align-items:center;justify-content:space-between;
  gap:1rem;margin-bottom:.8rem;flex-wrap:wrap;
}
.catalog-heading{
  display:flex;align-items:center;gap:.6rem;
}
.catalog-heading-icon{
  width:28px;height:28px;display:flex;align-items:center;justify-content:center;
  color:var(--accent-soft);
}
.catalog-heading-icon svg{width:20px;height:20px;stroke:currentColor;stroke-width:2;fill:none}
.catalog-title{
  font-size:1.15rem;font-weight:700;color:var(--text);
}
.catalog-title span{
  background:linear-gradient(135deg,var(--accent-soft),var(--orange));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}

.catalog-actions{display:flex;gap:.6rem;align-items:center}
.btn-reload{
  padding:.4rem .8rem;border-radius:999px;
  background:rgba(138,11,210,0.1);
  border:1px solid rgba(138,11,210,0.2);
  color:var(--accent-soft);font-size:.78rem;font-weight:600;
  transition:all .25s;
}
.btn-reload:hover{
  background:rgba(138,11,210,0.2);border-color:var(--accent);
  color:#fff;transform:translateY(-1px);
}

/* ============================================
   FILTER BAR (horizontal — replaces sidebars)
   ============================================ */
.filter-bar{
  display:flex;align-items:center;gap:.6rem;
  margin-bottom:1rem;
  flex-wrap:wrap;
}
.filter-group{
  display:flex;align-items:center;gap:.35rem;
  flex-wrap:wrap;
}
.filter-type{
  padding-right:.6rem;
  border-right:1px solid var(--border);
  margin-right:.2rem;
}
.filter-pill{
  display:inline-flex;align-items:center;gap:.3rem;
  padding:.4rem .85rem;border-radius:999px;
  background:var(--surface);
  border:1px solid var(--border);
  color:var(--muted);
  font-size:.78rem;font-weight:600;
  cursor:pointer;
  transition:all .25s;
  white-space:nowrap;
}
.filter-pill:hover{
  background:rgba(138,11,210,0.12);
  border-color:rgba(138,11,210,0.3);
  color:var(--text);
}
.filter-pill.active{
  background:var(--accent);
  border-color:var(--accent);
  color:#fff;
  box-shadow:0 2px 12px rgba(138,11,210,0.3);
}
.filter-pill .cat-count{
  font-size:.65rem;font-weight:700;
  background:rgba(255,255,255,0.15);
  padding:.1rem .35rem;border-radius:999px;
  min-width:18px;text-align:center;
}
.filter-pill.active .cat-count{
  background:rgba(255,255,255,0.25);
  color:#fff;
}
/* Free pill active */
.filter-free.active{
  background:var(--green);border-color:var(--green);
  box-shadow:0 2px 12px rgba(16,185,129,0.3);
}
/* Premium pill active */
.filter-premium.active{
  background:var(--orange);border-color:var(--orange);
  box-shadow:0 2px 12px rgba(249,115,22,0.3);
}

/* Category pills inside filter-cats */
.filter-cats a,
.filter-cats .category-link{
  display:inline-flex;align-items:center;gap:.3rem;
  padding:.35rem .7rem;border-radius:999px;
  background:var(--surface);
  border:1px solid var(--border);
  color:var(--muted);
  font-size:.72rem;font-weight:500;
  cursor:pointer;
  transition:all .25s;
  white-space:nowrap;
  text-decoration:none;
}
.filter-cats a:hover,
.filter-cats .category-link:hover{
  background:rgba(138,11,210,0.12);
  border-color:rgba(138,11,210,0.3);
  color:var(--text);
}
.filter-cats a.active,
.filter-cats .category-link.active{
  background:rgba(138,11,210,0.2);
  border-color:var(--accent);
  color:var(--accent-soft);
}
.cat-count{
  font-size:.65rem;font-weight:600;
  color:var(--accent-soft);
  background:rgba(138,11,210,0.1);
  padding:.1rem .35rem;border-radius:999px;
  min-width:18px;text-align:center;
}

/* Search */
.center-search{
  display:flex;gap:.4rem;margin-bottom:.8rem;
}
.center-search-input-wrap{flex:1}
.center-search-input-wrap input{
  width:100%;padding:.55rem .9rem;border-radius:var(--radius-sm);
  border:1px solid var(--border);
  background:var(--surface);color:var(--text);
  font-size:.88rem;outline:none;
  transition:border-color .3s;
}
.center-search-input-wrap input:focus{border-color:var(--accent)}
.center-search-input-wrap input::placeholder{color:var(--muted)}
.center-search-btn{
  width:42px;height:42px;border-radius:var(--radius-sm);
  background:var(--accent);
  display:flex;align-items:center;justify-content:center;
  color:#fff;transition:all .25s;border:none;
  flex-shrink:0;
}
.center-search-btn:hover{background:var(--accent-soft);transform:translateY(-1px)}
.center-search-btn svg{width:18px;height:18px}

/* ── Catálogo Grid (full width — no sidebars) ── */
.catalogo-scroll{overflow:visible}
.catalogo-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:1rem;
}

/* ── Paginación ── */
.pagination{
  display:flex;justify-content:center;gap:.4rem;
  margin-top:1rem;padding:.5rem 0;flex-wrap:wrap;
}
.page-pill{
  padding:.4rem .8rem;border-radius:999px;
  background:var(--surface);border:1px solid var(--border);
  color:var(--muted);font-size:.8rem;font-weight:500;
  transition:all .25s;cursor:pointer;
}
.page-pill:hover{border-color:var(--accent);color:var(--text)}
.page-pill.is-active{
  background:var(--accent);border-color:var(--accent);color:#fff;
}

/* ============================================
   CATALOG CARDS — UIverse Glass Orb Style
   (same visual as producto.css pd-rel-card)
   ============================================ */

/* ---- Card container ---- */
.catalog-card{
  position:relative;
  border:1px solid rgba(255,255,255,0.12);
  border-radius:16px;
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .4s;
}

/* Purple accent layer (behind everything) */
.catalog-card::before{
  content:'';position:absolute;
  inset:0;
  background:rgba(138,11,210,0.5);
  z-index:0;
}

/* Shaped cutout over the purple (UIverse card style) */
.catalog-card::after{
  content:'';position:absolute;
  top:3px;left:3px;right:3px;bottom:3px;
  border-radius:13px 60px 13px 13px;
  background:rgba(22,10,50,0.85);
  z-index:0;
}

.catalog-card:hover{
  transform:translateY(-6px);
  box-shadow:
    0 20px 50px rgba(0,0,0,0.3),
    0 0 30px rgba(138,11,210,0.15);
  border-color:rgba(255,255,255,0.2);
}

/* Badge */
.catalog-discount-badge{
  position:absolute;top:8px;right:8px;z-index:5;
  padding:.2rem .5rem;border-radius:999px;
  font-size:.65rem;font-weight:700;color:#fff;
}

/* ---- Card Image (visual area) ---- */
.card-image-link{
  display:block;text-decoration:none;
  position:relative;z-index:1;
}
.card-image{
  position:relative;
  overflow:hidden;
  background:rgba(0,0,0,0.1);
}
/* Gradient overlay on hover */
.card-image::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(13,6,32,0.65) 100%);
  opacity:0;transition:opacity .4s var(--ease);pointer-events:none;
  z-index:1;
}
.catalog-card:hover .card-image::after{opacity:1}

.design-card-img-wrapper{width:100%;position:relative}
.design-card-img-wrapper img{
  width:100%;height:auto;display:block;
  transition:transform .6s var(--ease);
}
.catalog-card:hover .design-card-img-wrapper img{
  transform:scale(1.05);
}

/* ---- Card Content (glass body) ---- */
.card-content{
  padding:.85rem .95rem .3rem;
  position:relative;z-index:1;
  background:rgba(245,243,255,0.04);
  border-top:1px solid rgba(255,255,255,0.06);
}
.card-title{
  font-size:.85rem;font-weight:600;line-height:1.35;margin:0;
  color:rgba(212,200,240,0.95);
  overflow:hidden;text-overflow:ellipsis;
  display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;
  transition:color .3s;
}
.card-title-link{
  color:inherit;text-decoration:none;transition:color .3s;
}
.catalog-card:hover .card-title-link{color:#fff}

/* ---- Card Price / Button area ---- */
.card-price-container{
  padding:.55rem .95rem .95rem;
  position:relative;z-index:1;
  margin-top:auto;
}

/* Precio premium (amber pill) */
.card-price-large{
  display:flex;align-items:center;justify-content:center;gap:.3rem;
  width:100%;text-align:center;
  padding:.55rem .75rem;border-radius:10px;
  font-size:.88rem;font-weight:700;
  transition:all .3s var(--ease);
}
.card-price-premium{
  background:rgba(245,243,255,0.06);
  color:rgba(251,191,36,0.9);
  border:1px solid rgba(255,255,255,0.08);
}
.card-price-premium:hover{
  background:rgba(245,243,255,0.1);
  border-color:rgba(255,255,255,0.14);
}

/* Download button — Uiverse shine style */
.card-download-btn{
  display:flex;align-items:center;justify-content:center;gap:.45rem;
  width:100%;padding:.5rem .75rem;
  border-radius:9999px;
  font-size:.8rem;font-weight:700;cursor:pointer;
  color:#fff;border:3px solid rgba(255,255,255,0.3);
  transition:all .3s ease-in-out;
  position:relative;overflow:hidden;
  box-shadow:0 6px 16px rgba(0,0,0,0.25);
  outline:none;
}
/* Shine sweep */
.card-download-btn::before{
  content:"";position:absolute;
  width:80px;height:100%;
  background-image:linear-gradient(120deg,rgba(255,255,255,0) 30%,rgba(255,255,255,0.7),rgba(255,255,255,0) 70%);
  top:0;left:-80px;opacity:.6;
}
.card-download-btn:hover{
  transform:scale(1.05);
  border-color:rgba(255,255,255,0.6);
}
.card-download-btn:hover::before{
  animation:cardBtnShine 1.5s ease-out infinite;
}
.card-download-btn:active{transform:scale(.98);transition-duration:.1s}
.card-download-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}

/* Free (green) */
.card-download-free{
  background:rgba(16,185,129,0.6);
}
.card-download-free:hover{
  box-shadow:0 8px 24px rgba(16,185,129,0.25);
}

/* Premium download (purple) */
.card-download-premium{
  background:rgba(138,11,210,0.6);
}
.card-download-premium:hover{
  box-shadow:0 8px 24px rgba(138,11,210,0.3);
}

/* Gift (purchased) */
.card-download-gift{
  background:rgba(138,11,210,0.5);
}

/* Shine icon nudge */
.card-download-btn:hover i{transform:translateX(3px);transition:transform .3s ease-in-out}

@keyframes cardBtnShine{
  0%{left:-80px}
  60%{left:100%}
  to{left:100%}
}

/* Descuento */
.card-price-section{
  display:flex;flex-direction:column;align-items:center;gap:.1rem;
  margin-bottom:.3rem;
}
.card-price-original{
  font-size:.7rem;color:var(--muted);
  text-decoration:line-through;
}
.card-price-final{
  font-size:.9rem;font-weight:700;color:var(--green);
}
.card-price-save{
  font-size:.65rem;color:var(--orange);font-weight:600;
}



/* ============================================
   EQUIPO CREATIVO
   ============================================ */
.team{
  width:95%;max-width:1600px;margin:1.5rem auto;
}
.team-inner{
  background:var(--surface);
  border-radius:var(--radius);
  border:1px solid var(--border);
  padding:1.25rem 1.5rem;
}
.team-top{
  display:flex;align-items:baseline;gap:1rem;
  margin-bottom:1rem;flex-wrap:wrap;
}
.team-header{
  font-size:1.1rem;font-weight:700;color:var(--text);margin:0;
}
.team-header span{
  background:linear-gradient(135deg,#ff8c42,#ff6b6b);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.team-subtitle{font-size:.8rem;color:var(--muted);margin:0}
.team-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;
}
.team-card{
  display:flex;align-items:center;gap:.7rem;
  background:rgba(10,5,20,0.5);
  border:1px solid rgba(138,11,210,0.12);
  border-radius:var(--radius-sm);
  padding:.7rem .85rem;transition:all .25s;
}
.team-card:hover{
  background:rgba(124,58,237,0.12);
  border-color:rgba(138,11,210,0.3);
  transform:translateY(-2px);
}
.team-avatar{
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,rgba(124,58,237,0.25),rgba(167,139,250,0.15));
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;color:var(--accent-soft);
}
.team-info{flex:1;min-width:0;display:flex;flex-direction:column}
.team-name{
  font-size:.88rem;font-weight:600;color:var(--text);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.team-role-tag{
  font-size:.68rem;color:var(--muted);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.team-socials{display:flex;gap:.35rem;flex-shrink:0}
.team-socials a{
  width:30px;height:30px;border-radius:8px;
  background:rgba(124,58,237,0.1);
  border:1px solid rgba(124,58,237,0.2);
  display:flex;align-items:center;justify-content:center;
  color:var(--accent-soft);transition:all .2s;
}
.team-socials a:hover{
  background:rgba(124,58,237,0.25);border-color:var(--accent);
  transform:scale(1.1);color:#fff;
}
@media(max-width:860px){
  .team-grid{grid-template-columns:1fr;gap:.5rem}
  .team-top{flex-direction:column;gap:.25rem;text-align:center}
}

/* ============================================
   FOOTER
   ============================================ */
.footer{
  border-top:1px solid var(--border);
  padding:1rem 0;
  margin-top:1.5rem;
}
.footer-inner{
  width:92%;max-width:1200px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:.8rem;
  font-size:.82rem;color:var(--muted);
}
.footer-inner a{color:var(--muted);transition:color .2s;margin-left:.8rem}
.footer-inner a:hover{color:var(--text)}

/* ============================================
   WHATSAPP FLOAT
   ============================================ */
.whatsapp-float{
  position:fixed;bottom:25px;right:25px;
  width:60px;height:60px;
  background:linear-gradient(135deg,#25D366,#128C7E);
  color:#fff;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,0.4);
  z-index:9999;transition:all .4s cubic-bezier(.68,-.55,.265,1.55);
  cursor:pointer;text-decoration:none;
  animation:slideInBounce .8s cubic-bezier(.68,-.55,.265,1.55) .5s both,float-bounce 3s ease-in-out infinite 1.5s,pulse-ring 2s infinite 1.5s;
}
.whatsapp-float::before{
  content:'';position:absolute;width:100%;height:100%;
  border-radius:50%;background:rgba(37,211,102,0.3);
  animation:ripple 2s infinite;z-index:-1;
}
.whatsapp-float:hover{
  transform:scale(1.15) rotate(5deg);
  box-shadow:0 8px 35px rgba(37,211,102,0.7);
}
.whatsapp-float svg{
  width:32px;height:32px;
  filter:drop-shadow(0 2px 4px rgba(0,0,0,0.2));
}
.whatsapp-tooltip{
  position:absolute;right:70px;
  background:#fff;color:#1f2937;
  padding:10px 18px;border-radius:12px;
  font-size:14px;font-weight:500;white-space:nowrap;
  box-shadow:0 4px 20px rgba(0,0,0,0.2);
  opacity:0;pointer-events:none;
  transform:translateX(10px);
  transition:all .3s cubic-bezier(.68,-.55,.265,1.55);
}
.whatsapp-tooltip::after{
  content:'';position:absolute;right:-6px;top:50%;
  transform:translateY(-50%);
  border-left:6px solid #fff;
  border-top:6px solid transparent;
  border-bottom:6px solid transparent;
}
.whatsapp-float:hover .whatsapp-tooltip{opacity:1;transform:translateX(0) scale(1)}
@keyframes float-bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes ripple{0%{transform:scale(1);opacity:.8}50%{transform:scale(1.3);opacity:.4}100%{transform:scale(1.6);opacity:0}}
@keyframes pulse-ring{0%,100%{box-shadow:0 4px 20px rgba(37,211,102,0.4)}50%{box-shadow:0 4px 35px rgba(37,211,102,0.8),0 0 0 10px rgba(37,211,102,0.2)}}
@keyframes slideInBounce{0%{transform:translateY(100px) scale(.5) rotate(-180deg);opacity:0}60%{transform:translateY(-10px) scale(1.1) rotate(10deg);opacity:1}80%{transform:translateY(5px) scale(.95) rotate(-5deg)}100%{transform:translateY(0) scale(1) rotate(0);opacity:1}}
@media(max-width:768px){
  .whatsapp-float{width:56px;height:56px;bottom:20px;right:20px}
  .whatsapp-float svg{width:28px;height:28px}
  .whatsapp-tooltip{display:none}
}

/* ============================================
   RESPONSIVE GLOBAL
   ============================================ */
@media(max-width:480px){
  .hero{padding:2rem 0 1.5rem}
  .hero-inner{width:90%}
  .hero-title{font-size:1.5rem}
  .hero-subtitle{font-size:.9rem}
  .layout{width:96%}
  .filter-bar{gap:.4rem}
  .filter-type{border-right:none;padding-right:0;margin-right:0}
  .filter-pill{padding:.3rem .6rem;font-size:.72rem}
  .filter-cats a,.filter-cats .category-link{padding:.28rem .5rem;font-size:.66rem}
  .catalogo-grid{grid-template-columns:repeat(2,1fr)!important;gap:.5rem}
  /* Glass Orb cards mobile */
  .catalog-card{border-radius:12px}
  .catalog-card::after{top:2px;left:2px;right:2px;bottom:2px;border-radius:10px 35px 10px 10px}
  .card-content{padding:.55rem .6rem .2rem}
  .card-title{font-size:.76rem}
  .card-price-container{padding:.4rem .6rem .7rem}
  .card-download-btn,.card-price-large{padding:.42rem .55rem;font-size:.73rem;border-radius:7px}
  .team{width:90%}
  .footer-inner{flex-direction:column;text-align:center;gap:.5rem}
}
