/* ── TOKENS ────────────────────────────────────────── */
    :root {
      /* === PALETA PRINCIPAL BNJ — BLUE MIRAGE === */
      --bg-base: #FAF6F0;        /* Fondo principal */
      --bg-alt: #F2E0D0;         /* Amber Smoke — superficie alternada */
      --bg-dark: #1E1040;        /* Footer y contacto */
      --accent-purple: #2D1F3D;  /* Tinta Profunda — headings y dark CTAs */
      --accent-gold: #9E88B0;    /* Blue Mirage — íconos, highlights, precios */
      --border-soft: #C5B8D6;    /* Blue Mirage Light — bordes y acentos suaves */
      --text-body: #2D1F3D;      /* Tinta Profunda */
      --text-secondary: #5A4A6A; /* Texto secundario */

      /* === ALIASES LEGACY (compatibilidad con clases existentes) === */
      --cream: #FAF6F0;
      --cream-soft: #F2E0D0;
      --amber: #F2E0D0;
      --amber-mid: #E8D0C0;
      --amber-deep: #9E88B0;     /* Blue Mirage como acento */
      --gold: #9E88B0;           /* Blue Mirage */
      --blue: #9E88B0;           /* Blue Mirage */
      --blue-deep: #2D1F3D;      /* Tinta Profunda */
      --blue-pale: #F2E0D0;      /* Amber Smoke */
      --blue-light: #C5B8D6;     /* Blue Mirage Light */
      --bg-dark-1: #F2E0D0;      /* Referentes/Campeonas → claro */
      --bg-dark-2: #1E1040;      /* Contacto → oscuro */
      --bg-dark-3: #1E1040;      /* Footer → oscuro */
      --white: #FFFFFF;
      --ink: #2D1F3D;            /* Tinta Profunda */
      --ink-soft: #5A4A6A;       /* Morado medio */
      --ink-muted: #8A7A9A;      /* Morado suave */
      --glass: rgba(255, 255, 255, 0.20);
      --glass-b: rgba(255, 255, 255, 0.40);
      --glass-border: rgba(255, 255, 255, 0.30);
    }

    * {
      margin: 0;
      padding: 0;
      box-sizing: border-box;
    }

    html {
      scroll-behavior: smooth;
    }

    body {
      font-family: 'Bree Serif', serif;
      background: var(--bg-base);
      color: var(--ink);
      overflow-x: hidden;
    }

    /* Pacifico only has weight 400 — global override */
    .brand-text .name, .hero h1, .sec-title, .prod-name,
    .tela-name, .envio-title, .champion-name, .stat-n,
    .c-head h3, .f-brand .fn, .about-float p,
    .modal-prod-name, #modalPrice, .contact-title {
      font-weight: 400;
    }

    /* Font utility classes */
    .pacifico-regular {
      font-family: "Pacifico", cursive;
      font-weight: 400;
      font-style: normal;
    }

    .bree-serif-regular {
      font-family: "Bree Serif", serif;
      font-weight: 400;
      font-style: normal;
    }

    img {
      max-width: 100%;
      height: auto;
    }

    ::-webkit-scrollbar {
      width: 5px;
    }

    ::-webkit-scrollbar-track {
      background: var(--amber);
    }

    ::-webkit-scrollbar-thumb {
      background: var(--blue);
      border-radius: 3px;
    }

    /* ── HEADER ────────────────────────────────────────── */
    .header {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      z-index: 200;
      height: 66px;
      padding: 0 2.5rem;
      display: flex;
      align-items: center;
      justify-content: space-between;
      background: rgba(250, 246, 240, 0.82);
      backdrop-filter: blur(20px);
      -webkit-backdrop-filter: blur(20px);
      border-bottom: 1px solid rgba(232, 224, 212, 0.6);
      transition: background .3s;
    }

    .header.scrolled {
      background: rgba(250, 246, 240, 0.97);
    }
    .logo-wrap {
      display: flex;
      align-items: center;
      gap: 12px;
      text-decoration: none;
      padding: 6px 10px 6px 4px;
      margin-left: -4px;
      border-radius: 12px;
      transition: background .2s;
    }

    .logo-wrap:hover {
      background: rgba(158, 136, 176, .1);
    }

    .logo-img {
      width: 46px;
      height: 46px;
      object-fit: contain;
      filter: drop-shadow(0 2px 10px rgba(122, 100, 144, .45));
    }

    .brand-text .name {
      font-family: 'Cormorant Garamond', Georgia, serif;
      font-size: clamp(1.1rem, 2.8vw, 1.3rem);
      font-weight: 600;
      font-style: italic;
      letter-spacing: .02em;
      line-height: 1.15;
      background: linear-gradient(135deg, #9E88B0 0%, #2D1F3D 60%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
    }

    .desktop-nav {
      display: flex;
      align-items: center;
      gap: 1.8rem;
    }

    .desktop-nav a {
      font-size: 13.5px;
      font-weight: 600;
      color: var(--ink);
      text-decoration: none;
      letter-spacing: .04em;
      cursor: pointer;
      position: relative;
      padding-bottom: 3px;
      transition: color .2s;
    }

    .desktop-nav a::after {
      content: '';
      position: absolute;
      bottom: 0;
      left: 0;
      width: 0;
      height: 1.5px;
      background: var(--accent-gold);
      transition: width 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    }

    .desktop-nav a:hover {
      color: var(--accent-purple);
    }

    .desktop-nav a:hover::after {
      width: 100%;
    }

    .desktop-nav a:active {
      color: var(--accent-purple);
    }

    .header-actions {
      display: flex;
      align-items: center;
      gap: .75rem;
    }

    .wa-header {
      background: linear-gradient(135deg, #25D366, #1da851);
      color: #fff;
      border: none;
      padding: 7px 14px;
      border-radius: 50px;
      font-family: 'Bree Serif', sans-serif;
      font-size: 12px;
      font-weight: 500;
      cursor: pointer;
      display: flex;
      align-items: center;
      gap: 6px;
      box-shadow: 0 3px 12px rgba(37, 211, 102, .3);
      transition: transform .2s;
    }

    .wa-header:hover {
      transform: translateY(-1px);
    }

    .cart-btn {
      background: var(--accent-purple);
      color: #fff;
      border: none;
      padding: 7px 16px;
      border-radius: 50px;
      font-family: 'Bree Serif', sans-serif;
      font-size: 13px;
      font-weight: 500;
      cursor: pointer;
      display: flex;
      align-items: center;
      gap: 7px;
      box-shadow: 0 3px 14px rgba(45, 27, 105, .25);
      transition: background .2s, transform .2s;
    }

    .cart-btn:hover {
      background: #1E1040;
      transform: translateY(-1px);
    }

    .cart-pill {
      background: var(--amber-deep);
      color: #fff;
      width: 18px;
      height: 18px;
      border-radius: 50%;
      font-size: 10px;
      display: flex;
      align-items: center;
      justify-content: center;
      font-weight: 600;
    }

    .hamburger {
      display: none;
      background: none;
      border: none;
      cursor: pointer;
      flex-direction: column;
      gap: 5px;
    }

    .hamburger span {
      display: block;
      width: 22px;
      height: 2px;
      background: var(--ink);
      border-radius: 2px;
      transition: .3s;
    }

    /* ── MOBILE NAV ─────────────────────────────────── */
    .mobile-nav {
      display: none;
      position: fixed;
      top: 66px;
      left: 0;
      right: 0;
      background: rgba(250, 246, 240, .98);
      backdrop-filter: blur(20px);
      border-bottom: 1px solid rgba(232, 224, 212, .5);
      z-index: 190;
      padding: 1.5rem 2rem;
      flex-direction: column;
      gap: 1rem;
    }

    .mobile-nav.open {
      display: flex;
    }

    .mobile-nav a {
      font-size: 15px;
      color: var(--ink);
      text-decoration: none;
      padding: .5rem 0;
      border-bottom: 1px solid rgba(158, 136, 176, .1);
      cursor: pointer;
    }

    /* ── HERO ───────────────────────────────────────── */
    .hero {
      min-height: 100vh;
      display: flex;
      align-items: center;
      position: relative;
      overflow: hidden;
      padding: 90px 2.5rem 3rem;
    }

    .hero-bg {
      position: absolute;
      inset: 0;
      background: var(--bg-base);
    }

    .orb {
      position: absolute;
      border-radius: 50%;
      filter: blur(70px);
      pointer-events: none;
      animation: floatOrb 9s ease-in-out infinite;
    }

    .orb1 {
      width: 420px;
      height: 420px;
      background: rgba(158, 136, 176, .22);
      top: 8%;
      right: 3%;
      animation-delay: 0s;
    }

    .orb2 {
      width: 300px;
      height: 300px;
      background: rgba(242, 224, 208, .7);
      bottom: 10%;
      left: 8%;
      animation-delay: -4s;
    }

    .orb3 {
      width: 220px;
      height: 220px;
      background: rgba(197, 184, 214, .3);
      top: 45%;
      left: 38%;
      animation-delay: -6s;
    }

    .orb4 {
      width: 160px;
      height: 160px;
      background: rgba(158, 136, 176, .28);
      top: 12%;
      left: 5%;
      animation-delay: -2s;
    }

    @keyframes floatOrb {

      0%,
      100% {
        transform: translateY(0) scale(1);
      }

      50% {
        transform: translateY(-22px) scale(1.03);
      }
    }

    .hero-inner {
      position: relative;
      z-index: 2;
      display: grid;
      grid-template-columns: 55fr 45fr;
      gap: 3rem;
      align-items: center;
      max-width: 1200px;
      margin: 0 auto;
      width: 100%;
    }

    .hero-eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      background: rgba(158, 136, 176, .12);
      border: 0.5px solid rgba(158, 136, 176, .35);
      padding: 5px 16px;
      border-radius: 50px;
      font-size: 10px;
      letter-spacing: .16em;
      text-transform: uppercase;
      color: var(--blue-deep);
      margin-bottom: 1.25rem;
    }

    .hero-content {
      display: flex;
      flex-direction: column;
    }

    .hero-award { order: 1; }
    .hero-eyebrow { order: 2; }
    .hero-decor { order: 3; }
    .hero-content h1 { order: 4; }
    .hero-pills { order: 5; }
    .hero-desc { order: 6; }
    .hero-btns { order: 7; }

    .hero h1 {
      font-family: 'Pacifico', cursive;
      font-size: clamp(2.6rem, 4.8vw, 4.2rem);
      font-weight: 400;
      line-height: 1.1;
      color: var(--ink);
      margin-bottom: 1.25rem;
    }

    .hero h1 em {
      font-style: italic;
      font-weight: 500;
      color: var(--gold);
      background: none;
      -webkit-text-fill-color: var(--gold);
    }

    .hero-desc {
      font-size: 14px;
      font-weight: 300;
      color: var(--ink-soft);
      line-height: 1.8;
      max-width: 420px;
      margin-bottom: 2rem;
    }

    .hero-pills {
      display: flex;
      flex-wrap: wrap;
      gap: .5rem;
      margin-bottom: 1.5rem;
    }

    .hero-pill {
      background: rgba(158, 136, 176, .1);
      border: 1px solid rgba(158, 136, 176, .22);
      padding: 5px 13px;
      border-radius: 20px;
      font-size: 11px;
      font-family: 'Bree Serif', sans-serif;
      color: var(--ink-soft);
      letter-spacing: .04em;
    }

    .hero-btns {
      display: flex;
      gap: .8rem;
      flex-wrap: wrap;
    }

    .btn-main {
      background: var(--ink);
      color: #F5EFFF;
      border: none;
      padding: 13px 28px;
      border-radius: 30px;
      font-family: 'Bree Serif', sans-serif;
      font-size: 14px;
      font-weight: 500;
      cursor: pointer;
      letter-spacing: .03em;
      box-shadow: 0 6px 20px rgba(45, 31, 61, .22);
      transition: transform .2s, box-shadow .2s, background .2s;
    }

    .btn-main:hover {
      background: var(--bg-dark-2);
      transform: translateY(-2px);
      box-shadow: 0 10px 28px rgba(45, 31, 61, .32);
    }

    .btn-ghost {
      background: transparent;
      color: var(--ink);
      border: 1px solid var(--ink);
      padding: 12px 24px;
      border-radius: 30px;
      font-family: 'Bree Serif', sans-serif;
      font-size: 14px;
      cursor: pointer;
      transition: all .2s;
    }

    .btn-ghost:hover {
      background: var(--ink);
      color: #F5EFFF;
    }

    .hero-mosaic {
      display: grid;
      grid-template-columns: 1.1fr .9fr;
      grid-template-rows: 1fr 1fr;
      gap: 12px;
      height: 540px;
    }

    .mosaic-item {
      border-radius: 16px;
      overflow: hidden;
      position: relative;
      box-shadow: 0 16px 40px rgba(45, 27, 105, .12), 0 4px 12px rgba(45, 27, 105, .06);
    }

    .mosaic-item img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      transition: transform .6s;
    }

    .mosaic-item:hover img {
      transform: scale(1.04);
    }

    .mosaic-item--tall {
      grid-row: 1 / -1;
      border-radius: 16px;
    }

    .mosaic-label {
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      padding: 10px 14px;
      background: rgba(255, 255, 255, .28);
      backdrop-filter: blur(12px);
      border-top: 1px solid rgba(255, 255, 255, .4);
      font-size: 12px;
      color: var(--ink);
      font-weight: 400;
    }

    .scroll-cue {
      position: absolute;
      bottom: 2rem;
      left: 50%;
      transform: translateX(-50%);
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 5px;
      opacity: .45;
      animation: cue 2s infinite;
    }

    @keyframes cue {

      0%,
      100% {
        transform: translateX(-50%) translateY(0);
      }

      50% {
        transform: translateX(-50%) translateY(6px);
      }
    }

    .scroll-cue .arr {
      width: 18px;
      height: 18px;
      border-right: 1.5px solid var(--blue);
      border-bottom: 1.5px solid var(--blue);
      transform: rotate(45deg);
    }

    .scroll-cue span {
      font-size: 9px;
      letter-spacing: .14em;
      text-transform: uppercase;
      color: var(--ink-soft);
    }

    /* ── STRIP ──────────────────────────────────────── */
    .strip {
      background: var(--ink);
      border-top: 1px solid rgba(122, 100, 144, .35);
      border-bottom: 1px solid rgba(122, 100, 144, .35);
      padding: .9rem 2.5rem;
      display: flex;
      justify-content: center;
      gap: 3.5rem;
      flex-wrap: wrap;
    }

    .strip-item {
      display: flex;
      align-items: center;
      gap: 9px;
    }

    .strip-icon {
      font-size: 17px;
      color: var(--gold);
    }

    .strip-t1 {
      font-size: 13px;
      font-weight: 500;
      font-family: 'Bree Serif', sans-serif;
      color: rgba(255, 255, 255, .9);
    }

    .strip-t2 {
      font-size: 11px;
      font-weight: 300;
      font-family: 'Bree Serif', sans-serif;
      color: rgba(255, 255, 255, .55);
    }

    /* ── SECTION ────────────────────────────────────── */
    .section {
      padding: 5rem 2.5rem;
      max-width: 1200px;
      margin: 0 auto;
    }

    /* Padding mínimo 80px en secciones principales */
    #campeonas, #telas, #nosotros, #productos {
      padding-top: 80px;
      padding-bottom: 80px;
    }

    .section-full {
      padding: 5rem 0;
    }

    .eyebrow {
      font-size: 10.5px;
      letter-spacing: .2em;
      text-transform: uppercase;
      color: var(--blue-deep);
      margin-bottom: .5rem;
      display: flex;
      align-items: center;
      gap: 8px;
    }

    .eyebrow::before {
      content: '';
      display: inline-block;
      width: 26px;
      height: 1.5px;
      background: var(--blue);
    }

    .sec-title {
      font-family: 'Pacifico', cursive;
      font-size: clamp(1.6rem, 2.8vw, 2.4rem);
      font-weight: 400;
      color: var(--ink);
      margin-bottom: .4rem;
    }

    .sec-sub {
      font-size: 13.5px;
      color: var(--ink-soft);
      line-height: 1.7;
      max-width: 640px;
      margin-bottom: 2.5rem;
    }

    /* ── FILTER BAR ─────────────────────────────────── */
    .filter-bar {
      display: flex;
      align-items: center;
      gap: .6rem;
      flex-wrap: wrap;
      margin-bottom: 2.5rem;
    }
    .filter-btn {
      background: rgba(255, 255, 255, .6);
      backdrop-filter: blur(8px);
      border: 1px solid rgba(158, 136, 176, .25);
      padding: 7px 18px;
      border-radius: 50px;
      font-family: 'Bree Serif', sans-serif;
      font-size: 12.5px;
      color: var(--ink-soft);
      cursor: pointer;
      transition: all .2s;
      white-space: nowrap;
    }

    .filter-btn:hover,
    .filter-btn.active {
      background: var(--accent-purple);
      color: #fff;
      border-color: var(--accent-purple);
      box-shadow: 0 4px 14px rgba(45, 27, 105, .2);
    }

    .search-wrap {
      margin-left: auto;
      position: relative;
    }

    .search-wrap input {
      background: rgba(255, 255, 255, .7);
      backdrop-filter: blur(8px);
      border: 1px solid rgba(158, 136, 176, .25);
      border-radius: 50px;
      padding: 7px 16px 7px 36px;
      font-family: 'Bree Serif', sans-serif;
      font-size: 12.5px;
      color: var(--ink);
      outline: none;
      width: 200px;
      transition: border-color .2s, width .3s;
    }

    .search-wrap input:focus {
      border-color: var(--blue);
      width: 240px;
    }

    .search-wrap .search-icon {
      position: absolute;
      left: 12px;
      top: 50%;
      transform: translateY(-50%);
      font-size: 13px;
      opacity: .4;
      pointer-events: none;
    }

    .product-count {
      font-size: 12px;
      color: var(--ink-muted);
      margin-left: .5rem;
      align-self: center;
    }

    /* ── PRODUCTS GRID ──────────────────────────────── */
    .products-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
      gap: 1.4rem;
    }

    .prod-card {
      background: #FFFFFF;
      border: 1px solid var(--border-soft);
      border-radius: 16px;
      overflow: hidden;
      transition: all 0.2s ease;
      display: flex;
      flex-direction: column;
    }

    .prod-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 12px 32px rgba(45, 27, 105, .10);
    }

    .prod-card[data-hidden="true"] {
      display: none;
    }

    .prod-img {
      height: 260px;
      overflow: hidden;
      position: relative;
      flex-shrink: 0;
    }

    .prod-img img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      transition: transform .5s;
    }

    .prod-card:hover .prod-img img {
      transform: scale(1.05);
    }

    .prod-img-placeholder {
      width: 100%;
      height: 100%;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 8px;
      background: linear-gradient(135deg, var(--blue-pale), var(--amber));
    }

    .prod-img-placeholder .ph-icon {
      font-size: 48px;
      opacity: .4;
    }

    .prod-img-placeholder .ph-txt {
      font-size: 11px;
      color: var(--ink-soft);
      opacity: .5;
      letter-spacing: .06em;
    }

    .prod-tag {
      position: absolute;
      top: 10px;
      left: 10px;
      background: rgba(255, 255, 255, .72);
      backdrop-filter: blur(8px);
      border: 1px solid rgba(255, 255, 255, .8);
      padding: 3px 11px;
      border-radius: 50px;
      font-size: 10px;
      color: var(--blue-deep);
      font-weight: 500;
      letter-spacing: .06em;
    }

    .prod-tag.hot {
      background: rgba(122, 100, 144, 0.88);
      color: #fff;
      border-color: transparent;
      border-radius: 6px;
      font-size: 11px;
      font-weight: 500;
      padding: 4px 10px;
    }

    .prod-tag.new {
      background: rgba(45, 27, 105, .85);
      color: #fff;
      border-color: transparent;
    }

    .prod-body {
      padding: 1rem 1rem 1.2rem;
      flex: 1;
      display: flex;
      flex-direction: column;
    }

    .prod-category {
      font-size: 10px;
      font-family: 'Bree Serif', sans-serif;
      color: var(--blue-deep);
      letter-spacing: .12em;
      text-transform: uppercase;
      margin-bottom: 3px;
    }

    .prod-name {
      font-family: 'Pacifico', cursive;
      font-size: 1.3rem;
      font-weight: 500;
      color: var(--ink);
      margin-bottom: 4px;
      line-height: 1.25;
    }

    .prod-desc {
      font-size: 12px;
      color: var(--ink-soft);
      line-height: 1.6;
      margin-bottom: auto;
      padding-bottom: .9rem;
    }

    .prod-sizes {
      display: flex;
      gap: .4rem;
      flex-wrap: wrap;
      margin-bottom: .9rem;
    }

    .size-chip {
      background: rgba(158, 136, 176, .12);
      border: 1px solid rgba(158, 136, 176, .22);
      padding: 2px 9px;
      border-radius: 50px;
      font-size: 10px;
      color: var(--ink-soft);
    }

    .prod-bottom {
      display: flex;
      align-items: flex-end;
      justify-content: space-between;
      gap: .5rem;
    }

    .prod-price {
      font-family: 'Bree Serif', sans-serif;
      font-size: 1.2rem;
      color: var(--accent-gold);
      font-weight: 600;
      line-height: 1;
    }

    .prod-price-note {
      font-family: 'Bree Serif', sans-serif;
      font-size: 9.5px;
      color: var(--ink-muted);
      margin-top: 2px;
    }

    .add-btn {
      background: var(--accent-purple);
      color: #fff;
      border: none;
      width: 38px;
      height: 38px;
      border-radius: 50%;
      flex-shrink: 0;
      font-size: 20px;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      transition: background .2s, transform .15s;
    }

    .add-btn:hover {
      background: #1E1040;
      transform: scale(1.08);
    }

    .add-btn.done {
      background: var(--accent-gold);
    }

    /* ── LOAD MORE ──────────────────────────────────── */
    .load-wrap {
      text-align: center;
      padding: 2rem 0;
    }

    .btn-load {
      background: transparent;
      color: var(--blue-deep);
      border: 1.5px solid rgba(158, 136, 176, .4);
      padding: 11px 32px;
      border-radius: 50px;
      font-family: 'Bree Serif', sans-serif;
      font-size: 13px;
      cursor: pointer;
      transition: all .2s;
    }

    .btn-load:hover {
      background: rgba(158, 136, 176, .08);
      border-color: var(--blue);
    }

    .btn-load:disabled {
      opacity: .4;
      cursor: default;
    }

    /* ── TELAS ──────────────────────────────────────── */
    .telas-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 1.25rem;
    }

    .tela-card {
      background: rgba(255, 255, 255, .6);
      backdrop-filter: blur(12px);
      border: 1px solid rgba(197, 184, 214, .35);
      border-radius: 18px;
      padding: 1.5rem 1.75rem;
      position: relative;
      overflow: hidden;
      /* Retorno lento y suave (mouse-out) */
      transition: transform 0.65s cubic-bezier(0.22, 1, 0.36, 1),
                  box-shadow 0.65s cubic-bezier(0.22, 1, 0.36, 1);
    }

    .tela-card:hover {
      transform: scale(1.035) translateY(-3px);
      box-shadow: 0 18px 44px rgba(45, 31, 61, .1);
      /* Expansión rápida (mouse-enter) */
      transition: transform 0.22s ease-out,
                  box-shadow 0.22s ease-out;
    }

    .tela-card.featured {
      border-color: rgba(158, 136, 176, .4);
      background: rgba(237, 232, 244, .45);
    }

    .tela-accent {
      position: absolute;
      top: 0;
      right: 0;
      width: 80px;
      height: 80px;
      border-radius: 0 18px 0 80px;
      background: linear-gradient(225deg, rgba(158, 136, 176, .15), transparent);
    }

    .tela-emoji {
      font-size: 22px;
      margin-bottom: .75rem;
      color: var(--gold);
      letter-spacing: 0;
    }

    .tela-name {
      font-family: 'Pacifico', cursive;
      font-size: 19px;
      font-weight: 600;
      color: var(--ink);
      margin-bottom: .3rem;
    }

    .tela-badge {
      display: inline-block;
      background: var(--accent-purple);
      color: #fff;
      font-size: 9px;
      padding: 2px 10px;
      border-radius: 50px;
      letter-spacing: .08em;
      margin-bottom: .6rem;
    }

    .tela-desc {
      font-size: 12.5px;
      color: var(--ink-soft);
      line-height: 1.7;
    }

    /* ── ENVIOS ─────────────────────────────────────── */
    .envios-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 2rem;
    }

    .envio-card {
      background: rgba(255, 255, 255, .6);
      backdrop-filter: blur(12px);
      border: 1px solid rgba(197, 184, 214, .35);
      border-radius: 20px;
      padding: 2rem;
      transition: transform 0.65s cubic-bezier(0.22, 1, 0.36, 1),
                  box-shadow 0.65s cubic-bezier(0.22, 1, 0.36, 1);
    }

    .envio-card:hover {
      transform: scale(1.03) translateY(-3px);
      box-shadow: 0 16px 40px rgba(45, 31, 61, .09);
      transition: transform 0.22s ease-out,
                  box-shadow 0.22s ease-out;
    }

    .envio-card.intl {
      background: linear-gradient(135deg, rgba(237, 232, 244, .5), rgba(242, 224, 208, .4));
    }

    .envio-icon {
      font-size: 20px;
      margin-bottom: 1rem;
      color: var(--gold);
    }

    .envio-title {
      font-family: 'Pacifico', cursive;
      font-size: 22px;
      font-weight: 600;
      color: var(--ink);
      margin-bottom: .5rem;
    }

    .envio-desc {
      font-size: 13px;
      color: var(--ink-soft);
      line-height: 1.75;
      margin-bottom: 1.25rem;
    }

    .countries-wrap {
      display: flex;
      flex-wrap: wrap;
      gap: .4rem;
    }

    .country-badge {
      background: rgba(158, 136, 176, .15);
      border: 1px solid rgba(158, 136, 176, .2);
      padding: 4px 12px;
      border-radius: 50px;
      font-size: 11px;
      color: var(--ink-soft);
    }

    .delivery-badge {
      display: inline-flex;
      align-items: center;
      gap: 7px;
      background: rgba(37, 211, 102, .12);
      border: 1px solid rgba(37, 211, 102, .25);
      padding: 7px 16px;
      border-radius: 50px;
      font-size: 12px;
      color: #1a8a3e;
      font-weight: 500;
      margin-top: .5rem;
    }

    /* ── ABOUT ──────────────────────────────────────── */
    .about-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 4rem;
      align-items: center;
    }

    .about-img-wrap {
      position: relative;
      border-radius: 24px;
      overflow: hidden;
      height: 500px;
    }

    .about-img-wrap img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }

    .about-float {
      position: absolute;
      bottom: 1.5rem;
      left: 1.5rem;
      right: 1.5rem;
      background: rgba(255, 255, 255, .38);
      backdrop-filter: blur(16px);
      border: 1px solid rgba(255, 255, 255, .6);
      border-radius: 16px;
      padding: 1rem 1.25rem;
    }

    .about-float p {
      font-size: 13px;
      color: var(--ink);
      line-height: 1.65;
      font-style: italic;
    }

    .about-float .sig {
      font-size: 11px;
      color: var(--blue-deep);
      margin-top: .5rem;
      font-style: normal;
      font-weight: 500;
    }

    .stats-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 1rem;
      margin-top: 2rem;
    }

    .stat-card {
      background: rgba(255, 255, 255, .52);
      backdrop-filter: blur(10px);
      border: 1px solid rgba(255, 255, 255, .7);
      border-radius: 14px;
      padding: 1rem 1.2rem;
      text-align: center;
    }

    .stat-n {
      font-family: 'Pacifico', cursive;
      font-size: 2.1rem;
      color: var(--accent-gold);
      font-weight: 600;
      line-height: 1;
    }

    .stat-l {
      font-size: 11px;
      color: var(--ink-soft);
      margin-top: 4px;
      letter-spacing: .04em;
    }

    .about-text p {
      font-size: 13.5px;
      color: var(--ink-soft);
      line-height: 1.85;
      margin-bottom: 1.1rem;
    }

    .about-text ul {
      padding-left: 1.25rem;
      margin-bottom: 1.1rem;
    }

    .about-text ul li {
      font-size: 13px;
      color: var(--ink-soft);
      line-height: 1.7;
      margin-bottom: .3rem;
    }

    /* ── TESTIMONIALS ───────────────────────────────── */
    .testimonials-bg {
      background: linear-gradient(135deg, rgba(237, 232, 244, .55), rgba(158, 136, 176, .12));
      padding: 5rem 2.5rem;
      border-top: 1px solid #9E88B0;
      border-bottom: 1px solid #9E88B0;
    }

    .test-grid {
      max-width: 1200px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 1.25rem;
    }

    .test-card {
      background: rgba(255, 255, 255, .55);
      backdrop-filter: blur(12px);
      border: 1px solid rgba(255, 255, 255, .7);
      border-radius: 18px;
      padding: 1.5rem 1.75rem;
    }

    .test-stars {
      color: var(--amber-deep);
      font-size: 14px;
      margin-bottom: .75rem;
      letter-spacing: 2px;
    }

    .test-text {
      font-size: 13px;
      color: var(--ink-soft);
      line-height: 1.75;
      font-style: italic;
      margin-bottom: 1rem;
    }

    .test-author {
      font-size: 12px;
      font-weight: 500;
      color: var(--ink);
    }

    .test-location {
      font-size: 11px;
      color: var(--ink-muted);
    }

    /* ── CART PANEL ─────────────────────────────────── */
    .c-overlay {
      position: fixed;
      inset: 0;
      background: rgba(45, 31, 61, .35);
      backdrop-filter: blur(4px);
      z-index: 300;
      opacity: 0;
      pointer-events: none;
      transition: opacity .3s;
    }

    .c-overlay.show {
      opacity: 1;
      pointer-events: all;
    }

    .cart-panel {
      position: fixed;
      top: 0;
      right: -100%;
      bottom: 0;
      width: min(420px, 100vw);
      background: rgba(237, 230, 220, .97);
      backdrop-filter: blur(28px);
      border-left: 1px solid rgba(158, 136, 176, .18);
      z-index: 310;
      display: flex;
      flex-direction: column;
      transition: right .35s cubic-bezier(.4, 0, .2, 1);
      pointer-events: none;
    }

    .cart-panel.open {
      right: 0;
      pointer-events: auto;
    }

    .c-head {
      padding: 1.2rem 1.5rem;
      border-bottom: 1px solid rgba(158, 136, 176, .12);
      display: flex;
      align-items: center;
      justify-content: space-between;
    }

    .c-head h3 {
      font-family: 'Pacifico', cursive;
      font-size: 22px;
      font-weight: 400;
    }

    .c-close {
      background: rgba(158, 136, 176, .14);
      border: none;
      width: 32px;
      height: 32px;
      border-radius: 50%;
      cursor: pointer;
      font-size: 15px;
      color: var(--ink-soft);
      display: flex;
      align-items: center;
      justify-content: center;
      transition: background .2s;
    }

    .c-close:hover {
      background: rgba(158, 136, 176, .28);
    }

    .c-items {
      flex: 1;
      overflow-y: auto;
      padding: 1rem 1.5rem;
    }

    .c-empty {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      height: 220px;
      gap: 10px;
      opacity: .5;
    }

    .c-empty .ce-icon {
      font-size: 28px;
      color: var(--ink-muted);
    }

    .c-empty p {
      font-size: 14px;
      color: var(--ink-soft);
    }

    .c-item {
      display: flex;
      gap: 11px;
      align-items: center;
      padding: 11px 0;
      border-bottom: 1px solid rgba(158, 136, 176, .1);
    }

    .c-item-img {
      width: 54px;
      height: 54px;
      border-radius: 10px;
      object-fit: cover;
      border: 1px solid rgba(158, 136, 176, .18);
      flex-shrink: 0;
    }

    .c-item-img-ph {
      width: 54px;
      height: 54px;
      border-radius: 10px;
      background: var(--blue-pale);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 22px;
      flex-shrink: 0;
    }

    .ci-info {
      flex: 1;
    }

    .ci-name {
      font-size: 13.5px;
      font-weight: 500;
      color: var(--ink);
      line-height: 1.3;
      margin-bottom: 2px;
    }

    .ci-sub {
      font-size: 11px;
      color: var(--ink-muted);
    }

    .ci-price {
      font-size: 13px;
      color: var(--blue-deep);
      font-weight: 500;
    }

    .ci-qty {
      display: flex;
      align-items: center;
      gap: 6px;
      margin-top: 4px;
    }

    .qty-btn {
      background: rgba(158, 136, 176, .15);
      border: none;
      width: 22px;
      height: 22px;
      border-radius: 50%;
      cursor: pointer;
      font-size: 13px;
      color: var(--ink);
      display: flex;
      align-items: center;
      justify-content: center;
      transition: background .2s;
    }

    .qty-btn:hover {
      background: rgba(158, 136, 176, .3);
    }

    .ci-qty-num {
      font-size: 13px;
      font-weight: 500;
      min-width: 16px;
      text-align: center;
    }

    .ci-rm {
      background: none;
      border: none;
      cursor: pointer;
      color: rgba(158, 136, 176, .5);
      font-size: 17px;
      padding: 3px;
      transition: color .2s;
    }

    .ci-rm:hover {
      color: var(--blue-deep);
    }

    .c-foot {
      padding: 1.2rem 1.5rem;
      border-top: 1px solid rgba(158, 136, 176, .12);
    }

    .c-total-row {
      display: flex;
      justify-content: space-between;
      align-items: baseline;
      margin-bottom: 1rem;
    }

    .c-total-row span {
      font-size: 13px;
      color: var(--ink-soft);
    }

    .c-total-row strong {
      font-family: 'Pacifico', cursive;
      font-size: 27px;
      color: var(--ink);
    }

    .c-wa-btn {
      width: 100%;
      background: #25D366;
      color: #fff;
      border: none;
      padding: 14px;
      border-radius: 50px;
      font-family: 'Bree Serif', sans-serif;
      font-size: 14.5px;
      font-weight: 500;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 9px;
      box-shadow: 0 7px 22px rgba(37, 211, 102, .28);
      transition: transform .2s, box-shadow .2s;
      margin-bottom: 8px;
    }

    .c-wa-btn:hover {
      transform: translateY(-2px);
      box-shadow: 0 10px 30px rgba(37, 211, 102, .38);
    }

    .c-note {
      font-size: 10.5px;
      color: var(--ink-muted);
      text-align: center;
      line-height: 1.5;
    }

    /* ── FOOTER ─────────────────────────────────────── */
    .footer {
      background: var(--bg-dark-3);
      padding: 4rem 2.5rem 2rem;
    }

    .footer-inner {
      max-width: 1200px;
      margin: 0 auto;
    }

    .footer-top {
      display: grid;
      grid-template-columns: 2fr 1fr 1fr 1fr;
      gap: 3rem;
      margin-bottom: 3rem;
    }

    .f-brand .fn {
      font-family: 'Pacifico', cursive;
      font-size: 20px;
      color: #fff;
      margin-bottom: .4rem;
    }

    .f-brand p {
      font-size: 12px;
      color: rgba(255, 255, 255, .42);
      line-height: 1.75;
      max-width: 270px;
      margin-bottom: 1rem;
    }

    .f-social {
      display: flex;
      gap: .6rem;
    }

    .f-soc-btn {
      background: rgba(255, 255, 255, .08);
      border: 1px solid rgba(255, 255, 255, .12);
      color: rgba(255, 255, 255, .6);
      padding: 6px 14px;
      border-radius: 50px;
      font-size: 11px;
      cursor: pointer;
      text-decoration: none;
      transition: all .2s;
    }

    .f-soc-btn:hover {
      background: rgba(158, 136, 176, .25);
      color: #fff;
    }

    .f-col h4 {
      font-size: 10px;
      letter-spacing: .18em;
      text-transform: uppercase;
      color: var(--blue-light);
      margin-bottom: 1rem;
    }

    .f-col a {
      display: block;
      font-size: 12.5px;
      color: rgba(255, 255, 255, .45);
      text-decoration: none;
      margin-bottom: .55rem;
      cursor: pointer;
      transition: color .2s;
    }

    .f-col a:hover {
      color: #fff;
    }

    .footer-bottom {
      border-top: 1px solid rgba(255, 255, 255, .07);
      padding-top: 1.5rem;
      display: flex;
      justify-content: space-between;
      align-items: center;
      flex-wrap: wrap;
      gap: 1rem;
    }

    .footer-bottom p {
      font-size: 11px;
      color: rgba(255, 255, 255, .28);
    }

    /* ── TOAST ──────────────────────────────────────── */
    .toast {
      position: fixed;
      bottom: 2rem;
      left: 50%;
      transform: translateX(-50%) translateY(16px);
      background: var(--ink);
      color: #fff;
      padding: 11px 22px;
      border-radius: 50px;
      font-size: 13px;
      z-index: 400;
      opacity: 0;
      pointer-events: none;
      transition: all .3s;
      border: 1px solid rgba(158, 136, 176, .3);
      display: flex;
      align-items: center;
      gap: 8px;
      white-space: nowrap;
    }

    .toast.show {
      opacity: 1;
      transform: translateX(-50%) translateY(0);
    }

    /* ── SECTION BACKGROUNDS ────────────────────────── */
    #productos {
      background: var(--bg-base);
    }

    #telas {
      background: var(--bg-alt);
      border-top: 1px solid var(--border-soft);
      border-bottom: 1px solid var(--border-soft);
    }

    #nosotros {
      background: var(--bg-base);
      border-top: 1px solid var(--border-soft);
    }

    #contacto {
      background: #EAE4F5;
    }

    #contacto .sec-title {
      font-family: 'Cormorant Garamond', 'Cinzel', serif;
      font-size: clamp(2.2rem, 4vw, 3rem);
      font-weight: 600;
      color: var(--ink);
      max-width: 600px;
      margin: 0 auto .5rem;
      text-align: center;
    }

    #contacto .sec-sub {
      color: var(--ink-soft);
      text-align: center;
      max-width: 560px;
      margin: 0 auto 2rem;
    }

    /* ── CONTACT CARDS ───────────────────────────────── */
    .contact-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
      gap: 1.2rem;
    }

    .contact-card {
      background: rgba(255, 255, 255, .07);
      border: 0.5px solid rgba(255, 255, 255, .15);
      border-radius: 18px;
      padding: 1.75rem;
      text-align: center;
    }

    .contact-icon {
      font-size: 20px;
      margin-bottom: .75rem;
      color: var(--gold);
    }

    .contact-title {
      font-family: 'Pacifico', cursive;
      font-size: 19px;
      color: #F5EFFF;
      margin-bottom: .4rem;
    }

    .contact-desc {
      font-size: 12.5px;
      font-family: 'Bree Serif', sans-serif;
      color: var(--blue-light);
      line-height: 1.65;
      margin-bottom: 1rem;
    }

    .contact-btn {
      display: inline-block;
      padding: 9px 22px;
      border-radius: 30px;
      font-family: 'Bree Serif', sans-serif;
      font-size: 13px;
      font-weight: 500;
      cursor: pointer;
      text-decoration: none;
      border: none;
      transition: transform .2s, opacity .2s;
    }

    .contact-btn:hover {
      transform: translateY(-1px);
      opacity: .9;
    }

    .contact-btn--wa {
      background: #25D366;
      color: #fff;
    }

    .contact-btn--ig {
      background: linear-gradient(135deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888);
      color: #fff;
    }

    .contact-btn--tk {
      background: rgba(197, 184, 214, .2);
      color: var(--blue-light);
      border: 0.5px solid rgba(197, 184, 214, .3);
    }

    /* ── HERO AWARD BADGE ───────────────────────────── */
    .hero-award {
      display: inline-flex;
      align-items: center;
      gap: 7px;
      background: rgba(158, 136, 176, .12);
      border: 0.5px solid var(--blue);
      padding: 5px 16px;
      border-radius: 50px;
      font-size: 10px;
      letter-spacing: .1em;
      text-transform: uppercase;
      font-family: 'Bree Serif', sans-serif;
      color: var(--blue-deep);
      font-weight: 500;
      margin-bottom: .85rem;
    }

    /* ── HERO DECORATIVE LINE ────────────────────────── */
    .hero-decor {
      display: flex;
      align-items: center;
      gap: 10px;
      margin-bottom: 1.1rem;
      font-family: 'Pacifico', cursive;
      font-size: 13px;
      color: rgba(158, 136, 176, .55);
      letter-spacing: .12em;
    }

    .hero-decor::before,
    .hero-decor::after {
      content: '';
      flex: 1;
      max-width: 55px;
      height: 1px;
      background: linear-gradient(90deg, transparent, rgba(158, 136, 176, .42));
    }

    .hero-decor::after {
      background: linear-gradient(270deg, transparent, rgba(158, 136, 176, .42));
    }

    /* ── CHAMPIONS SECTION ───────────────────────────── */
    .champions-section {
      padding: 5.5rem 0 5rem;
      background: var(--bg-alt);
      border-bottom: none;
    }

    .champions-section .eyebrow {
      color: var(--accent-purple);
      opacity: .9;
    }

    .champions-section .eyebrow::before {
      background: var(--accent-gold);
    }

    .champions-section .sec-title {
      color: var(--ink);
    }

    .champions-section .sec-sub {
      color: var(--ink-soft);
    }

    .champions-section .champions-note {
      color: var(--ink-muted);
    }

    .champions-intro {
      display: flex;
      align-items: flex-end;
      justify-content: space-between;
      gap: 2rem;
      margin-bottom: 2.75rem;
      flex-wrap: wrap;
    }

    .champions-intro-text .sec-title,
    .champions-intro-text .eyebrow {
      margin-bottom: .3rem;
    }

    .champions-note {
      font-size: 11.5px;
      color: var(--ink-muted);
      font-style: italic;
      letter-spacing: .04em;
      white-space: nowrap;
    }

    .champions-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 1.5rem;
    }

    .champion-card {
      background: #fff;
      border: 1px solid var(--border-soft);
      border-radius: 12px;
      overflow: hidden;
      transition: transform .35s, box-shadow .35s;
      position: relative;
    }

    .champion-card:hover {
      transform: translateY(-6px);
      box-shadow: 0 20px 48px rgba(45, 31, 61, .12);
      border-color: rgba(158, 136, 176, .45);
    }

    .champion-card::before {
      content: '';
      position: absolute;
      inset: 0;
      border-radius: 12px;
      background: linear-gradient(160deg, rgba(158, 136, 176, .06), transparent 55%);
      pointer-events: none;
      z-index: 1;
    }

    .champion-photo {
      width: 100%;
      aspect-ratio: 3 / 4;
      overflow: hidden;
      position: relative;
      background: linear-gradient(158deg, var(--bg-alt) 0%, var(--border-soft) 100%);
    }

    .champion-photo img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: top center;
      display: block;
      transition: transform .55s ease;
      filter: contrast(1.05);
      border-radius: 10px 10px 0 0;
    }

    .champion-card:hover .champion-photo img {
      transform: scale(1.05);
    }

    .champion-photo img ~ .champion-photo-placeholder {
      display: none;
    }

    .champion-photo-placeholder {
      width: 100%;
      height: 100%;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 10px;
    }

    .champion-photo-placeholder .ph-crown {
      font-size: 40px;
      opacity: .38;
    }

    .champion-photo-placeholder .ph-text {
      font-size: 9px;
      letter-spacing: .16em;
      text-transform: uppercase;
      color: var(--ink-soft);
      opacity: .45;
    }

    .champion-photo-overlay {
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      height: 60px;
      background: linear-gradient(0deg, rgba(240, 232, 218, .3), transparent);
      pointer-events: none;
    }

    .champion-body {
      padding: 1.1rem 1.3rem 1.4rem;
      position: relative;
      z-index: 2;
    }

    .champion-badge {
      display: inline-block;
      background: rgba(158, 136, 176, .15);
      border: 0.5px solid rgba(158, 136, 176, .35);
      color: var(--blue-deep);
      font-size: 9px;
      letter-spacing: .1em;
      text-transform: uppercase;
      padding: 3px 11px;
      border-radius: 50px;
      margin-bottom: .6rem;
      font-family: 'Bree Serif', sans-serif;
      font-weight: 500;
    }

    .champion-name {
      font-family: 'Pacifico', cursive;
      font-size: 1.3rem;
      font-weight: 600;
      color: var(--ink);
      line-height: 1.2;
      margin-bottom: .25rem;
    }

    .champion-title {
      font-size: 11px;
      font-family: 'Bree Serif', sans-serif;
      color: var(--ink-soft);
      font-weight: 400;
      margin-bottom: .55rem;
      letter-spacing: .03em;
    }

    .champion-desc {
      font-size: 0.85rem;
      font-family: 'Bree Serif', sans-serif;
      color: var(--ink-soft);
      line-height: 1.68;
      opacity: .85;
    }

    /* ── TESTIMONIALS QUOTE DECORATION ─────────────── */
    .test-card {
      position: relative;
      overflow: hidden;
    }

    .test-card::before {
      content: '\201C';
      position: absolute;
      top: -18px;
      left: 14px;
      font-family: 'Pacifico', cursive;
      font-size: 110px;
      color: rgba(158, 136, 176, .12);
      line-height: 1;
      pointer-events: none;
      font-style: italic;
    }

    /* ── REVEAL ANIMATION ───────────────────────────── */
    .rv {
      opacity: 0;
      transform: translateY(24px);
      transition: opacity .55s ease, transform .55s ease;
    }

    .rv.vi {
      opacity: 1;
      transform: none;
    }

    /* ── RESPONSIVE ─────────────────────────────────── */
    @media(max-width:1024px) {
      .hero-inner {
        grid-template-columns: 1fr;
      }

      .hero-mosaic {
        display: grid;
        height: 260px;
        grid-template-columns: 1fr;
        grid-template-rows: 1fr;
      }

      .mosaic-item--tall {
        grid-row: 1;
        border-radius: 16px;
      }

      .about-grid {
        grid-template-columns: 1fr;
      }

      .telas-grid {
        grid-template-columns: 1fr 1fr;
      }

      .envios-grid {
        grid-template-columns: 1fr;
      }

      .footer-top {
        grid-template-columns: 1fr 1fr;
      }

      .test-grid {
        grid-template-columns: 1fr 1fr;
      }

      .champions-grid {
        grid-template-columns: 1fr 1fr;
        gap: 1.2rem;
      }
    }

    @media(max-width:768px) {
      #campeonas, #telas, #nosotros, #productos {
        padding-top: 48px;
        padding-bottom: 48px;
      }

      .section {
        padding: 3rem 1.25rem;
      }

      .header {
        padding: 0 1rem;
        height: auto;
        min-height: 60px;
        flex-wrap: nowrap;
      }

      .logo-img {
        width: 42px;
        height: 42px;
      }

      .brand-text .name {
        font-size: clamp(0.95rem, 4.2vw, 1.15rem);
        max-width: 52vw;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
      }

      .header-actions {
        gap: 0.45rem;
        flex-shrink: 0;
      }

      .wa-header {
        padding: 8px 11px;
        font-size: 11px;
      }

      .cart-btn {
        padding: 8px 12px;
        font-size: 12px;
      }

      .desktop-nav {
        display: none;
      }

      .hamburger {
        display: flex;
      }

      .strip {
        gap: 1.5rem;
      }

      .telas-grid {
        grid-template-columns: 1fr;
      }

      .test-grid {
        grid-template-columns: 1fr;
      }

      .champions-grid {
        grid-template-columns: 1fr 1fr;
        gap: 1rem;
      }

      .champions-note {
        display: none;
      }

      .hero-mosaic {
        height: 240px;
      }

      .mosaic-item:not(.mosaic-item--tall) {
        display: none;
      }

      .stats-grid {
        grid-template-columns: 1fr 1fr;
      }

      .footer-top {
        grid-template-columns: 1fr;
      }
    }

    @media(max-width:520px) {
      .wa-header__label {
        display: none;
      }

      .wa-header {
        padding: 8px 11px;
      }

      .cart-btn__label {
        display: none;
      }

      .cart-btn {
        padding: 8px 12px;
        gap: 6px;
      }
    }

/* ═══════════════════════════════════════════════════════════
   PRODUCT MODAL — Misma estética del sitio (vertical)
═══════════════════════════════════════════════════════════ */
    #prodModal {
      position: fixed;
      inset: 0;
      z-index: 9000;
      background: rgba(45, 31, 61, .42);
      backdrop-filter: blur(12px);
      -webkit-backdrop-filter: blur(12px);
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 1rem;
      opacity: 0;
      pointer-events: none;
      transition: opacity .3s ease;
    }

    #prodModal.open {
      opacity: 1;
      pointer-events: all;
    }

    .modal-content {
      background: linear-gradient(165deg, rgba(255, 255, 255, .92) 0%, var(--cream) 45%, var(--blue-pale) 100%);
      border: 1px solid rgba(158, 136, 176, .45);
      border-radius: 22px;
      width: 100%;
      max-width: 420px;
      max-height: 92vh;
      display: flex;
      flex-direction: column;
      overflow: hidden;
      transform: translateY(24px) scale(.97);
      transition: transform .38s cubic-bezier(.16, 1, .3, 1);
      position: relative;
      box-shadow: 0 28px 80px rgba(122, 100, 144, .22), 0 0 0 1px rgba(158, 136, 176, .12);
    }

    #prodModal.open .modal-content {
      transform: translateY(0) scale(1);
    }

    .modal-content #modalTag .prod-tag {
      position: static;
      display: inline-block;
      margin-bottom: .35rem;
    }

    .modal-close-btn {
      position: absolute;
      top: .75rem;
      right: .75rem;
      z-index: 20;
      background: rgba(255, 255, 255, .85);
      border: 1px solid rgba(158, 136, 176, .35);
      color: var(--ink-soft);
      width: 38px;
      height: 38px;
      border-radius: 50%;
      cursor: pointer;
      font-size: 1.15rem;
      display: flex;
      align-items: center;
      justify-content: center;
      transition: all .2s;
      line-height: 1;
      padding: 0;
      -webkit-tap-highlight-color: transparent;
    }

    .modal-close-btn:hover {
      background: #fff;
      color: var(--ink);
      border-color: var(--blue);
    }

    .modal-gallery {
      flex-shrink: 0;
      background: linear-gradient(180deg, var(--blue-pale) 0%, rgba(250, 245, 238, .9) 100%);
      display: flex;
      flex-direction: column;
      overflow: hidden;
      border-bottom: 1px solid rgba(158, 136, 176, .28);
    }

    .gallery-main {
      position: relative;
      overflow: hidden;
      width: 100%;
      aspect-ratio: 3 / 4;
      max-height: min(52vh, 420px);
    }

    .gallery-main img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      transition: transform .45s ease;
    }

    .gallery-main img:hover {
      transform: scale(1.02);
    }

    .gallery-nav-btn {
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      background: rgba(255, 255, 255, .88);
      border: 1px solid rgba(158, 136, 176, .4);
      color: var(--blue-deep);
      width: 42px;
      height: 42px;
      border-radius: 50%;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.5rem;
      z-index: 5;
      transition: background .2s, border-color .2s, color .2s;
      -webkit-tap-highlight-color: transparent;
      box-shadow: 0 4px 14px rgba(122, 100, 144, .15);
    }

    .gallery-nav-btn:hover {
      background: #fff;
      border-color: var(--blue);
      color: var(--ink);
    }

    #galleryPrev {
      left: .55rem;
    }

    #galleryNext {
      right: .55rem;
    }

    .gallery-thumbs {
      display: flex;
      gap: .45rem;
      padding: .55rem .65rem;
      background: rgba(250, 245, 238, .75);
      overflow-x: auto;
      border-top: 1px solid rgba(158, 136, 176, .15);
    }

    .gallery-thumbs::-webkit-scrollbar {
      height: 3px;
    }

    .gallery-thumbs::-webkit-scrollbar-thumb {
      background: rgba(158, 136, 176, .45);
      border-radius: 2px;
    }

    .gallery-thumb {
      width: 56px;
      height: 56px;
      flex-shrink: 0;
      border: 2px solid transparent;
      border-radius: 10px;
      overflow: hidden;
      cursor: pointer;
      transition: border-color .2s, opacity .2s;
      opacity: .72;
    }

    .gallery-thumb.active {
      border-color: #9E88B0;
      opacity: 1;
      box-shadow: 0 0 0 1px rgba(158, 136, 176, .25);
    }

    .gallery-thumb:hover {
      opacity: .95;
    }

    .gallery-thumb img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }

    .modal-info {
      padding: 1.25rem 1.35rem 1.4rem;
      overflow-y: auto;
      display: flex;
      flex-direction: column;
      gap: .55rem;
      flex: 1;
      min-height: 0;
    }

    .modal-info::-webkit-scrollbar {
      width: 4px;
    }

    .modal-info::-webkit-scrollbar-thumb {
      background: rgba(158, 136, 176, .35);
      border-radius: 2px;
    }

    .modal-cat-label {
      font-size: .65rem;
      letter-spacing: .18em;
      text-transform: uppercase;
      color: var(--blue-deep);
      font-weight: 600;
    }

    .modal-prod-name {
      font-family: 'Pacifico', cursive;
      font-size: 1.35rem;
      font-weight: 600;
      color: var(--ink);
      line-height: 1.22;
    }

    .modal-prod-desc {
      font-size: .84rem;
      color: var(--ink-soft);
      line-height: 1.65;
    }

    .modal-prod-fabric {
      font-size: .78rem;
      color: var(--blue-deep);
      opacity: .9;
    }

    .modal-sizes-label {
      font-size: .74rem;
      color: var(--ink-muted);
      margin-bottom: .25rem;
    }

    .modal-size-chips {
      display: flex;
      flex-wrap: wrap;
      gap: .4rem;
    }

    .modal-size-chip {
      padding: .35rem .75rem;
      border: 1.5px solid rgba(158, 136, 176, .35);
      border-radius: 20px;
      font-size: .78rem;
      color: var(--ink-soft);
      cursor: pointer;
      transition: all .18s;
      white-space: nowrap;
      background: rgba(255, 255, 255, .55);
      -webkit-tap-highlight-color: transparent;
      font-family: inherit;
    }

    .modal-size-chip.active,
    .modal-size-chip:hover {
      border-color: #9E88B0;
      background: rgba(158, 136, 176, .14);
      color: var(--blue-deep);
    }

    .modal-price-block {
      margin-top: auto;
      padding-top: .75rem;
      border-top: 1px solid rgba(158, 136, 176, .22);
    }

    #modalPrice {
      font-size: 1.75rem;
      font-weight: 700;
      color: var(--blue-deep);
      font-family: 'Pacifico', cursive;
    }

    .modal-price-note {
      font-size: .65rem;
      color: var(--ink-muted);
    }

    .modal-add-btn {
      margin-top: .65rem;
      width: 100%;
      padding: .9rem 1rem;
      background: linear-gradient(135deg, var(--blue), var(--blue-deep));
      border: none;
      border-radius: 50px;
      color: #fff;
      font-size: .92rem;
      font-weight: 600;
      cursor: pointer;
      letter-spacing: .04em;
      transition: transform .2s, box-shadow .2s;
      -webkit-tap-highlight-color: transparent;
      font-family: inherit;
      box-shadow: 0 6px 20px rgba(122, 100, 144, .28);
    }

    .modal-add-btn:hover {
      transform: translateY(-2px);
      box-shadow: 0 10px 28px rgba(122, 100, 144, .35);
    }

    .modal-add-btn:active {
      transform: translateY(0);
    }

    /* Eye icon button for variant products */
    .add-btn-eye {
      font-size: .9rem !important;
    }

    /* ── MOBILE MODAL ─────────────────────────────────────── */
    @media(max-width:640px) {
      #prodModal {
        align-items: flex-end;
        padding: 0;
      }

      .modal-content {
        max-width: 100%;
        border-radius: 22px 22px 0 0;
        max-height: 94vh;
      }

      .gallery-main {
        max-height: 46vh;
      }

      .modal-info {
        padding: 1.1rem 1.15rem 1.25rem;
        gap: .5rem;
      }

      .modal-prod-name {
        font-size: 1.18rem;
      }

      #modalPrice {
        font-size: 1.5rem;
      }
    }

    /* ══════════════════════════════════════════════════════════
   MOBILE RESPONSIVE — Grid & Filters
══════════════════════════════════════════════════════════ */
    @media(max-width:768px) {
      #productsGrid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: .85rem !important;
      }

      .prod-name {
        font-size: .88rem !important;
      }

      .prod-desc {
        font-size: .76rem !important;
        -webkit-line-clamp: 2 !important;
        line-clamp: 2 !important;
      }

      .prod-price {
        font-size: 1.05rem !important;
      }

      .prod-price-note {
        font-size: .66rem !important;
      }

      .add-btn {
        width: 32px !important;
        height: 32px !important;
        font-size: 1rem !important;
      }

      .prod-card {
        border-radius: 14px !important;
      }

      .prod-body {
        padding: .85rem !important;
      }
    }

    @media(max-width:440px) {
      #productsGrid {
        grid-template-columns: 1fr !important;
      }

      .prod-card {
        max-width: 420px;
        margin: 0 auto;
        width: 100%;
      }
    }

    /* Filter bar horizontal scroll */
    .filter-bar {
      overflow-x: auto;
      -webkit-overflow-scrolling: touch;
      padding-bottom: .3rem;
      scrollbar-width: none;
    }

    .filter-bar::-webkit-scrollbar {
      display: none;
    }

    @media(max-width:600px) {
      .filter-btn {
        flex-shrink: 0 !important;
        white-space: nowrap !important;
        font-size: .75rem !important;
        padding: .4rem .82rem !important;
      }
    }

    /* Cart mobile: bottom sheet — oculto con transform (evita right:0 forzado siempre visible) */
    @media(max-width:600px) {
      .cart-panel {
        top: auto !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
        max-height: min(88vh, calc(100dvh - env(safe-area-inset-bottom, 0px))) !important;
        padding-bottom: env(safe-area-inset-bottom, 0px) !important;
        border-radius: 20px 20px 0 0 !important;
        border-left: none !important;
        border-top: 1px solid rgba(158, 136, 176, .25) !important;
        transform: translateY(110%);
        transition: transform .38s cubic-bezier(.4, 0, .2, 1) !important;
      }

      .cart-panel.open {
        transform: translateY(0) !important;
      }
    }

    /* Touch-friendly targets */
    @media(hover:none) {

      .add-btn,
      .qty-btn,
      .ci-rm,
      .modal-close-btn {
        min-width: 44px;
        min-height: 44px;
      }

      .filter-btn {
        min-height: 42px;
      }
    }

    /* ── DESKTOP TYPOGRAPHY OVERRIDE (≥768px) ─────────── */
    @media (min-width: 768px) {

      /* Hero h1 → Cinzel */
      .hero h1 {
        font-family: 'Cinzel', serif;
        font-weight: 600;
        font-optical-sizing: auto;
        font-size: clamp(2.8rem, 4.5vw, 4.6rem);
        line-height: 1.15;
      }

      .hero h1 em {
        font-style: normal;
        color: var(--accent-gold);
        -webkit-text-fill-color: var(--accent-gold);
      }

      /* Todos los demás títulos → Jost 500 */
      .sec-title,
      .champion-name,
      .tela-name,
      .envio-title,
      .prod-name,
      .stat-n,
      .f-brand .fn,
      .c-head h3,
      .modal-prod-name,
      #modalPrice,
      .contact-title {
        font-family: 'Jost', sans-serif;
        font-weight: 500;
        font-optical-sizing: auto;
      }

      /* Excepción: "Todos nuestros productos" en catálogo → mantiene Pacifico */
      #productos .sec-title {
        font-family: 'Pacifico', cursive;
        font-weight: 400;
      }

      /* Contacto → Cormorant Garamond para impacto */
      #contacto .sec-title {
        font-family: 'Cormorant Garamond', serif;
        font-weight: 600;
        font-size: clamp(2.4rem, 4vw, 3rem);
        color: var(--ink);
      }

      /* Eyebrow: color acento dorado */
      .eyebrow {
        color: var(--accent-purple);
      }

      /* Stat numbers: color dorado */
      .stat-n {
        color: var(--accent-gold);
      }
    }

  /* ══════════════════════════════════════════════════════
     TELAS + ENVÍOS COMBINADO
  ══════════════════════════════════════════════════════ */
  .telas-envios-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: start;
  }

  .te-col .telas-grid {
    display: flex;
    flex-direction: column;
    gap: 1rem;
  }

  .te-col .envios-grid {
    display: flex;
    flex-direction: column;
    gap: 1rem;
  }

  @media (max-width: 900px) {
    .telas-envios-grid {
      grid-template-columns: 1fr;
      gap: 3rem;
    }
  }

  /* ══════════════════════════════════════════════════════
     CONTACTO — CONVERSION STRIP
  ══════════════════════════════════════════════════════ */
  .contact-strip {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding-top: 5rem;
    padding-bottom: 5rem;
    max-width: 680px;
  }

  .contact-proof-points {
    display: flex;
    gap: 2rem;
    flex-wrap: wrap;
    justify-content: center;
    margin: 1.5rem 0 2.5rem;
  }

  .proof-point {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .9rem;
    font-family: 'Jost', sans-serif;
    font-weight: 500;
    color: var(--ink);
    letter-spacing: .02em;
  }

  .proof-icon {
    color: var(--accent-gold);
    font-size: 1rem;
  }

  .contact-wa-cta {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .85rem;
  }

  .wa-main-btn {
    display: inline-flex;
    align-items: center;
    gap: .75rem;
    background: #25D366;
    color: #fff;
    border: none;
    border-radius: 50px;
    padding: 14px 32px;
    font-size: 1rem;
    font-family: 'Jost', sans-serif;
    font-weight: 500;
    cursor: pointer;
    box-shadow: 0 8px 32px rgba(37, 211, 102, 0.35);
    transition: transform .25s ease, box-shadow .25s ease;
    letter-spacing: .02em;
  }

  .wa-main-btn:hover {
    transform: translateY(-3px) scale(1.03);
    box-shadow: 0 14px 40px rgba(37, 211, 102, 0.52);
  }

  .wa-cta-note {
    font-size: .8rem;
    color: var(--ink-muted);
    letter-spacing: .03em;
  }

  /* ── DIVISORES SECCIÓN ──────────────────────────── */
  .champions-section + .strip,
  #campeonas + .strip {
    border-top: 1px solid var(--border-soft);
  }

  #telas {
    border-top: 1px solid var(--border-soft);
    border-bottom: 1px solid var(--border-soft);
  }

  /* ── SOCIAL PILLS ────────────────────────────────── */
  .social-cards-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
    max-width: 780px;
    margin: 0 auto;
  }

  @media (max-width: 700px) {
    .social-cards-row {
      grid-template-columns: 1fr;
      max-width: 400px;
      gap: .75rem;
    }
  }

  .social-pill {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .75rem;
    padding: 1.5rem 1.25rem;
    background: rgba(255, 255, 255, .7);
    border: 1px solid var(--border-soft);
    border-top: 4px solid transparent;
    border-radius: 12px;
    text-decoration: none;
    color: var(--ink);
    cursor: pointer;
    text-align: center;
    transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
  }

  .social-pill:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 32px rgba(45, 31, 61, .1);
    background: rgba(255, 255, 255, .95);
  }

  .social-pill--ig { border-top-color: #E1306C; }
  .social-pill--fb { border-top-color: #1877F2; }
  .social-pill--tk { border-top-color: #2D1F3D; }

  .social-pill-icon {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .social-pill-icon svg {
    width: 28px;
    height: 28px;
  }

  .social-pill-info { text-align: center; }

  .social-pill-name {
    font-family: 'Jost', sans-serif;
    font-weight: 600;
    font-size: 1rem;
    line-height: 1.2;
    color: var(--ink);
  }

  .social-pill-handle {
    font-size: .78rem;
    color: var(--ink-soft);
    margin-top: 3px;
  }

  .social-pill-arrow {
    font-size: .9rem;
    color: var(--ink-muted);
    transition: transform .2s ease, color .2s ease;
  }

  .social-pill:hover .social-pill-arrow {
    transform: translateY(-2px);
    color: var(--blue);
  }


  /* ══════════════════════════════════════════════════════
     CHECKOUT MODAL
  ══════════════════════════════════════════════════════ */
  .co-modal {
    position: fixed;
    inset: 0;
    z-index: 9100;
    background: rgba(45, 31, 61, .45);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    display: none;
    align-items: center;
    justify-content: center;
    padding: 1rem;
  }

  .co-panel {
    background: linear-gradient(160deg, #fff 0%, var(--bg-alt) 100%);
    border: 1px solid var(--border-soft);
    border-radius: 20px;
    width: 100%;
    max-width: 500px;
    max-height: 92vh;
    overflow-y: auto;
    padding: 1.75rem 1.75rem 1.5rem;
    position: relative;
    box-shadow: 0 32px 80px rgba(45, 31, 61, .22);
  }

  .co-panel::-webkit-scrollbar { width: 4px; }
  .co-panel::-webkit-scrollbar-thumb { background: var(--border-soft); border-radius: 2px; }

  .co-close {
    position: absolute;
    top: .9rem;
    right: .9rem;
    background: rgba(158, 136, 176, .14);
    border: none;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    cursor: pointer;
    font-size: 14px;
    color: var(--ink-soft);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .2s;
  }
  .co-close:hover { background: rgba(158, 136, 176, .28); }

  .co-header {
    display: flex;
    align-items: center;
    gap: .9rem;
    margin-bottom: 1.25rem;
    padding-right: 2rem;
  }

  .co-header-icon { font-size: 1.8rem; }

  .co-title {
    font-family: 'Jost', sans-serif;
    font-size: 1.2rem;
    font-weight: 600;
    color: var(--ink);
    margin-bottom: .1rem;
  }

  .co-subtitle {
    font-size: .78rem;
    color: var(--ink-soft);
  }

  .co-summary {
    background: rgba(255,255,255,.65);
    border: 1px solid var(--border-soft);
    border-radius: 12px;
    padding: .75rem 1rem;
    margin-bottom: .5rem;
  }

  .co-item {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: .3rem 0;
    border-bottom: 1px solid rgba(197, 184, 214, .2);
    font-size: .85rem;
    gap: 1rem;
  }
  .co-item:last-child { border-bottom: none; }

  .co-item-name {
    color: var(--ink);
    flex: 1;
  }
  .co-item-name em {
    font-style: normal;
    color: var(--ink-muted);
    font-size: .8rem;
  }

  .co-item-price {
    color: var(--blue);
    font-weight: 600;
    white-space: nowrap;
    font-size: .9rem;
  }

  .co-total-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--blue-deep);
    color: #fff;
    border-radius: 10px;
    padding: .65rem 1rem;
    font-size: .85rem;
    margin-bottom: 1.2rem;
  }
  .co-total-bar strong {
    font-family: 'Jost', sans-serif;
    font-size: 1.1rem;
  }

  .co-fieldset {
    border: none;
    padding: 0;
    margin: 0 0 1rem;
  }

  .co-legend {
    font-size: .78rem;
    font-weight: 600;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--ink-soft);
    margin-bottom: .65rem;
    display: block;
  }

  .co-radio-group {
    display: flex;
    gap: .65rem;
    flex-wrap: wrap;
  }

  .co-radio-opt {
    flex: 1;
    min-width: 130px;
    cursor: pointer;
  }

  .co-radio-opt input { display: none; }

  .co-radio-box {
    display: flex;
    align-items: center;
    gap: .5rem;
    padding: .7rem 1rem;
    border: 1.5px solid var(--border-soft);
    border-radius: 10px;
    background: rgba(255,255,255,.6);
    transition: all .18s;
    font-size: .85rem;
    color: var(--ink-soft);
  }

  .co-radio-opt input:checked + .co-radio-box {
    border-color: var(--blue);
    background: rgba(158, 136, 176, .12);
    color: var(--ink);
    font-weight: 500;
  }

  .co-radio-icon { font-size: 1rem; }
  .co-radio-label { font-size: .85rem; }

  .co-address-fields { margin-bottom: .75rem; }

  .co-field { margin-bottom: .75rem; }

  .co-label {
    display: block;
    font-size: .75rem;
    font-weight: 600;
    color: var(--ink-soft);
    letter-spacing: .06em;
    text-transform: uppercase;
    margin-bottom: .3rem;
  }

  .co-input {
    width: 100%;
    padding: .65rem .9rem;
    border: 1.5px solid var(--border-soft);
    border-radius: 9px;
    font-family: 'Bree Serif', sans-serif;
    font-size: .85rem;
    color: var(--ink);
    background: rgba(255,255,255,.8);
    outline: none;
    transition: border-color .2s;
    -webkit-appearance: none;
    appearance: none;
  }
  .co-input:focus { border-color: var(--blue); }

  .co-select { cursor: pointer; }

  .co-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .65rem;
    margin-bottom: .75rem;
  }

  .co-send-btn {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .65rem;
    background: #25D366;
    color: #fff;
    border: none;
    border-radius: 50px;
    padding: .95rem 1.5rem;
    font-family: 'Jost', sans-serif;
    font-size: 1rem;
    font-weight: 500;
    cursor: pointer;
    box-shadow: 0 6px 22px rgba(37,211,102,.32);
    transition: transform .2s, box-shadow .2s;
    margin-top: 1.1rem;
    margin-bottom: .5rem;
  }
  .co-send-btn:hover { transform: translateY(-2px); box-shadow: 0 10px 30px rgba(37,211,102,.42); }

  .co-note {
    font-size: .73rem;
    color: var(--ink-muted);
    text-align: center;
    line-height: 1.5;
  }

  @media (max-width: 520px) {
    .co-panel { padding: 1.25rem 1.1rem 1rem; border-radius: 20px 20px 0 0; }
    .co-modal { align-items: flex-end; padding: 0; }
    .co-row { grid-template-columns: 1fr; }
  }

  /* ══════════════════════════════════════════════════════
     MICROINTERACCIONES
  ══════════════════════════════════════════════════════ */

  /* Pulso WhatsApp — llama la atención cada 4 segundos */
  @keyframes pulse-wa {
    0%, 100% { box-shadow: 0 8px 32px rgba(37,211,102,0.35), 0 0 0 0 rgba(37,211,102,0.4); }
    60%       { box-shadow: 0 8px 32px rgba(37,211,102,0.35), 0 0 0 12px rgba(37,211,102,0); }
  }

  .btn-whatsapp {
    animation: pulse-wa 4s ease 3s infinite;
  }

  .btn-whatsapp:hover {
    animation: none;
    transform: scale(1.03) translateY(-2px);
  }

  /* Eyebrow line: color dorado */
  .eyebrow::before {
    background: var(--accent-gold) !important;
  }

  /* ══════════════════════════════════════════════════════
     FOOTER — CRÉDITO BNJ SYSTEMS
  ══════════════════════════════════════════════════════ */
  .bnj-link {
    color: var(--gold);
    text-decoration: none;
    transition: opacity .2s;
  }

  .bnj-link:hover {
    opacity: .75;
  }

  /* ══════════════════════════════════════════════════════
     SCROLL-DRIVEN SECTION TRANSITIONS — DESKTOP ONLY
  ══════════════════════════════════════════════════════ */
  @media (min-width: 769px) {

    /* ── Hero: sticky background — sections slide over it ── */
    .hero {
      position: sticky;
      top: 0;
      z-index: 1;
      will-change: transform, opacity;
    }

    /* ── Champions: card that slides over the hero ── */
    .champions-section {
      position: relative;
      z-index: 2;
      border-radius: 28px 28px 0 0;
      box-shadow: 0 -24px 64px rgba(30, 16, 64, 0.18);
    }

    /* ── Strip + all subsequent sections cover the sticky hero ── */
    .strip,
    section#productos,
    section#telas,
    section#envios,
    section#nosotros,
    section#contacto,
    .footer {
      position: relative;
      z-index: 2;
    }

    /* ── Products section: card that slides over champions ── */
    section#productos {
      border-radius: 28px 28px 0 0;
      box-shadow: 0 -20px 56px rgba(30, 16, 64, .10);
      background: var(--bg-base);
    }

    /* ══════════════════════════════════════════════════════
       ANIMACIÓN PIANO INVERTIDA — CHAMPION CARDS
       Cada card arranca pequeña + rotada (alternando L/R)
       y se despliega con mucho scale. En hover: agranda + gira.
    ══════════════════════════════════════════════════════ */
    .champion-card {
      transition: transform .45s cubic-bezier(.22, .68, 0, 1.25),
                  box-shadow .45s ease;
      will-change: transform;
    }

    /* Estado inicial para reveal — alternando rotación */
    .champion-card.rv {
      opacity: 0;
      transform: translateY(72px) scale(0.78) rotate(var(--piano-rot, -5deg));
      transition: opacity .8s cubic-bezier(.22, .68, 0, 1.1),
                  transform .8s cubic-bezier(.22, .68, 0, 1.1);
      transition-delay: var(--stagger-delay, 0ms);
    }

    .champion-card.rv.vi {
      opacity: 1;
      transform: translateY(0) scale(1) rotate(0deg);
    }

    /* Hover: agranda bastante y gira en sentido opuesto a la rotación inicial */
    .champion-card:hover {
      transform: scale(1.08) rotate(var(--piano-hover-rot, 2deg));
      box-shadow: 0 28px 72px rgba(45, 31, 61, 0.40);
      z-index: 5;
    }

    /* ── Product cards: deeper offset + scale + stagger ── */
    .prod-card.rv {
      transform: translateY(48px) scale(0.95);
      transition: opacity .6s cubic-bezier(.22, .68, 0, 1.1),
                  transform .6s cubic-bezier(.22, .68, 0, 1.1);
      transition-delay: var(--stagger-delay, 0ms);
    }
    .prod-card.rv.vi {
      opacity: 1;
      transform: translateY(0) scale(1);
    }

    /* Global reveal: todas las secciones se revelan con más drama */
    .rv {
      transition: opacity .65s ease, transform .65s ease;
    }

    .tela-card.rv,
    .envio-card.rv,
    .stat-card.rv,
    .te-col.rv {
      transition: opacity .7s cubic-bezier(.22, .68, 0, 1.1),
                  transform .7s cubic-bezier(.22, .68, 0, 1.1);
      transition-delay: var(--stagger-delay, 0ms);
    }
  }

/* COLOR SELECTOR — MODAL */
.modal-color-block {
  margin-top: 1rem;
  padding-top: .85rem;
  border-top: 1px dashed rgba(201,154,114,.3);
}
.modal-color-chips {
  display: flex;
  gap: .65rem;
  flex-wrap: wrap;
  margin: .5rem 0 .3rem;
}
.modal-color-chip {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 3px solid transparent;
  cursor: pointer;
  transition: transform .18s, border-color .18s, box-shadow .18s;
  box-shadow: 0 2px 8px rgba(0,0,0,.22);
  outline: none;
  padding: 0;
}
.modal-color-chip:hover { transform: scale(1.15); }
.modal-color-chip.active {
  border-color: var(--accent-gold);
  transform: scale(1.18);
  box-shadow: 0 0 0 4px rgba(201,154,114,.3), 0 3px 10px rgba(0,0,0,.25);
}
.modal-color-name {
  font-size: .78rem;
  color: var(--ink-soft);
  font-family: 'Jost', sans-serif;
  letter-spacing: .04em;
  text-transform: uppercase;
  margin-top: .2rem;
}
.badge-free {
  display: inline-block;
  background: linear-gradient(135deg, #a8e063, #56ab2f);
  color: #fff;
  font-size: .65rem;
  font-weight: 700;
  font-family: 'Jost', sans-serif;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 20px;
  margin-left: .4rem;
  vertical-align: middle;
  box-shadow: 0 2px 8px rgba(86,171,47,.35);
}
.c-stock-note {
  display: flex;
  align-items: flex-start;
  gap: .55rem;
  background: rgba(255, 243, 205, .85);
  border: 1px solid rgba(201,154,114,.35);
  border-radius: 10px;
  padding: .7rem .95rem;
  margin: .85rem .85rem 0;
  font-size: .75rem;
  color: #7a5c1e;
  line-height: 1.45;
}
.c-stock-note strong { font-weight: 700; }
.c-stock-icon { font-size: .9rem; flex-shrink: 0; margin-top: .05rem; }

/* ══════════════════════════════════════════════════════
   LIGHTBOX PARA IMÁGENES
══════════════════════════════════════════════════════ */
.lightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(0, 0, 0, 0.9);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}
.lightbox.open {
  opacity: 1;
  pointer-events: auto;
}
.lightbox img {
  max-width: 90vw;
  max-height: 90vh;
  object-fit: contain;
  border-radius: 8px;
  box-shadow: 0 10px 40px rgba(0,0,0,0.5);
  transform: scale(0.95);
  transition: transform 0.3s ease;
}
.lightbox.open img {
  transform: scale(1);
}
.lightbox-close {
  position: absolute;
  top: 20px;
  right: 20px;
  background: rgba(255, 255, 255, 0.1);
  border: none;
  color: white;
  font-size: 24px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s;
  z-index: 10000;
}
.lightbox-close:hover {
  background: rgba(255, 255, 255, 0.2);
}
#modalMainImg {
  cursor: zoom-in;
}
