/* =============================================
   SECTIONS — Hero, Characters, Features, Sets,
   Pricing, Community, Footer
   opcartas
============================================= */

/* ── HERO ── */
#hero {
  position: relative;
  min-height: 45vh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  padding-top: var(--header-h);
  text-align: center;
}
.hero-bg {
  position: absolute; inset: 0;
  background-image: url('../../imagenes/one-piece-artwork_3840x2160_xtrafondos.com.jpg');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  z-index: 0;
}
.hero-bg::after {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 100% at 0% 50%, rgba(11,11,12,0.95) 0%, transparent 70%),
    radial-gradient(ellipse 60% 100% at 100% 50%, rgba(11,11,12,0.95) 0%, transparent 70%),
    linear-gradient(to bottom, rgba(11,11,12,0.3) 0%, rgba(11,11,12,0.75) 60%, rgba(11,11,12,1) 100%);
  z-index: 1;
}
.hero-grid {
  display: none;
}
.hero-orb { position: absolute; border-radius: 50%; filter: blur(80px); animation: floatOrb 8s ease-in-out infinite; pointer-events: none; }
.hero-orb-1 { width: 500px; height: 350px; background: rgba(230,57,70,0.1); top: -80px; right: -50px; }
.hero-orb-2 { width: 380px; height: 380px; background: rgba(212,175,55,0.07); bottom: -60px; left: -50px; animation-delay: -4s; }
@keyframes floatOrb {
  0%,100% { transform: translate(0,0) scale(1); }
  33% { transform: translate(25px,-18px) scale(1.05); }
  66% { transform: translate(-18px,13px) scale(0.97); }
}
.hero-cards { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.hero-card-img {
  position: absolute; border-radius: 10px;
  box-shadow: 0 16px 48px rgba(0,0,0,0.7);
  border: 2px solid rgba(212,175,55,0.2);
  opacity: 0; animation: heroCardFloat 12s ease-in-out infinite;
  object-fit: cover; object-position: top center;
  background: var(--c-dark-3);
}
.hero-card-img:nth-child(1) { width:120px;height:160px;top:14%;left:2%;animation-delay:0s;animation-duration:14s }
.hero-card-img:nth-child(2) { width:100px;height:135px;top:58%;left:5%;animation-delay:-3s;animation-duration:11s }
.hero-card-img:nth-child(3) { width:115px;height:150px;top:18%;right:2%;animation-delay:-5s;animation-duration:13s }
.hero-card-img:nth-child(4) { width:95px;height:128px;top:62%;right:6%;animation-delay:-8s;animation-duration:10s }
.hero-card-img:nth-child(5) { width:108px;height:144px;top:78%;left:18%;animation-delay:-2s;animation-duration:15s }
.hero-card-img:nth-child(6) { width:98px;height:130px;top:8%;right:17%;animation-delay:-6s;animation-duration:12s }
@media(max-width:768px){ .hero-card-img { display: none; } }
@keyframes heroCardFloat {
  0% { opacity:0; transform:translateY(28px) rotate(-2deg); }
  10% { opacity:0.65; }
  50% { transform:translateY(-14px) rotate(1deg); }
  90% { opacity:0.55; }
  100% { opacity:0; transform:translateY(22px) rotate(-1deg); }
}
.hero-content {
  position: relative; z-index: 2;
  padding: var(--sp-6) var(--sp-5);
  max-width: 900px;
  margin-inline: auto;
  display: flex; flex-direction: column; align-items: center;
}
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  background: rgba(212,175,55,0.08); border: 1px solid var(--c-border-gold);
  border-radius: 100px; padding: 6px 16px;
  font-size: 0.7rem; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--c-gold); margin-bottom: var(--sp-5);
  animation: fadeInUp 0.6s ease forwards;
}
.hero-title {
  font-family: var(--font-head);
  font-size: clamp(2rem, 4.5vw, 4rem);
  line-height: 1.1;
  font-weight: 900; line-height: 1.06; letter-spacing: -0.02em;
  margin-bottom: var(--sp-5);
  animation: fadeInUp 0.7s 0.1s ease both;
}
.hero-title .accent-red { color: var(--c-red); }
.hero-title .accent-gold { color: var(--c-gold); }
.hero-sub {
  font-family: var(--font-head);
  font-weight: 400;        /* más fino */
  letter-spacing: 0.08em;  /* más espaciado */
  font-size: clamp(0.85rem, 1.5vw, 1rem);  /* más pequeño */
}
.hero-cta {
  display: flex; flex-wrap: wrap; gap: var(--sp-3);
  justify-content: center; margin-bottom: var(--sp-7);
  animation: fadeInUp 0.7s 0.3s ease both;
}
.hero-cta .btn { min-width: 150px; }
.hero-stats {
  display: flex; flex-wrap: wrap; gap: var(--sp-5);
  justify-content: center;
  animation: fadeInUp 0.7s 0.4s ease both;
}
.hero-stat-num { font-family: var(--font-head); font-size: 1.6rem; font-weight: 700; color: var(--c-gold); line-height: 1; }
.hero-stat-label { font-size: 0.68rem; color: var(--c-muted); margin-top: 4px; text-transform: uppercase; letter-spacing: 0.08em; }
.hero-stat-divider { width: 1px; background: var(--c-border); align-self: stretch; }

.scroll-dot { width: 3px; height: 6px; background: var(--c-gold); border-radius: 2px; animation: scrollDot 2s ease infinite; }
.scroll-label { font-size: 9px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--c-muted); }
@keyframes scrollDot { 0%,100%{transform:translateY(0);opacity:1} 80%{transform:translateY(8px);opacity:0} }
@keyframes fadeInUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }

/* ── CHARACTER STRIP ── */
#chars-strip { padding: var(--sp-7) 0 var(--sp-8); overflow: hidden; position: relative; }
#chars-strip::before, #chars-strip::after { content:''; position:absolute; top:0; bottom:0; width:100px; z-index:2; pointer-events:none; }
#chars-strip::before { left:0; background:linear-gradient(90deg,var(--c-black),transparent); }
#chars-strip::after { right:0; background:linear-gradient(270deg,var(--c-black),transparent); }
.chars-label { text-align: center; margin-bottom: var(--sp-4); }
.chars-label .section-label { justify-content: center; }
.chars-label .section-label::before { display: none; }
.chars-track-wrap { overflow: hidden; }
.chars-track { display: flex; gap: var(--sp-3); animation: scrollChars 50s linear infinite; width: max-content; }
.chars-track:hover { animation-play-state: paused; }
@keyframes scrollChars { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.char-card { flex-shrink:0; width:155px; background:var(--c-dark); border:1px solid var(--c-border); border-radius:var(--radius-lg); overflow:hidden; transition:all var(--t-base); cursor:pointer; }
.char-card:hover { border-color:var(--c-border-gold); transform:translateY(-6px) scale(1.04); box-shadow:var(--shadow-gold); }
.char-card-img { width:100%; height:195px; object-fit:cover; object-position:top center; background:var(--c-dark-3); transition:transform var(--t-slow); }
.char-card:hover .char-card-img { transform: scale(1.07); }
.char-card-info { padding: var(--sp-3); }
.char-card-name { font-family:var(--font-head); font-size:0.76rem; font-weight:600; color:var(--c-white); margin-bottom:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.char-card-role { font-size: 0.68rem; color: var(--c-muted); }

/* ── FEATURES ── */
#features { padding: var(--sp-9) 0; }
.features-header { text-align:center; margin-bottom:var(--sp-7); }
.features-header .section-label { justify-content:center; }
.features-header .section-label::before { display:none; }
.features-header .section-subtitle { margin-inline:auto; text-align:center; }
.features-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:var(--sp-4); }
.feature-card { background:var(--c-dark); border:1px solid var(--c-border); border-radius:var(--radius-lg); padding:var(--sp-5); transition:all var(--t-base); position:relative; overflow:hidden; }
.feature-card::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,var(--c-gold-glow),transparent 60%); opacity:0; transition:opacity var(--t-base); }
.feature-card:hover { border-color:var(--c-border-gold); transform:translateY(-4px); box-shadow:var(--shadow-gold); }
.feature-card:hover::before { opacity:1; }
.feature-icon { width:44px; height:44px; background:rgba(212,175,55,0.1); border:1px solid var(--c-border-gold); border-radius:var(--radius-md); display:flex; align-items:center; justify-content:center; margin-bottom:var(--sp-4); color:var(--c-gold); transition:all var(--t-base); }
.feature-card:hover .feature-icon { background:rgba(212,175,55,0.18); box-shadow:var(--shadow-gold); }
.feature-title { font-family:var(--font-head); font-size:0.9rem; font-weight:600; color:var(--c-white); margin-bottom:var(--sp-2); position:relative; }
.feature-desc { font-size:0.82rem; color:var(--c-muted); line-height:1.65; position:relative; }

/* ── SETS ── */
#sets { padding:var(--sp-9) 0; background:var(--c-dark); position:relative; overflow:hidden; }
#sets::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,var(--c-border-gold),transparent); }
.sets-header { display:flex; align-items:flex-end; justify-content:space-between; flex-wrap:wrap; gap:var(--sp-4); margin-bottom:var(--sp-6); }
.sets-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:var(--sp-4); }
.set-card { border-radius:var(--radius-lg); overflow:hidden; position:relative; aspect-ratio:3/4; cursor:pointer; transition:all var(--t-base); }
.set-card:hover { transform:translateY(-7px) scale(1.025); box-shadow:var(--shadow-gold); }
.set-card-bg { position:absolute; inset:0; background-size:cover; background-position:center top; transition:transform var(--t-slow); }
.set-card:hover .set-card-bg { transform:scale(1.08); }
.set-card-overlay { position:absolute; inset:0; background:linear-gradient(0deg,rgba(11,11,12,0.97) 0%,rgba(11,11,12,0.48) 45%,rgba(11,11,12,0.06) 100%); transition:background var(--t-base); }
.set-card:hover .set-card-overlay { background:linear-gradient(0deg,rgba(11,11,12,0.98) 0%,rgba(11,11,12,0.65) 55%,rgba(11,11,12,0.16) 100%); }
.set-card-content { position:absolute; bottom:0; left:0; right:0; padding:var(--sp-4); }
.set-badge { display:inline-block; padding:3px 10px; border-radius:100px; font-size:9.5px; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; background:rgba(212,175,55,0.15); border:1px solid var(--c-border-gold); color:var(--c-gold); margin-bottom:var(--sp-2); }
.set-name { font-family:var(--font-head); font-size:0.9rem; font-weight:700; color:var(--c-white); margin-bottom:4px; line-height:1.2; }
.set-date { font-size:0.7rem; color:var(--c-muted); }
.set-card-hover-info { position:absolute; top:var(--sp-3); right:var(--sp-3); opacity:0; transform:translateY(-4px); transition:all var(--t-base); }
.set-card:hover .set-card-hover-info { opacity:1; transform:translateY(0); }
.set-info-pill { background:rgba(212,175,55,0.15); border:1px solid var(--c-border-gold); border-radius:100px; padding:3px 9px; font-size:10px; color:var(--c-gold); font-weight:600; }
.set-op01 .set-card-bg { background-color:#2a1020; }
.set-op02 .set-card-bg { background-color:#10102a; }
.set-op03 .set-card-bg { background-color:#102018; }
.set-op04 .set-card-bg { background-color:#281808; }
.set-op05 .set-card-bg { background-color:#18102a; }
.set-op06 .set-card-bg { background-color:#102828; }

/* ── PRICING ── */
#pricing { padding:var(--sp-9) 0; position:relative; overflow:hidden; }
#pricing::before { content:''; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:700px; height:500px; background:radial-gradient(ellipse,rgba(212,175,55,0.04),transparent 70%); pointer-events:none; }
.pricing-header { text-align:center; margin-bottom:var(--sp-7); }
.pricing-header .section-label { justify-content:center; }
.pricing-header .section-label::before { display:none; }
.pricing-header .section-subtitle { margin-inline:auto; text-align:center; }
.pricing-toggle { display:flex; align-items:center; justify-content:center; gap:var(--sp-3); margin-top:var(--sp-5); }
.toggle-label { font-size:0.875rem; color:var(--c-muted); cursor:pointer; transition:color var(--t-fast); }
.toggle-label.active { color:var(--c-white); }
.toggle-switch { width:44px; height:23px; background:var(--c-dark-3); border:1px solid var(--c-border); border-radius:100px; position:relative; cursor:pointer; transition:background var(--t-base); }
.toggle-switch.on { background:var(--c-gold); }
.toggle-switch::after { content:''; position:absolute; top:3px; left:3px; width:15px; height:15px; background:white; border-radius:50%; transition:transform var(--t-base); }
.toggle-switch.on::after { transform:translateX(21px); }
.save-badge { padding:3px 10px; background:rgba(230,57,70,0.15); border:1px solid rgba(230,57,70,0.3); border-radius:100px; font-size:11px; font-weight:600; color:var(--c-red); }
.pricing-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:var(--sp-5); max-width:720px; margin-inline:auto; }
.price-card { border-radius:var(--radius-xl); padding:var(--sp-6) var(--sp-5); position:relative; transition:all var(--t-base); }
.price-card-free { background:var(--c-dark); border:1px solid var(--c-border); }
.price-card-free:hover { border-color:rgba(255,255,255,0.12); transform:translateY(-2px); }
.price-card-pro { background:linear-gradient(145deg,var(--c-dark-2),var(--c-dark)); border:1px solid var(--c-border-gold); box-shadow:var(--shadow-gold); }
.price-card-pro:hover { transform:translateY(-4px); }
.pro-badge { position:absolute; top:-13px; left:50%; transform:translateX(-50%); background:linear-gradient(90deg,var(--c-gold),var(--c-gold-light)); color:var(--c-black); font-size:10.5px; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; padding:4px 14px; border-radius:100px; white-space:nowrap; }
.plan-name { font-family:var(--font-head); font-size:0.95rem; font-weight:600; color:var(--c-muted); margin-bottom:var(--sp-4); }
.price-card-pro .plan-name { color:var(--c-gold); }
.plan-price { display:flex; align-items:flex-end; gap:3px; margin-bottom:var(--sp-2); }
.price-amount { font-family:var(--font-head); font-size:2.7rem; font-weight:900; color:var(--c-white); line-height:1; }
.price-currency { font-size:1.1rem; font-weight:600; color:var(--c-muted); margin-bottom:6px; }
.price-period { font-size:0.8rem; color:var(--c-muted); margin-bottom:4px; }
.plan-desc { font-size:0.8rem; color:var(--c-muted); margin-bottom:var(--sp-4); padding-bottom:var(--sp-4); border-bottom:1px solid var(--c-border); }
.plan-features { display:flex; flex-direction:column; gap:10px; margin-bottom:var(--sp-5); }
.plan-feature { display:flex; align-items:center; gap:10px; font-size:0.82rem; color:rgba(255,255,255,0.75); }
.plan-feature svg { flex-shrink:0; }
.plan-feature.disabled { color:var(--c-muted); }
.plan-feature.disabled svg { color:rgba(138,138,154,0.4); }
.plan-cta { width:100%; }

/* ── COMMUNITY ── */
#community { padding:var(--sp-9) 0; position:relative; overflow:hidden; }
.community-inner { background:linear-gradient(135deg,#1a0608,#0b0b0c 50%,#1a1006); border:1px solid rgba(230,57,70,0.2); border-radius:var(--radius-xl); padding:var(--sp-9) var(--sp-6); text-align:center; position:relative; overflow:hidden; }
.community-inner::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 60% 80% at 20% 50%,rgba(230,57,70,0.08),transparent 60%),radial-gradient(ellipse 60% 80% at 80% 50%,rgba(212,175,55,0.06),transparent 60%); pointer-events:none; }
.community-icon { font-size:2.6rem; margin-bottom:var(--sp-4); position:relative; }
.community-title { font-family:var(--font-head); font-size:clamp(1.9rem,3.8vw,3.2rem); font-weight:900; margin-bottom:var(--sp-4); position:relative; }
.community-sub { font-size:1rem; color:rgba(255,255,255,0.5); max-width:480px; margin-inline:auto; margin-bottom:var(--sp-6); position:relative; }
.community-stats { display:flex; flex-wrap:wrap; justify-content:center; gap:var(--sp-6); margin-top:var(--sp-6); position:relative; }
.c-stat { text-align:center; }
.c-stat-num { font-family:var(--font-head); font-size:1.8rem; font-weight:700; color:var(--c-red); }
.c-stat-label { font-size:0.68rem; color:var(--c-muted); text-transform:uppercase; letter-spacing:0.1em; }

/* ── FOOTER ── */
#footer { background:var(--c-dark); border-top:1px solid var(--c-border); padding:var(--sp-9) 0 var(--sp-5); }
.footer-grid { display:grid; grid-template-columns:2fr repeat(3,1fr); gap:var(--sp-7); margin-bottom:var(--sp-6); }
.footer-brand-logo { display:flex; align-items:center; gap:var(--sp-2); margin-bottom:var(--sp-3); }
.footer-brand-desc { font-size:0.8rem; color:var(--c-muted); line-height:1.7; max-width:270px; margin-bottom:var(--sp-4); }
.footer-socials { display:flex; gap:var(--sp-2); }
.social-btn { width:33px; height:33px; display:flex; align-items:center; justify-content:center; border:1px solid var(--c-border); border-radius:var(--radius-sm); color:var(--c-muted); transition:all var(--t-fast); }
.social-btn:hover { color:var(--c-white); border-color:var(--c-border-gold); background:rgba(212,175,55,0.06); }
.footer-col-title { font-family:var(--font-head); font-size:0.72rem; font-weight:600; color:var(--c-white); letter-spacing:0.08em; text-transform:uppercase; margin-bottom:var(--sp-3); }
.footer-links { display:flex; flex-direction:column; gap:10px; }
.footer-link { font-size:0.8rem; color:var(--c-muted); transition:color var(--t-fast); }
.footer-link:hover { color:var(--c-gold); }
.footer-bottom { padding-top:var(--sp-5); border-top:1px solid var(--c-border); display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:var(--sp-4); }
.footer-copy { font-size:0.73rem; color:var(--c-muted); }
.footer-copy span { color:var(--c-gold); }
.footer-legal { display:flex; gap:var(--sp-4); }
.footer-legal-link { font-size:0.73rem; color:var(--c-muted); transition:color var(--t-fast); }
.footer-legal-link:hover { color:var(--c-white); }