/* ==========================================================
   CJ ACADEMIA — Rediseño 2026
   Paleta: rojo CJ + azul cinturón + crema + navy
   Tipografía MMA: Bowlby One SC + Anton + Teko + Manrope
   ========================================================== */
/* Fuentes: se cargan desde <head> (app/tpl/head.php) con preconnect — no usar @import aquí. */

:root{
  --cream:        #F4EEDC;
  --cream-2:      #EDE4CC;
  --cream-3:      #E5D9B6;
  --red:          #E8472B;
  --red-dark:     #C7371E;
  --red-deep:     #8E2412;
  --blue:         #2585C5;
  --blue-dark:    #1C6A9E;
  --blue-deep:    #0F4970;
  --navy:         #1E2350;
  --navy-2:       #161938;
  --ink:          #1A1814;
  --muted:        #6f6a5e;
  --paper:        #FFFFFF;
  --shadow:       0 10px 32px rgba(20,20,40,.14);
  --shadow-sm:    0 4px 14px rgba(20,20,40,.10);
  --shadow-lg:    0 22px 60px rgba(20,20,40,.22);
  --radius:       18px;
  --radius-sm:    10px;
  --maxw:         1200px;
}

/* Reset */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Manrope',system-ui,sans-serif;
  background:var(--cream);
  color:var(--ink);
  line-height:1.6;
  font-weight:500;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{max-width:100%;display:block}
a{color:var(--blue-dark);text-decoration:none}
a:hover{text-decoration:underline}
button{font-family:inherit;cursor:pointer}

/* Typography system */
.display,h1,h2,h3,h4{
  font-family:'Bowlby One SC','Anton',Impact,sans-serif;
  font-weight:400;
  letter-spacing:.5px;
  line-height:1.12;
  text-transform:uppercase;
  color:var(--navy);
}
h2{font-size:clamp(2rem,4.8vw,3.6rem)}
h3{font-size:1.55rem;line-height:1.05}
h4{font-size:1.15rem;line-height:1.15;font-family:'Anton',sans-serif;letter-spacing:1px}
.kicker{
  font-family:'Teko',sans-serif;font-weight:600;
  text-transform:uppercase;letter-spacing:3px;
  font-size:1.1rem;color:var(--red);
  display:inline-flex;align-items:center;gap:10px;
}
.kicker::before{content:"";width:34px;height:3px;background:var(--red)}
.section--navy .kicker{color:#ffb09c}
.section--navy .kicker::before{background:#ffb09c}
.section--red .kicker{color:#fff}
.section--red .kicker::before{background:#fff}
.lead{font-size:1.1rem;color:var(--muted);max-width:60ch;line-height:1.55}
.section--navy .lead{color:#cdd0e6}

/* Layout */
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:90px 0;position:relative}
.section--tight{padding:60px 0}
.section--cream2{background:var(--cream-2)}
.section--navy{background:var(--navy);color:#fff}
.section--navy h2,.section--navy h3,.section--navy h4{color:#fff}
.section--red{background:var(--red);color:#fff}
.section--red h2,.section--red h3{color:#fff}
.section--paper{background:var(--paper)}

/* Belt stripe pattern — signature decorative element */
.belt-stripe{
  height:14px;width:100%;
  background:
    repeating-linear-gradient(90deg,
      var(--red) 0 50px,
      var(--red) 50px,
      transparent 50px 56px,
      var(--blue) 56px 106px,
      transparent 106px 112px);
}
.belt-stripe--sm{height:8px}
.belt-stripe--xl{height:22px}

/* Tatami texture — subtle interlocking tiles */
.tatami-bg{
  background-color:var(--cream);
  background-image:
    linear-gradient(45deg,rgba(232,71,43,.04) 25%,transparent 25%),
    linear-gradient(-45deg,rgba(37,133,197,.04) 25%,transparent 25%),
    linear-gradient(45deg,transparent 75%,rgba(232,71,43,.04) 75%),
    linear-gradient(-45deg,transparent 75%,rgba(37,133,197,.04) 75%);
  background-size:48px 48px;
  background-position:0 0,0 24px,24px -24px,-24px 0;
}
.tatami-bg--strong{
  background-image:
    linear-gradient(45deg,rgba(232,71,43,.10) 25%,transparent 25%),
    linear-gradient(-45deg,rgba(37,133,197,.10) 25%,transparent 25%),
    linear-gradient(45deg,transparent 75%,rgba(232,71,43,.10) 75%),
    linear-gradient(-45deg,transparent 75%,rgba(37,133,197,.10) 75%);
}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Manrope';font-weight:800;font-size:.95rem;
  text-transform:uppercase;letter-spacing:1px;
  padding:14px 28px;border-radius:6px;border:none;
  cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,background .15s;
  text-decoration:none;position:relative;
}
.btn:hover{text-decoration:none;transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.btn svg{width:1.2em;height:1.2em;flex:none}
.btn>span{display:inline-flex;align-items:center}
.btn--red{background:var(--red);color:#fff;box-shadow:0 4px 0 var(--red-deep)}
.btn--red:hover{background:var(--red-dark);box-shadow:0 6px 0 var(--red-deep),var(--shadow)}
.btn--blue{background:var(--blue);color:#fff;box-shadow:0 4px 0 var(--blue-deep)}
.btn--blue:hover{background:var(--blue-dark);box-shadow:0 6px 0 var(--blue-deep),var(--shadow)}
.btn--navy{background:var(--navy);color:#fff;box-shadow:0 4px 0 #0a0d28}
.btn--navy:hover{background:var(--navy-2);box-shadow:0 6px 0 #0a0d28,var(--shadow)}
.btn--white{background:#fff;color:var(--navy);box-shadow:0 4px 0 rgba(0,0,0,.18)}
.btn--white:hover{background:#f5f5f5;box-shadow:0 6px 0 rgba(0,0,0,.18),var(--shadow)}
.btn--ghost{background:transparent;border:2.5px solid currentColor;color:var(--navy);box-shadow:none}
.btn--ghost:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn--lg{padding:18px 36px;font-size:1.02rem}
.btn--xl{padding:22px 44px;font-size:1.15rem;border-radius:8px}

/* Forms */
.field{margin-bottom:16px}
.field label{
  display:block;font-family:'Teko';font-weight:600;font-size:1rem;
  letter-spacing:1.5px;text-transform:uppercase;color:var(--navy);
  margin-bottom:6px;
}
input[type="text"],input[type="tel"],input[type="email"],
input[type="number"],input[type="date"],input[type="password"],
select,textarea{
  width:100%;font-family:'Manrope',system-ui,sans-serif;font-size:1rem;
  padding:13px 15px;border:2px solid #ddd3b9;border-radius:10px;
  background:#fff;color:var(--ink);font-weight:500;
  transition:border-color .15s,box-shadow .15s;
}
input:focus,select:focus,textarea:focus{
  outline:none;border-color:var(--blue);box-shadow:0 0 0 4px rgba(37,133,197,.15);
}
input::placeholder,textarea::placeholder{color:#a8a08a;font-weight:400}
textarea{min-height:96px;resize:vertical;font-family:'Manrope',system-ui,sans-serif;line-height:1.5}
select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%231E2350' stroke-width='3'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;cursor:pointer}

/* Header / Nav */
.site-header{
  position:sticky;top:0;z-index:50;
  background:var(--cream);
  border-bottom:3px solid var(--navy);
}
.site-header::after{
  content:"";position:absolute;left:0;right:0;bottom:-3px;height:3px;
  background:linear-gradient(90deg,var(--red) 0 33%,var(--blue) 33% 66%,var(--navy) 66%);
  display:none;
}
.nav{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:12px 24px;max-width:var(--maxw);margin:0 auto;
}
.brand{display:flex;align-items:center;gap:14px;text-decoration:none}
.brand:hover{text-decoration:none}
.brand img{height:62px;width:auto;flex:none;mix-blend-mode:multiply}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-name{font-family:'Bowlby One SC';font-size:1.4rem;color:var(--navy);letter-spacing:0}
.brand-name em{color:var(--red);font-style:normal}
.brand-sub{font-family:'Teko';font-size:.95rem;font-weight:600;letter-spacing:2.5px;color:var(--blue);text-transform:uppercase}

.nav-links{display:flex;align-items:center;gap:2px;list-style:none}
.nav-links a{
  font-family:'Manrope';font-weight:700;font-size:.82rem;color:var(--navy);
  padding:9px 11px;border-radius:6px;text-transform:uppercase;white-space:nowrap;
  letter-spacing:.5px;transition:background .15s,color .15s;
}
.nav-links a:hover{background:var(--cream-2);text-decoration:none}
.nav-links a.active{background:var(--navy);color:#fff}
.nav-links a.nav-cta{background:var(--red);color:#fff;margin-left:6px;box-shadow:0 3px 0 var(--red-deep)}
.nav-links a.nav-cta:hover{background:var(--red-dark)}
.nav-links a.nav-access{border:2px solid var(--navy);color:var(--navy);margin-left:6px;padding:7px 12px}
.nav-links a.nav-access:hover{background:var(--navy);color:#fff}
.nav-toggle{
  display:none;background:var(--navy);border:none;color:#fff;
  width:48px;height:48px;border-radius:8px;font-size:1.4rem;cursor:pointer;
}

/* Hero */
.hero{
  position:relative;background:var(--navy);color:#fff;overflow:hidden;
  padding:80px 0 90px;
}
.hero::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse at 85% 10%,rgba(232,71,43,.65),transparent 50%),
    radial-gradient(ellipse at 10% 100%,rgba(37,133,197,.55),transparent 55%),
    radial-gradient(circle at 50% 50%,transparent 40%,rgba(0,0,0,.35) 100%);
}
.hero::after{
  content:"";position:absolute;left:-10%;top:0;bottom:0;width:120%;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:80px 80px;
  transform:perspective(800px) rotateX(60deg) translateY(-30%);
  opacity:.5;
}
.hero .container{position:relative;z-index:2;display:grid;grid-template-columns:1.2fr .9fr;gap:60px;align-items:center}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(232,71,43,.20);
  border:1px solid rgba(255,255,255,.18);
  padding:8px 16px;border-radius:999px;
  font-family:'Teko';font-weight:600;letter-spacing:3px;text-transform:uppercase;
  font-size:1rem;color:#fff;margin-bottom:24px;
}
.hero-eyebrow .pulse{width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 0 0 rgba(232,71,43,.7);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(232,71,43,.7)}70%{box-shadow:0 0 0 12px rgba(232,71,43,0)}100%{box-shadow:0 0 0 0 rgba(232,71,43,0)}}
.hero h1{
  font-family:'Bowlby One SC',sans-serif;color:#fff;
  font-size:clamp(2.8rem,7vw,5.6rem);line-height:1.08;
  text-shadow:4px 4px 0 rgba(0,0,0,.25);
}
.hero h1 .red{color:var(--red);display:inline-block;transform:skewX(-4deg)}
.hero h1 .stroke{
  -webkit-text-stroke:3px #fff;color:transparent;display:block;
}
.hero p.hero-lede{
  font-size:1.18rem;color:#d9dcef;max-width:50ch;
  margin:24px 0 30px;line-height:1.6;font-weight:500;
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{
  display:flex;gap:32px;margin-top:42px;padding-top:28px;
  border-top:1px solid rgba(255,255,255,.15);
}
.hero-stat{display:flex;flex-direction:column;gap:2px}
.hero-stat-num{font-family:'Bowlby One SC';font-size:2.4rem;color:var(--red);line-height:1}
.hero-stat-lbl{font-family:'Teko';font-weight:500;letter-spacing:2px;text-transform:uppercase;color:#cdd0e6;font-size:.95rem}

/* Hero visual */
.hero-visual{position:relative;height:520px}
.hero-card{
  position:absolute;background:#fff;border-radius:14px;overflow:hidden;
  box-shadow:0 30px 70px rgba(0,0,0,.45);
}
.hero-card--main{width:78%;height:88%;right:0;top:6%;transform:rotate(2deg);background:var(--cream);overflow:hidden}
.hero-card--main img{width:100%;height:100%;object-fit:cover;display:block}
.hero-card--badge{
  width:55%;height:34%;left:-6%;top:8%;transform:rotate(-6deg);
  background:linear-gradient(135deg,var(--red) 0%,var(--red-dark) 100%);
  color:#fff;padding:20px;display:flex;flex-direction:column;justify-content:space-between;
}
.hero-card--belt{
  width:60%;height:24%;left:-4%;bottom:8%;transform:rotate(4deg);
  background:linear-gradient(135deg,var(--blue) 0%,var(--blue-dark) 100%);
  color:#fff;padding:18px;display:flex;align-items:center;gap:14px;
}
.hero-card--main .ph-photo{
  width:100%;height:100%;background:
    repeating-linear-gradient(45deg,rgba(232,71,43,.15) 0 20px,rgba(232,71,43,.05) 20px 40px),
    var(--cream-3);
  display:flex;align-items:center;justify-content:center;flex-direction:column;color:var(--navy);
}
.hero-card--main .ph-photo strong{font-family:'Bowlby One SC';font-size:1.4rem;color:var(--navy)}

/* Floating elements / pictograms */
.pictogram-grid{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background-image:
    radial-gradient(circle at 20% 30%,rgba(232,71,43,.08) 0,transparent 6%),
    radial-gradient(circle at 80% 70%,rgba(37,133,197,.08) 0,transparent 5%);
}

/* Cards / Grids */
.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-6{grid-template-columns:repeat(6,1fr)}

.card{
  background:var(--paper);border-radius:var(--radius);padding:28px;
  box-shadow:var(--shadow);border:1px solid rgba(20,20,40,.06);
  transition:transform .2s ease,box-shadow .2s ease;
}
.card--hover:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.card h3{color:var(--navy);margin-bottom:8px}
.card p{color:var(--muted);font-size:.97rem;line-height:1.55}

/* Discipline cards (custom) */
.disc-card{
  background:var(--paper);border-radius:var(--radius);
  padding:0;overflow:hidden;position:relative;
  box-shadow:var(--shadow);
  border:1px solid rgba(20,20,40,.05);
  transition:transform .25s ease,box-shadow .25s ease;
  display:flex;flex-direction:column;
}
.disc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.disc-card-head{
  height:120px;display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.disc-card-head::before{
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(135deg,rgba(255,255,255,.06) 0 30px,transparent 30px 60px);
}
.disc-card-head svg{position:relative;z-index:2;width:78px;height:78px;color:#fff}
/* Cabeceras .disc-card: degradado por disciplina generado en cj_disciplinas_css() desde la BD. */
.disc-card-body{padding:22px 24px 26px;flex:1;display:flex;flex-direction:column}
.disc-card-body h3{font-family:'Bowlby One SC';font-size:1.45rem;color:var(--navy);margin-bottom:6px}
.disc-card-body .disc-sub{font-family:'Teko';font-weight:500;text-transform:uppercase;letter-spacing:1.5px;font-size:1rem;color:var(--red);margin-bottom:10px}
.disc-card-body p{color:var(--muted);flex:1}
.disc-card-foot{
  margin-top:14px;padding-top:14px;border-top:1px dashed #ddd3b9;
  display:flex;align-items:center;justify-content:space-between;
  font-family:'Teko';font-weight:600;letter-spacing:1.5px;text-transform:uppercase;
  font-size:.95rem;color:var(--navy);
}
.disc-card-foot .arrow{
  width:34px;height:34px;border-radius:50%;background:var(--navy);color:#fff;
  display:grid;place-items:center;transition:background .2s;
}
.disc-card:hover .disc-card-foot .arrow{background:var(--red)}

/* Tags */
.tag{
  display:inline-block;font-family:'Teko';font-weight:600;font-size:.95rem;
  letter-spacing:1.5px;text-transform:uppercase;
  padding:3px 12px;border-radius:6px;line-height:1.4;
}
/* Los colores por disciplina (.tag--X, .slot--X, .cal-ev--X, .disc-card) se generan
   desde la BD (disciplinas.color) en cj_disciplinas_css() — configurables en Admin → Ajustes. */

/* Page header (interior pages) */
.page-head{
  background:var(--navy);color:#fff;padding:74px 0 84px;position:relative;overflow:hidden;
}
.page-head::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 90% 20%,rgba(232,71,43,.45),transparent 40%),
    radial-gradient(circle at 5% 90%,rgba(37,133,197,.4),transparent 45%);
}
.page-head .container{position:relative;z-index:2}
.page-head h1{font-family:'Bowlby One SC';font-size:clamp(2.4rem,5.6vw,4.2rem);color:#fff;line-height:1.12}
.page-head h1 .red{color:var(--red)}
.page-head p{color:#cdd0e6;max-width:62ch;margin-top:16px;font-size:1.1rem}
.crumbs{font-family:'Teko';font-size:1rem;color:#9aa0c8;margin-bottom:14px;text-transform:uppercase;letter-spacing:2px;font-weight:500}
.crumbs a{color:#9aa0c8}
.crumbs .sep{margin:0 10px;opacity:.6}

/* Schedule */
.schedule-toolbar{
  display:flex;gap:10px;flex-wrap:wrap;margin-bottom:28px;align-items:center;
}
.schedule-filter{
  font-family:'Teko';font-weight:600;letter-spacing:1.5px;text-transform:uppercase;
  font-size:.95rem;padding:8px 16px;border-radius:6px;border:2px solid var(--navy);
  background:transparent;color:var(--navy);cursor:pointer;transition:all .15s;
}
.schedule-filter.active{background:var(--navy);color:#fff}
.day-block{margin-bottom:18px}
.day-head{
  display:flex;align-items:center;gap:14px;margin-bottom:10px;
}
.day-pill{
  display:inline-block;font-family:'Bowlby One SC';background:var(--red);color:#fff;
  padding:6px 20px;border-radius:6px;text-transform:uppercase;letter-spacing:1px;font-size:1.1rem;
  box-shadow:0 3px 0 var(--red-deep);
}
.day-count{font-family:'Teko';font-weight:500;color:var(--muted);letter-spacing:1.5px;font-size:1rem;text-transform:uppercase}
.slot-list{list-style:none;display:grid;gap:8px}
.slot{
  display:grid;grid-template-columns:130px auto 1fr;gap:18px;align-items:center;
  background:#fff;border-left:5px solid var(--blue);
  padding:14px 20px;border-radius:0 12px 12px 0;
  box-shadow:var(--shadow-sm);transition:transform .15s;
}
.slot:hover{transform:translateX(4px)}
.slot .slot-time{font-family:'Teko';font-weight:700;color:var(--navy);font-size:1.25rem;letter-spacing:1px}
.slot .slot-note{color:var(--muted);font-size:.9rem;font-weight:500}
@media(max-width:760px){.slot{grid-template-columns:1fr;gap:6px}.slot .slot-note{order:4}}

/* Switch de vista lista/calendario */
.view-switch{display:inline-flex;margin-left:auto;border:2px solid var(--navy);border-radius:6px;overflow:hidden}
.view-switch button{
  font-family:'Teko';font-weight:600;letter-spacing:1.5px;text-transform:uppercase;
  font-size:.95rem;padding:8px 16px;border:none;background:transparent;color:var(--navy);
  cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:6px;
}
.view-switch button.active{background:var(--navy);color:#fff}
.view-hide{display:none !important}

/* Calendario semanal (7 columnas L-D) */
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;align-items:start}
.cal-day-head{
  font-family:'Bowlby One SC';text-align:center;background:var(--navy);color:#fff;
  border-radius:6px;padding:7px 2px;font-size:.85rem;letter-spacing:1px;text-transform:uppercase;
}
.cal-col{display:flex;flex-direction:column;gap:6px;min-height:40px}
.cal-empty{color:var(--muted);text-align:center;font-size:.8rem;opacity:.6;padding-top:10px}
.cal-ev{border-radius:8px;color:#fff;padding:9px 4px;text-align:center;line-height:1.12;box-shadow:var(--shadow-sm)}
.cal-ev-time{display:block;font-family:'Teko';font-weight:700;font-size:1.05rem;letter-spacing:1px}
.cal-ev-disc{display:block;font-family:'Manrope';font-weight:800;font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;margin-top:2px;opacity:.95}
.cal-day-head .d-short,.cal-ev .n-short,.cal-ev .t-short{display:none}
@media(max-width:760px){
  .cal-grid{gap:3px}
  .cal-day-head{font-size:.75rem;padding:6px 0;border-radius:4px}
  .cal-day-head .d-full{display:none}.cal-day-head .d-short{display:inline}
  .cal-col{gap:4px}
  .cal-ev{padding:6px 1px;border-radius:5px}
  .cal-ev-time{font-size:.74rem;letter-spacing:0}
  .cal-ev-disc{font-size:.5rem;letter-spacing:0;margin-top:1px}
  .cal-ev .n-full{display:none}.cal-ev .n-short{display:inline}
  .cal-ev .t-full{display:none}.cal-ev .t-short{display:inline}
}

/* Events */
.event-card{
  display:grid;grid-template-columns:140px 1fr;gap:24px;align-items:start;
  background:#fff;border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);
  border:1px solid rgba(20,20,40,.05);overflow:hidden;position:relative;
}
.event-date{
  background:var(--red);color:#fff;border-radius:14px;text-align:center;
  padding:14px 8px;font-family:'Bowlby One SC';line-height:1;box-shadow:0 4px 0 var(--red-deep);
}
.event-date .d{font-size:2.6rem;display:block}
.event-date .m{font-family:'Teko';font-size:1.05rem;letter-spacing:2px;font-weight:600}
.event-date .y{font-family:'Teko';font-size:.85rem;color:rgba(255,255,255,.7);display:block;margin-top:4px;letter-spacing:2px}
.event-body h3{font-family:'Bowlby One SC';font-size:1.35rem;color:var(--navy);margin-bottom:6px}
.event-meta{display:flex;gap:18px;flex-wrap:wrap;color:var(--muted);font-size:.92rem;font-weight:600;margin:8px 0 10px}
.event-meta span{display:inline-flex;align-items:center;gap:6px}
.event-past{opacity:.55}
.event-past .event-date{background:var(--muted);box-shadow:0 4px 0 #4a463d}
.event-card.featured{
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-2) 100%);color:#fff;
  border:none;
}
.event-card.featured h3{color:#fff}
.event-card.featured .event-meta{color:#cdd0e6}
.event-card.featured p{color:#d9dcef}

/* Pricing */
.price-card{
  background:#fff;border-radius:var(--radius);padding:36px 30px 32px;text-align:center;
  box-shadow:var(--shadow);border:3px solid transparent;position:relative;
  display:flex;flex-direction:column;
}
.price-card.featured{
  border-color:var(--red);
  background:linear-gradient(180deg,#fff 0%,#FFF7F4 100%);
  transform:scale(1.04);
}
.price-badge{
  position:absolute;top:-15px;left:50%;transform:translateX(-50%);
  background:var(--red);color:#fff;font-family:'Teko';font-weight:600;font-size:.95rem;
  text-transform:uppercase;letter-spacing:2px;padding:5px 18px;border-radius:6px;
  box-shadow:0 3px 0 var(--red-deep);
}
.price-card h3{font-family:'Bowlby One SC';color:var(--navy);font-size:1.6rem;line-height:1}
.price-card .price-sub{font-family:'Teko';font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--red);margin:6px 0 16px;font-size:1rem}
.price-amount{font-family:'Bowlby One SC';font-size:3.6rem;color:var(--navy);line-height:1;margin:14px 0 6px;display:flex;align-items:flex-start;justify-content:center;gap:4px}
.price-amount .currency{font-size:1.4rem;margin-top:8px}
.price-amount .per{font-family:'Teko';font-weight:500;font-size:1rem;color:var(--muted);align-self:flex-end;margin-left:6px;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px}
.price-card .price-mat{font-family:'Teko';color:var(--blue-dark);font-weight:600;letter-spacing:1px;text-transform:uppercase;margin-bottom:18px;font-size:.95rem}
.price-list{list-style:none;text-align:left;margin:18px 0;flex:1}
.price-list li{padding:9px 0;border-bottom:1px dashed #e7ddc4;display:flex;gap:10px;align-items:flex-start;font-size:.95rem}
.price-list li::before{
  content:"";flex:none;width:18px;height:18px;border-radius:50%;
  background:var(--blue);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'><path d='M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.5-1.5z'/></svg>");
  background-size:14px;background-position:center;background-repeat:no-repeat;
  margin-top:2px;
}
.price-list li:last-child{border-bottom:none}

/* Gear table */
.gear-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.gear-table th,.gear-table td{padding:16px 20px;text-align:left;border-bottom:1px solid #eee5cf}
.gear-table thead th{background:var(--navy);color:#fff;font-family:'Bowlby One SC';font-weight:400;letter-spacing:1px;font-size:.95rem}
.gear-table tbody tr:hover{background:var(--cream)}
.gear-table td:last-child,.gear-table th:last-child{text-align:right;font-family:'Teko';font-weight:700;color:var(--red);font-size:1.3rem;letter-spacing:.5px}

/* Contact */
.contact-card{
  display:flex;gap:20px;align-items:flex-start;
  background:#fff;border-radius:var(--radius);padding:26px;box-shadow:var(--shadow);
  transition:transform .15s,box-shadow .15s;text-decoration:none;color:inherit;
}
.contact-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);text-decoration:none}
.contact-card .ic{
  width:60px;height:60px;border-radius:14px;display:grid;place-items:center;
  font-size:1.6rem;flex:none;color:#fff;
}
.contact-card .ic svg{width:30px;height:30px}
.ic--wa{background:#25D366}
.ic--ig{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888)}
.ic--mail{background:var(--blue)}
.ic--phone{background:var(--navy)}
.ic--loc{background:var(--red)}
.contact-card h3{font-family:'Bowlby One SC';font-size:1.2rem;color:var(--navy);margin-bottom:4px}
.contact-card .contact-sub{font-family:'Teko';font-weight:500;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;font-size:.9rem}
.contact-card a{font-weight:700}

/* Footer */
.site-footer{background:var(--navy);color:#cdd0e6;padding:60px 0 24px;position:relative}
.site-footer::before{
  content:"";position:absolute;top:0;left:0;right:0;height:14px;
  background:
    repeating-linear-gradient(90deg,
      var(--red) 0 50px,
      var(--red) 50px,
      var(--navy) 50px 56px,
      var(--blue) 56px 106px,
      var(--navy) 106px 112px);
}
.site-footer a{color:#cdd0e6}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:34px;padding-top:14px}
.site-footer h4{font-family:'Bowlby One SC';color:#fff;font-size:1rem;letter-spacing:1px;margin-bottom:18px;text-transform:uppercase}
.site-footer ul{list-style:none}
.site-footer li{margin-bottom:10px;font-size:.92rem}
.footer-brand img{height:120px;margin-bottom:14px;background:#fff;padding:8px 14px;border-radius:14px;display:inline-block}
.footer-brand p{font-size:.92rem;color:#9aa0c8;line-height:1.6;max-width:32ch}
.social-row{display:flex;gap:10px;margin-top:14px}
.social-row a{
  width:42px;height:42px;border-radius:10px;background:rgba(255,255,255,.08);
  display:grid;place-items:center;transition:transform .15s,filter .15s;color:#fff;font-size:1.15rem;
}
.social-row a svg{width:20px;height:20px}
.social-row a:hover{transform:translateY(-2px);text-decoration:none;filter:brightness(1.1)}
.social-row a.s-wa{background:#25D366}
.social-row a.s-ig{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888)}
.social-row a.s-tel{background:var(--blue)}
.social-row a.s-mail{background:var(--navy-2)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.12);margin-top:42px;padding-top:20px;
  /* padding-right: que el FAB de WhatsApp (fixed, abajo-dcha) no tape el texto */
  padding-right:96px;
  font-size:.85rem;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;color:#7a83b3;
}

/* Notice / banners */
.notice{
  background:#fff7e6;border:1px solid #f1d99b;color:#8a6d1f;
  padding:14px 18px;border-radius:12px;font-size:.95rem;font-weight:600;
}
.center{text-align:center}
.mt-s{margin-top:14px}.mt-m{margin-top:26px}.mt-l{margin-top:40px}.mt-xl{margin-top:60px}
.stack>*+*{margin-top:14px}

/* Floating WhatsApp */
.fab-wa{
  position:fixed;bottom:24px;right:24px;z-index:60;
  width:64px;height:64px;border-radius:50%;background:#25D366;
  display:grid;place-items:center;color:#fff;
  box-shadow:0 8px 24px rgba(37,211,102,.45);
  transition:transform .15s,box-shadow .2s;
}
.fab-wa::before{
  content:"";position:absolute;inset:-4px;border-radius:50%;
  border:2px solid rgba(37,211,102,.5);
  animation:fab-pulse 2.2s infinite;
}
@keyframes fab-pulse{0%{transform:scale(1);opacity:1}100%{transform:scale(1.5);opacity:0}}
.fab-wa:hover{transform:scale(1.08);text-decoration:none}
.fab-wa svg{width:32px;height:32px;position:relative;z-index:2}

/* Toast */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(120px);
  background:var(--navy);color:#fff;padding:14px 26px;border-radius:999px;
  font-weight:700;box-shadow:var(--shadow);transition:transform .3s ease;z-index:99;
}
.toast.show{transform:translateX(-50%) translateY(0)}

/* Responsive */
@media (max-width:1024px){
  .hero .container{grid-template-columns:1fr;gap:40px}
  .hero-visual{height:380px;width:100%;max-width:520px;justify-self:center}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
}
@media (max-width:960px){
  .nav-toggle{display:block}
  .nav-links{
    display:none;position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;background:var(--cream);
    padding:14px 22px 22px;border-bottom:3px solid var(--navy);gap:4px;
  }
  .nav-links.open{display:flex}
  .nav-links li{width:100%}
  .nav-links a{display:block;width:100%;padding:13px 14px;border-radius:8px;font-size:.9rem}
  .nav-links a.nav-cta,.nav-links a.nav-access{margin-left:0;box-shadow:none;text-align:left}
}
@media (max-width:760px){
  .brand-text{display:none}
  .section{padding:60px 0}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .grid-4,.grid-6{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
  .event-card{grid-template-columns:100px 1fr;gap:16px;padding:18px}
  .event-date .d{font-size:2rem}
  .price-card.featured{transform:none}
  .hero-stats{flex-wrap:wrap;gap:20px}
  .hero{padding:50px 0 70px}
  .fab-wa{width:56px;height:56px;bottom:18px;right:18px}
  .fab-wa svg{width:28px;height:28px}
}

/* ==========================================================
   SEO / contenido local
   ========================================================== */

/* Texto solo para lectores de pantalla (y rastreadores) */
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* Bloque de texto SEO local */
.seo-local p{max-width:860px;color:var(--ink);margin-bottom:14px;line-height:1.7}
.seo-local p a{font-weight:700}

/* FAQ con <details> */
.faq-list{max-width:860px;margin-top:26px}
.faq-list details{
  background:var(--paper);border-radius:var(--radius-sm);
  box-shadow:var(--shadow-sm);margin-bottom:12px;overflow:hidden;
}
.faq-list summary{
  cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px;
  padding:16px 20px;font-family:'Manrope';font-weight:800;font-size:1.02rem;color:var(--navy);
}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:"+";font-family:'Bowlby One SC';color:var(--red);font-size:1.2rem;line-height:1}
.faq-list details[open] summary::after{content:"–"}
.faq-list .faq-a{padding:0 20px 18px;color:var(--ink);line-height:1.65}

/* Landing de disciplina */
.lp-intro p{max-width:820px;margin-bottom:14px;line-height:1.7}
.lp-cols{display:grid;grid-template-columns:1.5fr 1fr;gap:40px;align-items:start}
.lp-aside .card{position:sticky;top:90px}
.lp-check{list-style:none;margin:14px 0 0}
.lp-check li{padding:7px 0 7px 30px;position:relative}
.lp-check li::before{content:"✔";position:absolute;left:0;color:var(--red);font-weight:800}
.lp-precios{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.lp-precio{
  background:var(--paper);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);
  padding:12px 18px;font-weight:700;color:var(--navy);
}
.lp-precio strong{font-family:'Bowlby One SC';color:var(--red);font-size:1.15rem;font-weight:400}
.lp-otras{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.lp-otras a{
  background:var(--paper);border:2px solid var(--cream-3);border-radius:999px;
  padding:8px 18px;font-weight:700;color:var(--navy);font-size:.92rem;
}
.lp-otras a:hover{border-color:var(--red);color:var(--red);text-decoration:none}
@media (max-width:900px){.lp-cols{grid-template-columns:1fr}.lp-aside .card{position:static}}
