/* Kit Blocks — component styles. Namespaced kit-, consumes tokens.css. */

/* ============ SECTION (layout primitive) ============ */
.kit-section { position: relative; }
.kit-section--base  { background: var(--kit-base); }
.kit-section--alt   { background: var(--kit-base-2); border-top: 1px solid var(--kit-line); border-bottom: 1px solid var(--kit-line); }
.kit-section--dark  { background: var(--kit-ink); color: var(--kit-base); }
.kit-section--dark .kit-section__inner { color: var(--kit-base); }

.kit-section--sp-none .kit-section__inner { padding-top: 0; padding-bottom: 0; }
.kit-section--sp-sm   .kit-section__inner { padding-top: var(--kit-sp-sm); padding-bottom: var(--kit-sp-sm); }
.kit-section--sp-md   .kit-section__inner { padding-top: var(--kit-sp-md); padding-bottom: var(--kit-sp-md); }
.kit-section--sp-lg   .kit-section__inner { padding-top: var(--kit-sp-lg); padding-bottom: var(--kit-sp-lg); }
.kit-section--sp-xl   .kit-section__inner { padding-top: var(--kit-sp-xl); padding-bottom: var(--kit-sp-xl); }

.kit-section__inner { margin-inline: auto; padding-inline: 24px; max-width: var(--kit-container); }
.kit-section--wide .kit-section__inner { max-width: var(--kit-container-wide); }
.kit-section--full .kit-section__inner { max-width: none; padding-inline: 0; }
.kit-section--patterned {
  background-image: radial-gradient(circle at 1px 1px, rgba(0,0,0,.05) 1px, transparent 0);
  background-size: 22px 22px;
}

/* ============ GRID ============ */
.kit-grid { display: grid; gap: 16px; }
.kit-grid--gap-sm { gap: 10px; }
.kit-grid--gap-lg { gap: 24px; }
.kit-grid--cols-1 { grid-template-columns: 1fr; }
.kit-grid--cols-2 { grid-template-columns: repeat(2, 1fr); }
.kit-grid--cols-3 { grid-template-columns: repeat(3, 1fr); }
.kit-grid--cols-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px) { .kit-grid--cols-3, .kit-grid--cols-4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .kit-grid { grid-template-columns: 1fr !important; } }

/* ============ BUTTONS ============ */
.kit-btn {
  display: inline-block;  font-weight: 600;
  text-decoration: none; letter-spacing: .02em; border-radius: var(--kit-radius-sm);
  border: 1px solid transparent; cursor: pointer; transition: background .15s, transform .1s, border-color .15s;
}
.kit-btn:active { transform: translateY(1px); }
.kit-btn--sm { font-size: 13px; padding: 10px 20px; }
.kit-btn--md { font-size: 15px; padding: 15px 32px; }
.kit-btn--lg { font-size: 17px; padding: 18px 40px; }
.kit-btn--primary { background: var(--kit-accent); color: #fff; }
.kit-btn--primary:hover { background: var(--kit-accent-dk); color: #fff; }
.kit-btn--ghost { background: transparent; color: var(--kit-ink); border-color: var(--kit-line); }
.kit-btn--ghost:hover { border-color: var(--kit-ink); }
.kit-btn--dark { background: var(--kit-ink); color: var(--kit-base); }
.kit-btn--dark:hover { background: #000; color: #fff; }
.kit-btn-row { display: flex; gap: 14px; align-items: center; flex-wrap: wrap; }

/* ============ HERO ============ */
.kit-hero { max-width: 760px; }
.kit-hero__eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase;
  color: var(--kit-accent); margin-bottom: 18px;
}
.kit-hero__eyebrow::before { content: ""; width: 28px; height: 2px; background: var(--kit-accent); }
.kit-hero__title {
   font-weight: 800; line-height: .86;
  text-transform: uppercase; font-size: clamp(72px, 11vw, 132px); margin: 0 0 22px;
}
.kit-hero__title em { font-style: normal; color: var(--kit-accent); }
.kit-hero__sub {
  color: var(--kit-ink-soft);
 max-width: 540px; margin: 0 0 34px;
}
.kit-hero__sub b { color: var(--kit-ink); font-weight: 600; }

/* ============ STAT (big number card) ============ */
.kit-stat {
  background: var(--kit-white); border: 1px solid var(--kit-line); border-radius: var(--kit-radius);
  padding: 30px 26px; transition: transform .15s, box-shadow .15s; height: 100%;
}
.kit-stat:hover { transform: translateY(-3px); box-shadow: var(--kit-shadow); }
.kit-stat__value {font-weight: 800; font-size: 60px; line-height: .9; color: var(--kit-accent); }
.kit-stat__value small { display: block; font-size: 22px; color: var(--kit-ink); font-weight: 600; letter-spacing: .04em; text-transform: uppercase; }
.kit-stat__title {font-size: 18px; font-weight: 600; margin: 14px 0 6px; }
.kit-stat__text  {font-size: 14px; color: var(--kit-ink-soft); margin: 0; }

/* ============ FEATURE (icon + title + text) ============ */
.kit-feature { text-align: center; padding: 8px; }
.kit-feature__icon { color: var(--kit-accent); margin-bottom: 10px; display: flex; justify-content: center; }
.kit-feature__title {  font-size: 15px; font-weight: 600; margin: 0 0 4px; }
.kit-feature__text  {  font-size: 13px; color: var(--kit-ink-soft); margin: 0; }

/* ============ CTA BANNER ============ */
.kit-cta {
  background: var(--kit-ink); color: var(--kit-base); border-radius: var(--kit-radius);
  padding: 44px 40px; display: flex; align-items: center; justify-content: space-between;
  gap: 28px; flex-wrap: wrap;
}
.kit-cta__heading { font-weight: 700; text-transform: uppercase; line-height: 1; color: #fff; font-size: clamp(26px, 4vw, 38px); margin: 0; }
.kit-cta__text { color: #B9B4AC; font-size: 15px; margin: 8px 0 0; max-width: 480px; }

/* ============ COUNTDOWN wrapper ============ */
.kit-countdown { max-width: 420px; }

/* ============ ACCORDION ============ */
.kit-accordion { border-top: 1px solid var(--kit-line); }
.kit-acc-item { border-bottom: 1px solid var(--kit-line); }
.kit-acc-item > summary {
  list-style: none; cursor: pointer; padding: 18px 4px;;
  font-size: 17px; font-weight: 600; color: var(--kit-ink);
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
}
.kit-acc-item > summary::-webkit-details-marker { display: none; }
.kit-acc-item > summary::after { content: "+"; font-size: 26px; color: var(--kit-accent); line-height: 1; transition: transform .2s; }
.kit-acc-item[open] > summary::after { transform: rotate(45deg); }
.kit-acc-item__body { padding: 0 4px 20px; color: var(--kit-ink-soft); font-size: 15px; line-height: 1.6; }

/* ============ PRODUCT GRID ============ */
.kit-products { display: grid; gap: 16px; }
.kit-products--cols-1 { grid-template-columns: 1fr; }
.kit-products--cols-2 { grid-template-columns: repeat(2, 1fr); }
.kit-products--cols-3 { grid-template-columns: repeat(3, 1fr); }
.kit-products--cols-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px) { .kit-products--cols-3, .kit-products--cols-4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .kit-products { grid-template-columns: 1fr !important; } }

.kit-products__card {
  background: var(--kit-white); border: 1px solid var(--kit-line); border-radius: var(--kit-radius);
  overflow: hidden; display: flex; flex-direction: column; transition: transform .15s, box-shadow .15s;
}
.kit-products__card:hover { transform: translateY(-3px); box-shadow: var(--kit-shadow); }
.kit-products__img { position: relative; aspect-ratio: 1/1; background: var(--kit-base-2); display: block; }
.kit-products__img img { width: 100%; height: 100%; object-fit: contain; padding: 14px; }
.kit-products__badge {
  position: absolute; top: 12px; left: 12px; background: var(--kit-accent); color: #fff;
   font-size: 12px; font-weight: 600; letter-spacing: .03em;
  padding: 5px 10px; border-radius: var(--kit-radius-sm); z-index: 2;
}
.kit-products__body { padding: 16px 16px 18px; display: flex; flex-direction: column; flex: 1; }
.kit-products__cat { font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--kit-ink-soft); margin-bottom: 7px; }
.kit-products__name { font-size: 15px; font-weight: 500; line-height: 1.3; margin-bottom: 14px; flex: 1; }
.kit-products__name a { color: inherit; text-decoration: none; }
.kit-products__name a:hover { color: var(--kit-accent); }
.kit-products__price { display: flex; align-items: baseline; gap: 9px; flex-wrap: wrap; }
.kit-products__price del { color: var(--kit-ink-soft); font-size: 13px; }
.kit-products__price ins { color: var(--kit-accent); font-weight: 600; font-size: 19px; text-decoration: none; }
.kit-products__price .amount { font-weight: 600; }
.kit-products__btn {
  margin-top: 14px; text-align: center; border: 1px solid var(--kit-ink); border-radius: var(--kit-radius-sm);
  padding: 10px; font-size: 13px; font-weight: 500; color: var(--kit-ink); text-decoration: none; transition: all .15s;
}
.kit-products__btn:hover { background: var(--kit-ink); color: var(--kit-base); }
.kit-products__empty { color: var(--kit-ink-soft); }

/* ============ Editor niceties ============ */
.kit-section .block-editor-inner-blocks { width: 100%; }
