:root{
  --navy:#06145f;
  --navy-2:#071d75;
  --blue:#005bb5;
  --blue-2:#0b72d0;
  --gray:#e9e9eb;
  --gray-soft:#f7f8fc;
  --white:#ffffff;
  --ink:#111827;
  --muted:#647082;
  --line:rgba(6,20,95,.13);
  --shadow:0 24px 70px rgba(6,20,95,.18);
  --shadow-soft:0 16px 42px rgba(6,20,95,.10);
  --radius-xl:34px;
  --radius-lg:24px;
  --radius-md:16px;
  --max:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--gray-soft);
  color:var(--ink);
  font-family:Arial, Helvetica, sans-serif;
  line-height:1.6;
  overflow-x:hidden;
}
body.nav-open{overflow:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.skip-link{
  position:absolute;
  left:18px;
  top:-50px;
  z-index:999;
  background:var(--navy);
  color:var(--white);
  padding:10px 14px;
  border-radius:999px;
}
.skip-link:focus{top:16px}

.container{width:min(100% - 36px,var(--max));margin-inline:auto}
.section-padding{padding:clamp(64px,8vw,110px) 0}

.site-header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(6,20,95,.08);
}
.navbar{
  width:min(100% - 36px,var(--max));
  min-height:82px;
  margin-inline:auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.brand{display:flex;align-items:center;gap:14px;min-width:0}
.brand-symbol,.hero-logo{
  position:relative;
  flex:0 0 auto;
  width:88px;
  height:56px;
}
.brand-symbol{width:72px;height:46px}
.head{
  position:absolute;
  bottom:2px;
  width:38px;
  height:42px;
  border-radius:52% 48% 46% 54%;
  border:2px solid rgba(6,20,95,.16);
}
.head-light{left:0;background:#fff;box-shadow:0 8px 20px rgba(6,20,95,.10)}
.head-blue{right:0;background:var(--navy);border-color:var(--navy)}
.psi{
  position:absolute;
  left:50%;
  top:52%;
  transform:translate(-50%,-50%);
  color:#8b8f99;
  font-family:Georgia,'Times New Roman',serif;
  font-size:33px;
  font-weight:700;
  text-shadow:0 1px 0 #fff;
}
.hero-logo .head{width:48px;height:52px}.hero-logo .psi{font-size:43px}
.brand-copy strong{
  display:block;
  color:var(--blue);
  font-family:Georgia,'Times New Roman',serif;
  font-size:clamp(1.05rem,2vw,1.28rem);
  line-height:1;
  letter-spacing:-.03em;
}
.brand-copy small{
  display:block;
  margin-top:6px;
  color:var(--navy);
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  white-space:nowrap;
}
.nav-menu{display:flex;align-items:center;gap:8px}
.nav-menu a{
  color:var(--navy);
  font-weight:800;
  border-radius:999px;
  padding:10px 14px;
  transition:background .2s ease,color .2s ease,transform .2s ease;
}
.nav-menu a:hover,.nav-menu a:focus-visible{background:var(--navy);color:#fff;transform:translateY(-1px)}
.nav-toggle{
  display:none;
  width:48px;
  height:48px;
  border:0;
  border-radius:14px;
  background:var(--navy);
  padding:11px;
  cursor:pointer;
}
.nav-toggle span{display:block;height:2px;margin:6px 0;border-radius:999px;background:#fff}

.hero{
  min-height:calc(100svh - 82px);
  display:grid;
  grid-template-columns:1fr 1fr;
  position:relative;
  isolation:isolate;
  overflow:hidden;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-2;
  background:linear-gradient(90deg,var(--gray) 0 50%,var(--navy) 50% 100%);
}
.hero::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  background:
    radial-gradient(circle at 52% 42%,rgba(255,255,255,.14),transparent 17%),
    radial-gradient(circle at 88% 14%,rgba(255,255,255,.13),transparent 20%),
    radial-gradient(circle at 18% 83%,rgba(0,91,181,.12),transparent 22%);
}
.hero-left,.hero-right{align-self:center;padding:clamp(46px,7vw,96px)}
.hero-left{justify-self:end;width:min(100%,650px)}
.hero-right{display:grid;place-items:center;min-height:520px;color:#fff}
.kicker,.section-label{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:var(--blue);
  font-weight:900;
  letter-spacing:.02em;
  font-size:clamp(1rem,2vw,1.38rem);
}
.section-label::before{
  content:"";
  width:36px;
  height:3px;
  border-radius:999px;
  background:currentColor;
}
.section-label.light{color:#fff}
.hero h1{
  margin:14px 0 8px;
  color:var(--blue);
  font-family:Georgia,'Times New Roman',serif;
  font-size:clamp(3.2rem,7.3vw,7rem);
  line-height:.9;
  letter-spacing:-.065em;
}
.hero h1 span{color:var(--blue)}
.subtitle{
  margin:0 0 32px;
  color:var(--navy);
  font-weight:800;
  letter-spacing:.09em;
  text-transform:uppercase;
  font-size:clamp(.95rem,1.6vw,1.32rem);
}
.experience-badge{
  width:min(100%,410px);
  padding:22px 40px 22px 28px;
  margin:0 0 32px;
  background:var(--navy);
  color:#fff;
  clip-path:polygon(0 0,84% 0,100% 50%,84% 100%,0 100%);
  box-shadow:var(--shadow-soft);
}
.experience-badge strong,.experience-badge span{display:block;font-size:clamp(1.35rem,3vw,2.05rem);line-height:1.14}
.experience-badge strong{font-weight:900}.experience-badge span{font-weight:700}
.hero-buttons{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;width:min(100%,440px)}
.btn{
  display:inline-flex;
  justify-content:center;
  align-items:center;
  min-height:54px;
  padding:13px 20px;
  border-radius:999px;
  font-weight:900;
  box-shadow:var(--shadow-soft);
  transition:transform .2s ease,box-shadow .2s ease,background .2s ease,color .2s ease;
}
.btn:hover,.btn:focus-visible{transform:translateY(-2px);box-shadow:0 20px 50px rgba(6,20,95,.18)}
.btn-primary{background:var(--navy);color:#fff}.btn-secondary{background:#fff;color:var(--navy);border:1px solid var(--line)}
.appointment-card{
  width:min(100%,440px);
  padding:42px 34px;
  text-align:center;
  border:1px solid rgba(255,255,255,.18);
  border-radius:var(--radius-xl);
  background:linear-gradient(145deg,rgba(255,255,255,.12),rgba(255,255,255,.04));
  box-shadow:0 30px 90px rgba(0,0,0,.20);
}
.appointment-card p{margin:18px 0 2px;font-size:clamp(1.35rem,3vw,2.15rem);font-weight:800}
.appointment-card a{font-size:clamp(1.35rem,3vw,2.15rem);font-weight:900;letter-spacing:.02em}
.calendar{
  position:relative;
  width:132px;
  height:110px;
  margin:0 auto 26px;
  border:5px solid rgba(255,255,255,.9);
  border-top-width:12px;
  border-radius:8px;
}
.calendar .rings::before,.calendar .rings::after{
  content:"";
  position:absolute;
  top:-26px;
  width:14px;
  height:28px;
  border:5px solid rgba(255,255,255,.9);
  border-bottom:0;
  border-radius:6px 6px 0 0;
}
.calendar .rings::before{left:18px}.calendar .rings::after{right:18px}
.calendar .rows,.calendar .rows::before,.calendar .rows::after{
  position:absolute;
  left:23px;
  right:23px;
  height:5px;
  border-radius:999px;
  background:rgba(255,255,255,.9);
}
.calendar .rows{top:34px}.calendar .rows::before{content:"";top:20px;left:0;right:0}.calendar .rows::after{content:"";top:40px;left:0;right:0}
.calendar .check{
  position:absolute;
  right:-30px;
  bottom:-26px;
  width:66px;
  height:66px;
  border:5px solid rgba(255,255,255,.95);
  border-radius:50%;
  background:var(--navy-2);
}
.calendar .check::after{
  content:"";
  position:absolute;
  left:19px;
  top:15px;
  width:17px;
  height:28px;
  border:solid #fff;
  border-width:0 5px 5px 0;
  transform:rotate(45deg);
}

.intro{background:#fff}.intro-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:24px;align-items:stretch}
.intro-card,.intro-highlight,.formation-card,.gallery-frame,.contact-panel{
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-soft);
}
.intro-card{padding:34px;background:linear-gradient(145deg,#fff,#f3f6fb)}
.intro-card h2,.section-heading h2,.modalities-copy h2,.gallery-copy h2,.contact-copy h2,.blue-band h2{
  margin:10px 0 10px;
  font-family:Georgia,'Times New Roman',serif;
  line-height:1.05;
  letter-spacing:-.04em;
  font-size:clamp(2.2rem,5vw,4.5rem);
}
.intro-card p,.section-heading p,.modalities-copy p,.gallery-copy p{margin:0;color:var(--muted);font-size:1.08rem}
.intro-highlight{
  padding:34px;
  background:var(--navy);
  color:#fff;
  display:grid;
  place-content:center;
  text-align:center;
}
.intro-highlight strong{font-size:clamp(1.7rem,4vw,3rem);font-family:Georgia,'Times New Roman',serif;line-height:1}
.intro-highlight span{margin-top:12px;font-weight:700}

.section-heading{max-width:820px;margin:0 0 34px}.section-heading h2{color:var(--navy)}
.formation{background:var(--gray-soft)}
.formation-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.formation-card{
  min-height:220px;
  padding:24px;
  background:#fff;
  position:relative;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
.formation-card::after{
  content:"";
  position:absolute;
  right:-36px;
  top:-36px;
  width:110px;
  height:110px;
  border-radius:50%;
  background:rgba(0,91,181,.08);
}
.formation-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:rgba(0,91,181,.30)}
.formation-card span{color:var(--blue);font-weight:900;font-size:.92rem;letter-spacing:.12em}
.formation-card h3{margin:24px 0 0;color:var(--navy);font-size:clamp(1.08rem,1.6vw,1.36rem);line-height:1.22}
.formation-card p{margin:12px 0 0;color:var(--muted);font-size:1.02rem}

.blue-band{padding:clamp(54px,7vw,86px) 0;background:var(--navy);color:#fff;position:relative;overflow:hidden}
.blue-band::before{content:"";position:absolute;inset:auto -10% -90% 50%;height:180%;border-radius:50%;background:rgba(255,255,255,.08)}
.blue-band-grid{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;position:relative}.blue-band h2{margin-bottom:0;color:#fff}.blue-pill{padding:18px 24px;border:1px solid rgba(255,255,255,.24);border-radius:999px;background:rgba(255,255,255,.10);font-weight:900;white-space:nowrap}

.modalities{background:#fff}.modalities-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:34px;align-items:center}.modalities-copy h2{color:var(--navy)}.modality-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}.modality-cards article{min-height:210px;border-radius:var(--radius-xl);padding:28px;background:linear-gradient(145deg,var(--navy),var(--navy-2));color:#fff;box-shadow:var(--shadow);display:flex;flex-direction:column;justify-content:space-between}.modality-cards span{font-weight:900;color:rgba(255,255,255,.66);letter-spacing:.14em}.modality-cards strong{font-family:Georgia,'Times New Roman',serif;font-size:clamp(2.1rem,5vw,4rem);line-height:1}

.topics{background:linear-gradient(180deg,var(--gray-soft),#fff)}.topic-list{display:flex;flex-wrap:wrap;gap:12px}.topic-list span{padding:13px 18px;border-radius:999px;background:#fff;border:1px solid var(--line);color:var(--navy);font-weight:900;box-shadow:0 10px 24px rgba(6,20,95,.07)}

.gallery{background:#fff}.gallery-grid{display:grid;grid-template-columns:.75fr 1.25fr;gap:34px;align-items:center}.gallery-copy h2{color:var(--navy)}.gallery-frame{margin:0;padding:14px;background:linear-gradient(145deg,#fff,#eef3fb);border-radius:var(--radius-xl)}.gallery-frame img{width:100%;height:auto;border-radius:24px;object-fit:contain;background:#fff}

.contact{padding:clamp(64px,8vw,110px) 0;background:linear-gradient(135deg,var(--navy),#04104d);color:#fff;position:relative;overflow:hidden}.contact::after{content:"";position:absolute;right:-140px;top:-140px;width:360px;height:360px;border-radius:50%;background:rgba(255,255,255,.08)}.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:34px;align-items:start;position:relative;z-index:1}.contact-copy h2{color:#fff}.contact-copy p{margin:8px 0;font-weight:700}.contact-panel{padding:14px;background:#fff;color:var(--ink);border-color:rgba(255,255,255,.20)}.contact-item{display:flex;justify-content:space-between;gap:18px;align-items:center;padding:18px;border-radius:18px;border:1px solid rgba(6,20,95,.10);margin-bottom:10px;transition:background .2s ease,transform .2s ease}.contact-item:last-child{margin-bottom:0}.contact-item:not(.static):hover{background:#f3f7ff;transform:translateY(-2px)}.contact-item span{color:var(--muted);font-weight:800}.contact-item strong{color:var(--navy);text-align:right;overflow-wrap:anywhere}

.footer{background:#045fb4;color:#fff;padding:24px 0}.footer-grid{display:flex;justify-content:space-between;gap:20px;align-items:center}.footer p{margin:4px 0}.footer a,.footer strong{font-weight:900}
.whatsapp-float{position:fixed;right:20px;bottom:20px;z-index:90;width:62px;height:62px;border-radius:50%;background:#25d366;display:grid;place-items:center;box-shadow:0 18px 42px rgba(0,0,0,.22);transition:transform .2s ease}.whatsapp-float:hover{transform:translateY(-3px) scale(1.03)}.whatsapp-float svg{width:34px;height:34px;fill:#fff}

/* La página queda visible aunque JavaScript no cargue en Cloudflare. */
.reveal{opacity:1;transform:none}.js .reveal{opacity:0;transform:translateY(24px);transition:opacity .72s ease,transform .72s ease}.js .reveal.visible{opacity:1;transform:none}

@media (max-width:1040px){.formation-grid{grid-template-columns:repeat(2,1fr)}.hero-left,.hero-right{padding:48px}.hero h1{font-size:clamp(3.2rem,9vw,5.6rem)}}
@media (max-width:820px){
  .navbar{min-height:76px}.nav-toggle{display:block}.nav-menu{position:fixed;left:18px;right:18px;top:88px;display:grid;gap:8px;padding:14px;border-radius:22px;background:#fff;box-shadow:var(--shadow);opacity:0;transform:translateY(-12px);pointer-events:none;transition:opacity .22s ease,transform .22s ease}.nav-menu.open{opacity:1;transform:none;pointer-events:auto}.nav-menu a{padding:14px 16px}
  .hero{grid-template-columns:1fr;min-height:auto}.hero::before{background:linear-gradient(180deg,var(--gray) 0 56%,var(--navy) 56% 100%)}.hero-left{justify-self:stretch}.hero-right{min-height:auto;padding-top:20px}.experience-badge{clip-path:none;border-radius:22px;padding:22px}.hero-buttons{grid-template-columns:1fr}.btn{width:100%}
  .intro-grid,.modalities-grid,.gallery-grid,.contact-grid,.blue-band-grid{grid-template-columns:1fr}.formation-grid{grid-template-columns:1fr}.modality-cards{grid-template-columns:1fr}.blue-pill{width:max-content;max-width:100%;white-space:normal}.footer-grid{display:grid}.contact-item{display:grid}.contact-item strong{text-align:left}.brand-symbol{width:60px}.brand-copy small{font-size:.64rem;white-space:normal}.gallery-frame{padding:10px}.gallery-frame img{border-radius:18px}
}
@media (max-width:480px){.container,.navbar{width:min(100% - 28px,var(--max))}.hero-left,.hero-right{padding-left:18px;padding-right:18px}.hero-logo{width:78px}.hero h1{font-size:clamp(2.85rem,14vw,4.2rem)}.appointment-card{padding:34px 18px}.calendar{width:112px;height:94px}.calendar .check{width:58px;height:58px}.whatsapp-float{width:56px;height:56px}.topic-list span{width:100%;text-align:center}}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.js .reveal{opacity:1;transform:none}}
