/* ── PRODUCT DETAIL PAGE ─────────────────────────────────── */



/* ── Scroll offset fix: account for fixed header + sticky product nav ── */

[id] {

  scroll-margin-top: 176px;

}



/* ── Breadcrumb ─────────────────────────────── */

.product-breadcrumb {

  padding: 1rem 0;

  font-size: 0.875rem;

  color: var(--color-gray-500);

  font-family: var(--font-body);

}



.product-breadcrumb a {

  color: var(--color-gray-500);

  text-decoration: none;

  transition: color 0.2s;

}



.product-breadcrumb a:hover {

  color: var(--color-black);

}



.product-breadcrumb span {

  margin: 0 0.5rem;

  opacity: 0.5;

}



/* ── Product Hero ────────────────────────────── */

.product-hero {

  position: relative;

  min-height: 52vh;

  display: flex;

  align-items: flex-end;

  background-size: cover;

  background-position: center;

  overflow: hidden;

}



.product-hero::before {

  content: '';

  position: absolute;

  inset: 0;

  background: linear-gradient(to top, rgba(0, 0, 0, 0.78) 0%, rgba(0, 0, 0, 0.25) 55%, transparent 100%);

}



.product-hero-content {

  position: relative;

  width: 100%;

  max-width: var(--max-width);

  margin: 0 auto;

  padding: var(--space-lg) var(--space-md);

}



.product-hero-content .product-breadcrumb {

  color: rgba(255, 255, 255, 0.65);

}



.product-hero-content .product-breadcrumb a {

  color: rgba(255, 255, 255, 0.65);

}



.product-hero-content .product-breadcrumb a:hover {

  color: #fff;

}



.product-hero h1 {

  font-family: var(--font-display);

  font-size: clamp(2.25rem, 5vw, 4rem);

  font-weight: 700;

  color: #fff;

  text-transform: uppercase;

  letter-spacing: 0.03em;

  margin-top: 0.5rem;

  line-height: 1.05;

}



.product-hero-subtitle {

  font-size: 1.125rem;

  color: rgba(255, 255, 255, 0.75);

  margin-top: 0.5rem;

  font-family: var(--font-body);

  letter-spacing: 0.02em;

}



/* ── Sticky Product Nav ─────────────────────── */

.product-nav {

  position: sticky;

  top: var(--header-height, 110px);

  z-index: 90;

  background: #fff;

  border-bottom: 2px solid var(--color-gray-100);

  overflow-x: auto;

  -webkit-overflow-scrolling: touch;

}



.product-nav-inner {

  max-width: var(--max-width);

  margin: 0 auto;

  padding: 0 var(--space-md);

  display: flex;

  gap: 0;

}



.product-nav a {

  display: block;

  padding: 1rem 1.5rem;

  font-family: var(--font-body);

  font-size: 0.875rem;

  font-weight: 600;

  text-transform: uppercase;

  letter-spacing: 0.06em;

  color: var(--color-gray-500);

  text-decoration: none;

  white-space: nowrap;

  border-bottom: 2px solid transparent;

  margin-bottom: -2px;

  transition: all 0.2s;

}



.product-nav a:hover,

.product-nav a.active {

  color: var(--color-black);

  border-bottom-color: var(--color-black);

}



/* ── Product Sections ────────────────────────── */

.product-section {

  padding: var(--space-xl) 0;

}



.product-section-alt {

  padding: var(--space-xl) 0;

  background: var(--color-gray-50);

}



.product-section-inner {

  max-width: var(--max-width);

  margin: 0 auto;

  padding: 0 var(--space-md);

}



/* Section title */

.product-section-title {

  font-family: var(--font-display);

  font-size: clamp(1.4rem, 2.2vw, 2rem);

  font-weight: 700;

  text-transform: uppercase;

  letter-spacing: 0.04em;

  margin-bottom: var(--space-md);

  color: var(--color-black);

}



.product-section-title::after {

  content: '';

  display: block;

  width: 40px;

  height: 3px;

  background: var(--color-black);

  margin-top: 0.65rem;

}



.product-title-with-logo {

  display: flex;

  align-items: flex-start;

  justify-content: space-between;

  gap: 1rem;

}



.product-title-with-logo .product-section-title {

  margin-bottom: var(--space-md);

}



.product-title-logo {

  width: clamp(140px, 20vw, 220px);

  height: auto;

  object-fit: contain;

}



/* ─────────────────────────────────────────────

   INFO SECTION

   Layout: full-width text on top,

           two images side-by-side below

   ───────────────────────────────────────────── */

.product-info-text {

  font-size: 1.0625rem;

  line-height: 1.85;

  color: var(--color-gray-700);

  max-width: 820px;

}



.product-info-text p+p {

  margin-top: 1.25rem;

}



.product-info-images {

  display: grid;

  grid-template-columns: 1fr 1fr;

  gap: 1.25rem;

  margin-top: var(--space-md);

}



.product-info-images img {

  width: 100%;

  height: 280px;

  object-fit: cover;

  display: block;

  border-radius: 2px;

}



.product-info-top-image {

  margin-top: 0.25rem;

  margin-bottom: 0.75rem;

  display: flex;

  justify-content: center;

}



.product-info-top-image img {

  width: min(100%, 560px);

  height: auto;

  display: block;

  border-radius: 8px;

}



/* ─────────────────────────────────────────────

   3D MODEL — centered, large, prominent

   ───────────────────────────────────────────── */

.product-3d-wrap {

  margin-top: var(--space-lg);

  border-top: 1px solid var(--color-gray-100);

  padding-top: var(--space-lg);

}



.product-3d-label {

  font-family: var(--font-body);

  font-size: 0.75rem;

  font-weight: 700;

  text-transform: uppercase;

  letter-spacing: 0.12em;

  color: var(--color-gray-500);

  margin-bottom: 0.875rem;

}



.product-3d-viewer {

  position: relative;

  width: 100%;

  max-width: 900px;

  margin: 0 auto;

  padding-bottom: 52%;

  /* ~16:8.5 — tall enough for the model */

  height: 0;

  overflow: hidden;

  border-radius: 2px;

  background: var(--color-gray-100);

  box-shadow: 0 4px 32px rgba(0, 0, 0, 0.08);

}



.product-3d-viewer iframe {

  position: absolute;

  top: 0;

  left: 0;

  width: 100%;

  height: 100%;

  border: none;

}



/* ─────────────────────────────────────────────

   TECHNICAL DETAILS

   Two-column specs cards

   ───────────────────────────────────────────── */

.product-specs-grid {

  display: grid;

  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));

  gap: 1px;

  background: var(--color-gray-200);

  border: 1px solid var(--color-gray-200);

  border-radius: 2px;

  overflow: hidden;

}



.product-spec-cell {

  background: #fff;

  padding: 1.5rem 1.75rem;

  display: flex;

  flex-direction: column;

  gap: 0.3rem;

}



.product-spec-label {

  font-family: var(--font-body);

  font-size: 0.75rem;

  font-weight: 700;

  text-transform: uppercase;

  letter-spacing: 0.1em;

  color: var(--color-gray-500);

}



.product-spec-value {

  font-family: var(--font-display);

  font-size: 1.5rem;

  font-weight: 700;

  color: var(--color-black);

  line-height: 1.1;

}



.product-spec-unit {

  font-family: var(--font-body);

  font-size: 0.8125rem;

  font-weight: 500;

  color: var(--color-gray-500);

  margin-top: 0.1rem;

}



/* Diagram below specs */

.product-specs-diagram {

  max-width: 680px;

  margin-top: var(--space-md);

}



.product-specs-diagram img {

  width: 100%;

  height: auto;

  border-radius: 2px;

}



/* ─────────────────────────────────────────────

   COLOUR / COATING SECTION

   ───────────────────────────────────────────── */

.product-colour-grid {

  display: grid;

  grid-template-columns: 1fr 1.6fr;

  gap: var(--space-lg);

  align-items: start;

}



.product-colour-info {

  display: flex;

  flex-direction: column;

  gap: 0.75rem;

}



.product-colour-info h3 {

  font-family: var(--font-display);

  font-size: 1.5rem;

  font-weight: 700;

  color: var(--color-black);

  text-transform: uppercase;

  letter-spacing: 0.03em;

}



.product-colour-name {

  font-family: var(--font-display);

  font-size: 1.125rem;

  font-weight: 600;

  color: var(--color-black);

}



.product-colour-desc {

  font-size: 1rem;

  line-height: 1.75;

  color: var(--color-gray-700);

}



.product-colour-image {

  align-self: start;

}



.product-colour-image img {

  width: 100%;

  height: auto;

  border-radius: 2px;

  display: block;

  cursor: pointer;

}



.product-colour-grid--tofino {

  grid-template-columns: minmax(320px, 1.1fr) minmax(260px, 0.9fr);

  align-items: start;

  gap: 1rem;

}



.product-colour-info--tofino {

  gap: 1.2rem;

  padding-top: 0.25rem;

}



.product-colour-label-group p {

  margin: 0;

  font-family: var(--font-body);

  font-size: clamp(1rem, 1.3vw, 1.15rem);

  font-weight: 500;

  line-height: 1.2;

  letter-spacing: 0.01em;

  color: var(--color-gray-500);

}



.product-colour-label-group p:first-child {

  font-family: var(--font-display);

  font-size: clamp(1.7rem, 2.25vw, 2rem);

  font-weight: 700;

  line-height: 1.05;

  letter-spacing: 0.02em;

  color: var(--color-black);

  margin-bottom: 0.35rem;

}



.product-colour-image--tofino-plus {

  grid-column: 1 / -1;

}



.product-colour-image--tofino-plus img {

  width: min(100%, 760px);

}



.product-colour-grid--tofino-split {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.25rem;
  align-items: start;
}

.product-colour-grid--traditional-soffit {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.5rem;
  align-items: start;
}


.product-colour-group {

  display: flex;

  flex-direction: column;

  gap: 0.75rem;

}



.product-colour-grid--tofino-split .product-colour-label-group {
  min-height: 6.2rem;
}

.product-colour-grid--traditional-soffit .product-colour-label-group {
  min-height: 0;
}


.product-colour-grid--tofino-split .product-colour-image img {
  cursor: default;
  width: 100%;
  max-width: none;
}

.product-colour-grid--traditional-soffit .product-colour-image {
  display: flex;
  justify-content: center;
}

.product-colour-grid--traditional-soffit .product-colour-image img {
  cursor: default;
  width: min(100%, 165px);
  max-width: 165px;
}

.product-colour-grid--traditional-soffit .product-colour-label-group {
  text-align: center;
}


.product-colour-grid--gutter .product-colour-image--gutter {

  align-self: start;

  transform: translateY(-5.8rem);

}



/* Reversed: image left, text right — equal 50/50 columns */

.product-colour-grid--reversed {

  grid-template-columns: 1fr 1fr;

  direction: ltr;

}



.product-colour-grid--reversed .product-colour-image {

  order: -1;

}



.product-colour-grid--reversed.product-colour-grid--gutter .product-colour-image--gutter {

  transform: none;

}



/* ─────────────────────────────────────────────

   INPUT MATERIAL SECTION

   Matches BTR layout: dark grey bg, 3-col grid

   Logo card | Big headline | Material list

   ───────────────────────────────────────────── */

.product-section--materials {

  background: #4D5056;

  color: #fff;

  padding: var(--space-xl) 0;

}



.product-section--materials .product-section-title {

  color: #fff;

}



.product-section--materials .product-section-title::after {

  background: rgba(255, 255, 255, 0.3);

}



/* 3-column grid: logo+photo | headline | material list */

.product-materials-body {

  display: grid;

  grid-template-columns: 440px 1fr 340px;

  gap: 3rem;

  align-items: center;

  /* Center to align the headline nicely with the photos vertically */

}



/* Left col: logo card stacked above photo with exact corner alignment */

.product-materials-left {

  position: relative;

  display: flex;

  flex-direction: column;

  min-height: 480px;

  /* Force the grid row to have height so absolute child doesn't escape downward visually into next section */

}



.product-materials-logo-card {

  background: #fff;

  padding: 1.5rem;

  display: flex;

  align-items: center;

  justify-content: center;

  width: 180px;

  height: 180px;

  position: relative;

  z-index: 2;

  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.15);

  border-radius: 2px;

}



.product-materials-logo-card img {

  width: 100%;

  max-width: 130px;

  height: auto;

  display: block;

}



.product-materials-photo {

  position: absolute;

  top: 180px;

  /* Anchor exactly at bottom of 180px card */

  left: 180px;

  /* Anchor exactly at right of 180px card */

  z-index: 1;

  width: 260px;

  /* Explicit width */

}



.product-materials-photo img {

  width: 100%;

  /* Fill the 260px wrapper */

  height: auto;

  display: block;

  border-radius: 2px;

  box-shadow: 0 15px 40px rgba(0, 0, 0, 0.3);

}



/* Center col: large bold headline */

.product-materials-headline {

  padding-top: 1rem;

}



.product-materials-headline h3 {

  font-family: var(--font-display);

  font-size: clamp(1.6rem, 2.5vw, 2.25rem);

  font-weight: 700;

  color: #fff;

  line-height: 1.25;

}



/* Right col: plain text material entries — no cards, just spacing */

.product-materials-list {

  list-style: none;

  padding: 0;

  margin: 0;

  display: flex;

  flex-direction: column;

  gap: 2rem;

  padding-top: 1rem;

}



.product-materials-list li {

  font-size: 0.9375rem;

  line-height: 1.6;

  color: rgba(255, 255, 255, 0.7);

}



.product-materials-list li strong {

  display: block;

  font-family: var(--font-display);

  font-size: 1.0625rem;

  font-weight: 700;

  color: #fff;

  margin-bottom: 0.4rem;

  letter-spacing: 0.01em;

}



/* ─────────────────────────────────────────────

   PLADUR COATING SECTION

   White background — completely separate from

   the dark materials section.

   Left: heading + text  |  Right: diagram + list

   ───────────────────────────────────────────── */

.product-section--coating {

  background: #fff;

  padding: var(--space-xl) 0;

}



.product-coating-layout {

  display: grid;

  grid-template-columns: 4fr 6fr;

  /* 40% left / 60% right */

  gap: 4rem;

  align-items: center;

}



/* Left: heading + paragraphs */

.product-coating-text h3 {

  font-family: var(--font-display);

  font-size: clamp(1.5rem, 2.5vw, 2rem);

  font-weight: 700;

  color: var(--color-black);

  margin-bottom: 1.5rem;

  line-height: 1.2;

}



.product-coating-text p {

  font-size: 1.0625rem;

  line-height: 1.75;

  color: var(--color-gray-700);

}



.product-coating-text p+p {

  margin-top: 1.25rem;

}



/* Right: diagram + ThyssenKrupp branding + layer list */

.product-coating-visual {

  display: grid;

  grid-template-columns: 1fr 1fr;

  gap: 2rem;

  align-items: center;

}



.product-coating-diagram img {

  width: 100%;

  height: auto;

  display: block;

}



.product-coating-info {

  display: flex;

  flex-direction: column;

}



.product-coating-info-logo {

  display: flex;

  align-items: center;

  gap: 0.75rem;

  margin-bottom: 1rem;

}



.product-coating-info-logo img {

  width: 120px;

  height: auto;

}



.product-coating-info-logo span {

  font-family: var(--font-body);

  font-size: 1rem;

  font-weight: 600;

  color: #0d6abf;

  /* thyssenkrupp blue */

}



.product-coating-info-title {

  font-family: var(--font-display);

  font-size: 1.25rem;

  font-weight: 700;

  color: #0d6abf;

  margin-bottom: 1.25rem;

  line-height: 1.3;

}



.product-coating-layers {

  list-style: none;

  padding: 0;

  margin: 0;

}



ol.product-coating-layers {

  counter-reset: layer-counter;

}



ol.product-coating-layers li {

  counter-increment: layer-counter;

  padding-left: 2.5rem;

  position: relative;

}



ol.product-coating-layers li::before {

  content: counter(layer-counter);

  position: absolute;

  left: 0;

  top: 0.875rem;

  width: 1.75rem;

  height: 1.75rem;

  display: flex;

  align-items: center;

  justify-content: center;

  background: var(--color-gray-100);

  border-radius: 50%;

  font-family: var(--font-display);

  font-size: 0.8125rem;

  font-weight: 700;

  color: var(--color-black);

}



.product-coating-layers li {

  font-size: 0.9375rem;

  font-weight: 500;

  color: var(--color-gray-700);

  padding: 0.875rem 0;

  border-bottom: 1px solid var(--color-gray-200);

  line-height: 1.4;

}



.product-coating-layers li:first-child {

  border-top: 2px solid var(--color-gray-200);

}



/* ─────────────────────────────────────────────

   WARRANTY SECTION

   ───────────────────────────────────────────── */

.product-warranty-grid {

  display: grid;

  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));

  gap: 1.25rem;

}



.product-warranty-card {

  padding: 2rem 1.5rem;

  background: #fff;

  border: 1px solid var(--color-gray-100);

  border-radius: 2px;

  text-align: center;

  transition: box-shadow 0.3s, transform 0.3s;

}



.product-warranty-card:hover {

  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);

  transform: translateY(-2px);

}



.product-warranty-years {

  font-family: var(--font-display);

  font-size: 3.25rem;

  font-weight: 800;

  color: var(--color-black);

  line-height: 1;

}



.product-warranty-years small {

  display: block;

  font-size: 0.75rem;

  font-weight: 700;

  text-transform: uppercase;

  letter-spacing: 0.1em;

  margin-top: 0.25rem;

  color: var(--color-gray-500);

}



.product-warranty-label {

  font-size: 0.875rem;

  font-weight: 600;

  margin-top: 1rem;

  color: var(--color-black);

  line-height: 1.4;

}



.product-warranty-desc {

  font-size: 0.8125rem;

  line-height: 1.5;

  color: var(--color-gray-500);

  margin-top: 0.5rem;

}



/* ─────────────────────────────────────────────

   PHOTO GALLERY

   ───────────────────────────────────────────── */

.product-gallery-grid {

  display: grid;

  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));

  gap: 0.625rem;

}



.product-gallery-thumb {

  position: relative;

  overflow: hidden;

  border-radius: 2px;

  cursor: pointer;

  aspect-ratio: 4/3;

}



.product-gallery-thumb::after {

  content: '';

  position: absolute;

  inset: 0;

  background: rgba(0, 0, 0, 0);

  transition: background 0.3s;

}



.product-gallery-thumb:hover::after {

  background: rgba(0, 0, 0, 0.18);

}



.product-gallery-thumb img {

  width: 100%;

  height: 100%;

  object-fit: cover;

  transition: transform 0.45s cubic-bezier(0.25, 0.46, 0.45, 0.94);

}



.product-gallery-thumb:hover img {

  transform: scale(1.06);

}



/* ─────────────────────────────────────────────

   LIGHTBOX

   ───────────────────────────────────────────── */

.product-lightbox {

  display: none;

  position: fixed;

  inset: 0;

  z-index: 9999;

  background: rgba(0, 0, 0, 0.94);

  align-items: center;

  justify-content: center;

}



.product-lightbox.active {

  display: flex;

}



.product-lightbox img {

  max-width: 90vw;

  max-height: 85vh;

  object-fit: contain;

  border-radius: 2px;

}



.product-lightbox-close {

  position: absolute;

  top: 1.5rem;

  right: 1.5rem;

  background: rgba(255, 255, 255, 0.1);

  border: none;

  color: #fff;

  font-size: 1.5rem;

  cursor: pointer;

  width: 44px;

  height: 44px;

  border-radius: 50%;

  display: flex;

  align-items: center;

  justify-content: center;

  transition: background 0.2s;

}



.product-lightbox-close:hover {

  background: rgba(255, 255, 255, 0.2);

}



.product-lightbox-prev,

.product-lightbox-next {

  position: absolute;

  top: 50%;

  transform: translateY(-50%);

  background: rgba(255, 255, 255, 0.1);

  border: none;

  color: #fff;

  font-size: 1.5rem;

  cursor: pointer;

  padding: 0;

  width: 52px;

  height: 52px;

  border-radius: 50%;

  display: flex;

  align-items: center;

  justify-content: center;

  opacity: 0.8;

  transition: opacity 0.2s, background 0.2s;

}



.product-lightbox-prev:hover,

.product-lightbox-next:hover {

  opacity: 1;

  background: rgba(255, 255, 255, 0.2);

}



.product-lightbox-prev {

  left: 1.5rem;

}



.product-lightbox-next {

  right: 1.5rem;

}



/* ─────────────────────────────────────────────

   CTA / CONTACT SECTION

   ───────────────────────────────────────────── */

.product-cta {

  padding: var(--space-xl) 0;

  background: var(--color-black);

  color: #fff;

  text-align: center;

}



.product-cta-inner {

  max-width: 700px;

  margin: 0 auto;

  padding: 0 var(--space-md);

}



.product-cta h2 {

  font-family: var(--font-display);

  font-size: clamp(1.5rem, 3vw, 2.5rem);

  font-weight: 700;

  text-transform: uppercase;

  letter-spacing: 0.03em;

  margin-bottom: 1rem;

}



.product-cta p {

  font-size: 1.0625rem;

  line-height: 1.7;

  color: rgba(255, 255, 255, 0.7);

  margin-bottom: 2rem;

}



.product-cta-actions {

  display: flex;

  gap: 1rem;

  justify-content: center;

  flex-wrap: wrap;

}



/* ─────────────────────────────────────────────

   ADVANTAGES

   ───────────────────────────────────────────── */

.product-advantages-grid {

  display: grid;

  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));

  gap: 1.25rem;

}



.product-advantage-card {

  padding: 1.75rem;

  background: #fff;

  border: 1px solid var(--color-gray-100);

  border-radius: 2px;

  transition: box-shadow 0.3s;

}



.product-advantage-card:hover {

  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);

}



.product-advantage-card h4 {

  font-family: var(--font-display);

  font-size: 0.9375rem;

  font-weight: 700;

  text-transform: uppercase;

  letter-spacing: 0.05em;

  margin-bottom: 0.5rem;

  color: var(--color-black);

}



.product-advantage-card p {
  font-size: 0.9375rem;
  line-height: 1.65;
  color: var(--color-gray-700);
}

.product-advantage-icon {
  width: min(100%, 110px);
  height: auto;
  margin: 0 auto 1rem;
  display: block;
}

.product-rich-content {
  display: grid;
  gap: 1.5rem;
}

.product-rich-content h3 {
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 2vw, 1.65rem);
  line-height: 1.2;
  color: var(--color-black);
  margin: 0 0 0.75rem;
}

.product-rich-content p,
.product-rich-content li,
.product-rich-content td,
.product-rich-content th {
  font-size: 1rem;
  line-height: 1.75;
  color: var(--color-gray-600);
}

.product-rich-content p:last-child {
  margin-bottom: 0;
}

.product-rich-content ul,
.product-rich-content ol {
  display: grid;
  gap: 0.65rem;
  padding-left: 1.2rem;
}

.product-rich-content img {
  display: block;
  max-width: 100%;
  height: auto;
  margin: 0 auto;
  border-radius: var(--radius-md);
}

.product-krop-info-block {
  display: grid;
  gap: 1.25rem;
}

.product-krop-info-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1.25rem;
  align-items: start;
}

.product-krop-info-text,
.product-krop-info-text p,
.product-krop-info-text div {
  font-size: 1rem;
  line-height: 1.75;
  color: var(--color-gray-600);
}

.product-krop-info-text p:last-child,
.product-krop-info-text div:last-child {
  margin-bottom: 0;
}

.product-krop-info-logo {
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
}

.product-krop-info-logo img {
  width: min(100%, 220px);
  max-width: 220px;
  margin: 0;
  border-radius: 0;
}

.product-krop-info-gallery {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.product-krop-info-image {
  margin: 0;
}

.product-krop-info-image img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  margin: 0;
}

.product-rich-content a {
  color: var(--color-accent);
}

.product-rich-content center {
  display: block;
}

.product-rich-content table {
  width: 100%;
  border-collapse: collapse;
  overflow: hidden;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-gray-200);
  background: var(--color-white);
}

.product-rich-content th,
.product-rich-content td {
  padding: 0.85rem 1rem;
  text-align: left;
  border-bottom: 1px solid var(--color-gray-200);
}

.product-rich-content tr:last-child td,
.product-rich-content tr:last-child th {
  border-bottom: 0;
}

.product-rich-content th {
  font-weight: 700;
  color: var(--color-gray-900);
  background: var(--color-gray-100);
}


/* ─────────────────────────────────────────────

   RESPONSIVE

   ───────────────────────────────────────────── */

@media (max-width: 1024px) {

  \n .product-materials-body {

    grid-template-columns: 1fr;

  }



  \n .product-coating-layout {

    grid-template-columns: 1fr;

  }



  .product-materials-header {

    grid-template-columns: 180px 1fr;

  }



  .product-coating-layout {

    grid-template-columns: 1fr 1fr;

  }



  .product-colour-grid {

    grid-template-columns: 1fr 1.3fr;

  }



  .product-colour-grid--tofino {

    grid-template-columns: 1fr;

  }



  .product-colour-grid--tofino-split {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .product-colour-grid--traditional-soffit {
    grid-template-columns: 1fr;
    gap: 1rem;
  }


  .product-colour-grid--gutter .product-colour-image--gutter {
    transform: translateY(-4.6rem);
  }

  .product-rich-content table {
    display: block;
    overflow-x: auto;
    white-space: nowrap;
  }
}


@media (max-width: 768px) {

  .product-title-with-logo {

    flex-direction: column;

    align-items: flex-start;

  }



  .product-title-logo {

    width: clamp(120px, 42vw, 200px);

  }



  .product-colour-grid--gutter .product-colour-image--gutter {

    transform: translateY(-2rem);

  }



  .product-hero {

    min-height: 40vh;

  }



  .product-hero h1 {

    font-size: 2rem;

  }



  .product-nav a {

    padding: 0.875rem 1rem;

    font-size: 0.75rem;

  }



  .product-section,

  .product-section-alt,

  .product-section--materials {

    padding: var(--space-lg) 0;

  }



  .product-info-images {

    grid-template-columns: 1fr 1fr;

  }



  .product-info-images img {

    height: 200px;

  }



  .product-materials-header {

    grid-template-columns: 1fr;

    gap: 1rem;

  }



  .product-materials-logo-card {

    max-width: 200px;

  }



  .product-coating-layout {

    grid-template-columns: 1fr;

  }



  .product-colour-grid {

    grid-template-columns: 1fr;

  }



  .product-gallery-grid {

    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));

  }



  .product-warranty-grid,

  .product-advantages-grid {

    grid-template-columns: 1fr 1fr;

  }



  .product-3d-viewer {

    padding-bottom: 62%;

  }

}



@media (max-width: 480px) {

  .product-info-images {

    grid-template-columns: 1fr;

  }



  .product-info-images img {

    height: 220px;

  }



  .product-gallery-grid {

    grid-template-columns: 1fr 1fr;

    gap: 0.4rem;

  }



  .product-warranty-grid,

  .product-advantages-grid {

    grid-template-columns: 1fr;

  }



  .product-cta-actions {

    flex-direction: column;

  }



  .product-specs-grid {

    grid-template-columns: 1fr 1fr;

  }

}



/* Preserve original image aspect ratio for pages that opt in. */

.product-info-images--natural img {

  height: auto;

  object-fit: contain;

}



.product-tabs-section {

  padding: var(--space-lg) 0 var(--space-xl);

  background: linear-gradient(180deg, #f3f4f6 0%, #ffffff 100%);

}



.product-tabs-card {

  background: #fff;

  border: 1px solid var(--color-gray-200);

  border-radius: 16px;

  box-shadow: 0 16px 40px rgba(15, 23, 42, 0.08);

  max-width: 1080px;

  margin: 0 auto;

  padding: 0.85rem;

}



.product-tabs-nav {

  display: grid;

  grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));

  gap: 0.75rem;

  margin-bottom: 1rem;

}



.product-tab-btn {

  border: 1px solid var(--color-gray-200);

  background: #fff;

  color: var(--color-gray-600);

  border-radius: 8px;

  padding: 0.8rem 0.95rem;

  font-family: var(--font-body);

  font-size: 0.85rem;

  font-weight: 700;

  text-transform: uppercase;

  letter-spacing: 0.06em;

  text-align: center;

  cursor: pointer;

  transition: all 0.2s ease;

}



.product-tab-btn:hover {

  border-color: var(--color-gray-400);

  color: var(--color-black);

  background: #fff;

}



.product-tab-btn.is-active,
.product-tab-btn.is-active:hover,
.product-tab-btn.is-active:focus-visible,
.product-tab-btn.is-active:active {

  background: var(--color-black);

  color: #fff;

  border-color: var(--color-black);

  box-shadow: none;

}



.product-tab-panel {

  border: 1px solid var(--color-gray-100);

  background: #fff;

  border-radius: 14px;

  padding: clamp(0.85rem, 1.7vw, 1.35rem);

}



.product-tab-panel.is-active {

  animation: tabFadeIn 380ms cubic-bezier(0.16, 1, 0.3, 1) both;

}



@keyframes tabFadeIn {

  from {

    opacity: 0;

    transform: translateY(12px);

  }

  to {

    opacity: 1;

    transform: translateY(0);

  }

}



@media (prefers-reduced-motion: reduce) {

  .product-tab-panel.is-active {

    animation: none;

  }

}



.product-tabs-panels {

  overflow: hidden;

  overflow-anchor: none;

}



.product-tab-panel[hidden] {

  display: none;

}



.product-tab-subsection {

  margin-top: var(--space-lg);

}



.product-tab-panel#tab-info .product-info-text {

  margin-bottom: 1rem;

}



.product-tab-materials-block {

  background: #4D5056;

  border-radius: 12px;

  padding: clamp(1rem, 2vw, 1.5rem);

  margin-top: 0.4rem;

}



.product-tab-materials-block .product-materials-body {

  margin-top: 0;

  grid-template-columns: minmax(520px, 1.15fr) minmax(340px, 0.95fr);

  grid-template-areas:

    "headline list"

    "media list";

  gap: 0.85rem 1.5rem;

  align-items: start;

}



.product-tab-materials-block .product-materials-headline {

  grid-area: headline;

  padding-top: 0;

}



.product-tab-materials-block .product-materials-headline h3 {

  font-size: clamp(1.35rem, 2.1vw, 1.9rem);

}



.product-tab-materials-block .product-materials-left {

  grid-area: media;

  min-height: 0;

  display: flex;

  flex-direction: row;

  align-items: flex-start;

  gap: 0.9rem;

}



.product-tab-materials-block .product-materials-logo-card {

  width: 170px;

  height: 170px;

  padding: 1.1rem;

  box-shadow: none;

}



.product-tab-materials-block .product-materials-photo {

  position: relative;

  top: auto;

  left: auto;

  width: 300px;

}



.product-tab-materials-block .product-materials-photo img {

  box-shadow: none;

}



.product-tab-materials-block .product-materials-list {

  grid-area: list;

  padding-top: 0.15rem;

  padding-right: 1rem;

  justify-self: end;

  width: 100%;

  max-width: 440px;

}



.product-tab-materials-block .product-materials-body.product-materials-body--simplified {
  grid-template-columns: minmax(420px, 1fr) minmax(320px, 1fr);
  gap: 1.25rem;
}


.product-materials-left-title {

  font-family: var(--font-display);

  font-size: clamp(1.35rem, 2.2vw, 1.9rem);

  font-weight: 700;

  line-height: 1.25;

  color: #fff;

  margin: 0;

}



.materials-line-nowrap {

  white-space: nowrap;

}



.product-materials-body--simplified .product-materials-list {

  padding-left: 1.25rem;

  padding-right: 0.7rem;

}



.product-tab-subtitle {

  font-family: var(--font-display);

  font-size: clamp(1.2rem, 2vw, 1.5rem);

  letter-spacing: 0.03em;

  margin-bottom: 1rem;

  text-transform: uppercase;

}



.product-specs-board {

  display: flex;

  flex-direction: column;

  width: min(100%, 370px);

  border: 1px solid #dbe2ea;

  border-radius: 10px;

  overflow: hidden;

  background: #fff;

}



.product-spec-row {

  display: grid;

  grid-template-columns: minmax(0, 1fr) auto;

  align-items: center;

  column-gap: 0.28rem;

  width: 100%;

  padding: 0.62rem 0.78rem;

  background: #fff;

  border-bottom: 1px solid #e5eaf0;

}



.product-spec-row:last-child {

  border-bottom: none;

}



.product-spec-key {

  font-family: var(--font-body);

  font-size: 0.8rem;

  font-weight: 700;

  text-transform: uppercase;

  letter-spacing: 0.04em;

  color: var(--color-gray-500);

}



.product-spec-data {

  font-family: var(--font-display);

  font-size: 1.1rem;

  font-weight: 700;

  color: var(--color-black);

  text-align: right;

  white-space: nowrap;

}



.product-specs-layout {

  display: grid;

  grid-template-columns: minmax(320px, 1fr) minmax(280px, 0.95fr);

  gap: 1rem;

  align-items: start;

}



.product-specs-layout .product-specs-board {

  width: 100%;

  align-self: start;

}



.product-specs-figure {

  align-self: start;

}



.product-specs-figure .product-specs-diagram {

  margin-top: 0;

  max-width: none;

}



.product-specs-figure img {

  width: 100%;

  height: auto;

  display: block;

  border-radius: 8px;

  cursor: pointer;

}



.product-specs-zoom-image {

  position: fixed;

  z-index: 12000;

  object-fit: fill;

  cursor: pointer;

  border-radius: 12px;

  box-shadow: 0 30px 70px rgba(2, 6, 23, 0.52);

  user-select: none;

  -webkit-user-drag: none;

}



.product-specs-layout--tofino {

  grid-template-columns: minmax(280px, 0.72fr) minmax(460px, 1.28fr);

  gap: 0.75rem;

}



.product-specs-layout--tofino .product-specs-board {

  max-width: 340px;

}





.product-specs-layout--gutter .product-specs-figure {
  margin-top: -4.2rem;
}

.product-specs-layout--gutter .product-specs-diagram {
  margin-top: -4.2rem;
}

/* ── Interaction Polish ──────────────────────────────────── */
.product-nav {
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.product-nav-inner {
  scroll-snap-type: x proximity;
}

.product-nav a {
  scroll-snap-align: start;
  border-radius: 8px 8px 0 0;
  transition:
    color 0.18s ease,
    border-color 0.18s ease,
    background-color 0.18s ease,
    transform 0.18s ease,
    box-shadow 0.18s ease;
}

.product-nav a:hover,
.product-nav a:focus-visible,
.product-nav a.active {
  color: var(--color-black);
  background: rgba(15, 23, 42, 0.03);
}

.product-nav a:focus-visible {
  outline: none;
  box-shadow: inset 0 0 0 1px rgba(26, 26, 26, 0.08);
}

.product-nav a:active {
  transform: translateY(1px);
}

.product-specs-diagram img,
.product-info-images img,
.product-coating-diagram img,
.product-krop-info-image img {
  transition: transform 0.32s ease, box-shadow 0.32s ease, filter 0.32s ease;
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.08);
}

.product-colour-image img,
.product-coating-visual img {
  transition: transform 0.32s ease, box-shadow 0.32s ease, filter 0.32s ease;
}

.product-specs-diagram img:hover,
.product-specs-diagram img:focus-visible,
.product-colour-image img:hover,
.product-colour-image img:focus-visible,
.product-info-images img:hover,
.product-info-images img:focus-visible,
.product-coating-diagram img:hover,
.product-coating-diagram img:focus-visible,
.product-coating-visual img:hover,
.product-coating-visual img:focus-visible,
.product-krop-info-image img:hover,
.product-krop-info-image img:focus-visible {
  transform: translateY(-2px);
  filter: saturate(1.02);
  outline: none;
}

.product-specs-diagram img:hover,
.product-specs-diagram img:focus-visible,
.product-info-images img:hover,
.product-info-images img:focus-visible,
.product-coating-diagram img:hover,
.product-coating-diagram img:focus-visible,
.product-krop-info-image img:hover,
.product-krop-info-image img:focus-visible {
  box-shadow: 0 18px 36px rgba(15, 23, 42, 0.14);
}

.product-gallery-thumb {
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
  transition: transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease;
}

.product-gallery-thumb::after {
  background: linear-gradient(180deg, rgba(15, 23, 42, 0) 35%, rgba(15, 23, 42, 0.16) 100%);
  opacity: 0;
  transition: opacity 0.28s ease;
}

.product-gallery-thumb:hover,
.product-gallery-thumb:focus-within {
  transform: translateY(-3px);
  border-color: rgba(15, 23, 42, 0.16);
  box-shadow: 0 18px 36px rgba(15, 23, 42, 0.14);
}

.product-gallery-thumb:hover::after,
.product-gallery-thumb:focus-within::after {
  opacity: 1;
}

.product-gallery-thumb:hover img,
.product-gallery-thumb:focus-within img {
  transform: scale(1.06);
}

.product-gallery-thumb img:focus-visible {
  outline: none;
}

.product-tabs-card {
  box-shadow: 0 20px 48px rgba(15, 23, 42, 0.1);
}

.product-tab-btn {
  min-height: 3.2rem;
  transition:
    border-color 0.18s ease,
    background-color 0.18s ease,
    color 0.18s ease,
    transform 0.18s ease,
    box-shadow 0.18s ease;
}

.product-tab-btn:hover,
.product-tab-btn:focus-visible {
  border-color: var(--color-gray-400);
  color: var(--color-black);
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
}

.product-tab-btn:focus-visible {
  outline: none;
}

.product-tab-btn:active {
  transform: translateY(0) scale(0.99);
  box-shadow: 0 6px 14px rgba(15, 23, 42, 0.06);
}

.product-tab-btn.is-active,
.product-tab-btn.is-active:hover,
.product-tab-btn.is-active:focus-visible,
.product-tab-btn.is-active:active {
  background: #111827;
  border-color: #111827;
  box-shadow: 0 14px 28px rgba(17, 24, 39, 0.14);
}

.product-warranty-card,
.product-advantage-card {
  transition: transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease;
}

.product-warranty-card:hover,
.product-advantage-card:hover {
  transform: translateY(-4px);
}

.product-rich-content a {
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.16em;
}

.product-rich-content a:hover {
  color: var(--color-black);
}

.product-krop-info-image img {
  border-radius: 10px;
}

@media (max-width: 768px) {
  .product-nav-inner {
    padding: 0 0.75rem;
  }

  .product-tab-btn {
    min-height: 3rem;
    padding: 0.72rem 0.7rem;
    font-size: 0.76rem;
  }
}

@media (max-width: 480px) {
  .product-tabs-card {
    padding: 0.6rem;
  }

  .product-tabs-nav {
    gap: 0.55rem;
  }

  .product-tab-btn {
    min-height: 2.85rem;
    padding: 0.7rem 0.6rem;
    font-size: 0.72rem;
    letter-spacing: 0.04em;
  }
}


.product-specs-layout--gutter .product-specs-board {

  max-width: 640px;

}



.product-specs-layout--gutter .product-spec-row {

  grid-template-columns: minmax(72px, 0.65fr) minmax(120px, 0.8fr) minmax(220px, 1.55fr);

  align-items: center;

  column-gap: 0.5rem;

}



.product-specs-layout--gutter .product-spec-row--header {

  background: #f8fafc;

}



.product-specs-layout--gutter .product-spec-row--header .product-spec-key {

  font-size: 0.74rem;

  letter-spacing: 0.08em;

  color: var(--color-gray-600);

}



.product-spec-system {

  font-family: var(--font-display);

  font-size: 1.02rem;

  font-weight: 700;

  color: var(--color-black);

  text-align: left;

}



.product-specs-layout--gutter .product-spec-row .product-spec-key {

  text-align: left;

}



.product-specs-layout--gutter .product-spec-row .product-spec-data {

  text-align: left;

  white-space: nowrap;

}



.product-spec-data-secondary {

  font-family: var(--font-body);

  font-size: 0.92rem;

  font-weight: 600;

  color: var(--color-gray-700);

  text-align: left;

  white-space: nowrap;

}



.product-specs-board--vancouver {

  width: 100%;

  max-width: 980px;

}



.product-specs-board--vancouver .product-spec-row--vancouver {

  grid-template-columns: minmax(160px, 0.95fr) minmax(220px, 1fr) minmax(220px, 1fr);

  align-items: center;

  column-gap: 0.8rem;

}



.product-specs-board--vancouver .product-spec-row--vancouver .product-spec-data {

  text-align: left;

}



.product-specs-extra-image {

  margin-top: 0.9rem;

}



.product-specs-extra-image img {

  width: min(100%, 760px);

  display: block;

  height: auto;

  border-radius: 8px;

}



.product-coating-summary {

  display: grid;

  grid-template-columns: 1fr 1.15fr;

  gap: 1.25rem;

  align-items: start;

  background: #fff;

}



.product-coating-copy .product-tab-subtitle {

  margin-top: 0;

}



.product-coating-diagram--large img {

  width: 100%;

  max-width: 100%;

  margin: 0;

  display: block;

  border-radius: 6px;

  box-shadow: none;

}



@media (max-width: 1024px) {

  .product-tabs-nav {

    grid-template-columns: repeat(3, minmax(0, 1fr));

  }



  .product-specs-layout {

    grid-template-columns: 1fr;

  }



  .product-tab-materials-block .product-materials-body {

    grid-template-columns: 1fr;

    grid-template-areas:

      "headline"

      "media"

      "list";

    gap: 1rem;

  }



  .product-tab-materials-block .product-materials-list {

    padding-right: 0;

  }



  .product-tab-materials-block .product-materials-body.product-materials-body--simplified {

    grid-template-columns: 1fr;

  }



  .product-materials-body--simplified .product-materials-list {

    padding-left: 0;

  }

}



@media (max-width: 768px) {

  .product-tabs-card {

    border-radius: 12px;

    padding: 0.75rem;

  }



  .product-tabs-nav {

    display: grid;

    grid-template-columns: repeat(3, minmax(0, 1fr));

    overflow: visible;

    gap: 0.5rem;

  }



  .product-tabs-nav::-webkit-scrollbar {

    display: none;

  }



  .product-tab-btn {
    width: 100%;
    white-space: normal;
    font-size: 0.78rem;
    padding: 0.65rem 0.55rem;
    line-height: 1.25;
  }

  .product-krop-info-head {
    grid-template-columns: minmax(0, 1fr) 110px;
    gap: 0.85rem;
  }

  .product-krop-info-logo img {
    width: 100%;
    max-width: none;
  }

  .product-tab-panel {
    border-radius: 10px;
    padding: 0.9rem;
  }



  .product-spec-row {

    width: 100%;

    grid-template-columns: minmax(0, 1fr) auto;

    column-gap: 0.5rem;

    row-gap: 0;

    align-items: center;

  }



  .product-spec-key,

  .product-spec-data {

    text-align: left;

  }



  .product-spec-data {

    text-align: right;

    white-space: nowrap;

  }



  .product-specs-layout {

    grid-template-columns: 1fr;

    gap: 0.85rem;

  }



  .product-specs-board {

    margin-left: auto;

    margin-right: auto;

  }



  .product-specs-layout--gutter .product-specs-figure {

    margin-top: -1.5rem;

  }



  .product-specs-layout--gutter .product-specs-diagram {

    margin-top: -1.5rem;

  }



  .product-specs-layout--gutter .product-spec-row {

    grid-template-columns: 1fr 1fr 1fr;

  }



  .product-spec-data-secondary {

    text-align: left;

    white-space: normal;

  }



  .product-coating-summary {

    grid-template-columns: 1fr;

    gap: 0.9rem;

  }



  .product-coating-copy .product-tab-subtitle {

    font-size: 1.05rem;

    margin-bottom: 0.7rem;

  }



  .product-coating-text p {

    font-size: 0.9rem;

    line-height: 1.55;

  }



  .product-specs-board--vancouver {

    width: 100%;

    max-width: 100%;

  }



  .product-specs-board--vancouver .product-spec-row--vancouver {

    grid-template-columns: minmax(92px, 1fr) minmax(0, 1fr) minmax(0, 1fr);

    column-gap: 0.4rem;

    align-items: start;

  }



  .product-specs-board--vancouver .product-spec-row--vancouver .product-spec-key,

  .product-specs-board--vancouver .product-spec-row--vancouver .product-spec-data {

    font-size: 0.74rem;

    line-height: 1.25;

    white-space: normal;

    word-break: normal;

    overflow-wrap: anywhere;

  }



  .product-specs-board--vancouver .product-spec-row--vancouver .product-spec-key:first-child,

  .product-specs-board--vancouver .product-spec-row--vancouver .product-spec-data:first-child {

    text-align: left;

  }



  .product-specs-board--vancouver .product-spec-row--vancouver .product-spec-key:nth-child(2),

  .product-specs-board--vancouver .product-spec-row--vancouver .product-spec-key:nth-child(3),

  .product-specs-board--vancouver .product-spec-row--vancouver .product-spec-data:nth-child(2),

  .product-specs-board--vancouver .product-spec-row--vancouver .product-spec-data:nth-child(3) {

    text-align: center;

  }



  .product-tab-materials-block {

    overflow: hidden;

    margin-left: -0.9rem;

    margin-right: -0.9rem;

    border-radius: 10px;

  }



  .product-tab-materials-block .product-materials-left {

    flex-wrap: wrap;

    gap: 0.6rem;

  }



  .product-tab-materials-block .product-materials-logo-card {

    width: 112px;

    height: 112px;

    flex: 0 0 112px;

    padding: 0.75rem;

  }



  .product-tab-materials-block .product-materials-photo {

    width: min(100%, 190px);

  }



  .product-tab-materials-block .product-materials-headline h3,

  .product-materials-left-title {

    font-size: 1.1rem;

    line-height: 1.3;

  }



  .product-tab-materials-block .product-materials-list {

    gap: 1rem;

  }



  .product-tab-materials-block .product-materials-list li {

    font-size: 0.82rem;

    line-height: 1.45;

  }



  .product-tab-materials-block .product-materials-list li strong {

    font-size: 0.9rem;

    margin-bottom: 0.25rem;

  }



  .product-warranty-grid {

    grid-template-columns: 1fr;

    gap: 0.65rem;

  }



  .product-warranty-card {

    display: grid;

    grid-template-columns: auto minmax(0, 1fr);

    align-items: center;

    column-gap: 0.8rem;

    row-gap: 0.2rem;

    text-align: left;

    padding: 0.9rem 0.85rem;

  }



  .product-warranty-years {

    grid-column: 1;

    grid-row: 1 / span 2;

    min-width: 74px;

    font-size: 2rem;

    text-align: center;

  }



  .product-warranty-years small {

    font-size: 0.62rem;

    margin-top: 0.1rem;

  }



  .product-warranty-label {

    grid-column: 2;

    grid-row: 1;

    margin-top: 0;

    font-size: 0.82rem;

  }



  .product-warranty-desc {

    grid-column: 2;

    grid-row: 2;

    margin-top: 0;

    font-size: 0.74rem;

  }

}







/* Banff info tab media row: stacked images left, 3D model right */

.product-info-media {

  display: grid;

  grid-template-columns: minmax(240px, 0.92fr) minmax(320px, 1.2fr);

  gap: 0.85rem;

  align-items: stretch;

  margin-bottom: 1rem;

}



.product-info-images-vertical {

  display: grid;

  grid-template-rows: 1fr 1fr;

  gap: 0.75rem;

}



.product-info-images-vertical img {

  width: 100%;

  height: 100%;

  min-height: 145px;

  object-fit: cover;

  border-radius: 8px;

  display: block;

}



.product-info-media .product-3d-viewer {

  max-width: none;

  margin: 0;

  padding-bottom: 0;

  height: 100%;

  min-height: 300px;

}



.product-info-media .product-3d-viewer iframe {

  position: absolute;

}



@media (max-width: 1024px) {

  .product-info-media {

    grid-template-columns: 1fr;

  }



  .product-info-media .product-3d-viewer {

    order: -1;

    min-height: 280px;

  }

}



@media (max-width: 480px) {
  .product-info-images-vertical img {
    min-height: 130px;
  }

  .product-krop-info-head {
    grid-template-columns: minmax(0, 1fr) 88px;
    gap: 0.7rem;
  }

  .product-info-media .product-3d-viewer {
    min-height: 230px;
  }


  .product-tab-materials-block .product-materials-logo-card {

    width: 104px;

    height: 104px;

    flex-basis: 104px;

  }



  .product-tab-materials-block .product-materials-photo {

    width: min(100%, 170px);

  }

}







.product-materials-body--simplified .product-materials-photo img {

  width: min(100%, 420px);

  max-width: 420px;

}



.product-colour-image--banff {

  display: flex;

  justify-content: flex-start;

  align-items: flex-start;

  align-self: flex-start;

  padding-top: 0.2rem;

}



.product-colour-image--banff img {

  width: min(100%, 352px);

  max-width: 352px;

}



/* Force colour image column to align at the top */

.product-colour-grid {

  align-items: start;

}



.product-colour-image {

  align-self: start;

}



/* Gutter cross section below colour panel */

.product-colour-cross-section {

  margin-top: var(--space-md);

  border-top: 1px solid var(--color-gray-100);

  padding-top: var(--space-md);

}



.product-colour-cross-section h3 {

  font-family: var(--font-display);

  font-size: clamp(1.1rem, 1.8vw, 1.4rem);

  font-weight: 700;

  text-transform: uppercase;

  letter-spacing: 0.04em;

  color: var(--color-black);

  margin-bottom: 0.75rem;

}



.product-colour-cross-section p {

  font-size: 0.9375rem;

  line-height: 1.7;

  color: var(--color-gray-700);

  margin-bottom: 0.85rem;

}



.product-colour-cross-section img {

  display: block;

  max-width: 520px;

  width: 100%;

  height: auto;

  border-radius: 8px;

  margin-top: 0.5rem;

}





/* ── Compact Product Hero Overrides ────────────────────────────── */

.service-pan-wrapper {

  padding-top: calc(var(--header-height, 110px) + 2rem);

  padding-bottom: 0.5rem;

}



.pan-header {

  margin-bottom: 1.5rem;

}



.product-breadcrumb {

  margin-bottom: 0.75rem !important;

  padding-top: 0;

  padding-bottom: 0;

}



.service-eyebrow {

  margin-bottom: 0.75rem;

}



.service-headline {

  margin-bottom: 0.5rem;

}



@media (max-width: 768px) {
  .service-pan-wrapper {
    padding-top: calc(var(--header-height, 80px) + 1rem);
  }

  .product-breadcrumb {
    flex-wrap: wrap;
    row-gap: 0.35rem;
    column-gap: 0.35rem;
  }

  .product-breadcrumb span {
    margin: 0;
  }

  .service-headline {
    white-space: normal;
    text-wrap: balance;
    font-size: clamp(1.35rem, 7.2vw, 2.35rem);
  }

  .product-tabs-nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .product-tab-btn {
    min-height: 3rem;
  }

  .product-krop-info-gallery {
    gap: 0.75rem;
  }
}
