/* ================================================================
   ICEFP – Redesign v1.0
   Institucional-Comercial Design System
   Based on consultant report – Clean, Professional, Conversion-focused
   ================================================================ */

@font-face {
  font-family: 'Rifton Norm';
  src: url('../fonts/Rifton Norm.woff2') format('woff2'),
       url('../fonts/Rifton Norm.woff') format('woff');
  font-style: normal;
  font-weight: 400;
  font-display: swap;
}

@font-face {
  font-family: 'Galano Grotesque';
  src: url('../fonts/Galano Grotesque.woff2') format('woff2'),
       url('../fonts/Galano Grotesque.woff') format('woff');
  font-style: normal;
  font-weight: 400;
  font-display: swap;
}

/* ── CSS Variables ─────────────────────────────────────────── */
:root {
  --primary:      #0E4AA8;
  --primary-dark:  #08397F;
  --primary-light: #1A6DD8;
  --secondary:    #35A7FF;
  --accent:       #F4B400;
  --bg:           #FFFFFF;
  --bg-soft:      #F6F8FB;
  --bg-dark:      #0B1A3E;
  --text:         #1C1C1C;
  --text-muted:   #5F6368;
  --text-light:   #8D9196;
  --border:       #E3E7ED;
  --border-light: #F0F2F5;
  --success:      #25D366;
  --success-dark: #1EAD54;
  --danger:       #DC2626;

  --shadow-xs:  0 1px 2px rgba(0,0,0,.04);
  --shadow-sm:  0 2px 8px rgba(0,0,0,.06);
  --shadow:     0 4px 16px rgba(0,0,0,.08);
  --shadow-md:  0 8px 24px rgba(0,0,0,.10);
  --shadow-lg:  0 16px 48px rgba(0,0,0,.12);
  --shadow-blue: 0 8px 32px rgba(14,74,168,.20);
  --shadow-green: 0 8px 32px rgba(37,211,102,.25);

  --font: 'Galano Grotesque', 'Inter', sans-serif;
  --font-heading: 'Rifton Norm', 'Galano Grotesque', 'Inter', sans-serif;
  --radius:    12px;
  --radius-sm: 8px;
  --radius-lg: 16px;
  --radius-xl: 24px;
  --radius-full: 9999px;

  --transition: .3s cubic-bezier(.4,0,.2,1);
  --transition-fast: .15s ease;

  --container: 1280px;
}

/* ── Keyframes ─────────────────────────────────────────────── */
@keyframes fadeInUp { from { opacity:0; transform:translateY(30px); } to { opacity:1; transform:translateY(0); } }
@keyframes fadeInLeft { from { opacity:0; transform:translateX(-30px); } to { opacity:1; transform:translateX(0); } }
@keyframes fadeInRight { from { opacity:0; transform:translateX(30px); } to { opacity:1; transform:translateX(0); } }
@keyframes fadeIn { from { opacity:0; } to { opacity:1; } }
@keyframes scaleIn { from { opacity:0; transform:scale(.9); } to { opacity:1; transform:scale(1); } }
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }
@keyframes float-slow { 0%,100%{transform:translateY(0) rotate(0deg)} 50%{transform:translateY(-18px) rotate(3deg)} }
@keyframes pulse-ring { 0%{transform:scale(1);opacity:.7} 100%{transform:scale(1.5);opacity:0} }
@keyframes marquee { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
@keyframes count-glow { 0%,100%{text-shadow:none} 50%{text-shadow:0 0 20px rgba(14,74,168,.3)} }
@keyframes shimmer { 0%{background-position:-200% center} 100%{background-position:200% center} }
@keyframes slide-up-3d { from { opacity:0; transform:perspective(1000px) rotateX(8deg) translateY(40px); } to { opacity:1; transform:perspective(1000px) rotateX(0) translateY(0); } }
@keyframes blur-in { from { opacity:0; filter:blur(8px); transform:translateY(20px); } to { opacity:1; filter:blur(0); transform:translateY(0); } }
@keyframes slide-in-bounce { 0% { opacity:0; transform:translateY(50px) scale(.95); } 60% { transform:translateY(-8px) scale(1.01); } 100% { opacity:1; transform:translateY(0) scale(1); } }
@keyframes glow-pulse { 0%,100%{box-shadow:0 0 0 0 rgba(14,74,168,.15)} 50%{box-shadow:0 0 30px 8px rgba(14,74,168,.1)} }
@keyframes rotate-in { from { opacity:0; transform:rotate(-6deg) scale(.9); } to { opacity:1; transform:rotate(0) scale(1); } }
@keyframes morph-blob { 0%,100%{border-radius:60% 40% 30% 70%/60% 30% 70% 40%} 25%{border-radius:30% 60% 70% 40%/50% 60% 30% 60%} 50%{border-radius:50% 60% 30% 60%/30% 40% 70% 60%} 75%{border-radius:60% 40% 60% 40%/40% 60% 40% 60%} }
@keyframes gradient-shift { 0%{background-position:0% 50%} 50%{background-position:100% 50%} 100%{background-position:0% 50%} }

/* ── Reset ─────────────────────────────────────────────────── */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  font-family: var(--font);
  font-size: 16px;
  line-height: 1.65;
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img,video { max-width:100%; height:auto; display:block; }
a { color:inherit; text-decoration:none; }
button { font-family:inherit; cursor:pointer; border:none; background:none; }
ul,ol { list-style:none; }
h1,h2,h3,h4,h5 { font-family:'Inter', 'Galano Grotesque', sans-serif; line-height:1.25; color:var(--text); }
.page-rifton h1,.page-rifton h2,.page-rifton h3,.page-rifton h4,.page-rifton h5 { font-family:var(--font-heading); }

/* Title accent — one word enlarged per title for Rifton visual play */
.title-accent {
  font-size:1.35em;
  display:inline;
  color:var(--primary);
}
.section-dark .title-accent,
.section-blue .title-accent,
.cta-final .title-accent { color:var(--secondary); }
::selection { background:rgba(10,22,40,.92); color:#fff; }

/* ── Container ─────────────────────────────────────────────── */
.container {
  width:100%;
  max-width: var(--container);
  margin:0 auto;
  padding:0 2rem;
}
@media(max-width:768px){ .container { padding:0 1.25rem; } }
@media(max-width:480px){ .container { padding:0 1rem; } }

/* ── Section System ────────────────────────────────────────── */
.section { padding:5.5rem 0; }
.section-soft { background:var(--bg-soft); }
.section-dark { background:var(--bg-dark); color:#fff; }
.section-blue { background:#0E4AA8; color:#fff; }
.section-blue .badge { color:rgba(255,255,255,.8); }
.section-blue .section-head h2 { color:#fff; }
.section-blue .section-head p { color:rgba(255,255,255,.65); }
.section-blue .faq-item { background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.15); }
.section-blue .faq-item:hover { border-color:rgba(255,255,255,.3); }
.section-blue .faq-item.open { border-color:rgba(255,255,255,.4); }
.section-blue .faq-question { color:#fff; }
.section-blue .faq-question i { color:rgba(255,255,255,.7); }
.section-blue .faq-answer p { color:rgba(255,255,255,.75); }
.section-blue .faq-answer a { color:var(--accent); }

/* Hover contrast fix: ensure links in dark/blue sections stay visible */
.section-dark a:not(.btn):hover,
.cta-final a:not(.btn):hover,
.footer a:not(.btn):not(.libro-reclamo):hover { color:#fff; }
.section-dark .badge { color:rgba(255,255,255,.8); }
.section-dark .section-head p { color:rgba(255,255,255,.6); }
.section-dark .faq-answer a:hover { color:var(--secondary); }

.section-head {
  text-align:center;
  max-width:640px;
  margin:0 auto 3.5rem;
}
.section-head h2 {
  font-size: clamp(1.75rem, 3.5vw, 2.5rem);
  font-weight:800;
  margin-bottom:.75rem;
  letter-spacing:-.02em;
  position:relative;
  display:inline-block;
}
.section-head h2::after {
  content:'';
  position:absolute;
  bottom:-.15rem; left:50%;
  width:0; height:3px;
  background:linear-gradient(90deg, var(--primary), var(--secondary));
  border-radius:2px;
  transition:width .8s cubic-bezier(.25,.46,.45,.94), left .8s cubic-bezier(.25,.46,.45,.94);
}
.section-head.revealed h2::after { width:60px; left:calc(50% - 30px); }
.section-head p {
  font-size:1rem;
  color:var(--text);
  line-height:1.75;
}
.section-cta { text-align:center; margin-top:2.5rem; }

/* ── Badge ─────────────────────────────────────────────────── */
.badge {
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  font-size:1.05rem;
  font-family:var(--font-heading);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--primary);
  background:none;
  border:none;
  padding:0;
  border-radius:0;
  margin-bottom:1rem;
}
.badge i { font-size:.65rem; }
.badge-light {
  color:#fff;
  background:none;
  border:none;
}
.badge-green {
  color:var(--success);
  background:none;
  border:none;
}

/* ── Scroll Reveal ─────────────────────────────────────────── */
[data-reveal] {
  opacity:0;
  transform:perspective(1000px) translateY(40px) rotateX(4deg);
  filter:blur(3px);
  transition:opacity .8s cubic-bezier(.25,.46,.45,.94), transform .8s cubic-bezier(.25,.46,.45,.94), filter .8s cubic-bezier(.25,.46,.45,.94);
}
[data-reveal].revealed { opacity:1; transform:perspective(1000px) translateY(0) rotateX(0); filter:blur(0); }
[data-reveal="left"] { transform:translateX(-50px) rotate(-2deg); filter:blur(3px); }
[data-reveal="left"].revealed { transform:translateX(0) rotate(0); filter:blur(0); }
[data-reveal="right"] { transform:translateX(50px) rotate(2deg); filter:blur(3px); }
[data-reveal="right"].revealed { transform:translateX(0) rotate(0); filter:blur(0); }
[data-reveal="scale"] { transform:scale(.85); filter:blur(4px); }
[data-reveal="scale"].revealed { transform:scale(1); filter:blur(0); }
[data-reveal="flip"] { transform:perspective(800px) rotateY(-15deg); filter:blur(2px); }
[data-reveal="flip"].revealed { transform:perspective(800px) rotateY(0); filter:blur(0); }

[data-stagger] > * {
  opacity:0;
  transform:translateY(30px) scale(.95);
  filter:blur(2px);
  transition:opacity .6s cubic-bezier(.25,.46,.45,.94), transform .6s cubic-bezier(.25,.46,.45,.94), filter .6s cubic-bezier(.25,.46,.45,.94);
}
[data-stagger].revealed > * { opacity:1; transform:translateY(0) scale(1); filter:blur(0); }
[data-stagger].revealed > *:nth-child(1) { transition-delay:0s; }
[data-stagger].revealed > *:nth-child(2) { transition-delay:.1s; }
[data-stagger].revealed > *:nth-child(3) { transition-delay:.2s; }
[data-stagger].revealed > *:nth-child(4) { transition-delay:.3s; }
[data-stagger].revealed > *:nth-child(5) { transition-delay:.4s; }
[data-stagger].revealed > *:nth-child(6) { transition-delay:.5s; }
[data-stagger].revealed > *:nth-child(7) { transition-delay:.6s; }
[data-stagger].revealed > *:nth-child(8) { transition-delay:.7s; }

/* ── Buttons ───────────────────────────────────────────────── */
.btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  padding:.75rem 1.75rem;
  font-size:.875rem;
  font-weight:600;
  border-radius:var(--radius-sm);
  transition:all var(--transition);
  white-space:nowrap;
  border:2px solid transparent;
}
.btn:hover { transform:translateY(-3px); box-shadow:0 8px 25px rgba(0,0,0,.15); }
.btn:active { transform:translateY(-1px); }

.btn-primary {
  background:var(--primary);
  color:#fff;
  border-color:var(--primary);
  box-shadow:var(--shadow-blue);
}
.btn-primary:hover { background:var(--primary-dark); border-color:var(--primary-dark); box-shadow:0 8px 30px rgba(14,74,168,.35); }

.btn-whatsapp {
  background:var(--success);
  color:#fff;
  border-color:var(--success);
  box-shadow:var(--shadow-green);
}
.btn-whatsapp:hover { background:var(--success-dark); border-color:var(--success-dark); }

.btn-outline {
  background:transparent;
  color:var(--primary);
  border-color:var(--border);
}
.btn-outline:hover { background:var(--primary); color:#fff; border-color:var(--primary); }

.btn-outline-light {
  background:transparent;
  color:#fff;
  border-color:rgba(255,255,255,.4);
}
.btn-outline-light:hover { background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.7); }

.btn-white {
  background:#fff;
  color:var(--primary);
  border-color:#fff;
  box-shadow:var(--shadow-sm);
}
.btn-white:hover { box-shadow:var(--shadow-md); }

.btn-outline-white {
  background:transparent;
  color:#fff;
  border-color:rgba(255,255,255,.4);
}
.btn-outline-white:hover { background:rgba(255,255,255,.1); border-color:#fff; }

.btn-lg { padding:.95rem 2.25rem; font-size:1rem; }
.btn-sm { padding:.55rem 1.15rem; font-size:.8rem; }
.btn-block { width:100%; }

.btn-success {
  background:var(--success);
  color:#fff;
  border-color:var(--success);
  box-shadow:var(--shadow-green);
}
.btn-success:hover { background:var(--success-dark); border-color:var(--success-dark); box-shadow:0 8px 30px rgba(40,167,69,.35); }

/* ── 1. TOPBAR ─────────────────────────────────────────────── */
.topbar {
  background:var(--bg-dark);
  color:var(--text-light);
  font-size:.75rem;
  padding:.45rem 0;
  position:relative;
  z-index:1001;
}
.topbar-inner {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;
}
.topbar-left,.topbar-right { display:flex; align-items:center; gap:1.25rem; }
.topbar a {
  color:var(--text-light);
  display:flex; align-items:center; gap:.35rem;
  transition:color var(--transition-fast);
}
.topbar a:hover { color:#fff; }
.topbar-sep { color:rgba(255,255,255,.2); }
.topbar span { display:flex; align-items:center; gap:.35rem; }

@media(max-width:768px){ .topbar { display:none; } }

/* ── 2. HEADER ─────────────────────────────────────────────── */
.header {
  position:sticky;
  top:0;
  z-index:1000;
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border-light);
  transition:all var(--transition);
}
.header.scrolled {
  box-shadow:0 4px 24px rgba(0,0,0,.06);
  background:rgba(255,255,255,.98);
}
.header.nav-hidden { transform:translateY(-100%); }

.header-inner {
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:72px;
  gap:1.5rem;
}
.header-logo img { height:59px; width:auto; }

.nav-desktop { display:flex; align-items:center; gap:.25rem; }
.nav-link {
  padding:.5rem .85rem;
  font-size:.84rem;
  font-weight:500;
  color:var(--text-muted);
  border-radius:var(--radius-sm);
  transition:all var(--transition);
  position:relative;
}
.nav-link::after {
  content:'';
  position:absolute;
  bottom:2px; left:50%; right:50%;
  height:2px;
  background:var(--primary);
  border-radius:1px;
  transition:all var(--transition);
}
.nav-link:hover::after, .nav-link.active::after { left:.85rem; right:.85rem; }
.nav-link:hover { color:var(--primary); }
.nav-link.active { color:var(--primary); font-weight:600; }

/* Aula Virtual link standout */
.nav-aula {
  background:rgba(14,74,168,.06);
  color:var(--primary) !important;
  font-weight:600 !important;
  cursor:pointer;
  border:1px solid rgba(14,74,168,.15);
  padding:.45rem 1rem;
  display:inline-flex;
  align-items:center;
  gap:.4rem;
}
.nav-aula::after { display:none; }
.nav-aula:hover {
  background:var(--primary);
  color:#fff !important;
  border-color:var(--primary);
  transform:translateY(-1px);
}

.header-cta { flex-shrink:0; }

/* Dropdown */
.nav-dropdown { position:relative; }
.dropdown-toggle {
  display:flex; align-items:center; gap:.3rem;
  cursor:pointer;
}
.dropdown-toggle i { font-size:.55rem; transition:transform .25s; }
.dropdown-panel {
  position:absolute;
  top:calc(100% + 12px);
  left:-8px;
  min-width:240px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:.5rem;
  box-shadow:var(--shadow-lg);
  opacity:0;
  visibility:hidden;
  transform:translateY(8px);
  transition:all .25s cubic-bezier(.4,0,.2,1);
  z-index:100;
}
.nav-dropdown:hover .dropdown-panel { opacity:1; visibility:visible; transform:translateY(0); }
.nav-dropdown:hover .dropdown-toggle i { transform:rotate(180deg); }
.dropdown-panel a {
  display:flex; align-items:center; gap:.6rem;
  padding:.6rem .85rem;
  font-size:.84rem;
  color:var(--text-muted);
  border-radius:var(--radius-sm);
  transition:all .15s;
}
.dropdown-panel a:hover { background:rgba(14,74,168,.06); color:var(--primary); transform:translateX(3px); }
.dropdown-panel a i { width:20px; text-align:center; font-size:.8rem; color:var(--primary); }

/* Hamburger */
.hamburger {
  display:none;
  flex-direction:column;
  gap:5px;
  padding:.5rem;
  width:40px;
  height:40px;
  align-items:center;
  justify-content:center;
}
.hamburger span {
  display:block;
  width:22px;
  height:2px;
  background:var(--text);
  border-radius:2px;
  transition:all .3s;
}

@media(max-width:900px){
  .nav-desktop, .header-cta { display:none; }
  .hamburger { display:flex; }
}

/* Legacy nav classes for verification page */
.main-nav { position:sticky; top:0; z-index:1000; background:rgba(255,255,255,.95); backdrop-filter:blur(16px); border-bottom:1px solid var(--border-light); transition:all var(--transition); }
.main-nav.scrolled { box-shadow:0 4px 24px rgba(0,0,0,.06); }
.main-nav.nav-hidden { transform:translateY(-100%); }
.nav-inner { display:flex; align-items:center; justify-content:space-between; height:68px; gap:1.5rem; }
.nav-logo img { height:59px; width:auto; }
.nav-links { display:flex; align-items:center; gap:.15rem; }
.nav-cta { margin-left:.5rem; }
.mobile-menu-btn { display:none; font-size:1.3rem; color:var(--text-muted); padding:.5rem; }
@media(max-width:900px){ .nav-links,.nav-cta { display:none; } .mobile-menu-btn { display:flex; } }

/* ── MOBILE DRAWER ─────────────────────────────────────────── */
.mobile-overlay {
  position:fixed; inset:0; z-index:2000;
  background:rgba(0,0,0,.5);
  backdrop-filter:blur(4px);
  opacity:0; visibility:hidden;
  transition:all .35s;
}
.mobile-overlay.show { opacity:1; visibility:visible; }
.mobile-drawer {
  position:absolute; top:0; right:0;
  width:min(360px,88vw); height:100%;
  background:#fff;
  display:flex; flex-direction:column;
  padding:1.75rem;
  transform:translateX(100%);
  transition:transform .35s cubic-bezier(.4,0,.2,1);
  overflow-y:auto;
  box-shadow:-8px 0 40px rgba(0,0,0,.15);
}
.mobile-overlay.show .mobile-drawer { transform:translateX(0); }
.mobile-drawer-header {
  display:flex; justify-content:space-between; align-items:center;
  padding-bottom:1.25rem; border-bottom:1px solid var(--border); margin-bottom:1rem;
}
.mobile-drawer-header button {
  width:36px; height:36px;
  display:flex; align-items:center; justify-content:center;
  border-radius:var(--radius-sm);
  font-size:1.2rem;
  color:var(--text-muted);
}
.mobile-drawer-header button:hover { background:var(--bg-soft); }
.mobile-nav { display:flex; flex-direction:column; gap:.25rem; }
.mobile-link {
  display:flex; align-items:center; gap:.75rem;
  padding:.85rem .75rem;
  font-size:.95rem; font-weight:500;
  color:var(--text-muted); border-radius:var(--radius-sm);
  transition:all .2s;
}
.mobile-link i { width:22px; text-align:center; color:var(--primary); font-size:.9rem; }
.mobile-link:hover, .mobile-link.active { color:var(--primary); background:rgba(14,74,168,.06); }
.mobile-drawer-footer {
  margin-top:auto; padding-top:1.5rem;
  border-top:1px solid var(--border);
  display:flex; flex-direction:column; gap:1rem;
}
.mobile-drawer-contact {
  display:flex; flex-direction:column; gap:.5rem;
  font-size:.82rem; color:var(--text-muted);
}
.mobile-drawer-contact a { display:flex; align-items:center; gap:.4rem; }
.mobile-drawer-contact a:hover { color:var(--primary); }

/* Legacy mobile menu for verification page */
.mega-menu-overlay { position:fixed; inset:0; z-index:2000; background:rgba(0,0,0,.5); backdrop-filter:blur(4px); opacity:0; visibility:hidden; transition:all .35s; }
.mega-menu-overlay.show { opacity:1; visibility:visible; }
.mega-menu-content { position:absolute; top:0; right:0; width:min(340px,88vw); height:100%; background:#fff; display:flex; flex-direction:column; padding:1.5rem; transform:translateX(100%); transition:transform .35s cubic-bezier(.4,0,.2,1); overflow-y:auto; box-shadow:-8px 0 40px rgba(0,0,0,.15); }
.mega-menu-overlay.show .mega-menu-content { transform:translateX(0); }
.mega-menu-header { display:flex; justify-content:space-between; align-items:center; padding-bottom:1.25rem; border-bottom:1px solid var(--border); margin-bottom:1rem; }
.mega-menu-header button { width:36px; height:36px; display:flex; align-items:center; justify-content:center; border-radius:var(--radius-sm); font-size:1.2rem; color:var(--text-muted); }
.mob-link { display:flex; align-items:center; gap:.75rem; padding:.85rem .75rem; font-size:.95rem; font-weight:500; color:var(--text-muted); border-radius:var(--radius-sm); transition:all .2s; }
.mob-link i { width:22px; text-align:center; color:var(--primary); font-size:.9rem; }
.mob-link:hover,.mob-link.active { color:var(--primary); background:rgba(14,74,168,.06); }
.mega-menu-footer { margin-top:auto; padding-top:1.25rem; border-top:1px solid var(--border); display:flex; flex-direction:column; gap:.5rem; font-size:.8rem; color:var(--text-muted); }
.mega-menu-footer a { color:var(--text-muted); display:flex; align-items:center; gap:.4rem; }
.mega-menu-footer a:hover { color:var(--primary); }

/* ── 3. HERO ───────────────────────────────────────────────── */
.hero {
  background: linear-gradient(135deg, var(--bg-dark) 0%, #0d2f6b 50%, var(--primary) 100%);
  background-size:200% 200%;
  animation:gradient-shift 12s ease infinite;
  padding:0.9rem 0 0;
  position:relative;
  overflow:visible;
  color:#fff;
}
.hero-lite {
  background:linear-gradient(180deg, #f8fbff 0%, #eef5ff 52%, #e6f0ff 100%);
  color:var(--text);
}
.hero-lite::before {
  background:rgba(53,167,255,.14);
}
.hero-lite::after {
  background:rgba(16,185,129,.1);
}
.hero-lite .badge-light,
.hero-lite .hero-badge {
  background:#fff;
  border-color:rgba(14,74,168,.1);
  color:var(--primary);
}
.hero-lite h1,
.hero-lite .hero-subtitle,
.hero-lite p {
  color:var(--text);
}
.hero::before {
  content:'';
  position:absolute;
  width:600px; height:600px;
  border-radius:50%;
  background:rgba(53,167,255,.1);
  top:-200px; right:-150px;
  animation:morph-blob 15s ease-in-out infinite, float-slow 8s ease-in-out infinite;
}
.hero::after {
  content:'';
  position:absolute;
  width:400px; height:400px;
  border-radius:50%;
  background:rgba(244,180,0,.08);
  bottom:-150px; left:-100px;
  animation:morph-blob 12s ease-in-out infinite reverse, float-slow 10s ease-in-out infinite reverse;
}
.hero-inner {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4rem;
  align-items:end;
  position:relative;
  z-index:1;
}
.hero-content { align-self:center; max-width:600px; }
.hero-badge {
  display:none;
  align-items:center;
  gap:.4rem;
  font-size:.75rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:rgba(255,255,255,.85);
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.15);
  padding:.35rem 1rem;
  border-radius:var(--radius-full);
  margin-bottom:1.5rem;
  animation:blur-in .8s ease both;
}
.hero h1 {
  font-size:clamp(2rem, 5vw, 3.25rem);
  font-weight:800;
  color:#fff;
  line-height:1.15;
  margin-bottom:1.25rem;
  letter-spacing:-.02em;
  animation:slide-up-3d 1s cubic-bezier(.25,.46,.45,.94) .2s both;
}
.text-gradient {
  color:#fff;
  -webkit-text-fill-color:#fff;
}
/* Hero size-play: large word + small word */
.hero-word-lg {
  display:block;
  font-size:1.4em;
  line-height:1.05;
  letter-spacing:.04em;
}
.hero-word-sm {
  display:block;
  font-size:.65em;
  font-weight:700;
  letter-spacing:.06em;
  color:rgba(255,255,255,.85);
  margin-top:.15em;
}
.hero-subtitle {
  font-size:1.05rem;
  color:rgba(255,255,255,.75);
  line-height:1.75;
  margin-bottom:1.5rem;
  animation:blur-in 1s ease .4s both;
}
.hero-bullets {
  display:flex; flex-direction:column; gap:.6rem;
  margin-bottom:2rem;
}
.hero-bullets li {
  display:flex; align-items:center; gap:.6rem;
  font-size:.9rem;
  color:rgba(255,255,255,.85);
}
.hero-bullets li i { color:var(--success); font-size:.8rem; }
.hero-actions {
  display:flex; gap:1rem; flex-wrap:wrap;
  margin-bottom:2.5rem;
  animation:slide-in-bounce .8s cubic-bezier(.25,.46,.45,.94) .6s both;
}
.hero-trust {
  display:flex; align-items:center; gap:1.5rem;
  padding-top:1.5rem;
  border-top:1px solid rgba(255,255,255,.12);
}
.hero-trust-item {
  font-size:.82rem;
  color:rgba(255,255,255,.7);
}
.hero-trust-item strong {
  color:#fff;
  font-weight:700;
}
.hero-trust-sep {
  width:1px; height:32px;
  background:rgba(255,255,255,.15);
}

/* Hero visual */
.hero-visual { display:flex; justify-content:center; align-items:flex-end; position:relative; }
.hero-image-wrapper {
  position:relative;
  max-width:520px;
  width:100%;
  padding:0;
  background:none;
  border:none;
}
.hero-image-wrapper img {
  width:100%;
  height:auto;
  aspect-ratio:4/5;
  object-fit:contain;
  object-position:bottom center;
  background:transparent;
  filter:drop-shadow(0 16px 40px rgba(0,0,0,.25));
  position:relative;
  z-index:3;
}
.hero-placeholder {
  width:100%;
  aspect-ratio:4/5;
  background:rgba(255,255,255,.05);
  border:2px dashed rgba(255,255,255,.2);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:.75rem;
  color:rgba(255,255,255,.4);
  font-size:.85rem;
  text-align:center;
}
.hero-placeholder i { font-size:3rem; }
.hero-cert-card {
  position:absolute;
  bottom:2rem; left:-2rem;
  background:#fff;
  color:var(--text);
  padding:1rem 1.25rem;
  border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  display:flex; align-items:center; gap:.75rem;
  animation:float-slow 5s ease-in-out infinite, blur-in .8s ease 1s both;
  z-index:4;
}
.hero-cert-card i { font-size:1.5rem; color:var(--primary); }
.hero-cert-card strong { font-size:.82rem; display:block; }
.hero-cert-card small { font-size:.72rem; color:var(--text-muted); }

/* Hero separator line (replaces wave) */
.hero-wave {
  position:absolute;
  bottom:0; left:0; right:0;
  z-index:2;
  height:4px;
  background:linear-gradient(90deg, transparent 0%, var(--primary) 20%, var(--secondary) 50%, var(--primary) 80%, transparent 100%);
}
.hero-wave svg { display:none; }

@media(max-width:900px){
  .hero { padding:4rem 0 0; }
  .hero-inner { grid-template-columns:1fr; gap:2.5rem; }
  .hero-visual { order:-1; }
  .hero-image-wrapper { max-width:340px; }
  .hero-cert-card { left:0; bottom:1rem; }
  .hero-trust { flex-wrap:wrap; gap:1rem; }
}
@media(max-width:480px){
  .hero { padding:3rem 0 0; }
  .hero-actions { flex-direction:column; }
  .hero-actions .btn { width:100%; }
}

/* ── 4. TRUST BAND ─────────────────────────────────────────── */
.trust-band {
  background:var(--bg-soft);
  padding:3rem 0;
  border-bottom:1px solid var(--border-light);
  position:relative;
  z-index:1;
}
.trust-band-grid {
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:1.5rem;
}
.trust-band-item {
  display:flex;
  align-items:center;
  gap:1rem;
  padding:1.25rem;
  background:#fff;
  border-radius:0;
  border:none;
  transition:all var(--transition);
}
.trust-band-item[data-color="green"] { background:#e8f0fe; border-left:4px solid var(--primary); }
.trust-band-item[data-color="red"] { background:#e8f0fe; border-left:4px solid var(--primary); }
.trust-band-item[data-color="blue"] { background:#e8f0fe; border-left:4px solid var(--primary); }
.trust-band-item[data-color="yellow"] { background:#e8f0fe; border-left:4px solid var(--primary); }
.trust-band-item:hover { transform:translateY(-5px) scale(1.03); box-shadow:var(--shadow-md); }
.trust-band-icon {
  flex-shrink:0;
  width:48px; height:48px;
  display:flex; align-items:center; justify-content:center;
  background:transparent;
  color:inherit;
  border-radius:0;
  font-size:1.3rem;
}
.trust-band-item[data-color="green"] .trust-band-icon { color:var(--primary); }
.trust-band-item[data-color="red"] .trust-band-icon { color:var(--primary); }
.trust-band-item[data-color="blue"] .trust-band-icon { color:var(--primary); }
.trust-band-item[data-color="yellow"] .trust-band-icon { color:var(--primary); }
.trust-band-item strong { font-size:.88rem; color:var(--text); display:block; }
.trust-band-item p { font-size:.78rem; color:var(--text-muted); line-height:1.5; margin:0; }

@media(max-width:900px){ .trust-band-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:480px){ .trust-band-grid { grid-template-columns:1fr; } }

/* ── 5. ABOUT / QUÉ HACE ICEFP ────────────────────────────── */
.about-layout {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4rem;
  align-items:center;
}
.about-content h2 {
  font-size:clamp(1.5rem, 3vw, 2.15rem);
  font-weight:800;
  margin-bottom:1rem;
  letter-spacing:-.01em;
}
.about-content p {
  font-size:.95rem;
  color:var(--text-muted);
  line-height:1.8;
  margin-bottom:1rem;
}
.about-highlights {
  display:flex; flex-direction:column; gap:.75rem;
  margin:1.5rem 0 2rem;
}
.about-highlight {
  display:flex; align-items:center; gap:.75rem;
  font-size:.88rem;
  font-weight:500;
  color:var(--text);
}
.about-highlight i {
  color:var(--primary);
  width:20px;
  text-align:center;
}
.about-image { position:relative; }
.about-image img {
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  width:100%;
  object-fit:cover;
}
.about-img-placeholder {
  width:100%;
  aspect-ratio:1.1;
  border-radius:var(--radius-lg);
  background:var(--bg-soft);
  border:2px dashed var(--border);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:.75rem;
  color:var(--text-light);
  font-size:.85rem;
  text-align:center;
}
.about-img-placeholder i { font-size:3rem; }

@media(max-width:768px){
  .about-layout { grid-template-columns:1fr; gap:2.5rem; }
  .about-image { order:-1; max-width:420px; margin:0 auto; }
}

/* ── 6. AREAS GRID ─────────────────────────────────────────── */
.areas-grid {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1.5rem;
}
.area-card {
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:2rem 1.75rem;
  text-align:center;
  transition:all var(--transition);
  display:flex; flex-direction:column; align-items:center; gap:.75rem;
  text-decoration:none;
  color:inherit;
}
.area-card:hover {
  transform:translateY(-6px);
  box-shadow:var(--shadow-md);
  border-color:var(--ac, var(--primary));
}
.area-icon {
  width:60px; height:60px;
  display:flex; align-items:center; justify-content:center;
  border-radius:var(--radius);
  font-size:1.4rem;
  background:var(--ac-bg, rgba(14,74,168,.08));
  color:var(--ac, var(--primary));
  transition:all var(--transition);
  margin-bottom:.5rem;
}
.area-card:hover .area-icon { transform:scale(1.1); }
.area-card h3 {
  font-size:1rem;
  font-weight:700;
  color:var(--text);
}
.area-card p {
  font-size:.82rem;
  color:var(--text-muted);
  line-height:1.6;
}
.area-cta {
  margin-top:auto;
  font-size:.8rem;
  font-weight:600;
  color:var(--primary);
  display:flex; align-items:center; gap:.35rem;
  transition:all var(--transition);
}
.area-card:hover .area-cta { gap:.6rem; }

@media(max-width:900px){ .areas-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:480px){ .areas-grid { grid-template-columns:1fr; } }

/* ── 6B. AREAS TALL (2×3 grid with head-peek effect) ──── */
.areas-tall {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1.2rem;
  max-width:980px;
  margin:0 auto;
}
.area-tall-card {
  position:relative;
  width:100%;
  height:380px; 
  border-radius:var(--radius-lg);
  overflow:visible;
  text-decoration:none;
  color:#fff;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  transition:transform .6s cubic-bezier(.25,.46,.45,.94), box-shadow .6s ease;
  clip-path:inset(-12% 0 0 0 round var(--radius-lg));
}
/* Individual solid colors for each area — VIBRANT */
.area-tall-card:nth-child(1) { background:#1565C0; } /* Educación - azul vibrante */
.area-tall-card:nth-child(2) { background:#00897B; } /* Contabilidad - verde teal */
.area-tall-card:nth-child(3) { background:#8E24AA; } /* Administración - púrpura vibrante */
.area-tall-card:nth-child(4) { background:#F57F17; } /* Derecho - dorado vibrante */
.area-tall-card:nth-child(5) { background:#E53935; } /* Ingeniería - rojo vibrante */
.area-tall-card:nth-child(6) { background:#1E88E5; } /* Enfermería - azul celeste */
.area-tall-card::before { display:none; }

/* Background letter pattern — behind image, Rifton exterior stroke */
.area-tall-card::after {
  content:attr(data-label) '\A' attr(data-label) '\A' attr(data-label) '\A' attr(data-label) '\A' attr(data-label);
  white-space:pre-wrap;
  position:absolute;
  top:50%; left:50%;
  transform:translate(-50%,-50%);
  font-family:'Rifton Norm', 'Inter', sans-serif;
  font-size:2.9rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:transparent;
  -webkit-text-stroke:0.4px rgba(255,255,255,.22);
  paint-order:stroke fill;
  line-height:1.1;
  pointer-events:none;
  z-index:0;
  text-align:center;
  width:250%;
}
.area-tall-card:hover {
  transform:translateY(-10px) scale(1.02);
  box-shadow:0 28px 70px rgba(0,0,0,.35), 0 0 30px rgba(14,74,168,.12);
}
.area-tall-card img {
  position:absolute;
  bottom:0; left:50%;
  transform:translateX(-50%);
  width:100%;
  height:auto;
  max-height:110%;
  object-fit:contain;
  object-position:bottom center;
  transition:transform .8s cubic-bezier(.25,.46,.45,.94), filter .6s ease;
  filter:drop-shadow(0 8px 20px rgba(0,0,0,.3));
  z-index:1;
}
.area-tall-card:hover img { transform:translateX(-50%) scale(1.04) translateY(-8px); filter:drop-shadow(0 12px 28px rgba(0,0,0,.4)); }
.area-tall-placeholder {
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, var(--primary) 0%, #0d2f6b 100%);
  flex-direction:column;
  align-items:center;
  justify-content:center;
  color:rgba(255,255,255,.4);
  font-size:3rem;
}

.area-tall-overlay {
  position:relative;
  z-index:2;
  padding:1.75rem 1.25rem;
  background:linear-gradient(to top, rgba(0,0,0,.95) 0%, rgba(0,0,0,.65) 55%, transparent 100%);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:0;
  min-height:35%;
  transition:min-height .6s cubic-bezier(.25,.46,.45,.94);
}
/* Hide icons in area cards */
.area-tall-icon { display:none; }

/* Area name — centered, uppercase, bold */
.area-tall-overlay h3 {
  font-size:1.35rem;
  font-weight:900;
  color:#fff;
  text-transform:uppercase;
  letter-spacing:.06em;
  text-align:center;
  text-shadow:0 2px 10px rgba(0,0,0,.7);
  position:relative;
  z-index:1;
  line-height:1.2;
}
/* Remove old h3 pattern — now on card::after */
.area-tall-overlay h3::before,
.area-tall-overlay h3::after {
  display:none;
}
.area-tall-overlay p {
  font-size:.78rem;
  color:rgba(255,255,255,.75);
  line-height:1.5;
  max-height:0;
  overflow:hidden;
  opacity:0;
  text-align:center;
  transition:max-height .5s ease, opacity .4s ease, margin .4s ease;
  margin-top:0;
}
.area-tall-card:hover .area-tall-overlay p {
  max-height:60px;
  opacity:1;
  margin-top:.5rem;
}

.areas-cta {
  text-align:center;
  margin-top:2rem;
}
.areas-btn-ver {
  font-size:1rem;
  padding:1rem 2.5rem;
  letter-spacing:.02em;
  animation:pulse-soft 2.5s infinite;
}
@keyframes pulse-soft {
  0%,100% { box-shadow:0 8px 32px rgba(37,211,102,.25); }
  50% { box-shadow:0 8px 48px rgba(37,211,102,.45); }
}

@media(max-width:1100px){
  .areas-tall { grid-template-columns:repeat(3, 1fr); }
  .area-tall-card { height:340px; }
}
@media(max-width:700px){
  .areas-tall { grid-template-columns:repeat(2, 1fr); gap:1rem; }
  .area-tall-card { height:300px; }
}
@media(max-width:480px){
  .areas-tall { grid-template-columns:1fr 1fr; }
  .area-tall-card { height:260px; }
}

/* ── 7B. REASONS INVERTED-U (∩ con imagen central) ─────── */
.reasons-u {
  position:relative;
  max-width:1180px;
  margin:0 auto;
  min-height:760px;
  display:grid;
  grid-template-columns:minmax(230px, 260px) minmax(360px, 420px) minmax(230px, 260px);
  grid-template-rows:220px 240px 240px;
  gap:1.1rem 1.6rem;
  justify-content:center;
  align-items:stretch;
}
/* Center image — free, no frame */
.reasons-u-center {
  grid-column:2;
  grid-row:2 / 4;
  justify-self:center;
  width:min(100%, 390px);
  align-self:stretch;
  display:flex;
  align-items:center;
  justify-content:center;
}
.reasons-u-center img {
  width:100%;
  height:100%;
  object-fit:contain;
  background:none;
  border:none;
  padding:0;
  border-radius:0;
  box-shadow:none;
  filter:drop-shadow(0 20px 50px rgba(14,74,168,.18));
  transition:transform .6s ease;
}
.reasons-u-center:hover img { transform:scale(1.04); }
.reasons-u .reasons-img-placeholder {
  width:100%;
  height:100%;
  border-radius:28px;
  background:linear-gradient(180deg, #ffffff 0%, #eef5ff 100%);
  border:2px dashed var(--border);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  color:var(--text-light);
  font-size:.8rem;
  text-align:center;
}
.reasons-u .reasons-img-placeholder i { font-size:2.5rem; }

/* Shared card style — slightly smaller, centered, uppercase titles */
.reason-u-card {
  background:#fff;
  border:1px solid var(--border);
  border-radius:20px;
  padding:1.25rem;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:.7rem;
  min-height:175px;
  transition:all .5s cubic-bezier(.25,.46,.45,.94);
  position:relative;
  overflow:hidden;
  box-shadow:0 8px 24px rgba(15,23,42,.05);
}
.reason-u-card::before {
  content:'';
  position:absolute;
  top:0; left:0; right:0;
  height:3px;
  background:var(--primary);
  transform:scaleX(0);
  transition:transform .5s cubic-bezier(.25,.46,.45,.94);
  transform-origin:left;
}
.reason-u-card:hover::before { transform:scaleX(1); }
.reason-u-card:hover {
  transform:translateY(-8px);
  box-shadow:0 20px 50px rgba(14,74,168,.15), 0 0 16px rgba(14,74,168,.06);
  border-color:rgba(14,74,168,.25);
}
.reason-u-icon {
  width:54px; height:54px;
  display:flex; align-items:center; justify-content:center;
  background:var(--primary);
  color:#fff;
  border-radius:16px;
  font-size:1.3rem;
  transition:all .5s cubic-bezier(.25,.46,.45,.94);
  box-shadow:0 6px 18px rgba(14,74,168,.2);
}
.reason-u-card:hover .reason-u-icon {
  transform:scale(1.12) rotate(6deg);
  box-shadow:0 10px 24px rgba(14,74,168,.35);
}
.reason-u-card h3 {
  font-size:1.35rem;
  font-weight:800;
  color:var(--text);
  line-height:1.15;
  text-transform:uppercase;
  letter-spacing:.03em;
  transition:opacity .35s ease, max-height .4s ease, transform .35s ease;
}
/* On hover: hide title, show description */
.reason-u-card:hover h3 {
  opacity:0;
  max-height:0;
  overflow:hidden;
  transform:translateY(-8px);
}
.reason-u-card p {
  font-size:.88rem;
  color:var(--text);
  line-height:1.55;
  opacity:0;
  max-height:0;
  overflow:hidden;
  transform:translateY(10px);
  transition:max-height .4s ease, opacity .35s ease, transform .35s ease;
}
.reason-u-card:hover p,
.reason-u-card:focus-visible p {
  opacity:1;
  max-height:120px;
  transform:translateY(0);
}

/* Position cards: 2 left, 1 top-center, 2 right (∩ shape) */
.reason-u-pos-1 { grid-column:1; grid-row:2; }
.reason-u-pos-2 { grid-column:1; grid-row:3; }
.reason-u-pos-3 { grid-column:2; grid-row:1; text-align:center; align-items:center; justify-self:center; width:min(100%, 260px); }
.reason-u-pos-4 { grid-column:3; grid-row:2; }
.reason-u-pos-5 { grid-column:3; grid-row:3; }

@media(max-width:900px){
  .reasons-u {
    grid-template-columns:1fr;
    grid-template-rows:auto;
    min-height:auto;
  }
  .reasons-u-center { grid-column:1; grid-row:1; width:min(100%, 320px); margin:0 auto 1rem; }
  .reason-u-pos-1, .reason-u-pos-2, .reason-u-pos-3,
  .reason-u-pos-4, .reason-u-pos-5 { grid-column:1; grid-row:auto; }
  .reason-u-card { min-height:auto; aspect-ratio:auto; }
  .reason-u-card h3 { opacity:1 !important; max-height:none !important; transform:none !important; }
  .reason-u-card p { opacity:1; max-height:120px; transform:none; }
}

/* ── 9B. PROFILES INVERTED-U (∩ con imagen central) ──── */
.profiles-u {
  position:relative;
  max-width:1180px;
  margin:0 auto;
  min-height:760px;
  display:grid;
  grid-template-columns:minmax(230px, 260px) minmax(360px, 420px) minmax(230px, 260px);
  grid-template-rows:220px 240px 240px;
  gap:1.1rem 1.6rem;
  justify-content:center;
  align-items:stretch;
}
.profiles-u-center {
  grid-column:2;
  grid-row:2 / 4;
  justify-self:center;
  width:min(100%, 390px);
  align-self:stretch;
  display:flex;
  align-items:center;
  justify-content:center;
}
.profiles-u-center img {
  width:100%;
  height:100%;
  object-fit:contain;
  background:none;
  border:none;
  padding:0;
  border-radius:0;
  box-shadow:none;
  filter:drop-shadow(0 20px 50px rgba(14,74,168,.18));
  transition:transform .6s ease;
}
.profiles-u-center:hover img { transform:scale(1.04); }
.profiles-u .profiles-img-placeholder {
  width:100%;
  height:100%;
  border-radius:28px;
  background:linear-gradient(180deg, #ffffff 0%, #eef5ff 100%);
  border:2px dashed var(--border);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  color:var(--text-light);
  font-size:.8rem;
  text-align:center;
}
.profiles-u .profiles-img-placeholder i { font-size:2.5rem; }

.profile-u-card {
  background:#fff;
  border:1px solid var(--border);
  border-radius:20px;
  padding:1.5rem;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:.7rem;
  min-height:175px;
  transition:all .5s cubic-bezier(.25,.46,.45,.94);
  position:relative;
  overflow:hidden;
  box-shadow:0 8px 24px rgba(15,23,42,.05);
}
.profile-u-card::before {
  content:'';
  position:absolute;
  top:0; left:0; right:0;
  height:3px;
  background:var(--primary);
  transform:scaleX(0);
  transition:transform .5s cubic-bezier(.25,.46,.45,.94);
  transform-origin:left;
}
.profile-u-card:hover::before { transform:scaleX(1); }
.profile-u-card:hover {
  transform:translateY(-8px);
  box-shadow:0 20px 50px rgba(14,74,168,.15), 0 0 16px rgba(14,74,168,.06);
  border-color:rgba(14,74,168,.25);
}
.profile-u-icon {
  width:54px; height:54px;
  display:flex; align-items:center; justify-content:center;
  background:var(--primary);
  color:#fff;
  border-radius:50%;
  font-size:1.3rem;
  transition:all .5s cubic-bezier(.25,.46,.45,.94);
  box-shadow:0 6px 18px rgba(14,74,168,.2);
}
.profile-u-card:hover .profile-u-icon {
  transform:scale(1.12) rotate(6deg);
  box-shadow:0 10px 24px rgba(14,74,168,.35);
}
.profile-u-card h3 {
  font-size:1.35rem;
  font-weight:800;
  color:var(--text);
  line-height:1.15;
  text-transform:uppercase;
  letter-spacing:.03em;
  transition:opacity .35s ease, max-height .4s ease, transform .35s ease;
}
.profile-u-card:hover h3 {
  opacity:0;
  max-height:0;
  overflow:hidden;
  transform:translateY(-8px);
}
.profile-u-card p {
  font-size:.88rem;
  color:var(--text);
  line-height:1.55;
  opacity:0;
  max-height:0;
  overflow:hidden;
  transform:translateY(10px);
  transition:max-height .4s ease, opacity .35s ease, transform .35s ease;
}
.profile-u-card:hover p,
.profile-u-card:focus-visible p {
  opacity:1;
  max-height:120px;
  transform:translateY(0);
}

.profile-u-pos-1 { grid-column:1; grid-row:2; }
.profile-u-pos-2 { grid-column:1; grid-row:3; }
.profile-u-pos-3 { grid-column:2; grid-row:1; text-align:center; align-items:center; justify-self:center; width:min(100%, 260px); }
.profile-u-pos-4 { grid-column:3; grid-row:2; }
.profile-u-pos-5 { grid-column:3; grid-row:3; }

@media(max-width:900px){
  .profiles-u {
    grid-template-columns:1fr;
    grid-template-rows:auto;
    min-height:auto;
  }
  .profiles-u-center { grid-column:1; grid-row:1; width:min(100%, 320px); margin:0 auto 1rem; }
  .profile-u-pos-1, .profile-u-pos-2, .profile-u-pos-3,
  .profile-u-pos-4, .profile-u-pos-5 { grid-column:1; grid-row:auto; }
  .profile-u-card { min-height:auto; aspect-ratio:auto; }
  .profile-u-card h3 { opacity:1 !important; max-height:none !important; transform:none !important; }
  .profile-u-card p { opacity:1; max-height:120px; transform:none; }
}

/* ── 8. CERTIFICADOS ───────────────────────────────────────── */
.cert-layout {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4rem;
  align-items:center;
}
.cert-content h2 {
  font-size:clamp(1.5rem, 3vw, 2.15rem);
  font-weight:800;
  color:#fff;
  margin-bottom:1rem;
}
.cert-content p {
  font-size:.95rem;
  color:rgba(255,255,255,.7);
  line-height:1.8;
  margin-bottom:1.5rem;
}
.cert-features {
  display:flex; flex-direction:column; gap:.75rem;
  margin-bottom:2rem;
}
.cert-feature {
  display:flex; align-items:center; gap:.75rem;
  font-size:.88rem;
  color:rgba(255,255,255,.85);
}
.cert-feature i { color:var(--secondary); width:20px; text-align:center; }
.cert-actions { display:flex; gap:1rem; flex-wrap:wrap; }

/* Cert visual — no frame, larger */
.cert-visual { display:flex; justify-content:center; position:relative; }
.cert-mockup { position:relative; max-width:620px; width:100%; }
.cert-mockup img {
  width:100%;
  height:auto;
  object-fit:contain;
  background:none;
  padding:0;
  border:none;
  border-radius:0;
  box-shadow:none;
  filter:drop-shadow(0 24px 60px rgba(0,0,0,.35));
}
.cert-mockup-placeholder {
  width:100%;
  aspect-ratio:1.4;
  border-radius:var(--radius-lg);
  background:rgba(255,255,255,.05);
  border:2px dashed rgba(255,255,255,.2);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:.75rem;
  color:rgba(255,255,255,.4);
  font-size:.85rem;
  text-align:center;
}
.cert-mockup-placeholder i { font-size:3rem; }
.cert-qr-badge {
  position:absolute;
  bottom:1rem; right:-.5rem;
  background:#fff;
  color:#16a34a;
  padding:.75rem 1.15rem;
  border-radius:var(--radius);
  box-shadow:0 8px 28px rgba(22,163,74,.25);
  display:flex; align-items:center; gap:.5rem;
  font-size:.82rem;
  font-weight:700;
  animation:float 4s ease-in-out infinite 1s;
  border:2px solid rgba(22,163,74,.15);
}
.cert-qr-badge i { font-size:1.25rem; color:#16a34a; }

@media(max-width:768px){
  .cert-layout { grid-template-columns:1fr; gap:2.5rem; }
  .cert-visual { order:-1; }
  .cert-mockup { max-width:400px; }
}

/* ── 10. STEPS / CÓMO FUNCIONA ─────────────────────────────── */
.steps-timeline {
  display:flex;
  align-items:flex-start;
  justify-content:center;
  gap:0;
}
.step-card {
  flex:1;
  max-width:260px;
  text-align:center;
  padding:1.5rem 1rem;
}
.step-number {
  width:40px; height:40px;
  display:flex; align-items:center; justify-content:center;
  background:var(--primary);
  color:#fff;
  border-radius:50%;
  font-size:.85rem;
  font-weight:800;
  margin:0 auto .75rem;
}
.step-icon {
  width:56px; height:56px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(14,74,168,.08);
  color:var(--primary);
  border-radius:var(--radius);
  font-size:1.3rem;
  margin:0 auto 1rem;
}
.step-card h3 { font-size:.9rem; font-weight:700; margin-bottom:.4rem; }
.step-card p { font-size:.82rem; color:var(--text-muted); line-height:1.65; }

.step-connector {
  flex:0 0 40px;
  height:2px;
  background:var(--border);
  margin-top:52px;
}

@media(max-width:768px){
  .steps-timeline { flex-direction:column; align-items:center; }
  .step-connector { width:2px; height:30px; flex:0 0 30px; margin-top:0; }
}

/* ── 11. PROMO + FEATURED GRID ─────────────────────────────── */
.promo-featured { margin-bottom:3rem; }
.promo-star {
  background:linear-gradient(135deg, var(--primary) 0%, #0d2f6b 100%);
  color:#fff;
  border-radius:var(--radius-lg);
  padding:3rem;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.promo-star::before {
  content:'';
  position:absolute;
  width:300px; height:300px;
  border-radius:50%;
  background:rgba(255,255,255,.04);
  top:-100px; right:-80px;
  animation:morph-blob 14s ease-in-out infinite;
}
.promo-star-badge {
  display:inline-block;
  font-size:.9rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  background:var(--accent);
  color:var(--bg-dark);
  padding:.5rem 1.5rem;
  border-radius:var(--radius-full);
  margin-bottom:1rem;
}
.promo-star h3 {
  font-size:clamp(1.75rem, 4vw, 2.5rem);
  font-weight:900;
  color:#fff;
  margin-bottom:.75rem;
}
.promo-star > p {
  font-size:1rem;
  color:rgba(255,255,255,.75);
  max-width:500px;
  margin:0 auto 1.5rem;
  line-height:1.7;
}
.promo-star ul {
  display:flex; flex-wrap:wrap; justify-content:center; gap:.75rem 2rem;
  margin-bottom:2rem;
}
.promo-star li {
  display:flex; align-items:center; gap:.5rem;
  font-size:.88rem;
  color:rgba(255,255,255,.85);
}
.promo-star li i { color:var(--success); }

.featured-grid {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1.5rem;
}
.feat-card {
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:1.75rem;
  display:flex; flex-direction:column; gap:.6rem;
  transition:all var(--transition);
  position:relative;
  overflow:hidden;
}
.feat-card::before {
  content:'';
  position:absolute;
  top:0; left:0; right:0;
  height:3px;
  background:var(--primary);
  transform:scaleX(0);
  transition:transform .4s ease;
  transform-origin:left;
}
.feat-card:hover::before { transform:scaleX(1); }
.feat-card:hover { transform:perspective(600px) translateY(-8px) rotateX(2deg); box-shadow:0 20px 50px rgba(0,0,0,.1), 0 0 15px rgba(14,74,168,.06); }
.feat-tag {
  display:inline-block;
  font-size:.65rem; font-weight:700;
  color:#fff;
  padding:.2rem .7rem;
  border-radius:var(--radius-full);
  width:fit-content;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.feat-title { font-size:.95rem; font-weight:700; line-height:1.35; }
.feat-area { font-size:.78rem; color:var(--text-muted); display:flex; align-items:center; gap:.35rem; }
.feat-area i { font-size:.65rem; }
.feat-meta {
  display:flex; gap:1rem;
  font-size:.78rem; color:var(--text-muted);
  padding-top:.6rem;
  border-top:1px solid var(--border-light);
}
.feat-meta i { margin-right:.3rem; color:var(--primary); }
.feat-card .btn { margin-top:auto; align-self:flex-start; }

@media(max-width:900px){ .featured-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:480px){ .featured-grid { grid-template-columns:1fr; } }

/* ── 12. STATS ─────────────────────────────────────────────── */
.stats-section {
  background:linear-gradient(135deg, var(--bg-dark) 0%, #0d2f6b 100%);
  padding:5rem 0;
  position:relative;
  overflow:hidden;
}
.stats-section::before {
  content:'';
  position:absolute;
  width:500px; height:500px;
  border-radius:50%;
  background:rgba(53,167,255,.08);
  top:-200px; right:-100px;
}
.stats-grid {
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:2rem;
  text-align:center;
}
.stat-item {
  padding:2rem 1rem;
  border-radius:var(--radius-lg);
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  transition:all var(--transition);
}
.stat-item:hover {
  background:rgba(255,255,255,.1);
  transform:translateY(-4px);
}
.stat-number {
  font-size:clamp(2rem, 4vw, 2.75rem);
  font-weight:900;
  color:#fff;
  line-height:1;
  margin-bottom:.5rem;
}
.stat-number.counting { animation:count-glow 2s ease forwards; }
.stat-plus { color:var(--secondary); }
.stat-label {
  font-size:.78rem;
  font-weight:600;
  color:rgba(255,255,255,.5);
  text-transform:uppercase;
  letter-spacing:.06em;
}

@media(max-width:768px){ .stats-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:480px){ .stats-grid { grid-template-columns:1fr 1fr; gap:1rem; } }

/* ── 13. TESTIMONIALS ──────────────────────────────────────── */
.testimonials-wrapper { overflow:hidden; padding:1rem 0; }
.testimonials-track {
  display:flex;
  gap:1.5rem;
  animation:marquee 35s linear infinite;
  width:max-content;
}
.testimonials-track:hover { animation-play-state:paused; }
.testimonial-card {
  width:360px;
  flex-shrink:0;
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:2rem;
  transition:all var(--transition);
}
.testimonial-card:hover {
  transform:perspective(600px) translateY(-5px) rotateX(1deg);
  box-shadow:0 16px 40px rgba(0,0,0,.08), 0 0 15px rgba(14,74,168,.04);
  border-color:rgba(14,74,168,.2);
}
.testimonial-stars {
  color:#F59E0B;
  font-size:.75rem;
  margin-bottom:.75rem;
  letter-spacing:.1em;
}
.testimonial-text {
  font-size:.88rem;
  color:var(--text-muted);
  line-height:1.75;
  font-style:italic;
  margin-bottom:1.25rem;
}
.testimonial-text::before { content:'\201C'; font-size:1.2rem; color:var(--primary); opacity:.5; }
.testimonial-text::after { content:'\201D'; font-size:1.2rem; color:var(--primary); opacity:.5; }
.testimonial-author { display:flex; align-items:center; gap:.75rem; }
.testimonial-avatar {
  width:42px; height:42px;
  border-radius:50%;
  background:rgba(14,74,168,.1);
  color:var(--primary);
  display:flex; align-items:center; justify-content:center;
  font-weight:700;
  font-size:.8rem;
}
.testimonial-name { font-size:.84rem; font-weight:600; color:var(--text); }
.testimonial-role { font-size:.74rem; color:var(--text-muted); }

/* ── 14. FAQ ───────────────────────────────────────────────── */
.faq-list {
  max-width:768px;
  margin:0 auto;
  display:flex; flex-direction:column; gap:.75rem;
}
.faq-item {
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  transition:all var(--transition);
}
.faq-item:hover { border-color:rgba(14,74,168,.2); box-shadow:0 4px 16px rgba(0,0,0,.04); }
.faq-item.open { border-color:var(--primary); box-shadow:var(--shadow-sm); }
.faq-question {
  width:100%;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:1.25rem 1.5rem;
  font-size:.9rem;
  font-weight:600;
  color:var(--text);
  text-align:left;
  gap:1rem;
  cursor:pointer;
}
.faq-question i {
  flex-shrink:0;
  font-size:.75rem;
  color:var(--primary);
  transition:transform .3s;
}
.faq-item.open .faq-question i { transform:rotate(45deg); }
.faq-answer {
  max-height:0;
  overflow:hidden;
  transition:max-height .35s cubic-bezier(.4,0,.2,1), padding .35s;
  padding:0 1.5rem;
}
.faq-item.open .faq-answer {
  max-height:300px;
  padding:0 1.5rem 1.25rem;
}
.faq-answer p {
  font-size:.88rem;
  color:var(--text-muted);
  line-height:1.75;
}
.faq-answer a { color:var(--primary); text-decoration:underline; }

/* ── 15. CTA FINAL ─────────────────────────────────────────── */
.cta-final {
  background:linear-gradient(135deg, var(--primary) 0%, #0d2f6b 100%);
  background-size:200% 200%;
  animation:gradient-shift 10s ease infinite;
  padding:5rem 0;
  position:relative;
  overflow:hidden;
}
.cta-final::before {
  content:'';
  position:absolute;
  width:400px; height:400px;
  border-radius:50%;
  background:rgba(255,255,255,.04);
  top:-150px; right:-100px;
  animation:morph-blob 12s ease-in-out infinite;
}
.cta-final-inner {
  text-align:center;
  position:relative;
  z-index:1;
  max-width:640px;
  margin:0 auto;
}
.cta-final h2 {
  font-size:clamp(1.5rem, 3.5vw, 2.25rem);
  font-weight:800;
  color:#fff;
  margin-bottom:1rem;
}
.cta-final p {
  font-size:1rem;
  color:rgba(255,255,255,.7);
  line-height:1.75;
  margin-bottom:2rem;
}
.cta-final-actions { display:flex; justify-content:center; gap:1rem; flex-wrap:wrap; }
.cta-final-badge {
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  font-size:.7rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:rgba(255,255,255,.7);
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.15);
  padding:.35rem 1rem;
  border-radius:var(--radius-full);
  margin-bottom:1rem;
}
.cta-final-badge i { font-size:.65rem; }
.cta-final-note {
  font-size:.82rem;
  color:rgba(255,255,255,.5);
  margin-top:1.5rem;
  margin-bottom:0;
}
.cta-final-note i { margin-right:.35rem; }

@media(max-width:480px){
  .cta-final-actions { flex-direction:column; }
  .cta-final-actions .btn { width:100%; }
}

/* ── 16. FOOTER (compact) ──────────────────────────────────── */
.footer {
  background:#fff;
  color:var(--text-muted);
  padding:2.5rem 0 0;
  border-top:1px solid var(--border);
}
.footer-grid {
  display:grid;
  grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;
  gap:1.75rem;
}
.footer-col { display:flex; flex-direction:column; gap:.35rem; }
.footer-logo { margin-bottom:.75rem; }
.footer-brand { font-size:1.5rem; font-weight:800; color:var(--text); margin-bottom:1rem; display:block; }
.footer-desc { font-size:.78rem; line-height:1.65; color:var(--text-muted); }
.footer-social { display:flex; gap:.6rem; margin-top:1rem; }
.footer-social a {
  width:36px; height:36px;
  display:flex; align-items:center; justify-content:center;
  background:var(--bg-soft);
  color:var(--text-muted);
  border-radius:var(--radius-sm);
  font-size:.8rem;
  transition:all var(--transition);
  border:1px solid var(--border-light);
}
.footer-social a:hover {
  background:var(--primary);
  color:#fff;
  transform:translateY(-3px);
  box-shadow:0 4px 12px rgba(14,74,168,.4);
}
.footer-col h4 {
  font-size:.75rem;
  font-weight:700;
  color:var(--text);
  text-transform:uppercase;
  letter-spacing:.06em;
  margin-bottom:.5rem;
}
.footer-col a, .footer-col span {
  font-size:.78rem;
  color:var(--text-muted);
  display:flex; align-items:center; gap:.4rem;
  padding:.2rem 0;
  transition:all var(--transition);
}
.footer-col a:hover { color:var(--primary); transform:translateX(3px); }
.footer-col a i { font-size:.75rem; width:16px; }
.footer-legal { font-size:.75rem; color:var(--text-light); }
.libro-reclamo {
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding:.55rem .9rem;
  background:#DC2626;
  color:#fff !important;
  border-radius:var(--radius-sm);
  font-size:.72rem;
  font-weight:700;
  margin-top:.75rem;
  transition:all var(--transition);
  text-transform:uppercase;
  letter-spacing:.02em;
  width:fit-content;
}
.libro-reclamo:hover { background:#B91C1C; transform:translateY(-2px); box-shadow:0 4px 12px rgba(220,38,38,.3); }
.libro-reclamo i { font-size:1rem; }

.libro-reclamo-img {
  height:auto;
  width:100%;
  max-width:180px;
  margin-top:.75rem;
  transition:all var(--transition);
  cursor:pointer;
  border:none;
  background:none;
  border-radius:0;
  padding:0;
}
.libro-reclamo-img:hover { transform:translateY(-2px); filter:brightness(1.1); }
.libro-reclamo-fallback {
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding:.55rem .9rem;
  background:#DC2626;
  color:#fff;
  border-radius:var(--radius-sm);
  font-size:.72rem;
  font-weight:700;
  margin-top:.75rem;
  text-transform:uppercase;
  letter-spacing:.02em;
  width:fit-content;
  transition:all var(--transition);
}
.libro-reclamo-fallback:hover { background:#B91C1C; transform:translateY(-2px); }

.footer-bottom {
  margin-top:1.5rem;
  padding:1rem 0;
  border-top:1px solid var(--border);
  text-align:center;
  font-size:.72rem;
  color:var(--text-light);
}
.footer-disclaimer {
  max-width:700px;
  margin:.5rem auto 0;
  font-size:.72rem;
  color:var(--text-light);
  line-height:1.75;
}
.footer-disclaimer a { color:var(--primary); text-decoration:underline; display:inline; }
.footer-disclaimer a:hover { color:var(--primary-dark); }

@media(max-width:900px){ .footer-grid { grid-template-columns:1fr 1fr 1fr; } }
@media(max-width:768px){ .footer-grid { grid-template-columns:1fr 1fr; gap:2rem; } }
@media(max-width:480px){ .footer-grid { grid-template-columns:1fr; } }

/* ── MOBILE BOTTOM BAR ─────────────────────────────────────── */
.mobile-bar {
  display:none;
  position:fixed;
  bottom:0; left:0; right:0;
  z-index:900;
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(12px);
  border-top:1px solid var(--border);
  padding:.5rem 0 max(.5rem, env(safe-area-inset-bottom));
  box-shadow:0 -4px 20px rgba(0,0,0,.06);
  justify-content:space-around;
  align-items:center;
}
.mobile-bar-item {
  display:flex; flex-direction:column; align-items:center;
  font-size:.6rem; color:var(--text-muted);
  text-decoration:none; gap:.15rem;
  transition:all var(--transition);
  padding:.3rem .5rem;
}
.mobile-bar-item i { font-size:1.1rem; }
.mobile-bar-item.active { color:var(--primary); }
.mobile-bar-item.wa { color:var(--success); }

@media(max-width:768px){
  .mobile-bar { display:flex; }
  body { padding-bottom:68px; }
}

/* ── WHATSAPP FLOAT ────────────────────────────────────────── */
.wa-float {
  position:fixed;
  bottom:1.5rem; right:1.5rem;
  z-index:800;
  display:flex; align-items:center; justify-content:center;
  background:var(--success);
  color:#fff;
  border-radius:50%;
  width:56px; height:56px;
  font-size:1.65rem;
  box-shadow:var(--shadow-green);
  transition:all var(--transition);
  text-decoration:none;
}
.wa-float:hover { transform:scale(1.08); box-shadow:0 8px 32px rgba(37,211,102,.4); }
.wa-float::before {
  content:'';
  position:absolute;
  inset:-4px;
  border-radius:50%;
  border:2px solid var(--success);
  animation:pulse-ring 2s ease infinite;
}

@media(max-width:768px){
  .wa-float { bottom:80px; right:1rem; width:50px; height:50px; font-size:1.4rem; }
}

/* ── BACK TO TOP ───────────────────────────────────────────── */
#back-to-top {
  position:fixed;
  bottom:1.5rem; left:1.5rem;
  z-index:800;
  width:42px; height:42px;
  background:var(--primary);
  color:#fff;
  border-radius:50%;
  font-size:.85rem;
  display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow-blue);
  transition:all var(--transition);
  border:none;
}
#back-to-top:hover { transform:translateY(-3px) scale(1.05); }

@media(max-width:768px){
  #back-to-top { bottom:80px; left:1rem; width:38px; height:38px; }
}

/* ── Utilities ─────────────────────────────────────────────── */
.text-center { text-align:center; }
.hidden { display:none !important; }
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }

/* ── Legacy compatibility ──────────────────────────────────── */
/* These classes ensure the verification page and other sub-pages still work */
.site-footer { background:#fff; color:var(--text-muted); padding:4rem 0 0; border-top:1px solid var(--border); }
.footer-grid { display:grid; gap:2.5rem; }
.footer-bottom-bar { padding:1.5rem 0; border-top:1px solid var(--border); text-align:center; font-size:.75rem; color:var(--text-light); }
.footer-extended { background:#fff; color:var(--text-muted); }
.footer-legal-item { font-size:.75rem; color:var(--text-light); }
.libro-badge { display:inline-flex; align-items:center; gap:.5rem; padding:.55rem .9rem; background:#DC2626; color:#fff; border-radius:var(--radius-sm); font-size:.68rem; font-weight:700; line-height:1.3; margin-top:1rem; transition:all var(--transition); text-transform:uppercase; letter-spacing:.02em; width:fit-content; }
.libro-badge:hover { background:#B91C1C; color:#fff; transform:translateY(-2px); }
.libro-badge i { font-size:1.15rem; }

/* Legacy stat classes */
.stats-row { display:flex; align-items:center; justify-content:center; flex-wrap:wrap; }
.stat-icon { width:48px; height:48px; margin:0 auto .65rem; display:flex; align-items:center; justify-content:center; background:rgba(14,74,168,.1); color:var(--primary); border-radius:var(--radius-sm); font-size:1.1rem; }
.stat-divider { width:1px; height:56px; background:rgba(255,255,255,.1); }
.stat-accent { color:var(--secondary); font-weight:700; }

/* Legacy hero slider (for sub-pages that may use it) */
.hero-slider { position:relative; width:100%; height:580px; overflow:hidden; background:var(--bg-dark); }
.hero-slide { position:absolute; inset:0; opacity:0; transition:opacity 1.2s ease; }
.hero-slide.active { opacity:1; z-index:1; }
.hero-slide img { width:100%; height:100%; object-fit:cover; }
.hero-slide.placeholder-slide { display:flex; flex-direction:column; align-items:center; justify-content:center; background:var(--bg-dark); color:rgba(255,255,255,.4); font-size:.9rem; gap:1rem; }
.slider-arrow { position:absolute; top:50%; transform:translateY(-50%); z-index:5; width:46px; height:46px; background:rgba(255,255,255,.12); color:#fff; border-radius:50%; font-size:.9rem; display:flex; align-items:center; justify-content:center; transition:all var(--transition); }
.slider-arrow:hover { background:rgba(255,255,255,.25); }
.slider-arrow.prev { left:1.25rem; }
.slider-arrow.next { right:1.25rem; }
.slider-dots { position:absolute; bottom:1.5rem; left:50%; transform:translateX(-50%); z-index:5; display:flex; gap:.6rem; }
.slider-dot { width:10px; height:10px; border-radius:50%; background:rgba(255,255,255,.35); border:none; transition:all .4s; }
.slider-dot.active { background:#fff; width:28px; border-radius:5px; }

/* Legacy section classes */
.section-badge { display:inline-flex; align-items:center; gap:.4rem; font-size:.7rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--primary); background:rgba(14,74,168,.08); border:1px solid rgba(14,74,168,.15); padding:.35rem 1rem; border-radius:var(--radius-full); margin-bottom:.85rem; }
.section-badge i { font-size:.65rem; }
.section-title { font-size:clamp(1.6rem, 4vw, 2.4rem); font-weight:800; color:var(--text); margin-bottom:.65rem; letter-spacing:-.01em; position:relative; display:inline-block; }
.section-header .section-title::after { content:''; position:absolute; bottom:-.15rem; left:50%; width:0; height:3px; background:linear-gradient(90deg, var(--primary), var(--secondary)); border-radius:2px; transition:width .8s cubic-bezier(.25,.46,.45,.94), left .8s cubic-bezier(.25,.46,.45,.94); }
.section-header.revealed .section-title::after, .revealed .section-title::after { width:60px; left:calc(50% - 30px); }
.section-line { width:50px; height:3px; background:var(--primary); border-radius:2px; margin:.75rem auto 0; }
.section-desc { font-size:.95rem; color:var(--text); line-height:1.75; max-width:520px; margin:0 auto; }
.section-header { text-align:center; max-width:640px; margin:0 auto 3rem; }
.section-deco { position:absolute; border-radius:50%; pointer-events:none; z-index:0; }

/* ── MOBILE RESPONSIVE OVERHAUL ────────────────────────────── */
@media(max-width:768px){
  /* General spacing */
  .section { padding:3.5rem 0; }
  .section-head h2 { font-size:1.4rem; }
  .section-head p { font-size:.88rem; }

  /* Hero mobile */
  .hero { padding:5rem 0 0; }
  .hero-inner { grid-template-columns:1fr; gap:2rem; text-align:center; }
  .hero-content { max-width:100%; }
  .hero-visual { order:-1; }
  .hero-image-wrapper { max-width:280px; margin:0 auto; }
  .hero h1 { font-size:1.8rem; }
  .hero-subtitle { font-size:.92rem; }
  .hero-bullets { align-items:center; }
  .hero-actions { justify-content:center; flex-direction:column; }
  .hero-actions .btn { width:100%; }
  .hero-trust { justify-content:center; flex-wrap:wrap; gap:.75rem; }
  .hero-cert-card { position:relative; bottom:auto; left:auto; margin:1rem auto 0; }

  /* Trust band mobile */
  .trust-band { padding:2rem 0; }
  .trust-band-grid { grid-template-columns:1fr; gap:.75rem; }
  .trust-band-item { padding:1rem; }

  /* Areas grid mobile */
  .areas-tall { grid-template-columns:1fr 1fr; gap:.75rem; max-width:100%; }
  .area-tall-card { height:240px; width:100%; }
  .area-tall-overlay h3 { font-size:1rem; }
  .area-tall-card::after { font-size:1.8rem; }

  /* Reasons U mobile */
  .reasons-u { 
    grid-template-columns:1fr; 
    grid-template-rows:auto; 
    min-height:auto; 
    gap:.75rem; 
  }
  .reasons-u-center { grid-column:1; grid-row:1; width:280px; margin:0 auto 1rem; }
  .reason-u-pos-1,.reason-u-pos-2,.reason-u-pos-3,
  .reason-u-pos-4,.reason-u-pos-5 { grid-column:1; grid-row:auto; }
  .reason-u-card { min-height:auto; padding:1.2rem; }
  .reason-u-card h3 { opacity:1 !important; max-height:none !important; transform:none !important; }
  .reason-u-card p { opacity:1; max-height:120px; transform:none; }

  /* Profiles U mobile */
  .profiles-u { 
    grid-template-columns:1fr; 
    grid-template-rows:auto; 
    min-height:auto; 
    gap:.75rem; 
  }
  .profiles-u-center { grid-column:1; grid-row:1; width:280px; margin:0 auto 1rem; }
  .profile-u-pos-1,.profile-u-pos-2,.profile-u-pos-3,
  .profile-u-pos-4,.profile-u-pos-5 { grid-column:1; grid-row:auto; }
  .profile-u-card { min-height:auto; padding:1.2rem; }
  .profile-u-card h3 { opacity:1 !important; max-height:none !important; transform:none !important; }
  .profile-u-card p { opacity:1; max-height:120px; transform:none; }

  /* Certificates mobile */
  .cert-layout { grid-template-columns:1fr; gap:2rem; }
  .cert-visual { order:-1; }
  .cert-mockup { max-width:300px; margin:0 auto; }

  /* Promo & Featured mobile */
  .promo-star { padding:2rem 1.5rem; }
  .promo-star h3 { font-size:1.5rem; }
  .featured-grid { grid-template-columns:1fr; }

  /* Stats mobile */
  .stats-section { padding:3rem 0; }
  .stats-grid { grid-template-columns:1fr 1fr; gap:1rem; }
  .stat-item { padding:1.5rem .75rem; }
  .stat-number { font-size:1.8rem; }

  /* Testimonials mobile */
  .testimonial-card { width:300px; padding:1.5rem; }

  /* FAQ mobile */
  .faq-question { padding:1rem 1.25rem; font-size:.85rem; }
  .faq-answer { padding:0 1.25rem; }
  .faq-item.open .faq-answer { padding:0 1.25rem 1rem; }

  /* CTA mobile */
  .cta-final { padding:3.5rem 0; }
  .cta-final h2 { font-size:1.4rem; }
  .cta-final-actions { flex-direction:column; }
  .cta-final-actions .btn { width:100%; }

  /* Footer mobile */
  .footer-grid { grid-template-columns:1fr; gap:1.75rem; }
  .footer-col { text-align:center; align-items:center; }
  .footer-social { justify-content:center; }
}

@media(max-width:480px){
  .section { padding:2.5rem 0; }
  .hero { padding:4rem 0 0; }
  .hero h1 { font-size:1.5rem; }
  .hero-image-wrapper { max-width:220px; }
  .areas-tall { gap:.5rem; }
  .area-tall-card { height:200px; }
  .area-tall-overlay h3 { font-size:.85rem; }
  .area-tall-card::after { font-size:1.4rem; }
  .stats-grid { gap:.75rem; }
  .stat-item { padding:1rem .5rem; }
  .stat-number { font-size:1.5rem; }
}

/* Legacy inscription for sub-pages */
.inscription-section { background:#fff; }
.inscription-layout { display:grid; grid-template-columns:1fr 400px; gap:3.5rem; align-items:center; }
.inscription-card { background:var(--bg-soft); border:1px solid var(--border); border-radius:var(--radius-xl); padding:2.75rem 2rem; text-align:center; width:100%; }
.inscription-wa-icon { font-size:2.75rem; color:var(--success); margin-bottom:.85rem; }
.inscription-note { display:block; margin-top:.85rem; font-size:.72rem; color:var(--text-muted); }
.step-num { flex-shrink:0; width:40px; height:40px; display:flex; align-items:center; justify-content:center; background:rgba(14,74,168,.1); color:var(--primary); font-size:.85rem; font-weight:800; border-radius:50%; }
.inscription-steps .step { display:flex; align-items:flex-start; gap:1.1rem; padding:.75rem; border-radius:var(--radius); }
.inscription-steps .step strong { display:block; font-size:.87rem; color:var(--text); margin-bottom:.15rem; }
.inscription-steps .step span { font-size:.78rem; color:var(--text-muted); line-height:1.5; }
@media(max-width:900px){ .inscription-layout { grid-template-columns:1fr; } }

/* Legacy CTA dark */
.cta-dark { background:var(--bg-dark); padding:4rem 0; position:relative; overflow:hidden; }
.cta-inner { display:flex; align-items:center; justify-content:space-between; gap:2.5rem; flex-wrap:wrap; position:relative; z-index:1; }
.cta-text h2 { font-size:clamp(1.3rem, 3vw, 1.85rem); font-weight:800; color:#fff; margin-bottom:.5rem; }
.cta-text p { color:rgba(255,255,255,.6); font-size:.92rem; max-width:540px; line-height:1.7; }
@media(max-width:768px){ .cta-inner { flex-direction:column; text-align:center; } }

/* Legacy why section */
.why-section { background:#fff; }
.why-layout { display:grid; grid-template-columns:1fr 280px 1fr; gap:1.75rem; align-items:center; max-width:1080px; margin:0 auto; }
.why-col { display:flex; flex-direction:column; gap:1.1rem; }
.why-card { display:flex; align-items:flex-start; gap:1rem; padding:1.25rem; background:#fff; border:1px solid var(--border); border-radius:var(--radius); transition:all var(--transition); }
.why-card:hover { transform:perspective(600px) translateY(-5px) rotateX(1deg); box-shadow:var(--shadow-md); }
.why-icon { flex-shrink:0; width:44px; height:44px; display:flex; align-items:center; justify-content:center; border-radius:var(--radius-sm); font-size:1rem; }
.why-text h4 { font-size:.85rem; font-weight:700; color:var(--text); margin-bottom:.2rem; }
.why-text p { font-size:.77rem; color:var(--text-muted); line-height:1.6; }
.why-center { display:flex; align-items:center; justify-content:center; position:relative; }
.why-center img { width:260px; height:370px; object-fit:cover; border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); }
.why-img-placeholder { width:260px; height:370px; border-radius:var(--radius-lg); background:var(--bg-soft); border:2px dashed var(--border); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.75rem; color:var(--text-light); }
.why-img-placeholder i { font-size:2.8rem; }
@media(max-width:900px){ .why-layout { grid-template-columns:1fr; max-width:600px; } .why-center { order:-1; margin-bottom:1.5rem; } .why-col { display:grid; grid-template-columns:1fr 1fr; gap:1rem; } }
@media(max-width:540px){ .why-col { grid-template-columns:1fr; } }

/* Trust section legacy */
.trust-section { background:var(--bg-soft); padding:3rem 0; border-top:1px solid var(--border-light); border-bottom:1px solid var(--border-light); }
.trust-label { text-align:center; font-size:.72rem; font-weight:600; text-transform:uppercase; letter-spacing:.1em; color:var(--text-light); margin-bottom:1.5rem; }
.trust-logos { display:flex; align-items:center; justify-content:center; gap:3rem; flex-wrap:wrap; }
.trust-item { display:flex; flex-direction:column; align-items:center; gap:.5rem; opacity:.5; transition:all var(--transition); padding:.75rem; }
.trust-item:hover { opacity:1; transform:translateY(-2px); }
.trust-item i { font-size:1.5rem; color:var(--text-muted); }
.trust-item span { font-size:.7rem; font-weight:600; color:var(--text-muted); text-transform:uppercase; }

/* Legacy testimonials */
.testimonials-section { background:#fff; overflow:hidden; }

/* Legacy featured */
.featured-section { background:var(--bg-soft); }
.featured-cta { text-align:center; margin-top:2.5rem; }

/* Legacy areas */
.areas-section { background:var(--bg-soft); }

/* Keep legacy button aliases working */
.btn-gold { background:var(--primary); color:#fff; box-shadow:var(--shadow-blue); }
.btn-gold:hover { background:var(--primary-dark); }
.btn-green { background:var(--success); color:#fff; box-shadow:var(--shadow-green); }
.btn-green:hover { background:var(--success-dark); }

/* Nav dropdown legacy */
.nav-dropdown-menu { position:absolute; top:calc(100% + 12px); left:-8px; min-width:280px; background:#fff; border:1px solid var(--border); border-radius:var(--radius); padding:.5rem; box-shadow:var(--shadow-lg); opacity:0; visibility:hidden; transform:translateY(10px); transition:all .25s; z-index:100; }
.nav-dropdown:hover .nav-dropdown-menu { opacity:1; visibility:visible; transform:translateY(0); }
.nav-dropdown-item { display:flex; align-items:center; gap:.75rem; padding:.6rem .85rem; font-size:.82rem; color:var(--text-muted); border-radius:var(--radius-sm); transition:all .15s; text-decoration:none; }
.nav-dropdown-item:hover { background:rgba(14,74,168,.06); transform:translateX(3px); }
.nav-dropdown-item i { width:32px; height:32px; display:flex; align-items:center; justify-content:center; border-radius:8px; font-size:.8rem; }

/* Legacy bottom bar */
.mobile-bottom-bar { display:none; position:fixed; bottom:0; left:0; right:0; z-index:900; background:rgba(255,255,255,.97); backdrop-filter:blur(12px); border-top:1px solid var(--border); padding:.5rem 0 max(.5rem, env(safe-area-inset-bottom)); box-shadow:0 -4px 20px rgba(0,0,0,.06); justify-content:space-around; align-items:center; }
.bottom-bar-item, .mob-item { display:flex; flex-direction:column; align-items:center; font-size:.6rem; color:var(--text-muted); text-decoration:none; gap:.15rem; transition:all var(--transition); padding:.3rem .5rem; }
.bottom-bar-item i, .mob-item i { font-size:1.1rem; }
.bottom-bar-item.active, .mob-item.active { color:var(--primary); }
.bottom-bar-item.wa-item { color:var(--success); }
@media(max-width:768px){ .mobile-bottom-bar { display:flex; } }

/* Benefit card flip legacy */
.benefit-card { transition:all var(--transition); }
.benefit-card.flipped { transform:rotateY(180deg); }

/* Hero shapes legacy */
.hero-shapes { position:absolute; inset:0; z-index:2; pointer-events:none; overflow:hidden; }
.hero-shape { position:absolute; border-radius:50%; opacity:.08; background:#fff; }

/* Decorative */
.deco-1 { width:200px; height:200px; background:rgba(14,74,168,.05); top:-60px; right:-60px; opacity:.5; }
.deco-2 { width:140px; height:140px; background:rgba(14,74,168,.05); bottom:-40px; left:-40px; opacity:.4; }

/* Verify hero (for verification page) */
.verify-hero { background:linear-gradient(180deg, #f8fbff 0%, #eef5ff 100%); padding:4rem 0 5.5rem; position:relative; }

/* ── REDUCED MOTION ────────────────────────────────────────── */
@media(prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration:0.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.01ms !important;
  }
  [data-reveal] { opacity:1; transform:none; filter:none; }
  [data-stagger] > * { opacity:1; transform:none; filter:none; }
}
