/* =========================================================
   MAKETICKET — Estilos v3
   Light theme sofisticado · texturas + tipografía display
   ========================================================= */

:root{
  --bg:            #FFFFFF;
  --bg-soft:       #FAFAF7;
  --bg-cream:      #FBF8F2;
  --bg-elev:       #FFFFFF;
  --surface:       #F4F4F0;
  --border:        #ECECEC;
  --border-strong: #D6D6D6;
  --text:          #0A0A0A;
  --text-muted:    #5A5A5A;
  --text-dim:      #909090;
  --primary:       #E41C34;          /* rojo Maketicket */
  --primary-hover: #C61428;
  --primary-soft:  #FFF1F3;
  --primary-glow:  rgba(228,28,52,0.18);
  --ink:           #0A0A0A;           /* near-black para contraste */
  --accent-warm:   #F5C84B;           /* dorado como guiño a los flyers */
  --success:       #16A34A;
  --gradient:      linear-gradient(135deg,#E41C34 0%,#FF5570 100%);
  --shadow-xs:     0 1px 2px rgba(0,0,0,0.05);
  --shadow-sm:     0 2px 4px rgba(0,0,0,0.04), 0 4px 8px rgba(0,0,0,0.04);
  --shadow:        0 4px 16px rgba(10,10,10,0.06), 0 12px 32px -8px rgba(10,10,10,0.10);
  --shadow-lg:     0 24px 60px -20px rgba(10,10,10,0.25);
  --radius:        16px;
  --radius-sm:     10px;
  --radius-lg:     24px;
  --max-w:         1320px;
  --font-display:  'Fraunces','Playfair Display',Georgia,serif;
  --font-sans:     'Inter',system-ui,sans-serif;
  --font-mono:     'Space Grotesk','Inter',sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-sans);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  /* Textura sutil de puntos */
  background-image:
    radial-gradient(circle at 1px 1px, rgba(10,10,10,0.025) 1px, transparent 0);
  background-size: 24px 24px;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none;transition:opacity .2s ease}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--primary);color:#fff}

/* ======= Layout ======= */
.container{
  width:100%;max-width:var(--max-w);margin:0 auto;padding:0 28px;
}
.section{padding:90px 0}
.section-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-mono);
  font-size:.78rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.18em;
  color:var(--primary);margin-bottom:14px;
}
.section-eyebrow::before{
  content:'';width:24px;height:1px;background:var(--primary);
}
.section-title{
  font-family:var(--font-display);
  font-size:clamp(2.2rem,4.2vw,3.4rem);
  font-weight:600;
  letter-spacing:-0.025em;
  line-height:1.05;
  margin-bottom:14px;
  color:var(--ink);
  font-variation-settings: "SOFT" 30, "WONK" 0;
}
.section-title em{
  font-style:italic;color:var(--primary);
  font-variation-settings: "SOFT" 100, "WONK" 1;
}
.section-subtitle{
  color:var(--text-muted);font-size:1.05rem;
  margin-bottom:40px;max-width:680px;line-height:1.65;
}

/* ======= Header ======= */
.header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,0.85);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  border-bottom:1px solid var(--border);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:84px;gap:24px}
.logo{display:flex;align-items:center;gap:10px;color:var(--text)}
.logo img{height:44px;width:auto;display:block}
.logo-text{font-family:var(--font-display);font-weight:600;font-size:1.55rem;letter-spacing:-0.02em}

@media (max-width:640px){
  .header-inner{height:72px}
  .logo img{height:38px}
}
.nav{display:flex;gap:32px;align-items:center}
.nav a{color:var(--text);font-size:.93rem;font-weight:500;transition:color .2s ease;position:relative}
.nav a:not(.btn):hover{color:var(--primary)}
.nav a:not(.btn)::after{
  content:'';position:absolute;bottom:-6px;left:0;right:0;height:2px;
  background:var(--primary);transform:scaleX(0);transform-origin:center;
  transition:transform .25s ease;
}
.nav a:not(.btn):hover::after{transform:scaleX(1)}
.nav .btn{padding:10px 22px;font-size:.88rem}
.mobile-toggle{display:none;font-size:1.6rem;color:var(--text)}
@media (max-width:880px){.nav{display:none}.mobile-toggle{display:block}}

/* ======= Buttons ======= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 28px;border-radius:50px;
  font-weight:600;font-size:.95rem;
  font-family:var(--font-sans);
  transition:all .25s cubic-bezier(.4,0,.2,1);
  cursor:pointer;white-space:nowrap;
  border:1.5px solid transparent;
  line-height:1;
}
.btn-primary{
  background:var(--primary);color:#fff;
  box-shadow:0 4px 12px -2px rgba(228,28,52,0.35);
}
.btn-primary:hover{
  background:var(--primary-hover);
  transform:translateY(-2px);
  box-shadow:0 12px 28px -8px rgba(228,28,52,0.55);
}
.btn-secondary{
  background:transparent;color:var(--text);
  border-color:var(--border-strong);
}
.btn-secondary:hover{background:var(--bg-soft);border-color:var(--ink)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#222;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--text)}
.btn-ghost:hover{background:var(--bg-soft)}
.btn-large{padding:17px 34px;font-size:1rem}
.btn-full{width:100%}

/* ======= Hero ======= */
.hero{
  position:relative;
  padding:80px 0 50px;
  overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(800px 400px at 92% 10%, rgba(228,28,52,0.08), transparent 60%),
    radial-gradient(700px 350px at 5% 90%, rgba(245,200,75,0.10), transparent 65%);
  pointer-events:none;
}
.hero-inner{
  position:relative;z-index:1;text-align:center;max-width:900px;margin:0 auto;
}
.hero-logo{
  display:flex;flex-direction:column;align-items:center;
  margin-bottom:28px;gap:14px;
  animation:heroLogoIn .8s cubic-bezier(.4,0,.2,1);
}
.hero-logo img{
  height:80px;width:auto;
  filter:drop-shadow(0 4px 12px rgba(228,28,52,0.12));
}
.hero-logo-stamp{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-mono);
  font-size:.78rem;
  color:var(--text-muted);
  letter-spacing:.05em;
  text-transform:uppercase;
  background:#fff;
  padding:7px 16px;
  border-radius:50px;
  border:1px solid var(--border);
  box-shadow:var(--shadow-xs);
}
.hero-logo-stamp strong{
  color:var(--ink);font-weight:700;letter-spacing:0;
  text-transform:lowercase;font-size:.85rem;
}
.hero-logo-stamp .stamp-dot{
  width:7px;height:7px;border-radius:50%;
  background:#16A34A;
  box-shadow:0 0 0 3px rgba(22,163,74,0.15);
}
.hero-logo-stamp .stamp-sep{color:var(--border-strong)}
@media (max-width:640px){
  .hero-logo{margin-bottom:20px;gap:10px}
  .hero-logo img{height:58px}
  .hero-logo-stamp{font-size:.7rem;padding:6px 12px}
  .hero-logo-stamp strong{font-size:.75rem}
}
@keyframes heroLogoIn{
  from{opacity:0;transform:translateY(-12px) scale(0.95)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 16px;background:#fff;
  border:1px solid var(--border);
  border-radius:50px;
  font-size:.82rem;font-weight:500;color:var(--text-muted);
  margin-bottom:24px;box-shadow:var(--shadow-xs);
}
.hero-badge::before{
  content:'';width:8px;height:8px;border-radius:50%;
  background:var(--primary);
  box-shadow:0 0 0 4px rgba(228,28,52,0.18);
}
.hero h1{
  font-family:var(--font-display);
  font-size:clamp(2.5rem,5.5vw,4.4rem);
  font-weight:500;letter-spacing:-0.035em;line-height:1.02;
  margin-bottom:24px;color:var(--ink);
  font-variation-settings:"SOFT" 50;
}
.hero h1 .accent{
  font-style:italic;color:var(--primary);
  font-variation-settings:"SOFT" 100, "WONK" 1;
}
.hero p{
  font-size:1.18rem;color:var(--text-muted);
  max-width:640px;margin:0 auto 36px;line-height:1.55;
}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero-meta{
  display:flex;justify-content:center;gap:32px;flex-wrap:wrap;
  margin-top:48px;color:var(--text-dim);font-size:.85rem;
}
.hero-meta strong{color:var(--ink);font-weight:600;font-family:var(--font-mono)}

/* ======= Carrusel ======= */
.carousel{
  position:relative;
  margin:30px auto 0;
  max-width:var(--max-w);
  padding:0 28px;
}
.carousel-track-wrap{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow);
  background:var(--ink);
  aspect-ratio:8/3;
  max-height:560px;
}
.carousel-track{
  display:flex;height:100%;
  transition:transform .6s cubic-bezier(.4,0,.2,1);
}
.carousel-slide{
  flex:0 0 100%;height:100%;
  position:relative;cursor:pointer;
  overflow:hidden;
}
.carousel-slide img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 6s ease-out;
}
.carousel-slide:hover img{transform:scale(1.04)}
.carousel-caption{
  position:absolute;left:0;right:0;bottom:0;
  padding:36px 40px;
  background:linear-gradient(to top, rgba(0,0,0,0.85), rgba(0,0,0,0.35) 60%, transparent);
  color:#fff;
}
.carousel-caption h3{
  font-family:var(--font-display);
  font-size:clamp(1.4rem,2.4vw,2.2rem);
  font-weight:500;letter-spacing:-0.02em;
  margin-bottom:6px;
}
.carousel-caption p{
  font-size:.95rem;opacity:.85;
  font-family:var(--font-mono);
  letter-spacing:.03em;
}
.carousel-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,0.95);color:var(--ink);
  display:grid;place-items:center;font-size:1.2rem;
  cursor:pointer;z-index:5;
  transition:all .2s ease;
  box-shadow:var(--shadow-sm);
}
.carousel-arrow:hover{background:#fff;transform:translateY(-50%) scale(1.08)}
.carousel-arrow.prev{left:16px}
.carousel-arrow.next{right:16px}
.carousel-dots{
  display:flex;gap:8px;justify-content:center;
  margin-top:18px;
}
.carousel-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--border-strong);
  cursor:pointer;transition:all .25s ease;
}
.carousel-dot.active{background:var(--primary);width:24px;border-radius:4px}

@media (max-width:640px){
  .carousel{padding:0 16px;margin-top:20px}
  .carousel-track-wrap{aspect-ratio:4/3;border-radius:var(--radius)}
  .carousel-caption{padding:20px 22px}
  .carousel-arrow{width:36px;height:36px}
}

/* ======= Filtros / búsqueda ======= */
.events-toolbar{
  display:flex;gap:8px;flex-wrap:wrap;align-items:center;
  margin-bottom:32px;
}
.filter-chip{
  padding:9px 18px;border-radius:50px;
  border:1px solid var(--border-strong);
  background:#fff;color:var(--text);
  font-size:.88rem;font-weight:500;cursor:pointer;
  transition:all .2s ease;font-family:var(--font-sans);
}
.filter-chip:hover{border-color:var(--ink);color:var(--ink)}
.filter-chip.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.search-box{flex:1;min-width:220px;max-width:340px;position:relative}
.search-box input{
  width:100%;padding:11px 14px 11px 40px;
  border:1px solid var(--border-strong);
  border-radius:50px;font-size:.92rem;font-family:inherit;
  background:#fff;color:var(--text);
  transition:border-color .2s ease;
}
.search-box input:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 4px rgba(0,0,0,0.04)}
.search-box::before{
  content:'';position:absolute;left:14px;top:50%;
  width:16px;height:16px;
  transform:translateY(-50%);
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235A5A5A' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'><circle cx='11' cy='11' r='7'/><path d='m21 21-4.35-4.35'/></svg>") center/contain no-repeat;
}

/* ======= Events Grid ======= */
.events{padding:60px 0 100px}
.events-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(290px,1fr));
  gap:28px;
}
.event-card{
  position:relative;
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  transition:transform .35s cubic-bezier(.4,0,.2,1), box-shadow .35s ease;
  display:flex;flex-direction:column;
}
.event-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow);
}
.event-img{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--bg-soft)}
.event-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s cubic-bezier(.4,0,.2,1);
}
.event-card:hover .event-img img{transform:scale(1.06)}
.event-tag{
  position:absolute;top:14px;left:14px;
  background:rgba(255,255,255,0.95);
  backdrop-filter:blur(10px);
  color:var(--ink);padding:6px 12px;border-radius:50px;
  font-size:.7rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;
  font-family:var(--font-mono);
}
.event-tag.tag-hot{background:var(--primary);color:#fff}
.event-tag.tag-soon{background:var(--ink);color:#fff}
.event-tag.tag-sold-out{background:#888;color:#fff}
.event-tag.tag-multi{
  background:#fff;color:var(--ink);
  border:1px solid var(--border-strong);
}
.event-tag.tag-multi::before{content:'📅 '}
.event-body{
  padding:20px 22px 22px;
  display:flex;flex-direction:column;flex:1;gap:8px;
}
.event-date{
  font-size:.78rem;color:var(--primary);
  font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  font-family:var(--font-mono);
}
.event-title{
  font-family:var(--font-display);
  font-size:1.25rem;font-weight:500;line-height:1.15;
  letter-spacing:-0.015em;color:var(--ink);
}
.event-venue{
  color:var(--text-muted);font-size:.88rem;
  display:flex;align-items:flex-start;gap:6px;
  margin-top:2px;
}
.event-venue::before{content:'·';color:var(--primary);font-weight:bold}
.event-cta{
  margin-top:auto;padding-top:8px;
  display:flex;align-items:center;justify-content:space-between;
  font-weight:600;font-size:.9rem;color:var(--ink);
  font-family:var(--font-sans);
}
.event-cta-arrow{
  width:32px;height:32px;border-radius:50%;
  background:var(--primary-soft);color:var(--primary);
  display:grid;place-items:center;
  transition:all .25s ease;
}
.event-card:hover .event-cta-arrow{
  background:var(--primary);color:#fff;transform:translateX(4px);
}

.empty-state{
  grid-column:1/-1;
  text-align:center;padding:80px 20px;
  color:var(--text-muted);
}
.empty-state h3{font-family:var(--font-display);color:var(--text);margin-bottom:6px;font-size:1.4rem;font-weight:500}

/* ======= Event Detail ======= */
.event-hero{
  position:relative;padding:50px 0 40px;
  overflow:hidden;
}
.event-hero::before{
  content:'';position:absolute;inset:0;z-index:0;
  background:radial-gradient(700px 400px at 90% 10%, rgba(228,28,52,0.05), transparent 60%);
  pointer-events:none;
}
.event-hero-inner{
  display:grid;grid-template-columns:0.9fr 1.1fr;gap:50px;align-items:start;
  position:relative;z-index:1;
}
@media (max-width:900px){.event-hero-inner{grid-template-columns:1fr;gap:32px}}
.event-hero-img{
  border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-lg);
  aspect-ratio:4/5;background:var(--bg-soft);
  position:sticky;top:96px;
}
@media (max-width:900px){.event-hero-img{position:static}}
.event-hero-img img{width:100%;height:100%;object-fit:cover}
.event-hero-info .event-date{margin-bottom:14px;font-size:.88rem}
.event-hero-info h1{
  font-family:var(--font-display);
  font-size:clamp(2.1rem,4.2vw,3.2rem);
  font-weight:500;letter-spacing:-0.025em;line-height:1.05;
  margin-bottom:16px;color:var(--ink);
}
.event-description{
  color:var(--text-muted);font-size:1.04rem;
  margin-bottom:24px;line-height:1.65;
}

/* Date selector para eventos multi-día */
.date-selector{
  margin:24px 0 32px;
  background:var(--bg-cream);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:20px 22px;
}
.date-selector h4{
  font-family:var(--font-mono);
  font-size:.78rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;
  color:var(--ink);margin-bottom:14px;
}
.date-list{display:flex;flex-direction:column;gap:10px}
.date-item{
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:14px 16px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  transition:all .2s ease;
}
.date-item:hover{border-color:var(--primary);box-shadow:var(--shadow-xs)}
.date-item.highlight{
  background:linear-gradient(135deg,var(--primary-soft) 0%,#fff 100%);
  border-color:var(--primary);
}
.date-item-info strong{
  font-family:var(--font-display);
  font-weight:500;font-size:1.05rem;
  letter-spacing:-0.01em;color:var(--ink);
  display:block;
}
.date-item-info span{
  font-family:var(--font-mono);
  font-size:.82rem;color:var(--text-muted);
  text-transform:uppercase;letter-spacing:.06em;
}
.date-item .btn{padding:10px 20px;font-size:.85rem;flex-shrink:0}

.event-meta{display:grid;gap:10px;margin:24px 0 28px}
.event-meta-row{
  display:flex;align-items:center;gap:14px;
  padding:14px 18px;background:var(--bg-soft);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
}
.event-meta-row strong{
  display:block;font-size:.7rem;color:var(--text-dim);
  text-transform:uppercase;letter-spacing:.08em;
  margin-bottom:2px;font-weight:700;font-family:var(--font-mono);
}
.event-meta-row span{font-size:.96rem;font-weight:500;color:var(--text)}
.event-meta-icon{
  width:38px;height:38px;flex-shrink:0;border-radius:10px;
  background:#fff;color:var(--primary);
  display:grid;place-items:center;font-size:1rem;
  border:1px solid var(--border);
}

/* Plano */
.seating-map-wrap{
  background:var(--bg-soft);border:1px solid var(--border);
  border-radius:var(--radius);padding:24px;overflow:hidden;
}
.seating-map-wrap img{width:100%;border-radius:var(--radius-sm)}

/* Pricing */
.pricing{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:14px;margin-bottom:40px;
}
.price-tier{
  padding:24px 20px;background:#fff;
  border:1px solid var(--border);border-radius:var(--radius);
  text-align:center;
  transition:all .25s ease;
  position:relative;
}
.price-tier:hover{
  border-color:var(--primary);
  transform:translateY(-3px);
  box-shadow:var(--shadow);
}
.price-tier.featured{
  background:var(--ink);border-color:var(--ink);position:relative;
}
.price-tier.featured::before{
  content:'⭐ MÁS VENDIDA';position:absolute;top:-12px;left:50%;
  transform:translateX(-50%);
  background:var(--primary);color:#fff;
  font-size:.66rem;font-weight:700;
  padding:5px 12px;border-radius:50px;
  letter-spacing:.08em;
  font-family:var(--font-mono);
}
.price-tier-name{
  font-family:var(--font-mono);
  font-size:.78rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.08em;
  color:var(--text-muted);margin-bottom:10px;
}
.price-tier.featured .price-tier-name{color:rgba(255,255,255,0.7)}
.price-tier-amount{
  font-family:var(--font-display);
  font-size:1.9rem;font-weight:500;
  letter-spacing:-0.02em;color:var(--ink);
  line-height:1;
}
.price-tier.featured .price-tier-amount{color:#fff}
.price-tier-currency{
  font-size:.85rem;color:var(--text-muted);
  font-weight:500;margin-right:3px;
  font-family:var(--font-mono);
}
.price-tier.featured .price-tier-currency{color:rgba(255,255,255,0.6)}
.price-tier-note{
  font-size:.74rem;color:var(--text-dim);margin-top:6px;
}
.price-tier.featured .price-tier-note{color:rgba(255,255,255,0.6)}

/* CTA box */
.buy-cta-section{
  margin:48px auto;max-width:640px;
  background:linear-gradient(135deg,#fff 0%,var(--bg-cream) 100%);
  border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:36px 32px;text-align:center;box-shadow:var(--shadow);
}
.buy-cta-section h3{
  font-family:var(--font-display);font-size:1.5rem;font-weight:500;
  margin-bottom:8px;color:var(--ink);letter-spacing:-0.01em;
}
.buy-cta-section p{color:var(--text-muted);font-size:.94rem;margin-bottom:22px}

.back-link{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--text-muted);font-size:.88rem;
  margin-bottom:18px;transition:color .2s ease;
  font-family:var(--font-mono);text-transform:uppercase;
  letter-spacing:.06em;font-weight:600;
}
.back-link:hover{color:var(--primary)}
.back-link::before{content:'←';font-family:var(--font-sans);font-weight:400}

/* ======= Espacios publicitarios ======= */
.ad-grid-card{
  grid-column:span 1;
  background:linear-gradient(135deg, var(--ink) 0%, #1f1f1f 100%);
  color:#fff;border-radius:var(--radius);
  overflow:hidden;padding:32px 26px;
  display:flex;flex-direction:column;justify-content:center;
  min-height:380px;
  position:relative;
}
.ad-grid-card::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 80% 20%, rgba(228,28,52,0.25), transparent 60%);
  pointer-events:none;
}
.ad-grid-card > *{position:relative;z-index:1}
.ad-grid-card h3{
  font-family:var(--font-display);
  font-size:1.6rem;font-weight:500;line-height:1.1;
  margin-bottom:10px;letter-spacing:-0.015em;
}
.ad-grid-card h3 em{color:var(--accent-warm);font-style:italic}
.ad-grid-card p{font-size:.94rem;opacity:.85;margin-bottom:20px;line-height:1.5}
.ad-grid-card .btn{background:#fff;color:var(--ink);align-self:flex-start}
.ad-grid-card .btn:hover{background:var(--accent-warm)}
.ad-label{
  position:absolute;top:14px;right:14px;
  background:rgba(255,255,255,0.1);color:#fff;
  font-size:.65rem;padding:3px 8px;border-radius:4px;
  letter-spacing:.08em;text-transform:uppercase;
  font-weight:600;font-family:var(--font-mono);
}

/* ======= Sección Trust + Stats ======= */
.trust{
  background:var(--bg-cream);
  padding:90px 0;
  border-top:1px solid var(--border);
  position:relative;
}
.trust::before{
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 1px 1px, rgba(10,10,10,0.04) 1px, transparent 0);
  background-size: 24px 24px;
  opacity:0.4;
  pointer-events:none;
}
.trust > *{position:relative;z-index:1}
.trust-header{text-align:center;margin-bottom:56px;max-width:720px;margin-left:auto;margin-right:auto}
.trust-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:22px;
}
.trust-item{
  padding:30px 26px;background:#fff;border-radius:var(--radius);
  border:1px solid var(--border);
  transition:transform .25s ease,box-shadow .25s ease;
}
.trust-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.trust-icon{
  width:46px;height:46px;border-radius:12px;
  background:var(--primary-soft);color:var(--primary);
  display:grid;place-items:center;font-size:1.3rem;
  margin-bottom:16px;
}
.trust-item h3{
  font-family:var(--font-display);
  font-size:1.2rem;font-weight:500;
  margin-bottom:8px;letter-spacing:-0.01em;
}
.trust-item p{color:var(--text-muted);font-size:.94rem;line-height:1.55}

.stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:24px;margin-top:60px;
  padding:36px;background:#fff;
  border:1px solid var(--border);border-radius:var(--radius-lg);
}
@media (max-width:680px){.stats{grid-template-columns:1fr;padding:24px}}
.stat{text-align:center;position:relative}
.stat:not(:last-child)::after{
  content:'';position:absolute;right:-12px;top:20%;height:60%;width:1px;
  background:var(--border);
}
@media (max-width:680px){.stat:not(:last-child)::after{display:none}}
.stat-num{
  font-family:var(--font-display);
  font-size:clamp(2.2rem,4vw,3rem);
  font-weight:500;line-height:1;
  letter-spacing:-0.025em;color:var(--ink);
}
.stat-num em{color:var(--primary);font-style:normal}
.stat-label{
  font-family:var(--font-mono);
  font-size:.78rem;color:var(--text-muted);
  text-transform:uppercase;letter-spacing:.1em;
  margin-top:8px;font-weight:500;
}

/* ======= Sectores ======= */
.sectors{padding:90px 0;background:#fff;border-top:1px solid var(--border)}
.sectors-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
@media (max-width:920px){.sectors-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.sectors-grid{grid-template-columns:1fr}}
.sector-item{
  background:var(--bg-soft);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:26px 22px;
  transition:all .25s ease;
  position:relative;
  overflow:hidden;
}
.sector-item::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--primary);
  transform:scaleY(0);transform-origin:top;
  transition:transform .25s ease;
}
.sector-item:hover{
  background:#fff;border-color:var(--border-strong);
  transform:translateY(-3px);box-shadow:var(--shadow-sm);
}
.sector-item:hover::before{transform:scaleY(1)}
.sector-icon{
  font-size:1.6rem;margin-bottom:12px;
  display:inline-flex;width:44px;height:44px;
  background:#fff;border:1px solid var(--border);
  border-radius:12px;align-items:center;justify-content:center;
}
.sector-item h3{
  font-family:var(--font-display);
  font-size:1.15rem;font-weight:500;
  letter-spacing:-0.01em;color:var(--ink);
  margin-bottom:6px;
}
.sector-item p{
  color:var(--text-muted);font-size:.88rem;line-height:1.55;
}

/* ======= Cómo trabajamos ======= */
.process{
  padding:90px 0;
  background:var(--bg-cream);
  border-top:1px solid var(--border);
  position:relative;
}
.process::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle at 1px 1px, rgba(10,10,10,0.04) 1px, transparent 0);
  background-size:24px 24px;opacity:0.4;pointer-events:none;
}
.process > *{position:relative;z-index:1}
.process-timeline{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:18px;position:relative;
}
@media (max-width:980px){.process-timeline{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.process-timeline{grid-template-columns:1fr}}
.process-timeline::before{
  content:'';position:absolute;
  top:40px;left:6%;right:6%;height:2px;
  background:repeating-linear-gradient(
    to right,
    var(--border-strong) 0 8px,
    transparent 8px 16px
  );
  z-index:0;
}
@media (max-width:980px){.process-timeline::before{display:none}}
.process-step{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--radius);padding:22px 20px;
  text-align:center;position:relative;z-index:1;
  transition:transform .25s ease,box-shadow .25s ease;
}
.process-step:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.process-num{
  width:48px;height:48px;border-radius:50%;
  background:var(--primary);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:600;font-size:1.4rem;
  margin:0 auto 14px;
  box-shadow:0 4px 12px -3px rgba(228,28,52,0.45);
}
.process-step h3{
  font-family:var(--font-display);font-size:1.1rem;font-weight:500;
  letter-spacing:-0.01em;color:var(--ink);margin-bottom:6px;
}
.process-step p{color:var(--text-muted);font-size:.85rem;line-height:1.5}

/* ======= FAQ ======= */
.faq-section{
  padding:90px 0;background:#fff;
  border-top:1px solid var(--border);
}
.faq-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  max-width:980px;margin:0 auto;
}
@media (max-width:780px){.faq-grid{grid-template-columns:1fr}}
.faq-item{
  background:var(--bg-soft);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:0;
  transition:border-color .2s ease;
}
.faq-item:hover{border-color:var(--border-strong)}
.faq-item[open]{border-color:var(--primary);background:#fff}
.faq-item summary{
  cursor:pointer;
  padding:20px 22px;
  font-family:var(--font-display);
  font-weight:500;font-size:1.02rem;
  color:var(--ink);letter-spacing:-0.005em;
  list-style:none;
  display:flex;justify-content:space-between;align-items:center;
  gap:14px;line-height:1.3;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:'+';
  font-family:var(--font-sans);
  font-size:1.6rem;font-weight:300;color:var(--primary);
  flex-shrink:0;
  transition:transform .25s ease;
  line-height:1;
}
.faq-item[open] summary::after{
  content:'−';transform:rotate(0deg);
}
.faq-item p{
  padding:0 22px 22px;
  color:var(--text-muted);
  font-size:.95rem;line-height:1.65;
}

/* ======= Footer ======= */
.footer{
  padding:70px 0 30px;
  background:var(--ink);
  color:rgba(255,255,255,0.7);
  position:relative;
  overflow:hidden;
}
.footer::before{
  content:'';position:absolute;top:0;left:0;right:0;
  height:1px;background:linear-gradient(90deg, transparent, var(--primary), transparent);
}
.footer-grid{
  display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;
  gap:48px;margin-bottom:48px;
}
@media (max-width:860px){.footer-grid{grid-template-columns:1fr 1fr;gap:36px}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr;gap:32px}}
.footer-brand img{filter:brightness(0) invert(1);height:30px;margin-bottom:18px}
.footer-brand .mission{
  font-family:var(--font-display);font-style:italic;
  color:rgba(255,255,255,0.85);
  font-size:1.05rem;line-height:1.5;max-width:380px;
  margin-bottom:20px;
}
.footer h4{
  font-family:var(--font-mono);
  font-size:.74rem;text-transform:uppercase;
  letter-spacing:.12em;color:rgba(255,255,255,0.5);
  margin-bottom:16px;font-weight:600;
}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer ul a{color:rgba(255,255,255,0.7);font-size:.93rem;transition:color .2s ease}
.footer ul a:hover{color:#fff}
.footer-social{display:flex;gap:10px;margin-top:18px}
.footer-social a{
  width:38px;height:38px;display:grid;place-items:center;
  background:rgba(255,255,255,0.08);color:#fff;
  border-radius:50%;transition:all .25s ease;
  font-size:.8rem;font-weight:700;
  font-family:var(--font-mono);
}
.footer-social a:hover{background:var(--primary);transform:translateY(-3px)}
.footer-bottom{
  padding-top:30px;border-top:1px solid rgba(255,255,255,0.08);
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:12px;color:rgba(255,255,255,0.45);font-size:.82rem;
}

/* ======= Responsive ======= */
@media (max-width:640px){
  .section{padding:60px 0}
  .hero{padding:60px 0 20px}
  .events{padding:40px 0 80px}
  .events-grid{grid-template-columns:1fr 1fr;gap:16px}
  .event-body{padding:14px 14px 16px}
  .event-title{font-size:1rem}
  .event-venue{font-size:.78rem}
  .container{padding:0 16px}
  .btn-large{padding:14px 26px;font-size:.95rem}
  .price-tier{padding:18px 14px}
  .price-tier-amount{font-size:1.5rem}
}
@media (max-width:380px){.events-grid{grid-template-columns:1fr}}
