/* =====================================================================
   ELENEX — DESIGN-SYSTEM COMPONENTS (global)
   Token-driven, namespaced .el-*. Loaded on every page via layout.
   Covers: primitives, button, ticker, hero, product card/grid, editorial,
   categories, listing+filters, prose, forms. (Page-specific bits stay in
   their own stylesheets.)
   ===================================================================== */

/* clears the fixed header + promo strip so content starts below it */
.el-headroom { height: var(--chrome-h); }

/* ---- shared primitives ---- */
.el-container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter); }
.el-container--wide { max-width: var(--container-wide); }
.el-container--narrow { max-width: 56rem; }

.el-section { padding-block: var(--space-xl); }

.el-section__head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: var(--space-s); margin-bottom: var(--space-l);
  border-bottom: var(--border-strong); padding-bottom: var(--space-xs);
}
.el-section__eyebrow {
  display: block; font-family: var(--font-body); font-size: var(--step--1);
  letter-spacing: var(--tracking-label); text-transform: uppercase;
  color: var(--smoke); margin-bottom: var(--space-3xs);
}
.el-section__title {
  font-family: var(--font-display); font-size: var(--step-3);
  line-height: var(--leading-tight); letter-spacing: var(--tracking-display);
  text-transform: uppercase; color: var(--ink); margin: 0;
}
.el-section__link {
  flex: none; font-family: var(--font-body); font-size: var(--step--1);
  letter-spacing: var(--tracking-label); text-transform: uppercase;
  color: var(--ink); text-decoration: none;
  border-bottom: 2px solid transparent; transition: border-color var(--dur-1) var(--ease-out);
  white-space: nowrap;
}
.el-section__link:hover { border-color: var(--ink); }

/* ---- button ---- */
.el-btn {
  --btn-bg: var(--ink); --btn-fg: var(--paper); --btn-bd: var(--ink);
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2xs);
  font-family: var(--font-body); font-weight: 700; font-size: var(--step--1);
  letter-spacing: var(--tracking-label); text-transform: uppercase; text-decoration: none;
  padding: 0.9em 1.8em; border: 2px solid var(--btn-bd);
  background: var(--btn-bg); color: var(--btn-fg); cursor: pointer; border-radius: var(--radius-0);
  transition: background var(--dur-2) var(--ease-out), color var(--dur-2) var(--ease-out);
}
.el-btn--lg { padding: 1.1em 2.4em; font-size: var(--step-0); }
.el-btn--block { display: flex; width: 100%; }
.el-btn--outline { --btn-bg: transparent; --btn-fg: var(--ink); --btn-bd: var(--ink); }
.el-btn--invert  { --btn-bg: var(--paper); --btn-fg: var(--ink); --btn-bd: var(--paper); }
.el-btn:hover    { background: transparent; color: var(--ink); }
.el-btn--invert:hover { background: transparent; color: var(--paper); border-color: var(--paper); }
.el-btn--solid:hover  { background: transparent; color: var(--ink); }

/* ---- ticker / marquee ---- */
.el-ticker { overflow: hidden; background: var(--ink); color: var(--paper); border-block: 1px solid var(--ink); padding-block: 0.6em; }
.el-ticker__track { display: flex; width: max-content; animation: el-marquee var(--ticker-speed, 30s) linear infinite; }
.el-ticker__group { display: flex; flex: none; gap: var(--space-l); padding-inline: var(--space-l); }
.el-ticker__group > * { font-family: var(--font-display); font-size: var(--step-1); letter-spacing: var(--tracking-display); text-transform: uppercase; white-space: nowrap; }
.el-ticker:hover .el-ticker__track { animation-play-state: paused; }

/* ---- HERO ---- */
.el-hero { position: relative; min-height: clamp(30rem, 78vh, 52rem); display: flex; align-items: flex-end; overflow: hidden; color: var(--paper); }
.el-hero--compact { min-height: clamp(18rem, 42vh, 28rem); }
.el-hero__media { position: absolute; inset: 0; z-index: 0; }
.el-hero__img { width: 100%; height: 100%; object-fit: cover; object-position: center 30%; }
/* on mobile, crop toward the right edge of the cover image */
@media (max-width: 768px) { .el-hero__img { object-position: right center; } }
.el-hero__scrim {
  position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(10,10,10,.7) 0%, rgba(10,10,10,.25) 45%, transparent 75%),
              linear-gradient(0deg, rgba(10,10,10,.55) 0%, transparent 40%);
}
.el-hero__content { position: relative; z-index: 1; width: 100%; max-width: var(--container); margin-inline: auto; padding: var(--space-xl) var(--gutter) var(--space-l); }
.el-hero__kicker { display: inline-block; font-family: var(--font-body); font-size: var(--step--1); letter-spacing: var(--tracking-label); text-transform: uppercase; margin-bottom: var(--space-xs); padding-bottom: var(--space-3xs); border-bottom: 2px solid var(--paper); }
.el-hero__title { font-family: var(--font-display); font-weight: 400; font-size: var(--display-2); line-height: var(--leading-tight); letter-spacing: var(--tracking-display); text-transform: uppercase; margin: 0 0 0 -0.04em; }
.el-hero__sub { font-family: var(--font-body); font-size: var(--step-1); line-height: var(--leading-snug); max-width: 32ch; margin: var(--space-s) 0 var(--space-m); color: rgba(255,255,255,.85); }
.el-hero__cta { margin-top: var(--space-s); }

/* ---- PRODUCT GRID + CARD ---- */
.el-grid { display: grid; grid-template-columns: repeat(2, 1fr); grid-auto-rows: 1fr; gap: clamp(0.5rem, 1.5vw, 1.25rem); }
@media (min-width: 768px)  { .el-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1100px) { .el-grid { grid-template-columns: repeat(4, 1fr); } }

.el-card { position: relative; display: flex; flex-direction: column; text-decoration: none; color: var(--ink); background: var(--paper-2); }
.el-card__media { position: relative; aspect-ratio: 3 / 4; overflow: hidden; background: var(--paper-2); }
.el-card__media-link { position: absolute; inset: 0; display: block; z-index: 1; }

/* wishlist heart (localStorage — wishlist.js) */
.el-wish { position: absolute; top: var(--space-2xs); right: var(--space-2xs); z-index: 3; width: 34px; height: 34px; display: flex; align-items: center; justify-content: center; background: var(--paper); color: var(--ink); border: none; cursor: pointer; transition: transform var(--dur-1) var(--ease-out); }
.el-wish svg { width: 18px; height: 18px; }
.el-wish:hover { transform: scale(1.12); }
.el-wish.is-active svg { fill: var(--ink); }

.el-card__sizes { font-family: var(--font-body); font-size: var(--step--1); letter-spacing: 0.04em; color: var(--smoke); margin: 2px 0 0; }
.el-card__meta-main { min-width: 0; }
.el-card__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: opacity var(--dur-2) var(--ease-out), transform var(--dur-3) var(--ease-out); }
.el-card__img--hover { opacity: 0; }
.el-card:hover .el-card__img--main  { opacity: 0; transform: scale(1.06); }
.el-card:hover .el-card__img--hover { opacity: 1; transform: scale(1.06); }
.el-card:hover .el-card__img--main:only-of-type { opacity: 1; }
.el-card__tag { position: absolute; top: var(--space-2xs); left: var(--space-2xs); z-index: 2; font-family: var(--font-body); font-size: var(--step--1); font-weight: 700; letter-spacing: var(--tracking-label); text-transform: uppercase; background: var(--ink); color: var(--paper); padding: 0.3em 0.7em; }
.el-card__meta { display: flex; align-items: baseline; justify-content: space-between; gap: var(--space-2xs); padding: var(--space-xs) var(--space-2xs) var(--space-2xs); }
.el-card__name { font-family: var(--font-display); font-size: var(--step-1); line-height: var(--leading-snug); letter-spacing: var(--tracking-display); margin: 0; }
.el-card__price { flex: none; font-family: var(--font-body); font-weight: 700; font-size: var(--step-0); margin: 0; }

/* quick-add (listing pages) */
.el-card__add {
  margin: 0 var(--space-2xs) var(--space-2xs);
  font-family: var(--font-body); font-weight: 700; font-size: var(--step--1);
  letter-spacing: var(--tracking-label); text-transform: uppercase;
  padding: 0.7em 1em; border: 2px solid var(--ink); background: transparent; color: var(--ink);
  cursor: pointer; display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2xs);
  transition: background var(--dur-1) var(--ease-out), color var(--dur-1) var(--ease-out);
}
.el-card__add:hover { background: var(--ink); color: var(--paper); }

/* featured cell — spans 2x2 on tablet+ */
@media (min-width: 768px) {
  .el-card--featured { grid-column: span 2; grid-row: span 2; }
  .el-card--featured .el-card__media { aspect-ratio: auto; height: 100%; }
  .el-card--featured .el-card__name { font-size: var(--step-2); }
}

/* trailing CTA tile */
.el-grid__cta { display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-end; gap: var(--space-xs); padding: var(--space-m); background: var(--ink); color: var(--paper); text-decoration: none; min-height: 12rem; transition: background var(--dur-2) var(--ease-out); }
.el-grid__cta-label { font-family: var(--font-display); font-size: var(--step-2); letter-spacing: var(--tracking-display); text-transform: uppercase; }
.el-grid__cta-arrow { font-size: var(--step-2); transition: transform var(--dur-2) var(--ease-out); }
.el-grid__cta:hover .el-grid__cta-arrow { transform: translateX(0.4em); }

/* ---- EDITORIAL SPLIT ---- */
.el-editorial { display: grid; grid-template-columns: 1fr; gap: var(--space-m); align-items: center; }
@media (min-width: 900px) { .el-editorial { grid-template-columns: 1.1fr 0.9fr; gap: var(--space-xl); } .el-editorial--reverse > .el-editorial__media { order: 2; } }
.el-editorial__media { overflow: hidden; }
.el-editorial__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.el-editorial__body { padding-block: var(--space-s); }
.el-editorial__title { font-family: var(--font-display); font-size: var(--step-3); line-height: var(--leading-tight); letter-spacing: var(--tracking-display); text-transform: uppercase; margin: 0 0 var(--space-s); }
.el-editorial__text { font-family: var(--font-body); font-size: var(--step-0); line-height: var(--leading-body); color: var(--smoke); max-width: 46ch; margin: 0 0 var(--space-m); }

/* ---- banner ---- */
.el-banner { display: block; width: 100%; }
.el-banner img { width: 100%; height: auto; display: block; }

/* ---- categories grid ---- */
.el-cats { display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(0.5rem, 1.5vw, 1.25rem); }
@media (min-width: 768px)  { .el-cats { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1100px) { .el-cats { grid-template-columns: repeat(6, 1fr); } }
.el-cat { text-decoration: none; color: var(--ink); }
.el-cat__media { position: relative; aspect-ratio: 3 / 4; overflow: hidden; background: var(--paper-2); }
.el-cat__media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform var(--dur-3) var(--ease-out); }
.el-cat:hover .el-cat__media img { transform: scale(1.07); }
.el-cat__media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(0deg, var(--overlay) 0%, transparent 55%); }
.el-cat__name { position: absolute; left: var(--space-2xs); bottom: var(--space-2xs); z-index: 1; font-family: var(--font-display); font-size: var(--step-1); letter-spacing: var(--tracking-display); color: var(--paper); }

/* =====================================================================
   LISTING (catalogo / woman / kids / afterwave / new-arrivals)
   ===================================================================== */
.el-listing { padding-top: var(--space-l); padding-bottom: var(--space-2xl); }
.el-listing__head { display: flex; flex-direction: column; gap: var(--space-3xs); margin-bottom: var(--space-m); }
.el-listing__title { font-family: var(--font-display); font-size: var(--display-1); line-height: var(--leading-tight); letter-spacing: var(--tracking-display); text-transform: uppercase; margin: 0; }
.el-listing__count { font-family: var(--font-body); font-size: var(--step--1); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--smoke); }

/* filter pills — horizontal, scroll-snap on mobile */
.el-filters {
  display: flex; gap: var(--space-2xs); flex-wrap: wrap;
  margin-bottom: var(--space-l); padding-bottom: var(--space-s);
  border-bottom: var(--border-strong);
}
@media (max-width: 640px) {
  .el-filters { flex-wrap: nowrap; overflow-x: auto; scrollbar-width: none; scroll-snap-type: x mandatory; }
  .el-filters::-webkit-scrollbar { display: none; }
  .el-filter { scroll-snap-align: start; }
}
.el-filter {
  flex: none; font-family: var(--font-body); font-weight: 700; font-size: var(--step--1);
  letter-spacing: var(--tracking-label); text-transform: uppercase; text-decoration: none;
  padding: 0.55em 1.1em; border: 2px solid var(--ink); color: var(--ink); background: transparent;
  white-space: nowrap; transition: background var(--dur-1) var(--ease-out), color var(--dur-1) var(--ease-out);
}
.el-filter:hover { background: var(--paper-2); }
.el-filter.is-active { background: var(--ink); color: var(--paper); }

.el-empty { text-align: center; padding: var(--space-2xl) 0; color: var(--smoke); font-family: var(--font-body); }

/* =====================================================================
   PROSE (legal / faq / static text)
   ===================================================================== */
.el-prose { max-width: 70ch; font-family: var(--font-body); font-size: var(--step-0); line-height: var(--leading-body); color: var(--ink-soft); }
.el-prose h1, .el-prose h2 { font-family: var(--font-display); letter-spacing: var(--tracking-display); text-transform: uppercase; color: var(--ink); line-height: var(--leading-tight); margin: var(--space-l) 0 var(--space-s); }
.el-prose h1 { font-size: var(--step-3); }
.el-prose h2 { font-size: var(--step-2); }
.el-prose h3 { font-family: var(--font-body); font-weight: 700; font-size: var(--step-1); margin: var(--space-m) 0 var(--space-2xs); }
.el-prose p, .el-prose li { margin: 0 0 var(--space-s); }
.el-prose ul, .el-prose ol { padding-left: 1.4em; margin-bottom: var(--space-s); }
.el-prose a { color: var(--ink); text-decoration: underline; text-underline-offset: 3px; }

/* =====================================================================
   FORMS (auth / account / checkout / reclamaciones)
   ===================================================================== */
.el-form { display: flex; flex-direction: column; gap: var(--space-s); }
.el-field { display: flex; flex-direction: column; gap: var(--space-3xs); }
.el-label { font-family: var(--font-body); font-weight: 700; font-size: var(--step--1); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--ink); }
.el-input, .el-select, .el-textarea {
  width: 100%; font-family: var(--font-body); font-size: var(--step-0); color: var(--ink);
  padding: 0.8em 0.9em; border: 2px solid var(--line); background: var(--paper); border-radius: var(--radius-0);
  transition: border-color var(--dur-1) var(--ease-out);
}
.el-input:focus, .el-select:focus, .el-textarea:focus { outline: none; border-color: var(--ink); }
.el-textarea { resize: vertical; min-height: 7rem; }
.el-field__error { font-size: var(--step--1); color: #b00020; }
.el-form__note { font-family: var(--font-body); font-size: var(--step--1); color: var(--smoke); }
.el-form__note a { color: var(--ink); }

/* card-like surface for account/auth/checkout blocks */
.el-panel { background: var(--paper); border: var(--border-hair); padding: var(--space-l); }
.el-panel--ink { background: var(--ink); color: var(--paper); }

/* page intro heading (account, static pages) */
.el-page-head { padding: var(--space-l) 0 var(--space-m); border-bottom: var(--border-strong); margin-bottom: var(--space-l); }
.el-page-head__eyebrow { font-family: var(--font-body); font-size: var(--step--1); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--smoke); }
.el-page-head__title { font-family: var(--font-display); font-size: var(--display-1); line-height: var(--leading-tight); letter-spacing: var(--tracking-display); text-transform: uppercase; margin: var(--space-3xs) 0 0; }
.el-page-head--row { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--space-s); flex-wrap: wrap; }

/* alerts / inline messages */
.el-alert { padding: var(--space-xs) var(--space-s); border: 2px solid var(--ink); font-family: var(--font-body); font-size: var(--step--1); margin-bottom: var(--space-s); }
.el-alert--error { border-color: #b00020; color: #b00020; }
.el-alert ul { margin: 0; padding-left: 1.2em; }

/* auth (login / register) */
.el-auth { max-width: 34rem; margin-inline: auto; }
.el-auth__head { text-align: center; margin-bottom: var(--space-l); }
.el-auth__title { font-family: var(--font-display); font-size: var(--display-1); line-height: var(--leading-tight); letter-spacing: var(--tracking-display); text-transform: uppercase; margin: 0; }
.el-auth__sub { font-family: var(--font-body); font-size: var(--step--1); color: var(--smoke); margin: var(--space-2xs) 0 0; }
.el-auth__sub a { color: var(--ink); font-weight: 700; }
.el-check { display: flex; align-items: center; gap: var(--space-2xs); font-family: var(--font-body); font-size: var(--step--1); }
.el-check input { width: 16px; height: 16px; accent-color: var(--ink); }

/* status badges (monochrome: solid = closed/positive, outline = in-progress, muted = pending/cancelled) */
.el-badge { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-body); font-weight: 700; font-size: var(--step--1); letter-spacing: var(--tracking-label); text-transform: uppercase; padding: 0.35em 0.8em; border: 2px solid var(--ink); white-space: nowrap; }
.el-badge--solid { background: var(--ink); color: var(--paper); }
.el-badge--outline { background: transparent; color: var(--ink); }
.el-badge--muted { border-color: var(--ash); color: var(--smoke); }

/* order list / detail */
.el-order { display: flex; justify-content: space-between; gap: var(--space-s); flex-wrap: wrap; align-items: flex-start; padding: var(--space-m); border: var(--border-hair); transition: border-color var(--dur-1) var(--ease-out); }
.el-order:hover { border-color: var(--ink); }
.el-order__eyebrow { font-family: var(--font-body); font-size: var(--step--1); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--smoke); }
.el-order__code { font-family: var(--font-display); font-size: var(--step-2); letter-spacing: 0.08em; margin: 2px 0; }
.el-order__meta { font-family: var(--font-body); font-size: var(--step--1); color: var(--smoke); }
.el-order__side { display: flex; flex-direction: column; align-items: flex-end; gap: var(--space-2xs); }
.el-order__total { font-family: var(--font-display); font-size: var(--step-2); }
.el-orders { display: flex; flex-direction: column; gap: var(--space-s); }
.el-row { display: flex; justify-content: space-between; gap: var(--space-s); font-family: var(--font-body); font-size: var(--step--1); color: var(--smoke); padding: var(--space-3xs) 0; }
.el-row--total { font-family: var(--font-display); font-size: var(--step-2); letter-spacing: var(--tracking-display); color: var(--ink); border-top: var(--border-strong); margin-top: var(--space-2xs); padding-top: var(--space-2xs); }

/* FAQ accordion */
.el-faq { border-top: var(--border-hair); }
.el-faq__item { border-bottom: var(--border-hair); }
.el-faq__q { width: 100%; text-align: left; background: none; border: none; cursor: pointer; padding: var(--space-s) 0; display: flex; justify-content: space-between; align-items: center; gap: var(--space-s); font-family: var(--font-display); font-size: var(--step-1); letter-spacing: 0.03em; text-transform: uppercase; color: var(--ink); }
.el-faq__q::after { content: "+"; font-family: var(--font-body); font-size: var(--step-2); line-height: 1; }
.el-faq__item.active .el-faq__q::after { content: "\2013"; }
.el-faq__a { max-height: 0; overflow: hidden; transition: max-height var(--dur-2) var(--ease-out); font-family: var(--font-body); font-size: var(--step-0); line-height: var(--leading-body); color: var(--smoke); }
.el-faq__item.active .el-faq__a { max-height: 40rem; padding-bottom: var(--space-s); }
.el-faq__a ul { padding-left: 1.3em; margin-top: var(--space-2xs); }

/* footer admin entry (discreet) */
.footer-bottom .el-admin-link { opacity: 0.5; transition: opacity var(--dur-1) var(--ease-out); }
.footer-bottom .el-admin-link:hover { opacity: 1; }

/* ---- breadcrumbs ---- */
.el-breadcrumb { display: flex; align-items: center; flex-wrap: wrap; gap: var(--space-3xs) var(--space-2xs); margin-bottom: var(--space-m); font-family: var(--font-body); font-size: var(--step--1); letter-spacing: var(--tracking-label); text-transform: uppercase; }
.el-breadcrumb__item { color: var(--smoke); text-decoration: none; transition: color var(--dur-1) var(--ease-out); }
a.el-breadcrumb__item:hover { color: var(--ink); }
.el-breadcrumb__item--current { color: var(--ink); font-weight: 700; }
.el-breadcrumb__sep { color: var(--ash); }

/* ---- WhatsApp floating button ---- */
.el-wa {
  position: fixed; right: clamp(0.9rem, 2.5vw, 1.6rem); bottom: clamp(0.9rem, 2.5vw, 1.6rem);
  z-index: calc(var(--z-overlay) - 10);
  width: 56px; height: 56px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: var(--ink); color: var(--paper); text-decoration: none;
  box-shadow: 0 8px 24px rgba(10,10,10,0.28);
  animation: el-wa-in 0.5s var(--ease-out) 0.6s both;
  transition: transform var(--dur-2) var(--ease-out), box-shadow var(--dur-2) var(--ease-out);
}
.el-wa:hover { transform: scale(1.08); box-shadow: 0 12px 30px rgba(10,10,10,0.36); }
.el-wa svg { width: 28px; height: 28px; }
@media (max-width: 600px) { .el-wa { width: 50px; height: 50px; } .el-wa svg { width: 25px; height: 25px; } }
@keyframes el-wa-in { from { opacity: 0; transform: scale(0.4) translateY(20px); } to { opacity: 1; transform: scale(1) translateY(0); } }
@media (prefers-reduced-motion: reduce) { .el-wa { animation: none; } }
