:root{
  --accent: #2b6cb0;
  --accent-dark: #1f4e79;
  --accent-darker: #163a5a;
  --accent-light: #6ba3d6;
  --accent-mint: #cfe0f0;
  --accent-tint: #eef4fb;
  --accent-gradient: linear-gradient(135deg, #2b6cb0 0%, #1f4e79 100%);
  --accent-rgb: 43,108,176;
  --accent-d-rgb: 24,58,90;
  --accent-l-rgb: 107,163,214;
  --footer-bg: #15212e;
}

/* ================================================================
   TOKENS DE MARCA — Opirex
   PERSONALIZAR: cambia --accent (y sus variantes) por cliente.
   Todo el color de marca sale de estas variables.
   ================================================================ */
:root{

  --text:          #1f2937;   /* texto principal */
  --text-soft:     #6b7280;   /* texto secundario */
  --bg:            #ffffff;   /* fondo base */
  --bg-alt:        #f9fafb;   /* secciones alternas */
  --border:        #e5e7eb;   /* bordes */

  --font-head: 'Manrope', system-ui, sans-serif;
  --font-body: 'Inter', system-ui, sans-serif;

  --radius:    16px;
  --radius-sm: 10px;
  --radius-lg: 24px;
  --shadow:    0 1px 3px rgba(16,24,40,.06), 0 8px 24px rgba(16,24,40,.06);
  --shadow-lg: 0 12px 40px rgba(16,24,40,.12);

  --maxw: 1140px;
  --header-h: 72px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; scroll-padding-top: calc(var(--header-h) + 12px); }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--text);
  background:var(--bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{ font-family:var(--font-head); color:var(--text); line-height:1.15; margin:0; letter-spacing:-.02em; }
p{ margin:0; }
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
ul{ margin:0; padding:0; list-style:none; }

/* ---------- Utilidades de layout ---------- */
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:20px; }
.section{ padding:72px 0; }
.section--alt{ background:var(--bg-alt); }
.eyebrow{
  display:inline-block; font-family:var(--font-head); font-weight:700;
  font-size:.8rem; letter-spacing:.08em; text-transform:uppercase;
  color:var(--accent-dark); margin-bottom:14px;
}
.section-head{ max-width:680px; margin-bottom:44px; }
.section-head--center{ margin-inline:auto; text-align:center; }
.section-title{ font-size:clamp(1.8rem, 4vw, 2.5rem); font-weight:800; }
.section-sub{ color:var(--text-soft); font-size:1.075rem; margin-top:14px; text-wrap:pretty; }

/* ---------- Botones ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:var(--font-head); font-weight:700; font-size:1rem;
  padding:14px 26px; border-radius:999px; border:2px solid transparent;
  cursor:pointer; transition:transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
  min-height:48px; white-space:nowrap;
}
.btn:focus-visible{ outline:3px solid var(--accent-light); outline-offset:2px; }
.btn--primary{ background:var(--accent-gradient); color:#fff; box-shadow:0 6px 18px rgba(var(--accent-rgb),.32); }
.btn--primary:hover{ transform:translateY(-2px); box-shadow:0 10px 26px rgba(var(--accent-rgb),.4); }
.btn--ghost{ background:#fff; color:var(--accent-dark); border-color:var(--border); }
.btn--ghost:hover{ border-color:var(--accent); color:var(--accent-dark); transform:translateY(-2px); }
.btn--on-dark{ background:rgba(255,255,255,.14); color:#fff; border-color:rgba(255,255,255,.45); backdrop-filter:blur(4px); }
.btn--on-dark:hover{ background:rgba(255,255,255,.24); transform:translateY(-2px); }
.btn--sm{ padding:10px 18px; font-size:.92rem; min-height:42px; }

/* ================================================================
   HEADER
   ================================================================ */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:100;
  height:var(--header-h);
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;
  transition:border-color .2s ease, box-shadow .2s ease;
}
.site-header.scrolled{ border-bottom-color:var(--border); box-shadow:0 2px 12px rgba(16,24,40,.05); }
.nav{ display:flex; align-items:center; gap:32px; height:100%; }
/* PERSONALIZAR: logo (texto o <img>) */
.brand{ display:flex; align-items:center; gap:10px; font-family:var(--font-head); font-weight:800; font-size:1.25rem; flex:none; margin-right:auto; }
.brand-mark{
  width:38px; height:38px; border-radius:11px; background:var(--accent-gradient);
  display:grid; place-items:center; color:#fff; flex:none; box-shadow:0 4px 12px rgba(var(--accent-rgb),.35);
}
.brand-mark svg{ width:20px; height:20px; }
.brand-logo{ height:46px; width:auto; flex:none; }
.brand b{ color:var(--accent-dark); }

.nav-links{ display:flex; align-items:center; gap:30px; }
.nav-links a{ font-weight:600; font-size:.96rem; color:var(--text); position:relative; padding:6px 0; }
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:0; height:2px; width:0; background:var(--accent);
  transition:width .22s ease;
}
.nav-links a:hover{ color:var(--accent-dark); }
.nav-links a:hover::after{ width:100%; }
.nav-cta{ display:flex; align-items:center; gap:14px; }
/* El botón dentro del menú desplegable solo aparece en móvil */
.nav-links .btn{ display:none; }

.menu-toggle{
  display:none; background:none; border:none; cursor:pointer; padding:8px;
  width:44px; height:44px; border-radius:10px; color:var(--text);
}
.menu-toggle svg{ width:26px; height:26px; }

/* ================================================================
   HERO
   ================================================================ */
.hero{
  position:relative; isolation:isolate; min-height:88vh; display:flex; align-items:center;
  padding-top:var(--header-h); overflow:hidden; color:#fff;
}
/* PERSONALIZAR: imagen de fondo del hero.
   El degradado de marca va ENCIMA de la foto para mantener legible el texto blanco.
   Sustituye 'hero.jpg' por la foto real de la academia (misma proporción apaisada). */
.hero-bg{
  position:absolute; inset:0; z-index:-2;
  background:
    linear-gradient(135deg, rgba(var(--accent-d-rgb),.90) 0%, rgba(var(--accent-rgb),.76) 55%, rgba(var(--accent-l-rgb),.68) 100%),
    url('img/hero.jpg') center/cover no-repeat;
}
.hero-bg::after{
  /* textura sutil — sustituible por foto real */
  content:""; position:absolute; inset:0;
  background-image:radial-gradient(circle at 1px 1px, rgba(255,255,255,.18) 1px, transparent 0);
  background-size:26px 26px; opacity:.5; z-index:-1;
}
.hero-inner{ max-width:720px; padding-block:60px; }
.hero .pill{
  display:inline-flex; align-items:center; gap:8px; background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.3); padding:7px 16px; border-radius:999px;
  font-size:.85rem; font-weight:600; margin-bottom:24px; backdrop-filter:blur(4px);
}
.hero h1{ color:#fff; font-size:clamp(2.4rem, 6vw, 4rem); font-weight:800; text-wrap:balance; }
.hero .claim{ font-size:clamp(1.1rem, 2.4vw, 1.4rem); margin-top:20px; max-width:560px; color:rgba(255,255,255,.94); text-wrap:pretty; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:36px; }
/* CTA principal del hero: blanco sobre el fondo verde para que destaque */
.hero-actions .btn--primary{ background:#fff; color:var(--accent-dark); box-shadow:0 8px 22px rgba(0,0,0,.18); }
.hero-actions .btn--primary:hover{ background:#fff; color:var(--accent-dark); transform:translateY(-2px); box-shadow:0 12px 28px rgba(0,0,0,.26); }
.hero-trust{ display:flex; flex-wrap:nowrap; gap:22px; margin-top:42px; font-size:.88rem; color:rgba(255,255,255,.9); }
.hero-trust div{ display:flex; align-items:center; gap:9px; white-space:nowrap; }
.hero-trust svg{ width:20px; height:20px; flex:none; }

/* ================================================================
   SOBRE
   ================================================================ */
.about-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:56px; align-items:center; }
.about-media{
  position:relative; border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:4/3;
  background:var(--accent-tint); box-shadow:var(--shadow-lg);
}
/* PERSONALIZAR: foto real de la academia dentro de .about-media */
.media-placeholder{
  position:absolute; inset:0; display:grid; place-items:center; gap:10px;
  color:var(--accent-dark); background:
    repeating-linear-gradient(45deg, rgba(var(--accent-rgb),.06) 0 14px, rgba(var(--accent-rgb),.12) 14px 28px);
  font-family:var(--font-head); font-weight:600; font-size:.9rem; text-align:center;
}
.media-placeholder svg{ width:54px; height:54px; opacity:.7; }
.features{ display:grid; grid-template-columns:1fr 1fr; gap:22px; margin-top:30px; }
.feature{ display:flex; gap:14px; }
.feature-ico{
  width:46px; height:46px; border-radius:12px; flex:none; display:grid; place-items:center;
  background:var(--accent-tint); color:var(--accent-dark);
}
.feature-ico svg{ width:24px; height:24px; }
.feature h3{ font-size:1.05rem; font-weight:700; margin-bottom:3px; }
.feature p{ font-size:.92rem; color:var(--text-soft); }

/* ================================================================
   CLASES
   ================================================================ */
.cards-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(280px,1fr)); gap:24px; }
.class-card{
  background:#fff; border:1px solid var(--border); border-radius:var(--radius);
  padding:28px 26px; display:flex; flex-direction:column; gap:14px; overflow:hidden;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.class-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:transparent; }
/* PERSONALIZAR: foto real de cada clase (banda superior de la tarjeta) */
.class-photo{ margin:-28px -26px 6px; height:180px; overflow:hidden; }
.class-photo img{ width:100%; height:100%; object-fit:cover; transition:transform .35s ease; }
.class-card:hover .class-photo img{ transform:scale(1.06); }
.class-ico{
  width:52px; height:52px; border-radius:14px; display:grid; place-items:center;
  background:var(--accent-gradient); color:#fff; box-shadow:0 6px 16px rgba(var(--accent-rgb),.3);
}
.class-ico svg{ width:26px; height:26px; }
.class-card h3{ font-size:1.25rem; font-weight:700; }
.class-card p{ color:var(--text-soft); font-size:.96rem; flex:1; }
.class-meta{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-top:6px; }
.price{ font-family:var(--font-head); font-weight:800; font-size:1.05rem; color:var(--text); }
.price span{ font-weight:500; font-size:.82rem; color:var(--text-soft); }
.link-cta{ font-family:var(--font-head); font-weight:700; font-size:.92rem; color:var(--accent-dark); display:inline-flex; align-items:center; gap:5px; }
.link-cta svg{ width:16px; height:16px; transition:transform .18s ease; }
.class-card:hover .link-cta svg{ transform:translateX(4px); }

/* ================================================================
   HORARIOS
   ================================================================ */
.schedule-wrap{ overflow:hidden; border:1px solid var(--border); border-radius:var(--radius); box-shadow:var(--shadow); }
table.schedule{ width:100%; border-collapse:collapse; font-size:.96rem; }
table.schedule th, table.schedule td{ padding:15px 18px; text-align:left; border-bottom:1px solid var(--border); }
table.schedule thead th{ background:var(--accent-tint); font-family:var(--font-head); font-weight:700; color:var(--accent-dark); }
table.schedule tbody tr:last-child td{ border-bottom:none; }
table.schedule td:first-child{ font-weight:600; }
table.schedule .day-pill{ display:inline-block; background:var(--bg-alt); border:1px solid var(--border); border-radius:999px; padding:3px 11px; font-size:.82rem; color:var(--text-soft); }
/* Versión móvil en tarjetas — se muestra con media query */
.schedule-cards{ display:none; }
.sched-card{ background:#fff; border:1px solid var(--border); border-radius:var(--radius); padding:18px 20px; }
.sched-card + .sched-card{ margin-top:14px; }
.sched-card h3{ font-size:1.1rem; font-weight:700; margin-bottom:10px; color:var(--accent-dark); }
.sched-row{ display:flex; justify-content:space-between; gap:14px; padding:7px 0; border-top:1px dashed var(--border); }
.sched-row:first-of-type{ border-top:none; }
.sched-row span:first-child{ color:var(--text-soft); }
.sched-row span:last-child{ font-weight:600; }

/* ================================================================
   PROFESORADO  (sección fácil de eliminar entera)
   ================================================================ */
.team-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(220px,1fr)); gap:30px; }
.teacher{ text-align:center; }
.teacher-photo{
  width:140px; height:140px; border-radius:50%; margin:0 auto 16px; overflow:hidden;
  background:var(--accent-tint); display:grid; place-items:center; color:var(--accent-dark);
  border:4px solid #fff; box-shadow:var(--shadow); position:relative;
}
.teacher-photo svg{ width:54px; height:54px; opacity:.65; }
.teacher-photo img{ width:100%; height:100%; object-fit:cover; }
/* PERSONALIZAR: sustituir el placeholder por <img class="teacher-photo" ...> */
.teacher h3{ font-size:1.1rem; font-weight:700; }
.teacher .role{ color:var(--accent-dark); font-weight:600; font-size:.9rem; margin-top:2px; }
.teacher p{ color:var(--text-soft); font-size:.9rem; margin-top:8px; text-wrap:pretty; }

/* ================================================================
   TESTIMONIOS
   ================================================================ */
.reviews-grid{ display:grid; grid-template-columns:repeat(auto-fit, minmax(300px,1fr)); gap:24px; }
.review{
  background:#fff; border:1px solid var(--border); border-radius:var(--radius);
  padding:30px 28px; display:flex; flex-direction:column; gap:16px; box-shadow:var(--shadow);
}
.stars{ display:flex; gap:3px; color:#f59e0b; }
.stars svg{ width:20px; height:20px; }
.review blockquote{ margin:0; font-size:1.05rem; color:var(--text); line-height:1.6; text-wrap:pretty; }
.reviewer{ display:flex; align-items:center; gap:12px; margin-top:auto; }
.reviewer .reviewer-avatar{ width:46px; height:46px; border-radius:50%; background:linear-gradient(135deg, var(--accent-dark) 0%, var(--accent-darker) 100%); color:#fff; display:grid; place-items:center; font-family:var(--font-head); font-weight:700; font-size:.95rem; flex:none; }
.reviewer b{ display:block; font-family:var(--font-head); font-size:.96rem; }
.reviewer span{ font-size:.85rem; color:var(--text-soft); }

/* ================================================================
   FAQ
   ================================================================ */
.faq-list{ max-width:780px; margin-inline:auto; }
.faq-item{ border:1px solid var(--border); border-radius:var(--radius-sm); background:#fff; margin-bottom:14px; overflow:hidden; }
.faq-q{
  width:100%; text-align:left; background:none; border:none; cursor:pointer;
  font-family:var(--font-head); font-weight:700; font-size:1.05rem; color:var(--text);
  padding:20px 22px; display:flex; align-items:center; justify-content:space-between; gap:16px;
}
.faq-q:focus-visible{ outline:3px solid var(--accent-light); outline-offset:-3px; }
.faq-q .chev{ flex:none; width:22px; height:22px; color:var(--accent-dark); transition:transform .25s ease; }
.faq-item.open .faq-q .chev{ transform:rotate(180deg); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .3s ease; }
.faq-a p{ padding:0 22px 22px; color:var(--text-soft); text-wrap:pretty; }

/* ================================================================
   CONTACTO
   ================================================================ */
.contact-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:48px; align-items:start; }
.form-card{ background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); padding:34px; box-shadow:var(--shadow); }
.field{ margin-bottom:18px; }
.field label{ display:block; font-family:var(--font-head); font-weight:600; font-size:.9rem; margin-bottom:7px; }
.field .req{ color:var(--accent-dark); }
.field input, .field select, .field textarea{
  width:100%; padding:13px 15px; border:1.5px solid var(--border); border-radius:var(--radius-sm);
  font-family:var(--font-body); font-size:1rem; color:var(--text); background:#fff; transition:border-color .15s ease, box-shadow .15s ease;
}
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(var(--accent-rgb),.16); }
.field textarea{ resize:vertical; min-height:110px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.consent{ display:flex; gap:10px; align-items:flex-start; font-size:.85rem; color:var(--text-soft); margin-bottom:20px; }
.consent input{ margin-top:3px; width:18px; height:18px; flex:none; accent-color:var(--accent); }
.form-note{ font-size:.82rem; color:var(--text-soft); margin-top:14px; text-align:center; }
.form-success{ display:none; background:var(--accent-tint); border:1px solid var(--accent-light); color:var(--accent-dark); border-radius:var(--radius-sm); padding:16px 18px; font-weight:600; margin-bottom:18px; }

.contact-info{ display:flex; flex-direction:column; gap:22px; }
.info-row{ display:flex; gap:14px; align-items:flex-start; }
.info-ico{ width:44px; height:44px; border-radius:12px; flex:none; display:grid; place-items:center; background:var(--accent-tint); color:var(--accent-dark); }
.info-ico svg{ width:22px; height:22px; }
.info-row b{ font-family:var(--font-head); display:block; margin-bottom:2px; }
.info-row a, .info-row p{ color:var(--text-soft); font-size:.95rem; }
.info-row a:hover{ color:var(--accent-dark); }
.socials{ display:flex; gap:12px; margin-top:4px; }
.socials a{ width:42px; height:42px; border-radius:12px; border:1px solid var(--border); display:grid; place-items:center; color:var(--text); transition:all .18s ease; }
.socials a:hover{ background:var(--accent); color:#fff; border-color:var(--accent); transform:translateY(-2px); }
.socials svg{ width:20px; height:20px; }
.map-embed{ margin-top:6px; border-radius:var(--radius); overflow:hidden; border:1px solid var(--border); box-shadow:var(--shadow); }
.map-embed iframe{ width:100%; height:260px; border:0; display:block; }

/* ================================================================
   FOOTER
   ================================================================ */
.site-footer{ background:var(--footer-bg); color:rgba(255,255,255,.78); padding:60px 0 26px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; }
.site-footer .brand{ color:#fff; margin-bottom:14px; }
.footer-about{ font-size:.95rem; max-width:340px; }
.site-footer h4{ color:#fff; font-size:1rem; margin-bottom:16px; font-weight:700; }
.footer-links li{ margin-bottom:10px; }
.footer-links a{ font-size:.95rem; transition:color .15s ease; }
.footer-links a:hover{ color:var(--accent-light); }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.12); margin-top:44px; padding-top:24px; display:flex; flex-wrap:wrap; gap:14px; justify-content:space-between; align-items:center; font-size:.85rem; }
.footer-bottom a{ color:#fff; font-weight:600; }
.footer-bottom a:hover{ color:var(--accent-light); }

/* ================================================================
   WHATSAPP FLOTANTE
   ================================================================ */
.whatsapp-fab{
  position:fixed; right:20px; bottom:20px; z-index:90;
  width:60px; height:60px; border-radius:50%; background:#25d366; color:#fff;
  display:grid; place-items:center; box-shadow:0 8px 24px rgba(37,211,102,.45);
  transition:transform .2s ease; animation:fab-in .4s ease both .8s;
}
.whatsapp-fab:hover{ transform:scale(1.08); }
.whatsapp-fab svg{ width:32px; height:32px; }
@keyframes fab-in{ from{ transform:scale(0); } to{ transform:scale(1); } }

/* ================================================================
   COOKIE BANNER
   ================================================================ */
.cookie-banner{
  position:fixed; left:20px; right:20px; bottom:20px; z-index:120; max-width:560px;
  background:#fff; border:1px solid var(--border); border-radius:var(--radius); padding:20px 22px;
  box-shadow:var(--shadow-lg); display:none; gap:16px; align-items:center;
}
.cookie-banner.show{ display:flex; flex-wrap:wrap; animation:fab-in .35s ease both; }
.cookie-banner p{ font-size:.9rem; color:var(--text-soft); flex:1; min-width:240px; }
.cookie-banner a{ color:var(--accent-dark); font-weight:600; text-decoration:underline; }
.cookie-actions{ display:flex; gap:10px; }

/* ================================================================
   ANIMACIONES AL SCROLL
   ================================================================ */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .6s ease, transform .6s ease; }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  html{ scroll-behavior:auto; }
  .whatsapp-fab{ animation:none; }
}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width:920px){
  .about-grid{ grid-template-columns:1fr; gap:36px; }
  .contact-grid{ grid-template-columns:1fr; gap:34px; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .footer-about{ grid-column:1 / -1; }
}
@media (max-width:1000px){
  /* Nav móvil — colapsa antes para no chocar con el logo */
  .menu-toggle{ display:grid; place-items:center; }
  .nav-links{
    position:fixed; inset:var(--header-h) 0 auto 0; flex-direction:column; gap:0;
    background:#fff; border-bottom:1px solid var(--border); box-shadow:var(--shadow-lg);
    padding:12px 20px 22px; align-items:stretch;
    opacity:0; pointer-events:none;
  }
  .nav-links.open{ opacity:1; pointer-events:auto; }
  .nav-links a:not(.btn){ padding:14px 4px; border-bottom:1px solid var(--border); font-size:1.05rem; }
  .nav-links a::after{ display:none; }
  .nav-cta .btn{ display:none; } /* el CTA vive dentro del menú en móvil */
  .nav-links .btn{ display:inline-flex; margin-top:14px; }
}
@media (max-width:760px){
  .section{ padding:54px 0; }
  .features{ grid-template-columns:1fr; }
  .hero-trust{ flex-wrap:wrap; gap:14px 22px; }
  /* Horarios -> tarjetas */
  .schedule-wrap{ display:none; }
  .schedule-cards{ display:block; }
  .field-row{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr; gap:28px; }
  .form-card{ padding:26px 22px; }
}
@media (max-width:420px){
  .hero-actions .btn{ width:100%; }
}

/* ================================================================
   NAV activo (multipágina)
   ================================================================ */
.nav-links a[aria-current="page"]{ color:var(--accent-dark); }
.nav-links a[aria-current="page"]::after{ width:100%; }

/* ================================================================
   PAGE HERO (cabecera de páginas internas)
   ================================================================ */
.page-hero{ position:relative; isolation:isolate; color:#fff; overflow:hidden;
  padding:calc(var(--header-h) + 54px) 0 54px; }
.page-hero::before{ content:""; position:absolute; inset:0; z-index:-2; background:var(--accent-gradient); }
.page-hero--photo::before{ background:linear-gradient(135deg, rgba(var(--accent-d-rgb),.93) 0%, rgba(var(--accent-rgb),.80) 100%); }
.page-hero .ph-img{ position:absolute; inset:0; z-index:-3; width:100%; height:100%; object-fit:cover; }
.page-hero h1{ color:#fff; font-size:clamp(2rem,5vw,3rem); font-weight:800; max-width:800px; text-wrap:balance; }
.page-hero .lead{ color:rgba(255,255,255,.93); margin-top:16px; max-width:640px; font-size:1.1rem; text-wrap:pretty; }
.breadcrumb{ font-size:.85rem; color:rgba(255,255,255,.85); margin-bottom:18px; display:flex; gap:8px; flex-wrap:wrap; align-items:center; }
.breadcrumb a:hover{ color:#fff; text-decoration:underline; }
.breadcrumb .sep{ opacity:.55; }

/* ================================================================
   SPLIT (contenido + sidebar) para páginas de disciplina/artículo
   ================================================================ */
.split{ display:grid; grid-template-columns:1.6fr .9fr; gap:48px; align-items:start; }
.prose > * + *{ margin-top:18px; }
.prose h2{ font-size:1.5rem; font-weight:800; margin-top:36px; }
.prose h3{ font-size:1.15rem; font-weight:700; margin-top:24px; }
.prose p{ color:var(--text); }
.prose a{ color:var(--accent-dark); font-weight:600; text-decoration:underline; }
.media-band{ border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-lg); aspect-ratio:16/9; margin-bottom:30px; }
.media-band img{ width:100%; height:100%; object-fit:cover; }
.check-list{ display:flex; flex-direction:column; gap:12px; margin-top:6px; }
.check-list li{ display:flex; gap:12px; align-items:flex-start; color:var(--text); }
.check-list svg{ width:22px; height:22px; color:var(--accent-dark); flex:none; margin-top:3px; }

.sidebar{ display:flex; flex-direction:column; gap:18px; position:sticky; top:calc(var(--header-h) + 18px); }
.side-card{ background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); padding:26px; box-shadow:var(--shadow); }
.side-card h3{ font-size:1.1rem; font-weight:700; margin-bottom:6px; }
.price-big{ font-family:var(--font-head); font-weight:800; font-size:2rem; color:var(--accent-dark); }
.price-big span{ font-size:.9rem; font-weight:500; color:var(--text-soft); }
.side-card dl{ margin:18px 0 20px; display:grid; gap:0; }
.side-card .row{ display:flex; justify-content:space-between; gap:12px; font-size:.95rem; border-top:1px dashed var(--border); padding:10px 0; }
.side-card .row:first-of-type{ border-top:none; }
.side-card .row span:first-child{ color:var(--text-soft); }
.side-card .row span:last-child{ font-weight:600; text-align:right; }
.side-card .btn{ width:100%; }
.side-card .btn + .btn{ margin-top:10px; }
.btn--wa{ background:#25d366; color:#fff; }
.btn--wa:hover{ background:#1ebe5d; transform:translateY(-2px); }

/* ================================================================
   CTA BAND (cierre de páginas)
   ================================================================ */
.cta-band{ background:var(--accent-gradient); color:#fff; border-radius:var(--radius-lg); padding:50px 40px; text-align:center; }
.cta-band h2{ color:#fff; font-size:clamp(1.6rem,3.5vw,2.2rem); font-weight:800; text-wrap:balance; }
.cta-band p{ color:rgba(255,255,255,.93); margin-top:12px; max-width:560px; margin-inline:auto; }
.cta-band .actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:26px; }
.cta-band .btn--primary{ background:#fff; color:var(--accent-dark); box-shadow:0 8px 22px rgba(0,0,0,.18); }
.cta-band .btn--primary:hover{ background:#fff; }

/* ================================================================
   BLOG
   ================================================================ */
.blog-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:26px; }
.post-card{ background:#fff; border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; display:flex; flex-direction:column; transition:transform .2s ease, box-shadow .2s ease; }
.post-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.post-card .ph{ height:190px; overflow:hidden; }
.post-card .ph img{ width:100%; height:100%; object-fit:cover; transition:transform .35s ease; }
.post-card:hover .ph img{ transform:scale(1.05); }
.post-card .body{ padding:22px 24px; display:flex; flex-direction:column; gap:10px; flex:1; }
.post-card .tag{ font-size:.74rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--accent-dark); }
.post-card h3{ font-size:1.18rem; font-weight:700; }
.post-card p{ color:var(--text-soft); font-size:.95rem; flex:1; }
.post-card .meta{ font-size:.82rem; color:var(--text-soft); }
.post-body{ max-width:760px; margin-inline:auto; }
.post-body .post-meta{ color:var(--text-soft); font-size:.9rem; margin-bottom:8px; }
.post-body .lead{ font-size:1.2rem; color:var(--text-soft); margin:14px 0 8px; }

/* ================================================================
   RESPONSIVE añadido
   ================================================================ */
@media (max-width:920px){
  .split{ grid-template-columns:1fr; gap:34px; }
  .sidebar{ position:static; }
}

/* ================================================================
   PÁGINAS LEGALES
   ================================================================ */
.legal-prose .updated{ color:var(--text-soft); font-size:.9rem; margin-bottom:24px; }
.legal-prose ul{ list-style:disc; padding-left:22px; display:flex; flex-direction:column; gap:8px; }
.legal-prose li{ color:var(--text); }
.legal-prose .note{ background:var(--accent-tint); border:1px solid var(--accent-light); border-radius:var(--radius-sm); padding:14px 16px; font-size:.92rem; color:var(--text); }
.legal-prose table{ width:100%; border-collapse:collapse; font-size:.92rem; margin-top:8px; border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
.legal-prose th, .legal-prose td{ padding:11px 14px; text-align:left; border-bottom:1px solid var(--border); vertical-align:top; }
.legal-prose thead th{ background:var(--accent-tint); color:var(--accent-dark); font-family:var(--font-head); }
.legal-prose tbody tr:last-child td{ border-bottom:none; }

/* ================================================================
   BANNER + MODAL "QUIERO UNA WEB COMO ESTA" (solo demos Opirex)
   ================================================================ */
.opx-banner{
  position:fixed; left:0; right:0; bottom:0; z-index:110;
  background:#0f172a; color:#fff; padding:11px 18px;
  display:flex; gap:16px; align-items:center; justify-content:center; flex-wrap:wrap;
  box-shadow:0 -6px 24px rgba(0,0,0,.22); transform:translateY(100%);
  transition:transform .4s ease; font-size:.95rem;
}
.opx-banner.show{ transform:none; }
.opx-banner strong{ font-family:var(--font-head); }
.opx-banner .opx-tag{ background:var(--accent); color:#fff; font-family:var(--font-head); font-weight:700; font-size:.7rem; letter-spacing:.06em; text-transform:uppercase; padding:3px 9px; border-radius:999px; }
.opx-banner .btn{ background:var(--accent-gradient); color:#fff; border:none; }
.opx-banner .btn:hover{ transform:translateY(-2px); }
.opx-banner .opx-close{ background:none; border:none; color:rgba(255,255,255,.6); cursor:pointer; font-size:1.4rem; line-height:1; padding:4px 8px; }
.opx-banner .opx-close:hover{ color:#fff; }
.opx-banner a.opx-by{ color:var(--accent-light); font-weight:600; }
/* subir FAB y cookie cuando el banner está visible */
.has-opx-banner .whatsapp-fab{ bottom:86px; }
.has-opx-banner .cookie-banner{ bottom:86px; }

.opx-modal{
  position:fixed; inset:0; z-index:130; display:none; align-items:center; justify-content:center;
  background:rgba(15,23,42,.6); backdrop-filter:blur(3px); padding:20px;
}
.opx-modal.open{ display:flex; animation:opx-fade .25s ease both; }
@keyframes opx-fade{ from{opacity:0} to{opacity:1} }
.opx-dialog{
  background:#fff; border-radius:var(--radius-lg); max-width:480px; width:100%;
  padding:32px; box-shadow:var(--shadow-lg); position:relative; max-height:92vh; overflow:auto;
  animation:opx-pop .28s ease both;
}
@keyframes opx-pop{ from{opacity:0; transform:translateY(14px) scale(.98)} to{opacity:1; transform:none} }
.opx-dialog .opx-close{ position:absolute; top:14px; right:16px; background:none; border:none; font-size:1.6rem; line-height:1; color:var(--text-soft); cursor:pointer; }
.opx-dialog .opx-close:hover{ color:var(--text); }
.opx-dialog .opx-eyebrow{ color:var(--accent-dark); font-family:var(--font-head); font-weight:700; font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; }
.opx-dialog h2{ font-size:1.5rem; font-weight:800; margin:8px 0 6px; }
.opx-dialog p.opx-sub{ color:var(--text-soft); font-size:.96rem; margin-bottom:20px; }
.opx-dialog .btn{ width:100%; margin-top:4px; }
.opx-dialog .opx-success{ display:none; text-align:center; padding:18px 0; }
.opx-dialog .opx-success svg{ width:54px; height:54px; color:var(--accent-dark); margin-bottom:10px; }
.opx-dialog .opx-success h2{ margin-top:0; }
.opx-foot{ font-size:.8rem; color:var(--text-soft); text-align:center; margin-top:14px; }
@media (max-width:600px){
  .opx-banner{ font-size:.88rem; padding:10px 14px; }
  .opx-banner .opx-msg{ flex-basis:100%; text-align:center; }
}
