/* ============================================================================
   GRUPO EDU — ONE PAGE
   Basado en el Design System Grupo EDU · Plus Jakarta Sans · mobile-first
   ============================================================================ */

:root {
  /* Marca */
  --navy:        #04397A;
  --navy-hover:  #032E63;
  --navy-deep:   #112345;
  --navy-tint:   #E6EDF5;
  --ink:         #1D3C73;
  --ink-soft:    #566C96;
  --ink-900:     #0D1B34;
  --blue-bright: #5AA9F2;   /* azul claro para texto/acento sobre oscuro */

  /* Acentos por unidad */
  --salud: #00A52B;     --salud-on: #112345;   --salud-bright: #3FD466;
  --gestion: #40A3ED;   --gestion-on: #112345; --gestion-bright: #8CC8F7;
  --logistica: #FF6915; --logistica-on: #112345; --logistica-bright: #FF9A5E;
  --farma: #824DCE;     --farma-on: #FFFFFF;   --farma-bright: #B08AE6;
  --trabajo: #FCAD3A;   --trabajo-on: #112345; --trabajo-bright: #FFC062;

  /* Superficies */
  --surface: #FFFFFF;
  --surface-alt: #F9F9F9;
  --surface-tinted: #F4F5F8;
  --border: #E5E5E5;

  /* Acento activo (tematización por unidad) */
  --accent: var(--navy);
  --accent-on: #FFFFFF;
  --accent-bright: var(--blue-bright);

  /* Tipografía */
  --font: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  --fs-xs:   clamp(0.75rem, 0.70rem + 0.20vw, 0.8125rem);
  --fs-sm:   clamp(0.875rem, 0.82rem + 0.25vw, 0.9375rem);
  --fs-base: clamp(0.9375rem, 0.90rem + 0.25vw, 1.0625rem);
  --fs-md:   clamp(1.05rem, 0.95rem + 0.5vw, 1.25rem);
  --fs-lg:   clamp(1.25rem, 1.05rem + 0.9vw, 1.6rem);
  --fs-xl:   clamp(1.6rem, 1.25rem + 1.6vw, 2.4rem);
  --fs-2xl:  clamp(2.1rem, 1.5rem + 3vw, 3.6rem);
  --fs-3xl:  clamp(2.6rem, 1.7rem + 4.6vw, 5.5rem);
  --fs-hero: clamp(2.9rem, 1.6rem + 7vw, 7.5rem);

  /* Espaciado */
  --space-sm: clamp(0.75rem, 0.6rem + 0.75vw, 1.25rem);
  --space-md: clamp(1.25rem, 1rem + 1.5vw, 2rem);
  --space-lg: clamp(2rem, 1.5rem + 2.5vw, 3.5rem);
  --space-xl: clamp(3.5rem, 2.4rem + 5vw, 7rem);
  --space-2xl: clamp(5rem, 3.2rem + 8vw, 10rem);

  /* Layout */
  --container: 1280px;
  --pad: clamp(1.25rem, 4vw, 3.5rem);
  --radius: 22px;
  --radius-lg: 32px;
  --radius-pill: 999px;

  /* Sombras */
  --shadow-md: 0 6px 18px -6px rgba(29,59,115,0.12), 0 2px 6px rgba(29,59,115,0.05);
  --shadow-lg: 0 30px 60px -20px rgba(17,35,69,0.28), 0 10px 20px -10px rgba(17,35,69,0.12);

  /* Movimiento */
  --ease: cubic-bezier(0.16, 1, 0.3, 1);
  --dur: 0.4s;
}

/* ---- Reset ---- */
*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font);
  font-size: var(--fs-base);
  line-height: 1.65;
  color: var(--ink);
  background: var(--surface);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }

::selection { background: var(--navy); color: #fff; }

.skip-link { position: absolute; left: -999px; top: 0; background: var(--navy); color:#fff; padding: .7rem 1rem; border-radius: 0 0 8px 0; z-index: 2000; }
.skip-link:focus { left: 0; }

/* ---- Layout helpers ---- */
.wrap { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--pad); }
.section { position: relative; padding-block: var(--space-2xl); }
.section--dark { background: var(--navy-deep); color: #fff; }
.section--tinted { background: var(--surface-tinted); }

.eyebrow {
  display: inline-block;
  font-size: var(--fs-xs); font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.2em;
  color: var(--accent);
}
.eyebrow--light { color: var(--blue-bright); }

.display {
  font-weight: 800; line-height: 1.04; letter-spacing: -0.03em;
  font-size: var(--fs-2xl); color: var(--ink);
}
.section--dark .display { color: #fff; }
.display em, .em--on-dark { font-style: italic; color: var(--accent); }
.section--dark .display em { color: var(--blue-bright); }
.em--on-dark { color: var(--blue-bright); }

.lead { font-size: var(--fs-md); color: var(--ink); }
.section--dark .lead, .section--dark p { color: rgba(255,255,255,0.82); }

.section__head { max-width: 60ch; margin-bottom: var(--space-lg); }
.section__head.center { margin-inline: auto; text-align: center; }
.section__intro { margin-top: var(--space-sm); color: var(--ink-soft); font-size: var(--fs-md); }
.section--dark .section__intro { color: rgba(255,255,255,0.7); }
.section__head.center .section__intro { margin-inline: auto; max-width: 56ch; }

/* ---- BOTONES (Design System) ---- */
.btn {
  --btn-bg: var(--accent); --btn-fg: var(--accent-on); --btn-bd: transparent;
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  padding: .95rem 1.6rem; border-radius: var(--radius-pill);
  font-weight: 700; font-size: var(--fs-sm); line-height: 1.1; letter-spacing: -0.005em;
  background: var(--btn-bg); color: var(--btn-fg); border: 2px solid var(--btn-bd);
  transition: transform var(--dur) var(--ease), background var(--dur), border-color var(--dur), color var(--dur), box-shadow var(--dur);
  text-align: center; white-space: nowrap;
}
.btn:hover { transform: translateY(-2px); box-shadow: 0 14px 30px -12px color-mix(in srgb, var(--accent) 50%, transparent); background: var(--navy-hover); }
.btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; }
.btn--lg { padding: 1.1rem 2.1rem; font-size: var(--fs-base); }
.btn--sm { padding: .6rem 1.1rem; font-size: var(--fs-xs); }
.btn--outline { --btn-bg: transparent; --btn-fg: var(--navy); --btn-bd: var(--navy); }
.btn--outline:hover { --btn-bg: var(--navy); --btn-fg: #fff; }
.btn--on-dark { --btn-fg: #fff; }
.btn--on-dark.btn--outline { --btn-bg: transparent; --btn-fg: #fff; --btn-bd: rgba(255,255,255,0.5); }
.btn--on-dark.btn--outline:hover { --btn-bg: rgba(255,255,255,0.14); --btn-bd: #fff; }
.btn__arrow { transition: transform var(--dur) var(--ease); }
.btn:hover .btn__arrow { transform: translateX(5px); }

/* ============================================================================
   NAVBAR
   ============================================================================ */
.navbar {
  position: fixed; inset: 0 0 auto 0; z-index: 1000;
  padding-block: 1rem; transition: background var(--dur), padding var(--dur), box-shadow var(--dur);
}
.navbar__inner { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--pad);
  display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.navbar__logo-img { height: 30px; width: auto; transition: opacity var(--dur); }
.navbar__logo-img--dark { display: none; }
.navbar__menu { display: none; align-items: center; gap: clamp(1rem, 2vw, 2rem); }
.navbar__menu a { font-size: var(--fs-sm); font-weight: 600; color: #fff; transition: opacity var(--dur); }
.navbar__menu a:hover { opacity: .65; }
.navbar__cta { color: #fff !important; }

/* scrolled */
.navbar--scrolled { background: rgba(255,255,255,0.92); backdrop-filter: saturate(180%) blur(16px); -webkit-backdrop-filter: saturate(180%) blur(16px); padding-block: .55rem; box-shadow: 0 1px 0 rgba(29,59,115,0.08); }
.navbar--scrolled .navbar__logo-img--light { display: none; }
.navbar--scrolled .navbar__logo-img--dark { display: block; }
.navbar--scrolled .navbar__menu a { color: var(--ink); }
.navbar--scrolled .navbar__toggle span { background: var(--ink); }

/* hamburger */
.navbar__toggle { display: inline-flex; flex-direction: column; gap: 5px; padding: 8px; z-index: 1100; }
.navbar__toggle span { width: 26px; height: 2px; background: #fff; border-radius: 2px; transition: transform var(--dur) var(--ease), opacity var(--dur); }
body.menu-open .navbar__toggle span { background: #fff; }
body.menu-open .navbar__toggle span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
body.menu-open .navbar__toggle span:nth-child(2) { opacity: 0; }
body.menu-open .navbar__toggle span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* mobile overlay */
.mobile-menu {
  position: fixed; inset: 0; z-index: 1050; background: var(--navy-deep);
  display: flex; flex-direction: column; justify-content: center; gap: var(--space-lg);
  padding: var(--pad);
  clip-path: circle(0% at calc(100% - 40px) 40px);
  transition: clip-path 0.6s var(--ease); pointer-events: none;
}
body.menu-open .mobile-menu { clip-path: circle(150% at calc(100% - 40px) 40px); pointer-events: auto; }
.mobile-menu__nav { display: flex; flex-direction: column; gap: clamp(.5rem,2vw,1rem); }
.mobile-menu__nav a { font-size: clamp(2rem, 9vw, 3rem); font-weight: 800; letter-spacing: -0.03em; color: #fff; display: flex; align-items: baseline; gap: 1rem; }
.mobile-menu__nav a span { font-size: var(--fs-sm); font-weight: 700; color: var(--blue-bright); }
.mobile-menu__nav a:hover { color: var(--blue-bright); }
.mobile-menu__foot { display: flex; flex-direction: column; gap: .35rem; color: rgba(255,255,255,0.7); font-weight: 600; }

/* ============================================================================
   HERO
   ============================================================================ */
.hero {
  position: relative; min-height: 100svh; display: flex; flex-direction: column; justify-content: center;
  background: var(--navy-deep); color: #fff; overflow: hidden;
  padding: calc(var(--space-2xl) + 3rem) var(--pad) var(--space-xl);
}
.hero__bg { position: absolute; inset: 0; z-index: 0; }
.hero__glow { position: absolute; inset: -25% 0;
  background: radial-gradient(60% 60% at 75% 30%, rgba(64,163,237,0.30), transparent 60%),
              radial-gradient(50% 50% at 10% 85%, rgba(4,57,122,0.55), transparent 60%); }
.hero__star {
  position: absolute; top: 50%; right: -8%; width: min(70vw, 620px); transform: translateY(-50%);
  color: rgba(255,255,255,0.03); opacity: .3;
}
.hero__inner { position: relative; z-index: 1; width: 100%; max-width: var(--container); margin-inline: auto; }
.hero__title {
  font-weight: 800; letter-spacing: -0.04em; line-height: 0.98; font-size: var(--fs-hero);
  margin: 1rem 0 1.25rem;
}
.hero__title .line { display: block; overflow: hidden; }
.hero__title em { font-style: italic; color: var(--blue-bright); }
.hero__sub { max-width: 46ch; font-size: var(--fs-md); color: rgba(255,255,255,0.82); }
.hero__cta { display: flex; flex-wrap: wrap; gap: .75rem; margin-top: var(--space-md); }
.hero__scroll { position: absolute; bottom: 1.5rem; left: var(--pad); z-index: 1;
  display: inline-flex; align-items: center; gap: .6rem; font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.2em; color: rgba(255,255,255,0.6); }
.hero__scroll span { width: 26px; height: 1px; background: rgba(255,255,255,0.5); position: relative; overflow: hidden; }
.hero__scroll span::after { content:""; position:absolute; inset:0; background:#fff; animation: scrollLine 2s var(--ease) infinite; }
@keyframes scrollLine { 0%{transform:translateX(-100%)} 60%,100%{transform:translateX(100%)} }

/* ============================================================================
   STATS
   ============================================================================ */
.stats { background: var(--navy); color: #fff; }
.stats__grid { width: 100%; max-width: var(--container); margin-inline: auto; padding: var(--space-lg) var(--pad);
  display: grid; grid-template-columns: 1fr; gap: var(--space-md); }
.stat { display: flex; flex-direction: column; gap: .35rem; padding-block: .5rem; border-top: 1px solid rgba(255,255,255,0.15); padding-top: 1rem; }
.stat__num { font-size: var(--fs-2xl); font-weight: 800; letter-spacing: -0.03em; line-height: 1; color: #fff; }
.stat__label { font-size: var(--fs-sm); color: rgba(255,255,255,0.7); max-width: 28ch; }

/* ============================================================================
   NOSOTROS (split)
   ============================================================================ */
.split { display: grid; grid-template-columns: 1fr; gap: var(--space-lg); align-items: center; }
.split__media { position: relative; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-lg); height: clamp(300px, 56vw, 520px); }
.split__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }
.split__badge { position: absolute; z-index: 2; left: 1rem; bottom: 1rem; display: inline-flex; align-items: baseline; gap: .45rem;
  background: var(--navy); color: #fff; padding: .65rem 1.1rem; border-radius: var(--radius-pill); font-size: var(--fs-sm); font-weight: 600; box-shadow: var(--shadow-md); }
.split__badge strong { font-size: var(--fs-lg); font-weight: 800; color: var(--blue-bright); }
.split__head .display { margin-top: .75rem; }
.split__body { display: flex; flex-direction: column; gap: 1rem; margin-top: var(--space-md); }

/* ============================================================================
   ECOSISTEMA
   ============================================================================ */
#ecosistema { overflow: hidden; }
.ecosystem__star { position: absolute; top: -6%; left: -10%; width: min(50vw, 380px); color: rgba(255,255,255,0.04); z-index: 0; pointer-events: none; }
#ecosistema .wrap { position: relative; z-index: 1; }
.units { display: grid; grid-template-columns: 1fr; gap: var(--space-sm); margin-top: var(--space-lg); }
.unit {
  --accent: var(--navy);
  position: relative; background: #fff; border-radius: var(--radius); padding: var(--space-md);
  display: flex; flex-direction: column; gap: 1rem; overflow: hidden;
  border-top: 4px solid var(--accent);
  box-shadow: 0 18px 40px -26px rgba(0,0,0,0.55);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur);
}
.unit[data-brand="salud"]     { --accent: var(--salud); }
.unit[data-brand="gestion"]   { --accent: var(--gestion); }
.unit[data-brand="logistica"] { --accent: var(--logistica); }
.unit[data-brand="farma"]     { --accent: var(--farma); }
.unit[data-brand="trabajo"]   { --accent: var(--trabajo); }
/* halo sutil del color de marca detrás del logo — reemplaza el recuadro blanco */
.unit::after { content:""; position: absolute; inset: 0 0 auto 0; height: 130px; pointer-events: none;
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 10%, transparent), transparent); }
.unit:hover { transform: translateY(-8px); box-shadow: 0 38px 64px -30px color-mix(in srgb, var(--accent) 50%, rgba(0,0,0,0.5)); }
.unit > * { position: relative; z-index: 1; }
.unit__top { display: flex; align-items: center; min-height: 50px; }
.unit__logo { height: 34px; width: auto; max-width: 88%; }
.section--dark .unit__desc { color: var(--ink); font-size: var(--fs-sm); }
.unit__tag { margin-top: auto; align-self: flex-start; font-size: var(--fs-xs); font-weight: 700; text-transform: uppercase; letter-spacing: .1em;
  color: var(--navy); background: color-mix(in srgb, var(--accent) 14%, #fff); padding: .4rem .85rem; border-radius: var(--radius-pill); }
.unit--cta { justify-content: center; align-items: flex-start; gap: 1.2rem; background: linear-gradient(150deg, var(--navy), var(--navy-deep)); border-top-color: var(--blue-bright); }
.unit--cta::after { display: none; }
.unit--cta h3 { font-size: var(--fs-lg); font-weight: 800; letter-spacing: -0.02em; color: #fff; line-height: 1.1; }

/* ============================================================================
   DIFERENCIAL
   ============================================================================ */
.pillars { display: grid; grid-template-columns: 1fr; gap: var(--space-sm); margin-top: var(--space-lg); }
.pillar { position: relative; padding: var(--space-md); border: 1px solid var(--border); border-radius: var(--radius); background: var(--surface);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur), border-color var(--dur); }
.pillar:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); border-color: transparent; }
.pillar__num { font-size: var(--fs-xl); font-weight: 800; color: var(--navy-tint); letter-spacing: -0.04em;
  -webkit-text-stroke: 1px var(--blue-bright); color: transparent; }
.pillar h3 { font-size: var(--fs-lg); font-weight: 800; letter-spacing: -0.02em; line-height: 1.02; color: var(--ink); margin: .35rem 0 .55rem; }
.pillar p { color: var(--ink-soft); font-size: var(--fs-sm); }

/* ============================================================================
   PROPÓSITO
   ============================================================================ */
.purpose { display: grid; grid-template-columns: 1fr; gap: var(--space-sm); margin-top: var(--space-lg); }
.purpose__card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: var(--space-md); box-shadow: var(--shadow-md); }
.purpose__card h3 { font-size: var(--fs-xl); font-weight: 800; letter-spacing: -0.025em; color: var(--navy); margin-bottom: .6rem; }
.purpose__card p { color: var(--ink); }
.values { display: grid; gap: .6rem; }
.values li { position: relative; padding-left: 1.6rem; font-weight: 600; color: var(--ink); }
.values li::before { content:""; position: absolute; left: 0; top: .55em; width: 9px; height: 9px; border-radius: 50%; background: var(--navy); }
.purpose__card--values li:nth-child(1)::before { background: var(--salud); }
.purpose__card--values li:nth-child(2)::before { background: var(--gestion); }
.purpose__card--values li:nth-child(3)::before { background: var(--logistica); }
.purpose__card--values li:nth-child(4)::before { background: var(--farma); }
.purpose__card--values li:nth-child(5)::before { background: var(--trabajo); }
.purpose__card--values li:nth-child(6)::before { background: var(--navy); }

/* ============================================================================
   CONTACTO
   ============================================================================ */
.contact { display: grid; grid-template-columns: 1fr; gap: var(--space-lg); }
.contact__list { margin-top: var(--space-md); display: grid; gap: .9rem; }
.contact__list li { display: flex; flex-direction: column; gap: .1rem; border-top: 1px solid rgba(255,255,255,0.14); padding-top: .7rem; }
.contact__list span { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: .16em; color: rgba(255,255,255,0.5); }
.contact__list a { font-size: var(--fs-md); font-weight: 700; color: #fff; transition: color var(--dur); }
.contact__list a:hover { color: var(--blue-bright); }

.contact__form { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.12); border-radius: var(--radius-lg); padding: var(--space-md); display: grid; gap: 1rem; }
.field { display: grid; gap: .4rem; }
.field label { font-size: var(--fs-sm); font-weight: 600; color: rgba(255,255,255,0.85); }
.field .opt { color: rgba(255,255,255,0.45); font-weight: 400; }
.input {
  width: 100%; padding: .85rem 1.05rem; font-family: var(--font); font-size: var(--fs-base);
  color: #fff; background: rgba(255,255,255,0.06); border: 2px solid rgba(255,255,255,0.16); border-radius: 14px;
  transition: border-color var(--dur), box-shadow var(--dur), background var(--dur);
}
.input::placeholder { color: rgba(255,255,255,0.4); }
.input:focus { outline: none; border-color: var(--blue-bright); background: rgba(255,255,255,0.10); box-shadow: 0 0 0 4px rgba(90,169,242,0.18); }
textarea.input { resize: vertical; min-height: 110px; }
.contact__form .btn { width: 100%; --accent: var(--blue-bright); --accent-on: var(--navy-deep); }
.contact__form .btn:hover { background: #7BBAF5; }
.form-status { font-size: var(--fs-sm); font-weight: 600; min-height: 1.2em; }
.form-status.ok { color: var(--salud-bright); }
.form-status.err { color: #FF8A7A; }

/* ============================================================================
   FOOTER
   ============================================================================ */
.footer { background: var(--ink-900); color: rgba(255,255,255,0.7); padding-top: var(--space-xl); }
.footer__inner { display: grid; grid-template-columns: 1fr; gap: var(--space-lg); padding-bottom: var(--space-lg); }
.footer__logo { height: 34px; margin-bottom: 1rem; }
.footer__brand p { max-width: 42ch; font-size: var(--fs-sm); }
.footer__nav { display: flex; flex-wrap: wrap; gap: .6rem 1.4rem; }
.footer__nav a, .footer__contact a { font-weight: 600; color: rgba(255,255,255,0.8); transition: color var(--dur); }
.footer__nav a:hover, .footer__contact a:hover { color: var(--blue-bright); }
.footer__contact { display: flex; flex-direction: column; gap: .4rem; }
.footer__bottom { display: flex; flex-direction: column; gap: .5rem; padding-block: var(--space-md); border-top: 1px solid rgba(255,255,255,0.10); font-size: var(--fs-xs); color: rgba(255,255,255,0.45); }
.footer__units { letter-spacing: .04em; }

/* ============================================================================
   WHATSAPP
   ============================================================================ */
.wa { position: fixed; right: 1.1rem; bottom: 1.1rem; z-index: 900; width: 56px; height: 56px; border-radius: 50%;
  display: grid; place-items: center; background: #25D366; color: #fff; box-shadow: 0 12px 26px -8px rgba(37,211,102,0.6);
  transition: transform var(--dur) var(--ease); }
.wa::after { content:""; position: absolute; inset: 0; border-radius: 50%; box-shadow: 0 0 0 0 rgba(37,211,102,0.5); animation: waPulse 2.4s infinite; }
.wa:hover { transform: scale(1.08); }
@keyframes waPulse { 0%{box-shadow:0 0 0 0 rgba(37,211,102,0.5)} 70%{box-shadow:0 0 0 16px rgba(37,211,102,0)} 100%{box-shadow:0 0 0 0 rgba(37,211,102,0)} }

/* ============================================================================
   BREAKPOINTS
   ============================================================================ */
@media (min-width: 768px) {
  .stats__grid { grid-template-columns: repeat(3, 1fr); gap: var(--space-lg); }
  .stat { border-top: none; border-left: 1px solid rgba(255,255,255,0.18); padding-left: 1.5rem; padding-top: .5rem; }
  .units { grid-template-columns: repeat(2, 1fr); gap: var(--space-md); }
  .pillars { grid-template-columns: repeat(2, 1fr); gap: var(--space-md); }
  .purpose { grid-template-columns: repeat(3, 1fr); gap: var(--space-md); }
  .contact { grid-template-columns: 1fr 1fr; gap: var(--space-xl); align-items: start; }
  .footer__inner { grid-template-columns: 2fr 1fr 1fr; }
  .footer__bottom { flex-direction: row; justify-content: space-between; align-items: center; }
}

@media (min-width: 1024px) {
  .navbar__menu { display: flex; }
  .navbar__toggle { display: none; }
  .split { grid-template-columns: 0.95fr 1.05fr; gap: var(--space-xl); align-items: center; }
  .units { grid-template-columns: repeat(3, 1fr); }
  .pillars { grid-template-columns: repeat(4, 1fr); }
  .hero__sub { font-size: var(--fs-lg); }
}

/* ---- Reduced motion ---- */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
  .hero__star { animation: none !important; }
}
