/* ============================================================
   GRWM · base
   ============================================================ */
:root {
  color-scheme: dark;
  --pink: #ff3d96;
  --pink-bright: #ff1f8e;
  --ink: #111;
  --paper: #fff;
  --bg: #000;
  --border: rgba(255, 255, 255, .1);
  --border-soft: rgba(255, 255, 255, .06);
  --muted: rgba(255, 255, 255, .55);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
html, body { width: 100%; }
body {
  font-family: 'Inter', system-ui, sans-serif;
  -webkit-font-smoothing: antialiased;
  background: var(--bg);
  color: #fff;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button { font: inherit; cursor: pointer; border: 0; background: 0; color: inherit; }
body.locked { overflow: hidden; }

/* ============================================================
   ACCESIBILIDAD: foco visible on-brand + skip-link
   ============================================================ */
/* Anillo de foco rosa sólo para navegación por teclado (no en click/touch) */
a:focus-visible,
button:focus-visible,
input:focus-visible,
[tabindex]:focus-visible,
summary:focus-visible {
  outline: 2px solid var(--pink);
  outline-offset: 2px;
  border-radius: 2px;
}
/* Radios de color/talla van ocultos: el foco debe verse en su <span> visible */
.opts .swatches input:focus-visible + span,
.opts .sizes input:focus-visible + span {
  outline: 2px solid var(--pink);
  outline-offset: 2px;
}

/* Skip-link: salta la navegación. Visible sólo al recibir foco con teclado. */
.skip-link {
  position: absolute; left: 12px; top: -60px; z-index: 10001;
  background: var(--pink); color: #000;
  padding: 10px 18px; border-radius: 999px;
  font-family: 'Space Grotesk', sans-serif; font-weight: 700;
  font-size: 13px; letter-spacing: .04em;
  transition: top .2s ease;
}
.skip-link:focus { top: 12px; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}

.hide-mobile { display: inline; }
@media (max-width: 600px) { .hide-mobile { display: none; } }

/* ============================================================
   INTRO LOADER
   ============================================================ */
#loader {
  position: fixed; inset: 0; z-index: 10000;
  background: #000; display: grid; place-items: center;
  transition: opacity 700ms ease, visibility 700ms;
}
#loader.gone { opacity: 0; visibility: hidden; pointer-events: none; }

.loader-mark { text-align: center; overflow: visible; }
.loader-letters {
  display: flex; gap: clamp(2px, .6vw, 8px);
  justify-content: center; overflow: hidden; padding: 0 8px;
}
.loader-mark .l {
  display: inline-block;
  font-family: 'Archivo Black', sans-serif;
  font-size: clamp(64px, 14vw, 200px);
  color: #fff; letter-spacing: -.05em; line-height: 1;
  transform: translateY(120%);
  animation: dropIn 1.1s cubic-bezier(.16, .84, .24, 1) forwards;
}
.loader-mark .l.pink { color: var(--pink); }
.loader-mark .l:nth-child(1) { animation-delay: .1s; }
.loader-mark .l:nth-child(2) { animation-delay: .25s; }
.loader-mark .l:nth-child(3) { animation-delay: .4s; }
.loader-mark .l:nth-child(4) { animation-delay: .55s; }

.loader-brush {
  height: clamp(8px, 1.2vw, 16px); width: 88%; background: #fff;
  margin: clamp(10px, 1.4vw, 20px) auto 0;
  clip-path: polygon(0% 40%, 4% 10%, 12% 35%, 22% 5%, 36% 55%, 50% 15%, 64% 60%, 78% 20%, 90% 50%, 100% 25%, 100% 100%, 0% 100%);
  transform: scaleX(0); transform-origin: left center;
  animation: drawBrush .9s cubic-bezier(.65, 0, .35, 1) .85s forwards;
}
.loader-tag {
  margin-top: 24px;
  font-family: 'Space Grotesk', sans-serif; font-size: 11px; letter-spacing: .4em;
  color: #fff; opacity: 0; text-transform: uppercase;
  animation: fadeIn .7s ease 1.4s forwards;
}

@keyframes dropIn { to { transform: translateY(0); } }
@keyframes drawBrush { to { transform: scaleX(1); } }
@keyframes fadeIn { to { opacity: .6; } }

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
[data-reveal] {
  opacity: 0; transform: translateY(22px);
  transition:
    opacity 1100ms cubic-bezier(.16, .84, .24, 1) var(--delay, 0ms),
    transform 1100ms cubic-bezier(.16, .84, .24, 1) var(--delay, 0ms);
  will-change: opacity, transform;
}
[data-reveal="left"] { transform: translateX(-28px); }
[data-reveal="right"] { transform: translateX(28px); }
[data-reveal="scale"] { transform: scale(.97); opacity: 0; }
[data-reveal].is-visible { opacity: 1; transform: translate(0, 0) scale(1); }

@media (prefers-reduced-motion: reduce) {
  #loader { display: none !important; }
  .loader-mark .l, .loader-brush, .loader-tag {
    animation: none !important; transform: none !important; opacity: 1 !important;
  }
  [data-reveal] {
    opacity: 1 !important; transform: none !important; transition: none !important;
  }
  html { scroll-behavior: auto; }
}

/* ============================================================
   TOP NAV (absolute, only over hero)
   ============================================================ */
.top-nav {
  position: absolute; top: 0; left: 0; right: 0; z-index: 30;
  display: flex; justify-content: space-between; align-items: center;
  padding: 18px 28px; color: #fff;
}
.top-nav .logo { font-family: 'Archivo Black'; font-size: 18px; letter-spacing: -.02em; }
.top-nav .logo .m { color: var(--pink); }
.top-nav .meta {
  font-family: 'Space Grotesk'; font-size: 12px; letter-spacing: .15em;
  text-transform: uppercase; display: flex; gap: 22px;
}

/* ============================================================
   HERO
   ============================================================ */
.hero {
  min-height: 100vh; display: grid; place-items: center;
  padding: 120px 24px 80px; position: relative;
}
.hero-inner { text-align: center; max-width: 1100px; }
.hero .eyebrow {
  font-family: 'Space Grotesk'; font-size: 12px; letter-spacing: .35em;
  text-transform: uppercase; opacity: .55;
}
.hero h1 {
  font-family: 'Archivo Black', sans-serif;
  font-size: clamp(72px, 14vw, 220px);
  line-height: .82; letter-spacing: -.04em;
  margin: 22px 0 18px;
}
.hero h1 .pink { color: var(--pink); }
.hero .sub {
  font-family: 'Space Grotesk'; font-size: 14px; letter-spacing: .25em;
  text-transform: uppercase; opacity: .7; margin-bottom: 36px;
}
.hero .cta {
  display: inline-block; padding: 14px 26px;
  border: 1.5px solid #fff; border-radius: 999px;
  font-family: 'Space Grotesk'; font-size: 13px; letter-spacing: .25em;
  text-transform: uppercase; color: #fff;
  transition: background .25s ease, color .25s ease;
}
.hero .cta:hover { background: #fff; color: #000; }
.hero .scroll-hint {
  position: absolute; bottom: 30px; left: 50%; transform: translateX(-50%);
  font-family: 'Space Grotesk'; font-size: 11px; letter-spacing: .3em;
  text-transform: uppercase; opacity: .35;
}

/* ============================================================
   CÁPSULA NAV (sticky)
   ============================================================ */
.capnav {
  position: sticky; top: 0; z-index: 50; background: #000;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: stretch; gap: 0;
  font-family: 'Space Grotesk'; font-weight: 700; font-size: 13px;
  letter-spacing: .18em; text-transform: uppercase;
}
.capnav .home {
  padding: 18px 22px; font-family: 'Archivo Black';
  letter-spacing: -.02em; text-transform: none; font-size: 18px;
  color: #fff; border-right: 1px solid var(--border);
}
.capnav .home .m { color: var(--pink); }
.capnav .links { display: flex; flex: 1; overflow-x: auto; scrollbar-width: none; }
.capnav .links::-webkit-scrollbar { display: none; }
.capnav .links a {
  padding: 18px 22px; border-right: 1px solid var(--border-soft);
  white-space: nowrap; color: #fff; opacity: .6;
  display: flex; align-items: center;
  transition: color .2s ease, opacity .2s ease;
}
.capnav .links a.active { opacity: 1; color: #000; background: var(--pink); }
.capnav .links a:hover { opacity: 1; color: var(--pink); }
.capnav .links a.active:hover { color: #000; }
.capnav .cart-link {
  padding: 18px 22px; border-left: 1px solid var(--border);
  color: #fff; white-space: nowrap;
  display: flex; align-items: center; margin-left: auto;
}
.capnav .cart-link:hover { color: var(--pink); }

/* ============================================================
   MANIFIESTO
   ============================================================ */
.manifesto { padding: 28vh 6vw; }
.manifesto.right { text-align: right; }
.manifesto h2 {
  font-family: 'Archivo Black';
  font-size: clamp(48px, 9vw, 140px);
  line-height: .9; letter-spacing: -.03em; max-width: 18ch;
}
.manifesto.right h2 { margin-left: auto; }
.manifesto h2 em { font-style: normal; color: var(--pink); }
.manifesto p {
  margin-top: 22px; font-family: 'Space Grotesk'; font-size: 13px;
  letter-spacing: .25em; text-transform: uppercase; opacity: .55; max-width: 60ch;
}
.manifesto.right p { margin-left: auto; }

/* ============================================================
   PRODUCT GRID
   ============================================================ */
.grid {
  display: grid; grid-template-columns: repeat(12, 1fr); gap: 1px;
  background: rgba(255, 255, 255, .08);
  border-top: 1px solid rgba(255, 255, 255, .08);
  border-bottom: 1px solid rgba(255, 255, 255, .08);
}
.card { background: #000; padding: 24px; display: flex; flex-direction: column; gap: 18px; }
.card > a { display: flex; flex-direction: column; gap: 18px; height: 100%; color: inherit; }
.card.s6 { grid-column: span 6; }
.card.s4 { grid-column: span 4; }
.card.s8 { grid-column: span 8; }
.card.s12 { grid-column: span 12; }
.card .meta-row {
  display: flex; justify-content: space-between;
  font-family: 'Space Grotesk'; font-size: 12px; letter-spacing: .15em;
  text-transform: uppercase; opacity: .55;
}
.card .title {
  font-family: 'Archivo Black'; font-size: 26px;
  letter-spacing: -.02em; line-height: 1; margin-top: -4px;
}
.card .title em { font-style: normal; color: var(--pink); }
.card .desc { font-size: 14px; opacity: .65; line-height: 1.45; max-width: 38ch; }
.card .foot {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: auto; padding-top: 16px;
  border-top: 1px dashed rgba(255, 255, 255, .2);
  font-family: 'Space Grotesk'; font-size: 13px; letter-spacing: .12em;
  text-transform: uppercase;
}
.card .foot .add {
  padding: 9px 16px; border: 1.5px solid #fff; border-radius: 999px;
  color: #fff; transition: background .2s ease, color .2s ease, border-color .2s ease;
}
.card:hover .foot .add { background: var(--pink); border-color: var(--pink); color: #000; }
.card .price { font-family: 'Archivo Black'; font-size: 20px; color: var(--pink); }
.card.s8 .capsule-row, .card.s12 .capsule-row { display: flex; gap: 24px; align-items: center; flex: 1; }
.card.s8 .capsule-tee, .card.s12 .capsule-tee { flex: 0 0 38%; }
.card.s8 .capsule-body, .card.s12 .capsule-body { flex: 1; }
/* A LIARLA (s12): foto a toda pantalla arriba, texto debajo bien separado */
.card.s12 .capsule-row { flex-direction: column; align-items: stretch; gap: 48px; }
.card.s12 .capsule-tee { flex: 0 0 auto; }
.card.s12 .capsule-tee .tee { aspect-ratio: 16 / 10; }

/* ============================================================
   T-SHIRT MOCKUP (CSS-only, placeholder until real photos)
   ============================================================ */
.tee {
  position: relative; width: 100%; aspect-ratio: 1 / 1;
  display: grid; place-items: center;
  background: #0a0a0a; overflow: hidden;
}
.tee.cream { background: #ece8df; }
.tee.bone { background: #d9d3c3; }
.tee::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(ellipse 70% 60% at 50% 55%, transparent 0 55%, rgba(255, 255, 255, .04) 56% 100%);
}

/* Real product photo inside .tee — supersedes the CSS lockup */
.tee img.photo {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform .8s cubic-bezier(.22, 1, .36, 1);
}
.tee:has(img.photo) { background: transparent; }
.tee:has(img.photo)::before { display: none; }
.tee:has(img.photo) .lockup { display: none; }
.card:hover .tee img.photo { transform: scale(1.03); }
.tee .lockup { text-align: center; line-height: .82; transform: translateY(8%); }

.lockup .top {
  font-family: 'Archivo Black', sans-serif; color: #fff;
  font-size: clamp(28px, 4.2vw, 60px); letter-spacing: -.02em;
}
.lockup .morro {
  font-family: 'Archivo Black', sans-serif; color: var(--pink);
  font-size: clamp(46px, 7vw, 100px); display: inline-block;
  margin-top: 6px; letter-spacing: -.03em;
}
.lockup .smiley { color: var(--pink); font-size: clamp(28px, 4.5vw, 64px); }
.lockup .chulo {
  font-family: 'Archivo Black', sans-serif; color: var(--pink);
  font-size: clamp(50px, 7vw, 110px); letter-spacing: -.04em;
  display: inline-block;
}
.tee.cream .lockup .top { color: var(--ink); }

.tee.grwm .lockup .top { font-size: clamp(60px, 9vw, 130px); letter-spacing: -.04em; }
.tee.grwm .lockup .pink-letter { color: var(--pink); }
.tee.grwm .lockup .morro-line {
  display: block; font-family: 'Inter', sans-serif; font-weight: 800;
  font-size: clamp(10px, 1.2vw, 14px); letter-spacing: .25em;
  margin-top: 14px; color: #fff;
}
.tee.grwm .lockup .pink-text { color: var(--pink); }
.tee.grwm .underline { display: block; height: 6px; width: 64%; background: #fff; margin: 8px auto 0; }
.tee.grwm.cream .lockup .top { color: #111; }
.tee.grwm.cream .lockup .morro-line { color: #111; }
.tee.grwm.cream .underline { background: #111; }

.underline-brush, .brush-stroke {
  display: block; width: 70%; height: 10px; margin: 14px auto 0;
  background: #fff;
  clip-path: polygon(0% 40%, 4% 10%, 12% 35%, 22% 5%, 36% 55%, 50% 15%, 64% 60%, 78% 20%, 90% 50%, 100% 25%, 100% 100%, 0% 100%);
}
.brush-stroke { width: 62%; height: 8px; margin: 10px auto 0; }
.tee.cream .underline-brush, .tee.cream .brush-stroke { background: #111; }

.pink-text { color: var(--pink); }

/* ============================================================
   MARQUEE STRIP
   ============================================================ */
.strip {
  padding: 22px 0; overflow: hidden;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.strip .marquee {
  font-family: 'Archivo Black'; font-size: 36px;
  white-space: nowrap; letter-spacing: -.02em;
  animation: marquee 26s linear infinite;
}
.strip span { margin: 0 28px; }
@keyframes marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

/* ============================================================
   CÁPSULAS TEASER
   ============================================================ */
.caps-teaser {
  padding: 16vh 6vw; display: flex; flex-direction: column;
  border-top: 1px solid rgba(255, 255, 255, .08);
}
.caps-item {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 24px 0; border-bottom: 1px solid rgba(255, 255, 255, .08);
  font-family: 'Archivo Black'; font-size: clamp(48px, 8vw, 120px);
  letter-spacing: -.03em; color: #fff; line-height: 1;
  transition: color .25s ease, padding-left .35s ease;
}
.caps-item:hover { color: var(--pink); padding-left: 20px; }
.caps-item .arrow {
  font-family: 'Space Grotesk'; font-size: 14px; letter-spacing: .25em; opacity: .4;
  transition: color .25s ease, opacity .25s ease;
}
.caps-item:hover .arrow { opacity: 1; color: var(--pink); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-foot { padding: 26vh 6vw 18vh; text-align: center; }
.site-foot h4 {
  font-family: 'Archivo Black'; color: var(--pink);
  font-size: clamp(80px, 15vw, 240px); letter-spacing: -.04em; line-height: .9;
}
.site-foot .legal {
  margin-top: 28px; font-family: 'Space Grotesk'; font-size: 11px;
  letter-spacing: .3em; text-transform: uppercase; opacity: .5;
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 16px;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 900px) {
  .top-nav { padding: 14px 18px; }
  .top-nav .meta { font-size: 10px; gap: 14px; }
  .hero { padding: 110px 20px 80px; }
  .hero h1 { font-size: clamp(64px, 22vw, 160px); }
  .hero .sub { font-size: 12px; letter-spacing: .2em; }

  .capnav .home, .capnav .links a, .capnav .cart-link {
    padding: 14px 14px; font-size: 11px; letter-spacing: .12em;
  }
  .capnav .home { font-size: 16px; letter-spacing: -.02em; }

  .manifesto { padding: 18vh 20px; }
  .manifesto h2 { max-width: none; font-size: clamp(40px, 11vw, 72px); }
  .manifesto.right { text-align: left; }
  .manifesto.right h2, .manifesto.right p { margin-left: 0; }

  .card.s6, .card.s4, .card.s8, .card.s12 { grid-column: span 12; }
  .card { padding: 18px; gap: 14px; }
  .card .title { font-size: 22px; }
  .card.s8 .capsule-row, .card.s12 .capsule-row { flex-direction: column; gap: 40px; }
  .card.s8 .capsule-tee, .card.s12 .capsule-tee { flex: 0 0 auto; }

  .strip .marquee { font-size: 28px; }

  .caps-teaser { padding: 10vh 20px; }
  .caps-item { padding: 18px 0; font-size: clamp(40px, 14vw, 80px); }
  .caps-item:hover { padding-left: 8px; }
  .caps-item .arrow { font-size: 11px; letter-spacing: .15em; }

  .site-foot { padding: 18vh 20px 14vh; }
  .site-foot h4 { font-size: clamp(64px, 22vw, 140px); }
  .site-foot .legal { flex-direction: column; gap: 10px; text-align: center; font-size: 10px; }
}

@media (max-width: 480px) {
  .capnav .cart-link { display: none; }
  .hero .scroll-hint { display: none; }
  .card .foot { flex-wrap: wrap; gap: 10px; }
}

/* ============================================================
   PRODUCT DETAIL PAGE (PDP)
   ============================================================ */
.pdp {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: 0;
  border-bottom: 1px solid var(--border);
}

/* === Galería (vertical stack) === */
.pdp-gallery {
  display: flex; flex-direction: column;
  border-right: 1px solid var(--border);
}
.pdp-gallery .ph {
  position: relative;
  border-bottom: 1px solid var(--border);
}
.pdp-gallery .ph:last-child { border-bottom: 0; }
.pdp-gallery .ph .tee {
  aspect-ratio: 1 / 1;
  width: 100%;
}
.pdp-gallery figcaption {
  position: absolute; left: 18px; top: 18px;
  font-family: 'Space Grotesk'; font-size: 10px;
  letter-spacing: .35em; text-transform: uppercase;
  color: rgba(255,255,255,.55);
  mix-blend-mode: difference;
}

/* === Info panel (sticky) === */
.pdp-info { position: relative; }
.pdp-sticky {
  position: sticky; top: 56px; /* altura aproximada del capnav */
  padding: 48px 40px;
  display: flex; flex-direction: column; gap: 22px;
  max-height: calc(100vh - 56px); overflow-y: auto;
  scrollbar-width: thin; scrollbar-color: rgba(255,255,255,.2) transparent;
}
.pdp-sticky::-webkit-scrollbar { width: 6px; }
.pdp-sticky::-webkit-scrollbar-thumb { background: rgba(255,255,255,.15); border-radius: 4px; }

.pdp-info .back {
  font-family: 'Space Grotesk'; font-size: 11px;
  letter-spacing: .3em; text-transform: uppercase;
  opacity: .55; transition: opacity .2s ease;
  align-self: flex-start;
}
.pdp-info .back:hover { opacity: 1; color: var(--pink); }

.pdp-info .head { display: flex; flex-direction: column; gap: 10px; }
.pdp-info .head .meta {
  font-family: 'Space Grotesk'; font-size: 11px;
  letter-spacing: .25em; text-transform: uppercase;
  opacity: .55;
}
.pdp-info h1 {
  font-family: 'Archivo Black';
  font-size: clamp(36px, 4.5vw, 64px);
  line-height: .95; letter-spacing: -.03em;
}
.pdp-info h1 em { font-style: normal; color: var(--pink); }
.pdp-info .price {
  font-family: 'Archivo Black'; font-size: 28px;
  color: var(--pink); letter-spacing: -.02em;
}

.pdp-info .lead {
  font-size: 15px; line-height: 1.55; opacity: .85;
  max-width: 50ch;
}
.pdp-info .lead.muted { opacity: .55; font-style: italic; }
.pdp-info .lead strong { color: #fff; font-weight: 700; }

/* === Form: opciones, talla, qty === */
.opts { display: flex; flex-direction: column; gap: 18px; margin-top: 6px; }
.opts fieldset { border: 0; padding: 0; }
.opts legend {
  font-family: 'Space Grotesk'; font-size: 11px;
  letter-spacing: .25em; text-transform: uppercase;
  opacity: .55; margin-bottom: 10px;
}

.opts .swatches, .opts .sizes { display: flex; gap: 8px; flex-wrap: wrap; }
.opts .swatches label, .opts .sizes label {
  position: relative; cursor: pointer;
  user-select: none;
}
.opts .swatches input, .opts .sizes input {
  position: absolute; opacity: 0; pointer-events: none;
}
.opts .swatches span, .opts .sizes span {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 56px; padding: 12px 14px;
  border: 1.5px solid rgba(255,255,255,.2); border-radius: 999px;
  font-family: 'Space Grotesk'; font-weight: 700; font-size: 13px;
  letter-spacing: .15em; text-transform: uppercase;
  transition: border-color .2s ease, background .2s ease, color .2s ease;
}
.opts .swatches label:hover span, .opts .sizes label:hover span {
  border-color: #fff;
}
.opts .swatches input:checked + span,
.opts .sizes input:checked + span {
  background: #fff; color: #000; border-color: #fff;
}
.opts .sizes label input:disabled + span,
.opts .sizes label[aria-disabled="true"] span {
  opacity: .25; text-decoration: line-through; cursor: not-allowed;
}

.size-guide {
  display: inline-block; margin-top: 12px;
  font-family: 'Space Grotesk'; font-size: 11px;
  letter-spacing: .2em; text-transform: uppercase;
  opacity: .55;
}
.size-guide:hover { opacity: 1; color: var(--pink); }

.qty-row .qty {
  display: inline-flex; align-items: stretch;
  border: 1.5px solid rgba(255,255,255,.2); border-radius: 999px;
  overflow: hidden;
}
.qty button {
  width: 44px; font-size: 18px; font-weight: 700;
  background: transparent; color: #fff;
  transition: background .2s ease;
}
.qty button:hover { background: rgba(255,255,255,.1); }
.qty input {
  width: 56px; text-align: center;
  background: transparent; color: #fff; border: 0;
  font-family: 'Archivo Black'; font-size: 18px;
  -moz-appearance: textfield;
}
.qty input::-webkit-outer-spin-button,
.qty input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

/* === CTA === */
.add-to-cart {
  margin-top: 6px;
  padding: 18px 28px;
  background: var(--pink); color: #000;
  border-radius: 999px;
  font-family: 'Archivo Black'; font-size: 16px;
  letter-spacing: .02em;
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  transition: transform .2s ease, background .2s ease;
  box-shadow: 0 8px 24px rgba(255,61,150,.25);
}
.add-to-cart:hover:not(:disabled) { background: var(--pink-bright); transform: translateY(-1px); }
.add-to-cart:disabled { background: #2a2a2a; color: #fff; box-shadow: none; cursor: default; }
.add-to-cart .dot { opacity: .6; }
.add-to-cart .total { font-family: 'Archivo Black'; }

.ship-note {
  margin-top: -2px;
  font-family: 'Space Grotesk'; font-size: 11px;
  letter-spacing: .2em; text-transform: uppercase;
  opacity: .5; text-align: center;
}

/* === Accordions (Detalles, Envío, Cuidados) === */
.acc {
  border-top: 1px solid var(--border);
  padding: 18px 0;
}
.acc summary {
  list-style: none; cursor: pointer;
  display: flex; justify-content: space-between; align-items: center;
  font-family: 'Space Grotesk'; font-weight: 700; font-size: 13px;
  letter-spacing: .18em; text-transform: uppercase;
}
.acc summary::-webkit-details-marker { display: none; }
.acc summary::after {
  content: "+"; font-family: 'Archivo Black'; font-size: 22px;
  transition: transform .2s ease; line-height: 1;
}
.acc[open] summary::after { transform: rotate(45deg); }
.acc p, .acc ul {
  margin-top: 14px; font-size: 14px; line-height: 1.55; opacity: .75;
}
.acc ul { padding-left: 18px; }
.acc li { margin-bottom: 4px; }

/* === Related products grid (reuse .grid + .card) === */
.grid.related {
  border-top: 1px solid var(--border);
}

/* === PDP responsive === */
@media (max-width: 900px) {
  .pdp { grid-template-columns: 1fr; }
  .pdp-gallery { border-right: 0; border-bottom: 1px solid var(--border); }
  .pdp-sticky {
    position: static; max-height: none; overflow: visible;
    padding: 32px 20px;
  }
  .pdp-info h1 { font-size: clamp(36px, 11vw, 56px); }
  .pdp-info .price { font-size: 24px; }
  .opts .swatches span, .opts .sizes span { min-width: 48px; padding: 10px 12px; font-size: 12px; }
  .add-to-cart { padding: 16px 22px; font-size: 15px; }
}

/* ============================================================
   CART
   ============================================================ */
.cart { padding: 6vh 6vw 12vh; min-height: 70vh; }

.cart-empty {
  text-align: center; padding: 14vh 6vw;
  display: flex; flex-direction: column; align-items: center; gap: 14px;
}
.cart-empty h1 {
  font-family: 'Archivo Black'; font-size: clamp(48px, 8vw, 96px);
  letter-spacing: -.03em; line-height: .95;
}
.cart-empty p {
  font-family: 'Space Grotesk'; font-size: 12px; letter-spacing: .25em;
  text-transform: uppercase; opacity: .55;
}
.cart-empty .cta {
  display: inline-block; margin-top: 18px;
  padding: 14px 26px; border: 1.5px solid #fff; border-radius: 999px;
  font-family: 'Space Grotesk'; font-size: 13px;
  letter-spacing: .25em; text-transform: uppercase; color: #fff;
}
.cart-empty .cta:hover { background: #fff; color: #000; }

.cart-head { margin-bottom: 36px; }
.cart-head h1 {
  font-family: 'Archivo Black';
  font-size: clamp(48px, 7vw, 96px);
  letter-spacing: -.03em; line-height: .95;
}
.cart-head .meta {
  margin-top: 10px;
  font-family: 'Space Grotesk'; font-size: 12px; letter-spacing: .25em;
  text-transform: uppercase; opacity: .55;
}

.cart-grid {
  display: grid; gap: 60px;
  grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
  align-items: start;
}

.cart-lines { list-style: none; display: flex; flex-direction: column; gap: 0; }
.cart-line {
  display: grid;
  grid-template-columns: 110px 1fr auto;
  gap: 18px; align-items: center;
  padding: 22px 0;
  border-top: 1px solid var(--border);
}
.cart-line:last-child { border-bottom: 1px solid var(--border); }
.cart-line .thumb .tee { aspect-ratio: 1 / 1; width: 110px; }
.cart-line .info { display: flex; flex-direction: column; gap: 8px; }
.cart-line .info .title {
  font-family: 'Archivo Black'; font-size: 18px;
  letter-spacing: -.02em; line-height: 1.05;
}
.cart-line .info .opts {
  font-family: 'Space Grotesk'; font-size: 11px;
  letter-spacing: .15em; text-transform: uppercase;
  opacity: .45;
}
.cart-line .qty-row { display: flex; gap: 14px; align-items: center; margin-top: 4px; }
.cart-line .qty { /* hereda de .qty del PDP */ }
.cart-line .remove {
  font-family: 'Space Grotesk'; font-size: 11px;
  letter-spacing: .2em; text-transform: uppercase;
  color: rgba(255,255,255,.5);
  transition: color .2s ease;
}
.cart-line .remove:hover { color: var(--pink); }
.cart-line .line-total {
  font-family: 'Archivo Black'; font-size: 18px;
  letter-spacing: -.01em; color: var(--pink);
}

.cart-summary { position: relative; }
.summary-sticky {
  position: sticky; top: 80px;
  padding: 26px; border: 1px solid var(--border); border-radius: 6px;
  display: flex; flex-direction: column; gap: 14px;
  background: rgba(255,255,255,.02);
}
.summary-sticky .row {
  display: flex; justify-content: space-between;
  font-family: 'Space Grotesk'; font-size: 14px;
  letter-spacing: .04em;
}
.summary-sticky .row.muted { opacity: .55; font-size: 12px; letter-spacing: .15em; text-transform: uppercase; }
.summary-sticky .row.total {
  padding-top: 14px; border-top: 1px solid var(--border);
  font-family: 'Archivo Black'; font-size: 22px; letter-spacing: -.02em;
}
.summary-sticky .row.total span:last-child { color: var(--pink); }
.summary-sticky .add-to-cart { width: 100%; margin-top: 8px; }
.summary-sticky .ship-note { text-align: center; }
.summary-sticky .back {
  text-align: center; margin-top: 10px;
  font-family: 'Space Grotesk'; font-size: 11px;
  letter-spacing: .25em; text-transform: uppercase;
  opacity: .55;
}
.summary-sticky .back:hover { color: var(--pink); opacity: 1; }

@media (max-width: 900px) {
  .cart { padding: 4vh 5vw 10vh; }
  .cart-grid { grid-template-columns: 1fr; gap: 30px; }
  .cart-line { grid-template-columns: 80px 1fr; }
  .cart-line .line-total { grid-column: 2; justify-self: end; }
  .cart-line .thumb .tee { width: 80px; }
  .summary-sticky { position: static; }
}

/* ============================================================
   CAPSULE LANDING PAGE (/capsula/<slug>)
   ============================================================ */
.capsule-hero {
  padding: 18vh 6vw 12vh;
  text-align: center;
  border-bottom: 1px solid var(--border);
  position: relative;
}
.capsule-hero .back {
  position: absolute; top: 24px; left: 24px;
  font-family: 'Space Grotesk'; font-size: 11px;
  letter-spacing: .3em; text-transform: uppercase;
  opacity: .55;
}
.capsule-hero .back:hover { opacity: 1; color: var(--pink); }
.capsule-eyebrow {
  font-family: 'Space Grotesk'; font-size: 12px;
  letter-spacing: .35em; text-transform: uppercase;
  color: var(--pink); margin-bottom: 24px;
}
.capsule-word {
  font-family: 'Archivo Black';
  color: var(--pink);
  font-size: clamp(120px, 28vw, 380px);
  line-height: .85; letter-spacing: -.05em;
  display: inline-block;
}
.capsule-word .brush {
  display: block;
  width: 60%; height: clamp(10px, 1.4vw, 20px);
  background: #fff;
  margin: 18px auto 0;
  clip-path: polygon(0% 40%, 4% 10%, 12% 35%, 22% 5%, 36% 55%, 50% 15%, 64% 60%, 78% 20%, 90% 50%, 100% 25%, 100% 100%, 0% 100%);
}
.capsule-tagline {
  margin-top: 32px;
  font-family: 'Space Grotesk'; font-size: 14px;
  letter-spacing: .25em; text-transform: uppercase;
  opacity: .7;
}
.capsule-tagline em {
  font-style: normal;
  font-family: 'Archivo Black';
  color: var(--pink);
  letter-spacing: -.02em;
  text-transform: none;
  font-size: 15px;
}

@media (max-width: 900px) {
  .capsule-hero { padding: 12vh 5vw 8vh; }
  .capsule-hero .back { top: 16px; left: 16px; }
  .capsule-word { font-size: clamp(80px, 24vw, 200px); }
}

/* Active state del cart link en el capnav cuando estás en /carrito */
.capnav .cart-link.active { color: #000; background: var(--pink); }
.capnav .cart-link.active:hover { color: #000; }

/* ============================================================
   /sobre · about page
   ============================================================ */
.about-hero {
  padding: 18vh 6vw 14vh;
  text-align: center;
  border-bottom: 1px solid var(--border);
}
.about-hero .eyebrow {
  font-family: 'Space Grotesk'; font-size: 12px;
  letter-spacing: .35em; text-transform: uppercase;
  color: var(--pink); margin-bottom: 28px;
}
.about-hero h1 {
  font-family: 'Archivo Black';
  font-size: clamp(72px, 13vw, 200px);
  line-height: .9; letter-spacing: -.04em;
}
.about-hero h1 em { font-style: normal; color: var(--pink); }
.about-hero .lead {
  margin: 32px auto 0; max-width: 56ch;
  font-family: 'Space Grotesk'; font-size: 16px;
  line-height: 1.55; opacity: .75;
}

.about-section {
  padding: 16vh 6vw;
  border-bottom: 1px solid var(--border);
}
.about-section.split {
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: 8vw;
  align-items: center;
}
.about-section.split.flip .left { order: 2; }
.about-section.split.flip .right { order: 1; }
.about-section h2 {
  font-family: 'Archivo Black';
  font-size: clamp(48px, 7vw, 120px);
  line-height: .9; letter-spacing: -.03em;
  max-width: 14ch;
}
.about-section h2 em { font-style: normal; color: var(--pink); }
.about-section p {
  font-size: 17px; line-height: 1.6;
  opacity: .85; max-width: 54ch;
  margin-bottom: 16px;
}
.about-section p:last-child { margin-bottom: 0; }
.about-section p.muted { opacity: .5; font-style: italic; font-size: 14px; }
.about-section p strong { color: #fff; font-weight: 700; }
.about-section p em {
  font-style: normal; color: var(--pink);
  font-family: 'Archivo Black'; letter-spacing: -.01em;
}
.about-section.center { text-align: center; }
.about-section.center h2 { margin: 0 auto; max-width: none; }
.about-section.center h2.huge { font-size: clamp(64px, 12vw, 200px); }
.about-section.center .lead {
  margin: 28px auto 0; max-width: 56ch;
  font-family: 'Space Grotesk'; font-size: 14px;
  letter-spacing: .15em; text-transform: uppercase;
  opacity: .55;
}

.photo-divider {
  display: block;
  border-bottom: 1px solid var(--border);
}
.photo-divider img {
  width: 100%; height: clamp(380px, 60vh, 720px);
  object-fit: cover; display: block;
}

.about-cta {
  padding: 22vh 6vw;
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 32px;
}
.about-cta h3 {
  font-family: 'Archivo Black';
  font-size: clamp(48px, 8vw, 120px);
  line-height: .9; letter-spacing: -.03em;
  color: var(--pink);
}
.cta-pill {
  display: inline-block;
  padding: 18px 36px;
  background: var(--pink); color: #000;
  border-radius: 999px;
  font-family: 'Archivo Black'; font-size: 16px;
  letter-spacing: .02em;
  box-shadow: 0 12px 40px rgba(255,61,150,.3);
  transition: transform .2s ease, background .2s ease;
}
.cta-pill:hover { background: var(--pink-bright); transform: translateY(-2px); }

@media (max-width: 900px) {
  .about-hero { padding: 12vh 5vw 10vh; }
  .about-hero h1 { font-size: clamp(56px, 18vw, 100px); }
  .about-section { padding: 10vh 5vw; }
  .about-section.split { grid-template-columns: 1fr; gap: 32px; }
  .about-section.split.flip .left { order: 0; }
  .about-section.split.flip .right { order: 0; }
  .about-section h2 { font-size: clamp(40px, 12vw, 72px); max-width: none; }
  .about-section.center h2.huge { font-size: clamp(48px, 18vw, 100px); }
  .about-cta { padding: 14vh 5vw; }
  .photo-divider img { height: 60vh; }
}

/* ============================================================
   /manifiesto · declaration list
   ============================================================ */
.manifesto-page { padding-bottom: 0; }

.man-hero {
  padding: 18vh 6vw 14vh;
  text-align: center;
  border-bottom: 1px solid var(--border);
}
.man-hero .eyebrow {
  font-family: 'Space Grotesk'; font-size: 12px;
  letter-spacing: .35em; text-transform: uppercase;
  color: var(--pink); margin-bottom: 28px;
}
.man-hero h1 {
  font-family: 'Archivo Black';
  font-size: clamp(72px, 14vw, 220px);
  line-height: .9; letter-spacing: -.04em;
}
.man-hero h1 .dot { color: var(--pink); }
.man-hero .lead {
  margin: 28px auto 0; max-width: 40ch;
  font-family: 'Space Grotesk'; font-size: 13px;
  letter-spacing: .25em; text-transform: uppercase;
  opacity: .55;
}

.declaration {
  padding: 22vh 6vw;
  border-bottom: 1px solid var(--border);
  position: relative;
}
.declaration .num {
  position: absolute; top: 24px; left: 24px;
  font-family: 'Space Grotesk'; font-weight: 700; font-size: 11px;
  letter-spacing: .35em; text-transform: uppercase;
  color: var(--pink); opacity: .65;
}
.declaration.right { text-align: right; }
.declaration.right .num { left: auto; right: 24px; }
.declaration h2 {
  font-family: 'Archivo Black';
  font-size: clamp(56px, 11vw, 200px);
  line-height: .85; letter-spacing: -.04em;
  max-width: 22ch;
}
.declaration.right h2 { margin-left: auto; }
.declaration h2 em {
  font-style: normal; color: var(--pink);
}

.man-close {
  padding: 22vh 6vw;
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 32px;
  border-bottom: 1px solid var(--border);
}
.man-close h3 {
  font-family: 'Archivo Black';
  font-size: clamp(48px, 8vw, 120px);
  line-height: .9; letter-spacing: -.03em;
}

@media (max-width: 900px) {
  .man-hero { padding: 12vh 5vw 10vh; }
  .man-hero h1 { font-size: clamp(56px, 20vw, 120px); }
  .declaration { padding: 14vh 5vw; }
  .declaration h2 { font-size: clamp(44px, 14vw, 80px); max-width: none; }
  .declaration .num { font-size: 10px; }
  .man-close { padding: 14vh 5vw; }
}

/* ============================================================
   /legal · aviso legal · privacidad · cookies · términos
   ============================================================ */
.legal-page { padding-bottom: 0; }

.legal-hero {
  padding: 16vh 6vw 10vh;
  text-align: center;
  border-bottom: 1px solid var(--border);
}
.legal-hero .eyebrow {
  font-family: 'Space Grotesk'; font-size: 12px;
  letter-spacing: .35em; text-transform: uppercase;
  color: var(--pink); margin-bottom: 28px;
}
.legal-hero h1 {
  font-family: 'Archivo Black';
  font-size: clamp(72px, 12vw, 200px);
  line-height: .9; letter-spacing: -.04em;
}
.legal-hero h1 .dot { color: var(--pink); }
.legal-hero .lead {
  margin: 28px auto 0; max-width: 56ch;
  font-family: 'Space Grotesk'; font-size: 15px;
  line-height: 1.55; opacity: .75;
}
.legal-toc {
  margin-top: 40px;
  display: flex; justify-content: center; flex-wrap: wrap; gap: 8px 4px;
  font-family: 'Space Grotesk'; font-size: 12px;
  letter-spacing: .25em; text-transform: uppercase;
}
.legal-toc a {
  padding: 10px 18px;
  border: 1px solid var(--border);
  border-radius: 999px;
  transition: border-color .2s ease, color .2s ease, background .2s ease;
}
.legal-toc a:hover { color: #000; background: var(--pink); border-color: var(--pink); }

.legal-section {
  padding: 14vh 6vw;
  border-bottom: 1px solid var(--border);
  scroll-margin-top: 60px; /* offset por la sticky capnav al hacer link interno */
}

.legal-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 2.4fr);
  gap: 8vw;
  align-items: start;
}

.legal-side {
  position: sticky; top: 80px;
  display: flex; flex-direction: column; gap: 16px;
  min-width: 0; /* permite shrink dentro del grid */
}
.legal-side .num {
  font-family: 'Space Grotesk'; font-weight: 700; font-size: 11px;
  letter-spacing: .35em; text-transform: uppercase;
  color: var(--pink);
}
.legal-side h2 {
  font-family: 'Archivo Black';
  font-size: clamp(32px, 3.5vw, 48px);
  line-height: .95; letter-spacing: -.02em;
  overflow-wrap: break-word;
}

.legal-body { max-width: 64ch; }
.legal-body .muted-intro {
  font-family: 'Space Grotesk'; font-size: 13px;
  letter-spacing: .15em; text-transform: uppercase;
  color: var(--pink); opacity: .85;
  margin-bottom: 28px;
}
.legal-body h3 {
  font-family: 'Archivo Black';
  font-size: 18px; letter-spacing: -.01em;
  margin: 32px 0 10px;
}
.legal-body h3:first-of-type { margin-top: 8px; }
.legal-body p {
  font-size: 15px; line-height: 1.65;
  opacity: .8; margin-bottom: 12px;
}
.legal-body p strong { color: #fff; font-weight: 700; }
.legal-body ul, .legal-body ol {
  margin: 12px 0 16px 22px;
  font-size: 15px; line-height: 1.65; opacity: .8;
}
.legal-body li { margin-bottom: 6px; }
.legal-body li strong { color: #fff; font-weight: 700; }
.legal-body a {
  color: var(--pink);
  border-bottom: 1px solid rgba(255, 61, 150, .35);
  transition: border-color .2s ease;
}
.legal-body a:hover { border-color: var(--pink); }
.legal-body code {
  font-family: 'SF Mono', Menlo, Consolas, monospace;
  font-size: 13px;
  background: rgba(255, 255, 255, .08);
  padding: 1px 6px; border-radius: 3px;
}

.legal-data {
  list-style: none !important; margin-left: 0 !important;
  border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
  padding: 14px 0;
}
.legal-data li {
  display: flex; gap: 12px; padding: 6px 0;
  font-size: 14px;
}
.legal-data li strong {
  flex: 0 0 160px;
  font-family: 'Space Grotesk'; font-size: 11px; font-weight: 700;
  letter-spacing: .2em; text-transform: uppercase;
  opacity: .55; color: #fff;
}

.legal-updated {
  padding: 60px 6vw 80px;
  text-align: center;
  font-family: 'Space Grotesk'; font-size: 11px;
  letter-spacing: .3em; text-transform: uppercase;
  opacity: .4;
}

@media (max-width: 900px) {
  .legal-hero { padding: 12vh 5vw 8vh; }
  .legal-hero h1 { font-size: clamp(56px, 18vw, 100px); }
  .legal-section { padding: 10vh 5vw; }
  .legal-grid { grid-template-columns: 1fr; gap: 32px; }
  .legal-side { position: static; }
  .legal-side h2 { font-size: clamp(32px, 9vw, 56px); }
  .legal-body h3 { font-size: 16px; }
  .legal-data li { flex-direction: column; gap: 2px; padding: 8px 0; }
  .legal-data li strong { flex: none; }
}

/* ============================================================
   /<capsule> coming-soon · notify · archive
   ============================================================ */
.capsule-hero.coming-soon .capsule-eyebrow,
.capsule-hero.archive .capsule-eyebrow {
  color: var(--pink);
  opacity: .85;
}
.capsule-hero.coming-soon .capsule-word,
.capsule-hero.archive .capsule-word {
  opacity: .45;
  transition: opacity .4s ease;
}
.capsule-hero.coming-soon:hover .capsule-word,
.capsule-hero.archive:hover .capsule-word { opacity: .65; }
.capsule-hero.archive .capsule-word { color: #fff; }

.notify {
  padding: 18vh 6vw;
  text-align: center;
  border-bottom: 1px solid var(--border);
  display: flex; flex-direction: column; align-items: center; gap: 22px;
}
.notify h2 {
  font-family: 'Archivo Black';
  font-size: clamp(48px, 8vw, 120px);
  line-height: .9; letter-spacing: -.03em;
}
.notify h2 em { font-style: normal; color: var(--pink); }
.notify p {
  font-family: 'Space Grotesk'; font-size: 12px;
  letter-spacing: .25em; text-transform: uppercase;
  opacity: .55; max-width: 50ch;
}

.notify-form {
  display: flex; gap: 8px; flex-wrap: wrap;
  justify-content: center;
  width: 100%; max-width: 520px;
  margin-top: 14px;
}
.notify-form input[type="email"] {
  flex: 1; min-width: 240px;
  padding: 16px 22px;
  background: rgba(255, 255, 255, .04);
  border: 1.5px solid var(--border);
  border-radius: 999px;
  color: #fff; font-family: 'Inter', sans-serif; font-size: 15px;
  outline: none;
  transition: border-color .2s ease, background .2s ease;
}
.notify-form input[type="email"]::placeholder { color: rgba(255, 255, 255, .35); }
.notify-form input[type="email"]:focus {
  border-color: var(--pink);
  background: rgba(255, 255, 255, .06);
}
.notify-form input[type="email"]:disabled { opacity: .5; }

.notify-form button {
  padding: 16px 28px;
  background: var(--pink); color: #000;
  border-radius: 999px;
  font-family: 'Archivo Black'; font-size: 14px;
  letter-spacing: .02em;
  box-shadow: 0 8px 24px rgba(255, 61, 150, .25);
  transition: background .2s ease, transform .2s ease;
}
.notify-form button:hover:not(:disabled) { background: var(--pink-bright); transform: translateY(-1px); }
.notify-form button:disabled { background: #2a2a2a; color: #fff; box-shadow: none; cursor: default; }

.notify .notify-note {
  margin-top: 4px;
  font-size: 12px; letter-spacing: .15em;
  text-transform: uppercase; opacity: .35;
}

/* Archivo vacío */
.archive-empty {
  padding: 22vh 6vw;
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 24px;
  border-bottom: 1px solid var(--border);
}
.archive-empty h2 {
  font-family: 'Archivo Black';
  font-size: clamp(48px, 8vw, 120px);
  line-height: .9; letter-spacing: -.03em;
}
.archive-empty h2 em { font-style: normal; color: var(--pink); }
.archive-empty p {
  font-family: 'Space Grotesk'; font-size: 12px;
  letter-spacing: .25em; text-transform: uppercase;
  opacity: .55; max-width: 50ch;
}

@media (max-width: 900px) {
  .notify { padding: 12vh 5vw; }
  .notify h2 { font-size: clamp(40px, 12vw, 72px); }
  .notify-form { flex-direction: column; max-width: 100%; }
  .notify-form input[type="email"], .notify-form button { width: 100%; }
  .archive-empty { padding: 14vh 5vw; }
  .archive-empty h2 { font-size: clamp(40px, 12vw, 72px); }
}

/* ============================================================
   FOOTER NAV (used in sobre, manifiesto, and progressively elsewhere)
   ============================================================ */
.site-foot .foot-nav {
  margin-top: 30px;
  display: flex; justify-content: center; gap: 28px;
  font-family: 'Space Grotesk'; font-size: 12px;
  letter-spacing: .3em; text-transform: uppercase;
  opacity: .7;
}
.site-foot .foot-nav a {
  transition: color .2s ease, opacity .2s ease;
}
.site-foot .foot-nav a:hover { color: var(--pink); opacity: 1; }

/* ============================================================
   /gracias · order confirmation
   ============================================================ */
.thanks {
  min-height: 70vh;
  padding: 12vh 6vw 14vh;
  display: flex; justify-content: center;
}
.thanks-block {
  max-width: 760px; width: 100%;
  display: flex; flex-direction: column; gap: 24px;
}
.thanks-block .eyebrow {
  font-family: 'Space Grotesk'; font-size: 12px;
  letter-spacing: .35em; text-transform: uppercase;
  color: var(--pink);
}
.thanks-block h1 {
  font-family: 'Archivo Black';
  font-size: clamp(72px, 12vw, 180px);
  letter-spacing: -.04em; line-height: .9;
}
.thanks-block h1 em { font-style: normal; color: var(--pink); }
.thanks-block .lead {
  font-family: 'Space Grotesk'; font-size: 13px;
  letter-spacing: .25em; text-transform: uppercase;
  opacity: .7;
}
.thanks-block .ref {
  margin-top: 6px;
  font-family: 'Space Grotesk'; font-size: 12px;
  letter-spacing: .25em; text-transform: uppercase;
  opacity: .55;
}
.thanks-block .ref strong {
  font-family: 'Archivo Black'; color: var(--pink);
  letter-spacing: .04em;
}

/* Pasos siguientes */
.next-steps {
  margin-top: 18px;
  display: flex; flex-direction: column; gap: 0;
  border-top: 1px solid var(--border);
}
.next-steps .step {
  display: grid; grid-template-columns: 60px 1fr; gap: 18px;
  padding: 22px 0;
  border-bottom: 1px solid var(--border);
  align-items: center;
}
.next-steps .step .n {
  font-family: 'Archivo Black'; color: var(--pink);
  font-size: 22px; letter-spacing: -.02em;
}
.next-steps .step p {
  font-size: 15px; line-height: 1.5; opacity: .85; max-width: 50ch;
}
.next-steps .step p strong { color: #fff; font-weight: 700; }

/* P.D. canalla al final */
.thanks-block .pd {
  margin-top: 4px;
  padding: 18px 22px;
  border-left: 2px solid var(--pink);
  font-size: 14px; line-height: 1.55; opacity: .75; font-style: italic;
  max-width: 56ch;
}
.thanks-block .pd span {
  font-family: 'Archivo Black'; font-style: normal;
  color: var(--pink); margin-right: 8px;
  letter-spacing: .04em;
}

/* Resumen de orden enriquecido (fetched) */
.order-card {
  margin-top: 6px; padding: 22px;
  border: 1px solid var(--border); border-radius: 6px;
  background: rgba(255,255,255,.02);
  display: flex; flex-direction: column; gap: 14px;
}
.order-card .row {
  display: flex; justify-content: space-between;
  font-family: 'Space Grotesk'; font-size: 12px;
  letter-spacing: .2em; text-transform: uppercase;
  opacity: .55;
}
.order-card .row.total {
  padding-top: 14px; border-top: 1px solid var(--border);
  font-family: 'Archivo Black'; font-size: 18px;
  letter-spacing: -.01em; opacity: 1;
}
.order-card .row.total span:last-child { color: var(--pink); }
.order-card ul { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.order-card li {
  display: flex; justify-content: space-between; gap: 18px;
  font-size: 14px;
}
.order-card li .ln em { font-style: normal; opacity: .55; }
.order-card li .amt {
  font-family: 'Archivo Black'; color: var(--pink);
  font-size: 14px;
}
.order-card .ship {
  padding-top: 12px; border-top: 1px solid var(--border);
  font-size: 13px; opacity: .8;
}
.order-card .ship .lbl {
  font-family: 'Space Grotesk'; font-size: 11px;
  letter-spacing: .25em; text-transform: uppercase;
  opacity: .55; margin-bottom: 4px;
}

/* CTAs finales */
.thanks-block .ctas {
  margin-top: 14px;
  display: flex; gap: 14px; flex-wrap: wrap;
}
.thanks-block .ctas .cta {
  padding: 14px 26px; border-radius: 999px;
  font-family: 'Space Grotesk'; font-size: 13px;
  letter-spacing: .25em; text-transform: uppercase;
  transition: background .2s ease, color .2s ease, border-color .2s ease;
}
.thanks-block .ctas .cta.primary {
  background: var(--pink); color: #000; border: 1.5px solid var(--pink);
}
.thanks-block .ctas .cta.primary:hover {
  background: var(--pink-bright); border-color: var(--pink-bright);
}
.thanks-block .ctas .cta.ghost {
  background: transparent; color: #fff; border: 1.5px solid rgba(255,255,255,.3);
}
.thanks-block .ctas .cta.ghost:hover { border-color: #fff; }

@media (max-width: 900px) {
  .thanks { padding: 8vh 5vw 10vh; }
  .next-steps .step { grid-template-columns: 40px 1fr; gap: 12px; padding: 18px 0; }
  .next-steps .step .n { font-size: 18px; }
  .order-card li { flex-direction: column; gap: 4px; }
  .thanks-block .ctas .cta { padding: 12px 22px; font-size: 12px; }
}
