:root{
  --blue:#1550b7;--deep:#102a61;--petrol:#174a72;--text:#22304a;--muted:#66738d;--line:#dce7f4;--soft:#f6f9fd;--sky:#edf6fb;--mint:#edf8f5;--lav:#f2efff;--beige:#fbf2e9;--coral:#fff0ed;--white:#fff;--shadow:0 20px 55px rgba(16,42,97,.09);
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;color:var(--text);background:#fffdf9;font-size:15px}a{text-decoration:none;color:inherit}img{max-width:100%;display:block}.container{width:min(100% - 42px,1200px);margin-inline:auto}.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);backdrop-filter:blur(14px);border-bottom:1px solid rgba(220,231,244,.7)}.nav-wrap{height:82px;display:flex;align-items:start;gap:24px}.brand img{width:138px;height:66px;object-fit:contain}.main-nav{display:flex;align-items:center;gap:22px;margin-left:auto}.main-nav a{font-size:13px;font-weight:750;color:#3d4963}.main-nav a.active,.main-nav a:hover{color:var(--blue)}.nav-actions{display:flex;gap:12px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;border-radius:9px;padding:12px 18px;font-weight:800;font-size:14px;border:1px solid transparent;transition:.2s ease;white-space:nowrap}.btn-primary{background:var(--blue);color:#fff;box-shadow:0 10px 26px rgba(21,80,183,.22)}.btn-primary:hover{transform:translateY(-1px);background:#0f439f}.btn-ghost{background:#fff;color:var(--blue);border-color:#b9cbea}.btn-soft{background:#fff;color:var(--blue);border-color:#cbdaf0;padding:10px 14px}.btn-white{background:#fff;color:var(--blue)}.btn-blue-outline{border-color:rgba(255,255,255,.7);color:#fff;background:rgba(255,255,255,.06)}.btn-blue-outline .btn-icon{width:20px;height:20px}.btn-large{padding:15px 20px;font-size:15px}.menu-btn{display:none;margin-left:auto;border:0;background:transparent;width:42px;height:42px}.menu-btn span{display:block;width:25px;height:2px;background:var(--deep);margin:5px auto;border-radius:9px}
.hero{position:relative;background:#fff;overflow:hidden;border-bottom:1px solid rgba(220,231,244,.65)}.hero:before{display:none}.hero>.container{width:100%;max-width:none}.hero-inner{position:relative;min-height:610px;display:block;align-items:stretch;padding:56px max(28px,calc((100vw - 1480px)/2 + 56px)) 42px}.hero-copy{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:center;max-width:600px;padding:0}.hero h1{font-size:clamp(52px,5.2vw,72px);line-height:.98;letter-spacing:-.065em;color:var(--deep);margin:0 0 21px;max-width:660px}.hero p{font-size:18px;line-height:1.55;color:#334366;margin:0 0 25px;max-width:575px}.hero-actions{display:flex;gap:20px;flex-wrap:wrap;margin-bottom:30px}.ico{font-size:15px}.btn-icon{width:22px;height:22px;object-fit:contain;display:block;flex:0 0 auto}.btn-icon-light{filter:brightness(0) invert(1)}.hero-trust{display:grid;grid-template-columns:repeat(3,max-content);gap:34px}.hero-trust div{display:flex;align-items:center;gap:10px;color:#314467;font-size:13px;line-height:1.2}.trust-icon{width:40px;height:40px;object-fit:contain;display:block;flex:0 0 auto}.hero-trust span{font-size:30px;color:var(--blue)}.hero-photo{position:absolute;inset:0;width:100%;height:100%;overflow:hidden;z-index:0}.hero-photo img{width:100%;height:100%;object-fit:contain;object-position:center center;opacity:1;filter:none}.section{padding:34px 0}.strip{padding:18px 0 24px}.card{background:rgba(255,255,255,.9);border:1px solid var(--line);border-radius:18px;box-shadow:0 16px 38px rgba(16,42,97,.045)}h2{font-size:28px;line-height:1.1;color:var(--blue);margin:0 0 10px;letter-spacing:-.035em}h3{font-size:16px;color:var(--deep);margin:0 0 8px}p{color:var(--muted);line-height:1.55}.center{text-align:center}.about-panel{display:grid;grid-template-columns:220px 1fr 1.22fr;align-items:center;gap:28px;padding:38px 58px;min-height:280px}.about-banner{position:relative;overflow:hidden;background-image:url('assets/about-banner-bg.png');background-size:cover;background-position:center;border:0;box-shadow:0 22px 48px rgba(16,42,97,.065)}.about-visual-space{min-height:1px}.about-banner .about-text{position:relative;z-index:1}.about-banner .value-row{position:relative;z-index:1}.round-mark,.doc{display:grid;place-items:center;border-radius:18px;color:var(--blue);font-weight:900}.round-mark{width:70px;height:70px;background:#f4f9fe;border:1px solid var(--line);font-size:34px}.about-text p{font-size:14px;margin:0 0 12px}.inline-link,.section-head a{color:var(--blue);font-weight:800;font-size:13px}.about-banner .inline-link{display:inline-flex;align-items:center;justify-content:center;gap:18px;margin-top:8px;padding:12px 22px;border:1.5px solid rgba(22,87,194,.55);border-radius:10px;background:rgba(255,255,255,.55);backdrop-filter:blur(3px);font-size:15px}.value-row{display:grid;grid-template-columns:repeat(4,1fr);height:100%}.value-row div{border-left:1px solid rgba(22,87,194,.18);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:12px;min-height:130px}.value-row i{font-style:normal;color:var(--blue);font-size:30px}.value-icon{width:44px;height:44px;object-fit:contain;display:block}.value-row span{font-size:12px;font-weight:800;color:#405171}.section-title.left{margin-bottom:16px}.section-title p{margin:0;font-size:13px}.treatment-layout{display:grid;grid-template-columns:.95fr 1.25fr;gap:24px;align-items:center}.treatment-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.mini-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px 16px;min-height:192px}.mini-icon-wrap{width:76px;height:76px;border-radius:20px;display:grid;place-items:center;margin:0 auto 14px}.mini-icon{width:52px;height:52px;object-fit:contain;display:block}.mini-card span:not(.mini-icon-wrap){font-size:28px;color:var(--blue);display:block;margin-bottom:8px;text-align:center}.mini-card h3{text-align:center;font-size:13px}.mini-card p{font-size:11px;line-height:1.42;text-align:center;margin:0}.treatment-img img{border-radius:18px;object-fit:cover;width:100%;height:315px}.help{padding-top:10px}.help-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.help-card{border:1px solid var(--line);border-radius:18px;padding:26px;display:flex;gap:20px;align-items:flex-start}.help-icon-wrap{width:76px;height:76px;border-radius:18px;background:rgba(255,255,255,.62);display:grid;place-items:center;flex:0 0 auto}.help-icon{width:52px;height:52px;object-fit:contain;display:block}.help-card p{font-size:13px;margin:0 0 14px}.help-card a{font-size:13px;font-weight:800;color:var(--blue)}.lavender{background:var(--lav)}.sky{background:var(--sky)}.mint{background:var(--mint)}.beige{background:var(--beige)}.coral{background:var(--coral)}.staff-panel{display:grid;grid-template-columns:.95fr 1.05fr;gap:20px;padding:24px}.staff-info p{font-size:13px;margin:0 0 18px}.profiles{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.profile-card{display:flex;gap:10px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px}.avatar{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,#edf6fb,#f2efff);color:var(--blue);font-size:12px;font-weight:900;flex:0 0 auto}.profile-card h3{font-size:12px;margin-bottom:2px}.profile-card p{font-size:10px;line-height:1.25;margin:0 0 5px}.profile-card a{font-size:10px;color:var(--blue);font-weight:850}.staff-image img{height:390px;width:100%;object-fit:cover;border-radius:14px}.process{padding:12px 0 32px}.process-card{padding:24px 22px}.process-card h2{text-align:center}.timeline{position:relative;display:grid;grid-template-columns:repeat(7,1fr);gap:14px;text-align:center}.timeline:before{content:"";position:absolute;left:7%;right:7%;top:41px;border-top:3px solid #bed1ee;z-index:0}.timeline div{position:relative;z-index:1}.timeline span{width:82px;height:82px;border-radius:50%;margin:0 auto 10px;background:#fff;border:2px solid #cbdcf1;display:grid;place-items:center;color:var(--blue);font-size:24px}.timeline strong{display:block;color:var(--deep);font-size:18px}.timeline p{font-size:11px;line-height:1.25;font-weight:800;color:#405171;margin:4px 0 0}.timeline-icon{width:44px;height:44px;object-fit:contain;display:block}.section-head{display:flex;justify-content:space-between;margin-bottom:18px}.section-head h2{display:inline-block;margin-right:18px}.grid{display:grid;gap:20px}.grid.three{grid-template-columns:repeat(3,1fr)}.grid.four{grid-template-columns:repeat(4,1fr)}.resource-card,.course-card{padding:24px}.doc{width:82px;height:82px;font-size:30px;margin-bottom:20px;border-radius:18px}.doc-icon{width:56px;height:56px;object-fit:contain;display:block}.course-card .doc-icon{width:58px;height:58px}.resource-card h3,.course-card h3{font-size:16px}.resource-card p,.course-card li{font-size:13px}.resource-card small{display:block;color:#7d8ba3;font-weight:700;margin:12px 0 16px}.course-card ul{padding-left:18px;margin:10px 0 18px;color:var(--muted)}.media-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.media-card{display:grid;grid-template-columns:.85fr 1.15fr;overflow:hidden;min-height:240px}.media-card img{width:100%;height:100%;object-fit:cover}.media-copy{padding:26px;display:flex;flex-direction:column;justify-content:center}.media-copy p{font-size:13px}.button-row{display:flex;gap:10px;flex-wrap:wrap}.testimonial-panel{padding:26px}.testimonial-panel h2{text-align:center}.testimonial-grid blockquote{margin:0;border:1px solid var(--line);border-radius:14px;padding:26px;background:#fff;color:#314467;font-size:18px;font-weight:750;font-style:italic;line-height:1.45}.testimonial-grid cite{display:block;margin-top:10px;color:var(--muted);font-size:13px;font-style:normal}.note{text-align:center;font-size:12px;margin:16px 0 0}.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.myth-box,.faq-box{padding:24px}.myth-list{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}.myth-list div{text-align:center}.myth-list span{width:86px;height:86px;border-radius:50%;background:#edf6fb;color:var(--blue);display:grid;place-items:center;margin:0 auto 14px;font-size:26px}.myth-icon{width:52px;height:52px;object-fit:contain;display:block}.myth-list p{font-size:11px;line-height:1.25;font-weight:750;margin:0}.faq-title{display:flex;align-items:center;justify-content:space-between}.faq-title a{color:var(--blue);font-weight:800;font-size:12px}.faq-list{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff}.faq-list button{width:100%;padding:12px 14px;display:flex;justify-content:space-between;align-items:center;border:0;border-bottom:1px solid var(--line);background:#fff;color:var(--deep);font-weight:800;text-align:left;cursor:pointer}.faq-list p{font-size:12px;margin:0;padding:12px 14px;background:#fff}.final-cta{padding:12px 0 24px}.cta-card{display:grid;grid-template-columns:.9fr 1.05fr auto;gap:28px;align-items:center;padding:34px;border-radius:24px;background:linear-gradient(135deg,#0f3c88,#1550b7 62%,#0b2b68);color:#fff;position:relative;overflow:hidden}.cta-card:after{content:"";position:absolute;right:-90px;bottom:-120px;width:360px;height:260px;border-radius:50%;background:rgba(255,255,255,.13)}.cta-card>*{position:relative;z-index:1}.cta-card h2{font-size:29px;color:#fff;margin:0}.cta-card p{color:#edf5ff;margin:0}.cta-actions{display:flex;gap:12px}.contact-row{grid-column:1/-1;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}.contact-row a{min-width:245px;text-align:center;background:#fff;color:var(--blue);border-radius:999px;padding:12px 20px;font-weight:850;display:inline-flex;align-items:center;justify-content:center;gap:10px}.social-pill-icon{width:22px;height:22px;object-fit:contain;display:block;flex:0 0 auto}.site-footer{padding:28px 0 15px;border-top:1px solid var(--line);background:#fff}.footer-inner{display:flex;align-items:center;gap:24px}.footer-inner img{width:120px;height:58px;object-fit:contain}.footer-inner nav{display:flex;flex-wrap:wrap;gap:20px;margin:auto;color:#65728a;font-size:12px;font-weight:750}.socials{display:flex;gap:12px;font-size:26px;color:var(--blue)}.site-footer>p{text-align:center;color:#7c879d;font-size:12px;margin:15px 0 0}
@media(max-width:1100px){.main-nav,.nav-actions{display:none}.menu-btn{display:block}.main-nav.open{display:flex;position:absolute;top:82px;left:20px;right:20px;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:18px;padding:16px;box-shadow:var(--shadow)}.hero>.container{width:100%;max-width:none}.hero-inner{display:grid;grid-template-columns:1fr;min-height:unset;padding:32px}.hero-copy{max-width:none;padding:0}.hero-photo{position:relative;inset:auto;width:100%;height:390px;border-radius:22px;margin-top:14px}.hero-photo img{object-position:center top}.about-panel,.staff-panel,.split-grid,.media-grid,.treatment-layout{grid-template-columns:1fr}.about-panel{padding:34px;min-height:auto}.about-visual-space{display:none}.value-row{border-top:1px solid var(--line)}.profiles{grid-template-columns:repeat(2,1fr)}.timeline{grid-template-columns:repeat(2,1fr)}.timeline:before{display:none}.grid.four{grid-template-columns:repeat(2,1fr)}}
@media(max-width:720px){.container{width:min(100% - 28px,1200px)}.about-panel{padding:28px 20px;background-position:left center}.about-banner .inline-link{width:100%;font-size:14px}.value-row div{min-height:110px}.nav-wrap{height:74px}.brand img{width:116px}.hero-inner{padding:26px 18px}.hero-copy{padding:0 0 18px}.hero h1{font-size:43px}.hero p{font-size:16px}.hero-actions,.cta-actions,.button-row{flex-direction:column}.btn{width:100%}.hero-trust{grid-template-columns:1fr;gap:12px}.hero-photo{height:620px;border-radius:20px}.hero-photo img{object-position:center top}.section{padding:28px 0}.about-panel{padding:22px;gap:18px}.value-row{grid-template-columns:repeat(2,1fr)}.value-row div{padding:14px;border-top:1px solid var(--line);border-left:0}.treatment-cards,.help-grid,.profiles,.grid.three,.grid.four{grid-template-columns:1fr}.treatment-img img{height:auto}.staff-image img{height:auto}.timeline{grid-template-columns:1fr}.media-card{grid-template-columns:1fr}.media-card img{height:240px;order:-1}.testimonial-grid blockquote{font-size:16px}.myth-list{grid-template-columns:1fr}.cta-card{grid-template-columns:1fr;padding:28px}.contact-row{flex-direction:column}.contact-row a{min-width:0;width:100%}.social-pill-icon{width:24px;height:24px}.footer-inner{flex-direction:column}.footer-inner nav{justify-content:center}.section-head{display:block}}


/* Testimonials showcase section */
.testimonials-showcase{padding:28px 0 34px}
.testimonials-bg{
  background-image:url('assets/testimonials-bg.png');
  background-size:cover;
  background-position:center;
  border-radius:28px;
  overflow:hidden;
  padding:34px 24px 28px;
}
.testimonials-head{text-align:center;max-width:860px;margin:0 auto 28px}
.testimonials-head h2{font-size:56px;line-height:1;margin:0 0 14px;color:#132c9c;letter-spacing:-.06em}
.testimonials-head p{margin:0;color:#3a4a63;font-size:16px}
.title-accent{display:flex;align-items:center;justify-content:center;gap:10px;margin:0 0 16px}
.title-accent span{display:block;width:42px;height:2px;background:#2ab3eb;border-radius:999px}
.title-accent i{display:block;width:11px;height:11px;background:#2ab3eb;border-radius:50%}
.testimonials-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1.4fr) minmax(0,1fr);
  gap:34px;
  align-items:start;
}
.testimonial-card{
  position:relative;
  background:rgba(255,255,255,.96);
  border:1px solid rgba(151,167,191,.35);
  border-radius:20px;
  box-shadow:0 14px 36px rgba(16,42,97,.09);
  padding:0 22px 26px;
  margin-top:78px;
}
.featured-card{margin-top:82px}
.testimonial-avatar{
  width:140px;
  height:140px;
  border-radius:50%;
  overflow:hidden;
  border:4px solid #0ec3f6;
  box-shadow:0 10px 24px rgba(14,195,246,.18);
  margin:-74px auto 12px;
  background:#fff;
}
.featured-card .testimonial-avatar{width:154px;height:154px;margin-top:-82px}
.testimonial-avatar img{width:100%;height:100%;object-fit:cover}
.testimonial-body{text-align:center}
.testimonial-body h3{
  margin:0 0 8px;
  color:#132c9c;
  font-size:32px;
  line-height:1.1;
  letter-spacing:-.03em;
}
.side-card .testimonial-body h3{font-size:28px}
.testimonial-body strong{
  display:block;
  color:#2f3746;
  font-size:18px;
  line-height:1.2;
  margin-bottom:18px;
}
.testimonial-divider{
  width:100%;
  height:1px;
  background:rgba(151,167,191,.55);
  margin:0 0 18px;
}
.testimonial-body p{
  margin:0;
  color:#545f71;
  font-size:17px;
  line-height:1.65;
}
.side-card .testimonial-body p{font-size:16px;line-height:1.7}
.testimonials-note{
  text-align:center;
  margin:22px 0 0;
  color:#6d7889;
  font-size:12px;
  font-weight:700;
}
@media(max-width:1300px){
  .testimonials-head h2{font-size:48px}
  .testimonials-layout{grid-template-columns:repeat(2,minmax(0,1fr))}
  .featured-card{grid-column:1/-1;max-width:880px;margin-left:auto;margin-right:auto}
}
@media(max-width:920px){
  .testimonials-bg{padding:28px 18px 24px}
  .testimonials-layout{grid-template-columns:1fr;gap:28px}
  .testimonial-card,.featured-card{max-width:760px;margin:78px auto 0}
  .featured-card{margin-top:82px}
  .testimonials-head h2{font-size:42px}
  .testimonial-body h3{font-size:28px}
  .side-card .testimonial-body h3{font-size:26px}
}
@media(max-width:720px){
  .testimonials-showcase{padding:24px 0 28px}
  .testimonials-bg{border-radius:22px;padding:24px 14px 20px}
  .testimonials-head{margin-bottom:18px}
  .testimonials-head h2{font-size:36px}
  .testimonials-head p{font-size:14px}
  .title-accent span{width:34px}
  .testimonial-card,.featured-card{padding:0 16px 22px;margin-top:70px}
  .testimonial-avatar{width:114px;height:114px;margin-top:-58px}
  .featured-card .testimonial-avatar{width:118px;height:126px;margin-top:-64px}
  .testimonial-body h3,.side-card .testimonial-body h3{font-size:22px}
  .testimonial-body strong{font-size:16px;margin-bottom:14px}
  .testimonial-body p,.side-card .testimonial-body p{font-size:15px;line-height:1.6}
}



/* Instagram official embeds section */
.instagram-section{padding:28px 0 34px}
.instagram-panel{
  position:relative;
  overflow:hidden;
  border-radius:28px;
  padding:34px;
  background:
    radial-gradient(circle at 8% 0%, rgba(237,246,251,.95), transparent 32%),
    radial-gradient(circle at 94% 100%, rgba(242,239,255,.8), transparent 30%),
    linear-gradient(135deg,#fffdf9 0%,#f6f9fd 100%);
  border:1px solid rgba(220,231,244,.85);
  box-shadow:0 18px 44px rgba(16,42,97,.06);
}
.instagram-panel:before{
  content:"";
  position:absolute;
  inset:18px auto auto -90px;
  width:280px;
  height:280px;
  border-radius:50%;
  border:2px solid rgba(42,179,235,.14);
}
.instagram-panel:after{
  content:"";
  position:absolute;
  right:-70px;
  bottom:-130px;
  width:360px;
  height:260px;
  border-radius:50%;
  background:rgba(237,246,251,.82);
}
.instagram-panel>*{position:relative;z-index:1}
.instagram-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:22px;
  margin-bottom:22px;
}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:var(--blue);
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.16em;
  margin-bottom:8px;
}
.instagram-head h2{
  margin:0 0 8px;
  font-size:34px;
  letter-spacing:-.045em;
}
.instagram-head p{margin:0;max-width:660px;font-size:14px}
.instagram-profile img{width:22px;height:22px;object-fit:contain}
.instagram-status{
  color:#64728a;
  font-size:13px;
  font-weight:750;
  margin:0 0 16px;
}
.instagram-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
  align-items:start;
}
.instagram-embed-card{
  min-height:470px;
  border-radius:20px;
  background:#fff;
  border:1px solid rgba(220,231,244,.95);
  box-shadow:0 12px 28px rgba(16,42,97,.055);
  padding:10px;
  overflow:hidden;
}
.instagram-embed-card blockquote.instagram-media{
  margin:0 auto!important;
  min-width:0!important;
  width:100%!important;
  max-width:540px!important;
  border:0!important;
  box-shadow:none!important;
}
.instagram-fallback{
  display:grid;
  place-items:center;
  min-height:330px;
  text-align:center;
  padding:24px;
  color:#405171;
}
.instagram-fallback img{width:34px;height:34px;margin:0 auto 12px}
.instagram-fallback a{color:var(--blue);font-weight:900}
@media(max-width:1100px){
  .instagram-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:720px){
  .instagram-panel{padding:24px 14px;border-radius:22px}
  .instagram-head{display:block}
  .instagram-head h2{font-size:28px}
  .instagram-profile{width:100%;margin-top:16px}
  .instagram-grid{grid-template-columns:1fr}
  .instagram-embed-card{min-height:430px}
}


.instagram-empty{
  grid-column:1/-1;
  min-height:260px;
  display:grid;
  place-items:center;
  text-align:center;
  padding:34px;
  background:#fff;
  border:1px solid rgba(220,231,244,.95);
  border-radius:20px;
  box-shadow:0 12px 28px rgba(16,42,97,.055);
}
.instagram-empty img{width:44px;height:44px;margin:0 auto 12px}
.instagram-empty h3{margin:0 0 8px;color:var(--deep);font-size:20px}
.instagram-empty p{max-width:640px;margin:0 auto 18px;font-size:14px}


/* Redesigned resources section */
.resources-redesign{padding:30px 0 36px}
.resources-shell{
  position:relative;
  overflow:hidden;
  border-radius:28px;
  padding:34px 28px 28px;
  background-image:url('assets/resources-section-bg.png');
  background-size:cover;
  background-position:center;
  box-shadow:0 18px 44px rgba(16,42,97,.055);
}
.resources-shell::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,.22) 0%, rgba(255,255,255,.06) 100%);
  pointer-events:none;
}
.resources-shell > *{position:relative;z-index:1}
.resources-topbar{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:24px;
  margin-bottom:24px;
}
.resources-topbar h2{margin:0 0 10px;font-size:34px;letter-spacing:-.045em}
.resources-topbar p{max-width:760px;margin:0;font-size:14px;line-height:1.6;color:#50607a}
.resources-all-link{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:12px 18px;
  border-radius:999px;
  border:1px solid rgba(22,87,194,.18);
  background:rgba(255,255,255,.78);
  color:var(--blue);
  font-weight:850;
  font-size:14px;
  box-shadow:0 10px 24px rgba(16,42,97,.04);
}
.resources-all-link span{font-size:18px;line-height:1}
.resources-grid-v2{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:12px;padding-top:8px}
.resource-card-v2{
  display:grid;
  grid-template-columns:76px 1fr;
  gap:18px;
  align-items:flex-start;
  padding:20px 18px;
  border-radius:20px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(217,227,239,.95);
  box-shadow:0 14px 30px rgba(16,42,97,.045);
  min-height:100%;
}
.resource-icon-box{
  width:78px;height:78px;border-radius:18px;display:grid;place-items:center;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.6);
}
.mint-soft{background:#dff2ee}
.lavender-soft{background:#ede8f9}
.beige-soft{background:#f4ebdc}
.resource-card-icon{width:58px;height:58px;object-fit:contain;display:block;background:transparent}
.resource-card-body h3{
  font-size:22px;
  line-height:1.22;
  letter-spacing:-.03em;
  color:#1f2960;
  margin:2px 0 12px;
}
.resource-card-body p{font-size:14px;line-height:1.62;color:#58677f;margin:0 0 14px}
.resource-card-body small{display:block;color:#7d8ba3;font-weight:700;margin:0 0 18px}
.resource-download-btn{display:inline-flex;width:auto;gap:10px;padding-inline:18px}
@media(max-width:1100px){
  .resources-topbar{display:block}
  .resources-all-link{margin-top:16px}
  .resources-grid-v2{grid-template-columns:1fr 1fr}
}
@media(max-width:720px){
  .resources-shell{padding:24px 14px 16px;border-radius:22px}
  .resources-topbar h2{font-size:28px}
  .resources-topbar p{font-size:13px}
  .resources-all-link{width:100%;justify-content:center}
  .resources-grid-v2{grid-template-columns:1fr;gap:14px}
  .resource-card-v2{grid-template-columns:68px 1fr;gap:14px;padding:16px 14px;border-radius:18px}
  .resource-icon-box{width:68px;height:68px;border-radius:16px}
  .resource-card-icon{width:50px;height:50px}
  .resource-card-body h3{font-size:19px}
  .resource-card-body p{font-size:13px}
  .resource-download-btn{width:100%;justify-content:center}
}


/* Sabías que Instagram embeds inside Resources */
.sabias-que-block{
  margin:26px 0 54px;
  padding:24px;
  border-radius:24px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(220,231,244,.75);
  box-shadow:0 14px 30px rgba(16,42,97,.045);
  backdrop-filter:blur(4px);
}
.sabias-que-head{
  max-width:820px;
  margin:0 0 20px;
}
.sabias-que-head h3{
  color:#102a61;
  font-size:30px;
  line-height:1.1;
  letter-spacing:-.04em;
  margin:0 0 8px;
}
.sabias-que-head p{
  margin:0;
  color:#58677f;
  font-size:14px;
  line-height:1.6;
}
.sabias-instagram-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
  align-items:start;
}
.sabias-post-card{
  min-height:470px;
  border-radius:20px;
  background:#fff;
  border:1px solid rgba(220,231,244,.95);
  box-shadow:0 12px 28px rgba(16,42,97,.055);
  padding:10px;
  overflow:hidden;
}
.sabias-post-card blockquote.instagram-media{
  margin:0 auto!important;
  min-width:0!important;
  width:100%!important;
  max-width:540px!important;
  border:0!important;
  box-shadow:none!important;
}
@media(max-width:1100px){
  .sabias-instagram-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:720px){
  .sabias-que-block{padding:18px 12px;border-radius:20px;margin-bottom:38px}
  .sabias-que-head h3{font-size:26px}
  .sabias-instagram-grid{grid-template-columns:1fr}
  .sabias-post-card{min-height:430px}
}



/* New staff section */
.staff-section-new{padding:24px 0 34px}
.staff-shell{
  position:relative;
  overflow:hidden;
  border-radius:30px;
  padding:34px 28px 28px;
  background-image:url('assets/staff-section-bg.png');
  background-size:cover;
  background-position:center;
  border:1px solid rgba(220,231,244,.92);
  box-shadow:0 18px 44px rgba(16,42,97,.06);
}
.staff-shell::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,.24) 0%, rgba(255,255,255,.08) 100%);
  pointer-events:none;
}
.staff-shell > *{position:relative;z-index:1}
.staff-section-head{max-width:900px;margin:0 0 24px}
.staff-section-head h2{font-size:36px;line-height:1.04;letter-spacing:-.05em;margin:0 0 10px;color:var(--deep)}
.staff-section-head p{margin:0;color:#50607a;font-size:15px;line-height:1.65}
.staff-grid-new{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px}
.staff-card-new{
  display:grid;
  grid-template-columns:132px 1fr;
  gap:20px;
  align-items:flex-start;
  padding:22px;
  border-radius:24px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(219,228,240,.96);
  box-shadow:0 14px 30px rgba(16,42,97,.05);
  min-height:100%;
}
.featured-staff-card,.assistant-card{grid-column:span 2}
.featured-staff-card{background:rgba(255,255,255,.95)}
.staff-photo-wrap{
  width:132px;
  height:132px;
  border-radius:22px;
  overflow:hidden;
  background:linear-gradient(180deg,#edf6fb,#f2efff);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.6);
}
.staff-photo-wrap img{width:100%;height:100%;object-fit:cover;display:block}
.staff-copy{display:flex;flex-direction:column;align-items:flex-start}
.staff-tag{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 12px;
  border-radius:999px;
  background:#eef5ff;
  color:var(--blue);
  font-size:12px;
  font-weight:850;
  letter-spacing:.02em;
  margin-bottom:12px;
}
.staff-copy h3{font-size:28px;line-height:1.05;letter-spacing:-.04em;color:var(--deep);margin:0 0 8px}
.staff-copy h4{font-size:15px;line-height:1.35;color:var(--blue);margin:0 0 12px;font-weight:850}
.staff-copy p{font-size:14px;line-height:1.66;color:#56657d;margin:0 0 18px}
.staff-copy .btn{width:auto;padding-inline:18px}
@media(max-width:1100px){
  .staff-grid-new{grid-template-columns:1fr}
  .featured-staff-card,.assistant-card{grid-column:auto}
}
@media(max-width:720px){
  .staff-section-new{padding:20px 0 28px}
  .staff-shell{padding:24px 14px 16px;border-radius:22px}
  .staff-section-head h2{font-size:30px}
  .staff-section-head p{font-size:14px}
  .staff-card-new{grid-template-columns:1fr;gap:16px;padding:18px;border-radius:20px}
  .staff-photo-wrap{width:100%;height:auto;aspect-ratio:1/1;max-width:220px}
  .staff-copy h3{font-size:24px}
  .staff-copy h4{font-size:14px}
  .staff-copy p{font-size:13px}
  .staff-copy .btn{width:100%;justify-content:center}
}



/* Standalone Staff page matching generated mockup */
.staff-page-body{
  --staff-navy:#102a61;
  --staff-teal:#2b9caf;
  --staff-purple:#7769e8;
  background:#fff;
  min-height:100vh;
  overflow-x:hidden;
}
.staff-page-header{
  position:relative;
  z-index:20;
  height:78px;
  background:transparent;
  border-bottom:1px solid rgba(220,231,244,.75);
  box-shadow:0 10px 28px rgba(16,42,97,.07);
}
.staff-page-nav{
  width:min(100% - 70px,1400px);
  height:78px;
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:36px;
}
.staff-page-brand img{
  width:198px;
  height:58px;
  object-fit:contain;
}
.staff-page-menu{
  display:flex;
  align-items:center;
  gap:52px;
  font-size:16px;
  font-weight:650;
  color:#17203d;
}
.staff-page-menu a{
  position:relative;
  padding:29px 0 28px;
}
.staff-page-menu a.active{
  color:var(--staff-purple);
  font-weight:800;
}
.staff-page-menu a.active::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:0;
  width:148px;
  height:3px;
  transform:translateX(-50%);
  border-radius:999px;
  background:var(--staff-purple);
}
.staff-page-main{
  background-image:url('assets/staff-section-bg.png');
  background-size:cover;
  background-position:center top;
  min-height:calc(100vh - 78px);
}
.staff-hero-page{
  width:min(100% - 76px,1370px);
  margin:0 auto;
  padding:34px 0 32px;
}
.staff-page-title{
  text-align:center;
  margin:0 auto 42px;
}
.staff-page-title h1{
  font-family:'Playfair Display', Georgia, serif;
  font-size:82px;
  line-height:.9;
  color:var(--staff-navy);
  margin:0 0 9px;
  letter-spacing:-.04em;
}
.staff-title-accent{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  height:16px;
  margin:0 0 12px;
}
.staff-title-accent i,
.staff-title-accent b{
  display:block;
  width:10px;
  height:10px;
  border-radius:50%;
  background:var(--staff-teal);
}
.staff-title-accent b{background:var(--staff-purple)}
.staff-title-accent span{
  display:block;
  width:84px;
  height:4px;
  border-radius:999px;
  background:var(--staff-teal);
}
.staff-page-title p{
  color:#17203d;
  font-size:20px;
  line-height:1.38;
  margin:0;
  font-weight:500;
}
.staff-page-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px 16px;
}
.staff-profile-card{
  min-height:288px;
  display:flex;
  gap:24px;
  padding:9px 20px 10px 9px;
  background:rgba(255,255,255,.96);
  border:1px solid rgba(222,229,239,.95);
  border-radius:13px;
  box-shadow:0 8px 20px rgba(16,42,97,.085);
  overflow:hidden;
}
.staff-portrait{
  flex:0 0 184px;
  width:184px;
  height:268px;
  border-radius:9px;
  overflow:hidden;
  background:#edf6fb;
  align-self:stretch;
}
.staff-portrait img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.staff-content{
  flex:1 1 auto;
  min-width:0;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  padding-top:7px;
}
.staff-content h2{
  font-family:'Playfair Display', Georgia, serif;
  color:var(--staff-navy);
  font-size:26px;
  line-height:1.08;
  margin:0 0 6px;
  letter-spacing:-.02em;
}
.staff-content h3{
  color:var(--staff-teal);
  font-size:14px;
  line-height:1.2;
  margin:0 0 10px;
  font-weight:850;
}
.staff-mini-line{
  width:24px;
  height:2px;
  border-radius:99px;
  background:var(--staff-teal);
  margin:0 0 13px;
}
.staff-content p{
  color:#16223b;
  font-size:10.9px;
  line-height:1.44;
  margin:0 0 12px;
  font-weight:500;
}
.staff-card-btn{
  margin-top:auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:9px;
  min-width:120px;
  padding:9px 17px;
  border-radius:6px;
  background:linear-gradient(180deg,#43aebb,#3399a7);
  color:#fff;
  font-size:13px;
  font-weight:850;
  box-shadow:0 7px 16px rgba(43,156,175,.20);
}
.staff-card-btn img{
  width:16px;
  height:16px;
  object-fit:contain;
  filter:brightness(0) invert(1);
}
.staff-page-footer{
  position:relative;
  z-index:2;
  background:rgba(255,255,255,.72);
  backdrop-filter:blur(6px);
  border-top:1px solid rgba(220,231,244,.75);
  padding:22px 20px 14px;
  text-align:center;
}
.staff-page-footer nav{
  display:flex;
  justify-content:center;
  gap:70px;
  flex-wrap:wrap;
  color:#17203d;
  font-size:15px;
  font-weight:600;
  margin-bottom:14px;
}
.staff-page-footer a.active{color:var(--staff-purple);font-weight:800}
.staff-page-footer p{
  margin:0;
  color:#777;
  font-size:15px;
}
.staff-teaser-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  border-radius:24px;
  padding:28px;
  background:linear-gradient(135deg,#f7fbff,#fff);
  border:1px solid rgba(220,231,244,.9);
  box-shadow:0 16px 38px rgba(16,42,97,.045);
}
.staff-teaser-card h2{margin:0 0 8px}
.staff-teaser-card p{max-width:720px;margin:0}

@media(max-width:1280px){
  .staff-page-menu{gap:28px;font-size:14px}
  .staff-page-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:900px){
  .staff-page-nav{width:min(100% - 32px,1400px)}
  .staff-page-menu{display:none}
  .staff-page-brand img{width:150px}
  .staff-hero-page{width:min(100% - 28px,1370px)}
  .staff-page-title h1{font-size:56px}
  .staff-page-title p{font-size:16px}
  .staff-page-grid{grid-template-columns:1fr}
  .staff-profile-card{display:flex}
  .staff-portrait{flex-basis:132px;width:132px;height:190px}
  .staff-page-footer nav{gap:18px}
  .staff-teaser-card{display:block}
  .staff-teaser-card .btn{margin-top:18px}
}
@media(max-width:560px){
  .staff-profile-card{display:block;padding:12px}
  .staff-portrait{width:100%;height:auto;aspect-ratio:1/1}
  .staff-content h2{font-size:25px}
  .staff-card-btn{width:100%}
}



/* Staff page using original site navbar */
.staff-page-main-with-original-nav{
  min-height:calc(100vh - 82px);
}
.staff-page-body .site-header{
  position:sticky;
  top:0;
}
.staff-page-body .main-nav a{
  position:relative;
}
.staff-page-body .main-nav a.active{
  color:var(--blue);
}
.staff-page-body .main-nav a.active::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:3px;
  height:3px;
  border-radius:999px;
  background:var(--blue);
}


/* Staff page original footer compatibility */
.staff-page-body .site-footer{
  background:#fff;
  margin-top:0;
}
.staff-page-body .site-footer .footer-inner{
  width:min(100% - 42px,1200px);
  margin-inline:auto;
}
.staff-card-btn img{
  width:16px;
  height:16px;
  object-fit:contain;
  filter:brightness(0) invert(1);
}



/* Standalone Courses page */
.courses-page-body{
  background:#fff;
  min-height:100vh;
}
.courses-page-body .site-header{
  position:sticky;
  top:0;
  z-index:50;
}
.courses-page-body .main-nav a{
  position:relative;
}
.courses-page-body .main-nav a.active{
  color:var(--blue);
}
.courses-page-body .main-nav a.active::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:3px;
  height:3px;
  border-radius:999px;
  background:var(--blue);
}
.courses-page-main{
  background-image:url('assets/courses-page-bg-full.png');
  background-size:cover;
  background-position:center top;
  background-repeat:no-repeat;
  min-height:100vh;
}
.courses-page-section{
  padding:28px 0 44px;
}
.courses-page-inner{
  width:min(100% - 76px,1370px);
  margin:0 auto;
}
.courses-head{
  max-width:620px;
  margin:0 0 22px;
  position:relative;
  z-index:1;
}
.courses-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:14px;
  padding:10px 24px 10px 12px;
  border-radius:999px;
  background:rgba(242,245,255,.86);
  color:#102a61;
  text-transform:uppercase;
  letter-spacing:.24em;
  font-size:12px;
  font-weight:900;
  margin:0 0 10px;
}
.courses-eyebrow img{
  width:36px;
  height:36px;
  border-radius:50%;
  object-fit:contain;
  padding:6px;
  background:#fff;
  border:1px solid rgba(43,90,210,.15);
}
.courses-head h1{
  color:#102a61;
  font-size:72px;
  line-height:.96;
  letter-spacing:-.065em;
  margin:0 0 12px;
}
.courses-head p{
  margin:0;
  color:#233052;
  font-size:18px;
  line-height:1.48;
}
.courses-head-line{
  display:flex;
  align-items:center;
  gap:10px;
  margin-top:18px;
}
.courses-head-line i{
  width:8px;
  height:8px;
  display:block;
  border-radius:50%;
  background:#5b75e7;
}
.courses-head-line span{
  width:138px;
  height:2px;
  display:block;
  border-radius:999px;
  background:#ccd6f3;
}
.courses-grid-page{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px 28px;
}
.course-page-card{
  position:relative;
  min-height:324px;
  display:grid;
  grid-template-columns:176px 1fr;
  gap:22px;
  overflow:hidden;
  border-radius:18px;
  padding:22px 28px 20px 26px;
  background-image:var(--card-bg);
  background-size:cover;
  background-position:center;
  border:1px solid rgba(207,219,238,.95);
  box-shadow:0 16px 34px rgba(16,42,97,.08);
}
.course-media{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:space-between;
  min-height:280px;
}
.course-icon-circle{
  width:126px;
  height:126px;
  border-radius:50%;
  display:grid;
  place-items:center;
  margin-top:2px;
}
.course-icon-circle img{
  width:96px;
  height:96px;
  object-fit:contain;
  display:block;
}
.purple-circle{background:rgba(232,221,250,.72)}
.teal-circle{background:rgba(220,242,238,.78)}
.blue-circle{background:rgba(226,237,250,.82)}
.orange-circle{background:rgba(248,230,209,.82)}
.course-video-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:28px;
  width:148px;
  min-height:42px;
  border-radius:10px;
  border:1.5px solid #657dea;
  background:rgba(255,255,255,.7);
  color:#1644a9;
  font-weight:900;
  font-size:14px;
  box-shadow:0 8px 18px rgba(16,42,97,.04);
}
.course-video-btn b{
  width:0;
  height:0;
  border-top:6px solid transparent;
  border-bottom:6px solid transparent;
  border-left:9px solid #5b75e7;
}
.course-info{
  min-width:0;
  padding-top:4px;
}
.course-info h2{
  color:#102a61;
  font-size:25px;
  line-height:1.08;
  letter-spacing:-.045em;
  margin:0 0 4px;
}
.course-info h3{
  color:#566de0;
  font-size:15px;
  line-height:1.25;
  margin:0 0 16px;
  font-weight:850;
}
.course-teal .course-info h3{color:#409a91}
.course-row{
  display:grid;
  grid-template-columns:24px 1fr;
  gap:14px;
  align-items:start;
  margin:0 0 12px;
}
.course-row img{
  width:23px;
  height:23px;
  object-fit:contain;
  display:block;
}
.course-row p{
  margin:0;
  color:#1e2c4b;
  font-size:13px;
  line-height:1.38;
}
.course-row strong{
  color:#102a61;
  font-weight:900;
}
.family-course h2{
  font-size:24px;
  margin-bottom:16px;
}
.family-paragraph{
  display:grid;
  grid-template-columns:10px 1fr;
  gap:12px;
  margin:0 0 14px;
}
.family-paragraph i{
  width:7px;
  height:7px;
  border-radius:50%;
  background:#d88a4d;
  margin-top:7px;
  box-shadow:0 0 0 4px rgba(216,138,77,.12);
}
.family-paragraph p{
  margin:0;
  color:#1e2c4b;
  font-size:12.5px;
  line-height:1.45;
}
.courses-page-body .site-footer{
  background:#fff;
}
@media(max-width:1180px){
  .courses-page-inner{width:min(100% - 34px,1370px)}
  .courses-grid-page{grid-template-columns:1fr}
  .course-page-card{min-height:300px}
}
@media(max-width:720px){
  .courses-page-section{
  padding:28px 0 44px;
}
  .courses-head h1{font-size:48px}
  .courses-head p{font-size:16px}
  .courses-eyebrow{font-size:10px;letter-spacing:.16em;padding-right:16px}
  .course-page-card{
    grid-template-columns:1fr;
    padding:20px 16px;
    min-height:auto;
  }
  .course-media{
    min-height:0;
    gap:16px;
  }
  .course-icon-circle{
    width:120px;
    height:120px;
  }
  .course-info h2{font-size:23px}
  .course-video-btn{
    width:100%;
  }
}



/* Courses page adjusted to match reference card composition */
.courses-page-main{
  background-image:url('assets/courses-page-bg-full.png');
  background-size:cover;
  background-position:center top;
  background-repeat:no-repeat;
  min-height:100vh;
}
.courses-page-section{padding:26px 0 44px;}
.courses-page-inner{width:min(100% - 76px,1370px);margin:0 auto;}
.courses-head{max-width:620px;margin:0 0 22px;position:relative;z-index:1;}
.courses-head h1{color:#102a61;font-size:72px;line-height:.96;letter-spacing:-.065em;margin:0 0 12px;}
.courses-head p{margin:0;color:#233052;font-size:18px;line-height:1.48;}
.courses-grid-page{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px 28px;align-items:stretch;}
.course-page-card{
  position:relative;
  min-height:352px;
  display:grid;
  grid-template-columns:minmax(0,1.2fr) 240px;
  gap:10px;
  overflow:hidden;
  border-radius:18px;
  padding:26px 26px 22px 28px;
  background-image:var(--card-bg);
  background-size:cover;
  background-position:center;
  border:1px solid rgba(207,219,238,.95);
  box-shadow:0 16px 34px rgba(16,42,97,.08);
}
.course-info{min-width:0;padding-top:2px;display:flex;flex-direction:column;align-items:flex-start;}
.course-info h2{color:#102a61;font-size:25px;line-height:1.08;letter-spacing:-.045em;margin:0 0 4px;max-width:440px;}
.course-info h3{color:#566de0;font-size:15px;line-height:1.25;margin:0 0 18px;font-weight:850;max-width:432px;}
.course-teal .course-info h3,.course-page-card.course-teal .course-info h3{color:#42988f;}
.course-row{display:grid;grid-template-columns:22px 1fr;gap:12px;align-items:start;margin:0 0 12px;max-width:430px;}
.course-row img{width:22px;height:22px;object-fit:contain;display:block;}
.course-row p{margin:0;color:#1e2c4b;font-size:13px;line-height:1.38;}
.course-row strong{color:#102a61;font-weight:900;}
.featured-row{margin-top:2px;padding-bottom:14px;border-bottom:1px solid rgba(147,169,228,.35);margin-bottom:14px;width:100%;}
.objective-row{margin-bottom:16px;}
.course-media{display:flex;align-items:center;justify-content:center;min-height:100%;}
.media-right{justify-content:flex-end;align-items:center;}
.course-icon-circle{width:230px;height:230px;border-radius:50%;display:grid;place-items:center;flex:0 0 auto;}
.course-icon-circle img{width:168px;height:168px;object-fit:contain;display:block;}
.large-illustration img{filter:none;}
.purple-circle{background:rgba(232,221,250,.42)}
.teal-circle{background:rgba(220,242,238,.56)}
.blue-circle{background:rgba(226,237,250,.56)}
.orange-circle{background:rgba(248,230,209,.62)}
.course-video-btn.solid-btn{
  margin-top:auto;
  display:inline-flex;align-items:center;justify-content:space-between;
  gap:18px;min-width:170px;height:48px;padding:0 18px 0 24px;
  border-radius:14px;border:none;background:#0f43af;color:#fff;
  font-weight:800;font-size:16px;box-shadow:0 16px 24px rgba(15,67,175,.18);
}
.course-video-btn.solid-btn b{width:0;height:0;border-top:7px solid transparent;border-bottom:7px solid transparent;border-left:11px solid #ffffff;}
.family-course h2{font-size:24px;max-width:420px;margin-bottom:8px;}
.family-course h3{max-width:420px;margin-bottom:18px;}
.family-text-block{display:flex;flex-direction:column;gap:10px;margin-bottom:14px;max-width:430px;}
.family-text-block p{margin:0;color:#1e2c4b;font-size:12.25px;line-height:1.42;}
@media(max-width:1180px){
  .courses-page-inner{width:min(100% - 34px,1370px)}
  .courses-grid-page{grid-template-columns:1fr}
  .course-page-card{grid-template-columns:minmax(0,1fr) 240px;min-height:330px}
}
@media(max-width:820px){
  .courses-page-section{padding:22px 0 32px}
  .courses-head h1{font-size:48px}
  .courses-head p{font-size:16px}
  .courses-eyebrow{font-size:10px;letter-spacing:.16em;padding-right:16px}
  .course-page-card{grid-template-columns:1fr;padding:20px 16px;min-height:auto;}
  .course-media{order:-1;justify-content:center;min-height:0;padding-bottom:12px;}
  .course-icon-circle{width:160px;height:160px;}
  .course-icon-circle img{width:120px;height:120px;}
  .course-info h2{font-size:23px}
  .course-info h3,.course-row,.family-text-block,.course-info h2{max-width:none;}
  .featured-row{width:100%;}
  .course-video-btn.solid-btn{width:100%;justify-content:center;}
}


/* Final Courses card positioning fix: icons without extra circle, positioned like reference */
.courses-grid-page{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px 28px;
  align-items:stretch;
}
.course-page-card{
  position:relative;
  min-height:352px;
  display:block;
  overflow:hidden;
  border-radius:18px;
  padding:27px 28px 22px 28px;
  background-image:var(--card-bg);
  background-size:cover;
  background-position:center;
  border:1px solid rgba(207,219,238,.95);
  box-shadow:0 16px 34px rgba(16,42,97,.08);
}
.course-info{
  position:relative;
  z-index:2;
  width:62%;
  min-width:0;
  padding-top:0;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  min-height:303px;
}
.course-info h2{
  color:#102a61;
  font-size:25px;
  line-height:1.08;
  letter-spacing:-.045em;
  margin:0 0 4px;
  max-width:430px;
}
.course-info h3{
  color:#566de0;
  font-size:15px;
  line-height:1.25;
  margin:0 0 18px;
  font-weight:850;
  max-width:420px;
}
.course-teal .course-info h3,
.course-page-card.course-teal .course-info h3{
  color:#42988f;
}
.course-row{
  display:grid;
  grid-template-columns:22px 1fr;
  gap:12px;
  align-items:start;
  margin:0 0 12px;
  max-width:430px;
}
.course-row img{
  width:22px;
  height:22px;
  object-fit:contain;
  display:block;
}
.course-row p{
  margin:0;
  color:#1e2c4b;
  font-size:13px;
  line-height:1.38;
}
.course-row strong{
  color:#102a61;
  font-weight:900;
}
.featured-row{
  margin-top:2px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(147,169,228,.35);
  margin-bottom:14px;
  width:100%;
}
.objective-row{
  margin-bottom:16px;
}
.course-media.media-right{
  position:absolute;
  z-index:1;
  right:44px;
  top:50%;
  transform:translateY(-50%);
  width:230px;
  height:230px;
  display:grid;
  place-items:center;
  min-height:0;
  pointer-events:none;
}
.course-icon-circle,
.course-icon-circle.purple-circle,
.course-icon-circle.teal-circle,
.course-icon-circle.blue-circle,
.course-icon-circle.orange-circle,
.purple-circle,
.teal-circle,
.blue-circle,
.orange-circle{
  background:transparent!important;
  border-radius:0!important;
  width:230px!important;
  height:230px!important;
  display:grid;
  place-items:center;
  box-shadow:none!important;
  margin:0!important;
}
.course-icon-circle img{
  width:210px!important;
  height:210px!important;
  object-fit:contain;
  display:block;
}
.course-page-card.course-orange .course-media.media-right{
  right:44px;
}
.course-page-card.course-orange .course-icon-circle img{
  width:220px!important;
  height:220px!important;
}
.course-video-btn.solid-btn{
  margin-top:auto;
  display:inline-flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  min-width:170px;
  height:48px;
  padding:0 18px 0 24px;
  border-radius:14px;
  border:none;
  background:#0f43af;
  color:#fff;
  font-weight:800;
  font-size:16px;
  box-shadow:0 16px 24px rgba(15,67,175,.18);
}
.course-video-btn.solid-btn b{
  width:0;
  height:0;
  border-top:7px solid transparent;
  border-bottom:7px solid transparent;
  border-left:11px solid #ffffff;
}
.family-course{
  width:61%;
}
.family-course h2{
  font-size:24px;
  max-width:430px;
  margin-bottom:8px;
}
.family-course h3{
  max-width:430px;
  margin-bottom:18px;
}
.family-text-block{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-bottom:14px;
  max-width:430px;
}
.family-text-block p{
  margin:0;
  color:#1e2c4b;
  font-size:12.25px;
  line-height:1.42;
}
@media(max-width:1180px){
  .courses-page-inner{width:min(100% - 34px,1370px)}
  .courses-grid-page{grid-template-columns:1fr}
  .course-info{width:64%}
  .family-course{width:64%}
}
@media(max-width:820px){
  .course-page-card{
    padding:20px 16px;
    min-height:auto;
  }
  .course-info,
  .family-course{
    width:100%;
    min-height:0;
  }
  .course-media.media-right{
    position:relative;
    right:auto;
    top:auto;
    transform:none;
    width:160px;
    height:160px;
    margin:0 auto 16px;
    order:-1;
  }
  .course-icon-circle,
  .course-icon-circle.purple-circle,
  .course-icon-circle.teal-circle,
  .course-icon-circle.blue-circle,
  .course-icon-circle.orange-circle{
    width:160px!important;
    height:160px!important;
  }
  .course-icon-circle img,
  .course-page-card.course-orange .course-icon-circle img{
    width:140px!important;
    height:140px!important;
  }
  .course-info h2,
  .course-info h3,
  .course-row,
  .family-text-block{
    max-width:none;
  }
  .course-video-btn.solid-btn{
    width:100%;
    justify-content:center;
  }
}



/* ===============================
   QUIÉNES SOMOS V2
================================= */
.about-v2-body{
  background:#ffffff;
}
.about-v2-body .site-header{
  position:sticky;
  top:0;
  z-index:60;
}
.about-v2-body .main-nav a{
  position:relative;
}
.about-v2-body .main-nav a.active{
  color:var(--blue);
}
.about-v2-body .main-nav a.active::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:3px;
  height:3px;
  border-radius:999px;
  background:var(--blue);
}
.about-v2-main{
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(180deg, rgba(255,255,255,.95) 0%, rgba(255,255,255,.98) 100%),
    url('assets/about-elegant-bg.png') center top / cover no-repeat;
}
.about-v2-main::before{
  content:"";
  position:absolute;
  inset:0;
  background:url('assets/about-elegant-bg.png') center top / cover no-repeat;
  opacity:.86;
  pointer-events:none;
}
.about-v2-main > *{
  position:relative;
  z-index:1;
}
.about-v2-shell{
  width:min(100% - 72px, 1520px);
  margin:0 auto;
  padding:0 0 48px;
}
.about-v2-hero{
  padding:18px 0 24px;
}
.about-v2-rule{
  height:1px;
  background:rgba(119,135,185,.22);
  margin-bottom:18px;
}
.about-v2-grid{
  display:grid;
  grid-template-columns:minmax(560px, 1.15fr) 180px minmax(540px, 600px);
  gap:26px;
  align-items:center;
}
.about-v2-copy{
  padding:6px 0 8px;
}
.about-v2-copy h1{
  margin:0;
  color:#0f2b72;
  font-family:'Fraunces', Georgia, serif;
  font-size:84px;
  line-height:.94;
  letter-spacing:-.045em;
  font-weight:500;
}
.about-v2-copy h1 span{
  color:#7b6df1;
}
.about-v2-accent{
  width:58px;
  height:3px;
  border-radius:999px;
  background:#8d7af5;
  margin:18px 0 22px;
}
.about-v2-lead{
  max-width:560px;
  margin:0 0 26px;
  color:#34456f;
  font-size:18px;
  line-height:1.72;
  font-weight:500;
}
.about-v2-text-block{
  max-width:650px;
}
.about-v2-text-block p{
  margin:0;
  color:#2f4160;
  font-size:16px;
  line-height:1.95;
}
.about-v2-hero .about-v2-text-block p{
  max-width:650px;
}
.about-v2-center-mark{
  align-self:stretch;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  min-height:420px;
}
.about-v2-divider{
  position:absolute;
  top:38px;
  bottom:38px;
  left:50%;
  width:1px;
  background:rgba(133,149,190,.24);
  transform:translateX(-50%);
}
.about-v2-center-mark img{
  width:176px;
  max-width:100%;
  position:relative;
  z-index:1;
  background:transparent;
  padding:0;
}
.about-v2-center-mark::before{
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
}
.about-v2-photo-wrap{
  display:flex;
  justify-content:flex-start;
  align-items:flex-start;
  padding-top:6px;
}
.about-v2-photo-card{
  width:min(100%, 560px);
  aspect-ratio:1 / 1;
  border-radius:30px;
  overflow:hidden;
  border:0;
  box-shadow:none;
  background:transparent;
}
.about-v2-photo-card img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  border:0;
  background:transparent;
}
.about-v2-cards{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
  padding:16px 0 18px;
}
.about-v2-card{
  min-height:100%;
  padding:16px 22px 18px;
  border-radius:18px;
  background:rgba(255,255,255,.9);
  border:1px solid rgba(208,218,238,.84);
  box-shadow:0 8px 24px rgba(27,51,110,.05);
  text-align:center;
}
.about-v2-card-icon{
  width:86px;
  height:86px;
  border-radius:50%;
  background:#f3f0ff;
  display:grid;
  place-items:center;
  margin:0 auto 16px;
}
.about-v2-card-icon img{
  width:58px;
  height:58px;
  object-fit:contain;
}
.about-v2-card h2{
  margin:0;
  color:#1f4fe4;
  font-size:18px;
  line-height:1.25;
  font-weight:700;
}
.about-v2-card-line{
  display:block;
  width:52px;
  height:3px;
  border-radius:999px;
  background:#8c78f4;
  margin:12px auto 16px;
  opacity:.85;
}
.about-v2-card p{
  margin:0;
  color:#33456d;
  font-size:14px;
  line-height:1.58;
}
.about-v2-commitment-strip{
  position:relative;
  display:grid;
  grid-template-columns:92px 1fr 92px;
  align-items:center;
  gap:18px;
  margin-top:10px;
  padding:14px 20px;
  border-radius:18px;
  background:#f4f1fb url('assets/about-banner-bg-final.png') center center / cover no-repeat;
  border:1px solid rgba(222,225,244,.96);
  overflow:hidden;
}
.about-v2-strip-icon{
  width:74px;
  height:74px;
  display:grid;
  place-items:center;
  justify-self:center;
  background:transparent;
  box-shadow:none;
}
.about-v2-strip-icon img{
  width:74px;
  height:74px;
  object-fit:contain;
  display:block;
}
.about-v2-commitment-strip p{
  margin:0;
  color:#31415d;
  font-size:15px;
  line-height:1.6;
  text-align:center;
  position:relative;
  z-index:1;
}
.about-v2-strip-leaf{
  display:none;
}

@media (max-width: 1220px){
  .about-v2-grid{
    grid-template-columns:1fr;
    gap:22px;
  }
  .about-v2-center-mark{
    min-height:110px;
  }
  .about-v2-divider{
    top:50%;
    left:0;
    right:0;
    bottom:auto;
    width:auto;
    height:1px;
    transform:none;
  }
  .about-v2-center-mark img{
    width:140px;
  }
  .about-v2-photo-wrap{
    justify-content:center;
  }
  .about-v2-cards{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media (max-width: 820px){
  .about-v2-shell{
    width:min(100% - 32px, 1280px);
  }
  .about-v2-copy h1{
    font-size:58px;
  }
  .about-v2-lead{
    font-size:17px;
  }
  .about-v2-cards{
    grid-template-columns:1fr;
  }
  .about-v2-commitment-strip{
    grid-template-columns:1fr;
    text-align:center;
  }
  .about-v2-strip-leaf{
    display:none;
  }
}
@media (max-width: 560px){
  .about-v2-copy h1{
    font-size:46px;
  }
  .about-v2-text-block p,
  .about-v2-card p,
  .about-v2-commitment-strip p{
    font-size:14px;
  }
  .about-v2-card{
    padding:18px;
  }
  .about-v2-photo-card{
    border-radius:24px;
  }
}


/* About cards: transparent generated icons */
.about-v2-card-icon{
  overflow:hidden;
}
.about-v2-card-icon img{
  mix-blend-mode:normal;
  background:transparent!important;
  display:block;
}


/* Navbar/footer unified across all pages */
.site-header .main-nav a.active{color:var(--blue);}
.site-header .main-nav a.active::after{content:"";position:absolute;left:0;right:0;bottom:3px;height:2px;border-radius:10px;background:var(--blue);}
.about-v2-body .main-nav a.active::after{bottom:3px;}
.about-v2-strip-icon,
.about-v2-strip-icon img{background:transparent!important;box-shadow:none!important;border:0!important;}
.about-v2-strip-icon img{display:block;object-fit:contain;}


/* =====================================
   Reorganización por páginas según sitio original
===================================== */
.main-nav a.active{color:var(--blue)}
.home-directory{padding:44px 0 30px;background:linear-gradient(180deg,#fff 0%,#fbfdff 100%)}
.home-directory-head{text-align:center;max-width:760px;margin:0 auto 24px}
.home-directory-head h2{font-size:34px;color:var(--deep);margin:6px 0 10px}
.home-directory-head p{font-size:16px;margin:0;color:#405171}
.home-directory-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}
.home-link-card{background:rgba(255,255,255,.92);border:1px solid rgba(207,219,238,.92);border-radius:20px;padding:26px 24px;min-height:230px;box-shadow:0 18px 40px rgba(16,42,97,.055);display:flex;flex-direction:column;align-items:flex-start;transition:transform .2s ease, box-shadow .2s ease}
.home-link-card:hover{transform:translateY(-3px);box-shadow:0 22px 46px rgba(16,42,97,.09)}
.home-card-icon{width:74px;height:74px;border-radius:22px;display:grid;place-items:center;margin-bottom:16px}
.home-card-icon img{width:46px;height:46px;object-fit:contain}
.home-link-card h3{font-size:20px;color:var(--blue);margin:0 0 8px}
.home-link-card p{font-size:14px;color:#405171;margin:0 0 18px;line-height:1.55}
.home-link-card a{margin-top:auto;color:var(--blue);font-weight:850;font-size:14px;display:inline-flex;gap:8px;align-items:center}
.home-contact-strip{padding:10px 0 34px}.home-contact-card{display:flex;justify-content:space-between;gap:28px;align-items:center;padding:28px 32px;border:1px solid rgba(207,219,238,.92);border-radius:22px;background:linear-gradient(135deg,#f8f7ff,#ffffff 55%,#eef7fb);box-shadow:0 14px 36px rgba(16,42,97,.055)}
.home-contact-card h2{font-size:28px;color:var(--deep)}.home-contact-card p{margin:0;font-size:15px;color:#405171}
.resources-page-main{background:#fff}.resources-page-hero{position:relative;overflow:hidden;padding:54px 0 18px;background:linear-gradient(180deg,#fff,#fbfdff)}
.resources-page-hero:after{content:"";position:absolute;right:-70px;top:-140px;width:420px;height:320px;border-radius:50%;background:rgba(112,119,235,.08);pointer-events:none}
.resources-page-hero h1{font-size:clamp(46px,5vw,74px);line-height:1;color:var(--deep);letter-spacing:-.06em;margin:6px 0 12px}.resources-page-hero p{font-size:18px;max-width:750px;color:#405171;margin:0;line-height:1.6}
.resources-page-main .resources-redesign{padding-top:24px}.resources-page-main .myths-faq{padding-top:20px}
.contact-page-section{padding:44px 0 64px;background:linear-gradient(180deg,#fff,#fbfdff)}.contact-page-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:24px;align-items:stretch}
.contact-copy,.contact-form{padding:34px;border-radius:22px}.contact-copy h1{font-size:clamp(42px,4.4vw,68px);line-height:1;color:var(--deep);letter-spacing:-.055em;margin:5px 0 16px}.contact-copy p{font-size:16px;color:#405171;line-height:1.7}.contact-direct-list{display:grid;gap:12px;margin-top:24px}.contact-direct-list a{display:flex;align-items:center;gap:12px;padding:13px 16px;border:1px solid var(--line);border-radius:999px;background:#fff;color:var(--blue);font-weight:850}.contact-direct-list img{width:24px;height:24px;object-fit:contain}.contact-form{display:grid;gap:16px;background:#fff}.contact-form label{display:grid;gap:8px;color:var(--deep);font-weight:800;font-size:14px}.contact-form input,.contact-form select,.contact-form textarea{width:100%;border:1px solid rgba(207,219,238,.95);border-radius:14px;padding:14px 16px;font:inherit;color:#314467;background:#fbfdff;outline:none}.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{border-color:rgba(22,87,194,.55);box-shadow:0 0 0 4px rgba(22,87,194,.08)}.contact-form button{justify-content:center;border:0;cursor:pointer}
@media(max-width:1100px){.home-directory-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.contact-page-grid{grid-template-columns:1fr}}
@media(max-width:720px){.home-directory-grid{grid-template-columns:1fr}.home-contact-card{display:grid}.home-contact-card .btn{width:100%}.home-link-card{min-height:auto}.resources-page-hero{padding:34px 0 12px}.contact-copy,.contact-form{padding:24px}}


/* === Carrusel principal agregado sin modificar navbar ni footer === */
.hero-carousel-only{
  position:relative;
  overflow:hidden;
}
.hero-carousel{
  position:relative;
  overflow:hidden;
}
.hero-carousel-viewport{
  overflow:hidden;
}
.hero-carousel-track{
  display:flex;
  align-items:stretch;
  transition:transform .7s cubic-bezier(.22,.61,.36,1);
  will-change:transform;
}
.hero-carousel-slide{
  min-width:100%;
  position:relative;
}
.hero-carousel-slide .hero-inner{
  min-height:610px;
}
.hero-banner-slide{
  min-height:610px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:44px 0 42px;
}
.hero-banner-frame{
  position:relative;
  display:block;
  width:100%;
  min-height:520px;
  border-radius:28px;
  overflow:hidden;
  border:1px solid rgba(220,231,244,.8);
  box-shadow:0 16px 42px rgba(16,42,97,.10);
  background:#fff;
}
.hero-banner-frame img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
}
.hero-banner-frame-mission img{
  object-position:center center;
}
.hero-banner-frame-podcast img{
  object-position:center center;
}
.hero-banner-frame-podcast::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(30,54,92,.52) 0%,rgba(30,54,92,.25) 32%,rgba(30,54,92,0) 62%);
  pointer-events:none;
}
.hero-podcast-overlay{
  position:absolute;
  left:46px;
  bottom:46px;
  z-index:2;
  color:#fff;
  max-width:460px;
}
.hero-podcast-overlay span{
  display:block;
  color:#dbc0ef;
  font-size:18px;
  font-weight:800;
  margin-bottom:10px;
}
.hero-podcast-overlay h2{
  color:#fff;
  font-size:clamp(34px,3.6vw,48px);
  line-height:1.08;
  letter-spacing:-.045em;
  margin:0 0 18px;
}
.hero-podcast-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  min-height:58px;
  padding:0 20px;
  border-radius:16px;
  background:#fff;
  color:#20355f;
  font-weight:850;
  font-size:16px;
  box-shadow:0 14px 26px rgba(16,42,97,.12);
}
.hero-podcast-icon{
  color:#9b7fcf!important;
  font-size:22px!important;
  margin:0!important;
}
.hero-podcast-button strong{
  font-size:25px;
  line-height:1;
  color:#20355f;
}
.hero-carousel-arrow{
  position:absolute;
  z-index:5;
  top:50%;
  transform:translateY(-50%);
  width:54px;
  height:54px;
  border-radius:50%;
  border:1px solid rgba(220,231,244,.9);
  background:rgba(255,255,255,.94);
  color:var(--deep);
  font-size:34px;
  line-height:1;
  cursor:pointer;
  display:grid;
  place-items:center;
  box-shadow:0 10px 24px rgba(16,42,97,.10);
}
.hero-carousel-arrow-prev{left:28px}
.hero-carousel-arrow-next{right:28px}
.hero-carousel-dots{
  position:absolute;
  left:50%;
  bottom:34px;
  transform:translateX(-50%);
  z-index:6;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
}
.hero-carousel-dots button{
  width:11px;
  height:11px;
  border-radius:50%;
  border:0;
  padding:0;
  background:rgba(255,255,255,.72);
  cursor:pointer;
  box-shadow:0 0 0 1px rgba(16,42,97,.08);
}
.hero-carousel-dots button.is-active{
  background:#c9b2ec;
  box-shadow:0 0 0 3px rgba(255,255,255,.24);
}
@media(max-width:1100px){
  .hero-carousel-slide .hero-inner{
    min-height:unset;
  }
  .hero-banner-slide{
    min-height:auto;
    padding:32px 0;
  }
  .hero-banner-frame{
    min-height:430px;
  }
}
@media(max-width:720px){
  .hero-banner-slide{
    padding:24px 0;
  }
  .hero-banner-frame{
    min-height:470px;
    border-radius:22px;
  }
  .hero-banner-frame-mission img{
    object-position:center center;
  }
  .hero-podcast-overlay{
    left:22px;
    right:22px;
    bottom:24px;
    max-width:none;
  }
  .hero-podcast-overlay h2{
    font-size:30px;
  }
  .hero-podcast-button{
    width:100%;
  }
  .hero-carousel-arrow{
    width:44px;
    height:44px;
    font-size:28px;
  }
  .hero-carousel-arrow-prev{left:14px}
  .hero-carousel-arrow-next{right:14px}
  .hero-carousel-dots{
    bottom:26px;
  }
}


/* Ajuste: banners del carrusel a todo el ancho */
.hero-banner-slide-fullwidth{
  width:100%;
  max-width:none;
  padding:0;
}
.hero-banner-slide-fullwidth .hero-banner-frame{
  width:100%;
  min-height:640px;
  border-radius:0;
  border:0;
  box-shadow:none;
}
.hero-banner-slide-fullwidth.hero-banner-slide-mission .hero-banner-frame img,
.hero-banner-slide-fullwidth.hero-banner-slide-podcast .hero-banner-frame img{
  object-fit:cover;
  width:100%;
  height:100%;
}
.hero-banner-slide-fullwidth.hero-banner-slide-mission .hero-banner-frame img{
  object-position:center center;
}
@media(max-width:1100px){
  .hero-banner-slide-fullwidth .hero-banner-frame{min-height:520px}
}
@media(max-width:720px){
  .hero-banner-slide-fullwidth .hero-banner-frame{
    min-height:420px;
    border-radius:0;
  }
  .hero-banner-slide-fullwidth .hero-podcast-overlay{left:18px;right:18px;bottom:18px}
}


/* Carrusel con imágenes entregadas por el usuario */
.hero-banner-frame-main,
.hero-banner-frame-mission,
.hero-banner-frame-podcast{
  width:100%;
  min-height:640px;
  overflow:hidden;
}
.hero-banner-frame-main picture,
.hero-banner-frame-mission picture{
  display:block;
  width:100%;
  height:100%;
}
.hero-banner-frame-main img,
.hero-banner-frame-main picture img,
.hero-banner-frame-mission img,
.hero-banner-frame-mission picture img,
.hero-banner-frame-podcast img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
}
.hero-banner-frame-main img{object-position:center center;}
.hero-banner-frame-mission img{object-position:center center;}
.hero-banner-frame-podcast img{object-position:center center;}
.hero-banner-frame-podcast{position:relative;}
.hero-banner-slide-podcast .hero-podcast-overlay{
  position:absolute;
  left:4.5%;
  bottom:8%;
  max-width:360px;
  padding:0;
}
.hero-banner-slide-podcast .hero-podcast-overlay span{
  color:#eab7d2;
  font-size:1.15rem;
  font-weight:700;
}
.hero-banner-slide-podcast .hero-podcast-overlay h2{
  color:#fff;
  font-size:2.1rem;
  line-height:1.1;
  margin:.8rem 0 1.35rem;
}
.hero-podcast-button{
  background:#fff;
  color:#1a2f77;
  border-radius:20px;
  padding:1rem 1.25rem;
  display:inline-flex;
  align-items:center;
  gap:.75rem;
  font-weight:700;
  box-shadow:0 8px 24px rgba(0,0,0,.12);
}
.hero-podcast-icon{font-size:1.35rem;}
.hero-banner-slide-fullwidth .hero-banner-frame{border-radius:0;box-shadow:none;border:0;}
@media (max-width: 720px){
  .hero-banner-frame-main,
  .hero-banner-frame-mission,
  .hero-banner-frame-podcast{min-height:500px;}
  .hero-banner-frame-main img{object-fit:cover; object-position:center center;}
  .hero-banner-frame-mission img{object-fit:cover; object-position:center center;}
  .hero-banner-frame-podcast img{object-fit:cover; object-position:center center;}
  .hero-banner-slide-podcast .hero-podcast-overlay{
    left:20px;
    right:20px;
    bottom:22px;
    max-width:none;
  }
  .hero-banner-slide-podcast .hero-podcast-overlay h2{font-size:1.55rem;}
  .hero-podcast-button{padding:.9rem 1rem; border-radius:18px;}
}


/* Navbar restored from espacio_toc_site_hero_modificado style */
.site-header{
  position:sticky;
  top:0;
  z-index:80;
  background:rgba(255,253,249,.88);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(223,232,244,.75);
}
.header-inner{
  height:86px;
  display:flex;
  align-items:center;
  gap:24px;
}
.brand img{
  width:134px;
  height:62px;
  object-fit:contain;
  object-position:left center;
}
.main-nav{
  display:flex;
  gap:18px;
  align-items:center;
  margin-left:auto;
  font-size:13px;
  font-weight:650;
  color:#334366;
}
.main-nav a{
  position:relative;
  padding:10px 0;
  white-space:nowrap;
  font-size:13px;
  font-weight:650;
  color:#334366;
}
.main-nav a.active,
.main-nav a:hover{
  color:var(--blue);
}
.main-nav a.active::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:3px;
  height:2px;
  background:var(--blue);
  border-radius:10px;
}
.header-actions{
  display:flex;
  gap:10px;
  margin-left:4px;
  align-items:center;
}
.btn-outline{
  background:#fff;
  color:var(--blue);
  border-color:#aac2e5;
}
.nav-toggle{
  display:none;
  background:none;
  border:0;
  width:42px;
  height:42px;
  margin-left:auto;
  padding:0;
  cursor:pointer;
}
.nav-toggle span{
  display:block;
  height:2px;
  background:var(--deep);
  margin:7px 5px;
  border-radius:4px;
}

/* hide newer navbar wrappers if any remained */
.nav-wrap{height:86px}
.menu-btn{display:none!important}
.nav-actions{display:none!important}

/* Internal-page active underline compatibility */
.courses-page-body .main-nav a.active::after,
.staff-page-body .main-nav a.active::after,
.about-page-body .main-nav a.active::after{
  bottom:3px;
  height:2px;
}

@media(max-width:1180px){
  .main-nav{gap:13px;font-size:12px}
  .main-nav a{font-size:12px}
  .header-actions .btn{padding:11px 13px;font-size:13px}
  .brand img{width:126px}
}
@media(max-width:980px){
  .header-inner{
    height:78px;
    gap:12px;
  }
  .brand img{
    width:126px;
    height:58px;
  }
  .nav-toggle{
    display:block;
    order:3;
  }
  .main-nav{
    display:none;
    position:absolute;
    top:78px;
    left:20px;
    right:20px;
    flex-direction:column;
    align-items:stretch;
    gap:0;
    margin-left:0;
    padding:10px;
    background:#fff;
    border:1px solid var(--line);
    border-radius:18px;
    box-shadow:var(--shadow);
  }
  .main-nav.open{
    display:flex;
  }
  .main-nav a{
    padding:13px 14px;
    border-radius:12px;
    font-size:14px;
  }
  .main-nav a.active::after{
    display:none;
  }
  .main-nav a.active,
  .main-nav a:hover{
    background:#f7faff;
  }
  .header-actions{
    margin-left:auto;
  }
  .header-actions .btn-outline{
    display:none;
  }
}
@media(max-width:640px){
  .container{width:min(100% - 28px,1200px)}
  .header-inner{height:74px}
  .brand img{width:118px;height:54px}
  .main-nav{top:74px;left:14px;right:14px}
  .header-actions .btn-primary{
    padding:10px 12px;
    font-size:12px;
  }
}


/* Final fix: navbar active underline aligned like hero_modificado */
.site-header .main-nav a.active::after,
body .site-header .main-nav a.active::after,
.courses-page-body .site-header .main-nav a.active::after,
.staff-page-body .site-header .main-nav a.active::after,
.about-page-body .site-header .main-nav a.active::after,
.about-v2-body .site-header .main-nav a.active::after,
.contact-page-body .site-header .main-nav a.active::after,
.resources-page-body .site-header .main-nav a.active::after{
  content:"" !important;
  position:absolute !important;
  left:0 !important;
  right:0 !important;
  bottom:3px !important;
  height:2px !important;
  background:var(--blue) !important;
  border-radius:10px !important;
  display:block;
}

@media(max-width:980px){
  .site-header .main-nav a.active::after,
  body .site-header .main-nav a.active::after{
    display:none !important;
  }
}



/* Third carousel image responsive sizing */
.hero-banner-frame-podcast picture{
  display:block;
  width:100%;
  height:100%;
}
.hero-banner-frame-podcast picture img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center center;
}



/* Mission slide recreated to match reference */
.hero-banner-frame-mission-generated{
  position:relative;
  background-image:url('assets/home-mission-slide-bg.png');
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:640px;
}
.hero-banner-frame-mission-generated::before{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(255,255,255,.02);
}
.hero-banner-frame-mission-generated .hero-mission-content{
  position:relative;
  z-index:1;
  width:min(100% - 60px, 1160px);
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  margin-top:-10px;
}
.hero-banner-frame-mission-generated .hero-mission-logo{
  position:relative !important;
  inset:auto !important;
  left:auto !important;
  top:auto !important;
  right:auto !important;
  bottom:auto !important;
  width:min(23vw, 300px) !important;
  min-width:210px;
  height:auto !important;
  max-height:none !important;
  flex:0 0 auto;
  display:block;
  object-fit:contain !important;
  object-position:center center !important;
  margin:0 auto 38px;
  filter:drop-shadow(0 3px 8px rgba(36,86,214,.04));
  z-index:1;
}
.hero-banner-frame-mission-generated .hero-mission-title{
  margin:0;
  font-family:'Playfair Display', Georgia, serif;
  font-size:clamp(48px, 5vw, 86px);
  line-height:1.06;
  letter-spacing:-.035em;
  color:#2857d7;
  font-weight:700;
}
.hero-banner-frame-mission-generated .hero-mission-text{
  margin:24px 0 0;
  font-family:Inter, system-ui, sans-serif;
  font-size:clamp(18px, 1.6vw, 26px);
  line-height:1.35;
  color:#2f63df;
  font-weight:500;
  max-width:1120px;
}
.hero-banner-frame-mission-generated .hero-mission-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-top:56px;
  min-width:356px;
  min-height:114px;
  padding:0 42px;
  border-radius:24px;
  background:linear-gradient(180deg,#ff5f88 0%, #ff4f7f 52%, #ff4a78 100%);
  color:#ffffff;
  font-family:Inter, system-ui, sans-serif;
  font-size:clamp(30px, 2.4vw, 36px);
  font-weight:850;
  box-shadow:0 16px 34px rgba(255, 97, 136, .28), 0 8px 16px rgba(255,97,136,.18);
}
.hero-banner-frame-mission-generated:hover .hero-mission-button{
  transform:translateY(-1px);
}

@media (max-width: 1200px){
  .hero-banner-frame-mission-generated .hero-mission-logo{margin-bottom:28px;}
  .hero-banner-frame-mission-generated .hero-mission-text{max-width:900px;}
}

@media (max-width: 720px){
  .hero-banner-frame-mission-generated{
    min-height:500px;
    background-position:center center;
  }
  .hero-banner-frame-mission-generated .hero-mission-content{
    width:min(100% - 32px, 680px);
    margin-top:-4px;
  }
  .hero-banner-frame-mission-generated .hero-mission-logo{
    width:min(52vw, 250px) !important;
    min-width:180px;
    height:auto !important;
    max-height:none !important;
    margin-bottom:24px;
  }
  .hero-banner-frame-mission-generated .hero-mission-title{
    font-size:clamp(31px, 9vw, 52px);
    line-height:1.08;
    max-width:95%;
  }
  .hero-banner-frame-mission-generated .hero-mission-text{
    margin-top:16px;
    font-size:clamp(16px, 4.2vw, 21px);
    line-height:1.35;
    max-width:92%;
  }
  .hero-banner-frame-mission-generated .hero-mission-button{
    margin-top:34px;
    min-width:245px;
    min-height:74px;
    padding:0 26px;
    border-radius:18px;
    font-size:clamp(21px, 5.7vw, 28px);
    box-shadow:0 14px 26px rgba(255,97,136,.25), 0 6px 14px rgba(255,97,136,.14);
  }
}


/* Hero contenido del primer carrusel con información del hero antiguo */
.hero-banner-frame-main{
  position:relative;
}
.hero-banner-frame-main::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(255,255,255,.88) 0%, rgba(255,255,255,.80) 34%, rgba(255,255,255,.25) 56%, rgba(255,255,255,0) 72%);
  pointer-events:none;
}
.hero-main-overlay{
  position:absolute;
  inset:0;
  z-index:2;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  pointer-events:none;
}
.hero-main-content{
  width:min(46vw, 620px);
  margin-left:clamp(44px, 5.5vw, 104px);
  margin-right:24px;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  pointer-events:auto;
}
.hero-main-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin:0 0 16px;
  padding:12px 18px;
  border-radius:999px;
  background:rgba(255,255,255,.82);
  border:1px solid rgba(188,205,233,.72);
  box-shadow:0 10px 26px rgba(16,42,97,.06);
  color:#50617f;
  font-size:12px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.hero-main-title{
  margin:0 0 18px;
  color:var(--deep);
  font-size:clamp(48px, 4.8vw, 76px);
  line-height:.98;
  letter-spacing:-.065em;
  max-width:700px;
}
.hero-main-text{
  margin:0 0 28px;
  color:#384867;
  font-size:18px;
  line-height:1.58;
  max-width:590px;
}
.hero-main-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-bottom:26px;
}
.hero-main-actions .btn{
  min-height:58px;
  padding:15px 22px;
  border-radius:14px;
  font-size:15px;
  box-shadow:0 14px 28px rgba(16,42,97,.10);
}
.hero-main-actions .btn-outline{
  background:rgba(255,255,255,.88);
}
.hero-main-btn .btn-icon{
  width:20px;
  height:20px;
}
.hero-main-trust{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, max-content));
  gap:14px;
}
.hero-main-trust-item{
  display:flex;
  align-items:center;
  gap:12px;
  padding:10px 14px;
  border-radius:16px;
  background:rgba(255,255,255,.76);
  border:1px solid rgba(205,218,239,.72);
  box-shadow:0 8px 20px rgba(16,42,97,.05);
}
.hero-main-trust-item span{
  color:#3a4a63;
  font-size:13px;
  font-weight:800;
  line-height:1.25;
}
.hero-main-trust-item .trust-icon{
  width:36px;
  height:36px;
}
@media(max-width:1400px){
  .hero-main-content{width:min(48vw, 580px); margin-left:clamp(32px, 4vw, 64px)}
  .hero-main-title{font-size:clamp(42px, 4.4vw, 66px)}
}
@media(max-width:1180px){
  .hero-banner-slide-fullwidth .hero-banner-frame.hero-banner-frame-main{min-height:700px;}
  .hero-banner-frame-main::after{background:linear-gradient(90deg, rgba(255,255,255,.92) 0%, rgba(255,255,255,.88) 45%, rgba(255,255,255,.42) 66%, rgba(255,255,255,.05) 82%)}
  .hero-main-content{width:min(54vw, 540px); margin-left:32px;}
  .hero-main-title{font-size:clamp(38px, 4.6vw, 58px)}
  .hero-main-text{font-size:17px}
  .hero-main-trust{grid-template-columns:1fr;max-width:360px}
}
@media(max-width:720px){
  .hero-banner-slide-fullwidth .hero-banner-frame.hero-banner-frame-main{min-height:1020px;}
  .hero-banner-frame-main::after{background:linear-gradient(180deg, rgba(255,255,255,.96) 0%, rgba(255,255,255,.93) 30%, rgba(255,255,255,.66) 54%, rgba(255,255,255,.18) 74%, rgba(255,255,255,0) 100%)}
  .hero-main-overlay{align-items:flex-start;}
  .hero-main-content{
    width:auto;
    margin:24px 18px 0;
    padding:18px 18px 16px;
    border-radius:24px;
    background:rgba(255,255,255,.72);
    border:1px solid rgba(214,225,242,.88);
    backdrop-filter:blur(10px);
    box-shadow:0 18px 34px rgba(16,42,97,.08);
  }
  .hero-main-eyebrow{
    margin-bottom:12px;
    padding:9px 14px;
    font-size:11px;
    letter-spacing:.11em;
  }
  .hero-main-title{
    font-size:clamp(33px, 9.2vw, 52px);
    line-height:1.02;
    margin-bottom:14px;
    max-width:none;
  }
  .hero-main-text{
    font-size:15px;
    line-height:1.48;
    margin-bottom:18px;
    max-width:none;
  }
  .hero-main-actions{
    width:100%;
    flex-direction:column;
    gap:12px;
    margin-bottom:16px;
  }
  .hero-main-actions .btn{
    width:100%;
    min-height:54px;
    padding:14px 18px;
    font-size:14px;
  }
  .hero-main-trust{
    grid-template-columns:1fr;
    gap:10px;
    max-width:none;
  }
  .hero-main-trust-item{
    width:100%;
    padding:10px 12px;
  }
  .hero-main-trust-item span{font-size:12px}
  .hero-main-trust-item .trust-icon{width:32px;height:32px}
}


/* ===== Recursos gratuitos: banner educativo tratamiento ===== */
.treatment-banner{padding-top:18px;padding-bottom:22px}
.treatment-banner-shell{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr);align-items:center;gap:34px;padding:38px 36px;background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(251,252,255,.98));border-radius:34px;box-shadow:0 22px 56px rgba(39,67,120,.08);overflow:hidden;position:relative}
.treatment-banner-shell:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 74% 24%,rgba(232,239,252,.72),transparent 16%),radial-gradient(circle at 90% 80%,rgba(248,237,225,.58),transparent 14%),radial-gradient(circle at 8% 80%,rgba(233,240,252,.45),transparent 14%);pointer-events:none}
.treatment-banner-copy,.treatment-banner-visual{position:relative;z-index:1}
.treatment-banner-title h2{font-size:clamp(34px,3.2vw,48px);letter-spacing:-.045em;margin-bottom:10px;color:#173a8a}
.treatment-banner-title p{font-size:17px;max-width:680px;color:#536480;line-height:1.55}
.treatment-cards-banner{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
.mini-card-banner{min-height:250px;padding:22px 18px 20px;border-radius:22px;border:1px solid rgba(189,204,230,.65);box-shadow:0 10px 28px rgba(35,65,123,.05);background:rgba(255,255,255,.96);display:flex;flex-direction:column;align-items:center;justify-content:flex-start;text-align:center}
.mini-card-banner .mini-icon-wrap{width:82px;height:82px;border-radius:24px;margin:0 auto 16px;background:linear-gradient(180deg,rgba(241,245,254,.95),rgba(247,249,255,.9))}
.mini-card-banner .mini-icon-wrap.sky{background:linear-gradient(180deg,rgba(239,248,254,.98),rgba(247,252,255,.95))}
.mini-card-banner .mini-icon-wrap.mint{background:linear-gradient(180deg,rgba(239,251,248,.95),rgba(247,252,250,.95))}
.mini-card-banner .mini-icon-wrap.beige{background:linear-gradient(180deg,rgba(252,247,239,.96),rgba(255,251,246,.95))}
.mini-card-banner .mini-icon{width:50px;height:50px}
.mini-card-banner h3{font-size:13px;line-height:1.32;color:#1e3f8e;margin:0 0 10px;max-width:160px}
.mini-card-banner p{font-size:11.6px;line-height:1.55;color:#5d6d89;margin:0}
.treatment-banner-visual{min-height:390px;display:flex;align-items:center;justify-content:center;padding:0;overflow:visible;border:none;background:none;border-radius:0;box-shadow:none}
.treatment-banner-visual picture{display:block;width:100%}.treatment-banner-visual img{width:100%;height:auto;max-width:760px;object-fit:contain;object-position:center center;display:block;position:relative;z-index:2;filter:none}
.treatment-visual-orb{position:absolute;border-radius:50%;pointer-events:none}
.treatment-visual-orb-one{width:320px;height:320px;right:10px;top:18px;background:rgba(233,239,250,.88)}
.treatment-visual-orb-two{width:188px;height:188px;right:-50px;bottom:-16px;background:rgba(244,232,220,.78)}
.treatment-visual-orb-three{width:120px;height:120px;left:8px;bottom:10px;background:rgba(236,243,252,.8)}
.treatment-dots{position:absolute;width:82px;height:82px;opacity:.55;background-image:radial-gradient(circle,#9fb9e8 2px,transparent 2.5px);background-size:18px 18px;background-repeat:repeat}
.treatment-dots-left{left:18px;top:42px}
.treatment-dots-right{right:26px;top:26px}
@media (max-width: 1200px){.treatment-banner-shell{grid-template-columns:1fr;gap:24px;padding:32px 28px}.treatment-cards-banner{grid-template-columns:repeat(2,minmax(0,1fr))}.treatment-banner-visual{min-height:320px}}
@media (max-width: 720px){.treatment-banner-shell{padding:24px 18px;border-radius:26px;gap:18px}.treatment-banner-title h2{font-size:30px}.treatment-banner-title p{font-size:15px}.treatment-cards-banner{grid-template-columns:1fr;gap:14px}.mini-card-banner{min-height:auto;padding:20px 16px;border-radius:18px}.mini-card-banner .mini-icon-wrap{width:74px;height:74px;border-radius:20px}.mini-card-banner .mini-icon{width:44px;height:44px}.treatment-banner-visual{min-height:auto;padding-top:6px}.treatment-banner-visual img{max-width:430px}.treatment-visual-orb-one{width:220px;height:220px;right:-8px;top:18px}.treatment-visual-orb-two{width:130px;height:130px;right:-26px;bottom:-14px}.treatment-visual-orb-three{width:76px;height:76px;left:0;bottom:8px}.treatment-dots{width:64px;height:64px;background-size:16px 16px}}


/* Ajuste final: cards con ancho medio en banner educativo de recursos */
.treatment-banner .container{
  width:min(100% - 42px, 1380px);
}
.treatment-banner-shell{
  grid-template-columns:minmax(760px, 1.05fr) minmax(410px, .95fr);
  gap:28px;
  padding:38px 34px;
}
.treatment-cards-banner{
  grid-template-columns:repeat(4, minmax(165px, 1fr));
  gap:16px;
}
.mini-card-banner{
  min-height:258px;
  padding:23px 18px 21px;
}
.mini-card-banner h3{
  max-width:165px;
  font-size:13.5px;
  line-height:1.32;
}
.mini-card-banner p{
  font-size:11.7px;
  line-height:1.55;
}
.treatment-banner-visual img{
  max-width:720px;
}

@media(max-width:1320px){
  .treatment-banner .container{
    width:min(100% - 36px, 1240px);
  }
  .treatment-banner-shell{
    grid-template-columns:minmax(700px, 1fr) minmax(360px, .82fr);
    gap:22px;
    padding:34px 28px;
  }
  .treatment-cards-banner{
    grid-template-columns:repeat(4, minmax(150px, 1fr));
    gap:14px;
  }
  .mini-card-banner{
    padding:21px 15px 19px;
  }
}
@media(max-width:1180px){
  .treatment-banner .container{
    width:min(100% - 36px, 1040px);
  }
  .treatment-banner-shell{
    grid-template-columns:1fr;
  }
  .treatment-cards-banner{
    grid-template-columns:repeat(2, minmax(240px, 1fr));
    gap:16px;
  }
  .mini-card-banner{
    min-height:220px;
  }
}
@media(max-width:720px){
  .treatment-banner .container{
    width:min(100% - 28px, 1200px);
  }
  .treatment-cards-banner{
    grid-template-columns:1fr;
  }
  .mini-card-banner{
    min-height:auto;
    padding:22px 20px;
  }
}


/* Página separada: Tratamiento */
.treatment-page-main{
  background:linear-gradient(180deg,#fffdf9 0%,#f7faff 45%,#fffdf9 100%);
}
.treatment-page-hero{
  padding:54px 0 16px;
  text-align:center;
}
.treatment-page-hero h1{
  margin:8px auto 14px;
  max-width:920px;
  color:var(--blue);
  font-size:clamp(44px,5vw,78px);
  line-height:.98;
  letter-spacing:-.06em;
}
.treatment-page-hero p{
  max-width:850px;
  margin:0 auto;
  font-size:18px;
  color:#52617c;
}
.treatment-page-main .treatment-banner{
  padding-top:20px;
}
.treatment-page-main .treatment-banner .container{
  width:min(100% - 42px, 1380px);
}
.treatment-next-step{
  padding-top:14px;
}
.treatment-next-card{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:28px;
  padding:32px;
  border-radius:26px;
}
.treatment-next-card h2{
  font-size:32px;
  margin-bottom:8px;
}
.treatment-next-card p{
  margin:0;
  max-width:720px;
}
.treatment-next-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
@media(max-width:1180px){
  .main-nav{
    gap:10px;
  }
  .main-nav a{
    font-size:11.5px;
  }
  .header-actions .btn{
    padding:10px 11px;
    font-size:12px;
  }
}
@media(max-width:980px){
  .main-nav a{
    font-size:14px;
  }
}
@media(max-width:720px){
  .treatment-page-hero{
    padding:36px 0 8px;
  }
  .treatment-page-hero p{
    font-size:15px;
  }
  .treatment-next-card{
    flex-direction:column;
    align-items:flex-start;
    padding:24px;
  }
  .treatment-next-actions,
  .treatment-next-actions .btn{
    width:100%;
  }
}


/* Recursos gratuitos: layout más limpio, sin sensación de cuadros dentro de cuadros */
.resources-page-main .resources-redesign{
  padding-top:20px;
}
.resources-page-main .resources-shell{
  background:transparent !important;
  background-image:none !important;
  border:0 !important;
  box-shadow:none !important;
  padding:0 !important;
  border-radius:0 !important;
}
.resources-page-main .resources-topbar{
  padding:22px 24px 12px;
  margin:0;
  border:1px solid rgba(202,214,235,.72);
  border-bottom:0;
  border-radius:22px 22px 0 0;
  background:rgba(255,255,255,.9);
}
.resources-page-main .resources-topbar .eyebrow,
.resources-page-main .resources-topbar p{
  display:none;
}
.resources-page-main .resources-topbar h2{
  font-size:28px;
  margin:0;
  color:#173a8a;
}
.resources-page-main .resources-all-link{
  font-size:12px;
  color:#2456c6;
  font-weight:850;
}
.resources-page-main .resources-grid-v2{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:28px;
  padding:0 24px 24px !important;
  margin:0 0 0 !important;
  border:1px solid rgba(202,214,235,.72);
  border-top:0;
  border-radius:0 0 22px 22px;
  background:rgba(255,255,255,.9);
}
.resources-page-main .resource-card-v2{
  display:grid;
  grid-template-columns:94px 1fr;
  gap:20px;
  align-items:center;
  min-height:156px;
  padding:22px 22px;
  border:1px solid rgba(202,214,235,.7);
  border-radius:13px;
  background:rgba(255,255,255,.96);
  box-shadow:none;
}
.resources-page-main .resource-card-v2::before,
.resources-page-main .resource-card-v2::after{
  display:none !important;
}
.resources-page-main .resource-icon-box{
  width:82px;
  height:82px;
  border-radius:18px;
  margin:0;
}
.resources-page-main .resource-card-icon{
  width:58px;
  height:58px;
}
.resources-page-main .resource-card-body h3{
  font-size:16px;
  line-height:1.22;
  margin:0 0 8px;
  color:#173a8a;
}
.resources-page-main .resource-card-body p{
  font-size:12px;
  line-height:1.42;
  margin:0 0 8px;
}
.resources-page-main .resource-card-body small{
  display:block;
  font-size:11px;
  margin:0 0 12px;
}
.resources-page-main .resource-download-btn{
  width:100%;
  min-height:38px;
  padding:9px 12px;
  border-radius:7px;
  font-size:12px;
  justify-content:center;
  background:#f7f7ff;
  border:1px solid rgba(189,198,231,.9);
  box-shadow:none;
}
.resources-page-main .resource-download-btn .btn-icon{
  width:18px;
  height:18px;
  margin-left:auto;
}

/* Cursos limpios dentro de recursos, estilo similar a la referencia */
.resources-courses-clean{
  padding-top:6px;
  padding-bottom:20px;
}
.clean-section-panel{
  border:1px solid rgba(202,214,235,.72);
  border-radius:22px;
  background:rgba(255,255,255,.9);
  padding:22px 24px 24px;
}
.clean-section-head{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:18px;
  margin-bottom:16px;
}
.clean-section-head h2{
  font-size:28px;
  margin:0;
  color:#173a8a;
}
.clean-section-head a{
  font-size:12px;
  color:#2456c6;
  font-weight:850;
}
.clean-courses-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:28px;
}
.clean-course-card{
  display:grid;
  grid-template-columns:72px 1fr;
  gap:18px;
  align-items:flex-start;
  padding:22px 20px;
  min-height:168px;
  border:1px solid rgba(202,214,235,.7);
  border-radius:13px;
  background:rgba(255,255,255,.96);
}
.clean-course-icon{
  width:70px;
  height:70px;
  border-radius:14px;
  display:grid;
  place-items:center;
}
.clean-course-icon img{
  width:46px;
  height:46px;
  object-fit:contain;
}
.clean-course-card h3{
  margin:0 0 10px;
  color:#173a8a;
  font-size:15px;
  line-height:1.18;
}
.clean-course-card ul{
  margin:0 0 12px;
  padding-left:15px;
}
.clean-course-card li{
  color:#5d6d89;
  font-size:11.5px;
  line-height:1.45;
}
.clean-mini-btn{
  min-width:118px;
  height:36px;
  padding:0 14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:16px;
  border:1px solid rgba(189,198,231,.9);
  border-radius:7px;
  background:#fff;
  color:#173a8a;
  font-size:12px;
  font-weight:850;
}

@media(max-width:1180px){
  .resources-page-main .resources-grid-v2,
  .clean-courses-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:18px;
  }
}
@media(max-width:720px){
  .resources-page-main .resources-topbar,
  .resources-page-main .resources-grid-v2,
  .clean-section-panel{
    padding-left:16px !important;
    padding-right:16px !important;
  }
  .resources-page-main .resources-grid-v2,
  .clean-courses-grid{
    grid-template-columns:1fr;
  }
  .resources-page-main .resource-card-v2,
  .clean-course-card{
    grid-template-columns:70px 1fr;
    gap:14px;
    padding:18px 16px;
  }
  .resources-page-main .resource-icon-box{
    width:66px;
    height:66px;
  }
  .resources-page-main .resource-card-icon{
    width:46px;
    height:46px;
  }
}


/* Restauración sección Instagram educativa en Recursos */
.sabias-que-section-restored{
  padding-top:4px;
  padding-bottom:20px;
}
.clean-instagram-panel{
  border:1px solid rgba(202,214,235,.72);
  border-radius:22px;
  background:rgba(255,255,255,.9);
  padding:24px;
}
.clean-instagram-panel .sabias-que-block{
  display:block;
  margin:0;
}
.clean-instagram-panel .sabias-que-head{
  max-width:820px;
  margin:0 0 20px;
}
.clean-instagram-panel .sabias-que-head h3{
  font-size:28px;
  color:#173a8a;
  margin:0 0 8px;
}
.clean-instagram-panel .sabias-que-head p{
  font-size:14px;
  margin:0;
  color:#5d6d89;
}
.clean-instagram-panel .sabias-instagram-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
  margin:0;
}
.clean-instagram-panel .sabias-post-card{
  border:1px solid rgba(202,214,235,.72);
  border-radius:16px;
  background:#fff;
  overflow:hidden;
  min-height:320px;
}
@media(max-width:1180px){
  .clean-instagram-panel .sabias-instagram-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media(max-width:720px){
  .clean-instagram-panel{
    padding:18px 16px;
  }
  .clean-instagram-panel .sabias-instagram-grid{
    grid-template-columns:1fr;
  }
}



/* Ajuste visual: sección Sabías que más limpia y sin cuadros excesivos */
.clean-instagram-panel{
  border:1px solid rgba(202,214,235,.72);
  border-radius:22px;
  background:rgba(255,255,255,.92);
  padding:26px 28px;
  box-shadow:none;
}
.clean-instagram-panel .sabias-que-block{
  margin:0;
  padding:0;
  border:none;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  backdrop-filter:none;
}
.clean-instagram-panel .sabias-que-head{
  margin:0 0 22px;
}
.clean-instagram-panel .sabias-instagram-grid{
  gap:20px;
}
.clean-instagram-panel .sabias-post-card{
  border:none;
  border-radius:18px;
  background:transparent;
  box-shadow:none;
  padding:0;
  min-height:auto;
  overflow:hidden;
}
.clean-instagram-panel .sabias-post-card blockquote.instagram-media{
  border-radius:18px!important;
  overflow:hidden!important;
  background:#fff!important;
}
@media(max-width:720px){
  .clean-instagram-panel{padding:20px 16px;}
  .clean-instagram-panel .sabias-que-head{margin:0 0 18px;}
  .clean-instagram-panel .sabias-post-card blockquote.instagram-media{border-radius:16px!important;}
}


/* Fix definitivo: tamaños correctos para íconos del primer carrusel */
.hero-banner-frame-main > picture,
.hero-banner-frame-main > picture > img{
  display:block;
  width:100%;
  height:100%;
}
.hero-banner-frame-main > picture > img{
  object-fit:cover;
  object-position:center center;
}

/* Reseteo de posicionamiento, sin dejar width:auto para evitar íconos gigantes */
.hero-banner-frame-main .hero-main-overlay img{
  position:static !important;
  inset:auto !important;
  transform:none !important;
  object-fit:contain !important;
  object-position:center center !important;
}

/* Íconos de los botones */
.hero-banner-frame-main .hero-main-overlay .hero-main-btn img.btn-icon,
.hero-banner-frame-main .hero-main-overlay .hero-main-btn .btn-icon{
  width:20px !important;
  min-width:20px !important;
  max-width:20px !important;
  height:20px !important;
  min-height:20px !important;
  max-height:20px !important;
  flex:0 0 20px !important;
  display:inline-block !important;
}

/* Íconos de beneficios inferiores */
.hero-banner-frame-main .hero-main-overlay .hero-main-trust-item img.trust-icon,
.hero-banner-frame-main .hero-main-overlay .hero-main-trust-item .trust-icon{
  width:36px !important;
  min-width:36px !important;
  max-width:36px !important;
  height:36px !important;
  min-height:36px !important;
  max-height:36px !important;
  flex:0 0 36px !important;
  display:block !important;
}

/* Icono de calendario del botón primario en blanco */
.hero-banner-frame-main .hero-main-overlay .hero-main-btn .btn-icon-light{
  filter:brightness(0) invert(1);
}

@media(max-width:720px){
  .hero-banner-frame-main .hero-main-overlay .hero-main-btn img.btn-icon,
  .hero-banner-frame-main .hero-main-overlay .hero-main-btn .btn-icon{
    width:19px !important;
    min-width:19px !important;
    max-width:19px !important;
    height:19px !important;
    min-height:19px !important;
    max-height:19px !important;
    flex-basis:19px !important;
  }
  .hero-banner-frame-main .hero-main-overlay .hero-main-trust-item img.trust-icon,
  .hero-banner-frame-main .hero-main-overlay .hero-main-trust-item .trust-icon{
    width:32px !important;
    min-width:32px !important;
    max-width:32px !important;
    height:32px !important;
    min-height:32px !important;
    max-height:32px !important;
    flex-basis:32px !important;
  }
}


/* Segundo carrusel: solo el botón Agenda debe ser clickeable */
.hero-banner-frame-mission-generated{
  cursor:default;
}
.hero-banner-frame-mission-generated .hero-mission-content{
  pointer-events:none;
}
.hero-banner-frame-mission-generated .hero-mission-button{
  pointer-events:auto;
  text-decoration:none;
  cursor:pointer;
}
.hero-banner-frame-mission-generated .hero-mission-button:focus-visible{
  outline:3px solid rgba(255,79,127,.35);
  outline-offset:4px;
}


/* Mejora responsive: carruseles en versión móvil */
@media(max-width:720px){
  .hero.hero-carousel-only{
    padding:10px 0 18px;
    overflow:hidden;
  }

  .hero-carousel{
    border-radius:0;
    box-shadow:none;
  }

  .hero-carousel-track{
    align-items:stretch;
  }

  .hero-carousel-slide{
    min-height:760px;
  }

  .hero-banner-slide-fullwidth{
    min-height:760px;
  }

  .hero-banner-frame{
    border-radius:0;
  }

  .hero-carousel-arrow{
    width:42px;
    height:42px;
    top:auto;
    bottom:20px;
    transform:none;
    z-index:8;
    background:rgba(255,255,255,.92);
    box-shadow:0 10px 26px rgba(16,42,97,.12);
  }

  .hero-carousel-arrow-prev{
    left:18px;
  }

  .hero-carousel-arrow-next{
    right:18px;
  }

  .hero-carousel-dots{
    bottom:32px;
    z-index:7;
  }

  /* Slide 1: hero informativo */
  .hero-banner-slide-fullwidth .hero-banner-frame.hero-banner-frame-main{
    min-height:760px;
  }

  .hero-banner-frame-main > picture img{
    object-position:center bottom;
  }

  .hero-banner-frame-main::after{
    background:
      linear-gradient(180deg,
        rgba(255,255,255,.98) 0%,
        rgba(255,255,255,.96) 34%,
        rgba(255,255,255,.70) 58%,
        rgba(255,255,255,.08) 100%);
  }

  .hero-main-overlay{
    align-items:flex-start;
    justify-content:center;
  }

  .hero-main-content{
    width:calc(100% - 32px);
    margin:18px 16px 0;
    padding:18px 16px 15px;
    border-radius:22px;
    background:rgba(255,255,255,.82);
    border:1px solid rgba(204,219,242,.82);
    box-shadow:0 16px 34px rgba(16,42,97,.08);
    backdrop-filter:blur(8px);
  }

  .hero-main-eyebrow{
    margin-bottom:10px;
    padding:8px 12px;
    font-size:10px;
    letter-spacing:.1em;
  }

  .hero-main-title{
    font-size:clamp(31px, 9vw, 43px);
    line-height:1.03;
    letter-spacing:-.055em;
    margin-bottom:12px;
  }

  .hero-main-text{
    font-size:14.5px;
    line-height:1.45;
    margin-bottom:16px;
  }

  .hero-main-actions{
    gap:10px;
    margin-bottom:14px;
  }

  .hero-main-actions .btn{
    min-height:50px;
    border-radius:13px;
    font-size:13.5px;
  }

  .hero-main-trust{
    grid-template-columns:1fr;
    gap:8px;
  }

  .hero-main-trust-item{
    padding:9px 10px;
    border-radius:14px;
  }

  /* Slide 2: misión */
  .hero-banner-frame-mission-generated{
    min-height:760px;
    background-position:center center;
    align-items:flex-start;
    padding-top:64px;
  }

  .hero-banner-frame-mission-generated .hero-mission-content{
    width:calc(100% - 34px);
    margin:0 auto;
    padding:22px 16px 24px;
    border-radius:24px;
    background:rgba(255,255,255,.70);
    border:1px solid rgba(213,224,244,.72);
    box-shadow:0 18px 38px rgba(16,42,97,.07);
    backdrop-filter:blur(6px);
  }

  .hero-banner-frame-mission-generated .hero-mission-logo{
    width:min(48vw, 190px) !important;
    min-width:150px !important;
    margin-bottom:18px;
  }

  .hero-banner-frame-mission-generated .hero-mission-title{
    font-size:clamp(32px, 9vw, 48px);
    line-height:1.05;
    letter-spacing:-.05em;
  }

  .hero-banner-frame-mission-generated .hero-mission-text{
    margin-top:14px;
    max-width:100%;
    font-size:clamp(15px, 4vw, 19px);
    line-height:1.36;
  }

  .hero-banner-frame-mission-generated .hero-mission-button{
    margin-top:28px;
    min-width:220px;
    min-height:62px;
    border-radius:17px;
    font-size:clamp(20px, 5.6vw, 25px);
  }

  /* Slide 3: TOCcast / podcast */
  .hero-banner-slide-podcast{
    min-height:760px;
  }

  .hero-banner-frame-podcast{
    min-height:760px;
    background:#eef3f8;
  }

  .hero-banner-frame-podcast picture,
  .hero-banner-frame-podcast picture img{
    width:100%;
    height:100%;
    display:block;
  }

  .hero-banner-frame-podcast picture img{
    object-fit:cover;
    object-position:center center;
  }

  .hero-podcast-overlay{
    align-items:flex-start;
    justify-content:center;
    padding:22px 16px 0;
  }

  .hero-podcast-content{
    width:100%;
    max-width:390px;
    padding:18px 16px;
    border-radius:22px;
    background:rgba(255,255,255,.80);
    border:1px solid rgba(204,219,242,.76);
    box-shadow:0 16px 34px rgba(16,42,97,.08);
    backdrop-filter:blur(8px);
  }

  .hero-podcast-content span{
    font-size:11px;
    letter-spacing:.13em;
  }

  .hero-podcast-content h2{
    font-size:clamp(30px, 8vw, 42px);
    line-height:1.05;
  }

  .hero-podcast-button{
    min-height:50px;
    padding:0 16px;
    border-radius:14px;
    font-size:14px;
  }
}

/* Ajuste para móviles muy angostos */
@media(max-width:390px){
  .hero-carousel-slide,
  .hero-banner-slide-fullwidth,
  .hero-banner-slide-fullwidth .hero-banner-frame.hero-banner-frame-main,
  .hero-banner-frame-mission-generated,
  .hero-banner-slide-podcast,
  .hero-banner-frame-podcast{
    min-height:720px;
  }

  .hero-main-title{
    font-size:30px;
  }

  .hero-banner-frame-mission-generated{
    padding-top:48px;
  }

  .hero-banner-frame-mission-generated .hero-mission-title{
    font-size:30px;
  }
}


/* =========================================================
   Responsive global completo - Espacio TOC
   Ajustes finales para escritorio, tablet y móvil.
========================================================= */

/* Seguridad contra desbordes horizontales */
html,
body{
  max-width:100%;
  overflow-x:hidden;
}

*,
*::before,
*::after{
  box-sizing:border-box;
}

img,
video,
picture,
svg{
  max-width:100%;
}

.container{
  width:min(100% - 40px, 1180px);
}

/* Header responsive */
.site-header{
  z-index:1000;
}

.header-inner{
  min-height:76px;
}

.main-nav{
  min-width:0;
}

.main-nav a,
.header-actions .btn{
  white-space:nowrap;
}

/* Evita que el navbar se apriete en desktop medio */
@media(max-width:1220px){
  .header-inner{
    gap:12px;
  }

  .brand img{
    max-width:128px;
  }

  .main-nav{
    gap:8px;
  }

  .main-nav a{
    font-size:11.5px;
    padding:9px 7px;
  }

  .header-actions{
    gap:8px;
  }

  .header-actions .btn{
    padding:10px 11px;
    font-size:12px;
  }
}

/* Tablet: convertir navegación en menú móvil antes de que se rompa */
@media(max-width:1040px){
  .header-inner{
    min-height:72px;
  }

  .nav-toggle{
    display:flex;
  }

  .main-nav{
    position:fixed;
    top:72px;
    left:16px;
    right:16px;
    display:none;
    flex-direction:column;
    align-items:stretch;
    gap:4px;
    padding:16px;
    border:1px solid rgba(202,214,235,.9);
    border-radius:22px;
    background:rgba(255,255,255,.97);
    box-shadow:0 24px 48px rgba(16,42,97,.14);
    backdrop-filter:blur(14px);
    max-height:calc(100vh - 92px);
    overflow:auto;
    z-index:1100;
  }

  .main-nav.is-open,
  .site-header.nav-open .main-nav,
  body.nav-open .main-nav{
    display:flex;
  }

  .main-nav a{
    width:100%;
    font-size:15px;
    padding:13px 14px;
    border-radius:14px;
  }

  .main-nav a::after{
    display:none !important;
  }

  .main-nav a.active{
    background:rgba(31,91,198,.09);
    color:var(--blue);
  }

  .header-actions{
    margin-left:auto;
  }

  .header-actions .btn-outline{
    display:none;
  }

  .header-actions .btn-primary{
    padding:11px 14px;
    font-size:13px;
  }
}

@media(max-width:560px){
  .container{
    width:min(100% - 28px, 1180px);
  }

  .brand img{
    max-width:116px;
  }

  .header-actions .btn-primary{
    display:none;
  }

  .main-nav{
    top:70px;
    left:12px;
    right:12px;
  }
}

/* Carrusel: evitar cortes laterales y mejorar comportamiento */
.hero-carousel,
.hero-carousel-track,
.hero-carousel-slide{
  max-width:100%;
}

.hero-banner-frame-main,
.hero-banner-frame-mission,
.hero-banner-frame-podcast{
  max-width:100%;
  overflow:hidden;
}

/* Grillas generales */
.grid,
.split-grid,
.resources-grid-v2,
.clean-courses-grid,
.staff-page-grid,
.courses-grid,
.courses-image-grid,
.instagram-grid,
.sabias-instagram-grid,
.testimonials-grid,
.help-grid,
.process-grid,
.contact-page-grid{
  max-width:100%;
}

/* Secciones en tablet */
@media(max-width:1180px){
  .split-grid,
  .contact-page-grid{
    grid-template-columns:1fr !important;
  }

  .help-grid,
  .process-grid,
  .testimonials-grid{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }

  .staff-page-grid,
  .courses-grid,
  .courses-image-grid{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }

  .resources-grid-v2,
  .clean-courses-grid{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }

  .instagram-grid,
  .sabias-instagram-grid,
  .clean-instagram-panel .sabias-instagram-grid{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }

  .final-cta .cta-card,
  .cta-card{
    grid-template-columns:1fr !important;
    text-align:left;
  }

  .contact-row{
    flex-wrap:wrap;
  }
}

/* Móvil general */
@media(max-width:720px){
  body{
    font-size:15px;
  }

  section,
  .section{
    padding-left:0;
    padding-right:0;
  }

  .section-title,
  .section-title.left,
  .resources-topbar,
  .clean-section-head,
  .instagram-head,
  .sabias-que-head{
    text-align:left;
  }

  .section-title h2,
  .resources-topbar h2,
  .clean-section-head h2,
  .instagram-head h2,
  .sabias-que-head h3{
    font-size:clamp(26px, 8vw, 34px) !important;
    line-height:1.08;
  }

  .section-title p,
  .resources-topbar p,
  .instagram-head p,
  .sabias-que-head p{
    font-size:14px !important;
    line-height:1.55;
  }

  .help-grid,
  .process-grid,
  .testimonials-grid,
  .staff-page-grid,
  .courses-grid,
  .courses-image-grid,
  .resources-grid-v2,
  .clean-courses-grid,
  .instagram-grid,
  .sabias-instagram-grid,
  .clean-instagram-panel .sabias-instagram-grid{
    grid-template-columns:1fr !important;
  }

  .card,
  .clean-section-panel,
  .clean-instagram-panel,
  .resources-page-main .resources-topbar,
  .resources-page-main .resources-grid-v2,
  .treatment-banner-shell,
  .treatment-next-card,
  .cta-card{
    border-radius:20px !important;
  }

  .resources-page-main .resource-card-v2,
  .clean-course-card{
    grid-template-columns:64px 1fr !important;
    gap:14px !important;
    padding:16px 14px !important;
  }

  .resources-page-main .resource-icon-box,
  .clean-course-icon{
    width:62px !important;
    height:62px !important;
    border-radius:14px !important;
  }

  .resources-page-main .resource-card-icon,
  .clean-course-icon img{
    width:42px !important;
    height:42px !important;
  }

  .resource-card-body h3,
  .clean-course-card h3{
    font-size:16px !important;
  }

  .resource-card-body p,
  .clean-course-card li{
    font-size:12px !important;
  }

  .resource-download-btn,
  .clean-mini-btn{
    width:100%;
  }

  /* Staff */
  .staff-profile-card,
  .staff-card,
  .staff-mini-card{
    width:100%;
  }

  .staff-portrait{
    aspect-ratio:4/3;
  }

  /* Cursos */
  .course-exact-card,
  .course-card{
    width:100%;
  }

  /* Sección tratamiento en inicio */
  .treatment-banner .container,
  .treatment-page-main .treatment-banner .container{
    width:min(100% - 28px, 1180px) !important;
  }

  .treatment-banner-shell{
    padding:22px 16px !important;
  }

  .treatment-cards-banner{
    grid-template-columns:1fr !important;
  }

  .mini-card-banner{
    min-height:auto !important;
  }

  .treatment-banner-visual{
    width:100%;
    min-height:auto !important;
  }

  .treatment-banner-visual img{
    max-width:100% !important;
  }

  /* Mitos + FAQ */
  .myths-faq .split-grid{
    grid-template-columns:1fr !important;
  }

  .myth-list{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:12px !important;
  }

  .myth-list div{
    min-width:0;
  }

  .faq-list button{
    text-align:left;
    gap:10px;
  }

  /* CTA final */
  .final-cta{
    padding-left:0;
    padding-right:0;
  }

  .final-cta .cta-card,
  .cta-card{
    padding:24px 18px !important;
  }

  .cta-card h2{
    font-size:clamp(26px, 8vw, 36px) !important;
  }

  .cta-actions{
    width:100%;
    flex-direction:column;
  }

  .cta-actions .btn{
    width:100%;
    justify-content:center;
  }

  .contact-row{
    width:100%;
    display:grid !important;
    grid-template-columns:1fr;
    gap:10px;
  }

  .contact-row a{
    width:100%;
    justify-content:center;
    min-width:0;
  }

  /* Footer */
  .footer-inner{
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:18px;
    text-align:center;
  }

  .footer-inner nav{
    display:flex;
    flex-wrap:wrap;
    justify-content:center;
    gap:10px 16px;
  }
}

/* Móvil muy angosto */
@media(max-width:420px){
  .container{
    width:min(100% - 22px, 1180px);
  }

  .hero-carousel-arrow{
    width:38px !important;
    height:38px !important;
  }

  .hero-carousel-arrow-prev{
    left:10px !important;
  }

  .hero-carousel-arrow-next{
    right:10px !important;
  }

  .myth-list{
    grid-template-columns:1fr !important;
  }

  .resources-page-main .resource-card-v2,
  .clean-course-card{
    grid-template-columns:1fr !important;
  }

  .resources-page-main .resource-icon-box,
  .clean-course-icon{
    margin-bottom:8px;
  }

  .hero-main-content,
  .hero-banner-frame-mission-generated .hero-mission-content,
  .hero-podcast-content{
    width:calc(100% - 24px) !important;
    margin-left:12px !important;
    margin-right:12px !important;
  }
}

/* Evitar cualquier elemento fugitivo que corte el móvil */
@media(max-width:720px){
  [class*="grid"],
  [class*="panel"],
  [class*="shell"],
  [class*="card"]{
    max-width:100%;
  }
}


/* Primer carrusel sin badge superior */
.hero-main-content{
  padding-top:0;
}
.hero-main-title{
  margin-top:0;
}
@media(max-width:720px){
  .hero-main-content{
    padding-top:18px;
  }
}


/* =========================================================
   Fix definitivo: carrusel 2 y 3 móvil cubren igual que carrusel 1
   No cambia imágenes, solo la forma de mostrarlas.
========================================================= */
@media(max-width:720px){
  /* Mismo alto/área visual para los 3 slides */
  .hero-carousel-slide,
  .hero-banner-slide-fullwidth,
  .hero-banner-frame,
  .hero-banner-frame-main,
  .hero-banner-frame-mission-generated,
  .hero-banner-slide-podcast,
  .hero-banner-frame-podcast{
    min-height:760px !important;
    height:760px !important;
    aspect-ratio:auto !important;
  }

  /* Slide 2: usar la imagen móvil como fondo, cubriendo todo */
  .hero-carousel-slide:nth-child(2) .hero-banner-frame-mission-generated{
    background-image:url('assets/home-mission-slide-bg-mobile.png') !important;
    background-size:cover !important;
    background-position:center center !important;
    background-repeat:no-repeat !important;
    align-items:flex-start !important;
    justify-content:center !important;
    overflow:hidden !important;
    padding-top:64px !important;
    padding-bottom:0 !important;
  }

  /* Slide 3: la imagen debe comportarse igual que el slide 1 */
  .hero-carousel-slide:nth-child(3) .hero-banner-frame-podcast{
    overflow:hidden !important;
    background:#eef3f8 !important;
    padding:0 !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-banner-frame-podcast picture{
    position:absolute !important;
    inset:0 !important;
    display:block !important;
    width:100% !important;
    height:100% !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-banner-frame-podcast picture img{
    position:absolute !important;
    inset:0 !important;
    width:100% !important;
    height:100% !important;
    max-width:none !important;
    display:block !important;
    object-fit:cover !important;
    object-position:center center !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-overlay{
    position:absolute !important;
    left:18px !important;
    right:18px !important;
    bottom:20px !important;
    top:auto !important;
    z-index:3 !important;
    padding:0 !important;
    max-width:none !important;
  }
}

@media(max-width:390px){
  .hero-carousel-slide,
  .hero-banner-slide-fullwidth,
  .hero-banner-frame,
  .hero-banner-frame-main,
  .hero-banner-frame-mission-generated,
  .hero-banner-slide-podcast,
  .hero-banner-frame-podcast{
    min-height:720px !important;
    height:720px !important;
    aspect-ratio:auto !important;
  }

  .hero-carousel-slide:nth-child(2) .hero-banner-frame-mission-generated{
    padding-top:48px !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-overlay{
    left:14px !important;
    right:14px !important;
    bottom:16px !important;
  }
}


/* =========================================================
   Ajuste prueba: hero 1 móvil más limpio para que se vea la imagen
   - Caja de texto más compacta
   - Botones más bajos
   - Beneficios ocultos en móvil para no tapar toda la imagen
========================================================= */
@media(max-width:720px){
  .hero-carousel-slide:nth-child(1) .hero-banner-frame-main{
    min-height:760px !important;
    height:760px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-overlay{
    align-items:flex-start !important;
    justify-content:flex-start !important;
    padding:0 !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-content{
    width:min(calc(100% - 28px), 390px) !important;
    margin:14px auto 0 !important;
    padding:18px 18px 16px !important;
    border-radius:22px !important;
    background:rgba(255,255,255,.86) !important;
    border:1px solid rgba(204,219,242,.82) !important;
    box-shadow:0 16px 34px rgba(16,42,97,.08) !important;
    backdrop-filter:blur(8px);
  }

  .hero-carousel-slide:nth-child(1) .hero-main-title{
    font-size:clamp(30px, 8.5vw, 39px) !important;
    line-height:1.03 !important;
    letter-spacing:-.055em !important;
    margin:0 0 12px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-text{
    font-size:14.5px !important;
    line-height:1.43 !important;
    margin:0 0 15px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-actions{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:10px !important;
    margin:0 !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-actions .btn{
    min-height:46px !important;
    padding:0 14px !important;
    border-radius:13px !important;
    font-size:13.5px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-btn .btn-icon{
    width:18px !important;
    height:18px !important;
    min-width:18px !important;
    max-width:18px !important;
    min-height:18px !important;
    max-height:18px !important;
    flex-basis:18px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-trust{
    display:none !important;
  }
}

@media(max-width:390px){
  .hero-carousel-slide:nth-child(1) .hero-banner-frame-main{
    min-height:720px !important;
    height:720px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-content{
    width:calc(100% - 22px) !important;
    margin-top:10px !important;
    padding:16px 15px 14px !important;
    border-radius:20px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-title{
    font-size:29px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-text{
    font-size:13.8px !important;
  }
}


/* =========================================================
   Ajuste prueba 2: hero 1 móvil compacto sin tapar rostro
   Mantiene texto y botones, pero reduce altura real de la tarjeta.
========================================================= */
@media(max-width:720px){
  .hero-carousel-slide:nth-child(1) .hero-main-overlay{
    align-items:flex-start !important;
    justify-content:flex-start !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-content{
    width:min(calc(100% - 30px), 382px) !important;
    margin:10px auto 0 !important;
    padding:14px 16px 14px !important;
    border-radius:20px !important;
    background:rgba(255,255,255,.84) !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-title{
    font-size:clamp(27px, 7.6vw, 34px) !important;
    line-height:1.01 !important;
    margin-bottom:10px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-text{
    font-size:13.2px !important;
    line-height:1.35 !important;
    margin-bottom:12px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-actions{
    gap:8px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-actions .btn{
    min-height:42px !important;
    padding:0 12px !important;
    border-radius:12px !important;
    font-size:13px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-trust{
    display:none !important;
  }
}

@media(max-width:390px){
  .hero-carousel-slide:nth-child(1) .hero-main-content{
    width:calc(100% - 22px) !important;
    margin-top:8px !important;
    padding:12px 14px 12px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-title{
    font-size:26px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-text{
    font-size:12.8px !important;
    line-height:1.32 !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-actions .btn{
    min-height:40px !important;
  }
}

/* =========================================================
   Ajuste final: hero 1 móvil con imagen más clara
   - elimina el velo/degradado blanco sobre la imagen
   - mantiene la tarjeta superior legible
========================================================= */
@media(max-width:720px){
  .hero-carousel-slide:nth-child(1) .hero-banner-frame-main::after{
    display:none !important;
    background:none !important;
    opacity:0 !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-photo::after,
  .hero-carousel-slide:nth-child(1) .hero-photo::before{
    display:none !important;
    content:none !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-photo img,
  .hero-carousel-slide:nth-child(1) .hero-banner-frame-main img{
    opacity:1 !important;
    filter:none !important;
    mix-blend-mode:normal !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-content{
    background:rgba(255,255,255,.96) !important;
    backdrop-filter:none !important;
  }
}


/* =========================================================
   Beneficios compactos en carrusel 1 móvil
   Los vuelve a mostrar abajo, sin agrandar la tarjeta principal.
========================================================= */
@media(max-width:720px){
  .hero-carousel-slide:nth-child(1) .hero-banner-frame-main{
    position:relative;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-content{
    position:static !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-trust{
    position:absolute !important;
    left:16px !important;
    right:16px !important;
    bottom:58px !important;
    z-index:5 !important;
    display:grid !important;
    grid-template-columns:repeat(3,minmax(0,1fr)) !important;
    gap:8px !important;
    margin:0 !important;
    pointer-events:none !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-trust-item{
    min-width:0 !important;
    padding:9px 7px !important;
    border-radius:14px !important;
    background:rgba(255,255,255,.92) !important;
    border:1px solid rgba(200,215,239,.88) !important;
    box-shadow:0 10px 22px rgba(16,42,97,.08) !important;
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    justify-content:center !important;
    gap:5px !important;
    text-align:center !important;
    backdrop-filter:blur(8px);
  }

  .hero-carousel-slide:nth-child(1) .hero-main-trust-item .trust-icon{
    width:24px !important;
    min-width:24px !important;
    max-width:24px !important;
    height:24px !important;
    min-height:24px !important;
    max-height:24px !important;
    flex:0 0 24px !important;
    object-fit:contain !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-trust-item span{
    display:block !important;
    color:#304262 !important;
    font-size:10.5px !important;
    font-weight:850 !important;
    line-height:1.15 !important;
    letter-spacing:-.02em !important;
  }
}

@media(max-width:390px){
  .hero-carousel-slide:nth-child(1) .hero-main-trust{
    left:12px !important;
    right:12px !important;
    bottom:54px !important;
    gap:6px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-trust-item{
    padding:8px 5px !important;
    border-radius:13px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-trust-item .trust-icon{
    width:22px !important;
    min-width:22px !important;
    max-width:22px !important;
    height:22px !important;
    min-height:22px !important;
    max-height:22px !important;
    flex-basis:22px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-trust-item span{
    font-size:9.8px !important;
  }
}


/* =========================================================
   VERIFICADO FINAL: TOCcast móvil centrado, transparente y legible
========================================================= */
@media(max-width:720px){
  .hero-carousel-slide:nth-child(3) .hero-podcast-overlay{
    left:20px !important;
    right:20px !important;
    bottom:70px !important;
    top:auto !important;
    z-index:9 !important;
    padding:0 !important;
    max-width:none !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-overlay > span,
  .hero-carousel-slide:nth-child(3) .hero-podcast-overlay h2{
    display:none !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-button{
    position:relative !important;
    width:100% !important;
    min-height:62px !important;
    padding:0 54px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    border-radius:20px !important;
    background:transparent !important;
    border:1px solid rgba(255,255,255,.72) !important;
    box-shadow:none !important;
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
    color:#fff !important;
    text-decoration:none !important;
    overflow:hidden !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-button:hover{
    background:transparent !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-button-main{
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    gap:10px !important;
    margin:0 auto !important;
    min-width:0 !important;
    max-width:100% !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-youtube-icon{
    width:30px !important;
    min-width:30px !important;
    max-width:30px !important;
    height:21px !important;
    min-height:21px !important;
    max-height:21px !important;
    flex:0 0 30px !important;
    display:inline-block !important;
    margin:0 !important;
    background-image:url('assets/icon-youtube.svg') !important;
    background-repeat:no-repeat !important;
    background-position:center center !important;
    background-size:contain !important;
    filter:drop-shadow(0 1px 2px rgba(0,0,0,.16)) !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-button-label{
    display:inline-block !important;
    color:#fff !important;
    font-size:18px !important;
    font-weight:850 !important;
    line-height:1.1 !important;
    letter-spacing:-.02em !important;
    white-space:nowrap !important;
    text-align:center !important;
    text-shadow:0 2px 5px rgba(0,0,0,.34) !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-button strong{
    position:absolute !important;
    right:22px !important;
    top:50% !important;
    transform:translateY(-50%) !important;
    width:auto !important;
    margin:0 !important;
    color:#fff !important;
    font-size:30px !important;
    line-height:1 !important;
    font-weight:900 !important;
    text-shadow:0 2px 5px rgba(0,0,0,.32) !important;
  }

  .hero-carousel-dots{
    bottom:14px !important;
    z-index:8 !important;
  }
}

@media(max-width:390px){
  .hero-carousel-slide:nth-child(3) .hero-podcast-overlay{
    left:16px !important;
    right:16px !important;
    bottom:66px !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-button{
    min-height:58px !important;
    padding-left:44px !important;
    padding-right:44px !important;
    border-radius:19px !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-button-main{
    gap:9px !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-youtube-icon{
    width:28px !important;
    min-width:28px !important;
    max-width:28px !important;
    height:20px !important;
    min-height:20px !important;
    max-height:20px !important;
    flex-basis:28px !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-button-label{
    font-size:16px !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-button strong{
    right:18px !important;
    font-size:27px !important;
  }
}


/* Icono YouTube del botón TOCcast hecho en CSS para alineación perfecta */
@media(max-width:720px){
  .hero-carousel-slide:nth-child(3) .hero-podcast-youtube-icon{
    position:relative !important;
    width:30px !important;
    min-width:30px !important;
    max-width:30px !important;
    height:21px !important;
    min-height:21px !important;
    max-height:21px !important;
    flex:0 0 30px !important;
    display:inline-block !important;
    margin:0 !important;
    background:#ff0000 !important;
    border-radius:5px !important;
    box-shadow:0 1px 2px rgba(0,0,0,.16) !important;
  }
  .hero-carousel-slide:nth-child(3) .hero-podcast-youtube-icon::after{
    content:"" !important;
    position:absolute !important;
    left:11px !important;
    top:6px !important;
    width:0 !important;
    height:0 !important;
    border-left:8px solid #fff !important;
    border-top:5px solid transparent !important;
    border-bottom:5px solid transparent !important;
  }
}
@media(max-width:390px){
  .hero-carousel-slide:nth-child(3) .hero-podcast-youtube-icon{
    width:28px !important;
    min-width:28px !important;
    max-width:28px !important;
    height:20px !important;
    min-height:20px !important;
    max-height:20px !important;
    flex-basis:28px !important;
  }
  .hero-carousel-slide:nth-child(3) .hero-podcast-youtube-icon::after{
    left:10px !important;
    top:5px !important;
  }
}


/* Icono YouTube reutilizable en el botón del TOCcast */
.hero-podcast-youtube-icon{
  position:relative;
  width:26px;
  min-width:26px;
  height:18px;
  display:inline-block;
  background:#ff0000;
  border-radius:4.5px;
  flex:0 0 26px;
}
.hero-podcast-youtube-icon::after{
  content:"";
  position:absolute;
  left:9.8px;
  top:4.7px;
  width:0;
  height:0;
  border-left:7px solid #fff;
  border-top:4.5px solid transparent;
  border-bottom:4.5px solid transparent;
}



/* Ajuste profesional del botón TOCcast en escritorio */
@media (min-width: 721px){
  .hero-carousel-slide:nth-child(3) .hero-podcast-overlay{
    max-width: 430px !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-button{
    width: auto !important;
    min-width: 320px !important;
    max-width: 380px !important;
    min-height: 68px !important;
    padding: 14px 20px 14px 18px !important;
    border-radius: 22px !important;
    background: rgb(255 255 255 / 14%) !important;
    border: 1px solid rgb(255 255 255 / 38%) !important;
    box-shadow: 0 18px 40px rgba(12, 24, 58, .22) !important;
    backdrop-filter: blur(8px) !important;
    -webkit-backdrop-filter: blur(8px) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 14px !important;
    text-decoration: none !important;
    overflow: visible !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-button:hover{
    background: rgb(255 255 255 / 18%) !important;
    border-color: rgb(255 255 255 / 48%) !important;
    transform: translateY(-1px) !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-button-main{
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 12px !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
    margin: 0 !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-youtube-icon{
    width: 34px !important;
    min-width: 34px !important;
    height: 24px !important;
    min-height: 24px !important;
    border-radius: 6px !important;
    flex: 0 0 34px !important;
    margin: 0 !important;
    align-self: center !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-youtube-icon::after{
    left: 12px !important;
    top: 7px !important;
    border-left-width: 9px !important;
    border-top-width: 5px !important;
    border-bottom-width: 5px !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-button-label{
    display: inline-flex !important;
    align-items: center !important;
    line-height: 1.05 !important;
    color: #ffffff !important;
    font-size: 23px !important;
    font-weight: 850 !important;
    letter-spacing: -.02em !important;
    text-shadow: 0 2px 6px rgba(0,0,0,.24) !important;
    white-space: nowrap !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-button strong{
    position: static !important;
    transform: none !important;
    margin: 0 0 0 8px !important;
    color: #ffffff !important;
    font-size: 32px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    text-shadow: 0 2px 6px rgba(0,0,0,.24) !important;
    flex: 0 0 auto !important;
  }
}


/* Ajuste final: botón TOCcast escritorio totalmente transparente y alineado */
@media (min-width: 721px){
  .hero-carousel-slide:nth-child(3) .hero-podcast-button{
    background: transparent !important;
    border: 1px solid rgba(255, 255, 255, 0.55) !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    min-height: 70px !important;
    padding: 14px 20px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: space-between !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-button:hover,
  .hero-carousel-slide:nth-child(3) .hero-podcast-button:focus-visible{
    background: transparent !important;
    border-color: rgba(255,255,255,0.75) !important;
    box-shadow: none !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-button-main{
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 14px !important;
    min-height: 40px !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-youtube-icon{
    width: 36px !important;
    min-width: 36px !important;
    height: 25px !important;
    min-height: 25px !important;
    margin: 0 !important;
    align-self: center !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-youtube-icon::after{
    left: 13px !important;
    top: 7px !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-button-label{
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 25px !important;
    line-height: 1 !important;
    margin: 0 !important;
    padding: 0 !important;
    vertical-align: middle !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-button strong{
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 25px !important;
    line-height: 1 !important;
    margin: 0 0 0 12px !important;
    align-self: center !important;
  }
}


/* =========================================================
   Ajuste tablet / iPad: 721px a 1024px
   Evita que el carrusel use una composición demasiado móvil
   y mejora proporciones de imágenes, texto y botones.
========================================================= */
@media (min-width:721px) and (max-width:1024px){
  .site-header .container{
    min-height:76px !important;
    padding-inline:24px !important;
  }

  .brand img,
  .site-logo,
  .logo img{
    max-height:56px !important;
  }

  .main-nav{
    gap:14px !important;
  }

  .main-nav a{
    font-size:12px !important;
  }

  .nav-cta,
  .btn-header,
  .header-cta{
    min-height:38px !important;
    padding:0 16px !important;
    border-radius:10px !important;
    font-size:12px !important;
  }

  .hero-carousel,
  .hero-carousel-track,
  .hero-carousel-slide,
  .hero-banner-slide-fullwidth,
  .hero-banner-frame,
  .hero-banner-frame-main,
  .hero-banner-frame-mission-generated,
  .hero-banner-slide-podcast,
  .hero-banner-frame-podcast{
    min-height:560px !important;
    height:560px !important;
    aspect-ratio:auto !important;
  }

  .hero-carousel-slide{
    overflow:hidden !important;
  }

  .hero-banner-frame-main,
  .hero-banner-frame-mission-generated,
  .hero-banner-frame-podcast{
    border-radius:0 !important;
    overflow:hidden !important;
  }

  .hero-banner-frame-main img,
  .hero-banner-frame-mission-generated img,
  .hero-banner-frame-podcast img,
  .hero-banner-frame-podcast picture,
  .hero-banner-frame-podcast picture img{
    width:100% !important;
    height:100% !important;
    object-fit:cover !important;
    display:block !important;
  }

  /* Carrusel 1: texto compacto a la izquierda, imagen visible a la derecha */
  .hero-carousel-slide:nth-child(1) .hero-banner-frame-main img{
    object-position:center right !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-overlay{
    align-items:center !important;
    justify-content:flex-start !important;
    padding-left:34px !important;
    padding-right:34px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-content{
    width:min(48%, 390px) !important;
    margin:0 !important;
    padding:0 !important;
    background:transparent !important;
    box-shadow:none !important;
    border:0 !important;
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-title{
    font-size:clamp(42px, 6vw, 62px) !important;
    line-height:.98 !important;
    margin-bottom:18px !important;
    letter-spacing:-.06em !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-text{
    font-size:16px !important;
    line-height:1.45 !important;
    max-width:370px !important;
    margin-bottom:22px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-actions{
    display:flex !important;
    flex-wrap:wrap !important;
    gap:12px !important;
    margin-bottom:22px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-actions .btn{
    min-height:46px !important;
    padding:0 18px !important;
    border-radius:12px !important;
    font-size:13px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-trust{
    position:static !important;
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:10px !important;
    width:min(270px, 100%) !important;
    margin:0 !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-trust-item{
    min-height:48px !important;
    padding:9px 14px !important;
    border-radius:14px !important;
    display:flex !important;
    flex-direction:row !important;
    justify-content:flex-start !important;
    gap:10px !important;
    text-align:left !important;
    background:rgba(255,255,255,.88) !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-trust-item .trust-icon{
    width:24px !important;
    height:24px !important;
    min-width:24px !important;
    flex-basis:24px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-trust-item span{
    font-size:12px !important;
    line-height:1.15 !important;
  }

  /* Carrusel 2: mantener estilo horizontal de tablet */
  .hero-carousel-slide:nth-child(2) .hero-banner-frame-mission-generated{
    background-size:cover !important;
    background-position:center center !important;
    justify-content:center !important;
    align-items:center !important;
    padding:0 54px !important;
  }

  .hero-carousel-slide:nth-child(2) .hero-mission-content{
    transform:scale(.82) !important;
    transform-origin:center center !important;
  }

  /* Carrusel 3: imagen horizontal y botón/texto sin competir con los dibujos */
  .hero-carousel-slide:nth-child(3) .hero-banner-frame-podcast picture,
  .hero-carousel-slide:nth-child(3) .hero-banner-frame-podcast picture img{
    position:absolute !important;
    inset:0 !important;
    width:100% !important;
    height:100% !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-banner-frame-podcast picture img{
    object-fit:cover !important;
    object-position:center center !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-overlay{
    left:36px !important;
    right:auto !important;
    bottom:58px !important;
    top:auto !important;
    max-width:330px !important;
    z-index:9 !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-overlay > span,
  .hero-carousel-slide:nth-child(3) .hero-podcast-overlay h2{
    display:block !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-overlay h2{
    font-size:clamp(30px, 4.4vw, 40px) !important;
    line-height:1.05 !important;
    margin-bottom:16px !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-button{
    width:auto !important;
    min-width:260px !important;
    max-width:310px !important;
    min-height:56px !important;
    padding:0 18px !important;
    border-radius:18px !important;
    background:transparent !important;
    border:1px solid rgba(255,255,255,.62) !important;
    box-shadow:none !important;
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    gap:12px !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-button-main{
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    gap:10px !important;
    min-height:28px !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-youtube-icon{
    width:28px !important;
    min-width:28px !important;
    height:20px !important;
    min-height:20px !important;
    flex:0 0 28px !important;
    align-self:center !important;
    margin:0 !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-button-label{
    font-size:16px !important;
    line-height:1 !important;
    min-height:20px !important;
    display:inline-flex !important;
    align-items:center !important;
    color:#fff !important;
    text-shadow:0 2px 5px rgba(0,0,0,.32) !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-button strong{
    position:static !important;
    transform:none !important;
    margin:0 0 0 8px !important;
    font-size:26px !important;
    line-height:1 !important;
    color:#fff !important;
  }

  .hero-carousel-arrow{
    width:46px !important;
    height:46px !important;
    font-size:28px !important;
    z-index:15 !important;
  }

  .hero-carousel-arrow-prev{
    left:22px !important;
  }

  .hero-carousel-arrow-next{
    right:22px !important;
  }

  .hero-carousel-dots{
    bottom:22px !important;
    z-index:12 !important;
  }
}

/* iPad angosto: ajustes extra para 721px a 820px */
@media (min-width:721px) and (max-width:820px){
  .hero-carousel,
  .hero-carousel-track,
  .hero-carousel-slide,
  .hero-banner-slide-fullwidth,
  .hero-banner-frame,
  .hero-banner-frame-main,
  .hero-banner-frame-mission-generated,
  .hero-banner-slide-podcast,
  .hero-banner-frame-podcast{
    min-height:520px !important;
    height:520px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-overlay{
    padding-left:28px !important;
    padding-right:28px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-content{
    width:46% !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-title{
    font-size:clamp(38px, 5.5vw, 52px) !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-text{
    font-size:14px !important;
    max-width:330px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-trust{
    width:230px !important;
  }

  .hero-carousel-slide:nth-child(1) .hero-main-trust-item span{
    font-size:11px !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-overlay{
    left:30px !important;
    bottom:54px !important;
    max-width:300px !important;
  }

  .hero-carousel-slide:nth-child(3) .hero-podcast-overlay h2{
    font-size:30px !important;
  }
}


/* =========================================================
   Footer: iconos sociales reales a la derecha
========================================================= */
.footer-socials{
  margin-left:auto;
  display:flex !important;
  align-items:center !important;
  justify-content:flex-end !important;
  gap:18px !important;
  flex:0 0 auto;
}

.footer-socials a{
  width:34px;
  height:34px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:10px;
  transition:transform .18s ease, opacity .18s ease;
}

.footer-socials a:hover{
  transform:translateY(-1px);
  opacity:.86;
}

.footer-socials img{
  width:28px !important;
  height:28px !important;
  max-width:28px !important;
  max-height:28px !important;
  object-fit:contain !important;
  display:block !important;
}

.footer-socials a[aria-label="YouTube"] img{
  width:31px !important;
  max-width:31px !important;
}

@media(max-width:720px){
  .footer-inner{
    justify-content:center;
  }

  .footer-socials{
    margin-left:0;
    justify-content:center !important;
    width:100%;
    gap:16px !important;
  }
}


@media(max-width:720px){.myth-list span{width:80px !important;height:80px !important;margin:0 auto 12px !important}.myth-icon{width:48px !important;height:48px !important}}


/* =========================================================
   FAQ funcional tipo acordeón
========================================================= */
.faq-list .faq-question{
  cursor:pointer;
}

.faq-list .faq-question span{
  transition:transform .18s ease;
}

.faq-list .faq-question.open{
  color:var(--blue);
}

.faq-answer{
  border-bottom:1px solid var(--line);
  background:#fff;
}

.faq-answer[hidden]{
  display:none !important;
}

.faq-answer p{
  font-size:14px !important;
  line-height:1.55 !important;
  margin:0 !important;
  padding:16px 18px 18px !important;
  color:#58677f !important;
}

.faq-list .faq-answer:last-child{
  border-bottom:0;
}

@media(max-width:720px){
  .faq-answer p{
    font-size:13.5px !important;
    padding:14px 14px 16px !important;
  }
}


/* =========================================================
   Nuevas secciones: Para quién es este espacio + Señales de apoyo
========================================================= */
.audience-section{
  padding:34px 0 18px;
}

.support-signals-section{
  padding:18px 0 38px;
}

.audience-panel,
.support-signals-panel{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(189,207,237,.85);
  border-radius:28px;
  background:#fff;
  box-shadow:0 18px 46px rgba(16,42,97,.08);
}

.audience-panel{
  padding:56px 34px 48px;
  background-image:url('assets/section-audience-bg.png');
  background-size:cover;
  background-position:center;
}

.support-signals-panel{
  padding:50px 34px 34px;
  background-image:url('assets/section-signals-bg.png');
  background-size:cover;
  background-position:center;
}

.section-title-centered{
  text-align:center;
  max-width:800px;
  margin:0 auto 40px;
}

.section-title-centered h2{
  color:#0e3f99;
  font-size:clamp(36px, 4.2vw, 54px);
  line-height:1.04;
  letter-spacing:-.055em;
  margin:0 0 14px;
}

.section-title-centered p{
  color:#54647e;
  font-size:clamp(16px, 1.45vw, 20px);
  line-height:1.55;
  margin:0 auto;
  max-width:760px;
}

.audience-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:22px;
}

.audience-card{
  min-height:340px;
  border-radius:24px;
  padding:30px 22px 28px;
  background:rgba(255,255,255,.82);
  border:1px solid rgba(199,214,240,.9);
  box-shadow:0 18px 36px rgba(16,42,97,.06);
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  justify-content:flex-start;
  transition:transform .18s ease, box-shadow .18s ease;
  backdrop-filter:blur(8px);
}

.audience-card:hover{
  transform:translateY(-3px);
  box-shadow:0 22px 44px rgba(16,42,97,.1);
}

.audience-icon-bubble{
  width:112px;
  height:112px;
  border-radius:50%;
  display:grid;
  place-items:center;
  margin:0 auto 22px;
  background:linear-gradient(135deg, rgba(241,244,255,.96), rgba(255,255,255,.78));
  box-shadow:inset 0 0 0 1px rgba(205,218,245,.72);
}

.audience-icon-bubble img{
  width:70px;
  height:70px;
  object-fit:contain;
  display:block;
}

.audience-card h3{
  color:#0b357f;
  font-size:22px;
  line-height:1.13;
  letter-spacing:-.035em;
  margin:0;
  min-height:52px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.audience-line{
  width:32px;
  height:4px;
  border-radius:999px;
  margin:22px auto 20px;
  background:#8d98ee;
}

.audience-card p{
  color:#4d5c76;
  font-size:15px;
  line-height:1.65;
  margin:0;
}

.audience-card-green{
  border-color:rgba(176,214,200,.92);
}

.audience-card-green .audience-icon-bubble{
  background:linear-gradient(135deg, rgba(234,248,243,.96), rgba(255,255,255,.78));
}

.audience-card-green .audience-line{
  background:#90c7b4;
}

.audience-card-orange{
  border-color:rgba(232,204,183,.92);
}

.audience-card-orange .audience-icon-bubble{
  background:linear-gradient(135deg, rgba(255,244,235,.96), rgba(255,255,255,.78));
}

.audience-card-orange .audience-line{
  background:#dfb28d;
}

.audience-card-blue{
  border-color:rgba(190,211,246,.92);
}

.audience-card-blue .audience-icon-bubble{
  background:linear-gradient(135deg, rgba(235,244,255,.96), rgba(255,255,255,.78));
}

.audience-card-blue .audience-line{
  background:#88a8ea;
}

.signals-grid{
  max-width:1050px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px 28px;
}

.signal-item{
  min-height:96px;
  border:1px solid rgba(190,211,246,.86);
  border-radius:18px;
  background:rgba(255,255,255,.8);
  box-shadow:0 12px 26px rgba(16,42,97,.045);
  display:grid;
  grid-template-columns:82px 1fr;
  align-items:center;
  gap:18px;
  padding:16px 22px 16px 16px;
  backdrop-filter:blur(8px);
}

.signal-icon{
  width:66px;
  height:66px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, rgba(237,243,255,.98), rgba(255,255,255,.76));
  box-shadow:inset 0 0 0 1px rgba(209,220,247,.72);
}

.signal-icon img{
  width:44px;
  height:44px;
  object-fit:contain;
  display:block;
}

.signal-item p{
  color:#263a61;
  font-size:18px;
  line-height:1.45;
  margin:0;
  font-weight:650;
}

.signals-note{
  max-width:1050px;
  min-height:86px;
  margin:34px auto 0;
  border:1px solid rgba(190,211,246,.9);
  border-radius:18px;
  background:rgba(255,255,255,.78);
  background-image:url('assets/section-note-bg.png');
  background-size:cover;
  background-position:center;
  display:flex;
  align-items:center;
  gap:22px;
  padding:18px 28px;
  color:#29416d;
  backdrop-filter:blur(8px);
}

.signals-note-icon{
  width:42px;
  height:42px;
  border-radius:50%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:2px solid #316bd7;
  color:#316bd7;
  font-weight:900;
  font-size:20px;
  flex:0 0 auto;
  font-family:Georgia, serif;
}

.signals-note p{
  margin:0;
  font-size:16px;
  line-height:1.45;
  font-weight:650;
}

@media(max-width:1100px){
  .audience-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .audience-card{
    min-height:300px;
  }
}

@media(max-width:820px){
  .audience-section{
    padding:26px 0 14px;
  }

  .support-signals-section{
    padding:14px 0 30px;
  }

  .audience-panel,
  .support-signals-panel{
    border-radius:24px;
  }

  .audience-panel{
    padding:42px 22px 34px;
  }

  .support-signals-panel{
    padding:40px 22px 26px;
  }

  .section-title-centered{
    margin-bottom:28px;
  }

  .signals-grid{
    grid-template-columns:1fr;
    gap:14px;
  }

  .signal-item{
    grid-template-columns:70px 1fr;
    min-height:86px;
  }

  .signal-item p{
    font-size:16px;
  }
}

@media(max-width:560px){
  .audience-panel,
  .support-signals-panel{
    border-radius:20px;
  }

  .audience-panel{
    padding:34px 16px 24px;
  }

  .support-signals-panel{
    padding:34px 16px 22px;
  }

  .section-title-centered h2{
    font-size:clamp(29px, 9vw, 38px);
  }

  .section-title-centered p{
    font-size:15px;
  }

  .audience-grid{
    grid-template-columns:1fr;
    gap:14px;
  }

  .audience-card{
    min-height:auto;
    padding:24px 18px;
  }

  .audience-icon-bubble{
    width:96px;
    height:96px;
    margin-bottom:18px;
  }

  .audience-icon-bubble img{
    width:62px;
    height:62px;
  }

  .audience-card h3{
    min-height:auto;
    font-size:21px;
  }

  .audience-line{
    margin:16px auto 14px;
  }

  .audience-card p{
    font-size:14px;
  }

  .signal-item{
    grid-template-columns:58px 1fr;
    gap:12px;
    padding:14px;
    border-radius:16px;
  }

  .signal-icon{
    width:54px;
    height:54px;
  }

  .signal-icon img{
    width:36px;
    height:36px;
  }

  .signal-item p{
    font-size:14px;
    line-height:1.45;
  }

  .signals-note{
    margin-top:22px;
    min-height:auto;
    padding:16px;
    gap:14px;
    align-items:flex-start;
  }

  .signals-note-icon{
    width:34px;
    height:34px;
    font-size:16px;
  }

  .signals-note p{
    font-size:13.5px;
  }
}


/* =========================================================
   Señales de apoyo: iconos más grandes y legibles
========================================================= */
.support-signals-section .signal-item{
  grid-template-columns:112px 1fr !important;
  min-height:126px !important;
  padding:18px 26px 18px 20px !important;
  gap:22px !important;
}

.support-signals-section .signal-icon{
  width:94px !important;
  height:94px !important;
  min-width:94px !important;
  border-radius:50% !important;
}

.support-signals-section .signal-icon img{
  width:68px !important;
  height:68px !important;
  max-width:68px !important;
  max-height:68px !important;
  object-fit:contain !important;
}

@media(max-width:820px){
  .support-signals-section .signal-item{
    grid-template-columns:96px 1fr !important;
    min-height:112px !important;
    gap:18px !important;
    padding:16px 22px 16px 18px !important;
  }

  .support-signals-section .signal-icon{
    width:82px !important;
    height:82px !important;
    min-width:82px !important;
  }

  .support-signals-section .signal-icon img{
    width:60px !important;
    height:60px !important;
    max-width:60px !important;
    max-height:60px !important;
  }
}

@media(max-width:560px){
  .support-signals-section .signal-item{
    grid-template-columns:82px 1fr !important;
    min-height:96px !important;
    gap:14px !important;
    padding:14px 16px !important;
  }

  .support-signals-section .signal-icon{
    width:72px !important;
    height:72px !important;
    min-width:72px !important;
  }

  .support-signals-section .signal-icon img{
    width:52px !important;
    height:52px !important;
    max-width:52px !important;
    max-height:52px !important;
  }
}


/* Crédito discreto de desarrollo en el footer */
.site-footer .footer-credit{
  margin:4px 0 0;
  padding:0 16px 12px;
  text-align:center;
  font-size:11px;
  line-height:1.4;
  color:#7b879c;
}

.site-footer .footer-credit a{
  color:#3159a8;
  font-weight:700;
  text-decoration:none;
}

.site-footer .footer-credit a:hover{
  text-decoration:underline;
}

@media(max-width:720px){
  .site-footer .footer-credit{
    font-size:10.5px;
    padding-bottom:14px;
  }
}

