/* ───────── Miriam Ferrucci · shared design system ───────── */
:root{
  /* espaciomiriam brand · mauve #9F8AAB + charcoal #2A272D */
  --malva:#9F8AAB;
  --malva-mid:#B7A6C2;
  --malva-light:#D6CADD;
  --malva-pale:#F1ECF4;
  --malva-dark:#6E5C7E;
  --cream:#FAF8F5;
  --warm-white:#FFFEFB;
  --text:#2A272D;
  --text-mid:#5C5560;
  --text-soft:#9F8AAB;
  --charcoal:#2A272D;
  --serif:'Fraunces',Georgia,serif;
  --sans:'Montserrat','DM Sans',system-ui,-apple-system,sans-serif;
  --shadow-sm:0 1px 2px rgba(38,24,48,.04),0 4px 16px rgba(38,24,48,.04);
  --shadow-md:0 24px 60px rgba(139,107,174,.12);
  --shadow-lg:0 30px 80px rgba(92,63,133,.18);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);font-weight:400;font-size:16px;line-height:1.65;
  color:var(--text);background:var(--cream);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
/* Estilo de <em> sólo en titulares/heros (acento de marca: malva + bold).
   En cuerpos de artículo y legal-prose se mantiene la cursiva semántica. */
h1 em, h2 em, h3 em, .h1 em, .h2 em, .h3 em, .hero-h1 em,
.bp-step-title em, .ah-h1 em, .let-hero h1 em, .blog-hero h1 em,
.spec-section h1 em, .spec-section h2 em, .spec-cta h2 em,
.section-head em, .final-cta-inner h2 em, .cta-row h2 em,
.modes-head em, blockquote.ah-blockquote em{
  font-style:normal;color:var(--malva-dark);font-weight:600
}
::selection{background:var(--malva-light);color:var(--text)}

/* type scale — Montserrat-led, restrained */
.h1{font-family:var(--sans);font-weight:600;font-size:clamp(38px,5.4vw,62px);line-height:1.06;letter-spacing:-0.025em}
.h2{font-family:var(--sans);font-weight:600;font-size:clamp(32px,3.8vw,46px);line-height:1.1;letter-spacing:-0.02em}
.h3{font-family:var(--sans);font-weight:600;font-size:22px;line-height:1.25;letter-spacing:-0.01em}
.body-lg{font-size:18px;line-height:1.6;color:var(--text-mid);font-weight:400}
.body{font-size:16px;line-height:1.65;color:var(--text-mid);font-weight:400}
.caption{font-family:var(--sans);font-weight:600;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--text-soft)}

.pretitle{display:inline-flex;align-items:center;gap:14px;margin-bottom:22px;
  font-family:var(--sans);font-weight:600;font-size:11px;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--malva-dark)}
.pretitle::before{content:"";display:block;width:28px;height:1px;background:var(--malva)}
.pretitle.on-dark{color:var(--malva-light)}
.pretitle.on-dark::before{background:var(--malva-light)}

.wrap{max-width:1280px;margin:0 auto;padding:0 60px}
@media (max-width:768px){.wrap{padding:0 22px}}

/* specialty page shared */
.spec-hero{padding:48px 60px 56px;background:var(--cream)}
.spec-hero-inner{max-width:880px;margin:0 auto}
.spec-hero h1{margin:14px 0 18px}
.spec-section{padding:60px;max-width:880px;margin:0 auto}
.spec-section h2{font-size:32px;font-weight:600;letter-spacing:-0.02em;margin-bottom:18px}
.spec-section .lead{font-size:17px;color:var(--text-mid);margin-bottom:24px;line-height:1.65}
.spec-list{list-style:none;display:flex;flex-direction:column;gap:14px;margin-bottom:24px}
.spec-list li{padding:18px 22px;background:var(--warm-white);border:1px solid var(--malva-light);border-radius:12px;
  font-size:15px;color:var(--text);line-height:1.6;display:flex;gap:14px;align-items:flex-start}
.spec-list li::before{content:"·";color:var(--malva);font-size:28px;line-height:0.6;margin-top:6px}
.spec-callout{background:var(--malva-pale);border-radius:14px;padding:22px 26px;font-size:15.5px;color:var(--malva-dark);font-weight:500;margin:24px 0}
.spec-warn{background:#FEF6E7;border-left:3px solid #C99A3A;border-radius:10px;padding:20px 24px;margin:24px 0;font-size:14.5px;line-height:1.6;color:#5C3F00}
.subblock{padding:24px 0;border-top:1px solid var(--malva-light)}
.subblock:first-child{border-top:none;padding-top:8px}
.subblock h3{font-size:13px;font-weight:600;color:var(--malva-dark);letter-spacing:0.14em;text-transform:uppercase;margin-bottom:10px}
.subblock p{color:var(--text-mid);font-size:15.5px;line-height:1.7}
.timeline{display:grid;gap:14px;margin:24px 0}
.timeline div{padding:18px 22px;background:var(--warm-white);border:1px solid var(--malva-light);border-radius:12px}
.timeline strong{color:var(--malva-dark);font-size:13px;letter-spacing:0.06em;text-transform:uppercase;display:block;margin-bottom:6px;font-weight:600}
.timeline p{color:var(--text-mid);font-size:14.5px;line-height:1.6}
.tag-row{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0}
.tag-row span{padding:8px 16px;background:var(--warm-white);border:1px solid var(--malva-light);border-radius:30px;font-size:13.5px;color:var(--text-mid)}
.spec-cta{padding:60px 22px 100px;text-align:center}
.spec-cta h2{font-size:30px;font-weight:600;margin-bottom:14px;letter-spacing:-0.02em}
.spec-cta p{color:var(--text-mid);max-width:480px;margin:0 auto 22px}
@media (max-width:768px){.spec-hero{padding:32px 22px 36px}.spec-section{padding:40px 22px}}

/* legal pages */
.legal-hero{padding:48px 22px 24px;background:var(--cream);text-align:center}
.legal-hero .crumb{font-size:12px;color:var(--text-soft);letter-spacing:0.06em;margin-bottom:14px}
.legal-hero .crumb a{color:var(--malva-dark)}
.legal-hero h1{font-size:clamp(32px,4vw,42px);font-weight:600;letter-spacing:-0.02em;margin-bottom:8px}
.legal-hero p{font-size:14px;color:var(--text-soft);max-width:480px;margin:0 auto}
.legal-prose{max-width:760px;margin:0 auto;padding:40px 22px 100px;font-size:16.5px;line-height:1.8;color:var(--text-mid)}
/* Tablas legales: overflow horizontal en mobile para no romper layout en <768. */
@media (max-width:768px){
  .legal-prose .table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:14px -22px;padding:0 22px}
  .legal-prose table{min-width:540px;font-size:13.5px}
}
.legal-prose h2{margin:48px 0 14px;font-size:22px;font-weight:600;color:var(--text);letter-spacing:-0.01em}
.legal-prose h3{margin:28px 0 8px;font-size:16px;font-weight:600;color:var(--text)}
.legal-prose p{margin-bottom:14px}
.legal-prose ul{margin:8px 0 18px 22px}
.legal-prose ul li{margin-bottom:6px}
.legal-prose a{color:var(--malva-dark);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.legal-prose .updated{padding:14px 18px;background:var(--malva-pale);border-radius:10px;font-size:13px;color:var(--malva-dark);margin-bottom:32px;font-weight:500}
.legal-prose table{width:100%;border-collapse:collapse;margin:14px 0;font-size:13.5px}
.legal-prose th,.legal-prose td{padding:10px 14px;border:1px solid var(--malva-light);text-align:left;vertical-align:top}
.legal-prose th{background:var(--malva-pale);font-weight:600;color:var(--text);font-size:12.5px}

/* cookie banner */
.cookie-banner{position:fixed;bottom:18px;left:18px;right:18px;max-width:520px;
  background:var(--warm-white);border:1px solid var(--malva-light);border-radius:16px;
  padding:22px 24px;box-shadow:var(--shadow-lg);z-index:9000;display:none}
.cookie-banner.show{display:block;animation:cb-up .35s ease both}
@keyframes cb-up{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.cookie-banner h4{font-size:14px;font-weight:600;margin-bottom:6px}
.cookie-banner p{font-size:13px;color:var(--text-mid);line-height:1.55;margin-bottom:14px}
.cookie-banner p a{color:var(--malva-dark);font-weight:600;text-decoration:underline}
.cookie-banner .cb-row{display:flex;flex-wrap:wrap;gap:8px}
.cookie-banner button{padding:13px 18px;border-radius:24px;font-size:13.5px;font-weight:600;cursor:pointer;border:none;transition:.2s;font-family:inherit;min-height:44px}
/* AEPD 2023: Aceptar y Rechazar deben tener misma prominencia visual */
.cookie-banner .cb-accept,
.cookie-banner .cb-reject,
.cookie-banner .cb-config{
  background:var(--malva);color:#fff;border:none;
  padding:10px 18px;border-radius:24px;font-size:13px;font-weight:600;
  cursor:pointer;transition:.2s;font-family:inherit;flex:1;min-width:120px
}
.cookie-banner .cb-accept:hover,
.cookie-banner .cb-reject:hover,
.cookie-banner .cb-config:hover{background:var(--malva-dark)}
@media (max-width:560px){
  .cookie-banner{left:12px;right:12px;bottom:12px;padding:18px}
  .cookie-banner .cb-row{flex-direction:column;gap:10px}
  .cookie-banner .cb-row button{width:100%}
}

/* blog */
.blog-hero{padding:60px 22px 30px;text-align:center;background:var(--cream)}
.blog-hero h1{font-size:clamp(36px,4.6vw,52px);font-weight:600;letter-spacing:-0.02em;margin:14px 0 12px}
.blog-hero p{color:var(--text-mid);max-width:520px;margin:0 auto;font-size:16px}
.blog-grid{max-width:1080px;margin:0 auto;padding:40px 22px 100px;display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
@media (max-width:900px){.blog-grid{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.blog-grid{grid-template-columns:1fr}}
.post-card{background:var(--warm-white);border:1px solid var(--malva-light);border-radius:16px;
  overflow:hidden;display:flex;flex-direction:column;transition:.25s}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.post-thumb{aspect-ratio:16/10;background:linear-gradient(135deg,var(--malva-light),var(--malva-mid));position:relative;overflow:hidden}
.post-thumb::after{content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 70% 30%,rgba(255,255,255,.25),transparent 50%)}
.post-thumb.t2{background:linear-gradient(135deg,#E8DCC0,#C9A87C)}
.post-thumb.t3{background:linear-gradient(135deg,#9A8FB8,#5C3F85)}
.post-card .pc-body{padding:24px;flex:1;display:flex;flex-direction:column}
.post-card .pc-cat{font-size:10.5px;font-weight:600;color:var(--malva-dark);letter-spacing:0.16em;text-transform:uppercase;margin-bottom:12px}
.post-card h3{font-size:18px;font-weight:600;letter-spacing:-0.01em;line-height:1.3;margin-bottom:10px;color:var(--text)}
.post-card p{font-size:15.5px;color:var(--text-mid);line-height:1.6;margin-bottom:18px;flex:1}
.post-card .pc-meta{font-size:12.5px;color:var(--text-soft);display:flex;justify-content:space-between;align-items:center}
.post-card .pc-meta .read{color:var(--malva-dark);font-weight:600}

/* article */
.article{max-width:720px;margin:0 auto;padding:40px 22px 80px}
.article .crumb{font-size:12px;color:var(--text-soft);margin-bottom:22px}
.article .crumb a{color:var(--malva-dark)}
.article .a-cat{font-size:11px;font-weight:600;color:var(--malva-dark);letter-spacing:0.18em;text-transform:uppercase;margin-bottom:14px;display:block}
.article h1{font-size:clamp(32px,4.4vw,44px);font-weight:600;letter-spacing:-0.02em;line-height:1.15;margin-bottom:18px}
.article .a-meta{display:flex;gap:18px;align-items:center;font-size:14.5px;color:var(--text-soft);margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--malva-light)}
.article .a-cover{aspect-ratio:16/9;border-radius:16px;margin-bottom:32px;background:linear-gradient(135deg,var(--malva-light),var(--malva-mid))}
.article p{font-size:17px;line-height:1.75;color:var(--text);margin-bottom:18px}
.article h2{font-family:var(--sans);font-size:24px;font-weight:600;letter-spacing:-0.02em;margin:42px 0 14px}
.article h3{font-size:18px;font-weight:600;margin:32px 0 10px}
.article ul,.article ol{margin:8px 0 22px 22px}
.article li{margin-bottom:8px;font-size:16.5px;line-height:1.7;color:var(--text)}
.article blockquote{border-left:3px solid var(--malva);padding:8px 0 8px 22px;margin:28px 0;
  font-family:var(--serif);font-style:italic;font-size:20px;color:var(--malva-dark);line-height:1.5;font-weight:400}
@media (max-width:768px){.article blockquote{font-size:18px}}
.article .pull{background:var(--malva-pale);border-radius:14px;padding:24px 28px;margin:28px 0}
.article .pull strong{color:var(--malva-dark)}
.article .a-end{margin-top:48px;padding:32px;background:var(--text);color:#fff;border-radius:18px;text-align:center}
.article .a-end h3{color:#fff;font-size:22px;margin-bottom:10px}
.article .a-end p{color:rgba(255,255,255,.7);font-size:15px;margin-bottom:18px}

/* nav */
.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  background:rgba(250,248,245,.88);border-bottom:1px solid rgba(139,107,174,.08)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;
  padding:16px 60px;max-width:1440px;margin:0 auto}
.logo{display:flex;align-items:center;gap:8px}
.logo-img{height:42px;width:auto;display:block}
@media (max-width:1024px){.logo-img{height:36px}}
.logo-mark{width:28px;height:28px;border-radius:50%;background:var(--malva);display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:600}
.nav-links{display:flex;align-items:center;gap:32px;font-size:13.5px;font-weight:500;color:var(--text-mid)}
.nav-links a{transition:color .2s ease}
.nav-links a:hover{color:var(--malva-dark)}
.nav-links a.active{color:var(--malva-dark)}
.nav-cta{display:inline-flex;align-items:center;gap:8px;
  padding:11px 22px;border-radius:50px;background:var(--malva);color:#fff !important;
  font-weight:600;font-size:13px;letter-spacing:0.01em;transition:all .25s ease}
.nav-cta:hover{background:var(--malva-dark);transform:translateY(-1px)}
.nav-portal{display:inline-flex;align-items:center;gap:6px;
  font-size:13px;color:var(--malva-dark) !important;font-weight:500;
  padding:12px 16px;border:1px solid var(--malva-light);border-radius:50px;
  transition:all .2s ease;min-height:44px}
.nav-portal:hover{background:var(--malva-pale);border-color:var(--malva-mid)}
.nav-portal.active{background:var(--malva-pale);border-color:var(--malva-mid)}
.mobile-portal-link{margin-top:10px;padding:14px 16px !important;font-size:14px !important;
  color:var(--malva-dark) !important;font-weight:600;background:var(--malva-pale);
  border:1px solid var(--malva-light) !important;border-radius:14px;
  display:flex;justify-content:space-between;align-items:center;gap:10px}
.nav-burger{display:none;width:40px;height:40px;border:none;background:transparent;cursor:pointer}
.nav-burger span{display:block;width:22px;height:2px;background:var(--text);margin:5px auto;transition:.25s;border-radius:2px}
@media (max-width:1024px){.nav-inner{padding:14px 22px}.nav-links{display:none}.nav-burger{display:block}}
.mobile-menu{display:none;position:fixed;top:64px;left:0;right:0;bottom:0;
  height:calc(100dvh - 64px);background:var(--cream);z-index:49;
  padding:24px 22px;flex-direction:column;gap:4px;overflow-y:auto;-webkit-overflow-scrolling:touch}
.mobile-menu.open{display:flex}
.mobile-menu a{padding:14px 0;font-size:18px;font-weight:500;border-bottom:1px solid var(--malva-light)}
.mobile-menu .nav-cta{margin-top:18px;justify-content:center}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 28px;border-radius:50px;
  font-family:var(--sans);font-size:14px;font-weight:600;letter-spacing:0.01em;
  cursor:pointer;border:none;transition:all .25s ease;white-space:nowrap;text-decoration:none}
.btn-primary{background:var(--malva);color:#fff}
.btn-primary:hover{background:var(--malva-dark);transform:translateY(-1px);box-shadow:0 12px 30px rgba(139,107,174,.3)}
.btn-secondary{background:transparent;color:var(--text-mid);padding:14px 0}
.btn-secondary:hover{color:var(--malva-dark)}
.btn-secondary .arrow{transition:transform .25s ease}
.btn-secondary:hover .arrow{transform:translateX(3px)}
.btn-outline-dark{background:transparent;color:var(--text);border:1.5px solid var(--text)}
.btn-outline-dark:hover{background:var(--text);color:#fff}
.btn-outline-light{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.4)}
.btn-outline-light:hover{background:rgba(255,255,255,.1);border-color:#fff}
.btn-cream{background:var(--warm-white);color:var(--malva-dark)}
.btn-cream:hover{transform:translateY(-1px);box-shadow:0 12px 30px rgba(0,0,0,.15)}
.btn-block{width:100%;justify-content:center}

/* section padding */
.section{padding:64px 60px 72px}
@media (max-width:768px){.section{padding:64px 22px}}

/* mobile-only section visibility */
@media (max-width:768px){
  .mobile-hide{display:none!important}
}
.mobile-only{display:none}
@media (max-width:768px){
  .mobile-only{display:block}
}

/* mobile-summary — condensed homepage block shown only on mobile.
   Replaces the long "Modalidades / Cómo funciona / Sobre mí / FAQ /
   Letrados / Evidencia" sections that are hidden on small screens. */
.mobile-summary{padding:36px 22px 16px;background:var(--cream);display:flex;flex-direction:column;gap:20px}
.mobile-summary .ms-card{background:var(--warm-white);border:1px solid var(--malva-light);border-radius:18px;padding:26px 22px}
.mobile-summary .ms-card h3{font-family:var(--sans);font-weight:600;font-size:19px;line-height:1.25;color:var(--text);margin-bottom:14px;letter-spacing:-0.01em}
.mobile-summary .ms-steps{list-style:none;padding:0;margin:0 0 18px}
.mobile-summary .ms-steps li{display:flex;gap:14px;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--malva-pale);font-size:14.5px;color:var(--text);line-height:1.5}
.mobile-summary .ms-steps li:last-child{border-bottom:none}
.mobile-summary .ms-steps li span{flex-shrink:0;font-family:var(--sans);font-weight:600;font-size:11px;color:var(--malva-dark);background:var(--malva-pale);padding:4px 8px;border-radius:6px;letter-spacing:0.06em}
.mobile-summary .ms-about{display:flex;gap:16px;align-items:flex-start}
.mobile-summary .ms-photo{width:80px;height:80px;border-radius:50%;object-fit:cover;object-position:center 18%;flex-shrink:0;border:1px solid var(--malva-light)}
.mobile-summary .ms-bio{font-size:13.5px;color:var(--text-mid);line-height:1.55;margin-bottom:12px}
.mobile-summary .ms-link{display:inline-block;font-size:13px;font-weight:600;color:var(--malva-dark);transition:.2s}
.mobile-summary .ms-link:hover{color:var(--text)}

/* Sticky mobile CTA — siempre visible en móvil para no perder conversión
   en páginas largas. Se oculta cuando un CTA principal (final-cta, cta-row,
   spec-cta, let-form) entra en viewport (lógica en partials.js IntersectionObserver). */
.mobile-cta{display:none}
@media (max-width:768px){
  /* Cuando la página tiene sticky CTA, compensamos con padding-bottom para
     que el último párrafo no quede tapado. body:has() funciona en todos
     los browsers modernos; en los antiguos simplemente no compensa. */
  body:has(.mobile-cta){padding-bottom:88px}
  .mobile-cta{
    display:flex;align-items:center;justify-content:space-between;gap:12px;
    position:fixed;left:12px;right:12px;
    bottom:calc(env(safe-area-inset-bottom,0) + 12px);
    z-index:50;
    background:var(--malva-dark);color:#fff;
    padding:12px 16px 12px 18px;border-radius:14px;
    box-shadow:0 12px 30px rgba(38,24,48,.25);
    text-decoration:none;font-weight:600;font-size:14.5px;
    transform:translateY(0);transition:transform .3s ease,opacity .3s ease
  }
  .mobile-cta.hidden-cta{transform:translateY(140%);opacity:0;pointer-events:none}
  .mobile-cta .mc-label{display:flex;flex-direction:column;line-height:1.2}
  .mobile-cta .mc-sub{font-size:11px;font-weight:400;opacity:.75;margin-top:2px}
  .mobile-cta .mc-arrow{font-size:18px;flex-shrink:0}
}
/* Hide sticky CTA while cookie banner is asking for consent */
body.cb-pending .mobile-cta{display:none}

/* El orden HTML ya es el correcto para mobile: nav → trust → hero → social-proof
   → sobre miriam → modes → especialidades → dark steps → faq → letrados →
   testimonios → final-cta → footer. Sin reordering CSS, que generaba un bug
   con secciones sin `order:` declarado (default 0 < hero order 1) que
   aparecían ANTES del hero — la foto de Sobre Miriam se veía primero. */

/* trust bar */
.trust-bar{background:var(--malva-pale);padding:14px 60px;border-bottom:1px solid var(--malva-light)}
.trust-bar-inner{max-width:1280px;margin:0 auto;display:flex;justify-content:center;gap:36px;flex-wrap:wrap;
  font-size:12px;color:var(--text-mid);font-weight:500}
.trust-bar-inner span{display:inline-flex;align-items:center;gap:8px}
.trust-bar-inner .dot{width:6px;height:6px;border-radius:50%;background:var(--malva)}
@media (max-width:768px){.trust-bar{padding:12px 22px}.trust-bar-inner{gap:14px;font-size:13px}}

/* footer */
footer{background:var(--text);color:rgba(255,255,255,.7);padding:80px 60px 36px}
.f-grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:60px;padding-bottom:50px;border-bottom:1px solid rgba(255,255,255,.1)}
.f-logo{font-family:var(--sans);font-weight:700;font-size:18px;color:#fff;margin-bottom:14px;display:flex;align-items:center;gap:10px}
.f-logo .logo-mark{background:var(--malva-light);color:var(--text)}
.f-tag{font-size:14px;color:rgba(255,255,255,.5);max-width:280px;line-height:1.6}
.f-col h5{font-family:var(--sans);font-weight:600;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:#fff;margin-bottom:18px}
.f-col ul{list-style:none;display:flex;flex-direction:column;gap:10px;font-size:13.5px}
.f-col a{color:rgba(255,255,255,.72);transition:.2s;font-size:14.5px}
.f-col a:hover{color:var(--malva-light)}
.f-bottom{max-width:1280px;margin:30px auto 0;display:flex;justify-content:space-between;font-size:12px;color:rgba(255,255,255,.45);flex-wrap:wrap;gap:14px}
@media (max-width:900px){.f-grid{grid-template-columns:1fr 1fr;gap:36px}}
@media (max-width:560px){.f-grid{grid-template-columns:1fr}footer{padding:60px 22px 32px}}

/* reveal animation — has a CSS fallback so content shows even if JS fails.
   Normal flow: .in is added by IntersectionObserver → transition fades in.
   Fallback: at t=3s, the reveal-fallback animation pops content visible.
   The .in rule cancels the fallback when JS is working. */
.reveal{
  opacity:0;transform:translateY(20px);
  transition:opacity .7s ease,transform .7s ease;
  animation:reveal-fallback 0s 3s forwards
}
@media (max-width:768px){.reveal{transform:translateY(12px)}}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1 !important;transform:none !important;animation:none !important}}
@keyframes reveal-fallback{to{opacity:1;transform:none}}
.reveal.in{opacity:1;transform:none;animation:none}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none!important;animation:none!important}
}

/* FAQ button reset (semantic <button> for a11y).
   Padding 14px vertical para llegar al mínimo WCAG 44px de área de toque. */
button.faq-q{
  width:100%;background:transparent;border:none;font:inherit;color:inherit;
  text-align:left;padding:14px 0;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  font-size:16px;font-weight:600;color:var(--text);transition:.2s
}
button.faq-q:hover{color:var(--malva-dark)}
button.faq-q:focus-visible{outline:2px solid var(--malva);outline-offset:4px;border-radius:4px}

/* generic page hero */
.page-hero{padding:80px 60px 60px;background:var(--cream)}
.page-hero-inner{max-width:880px;margin:0 auto}
.page-hero h1{margin:18px 0 22px}
.page-hero .body-lg{max-width:680px}
@media (max-width:768px){.page-hero{padding:48px 22px 36px}}

/* breadcrumb */
.breadcrumb{font-size:13px;color:var(--text-soft);margin-bottom:8px;font-weight:500;letter-spacing:0.04em}
.breadcrumb a{color:var(--malva-dark)}
.breadcrumb a:hover{text-decoration:underline}

/* cards */
.card{position:relative;background:var(--warm-white);border:1px solid var(--malva-light);
  border-radius:20px;padding:32px 28px;overflow:hidden;transition:all .3s ease}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--malva-mid)}
.card .accent{width:36px;height:3px;background:var(--malva);border-radius:2px;margin-bottom:20px}
.card h3{margin-bottom:12px;color:var(--text)}
.card .body{font-size:14.5px;line-height:1.6}

/* form fields */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.field label{font-size:12px;font-weight:600;color:var(--text);letter-spacing:0.02em}
.field label .opt{color:var(--text-soft);font-weight:400;text-transform:none;letter-spacing:0}
.field input,.field textarea,.field select{
  font-family:var(--sans);font-size:15px;padding:13px 16px;border:1px solid var(--malva-light);
  border-radius:12px;background:var(--warm-white);color:var(--text);outline:none;transition:.2s;
  font-weight:400}
/* iOS hace zoom al enfocar inputs <16px. En mobile fijamos 16px mínimo. */
@media (max-width:768px){
  .field input,.field textarea,.field select{font-size:16px}
  .cf-card input,.cf-card select,.cf-card textarea{font-size:16px !important}
  .let-form input,.let-form select,.let-form textarea{font-size:16px !important}
}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--malva);box-shadow:0 0 0 3px var(--malva-pale)}
.field textarea{resize:vertical;min-height:90px;font-family:var(--sans)}
.checkbox-row{display:flex;gap:12px;align-items:flex-start;font-size:13px;color:var(--text-mid);margin-bottom:12px;line-height:1.5}
.checkbox-row input{margin-top:3px;accent-color:var(--malva)}
.checkbox-row a{color:var(--malva-dark);text-decoration:underline}

/* Recordatorios opcionales (toggle-style, sin densidad de consentimientos) */
.notif-opts{margin-top:18px;padding:16px 18px;border:1px dashed var(--malva-light);border-radius:12px;background:var(--cream)}
.notif-opts-title{display:block;font-size:11px;font-weight:600;color:var(--text-soft);letter-spacing:0.14em;text-transform:uppercase;margin-bottom:10px}
.notif-toggle{display:flex;gap:10px;align-items:center;padding:8px 0;font-size:13.5px;color:var(--text-mid);cursor:pointer}
.notif-toggle input{accent-color:var(--malva);flex-shrink:0;width:16px;height:16px}
.notif-toggle .nt-label{line-height:1.45}
.notif-help{font-size:11.5px;color:var(--text-soft);margin:8px 2px 0;line-height:1.5}

/* Pricing strip — bloque de tarifas mini en home */
.pricing-strip{background:var(--cream);padding:80px 60px}
@media(max-width:768px){.pricing-strip{padding:60px 22px}}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1080px;margin:0 auto}
@media(max-width:900px){.pricing-grid{grid-template-columns:1fr;max-width:480px}}
.pricing-card{background:#fff;border:1px solid var(--malva-light);border-radius:16px;padding:30px 28px;display:flex;flex-direction:column;gap:8px;position:relative;transition:transform .2s,box-shadow .2s}
.pricing-card:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(155,138,171,.12)}
.pricing-card.featured{border:2px solid var(--malva-dark);background:linear-gradient(180deg,#fff 0%,var(--malva-pale) 100%)}
.pricing-card .pc-tag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--malva-dark);color:#fff;font-size:11px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;padding:5px 12px;border-radius:12px;white-space:nowrap}
.pricing-card .pc-label{font-size:12px;color:var(--text-soft);text-transform:uppercase;letter-spacing:0.12em;font-weight:600;margin-bottom:4px}
.pricing-card .pc-price{display:flex;align-items:baseline;gap:5px;margin:8px 0 4px}
.pricing-card .pc-price .num{font-family:Fraunces,serif;font-size:46px;font-weight:400;color:var(--text);line-height:1}
.pricing-card .pc-price .cur{font-size:20px;color:var(--text-soft)}
.pricing-card .pc-meta{font-size:13px;color:var(--text-soft);margin:0 0 14px}
.pricing-card .pc-link{font-size:14px;font-weight:500;color:var(--malva-dark);text-decoration:none;margin-top:auto;border-bottom:1px solid var(--malva-light);padding-bottom:2px;display:inline-block;align-self:flex-start}
.pricing-card .pc-link:hover{border-color:var(--malva-dark)}
.pricing-foot{text-align:center;font-size:13px;color:var(--text-soft);margin:32px auto 0;max-width:680px}

/* Newsletter strip — solo en blog posts (partials.js data-newsletter="true") */
.newsletter-strip{background:var(--malva-pale);padding:64px 22px;border-top:1px solid var(--malva-light)}
.newsletter-strip .ns-inner{max-width:880px;margin:0 auto;display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:center}
@media(max-width:760px){.newsletter-strip .ns-inner{grid-template-columns:1fr;gap:28px}}
.newsletter-strip h3{font-family:Fraunces,serif;font-size:26px;color:var(--text);margin:0 0 10px;line-height:1.25;font-weight:400}
.newsletter-strip .ns-text p{font-size:14.5px;color:var(--text-mid);line-height:1.6;margin:0}
.ns-form{background:#fff;border:1px solid var(--malva-light);border-radius:14px;padding:20px 22px}
.ns-row{display:flex;gap:10px;margin-bottom:12px}
@media(max-width:480px){.ns-row{flex-direction:column}}
.ns-row input[type="email"]{flex:1;font-family:var(--sans);font-size:15px;padding:12px 14px;border:1px solid var(--malva-light);border-radius:10px;background:var(--warm-white);color:var(--text);outline:none}
.ns-row input[type="email"]:focus{border-color:var(--malva-dark);box-shadow:0 0 0 3px var(--malva-pale)}
.ns-row button{background:var(--malva-dark);color:#fff;border:0;padding:12px 22px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;transition:.2s}
.ns-row button:hover{background:var(--text)}
.ns-row button:disabled{opacity:.6;cursor:wait}
.ns-consent{display:flex;gap:10px;align-items:flex-start;font-size:12.5px;color:var(--text-soft);line-height:1.5}
.ns-consent input{margin-top:3px;accent-color:var(--malva-dark);flex-shrink:0}
.ns-consent a{color:var(--malva-dark);text-decoration:underline}
.ns-status{margin:12px 0 0;font-size:13px;line-height:1.5}
