/*
Theme Name: SAPPRO Pro
Theme URI: https://consultorsapsd.com/
Author: Reyes Montoya
Author URI: https://www.linkedin.com/in/reyes-montoya/
Description: Tema moderno corporativo para SAPPRO, el blog para consultores SAP. Diseño limpio y profesional con identidad propia. Incluye plantillas para Inicio, Blog, Conóceme, Preguntas frecuentes y Guías.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: sappro-pro
*/

/* ============================================================
   TOKENS / VARIABLES
   Paleta renovada: azul medianoche + cian eléctrico + cobre
   ============================================================ */
:root{
  --c-ink:        #0B1A2F;   /* azul medianoche, texto y fondos oscuros */
  --c-ink-soft:   #16273f;
  --c-deep:       #102845;   /* azul profundo de superficie */
  --c-accent:     #1FB6C9;   /* cian eléctrico, acento principal */
  --c-accent-2:   #C97B3E;   /* cobre cálido, acento secundario */
  --c-paper:      #FAFBFC;   /* fondo claro */
  --c-paper-2:    #EEF2F6;   /* gris muy suave */
  --c-line:       #D7DEE7;   /* líneas / bordes */
  --c-muted:      #5A6B7E;   /* texto secundario */
  --c-white:      #FFFFFF;

  --font-display: "Sora", system-ui, -apple-system, sans-serif;
  --font-body:    "Inter", system-ui, -apple-system, sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --maxw: 1180px;
  --radius: 16px;
  --radius-sm: 10px;
  --shadow: 0 10px 40px -12px rgba(11,26,47,.18);
  --shadow-soft: 0 4px 20px -8px rgba(11,26,47,.12);
  --ease: cubic-bezier(.2,.7,.2,1);
}

/* ============================================================
   RESET / BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--c-ink);
  background:var(--c-paper);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--c-accent);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--c-accent-2)}
h1,h2,h3,h4,h5{font-family:var(--font-display);line-height:1.15;font-weight:700;color:var(--c-ink);margin:0 0 .5em}
h1{font-size:clamp(2.2rem,5vw,3.6rem);letter-spacing:-.02em}
h2{font-size:clamp(1.7rem,3.5vw,2.6rem);letter-spacing:-.015em}
h3{font-size:1.35rem}
p{margin:0 0 1rem}
ul,ol{margin:0 0 1rem;padding-left:1.2rem}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:24px}
.section{padding:clamp(56px,8vw,110px) 0}
.section--tight{padding:clamp(40px,6vw,72px) 0}
.eyebrow{
  font-family:var(--font-mono);
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--c-accent);
  margin:0 0 14px;
  display:inline-flex;align-items:center;gap:8px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--c-accent)}
.lead{font-size:1.15rem;color:var(--c-muted);max-width:60ch}
.text-center{text-align:center}
.text-center .lead,.text-center .eyebrow{margin-inline:auto}
.text-center .eyebrow{justify-content:center}

/* skip link */
.skip-link{position:absolute;left:-999px}
.skip-link:focus{left:16px;top:16px;background:var(--c-ink);color:#fff;padding:10px 16px;border-radius:8px;z-index:999}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-weight:600;font-size:.98rem;
  padding:14px 26px;border-radius:999px;cursor:pointer;border:0;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease);
  text-decoration:none;
}
.btn svg{width:18px;height:18px}
.btn--primary{background:var(--c-accent);color:var(--c-ink)}
.btn--primary:hover{background:var(--c-accent-2);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow)}
.btn--ghost{background:transparent;color:var(--c-ink);border:1.5px solid var(--c-line)}
.btn--ghost:hover{border-color:var(--c-ink);color:var(--c-ink);transform:translateY(-2px)}
.btn--light{background:var(--c-white);color:var(--c-ink)}
.btn--light:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn--onlight-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.4)}
.btn--onlight-ghost:hover{border-color:#fff;color:#fff;background:rgba(255,255,255,.08);transform:translateY(-2px)}

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(250,251,252,.82);
  backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .3s,box-shadow .3s;
}
.site-header.is-scrolled{border-color:var(--c-line);box-shadow:var(--shadow-soft)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;height:74px}
.nav__brand{display:flex;align-items:center;gap:12px;font-family:var(--font-display);font-weight:800;font-size:1.15rem;color:var(--c-ink);letter-spacing:-.01em}
.nav__brand:hover{color:var(--c-ink)}
.nav__logo-img{max-height:38px;width:auto}
.brand-mark{
  width:38px;height:38px;border-radius:10px;flex:none;
  background:var(--c-ink);color:var(--c-accent);
  display:grid;place-items:center;font-family:var(--font-mono);font-weight:700;font-size:.95rem;
}
.nav__menu{display:flex;align-items:center;gap:6px;list-style:none;margin:0;padding:0}
.nav__menu a{
  font-family:var(--font-display);font-weight:500;font-size:.95rem;
  color:var(--c-ink);padding:9px 14px;border-radius:999px;
  transition:background .2s,color .2s;
}
.nav__menu a:hover,.nav__menu .current-menu-item>a{background:var(--c-paper-2);color:var(--c-ink)}
.nav__cta{margin-left:8px}
.nav__toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;color:var(--c-ink)}
.nav__toggle svg{width:26px;height:26px}

@media(max-width:920px){
  .nav__menu,.nav__cta{display:none}
  .nav__toggle{display:block}
  .site-header.menu-open .nav__menu{
    display:flex;position:absolute;top:74px;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:2px;
    background:var(--c-paper);border-bottom:1px solid var(--c-line);
    padding:14px 24px 22px;box-shadow:var(--shadow);
  }
  .site-header.menu-open .nav__menu a{padding:13px 16px}
  .site-header.menu-open .nav__cta{display:block;padding:6px 24px 0}
  .site-header.menu-open .nav__cta .btn{width:100%;justify-content:center}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;overflow:hidden;
  background:linear-gradient(160deg,var(--c-ink) 0%,var(--c-deep) 60%,var(--c-ink-soft) 100%);
  color:#fff;
  padding:clamp(70px,10vw,130px) 0 clamp(60px,8vw,110px);
}
.hero::before{
  content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background:
    radial-gradient(420px 420px at 78% 18%,rgba(31,182,201,.22),transparent 70%),
    radial-gradient(360px 360px at 12% 88%,rgba(201,123,62,.16),transparent 70%);
}
.hero__grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(30px,5vw,64px);align-items:center;
}
.hero h1{color:#fff}
.hero h1 .hl{color:var(--c-accent)}
.hero .eyebrow{color:var(--c-accent)}
.hero__lead{color:rgba(255,255,255,.82);font-size:1.18rem;max-width:52ch;margin-bottom:14px}
.hero__cert{
  display:inline-flex;align-items:center;gap:10px;margin:6px 0 28px;
  font-family:var(--font-mono);font-size:.82rem;letter-spacing:.04em;
  color:var(--c-accent);background:rgba(31,182,201,.1);
  border:1px solid rgba(31,182,201,.3);padding:8px 16px;border-radius:999px;
}
.hero__cert svg{width:18px;height:18px;flex:none}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px}
.hero__media{position:relative}
.hero__media img{
  border-radius:24px;box-shadow:0 30px 80px -20px rgba(0,0,0,.55);
  position:relative;z-index:1;width:100%;object-fit:cover;aspect-ratio:4/5;
}
.hero__media::after{
  content:"";position:absolute;inset:auto -18px -18px auto;width:62%;height:62%;
  border:2px solid var(--c-accent);border-radius:24px;z-index:0;
}
.hero__badge{
  position:absolute;left:-18px;bottom:28px;z-index:2;
  background:#fff;color:var(--c-ink);border-radius:14px;padding:14px 18px;
  box-shadow:var(--shadow);display:flex;align-items:center;gap:12px;max-width:230px;
}
.hero__badge strong{font-family:var(--font-display);display:block;font-size:1.5rem;line-height:1}
.hero__badge span{font-size:.8rem;color:var(--c-muted)}
.hero__badge .dot{width:10px;height:10px;border-radius:50%;background:var(--c-accent);flex:none}
@media(max-width:820px){
  .hero__grid{grid-template-columns:1fr}
  .hero__media{max-width:420px;margin:8px auto 0}
}

/* stats strip */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;border-top:1px solid var(--c-line);border-bottom:1px solid var(--c-line);padding:32px 0;text-align:center}
.stats .num{font-family:var(--font-display);font-size:clamp(1.8rem,4vw,2.6rem);font-weight:800;color:var(--c-ink);line-height:1}
.stats .num em{color:var(--c-accent);font-style:normal}
.stats .lbl{font-size:.85rem;color:var(--c-muted);margin-top:6px}
@media(max-width:680px){.stats{grid-template-columns:repeat(2,1fr);gap:28px 16px}}

/* ============================================================
   FEATURE CARDS (cualidades)
   ============================================================ */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:900px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.cards{grid-template-columns:1fr}}
.card{
  background:var(--c-white);border:1px solid var(--c-line);border-radius:var(--radius);
  padding:30px 28px;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;
  position:relative;overflow:hidden;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.card__icon{
  width:50px;height:50px;border-radius:12px;display:grid;place-items:center;margin-bottom:18px;
  background:var(--c-ink);color:var(--c-accent);
}
.card__icon svg{width:24px;height:24px}
.card h3{margin-bottom:10px;font-size:1.2rem}
.card p{color:var(--c-muted);font-size:.96rem;margin:0}
.card__num{position:absolute;top:18px;right:22px;font-family:var(--font-mono);font-size:.8rem;color:var(--c-line)}

/* ============================================================
   ABOUT / CERT
   ============================================================ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,64px);align-items:center}
@media(max-width:840px){.split{grid-template-columns:1fr}}
.cert-list{list-style:none;padding:0;margin:18px 0 0;display:grid;gap:14px}
.cert-list li{
  display:flex;gap:14px;align-items:flex-start;background:var(--c-white);
  border:1px solid var(--c-line);border-radius:var(--radius-sm);padding:16px 18px;
}
.cert-list .chk{flex:none;width:26px;height:26px;border-radius:50%;background:rgba(31,182,201,.14);color:var(--c-accent);display:grid;place-items:center}
.cert-list .chk svg{width:15px;height:15px}
.cert-list strong{font-family:var(--font-display);display:block;font-size:1rem}
.cert-list span{font-size:.88rem;color:var(--c-muted)}
.media-frame{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-soft);border:1px solid var(--c-line)}

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band{
  background:linear-gradient(135deg,var(--c-ink),var(--c-deep));
  color:#fff;border-radius:var(--radius);padding:clamp(40px,6vw,64px);
  text-align:center;position:relative;overflow:hidden;
}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(500px 300px at 80% 0%,rgba(31,182,201,.2),transparent 70%)}
.cta-band>*{position:relative;z-index:1}
.cta-band h2{color:#fff}
.cta-band p{color:rgba(255,255,255,.82);max-width:54ch;margin-inline:auto}

/* ============================================================
   DOWNLOADS
   ============================================================ */
.dl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:900px){.dl-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.dl-grid{grid-template-columns:1fr}}
.dl-card{
  display:flex;flex-direction:column;background:var(--c-white);border:1px solid var(--c-line);
  border-radius:var(--radius);padding:26px;transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.dl-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.dl-card .ext{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;color:var(--c-accent-2);text-transform:uppercase}
.dl-card h3{font-size:1.15rem;margin:12px 0 8px}
.dl-card p{color:var(--c-muted);font-size:.92rem;flex:1}
.dl-card .dl-link{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:600;font-size:.92rem;margin-top:10px}
.dl-card .dl-link svg{width:16px;height:16px;transition:transform .25s var(--ease)}
.dl-card:hover .dl-link svg{transform:translateY(2px)}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.tst-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
@media(max-width:760px){.tst-grid{grid-template-columns:1fr}}
.tst{background:var(--c-white);border:1px solid var(--c-line);border-radius:var(--radius);padding:30px 28px}
.tst__quote{font-size:1rem;color:var(--c-ink);margin:0 0 20px;position:relative}
.tst__mark{font-family:var(--font-display);font-size:3rem;color:var(--c-accent);line-height:.6;display:block;margin-bottom:6px}
.tst__who{display:flex;align-items:center;gap:14px}
.tst__avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;background:var(--c-paper-2);flex:none}
.tst__name{font-family:var(--font-display);font-weight:700;font-size:.98rem}
.tst__role{font-size:.82rem;color:var(--c-muted)}

/* ============================================================
   BLOG / POSTS
   ============================================================ */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
@media(max-width:900px){.posts{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.posts{grid-template-columns:1fr}}
.post-card{display:flex;flex-direction:column;background:var(--c-white);border:1px solid var(--c-line);border-radius:var(--radius);overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.post-card__thumb{aspect-ratio:16/10;overflow:hidden;background:var(--c-paper-2)}
.post-card__thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.post-card:hover .post-card__thumb img{transform:scale(1.05)}
.post-card__body{padding:24px;display:flex;flex-direction:column;flex:1}
.post-card__meta{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.05em;color:var(--c-muted);text-transform:uppercase;margin-bottom:10px}
.post-card h3{font-size:1.18rem;margin-bottom:10px;line-height:1.3}
.post-card h3 a{color:var(--c-ink)}
.post-card h3 a:hover{color:var(--c-accent)}
.post-card__excerpt{color:var(--c-muted);font-size:.93rem;flex:1}
.post-card__more{font-family:var(--font-display);font-weight:600;font-size:.9rem;margin-top:14px;display:inline-flex;align-items:center;gap:8px}

/* single + page content */
.entry{max-width:760px;margin-inline:auto}
.entry__header{margin-bottom:36px}
.entry__title{margin-bottom:12px}
.entry__meta{font-family:var(--font-mono);font-size:.8rem;color:var(--c-muted);letter-spacing:.05em}
.entry__featured{border-radius:var(--radius);overflow:hidden;margin:0 0 36px;box-shadow:var(--shadow-soft)}
.entry-content{font-size:1.08rem}
.entry-content h2{margin-top:1.8em}
.entry-content h3{margin-top:1.5em}
.entry-content img{border-radius:var(--radius-sm);margin:1.5em 0}
.entry-content blockquote{border-left:3px solid var(--c-accent);margin:1.5em 0;padding:.4em 0 .4em 1.2em;color:var(--c-muted);font-style:italic}
.entry-content a{text-decoration:underline;text-underline-offset:3px}
.entry-content code{font-family:var(--font-mono);background:var(--c-paper-2);padding:2px 7px;border-radius:6px;font-size:.88em}

/* pagination */
.pagination{display:flex;gap:8px;justify-content:center;margin-top:48px;flex-wrap:wrap}
.pagination .page-numbers{display:grid;place-items:center;min-width:44px;height:44px;padding:0 14px;border-radius:999px;border:1px solid var(--c-line);font-family:var(--font-display);font-weight:600;color:var(--c-ink)}
.pagination .page-numbers.current{background:var(--c-ink);color:#fff;border-color:var(--c-ink)}
.pagination a.page-numbers:hover{border-color:var(--c-ink)}

/* ============================================================
   PAGE HERO (subpáginas)
   ============================================================ */
.page-hero{
  background:linear-gradient(160deg,var(--c-ink),var(--c-deep));
  color:#fff;padding:clamp(60px,8vw,96px) 0 clamp(48px,6vw,72px);text-align:center;
  position:relative;overflow:hidden;
}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(500px 300px at 50% 0%,rgba(31,182,201,.18),transparent 70%)}
.page-hero>*{position:relative;z-index:1}
.page-hero h1{color:#fff}
.page-hero p{color:rgba(255,255,255,.82);max-width:60ch;margin-inline:auto}
.page-hero .eyebrow{color:var(--c-accent)}

/* ============================================================
   FAQ
   ============================================================ */
.faq{max-width:820px;margin-inline:auto;display:grid;gap:14px}
.faq__item{background:var(--c-white);border:1px solid var(--c-line);border-radius:var(--radius-sm);overflow:hidden}
.faq__q{
  width:100%;text-align:left;background:none;border:0;cursor:pointer;
  padding:22px 24px;font-family:var(--font-display);font-weight:600;font-size:1.05rem;color:var(--c-ink);
  display:flex;justify-content:space-between;align-items:center;gap:16px;
}
.faq__q .ic{flex:none;width:24px;height:24px;transition:transform .3s var(--ease);color:var(--c-accent)}
.faq__item.open .faq__q .ic{transform:rotate(45deg)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.faq__a-inner{padding:0 24px 22px;color:var(--c-muted)}

/* ============================================================
   CONTACT CARDS
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr}}
.contact-card{background:var(--c-white);border:1px solid var(--c-line);border-radius:var(--radius);padding:30px;text-align:center;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.contact-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.contact-card .ci{width:54px;height:54px;border-radius:14px;margin:0 auto 16px;display:grid;place-items:center;background:var(--c-ink);color:var(--c-accent)}
.contact-card .ci svg{width:26px;height:26px}
.contact-card h3{font-size:1.1rem;margin-bottom:8px}
.contact-card p{color:var(--c-muted);font-size:.92rem;margin-bottom:14px}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--c-ink);color:rgba(255,255,255,.7);padding:64px 0 0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:48px}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr;gap:32px}}
.site-footer h4{color:#fff;font-size:1rem;margin-bottom:16px}
.site-footer a{color:rgba(255,255,255,.7)}
.site-footer a:hover{color:var(--c-accent)}
.footer-brand{display:flex;align-items:center;gap:12px;margin-bottom:16px;color:#fff;font-family:var(--font-display);font-weight:800;font-size:1.2rem}
.footer-menu{list-style:none;padding:0;margin:0;display:grid;gap:10px;font-size:.95rem}
.footer-social{display:flex;gap:10px;margin-top:16px}
.footer-social a{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.07);color:#fff;transition:background .25s,transform .25s}
.footer-social a:hover{background:var(--c-accent);color:var(--c-ink);transform:translateY(-2px)}
.footer-social svg{width:20px;height:20px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:22px 0;font-size:.85rem;text-align:center}

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
/* Red de seguridad: si JS no se ejecuta, el contenido se ve igual */
.no-js .reveal{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* WP core alignments */
.aligncenter{margin-inline:auto;display:block}
.alignright{float:right;margin:0 0 1em 1.5em}
.alignleft{float:left;margin:0 1.5em 1em 0}
.wp-caption-text{font-size:.85rem;color:var(--c-muted);text-align:center}
.sticky,.gallery-caption,.bypostauthor{}

/* ============================================================
   COMPATIBILIDAD CON CONTENIDO DE PÁGINAS (Kubio / Elementor)
   Suaviza bloques heredados para que combinen con el tema.
   ============================================================ */
.entry-content .wp-block-group,
.entry-content .wp-block-columns{margin-block:1.5em}
.entry-content .wp-block-button__link{
  background:var(--c-accent);color:var(--c-ink);border-radius:999px;
  font-family:var(--font-display);font-weight:600;padding:12px 24px;
}
.entry-content .wp-block-button__link:hover{background:var(--c-accent-2);color:#fff}
/* Tarjetas / cajas de descargables heredadas */
.entry-content .wp-block-file{
  background:var(--c-white);border:1px solid var(--c-line);border-radius:var(--radius-sm);
  padding:18px 22px;margin-block:14px;display:flex;align-items:center;justify-content:space-between;gap:16px;
}
.entry-content .wp-block-file a:first-child{font-family:var(--font-display);font-weight:600;color:var(--c-ink)}
.entry-content .wp-block-file .wp-block-file__button{
  background:var(--c-accent);color:var(--c-ink);border-radius:999px;padding:8px 18px;
  font-family:var(--font-display);font-weight:600;text-decoration:none;
}

/* ============================================================
   CONÓCEME / PÁGINAS LARGAS — robustez en móvil
   Evita que columnas heredadas oculten contenido o desborden.
   ============================================================ */
.entry-content{overflow-wrap:break-word;word-wrap:break-word}
.entry-content img{height:auto}
.entry-content figure{margin:1.5em 0}
@media(max-width:760px){
  /* Apila cualquier estructura de columnas heredada */
  .entry-content .wp-block-columns,
  .entry-content .wp-block-column,
  .entry-content [class*="columns"],
  .entry-content [class*="col-"]{
    display:block !important;
    width:100% !important;
    max-width:100% !important;
    flex:none !important;
    float:none !important;
  }
  .entry-content img,
  .entry-content figure,
  .entry-content figure img{
    width:100% !important;
    max-width:100% !important;
    height:auto !important;
    float:none !important;
    margin-left:0 !important;
    margin-right:0 !important;
  }
  /* Garantiza visibilidad de bloques heredados en móvil */
  .entry-content [style*="opacity:0"],
  .entry-content [style*="opacity: 0"]{opacity:1 !important}
}
