/* ============================================================
   DESIGN SYSTEM — Industrial / Editorial Moto Culture
   Escuela de Ruta · Motoviajero Paraguay
   ============================================================ */
*{margin:0;padding:0;box-sizing:border-box}

:root{
  --noir:#0E0E0C;
  --noir-soft:#1A1916;
  --primary:#D85A30;
  --primary-deep:#993C1D;
  --primary-light:#F0997B;
  --cream:#F4ECD8;
  --cream-soft:#FAF6EC;
  --signal:#F5C842;
  --text:#1F1E1B;
  --text-soft:#45433F;
  --muted:#6B6864;
  --muted-soft:#8E8B85;
  --white:#FFFFFF;
  --border:rgba(14,14,12,0.12);
  --border-dark:rgba(255,255,255,0.10);
  --green:#1D9E75;
  --red:#A32D2D;

  --font-display:'Big Shoulders Display',Impact,sans-serif;
  --font-body:'Manrope',system-ui,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
}

html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--cream);
  color:var(--text);
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

/* Grain overlay */
.grain{position:relative;isolation:isolate}
.grain::before{
  content:'';
  position:absolute;inset:0;
  pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,%3Csvg viewBox='0 0 250 250' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.6 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.18;mix-blend-mode:overlay;z-index:1;
}
.grain > *{position:relative;z-index:2}

/* Typography */
h1{font-family:var(--font-display);font-weight:900;line-height:.88;letter-spacing:-.02em;text-transform:uppercase}
h2{font-family:var(--font-display);font-weight:800;line-height:.95;letter-spacing:-.015em;text-transform:uppercase;font-size:clamp(2.2rem,5vw,3.6rem)}
h3{font-family:var(--font-display);font-weight:700;line-height:1;letter-spacing:-.005em;text-transform:uppercase}
p{font-size:1rem;line-height:1.7}

.section-tag{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-mono);
  font-size:11px;font-weight:500;
  letter-spacing:.12em;color:var(--primary);
  margin-bottom:1.25rem;
}
.section-tag::before{content:'';width:24px;height:1px;background:var(--primary)}
.dark .section-tag{color:var(--primary-light)}
.dark .section-tag::before{background:var(--primary-light)}

/* Icons */
.icon{width:24px;height:24px;display:inline-block;vertical-align:middle;flex-shrink:0;stroke:currentColor;stroke-width:1.5;fill:none;stroke-linecap:round;stroke-linejoin:round}
.icon-lg{width:32px;height:32px}
.icon-xl{width:40px;height:40px}

/* ============================================================
   NAV
   ============================================================ */
nav{
  background:var(--noir);
  position:sticky;top:0;z-index:200;
  height:64px;padding:0 2rem;
  display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid var(--border-dark);
}
.nav-logo{color:#fff;font-size:14px;font-weight:600;display:flex;align-items:center;gap:10px;text-decoration:none;letter-spacing:.02em;font-family:var(--font-body)}
.nav-logo-mark{font-family:var(--font-display);font-weight:900;font-size:22px;color:var(--primary);letter-spacing:-.02em;line-height:1}
.nav-logo-mark sup{font-size:9px;color:var(--cream);font-family:var(--font-mono);font-weight:500;margin-left:2px;vertical-align:top}
.nav-links{display:flex;gap:1.75rem}
.nav-links a{color:rgba(255,255,255,0.6);text-decoration:none;font-size:12px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;transition:color .2s;font-family:var(--font-body)}
.nav-links a:hover{color:#fff}
.nav-cta{
  background:var(--primary);color:#fff;
  padding:9px 18px;
  font-size:11px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;text-decoration:none;
  font-family:var(--font-body);
  border:1px solid var(--primary);
  transition:background .2s,color .2s;
}
.nav-cta:hover{background:transparent;color:var(--primary)}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  display:grid;
  grid-template-columns:1fr 1.15fr;
  min-height:calc(100vh - 64px);
  background:var(--noir);
  color:#fff;
  position:relative;
}
.hero-photo{
  background:url('foto-hero.jpg') center/cover no-repeat,linear-gradient(135deg,#1a1a1a,#2d1a10);
  position:relative;
  border-right:1px solid var(--border-dark);
}
.hero-photo::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(120deg,rgba(14,14,12,0) 30%,rgba(14,14,12,0.5) 100%);
}
.hero-photo-meta{
  position:absolute;left:1.5rem;bottom:1.5rem;
  font-family:var(--font-mono);font-size:10px;
  color:rgba(255,255,255,0.65);
  letter-spacing:.15em;text-transform:uppercase;z-index:2;
}
.hero-photo-meta::before{content:'◉ ';color:var(--primary)}
.hero-photo-vside{
  position:absolute;top:1.5rem;left:1.5rem;
  font-family:var(--font-mono);font-size:10px;
  color:rgba(255,255,255,0.4);
  letter-spacing:.2em;text-transform:uppercase;
  writing-mode:vertical-rl;transform:rotate(180deg);z-index:2;
}

.hero-text{
  padding:3rem 3.5rem;
  display:flex;flex-direction:column;justify-content:center;
  position:relative;
}
.hero-meta{
  font-family:var(--font-mono);font-size:11px;
  color:rgba(255,255,255,0.45);
  letter-spacing:.15em;text-transform:uppercase;
  margin-bottom:2rem;
  display:flex;align-items:center;gap:12px;
}
.hero-meta::before{content:'';width:32px;height:1px;background:var(--primary)}
.hero h1{font-size:clamp(2.8rem,7.5vw,6rem);margin-bottom:1.5rem;color:#fff}
.hero h1 .line{display:block}
.hero h1 .accent{color:var(--primary)}
.hero-sub{
  font-family:var(--font-body);font-weight:400;
  font-size:clamp(.95rem,1.1vw,1.05rem);
  color:rgba(255,255,255,0.65);
  max-width:520px;line-height:1.6;
  margin-bottom:2.25rem;
}
.hero-cta{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:2.5rem}
.btn-bold{
  background:var(--primary);color:#fff;border:1px solid var(--primary);
  padding:14px 26px;
  font-family:var(--font-body);font-size:12px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  text-decoration:none;cursor:pointer;transition:all .25s;
  display:inline-flex;align-items:center;gap:10px;
}
.btn-bold:hover{background:transparent;color:var(--primary);transform:translateX(2px)}
.btn-bold:disabled{background:#444;border-color:#444;color:#888;cursor:not-allowed;transform:none}
.btn-line{
  background:transparent;color:#fff;
  border:1px solid rgba(255,255,255,0.25);
  padding:14px 26px;
  font-family:var(--font-body);font-size:12px;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  text-decoration:none;cursor:pointer;transition:all .25s;
}
.btn-line:hover{border-color:#fff;background:rgba(255,255,255,0.04)}
.hero-credit{
  font-family:var(--font-mono);font-size:11px;
  color:rgba(255,255,255,0.35);
  letter-spacing:.12em;text-transform:uppercase;
  border-top:1px solid var(--border-dark);
  padding-top:1.5rem;
  display:flex;flex-wrap:wrap;gap:1.5rem;
}
.hero-credit span:not(:last-child)::after{content:'';display:inline-block;width:4px;height:4px;background:var(--primary);border-radius:50%;margin-left:1.5rem;vertical-align:middle}

/* Ticker */
.ticker{
  background:var(--primary);color:#fff;
  padding:14px 0;overflow:hidden;position:relative;
  border-top:1px solid var(--primary-deep);
  border-bottom:1px solid var(--primary-deep);
}
.ticker-track{
  display:flex;gap:3rem;
  animation:scroll 35s linear infinite;
  white-space:nowrap;width:max-content;
}
.ticker-item{
  font-family:var(--font-display);font-weight:800;font-size:18px;
  letter-spacing:.05em;text-transform:uppercase;
  display:flex;align-items:center;gap:3rem;
}
.ticker-item::after{content:'◉';color:rgba(255,255,255,0.5);font-size:10px}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   PROBLEMA — Stats
   ============================================================ */
.problema{background:var(--noir);color:#fff;padding:6rem 2rem;position:relative;overflow:hidden}
.problema-inner{max-width:1200px;margin:0 auto;position:relative;z-index:2}
.problema-header{margin-bottom:4rem;max-width:900px}
.problema-header h2{color:#fff;font-size:clamp(2.4rem,5.5vw,4.2rem)}
.problema-header h2 .accent{color:var(--primary)}
.problema-lead{color:rgba(255,255,255,0.55);font-size:1.05rem;margin-top:1.25rem;max-width:580px}

.stats-layout{
  display:grid;grid-template-columns:1.4fr 1fr;gap:3rem;
  align-items:stretch;
  border-top:1px solid var(--border-dark);padding-top:3rem;
}
.stat-headline{display:flex;flex-direction:column;justify-content:center}
.stat-headline-num{
  display:flex;align-items:flex-start;
  font-family:var(--font-display);color:var(--primary);
  line-height:.85;letter-spacing:-.04em;font-weight:900;
}
.stat-headline-num .big{font-size:clamp(8rem,18vw,16rem)}
.stat-headline-num .pct{font-size:clamp(3rem,7vw,6rem);margin-top:.6rem;color:var(--primary-light)}
.stat-headline-desc{
  font-family:var(--font-display);font-weight:700;text-transform:uppercase;
  color:#fff;font-size:clamp(1.4rem,2.6vw,2rem);
  line-height:1.05;letter-spacing:-.01em;
  margin-top:.5rem;max-width:600px;
}
.stat-headline-source{
  font-family:var(--font-mono);font-size:11px;
  color:rgba(255,255,255,0.4);
  letter-spacing:.12em;text-transform:uppercase;
  margin-top:1.5rem;
  display:flex;align-items:center;gap:10px;
}
.stat-headline-source::before{content:'';width:18px;height:1px;background:rgba(255,255,255,0.3)}
.stat-supports{
  display:flex;flex-direction:column;justify-content:space-between;gap:1.5rem;
  border-left:1px solid var(--border-dark);padding-left:3rem;
}
.stat-row{padding-bottom:1.5rem;border-bottom:1px solid var(--border-dark)}
.stat-row:last-child{border-bottom:none;padding-bottom:0}
.stat-row-num{
  font-family:var(--font-display);font-weight:900;
  font-size:clamp(2.6rem,4.5vw,3.8rem);
  color:#fff;line-height:1;letter-spacing:-.02em;
  margin-bottom:.5rem;
}
.stat-row-num .pct{color:var(--primary-light);font-size:.7em}
.stat-row-text{color:rgba(255,255,255,0.55);font-size:.95rem;line-height:1.55}
.stat-row-source{
  font-family:var(--font-mono);font-size:10px;
  color:rgba(255,255,255,0.3);
  letter-spacing:.1em;text-transform:uppercase;
  margin-top:.5rem;
}

/* ============================================================
   GENERIC SECTION
   ============================================================ */
.sec{padding:6rem 2rem;max-width:1200px;margin:0 auto}
.sec-header{max-width:760px;margin-bottom:3rem}
.sec-header h2{margin-bottom:1rem}
.sec-lead{font-size:1.05rem;color:var(--muted);max-width:620px;line-height:1.7}

/* ============================================================
   QUÉ ES
   ============================================================ */
.about-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:4rem;align-items:start}
.about-photo-wrap{position:relative}
.about-photo{width:100%;aspect-ratio:4/5;object-fit:cover;display:block}
.about-photo-stamp{
  position:absolute;top:1rem;left:1rem;
  background:var(--primary);color:#fff;
  padding:8px 14px;
  font-family:var(--font-mono);font-size:10px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
}
.about-points{display:flex;flex-direction:column;gap:1.75rem;margin-top:1rem}
.apoint{display:flex;gap:1.25rem;align-items:flex-start;padding-bottom:1.75rem;border-bottom:1px dashed var(--border)}
.apoint:last-child{border-bottom:none;padding-bottom:0}
.apoint-icon{
  width:44px;height:44px;
  background:var(--noir);color:var(--cream);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.apoint-text strong{
  display:block;
  font-family:var(--font-display);font-weight:800;
  font-size:1.15rem;letter-spacing:-.005em;
  text-transform:uppercase;
  margin-bottom:.35rem;color:var(--text);
}
.apoint-text span{font-size:.92rem;color:var(--muted);line-height:1.6;display:block}

/* ============================================================
   AUDIENCIA
   ============================================================ */
.audience-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  margin-top:2.5rem;
  border-top:1px solid var(--border);border-left:1px solid var(--border);
}
.aud-card{
  padding:2rem 1.5rem;
  border-right:1px solid var(--border);
  border-bottom:1px solid var(--border);
  background:var(--white);
  transition:background .2s,color .2s;
  position:relative;
}
.aud-card::before{
  content:attr(data-num);
  position:absolute;top:1rem;right:1.25rem;
  font-family:var(--font-mono);font-size:11px;
  color:var(--muted-soft);letter-spacing:.1em;
}
.aud-card:hover{background:var(--noir);color:#fff}
.aud-card:hover .aud-icon{color:var(--primary-light)}
.aud-card:hover .aud-desc{color:rgba(255,255,255,0.65)}
.aud-card:hover::before{color:rgba(255,255,255,0.4)}
.aud-icon{margin-bottom:1.25rem;color:var(--primary);transition:color .2s}
.aud-card h4{
  font-family:var(--font-display);font-weight:800;
  font-size:1.3rem;letter-spacing:-.005em;
  text-transform:uppercase;margin-bottom:.5rem;
}
.aud-desc{font-size:.88rem;color:var(--muted);line-height:1.6}
.aud-extra{
  margin-top:2rem;
  background:var(--noir);color:#fff;
  padding:1.25rem 1.5rem;font-size:.92rem;
  border-left:4px solid var(--primary);
  font-family:var(--font-body);
}
.aud-extra strong{color:var(--primary-light)}

/* ============================================================
   MÓDULOS
   ============================================================ */
.mod-timeline{display:flex;flex-direction:column;margin-top:2.5rem;position:relative}
.mod-row{
  display:grid;grid-template-columns:140px 1fr;gap:2rem;
  padding:2.5rem 0;
  border-bottom:1px solid var(--border-dark);position:relative;
}
.mod-row:first-child{padding-top:0}
.mod-row:last-child{border-bottom:none}
.mod-marker{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem}
.mod-code{
  font-family:var(--font-display);font-weight:900;
  font-size:clamp(2.5rem,4.5vw,3.6rem);
  color:var(--primary);letter-spacing:-.02em;line-height:.9;
}
.mod-dur{
  display:inline-block;background:rgba(216,90,48,0.18);
  color:var(--primary-light);padding:3px 8px;
  font-family:var(--font-mono);font-size:10px;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;
  margin-top:.5rem;
}
.mod-body{flex:1}
.mod-week{
  font-family:var(--font-mono);font-size:11px;
  color:var(--primary-light);
  letter-spacing:.12em;text-transform:uppercase;
  margin-bottom:.5rem;
}
.mod-title{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(1.6rem,3vw,2.1rem);
  color:#fff;letter-spacing:-.005em;
  text-transform:uppercase;margin-bottom:1.25rem;line-height:1.05;
}
.mod-list{display:grid;grid-template-columns:1fr 1fr;gap:.4rem 1.5rem;list-style:none}
.mod-list li{
  font-size:.92rem;color:rgba(255,255,255,0.6);
  padding-left:18px;position:relative;line-height:1.6;
}
.mod-list li::before{content:'';position:absolute;left:0;top:.7em;width:10px;height:1px;background:var(--primary)}

.mod-extra{
  background:linear-gradient(135deg,var(--primary-deep),var(--primary));
  padding:2.5rem;margin-top:3rem;
  display:grid;grid-template-columns:1.5fr 1fr;gap:2rem;align-items:center;
  position:relative;overflow:hidden;
}
.mod-extra::before{
  content:'M04+';
  position:absolute;top:-1rem;right:-1rem;
  font-family:var(--font-display);font-weight:900;
  font-size:14rem;color:rgba(255,255,255,0.07);
  letter-spacing:-.05em;line-height:1;pointer-events:none;
}
.mod-extra-badge{
  font-family:var(--font-mono);font-size:11px;font-weight:700;
  color:rgba(255,255,255,0.85);
  letter-spacing:.12em;text-transform:uppercase;
  margin-bottom:.75rem;
  display:inline-flex;align-items:center;gap:8px;
}
.mod-extra-badge::before{content:'★';color:var(--signal)}
.mod-extra h3{
  color:#fff;font-size:clamp(1.6rem,3vw,2.2rem);
  font-family:var(--font-display);font-weight:800;
  margin-bottom:.75rem;text-transform:uppercase;letter-spacing:-.005em;
}
.mod-extra p{color:rgba(255,255,255,0.85);font-size:.95rem;line-height:1.65}
.mod-price-box{background:var(--noir);padding:1.5rem;text-align:center;position:relative;z-index:1}
.mod-price-box .pl{
  font-family:var(--font-mono);font-size:10px;
  color:rgba(255,255,255,0.5);
  letter-spacing:.12em;text-transform:uppercase;margin-bottom:.5rem;
}
.mod-price-box .pn{
  font-family:var(--font-display);font-weight:900;
  font-size:clamp(2rem,4vw,2.6rem);color:#fff;line-height:1;letter-spacing:-.01em;
}
.mod-price-box .pn span{font-size:.5em;color:var(--primary-light);font-weight:700;margin-left:6px}
.mod-price-box .ps{
  font-family:var(--font-mono);font-size:10px;
  color:rgba(255,255,255,0.4);
  letter-spacing:.1em;text-transform:uppercase;margin-top:.6rem;
}

.niveles-block{
  margin-top:3rem;
  background:rgba(255,255,255,0.03);
  border:1px solid var(--border-dark);
  padding:2rem;
}
.niveles-tag{
  font-family:var(--font-mono);font-size:11px;
  color:var(--primary-light);
  letter-spacing:.15em;text-transform:uppercase;
  margin-bottom:1.5rem;
}
.niveles-tag::before{content:'/// '}
.niveles-grid{display:flex;flex-wrap:wrap;gap:10px}
.nivel-item{
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border-dark);
  padding:14px 18px;flex:1;min-width:170px;
}
.nivel-item.instructor{background:rgba(216,90,48,0.12);border-color:rgba(216,90,48,0.4)}
.nivel-code{
  font-family:var(--font-display);font-weight:900;
  font-size:1.5rem;color:#fff;line-height:1;
  letter-spacing:-.01em;text-transform:uppercase;margin-bottom:.25rem;
}
.nivel-item.instructor .nivel-code{color:var(--primary-light)}
.nivel-name{font-family:var(--font-body);font-weight:600;color:#fff;font-size:.9rem;margin-bottom:.35rem}
.nivel-desc{
  font-family:var(--font-mono);font-size:10px;
  color:rgba(255,255,255,0.4);
  letter-spacing:.05em;line-height:1.4;
}
.niveles-note{
  font-family:var(--font-mono);font-size:11px;
  color:rgba(255,255,255,0.45);
  letter-spacing:.05em;margin-top:1.25rem;
}
.niveles-note::before{content:'⚡ ';color:var(--signal)}

/* ============================================================
   PRECIOS
   ============================================================ */
.pricing-grid{
  display:grid;grid-template-columns:1.2fr 1fr;gap:0;
  margin-top:2.5rem;
  border:1px solid var(--border);background:var(--white);
}
.price-card{padding:2.5rem;position:relative;border-right:1px solid var(--border)}
.price-card:last-child{border-right:none}
.price-card.featured{background:var(--noir);color:#fff}
.price-card.featured .price-name,.price-card.featured .price-desc{color:rgba(255,255,255,0.6)}
.price-card.featured .price-ul li{color:rgba(255,255,255,0.8)}
.price-badge{
  position:absolute;top:1.25rem;right:1.25rem;
  background:var(--primary);color:#fff;
  font-family:var(--font-mono);font-size:10px;font-weight:700;
  padding:5px 12px;letter-spacing:.12em;text-transform:uppercase;
}
.price-name{
  font-family:var(--font-mono);font-size:11px;font-weight:600;
  color:var(--muted);letter-spacing:.12em;text-transform:uppercase;
  margin-bottom:.5rem;
}
.price-n{
  font-family:var(--font-display);font-weight:900;
  font-size:clamp(3rem,6vw,4.2rem);
  letter-spacing:-.025em;line-height:.95;margin-bottom:.25rem;
}
.price-n span{
  font-family:var(--font-body);font-size:1.1rem;font-weight:500;
  color:var(--muted);margin-left:6px;letter-spacing:.02em;
}
.price-card.featured .price-n span{color:rgba(255,255,255,0.55)}
.price-desc{
  font-size:.92rem;color:var(--muted);
  margin-bottom:1.5rem;padding-bottom:1.5rem;
  border-bottom:1px dashed var(--border);
}
.price-card.featured .price-desc{border-bottom-color:var(--border-dark)}
.price-ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.price-ul li{font-size:.9rem;display:flex;gap:10px;align-items:flex-start;line-height:1.5}
.price-ul li::before{content:'✓';color:var(--primary);font-weight:700;flex-shrink:0;font-family:var(--font-mono)}
.price-card.featured .price-ul li::before{color:var(--primary-light)}
.price-note{
  margin-top:1.5rem;padding:1.25rem 1.5rem;
  background:var(--cream);
  border-left:4px solid var(--signal);
  font-size:.88rem;color:var(--text-soft);line-height:1.6;
}
.price-note strong{color:var(--primary-deep)}

/* ============================================================
   INSTRUCTOR
   ============================================================ */
.instructor-grid{display:grid;grid-template-columns:380px 1fr;gap:4rem;align-items:start}
.instructor-photo-wrap{position:relative}
.instructor-photo{width:100%;aspect-ratio:3/4;object-fit:cover;display:block}
.instructor-photo-tag{
  position:absolute;left:0;right:0;bottom:0;
  background:var(--noir);color:#fff;
  padding:1rem 1.25rem;
  display:flex;justify-content:space-between;align-items:center;
}
.instructor-photo-tag span:first-child{
  font-family:var(--font-mono);font-size:10px;
  letter-spacing:.15em;text-transform:uppercase;color:var(--primary-light);
}
.instructor-photo-tag span:last-child{
  font-family:var(--font-mono);font-size:10px;
  letter-spacing:.1em;color:rgba(255,255,255,0.5);
}
.instructor-name{
  font-family:var(--font-display);font-weight:900;
  font-size:clamp(2.5rem,4.5vw,3.4rem);
  letter-spacing:-.02em;line-height:.95;
  text-transform:uppercase;margin-bottom:.5rem;
}
.instructor-title{
  font-family:var(--font-mono);font-size:11px;
  color:var(--primary);letter-spacing:.15em;text-transform:uppercase;
  margin-bottom:2rem;padding-bottom:1.5rem;
  border-bottom:1px solid var(--border);
}
.cred-list{display:flex;flex-direction:column;gap:1.5rem}
.cred-item{display:flex;gap:1.25rem;align-items:flex-start}
.cred-icon{
  width:48px;height:48px;
  background:var(--noir);color:var(--cream);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.cred-text strong{
  display:block;
  font-family:var(--font-display);font-weight:800;
  font-size:1.05rem;text-transform:uppercase;
  letter-spacing:-.005em;margin-bottom:.25rem;
}
.cred-text span{font-size:.9rem;color:var(--muted);line-height:1.6;display:block}

/* ============================================================
   RESERVAS — Pit-pass tickets
   ============================================================ */
.prog-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(330px,1fr));
  gap:1.5rem;margin-top:2.5rem;
}
.prog-card{
  background:var(--white);position:relative;
  border:1px solid var(--border);
  transition:transform .25s,border-color .25s;
  display:flex;flex-direction:column;
  --notch:18px;
  clip-path:polygon(0 0,calc(100% - var(--notch)) 0,100% var(--notch),100% 100%,0 100%);
}
.prog-card:hover{transform:translateY(-3px);border-color:var(--primary)}
.prog-card-header{
  display:flex;gap:1.25rem;padding:1.5rem;
  border-bottom:1px dashed var(--border);
  background:var(--cream-soft);
}
.prog-date{
  flex-shrink:0;
  background:var(--noir);color:#fff;
  padding:.9rem 1rem;text-align:center;min-width:80px;
}
.prog-date-num{
  display:block;
  font-family:var(--font-display);font-weight:900;
  font-size:2.4rem;line-height:.95;letter-spacing:-.02em;
}
.prog-date-month{
  display:block;
  font-family:var(--font-mono);font-size:10px;font-weight:600;
  color:var(--primary-light);
  letter-spacing:.15em;text-transform:uppercase;margin-top:.25rem;
}
.prog-meta{flex:1;min-width:0}
.prog-eyebrow{
  font-family:var(--font-mono);font-size:10px;
  color:var(--muted);
  letter-spacing:.12em;text-transform:uppercase;margin-bottom:.3rem;
}
.prog-name{
  font-family:var(--font-display);font-weight:800;
  font-size:1.25rem;line-height:1.05;letter-spacing:-.005em;
  text-transform:uppercase;margin-bottom:.6rem;color:var(--text);
}
.ptag{
  font-family:var(--font-mono);font-size:10px;font-weight:700;
  padding:4px 10px;letter-spacing:.1em;text-transform:uppercase;
  display:inline-block;
}
.t-open{background:#EAF3DE;color:#3B6D11}
.t-few{background:#FAEEDA;color:#854F0B}
.t-closed{background:#FCEBEB;color:#A32D2D}

.prog-info{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.6rem}
.prog-info-row{
  display:flex;justify-content:space-between;align-items:baseline;
  gap:1rem;font-size:.9rem;
  padding-bottom:.6rem;border-bottom:1px dotted var(--border);
}
.prog-info-row:last-child{border-bottom:none;padding-bottom:0}
.prog-info-label{
  font-family:var(--font-mono);font-size:10px;
  color:var(--muted);letter-spacing:.12em;text-transform:uppercase;flex-shrink:0;
}
.prog-info-val{text-align:right;color:var(--text);font-weight:500}
.prog-info-val.mono{font-family:var(--font-mono);font-weight:700}
.prog-info-val.primary{color:var(--primary)}

.prog-spots{padding:0 1.5rem 1.25rem}
.prog-spots-bar{display:flex;gap:3px;margin-bottom:.5rem}
.spot-segment{flex:1;height:8px;background:#EFEDE6;transition:background .3s}
.spot-segment.taken{background:var(--primary)}
.prog-spots-label{
  font-family:var(--font-mono);font-size:10px;
  color:var(--muted);letter-spacing:.1em;text-transform:uppercase;
}

.btn-book{
  width:100%;background:var(--noir);color:#fff;border:none;
  padding:1.1rem 1.5rem;
  font-family:var(--font-body);font-size:12px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;cursor:pointer;
  transition:background .2s;
  display:flex;align-items:center;justify-content:space-between;
  gap:1rem;margin-top:auto;
}
.btn-book:hover:not(:disabled){background:var(--primary)}
.btn-book:disabled{background:#D3D1C7;cursor:not-allowed;color:#fff}

/* ============================================================
   CARD ÚNICA POR PROGRAMA — selector de fechas
   ============================================================ */
.prog-card-multi .prog-card-header{align-items:flex-start}
.prog-card-multi .prog-name{margin-bottom:.75rem}

.edicion-selector{
  padding:1.1rem 1.5rem .25rem;
}
.edicion-selector-label{
  font-family:var(--font-mono);font-size:10px;font-weight:600;
  color:var(--muted);letter-spacing:.12em;text-transform:uppercase;
  margin-bottom:.7rem;
}
.edicion-pills{
  display:flex;flex-wrap:wrap;gap:.5rem;
}
.edicion-pill{
  background:var(--white);
  border:1px solid var(--border);
  padding:.55rem .8rem;cursor:pointer;
  font-family:var(--font-mono);font-size:11px;font-weight:600;
  letter-spacing:.04em;text-transform:uppercase;color:var(--text-soft);
  display:inline-flex;align-items:center;gap:.5rem;
  transition:border-color .15s,background .15s,color .15s;
  line-height:1.1;
}
.edicion-pill:hover{border-color:var(--noir)}
.edicion-pill.active{
  background:var(--noir);color:#fff;border-color:var(--noir);
}
.edicion-pill.few:not(.active){
  border-color:#D9A441;
}
.edicion-pill.full{
  opacity:.7;
}
.edicion-pill.full.active{
  background:#7A2A2A;border-color:#7A2A2A;color:#fff;
}
.edicion-pill-date{white-space:nowrap}
.edicion-pill-tag{
  font-size:8px;font-weight:700;letter-spacing:.08em;
  background:#FCEBEB;color:#A32D2D;padding:2px 5px;
}
.edicion-pill.active .edicion-pill-tag{
  background:rgba(255,255,255,.2);color:#fff;
}

.prog-edicion-body{display:flex;flex-direction:column;flex:1}
.prog-edicion-status{padding:1rem 1.5rem 0}

/* Botón recomendá a un amigo — verde WhatsApp, compacto y subordinado a Reservar */
.btn-recomendar{
  display:flex;align-items:center;justify-content:center;gap:.4rem;
  background:#25D366;color:#fff;text-decoration:none;
  padding:.45rem 1rem;
  font-family:var(--font-body);font-size:9px;font-weight:700;
  letter-spacing:.05em;text-transform:uppercase;
  transition:background .2s;
}
.btn-recomendar:hover{background:#1FAE54}
.btn-recomendar svg{flex-shrink:0;width:11px;height:11px}

.prog-card-skeleton{
  background:var(--white);
  border:1px solid var(--border);
  padding:1.5rem;
  animation:pulse 1.5s ease-in-out infinite;
}
.skel-line{background:#E8E5DC;border-radius:2px;height:14px;margin-bottom:10px}
.skel-line.short{width:40%}
.skel-line.med{width:65%}
.skel-line.full{width:100%}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.55}}
.prog-error{
  background:#FFF8F5;border:1px solid #F5C4B3;
  padding:2rem;text-align:center;
  color:var(--primary-deep);font-size:.95rem;grid-column:1/-1;
}
.prog-error a{color:var(--primary);font-weight:700;text-decoration:underline}

/* ============================================================
   PROGRAMA — Botón "Ver fechas" en la tarjeta
   ============================================================ */
.btn-prog-detail{
  display:block;width:100%;padding:.7rem 1rem;
  background:transparent;border:1px solid var(--border);
  color:var(--text);
  font-family:var(--font-body);font-size:11px;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;
  cursor:pointer;transition:all .2s;
  margin:0 0 .5rem;
}
.btn-prog-detail:hover{background:var(--noir);color:#fff;border-color:var(--noir)}

/* ============================================================
   PROGRAMA — Modal "Ver fechas del programa"
   ============================================================ */
.prog-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem}
.prog-modal[hidden]{display:none}
.prog-modal-backdrop{position:absolute;inset:0;background:rgba(14,14,12,0.85);backdrop-filter:blur(4px)}
.prog-modal-box{
  position:relative;max-width:600px;width:100%;max-height:92vh;overflow:auto;
  background:var(--cream-soft);padding:2.5rem;
  --notch:24px;
  clip-path:polygon(0 0,calc(100% - var(--notch)) 0,100% var(--notch),100% 100%,0 100%);
}
.prog-modal-close{
  position:absolute;top:1rem;right:1rem;
  background:none;border:1px solid var(--border);
  width:36px;height:36px;font-size:18px;cursor:pointer;
  color:var(--text);line-height:1;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .2s,color .2s;
}
.prog-modal-close:hover{border-color:var(--primary);color:var(--primary)}
.prog-modal-eyebrow{
  font-family:var(--font-mono);font-size:11px;font-weight:600;
  letter-spacing:.15em;color:var(--primary);
  text-transform:uppercase;margin-bottom:.5rem;
}
#prog-modal-title{
  font-family:var(--font-display);font-weight:900;
  font-size:1.6rem;line-height:1.1;letter-spacing:-.01em;
  text-transform:uppercase;margin:0 0 .25rem;
}
.prog-modal-sub{
  font-family:var(--font-mono);font-size:.78rem;
  color:var(--muted);margin:0 0 1.5rem;
  letter-spacing:.04em;text-transform:uppercase;
}
.prog-modal-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}
.prog-mod-row{
  display:flex;gap:1rem;padding:1rem 1.25rem;background:var(--white);
  border-left:3px solid var(--primary);
}
.prog-mod-code{
  font-family:var(--font-display);font-weight:900;
  color:var(--primary);min-width:48px;font-size:1.4rem;line-height:1;
  letter-spacing:-.01em;
}
.prog-mod-body{flex:1}
.prog-mod-title{
  font-family:var(--font-display);font-weight:800;
  font-size:1.05rem;text-transform:uppercase;letter-spacing:-.005em;
  margin-bottom:.35rem;line-height:1.1;
}
.prog-mod-meta{
  font-size:.85rem;color:var(--text-soft);
  display:flex;gap:.4rem;flex-wrap:wrap;align-items:center;
}
.prog-mod-sep{opacity:.4}
.prog-mod-place{
  font-family:var(--font-mono);font-size:.72rem;
  color:var(--muted-soft);margin-top:.4rem;
  letter-spacing:.04em;text-transform:uppercase;
}
.prog-modal-note{
  font-size:.82rem;color:var(--muted);
  padding:.85rem 1rem;background:var(--cream);
  border-left:3px solid var(--signal);
  margin:1.5rem 0 1.25rem;line-height:1.55;
}
.prog-modal-actions{margin-top:1rem}
.prog-modal-actions .btn-book{width:100%;justify-content:center}

/* ============================================================
   PROGRAMA — Bloque "edición llena → próxima"
   ============================================================ */
.full-suggest{
  background:#FFF3E8;border-left:3px solid var(--primary);
  padding:1rem 1.25rem;margin-top:auto;
}
.full-suggest-label{
  font-family:var(--font-mono);font-size:10px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--primary-deep);margin-bottom:.4rem;
}
.full-suggest-next{font-size:.88rem;color:var(--text-soft);margin-bottom:.85rem;line-height:1.4}
.full-suggest-next strong{color:var(--primary);font-weight:700}
.btn-suggest{
  width:100%;padding:.85rem;background:var(--primary);
  color:#fff;border:0;
  font-family:var(--font-body);font-size:12px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;cursor:pointer;
  transition:background .2s;
}
.btn-suggest:hover{background:var(--primary-deep)}
.btn-waitlist-secondary{
  width:100%;padding:.65rem;background:transparent;
  border:1px solid var(--border);
  color:var(--muted);
  font-family:var(--font-body);font-size:11px;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;cursor:pointer;
  margin-top:.5rem;transition:all .2s;
}
.btn-waitlist-secondary:hover{border-color:var(--text);color:var(--text)}

/* ============================================================
   GALERÍA EDITORIAL
   ============================================================ */
.gallery-editorial{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  grid-auto-rows:160px;gap:8px;margin-top:2rem;
}
.gal-item{
  position:relative;overflow:hidden;
  background:var(--noir-soft);cursor:pointer;
}
.gal-item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s ease;display:block;
}
.gal-item:hover img{transform:scale(1.06)}
.gal-overlay{
  position:absolute;left:0;right:0;bottom:0;
  padding:.75rem 1rem;
  background:linear-gradient(to top,rgba(14,14,12,0.95),transparent);
  color:#fff;
  font-family:var(--font-mono);font-size:10px;
  letter-spacing:.12em;text-transform:uppercase;
  opacity:0;transition:opacity .25s;
}
.gal-item:hover .gal-overlay{opacity:1}
.gal-item.always-caption .gal-overlay{opacity:1}
.gal-item:nth-child(1){grid-column:span 3;grid-row:span 2}
.gal-item:nth-child(2){grid-column:span 2}
.gal-item:nth-child(3){grid-column:span 1;grid-row:span 2}
.gal-item:nth-child(4){grid-column:span 2}
.gal-item:nth-child(5){grid-column:span 2;grid-row:span 2}
.gal-item:nth-child(6){grid-column:span 2}
.gal-item:nth-child(7){grid-column:span 2}
.gal-item:nth-child(8){grid-column:span 2;grid-row:span 2}
.gal-item:nth-child(9){grid-column:span 2}
.gal-item:nth-child(10){grid-column:span 2}
.gal-item:nth-child(11){grid-column:span 2}
.gal-item:nth-child(12){grid-column:span 2}

.ig-cta{
  display:inline-flex;align-items:center;gap:10px;
  margin-top:2rem;
  background:var(--primary);color:#fff;
  padding:14px 24px;text-decoration:none;
  font-family:var(--font-body);font-size:12px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  transition:background .25s;
}
.ig-cta:hover{background:var(--primary-deep)}

/* ============================================================
   FAQ
   ============================================================ */
.faq-wrap{max-width:840px;margin:2rem auto 0;counter-reset:faq-counter}
.faq-item{border-bottom:1px solid var(--border);position:relative}
.faq-item::before{
  content:counter(faq-counter,decimal-leading-zero);
  position:absolute;left:0;top:1.5rem;
  font-family:var(--font-mono);font-size:11px;font-weight:600;
  color:var(--primary);letter-spacing:.1em;
  counter-increment:faq-counter;
}
.faq-btn{
  width:100%;text-align:left;
  background:none;border:none;
  padding:1.4rem 0 1.4rem 3.5rem;
  font-family:var(--font-display);font-weight:700;
  font-size:1.15rem;letter-spacing:-.005em;
  text-transform:uppercase;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;
  color:var(--text);gap:1rem;line-height:1.2;
}
.faq-btn:hover{color:var(--primary)}
.faq-arrow{
  width:32px;height:32px;
  border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:14px;flex-shrink:0;
  transition:transform .3s,background .2s,color .2s,border-color .2s;
  font-family:var(--font-mono);
}
.faq-btn.open .faq-arrow{transform:rotate(45deg);background:var(--primary);border-color:var(--primary);color:#fff}
.faq-ans{
  font-size:.95rem;color:var(--muted);line-height:1.75;
  max-height:0;overflow:hidden;
  transition:max-height .35s ease,padding .35s;
  padding-left:3.5rem;
}
.faq-ans.open{max-height:500px;padding-bottom:1.5rem}

/* ============================================================
   CONTACTO
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;margin-top:2.5rem}
.c-card{
  background:var(--white);
  border:1px solid var(--border);
  padding:2.5rem;
}
.c-card h3{
  font-family:var(--font-display);font-weight:800;
  font-size:1.5rem;letter-spacing:-.005em;
  text-transform:uppercase;margin-bottom:1.5rem;
}
.fg{margin-bottom:1.25rem}
.fg label{
  display:block;
  font-family:var(--font-mono);font-size:10px;font-weight:600;
  color:var(--muted);letter-spacing:.12em;text-transform:uppercase;
  margin-bottom:6px;
}
.fg input,.fg textarea,.fg select{
  width:100%;padding:12px 14px;
  border:1px solid var(--border);
  background:var(--cream-soft);color:var(--text);
  font-size:.95rem;font-family:var(--font-body);
}
.fg input:focus,.fg textarea:focus,.fg select:focus{
  outline:none;border-color:var(--primary);background:var(--white);
}
.fg textarea{resize:vertical;min-height:90px}
.btn-wa{
  width:100%;background:#25D366;color:#fff;border:none;
  padding:14px;
  font-family:var(--font-body);font-size:12px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:10px;
  margin-top:.5rem;transition:background .2s;
}
.btn-wa:hover{background:#1ea854}
.c-info{display:flex;flex-direction:column;gap:1.75rem}
.c-info-lead{
  font-family:var(--font-mono);font-size:11px;
  color:var(--muted);letter-spacing:.12em;text-transform:uppercase;
}
.ci-item{display:flex;gap:1rem;align-items:flex-start}
.ci-icon{
  width:48px;height:48px;
  background:var(--noir);color:var(--cream);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.ci-text strong{
  display:block;
  font-family:var(--font-display);font-weight:800;
  font-size:1.1rem;text-transform:uppercase;letter-spacing:-.005em;
}
.ci-text span{
  font-family:var(--font-mono);font-size:.85rem;
  color:var(--muted-soft);display:block;
  letter-spacing:.04em;margin-top:.15rem;
}
.ci-link{
  color:var(--primary);font-size:.85rem;text-decoration:none;
  display:inline-block;margin-top:.5rem;
  font-family:var(--font-body);font-weight:600;
  border-bottom:1px solid currentColor;
}

/* ============================================================
   MODAL DE RESERVA
   ============================================================ */
.modal-bg{
  display:none;position:fixed;inset:0;
  background:rgba(14,14,12,0.85);
  z-index:999;
  align-items:center;justify-content:center;
  padding:1rem;backdrop-filter:blur(4px);
}
.modal-bg.on{display:flex}
.modal-box{
  background:var(--cream-soft);
  max-width:560px;width:100%;max-height:92vh;overflow-y:auto;
  padding:2.5rem;position:relative;
  --notch:24px;
  clip-path:polygon(0 0,calc(100% - var(--notch)) 0,100% var(--notch),100% 100%,0 100%);
}
.modal-top{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}
.modal-top h3{
  font-family:var(--font-display);font-weight:900;
  font-size:1.5rem;letter-spacing:-.01em;
  text-transform:uppercase;line-height:1.1;
}
.modal-close{
  background:none;border:1px solid var(--border);
  width:36px;height:36px;font-size:18px;cursor:pointer;
  color:var(--text);line-height:1;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .2s,color .2s;flex-shrink:0;
}
.modal-close:hover{border-color:var(--primary);color:var(--primary)}
.steps{display:flex;gap:6px;margin-bottom:2rem}
.step-bar{flex:1;height:3px;background:var(--border)}
.step-bar.active{background:var(--primary)}
.step-bar.done{background:var(--green)}
.modal-grid2{display:grid;grid-template-columns:1fr 1fr;gap:0 12px}
.pay-opts{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-top:1rem}
.pay-opt{
  border:1.5px solid var(--border);
  padding:1.25rem 1rem;text-align:center;cursor:pointer;
  transition:border-color .2s,background .2s;background:var(--white);
}
.pay-opt:hover{border-color:var(--primary)}
.pay-opt.sel{border-color:var(--primary);background:var(--primary);color:#fff}
.pay-opt-icon{font-size:24px;margin-bottom:.5rem}
.pay-opt strong{
  font-family:var(--font-display);font-weight:800;
  font-size:1rem;text-transform:uppercase;letter-spacing:-.005em;display:block;
}
.pay-opt-sub{
  font-family:var(--font-mono);font-size:10px;
  color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-top:.35rem;
}
.pay-opt.sel .pay-opt-sub{color:rgba(255,255,255,0.8)}
.pay-box{
  background:var(--white);
  border:1px solid var(--border);
  padding:1.5rem;margin:1.25rem 0;
}
.pay-box h4{
  font-family:var(--font-mono);font-size:11px;font-weight:700;
  color:var(--primary);letter-spacing:.12em;text-transform:uppercase;margin-bottom:1rem;
}
.pay-row{
  display:flex;justify-content:space-between;align-items:baseline;
  font-size:.92rem;
  padding:8px 0;border-bottom:1px dotted var(--border);
}
.pay-row:last-child{border:none;font-weight:600;padding-bottom:0}
.pay-row span:first-child{
  font-family:var(--font-mono);font-size:11px;
  color:var(--muted);letter-spacing:.08em;text-transform:uppercase;
}
.pay-row span:last-child{font-family:var(--font-mono);font-weight:500}
#pay-amt{color:var(--primary);font-weight:700;font-size:1.05rem}
.upload-zone{
  border:2px dashed var(--border);
  padding:1.5rem;text-align:center;cursor:pointer;
  font-size:.9rem;color:var(--muted);
  transition:border-color .2s,background .2s;
  font-family:var(--font-mono);letter-spacing:.05em;
}
.upload-zone:hover{border-color:var(--primary);background:var(--white)}
.form-error{
  background:#FCEBEB;border-left:4px solid var(--red);
  color:var(--red);padding:12px 16px;font-size:.88rem;line-height:1.6;
  margin-top:1rem;display:none;
}
.checkbox-row{
  display:flex;gap:12px;align-items:flex-start;cursor:pointer;
  margin-top:1.25rem;padding:1rem;
  background:var(--white);border:1px solid var(--border);
}
.checkbox-row input{margin-top:3px;width:16px;height:16px;flex-shrink:0;accent-color:var(--primary)}
.checkbox-row span{font-size:.82rem;color:var(--muted);line-height:1.55}
.confirm-note{
  background:#F0F7EE;border-left:4px solid var(--green);
  padding:10px 14px;font-size:.85rem;color:#3B6D11;
  margin-bottom:1rem;font-family:var(--font-body);
}
.modal-actions{display:flex;gap:10px;margin-top:1.75rem}
.btn-modal-back{
  flex:1;border:1px solid var(--border);background:var(--cream-soft);
  padding:14px;cursor:pointer;
  font-family:var(--font-body);font-size:12px;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;transition:border-color .2s;
}
.btn-modal-back:hover{border-color:var(--text)}
.btn-modal-confirm{
  flex:2;background:var(--noir);color:#fff;border:none;
  padding:14px;cursor:pointer;
  font-family:var(--font-body);font-size:12px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;transition:background .2s;
}
.btn-modal-confirm:hover{background:var(--primary)}
.btn-modal-confirm:disabled{background:var(--muted-soft);cursor:not-allowed}

/* ============================================================
   FOOTER
   ============================================================ */
footer{
  background:var(--noir);color:rgba(255,255,255,0.55);
  padding:4rem 2rem 2rem;position:relative;
}
.footer-inner{max-width:1200px;margin:0 auto}
.footer-top{
  display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:3rem;
  padding-bottom:3rem;border-bottom:1px solid var(--border-dark);
}
.footer-brand{
  font-family:var(--font-display);font-weight:900;
  color:#fff;font-size:clamp(2rem,4vw,3rem);
  text-transform:uppercase;letter-spacing:-.02em;line-height:.95;
  margin-bottom:.75rem;
}
.footer-brand span{color:var(--primary)}
.footer-tagline{
  font-family:var(--font-mono);font-size:11px;
  color:var(--primary-light);
  letter-spacing:.15em;text-transform:uppercase;margin-bottom:1rem;
}
.footer-desc{font-size:.92rem;line-height:1.65;max-width:380px}
.footer-col h5{
  font-family:var(--font-mono);font-size:10px;font-weight:700;
  color:rgba(255,255,255,0.4);letter-spacing:.15em;text-transform:uppercase;
  margin-bottom:1rem;
}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.5rem}
.footer-col a{color:rgba(255,255,255,0.65);text-decoration:none;font-size:.9rem;transition:color .2s}
.footer-col a:hover{color:var(--primary-light)}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:1rem;padding-top:2rem;
  font-family:var(--font-mono);font-size:10px;
  color:rgba(255,255,255,0.35);letter-spacing:.1em;text-transform:uppercase;
}
.footer-bottom-credit{color:rgba(255,255,255,0.5)}
.footer-bottom-credit strong{color:var(--primary-light);font-weight:600}

/* ============================================================
   FLOATING WHATSAPP
   ============================================================ */
.wa-btn{
  position:fixed;bottom:28px;right:28px;z-index:500;
  background:#25D366;width:60px;height:60px;
  display:flex;align-items:center;justify-content:center;
  text-decoration:none;color:#fff;
  box-shadow:0 8px 24px rgba(37,211,102,0.4);
  transition:transform .25s;
}
.wa-btn:hover{transform:scale(1.08)}
.wa-btn::after{
  content:'';position:absolute;inset:-4px;
  border:2px solid #25D366;opacity:.4;
  animation:wapulse 2.5s infinite;
}
@keyframes wapulse{
  0%{opacity:.5;transform:scale(.95)}
  70%{opacity:0;transform:scale(1.4)}
  100%{opacity:0;transform:scale(1.4)}
}

/* ============================================================
   MOTION
   ============================================================ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease-out,transform .8s ease-out}
.reveal.revealed{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.hero-text > *{opacity:0;transform:translateY(20px);animation:fadeUp .9s ease-out forwards}
.hero-text > *:nth-child(1){animation-delay:.15s}
.hero-text > *:nth-child(2){animation-delay:.3s}
.hero-text > *:nth-child(3){animation-delay:.45s}
.hero-text > *:nth-child(4){animation-delay:.6s}
.hero-text > *:nth-child(5){animation-delay:.75s}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-photo{min-height:50vh;border-right:none;border-bottom:1px solid var(--border-dark)}
  .hero-text{padding:3rem 2rem}
  .stats-layout{grid-template-columns:1fr;gap:2.5rem}
  .stat-supports{border-left:none;border-top:1px solid var(--border-dark);padding-left:0;padding-top:2rem}
  .about-grid,.instructor-grid{grid-template-columns:1fr;gap:2.5rem}
  .pricing-grid{grid-template-columns:1fr}
  .price-card{border-right:none;border-bottom:1px solid var(--border)}
  .price-card:last-child{border-bottom:none}
  .audience-grid{grid-template-columns:repeat(2,1fr)}
  .mod-list{grid-template-columns:1fr}
  .mod-extra{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
}
@media(max-width:680px){
  .nav-links{display:none}
  nav{padding:0 1rem}
  .sec,.problema{padding:4rem 1.25rem}
  .hero-text{padding:2.5rem 1.5rem}
  .mod-row{grid-template-columns:1fr;gap:1rem}
  .gallery-editorial{grid-template-columns:repeat(2,1fr)}
  .gallery-editorial .gal-item{grid-column:span 1!important;grid-row:span 1!important}
  .pay-opts{grid-template-columns:1fr}
  .modal-grid2{grid-template-columns:1fr}
  .modal-box,.prog-modal-box{padding:1.75rem}
  .contact-grid{grid-template-columns:1fr}
  .audience-grid{grid-template-columns:1fr}
}

/* ============================================================
   HERO · banner "Nos apoyan: [logos]"
   ============================================================ */
.hero-apoyos{
  display:flex;align-items:center;gap:1rem;
  padding:.75rem 0;
  margin-bottom:1.5rem;
  border-bottom:1px solid var(--border-dark);
  flex-wrap:wrap;
}
.hero-apoyos-label{
  font-family:var(--font-mono);
  font-size:10px;font-weight:600;
  color:var(--muted-soft);
  letter-spacing:.16em;text-transform:uppercase;
}
.hero-apoyos-logos{
  display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap;
}
.hero-apoyos-logos img,
.hero-apoyos-logos a img{
  height:22px;width:auto;max-width:90px;
  object-fit:contain;
  filter:grayscale(1) brightness(0) invert(.7);
  opacity:.55;
  transition:opacity .25s,filter .25s;
}
.hero-apoyos-logos a:hover img,
.hero-apoyos-logos img:hover{
  filter:grayscale(0) brightness(1) invert(0);
  opacity:1;
}

/* ============================================================
   /07 · TESTIMONIOS
   ============================================================ */
.testimonios-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.25rem;
  max-width:1280px;margin:0 auto;
}
.testimonio-card{
  background:var(--white);
  padding:1.75rem;
  display:flex;flex-direction:column;gap:1.25rem;
  border-left:3px solid var(--primary);
  position:relative;
}
.testimonio-card::before{
  content:'"';
  position:absolute;top:.5rem;right:1rem;
  font-family:var(--font-display);
  font-size:5rem;line-height:1;
  color:var(--primary);opacity:.15;
  font-weight:900;
}
.testimonio-foto{
  width:60px;height:60px;border-radius:50%;
  background-size:cover;background-position:center;
  background-color:var(--cream);
  flex-shrink:0;
}
.testimonio-foto.placeholder{
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:900;
  font-size:1.6rem;color:var(--primary);
  background:var(--cream);
}
.testimonio-quote{
  font-size:.95rem;line-height:1.6;
  color:var(--text-soft);font-style:italic;
}
.testimonio-meta{margin-top:auto;padding-top:.5rem;border-top:1px solid var(--border)}
.testimonio-nombre{
  font-family:var(--font-display);font-weight:800;
  text-transform:uppercase;font-size:1rem;
  letter-spacing:-.005em;line-height:1.1;
}
.testimonio-cohorte{
  font-size:.72rem;color:var(--muted);
  letter-spacing:.05em;margin-top:.15rem;
}

/* CTA "Dejá tu testimonio" */
.testimonio-cta{
  margin-top:2.5rem;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:1rem;
}
.testimonio-cta-text{
  font-size:1rem;color:var(--text-soft);max-width:480px;margin:0;
}
.btn-testimonio-open{
  background:var(--noir);color:#fff;border:none;
  padding:1rem 2rem;cursor:pointer;
  font-family:var(--font-body);font-size:12px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  transition:background .2s;
}
.btn-testimonio-open:hover{background:var(--primary)}

/* Estrellas de calificación */
.star-rating{display:flex;gap:.25rem}
.star-rating .star{
  background:none;border:none;cursor:pointer;
  font-size:2rem;line-height:1;padding:0;
  color:#D8D5CC;transition:color .12s;
}
.star-rating .star:hover,
.star-rating .star.on{color:#E8A317}

/* Preview de la foto del testimonio */
.t-foto-preview{margin-top:.6rem}
.t-foto-preview img{
  max-width:120px;max-height:120px;
  object-fit:cover;border:1px solid var(--border);
}

/* Honeypot anti-spam: fuera de pantalla, invisible para humanos */
.hp-field{
  position:absolute;left:-9999px;top:auto;
  width:1px;height:1px;overflow:hidden;
}

/* ============================================================
   /11 · APOYOS / AUSPICIANTES
   ============================================================ */
.apoyos-featured{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1.5rem;
  max-width:1080px;margin:0 auto 2rem;
}
.apoyos-featured:empty{display:none;margin:0}
.apoyo-card.featured{
  background:var(--noir);
  padding:2.25rem 2rem;
  display:flex;align-items:center;justify-content:center;
  min-height:140px;
  text-decoration:none;color:inherit;
  border:1px solid var(--border);
  border-radius:6px;
  transition:border-color .2s,transform .2s;
}
a.apoyo-card.featured:hover{border-color:var(--primary);transform:translateY(-2px)}
.apoyo-card-logo{
  width:100%;max-width:280px;height:80px;
  display:flex;align-items:center;justify-content:center;
}
.apoyo-card-logo img{max-width:100%;max-height:100%;object-fit:contain}
.apoyo-card-body{flex:1;min-width:0}
.apoyo-card-name{
  font-family:var(--font-display);font-weight:800;
  font-size:1.2rem;letter-spacing:-.005em;
  text-transform:uppercase;margin-bottom:.35rem;
}
.apoyo-card-desc{font-size:.9rem;color:var(--muted);line-height:1.5}

.apoyos-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:1.25rem;
  max-width:1080px;margin:0 auto;
}
.apoyos-grid:empty{display:none}
.apoyo-logo{
  background:var(--noir);
  height:90px;
  display:flex;align-items:center;justify-content:center;
  padding:1.15rem 1.25rem;border:1px solid var(--border);
  border-radius:4px;
  text-decoration:none;
  transition:border-color .2s,transform .2s;
}
.apoyo-logo img{
  max-width:100%;max-height:100%;object-fit:contain;
}
a.apoyo-logo:hover{border-color:var(--primary);transform:translateY(-2px)}

@media(max-width:1024px){
  .testimonios-grid{grid-template-columns:repeat(2,1fr)}
  .apoyos-grid{grid-template-columns:repeat(4,1fr)}
}
@media(max-width:680px){
  .testimonios-grid{grid-template-columns:1fr}
  .apoyos-featured{grid-template-columns:1fr}
  .apoyo-card.featured{flex-direction:column;text-align:center}
  .apoyos-grid{grid-template-columns:repeat(2,1fr)}
  .hero-apoyos{padding:.5rem 0}
  .hero-apoyos-logos img{height:18px;max-width:70px}
}

/* ============================================================
   LOGO DEL CMS · sustituye el texto cuando branding.logo_url está set
   ============================================================ */
.logo-img-nav{
  display:block;
  object-fit:contain;
  max-height:60px; /* tope superior por seguridad si configuran muy grande */
  max-width:240px;
}
.logo-img-footer{
  display:block;
  object-fit:contain;
  max-height:140px;
  max-width:360px;
  margin-bottom:.75rem;
}
.nav-logo[data-logo-host] img.logo-img-nav{vertical-align:middle}
.footer-brand[data-logo-host]{
  /* Cuando hay img, sacamos el font-size grande que tiene el texto */
  font-size:0;line-height:0;
}
.footer-brand[data-logo-host] .footer-brand-default{
  font-size:clamp(2rem,4vw,3rem);line-height:.95;
}
