/* Rare Curtains — premium interior palette: cream, blush, wood, charcoal */
.lux-site {
  --lux-cream: #f7f0e8;
  --lux-blush: #f0e0dc;
  --lux-sand: #e8ddcf;
  --lux-ink: #1c1917;
  --lux-wood: #7c5e3c;
  --lux-gold: #b8860b;
  --lux-gold-soft: #c9a227;
  --lux-radial: radial-gradient(ellipse 120% 80% at 10% 0%, rgba(200, 170, 120, 0.18) 0%, transparent 50%);
}

.lux-site .site-page-bg,
body.site-page-bg.lux-site {
  background: var(--lux-radial), linear-gradient(180deg, #faf6f0 0%, #f3ece4 40%, #ebe4dc 100%);
  background-attachment: fixed;
}

/* Nav */
.lux-nav {
  background: rgba(255, 252, 248, 0.86) !important;
  border-bottom: 1px solid rgba(120, 90, 60, 0.12) !important;
  backdrop-filter: blur(12px);
}

/* Logo — vibrant gradient, on-trend; fallback solid if clip unsupported */
.lux-site-brand-link {
  text-decoration: none;
  line-height: 1.1;
}
.lux-site-brand {
  display: inline-block;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(1.4rem, 0.2vw + 1.3rem, 1.65rem);
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 1.1;
  background: linear-gradient(
    105deg,
    #be185d 0%,
    #ea580c 18%,
    #ca8a04 40%,
    #0d9488 62%,
    #7c3aed 85%,
    #db2777 100%
  );
  -webkit-background-clip: text;
  background-clip: text;
  color: #92400e;
  -webkit-text-fill-color: transparent;
  transition: filter 0.2s ease, transform 0.2s ease;
}
@supports not (background-clip: text) {
  .lux-site-brand {
    -webkit-text-fill-color: currentColor;
    color: #9a3412;
    background: none;
  }
}
.lux-site-brand-link:hover .lux-site-brand {
  filter: brightness(1.08) saturate(1.05);
}

.lux-nav-pill {
  padding: 0.3rem 0.5rem;
  border-radius: 0.5rem;
  color: #57534e;
  font-weight: 500;
  border: 1px solid rgba(120, 90, 60, 0.08);
  background: rgba(255, 255, 255, 0.45);
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
  white-space: nowrap;
}

.lux-nav-pill:hover {
  background: rgba(120, 90, 60, 0.08);
  color: #92400e;
  border-color: rgba(180, 83, 9, 0.2);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.lux-nav a {
  color: #44403c;
  transition: color 0.2s ease;
}

.lux-nav a:hover {
  color: var(--lux-wood);
}

.lux-nav a.lux-nav-active {
  color: #92400e;
  font-weight: 600;
}

.lux-cta-nav {
  background: linear-gradient(135deg, #b45309 0%, #92400e 100%);
  color: #fff !important;
  padding: 0.4rem 0.9rem;
  border-radius: 9999px;
  font-size: 0.8rem;
  font-weight: 600;
  box-shadow: 0 4px 14px rgba(146, 64, 14, 0.25);
}

.lux-cta-nav:hover {
  filter: brightness(1.05);
  color: #fff !important;
}

/* Home hero — flex + flex-start (no absolute) so copy cannot vertically center; Tailwind-safe */
.lux-hero--home {
  min-height: min(88vh, 52rem);
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  padding: 0.4rem 1rem 2.75rem;
  box-sizing: border-box;
  background-color: #1c1917;
  background-image: var(--home-hero-image, url("/static/images/hero-ambient.jpg"));
  background-size: cover;
  background-position: center 35%;
  background-repeat: no-repeat;
  overflow: hidden;
}

/* Warm sepia scrim — easier on the eyes than cold black; ties to site cream (#faf6f0) */
.lux-hero--home::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    105deg,
    rgba(48, 36, 28, 0.58) 0%,
    rgba(62, 48, 38, 0.28) 46%,
    rgba(48, 36, 28, 0) 72%
  );
  pointer-events: none;
  z-index: 0;
}

.lux-hero--home::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 36%;
  background: linear-gradient(
    to top,
    #faf6f0 0%,
    rgba(250, 246, 240, 0.45) 45%,
    rgba(255, 252, 248, 0) 100%
  );
  pointer-events: none;
  z-index: 0;
}

/* Stays at start of flex column = true top; never “floats” to vertical center */
.lux-hero__shell {
  position: relative;
  z-index: 2;
  flex: 0 0 auto;
  width: 100%;
  max-width: 38rem;
  margin: 0;
  margin-right: auto;
  padding: 0;
  box-sizing: border-box;
}

/* Copy sits on the image — no panel, no border; type uses shadow for contrast */
.lux-hero__copy {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 36rem;
  text-align: left;
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  box-shadow: none;
}

.lux-hero--home .lux-hero__kicker {
  font-family: "Poppins", system-ui, sans-serif;
  color: #292524;
  letter-spacing: 0.3em;
  font-size: 0.62rem;
  text-transform: uppercase;
  font-weight: 600;
  margin: 0;
  text-shadow: 0 0 0 0.5px rgba(255, 252, 248, 0.4), 0 1px 1px rgba(255, 250, 245, 0.35);
}

.lux-hero--home .lux-hero__h1 {
  font-family: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  color: #0c0a09;
  line-height: 1.22;
  font-size: clamp(1.45rem, 2.8vw + 0.5rem, 2.05rem);
  font-weight: 500;
  font-style: normal;
  letter-spacing: -0.01em;
  margin: 0.75rem 0 0 0;
  /* Hairline light edge so black stays legible on mid-tones in the photo */
  text-shadow: 0 0 0 0.5px rgba(255, 252, 248, 0.55), 0 1px 2px rgba(255, 250, 245, 0.45);
}

.lux-hero--home .lux-hero__sub {
  font-family: "Poppins", system-ui, sans-serif;
  color: #ebe3d6;
  margin: 1.1rem 0 0 0;
  line-height: 1.7;
  font-size: 0.95rem;
  font-weight: 400;
  letter-spacing: 0.02em;
  max-width: none;
  text-shadow: 0 1px 2px rgba(40, 28, 22, 0.35);
}

.lux-hero__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem;
  margin-top: 1.5rem;
}

.lux-hero-ghost {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.6rem 1.15rem;
  border-radius: 9999px;
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: #f5ede3;
  background: rgba(55, 44, 36, 0.28);
  border: 1px solid rgba(210, 190, 165, 0.42);
  box-shadow: 0 1px 3px rgba(40, 28, 22, 0.25);
  text-decoration: none;
  transition: background 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.lux-hero-ghost:hover {
  background: rgba(98, 78, 62, 0.35);
  border-color: rgba(232, 210, 185, 0.55);
  color: #fffdf9;
  transform: translateY(-1px);
}

/* Honey-amber CTA — same family as nav but softer next to warm type */
.lux-hero--home .lux-cta-nav {
  background: linear-gradient(135deg, #b7843f 0%, #8a5a32 100%) !important;
  color: #fffaf5 !important;
  font-weight: 600;
  letter-spacing: 0.04em;
  box-shadow: 0 6px 24px -3px rgba(80, 48, 28, 0.42);
}

.lux-hero--inner {
  min-height: 48vh;
  padding-bottom: 2.5rem;
  align-items: flex-end;
}

.lux-hero--inner::after {
  height: 70%;
  background: linear-gradient(to top, var(--lux-cream) 0%, transparent 100%);
}

.lux-hero--inner .lux-hero__h1 {
  font-size: clamp(1.85rem, 3.2vw, 2.6rem);
  color: #fff;
  text-shadow: 0 2px 40px rgba(0, 0, 0, 0.35);
}

.lux-hero--inner .lux-hero__sub {
  color: #57534e;
  font-size: 0.95rem;
}

/* Category page hero */
.lux-cat-hero {
  position: relative;
  padding: 4rem 0 3.5rem;
  background: linear-gradient(180deg, #faf6f0 0%, #f0e8df 100%);
  border-bottom: 1px solid rgba(120, 90, 60, 0.1);
}

.lux-cat-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--cat-hero-image, url("/static/images/hero-ambient.jpg")) center 30% / cover;
  opacity: 0.32;
  filter: saturate(0.75);
}

.lux-cat-hero__inner {
  position: relative;
  z-index: 1;
}

/* Product grid */
.lux-grid {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 1.5rem;
}

@media (min-width: 640px) {
  .lux-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .lux-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem;
  }
}

.lux-product-card {
  position: relative;
  border-radius: 1.25rem;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 4px 30px rgba(60, 48, 40, 0.08);
  border: 1px solid rgba(120, 90, 60, 0.1);
  transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.35s ease;
}

.lux-product-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 50px rgba(60, 48, 40, 0.14);
}

.lux-product-card__media {
  position: relative;
  aspect-ratio: 4/3;
  background: #292524;
  overflow: hidden;
}

.lux-product-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
}

.lux-product-card:hover .lux-product-card__media img {
  transform: scale(1.05);
}

.lux-product-card__body {
  padding: 1.25rem 1.35rem 1.5rem;
}

.lux-product-card__label {
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #a16207;
  font-weight: 600;
}

.lux-product-card__title {
  font-size: 1.2rem;
  font-weight: 500;
  color: var(--lux-ink);
  margin-top: 0.35rem;
  letter-spacing: -0.02em;
}

.lux-product-card__excerpt {
  color: #57534e;
  font-size: 0.9rem;
  line-height: 1.55;
  margin-top: 0.5rem;
}

.lux-pill {
  display: inline-block;
  font-size: 0.7rem;
  padding: 0.2rem 0.55rem;
  border-radius: 9999px;
  background: #fef3c7;
  color: #92400e;
  margin-top: 0.5rem;
}

.lux-btn-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 1rem;
}

.lux-btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem 1.1rem;
  border-radius: 9999px;
  background: var(--lux-ink);
  color: #fff !important;
  font-size: 0.8rem;
  font-weight: 500;
  transition: background 0.2s ease;
}

.lux-btn-primary:hover {
  background: #44403c;
  color: #fff !important;
}

.lux-btn-ghost {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem 1.1rem;
  border-radius: 9999px;
  border: 1px solid rgba(60, 48, 40, 0.25);
  color: #44403c !important;
  font-size: 0.8rem;
  font-weight: 500;
  background: rgba(255, 255, 255, 0.7);
  transition: border-color 0.2s, background 0.2s;
}

.lux-btn-ghost:hover {
  background: #fff;
  border-color: #92400e;
  color: #92400e !important;
}

/* Reveal on scroll */
.lux-reveal {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 0.65s ease, transform 0.65s ease;
}

.lux-reveal.lux-reveal--visible {
  opacity: 1;
  transform: none;
}

/* Product detail */
.lux-pd-gallery {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
}

@media (min-width: 768px) {
  .lux-pd-gallery {
    grid-template-columns: 1fr 100px;
  }
}

.lux-pd-hero {
  position: relative;
  border-radius: 1.25rem;
  overflow: hidden;
  aspect-ratio: 4/3;
  background: #1c1917;
}

.lux-pd-hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.lux-pd-thumbs {
  display: flex;
  flex-direction: row;
  gap: 0.5rem;
  overflow-x: auto;
  padding-bottom: 0.25rem;
}

@media (min-width: 768px) {
  .lux-pd-thumbs {
    flex-direction: column;
    overflow-x: visible;
    overflow-y: auto;
    max-height: 28rem;
    padding-bottom: 0;
  }
}

.lux-pd-thumbs button {
  flex-shrink: 0;
  width: 4.5rem;
  height: 4.5rem;
  border-radius: 0.6rem;
  overflow: hidden;
  border: 2px solid transparent;
  padding: 0;
  cursor: pointer;
  opacity: 0.7;
  transition: opacity 0.2s, border-color 0.2s;
}

.lux-pd-thumbs button.is-active,
.lux-pd-thumbs button:hover {
  opacity: 1;
  border-color: #b45309;
}

.lux-pd-thumbs button img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.lux-dl {
  display: grid;
  gap: 0.5rem;
  font-size: 0.9rem;
}

.lux-dl > div {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding-bottom: 0.6rem;
  border-bottom: 1px solid rgba(120, 90, 60, 0.12);
}

.lux-dl dt {
  color: #78716c;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.lux-dl dd {
  color: #292524;
  margin: 0;
  line-height: 1.5;
}

/* Home category tiles */
.lux-cat-tile {
  position: relative;
  border-radius: 1.25rem;
  overflow: hidden;
  min-height: 10rem;
  display: flex;
  align-items: flex-end;
  padding: 1.5rem;
  text-decoration: none;
  color: #fff !important;
  background: #292524;
  transition: transform 0.35s ease, box-shadow 0.35s ease;
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12);
}

.lux-cat-tile::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(160deg, rgba(40, 30, 25, 0.5) 0%, rgba(20, 15, 12, 0.85) 100%),
    var(--cat-tile-image, url("/static/images/hero-ambient.jpg"));
  background-size: cover;
  background-position: center;
  transition: transform 0.5s ease;
}

.lux-cat-tile:hover::before {
  transform: scale(1.04);
}

.lux-cat-tile__label {
  position: relative;
  z-index: 1;
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #fcd34d;
}

.lux-cat-tile__title {
  position: relative;
  z-index: 1;
  font-size: 1.1rem;
  font-weight: 500;
  margin-top: 0.3rem;
}

.lux-why {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}

@media (min-width: 640px) {
  .lux-why {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .lux-why {
    grid-template-columns: repeat(4, 1fr);
  }
}

.lux-why-card {
  background: #fff;
  border-radius: 1rem;
  padding: 1.5rem;
  border: 1px solid rgba(120, 90, 60, 0.1);
  box-shadow: 0 2px 16px rgba(60, 48, 40, 0.06);
}

.lux-why-icon {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 9999px;
  background: linear-gradient(135deg, #fff7ed 0%, #ffedd5 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #b45309;
  font-size: 1.1rem;
  margin-bottom: 0.75rem;
}

/* Booking form in luxury */
.lux-form input,
.lux-form textarea,
.lux-form select,
.lux-form .field {
  background: #fff;
  border-color: rgba(120, 90, 60, 0.15);
  border-radius: 0.75rem;
}

.lux-form input:focus,
.lux-form textarea:focus,
.lux-form .field:focus {
  border-color: #b45309;
  box-shadow: 0 0 0 3px rgba(180, 83, 9, 0.12);
}

.lux-form button[type="submit"] {
  background: linear-gradient(135deg, #1c1917 0%, #44403c 100%) !important;
  border-radius: 9999px;
}

/* Testimonials in luxury (override) */
.lux-testimonials {
  background: linear-gradient(180deg, #faf6f0 0%, #f3ece4 100%) !important;
  border-top: 1px solid rgba(120, 90, 60, 0.08);
}

.lux-testimonials .testimonial-card {
  background: rgba(255, 255, 255, 0.8);
  border: 1px solid rgba(120, 90, 60, 0.1);
}

.lux-testimonials .testimonial-avatar {
  border-color: rgba(120, 90, 60, 0.22);
  box-shadow: 0 2px 12px rgba(15, 23, 42, 0.07);
}

/* Footer */
.lux-foot {
  background: linear-gradient(180deg, #1c1917 0%, #0c0a09 100%) !important;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  color: #d6d3d1 !important;
}

.lux-foot a {
  color: #e7e5e4;
}

.lux-foot a:hover {
  color: #fcd34d;
}

/* --- Product image moods: name + type read visually (works with Picsum or local fallback) --- */
.lux-mood {
  position: relative;
  overflow: hidden;
}

.lux-mood::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
  z-index: 1;
  transition: opacity 0.3s ease;
}

.lux-mood .lux-mood-img {
  position: relative;
  z-index: 0;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: filter 0.35s ease, transform 0.5s ease;
}

/* Sheers — soft, high-key daylight */
.lux-mood[data-mood="sheer_bright"] .lux-mood-img {
  filter: brightness(1.1) contrast(0.97) saturate(0.9);
}
.lux-mood[data-mood="sheer_bright"]::after {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.2) 0%, transparent 45%, rgba(200, 180, 150, 0.05) 100%);
}

/* Blackout range — room reads darker */
.lux-mood[data-mood="blackout_dim"] .lux-mood-img {
  filter: brightness(0.45) contrast(1.12) saturate(0.88);
}
.lux-mood[data-mood="blackout_dim"]::after {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.1) 0%, rgba(0, 0, 0, 0.5) 100%);
}

/* Cinema / zero-light */
.lux-mood[data-mood="blackout_cinema"] .lux-mood-img {
  filter: brightness(0.25) contrast(1.2) saturate(0.8);
}
.lux-mood[data-mood="blackout_cinema"]::after {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.35) 0%, rgba(0, 0, 0, 0.75) 100%);
}

/* Hotel layered — warm evening, soft lamp glow */
.lux-mood[data-mood="hotel_dim"] .lux-mood-img {
  filter: brightness(0.55) contrast(1.02) sepia(0.12) saturate(0.9);
}
.lux-mood[data-mood="hotel_dim"]::after {
  background: linear-gradient(165deg, rgba(80, 50, 30, 0.25) 0%, rgba(0, 0, 0, 0.35) 100%);
}

/* Sheer + drape double stack */
.lux-mood[data-mood="layered_warm"] .lux-mood-img {
  filter: brightness(0.78) contrast(1.04) sepia(0.08) saturate(0.92);
}
.lux-mood[data-mood="layered_warm"]::after {
  background: linear-gradient(90deg, rgba(255, 250, 240, 0.1) 0%, transparent 40%, rgba(20, 15, 10, 0.25) 100%);
}

/* Classic living / premium curtains */
.lux-mood[data-mood="living_warm"] .lux-mood-img {
  filter: brightness(0.88) contrast(1.03) sepia(0.06) saturate(0.95);
}
.lux-mood[data-mood="living_warm"]::after {
  background: linear-gradient(to top, rgba(30, 20, 12, 0.15) 0%, transparent 55%);
}

/* Velvet / brocade evening elegance */
.lux-mood[data-mood="luxe_dim"] .lux-mood-img {
  filter: brightness(0.62) contrast(1.08) saturate(0.85);
}
.lux-mood[data-mood="luxe_dim"]::after {
  background: linear-gradient(120deg, rgba(40, 20, 15, 0.35) 0%, rgba(0, 0, 0, 0.15) 100%);
}

/* Indian salon / formal living */
.lux-mood[data-mood="indian_salon_warm"] .lux-mood-img {
  filter: brightness(0.75) contrast(1.04) sepia(0.2) saturate(0.9);
}
.lux-mood[data-mood="indian_salon_warm"]::after {
  background: linear-gradient(180deg, rgba(200, 160, 80, 0.12) 0%, rgba(20, 10, 5, 0.35) 100%);
}

/* Stitching / headers */
.lux-mood[data-mood="stitching_neutral"] .lux-mood-img {
  filter: brightness(0.9) contrast(1.05) saturate(0.75);
}
.lux-mood[data-mood="stitching_neutral"]::after {
  background: linear-gradient(to bottom, rgba(60, 50, 45, 0.08) 0%, rgba(0, 0, 0, 0.12) 100%);
}

/* --- Homepage: Atelier journey (dark editorial interlude, not a dashed timeline) --- */
.lux-journey {
  position: relative;
  padding: 2.5rem 0 2.75rem;
  overflow: hidden;
  color: #e7e5e4;
}

.lux-journey__bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 90% 55% at 50% -10%, rgba(180, 130, 60, 0.16) 0%, transparent 55%),
    radial-gradient(ellipse 70% 40% at 100% 80%, rgba(80, 60, 40, 0.2) 0%, transparent 50%),
    linear-gradient(165deg, #0c0a09 0%, #1c1917 38%, #292524 72%, #1a1816 100%);
  pointer-events: none;
}

.lux-journey__bg::after {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0.35;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
}

.lux-journey__eyebrow {
  text-align: center;
  font-size: 0.65rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: #d6b68a;
  margin-bottom: 0.5rem;
}

.lux-journey__h2 {
  text-align: center;
  font-size: clamp(1.5rem, 3.2vw, 2.1rem);
  font-weight: 400;
  letter-spacing: -0.02em;
  color: #fafaf9;
  line-height: 1.2;
  margin: 0;
}

.lux-journey__intro {
  text-align: center;
  max-width: 32rem;
  margin: 0.6rem auto 0;
  font-size: 0.8125rem;
  line-height: 1.55;
  color: #a8a29e;
  font-weight: 300;
}

.lux-journey__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.1rem;
  margin-top: 1.5rem;
}

@media (min-width: 640px) {
  .lux-journey__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem 0.9rem;
  }
}

@media (min-width: 1024px) {
  .lux-journey__grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.75rem 0.65rem;
    align-items: stretch;
  }
}

.lux-journey__card {
  position: relative;
  display: flex;
  flex-direction: column;
  border-radius: 0.85rem;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(41, 37, 36, 0.65) 0%, rgba(28, 25, 23, 0.9) 100%);
  border: 1px solid rgba(180, 130, 60, 0.18);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.28);
  transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.4s ease, border-color 0.3s ease;
}

.lux-journey__card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(145deg, rgba(244, 208, 127, 0.35) 0%, transparent 42%, rgba(100, 80, 60, 0.15) 100%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 2;
  opacity: 0.6;
}

.lux-journey__card:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.4);
  border-color: rgba(212, 175, 110, 0.35);
}

.lux-journey__media {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: #0c0a09;
}

.lux-journey__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  filter: brightness(0.88) contrast(1.04) saturate(0.9);
  transition: transform 0.6s ease, filter 0.4s ease;
}

.lux-journey__card:hover .lux-journey__img {
  transform: scale(1.03);
  filter: brightness(0.95) contrast(1.02) saturate(0.95);
}

/* Simulates a team t-shirt “Rare Curtains” until a real on-site team photo is added. */
.lux-journey__media--tee .lux-journey__tee {
  position: absolute;
  left: 50%;
  bottom: 20%;
  transform: translateX(-50%);
  margin: 0;
  pointer-events: none;
  z-index: 1;
}

.lux-journey__tee-mark {
  display: inline-block;
  max-width: 7rem;
  padding: 0.28em 0.45em 0.3em;
  font-family: "Poppins", system-ui, sans-serif;
  font-size: clamp(0.5rem, 1.55vw, 0.65rem);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  line-height: 1.1;
  text-align: center;
  color: #fafaf9;
  background: #1a1815;
  border: 1px solid rgba(251, 191, 36, 0.45);
  border-radius: 0.2rem;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.4);
}

.lux-journey__body {
  padding: 0.75rem 0.7rem 0.9rem;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.lux-journey__index {
  display: block;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 1.55rem;
  line-height: 1;
  background: linear-gradient(135deg, #fcd34d 0%, #b45309 50%, #d97706 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  opacity: 0.95;
  margin-bottom: 0.1rem;
  font-weight: 500;
  letter-spacing: 0.02em;
}

.lux-journey__title {
  font-size: 0.95rem;
  font-weight: 500;
  color: #fafaf9;
  margin: 0;
  letter-spacing: 0.01em;
  line-height: 1.2;
}

.lux-journey__text {
  margin: 0;
  font-size: 0.75rem;
  line-height: 1.5;
  color: #c4c2be;
  font-weight: 400;
}

@media (min-width: 640px) {
  .lux-journey__text {
    font-size: 0.8125rem;
  }
}

.lux-journey__text em {
  color: #d6d3d1;
  font-style: italic;
  font-weight: 400;
}

.lux-journey__footer {
  text-align: center;
  margin-top: 1.25rem;
}

.lux-journey__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.6rem 1.35rem;
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #1c1917;
  text-decoration: none;
  background: linear-gradient(135deg, #fbbf24 0%, #d97706 45%, #b45309 100%);
  border-radius: 9999px;
  box-shadow: 0 6px 24px rgba(180, 83, 9, 0.35);
  transition: filter 0.2s ease, transform 0.2s ease;
}

.lux-journey__cta:hover {
  filter: brightness(1.08);
  color: #1c1917;
  transform: translateY(-1px);
}

/* Client-submitted + moderated feedback */
.lux-feedback-published {
  border-radius: 1.1rem;
  padding: 1rem 1.15rem;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(120, 90, 60, 0.12);
  box-shadow: 0 2px 16px rgba(15, 23, 42, 0.05);
}

.lux-testimonials .lux-feedback-form input,
.lux-testimonials .lux-feedback-form textarea,
.lux-testimonials .lux-feedback-form select {
  font-family: "Poppins", system-ui, sans-serif;
}

/* --- Floating site assistant (quick links + simple FAQ) --- */
.lux-chatbot {
  position: fixed;
  z-index: 100;
  right: max(1rem, env(safe-area-inset-right, 0));
  bottom: max(1rem, env(safe-area-inset-bottom, 0));
  left: auto;
  width: max-content;
  max-width: min(100vw - 1.5rem, 22rem);
  pointer-events: none;
  font-family: "Poppins", system-ui, sans-serif;
  font-size: 0.8125rem;
  line-height: 1.45;
  color: #292524;
}

.lux-chatbot * {
  box-sizing: border-box;
}

.lux-chatbot__stack {
  display: flex;
  flex-direction: column-reverse;
  align-items: flex-end;
  gap: 0.5rem;
  pointer-events: auto;
  max-width: min(100vw - 1.5rem, 20.5rem);
}

.lux-chatbot__panel {
  display: none;
  width: 100%;
  max-height: min(32rem, 70vh);
  flex-direction: column;
  background: #fffefb;
  border: 1px solid rgba(120, 90, 60, 0.2);
  border-radius: 1rem;
  box-shadow: 0 18px 48px rgba(15, 23, 42, 0.18);
  overflow: hidden;
}

.lux-chatbot--open .lux-chatbot__panel {
  display: flex;
}

.lux-chatbot__head {
  padding: 0.9rem 1rem 0.6rem;
  background: linear-gradient(160deg, #1c1917 0%, #292524 100%);
  color: #fafaf9;
}

.lux-chatbot__title {
  font-size: 1.1rem;
  font-weight: 500;
  margin: 0;
  line-height: 1.2;
  color: #fff;
}

.lux-chatbot__sub {
  margin: 0.35rem 0 0;
  font-size: 0.7rem;
  line-height: 1.4;
  color: #a8a29e;
  font-weight: 400;
}

.lux-chatbot__scroll {
  display: flex;
  flex-direction: column;
  min-height: 0;
  flex: 1 1 auto;
  max-height: min(20rem, 45vh);
}

.lux-chatbot__messages {
  flex: 1 1 auto;
  overflow: auto;
  padding: 0.65rem 0.75rem 0.5rem;
  -webkit-overflow-scrolling: touch;
  background: #faf6f0;
}

.lux-chatbot__row {
  display: flex;
  margin-bottom: 0.5rem;
  justify-content: flex-start;
}

.lux-chatbot__row--user {
  justify-content: flex-end;
}

.lux-chatbot__bubble {
  max-width: 90%;
  margin: 0;
  padding: 0.45rem 0.6rem;
  border-radius: 0.75rem;
  font-size: 0.75rem;
  line-height: 1.5;
  word-wrap: break-word;
}

.lux-chatbot__bubble--bot {
  background: #fff;
  border: 1px solid rgba(120, 90, 60, 0.12);
  color: #44403c;
  border-top-left-radius: 0.2rem;
}

.lux-chatbot__bubble--user {
  background: #1c1917;
  color: #fafaf9;
  border: 1px solid #44403c;
  border-top-right-radius: 0.2rem;
}

.lux-chatbot__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  padding: 0.45rem 0.65rem 0.65rem;
  background: #faf6f0;
  border-top: 1px solid rgba(120, 90, 60, 0.08);
}

.lux-chatbot__chip {
  display: inline-flex;
  align-items: center;
  padding: 0.3rem 0.55rem;
  font-size: 0.65rem;
  font-weight: 500;
  line-height: 1.2;
  color: #44403c;
  text-decoration: none;
  background: #fff;
  border: 1px solid rgba(120, 90, 60, 0.18);
  border-radius: 9999px;
  transition: background 0.15s ease, border-color 0.15s ease;
}

.lux-chatbot__chip:hover {
  background: #fff7ed;
  border-color: rgba(180, 83, 9, 0.4);
  color: #1c1917;
}

.lux-chatbot__chip--wa {
  color: #047857;
  border-color: rgba(4, 120, 87, 0.35);
}

.lux-chatbot__chip--wa:hover {
  background: #ecfdf5;
  color: #065f46;
}

.lux-chatbot__form {
  display: flex;
  gap: 0.4rem;
  padding: 0.55rem 0.6rem 0.65rem;
  border-top: 1px solid rgba(120, 90, 60, 0.12);
  background: #fff;
}

.lux-chatbot__input {
  flex: 1 1 auto;
  min-width: 0;
  padding: 0.4rem 0.5rem;
  font-size: 0.75rem;
  border: 1px solid rgba(120, 90, 60, 0.2);
  border-radius: 0.5rem;
  color: #1c1917;
}

.lux-chatbot__input::placeholder {
  color: #a8a29e;
}

.lux-chatbot__input:focus {
  outline: none;
  border-color: #b45309;
  box-shadow: 0 0 0 2px rgba(180, 83, 9, 0.15);
}

.lux-chatbot__send {
  flex-shrink: 0;
  padding: 0.4rem 0.7rem;
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #1c1917;
  background: linear-gradient(135deg, #fbbf24 0%, #d97706 70%, #b45309 100%);
  border: none;
  border-radius: 0.5rem;
  cursor: pointer;
}

.lux-chatbot__send:hover {
  filter: brightness(1.04);
}

.lux-chatbot__send:focus-visible {
  outline: 2px solid #b45309;
  outline-offset: 1px;
}

@keyframes lux-chatbot-fab-breathe {
  0%,
  100% {
    box-shadow:
      0 6px 20px rgba(0, 0, 0, 0.35),
      0 0 0 0 rgba(245, 158, 11, 0.35),
      0 0 18px rgba(245, 158, 11, 0.12);
  }
  55% {
    box-shadow:
      0 8px 28px rgba(0, 0, 0, 0.38),
      0 0 0 5px rgba(245, 158, 11, 0.08),
      0 0 26px rgba(251, 191, 36, 0.32);
  }
}

.lux-chatbot__fab {
  position: relative;
  z-index: 1;
  width: 3.9rem;
  height: 3.9rem;
  border-radius: 9999px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: #fffbeb;
  background:
    radial-gradient(120% 100% at 32% 18%, #4a4541 0%, transparent 48%),
    linear-gradient(155deg, #0f0d0b 0%, #1c1917 42%, #292524 100%);
  box-shadow:
    0 6px 20px rgba(0, 0, 0, 0.35),
    0 0 0 1px rgba(251, 191, 36, 0.35),
    0 0 0 0 rgba(245, 158, 11, 0.35),
    0 0 18px rgba(245, 158, 11, 0.12);
  border: 1.5px solid rgba(252, 211, 77, 0.5);
  pointer-events: auto;
  transition:
    transform 0.25s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.25s ease,
    border-color 0.25s ease;
  animation: lux-chatbot-fab-breathe 2.6s ease-in-out infinite;
}

.lux-chatbot__fab:hover {
  transform: translateY(-2px) scale(1.04);
  border-color: rgba(252, 211, 77, 0.85);
  color: #fff;
  box-shadow:
    0 12px 40px rgba(0, 0, 0, 0.4),
    0 0 0 1px rgba(253, 230, 138, 0.55),
    0 0 32px rgba(251, 191, 36, 0.45);
  animation: none;
}

.lux-chatbot__fab:focus-visible {
  outline: 2px solid #fde047;
  outline-offset: 3px;
  animation: none;
}

.lux-chatbot--open .lux-chatbot__fab {
  animation: none;
  box-shadow:
    0 6px 20px rgba(0, 0, 0, 0.35),
    0 0 0 1px rgba(251, 191, 36, 0.45);
}

@keyframes lux-chatbot-hello-drift {
  0%,
  100% {
    transform: translateY(0) translateX(0) scale(1);
  }
  50% {
    transform: translateY(-4px) translateX(1px) scale(1.04);
  }
}

@keyframes lux-chatbot-bubble-glow {
  0%,
  100% {
    box-shadow:
      0 2px 14px rgba(0, 0, 0, 0.12),
      0 0 0 1px rgba(255, 255, 255, 0.55) inset,
      0 0 18px rgba(236, 72, 153, 0.45),
      0 0 28px rgba(6, 182, 212, 0.25);
  }
  50% {
    box-shadow:
      0 4px 22px rgba(0, 0, 0, 0.14),
      0 0 0 1px rgba(255, 255, 255, 0.65) inset,
      0 0 26px rgba(244, 114, 182, 0.65),
      0 0 38px rgba(34, 211, 238, 0.4),
      0 0 20px rgba(250, 204, 21, 0.35);
  }
}

@keyframes lux-chatbot-hello-wave {
  0%,
  100% {
    transform: rotate(0deg);
  }
  25% {
    transform: rotate(12deg);
  }
  50% {
    transform: rotate(-5deg);
  }
  75% {
    transform: rotate(8deg);
  }
}

.lux-chatbot__fab-waver {
  position: absolute;
  z-index: 2;
  top: -0.6rem;
  right: 0.05rem;
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
  animation: lux-chatbot-hello-drift 2.4s ease-in-out infinite;
  filter: drop-shadow(0 4px 8px rgba(236, 72, 153, 0.35)) drop-shadow(0 2px 12px rgba(6, 182, 212, 0.25));
}

.lux-chatbot__fab-waver-bubble {
  display: block;
  width: 3.1rem;
  height: 3.65rem;
  padding: 0.1rem 0.15rem 0.05rem;
  background: linear-gradient(
    140deg,
    #fff1f2 0%,
    #fef3c7 22%,
    #dbeafe 48%,
    #fce7f3 72%,
    #fef9c3 100%
  );
  border: 2px solid rgba(244, 114, 182, 0.7);
  border-radius: 0.95rem;
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.55) inset,
    0 2px 14px rgba(0, 0, 0, 0.12),
    0 0 18px rgba(236, 72, 153, 0.45),
    0 0 28px rgba(6, 182, 212, 0.25);
  animation: lux-chatbot-bubble-glow 2.1s ease-in-out infinite;
}

.lux-chatbot__waver-figure {
  display: block;
  width: 100%;
  height: 100%;
}

.lux-chatbot__waver-arm {
  transform-origin: 0 0;
  transform-box: fill-box;
  animation: lux-chatbot-hello-wave 1.3s ease-in-out infinite;
}

.lux-chatbot--open .lux-chatbot__fab-waver {
  opacity: 0;
  transform: scale(0.9);
  pointer-events: none;
}

.lux-chatbot__fab-icons {
  position: relative;
  display: block;
  width: 1.7rem;
  height: 1.7rem;
  filter: drop-shadow(0 0 1px rgba(0, 0, 0, 0.15));
}

.lux-chatbot__icon {
  position: absolute;
  inset: 0;
  display: block;
  margin: auto;
}

.lux-chatbot__icon--close {
  display: none;
  width: 1.5rem;
  height: 1.5rem;
  inset: 0;
  margin: auto;
}

.lux-chatbot--open .lux-chatbot__icon--open {
  display: none;
}

.lux-chatbot--open .lux-chatbot__icon--close {
  display: block;
}

/* --- /curtains premium hub (ranges, headers, rooms) --- */
.lux-curt-hub__strip {
  background: rgba(255, 255, 255, 0.65);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.lux-curt-hub__pill {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0.85rem;
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #57534e;
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(120, 90, 60, 0.15);
  border-radius: 9999px;
  text-decoration: none;
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.lux-curt-hub__pill:hover {
  background: #fff;
  border-color: rgba(180, 83, 9, 0.35);
  color: #1c1917;
}

.lux-curt-hub__pill--accent {
  color: #1c1917;
  background: linear-gradient(135deg, #fde68a 0%, #fbbf24 45%, #d97706 100%);
  border-color: rgba(180, 83, 9, 0.25);
}

.lux-curt-hub__pill--accent:hover {
  filter: brightness(1.03);
  color: #0c0a09;
}

.lux-curt-hub__range-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

@media (min-width: 640px) {
  .lux-curt-hub__range-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.1rem;
  }
}

@media (min-width: 1024px) {
  .lux-curt-hub__range-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
  }
}

.lux-curt-hub__range-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: 1.15rem 1.1rem 1.25rem;
  text-align: left;
  text-decoration: none;
  color: inherit;
  background: #fff;
  border: 1px solid rgba(120, 90, 60, 0.12);
  border-radius: 0.9rem;
  box-shadow: 0 2px 14px rgba(15, 23, 42, 0.04);
  transition: box-shadow 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
  min-height: 100%;
}

.lux-curt-hub__range-card:hover {
  border-color: rgba(180, 83, 9, 0.28);
  box-shadow: 0 8px 28px rgba(15, 23, 42, 0.08);
  transform: translateY(-2px);
}

.lux-curt-hub__range-kicker {
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #b45309;
}

.lux-curt-hub__range-title {
  display: block;
  margin-top: 0.35rem;
  font-size: 1.15rem;
  font-weight: 500;
  line-height: 1.2;
  color: #1c1917;
}

.lux-curt-hub__range-desc {
  display: block;
  margin-top: 0.45rem;
  font-size: 0.8rem;
  line-height: 1.5;
  color: #57534e;
  flex: 1 1 auto;
}

.lux-curt-hub__range-cta {
  display: block;
  margin-top: 0.75rem;
  font-size: 0.72rem;
  font-weight: 600;
  color: #92400e;
  letter-spacing: 0.02em;
}

.lux-curt-hub__header-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

@media (min-width: 640px) {
  .lux-curt-hub__header-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .lux-curt-hub__header-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.9rem;
  }
}

.lux-curt-hub__header-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 1.1rem 1rem 1.2rem;
  text-decoration: none;
  color: inherit;
  background: linear-gradient(180deg, #fffefb 0%, #faf5f0 100%);
  border: 1px solid rgba(120, 90, 60, 0.14);
  border-radius: 0.85rem;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.lux-curt-hub__header-card:hover {
  border-color: rgba(180, 83, 9, 0.35);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
}

.lux-curt-hub__header-name {
  font-size: 1.1rem;
  font-weight: 500;
  color: #1c1917;
  margin: 0;
}

.lux-curt-hub__header-desc {
  font-size: 0.75rem;
  line-height: 1.5;
  color: #57534e;
  margin: 0.5rem 0 0;
  flex: 1 1 auto;
}

.lux-curt-hub__header-use {
  font-size: 0.65rem;
  line-height: 1.4;
  color: #a8a29e;
  margin-top: 0.55rem;
  font-style: italic;
}

.lux-curt-hub__header-more {
  margin-top: 0.6rem;
  font-size: 0.7rem;
  font-weight: 600;
  color: #b45309;
}

.lux-curt-hub__room {
  padding: 1.1rem 1.15rem;
  background: #fff;
  border: 1px solid rgba(120, 90, 60, 0.1);
  border-radius: 0.75rem;
  box-shadow: 0 1px 8px rgba(15, 23, 42, 0.03);
}

/* --- /curtain-types infographic guide --- */
.lux-types-guide {
  --t-rose: #9f6b6b;
  --t-cream: #faf5f0;
  --t-paper: #fffcf9;
}

.lux-types-guide__hero {
  background: linear-gradient(180deg, #f4e8e4 0%, var(--t-cream) 45%, #ebe4dc 100%);
  border-bottom: 1px solid rgba(120, 90, 60, 0.12);
}

.lux-types-guide__kicker {
  display: inline-block;
  padding: 0.2rem 0.9rem;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #fff;
  background: var(--t-rose);
  border-radius: 2px;
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.06);
}

.lux-types-guide__h1 {
  font-size: clamp(1.75rem, 4vw, 2.4rem);
  font-weight: 500;
  color: #3f2a28;
  margin: 0.6rem 0 0;
  letter-spacing: 0.02em;
}

.lux-types-guide__subhead {
  margin: 0.75rem auto 0;
  max-width: 28rem;
  font-size: 0.9rem;
  line-height: 1.6;
  color: #5c4d4a;
}

.lux-types-guide__deco {
  margin-top: 0.75rem;
  color: var(--t-rose);
  opacity: 0.6;
  font-size: 0.9rem;
  letter-spacing: 0.5em;
}

.lux-types-guide__section {
  padding: 1.25rem 0;
  border-bottom: 1px dashed rgba(120, 90, 60, 0.15);
}

.lux-types-guide__section--popular {
  background: var(--t-paper);
  margin-left: -1rem;
  margin-right: -1rem;
  padding-left: 1rem;
  padding-right: 1rem;
  border-radius: 0.75rem;
  border: 1px solid rgba(120, 90, 60, 0.1);
  border-bottom: 1px solid rgba(120, 90, 60, 0.1);
}

.lux-types-guide__h2 {
  font-size: 1.25rem;
  font-weight: 500;
  color: #3f2a28;
  margin: 0 0 0.35rem;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.35rem;
}

.lux-types-guide__h2-emoji {
  font-size: 1.1em;
  line-height: 1;
}

.lux-types-guide__h3 {
  font-size: 0.9rem;
  font-weight: 600;
  color: #1c1917;
  margin: 0 0 0.35rem;
  font-family: "Poppins", system-ui, sans-serif;
}

.lux-types-guide__lead {
  font-size: 0.8rem;
  line-height: 1.5;
  color: #6b5d59;
  margin: 0 0 0.9rem;
  max-width: 40rem;
}

.lux-types-guide__chip-grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.5rem;
}

@media (min-width: 480px) {
  .lux-types-guide__chip-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 900px) {
  .lux-types-guide__chip-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.lux-types-guide__fabric {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8rem;
  line-height: 1.3;
  color: #44403c;
  padding: 0.4rem 0.5rem;
  background: #fff;
  border: 1px solid rgba(120, 90, 60, 0.12);
  border-radius: 0.4rem;
}

.lux-types-guide__swatch {
  width: 1.1rem;
  height: 1.1rem;
  border-radius: 50%;
  flex-shrink: 0;
  border: 1px solid rgba(0, 0, 0, 0.1);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.35);
}
.lux-types-guide__swatch--cotton {
  background: #f5f0e6;
}
.lux-types-guide__swatch--linen {
  background: #d4c4a8;
}
.lux-types-guide__swatch--silk {
  background: #fce7f3;
}
.lux-types-guide__swatch--velvet {
  background: #4a3728;
}
.lux-types-guide__swatch--jacq {
  background: linear-gradient(135deg, #e7e0d8, #8b7355);
}
.lux-types-guide__swatch--poly {
  background: #e2e8f0;
}
.lux-types-guide__swatch--bo {
  background: #1e293b;
}

/* Image-led type cards (curtain types guide) */
.lux-types-guide__fig {
  width: 100%;
  background: #f4f0eb;
  border-bottom: 1px solid rgba(120, 90, 60, 0.1);
  overflow: hidden;
}

.lux-types-guide__fig img {
  width: 100%;
  height: auto;
  aspect-ratio: 5 / 3;
  object-fit: cover;
  display: block;
}

.lux-types-guide__image-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
  margin: 0;
  padding: 0;
}

@media (min-width: 480px) {
  .lux-types-guide__image-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 768px) {
  .lux-types-guide__image-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 1200px) {
  .lux-types-guide__image-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.lux-types-guide__type-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  background: #fff;
  border: 1px solid rgba(120, 90, 60, 0.12);
  border-radius: 0.5rem;
  overflow: hidden;
  box-shadow: 0 1px 6px rgba(15, 23, 42, 0.04);
}

.lux-types-guide__type-card .lux-types-guide__h3 {
  margin: 0.6rem 0.85rem 0.25rem;
  padding: 0;
}

.lux-types-guide__type-card p {
  margin: 0;
  font-size: 0.75rem;
  line-height: 1.5;
  color: #5c4d4a;
  padding: 0 0.85rem 0.9rem;
}

.lux-types-guide__style-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
}

@media (min-width: 640px) {
  .lux-types-guide__style-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.lux-types-guide__style-card {
  text-decoration: none;
  color: inherit;
  padding: 1rem;
  background: #fff;
  border: 1px solid rgba(120, 90, 60, 0.14);
  border-radius: 0.5rem;
  box-shadow: 0 1px 6px rgba(15, 23, 42, 0.04);
  transition: border-color 0.2s, box-shadow 0.2s;
  display: block;
}

.lux-types-guide__style-card:hover {
  border-color: rgba(159, 107, 107, 0.45);
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.05);
}

.lux-types-guide__style-card--static {
  cursor: default;
}

.lux-types-guide__style-card--visual {
  padding: 0;
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
}

.lux-types-guide__style-card--visual .lux-types-guide__h3 {
  margin: 0.6rem 0.85rem 0.25rem;
  padding: 0;
}

.lux-types-guide__style-card--visual p {
  padding: 0 0.85rem 0.9rem;
}

.lux-types-guide__style-card p,
.lux-types-guide__special p {
  margin: 0;
  font-size: 0.75rem;
  line-height: 1.5;
  color: #5c4d4a;
}

.lux-types-guide__special-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
}

@media (min-width: 640px) {
  .lux-types-guide__special-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.lux-types-guide__special {
  text-decoration: none;
  color: inherit;
  display: block;
  padding: 1rem 1.05rem;
  background: linear-gradient(165deg, #fff 0%, #f9f2ec 100%);
  border: 1px solid rgba(159, 107, 107, 0.25);
  border-radius: 0.5rem;
  transition: box-shadow 0.2s;
}
.lux-types-guide__special:hover {
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.06);
}

.lux-types-guide__special--visual {
  background: #fff;
  border: 1px solid rgba(120, 90, 60, 0.14);
  border-radius: 0.5rem;
  padding: 0;
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  box-shadow: 0 1px 6px rgba(15, 23, 42, 0.04);
}

.lux-types-guide__special--visual:hover {
  border-color: rgba(159, 107, 107, 0.4);
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.05);
}

.lux-types-guide__special--visual .lux-types-guide__h3 {
  margin: 0.6rem 0.85rem 0.25rem;
  padding: 0;
}

.lux-types-guide__special--visual p {
  padding: 0 0.85rem 0.9rem;
}

.lux-types-guide__design-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

@media (min-width: 700px) {
  .lux-types-guide__design-row {
    grid-template-columns: repeat(3, 1fr);
  }
}

.lux-types-guide__design-row .lux-types-guide__type-card {
  text-align: left;
}

.lux-types-guide__design-card {
  text-align: center;
  padding: 0.75rem 0.5rem;
}

.lux-types-guide__mock {
  width: 100%;
  aspect-ratio: 4 / 3;
  max-height: 5.5rem;
  margin: 0 auto 0.5rem;
  border-radius: 0.35rem;
  border: 1px solid rgba(120, 90, 60, 0.15);
}
.lux-types-guide__mock--plain {
  background: #e7e1db;
}
.lux-types-guide__mock--print {
  background: repeating-linear-gradient(
    45deg,
    #f4e4dc,
    #f4e4dc 6px,
    #e8d4cf 6px,
    #e8d4cf 12px
  );
}
.lux-types-guide__mock--tex {
  background: linear-gradient(160deg, #d6cfc4 0%, #9c8b7a 100%);
}

.lux-types-guide__checklist {
  list-style: none;
  margin: 0.75rem 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  font-size: 0.8rem;
  line-height: 1.45;
  color: #4b423f;
}
.lux-types-guide__checklist li {
  position: relative;
  padding-left: 1.25rem;
}
.lux-types-guide__checklist li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--t-rose);
  font-weight: 700;
  font-size: 0.75rem;
}

.lux-types-guide__pro {
  padding: 1.5rem 1.1rem;
  background: linear-gradient(120deg, #faf0ec 0%, #f0e6df 100%);
  border: 1px solid rgba(120, 90, 60, 0.12);
  border-radius: 0.75rem;
}

.lux-types-guide__pro-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  margin-top: 0.75rem;
  text-align: left;
}
@media (min-width: 768px) {
  .lux-types-guide__pro-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
.lux-types-guide__pro-item p {
  margin: 0.35rem 0 0;
  font-size: 0.8rem;
  line-height: 1.5;
  color: #5c4d4a;
}

.lux-types-guide__footer {
  padding-top: 0.5rem;
}

.lux-nav a.lux-nav-active.lux-nav-pill {
  border-color: rgba(180, 83, 9, 0.35);
  background: rgba(255, 251, 235, 0.85);
}

@media (min-width: 640px) {
  .lux-site-brand {
    font-size: 1.55rem;
  }
}

@media (max-width: 380px) {
  .lux-chatbot {
    right: 0.5rem;
    bottom: 0.5rem;
  }
  .lux-chatbot__stack {
    max-width: calc(100vw - 1rem);
  }
}

@media (prefers-reduced-motion: reduce) {
  .lux-chatbot__fab {
    transition: none;
    animation: none;
  }
  .lux-chatbot__fab:hover {
    transform: none;
  }
  .lux-chatbot__fab-waver,
  .lux-chatbot__fab-waver-bubble,
  .lux-chatbot__waver-arm {
    animation: none;
  }
  .lux-chatbot__fab-waver {
    filter: none;
  }
  .lux-journey__card,
  .lux-journey__img,
  .lux-journey__cta {
    transition: none;
  }
  .lux-journey__card:hover {
    transform: none;
  }
  .lux-journey__card:hover .lux-journey__img {
    transform: none;
  }
  .lux-curt-hub__range-card:hover {
    transform: none;
  }
}
