/* =========================================================
   Lasertag.pty — base + nav + hero
   ========================================================= */
:root {
  --navy: #0d1b2a;
  --navy-2: #122336;
  --navy-3: #1a2e44;
  --cream: #F4EFE3;
  --cream-2: #ebe4d3;
  --ink: #0d1b2a;
  --ink-soft: #3a4756;
  --green: #7DC242;
  --green-2: #6cae34;
  --green-soft: rgba(125, 194, 66, 0.16);
  --line: rgba(255, 255, 255, 0.12);
  --line-dark: rgba(13, 27, 42, 0.12);
  --whatsapp: #25D366;

  --serif: "Cormorant Garamond", "Times New Roman", serif;
  --sans: "Manrope", system-ui, -apple-system, sans-serif;

  --container: 1280px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { background: #08111c; }
body {
  font-family: var(--sans);
  color: var(--ink);
  background: #08111c;
  font-size: 17px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }

.container {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 32px;
}

/* ---- Buttons ---- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 20px;
  border-radius: 999px;
  font-family: var(--sans);
  font-weight: 600;
  font-size: 15px;
  letter-spacing: 0.01em;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform .15s ease, background .2s ease, color .2s ease, border-color .2s ease, box-shadow .2s ease;
  white-space: nowrap;
}
.btn svg { width: 18px; height: 18px; }
.btn--lg { padding: 16px 28px; font-size: 16px; }
.btn--accent {
  background: var(--green);
  color: var(--navy);
  box-shadow: 0 10px 24px -12px rgba(125, 194, 66, 0.7);
}
.btn--accent:hover { background: var(--green-2); transform: translateY(-1px); }
.btn--ghost {
  background: transparent;
  color: #fff;
  border-color: rgba(255,255,255,0.25);
}
.btn--ghost:hover { border-color: #fff; background: rgba(255,255,255,0.06); }
.btn--ink {
  background: var(--navy);
  color: #fff;
}
.btn--ink:hover { background: #000; }

/* ---- Eyebrow tag ---- */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.82);
  padding: 8px 14px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255,255,255,0.03);
}
.eyebrow__dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 0 4px rgba(125,194,66,0.18);
}
.eyebrow--dark {
  color: var(--ink-soft);
  border-color: var(--line-dark);
  background: rgba(13,27,42,0.04);
}

/* =========================================================
   NAV
   ========================================================= */
.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(13, 27, 42, 0.85);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--line);
}
.nav__inner {
  max-width: var(--container);
  margin: 0 auto;
  padding: 18px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
}
.nav__logo img {
  height: 44px;
  width: auto;
  filter: brightness(0) invert(1);
  /* Logo is dark-on-transparent; invert to white for the navy bar.
     The green strokes are lost, so we layer a subtle green halo. */
  filter: brightness(0) invert(1) drop-shadow(0 0 0 transparent);
}
.nav__logo {
  display: flex; align-items: center;
  padding: 4px 0;
}
.nav__links {
  display: flex;
  gap: 36px;
  font-size: 15px;
  font-weight: 500;
  color: rgba(255,255,255,0.78);
}
.nav__links a {
  position: relative;
  padding: 6px 0;
  transition: color .2s ease;
}
.nav__links a:hover { color: #fff; }
.nav__links a::after {
  content: "";
  position: absolute;
  left: 0; right: 100%;
  bottom: 0;
  height: 1px;
  background: var(--green);
  transition: right .25s ease;
}
.nav__links a:hover::after { right: 0; }
.nav__cta { padding: 10px 18px; font-size: 14px; }

@media (max-width: 860px) {
  /* mobile nav handled by responsive overrides at end of file */
}

/* =========================================================
   HERO
   ========================================================= */
.hero {
  position: relative;
  background:
    radial-gradient(1100px 600px at 85% -10%, rgba(125,194,66,0.18), transparent 60%),
    radial-gradient(900px 500px at -10% 110%, rgba(125,194,66,0.10), transparent 55%),
    linear-gradient(180deg, #0d1b2a 0%, #0a1623 100%);
  color: #fff;
  overflow: hidden;
  isolation: isolate;
}
.hero__grain {
  position: absolute; inset: 0;
  background-image:
    radial-gradient(rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 3px 3px;
  opacity: 0.4;
  mix-blend-mode: overlay;
  pointer-events: none;
}
.hero__beam {
  position: absolute;
  width: 1px;
  background: linear-gradient(180deg, transparent, var(--green) 30%, var(--green) 70%, transparent);
  opacity: 0.35;
  pointer-events: none;
}
.hero__beam--a { left: 14%; top: -10%; height: 60%; transform: rotate(8deg); }
.hero__beam--b { right: 22%; top: 30%; height: 55%; transform: rotate(-6deg); opacity: 0.18; }

.hero__inner {
  position: relative;
  max-width: var(--container);
  margin: 0 auto;
  padding: 88px 32px 120px;
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 80px;
  align-items: center;
}
.hero__copy { max-width: 620px; }
.hero__title {
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(56px, 7vw, 96px);
  line-height: 1.02;
  letter-spacing: -0.015em;
  margin: 24px 0 28px;
  color: #fff;
}
.hero__title em {
  font-style: italic;
  font-weight: 500;
  color: #fff;
}
.hero__highlight {
  position: relative;
  white-space: nowrap;
  color: var(--green);
  font-style: italic;
}
.hero__highlight::after {
  content: "";
  position: absolute;
  left: 4px; right: 4px; bottom: 4px;
  height: 10px;
  background: rgba(125,194,66,0.22);
  z-index: -1;
  border-radius: 2px;
}
.hero__sub {
  font-size: 19px;
  line-height: 1.55;
  color: rgba(255,255,255,0.78);
  max-width: 520px;
  margin: 0 0 36px;
}
.hero__actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 56px;
}
.hero__meta {
  list-style: none;
  margin: 0; padding: 0;
  display: flex;
  gap: 40px;
  border-top: 1px solid var(--line);
  padding-top: 28px;
}
.hero__meta li {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.hero__meta strong {
  font-family: var(--serif);
  font-size: 36px;
  font-weight: 500;
  line-height: 1;
  color: #fff;
}
.hero__meta span {
  font-size: 13px;
  letter-spacing: 0.05em;
  color: rgba(255,255,255,0.74);
}

/* --- Hero media composition --- */
.hero__media {
  position: relative;
  aspect-ratio: 1 / 1.05;
  min-height: 520px;
}
.hero__card {
  position: absolute;
  border-radius: 18px;
  overflow: hidden;
  box-shadow:
    0 30px 60px -30px rgba(0,0,0,0.6),
    0 0 0 1px rgba(255,255,255,0.06);
  background: var(--navy-2);
}
.hero__card img { width: 100%; height: 100%; object-fit: cover; }
.hero__card--main {
  inset: 0 8% 22% 18%;
  border-radius: 22px;
}
.hero__card--main .hero__tag {
  position: absolute;
  left: 16px; bottom: 16px;
  display: inline-flex;
  align-items: center;
  background: rgba(13,27,42,0.78);
  color: #fff;
  font-size: 12px;
  letter-spacing: 0.04em;
  padding: 8px 12px;
  border-radius: 999px;
  backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,0.12);
}
.hero__card--mini {
  width: 42%;
  aspect-ratio: 1/1;
  left: 0;
  bottom: 4%;
  transform: rotate(-4deg);
  border: 4px solid var(--cream);
}
.hero__card--badge {
  background: var(--green);
  color: var(--navy);
  right: 0; top: 4%;
  width: 30%;
  aspect-ratio: 1/1;
  border-radius: 50%;
  display: grid; place-items: center;
  text-align: center;
  box-shadow: 0 20px 40px -20px rgba(125,194,66,0.6);
}
.hero__badge { padding: 18px; }
.hero__badge-num {
  display: block;
  font-family: var(--serif);
  font-size: 46px;
  font-weight: 600;
  line-height: 1;
  font-style: italic;
}
.hero__badge-lbl {
  display: block;
  margin-top: 8px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

/* --- Marquee --- */
.hero__marquee {
  position: relative;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: rgba(255,255,255,0.02);
  overflow: hidden;
  padding: 18px 0;
}
.hero__marquee-track {
  display: flex;
  gap: 36px;
  align-items: center;
  white-space: nowrap;
  animation: marquee 32s linear infinite;
  font-family: var(--serif);
  font-style: italic;
  font-size: 26px;
  color: rgba(255,255,255,0.75);
}
.hero__marquee-track i {
  color: var(--green);
  font-style: normal;
  font-size: 18px;
}
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

@media (max-width: 960px) {
  .hero__inner { grid-template-columns: 1fr; gap: 56px; padding: 56px 24px 80px; }
  .hero__media { min-height: 460px; max-width: 520px; }
  .hero__meta { gap: 28px; flex-wrap: wrap; }
}

/* =========================================================
   SECTION HEAD (shared)
   ========================================================= */
.section__head {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 80px;
  align-items: end;
  margin-bottom: 64px;
}
.section__head--center {
  grid-template-columns: 1fr;
  text-align: center;
  justify-items: center;
  gap: 24px;
  max-width: 880px;
  margin-left: auto;
  margin-right: auto;
}
.section__title {
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(40px, 4.6vw, 64px);
  line-height: 1.05;
  letter-spacing: -0.01em;
  margin: 18px 0 0;
  color: var(--ink);
}
.section__title em {
  font-style: italic;
  color: var(--green-2);
}
.section__lede {
  font-size: 18px;
  line-height: 1.6;
  color: var(--ink-soft);
  max-width: 460px;
  margin: 0;
}

/* =========================================================
   CATEGORIES
   ========================================================= */
.cats {
  background: var(--cream);
  padding: 120px 0 100px;
  position: relative;
}
.cats::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 60px;
  background: linear-gradient(180deg, var(--navy) 0%, var(--cream) 100%);
  clip-path: polygon(0 0, 100% 0, 100% 0, 0 0);
  display: none; /* keep clean transition */
}
.cats__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.cat {
  position: relative;
  display: flex;
  flex-direction: column;
  border-radius: 18px;
  overflow: hidden;
  background: #fff;
  border: 1px solid var(--line-dark);
  transition: transform .35s ease, box-shadow .35s ease;
  min-height: 380px;
  color: var(--ink);
}
.cat:hover {
  transform: translateY(-4px);
  box-shadow: 0 30px 50px -30px rgba(13,27,42,0.25);
}
.cat__media {
  flex: 1;
  background-image: var(--cat-bg);
  background-size: cover;
  background-position: center;
  position: relative;
}
.cat__media::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(13,27,42,0) 50%, rgba(13,27,42,0.35) 100%);
}
.cat__body {
  position: relative;
  padding: 22px 24px 24px;
  background: #fff;
  display: grid;
  grid-template-columns: auto 1fr auto;
  grid-template-rows: auto auto;
  column-gap: 14px;
  row-gap: 4px;
  align-items: center;
}
.cat__num {
  grid-column: 1; grid-row: 1;
  font-family: var(--serif);
  font-style: italic;
  font-size: 18px;
  color: var(--green-2);
  font-weight: 500;
}
.cat h3 {
  grid-column: 2; grid-row: 1;
  font-family: var(--serif);
  font-weight: 500;
  font-size: 28px;
  margin: 0;
  line-height: 1.1;
}
.cat__arrow {
  grid-column: 3; grid-row: 1 / span 2;
  width: 40px; height: 40px;
  border-radius: 50%;
  border: 1px solid var(--line-dark);
  display: grid; place-items: center;
  font-size: 16px;
  color: var(--ink);
  transition: background .2s ease, color .2s ease, transform .2s ease;
}
.cat:hover .cat__arrow {
  background: var(--green);
  border-color: var(--green);
  transform: translateX(2px);
}
.cat p {
  grid-column: 1 / span 2; grid-row: 2;
  margin: 4px 0 0;
  font-size: 14.5px;
  color: var(--ink-soft);
  line-height: 1.5;
}

@media (max-width: 960px) {
  .section__head { grid-template-columns: 1fr; gap: 24px; margin-bottom: 48px; }
  .cats__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 620px) {
  .cats__grid { grid-template-columns: 1fr; }
}

/* =========================================================
   GALLERY
   ========================================================= */
.gallery {
  background: var(--cream-2);
  padding: 120px 0;
}
.gallery__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 220px;
  gap: 14px;
}
.g {
  position: relative;
  margin: 0;
  overflow: hidden;
  border-radius: 14px;
  background: #d8d2c2;
}
.g img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .6s ease;
}
.g:hover img { transform: scale(1.04); }
.g figcaption {
  position: absolute;
  left: 14px; bottom: 14px;
  background: rgba(13,27,42,0.78);
  color: #fff;
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 12px;
  letter-spacing: 0.04em;
  font-weight: 500;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity .25s ease, transform .25s ease;
  backdrop-filter: blur(4px);
}
.g:hover figcaption { opacity: 1; transform: translateY(0); }
.g--tall { grid-row: span 2; }
.g--wide { grid-column: span 2; }

@media (max-width: 960px) {
  .gallery__grid { grid-template-columns: repeat(3, 1fr); grid-auto-rows: 180px; }
}
@media (max-width: 620px) {
  .gallery__grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 150px; }
  .g--wide { grid-column: span 2; }
  .g--tall { grid-row: span 2; }
}

/* =========================================================
   WHY
   ========================================================= */
.why {
  background: var(--cream);
  padding: 120px 0;
}
.why__head { margin-bottom: 72px; }
.why__grid {
  list-style: none;
  margin: 0; padding: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--line-dark);
  border-bottom: 1px solid var(--line-dark);
}
.why__item {
  padding: 40px 28px 44px;
  border-right: 1px solid var(--line-dark);
  position: relative;
  background: transparent;
  transition: background .25s ease;
}
.why__item:last-child { border-right: none; }
.why__item:hover { background: rgba(125,194,66,0.06); }
.why__num {
  font-family: var(--serif);
  font-style: italic;
  font-size: 15px;
  color: var(--ink-soft);
}
.why__icon {
  margin: 28px 0 24px;
  width: 56px; height: 56px;
  border-radius: 14px;
  background: var(--navy);
  color: var(--green);
  display: grid;
  place-items: center;
}
.why__icon svg { width: 28px; height: 28px; }
.why__item h3 {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 28px;
  margin: 0 0 10px;
  line-height: 1.15;
}
.why__item p {
  margin: 0;
  font-size: 15px;
  line-height: 1.55;
  color: var(--ink-soft);
}

@media (max-width: 960px) {
  .why__grid { grid-template-columns: repeat(2, 1fr); }
  .why__item:nth-child(2) { border-right: none; }
  .why__item:nth-child(1), .why__item:nth-child(2) { border-bottom: 1px solid var(--line-dark); }
}
@media (max-width: 560px) {
  .why__grid { grid-template-columns: 1fr; }
  .why__item { border-right: none; border-bottom: 1px solid var(--line-dark); }
  .why__item:last-child { border-bottom: none; }
}

/* =========================================================
   CTA BANNER
   ========================================================= */
.cta {
  position: relative;
  background:
    radial-gradient(800px 400px at 80% 30%, rgba(125,194,66,0.22), transparent 60%),
    linear-gradient(180deg, #0d1b2a, #0a1623);
  color: #fff;
  padding: 120px 0 130px;
  overflow: hidden;
}
.cta__grain {
  position: absolute; inset: 0;
  background-image:
    radial-gradient(rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: 4px 4px;
  opacity: 0.6;
  pointer-events: none;
}
.cta__inner {
  position: relative;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 60px;
  align-items: center;
}
.cta__title {
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(44px, 5vw, 76px);
  line-height: 1.05;
  letter-spacing: -0.01em;
  margin: 22px 0 22px;
}
.cta__title em { font-style: italic; color: var(--green); }
.cta__sub {
  font-size: 18px;
  line-height: 1.6;
  color: rgba(255,255,255,0.78);
  max-width: 540px;
  margin: 0 0 32px;
}
.cta__actions { display: flex; gap: 14px; flex-wrap: wrap; }
.btn--wa { background: var(--whatsapp); color: #fff; }
.btn--wa:hover { background: #1ebe5a; transform: translateY(-1px); }
.btn--wa svg { width: 20px; height: 20px; }

.cta__beam {
  position: relative;
  aspect-ratio: 1/1;
  display: grid;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 28px;
  background:
    radial-gradient(circle at 50% 50%, rgba(125,194,66,0.18), transparent 70%),
    rgba(255,255,255,0.02);
}
.cta__beam-num {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 500;
  font-size: 140px;
  line-height: 1;
  color: var(--green);
}
.cta__beam-num span {
  font-family: var(--sans);
  font-style: normal;
  font-size: 18px;
  letter-spacing: 0.5em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.6);
  display: block;
  text-align: center;
  margin-top: 6px;
  letter-spacing: 0.42em;
  padding-left: 0.42em;
}
.cta__beam-line {
  position: absolute;
  left: 10%; right: 10%;
  top: 50%;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--green), transparent);
  opacity: 0.45;
}
.cta__beam-dot {
  position: absolute;
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 24px 4px rgba(125,194,66,0.6);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  animation: beamPulse 2.6s ease-in-out infinite;
}
@keyframes beamPulse {
  0%, 100% { transform: translate(-50%, -50%) scale(1); opacity: 1; }
  50%      { transform: translate(-50%, -50%) scale(1.6); opacity: 0.6; }
}

@media (max-width: 960px) {
  .cta__inner { grid-template-columns: 1fr; gap: 48px; }
  .cta__beam { max-width: 420px; }
}

/* =========================================================
   FOOTER
   ========================================================= */
.footer {
  background: #08111c;
  color: rgba(255,255,255,0.7);
  padding: 80px 0 28px;
  border-top: 1px solid var(--line);
}
.footer__inner {
  display: grid;
  grid-template-columns: 1.4fr repeat(3, 1fr);
  gap: 48px;
  padding-bottom: 56px;
  border-bottom: 1px solid var(--line);
}
.footer__brand p {
  margin: 16px 0 0;
  max-width: 280px;
  font-size: 14.5px;
  line-height: 1.6;
}
.footer__logo {
  height: 40px;
  width: auto;
  filter: brightness(0) invert(1);
}
.footer__col h4 {
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.7);
  margin: 0 0 18px;
}
.footer__col a, .footer__col p {
  display: block;
  font-size: 14.5px;
  line-height: 1.7;
  color: rgba(255,255,255,0.78);
  margin: 0 0 6px;
  transition: color .2s ease;
}
.footer__col a:hover { color: var(--green); }
.footer__base {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 22px;
  font-size: 12.5px;
  letter-spacing: 0.04em;
  color: rgba(255,255,255,0.7);
}
.footer__sig i {
  color: var(--green);
  font-style: normal;
  margin-left: 6px;
}

@media (max-width: 860px) {
  .footer { padding: 44px 0 20px; }
  .footer__inner { grid-template-columns: 1fr 1fr; gap: 28px 24px; padding-bottom: 28px; }
  .footer__base { flex-direction: column; gap: 8px; padding-top: 16px; }
  .footer__col h4 { margin-bottom: 10px; font-size: 11.5px; }
  .footer__col a, .footer__col p { font-size: 13.5px; line-height: 1.5; margin-bottom: 4px; }
  .footer__brand p { font-size: 13.5px; line-height: 1.5; margin-top: 12px; }
  .footer__logo { height: 32px; }
  /* Sub-categorías compactas en el footer */
  .footer__col .nav__dd-menu,
  .footer__col [class*="subcat"] { margin-top: 4px; }
  .footer__col a { padding: 2px 0; }
}
@media (max-width: 600px) {
  .footer { padding: 36px 0 18px; }
  .footer__inner { grid-template-columns: 1fr 1fr; gap: 22px 16px; padding-bottom: 22px; }
  .footer__brand { grid-column: 1 / -1; }
  .footer__brand p { max-width: none; }
  .footer__col h4 { margin-bottom: 8px; }
  .footer__col a, .footer__col p { font-size: 13px; line-height: 1.45; margin-bottom: 3px; }
}


/* =========================================================
   RETAIL — Tienda al Detal
   ========================================================= */
.page--retail { background: var(--navy); }

/* --- Active nav state --- */
.nav__links a.is-active {
  color: var(--green);
}
.nav__links a.is-active::after {
  right: 0;
  background: var(--green);
}

/* ---- Retail hero (navy) ---- */
.retail-hero {
  position: relative;
  background: var(--navy);
  color: #fff;
  padding: 180px 0 110px;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}
.retail-hero__inner {
  position: relative;
  z-index: 2;
  max-width: 880px;
  text-align: left;
}
.retail-hero__title {
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(48px, 7.4vw, 104px);
  line-height: 0.98;
  letter-spacing: -0.02em;
  margin: 22px 0 0;
  color: #fff;
}
.retail-hero__title em {
  font-style: italic;
  color: var(--green);
  font-weight: 500;
}
.retail-hero__sub {
  margin: 26px 0 0;
  font-size: 20px;
  line-height: 1.55;
  max-width: 620px;
  color: rgba(255,255,255,0.78);
}
.retail-hero__sub strong {
  color: #fff;
  font-weight: 600;
  background: linear-gradient(180deg, transparent 62%, rgba(125,194,66,0.32) 62%);
  padding: 0 2px;
}
.retail-hero__meta {
  list-style: none;
  margin: 38px 0 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 12px 26px;
  font-size: 13.5px;
  letter-spacing: 0.02em;
  color: rgba(255,255,255,0.72);
}
.retail-hero__meta li {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.retail-hero__dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 0 3px rgba(125,194,66,0.18);
}

/* ---- Retail section (cream) ---- */
.retail {
  background: var(--cream);
  color: var(--ink);
  padding: 110px 0 100px;
  position: relative;
}
.retail__head {
  margin-bottom: 64px;
}

.retail__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

/* ---- Product card ---- */
.product {
  display: flex;
  flex-direction: column;
  background: #fff;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(13,27,42,0.08);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.7) inset,
    0 20px 40px -28px rgba(13,27,42,0.25);
  transition: transform .35s ease, box-shadow .35s ease;
}
.product:hover {
  transform: translateY(-4px);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.7) inset,
    0 30px 50px -28px rgba(13,27,42,0.35);
}

.product__media {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--cream-2);
}
.product__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .6s ease;
}
.product__media--contain {
  background: #f4efe3;
}
.product__media--contain img {
  object-fit: contain;
  padding: 12px;
}
.product__media--bottom img {
  object-position: center bottom;
}
.product__media--frame img {
  object-position: center 72%;
}
.product:hover .product__media img {
  transform: scale(1.04);
}
.product__num {
  position: absolute;
  top: 14px; left: 16px;
  font-family: var(--serif);
  font-style: italic;
  font-size: 17px;
  color: #fff;
  letter-spacing: 0.02em;
  background: rgba(13,27,42,0.55);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  padding: 4px 12px;
  border-radius: 100px;
}

.product__body {
  padding: 26px 26px 28px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.product__name {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 30px;
  line-height: 1.1;
  letter-spacing: -0.01em;
  margin: 0;
  color: var(--ink);
}
.product__desc {
  margin: 10px 0 0;
  font-size: 15px;
  line-height: 1.55;
  color: var(--ink-soft);
}

.product__price-row {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin: 22px 0 22px;
  padding: 18px 0 0;
  border-top: 1px dashed rgba(13,27,42,0.12);
}
.product__price {
  font-family: var(--serif);
  font-weight: 600;
  font-size: 56px;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--green-2);
}
.product__unit {
  font-size: 13px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-soft);
}
.product__specs {
  margin: -10px 0 22px;
  padding: 0;
  font-size: 13px;
  line-height: 1.55;
  color: var(--ink-soft);
}
.product__specs strong {
  color: var(--ink);
  font-weight: 600;
  letter-spacing: 0.02em;
}
.product__specs span + span::before {
  content: " · ";
  color: var(--green-2);
  margin: 0 4px;
  font-weight: 700;
}
.product__note {
  margin: -14px 0 20px;
  padding: 0;
  font-size: 11.5px;
  line-height: 1.5;
  color: var(--ink-soft);
  font-style: italic;
  opacity: 0.85;
}

.product__cta {
  width: 100%;
  justify-content: center;
  margin-top: auto;
}
.product__cta svg {
  width: 20px; height: 20px;
}

.retail__note {
  margin: 64px auto 0;
  max-width: 720px;
  text-align: center;
  font-size: 14px;
  color: var(--ink-soft);
  line-height: 1.6;
}
.retail__note-icon {
  color: var(--green-2);
  margin-right: 8px;
}

@media (max-width: 960px) {
  .retail__grid { grid-template-columns: 1fr; gap: 22px; }
  .retail-hero { padding: 140px 0 84px; }
  .retail { padding: 80px 0 80px; }
}

/* ---- Retail band (CTA strip) ---- */
.retail-band {
  position: relative;
  background: var(--navy-2);
  color: #fff;
  padding: 80px 0;
  overflow: hidden;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.retail-band__grain {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 20% 50%, rgba(125,194,66,0.14), transparent 55%),
    radial-gradient(ellipse at 90% 30%, rgba(125,194,66,0.06), transparent 50%);
  pointer-events: none;
}
.retail-band__inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 40px;
}
.retail-band__title {
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(32px, 4vw, 52px);
  line-height: 1.05;
  letter-spacing: -0.01em;
  margin: 0;
  color: #fff;
}
.retail-band__title em {
  font-style: italic;
  color: var(--green);
  font-weight: 500;
}
.retail-band__sub {
  margin: 14px 0 0;
  font-size: 17px;
  color: rgba(255,255,255,0.72);
  max-width: 520px;
  line-height: 1.55;
}
.retail-band__cta {
  flex-shrink: 0;
}
@media (max-width: 760px) {
  .retail-band__inner { grid-template-columns: 1fr; }
}

/* ---- Floating WhatsApp button ---- */
.wa-float {
  position: fixed;
  right: 24px;
  bottom: 24px;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: var(--green);
  color: var(--navy);
  display: grid;
  place-items: center;
  z-index: 50;
  box-shadow:
    0 14px 28px -10px rgba(125,194,66,0.55),
    0 0 0 1px rgba(13,27,42,0.08);
  transition: transform .25s ease, box-shadow .25s ease, background .25s ease;
}
.wa-float:hover {
  transform: translateY(-2px) scale(1.04);
  background: var(--green-2);
  box-shadow:
    0 18px 32px -10px rgba(125,194,66,0.7),
    0 0 0 1px rgba(13,27,42,0.08);
}
.wa-float svg {
  width: 30px; height: 30px;
  position: relative;
  z-index: 2;
}
.wa-float__pulse {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: var(--green);
  opacity: 0.6;
  animation: waPulse 2.2s ease-out infinite;
  z-index: 1;
}
@keyframes waPulse {
  0%   { transform: scale(1);    opacity: 0.55; }
  70%  { transform: scale(1.45); opacity: 0;    }
  100% { transform: scale(1.45); opacity: 0;    }
}
@media (max-width: 600px) {
  .wa-float { width: 54px; height: 54px; right: 16px; bottom: 16px; }
  .wa-float svg { width: 26px; height: 26px; }
}


/* =========================================================
   HOMEPAGE — Explore band (under hero)
   ========================================================= */
.explore {
  background: #08111c;
  color: #fff;
  padding: 100px 0 80px;
  border-top: 1px solid var(--line);
  position: relative;
}
.explore__head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: end;
  gap: 40px;
  margin-bottom: 56px;
}
.explore__title {
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(36px, 4.6vw, 64px);
  line-height: 1;
  letter-spacing: -0.01em;
  margin: 16px 0 0;
  color: #fff;
}
.explore__title em { font-style: italic; color: var(--green); font-weight: 500; }
.explore__lede {
  font-size: 17px;
  line-height: 1.6;
  color: rgba(255,255,255,0.7);
  max-width: 420px;
  margin: 0;
  justify-self: end;
}
.explore__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}
.explore__card {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  aspect-ratio: 3 / 4;
  border-radius: 18px;
  overflow: hidden;
  color: #fff;
  background: var(--navy-2);
  isolation: isolate;
  transition: transform .35s ease;
}
.explore__card:hover { transform: translateY(-4px); }
.explore__card-img {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  z-index: -2;
  transition: transform .6s ease;
}
.explore__card:hover .explore__card-img { transform: scale(1.06); }
.explore__card::before {
  content: "";
  position: absolute; inset: 0;
  z-index: -1;
  background: linear-gradient(180deg, rgba(13,27,42,0) 30%, rgba(13,27,42,0.85) 100%);
}
.explore__card-body {
  padding: 22px 22px 24px;
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 12px;
}
.explore__card h3 {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 28px;
  line-height: 1;
  margin: 0;
  letter-spacing: -0.01em;
}
.explore__card span {
  display: block;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 8px;
}
.explore__card-arrow {
  width: 38px; height: 38px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.35);
  display: grid; place-items: center;
  color: #fff;
  flex-shrink: 0;
  transition: background .25s ease, color .25s ease, border-color .25s ease, transform .25s ease;
}
.explore__card:hover .explore__card-arrow {
  background: var(--green);
  border-color: var(--green);
  color: var(--navy);
  transform: translateX(3px);
}
@media (max-width: 960px) {
  .explore__head { grid-template-columns: 1fr; }
  .explore__lede { justify-self: start; }
  .explore__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .explore__grid { grid-template-columns: 1fr; }
  .explore__card { aspect-ratio: 16 / 10; }
}

/* =========================================================
   PAGE — Generic top header (categorias, galeria, nosotros, contacto)
   ========================================================= */
.page-head {
  position: relative;
  background: var(--navy);
  color: #fff;
  padding: 170px 0 100px;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}
.page-head__inner {
  position: relative;
  z-index: 2;
  max-width: 880px;
}
.page-head__title {
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(48px, 7vw, 96px);
  line-height: 1;
  letter-spacing: -0.02em;
  margin: 22px 0 0;
  color: #fff;
}
.page-head__title em { font-style: italic; color: var(--green); font-weight: 500; }
.page-head__sub {
  margin: 24px 0 0;
  font-size: 19px;
  line-height: 1.6;
  max-width: 600px;
  color: rgba(255,255,255,0.78);
}

/* =========================================================
   CONTACT PAGE
   ========================================================= */
.contact-page {
  background: var(--cream);
  color: var(--ink);
  padding: 100px 0 110px;
}
.contact-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 40px;
  align-items: stretch;
}
.contact-card {
  background: #fff;
  border: 1px solid rgba(13,27,42,0.08);
  border-radius: 22px;
  padding: 44px 44px 44px;
  display: flex;
  flex-direction: column;
  box-shadow: 0 24px 48px -28px rgba(13,27,42,0.25);
}
.contact-card__eyebrow {
  font-size: 11.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--green-2);
  font-weight: 600;
  margin: 0 0 8px;
}
.contact-card h2 {
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(34px, 4vw, 46px);
  line-height: 1.05;
  letter-spacing: -0.01em;
  margin: 0 0 8px;
  color: var(--ink);
}
.contact-card h2 em { font-style: italic; color: var(--green-2); font-weight: 500; }
.contact-card p.lede {
  font-size: 17px;
  line-height: 1.6;
  color: var(--ink-soft);
  margin: 6px 0 28px;
  max-width: 460px;
}
.contact-list {
  list-style: none;
  padding: 0;
  margin: 0 0 28px;
  display: flex;
  flex-direction: column;
  gap: 22px;
  border-top: 1px solid rgba(13,27,42,0.08);
  padding-top: 28px;
}
.contact-list li {
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: 16px;
  align-items: start;
}
.contact-list .lbl {
  font-size: 11.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin: 0 0 4px;
  font-weight: 600;
}
.contact-list .val {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 22px;
  line-height: 1.2;
  color: var(--ink);
  letter-spacing: -0.005em;
}
.contact-list a.val:hover { color: var(--green-2); }
.contact-icon {
  width: 40px; height: 40px;
  border-radius: 12px;
  background: var(--green-soft);
  color: var(--green-2);
  display: grid;
  place-items: center;
}
.contact-icon svg { width: 18px; height: 18px; }
.contact-card__actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: auto;
  padding-top: 8px;
}

.contact-side {
  display: flex;
  flex-direction: column;
  gap: 22px;
}
.contact-pane {
  background: var(--navy);
  color: #fff;
  border-radius: 22px;
  padding: 36px;
  position: relative;
  overflow: hidden;
  flex: 1;
}
.contact-pane h3 {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 28px;
  line-height: 1.1;
  margin: 0 0 18px;
  color: #fff;
}
.contact-pane h3 em { font-style: italic; color: var(--green); font-weight: 500; }
.contact-pane p {
  margin: 0 0 8px;
  font-size: 15px;
  line-height: 1.6;
  color: rgba(255,255,255,0.78);
}
.hours-list {
  list-style: none;
  padding: 0;
  margin: 18px 0 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  font-size: 15px;
  color: rgba(255,255,255,0.85);
}
.hours-list li {
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px dashed rgba(255,255,255,0.12);
}
.hours-list li:last-child { border-bottom: 0; }
.hours-list .day { color: rgba(255,255,255,0.7); }
.hours-list .time { font-family: var(--serif); font-size: 17px; }

.contact-pane--green {
  background: var(--green);
  color: var(--navy);
}
.contact-pane--green h3 { color: var(--navy); }
.contact-pane--green h3 em { color: var(--navy); font-style: italic; }
.contact-pane--green p { color: rgba(13,27,42,0.78); }
.contact-pane--green .pane-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 18px;
  font-weight: 600;
  color: var(--navy);
  border-bottom: 1px solid var(--navy);
  padding-bottom: 4px;
  font-size: 15px;
}

@media (max-width: 900px) {
  .contact-grid { grid-template-columns: 1fr; }
  .contact-card { padding: 32px 26px; }
}


/* =========================================================
   RESPONSIVE OVERRIDES  (fluid scaling, no horizontal scroll)
   ========================================================= */

/* --- Hard no-overflow guards --- */
html, body {
  overflow-x: clip;
  max-width: 100%;
}
img, video, svg, iframe {
  max-width: 100%;
  height: auto;
}

/* --- Fluid horizontal padding token --- */
:root {
  --pad-x: clamp(16px, 4vw, 32px);
}

/* Re-apply the token to every wrapper that previously used a fixed 32px */
.container,
.nav__inner,
.hero__inner,
.cta__inner,
.footer__inner,
.footer__base {
  padding-left: var(--pad-x);
  padding-right: var(--pad-x);
}

/* Section paddings on mobile — pull verticals in so things breathe */
@media (max-width: 760px) {
  .hero { isolation: isolate; }
  .hero__inner { padding-top: 56px; padding-bottom: 72px; }
  .cats, .why, .gallery, .cta, .retail, .contact-page, .explore { padding-top: 72px; padding-bottom: 72px; }
  .page-head { padding-top: 130px; padding-bottom: 70px; }
  .retail-hero { padding-top: 130px; padding-bottom: 70px; }
}

/* --- Type: lower the floors so headlines don't overflow on narrow phones --- */
.hero__title          { font-size: clamp(40px, 9vw, 96px); }
.section__title       { font-size: clamp(30px, 6.6vw, 64px); }
.page-head__title     { font-size: clamp(36px, 9vw, 96px); }
.retail-hero__title   { font-size: clamp(38px, 9.5vw, 104px); }
.retail-band__title   { font-size: clamp(28px, 5.4vw, 52px); }
.cta__title           { font-size: clamp(34px, 7vw, 76px); }
.explore__title       { font-size: clamp(30px, 6.4vw, 64px); }
.contact-card h2      { font-size: clamp(28px, 5vw, 46px); }
.product__name        { font-size: clamp(22px, 3.4vw, 30px); }
.product__price       { font-size: clamp(42px, 7.4vw, 56px); }
.hero__meta strong    { font-size: clamp(26px, 4vw, 36px); }

/* Long words must break before they overflow */
.hero__title,
.section__title,
.page-head__title,
.retail-hero__title,
.retail-band__title,
.cta__title,
.explore__title,
.contact-card h2,
.product__name {
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* Marquee text shrinks on phones */
@media (max-width: 600px) {
  .hero__marquee-track { font-size: 20px; gap: 22px; }
  .hero__marquee-track i { font-size: 14px; }
}

/* Hero media: clamp height so it never towers over the title on mobile */
@media (max-width: 720px) {
  .hero__media {
    min-height: 0;
    aspect-ratio: auto;
    height: clamp(280px, 70vw, 460px);
    max-width: 100%;
    margin-inline: auto;
  }
}

/* CTA beam: the giant "Laser" number was a fixed 140px → fluid */
.cta__beam-num { font-size: clamp(72px, 12vw, 140px); }
@media (max-width: 720px) {
  .cta__beam { max-width: 100%; aspect-ratio: 1.4 / 1; }
}

/* Footer base — keep two columns where possible, stack only on phones */
@media (max-width: 540px) {
  .footer__base { text-align: center; }
}

/* Section heads centered on phones look better */
@media (max-width: 760px) {
  .section__head { text-align: left; }
  .section__head .section__title { margin-top: 12px; }
}

/* --- Categories: ensure the navy gradient strip doesn't push width --- */
.cats, .gallery, .why, .retail, .contact-page { overflow-x: clip; }

/* =========================================================
   MOBILE NAV — Hamburger drawer (<=860px)
   ========================================================= */
.nav__burger {
  display: none;
  width: 44px; height: 44px;
  background: transparent;
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 12px;
  color: #fff;
  cursor: pointer;
  padding: 0;
  place-items: center;
  flex-direction: column;
  gap: 4px;
  align-items: center;
  justify-content: center;
  transition: border-color .2s ease, background .2s ease;
}
.nav__burger:hover { border-color: rgba(255,255,255,0.32); }
.nav__burger span {
  display: block;
  width: 18px;
  height: 1.5px;
  background: currentColor;
  border-radius: 2px;
  transform-origin: center;
  transition: transform .25s ease, opacity .25s ease;
}
.nav--open .nav__burger { border-color: var(--green); color: var(--green); }
.nav--open .nav__burger span:nth-child(1) { transform: translateY(5.5px) rotate(45deg); }
.nav--open .nav__burger span:nth-child(2) { opacity: 0; }
.nav--open .nav__burger span:nth-child(3) { transform: translateY(-5.5px) rotate(-45deg); }

@media (max-width: 860px) {
  .nav__inner { position: relative; gap: 16px; padding-top: 14px; padding-bottom: 14px; }
  .nav__burger { display: flex; margin-left: auto; }
  .nav__cta { display: none; }

  .nav__links {
    position: absolute;
    top: 100%;
    left: 0; right: 0;
    flex-direction: column;
    background: rgba(13, 27, 42, 0.97);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    padding: 14px var(--pad-x) 24px;
    gap: 2px;
    border-bottom: 1px solid var(--line);
    transform: translateY(-12px);
    opacity: 0;
    pointer-events: none;
    transition: transform .25s ease, opacity .25s ease;
    font-size: 18px;
    max-height: calc(100vh - 70px);
    overflow-y: auto;
  }
  .nav__links a {
    padding: 14px 4px;
    border-bottom: 1px solid rgba(255,255,255,0.06);
  }
  .nav__links a:last-child { border-bottom: 0; }
  .nav__links a::after { display: none; }

  .nav--open .nav__links {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
  }
}

/* =========================================================
   FIX FINAL — hero compacto + sin scroll horizontal
   (override: va al final para ganar la cascada)
   ========================================================= */

/* Nada se desborda a los lados en ninguna pantalla */
html, body { max-width: 100%; overflow-x: hidden; }
.hero, .hero__marquee, .page-head, section, footer { max-width: 100%; }
img, svg { max-width: 100%; height: auto; }

/* Desktop: cerrar el hueco negro entre los stats y el marquee.
   El problema era que la columna de fotos forzaba mucha altura y
   align-items:center dejaba un vacío grande debajo de los stats. */
@media (min-width: 961px) {
  .hero__inner {
    align-items: center;
    padding-top: 76px;
    padding-bottom: 56px;
  }
  .hero__media {
    min-height: 0;
    aspect-ratio: 1 / 0.84;
  }
  .hero__meta { padding-top: 24px; }
}

/* Pantallas medianas: idem, sin exceso vertical */
@media (min-width: 721px) and (max-width: 960px) {
  .hero__inner { padding-bottom: 56px; gap: 44px; }
  .hero__media { min-height: 0; aspect-ratio: 1 / 0.8; }
}

/* =========================================================
   FIX — "Por qué elegirnos" más compacto (menos aire)
   ========================================================= */
.why { padding: 64px 0 !important; }
.why__head { margin-bottom: 40px !important; }
.why__item { padding: 30px 24px 32px !important; }
.why__icon { margin: 18px 0 16px !important; width: 46px !important; height: 46px !important; border-radius: 12px; }
.why__icon svg { width: 22px !important; height: 22px !important; }
.why__item h3 { font-size: 23px !important; margin-bottom: 8px !important; }
.why__item p { font-size: 15px !important; line-height: 1.55 !important; }
@media (max-width: 760px) {
  .why { padding: 48px 0 !important; }
  .why__item { padding: 24px 20px 26px !important; }
}

/* =========================================================
   FIX — Categorías 4 por línea (tarjetas más compactas)
   ========================================================= */
@media (min-width: 961px) {
  .cats__grid { grid-template-columns: repeat(4, 1fr) !important; gap: 18px !important; }
  .cat { min-height: 300px !important; }
  .cat__body h3 { font-size: 21px !important; }
  .cat__body p { font-size: 14px !important; }
}

/* =========================================================
   FIX — Encabezado oscuro (.page-head) más compacto
   para que las categorías se asomen y la gente sepa
   que hay contenido abajo (señal de scroll)
   ========================================================= */
.page-head { padding: 116px 0 52px !important; }
.page-head__title { font-size: clamp(34px, 5vw, 60px) !important; margin-top: 16px !important; }
.page-head__sub { font-size: 17px !important; margin-top: 16px !important; }
@media (max-width: 760px) {
  .page-head { padding: 96px 0 40px !important; }
  .page-head__title { font-size: clamp(30px, 8vw, 44px) !important; }
  .page-head__sub { font-size: 15px !important; }
}

/* =========================================================
   FIX — Hero de Al Detal (.retail-hero) compacto,
   mismo criterio que .page-head: que los productos
   se asomen y la gente sepa que hay que scrollear
   ========================================================= */
.retail-hero { padding: 116px 0 52px !important; }
.retail-hero__title { font-size: clamp(34px, 5vw, 60px) !important; margin-top: 16px !important; }
.retail-hero__sub { font-size: 17px !important; margin-top: 16px !important; }
.retail-hero__meta { margin-top: 22px !important; }
@media (max-width: 760px) {
  .retail-hero { padding: 96px 0 40px !important; }
  .retail-hero__title { font-size: clamp(30px, 8vw, 44px) !important; }
  .retail-hero__sub { font-size: 15px !important; }
}

/* =========================================================
   FIX — Altura uniforme en TODOS los headers internos
   (.page-head y .retail-hero) para que cada página
   se vea del mismo tamaño sin importar el largo del título
   ========================================================= */
.page-head, .retail-hero {
  min-height: 360px !important;
  display: flex !important;
  align-items: center !important;
  padding-top: 110px !important;
  padding-bottom: 48px !important;
}
.page-head > .page-head__inner,
.retail-hero > .retail-hero__inner { width: 100%; }
@media (max-width: 760px) {
  .page-head, .retail-hero {
    min-height: 280px !important;
    padding-top: 92px !important;
    padding-bottom: 36px !important;
  }
}

/* =========================================================
   FIX — Contacto: mapa arriba, horario medio,
   "al detal" como banda fina abajo
   ========================================================= */
.contact-pane--map {
  padding: 0 !important;
  flex: 0 0 auto !important;
  min-height: 300px;
  height: 300px;
}
.contact-pane--map iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}
.detal-strip {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  flex-wrap: wrap;
  background: rgba(125,194,66,0.12);
  border: 1px solid rgba(125,194,66,0.4);
  border-radius: 16px;
  padding: 16px 22px;
  text-decoration: none;
  transition: background .2s ease;
}
.detal-strip:hover { background: rgba(125,194,66,0.2); }
.detal-strip__txt {
  font-size: 14px;
  color: var(--ink);
  line-height: 1.5;
}
.detal-strip__txt strong { color: var(--navy); font-weight: 700; }
.detal-strip__cta {
  font-size: 14px;
  font-weight: 700;
  color: #4e7d20;
  white-space: nowrap;
}

/* =========================================================
   FIX — Hero Inicio: slideshow de fotos borrosas de fondo
   (Opción A: sin tarjetas, texto centrado, badge 100%)
   ========================================================= */
.hero--slideshow .hero__inner {
  grid-template-columns: 1fr !important;
  justify-items: center;
  text-align: center;
  padding-top: 120px;
  padding-bottom: 130px;
}
.hero--slideshow .hero__copy { max-width: 760px; }
.hero--slideshow .hero__actions,
.hero--slideshow .hero__meta { justify-content: center; }
.hero--slideshow .eyebrow { margin-left: auto; margin-right: auto; }

.hero__slideshow { position: absolute; inset: 0; z-index: 0; overflow: hidden; }
.hero__slide {
  position: absolute; inset: -4%;
  background-size: cover;
  background-position: center;
  filter: blur(5px) brightness(0.6) saturate(1.12);
  transform: scale(1.06);
  opacity: 0;
  transition: opacity 1.6s ease-in-out;
}
.hero__slide.is-active { opacity: 1; }
.hero__veil {
  position: absolute; inset: 0; z-index: 1;
  background:
    radial-gradient(900px 500px at 80% -10%, rgba(125,194,66,0.14), transparent 60%),
    linear-gradient(180deg, rgba(13,27,42,0.55) 0%, rgba(10,22,35,0.70) 100%);
  pointer-events: none;
}
.hero--slideshow .hero__inner { position: relative; z-index: 3; }
.hero--slideshow .hero__grain,
.hero--slideshow .hero__beam { z-index: 2; }
.hero--slideshow .hero__marquee { position: relative; z-index: 3; }

/* Badge "100% hecho a la medida en Panamá" */
.hero__pledge {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  margin-top: 34px;
  padding: 12px 22px 12px 16px;
  border: 1px solid rgba(125,194,66,0.45);
  background: rgba(125,194,66,0.12);
  border-radius: 999px;
  backdrop-filter: blur(2px);
}
.hero__pledge-num {
  font-family: var(--serif);
  font-style: italic;
  font-size: 30px;
  font-weight: 600;
  color: var(--green);
  line-height: 1;
}
.hero__pledge-lbl {
  font-size: 14px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.85);
  font-weight: 600;
}
@media (max-width: 760px) {
  .hero--slideshow .hero__inner { padding-top: 96px; padding-bottom: 90px; }
  .hero__pledge-num { font-size: 24px; }
  .hero__pledge-lbl { font-size: 12px; }
}

/* =========================================================
   Hero slideshow: fondo navy + centrar el bloque de texto
   ========================================================= */
/* el fondo navy de la propia sección tapaba las fotos */
.hero--slideshow { background: #0a1623; }

/* Centrar todo el bloque de texto del hero */
.hero--slideshow .hero__copy { margin-left: auto; margin-right: auto; }
.hero--slideshow .hero__sub {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
  max-width: 600px;
}
.hero--slideshow .hero__title { text-align: center; }

/* =========================================================
   Menú desplegable de Categorías en el navbar
   ========================================================= */
.nav__dd { position: relative; display: inline-flex; align-items: center; }
.nav__dd-btn { display: inline-flex; align-items: center; gap: 6px; }
.nav__dd-caret { font-size: 10px; opacity: .7; transition: transform .2s ease; }
.nav__dd:hover .nav__dd-caret,
.nav__dd:focus-within .nav__dd-caret { transform: rotate(180deg); }
.nav__dd-menu {
  position: absolute;
  top: calc(100% + 6px);
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  min-width: 250px;
  background: rgba(13,27,42,0.98);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 14px;
  padding: 8px;
  display: flex;
  flex-direction: column;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .2s ease, transform .2s ease, visibility .2s;
  box-shadow: 0 24px 50px -20px rgba(0,0,0,0.65);
  z-index: 200;
}
.nav__dd-menu::before {
  content: "";
  position: absolute;
  top: -12px; left: 0; right: 0;
  height: 12px;
}
.nav__dd:hover .nav__dd-menu,
.nav__dd:focus-within .nav__dd-menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.nav__dd-menu a {
  padding: 11px 16px;
  border-radius: 9px;
  color: rgba(255,255,255,0.82);
  font-size: 14px;
  white-space: nowrap;
  transition: background .15s ease, color .15s ease;
}
.nav__dd-menu a:hover {
  background: rgba(125,194,66,0.15);
  color: var(--green);
}
/* Móvil: sin subcategorías expandidas. "Categorías" actúa como link directo */
@media (max-width: 860px) {
  /* Drawer del navbar — fondo opaco, cubre toda la pantalla */
  .nav__links {
    background: #0d1b2a !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    height: calc(100vh - 70px);
    max-height: calc(100vh - 70px);
  }
  /* Ocultar el dropdown de subcategorías tanto en nav como en footer */
  .nav__dd-menu { display: none !important; }
  .nav__dd-caret { display: none !important; }
  /* "Categorías" se comporta como cualquier link normal */
  .nav__dd { display: block; width: 100%; }
  .nav__dd-btn {
    display: block;
    width: 100%;
    pointer-events: auto !important;
  }
  /* Footer: "Categorías" igual que los otros links */
  .footer .nav__dd-btn {
    font-size: 14.5px;
    line-height: 1.6;
    color: rgba(255,255,255,0.78);
    padding: 2px 0;
    margin-bottom: 4px;
    text-transform: none;
    letter-spacing: normal;
  }
}

/* =========================================================
   Al Detal — placeholder "Foto próximamente"
   (ocupa el mismo espacio 4/3 que tendrá la foto real)
   ========================================================= */
.product__media--soon {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--cream-2), #e7e1d2);
}
.product__soon {
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(13,27,42,0.42);
  font-weight: 600;
  border: 1px dashed rgba(13,27,42,0.22);
  padding: 8px 16px;
  border-radius: 100px;
}

/* =========================================================
   FIX — Galería: mostrar fotos COMPLETAS (sin recorte/zoom)
   ========================================================= */
.g { background: #fff !important; border: 1px solid #ece7da; }
.g img { object-fit: contain !important; padding: 10px; }
.g:hover img { transform: none !important; }

/* =========================================================
   FIX FINAL — Galería estilo masonry (Pinterest):
   fotos completas, proporción natural, sin huecos
   ========================================================= */
.gallery__grid {
  display: flex !important;
  gap: 16px;
  column-count: unset !important;
  grid-template-columns: none !important;
  grid-auto-rows: auto !important;
  align-items: flex-start;
}
.gcol {
  flex: 1 1 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-width: 0;
}
.g {
  display: block !important;
  width: 100%;
  margin: 0 !important;
  background: #fff !important;
  border: 1px solid #ece7da;
  border-radius: 14px;
  overflow: hidden;
  grid-row: auto !important;
  grid-column: auto !important;
}
.g img {
  width: 100% !important;
  height: auto !important;
  padding: 0 !important;
  display: block;
}
.g.is-hidden { display: none !important; }

/* =========================================================
   Galería — filtros por categoría
   ========================================================= */
.gallery__filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:28px}
.gallery__filter{padding:9px 20px;border-radius:999px;border:1px solid var(--line-dark);background:#fff;color:var(--ink);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit}
.gallery__filter:hover{border-color:var(--green);color:var(--green-2)}
.gallery__filter.is-active{background:var(--navy);color:#fff;border-color:var(--navy)}
.g.is-hidden{display:none !important}

/* =========================================================
   FAQ — Preguntas frecuentes (landings SEO)
   ========================================================= */
.faq{background:#fff;padding:44px 0;border-top:1px solid #ece7da}
.faq__title{font-family:var(--serif),Georgia,serif;font-size:clamp(20px,2.6vw,26px);font-weight:600;line-height:1.2;margin:0 0 20px;color:var(--navy);text-align:center}
.faq__list{max-width:680px;margin:0 auto;display:flex;flex-direction:column;gap:6px}
.faq__item{background:#faf7f1;border:1px solid #ece7da;border-radius:8px;padding:0;overflow:hidden;transition:border-color .2s}
.faq__item[open]{border-color:var(--navy);background:#fff}
.faq__item summary{cursor:pointer;padding:10px 14px;font-weight:600;font-size:13.5px;color:var(--navy);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px;line-height:1.3}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";font-size:17px;font-weight:400;color:var(--navy);transition:transform .2s;flex-shrink:0}
.faq__item[open] summary::after{content:"−"}
.faq__item p{margin:0;padding:0 14px 12px;color:#3a4654;line-height:1.5;font-size:13px}

/* =========================================================
   Al Detal — Banner de personalización
   ========================================================= */
.retail__custom-banner{display:flex;align-items:flex-start;gap:14px;max-width:780px;margin:0 auto 44px;padding:18px 24px;background:#faf7f1;border:1px solid #ece7da;border-left:3px solid var(--green);border-radius:10px}
.retail__custom-banner-icon{color:var(--green);font-size:20px;line-height:1;flex-shrink:0;margin-top:2px}
.retail__custom-banner p{margin:0;font-size:14px;line-height:1.55;color:#3a4654}
.retail__custom-banner p strong{color:var(--navy);font-weight:700}
@media (max-width:600px){.retail__custom-banner{padding:14px 18px;gap:10px;margin-bottom:32px}.retail__custom-banner p{font-size:13px}}

/* ===================== LIGHTBOX ===================== */
.lightbox{position:fixed;inset:0;background:rgba(13,27,42,0.92);display:flex;align-items:center;justify-content:center;z-index:9999;opacity:0;visibility:hidden;transition:opacity .25s ease, visibility .25s ease;padding:40px}
.lightbox.is-open{opacity:1;visibility:visible}
.lightbox__figure{margin:0;max-width:min(92vw,1200px);max-height:88vh;display:flex;flex-direction:column;align-items:center;gap:14px}
.lightbox__figure img{max-width:100%;max-height:80vh;width:auto;height:auto;object-fit:contain;border-radius:8px;box-shadow:0 30px 80px rgba(0,0,0,0.5);background:#0d1b2a}
.lightbox__cap{color:#f4efe7;font-family:var(--sans),system-ui,sans-serif;font-size:14px;letter-spacing:0.02em;text-align:center;max-width:80ch;opacity:0.85}
.lightbox__close,.lightbox__nav{position:absolute;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);color:#fff;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:24px;line-height:1;transition:background .2s ease, transform .2s ease;font-family:system-ui,sans-serif}
.lightbox__close:hover,.lightbox__nav:hover{background:rgba(255,255,255,0.22);transform:scale(1.05)}
.lightbox__close{top:24px;right:24px;font-size:28px}
.lightbox__nav--prev{left:24px;top:50%;transform:translateY(-50%)}
.lightbox__nav--next{right:24px;top:50%;transform:translateY(-50%)}
.lightbox__nav--prev:hover{transform:translateY(-50%) scale(1.05)}
.lightbox__nav--next:hover{transform:translateY(-50%) scale(1.05)}
@media (max-width:600px){
  .lightbox{padding:16px}
  .lightbox__close{top:12px;right:12px;width:40px;height:40px;font-size:22px}
  .lightbox__nav{width:40px;height:40px;font-size:18px}
  .lightbox__nav--prev{left:8px}
  .lightbox__nav--next{right:8px}
  .lightbox__cap{font-size:12px}
}

/* =========================================================
   ACCESIBILIDAD — foco visible por teclado
   (no afecta el mouse: solo aparece al navegar con Tab)
   ========================================================= */
a:focus-visible,
button:focus-visible,
summary:focus-visible,
.btn:focus-visible,
.nav__links a:focus-visible,
.gallery__filter:focus-visible,
.wa-float:focus-visible,
.lightbox__close:focus-visible,
.lightbox__nav:focus-visible {
  outline: 3px solid var(--green);
  outline-offset: 3px;
  border-radius: 6px;
}
/* En superficies oscuras, un halo para que el verde resalte */
.nav__links a:focus-visible,
.wa-float:focus-visible,
.lightbox__close:focus-visible,
.lightbox__nav:focus-visible {
  outline-color: #fff;
  box-shadow: 0 0 0 6px rgba(125,194,66,0.45);
}

/* =========================================================
   MOVIMIENTO REDUCIDO — respeta la preferencia del sistema
   (mareo / vestibular). Apaga marquee, pulsos y transiciones.
   ========================================================= */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
  .hero__marquee-track,
  .wa-float__pulse,
  .cta__beam-dot {
    animation: none !important;
  }
  .hero__slide { transition: opacity 0.2s linear !important; }
}
