/*
 * Kit Blocks — shared stylesheet (front + editor)
 * -------------------------------------------------
 * Brand-agnostic. Colour comes from --accent, which the theme sets per site
 * (GigGear #EF233C, JP Cases #53d4fa). Hover/text shades are derived with
 * color-mix() so neither store needs forked CSS.
 *
 * Uses: native nesting, container queries, color-mix(), clamp(), logical
 * properties, :has(), text-wrap. Targets evergreen browsers.
 */

:where(.kit-section, .kit-heading, .kit-btn, .kit-badge, .kit-spec, .kit-media,
       .kit-grid, .kit-card, .kit-product, .kit-trust, .kit-review) {
  /* Material palette — overridable from the theme */
  --kit-page: #F4F2ED;
  --kit-card: #FFFFFF;
  --kit-panel: #23221F;
  --kit-chrome: #1A1917;
  --kit-ink: #1A1917;
  --kit-muted: #56554F;

  --accent: #EF233C;
  --kit-on-accent: #FFFFFF;
  --kit-accent-hover: color-mix(in srgb, var(--accent) 82%, #000);
  --kit-accent-text: color-mix(in srgb, var(--accent) 88%, #000);

  --kit-instock: #1D9E75;
  --kit-lowstock: #BA7517;
  --kit-outstock: #8A8980;

  --kit-radius: 8px;
  --kit-seam: color-mix(in srgb, currentColor 14%, transparent);

  --kit-display: "Barlow Condensed", system-ui, sans-serif;
  --kit-body: "Geist", system-ui, -apple-system, sans-serif;
  --kit-mono: "Geist Mono", ui-monospace, "SFMono-Regular", monospace;
}

/* ---------- kit/section ---------- */
.kit-section {
  font-family: var(--kit-body);
  position: relative;
  background-position: center;
  background-size: cover;
  padding-block: clamp(2.5rem, 6vw, 5rem);

  &.pad-sm { padding-block: clamp(1.25rem, 3vw, 2rem); }
  &.is-paper { background-color: var(--kit-page); color: var(--kit-ink); }
  &.is-panel { background-color: var(--kit-panel); color: #E8E7E2; }
  &.is-chrome { background-color: var(--kit-chrome); color: #FFFFFF; }

  /* When a chrome/panel section carries a background image, drop a scrim so
     text stays legible — done with :has(), no extra markup. */
  &.has-bg:where(.is-chrome, .is-panel)::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg,
      color-mix(in srgb, var(--kit-chrome) 88%, transparent),
      color-mix(in srgb, var(--kit-chrome) 45%, transparent));
  }
}
.kit-section__inner {
  position: relative;
  z-index: 1;
  max-inline-size: 1200px;
  margin-inline: auto;
  padding-inline: clamp(1rem, 4vw, 2rem);
}

/* ---------- kit/grid (container-query responsive) ---------- */
.kit-grid {
  --kit-cols: 3;
  container-type: inline-size;
  display: grid;
  grid-template-columns: repeat(var(--kit-cols), minmax(0, 1fr));
  gap: 1rem;

  &.gap-sm { gap: 0.5rem; }
  &.gap-lg { gap: 1.5rem; }
}
.kit-grid__inner { display: contents; }

@container (max-width: 780px) {
  .kit-grid:where(:not(.keep-cols)) { grid-template-columns: repeat(min(var(--kit-cols), 3), minmax(0, 1fr)); }
}
@container (max-width: 540px) {
  .kit-grid:where(:not(.keep-cols)) { grid-template-columns: repeat(min(var(--kit-cols), 2), minmax(0, 1fr)); }
}
@container (max-width: 360px) {
  .kit-grid:where(:not(.keep-cols)) { grid-template-columns: 1fr; }
}

/* ---------- kit/heading ---------- */
.kit-heading {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;

  & .kit-heading__eyebrow {
    font-family: var(--kit-display);
    font-weight: 600;
    font-size: 0.8125rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--accent);
  }
  & .kit-heading__title {
    font-family: var(--kit-display);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.01em;
    line-height: 0.98;
    text-wrap: balance;
    margin: 0;
    font-size: clamp(1.9rem, 3.4vw, 2.75rem);
  }
  &:has(h1) .kit-heading__title { font-size: clamp(2.4rem, 5.2vw, 4.25rem); }
}

/* ---------- kit/button ---------- */
.kit-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--kit-body);
  font-weight: 500;
  font-size: 0.9375rem;
  line-height: 1;
  padding-block: 0.8rem;
  padding-inline: 1.4rem;
  border-radius: var(--kit-radius);
  border: 1px solid transparent;
  text-decoration: none;
  cursor: pointer;
  transition: background-color 0.15s, border-color 0.15s, transform 0.05s;

  &:active { transform: scale(0.985); }

  &.kit-btn--primary { background: var(--accent); color: var(--kit-on-accent); }
  &.kit-btn--primary:hover { background: var(--kit-accent-hover); }

  &.kit-btn--dark { background: var(--kit-ink); color: #fff; }
  &.kit-btn--dark:hover { background: #000; }

  &.kit-btn--ghost { border-color: color-mix(in srgb, currentColor 40%, transparent); color: inherit; }
  &.kit-btn--ghost:hover { background: color-mix(in srgb, currentColor 10%, transparent); }

  &.kit-btn--outline { border-color: var(--kit-seam); color: inherit; }
  &.kit-btn--outline:hover { background: color-mix(in srgb, currentColor 6%, transparent); }
}

/* ---------- kit/badge ---------- */
.kit-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  font-family: var(--kit-display);
  font-weight: 600;
  font-size: 0.6875rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding-block: 0.2rem;
  padding-inline: 0.55rem;
  border-radius: 4px;

  &.kit-badge--sale { background: var(--accent); color: var(--kit-on-accent); }
  &.kit-badge--new { background: var(--kit-ink); color: #fff; }
  &.kit-badge--info { background: color-mix(in srgb, var(--accent) 14%, transparent); color: var(--kit-accent-text); }
  &.kit-badge--stock-in { background: none; color: var(--kit-instock); letter-spacing: normal; text-transform: none; font-family: var(--kit-body); }
  &.kit-badge--stock-out { background: none; color: var(--kit-outstock); letter-spacing: normal; text-transform: none; font-family: var(--kit-body); }
  &:where(.kit-badge--stock-in, .kit-badge--stock-out)::before {
    content: ""; inline-size: 7px; block-size: 7px; border-radius: 50%; background: currentColor;
  }
}

/* ---------- kit/spec-stat ---------- */
.kit-spec {
  display: flex;
  flex-direction: column;
  & .kit-spec__value {
    font-family: var(--kit-display);
    font-weight: 600;
    font-size: clamp(1.5rem, 2.6vw, 1.75rem);
    letter-spacing: 0.01em;
  }
  & .kit-spec__label {
    font-family: var(--kit-mono);
    font-size: 0.75rem;
    color: color-mix(in srgb, currentColor 60%, transparent);
  }
}

/* ---------- ball-corner brackets (shared signature) ---------- */
.kit-corner {
  position: absolute;
  inline-size: 14px;
  block-size: 14px;
  border: 2px solid var(--accent);
  z-index: 2;
  pointer-events: none;
  &.kit-corner--tl { inset-block-start: 8px; inset-inline-start: 8px; border-inline-end: 0; border-block-end: 0; }
  &.kit-corner--tr { inset-block-start: 8px; inset-inline-end: 8px; border-inline-start: 0; border-block-end: 0; }
  &.kit-corner--bl { inset-block-end: 8px; inset-inline-start: 8px; border-inline-end: 0; border-block-start: 0; }
  &.kit-corner--br { inset-block-end: 8px; inset-inline-end: 8px; border-inline-start: 0; border-block-start: 0; }
}

/* ---------- kit/media ---------- */
.kit-media {
  position: relative;
  margin: 0;
  border-radius: var(--kit-radius);
  overflow: clip;
  & img { display: block; inline-size: 100%; block-size: 100%; object-fit: cover; }
  & .kit-media__ph {
    aspect-ratio: 4 / 3;
    background: color-mix(in srgb, var(--kit-ink) 10%, var(--kit-page));
    display: grid;
    place-items: center;
  }
  &.kit-media--corners { overflow: visible; }
}

/* ---------- kit/card ---------- */
.kit-card {
  position: relative;
  border-radius: var(--kit-radius);
  border: 1px solid var(--kit-seam);
  background: var(--kit-card);
  color: var(--kit-ink);
  overflow: clip;
  transition: transform 0.15s, box-shadow 0.15s;

  &.is-panel { background: var(--kit-panel); color: #E8E7E2; }
  &.is-chrome { background: var(--kit-chrome); color: #fff; }
  &.has-corners { overflow: visible; }
  &:hover { transform: translateY(-3px); box-shadow: 0 8px 22px color-mix(in srgb, var(--kit-ink) 10%, transparent); }
}
.kit-card__inner { padding: 1.1rem 1.25rem; }

/* ---------- kit/product-card ---------- */
.kit-product {
  position: relative;
  display: flex;
  flex-direction: column;
  border-radius: var(--kit-radius);
  border: 1px solid var(--kit-seam);
  background: var(--kit-card);
  color: var(--kit-ink);
  text-decoration: none;
  overflow: clip;
  transition: transform 0.15s, box-shadow 0.15s;

  &.kit-product--corners { overflow: visible; }
  &:hover { transform: translateY(-3px); box-shadow: 0 8px 22px color-mix(in srgb, var(--kit-ink) 10%, transparent); }
  &.kit-product--empty { padding: 2rem; text-align: center; color: var(--kit-muted); font-family: var(--kit-mono); font-size: 0.8rem; }
}
.kit-product__media {
  margin: 0;
  aspect-ratio: 1;
  background: color-mix(in srgb, var(--kit-ink) 8%, var(--kit-page));
  & img { inline-size: 100%; block-size: 100%; object-fit: contain; }
}
.kit-product__body { display: flex; flex-direction: column; gap: 0.5rem; padding: 0.9rem; flex: 1; }
.kit-product__name { font-size: 0.875rem; font-weight: 500; line-height: 1.4; text-wrap: pretty; }
.kit-product__meta { display: flex; align-items: center; justify-content: space-between; margin-block-start: auto; }
.kit-product__price { font-family: var(--kit-mono); font-weight: 500; font-size: 0.9375rem; }
.kit-product__price del { color: var(--kit-muted); font-weight: 400; margin-inline-end: 0.35rem; }
.kit-product__stock {
  display: inline-flex; align-items: center; gap: 0.35rem; font-size: 0.72rem; font-weight: 500;
  &::before { content: ""; inline-size: 7px; block-size: 7px; border-radius: 50%; background: currentColor; }
  &.is-instock { color: var(--kit-instock); }
  &.is-outstock { color: var(--kit-outstock); }
}

/* ---------- kit/trust-item ---------- */
.kit-trust {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  & .kit-trust__icon { color: var(--accent); flex-shrink: 0; display: inline-flex; }
  & .kit-trust__icon svg { inline-size: 26px; block-size: 26px; }
  & .kit-trust__title { display: block; font-size: 0.875rem; font-weight: 500; }
  & .kit-trust__sub { display: block; font-family: var(--kit-mono); font-size: 0.72rem; color: color-mix(in srgb, currentColor 60%, transparent); }
}

/* ---------- kit/review-card ---------- */
.kit-review {
  margin: 0;
  padding: 1.5rem;
  border-radius: var(--kit-radius);
  border: 1px solid var(--kit-seam);
  background: color-mix(in srgb, currentColor 5%, transparent);
  & .kit-review__title {
    font-family: var(--kit-display); font-weight: 600; text-transform: uppercase;
    letter-spacing: 0.02em; font-size: 1.125rem; margin: 0 0 0.5rem;
  }
  & .kit-review__quote { margin: 0 0 0.75rem; font-size: 0.9rem; text-wrap: pretty; color: color-mix(in srgb, currentColor 80%, transparent); }
  & .kit-review__cite { font-style: normal; font-size: 0.8rem; font-weight: 500; }
}

@media (prefers-reduced-motion: reduce) {
  .kit-btn, .kit-card, .kit-product { transition: none; }
}

/* ---------- kit/countdown ---------- */
.kit-countdown {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  align-items: flex-start;
  font-family: var(--kit-body);
}
.kit-countdown__label {
  font-family: var(--kit-display);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.8125rem;
  color: var(--accent);
}
.kit-countdown__row { display: flex; gap: 0.5rem; }
.kit-countdown__unit {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-inline-size: 3.25rem;
  padding-block: 0.5rem;
  padding-inline: 0.35rem;
  border-radius: var(--kit-radius);
  background: color-mix(in srgb, currentColor 8%, transparent);
  border: 1px solid var(--kit-seam);
}
.kit-countdown__num {
  font-family: var(--kit-mono);
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.kit-countdown__lab {
  font-family: var(--kit-mono);
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: color-mix(in srgb, currentColor 60%, transparent);
  margin-block-start: 0.25rem;
}
.kit-countdown__done {
  font-family: var(--kit-display);
  font-weight: 700;
  text-transform: uppercase;
  font-size: 1.25rem;
  color: var(--accent);
}
