:root{
  --rojo:#e10613;
  --gris:#1f2329;
  --blanco:#ffffff;
  --negro:#000000;
  --shadow:0 10px 30px rgba(0,0,0,.12);
  --radius:18px;
}

*{box-sizing:border-box;margin:0;padding:0;font-family:'Inter',sans-serif;}
html{scroll-behavior:smooth;}
body{background:var(--blanco);color:var(--gris);}
a{text-decoration:none;color:inherit}

/* NAV */
nav{
  position:sticky;top:0;
  background:rgba(255,255,255,0.9);
  backdrop-filter:blur(8px);
  display:flex;justify-content:space-between;align-items:center;
  padding:12px 24px;z-index:1000;
  border-bottom:1px solid rgba(0,0,0,0.1)
}
.logo{font-weight:800;display:flex;align-items:center;gap:10px;color:var(--rojo)}
.links a{margin:0 10px;font-weight:600;}

.btn{
  padding:10px 18px;border-radius:999px;
  font-weight:600;border:1px solid transparent;
  transition:.3s;cursor:pointer
}
.btn.primary{background:var(--rojo);color:var(--blanco)}
.btn.primary:hover{background:#b50510}

/* HERO */
header{
  position:relative;height:90vh;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  color:var(--blanco)
}
.hero-slides img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;opacity:0;
  transition:opacity 1s ease;z-index:1
}
.hero-slides img.active{opacity:1}
.hero-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.55);z-index:2}
.hero-text{
  position:relative;z-index:3;text-align:center;
  background:rgba(255,255,255,0.08);
  backdrop-filter:blur(10px);
  padding:40px 60px;border-radius:20px;
  border:1px solid rgba(255,255,255,0.3)
}
.hero-text h1{font-size:48px;color:var(--blanco);margin-bottom:10px;}
.hero-text p{font-size:20px;color:var(--blanco);opacity:.9}

/* SECCIONES */
section{padding:60px 20px;max-width:1200px;margin:auto;}
h2{font-size:32px;color:var(--rojo);margin-bottom:10px;}
p{margin-bottom:20px;}

/* OMV */
.omv{padding-top:20px;padding-bottom:10px;}
.omv-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:16px
}
.omv-card{
  background:#fff;border:1px solid #e6e6e6;
  border-radius:16px;box-shadow:var(--shadow);
  padding:18px
}
.omv-card h3{
  color:#b4040e;
  font-weight:800;
  letter-spacing:0.5px;
  margin-bottom:10px;
  text-transform:uppercase;
}
.omv-card p{margin:0}

/* DAMAS CMIC */
.damas{background:#f8f8f8;padding:60px 20px;}
.damas p{max-width:900px;}

/* CURSOS */
.grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:20px;
}
.card{
  background:#fff;border:1px solid #ddd;
  border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);
  transition:transform .3s ease, box-shadow .3s ease;
}
.card:hover{
  transform:translateY(-5px);
  box-shadow:0 6px 16px rgba(0,0,0,0.15);
}
.card img{width:100%;height:180px;object-fit:cover}
.card-body{padding:16px;text-align:center}
.card-body h3{font-weight:600;margin-bottom:.5rem}
.card-body p{font-size:.95rem;line-height:1.4;color:#444}

/* Botón ICIC */
.row-center{display:flex;justify-content:center;margin-top:16px}
.btn-cmic-icic{
  background-color:#E30613;color:#fff;
  padding:12px 28px;border:none;border-radius:30px;
  font-weight:600;font-size:16px;letter-spacing:.5px;
  cursor:pointer;text-decoration:none;display:inline-block;
  transition:background .2s ease, transform .2s ease;
  position:relative;overflow:hidden;
  box-shadow:0 4px 12px rgba(227, 6, 19, 0.3);
}
.btn-cmic-icic:hover{background-color:#c10510;transform:translateY(-2px)}
.btn-cmic-icic:active{transform:translateY(0);box-shadow:0 2px 8px rgba(227, 6, 19, 0.25)}
.btn-cmic-icic .ripple{
  position:absolute;border-radius:50%;
  transform:scale(0);
  animation:ripple-icic .6s ease-out;
  background:rgba(255,255,255,0.45);
  pointer-events:none;
}
@keyframes ripple-icic{to{transform:scale(12);opacity:0}}

/* EVENTOS Carousel */
.carousel{
  position:relative;overflow:hidden;
  border:1px solid #e6e6e6;border-radius:16px;
  box-shadow:var(--shadow);background:#fafafa;
}
.carousel-track{display:flex;transition:transform .45s ease}
.slide{min-width:100%;display:flex;align-items:center;justify-content:center;background:#f6f6f6}
.slide img{width:100%;height:auto;display:block}
.control{
  position:absolute;top:50%;transform:translateY(-50%);
  border:none;background:rgba(0,0,0,.45);color:#fff;
  width:40px;height:40px;border-radius:999px;
  cursor:pointer;z-index:5;font-size:26px;line-height:1;
}
#evPrev{left:10px} 
#evNext{right:10px}
.dots{display:flex;gap:8px;justify-content:center;margin-top:10px}
.dots .dot{width:8px;height:8px;border-radius:999px;background:#d0d0d0}
.dots .dot.active{background:linear-gradient(90deg,var(--rojo),#7a0007)}

/* CTA MAESTRÍAS */
.cta-glow{
  display:inline-flex;align-items:center;gap:10px;
  margin-top:8px;padding:14px 22px;border-radius:14px;
  background:linear-gradient(90deg,#b4040e,var(--rojo));
  color:#fff;font-weight:800;letter-spacing:.2px;
  box-shadow:0 10px 28px rgba(225,6,19,.35);
  position:relative;overflow:hidden
}
.cta-glow .arrow{transition:transform .25s ease}
.cta-glow:hover .arrow{transform:translateX(3px)}
.cta-glow:after{
  content:"";position:absolute;inset:-40% -10%;
  background:radial-gradient(closest-side, rgba(255,255,255,.35), transparent 70%);
  filter:blur(18px);opacity:.5;animation:pulse 2.2s infinite ease-in-out
}
@keyframes pulse{0%,100%{opacity:.35}50%{opacity:.75}}

/* MAESTRÍAS cards panel (estático) */
.cmic-cards-section{max-width:1240px;margin:34px auto 60px;padding:0 20px;}
.cmic-cards-panel{
  position:relative;
  background:rgba(255, 2, 2, 0.764);
  border:1px solid rgba(195, 11, 11, 0.712);
  border-radius:22px;
  backdrop-filter:blur(6px);
  box-shadow:0 20px 50px rgba(73, 21, 21, 0.47);
  padding:clamp(16px,3vw,26px);
  overflow:hidden;
}
.cc-viewport{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));}
.cc-card{position:relative;border-radius:20px;overflow:hidden;box-shadow:0 16px 40px rgba(0,0,0,.28);}
.cc-card a{display:block}
.cc-card img{width:100%;height:auto;display:block}
.cc-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 45%, rgba(0,0,0,.58) 100%);
}
.cc-content{position:absolute;left:16px;right:16px;bottom:16px;color:#fff;}
.cc-title{margin:0 0 2px;font-weight:800;font-size:18px}
.cc-meta{opacity:.9;font-size:13px;margin-bottom:10px}
.cc-btn{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.25);
  border-radius:14px;padding:10px 14px;font-size:14px;
}

/* AFÍLIATE */
.afiliate-section{
  background-color:#f8f8f8;
  padding:80px 20px;
  text-align:center;
}
.afiliate-container{
  max-width:900px;
  margin:0 auto;
  background:#fff;
  border-radius:16px;
  box-shadow:0 4px 20px rgba(0,0,0,0.1);
  padding:40px;
  transition:transform .3s ease, box-shadow .3s ease;
}
.afiliate-container:hover{transform:scale(1.01);box-shadow:0 8px 25px rgba(0,0,0,0.15);}
.afiliate-section h2{color:#c8102e;font-weight:800;margin-bottom:15px;font-size:2em;}
.afiliate-section .intro{color:#333;margin-bottom:25px;line-height:1.6;}
.afiliate-card{
  background:#f0f0f0;
  border-left:6px solid #c8102e;
  padding:25px;margin-bottom:25px;text-align:left;
  border-radius:12px;
}
.afiliate-card h3{color:#333;margin-bottom:15px;}
.benefits-list{list-style:none;padding-left:0;}
.benefits-list li{
  position:relative;padding-left:28px;margin-bottom:10px;color:#555;
  line-height:1.6;font-size:.95rem;
}
.benefits-list li::before{
  content:"";position:absolute;left:0;top:9px;
  width:10px;height:10px;background-color:#c8102e;border-radius:50%;
  box-shadow:1px 1px 4px rgba(0, 0, 0, 0.3);
}
.cta-text{margin:20px 0;color:#444;font-weight:500;}
.btn-afiliate{
  display:inline-block;background-color:#c8102e;color:#fff;
  padding:12px 28px;border-radius:30px;text-decoration:none;font-weight:600;
  transition:background .3s ease, transform .2s ease;
}
.btn-afiliate:hover{background-color:#a00e25;transform:scale(1.05);}

/* ===== Carrusel Descuentos Afiliados (clases únicas) ===== */
.af-carousel-section{
  width:100%;
  padding:60px 20px;
  background:#f5f5f5;
  text-align:center;
  max-width:1200px;
  margin:auto;
}
.af-carousel-title{
  font-size:28px;
  font-weight:800;
  color:#b5121b;
  margin-bottom:20px;
  letter-spacing:.4px;
}
.af-carousel-container{
  position:relative;
  width:100%;
  max-width:900px;
  margin:0 auto;
  overflow:hidden;
  border-radius:16px;
  box-shadow:var(--shadow);
  background:#fff;
}
.af-carousel-track{
  display:flex;
  transition:transform .45s ease;
}
.af-slide{
  min-width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#fff;
}
.af-slide img{
  width:100%;
  height:auto;
  display:block;
}
.af-carousel-btn{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  border:none;
  background:rgba(0,0,0,.45);
  color:#fff;
  width:42px;
  height:42px;
  border-radius:999px;
  cursor:pointer;
  z-index:5;
  font-size:26px;
  line-height:1;
}
.af-prev{left:10px}
.af-next{right:10px}
.af-carousel-btn:hover{background:rgba(0,0,0,.75)}
.af-dots{
  display:flex;
  gap:8px;
  justify-content:center;
  padding:12px 0 14px;
  background:#fff;
}
.af-dots .dot{
  width:8px;height:8px;border-radius:999px;
  background:#d0d0d0;cursor:pointer;
}
.af-dots .dot.active{
  background:linear-gradient(90deg,var(--rojo),#7a0007);
}

/* ==== Coverflow Damas CMIC ==== */
.coverflow{
  position:relative;
  margin-top:18px;
  height:420px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:8px;
}
.coverflow .cf-btn{
  width:44px;height:44px;border-radius:12px;
  border:1px solid rgba(255,255,255,.2);
  background:#15181d;color:#fff;cursor:pointer;
  display:grid;place-items:center;font-size:24px;line-height:1;
  transition:.2s;box-shadow:0 8px 18px rgba(0,0,0,.25);
}
.coverflow .cf-btn:hover{transform:translateY(-1px);background:#1d232b}
.cf-stage{
  position:relative;height:100%;
  perspective:1200px;
  display:flex;align-items:center;justify-content:center;
  overflow:visible;
}
.cf-card{
  position:absolute;
  width:min(56vw, 320px);
  height:min(70%, 360px);
  border-radius:22px;
  overflow:hidden;
  box-shadow:0 18px 40px rgba(0,0,0,.35);
  transform-origin:center center;
  display:block;
  background:#0f1216;
}
.cf-card img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}

/* Etiquetas coverflow */
.cf-labels{
  position:absolute;
  left:50%;
  bottom:12px;
  transform:translateX(-50%);
  text-align:center;
  color:#fff;
  pointer-events:none;
}
.cf-title{
  margin:0;
  font-weight:800;
  letter-spacing:.3px;
  text-shadow:0 6px 20px rgba(0,0,0,.45);
}
.cf-sub{margin:.25rem 0 0;opacity:.9;color:#e5e7eb}

/* Footer */
.cmic-footer{background:var(--gris);color:#fff;margin-top:40px;border-top:3px solid var(--rojo)}
.cmic-footer__wrap{
  max-width:1200px;margin:0 auto;padding:30px 20px;
  display:grid;gap:30px;grid-template-columns:1fr 1fr 1fr;align-items:start;
}
.cmic-footer__brand{display:flex;align-items:center;gap:14px}
.cmic-footer__logo{
  width:60px;height:60px;display:grid;place-items:center;
  font-weight:900;color:#fff;
  background:linear-gradient(135deg,var(--rojo),#a1121b);
  border-radius:16px;box-shadow:0 8px 24px rgba(225,6,19,.35);
}
.cmic-footer__brand h3{margin:0 0 6px}
.cmic-footer__brand p{margin:0;color:#d9d9d9}
.cmic-footer__mapa h4,
.cmic-footer__contacto h4{margin:0 0 10px;color:#f2f2f2}
.cmic-footer__map{
  width:100%;height:220px;border-radius:12px;overflow:hidden;
  border:1px solid rgba(255,255,255,.15);background:#0f0f0f;margin-bottom:12px;
}
.footer-form{display:flex;flex-direction:column;gap:10px}
.footer-form input{
  padding:10px 12px;border-radius:10px;border:1px solid rgba(255,255,255,.2);
  background:#1b1b1b;color:#fff;outline:none;
}
.footer-form input::placeholder{color:#aaa}
.footer-form button{margin-top:5px;align-self:flex-start}
.cmic-footer__social{display:flex;justify-content:center}
.cmic-footer__icons{display:flex;gap:12px;flex-wrap:wrap;padding-bottom:10px}
.cmic-icon{
  width:44px;height:44px;display:grid;place-items:center;border-radius:12px;
  background:#151515;border:1px solid rgba(255,255,255,.15);transition:.2s ease;
}
.cmic-icon svg{width:22px;height:22px;fill:#e8e8e8}
.cmic-icon:hover{transform:translateY(-2px);box-shadow:0 10px 16px rgba(0,0,0,.35)}
.cmic-icon:hover svg{fill:#fff}
.cmic-footer__bottom{
  text-align:center;color:#ddd;padding:16px 10px 24px;
  border-top:1px dashed rgba(255,255,255,.15);
  max-width:1200px;margin:0 auto;
}

/* Responsive footer + coverflow */
@media (max-width: 900px){
  .cmic-footer__wrap{grid-template-columns:1fr 1fr}
  .coverflow{height:380px}
  .cf-card{width:min(70vw, 300px);height:min(68%, 340px)}
}
@media (max-width: 620px){
  .cmic-footer__wrap{grid-template-columns:1fr}
  .coverflow{height:360px}
  .cf-card{width:min(78vw, 280px);height:min(66%, 320px)}
}
