/* assets/css/archive-skeleton.css */

/* ---------- Overlay container ---------- */
.ph-archive-click-skeleton {
  position: fixed;
  top: var(--ph-archive-header-offset, 0px);
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 9998;
  background: #fff;
  display: none;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

/* only show during clicking */
html.ph-archive-skeleton-clicking .ph-archive-click-skeleton {
  display: block;
}

/* prevent scroll during overlay */
html.ph-archive-skeleton-clicking {
  overflow: hidden;
}
html.ph-archive-skeleton-clicking,
html.ph-archive-skeleton-clicking * {
  cursor: progress !important;
}

/* inner width mimics your archive full-width + padding */
.ph-archive-click-skeleton__inner {
  display: block !important;
  width: 100%;
  padding: 0 20px;
  box-sizing: border-box;
}

/* ---------- Variant switching (SCOPE TO OVERLAY ONLY) ---------- */
.ph-archive-click-skeleton .ph-archive-skel { display: none; }
html[data-ph-archive-skel-variant="products"] .ph-archive-click-skeleton .ph-archive-skel--products { display: block; }
html[data-ph-archive-skel-variant="categories"] .ph-archive-click-skeleton .ph-archive-skel--categories { display: block; }
/* Treat products_noheader the same as products (products grid) */
html[data-ph-archive-skel-variant="products_noheader"] .ph-archive-click-skeleton .ph-archive-skel--products { display: block; }
/* Hide header area only for noheader variant */
html[data-ph-archive-skel-variant="products_noheader"] .ph-archive-click-skeleton .ph-archive-skel__header { display: none !important; }
html[data-ph-archive-skel-variant="single"] .ph-archive-click-skeleton .ph-archive-skel--single { display: block; }
html[data-ph-archive-skel-variant="checkout"] .ph-archive-click-skeleton .ph-archive-skel--checkout { display: block; }
/* Favorites: use PRODUCTS skeleton (grid/cards) */
html[data-ph-archive-skel-variant="favorites"] .ph-archive-click-skeleton .ph-archive-skel--products {
  display: block;
}




/* ---------- Header skeleton area ---------- */
.ph-archive-skel__header {
  padding: 26px 0 14px;

  /* This is the key: center the header blocks (breadcrumb + title),
     but keep the toolbar row full-width */
  display: flex;
  flex-direction: column;
}

/* Center everything in the header EXCEPT the toolbar row */
.ph-archive-skel__header > :not(.ph-archive-skel__toolbar) {
  align-self: center;
}

/* Toolbar stays full width (so left stays left, right stays right) */
.ph-archive-skel__toolbar {
  margin-top: 18px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;

  align-self: stretch;
  width: 100%;
}

/* ---------- Category variant simplification ----------
   - No toolbar (no left/right lines)
   - No “product details” under tiles
*/
html[data-ph-archive-skel-variant="categories"] .ph-archive-skel__toolbar {
  display: none !important;
}

/* Remove any meta/details blocks under category tiles (keep tiles clean) */
html[data-ph-archive-skel-variant="categories"] .ph-archive-card__meta,
html[data-ph-archive-skel-variant="categories"] .ph-archive-card__catbar {
  display: none !important;
}

/* ---------- Shimmer primitives ---------- */
/* (REMOVED — replaced by overlay-based shimmer at bottom) */

.ph-skel-line {
  height: 14px;
  border-radius: 7px;
  margin: 10px 0;
}

.ph-skel-h1 {
  height: 14px;
  border-radius: 7px;
  margin-top: 18px;
}

.ph-skel-pill {
  height: 26px;
  border-radius: 13px;
}

/* width helpers */
.ph-skel-w-10 { width: 10%; }
.ph-skel-w-18 { width: 18%; }
.ph-skel-w-20 { width: 20%; }
.ph-skel-w-25 { width: 25%; }
.ph-skel-w-30 { width: 30%; }
.ph-skel-w-40 { width: 40%; }
.ph-skel-w-45 { width: 45%; }
.ph-skel-w-55 { width: 55%; }
.ph-skel-w-70 { width: 70%; }
.ph-skel-w-85 { width: 85%; }

/* ---------- Grid skeleton ---------- */
.ph-archive-grid {
  list-style: none;
  margin: 0;
  padding: 14px 0 40px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 22px;
  box-sizing: border-box;
}

/* Space around the two “toolbar” lines (left filter + right results) */
.ph-archive-click-skeleton .ph-archive-skel--products .ph-archive-skel__toolbar {
  margin-top: 50px;     /* space between title area and those two lines */
}



/* Category tiles */
.ph-archive-card--category .ph-archive-card__thumb {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 16px;
}

/* Product cards */
.ph-archive-card--product .ph-archive-card__thumb {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 18px;
}

.ph-archive-card--product .ph-archive-card__meta {
  padding-top: 12px;
}

/* Responsive */
@media (max-width: 61.24em) {
  .ph-archive-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
  }
  .ph-skel-w-40 { width: 70%; }
  .ph-skel-w-25 { width: 60%; }
  .ph-skel-w-18 { width: 44%; }
}

@media (max-width: 420px) {
  .ph-archive-grid {
    grid-template-columns: 1fr;
  }
}

/* Reduce motion */
/* (REMOVED — handled by overlay-based shimmer at bottom) */

/* ---------- for you specific ---------- */
/* For You / Explore: hide Astra below-header immediately during click-skeleton */
html.ph-archive-skeleton-clicking[data-ph-hide-below-header="1"] .ast-below-header-wrap,
html.ph-archive-skeleton-clicking[data-ph-hide-below-header="1"] .ast-below-header-bar,
html.ph-archive-skeleton-clicking[data-ph-hide-below-header="1"] .ast-below-header {
  display: none !important;
}



/* ---------- Single Product (PDP) variant ---------- */

.ph-pdp-skel {
  padding: 18px 0 40px;
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
  gap: 56px;
  align-items: start;

  /* FIX: prevent horizontal overflow on mobile */
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

/* FIX: grid children must be allowed to shrink (prevents “pushing” off-screen) */
.ph-pdp-skel > * {
  min-width: 0;
}

.ph-pdp-skel__media {
  position: relative;

  /* FIX: stop any weird overflow from absolutely-positioned nav, etc. */
  max-width: 100%;
}

.ph-pdp-skel__media-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 0 12px;
}

.ph-pdp-skel__heart {
  width: 28px;
  height: 28px;
  border-radius: 999px;
}

.ph-pdp-skel__media-main {
  width: 100%;
  aspect-ratio: 1 / 1;
  min-height: 520px;
  border-radius: 18px;

  /* FIX: make sure it never exceeds viewport width */
  max-width: 100%;
}

.ph-pdp-skel__nav {
  position: absolute;
  left: 0;
  right: 0;
  top: 52%;
  transform: translateY(-50%);
  display: flex;
  justify-content: space-between;
  padding: 0 12px;
  pointer-events: none;

  /* FIX: ensure nav never causes horizontal scroll */
  max-width: 100%;
  box-sizing: border-box;
}

/* Tighten the "top line -> title" gap ONLY on PDP skeleton */
.ph-pdp-skel__summary > .ph-skel-line:first-child {
  margin-bottom: 4px;
}

.ph-pdp-skel__summary > .ph-skel-h1 {
  margin-top: 6px; /* was 18px */
}


.ph-pdp-skel__navbtn {
  width: 34px;
  height: 34px;
  border-radius: 999px;
}

.ph-pdp-skel__summary {
  padding-top: 10px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;

  /* FIX: allow right column to shrink on smaller widths */
  min-width: 0;
  max-width: 100%;
}

.ph-pdp-skel__btn {
  width: 100%;
  max-width: 460px;
  height: 48px;              /* Apple Pay height */
  border-radius: 999px;      /* pill */
  margin-top: 14px;
}

.ph-pdp-skel__btn--secondary {
  height: 44px;              /* Add to bag / Offer */
  border-radius: 12px;
}

.ph-pdp-skel__divider {
  width: 100%;
  max-width: 520px;
  height: 1px;
  background: #e6e6e6;
  margin: 18px 0;
}

@media (max-width: 61.24em) {
  .ph-pdp-skel {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 12px 0 24px;

    /* Wide-mobile fluid width */
    --ph-pdp-mobile-w: clamp(320px, 92vw, 720px);

    align-items: center;
  }

  /* Keep media first, summary second */
  .ph-pdp-skel__media { order: 1; }
  .ph-pdp-skel__summary { order: 2; margin: 0; padding-top: 0; }

  /* Make the whole skeleton scale with screen size */
  .ph-pdp-skel__media,
  .ph-pdp-skel__summary {
    width: var(--ph-pdp-mobile-w);
    max-width: 100%;
  }

  /* Don’t force “desktop-ish” tall behavior on wide mobile */
  .ph-pdp-skel__media-main {
    min-height: 0;
    width: 100%;
    aspect-ratio: 1 / 1;
  }

  /* Slightly tighter padding so nav/buttons never clip */
  .ph-pdp-skel__nav {
    padding: 0 10px;
  }

  /* Buttons should match the fluid container width */
  .ph-pdp-skel__btn {
    max-width: 100%;
  }
}



/* Extra small safety: kill any accidental horizontal scroll */
@media (max-width: 46.24em) {
  .ph-pdp-skel {
    padding-left: 0;
    padding-right: 0;
  }

  .ph-pdp-skel__nav {
    padding: 0 8px;
  }
}



/* ---------- Checkout variant ---------- */

.ph-checkout-skel {
  padding: 14px 0 40px; /* tightened so it sits right under topbar */
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 0.72fr);
  gap: 56px;
  align-items: start;

  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

.ph-checkout-skel > * { min-width: 0; }

.ph-checkout-skel__main,
.ph-checkout-skel__side {
  max-width: 100%;
}

.ph-checkout-skel__hline {
  margin-top: 6px;
  margin-bottom: 14px;
}

.ph-checkout-skel__card {
  width: 100%;
  height: 86px;
  border-radius: 16px;
  margin: 8px 0 12px;
}

.ph-checkout-skel__input {
  width: 100%;
  height: 48px;
  border-radius: 12px;
}

.ph-checkout-skel__row2 {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 14px;
  margin: 12px 0;
}

.ph-checkout-skel__divider {
  width: 100%;
  height: 1px;
  background: #e6e6e6;
  margin: 18px 0;
}

.ph-checkout-skel__btnsm {
  width: 100%;
  height: 48px;
  border-radius: 12px;
}

.ph-checkout-skel__payment {
  width: 100%;
  height: 280px; /* matches Stripe element “block” feel */
  border-radius: 16px;
  margin-top: 10px;
}

.ph-checkout-skel__place {
  width: 100%;
  height: 52px;
  border-radius: 999px;
  margin-top: 18px;
}

/* Right summary */
.ph-checkout-skel__item {
  display: grid;
  grid-template-columns: 74px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  margin-top: 12px;
}

.ph-checkout-skel__thumb {
  width: 74px;
  height: 74px;
  border-radius: 14px;
}

.ph-checkout-skel__info .ph-skel-line {
  margin: 8px 0;
}

.ph-checkout-skel__totals {
  margin-top: 10px;
}

.ph-checkout-skel__totrow {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
}

.ph-checkout-skel__totrow .ph-skel-line {
  margin: 8px 0;
}

.ph-checkout-skel__totrow--total .ph-skel-line {
  height: 16px;
}

/* ---------- Checkout “instant header” inside overlay ---------- */
.ph-checkout-skel__topbar{
  position: sticky;
  top: 0;
  z-index: 5;
  background: #fff;
  border-bottom: 1px solid #eee;
}

.ph-checkout-skel__topbar-inner{
  display: flex;
  align-items: center;
  justify-content: flex-start; /* Desktop: logo + text on same (left) side */
  gap: clamp(8px, 1.2vw, 12px);
  padding: clamp(10px, 1.6vw, 14px) 0;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

.ph-checkout-skel__logo{
  display: block;
  height: clamp(16px, 1.6vw + 8px, 19px);
  width: auto;
  max-width: clamp(140px, 18vw, 175px);
  transform: none !important; /* avoid blur from scaling */
}

.ph-checkout-skel__secure{
  font-weight: 400;
  font-size: clamp(1.05rem, 1.2vw + 0.6rem, 1.3rem);
  line-height: 1;
  white-space: nowrap;
}

/* ---------- Mobile: stack (summary below) + header sizing fixes ---------- */
@media (max-width: 61.24em) {
  .ph-checkout-skel {
    grid-template-columns: 1fr;
    gap: 22px;
    padding-left: 0;
    padding-right: 0;
  }

  .ph-checkout-skel__row2 {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .ph-checkout-skel__payment {
    height: 240px;
  }

  /* Mobile: logo left, Secure Checkout right + smaller sizing */
  .ph-checkout-skel__topbar-inner{
    justify-content: space-between; /* Mobile: split sides */
    padding: 10px 0;
  }

  .ph-checkout-skel__logo{
    height: clamp(18px, 2.6vw, 20px);
    max-width: clamp(150px, 26vw, 180px);
  }

  .ph-checkout-skel__secure{
    font-size: clamp(1.1rem, 2.2vw, 1.25rem);
    margin-left: auto; /* extra safety to keep it on the right */
  }
}





/* ---------- Favorites variant ----------
   Favorites uses PRODUCTS grid/cards, but header should look like category pages:
   - no toolbar
   - title first (SHORTER)
   - subtitle line second (LONGER)
*/
html[data-ph-archive-skel-variant="favorites"] .ph-archive-skel__toolbar {
  display: none !important;
}

/* Top line (title) — shorter */
html[data-ph-archive-skel-variant="favorites"]
  .ph-archive-click-skeleton
  .ph-archive-skel--products
  .ph-archive-skel__header
  .ph-skel-h1 {
  width: 32% !important;     /* shorter first line */
  margin-bottom: 10px;       /* space before subtitle */
}

/* Second line (subtitle) — longer */
html[data-ph-archive-skel-variant="favorites"]
  .ph-archive-click-skeleton
  .ph-archive-skel--products
  .ph-archive-skel__header
  .ph-skel-h1::after {
  content: "";
  display: block;
  height: 14px;
  border-radius: 7px;
  margin: 12px auto 0;
  width: 58%;                /* longer second line */

  background: #f1f1f1;
}

/* Mobile tuning */
@media (max-width: 61.24em) {
  html[data-ph-archive-skel-variant="favorites"]
    .ph-archive-click-skeleton
    .ph-archive-skel--products
    .ph-archive-skel__header
    .ph-skel-h1 {
    width: 55% !important;
  }

  html[data-ph-archive-skel-variant="favorites"]
    .ph-archive-click-skeleton
    .ph-archive-skel--products
    .ph-archive-skel__header
    .ph-skel-h1::after {
    width: 80%;
  }
}

/* Reduced motion */
/* (REMOVED — handled by overlay-based shimmer below) */


/* ================================
   Skeleton shimmer (overlay-based)
   Applies to ALL archive skeleton placeholders
   ================================ */

.ph-archive-click-skeleton .ph-skel-pulse,
.ph-archive-click-skeleton .ph-skel-line,
.ph-archive-click-skeleton .ph-skel-pill,
.ph-archive-click-skeleton .ph-skel-h1,
.ph-archive-click-skeleton .ph-archive-card__thumb,
.ph-archive-click-skeleton .ph-pdp-skel__heart,
.ph-archive-click-skeleton .ph-pdp-skel__navbtn,
.ph-archive-click-skeleton .ph-pdp-skel__btn,
.ph-archive-click-skeleton .ph-checkout-skel__card,
.ph-archive-click-skeleton .ph-checkout-skel__input,
.ph-archive-click-skeleton .ph-checkout-skel__btnsm,
.ph-archive-click-skeleton .ph-checkout-skel__payment,
.ph-archive-click-skeleton .ph-checkout-skel__place,
.ph-archive-click-skeleton .ph-checkout-skel__thumb {
  position: relative;
  overflow: hidden;
  background-color: #f1f1f1 !important;
}

.ph-archive-click-skeleton .ph-skel-pulse::before,
.ph-archive-click-skeleton .ph-skel-line::before,
.ph-archive-click-skeleton .ph-skel-pill::before,
.ph-archive-click-skeleton .ph-skel-h1::before,
.ph-archive-click-skeleton .ph-archive-card__thumb::before,
.ph-archive-click-skeleton .ph-pdp-skel__heart::before,
.ph-archive-click-skeleton .ph-pdp-skel__navbtn::before,
.ph-archive-click-skeleton .ph-pdp-skel__btn::before,
.ph-archive-click-skeleton .ph-checkout-skel__card::before,
.ph-archive-click-skeleton .ph-checkout-skel__input::before,
.ph-archive-click-skeleton .ph-checkout-skel__btnsm::before,
.ph-archive-click-skeleton .ph-checkout-skel__payment::before,
.ph-archive-click-skeleton .ph-checkout-skel__place::before,
.ph-archive-click-skeleton .ph-checkout-skel__thumb::before {
  content: "";
  position: absolute;
  inset: 0;
  transform: translate3d(-120%, 0, 0);

  background-image: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0) 0%,
    rgba(255, 255, 255, 0.35) 35%,
    rgba(255, 255, 255, 0.7) 50%,
    rgba(255, 255, 255, 0.35) 65%,
    rgba(255, 255, 255, 0) 100%
  );

  animation: phArchiveShimmerX 1.25s linear infinite;
  will-change: transform;
  pointer-events: none;
  border-radius: inherit;
}

@keyframes phArchiveShimmerX {
  0%   { transform: translate3d(-120%, 0, 0); }
  100% { transform: translate3d(120%, 0, 0); }
}

@media (prefers-reduced-motion: reduce) {
  .ph-archive-click-skeleton .ph-skel-pulse::before,
  .ph-archive-click-skeleton .ph-skel-line::before,
  .ph-archive-click-skeleton .ph-skel-pill::before,
  .ph-archive-click-skeleton .ph-skel-h1::before,
  .ph-archive-click-skeleton .ph-archive-card__thumb::before,
  .ph-archive-click-skeleton .ph-pdp-skel__heart::before,
  .ph-archive-click-skeleton .ph-pdp-skel__navbtn::before,
  .ph-archive-click-skeleton .ph-pdp-skel__btn::before,
  .ph-archive-click-skeleton .ph-checkout-skel__card::before,
  .ph-archive-click-skeleton .ph-checkout-skel__input::before,
  .ph-archive-click-skeleton .ph-checkout-skel__btnsm::before,
  .ph-archive-click-skeleton .ph-checkout-skel__payment::before,
  .ph-archive-click-skeleton .ph-checkout-skel__place::before,
  .ph-archive-click-skeleton .ph-checkout-skel__thumb::before {
    animation: none !important;
    opacity: 0;
  }
}
