/* ===========================================================
   ARENAS SAN MIGUEL — Tienda premium para gatos
   Grafito + dorado · elegante
   =========================================================== */

:root {
  --ink: #110E0C;          /* deepest graphite */
  --graphite: #16120F;     /* page bg */
  --graphite-2: #1E1916;   /* cards */
  --graphite-3: #271F1A;   /* hover */
  --gold: #C9A24B;
  --gold-light: #E4C273;
  --gold-deep: #A8842F;
  --cream: #F5F1E8;
  --cream-soft: #C7BFB1;
  --cream-mute: #8A8073;
  --line: rgba(201,162,75,0.16);
  --line-soft: rgba(245,241,232,0.08);
  --shadow: 0 30px 70px -30px rgba(0,0,0,0.7);
  --r: 18px;
  --maxw: 1240px;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: 'Manrope', system-ui, sans-serif;
  background: var(--graphite);
  color: var(--cream);
  line-height: 1.65;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

.container { max-width: var(--maxw); margin: 0 auto; padding: 0 clamp(20px, 5vw, 48px); }

h1, h2, h3, h4 { font-family: 'Marcellus', serif; font-weight: 400; line-height: 1.1; letter-spacing: 0.005em; }
.gold { color: var(--gold); }

/* ─── Buttons ─────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: 'Manrope', sans-serif; font-weight: 600;
  font-size: 14px; letter-spacing: 0.02em;
  padding: 13px 26px; border-radius: 999px; border: 1px solid transparent;
  cursor: pointer; transition: transform .3s, box-shadow .3s, background .3s, color .3s;
  white-space: nowrap; position: relative; overflow: hidden;
}
.btn .arrow { transition: transform .3s; }
.btn:hover .arrow { transform: translateX(4px); }
.btn--gold { background: linear-gradient(135deg, var(--gold-light), var(--gold-deep)); color: #1a1410; box-shadow: 0 8px 24px -10px rgba(201,162,75,.5); }
.btn--gold::after { content:""; position:absolute; top:0; left:-60%; width:40%; height:100%; background:linear-gradient(100deg,transparent,rgba(255,255,255,.5),transparent); transform:skewX(-18deg); transition:left .6s; }
.btn--gold:hover { transform: translateY(-2px); box-shadow: 0 14px 34px -10px rgba(201,162,75,.7); }
.btn--gold:hover::after { left: 130%; }
.btn--ghost { background: transparent; border-color: rgba(245,241,232,.28); color: var(--cream); }
.btn--ghost:hover { border-color: var(--gold); color: var(--gold-light); }
.btn--lg { padding: 16px 32px; font-size: 15px; }
.btn--xl { padding: 19px 44px; font-size: 16px; }

/* ─── Nav ─────────────────────────────────────────────────── */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px; padding: 16px clamp(20px, 5vw, 48px);
  transition: background .4s, box-shadow .4s, padding .4s;
}
.nav.scrolled { background: rgba(17,14,12,.86); backdrop-filter: blur(16px); box-shadow: 0 1px 0 var(--line); padding: 11px clamp(20px, 5vw, 48px); }

.brand { display: flex; align-items: center; gap: 12px; }
.brand__logo { width: 46px; height: 46px; border-radius: 12px; overflow: hidden; flex-shrink: 0; box-shadow: 0 0 0 1px var(--line), 0 0 20px rgba(201,162,75,.32); }
.brand__logo img { width: 100%; height: 100%; object-fit: cover; }
.brand__name { letter-spacing: 0.16em; }
.brand__name { font-family: 'Marcellus', serif; font-size: 18px; letter-spacing: 0.02em; color: var(--cream); display: block; line-height: 1; }
.brand__sub { font-size: 10px; letter-spacing: 0.18em; color: var(--gold); text-transform: uppercase; display: block; margin-top: 4px; }

.nav__links { display: flex; align-items: center; gap: clamp(16px, 2vw, 30px); margin-left: auto; }
.nav__links a { position:relative; font-size: 14px; font-weight: 500; color: var(--cream-soft); transition: color .2s; }
.nav__links a:hover { color: var(--gold-light); }
.nav__links a.active { color: var(--gold-light); }
.nav__links a.active::after { content:""; position:absolute; left:0; right:0; bottom:-6px; height:2px; background:linear-gradient(90deg,var(--gold-light),var(--gold-deep)); border-radius:2px; }
.nav__cta { margin-left: 6px; }

.nav__burger { display: none; flex-direction: column; gap: 5px; background: none; border: 0; cursor: pointer; padding: 8px; }
.nav__burger span { width: 24px; height: 2px; background: var(--cream); border-radius: 2px; transition: .3s; }

.mobile-menu {
  position: fixed; top: 0; right: 0; bottom: 0; width: min(82vw, 340px);
  background: var(--ink); z-index: 99; transform: translateX(100%);
  transition: transform .4s cubic-bezier(.4,0,.2,1); padding: 96px 32px 32px;
  display: flex; flex-direction: column; gap: 4px; box-shadow: var(--shadow); border-left: 1px solid var(--line);
}
.mobile-menu.open { transform: translateX(0); }
.mobile-menu a { color: var(--cream); font-family: 'Marcellus', serif; font-size: 19px; padding: 15px 0; border-bottom: 1px solid var(--line-soft); }
.mobile-menu a:last-of-type { border: 0; }

/* ─── Hero ────────────────────────────────────────────────── */
.hero { position: relative; min-height: 100vh; min-height: 100svh; display: flex; align-items: center; overflow: hidden; background: var(--ink); }
.hero__media { position: absolute; inset: 0; z-index: 0; }
.hero__media img { width: 100%; height: 100%; object-fit: cover; object-position: 70% center; }
.hero__scrim { position: absolute; inset: 0; background:
  linear-gradient(100deg, rgba(17,14,12,.96) 0%, rgba(17,14,12,.8) 40%, rgba(17,14,12,.35) 75%, rgba(17,14,12,.55) 100%),
  radial-gradient(circle at 18% 50%, rgba(201,162,75,.12), transparent 45%); }
.hero__inner { position: relative; z-index: 2; max-width: var(--maxw); margin: 0 auto; padding: 120px clamp(20px,5vw,48px) 80px; width: 100%; }
.hero__eyebrow { display: inline-flex; align-items: center; gap: 10px; font-size: 13px; font-weight: 500; letter-spacing: .04em; color: var(--gold-light); background: rgba(201,162,75,.08); border: 1px solid var(--line); padding: 9px 18px; border-radius: 999px; margin-bottom: 28px; }
.hero__eyebrow .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 0 4px rgba(201,162,75,.2); }
.hero__title { font-size: clamp(40px, 7vw, 86px); color: var(--cream); letter-spacing: -0.01em; line-height: 1.04; }
.hero__sub { font-size: clamp(16px, 2vw, 21px); color: var(--cream-soft); max-width: 54ch; margin: 26px 0 0; font-weight: 300; }
.hero__ctas { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 40px; }

/* ─── Hero con logo (Felinara) ────────────────────────────── */
.hero__scrim--solo { position:absolute; inset:0; background: radial-gradient(circle at 50% 34%, rgba(201,162,75,.12), transparent 56%), linear-gradient(180deg, var(--ink), var(--graphite)); }
.hero__inner--logo { text-align:center; display:flex; flex-direction:column; align-items:center; }
.hero__logo { margin-bottom: 8px; }
.hero__logo img { width: clamp(280px, 42vw, 480px); height:auto; border-radius: 24px; filter: drop-shadow(0 0 60px rgba(201,162,75,.42)); animation: logoGlow 5s ease-in-out infinite; }
@keyframes logoGlow { 0%,100%{ filter: drop-shadow(0 0 38px rgba(201,162,75,.32)); } 50%{ filter: drop-shadow(0 0 74px rgba(201,162,75,.58)); } }
.hero__wordmark { font-family:'Marcellus',serif; font-size: clamp(34px,6vw,60px); letter-spacing:0.34em; padding-left:0.34em; color:var(--cream); margin-top:14px; text-shadow:0 2px 30px rgba(201,162,75,.22); }
.hero__inner--logo .hero__sub { margin-left:auto; margin-right:auto; }
.hero__inner--logo .hero__ctas { justify-content:center; }
.hero__trust { list-style:none; display:flex; flex-wrap:wrap; justify-content:center; gap:10px 26px; margin-top:38px; padding-top:26px; border-top:1px solid var(--line-soft); }
.hero__trust li { position:relative; padding-left:24px; font-size:13.5px; color:var(--cream-soft); font-weight:500; }
.hero__trust li::before { content:"\2713"; position:absolute; left:0; color:var(--gold); font-weight:700; }

/* ─── Sections ────────────────────────────────────────────── */
.section { padding: clamp(72px, 10vw, 128px) 0; }
.section--soft { background: var(--graphite-2); }
.shead { max-width: 720px; margin: 0 0 60px; }
.shead--center { margin-left: auto; margin-right: auto; text-align: center; }
.eyebrow { font-family: 'Manrope', sans-serif; font-weight: 600; letter-spacing: .2em; text-transform: uppercase; font-size: 12px; color: var(--gold); }
.stitle { font-size: clamp(30px, 4.4vw, 50px); margin-top: 14px; color: var(--cream); }
.slede { font-size: clamp(16px, 1.6vw, 18px); color: var(--cream-soft); margin-top: 16px; font-weight: 300; }
.shead--center .slede { max-width: 60ch; margin-left: auto; margin-right: auto; }

/* ─── Beneficios ──────────────────────────────────────────── */
.ben-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.ben { background: var(--graphite-2); border: 1px solid var(--line); border-radius: var(--r); padding: 38px 30px; transition: transform .35s, border-color .35s, box-shadow .35s; }
.ben:hover { transform: translateY(-6px); border-color: rgba(201,162,75,.45); box-shadow: var(--shadow); }
.ben__ico { width: 56px; height: 56px; border-radius: 14px; background: rgba(201,162,75,.1); border: 1px solid var(--line); color: var(--gold-light); display: grid; place-items: center; margin-bottom: 22px; }
.ben__ico svg { width: 26px; height: 26px; }
.ben h3 { font-size: 21px; color: var(--cream); }
.ben p { font-size: 14.5px; color: var(--cream-soft); margin-top: 10px; font-weight: 300; }

/* ─── Categorías ──────────────────────────────────────────── */
.cat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.cat { background: var(--graphite); border: 1px solid var(--line); border-radius: var(--r); overflow: hidden; transition: transform .4s, box-shadow .4s, border-color .4s; }
.section--soft .cat { background: var(--graphite); }
.cat:hover { transform: translateY(-8px); box-shadow: var(--shadow); border-color: rgba(201,162,75,.45); }
.cat__media { aspect-ratio: 4/3; overflow: hidden; position: relative; background: linear-gradient(140deg, var(--graphite-3), var(--ink)); }
.cat__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s; }
.cat:hover .cat__media img { transform: scale(1.07); }
.cat__media.noimg::after { content: "🐾"; position: absolute; inset: 0; display: grid; place-items: center; font-size: 48px; opacity: .4; }
.cat__media.noimg img { display: none; }
.cat__body { padding: 24px 24px 26px; }
.cat__body h3 { font-size: 23px; color: var(--cream); }
.cat__body p { font-size: 14.5px; color: var(--cream-soft); margin-top: 8px; font-weight: 300; }
.cat__link { display: inline-flex; align-items: center; gap: 8px; margin-top: 18px; font-weight: 600; font-size: 13.5px; color: var(--gold-light); }
.cat__link .arrow { transition: transform .3s; }
.cat:hover .cat__link .arrow { transform: translateX(4px); }

/* ─── Emocional ───────────────────────────────────────────── */
.emo { position: relative; padding: clamp(96px, 16vw, 180px) 0; overflow: hidden; text-align: center; }
.emo__media { position: absolute; inset: 0; z-index: 0; }
.emo__media img { width: 100%; height: 100%; object-fit: cover; }
.emo__scrim { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(17,14,12,.82), rgba(17,14,12,.88)), radial-gradient(circle at 50% 40%, rgba(201,162,75,.14), transparent 55%); }
.emo__inner { position: relative; z-index: 2; }
.emo__title { font-size: clamp(30px, 5vw, 60px); color: var(--cream); }
.emo__txt { font-family: 'Cormorant Garamond', serif; font-size: clamp(19px, 2.2vw, 26px); font-style: italic; color: var(--cream-soft); max-width: 60ch; margin: 26px auto 0; line-height: 1.5; }

/* ─── Producto destacado ──────────────────────────────────── */
.feat { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(36px, 6vw, 76px); align-items: center; }
.feat__media { position: relative; aspect-ratio: 4/5; border-radius: var(--r); overflow: hidden; border: 1px solid var(--line); background: linear-gradient(140deg, var(--graphite-3), var(--ink)); box-shadow: var(--shadow); }
.feat__media img { width: 100%; height: 100%; object-fit: cover; }
.feat__media.noimg::after { content:"🐾"; position:absolute; inset:0; display:grid; place-items:center; font-size:64px; opacity:.4; }
.feat__media.noimg img { display:none; }
.feat__badge { position: absolute; top: 18px; left: 18px; background: linear-gradient(135deg, var(--gold-light), var(--gold-deep)); color: #1a1410; font-weight: 700; font-size: 12px; letter-spacing: .04em; padding: 7px 15px; border-radius: 999px; }
.feat__list { list-style: none; margin: 26px 0 32px; display: grid; gap: 14px; }
.feat__list li { position: relative; padding-left: 34px; font-size: 16.5px; color: var(--cream); }
.feat__list li::before { content: "✓"; position: absolute; left: 0; top: 0; width: 22px; height: 22px; border-radius: 50%; background: rgba(201,162,75,.16); color: var(--gold-light); font-size: 12px; font-weight: 700; display: grid; place-items: center; }

/* ─── Testimonios ─────────────────────────────────────────── */
.testi-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.testi { background: var(--graphite); border: 1px solid var(--line); border-radius: var(--r); padding: 32px 28px; }
.section--soft .testi { background: var(--ink); }
.testi__stars { color: var(--gold); letter-spacing: 3px; font-size: 15px; }
.testi p { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 19px; color: var(--cream); margin: 16px 0 22px; line-height: 1.5; }
.testi__who { display: flex; align-items: center; gap: 12px; }
.testi__av { width: 46px; height: 46px; border-radius: 50%; background: linear-gradient(135deg, var(--gold-light), var(--gold-deep)); color: #1a1410; display: grid; place-items: center; font-family: 'Marcellus', serif; font-size: 19px; }
.testi__who strong { display: block; font-size: 14.5px; color: var(--cream); }
.testi__who span { font-size: 13px; color: var(--cream-mute); }

/* ─── Confianza ───────────────────────────────────────────── */
.trust-grid { list-style: none; display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; max-width: 920px; margin: 0 auto; }
.trust-grid li { background: var(--graphite-2); border: 1px solid var(--line); border-radius: 12px; padding: 20px 22px 20px 52px; position: relative; font-weight: 500; color: var(--cream); }
.trust-grid li::before { content: "✓"; position: absolute; left: 20px; top: 50%; transform: translateY(-50%); width: 22px; height: 22px; border-radius: 50%; background: rgba(201,162,75,.16); color: var(--gold-light); font-size: 12px; font-weight: 700; display: grid; place-items: center; }

/* ─── CTA final ───────────────────────────────────────────── */
.cta { padding: clamp(80px, 12vw, 150px) 0; text-align: center; background:
  radial-gradient(circle at 50% 0%, rgba(201,162,75,.12), transparent 55%), var(--ink); }
.cta__title { font-size: clamp(34px, 5.6vw, 66px); color: var(--cream); }
.cta__txt { font-size: clamp(16px, 2vw, 20px); color: var(--cream-soft); margin: 20px auto 36px; max-width: 50ch; font-weight: 300; }
.cta__phone { font-family: 'Marcellus', serif; font-size: 22px; color: var(--gold-light); margin-top: 22px; letter-spacing: 0.04em; }

/* ─── Footer ──────────────────────────────────────────────── */
.footer { background: var(--ink); padding: 64px 0 28px; border-top: 1px solid var(--line); }
.footer__row { display: grid; grid-template-columns: 2fr 1fr 1.4fr; gap: 40px; padding-bottom: 44px; border-bottom: 1px solid var(--line-soft); }
.footer__tag { color: var(--cream-soft); font-size: 14px; margin-top: 16px; max-width: 34ch; font-weight: 300; }
.footer__col h4 { font-family: 'Manrope', sans-serif; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; font-size: 12px; color: var(--gold); margin-bottom: 16px; }
.footer__col a, .footer__loc { display: block; color: var(--cream-soft); font-size: 14px; padding: 5px 0; transition: color .2s; }
.footer__col a:hover { color: var(--gold-light); }
.footer__base { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px; padding-top: 24px; font-size: 13px; color: var(--cream-mute); }

/* ─── WhatsApp float ──────────────────────────────────────── */
.wsp-float { position: fixed; right: 22px; bottom: 22px; width: 60px; height: 60px; border-radius: 50%; background: #25d366; color: #fff; display: grid; place-items: center; z-index: 90; box-shadow: 0 12px 30px rgba(0,0,0,.4); transition: transform .3s; }
.wsp-float svg { width: 33px; height: 33px; }
.wsp-float:hover { transform: scale(1.08); }
.wsp-float::after { content:""; position:absolute; inset:0; border-radius:50%; background:#25d366; z-index:-1; animation: ping2 2.6s ease-out infinite; }
@keyframes ping2 { 0%{transform:scale(1);opacity:.5;}70%,100%{transform:scale(1.7);opacity:0;} }

/* ─── Reveal ──────────────────────────────────────────────── */
.reveal-on [data-reveal] { opacity: 0; transform: translateY(24px); transition: opacity .8s cubic-bezier(.22,1,.36,1), transform .8s cubic-bezier(.22,1,.36,1); }
.reveal-on [data-reveal].in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .reveal-on [data-reveal] { opacity: 1; transform: none; transition: none; } }

/* ─── Productos destacados ────────────────────────────────── */
.prod-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.prod { background:var(--graphite-2); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; transition:transform .4s, box-shadow .4s, border-color .4s; }
.prod:hover { transform:translateY(-8px); box-shadow:var(--shadow); border-color:rgba(201,162,75,.45); }
.prod__media { aspect-ratio:4/3; position:relative; overflow:hidden; background:linear-gradient(140deg,var(--graphite-3),var(--ink)); }
.prod__media img { width:100%; height:100%; object-fit:cover; transition:transform .6s; }
.prod:hover .prod__media img { transform:scale(1.06); }
.prod__media.noimg::after { content:"🐾"; position:absolute; inset:0; display:grid; place-items:center; font-size:48px; opacity:.4; }
.prod__media.noimg img { display:none; }
.prod__tag { position:absolute; top:14px; left:14px; background:linear-gradient(135deg,var(--gold-light),var(--gold-deep)); color:#1a1410; font-weight:700; font-size:11px; letter-spacing:.04em; padding:6px 13px; border-radius:999px; }
.prod__body { padding:22px 22px 24px; }
.prod__body h3 { font-size:21px; color:var(--cream); }
.prod__body p { font-size:14px; color:var(--cream-soft); margin-top:8px; font-weight:300; }
.prod__foot { display:flex; align-items:center; justify-content:space-between; gap:14px; margin-top:18px; flex-wrap:wrap; }
.prod__price { font-family:'Marcellus',serif; font-size:24px; color:var(--gold-light); }
.prod__btns { display:flex; gap:8px; }
.prod__wa { display:inline-flex; align-items:center; font-size:12px; font-weight:600; color:#25d366; border:1px solid rgba(37,211,102,.4); border-radius:999px; padding:9px 14px; transition:background .25s,color .25s; }
.prod__wa:hover { background:#25d366; color:#fff; }
.btn--sm { padding:9px 18px; font-size:13px; }
.prod__note { text-align:center; margin-top:40px; color:var(--cream-mute); font-size:14px; }

/* ─── Mundo Felinara ──────────────────────────────────────── */
.mundo-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.mcard { text-align:left; cursor:pointer; background:var(--graphite); border:1px solid var(--line); border-radius:var(--r); padding:30px 26px 26px; display:flex; flex-direction:column; gap:8px; transition:transform .4s, box-shadow .4s, border-color .4s, background .4s; font-family:inherit; color:inherit; }
.section--soft .mcard { background:var(--ink); }
.mcard:hover { transform:translateY(-6px); box-shadow:var(--shadow); border-color:rgba(201,162,75,.5); }
.mcard__no { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:30px; color:rgba(201,162,75,.55); }
.mcard h3 { font-size:19px; color:var(--cream); line-height:1.2; }
.mcard p { font-size:13.5px; color:var(--cream-soft); font-weight:300; }
.mcard__go { margin-top:auto; padding-top:12px; font-size:12.5px; font-weight:600; letter-spacing:.04em; color:var(--gold-light); display:inline-flex; align-items:center; gap:6px; }
.mcard__go .arrow { transition:transform .3s; }
.mcard:hover .mcard__go .arrow { transform:translateX(4px); }

/* ─── Modal ───────────────────────────────────────────────── */
.modal { position:fixed; inset:0; z-index:200; display:grid; place-items:center; padding:24px; }
.modal[hidden] { display:none; }
.modal__backdrop { position:absolute; inset:0; background:rgba(8,6,5,.82); backdrop-filter:blur(8px); animation:fade .3s ease; }
.modal__panel { position:relative; width:min(820px,100%); max-height:88vh; display:flex; flex-direction:column; background:linear-gradient(180deg,var(--graphite-2),var(--graphite)); border:1px solid var(--line); border-radius:22px; box-shadow:var(--shadow); animation:pop .4s cubic-bezier(.22,1,.36,1); overflow:hidden; }
@keyframes fade { from{opacity:0;} } @keyframes pop { from{opacity:0; transform:translateY(24px) scale(.98);} }
.modal__close { position:absolute; top:16px; right:16px; z-index:3; width:42px; height:42px; border-radius:50%; background:rgba(17,14,12,.7); border:1px solid var(--line); color:var(--cream); font-size:15px; cursor:pointer; transition:background .25s,color .25s,transform .25s; }
.modal__close:hover { background:var(--gold); color:#1a1410; transform:rotate(90deg); }
.modal__scroll { overflow-y:auto; padding:44px clamp(24px,4vw,48px) 24px; }
.modal__scroll::-webkit-scrollbar { width:8px; } .modal__scroll::-webkit-scrollbar-thumb { background:rgba(201,162,75,.4); border-radius:8px; }
.modal__bar { display:flex; gap:10px; justify-content:flex-end; padding:16px clamp(24px,4vw,48px); border-top:1px solid var(--line-soft); background:rgba(12,10,8,.5); }
.modal__eyebrow { font-family:'Manrope',sans-serif; font-weight:600; letter-spacing:.2em; text-transform:uppercase; font-size:11px; color:var(--gold); }
.modal__title { font-family:'Marcellus',serif; font-size:clamp(26px,4vw,40px); color:var(--cream); margin:10px 0 6px; line-height:1.1; }
.modal__hero { aspect-ratio:16/7; border-radius:14px; overflow:hidden; margin:18px 0 22px; background:linear-gradient(140deg,var(--graphite-3),var(--ink)); border:1px solid var(--line); }
.modal__hero img { width:100%; height:100%; object-fit:cover; }
.modal__body h4 { font-family:'Marcellus',serif; font-size:21px; color:var(--gold-light); margin:24px 0 10px; }
.modal__body p { color:var(--cream-soft); margin-bottom:14px; line-height:1.75; font-weight:300; }
.modal__body ul { margin:0 0 16px; padding-left:0; list-style:none; }
.modal__body li { position:relative; padding-left:26px; margin-bottom:10px; color:var(--cream-soft); font-weight:300; }
.modal__body li::before { content:"🐾"; position:absolute; left:0; font-size:13px; }
.race-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin-top:16px; }
.race { text-align:left; cursor:pointer; background:var(--graphite); border:1px solid var(--line); border-radius:14px; overflow:hidden; transition:transform .3s,border-color .3s; font-family:inherit; color:inherit; }
.race:hover { transform:translateY(-4px); border-color:rgba(201,162,75,.5); }
.race__media { aspect-ratio:16/10; overflow:hidden; background:linear-gradient(140deg,var(--graphite-3),var(--ink)); }
.race__media img { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.race:hover .race__media img { transform:scale(1.07); }
.race__media.noimg::after{content:"🐱";position:absolute;inset:0;display:grid;place-items:center;font-size:34px;opacity:.4;}
.race__name { padding:12px 14px; font-family:'Marcellus',serif; font-size:16px; color:var(--cream); display:flex; justify-content:space-between; align-items:center; }
.race__name .arrow { color:var(--gold-light); }
.faqitem { border-bottom:1px solid var(--line-soft); padding:16px 0; }
.faqq { font-weight:600; color:var(--cream); }
.faqa { color:var(--cream-soft); font-weight:300; margin-top:8px; line-height:1.7; }

/* ─── Guía ────────────────────────────────────────────────── */
.guide__inner { display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(36px,5vw,64px); align-items:center; }
.guide__bullets { list-style:none; margin:24px 0 0; padding:0; display:grid; gap:12px; }
.guide__bullets li { position:relative; padding-left:30px; color:var(--cream); }
.guide__bullets li::before { content:"✓"; position:absolute; left:0; width:20px; height:20px; border-radius:50%; background:rgba(201,162,75,.16); color:var(--gold-light); font-size:11px; font-weight:700; display:grid; place-items:center; }
.glass { background:rgba(30,25,22,.6); backdrop-filter:blur(10px); border:1px solid var(--line); border-radius:var(--r); }
.guide__form { padding:36px 32px; }
.guide__form h3 { font-size:24px; color:var(--cream); margin-bottom:20px; }
.guide__form label { display:block; font-size:13px; color:var(--cream-soft); margin-bottom:16px; }
.guide__form input { width:100%; margin-top:7px; background:var(--ink); border:1px solid var(--line); border-radius:11px; padding:13px 15px; color:var(--cream); font-family:inherit; font-size:15px; transition:border-color .25s; }
.guide__form input:focus { outline:none; border-color:var(--gold); }
.guide__ok { color:#7ddf9e; font-weight:600; margin-top:16px; text-align:center; }

/* ─── CTA btns ────────────────────────────────────────────── */
.cta__logo img { width:170px; height:auto; border-radius:20px; margin:0 auto 22px; filter:drop-shadow(0 0 44px rgba(201,162,75,.42)); }
.cta__btns { display:flex; flex-wrap:wrap; gap:14px; justify-content:center; }

/* ─── Club Felinara / Aliado ──────────────────────────────── */
.ally { position:relative; overflow:hidden; max-width:920px; margin:0 auto; background:linear-gradient(160deg, var(--graphite-3), var(--ink)); border:1px solid rgba(201,162,75,.32); border-radius:24px; padding:clamp(30px,5vw,52px); box-shadow:var(--shadow); }
.ally__glow { position:absolute; top:-30%; right:-10%; width:340px; height:340px; border-radius:50%; background:rgba(201,162,75,.14); filter:blur(80px); pointer-events:none; }
.ally__head { display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; position:relative; z-index:2; }
.ally__brand { font-family:'Marcellus',serif; font-size:clamp(24px,3.4vw,34px); color:var(--cream); letter-spacing:.04em; }
.ally__badge { font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-light); border:1px solid var(--line); border-radius:999px; padding:7px 15px; }
.ally__lead { color:var(--cream-soft); margin:18px 0 22px; line-height:1.7; font-weight:300; position:relative; z-index:2; }
.ally__cols { display:grid; grid-template-columns:1fr 1fr; gap:0 30px; margin-bottom:26px; position:relative; z-index:2; }
.ally__list { list-style:none; margin:0; padding:0; }
.ally__list li { position:relative; padding:9px 0 9px 26px; color:var(--cream); border-bottom:1px solid var(--line-soft); }
.ally__list li::before { content:"✓"; position:absolute; left:0; color:var(--gold-light); font-weight:700; }
.ally__offer { text-align:center; background:linear-gradient(135deg, rgba(201,162,75,.16), rgba(201,162,75,.05)); border:1px solid rgba(201,162,75,.4); border-radius:16px; padding:24px; margin-bottom:22px; position:relative; z-index:2; }
.ally__gift { display:block; color:var(--cream-soft); font-size:14px; }
.ally__pct { display:block; font-family:'Marcellus',serif; font-size:clamp(30px,5vw,44px); color:var(--gold-light); margin:6px 0; letter-spacing:.02em; }
.ally__small { display:block; color:var(--cream-mute); font-size:13px; }
.ally__trust { color:var(--cream-soft); font-size:14.5px; line-height:1.7; font-weight:300; margin-bottom:26px; position:relative; z-index:2; }
.ally__btns { display:flex; flex-wrap:wrap; gap:14px; position:relative; z-index:2; }
.ally__soon { max-width:920px; margin:22px auto 0; text-align:center; border:1px dashed var(--line); border-radius:18px; padding:28px 32px; }
.ally__soon-tag { font-size:11px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); }
.ally__soon p { color:var(--cream-soft); font-weight:300; margin-top:12px; line-height:1.7; }

/* ─── Arenas Destacadas ───────────────────────────────────── */
.arena-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.arena { display:flex; flex-direction:column; background:var(--graphite-2); border:1px solid rgba(201,162,75,.3); border-radius:var(--r); overflow:hidden; transition:transform .4s, box-shadow .4s, border-color .4s; }
.arena:hover { transform:translateY(-8px); box-shadow:var(--shadow), 0 0 40px rgba(201,162,75,.12); border-color:rgba(201,162,75,.55); }
.arena__media { position:relative; aspect-ratio:1; overflow:hidden; background:#000; display:grid; place-items:center; }
.arena__media img { width:100%; height:100%; object-fit:contain; transition:transform .5s; }
.arena:hover .arena__media img { transform:scale(1.04); }
.arena__media.noimg::after { content:"🐾"; position:absolute; inset:0; display:grid; place-items:center; font-size:48px; opacity:.4; }
.arena__media.noimg img { display:none; }
.arena__flag { position:absolute; top:14px; left:14px; font-size:12px; font-weight:700; letter-spacing:.03em; padding:7px 14px; border-radius:999px; }
.arena__flag--gold { background:linear-gradient(135deg,var(--gold-light),var(--gold-deep)); color:#1a1410; }
.arena__flag--fire { background:linear-gradient(135deg,#ff8a3d,#c2410c); color:#fff; }
.arena__flag--value { background:rgba(12,10,8,.72); color:var(--gold-light); border:1px solid rgba(201,162,75,.5); top:auto; bottom:14px; backdrop-filter:blur(4px); }
.arena__sizes { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin:0 0 20px; }
.arena__size { font-size:13px; color:var(--cream-soft); background:rgba(201,162,75,.06); border:1px solid var(--line); border-radius:9px; padding:8px 12px; }
.arena__size strong { color:var(--gold-light); }
.btn--detalles { width:100%; justify-content:center; }
.noimg-ph { position:absolute; inset:0; display:grid; place-items:center; font-size:48px; opacity:.4; }
#arenasDinamicas:empty { display:none; }
#arenasDinamicas { margin-top:24px; }
.arena__body { padding:26px 26px 28px; display:flex; flex-direction:column; flex:1; }
.arena__body h3 { font-size:22px; color:var(--cream); line-height:1.2; }
.arena__meta { display:flex; align-items:baseline; gap:14px; margin:12px 0 14px; }
.arena__price { font-family:'Marcellus',serif; font-size:30px; color:var(--gold-light); }
.arena__fmt { font-size:13px; color:var(--cream-mute); border:1px solid var(--line); border-radius:999px; padding:4px 12px; }
.arena__body p { font-size:14px; color:var(--cream-soft); font-weight:300; line-height:1.7; }
.arena__list { list-style:none; margin:18px 0 22px; padding:0; display:grid; grid-template-columns:1fr 1fr; gap:8px 16px; }
.arena__list li { position:relative; padding-left:22px; font-size:13px; color:var(--cream-soft); }
.arena__list li::before { content:"✓"; position:absolute; left:0; color:var(--gold-light); font-weight:700; }
.arena__btns { margin-top:auto; display:flex; flex-direction:column; gap:10px; }

/* ─── Carro: control de compra en tarjeta ─────────────────── */
.arena__buy { display:flex; flex-direction:column; gap:10px; margin-bottom:10px; }
.buy-row { display:flex; gap:10px; }
.buy-size { flex:1; min-width:0; background:var(--ink); border:1px solid var(--line); border-radius:10px; color:var(--cream); font-family:inherit; font-size:13.5px; padding:11px 12px; }
.buy-size:focus { outline:none; border-color:var(--gold); }
.buy-qty { display:flex; align-items:center; border:1px solid var(--line); border-radius:10px; overflow:hidden; flex-shrink:0; }
.buy-qty button { width:38px; height:42px; background:var(--ink); color:var(--gold-light); font-size:18px; line-height:1; transition:background .2s; }
.buy-qty button:hover { background:rgba(201,168,128,.14); }
.buy-n { min-width:30px; text-align:center; font-weight:600; color:var(--cream); }
.buy-add { width:100%; justify-content:center; }

/* ─── Carro: botón flotante ───────────────────────────────── */
.cart-fab { position:fixed; right:22px; bottom:90px; width:58px; height:58px; border-radius:50%; background:linear-gradient(135deg,var(--gold-light,#e0c074),var(--gold-deep,#a98e63)); color:#1a1410; display:grid; place-items:center; z-index:91; box-shadow:0 12px 30px rgba(0,0,0,.3); transition:transform .35s; }
.cart-fab:hover { transform:scale(1.08); }
.cart-fab svg { width:26px; height:26px; }
.cart-fab__count { position:absolute; top:-4px; right:-4px; min-width:22px; height:22px; padding:0 6px; border-radius:999px; background:#c2410c; color:#fff; font-size:12px; font-weight:700; display:grid; place-items:center; box-shadow:0 2px 8px rgba(0,0,0,.4); }

/* ─── Carro: overlay + drawer ─────────────────────────────── */
.cart-overlay { position:fixed; inset:0; background:rgba(6,5,4,.6); backdrop-filter:blur(4px); z-index:200; opacity:0; transition:opacity .34s; }
.cart-overlay.open { opacity:1; }
.cart { position:fixed; top:0; right:0; bottom:0; width:min(420px,92vw); background:linear-gradient(180deg,var(--graphite-2,#16120e),var(--graphite,#0c0a08)); border-left:1px solid var(--line); z-index:201; display:flex; flex-direction:column; transform:translateX(100%); transition:transform .38s cubic-bezier(.22,1,.36,1); box-shadow:-30px 0 80px rgba(0,0,0,.5); }
.cart.open { transform:translateX(0); }
.cart__head { display:flex; align-items:center; justify-content:space-between; padding:24px 26px; border-bottom:1px solid var(--line); }
.cart__eyebrow { font-size:10px; font-weight:700; letter-spacing:.24em; text-transform:uppercase; color:var(--gold-light); }
.cart__head h3 { font-family:'Marcellus',serif; font-size:24px; color:var(--cream); margin-top:3px; }
.cart__close { width:40px; height:40px; border-radius:50%; border:1px solid var(--line); color:var(--cream); font-size:14px; transition:all .25s; }
.cart__close:hover { background:var(--gold); color:#1a1410; transform:rotate(90deg); }
.cart__items { flex:1; overflow-y:auto; padding:18px 26px; }
.ci { display:flex; gap:12px; justify-content:space-between; padding:16px 0; border-bottom:1px solid var(--line); }
.ci__name { display:block; color:var(--cream); font-weight:600; font-size:14.5px; line-height:1.3; }
.ci__size { display:block; font-size:12.5px; color:var(--cream-mute); margin-top:3px; }
.ci__right { display:flex; flex-direction:column; align-items:flex-end; gap:8px; flex-shrink:0; }
.ci__qty { display:flex; align-items:center; gap:8px; border:1px solid var(--line); border-radius:999px; padding:2px; }
.ci__qty button { width:26px; height:26px; border-radius:50%; color:var(--gold-light); font-size:15px; line-height:1; }
.ci__qty button:hover { background:rgba(201,168,128,.16); }
.ci__qty span { min-width:18px; text-align:center; font-size:13px; color:var(--cream); }
.ci__lt { font-family:'Marcellus',serif; font-size:16px; color:var(--gold-light); }
.ci__rm { color:var(--cream-mute); font-size:12px; }
.ci__rm:hover { color:#ff9a9a; }
.cart__empty { flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; text-align:center; color:var(--cream-mute); padding:40px; }
.cart__empty-ic { font-size:46px; opacity:.5; }
.cart__empty-link { color:var(--gold-light); border-bottom:1px solid var(--gold); font-weight:600; font-size:14px; }
.cart__foot { padding:22px 26px calc(22px + env(safe-area-inset-bottom)); border-top:1px solid var(--line); background:rgba(12,10,8,.5); }
.cart__total { display:flex; align-items:baseline; justify-content:space-between; margin-bottom:18px; }
.cart__total span { font-size:13px; letter-spacing:.1em; text-transform:uppercase; color:var(--cream-soft); }
.cart__total strong { font-family:'Marcellus',serif; font-size:30px; color:var(--gold-light); }
.cart__form { display:flex; flex-direction:column; gap:10px; margin-bottom:12px; }
.cart__form input { background:var(--ink); border:1px solid var(--line); border-radius:10px; color:var(--cream); font-family:inherit; font-size:14px; padding:12px 14px; }
.cart__form input:focus { outline:none; border-color:var(--gold); }
.cart__note { font-size:12px; color:var(--cream-mute); margin-bottom:14px; line-height:1.5; }
.cart__send { width:100%; justify-content:center; }
.cart__send-mail { width:100%; margin-top:10px; padding:13px; border:1px solid var(--line); border-radius:999px; color:var(--cream); font-weight:600; font-size:13.5px; transition:all .25s; }
.cart__send-mail:hover { border-color:var(--gold); color:var(--gold-light); }

@media (max-width:560px){ .cart-fab { bottom:84px; } .buy-row { flex-wrap:wrap; } }
.btn--soon { width:100%; justify-content:center; opacity:.62; cursor:not-allowed; }
.btn--soon:hover { transform:none; box-shadow:0 8px 24px -10px rgba(201,162,75,.5); }
.arena__btns .prod__wa { justify-content:center; }

/* ─── Destacados 2 (Arenas + Próximamente) ────────────────── */
.feat2-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.feat2 { position:relative; overflow:hidden; display:flex; flex-direction:column; align-items:flex-start; background:linear-gradient(160deg,var(--graphite-3),var(--ink)); border:1px solid rgba(201,162,75,.3); border-radius:var(--r); padding:clamp(28px,4vw,44px); transition:transform .4s,box-shadow .4s,border-color .4s; }
.feat2:hover { transform:translateY(-6px); box-shadow:var(--shadow),0 0 40px rgba(201,162,75,.1); border-color:rgba(201,162,75,.5); }
.feat2--soon { border-style:dashed; }
.feat2__glow { position:absolute; top:-30%; right:-10%; width:280px; height:280px; border-radius:50%; background:rgba(201,162,75,.12); filter:blur(70px); pointer-events:none; }
.feat2__tag { position:relative; z-index:2; font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); border:1px solid var(--line); border-radius:999px; padding:7px 15px; }
.feat2__tag--gold { background:linear-gradient(135deg,var(--gold-light),var(--gold-deep)); color:#1a1410; border-color:transparent; }
.feat2 h3 { position:relative; z-index:2; font-size:clamp(24px,3vw,30px); color:var(--cream); margin:18px 0 12px; }
.feat2 p { position:relative; z-index:2; color:var(--cream-soft); font-weight:300; line-height:1.7; margin-bottom:18px; }
.feat2__mini { position:relative; z-index:2; list-style:none; margin:0 0 24px; padding:0; }
.feat2__mini li { position:relative; padding-left:24px; margin-bottom:9px; color:var(--cream); }
.feat2__mini li::before { content:"✓"; position:absolute; left:0; color:var(--gold-light); font-weight:700; }
.feat2 .btn { position:relative; z-index:2; margin-top:auto; }

/* ─── Comunidad Felinara ──────────────────────────────────── */
.comu-cats { display:flex; flex-wrap:wrap; justify-content:center; gap:10px; max-width:880px; margin:0 auto 44px; }
.comu-cat { font-size:13.5px; font-weight:500; color:var(--cream); background:var(--graphite-2); border:1px solid var(--line); border-radius:999px; padding:10px 18px; transition:border-color .3s,transform .3s; }
.comu-cat:hover { border-color:rgba(201,162,75,.5); transform:translateY(-2px); }
.comu-form { max-width:760px; margin:0 auto; padding:clamp(28px,4vw,44px); }
.comu-form h3 { font-size:24px; color:var(--cream); }
.comu-form__note { color:var(--cream-mute); font-size:13.5px; margin:8px 0 24px; }
.comu-form__grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:22px; }
.comu-form__full { grid-column:1 / -1; }
.comu-form label { display:block; font-size:13px; color:var(--cream-soft); }
.comu-form input, .comu-form select, .comu-form textarea { width:100%; margin-top:7px; background:var(--ink); border:1px solid var(--line); border-radius:11px; padding:13px 15px; color:var(--cream); font-family:inherit; font-size:15px; transition:border-color .25s; }
.comu-form input:focus, .comu-form select:focus, .comu-form textarea:focus { outline:none; border-color:var(--gold); }
.comu-form textarea { resize:vertical; }
.comu-form input[type=file] { padding:11px 15px; color:var(--cream-soft); }
.comu-form__ok { color:#7ddf9e; font-weight:500; margin-top:16px; text-align:center; line-height:1.6; }

/* Avisos aprobados */
.comu-aprob { max-width:980px; margin:48px auto 0; }
.comu-aprob__title { text-align:center; font-family:'Marcellus',serif; font-size:24px; color:var(--cream); margin-bottom:24px; }
.comu-aprob__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.comu-aviso { background:var(--graphite-2); border:1px solid var(--line); border-radius:16px; overflow:hidden; padding:0 0 18px; }
.comu-aviso__img { aspect-ratio:4/3; overflow:hidden; background:var(--ink); margin-bottom:14px; }
.comu-aviso__img img { width:100%; height:100%; object-fit:cover; }
.comu-aviso__cat { display:inline-block; margin:0 18px; font-size:11px; font-weight:700; letter-spacing:.08em; color:var(--gold-light); border:1px solid var(--line); border-radius:999px; padding:4px 12px; }
.comu-aviso h4 { font-size:18px; color:var(--cream); margin:12px 18px 8px; }
.comu-aviso p { font-size:14px; color:var(--cream-soft); line-height:1.6; margin:0 18px 12px; font-weight:300; }
.comu-aviso__by { font-size:12px; color:var(--cream-mute); margin:0 18px; }

/* ─── Michi Avisos ────────────────────────────────────────── */
.michi-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(280px, 1fr)); gap:20px; }
.michi-grid:empty { display:none; }
.michi { background:var(--graphite-2); border:1px solid var(--line); border-radius:18px; overflow:hidden; display:flex; flex-direction:column; transition:transform .4s,box-shadow .4s,border-color .4s; }
.michi:hover { transform:translateY(-5px); box-shadow:var(--shadow); border-color:rgba(201,168,128,.5); }
.michi__img { aspect-ratio:4/3; overflow:hidden; background:var(--ink); }
.michi__img img { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.michi:hover .michi__img img { transform:scale(1.05); }
.michi__img--none { display:grid; place-items:center; font-size:48px; opacity:.4; }
.michi__body { padding:20px 24px 24px; display:flex; flex-direction:column; flex:1; }
.michi__cat { font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--gold-light); }
.michi__body h3 { font-family:'Marcellus',serif; font-size:21px; color:var(--cream); margin:8px 0 10px; line-height:1.2; }
.michi__body p { font-size:14.5px; color:var(--cream-soft); font-weight:300; line-height:1.6; flex:1; }
.michi__by { font-size:12px; color:var(--cream-mute); margin-top:16px; }
.michi__wa { margin-top:16px; display:inline-flex; align-items:center; justify-content:center; gap:8px; font-size:13px; font-weight:600; color:#25d366; border:1px solid rgba(37,211,102,.4); border-radius:999px; padding:10px 16px; transition:background .25s,color .25s; }
.michi__wa:hover { background:#25d366; color:#fff; }
.michi-empty { text-align:center; color:var(--cream-mute); font-size:15px; margin-top:10px; }
.michi-empty a { color:var(--gold-light); border-bottom:1px solid var(--gold); }

/* ─── Academia: enciclopedia de razas ─────────────────────── */
.ac-tools { max-width:880px; margin:0 auto 36px; }
.ac-search { position:relative; margin-bottom:20px; }
.ac-search__ic { position:absolute; left:18px; top:50%; transform:translateY(-50%); font-size:16px; opacity:.7; }
.ac-search input { width:100%; background:var(--ink); border:1px solid var(--line); border-radius:999px; padding:15px 20px 15px 48px; color:var(--cream); font-family:inherit; font-size:15px; transition:border-color .25s; }
.ac-search input:focus { outline:none; border-color:var(--gold); }
.ac-filters { display:flex; flex-wrap:wrap; justify-content:center; gap:9px; }
.ac-chip { font-size:13px; font-weight:500; color:var(--cream-soft); background:var(--graphite-2); border:1px solid var(--line); border-radius:999px; padding:9px 16px; cursor:pointer; transition:all .25s; }
.ac-chip:hover { border-color:rgba(201,162,75,.5); color:var(--gold-light); }
.ac-chip.active { background:linear-gradient(135deg,var(--gold-light),var(--gold-deep)); color:#1a1410; border-color:transparent; font-weight:700; }

.breed-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.breed { text-align:left; cursor:pointer; background:var(--graphite-2); border:1px solid var(--line); border-radius:18px; overflow:hidden; font-family:inherit; color:inherit; display:flex; flex-direction:column; transition:transform .45s,box-shadow .45s,border-color .45s; }
.breed:hover { transform:translateY(-8px); box-shadow:var(--shadow),0 0 44px rgba(201,162,75,.14); border-color:rgba(201,162,75,.55); }
.breed__media { aspect-ratio:4/3; overflow:hidden; background:linear-gradient(140deg,var(--graphite-3),var(--ink)); position:relative; }
.breed__media img { width:100%; height:100%; object-fit:cover; object-position:center 25%; transition:transform .6s; }
.img-zoom { position:absolute; bottom:12px; left:50%; transform:translateX(-50%) translateY(6px); opacity:0; font-size:11px; font-weight:600; letter-spacing:.04em; color:var(--gold-light); background:rgba(12,10,8,.78); border:1px solid rgba(201,162,75,.5); border-radius:999px; padding:6px 14px; backdrop-filter:blur(6px); transition:opacity .35s,transform .35s; pointer-events:none; z-index:3; }
.breed:hover .img-zoom, .ac-hist:hover .img-zoom { opacity:1; transform:translateX(-50%) translateY(0); }
.img-zoom--lg { bottom:16px; font-size:12px; padding:8px 16px; }
.acm-hero[data-lbsrc] { cursor:zoom-in; }
.acm-hero[data-lbsrc] .img-zoom { opacity:0; }
.acm-hero[data-lbsrc]:hover .img-zoom { opacity:1; transform:translateX(-50%) translateY(0); }
.breed:hover .breed__media img { transform:scale(1.07); }
.breed__media.noimg::after { content:"🐱"; position:absolute; inset:0; display:grid; place-items:center; font-size:46px; opacity:.4; }
.breed__media.noimg img { display:none; }
.breed__body { padding:22px 24px 24px; display:flex; flex-direction:column; flex:1; }
.breed__name { font-family:'Marcellus',serif; font-size:23px; color:var(--cream); }
.breed__sub { font-size:12px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--gold-light); margin:4px 0 12px; }
.breed__desc { font-size:14px; color:var(--cream-soft); font-weight:300; line-height:1.6; margin-bottom:16px; }
.breed .mcard__go { margin-top:auto; font-size:12.5px; font-weight:600; color:var(--gold-light); display:inline-flex; align-items:center; gap:6px; }
.breed:hover .mcard__go .arrow { transform:translateX(4px); }
.ac-empty { text-align:center; color:var(--cream-mute); margin-top:30px; }

/* Modal academia */
.acmodal { position:fixed; inset:0; z-index:320; display:grid; place-items:center; padding:24px; }
.acmodal[hidden] { display:none; }
.acmodal__bg { position:absolute; inset:0; background:rgba(6,5,4,.86); backdrop-filter:blur(10px); animation:fade .3s ease; }
.acmodal__panel { position:relative; width:min(860px,100%); max-height:90vh; background:linear-gradient(180deg,var(--graphite-2),var(--graphite)); border:1px solid var(--line); border-radius:22px; overflow:hidden; box-shadow:var(--shadow); animation:pop .4s cubic-bezier(.22,1,.36,1); }
.acmodal__x { position:absolute; top:16px; right:16px; z-index:4; width:44px; height:44px; border-radius:50%; background:rgba(12,10,8,.72); border:1px solid var(--line); color:var(--cream); font-size:15px; cursor:pointer; transition:all .25s; }
.acmodal__x:hover { background:var(--gold); color:#1a1410; transform:rotate(90deg); }
.acmodal__scroll { overflow-y:auto; max-height:90vh; }
.acmodal__scroll::-webkit-scrollbar { width:8px; } .acmodal__scroll::-webkit-scrollbar-thumb { background:rgba(201,162,75,.4); border-radius:8px; }
.acm-hero { aspect-ratio:16/8; overflow:hidden; background:linear-gradient(140deg,var(--graphite-3),var(--ink)); position:relative; }
.acm-hero img { width:100%; height:100%; object-fit:cover; object-position:center 22%; }
.acm-hero--prod img { object-fit:contain; background:#000; }
.acm-hero.noimg::after { content:"🐾"; position:absolute; inset:0; display:grid; place-items:center; font-size:54px; opacity:.4; }
.acm-hero.noimg img { display:none; }
.acm-body { padding:clamp(24px,4vw,44px); }
.acm-eyebrow { font-family:'Manrope',sans-serif; font-weight:600; letter-spacing:.2em; text-transform:uppercase; font-size:11px; color:var(--gold); }
.acm-title { font-family:'Marcellus',serif; font-size:clamp(28px,4vw,42px); color:var(--cream); margin:10px 0 4px; }
.acm-sub { font-size:13px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--gold-light); margin-bottom:18px; }
.acm-text { color:var(--cream-soft); line-height:1.75; font-weight:300; margin-bottom:24px; }
.acm-cols { display:grid; grid-template-columns:1fr 1fr; gap:28px; margin-bottom:24px; }
.acm-body h4 { font-family:'Marcellus',serif; font-size:18px; color:var(--gold-light); margin-bottom:14px; }
.stats { display:flex; flex-direction:column; gap:11px; }
.stat { display:flex; align-items:center; gap:10px; font-size:13px; }
.stat__l { width:74px; color:var(--cream-soft); flex-shrink:0; }
.stat__bar { flex:1; height:6px; background:var(--ink); border-radius:999px; overflow:hidden; }
.stat__bar span { display:block; height:100%; background:linear-gradient(90deg,var(--gold-light),var(--gold-deep)); border-radius:999px; }
.stat__n { width:26px; text-align:right; color:var(--gold-light); font-weight:600; }
.acm-ul { list-style:none; padding:0; margin:0; }
.acm-ul li { position:relative; padding-left:24px; margin-bottom:9px; color:var(--cream-soft); font-weight:300; }
.acm-ul li::before { content:"✓"; position:absolute; left:0; color:var(--gold-light); font-weight:700; }
.acm-ul--star li::before { content:"★"; font-size:11px; top:2px; }
.acm-care { background:rgba(201,162,75,.05); border:1px solid var(--line); border-radius:14px; padding:20px 22px; margin-bottom:22px; }
.acm-care p { color:var(--cream-soft); font-weight:300; line-height:1.7; }
.acm-reco { border-top:1px solid var(--line); padding-top:22px; }
.acm-reco__tag { display:inline-block; font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--gold-light); border:1px solid rgba(201,162,75,.5); border-radius:999px; padding:5px 13px; margin-bottom:12px; }
.acm-reco p { color:var(--cream-soft); font-weight:300; margin-bottom:16px; }
.acm-sizes { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.acm-size { display:flex; flex-direction:column; background:rgba(201,162,75,.06); border:1px solid var(--line); border-radius:10px; padding:12px 14px; color:var(--gold-light); font-size:18px; }
.acm-size strong { color:var(--cream); font-size:13px; font-family:'Manrope',sans-serif; letter-spacing:.05em; margin-bottom:3px; }

/* Test interactivo */
.ac-quiz { max-width:720px; margin:70px auto 0; background:linear-gradient(160deg,var(--graphite-3),var(--ink)); border:1px solid rgba(201,162,75,.3); border-radius:24px; padding:clamp(28px,4vw,48px); }
.ac-quiz__head { text-align:center; margin-bottom:28px; }
.ac-quiz__head h3 { font-family:'Marcellus',serif; font-size:clamp(24px,3vw,32px); color:var(--cream); margin:10px 0 8px; }
.ac-quiz__head p { color:var(--cream-soft); font-weight:300; }
.quiz-card { text-align:center; }
.quiz-step { font-size:11px; font-weight:700; letter-spacing:.15em; text-transform:uppercase; color:var(--gold); }
.quiz-card h4 { font-family:'Marcellus',serif; font-size:22px; color:var(--cream); margin:12px 0 24px; }
.quiz-opts { display:flex; flex-direction:column; gap:12px; max-width:440px; margin:0 auto; }
.quiz-opt { background:var(--graphite-2); border:1px solid var(--line); border-radius:12px; padding:15px 20px; color:var(--cream); font-family:inherit; font-size:15px; cursor:pointer; transition:all .25s; }
.quiz-opt:hover { border-color:var(--gold); background:rgba(201,162,75,.08); transform:translateY(-2px); }
.quiz-result { text-align:center; }
.quiz-result__media { width:160px; height:160px; margin:16px auto; border-radius:50%; overflow:hidden; border:2px solid rgba(201,162,75,.5); }
.quiz-result__media img { width:100%; height:100%; object-fit:cover; }
.quiz-result h4 { font-family:'Marcellus',serif; font-size:28px; color:var(--gold-light); }
.quiz-result__sub { font-size:12px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--cream-soft); margin:4px 0 12px; }
.quiz-result p { color:var(--cream-soft); font-weight:300; max-width:440px; margin:0 auto; }
.quiz-result__btns { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top:24px; }

/* Historia / cultura */
.ac-history { margin-top:80px; }
.ac-history__head { text-align:center; margin-bottom:36px; }
.ac-history__head h3 { font-family:'Marcellus',serif; font-size:clamp(24px,3.2vw,36px); color:var(--cream); margin-top:10px; }
.ac-hist-cards { display:grid; grid-template-columns:1fr 1fr; gap:22px; margin-bottom:48px; }
.ac-hist { text-align:left; cursor:pointer; border:none; padding:0; overflow:hidden; display:flex; flex-direction:column; font-family:inherit; color:inherit; transition:transform .4s,box-shadow .4s; }
.ac-hist:hover { transform:translateY(-6px); box-shadow:var(--shadow); }
.ac-hist__media { aspect-ratio:16/9; overflow:hidden; background:linear-gradient(140deg,var(--graphite-3),var(--ink)); position:relative; }
.ac-hist__media img { width:100%; height:100%; object-fit:cover; object-position:center 30%; transition:transform .5s; }
.ac-hist:hover .ac-hist__media img { transform:scale(1.05); }
.ac-hist__media.noimg::after { content:"🐾"; position:absolute; inset:0; display:grid; place-items:center; font-size:40px; opacity:.4; }
.ac-hist__body { padding:22px 24px; }
.ac-hist__body h4 { font-family:'Marcellus',serif; font-size:21px; color:var(--cream); margin-bottom:8px; }
.ac-hist__body p { font-size:14px; color:var(--cream-soft); font-weight:300; line-height:1.6; margin-bottom:12px; }

.ac-timeline { background:var(--graphite-2); border:1px solid var(--line); border-radius:20px; padding:clamp(26px,4vw,40px); }
.ac-tl__title { display:block; text-align:center; font-family:'Marcellus',serif; font-size:22px; color:var(--gold-light); margin-bottom:28px; }
.ac-tl { list-style:none; padding:0; margin:0; display:flex; justify-content:space-between; gap:8px; position:relative; counter-reset:tl; }
.ac-tl::before { content:""; position:absolute; top:7px; left:5%; right:5%; height:1px; background:linear-gradient(90deg,transparent,rgba(201,162,75,.5),transparent); }
.ac-tl li { position:relative; flex:1; text-align:center; display:flex; flex-direction:column; align-items:center; gap:4px; }
.ac-tl__dot { width:14px; height:14px; border-radius:50%; background:var(--gold); box-shadow:0 0 0 4px rgba(201,162,75,.15); position:relative; z-index:2; margin-bottom:8px; }
.ac-tl strong { font-size:13px; color:var(--cream); }
.ac-tl em { font-size:11px; color:var(--cream-mute); font-style:normal; line-height:1.4; }

.ac-knowledge { display:flex; flex-wrap:wrap; justify-content:center; gap:10px; margin-top:54px; }
.ac-kbtn { font-family:'Manrope',sans-serif; font-size:13px; font-weight:600; color:var(--cream); background:var(--graphite-2); border:1px solid var(--line); border-radius:999px; padding:11px 20px; cursor:pointer; transition:all .25s; }
.ac-kbtn:hover { border-color:var(--gold); color:var(--gold-light); transform:translateY(-2px); }

/* ─── Lightbox premium ────────────────────────────────────── */
.lightbox { position:fixed; inset:0; z-index:300; display:grid; place-items:center; padding:28px; }
.lightbox[hidden] { display:none; }
.lightbox__bg { position:absolute; inset:0; background:rgba(6,5,4,.9); backdrop-filter:blur(10px); animation:fade .3s ease; }
.lightbox__fig { position:relative; z-index:2; max-width:min(92vw,1000px); max-height:88vh; animation:pop .45s cubic-bezier(.22,1,.36,1); }
.lightbox__fig img { max-width:100%; max-height:84vh; object-fit:contain; border-radius:14px; box-shadow:0 30px 80px rgba(0,0,0,.6); border:1px solid rgba(201,162,75,.3); background:#0c0a08; opacity:0; transition:opacity .45s ease; }
.lightbox__fig img.loaded { opacity:1; }
.lightbox__cap { text-align:center; color:var(--cream-soft); font-size:14px; margin-top:14px; }
.lightbox__x { position:absolute; top:-14px; right:-14px; width:44px; height:44px; border-radius:50%; background:var(--gold); color:#1a1410; border:none; font-size:16px; font-weight:700; cursor:pointer; box-shadow:0 8px 24px rgba(0,0,0,.4); transition:transform .25s; z-index:3; }
.lightbox__x:hover { transform:rotate(90deg) scale(1.05); }
.arena__media { cursor:zoom-in; }

/* ─── Responsive ──────────────────────────────────────────── */
@media (max-width: 1024px) {
  .nav__links, .nav__cta { display: none; }
  .nav__burger { display: flex; }
  .ben-grid { grid-template-columns: repeat(2, 1fr); }
  .cat-grid { grid-template-columns: repeat(2, 1fr); }
  .cat-grid--8 { grid-template-columns: repeat(2, 1fr); }
  .prod-grid { grid-template-columns: 1fr; max-width:420px; margin:0 auto; }
  .mundo-grid { grid-template-columns: repeat(2, 1fr); }
  .guide__inner { grid-template-columns:1fr; }
  .testi-grid { grid-template-columns: 1fr; }
  .ally__cols { grid-template-columns: 1fr; gap:0; }
  .arena-grid { grid-template-columns: 1fr; max-width:480px; margin:0 auto; }
  .feat2-grid { grid-template-columns:1fr; }
  .comu-form__grid { grid-template-columns:1fr; }
  .arena__sizes { grid-template-columns:1fr 1fr; }
  .comu-aprob__grid { grid-template-columns:1fr; max-width:420px; margin:24px auto 0; }
  .breed-grid { grid-template-columns:1fr 1fr; }
  .ac-hist-cards { grid-template-columns:1fr; }
  .acm-cols { grid-template-columns:1fr; }
  .ac-tl { flex-wrap:wrap; gap:18px; }
  .ac-tl::before { display:none; }
  .ac-tl li { flex:0 0 28%; }
  .trust-grid { grid-template-columns: repeat(2, 1fr); }
  .feat { grid-template-columns: 1fr; }
  .feat__media { max-width: 440px; margin: 0 auto; }
  .footer__row { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .michi-grid { grid-template-columns:1fr; max-width:400px; margin:0 auto; }
  .ben-grid, .cat-grid, .trust-grid { grid-template-columns: 1fr; }
  .cat-grid--8 { grid-template-columns: 1fr 1fr; }
  .mundo-grid { grid-template-columns: 1fr; }
  .race-grid { grid-template-columns: 1fr; }
  .footer__row { grid-template-columns: 1fr; gap: 28px; }
  .breed-grid { grid-template-columns:1fr; max-width:380px; margin:0 auto; }
  .ac-tl li { flex:0 0 42%; }
  .acm-sizes, .acm-cols { grid-template-columns:1fr; }
  .arena__sizes { grid-template-columns:1fr; }
  .quiz-result__btns { flex-direction:column; }
}
