/*!
 * Chibalete Editores - main.css
 * Extraido VERBATIM del <style> de chibalete-editores-home.html (diseno aprobado).
 * No reescribir ni reemplazar por framework. Ajustes de rutas WordPress documentados en README.
 */

:root{
    --paper:#FFFFFF;
    --paper-2:#F3F2EE;
    --ink:#141414;
    --ink-2:#6A6A66;
    --red:#E52521;
    --red-2:#C21B17;
    --mute-light:#BDBDB8;
    --line:rgba(20,20,20,.16);
    --font-display:'Bricolage Grotesque',sans-serif;
    --font-ui:'Space Grotesk',sans-serif;
    --font-mono:'Space Mono',monospace;
    --maxw:1200px;
    --pad:clamp(1.25rem,4vw,3.5rem);
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    background:var(--paper);
    color:var(--ink);
    font-family:var(--font-ui);
    font-size:16px;
    line-height:1.5;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}
  .wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
  .eyebrow{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2)}

  /* ---------- header ---------- */
  header{position:sticky;top:0;z-index:50;background:var(--paper);border-bottom:1px solid var(--line)}
  .nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding-top:.7rem;padding-bottom:.7rem}
  .brand{display:flex;align-items:center;gap:.6rem}
  .brand__icon{height:42px;width:auto}
  .brand__txt{display:flex;flex-direction:column;line-height:.86}
  .brand__txt b{font-family:var(--font-display);font-weight:800;font-size:1.3rem;letter-spacing:-.03em}
  .brand__txt i{font-style:normal;font-family:var(--font-mono);font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2)}
  .menu{display:flex;gap:1.6rem;align-items:center}
  .menu a{font-size:.92rem;font-weight:500;position:relative;padding:.15rem 0}
  .menu a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--red);transition:width .22s ease}
  .menu a:hover::after,.menu a:focus-visible::after{width:100%}
  .nav__tools{display:flex;gap:1rem;align-items:center}
  .nav__tools button{background:none;border:0;cursor:pointer;color:var(--ink);font-size:1.1rem;line-height:1;display:grid;place-items:center}
  .burger{display:none}

  /* ---------- hero ---------- */
  .hero{padding-top:clamp(2.5rem,6vw,5rem);padding-bottom:clamp(2.5rem,6vw,5rem)}
  .hero__grid{display:grid;grid-template-columns:1.55fr 1fr;gap:clamp(1.5rem,4vw,4rem);align-items:end}
  .hero h1{
    font-family:var(--font-display);
    font-weight:700;
    font-size:clamp(3rem,9.5vw,7.4rem);
    line-height:.92;
    letter-spacing:-.035em;
    text-wrap:balance;
  }
  .hero h1 .accent{color:var(--red)}
  .hero__lead{margin-top:1.6rem;max-width:34ch;font-size:1.05rem;color:var(--ink-2);line-height:1.55}
  .hero__cta{margin-top:1.6rem;display:inline-flex;align-items:center;gap:.6rem;background:var(--ink);color:var(--paper);font-weight:600;font-size:.92rem;padding:.85rem 1.4rem}
  .hero__cta span{transition:transform .2s ease}
  .hero__cta:hover span{transform:translateX(4px)}

  /* featured book + sticker */
  .feat{position:relative;align-self:stretch}
  .feat__cover{background:var(--paper-2);border:1px solid var(--ink);aspect-ratio:3/4;padding:1.4rem;display:flex;flex-direction:column;justify-content:space-between}
  .feat__cover .kicker{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-2)}
  .feat__cover .title{font-family:var(--font-display);font-weight:500;font-size:clamp(1.7rem,3.5vw,2.4rem);line-height:1.02;letter-spacing:-.02em}
  .feat__cover .by{font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-2)}
  .sticker{
    position:absolute;left:-2.2rem;top:1.4rem;transform:rotate(-5deg);
    background:var(--red);color:#fff;padding:.85rem 1rem;
    box-shadow:3px 4px 0 var(--ink);min-width:215px;
  }
  .sticker h4{font-family:var(--font-mono);font-weight:700;font-size:.74rem;letter-spacing:.05em;border-bottom:1px solid rgba(255,255,255,.5);padding-bottom:.45rem;margin-bottom:.5rem}
  .sticker dl{display:grid;grid-template-columns:auto 1fr;gap:.18rem .6rem;font-family:var(--font-mono);font-size:.64rem;text-transform:uppercase;letter-spacing:.03em}
  .sticker dt{opacity:.8}
  .sticker dd{font-weight:700}

  /* ---------- section frame ---------- */
  .sec{padding-top:clamp(3rem,7vw,5.5rem);padding-bottom:clamp(3rem,7vw,5.5rem);border-top:1px solid var(--line)}
  .sec__head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:2rem}
  .sec__head h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.9rem,5vw,3.2rem);letter-spacing:-.03em;line-height:1}
  .sec__head a{font-family:var(--font-mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;color:var(--red);white-space:nowrap}
  .sec__head a:hover{text-decoration:underline}

  /* ---------- novedades ---------- */
  .books{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
  .book{cursor:pointer}
  .book__cover{background:var(--paper-2);border:1px solid var(--ink);aspect-ratio:3/4;padding:1rem;display:flex;flex-direction:column;justify-content:space-between;transition:transform .25s ease, box-shadow .25s ease}
  .book:hover .book__cover{transform:translate(-3px,-3px);box-shadow:5px 5px 0 var(--red)}
  .book__no{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.05em;color:var(--ink-2)}
  .book__title{font-family:var(--font-display);font-weight:500;font-size:1.18rem;line-height:1.04;letter-spacing:-.01em}
  .book__meta{margin-top:.75rem;display:flex;justify-content:space-between;align-items:baseline;gap:.5rem}
  .book__author{font-size:.84rem;color:var(--ink-2)}
  .tag{font-family:var(--font-mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.05em;border:1px solid var(--ink);padding:.18rem .4rem;white-space:nowrap}

  /* ---------- colecciones ---------- */
  .coll{border-top:1px solid var(--ink)}
  .coll__row{position:relative;display:grid;grid-template-columns:3.2rem 1fr 1.4fr auto;gap:1.5rem;align-items:baseline;padding:1.4rem 0;border-bottom:1px solid var(--line);transition:padding-left .2s ease,color .2s ease}
  .coll__row:hover{padding-left:1rem;color:var(--red)}
  .coll__no{font-family:var(--font-mono);font-size:.78rem;color:var(--ink-2)}
  .coll__name{font-family:var(--font-display);font-weight:500;font-size:clamp(1.4rem,3vw,2rem);letter-spacing:-.02em;line-height:1}
  .coll__def{font-size:.95rem;color:var(--ink-2);line-height:1.4}
  .coll__row:hover .coll__def{color:var(--red)}
  .coll__count{font-family:var(--font-mono);font-size:.74rem;color:var(--ink-2);white-space:nowrap}

  /* ---------- manifesto ---------- */
  .manifesto{background:var(--ink);color:#fff;border:0}
  .manifesto .eyebrow{color:var(--mute-light)}
  .manifesto h2{font-family:var(--font-display);font-weight:700;font-size:clamp(2rem,6.5vw,4.6rem);line-height:.98;letter-spacing:-.03em;max-width:18ch;margin:1.2rem 0 2.5rem}
  .manifesto h2 em{font-style:italic;color:var(--red)}
  .stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;border-top:1px solid rgba(255,255,255,.25);padding-top:2rem}
  .stat .n{font-family:var(--font-display);font-weight:700;font-size:clamp(2rem,5vw,3.4rem);letter-spacing:-.02em;line-height:1}
  .stat .l{font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--mute-light);margin-top:.4rem}

  /* ---------- plataformas ---------- */
  .plat{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
  .platcard{border:1px solid var(--ink);padding:1.6rem;display:flex;flex-direction:column;min-height:230px;transition:background .2s ease,color .2s ease}
  .platcard:hover{background:var(--ink);color:#fff}
  .platcard .pk{font-family:var(--font-mono);font-size:.66rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-2)}
  .platcard:hover .pk{color:var(--red)}
  .platcard h3{font-family:var(--font-display);font-weight:700;font-size:clamp(1.8rem,4vw,2.6rem);letter-spacing:-.02em;margin:.4rem 0 .7rem;line-height:1}
  .platcard p{color:var(--ink-2);max-width:30ch;line-height:1.5}
  .platcard:hover p{color:var(--mute-light)}
  .platcard .go{margin-top:auto;font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;display:inline-flex;align-items:center;gap:.5rem}

  /* ---------- servicios ---------- */
  .serv{display:grid;grid-template-columns:1fr 1fr;gap:0 3rem}
  .serv__item{display:grid;grid-template-columns:2.6rem 1fr;gap:1rem;align-items:baseline;padding:1rem 0;border-bottom:1px solid var(--line)}
  .serv__item .sn{font-family:var(--font-mono);font-size:.74rem;color:var(--red)}
  .serv__item .st{font-family:var(--font-display);font-weight:500;font-size:1.25rem;letter-spacing:-.01em}
  .serv__item .sd{display:block;font-family:var(--font-ui);font-weight:400;font-size:.86rem;color:var(--ink-2);margin-top:.2rem;letter-spacing:0}

  /* ---------- footer ---------- */
  footer{background:var(--paper);color:var(--ink);border-top:1px solid var(--ink);padding-top:clamp(3rem,6vw,4.5rem);padding-bottom:2rem}
  .foot__top{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:2rem}
  .foot__logo{width:190px;height:auto;margin-bottom:.4rem}
  .foot__brand p{color:var(--ink-2);max-width:26ch;font-size:.9rem;line-height:1.5}
  .foot__news{margin-top:1.5rem;display:flex;border:1px solid var(--ink)}
  .foot__news input{flex:1;background:none;border:0;color:var(--ink);font-family:var(--font-ui);font-size:.85rem;padding:.7rem .8rem}
  .foot__news input::placeholder{color:#9a978f}
  .foot__news button{background:var(--red);border:0;color:#fff;font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;font-weight:700;padding:0 1rem;cursor:pointer}
  .foot__news button:hover{background:var(--red-2)}
  .foot__col h5{font-family:var(--font-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:var(--red);margin-bottom:1rem}
  .foot__col a{display:block;font-size:.88rem;color:var(--ink-2);padding:.32rem 0}
  .foot__col a:hover{color:var(--ink)}
  .foot__bar{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-top:3rem;padding-top:1.4rem;border-top:1px solid var(--line);font-family:var(--font-mono);font-size:.66rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-2)}

  /* ---------- reveal (progressive enhancement: estado oculto solo con JS) ---------- */
  html.js .reveal{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease,ease),transform .6s var(--ease,ease)}
  .reveal.in{opacity:1;transform:none}

  /* ---------- responsive ---------- */
  @media(max-width:880px){
    .menu,.nav__tools .search{display:none}
    .burger{display:grid}
    .hero__grid{grid-template-columns:1fr}
    .feat{max-width:340px}
    .sticker{left:auto;right:0;top:-1rem}
    .books{grid-template-columns:repeat(2,1fr)}
    .coll__row{grid-template-columns:2.4rem 1fr;row-gap:.4rem}
    .coll__def,.coll__count{grid-column:2}
    .stats{grid-template-columns:repeat(2,1fr)}
    .plat,.serv{grid-template-columns:1fr}
    .serv{gap:0}
    .foot__top{grid-template-columns:1fr 1fr}
  }
  @media(max-width:520px){
    .books{grid-template-columns:1fr}
    .foot__top{grid-template-columns:1fr}
  }
  @media(prefers-reduced-motion:reduce){
    *{animation:none!important;transition:none!important}
    html.js .reveal,html.js .stagger>*,html.js .hero .line__in,html.js .hero .hero-in,html.js .hero-sticker{opacity:1!important;transform:none!important}
  }
  :focus-visible{outline:2px solid var(--red);outline-offset:3px}
  .manifesto :focus-visible{outline-color:#fff}

  /* ============================================================
     Motion layer (Fase 8.1) — sobrio; solo transform/opacity; PE bajo html.js.
     ============================================================ */
  :root{--ease:cubic-bezier(.16,1,.3,1)}

  /* Motion 1 — Hero line reveal (titulo en lineas enmascaradas) + entrada de eyebrow/lead/cta */
  .hero__title-lines{display:block}
  .hero .line{display:block;overflow:hidden;padding-bottom:.12em;margin-bottom:-.1em}
  html.js .hero .line__in{display:block;opacity:0;transform:translateY(110%)}
  html.js .hero.hero-ready .line__in{opacity:1;transform:none;transition:opacity .85s var(--ease),transform .85s var(--ease);transition-delay:calc(var(--d,0)*.08s)}
  html.js .hero .hero-in{opacity:0;transform:translateY(14px)}
  html.js .hero.hero-ready .hero-in{opacity:1;transform:none;transition:opacity .7s var(--ease),transform .7s var(--ease);transition-delay:calc(var(--d,0)*.08s)}

  /* Motion 2 — Sticker stamp */
  html.js .hero-sticker{opacity:0}
  html.js .hero.hero-ready .hero-sticker{animation:chib-stamp .5s var(--ease) .55s forwards}
  @keyframes chib-stamp{0%{opacity:0;transform:scale(1.18)}60%{opacity:1}100%{opacity:1;transform:scale(1)}}

  /* Motion 4 — Staggered reveal (hijos del contenedor .stagger) */
  html.js .stagger>*{opacity:0;transform:translateY(16px)}
  html.js .stagger.in>*{opacity:1;transform:none;transition:opacity .55s var(--ease),transform .55s var(--ease)}
  html.js .stagger.in>*:nth-child(2){transition-delay:.06s}
  html.js .stagger.in>*:nth-child(3){transition-delay:.12s}
  html.js .stagger.in>*:nth-child(4){transition-delay:.18s}
  html.js .stagger.in>*:nth-child(5){transition-delay:.24s}
  html.js .stagger.in>*:nth-child(6){transition-delay:.30s}

  /* Motion 5 — Hover marker en collection-row (barra roja que crece) */
  .coll__row::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--red);transform:scaleY(0);transform-origin:bottom;transition:transform .25s var(--ease)}
  .coll__row:hover::before,.coll__row:focus-visible::before{transform:scaleY(1)}

  /* ---------- menu movil (anadido en Fase 5.1; ajuste minimo, no del diseno original) ---------- */
  @media(max-width:880px){
    .nav{position:relative}
    .menu.is-open{
      display:flex;flex-direction:column;gap:1.1rem;
      position:absolute;top:100%;left:0;right:0;z-index:60;
      background:var(--paper);padding:1.25rem clamp(1.25rem,4vw,3.5rem);
      border-top:1px solid var(--line);box-shadow:0 16px 40px rgba(20,20,20,.08)
    }
  }

  /* ============================================================
     WooCommerce catalog (Fase 5.2) — coherente con tokens del diseno.
     No altera estilos previos; solo anade clases nuevas y de WooCommerce.
     ============================================================ */
  .page-head{margin-bottom:2.5rem;max-width:62ch}
  .page-head h1{font-family:var(--font-display);font-weight:700;font-size:clamp(2rem,5vw,3.4rem);letter-spacing:-.03em;line-height:1.02}
  .page-head__desc{margin-top:1rem;color:var(--ink-2);font-size:1.05rem;line-height:1.55}
  .page-head__count{margin-top:.6rem;font-family:var(--font-mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-2)}

  /* chips de colecciones + ordenamiento */
  .catalog__cats{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}
  .catalog__cats .tag:hover{background:var(--ink);color:var(--paper)}
  .catalog__tools{display:flex;justify-content:flex-end;margin-bottom:1.5rem}
  .catalog__tools select,.woocommerce-ordering select{font-family:var(--font-mono);font-size:.8rem;padding:.5rem .7rem;border:1px solid var(--ink);background:var(--paper);color:var(--ink)}

  /* portada como imagen + badges + precio en la card */
  .book__cover{background-size:cover;background-position:center;position:relative}
  .book__badges{position:absolute;top:.6rem;left:.6rem;display:flex;flex-direction:column;gap:.3rem;z-index:2}
  .book__badge{font-family:var(--font-mono);font-size:.56rem;text-transform:uppercase;letter-spacing:.05em;background:var(--red);color:#fff;padding:.2rem .45rem}
  .book__price{margin-top:.4rem;font-family:var(--font-mono);font-size:.9rem;font-weight:700}
  .book__price del{color:var(--ink-2);font-weight:400;margin-right:.4rem}
  .book__price ins{text-decoration:none}

  /* ficha de producto */
  .product-single__top{display:grid;grid-template-columns:minmax(0,42%) 1fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:start}
  .product-single__media img{width:100%;border:1px solid var(--ink)}
  .product-single__media .flex-control-thumbs{display:flex;gap:.5rem;list-style:none;padding:0;margin:.6rem 0 0}
  .product-single__media .flex-control-thumbs img{cursor:pointer}
  .product-single__title{font-family:var(--font-display);font-weight:700;font-size:clamp(2rem,4.5vw,3rem);letter-spacing:-.03em;line-height:1.02;margin-top:.4rem}
  .product-single__author{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;font-size:.8rem;color:var(--ink-2);margin-top:.6rem}
  .product-single__badges{margin-top:.8rem;display:flex;gap:.4rem}
  .product-single__price{margin-top:1.2rem;font-family:var(--font-display);font-size:1.6rem;font-weight:700}
  .product-single__short{margin-top:1rem;color:var(--ink-2);line-height:1.6}
  .product-single__cart{margin-top:1.4rem}
  .product-single__body{margin-top:clamp(2.5rem,6vw,4.5rem);display:grid;grid-template-columns:1fr 320px;gap:clamp(1.5rem,4vw,3rem);align-items:start}
  .product-single__desc{line-height:1.7}
  .product-single__desc h2{font-family:var(--font-display);font-weight:700;font-size:1.5rem;margin:1.8rem 0 .8rem;letter-spacing:-.02em}
  .product-single__desc p{margin-bottom:1rem}
  .product-single__topics,.product-single__peda{margin-top:2rem}
  .product-single__topics{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}

  /* ficha bibliografica (sticker variante neutra, posicion estatica) */
  .sticker--meta{position:static;background:var(--ink);color:#fff;box-shadow:3px 4px 0 var(--red);min-width:0;padding:1.1rem 1.2rem}
  .sticker--meta h4{border-bottom-color:rgba(255,255,255,.4)}
  .sticker--meta dl{font-size:.66rem}
  .sticker__topics{margin-top:.8rem;display:flex;flex-wrap:wrap;gap:.35rem}
  .tag--light{border-color:rgba(255,255,255,.5);color:#fff;font-size:.56rem}

  /* botones / notices / cantidad WooCommerce */
  .button,.single_add_to_cart_button,.product-single__cart .button{display:inline-flex;align-items:center;gap:.5rem;background:var(--ink);color:var(--paper);font-family:var(--font-ui);font-weight:600;font-size:.92rem;padding:.85rem 1.4rem;border:0;cursor:pointer;transition:background .2s ease}
  .button:hover,.single_add_to_cart_button:hover,.button:focus-visible{background:var(--red);color:#fff}
  .cart{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem}
  .quantity input{width:4rem;padding:.6rem;border:1px solid var(--ink);font-family:var(--font-mono);text-align:center}
  .woocommerce-message,.woocommerce-info,.woocommerce-error,.notice{border:1px solid var(--ink);padding:1rem 1.2rem;margin-bottom:1.5rem;font-size:.95rem;list-style:none}
  .woocommerce-message{border-left:4px solid var(--red)}
  .notice--soldout,.notice--empty,.notice--info{color:var(--ink-2)}

  /* paginacion */
  .woocommerce-pagination{margin-top:2.5rem;font-family:var(--font-mono)}
  .woocommerce-pagination ul{display:flex;gap:.4rem;list-style:none;flex-wrap:wrap;padding:0}
  .woocommerce-pagination a,.woocommerce-pagination span{display:grid;place-items:center;min-width:2.4rem;height:2.4rem;border:1px solid var(--line);padding:0 .5rem}
  .woocommerce-pagination .current{background:var(--ink);color:var(--paper);border-color:var(--ink)}

  /* listados WooCommerce por defecto (relacionados / cross-sells) */
  .collection__nav{margin-top:3rem;display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;border-top:1px solid var(--line);padding-top:1.5rem}
  ul.products{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;padding:0;margin-top:1.5rem}
  ul.products li.product img{border:1px solid var(--ink);margin-bottom:.6rem}
  ul.products li.product .woocommerce-loop-product__title{font-family:var(--font-display);font-size:1.05rem;font-weight:500;line-height:1.1}
  ul.products li.product .price{font-family:var(--font-mono);font-size:.85rem;display:block;margin:.3rem 0 .6rem}
  .related>h2,.up-sells>h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.6rem,4vw,2.4rem);letter-spacing:-.02em;margin-bottom:1rem}

  @media(max-width:880px){
    .product-single__top{grid-template-columns:1fr}
    .product-single__body{grid-template-columns:1fr}
    ul.products{grid-template-columns:repeat(2,1fr)}
  }
  @media(max-width:520px){
    ul.products{grid-template-columns:1fr}
  }

  /* ===== Páginas institucionales y hubs (Fase 8) ===== */
  .page .page-head{margin-bottom:2rem}
  .prose{max-width:72ch;line-height:1.7}
  .prose .lead{font-size:1.18rem;color:var(--ink);line-height:1.5;margin-bottom:1.4rem}
  .prose h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.5rem,3.5vw,2.1rem);letter-spacing:-.02em;margin:2rem 0 .8rem}
  .prose h3{font-family:var(--font-display);font-weight:600;font-size:1.18rem;margin:1.4rem 0 .5rem}
  .prose p{margin-bottom:1rem}
  .prose ul{margin:0 0 1rem 1.2rem}
  .prose li{margin-bottom:.4rem}
  .prose a{color:var(--red);text-decoration:underline;text-underline-offset:2px}
  .prose strong{font-weight:700}
  .prose .note{color:var(--ink-2);font-size:.9rem}
  .prose .serv{margin:1.4rem 0}
  .hub-cta{margin:1.8rem 0;display:flex;align-items:center;gap:1rem;flex-wrap:wrap;color:var(--ink-2)}
  .hub-faq{margin-top:2.5rem;border-top:1px solid var(--line);padding-top:1.5rem}
  .hub-faq h2{margin-top:0}
  .hub-faq__item{margin-bottom:1.2rem}
  .hub-faq__item h3{margin:0 0 .3rem;font-size:1.05rem}
  .foot__legal{display:inline-flex;gap:1rem;flex-wrap:wrap}
  .foot__legal a{color:inherit;text-decoration:none}
  .foot__legal a:hover{color:var(--red)}
  .foot__social{display:flex;gap:1rem;margin-top:1rem;font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em}
  .foot__social a{color:var(--ink-2)}
  .foot__social a:hover,.foot__social a:focus-visible{color:var(--red)}
