/* ============================================================
   Shared Grön Modern Portfolio styles
   Used by: gron-preamble, gron-voice, gron-category, gron-photography, gron-figma, gron-eatgron
   ============================================================ */

:root {
  --gron-teal: #4FD3BD;
  --gron-dark: #4C0000;
  --gutter: 75px;
}

/* ================= Bands ================= */
.wc-band {
  width: 100%;
  max-width: none;
  padding: clamp(60px, 9vh, 110px) var(--gutter);
}
.wc-band--lg    { padding: clamp(120px, 16vh, 200px) var(--gutter); }
.wc-band--xl    { padding: clamp(160px, 22vh, 250px) var(--gutter); }
.wc-band--sm    { padding: clamp(40px, 6vh, 70px) var(--gutter); }
.wc-band--flush { padding: 0; }

.wc-bg--teal  { background: var(--gron-teal); }
.wc-bg--dark  { background: var(--gron-dark); }
.wc-bg--black { background: #000; }
.wc-bg--white { background: #fff; }

.wc-inner          { max-width: 1240px; margin: 0 auto; }
.wc-inner--narrow  { max-width: 900px; }
.wc-inner--wide    { max-width: 1440px; }
.wc-inner--prose   { max-width: 1100px; margin: 0 auto; padding-left: clamp(0px, 4vw, 60px); }

/* ================= Typography — standardized to Nike Strike Series copy block ================= */
.wc-heading,
.wc-heading--lg,
.wc-heading--xl {
  margin: 0 auto 28px;
  max-width: 900px;
  font-family: var(--f-sans);
  font-size: clamp(32px, 3.8vw, 48px);
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 1.05;
  text-align: left;
}
.wc-heading--italic { font-style: italic; }
.wc-heading--center { text-align: center; }
.wc-heading--light  { font-weight: 600; letter-spacing: -0.025em; }

.wc-body,
.wc-body--lg,
.wc-body--xl {
  margin: 0 auto 1.4em;
  max-width: 900px;
  font-family: var(--f-sans);
  font-size: clamp(19px, 1.3vw, 21px);
  font-weight: 400;
  line-height: 1.65;
  letter-spacing: 0.012em;
  text-align: left;
}

.wc-caption {
  margin: 0 auto;
  max-width: 1100px;
  font-family: var(--f-sans);
  font-size: 14px;
  font-weight: 600;
  line-height: 1.55;
  letter-spacing: 0.04em;
  text-align: left;
  border-left: 3px solid var(--gron-teal);
  padding: 6px 0 6px 22px;
}

.wc-eyebrow {
  margin: 0 auto 18px;
  max-width: 900px;
  font-family: var(--f-sans);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.t-white { color: #fff; }
.t-black { color: #565656; }
.t-teal  { color: var(--gron-teal); }

/* ================= Hero ================= */
.wc-hero {
  width: 100%;
  background: var(--gron-teal);
  padding: clamp(100px, 16vh, 180px) var(--gutter);
  text-align: center;
  color: #fff;
}
.wc-hero__eyebrow {
  margin: 0 0 28px;
  font-family: var(--f-sans);
  font-size: clamp(14px, 1.1vw, 17px);
  font-weight: 700;
  letter-spacing: 0.32em;
  text-transform: uppercase;
}
.wc-hero__title {
  margin: 0;
  font-family: var(--f-sans);
  font-size: clamp(38px, 5vw, 64px);
  font-weight: 300;
  letter-spacing: 0.08em;
  line-height: 1.1;
  text-transform: uppercase;
}

/* ================= Series sub-nav ================= */
.gron-series {
  background: #fff;
  padding: clamp(50px, 8vh, 100px) var(--gutter) clamp(40px, 6vh, 70px);
}
.gron-series__header {
  text-align: center;
  max-width: 900px;
  margin: 0 auto clamp(30px, 5vh, 60px);
}
.gron-series__head {
  margin: 0 0 12px;
  font-family: var(--f-sans);
  font-size: clamp(20px, 1.8vw, 26px);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #565656;
}
.gron-series__lede {
  margin: 0;
  font-family: var(--f-sans);
  font-size: clamp(15px, 1.1vw, 17px);
  line-height: 1.6;
  color: #333;
}
.gron-series__grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: clamp(10px, 1.2vw, 18px);
  max-width: 1440px;
  margin: 0 auto;
}
.gron-series__item { text-decoration: none; color: inherit; display: block; }
.gron-series__thumb {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  display: block;
  background: #f2f2f2;
}
.gron-series__label {
  margin: 12px 0 0;
  font-family: var(--f-sans);
  font-size: 11px;
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-align: center;
  color: #565656;
}
.gron-series__item--active .gron-series__label { color: var(--gron-teal); }
@media (max-width: 860px) {
  .gron-series__grid { grid-template-columns: repeat(3, 1fr); }
}

/* ================= Divider rules ================= */
.wc-rule {
  width: 100%;
  height: 4px;
  background: var(--gron-teal);
  border: 0;
  margin: 0;
}
.wc-rule--white { background: #fff; }

/* ================= Image utilities ================= */
.wc-fullwidth { background: transparent; font-size: 0; line-height: 0; }
.wc-fullwidth img { display: block; width: 100%; height: auto; }

.wc-img--contained {
  display: block;
  width: 100%;
  height: auto;
  margin: 0 auto;
}

/* ================= Video embed ================= */
.wc-video {
  position: relative;
  max-width: 1100px;
  margin: 0 auto;
  aspect-ratio: 16 / 9;
  width: 100%;
  background: #000;
  overflow: hidden;
  border-radius: 16px;
}
.wc-video iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

/* ================= CTA button ================= */
.wc-cta {
  display: inline-block;
  padding: 18px 60px;
  background: #fff;
  color: var(--gron-teal);
  font-family: var(--f-sans);
  font-size: clamp(18px, 1.4vw, 22px);
  font-weight: 600;
  letter-spacing: 0.16em;
  text-decoration: none;
  border: 2px solid #fff;
  transition: background-color .25s ease, color .25s ease, border-color .25s ease;
}
.wc-cta:hover {
  background: #000;
  color: #fff;
  border-color: #000;
}

/* ================= More Grön Projects ================= */
.gron-more {
  background: #fff;
  padding: clamp(80px, 12vh, 140px) var(--gutter);
}
.gron-more__head {
  margin: 0 auto clamp(40px, 6vh, 70px);
  max-width: 1440px;
  font-family: var(--f-sans);
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.1;
  color: #565656;
}
.gron-more__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(18px, 2vw, 32px);
  max-width: 1440px;
  margin: 0 auto;
}
.gron-more__item {
  display: block;
  text-decoration: none;
  color: inherit;
}
.gron-more__thumb {
  margin: 0 0 16px;
  width: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: #f2f2f2;
}
.gron-more__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .35s ease;
}
.gron-more__item:hover .gron-more__thumb img {
  transform: scale(1.04);
}
.gron-more__title {
  margin: 0 0 4px;
  font-family: var(--f-sans);
  font-size: clamp(14px, 1.1vw, 16px);
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.3;
  text-transform: uppercase;
  color: #565656;
}
.gron-more__cat {
  margin: 0;
  font-family: var(--f-sans);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1.3;
  color: #888;
}
@media (max-width: 900px) {
  .gron-more__grid { grid-template-columns: repeat(2, 1fr); }
}

/* ================= Footer =================
   The site-wide sitemap footer lives in home-styles.css; no override here. */
