/* =====================================================
   IMAGINE YOUR KITCHEN — section + gallery + modal
   Cyan accent, Inter, modern photoreal direction
   ===================================================== */

/* Section foundation */
.imagine {
  padding: 96px 24px;
  background: var(--cream-alt, #f5f1ec);
}
@media (max-width: 720px) { .imagine { padding: 64px 20px; } }

.imagine .container, .imagine__container {
  max-width: 1140px; margin: 0 auto;
}

.imagine__header { text-align: center; margin-bottom: 40px; }
.imagine__eyebrow {
  font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--cyan, #5BC5D4); font-weight: 700; margin-bottom: 10px;
}
.imagine__title {
  font-family: 'Inter', sans-serif;
  font-size: clamp(28px, 4vw, 40px); font-weight: 800;
  color: var(--navy, #0B1D2E); margin: 0 0 12px 0;
  letter-spacing: -0.01em; line-height: 1.1;
}
.imagine__subtitle {
  font-size: 16px; line-height: 1.55; color: var(--stone-500, #6B6560);
  max-width: 600px; margin: 0 auto;
}

/* Filter chips */
.imagine__filters {
  display: flex; gap: 8px; justify-content: center;
  margin: 0 auto 32px; flex-wrap: wrap;
}
.filter-chip {
  padding: 8px 18px; background: var(--white, #fff);
  border: 1px solid var(--stone-200, #d4cfca); border-radius: 999px;
  font-family: 'Inter', sans-serif; font-size: 13px;
  color: var(--stone-500, #6B6560); cursor: pointer;
  transition: all 0.2s ease;
}
.filter-chip:hover { border-color: var(--cyan, #5BC5D4); color: var(--navy, #0B1D2E); }
.filter-chip--active {
  background: var(--navy, #0B1D2E); border-color: var(--navy, #0B1D2E); color: var(--cyan, #5BC5D4);
}

/* Grid */
.imagine__grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
}
@media (max-width: 900px) { .imagine__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .imagine__grid { grid-template-columns: 1fr; } }

/* Kitchen card */
.kitchen-card {
  background: var(--white, #fff); border-radius: 6px; overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
  position: relative; transition: transform 0.25s ease, box-shadow 0.25s ease;
  cursor: pointer;
}
.kitchen-card:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0, 0, 0, 0.08); }
.kitchen-card__img {
  aspect-ratio: 4 / 3; background: var(--stone-200, #d4cfca);
  position: relative; overflow: hidden;
}
.kitchen-card__img img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.kitchen-card__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 55%, rgba(11, 29, 46, 0.85));
  display: flex; align-items: flex-end; justify-content: center;
  padding: 16px;
  opacity: 0; transition: opacity 0.25s ease;
}
.kitchen-card:hover .kitchen-card__overlay,
.kitchen-card:focus-within .kitchen-card__overlay { opacity: 1; }
@media (hover: none) {
  .kitchen-card__overlay { opacity: 1; background: linear-gradient(180deg, transparent 70%, rgba(11, 29, 46, 0.6)); }
}
.kitchen-card__remix {
  background: var(--cyan, #5BC5D4); color: var(--navy, #0B1D2E);
  border: none; padding: 10px 18px;
  font-family: 'Inter', sans-serif; font-size: 12px; font-weight: 700;
  letter-spacing: 0.04em; border-radius: 3px; cursor: pointer;
}
.kitchen-card__remix:hover { background: var(--cyan-strong, #4ab1c0); }
.kitchen-card__body { padding: 14px 16px; }
.kitchen-card__style {
  font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--cyan, #5BC5D4); font-weight: 700;
}
.kitchen-card__name {
  font-family: 'Inter', sans-serif; font-size: 15px; font-weight: 600;
  color: var(--navy, #0B1D2E); margin-top: 4px;
}
.kitchen-card.is-remixed .kitchen-card__overlay { background: rgba(11, 29, 46, 0.7); opacity: 1; }
.kitchen-card.is-remixed .kitchen-card__remix { background: transparent; border: 1px solid var(--white); color: var(--white); cursor: default; }
.kitchen-card.is-hidden { display: none; }

/* =====================================================
   IMAGINE YOUR KITCHEN — modal
   ===================================================== */

.remix-modal { position: fixed; inset: 0; z-index: 200; }
.remix-modal[hidden] { display: none; }
.remix-modal__backdrop {
  position: absolute; inset: 0;
  background: rgba(11, 29, 46, 0.6);
  backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
}
.remix-modal__panel {
  position: relative; max-width: 480px; margin: 5vh auto;
  background: var(--white, #FEFDFB);
  border-radius: 8px; padding: 28px 28px 24px;
  box-shadow: 0 30px 60px rgba(0, 0, 0, 0.3);
  max-height: 90vh; overflow-y: auto;
}
.remix-modal__close {
  position: absolute; top: 12px; right: 16px;
  background: none; border: none;
  font-size: 22px; color: var(--stone-500, #6B6560);
  cursor: pointer; padding: 4px 8px;
}
.remix-modal__preview {
  aspect-ratio: 4 / 3;
  background: var(--stone-200, #d4cfca) center/cover no-repeat;
  border-radius: 6px; margin-bottom: 18px;
}
.remix-modal__title {
  font-family: 'Inter', sans-serif; font-size: 22px; font-weight: 800;
  color: var(--navy, #0B1D2E); margin: 0 0 6px 0; letter-spacing: -0.01em;
}
.remix-modal__sub {
  font-size: 13px; color: var(--stone-500, #6B6560); margin: 0 0 22px 0;
}

.remix-picker { margin-bottom: 16px; }
.remix-picker__label {
  font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--cyan, #5BC5D4); font-weight: 700; margin-bottom: 6px;
}
.remix-picker__swatches { display: flex; gap: 6px; flex-wrap: wrap; }

.swatch {
  width: 36px; height: 36px; border-radius: 4px;
  border: 2px solid transparent; cursor: pointer;
}
.swatch--selected { border-color: var(--cyan, #5BC5D4); box-shadow: 0 0 0 2px var(--cyan, #5BC5D4); }
.swatch:focus-visible { outline: 2px solid var(--cyan, #5BC5D4); outline-offset: 2px; }

/* Swatch backgrounds — unchanged from prior build (they encode material colour) */
.swatch[data-key="cabinet"][data-val="white"]   { background: #f5f0e8; }
.swatch[data-key="cabinet"][data-val="grey"]    { background: #b0a8a0; }
.swatch[data-key="cabinet"][data-val="navy"]    { background: #1E3A52; }
.swatch[data-key="cabinet"][data-val="sage"]    { background: #97a08a; }
.swatch[data-key="cabinet"][data-val="timber"]  { background: linear-gradient(135deg, #c4a882, #8b6f48); }
.swatch[data-key="benchtop"][data-val="timber"]    { background: linear-gradient(135deg, #c4a882, #8b6f48); }
.swatch[data-key="benchtop"][data-val="stone"]     { background: linear-gradient(135deg, #e8e3dc, #c4cfca); }
.swatch[data-key="benchtop"][data-val="marble"]    { background: linear-gradient(135deg, #fff, #e0e0e0); }
.swatch[data-key="benchtop"][data-val="darkStone"] { background: linear-gradient(135deg, #4a4a4a, #2a2a2a); }
.swatch[data-key="splashback"][data-val="subway"] { background: repeating-linear-gradient(0deg, #fff, #fff 4px, #ddd 4px, #ddd 5px); }
.swatch[data-key="splashback"][data-val="glass"]  { background: linear-gradient(135deg, #d4e7e9, #a8c8cb); }
.swatch[data-key="splashback"][data-val="stone"]  { background: linear-gradient(135deg, #e8e3dc, #c4cfca); }
.swatch[data-key="splashback"][data-val="tiled"]  { background: repeating-linear-gradient(45deg, #c4a882, #c4a882 4px, #b8965a 4px, #b8965a 8px); }
.swatch[data-key="floor"][data-val="oak"]         { background: linear-gradient(135deg, #d4b890, #b8965a); }
.swatch[data-key="floor"][data-val="walnut"]      { background: linear-gradient(135deg, #6b4a2a, #4a3018); }
.swatch[data-key="floor"][data-val="stone"]       { background: linear-gradient(135deg, #e8e3dc, #c4cfca); }
.swatch[data-key="floor"][data-val="herringbone"] { background: repeating-linear-gradient(60deg, #c4a882, #c4a882 5px, #b8965a 5px, #b8965a 10px); }

/* Form */
.remix-form__fields {
  border-top: 1px solid var(--stone-100, #f0ebe4); padding-top: 18px; margin-top: 20px;
  display: grid; gap: 10px;
}
.remix-form__field { display: block; }
.remix-form__label {
  display: block; font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--cyan, #5BC5D4); font-weight: 700; margin-bottom: 4px;
}
.remix-form__field input {
  width: 100%; padding: 10px 12px;
  border: 1px solid var(--stone-200, #d4cfca); border-radius: 3px;
  font-family: 'Inter', sans-serif; font-size: 14px;
  color: var(--navy, #0B1D2E); background: var(--white, #fff);
}
.remix-form__field input:focus { outline: none; border-color: var(--cyan, #5BC5D4); }
.remix-form__field--invalid input { border-color: var(--error, #b04444); }
.remix-form__error {
  display: block; color: var(--error, #b04444); font-size: 12px;
  min-height: 16px; margin-top: 4px;
}
.remix-form__banner {
  background: #fff0f0; color: #8b3a3a; border: 1px solid #f4c4c4;
  padding: 10px 14px; border-radius: 4px; font-size: 13px; margin-top: 14px;
}
.remix-form__submit {
  width: 100%; background: var(--navy, #0B1D2E); color: var(--white);
  border: none; padding: 14px; border-radius: 3px;
  font-family: 'Inter', sans-serif; font-size: 14px; font-weight: 700;
  letter-spacing: 0.04em; cursor: pointer; margin-top: 16px;
  transition: background 0.2s ease;
}
.remix-form__submit:hover { background: var(--navy-mid, #152D42); }
.remix-form__submit:disabled { opacity: 0.6; cursor: wait; }
.remix-form__fields--hidden { display: none !important; }
.remix-form__disclaimer {
  font-size: 11px; color: var(--stone-500, #6B6560); text-align: center; margin: 12px 0 0;
}

.remix-modal__success { text-align: center; padding: 40px 0; }
.remix-modal__success h3 {
  font-family: 'Inter', sans-serif; font-size: 26px; font-weight: 800;
  color: var(--navy, #0B1D2E); margin: 0 0 8px;
}
.remix-modal__success p { color: var(--stone-500, #6B6560); font-size: 14px; }

/* =====================================================
   IYK LIGHTBOX — full-size preview before the remix modal
   ===================================================== */

.iyk-lightbox { position: fixed; inset: 0; z-index: 300; }
.iyk-lightbox[hidden] { display: none; }
.iyk-lightbox__backdrop {
  position: absolute; inset: 0;
  background: rgba(11, 29, 46, 0.85);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.iyk-lightbox__panel {
  position: relative; max-width: 960px; margin: 3vh auto;
  background: var(--white, #FEFDFB); border-radius: 10px;
  box-shadow: 0 30px 60px rgba(0, 0, 0, 0.4);
  max-height: 94vh; overflow-y: auto;
  display: flex; flex-direction: column;
}
.iyk-lightbox__close {
  position: absolute; top: 12px; right: 16px; z-index: 2;
  background: rgba(11, 29, 46, 0.6); border: none;
  color: var(--white); font-size: 22px; cursor: pointer;
  width: 36px; height: 36px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.2s ease;
}
.iyk-lightbox__close:hover { background: rgba(11, 29, 46, 0.85); }
.iyk-lightbox__img {
  aspect-ratio: 16 / 10;
  background: var(--stone-200, #d4cfca) center/cover no-repeat;
  border-radius: 10px 10px 0 0;
  flex-shrink: 0;
}
.iyk-lightbox__info {
  padding: 24px 28px 8px; text-align: center;
}
.iyk-lightbox__style {
  font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--cyan, #5BC5D4); font-weight: 700; margin-bottom: 4px;
}
.iyk-lightbox__name {
  font-family: 'Inter', sans-serif; font-size: 22px; font-weight: 800;
  color: var(--navy, #0B1D2E); margin: 0; letter-spacing: -0.01em;
}
.iyk-lightbox__cta {
  display: block; width: calc(100% - 56px); margin: 20px 28px 28px;
  padding: 14px; background: var(--navy, #0B1D2E); color: var(--white);
  border: none; border-radius: 4px;
  font-family: 'Inter', sans-serif; font-size: 15px; font-weight: 700;
  letter-spacing: 0.03em; cursor: pointer;
  transition: background 0.2s ease;
}
.iyk-lightbox__cta:hover { background: var(--navy-mid, #152D42); }

@media (max-width: 720px) {
  .iyk-lightbox__panel { margin: 0; border-radius: 0; max-height: 100vh; }
  .iyk-lightbox__img { border-radius: 0; aspect-ratio: 4/3; }
  .iyk-lightbox__cta { width: calc(100% - 40px); margin: 16px 20px 20px; }
  .iyk-lightbox__info { padding: 20px 20px 4px; }
  .iyk-lightbox__name { font-size: 18px; }
}
