@import url('https://fonts.googleapis.com/css2?family=Archivo+Black&family=Rubik:wght@400;500;600;700&display=swap');

:root {
  --turf: #1b4332;
  --turf-light: #2d6a4f;
  --gold: #e9c46a;
  --navy: #1d3557;
  --red: #e63946;
  --bg: #f8f9fa;
  --white: #fff;
  --ink: #14213d;
  --muted: #6c757d;
  --border: #dee2e6;
  --max: 1180px;
  --radius: 14px;
  --shadow: 0 16px 40px rgba(20,33,61,.1);
  --font-display: 'Archivo Black', Impact, sans-serif;
  --font-ui: 'Rubik', system-ui, sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-ui);color:var(--ink);background:var(--bg);line-height:1.6;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--turf);text-decoration:none}
a:hover{color:var(--red)}
.skip-link{position:absolute;left:-9999px;top:0;z-index:999;background:var(--red);color:#fff;padding:8px 16px}
.skip-link:focus{left:0}

/* ── Animaciones globales ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(32px)}to{opacity:1;transform:none}}
@keyframes fadeLeft{from{opacity:0;transform:translateX(-40px)}to{opacity:1;transform:none}}
@keyframes fadeRight{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:none}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes pulseGlow{0%,100%{box-shadow:0 0 0 0 rgba(233,196,106,.5)}50%{box-shadow:0 0 24px 6px rgba(233,196,106,.25)}}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes shimmer{0%{background-position:-200% center}100%{background-position:200% center}}
@keyframes yardScroll{0%{background-position:0 0}100%{background-position:80px 0}}
@keyframes spinSlow{to{transform:rotate(360deg)}}
@keyframes pricePop{0%{transform:scale(.9);opacity:0}60%{transform:scale(1.04)}100%{transform:scale(1);opacity:1}}

.top-bar{background:var(--navy);color:#fff;font-size:.78rem;padding:8px 20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}
.tasa-bcv{color:var(--gold);font-weight:600;animation:pulseGlow 3s ease infinite}

.site-header{position:sticky;top:0;z-index:200;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:3px solid var(--turf);box-shadow:0 4px 20px rgba(0,0,0,.06);transition:.3s}
.header-inner{max-width:var(--max);margin:0 auto;padding:12px 20px;display:flex;align-items:center;gap:16px}
.logo{display:inline-flex;align-items:center;gap:10px;text-decoration:none!important;color:var(--ink)!important}
.logo-mark svg{width:44px;height:44px;transition:.3s}
.logo:hover .logo-mark svg{transform:rotate(-8deg) scale(1.05)}
.logo-word{display:flex;flex-direction:column;line-height:1}
.logo-name{font-family:var(--font-display);font-size:1.1rem;letter-spacing:.02em;text-transform:uppercase}
.logo-sub{font-size:.72rem;font-weight:700;color:var(--red);letter-spacing:.15em;text-transform:uppercase}

.nav-panel{display:flex;gap:4px;margin-left:auto;flex-wrap:wrap}
.nav-panel a{padding:8px 14px;border-radius:8px;font-size:.85rem;font-weight:600;color:var(--muted);transition:.25s;position:relative}
.nav-panel a::after{content:'';position:absolute;bottom:4px;left:50%;width:0;height:2px;background:var(--gold);transition:.25s;transform:translateX(-50%)}
.nav-panel a:hover::after,.nav-panel a.active::after{width:60%}
.nav-panel a:hover,.nav-panel a.active{background:var(--turf);color:#fff}
.nav-btn{display:none;border:0;background:var(--bg);padding:10px 14px;border-radius:8px;font-size:1.2rem;cursor:pointer;margin-left:auto}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 24px;border-radius:10px;font-weight:700;font-size:.9rem;border:0;cursor:pointer;transition:.25s;text-decoration:none!important;font-family:inherit;position:relative;overflow:hidden}
.btn-primary{background:var(--red);color:#fff;box-shadow:0 6px 20px rgba(230,57,70,.35)}
.btn-primary:hover{transform:translateY(-3px);color:#fff;background:#c1121f;box-shadow:0 12px 28px rgba(230,57,70,.4)}
.btn-turf{background:var(--turf);color:#fff}
.btn-turf:hover{background:var(--turf-light);color:#fff;transform:translateY(-2px)}
.btn-outline{background:transparent;border:2px solid var(--turf);color:var(--turf)}
.btn-sm{padding:8px 16px;font-size:.82rem}
.btn-block{width:100%}
.btn-shine::before{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);transition:.5s}
.btn-shine:hover::before{left:120%}

/* ── Hero espectacular ── */
.hero-sport{position:relative;background:linear-gradient(135deg,var(--navy) 0%,#0d1b2a 50%,var(--turf) 100%);color:#fff;overflow:hidden;min-height:92vh;display:flex;align-items:center;padding:48px 20px 90px}
.hero-sport::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(90deg,rgba(255,255,255,.04) 0,rgba(255,255,255,.04) 40px,transparent 40px,transparent 80px);animation:yardScroll 8s linear infinite}
.hero-sport::after{content:'';position:absolute;bottom:0;left:0;right:0;height:10px;background:repeating-linear-gradient(90deg,var(--gold) 0 40px,var(--turf) 40px 80px)}
.hero-particles{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.hero-particles span{position:absolute;font-size:1.4rem;opacity:.12;animation:float 6s ease-in-out infinite}
.hero-particles span:nth-child(1){top:15%;left:8%;animation-delay:0s}
.hero-particles span:nth-child(2){top:60%;left:15%;animation-delay:1s;font-size:2rem}
.hero-particles span:nth-child(3){top:30%;right:12%;animation-delay:2s}
.hero-particles span:nth-child(4){bottom:25%;right:20%;animation-delay:.5s;font-size:1.8rem}
.hero-particles span:nth-child(5){top:45%;left:45%;animation-delay:1.5s}
.hero-inner{max-width:var(--max);margin:0 auto;display:grid;gap:40px;align-items:center;width:100%;position:relative;z-index:1}
@media(min-width:900px){.hero-inner{grid-template-columns:1.1fr 1fr}}
.hero-copy{animation:fadeLeft .9s ease both}
.hero-tag{display:inline-block;background:var(--red);color:#fff;font-size:.7rem;font-weight:700;padding:6px 14px;border-radius:4px;text-transform:uppercase;letter-spacing:.12em;margin-bottom:16px;animation:pulseGlow 2.5s ease infinite}
.hero-sport h1{font-family:var(--font-display);font-size:clamp(2.2rem,6vw,4rem);line-height:1.02;text-transform:uppercase;margin-bottom:18px}
.hero-sport h1 span{color:var(--gold);display:inline-block;animation:fadeUp .8s .2s ease both}
.hero-sport .lead{color:rgba(255,255,255,.85);max-width:500px;margin-bottom:28px;font-size:1.08rem;animation:fadeUp .8s .35s ease both}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;animation:fadeUp .8s .5s ease both}
.hero-stats-row{display:flex;flex-wrap:wrap;gap:20px;margin-top:28px;animation:fadeUp .8s .65s ease both}
.hero-stat{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:12px 18px;backdrop-filter:blur(6px)}
.hero-stat strong{display:block;font-family:var(--font-display);font-size:1.5rem;color:var(--gold)}
.hero-stat span{font-size:.75rem;opacity:.8;text-transform:uppercase;letter-spacing:.06em}
.hero-photo{border-radius:var(--radius);overflow:hidden;box-shadow:0 32px 64px rgba(0,0,0,.35);border:4px solid var(--gold);position:relative;animation:fadeRight .9s .3s ease both}
.hero-photo img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .1s linear}
.hero-photo::before{content:'';position:absolute;inset:0;border:2px solid rgba(233,196,106,.4);border-radius:var(--radius);animation:pulseGlow 3s ease infinite;pointer-events:none;z-index:2}
.hero-badge{position:absolute;bottom:16px;left:16px;background:var(--turf);color:#fff;padding:10px 16px;border-radius:8px;font-weight:700;font-size:.85rem;z-index:3;animation:float 4s ease-in-out infinite}
.hero-float-card{position:absolute;top:16px;right:-8px;background:var(--red);color:#fff;padding:12px 16px;border-radius:10px;font-weight:700;font-size:.8rem;z-index:3;box-shadow:var(--shadow);animation:float 3s ease-in-out infinite}
@media(max-width:899px){.hero-float-card{right:8px;top:auto;bottom:60px}}

.strip-shipping{background:var(--turf);color:#fff;text-align:center;padding:14px 20px;font-size:.88rem;font-weight:600;position:relative;overflow:hidden}
.strip-shipping::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);animation:shimmer 3s linear infinite;background-size:200% 100%}

/* ── Stats bar ── */
.stats-bar{background:var(--white);border-bottom:1px solid var(--border);padding:40px 20px}
.stats-grid{max-width:var(--max);margin:0 auto;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));text-align:center}
.stat-item{padding:16px;border-radius:var(--radius);transition:.3s}
.stat-item:hover{transform:translateY(-4px);background:var(--bg)}
.stat-num{font-family:var(--font-display);font-size:clamp(2rem,4vw,2.8rem);color:var(--turf);line-height:1}
.stat-num span{color:var(--red)}
.stat-label{font-size:.82rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-top:6px}

/* ── Marquee ── */
.marquee-wrap{background:var(--navy);color:rgba(255,255,255,.7);padding:14px 0;overflow:hidden;border-top:2px solid var(--gold);border-bottom:2px solid var(--gold)}
.marquee-inner{display:flex;width:max-content;animation:marquee 28s linear infinite}
.marquee-track{display:flex;gap:48px;padding:0 24px;white-space:nowrap;font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.1em}
.marquee-track span{color:var(--gold)}

.section{padding:72px 20px}
.section-head{max-width:640px;margin-bottom:40px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-head h2{font-family:var(--font-display);font-size:clamp(1.6rem,3.5vw,2.4rem);text-transform:uppercase;margin-bottom:12px}
.section-head p{color:var(--muted)}

.cats-grid{max-width:var(--max);margin:0 auto;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}
.cat-tile{position:relative;background:var(--white);border-radius:var(--radius);padding:80px 16px 24px;text-align:center;border:2px solid var(--border);transition:.35s;cursor:pointer;overflow:hidden;min-height:180px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end}
.cat-tile::before{content:'';position:absolute;inset:0;background-size:cover;background-position:center;opacity:.25;transition:.4s;transform:scale(1)}
.cat-tile:hover::before{opacity:.45;transform:scale(1.08)}
.cat-tile:hover{border-color:var(--gold);transform:translateY(-8px) scale(1.02);box-shadow:0 24px 48px rgba(20,33,61,.18)}
.cat-tile .ico{font-size:2.2rem;margin-bottom:10px;position:relative;z-index:1;transition:.3s}
.cat-tile:hover .ico{transform:scale(1.2) rotate(-5deg)}
.cat-tile span{font-weight:700;font-size:.9rem;color:var(--navy);position:relative;z-index:1}
.cat-tile--proteccion::before{background-image:url('../assets/img/cat-proteccion.jpg')}
.cat-tile--balones::before{background-image:url('../assets/img/cat-balones.jpg')}
.cat-tile--calzado::before{background-image:url('../assets/img/cat-calzado.jpg')}
.cat-tile--entrenamiento::before{background-image:url('../assets/img/cat-entrenamiento.jpg')}
.cat-tile--indumentaria::before{background-image:url('../assets/img/cat-indumentaria.jpg')}

.featured-grid{max-width:var(--max);margin:0 auto;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.card-prod{background:var(--white);border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow);transition:.35s}
.card-prod:hover{transform:translateY(-8px);box-shadow:0 28px 56px rgba(20,33,61,.18)}
.card-prog-img{position:relative;aspect-ratio:1;overflow:hidden;background:#eee}
.card-prog-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.25,.46,.45,.94)}
.card-prod:hover .card-prog-img img{transform:scale(1.1) rotate(1deg)}
.badge-pop{position:absolute;top:12px;left:12px;background:var(--red);color:#fff;font-size:.68rem;font-weight:700;padding:5px 10px;border-radius:4px;text-transform:uppercase;z-index:2}
.badge-size{position:absolute;top:12px;right:12px;background:var(--gold);color:var(--ink);font-size:.68rem;font-weight:700;padding:5px 8px;border-radius:4px;z-index:2}
.badge-precio-fijo{position:absolute;bottom:12px;left:12px;background:rgba(27,67,50,.92);color:var(--gold);font-size:.78rem;font-weight:700;padding:6px 12px;border-radius:6px;z-index:2;backdrop-filter:blur(4px)}
.card-prog-body{padding:20px}
.card-sku{font-size:.7rem;color:var(--muted);letter-spacing:.08em}
.card-prog-body h3{font-size:1.05rem;margin:8px 0;font-weight:700}
.card-prog-body p{font-size:.85rem;color:var(--muted);margin-bottom:10px}
.feat-chips{display:flex;flex-wrap:wrap;gap:6px;list-style:none;margin:0 0 12px;padding:0}
.feat-chips li{font-size:.68rem;font-weight:600;background:var(--bg);color:var(--turf);padding:4px 8px;border-radius:4px;border:1px solid var(--border)}

.card-precio{margin-bottom:14px;padding:14px;background:linear-gradient(135deg,#f0fdf4,#fff);border-radius:10px;border:1px solid rgba(27,67,50,.15);animation:pricePop .5s ease both}
.card-precio--fijo{border-color:var(--gold);background:linear-gradient(135deg,rgba(233,196,106,.12),#fff)}
.precio-label{display:inline-block;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--red);margin-bottom:6px}
.precio-row{display:flex;align-items:baseline;gap:8px}
.card-precio .usd{font-size:1.6rem;font-weight:700;color:var(--turf);font-family:var(--font-display)}
.usd-tag{font-size:.7rem;font-weight:700;color:var(--muted);background:var(--bg);padding:2px 6px;border-radius:4px}
.card-precio .bs-ref{display:block;font-size:.8rem;color:var(--navy);font-weight:600;margin-top:4px}
.precio-nota{display:block;font-size:.68rem;color:var(--muted);margin-top:6px}
.price-updated .usd,.price-updated .bs-ref{animation:pricePop .4s ease}

/* ── Tabla precios ── */
.precios-section{background:var(--white)}
.tabla-precios-wrap{max-width:var(--max);margin:0 auto;overflow-x:auto;border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border)}
.tabla-precios{width:100%;border-collapse:collapse;font-size:.88rem}
.tabla-precios thead{background:var(--navy);color:#fff}
.tabla-precios th{padding:14px 16px;text-align:left;font-size:.75rem;text-transform:uppercase;letter-spacing:.06em}
.tabla-precios td{padding:14px 16px;border-bottom:1px solid var(--border);vertical-align:middle}
.tabla-precios tbody tr{transition:.2s}
.tabla-precios tbody tr:hover{background:rgba(233,196,106,.08)}
.tab-precio{font-family:var(--font-display);font-size:1.1rem;color:var(--turf)}
.tab-bs{font-weight:600;color:var(--navy)}
.tab-sku{font-size:.72rem;color:var(--muted)}

/* ── Galería mosaic ── */
.gallery-section{background:var(--navy);color:#fff;padding:72px 20px}
.gallery-section .section-head h2{color:#fff}
.gallery-section .section-head p{color:rgba(255,255,255,.65)}
.gallery-mosaic{max-width:var(--max);margin:0 auto;display:grid;gap:12px;grid-template-columns:repeat(12,1fr);grid-auto-rows:140px}
@media(min-width:768px){.gallery-mosaic{grid-auto-rows:180px}}
.g-item{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s,filter .3s}
.g-item:hover img{transform:scale(1.08);filter:brightness(1.1)}
.g-item::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.5),transparent);opacity:0;transition:.3s}
.g-item:hover::after{opacity:1}
.g-item span{position:absolute;bottom:12px;left:12px;font-weight:700;font-size:.85rem;z-index:2;opacity:0;transform:translateY(8px);transition:.3s}
.g-item:hover span{opacity:1;transform:none}
.g-item--1{grid-column:span 6;grid-row:span 2}
.g-item--2{grid-column:span 3}
.g-item--3{grid-column:span 3}
.g-item--4{grid-column:span 4}
.g-item--5{grid-column:span 4}
.g-item--6{grid-column:span 4}
@media(max-width:767px){.g-item--1,.g-item--2,.g-item--3,.g-item--4,.g-item--5,.g-item--6{grid-column:span 6;grid-row:span 1}}

/* ── Niveles ── */
.niveles-grid{max-width:var(--max);margin:0 auto;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.nivel-card{background:var(--white);border-radius:var(--radius);padding:28px;border:2px solid var(--border);transition:.35s;position:relative;overflow:hidden}
.nivel-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--turf),var(--gold),var(--red));transform:scaleX(0);transform-origin:left;transition:.4s}
.nivel-card:hover::before{transform:scaleX(1)}
.nivel-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--turf)}
.nivel-icon{font-size:2.5rem;margin-bottom:12px;display:block}
.nivel-card h3{font-family:var(--font-display);text-transform:uppercase;font-size:1.1rem;margin-bottom:10px}
.nivel-card p{font-size:.88rem;color:var(--muted);margin-bottom:12px}
.nivel-card ul{list-style:none;font-size:.85rem}
.nivel-card li{padding:6px 0 6px 20px;position:relative;border-bottom:1px solid var(--border)}
.nivel-card li::before{content:'✓';position:absolute;left:0;color:var(--turf);font-weight:700}

.split-band{background:var(--white);padding:64px 20px}
.split-row{max-width:var(--max);margin:0 auto;display:grid;gap:40px;align-items:center}
@media(min-width:768px){.split-row{grid-template-columns:1fr 1fr}}
.split-media{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);position:relative}
.split-media img{width:100%;aspect-ratio:16/10;object-fit:cover;transition:transform .6s}
.split-media:hover img{transform:scale(1.05)}
.split-media::after{content:'🏈';position:absolute;top:16px;right:16px;font-size:2rem;animation:float 3s ease infinite}
.split-text h3{font-family:var(--font-display);font-size:1.6rem;text-transform:uppercase;margin-bottom:14px}
.split-list{list-style:none;margin:16px 0}
.split-list li{padding:8px 0 8px 28px;position:relative;border-bottom:1px solid var(--border);font-size:.92rem;transition:.2s}
.split-list li:hover{padding-left:32px;color:var(--turf)}
.split-list li::before{content:'🏈';position:absolute;left:0;transition:.2s}

.contact-section{background:linear-gradient(180deg,var(--white),var(--bg))}
.contact-grid{max-width:var(--max);margin:0 auto;display:grid;gap:28px}
@media(min-width:768px){.contact-grid{grid-template-columns:1fr 1fr}}
.contact-box{background:var(--white);padding:28px;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);transition:.3s}
.contact-box:hover{box-shadow:0 24px 48px rgba(20,33,61,.12)}
.contact-box label{display:block;font-size:.85rem;font-weight:600;margin:10px 0 6px}
.contact-box input,.contact-box textarea{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:8px;font-family:inherit;transition:.2s}
.contact-box input:focus,.contact-box textarea:focus{outline:none;border-color:var(--turf);box-shadow:0 0 0 3px rgba(27,67,50,.12)}
.contact-box textarea{min-height:110px;resize:vertical}
.mapa iframe{width:100%;height:220px;border:0;border-radius:8px;margin-top:14px}
.legal-note{font-size:.8rem;color:var(--muted);margin-top:12px}

.site-footer{background:var(--navy);color:rgba(255,255,255,.75);padding:56px 20px 28px}
.footer-grid{max-width:var(--max);margin:0 auto 32px;display:grid;gap:32px}
@media(min-width:768px){.footer-grid{grid-template-columns:2fr 1fr 1fr}}
.site-footer h4{color:var(--gold);margin-bottom:12px;font-size:.78rem;text-transform:uppercase;letter-spacing:.1em}
.site-footer ul{list-style:none}
.site-footer li{margin:8px 0}
.site-footer a{color:rgba(255,255,255,.65)}
.site-footer a:hover{color:var(--gold)}
.footer-bottom{max-width:var(--max);margin:0 auto;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);text-align:center;font-size:.85rem}
.logo--footer .logo-name,.logo--footer .logo-sub{color:#fff}

.wa-float{position:fixed;right:20px;bottom:20px;z-index:150;width:56px;height:56px;background:#25D366;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;box-shadow:var(--shadow);animation:pulseGlow 2s ease infinite;transition:.3s}
.wa-float:hover{transform:scale(1.1)}
.scroll-top{position:fixed;right:20px;bottom:86px;z-index:150;width:44px;height:44px;border:0;border-radius:50%;background:var(--red);color:#fff;cursor:pointer;opacity:0;pointer-events:none;transition:.3s}
.scroll-top.visible{opacity:1;pointer-events:auto}
.scroll-top:hover{transform:translateY(-4px)}

.cookie-banner{position:fixed;bottom:16px;left:16px;right:16px;max-width:500px;margin:0 auto;z-index:300;background:var(--white);padding:18px;border-radius:var(--radius);box-shadow:var(--shadow);transform:translateY(120%);transition:.35s;border:1px solid var(--border)}
.cookie-banner.show{transform:translateY(0)}
.cookie-inner{display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.cookie-inner p{font-size:.82rem;color:var(--muted);flex:1;min-width:180px}
.cookie-actions{display:flex;gap:8px;flex-wrap:wrap}

.page-hero-cat{position:relative;background:var(--navy);color:#fff;padding:110px 20px 70px;text-align:center;overflow:hidden}
.page-hero-cat-bg{position:absolute;inset:0;background:url('../assets/img/cat-hero.jpg') center/cover no-repeat;opacity:.35;animation:yardScroll 20s linear infinite;background-size:120% auto}
.page-hero-cat h1{position:relative;font-family:var(--font-display);font-size:clamp(2rem,4vw,3rem);text-transform:uppercase;animation:fadeUp .8s ease both}
.page-hero-cat p{position:relative;opacity:.9;margin-top:10px;animation:fadeUp .8s .2s ease both}
.chips-wrap{max-width:var(--max);margin:-28px auto 32px;padding:0 20px;position:relative;z-index:2}
.chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;background:var(--white);padding:14px;border-radius:12px;box-shadow:var(--shadow)}
.chip{padding:9px 18px;border:0;border-radius:8px;background:var(--bg);cursor:pointer;font-weight:600;font-size:.85rem;font-family:inherit;color:var(--muted);transition:.25s}
.chip.active,.chip:hover{background:var(--turf);color:#fff;transform:translateY(-2px)}
.catalogo-grid{max-width:var(--max);margin:0 auto 64px;padding:0 20px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}

.legal-page-header{background:var(--navy);color:#fff;padding:90px 20px 40px;text-align:center}
.legal-page-header h1{font-family:var(--font-display);text-transform:uppercase}
.pagina-legal{max-width:720px;margin:0 auto;padding:40px 24px 80px}
.pagina-legal h2{margin:24px 0 10px;color:var(--turf);font-size:1.1rem}
.pagina-legal ul{margin:10px 0 10px 1.2rem}

.cta-band{position:relative;background:linear-gradient(135deg,var(--turf),var(--turf-light));color:#fff;text-align:center;padding:64px 20px;overflow:hidden}
.cta-band::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(90deg,rgba(255,255,255,.03) 0 40px,transparent 40px 80px);animation:yardScroll 6s linear infinite}
.cta-band > *{position:relative;z-index:1}
.cta-band h2{font-family:var(--font-display);text-transform:uppercase;margin-bottom:12px;font-size:clamp(1.5rem,3vw,2.2rem)}

.reveal{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s ease}
.reveal.is-visible{opacity:1;transform:none}
.disclaimer-block{max-width:var(--max);margin:0 auto;padding:20px;text-align:center;font-size:.75rem;color:var(--muted)}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .reveal{opacity:1;transform:none}
}

@media(max-width:900px){
  .nav-btn{display:block}
  .nav-panel{display:none;position:fixed;inset:0;top:58px;background:var(--white);flex-direction:column;padding:24px}
  .nav-panel.open{display:flex}
  body.nav-open{overflow:hidden}
  .header-inner .btn-primary.header-cta{display:none}
}
