/* ================================================================
       SIMÓN DICE — v5 · menú CSS-only · iconos grandes · botones planos
       ================================================================ */
    :root {
      --sd-magenta:    #FF00BB;
      --sd-magenta-2:  #FF4FCB;
      --sd-magenta-3:  #C70094;
      --sd-violet:     #9F0EED;
      --sd-violet-2:   #7E0BC0;
      --sd-pink-soft:  #FFD8F1;
      --sd-pink-bg:    #FFF0FA;
      --sd-black:      #0A0A0A;
      --sd-night:      #14081D;
      --sd-gray-900:   #1C1C1C;
      --sd-gray-700:   #3A3A3A;
      --sd-gray-500:   #6B6B6B;
      --sd-gray-300:   #C7C3CD;
      --sd-gray-200:   #E8E8E8;
      --sd-gray-50:    #FAFAFA;
      --sd-cream:      #FAFAFA;
      --sd-white:      #FFFFFF;

      --grad-magenta: linear-gradient(180deg, #FF4FCB 0%, #FF00BB 60%, #C70094 100%);
      --grad-hero: linear-gradient(180deg, rgba(10,5,15,.5) 0%, rgba(10,5,15,.78) 100%);

      --shadow-flat:   0 10px 28px -10px rgba(255,0,187,.55);
      --shadow-violet: 0 10px 28px -10px rgba(159,14,237,.55);
      --shadow-md:     0 12px 32px -10px rgba(255,0,187,.45);
      --shadow-lg:     0 24px 56px -16px rgba(10,10,10,.5);

      --r-sm: 10px;
      --r-md: 18px;
      --r-lg: 28px;

      --t-xs:  clamp(0.75rem, 0.72rem + 0.15vw, 0.82rem);
      --t-sm:  clamp(0.875rem, 0.84rem + 0.2vw, 0.95rem);
      --t-md:  clamp(1rem, 0.96rem + 0.3vw, 1.125rem);
      --t-lg:  clamp(1.15rem, 1.05rem + 0.5vw, 1.45rem);
      --t-xl:  clamp(1.6rem, 1.3rem + 1.5vw, 2.5rem);
      --t-2xl: clamp(2.25rem, 1.7rem + 2.8vw, 4rem);
      --t-3xl: clamp(2.75rem, 2rem + 4vw, 5.5rem);
      --t-4xl: clamp(3rem, 2.2rem + 5.5vw, 6.5rem);

      --container: 1240px;
      --pad: clamp(1rem, 4vw, 2rem);
    }

    *, *::before, *::after { box-sizing: border-box; }
    html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
    body {
      margin: 0;
      font-family: 'DM Sans', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
      font-size: var(--t-md);
      line-height: 1.65;
      color: var(--sd-gray-900);
      background: var(--sd-night);
      -webkit-font-smoothing: antialiased;
      text-rendering: optimizeLegibility;
      overflow-x: hidden;
    }
    img, picture, svg, video { display: block; max-width: 100%; height: auto; }
    a { color: inherit; text-decoration: none; }
    button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; }
    ::selection { background: var(--sd-magenta); color: #fff; }

    .leckerli { font-family: 'Leckerli One', cursive; letter-spacing: -.005em; }

    h1, h2, h3 {
      font-family: 'Covered By Your Grace', cursive;
      font-weight: 400;
      line-height: 1.05;
      margin: 0 0 .35em;
    }
    h1 { font-size: var(--t-4xl); }
    h2 { font-size: var(--t-3xl); }
    h3 { font-size: var(--t-xl); }
    p  { margin: 0 0 1em; }

    .container {
      width: 100%;
      max-width: var(--container);
      margin-inline: auto;
      padding-inline: var(--pad);
    }

    /* Reveal */
    .reveal {
      opacity: 0;
      transform: translateY(30px) scale(.985);
      filter: blur(3px);
      transition: opacity .85s cubic-bezier(.2,.7,.2,1),
                  transform .85s cubic-bezier(.2,.7,.2,1),
                  filter .85s cubic-bezier(.2,.7,.2,1);
      will-change: transform, opacity;
    }
    .reveal.is-visible { opacity: 1; transform: none; filter: blur(0); }
    .reveal[data-delay="100"] { transition-delay: .1s; }
    .reveal[data-delay="200"] { transition-delay: .2s; }
    .reveal[data-delay="300"] { transition-delay: .3s; }
    .reveal[data-delay="400"] { transition-delay: .4s; }
    .reveal[data-delay="500"] { transition-delay: .5s; }

    @media (prefers-reduced-motion: reduce) {
      html { scroll-behavior: auto; }
      .reveal { opacity: 1; transform: none; transition: none; filter: none; }
      .marquee__track, .call-fab, .hero__eyebrow::before, .pick-card__icon::before { animation: none !important; }
      *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
    }

    /* ================================================================
       BOTONES — color plano, sin gradiente
       ================================================================ */
    .btn {
      display: inline-flex; align-items: center; justify-content: center;
      gap: .55rem;
      padding: 1rem 1.6rem;
      border-radius: 999px;
      font-family: 'DM Sans', sans-serif;
      font-weight: 600;
      font-size: var(--t-md);
      transition: transform .25s ease, box-shadow .25s ease, background .2s ease;
      min-height: 50px;
      will-change: transform;
      position: relative; overflow: hidden;
      isolation: isolate;
      letter-spacing: .005em;
    }
    .btn::before {
      content: ""; position: absolute; inset: 0;
      background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.28) 50%, transparent 70%);
      transform: translateX(-110%);
      transition: transform .65s ease;
      z-index: -1;
    }
    .btn:hover::before { transform: translateX(110%); }

    .btn--magenta {
      color: #fff;
      background: var(--sd-magenta);
      box-shadow: var(--shadow-flat);
    }
    .btn--magenta:hover { background: #ff1ac5; transform: translateY(-3px); box-shadow: 0 14px 32px -10px rgba(255,0,187,.7); }
    .btn--magenta:active { transform: translateY(-1px); }

    .btn--violet {
      color: #fff;
      background: var(--sd-violet);
      box-shadow: var(--shadow-violet);
    }
    .btn--violet:hover { background: #ad1ff0; transform: translateY(-3px); }

    .btn--ghost {
      color: #fff;
      border: 2px solid rgba(255,255,255,.55);
      background: rgba(255,255,255,.05);
      backdrop-filter: blur(8px);
    }
    .btn--ghost:hover { background: rgba(255,255,255,.15); border-color: #fff; transform: translateY(-2px); }

    .btn--dark { color: #fff; background: var(--sd-black); }
    .btn--dark:hover { background: var(--sd-magenta); transform: translateY(-2px); }

    .btn--lg { padding: 1.2rem 2rem; font-size: var(--t-lg); min-height: 60px; }

    .skip-link {
      position: absolute; top: -100px; left: 0;
      padding: .75rem 1rem;
      background: var(--sd-magenta); color: #fff;
      z-index: 999; font-weight: 600;
    }
    .skip-link:focus { top: 0; }

    /* ================================================================
       MENÚ CSS-only — checkbox + label, funciona sin JS
       ================================================================ */
    .nav-input {
      position: absolute;
      width: 1px; height: 1px;
      opacity: 0; pointer-events: none;
      overflow: hidden;
    }
    .nav-input:focus-visible + * .nav-toggle {
      outline: 3px solid var(--sd-magenta); outline-offset: 3px;
    }

    .site-header {
      position: sticky; top: 0; z-index: 80;
      background: rgba(10,5,15,.92);
      box-shadow: 0 1px 0 rgba(255,0,187,.18);
      isolation: isolate;
    }
    /* Blur en pseudo-elemento para no crear containing block en el header
       (afectaría al nav con position: fixed). */
    .site-header::before {
      content: ""; position: absolute; inset: 0;
      backdrop-filter: blur(16px) saturate(160%);
      -webkit-backdrop-filter: blur(16px) saturate(160%);
      z-index: -1;
      pointer-events: none;
    }
    .site-header__inner {
      display: flex; align-items: center; justify-content: space-between;
      gap: clamp(.75rem, 2vw, 1.5rem);
      padding-block: .55rem;
      flex-wrap: nowrap;
    }
    .brand { display: inline-flex; align-items: center; transition: transform .3s ease; flex-shrink: 0; }
    .brand:hover { transform: scale(1.04); }
    .brand img { height: 50px; width: auto; filter: drop-shadow(0 4px 12px rgba(255,0,187,.4)); }
    @media (min-width: 900px) { .brand img { height: 60px; } }
    @media (min-width: 1200px) { .brand img { height: 64px; } }

    /* Hamburguesa (label) */
    .nav-toggle {
      display: inline-flex; align-items: center; justify-content: center;
      width: 50px; height: 50px;
      border-radius: 14px;
      color: #fff;
      background: var(--sd-magenta);
      box-shadow: var(--shadow-flat);
      cursor: pointer;
      position: relative; z-index: 95;
      transition: background .2s ease;
      -webkit-tap-highlight-color: transparent;
    }
    .nav-toggle:hover { background: #ff1ac5; }
    .nav-toggle__bars { position: relative; width: 22px; height: 16px; }
    .nav-toggle__bars span {
      position: absolute; left: 0; right: 0; height: 2.4px;
      background: #fff; border-radius: 4px;
      transition: transform .35s ease, top .25s ease, opacity .2s ease;
    }
    .nav-toggle__bars span:nth-child(1) { top: 0; }
    .nav-toggle__bars span:nth-child(2) { top: 7px; }
    .nav-toggle__bars span:nth-child(3) { top: 14px; }
    /* Animación abrir cuando checkbox está marcado (estado en :checked, propagado vía :has()) */
    .site-header:has(.nav-input:checked) .nav-toggle__bars span:nth-child(1) { top: 7px; transform: rotate(45deg); }
    .site-header:has(.nav-input:checked) .nav-toggle__bars span:nth-child(2) { opacity: 0; }
    .site-header:has(.nav-input:checked) .nav-toggle__bars span:nth-child(3) { top: 7px; transform: rotate(-45deg); }

    /* Drawer */
    .primary-nav {
      position: fixed; top: 0; right: 0; bottom: 0;
      width: min(88vw, 400px);
      padding: 0;
      /* Color de fondo SÓLIDO + gradientes encima — separado del shorthand
         para evitar parser dropping color cuando hay layers. */
      background-color: #0A0A0A;
      background-image:
        radial-gradient(60% 40% at 100% 0%, rgba(255,0,187,.22), transparent 60%),
        radial-gradient(60% 40% at 0% 100%, rgba(159,14,237,.22), transparent 60%);
      transform: translateX(100%);
      transition: transform .42s cubic-bezier(.2,.85,.25,1);
      z-index: 90;
      display: flex; flex-direction: column;
      color: #fff;
      box-shadow: var(--shadow-lg);
      overflow-y: auto;
      visibility: hidden;
    }
    /* MENÚ ABIERTO */
    html:has(.nav-input:checked) .primary-nav {
      transform: translateX(0);
      visibility: visible;
    }
    .primary-nav__head {
      display: flex; align-items: center; justify-content: space-between;
      padding: 1.25rem 1.5rem;
      border-bottom: 1px solid rgba(255,0,187,.25);
      background: linear-gradient(135deg, rgba(255,0,187,.22), rgba(159,14,237,.14));
    }
    .primary-nav__brand img { height: 56px; filter: drop-shadow(0 2px 10px rgba(255,0,187,.5)); }
    .primary-nav__close {
      width: 46px; height: 46px;
      border-radius: 14px;
      background: rgba(255,255,255,.1);
      color: #fff;
      display: grid; place-items: center;
      cursor: pointer;
      transition: background .2s ease, transform .25s ease;
      -webkit-tap-highlight-color: transparent;
    }
    .primary-nav__close:hover { background: var(--sd-magenta); transform: rotate(90deg); }
    .primary-nav__list {
      list-style: none; padding: 1.25rem 0; margin: 0;
      display: flex; flex-direction: column; flex: 1;
    }
    .primary-nav__list li {
      opacity: 1;             /* visible siempre */
      transform: none;
    }
    .primary-nav__list a {
      display: flex; align-items: center; justify-content: space-between;
      padding: 1.1rem 1.5rem;
      font-family: 'DM Sans', sans-serif;
      font-weight: 700;
      font-size: 1.2rem;
      color: #ffffff;          /* blanco sólido */
      border-left: 3px solid transparent;
      transition: color .2s ease, background .2s ease, border-color .2s ease, padding-left .2s ease;
      position: relative;
      letter-spacing: .005em;
    }
    .primary-nav__list a::after {
      content: "›";
      font-family: 'DM Sans', sans-serif;
      font-weight: 700;
      font-size: 1.6rem;
      color: rgba(255,255,255,.45);
      transition: transform .25s ease, color .25s ease;
      line-height: 1;
    }
    .primary-nav__list a:hover,
    .primary-nav__list a:focus-visible {
      color: #fff;
      background: linear-gradient(90deg, rgba(255,0,187,.22), transparent 80%);
      border-left-color: var(--sd-magenta);
      padding-left: 1.75rem;
    }
    .primary-nav__list a:hover::after,
    .primary-nav__list a:focus-visible::after {
      color: var(--sd-magenta);
      transform: translateX(4px);
    }

    .primary-nav__cta {
      padding: 1.25rem 1.5rem;
      border-top: 1px solid rgba(255,255,255,.08);
      display: grid; gap: .85rem;
    }
    .primary-nav__cta .btn { width: 100%; }
    .primary-nav__phone {
      display: flex; align-items: center; justify-content: center; gap: .5rem;
      padding: .6rem;
      font-family: 'DM Sans', sans-serif;
      font-size: .92rem;
      color: rgba(255,255,255,.7);
    }
    .primary-nav__phone svg { width: 16px; height: 16px; }
    .primary-nav__phone strong { color: #fff; font-weight: 700; }

    /* Backdrop */
    /* Backdrop: z-index 50 (debajo del header z-80) para que el drawer
       que vive DENTRO del header escape sin quedar atrapado.
       Sin backdrop-filter blur para no opacar el drawer. */
    .nav-backdrop {
      position: fixed; inset: 0;
      background: rgba(10,5,15,.65);
      z-index: 50;
      opacity: 0; pointer-events: none;
      transition: opacity .3s ease;
      cursor: pointer;
    }
    html:has(.nav-input:checked) .nav-backdrop { opacity: 1; pointer-events: auto; }

    /* Lock scroll */
    html:has(.nav-input:checked) { overflow: hidden; }

    .header-cta { display: none; }

    @media (min-width: 960px) {
      .nav-toggle, .primary-nav__head, .primary-nav__cta { display: none; }
      .primary-nav {
        position: static; transform: none; padding: 0;
        background: none;
        flex-direction: row; align-items: center;
        display: flex;
        width: auto; box-shadow: none; overflow: visible;
        visibility: visible;
        flex: 1; justify-content: center;
      }
      .primary-nav__list {
        display: flex; flex-direction: row; align-items: center;
        gap: .25rem; padding: 0; flex: initial;
      }
      .primary-nav__list li {
        /* Desktop: ignorar el stagger animation */
        opacity: 1; transform: none; transition: none;
      }
      .primary-nav__list a {
        padding: .55rem clamp(.7rem, 1.3vw, 1.1rem);
        border: 0; border-left: 0; border-radius: 999px;
        font-size: clamp(.9rem, 1.05vw, 1rem);
        color: rgba(255,255,255,.85);
        white-space: nowrap;
        background: transparent;
      }
      .primary-nav__list a::after { display: none; }
      .primary-nav__list a:hover,
      .primary-nav__list a:focus-visible {
        background: rgba(255,0,187,.18); color: #fff;
        padding-left: clamp(.7rem, 1.3vw, 1.1rem);
        border-left-color: transparent;
      }
      .nav-backdrop { display: none; }
      .header-cta { display: inline-flex; flex-shrink: 0; }
      html:has(.nav-input:checked) { overflow: visible; }
    }

    /* ================================================================
       HERO con JUEGO — iconos grandes, hint
       ================================================================ */
    .hero {
      position: relative;
      isolation: isolate;
      color: #fff;
      overflow: hidden;
      background: var(--sd-night);
      padding-block: clamp(3rem, 7vw, 5rem) clamp(4rem, 8vw, 6rem);
      min-height: clamp(700px, 96vh, 1000px);
      display: grid; align-items: center;
    }
    .hero__bg {
      position: absolute; inset: 0;
      background-color: var(--sd-night);
      background-size: cover;
      background-position: center center;
      background-repeat: no-repeat;
      z-index: -3;
      transform: scale(1.04);
      opacity: 0;
      transition: opacity 1.1s cubic-bezier(.2,.7,.2,1), transform 1.6s ease-out;
      will-change: opacity, transform;
    }
    /* Imagen para "Para Ella" */
    .hero[data-revealed="ella"] .hero__bg {
      background-image:
        image-set(
          url('../img/hero-simondice.webp') type('image/webp') 1x,
          url('../img/hero-simondice.jpg')  type('image/jpeg') 1x
        );
      opacity: 1;
      transform: scale(1);
    }
    /* Imagen para "Para Él" */
    .hero[data-revealed="el"] .hero__bg {
      background-image: image-set(url('/assets/img/hero-bachelor-party.webp') type('image/webp'), url('/assets/img/hero-bachelor-party.jpg') type('image/jpeg'));
      opacity: 1;
      transform: scale(1);
    }
    @supports not (background-image: image-set(url('a.webp') 1x)) {
      .hero[data-revealed="ella"] .hero__bg { background-image: url('../img/hero-simondice.jpg'); }
    }
    .hero__overlay {
      position: absolute; inset: 0;
      background:
        radial-gradient(60% 80% at 20% 110%, rgba(159,14,237,.55) 0%, transparent 60%),
        radial-gradient(50% 70% at 50% 0%,   rgba(255,0,187,.32) 0%, transparent 55%),
        linear-gradient(180deg, rgba(10,5,15,.25) 0%, rgba(10,5,15,.62) 100%);
      z-index: -2;
    }
    .hero__particles {
      position: absolute; inset: 0;
      width: 100%; height: 100%;
      z-index: -1;
      pointer-events: none;
    }
    .hero__inner {
      max-width: 960px;
      margin-inline: auto;
      padding-block: 1rem;
      text-align: center;
      width: 100%;
    }
    .hero__eyebrow {
      display: inline-flex; align-items: center; gap: .55rem;
      font-family: 'DM Sans', sans-serif;
      font-weight: 600; font-size: var(--t-sm);
      color: var(--sd-pink-soft);
      letter-spacing: .2em; text-transform: uppercase;
      margin-bottom: 1em;
      padding: .45rem 1rem;
      border: 1px solid rgba(255,0,187,.5);
      border-radius: 999px;
      background: rgba(10,5,15,.5);
      backdrop-filter: blur(8px);
    }
    .hero__eyebrow::before {
      content: ""; width: 8px; height: 8px; border-radius: 50%;
      background: var(--sd-magenta);
      box-shadow: 0 0 14px var(--sd-magenta);
      animation: ping 1.6s ease-in-out infinite;
    }
    @keyframes ping {
      0%, 100% { opacity: 1; transform: scale(1); }
      50%      { opacity: .55; transform: scale(1.5); }
    }
    .hero h1 {
      font-size: clamp(2.8rem, 1.8rem + 6vw, 6rem);
      color: #fff;
      text-shadow: 0 6px 36px rgba(10,10,10,.5);
      margin-bottom: .35em;
    }
    .hero h1 em, .hero h1 .pick-out {
      font-style: normal;
      background: linear-gradient(120deg, #FFC4ED 0%, #FF4FCB 35%, #FF00BB 65%, #9F0EED 100%);
      -webkit-background-clip: text; background-clip: text;
      color: transparent;
      display: inline-block;
    }
    .hero__lede {
      font-family: 'DM Sans', sans-serif;
      font-size: var(--t-lg);
      color: rgba(255,255,255,.92);
      max-width: 56ch;
      margin: .5em auto 1.5em;
    }

    /* JUEGO — cartas grandes, iconos grandes, hint */
    .pick-hint {
      display: inline-flex; align-items: center; gap: .5rem;
      font-family: 'DM Sans', sans-serif;
      font-weight: 500; font-size: var(--t-sm);
      color: rgba(255,255,255,.78);
      margin-bottom: 1rem;
      padding: .35rem .85rem;
      border-radius: 999px;
      background: rgba(255,255,255,.08);
    }
    .pick-hint__finger {
      display: inline-block;
      animation: pointDown 1.6s ease-in-out infinite;
    }
    @keyframes pointDown {
      0%, 100% { transform: translateY(0); }
      50%      { transform: translateY(4px); }
    }
    .pick {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 1rem;
      max-width: 640px;
      margin: 0 auto 1.75rem;
    }
    .pick-card {
      position: relative;
      padding: 1.75rem 1.25rem 1.5rem;
      border-radius: var(--r-lg);
      background: rgba(255,255,255,.1);
      border: 2px solid rgba(255,255,255,.28);
      backdrop-filter: blur(12px);
      color: #fff;
      cursor: pointer;
      display: flex; flex-direction: column; align-items: center; gap: .85rem;
      overflow: hidden;
      isolation: isolate;
      transition: transform .3s ease, border-color .3s ease, background .3s ease, box-shadow .3s ease;
      -webkit-tap-highlight-color: transparent;
    }
    .pick-card::after {
      content: ""; position: absolute; inset: -2px;
      border-radius: inherit;
      padding: 2px;
      background: linear-gradient(135deg, var(--sd-magenta), var(--sd-violet));
      -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
      mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
      -webkit-mask-composite: xor; mask-composite: exclude;
      opacity: 0; transition: opacity .3s ease;
      z-index: -1;
    }
    .pick-card:hover {
      transform: translateY(-6px) scale(1.02);
      background: rgba(255,255,255,.18);
      border-color: transparent;
      box-shadow: 0 18px 36px -12px rgba(255,0,187,.5);
    }
    .pick-card:hover::after { opacity: 1; }
    .pick-card[data-active="true"] {
      transform: translateY(-4px) scale(1.04);
      border-color: transparent;
      background: rgba(255,0,187,.22);
      box-shadow: 0 24px 48px -12px rgba(255,0,187,.6);
    }
    .pick-card[data-active="true"]::after { opacity: 1; }
    .pick-card[data-faded="true"] {
      opacity: .35; pointer-events: none;
      transform: scale(.96);
      filter: grayscale(.3);
    }
    .pick-card__icon {
      width: 110px; height: 110px;
      display: grid; place-items: center;
      border-radius: 50%;
      background:
        radial-gradient(circle at 30% 30%, rgba(255,255,255,.3), transparent 60%),
        rgba(255,255,255,.14);
      box-shadow: inset 0 0 0 2px rgba(255,255,255,.3),
                  0 8px 20px -8px rgba(255,0,187,.4);
      transition: transform .35s ease;
      position: relative;
    }
    .pick-card__icon::before {
      content: ""; position: absolute; inset: -10px;
      border-radius: 50%;
      border: 2px dashed rgba(255,255,255,.28);
      animation: spin 14s linear infinite;
      animation-play-state: paused;
    }
    .pick-card:hover .pick-card__icon { transform: rotate(-8deg) scale(1.06); }
    .pick-card:hover .pick-card__icon::before { animation-play-state: running; }
    .pick-card[data-active="true"] .pick-card__icon::before { animation-play-state: running; border-color: rgba(255,0,187,.5); }
    @keyframes spin { to { transform: rotate(360deg); } }

    .pick-card__icon img {
      width: 64px; height: auto;
      filter: brightness(1.1) drop-shadow(0 2px 6px rgba(0,0,0,.4));
    }
    .pick-card__label {
      font-family: 'Covered By Your Grace', cursive;
      font-size: 1.9rem; line-height: 1;
    }
    .pick-card__sub {
      font-family: 'DM Sans', sans-serif;
      font-size: .82rem;
      color: rgba(255,255,255,.78);
      letter-spacing: .04em;
      text-transform: uppercase;
    }

    .hero__cta-row {
      display: flex; flex-wrap: wrap; gap: .85rem; justify-content: center; align-items: center;
    }
    .hero__reset {
      display: inline-flex; align-items: center; gap: .35rem;
      padding: .6rem .95rem;
      font-family: 'DM Sans', sans-serif; font-weight: 500;
      color: rgba(255,255,255,.78);
      border-radius: 999px;
      transition: color .2s ease, background .2s ease;
    }
    .hero__reset:hover { color: #fff; background: rgba(255,255,255,.12); }
    .hero__reset[hidden] { display: none; }

    .hero__chips {
      display: flex; flex-wrap: wrap; gap: .5rem;
      margin-top: 2.25rem;
      padding: 0; list-style: none;
      justify-content: center;
    }
    .hero__chip {
      display: inline-flex; align-items: center; gap: .5rem;
      padding: .5rem .95rem;
      border-radius: 999px;
      background: rgba(255,255,255,.1);
      border: 1px solid rgba(255,255,255,.2);
      font-family: 'DM Sans', sans-serif;
      font-size: var(--t-sm); font-weight: 500;
      backdrop-filter: blur(8px);
    }
    .hero__chip svg { width: 16px; height: 16px; color: var(--sd-magenta-2); }

    .hero__scroll {
      position: absolute; bottom: 1.25rem; left: 50%;
      transform: translateX(-50%);
      width: 28px; height: 44px;
      border: 2px solid rgba(255,255,255,.4);
      border-radius: 999px;
      display: grid; place-items: start center;
      padding-top: 7px;
    }
    .hero__scroll::before {
      content: ""; width: 4px; height: 7px;
      background: #fff; border-radius: 4px;
      animation: scroll 1.8s ease-in-out infinite;
    }
    @keyframes scroll {
      0%   { transform: translateY(0); opacity: 1; }
      100% { transform: translateY(15px); opacity: 0; }
    }

    /* ================================================================
       MARQUEE
       ================================================================ */
    .marquee {
      background: var(--sd-black); color: #fff;
      overflow: hidden;
      padding-block: 1rem;
    }
    .marquee__track {
      display: flex; gap: 2.5rem;
      width: max-content;
      animation: marquee 28s linear infinite;
    }
    .marquee:hover .marquee__track { animation-play-state: paused; }
    .marquee__item {
      display: inline-flex; align-items: center; gap: .85rem;
      font-family: 'Covered By Your Grace', cursive;
      font-size: 1.7rem;
      color: #fff;
      white-space: nowrap;
    }
    .marquee__item span {
      width: 8px; height: 8px; border-radius: 50%;
      background: var(--sd-magenta);
      box-shadow: 0 0 12px var(--sd-magenta);
    }
    .marquee__item:nth-child(odd) {
      background: linear-gradient(120deg, #FFC4ED, #FF00BB);
      -webkit-background-clip: text; background-clip: text;
      color: transparent;
    }
    @keyframes marquee {
      from { transform: translateX(0); }
      to   { transform: translateX(-50%); }
    }

    /* ================================================================
       KARAOKE
       ================================================================ */
    .karaoke {
      background: var(--grad-magenta);
      color: #fff;
      position: relative;
      overflow: hidden;
    }
    .karaoke::before {
      content: ""; position: absolute; inset: -10% -10% auto auto;
      width: 60%; height: 80%;
      background: radial-gradient(circle, rgba(255,255,255,.18), transparent 60%);
      border-radius: 50%;
      animation: float 9s ease-in-out infinite;
    }
    @keyframes float {
      0%, 100% { transform: translate(0,0); }
      50%      { transform: translate(-22px, 22px); }
    }
    .karaoke__inner {
      display: grid; grid-template-columns: 1fr; gap: 2.5rem;
      align-items: center;
      padding-block: clamp(3rem, 7vw, 5.5rem);
    }
    .karaoke__photo {
      order: -1; max-width: 520px; margin-inline: auto;
      transform: rotate(-3deg);
      transition: transform .4s cubic-bezier(.2,.85,.25,1);
    }
    .karaoke__photo:hover { transform: rotate(0deg) scale(1.02); }
    .karaoke__photo img { filter: drop-shadow(0 30px 50px rgba(10,10,10,.45)); }
    .karaoke h2 {
      font-size: clamp(2.4rem, 1.6rem + 4.5vw, 4rem);
      color: #fff; margin-bottom: .25em;
    }
    .karaoke__lede {
      font-family: 'DM Sans', sans-serif;
      font-weight: 500;
      font-size: var(--t-lg);
      color: rgba(255,255,255,.95);
      margin-bottom: 1.5rem;
    }
    @media (min-width: 880px) {
      .karaoke__inner { grid-template-columns: 1fr 1.2fr; gap: 3.5rem; }
      .karaoke__photo { order: 0; }
    }

    /* ================================================================
       SELECTOR
       ================================================================ */
    .selector {
      background:
        radial-gradient(40% 60% at 0% 0%, rgba(255,0,187,.06), transparent 60%),
        radial-gradient(40% 60% at 100% 100%, rgba(159,14,237,.06), transparent 60%),
        var(--sd-cream);
      padding-block: clamp(3.5rem, 7vw, 6rem);
    }
    .selector__head { max-width: 720px; margin-inline: auto; text-align: center; margin-bottom: 3rem; }
    .selector__head h2 { color: var(--sd-black); margin: 0 0 .25em; }
    .selector__head p {
      font-size: var(--t-lg); color: var(--sd-gray-700);
      margin: 0 auto; max-width: 50ch;
    }
    .selector__grid {
      display: grid; gap: 1.5rem; grid-template-columns: 1fr;
      max-width: 920px; margin-inline: auto;
    }
    @media (min-width: 720px) { .selector__grid { grid-template-columns: 1fr 1fr; } }
    .gender-card {
      position: relative;
      padding: 2.5rem 1.75rem 2rem;
      border-radius: var(--r-lg);
      background: #fff;
      border: 2px solid var(--sd-gray-200);
      transition: transform .35s cubic-bezier(.2,.85,.25,1), border-color .35s ease, box-shadow .35s ease;
      display: flex; flex-direction: column; align-items: center; gap: 1rem;
      overflow: hidden;
      isolation: isolate;
      text-align: center;
    }
    .gender-card::before {
      content: ""; position: absolute; inset: -2px;
      border-radius: inherit; padding: 2px;
      background: linear-gradient(120deg, var(--sd-magenta), var(--sd-violet));
      -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
      mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
      -webkit-mask-composite: xor; mask-composite: exclude;
      opacity: 0; transition: opacity .35s ease;
      z-index: -1;
    }
    .gender-card:hover { transform: translateY(-8px) rotate(-.5deg); border-color: transparent; box-shadow: var(--shadow-md); }
    .gender-card:hover::before { opacity: 1; }
    .gender-card__icon {
      width: 130px; height: 130px;
      display: grid; place-items: center;
      background: conic-gradient(from 180deg at 50% 50%, var(--sd-pink-bg), #fff, var(--sd-pink-bg));
      border-radius: 50%;
      box-shadow: inset 0 0 0 1px rgba(255,0,187,.18);
      transition: transform .35s ease;
    }
    .gender-card:hover .gender-card__icon { transform: rotate(8deg) scale(1.04); }
    .gender-card__icon img { width: 80px; height: auto; }
    .gender-card h3 { color: var(--sd-magenta); font-size: var(--t-2xl); margin: 0; }
    .gender-card p {
      font-family: 'DM Sans', sans-serif;
      color: var(--sd-gray-700); font-size: var(--t-md);
      max-width: 30ch; margin: 0;
    }
    .gender-card__cta {
      margin-top: .25rem;
      display: inline-flex; align-items: center; gap: .55rem;
      padding: .9rem 1.85rem;
      border-radius: 999px;
      background: var(--sd-magenta);
      color: #fff;
      font-family: 'DM Sans', sans-serif;
      font-weight: 600; font-size: var(--t-md);
      box-shadow: var(--shadow-flat);
      transition: background .2s ease;
    }
    .gender-card__cta:hover { background: #ff1ac5; }
    .gender-card__cta::after { content: "→"; transition: transform .3s ease; }
    .gender-card:hover .gender-card__cta::after { transform: translateX(6px); }

    /* ================================================================
       PROMESAS
       ================================================================ */
    .promesas { padding-block: clamp(3.5rem, 7vw, 6rem); background: var(--sd-white); }
    .section-head { max-width: 760px; margin: 0 auto clamp(2rem, 4vw, 3rem); text-align: center; }
    .section-head .leckerli {
      display: inline-block;
      font-size: var(--t-md); color: var(--sd-magenta);
      margin-bottom: .25em;
    }
    .section-head h2 { color: var(--sd-black); margin: 0; }
    .section-head p {
      font-family: 'DM Sans', sans-serif;
      font-size: var(--t-lg); color: var(--sd-gray-700);
      margin-top: .75em;
    }
    .promesas__grid {
      display: grid; gap: 1rem;
      grid-template-columns: 1fr;
    }
    @media (min-width: 600px) { .promesas__grid { grid-template-columns: 1fr 1fr; } }
    @media (min-width: 1000px) { .promesas__grid { grid-template-columns: repeat(4, 1fr); } }
    .promesa {
      padding: 2.25rem 1.5rem 1.75rem;
      border-radius: var(--r-md);
      background: linear-gradient(180deg, var(--sd-pink-bg) 0%, #fff 100%);
      border: 1px solid var(--sd-pink-soft);
      display: flex; flex-direction: column; gap: .85rem;
      text-align: center; align-items: center;
      transition: transform .3s ease, box-shadow .3s ease;
    }
    .promesa:hover { transform: translateY(-6px); box-shadow: 0 16px 40px -16px rgba(255,0,187,.3); }
    .promesa:nth-child(2) { border-radius: 14px 32px 14px 32px; }
    .promesa:nth-child(3) { border-radius: 32px 14px 32px 14px; }
    .promesa:nth-child(4) { border-radius: 32px 32px 14px 32px; }
    .promesa__icon {
      width: 76px; height: 76px;
      display: grid; place-items: center;
      border-radius: 22px;
      background: var(--sd-magenta);
      color: #fff;
      box-shadow: var(--shadow-flat), inset 0 0 0 2px rgba(255,255,255,.18);
      transition: transform .35s cubic-bezier(.2,.85,.25,1);
      position: relative;
    }
    .promesa__icon::after {
      content: ""; position: absolute; inset: -8px;
      border-radius: 26px;
      border: 1.5px dashed rgba(255,0,187,.4);
      opacity: 0;
      transition: opacity .3s ease;
      animation: spin 14s linear infinite;
      animation-play-state: paused;
    }
    .promesa:hover .promesa__icon { transform: rotate(-8deg) scale(1.08); }
    .promesa:hover .promesa__icon::after { opacity: 1; animation-play-state: running; }
    .promesa__icon svg { width: 38px; height: 38px; }
    .promesa h3 {
      font-family: 'DM Sans', sans-serif;
      font-weight: 700; font-size: var(--t-lg);
      color: var(--sd-black); margin: 0;
      line-height: 1.3;
    }
    .promesa p {
      font-family: 'DM Sans', sans-serif;
      color: var(--sd-gray-700); font-size: var(--t-sm);
      margin: 0;
    }

    /* ================================================================
       HOMBRES
       ================================================================ */
    .hombres {
      position: relative; isolation: isolate;
      color: #fff; overflow: hidden;
      padding-block: clamp(4rem, 9vw, 7rem);
    }
    .hombres__bg {
      position: absolute; inset: 0;
      background:
        radial-gradient(45% 70% at 100% 50%, rgba(159,14,237,.55) 0%, transparent 60%),
        radial-gradient(45% 70% at 0% 100%, rgba(255,0,187,.4) 0%, transparent 60%),
        var(--sd-night);
      z-index: -2;
    }
    .hombres__photo {
      position: absolute; inset: 0;
      background-image: image-set(url('/assets/img/hero-bachelor-party.webp') type('image/webp'), url('/assets/img/hero-bachelor-party.jpg') type('image/jpeg'));
      background-size: cover; background-position: center;
      opacity: .22; mix-blend-mode: screen;
      z-index: -1;
    }
    .hombres__inner { max-width: 760px; text-align: center; margin-inline: auto; }
    .hombres .leckerli { color: var(--sd-magenta-2); font-size: var(--t-lg); }
    .hombres h2 {
      color: #fff;
      font-size: clamp(2.2rem, 1.6rem + 4.5vw, 4.5rem);
      margin: .25em 0 .5em;
    }
    .hombres h2 em {
      font-style: normal;
      background: linear-gradient(120deg, #FF4FCB, #FFC4ED 70%, #FF00BB);
      -webkit-background-clip: text; background-clip: text;
      color: transparent;
    }
    .hombres p {
      font-family: 'DM Sans', sans-serif;
      font-size: var(--t-lg); color: rgba(255,255,255,.88);
      max-width: 50ch; margin: 0 auto 2rem;
    }
    .hombres__actions { display: flex; flex-wrap: wrap; gap: .85rem; justify-content: center; }

    /* ================================================================
       PASOS
       ================================================================ */
    .pasos { padding-block: clamp(3.5rem, 7vw, 6rem); background: var(--sd-white); }
    .pasos__grid {
      display: grid; gap: 1.25rem; grid-template-columns: 1fr;
      counter-reset: paso;
    }
    @media (min-width: 800px) { .pasos__grid { grid-template-columns: repeat(3, 1fr); } }
    .paso {
      counter-increment: paso;
      padding: 2.25rem 1.75rem;
      border-radius: var(--r-md);
      background: linear-gradient(180deg, #fff, var(--sd-pink-bg));
      border: 1px solid var(--sd-pink-soft);
      transition: transform .3s ease;
    }
    .paso:hover { transform: translateY(-6px); }
    @media (min-width: 800px) {
      .paso:nth-child(2) { transform: translateY(20px); }
      .paso:nth-child(2):hover { transform: translateY(14px); }
    }
    .paso::before {
      content: counter(paso, decimal-leading-zero);
      font-family: 'Leckerli One', cursive;
      font-size: 3.4rem; line-height: 1;
      background: linear-gradient(120deg, var(--sd-magenta), var(--sd-violet));
      -webkit-background-clip: text; background-clip: text;
      color: transparent;
      display: block; margin-bottom: .35em;
    }
    .paso h3 {
      font-family: 'DM Sans', sans-serif;
      font-weight: 700; font-size: var(--t-lg);
      color: var(--sd-black); margin-bottom: .35em;
    }
    .paso p {
      font-family: 'DM Sans', sans-serif;
      color: var(--sd-gray-700); font-size: var(--t-md); margin: 0;
    }

    /* ================================================================
       GALERÍA bento
       ================================================================ */
    .galeria { padding-block: clamp(3.5rem, 7vw, 6rem); background: var(--sd-cream); }
    .galeria__grid {
      display: grid; gap: 1rem;
      grid-template-columns: repeat(2, 1fr);
      grid-auto-flow: dense;
    }
    @media (min-width: 720px) {
      .galeria__grid { grid-template-columns: repeat(4, 1fr); grid-auto-rows: 200px; }
    }
    .galeria__item {
      position: relative; overflow: hidden;
      border-radius: var(--r-md);
      aspect-ratio: 3 / 4;
      background: var(--sd-gray-200);
      box-shadow: 0 12px 24px -10px rgba(10,10,10,.18);
    }
    .galeria__item img {
      width: 100%; height: 100%;
      object-fit: cover;
      transition: transform .8s cubic-bezier(.2,.7,.2,1), filter .4s ease;
      will-change: transform;
    }
    .galeria__item:hover img { transform: scale(1.08); filter: saturate(1.12); }
    .galeria__item::after {
      content: ""; position: absolute; inset: 0;
      background: linear-gradient(180deg, transparent 55%, rgba(20,8,29,.55) 100%);
      pointer-events: none;
    }
    @media (min-width: 720px) {
      .galeria__item { aspect-ratio: auto; }
      .galeria__item--xl { grid-column: span 2; grid-row: span 2; }
      .galeria__item--w  { grid-column: span 2; }
      .galeria__item--h  { grid-row: span 2; }
    }

    /* ================================================================
       TESTIMONIOS
       ================================================================ */
    .testimonios { padding-block: clamp(3.5rem, 7vw, 6rem); background: var(--sd-pink-bg); }
    .testimonios__grid {
      display: grid; gap: 1.25rem; grid-template-columns: 1fr;
    }
    @media (min-width: 800px) { .testimonios__grid { grid-template-columns: repeat(3, 1fr); } }
    .testimonio {
      padding: 2rem 1.75rem;
      border-radius: var(--r-md);
      background: #fff;
      border: 1px solid var(--sd-pink-soft);
      display: flex; flex-direction: column; gap: 1rem;
      position: relative;
      transition: transform .3s ease;
    }
    .testimonio:hover { transform: translateY(-4px); }
    .testimonio::before {
      content: '"';
      position: absolute; top: -10px; left: 18px;
      font-family: 'Leckerli One', cursive;
      font-size: 5rem; color: var(--sd-magenta);
      line-height: 1;
    }
    .testimonio__rating { color: #FFB400; font-size: 1.1rem; letter-spacing: 2px; }
    .testimonio blockquote {
      margin: 0;
      font-family: 'DM Sans', sans-serif;
      font-size: var(--t-md); color: var(--sd-gray-900);
      font-weight: 500; line-height: 1.55;
    }
    .testimonio cite {
      font-style: normal;
      font-family: 'DM Sans', sans-serif;
      font-size: var(--t-sm); color: var(--sd-gray-500);
      margin-top: auto;
    }
    .testimonio cite strong {
      display: block; color: var(--sd-violet);
      font-weight: 700; font-size: var(--t-md);
    }

    /* ================================================================
       FAQ
       ================================================================ */
    .faq { padding-block: clamp(3.5rem, 7vw, 6rem); background: var(--sd-white); }
    .faq__list { display: grid; gap: .75rem; max-width: 820px; margin-inline: auto; }
    .faq-item {
      background: var(--sd-pink-bg);
      border: 1px solid var(--sd-pink-soft);
      border-radius: var(--r-md);
      overflow: hidden;
      transition: border-color .25s ease, background .25s ease, box-shadow .3s ease;
    }
    .faq-item[open] { border-color: var(--sd-magenta); background: #fff; box-shadow: var(--shadow-md); }
    .faq-item summary {
      list-style: none;
      padding: 1.2rem 1.25rem;
      font-family: 'DM Sans', sans-serif;
      font-weight: 600; font-size: var(--t-md);
      cursor: pointer;
      display: flex; align-items: center; justify-content: space-between;
      gap: 1rem; color: var(--sd-black);
    }
    .faq-item summary::-webkit-details-marker { display: none; }
    .faq-item summary::after {
      content: "+"; font-family: 'Leckerli One', cursive;
      font-size: 1.9rem; line-height: 1;
      color: var(--sd-magenta);
      transition: transform .3s ease;
    }
    .faq-item[open] summary::after { content: "−"; transform: rotate(180deg); }
    .faq-item__body {
      padding: 0 1.25rem 1.25rem;
      font-family: 'DM Sans', sans-serif;
      color: var(--sd-gray-700); font-size: var(--t-md);
    }

    /* ================================================================
       CTA FINAL
       ================================================================ */
    .cta-final {
      padding-block: clamp(4rem, 8vw, 6rem);
      color: #fff;
      background: var(--sd-magenta);
      position: relative; overflow: hidden;
    }
    .cta-final::before {
      content: ""; position: absolute; inset: 0;
      background:
        radial-gradient(ellipse at 100% 0%, rgba(255,79,168,.4), transparent 60%),
        radial-gradient(ellipse at 0% 100%, rgba(159,14,237,.5), transparent 60%);
      pointer-events: none;
    }
    .cta-final__inner {
      position: relative;
      display: grid; gap: 2rem; align-items: center;
    }
    @media (min-width: 880px) {
      .cta-final__inner { grid-template-columns: 1.4fr 1fr; gap: 3rem; }
    }
    .cta-final h2 { color: #fff; margin-bottom: .25em; }
    .cta-final__lede {
      font-family: 'DM Sans', sans-serif;
      font-size: var(--t-lg);
      color: rgba(255,255,255,.94);
      margin-bottom: 1.5rem;
    }
    .cta-final__actions { display: flex; flex-wrap: wrap; gap: .85rem; }
    .cta-final__contact {
      background: rgba(0,0,0,.32);
      border: 1px solid rgba(255,255,255,.22);
      backdrop-filter: blur(12px);
      padding: 1.75rem;
      border-radius: var(--r-md);
      display: grid; gap: .85rem;
    }
    .cta-final__contact a {
      display: flex; align-items: center; gap: .85rem;
      padding: .9rem 1rem;
      border-radius: var(--r-sm);
      background: rgba(255,255,255,.08);
      transition: background .2s ease, transform .2s ease;
      font-family: 'DM Sans', sans-serif; font-weight: 500;
    }
    .cta-final__contact a:hover { background: rgba(255,255,255,.18); transform: translateX(4px); }
    .cta-final__contact svg { width: 22px; height: 22px; flex-shrink: 0; }

    /* ================================================================
       FOOTER
       ================================================================ */
    .site-footer {
      background: var(--sd-black);
      color: rgba(255,255,255,.7);
      padding-block: 3.5rem 1.5rem;
      font-family: 'DM Sans', sans-serif;
    }
    .site-footer__grid {
      display: grid; gap: 2.25rem; grid-template-columns: 1fr;
    }
    @media (min-width: 720px) { .site-footer__grid { grid-template-columns: 1.5fr 1fr 1fr 1fr; } }
    .site-footer .brand { margin-bottom: 1rem; }
    .site-footer .brand img { height: 64px; }
    .site-footer h4 {
      font-family: 'DM Sans', sans-serif;
      font-weight: 700; color: #fff; font-size: var(--t-md);
      margin: 0 0 1rem;
    }
    .site-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: .55rem; font-size: var(--t-sm); }
    .site-footer a:hover { color: var(--sd-magenta); }
    .site-footer__brand p {
      font-size: var(--t-sm); max-width: 36ch;
      color: rgba(255,255,255,.6);
    }
    .site-footer__bottom {
      margin-top: 2.5rem;
      padding-top: 1.25rem;
      border-top: 1px solid rgba(255,255,255,.08);
      display: flex; flex-wrap: wrap;
      gap: .75rem; justify-content: space-between;
      font-size: var(--t-xs); color: rgba(255,255,255,.4);
    }

    /* ================================================================
       SOCIAL RAIL + FAB
       ================================================================ */
    .social-rail {
      position: fixed; right: 0; top: 50%;
      transform: translateY(-50%);
      z-index: 60;
      display: none;
      flex-direction: column; gap: 6px;
    }
    @media (min-width: 720px) { .social-rail { display: flex; } }
    .social-rail a {
      width: 44px; height: 44px;
      display: grid; place-items: center;
      color: #fff;
      transition: transform .25s ease;
    }
    .social-rail a:hover { transform: translateX(-6px) scale(1.06); }
    .social-rail .s-fb { background: #1877F2; }
    .social-rail .s-ig { background: linear-gradient(135deg,#FFD600,#FF7A00,#FF1E56,#D300C5,#7638FA); }
    .social-rail .s-tt { background: #000; }
    .social-rail svg { width: 22px; height: 22px; }

    .wa-fab {
      position: fixed; left: 1rem; bottom: 1rem;
      display: inline-flex; align-items: center; gap: .55rem;
      padding: .8rem 1.15rem .8rem .85rem;
      border-radius: 999px;
      background: #25D366; color: #fff;
      box-shadow: 0 12px 28px -8px rgba(37,211,102,.6);
      z-index: 70;
      transition: transform .25s ease;
      font-family: 'DM Sans', sans-serif;
      font-weight: 600; font-size: .95rem;
    }
    .wa-fab:hover { transform: scale(1.04) translateY(-2px); }
    .wa-fab svg { width: 26px; height: 26px; }

    .call-fab {
      position: fixed; right: 1rem; bottom: 1rem;
      width: 60px; height: 60px;
      border-radius: 50%;
      background: var(--sd-magenta); color: #fff;
      display: grid; place-items: center;
      box-shadow: var(--shadow-flat);
      z-index: 70;
      transition: transform .25s ease, background .2s ease;
      animation: pulse 2.4s ease-in-out infinite;
    }
    .call-fab:hover { transform: scale(1.1); background: #ff1ac5; animation: none; }
    .call-fab svg { width: 26px; height: 26px; }
    @keyframes pulse {
      0%, 100% { box-shadow: 0 0 0 0 rgba(255,0,187,.5), var(--shadow-flat); }
      50%      { box-shadow: 0 0 0 16px rgba(255,0,187,0),  var(--shadow-flat); }
    }
    @media (min-width: 720px) { .call-fab { right: 56px; } }

/* ====================================================================
   BLOG — Post pages (modo oscuro, contraste WCAG AA verificado)
   ==================================================================== */
/* Article container — fondo oscuro de marca */
body[data-page^="blog/"] { background: #0c0716; }

.post { color: #ECE6F2; }

/* CUERPO: fondo oscuro, texto light cream — ratio 16.2:1 [AAA] */
.post .post__body {
  background: #0c0716;
  color: #ECE6F2 !important;
  font-size: clamp(17px, 1.05rem, 19px);
  line-height: 1.78;
}
.post .post__body p { margin: 0 0 1.25em; color: #ECE6F2 }
.post .post__body strong, .post .post__body b { color: #FFFFFF; font-weight: 700 }
.post .post__body em, .post .post__body i { color: #FFFFFF }

/* HEADINGS — blanco con accent magenta */
.post .post__body h2 {
  color: #FFFFFF;
  font-size: clamp(1.5rem, 3vw, 2rem);
  line-height: 1.22;
  margin: 2.6rem 0 1.1rem;
  padding-bottom: .55rem;
  border-bottom: 2px solid #FF1F8A;
  font-weight: 800;
}
.post .post__body h3 {
  color: #FFFFFF;
  font-size: 1.22rem;
  line-height: 1.3;
  margin: 1.9rem 0 .85rem;
  font-weight: 700;
}
.post .post__body h3::before {
  content: "";
  display: inline-block;
  width: 14px;
  height: 3px;
  background: #FF1F8A;
  margin-right: .6rem;
  vertical-align: middle;
  border-radius: 2px;
}

/* LISTAS */
.post .post__body ul,
.post .post__body ol { margin: 0 0 1.5em 1.4em; padding: 0; color: #ECE6F2 }
.post .post__body li { margin-bottom: .55em; line-height: 1.7; color: #ECE6F2 }
.post .post__body ul li::marker { color: #FF1F8A }
.post .post__body ol li::marker { color: #FF1F8A; font-weight: 700 }

/* LINKS — magenta vivo, ratio 5.5:1 [AA] */
.post .post__body a {
  color: #FF1F8A;
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1.5px;
  font-weight: 600;
}
.post .post__body a:hover { color: #FF6BC1; text-decoration-color: #FF6BC1 }

/* LEAD — caja destacada al inicio, fondo magenta translúcido */
.post .post__lead {
  font-size: clamp(1.05rem, 1.18rem, 1.25rem);
  line-height: 1.65;
  background: rgba(255, 31, 138, 0.10);
  border-left: 4px solid #FF1F8A;
  padding: 1.3rem 1.5rem;
  border-radius: 0 .65rem .65rem 0;
  margin-bottom: 2.5rem;
  color: #ECE6F2;
}
.post .post__lead strong { color: #FF6BC1 }

/* TABLA — fondo levantado #1a1024 sobre #0c0716 */
.post .post-table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.5rem 0 2rem;
  font-size: .96rem;
  background: #1a1024;
  color: #ECE6F2;
  border: 1px solid rgba(255,31,138,0.25);
  border-radius: .65rem;
  overflow: hidden;
}
.post .post-table th {
  background: linear-gradient(135deg, #FF1F8A, #9F0EED);
  color: #FFFFFF;
  font-weight: 700;
  text-align: left;
  padding: .9rem 1rem;
}
.post .post-table td {
  padding: .8rem 1rem;
  border-top: 1px solid rgba(255,255,255,0.06);
  vertical-align: top;
  color: #ECE6F2;
}
.post .post-table tr:nth-child(even) td { background: rgba(255,255,255,0.02) }
@media (max-width: 720px) {
  .post .post-table { font-size: .9rem }
  .post .post-table th, .post .post-table td { padding: .65rem .75rem }
}

/* CTA al final del post — ya tiene fondo magenta sólido en inline */
/* FAQs section: heredan estilo del sitio */
.post .post__faqs { background: #0c0716; color: #ECE6F2 }
.post .post__faqs h2 { color: #FFFFFF }
.post .post__faqs .faq-item {
  background: #1a1024;
  border: 1px solid rgba(255,31,138,0.18);
  border-radius: .6rem;
  margin-bottom: .75rem;
  overflow: hidden;
}
.post .post__faqs .faq-item summary {
  padding: 1rem 1.25rem;
  color: #FFFFFF;
  font-weight: 600;
  cursor: pointer;
  font-size: 1.02rem;
  list-style: none;
}
.post .post__faqs .faq-item summary::-webkit-details-marker { display: none }
.post .post__faqs .faq-item summary::after {
  content: "+";
  float: right;
  color: #FF1F8A;
  font-weight: 700;
  font-size: 1.4rem;
  line-height: 1;
}
.post .post__faqs .faq-item[open] summary::after { content: "−" }
.post .post__faqs .faq-item__body {
  padding: 0 1.25rem 1.1rem;
  color: #ECE6F2;
  line-height: 1.65;
}

/* Related posts cards — mantener fondo light para contraste interno */
.post .post__related { background: #FAFAFA }
.post .post__related h2 { color: #1a0028 }

/* Hero del post — el shell ya tiene gradiente oscuro inline */
.post .post__hero h1 { color: #FFFFFF }
.post .post__crumbs a { color: rgba(255,255,255,0.75) }
.post .post__crumbs a:hover { color: #FF1F8A }

/* === FIX 2026-05-08: galería bento — el <picture> es inline por defecto y no
   propagaba la altura de .galeria__item al <img> (height:100% no se aplicaba),
   dejando un espacio gris debajo de la imagen. === */
.galeria__item picture { display: block; width: 100%; height: 100%; }

/* === FIX 2026-05-08: blog listing — el body usa --sd-night oscuro y
   .section-head h2 usa --sd-black, así que el título "Guías 2026..." y el
   párrafo se perdían. .blog-grid no tenía background propio (a diferencia de
   .galeria), así que añadimos cream igual que el resto de secciones. === */
.blog-grid { background: var(--sd-cream); padding-block: clamp(3.5rem, 7vw, 6rem); }
