:root{
  --bg:#ffffff;
  --bg-soft:#f7fbfc;
  --text:#182132;
  --muted:#64748b;
  --line:#e4edf2;
  --white:#ffffff;
  --cyan:#0b8fa6;
  --cyan-dark:#0c7488;
  --cyan-soft:#e9fbfd;
  --aqua:#64cada;
  --aqua-dark:#3eb6c8;
  --aqua-soft:#f1fdff;
  --aqua-strong:#dbf8fb;
  --violet:#8a61e3;
  --violet-dark:#734dd1;
  --violet-soft:#f7f1ff;
  --shadow:0 26px 72px rgba(15,23,42,.12);
  --shadow-soft:0 18px 42px rgba(15,23,42,.08);
  --radius:32px;
  --header-bg:rgba(255,255,255,.9);
  --footer-bg:rgba(255,255,255,.92);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Inter",sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden}
a{text-decoration:none;color:inherit}
img,video{max-width:100%;display:block}
button{font:inherit}
body.viewer-open{overflow:hidden}

.container{width:min(1200px,calc(100% - 40px));margin:0 auto}
.container-wide{width:min(1360px,calc(100% - 48px));margin:0 auto}
.container-edge{width:min(1460px,calc(100% - 48px));margin:0 auto}
.max-text{max-width:780px}
.center-head{text-align:center}
.centered{text-align:center;margin-left:auto;margin-right:auto}

.header{
  position:sticky;top:0;z-index:100;
  background:linear-gradient(var(--header-bg),var(--header-bg)),url("./images/fondo-topnav.png");
  background-position:center;background-size:cover;background-repeat:no-repeat;
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(228,237,242,.75);
}
.escolar-header{background:linear-gradient(rgba(255,255,255,.92),rgba(255,255,255,.92)),url("./images/fondo-topnav.png");background-position:center;background-size:cover;background-repeat:no-repeat}
.nav{min-height:82px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center;flex-shrink:0}
.brand-logo{height:44px;width:auto;object-fit:contain}
.menu{display:flex;align-items:center;gap:28px;font-size:.96rem;color:#58708f}
.menu a{transition:color .22s ease}
.menu a:hover{color:var(--text)}
.nav-actions{display:flex;align-items:center;gap:12px}
.nav-whatsapp{white-space:nowrap}
.menu-toggle{
  display:none;width:46px;height:46px;border:1px solid rgba(203,213,225,.95);background:rgba(255,255,255,.84);
  border-radius:16px;cursor:pointer;padding:0;align-items:center;justify-content:center;flex-direction:column;gap:5px;
}
.menu-toggle span{width:18px;height:2px;background:#0f172a;border-radius:999px;transition:transform .22s ease,opacity .22s ease}
.menu-toggle.is-active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle.is-active span:nth-child(2){opacity:0}
.menu-toggle.is-active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{display:none;border-top:1px solid rgba(228,237,242,.78);background:linear-gradient(rgba(255,255,255,.96),rgba(255,255,255,.96)),url("./images/fondo-topnav.png");background-position:center;background-size:cover;background-repeat:no-repeat}
.mobile-menu.open{display:block}
.mobile-menu-inner{width:min(1360px,calc(100% - 40px));margin:0 auto;padding:18px 0 22px;display:grid;gap:12px}
.mobile-menu-inner a:not(.mobile-menu-btn){padding:8px 0;color:var(--text)}
.mobile-menu-btn{width:fit-content;margin-top:6px}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 20px;border-radius:18px;font-weight:700;font-size:.95rem;
  transition:transform .22s ease,box-shadow .22s ease,background .22s ease,border-color .22s ease,color .22s ease;
  cursor:pointer;border:none;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:linear-gradient(135deg,var(--cyan) 0%,#1aa6bc 100%);color:#fff;box-shadow:0 12px 28px rgba(11,143,166,.2)}
.btn-primary:hover{background:linear-gradient(135deg,var(--cyan-dark) 0%,#1599ae 100%)}
.btn-secondary{background:#fff;color:var(--text);border:1px solid #d3dde6;box-shadow:0 8px 20px rgba(15,23,42,.04)}
.btn-secondary:hover{border-color:#b7c7d7;background:#fbfdff}
.btn-escolar{background:linear-gradient(135deg,var(--violet) 0%,#a26ff0 100%);color:#fff;box-shadow:0 14px 30px rgba(138,97,227,.22)}
.btn-escolar:hover{background:linear-gradient(135deg,var(--violet-dark) 0%,#9866e8 100%)}
.full-width{width:100%}
.inline-link{font-weight:700;color:var(--cyan-dark)}
.inline-link:hover{color:var(--cyan)}

.section{padding:96px 0}
.section-label{font-size:.84rem;letter-spacing:.04em;color:var(--muted);font-weight:700;text-transform:uppercase}
.section-label.light{color:rgba(255,255,255,.86)}
.section-head h2,.hero h1,.contact-box h2{margin:10px 0 0;letter-spacing:-.045em;line-height:1.03}
.section-head h2{font-size:clamp(2rem,3.2vw,3.15rem)}
.section-text,.hero-text,.contact-text{color:var(--muted);line-height:1.82;font-size:1.03rem}

.hero{padding:92px 0 58px}
.hero-home{background:radial-gradient(circle at left top,rgba(86,202,218,.14),transparent 34%),radial-gradient(circle at 88% 18%,rgba(138,97,227,.11),transparent 24%),linear-gradient(180deg,#fff 0%,#f9fcfd 100%)}
.hero-escolar{background:radial-gradient(circle at left top,rgba(138,97,227,.11),transparent 34%),radial-gradient(circle at 88% 18%,rgba(86,202,218,.14),transparent 24%),linear-gradient(180deg,#fff 0%,#f9fbff 100%)}
.hero-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:42px;align-items:center}
.hero-copy h1{font-size:clamp(2.9rem,6vw,5rem);max-width:760px}
.hero-text{margin-top:22px;max-width:760px}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}
.badge{display:inline-flex;padding:9px 14px;border-radius:999px;background:#eefcff;border:1px solid #ccebf1;color:var(--cyan-dark);font-weight:700;font-size:.8rem;box-shadow:0 10px 24px rgba(11,143,166,.07)}
.badge-escolar{background:#f4efff;border-color:#e2d5ff;color:var(--violet-dark)}
.hero-media{position:relative}
.video-stage-real{padding:18px;border-radius:34px;background:linear-gradient(135deg,#ffffff 0%,#f8f3ff 100%);box-shadow:var(--shadow);border:1px solid rgba(232,220,255,.9)}
.hero-video{width:100%;aspect-ratio:16/9;height:auto;border-radius:26px;background:#0f172a;object-fit:contain}

.subtle-card{
  background:#fff;border:1px solid rgba(226,235,241,.98);box-shadow:var(--shadow-soft);
  transition:transform .26s ease,box-shadow .26s ease,background .26s ease,border-color .26s ease;
}
.subtle-card:hover{transform:translateY(-5px);box-shadow:0 24px 52px rgba(15,23,42,.11)}
.tone-ice{background:linear-gradient(180deg,#fff 0%,#f4fbff 100%)}
.tone-cyan{background:linear-gradient(180deg,#fff 0%,#eafafd 100%)}
.tone-aqua{background:linear-gradient(180deg,#fff 0%,#f2fdff 100%)}
.tone-aqua-soft{background:linear-gradient(180deg,#fff 0%,#f7feff 100%)}
.tone-aqua-strong{background:linear-gradient(180deg,#effcfe 0%,#e1f9fc 100%)}
.tone-ice:hover{background:linear-gradient(180deg,#fcfeff 0%,#ebf7fd 100%);border-color:#d7e6f0}
.tone-cyan:hover{background:linear-gradient(180deg,#fbfeff 0%,#e4f7fb 100%);border-color:#cfe6ed}
.tone-aqua:hover{background:linear-gradient(180deg,#fcffff 0%,#eafcff 100%);border-color:#d0edf2}
.tone-aqua-soft:hover{background:linear-gradient(180deg,#fdffff 0%,#edfdfd 100%);border-color:#d8eef2}
.tone-aqua-strong:hover{background:linear-gradient(180deg,#eefcfe 0%,#d9f5f9 100%);border-color:#c8edf1}

.section-services{background:#fff}
.services-columns{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;margin-top:38px}
.service-column{padding:24px;border-radius:30px;display:flex;flex-direction:column;gap:22px}
.service-image{width:100%;aspect-ratio:1.54/1;object-fit:cover;border-radius:24px;border:1px solid rgba(255,255,255,.95);background:#fff}
.service-copy{display:grid;gap:12px}
.service-kicker{display:inline-flex;width:44px;height:44px;border-radius:999px;align-items:center;justify-content:center;background:#fff;border:1px solid rgba(220,230,238,.96);font-weight:800;font-size:.88rem}
.service-copy h3{margin:0;font-size:1.44rem;line-height:1.18}
.service-copy p{margin:0;color:#526173;line-height:1.82}

.how-section{background:linear-gradient(180deg,#fbfeff 0%,#f2fcff 100%)}
.process-flow{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:40px;margin-top:48px;padding:28px 0 14px}
.process-line{
  position:absolute;left:7%;right:7%;top:52%;height:3px;transform:translateY(-50%);
  background:repeating-linear-gradient(90deg,rgba(86,202,218,.55) 0,rgba(86,202,218,.55) 22px,rgba(86,202,218,0) 22px,rgba(86,202,218,0) 40px);
  border-radius:999px;pointer-events:none;
}
.process-step{position:relative;padding:24px;min-height:250px;border-radius:30px;z-index:1}
.process-step:nth-of-type(1){margin-top:0}
.process-step:nth-of-type(2){margin-top:54px}
.process-step:nth-of-type(3){margin-top:0}
.process-step:nth-of-type(4){margin-top:54px}
.step-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}
.step-image{width:82px;height:64px;object-fit:cover;border-radius:18px;background:#fff;border:1px solid rgba(221,232,240,.95)}
.step-number{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:#fff;border:1px solid rgba(219,229,239,.96);font-weight:800;flex:0 0 auto}
.process-step h3{margin:0 0 10px;font-size:1.26rem}
.process-step p{margin:0;color:#526173;line-height:1.76}

.section-about{background:#fff}
.about-feature{display:grid;grid-template-columns:1.16fr .84fr;gap:38px;align-items:center}
.about-main{padding-right:10px}
.about-title{font-size:clamp(1.9rem,2.35vw,2.5rem)!important;line-height:1.14!important;max-width:900px;margin-top:10px!important}
.about-aside{padding:30px;border-radius:32px}
.about-aside h3{margin:12px 0 12px;font-size:1.54rem;line-height:1.16}
.about-aside p{margin:0;color:#446070;line-height:1.82}
.aside-points{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.aside-points span{padding:11px 14px;border-radius:999px;background:#fff;border:1px solid rgba(203,231,236,.95);font-weight:700;color:#366171}

.values-section-home{
  background:#dff4f7;
}
.values-columns{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:26px;
  margin-top:40px;
  padding-top:10px;
}
.value-column{
  padding:0 14px;
  border-right:1px solid rgba(24,33,50,.10);
}
.value-column:last-child{
  border-right:none;
}
.value-column h3{
  margin:0 0 12px;
  font-size:1.08rem;
  line-height:1.2;
  color:var(--text);
}
.value-column p{
  margin:0;
  color:#4f6478;
  line-height:1.75;
  font-size:.98rem;
}

.contact-section-solid{padding-top:34px;background:linear-gradient(180deg,#f6fcfe 0%,#ffffff 100%)}
.contact-box{
  display:grid;grid-template-columns:1.14fr .86fr;gap:30px;align-items:center;
  padding:40px;border-radius:34px;color:#fff;box-shadow:var(--shadow);
}
.contact-box-home{background:linear-gradient(96deg,#17324a 0%,#2a587d 48%,#65c3d2 100%)}
.escolar-contact{background:linear-gradient(96deg,#7258d5 0%,#8f70ea 42%,#66c6d4 100%)}
.contact-box h2{font-size:clamp(2rem,3.2vw,3rem)}
.contact-text{color:rgba(255,255,255,.96);font-size:1rem;line-height:1.78}
.contact-card-solid{background:#fff;color:var(--text);padding:26px;border-radius:26px;box-shadow:0 18px 42px rgba(15,23,42,.14)}
.contact-card-solid h3{margin:0;font-size:1.3rem}
.contact-card-solid .contact-lines{margin-top:16px;display:grid;gap:10px;color:#5d6f86;line-height:1.65}
.contact-card-solid .btn{margin-top:22px}
.modules-contact-inline{margin-top:46px}
.contact-card-escolar .contact-lines{color:#64748b}

.platform-brief-section{padding-top:34px;padding-bottom:24px;background:linear-gradient(180deg,#f9fbff 0%,#ffffff 100%)}
.platform-brief{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:center;padding:28px 30px;border-radius:30px;background:linear-gradient(135deg,#ffffff 0%,#faf5ff 100%);box-shadow:var(--shadow-soft);border:1px solid rgba(234,220,255,.88)}
.platform-inline-points{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.platform-inline-points div{padding:16px 18px;border-radius:20px;background:#fff;border:1px solid rgba(231,220,252,.95);font-weight:700;color:#5d468d;box-shadow:0 10px 22px rgba(138,97,227,.08)}

.modules-showcase-section{padding-top:40px;background:#fff}
.module-tabs{display:grid;grid-template-columns:340px 1fr;gap:30px;margin-top:40px}
.module-tabs-wide{grid-template-columns:350px 1fr}
.module-list{display:grid;gap:12px;align-self:start;position:sticky;top:108px}
.module-tab{
  text-align:left;border:1px solid #eadcff;background:#fff;color:var(--text);border-radius:22px;padding:17px 18px;cursor:pointer;
  transition:transform .22s ease,background .28s ease,color .28s ease,border-color .28s ease,box-shadow .28s ease;
}
.module-tab:hover{transform:translateY(-1px);border-color:#d7c4f8;background:#fbf8ff}
.module-tab.active{background:linear-gradient(135deg,#7d57da 0%,#a370f0 100%);color:#fff;border-color:transparent;box-shadow:0 16px 30px rgba(125,87,218,.18)}
.module-preview{display:grid;gap:18px}
.module-shot{
  padding:26px;border-radius:34px;background:linear-gradient(135deg,#fff 0%,#faf5ff 100%);
  border:1px solid rgba(234,220,255,.94);box-shadow:var(--shadow-soft)
}
.module-main-image-wrap{
  appearance:none;border:none;background:#fff;padding:0;cursor:pointer;width:100%;border-radius:28px;
  box-shadow:0 14px 34px rgba(15,23,42,.06);overflow:hidden;transition:transform .24s ease,box-shadow .24s ease;
}
.module-main-image-wrap:hover{transform:translateY(-2px);box-shadow:0 18px 38px rgba(15,23,42,.1)}
.module-image{
  width:100%;min-height:520px;max-height:620px;object-fit:contain;background:#fff;
  border:1px solid rgba(238,227,255,.96);border-radius:28px;transition:opacity .28s ease,transform .28s ease
}
.module-copy-wrap{padding:18px 4px 0}
.module-copy-wrap span{display:block;font-size:.82rem;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.module-copy-wrap strong{display:block;font-size:1.96rem;line-height:1.08;margin-bottom:10px}
.module-copy-wrap p{margin:0;color:#475569;line-height:1.8;max-width:820px}

.module-thumbs{
  display:flex;
  gap:12px;
  flex-wrap:nowrap;
  overflow-x:auto;
  overflow-y:hidden;
  padding:4px 2px 8px;
  scrollbar-width:thin;
}
.module-thumb{
  appearance:none;
  border:none;
  background:transparent;
  padding:0;
  border-radius:18px;
  cursor:pointer;
  flex:0 0 156px;
}
.module-thumb img{
  width:156px;
  height:92px;
  object-fit:cover;
  border-radius:18px;
  border:1px solid #e3d6fb;
  box-shadow:0 10px 22px rgba(15,23,42,.05);
  transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease,opacity .22s ease;
}
.module-thumb:hover img{transform:translateY(-2px);box-shadow:0 14px 28px rgba(15,23,42,.09)}
.module-thumb.is-active img{border-color:#9d79f2;box-shadow:0 18px 34px rgba(125,87,218,.18)}
.module-thumb.is-hidden{display:none}

.media-viewer{
  position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:300;padding:28px;
}
.media-viewer.is-open{display:flex}
.media-viewer-backdrop{position:absolute;inset:0;background:rgba(9,15,26,.72);backdrop-filter:blur(6px)}
.media-viewer-dialog{
  position:relative;z-index:2;width:min(1180px,100%);max-height:min(92vh,980px);overflow:hidden;
  background:#fff;border-radius:30px;box-shadow:0 32px 80px rgba(9,15,26,.32);padding:24px
}
.viewer-close{
  position:absolute;top:16px;right:16px;width:44px;height:44px;border:none;border-radius:50%;cursor:pointer;
  background:rgba(24,33,50,.08);color:#182132;font-size:1.8rem;line-height:1
}
.viewer-main{position:relative;display:flex;align-items:center;justify-content:center;border-radius:24px;background:#f8fbff;min-height:62vh;padding:22px 66px 22px}
.viewer-image{width:100%;max-height:68vh;object-fit:contain;border-radius:18px;background:#fff}
.viewer-nav{
  position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border:none;border-radius:50%;cursor:pointer;
  background:#fff;box-shadow:0 12px 24px rgba(15,23,42,.12);font-size:2rem;line-height:1;color:#182132
}
.viewer-prev{left:14px}
.viewer-next{right:14px}
.viewer-caption{padding:20px 6px 8px}
.viewer-caption strong{display:block;font-size:1.28rem;margin-bottom:8px}
.viewer-caption p{margin:0;color:#526173;line-height:1.76}
.viewer-thumbs{display:flex;gap:12px;overflow-x:auto;padding:10px 2px 2px}
.viewer-thumb{appearance:none;border:none;background:transparent;padding:0;border-radius:18px;cursor:pointer;flex:0 0 124px}
.viewer-thumb img{width:124px;height:76px;object-fit:cover;border-radius:16px;border:1px solid #e0d2f9;box-shadow:0 8px 20px rgba(15,23,42,.06)}
.viewer-thumb.is-active img{border-color:#9d79f2;box-shadow:0 12px 28px rgba(125,87,218,.18)}

.footer{
  border-top:1px solid rgba(228,237,242,.84);
  background:linear-gradient(var(--footer-bg),var(--footer-bg)),url("./images/fondo-footer.png");
  background-position:center;background-size:cover;background-repeat:no-repeat;
}
.escolar-footer{background:linear-gradient(rgba(255,255,255,.88),rgba(255,255,255,.88)),url("./images/fondo-footer.png");background-position:center;background-size:cover;background-repeat:no-repeat}
.footer-inner{min-height:92px;display:flex;align-items:center;justify-content:space-between;gap:20px;color:#58708f;font-size:.95rem}
.footer-brand{color:var(--text);font-weight:700}
.footer-contact{display:flex;flex-direction:column;gap:4px;align-items:flex-end}

.reveal{
  opacity:0;filter:blur(7px);
  transform:translate3d(var(--tx,0px),calc(var(--ty,74px) + var(--parallax,0px)),0) scale(.962);
  transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1.08s cubic-bezier(.16,1,.3,1),filter 1s cubic-bezier(.16,1,.3,1);
  will-change:transform,opacity,filter;
}
.reveal.in-view{opacity:1;filter:blur(0);transform:translate3d(0,var(--parallax,0px),0) scale(1)}
.reveal.from-left{--tx:-70px;--ty:0px}
.reveal.from-right{--tx:70px;--ty:0px}
.reveal.from-bottom{--tx:0px;--ty:82px}
.parallax-soft{--parallax:0px}

/* Hero full width Home */
.hero-fullwidth{
  position:relative;
  min-height:78vh;
  padding:0;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.hero-home-full{
  background:#0f172a;
}
.hero-carousel,
.hero-slide,
.hero-slide-image,
.hero-overlay{
  position:absolute;
  inset:0;
}
.hero-slide-image{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 48%;
}
.hero-overlay{
  background:
    linear-gradient(180deg,rgba(8,22,38,.18) 0%,rgba(8,22,38,.34) 100%),
    linear-gradient(90deg,rgba(8,22,38,.10) 0%,rgba(8,22,38,.04) 100%);
}
.hero-center-copy{
  position:relative;
  z-index:2;
  width:min(1180px,calc(100% - 40px));
  margin:0 auto;
  text-align:center;
  display:grid;
  gap:20px;
  justify-items:center;
  padding:126px 0 114px;
}
.badge-on-hero{
  background:rgba(255,255,255,.12);
  color:#ffffff;
  border:1px solid rgba(255,255,255,.36);
  backdrop-filter:blur(10px);
  box-shadow:0 16px 34px rgba(8,22,38,.18);
}
.badge-on-hero-large{
  font-size:1.5rem;
  line-height:1.1;
  padding:18px 30px;
  font-weight:800;
  border-width:2px;
}
.hero-title-on-image{
  margin:0;
  max-width:1080px;
  color:#ffffff;
  font-size:clamp(3.4rem,6vw,5.7rem);
  line-height:1.02;
  letter-spacing:-.05em;
  text-shadow:
    0 0 14px rgba(92,210,222,.18),
    0 0 2px rgba(255,255,255,.65),
    0 10px 30px rgba(9,22,39,.32);
}
.hero-title-on-image span{
  display:block;
}

@media (max-width:1320px){
  .values-columns{grid-template-columns:repeat(3,1fr)}
  .value-column{border-right:none;padding:0}
  .process-flow{grid-template-columns:repeat(2,1fr)}
  .process-line{display:none}
  .process-step:nth-of-type(2),.process-step:nth-of-type(4){margin-top:34px}
}

@media (max-width:1100px){
  .menu{display:none}
  .menu-toggle{display:inline-flex}
  .nav-whatsapp{display:none}
  .hero-grid,.services-columns,.about-feature,.contact-box,.platform-brief,.module-tabs{grid-template-columns:1fr}
  .module-list{position:static}
  .platform-inline-points{grid-template-columns:1fr}
  .values-columns{grid-template-columns:repeat(2,1fr);gap:24px 20px}
}

@media (min-width:1101px){
  .mobile-menu{display:none!important}
}

@media (max-width:720px){
  .container,.container-wide,.container-edge{width:min(100% - 28px,1460px)}
  .nav{min-height:76px}
  .brand-logo{height:38px}
  .section{padding:76px 0}
  .hero{padding-top:58px}
  .hero-copy h1{font-size:clamp(2.35rem,11vw,3.9rem)}
  .service-column,.process-step,.about-aside,.contact-box,.contact-card-solid,.platform-brief,.module-shot,.media-viewer-dialog,.video-stage-real{padding:22px}
  .process-flow,.values-columns{grid-template-columns:1fr}
  .process-step:nth-of-type(2),.process-step:nth-of-type(4){margin-top:0}
  .module-image{min-height:300px;max-height:420px}
  .module-thumb{flex-basis:132px}
  .module-thumb img{width:132px;height:78px}
  .viewer-main{padding:16px 52px;min-height:44vh}
  .viewer-nav{width:42px;height:42px;font-size:1.7rem}
  .viewer-thumb{flex-basis:110px}
  .hero-fullwidth{min-height:62vh}
  .hero-center-copy{width:min(100% - 28px,980px);padding:96px 0 84px}
  .badge-on-hero-large{font-size:1rem;padding:14px 20px}
  .hero-title-on-image{font-size:clamp(2.4rem,10vw,4rem)}
  .value-column{border-right:none;padding:0}
  .footer-inner{min-height:auto;padding:18px 0;flex-direction:column;align-items:flex-start}
  .footer-contact{align-items:flex-start}
}

.escolar-band-section{
  padding:0;
  background:#ffffff;
}

.escolar-band{
  width:100%;
  background:linear-gradient(96deg,#f4efff 0%,#f2fbff 52%,#e7fbff 100%);
  border-top:1px solid rgba(210,223,246,.7);
  border-bottom:1px solid rgba(210,223,246,.7);
}

.escolar-band-inner{
  min-height:240px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  gap:18px;
  padding:42px 0;
}

.light-band{
  color:#5d6f86;
}

.escolar-band-copy{
  width:100%;
  max-width:920px;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
}

.escolar-band-copy .section-label,
.escolar-band-copy h2,
.escolar-band-copy p{
  text-align:center;
}

.escolar-band-copy h2{
  margin:10px 0 0;
  font-size:clamp(2.3rem,3.4vw,3.3rem);
  line-height:1.02;
  letter-spacing:-.045em;
  color:var(--text);
}

.escolar-band-copy p{
  margin:16px 0 0;
  max-width:820px;
  color:#4f6478;
  font-size:1.04rem;
  line-height:1.82;
}

.escolar-band-actions{
  width:100%;
  display:flex;
  justify-content:center;
  align-items:center;
}

.escolar-band-actions .btn{
  margin:0 auto;
}

@media (max-width:1100px){
  .escolar-band-inner{
    min-height:auto;
    padding:36px 0;
  }
}

.escolar-band-section{
  background:linear-gradient(96deg,#f4efff 0%,#f2fbff 52%,#e7fbff 100%);
  padding:70px 0;
}

.escolar-band-section .section-head{
  max-width:980px;
  margin:0 auto;
}

.escolar-band-section .section-label{
  color:#5d6f86;
}

.escolar-band-section .section-text{
  color:#4f6478;
}

.escolar-band-actions{
  display:flex;
  justify-content:center;
  align-items:center;
  margin-top:22px;
}