/* =====================================================================
 * front.css — Front page only (is_front_page).
 *
 * Owns: hero, category strip, featured grid, "two-path" buy/print
 * section, maker line / signature, homepage-only adjustments.
 * Atoms (cards, buttons, eyebrows) live in base.css.
 * ===================================================================== */

/* ---------- Hero ---------- */
.f3d-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--f3d-sp-20);
  padding: var(--f3d-sp-20) var(--f3d-page-pad-x) var(--f3d-section-gap);
  align-items: center;
  max-width: var(--f3d-content-max);
  margin: 0 auto;
}

.f3d-hero__left { max-width: 520px; }

.f3d-hero__title {
  font-family: var(--f3d-font-display);
  font-size: var(--f3d-fs-display-xl);
  font-weight: var(--f3d-fw-light);
  line-height: var(--f3d-lh-display);
  letter-spacing: var(--f3d-ls-display);
  margin: 0 0 var(--f3d-sp-7);
  color: var(--f3d-ink-primary);
}

.f3d-hero__lede {
  font-size: var(--f3d-fs-lede);
  line-height: var(--f3d-lh-relaxed);
  color: var(--f3d-ink-soft);
  margin: 0 0 var(--f3d-sp-8);
  max-width: 460px;
}

.f3d-hero__ctas {
  display: flex;
  gap: var(--f3d-sp-5);
  align-items: center;
  flex-wrap: wrap;
}

.f3d-hero__right { position: relative; }
.f3d-hero__image {
  display: block;
  background: var(--f3d-bg-paper);
  aspect-ratio: 1 / 0.82;
  overflow: hidden;
  text-decoration: none;
}
.f3d-hero__image img { width: 100%; height: 100%; object-fit: cover; }

.f3d-hero__meta {
  text-decoration: none;
  color: inherit;
  transition: border-color var(--f3d-dur) var(--f3d-easing),
              box-shadow var(--f3d-dur) var(--f3d-easing);
  position: absolute;
  right: var(--f3d-sp-6);
  bottom: var(--f3d-sp-6);
  background: var(--f3d-bg-base);
  padding: var(--f3d-sp-5) var(--f3d-sp-6);
  font-family: var(--f3d-font-mono);
  font-size: var(--f3d-fs-eye);
  min-width: 260px;
  border: 1px solid var(--f3d-rule);
  border-radius: var(--f3d-radius);
  box-shadow: var(--f3d-shadow-sm);
}
.f3d-hero__meta-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  /* Hard gap so labels and values can never collide even when the
     meta card is at its min-width. Without this, "PRINTET HOS" runs
     directly into "Noerstad verksted" because both sides are flex
     children with no internal whitespace. */
  gap: var(--f3d-sp-6);
  padding: 3px 0;
}
.f3d-hero__meta-row > span:first-child {
  color: var(--f3d-ink-faint);
  text-transform: uppercase;
  letter-spacing: var(--f3d-ls-loose);
}
.f3d-hero__meta-row > span:last-child { color: var(--f3d-ink-primary); }
.f3d-hero__meta:hover {
  border-color: var(--f3d-ink-primary);
  box-shadow: var(--f3d-shadow-sm);
}

/* ---------- Category strip ---------- */
.f3d-cat-strip {
  padding: var(--f3d-sp-3) var(--f3d-page-pad-x) var(--f3d-sp-16);
  max-width: var(--f3d-content-max);
  margin: 0 auto;
}

.f3d-cat-strip__head { margin-bottom: var(--f3d-sp-5); }

.f3d-cat-strip__grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--f3d-sp-5);
}

/* Cat strip uses .f3d-cat-card (defined in base.css) for the cards
   themselves; the strip just provides the responsive grid container. */

/* ---------- Featured grid ---------- */
.f3d-featured {
  padding: 0 var(--f3d-page-pad-x) var(--f3d-sp-20);
  max-width: var(--f3d-content-max);
  margin: 0 auto;
}

.f3d-featured__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: var(--f3d-sp-10);
}

.f3d-featured__h {
  font-size: var(--f3d-fs-display-m);
  margin: 0;
}

/* The [products] shortcode renders via our loop-start template
 * which emits `<div class="woocommerce columns-3"><div class="f3d-shop-grid">`.
 * `.f3d-shop-grid` inherits the SHOP archive's auto-fill grid
 * (cards max 280px each) — which on the front page gives oversized
 * cards stacked vertically when the wrapper is narrow. Force
 * exactly 3 equal columns here. */
.f3d-featured__grid .woocommerce,
.f3d-featured__grid .woocommerce.columns-3 {
  display: block !important;
  width: 100%;
  float: none;
  margin: 0;
  padding: 0;
}
.f3d-featured__grid .f3d-shop-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: var(--f3d-sp-10);
  width: 100%;
}
.f3d-featured__grid .f3d-shop-grid > .f3d-card,
.f3d-featured__grid .f3d-shop-grid > article {
  width: auto !important;
  min-width: 0;
  margin: 0;
  float: none;
}

/* ---------- Two-path: Buy or Print ---------- */
.f3d-paths {
  background: var(--f3d-bg-cream);
  padding: var(--f3d-section-gap) var(--f3d-page-pad-x);
}

.f3d-paths__inner {
  display: grid;
  grid-template-columns: 1fr 1px 1fr;
  gap: var(--f3d-sp-20);
  max-width: 1100px;
  margin: 0 auto;
}

.f3d-paths__num {
  font-family: var(--f3d-font-mono);
  font-size: var(--f3d-fs-eye);
  color: var(--f3d-accent);
  text-transform: uppercase;
  letter-spacing: var(--f3d-ls-eye);
  margin-bottom: var(--f3d-sp-4);
}
.f3d-paths__num--alt { color: var(--f3d-ink-faint); }

.f3d-paths__title {
  font-size: var(--f3d-fs-display-s);
  margin: 0 0 var(--f3d-sp-4);
}

.f3d-paths__body {
  font-size: var(--f3d-fs-body);
  color: var(--f3d-ink-soft);
  margin: 0 0 var(--f3d-sp-5);
  max-width: 400px;
}

.f3d-paths__divider {
  background: var(--f3d-rule);
  width: 1px;
}

/* ---------- Maker signature line ---------- */
.f3d-maker {
  padding: var(--f3d-sp-20) var(--f3d-page-pad-x) var(--f3d-section-gap);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--f3d-sp-7);
  text-align: center;
}

.f3d-maker__line {
  width: 60px;
  height: 1px;
  background: oklch(0.7 0.01 250);
}

.f3d-maker__text {
  font-family: var(--f3d-font-display);
  font-size: var(--f3d-fs-h-l);
  font-style: italic;
  color: var(--f3d-ink-muted);
  margin: 0;
  line-height: var(--f3d-lh-snug);
}

.f3d-maker__by {
  display: block;
  font-family: var(--f3d-font-mono);
  font-size: var(--f3d-fs-eye);
  font-style: normal;
  letter-spacing: var(--f3d-ls-eye);
  text-transform: uppercase;
  color: var(--f3d-ink-faint);
  margin-top: var(--f3d-sp-4);
}

/* ---------- Responsive ---------- */
@media (max-width: 1024px) {
  .f3d-hero { padding-inline: var(--f3d-page-pad-x-md); gap: var(--f3d-sp-12); }
  .f3d-hero__title { font-size: 48px; }
  .f3d-cat-strip,
  .f3d-featured { padding-inline: var(--f3d-page-pad-x-md); }
  .f3d-cat-strip__grid { grid-template-columns: repeat(3, 1fr); }
  .f3d-featured__grid .f3d-shop-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .f3d-paths { padding-inline: var(--f3d-page-pad-x-md); padding-block: var(--f3d-sp-20); }
}

@media (max-width: 768px) {
  .f3d-hero {
    grid-template-columns: 1fr;
    padding-inline: var(--f3d-page-pad-x-sm);
    padding-block: var(--f3d-sp-12) var(--f3d-sp-16);
    gap: var(--f3d-sp-10);
  }
  .f3d-hero__title { font-size: 40px; }
  .f3d-hero__meta { position: static; margin-top: var(--f3d-sp-3); }

  .f3d-cat-strip,
  .f3d-featured { padding-inline: var(--f3d-page-pad-x-sm); }
  .f3d-cat-strip__grid { grid-template-columns: repeat(2, 1fr); gap: var(--f3d-sp-3); }
  .f3d-featured__grid .f3d-shop-grid { grid-template-columns: 1fr !important; gap: var(--f3d-sp-10); }
  .f3d-featured__h { font-size: 32px; }

  .f3d-paths {
    padding-inline: var(--f3d-page-pad-x-sm);
    padding-block: var(--f3d-sp-16);
  }
  .f3d-paths__inner {
    grid-template-columns: 1fr;
    gap: var(--f3d-sp-10);
  }
  .f3d-paths__divider {
    width: auto;
    height: 1px;
  }
  .f3d-paths__title { font-size: 28px; }

  .f3d-maker { padding-block: var(--f3d-sp-16); padding-inline: var(--f3d-page-pad-x-sm); }
  .f3d-maker__text { font-size: var(--f3d-fs-h-m); }
}
