:root{
  --primary:#A4281C;
  --primary2:#700F06;
    --primaryDark: var(--primary2);
  --accent2: var(--primary2);
  --dark: var(--primary2);
--accent:#EF1A06;
  --bg:#ffffff;
  --paper:#ffffff;
  --card:#F3EAE8;
  --ink:#0f172a;
  --muted:#475569;
  --line:rgba(15,23,42,.12);
  --shadow:0 10px 30px rgba(15,23,42,.08);
  --radius:18px;

  --pagePad: clamp(10px, 1.4vw, 16px);
}

*{ box-sizing:border-box; }
html,body{background: var(--bg); height:100%; }
html{ scroll-behavior:smooth; scroll-padding-top: var(--headerH, 120px); }
body{
  margin:0;
  font-family:"Open Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--ink);
  background:linear-gradient(180deg,#fff, var(--paper));
}

a{ color:inherit; }
img{ max-width:100%; display:block; }

.container{
  width: min(1280px, calc(100% - (var(--pagePad) * 2)));
  margin: 0 auto;
}

.main{ padding-top:0; padding-bottom:20px; }

.siteHeader{
  position:relative;
  top:auto;
  z-index:50;
  background:#fff;
  backdrop-filter:none;
  border-bottom:1px solid var(--line);
}

.topbar{
  border-bottom:1px solid rgba(15,23,42,.08);
}
.topbar__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:6px 0;
}
.topbar__msg{
  margin:0;
  font-size:12px;
  color:var(--muted);
}
.topbar__actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.topbar__link{
  text-decoration:none;
  font-size:12px;
  color:var(--muted);
}
.topbar__link:hover{ color:var(--ink); }

.header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:8px 0;
}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  min-width: 260px;
}
.brand__img{
  width:52px;
  height:52px;
  object-fit:contain;
  flex:0 0 auto;
}
.brand__text strong{
  display:block;
  font-size:14px;
  letter-spacing:.2px;
}
.brand__text small{
  display:block;
  font-size:12px;
  color:var(--muted);
}

.tabs{
  position:relative;
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
  overflow:visible;
}
.tab{
  appearance:none;
  border:0;
  background:transparent;
  color:var(--ink);
  font-weight:700;
  font-size:13px;
  padding:10px 8px;
  cursor:pointer;
  white-space:nowrap;
  letter-spacing:.2px;
  position:relative;
  transition: color .2s ease, transform .2s ease, background-color .2s ease;
  border-radius:12px;
}

.tab:focus-visible{
  outline:2px solid rgba(239,26,6,.45);
  outline-offset:2px;
}

.tab:hover{
  color:var(--primary);
  background: rgba(164,40,28,.06);
}
.tab.is-active{
  color:var(--primary);
}
.tab--focus{ color:var(--primary); }
.tabs__indicator{
  position:absolute;
  height:2px;
  background:linear-gradient(90deg,var(--primary),var(--accent));
  border-radius:2px;
  bottom:2px;
  left:0;
  width:0;
  opacity:.9;
  transition: transform .25s ease, width .25s ease, opacity .25s ease;
  pointer-events:none;
}

.panel{ display:none; scroll-margin-top: var(--headerH, 120px); }
.panel.is-active{ display:block; }

.section{ padding:34px 0; }
.section.alt{ background: #fff; border-top:1px solid rgba(15,23,42,.06); border-bottom:1px solid rgba(15,23,42,.06); }
.section__head{ margin-bottom:16px; }
.section__head h2{ margin:0 0 6px 0; font-size:26px; font-family:"Times New Roman", Times, serif; }
.muted{ color:var(--muted); }
.soft{ color:rgba(71,85,105,.9); }
.subhead{ margin:18px 0 12px; font-family:"Times New Roman", Times, serif; }

.hero--paper{
  background:
    radial-gradient(900px 340px at 20% 10%, rgba(255,255,255,.16), transparent 60%),
    linear-gradient(135deg, var(--primary2), var(--primary));
  color:#fff;
}
.hero__grid{
  display:grid;
  grid-template-columns: 1fr;
  justify-items:center;
  gap:22px;
  align-items:center;
  padding:0 0 18px;
}

.hero__title--center{
  margin:0;
  text-align:center;
  margin-left:auto;
  margin-right:auto;
  width:100%;
}
.hero__title--center::after{
  content:"";
  display:block;
  height:18px;
}
.hero__lead{ max-width:62ch; opacity:.93; }
.hero__cta{ display:flex; gap:10px; flex-wrap:wrap; margin-top:12px; }
.hero__highlights{ display:grid; gap:10px; margin-top:14px; }
.hero__title--center{ text-align:center; }
.t-tnr{ font-family:"Times New Roman", Times, serif; font-weight:800; letter-spacing:.6px; }
.t-tnr--small{ font-size: clamp(16px, 1.7vw, 22px); opacity:.95; letter-spacing: .4px; }
.t-tnr--big{ font-size: clamp(26px, 3.2vw, 44px); }
.pill{
  display:inline-block;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.10);
  font-size:12px;
  margin:0 0 10px 0;
}

.slider{
  background: rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  border-radius: var(--radius);
  padding:10px;
}
.slider__frame{
  position:relative;
  border-radius: calc(var(--radius) - 6px);
  overflow:hidden;
  aspect-ratio: 16/9;
  background: rgba(255,255,255,.10);
}

.homeMeta--slider .slider__frame{
  aspect-ratio: auto !important;
  height: clamp(420px, 52vw, 640px) !important;
}
@media (max-width: 768px){
  .homeMeta--slider .slider__frame{
    height: clamp(260px, 70vw, 420px) !important;
  }
}

.slider__img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:0;
  transform: scale(1.03);
  transition: opacity .75s cubic-bezier(.2,.8,.2,1), transform 1.05s cubic-bezier(.2,.8,.2,1);
}
.slider__img.is-active{ opacity:1; transform: scale(1); }
.slider__dots{
  display:flex;
  gap:8px;
  justify-content:center;
  margin-top:10px;
}
.dot{
  width:10px; height:10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.35);
  background: rgba(255,255,255,.12);
  cursor:pointer;
}
.dot.is-active{ background:#fff; border-color:#fff; }

.grid{ display:grid; gap:14px; }
.grid--2{ grid-template-columns: repeat(2, 1fr); }
.grid--3{ grid-template-columns: repeat(3, 1fr); }
.grid--4{ grid-template-columns: repeat(4, 1fr); }

.two-col{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:14px;
}

.card{
  background:#fff;
  color: var(--ink);
  border:1px solid var(--line);
  border-radius: var(--radius);
  padding:16px;
  box-shadow: var(--shadow);
}
.card h3{ margin:0 0 8px 0; font-family:"Times New Roman", Times, serif; }
.cardImg{
  height:160px;
  border-radius: 14px;
  border:1px solid rgba(15,23,42,.10);
  background:#f1f5f9;
  background-size:cover;
  background-position:center;
  margin-bottom:10px;
}
.cardsRow{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap:12px;
  margin-top:12px;
}
.program{ text-decoration:none; position:relative; overflow:hidden; }
.program--focus{
  border-color: rgba(239,26,6,.18);
  background: linear-gradient(180deg, #fff, rgba(239,26,6,.03));
}
.tag{
  display:inline-block;
  font-size:11px;
  color:#fff;
  background: linear-gradient(90deg, var(--primary), var(--accent));
  padding:6px 10px;
  border-radius:999px;
  margin-bottom:10px;
}
.link{ color: var(--primary); font-weight:700; font-size:12px; text-decoration:none; }
.program:hover .link{ text-decoration:underline; }

.mini-card{
  border:1px solid rgba(15,23,42,.12);
  border-radius: 14px;
  padding:12px;
  background: rgba(255,255,255,.08);
}
.mini-card--light{
  background: rgba(0,0,0,.22);
  border-color: rgba(255,255,255,.24);
}
.mini-card span{ display:block; opacity:.92; }

.softBox{
  border:1px solid rgba(15,23,42,.10);
  border-radius: 14px;
  padding:12px;
  background: linear-gradient(180deg, #fff, rgba(15,23,42,.02));
}
.h4{ margin:0 0 6px 0; font-size:14px; font-weight:700; color:var(--ink); }

.chips{ display:grid; gap:10px; margin-top:10px; }
.chipBox{
  background: #f2f3f5;
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 16px;
  padding: 14px 14px 12px;
}
.chipBox strong{
  display:block;
  margin-bottom:6px;
  font-size:13px;
  color:var(--ink);
}
.chipBox span{
  display:inline-block;
  margin:6px 6px 0 0;
  padding:6px 10px;
  border-radius: 999px;
  background:#e5e7eb;
  border:1px solid rgba(15,23,42,.08);
  font-size:12px;
  color:#111827;
}

.btn{
  appearance:none;
  border: 1px solid rgba(112,15,6,.45);
  background: #A4281C;
  color:#fff;
  padding:11px 14px;
  border-radius: 999px;
  font-weight:800;
  cursor:pointer;
  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  line-height:1;
  box-shadow: 0 10px 22px rgba(112,15,6,.22);
  text-shadow: 0 1px 0 rgba(0,0,0,.12);
}
.btn--small{ padding:9px 12px; font-size:12px; }
.btn:hover{ transform: translateY(-1px); box-shadow: 0 10px 22px rgba(15,23,42,.10); }
.btn--primary{
  background: #A4281C;
  color:#fff;
  border: 1px solid rgba(112,15,6,.45);
  box-shadow: 0 10px 22px rgba(112,15,6,.22);
  text-shadow: 0 1px 0 rgba(0,0,0,.12);
}
.btn--primary:hover{ filter: brightness(1.03); transform: translateY(-1px); }
.btn--primary:active{ transform: translateY(0px); }
.btn--primary:hover{ box-shadow: 0 14px 26px rgba(164,40,28,.18); }
.btn--ghost{ background: linear-gradient(180deg, #EF1A06 0%, #A4281C 55%, #700F06 100%); color:#fff; border: 1px solid rgba(112,15,6,.45); }
.btn--light{
  background:#fff;
  border-color: rgba(255,255,255,.35);
  color: var(--primary2);
}
.btn--ghostLight{
  background: transparent;
  border-color: rgba(255,255,255,.35);
  color:#fff;
}
.cta-row{ display:flex; gap:10px; flex-wrap:wrap; align-items:center; margin-top:10px; }

.map{
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(15,23,42,.10);
  background:#f1f5f9;
  aspect-ratio: 16/9;
}
.map iframe{ width:100%; height:100%; border:0; display:block; }
.map--big{ aspect-ratio: 16/11; }
.mapWrap p{ margin:0 0 12px; }

.socials, .phones{ display:flex; flex-wrap:wrap; gap:8px; margin-top:8px; }
.chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(15,23,42,.12);
  background:#fff;
  text-decoration:none;
  font-size:12px;
  color:var(--ink);
}
.chip:hover{ border-color: rgba(164,40,28,.35); }

.socialIcon{
  width:44px;
  height:44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:14px;
  border:1px solid rgba(15,23,42,.12);
  background: rgba(255,255,255,.92);
  text-decoration:none;
  transition: transform .12s ease, border-color .12s ease, box-shadow .12s ease;
}
.socialIcon:hover{
  transform: translateY(-1px);
  border-color: rgba(164,40,28,.35);
  box-shadow: 0 8px 20px rgba(15,23,42,.10);
}
.socialIcon__img{
  width:30px;
  height:30px;
  display:block;
}

.hours{
  margin-top:10px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(239,26,6,.20);
  background: linear-gradient(180deg, rgba(239,26,6,.06), rgba(164,40,28,.04));
}
.hours strong{ display:block; color:var(--primary2); }
.hours span{ display:block; color:var(--muted); margin-top:4px; font-weight:600; }
.hours--footer{ max-width: 320px; }

.gov .img-slot{
  height:clamp(70px, 10vw, 110px);
  border-radius:14px;
  background:#f1f5f9;
  border:1px dashed rgba(15,23,42,.18);
  margin-bottom:12px;
}
.gov h3{ margin-bottom:6px; }

.tear-top, .tear-bottom{ position:relative; }
.tear-top::before,
.tear-bottom::after{
  content:"";
  position:absolute; left:0; right:0;
  height:30px;
  background:
    radial-gradient(14px 10px at 16px 14px, #ffffff 60%, transparent 61%) repeat-x;
  background-size: 34px 30px;
  pointer-events:none;
}
.tear-top::before{ top:-15px; transform: rotate(180deg); }
.tear-bottom::after{ bottom:-15px; }

.flip-grid{
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: clamp(16px, 2.2vw, 26px);
  align-items: stretch;
}
.flip{ perspective: 1200px; min-height: 560px; }
.flip__inner{
  position: relative;
  min-height: 380px;
  transform-style: preserve-3d;
  transition: transform .7s cubic-bezier(.2,.8,.2,1);
  border-radius: var(--radius);
}

@media (hover:hover) and (pointer:fine){
  .flip:hover .flip__inner,
  .flip:focus-within .flip__inner{ transform: rotateY(180deg); }
}

.flip__face{
  position:absolute; inset:0;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-soft);
  background:#fff;
  padding: 18px;
  display:flex;
  flex-direction:column;
  gap: 10px;
  backface-visibility: hidden;
  overflow: hidden;
}

.flip__front .small{ font-size: 13px; }
.flip__back{
  transform: rotateY(180deg);
  background: linear-gradient(135deg, rgba(164,40,28,.07), rgba(15,23,42,.02));
}

.flip__media{
  height: 150px;
  border-radius: 14px;
  border:1px solid rgba(15,23,42,.10);
  background:#f1f5f9;
  background-size:cover;
  background-position:center;
}

.flip__scroll{
  flex: 1;
  overflow: auto;
  padding-right: 6px;
  scrollbar-width: thin;
}
.flip__scroll::-webkit-scrollbar{ width: 8px; }
.flip__scroll::-webkit-scrollbar-thumb{ background: rgba(15,23,42,.15); border-radius: 999px; }
.flip__scroll::-webkit-scrollbar-track{ background: transparent; }

.miniBlock{
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed rgba(15,23,42,.18);
}
.miniBlock:first-child{ margin-top: 0; padding-top: 0; border-top: none; }

.miniTitle{
  font-weight: 800;
  font-size: 12px;
  letter-spacing: .2px;
  color: rgba(15,23,42,.82);
  text-transform: uppercase;
}

.miniRow{
  display:flex;
  gap:10px;
  justify-content: space-between;
  align-items:flex-start;
  padding: 6px 0;
  border-bottom: 1px dashed rgba(0,0,0,.12);
}
.miniRow:last-child{ border-bottom: none; }
.miniK{
  font-weight: 800;
  font-size: 12px;
  color: rgba(15,23,42,.78);
  white-space: nowrap;
}
.miniV{
  font-size: 12px;
  color: rgba(15,23,42,.78);
  text-align: right;
  max-width: 70%;
}

.flip__actions{
  margin-top: 10px;
  display:flex;
  justify-content:flex-end;
}

.list.compact{ margin:8px 0 0; padding-left:18px; }
.list.compact li{ margin:4px 0; }
.muted.small{ font-size:12.5px; }

.docGrid{
  margin-top:10px;
  padding-top:10px;
  border-top:1px dashed var(--line);
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
}
.docGrid__item .h4{ margin:0 0 6px; font-size:13px; }
@media (max-width: 980px){
  .docGrid{ grid-template-columns:1fr; }
  .flip-grid{
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: clamp(16px, 2.2vw, 26px);
  align-items: stretch;
}
  .flip__inner{ min-height: 380px; }
}
@media (max-width: 560px){
  .flip-grid{
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: clamp(16px, 2.2vw, 26px);
  align-items: stretch;
}
  .flip__inner{ min-height: 380px; }
}

.form{ display:grid; gap:10px; }
label{ font-size:12px; color:var(--muted); font-weight:700; }
input, select, textarea{
  width:100%;
  margin-top:6px;
  padding:11px 12px;
  border-radius: 14px;
  border:1px solid rgba(15,23,42,.14);
  background:#fff;
  font-family: inherit;
  font-size:14px;
  color:var(--ink);
  outline:none;
}
input:focus, select:focus, textarea:focus{
  border-color: rgba(239,26,6,.45);
  box-shadow: 0 0 0 4px rgba(239,26,6,.10);
}

.fbWrap{ border-radius:14px; overflow:hidden; border:1px solid rgba(15,23,42,.10); }

.footer{
  margin-top:0;
  background: #2b0a0a;
  border-top:1px solid rgba(255,255,255,.10);
  color:#fff;
}
.footer__grid{
  display:grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap:14px;
  padding: 12px 0;
}
.footer__grid h3{ margin:0 0 6px 0; font-family:"Times New Roman", Times, serif; }
.footer__bottom{
  display:flex;
  justify-content:flex-start;
  align-items:center;
  flex-wrap:wrap;
  gap:10px;
  padding:12px 0 18px;
  border-top:1px solid rgba(15,23,42,.06);
  color:var(--muted);
  font-size:12px;
}
.link{ color:var(--primary); }

.modal{ position:fixed; inset:0; display:none; z-index:80; }
.modal.is-open{ display:block; }
.modal__backdrop{ position:absolute; inset:0; background: rgba(15,23,42,.55); }
.modal__card{
  position:relative;
  width:min(520px, calc(100% - 28px));
  margin: 10vh auto 0;
  background:#fff;
  border-radius: 20px;
  border:1px solid rgba(15,23,42,.12);
  box-shadow: 0 30px 60px rgba(15,23,42,.25);
  padding:16px;
}
.modal__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.x{
  appearance:none;
  border:0;
  background:#f3f4f6;
  border-radius: 12px;
  width:40px;
  height:40px;
  cursor:pointer;
  font-weight:900;
}
.x:hover{ background:#e5e7eb; }

.wa-float{
  position:fixed;
  right:16px;
  bottom:16px;
  z-index:90;
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border-radius: 999px;
  text-decoration:none;
  color:#fff;
  background: linear-gradient(90deg, var(--primary), var(--accent));
  border:1px solid rgba(255,255,255,.22);
  box-shadow: 0 18px 34px rgba(164,40,28,.22);
  transform: translateZ(0);
}
.wa-float:hover{ box-shadow: 0 22px 40px rgba(164,40,28,.28); transform: translateY(-1px); }
.wa-float__label{ font-weight:800; font-size:13px; letter-spacing:.2px; }
.wa-float__dot{
  width:12px; height:12px; border-radius:999px;
  background:#fff;
  box-shadow: 0 0 0 0 rgba(255,255,255,.55);
  animation: pulse 1.6s infinite;
}
@keyframes pulse{
  0%{ box-shadow: 0 0 0 0 rgba(255,255,255,.55); }
  70%{ box-shadow: 0 0 0 12px rgba(255,255,255,0); }
  100%{ box-shadow: 0 0 0 0 rgba(255,255,255,0); }
}

@media (max-width: 980px){
  .hero__grid{ grid-template-columns:1fr; }
  .cardsRow{ grid-template-columns:1fr; }
  .two-col{ grid-template-columns:1fr; }
  .grid--4{ grid-template-columns: repeat(2, 1fr); }
  .grid--3{ grid-template-columns: repeat(2, 1fr); }
  .flip-grid{
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: clamp(16px, 2.2vw, 26px);
  align-items: stretch;
}
  .footer__grid{ grid-template-columns:1fr; }
  .brand{ min-width: auto; }
}
@media (max-width: 560px){
  .container{ width: min(1280px, calc(100% - (var(--pagePad) * 2))); }
  .topbar__inner{ flex-direction:column; align-items:flex-start; }
  .header__inner{ flex-direction:column; align-items:flex-start; }
  .tabs{ justify-content:flex-start; }
  .tab{ padding:9px 10px; font-size:12px; }
  .grid--2{ grid-template-columns:1fr; }
  .grid--3{ grid-template-columns:1fr; }
  .grid--4{ grid-template-columns:1fr; }
  .flip-grid{
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: clamp(16px, 2.2vw, 26px);
  align-items: stretch;
}
  .modal__card{ margin-top: 6vh; }
}

.miniMeta{
  margin-top: 10px;
  padding: 10px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 14px;
  background: rgba(255,255,255,.7);
}
.miniRow{
  display:flex;
  gap:10px;
  justify-content: space-between;
  align-items:flex-start;
  padding: 6px 0;
  border-bottom: 1px dashed rgba(0,0,0,.12);
}
.miniRow:last-child{ border-bottom: none; }
.miniK{
  font-weight: 700;
  font-size: 12px;
  color: rgba(15,23,42,.78);
  white-space: nowrap;
}
.miniV{
  font-size: 12px;
  color: rgba(15,23,42,.78);
  text-align: right;
  line-height: 1.3;
}

.miniChips{
  margin-top: 10px;
  display: grid;
  gap: 10px;
}
.chipBoxSm{
  background: rgba(148,163,184,.18);
  border: 1px solid rgba(148,163,184,.35);
  border-radius: 14px;
  padding: 10px;
  display:flex;
  flex-direction: column;
  gap: 6px;
}
.chipBoxSm strong{
  font-size: 12px;
  color: rgba(15,23,42,.88);
}
.chipBoxSm span{
  display:inline-block;
  padding: 6px 8px;
  border-radius: 10px;
  background: rgba(148,163,184,.22);
  border: 1px solid rgba(148,163,184,.35);
  font-size: 12px;
  color: rgba(15,23,42,.78);
}
.topbar{ padding:6px 0 !important; }
.header{ padding:10px 0 !important; }
.header__inner{ gap:12px !important; }
.tabs{ gap:14px !important; }

.main{ padding-top:0 !important; }

.hero__title--center{ text-align:center; }
.t-tnr--small{ font-size: clamp(16px, 1.7vw, 22px); opacity:.95; letter-spacing: .4px; }
.t-tnr--big{ font-size: clamp(40px, 4.2vw, 70px) !important; letter-spacing:.8px; display:block; }

.feature-grid .feature-card,
.feature-card{
  background: rgba(255,255,255,.92) !important;
}
.feature-card h3, .feature-card p{ color: rgba(15,23,42,.92) !important; }

.flip__front{ padding-bottom:18px !important; }
.flip__back{ overflow:hidden; }
.flip__back .info-block{ margin-top:10px; padding-top:10px; border-top:1px solid rgba(15,23,42,.10); }
.list--tight li{ margin: 4px 0; }
.chip-row{ display:flex; flex-wrap:wrap; gap:8px; margin-top:10px; }
.btn--link{ background:transparent; border:0; padding:0; color: var(--accent); font-weight:800; cursor:pointer; text-align:left; }
.btn--link:hover{ text-decoration: underline; }

.wa-float{
  padding: 14px 16px !important;
  border-radius: 999px !important;
  box-shadow: 0 12px 28px rgba(0,0,0,.22) !important;
  transform: translateZ(0);
}
.wa-float__text{ font-weight:800 !important; }

.footer{
  background: linear-gradient(135deg, var(--primary), var(--primary2)) !important;
  color: rgba(255,255,255,.92) !important;
  border-top: 1px solid rgba(255,255,255,.12) !important;
}
.footer .muted{ color: rgba(255,255,255,.82) !important; }
.footer a{ color: rgba(255,255,255,.92) !important; }
.footer .logo-slot{
  width: 120px; height: 48px;
  border:1px dashed rgba(255,255,255,.35);
  border-radius: 14px;
  display:flex; align-items:center; justify-content:center;
  font-weight:800;
  color: rgba(255,255,255,.85);
}
.footer .social-slot{
  width:44px; height:44px;
  border:1px dashed rgba(255,255,255,.35);
  border-radius: 14px;
}

.testimonials{ align-items: stretch; }
.quote p{ font-size: 15px; line-height: 1.45; }
.quote span{ display:block; margin-top:10px; font-weight:800; }
.footer__brand{ display:flex; gap:14px; align-items:flex-start; }
.social-icons{ display:flex; gap:10px; flex-wrap:wrap; margin-top:10px; }
.chip--wa{ background: rgba(255,255,255,.16) !important; border:1px solid rgba(255,255,255,.25) !important; }
.chips{ display:flex; flex-wrap:wrap; gap:8px; }
.chips--gray .chip--gray{
  background: rgba(15,23,42,.06);
  border: 1px solid rgba(15,23,42,.10);
  color: rgba(15,23,42,.88);
}
.chip--gray{ padding:6px 10px; border-radius: 999px; font-size: 12px; font-weight:800; }

.sem-grid{ display:grid; grid-template-columns: 1fr; gap:12px; }
.sem{ padding:12px; border:1px solid rgba(15,23,42,.10); border-radius: 16px; background: rgba(255,255,255,.65); }
.sem__t{ display:inline-block; font-weight:900; margin-bottom:8px; }

@media (max-width: 860px){
  .grid--2.testimonials{ grid-template-columns: 1fr !important; }
}

.t-tnr--small{ font-size: clamp(16px, 1.7vw, 22px); opacity:.95; letter-spacing: .4px; }
.t-cambria--big{
  font-family: Cambria, "Times New Roman", serif;
  font-weight: 800;
  text-transform: uppercase;
  color: var(--primary2);
  font-size: clamp(70px, 7.2vw, 130px);
  letter-spacing: 1.2px;
  line-height: 1.03;
}

#panel-inicio .hero--paper{ margin-top:0; }
.hero__title--center{ text-align:center; }

.hero--paper .program{ color:#fff; background: rgba(255,255,255,.10); border-color: rgba(255,255,255,.18); }
.hero--paper .program .muted{ color: rgba(255,255,255,.88); }
.hero--paper .program .link{ color:#fff; opacity:.95; text-decoration: underline; text-underline-offset: 3px; }
.hero--paper .tag{ background: rgba(255,255,255,.16); color:#fff; border-color: rgba(255,255,255,.18); }

.flip__inner{ min-height: 380px; }
.flip__back{ overflow:auto; }

.testimonials{ gap:14px; }

.wa-float{ padding: 14px 18px; right:18px; bottom:18px; }
.wa-float__label{ font-size: 15px; }
.wa-float__dot{ width: 14px; height:14px; }

.panelHero{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:14px;
  margin: 14px 0 18px;
}
.panelHero__media{
  min-height: 220px;
  border-radius: 18px;
  border: 1px solid rgba(15,23,42,.10);
  background:
    radial-gradient(900px 260px at 12% 0%, rgba(255,255,255,.22), transparent 60%),
    linear-gradient(135deg, rgba(164,40,28,.30), rgba(15,23,42,.08));
  background-size: cover;
  background-position: center;
  box-shadow: var(--shadow);
}
.panelHero__gallery{
  display:grid;
  grid-template-columns: repeat(5, 1fr);
  grid-auto-rows: 1fr;
  gap:10px;
  align-content: start;
}
.thumb{
  height: 74px;
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,.10);
  background:
    linear-gradient(135deg, rgba(255,255,255,.12), rgba(0,0,0,.05));
  background-size: cover;
  background-position: center;
  box-shadow: 0 10px 30px rgba(2,6,23,.06);
  opacity: .65;
  transform: translateY(0);
  transition: opacity .25s ease, transform .25s ease, outline-color .25s ease;
}
.thumb.is-active{
  opacity: 1;
  transform: translateY(-2px);
  outline: 2px solid rgba(239,26,6,.28);
  outline-offset: 2px;
}

.voices{
  display:flex;
  justify-content:center;
  gap:16px;
  flex-wrap:wrap;
}
.voices .voiceCard{max-width:520px; flex:1 1 360px;}
.voiceCard{
  border:1px solid rgba(15,23,42,.10);
  border-radius:18px;
  padding:14px;
  background: linear-gradient(180deg,#fff, rgba(164,40,28,.03));
  box-shadow: var(--shadow);
  display:grid;
  grid-template-columns: 130px 1fr;
  gap:14px;
  align-items: stretch;
  min-height: 170px;
}
.voicePhoto{display:none;}
.voiceQuote{
  margin: 0;
  color: var(--ink);
  line-height: 1.5;
  font-size: 14px;
}
.voiceMeta{
  margin-top: 10px;
  color: var(--muted);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: .2px;
}
.voiceCard.fade-in{
  animation: fadeIn .45s ease both;
}
@keyframes fadeIn{
  from{ opacity:.2; transform: translateY(4px); }
  to{ opacity:1; transform: translateY(0); }
}

.cardImg, .img-slot{
  width:100%;
  height: 140px;
  border-radius: 16px;
  border: 1px solid rgba(15,23,42,.10);
  margin-bottom: 10px;
  background:
    radial-gradient(900px 260px at 12% 0%, rgba(255,255,255,.24), transparent 60%),
    linear-gradient(135deg, rgba(164,40,28,.25), rgba(15,23,42,.08));
  background-size: cover;
  background-position: center;
}

.btn.btn--primary, .btn.btn--small.btn--primary{
  background: #A4281C;
  color:#fff;
  border: 1px solid rgba(112,15,6,.45);
  box-shadow: 0 10px 22px rgba(112,15,6,.22);
  text-shadow: 0 1px 0 rgba(0,0,0,.12);
}
.btn--primary:hover{ filter: brightness(1.03); transform: translateY(-1px); }
.btn--primary:active{ transform: translateY(0px); }
.btn.btn--primary:hover, .btn.btn--small.btn--primary:hover{
  transform: translateY(-1px);
  filter: brightness(1.03);
}
.btn--small{
  padding: 10px 12px;
  font-size: 12px;
}

.hero--paper .program h3,
.hero--paper .program .muted,
.hero--paper .program .link{
  color:#fff !important;
}
.hero--paper .program .muted{ opacity:.92; }

@media (max-width: 900px){
  .panelHero{ grid-template-columns: 1fr; }
  .panelHero__media{ min-height: 200px; }
  .panelHero__gallery{ grid-template-columns: repeat(5, 1fr); }
  .thumb{ height: 64px; }
}
@media (max-width: 720px){
  .voices{ grid-template-columns: 1fr; }
  .voiceCard{ grid-template-columns: 1fr; }
  .voicePhoto{display:none;}
  .panelHero__gallery{ grid-template-columns: repeat(4, 1fr); }
}

.reveal{ opacity:1; transform:none; filter:none; }
.reveal.is-in{ animation: revealUp .55s ease both; }
@keyframes revealUp{
  from{ opacity:0; transform: translateY(12px); filter: blur(1px); }
  to{ opacity:1; transform: translateY(0); filter: blur(0); }
}

.container{
  width: min(1280px, calc(100% - (var(--pagePad) * 2)));
  margin: 0 auto;
}
.section{ padding: 56px 0; }
.section.alt{ padding: 56px 0; }
.section__head{ margin-bottom: 18px; }
.section__head h2{ margin: 0 0 6px; }
.section__head .muted{ margin: 0; }

.grid{ gap: 16px; }
.grid--2{ gap: clamp(16px, 2.2vw, 26px); }
.grid--3{ gap: clamp(16px, 2.2vw, 26px); }
.two-col{ gap: 20px; align-items: start; }

.card{ padding: 18px; }

.header{ padding: 8px 0 !important; }
.header__inner{ gap: 12px; flex-wrap: wrap; }
.brand{ min-width: 240px; }
.brand__img{ width: 54px; height: 54px; object-fit: contain; }

.tabs{
  flex: 1 1 560px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  align-items: center;
  padding: 4px 0;
}

.tab{
  appearance: none;
  border: 1px solid rgba(15,23,42,.12);
  background: rgba(255,255,255,.9);
  color: rgba(15,23,42,.86);
  padding: 10px 14px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: .2px;
  line-height: 1;
  cursor: pointer;
  transition: transform .12s ease, background-color .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease;
}

.tab:hover{
  border-color: rgba(164,40,28,.28);
  box-shadow: 0 8px 22px rgba(15,23,42,.08);
  transform: translateY(-1px);
}

.tab.is-active{
  background: linear-gradient(135deg, var(--primary), var(--accent));
  color: #fff;
  border-color: transparent;
}

.tab:focus-visible{
  outline: 3px solid rgba(164,40,28,.22);
  outline-offset: 2px;
}

@media (max-width: 860px){
  .tabs{ justify-content: flex-start; }
}

@media (max-width: 520px){
  .brand{ min-width: 0; }
  .tab{ padding: 9px 12px; font-size: 12px; }
}

.flip-grid{
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: clamp(16px, 2.2vw, 26px);
  align-items: stretch;
}
.flip__inner{ min-height: 360px; }
.flip__face{
  position:absolute; inset:0;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-soft);
  background:#fff;
  padding: 18px;
  display:flex;
  flex-direction:column;
  gap: 10px;
  backface-visibility: hidden;
  overflow: hidden;
}
.flip__media{ height: 170px; }
.flip__back p{ margin: 0; }
.flip__back .chips{ margin-top: 10px; gap: 8px; }

.hero .card{
  background: rgba(255,255,255,.92);
}
.hero .card h3,
.hero .card p,
.hero .card a{ color: rgba(15,23,42,.92); }
.hero .card .link{ color: var(--primary); font-weight: 800; }

.mod-card .btn,
.mod-card a.btn,
.flip .btn,
.flip a.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:44px;
  border-radius:999px;
  padding:12px 16px;
  margin-top:14px;
  box-sizing:border-box;
  position:static !important;
  transform:none !important;
}

.mod-card{ display:flex; flex-direction:column; }
.mod-card .chips{ margin-top:auto; }
.mod-card .btn{ margin-bottom:0; }

.section.tear-bottom{ padding-bottom: 86px; }
.section.hero--paper.tear-bottom{ padding-bottom: 80px; }

.hero .feature-cards .card,
.hero .mini-cards .mini-card,
.hero .featured .card{
  background: rgba(255,255,255,.92) !important;
  border: 1px solid rgba(255,255,255,.35);
}
.hero .featured .card h3,
.hero .featured .card p,
.hero .featured .card a,
.hero .feature-cards .card h3,
.hero .feature-cards .card p,
.hero .feature-cards .card a{
  color: rgba(15,23,42,.92) !important;
}
.hero .featured .badge,
.hero .feature-cards .badge{
  background: rgba(164,40,28,.12) !important;
  color: #7f1d1d !important;
  border: 1px solid rgba(164,40,28,.22) !important;
}

.hero .featured .card,
.hero .feature-cards .card{
  opacity: 1 !important;
}

.tear-top::before,
.tear-bottom::after{
  z-index: 0;
}
.tear-top > *,
.tear-bottom > *{
  position: relative;
  z-index: 1;
}

.hero .featured .card,
.hero .feature-cards .card{
  background: rgba(255,255,255,.94) !important;
  border: 1px solid rgba(255,255,255,.28) !important;
}
.hero .featured .card *,
.hero .feature-cards .card *{
  color: rgba(15,23,42,.92) !important;
}
.hero .featured .card a,
.hero .feature-cards .card a{
  color: var(--primary) !important;
  font-weight: 800 !important;
}
.hero .featured .badge,
.hero .feature-cards .badge{
  background: rgba(164,40,28,.14) !important;
  color: #7f1d1d !important;
  border: 1px solid rgba(164,40,28,.24) !important;
}

.mod-card{ display:flex; flex-direction:column; min-height: 360px; }
.mod-card .chips{ margin-top:auto; }
.mod-cta{ margin-top: 14px; }
.mod-cta .btn{ width:100%; }

.tear-bottom::after{ z-index:0; pointer-events:none; }
.section, .hero, .page-section{ position:relative; }
.section > *, .hero > *{ position:relative; z-index:1; }

.section.tear-bottom{ padding-bottom: 110px !important; }

.flip__front .btn{
  margin-top:auto;
  align-self:flex-start;
}

.chips--semesters{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 16px;
}
.chipBox__cols{
  display:block;
  margin-top: 10px;
}
.chipCol em{
  display:block;
  font-style: normal;
  font-weight: 800;
  font-size: 12px;
  letter-spacing: .02em;
  color: rgba(17,24,39,.75);
  margin-bottom: 6px;
}
.chipWrap span{
  display:inline-block;
  margin: 6px 6px 0 0;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(15,23,42,.06);
  border: 1px solid rgba(15,23,42,.08);
  font-size: 12px;
  color: #111827;
}
@media (max-width: 820px){
  .chipBox__cols{
  display:block;
  margin-top: 10px;
}
}

.panelHero__media{ aspect-ratio: 16 / 9; min-height: 220px; }
.flip__media{ aspect-ratio: 16 / 9; height:auto; min-height: 150px; }
.cardImg{ aspect-ratio: 16 / 9; height:auto; min-height: 160px; }

.cardsRow .card,
.cardsRow .card *{
  color: rgba(15,23,42,.92) !important;
}
.cardsRow .card{
  background: rgba(255,255,255,.95) !important;
}
.cardsRow .card .muted{ color: rgba(15,23,42,.72) !important; }
.cardsRow .card .link{ color: var(--primary) !important; font-weight: 800 !important; }

.hero.tear-bottom{ padding-bottom: 92px; }

.flip__face{
  position:absolute; inset:0;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-soft);
  background:#fff;
  padding: 18px;
  display:flex;
  flex-direction:column;
  gap: 10px;
  backface-visibility: hidden;
  overflow: hidden;
}
.flip__front{ overflow:hidden; }
.flip__front p{
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  overflow: hidden;
}
.flip__front .chip-row{ flex-wrap:wrap; gap:6px; }
.flip__front .btn{ margin-top:auto !important; }

.flip .btn,
.flip a.btn{
  width:100%;
  margin-top:auto !important;
}

.chips--semesters{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 16px;
}
.chipBox{
  background: #f2f3f5;
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 16px;
  padding: 14px 14px 12px;
}
.chipBox__head{ display:flex; align-items:baseline; justify-content:space-between; gap:10px; }
.chipBox__head strong{ letter-spacing:.3px; }

.topbar__actions .btn{ cursor:pointer; }

.heroBanner{
  width: 100vw;
  max-width: none;
  height: clamp(120px, 18vw, 220px);
  margin: 0 0 14px;
  border-radius: 0;
  background: #efe7e6 center/cover no-repeat;
  background-image: var(--banner-image, url('Artboard_1.jpg'));
  box-shadow: none;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

.t-cambria--big{
  font-family: Cambria, "Times New Roman", serif;
  font-weight: 800;
  text-transform: uppercase;
  color: var(--primary2);
  font-size: clamp(70px, 7.2vw, 130px);
  letter-spacing: 1.2px;
  line-height: 1.03;
}

.hero__highlights{
  display:flex;
  justify-content:center;
  gap: 12px;
  flex-wrap:wrap;
}
.mini-card--light{
  background: rgba(255,255,255,.92);
  color: var(--ink);
  border: 1px solid rgba(20,20,20,.08);
}
.mini-card--light strong{ color: var(--ink); }

.btn--outlinePrimary{
  border: 2px solid var(--primary);
  color: var(--primary);
  background: transparent;
}
.btn--outlinePrimary:hover{
  background: rgba(164,40,28,.08);
}

.featured .card,
.featuredGrid .card{
  position: relative;
  background: linear-gradient(135deg, rgba(164,40,28,.14) 0%, rgba(255,255,255,.92) 58%, rgba(112,15,6,.10) 100%);
  border: 1px solid rgba(164,40,28,.20);
  box-shadow: 0 16px 34px rgba(17,24,39,.10);
}
.featuredGrid .card::before{
  content:"";
  position:absolute; inset:0;
  border-radius: inherit;
  background: radial-gradient(circle at 20% 20%, rgba(239,26,6,.12), transparent 55%);
  pointer-events:none;
}
.featuredGrid .card,
.featuredGrid .card *{ color: var(--ink) !important; }
.featuredGrid .card .muted{ color: rgba(15,23,42,.78) !important; }
.featuredGrid .card a{ color: var(--primary) !important; }
.featured .card .muted,
.featuredGrid .card .muted{ color: rgba(25,25,25,.72) !important; }

.flip__front{
  display:flex;
  flex-direction:column;
}
.flip__front .chip-row{ margin-bottom: 10px; }
.flip__front .btn{ align-self:flex-start; }
.flip__cta{
  margin-top: 10px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.flip__cta .btn{ margin-top:0; }

.chipWrap{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top: 8px;
}
.chipWrap span{
  display:inline-flex;
  align-items:center;
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(112,15,6,.06);
  border: 1px solid rgba(112,15,6,.12);
  color: rgba(20,20,20,.86);
  line-height: 1.1;
}

.chipBox--compact{ padding: 14px; }
.chip-grid--tight{ display:flex; flex-wrap:wrap; gap:8px; }
.chip-grid--tight .chip--gray{ margin:0; }

.footer{
  color: rgba(255,255,255,.92);
}
.footer a{ color: rgba(255,255,255,.92); }
.footer .muted{ color: rgba(255,255,255,.78) !important; }

.wa-float{ background: none !important; }
.wa-float.btn--primary{ }

.flip__front h3{
  text-align:center;
  font-size: 20px;
  margin-top: 2px;
}
.flip__front p.muted{
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.flip__front .btn{
  margin-top: auto;
  width: 100%;
  justify-content:center;
}

footer, .footer{ color: rgba(255,255,255,.92); }
footer a, .footer a{ color: rgba(255,255,255,.95); }

.flip__actions{
  margin-top: auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
@media (min-width: 900px){
  .flip__actions{ grid-template-columns: 1fr; }
}

.homeSplit{ display:grid; grid-template-columns: 1fr 1.25fr; gap: clamp(16px, 2.2vw, 26px); align-items: start; margin-top: 14px; }
.homeMeta{ background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.22); border-radius: var(--radius); padding: 16px; }
.homeMeta .hero__lead{ margin: 0 0 10px; }
.homeMeta .hero__cta{ margin-top: 10px; }
.homeMeta .hero__highlights{ margin-top: 10px; display:grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.homeFeatured .cardsRow{ margin: 0; }

.cardsRow{ display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 14px; }
@media (max-width: 740px){ .cardsRow{ grid-template-columns: 1fr; } }
.card.program.program--focus{
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(245,246,248,.92));
  border: 1px solid rgba(0,0,0,.10);
}
.card.program.program--focus h3{ color:#111; }
.card.program.program--focus .muted{ color: rgba(17,17,17,.75); }

.card.program.program--focus .tag{
  display:inline-flex;
  border-radius: 999px;
  padding: 6px 10px;
  border: 1px solid rgba(164,40,28,.55);
  color: var(--primary);
  background: rgba(255,255,255,.9);
  font-weight: 800;
  letter-spacing: .02em;
}

.btn.btn--primary, a.btn.btn--primary{
  background: #A4281C;
  box-shadow: 0 10px 24px rgba(0,0,0,.18);
}
.btn.btn--primary:hover, a.btn.btn--primary:hover{ filter: brightness(1.03); transform: translateY(-1px); }
.wa-float.btn.btn--primary{ background: #A4281C; color:#fff !important; border: none !important; }

.flip-grid{ gap: 22px; }
.flip__inner{ min-height: 480px; }
.flip__face{ overflow: hidden; }
.flip__front{ overflow:hidden; }
.flip__back{ overflow-y:auto; overflow-x:hidden; padding-right: 10px; }
.flip__actions{ display:flex; gap:10px; margin-top:auto; flex-wrap:wrap; }
.flip__actions .btn{ flex: 1 1 auto; }
.flip__actions--back{ margin-top: 12px; }
.flip.is-flipped .flip__inner{ transform: rotateY(180deg); }
@media (hover:hover){
  .flip:hover .flip__inner,
  .flip:focus-within .flip__inner{ transform: rotateY(180deg); }
}
@media (max-width: 820px){
  .homeSplit{ grid-template-columns: 1fr; }
  .homeMeta .hero__highlights{ grid-template-columns: 1fr; }
  .flip__inner{ min-height: 560px; }
}

.subjectsBlock{ margin-top: 18px; }
.subjectsBlock h3{ margin: 0 0 10px; }
.semesterGrid{ display:grid; grid-template-columns: repeat(auto-fit, minmax(340px, 1fr)); gap: 14px; }
.semCard{ background: rgba(255,255,255,.9); border: 1px solid var(--line); border-radius: 16px; padding: 12px; }
.semHead{ font-weight: 900; letter-spacing: .06em; font-size: 12px; color: #111; margin-bottom: 10px; }
.semCols{ display:grid; grid-template-columns: 1fr; gap: 10px; }
.semLabel{ font-size: 12px; font-weight: 800; color: rgba(17,17,17,.75); margin-bottom: 6px; }
.chipWrap{ display:flex; flex-wrap:wrap; gap: 8px; }
.chip.chip--solid{ background: #eef0f3; border: 1px solid rgba(0,0,0,.08); }

#panel-ae .chipBox{ margin-top: 14px; }

.btn, .btn:visited { text-decoration:none; }
.btn--primary{
  background: #A4281C;
  color:#fff;
  border:1px solid rgba(255,255,255,.12);
  box-shadow: 0 10px 24px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.18);
}
.btn--primary:hover{ filter: brightness(1.03); transform: translateY(-1px); }
.btn--primary:active{ transform: translateY(0); filter: brightness(.98); }

.btn--wa{ background: linear-gradient(180deg, var(--accent) 0%, var(--primary) 70%, var(--primaryDark) 100%); }

.homeSplit{ display:flex; gap:24px; align-items:flex-start; }
.homeMeta{ flex: 0 0 44%; }
.homeFeatured{ flex: 1; }

.homeFeatured .program{
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(164,40,28,.28);
  box-shadow: 0 14px 30px rgba(0,0,0,.10);
}
.homeFeatured .program h3{ color:#111; }
.homeFeatured .program .tag{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(164,40,28,.6);
  color: var(--primary);
  background: rgba(255,255,255,.45);
  font-weight:700;
}

.flip-grid{
  display:grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap:16px;
}
@media (max-width: 1200px){
  .flip-grid{
    grid-template-columns: none;
    grid-auto-flow: column;
    grid-auto-columns: minmax(260px, 1fr);
    overflow-x:auto;
    padding-bottom:10px;
    scroll-snap-type:x mandatory;
  }
  .flip-grid > .flip{ scroll-snap-align: start; }
}

.flip__back{ overflow:hidden; }
.flip__back .flip__content{ overflow:auto; max-height: 420px; padding-right: 6px; }
@media (max-width: 720px){
  .flip__back .flip__content{ max-height: 56vh; }
}
.flip__actions{ display:flex; gap:10px; justify-content:center; margin-top:12px; }

.flip__front .cta-row, .flip__back .flip__actions{ position: relative; z-index: 3; }
.flip__inner{ position:relative; }

.semesterGrid{
  display:flex;
  gap:14px;
  overflow-x:auto;
  padding-bottom:10px;
}
.semesterCard{
  min-width: 320px;
  flex: 0 0 auto;
}
@media (max-width: 720px){
  .semesterCard{ min-width: 86vw; }
}

.homeSplit{grid-template-columns: 1fr 1fr; }
.homeMeta{grid-column:1;}
.homeFeatured{grid-column:2;}

.btn,
.btn--primary,
.btn--wa,
.btn--outlinePrimary,
.btn--ghost,
.btn--ghostLight,
.btn--light{
  background: linear-gradient(90deg, var(--primary), var(--accent));
  color:#fff !important;
  border:1px solid rgba(255,255,255,.22);
  box-shadow: 0 14px 26px rgba(164,40,28,.24);
}
.btn:hover{ filter: brightness(1.05); transform: translateY(-1px); }
.btn:active{ transform: translateY(0); filter: brightness(.98); }
.btn--link{ color: var(--accent); }
.wa-float{ background: linear-gradient(90deg, var(--primary), var(--accent)) !important; }

.flip-grid{
  display:grid;
  grid-template-columns: repeat(5, minmax(220px, 1fr));
  gap:14px;
  align-items: stretch;
}
@media (max-width: 1200px){
  .flip-grid{
    grid-template-columns: repeat(5, 260px);
    overflow-x:auto;
    padding-bottom: 10px;
    scroll-snap-type: x mandatory;
  }
  .flip-grid > .flip{ scroll-snap-align: start; }
}
.flip{ min-height: 520px; }
.flip__face{ overflow:hidden; }
.flip__back .flip__content{ max-height: 380px; overflow-y:auto; padding-right: 8px; }
.flip__back .flip__content::-webkit-scrollbar{ width:10px; }
.flip__back .flip__content::-webkit-scrollbar-thumb{ background: rgba(255,255,255,.25); border-radius: 999px; }
.flip__back .flip__actions{ margin-top: 12px; }
.flip__front h3{ text-align:center; }

.homeFeatured .program{ color:#0f172a; }
.homeFeatured .program h3{ color:#0b1220; }
.homeFeatured .program .muted{ color: rgba(15,23,42,.75); }
.homeFeatured .program .link{ color: #A4281C; font-weight:800; }

.homeFeatured .tag{
  color:#A4281C;
  background: rgba(255,255,255,.92);
  border:1px solid rgba(239,26,6,.45);
  border-radius: 999px;
  padding:6px 10px;
  font-weight:800;
  box-shadow: 0 10px 18px rgba(112,15,6,.10);
}

.flip-grid{
  display:grid;
  grid-template-columns: repeat(5, minmax(220px, 1fr));
  gap: clamp(16px, 2.2vw, 26px);
  align-items: stretch;
}
@media (max-width: 1200px){
  .flip-grid{
    display:flex;
    overflow-x:auto;
    overflow-y:hidden;
    padding-bottom: 12px;
    scroll-snap-type: x proximity;
  }
  .flip-grid::-webkit-scrollbar{ height: 10px; }
  .flip-grid::-webkit-scrollbar-thumb{ background: rgba(164,40,28,.55); border-radius: 999px; }
  .flip{ flex: 0 0 290px; scroll-snap-align: start; }
}
.flip__back{ overflow:auto; }
.flip__actions{ margin-top:auto; display:flex; gap:10px; flex-wrap:wrap; }
.flip__actions .btn{ flex: 1 1 auto; }
.flip__actions--back{ position: sticky; bottom: 0; padding-top: 10px; background: linear-gradient(180deg, rgba(255,255,255,0) 0%, #fff 45%); }

a[data-open="lead-modal"], button[data-open="lead-modal"]{ }

.btn, a.btn, button.btn, input.btn[type="submit"], input.btn[type="button"]{
  background: linear-gradient(180deg, var(--accent) 0%, var(--primary) 70%, var(--primaryDark) 100%) !important;
  color: #fff !important;
  border: 1px solid rgba(112,15,6,.45) !important;
  box-shadow: 0 10px 24px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.18) !important;
  text-shadow: 0 1px 0 rgba(0,0,0,.12) !important;
}
.btn:visited{ color:#fff !important; }

.btn--light, .btn--ghostLight, .btn--outlinePrimary{
  background: linear-gradient(180deg, var(--accent) 0%, var(--primary) 70%, var(--primaryDark) 100%) !important;
  color:#fff !important;
  border-color: rgba(112,15,6,.45) !important;
}

.btn--link{ background:transparent !important; box-shadow:none !important; border:0 !important; color: var(--accent) !important; }

.flip__front{ z-index:2; }
.flip__back{ z-index:1; }
.flip.is-flipped .flip__front{ z-index:1; }
.flip.is-flipped .flip__back{ z-index:2; }

.btn--light,
.btn--ghostLight,
.btn--outlinePrimary,
a.btn--light,
a.btn--ghostLight,
a.btn--outlinePrimary{
  background: linear-gradient(180deg, #EF1A06 0%, #A4281C 55%, #700F06 100%) !important;
  color:#fff !important;
  border: 1px solid rgba(112,15,6,.45) !important;
  box-shadow: 0 10px 22px rgba(112,15,6,.22) !important;
  text-shadow: 0 1px 0 rgba(0,0,0,.12);
}
.btn--light:hover,
.btn--outlinePrimary:hover,
.btn--ghostLight:hover{ filter: brightness(1.05) !important; transform: translateY(-1px); }

.flip-grid--five{
  grid-template-columns: repeat(5, minmax(220px, 1fr));
}
@media (max-width: 1100px){
  .flip-grid--five{
    grid-template-columns: repeat(5, minmax(240px, 1fr));
    overflow-x: auto;
    padding-bottom: 10px;
    scroll-snap-type: x mandatory;
  }
  .flip-grid--five > .flip{ scroll-snap-align: start; min-width: 240px; }
}

.flip.is-flipped .flip__inner{ transform: rotateY(180deg); }
.flip__title{ text-align:center; }
.chip-row--center{ justify-content:center; flex-wrap: wrap; }
.flip__hint{ text-align:center; margin-top: 10px; }

.flip{ min-height: 520px; }
.flip__inner{ min-height: 520px; cursor: pointer; }

.flip__scroll{
  max-height: 260px;
  overflow-y: auto;
  padding-right: 8px;
}
.flip__scroll::-webkit-scrollbar{ width: 10px; }
.flip__scroll::-webkit-scrollbar-thumb{
  background: rgba(164,40,28,.35);
  border-radius: 999px;
}
.flip__actions--single{ margin-top: 14px; display:flex; justify-content:center; }

a.btn{ color:#fff; }

.btn--light,
.btn--outlinePrimary,
.btn--outline,
.btn--secondary,
.btn--ghost{
  background: linear-gradient(180deg, #EF1A06 0%, #A4281C 55%, #700F06 100%) !important;
  color:#fff !important;
  border: 1px solid rgba(112,15,6,.45) !important;
  box-shadow: 0 10px 22px rgba(112,15,6,.22) !important;
  text-decoration:none !important;
}
.btn--outlinePrimary:hover,
.btn--outline:hover,
.btn--light:hover,
.btn--secondary:hover,
.btn--ghost:hover{
  filter: brightness(1.02) saturate(1.03) !important;
  transform: translateY(-1px);
}

a.btn, button.btn{ color:#fff !important; }

.homeFeatured .tag{
  background:#f2f3f5 !important;
  border:1px solid rgba(15,23,42,.12) !important;
  color: var(--ink) !important;
}
.homeFeatured .program h3{
  color: var(--primary2) !important;
}

.govGrid{ grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)) !important; }
.gov{ text-align:center; }
.gov .applies{ margin: 6px 0 10px; font-weight:700; color: var(--primary2); }
.gov .muted{ margin-left:auto; margin-right:auto; }

.btn, a.btn, button.btn, input.btn {
  background: linear-gradient(180deg, var(--accent2) 0%, var(--primary) 55%, var(--primaryDark) 100%) !important;
  color: #fff !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  box-shadow: 0 12px 22px rgba(112,15,6,.22) !important;
  text-decoration: none !important;
  -webkit-font-smoothing: antialiased;
}
.btn:hover, a.btn:hover, button.btn:hover, input.btn:hover {
  filter: brightness(1.05) !important;
  transform: translateY(-1px);
}
.btn:active, a.btn:active, button.btn:active, input.btn:active {
  transform: translateY(0px);
  filter: brightness(.98) !important;
}
.btn--light, .btn--ghostLight, .btn--outlinePrimary, .btn--link {
  background: linear-gradient(180deg, var(--accent2) 0%, var(--primary) 55%, var(--primaryDark) 100%) !important;
  color: #fff !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  box-shadow: 0 12px 22px rgba(112,15,6,.22) !important;
  text-decoration: none !important;
}

.actions, .flip__actions, .topbar__actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}
.actions .btn, .flip__actions .btn, .topbar__actions .btn {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

:root{
  --paper: #f6f1e6;
  --paper2:#fbf8f1;
  --ink:#151515;
  --ink2:#2a2a2a;
  --rule: rgba(21,21,21,.14);
  --shadowSoft: 0 18px 45px rgba(17,24,39,.10);
  --btnGrad: linear-gradient(180deg, var(--accent) 0%, var(--primary) 58%, var(--dark) 100%);
}

body{
  background:
    radial-gradient(1200px 700px at 20% -10%, rgba(164,40,28,.08), transparent 55%),
    radial-gradient(1200px 700px at 80% -10%, rgba(239,26,6,.06), transparent 55%),
    repeating-linear-gradient(0deg, rgba(21,21,21,.018) 0 1px, transparent 1px 6px),
    linear-gradient(180deg, var(--paper2), var(--paper));
  color: var(--ink);
}

.section__head h2,
.section__head h3,
.panel h2{
  letter-spacing:.02em;
}
.section__head{
  position:relative;
}
.section__head:after{
  content:"";
  display:block;
  height:1px;
  background: var(--rule);
  margin-top:12px;
}

.tabs{
  background: rgba(251,248,241,.72);
  border:1px solid rgba(21,21,21,.10);
  box-shadow: 0 14px 30px rgba(17,24,39,.08);
}
.tab{
  font-family: "Times New Roman", Times, serif;
  letter-spacing:.02em;
}
.tab--focus{
  position:relative;
  background: linear-gradient(180deg, rgba(255,255,255,.82), rgba(246,241,230,.92));
  border:1px solid rgba(21,21,21,.12);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.8);
}
.tab--focus:after{
  content:"";
  position:absolute;
  left:12px;
  right:12px;
  bottom:6px;
  height:2px;
  background: linear-gradient(90deg, transparent, rgba(164,40,28,.95), transparent);
}
.tab.is-active{
  background: rgba(164,40,28,.10);
  border:1px solid rgba(164,40,28,.28);
}

.btn,
a.btn,
button.btn,
input.btn,
input.btn[type="submit"],
input.btn[type="button"],
.topbar__actions a,
.topbar__actions button,
.form__actions a,
.form__actions button{
  background: var(--btnGrad) !important;
  color:#fff !important;
  border: 1px solid rgba(112,15,6,.55) !important;
  box-shadow: 0 14px 28px rgba(164,40,28,.18) !important;
}

.btn--outlinePrimary,
.btn--light,
.btn--ghostLight,
a.btn--outlinePrimary,
a.btn--light,
a.btn--ghostLight,
button.btn--outlinePrimary,
button.btn--light,
button.btn--ghostLight{
  background: var(--btnGrad) !important;
  color:#fff !important;
  border: 1px solid rgba(112,15,6,.55) !important;
}

.btn:hover,
a.btn:hover,
button.btn:hover,
input.btn:hover{
  filter: brightness(1.04) !important;
  transform: translateY(-1px);
}
.btn:active,
a.btn:active,
button.btn:active,
input.btn:active{
  transform: translateY(0);
  filter: brightness(.98) !important;
}

.card a[href^="#panel-"]{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:38px;
  padding:10px 14px;
  border-radius:999px;
  background: var(--btnGrad) !important;
  color:#fff !important;
  border: 1px solid rgba(112,15,6,.55) !important;
  text-decoration:none !important;
  font-weight:800;
}

.card .tag,
.card .pill,
.card .badge{
  background: #eef0f3 !important;
  color: #1f2937 !important;
  border:1px solid rgba(31,41,55,.18) !important;
}

.card h3,
.card .card__title,
.card .t-cardTitle{
  color: var(--primaryDark);
}

.card,
.box,
.panelBox,
.mod-card,
.flip{
  background:
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(246,241,230,.92));
  border: 1px solid rgba(21,21,21,.10);
  box-shadow: var(--shadowSoft);
}

:root{
  --btnGrad: linear-gradient(180deg, #EF1A06 0%, #A4281C 60%, #700F06 100%);
}

.btn,
a.btn,
button.btn,
input.btn[type="submit"],
input.btn[type="button"],
button,
input[type="submit"],
input[type="button"],
a[data-open],
a[data-open-lead],
button[data-open],
button[data-open-lead],
a[href^="https://wa.me"],
a[href*="whatsapp" i],
.form__actions button,
.topbar__actions .btn,
.flip__actions .btn,
.mod-card .btn,
.card a[href^="#panel-"]{
  background: var(--btnGrad) !important;
  background-color: #A4281C !important;
  color: #fff !important;
  -webkit-text-fill-color: #fff !important;
  border: 1px solid rgba(112,15,6,.65) !important;
  box-shadow: 0 12px 24px rgba(164,40,28,.22) !important;
  text-decoration: none !important;
}

.tabs__btn,
.tab,
.nav__link,
.topbar__nav a{
  background: initial !important;
  background-color: initial !important;
  box-shadow: initial !important;
}

.btn--outline,
.btn--outlinePrimary,
.btn--light,
.btn--ghost,
.btn--ghostLight,
.btn--secondary,
a.btn--outline,
a.btn--outlinePrimary,
a.btn--light,
a.btn--ghost,
a.btn--ghostLight,
a.btn--secondary,
button.btn--outline,
button.btn--outlinePrimary,
button.btn--light,
button.btn--ghost,
button.btn--ghostLight,
button.btn--secondary{
  background: var(--btnGrad) !important;
  background-color: #A4281C !important;
  color:#fff !important;
  -webkit-text-fill-color:#fff !important;
}

.btn:hover,
a.btn:hover,
button:hover,
input[type="submit"]:hover,
input[type="button"]:hover,
a[data-open]:hover,
button[data-open]:hover,
a[href^="https://wa.me"]:hover{
  filter: brightness(1.06) !important;
  transform: translateY(-1px);
}
.btn:active,
a.btn:active,
button:active,
input[type="submit"]:active,
input[type="button"]:active,
a[data-open]:active,
button[data-open]:active,
a[href^="https://wa.me"]:active{
  filter: brightness(.98) !important;
  transform: translateY(0);
}

.btn,
a.btn,
button.btn,
input[type="submit"],
input[type="button"],
a[data-open],
button[data-open],
a[href^="https://wa.me"],
a[href^="https://api.whatsapp.com"],
.form__actions button,
.form__actions a{
  background: linear-gradient(180deg, #EF1A06 0%, #A4281C 100%) !important;
  color: #fff !important;
  border: 1px solid #700F06 !important;
  box-shadow: 0 10px 22px rgba(164,40,28,.28) !important;
  text-decoration: none !important;
}

.btn:hover,
a.btn:hover,
button.btn:hover,
input[type="submit"]:hover,
input[type="button"]:hover,
a[data-open]:hover,
button[data-open]:hover,
a[href^="https://wa.me"]:hover,
a[href^="https://api.whatsapp.com"]:hover{
  background: linear-gradient(180deg, #A4281C 0%, #700F06 100%) !important;
  color:#fff !important;
}

.btn--outline,
.btn--ghost,
.btn--light,
.btn.is-outline,
a.btn--outline,
a.btn--ghost,
a.btn--light{
  background: linear-gradient(180deg, #EF1A06 0%, #A4281C 100%) !important;
  color:#fff !important;
  border-color:#700F06 !important;
}

.wa-float{
  padding: 14px 18px !important;
  background: linear-gradient(180deg, #EF1A06 0%, #A4281C 100%) !important;
  border: 1px solid #700F06 !important;
}
.wa-float__label{ font-size:14px !important; }

.topbar__link{
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  color: var(--primary) !important;
  font-weight: 800;
  text-decoration: none;
  position: relative;
}
.topbar__link::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:-4px;
  height:2px;
  background: rgba(164,40,28,.85);
  transform: scaleX(0);
  transform-origin:left;
  transition: transform .2s ease;
}
.topbar__link:hover::after{ transform: scaleX(1); }

.tabs{
  background: rgba(255,255,255,.58);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 18px;
  padding: 10px 12px;
  box-shadow: 0 10px 30px rgba(20,16,10,.08);
}
.tab{
  background: transparent !important;
  border: 0 !important;
  padding: 10px 10px !important;
  border-radius: 12px;
  color: rgba(20,16,10,.78);
  font-weight: 700;
}
.tab:hover{ background: rgba(0,0,0,.04) !important; }
.tab.is-active{
  background: transparent !important;
  color: var(--primary) !important;
  box-shadow: inset 0 -2px 0 rgba(164,40,28,.95);
}
.tab--key{
  color: rgba(112,15,6,.90) !important;
  font-weight: 900;
  letter-spacing: .3px;
}

.grid--5.govGrid{
  grid-template-columns: repeat(5, minmax(170px, 1fr));
}
@media (max-width: 1100px){
  .grid--5.govGrid{ grid-template-columns: repeat(3, minmax(180px, 1fr)); }
}
@media (max-width: 720px){
  .grid--5.govGrid{ grid-template-columns: repeat(2, minmax(160px, 1fr)); }
}

.hero__media .slider{
  max-width: none;
  width: 100%;
  margin: 10px 0 0;
}
.hero__media .slider__frame{
  height: clamp(320px, 36vw, 520px);
  aspect-ratio: auto;
  position: relative;
}
@media (max-width: 720px){
  .hero__media .slider__frame{ height: clamp(200px, 48vw, 320px); }
}

.topbar__actions .topbar__link{
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  color: var(--ink) !important;
  font-weight: 800;
  letter-spacing: .01em;
}
.topbar__actions .topbar__link:hover{
  color: var(--primary) !important;
}

.tabs{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap: nowrap;
  overflow-x:auto;
  overflow-y:hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  background: rgba(251,248,241,.86) !important;
  border: 0 !important;
  box-shadow: 0 10px 24px rgba(17,24,39,.06) !important;
  padding: 10px 12px !important;
  border-radius: 18px !important;
}
.tabs::-webkit-scrollbar{ height: 8px; }
.tabs::-webkit-scrollbar-thumb{ background: rgba(164,40,28,.22); border-radius: 99px; }
.tabs::-webkit-scrollbar-track{ background: rgba(0,0,0,.05); border-radius: 99px; }

.tab{
  background: rgba(255,255,255,.78) !important;
  border: 0 !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.9) !important;
  color: var(--ink) !important;
  padding: 10px 14px !important;
  border-radius: 999px !important;
  white-space: nowrap;
  position: relative;
}
.tab::after{
  content:"";
  position:absolute;
  left:14px;
  right:14px;
  bottom:6px;
  height:2px;
  background: rgba(164,40,28,.0);
  border-radius:99px;
  transition: background .2s ease, transform .2s ease;
  transform: scaleX(.2);
  transform-origin:center;
}
.tab.is-active{
  background: rgba(255,255,255,.96) !important;
  color: var(--primary) !important;
}
.tab.is-active::after{
  background: rgba(164,40,28,.92);
  transform: scaleX(1);
}

.tab--key{
  font-weight: 900 !important;
}

.wa-float{
  background: linear-gradient(180deg, #EF1A06 0%, #A4281C 100%) !important;
  color: #fff !important;
  border: 1px solid rgba(112,15,6,.55) !important;
  box-shadow: 0 18px 34px rgba(164,40,28,.22) !important;
}

.siteHeader{
  position:relative;
  top:auto;
  z-index:50;
  background:#fff;
  backdrop-filter:none;
  border-bottom:1px solid var(--line);
}

.tabs{
  flex-wrap: wrap !important;
  overflow: visible !important;
  overflow-x: visible !important;
  overflow-y: visible !important;
  scrollbar-width: none !important;
}
.tabs::-webkit-scrollbar{ height:0 !important; }
@media (max-width: 900px){
  .tabs{
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin !important;
  }
  .tabs::-webkit-scrollbar{ height: 8px !important; }
  .tabs::-webkit-scrollbar-thumb{
    background: rgba(164,40,28,.20) !important;
    border-radius: 999px !important;
  }
}

.tab{
  background: rgba(255,255,255,.70) !important;
  border: 1px solid rgba(164,40,28,.10) !important;
  color: rgba(17,24,39,.86) !important;
}
.tab:hover{
  background: rgba(255,255,255,.92) !important;
}
.tab.is-active{
  color: var(--primary) !important;
  background: rgba(255,255,255,.96) !important;
  border-color: rgba(164,40,28,.18) !important;
}

.topbar__actions a:not(.btn){
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
  color: rgba(17,24,39,.92) !important;
  font-weight: 700 !important;
  text-decoration: none !important;
}
.topbar__actions a:not(.btn):hover{
  color: var(--primary) !important;
  text-decoration: underline !important;
  text-underline-offset: 4px;
}

button.btn,
a.btn,
.btn,
input[type="submit"].btn,
input[type="button"].btn{
  background: #A4281C;
  background-image: linear-gradient(180deg, #EF1A06 0%, #A4281C 70%, #700F06 100%) !important;
  color: #fff !important;
  border: 1px solid #700F06 !important;
  opacity: 1 !important;
}
button.btn:hover,
a.btn:hover,
.btn:hover,
input[type="submit"].btn:hover,
input[type="button"].btn:hover{
  background-image: linear-gradient(180deg, #A4281C 0%, #700F06 100%) !important;
  color:#fff !important;
}

.btn--outline, .btn--ghost, .btn--light, .btn--pill{
  background: var(--primary) !important;
  background-image: linear-gradient(180deg, #EF1A06 0%, #A4281C 70%, #700F06 100%) !important;
  color:#fff !important;
  border-color:#700F06 !important;
}

.wa-float{
  background: var(--primary) !important;
  background-image: none !important;
  border: 1px solid rgba(112,15,6,.45) !important;
  padding: 14px 18px !important;
}
.wa-float *{ color:#fff !important; }

.modal__card{
  max-height: calc(100vh - 90px) !important;
  overflow: auto !important;
  margin: 6vh auto 0 !important;
}
@media (max-width: 520px){
  .modal__card{
    margin: 12px auto 0 !important;
    max-height: calc(100vh - 24px) !important;
  }
}

.header{
  position: sticky !important;
  top: 0 !important;
  z-index: 95 !important;
  backdrop-filter: blur(8px);
}

.btn,
a.btn,
button.btn,
input[type="submit"],
input[type="button"],
.modal__actions .btn,
.modal__actions button.btn{
  background: #A4281C;
  color: #ffffff !important;
  border: 1px solid #700F06 !important;
  box-shadow: 0 10px 24px rgba(164,40,28,.28) !important;
  opacity: 1 !important;
}

.btn:hover,
a.btn:hover,
button.btn:hover{
  background: linear-gradient(180deg, #A4281C 0%, #700F06 100%) !important;
  color:#fff !important;
}

.tab{
  background: rgba(255,255,255,.85) !important;
  color: var(--ink) !important;
  border: 1px solid rgba(15,23,42,.10) !important;
  box-shadow: none !important;
  padding: 10px 12px !important;
  border-radius: 999px !important;
}
.tab:hover{
  background: rgba(255,255,255,.95) !important;
  color: var(--primary) !important;
}
.tab.is-active{
  background: rgba(255,255,255,.98) !important;
  border-color: rgba(164,40,28,.22) !important;
  color: var(--primary) !important;
  box-shadow: 0 10px 26px rgba(15,23,42,.08) !important;
}
.tab--featured{
  border-color: rgba(164,40,28,.28) !important;
}

.tabs{ gap:10px !important; }
.tab{ border-width: 1px !important; }

.wa-float{
  background: #A4281C !important;
  background-image: none !important;
  border: 1px solid #700F06 !important;
  opacity: 1 !important;
}
.wa-float:hover{ background:#700F06 !important; }

.topbar__link{
  background: transparent !important;
  border: 0 !important;
  color: #700F06 !important;
  box-shadow: none !important;
  padding: 6px 4px !important;
}
.topbar__link:hover{
  text-decoration: underline;
  text-underline-offset: 4px;
}

.btn,
a.btn,
button.btn,
input.btn,
.btn--ghostLight,
.btn--ghost,
.btn--outline,
.btn--light,
.topbar__actions .btn,
.cta-row .btn,
.modal__actions .btn,
.card .btn,
.section .btn,
.panel .btn{
  background: #A4281C;
  color: #ffffff !important;
  border-color: #700F06 !important;
}

.btn:hover,
a.btn:hover,
button.btn:hover,
input.btn:hover,
.btn--ghostLight:hover,
.btn--ghost:hover,
.btn--outline:hover,
.btn--light:hover{
  background: linear-gradient(180deg, #A4281C 0%, #700F06 100%) !important;
  color:#fff !important;
}

.wa-float{
  background: #A4281C !important;
  border: 1px solid #700F06 !important;
  color:#fff !important;
}
.wa-float:hover{ background:#700F06 !important; }

.tabs{
  overflow: visible !important;
}
.tab{
  background: rgba(255,255,255,.85) !important;
  color: #1f2937 !important;
  border: 1px solid rgba(112,15,6,.14) !important;
  box-shadow: none !important;
}
.tab:hover{
  background: rgba(255,255,255,.98) !important;
}
.tab.is-active{
  background: #ffffff !important;
  color: #700F06 !important;
  border-color: rgba(112,15,6,.22) !important;
}
.tab--key{
  font-weight: 900 !important;
  color: #A4281C !important;
}
.tab--key.is-active{
  color: #700F06 !important;
}

.topbar__actions a:not(.btn){
  border: 0 !important;
  background: transparent !important;
  color: #111827 !important;
}

.siteHeader{
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
}

.tabs{
  display:flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  align-items:center !important;
  gap:10px 12px !important;
  padding: 12px 14px !important;
  overflow: visible !important;
  background: rgba(250, 247, 242, .92) !important;
  border: 1px solid rgba(15,23,42,.06) !important;
  border-radius: 18px !important;
}
.tabs::-webkit-scrollbar{ height:0 !important; }
.tab{
  background: rgba(255,255,255,.92) !important;
  color: #2b1b1b !important;
  border: 1px solid rgba(15,23,42,.10) !important;
  border-radius: 999px !important;
  padding: 10px 14px !important;
  font-weight: 700 !important;
}
.tab:hover{ color:#700F06 !important; border-color: rgba(112,15,6,.22) !important; }
.tab.is-active{
  color:#700F06 !important;
  background: rgba(255,255,255,.98) !important;
  border-color: rgba(112,15,6,.28) !important;
  box-shadow: 0 8px 18px rgba(17,24,39,.08) !important;
}

.tab--featured{
  color:#700F06 !important;
  border-color: rgba(112,15,6,.22) !important;
  background: rgba(255,255,255,.96) !important;
}

.btn,
a.btn,
button.btn,
input[type="submit"],
input[type="button"],
button:not(.tab):not(.x),
a[data-open],
button[data-open],
a[data-open-lead],
button[data-open-lead],
a[href^="https://wa.me"],
a[href^="https://api.whatsapp.com"],
a[href*="whatsapp" i],
.form__actions button,
.form__actions a,
.modal__actions button,
.modal__actions a{
  background: #A4281C !important;
  background-image: none !important;
  color:#fff !important;
  -webkit-text-fill-color:#fff !important;
  border: 1px solid #700F06 !important;
  opacity: 1 !important;
}

.wa-float{
  background:#A4281C !important;
  background-image:none !important;
  border:1px solid #700F06 !important;
  color:#fff !important;
  opacity:1 !important;
  padding: 16px 20px !important;
  box-shadow: 0 14px 28px rgba(164,40,28,.28) !important;
}
.wa-float__dot{ background:#fff !important; }

.modal__card{
  max-height: calc(100vh - 120px) !important;
  overflow: auto !important;
}
.modal__card::-webkit-scrollbar{ width:10px; }
.modal__card::-webkit-scrollbar-thumb{
  background: rgba(112,15,6,.25);
  border-radius: 10px;
}

.tabs{ opacity:1 !important; filter:none !important; }
.tabs .tab{
  background: rgba(255,255,255,.92) !important;
  color: #1f2937 !important;
  border: 1px solid rgba(15,23,42,.14) !important;
  border-radius: 999px !important;
  padding: 10px 14px !important;
  font-weight: 600 !important;
  letter-spacing: .2px !important;
  box-shadow: none !important;
  opacity: 1 !important;
}
.tabs .tab:hover{
  background: rgba(164,40,28,.06) !important;
  color: var(--primary) !important;
  border-color: rgba(164,40,28,.22) !important;
}
.tabs .tab.is-active{
  background: rgba(164,40,28,.08) !important;
  color: var(--primary) !important;
  border-color: rgba(164,40,28,.28) !important;
}
.tabs .tab--featured{
  background: rgba(164,40,28,.05) !important;
  border-color: rgba(164,40,28,.22) !important;
  color: var(--primary2, #700F06) !important;
  font-weight: 700 !important;
}

.tabs .tab.btn,
.tabs .tab[class*="btn"]{
  background: rgba(255,255,255,.92) !important;
  color:#1f2937 !important;
  border:1px solid rgba(15,23,42,.14) !important;
  box-shadow:none !important;
}

.wa-float{
  background: #A4281C !important;
  background-image: none !important;
  color: #fff !important;
  border: 1px solid #700F06 !important;
  opacity: 1 !important;
  padding: 12px 18px !important;
  min-height: 44px !important;
}

.program--center{ text-align:center !important; }
.program--center .tag{ display:inline-flex !important; margin-inline:auto !important; }
.program__media{
  width:100%;
  height:88px;
  border-radius:16px;
  background: #e6e0d8;
  border: 1px solid rgba(15,23,42,.10);
  margin: 6px 0 12px 0;
}
.program__media--ae{ background: linear-gradient(180deg, rgba(164,40,28,.10), rgba(230,224,216,.85)); }
.program__media--bteg{ background: linear-gradient(180deg, rgba(112,15,6,.10), rgba(230,224,216,.85)); }
.program__media--prepa{ background: linear-gradient(180deg, rgba(239,26,6,.08), rgba(230,224,216,.85)); }
.program__media--cursos{ background: linear-gradient(180deg, rgba(31,41,55,.06), rgba(230,224,216,.85)); }

.program__media{
  background-position:center;
  background-repeat:no-repeat;
  background-size:cover;
}
.program__media--ae{ background-image: url('images/destacadas/ae.jpg'); }
.program__media--bteg{ background-image: url('images/destacadas/bteg.jpg'); }
.program__media--prepa{ background-image: url('images/destacadas/prepa.jpg'); }
.program__media--cursos{ background-image: url('images/destacadas/cursos.jpg'); }

.tabs .tab,
button.tab{
  opacity: 1 !important;
  color: #2b2b2b !important;
  -webkit-text-fill-color: #2b2b2b !important;
  background: rgba(255,255,255,.96) !important;
  border-color: rgba(112,15,6,.16) !important;
}
.tabs .tab--featured{
  color: #700F06 !important;
  -webkit-text-fill-color: #700F06 !important;
  background: rgba(164,40,28,.06) !important;
  border-color: rgba(164,40,28,.18) !important;
}
.tabs .tab.is-active{
  color: #A4281C !important;
  -webkit-text-fill-color: #A4281C !important;
  background: rgba(164,40,28,.08) !important;
  border-color: rgba(164,40,28,.22) !important;
}

button.tab,
.tabs .tab{ box-shadow:none !important; filter:none !important; transform:none !important; }

.voiceQuote{font-size:15px; line-height:1.6; text-align:center;}
.voiceMeta{margin-top:10px; text-align:center; font-weight:700; color:var(--ink);}

.footer .muted{color:rgba(255,255,255,.80)!important;}
.footer h3,.footer .h4{color:#fff!important;}
.footer a{color:#fff;}
.footer .chip{background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.18); color:#fff;}

.panelHero__media{aspect-ratio: 16/9; min-height:220px; max-height:360px; width:100%; background-size:cover; background-position:center;}

.panelHero__gallery .thumb{width:44px; height:34px;}
@media (max-width: 720px){.panelHero__media{min-height:180px; max-height:260px;} .panelHero__gallery .thumb{width:38px; height:30px;}}

.voicesGrid{ align-items: stretch; }
.voiceFlip .flip__inner{ min-height: 320px; }
.voiceFlip .flip__front{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  padding: 22px 22px 18px;
  text-align:center;
}
.voiceFlip .flip__back{
  padding: 18px 18px 16px;
}
.voiceText{
  font-family: "Times New Roman", serif;
  font-size: 18px;
  line-height: 1.35;
  color: var(--ink);
}
.voiceName{
  margin-top: 14px;
  font-size: 14px;
  letter-spacing: .02em;
  color: var(--primary2);
}
.voiceName strong{
  display:block;
  font-size: 16px;
  color: var(--primary);
}
@media (max-width: 720px){
  .voiceFlip .flip__inner{ min-height: 280px; }
  .voiceText{ font-size: 16px; }
}

.voces-viewport{
  max-width: 1100px;
  margin: 0 auto;
}
.voces-track{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.25rem;
  align-items: stretch;
  min-height: 240px;
}
.voces-card{
  background: #fff;
  border: 1px solid rgba(112,15,6,.12);
  border-radius: 16px;
  padding: 1.6rem 1.5rem;
  box-shadow: 0 18px 36px rgba(0,0,0,.06);
  text-align: center;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
}
.voces-text{
  margin:0 0 0.9rem 0;
  line-height: 1.65;
  color:#1b1b1b;
  font-style: italic;
}
.voces-name{
  margin-top:auto;
  margin:0;
  font-weight: 900;
  letter-spacing: .01em;
  color:#700F06;
}
.voces-mod{
  display:block;
  margin-top:.35rem;
  font-weight: 800;
  font-size: .92rem;
  color:#A4281C;
}
.voces-card.is-enter{
  animation: vocesEnter .65s cubic-bezier(.2,.8,.2,1) both;
}
@keyframes vocesEnter{
  from{ opacity:0; transform: translateY(10px); filter: blur(1px); }
  to{ opacity:1; transform: translateY(0); filter: blur(0); }
}
@media (max-width: 820px){
  .voces-track{ grid-template-columns: 1fr; }
}

.homeMeta__slider{ margin-bottom:14px; }
.homeMeta__slider .slider{ padding:10px; background: rgba(255,255,255,.06); }
.homeMeta__slider .slider__frame{ aspect-ratio: 4/3; }
@media (max-width: 860px){
  .homeMeta__slider .slider__frame{ aspect-ratio: 16/9; }
}

.homeSplit{ display:grid; grid-template-columns: 1fr 1.25fr; gap: clamp(16px, 2.2vw, 26px); align-items:start; }
.homeMeta{ grid-column:1; }
.homeFeatured{ grid-column:2; }

.program__media{
  position: relative;
  overflow: hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#f4f1ec;
}
.program__img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}

.homeSplit{ display:grid; grid-template-columns: 1.1fr 1fr; gap: 22px; align-items: start; }
.homeFeatured{ margin-top: 0; }
.homeFeatured .cardsRow{ display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
@media (max-width: 820px){
  .homeSplit{ grid-template-columns: 1fr; }
  .homeFeatured .cardsRow{ grid-template-columns: 1fr; }
}

.program__media{
  border-radius: 14px;
  overflow:hidden;
  background: rgba(244,241,236,1);
  border:1px solid rgba(112,15,6,.10);
  height: 110px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom: 10px;
}
.program__img{
  width:100%;
  height:100%;
  object-fit: cover;
}

.wa-float{
  background: #A4281C !important;
  border-color: #700F06 !important;
  box-shadow: 0 12px 28px rgba(112,15,6,.25) !important;
  padding: 14px 16px !important;
}
.wa-float__label{ color:#fff !important; font-weight:800; }

.modal__dialog{
  max-height: 85vh;
  overflow: auto;
}

.panelHeroSimple{
  width:100%;
  display:flex;
  justify-content:center;
  margin: 1.25rem 0 2.25rem;
}
.panelHeroSimple img{
  width: min(980px, 100%);
  height: auto;
  display:block;
  object-fit: contain;
  border-radius: 18px;
  background: rgba(244,241,236,0.9);
  box-shadow: 0 18px 40px rgba(0,0,0,0.18);
  padding: 14px;
}
@media (max-width: 720px){
  .panelHeroSimple img{
    padding: 10px;
    border-radius: 14px;
  }
}

.socialIcon img{
  width: 28px;
  height: 28px;
  object-fit: contain;
  display: block;
  opacity: .92;
}
.socialIcon:hover img{ opacity: 1; transform: scale(1.08); }

.social-slot img{
  width: 30px;
  height: 30px;
  object-fit: contain;
  display: block;
  opacity: .92;
}
.social-slot:hover img{ opacity: 1; transform: scale(1.08); }

.logo-slot img{
  max-width: 140px;
  height: auto;
  display: block;
}

.gov .img-slot{
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  background-color: #f4f1ec;
  border-radius: 12px;
  min-height: 90px;
}

.govGrid .gov:nth-child(1) .img-slot{ background-image:url("images/validez/sep.jpg"); }
.govGrid .gov:nth-child(2) .img-slot{ background-image:url("images/validez/dgeti.jpg"); }
.govGrid .gov:nth-child(3) .img-slot{ background-image:url("images/validez/dgcft.jpg"); }
.govGrid .gov:nth-child(4) .img-slot{ background-image:url("images/validez/conaip.jpg"); }
.govGrid .gov:nth-child(5) .img-slot{ background-image:url("images/validez/tsu.jpg"); }
.govGrid .gov:nth-child(6) .img-slot{ background-image:url("images/validez/conocer.jpg"); }
.logo-slot{
  margin-top: 12px;
}

.logo-slot img{
  max-width: 140px;
  height: auto;
  display: block;
}
footer,
footer p,
footer span,
footer small,
footer a{
  color: #ffffff;
}

footer a{
  opacity: .9;
}

footer a:hover{
  opacity: 1;
}

footer{
  background: linear-gradient(180deg, #8e1c12 0%, #6f140d 100%);
}

.footer-grid{
  display: grid;
  grid-template-columns: 1.1fr 1.6fr 1.3fr 1fr;
  align-items: flex-end;
  gap: 28px;
}

.footer-logo img{
  max-width: 140px;
  height: auto;
  display: block;
  margin-top: 24px;
}

footer,
footer p,
footer span,
footer small,
footer a,
.footer-info,
.footer-info strong{
  color: #ffffff !important;
}

.footer-info .schedule{
  opacity: .9;
  line-height: 1.5;
}

.footer-contact span{
  background: rgba(255,255,255,.12);
  border-radius: 999px;
  padding: 6px 12px;
  font-size: 13px;
}

.footer-socials{
  margin-top: 24px;
}

.footer-socials .socials{
  display: flex;
  gap: 14px;
  align-items: flex-end;
}

.footer-socials a{
  border: none !important;
  outline: none !important;
}

.footer-socials img{
  width: 28px;
  height: 28px;
  object-fit: contain;
  display: block;
  opacity: .9;
  background: none;
}

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

.footer-socials .socials{
  display: flex;
  gap: 16px;
  align-items: flex-end;
}

.footer-socials a{
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none !important;
  outline: none !important;
  background: none;
}

.footer-socials img{
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  display: block;
  margin: auto;
  opacity: .9;
}

.footer-socials a:hover img{
  opacity: 1;
  transform: scale(1.05);
}

footer *{
  color: #ffffff !important;
}

footer .footer-grid,
footer .footerGrid,
footer .footer__grid,
footer .grid-footer{
  align-items: flex-end !important;
}

footer .logo-slot,
footer .footer-logo,
footer .footerLogo,
footer .brand,
footer .footer-brand{
  align-self: flex-end !important;
  margin-top: 20px !important;
  padding-top: 20px !important;
}

footer .logo-slot img,
footer .footer-logo img,
footer .footerLogo img,
footer .brand img,
footer .footer-brand img{
  display: block;
  max-width: 150px;
  height: auto;
}

footer .schedule,
footer .horarios,
footer .hours,
footer .footer-info,
footer .footerInfo{
  color: #ffffff !important;
  opacity: 1 !important;
}

footer .schedule * ,
footer .horarios * ,
footer .hours * ,
footer .footer-info * ,
footer .footerInfo *{
  color: #ffffff !important;
  opacity: 1 !important;
}

footer .social-row,
footer .footer-socials,
footer .footerSocials{
  margin-top: 14px;
}

footer .social-row a,
footer .footer-socials a,
footer .footerSocials a,
footer a.social-slot{
  border: none !important;
  background: transparent !important;
  outline: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
  text-decoration: none !important;
}

footer a.social-slot:focus,
footer .social-row a:focus{
  outline: none !important;
}
footer a.social-slot:focus-visible,
footer .social-row a:focus-visible{
  outline: 2px solid rgba(255,255,255,.45) !important;
  outline-offset: 3px;
  border-radius: 10px;
}

footer a.social-slot,
footer .social-row a{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
}

footer a.social-slot img,
footer .social-row img{
  width: 28px;
  height: 28px;
  object-fit: contain;
  display: block;
}

footer a.social-slot,
footer .social-row a{
  font-size: 0;
  line-height: 0;
}
footer a.social-slot img,
footer .social-row a img{
  font-size: initial;
  line-height: initial;
}

footer a.social-slot:hover img,
footer .social-row a:hover img{
  transform: translateY(-2px);
  opacity: 1;
}

footer.footer .footer__grid{
  align-items: flex-end !important;
}

footer.footer .footer__brand{
  align-self: flex-end !important;
}

footer.footer .footer__brand .logo-slot{
  margin-top: 0 !important;
  padding-top: 40px !important;
  padding-left: 18px !important;
}

footer.footer .footer__brand .logo-slot img{
  display: block !important;
  max-width: 150px !important;
  height: auto !important;
  transform: translate(-18px, 18px) !important;
}

.section, .panel{ background: var(--bg); }
.card, .panelCard, .flip, .legalCard{ background: var(--card); }

.hero__title--center{ text-align:center; }
.hero__kicker{
  display:block;
  font-family:"Open Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight:600;
  font-size: clamp(16px, 2.1vw, 24px);
  letter-spacing:.08em;
  text-transform:uppercase;
  opacity:.95;
}
.hero__brand{
  display:block;
  font-family:"Times New Roman", Times, serif;
  font-weight:700;
}
.hero__brand-top{
  display:block;
  font-size: clamp(38px, 4.2vw, 66px);
  letter-spacing:.12em;
}
.hero__brand-main{
  gap: clamp(8px, 1.2vw, 16px);
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  width:100%;
  max-width: 1280px;
  text-align:center;
  font-size: clamp(53px, 9vw, 135px);
  line-height:1;
  margin-top: clamp(10px, 1.6vw, 18px);
  letter-spacing: 0;
  white-space:nowrap;
  margin: 10px auto 0;
  padding-inline: clamp(2px, 1.2vw, 16px);
  box-sizing:border-box;
}
.hero__brand-main > span{
  display:block;
  flex:0 0 auto;
}

.legalCard{
  border:1px solid rgba(15,23,42,.10);
  border-radius: 16px;
  padding: 18px;
  box-shadow: var(--shadow);
}
.legalText{
  margin: 0 0 12px;
  font-family:"Open Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--ink);
  line-height:1.6;
}
.legalText:last-child{ margin-bottom:0; }

.footer__grid{ align-items:start; }
.footer__bottom{
  display:flex;
  flex-wrap:wrap;
  gap:10px 14px;
  align-items:center;
  justify-content:space-between;
}
.footer__legal{ opacity:.92; }

:root{
  --primary:#A4281C;
  --primary2:#700F06;
  --accent:#EF1A06;
  --bg:#ffffff;
  --paper:#fbf7f6;
  --ink:#0f172a;
  --muted:#475569;
  --line:rgba(15,23,42,.12);
}

body{
  margin:0;
  font-family:"Open Sans", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  background: #fff;
  color: var(--ink);
}

h1,h2,h3,h4,h5,h6,
.section__head h2,
.section__head h3,
.hero__brand-top,
.hero__brand-main{
  font-family:"Times New Roman", Times, serif;
}

.hero__brand-main{
  font-weight:900;
  font-size: clamp(72px, 10.6vw, 190px);
  letter-spacing: clamp(.16em, 1.6vw, .34em);
  line-height: .92;
  white-space: nowrap;
}

@media (max-width: 560px){
  .hero__brand-main{
    font-size: clamp(54px, 14vw, 120px);
    letter-spacing: .14em;
    white-space: normal;
  }
}

.homeMeta__slider .slider__frame{
  aspect-ratio: auto;
  height: clamp(220px, 28vw, 420px);
}

@media (max-width: 860px){
  .homeMeta__slider .slider__frame{
    height: clamp(180px, 48vw, 320px);
  }
}

.hero__brand-main{
  text-indent: 0 !important;
  margin-left:auto !important;
  margin-right:auto !important;
  max-width: 1200px;
  overflow: hidden;
}

@media (max-width: 720px){
  .hero__brand-main{
    white-space: normal !important;
    letter-spacing: 0.18em !important;
    font-size: clamp(46px, 12.5vw, 96px) !important;
    line-height: 1.02;
  }
}

.slider{
  max-width: 1100px;
  margin-left:auto;
  margin-right:auto;
}
.slider__frame{
  aspect-ratio: 16/9 !important;
  height: clamp(180px, 24vw, 340px) !important;
}

.legalCard{
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: var(--radius);
  padding: clamp(16px, 2.2vw, 26px);
  box-shadow: 0 10px 24px rgba(0,0,0,.08);
}
.legalContent{
  max-width: 78ch;
  margin: 0 auto;
  color: rgba(20,20,20,.92);
  line-height: 1.65;
  font-family: "Open Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}
.legalContent h3{
  margin-top: 18px;
  margin-bottom: 8px;
  font-family: "Times New Roman", Times, serif;
  letter-spacing: .02em;
}
.legalContent p{ margin: 10px 0; }
.legalContent ul{
  margin: 8px 0 14px;
  padding-left: 18px;
}
.legalContent li{ margin: 6px 0; }
.legalLink{ color: #A4281C; font-weight: 700; }
.legalNote{ opacity: .8; font-style: italic; margin-top: 14px; }

.panel .section{ padding-top: 22px; padding-bottom: 22px; }

.homeMeta--slider{
  padding: 0;
  background: transparent;
  border: 0;
}
.homeMeta--slider .slider{
  padding: 0;
  border: 0;
  background: transparent;
  border-radius: 0;
}
.homeMeta--slider .slider__frame{
  border-radius: 0;
  aspect-ratio: auto;
  height: clamp(320px, 58vh, 640px);
}
@media (max-width: 920px){
  .homeSplit{ grid-template-columns: 1fr; }
  .homeMeta--slider .slider__frame{ height: clamp(240px, 46vh, 520px); }
}
.homeMeta--slider .slider__img{ transform: none; }

.hero__title--center{ text-align:center; }
.hero__brand{ display:block; }
.hero__brand-main{
  display:flex;
  justify-content: space-between;
  align-items: baseline;
  width: min(100vw, 1400px);
  margin: 0 auto;
  padding-inline: clamp(4px, 0.6vw, 10px);
  font-family: var(--font-serif, "Times New Roman", Times, serif);
  font-weight: 700;
  line-height: .9;
  font-size: clamp(64px, 10.5vw, 170px);
  letter-spacing: 0;
  white-space: nowrap;
}
.hero__brand-main > span{
  display:inline-block;
  transform: translateY(0);
}

.hero__title, .hero__title--center{ overflow: visible; }

.hero .container.hero__grid{
  width: 100%;
  margin: 0;
}
.hero .hero__copy{ padding-inline: 0; width:100%; display:flex; flex-direction:column; align-items:center; }

.hero .hero__copy{ width:100% !important; display:flex !important; flex-direction:column !important; align-items:center !important; }
.hero .hero__title--center{ width:100% !important; text-align:center !important; margin-left:auto !important; margin-right:auto !important; }
.hero .hero__brand-main{
  width:100% !important;
  max-width:1280px !important;
  margin-left:auto !important;
  margin-right:auto !important;
  justify-content:space-between !important;
  font-size: clamp(92px, 14vw, 230px) !important;
  padding-inline: clamp(2px, 1.2vw, 16px) !important;
}

.hero__brand-main{ overflow: visible !important; }

.hero__title--center{
  width: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
}

.hero__brand-main{
  width: 100% !important;
  max-width: min(1200px, 100% - 40px) !important;
  margin: 10px auto 0 !important;
  padding-inline: 0 !important;
  justify-content: space-between !important;
  font-size: clamp(84px, 11.5vw, 210px) !important;
  line-height: .92 !important;
  white-space: nowrap !important;
}

@media (max-width: 980px){
  .hero__brand-main{
    max-width: min(980px, 100% - 28px) !important;
    font-size: clamp(64px, 12.5vw, 160px) !important;
  }
}

.homeSplit,
.homeFeatured{
  max-width: var(--container, 1200px);
  margin-left: auto;
  margin-right: auto;
}

.homeFeatured{ padding-left: 24px; padding-right: 24px; }

@media (max-width: 720px){
  .homeFeatured{ padding-left: 16px; padding-right: 16px; }
}

.hero .container.hero__grid{
  width: min(1140px, calc(100% - 32px)) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.hero__title--center{
  display: block !important;
  align-items: initial !important;
}

.hero__brand-main{
  width: 100% !important;
  max-width: 100% !important;
  margin: 10px auto 0 !important;
  padding-inline: 6px !important;
  overflow: visible !important;
  font-size: clamp(88px, 12vw, 220px) !important;
  line-height: .95 !important;
  justify-content: space-between !important;
}

.hero__brand-main > span{
  flex: 1 1 0 !important;
  text-align: center !important;
}

.homeSplit{
  width: 100% !important;
  max-width: none !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.homeSplit{
  display: grid !important;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr) !important;
  gap: clamp(22px, 3vw, 44px) !important;
  align-items: start !important;
  margin-top: 18px !important;
}

.homeMeta,
.homeFeatured{
  margin-top: 0 !important;
}

.homeFeatured{
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.homeFeatured .cardsRow{
  margin: 0 !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 16px !important;
}

@media (max-width: 980px){
  .homeSplit{ grid-template-columns: 1fr !important; }
  .homeFeatured .cardsRow{ grid-template-columns: 1fr !important; }
}

.slider__frame{
  position: relative !important;
  width: 100% !important;
  height: clamp(290px, 40vh, 520px) !important;
  aspect-ratio: auto !important;
  overflow: hidden !important;
  border-radius: 18px !important;
}

.slider__img{
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
  opacity: 0 !important;
  transition: opacity .45s ease !important;
}

.slider__img.is-active{ opacity: 1 !important; }

.container{
  width: min(1280px, calc(100% - (var(--pagePad) * 2))) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.homeSplit{
  gap: clamp(18px, 3vw, 44px) !important;
}
:root{
  --container-max: 1296px;
  --pagePad: clamp(14px, 2.2vw, 24px);
}

.container{
  width: min(var(--container-max), calc(100% - (var(--pagePad) * 2))) !important;
  margin-inline: auto !important;
  padding-inline: 0 !important;
}

.panel .container,
.section .container,
main .container{
  padding-inline: 0 !important;
}
:root{

  --container-max: 1368px;
  --pagePad: clamp(14px, 2.2vw, 24px);
}

.container{
  width: min(var(--container-max), calc(100% - (var(--pagePad) * 2))) !important;
  margin-inline: auto !important;
  padding-inline: 0 !important;
}
:root{
  --container-max: 1325px;
  --pagePad: clamp(14px, 2.2vw, 24px);
}

.container{
  width: min(var(--container-max), calc(100% - (var(--pagePad) * 2))) !important;
  margin-inline: auto !important;
  padding-inline: 0 !important;
}
:root{
  --container-max: 1397px;
  --pagePad: clamp(14px, 2.2vw, 24px);
}

.container{
  width: min(var(--container-max), calc(100% - (var(--pagePad) * 2))) !important;
  margin-inline: auto !important;
  padding-inline: 0 !important;
}
.voces-item p {
  margin-bottom: 8px;
}

.voces-item .nombre {
  margin-top: 0;
}
.voces-item p {
  font-style: italic;
}

.voces-item .nombre {
  font-style: normal;
  font-weight: 600;
}
.hero-logo img {
  height: 120px;
  filter: brightness(0) saturate(100%) invert(1);
  opacity: 0.18;
}

.card{ display:flex; flex-direction:column; gap:10px; }
.card > *:last-child{ margin-bottom:0; }

.chips--semesters{ gap:12px; }
.chipBox--compact{ padding:12px 12px 10px; border-radius:16px; }
.chipBox__head{ display:flex; justify-content:space-between; gap:10px; align-items:baseline; margin-bottom:6px; }
.chip-grid{ display:flex; flex-wrap:wrap; gap:8px; }
.chip-grid--tight{ gap:8px; }
.chips--inline{ gap:12px; }

.flip.is-flipped .flip__inner{ transform: rotateY(180deg); }
.flip__hint{ font-size:12px; margin-top:auto; }

.flip-grid--bteg{ grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.flip--bteg{ min-height: 420px; }
.flip--bteg .flip__inner{ min-height: 420px; }
.flip--bteg .flip__title{ margin:0; }
.flip__back--red{
  background: linear-gradient(135deg, var(--primary2), var(--primary));
  color:#fff;
}
.flip__back--red h3{ color:#fff; font-family:"Times New Roman", Times, serif; }
.flip__back--red .chip{ background: rgba(255,255,255,.10); border-color: rgba(255,255,255,.22); color:#fff; }
.chip--invert{ background: rgba(255,255,255,.12) !important; border-color: rgba(255,255,255,.25) !important; color:#fff !important; }

.newsSocialTop{ margin-bottom:14px; display:flex; align-items:center; justify-content:space-between; gap:12px; text-align:left; }
.newsSocialTop__title{ margin:0 0 4px 0; }
.newsSocialTop__sub{ margin:0 0 10px 0; }
.socials--center{ justify-content:center; }

.socialViewer{ margin-top:10px; }
.socialViewer__tabs{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:center;
  margin-bottom:10px;
}
.svTab{
  appearance:none;
  border:1px solid rgba(15,23,42,.14);
  background:#fff;
  border-radius:999px;
  padding:8px 12px;
  font-weight:800;
  cursor:pointer;
}
.svTab.is-active{
  border-color: rgba(239,26,6,.35);
  background: rgba(164,40,28,.06);
  color: var(--primary);
}
.socialViewer__frame{
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(15,23,42,.10);
  background:#f8fafc;
  position:relative;
  min-height:520px;
}
.socialViewer__frame iframe{
  width:100%;
  height:520px;
  border:0;
  display:block;
}
.socialViewer__fallback{
  position:absolute;
  inset:0;
  padding:14px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
  background: rgba(255,255,255,.94);
}

p:last-child{ margin-bottom:0; }

.list{ margin:8px 0 0; padding-left:18px; }
.list li{ margin:6px 0; }
.list li p{ margin:0; }

.newsGrid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:24px;
  align-items:start;
}
@media (max-width: 980px){
  .newsGrid{ grid-template-columns:1fr; }
}
.fbWrap, .igWrap{
  display:flex;
  justify-content:center;
}
.fbWrap iframe{
  width:100%;
  max-width:500px;
}
.igWrap iframe{
  width:100%;
  min-height:520px;
  border:0;
}

.socialCarousel__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}
.socialCarousel__tabs{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.socialTab{
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  border-radius:999px;
  padding:8px 12px;
  font:inherit;
  cursor:pointer;
}
.socialTab.is-active{
  border-color:#A4281C;
  color:#A4281C;
}
.socialPane{ display:none; }
.socialPane.is-active{ display:block; }

.ttWrap{
  display:flex;
  justify-content:center;
}
.ttWrap blockquote{
  width:100%;
}
@media (max-width: 640px){
  .socialCarousel__head{ flex-direction:column; align-items:flex-start; }
  .socialCarousel__tabs{ justify-content:flex-start; }
}

.flip__back--red .chip{
  border-color: rgba(255,255,255,.25);
  background: rgba(255,255,255,.12);
  color:#fff;
}
.flip__back--red .chip--solid{
  border-color: rgba(255,255,255,.25);
  background: rgba(255,255,255,.12);
  color:#fff;
}
.flip__back--red .muted{ color: rgba(255,255,255,.86); }
.img-slot{
  background-color:#fff;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}

.img-slot[data-bg="campo-beistegui"]{ background-image:url("images/campo-beistegui.jpg"); }
.img-slot[data-bg="campo-cais"]{ background-image:url("images/campo-cais.jpg"); }
.img-slot[data-bg="campo-balbuena"]{ background-image:url("images/campo-balbuena.jpg"); }

.img-slot[data-bg="bls"]{
  background-image:url("images/validez/bls.jpg");
}

.img-slot[data-bg="tsu"]{
  background-image:url("images/validez/tsu.jpg");
}

.img-slot[data-bg="conocer"]{
  background-image:url("images/validez/conocer.jpg");
}

.cardImg{
  background-color:#fff;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}

.cardImg[data-bg="bls-card"]{
  background-image:url("images/formacion/bls.jpg");
}
.cardImg[data-bg="conocer-card"]{
  background-image:url("images/formacion/conocer.jpg");
}
.cardImg[data-bg="tsu-card"]{
  background-image:url("images/formacion/tsu.jpg");
}

.phones--list{
  display:grid;
  gap:10px;
  margin-top:10px;
}
.phoneItem{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  padding:8px 10px;
  border-radius:14px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.14);
}
.phoneItem:hover{ border-color: rgba(255,255,255,.22); }
.iconSlot{
  width:34px; height:34px;
  border-radius:12px;
  background: rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.18);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  flex: 0 0 auto;
}
.iconSlot img{
  width:22px; height:22px;
  object-fit:contain;
  display:block;
}
.phoneText{ font-weight:800; color: rgba(255,255,255,.92); letter-spacing:.2px; }

#panel-contacto .phoneText{ color: var(--primary2) !important; }

.chip--waFooter{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 12px;
  border-radius:14px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.14);
  font-weight:900;
}
.chip--waFooter:hover{ border-color: rgba(255,255,255,.22); }

.footer .hours{
  border:0 !important;
  background: transparent !important;
  padding:0 !important;
}
.footer .hours strong{ color: rgba(255,255,255,.92) !important; }
.footer .hours span{ color: rgba(255,255,255,.82) !important; }

.legalHead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom: 12px;
}
.legalLogo{
  width:72px;
  height:72px;
  object-fit:contain;
  border-radius: 14px;
  border:1px solid rgba(15,23,42,.10);
  background:#fff;
}
.legalClose{
  width:54px;
  height:54px;
  border-radius: 16px;
  border:1px solid rgba(15,23,42,.12);
  background:#fff;
  cursor:pointer;
  font-weight: 900;
  font-size: 30px;
  line-height: 1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.legalContent{
  padding-left: 8px;
}

.footer .hours{
  border:0 !important;
  background: transparent !important;
  padding:0 !important;
}

.panelHero{
  margin: 0 0 18px;
}
.panelHero--bleed{
  width: 100vw;
  margin-left: calc(50% - 50vw);
}
.panelHero__media{
  width: 100%;
  height: 400px;
  border-radius: 0;
  border: 0;
  background-size: cover;
  background-position: center;
  box-shadow: none;
}
@media (max-width: 560px){
  .panelHero__media{ height: 260px; }
}

.panelHero{
  position: relative;
  width: 100vw;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  margin-bottom: 0;
}

.panelHero__media{
  width: 100vw;
  height: 200px;
  background-size: cover;
  background-position: center;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

.panelHero + .section,
.panelHero + section{
  border-top: 0 !important;
  margin-top: 0 !important;
  padding-top: 18px;
}

.siteHeader{
  background: #ffffff !important;
  backdrop-filter: none !important;
}
.topbar{
  background: #ffffff !important;
}
.header{
  background: #ffffff !important;
}

.panelHero.panelHero--bleed{
  position: relative;
  width: 100vw !important;
  left: 50%;
  right: 50%;
  margin-left: -50vw !important;
  margin-right: -50vw !important;
  margin-top: 0 !important;
  margin-bottom: 18px !important;
}
.panelHero__media{
  width: 100vw !important;
  height: 200px !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background-size: cover !important;
  background-position: center !important;
}

.panelHero.panelHero--bleed + .section,
.panelHero.panelHero--bleed + section{
  border-top: 0 !important;
}

.btn,
a.btn,
button.btn{
  background: #A4281C !important;
  color: #fff !important;
  border: 1px solid rgba(112,15,6,.45) !important;
  text-shadow: none !important;
  font-family: "Open Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
}
.btn--small{ font-size: 12px !important; }

.footer__grid{
  align-items: flex-start !important;
  padding-top: 10px !important;
  padding-bottom: 10px !important;
  gap: 12px !important;
}
.footer__grid > *{
  margin-top: 0 !important;
}
.footer__grid h3{ margin: 0 0 6px 0 !important; }
.footer__grid p{ margin: 0 0 8px 0 !important; }
.footer .hours{
  border: 0 !important;
  background: transparent !important;
  padding: 0 !important;
  margin: 8px 0 0 0 !important;
}

.modal{
  align-items:center;
  justify-content:center;
}
.modal.is-open{
  display:flex !important;
}
.modal__card{
  margin: 0 !important;
  max-height: calc(100vh - 48px);
  overflow:auto;
  -webkit-overflow-scrolling: touch;
  background:#fff !important;
}
.modal__head h3{ margin:0; }
@media (max-width:560px){
  .modal__card{
    width: min(520px, calc(100% - 18px)) !important;
    max-height: calc(100vh - 24px);
  }
}

.slider__img{
  will-change: opacity, transform;
  transition: opacity .45s ease, transform .85s ease !important;
}
.slider__dots{ margin-top: 12px !important; }
.dot{
  width: 9px !important; height: 9px !important;
  opacity: .7;
  transition: transform .18s ease, opacity .18s ease, background-color .18s ease;
}
.dot:hover{ transform: scale(1.15); opacity: 1; }

.voces-viewport{ max-width: 1080px !important; }
.voces-track{
  gap: 14px !important;
  min-height: unset !important;
}
.voces-card{
  padding: 1.2rem 1.15rem !important;
}
.voces-text{ margin:0 0 .75rem 0 !important; }

.footer__grid{
  align-items:start !important;
}
.footer__grid h4.h4{ margin-top:0 !important; }
.footer__brand{ align-items:flex-start !important; }
.footer__bottom{
  flex-wrap:wrap;
  align-items:center;
  gap:10px;
  color: rgba(255,255,255,.78) !important;
}
.footer__bottom small{ color: rgba(255,255,255,.78) !important; }
.footer__bottom .footer__legal,
.footer__bottom a.link{
  color: rgba(255,255,255,.92) !important;
  text-decoration:none;
}
.footer__bottom a[data-scrolltop]{
  padding:8px 12px;
  border-radius:999px;
  background: rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.22);
  font-weight:800;
}
.footer__bottom a[data-scrolltop]:hover{
  background: rgba(255,255,255,.18);
  border-color: rgba(255,255,255,.28);
}

.section__head h2{
  position:relative;
  display:inline-block;
  color:#fff !important;
  padding: 10px 14px;
  line-height:1.05;
  text-shadow: 0 10px 26px rgba(0,0,0,.22);
}
.section__head h2::before{
  content:"";
  position:absolute;
  inset: 0 -10px -6px -10px;
  background: linear-gradient(90deg, var(--primary2), var(--primary), var(--accent));
  border-radius: 18px 26px 20px 24px;
  transform: rotate(0deg);
  filter: saturate(1.05);
  z-index:-1;
}
.section__head h2::after{
  content:"";
  position:absolute;
  left:-6px; right:-6px; bottom:-8px;
  height: 10px;
  background: rgba(0,0,0,.12);
  border-radius: 999px;
  filter: blur(6px);
  z-index:-2;
}

.hero__kicker{
  font-size: clamp(18px, 2.1vw, 26px) !important;
}
.hero__brand-top{
  font-size: clamp(36px, 4.8vw, 68px) !important;
}
.hero__brand-main{
  font-size: clamp(62px, 10.0vw, 155px) !important;
}

.tabs{
  align-items:flex-end;
  gap:10px !important;
  padding-bottom: 2px;
  border-bottom: 1px solid rgba(15,23,42,.10);
}
.tab{
  background: rgba(255,255,255,.86) !important;
  border: 1px solid rgba(15,23,42,.12) !important;
  border-bottom-color: rgba(15,23,42,.10) !important;
  padding: 10px 12px !important;
  border-radius: 14px 14px 8px 8px !important;
  box-shadow: 0 10px 22px rgba(15,23,42,.06);
  transform: translateY(2px);
}
.tab:hover{
  transform: translateY(0px);
}
.tab.is-active{
  background: #fff !important;
  border-color: rgba(164,40,28,.20) !important;
  box-shadow: 0 14px 28px rgba(15,23,42,.08);
  transform: translateY(0px);
}
.tabs__indicator{
  bottom: -1px !important;
  height: 3px !important;
  border-radius: 999px !important;
}

.footer__bottom a[data-scrolltop]{ margin-left:auto; margin-right:110px; }
.footer__legal{ margin-right: 12px; }

.footer__container{
  max-width: 1200px;
  margin: 0 auto;
  padding: 48px 20px 22px;
}
.footer__grid{
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 28px;
  align-items: start;
}
.footer__col h4{
  font-family: "Times New Roman", Times, serif;
  font-size: 18px;
  margin: 0 0 10px;
  color: #fff;
}
.footer__col h5{
  margin: 14px 0 6px;
  font-size: 15px;
  color:#fff;
}
.footer__col p{
  margin: 0 0 10px;
  color: rgba(255,255,255,.92);
  line-height: 1.5;
}
.footer__muted{
  color: rgba(255,255,255,.85);
  font-size: 13px;
}
.footer__list{
  list-style: none;
  padding: 0;
  margin: 0 0 10px;
}
.footer__list li{
  margin: 0 0 8px;
  color: rgba(255,255,255,.92);
}
.footer__list a{
  color: rgba(255,255,255,.92);
  text-decoration: none;
}
.footer__list a:hover{ text-decoration: underline; }

.footer__social{
  display:flex;
  gap: 14px;
  flex-wrap: wrap;
  align-items: center;
}
.footer__social a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
}

.footer__bottom{
  margin-top: 26px;
  padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,.18);
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 14px;
  align-items: center;
}
.footer__bottom-center{
  display:flex;
  gap: 18px;
  justify-content:center;
  flex-wrap: wrap;
}
.footer__bottom-center a{
  color: rgba(255,255,255,.9);
  text-decoration: none;
  font-size: 13px;
}
.footer__bottom-center a:hover{ text-decoration: underline; }

.footer__btt{ margin-right: 220px; }

@media (max-width: 980px){
  .footer__grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .footer__bottom{ grid-template-columns: 1fr; text-align:center; }
  .footer__btt{ margin-right: 220px; }
}
@media (max-width: 520px){
  .footer__grid{ grid-template-columns: 1fr; }
}

footer.footer--layout2{ padding: 0; }
.footer2__container{ max-width:1200px; margin:0 auto; padding:54px 20px 18px; }
.footer2__grid{ display:grid; grid-template-columns: 1.2fr 1fr 1fr; gap:44px; align-items:start; }
.footer2__logo{ width:92px; height:auto; display:block; margin:0 0 14px; }
.footer2__col h4{ font-family:"Times New Roman", Times, serif; font-size:18px; margin:0 0 12px; color:rgba(255,255,255,.96); }
.footer2__col h5{ margin:18px 0 8px; font-size:14px; color:rgba(255,255,255,.92); }
.footer2__col p{ margin:0 0 10px; color:rgba(255,255,255,.9); line-height:1.55; }
.footer2__muted{ color:rgba(255,255,255,.86); font-size:13px; }
.footer2__list{ list-style:none; padding:0; margin:0; }
.footer2__list li{ margin:0 0 10px; color:rgba(255,255,255,.92); font-size:14px; }
.footer2__list a{ color:rgba(255,255,255,.92); text-decoration:none; }
.footer2__list a:hover{ text-decoration:underline; }
.footer2__bottom{ margin-top:34px; padding-top:18px; border-top:1px solid rgba(255,255,255,.18); display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap; }
.footer2__bottom-left{ color:rgba(255,255,255,.85); font-size:13px; }
.footer2__bottom-center{ display:flex; gap:18px; flex-wrap:wrap; justify-content:center; }
.footer2__bottom-center a{ color:rgba(255,255,255,.86); font-size:13px; text-decoration:none; }
.footer2__bottom-center a:hover{ text-decoration:underline; }
.footer2__bottom-right{ display:flex; align-items:center; gap:14px; }
.footer2__social{ display:flex; gap:10px; align-items:center; }
.footer2__social a{ width:32px; height:32px; border-radius:999px; border:1px solid rgba(255,255,255,.28); display:inline-flex; align-items:center; justify-content:center; color:rgba(255,255,255,.92); text-decoration:none; font-size:13px; }
.footer2__social img{ width:18px; height:18px; object-fit:contain; }
.footer2__btt{ display:inline-flex; align-items:center; justify-content:center; padding:10px 16px; border-radius:999px; background:rgba(255,255,255,.10); border:1px solid rgba(255,255,255,.20); color:rgba(255,255,255,.95); text-decoration:none; font-weight:700; font-size:13px; margin-right:140px; }
.footer2__btt:hover{ filter:brightness(1.05); }
@media (max-width: 980px){ .footer2__grid{ grid-template-columns:1fr; gap:22px; } .footer2__btt{ margin-right:0; } }

.footer2__phone{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: rgba(255,255,255,.92);
  text-decoration: none;
}
.footer2__phone:hover{ text-decoration: underline; }

.footer2__phone-icon{
  width: 34px;
  height: 34px;
  flex: 0 0 34px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.10);
  background-image: url("images/telefono.jpg");
  background-size: cover;
  background-position: center;
}
.footer2__phone-text{
  display: inline-block;
  transform: translateY(1px);
}

.footer2__col .footer2__list{ padding-left: 6px; }

.section-title,
.brush-title,
h2.section-title,
h3.section-title{
  margin-bottom: 18px;
}

.heroBanner{
  margin-bottom: 6px !important;
}

.panel .section:first-child,
.panel .container:first-child{
  margin-top: 0 !important;
  padding-top: 0 !important;
}

.heroBanner + .section,
.heroBanner + .container,
.heroBanner + div{
  margin-top: 0 !important;
  padding-top: 0 !important;
}

.panelHero__media{
  aspect-ratio: 17 / 6;
  min-height: 0 !important;
}

.panelHero__media{
  aspect-ratio: 17 / 6;
  width: 100%;
  max-height: clamp(260px, 22vw, 340px);
}

   images/mod_headers/<modalidad>_header.jpg  (ej: images/mod_headers/ae_header.jpg)

.panel.is-active{ display:block; }

.panel--entering{
  opacity: 0;
  transform: translateY(10px);
}
.panel--leaving{
  opacity: 1;
  transform: translateY(0);
  pointer-events: none;
}
.panel--animate{
  transition: opacity .24s ease, transform .24s ease;
}
.panel--entering.panel--animate{
  opacity: 1;
  transform: translateY(0);
}
.panel--leaving.panel--animate{
  opacity: 0;
  transform: translateY(-6px);
}

@media (prefers-reduced-motion: reduce){
  .panel--animate{ transition: none !important; }
  .slider__img{ transition: none !important; }
}

html, body{ overflow-anchor: none; }
.panel{ overflow-anchor: none; }

#panel-noticias .newsSocialTop{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding: 10px 14px;

  flex-wrap: nowrap;
  min-height: 0;}
#panel-noticias .newsSocialTop__left{
  text-align:left;
  flex: 1 1 auto;
  display:flex;
  justify-content:flex-start;
}
#panel-noticias .newsSocialTop__line{ text-align:left; }
#panel-noticias .newsSocialTop .socials{
  margin-top:0;
  flex: 0 0 auto;
}
#panel-noticias .newsSocialTop__line{
  margin:0;
  line-height:1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
#panel-noticias .newsSocialTop__dot{
  margin:0 10px;
  opacity:.6;
}
#panel-noticias .socials--right{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
}

#panel-noticias .newsSocialTop .socialIcon{
  width:40px;
  height:40px;
  border-radius:14px;
}
#panel-noticias .newsSocialTop .socialIcon img{
  width:34px;
  height:34px;
  border-radius:10px;
  display:block;
}

#panel-noticias .fbWrap,
#panel-noticias .igWrap{
  border-radius:18px;
  overflow:hidden;
}
#panel-noticias .fbWrap iframe{
  display:block;
  width:100% !important;
  height:520px;
  border:0;
}
#panel-noticias #igFrame{
  display:block;
  width:100%;
  height:520px;
  border:0;
}

@media (max-width: 640px){
  #panel-noticias .newsSocialTop{
    flex-direction:column;
    align-items:flex-start;
  }
  #panel-noticias .socials--right{
    width:100%;
    justify-content:flex-start;
  }
}

.footer__brand img,
.footer img[src*="logo-footer"]{
  height: 200px !important;
  max-height: 200px !important;
  width: auto;
}

.legalLogo,
footer .legalLogo{
  width: 200px !important;
  height: 200px !important;
  max-width: 200px !important;
  max-height: 200px !important;
}

@media (max-width: 520px){
  .footer__brand img{
    height: 150px !important;
    max-height: 150px !important;
  }
  .legalLogo{
    width: 140px !important;
    height: 140px !important;
  }
}

.hero__overline{
  font-size: clamp(1.4rem, 2.2vw, 2rem) !important;
}

.hero__brand-sub{
  font-size: clamp(1.6rem, 2.6vw, 2.3rem) !important;
}

.newsSocialTop{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;

  padding: 10px 18px;
  border-radius: 12px;
}

.newsSocialTop__text{
  display: flex;
  align-items: center;
  gap: 8px;

  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.newsSocialTop__icons{
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}

.newsSocialTop__icons img{
  width: 34px;
  height: 34px;
  object-fit: contain;
}

@media (max-width:768px){
  .newsSocialTop{
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }

  .newsSocialTop__text{
    white-space: normal;
  }
}

#panel-noticias .newsSocialTop{
  display:flex !important;
  flex-direction: row !important;
  align-items:center !important;
  justify-content: space-between !important;
  text-align:left !important;
  padding: 10px 14px !important;
  gap: 14px !important;
}

#panel-noticias .newsSocialTop__left{
  flex: 1 1 auto !important;
  display:block !important;
  text-align:left !important;
  margin-right:auto !important;
}

#panel-noticias .newsSocialTop__line{
  margin:0 !important;
  text-align:left !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

#panel-noticias .newsSocialTop .socials.socials--right{
  display:flex !important;
  flex-wrap: nowrap !important;
  align-items:center !important;
  justify-content:flex-end !important;
  margin-top:0 !important;
  margin-left:auto !important;
  gap:10px !important;
}

@media (max-width: 640px){
  #panel-noticias .newsSocialTop{
    flex-direction: column !important;
    align-items:flex-start !important;
  }
  #panel-noticias .newsSocialTop .socials.socials--right{
    width:100% !important;
    justify-content:flex-start !important;
  }
}

.hero--paper .slider__frame{
  aspect-ratio: auto;
  height: clamp(320px, 42vw, 560px);
}

.slider__nav{
  position:absolute;
  top:50%;
  transform: translateY(-50%);
  z-index:4;
  width:40px;
  height:40px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.35);
  background: rgba(0,0,0,.28);
  color:#fff;
  font-size:22px;
  line-height:1;
  display:grid;
  place-items:center;
  cursor:pointer;
  user-select:none;
  opacity:.8;
  box-shadow: 0 6px 18px rgba(0,0,0,.25);
  backdrop-filter: blur(4px);
}

.slider__nav--prev{ left:10px; }
.slider__nav--next{ right:10px; }

.slider__nav:hover,
.slider__nav:focus-visible{
  opacity:.9;
  background: rgba(0,0,0,.32);
}

@media (max-width: 720px){
  .slider__nav{
    width:44px;
    height:44px;
    opacity:.75;
  }
}

@media (hover: none){
  .slider__nav{ opacity:.9; }
}

.slider__nav,
.slider__dots .dot{
  -webkit-appearance: none;
  appearance: none;
  -webkit-tap-highlight-color: transparent;
}

.slider__nav{
  background: transparent !important;
  border: 1px solid rgba(255,255,255,.0) !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  opacity: .50;
  width: 44px;
  height: 44px;
  padding: 0;
  filter: none !important;

  transform: translateY(-50%) !important;
}

.slider__frame:hover .slider__nav{ opacity: .75; }

.slider__nav:hover,
.slider__nav:focus-visible{
  background: rgba(0,0,0,.14) !important;
  border-color: rgba(255,255,255,.22) !important;
  opacity: .88;
  transform: translateY(-50%) !important;
  filter: none !important;
}

.slider__nav:active{
  transform: translateY(-50%) !important;
  filter: none !important;
}

.slider__dots{ gap:10px; }

.slider__dots .dot{
  position: relative;
  width: 8px;
  height: 8px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.0) !important;
  background: rgba(255,255,255,.20) !important;
  opacity: .55;
  filter: none !important;
  transform: none !important;
}

.slider__dots .dot::after{
  content:"";
  position:absolute;
  inset:-10px;
}

.slider__dots .dot:hover,
.slider__dots .dot:focus-visible{
  opacity: .85;
  background: rgba(255,255,255,.28) !important;
  transform: none !important;
  filter: none !important;
}

.slider__dots .dot:active{
  transform: none !important;
  filter: none !important;
}

.slider__dots .dot.is-active{
  opacity: 1;
  background: rgba(255,255,255,.92) !important;
  border-color: rgba(255,255,255,.0) !important;
}

@media (hover: none){
  .slider__frame:hover .slider__nav{ opacity: .62; }
  .slider__nav{ opacity: .62; }
}

.hero__kicker{
  margin-bottom:12px !important;
}

.hero__brand-top{
  margin:4px 0 10px !important;
  line-height:1.04 !important;
  font-size:clamp(3.6rem, 7.8vw, 5.2rem) !important;
}

.hero__brand-main{
  margin-top:8px !important;
  margin-bottom:28px !important;
  line-height:0.95 !important;
}

.hero__title--center::after{
  content:"" !important;
  display:block !important;
  height:9px !important;
}

.section__head{ text-align:center; }
.section__head h2{ overflow:visible !important; margin-left:auto; margin-right:auto; }
.section__head p{ text-align:center; margin:14px auto 0; max-width:72ch; }

.slider__frame{ overflow:hidden; }
.map{ overflow:hidden; }
.fbWrap{ overflow:hidden; }

.section__head h2{ opacity:0; transform:translateX(-80px); transition:opacity .9s cubic-bezier(.2,.8,.2,1), transform .9s cubic-bezier(.2,.8,.2,1); }
.section__head h2.is-visible{ opacity:1; transform:translateX(0); }
.reveal{ opacity:0; transform:translateY(40px); transition:opacity .9s cubic-bezier(.2,.8,.2,1), transform .9s cubic-bezier(.2,.8,.2,1); }
.reveal.is-visible{ opacity:1; transform:translateY(0); }

.section__head{ text-align:center; }
.section__head > p,
.section__head > p.muted{
  text-align:center !important;
  margin-left:auto;
  margin-right:auto;
  max-width:72ch;
  display:block;
  overflow:visible;
  -webkit-line-clamp: unset;
  -webkit-box-orient: unset;
}

.panelHero__media {
  height: 350px !important;
  min-height: 350px !important;
  max-height: 350px !important;
}

.heroBanner {
  height: 260px !important;
  min-height: 260px !important;
  max-height: 260px !important;
}

@media (max-width: 768px) {
  .panelHero__media {
    height: 260px !important;
    min-height: 260px !important;
    max-height: 260px !important;
  }
  .heroBanner {
    height: 220px !important;
    min-height: 220px !important;
    max-height: 220px !important;
  }
}

:root{ --headerH: 88px; }
body{ padding-top: 0; }

.header{
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  z-index: 9999 !important;
  background: #ffffff !important;
  border-bottom: 1px solid rgba(0,0,0,.08) !important;
}

@media (max-width: 560px){
  body{ padding-top: var(--headerH, 88px); }
}

.mobileNav__toggle{ display:none; }
.mobileNav{
  position:fixed; inset:0;
  display:none;
  z-index:1200;
}
.mobileNav.is-open{ display:block; }
.mobileNav__backdrop{
  position:absolute; inset:0;
  background: rgba(15,23,42,.55);
}
.mobileNav__panel{
  position:absolute;
  right:0; top:0; bottom:0;
  width:min(420px, 88vw);
  background:#fff;
  border-left:1px solid rgba(15,23,42,.10);
  box-shadow: 0 30px 60px rgba(15,23,42,.28);
  display:flex;
  flex-direction:column;
}
.mobileNav__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 14px;
  border-bottom:1px solid rgba(15,23,42,.08);
  background: linear-gradient(180deg, #fff, rgba(15,23,42,.02));
}
.mobileNav__brand strong{
  display:block;
  font-family:"Times New Roman", Times, serif;
  font-size:14px;
  letter-spacing:.2px;
  color: var(--ink);
}
.mobileNav__brand small{
  display:block;
  font-size:12px;
  color: var(--muted);
}
.mobileNav__close{
  appearance:none;
  border:0;
  background:#f3f4f6;
  border-radius:12px;
  width:40px;
  height:40px;
  cursor:pointer;
  font-weight:900;
}
.mobileNav__close:hover{ background:#e5e7eb; }

.mobileNav__list{
  padding:10px;
  display:grid;
  gap:8px;
  overflow:auto;
}
.mobileNav__item{
  appearance:none;
  border:1px solid rgba(15,23,42,.10);
  background: #fff;
  border-radius: 14px;
  padding:12px 12px;
  text-align:left;
  font-weight:800;
  color: var(--ink);
  cursor:pointer;
}
.mobileNav__item:hover{
  border-color: rgba(164,40,28,.30);
  background: rgba(164,40,28,.04);
}

.is-mobileNavOpen{ overflow:hidden; }

@media (max-width: 560px){

  .header{ padding: 6px 0 !important; }
  .header__inner{
    flex-direction: row !important;
    align-items:center !important;
    justify-content: space-between !important;
    gap:10px !important;
  }
  .brand{ min-width: 0 !important; }
  .brand__img{ width:40px !important; height:40px !important; }
  .brand__text strong{ font-size:13px !important; }
  .brand__text small{ font-size:11px !important; }

  .tabs{ display:none !important; }
  .mobileNav__toggle{
    display:inline-flex !important;
    align-items:center;
    justify-content:center;
    width:44px;
    height:44px;
    border-radius:14px;
    border:1px solid rgba(15,23,42,.12);
    background:#fff;
    cursor:pointer;
    flex:0 0 auto;
  }
  .mobileNav__toggle:focus-visible{
    outline:2px solid rgba(239,26,6,.45);
    outline-offset:2px;
  }
  .mobileNav__icon{
    width:22px; height:2px;
    background: var(--primary2);
    position:relative;
    border-radius:2px;
  }
  .mobileNav__icon::before,
  .mobileNav__icon::after{
    content:"";
    position:absolute;
    left:0;
    width:22px; height:2px;
    background: var(--primary2);
    border-radius:2px;
  }
  .mobileNav__icon::before{ top:-7px; }
  .mobileNav__icon::after{ top:7px; }

  .main{ padding-top: var(--headerH, 0px) !important; }

  .heroBanner{
    background-size: contain !important;
    background-repeat:no-repeat !important;
    background-position:center !important;
    height: clamp(110px, 26vw, 170px) !important;
  }
  .homeMeta--slider .slider__frame{
    height: clamp(220px, 66vw, 360px) !important;
  }
}

@media (max-width: 560px){
  html, body{ overflow-x: hidden; }

  .section, .section.alt{ padding: 36px 0 !important; }
  .section__head{ margin-bottom: 16px !important; }
  .section__head h2{ font-size: 22px !important; line-height: 1.15 !important; }
  .section__lead{ font-size: 14px !important; line-height: 1.55 !important; }

  p, .muted{ line-height: 1.6 !important; }
  .muted{ font-size: 14px !important; }

  .card{ padding: 16px !important; border-radius: 16px !important; }
  .cardsRow{ gap: 12px !important; }
  .grid{ gap: 14px !important; }

  .hero__cta, .cta-row, .actions{ gap: 10px !important; flex-wrap: wrap !important; }
  .hero__cta .btn,
  .flip__actions .btn,
  .flip__actions a.btn{
    width: 100% !important;
    justify-content: center !important;
  }

  .btn, a.btn, button.btn{ width: auto; }

  .panelHero--bleed{
    width: 100% !important;
    margin-left: 0 !important;
  }

  .flip{ min-height: auto !important; }
  .flip__inner{ min-height: 440px !important; }
  .flip__face{ padding: 16px !important; }
  .flip__media{ height: 140px !important; }
  .flip__scroll{
    max-height: 46vh !important;
    overflow: auto !important;
    padding-right: 4px !important;
  }
  .chip-row{ gap: 6px !important; flex-wrap: wrap !important; }
  .chip{ font-size: 12px !important; padding: 7px 10px !important; }

  .footer__brand img,
  .footer img[src*="logo-footer"]{
    height: 110px !important;
    max-height: 110px !important;
  }
  .legalLogo,
  footer .legalLogo{
    width: 110px !important;
    height: 110px !important;
    max-width: 110px !important;
    max-height: 110px !important;
  }

  .miniV{ max-width: 100% !important; word-break: break-word; }

  .newsSocialTop__text{ white-space: normal !important; }
}

@media (max-width: 560px){

  #panel-inicio .hero--paper .container.hero__grid,
  #panel-inicio .hero--paper .container.homeSplit{
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  #panel-inicio .hero__copy{ padding-left: 16px !important; padding-right: 16px !important; }

  .heroBanner{
    height: 290px !important;
    min-height: 290px !important;
    max-height: 290px !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    border-radius: 0 !important;
  }

  #panel-inicio .homeMeta--slider{ padding-left: 16px !important; padding-right: 16px !important; }
  #panel-inicio .homeMeta--slider .slider{
    width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
  }
  #panel-inicio .homeMeta--slider .slider__frame{
    border-radius: 0 !important;
    height: clamp(290px, 56vh, 520px) !important;
  }
  #panel-inicio .homeMeta--slider .slider__img{ object-fit: cover !important; }
}

@media (hover: none), (pointer: coarse){
  .flip:focus-within .flip__inner{ transform: none !important; }
}

@media (max-width: 560px){

  .siteHeader{display:none !important; height:0 !important; padding:0 !important; margin:0 !important; border:0 !important;}

  body{padding-top:0 !important;}
  .main{padding-top: var(--headerH, 88px) !important;}

  #panel-inicio > .hero{margin-top:0 !important; padding-top:0 !important;}
  .panelHero{margin-top:0 !important;}
  .panelHero.panelHero--bleed{margin-top:0 !important;}
  .panelHero__media{background-position:center center !important; background-size:cover !important;}

  .hero__grid{padding-top:0 !important;}
  .heroBanner{margin-top:0 !important; background-position:center center !important; background-size:contain !important;}

  .container{padding-left: var(--pagePad) !important; padding-right: var(--pagePad) !important;}
  .hero__copy, .hero__title, .hero__lead{ text-align:center !important; }

  img{display:block; max-width:100% !important; height:auto !important; margin-left:auto !important; margin-right:auto !important;}

  .slider__frame{width:100% !important;}
  .slider__img{width:100% !important; height:100% !important; object-fit:cover !important; object-position:center center !important;}

  section.section{padding-top: clamp(16px, 4vw, 22px) !important;}
}

@media (max-width: 720px){

  *, *::before, *::after{ box-sizing: border-box; }
  html, body{ width:100%; overflow-x:hidden; }

  body{ padding-top: var(--headerH, 74px) !important; }
  .siteHeader{ display:none !important; }

  header.header{ position: fixed !important; top:0; left:0; right:0; width:100%; }
  .main{
    padding-top: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .container{
    width:100% !important;
    max-width: 100% !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  .section{ padding-top: 22px !important; padding-bottom: 22px !important; }
  .section__head{ margin-bottom: 14px !important; }
  p{ line-height: 1.55 !important; }

  .heroBanner{
    height: clamp(170px, 36vw, 260px) !important;
    margin-bottom: 14px !important;
    background-position: center !important;
  }
  .hero__title{ padding-left: 12px !important; padding-right: 12px !important; }
  .hero__kicker{
    font-size: 12px !important;
    letter-spacing: .08em !important;
    text-align: center !important;
  }
  .hero__brand{ display:block !important; text-align:center !important; }
  .hero__brand-top{
    font-size: clamp(18px, 5.2vw, 26px) !important;
    text-align:center !important;
  }

  .hero__brand-main{
    width: auto !important;
    max-width: none !important;
    justify-content: center !important;
    gap: .18em !important;
    padding-inline: 0 !important;
    white-space: normal !important;
    font-size: clamp(44px, 14.5vw, 78px) !important;
    margin: 10px auto 0 !important;
  }
  .hero__brand-main > span{ display:inline-block !important; }

  .homeSplit{
    grid-template-columns: 1fr !important;
    gap: 18px !important;
    margin-top: 10px !important;
  }

  .slider{ width:100% !important; }
  .slider__frame{ aspect-ratio: 4/3 !important; border-radius: 16px !important; }
  .slider__img{ object-position: center !important; }
  .slider__dots{ padding-top: 10px !important; }

  .cardsRow{
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }
  .card, .program{
    border-radius: 18px !important;
  }
  .program__media{ border-radius: 16px !important; overflow:hidden !important; }
  .program__img{ object-position:center !important; }

  .split, .twoCol, .cols, .grid2, .grid3{
    grid-template-columns: 1fr !important;
  }

  .btn, button, .pill, .tag{
    max-width: 100%;
  }

  .float-whatsapp, .whatsapp-float, .whatsappBtn, .whatsBtn{
    bottom: 16px !important;
    right: 16px !important;
  }
  .footer2__btt{
    width: 100% !important;
    justify-content: center !important;
  }

  img, video{ max-width:100%; height:auto; }
}

@media (max-width: 560px){

  #panel-inicio .hero--paper .container,
  #panel-inicio .homeSplit.container{
    width: min(1280px, calc(100% - (var(--pagePad) * 2))) !important;
    margin: 0 auto !important;
    padding-left: var(--pagePad) !important;
    padding-right: var(--pagePad) !important;
  }

  #panel-inicio .homeMeta--slider{
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    left: auto !important;
    right: auto !important;
    position: relative !important;
  }

  #panel-inicio .homeMeta--slider .slider__frame{
    border-radius: var(--radius) !important;
    overflow: hidden !important;
  }

  #panel-inicio .hero__grid{
    justify-items: center !important;
    text-align: center !important;
  }

  #panel-inicio .hero__copy{
    text-align: center !important;
  }

  #panel-inicio .hero__kicker{
    display: block !important;
    font-size: 13.5px !important;
    line-height: 1.4 !important;
    padding: 0 6px !important;
  }

  #panel-inicio .hero__brand-main{
    display: flex !important;
    justify-content: center !important;
    gap: clamp(8px, 2.5vw, 14px) !important;
    font-size: clamp(42px, 14vw, 60px) !important;
    letter-spacing: .08em !important;
    width: 100% !important;
  }

}

@media (max-width: 560px){

  #panel-inicio .hero--paper::before,
  #panel-inicio .hero--paper::after,
  #panel-inicio .tear-top::before,
  #panel-inicio .tear-bottom::after{
    display: none !important;
  }

  #panel-inicio .hero--paper{
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }

  #panel-inicio .hero--paper .container{
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
  }

  #panel-inicio .slider{
    padding: 0 !important;
    background: none !important;
    border: 0 !important;
    border-radius: 0 !important;
  }

  #panel-inicio .slider__frame{
    border-radius: 0 !important;
  }

  #panel-inicio .hero__copy{
    padding: 20px 16px 0 !important;
  }

}

@media (max-width: 560px){

  #panel-inicio .hero__grid{
    padding-top: 0 !important;
    padding-bottom: 10px !important;
    gap: 0 !important;
  }

  #panel-inicio .hero__copy{
    padding: 0 !important;
    margin: 0 !important;
  }

  #panel-inicio .heroBanner{
    width: 100vw !important;
    max-width: none !important;
    height: clamp(260px, 70vw, 420px) !important;
    margin: 0 !important;
    border-radius: 0 !important;
    background-color: transparent !important;
    background-repeat: no-repeat !important;
    background-size: cover !important;
    background-position: center center !important;

    background-image: url('images/Artboard_1.jpg') !important;

    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
  }

  #panel-inicio .hero__title--center{
    margin: 0 auto !important;
    text-align: center !important;
    padding: 14px 0 6px !important;
  }
  #panel-inicio .hero__title--center::after{
    display:none !important;
    height:0 !important;
  }
}

.heroBanner{
  background-image: url("images/Artboard_1.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

@media (max-width: 900px) and (orientation: landscape){
  .topbar{ display:none !important; }

  .header{ padding:6px 0 !important; }
  .header__inner{
    flex-direction:row !important;
    align-items:center !important;
    justify-content:space-between !important;
  }

  .homeMeta--slider .slider__frame{
    height: 78vh !important;
    max-height: 520px !important;
  }
  .hero__grid{ padding-bottom: 10px !important; }

  .mobileNav__toggle{ display:flex !important; }
  .tabs{ display:none !important; }
}

.mobileNav__toggle{
  display:none;
  width:44px;
  height:44px;
  border-radius:12px;
  border:1px solid rgba(15,23,42,.12);
  background:#fff;
  cursor:pointer;
  align-items:center;
  justify-content:center;
  position:relative;
}
.mobileNav__icon,
.mobileNav__icon::before,
.mobileNav__icon::after{
  content:"";
  display:block;
  width:20px;
  height:2px;
  background:var(--primary);
  border-radius:2px;
  transition:.3s ease;
  position:relative;
}
.mobileNav__icon::before{ position:absolute; top:-6px; }
.mobileNav__icon::after{ position:absolute; top:6px; }

@media (max-width: 900px){
  .homeSplit{ grid-template-columns: 1fr !important; display: grid !important; }
  .homeMeta, .homeFeatured{ grid-column: auto !important; }
  .homeFeatured{ margin-top: 16px !important; }
  .homeFeatured .cardsRow{ grid-template-columns: 1fr !important; }
}

@media (max-width: 560px), (max-width: 900px) and (orientation: landscape){
  .mobileNav__toggle{
    background: var(--primary2) !important;
    border-color: rgba(255,255,255,.28) !important;
  }

  .mobileNav__icon{
    width:22px !important;
    height:2px !important;
    background:#fff !important;
    position:relative !important;
    border-radius:2px !important;
  }
  .mobileNav__icon::before,
  .mobileNav__icon::after{
    content:"" !important;
    position:absolute !important;
    left:0 !important;
    width:22px !important;
    height:2px !important;
    background:#fff !important;
    border-radius:2px !important;
  }
  .mobileNav__icon::before{ top:-7px !important; }
  .mobileNav__icon::after{ top:7px !important; }

  .mobileNav__icon,
  .mobileNav__icon::before,
  .mobileNav__icon::after{
    transition:none !important;
    transform:none !important;
    opacity:1 !important;
    animation:none !important;
  }
}

@media (min-width: 981px){
  #panel-inicio .homeSplit{ grid-template-columns: 1fr 1.25fr !important; }
  #panel-inicio .homeMeta{ grid-column: 1 !important; }
  #panel-inicio .homeFeatured{ grid-column: 2 !important; margin-top: 0 !important; }
  #panel-inicio .homeFeatured .cardsRow{ grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}

@media (max-width: 980px) and (any-hover: hover) and (any-pointer: fine){
  #panel-inicio .homeSplit{ grid-template-columns: 1fr 1.25fr !important; }
  #panel-inicio .homeMeta{ grid-column: 1 !important; }
  #panel-inicio .homeFeatured{ grid-column: 2 !important; margin-top: 0 !important; }
  #panel-inicio .homeFeatured .cardsRow{ grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}

@media (max-width: 980px) and (any-hover: none) and (any-pointer: coarse){
  #panel-inicio .homeSplit{ grid-template-columns: 1fr !important; }
  #panel-inicio .homeMeta, #panel-inicio .homeFeatured{ grid-column: auto !important; }
  #panel-inicio .homeFeatured .cardsRow{ grid-template-columns: 1fr !important; }
}
