/* shop.css — lean styles for the redesigned shop-first pages (tienda / producto).
   Self-contained brand tokens so these pages don't pull the 256KB legacy style.css. */

@font-face {
  font-family: 'Hanson';
  src: url('/assets/fonts/Hanson-Bold.ttf') format('truetype');
  font-weight: 700; font-display: swap;
}

:root {
  --font-display: 'Inter', 'Helvetica Neue', sans-serif;
  --font-body:    'Inter', 'Helvetica Neue', sans-serif;
  --font-mono:    'Roboto Mono', 'Courier New', monospace;
  --font-hanson:  'Hanson', 'Inter', sans-serif;

  --color-bg:          #D6D2C4;
  --color-surface:     #ccc8b8;
  --color-card:        #e3e0d6;
  --color-divider:     #b8b4a3;
  --color-border:      #a8a494;
  --color-text:        #1a1a1a;
  --color-text-muted:  #4a4a42;
  --color-text-faint:  #8a8778;
  --color-text-inverse:#D6D2C4;
  --color-primary:     #006B3F;
  --color-primary-hover:#005530;
  --color-black:       #1a1a1a;
  --color-white:       #f5f4f0;

  --ease: cubic-bezier(0.16, 1, 0.3, 1);
  --maxw: 1200px;
}

body { font-family: var(--font-body); background: var(--color-bg); color: var(--color-text); }

/* ── Header ─────────────────────────────────────────────── */
.shop-header {
  position: sticky; top: 0; z-index: 40;
  background: rgba(214,210,196,0.92); backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--color-border);
}
.shop-header__bar {
  max-width: var(--maxw); margin: 0 auto;
  display: flex; align-items: center; gap: 14px;
  padding: 12px 16px;
}
.shop-header__logo {
  font-family: var(--font-hanson); font-size: 1.15rem; letter-spacing: 0.14em;
  text-decoration: none; color: var(--color-text); margin-right: auto;
}
.shop-nav { display: flex; gap: 22px; align-items: center; }
.shop-nav > a, .shop-nav .nav-info__btn { line-height: 1; padding: 4px 0; display: inline-flex; align-items: center; }

/* WhatsApp floating button (all pages) */
.wa-fab { position: fixed; right: 18px; bottom: 18px; z-index: 70; width: 52px; height: 52px; border-radius: 50%; background: #25D366; color: #fff; display: flex; align-items: center; justify-content: center; box-shadow: 0 6px 20px rgba(0,0,0,0.25); }
.wa-fab:hover { background: #1ebe5b; }
@media (max-width: 640px) { .wa-fab { right: 14px; bottom: 14px; width: 48px; height: 48px; } }

/* WhatsApp redirect confirmation ("¡Gracias! redirigiendo…") */
.wa-redirect { position: fixed; inset: 0; z-index: 120; display: flex; align-items: center; justify-content: center; padding: 24px; background: rgba(10,10,10,0.72); opacity: 0; transition: opacity 0.25s ease; }
.wa-redirect.is-open { opacity: 1; }
.wa-redirect__card { background: var(--color-card, #fff); border-radius: var(--border-radius-lg, 14px); padding: 30px 26px; max-width: 360px; width: 100%; text-align: center; transform: translateY(10px); transition: transform 0.25s ease; }
.wa-redirect.is-open .wa-redirect__card { transform: translateY(0); }
.wa-redirect__spin { width: 34px; height: 34px; margin: 0 auto 16px; border: 3px solid rgba(37,211,102,0.25); border-top-color: #25D366; border-radius: 50%; animation: waSpin 0.8s linear infinite; }
@keyframes waSpin { to { transform: rotate(360deg); } }
.wa-redirect__h { font-family: var(--font-hanson); font-size: 1.5rem; letter-spacing: 0.03em; }
.wa-redirect__p { color: var(--color-text-muted); font-size: 0.9rem; line-height: 1.6; margin: 8px 0 18px; }
.wa-redirect__go { display: block; background: #25D366; color: #fff; text-decoration: none; font-weight: 700; padding: 12px; border-radius: 999px; font-size: 0.95rem; }
.wa-redirect__go:hover { background: #1ebe5b; }
.wa-redirect__close { display: block; width: 100%; margin-top: 10px; background: none; border: 0; color: var(--color-text-faint); font-size: 0.82rem; cursor: pointer; padding: 6px; }
.shop-nav a {
  font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.12em;
  text-transform: uppercase; text-decoration: none; color: var(--color-text-muted);
}
.shop-nav a:hover, .shop-nav a.is-active { color: var(--color-primary); }
.shop-header__actions { display: flex; align-items: center; gap: 14px; }
.lang-toggle { display: flex; font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.08em; }
.lang-toggle button { color: var(--color-text-faint); padding: 2px 4px; }
.lang-toggle button.is-active { color: var(--color-text); font-weight: 700; text-decoration: underline; }
.cur-toggle { display: flex; font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.08em; }
.cur-toggle button { color: var(--color-text-faint); padding: 2px 4px; }
.cur-toggle button.is-active { color: var(--color-text); font-weight: 700; text-decoration: underline; }
.cart-btn { position: relative; display: flex; align-items: center; color: var(--color-text); }
.cart-btn__count {
  position: absolute; top: -8px; right: -10px; min-width: 16px; height: 16px;
  background: var(--color-primary); color: var(--color-white);
  border-radius: 999px; font-family: var(--font-mono); font-size: 0.6rem;
  display: flex; align-items: center; justify-content: center; padding: 0 4px;
}
.shop-burger { display: none; }

/* drop banner */
.drop-bar {
  background: var(--color-black); color: var(--color-text-inverse);
  font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.22em;
  text-transform: uppercase; text-align: center; padding: 6px;
}

/* ── Filters ────────────────────────────────────────────── */
.shop-filters {
  max-width: var(--maxw); margin: 0 auto; padding: 16px 16px 6px;
  display: flex; flex-wrap: wrap; gap: 8px; align-items: center;
}
.filter-group { display: flex; gap: 8px; flex-wrap: wrap; }
.filter-group--weight { margin-left: auto; }
.chip {
  font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.06em;
  text-transform: uppercase; padding: 6px 13px; border-radius: 999px;
  border: 1px solid var(--color-border); color: var(--color-text-muted);
  background: transparent; white-space: nowrap;
}
.chip.is-active { background: var(--color-black); color: var(--color-white); border-color: var(--color-black); }
.chip--weight.is-active { background: var(--color-primary); border-color: var(--color-primary); }

/* Category bar — big, clear, thumb-friendly */
.cat-bar {
  max-width: var(--maxw); margin: 0 auto; padding: 16px 16px 6px;
  display: flex; gap: 10px; overflow-x: auto; -webkit-overflow-scrolling: touch;
}
.cat-bar::-webkit-scrollbar { display: none; }
.cat-chip {
  font-family: var(--font-mono); font-size: 0.84rem; letter-spacing: 0.04em;
  padding: 11px 20px; border-radius: 999px; white-space: nowrap;
  border: 1.5px solid var(--color-border); color: var(--color-text);
  background: transparent; display: inline-flex; align-items: baseline; gap: 6px;
}
.cat-chip.is-active { background: var(--color-black); color: var(--color-white); border-color: var(--color-black); }
.cat-chip__n { font-size: 0.66rem; opacity: 0.55; font-style: normal; }

/* Color filter — dot + plain label */
.color-bar {
  max-width: var(--maxw); margin: 0 auto; padding: 4px 16px 6px;
  display: flex; gap: 8px; flex-wrap: wrap; align-items: center;
}
.color-chip {
  font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.02em;
  padding: 7px 13px 7px 11px; border-radius: 999px;
  border: 1px solid var(--color-border); color: var(--color-text-muted);
  background: transparent; display: inline-flex; align-items: center; gap: 7px;
}
.color-chip.is-active { border-color: var(--color-text); color: var(--color-text); font-weight: 500; }
.color-dot { width: 15px; height: 15px; border-radius: 50%; border: 1px solid rgba(26,26,26,0.18); display: inline-block; }

/* Collab sub-filter bar (shown only inside Collabs) */
.subcat-bar {
  max-width: var(--maxw); margin: 0 auto; padding: 2px 16px 4px;
  display: flex; gap: 8px; flex-wrap: wrap; align-items: center;
}
.subcat-bar[hidden] { display: none; }
.subcat-chip {
  font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.04em;
  padding: 6px 12px; border-radius: 999px; white-space: nowrap;
  border: 1px solid var(--color-divider); color: var(--color-text-muted); background: transparent;
}
.subcat-chip.is-active { background: var(--color-primary); color: var(--color-white); border-color: var(--color-primary); }
.subcat-chip em { font-style: normal; opacity: 0.6; font-size: 0.62rem; margin-left: 3px; }

/* ── Editorial hero ─────────────────────────────────────── */
.hero { position: relative; }
.hero[hidden] { display: none; }
.hero__img { width: 100%; height: min(82vh, 760px); object-fit: cover; object-position: center 38%; display: block; background: #141414; }
.hero__overlay {
  position: absolute; inset: 0; display: flex; flex-direction: column;
  align-items: center; justify-content: flex-end; text-align: center; gap: 8px;
  padding: 0 16px 8vh; background: linear-gradient(to top, rgba(18,18,16,0.62), rgba(18,18,16,0) 46%);
}
.hero__drop { font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.22em; text-transform: uppercase; color: rgba(245,244,240,0.85); }
.hero__wordmark { font-family: var(--font-hanson); font-size: clamp(2.6rem, 12vw, 6rem); letter-spacing: 0.06em; color: var(--color-white); line-height: 0.95; }
.hero__tag { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.3em; color: rgba(245,244,240,0.9); }
.hero__cta { margin-top: 14px; font-family: var(--font-mono); font-size: 0.74rem; letter-spacing: 0.14em; text-transform: uppercase; background: var(--color-white); color: var(--color-black); padding: 13px 30px; border-radius: 999px; text-decoration: none; }
.hero__cta:hover { background: var(--color-primary); color: var(--color-white); }
/* desktop: anchor the wordmark bottom-left so it never stacks on the centred Kiko mascot */
@media (min-width: 800px) {
  .hero__img { height: min(88vh, 880px); object-position: center 52%; }
  .hero__overlay { align-items: flex-start; text-align: left; padding: 0 0 6vh 6vw; gap: 12px; background: linear-gradient(to top, rgba(18,18,16,0.7), rgba(18,18,16,0) 38%), linear-gradient(to right, rgba(18,18,16,0.55), rgba(18,18,16,0) 42%); }
  .hero__wordmark { font-size: clamp(3.5rem, 7vw, 5.5rem); }
}

/* ── Collections landing (grouped tiles) ────────────────── */
.landing-body[hidden] { display: none; }
.section-head { max-width: var(--maxw); margin: 0 auto; padding: 28px 16px 2px; font-family: var(--font-hanson); font-size: 1.1rem; letter-spacing: 0.08em; }
.coll-grid {
  max-width: var(--maxw); margin: 0 auto; padding: 10px 16px 16px;
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px;
}
.coll-tile {
  position: relative; border-radius: 12px; overflow: hidden;
  border: 1px solid var(--color-divider); background: var(--color-card);
  aspect-ratio: 3 / 4; padding: 0; text-align: left;
}
.coll-tile img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 1; }
.coll-tile__real { opacity: 0; transition: opacity 300ms var(--ease); }
.coll-tile:hover .coll-tile__real { opacity: 1; }
.coll-tile__cap {
  z-index: 2;
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: 38px 14px 13px;
  background: linear-gradient(to top, rgba(15,15,13,0.97) 0%, rgba(15,15,13,0.85) 42%, rgba(15,15,13,0) 100%);
  display: flex; align-items: baseline; justify-content: space-between; gap: 8px;
}
.coll-tile__name { font-family: var(--font-hanson); font-size: 1.02rem; letter-spacing: 0.04em; color: var(--color-white); text-shadow: 0 1px 8px rgba(0,0,0,0.7); }
.coll-tile__count { font-family: var(--font-mono); font-size: 0.66rem; color: rgba(245,244,240,0.8); }

.drill-head { max-width: var(--maxw); margin: 0 auto; padding: 16px 16px 6px; display: flex; align-items: baseline; gap: 14px; }
.drill-head[hidden] { display: none; }
.drill-back { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.06em; color: var(--color-text-muted); }
.drill-back:hover { color: var(--color-primary); }
.drill-title { font-family: var(--font-hanson); font-size: 1.15rem; letter-spacing: 0.04em; }
.shop-grid[hidden] { display: none; }

@media (min-width: 700px) { .coll-grid { grid-template-columns: repeat(3, 1fr); gap: 18px; } }
@media (min-width: 1000px) { .coll-grid { grid-template-columns: repeat(4, 1fr); } }

/* ── Product grid ───────────────────────────────────────── */
.shop-grid {
  max-width: var(--maxw); margin: 0 auto; padding: 10px 16px 120px;
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px;
}
.pcard {
  background: var(--color-card); border: 1px solid var(--color-divider);
  border-radius: 10px; overflow: hidden; display: flex; flex-direction: column;
}
.pcard__media { display: block; position: relative; aspect-ratio: 1/1; background: var(--color-surface); overflow: hidden; }
.pcard__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.pcard__img--alt { opacity: 0; transition: opacity 280ms var(--ease); }
.pcard__media:hover .pcard__img--alt { opacity: 1; }
.pcard__weight {
  z-index: 2;
  position: absolute; top: 8px; left: 8px;
  font-family: var(--font-mono); font-size: 0.58rem; letter-spacing: 0.08em;
  background: rgba(26,26,26,0.82); color: var(--color-white);
  padding: 2px 7px; border-radius: 4px;
}
.pcard__body { padding: 10px 11px 12px; display: flex; flex-direction: column; gap: 7px; flex: 1; }
.pcard__name { font-size: 0.82rem; font-weight: 600; line-height: 1.25; }
.pcard__color { font-family: var(--font-mono); font-size: 0.62rem; color: var(--color-text-faint); letter-spacing: 0.04em; }
.pcard__price { font-family: var(--font-mono); font-size: 0.78rem; color: var(--color-text); margin-top: auto; }
.pcard__sizes { display: flex; gap: 5px; flex-wrap: wrap; }
.size-pill {
  font-family: var(--font-mono); font-size: 0.64rem; min-width: 26px; text-align: center;
  padding: 3px 0; border: 1px solid var(--color-border); border-radius: 5px;
  color: var(--color-text-muted); background: transparent;
}
.size-pill.is-active { border-color: var(--color-primary); color: var(--color-primary); font-weight: 700; }
.size-pill--soon { opacity: 0.4; cursor: not-allowed; border-style: dashed; }
.pdp__size--soon { opacity: 0.4; cursor: not-allowed; border-style: dashed; }
.pdp__size-note { font-family: var(--font-mono); font-size: 0.66rem; color: var(--color-text-faint); margin-top: 8px; }
.pcard__atc {
  font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.1em; text-transform: uppercase;
  background: var(--color-black); color: var(--color-white);
  padding: 9px; border-radius: 7px; text-align: center; width: 100%;
}
.pcard__atc:hover { background: var(--color-primary); }
.pcard__atc.is-added { background: var(--color-primary); }
.pcard__atc:disabled { opacity: 0.45; }

/* ── Cart drawer ────────────────────────────────────────── */
.cart-scrim {
  position: fixed; inset: 0; background: rgba(26,26,26,0.45); z-index: 50;
  opacity: 0; visibility: hidden; transition: opacity 280ms var(--ease);
}
.cart-scrim.is-open { opacity: 1; visibility: visible; }
.cart-drawer {
  position: fixed; top: 0; right: 0; height: 100dvh; width: min(420px, 90vw);
  background: var(--color-bg); z-index: 51; transform: translateX(100%);
  transition: transform 320ms var(--ease); display: flex; flex-direction: column;
  border-left: 1px solid var(--color-border);
}
.cart-drawer.is-open { transform: translateX(0); }
.cart-drawer__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px; border-bottom: 1px solid var(--color-border);
  font-family: var(--font-mono); font-size: 0.8rem; letter-spacing: 0.1em; text-transform: uppercase;
}
.cart-drawer__items { flex: 1; overflow-y: auto; padding: 8px 16px; }
.cart-line { display: flex; gap: 10px; padding: 12px 0; border-bottom: 1px solid var(--color-divider); }
.cart-line__name { font-size: 0.82rem; font-weight: 600; }
.cart-line__meta { font-family: var(--font-mono); font-size: 0.64rem; color: var(--color-text-faint); margin-top: 2px; }
.cart-line__price { font-family: var(--font-mono); font-size: 0.74rem; margin-left: auto; white-space: nowrap; }
.cart-line__rm { font-family: var(--font-mono); font-size: 0.6rem; color: var(--color-text-faint); text-decoration: underline; margin-top: 4px; }
.cart-empty { color: var(--color-text-faint); font-family: var(--font-mono); font-size: 0.74rem; text-align: center; padding: 40px 0; }
.cart-drawer__foot { padding: 16px; border-top: 1px solid var(--color-border); display: flex; flex-direction: column; gap: 10px; }
.cart-total { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 0.86rem; }
.btn-primary {
  font-family: var(--font-mono); font-size: 0.74rem; letter-spacing: 0.1em; text-transform: uppercase;
  background: var(--color-primary); color: var(--color-white); padding: 13px; border-radius: 8px; text-align: center; width: 100%;
}
.btn-primary:hover { background: var(--color-primary-hover); }
.btn-ghost {
  font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.08em; text-transform: uppercase;
  background: transparent; color: var(--color-text-muted); border: 1px solid var(--color-border);
  padding: 11px; border-radius: 8px; text-align: center; width: 100%;
}

/* ── Sticky mobile cart bar ─────────────────────────────── */
.cart-sticky {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 35;
  display: none; align-items: center; justify-content: space-between; gap: 12px;
  padding: 12px 16px; background: var(--color-black); color: var(--color-white);
}
.cart-sticky.is-visible { display: flex; }
.cart-sticky__label { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.06em; }
.cart-sticky__cta { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.1em; text-transform: uppercase; background: var(--color-primary); color: var(--color-white); padding: 8px 16px; border-radius: 7px; }

/* ── Responsive ─────────────────────────────────────────── */
@media (min-width: 700px) {
  .shop-grid { grid-template-columns: repeat(3, 1fr); gap: 18px; }
  .pcard__name { font-size: 0.9rem; }
}
@media (min-width: 1000px) {
  .shop-grid { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 640px) {
  .shop-nav { display: none; }
  .shop-burger { display: flex; align-items: center; color: var(--color-text); background: none; border: 0; padding: 0; cursor: pointer; }
  .cart-sticky.is-visible { display: flex; }
  .shop-header__bar { position: relative; }
  .shop-header.is-nav-open .shop-nav {
    display: flex; flex-direction: column; align-items: stretch; gap: 0;
    position: absolute; top: 100%; left: 0; right: 0; z-index: 65;
    background: var(--color-bg); border-bottom: 1px solid var(--color-divider);
    box-shadow: 0 16px 30px rgba(0,0,0,0.22); padding: 2px 18px 12px;
  }
  .shop-header.is-nav-open .shop-nav > a { padding: 15px 2px; border-bottom: 1px solid var(--color-divider); font-size: 1.02rem; }
  .shop-header.is-nav-open .nav-info { width: 100%; }
  .shop-header.is-nav-open .nav-info__btn { width: 100%; text-align: left; padding: 15px 2px; }
  .shop-header.is-nav-open .nav-info__menu {
    position: static; display: none; box-shadow: none; background: none;
    border: 0; padding: 0 0 6px 12px; min-width: 0; transform: none;
  }
  .shop-header.is-nav-open .nav-info.is-open .nav-info__menu { display: flex; flex-direction: column; }
  .shop-header.is-nav-open .nav-info__menu a { padding: 9px 0; }
}

/* ── Header "Info" dropdown ─────────────────────────────── */
.nav-info { position: relative; }
.nav-info__btn { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-text-muted); background: none; display: inline-flex; align-items: center; gap: 4px; }
.nav-info:hover .nav-info__btn, .nav-info__btn:focus { color: var(--color-primary); }
.nav-info__menu {
  position: absolute; top: 130%; right: 0; min-width: 190px; background: var(--color-bg);
  border: 1px solid var(--color-border); border-radius: var(--border-radius-md);
  padding: 6px; display: none; flex-direction: column; z-index: 60; box-shadow: 0 10px 30px rgba(26,26,26,0.12);
}
.nav-info.is-open .nav-info__menu { display: flex; }
.nav-info__menu a { font-family: var(--font-mono); font-size: 0.74rem; letter-spacing: 0.04em; color: var(--color-text); text-decoration: none; padding: 8px 10px; border-radius: 6px; }
.nav-info__menu a:hover { background: var(--color-surface); color: var(--color-primary); }

/* ── Site footer ────────────────────────────────────────── */
.site-footer { background: var(--color-black); color: var(--color-text-inverse); margin-top: 40px; }
.site-footer__inner { max-width: var(--maxw); margin: 0 auto; padding: 44px 16px 28px; display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 28px; }
.site-footer__brand .ft-word { font-family: var(--font-hanson); font-size: 1.6rem; letter-spacing: 0.1em; }
.site-footer__brand p { color: rgba(214,210,196,0.6); font-size: 0.82rem; max-width: 34ch; margin-top: 10px; line-height: 1.6; }
.ft-col-label { font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(214,210,196,0.5); margin-bottom: 12px; }
.site-footer a { display: block; color: var(--color-text-inverse); text-decoration: none; font-size: 0.84rem; padding: 5px 0; }
.site-footer a:hover { color: #fff; text-decoration: underline; }
.site-footer__bottom { border-top: 1px solid rgba(214,210,196,0.15); padding: 16px; text-align: center; font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.1em; color: rgba(214,210,196,0.5); }
@media (max-width: 640px) { .site-footer__inner { grid-template-columns: 1fr 1fr; gap: 22px; } .site-footer__brand { grid-column: 1 / -1; } }

/* ── Info / policy pages ────────────────────────────────── */
.info-page { max-width: 880px; margin: 0 auto; padding: 32px 16px 60px; }
.info-page__eyebrow { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--color-text-faint); }
.info-page__title { font-family: var(--font-hanson); font-size: clamp(1.8rem, 6vw, 3rem); letter-spacing: 0.03em; margin: 6px 0 8px; }
.info-page__lead { color: var(--color-text-muted); max-width: 60ch; line-height: 1.7; }
.info-jump { display: flex; flex-wrap: wrap; gap: 8px; margin: 22px 0 8px; }
.info-jump a { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.06em; text-transform: uppercase; border: 1px solid var(--color-border); border-radius: 999px; padding: 6px 13px; color: var(--color-text-muted); text-decoration: none; }
.info-jump a:hover { border-color: var(--color-primary); color: var(--color-primary); }
.info-sec { padding-top: 30px; scroll-margin-top: 80px; }
.info-sec__h { font-family: var(--font-hanson); font-size: 1.2rem; letter-spacing: 0.04em; margin-bottom: 10px; }
.info-sec p, .info-sec li { color: var(--color-text); line-height: 1.7; font-size: 0.95rem; }
.info-sec ul { padding-left: 18px; }
.info-note { font-family: var(--font-mono); font-size: 0.74rem; color: var(--color-text-muted); margin-top: 10px; }
.faq-item { border-top: 1px solid var(--color-divider); padding: 14px 0; }
.faq-item summary { font-weight: 600; cursor: pointer; font-size: 0.95rem; }
.faq-item p { margin-top: 8px; color: var(--color-text-muted); }

/* size guide tables */
.sg-block { margin-top: 26px; }
.sg-block__h { font-family: var(--font-hanson); font-size: 1.05rem; letter-spacing: 0.03em; margin-bottom: 8px; }
.sg-table-wrap { overflow-x: auto; border: 1px solid var(--color-divider); border-radius: var(--border-radius-md); }
.sg-table { width: 100%; border-collapse: collapse; font-family: var(--font-mono); font-size: 0.78rem; min-width: 460px; }
.sg-table th { background: var(--color-surface); color: var(--color-text-muted); font-weight: 500; letter-spacing: 0.04em; padding: 10px 12px; text-align: center; }
.sg-table td { padding: 10px 12px; text-align: center; border-top: 1px solid var(--color-divider); }
.sg-table td:first-child, .sg-table th:first-child { text-align: left; }

/* featured (HQ) store — stacked: full-width slider on top, info below */
.store-hero { border: 1px solid var(--color-divider); border-radius: var(--border-radius-lg); overflow: hidden; margin-top: 24px; background: var(--color-card); }
.store-hero__img { width: 100%; height: 100%; min-height: 300px; object-fit: cover; }
.store-hero__body { padding: 22px 26px; display: flex; flex-direction: column; gap: 8px; }
.store-hero__name { font-family: var(--font-hanson); font-size: 1.6rem; letter-spacing: 0.03em; }
.store-hero__body p { color: var(--color-text-muted); font-size: 0.92rem; line-height: 1.65; }
.store-hero__body a { color: var(--color-primary); text-decoration: none; font-family: var(--font-mono); font-size: 0.8rem; letter-spacing: 0.04em; }

/* store photo slider (Dónde estamos hero) — every photo fully visible (contain) over a blurred fill of itself */
.store-slider { position: relative; width: 100%; aspect-ratio: 3 / 2; background: #131313; }
.store-slider__track { display: flex; height: 100%; overflow-x: auto; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
.store-slider__track::-webkit-scrollbar { display: none; }
.store-slider__slide { position: relative; flex: 0 0 100%; width: 100%; height: 100%; scroll-snap-align: center; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.store-slider__bg { position: absolute; inset: 0; background-size: cover; background-position: center; filter: blur(26px) brightness(0.5); transform: scale(1.15); }
.store-slider__slide img { position: relative; z-index: 1; max-width: 100%; max-height: 100%; width: auto; height: auto; object-fit: contain; }
.store-slider__dots { position: absolute; left: 0; right: 0; bottom: 12px; display: flex; justify-content: center; gap: 7px; pointer-events: none; z-index: 2; }
.store-slider__dot { width: 7px; height: 7px; border-radius: 50%; background: rgba(255,255,255,0.5); box-shadow: 0 0 0 1px rgba(0,0,0,0.18); pointer-events: auto; transition: background 0.2s, transform 0.2s; padding: 0; border: 0; cursor: pointer; }
.store-slider__dot.is-active { background: #fff; transform: scale(1.25); }

/* store cards */
.stores { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 18px; }
@media (max-width: 640px) { .stores { grid-template-columns: 1fr; } }
.store-card { border: 1px solid var(--color-divider); border-radius: var(--border-radius-lg); padding: 18px; background: var(--color-card); }
.store-card__name { font-family: var(--font-hanson); font-size: 1.05rem; letter-spacing: 0.03em; }
.store-card__tag { font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-primary); margin: 4px 0 10px; }
.store-card__row { font-size: 0.85rem; color: var(--color-text-muted); line-height: 1.7; }
.store-card a { color: var(--color-primary); text-decoration: none; font-size: 0.85rem; }

/* ── Drop page ──────────────────────────────────────────── */
.drop-page { max-width: 980px; margin: 0 auto; padding: 40px 16px 70px; text-align: center; }
.drop-page__eyebrow { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.24em; text-transform: uppercase; color: var(--color-text-faint); }
.drop-page__title { font-family: var(--font-hanson); font-size: clamp(2rem, 8vw, 3.6rem); letter-spacing: 0.03em; margin: 8px 0 6px; }
.drop-page__lead { color: var(--color-text-muted); max-width: 52ch; margin: 0 auto; line-height: 1.7; }
.countdown { display: flex; gap: 16px; justify-content: center; margin: 30px 0 8px; }
.cd-unit { min-width: 64px; }
.cd-num { font-family: var(--font-hanson); font-size: clamp(2rem, 9vw, 3.6rem); line-height: 1; }
.cd-label { font-family: var(--font-mono); font-size: 0.58rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-text-faint); margin-top: 6px; }
.reserve { max-width: 460px; margin: 24px auto 0; display: flex; gap: 8px; }
.reserve input { flex: 1; padding: 13px 14px; border: 1px solid var(--color-border); border-radius: 8px; font-family: var(--font-mono); font-size: 0.8rem; background: var(--color-bg); color: var(--color-text); }
.reserve button { font-family: var(--font-mono); font-size: 0.74rem; letter-spacing: 0.1em; text-transform: uppercase; background: var(--color-primary); color: var(--color-white); padding: 0 22px; border-radius: 8px; white-space: nowrap; }
.reserve-note { font-family: var(--font-mono); font-size: 0.66rem; color: var(--color-text-faint); margin-top: 10px; }
.drop-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; margin-top: 36px; }
.drop-tile { position: relative; border-radius: 10px; overflow: hidden; border: 1px solid var(--color-divider); aspect-ratio: 3/4; background: var(--color-card); }
.drop-tile img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(0.25) brightness(0.82); }
.drop-tile__lock { position: absolute; inset: 0; display: flex; flex-direction: column; gap: 4px; align-items: center; justify-content: center; background: rgba(18,18,16,0.32); color: #fff; font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.1em; text-transform: uppercase; }
.drop-tile__name { position: absolute; left: 0; right: 0; bottom: 0; padding: 8px; font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.06em; color: #fff; background: linear-gradient(to top, rgba(18,18,16,0.7), transparent); }
@media (max-width: 640px) { .drop-grid { grid-template-columns: repeat(2, 1fr); } .countdown { gap: 9px; } .cd-unit { min-width: 50px; } }

/* ── HQ lookbook ────────────────────────────────────────── */
.lb-hero { position: relative; }
.lb-hero__img { width: 100%; height: min(86vh, 820px); object-fit: cover; display: block; background: #141414; }
.lb-hero__overlay { position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: flex-end; padding: 0 0 8vh 6vw; gap: 10px; background: linear-gradient(to top, rgba(18,18,16,0.72), rgba(18,18,16,0) 46%); }
.lb-hero__eyebrow { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.24em; text-transform: uppercase; color: rgba(245,244,240,0.8); }
.lb-hero__title { font-family: var(--font-hanson); font-size: clamp(2.2rem, 8vw, 5rem); letter-spacing: 0.03em; color: var(--color-white); line-height: 0.95; }
.lb-hero__sub { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.14em; color: rgba(245,244,240,0.85); max-width: 46ch; line-height: 1.7; }
.lb { max-width: var(--maxw); margin: 0 auto; padding: 0 16px; }
.lb-sec { padding: 60px 0 8px; }
.lb-sec__eyebrow { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--color-text-faint); }
.lb-sec__title { font-family: var(--font-hanson); font-size: clamp(1.6rem, 5vw, 2.6rem); letter-spacing: 0.03em; margin: 6px 0 10px; }
.lb-sec__lead { max-width: 60ch; color: var(--color-text-muted); line-height: 1.75; font-size: 1.02rem; }
.lb-jp { font-family: var(--font-mono); }
.lb-pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 30px; }
.lb-pillar { border-top: 2px solid var(--color-primary); padding-top: 14px; }
.lb-pillar__num { font-family: var(--font-mono); font-size: 0.7rem; color: var(--color-text-faint); }
.lb-pillar__name { font-family: var(--font-hanson); font-size: 1.15rem; letter-spacing: 0.03em; margin: 4px 0 6px; }
.lb-pillar__note { color: var(--color-text-muted); font-size: 0.9rem; line-height: 1.6; }
.lb-coords { font-family: var(--font-mono); font-size: 0.72rem; color: var(--color-text-muted); letter-spacing: 0.06em; margin-top: 24px; }
.lb-triptych { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: 26px; }
.lb-triptych--4 { grid-template-columns: repeat(4, 1fr); }
.lb-duo { grid-template-columns: repeat(2, 1fr); max-width: 660px; margin-left: auto; margin-right: auto; }
@media (max-width: 700px) { .lb-triptych--4 { grid-template-columns: repeat(2, 1fr); } }
.lb-shot { position: relative; border-radius: 8px; overflow: hidden; aspect-ratio: 9 / 16; }
.lb-shot img { width: 100%; height: 100%; object-fit: cover; }
a.lb-shot--link { display: block; cursor: pointer; text-decoration: none; }
.lb-shot--link img { transition: transform 0.45s var(--ease, ease); }
.lb-shot--link:hover img { transform: scale(1.05); }
.lb-shot--link::after { content: "→"; position: absolute; top: 10px; right: 12px; color: #fff; font-family: var(--font-mono); opacity: 0; transform: translateX(-4px); transition: opacity 0.25s, transform 0.25s; }
.lb-shot--link:hover::after { opacity: 0.9; transform: translateX(0); }
.lb-shot__cap { position: absolute; left: 0; bottom: 0; width: 100%; padding: 14px; font-family: var(--font-hanson); letter-spacing: 0.12em; color: #fff; background: linear-gradient(to top, rgba(18,18,16,0.7), transparent); }
.lb-flats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: 24px; }
.lb-flat { border-radius: 8px; overflow: hidden; aspect-ratio: 3 / 4; background: var(--color-surface); }
.lb-flat img { width: 100%; height: 100%; object-fit: cover; }
.lb-flat__cap { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.06em; color: var(--color-text-muted); padding: 8px 2px 0; }
.lb-cta { text-align: center; padding: 56px 16px 20px; }
.lb-cta a { font-family: var(--font-mono); font-size: 0.76rem; letter-spacing: 0.14em; text-transform: uppercase; background: var(--color-black); color: #fff; padding: 14px 34px; border-radius: 999px; text-decoration: none; }
.lb-cta a:hover { background: var(--color-primary); }
@media (max-width: 700px) { .lb-pillars, .lb-triptych, .lb-flats { grid-template-columns: 1fr; } }

/* ── Product page (PDP) ─────────────────────────────────── */
.pdp { max-width: var(--maxw); margin: 0 auto; padding: 14px 16px 140px; }
.pdp__back { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.08em; color: var(--color-text-muted); text-decoration: none; display: inline-block; margin-bottom: 14px; }
.pdp__grid { display: grid; grid-template-columns: 1fr; gap: 22px; }
.pdp__slides { display: flex; overflow-x: auto; scroll-snap-type: x mandatory; aspect-ratio: 1/1; background: var(--color-card); border: 1px solid var(--color-divider); border-radius: 12px; scrollbar-width: none; -webkit-overflow-scrolling: touch; }
.pdp__slides::-webkit-scrollbar { display: none; }
.pdp__slide { flex: 0 0 100%; scroll-snap-align: center; }
.pdp__slide img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pdp__dots { display: flex; gap: 6px; justify-content: center; padding: 12px 0 0; }
.pdp__dot { width: 7px; height: 7px; border-radius: 50%; background: var(--color-border); transition: background 180ms; }
.pdp__dot.is-active { background: var(--color-text); }
.pdp__eyebrow { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--color-text-faint); }
.pdp__title { font-family: var(--font-hanson); font-size: clamp(1.5rem, 4vw, 2.2rem); letter-spacing: 0.02em; margin: 6px 0 4px; }
.pdp__color-name { font-family: var(--font-mono); font-size: 0.74rem; color: var(--color-text-muted); }
.pdp__price { font-family: var(--font-mono); font-size: 1.05rem; margin: 14px 0; }
.pdp__label { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-text-faint); display: flex; justify-content: space-between; align-items: baseline; margin: 18px 0 8px; }
.pdp__guide-link { text-transform: none; letter-spacing: 0; color: var(--color-primary); text-decoration: underline; background: none; }
.pdp__swatches { display: flex; gap: 9px; flex-wrap: wrap; }
.pdp__swatch { width: 34px; height: 34px; border-radius: 50%; border: 1px solid var(--color-border); position: relative; }
.pdp__swatch.is-active { box-shadow: 0 0 0 2px var(--color-bg), 0 0 0 4px var(--color-primary); }
.pdp__sizes { display: flex; gap: 8px; flex-wrap: wrap; }
.pdp__size { font-family: var(--font-mono); font-size: 0.78rem; min-width: 44px; padding: 10px 0; text-align: center; border: 1px solid var(--color-border); border-radius: 7px; color: var(--color-text-muted); }
.pdp__size.is-active { border-color: var(--color-primary); color: var(--color-primary); font-weight: 700; }
.pdp__specs { margin-top: 22px; border-top: 1px solid var(--color-divider); }
.pdp__spec-row { display: flex; justify-content: space-between; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--color-divider); font-size: 0.82rem; }
.pdp__spec-row dt { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-text-faint); }
.pdp__spec-row dd { text-align: right; color: var(--color-text); max-width: 60%; }
.pdp__add { margin-top: 22px; }
.pdp-sticky { position: fixed; left: 0; right: 0; bottom: 0; z-index: 36; display: flex; gap: 12px; align-items: center; padding: 12px 16px; background: rgba(214,210,196,0.96); backdrop-filter: blur(8px); border-top: 1px solid var(--color-border); }
.pdp-sticky__price { font-family: var(--font-mono); font-size: 0.86rem; white-space: nowrap; }
.pdp-sticky .btn-primary { margin-left: auto; max-width: 60%; }

/* size-guide bottom sheet (reuses scrim) */
.sheet { position: fixed; left: 0; right: 0; bottom: 0; z-index: 52; background: var(--color-bg); border-top: 1px solid var(--color-border); border-radius: 16px 16px 0 0; transform: translateY(100%); transition: transform 320ms var(--ease); max-height: 80dvh; overflow-y: auto; }
.sheet.is-open { transform: translateY(0); }
.sheet__head { display: flex; justify-content: space-between; align-items: center; padding: 16px; font-family: var(--font-mono); font-size: 0.8rem; letter-spacing: 0.1em; text-transform: uppercase; border-bottom: 1px solid var(--color-divider); }
.sheet__body { padding: 16px; }
.size-table { width: 100%; border-collapse: collapse; font-family: var(--font-mono); font-size: 0.74rem; }
.size-table th, .size-table td { padding: 9px 8px; text-align: center; border-bottom: 1px solid var(--color-divider); }
.size-table th { color: var(--color-text-faint); font-weight: 500; letter-spacing: 0.06em; }
.size-note { font-size: 0.74rem; color: var(--color-text-muted); margin-top: 12px; }

@media (min-width: 800px) {
  .pdp__grid { grid-template-columns: 1.1fr 1fr; gap: 40px; align-items: start; }
  .pdp-sticky { display: none; }
  .pdp__add { display: block; }
}
@media (min-width: 800px) { .pdp__add-inline { display: block; } }
@media (max-width: 799px) { .pdp__add-inline { display: none; } }

/* ── Event page (Hecho con el barrio → evento.html) ─────── */
.evento { max-width: 980px; margin: 0 auto; padding: 28px 16px 64px; }
.evento__back { display: inline-block; font-family: var(--font-mono); font-size: 0.74rem; letter-spacing: 0.06em; color: var(--color-text-faint); text-decoration: none; margin-bottom: 16px; }
.evento__back:hover { color: var(--color-text); }
.evento__eyebrow { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-primary); }
.evento__title { font-family: var(--font-hanson); font-size: clamp(2rem, 7vw, 3.2rem); letter-spacing: 0.03em; margin: 6px 0 10px; }
.evento__lead { color: var(--color-text-muted); max-width: 64ch; line-height: 1.7; font-size: 0.98rem; }
.ev-shop { display: inline-flex; align-items: center; gap: 6px; background: var(--color-primary); color: #fff; text-decoration: none; font-family: var(--font-mono); font-size: 0.82rem; letter-spacing: 0.05em; padding: 12px 24px; border-radius: 999px; margin-top: 18px; transition: opacity 0.2s; }
.ev-shop:hover { opacity: 0.88; }
.evento__cta { text-align: center; margin-top: 28px; }
.ev-gallery { columns: 3 260px; column-gap: 12px; margin-top: 26px; }
.ev-gallery img { width: 100%; margin: 0 0 12px; border-radius: 10px; display: block; break-inside: avoid; cursor: zoom-in; }
@media (max-width: 600px) { .ev-gallery { columns: 2 150px; column-gap: 8px; } .ev-gallery img { margin-bottom: 8px; } }
.ev-lb { position: fixed; inset: 0; z-index: 130; display: none; align-items: center; justify-content: center; background: rgba(8,8,8,0.94); }
.ev-lb.is-open { display: flex; }
.ev-lb img { max-width: 94vw; max-height: 92vh; object-fit: contain; border-radius: 6px; }
.ev-lb__close { position: absolute; top: 16px; right: 18px; background: none; border: 0; color: #fff; font-size: 1.6rem; cursor: pointer; line-height: 1; }

