/* ============================================================
   THE RETRO KIT — Phase 3 Section 1
   Header, drawers, footer, sticky bar, design tokens
   ============================================================ */

/* RESET & BASE */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  font-family: 'Manrope', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: 14px; line-height: 1.5; color: #0e0e10; background: #fff;
  -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;
  min-height: 100vh; display: flex; flex-direction: column;
}
body.is-locked { overflow: hidden; }
img, svg { display: block; max-width: 100%; }
button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
input, textarea, select { font: inherit; color: inherit; }

/* DESIGN TOKENS */
:root {
  --black-0:  #0e0e10;
  --black-1:  #1a1a1d;
  --black-2:  #2a2a2e;
  --black-3:  #3d3d42;
  --black-4:  #5a5a5d;
  --black-5:  #7a7a7e;
  --black-6:  #a8a8ad;
  --black-7:  #d4d2cc;
  --black-8:  #e8e6df;
  --black-9:  #f1efe8;
  --black-10: #f7f5f2;
  --white:    #ffffff;
  --red:      #d0021b;
  --red-dark: #a30015;
  --gold:     #d4a017;
  --green:    #2d6a4f;
  --container: 1280px;
  --pad: 16px;
}
@media (min-width: 768px)  { :root { --pad: 24px; } }
@media (min-width: 1024px) { :root { --pad: 32px; } }

/* TYPOGRAPHY HELPERS */
.h-display { font-weight: 900; letter-spacing: -0.025em; line-height: 1; }
.eyebrow { font-size: 10px; font-weight: 800; letter-spacing: 0.22em;
           text-transform: uppercase; color: var(--black-4); }
.eyebrow--light { color: var(--black-6); }
.eyebrow--dark { color: var(--black-0); }
.container { width: 100%; max-width: var(--container); margin: 0 auto;
             padding-left: var(--pad); padding-right: var(--pad); }

/* BUTTONS */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px;
       padding: 13px 24px; font-size: 12px; font-weight: 800; letter-spacing: 0.06em;
       text-transform: uppercase; transition: background-color 0.2s, color 0.2s, border-color 0.2s; }
.btn--dark { background: var(--black-0); color: var(--white); }
.btn--dark:hover { background: var(--black-2); }
.btn--ghost { background: transparent; color: var(--black-0); border: 1px solid var(--black-0); }
.btn--ghost:hover { background: var(--black-0); color: var(--white); }
.btn--white { background: var(--white); color: var(--black-0); }
.btn--white:hover { background: var(--black-9); }
.btn--ghost-white { background: transparent; color: var(--white); border: 1px solid var(--white); }
.btn--ghost-white:hover { background: var(--white); color: var(--black-0); }
.btn--block { display: flex; width: 100%; }

/* SKIP LINK (a11y) */
.trk-skip-link {
  position: absolute; left: -9999px; top: 8px;
  background: #0e0e10; color: #fff; padding: 8px 14px;
  font-size: 12px; font-weight: 800; letter-spacing: 0.06em;
  text-transform: uppercase; z-index: 999;
}
.trk-skip-link:focus { left: 8px; outline: 2px solid #d4a017; }

/* ANNOUNCEMENT BAR */
.announce {
  background: var(--black-0); color: var(--white);
  height: 36px; position: relative; overflow: hidden;
  display: flex; align-items: center; flex-shrink: 0;
}
.announce__track {
  flex: 1; height: 100%; position: relative;
  display: flex; align-items: center; justify-content: center;
}
.announce__msg {
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  font-size: 11px; font-weight: 700; letter-spacing: 0.12em;
  text-transform: uppercase; white-space: nowrap;
  opacity: 0; padding: 0 48px;
  animation: announce-cycle 12s infinite;
}
.announce__msg:nth-child(1) { animation-delay: 0s; }
.announce__msg:nth-child(2) { animation-delay: 4s; }
.announce__msg:nth-child(3) { animation-delay: 8s; }
.announce__msg__star { color: var(--red); margin-right: 6px; animation: star-flash 1s infinite; }
@keyframes announce-cycle {
  0%   { opacity: 0; transform: translate(-50%, -50%) translateY(20px); }
  3%   { opacity: 1; transform: translate(-50%, -50%) translateY(0); }
  30%  { opacity: 1; transform: translate(-50%, -50%) translateY(0); }
  33%  { opacity: 0; transform: translate(-50%, -50%) translateY(-20px); }
  100% { opacity: 0; transform: translate(-50%, -50%) translateY(-20px); }
}
@keyframes star-flash { 0%, 100% { opacity: 1; } 50% { opacity: 0.3; } }
.announce__close {
  position: absolute; right: var(--pad); top: 50%;
  transform: translateY(-50%);
  font-size: 16px; opacity: 0.6; line-height: 1; padding: 4px;
}
.announce__close:hover { opacity: 1; }

/* HEADER */
.header { background: var(--white); position: sticky; top: 0; z-index: 100;
          border-bottom: 1px solid var(--black-8); }

/* Top utility bar — laptop only */
.header__top { background: var(--black-10); border-bottom: 1px solid var(--black-8); display: none; }
@media (min-width: 1024px) {
  .header__top { display: block; }
  .header__top-inner { display: flex; justify-content: space-between; align-items: center;
                       padding: 7px 0; font-size: 11px; color: var(--black-3); font-weight: 500; }
  .header__top-links { display: flex; gap: 18px; }
  .header__top-links a { transition: color 0.15s; }
  .header__top-links a:hover { color: var(--black-0); }
  .header__currency { font-weight: 600; color: var(--black-3);
                      display: inline-flex; align-items: center; gap: 6px; }
}

/* Main bar */
.header__main { padding: 12px 0; }
.header__main-inner { display: flex; align-items: center; gap: 12px; }
.icon-btn { width: 40px; height: 40px; display: inline-flex;
            align-items: center; justify-content: center;
            color: var(--black-0); border-radius: 4px; transition: background-color 0.15s; flex-shrink: 0; }
.icon-btn:hover { background: var(--black-10); }
.icon-btn svg { width: 22px; height: 22px; }
.header__logo { font-size: 20px; font-weight: 900; letter-spacing: -0.02em; color: var(--black-0); flex-shrink: 0; }
.header__search { display: none; flex: 1; position: relative; }
.header__search form { width: 100%; }
.header__search input { width: 100%; padding: 11px 16px 11px 40px;
                        border: 1px solid var(--black-8); border-radius: 4px;
                        background: var(--black-10); font-size: 13px; outline: none;
                        font-family: inherit; transition: border-color 0.15s, background-color 0.15s; }
.header__search input:focus { border-color: var(--black-3); background: var(--white); }
.header__search-icon { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); color: var(--black-4); z-index: 1; }
.header__search-icon svg { width: 16px; height: 16px; }
.header__spacer { flex: 1; }
.header__actions { display: flex; align-items: center; gap: 4px; flex-shrink: 0; }
.header__perks { display: none; }
.header__cart { display: inline-flex; align-items: center; gap: 8px; padding: 9px 16px;
                background: var(--red); color: var(--white); border-radius: 99px;
                font-size: 12px; font-weight: 800; letter-spacing: 0.03em; flex-shrink: 0;
                transition: background-color 0.15s; cursor: pointer; }
.header__cart:hover { background: var(--red-dark); }
.header__cart svg { width: 16px; height: 16px; }
.header__cart-label { display: none; }

@media (min-width: 768px) {
  .header__main { padding: 14px 0; }
  .header__search { display: block; }
  .header__spacer { display: none; }
  .header__cart-label { display: inline; }
}
@media (min-width: 1024px) {
  .header__hamburger { display: none; }
  .header__perks { display: flex; gap: 18px; font-size: 11px; color: var(--black-4); margin-right: 8px; }
  .header__perk strong { color: var(--black-0); font-weight: 700; }
}
@media (max-width: 1023px) {
  .header__hamburger { display: inline-flex; }
}

/* NAV — hidden on mobile/tablet, mega-menu on laptop */
.nav { display: none; }
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }

@media (min-width: 1024px) {
  .nav { display: block; border-top: 1px solid var(--black-8);
         position: relative; background: var(--white); }
  .nav__inner { overflow: visible; }
  .nav__list { display: flex; justify-content: center; gap: 0;
               padding: 0; white-space: nowrap; list-style: none; }
  .nav__item, .nav__list > li > a {
    display: inline-flex; align-items: center; gap: 6px;
    background: transparent; color: var(--black-0);
    padding: 18px 18px; border-radius: 0; font-size: 12px; font-weight: 700;
    letter-spacing: 0.08em; text-transform: uppercase; position: relative;
    border-bottom: 3px solid transparent;
    cursor: pointer; transition: border-color 0.15s, color 0.15s;
  }
  .nav__caret { font-size: 8px; opacity: 0.7; }
  .nav__item:hover, .nav__list > li > a:hover {
    color: var(--black-0); border-bottom-color: var(--black-0);
  }
  .nav__item--featured { color: var(--red); font-weight: 800; }
  .nav__item--featured::after {
    content: ''; display: inline-block; width: 6px; height: 6px;
    background: var(--red); border-radius: 50%; margin-left: 4px;
    animation: pulse 2s infinite;
  }
  .nav__item--featured:hover { border-bottom-color: var(--red); }
}

/* DRAWERS (mobile menu + cart) */
.drawer-backdrop {
  position: fixed; inset: 0; background: rgba(14,14,16,0.55);
  opacity: 0; visibility: hidden;
  transition: opacity 0.25s, visibility 0.25s;
  z-index: 199;
}
.drawer-backdrop.is-open { opacity: 1; visibility: visible; }

.drawer {
  position: fixed; top: 0; bottom: 0; width: min(380px, 88vw);
  background: var(--white); z-index: 200;
  display: flex; flex-direction: column;
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  overflow: hidden;
}
.drawer--menu { left: 0; transform: translateX(-100%); }
.drawer--menu.is-open { transform: translateX(0); }
.drawer--cart { right: 0; transform: translateX(100%); }
.drawer--cart.is-open { transform: translateX(0); }

.drawer__header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px var(--pad); border-bottom: 1px solid var(--black-8); flex-shrink: 0;
}
.drawer__title { font-size: 14px; font-weight: 800; letter-spacing: 0.06em; text-transform: uppercase; }
.drawer__close { width: 32px; height: 32px; display: flex; align-items: center;
                 justify-content: center; color: var(--black-0); }
.drawer__close svg { width: 18px; height: 18px; }
.drawer__body { flex: 1; overflow-y: auto; -webkit-overflow-scrolling: touch; }

.menu-drawer__featured {
  background: var(--black-0); color: var(--white); padding: 18px var(--pad);
  display: flex; align-items: center; gap: 14px;
  border-bottom: 1px solid var(--black-2); position: relative;
}
.menu-drawer__featured::before {
  content: ''; width: 8px; height: 8px; background: var(--red);
  border-radius: 50%; flex-shrink: 0; animation: pulse 2s infinite;
}
.menu-drawer__featured-h {
  font-size: 14px; font-weight: 800; letter-spacing: 0.04em;
  text-transform: uppercase; color: var(--white);
}
.menu-drawer__featured-sub { font-size: 11px; color: var(--black-6); margin-top: 2px; }

.menu-drawer__list { padding: 8px 0; }
.menu-drawer__list li a {
  display: block; padding: 14px var(--pad); font-size: 14px; color: var(--black-0);
  font-weight: 600; border-bottom: 1px solid var(--black-9);
  transition: background-color 0.15s;
}
.menu-drawer__list li a:hover { background: var(--black-10); }

.menu-drawer__bottom {
  padding: 18px var(--pad); display: flex; flex-direction: column; gap: 12px;
  background: var(--black-10);
}
.menu-drawer__bottom-link { font-size: 13px; color: var(--black-3); font-weight: 600; }

/* FOOTER */
.footer {
  background: var(--black-0); color: var(--white);
  padding: 36px var(--pad) 24px;
  padding-bottom: 96px; /* extra room for sticky mobile bar */
  margin-top: auto;
  flex-shrink: 0;
}
.footer__brand-h { font-size: 22px; font-weight: 900; letter-spacing: -0.02em; color: var(--white); }
.footer__est { font-size: 10px; color: var(--black-6); letter-spacing: 0.18em; margin-top: 2px; }
.footer__about { font-size: 12px; color: var(--black-7); margin-top: 14px; line-height: 1.6; max-width: 320px; }
.footer__social { display: flex; gap: 14px; margin-top: 14px; font-size: 16px; }
.footer__social a { transition: color 0.15s; }
.footer__social a:hover { color: var(--red); }
.footer__cols { margin-top: 24px; border-top: 1px solid var(--black-2); }
.footer__col { border-bottom: 1px solid var(--black-2); }
.footer__col-trigger {
  width: 100%; display: flex; justify-content: space-between; align-items: center;
  padding: 16px 0; font-size: 11px; font-weight: 700; letter-spacing: 0.12em;
  color: var(--white); text-transform: uppercase; cursor: pointer;
}
.footer__col-trigger::after { content: '+'; color: var(--black-6); font-size: 18px; font-weight: 400; }
.footer__col[open] .footer__col-trigger::after { content: '−'; }
.footer__col-list { padding: 0 0 16px; display: flex; flex-direction: column; gap: 10px;
                    font-size: 12px; color: var(--black-6); }
.footer__col-list a { transition: color 0.15s; }
.footer__col-list a:hover { color: var(--white); }
.footer__legal { margin-top: 24px; font-size: 10px; color: var(--black-5); line-height: 1.7;
                 letter-spacing: 0.05em; }

@media (min-width: 768px) {
  .footer { padding-bottom: 48px; }
  .footer__inner { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr 1fr; gap: 32px; }
  .footer__brand { grid-column: 1; }
  .footer__cols { display: contents; margin: 0; border: none; }
  .footer__col { border: none; }
  .footer__col-trigger { padding: 0 0 12px; cursor: default; pointer-events: none;
                         color: var(--black-6); border-bottom: 1px solid var(--black-2); margin-bottom: 14px; }
  .footer__col-trigger::after { display: none; }
  .footer__col-list { padding: 0; }
  .footer__legal { grid-column: 1 / -1; padding-top: 24px; border-top: 1px solid var(--black-2);
                   display: flex; justify-content: space-between; }
}

/* STICKY MOBILE BOTTOM BAR */
.sticky-bar {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 90;
  background: var(--white); border-top: 1px solid var(--black-0);
  display: flex; justify-content: space-around; align-items: center;
  padding: 10px 8px;
  padding-bottom: calc(10px + env(safe-area-inset-bottom));
}
.sticky-bar__item { flex: 1; text-align: center; padding: 4px 6px;
                    transition: opacity 0.15s; }
.sticky-bar__item:hover { opacity: 0.7; }
.sticky-bar__icon { font-size: 18px; line-height: 1; position: relative; display: inline-block; }
.sticky-bar__lbl { font-size: 9px; font-weight: 700; letter-spacing: 0.05em;
                   margin-top: 4px; color: var(--black-0); text-transform: uppercase; }
.sticky-bar__item--accent .sticky-bar__icon { color: var(--red); font-weight: 900; }
.sticky-bar__item--accent .sticky-bar__lbl { color: var(--red); font-weight: 800; }
.sticky-bar__badge {
  position: absolute; top: -6px; right: -10px;
  background: var(--red); color: var(--white);
  font-size: 9px; font-weight: 800; padding: 1px 5px; border-radius: 99px;
  min-width: 16px; text-align: center;
}
@media (min-width: 1024px) { .sticky-bar { display: none; } }

/* TEMPORARY HEALTH-CHECK CARD (will be removed when front-page.php arrives in Section 2) */
.trk-temp-main {
  flex: 1; display: flex; align-items: flex-start; justify-content: center;
  padding: 40px 24px; background: var(--black-10);
}
.trk-temp-main__phase-card {
  max-width: 720px; width: 100%; background: #fff; padding: 40px;
  border: 1px solid var(--black-8);
}
.trk-temp-main__phase-card h1 {
  font-size: 32px; font-weight: 900; letter-spacing: -0.025em;
  line-height: 1.1; margin-bottom: 14px;
}
.trk-temp-main__phase-card h2 {
  font-size: 11px; font-weight: 800; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--black-4);
  margin: 32px 0 14px; padding-bottom: 8px;
  border-bottom: 1px solid var(--black-8);
}
.trk-temp-main__lead {
  font-size: 15px; line-height: 1.7; color: var(--black-3); max-width: 560px;
}
.trk-temp-main__check { list-style: none; margin: 0; padding: 0; }
.trk-temp-main__check li {
  padding: 10px 0; border-bottom: 1px solid var(--black-9);
  font-size: 13px; color: var(--black-3);
}
.trk-temp-main__check li:last-child { border-bottom: none; }
.trk-temp-main__check strong {
  display: inline-block; min-width: 180px; color: var(--black-0); font-weight: 700;
}
.trk-temp-main__posts { list-style: decimal; padding-left: 24px; }
.trk-temp-main__posts li { padding: 6px 0; font-size: 13px; }
.trk-temp-main__posts a {
  color: var(--black-0); font-weight: 600; text-decoration: underline;
}
.trk-temp-main__date { color: var(--black-5); font-size: 11px; margin-left: 4px; }
.trk-temp-main__next {
  margin-top: 32px; padding: 16px;
  background: var(--black-9); border-left: 3px solid var(--gold);
  font-size: 13px; font-style: italic; color: var(--black-3);
}
@media (max-width: 600px) {
  .trk-temp-main__phase-card { padding: 24px; }
  .trk-temp-main__phase-card h1 { font-size: 24px; }
  .trk-temp-main__check strong { display: block; min-width: 0; }
}

/* ============================================================
   PHASE 3 SECTION 2.1 — HERO SLIDER
   ============================================================ */

.hero { background: var(--black-0); color: var(--white); position: relative; overflow: hidden; }

.hero__slides { position: relative; width: 100%; }
.hero__slide {
  display: grid;
  grid-template-rows: auto auto;
  position: absolute; inset: 0;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.7s ease, visibility 0s linear 0.7s;
}
.hero__slide.is-active {
  opacity: 1;
  visibility: visible;
  transition: opacity 0.7s ease, visibility 0s linear 0s;
  position: relative;
}

.hero__media {
  position: relative;
  width: 100%;
  aspect-ratio: 4/5;
  background: var(--black-1);
  overflow: hidden;
}
.hero__media picture,
.hero__media picture img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}

/* Placeholder shown if images don't load yet */
.media-placeholder {
  position: absolute; inset: 0;
  display: none;
  flex-direction: column;
  align-items: center; justify-content: center;
  gap: 6px; padding: 20px;
  background: var(--black-1);
  color: var(--black-5);
  font-family: 'Courier New', monospace;
  font-size: 11px;
  text-align: center;
}
.is-empty .media-placeholder { display: flex; }
.media-placeholder__file {
  color: var(--white);
  font-weight: 700;
  background: var(--black-2);
  padding: 4px 10px;
  margin-top: 4px;
}
.media-placeholder__file:first-child { margin-top: 0; }
.media-placeholder__dim {
  font-size: 10px;
  letter-spacing: 0.05em;
}

.hero__body { padding: 28px var(--pad) 36px; }
.hero__h { font-size: 42px; margin-top: 12px; color: var(--white); }
.hero__sub { font-size: 13px; color: var(--black-7); line-height: 1.6; margin-top: 14px; max-width: 480px; }
.hero__ctas { display: flex; flex-direction: column; gap: 10px; margin-top: 22px; }

.hero__controls {
  position: absolute; bottom: 16px; left: 50%; transform: translateX(-50%);
  z-index: 10; display: flex; align-items: center; gap: 12px;
  background: rgba(14,14,16,0.7); padding: 8px 14px; border-radius: 99px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.hero__arrow {
  width: 28px; height: 28px;
  display: inline-flex; align-items: center; justify-content: center;
  background: transparent; color: var(--white);
  font-size: 16px; font-weight: 700; cursor: pointer;
  border-radius: 50%; transition: background-color 0.15s;
}
.hero__arrow:hover { background: rgba(255,255,255,0.15); }
.hero__dots { display: flex; gap: 6px; align-items: center; }
.hero__dot {
  width: 8px; height: 8px; padding: 0;
  background: rgba(255,255,255,0.35); border-radius: 50%;
  cursor: pointer; transition: background-color 0.2s, width 0.2s;
}
.hero__dot:hover { background: rgba(255,255,255,0.6); }
.hero__dot.is-active {
  background: var(--white);
  width: 24px;
  border-radius: 4px;
}

@media (min-width: 768px) {
  .hero__h { font-size: 56px; }
  .hero__ctas { flex-direction: row; }
  .hero__ctas .btn { width: auto; }
}
@media (min-width: 1024px) {
  .hero__slide { grid-template-rows: none; grid-template-columns: 1fr 1fr; }
  .hero__media { aspect-ratio: auto; height: 100%; min-height: 580px; }
  .hero__body { display: flex; flex-direction: column; justify-content: center; padding: 64px var(--pad); }
  .hero__h { font-size: 76px; }
  .hero__sub { font-size: 15px; }
  .hero__controls { bottom: 28px; padding: 10px 18px; }
  .hero__arrow { width: 36px; height: 36px; font-size: 20px; }
}

/* ============================================================
   PHASE 3 SECTION 2.2 — TRUST STRIP
   ============================================================ */

.trust {
  background: var(--black-10);
  border-top: 1px solid var(--black-1);
  border-bottom: 1px solid var(--black-1);
  padding: 18px 0;
}
.trust__inner {
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: flex-start;
}
.trust__rating {
  display: flex;
  align-items: center;
  gap: 12px;
}
.trust__stars {
  color: var(--gold);
  letter-spacing: 1px;
  font-size: 14px;
}
.trust__rating-text {
  font-size: 13px;
  font-weight: 800;
  color: var(--black-0);
  line-height: 1.2;
}
.trust__rating-sub {
  font-size: 10px;
  color: var(--black-4);
  margin-top: 2px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.trust__divider {
  height: 1px;
  width: 100%;
  background: var(--black-7);
}
.trust__perks {
  font-size: 11px;
  color: var(--black-3);
  font-weight: 600;
  line-height: 1.6;
  display: flex;
  flex-wrap: wrap;
  gap: 4px 16px;
}
.trust__perks span {
  display: inline-flex;
  align-items: center;
}
.trust__perks em {
  color: var(--black-0);
  font-style: italic;
  font-weight: 700;
  margin-left: 4px;
}

@media (min-width: 768px) {
  .trust__inner {
    flex-direction: row;
    align-items: center;
    justify-content: space-around;
    gap: 24px;
    flex-wrap: wrap;
  }
  .trust__divider {
    width: 1px;
    height: 40px;
  }
  .trust__perks {
    font-size: 12px;
    gap: 24px;
  }
}

/* ============================================================
   PHASE 3 SECTION 2.3 — WC 2026 COUNTDOWN
   ============================================================ */

.countdown {
  background: var(--black-0);
  color: var(--white);
  padding: 36px 0;
  text-align: center;
}
.countdown__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 22px;
}
.countdown__head {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.countdown__h {
  font-size: 36px;
  color: var(--white);
}
.countdown__digits {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  width: 100%;
  max-width: 580px;
}
.countdown__cell {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 16px 8px;
  background: var(--black-2);
  border: 1px solid var(--black-3);
}
.countdown__num {
  font-size: 32px;
  font-weight: 900;
  letter-spacing: -0.03em;
  line-height: 1;
  color: var(--white);
  font-variant-numeric: tabular-nums;
  font-feature-settings: 'tnum';
}
.countdown__lbl {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--black-6);
}
.countdown__cta {
  margin-top: 8px;
}

@media (min-width: 768px) {
  .countdown { padding: 56px 0; }
  .countdown__h { font-size: 52px; }
  .countdown__digits { gap: 16px; }
  .countdown__cell { padding: 24px 12px; }
  .countdown__num { font-size: 56px; }
  .countdown__lbl { font-size: 11px; }
}
@media (min-width: 1024px) {
  .countdown__h { font-size: 72px; }
  .countdown__num { font-size: 76px; }
}

/* ============================================================
   PHASE 3 SECTION 2.4 — WC 2026 NATIONS GRID
   ============================================================ */

.nations {
  background: var(--black-0);
  color: var(--white);
  padding: 36px 0 44px;
}
.sec__head--center {
  text-align: center;
  margin-bottom: 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.nations__h {
  font-size: 32px;
  color: var(--white);
}
.nations__lead {
  font-size: 13px;
  color: var(--black-6);
  line-height: 1.6;
  max-width: 540px;
  margin: 6px auto 0;
}

/* Mobile: horizontal scroll carousel */
.nations__grid {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  padding: 0 var(--pad);
  margin: 0 calc(var(--pad) * -1);
  scroll-padding-left: var(--pad);
}
.nations__grid::-webkit-scrollbar { display: none; }

.nation-tile {
  flex: 0 0 46%;
  scroll-snap-align: start;
  display: flex;
  flex-direction: column;
  position: relative;
  background: var(--black-1);
  border: 1px solid var(--black-2);
  transition: transform 0.15s, border-color 0.15s;
}
.nation-tile:hover {
  transform: translateY(-2px);
  border-color: var(--black-4);
}
.nation-tile__tag {
  position: absolute;
  top: 8px;
  left: 8px;
  padding: 3px 8px;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  z-index: 2;
}
.nation-tile__tag--host {
  background: var(--red);
  color: var(--white);
}
.nation-tile__media {
  width: 100%;
  aspect-ratio: 4/5;
  background: var(--black-2);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--black-5);
  font-family: 'Courier New', monospace;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.1em;
}
.nation-tile__name {
  padding: 12px 10px;
  font-size: 12px;
  font-weight: 700;
  text-align: center;
  color: var(--white);
  background: var(--black-1);
  letter-spacing: 0.02em;
}

.nations__cta {
  display: flex;
  justify-content: center;
  margin-top: 24px;
}

@media (min-width: 768px) {
  .nations { padding: 56px 0 64px; }
  .nations__h { font-size: 44px; }
  .nations__lead { font-size: 14px; }
  .nations__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
    overflow: visible;
    padding: 0;
    margin: 0;
    scroll-snap-type: none;
  }
  .nation-tile { flex: initial; }
  .nation-tile__name { padding: 14px 12px; font-size: 13px; }
}
@media (min-width: 1024px) {
  .nations__h { font-size: 56px; }
  .nations__grid {
    grid-template-columns: repeat(6, 1fr);
    gap: 16px;
  }
}

/* ============================================================
   PHASE 3 SECTION 2.4 — NATIONS — light theme override
   ============================================================ */

.nations {
  background: var(--white);
  color: var(--black-0);
}
.nations .eyebrow,
.nations__lead {
  color: var(--black-4);
}
.nations__h {
  color: var(--black-0);
}
.nations .btn--ghost-white {
  color: var(--black-0);
  border-color: var(--black-0);
}
.nations .btn--ghost-white:hover {
  background: var(--black-0);
  color: var(--white);
}

/* Tiles stay dark so they pop against the new white background */
.nation-tile {
  background: var(--black-0);
  border-color: var(--black-1);
}
.nation-tile:hover {
  border-color: var(--black-3);
}
.nation-tile__media {
  background: var(--black-1);
  color: var(--black-5);
}
.nation-tile__name {
  background: var(--black-0);
  color: var(--white);
}

/* ============================================================
   PHASE 3 SECTION 2.5 — EDITORIAL FEATURED PRODUCT
   ============================================================ */

.editorial {
  background: var(--black-0);
  color: var(--white);
}
.editorial__inner {
  display: grid;
  grid-template-rows: auto auto;
}
.editorial__media {
  position: relative;
  width: 100%;
  aspect-ratio: 4/5;
  background: var(--black-1);
  overflow: hidden;
}
.editorial__media picture,
.editorial__media picture img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.editorial__body {
  padding: 36px var(--pad);
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.editorial__h {
  font-size: 36px;
  color: var(--white);
}
.editorial__copy {
  font-size: 14px;
  line-height: 1.7;
  color: var(--black-7);
}
.editorial__specs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 24px;
  padding: 16px 0;
  border-top: 1px solid var(--black-2);
  border-bottom: 1px solid var(--black-2);
  margin: 0;
}
.editorial__specs > div {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.editorial__specs dt {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--black-5);
}
.editorial__specs dd {
  font-size: 13px;
  font-weight: 700;
  color: var(--white);
  margin: 0;
}
.instock {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: var(--green);
  font-weight: 700;
}
.instock::before {
  content: '';
  width: 6px;
  height: 6px;
  background: var(--green);
  border-radius: 50%;
}
.editorial__price-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.editorial__price {
  font-size: 32px;
  font-weight: 900;
  letter-spacing: -0.02em;
  color: var(--white);
  line-height: 1;
}
.editorial__rating {
  font-size: 13px;
  color: var(--gold);
  letter-spacing: 1px;
}
.editorial__rating em {
  color: var(--black-6);
  font-style: normal;
  font-size: 11px;
  letter-spacing: 0;
  margin-left: 6px;
}
.editorial__ctas {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 4px;
}

@media (min-width: 768px) {
  .editorial__body { padding: 56px var(--pad); gap: 22px; }
  .editorial__h { font-size: 52px; }
  .editorial__copy { font-size: 15px; }
  .editorial__price { font-size: 40px; }
  .editorial__ctas { flex-direction: row; }
  .editorial__ctas .btn { width: auto; }
}
@media (min-width: 1024px) {
  .editorial__inner {
    grid-template-rows: none;
    grid-template-columns: 1fr 1fr;
    align-items: stretch;
  }
  .editorial__media {
    aspect-ratio: auto;
    min-height: 640px;
  }
  .editorial__body {
    padding: 80px 64px;
    justify-content: center;
  }
  .editorial__h { font-size: 64px; }
}

/* ============================================================
   PHASE 3 SECTION 2.6 — SHOP BY CLUB
   ============================================================ */

.clubs {
  background: var(--white);
  padding: 36px 0 44px;
}
.sec__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 16px;
  margin-bottom: 22px;
  flex-wrap: wrap;
}
.sec__head .eyebrow {
  display: block;
  margin-bottom: 6px;
}
.clubs__h {
  font-size: 28px;
  color: var(--black-0);
}
.sec__link {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--black-0);
  border-bottom: 1px solid var(--black-0);
  padding-bottom: 2px;
  white-space: nowrap;
  transition: color 0.15s, border-color 0.15s;
}
.sec__link:hover {
  color: var(--red);
  border-bottom-color: var(--red);
}

.clubs__row {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  padding: 4px var(--pad);
  margin: 0 calc(var(--pad) * -1);
  scroll-padding-left: var(--pad);
}
.clubs__row::-webkit-scrollbar { display: none; }

.club-tile {
  flex: 0 0 auto;
  scroll-snap-align: start;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  width: 96px;
  text-align: center;
  transition: transform 0.15s;
}
.club-tile:hover {
  transform: translateY(-2px);
}
.club-tile__crest {
  width: 76px;
  height: 76px;
  border-radius: 50%;
  background: var(--black-9);
  border: 1px solid var(--black-7);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--black-4);
  font-family: 'Courier New', monospace;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.06em;
  transition: background-color 0.15s, border-color 0.15s;
}
.club-tile:hover .club-tile__crest {
  background: var(--white);
  border-color: var(--black-0);
}
.club-tile__name {
  font-size: 11px;
  font-weight: 600;
  color: var(--black-3);
  line-height: 1.3;
}

@media (min-width: 768px) {
  .clubs { padding: 56px 0 64px; }
  .clubs__h { font-size: 36px; }
  .clubs__row { gap: 18px; padding: 4px 0; margin: 0; }
  .club-tile { width: 120px; gap: 12px; }
  .club-tile__crest { width: 96px; height: 96px; font-size: 14px; }
  .club-tile__name { font-size: 12px; }
}
@media (min-width: 1024px) {
  .clubs__h { font-size: 44px; }
  .club-tile__crest { width: 110px; height: 110px; }
}

/* ============================================================
   PHASE 3 SECTION 2.7 — FEATURED COLLECTIONS
   ============================================================ */

.collections {
  background: var(--white);
  padding: 36px 0 44px;
}
.collections__h {
  font-size: 28px;
  color: var(--black-0);
}

.collections__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

.ctile {
  position: relative;
  display: block;
  overflow: hidden;
  background: var(--black-1);
  aspect-ratio: 4/5;
  transition: transform 0.2s;
}
.ctile:hover {
  transform: translateY(-3px);
}
.ctile__media {
  position: absolute;
  inset: 0;
  background: var(--black-1);
}
.ctile__placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Courier New', monospace;
  font-size: 11px;
  color: var(--black-5);
  padding: 16px;
  text-align: center;
  background: linear-gradient(135deg, var(--black-1) 0%, var(--black-2) 100%);
}
.ctile__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 22px;
  background: linear-gradient(to top, rgba(14,14,16,0.85) 0%, rgba(14,14,16,0.3) 50%, transparent 100%);
  color: var(--white);
  z-index: 2;
}
.ctile__eyebrow {
  display: inline-block;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.18em;
  color: var(--black-7);
  margin-bottom: 8px;
  align-self: flex-start;
}
.ctile__h {
  font-size: 24px;
  font-weight: 800;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--white);
}
.ctile__sub {
  font-size: 12px;
  font-weight: 500;
  line-height: 1.5;
  color: var(--black-7);
  margin-top: 8px;
  max-width: 320px;
}
.ctile:hover .ctile__h {
  color: var(--white);
}

@media (min-width: 768px) {
  .collections { padding: 56px 0 64px; }
  .collections__h { font-size: 36px; }
  .collections__grid {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto auto;
    gap: 16px;
  }
  .ctile--hero {
    grid-column: 1 / -1;
    grid-row: 1;
    aspect-ratio: 16/9;
  }
  .ctile__h { font-size: 28px; }
  .ctile--hero .ctile__h { font-size: 40px; }
  .ctile__overlay { padding: 28px; }
}
@media (min-width: 1024px) {
  .collections__h { font-size: 44px; }
  .collections__grid {
    grid-template-columns: 1.3fr 1fr 1fr;
    grid-template-rows: 1fr 1fr;
    gap: 20px;
  }
  .ctile--hero {
    grid-column: 1;
    grid-row: 1 / -1;
    aspect-ratio: auto;
  }
  .ctile { aspect-ratio: auto; min-height: 280px; }
  .ctile__h { font-size: 30px; }
  .ctile--hero .ctile__h { font-size: 56px; }
  .ctile__overlay { padding: 36px; }
}

/* ============================================================
   PHASE 3 SECTION 2.8 — NEW ARRIVALS (real product cards)
   ============================================================ */

.arrivals {
  background: var(--white);
  padding: 36px 0 44px;
}
.arrivals__h {
  font-size: 28px;
  color: var(--black-0);
}

.arrivals__row {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  padding: 4px var(--pad);
  margin: 0 calc(var(--pad) * -1);
  scroll-padding-left: var(--pad);
}
.arrivals__row::-webkit-scrollbar { display: none; }

.pcard {
  flex: 0 0 220px;
  scroll-snap-align: start;
  display: flex;
  flex-direction: column;
  background: var(--white);
  transition: transform 0.15s;
}
.pcard:hover {
  transform: translateY(-2px);
}
.pcard__media {
  position: relative;
  width: 100%;
  aspect-ratio: 1/1;
  background: var(--black-9);
  overflow: hidden;
}
.pcard__img,
.pcard__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.pcard__placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 16px;
  font-size: 11px;
  font-weight: 700;
  color: var(--black-4);
  letter-spacing: 0.02em;
  line-height: 1.4;
}
.pcard__body {
  padding: 12px 4px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.pcard__name {
  font-size: 13px;
  font-weight: 600;
  color: var(--black-0);
  line-height: 1.4;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.pcard__price {
  font-size: 14px;
  font-weight: 800;
  color: var(--black-0);
  letter-spacing: -0.01em;
}
.pcard__price del {
  font-weight: 500;
  color: var(--black-5);
  margin-right: 6px;
}
.pcard__price ins {
  text-decoration: none;
  color: var(--red);
}
.pcard:hover .pcard__name {
  color: var(--red);
}

@media (min-width: 768px) {
  .arrivals { padding: 56px 0 64px; }
  .arrivals__h { font-size: 36px; }
  .arrivals__row { gap: 18px; padding: 4px 0; margin: 0; }
  .pcard { flex: 0 0 240px; }
  .pcard__name { font-size: 14px; }
  .pcard__price { font-size: 15px; }
}
@media (min-width: 1024px) {
  .arrivals__h { font-size: 44px; }
  .pcard { flex: 0 0 260px; }
}

/* ============================================================
   PHASE 3 SECTION 2.9 — BEST SELLERS (dark, ranked)
   ============================================================ */

.bestsellers {
  background: var(--black-0);
  color: var(--white);
  padding: 36px 0 44px;
}
.bestsellers__h {
  font-size: 28px;
  color: var(--white);
}
.sec__head--dark .eyebrow,
.sec__head--dark .eyebrow--light {
  color: var(--black-6);
}
.sec__link--white {
  color: var(--white);
  border-bottom-color: var(--white);
}
.sec__link--white:hover {
  color: var(--red);
  border-bottom-color: var(--red);
}

.bestsellers__row {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  padding: 4px var(--pad);
  margin: 0 calc(var(--pad) * -1);
  scroll-padding-left: var(--pad);
}
.bestsellers__row::-webkit-scrollbar { display: none; }

.pcard--dark {
  background: var(--black-1);
  border: 1px solid var(--black-2);
}
.pcard--dark .pcard__media {
  background: var(--black-2);
}
.pcard--dark .pcard__placeholder {
  color: var(--black-5);
}
.pcard--dark .pcard__body {
  padding: 14px 12px;
}
.pcard--dark .pcard__name {
  color: var(--white);
}
.pcard--dark .pcard__price {
  color: var(--white);
}
.pcard--dark .pcard__price del {
  color: var(--black-5);
}
.pcard--dark:hover .pcard__name {
  color: var(--red);
}

.pcard__rank {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 2;
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: -0.02em;
  color: var(--white);
  background: var(--black-0);
  padding: 4px 8px;
  line-height: 1;
  border: 1px solid var(--black-3);
}

@media (min-width: 768px) {
  .bestsellers { padding: 56px 0 64px; }
  .bestsellers__h { font-size: 36px; }
  .bestsellers__row { gap: 18px; padding: 4px 0; margin: 0; }
  .pcard__rank { font-size: 16px; padding: 5px 10px; }
}
@media (min-width: 1024px) {
  .bestsellers__h { font-size: 44px; }
  .pcard__rank { font-size: 18px; }
}

/* ============================================================
   PHASE 3 SECTION 2.10 — PROMO PAIR (Mystery Box + Hidden Gems)
   ============================================================ */

.promos {
  background: var(--white);
  padding: 36px 0 44px;
}
.promos__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

.promo-card {
  position: relative;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-height: 360px;
  transition: transform 0.2s;
}
.promo-card:hover {
  transform: translateY(-3px);
}
.promo-card__media {
  position: relative;
  width: 100%;
  height: 200px;
  overflow: hidden;
  flex-shrink: 0;
}
.promo-card__placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Courier New', monospace;
  font-size: 11px;
  text-align: center;
  padding: 16px;
}
.promo-card__body {
  padding: 26px 22px 28px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  flex: 1;
}
.promo-card__h {
  font-size: 36px;
  line-height: 1;
}
.promo-card__copy {
  font-size: 13px;
  line-height: 1.6;
  margin: 0;
}
.promo-card__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-top: auto;
  padding-top: 8px;
  flex-wrap: wrap;
}
.promo-card__price {
  font-size: 24px;
  font-weight: 900;
  letter-spacing: -0.02em;
}

/* Mystery Box — dark theme */
.promo-card--mystery {
  background: var(--black-0);
  color: var(--white);
}
.promo-card--mystery .promo-card__media {
  background: linear-gradient(135deg, var(--black-1) 0%, var(--black-2) 100%);
}
.promo-card--mystery .promo-card__placeholder {
  color: var(--black-5);
}
.promo-card--mystery .promo-card__h,
.promo-card--mystery .promo-card__price {
  color: var(--white);
}
.promo-card--mystery .promo-card__copy {
  color: var(--black-7);
}

/* Hidden Gems — light theme */
.promo-card--gems {
  background: var(--black-9);
  color: var(--black-0);
}
.promo-card--gems .promo-card__media {
  background: linear-gradient(135deg, var(--black-8) 0%, var(--black-7) 100%);
}
.promo-card--gems .promo-card__placeholder {
  color: var(--black-3);
}
.promo-card--gems .promo-card__h {
  color: var(--black-0);
}
.promo-card--gems .promo-card__copy {
  color: var(--black-3);
}

/* Dark btn variant for the gems card */
.btn--dark {
  background: var(--black-0);
  color: var(--white);
  border: 1px solid var(--black-0);
}
.btn--dark:hover {
  background: transparent;
  color: var(--black-0);
}

@media (min-width: 768px) {
  .promos { padding: 56px 0 64px; }
  .promos__grid {
    grid-template-columns: 1fr 1fr;
    gap: 18px;
  }
  .promo-card { min-height: 440px; }
  .promo-card__media { height: 240px; }
  .promo-card__h { font-size: 44px; }
  .promo-card__copy { font-size: 14px; }
}
@media (min-width: 1024px) {
  .promo-card { flex-direction: row; min-height: 380px; }
  .promo-card__media {
    width: 45%;
    height: auto;
    flex-shrink: 0;
  }
  .promo-card__body {
    padding: 36px 32px;
    flex: 1;
  }
  .promo-card__h { font-size: 48px; }
}

/* ============================================================
   PHASE 3 SECTION 2.11 — TOP PICKS (curator's selection)
   ============================================================ */

.toppicks {
  background: var(--white);
  padding: 36px 0 44px;
}
.toppicks__h {
  font-size: 28px;
  color: var(--black-0);
}

.toppicks__row {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  padding: 4px var(--pad);
  margin: 0 calc(var(--pad) * -1);
  scroll-padding-left: var(--pad);
}
.toppicks__row::-webkit-scrollbar { display: none; }
.toppicks__row .pcard {
  flex: 0 0 220px;
  scroll-snap-align: start;
}

@media (min-width: 768px) {
  .toppicks { padding: 56px 0 64px; }
  .toppicks__h { font-size: 36px; }
  .toppicks__row { gap: 18px; padding: 4px 0; margin: 0; }
  .toppicks__row .pcard { flex: 0 0 240px; }
}
@media (min-width: 1024px) {
  .toppicks__h { font-size: 44px; }
  .toppicks__row .pcard { flex: 0 0 260px; }
}

/* ============================================================
   PHASE 3 SECTION 2.12 — BRAND STORY
   ============================================================ */

.story {
  background: var(--black-9);
  color: var(--black-0);
}
.story__inner {
  display: grid;
  grid-template-rows: auto auto;
}
.story__media {
  position: relative;
  width: 100%;
  aspect-ratio: 4/5;
  background: var(--black-7);
  overflow: hidden;
}
.story__media picture,
.story__media picture img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.story__body {
  padding: 36px var(--pad);
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.story__h {
  font-size: 36px;
  color: var(--black-0);
  line-height: 1.05;
}
.story__copy {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.story__copy p {
  font-size: 14px;
  line-height: 1.7;
  color: var(--black-2);
  margin: 0;
}
.story__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  padding: 22px 0;
  border-top: 1px solid var(--black-7);
  border-bottom: 1px solid var(--black-7);
  margin: 4px 0;
}
.story__stat {
  display: flex;
  flex-direction: column;
  gap: 4px;
  text-align: center;
}
.story__stat-num {
  font-size: 28px;
  font-weight: 900;
  letter-spacing: -0.03em;
  color: var(--black-0);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.story__stat-lbl {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--black-4);
  line-height: 1.3;
}
.story__ctas {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 4px;
}

/* Ghost button on dark text (for cream story background) */
.btn--ghost-dark {
  background: transparent;
  color: var(--black-0);
  border: 1px solid var(--black-0);
}
.btn--ghost-dark:hover {
  background: var(--black-0);
  color: var(--white);
}

@media (min-width: 768px) {
  .story__body { padding: 56px var(--pad); gap: 22px; }
  .story__h { font-size: 52px; }
  .story__copy p { font-size: 15px; }
  .story__stat-num { font-size: 36px; }
  .story__stats { padding: 26px 0; }
  .story__ctas { flex-direction: row; }
  .story__ctas .btn { width: auto; }
}
@media (min-width: 1024px) {
  .story__inner {
    grid-template-rows: none;
    grid-template-columns: 1fr 1fr;
    align-items: stretch;
  }
  .story__media {
    aspect-ratio: auto;
    min-height: 640px;
  }
  .story__body {
    padding: 80px 64px;
    justify-content: center;
  }
  .story__h { font-size: 60px; }
  .story__stat-num { font-size: 44px; }
}

/* ============================================================
   PHASE 3 SECTION 2.13 — TESTIMONIALS
   ============================================================ */

.testimonials {
  background: var(--white);
  padding: 36px 0 44px;
}
.testimonials__h {
  font-size: 28px;
  color: var(--black-0);
}
.sec__head--center .eyebrow {
  margin-bottom: 6px;
}

.testimonials__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 8px;
}

.testimonial {
  background: var(--black-10);
  padding: 24px 22px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  border: 1px solid var(--black-8);
  transition: border-color 0.15s, transform 0.15s;
}
.testimonial:hover {
  border-color: var(--black-7);
  transform: translateY(-2px);
}

.testimonial__stars {
  color: var(--gold);
  font-size: 14px;
  letter-spacing: 2px;
  line-height: 1;
}

.testimonial__quote {
  font-size: 14px;
  line-height: 1.7;
  color: var(--black-1);
  font-weight: 500;
  margin: 0;
  font-style: italic;
}

.testimonial__attribution {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding-top: 4px;
}
.testimonial__name {
  font-size: 13px;
  font-weight: 800;
  color: var(--black-0);
  letter-spacing: -0.01em;
}
.testimonial__meta {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--black-5);
}

.testimonial__product {
  font-size: 11px;
  font-weight: 700;
  color: var(--black-3);
  letter-spacing: 0.04em;
  padding-top: 12px;
  margin-top: auto;
  border-top: 1px solid var(--black-8);
}

@media (min-width: 768px) {
  .testimonials { padding: 56px 0 64px; }
  .testimonials__h { font-size: 36px; }
  .testimonials__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
  .testimonial { padding: 28px 26px; }
  .testimonial__quote { font-size: 15px; }
}
@media (min-width: 1024px) {
  .testimonials__h { font-size: 44px; }
}

/* ============================================================
   PHASE 3 SECTION 2.13 — TESTIMONIALS SLIDER (12 reviews, 4/3/2 visible)
   Replaces the static grid version above.
   ============================================================ */

.testimonials__lead {
  font-size: 13px;
  color: var(--black-4);
  margin: 6px 0 0;
  text-align: center;
}

.testimonials__viewport {
  overflow: hidden;
  margin: 22px calc(var(--pad) * -1) 0;
  padding: 0 var(--pad);
  position: relative;
}

.testimonials__track {
  display: flex;
  gap: 14px;
  transition: transform 0.5s ease;
}

.testimonials__track .testimonial {
  flex: 0 0 100%;
  display: flex;
  flex-direction: column;
}

.testimonials__controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-top: 24px;
}
.testimonials__arrow {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--white);
  color: var(--black-0);
  border: 1px solid var(--black-7);
  font-size: 22px;
  font-weight: 700;
  cursor: pointer;
  transition: background-color 0.15s, border-color 0.15s;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.testimonials__arrow:hover {
  background: var(--black-0);
  color: var(--white);
  border-color: var(--black-0);
}
.testimonials__dots {
  display: flex;
  gap: 6px;
  align-items: center;
}
.testimonials__dot {
  width: 8px;
  height: 8px;
  padding: 0;
  background: var(--black-7);
  border-radius: 50%;
  cursor: pointer;
  transition: background-color 0.2s, width 0.2s;
}
.testimonials__dot:hover { background: var(--black-4); }
.testimonials__dot.is-active {
  background: var(--black-0);
  width: 24px;
  border-radius: 4px;
}

@media (min-width: 768px) {
  .testimonials__track .testimonial {
    flex: 0 0 calc((100% - 28px) / 3);
  }
  .testimonials__viewport { margin: 28px 0 0; padding: 0; }
  .testimonials__track { gap: 18px; }
}
@media (min-width: 1024px) {
  .testimonials__track .testimonial {
    flex: 0 0 calc((100% - 60px) / 4);
  }
  .testimonials__track { gap: 20px; }
}

/* ============================================================
   PHASE 3 SECTION 2.14 — JOURNAL (blog post tiles)
   ============================================================ */

.journal {
  background: var(--white);
  padding: 36px 0 44px;
}
.journal__h {
  font-size: 28px;
  color: var(--black-0);
}

.journal__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}

.article-card {
  display: flex;
  flex-direction: column;
  background: var(--white);
  transition: transform 0.15s;
}
.article-card:hover {
  transform: translateY(-2px);
}

.article-card__media {
  position: relative;
  width: 100%;
  aspect-ratio: 16/10;
  background: var(--black-9);
  overflow: hidden;
  margin-bottom: 14px;
}
.article-card__img,
.article-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.article-card__placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 16px;
  font-family: 'Courier New', monospace;
  font-size: 12px;
  font-weight: 700;
  color: var(--black-4);
  line-height: 1.4;
  background: linear-gradient(135deg, var(--black-9) 0%, var(--black-8) 100%);
}

.article-card__body {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.article-card__cat {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--black-4);
}
.article-card__title {
  font-size: 18px;
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.25;
  color: var(--black-0);
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.article-card__meta {
  font-size: 11px;
  color: var(--black-4);
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 4px;
}
.article-card__read {
  color: var(--black-0);
  font-weight: 700;
  letter-spacing: 0.02em;
}
.article-card:hover .article-card__title {
  color: var(--red);
}

.journal__empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: 40px 20px;
  background: var(--black-10);
  border: 1px dashed var(--black-7);
}
.journal__empty p {
  color: var(--black-3);
  font-size: 13px;
  margin: 0;
}
.journal__empty a {
  color: var(--black-0);
  font-weight: 700;
  border-bottom: 1px solid var(--black-0);
}

@media (min-width: 768px) {
  .journal { padding: 56px 0 64px; }
  .journal__h { font-size: 36px; }
  .journal__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
  }
  .article-card__title { font-size: 20px; }
}
@media (min-width: 1024px) {
  .journal__h { font-size: 44px; }
  .article-card__title { font-size: 22px; }
}

/* ============================================================
   PHASE 3 SECTION 2.15 — SISTER BRAND CROSS-PROMO (TheNewKits)
   ============================================================ */

.sister {
  position: relative;
  background: var(--black-0);
  color: var(--white);
  padding: 48px 0 56px;
  overflow: hidden;
}
.sister__bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 80% 50%, rgba(208, 2, 27, 0.12) 0%, transparent 50%),
    radial-gradient(circle at 20% 100%, rgba(255, 255, 255, 0.04) 0%, transparent 60%);
  pointer-events: none;
}
.sister__inner {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.sister__copy {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.sister__h {
  font-size: 32px;
  color: var(--white);
  line-height: 1.05;
}
.sister__sub {
  font-size: 14px;
  line-height: 1.65;
  color: var(--black-7);
  margin: 0;
  max-width: 560px;
}
.sister__cta-wrap {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
}
.sister__link {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--black-7);
  border-bottom: 1px solid var(--black-4);
  padding-bottom: 2px;
  transition: color 0.15s, border-color 0.15s;
}
.sister__link:hover {
  color: var(--white);
  border-bottom-color: var(--white);
}

@media (min-width: 768px) {
  .sister { padding: 64px 0 72px; }
  .sister__h { font-size: 44px; }
  .sister__sub { font-size: 15px; }
  .sister__cta-wrap { flex-direction: row; align-items: center; gap: 24px; }
}
@media (min-width: 1024px) {
  .sister { padding: 88px 0 96px; }
  .sister__inner {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 48px;
  }
  .sister__copy { flex: 1; }
  .sister__cta-wrap { flex-shrink: 0; flex-direction: column; align-items: flex-end; gap: 14px; }
  .sister__h { font-size: 56px; }
  .sister__sub { font-size: 16px; }
}

/* ============================================================
   PHASE 3 SECTION 2.16 — NEWSLETTER (static, ready for Omnisend)
   ============================================================ */

.newsletter {
  background: var(--white);
  padding: 48px 0 56px;
}
.newsletter__inner {
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.newsletter__copy {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.newsletter__h {
  font-size: 32px;
  color: var(--black-0);
  line-height: 1.05;
}
.newsletter__sub {
  font-size: 14px;
  line-height: 1.65;
  color: var(--black-3);
  margin: 0;
  max-width: 540px;
}

.newsletter__form {
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-self: stretch;
  max-width: 560px;
}
.newsletter__label {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.newsletter__field {
  display: flex;
  flex-direction: column;
}
.newsletter__input {
  width: 100%;
  padding: 16px 18px;
  font-size: 15px;
  font-family: inherit;
  font-weight: 500;
  color: var(--black-0);
  background: var(--white);
  border: 1px solid var(--black-7);
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
  -webkit-appearance: none;
  appearance: none;
  border-radius: 0;
}
.newsletter__input::placeholder {
  color: var(--black-5);
}
.newsletter__input:focus {
  border-color: var(--black-0);
  box-shadow: 0 0 0 3px rgba(14, 14, 16, 0.1);
}
.newsletter__input:invalid:not(:placeholder-shown) {
  border-color: var(--red);
}

.newsletter__submit {
  width: 100%;
  position: relative;
}
.newsletter__submit-loading {
  display: none;
}
.newsletter__form.is-loading .newsletter__submit-default {
  display: none;
}
.newsletter__form.is-loading .newsletter__submit-loading {
  display: inline;
}
.newsletter__form.is-loading .newsletter__submit {
  opacity: 0.7;
  cursor: wait;
}

.newsletter__feedback {
  font-size: 13px;
  font-weight: 600;
  min-height: 0;
  transition: min-height 0.2s, padding 0.2s;
}
.newsletter__feedback.is-success {
  color: var(--green);
  background: rgba(45, 106, 79, 0.08);
  padding: 10px 14px;
  border-left: 3px solid var(--green);
  min-height: 40px;
  display: flex;
  align-items: center;
}
.newsletter__feedback.is-error {
  color: var(--red);
  background: rgba(208, 2, 27, 0.06);
  padding: 10px 14px;
  border-left: 3px solid var(--red);
  min-height: 40px;
  display: flex;
  align-items: center;
}

.newsletter__terms {
  font-size: 11px;
  color: var(--black-5);
  line-height: 1.5;
  margin: 4px 0 0;
}
.newsletter__terms a {
  color: var(--black-3);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.newsletter__terms a:hover {
  color: var(--black-0);
}

@media (min-width: 768px) {
  .newsletter { padding: 64px 0 72px; }
  .newsletter__h { font-size: 44px; }
  .newsletter__sub { font-size: 15px; }
  .newsletter__form {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: stretch;
  }
  .newsletter__field {
    flex: 1 1 auto;
    min-width: 280px;
  }
  .newsletter__submit {
    width: auto;
    flex: 0 0 auto;
    padding-left: 28px;
    padding-right: 28px;
  }
  .newsletter__feedback {
    flex-basis: 100%;
  }
  .newsletter__terms {
    flex-basis: 100%;
    margin-top: 8px;
  }
}
@media (min-width: 1024px) {
  .newsletter { padding: 88px 0 96px; }
  .newsletter__inner {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 60px;
  }
  .newsletter__copy { flex: 1; max-width: 540px; }
  .newsletter__form { flex: 0 0 480px; }
  .newsletter__h { font-size: 52px; }
  .newsletter__sub { font-size: 16px; }
}

/* ============================================================
   PHASE 3 SECTION 1B — HOVER DROPDOWNS (laptop nav submenus)
   ============================================================ */

/* The nav__list is a flex row of top-level items */
.nav__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 32px;
  position: relative;
}
.nav__list > li {
  position: relative;
}

/* WP renders submenus as nested <ul class="sub-menu"> */
.nav__list .sub-menu {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  list-style: none;
  margin: 0;
  padding: 12px 0;
  min-width: 220px;
  background: var(--white);
  border: 1px solid var(--black-8);
  box-shadow: 0 12px 32px rgba(14, 14, 16, 0.08), 0 2px 8px rgba(14, 14, 16, 0.04);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.18s ease, visibility 0s linear 0.18s, transform 0.18s ease;
  z-index: 100;
}

/* Show on hover OR when JS adds .is-open (mobile/touch tap) */
.nav__list > li:hover > .sub-menu,
.nav__list > li:focus-within > .sub-menu,
.nav__list > li.is-open > .sub-menu {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
  transition: opacity 0.18s ease, visibility 0s linear 0s, transform 0.18s ease;
}


/* Submenu items */
.nav__list .sub-menu li {
  list-style: none;
}
.nav__list .sub-menu a {
  display: block;
  padding: 10px 18px;
  font-size: 13px;
  font-weight: 500;
  color: var(--black-2);
  letter-spacing: 0.01em;
  text-transform: none;
  white-space: nowrap;
  transition: background-color 0.12s, color 0.12s;
}
.nav__list .sub-menu a:hover {
  background: var(--black-10);
  color: var(--black-0);
}

/* Hide deeper sub-sub-menus (3rd level: Premier League → Arsenal etc.) */
.nav__list .sub-menu .sub-menu {
  display: none;
}

/* Touch / mobile: when no real hover, dropdown opens via tap (handled in JS) */
@media (hover: none) {
  .nav__list > li:hover > .sub-menu {
    opacity: 0;
    visibility: hidden;
    transform: translateX(-50%) translateY(8px);
  }
  .nav__list > li.is-open > .sub-menu {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
  }
}

/* ============================================================
   PHASE 3 SECTION 1C — MEGA MENU (laptop hover panels)
   ============================================================ */

/* Reset nav__list to be the positioning context for the mega-panel */
.nav__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 32px;
  position: relative;
}
.nav__list > li {
  position: static; /* Static so mega-panel can full-width relative to .nav */
}

/* The chevron next to mega-menu parents */
.nav__chev {
  display: inline-block;
  width: 10px;
  height: 6px;
  margin-left: 6px;
  vertical-align: middle;
  opacity: 0.55;
  transition: transform 0.18s ease, opacity 0.18s ease;
}
.nav__list > li.has-mega:hover > .nav__item .nav__chev,
.nav__list > li.has-mega.is-open > .nav__item .nav__chev {
  transform: rotate(180deg);
  opacity: 1;
}

/* The mega-panel itself — full-width drop, hidden by default */
.mega-panel {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  width: 100%;
  background: var(--white);
  border-top: 1px solid var(--black-9);
  border-bottom: 1px solid var(--black-8);
  box-shadow: 0 12px 32px rgba(14, 14, 16, 0.06);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity 0.2s ease, visibility 0s linear 0.2s, transform 0.2s ease;
  z-index: 90;
  padding: 36px 0 40px;
}

/* Show on hover (laptop) or when JS adds .is-open (touch) */
.nav__list > li.has-mega:hover > .mega-panel,
.nav__list > li.has-mega:focus-within > .mega-panel,
.nav__list > li.has-mega.is-open > .mega-panel {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  transition: opacity 0.2s ease, visibility 0s linear 0s, transform 0.2s ease;
}

/* Mega-panel inner grid: 2 columns + 1 right rail */
.mega-panel__inner {
  display: grid;
  grid-template-columns: 1fr 1fr 1.1fr;
  gap: 56px;
  align-items: start;
}

/* Link columns */
.mega-col {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.mega-col__title {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--black-4);
  padding-bottom: 12px;
  border-bottom: 1px solid var(--black-9);
  margin-bottom: 4px;
}
.mega-col__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.mega-col__list li {
  list-style: none;
}
.mega-col__link {
  display: block;
  padding: 8px 0;
  font-size: 14px;
  font-weight: 500;
  color: var(--black-1);
  letter-spacing: 0.005em;
  transition: color 0.12s, transform 0.12s;
}
.mega-col__link:hover {
  color: var(--red);
  transform: translateX(4px);
}
.mega-col__link--cta {
  margin-top: 8px;
  padding-top: 12px;
  border-top: 1px solid var(--black-9);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--black-0);
}
.mega-col__link--cta:hover {
  color: var(--red);
}

/* Right rail: featured tile + promo block */
.mega-rail {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* Featured tile */
.mega-feat {
  position: relative;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: var(--black-1);
  aspect-ratio: 16/9;
  transition: transform 0.2s;
}
.mega-feat:hover {
  transform: translateY(-2px);
}
.mega-feat__media {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--black-1) 0%, var(--black-2) 100%);
}
.mega-feat__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.mega-feat__placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Courier New', monospace;
  font-size: 11px;
  color: var(--black-5);
  padding: 16px;
  text-align: center;
}
.mega-feat__media.is-empty .mega-feat__placeholder {
  /* placeholder stays visible */
}
.mega-feat__body {
  position: relative;
  z-index: 2;
  padding: 22px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  color: var(--white);
  background: linear-gradient(to top, rgba(14,14,16,0.85) 0%, rgba(14,14,16,0.3) 60%, transparent 100%);
  margin-top: auto;
}
.mega-feat__eyebrow {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--black-7);
}
.mega-feat__h {
  font-size: 22px;
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--white);
}
.mega-feat__cta {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--white);
  margin-top: 4px;
}

/* Promo block (icon + text only) */
.mega-promo {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 20px;
  background: var(--black-10);
  border: 1px solid var(--black-9);
}
.mega-promo__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  flex-shrink: 0;
  color: var(--black-0);
}
.mega-promo__icon svg {
  width: 24px;
  height: 24px;
}
.mega-promo__copy {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.mega-promo__h {
  font-size: 13px;
  font-weight: 800;
  color: var(--black-0);
  letter-spacing: -0.01em;
}
.mega-promo__sub {
  font-size: 11px;
  font-weight: 500;
  color: var(--black-4);
}

/* On touch devices the hover state can flicker — disable it */
@media (hover: none) {
  .nav__list > li.has-mega:hover > .mega-panel {
    opacity: 0;
    visibility: hidden;
    transform: translateY(8px);
  }
  .nav__list > li.has-mega.is-open > .mega-panel {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
  }
}

/* Below laptop: hide mega-panel entirely (mobile uses drawer accordion) */
@media (max-width: 1023px) {
  .mega-panel { display: none !important; }
  .nav__chev  { display: none; }
}

/* ============================================================
   PHASE 3 SECTION 1D — MOBILE DRAWER MEGA-MENU (accordion)
   ============================================================ */

.mob-menu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
}
.mob-menu li {
  list-style: none;
  border-bottom: 1px solid var(--black-9);
}

.mob-row {
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: space-between;
  padding: 18px 20px;
  background: transparent;
  color: var(--black-0);
  border: 0;
  text-align: left;
  font-family: inherit;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.005em;
  cursor: pointer;
  transition: background-color 0.12s;
  -webkit-tap-highlight-color: rgba(0,0,0,0.04);
}
.mob-row:hover,
.mob-row:focus-visible {
  background: var(--black-10);
  outline: none;
}
.mob-row__label {
  flex: 1;
}
.mob-row__chev {
  width: 14px;
  height: 9px;
  flex-shrink: 0;
  margin-left: 12px;
  color: var(--black-3);
  transition: transform 0.25s ease, color 0.15s;
}
.mob-row--toggle[aria-expanded="true"] .mob-row__chev {
  transform: rotate(180deg);
  color: var(--black-0);
}
.mob-row--toggle[aria-expanded="true"] {
  background: var(--black-10);
}

/* Sub-panel: hidden by default, slides open via max-height */
.mob-panel {
  background: var(--black-10);
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.32s ease;
}
.mob-panel[hidden] {
  display: block;     /* override browser's display:none so transition runs */
  max-height: 0;
  overflow: hidden;
}
.mob-panel.is-open {
  max-height: 2000px; /* large enough for any submenu */
  overflow: hidden;
}

/* Inner content wrapper for the sub-panel */
.mob-panel > .mob-group:first-of-type {
  padding-top: 8px;
}
.mob-panel > :last-child {
  padding-bottom: 16px;
}

/* Group title (BY LEAGUE / BY NATION) */
.mob-group {
  padding: 14px 20px 6px;
}
.mob-group__title {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--black-4);
  margin-bottom: 4px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--black-8);
}
.mob-group__list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.mob-group__list li {
  list-style: none;
  border-bottom: 0;
}
.mob-group__link {
  display: block;
  padding: 12px 0;
  font-size: 15px;
  font-weight: 500;
  color: var(--black-1);
  -webkit-tap-highlight-color: rgba(0,0,0,0.04);
}
.mob-group__link:active {
  color: var(--red);
}
.mob-group__link--cta {
  margin-top: 6px;
  padding: 12px 0 8px;
  border-top: 1px solid var(--black-8);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--black-0);
}

/* Featured tile inside accordion */
.mob-feat {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin: 14px 20px 0;
  padding: 18px 20px;
  background: var(--black-0);
  color: var(--white);
  border-radius: 4px;
}
.mob-feat__eyebrow {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--black-7);
}
.mob-feat__h {
  font-size: 18px;
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--white);
}
.mob-feat__cta {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--white);
  margin-top: 6px;
}

/* Promo block inside accordion */
.mob-promo {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 10px 20px 8px;
  padding: 12px 14px;
  background: var(--white);
  border: 1px solid var(--black-8);
  border-radius: 4px;
}
.mob-promo__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  flex-shrink: 0;
  color: var(--black-0);
}
.mob-promo__icon svg {
  width: 20px;
  height: 20px;
}
.mob-promo__copy {
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.mob-promo__h {
  font-size: 12px;
  font-weight: 800;
  color: var(--black-0);
}
.mob-promo__sub {
  font-size: 10px;
  color: var(--black-4);
}

/* ============================================================
   PHASE 3 SECTION 1E — SIMPLE DROPDOWNS (CS / Our Websites)
   ============================================================ */

/* Laptop simple dropdown — tighter, single column, narrower */
.mega-panel--simple {
  left: auto;
  right: auto;
  width: 240px;
  padding: 12px 0;
  border-top: 1px solid var(--black-9);
  border-bottom: 1px solid var(--black-8);
  box-shadow: 0 12px 32px rgba(14, 14, 16, 0.08);
}
.has-mega:has(.mega-panel--simple) {
  position: relative; /* Override the default static for full-width panels */
}
.simple-drop {
  list-style: none;
  margin: 0;
  padding: 0;
}
.simple-drop li {
  list-style: none;
}
.simple-drop__link {
  display: block;
  padding: 10px 22px;
  font-size: 14px;
  font-weight: 500;
  color: var(--black-1);
  letter-spacing: -0.005em;
  transition: background-color 0.12s, color 0.12s, padding-left 0.15s;
}
.simple-drop__link:hover {
  color: var(--red);
  background: var(--black-10);
  padding-left: 26px;
}

/* Mobile simple dropdown — within accordion */
.mob-panel--simple {
  background: var(--black-10);
}
.mob-simple {
  list-style: none;
  margin: 0;
  padding: 6px 0 12px;
}
.mob-simple li {
  list-style: none;
  border-bottom: 0;
}
.mob-simple__link {
  display: block;
  padding: 14px 20px 14px 32px;
  font-size: 15px;
  font-weight: 500;
  color: var(--black-1);
  -webkit-tap-highlight-color: rgba(0,0,0,0.04);
}
.mob-simple__link:active {
  color: var(--red);
}

/* ============================================================
   PHASE 4 — SHOP ARCHIVE PAGE
   ============================================================ */

/* ---------- ARCHIVE PAGE HEADER ---------- */
.archive-head {
  background: var(--white);
  padding: 32px 0 28px;
  border-bottom: 1px solid var(--black-9);
}
.crumb {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: var(--black-5);
  margin-bottom: 18px;
  letter-spacing: 0.02em;
  flex-wrap: wrap;
}
.crumb a:hover { color: var(--red); }
.crumb__sep { color: var(--black-7); }
.crumb__current { color: var(--black-1); font-weight: 600; }

.archive-head__row {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 32px;
}
.archive-head__title {
  font-size: 56px;
  font-weight: 800;
  color: var(--black-0, var(--black));
  letter-spacing: -0.03em;
  line-height: 1.05;
}
.archive-head__meta {
  display: flex;
  flex-direction: column;
  gap: 4px;
  text-align: right;
  font-size: 12px;
  color: var(--black-4);
  flex-shrink: 0;
}
.archive-head__count {
  font-size: 14px;
  font-weight: 600;
  color: var(--black-1);
}
.archive-head__desc {
  margin-top: 14px;
  max-width: 720px;
  color: var(--black-4);
  font-size: 14px;
  line-height: 1.55;
}

/* ---------- TOP TOOLBAR (sort + active filters) ---------- */
.toolbar {
  position: sticky;
  top: 0;
  z-index: 10;
  background: var(--white);
  border-bottom: 1px solid var(--black-9);
  padding: 14px 0;
}
.toolbar__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}
.toolbar__filters {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}
.toolbar__label {
  font-size: 11px;
  color: var(--black-5);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-right: 4px;
}
.pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  background: var(--white);
  border: 1px solid var(--black-9);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  color: var(--black-1);
  letter-spacing: 0.02em;
  transition: border-color 0.15s, background 0.15s;
  cursor: pointer;
  font-family: inherit;
}
.pill:hover { border-color: var(--black-4); }
.pill--active {
  background: var(--black-0, var(--black));
  color: var(--white);
  border-color: var(--black-0, var(--black));
}
.pill__close {
  width: 12px;
  height: 12px;
  opacity: 0.7;
}
.pill__chev {
  width: 8px;
  height: 5px;
  opacity: 0.6;
}

.toolbar__sort {
  display: flex;
  align-items: center;
  gap: 8px;
}
.sort-select {
  font-size: 12px;
  font-weight: 600;
  color: var(--black-1);
  background: var(--white);
  border: 1px solid var(--black-9);
  border-radius: 4px;
  padding: 8px 32px 8px 14px;
  letter-spacing: 0.02em;
  cursor: pointer;
  appearance: none;
  font-family: inherit;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6' fill='none'><path d='M1 1l4 4 4-4' stroke='%231A1A1D' stroke-width='1.5' stroke-linecap='round'/></svg>");
  background-repeat: no-repeat;
  background-position: right 12px center;
}

/* ---------- MAIN GRID LAYOUT ---------- */
.archive-main { padding: 32px 0 80px; }
.archive-main__grid {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 40px;
}

/* ---------- SIDEBAR ---------- */
.sidebar {
  position: sticky;
  top: 78px;
  align-self: start;
  max-height: calc(100vh - 100px);
  overflow-y: auto;
}
.filter-group {
  border-bottom: 1px solid var(--black-9);
  padding: 18px 0;
}
.filter-group:first-child { padding-top: 0; }
.filter-group__title {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--black-1);
  margin-bottom: 14px;
  cursor: pointer;
  background: transparent;
  border: 0;
  font-family: inherit;
  padding: 0;
}
.filter-group__title svg {
  width: 12px;
  height: 7px;
  transition: transform 0.2s;
  flex-shrink: 0;
}
.filter-group__title[aria-expanded="false"] svg {
  transform: rotate(-90deg);
}
.filter-group__title[aria-expanded="false"] + .filter-list,
.filter-group__title[aria-expanded="false"] + .size-grid,
.filter-group__title[aria-expanded="false"] + .price-range {
  display: none;
}

.filter-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: 240px;
  overflow-y: auto;
  padding-right: 8px;
}
.filter-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  color: var(--black-1);
  cursor: pointer;
  text-decoration: none;
  transition: color 0.12s;
}
.filter-item:hover { color: var(--red); }
.filter-item__check {
  width: 16px;
  height: 16px;
  border: 1.5px solid var(--black-7);
  border-radius: 3px;
  flex-shrink: 0;
  position: relative;
}
.filter-item--checked .filter-item__check {
  background: var(--black-0, var(--black));
  border-color: var(--black-0, var(--black));
}
.filter-item--checked .filter-item__check::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 5px;
  width: 4px;
  height: 7px;
  border-right: 2px solid var(--white);
  border-bottom: 2px solid var(--white);
  transform: rotate(45deg);
}
.filter-item__count {
  margin-left: auto;
  color: var(--black-5);
  font-size: 12px;
}

/* Size grid — special filter */
.size-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
}
.size-btn {
  padding: 8px 0;
  border: 1px solid var(--black-9);
  font-size: 12px;
  font-weight: 600;
  background: var(--white);
  text-align: center;
  border-radius: 3px;
  text-decoration: none;
  color: var(--black-1);
  display: block;
}
.size-btn:hover { border-color: var(--black-4); }
.size-btn--active {
  background: var(--black-0, var(--black));
  color: var(--white);
  border-color: var(--black-0, var(--black));
}

/* Price range filter */
.price-range {
  display: flex;
  align-items: center;
  gap: 8px;
}
.price-input {
  flex: 1;
  width: 100%;
  border: 1px solid var(--black-9);
  border-radius: 3px;
  padding: 8px 10px;
  font-size: 13px;
  font-family: inherit;
  font-weight: 600;
  color: var(--black-1);
  min-width: 0;
}
.price-input:focus {
  outline: none;
  border-color: var(--black-0, var(--black));
}
.price-dash { color: var(--black-5); }
.price-go {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: var(--black-0, var(--black));
  color: var(--white);
  padding: 8px 14px;
  border-radius: 3px;
  border: 0;
  cursor: pointer;
  font-family: inherit;
}

/* Filter actions at bottom */
.filter-actions {
  display: flex;
  gap: 8px;
  padding: 18px 0 0;
  margin-top: 8px;
}
.filter-clear {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--black-4);
  padding: 10px 14px;
  border: 1px solid var(--black-9);
  border-radius: 3px;
  text-decoration: none;
  display: inline-block;
  width: 100%;
  text-align: center;
}
.filter-clear:hover {
  color: var(--black-0, var(--black));
  border-color: var(--black-4);
}

/* ---------- PRODUCT GRID OVERRIDES ---------- */
.archive-main .products {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.archive-main .products li.product {
  list-style: none;
}

/* ---------- EMPTY STATE ---------- */
.archive-empty {
  text-align: center;
  padding: 80px 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}
.archive-empty svg {
  width: 56px;
  height: 56px;
  color: var(--black-7);
}
.archive-empty h2 {
  font-size: 22px;
  font-weight: 800;
  color: var(--black-0, var(--black));
}
.archive-empty p {
  color: var(--black-4);
  font-size: 14px;
}
.btn-clear-all {
  margin-top: 12px;
  background: var(--black-0, var(--black));
  color: var(--white);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 12px 24px;
  border-radius: 3px;
  text-decoration: none;
}

/* ---------- PAGINATION ---------- */
.woocommerce-pagination,
.archive-main .pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 6px;
  margin-top: 56px;
  list-style: none;
  padding: 0;
}
.woocommerce-pagination ul.page-numbers {
  display: flex;
  gap: 6px;
  list-style: none;
  margin: 0;
  padding: 0;
  justify-content: center;
  width: 100%;
  border: 0;
}
.woocommerce-pagination ul.page-numbers li {
  list-style: none;
  border: 0;
}
.woocommerce-pagination .page-numbers,
.archive-main .pagination__btn {
  min-width: 40px;
  height: 40px;
  padding: 0 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 700;
  color: var(--black-1);
  background: var(--white);
  border: 1px solid var(--black-9);
  border-radius: 3px;
  letter-spacing: 0.02em;
  text-decoration: none;
}
.woocommerce-pagination .page-numbers:hover {
  border-color: var(--black-4);
}
.woocommerce-pagination .page-numbers.current {
  background: var(--black-0, var(--black));
  color: var(--white);
  border-color: var(--black-0, var(--black));
}
.woocommerce-pagination .page-numbers.dots {
  border: 0;
  cursor: default;
  color: var(--black-5);
}

/* ---------- MOBILE FILTER BUTTON (in toolbar) ---------- */
.mobile-filter-btn {
  display: none;
  align-items: center;
  gap: 6px;
  background: var(--black-0, var(--black));
  color: var(--white);
  padding: 8px 16px;
  border-radius: 3px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border: 0;
  cursor: pointer;
  font-family: inherit;
}
.mobile-filter-btn svg { width: 12px; height: 12px; }
.mobile-filter-btn__count { opacity: 0.85; }

/* ---------- MOBILE STICKY BAR (bottom) ---------- */
.mobile-sticky {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--white);
  border-top: 1px solid var(--black-9);
  padding: 12px 16px;
  gap: 8px;
  z-index: 50;
  box-shadow: 0 -4px 16px rgba(0,0,0,0.04);
}
.mobile-sticky button {
  flex: 1;
  padding: 12px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-radius: 4px;
  border: 0;
  cursor: pointer;
  font-family: inherit;
}
.mobile-sticky__filter {
  background: var(--black-0, var(--black));
  color: var(--white);
}
.mobile-sticky__sort {
  background: var(--white);
  color: var(--black-0, var(--black));
  border: 1px solid var(--black-9);
}

/* ---------- MOBILE FILTER DRAWER ---------- */
.mobile-drawer {
  display: none;
  position: fixed;
  inset: 0;
  background: var(--white);
  z-index: 200;
  flex-direction: column;
}
.mobile-drawer.is-open {
  display: flex;
}
.mobile-drawer__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 18px 20px;
  border-bottom: 1px solid var(--black-9);
}
.mobile-drawer__title {
  font-size: 18px;
  font-weight: 800;
  letter-spacing: -0.01em;
}
.mobile-drawer__close {
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--black-10);
  border: 0;
  cursor: pointer;
}
.mobile-drawer__body {
  flex: 1;
  overflow-y: auto;
  padding: 20px;
}
.mobile-drawer__body .sidebar {
  position: static;
  max-height: none;
  overflow: visible;
}
.mobile-drawer__foot {
  display: flex;
  gap: 8px;
  padding: 16px 20px;
  border-top: 1px solid var(--black-9);
  background: var(--white);
}
.mobile-drawer__foot a,
.mobile-drawer__foot button {
  flex: 1;
  padding: 14px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-radius: 4px;
  border: 0;
  cursor: pointer;
  font-family: inherit;
  text-align: center;
  text-decoration: none;
}
.mobile-drawer__clear {
  background: var(--white);
  color: var(--black-0, var(--black));
  border: 1px solid var(--black-9) !important;
}
.mobile-drawer__apply {
  background: var(--black-0, var(--black));
  color: var(--white);
}

/* ---------- MOBILE OVERRIDES ---------- */
@media (max-width: 1023px) {
  .archive-head { padding: 22px 0 18px; }
  .archive-head__title { font-size: 32px; line-height: 1.1; }
  .archive-head__row { flex-direction: column; align-items: flex-start; gap: 10px; }
  .archive-head__meta { text-align: left; flex-direction: row; gap: 12px; }
  .archive-head__desc { font-size: 13px; margin-top: 10px; }

  .toolbar { display: none; }
  .sidebar { display: none; }

  .archive-main__grid { grid-template-columns: 1fr; gap: 0; }
  .archive-main { padding: 18px 0 96px; }

  .archive-main .products { grid-template-columns: repeat(2, 1fr); gap: 14px; }

  .mobile-sticky { display: flex; }

  .woocommerce-pagination { margin-top: 32px; gap: 4px; flex-wrap: wrap; }
  .woocommerce-pagination .page-numbers {
    min-width: 36px; height: 36px; font-size: 12px;
  }
}

@media (min-width: 1024px) {
  .mobile-filter-btn { display: none !important; }
}

/* ============================================================
   PHASE 4 — WOOCOMMERCE OVERRIDES
   ============================================================ */

/* Reset WC default product loop ul to use our grid */
.woocommerce ul.products,
ul.products {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.woocommerce ul.products li.product,
ul.products li.product {
  list-style: none;
  width: auto !important;
  float: none !important;
  margin: 0 !important;
  clear: none !important;
  padding: 0;
  display: flex;
  flex-direction: column;
}

/* WC default card structure */
.woocommerce ul.products li.product a img,
ul.products li.product a img {
  width: 100%;
  aspect-ratio: 4/5;
  object-fit: cover;
  background: var(--black-10);
  margin-bottom: 12px;
  display: block;
}

/* Title — WC uses h2.woocommerce-loop-product__title */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
ul.products li.product .woocommerce-loop-product__title {
  font-size: 14px;
  font-weight: 700;
  color: var(--black-1) !important;
  letter-spacing: -0.005em;
  line-height: 1.3;
  margin: 0 0 6px 0;
  padding: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.woocommerce ul.products li.product a .woocommerce-loop-product__title {
  color: var(--black-1) !important;
}
.woocommerce ul.products li.product a:hover .woocommerce-loop-product__title {
  color: var(--red) !important;
}

/* Price — WC uses span.price */
.woocommerce ul.products li.product .price,
ul.products li.product .price {
  font-size: 14px;
  font-weight: 800;
  color: var(--black-0, var(--black));
  margin: 4px 0 0 0;
  display: block;
}
.woocommerce ul.products li.product .price del {
  font-size: 12px;
  color: var(--black-6);
  font-weight: 500;
  margin-right: 6px;
}
.woocommerce ul.products li.product .price ins {
  text-decoration: none;
  color: var(--black-0, var(--black));
}

/* Star rating */
.woocommerce ul.products li.product .star-rating,
ul.products li.product .star-rating {
  display: inline-block;
  width: 80px;
  height: 14px;
  margin: 4px 0;
  font-size: 12px;
  color: var(--gold, #C29B3D);
}

/* Add to cart button on hover */
.woocommerce ul.products li.product .button,
ul.products li.product .button {
  margin-top: 8px;
  background: var(--black-0, var(--black)) !important;
  color: var(--white) !important;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 10px 14px;
  border-radius: 3px;
  border: 0;
  text-align: center;
  display: inline-block;
  width: auto !important;
  text-decoration: none;
  align-self: flex-start;
}
.woocommerce ul.products li.product .button:hover {
  background: var(--red) !important;
}
.woocommerce ul.products li.product .added_to_cart {
  display: none;
}

/* Sale flash badge */
.woocommerce ul.products li.product .onsale,
ul.products li.product .onsale {
  position: absolute;
  top: 12px;
  left: 12px;
  background: var(--red);
  color: var(--white);
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 0;
  z-index: 2;
  margin: 0;
  line-height: 1;
}
.woocommerce ul.products li.product {
  position: relative;
}

/* Hide default WC catalog ordering / result count above grid */
.woocommerce-result-count,
.woocommerce-ordering {
  display: none !important;
}

/* Hide default WC notice/breadcrumb if any leak through */
.woocommerce-breadcrumb {
  display: none;
}

/* Mobile: 2 columns */
@media (max-width: 1023px) {
  .woocommerce ul.products,
  ul.products {
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
  }
  .woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-size: 12px;
  }
  .woocommerce ul.products li.product .price {
    font-size: 13px;
  }
}

/* ============================================================
   PHASE 4 — COLOR FIX: Force black product titles + grid layout
   ============================================================ */
.archive-main a,
.archive-main a:link,
.archive-main a:visited {
  color: var(--black-1) !important;
  text-decoration: none;
}
.archive-main a:hover,
.archive-main a:hover .woocommerce-loop-product__title {
  color: var(--red) !important;
}
.archive-main .woocommerce-loop-product__title {
  color: var(--black-1) !important;
}
.archive-main .price,
.archive-main .price .woocommerce-Price-amount {
  color: var(--black-0, var(--black)) !important;
}

/* Force grid layout on the products container */
.archive-main ul.products,
.archive-main .products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 24px !important;
  list-style: none;
  margin: 0;
  padding: 0;
}
.archive-main .products li.product,
.archive-main .products .product {
  list-style: none;
  width: auto !important;
  float: none !important;
  margin: 0 !important;
  display: flex;
  flex-direction: column;
  position: relative;
}
.archive-main .products li.product img {
  width: 100%;
  aspect-ratio: 4/5;
  object-fit: cover;
  background: var(--black-10);
  margin-bottom: 12px;
  display: block;
}
.archive-main .products .button {
  margin-top: auto;
  align-self: flex-start;
  background: var(--black-0, var(--black)) !important;
  color: var(--white) !important;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 10px 14px;
  border-radius: 3px;
  text-decoration: none;
}
.archive-main .products .button:hover {
  background: var(--red) !important;
  color: var(--white) !important;
}
@media (max-width: 1023px) {
  .archive-main ul.products,
  .archive-main .products {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 14px !important;
  }
}

/* ============================================================
   PHASE 4 — POLISH: hide dots, refine title/price, mobile sticky
   ============================================================ */

/* 1. Hide the green dot — likely first-letter or list-style marker */
.archive-main .products li.product::marker,
.archive-main .products .product::marker {
  content: none !important;
  display: none !important;
}
.archive-main .products li.product::before,
.archive-main .products .product::before {
  content: none !important;
  display: none !important;
}
.archive-main .products li {
  list-style: none !important;
}

/* 2. Refine title styling */
.archive-main .products .woocommerce-loop-product__title {
  font-size: 13px !important;
  font-weight: 600 !important;
  letter-spacing: -0.005em !important;
  line-height: 1.35 !important;
  color: var(--black-1) !important;
  margin: 12px 0 6px 0 !important;
  padding: 0 !important;
  display: block !important;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
}

/* 3. Hide WooCommerce default screen-reader / star-rating text noise */
.archive-main .products .star-rating {
  display: none !important;
}
.archive-main .products .screen-reader-text {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip: rect(0,0,0,0) !important;
}

/* 4. Refine price */
.archive-main .products .price {
  font-size: 14px !important;
  font-weight: 800 !important;
  color: var(--black-0, var(--black)) !important;
  margin: 4px 0 12px 0 !important;
  display: block !important;
  letter-spacing: -0.01em !important;
}
.archive-main .products .price del {
  font-size: 12px;
  color: var(--black-6);
  font-weight: 500;
  margin-right: 6px;
  text-decoration: line-through;
}
.archive-main .products .price ins {
  text-decoration: none;
  color: var(--red);
}
.archive-main .products .woocommerce-Price-amount {
  color: inherit !important;
}
.archive-main .products .woocommerce-Price-currencySymbol {
  color: inherit !important;
}

/* 5. Refine Select Options button */
.archive-main .products .button {
  font-size: 10px !important;
  padding: 9px 14px !important;
  letter-spacing: 0.08em !important;
}

/* 6. Force the mobile sticky bar to show on mobile */
.mobile-sticky {
  display: none;
}
@media (max-width: 1023px) {
  .mobile-sticky {
    display: flex !important;
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    background: var(--white);
    border-top: 1px solid var(--black-9);
    padding: 12px 16px;
    gap: 8px;
    z-index: 50;
    box-shadow: 0 -4px 16px rgba(0,0,0,0.04);
  }
  .mobile-sticky button {
    flex: 1;
    padding: 12px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    border-radius: 4px;
    border: 0;
    cursor: pointer;
    font-family: inherit;
  }
  .mobile-sticky__filter {
    background: var(--black-0, var(--black));
    color: var(--white);
  }
  .mobile-sticky__sort {
    background: var(--white);
    color: var(--black-0, var(--black));
    border: 1px solid var(--black-9);
  }

  /* Make sure mobile-only stuff shows / hides correctly */
  .archive-main__grid {
    grid-template-columns: 1fr !important;
  }
  .sidebar {
    display: none !important;
  }
  .toolbar {
    display: none !important;
  }
  .archive-main {
    padding-bottom: 96px !important; /* clear space for sticky bar */
  }
}

/* Mobile drawer working state */
.mobile-drawer {
  display: none;
  position: fixed;
  inset: 0;
  background: var(--white);
  z-index: 200;
  flex-direction: column;
}
.mobile-drawer.is-open {
  display: flex !important;
}
@media (min-width: 1024px) {
  .mobile-drawer,
  .mobile-sticky {
    display: none !important;
  }
}

/* ============================================================
   PHASE 4 — POSITION FILTER BAR ABOVE EXISTING .sticky-bar
   ============================================================ */
@media (max-width: 1023px) {
  .mobile-sticky {
    bottom: 64px !important;
    z-index: 49 !important;
    border-bottom: 1px solid var(--black-9);
    padding: 10px 16px !important;
  }
  .mobile-sticky button {
    padding: 10px !important;
    font-size: 11px !important;
  }
  .archive-main {
    padding-bottom: 160px !important;
  }
  .mobile-drawer {
    z-index: 999 !important;
  }
}

/* ============================================================
   PHASE 4 — PAGE HEADER POLISH
   ============================================================ */

/* Tighten archive header — put title first, description below in single column */
.archive-head {
  padding: 28px 0 24px !important;
}
.archive-head__row {
  display: block !important; /* No more side-by-side column */
}
.archive-head__title {
  font-size: 44px !important;
  font-weight: 800 !important;
  letter-spacing: -0.025em !important;
  line-height: 1.05 !important;
  margin: 0 0 14px 0 !important;
}
.archive-head__desc {
  max-width: 720px !important;
  margin-top: 0 !important;
  font-size: 13px !important;
  line-height: 1.55 !important;
  color: var(--black-3, var(--black-4)) !important;
}
.archive-head__desc p {
  margin: 0 0 8px 0 !important;
  padding: 0 !important;
}
.archive-head__desc p:last-child {
  margin-bottom: 0 !important;
}
.archive-head__desc strong {
  color: var(--black-1) !important;
  font-weight: 700;
}
.archive-head__desc em {
  display: block;
  margin-top: 14px !important;
  font-style: italic;
  color: var(--black-5);
  font-size: 12px;
}

/* Hide the floating product count + USP block — redundant info */
.archive-head__meta {
  display: none !important;
}

/* Remove crumb bottom margin — tighter header */
.crumb {
  margin-bottom: 14px !important;
  font-size: 12px !important;
}

/* Mobile-specific tightening */
@media (max-width: 1023px) {
  .archive-head {
    padding: 18px 0 14px !important;
  }
  .archive-head__title {
    font-size: 28px !important;
    letter-spacing: -0.02em !important;
    margin-bottom: 10px !important;
  }
  .archive-head__desc {
    font-size: 12px !important;
    line-height: 1.5 !important;
  }
  .archive-head__desc em {
    font-size: 11px;
  }
}

/* ============================================================
   PHASE 4 — RESTORE META BLOCK (count + tagline) ON RIGHT
   ============================================================ */
.archive-head__row {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-end !important;
  gap: 32px;
}
.archive-head__row > div:first-child {
  flex: 1;
  min-width: 0;
}
.archive-head__meta {
  display: flex !important;
  flex-direction: column !important;
  text-align: right !important;
  flex-shrink: 0;
  gap: 4px;
  font-size: 12px;
  color: var(--black-4);
}
.archive-head__count {
  font-size: 18px !important;
  font-weight: 800 !important;
  color: var(--black-1) !important;
  letter-spacing: -0.01em;
}
@media (max-width: 1023px) {
  .archive-head__row {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 12px !important;
  }
  .archive-head__meta {
    text-align: left !important;
    flex-direction: row !important;
    gap: 12px !important;
    align-items: baseline;
  }
  .archive-head__count {
    font-size: 14px !important;
  }
}

/* ============================================================
   SALE MANAGER — banner + product hint
   ============================================================ */
.trk-sale-banner {
  background: var(--red);
  color: var(--white);
  text-align: center;
  padding: 8px 16px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
}
.trk-sale-banner strong { letter-spacing: 0.1em; }
.trk-sale-banner__star {
  color: var(--gold);
  margin-right: 4px;
}
.trk-sale-hint {
  display: flex; align-items: flex-start; gap: 10px;
  background: linear-gradient(135deg, #FFF6E5 0%, #FFE5E5 100%);
  border: 1px solid #FFD08C;
  border-radius: 6px;
  padding: 12px 14px;
  margin: 16px 0;
  font-size: 12px;
  line-height: 1.5;
}
.trk-sale-hint svg { color: var(--red); flex-shrink: 0; margin-top: 2px; }
.trk-sale-hint strong {
  font-weight: 800; color: var(--black-0);
  margin-right: 4px;
}


/* ============================================================
   PHASE 5 — SINGLE PRODUCT PAGE
   ============================================================ */

/* ===== PRODUCT TOP SECTION ===== */
.product-top {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: 56px;
  padding: 0 0 56px;
}

/* ===== GALLERY ===== */
.gallery { position: sticky; top: 24px; align-self: start; }
.gallery__main {
  background: var(--black-10);
  aspect-ratio: 4/5;
  border-radius: 6px;
  position: relative;
  overflow: hidden;
  margin-bottom: 12px;
}
.gallery__main img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.gallery__placeholder {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  color: var(--black-6); font-size: 13px;
}
.gallery__badge {
  position: absolute; top: 16px; left: 16px;
  background: var(--gold, #C29B3D); color: var(--white);
  font-size: 10px; font-weight: 800;
  padding: 5px 10px; letter-spacing: 0.14em;
  text-transform: uppercase; border-radius: 2px;
  z-index: 2;
}
.gallery__nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 40px; height: 40px;
  background: rgba(255,255,255,0.92);
  border: 0; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
  cursor: pointer; z-index: 2;
}
.gallery__nav--prev { left: 12px; }
.gallery__nav--next { right: 12px; }
.gallery__thumbs {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px;
}
.gallery__thumb {
  aspect-ratio: 1; background: var(--black-10);
  border: 2px solid transparent; border-radius: 4px;
  overflow: hidden; cursor: pointer; padding: 0;
  display: flex; align-items: center; justify-content: center;
}
.gallery__thumb img { width: 100%; height: 100%; object-fit: cover; }
.gallery__thumb--active { border-color: var(--black-0, var(--black)); }

/* ===== INFO COLUMN ===== */
.info { display: flex; flex-direction: column; }
.info__brand {
  font-size: 11px; font-weight: 700; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--black-5); margin-bottom: 8px;
}
.info__title {
  font-size: 32px; font-weight: 800; letter-spacing: -0.02em;
  line-height: 1.15; margin-bottom: 12px;
}
.info__rating {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 16px; font-size: 13px;
}
.stars { display: inline-flex; gap: 2px; color: var(--gold, #C29B3D); }
.info__rating-text { color: var(--black-4); font-size: 12px; }
.info__rating-text a { text-decoration: underline; color: inherit; }

.info__price-row {
  display: flex; align-items: baseline; gap: 12px;
  margin-bottom: 16px;
}
.info__price {
  font-size: 28px; font-weight: 800; color: var(--black-0, var(--black));
  letter-spacing: -0.01em;
}
.info__price del {
  font-size: 16px; color: var(--black-6); font-weight: 500; margin-right: 8px;
}
.info__price ins { text-decoration: none; color: var(--black-0, var(--black)); }
.info__price .woocommerce-Price-amount { font-size: inherit; font-weight: inherit; color: inherit; }

.info__bogo-hint {
  background: linear-gradient(135deg, #FFF6E5 0%, #FFE5E5 100%);
  border: 1px solid #FFD08C;
  padding: 10px 12px;
  border-radius: 6px;
  font-size: 12px;
  margin-bottom: 22px;
  line-height: 1.45;
}
.info__bogo-hint strong { color: var(--red); margin-right: 4px; }

/* ===== SIZE BLOCK ===== */
.size-block { margin-bottom: 22px; }
.size-block__head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 10px;
}
.size-block__label {
  font-size: 12px; font-weight: 700; letter-spacing: 0.1em;
  text-transform: uppercase;
}
.size-guide-trigger {
  font-size: 12px; font-weight: 600; text-decoration: underline;
  color: var(--black-1); display: inline-flex; align-items: center; gap: 6px;
  background: transparent; border: 0; cursor: pointer; padding: 0;
}
.size-guide-trigger svg { width: 14px; height: 14px; }
.size-grid {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px;
}
.size-btn {
  padding: 11px 0; font-size: 13px; font-weight: 600;
  background: var(--white); border: 1px solid var(--black-9);
  border-radius: 4px; text-align: center; cursor: pointer;
  text-transform: uppercase;
  transition: border-color 0.15s, background 0.15s;
}
.size-btn:hover:not(:disabled) { border-color: var(--black-3); }
.size-btn--active {
  background: var(--black-0, var(--black)); color: var(--white);
  border-color: var(--black-0, var(--black));
}
.size-btn--unavailable {
  color: var(--black-7); position: relative; cursor: not-allowed;
}
.size-btn--unavailable::after {
  content: ''; position: absolute; left: 8px; right: 8px; top: 50%;
  border-top: 1px solid var(--black-7); transform: rotate(-12deg);
}

/* ===== ADDONS ===== */
.addons {
  background: var(--black-10); padding: 16px; border-radius: 6px;
  margin-bottom: 22px;
}
.addons__head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 14px; padding-bottom: 12px;
  border-bottom: 1px solid var(--black-9);
}
.addons__title { font-size: 13px; font-weight: 700; letter-spacing: 0.04em; }
.addons__sub { font-size: 11px; color: var(--black-5); font-weight: 600; }
.addon {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--black-9);
  cursor: pointer;
}
.addon:last-child { border-bottom: 0; padding-bottom: 0; }
.addon__check {
  width: 18px; height: 18px;
  border: 1.5px solid var(--black-7);
  border-radius: 3px;
  flex-shrink: 0; margin-top: 2px;
  position: relative;
}
.addon--checked .addon__check {
  background: var(--black-0, var(--black)); border-color: var(--black-0, var(--black));
}
.addon--checked .addon__check::after {
  content: ''; position: absolute; top: 2px; left: 5px;
  width: 4px; height: 8px;
  border-right: 2px solid var(--white);
  border-bottom: 2px solid var(--white);
  transform: rotate(45deg);
}
.addon__body { flex: 1; min-width: 0; }
.addon__row1 {
  display: flex; justify-content: space-between; align-items: baseline;
  gap: 12px;
}
.addon__name { font-size: 13px; font-weight: 700; }
.addon__price { font-size: 12px; font-weight: 700; flex-shrink: 0; }
.addon__price--free {
  color: #2E7D32;
}
.addon__price--free .price-old {
  color: var(--black-6); text-decoration: line-through; font-weight: 500;
  margin-right: 4px; font-size: 11px;
}
.addon__hint {
  font-size: 11px; color: var(--black-5); margin-top: 2px;
}
.addon__input {
  margin-top: 8px; width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--black-9);
  border-radius: 3px;
  font-size: 13px; font-family: inherit;
  display: none;
}
.addon--checked .addon__input { display: block; }

/* ===== BUY ROW ===== */
.buy-row { display: flex; gap: 10px; margin-bottom: 10px; }
.qty {
  display: inline-flex; align-items: center;
  border: 1px solid var(--black-9); border-radius: 4px;
  overflow: hidden; flex-shrink: 0;
}
.qty__btn {
  width: 44px; height: 50px; font-size: 18px;
  color: var(--black-3); background: var(--white);
  border: 0; cursor: pointer;
}
.qty__btn:hover { background: var(--black-10); }
.qty__num {
  width: 44px; text-align: center; font-size: 14px; font-weight: 700;
  border: 0; outline: 0; height: 50px; background: var(--white);
}
.add-to-cart {
  flex: 1; height: 50px;
  background: var(--black-0, var(--black)); color: var(--white);
  font-size: 13px; font-weight: 800; letter-spacing: 0.08em;
  text-transform: uppercase; border: 0; border-radius: 4px;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  cursor: pointer; transition: background 0.18s;
}
.add-to-cart:hover { background: var(--red); }
.buy-now {
  width: 100%; height: 50px; margin-bottom: 16px;
  background: var(--white); color: var(--black-0, var(--black));
  border: 1.5px solid var(--black-0, var(--black));
  font-size: 13px; font-weight: 800; letter-spacing: 0.08em;
  text-transform: uppercase; border-radius: 4px; cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  transition: background 0.18s, color 0.18s, border-color 0.18s;
}
.buy-now:hover {
  background: var(--red); color: var(--white); border-color: var(--red);
}

/* ===== TRUST BADGES (4 in 2x2) ===== */
.trust {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px;
  margin-bottom: 16px;
}
.trust__item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; background: var(--black-10);
  border-radius: 4px;
}
.trust__icon { width: 18px; height: 18px; flex-shrink: 0; }
.trust__label { font-size: 11px; font-weight: 700; letter-spacing: 0.04em; line-height: 1.2; }

/* ===== TABS BLOCK ===== */
.tabs-block { padding: 56px 0; border-top: 1px solid var(--black-9); }
.tabs__nav { display: flex; gap: 0; border-bottom: 1px solid var(--black-9); margin-bottom: 28px; }
.tabs__btn {
  padding: 14px 0; margin-right: 32px;
  font-size: 13px; font-weight: 700; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--black-4);
  border: 0; border-bottom: 2px solid transparent;
  background: transparent; cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
}
.tabs__btn--active { color: var(--black-0, var(--black)); border-bottom-color: var(--black-0, var(--black)); }
.tabs__panel {
  max-width: 760px;
  font-size: 14px; line-height: 1.65; color: var(--black-3);
}
.tabs__panel-text p { margin-bottom: 14px; }
.tabs__panel h3 {
  font-size: 14px; font-weight: 800; letter-spacing: 0.04em;
  text-transform: uppercase; margin: 22px 0 12px;
  color: var(--black-1);
}
.auto-tag {
  display: inline-block; font-size: 9px; font-weight: 700;
  color: var(--black-5); letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 3px 7px; background: var(--black-10);
  border-radius: 3px; margin-left: 8px; vertical-align: middle;
}
.specs {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px 32px;
  padding: 16px 0; border-top: 1px solid var(--black-9);
  border-bottom: 1px solid var(--black-9); margin: 14px 0 24px;
}
.spec { display: flex; justify-content: space-between; padding: 4px 0; font-size: 13px; }
.spec__key { color: var(--black-4); font-weight: 600; }
.spec__val { color: var(--black-1); font-weight: 700; }

/* ===== ACCORDION (mobile) ===== */
.accordion { display: none; }
.accordion__item { border-bottom: 1px solid var(--black-9); }
.accordion__head {
  display: flex; justify-content: space-between; align-items: center;
  width: 100%; padding: 18px 0;
  font-size: 13px; font-weight: 700; letter-spacing: 0.06em;
  text-transform: uppercase;
  background: transparent; border: 0; cursor: pointer;
}
.accordion__head svg { width: 14px; height: 14px; transition: transform 0.2s; }
.accordion__item--open .accordion__head svg { transform: rotate(180deg); }
.accordion__panel {
  display: none; padding: 0 0 18px;
  font-size: 14px; line-height: 1.6; color: var(--black-3);
}
.accordion__item--open .accordion__panel { display: block; }

/* ===== UPSELL: COMPLETE THE KIT ===== */
.upsell { background: var(--black-10); padding: 56px 0; }
.section-title {
  font-size: 28px; font-weight: 800; letter-spacing: -0.015em;
  margin-bottom: 8px;
}
.section-sub {
  font-size: 13px; color: var(--black-4); margin-bottom: 28px;
}
.upsell__grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
  margin-bottom: 24px;
}
.upsell-card {
  background: var(--white); padding: 16px;
  border-radius: 8px;
  display: flex; flex-direction: column; gap: 12px;
}
.upsell-card__media {
  aspect-ratio: 4/3; background: var(--black-10);
  border-radius: 6px; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  color: var(--black-6); font-size: 11px;
}
.upsell-card__media img { width: 100%; height: 100%; object-fit: cover; }
.upsell-card__body { display: flex; flex-direction: column; flex: 1; }
.upsell-card__title {
  font-size: 14px; font-weight: 800; line-height: 1.3;
  margin: 0 0 4px;
}
.upsell-card__title a { color: inherit; text-decoration: none; }
.upsell-card__title a:hover { color: var(--red); }
.upsell-card__price-row {
  display: flex; gap: 8px; align-items: baseline;
  margin: 0 0 12px; flex-wrap: wrap;
}
.upsell-card__bundle { font-size: 16px; font-weight: 800; color: var(--black-1); }
.upsell-card__bundle .woocommerce-Price-amount { font-size: inherit; }
.upsell-card__bundle-old {
  font-size: 12px; color: var(--black-6); text-decoration: line-through;
}
.upsell-card__bundle-old .woocommerce-Price-amount { font-size: inherit; }
.upsell-card__save {
  font-size: 10px; font-weight: 800; color: #2E7D32;
  background: rgba(46,125,50,0.1); padding: 3px 7px; border-radius: 3px;
  letter-spacing: 0.04em;
}
.upsell-card__save .woocommerce-Price-amount { font-size: inherit; }
.upsell-card__btn {
  background: var(--black-0, var(--black)); color: var(--white);
  padding: 10px 16px; font-size: 11px; font-weight: 800;
  letter-spacing: 0.08em; text-transform: uppercase; border: 0; border-radius: 4px;
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  cursor: pointer; width: 100%;
  transition: background 0.18s;
}
.upsell-card__btn:hover { background: var(--red); }

.upsell__bundle-cta {
  background: var(--white); border: 2px solid var(--black-0, var(--black));
  border-radius: 8px; padding: 18px 22px;
  display: flex; justify-content: space-between; align-items: center;
  gap: 24px; margin-top: 16px;
}
.upsell__bundle-title {
  font-size: 13px; font-weight: 800; letter-spacing: 0.04em;
  text-transform: uppercase; margin-bottom: 4px;
}
.upsell__bundle-line {
  font-size: 12px; color: var(--black-4);
  display: flex; gap: 8px; flex-wrap: wrap; align-items: baseline;
}
.upsell__bundle-was {
  text-decoration: line-through; color: var(--black-6); font-weight: 600;
}
.upsell__bundle-now {
  color: var(--black-0, var(--black)); font-size: 16px; font-weight: 800;
}
.upsell__bundle-btn {
  background: var(--black-0, var(--black)); color: var(--white);
  padding: 12px 22px; font-size: 12px; font-weight: 800;
  letter-spacing: 0.08em; text-transform: uppercase; border: 0; border-radius: 4px;
  display: inline-flex; align-items: center; gap: 8px;
  flex-shrink: 0; cursor: pointer; transition: background 0.18s;
}
.upsell__bundle-btn:hover { background: var(--red); }

/* ===== REVIEWS ===== */
.reviews { padding: 56px 0; border-top: 1px solid var(--black-9); }
.reviews__header {
  display: flex; justify-content: space-between; align-items: flex-end;
  margin-bottom: 32px; gap: 32px;
}
.reviews__summary { display: flex; align-items: baseline; gap: 12px; }
.reviews__avg {
  font-size: 56px; font-weight: 800; line-height: 1;
  letter-spacing: -0.025em;
}
.reviews__total { font-size: 13px; color: var(--black-4); }
.reviews__write-btn {
  background: var(--black-0, var(--black)); color: var(--white);
  padding: 12px 22px; font-size: 12px; font-weight: 700;
  letter-spacing: 0.08em; text-transform: uppercase; border: 0; border-radius: 4px;
  cursor: pointer;
}

/* ===== MOST LIKED CAROUSEL ===== */
.most-liked { padding: 56px 0; border-top: 1px solid var(--black-9); }
.ml-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  margin-bottom: 28px; gap: 24px;
}
.ml-head__nav { display: flex; gap: 8px; }
.ml-arrow {
  width: 44px; height: 44px;
  background: var(--white);
  border: 1px solid var(--black-9);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}
.ml-arrow:hover { border-color: var(--black-3); background: var(--black-10); }
.ml-arrow:disabled { opacity: 0.4; cursor: not-allowed; }
.ml-carousel {
  display: flex; gap: 16px;
  overflow-x: auto; overflow-y: hidden;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding-bottom: 8px;
}
.ml-carousel::-webkit-scrollbar { display: none; }
.ml-card {
  flex: 0 0 calc((100% - 16px * 3) / 4);
  max-width: calc((100% - 16px * 3) / 4);
  scroll-snap-align: start;
  display: block; text-decoration: none; color: inherit;
}
.ml-card__media {
  aspect-ratio: 4/5; background: var(--black-10);
  border-radius: 4px; margin-bottom: 12px; position: relative;
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  color: var(--black-6); font-size: 11px;
}
.ml-card__media img { width: 100%; height: 100%; object-fit: cover; }
.ml-card__badge {
  position: absolute; top: 10px; left: 10px;
  background: var(--gold, #C29B3D); color: var(--white);
  font-size: 9px; font-weight: 800; padding: 3px 7px;
  letter-spacing: 0.1em; text-transform: uppercase;
}
.ml-card__title {
  font-size: 13px; font-weight: 600; line-height: 1.35;
  margin-bottom: 4px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
}
.ml-card__price { font-size: 13px; font-weight: 800; }
.ml-card__price .woocommerce-Price-amount { font-size: inherit; }
.ml-dots {
  display: flex; justify-content: center; gap: 6px; margin-top: 18px;
}
.ml-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--black-7); border: 0; padding: 0; cursor: pointer;
  transition: background 0.15s, width 0.15s;
}
.ml-dot--active {
  background: var(--black-0, var(--black));
  width: 24px; border-radius: 3px;
}

/* ===== MOBILE STICKY CTA ===== */
.mobile-cta {
  display: none;
  position: fixed; bottom: 0; left: 0; right: 0;
  background: var(--white); border-top: 1px solid var(--black-9);
  padding: 10px 14px;
  z-index: 100;
  box-shadow: 0 -4px 16px rgba(0,0,0,0.06);
}
.mobile-cta__inner { display: flex; gap: 8px; }
.mobile-cta__add,
.mobile-cta__buy {
  flex: 1; height: 46px;
  font-size: 12px; font-weight: 800;
  letter-spacing: 0.06em; text-transform: uppercase;
  border-radius: 4px; cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 6px;
}
.mobile-cta__add {
  background: var(--white); color: var(--black-0, var(--black));
  border: 1.5px solid var(--black-0, var(--black));
}
.mobile-cta__add svg { width: 12px; height: 12px; }
.mobile-cta__buy {
  background: var(--black-0, var(--black)); color: var(--white);
  border: 0;
}

/* ===== SIZE GUIDE MODAL ===== */
.size-modal {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(15,15,16,0.6);
  display: none; align-items: center; justify-content: center;
  padding: 20px;
}
.size-modal.is-open { display: flex; }
.size-modal__content {
  background: var(--white); border-radius: 8px;
  width: 100%; max-width: 720px; max-height: 92vh;
  overflow-y: auto;
  padding: 32px;
  position: relative;
}
.size-modal__close {
  position: absolute; top: 16px; right: 16px;
  width: 36px; height: 36px;
  background: var(--black-10); border: 0; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
}
.size-modal__title {
  font-size: 20px; font-weight: 800; margin-bottom: 6px;
}
.size-modal__sub {
  font-size: 13px; color: var(--black-4); margin-bottom: 24px;
}
.size-modal__tabs {
  display: flex; gap: 6px; margin-bottom: 20px;
  border-bottom: 1px solid var(--black-9); padding-bottom: 12px;
  flex-wrap: wrap;
}
.size-modal__tab {
  font-size: 11px; font-weight: 700; letter-spacing: 0.06em;
  text-transform: uppercase; padding: 8px 14px; border-radius: 999px;
  background: var(--black-10); color: var(--black-4);
  border: 0; cursor: pointer;
}
.size-modal__tab--active { background: var(--black-0, var(--black)); color: var(--white); }
.size-table {
  width: 100%; border-collapse: collapse;
  font-size: 13px;
}
.size-table th {
  text-align: left; padding: 12px 10px;
  background: var(--black-10);
  font-size: 11px; font-weight: 700; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--black-1);
  border-bottom: 1px solid var(--black-9);
}
.size-table td {
  padding: 12px 10px; border-bottom: 1px solid var(--black-9);
}
.size-table tr:last-child td { border-bottom: 0; }
.size-table td:first-child { font-weight: 700; }
.size-modal__note {
  margin-top: 16px; padding: 12px; background: var(--black-10);
  border-radius: 4px; font-size: 12px; color: var(--black-4); line-height: 1.55;
}
.size-modal__note strong { color: var(--black-1); }

/* ===== MOBILE BREAKPOINT ===== */
@media (max-width: 1023px) {
  .product-top {
    grid-template-columns: 1fr;
    gap: 24px;
    padding: 0 0 32px;
  }
  .gallery { position: static; }
  .gallery__thumbs { grid-template-columns: repeat(5, 1fr); gap: 6px; }
  .info__title { font-size: 22px; }
  .info__price { font-size: 22px; }

  .tabs-block { padding: 32px 0; }
  .tabs__nav { display: none; }
  .accordion { display: block; }
  .tabs__panel:not(.accordion__panel) { display: none !important; }

  .upsell { padding: 32px 0; }
  .upsell__grid {
    grid-template-columns: none;
    display: flex; flex-direction: row; gap: 12px;
    overflow-x: auto; overflow-y: hidden;
    scroll-snap-type: x mandatory;
    padding-bottom: 8px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .upsell__grid::-webkit-scrollbar { display: none; }
  .upsell-card {
    flex: 0 0 78%; max-width: 78%;
    scroll-snap-align: start;
  }
  .upsell__bundle-cta {
    flex-direction: column; align-items: flex-start;
    gap: 14px; padding: 14px 16px;
  }
  .upsell__bundle-btn { width: 100%; justify-content: center; }

  .reviews { padding: 32px 0; }
  .reviews__header { flex-direction: column; align-items: flex-start; gap: 16px; }

  .most-liked { padding: 32px 0; }
  .ml-card {
    flex: 0 0 calc((100% - 12px) / 2);
    max-width: calc((100% - 12px) / 2);
  }
  .ml-head { flex-direction: column; align-items: flex-start; gap: 12px; }
  .ml-head__nav { display: none; }

  .section-title { font-size: 20px; }

  /* Mobile sticky CTA bar — sits ABOVE existing site sticky-bar */
  .mobile-cta {
    display: block;
    bottom: 64px; /* matches existing sticky-bar height */
    z-index: 49;
  }
  /* Ensure last section has bottom padding so mobile-cta + sticky-bar don't cover content */
  .most-liked { padding-bottom: 160px; }
}

@media (min-width: 1024px) {
  .accordion { display: none; }
  .tabs__nav { display: flex; }
}


/* ============================================================
   PHASE 5 — SINGLE PRODUCT PAGE
   ============================================================ */

/* ===== PRODUCT TOP SECTION ===== */
.product-top {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: 56px;
  padding: 0 0 56px;
}

/* ===== GALLERY ===== */
.gallery { position: sticky; top: 24px; align-self: start; }
.gallery__main {
  background: var(--black-10);
  aspect-ratio: 4/5;
  border-radius: 6px;
  position: relative;
  overflow: hidden;
  margin-bottom: 12px;
}
.gallery__main img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.gallery__placeholder {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  color: var(--black-6); font-size: 13px;
}
.gallery__badge {
  position: absolute; top: 16px; left: 16px;
  background: var(--gold, #C29B3D); color: var(--white);
  font-size: 10px; font-weight: 800;
  padding: 5px 10px; letter-spacing: 0.14em;
  text-transform: uppercase; border-radius: 2px;
  z-index: 2;
}
.gallery__nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 40px; height: 40px;
  background: rgba(255,255,255,0.92);
  border: 0; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
  cursor: pointer; z-index: 2;
}
.gallery__nav--prev { left: 12px; }
.gallery__nav--next { right: 12px; }
.gallery__thumbs {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px;
}
.gallery__thumb {
  aspect-ratio: 1; background: var(--black-10);
  border: 2px solid transparent; border-radius: 4px;
  overflow: hidden; cursor: pointer; padding: 0;
  display: flex; align-items: center; justify-content: center;
}
.gallery__thumb img { width: 100%; height: 100%; object-fit: cover; }
.gallery__thumb--active { border-color: var(--black-0, var(--black)); }

/* ===== INFO COLUMN ===== */
.info { display: flex; flex-direction: column; }
.info__brand {
  font-size: 11px; font-weight: 700; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--black-5); margin-bottom: 8px;
}
.info__title {
  font-size: 32px; font-weight: 800; letter-spacing: -0.02em;
  line-height: 1.15; margin-bottom: 12px;
}
.info__rating {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 16px; font-size: 13px;
}
.stars { display: inline-flex; gap: 2px; color: var(--gold, #C29B3D); }
.info__rating-text { color: var(--black-4); font-size: 12px; }
.info__rating-text a { text-decoration: underline; color: inherit; }

.info__price-row {
  display: flex; align-items: baseline; gap: 12px;
  margin-bottom: 16px;
}
.info__price {
  font-size: 28px; font-weight: 800; color: var(--black-0, var(--black));
  letter-spacing: -0.01em;
}
.info__price del {
  font-size: 16px; color: var(--black-6); font-weight: 500; margin-right: 8px;
}
.info__price ins { text-decoration: none; color: var(--black-0, var(--black)); }
.info__price .woocommerce-Price-amount { font-size: inherit; font-weight: inherit; color: inherit; }

.info__bogo-hint {
  background: linear-gradient(135deg, #FFF6E5 0%, #FFE5E5 100%);
  border: 1px solid #FFD08C;
  padding: 10px 12px;
  border-radius: 6px;
  font-size: 12px;
  margin-bottom: 22px;
  line-height: 1.45;
}
.info__bogo-hint strong { color: var(--red); margin-right: 4px; }

/* ===== SIZE BLOCK ===== */
.size-block { margin-bottom: 22px; }
.size-block__head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 10px;
}
.size-block__label {
  font-size: 12px; font-weight: 700; letter-spacing: 0.1em;
  text-transform: uppercase;
}
.size-guide-trigger {
  font-size: 12px; font-weight: 600; text-decoration: underline;
  color: var(--black-1); display: inline-flex; align-items: center; gap: 6px;
  background: transparent; border: 0; cursor: pointer; padding: 0;
}
.size-guide-trigger svg { width: 14px; height: 14px; }
.size-grid {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px;
}
.size-btn {
  padding: 11px 0; font-size: 13px; font-weight: 600;
  background: var(--white); border: 1px solid var(--black-9);
  border-radius: 4px; text-align: center; cursor: pointer;
  text-transform: uppercase;
  transition: border-color 0.15s, background 0.15s;
}
.size-btn:hover:not(:disabled) { border-color: var(--black-3); }
.size-btn--active {
  background: var(--black-0, var(--black)); color: var(--white);
  border-color: var(--black-0, var(--black));
}
.size-btn--unavailable {
  color: var(--black-7); position: relative; cursor: not-allowed;
}
.size-btn--unavailable::after {
  content: ''; position: absolute; left: 8px; right: 8px; top: 50%;
  border-top: 1px solid var(--black-7); transform: rotate(-12deg);
}

/* ===== ADDONS ===== */
.addons {
  background: var(--black-10); padding: 16px; border-radius: 6px;
  margin-bottom: 22px;
}
.addons__head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 14px; padding-bottom: 12px;
  border-bottom: 1px solid var(--black-9);
}
.addons__title { font-size: 13px; font-weight: 700; letter-spacing: 0.04em; }
.addons__sub { font-size: 11px; color: var(--black-5); font-weight: 600; }
.addon {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--black-9);
  cursor: pointer;
}
.addon:last-child { border-bottom: 0; padding-bottom: 0; }
.addon__check {
  width: 18px; height: 18px;
  border: 1.5px solid var(--black-7);
  border-radius: 3px;
  flex-shrink: 0; margin-top: 2px;
  position: relative;
}
.addon--checked .addon__check {
  background: var(--black-0, var(--black)); border-color: var(--black-0, var(--black));
}
.addon--checked .addon__check::after {
  content: ''; position: absolute; top: 2px; left: 5px;
  width: 4px; height: 8px;
  border-right: 2px solid var(--white);
  border-bottom: 2px solid var(--white);
  transform: rotate(45deg);
}
.addon__body { flex: 1; min-width: 0; }
.addon__row1 {
  display: flex; justify-content: space-between; align-items: baseline;
  gap: 12px;
}
.addon__name { font-size: 13px; font-weight: 700; }
.addon__price { font-size: 12px; font-weight: 700; flex-shrink: 0; }
.addon__price--free {
  color: #2E7D32;
}
.addon__price--free .price-old {
  color: var(--black-6); text-decoration: line-through; font-weight: 500;
  margin-right: 4px; font-size: 11px;
}
.addon__hint {
  font-size: 11px; color: var(--black-5); margin-top: 2px;
}
.addon__input {
  margin-top: 8px; width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--black-9);
  border-radius: 3px;
  font-size: 13px; font-family: inherit;
  display: none;
}
.addon--checked .addon__input { display: block; }

/* ===== BUY ROW ===== */
.buy-row { display: flex; gap: 10px; margin-bottom: 10px; }
.qty {
  display: inline-flex; align-items: center;
  border: 1px solid var(--black-9); border-radius: 4px;
  overflow: hidden; flex-shrink: 0;
}
.qty__btn {
  width: 44px; height: 50px; font-size: 18px;
  color: var(--black-3); background: var(--white);
  border: 0; cursor: pointer;
}
.qty__btn:hover { background: var(--black-10); }
.qty__num {
  width: 44px; text-align: center; font-size: 14px; font-weight: 700;
  border: 0; outline: 0; height: 50px; background: var(--white);
}
.add-to-cart {
  flex: 1; height: 50px;
  background: var(--black-0, var(--black)); color: var(--white);
  font-size: 13px; font-weight: 800; letter-spacing: 0.08em;
  text-transform: uppercase; border: 0; border-radius: 4px;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  cursor: pointer; transition: background 0.18s;
}
.add-to-cart:hover { background: var(--red); }
.buy-now {
  width: 100%; height: 50px; margin-bottom: 16px;
  background: var(--white); color: var(--black-0, var(--black));
  border: 1.5px solid var(--black-0, var(--black));
  font-size: 13px; font-weight: 800; letter-spacing: 0.08em;
  text-transform: uppercase; border-radius: 4px; cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  transition: background 0.18s, color 0.18s, border-color 0.18s;
}
.buy-now:hover {
  background: var(--red); color: var(--white); border-color: var(--red);
}

/* ===== TRUST BADGES (4 in 2x2) ===== */
.trust {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px;
  margin-bottom: 16px;
}
.trust__item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; background: var(--black-10);
  border-radius: 4px;
}
.trust__icon { width: 18px; height: 18px; flex-shrink: 0; }
.trust__label { font-size: 11px; font-weight: 700; letter-spacing: 0.04em; line-height: 1.2; }

/* ===== TABS BLOCK ===== */
.tabs-block { padding: 56px 0; border-top: 1px solid var(--black-9); }
.tabs__nav { display: flex; gap: 0; border-bottom: 1px solid var(--black-9); margin-bottom: 28px; }
.tabs__btn {
  padding: 14px 0; margin-right: 32px;
  font-size: 13px; font-weight: 700; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--black-4);
  border: 0; border-bottom: 2px solid transparent;
  background: transparent; cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
}
.tabs__btn--active { color: var(--black-0, var(--black)); border-bottom-color: var(--black-0, var(--black)); }
.tabs__panel {
  max-width: 760px;
  font-size: 14px; line-height: 1.65; color: var(--black-3);
}
.tabs__panel-text p { margin-bottom: 14px; }
.tabs__panel h3 {
  font-size: 14px; font-weight: 800; letter-spacing: 0.04em;
  text-transform: uppercase; margin: 22px 0 12px;
  color: var(--black-1);
}
.auto-tag {
  display: inline-block; font-size: 9px; font-weight: 700;
  color: var(--black-5); letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 3px 7px; background: var(--black-10);
  border-radius: 3px; margin-left: 8px; vertical-align: middle;
}
.specs {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px 32px;
  padding: 16px 0; border-top: 1px solid var(--black-9);
  border-bottom: 1px solid var(--black-9); margin: 14px 0 24px;
}
.spec { display: flex; justify-content: space-between; padding: 4px 0; font-size: 13px; }
.spec__key { color: var(--black-4); font-weight: 600; }
.spec__val { color: var(--black-1); font-weight: 700; }

/* ===== ACCORDION (mobile) ===== */
.accordion { display: none; }
.accordion__item { border-bottom: 1px solid var(--black-9); }
.accordion__head {
  display: flex; justify-content: space-between; align-items: center;
  width: 100%; padding: 18px 0;
  font-size: 13px; font-weight: 700; letter-spacing: 0.06em;
  text-transform: uppercase;
  background: transparent; border: 0; cursor: pointer;
}
.accordion__head svg { width: 14px; height: 14px; transition: transform 0.2s; }
.accordion__item--open .accordion__head svg { transform: rotate(180deg); }
.accordion__panel {
  display: none; padding: 0 0 18px;
  font-size: 14px; line-height: 1.6; color: var(--black-3);
}
.accordion__item--open .accordion__panel { display: block; }

/* ===== UPSELL: COMPLETE THE KIT ===== */
.upsell { background: var(--black-10); padding: 56px 0; }
.section-title {
  font-size: 28px; font-weight: 800; letter-spacing: -0.015em;
  margin-bottom: 8px;
}
.section-sub {
  font-size: 13px; color: var(--black-4); margin-bottom: 28px;
}
.upsell__grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
  margin-bottom: 24px;
}
.upsell-card {
  background: var(--white); padding: 16px;
  border-radius: 8px;
  display: flex; flex-direction: column; gap: 12px;
}
.upsell-card__media {
  aspect-ratio: 4/3; background: var(--black-10);
  border-radius: 6px; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  color: var(--black-6); font-size: 11px;
}
.upsell-card__media img { width: 100%; height: 100%; object-fit: cover; }
.upsell-card__body { display: flex; flex-direction: column; flex: 1; }
.upsell-card__title {
  font-size: 14px; font-weight: 800; line-height: 1.3;
  margin: 0 0 4px;
}
.upsell-card__title a { color: inherit; text-decoration: none; }
.upsell-card__title a:hover { color: var(--red); }
.upsell-card__price-row {
  display: flex; gap: 8px; align-items: baseline;
  margin: 0 0 12px; flex-wrap: wrap;
}
.upsell-card__bundle { font-size: 16px; font-weight: 800; color: var(--black-1); }
.upsell-card__bundle .woocommerce-Price-amount { font-size: inherit; }
.upsell-card__bundle-old {
  font-size: 12px; color: var(--black-6); text-decoration: line-through;
}
.upsell-card__bundle-old .woocommerce-Price-amount { font-size: inherit; }
.upsell-card__save {
  font-size: 10px; font-weight: 800; color: #2E7D32;
  background: rgba(46,125,50,0.1); padding: 3px 7px; border-radius: 3px;
  letter-spacing: 0.04em;
}
.upsell-card__save .woocommerce-Price-amount { font-size: inherit; }
.upsell-card__btn {
  background: var(--black-0, var(--black)); color: var(--white);
  padding: 10px 16px; font-size: 11px; font-weight: 800;
  letter-spacing: 0.08em; text-transform: uppercase; border: 0; border-radius: 4px;
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  cursor: pointer; width: 100%;
  transition: background 0.18s;
}
.upsell-card__btn:hover { background: var(--red); }

.upsell__bundle-cta {
  background: var(--white); border: 2px solid var(--black-0, var(--black));
  border-radius: 8px; padding: 18px 22px;
  display: flex; justify-content: space-between; align-items: center;
  gap: 24px; margin-top: 16px;
}
.upsell__bundle-title {
  font-size: 13px; font-weight: 800; letter-spacing: 0.04em;
  text-transform: uppercase; margin-bottom: 4px;
}
.upsell__bundle-line {
  font-size: 12px; color: var(--black-4);
  display: flex; gap: 8px; flex-wrap: wrap; align-items: baseline;
}
.upsell__bundle-was {
  text-decoration: line-through; color: var(--black-6); font-weight: 600;
}
.upsell__bundle-now {
  color: var(--black-0, var(--black)); font-size: 16px; font-weight: 800;
}
.upsell__bundle-btn {
  background: var(--black-0, var(--black)); color: var(--white);
  padding: 12px 22px; font-size: 12px; font-weight: 800;
  letter-spacing: 0.08em; text-transform: uppercase; border: 0; border-radius: 4px;
  display: inline-flex; align-items: center; gap: 8px;
  flex-shrink: 0; cursor: pointer; transition: background 0.18s;
}
.upsell__bundle-btn:hover { background: var(--red); }

/* ===== REVIEWS ===== */
.reviews { padding: 56px 0; border-top: 1px solid var(--black-9); }
.reviews__header {
  display: flex; justify-content: space-between; align-items: flex-end;
  margin-bottom: 32px; gap: 32px;
}
.reviews__summary { display: flex; align-items: baseline; gap: 12px; }
.reviews__avg {
  font-size: 56px; font-weight: 800; line-height: 1;
  letter-spacing: -0.025em;
}
.reviews__total { font-size: 13px; color: var(--black-4); }
.reviews__write-btn {
  background: var(--black-0, var(--black)); color: var(--white);
  padding: 12px 22px; font-size: 12px; font-weight: 700;
  letter-spacing: 0.08em; text-transform: uppercase; border: 0; border-radius: 4px;
  cursor: pointer;
}

/* ===== MOST LIKED CAROUSEL ===== */
.most-liked { padding: 56px 0; border-top: 1px solid var(--black-9); }
.ml-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  margin-bottom: 28px; gap: 24px;
}
.ml-head__nav { display: flex; gap: 8px; }
.ml-arrow {
  width: 44px; height: 44px;
  background: var(--white);
  border: 1px solid var(--black-9);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}
.ml-arrow:hover { border-color: var(--black-3); background: var(--black-10); }
.ml-arrow:disabled { opacity: 0.4; cursor: not-allowed; }
.ml-carousel {
  display: flex; gap: 16px;
  overflow-x: auto; overflow-y: hidden;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding-bottom: 8px;
}
.ml-carousel::-webkit-scrollbar { display: none; }
.ml-card {
  flex: 0 0 calc((100% - 16px * 3) / 4);
  max-width: calc((100% - 16px * 3) / 4);
  scroll-snap-align: start;
  display: block; text-decoration: none; color: inherit;
}
.ml-card__media {
  aspect-ratio: 4/5; background: var(--black-10);
  border-radius: 4px; margin-bottom: 12px; position: relative;
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  color: var(--black-6); font-size: 11px;
}
.ml-card__media img { width: 100%; height: 100%; object-fit: cover; }
.ml-card__badge {
  position: absolute; top: 10px; left: 10px;
  background: var(--gold, #C29B3D); color: var(--white);
  font-size: 9px; font-weight: 800; padding: 3px 7px;
  letter-spacing: 0.1em; text-transform: uppercase;
}
.ml-card__title {
  font-size: 13px; font-weight: 600; line-height: 1.35;
  margin-bottom: 4px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
}
.ml-card__price { font-size: 13px; font-weight: 800; }
.ml-card__price .woocommerce-Price-amount { font-size: inherit; }
.ml-dots {
  display: flex; justify-content: center; gap: 6px; margin-top: 18px;
}
.ml-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--black-7); border: 0; padding: 0; cursor: pointer;
  transition: background 0.15s, width 0.15s;
}
.ml-dot--active {
  background: var(--black-0, var(--black));
  width: 24px; border-radius: 3px;
}

/* ===== MOBILE STICKY CTA ===== */
.mobile-cta {
  display: none;
  position: fixed; bottom: 0; left: 0; right: 0;
  background: var(--white); border-top: 1px solid var(--black-9);
  padding: 10px 14px;
  z-index: 100;
  box-shadow: 0 -4px 16px rgba(0,0,0,0.06);
}
.mobile-cta__inner { display: flex; gap: 8px; }
.mobile-cta__add,
.mobile-cta__buy {
  flex: 1; height: 46px;
  font-size: 12px; font-weight: 800;
  letter-spacing: 0.06em; text-transform: uppercase;
  border-radius: 4px; cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 6px;
}
.mobile-cta__add {
  background: var(--white); color: var(--black-0, var(--black));
  border: 1.5px solid var(--black-0, var(--black));
}
.mobile-cta__add svg { width: 12px; height: 12px; }
.mobile-cta__buy {
  background: var(--black-0, var(--black)); color: var(--white);
  border: 0;
}

/* ===== SIZE GUIDE MODAL ===== */
.size-modal {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(15,15,16,0.6);
  display: none; align-items: center; justify-content: center;
  padding: 20px;
}
.size-modal.is-open { display: flex; }
.size-modal__content {
  background: var(--white); border-radius: 8px;
  width: 100%; max-width: 720px; max-height: 92vh;
  overflow-y: auto;
  padding: 32px;
  position: relative;
}
.size-modal__close {
  position: absolute; top: 16px; right: 16px;
  width: 36px; height: 36px;
  background: var(--black-10); border: 0; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
}
.size-modal__title {
  font-size: 20px; font-weight: 800; margin-bottom: 6px;
}
.size-modal__sub {
  font-size: 13px; color: var(--black-4); margin-bottom: 24px;
}
.size-modal__tabs {
  display: flex; gap: 6px; margin-bottom: 20px;
  border-bottom: 1px solid var(--black-9); padding-bottom: 12px;
  flex-wrap: wrap;
}
.size-modal__tab {
  font-size: 11px; font-weight: 700; letter-spacing: 0.06em;
  text-transform: uppercase; padding: 8px 14px; border-radius: 999px;
  background: var(--black-10); color: var(--black-4);
  border: 0; cursor: pointer;
}
.size-modal__tab--active { background: var(--black-0, var(--black)); color: var(--white); }
.size-table {
  width: 100%; border-collapse: collapse;
  font-size: 13px;
}
.size-table th {
  text-align: left; padding: 12px 10px;
  background: var(--black-10);
  font-size: 11px; font-weight: 700; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--black-1);
  border-bottom: 1px solid var(--black-9);
}
.size-table td {
  padding: 12px 10px; border-bottom: 1px solid var(--black-9);
}
.size-table tr:last-child td { border-bottom: 0; }
.size-table td:first-child { font-weight: 700; }
.size-modal__note {
  margin-top: 16px; padding: 12px; background: var(--black-10);
  border-radius: 4px; font-size: 12px; color: var(--black-4); line-height: 1.55;
}
.size-modal__note strong { color: var(--black-1); }

/* ===== MOBILE BREAKPOINT ===== */
@media (max-width: 1023px) {
  .product-top {
    grid-template-columns: 1fr;
    gap: 24px;
    padding: 0 0 32px;
  }
  .gallery { position: static; }
  .gallery__thumbs { grid-template-columns: repeat(5, 1fr); gap: 6px; }
  .info__title { font-size: 22px; }
  .info__price { font-size: 22px; }

  .tabs-block { padding: 32px 0; }
  .tabs__nav { display: none; }
  .accordion { display: block; }
  .tabs__panel:not(.accordion__panel) { display: none !important; }

  .upsell { padding: 32px 0; }
  .upsell__grid {
    grid-template-columns: none;
    display: flex; flex-direction: row; gap: 12px;
    overflow-x: auto; overflow-y: hidden;
    scroll-snap-type: x mandatory;
    padding-bottom: 8px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .upsell__grid::-webkit-scrollbar { display: none; }
  .upsell-card {
    flex: 0 0 78%; max-width: 78%;
    scroll-snap-align: start;
  }
  .upsell__bundle-cta {
    flex-direction: column; align-items: flex-start;
    gap: 14px; padding: 14px 16px;
  }
  .upsell__bundle-btn { width: 100%; justify-content: center; }

  .reviews { padding: 32px 0; }
  .reviews__header { flex-direction: column; align-items: flex-start; gap: 16px; }

  .most-liked { padding: 32px 0; }
  .ml-card {
    flex: 0 0 calc((100% - 12px) / 2);
    max-width: calc((100% - 12px) / 2);
  }
  .ml-head { flex-direction: column; align-items: flex-start; gap: 12px; }
  .ml-head__nav { display: none; }

  .section-title { font-size: 20px; }

  /* Mobile sticky CTA bar — sits ABOVE existing site sticky-bar */
  .mobile-cta {
    display: block;
    bottom: 64px; /* matches existing sticky-bar height */
    z-index: 49;
  }
  /* Ensure last section has bottom padding so mobile-cta + sticky-bar don't cover content */
  .most-liked { padding-bottom: 160px; }
}

@media (min-width: 1024px) {
  .accordion { display: none; }
  .tabs__nav { display: flex; }
}


/* ============================================================
   PHASE 5 — SINGLE PRODUCT PAGE
   ============================================================ */

/* ===== PRODUCT TOP SECTION ===== */
.product-top {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: 56px;
  padding: 0 0 56px;
}

/* ===== GALLERY ===== */
.gallery { position: sticky; top: 24px; align-self: start; }
.gallery__main {
  background: var(--black-10);
  aspect-ratio: 4/5;
  border-radius: 6px;
  position: relative;
  overflow: hidden;
  margin-bottom: 12px;
}
.gallery__main img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.gallery__placeholder {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  color: var(--black-6); font-size: 13px;
}
.gallery__badge {
  position: absolute; top: 16px; left: 16px;
  background: var(--gold, #C29B3D); color: var(--white);
  font-size: 10px; font-weight: 800;
  padding: 5px 10px; letter-spacing: 0.14em;
  text-transform: uppercase; border-radius: 2px;
  z-index: 2;
}
.gallery__nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 40px; height: 40px;
  background: rgba(255,255,255,0.92);
  border: 0; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
  cursor: pointer; z-index: 2;
}
.gallery__nav--prev { left: 12px; }
.gallery__nav--next { right: 12px; }
.gallery__thumbs {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px;
}
.gallery__thumb {
  aspect-ratio: 1; background: var(--black-10);
  border: 2px solid transparent; border-radius: 4px;
  overflow: hidden; cursor: pointer; padding: 0;
  display: flex; align-items: center; justify-content: center;
}
.gallery__thumb img { width: 100%; height: 100%; object-fit: cover; }
.gallery__thumb--active { border-color: var(--black-0, var(--black)); }

/* ===== INFO COLUMN ===== */
.info { display: flex; flex-direction: column; }
.info__brand {
  font-size: 11px; font-weight: 700; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--black-5); margin-bottom: 8px;
}
.info__title {
  font-size: 32px; font-weight: 800; letter-spacing: -0.02em;
  line-height: 1.15; margin-bottom: 12px;
}
.info__rating {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 16px; font-size: 13px;
}
.stars { display: inline-flex; gap: 2px; color: var(--gold, #C29B3D); }
.info__rating-text { color: var(--black-4); font-size: 12px; }
.info__rating-text a { text-decoration: underline; color: inherit; }

.info__price-row {
  display: flex; align-items: baseline; gap: 12px;
  margin-bottom: 16px;
}
.info__price {
  font-size: 28px; font-weight: 800; color: var(--black-0, var(--black));
  letter-spacing: -0.01em;
}
.info__price del {
  font-size: 16px; color: var(--black-6); font-weight: 500; margin-right: 8px;
}
.info__price ins { text-decoration: none; color: var(--black-0, var(--black)); }
.info__price .woocommerce-Price-amount { font-size: inherit; font-weight: inherit; color: inherit; }

.info__bogo-hint {
  background: linear-gradient(135deg, #FFF6E5 0%, #FFE5E5 100%);
  border: 1px solid #FFD08C;
  padding: 10px 12px;
  border-radius: 6px;
  font-size: 12px;
  margin-bottom: 22px;
  line-height: 1.45;
}
.info__bogo-hint strong { color: var(--red); margin-right: 4px; }

/* ===== SIZE BLOCK ===== */
.size-block { margin-bottom: 22px; }
.size-block__head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 10px;
}
.size-block__label {
  font-size: 12px; font-weight: 700; letter-spacing: 0.1em;
  text-transform: uppercase;
}
.size-guide-trigger {
  font-size: 12px; font-weight: 600; text-decoration: underline;
  color: var(--black-1); display: inline-flex; align-items: center; gap: 6px;
  background: transparent; border: 0; cursor: pointer; padding: 0;
}
.size-guide-trigger svg { width: 14px; height: 14px; }
.size-grid {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px;
}
.size-btn {
  padding: 11px 0; font-size: 13px; font-weight: 600;
  background: var(--white); border: 1px solid var(--black-9);
  border-radius: 4px; text-align: center; cursor: pointer;
  text-transform: uppercase;
  transition: border-color 0.15s, background 0.15s;
}
.size-btn:hover:not(:disabled) { border-color: var(--black-3); }
.size-btn--active {
  background: var(--black-0, var(--black)); color: var(--white);
  border-color: var(--black-0, var(--black));
}
.size-btn--unavailable {
  color: var(--black-7); position: relative; cursor: not-allowed;
}
.size-btn--unavailable::after {
  content: ''; position: absolute; left: 8px; right: 8px; top: 50%;
  border-top: 1px solid var(--black-7); transform: rotate(-12deg);
}

/* ===== ADDONS ===== */
.addons {
  background: var(--black-10); padding: 16px; border-radius: 6px;
  margin-bottom: 22px;
}
.addons__head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 14px; padding-bottom: 12px;
  border-bottom: 1px solid var(--black-9);
}
.addons__title { font-size: 13px; font-weight: 700; letter-spacing: 0.04em; }
.addons__sub { font-size: 11px; color: var(--black-5); font-weight: 600; }
.addon {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--black-9);
  cursor: pointer;
}
.addon:last-child { border-bottom: 0; padding-bottom: 0; }
.addon__check {
  width: 18px; height: 18px;
  border: 1.5px solid var(--black-7);
  border-radius: 3px;
  flex-shrink: 0; margin-top: 2px;
  position: relative;
}
.addon--checked .addon__check {
  background: var(--black-0, var(--black)); border-color: var(--black-0, var(--black));
}
.addon--checked .addon__check::after {
  content: ''; position: absolute; top: 2px; left: 5px;
  width: 4px; height: 8px;
  border-right: 2px solid var(--white);
  border-bottom: 2px solid var(--white);
  transform: rotate(45deg);
}
.addon__body { flex: 1; min-width: 0; }
.addon__row1 {
  display: flex; justify-content: space-between; align-items: baseline;
  gap: 12px;
}
.addon__name { font-size: 13px; font-weight: 700; }
.addon__price { font-size: 12px; font-weight: 700; flex-shrink: 0; }
.addon__price--free {
  color: #2E7D32;
}
.addon__price--free .price-old {
  color: var(--black-6); text-decoration: line-through; font-weight: 500;
  margin-right: 4px; font-size: 11px;
}
.addon__hint {
  font-size: 11px; color: var(--black-5); margin-top: 2px;
}
.addon__input {
  margin-top: 8px; width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--black-9);
  border-radius: 3px;
  font-size: 13px; font-family: inherit;
  display: none;
}
.addon--checked .addon__input { display: block; }

/* ===== BUY ROW ===== */
.buy-row { display: flex; gap: 10px; margin-bottom: 10px; }
.qty {
  display: inline-flex; align-items: center;
  border: 1px solid var(--black-9); border-radius: 4px;
  overflow: hidden; flex-shrink: 0;
}
.qty__btn {
  width: 44px; height: 50px; font-size: 18px;
  color: var(--black-3); background: var(--white);
  border: 0; cursor: pointer;
}
.qty__btn:hover { background: var(--black-10); }
.qty__num {
  width: 44px; text-align: center; font-size: 14px; font-weight: 700;
  border: 0; outline: 0; height: 50px; background: var(--white);
}
.add-to-cart {
  flex: 1; height: 50px;
  background: var(--black-0, var(--black)); color: var(--white);
  font-size: 13px; font-weight: 800; letter-spacing: 0.08em;
  text-transform: uppercase; border: 0; border-radius: 4px;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  cursor: pointer; transition: background 0.18s;
}
.add-to-cart:hover { background: var(--red); }
.buy-now {
  width: 100%; height: 50px; margin-bottom: 16px;
  background: var(--white); color: var(--black-0, var(--black));
  border: 1.5px solid var(--black-0, var(--black));
  font-size: 13px; font-weight: 800; letter-spacing: 0.08em;
  text-transform: uppercase; border-radius: 4px; cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  transition: background 0.18s, color 0.18s, border-color 0.18s;
}
.buy-now:hover {
  background: var(--red); color: var(--white); border-color: var(--red);
}

/* ===== TRUST BADGES (4 in 2x2) ===== */
.trust {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px;
  margin-bottom: 16px;
}
.trust__item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; background: var(--black-10);
  border-radius: 4px;
}
.trust__icon { width: 18px; height: 18px; flex-shrink: 0; }
.trust__label { font-size: 11px; font-weight: 700; letter-spacing: 0.04em; line-height: 1.2; }

/* ===== TABS BLOCK ===== */
.tabs-block { padding: 56px 0; border-top: 1px solid var(--black-9); }
.tabs__nav { display: flex; gap: 0; border-bottom: 1px solid var(--black-9); margin-bottom: 28px; }
.tabs__btn {
  padding: 14px 0; margin-right: 32px;
  font-size: 13px; font-weight: 700; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--black-4);
  border: 0; border-bottom: 2px solid transparent;
  background: transparent; cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
}
.tabs__btn--active { color: var(--black-0, var(--black)); border-bottom-color: var(--black-0, var(--black)); }
.tabs__panel {
  max-width: 760px;
  font-size: 14px; line-height: 1.65; color: var(--black-3);
}
.tabs__panel-text p { margin-bottom: 14px; }
.tabs__panel h3 {
  font-size: 14px; font-weight: 800; letter-spacing: 0.04em;
  text-transform: uppercase; margin: 22px 0 12px;
  color: var(--black-1);
}
.auto-tag {
  display: inline-block; font-size: 9px; font-weight: 700;
  color: var(--black-5); letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 3px 7px; background: var(--black-10);
  border-radius: 3px; margin-left: 8px; vertical-align: middle;
}
.specs {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px 32px;
  padding: 16px 0; border-top: 1px solid var(--black-9);
  border-bottom: 1px solid var(--black-9); margin: 14px 0 24px;
}
.spec { display: flex; justify-content: space-between; padding: 4px 0; font-size: 13px; }
.spec__key { color: var(--black-4); font-weight: 600; }
.spec__val { color: var(--black-1); font-weight: 700; }

/* ===== ACCORDION (mobile) ===== */
.accordion { display: none; }
.accordion__item { border-bottom: 1px solid var(--black-9); }
.accordion__head {
  display: flex; justify-content: space-between; align-items: center;
  width: 100%; padding: 18px 0;
  font-size: 13px; font-weight: 700; letter-spacing: 0.06em;
  text-transform: uppercase;
  background: transparent; border: 0; cursor: pointer;
}
.accordion__head svg { width: 14px; height: 14px; transition: transform 0.2s; }
.accordion__item--open .accordion__head svg { transform: rotate(180deg); }
.accordion__panel {
  display: none; padding: 0 0 18px;
  font-size: 14px; line-height: 1.6; color: var(--black-3);
}
.accordion__item--open .accordion__panel { display: block; }

/* ===== UPSELL: COMPLETE THE KIT ===== */
.upsell { background: var(--black-10); padding: 56px 0; }
.section-title {
  font-size: 28px; font-weight: 800; letter-spacing: -0.015em;
  margin-bottom: 8px;
}
.section-sub {
  font-size: 13px; color: var(--black-4); margin-bottom: 28px;
}
.upsell__grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
  margin-bottom: 24px;
}
.upsell-card {
  background: var(--white); padding: 16px;
  border-radius: 8px;
  display: flex; flex-direction: column; gap: 12px;
}
.upsell-card__media {
  aspect-ratio: 4/3; background: var(--black-10);
  border-radius: 6px; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  color: var(--black-6); font-size: 11px;
}
.upsell-card__media img { width: 100%; height: 100%; object-fit: cover; }
.upsell-card__body { display: flex; flex-direction: column; flex: 1; }
.upsell-card__title {
  font-size: 14px; font-weight: 800; line-height: 1.3;
  margin: 0 0 4px;
}
.upsell-card__title a { color: inherit; text-decoration: none; }
.upsell-card__title a:hover { color: var(--red); }
.upsell-card__price-row {
  display: flex; gap: 8px; align-items: baseline;
  margin: 0 0 12px; flex-wrap: wrap;
}
.upsell-card__bundle { font-size: 16px; font-weight: 800; color: var(--black-1); }
.upsell-card__bundle .woocommerce-Price-amount { font-size: inherit; }
.upsell-card__bundle-old {
  font-size: 12px; color: var(--black-6); text-decoration: line-through;
}
.upsell-card__bundle-old .woocommerce-Price-amount { font-size: inherit; }
.upsell-card__save {
  font-size: 10px; font-weight: 800; color: #2E7D32;
  background: rgba(46,125,50,0.1); padding: 3px 7px; border-radius: 3px;
  letter-spacing: 0.04em;
}
.upsell-card__save .woocommerce-Price-amount { font-size: inherit; }
.upsell-card__btn {
  background: var(--black-0, var(--black)); color: var(--white);
  padding: 10px 16px; font-size: 11px; font-weight: 800;
  letter-spacing: 0.08em; text-transform: uppercase; border: 0; border-radius: 4px;
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  cursor: pointer; width: 100%;
  transition: background 0.18s;
}
.upsell-card__btn:hover { background: var(--red); }

.upsell__bundle-cta {
  background: var(--white); border: 2px solid var(--black-0, var(--black));
  border-radius: 8px; padding: 18px 22px;
  display: flex; justify-content: space-between; align-items: center;
  gap: 24px; margin-top: 16px;
}
.upsell__bundle-title {
  font-size: 13px; font-weight: 800; letter-spacing: 0.04em;
  text-transform: uppercase; margin-bottom: 4px;
}
.upsell__bundle-line {
  font-size: 12px; color: var(--black-4);
  display: flex; gap: 8px; flex-wrap: wrap; align-items: baseline;
}
.upsell__bundle-was {
  text-decoration: line-through; color: var(--black-6); font-weight: 600;
}
.upsell__bundle-now {
  color: var(--black-0, var(--black)); font-size: 16px; font-weight: 800;
}
.upsell__bundle-btn {
  background: var(--black-0, var(--black)); color: var(--white);
  padding: 12px 22px; font-size: 12px; font-weight: 800;
  letter-spacing: 0.08em; text-transform: uppercase; border: 0; border-radius: 4px;
  display: inline-flex; align-items: center; gap: 8px;
  flex-shrink: 0; cursor: pointer; transition: background 0.18s;
}
.upsell__bundle-btn:hover { background: var(--red); }

/* ===== REVIEWS ===== */
.reviews { padding: 56px 0; border-top: 1px solid var(--black-9); }
.reviews__header {
  display: flex; justify-content: space-between; align-items: flex-end;
  margin-bottom: 32px; gap: 32px;
}
.reviews__summary { display: flex; align-items: baseline; gap: 12px; }
.reviews__avg {
  font-size: 56px; font-weight: 800; line-height: 1;
  letter-spacing: -0.025em;
}
.reviews__total { font-size: 13px; color: var(--black-4); }
.reviews__write-btn {
  background: var(--black-0, var(--black)); color: var(--white);
  padding: 12px 22px; font-size: 12px; font-weight: 700;
  letter-spacing: 0.08em; text-transform: uppercase; border: 0; border-radius: 4px;
  cursor: pointer;
}

/* ===== MOST LIKED CAROUSEL ===== */
.most-liked { padding: 56px 0; border-top: 1px solid var(--black-9); }
.ml-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  margin-bottom: 28px; gap: 24px;
}
.ml-head__nav { display: flex; gap: 8px; }
.ml-arrow {
  width: 44px; height: 44px;
  background: var(--white);
  border: 1px solid var(--black-9);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}
.ml-arrow:hover { border-color: var(--black-3); background: var(--black-10); }
.ml-arrow:disabled { opacity: 0.4; cursor: not-allowed; }
.ml-carousel {
  display: flex; gap: 16px;
  overflow-x: auto; overflow-y: hidden;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding-bottom: 8px;
}
.ml-carousel::-webkit-scrollbar { display: none; }
.ml-card {
  flex: 0 0 calc((100% - 16px * 3) / 4);
  max-width: calc((100% - 16px * 3) / 4);
  scroll-snap-align: start;
  display: block; text-decoration: none; color: inherit;
}
.ml-card__media {
  aspect-ratio: 4/5; background: var(--black-10);
  border-radius: 4px; margin-bottom: 12px; position: relative;
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  color: var(--black-6); font-size: 11px;
}
.ml-card__media img { width: 100%; height: 100%; object-fit: cover; }
.ml-card__badge {
  position: absolute; top: 10px; left: 10px;
  background: var(--gold, #C29B3D); color: var(--white);
  font-size: 9px; font-weight: 800; padding: 3px 7px;
  letter-spacing: 0.1em; text-transform: uppercase;
}
.ml-card__title {
  font-size: 13px; font-weight: 600; line-height: 1.35;
  margin-bottom: 4px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
}
.ml-card__price { font-size: 13px; font-weight: 800; }
.ml-card__price .woocommerce-Price-amount { font-size: inherit; }
.ml-dots {
  display: flex; justify-content: center; gap: 6px; margin-top: 18px;
}
.ml-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--black-7); border: 0; padding: 0; cursor: pointer;
  transition: background 0.15s, width 0.15s;
}
.ml-dot--active {
  background: var(--black-0, var(--black));
  width: 24px; border-radius: 3px;
}

/* ===== MOBILE STICKY CTA ===== */
.mobile-cta {
  display: none;
  position: fixed; bottom: 0; left: 0; right: 0;
  background: var(--white); border-top: 1px solid var(--black-9);
  padding: 10px 14px;
  z-index: 100;
  box-shadow: 0 -4px 16px rgba(0,0,0,0.06);
}
.mobile-cta__inner { display: flex; gap: 8px; }
.mobile-cta__add,
.mobile-cta__buy {
  flex: 1; height: 46px;
  font-size: 12px; font-weight: 800;
  letter-spacing: 0.06em; text-transform: uppercase;
  border-radius: 4px; cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 6px;
}
.mobile-cta__add {
  background: var(--white); color: var(--black-0, var(--black));
  border: 1.5px solid var(--black-0, var(--black));
}
.mobile-cta__add svg { width: 12px; height: 12px; }
.mobile-cta__buy {
  background: var(--black-0, var(--black)); color: var(--white);
  border: 0;
}

/* ===== SIZE GUIDE MODAL ===== */
.size-modal {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(15,15,16,0.6);
  display: none; align-items: center; justify-content: center;
  padding: 20px;
}
.size-modal.is-open { display: flex; }
.size-modal__content {
  background: var(--white); border-radius: 8px;
  width: 100%; max-width: 720px; max-height: 92vh;
  overflow-y: auto;
  padding: 32px;
  position: relative;
}
.size-modal__close {
  position: absolute; top: 16px; right: 16px;
  width: 36px; height: 36px;
  background: var(--black-10); border: 0; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
}
.size-modal__title {
  font-size: 20px; font-weight: 800; margin-bottom: 6px;
}
.size-modal__sub {
  font-size: 13px; color: var(--black-4); margin-bottom: 24px;
}
.size-modal__tabs {
  display: flex; gap: 6px; margin-bottom: 20px;
  border-bottom: 1px solid var(--black-9); padding-bottom: 12px;
  flex-wrap: wrap;
}
.size-modal__tab {
  font-size: 11px; font-weight: 700; letter-spacing: 0.06em;
  text-transform: uppercase; padding: 8px 14px; border-radius: 999px;
  background: var(--black-10); color: var(--black-4);
  border: 0; cursor: pointer;
}
.size-modal__tab--active { background: var(--black-0, var(--black)); color: var(--white); }
.size-table {
  width: 100%; border-collapse: collapse;
  font-size: 13px;
}
.size-table th {
  text-align: left; padding: 12px 10px;
  background: var(--black-10);
  font-size: 11px; font-weight: 700; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--black-1);
  border-bottom: 1px solid var(--black-9);
}
.size-table td {
  padding: 12px 10px; border-bottom: 1px solid var(--black-9);
}
.size-table tr:last-child td { border-bottom: 0; }
.size-table td:first-child { font-weight: 700; }
.size-modal__note {
  margin-top: 16px; padding: 12px; background: var(--black-10);
  border-radius: 4px; font-size: 12px; color: var(--black-4); line-height: 1.55;
}
.size-modal__note strong { color: var(--black-1); }

/* ===== MOBILE BREAKPOINT ===== */
@media (max-width: 1023px) {
  .product-top {
    grid-template-columns: 1fr;
    gap: 24px;
    padding: 0 0 32px;
  }
  .gallery { position: static; }
  .gallery__thumbs { grid-template-columns: repeat(5, 1fr); gap: 6px; }
  .info__title { font-size: 22px; }
  .info__price { font-size: 22px; }

  .tabs-block { padding: 32px 0; }
  .tabs__nav { display: none; }
  .accordion { display: block; }
  .tabs__panel:not(.accordion__panel) { display: none !important; }

  .upsell { padding: 32px 0; }
  .upsell__grid {
    grid-template-columns: none;
    display: flex; flex-direction: row; gap: 12px;
    overflow-x: auto; overflow-y: hidden;
    scroll-snap-type: x mandatory;
    padding-bottom: 8px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .upsell__grid::-webkit-scrollbar { display: none; }
  .upsell-card {
    flex: 0 0 78%; max-width: 78%;
    scroll-snap-align: start;
  }
  .upsell__bundle-cta {
    flex-direction: column; align-items: flex-start;
    gap: 14px; padding: 14px 16px;
  }
  .upsell__bundle-btn { width: 100%; justify-content: center; }

  .reviews { padding: 32px 0; }
  .reviews__header { flex-direction: column; align-items: flex-start; gap: 16px; }

  .most-liked { padding: 32px 0; }
  .ml-card {
    flex: 0 0 calc((100% - 12px) / 2);
    max-width: calc((100% - 12px) / 2);
  }
  .ml-head { flex-direction: column; align-items: flex-start; gap: 12px; }
  .ml-head__nav { display: none; }

  .section-title { font-size: 20px; }

  /* Mobile sticky CTA bar — sits ABOVE existing site sticky-bar */
  .mobile-cta {
    display: block;
    bottom: 64px; /* matches existing sticky-bar height */
    z-index: 49;
  }
  /* Ensure last section has bottom padding so mobile-cta + sticky-bar don't cover content */
  .most-liked { padding-bottom: 160px; }
}

@media (min-width: 1024px) {
  .accordion { display: none; }
  .tabs__nav { display: flex; }
}


/* ============================================================
   PHASE 5 — POST-LAUNCH CLEANUP
   ============================================================ */

/* Specs grid: cleaner row layout (key on left, value on right) */
.specs {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  padding: 0;
  border-top: 1px solid var(--black-9);
  border-bottom: 1px solid var(--black-9);
  margin: 14px 0 24px;
}
.spec {
  display: grid;
  grid-template-columns: 140px 1fr;
  align-items: baseline;
  padding: 12px 0;
  border-bottom: 1px solid var(--black-9);
  font-size: 13px;
}
.spec:last-child { border-bottom: 0; }
.spec__key {
  color: var(--black-5);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.spec__val {
  color: var(--black-1);
  font-weight: 700;
  text-align: right;
}

@media (min-width: 1024px) {
  .specs {
    grid-template-columns: 1fr 1fr;
    gap: 0 32px;
  }
  .specs .spec:nth-last-child(2):nth-child(odd) {
    border-bottom: 0;
  }
}

/* Reviews — clean up native WP comments template */
#reviews-list .commentlist,
#reviews-list ol.commentlist {
  list-style: none;
  margin: 0;
  padding: 0;
}
#reviews-list ol.commentlist > li,
#reviews-list .commentlist > li {
  background: var(--white);
  border: 1px solid var(--black-9);
  border-radius: 6px;
  padding: 18px 20px;
  margin-bottom: 12px;
  list-style: none;
}
#reviews-list .commentlist > li::before {
  display: none;
}
#reviews-list .avatar {
  display: none; /* Hide default avatar placeholders */
}
#reviews-list .meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-bottom: 8px;
  font-size: 13px;
}
#reviews-list .meta strong {
  font-size: 14px;
  font-weight: 700;
}
#reviews-list .star-rating {
  font-size: 13px;
  color: var(--gold, #C29B3D);
  position: static;
  margin: 4px 0;
}
#reviews-list .description p {
  font-size: 14px;
  line-height: 1.6;
  color: var(--black-3);
  margin: 0;
}
#reviews-list h2 {
  font-size: 18px;
  font-weight: 800;
  margin-bottom: 18px;
}
#reviews-list #respond {
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--black-9);
}
#reviews-list #respond h3 {
  font-size: 15px;
  font-weight: 800;
  margin-bottom: 8px;
}
#reviews-list .comment-form-rating {
  margin-bottom: 14px;
}
#reviews-list .comment-form input[type="text"],
#reviews-list .comment-form input[type="email"],
#reviews-list .comment-form textarea {
  border: 1px solid var(--black-9);
  border-radius: 4px;
  padding: 10px 12px;
  font-size: 14px;
  font-family: inherit;
  width: 100%;
}
#reviews-list .comment-form .submit,
#reviews-list .submit {
  background: var(--black-0, var(--black));
  color: var(--white);
  padding: 11px 24px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: 0;
  border-radius: 4px;
  cursor: pointer;
}

/* Description: clean broken image fallback (just in case any sneak through) */
.tabs__panel-text img {
  max-width: 100%;
  height: auto;
}
.tabs__panel-text img[src=""],
.tabs__panel-text img:not([src]) {
  display: none;
}

/* Customer Reviews plugin overrides for cleaner look */
.cr-qna-fld, .cr-all-reviews, .cr-product-reviews, .cusrev-reviews {
  font-family: inherit !important;
}


/* ============================================================
   PHASE 5 — REVIEWS REAL STRUCTURE
   ============================================================ */

/* Strip the numbered list defaults */
ol.commentlist {
  list-style: none !important;
  margin: 0 0 32px !important;
  padding: 0 !important;
  counter-reset: none;
}
ol.commentlist > li.review {
  background: var(--white);
  border: 1px solid var(--black-9);
  border-radius: 8px;
  padding: 20px 22px;
  margin-bottom: 12px;
  list-style: none;
  display: flex;
  gap: 16px;
  align-items: flex-start;
}
ol.commentlist > li.review::before,
ol.commentlist > li.review::marker {
  display: none !important;
  content: '' !important;
}

/* Hide the gravatar placeholders (most are auto-generated grey silhouettes) */
ol.commentlist .avatar {
  display: none;
}

/* The .comment_container holds everything; the comment-text is the body */
ol.commentlist .comment_container {
  display: contents;
}
ol.commentlist .comment-text {
  flex: 1;
  min-width: 0;
}

/* Star rating — sits at top */
ol.commentlist .star-rating {
  display: inline-block;
  font-size: 13px;
  height: 1em;
  width: 5em;
  margin: 0 0 6px;
  position: static;
}
ol.commentlist .star-rating::before {
  content: '\2606\2606\2606\2606\2606';
  color: var(--black-9);
  position: absolute;
  letter-spacing: 1px;
}
ol.commentlist .star-rating span {
  overflow: hidden;
  position: absolute;
  top: 0;
  left: 0;
  height: 1em;
  white-space: nowrap;
}
ol.commentlist .star-rating span::before {
  content: '\2605\2605\2605\2605\2605';
  color: var(--gold, #C29B3D);
  position: absolute;
  left: 0;
  letter-spacing: 1px;
}
ol.commentlist .star-rating .rating { display: none; }

/* Meta line (author + verified + date) */
ol.commentlist .meta {
  font-size: 12px;
  color: var(--black-4);
  margin: 0 0 8px;
  line-height: 1.5;
}
ol.commentlist .woocommerce-review__author {
  font-size: 14px;
  font-weight: 700;
  color: var(--black-1);
}
ol.commentlist .woocommerce-review__verified {
  display: inline-block;
  font-size: 10px;
  font-weight: 600;
  color: #2E7D32;
  background: rgba(46,125,50,0.1);
  padding: 2px 6px;
  border-radius: 3px;
  font-style: normal;
  letter-spacing: 0.04em;
  margin-left: 4px;
  vertical-align: 1px;
}
ol.commentlist .woocommerce-review__dash {
  margin: 0 4px;
  color: var(--black-7);
}
ol.commentlist .woocommerce-review__published-date {
  font-size: 12px;
  color: var(--black-5);
}

/* Review body */
ol.commentlist .description p {
  font-size: 14px;
  line-height: 1.55;
  color: var(--black-2);
  margin: 0;
}
ol.commentlist .description:empty {
  display: none;
}

/* Reviews title */
.woocommerce-Reviews-title {
  font-size: 18px;
  font-weight: 800;
  margin: 0 0 24px;
}

/* Customer Reviews plugin image grid (cr-comment-images) */
.cr-comment-images,
.cr-comment-videos {
  display: flex;
  gap: 8px;
  margin-top: 8px;
  flex-wrap: wrap;
}
.cr-comment-images img,
.cr-comment-videos video {
  max-width: 80px;
  border-radius: 4px;
}

/* Review form */
#review_form_wrapper {
  margin-top: 32px;
  padding-top: 28px;
  border-top: 1px solid var(--black-9);
}
#respond {
  background: var(--black-10);
  padding: 24px;
  border-radius: 8px;
}
#respond .comment-reply-title {
  font-size: 16px;
  font-weight: 800;
  margin-bottom: 6px;
  display: block;
}
#commentform p {
  margin-bottom: 14px;
}
#commentform label {
  display: block;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--black-3);
  margin-bottom: 6px;
}
#commentform input[type="text"],
#commentform input[type="email"],
#commentform textarea,
#commentform select {
  width: 100%;
  padding: 11px 14px;
  border: 1px solid var(--black-9);
  border-radius: 4px;
  font-size: 14px;
  font-family: inherit;
  background: var(--white);
}
#commentform textarea {
  min-height: 120px;
  resize: vertical;
}
#commentform .submit {
  background: var(--black-0, var(--black));
  color: var(--white);
  padding: 12px 26px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: 0;
  border-radius: 4px;
  cursor: pointer;
}
#commentform .submit:hover {
  background: var(--red);
}
.cr-upload-images-status {
  display: inline-block;
  background: var(--white);
  border: 1px dashed var(--black-9);
  padding: 10px 16px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 13px;
}

@media (max-width: 1023px) {
  ol.commentlist > li.review {
    padding: 16px;
  }
}


/* ============================================================
   PHASE 5 — REVIEWS CAROUSEL
   ============================================================ */

.rev-carousel-wrap {
  position: relative;
  margin: 0 0 24px;
}

.rev-carousel {
  display: flex;
  gap: 16px;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding: 4px 0 12px;
}
.rev-carousel::-webkit-scrollbar { display: none; }

/* Desktop: 4 cards visible */
.rev-card {
  flex: 0 0 calc((100% - 48px) / 4);
  max-width: calc((100% - 48px) / 4);
  scroll-snap-align: start;
  background: var(--white);
  border: 1px solid var(--black-9);
  border-radius: 8px;
  padding: 18px 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: border-color 0.18s, box-shadow 0.18s;
}
.rev-card:hover {
  border-color: var(--black-7);
  box-shadow: 0 2px 12px rgba(0,0,0,0.04);
}

.rev-card__stars {
  display: flex;
  gap: 1px;
  font-size: 14px;
  letter-spacing: 1px;
}
.rev-star {
  color: var(--black-9);
}
.rev-star--filled {
  color: var(--gold, #C29B3D);
}

.rev-card__body {
  flex: 1;
  min-height: 60px;
}
.rev-card__text {
  font-size: 13px;
  line-height: 1.55;
  color: var(--black-2);
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.rev-card__text--empty {
  color: var(--black-6);
  font-style: italic;
}

.rev-card__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  padding-top: 10px;
  border-top: 1px solid var(--black-9);
  font-size: 11px;
}
.rev-card__author {
  font-weight: 700;
  color: var(--black-1);
  font-size: 12px;
}
.rev-card__verified {
  font-size: 10px;
  font-weight: 700;
  color: #2E7D32;
  background: rgba(46,125,50,0.1);
  padding: 2px 6px;
  border-radius: 3px;
  letter-spacing: 0.04em;
}
.rev-card__date {
  color: var(--black-5);
  margin-left: auto;
  font-size: 11px;
}

/* Arrows */
.rev-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 40px;
  height: 40px;
  background: var(--white);
  border: 1px solid var(--black-9);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 5;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
  transition: border-color 0.15s, background 0.15s, opacity 0.15s;
}
.rev-arrow:hover {
  border-color: var(--black-3);
  background: var(--black-10);
}
.rev-arrow:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}
.rev-arrow--prev { left: -18px; }
.rev-arrow--next { right: -18px; }

/* Progress bar (replaces dots — better for many reviews) */
.rev-dots {
  position: relative;
  height: 2px;
  background: var(--black-9);
  margin: 18px auto 0;
  max-width: 200px;
  border-radius: 1px;
  overflow: hidden;
}
.rev-dots .rev-dot {
  display: none; /* hide individual dot buttons */
}
.rev-dots__bar {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  background: var(--black-0, var(--black));
  border-radius: 1px;
  transition: left 0.3s ease, width 0.3s ease;
}

/* "View all reviews" link */
.reviews__view-all {
  display: inline-block;
  font-size: 13px;
  font-weight: 700;
  color: var(--black-1);
  text-decoration: underline;
  letter-spacing: 0.04em;
}
.reviews__view-all:hover {
  color: var(--red);
}

/* Mobile: 1 card visible */
@media (max-width: 1023px) {
  .rev-card {
    flex: 0 0 100%;
    max-width: 100%;
  }
  .rev-arrow {
    display: none; /* swipe instead */
  }
  .rev-carousel {
    gap: 12px;
  }
}

/* Tablet: 2 cards visible */
@media (min-width: 768px) and (max-width: 1023px) {
  .rev-card {
    flex: 0 0 calc((100% - 12px) / 2);
    max-width: calc((100% - 12px) / 2);
  }
}


/* ============================================================
   PHASE 6 — CART DRAWER
   ============================================================ */

/* Outer wrapper (overlay + panel) */
.cart-drawer {
  position: fixed;
  inset: 0;
  z-index: 9999;
  pointer-events: none;
  visibility: hidden;
  /* Delay visibility transition by 0.32s on close so overlay+panel can fade out */
  transition: visibility 0s linear 0.32s;
}
.cart-drawer.is-open {
  pointer-events: auto;
  visibility: visible;
  /* No delay on open — show immediately */
  transition: visibility 0s linear 0s;
}

/* Backdrop overlay */
.cart-drawer__overlay {
  position: absolute;
  inset: 0;
  background: rgba(15, 15, 16, 0.5);
  opacity: 0;
  transition: opacity 0.28s ease;
}
.cart-drawer.is-open .cart-drawer__overlay {
  opacity: 1;
}

/* Sliding panel */
.cart-drawer__panel {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  max-width: 420px;
  background: var(--white);
  display: flex;
  flex-direction: column;
  box-shadow: -8px 0 32px rgba(0, 0, 0, 0.12);
  transform: translateX(100%);
  transition: transform 0.32s cubic-bezier(0.4, 0, 0.2, 1);
}
.cart-drawer.is-open .cart-drawer__panel {
  transform: translateX(0);
}

/* Header */
.cart-drawer__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  border-bottom: 1px solid var(--black-9);
  flex-shrink: 0;
}
.cart-drawer__title {
  font-size: 16px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin: 0;
  display: flex;
  align-items: center;
  gap: 8px;
}
.cart-drawer__count {
  font-size: 11px;
  font-weight: 700;
  background: var(--black-10);
  color: var(--black-3);
  padding: 3px 9px;
  border-radius: 999px;
  letter-spacing: 0.06em;
}
.cart-drawer__close {
  width: 36px;
  height: 36px;
  background: transparent;
  border: 0;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--black-2);
  transition: background 0.18s;
}
.cart-drawer__close:hover { background: var(--black-10); }

/* Scrollable body */
.cart-drawer__body {
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}

/* ===== EMPTY STATE ===== */
.cart-drawer__empty {
  text-align: center;
  padding: 80px 32px 48px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  color: var(--black-4);
}
.cart-drawer__empty svg {
  color: var(--black-7);
  margin-bottom: 4px;
}
.cart-drawer__empty-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--black-1);
  margin: 0;
}
.cart-drawer__empty-sub {
  font-size: 13px;
  margin: 0 0 20px;
  max-width: 240px;
}
.cart-drawer__shop-btn {
  background: var(--black-0, var(--black));
  color: var(--white);
  padding: 12px 24px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: 4px;
  text-decoration: none;
  transition: background 0.18s;
}
.cart-drawer__shop-btn:hover { background: var(--red); }

/* ===== FREE SHIPPING PROGRESS ===== */
.cart-drawer__shipping-progress {
  padding: 16px 24px;
  background: linear-gradient(135deg, #FFF6E5 0%, #FFE5E5 100%);
  border-bottom: 1px solid var(--black-9);
}
.ship-progress__msg {
  font-size: 12px;
  color: var(--black-2);
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 6px;
  line-height: 1.45;
}
.ship-progress__msg strong {
  color: var(--black-0, var(--black));
  font-weight: 800;
}
.ship-progress__msg .woocommerce-Price-amount {
  font-weight: 800;
  font-size: inherit;
}
.ship-progress__msg--won {
  color: #2E7D32;
}
.ship-progress__msg--won strong {
  color: #2E7D32;
}
.ship-progress__bar {
  height: 6px;
  background: rgba(0,0,0,0.08);
  border-radius: 3px;
  overflow: hidden;
}
.ship-progress__fill {
  height: 100%;
  background: linear-gradient(90deg, var(--gold, #C29B3D), #E5B85A);
  border-radius: 3px;
  transition: width 0.4s ease;
}
.ship-progress__msg--won + .ship-progress__bar .ship-progress__fill {
  background: linear-gradient(90deg, #2E7D32, #4CAF50);
}

/* ===== CART ITEMS LIST ===== */
.cart-drawer__items {
  list-style: none;
  margin: 0;
  padding: 0;
  flex: 1;
}
.cart-item {
  display: flex;
  gap: 14px;
  padding: 16px 24px;
  border-bottom: 1px solid var(--black-9);
  position: relative;
}
.cart-item:last-child { border-bottom: 0; }

.cart-item__media {
  flex-shrink: 0;
  width: 72px;
  height: 90px;
  background: var(--black-10);
  border-radius: 4px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.cart-item__media img,
.cart-item__img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block;
}

.cart-item__body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-right: 24px; /* room for X */
}
.cart-item__brand {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--black-5);
}
.cart-item__title {
  font-size: 13px;
  font-weight: 700;
  line-height: 1.35;
  color: var(--black-1);
  text-decoration: none;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.cart-item__title:hover { color: var(--red); }
.cart-item__meta {
  font-size: 11px;
  color: var(--black-4);
  font-weight: 600;
  letter-spacing: 0.02em;
}

/* Bottom row: qty + price */
.cart-item__bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 6px;
  gap: 8px;
}
.cart-item__qty {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--black-9);
  border-radius: 3px;
  overflow: hidden;
}
.cart-item__qty-btn {
  width: 26px;
  height: 26px;
  background: var(--white);
  border: 0;
  font-size: 13px;
  color: var(--black-3);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s;
}
.cart-item__qty-btn:hover { background: var(--black-10); }
.cart-item__qty-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.cart-item__qty-num {
  display: inline-block;
  min-width: 24px;
  height: 26px;
  text-align: center;
  font-size: 12px;
  font-weight: 700;
  line-height: 26px;
  background: var(--white);
}
.cart-item__price {
  font-size: 13px;
  font-weight: 800;
  color: var(--black-0, var(--black));
}
.cart-item__price .woocommerce-Price-amount { font-size: inherit; }

/* Remove (×) button */
.cart-item__remove {
  position: absolute;
  top: 14px;
  right: 18px;
  width: 22px;
  height: 22px;
  background: transparent;
  border: 0;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--black-6);
  transition: background 0.15s, color 0.15s;
}
.cart-item__remove:hover {
  background: var(--black-10);
  color: var(--red);
}

/* ===== SUMMARY ===== */
.cart-drawer__summary {
  padding: 16px 24px;
  border-top: 1px solid var(--black-9);
  background: var(--white);
}
.cart-drawer__row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: 13px;
  margin-bottom: 8px;
}
.cart-drawer__row:last-child { margin-bottom: 0; }
.cart-drawer__row .woocommerce-Price-amount { font-size: inherit; }

.cart-drawer__row--discount {
  color: #2E7D32;
  font-weight: 700;
  font-size: 13px;
}

.cart-drawer__row--shipping {
  color: var(--black-4);
  font-size: 12px;
  margin-bottom: 12px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--black-9);
}
.cart-drawer__shipping-note {
  font-style: italic;
}

.cart-drawer__row--total {
  font-size: 16px;
  font-weight: 800;
  color: var(--black-0, var(--black));
  padding-top: 4px;
}
.cart-drawer__total-amount .woocommerce-Price-amount {
  font-size: 18px;
  font-weight: 800;
}

/* ===== FOOTER CTAs ===== */
.cart-drawer__foot {
  display: flex;
  gap: 8px;
  padding: 16px 24px 20px;
  background: var(--white);
  border-top: 1px solid var(--black-9);
  flex-shrink: 0;
}
.cart-drawer__cta {
  flex: 1;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: 4px;
  text-decoration: none;
  transition: background 0.18s, color 0.18s, border-color 0.18s;
}
.cart-drawer__cta--ghost {
  background: var(--white);
  color: var(--black-0, var(--black));
  border: 1.5px solid var(--black-0, var(--black));
}
.cart-drawer__cta--ghost:hover {
  background: var(--black-10);
}
.cart-drawer__cta--primary {
  background: var(--black-0, var(--black));
  color: var(--white);
  border: 1.5px solid var(--black-0, var(--black));
}
.cart-drawer__cta--primary:hover {
  background: var(--red);
  border-color: var(--red);
}

/* ===== TOAST NOTIFICATION ===== */
.trk-toast {
  position: fixed;
  top: 24px;
  right: 24px;
  z-index: 10000;
  background: var(--black-0, var(--black));
  color: var(--white);
  padding: 12px 20px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 10px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.18);
  transform: translateY(-12px);
  opacity: 0;
  pointer-events: none;
  transition: transform 0.3s, opacity 0.3s;
}
.trk-toast.is-visible {
  transform: translateY(0);
  opacity: 1;
}
.trk-toast--error {
  background: var(--red);
}
.trk-toast__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  background: rgba(255,255,255,0.15);
  border-radius: 50%;
}

/* ===== MOBILE ===== */
@media (max-width: 1023px) {
  .cart-drawer__panel {
    max-width: 100%;
  }
  .cart-drawer__head {
    padding: 16px 18px;
  }
  .cart-drawer__title { font-size: 14px; }
  .cart-drawer__shipping-progress {
    padding: 14px 18px;
  }
  .cart-item {
    padding: 14px 18px;
  }
  .cart-drawer__summary {
    padding: 14px 18px;
  }
  .cart-drawer__foot {
    padding: 14px 18px 16px;
  }
  .trk-toast {
    top: 14px;
    left: 14px;
    right: 14px;
    width: auto;
    justify-content: center;
  }
}


/* ============================================================
   PHASE 6 — CART PAGE
   ============================================================ */

.cart-page {
  max-width: 1280px;
  margin: 0 auto;
  padding: 24px 32px 80px;
}

/* Breadcrumb */
.cart-page__breadcrumb {
  font-size: 12px;
  color: var(--black-4);
  margin-bottom: 24px;
  display: flex;
  align-items: center;
  gap: 8px;
  letter-spacing: 0.02em;
}
.cart-page__breadcrumb a {
  color: var(--black-3);
  text-decoration: none;
}
.cart-page__breadcrumb a:hover { color: var(--red); }
.cart-page__breadcrumb .sep { color: var(--black-7); }

/* Title */
.cart-page__title {
  font-size: 32px;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0 0 32px;
  display: flex;
  align-items: baseline;
  gap: 16px;
}
.cart-page__count {
  font-size: 14px;
  font-weight: 600;
  color: var(--black-4);
  letter-spacing: 0;
}

/* ===== EMPTY STATE ===== */
.cart-page__empty {
  text-align: center;
  padding: 100px 32px 80px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  color: var(--black-4);
}
.cart-page__empty svg {
  color: var(--black-7);
  margin-bottom: 8px;
}
.cart-page__empty-title {
  font-size: 28px;
  font-weight: 800;
  color: var(--black-1);
  margin: 0;
  letter-spacing: -0.02em;
}
.cart-page__empty-sub {
  font-size: 14px;
  margin: 0 0 8px;
  max-width: 420px;
  line-height: 1.55;
}
.cart-page__empty-cta {
  background: var(--black-0, var(--black));
  color: var(--white);
  padding: 14px 32px;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: 4px;
  text-decoration: none;
  transition: background 0.18s;
}
.cart-page__empty-cta:hover { background: var(--red); }

/* ===== LAYOUT (2-column) ===== */
.cart-page__layout {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 40px;
  align-items: start;
}

/* ===== ITEMS COLUMN ===== */
.cart-page__items {
  background: var(--white);
}

.cart-list {
  list-style: none;
  margin: 0;
  padding: 0;
  border: 1px solid var(--black-9);
  border-radius: 6px;
}
.cart-list__item {
  display: flex;
  gap: 18px;
  padding: 20px 24px;
  border-bottom: 1px solid var(--black-9);
  position: relative;
}
.cart-list__item:last-child { border-bottom: 0; }

.cart-list__media {
  flex-shrink: 0;
  width: 96px;
  height: 120px;
  background: var(--black-10);
  border-radius: 4px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cart-list__media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block;
}

.cart-list__body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding-right: 36px;
}
.cart-list__brand {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--black-5);
}
.cart-list__title {
  font-size: 15px;
  font-weight: 700;
  line-height: 1.35;
  color: var(--black-1);
  text-decoration: none;
  margin-bottom: 2px;
}
.cart-list__title:hover { color: var(--red); }
.cart-list__meta {
  font-size: 12px;
  color: var(--black-4);
  font-weight: 600;
}

/* Addons (Player Name, Number, Patch) */
.cart-list__addons {
  font-size: 12px;
  color: var(--black-3);
  margin-top: 4px;
  line-height: 1.6;
}
.cart-list__addons p {
  margin: 0 0 2px;
}
.cart-list__addons strong {
  color: var(--black-2);
  font-weight: 700;
}

/* Bottom row: qty + price */
.cart-list__bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 12px;
  gap: 16px;
}
.cart-list__qty {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--black-8);
  border-radius: 4px;
  overflow: hidden;
  background: var(--white);
}
.cart-list__qty-btn {
  width: 32px;
  height: 32px;
  background: var(--white);
  border: 0;
  font-size: 14px;
  color: var(--black-3);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s;
}
.cart-list__qty-btn:hover { background: var(--black-10); }
.cart-list__qty-input {
  width: 40px;
  height: 32px;
  border: 0;
  border-left: 1px solid var(--black-9);
  border-right: 1px solid var(--black-9);
  text-align: center;
  font-size: 13px;
  font-weight: 700;
  color: var(--black-1);
  background: var(--white);
  -moz-appearance: textfield;
}
.cart-list__qty-input::-webkit-outer-spin-button,
.cart-list__qty-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.cart-list__price {
  font-size: 16px;
  font-weight: 800;
  color: var(--black-0, var(--black));
}
.cart-list__price .woocommerce-Price-amount { font-size: inherit; }

/* Remove (×) button */
.cart-list__remove {
  position: absolute;
  top: 18px;
  right: 18px;
  width: 28px;
  height: 28px;
  background: transparent;
  border: 0;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--black-5);
  transition: background 0.15s, color 0.15s;
}
.cart-list__remove:hover {
  background: var(--black-10);
  color: var(--red);
}

/* Continue Shopping */
.cart-page__actions {
  margin-top: 24px;
}
.cart-page__continue {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 700;
  color: var(--black-2);
  text-decoration: none;
  letter-spacing: 0.02em;
}
.cart-page__continue:hover { color: var(--red); }

/* ===== SUMMARY COLUMN (sticky) ===== */
.cart-page__summary {
  position: sticky;
  top: 96px;
  background: var(--white);
  border: 1px solid var(--black-9);
  border-radius: 6px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.cart-page__summary-title {
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 4px;
  color: var(--black-1);
}

/* Free express progress */
.cart-page__shipping-progress {
  background: linear-gradient(135deg, #FFF6E5 0%, #FFE5E5 100%);
  border-radius: 4px;
  padding: 14px 16px;
  margin: -4px -4px 0;
}
.cart-page__shipping-progress .ship-progress__msg {
  font-size: 12px;
  color: var(--black-2);
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 6px;
  line-height: 1.45;
}
.cart-page__shipping-progress .ship-progress__msg strong {
  color: var(--black-0, var(--black));
  font-weight: 800;
}
.cart-page__shipping-progress .ship-progress__msg .woocommerce-Price-amount {
  font-weight: 800;
  font-size: inherit;
}
.cart-page__shipping-progress .ship-progress__msg--won {
  color: #2E7D32;
}
.cart-page__shipping-progress .ship-progress__msg--won strong {
  color: #2E7D32;
}
.cart-page__shipping-progress .ship-progress__bar {
  height: 5px;
  background: rgba(0,0,0,0.08);
  border-radius: 3px;
  overflow: hidden;
}
.cart-page__shipping-progress .ship-progress__fill {
  height: 100%;
  background: linear-gradient(90deg, var(--gold, #C29B3D), #E5B85A);
  border-radius: 3px;
  transition: width 0.4s ease;
}
.cart-page__shipping-progress .ship-progress__msg--won + .ship-progress__bar .ship-progress__fill {
  background: linear-gradient(90deg, #2E7D32, #4CAF50);
}

/* Summary rows */
.cart-page__rows {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.cart-page__row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: 13px;
  color: var(--black-2);
}
.cart-page__row .woocommerce-Price-amount { font-size: inherit; }

.cart-page__row--discount {
  color: #2E7D32;
  font-weight: 700;
}

.cart-page__row--shipping {
  color: var(--black-4);
  font-size: 12px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--black-9);
}
.cart-page__shipping-note {
  font-style: italic;
}

.cart-page__row--total {
  font-size: 16px;
  font-weight: 800;
  color: var(--black-0, var(--black));
  margin-top: 2px;
}
.cart-page__total-amount .woocommerce-Price-amount {
  font-size: 20px;
  font-weight: 800;
}

/* Checkout button */
.cart-page__checkout-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--black-0, var(--black));
  color: var(--white);
  padding: 16px;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: 4px;
  text-decoration: none;
  transition: background 0.18s;
}
.cart-page__checkout-btn:hover { background: var(--red); }

/* Trust signals */
.cart-page__trust {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-top: 12px;
  border-top: 1px solid var(--black-9);
}
.cart-page__trust-row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  color: var(--black-5);
  font-weight: 600;
  letter-spacing: 0.02em;
}
.cart-page__trust-row svg {
  color: var(--black-3);
  flex-shrink: 0;
}

/* ===== CROSS-SELLS ===== */
.cart-page__crosssell {
  margin-top: 64px;
  padding-top: 48px;
  border-top: 1px solid var(--black-9);
}
.cart-page__crosssell-title {
  font-size: 14px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 24px;
}
.cart-page__crosssell .products {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  list-style: none;
  padding: 0;
  margin: 0;
}

/* ===== MOBILE / TABLET ===== */
@media (max-width: 1023px) {
  .cart-page {
    padding: 16px 16px 60px;
  }
  .cart-page__title {
    font-size: 24px;
    margin-bottom: 20px;
  }
  .cart-page__layout {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .cart-page__summary {
    position: static;
    padding: 20px;
  }
  .cart-list__item {
    padding: 16px;
    gap: 14px;
  }
  .cart-list__media {
    width: 80px;
    height: 100px;
  }
  .cart-list__body {
    padding-right: 30px;
  }
  .cart-list__title {
    font-size: 14px;
  }
  .cart-list__remove {
    top: 14px;
    right: 14px;
  }
  .cart-page__crosssell .products {
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }
}

@media (max-width: 599px) {
  .cart-page__title {
    font-size: 20px;
  }
  .cart-list__bottom {
    flex-wrap: wrap;
  }
}


/* ============================================================
   PHASE 6 — DEFAULT PAGE TEMPLATE
   ============================================================ */

.trk-page {
  /* Cart/checkout/my-account pages handle their own padding;
     other pages get this default container */
}

.trk-page__article > .trk-page__header,
.trk-page__article > .trk-page__content:not(:has(.cart-page)):not(:has(.checkout)):not(:has(.woocommerce-account)) {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 24px;
}

.trk-page__header {
  padding-top: 40px;
  padding-bottom: 24px;
}

.trk-page__title {
  font-size: 32px;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0;
}

@media (max-width: 1023px) {
  .trk-page__header {
    padding-top: 24px;
  }
  .trk-page__title {
    font-size: 24px;
  }
}


/* ============================================================
   PHASE 6 — CART PAGE UPSELL
   ============================================================ */

.cart-page__upsell {
  margin-top: 64px;
  padding-top: 48px;
  border-top: 1px solid var(--black-9);
}

.cart-page__upsell-title {
  font-size: 14px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 24px;
}

.cart-page__upsell-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

/* Reuse upsell-card styling from single product page */
.cart-page__upsell .upsell-card {
  display: block;
  text-decoration: none;
  color: inherit;
  background: var(--white);
  border: 1px solid var(--black-9);
  border-radius: 6px;
  overflow: hidden;
  transition: border-color 0.18s, transform 0.18s, box-shadow 0.18s;
}
.cart-page__upsell .upsell-card:hover {
  border-color: var(--black-6);
  transform: translateY(-2px);
  box-shadow: 0 4px 16px rgba(0,0,0,0.06);
}
.cart-page__upsell .upsell-card__media {
  aspect-ratio: 4 / 5;
  background: var(--black-10);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cart-page__upsell .upsell-card__media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block;
}
.cart-page__upsell .upsell-card__body {
  padding: 12px 14px 14px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.cart-page__upsell .upsell-card__brand {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--black-5);
}
.cart-page__upsell .upsell-card__title {
  font-size: 13px;
  font-weight: 700;
  line-height: 1.35;
  color: var(--black-1);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 36px;
}
.cart-page__upsell .upsell-card__price {
  font-size: 14px;
  font-weight: 800;
  color: var(--black-0, var(--black));
  margin-top: 2px;
}
.cart-page__upsell .upsell-card__price .woocommerce-Price-amount { font-size: inherit; }

/* MOBILE: 2 columns */
@media (max-width: 1023px) {
  .cart-page__upsell {
    margin-top: 40px;
    padding-top: 32px;
  }
  .cart-page__upsell-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
  }
}


/* ============================================================
   PHASE 6 — UPSELL QUICK ADD + MOBILE CAROUSEL
   ============================================================ */

/* Update upsell card to support quick-add overlay */
.cart-page__upsell .upsell-card {
  position: relative;
  display: flex;
  flex-direction: column;
}

.cart-page__upsell .upsell-card__link {
  display: block;
  text-decoration: none;
  color: inherit;
}

/* Quick add (+) button — bottom-right corner of card */
.upsell-card__quickadd-btn {
  position: absolute;
  top: 8px;
  right: 8px;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--white);
  color: var(--black-1);
  border: 1px solid var(--black-9);
  border-radius: 999px;
  padding: 6px 10px 6px 8px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
  transition: background 0.18s, color 0.18s, border-color 0.18s, transform 0.18s;
  z-index: 2;
}
.upsell-card__quickadd-btn:hover {
  background: var(--black-0, var(--black));
  color: var(--white);
  border-color: var(--black-0, var(--black));
  transform: translateY(-1px);
}
.upsell-card__quickadd-btn span {
  text-transform: uppercase;
}

/* Sizes overlay (slides up from bottom of card when quick-add tapped) */
.upsell-card__sizes {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--white);
  border-top: 1px solid var(--black-9);
  padding: 14px 14px 14px;
  z-index: 3;
  border-radius: 0 0 6px 6px;
  animation: trkSizesSlideUp 0.22s ease forwards;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.upsell-card__sizes[hidden] {
  display: none;
}

@keyframes trkSizesSlideUp {
  from { transform: translateY(100%); opacity: 0; }
  to   { transform: translateY(0); opacity: 1; }
}

.upsell-card__sizes-loading {
  font-size: 11px;
  color: var(--black-4);
  text-align: center;
  padding: 8px 0;
}

.upsell-card__sizes-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(40px, 1fr));
  gap: 5px;
}

.upsell-card__size-pill {
  height: 32px;
  border: 1px solid var(--black-8);
  background: var(--white);
  border-radius: 3px;
  font-size: 12px;
  font-weight: 700;
  color: var(--black-1);
  cursor: pointer;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.upsell-card__size-pill:hover {
  background: var(--black-0, var(--black));
  color: var(--white);
  border-color: var(--black-0, var(--black));
}
.upsell-card__size-pill:disabled,
.upsell-card__size-pill--out {
  opacity: 0.35;
  cursor: not-allowed;
  text-decoration: line-through;
}

.upsell-card__size-pill--loading {
  opacity: 0.5;
  pointer-events: none;
}

.upsell-card__sizes-close {
  position: absolute;
  top: 6px;
  right: 6px;
  width: 22px;
  height: 22px;
  background: transparent;
  border: 0;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--black-5);
  transition: background 0.15s, color 0.15s;
}
.upsell-card__sizes-close:hover {
  background: var(--black-10);
  color: var(--black-0, var(--black));
}

/* ===== MOBILE CAROUSEL ===== */
@media (max-width: 1023px) {
  .cart-page__upsell-grid {
    /* Override grid to flex carousel */
    display: flex;
    grid-template-columns: none;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    gap: 12px;
    padding: 4px 0 16px;
    margin: 0 -16px; /* extend to viewport edge */
    padding-left: 16px;
    padding-right: 16px;
  }
  .cart-page__upsell-grid::-webkit-scrollbar { display: none; }

  /* 1 card per slide with peek of next (~12% peek) */
  .cart-page__upsell .upsell-card {
    flex: 0 0 86%;
    max-width: 86%;
    scroll-snap-align: start;
  }

  /* Wrapper to hold arrows + dots */
  .cart-page__upsell-wrap {
    position: relative;
  }

  .upsell-card__quickadd-btn {
    /* Bigger tap target on mobile */
    padding: 8px 12px 8px 10px;
    font-size: 12px;
  }
}

/* Carousel arrows (desktop on larger screens, hidden mobile — swipe instead) */
.cart-page__upsell-arrow {
  display: none; /* off by default on desktop (no carousel needed) */
}

@media (max-width: 1023px) {
  /* Carousel dots */
  .cart-page__upsell-dots {
    display: flex;
    justify-content: center;
    gap: 6px;
    margin-top: 14px;
  }
  .cart-page__upsell-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--black-7);
    border: 0;
    padding: 0;
    cursor: pointer;
    transition: background 0.15s, width 0.15s;
  }
  .cart-page__upsell-dot--active {
    background: var(--black-0, var(--black));
    width: 22px;
    border-radius: 3px;
  }
}

/* On desktop, hide dots (4-up grid, no carousel) */
@media (min-width: 1024px) {
  .cart-page__upsell-dots {
    display: none;
  }
}


/* ============================================================
   PHASE 6 — CHECKOUT (CLASSIC SHORTCODE) — full mockup port
   Maps approved mockup design to classic WooCommerce checkout DOM.
   ============================================================ */

/* ===== PAGE WRAPPER ===== */
body.trk-classic-checkout main#main {
  background: #ffffff;
}

body.trk-classic-checkout .page-title,
body.trk-classic-checkout .entry-title {
  display: none !important;
}

/* Hide "You may be interested in" / cross-sells on checkout */
body.trk-classic-checkout .cross-sells {
  display: none !important;
}

.trk-checkout-page {
  max-width: 1280px;
  margin: 24px auto 80px;
  padding: 0 32px;
}

@media (max-width: 1023px) {
  .trk-checkout-page {
    padding: 0 16px;
    margin: 16px auto 100px;
  }
}

/* ===== PAGE HEADER ===== */
.trk-checkout-header {
  margin-bottom: 36px;
}
.trk-checkout-header__title {
  font-family: 'Manrope', sans-serif;
  font-weight: 800;
  font-size: 38px;
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--black-0);
  margin: 0 0 4px;
}
.trk-checkout-header__sub {
  font-size: 13px;
  color: var(--black-4);
  margin: 0;
}
.trk-checkout-header__sub a {
  color: var(--red);
  font-weight: 600;
  text-decoration: none;
}
.trk-checkout-header__sub a:hover { text-decoration: underline; }
.trk-checkout-header__divider { color: var(--black-7); }

@media (max-width: 767px) {
  .trk-checkout-header { margin-bottom: 24px; }
  .trk-checkout-header__title { font-size: 28px; }
  .trk-checkout-header__sub { font-size: 12px; }
}

/* ===== TWO-COLUMN GRID ===== */
.trk-checkout-grid {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 64px;
  align-items: start;
}

@media (max-width: 1023px) {
  .trk-checkout-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .trk-checkout-right { order: -1; } /* summary on top mobile */
}

.trk-checkout-left {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

/* ===== SECTION CARDS ===== */
.trk-checkout-section {
  background: #ffffff;
  border: 1px solid var(--black-9);
  border-radius: 8px;
  padding: 28px 32px;
}

@media (max-width: 767px) {
  .trk-checkout-section { padding: 20px 18px; }
}

.trk-section-title,
.trk-checkout-section h3 {
  font-family: 'Manrope', sans-serif !important;
  font-weight: 800 !important;
  font-size: 20px !important;
  letter-spacing: -0.015em !important;
  color: var(--black-0) !important;
  margin: 0 0 20px !important;
  padding: 0 !important;
}

@media (max-width: 767px) {
  .trk-section-title,
  .trk-checkout-section h3 {
    font-size: 18px !important;
    margin-bottom: 16px !important;
  }
}

#customer_details h3 {
  font-family: 'Manrope', sans-serif !important;
  font-weight: 800 !important;
  font-size: 20px !important;
  letter-spacing: -0.015em !important;
  color: var(--black-0) !important;
  margin: 0 0 20px !important;
}

#customer_details .col-1,
#customer_details .col-2 {
  width: 100%;
  max-width: none;
  float: none;
  padding: 0;
  margin: 0 0 24px;
}
#customer_details .col-2 { margin-bottom: 0; }

/* ===== FORM FIELDS — floating label ===== */
.trk-checkout-section .form-row,
.woocommerce-billing-fields .form-row,
.woocommerce-shipping-fields .form-row,
.woocommerce-additional-fields .form-row {
  margin: 0 0 12px !important;
  padding: 0 !important;
  position: relative !important;
  width: 100% !important;
  display: block !important;
}

/* Two-column rows (first/last name) */
.form-row.form-row-first,
.form-row.form-row-last {
  width: calc(50% - 6px) !important;
  display: inline-block !important;
}
.form-row.form-row-first { margin-right: 12px !important; }

@media (max-width: 599px) {
  .form-row.form-row-first,
  .form-row.form-row-last {
    width: 100% !important;
    margin-right: 0 !important;
    display: block !important;
  }
}

/* Labels floating */
.trk-checkout-section .form-row label,
.woocommerce-billing-fields .form-row label,
.woocommerce-shipping-fields .form-row label,
.woocommerce-additional-fields .form-row label {
  position: absolute !important;
  top: 16px !important;
  left: 16px !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  color: var(--black-4) !important;
  pointer-events: none !important;
  transition: all 0.16s ease !important;
  background: transparent !important;
  margin: 0 !important;
  padding: 0 !important;
  z-index: 2 !important;
  line-height: 1 !important;
}

.trk-checkout-section .form-row .required {
  color: var(--red);
  margin-left: 2px;
}

/* When focused or filled */
.trk-checkout-section .form-row input:focus + label,
.trk-checkout-section .form-row input:not(:placeholder-shown) + label,
.trk-checkout-section .form-row select:focus + label,
.trk-checkout-section .form-row.woocommerce-validated label,
.trk-checkout-section .form-row.woocommerce-invalid label {
  top: 6px !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: var(--black-2) !important;
}

/* Hide labels' native position before our absolute kicks in */
.trk-checkout-section .form-row > label:first-child {
  display: block !important;
}

/* Inputs */
.trk-checkout-section input[type="text"],
.trk-checkout-section input[type="email"],
.trk-checkout-section input[type="tel"],
.trk-checkout-section input[type="number"],
.trk-checkout-section input[type="password"],
.trk-checkout-section select,
.trk-checkout-section textarea,
.woocommerce-billing-fields input[type="text"],
.woocommerce-billing-fields input[type="email"],
.woocommerce-billing-fields input[type="tel"],
.woocommerce-billing-fields select,
.woocommerce-shipping-fields input[type="text"],
.woocommerce-shipping-fields input[type="tel"],
.woocommerce-shipping-fields select {
  width: 100% !important;
  border: 1px solid var(--black-8) !important;
  border-radius: 6px !important;
  padding: 22px 16px 8px !important;
  font-size: 14px !important;
  font-family: inherit !important;
  background: #ffffff !important;
  color: var(--black-0) !important;
  min-height: 56px !important;
  line-height: 1.4 !important;
  transition: border-color 0.18s ease, box-shadow 0.18s ease !important;
  appearance: none !important;
  -webkit-appearance: none !important;
}

.trk-checkout-section select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%231a1a1a' stroke-width='1.5' d='M1 1.5l5 5 5-5'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 16px center !important;
}

.trk-checkout-section input:focus,
.trk-checkout-section select:focus,
.trk-checkout-section textarea:focus {
  outline: none !important;
  border-color: var(--black-0) !important;
  box-shadow: 0 0 0 3px rgba(0,0,0,0.06) !important;
}

@media (max-width: 767px) {
  .trk-checkout-section input,
  .trk-checkout-section select,
  .trk-checkout-section textarea {
    font-size: 16px !important; /* prevent iOS zoom */
  }
}

/* Hide validation icons (woocommerce check / cross) */
.woocommerce-input-wrapper .woocommerce-input-wrapper__icon,
.form-row.woocommerce-validated .input-text + .woocommerce-input-wrapper__icon { display: none !important; }

/* select2 (used for country/state) */
.select2-container .select2-selection--single,
.select2-selection--single {
  height: 56px !important;
  border: 1px solid var(--black-8) !important;
  border-radius: 6px !important;
  padding: 22px 16px 8px !important;
  display: flex !important;
  align-items: center !important;
}
.select2-container .select2-selection--single .select2-selection__rendered {
  line-height: 1 !important;
  padding: 0 !important;
  color: var(--black-0) !important;
  font-size: 14px !important;
}
.select2-container .select2-selection--single .select2-selection__arrow {
  height: 56px !important;
  right: 12px !important;
}
.select2-dropdown {
  border: 1px solid var(--black-8) !important;
  border-radius: 6px !important;
  font-family: 'Manrope', sans-serif !important;
}

/* Checkboxes */
.trk-checkout-section .form-row.create-account,
.trk-checkout-section #ship-to-different-address,
.woocommerce-form__label-for-checkbox {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  font-size: 13px !important;
  color: var(--black-2) !important;
  cursor: pointer !important;
  font-weight: 500 !important;
  margin: 12px 0 0 !important;
}

.woocommerce-form__label-for-checkbox input[type="checkbox"],
.trk-checkout-section .input-checkbox {
  width: 20px !important;
  height: 20px !important;
  margin: 0 !important;
  border: 1.5px solid var(--black-7) !important;
  border-radius: 4px !important;
  cursor: pointer !important;
  accent-color: var(--black-0) !important;
}

#ship-to-different-address h3 {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--black-2) !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  margin: 0 !important;
  display: inline-block !important;
}
#ship-to-different-address h3 label {
  position: static !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}

/* ===== ORDER REVIEW (payment methods + place order) ===== */
.trk-review-order {
  margin-top: 24px;
}

.trk-payment-methods {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 20px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
}

.trk-payment-methods .wc_payment_method,
.trk-payment-methods .payment_method_stripe,
.trk-payment-methods li {
  border: 1.5px solid var(--black-9) !important;
  border-radius: 8px !important;
  padding: 0 !important;
  margin: 0 !important;
  background: #ffffff !important;
  overflow: hidden !important;
  transition: all 0.16s ease !important;
}

.trk-payment-methods li:hover {
  border-color: var(--black-6) !important;
}

.trk-payment-methods li.active,
.trk-payment-methods .wc_payment_method.active {
  border-color: var(--black-0) !important;
  box-shadow: 0 0 0 1px var(--black-0) inset !important;
}

.trk-payment-methods label {
  padding: 16px 18px !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  cursor: pointer !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  color: var(--black-0) !important;
  margin: 0 !important;
  position: static !important;
}

.trk-payment-methods input[type="radio"] {
  width: 20px !important;
  height: 20px !important;
  margin: 0 !important;
  accent-color: var(--black-0) !important;
}

.trk-payment-methods .payment_box {
  padding: 0 18px 18px !important;
  border-top: 1px solid var(--black-9) !important;
  margin-top: 0 !important;
  background: var(--black-10) !important;
  font-size: 12px !important;
  color: var(--black-3) !important;
}

.trk-payment-methods .payment_box p {
  margin: 12px 0 !important;
  line-height: 1.5 !important;
}

/* Stripe Elements iframe wrapper */
.trk-payment-methods .wc-stripe-payment-element-wrapper {
  background: #ffffff !important;
  border: 1px solid var(--black-9) !important;
  border-radius: 6px !important;
  padding: 14px !important;
  margin-top: 12px !important;
}

/* ===== TERMS ===== */
.trk-place-order .woocommerce-terms-and-conditions-wrapper {
  font-size: 12px !important;
  color: var(--black-4) !important;
  margin-bottom: 16px !important;
  padding: 0 !important;
  line-height: 1.6 !important;
}
.trk-place-order .woocommerce-terms-and-conditions-wrapper a {
  color: var(--black-1) !important;
  text-decoration: underline !important;
  font-weight: 600 !important;
}

/* ===== PLACE ORDER BUTTON ===== */
.trk-place-order-btn {
  background: var(--black-0) !important;
  color: #ffffff !important;
  border: 0 !important;
  border-radius: 6px !important;
  padding: 22px 24px !important;
  font-family: 'Manrope', sans-serif !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  width: 100% !important;
  cursor: pointer !important;
  transition: background 0.18s ease, transform 0.12s ease !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 12px !important;
  text-align: center !important;
}

.trk-place-order-btn:hover {
  background: var(--red) !important;
  transform: translateY(-1px) !important;
}

.trk-place-order-btn__price {
  font-family: 'Manrope', sans-serif !important;
  font-weight: 800 !important;
  font-size: 16px !important;
  letter-spacing: -0.01em !important;
}

.trk-place-order-btn__price .amount {
  font-weight: 800 !important;
}

@media (max-width: 767px) {
  .trk-place-order-btn {
    padding: 18px 20px !important;
    font-size: 13px !important;
    letter-spacing: 0.1em !important;
  }
  .trk-place-order-btn__price { font-size: 15px !important; }
}

/* ===== MINI SUMMARY (right column) ===== */
.trk-mini-summary {
  background: #ffffff;
  border: 1px solid var(--black-9);
  border-radius: 8px;
  padding: 28px;
  position: sticky;
  top: 96px;
}

@media (max-width: 1023px) {
  .trk-mini-summary {
    position: static;
    padding: 20px;
  }
}

.trk-mini-summary__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding-bottom: 16px;
  margin-bottom: 16px;
  border-bottom: 1px solid var(--black-9);
}
.trk-mini-summary__title {
  font-family: 'Manrope', sans-serif;
  font-weight: 800;
  font-size: 20px;
  letter-spacing: -0.015em;
  color: var(--black-0);
  margin: 0;
}
.trk-mini-summary__count {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--black-5);
}

@media (max-width: 767px) {
  /* Mobile: collapsible summary */
  .trk-mini-summary__head {
    cursor: pointer;
    padding-bottom: 0;
    margin-bottom: 0;
    border-bottom: 0;
  }
  .trk-mini-summary__head::after {
    content: '▼';
    font-size: 10px;
    color: var(--black-4);
    margin-left: 8px;
    transition: transform 0.2s ease;
  }
  .trk-mini-summary--open .trk-mini-summary__head::after {
    transform: rotate(180deg);
  }
  .trk-mini-summary__items,
  .trk-mini-summary__coupon,
  .trk-mini-summary__totals {
    display: none;
  }
  .trk-mini-summary--open .trk-mini-summary__items,
  .trk-mini-summary--open .trk-mini-summary__coupon,
  .trk-mini-summary--open .trk-mini-summary__totals {
    display: block;
  }
  .trk-mini-summary--open .trk-mini-summary__items {
    padding-top: 16px;
    margin-top: 16px;
    border-top: 1px solid var(--black-9);
  }
  .trk-mini-summary__title { font-size: 18px; }
  .trk-mini-summary__total { margin-top: 12px; padding-top: 12px; }
}

/* Items */
.trk-mini-summary__items {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding-bottom: 16px;
  margin-bottom: 16px;
  border-bottom: 1px solid var(--black-9);
}

.trk-mini-item {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}

.trk-mini-item__media {
  position: relative;
  width: 64px;
  height: 80px;
  border: 1px solid var(--black-9);
  border-radius: 4px;
  overflow: hidden;
  flex-shrink: 0;
  background: var(--black-10);
}
.trk-mini-item__media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}
.trk-mini-item__qty {
  position: absolute;
  top: -8px;
  right: -8px;
  width: 22px;
  height: 22px;
  background: var(--black-0);
  color: #ffffff;
  font-size: 11px;
  font-weight: 800;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.trk-mini-item__details { flex: 1; min-width: 0; }
.trk-mini-item__brand {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--black-5);
  margin-bottom: 2px;
}
.trk-mini-item__title {
  font-size: 13px;
  font-weight: 700;
  color: var(--black-0);
  line-height: 1.3;
  margin-bottom: 4px;
}
.trk-mini-item__meta {
  font-size: 11px;
  color: var(--black-4);
  line-height: 1.5;
}
.trk-mini-item__addons {
  font-size: 11px;
  color: var(--black-4);
  margin-top: 4px;
}
.trk-mini-item__addons span { display: block; }
.trk-mini-item__price {
  font-family: 'Manrope', sans-serif;
  font-weight: 800;
  font-size: 14px;
  letter-spacing: -0.01em;
  color: var(--black-0);
  white-space: nowrap;
}

/* Coupon */
.trk-mini-summary__coupon {
  padding-bottom: 16px;
  margin-bottom: 16px;
  border-bottom: 1px solid var(--black-9);
}
.trk-coupon-toggle {
  width: 100%;
  background: transparent;
  border: 0;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  color: var(--black-1);
  font-family: inherit;
}
.trk-coupon-toggle:hover { color: var(--red); }
.trk-coupon-toggle__icon {
  font-size: 18px;
  font-weight: 400;
  transition: transform 0.2s;
}
.trk-coupon-toggle[aria-expanded="true"] .trk-coupon-toggle__icon {
  transform: rotate(45deg);
}

.trk-coupon-form {
  display: flex;
  gap: 8px;
  margin-top: 12px;
}
.trk-coupon-form input {
  flex: 1;
  border: 1px solid var(--black-8) !important;
  border-radius: 6px !important;
  padding: 10px 14px !important;
  font-size: 13px !important;
  font-family: inherit !important;
  background: #ffffff !important;
  color: var(--black-0) !important;
}
.trk-coupon-apply {
  background: var(--black-0);
  color: #ffffff;
  border: 0;
  border-radius: 6px;
  padding: 10px 18px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.18s;
  font-family: inherit;
}
.trk-coupon-apply:hover { background: var(--red); }

/* Totals rows */
.trk-mini-summary__totals {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.trk-totals-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 13px;
}
.trk-totals-row__label {
  color: var(--black-3);
  font-weight: 500;
}
.trk-totals-row__value {
  font-family: 'Manrope', sans-serif;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--black-0);
}
.trk-totals-row--discount .trk-totals-row__value {
  color: var(--red);
}
.trk-totals-row--shipping-free .trk-totals-row__value {
  color: var(--green);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

/* Total */
.trk-mini-summary__total {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 2px solid var(--black-0);
}
.trk-mini-summary__total-label {
  font-family: 'Manrope', sans-serif;
  font-weight: 800;
  font-size: 16px;
  letter-spacing: -0.015em;
  color: var(--black-0);
}
.trk-mini-summary__total-value {
  font-family: 'Manrope', sans-serif;
  font-weight: 800;
  font-size: 28px;
  letter-spacing: -0.025em;
  color: var(--black-0);
}
.trk-mini-summary__total-value .amount {
  font-weight: 800 !important;
}

/* ===== TRUST SIGNALS (bottom) ===== */
.trk-checkout-trust {
  display: flex;
  gap: 24px;
  justify-content: center;
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--black-9);
  flex-wrap: wrap;
}
.trk-checkout-trust__item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--black-4);
}
.trk-checkout-trust__icon {
  color: var(--red);
  display: inline-flex;
}
.trk-checkout-trust__icon svg {
  width: 16px;
  height: 16px;
}

@media (max-width: 767px) {
  .trk-checkout-trust {
    gap: 12px;
    flex-direction: column;
    align-items: center;
  }
}

/* ===== STRIPE PAYMENT REQUEST BUTTON (Apple Pay / Google Pay) ===== */
/* When Stripe enabled, it injects an express button at top via wp_loaded hook */
#wc-stripe-payment-request-wrapper,
.wc-stripe-payment-request-wrapper {
  background: #ffffff !important;
  border: 1px solid var(--black-9) !important;
  border-radius: 8px !important;
  padding: 24px !important;
  margin-bottom: 16px !important;
}
#wc-stripe-payment-request-button-separator {
  text-align: center !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--black-5) !important;
  margin: 16px 0 !important;
  position: relative !important;
}
#wc-stripe-payment-request-button-separator::before,
#wc-stripe-payment-request-button-separator::after {
  content: '';
  position: absolute;
  top: 50%;
  width: 30%;
  height: 1px;
  background: var(--black-9);
}
#wc-stripe-payment-request-button-separator::before { left: 0; }
#wc-stripe-payment-request-button-separator::after { right: 0; }

/* ===== HIDE EMPTY/UNNEEDED ELEMENTS ===== */
.woocommerce-checkout #payment .form-row.place-order { padding: 0 !important; }
.checkout #order_review_heading { display: none !important; }
.woocommerce-checkout-review-order-table { display: none !important; } /* default WC totals table — we render our own */

/* WC notices */
.woocommerce-checkout .woocommerce-NoticeGroup,
.woocommerce-checkout .woocommerce-error,
.woocommerce-checkout .woocommerce-message {
  border: 1px solid var(--black-9) !important;
  border-radius: 8px !important;
  padding: 14px 18px !important;
  margin: 0 0 16px !important;
  font-size: 13px !important;
  background: var(--black-10) !important;
  color: var(--black-1) !important;
}
.woocommerce-checkout .woocommerce-error {
  background: #fff5f5 !important;
  border-color: #fecaca !important;
  color: var(--red-dark) !important;
}

/* ============================================================
   PHASE 6 — CHECKOUT V2 PORT — approved mockup, single block.
   Replaces: POST-PORT FIXES, PLACE ORDER mockup spec, POLISH,
   PLACE ORDER FINAL, MOCKUP VISUAL PASS. Maps mockup tokens to
   the real WC class names. Stripe UPE renders inside the
   payment-host card; gift card + order notes are wrapped into
   <details> collapsibles by main.js (PHASE 6 V2 IIFE).
   ============================================================ */

/* ---- Page wrapper ---- */
.trk-checkout-page {
    background: var(--black-10, #f7f5f2);
    padding: 40px 32px 96px;
    color: var(--black-0, #0e0e10);
    font-family: 'Manrope', sans-serif;
}
@media (max-width: 1023px) { .trk-checkout-page { padding: 28px 16px 96px; } }

/* ---- Header ---- */
.trk-checkout-header { max-width: 1280px; margin: 0 auto 36px; }
.trk-checkout-header__title {
    font-size: 44px; font-weight: 900; letter-spacing: -0.035em;
    line-height: 1; margin: 0 0 10px;
}
.trk-checkout-header__sub { font-size: 14px; color: var(--black-4, #5a5a5d); margin: 0; }
.trk-checkout-header__sub a { color: var(--red, #d0021b); text-decoration: none; font-weight: 600; }
.trk-checkout-header__sub a:hover { text-decoration: underline; }
.trk-checkout-header__divider { margin: 0 8px; color: var(--black-7, #d4d2cc); }
@media (max-width: 599px) { .trk-checkout-header__title { font-size: 32px; } }

/* ---- 2-col grid ---- */
.trk-checkout-grid {
    max-width: 1280px; margin: 0 auto;
    display: grid; grid-template-columns: 1fr 400px; gap: 48px; align-items: start;
}
.trk-checkout-left { min-width: 0; }
.trk-checkout-right { position: sticky; top: 24px; align-self: start; }
@media (max-width: 1023px) {
    .trk-checkout-grid { grid-template-columns: 1fr; gap: 24px; }
    .trk-checkout-right { position: static; order: -1; }
}

/* ---- Section cards ---- */
.trk-checkout-section,
.trk-checkout-form .trk-checkout-section {
    background: #fff !important;
    border: 1px solid var(--black-9, #f1efe8) !important;
    border-radius: 10px !important;
    padding: 26px 28px !important;
    margin: 0 0 16px !important;
    box-shadow: 0 1px 2px rgba(14,14,16,0.04);
}
@media (max-width: 599px) {
    .trk-checkout-section, .trk-checkout-form .trk-checkout-section { padding: 20px !important; }
}
.trk-section-title,
.trk-checkout-form .trk-section-title,
.trk-checkout-section h2,
.trk-checkout-section h3 {
    font-family: 'Manrope', sans-serif !important;
    font-size: 17px !important;
    font-weight: 800 !important;
    letter-spacing: -0.015em !important;
    color: var(--black-0, #0e0e10) !important;
    margin: 0 0 18px !important;
    text-transform: none !important;
    line-height: 1.3 !important;
}

/* ---- Fields (mockup spec mapped to p.form-row) ---- */
.trk-checkout-form p.form-row { position: relative !important; margin: 0 0 10px !important; padding: 0 !important; }
.trk-checkout-form p.form-row .woocommerce-input-wrapper { display: block; width: 100%; }
.trk-checkout-form p.form-row .input-text,
.trk-checkout-form p.form-row input[type="text"],
.trk-checkout-form p.form-row input[type="email"],
.trk-checkout-form p.form-row input[type="tel"],
.trk-checkout-form p.form-row input[type="number"],
.trk-checkout-form p.form-row input[type="password"],
.trk-checkout-form p.form-row select {
    width: 100% !important;
    padding: 22px 14px 8px !important;
    border: 1px solid var(--black-8, #e8e6df) !important;
    border-radius: 6px !important;
    font-family: 'Manrope', sans-serif !important;
    font-size: 14px !important;
    background: #fff !important;
    color: var(--black-1, #1a1a1d) !important;
    transition: border-color 0.16s ease, box-shadow 0.16s ease !important;
    appearance: none !important;
    -webkit-appearance: none !important;
    line-height: 1.4 !important;
}
.trk-checkout-form p.form-row textarea {
    width: 100% !important;
    padding: 26px 14px 12px !important;
    border: 1px solid var(--black-8, #e8e6df) !important;
    border-radius: 6px !important;
    min-height: 80px !important;
    resize: vertical !important;
    font-size: 14px !important;
    line-height: 1.4 !important;
    font-family: 'Manrope', sans-serif !important;
}
.trk-checkout-form p.form-row .input-text:focus,
.trk-checkout-form p.form-row select:focus,
.trk-checkout-form p.form-row textarea:focus {
    outline: none !important;
    border-color: var(--black-1, #1a1a1d) !important;
    box-shadow: 0 0 0 3px rgba(0,0,0,0.06) !important;
}
.trk-checkout-form p.form-row .input-text::placeholder,
.trk-checkout-form p.form-row textarea::placeholder { color: transparent !important; }
.trk-checkout-form p.form-row .input-text:focus::placeholder,
.trk-checkout-form p.form-row textarea:focus::placeholder { color: var(--black-5, #7a7a7e) !important; }

.trk-checkout-form p.form-row select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%231a1a1a' stroke-width='1.5' d='M1 1.5l5 5 5-5'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 14px center !important;
    cursor: pointer !important;
}

/* Floating label */
.trk-checkout-form p.form-row > label {
    position: absolute !important;
    top: 14px !important; left: 14px !important;
    font-size: 13px !important; font-weight: 400 !important;
    color: var(--black-4, #5a5a5d) !important;
    pointer-events: none !important;
    transition: all 0.14s ease !important;
    background: transparent !important;
    z-index: 1 !important;
    line-height: 1 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    margin: 0 !important;
}
.trk-checkout-form p.form-row > label .required,
.trk-checkout-form p.form-row > label .optional {
    color: var(--red, #d0021b) !important; text-decoration: none; margin-left: 2px;
}
.trk-checkout-form p.form-row:has(.input-text:focus) > label,
.trk-checkout-form p.form-row:has(.input-text:not(:placeholder-shown)) > label,
.trk-checkout-form p.form-row:has(input:focus) > label,
.trk-checkout-form p.form-row:has(input:not(:placeholder-shown)) > label,
.trk-checkout-form p.form-row:has(select) > label,
.trk-checkout-form p.form-row:has(textarea:focus) > label,
.trk-checkout-form p.form-row:has(textarea:not(:placeholder-shown)) > label {
    top: 7px !important;
    font-size: 9px !important;
    font-weight: 700 !important;
    letter-spacing: 0.1em !important;
    text-transform: uppercase !important;
    color: var(--black-3, #3d3d42) !important;
}

/* First/Last name on one row */
.trk-checkout-form #billing_first_name_field,
.trk-checkout-form #shipping_first_name_field { width: calc(50% - 5px) !important; display: inline-block !important; vertical-align: top !important; margin-right: 8px !important; }
.trk-checkout-form #billing_last_name_field,
.trk-checkout-form #shipping_last_name_field { width: calc(50% - 5px) !important; display: inline-block !important; vertical-align: top !important; }
@media (max-width: 599px) {
    .trk-checkout-form #billing_first_name_field,
    .trk-checkout-form #billing_last_name_field,
    .trk-checkout-form #shipping_first_name_field,
    .trk-checkout-form #shipping_last_name_field { width: 100% !important; margin-right: 0 !important; display: block !important; }
}

/* ---- Custom checkbox ---- */
.trk-checkout-form input[type="checkbox"] {
    appearance: none !important; -webkit-appearance: none !important;
    width: 18px !important; height: 18px !important; min-width: 18px !important;
    border: 1.5px solid var(--black-7, #d4d2cc) !important;
    border-radius: 4px !important;
    background: #fff !important;
    cursor: pointer !important;
    margin: 0 8px 0 0 !important;
    flex: 0 0 18px !important;
    position: relative !important;
    transition: all 0.14s ease !important;
    vertical-align: top !important;
    padding: 0 !important;
}
.trk-checkout-form input[type="checkbox"]:hover { border-color: var(--black-3, #3d3d42) !important; }
.trk-checkout-form input[type="checkbox"]:checked {
    background: var(--black-0, #0e0e10) !important;
    border-color: var(--black-0, #0e0e10) !important;
}
.trk-checkout-form input[type="checkbox"]:checked::after {
    content: "" !important; position: absolute !important;
    top: 1px !important; left: 5px !important;
    width: 5px !important; height: 10px !important;
    border: solid #fff !important;
    border-width: 0 2px 2px 0 !important;
    transform: rotate(45deg) !important;
}

/* Checkbox row layout */
.trk-checkout-form p.form-row.checkbox,
.trk-checkout-form p.form-row.form-row-wide.create-account,
.trk-checkout-form p.form-row[id*="omnisend"],
.trk-checkout-form p.form-row[id*="marketing"],
.trk-checkout-form p.form-row[id*="sms"],
.trk-checkout-form p.form-row[id*="consent"],
.trk-checkout-form #ship-to-different-address,
.trk-checkout-form .woocommerce-terms-and-conditions-wrap p.form-row.terms {
    display: flex !important;
    align-items: flex-start !important;
    gap: 10px !important;
    margin: 14px 0 !important;
    padding: 0 !important;
    position: static !important;
    line-height: 1.5;
}
.trk-checkout-form p.form-row.checkbox > label,
.trk-checkout-form p.form-row[id*="omnisend"] > label,
.trk-checkout-form p.form-row[id*="marketing"] > label,
.trk-checkout-form p.form-row[id*="sms"] > label,
.trk-checkout-form p.form-row[id*="consent"] > label,
.trk-checkout-form #ship-to-different-address label,
.trk-checkout-form .woocommerce-terms-and-conditions-wrap label.checkbox,
.trk-checkout-form .woocommerce-form__label-for-checkbox {
    position: static !important;
    transform: none !important;
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
    font-size: 13px !important;
    font-weight: 400 !important;
    color: var(--black-2, #2a2a2e) !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    line-height: 1.5 !important;
    pointer-events: auto !important;
    cursor: pointer;
    flex: 1;
}

/* ---- Payment area as payment-host ---- */
.trk-checkout-form .woocommerce-checkout-payment,
#payment.woocommerce-checkout-payment {
    background: transparent !important;
    border: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
}
ul.wc_payment_methods,
.trk-payment-methods {
    list-style: none !important;
    margin: 0 !important; padding: 0 !important;
    display: flex !important; flex-direction: column !important; gap: 8px !important;
}
ul.wc_payment_methods li.wc_payment_method,
.trk-payment-methods li.wc_payment_method {
    border: 1.5px solid var(--black-8, #e8e6df) !important;
    border-radius: 8px !important;
    padding: 0 !important;
    background: #fff !important;
    overflow: hidden !important;
}
ul.wc_payment_methods > li.wc_payment_method:only-child > input[type="radio"],
ul.wc_payment_methods > li.wc_payment_method:only-child > label { display: none !important; }
ul.wc_payment_methods > li.wc_payment_method:only-child .payment_box {
    display: block !important;
    padding: 22px 20px !important;
    margin: 0 !important;
    background: transparent !important;
    border: 0 !important;
}
ul.wc_payment_methods > li.wc_payment_method:only-child .payment_box::before { display: none !important; }
.payment_box .form-row { margin: 0 0 12px !important; }
.payment_box p:empty { display: none !important; }

.woocommerce-privacy-policy-text {
    margin: 16px 0 14px !important;
    font-size: 11px !important;
    color: var(--black-5, #7a7a7e) !important;
    line-height: 1.6 !important;
}
.trk-checkout-form .woocommerce-terms-and-conditions-wrap { margin: 16px 0 18px !important; }

/* ---- Collapsibles (gift card + order notes, wrapped by JS) ---- */
.trk-collapse {
    background: #fff;
    border: 1px solid var(--black-9, #f1efe8);
    border-radius: 10px;
    margin: 0 0 10px;
    overflow: hidden;
    box-shadow: 0 1px 2px rgba(14,14,16,0.04);
}
.trk-collapse > summary {
    list-style: none;
    cursor: pointer;
    padding: 16px 22px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 13px;
    font-weight: 700;
    color: var(--black-2, #2a2a2e);
    user-select: none;
    gap: 12px;
}
.trk-collapse > summary::-webkit-details-marker { display: none; }
.trk-collapse__icon { display: inline-flex; align-items: center; gap: 8px; }
.trk-collapse__icon svg { width: 14px; height: 14px; color: var(--black-4, #5a5a5d); flex-shrink: 0; }
.trk-collapse__chev { width: 16px; height: 16px; transition: transform 0.18s ease; color: var(--black-5, #7a7a7e); flex-shrink: 0; }
.trk-collapse[open] .trk-collapse__chev { transform: rotate(180deg); }
.trk-collapse__body { padding: 14px 22px 22px; border-top: 1px solid var(--black-9, #f1efe8); }

/* Gift card form inside collapsible — neutralise plugin's own card styling */
.trk-collapse--giftcard .pwgc-redeem-gift-card-form,
.trk-collapse--giftcard .pwgc-redeem-gift-card,
.trk-collapse--giftcard [id^="pwgc_redeem"],
.trk-collapse--giftcard [id^="pwgc-redeem"] {
    background: transparent !important;
    border: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    box-shadow: none !important;
    display: grid !important;
    grid-template-columns: 1fr auto !important;
    gap: 10px !important;
    align-items: stretch !important;
    border-radius: 0 !important;
}
.trk-collapse--giftcard .pwgc-redeem-gift-card-form > p:first-child,
.trk-collapse--giftcard .pwgc-redeem-gift-card > p:first-child {
    grid-column: 1 / -1 !important;
    margin: 0 !important;
    display: none !important;
}
.trk-collapse--giftcard .pwgc-redeem-gift-card-form input[type="text"] {
    width: 100% !important;
    padding: 14px !important;
    border: 1px solid var(--black-8, #e8e6df) !important;
    border-radius: 6px !important;
    background: #fff !important;
    font-size: 14px !important;
    margin: 0 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    font-weight: 400 !important;
}
.trk-collapse--giftcard .pwgc-redeem-gift-card-form button,
.trk-collapse--giftcard .pwgc-redeem-gift-card-form input[type="submit"] {
    background: var(--black-0, #0e0e10) !important;
    color: #fff !important;
    border: 0 !important;
    padding: 0 18px !important;
    border-radius: 6px !important;
    font-weight: 700 !important;
    font-size: 12px !important;
    letter-spacing: 0.12em !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    margin: 0 !important;
    height: auto !important;
    min-height: 46px;
}
.trk-collapse--giftcard .pwgc-redeem-gift-card-form button:hover { background: var(--red, #d0021b) !important; }

/* Order notes inside collapsible */
.trk-collapse--notes #order_comments_field { margin: 0 !important; padding: 0 !important; position: static !important; }
.trk-collapse--notes #order_comments_field > label { display: none !important; }
.trk-collapse--notes textarea {
    width: 100% !important;
    border: 1px solid var(--black-8, #e8e6df) !important;
    border-radius: 6px !important;
    padding: 12px 14px !important;
    font-family: inherit !important;
    font-size: 13px !important;
    resize: vertical !important;
    min-height: 80px !important;
    background: #fff !important;
    color: var(--black-1, #1a1a1d) !important;
}

/* ---- Place Order (pseudo-element) ---- */
.trk-place-order-btn,
button#place_order.trk-place-order-btn,
button#place_order {
    width: 100% !important;
    background: var(--black-0, #0e0e10) !important;
    color: #fff !important;
    border: 0 !important;
    padding: 22px 24px !important;
    margin: 18px 0 0 !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    transition: background 0.18s ease, transform 0.12s ease !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 14px !important;
    font-family: 'Manrope', sans-serif !important;
    font-size: 0 !important;
    line-height: 1 !important;
    box-shadow: 0 4px 14px rgba(14,14,16,0.1) !important;
}
.trk-place-order-btn:hover, button#place_order:hover {
    background: var(--red, #d0021b) !important;
    transform: translateY(-1px) !important;
}
.trk-place-order-btn .trk-place-order-btn__label,
.trk-place-order-btn .trk-place-order-btn__price { display: none !important; }
.trk-place-order-btn::before {
    content: 'Place Order';
    font-size: 14px !important;
    font-weight: 800 !important;
    letter-spacing: 0.14em !important;
    text-transform: uppercase !important;
    color: #fff !important;
    line-height: 1.2;
}
.trk-place-order-btn[data-total]:not([data-total=""])::after {
    content: attr(data-total);
    font-size: 16px !important;
    font-weight: 800 !important;
    letter-spacing: -0.01em !important;
    color: #fff !important;
    text-transform: none !important;
    line-height: 1.2;
}
@media (max-width: 599px) {
    .trk-place-order-btn, button#place_order { padding: 18px 20px !important; }
    .trk-place-order-btn::before { font-size: 13px !important; letter-spacing: 0.1em !important; }
    .trk-place-order-btn[data-total]:not([data-total=""])::after { font-size: 15px !important; }
}

/* === PHASE 6 V2 PATCH 1 — payment + collapse fixes === */
/* WC default ul.wc_payment_methods has a 1px border + bg — kill them */
ul.wc_payment_methods,
.woocommerce-checkout ul.wc_payment_methods,
.trk-payment-methods {
    border: 0 !important;
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* Each li keeps OUR rounded card border, no inner separators */
ul.wc_payment_methods li.wc_payment_method,
.woocommerce-checkout ul.wc_payment_methods li.wc_payment_method {
    padding: 0 !important;
    background: #fff !important;
    margin: 0 !important;
    border-top: 1.5px solid var(--black-8, #e8e6df) !important;
    border-right: 1.5px solid var(--black-8, #e8e6df) !important;
    border-bottom: 1.5px solid var(--black-8, #e8e6df) !important;
    border-left: 1.5px solid var(--black-8, #e8e6df) !important;
    border-radius: 8px !important;
    box-shadow: none !important;
    overflow: hidden !important;
}
ul.wc_payment_methods li.wc_payment_method::before,
ul.wc_payment_methods li.wc_payment_method::after {
    display: none !important; content: none !important; border: 0 !important;
}

/* payment_box default has bg + ::before arrow + 1em padding — neutralise */
ul.wc_payment_methods .payment_box,
li.wc_payment_method .payment_box,
.woocommerce-checkout-payment .payment_box {
    background: transparent !important;
    color: var(--black-1, #1a1a1d) !important;
    border: 0 !important;
    border-radius: 0 !important;
    padding: 22px 20px !important;
    margin: 0 !important;
    box-shadow: none !important;
    line-height: 1.5 !important;
    position: relative !important;
}
.payment_box::before,
.payment_box::after,
ul.wc_payment_methods .payment_box::before,
ul.wc_payment_methods .payment_box::after {
    display: none !important;
    content: none !important;
    border: 0 !important;
    background: transparent !important;
}

/* Privacy text spacing — give it room above the gift card collapse */
.woocommerce-privacy-policy-text {
    margin: 18px 0 16px !important;
    padding: 0 !important;
    font-size: 11px !important;
    line-height: 1.6 !important;
    color: var(--black-5, #7a7a7e) !important;
}

/* Defensive: even if PWGC plugin's outer container has its own card chrome,
   strip it (we put OUR card chrome on the .trk-collapse wrapper instead) */
.pwgc-redeem-gift-card-form,
.pwgc-redeem-gift-card,
[class*="pwgc-redeem"]:not(input):not(button) {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}

/* === PHASE 6 V2 PATCH 2 — fieldset, terms row, pwgc IDs === */
/* Default <fieldset> has 2px groove border — THIS was the "double border" */
.payment_box fieldset,
.woocommerce-checkout-payment fieldset,
.wc_payment_method fieldset,
#wc-stripe-upe-form,
fieldset.wc-upe-form,
fieldset.wc-payment-form {
    border: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    min-width: 0 !important;
    background: transparent !important;
}
.payment_box fieldset legend { display: none !important; }
#wc-stripe-upe-errors:empty { display: none !important; }
#wc-stripe-hidden-style-input { display: none !important; }

/* .form-row.place-order is a DIV wrapper, not a field */
.trk-checkout-form .form-row.place-order,
form[name="checkout"] .form-row.place-order {
    background: transparent !important;
    border: 0 !important;
    padding: 0 !important;
    margin: 18px 0 0 !important;
    position: static !important;
    display: block !important;
    box-shadow: none !important;
}

/* Terms checkbox row — was being floating-labeled. Force flex row layout. */
.trk-checkout-form p.form-row:has(> label.checkbox),
.trk-checkout-form p.form-row:has(> label.woocommerce-form__label-for-checkbox) {
    display: flex !important;
    align-items: flex-start !important;
    gap: 0 !important;
    margin: 14px 0 !important;
    padding: 0 !important;
    position: static !important;
    line-height: 1.5 !important;
}
.trk-checkout-form p.form-row:has(> label.checkbox) > label,
.trk-checkout-form p.form-row:has(> label.woocommerce-form__label-for-checkbox) > label {
    position: static !important;
    transform: none !important;
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
    font-size: 13px !important;
    font-weight: 400 !important;
    color: var(--black-2, #2a2a2e) !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    line-height: 1.5 !important;
    pointer-events: auto !important;
    cursor: pointer !important;
    flex: 1 !important;
    display: flex !important;
    align-items: flex-start !important;
    gap: 10px !important;
    top: auto !important;
    left: auto !important;
}

/* PWGC plugin uses IDs, not classes — target both */
#pwgc-redeem-gift-card-form,
#pwgc-redeem-form,
.pwgc-redeem-gift-card-form,
.pwgc-redeem-gift-card {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* Hide duplicate "Have a gift card?" inner label */
#pwgc-redeem-form > label,
#pwgc-redeem-form label[for="pwgc-redeem-gift-card-number"] {
    display: none !important;
}
#pwgc-redeem-error:empty { display: none !important; }

/* Form layout: input + Apply button side by side */
.trk-collapse--giftcard #pwgc-redeem-form {
    display: grid !important;
    grid-template-columns: 1fr auto !important;
    gap: 10px !important;
    align-items: stretch !important;
}
.trk-collapse--giftcard #pwgc-redeem-error {
    grid-column: 1 / -1 !important;
    margin: 0 !important;
}

.trk-collapse--giftcard #pwgc-redeem-gift-card-number {
    width: 100% !important;
    padding: 14px !important;
    border: 1px solid var(--black-8, #e8e6df) !important;
    border-radius: 6px !important;
    background: #fff !important;
    font-size: 14px !important;
    line-height: 1.4 !important;
    margin: 0 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    font-weight: 400 !important;
    font-family: 'Manrope', sans-serif !important;
    color: var(--black-1, #1a1a1d) !important;
    box-sizing: border-box !important;
}
.trk-collapse--giftcard #pwgc-redeem-gift-card-number:focus {
    outline: none !important;
    border-color: var(--black-1, #1a1a1d) !important;
    box-shadow: 0 0 0 3px rgba(0,0,0,0.06) !important;
}

.trk-collapse--giftcard #pwgc-redeem-button {
    background: var(--black-0, #0e0e10) !important;
    color: #fff !important;
    border: 0 !important;
    padding: 0 18px !important;
    border-radius: 6px !important;
    font-weight: 700 !important;
    font-size: 12px !important;
    letter-spacing: 0.12em !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    margin: 0 !important;
    min-height: 46px !important;
    font-family: 'Manrope', sans-serif !important;
    display: block !important;
    line-height: 1 !important;
}
.trk-collapse--giftcard #pwgc-redeem-button:hover {
    background: var(--red, #d0021b) !important;
}

/* === PHASE 6 V2 PATCH 4 — notes-bottom styling + mobile === */
/* PHP-rendered notes collapsible at bottom of place-order area */
.trk-collapse--notes-bottom { margin-top: 0 !important; margin-bottom: 14px !important; }
.trk-collapse--notes-bottom .trk-collapse__body { padding: 14px 22px 22px !important; }

#trk-order-comments-bottom,
.trk-order-comments-textarea {
    width: 100% !important;
    border: 1px solid var(--black-8, #e8e6df) !important;
    border-radius: 6px !important;
    padding: 12px 14px !important;
    font-family: 'Manrope', sans-serif !important;
    font-size: 13px !important;
    resize: vertical !important;
    min-height: 80px !important;
    background: #fff !important;
    color: var(--black-1, #1a1a1d) !important;
    line-height: 1.4 !important;
    box-sizing: border-box !important;
}
#trk-order-comments-bottom:focus,
.trk-order-comments-textarea:focus {
    outline: none !important;
    border-color: var(--black-1, #1a1a1d) !important;
    box-shadow: 0 0 0 3px rgba(0,0,0,0.06) !important;
}
.trk-collapse__hint {
    display: block;
    margin-top: 8px;
    font-size: 11px;
    color: var(--black-5, #7a7a7e);
    line-height: 1.5;
}

/* Mobile optimisations */
@media (max-width: 599px) {
    .trk-checkout-page { padding: 20px 12px 88px !important; }
    .trk-checkout-header { margin: 0 auto 22px !important; }
    .trk-checkout-header__title { font-size: 28px !important; line-height: 1.05 !important; }
    .trk-checkout-header__sub { font-size: 12px !important; }
    .trk-checkout-grid { gap: 14px !important; }
    .trk-checkout-section,
    .trk-checkout-form .trk-checkout-section { padding: 18px 16px !important; margin: 0 0 12px !important; }
    .trk-section-title,
    .trk-checkout-section h2,
    .trk-checkout-section h3 { font-size: 15px !important; margin: 0 0 14px !important; }
    .trk-checkout-form p.form-row { margin: 0 0 8px !important; }
    .trk-checkout-form p.form-row .input-text,
    .trk-checkout-form p.form-row select { padding: 20px 12px 7px !important; font-size: 14px !important; }
    .trk-collapse > summary { padding: 14px 16px !important; font-size: 13px !important; }
    .trk-collapse__body { padding: 12px 16px 16px !important; }
    .trk-collapse--notes-bottom .trk-collapse__body { padding: 12px 16px 16px !important; }
    .trk-place-order-btn,
    button#place_order { padding: 18px 16px !important; margin: 14px 0 0 !important; }
    .trk-place-order-btn::before { font-size: 12px !important; letter-spacing: 0.1em !important; }
    .trk-place-order-btn[data-total]:not([data-total=""])::after { font-size: 14px !important; }
    /* Stripe UPE iframe inside payment_box — give it less side padding on mobile */
    ul.wc_payment_methods > li.wc_payment_method:only-child .payment_box { padding: 16px 12px !important; }
}

/* === PHASE 6 V2 PATCH 5 — shipping methods in mini-summary === */
.trk-totals-row--shipping-methods {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px !important;
}
.trk-totals-row--shipping-methods > .trk-totals-row__label {
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    color: var(--black-3, #3d3d42) !important;
    margin-bottom: 2px;
}
.trk-shipping-methods {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
}
.trk-shipping-method { margin: 0 !important; padding: 0 !important; }
.trk-shipping-method label {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    cursor: pointer !important;
    padding: 10px 12px !important;
    border: 1px solid var(--black-8, #e8e6df) !important;
    border-radius: 6px !important;
    background: #fff !important;
    transition: border-color 0.16s ease, background 0.16s ease !important;
    margin: 0 !important;
}
.trk-shipping-method:hover label {
    border-color: var(--black-5, #7a7a7e) !important;
}
.trk-shipping-method input[type="radio"] {
    width: 16px !important;
    height: 16px !important;
    min-width: 16px !important;
    margin: 0 !important;
    accent-color: var(--black-0, #0e0e10) !important;
    flex: 0 0 16px !important;
    cursor: pointer !important;
    appearance: auto !important;
    -webkit-appearance: auto !important;
    border: 0 !important;
    background: initial !important;
}
.trk-shipping-method__label {
    flex: 1 !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    color: var(--black-1, #1a1a1d) !important;
    line-height: 1.3 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
}
.trk-shipping-method__price {
    font-size: 12px !important;
    font-weight: 800 !important;
    color: var(--black-0, #0e0e10) !important;
    white-space: nowrap !important;
    letter-spacing: -0.005em !important;
}
.trk-shipping-method--selected label {
    border-color: var(--black-0, #0e0e10) !important;
    background: var(--black-10, #f7f5f2) !important;
}

/* === PHASE 6 V2 PATCH 6 — left-column delivery method === */
/* Section card inherits .trk-checkout-section base styling automatically. */
.trk-checkout-section--delivery .trk-section-title { margin-bottom: 14px !important; }

.trk-shipping-section { display: block; }
.trk-shipping-section--empty {
    padding: 14px 16px;
    background: var(--black-10, #f7f5f2);
    border: 1px dashed var(--black-8, #e8e6df);
    border-radius: 6px;
    color: var(--black-4, #5a5a5d);
    font-size: 13px;
    text-align: center;
}
.trk-shipping-empty {
    padding: 14px 16px;
    background: var(--black-10, #f7f5f2);
    border: 1px dashed var(--black-8, #e8e6df);
    border-radius: 6px;
    color: var(--black-4, #5a5a5d);
    font-size: 13px;
    text-align: center;
    margin: 0;
}

/* Block-level radio cards — used in the left-column delivery section */
.trk-shipping-methods--block {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.trk-shipping-methods--block .trk-shipping-method { margin: 0; padding: 0; }
.trk-shipping-methods--block .trk-shipping-method label {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    cursor: pointer !important;
    padding: 16px 18px !important;
    border: 1.5px solid var(--black-8, #e8e6df) !important;
    border-radius: 8px !important;
    background: #fff !important;
    transition: border-color 0.16s ease, background 0.16s ease, box-shadow 0.16s ease !important;
    margin: 0 !important;
}
.trk-shipping-methods--block .trk-shipping-method:hover label {
    border-color: var(--black-5, #7a7a7e) !important;
}
.trk-shipping-methods--block .trk-shipping-method input[type="radio"] {
    width: 18px !important;
    height: 18px !important;
    min-width: 18px !important;
    margin: 0 !important;
    accent-color: var(--black-0, #0e0e10) !important;
    flex: 0 0 18px !important;
    cursor: pointer !important;
    appearance: auto !important;
    -webkit-appearance: auto !important;
    border: 0 !important;
    background: initial !important;
}
.trk-shipping-methods--block .trk-shipping-method__label {
    flex: 1 !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--black-0, #0e0e10) !important;
    line-height: 1.3 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
}
.trk-shipping-methods--block .trk-shipping-method__price {
    font-size: 14px !important;
    font-weight: 800 !important;
    color: var(--black-0, #0e0e10) !important;
    white-space: nowrap !important;
    letter-spacing: -0.005em !important;
}
.trk-shipping-methods--block .trk-shipping-method--selected label {
    border-color: var(--black-0, #0e0e10) !important;
    background: var(--black-10, #f7f5f2) !important;
    box-shadow: 0 0 0 1.5px var(--black-0, #0e0e10) inset !important;
}

@media (max-width: 599px) {
    .trk-shipping-methods--block .trk-shipping-method label { padding: 14px 14px !important; }
    .trk-shipping-methods--block .trk-shipping-method__label,
    .trk-shipping-methods--block .trk-shipping-method__price { font-size: 13px !important; }
}

/* === PHASE 6 — ORDER CONFIRMATION === */
.trk-confirmation { background: var(--white, #fff); color: var(--black-0, #0e0e10); font-family: 'Manrope', sans-serif; }
.trk-confirmation .confirm-main { max-width: 1200px; margin: 0 auto; padding: 40px 32px 80px; }
@media (max-width: 1023px) { .trk-confirmation .confirm-main { padding: 28px 16px 64px; } }

/* Hero */
.trk-confirmation .success-hero { text-align: center; padding: 28px 20px 36px; border-bottom: 1px solid var(--black-9, #f1efe8); margin-bottom: 36px; }
.trk-confirmation .success-icon { width: 72px; height: 72px; margin: 0 auto 18px; border-radius: 50%; background: var(--green-light, #d4ebe0); display: flex; align-items: center; justify-content: center; position: relative; }
.trk-confirmation .success-icon::after { content: ''; width: 28px; height: 16px; border-left: 4px solid var(--green, #2d6a4f); border-bottom: 4px solid var(--green, #2d6a4f); transform: rotate(-45deg); margin-top: -8px; }
.trk-confirmation .success-eyebrow { font-size: 11px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; color: var(--green, #2d6a4f); margin-bottom: 10px; }
.trk-confirmation .success-title { font-size: 38px; font-weight: 900; letter-spacing: -0.03em; line-height: 1.05; margin: 0 0 14px; color: var(--black-0, #0e0e10); }
.trk-confirmation .success-subtitle { font-size: 14px; color: var(--black-3, #3d3d42); line-height: 1.6; max-width: 520px; margin: 0 auto 18px; }
.trk-confirmation .success-meta { display: inline-flex; align-items: center; gap: 8px; padding: 8px 16px; background: var(--black-10, #f7f5f2); border-radius: 999px; }
.trk-confirmation .success-meta__label { font-size: 11px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--black-5, #7a7a7e); }
.trk-confirmation .success-meta__value { font-size: 13px; font-weight: 800; letter-spacing: 0.02em; color: var(--black-0, #0e0e10); }
@media (max-width: 599px) { .trk-confirmation .success-title { font-size: 28px; } }

/* Timeline */
.trk-confirmation .timeline { margin-bottom: 40px; }
.trk-confirmation .timeline__title { font-size: 11px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--black-5, #7a7a7e); text-align: center; margin-bottom: 22px; }
.trk-confirmation .timeline__steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; max-width: 720px; margin: 0 auto; position: relative; }
.trk-confirmation .timeline__steps::before { content: ''; position: absolute; left: 12.5%; right: 12.5%; top: 18px; height: 2px; background: var(--black-9, #f1efe8); z-index: 0; }
.trk-confirmation .tl-step { text-align: center; position: relative; z-index: 1; }
.trk-confirmation .tl-step__icon { width: 36px; height: 36px; border-radius: 50%; background: var(--white); border: 2px solid var(--black-8, #e8e6df); margin: 0 auto 10px; display: flex; align-items: center; justify-content: center; color: var(--black-6, #a8a8ad); }
.trk-confirmation .tl-step__icon svg { width: 16px; height: 16px; }
.trk-confirmation .tl-step--done .tl-step__icon { background: var(--green, #2d6a4f); border-color: var(--green, #2d6a4f); color: #fff; }
.trk-confirmation .tl-step--current .tl-step__icon { background: var(--black-0, #0e0e10); border-color: var(--black-0, #0e0e10); color: #fff; }
.trk-confirmation .tl-step__label { font-size: 12px; font-weight: 700; color: var(--black-5, #7a7a7e); margin-bottom: 2px; }
.trk-confirmation .tl-step__time { font-size: 10px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--black-6, #a8a8ad); }
.trk-confirmation .tl-step--done .tl-step__label, .trk-confirmation .tl-step--current .tl-step__label { color: var(--black-0, #0e0e10); }
@media (max-width: 599px) { .trk-confirmation .timeline__steps { gap: 4px; } .trk-confirmation .tl-step__label { font-size: 11px; } }

/* Grid */
.trk-confirmation .confirm-grid { display: grid; grid-template-columns: 1fr 380px; gap: 32px; align-items: start; margin-bottom: 32px; }
.trk-confirmation .confirm-left { min-width: 0; display: flex; flex-direction: column; gap: 16px; }
@media (max-width: 1023px) { .trk-confirmation .confirm-grid { grid-template-columns: 1fr; gap: 16px; } }

/* Info card */
.trk-confirmation .info-card, .trk-confirmation .items-card { background: #fff; border: 1px solid var(--black-9, #f1efe8); border-radius: 10px; padding: 24px 26px; box-shadow: 0 1px 2px rgba(14,14,16,0.04); }
@media (max-width: 599px) { .trk-confirmation .info-card, .trk-confirmation .items-card { padding: 18px; } }
.trk-confirmation .info-card__head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 18px; padding-bottom: 14px; border-bottom: 1px solid var(--black-9, #f1efe8); }
.trk-confirmation .info-card__title { display: inline-flex; align-items: center; gap: 10px; font-size: 15px; font-weight: 800; letter-spacing: -0.01em; color: var(--black-0, #0e0e10); margin: 0; }
.trk-confirmation .info-card__title-icon { width: 18px; height: 18px; color: var(--black-3, #3d3d42); flex-shrink: 0; }
.trk-confirmation .info-card__action { font-size: 11px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--black-5, #7a7a7e); }

/* Info row */
.trk-confirmation .info-row { display: grid; grid-template-columns: 110px 1fr; gap: 16px; padding: 14px 0; border-top: 1px solid var(--black-9, #f1efe8); }
.trk-confirmation .info-row:first-of-type { border-top: 0; padding-top: 0; }
.trk-confirmation .info-row__label { font-size: 11px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--black-5, #7a7a7e); padding-top: 2px; }
.trk-confirmation .info-row__value { font-size: 13px; color: var(--black-2, #2a2a2e); line-height: 1.6; }
.trk-confirmation .info-row__value strong { display: block; font-weight: 800; color: var(--black-0, #0e0e10); margin-bottom: 2px; }
.trk-confirmation .address-block { font-style: normal; line-height: 1.5; color: var(--black-2, #2a2a2e); }
.trk-confirmation .address-block__name { font-weight: 800; color: var(--black-0, #0e0e10); margin-bottom: 2px; }
@media (max-width: 599px) { .trk-confirmation .info-row { grid-template-columns: 1fr; gap: 4px; } }

/* Items list */
.trk-confirmation .items-list { display: flex; flex-direction: column; }
.trk-confirmation .items-row { display: flex; gap: 14px; padding: 14px 0; border-bottom: 1px solid var(--black-9, #f1efe8); }
.trk-confirmation .items-row:last-child { border-bottom: 0; padding-bottom: 0; }
.trk-confirmation .items-row:first-child { padding-top: 0; }
.trk-confirmation .items-row__media { position: relative; width: 64px; height: 80px; flex-shrink: 0; background: var(--black-10, #f7f5f2); border-radius: 6px; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.trk-confirmation .items-row__media img { width: 100%; height: 100%; object-fit: cover; }
.trk-confirmation .items-row__qty { position: absolute; top: -6px; right: -6px; background: var(--black-0, #0e0e10); color: #fff; font-size: 10px; font-weight: 800; width: 20px; height: 20px; border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.trk-confirmation .items-row__details { flex: 1; min-width: 0; }
.trk-confirmation .items-row__brand { font-size: 10px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--black-5, #7a7a7e); margin-bottom: 2px; }
.trk-confirmation .items-row__title { font-size: 14px; font-weight: 700; color: var(--black-0, #0e0e10); line-height: 1.3; margin-bottom: 4px; }
.trk-confirmation .items-row__meta { font-size: 12px; color: var(--black-4, #5a5a5d); }
.trk-confirmation .items-row__addons { margin-top: 4px; font-size: 11px; color: var(--black-5, #7a7a7e); }
.trk-confirmation .items-row__addons span { display: block; padding: 1px 0; }
.trk-confirmation .items-row__price { font-weight: 800; font-size: 14px; letter-spacing: -0.01em; white-space: nowrap; color: var(--black-0, #0e0e10); }

/* Note */
.trk-confirmation .note-display { padding: 16px 18px; background: var(--black-10, #f7f5f2); border-radius: 8px; font-size: 13px; line-height: 1.6; color: var(--black-2, #2a2a2e); position: relative; border-left: 3px solid var(--black-0, #0e0e10); }

/* Totals card */
.trk-confirmation .totals-card { background: #fff; border: 1px solid var(--black-9, #f1efe8); border-radius: 10px; padding: 26px; position: sticky; top: 24px; box-shadow: 0 1px 2px rgba(14,14,16,0.04); }
@media (max-width: 1023px) { .trk-confirmation .totals-card { position: static; } }
.trk-confirmation .totals-card__head { font-size: 15px; font-weight: 800; letter-spacing: -0.01em; margin: 0 0 20px; padding-bottom: 14px; border-bottom: 1px solid var(--black-9, #f1efe8); }
.trk-confirmation .totals-row { display: flex; justify-content: space-between; align-items: baseline; padding: 8px 0; font-size: 13px; }
.trk-confirmation .totals-row__label { color: var(--black-3, #3d3d42); }
.trk-confirmation .totals-row__value { font-weight: 700; color: var(--black-1, #1a1a1d); }
.trk-confirmation .totals-row--discount .totals-row__value { color: var(--red, #d0021b); }
.trk-confirmation .totals-row--shipping-free .totals-row__value { color: var(--green, #2d6a4f); font-size: 11px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; }

.trk-confirmation .totals-paid { display: flex; justify-content: space-between; align-items: baseline; margin-top: 14px; padding-top: 18px; border-top: 1px solid var(--black-9, #f1efe8); }
.trk-confirmation .totals-paid__label { font-size: 13px; font-weight: 800; letter-spacing: 0.06em; text-transform: uppercase; color: var(--black-0, #0e0e10); }
.trk-confirmation .totals-paid__value { font-size: 26px; font-weight: 900; letter-spacing: -0.025em; color: var(--black-0, #0e0e10); }

/* Payment pill */
.trk-confirmation .payment-pill { display: flex; justify-content: space-between; align-items: center; gap: 10px; margin-top: 18px; padding: 12px 14px; background: var(--black-10, #f7f5f2); border-radius: 8px; font-size: 12px; }
.trk-confirmation .payment-pill__left { display: flex; align-items: center; gap: 10px; color: var(--black-2, #2a2a2e); font-weight: 600; }
.trk-confirmation .payment-pill__icon { display: inline-flex; align-items: center; justify-content: center; padding: 4px 8px; background: var(--black-0, #0e0e10); color: #fff; border-radius: 4px; font-size: 9px; font-weight: 800; letter-spacing: 0.08em; }
.trk-confirmation .payment-pill__right { font-size: 10px; font-weight: 800; letter-spacing: 0.14em; color: var(--green, #2d6a4f); padding: 4px 10px; background: var(--green-light, #d4ebe0); border-radius: 4px; }

/* Action row */
.trk-confirmation .action-row { display: flex; gap: 10px; margin-top: 20px; }
.trk-confirmation .btn { flex: 1; display: inline-flex; align-items: center; justify-content: center; padding: 14px 16px; border-radius: 8px; font-size: 12px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; text-decoration: none; cursor: pointer; transition: all 0.18s ease; border: 0; }
.trk-confirmation .btn--primary { background: var(--black-0, #0e0e10); color: #fff; }
.trk-confirmation .btn--primary:hover { background: var(--red, #d0021b); }
.trk-confirmation .btn--ghost { background: transparent; color: var(--black-2, #2a2a2e); border: 1px solid var(--black-7, #d4d2cc); }
.trk-confirmation .btn--ghost:hover { background: var(--black-10, #f7f5f2); border-color: var(--black-0, #0e0e10); }

/* Account CTA */
.trk-confirmation .account-cta { display: flex; align-items: center; gap: 18px; padding: 22px 26px; background: var(--black-0, #0e0e10); color: #fff; border-radius: 10px; margin-bottom: 16px; }
.trk-confirmation .account-cta__icon { width: 44px; height: 44px; border-radius: 50%; background: rgba(255,255,255,0.1); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.trk-confirmation .account-cta__icon svg { width: 22px; height: 22px; color: #fff; }
.trk-confirmation .account-cta__text { flex: 1; }
.trk-confirmation .account-cta__title { font-size: 15px; font-weight: 800; margin-bottom: 3px; }
.trk-confirmation .account-cta__subtitle { font-size: 12px; color: rgba(255,255,255,0.7); line-height: 1.5; }
.trk-confirmation .account-cta__btn { flex-shrink: 0; padding: 12px 18px; background: #fff; color: var(--black-0, #0e0e10); border-radius: 6px; font-size: 12px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; text-decoration: none; transition: background 0.16s ease; }
.trk-confirmation .account-cta__btn:hover { background: var(--red, #d0021b); color: #fff; }
@media (max-width: 599px) { .trk-confirmation .account-cta { flex-direction: column; text-align: center; padding: 22px 20px; } }

/* Help card */
.trk-confirmation .help-card { display: flex; align-items: center; gap: 18px; padding: 22px 26px; background: var(--black-10, #f7f5f2); border-radius: 10px; margin-bottom: 32px; }
.trk-confirmation .help-card__icon { width: 44px; height: 44px; border-radius: 50%; background: #fff; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.trk-confirmation .help-card__icon svg { width: 22px; height: 22px; color: var(--black-2, #2a2a2e); }
.trk-confirmation .help-card__text { flex: 1; }
.trk-confirmation .help-card__title { font-size: 14px; font-weight: 800; color: var(--black-0, #0e0e10); margin-bottom: 3px; }
.trk-confirmation .help-card__subtitle { font-size: 12px; color: var(--black-4, #5a5a5d); line-height: 1.5; }
.trk-confirmation .help-card__contact { display: flex; flex-direction: column; gap: 4px; flex-shrink: 0; }
.trk-confirmation .help-card__contact a { font-size: 12px; font-weight: 700; color: var(--black-1, #1a1a1d); text-decoration: none; transition: color 0.16s ease; }
.trk-confirmation .help-card__contact a:hover { color: var(--red, #d0021b); }
@media (max-width: 599px) { .trk-confirmation .help-card { flex-direction: column; text-align: center; padding: 22px 20px; } .trk-confirmation .help-card__contact { align-items: center; } }

/* Keep shopping */
.trk-confirmation .keep-shopping { padding-top: 32px; border-top: 1px solid var(--black-9, #f1efe8); }
.trk-confirmation .keep-shopping__eyebrow { font-size: 11px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--black-5, #7a7a7e); margin-bottom: 10px; text-align: center; }
.trk-confirmation .keep-shopping__title { font-size: 24px; font-weight: 900; letter-spacing: -0.025em; margin: 0 0 28px; text-align: center; color: var(--black-0, #0e0e10); }
.trk-confirmation .products-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 24px; }
.trk-confirmation .product-card { background: #fff; border: 1px solid var(--black-9, #f1efe8); border-radius: 10px; overflow: hidden; transition: transform 0.2s ease, box-shadow 0.2s ease; text-decoration: none; }
.trk-confirmation .product-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(14,14,16,0.08); }
.trk-confirmation .product-card__media { aspect-ratio: 1 / 1; background: var(--black-10, #f7f5f2); display: flex; align-items: center; justify-content: center; overflow: hidden; }
.trk-confirmation .product-card__media img { width: 100%; height: 100%; object-fit: cover; }
.trk-confirmation .product-card__brand { font-size: 10px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--black-5, #7a7a7e); padding: 14px 14px 0; }
.trk-confirmation .product-card__name { font-size: 13px; font-weight: 700; color: var(--black-0, #0e0e10); padding: 4px 14px 0; line-height: 1.3; }
.trk-confirmation .product-card__price { font-size: 14px; font-weight: 800; color: var(--black-0, #0e0e10); padding: 6px 14px 14px; }
.trk-confirmation .continue-shopping { display: block; width: fit-content; margin: 0 auto; padding: 12px 24px; font-size: 12px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; color: var(--black-2, #2a2a2e); text-decoration: none; border: 1px solid var(--black-7, #d4d2cc); border-radius: 6px; transition: all 0.16s ease; }
.trk-confirmation .continue-shopping:hover { background: var(--black-0, #0e0e10); color: #fff; border-color: var(--black-0, #0e0e10); }
@media (max-width: 899px) { .trk-confirmation .products-grid { grid-template-columns: repeat(2, 1fr); } }

/* =========================================================================
   PHASE 6 — MY ACCOUNT
   ========================================================================= */
.trk-account-page {
  background: var(--black-10, #f7f5f2);
  padding: 36px 0 96px;
  min-height: 60vh;
}
.trk-account-page * { box-sizing: border-box; }

.trk-account-wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 32px;
}
.trk-account-page .trk-account-page-head {
  margin-bottom: 32px;
}
.trk-account-page .trk-account-page-head__title {
  font-size: 38px;
  font-weight: 900;
  letter-spacing: -0.03em;
  line-height: 1.05;
  margin: 0 0 8px;
  color: var(--black-0);
}
.trk-account-page .trk-account-page-head__subtitle {
  font-size: 14px;
  color: var(--black-4);
  margin: 0;
}
@media (max-width: 1023px) {
  .trk-account-page { padding: 24px 0 80px; }
  .trk-account-wrap { padding: 0 16px; }
  .trk-account-page .trk-account-page-head__title { font-size: 28px; }
  .trk-account-page .trk-account-page-head { margin-bottom: 22px; }
}

/* WC default content wrapper neutralisation */
.trk-account-page .woocommerce,
.trk-account-page .woocommerce-account {
  display: contents;
}
.trk-account-page .woocommerce-MyAccount-content > p:first-child:not(.trk-section-desc) {
  margin: 0 0 18px;
  color: var(--black-3);
  font-size: 14px;
}

/* =========================================================================
   GRID LAYOUT
   ========================================================================= */
.trk-account-page .trk-account-grid {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 32px;
  align-items: start;
}
.trk-account-page .trk-account-sidebar {
  position: sticky;
  top: 96px;
}
.trk-account-page .woocommerce-MyAccount-content {
  min-width: 0;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
@media (max-width: 1023px) {
  .trk-account-page .trk-account-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .trk-account-page .trk-account-sidebar { position: static; }
}

/* =========================================================================
   SIDEBAR NAV
   ========================================================================= */
.trk-account-page .trk-account-nav {
  background: #fff;
  border: 1px solid var(--black-9);
  border-radius: 10px;
  padding: 12px;
  box-shadow: var(--shadow-card, 0 1px 2px rgba(14,14,16,0.04));
}
.trk-account-page .trk-account-nav__list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.trk-account-page .trk-account-nav__item {
  display: block;
  margin: 0;
  padding: 0;
}
.trk-account-page .trk-account-nav__item::before { display: none !important; }
.trk-account-page .trk-account-nav__link {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  text-decoration: none;
  color: var(--black-3);
  font-size: 13px;
  font-weight: 700;
  border-radius: 8px;
  transition: background 0.16s ease, color 0.16s ease;
  border: 0;
  background: transparent;
  width: 100%;
  text-align: left;
}
.trk-account-page .trk-account-nav__link:hover {
  background: var(--black-10);
  color: var(--black-0);
}
.trk-account-page .trk-account-nav__item.is-active .trk-account-nav__link {
  background: var(--black-0);
  color: #fff;
}
.trk-account-page .trk-account-nav__item.is-active .trk-account-nav__link:hover {
  background: var(--black-0);
  color: #fff;
}
.trk-account-page .trk-account-nav__icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}
.trk-account-page .trk-account-nav__label { flex: 1; }
.trk-account-page .trk-account-nav__badge {
  background: var(--black-9);
  color: var(--black-3);
  font-size: 11px;
  font-weight: 800;
  padding: 2px 8px;
  border-radius: 999px;
  letter-spacing: 0.02em;
}
.trk-account-page .trk-account-nav__item.is-active .trk-account-nav__badge {
  background: rgba(255,255,255,0.18);
  color: #fff;
}
.trk-account-page .trk-account-nav__divider {
  height: 1px;
  background: var(--black-9);
  margin: 10px 6px;
  border: 0;
  list-style: none;
  padding: 0;
}
.trk-account-page .trk-account-nav__item--logout .trk-account-nav__link {
  color: var(--black-4);
}
.trk-account-page .trk-account-nav__item--logout .trk-account-nav__link:hover {
  background: rgba(208,2,27,0.08);
  color: var(--red, #d0021b);
}

/* Mobile horizontal scroll tabs */
@media (max-width: 1023px) {
  .trk-account-page .trk-account-nav {
    padding: 8px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .trk-account-page .trk-account-nav__list {
    display: flex;
    gap: 4px;
    min-width: max-content;
  }
  .trk-account-page .trk-account-nav__link {
    padding: 10px 14px;
    font-size: 12px;
    white-space: nowrap;
  }
  .trk-account-page .trk-account-nav__divider {
    width: 1px;
    height: auto;
    margin: 4px 6px;
    align-self: stretch;
  }
  .trk-account-page .trk-account-nav__badge { padding: 1px 6px; font-size: 10px; }
}

/* =========================================================================
   CARD / SECTION PRIMITIVES
   ========================================================================= */
.trk-account-page .trk-account-card {
  background: #fff;
  border: 1px solid var(--black-9);
  border-radius: 10px;
  padding: 26px 28px;
  box-shadow: var(--shadow-card, 0 1px 2px rgba(14,14,16,0.04));
}
@media (max-width: 599px) {
  .trk-account-page .trk-account-card { padding: 20px 18px; }
}

.trk-account-page .trk-section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 4px;
}
.trk-account-page .trk-section-head > div { min-width: 0; }
.trk-account-page .trk-section-title {
  font-size: 17px;
  font-weight: 800;
  letter-spacing: -0.015em;
  color: var(--black-0);
  margin: 0;
  line-height: 1.2;
}
.trk-account-page .trk-section-desc {
  font-size: 13px;
  color: var(--black-4);
  margin: 4px 0 18px;
  line-height: 1.5;
}
.trk-account-page .trk-section-link {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--black-2);
  text-decoration: none;
  cursor: pointer;
  background: transparent;
  border: 0;
  padding: 0;
}
.trk-account-page .trk-section-link:hover { color: var(--red, #d0021b); }
.trk-account-page .trk-count {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--black-5);
}

.trk-account-page .trk-sub-title {
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin: 0 0 16px;
  color: var(--black-0);
}

/* =========================================================================
   STATUS PILLS
   ========================================================================= */
.trk-account-page .trk-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 5px 10px;
  border-radius: 999px;
  white-space: nowrap;
  line-height: 1;
}
.trk-account-page .trk-status::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}
.trk-account-page .trk-status--processing,
.trk-account-page .trk-status--pending {
  background: rgba(14,14,16,0.06);
  color: var(--black-1);
}
.trk-account-page .trk-status--shipped,
.trk-account-page .trk-status--partial-shipped {
  background: var(--gold-light, #fdf3d8);
  color: var(--amber, #b45309);
}
.trk-account-page .trk-status--completed {
  background: var(--green-light, #d4ebe0);
  color: var(--green, #2d6a4f);
}
.trk-account-page .trk-status--on-hold {
  background: var(--amber-light, #fef3c7);
  color: var(--amber, #b45309);
}
.trk-account-page .trk-status--cancelled,
.trk-account-page .trk-status--failed {
  background: var(--black-9);
  color: var(--black-5);
}
.trk-account-page .trk-status--refunded {
  background: rgba(208,2,27,0.08);
  color: var(--red, #d0021b);
}

/* =========================================================================
   DASHBOARD
   ========================================================================= */
.trk-account-page .trk-welcome {
  background: var(--black-0);
  color: #fff;
  border-radius: 10px;
  padding: 28px 30px;
  position: relative;
  overflow: hidden;
}
.trk-account-page .trk-welcome::before {
  content: '';
  position: absolute;
  right: -40px; top: -40px;
  width: 220px; height: 220px;
  background: radial-gradient(circle, rgba(208,2,27,0.25), transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}
.trk-account-page .trk-welcome > * { position: relative; z-index: 1; }
.trk-account-page .trk-welcome__eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  margin-bottom: 8px;
}
.trk-account-page .trk-welcome__title {
  font-size: 26px;
  font-weight: 900;
  letter-spacing: -0.025em;
  margin: 0 0 6px;
  color: #fff;
}
.trk-account-page .trk-welcome__subtitle {
  font-size: 13px;
  color: rgba(255,255,255,0.7);
  margin: 0;
}

.trk-account-page .trk-stats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
@media (max-width: 599px) {
  .trk-account-page .trk-stats-grid { grid-template-columns: 1fr; }
}
.trk-account-page .trk-stat {
  background: #fff;
  border: 1px solid var(--black-9);
  border-radius: 10px;
  padding: 20px 22px;
  box-shadow: var(--shadow-card, 0 1px 2px rgba(14,14,16,0.04));
}
.trk-account-page .trk-stat__label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--black-5);
  margin-bottom: 8px;
}
.trk-account-page .trk-stat__value {
  display: block;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: -0.025em;
  color: var(--black-0);
  line-height: 1;
}
.trk-account-page .trk-stat__sub {
  display: block;
  margin-top: 6px;
  font-size: 11px;
  color: var(--black-5);
}
.trk-account-page .trk-stat--accent .trk-stat__value { color: var(--red, #d0021b); }

/* Mini orders list (dashboard recent) */
.trk-account-page .trk-mini-orders {
  display: flex;
  flex-direction: column;
  margin-top: 14px;
}
.trk-account-page .trk-mini-order {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 10px;
  border-top: 1px solid var(--black-9);
  text-decoration: none;
  color: inherit;
  transition: background 0.16s ease;
  margin: 0 -10px;
  border-radius: 6px;
}
.trk-account-page .trk-mini-order:first-child { border-top: 0; }
.trk-account-page .trk-mini-order:hover { background: var(--black-10); }
.trk-account-page .trk-mini-order__thumb {
  width: 44px; height: 56px;
  background-size: cover;
  background-position: center;
  background-color: var(--black-9);
  border-radius: 5px;
  flex-shrink: 0;
}
.trk-account-page .trk-mini-order__details { flex: 1; min-width: 0; }
.trk-account-page .trk-mini-order__num {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--black-5);
  margin-bottom: 2px;
}
.trk-account-page .trk-mini-order__title {
  font-size: 13px;
  font-weight: 700;
  color: var(--black-0);
  margin-bottom: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.trk-account-page .trk-mini-order__meta {
  font-size: 11px;
  color: var(--black-5);
}
.trk-account-page .trk-mini-order__right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 6px;
  flex-shrink: 0;
}
.trk-account-page .trk-mini-order__price {
  font-size: 14px;
  font-weight: 800;
  letter-spacing: -0.01em;
}

/* Quick actions grid */
.trk-account-page .trk-quick-actions {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-top: 14px;
}
@media (max-width: 599px) {
  .trk-account-page .trk-quick-actions { grid-template-columns: 1fr; }
}
.trk-account-page .trk-action-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 20px;
  background: var(--black-10);
  border: 1px solid var(--black-9);
  border-radius: 8px;
  text-decoration: none;
  color: inherit;
  transition: all 0.16s ease;
}
.trk-account-page .trk-action-card:hover {
  background: #fff;
  border-color: var(--black-7);
  transform: translateY(-2px);
  box-shadow: var(--shadow-elev, 0 4px 24px rgba(14,14,16,0.06));
}
.trk-account-page .trk-action-card__icon {
  width: 40px;
  height: 40px;
  background: #fff;
  border: 1px solid var(--black-8);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.trk-account-page .trk-action-card__icon svg {
  width: 18px;
  height: 18px;
  color: var(--black-2);
}
.trk-account-page .trk-action-card__title {
  font-size: 13px;
  font-weight: 800;
  color: var(--black-0);
  margin-bottom: 2px;
}
.trk-account-page .trk-action-card__sub {
  font-size: 11px;
  color: var(--black-5);
}

/* =========================================================================
   ORDERS LIST
   ========================================================================= */
.trk-account-page .trk-orders-toolbar {
  display: grid;
  grid-template-columns: 1fr 200px;
  gap: 10px;
  margin-bottom: 12px;
}
@media (max-width: 599px) {
  .trk-account-page .trk-orders-toolbar { grid-template-columns: 1fr; }
}
.trk-account-page .trk-search { position: relative; }
.trk-account-page .trk-search__icon {
  position: absolute;
  left: 14px; top: 50%;
  transform: translateY(-50%);
  width: 16px; height: 16px;
  color: var(--black-5);
  pointer-events: none;
}
.trk-account-page .trk-search input {
  width: 100%;
  padding: 13px 14px 13px 40px;
  border: 1px solid var(--black-8);
  border-radius: 8px;
  font-family: inherit;
  font-size: 13px;
  background: #fff;
  transition: border 0.16s ease, box-shadow 0.16s ease;
}
.trk-account-page .trk-search input:focus {
  outline: none;
  border-color: var(--black-1);
  box-shadow: 0 0 0 3px rgba(0,0,0,0.06);
}
.trk-account-page .trk-filter {
  width: 100%;
  padding: 13px 36px 13px 14px;
  border: 1px solid var(--black-8);
  border-radius: 8px;
  font-family: inherit;
  font-size: 13px;
  background: #fff;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%231a1a1a' stroke-width='1.5' d='M1 1.5l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  cursor: pointer;
  font-weight: 600;
}

.trk-account-page .trk-orders-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.trk-account-page .trk-order-card {
  background: #fff;
  border: 1px solid var(--black-9);
  border-radius: 10px;
  padding: 20px 22px;
  box-shadow: var(--shadow-card, 0 1px 2px rgba(14,14,16,0.04));
}
.trk-account-page .trk-order-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--black-9);
  margin-bottom: 14px;
}
.trk-account-page .trk-order-card__num {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--black-5);
  margin-bottom: 4px;
}
.trk-account-page .trk-order-card__date {
  font-size: 14px;
  font-weight: 800;
  letter-spacing: -0.01em;
  color: var(--black-0);
}
.trk-account-page .trk-order-card__body {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}
.trk-account-page .trk-order-card__items {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
  min-width: 0;
}
.trk-account-page .trk-order-card__thumbs {
  display: flex;
  flex-shrink: 0;
}
.trk-account-page .trk-order-card__thumbs > * {
  width: 40px;
  height: 50px;
  border-radius: 5px;
  background-size: cover;
  background-position: center;
  background-color: var(--black-9);
  margin-left: -8px;
  border: 2px solid #fff;
}
.trk-account-page .trk-order-card__thumbs > *:first-child { margin-left: 0; }
.trk-account-page .trk-order-card__items-text {
  font-size: 13px;
  color: var(--black-2);
  line-height: 1.4;
  min-width: 0;
}
.trk-account-page .trk-order-card__items-text strong {
  display: block;
  font-weight: 700;
  color: var(--black-0);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.trk-account-page .trk-order-card__items-text span {
  font-size: 11px;
  color: var(--black-5);
}
.trk-account-page .trk-order-card__total {
  font-size: 18px;
  font-weight: 900;
  letter-spacing: -0.02em;
  text-align: right;
  white-space: nowrap;
}
.trk-account-page .trk-order-card__actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

/* =========================================================================
   BUTTONS
   ========================================================================= */
.trk-account-page .trk-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px 16px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition: all 0.16s ease;
  border: 0;
  font-family: inherit;
  line-height: 1.2;
}
.trk-account-page .trk-btn--primary {
  background: var(--black-0);
  color: #fff;
}
.trk-account-page .trk-btn--primary:hover {
  background: var(--red, #d0021b);
  color: #fff;
}
.trk-account-page .trk-btn--ghost {
  background: transparent;
  color: var(--black-2);
  border: 1px solid var(--black-7);
}
.trk-account-page .trk-btn--ghost:hover {
  background: var(--black-10);
  border-color: var(--black-0);
  color: var(--black-0);
}
.trk-account-page .trk-btn--text {
  background: transparent;
  color: var(--black-3);
  padding: 10px 6px;
}
.trk-account-page .trk-btn--text:hover { color: var(--red, #d0021b); }
.trk-account-page .trk-btn--save {
  width: fit-content;
  padding: 14px 28px;
  font-size: 13px;
}
.trk-account-page .trk-btn--block { width: 100%; }
.trk-account-page .trk-btn--lg { padding: 14px 24px; font-size: 13px; }

/* WC core button neutralisation when inside our scope */
.trk-account-page .woocommerce-Button,
.trk-account-page button.button {
  background: var(--black-0);
  color: #fff;
  border: 0;
  border-radius: 6px;
  padding: 14px 28px;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-family: inherit;
  cursor: pointer;
  transition: background 0.16s ease;
  line-height: 1.2;
}
.trk-account-page .woocommerce-Button:hover,
.trk-account-page button.button:hover {
  background: var(--red, #d0021b);
  color: #fff;
}

/* =========================================================================
   PAGINATION
   ========================================================================= */
.trk-account-page .woocommerce-pagination,
.trk-account-page .trk-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  margin-top: 18px;
  list-style: none;
  padding: 0;
}
.trk-account-page .woocommerce-pagination ul,
.trk-account-page .woocommerce-pagination ol {
  display: flex;
  gap: 4px;
  list-style: none;
  padding: 0;
  margin: 0;
  border: 0;
}
.trk-account-page .woocommerce-pagination li {
  margin: 0;
  border: 0;
}
.trk-account-page .woocommerce-pagination li::before { display: none !important; }
.trk-account-page .woocommerce-pagination a,
.trk-account-page .woocommerce-pagination span,
.trk-account-page .trk-pagination button {
  min-width: 36px;
  height: 36px;
  border: 0;
  background: transparent;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 700;
  color: var(--black-3);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  padding: 0 10px;
}
.trk-account-page .woocommerce-pagination a:hover,
.trk-account-page .trk-pagination button:hover {
  background: var(--black-9);
}
.trk-account-page .woocommerce-pagination .current,
.trk-account-page .trk-pagination button.is-current {
  background: var(--black-0);
  color: #fff;
}

/* =========================================================================
   EMPTY STATE
   ========================================================================= */
.trk-account-page .trk-empty {
  background: #fff;
  border: 1px dashed var(--black-7);
  border-radius: 10px;
  padding: 48px 24px;
  text-align: center;
}
.trk-account-page .trk-empty__icon {
  width: 56px; height: 56px;
  background: var(--black-10);
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 18px;
}
.trk-account-page .trk-empty__icon svg {
  width: 24px; height: 24px;
  color: var(--black-5);
}
.trk-account-page .trk-empty__title {
  font-size: 17px;
  font-weight: 800;
  color: var(--black-0);
  margin: 0 0 6px;
}
.trk-account-page .trk-empty__sub {
  font-size: 13px;
  color: var(--black-4);
  margin: 0 0 20px;
}

/* =========================================================================
   SINGLE ORDER VIEW
   ========================================================================= */
.trk-account-page .trk-back-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 700;
  color: var(--black-4);
  text-decoration: none;
  margin-bottom: 4px;
  cursor: pointer;
  background: transparent;
  border: 0;
  padding: 0;
}
.trk-account-page .trk-back-link:hover { color: var(--red, #d0021b); }

.trk-account-page .trk-order-hero {
  background: #fff;
  border: 1px solid var(--black-9);
  border-radius: 10px;
  padding: 24px 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  box-shadow: var(--shadow-card, 0 1px 2px rgba(14,14,16,0.04));
}
.trk-account-page .trk-order-hero__num {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--black-5);
  margin-bottom: 4px;
}
.trk-account-page .trk-order-hero__date {
  font-size: 22px;
  font-weight: 900;
  letter-spacing: -0.025em;
  color: var(--black-0);
  line-height: 1.1;
}
.trk-account-page .trk-order-hero__status { margin-top: 8px; }
.trk-account-page .trk-order-hero__total {
  text-align: right;
}
.trk-account-page .trk-order-hero__total-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--black-5);
  margin-bottom: 4px;
}
.trk-account-page .trk-order-hero__total-value {
  font-size: 24px;
  font-weight: 900;
  letter-spacing: -0.025em;
}

.trk-account-page .trk-order-grid {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 16px;
  align-items: start;
}
@media (max-width: 1023px) {
  .trk-account-page .trk-order-grid { grid-template-columns: 1fr; }
}
.trk-account-page .trk-order-col-left,
.trk-account-page .trk-order-col-right {
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-width: 0;
}

.trk-account-page .trk-info-row {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 16px;
  padding: 14px 0;
  border-top: 1px solid var(--black-9);
}
.trk-account-page .trk-info-row:first-of-type {
  border-top: 0;
  padding-top: 0;
}
.trk-account-page .trk-info-row__label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--black-5);
  padding-top: 2px;
}
.trk-account-page .trk-info-row__value {
  font-size: 13px;
  color: var(--black-2);
  line-height: 1.6;
}
.trk-account-page .trk-info-row__value strong {
  display: block;
  font-weight: 800;
  color: var(--black-0);
  margin-bottom: 2px;
}
@media (max-width: 599px) {
  .trk-account-page .trk-info-row { grid-template-columns: 1fr; gap: 4px; }
}

.trk-account-page .trk-line-items {
  display: flex;
  flex-direction: column;
}
.trk-account-page .trk-line-item {
  display: flex;
  gap: 14px;
  padding: 14px 0;
  border-top: 1px solid var(--black-9);
  align-items: center;
}
.trk-account-page .trk-line-item:first-child {
  padding-top: 0;
  border-top: 0;
}
.trk-account-page .trk-line-item__thumb {
  width: 60px; height: 76px;
  background: var(--black-10);
  background-size: cover;
  background-position: center;
  border-radius: 6px;
  flex-shrink: 0;
  position: relative;
}
.trk-account-page .trk-line-item__qty {
  position: absolute;
  top: -6px; right: -6px;
  background: var(--black-0);
  color: #fff;
  font-size: 10px;
  font-weight: 800;
  width: 20px; height: 20px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.trk-account-page .trk-line-item__details {
  flex: 1;
  min-width: 0;
}
.trk-account-page .trk-line-item__brand {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--black-5);
  margin-bottom: 2px;
}
.trk-account-page .trk-line-item__title {
  font-size: 14px;
  font-weight: 700;
  color: var(--black-0);
  line-height: 1.3;
  margin-bottom: 4px;
}
.trk-account-page .trk-line-item__title a {
  color: inherit;
  text-decoration: none;
}
.trk-account-page .trk-line-item__title a:hover { color: var(--red, #d0021b); }
.trk-account-page .trk-line-item__meta {
  font-size: 12px;
  color: var(--black-4);
  line-height: 1.4;
}
.trk-account-page .trk-line-item__price {
  font-weight: 800;
  font-size: 14px;
  letter-spacing: -0.01em;
  white-space: nowrap;
  align-self: flex-start;
}

.trk-account-page .trk-totals-card {
  background: #fff;
  border: 1px solid var(--black-9);
  border-radius: 10px;
  padding: 22px 24px;
  box-shadow: var(--shadow-card, 0 1px 2px rgba(14,14,16,0.04));
}
.trk-account-page .trk-totals-card__head {
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin: 0 0 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--black-9);
}
.trk-account-page .trk-totals-row {
  display: flex;
  justify-content: space-between;
  padding: 7px 0;
  font-size: 13px;
}
.trk-account-page .trk-totals-row__label { color: var(--black-3); }
.trk-account-page .trk-totals-row__value { font-weight: 700; color: var(--black-1); }
.trk-account-page .trk-totals-row--discount .trk-totals-row__value { color: var(--red, #d0021b); }
.trk-account-page .trk-totals-row--free .trk-totals-row__value {
  color: var(--green, #2d6a4f);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.trk-account-page .trk-totals-paid {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-top: 12px;
  padding-top: 14px;
  border-top: 1px solid var(--black-9);
}
.trk-account-page .trk-totals-paid__label {
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.trk-account-page .trk-totals-paid__value {
  font-size: 22px;
  font-weight: 900;
  letter-spacing: -0.025em;
}
.trk-account-page .trk-totals-actions {
  margin-top: 18px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.trk-account-page .trk-tracking-card {
  background: var(--green-light, #d4ebe0);
  border: 1px solid rgba(45,106,79,0.2);
  border-radius: 8px;
  padding: 14px 16px;
  margin-top: 14px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.trk-account-page .trk-tracking-card__icon {
  width: 32px; height: 32px;
  background: var(--green, #2d6a4f);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.trk-account-page .trk-tracking-card__icon svg { width: 14px; height: 14px; }
.trk-account-page .trk-tracking-card__text {
  font-size: 12px;
  color: var(--green, #2d6a4f);
  font-weight: 700;
  flex: 1;
}
.trk-account-page .trk-tracking-card__text a {
  display: block;
  color: var(--black-0);
  text-decoration: none;
  font-weight: 800;
  font-size: 13px;
  margin-top: 2px;
  word-break: break-all;
}
.trk-account-page .trk-tracking-card__text a:hover { color: var(--red, #d0021b); }

.trk-account-page .trk-help-card {
  background: #fff;
  border: 1px solid var(--black-9);
  border-radius: 10px;
  padding: 18px 20px;
  box-shadow: var(--shadow-card, 0 1px 2px rgba(14,14,16,0.04));
}
.trk-account-page .trk-help-card__label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--black-5);
  margin-bottom: 6px;
}
.trk-account-page .trk-help-card p {
  font-size: 13px;
  color: var(--black-2);
  margin: 0 0 10px;
  line-height: 1.5;
}
.trk-account-page .trk-help-card a {
  font-size: 13px;
  font-weight: 800;
  color: var(--red, #d0021b);
  text-decoration: none;
}

/* Hide WC default order details/customer-details inside view-order */
.trk-account-page .woocommerce-order-details,
.trk-account-page .woocommerce-customer-details,
.trk-account-page .woocommerce-table--order-details,
.trk-account-page section.woocommerce-customer-details {
  display: none !important;
}
.trk-account-page .trk-show-wc-default .woocommerce-order-details,
.trk-account-page .trk-show-wc-default .woocommerce-customer-details {
  display: block !important;
}

/* =========================================================================
   ADDRESSES
   ========================================================================= */
.trk-account-page .trk-addresses-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
@media (max-width: 1023px) {
  .trk-account-page .trk-addresses-grid { grid-template-columns: 1fr; }
}
.trk-account-page .trk-address-card {
  background: #fff;
  border: 1px solid var(--black-9);
  border-radius: 10px;
  padding: 24px 26px;
  box-shadow: var(--shadow-card, 0 1px 2px rgba(14,14,16,0.04));
}
.trk-account-page .trk-address-card__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 18px;
}
.trk-account-page .trk-address-card__type {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--black-5);
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0;
}
.trk-account-page .trk-address-card__type svg { width: 14px; height: 14px; }
.trk-account-page .trk-address-card__edit {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--black-2);
  text-decoration: none;
  padding: 6px 12px;
  border: 1px solid var(--black-8);
  border-radius: 6px;
  transition: all 0.16s ease;
}
.trk-account-page .trk-address-card__edit:hover {
  background: var(--black-0);
  color: #fff;
  border-color: var(--black-0);
}
.trk-account-page .trk-address-block {
  font-style: normal;
  font-size: 14px;
  line-height: 1.6;
  color: var(--black-2);
  margin: 0;
}
.trk-account-page .trk-address-block strong {
  display: block;
  font-weight: 800;
  color: var(--black-0);
  margin-bottom: 2px;
}
.trk-account-page .trk-address-empty {
  font-size: 13px;
  color: var(--black-5);
  font-style: italic;
}

/* =========================================================================
   FORMS — floating-label pattern via :has()
   Wrap any form in .trk-account-form to enable
   ========================================================================= */
.trk-account-page .trk-account-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.trk-account-page .trk-account-form .trk-form-section {
  padding-bottom: 22px;
  margin-bottom: 4px;
  border-bottom: 1px solid var(--black-9);
}
.trk-account-page .trk-account-form .trk-form-section:last-of-type {
  border-bottom: 0;
  padding-bottom: 6px;
}
.trk-account-page .trk-account-form .trk-form-section + .trk-form-section { margin-top: 6px; }
.trk-account-page .trk-account-form .trk-form-row--2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 599px) {
  .trk-account-page .trk-account-form .trk-form-row--2col { grid-template-columns: 1fr; }
}

/* WC form rows inside our scope */
.trk-account-page .trk-account-form .form-row,
.trk-account-page .trk-account-form .trk-field {
  position: relative;
  margin: 0;
  padding: 0;
  width: 100%;
  display: block;
}
.trk-account-page .trk-account-form p.form-row {
  margin-bottom: 0;
}

.trk-account-page .trk-account-form .form-row .woocommerce-input-wrapper {
  display: block;
  width: 100%;
}

.trk-account-page .trk-account-form input[type="text"],
.trk-account-page .trk-account-form input[type="email"],
.trk-account-page .trk-account-form input[type="tel"],
.trk-account-page .trk-account-form input[type="password"],
.trk-account-page .trk-account-form input[type="number"],
.trk-account-page .trk-account-form select,
.trk-account-page .trk-account-form textarea {
  width: 100%;
  padding: 22px 14px 8px;
  border: 1px solid var(--black-8);
  border-radius: 6px;
  font-family: inherit;
  font-size: 14px;
  background: #fff;
  color: var(--black-1);
  transition: border-color 0.16s ease, box-shadow 0.16s ease;
  appearance: none;
  -webkit-appearance: none;
  line-height: 1.4;
  box-sizing: border-box;
}
.trk-account-page .trk-account-form select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%231a1a1a' stroke-width='1.5' d='M1 1.5l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 36px;
  cursor: pointer;
}
.trk-account-page .trk-account-form input:focus,
.trk-account-page .trk-account-form select:focus,
.trk-account-page .trk-account-form textarea:focus {
  outline: none;
  border-color: var(--black-1);
  box-shadow: 0 0 0 3px rgba(0,0,0,0.06);
}
.trk-account-page .trk-account-form input::placeholder,
.trk-account-page .trk-account-form textarea::placeholder { opacity: 0; }

.trk-account-page .trk-account-form .form-row > label,
.trk-account-page .trk-account-form .trk-field > label {
  position: absolute;
  top: 14px;
  left: 14px;
  font-size: 13px;
  font-weight: 400;
  color: var(--black-4);
  pointer-events: none;
  transition: top 0.14s ease, font-size 0.14s ease;
  background: transparent;
  line-height: 1;
  margin: 0;
  z-index: 1;
}
.trk-account-page .trk-account-form .form-row.woocommerce-validated > label,
.trk-account-page .trk-account-form .form-row:has(input:focus) > label,
.trk-account-page .trk-account-form .form-row:has(input:not(:placeholder-shown)) > label,
.trk-account-page .trk-account-form .form-row:has(select) > label,
.trk-account-page .trk-account-form .form-row:has(textarea:focus) > label,
.trk-account-page .trk-account-form .form-row:has(textarea:not(:placeholder-shown)) > label,
.trk-account-page .trk-account-form .trk-field:has(input:focus) > label,
.trk-account-page .trk-account-form .trk-field:has(input:not(:placeholder-shown)) > label,
.trk-account-page .trk-account-form .trk-field--filled > label {
  top: 7px;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--black-3);
}

/* WC required asterisk */
.trk-account-page .trk-account-form .form-row .required,
.trk-account-page .trk-account-form .trk-field--required > label::after {
  color: var(--red, #d0021b);
  text-decoration: none;
}
.trk-account-page .trk-account-form .trk-field--required > label::after {
  content: ' *';
}

.trk-account-page .trk-account-form .trk-field__hint,
.trk-account-page .trk-account-form .form-row em,
.trk-account-page .trk-account-form .form-row small {
  display: block;
  margin-top: 6px;
  font-size: 11px;
  color: var(--black-5);
  line-height: 1.5;
  padding: 0 4px;
  font-style: normal;
}

/* WC validation feedback */
.trk-account-page .trk-account-form .woocommerce-invalid input,
.trk-account-page .trk-account-form .woocommerce-invalid select {
  border-color: var(--red, #d0021b);
}
.trk-account-page .trk-account-form .woocommerce-invalid input:focus,
.trk-account-page .trk-account-form .woocommerce-invalid select:focus {
  box-shadow: 0 0 0 3px rgba(208,2,27,0.1);
}

/* Custom checkbox */
.trk-account-page .trk-checkbox {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: 13px;
  color: var(--black-2);
  line-height: 1.4;
}
.trk-account-page .trk-checkbox input[type="checkbox"] { display: none; }
.trk-account-page .trk-checkbox__box {
  width: 18px; height: 18px; min-width: 18px;
  border: 1.5px solid var(--black-7);
  border-radius: 4px;
  background: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all 0.14s ease;
}
.trk-account-page .trk-checkbox input:checked ~ .trk-checkbox__box {
  background: var(--black-0);
  border-color: var(--black-0);
}
.trk-account-page .trk-checkbox input:checked ~ .trk-checkbox__box::after {
  content: '';
  width: 5px; height: 9px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
  margin-top: -2px;
}

/* WC notices inside our scope */
.trk-account-page .woocommerce-message,
.trk-account-page .woocommerce-info,
.trk-account-page .woocommerce-error,
.trk-account-page .woocommerce-notice {
  background: #fff;
  border: 1px solid var(--black-9);
  border-radius: 8px;
  padding: 14px 18px;
  margin: 0 0 16px;
  font-size: 13px;
  color: var(--black-2);
  list-style: none;
  display: flex;
  align-items: center;
  gap: 12px;
}
.trk-account-page .woocommerce-message {
  border-left: 3px solid var(--green, #2d6a4f);
}
.trk-account-page .woocommerce-info {
  border-left: 3px solid var(--black-3);
}
.trk-account-page .woocommerce-error {
  border-left: 3px solid var(--red, #d0021b);
}
.trk-account-page .woocommerce-error li,
.trk-account-page .woocommerce-message li {
  padding: 0;
  margin: 0;
  list-style: none;
}
.trk-account-page .woocommerce-error li::before,
.trk-account-page .woocommerce-message li::before { display: none !important; }
.trk-account-page .woocommerce-message a.button,
.trk-account-page .woocommerce-info a.button {
  margin-left: auto;
  padding: 8px 14px;
  font-size: 11px;
}

/* =========================================================================
   AUTH (LOGIN/REGISTER)
   ========================================================================= */
.trk-account-page--auth {
  padding: 60px 0 96px;
}
.trk-account-page--auth .trk-account-wrap {
  max-width: 1100px;
}
.trk-account-page--auth .trk-account-page-head {
  text-align: center;
  margin-bottom: 40px;
}
.trk-account-page--auth .trk-account-page-head__title {
  font-size: 42px;
  letter-spacing: -0.035em;
}

.trk-account-page .trk-auth-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  align-items: stretch;
}
@media (max-width: 899px) {
  .trk-account-page--auth { padding: 40px 0 80px; }
  .trk-account-page--auth .trk-account-page-head__title { font-size: 32px; }
  .trk-account-page .trk-auth-grid { grid-template-columns: 1fr; }
}
.trk-account-page .trk-auth-card {
  background: #fff;
  border: 1px solid var(--black-9);
  border-radius: 12px;
  padding: 36px 38px;
  box-shadow: var(--shadow-card, 0 1px 2px rgba(14,14,16,0.04));
}
@media (max-width: 599px) {
  .trk-account-page .trk-auth-card { padding: 28px 22px; }
}
.trk-account-page .trk-auth-card--alt {
  background: var(--black-0);
  color: #fff;
  border-color: var(--black-0);
  position: relative;
  overflow: hidden;
}
.trk-account-page .trk-auth-card--alt::before {
  content: '';
  position: absolute;
  right: -60px; top: -60px;
  width: 220px; height: 220px;
  background: radial-gradient(circle, rgba(208,2,27,0.25), transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}
.trk-account-page .trk-auth-card__head {
  margin-bottom: 26px;
  position: relative;
}
.trk-account-page .trk-auth-card__title {
  font-size: 22px;
  font-weight: 900;
  letter-spacing: -0.02em;
  margin: 0 0 6px;
  color: inherit;
}
.trk-account-page .trk-auth-card__subtitle {
  font-size: 13px;
  color: var(--black-4);
  margin: 0;
}
.trk-account-page .trk-auth-card--alt .trk-auth-card__subtitle {
  color: rgba(255,255,255,0.65);
}

.trk-account-page .trk-auth-card--alt .trk-account-form input[type="text"],
.trk-account-page .trk-auth-card--alt .trk-account-form input[type="email"],
.trk-account-page .trk-auth-card--alt .trk-account-form input[type="password"] {
  background: rgba(255,255,255,0.06);
  color: #fff;
  border-color: rgba(255,255,255,0.18);
}
.trk-account-page .trk-auth-card--alt .trk-account-form input:focus {
  border-color: #fff;
  box-shadow: 0 0 0 3px rgba(255,255,255,0.1);
}
.trk-account-page .trk-auth-card--alt .trk-account-form .form-row > label,
.trk-account-page .trk-auth-card--alt .trk-account-form .trk-field > label {
  color: rgba(255,255,255,0.5);
}
.trk-account-page .trk-auth-card--alt .trk-account-form .form-row:has(input:focus) > label,
.trk-account-page .trk-auth-card--alt .trk-account-form .form-row:has(input:not(:placeholder-shown)) > label,
.trk-account-page .trk-auth-card--alt .trk-account-form .trk-field:has(input:focus) > label,
.trk-account-page .trk-auth-card--alt .trk-account-form .trk-field:has(input:not(:placeholder-shown)) > label,
.trk-account-page .trk-auth-card--alt .trk-account-form .trk-field--filled > label {
  color: rgba(255,255,255,0.6);
}

.trk-account-page .trk-form-options {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 6px 0 14px;
  flex-wrap: wrap;
  gap: 10px;
}
.trk-account-page .trk-text-link {
  font-size: 12px;
  font-weight: 700;
  color: var(--red, #d0021b);
  text-decoration: none;
}
.trk-account-page .trk-text-link:hover { text-decoration: underline; }

.trk-account-page .trk-auth-card--alt .trk-account-form button.button,
.trk-account-page .trk-auth-card--alt .trk-btn--primary,
.trk-account-page .trk-auth-card--alt .woocommerce-Button {
  background: #fff;
  color: var(--black-0);
}
.trk-account-page .trk-auth-card--alt .trk-account-form button.button:hover,
.trk-account-page .trk-auth-card--alt .trk-btn--primary:hover,
.trk-account-page .trk-auth-card--alt .woocommerce-Button:hover {
  background: var(--red, #d0021b);
  color: #fff;
}
.trk-account-page .trk-auth-card--alt .trk-text-link { color: #fff; }
.trk-account-page .trk-auth-card--alt .trk-checkbox { color: rgba(255,255,255,0.85); }
.trk-account-page .trk-auth-card--alt .trk-checkbox__box {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.3);
}
.trk-account-page .trk-auth-card--alt .trk-checkbox input:checked ~ .trk-checkbox__box {
  background: #fff;
  border-color: #fff;
}
.trk-account-page .trk-auth-card--alt .trk-checkbox input:checked ~ .trk-checkbox__box::after {
  border-color: var(--black-0);
}

.trk-account-page .trk-auth-bottom {
  text-align: center;
  margin-top: 36px;
  font-size: 13px;
  color: var(--black-4);
}
.trk-account-page .trk-auth-bottom a {
  color: var(--red, #d0021b);
  font-weight: 700;
  text-decoration: none;
}
.trk-account-page .trk-auth-bottom a:hover { text-decoration: underline; }

/* WC's lost-password text link below login */
.trk-account-page .lost_password {
  margin: 0;
  font-size: 0;
}
.trk-account-page .lost_password a {
  font-size: 12px;
  font-weight: 700;
  color: var(--red, #d0021b);
  text-decoration: none;
}
.trk-account-page .lost_password a:hover { text-decoration: underline; }

/* =========================================================================
   GIFT CARDS
   ========================================================================= */

/* Balance strip on dashboard */
.trk-account-page .trk-balance-strip {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  background: linear-gradient(90deg, rgba(208,2,27,0.06), rgba(208,2,27,0.02));
  border: 1px solid rgba(208,2,27,0.18);
  border-radius: 10px;
  text-decoration: none;
  color: inherit;
  transition: all 0.16s ease;
}
.trk-account-page .trk-balance-strip:hover {
  background: linear-gradient(90deg, rgba(208,2,27,0.1), rgba(208,2,27,0.04));
  border-color: rgba(208,2,27,0.3);
}
.trk-account-page .trk-balance-strip__icon {
  width: 36px; height: 36px;
  background: var(--red, #d0021b);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.trk-account-page .trk-balance-strip__icon svg { width: 18px; height: 18px; }
.trk-account-page .trk-balance-strip__text { flex: 1; min-width: 0; }
.trk-account-page .trk-balance-strip__label {
  font-size: 13px;
  font-weight: 700;
  color: var(--black-1);
}
.trk-account-page .trk-balance-strip__label strong {
  color: var(--red, #d0021b);
  font-weight: 800;
}
.trk-account-page .trk-balance-strip__sub {
  font-size: 11px;
  color: var(--black-5);
  margin-top: 2px;
}
.trk-account-page .trk-balance-strip__arrow {
  font-weight: 800;
  color: var(--red, #d0021b);
  font-size: 16px;
  flex-shrink: 0;
}

/* Gift cards page hero */
.trk-account-page .trk-gc-hero {
  background: var(--black-0);
  color: #fff;
  border-radius: 10px;
  padding: 32px 30px;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.trk-account-page .trk-gc-hero::before {
  content: '';
  position: absolute;
  right: -60px; top: -60px;
  width: 280px; height: 280px;
  background: radial-gradient(circle, rgba(208,2,27,0.3), transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}
.trk-account-page .trk-gc-hero > * { position: relative; z-index: 1; }
.trk-account-page .trk-gc-hero__main { min-width: 0; }
.trk-account-page .trk-gc-hero__eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  margin-bottom: 6px;
}
.trk-account-page .trk-gc-hero__balance {
  font-size: 44px;
  font-weight: 900;
  letter-spacing: -0.035em;
  line-height: 1;
  color: #fff;
  margin-bottom: 6px;
}
.trk-account-page .trk-gc-hero__balance .woocommerce-Price-amount,
.trk-account-page .trk-gc-hero__balance bdi {
  color: inherit;
  font-size: inherit;
  font-weight: inherit;
}
.trk-account-page .trk-gc-hero__sub {
  font-size: 13px;
  color: rgba(255,255,255,0.7);
}
.trk-account-page .trk-gc-hero__actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.trk-account-page .trk-btn--ghost-on-dark {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.18);
  color: #fff;
}
.trk-account-page .trk-btn--ghost-on-dark:hover {
  background: rgba(255,255,255,0.16);
  border-color: rgba(255,255,255,0.3);
  color: #fff;
}

/* Gift card list */
.trk-account-page .trk-gc-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
@media (max-width: 899px) {
  .trk-account-page .trk-gc-list { grid-template-columns: 1fr; }
}

.trk-account-page .trk-giftcard {
  background: #fff;
  border: 1px solid var(--black-9);
  border-radius: 12px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-card, 0 1px 2px rgba(14,14,16,0.04));
  transition: all 0.2s ease;
}
.trk-account-page .trk-giftcard:hover {
  border-color: var(--black-7);
  box-shadow: var(--shadow-elev, 0 4px 24px rgba(14,14,16,0.06));
}
.trk-account-page .trk-giftcard--used { opacity: 0.65; }
.trk-account-page .trk-giftcard--used .trk-giftcard__visual {
  background: linear-gradient(135deg, var(--black-3), var(--black-4));
}
.trk-account-page .trk-giftcard--used .trk-giftcard__visual::before { display: none; }

.trk-account-page .trk-giftcard__visual {
  background: linear-gradient(135deg, #1a1a1d 0%, #0e0e10 100%);
  color: #fff;
  padding: 22px 24px;
  position: relative;
  overflow: hidden;
}
.trk-account-page .trk-giftcard__visual::before {
  content: '';
  position: absolute;
  right: -50px; top: -50px;
  width: 180px; height: 180px;
  background: radial-gradient(circle, rgba(208,2,27,0.25), transparent 65%);
  border-radius: 50%;
  pointer-events: none;
}
.trk-account-page .trk-giftcard__visual::after {
  content: '';
  position: absolute;
  left: -30px; bottom: -80px;
  width: 200px; height: 200px;
  background: radial-gradient(circle, rgba(255,255,255,0.04), transparent 60%);
  border-radius: 50%;
  pointer-events: none;
}
.trk-account-page .trk-giftcard__visual > * { position: relative; z-index: 1; }
.trk-account-page .trk-giftcard__visual-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 18px;
}
.trk-account-page .trk-giftcard__visual-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}
.trk-account-page .trk-giftcard__visual-balance {
  font-size: 32px;
  font-weight: 900;
  letter-spacing: -0.025em;
  line-height: 1;
  margin-bottom: 14px;
  color: #fff;
}
.trk-account-page .trk-giftcard__visual-balance .woocommerce-Price-amount,
.trk-account-page .trk-giftcard__visual-balance bdi {
  color: inherit;
  font-size: inherit;
  font-weight: inherit;
}
.trk-account-page .trk-giftcard__visual-code-row {
  display: flex;
  align-items: center;
  gap: 10px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 6px;
  padding: 8px 10px 8px 12px;
}
.trk-account-page .trk-giftcard__visual-code {
  font-family: 'SF Mono', Monaco, 'Cascadia Code', monospace;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: rgba(255,255,255,0.92);
  flex: 1;
  user-select: all;
  word-break: break-all;
  background: transparent;
  padding: 0;
}
.trk-account-page .trk-giftcard__copy {
  width: 28px; height: 28px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 5px;
  color: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.16s ease;
  flex-shrink: 0;
  padding: 0;
  font-family: inherit;
}
.trk-account-page .trk-giftcard__copy:hover {
  background: rgba(255,255,255,0.15);
}
.trk-account-page .trk-giftcard__copy svg { width: 12px; height: 12px; }
.trk-account-page .trk-giftcard__copy.is-copied {
  background: var(--green, #2d6a4f);
  border-color: var(--green, #2d6a4f);
}

.trk-account-page .trk-giftcard__meta {
  padding: 16px 20px;
  border-bottom: 1px solid var(--black-9);
}
.trk-account-page .trk-giftcard__meta-row {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  margin-bottom: 6px;
}
.trk-account-page .trk-giftcard__meta-row span { color: var(--black-5); }
.trk-account-page .trk-giftcard__meta-row strong { color: var(--black-1); font-weight: 700; }
.trk-account-page .trk-giftcard__progress {
  height: 4px;
  background: var(--black-9);
  border-radius: 999px;
  overflow: hidden;
  margin-top: 12px;
}
.trk-account-page .trk-giftcard__progress-bar {
  height: 100%;
  background: linear-gradient(90deg, var(--red, #d0021b), var(--red-dark, #a30015));
  border-radius: 999px;
  transition: width 0.4s ease;
}
.trk-account-page .trk-giftcard__progress-text {
  font-size: 11px;
  color: var(--black-5);
  margin-top: 6px;
  text-align: right;
}
.trk-account-page .trk-giftcard__progress-text .woocommerce-Price-amount,
.trk-account-page .trk-giftcard__progress-text bdi {
  font-size: inherit;
  color: inherit;
  font-weight: inherit;
}

.trk-account-page .trk-giftcard__history { border: 0; }
.trk-account-page .trk-giftcard__history summary {
  list-style: none;
  cursor: pointer;
  padding: 12px 20px;
  font-size: 12px;
  font-weight: 700;
  color: var(--black-3);
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: background 0.16s ease;
}
.trk-account-page .trk-giftcard__history summary::-webkit-details-marker { display: none; }
.trk-account-page .trk-giftcard__history summary:hover { background: var(--black-10); }
.trk-account-page .trk-giftcard__history-chevron {
  width: 12px; height: 12px;
  transition: transform 0.18s ease;
  color: var(--black-5);
}
.trk-account-page .trk-giftcard__history[open] .trk-giftcard__history-chevron { transform: rotate(180deg); }
.trk-account-page .trk-giftcard__history-list {
  list-style: none;
  padding: 14px 20px 16px;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  border-top: 1px solid var(--black-9);
}
.trk-account-page .trk-giftcard__history-list li {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
  font-size: 12px;
  margin: 0;
  padding: 0;
}
.trk-account-page .trk-giftcard__history-list li::before { display: none !important; }
.trk-account-page .trk-giftcard__history-list li > div {
  display: flex;
  flex-direction: column;
  gap: 1px;
  min-width: 0;
}
.trk-account-page .trk-giftcard__history-list li strong { font-weight: 700; color: var(--black-1); }
.trk-account-page .trk-giftcard__history-list li span { font-size: 11px; color: var(--black-5); }
.trk-account-page .trk-giftcard__history-amount {
  font-weight: 800;
  color: var(--black-2);
  white-space: nowrap;
  font-size: 13px !important;
}
.trk-account-page .trk-giftcard__history-amount--in { color: var(--green, #2d6a4f); }

.trk-account-page .trk-gc-help { margin-top: 4px; }
.trk-account-page .trk-gc-help__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.trk-account-page .trk-gc-help__list li {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 0;
  margin: 0;
}
.trk-account-page .trk-gc-help__list li::before { display: none !important; }
.trk-account-page .trk-gc-help__num {
  width: 28px; height: 28px;
  background: var(--black-0);
  color: #fff;
  border-radius: 50%;
  font-size: 12px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.trk-account-page .trk-gc-help__list li > div {
  font-size: 13px;
  color: var(--black-3);
  line-height: 1.5;
}
.trk-account-page .trk-gc-help__list li strong {
  display: block;
  color: var(--black-0);
  font-weight: 800;
  margin-bottom: 2px;
}


/* =========================================================================
   MOBILE OPTIMIZATIONS
   ========================================================================= */

/* Tablet portrait & large phones */
@media (max-width: 1023px) {
  .trk-account-page { padding: 24px 0 80px; }
  .trk-account-page .trk-account-page-head { margin-bottom: 20px; }
  .trk-account-page .trk-account-page-head__title { font-size: 28px; }
  .trk-account-page .trk-account-grid { gap: 14px; }

  /* Sidebar nav: full-bleed horizontal scroll */
  .trk-account-page .trk-account-nav {
    margin: 0 -16px;
    border-radius: 0;
    border-left: 0;
    border-right: 0;
    padding: 6px 12px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .trk-account-page .trk-account-nav::-webkit-scrollbar { display: none; }
  .trk-account-page .trk-account-nav__link {
    padding: 12px 14px;
    min-height: 44px;
    font-size: 12px;
  }
  .trk-account-page .trk-account-nav__icon { width: 16px; height: 16px; }
}

/* Standard phones */
@media (max-width: 600px) {
  .trk-account-wrap { padding: 0 14px; }
  .trk-account-page .trk-account-page-head { margin-bottom: 16px; }
  .trk-account-page .trk-account-page-head__title { font-size: 24px; }
  .trk-account-page .trk-account-page-head__subtitle { font-size: 12px; }

  .trk-account-page .trk-account-grid { gap: 10px; }
  .trk-account-page .trk-account-card { padding: 18px 16px; border-radius: 8px; }

  .trk-account-page .trk-section-head { gap: 8px; }
  .trk-account-page .trk-section-title { font-size: 16px; }
  .trk-account-page .trk-section-desc { font-size: 12px; margin: 4px 0 14px; }
  .trk-account-page .trk-section-link { font-size: 11px; }
  .trk-account-page .trk-count { font-size: 10px; }

  .trk-account-page .trk-account-nav { padding: 6px 14px; }
  .trk-account-page .trk-account-nav__link { padding: 11px 14px; font-size: 12px; }
  .trk-account-page .trk-account-nav__badge { padding: 1px 7px; font-size: 10px; }

  /* Welcome card */
  .trk-account-page .trk-welcome { padding: 22px 20px; border-radius: 8px; }
  .trk-account-page .trk-welcome__eyebrow { font-size: 10px; margin-bottom: 6px; }
  .trk-account-page .trk-welcome__title { font-size: 20px; }
  .trk-account-page .trk-welcome__subtitle { font-size: 12px; }

  /* Stats */
  .trk-account-page .trk-stats-grid { gap: 8px; }
  .trk-account-page .trk-stat { padding: 16px 18px; border-radius: 8px; }
  .trk-account-page .trk-stat__label { font-size: 10px; margin-bottom: 6px; }
  .trk-account-page .trk-stat__value { font-size: 24px; }
  .trk-account-page .trk-stat__sub { font-size: 10px; }

  /* Mini orders */
  .trk-account-page .trk-mini-order { padding: 12px 8px; gap: 10px; }
  .trk-account-page .trk-mini-order__thumb { width: 40px; height: 50px; }
  .trk-account-page .trk-mini-order__num { font-size: 10px; }
  .trk-account-page .trk-mini-order__title { font-size: 12px; }
  .trk-account-page .trk-mini-order__meta { font-size: 10px; }
  .trk-account-page .trk-mini-order__price { font-size: 13px; }
  .trk-account-page .trk-mini-order__right { gap: 4px; }

  /* Quick actions */
  .trk-account-page .trk-action-card { padding: 14px 16px; border-radius: 8px; }
  .trk-account-page .trk-action-card__icon { width: 36px; height: 36px; }
  .trk-account-page .trk-action-card__icon svg { width: 16px; height: 16px; }
  .trk-account-page .trk-action-card__title { font-size: 12px; }
  .trk-account-page .trk-action-card__sub { font-size: 10px; }

  /* Orders toolbar — iOS no-zoom */
  .trk-account-page .trk-orders-toolbar { gap: 8px; margin-bottom: 10px; }
  .trk-account-page .trk-search input,
  .trk-account-page .trk-filter { font-size: 16px; }

  /* Order card stack body */
  .trk-account-page .trk-order-card { padding: 16px; border-radius: 8px; }
  .trk-account-page .trk-order-card__head { padding-bottom: 12px; margin-bottom: 12px; }
  .trk-account-page .trk-order-card__num { font-size: 10px; }
  .trk-account-page .trk-order-card__date { font-size: 13px; }
  .trk-account-page .trk-order-card__body {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
    margin-bottom: 12px;
  }
  .trk-account-page .trk-order-card__items { width: 100%; }
  .trk-account-page .trk-order-card__items-text strong { font-size: 12px; }
  .trk-account-page .trk-order-card__total {
    text-align: right;
    font-size: 17px;
    border-top: 1px dashed var(--black-9);
    padding-top: 10px;
    width: 100%;
  }
  .trk-account-page .trk-order-card__actions { gap: 6px; }
  .trk-account-page .trk-order-card__actions .trk-btn {
    flex: 1;
    min-width: 0;
    padding: 11px 12px;
    font-size: 11px;
    letter-spacing: 0.08em;
    min-height: 40px;
  }

  /* Single-order hero stack */
  .trk-account-page .trk-order-hero {
    padding: 18px 20px;
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
  }
  .trk-account-page .trk-order-hero__num { font-size: 10px; }
  .trk-account-page .trk-order-hero__date { font-size: 18px; }
  .trk-account-page .trk-order-hero__total {
    text-align: left;
    width: 100%;
    border-top: 1px solid var(--black-9);
    padding-top: 14px;
  }
  .trk-account-page .trk-order-hero__total-label { font-size: 10px; }
  .trk-account-page .trk-order-hero__total-value { font-size: 20px; }

  .trk-account-page .trk-order-grid { gap: 10px; }
  .trk-account-page .trk-info-row {
    grid-template-columns: 1fr;
    gap: 4px;
    padding: 12px 0;
  }
  .trk-account-page .trk-info-row__label { font-size: 10px; }
  .trk-account-page .trk-info-row__value { font-size: 13px; }

  .trk-account-page .trk-line-item { gap: 12px; padding: 12px 0; }
  .trk-account-page .trk-line-item__thumb { width: 50px; height: 64px; }
  .trk-account-page .trk-line-item__brand { font-size: 9px; }
  .trk-account-page .trk-line-item__title { font-size: 13px; }
  .trk-account-page .trk-line-item__meta { font-size: 11px; }
  .trk-account-page .trk-line-item__price { font-size: 13px; }

  .trk-account-page .trk-totals-card { padding: 18px 20px; border-radius: 8px; }
  .trk-account-page .trk-totals-row { font-size: 12px; padding: 6px 0; }
  .trk-account-page .trk-totals-paid__label { font-size: 12px; }
  .trk-account-page .trk-totals-paid__value { font-size: 18px; }

  .trk-account-page .trk-tracking-card { padding: 12px 14px; }
  .trk-account-page .trk-tracking-card__icon { width: 28px; height: 28px; }
  .trk-account-page .trk-tracking-card__text { font-size: 11px; }
  .trk-account-page .trk-tracking-card__text a { font-size: 12px; }

  /* Gift cards mobile */
  .trk-account-page .trk-balance-strip {
    padding: 12px 14px;
    gap: 10px;
    border-radius: 8px;
  }
  .trk-account-page .trk-balance-strip__icon { width: 32px; height: 32px; }
  .trk-account-page .trk-balance-strip__icon svg { width: 16px; height: 16px; }
  .trk-account-page .trk-balance-strip__label { font-size: 12px; }
  .trk-account-page .trk-balance-strip__sub { font-size: 10px; }

  .trk-account-page .trk-gc-hero {
    padding: 24px 22px;
    border-radius: 8px;
    flex-direction: column;
    align-items: stretch;
    gap: 18px;
  }
  .trk-account-page .trk-gc-hero__balance { font-size: 36px; }
  .trk-account-page .trk-gc-hero__sub { font-size: 12px; }
  .trk-account-page .trk-gc-hero__actions { width: 100%; }
  .trk-account-page .trk-gc-hero__actions .trk-btn {
    flex: 1;
    min-width: 0;
    padding: 12px 14px;
  }
  .trk-account-page .trk-giftcard { border-radius: 10px; }
  .trk-account-page .trk-giftcard__visual { padding: 18px 20px; }
  .trk-account-page .trk-giftcard__visual-balance { font-size: 26px; margin-bottom: 12px; }
  .trk-account-page .trk-giftcard__visual-code { font-size: 11px; }
  .trk-account-page .trk-giftcard__meta { padding: 14px 18px; }
  .trk-account-page .trk-giftcard__history summary { padding: 11px 18px; font-size: 11px; }
  .trk-account-page .trk-giftcard__history-list { padding: 12px 18px 14px; }
  .trk-account-page .trk-gc-help__list li { gap: 12px; }
  .trk-account-page .trk-gc-help__num { width: 26px; height: 26px; font-size: 11px; }
  .trk-account-page .trk-gc-help__list li > div { font-size: 12px; }

  /* Address cards */
  .trk-account-page .trk-address-card { padding: 20px 18px; border-radius: 8px; }
  .trk-account-page .trk-address-card__type { font-size: 10px; }
  .trk-account-page .trk-address-card__edit { padding: 6px 10px; font-size: 10px; }
  .trk-account-page .trk-address-block { font-size: 13px; }

  /* Forms — iOS no-zoom + larger tap targets */
  .trk-account-page .trk-account-form input[type="text"],
  .trk-account-page .trk-account-form input[type="email"],
  .trk-account-page .trk-account-form input[type="tel"],
  .trk-account-page .trk-account-form input[type="password"],
  .trk-account-page .trk-account-form input[type="number"],
  .trk-account-page .trk-account-form select,
  .trk-account-page .trk-account-form textarea {
    font-size: 16px;
    padding: 24px 14px 8px;
  }
  .trk-account-page .trk-account-form .form-row > label,
  .trk-account-page .trk-account-form .trk-field > label { font-size: 13px; top: 16px; }
  .trk-account-page .trk-account-form .trk-form-section { padding-bottom: 18px; }
  .trk-account-page .trk-checkbox { font-size: 12px; }

  /* Buttons */
  .trk-account-page .trk-btn { padding: 11px 14px; min-height: 40px; }
  .trk-account-page .trk-btn--lg { padding: 13px 20px; min-height: 48px; font-size: 12px; }
  .trk-account-page .trk-btn--save { padding: 13px 24px; }

  /* Empty state */
  .trk-account-page .trk-empty { padding: 36px 20px; }
  .trk-account-page .trk-empty__icon { width: 48px; height: 48px; margin-bottom: 14px; }
  .trk-account-page .trk-empty__title { font-size: 15px; }
  .trk-account-page .trk-empty__sub { font-size: 12px; margin-bottom: 16px; }

  /* Auth */
  .trk-account-page--auth { padding: 28px 0 60px; }
  .trk-account-page--auth .trk-account-page-head { margin-bottom: 28px; }
  .trk-account-page--auth .trk-account-page-head__title { font-size: 28px; }
  .trk-account-page .trk-auth-grid { gap: 14px; }
  .trk-account-page .trk-auth-card { padding: 26px 22px; border-radius: 10px; }
  .trk-account-page .trk-auth-card__head { margin-bottom: 22px; }
  .trk-account-page .trk-auth-card__title { font-size: 20px; }
  .trk-account-page .trk-auth-card__subtitle { font-size: 12px; }
  .trk-account-page .trk-form-options { font-size: 12px; }
  .trk-account-page .trk-text-link { font-size: 11px; }
  .trk-account-page .trk-auth-bottom { font-size: 12px; margin-top: 28px; }

  /* Pagination */
  .trk-account-page .woocommerce-pagination a,
  .trk-account-page .woocommerce-pagination span { min-width: 32px; height: 32px; font-size: 12px; }
}

/* Small phones (≤380px) */
@media (max-width: 380px) {
  .trk-account-wrap { padding: 0 12px; }
  .trk-account-page .trk-account-page-head__title { font-size: 22px; }
  .trk-account-page .trk-account-page-head__subtitle { font-size: 11px; }

  .trk-account-page .trk-account-card { padding: 16px 14px; }
  .trk-account-page .trk-welcome { padding: 18px 16px; }
  .trk-account-page .trk-welcome__title { font-size: 18px; }

  .trk-account-page .trk-stat { padding: 14px 16px; }
  .trk-account-page .trk-stat__value { font-size: 22px; }

  .trk-account-page .trk-order-card { padding: 14px; }
  .trk-account-page .trk-order-hero { padding: 16px 18px; }
  .trk-account-page .trk-totals-card { padding: 16px 18px; }
  .trk-account-page .trk-address-card { padding: 18px 16px; }

  .trk-account-page .trk-line-item { gap: 10px; }
  .trk-account-page .trk-line-item__thumb { width: 44px; height: 56px; }
  .trk-account-page .trk-line-item__title { font-size: 12px; }

  .trk-account-page .trk-auth-card { padding: 22px 18px; }
  .trk-account-page--auth .trk-account-page-head__title { font-size: 24px; }
  .trk-account-page .trk-auth-card__title { font-size: 18px; }

  .trk-account-page .trk-account-nav__link { padding: 10px 12px; }

  /* Action buttons stack vertically on tiny screens */
  .trk-account-page .trk-order-card__actions { flex-direction: column; }
  .trk-account-page .trk-order-card__actions .trk-btn { width: 100%; }
}

/* iOS safe-area insets */
@supports (padding: env(safe-area-inset-bottom)) {
  .trk-account-page { padding-bottom: calc(80px + env(safe-area-inset-bottom)); }
  .trk-account-page--auth { padding-bottom: calc(60px + env(safe-area-inset-bottom)); }
}

/* Touch devices: kill hover transforms */
@media (hover: none) {
  .trk-account-page .trk-action-card:hover {
    transform: none;
    box-shadow: var(--shadow-card, 0 1px 2px rgba(14,14,16,0.04));
  }
  .trk-account-page .trk-mini-order:hover { background: transparent; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .trk-account-page *,
  .trk-account-page *::before,
  .trk-account-page *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}


/* === PHASE 6 — MOBILE OVERFLOW FIXES === */
@media (max-width: 1023px) {
  .trk-account-page {
    overflow-x: hidden;
    max-width: 100vw;
  }
  .trk-account-page .trk-account-wrap {
    max-width: 100%;
    width: 100%;
  }
  .trk-account-page .woocommerce-MyAccount-content,
  .trk-account-page .woocommerce-MyAccount-content > * {
    max-width: 100%;
    min-width: 0;
  }
  .trk-account-page .woocommerce-message,
  .trk-account-page .woocommerce-info,
  .trk-account-page .woocommerce-error,
  .trk-account-page .woocommerce-notice {
    flex-wrap: wrap;
    word-break: break-word;
    align-items: flex-start;
  }
  .trk-account-page .woocommerce-message a.button,
  .trk-account-page .woocommerce-info a.button {
    margin-left: 0;
    margin-top: 6px;
    width: auto;
  }
  .trk-account-page .trk-welcome,
  .trk-account-page .trk-giftcard,
  .trk-account-page .trk-order-card,
  .trk-account-page .trk-account-card,
  .trk-account-page .trk-stat,
  .trk-account-page .trk-address-card {
    max-width: 100%;
    box-sizing: border-box;
  }
}

/* === PHASE 6 — MOBILE: NO HIDDEN CONTENT === */
@media (max-width: 768px) {

  /* Nav tabs: wrap onto multiple rows so all are visible without swiping */
  .trk-account-page .trk-account-nav {
    overflow: visible !important;
    margin: 0 !important;
    border-radius: 8px !important;
    border: 1px solid var(--black-9) !important;
    padding: 8px !important;
  }
  .trk-account-page .trk-account-nav__list {
    display: flex !important;
    flex-wrap: wrap !important;
    min-width: 0 !important;
    width: 100% !important;
    gap: 4px !important;
  }
  .trk-account-page .trk-account-nav__item {
    flex: 0 0 auto !important;
  }
  .trk-account-page .trk-account-nav__divider {
    display: none !important;
  }
  .trk-account-page .trk-account-nav__link {
    padding: 9px 12px !important;
    font-size: 12px !important;
  }

  /* WC notices: stack as block so full text is visible */
  .trk-account-page .woocommerce-message,
  .trk-account-page .woocommerce-info,
  .trk-account-page .woocommerce-error,
  .trk-account-page .woocommerce-notice {
    display: block !important;
    text-align: left;
  }
  .trk-account-page .woocommerce-message > li,
  .trk-account-page .woocommerce-info > li,
  .trk-account-page .woocommerce-error > li,
  .trk-account-page .woocommerce-notice > li {
    display: block;
    width: 100%;
    word-break: break-word;
    line-height: 1.5;
  }
  .trk-account-page .woocommerce-message a.button,
  .trk-account-page .woocommerce-info a.button,
  .trk-account-page .woocommerce-error a.button {
    display: inline-block;
    margin: 10px 0 0 0;
    width: auto;
  }
}

/* === PHASE 6 — MOBILE NAV: 2-COL GRID === */
@media (max-width: 768px) {
  .trk-account-page .trk-account-nav__list {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 6px !important;
    width: 100% !important;
  }
  .trk-account-page .trk-account-nav__item {
    flex: unset !important;
    width: 100% !important;
    margin: 0 !important;
  }
  .trk-account-page .trk-account-nav__link {
    width: 100% !important;
    justify-content: flex-start !important;
    box-sizing: border-box;
    padding: 11px 12px !important;
  }
  .trk-account-page .trk-account-nav__item--logout {
    grid-column: 1 / -1 !important;
  }
  .trk-account-page .trk-account-nav__item--logout .trk-account-nav__link {
    justify-content: center !important;
  }
}
/* =========================================================================
   PHASE 7 — WISHLIST
   ========================================================================= */

/* ----- Section head reuses Phase 6 patterns; ensure they exist ----- */
.trk-account-page .trk-section-head {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 4px;
}
.trk-account-page .trk-section-title {
	font-size: 20px;
	font-weight: 900;
	letter-spacing: -0.02em;
	color: var(--black-0);
	margin: 0;
}
.trk-account-page .trk-section-desc {
	font-size: 13px;
	color: var(--black-4);
	margin: 4px 0 18px;
	line-height: 1.5;
}
.trk-account-page .trk-count {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--black-5);
}

/* ----- Wishlist grid ----- */
.trk-account-page .trk-wishlist-grid,
.trk-account-page--standalone .trk-wishlist-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 16px;
	margin-top: 4px;
}
@media (max-width: 1023px) {
	.trk-account-page .trk-wishlist-grid,
	.trk-account-page--standalone .trk-wishlist-grid {
		grid-template-columns: 1fr;
	}
}

/* ----- Wishlist card ----- */
.trk-account-page .trk-wishlist-card {
	background: #fff;
	border: 1px solid var(--black-9);
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 1px 2px rgba(14,14,16,0.04);
	transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
	display: flex;
	flex-direction: column;
}
.trk-account-page .trk-wishlist-card:hover {
	border-color: var(--black-7);
	box-shadow: 0 4px 24px rgba(14,14,16,0.06);
	transform: translateY(-2px);
}
.trk-account-page .trk-wishlist-card__image {
	position: relative;
	aspect-ratio: 4 / 5;
	background: var(--black-9);
	background-size: cover;
	background-position: center;
}
.trk-account-page .trk-wishlist-card__pill {
	position: absolute;
	top: 12px;
	left: 12px;
	z-index: 2;
}
.trk-account-page .trk-wishlist-card__remove {
	position: absolute;
	top: 12px;
	right: 12px;
	z-index: 2;
	width: 36px;
	height: 36px;
	background: rgba(255,255,255,0.95);
	border: 0;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--red, #d0021b);
	box-shadow: 0 2px 6px rgba(0,0,0,0.08);
	cursor: pointer;
	transition: transform 0.16s ease, background 0.16s ease, box-shadow 0.16s ease;
	padding: 0;
}
.trk-account-page .trk-wishlist-card__remove:hover {
	background: #fff;
	transform: scale(1.08);
	box-shadow: 0 4px 12px rgba(208,2,27,0.2);
}
.trk-account-page .trk-wishlist-card__remove svg {
	width: 18px;
	height: 18px;
	display: block;
}
.trk-account-page .trk-wishlist-card__body {
	padding: 18px 20px 20px;
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.trk-account-page .trk-wishlist-card__brand {
	font-size: 10px;
	font-weight: 800;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--black-5);
}
.trk-account-page .trk-wishlist-card__title {
	font-size: 15px;
	font-weight: 800;
	letter-spacing: -0.01em;
	line-height: 1.3;
	color: var(--black-0);
	margin: 0;
}
.trk-account-page .trk-wishlist-card__title a {
	color: inherit;
	text-decoration: none;
}
.trk-account-page .trk-wishlist-card__title a:hover {
	color: var(--red);
}
.trk-account-page .trk-wishlist-card__meta {
	font-size: 12px;
	color: var(--black-4);
}
.trk-account-page .trk-wishlist-card__price {
	font-size: 18px;
	font-weight: 900;
	letter-spacing: -0.02em;
	color: var(--black-0);
	margin-top: 4px;
}
.trk-account-page .trk-wishlist-card__price del {
	font-size: 12px;
	font-weight: 600;
	color: var(--black-5);
	margin-left: 8px;
}
.trk-account-page .trk-wishlist-card__price ins {
	background: transparent;
	color: var(--red);
	text-decoration: none;
}
.trk-account-page .trk-wishlist-card__actions {
	margin-top: auto;
	padding-top: 12px;
	display: flex;
	gap: 8px;
}
.trk-account-page .trk-wishlist-card__notify {
	margin-top: 6px;
	padding: 10px 12px;
	background: var(--black-10);
	border: 1px solid var(--black-9);
	border-radius: 6px;
	font-size: 12px;
	color: var(--black-3);
	display: flex;
	align-items: center;
	gap: 8px;
}
.trk-account-page .trk-wishlist-card__notify svg {
	width: 14px;
	height: 14px;
	color: var(--black-4);
	flex-shrink: 0;
}

/* ----- Empty state (wishlist-specific tints) ----- */
.trk-account-page .trk-wishlist-empty .trk-empty__icon {
	background: rgba(208,2,27,0.06);
}
.trk-account-page .trk-wishlist-empty .trk-empty__icon svg {
	color: var(--red);
	width: 32px;
	height: 32px;
}

/* ----- Skeleton loader (guest hydration) ----- */
.trk-wishlist-skeleton {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 16px;
	margin-top: 4px;
}
@media (max-width: 1023px) {
	.trk-wishlist-skeleton { grid-template-columns: 1fr; }
}
.trk-wishlist-skeleton__card {
	aspect-ratio: 4 / 5;
	border-radius: 12px;
	background: linear-gradient(90deg, var(--black-9) 0%, var(--black-10) 50%, var(--black-9) 100%);
	background-size: 200% 100%;
	animation: trk-shimmer 1.4s ease-in-out infinite;
	border: 1px solid var(--black-9);
	min-height: 320px;
}
@keyframes trk-shimmer {
	0%   { background-position: 200% 0; }
	100% { background-position: -200% 0; }
}

/* ----- Standalone (guest) page wrapper ----- */
.trk-account-page.trk-account-page--standalone {
	padding: 36px 0 96px;
}
.trk-account-page--standalone .trk-account-wrap {
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 32px;
}
@media (max-width: 1023px) {
	.trk-account-page--standalone { padding: 24px 0 80px; }
	.trk-account-page--standalone .trk-account-wrap { padding: 0 16px; }
}
@media (max-width: 600px) {
	.trk-account-page--standalone .trk-account-wrap { padding: 0 14px; }
}

/* =========================================================================
   HEART BUTTON — SHOP LOOP OVERLAY
   ========================================================================= */
.trk-save-btn {
	position: absolute;
	top: 12px;
	right: 12px;
	width: 40px;
	height: 40px;
	background: rgba(255,255,255,0.95);
	border: 0;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--black-3);
	box-shadow: 0 2px 8px rgba(0,0,0,0.1);
	transition: transform 0.18s cubic-bezier(0.34, 1.56, 0.64, 1), background 0.18s ease, color 0.18s ease;
	z-index: 5;
	padding: 0;
	cursor: pointer;
}
.trk-save-btn:hover {
	transform: scale(1.1);
	background: #fff;
	color: var(--red, #d0021b);
}
.trk-save-btn:active { transform: scale(0.95); }
.trk-save-btn svg {
	width: 20px;
	height: 20px;
	transition: fill 0.2s ease;
	display: block;
}
.trk-save-btn.is-saved {
	background: #fff;
	color: var(--red, #d0021b);
}
.trk-save-btn.is-saved svg {
	fill: currentColor;
	animation: trk-heart-pop 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}
@keyframes trk-heart-pop {
	0%   { transform: scale(1); }
	50%  { transform: scale(1.3); }
	100% { transform: scale(1); }
}

/* Make sure shop loop product images are positioned for absolute children.
   Targets common WC structures — won't fight theme overrides if they exist. */
.products li.product .woocommerce-loop-product__link,
.products li.product a.woocommerce-LoopProduct-link,
ul.products li.product {
	position: relative;
}

/* =========================================================================
   HEART BUTTON — PDP (square, inline next to Add to Cart)
   ========================================================================= */
.trk-pdp-save {
	width: 52px;
	height: 52px;
	background: #fff;
	border: 1px solid var(--black-7);
	border-radius: 6px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--black-2);
	transition: background 0.16s ease, border-color 0.16s ease, color 0.16s ease;
	flex-shrink: 0;
	margin-left: 8px;
	vertical-align: middle;
	cursor: pointer;
	padding: 0;
}
.trk-pdp-save:hover {
	background: var(--black-10);
	border-color: var(--black-0);
	color: var(--red, #d0021b);
}
.trk-pdp-save svg {
	width: 22px;
	height: 22px;
	transition: fill 0.2s ease;
	display: block;
}
.trk-pdp-save.is-saved {
	background: rgba(208,2,27,0.06);
	border-color: var(--red, #d0021b);
	color: var(--red, #d0021b);
}
.trk-pdp-save.is-saved svg {
	fill: currentColor;
	animation: trk-heart-pop 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* =========================================================================
   TOAST (saved feedback)
   ========================================================================= */
.trk-toast {
	position: fixed;
	left: 50%;
	bottom: 32px;
	transform: translateX(-50%) translateY(20px);
	background: var(--black-0);
	color: #fff;
	padding: 12px 22px;
	border-radius: 999px;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.02em;
	box-shadow: 0 8px 32px rgba(14,14,16,0.18);
	z-index: 9999;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.25s ease, transform 0.25s ease;
}
.trk-toast.is-visible {
	opacity: 1;
	transform: translateX(-50%) translateY(0);
}
@media (max-width: 600px) {
	.trk-toast {
		bottom: 84px; /* clear sticky bottom bar */
		font-size: 12px;
		padding: 10px 18px;
	}
}

/* =========================================================================
   MOBILE TWEAKS — wishlist
   ========================================================================= */
@media (max-width: 600px) {
	.trk-account-page .trk-wishlist-card__body { padding: 14px 16px 16px; }
	.trk-account-page .trk-wishlist-card__title { font-size: 14px; }
	.trk-account-page .trk-wishlist-card__price { font-size: 16px; }
	.trk-account-page .trk-wishlist-card__remove { width: 32px; height: 32px; }
	.trk-account-page .trk-wishlist-card__remove svg { width: 16px; height: 16px; }
	.trk-account-page .trk-section-title { font-size: 17px; }
	.trk-save-btn { width: 36px; height: 36px; top: 10px; right: 10px; }
	.trk-save-btn svg { width: 18px; height: 18px; }
}

/* === PHASE 7 — TOAST OVERFLOW FIX === */
.trk-toast {
  display: inline-flex !important;
  align-items: center !important;
  width: auto !important;
  height: auto !important;
  min-width: 0 !important;
  min-height: 0 !important;
  max-width: calc(100vw - 40px) !important;
  white-space: nowrap !important;
  box-sizing: border-box !important;
  line-height: 1.4 !important;
}

/* === PHASE 7 — HEADER WISHLIST ICON === */
.header__wishlist {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	position: relative;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: var(--black-10, #f7f5f2);
	color: var(--black-0, #0e0e10);
	text-decoration: none;
	margin-right: 10px;
	flex-shrink: 0;
	transition: background 0.16s ease, color 0.16s ease, transform 0.16s ease;
	border: 0;
	cursor: pointer;
}
.header__wishlist:hover {
	background: var(--black-9, #f1efe8);
	color: var(--red, #d0021b);
	transform: translateY(-1px);
}
.header__wishlist svg {
	width: 20px;
	height: 20px;
	display: block;
}
.header__wishlist-count {
	position: absolute;
	top: -2px;
	right: -2px;
	min-width: 18px;
	height: 18px;
	padding: 0 5px;
	background: var(--red, #d0021b);
	color: #fff;
	border-radius: 999px;
	font-size: 10px;
	font-weight: 800;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
	border: 2px solid #fff;
	box-sizing: border-box;
	letter-spacing: 0.02em;
}
@media (max-width: 768px) {
	.header__wishlist {
		width: 38px;
		height: 38px;
		margin-right: 6px;
	}
	.header__wishlist svg { width: 18px; height: 18px; }
}


/* ============================================================
   PHASE 6 — HOMEPAGE IMAGE WIRING (Customizer-uploaded images)
   ============================================================ */

/* Header logo image (replaces "The Retro Kit" text) */
.header__logo-img {
  display: block;
  max-height: 32px;
  width: auto;
  object-fit: contain;
}
@media (max-width: 767px) {
  .header__logo-img { max-height: 24px; }
}

/* Nation tile — image fills the media area, name stays visible below */
.nation-tile__media {
  position: relative;
  overflow: hidden;
}
.nation-tile__media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* Make sure the name strip stays visible below the media area */
.nation-tile__name {
  position: relative;
  z-index: 2;
}

/* Club tile — image fills the round crest */
.club-tile__crest {
  overflow: hidden;
}
.club-tile__crest img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Mega collection tile — image fills card */
.ctile__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Promo card — image fills media area */
.promo-card__media {
  overflow: hidden;
}
.promo-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}


/* ============================================================
   PHASE 6 — MOBILE-ONLY POLISH (hero controls + trust strip)
   These rules ONLY apply on screens narrower than 768px.
   Laptop/desktop view (768px+) is untouched.
   ============================================================ */

@media (max-width: 767px) {

  /* ===== HERO controls — move below body, not overlapping CTAs ===== */
  .hero__slide {
    padding-bottom: 16px;
  }
  .hero__controls {
    position: relative !important;
    bottom: auto !important;
    left: auto !important;
    transform: none !important;
    margin: 16px auto 0 !important;
    background: transparent !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    padding: 0 !important;
    width: fit-content;
  }
  .hero__arrow {
    background: var(--black-1) !important;
    color: var(--white);
    width: 32px;
    height: 32px;
  }
  .hero__arrow:hover {
    background: var(--black-2) !important;
  }
  .hero__dot {
    background: var(--black-7);
  }
  .hero__dot.is-active {
    background: var(--black-0);
  }

  /* ===== TRUST STRIP — Option B: stars+rating on line 1, perks on line 2 ===== */
  .trust {
    padding: 12px 0;
  }
  .trust__inner {
    display: flex;
    flex-direction: column;
    gap: 8px;
    align-items: stretch;
    text-align: center;
  }

  /* Line 1 — stars + rating side by side */
  .trust__rating {
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 0;
  }
  .trust__stars {
    font-size: 12px;
    letter-spacing: 1px;
  }
  .trust__rating > div {
    text-align: left;
    display: flex;
    align-items: baseline;
    gap: 6px;
  }
  .trust__rating-text {
    font-size: 12px;
    font-weight: 800;
    color: var(--black-0);
    line-height: 1;
  }
  .trust__rating-sub {
    display: none;
  }

  /* Hide the divider — Option B uses just whitespace between rows */
  .trust__divider {
    display: none;
  }

  /* Line 2 — 3 perks with vertical separators */
  .trust__perks {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    gap: 0;
    padding: 0;
    font-size: 10px;
    line-height: 1.3;
    color: var(--black-2);
  }
  .trust__perks span {
    flex: 0 1 auto;
    padding: 0 8px;
    font-weight: 600;
    letter-spacing: 0.02em;
    position: relative;
    white-space: nowrap;
  }
  /* Vertical separators between perks */
  .trust__perks span + span::before {
    content: '·';
    position: absolute;
    left: -2px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--black-7);
    font-weight: 400;
  }
  .trust__perks em {
    color: var(--black-0);
    font-style: normal;
    font-weight: 800;
    margin-left: 2px;
  }

}


/* ============================================================
   PHASE 6 — MOBILE HEADER REDESIGN
   - Logo centered, search/wishlist/cart on right
   - New search icon button (mobile only) toggles search overlay
   - Wishlist icon style updated to match search (laptop + mobile)
   ============================================================ */

/* --- Wishlist icon: match new clean line style (LAPTOP + MOBILE) --- */
.header__wishlist svg {
  width: 22px;
  height: 22px;
}

/* --- Search toggle button: hidden by default (laptop), shown on mobile --- */
.header__search-toggle {
  display: none;
  background: none;
  border: 0;
  padding: 8px;
  cursor: pointer;
  color: var(--black-0);
  align-items: center;
  justify-content: center;
}
.header__search-toggle svg {
  width: 22px;
  height: 22px;
}
.header__search-toggle:hover { color: var(--red); }


/* ============================================================
   MOBILE-ONLY: header layout (max-width: 1023px)
   ============================================================ */
@media (max-width: 1023px) {

  /* Show the search toggle button on mobile */
  .header__search-toggle {
    display: inline-flex;
  }

  /* Reorder header__main-inner: burger → logo (centered) → spacer → actions */
  .header__main-inner {
    display: flex;
    align-items: center;
    gap: 8px;
    position: relative;
  }

  /* Hamburger stays left */
  .header__hamburger {
    order: 1;
    flex: 0 0 auto;
  }

  /* Logo CENTERED on mobile */
  .header__logo {
    order: 2;
    flex: 1 1 auto;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 0;
  }
  .header__logo-img {
    max-height: 28px;
    width: auto;
    margin: 0 auto;
  }

  /* Hide the inline search field on mobile by default */
  .header__search {
    display: none;
  }

  /* When search is open, show search field as full-width overlay below header */
  .header__main-inner.is-search-open .header__search {
    display: flex;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--white);
    border-top: 1px solid var(--black-9);
    border-bottom: 1px solid var(--black-9);
    padding: 12px 16px;
    z-index: 50;
    align-items: center;
    gap: 10px;
    box-shadow: 0 8px 16px -8px rgba(0,0,0,0.08);
  }
  .header__main-inner.is-search-open .header__search-icon {
    flex-shrink: 0;
    color: var(--black-4);
  }
  .header__main-inner.is-search-open .header__search-icon svg {
    width: 18px;
    height: 18px;
  }
  .header__main-inner.is-search-open .header__search form {
    flex: 1;
    margin: 0;
  }
  .header__main-inner.is-search-open .header__search input[type="search"] {
    width: 100%;
    border: 0;
    outline: none;
    font-size: 14px;
    font-family: inherit;
    color: var(--black-0);
    background: transparent;
    padding: 4px 0;
  }
  .header__main-inner.is-search-open .header__search input[type="search"]:focus {
    outline: none;
    box-shadow: none;
  }

  /* Hide the spacer + perks on mobile */
  .header__spacer { display: none; }
  .header__perks { display: none; }

  /* Right-side actions */
  .header__actions {
    order: 3;
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    gap: 4px;
    margin-left: auto;
  }

  /* Wishlist button — clean icon-only on mobile */
  .header__wishlist {
    background: none;
    border: 0;
    padding: 8px;
    color: var(--black-0);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    position: relative;
  }
  .header__wishlist:hover { color: var(--red); }
  .header__wishlist-count {
    position: absolute;
    top: 2px;
    right: 2px;
    background: var(--red);
    color: var(--white);
    font-size: 9px;
    font-weight: 800;
    min-width: 14px;
    height: 14px;
    line-height: 14px;
    padding: 0 3px;
    border-radius: 7px;
    text-align: center;
  }

  /* Cart pill — keep as-is (don't touch) */
  /* Cart label "Cart · " hidden on mobile, only count visible */
  .header__cart-label {
    display: none;
  }

  /* Toggle visual state when search is active — search icon turns red */
  .header__search-toggle[aria-expanded="true"] {
    color: var(--red);
  }
}

/* Extra-small phones */
@media (max-width: 374px) {
  .header__logo-img {
    max-height: 22px;
  }
  .header__search-toggle,
  .header__wishlist {
    padding: 6px;
  }
  .header__search-toggle svg,
  .header__wishlist svg {
    width: 20px;
    height: 20px;
  }
}


/* ============================================================
   PHASE 6 — CART DRAWER ADDON DISPLAY
   ============================================================ */
.cart-item__addons {
  margin-top: 4px;
  font-size: 11px;
  line-height: 1.4;
  color: var(--black-3);
}
.cart-item__addon-row {
  display: flex;
  gap: 4px;
  letter-spacing: 0.01em;
}
.cart-item__addon-row strong {
  color: var(--black-0);
  font-weight: 700;
}


/* ============================================================
   PHASE 6 — CART DRAWER OVERLAY FIX (strong)
   Force overlay to be a transparent dimming rectangle, never a circle.
   ============================================================ */
.cart-drawer__overlay,
.cart-drawer .cart-drawer__overlay,
div.cart-drawer__overlay {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  inset: 0 !important;
  border-radius: 0 !important;
  background-color: rgba(15, 15, 16, 0.5) !important;
  background-image: none !important;
  margin: 0 !important;
  padding: 0 !important;
  transform: none !important;
  clip-path: none !important;
  -webkit-clip-path: none !important;
  border: 0 !important;
  box-shadow: none !important;
}


/* ============================================================
   PHASE 6 — TOAST NOTIFICATION HARD FIX
   Force the toast to be a small pill, never a giant circle.
   ============================================================ */
.trk-toast,
#trkToast {
  position: fixed !important;
  top: 24px !important;
  right: 24px !important;
  bottom: auto !important;
  left: auto !important;
  width: auto !important;
  height: auto !important;
  min-width: 0 !important;
  min-height: 0 !important;
  max-width: calc(100vw - 32px) !important;
  max-height: none !important;
  border-radius: 8px !important;
  padding: 12px 18px !important;
  display: none;
  align-items: center !important;
  gap: 10px !important;
  background: #0e0e10 !important;
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  line-height: 1.4 !important;
  white-space: normal !important;
  z-index: 100000 !important;
  box-sizing: border-box !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.18) !important;
  transform: translateY(-12px) !important;
  opacity: 0 !important;
  transition: transform 0.22s ease, opacity 0.22s ease !important;
  pointer-events: none !important;
}
.trk-toast.is-visible,
#trkToast.is-visible {
  display: inline-flex !important;
  transform: translateY(0) !important;
  opacity: 1 !important;
  pointer-events: auto !important;
}
.trk-toast--error,
#trkToast.trk-toast--error {
  background: #d0021b !important;
}
.trk-toast__icon {
  width: 24px !important;
  height: 24px !important;
  min-width: 24px !important;
  min-height: 24px !important;
  max-width: 24px !important;
  max-height: 24px !important;
  border-radius: 50% !important;
  background: rgba(255,255,255,0.15) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  padding: 0 !important;
}
.trk-toast__icon svg {
  width: 14px !important;
  height: 14px !important;
}
.trk-toast__msg {
  flex: 0 1 auto !important;
  display: inline-block !important;
}

/* Mobile — toast spans width but stays a small pill at top */
@media (max-width: 1023px) {
  .trk-toast,
  #trkToast {
    top: 14px !important;
    left: 14px !important;
    right: 14px !important;
    width: auto !important;
    max-width: calc(100vw - 28px) !important;
    justify-content: center !important;
  }
  .trk-toast.is-visible,
  #trkToast.is-visible {
    display: flex !important;
  }
}


/* ============================================================
   PHASE 6 — COUNTDOWN HEADLINE FIT (one line)
   Long headline: "30% OFF 2nd kit · 60% OFF 3rd kit · 4th kit is FREE"
   Must fit ONE line on all screens.
   ============================================================ */

/* Override countdown headline size — needs to fit a long discount string */
.countdown__h {
  font-size: clamp(16px, 3.6vw, 32px) !important;
  letter-spacing: 0.01em !important;
  line-height: 1.15 !important;
  white-space: nowrap !important;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 6px !important;
}

/* Italic subline below the headline */
.countdown__sub {
  font-size: clamp(11px, 2.4vw, 14px);
  font-style: italic;
  color: var(--white);
  opacity: 0.85;
  letter-spacing: 0.02em;
  margin: 0 0 18px;
  text-align: center;
}

/* Extra-small phones — allow wrapping if absolutely needed */
@media (max-width: 360px) {
  .countdown__h {
    font-size: 14px !important;
    white-space: normal !important;
  }
}


/* ============================================================
   PHASE 6 — FOOTER LOGO IMAGE
   ============================================================ */
.footer__logo-img {
  display: block;
  max-height: 36px;
  width: auto;
  object-fit: contain;
}
@media (max-width: 767px) {
  .footer__logo-img { max-height: 30px; }
}


/* ============================================================
   PHASE 6 — FOOTER REBUILD (email + simplified legal)
   ============================================================ */
.footer__contact {
  margin-top: 14px;
}
.footer__email {
  display: inline-block;
  font-size: 13px;
  font-weight: 600;
  color: var(--black-4) !important;
  text-decoration: none;
  letter-spacing: 0.02em;
  transition: color 0.15s ease;
}
.footer__email:hover {
  color: var(--white, #fff) !important;
}


/* ============================================================
   PHASE 6 — FOOTER COLUMNS: force-open on laptop, accordion on mobile
   ============================================================ */
@media (min-width: 768px) {
  /* Laptop: show all column content, hide accordion arrows */
  .footer__col .footer__col-list {
    display: block !important;
  }
  .footer__col-trigger {
    cursor: default;
    pointer-events: none;
    list-style: none;
  }
  .footer__col-trigger::-webkit-details-marker,
  .footer__col-trigger::marker {
    display: none;
  }
  /* Hide any expand/collapse arrow icon */
  .footer__col-trigger::after,
  .footer__col-trigger::before {
    display: none !important;
  }
}


/* ============================================================
   PHASE 6 — SIZE GUIDE PAGE
   ============================================================ */

/* ---------- Reveal motion (intersection observer adds .is-revealed) ---------- */
.sg-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1),
              transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}
.sg-reveal.is-revealed {
  opacity: 1;
  transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
  .sg-reveal { opacity: 1; transform: none; transition: none; }
}

/* ---------- Hero ---------- */
.trk-size-guide-page {
  background: #fff;
}
.sg-hero {
  padding: 56px 0 40px;
  background: linear-gradient(180deg, #f7f5f0 0%, #fff 100%);
  border-bottom: 1px solid var(--black-1, #efece5);
}
.sg-hero__breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--black-4, #6b6862);
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.sg-hero__breadcrumb a {
  color: inherit;
  text-decoration: none;
  transition: color 0.15s;
}
.sg-hero__breadcrumb a:hover { color: var(--black-0, #1a1a1a); }
.sg-hero__breadcrumb svg { color: var(--black-3, #aaa6a0); }
.sg-hero__title {
  font-family: var(--font-display, "Playfair Display", Georgia, serif);
  font-size: clamp(32px, 6vw, 56px);
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--black-0, #0f0e0c);
  margin: 0 0 16px;
}
.sg-hero__lede {
  font-size: 17px;
  line-height: 1.55;
  color: var(--black-3, #555);
  max-width: 640px;
  margin: 0 0 32px;
}
.sg-hero__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
}
.sg-chip {
  display: inline-block;
  padding: 10px 16px;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--black-0, #1a1a1a);
  background: #fff;
  border: 1px solid var(--black-2, #ddd9d0);
  border-radius: 999px;
  text-decoration: none;
  transition: all 0.2s cubic-bezier(0.22, 1, 0.36, 1);
  cursor: pointer;
  white-space: nowrap;
}
.sg-chip:hover {
  background: var(--red, #c8102e);
  color: #fff;
  border-color: var(--red, #c8102e);
  transform: translateY(-2px);
  box-shadow: 0 6px 14px rgba(200, 16, 46, 0.18);
}
.sg-chip.is-active {
  background: var(--black-0, #0f0e0c);
  color: #fff;
  border-color: var(--black-0, #0f0e0c);
}

/* ---------- How-to section ---------- */
.sg-howto {
  padding: 56px 0;
  background: #fff;
}
.sg-howto__title {
  font-size: clamp(22px, 4vw, 30px);
  font-weight: 700;
  margin: 0 0 32px;
  text-align: center;
  color: var(--black-0, #0f0e0c);
}
.sg-howto__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
}
@media (min-width: 768px) {
  .sg-howto__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
  }
}
.sg-howto__item {
  background: #f9f7f3;
  border: 1px solid var(--black-1, #efece5);
  border-radius: 12px;
  padding: 28px 24px;
  text-align: center;
  transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1),
              box-shadow 0.3s ease;
}
.sg-howto__item:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 24px rgba(0,0,0,0.05);
}
.sg-howto__icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #fff;
  border: 1px solid var(--black-2, #ddd9d0);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 16px;
  color: var(--red, #c8102e);
}
.sg-howto__item h3 {
  font-size: 17px;
  font-weight: 700;
  margin: 0 0 8px;
  color: var(--black-0, #0f0e0c);
}
.sg-howto__item p {
  font-size: 14px;
  line-height: 1.55;
  color: var(--black-3, #555);
  margin: 0;
}

/* ---------- Tables section ---------- */
.sg-tables {
  padding: 24px 0 64px;
  background: #fff;
}
.sg-table-block {
  margin-bottom: 56px;
  scroll-margin-top: 100px;
}
.sg-table-block:last-child { margin-bottom: 0; }
.sg-table-block__head {
  margin-bottom: 20px;
}
.sg-table-block__head h2 {
  font-size: clamp(22px, 4vw, 28px);
  font-weight: 700;
  margin: 0 0 6px;
  color: var(--black-0, #0f0e0c);
}
.sg-table-block__head p {
  font-size: 13px;
  color: var(--black-4, #6b6862);
  margin: 0;
  letter-spacing: 0.02em;
}

/* ---------- Desktop/tablet TABLE (hidden on mobile) ---------- */
.sg-table-wrap {
  display: none;
}
@media (min-width: 640px) {
  .sg-table-wrap {
    display: block;
    overflow-x: auto;
    border: 1px solid var(--black-1, #efece5);
    border-radius: 12px;
  }
}
.sg-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}
.sg-table thead {
  background: #f9f7f3;
}
.sg-table th {
  padding: 14px 16px;
  text-align: left;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--black-3, #555);
  border-bottom: 1px solid var(--black-1, #efece5);
}
.sg-table td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--black-1, #efece5);
  color: var(--black-0, #1a1a1a);
}
.sg-table tbody tr:last-child td {
  border-bottom: none;
}
.sg-table tbody tr:hover {
  background: #faf8f4;
}
.sg-table__size {
  font-weight: 700;
  color: var(--black-0, #0f0e0c) !important;
}

/* ---------- Mobile CARDS (hidden on tablet+) ---------- */
.sg-cards {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
@media (min-width: 640px) {
  .sg-cards { display: none; }
}
.sg-card {
  background: #f9f7f3;
  border: 1px solid var(--black-1, #efece5);
  border-radius: 12px;
  padding: 16px 16px 12px;
}
.sg-card__size {
  font-size: 16px;
  font-weight: 800;
  color: var(--black-0, #0f0e0c);
  padding-bottom: 10px;
  margin-bottom: 12px;
  border-bottom: 1px solid var(--black-1, #efece5);
  letter-spacing: 0.01em;
}
.sg-card__list {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.sg-card__row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
}
.sg-card__row dt {
  font-size: 12px;
  color: var(--black-4, #6b6862);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 600;
  margin: 0;
}
.sg-card__row dd {
  font-size: 14px;
  font-weight: 700;
  color: var(--black-0, #1a1a1a);
  margin: 0;
  text-align: right;
}

/* ---------- Hero padding/spacing on mobile ---------- */
@media (max-width: 639px) {
  .sg-hero { padding: 32px 0 28px; }
  .sg-howto { padding: 40px 0; }
  .sg-tables { padding: 16px 0 48px; }
  .sg-table-block { margin-bottom: 36px; }
  .sg-chip { padding: 9px 14px; font-size: 12px; }
}


/* ============================================================
   PHASE 6 — SIZE GUIDE: ensure final CTA renders correctly
   ============================================================ */
.trk-size-guide-page .final-cta {
  background: #131313 !important;
  color: #ffffff !important;
  text-align: center;
  padding: 64px 0 !important;
}
.trk-size-guide-page .final-cta h2 {
  color: #ffffff !important;
  font-size: clamp(26px, 4vw, 44px);
  font-weight: 800;
  letter-spacing: -0.025em;
  line-height: 1.1;
  margin: 0 0 16px;
}
.trk-size-guide-page .final-cta p {
  color: rgba(255,255,255,0.75) !important;
  font-size: 16px;
  line-height: 1.55;
  max-width: 520px;
  margin: 0 auto 28px;
}
.trk-size-guide-page .final-cta .btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 32px;
  background: #E31E24 !important;
  color: #ffffff !important;
  border: none;
  border-radius: 999px;
  font-weight: 700;
  font-size: 15px;
  text-decoration: none;
  transition: transform 0.15s, background 0.2s, box-shadow 0.2s;
  margin-right: 12px;
}
.trk-size-guide-page .final-cta .btn-primary:hover {
  background: #B81015 !important;
  transform: translateY(-2px);
  box-shadow: 0 8px 18px rgba(227, 30, 36, 0.3);
}
.trk-size-guide-page .final-cta .btn-secondary-dark {
  display: inline-flex;
  align-items: center;
  padding: 16px 32px;
  background: transparent;
  color: #ffffff !important;
  border: 1.5px solid rgba(255,255,255,0.4);
  border-radius: 999px;
  font-weight: 700;
  font-size: 15px;
  text-decoration: none;
  transition: background 0.2s, border-color 0.2s;
}
.trk-size-guide-page .final-cta .btn-secondary-dark:hover {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.6);
}
@media (max-width: 639px) {
  .trk-size-guide-page .final-cta { padding: 48px 0 !important; }
  .trk-size-guide-page .final-cta .btn-primary { margin: 0 0 12px; display: flex; justify-content: center; }
  .trk-size-guide-page .final-cta .btn-secondary-dark { display: flex; justify-content: center; }
}


/* ============================================================
   PHASE 6 — 404 NOT FOUND PAGE
   ============================================================ */
.trk-404-page {
  background: #fff;
  min-height: 70vh;
}

/* Reveal motion */
.trk-404-reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1),
              transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}
.trk-404-reveal.is-revealed {
  opacity: 1;
  transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
  .trk-404-reveal { opacity: 1; transform: none; transition: none; }
}

/* Hero */
.trk-404__hero {
  padding: 80px 0 100px;
  background: linear-gradient(180deg, #f7f5f0 0%, #fff 100%);
}
@media (max-width: 639px) {
  .trk-404__hero { padding: 48px 0 64px; }
}

.trk-404__inner {
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
}

/* The big 404 number */
.trk-404__number-wrap {
  margin-bottom: 28px;
}
.trk-404__number {
  display: inline-block;
  font-family: var(--font-display, "Playfair Display", Georgia, serif);
  font-size: clamp(120px, 22vw, 220px);
  font-weight: 900;
  line-height: 0.9;
  letter-spacing: -0.05em;
  color: #E31E24;
  text-shadow: 0 2px 0 rgba(0,0,0,0.04);
}

/* Title */
.trk-404__title {
  font-family: var(--font-display, "Playfair Display", Georgia, serif);
  font-size: clamp(26px, 5vw, 44px);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: #0f0e0c;
  margin: 0 0 16px;
}

/* Lede */
.trk-404__lede {
  font-size: clamp(15px, 2vw, 17px);
  line-height: 1.6;
  color: #555;
  max-width: 520px;
  margin: 0 auto 44px;
}

/* Grid of 4 cards */
.trk-404__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  text-align: left;
  margin: 0 0 36px;
}
@media (min-width: 640px) {
  .trk-404__grid {
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }
}

.trk-404__card {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 18px 20px;
  background: #fff;
  border: 1px solid #ddd9d0;
  border-radius: 12px;
  text-decoration: none;
  color: inherit;
  transition: all 0.25s cubic-bezier(0.22, 1, 0.36, 1);
  position: relative;
  overflow: hidden;
}
.trk-404__card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(227, 30, 36, 0.04), transparent);
  opacity: 0;
  transition: opacity 0.25s;
  pointer-events: none;
}
.trk-404__card:hover {
  border-color: #E31E24;
  transform: translateY(-3px);
  box-shadow: 0 10px 24px rgba(0,0,0,0.06);
}
.trk-404__card:hover::before {
  opacity: 1;
}

.trk-404__card-icon {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  border-radius: 10px;
  background: #f5f2eb;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #E31E24;
  transition: background 0.25s, color 0.25s;
}
.trk-404__card:hover .trk-404__card-icon {
  background: #E31E24;
  color: #fff;
}

.trk-404__card-body {
  flex: 1;
  min-width: 0;
}
.trk-404__card-body h3 {
  font-size: 15px;
  font-weight: 700;
  color: #0f0e0c;
  margin: 0 0 2px;
  line-height: 1.3;
}
.trk-404__card-body p {
  font-size: 13px;
  color: #6b6862;
  margin: 0;
  line-height: 1.4;
}

.trk-404__card-arrow {
  flex-shrink: 0;
  color: #aaa6a0;
  transition: color 0.25s, transform 0.25s;
}
.trk-404__card:hover .trk-404__card-arrow {
  color: #E31E24;
  transform: translateX(3px);
}

/* Contact fallback */
.trk-404__contact {
  font-size: 14px;
  color: #6b6862;
  margin: 24px 0 0;
  line-height: 1.55;
}
.trk-404__contact a {
  color: #E31E24;
  text-decoration: none;
  font-weight: 700;
  border-bottom: 1.5px solid transparent;
  transition: border-color 0.2s;
}
.trk-404__contact a:hover {
  border-bottom-color: #E31E24;
}

/* Mobile fine-tuning */
@media (max-width: 639px) {
  .trk-404__number { font-size: 130px; }
  .trk-404__card { padding: 14px 16px; gap: 12px; }
  .trk-404__card-icon { width: 42px; height: 42px; }
  .trk-404__card-icon svg { width: 24px; height: 24px; }
}


/* ============================================================
   PHASE 6 — ADDON THUMBNAIL (frontend product page)
   Small 40px image next to the addon label, fits the existing
   .addon row layout cleanly. Mobile-optimised.
   ============================================================ */
.addon__thumb {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 6px;
  overflow: hidden;
  background: #f5f2eb;
  border: 1px solid #ddd9d0;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 10px;
  transition: border-color 0.15s, transform 0.2s;
}
.addon__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.addon.is-checked .addon__thumb,
.addon__checkbox:checked ~ .addon__thumb {
  border-color: #E31E24;
}
.addon--has-image .addon__body {
  flex: 1;
  min-width: 0;
}

/* On smaller mobile, slightly smaller thumb */
@media (max-width: 480px) {
  .addon__thumb {
    width: 36px;
    height: 36px;
    margin-right: 8px;
  }
}


/* ============================================================
   PHASE 6 — MEGA MENU NESTED CONTINENTS
   ============================================================ */
.mega-col__li { position: relative; }
.mega-col__li--has-children > .mega-col__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.mega-col__chevron {
  display: inline-flex;
  align-items: center;
  color: var(--black-5, #888);
  transition: transform 0.2s, color 0.2s;
}
.mega-col__li--has-children:hover .mega-col__chevron,
.mega-col__li--has-children.is-open > .mega-col__link .mega-col__chevron {
  color: var(--red, #E31E24);
  transform: rotate(90deg);
}
.mega-col__sub {
  display: none;
  list-style: none;
  margin: 0;
  padding: 0;
}
/* Desktop: hover the parent → flyout to the right */
@media (min-width: 769px) {
  .mega-col__sub {
    position: absolute;
    left: 100%;
    top: 0;
    min-width: 200px;
    background: #fff;
    padding: 16px 18px;
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.08);
    border-radius: 8px;
    z-index: 1000;
    border: 1px solid var(--black-9, #efece5);
  }
  .mega-col__li--has-children:hover > .mega-col__sub {
    display: block;
  }
}
/* Mobile (drawer): nested accordion, indent */
@media (max-width: 768px) {
  .mega-col__sub {
    padding-left: 20px;
    padding-top: 4px;
    padding-bottom: 8px;
    margin: 0;
  }
  .mega-col__li--has-children.is-open > .mega-col__sub {
    display: block;
  }
}
.mega-col__sublink {
  display: block;
  padding: 6px 0;
  font-size: 13px;
  color: var(--black-3, #555);
  text-decoration: none;
  transition: color 0.15s, transform 0.15s;
}
.mega-col__sublink:hover {
  color: var(--red, #E31E24);
  transform: translateX(3px);
}


/* ============================================================
   PHASE 6 — WC 2026 MENU ITEM HIGHLIGHT
   Full red-filled pill on desktop + red text + NEW badge on mobile.
   ============================================================ */
.menu-item-304687 > .nav__item {
  background: #E31E24 !important;
  color: #fff !important;
  font-weight: 800;
  letter-spacing: 0.04em;
  padding: 7px 14px !important;
  border-radius: 999px;
  transition: background 0.2s, transform 0.2s, box-shadow 0.2s;
  text-transform: uppercase;
  font-size: 12px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.menu-item-304687 > .nav__item::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  background: #fff;
  border-radius: 50%;
  animation: trk-wc-pulse 1.6s ease-in-out infinite;
}
.menu-item-304687 > .nav__item:hover {
  background: #B81015 !important;
  color: #fff !important;
  transform: translateY(-1px);
  box-shadow: 0 6px 14px rgba(227, 30, 36, 0.3);
}
@keyframes trk-wc-pulse {
  0%, 100% { transform: scale(1);   opacity: 1; }
  50%      { transform: scale(1.4); opacity: 0.6; }
}
@media (prefers-reduced-motion: reduce) {
  .menu-item-304687 > .nav__item::before { animation: none; }
}

/* Mobile drawer — same red-pill treatment */
.drawer .menu-item-304687 > a {
  background: #E31E24 !important;
  color: #fff !important;
  font-weight: 800;
  border-radius: 8px;
  padding: 10px 16px !important;
  margin: 4px 0;
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.drawer .menu-item-304687 > a::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  background: #fff;
  border-radius: 50%;
}
