/* ─────────────────────────────────────────────────────────────────────
   NEXTON common — shared primitives loaded on every page (theme.liquid).
   Cross-page-consistent components: header, footer, product card, grids,
   pagination, announcement bar, wishlist button.
   ───────────────────────────────────────────────────────────────────── */

/* ── Announcement bar ─────────────────────────────────────────────── */
.nx-announce {
  background: var(--color-text); color: #fff;
  font-size: var(--text-sm); text-align: center;
  padding: 8px var(--container-px);
  display: flex; align-items: center; justify-content: center; gap: var(--space-3);
}
.nx-announce a { text-decoration: underline; text-underline-offset: 2px; }
.nx-announce__close { margin-left: auto; background: none; border: 0; color: inherit; opacity: .7; }
.nx-announce__close:hover { opacity: 1; }

/* ── Header (Figma 83:489 — single 100px bar, no nav row) ─────────── */
.nx-header { position: sticky; top: 0; z-index: 100; background: var(--color-bg); border-bottom: 1px solid var(--color-border); }
.nx-header__bar {
  min-height: 100px;
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-5);
}
/* Logo — right-aligned wordmark stack (NEXTON / eCommerce) */
.nx-logo { display: inline-flex; flex-direction: column; align-items: flex-end; line-height: 1; color: var(--color-text); }
.nx-logo__name { font-weight: 600; font-size: 34px; line-height: 32px; letter-spacing: -0.03em; text-transform: uppercase; }
.nx-logo__sub { font-weight: 400; font-size: 14px; line-height: 0.8; letter-spacing: -0.06em; color: var(--color-text); }
.nx-logo__img { max-height: 48px; width: auto; }

/* Search — fixed 400px pill, gray fill (#f8f8f8) */
.nx-search { position: relative; flex-shrink: 0; width: 400px; }
.nx-search__input { height: 52px; border-radius: var(--radius-pill); background: var(--color-surface); border: 1px solid transparent; padding-left: 50px; font-size: 14px; }
.nx-search__input:focus { background: var(--color-bg); border-color: var(--color-border); box-shadow: none; }
.nx-search__icon { position: absolute; left: 24px; top: 50%; transform: translateY(-50%); width: 20px; height: 20px; color: var(--color-text-muted); pointer-events: none; }
.nx-search--drawer { display: block; width: 100%; margin-bottom: var(--space-4); }

.nx-header__actions { display: inline-flex; align-items: center; gap: var(--space-3); flex-shrink: 0; }
.nx-iconbtn { position: relative; width: 40px; height: 40px; border-radius: var(--radius-pill); display: inline-flex; align-items: center; justify-content: center; background: transparent; border: 0; color: var(--color-text); }
.nx-iconbtn:hover { background: var(--color-surface); }
.nx-iconbtn .icon { width: 24px; height: 24px; }
.nx-cart-badge {
  position: absolute; top: 2px; right: 0; min-width: 20px; height: 20px; padding: 0 5px;
  border-radius: var(--radius-pill); background: var(--color-accent); color: #fff;
  font-size: 12px; font-weight: 500; display: inline-flex; align-items: center; justify-content: center;
}
.nx-burger { display: none; }

/* Primary nav row (under the bar) */
.nx-nav { border-top: 1px solid var(--color-border); }
.nx-nav__list { display: flex; gap: var(--space-6); align-items: center; height: 52px; }
.nx-nav__item { position: relative; height: 100%; display: flex; align-items: center; }
.nx-nav__link { display: inline-flex; align-items: center; gap: 4px; font-size: 14px; font-weight: 500; color: var(--color-text); height: 100%; }
.nx-nav__link svg { width: 14px; height: 14px; }
.nx-nav__link:hover { color: var(--color-accent); }
.nx-nav__dropdown { position: absolute; top: 100%; left: 0; min-width: 200px; background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-md); box-shadow: var(--shadow-md); padding: var(--space-2); display: none; z-index: 50; }
.nx-nav__item:hover .nx-nav__dropdown { display: block; }
.nx-nav__dropdown a { display: block; padding: 8px 12px; border-radius: var(--radius-sm); font-size: 14px; color: var(--color-text); }
.nx-nav__dropdown a:hover { background: var(--color-surface); color: var(--color-accent); }

@media (max-width: 820px) {
  .nx-header__bar { min-height: 68px; }
  .nx-search { display: none; }
  .nx-burger { display: inline-flex; }
  .nx-logo { align-items: flex-start; }
  .nx-logo__name { font-size: 24px; line-height: 24px; }
  .nx-nav { display: none; }
}

/* ─────────────────────────────────────────────────────────────────────
   AMBER — bold fashion display heading treatment (shared across inner
   pages). Poppins Black, uppercase, with a skewed gold-yellow swoosh
   underneath. Mirrors the homepage .na__title signature so inner-page
   H1/H2 feel part of the same brand. Wrap the text node in a span so the
   swoosh hugs the glyphs, not the full-width block.
   ───────────────────────────────────────────────────────────────────── */
.amber-shout {
  font-family: var(--font-heading);
  font-weight: 900;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  line-height: 1.05;
  color: var(--color-text);
}
.amber-shout__accent {
  position: relative;
  display: inline-block;
  z-index: 0;
}
.amber-shout__accent::after {
  content: "";
  position: absolute;
  left: -2%;
  right: -4%;
  bottom: 0.04em;
  height: 0.30em;
  border-radius: 999px;
  background: var(--color-accent);
  transform: skewX(-12deg);
  z-index: -1;
}

/* ── Product card ─────────────────────────────────────────────────── */
.nx-card { position: relative; display: flex; flex-direction: column; gap: 10px; }
.nx-card__media {
  position: relative; display: block; aspect-ratio: 1 / 1;
  background: var(--color-surface); border-radius: var(--radius-card); overflow: hidden;
  transition: box-shadow var(--transition);
}
.nx-card:hover .nx-card__media { box-shadow: 0 14px 30px -12px rgba(0,0,0,0.22); }
.nx-card__img { width: 100%; height: 100%; object-fit: cover; transition: transform 500ms var(--ease-out); }
.nx-card:hover .nx-card__img { transform: scale(1.04); }
.nx-card__ph { position: absolute; inset: 0; display: grid; place-items: center; font-size: 3rem; font-weight: 600; color: var(--color-text-soft); }
.nx-card__badge { position: absolute; top: 12px; left: 12px; }
.nx-card__badge--soldout { background: var(--color-surface); color: var(--color-text-muted); border: 1px solid var(--color-border); }
.nx-card__add {
  position: absolute; top: 12px; right: 12px; width: 40px; height: 40px; border-radius: 12px;
  background: var(--color-bg); border: 0; color: var(--color-text);
  display: inline-flex; align-items: center; justify-content: center; box-shadow: var(--shadow-sm);
  opacity: 0; transform: translateY(-4px); transition: opacity var(--transition), transform var(--transition), background var(--transition), color var(--transition);
}
.nx-card:hover .nx-card__add { opacity: 1; transform: none; }
.nx-card__add:hover { background: var(--color-text); color: #fff; }
.nx-card__add .icon { width: 18px; height: 18px; }
.nx-card__row { display: flex; align-items: baseline; justify-content: space-between; gap: var(--space-3); }
.nx-card__row--sub { margin-top: -4px; }
.nx-card__name { font-weight: 700; font-size: var(--text-base); color: var(--color-text); line-height: 1.3; letter-spacing: -0.01em; }
.nx-card__name:hover { color: var(--color-accent); }
.nx-card__cat { font-size: var(--text-sm); color: var(--color-text-muted); }
.nx-card__rating { margin-top: 2px; }
@media (max-width: 520px) { .nx-card__add { opacity: 1; transform: none; } }

/* ── Product grid + rail ──────────────────────────────────────────── */
.nx-grid { display: grid; gap: var(--space-5) var(--space-5); grid-template-columns: repeat(4, 1fr); }
.nx-grid--4 { grid-template-columns: repeat(4, 1fr); }
.nx-grid--3 { grid-template-columns: repeat(3, 1fr); }
.nx-grid--2 { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 900px) { .nx-grid, .nx-grid--4, .nx-grid--3 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .nx-grid, .nx-grid--4, .nx-grid--3, .nx-grid--2 { grid-template-columns: repeat(2, 1fr); gap: var(--space-4) var(--space-3); } }

/* Related / "Recommended products" section heading (PDP) */
.nx-related { padding-block: clamp(40px, 6vw, 72px); }
.nx-related__title {
  font-family: var(--font-heading);
  font-size: var(--text-2xl); font-weight: 900;
  letter-spacing: -0.01em;
  margin-bottom: var(--space-6);
}
@media (max-width: 520px) { .nx-related__title { font-size: var(--text-xl); } }

.nx-rail-wrap { position: relative; }
.nx-rail { display: grid; grid-auto-flow: column; grid-auto-columns: calc((100% - 3 * var(--space-5)) / 4); gap: var(--space-5); overflow-x: auto; scroll-snap-type: x mandatory; -ms-overflow-style: none; scrollbar-width: none; padding-bottom: 4px; }
.nx-rail::-webkit-scrollbar { display: none; }
.nx-rail > * { scroll-snap-align: start; }
.nx-rail-nav { display: inline-flex; gap: var(--space-2); }
.nx-rail-btn { width: 40px; height: 40px; border-radius: var(--radius-pill); border: 1px solid var(--color-border); background: var(--color-bg); display: inline-flex; align-items: center; justify-content: center; }
.nx-rail-btn:hover { background: var(--color-surface); border-color: var(--color-text); }
.nx-rail-btn:disabled { opacity: .35; cursor: default; }
.nx-rail-btn .icon { width: 18px; height: 18px; }
@media (max-width: 900px) { .nx-rail { grid-auto-columns: calc((100% - var(--space-5)) / 2); } }
@media (max-width: 520px) { .nx-rail { grid-auto-columns: 70%; } }

/* ── Pagination ───────────────────────────────────────────────────── */
.nx-pagination { display: flex; align-items: center; justify-content: center; gap: var(--space-2); margin-top: var(--space-7); }
.nx-pagination a, .nx-pagination span { min-width: 40px; height: 40px; padding: 0 8px; border-radius: var(--radius-pill); display: inline-flex; align-items: center; justify-content: center; font-size: var(--text-base); border: 1px solid transparent; }
.nx-pagination a:hover { background: var(--color-surface); }
.nx-pagination .is-active { background: var(--color-text); color: #fff; }

/* ── Wishlist button (snippet) ────────────────────────────────────── */
.wishlist-btn, [data-add-to-wishlist] {
  position: absolute; bottom: 12px; right: 12px; z-index: 2; width: 40px; height: 40px; border-radius: 12px;
  background: var(--color-bg); border: 0; color: var(--color-text); box-shadow: var(--shadow-sm);
  display: inline-flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity var(--transition), color var(--transition);
}
.nx-card:hover .wishlist-btn, .nx-card:hover [data-add-to-wishlist] { opacity: 1; }
.wishlist-btn svg, [data-add-to-wishlist] svg { width: 18px; height: 18px; }
/* JS sets data-in-wishlist (value "1") on toggle — match presence, fill the heart. */
.wishlist-btn[data-in-wishlist], [data-in-wishlist] { color: var(--color-accent); }
.wishlist-btn[data-in-wishlist] svg, [data-in-wishlist] svg { fill: currentColor; }
@media (max-width: 520px) { .wishlist-btn, [data-add-to-wishlist] { opacity: 1; } }

/* ── Footer ───────────────────────────────────────────────────────── */
.nx-footer { border-top: 1px solid var(--color-border); margin-top: var(--space-8); }
.nx-footer__top { max-width: var(--container-max); margin: 0 auto; padding: var(--space-8) var(--container-px) var(--space-7); display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: var(--space-6); }
.nx-footer__brand-name { font-weight: 600; font-size: 1.25rem; }
.nx-footer__brand-sub { font-size: 11px; color: var(--color-text-muted); margin-bottom: var(--space-4); }
.nx-footer__social { display: grid; gap: var(--space-3); margin-top: var(--space-4); }
.nx-footer__social a { display: inline-flex; align-items: center; gap: 10px; font-size: var(--text-base); color: var(--color-text-muted); }
.nx-footer__social a:hover { color: var(--color-text); }
.nx-footer__social .icon { width: 20px; height: 20px; }
.nx-footer__col-title { font-size: var(--text-sm); font-weight: 600; margin-bottom: var(--space-4); }
.nx-footer__links { display: grid; gap: var(--space-3); }
.nx-footer__links a { font-size: var(--text-base); color: var(--color-text-muted); }
.nx-footer__links a:hover { color: var(--color-text); }
.nx-footer__bottom { border-top: 1px solid var(--color-border); }
.nx-footer__bottom-inner { max-width: var(--container-max); margin: 0 auto; padding: var(--space-4) var(--container-px); display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); flex-wrap: wrap; }
.nx-footer__copy { font-size: var(--text-sm); color: var(--color-text-muted); }
.nx-footer__pay { display: inline-flex; align-items: center; gap: 10px; }
.nx-footer__pay img, .nx-footer__pay svg { height: 24px; width: auto; }
@media (max-width: 900px) { .nx-footer__top { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .nx-footer__top { grid-template-columns: 1fr 1fr; gap: var(--space-5); } .nx-footer__bottom-inner { flex-direction: column; align-items: flex-start; } }

/* ── AMBER header (bold fashion bar) ──────────────────────────────── */
.am-header { position: sticky; top: 0; z-index: 100; background: #fff; border-bottom: 1px solid var(--color-border); }
.am-header__bar { display: flex; align-items: center; gap: var(--space-5); min-height: 80px; }
.am-logo { display: inline-flex; align-items: center; gap: 8px; color: #000; flex-shrink: 0; }
.am-logo__mark { width: 18px; height: 18px; color: #000; }
.am-logo__name { font-weight: 900; font-size: 20px; letter-spacing: -0.01em; text-transform: uppercase; }
.am-logo__img { max-height: 40px; width: auto; }
.am-nav { margin: 0 auto; }
.am-nav__list { display: flex; gap: var(--space-6); align-items: center; }
.am-nav__link { font-size: 14px; font-weight: 500; color: #000; padding: 4px 0; border-bottom: 2px solid transparent; transition: border-color var(--transition); }
.am-nav__link:hover { border-bottom-color: var(--color-accent); }
.am-header__actions { display: inline-flex; align-items: center; gap: var(--space-3); flex-shrink: 0; }
.am-signup { white-space: nowrap; }
.am-header .nx-burger { display: none; }
@media (max-width: 900px) {
  .am-header__bar { min-height: 64px; gap: var(--space-3); }
  .am-nav { display: none; }
  .am-header .nx-burger { display: inline-flex; }
  /* Logo must yield space to the burger + actions so the bar never overflows. */
  .am-logo { flex: 1 1 auto; min-width: 0; }
  .am-logo__name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; min-width: 0; }
}
@media (max-width: 480px) {
  .am-logo__name { font-size: 17px; letter-spacing: 0; }
  .am-header__actions { gap: var(--space-2); }
  .am-signup { padding-left: 12px; padding-right: 12px; }
}
