/* ── Home page overrides — loaded on top of styles.css ── */
.home-page {
  --ink: #1b2320;
  --muted: #5b6762;
  --line: rgba(27, 35, 32, .14);
  --paper: #f4f0e7;
  --paper-strong: #e6dfd2;
  --white: #fffaf1;
  --forest: #223b31;
  --forest-soft: #dbe5dd;
  --clay: #b53b31;
  --sand: #d7c2a2;
  --sky: #9fb3b5;
  --shadow: 0 30px 90px rgba(26, 33, 30, .16);
  font-family: "Outfit", "Avenir Next", "Segoe UI", system-ui, -apple-system, sans-serif;
  background: var(--paper);
}

.home-page .site-header {
  border-bottom-color: rgba(27, 35, 32, .09);
  background: rgba(244, 240, 231, .78);
}

.home-page .menu-button {
  position: fixed;
  top: 17px;
  right: clamp(16px, 4vw, 24px);
  left: auto;
  z-index: 80;
  display: inline-grid !important;
  place-items: center;
  border-color: var(--ink);
  background: var(--ink);
  color: var(--white);
  box-shadow: 0 12px 28px rgba(27, 35, 32, .2);
}

.home-page .eyebrow {
  color: var(--clay);
  font-size: .88rem;
  letter-spacing: 0;
  text-transform: none;
}

.home-page .button,
.home-page .nav-cta {
  box-shadow: 0 12px 28px rgba(27, 35, 32, .16);
}

.home-page .button.secondary {
  background: rgba(255, 250, 241, .58);
  color: var(--ink);
  border-color: rgba(27, 35, 32, .22);
  box-shadow: none;
  backdrop-filter: blur(14px);
}

.home-page .button.secondary:hover {
  border-color: var(--ink);
}

.ghost-light {
  border-color: rgba(255, 250, 241, .4);
  background: transparent;
  color: var(--white);
}

.ghost-light:hover {
  background: rgba(255, 250, 241, .12);
}

/* ── Landing Hero ── */
.landing-hero {
  position: relative;
  min-height: calc(100dvh - 78px);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-bottom: 1px solid rgba(27, 35, 32, .12);
  background:
    linear-gradient(120deg, rgba(244, 240, 231, .98) 0%, rgba(244, 240, 231, .9) 42%, rgba(159, 179, 181, .38) 100%),
    var(--paper);
  isolation: isolate;
}

.solar-veil {
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(105deg, transparent 0 18%, rgba(181, 59, 49, .13) 18% 24%, transparent 24% 31%, rgba(255, 250, 241, .7) 31% 40%, transparent 40% 100%);
  animation: solar-drift 12s cubic-bezier(.16, 1, .3, 1) infinite alternate;
  transform-origin: 50% 0;
}

@keyframes solar-drift {
  from { transform: translate3d(-1.5%, 0, 0) skewX(-2deg); }
  to { transform: translate3d(1.5%, 0, 0) skewX(2deg); }
}

.landing-hero-grid {
  width: min(100%, 1500px);
  margin: auto auto 0;
  padding: clamp(16px, 2.6vw, 42px) clamp(18px, 4vw, 58px) 10px;
  display: grid;
  grid-template-columns: minmax(360px, .86fr) minmax(500px, 1.14fr);
  gap: clamp(34px, 6vw, 94px);
  align-items: start;
}

.landing-hero-copy {
  position: relative;
  z-index: 2;
}

.landing-hero-copy h1 {
  max-width: 14.5ch;
  font-size: clamp(2.85rem, 4.7vw, 5.35rem);
  line-height: .98;
  text-wrap: balance;
}

.landing-hero-copy .lead {
  max-width: 47ch;
  margin: 1rem 0 1.15rem;
  color: #43504b;
}

.hero-composition {
  position: relative;
  min-height: clamp(390px, 43vw, 560px);
}

.hero-frame {
  position: absolute;
  margin: 0;
  overflow: hidden;
  border: 1px solid rgba(255, 250, 241, .64);
  background: var(--paper-strong);
  box-shadow: var(--shadow);
}

.hero-frame img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .6s cubic-bezier(.16, 1, .3, 1);
}

.hero-frame picture {
  display: block;
  width: 100%;
  height: 100%;
}

.hero-frame:hover img {
  transform: scale(1.045);
}

.hero-frame-main {
  inset: 0 0 12% 17%;
  border-radius: 6px 6px 70px 6px;
}

.hero-frame-left {
  left: 0;
  bottom: 0;
  width: 43%;
  height: 35%;
  border-radius: 60px 6px 6px 6px;
  transform: rotate(-3deg);
}

.hero-frame-bottom {
  right: 7%;
  bottom: -1%;
  width: 39%;
  height: 22%;
  border-radius: 6px 6px 6px 46px;
  transform: rotate(2deg);
}

.hero-seal {
  position: absolute;
  top: 9%;
  left: 5%;
  width: clamp(150px, 16vw, 220px);
  padding: 1.1rem 1.2rem;
  border: 1px solid rgba(255, 250, 241, .32);
  background: rgba(27, 35, 32, .82);
  color: var(--white);
  box-shadow: 0 26px 70px rgba(27, 35, 32, .28);
  backdrop-filter: blur(14px);
}

.hero-seal span {
  display: block;
  color: rgba(255, 250, 241, .66);
  font-size: .84rem;
  font-weight: 800;
}

.hero-seal strong {
  display: block;
  margin-top: .25rem;
  color: var(--white);
  font-size: clamp(1.25rem, 2.1vw, 2rem);
  line-height: 1.04;
}

.hero-proof-bar {
  width: min(100%, 1500px);
  margin: auto auto 0;
  padding: 0 clamp(18px, 4vw, 58px) clamp(14px, 2.3vw, 28px);
  display: grid;
  grid-template-columns: 1.15fr .92fr .92fr;
  gap: 1px;
}

.hero-proof-tile {
  position: relative;
  min-height: 112px;
  padding: clamp(15px, 2.2vw, 26px);
  display: grid;
  align-content: end;
  border: 1px solid rgba(27, 35, 32, .12);
  background: rgba(255, 250, 241, .62);
  backdrop-filter: blur(16px);
  transition: transform .24s cubic-bezier(.16, 1, .3, 1), background .24s ease;
}

.hero-proof-tile:hover {
  transform: translateY(-4px);
  background: rgba(255, 250, 241, .9);
}

.hero-proof-tile strong {
  color: var(--clay);
  font-size: clamp(2.1rem, 5vw, 4.8rem);
  line-height: .85;
}

.hero-proof-tile span {
  max-width: 14ch;
  margin-top: .55rem;
  color: var(--ink);
  font-size: clamp(1rem, 1.4vw, 1.35rem);
  font-weight: 800;
  line-height: 1.05;
}

.hero-proof-tile small {
  position: absolute;
  bottom: clamp(8px, 1.2vw, 14px);
  right: clamp(10px, 1.6vw, 18px);
  color: rgba(27, 35, 32, .48);
  font-size: .68rem;
  font-weight: 400;
  line-height: 1.2;
}

/* ── Proof Section ── */
.proof-section {
  position: relative;
  overflow: hidden;
  padding: clamp(76px, 11vw, 150px) 0 clamp(104px, 13vw, 184px);
  background:
    linear-gradient(180deg, rgba(34, 59, 49, .96), rgba(27, 35, 32, .98)),
    var(--forest);
  color: var(--white);
}

.proof-section::before {
  content: "REX";
  position: absolute;
  right: -4vw;
  top: -4vw;
  color: rgba(255, 250, 241, .04);
  font-size: clamp(9rem, 25vw, 26rem);
  font-weight: 900;
  line-height: .75;
}

.proof-layout {
  position: relative;
  display: grid;
  grid-template-columns: minmax(280px, .72fr) minmax(0, 1.28fr);
  column-gap: clamp(34px, 7vw, 92px);
  row-gap: clamp(54px, 7vw, 104px);
  align-items: center;
}

.proof-intro {
  position: sticky;
  top: 116px;
  align-self: center;
}

.proof-intro h2 {
  font-size: clamp(2.1rem, 3.4vw, 4.25rem);
}

.proof-section h2,
.proof-section h3,
.proof-section p {
  color: var(--white);
}

.proof-section .lead,
.proof-section p {
  color: rgba(255, 250, 241, .72);
}

.proof-ledger {
  display: grid;
  gap: 14px;
}

.proof-slab {
  min-height: 280px;
  padding: clamp(24px, 4vw, 48px);
  display: grid;
  align-content: space-between;
  border: 1px solid rgba(255, 250, 241, .16);
  background:
    linear-gradient(135deg, rgba(255, 250, 241, .08), rgba(255, 250, 241, .02)),
    rgba(255, 250, 241, .03);
  box-shadow: inset 0 1px 0 rgba(255, 250, 241, .08);
}

.proof-slab-large {
  min-height: 390px;
  grid-template-columns: .72fr 1fr;
  gap: clamp(18px, 4vw, 44px);
  align-items: end;
}

.proof-slab-red {
  position: relative;
  grid-template-columns: .35fr 1fr;
  gap: clamp(18px, 4vw, 42px);
  align-items: end;
  background:
    linear-gradient(135deg, rgba(181, 59, 49, .92), rgba(113, 36, 31, .78)),
    var(--clay);
}

.proof-slab-red small {
  position: absolute;
  bottom: clamp(8px, 1.2vw, 14px);
  right: clamp(10px, 1.6vw, 18px);
  color: rgba(255, 250, 241, .48);
  font-size: .68rem;
  font-weight: 400;
  line-height: 1.2;
}

.proof-stat {
  display: grid;
  justify-items: start;
  align-self: end;
}

.proof-over {
  display: block;
  margin: 0 0 1.35rem .2em;
  color: var(--white);
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 900;
  line-height: 1;
}

.proof-number {
  display: block;
  color: var(--white);
  font-size: clamp(6.8rem, 16vw, 15rem);
  font-weight: 900;
  line-height: .72;
  font-variant-numeric: tabular-nums;
}

.proof-word {
  display: block;
  color: rgba(255, 250, 241, .88);
  font-size: clamp(4rem, 11vw, 9rem);
  font-weight: 900;
  line-height: .82;
}

.proof-slab h3 {
  margin-bottom: .65rem;
  font-size: clamp(1.5rem, 3vw, 3rem);
}

/* ── Google Reviews ── */
.google-reviews {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(12px, 1.8vw, 22px);
}

.google-review {
  position: relative;
  margin: 0;
  min-height: 230px;
  padding: 2.7rem clamp(.9rem, 1.4vw, 1.15rem) 1.05rem;
  display: grid;
  align-content: space-between;
  gap: 1rem;
  overflow: hidden;
  border: 1px solid rgba(255, 250, 241, .64);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255, 250, 241, .96), rgba(236, 225, 207, .9)),
    var(--white);
  box-shadow: 0 18px 46px rgba(8, 15, 12, .22);
}

.google-review::before {
  content: "\201C";
  position: absolute;
  left: .82rem;
  top: .28rem;
  color: var(--clay);
  font-size: 4.7rem;
  font-weight: 900;
  line-height: 1;
  opacity: .9;
}

.google-review blockquote {
  position: relative;
  margin: 0;
}

.google-review p {
  margin: 0;
  color: var(--ink);
  font-size: clamp(.95rem, 1vw, 1.06rem);
  font-weight: 700;
  line-height: 1.4;
}

.review-person {
  position: relative;
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: .72rem;
  align-items: center;
}

.review-person img {
  display: block;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  object-fit: cover;
  background: var(--forest);
  box-shadow: 0 0 0 3px rgba(255, 250, 241, .92);
}

.review-person span {
  display: grid;
  gap: .1rem;
}

.review-person strong {
  color: var(--ink);
  font-size: .94rem;
  line-height: 1.15;
}

.review-person small {
  color: var(--clay);
  font-size: .74rem;
  font-weight: 900;
  line-height: 1.2;
}

.stars {
  color: var(--clay);
  letter-spacing: .06em;
  font-size: 1.05em;
}

/* ── Collection ── */
.collection-section {
  position: relative;
  padding: clamp(80px, 11vw, 160px) 0;
  overflow: hidden;
  border-block: 1px solid rgba(27, 35, 32, .1);
  background:
    linear-gradient(120deg, rgba(244, 240, 231, .98) 0%, rgba(244, 240, 231, .9) 45%, rgba(159, 179, 181, .28) 100%),
    var(--paper);
  isolation: isolate;
}

.collection-section::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    linear-gradient(108deg, transparent 0 16%, rgba(181, 59, 49, .11) 16% 21%, transparent 21% 32%, rgba(255, 250, 241, .62) 32% 41%, transparent 41% 100%);
}

.collection-heading {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: .64fr 1fr;
  gap: 34px;
  align-items: end;
  margin-bottom: clamp(34px, 6vw, 76px);
}

.collection-heading h2 {
  max-width: 14ch;
  font-size: clamp(2.7rem, 6vw, 6.4rem);
}

.collection-rail {
  position: relative;
  z-index: 1;
  width: min(100% - 36px, 1420px);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(14px, 2vw, 28px);
  align-items: stretch;
}

.showcase-card {
  position: relative;
  min-height: clamp(540px, 42vw, 640px);
  display: grid;
  align-content: end;
  overflow: hidden;
  padding: clamp(20px, 3vw, 34px);
  color: var(--white);
  background: var(--ink);
}

.showcase-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, transparent 24%, rgba(27, 35, 32, .78)),
    linear-gradient(105deg, rgba(181, 59, 49, .2), transparent 42%);
}

.showcase-card img {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .6s cubic-bezier(.16, 1, .3, 1);
}

.showcase-card picture {
  display: block;
  width: 100%;
  height: 100%;
}

.showcase-card:hover img {
  transform: scale(1.045);
}

.showcase-card span,
.showcase-card p {
  position: relative;
  z-index: 2;
}

.showcase-card span {
  display: block;
  max-width: 100%;
  margin-bottom: .65rem;
  color: var(--white);
  font-size: 2rem;
  font-weight: 900;
  line-height: .94;
  white-space: nowrap;
}

.showcase-card p {
  max-width: 24ch;
  color: rgba(255, 250, 241, .78);
}

.showcase-card-wide {
  border-radius: 6px 80px 6px 6px;
}

.showcase-card-tall {
  border-radius: 70px 6px 6px 6px;
}

.showcase-card:not(.showcase-card-wide):not(.showcase-card-tall) {
  border-radius: 6px 6px 70px 6px;
}

.showcase-card-zip {
  border-radius: 6px 70px 6px 6px;
}

/* ── Craft ── */
.craft-section {
  padding: clamp(78px, 11vw, 150px) 0;
  background:
    linear-gradient(90deg, rgba(159, 179, 181, .26), transparent 42%),
    var(--white);
}

.craft-grid {
  display: grid;
  grid-template-columns: minmax(280px, .72fr) minmax(0, 1.28fr);
  gap: clamp(34px, 7vw, 94px);
  align-items: center;
}

.craft-copy h2 {
  max-width: 12ch;
}

.craft-strip {
  display: grid;
  grid-template-columns: minmax(220px, .7fr) 1fr;
  gap: 1px;
  background: rgba(27, 35, 32, .16);
  border: 1px solid rgba(27, 35, 32, .16);
  box-shadow: var(--shadow);
}

.craft-strip figure {
  position: relative;
  min-height: 480px;
  margin: 0;
  overflow: hidden;
  background: var(--paper-strong);
}

.craft-strip img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.craft-strip figcaption {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 18px;
  padding: .8rem .9rem;
  background: rgba(255, 250, 241, .82);
  color: var(--ink);
  font-weight: 800;
  backdrop-filter: blur(12px);
}

.craft-strip ol {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  background: var(--white);
}

.craft-strip li {
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: clamp(16px, 3vw, 34px);
  align-items: center;
  padding: clamp(18px, 3vw, 36px);
  border-bottom: 1px solid rgba(27, 35, 32, .12);
  color: var(--ink);
  font-size: clamp(1.2rem, 2.6vw, 2rem);
  font-weight: 800;
  line-height: 1.08;
}

.craft-strip li:last-child {
  border-bottom: 0;
}

.craft-strip li span {
  color: var(--clay);
  font-size: 1rem;
  font-weight: 900;
  font-variant-numeric: tabular-nums;
}

/* ── Fabric Story ── */
.fabric-story {
  position: relative;
  min-height: 760px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 540px);
  align-items: end;
  gap: clamp(24px, 5vw, 70px);
  padding: clamp(34px, 6vw, 78px);
  overflow: hidden;
  background: var(--paper-strong);
}

.fabric-canvas {
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.fabric-canvas::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(244, 240, 231, .02) 0%, rgba(244, 240, 231, .08) 42%, rgba(244, 240, 231, .56) 76%, rgba(244, 240, 231, .72) 100%),
    linear-gradient(180deg, rgba(27, 35, 32, .02), rgba(27, 35, 32, .22));
}

.fabric-canvas img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center 48%;
  filter: saturate(1.08) contrast(1.08) brightness(1.02);
  transform: scale(1.06);
  transform-origin: center center;
  transition: transform .8s cubic-bezier(.16, 1, .3, 1);
}

.fabric-canvas:hover img {
  transform: scale(1.085);
}

.fabric-copy {
  position: relative;
  grid-column: 2;
  padding: clamp(24px, 4vw, 46px);
  border-left: 5px solid var(--clay);
  background: rgba(255, 250, 241, .84);
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px);
}

.fabric-copy h2 {
  font-size: clamp(2.1rem, 4vw, 4.4rem);
}

/* ── Home CTA ── */
.home-cta {
  padding: clamp(78px, 11vw, 150px) 0;
  background: var(--forest);
  color: var(--white);
}

.home-cta-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(300px, .7fr);
  gap: clamp(28px, 7vw, 90px);
  align-items: end;
}

.home-cta h2,
.home-cta p {
  color: var(--white);
}

.home-cta h2 {
  max-width: 13ch;
  font-size: clamp(2.6rem, 6vw, 6rem);
}

.home-cta p {
  color: rgba(255, 250, 241, .76);
  font-size: 1.18rem;
}

/* ── Content-visibility hints (perf) ── */
.proof-section,
.collection-section,
.craft-section,
.fabric-story,
.home-cta,
.footer {
  content-visibility: auto;
  contain-intrinsic-size: 900px;
}

/* ── Responsive ── */
@media (max-width: 1400px) {
  .home-page .brand-text {
    display: none;
  }

  .home-page .nav {
    padding-inline: 18px;
    gap: 10px;
  }

  .home-page .nav-menu {
    gap: 1px;
  }

  .home-page .nav-link,
  .home-page .dropdown-toggle {
    padding-inline: .5rem;
    font-size: .88rem;
  }

  .home-page .nav-cta {
    min-height: 42px;
    padding-inline: .82rem;
    font-size: .9rem;
  }
}

@media (min-width: 1321px) {
  .home-page .menu-button {
    display: none !important;
  }
}

@media (max-width: 1320px) {
  .home-page .nav {
    display: flex;
    justify-content: space-between;
    max-width: none;
  }

  .home-page .menu-button {
    display: inline-grid;
    margin-left: auto;
  }

  .home-page .nav-menu {
    position: fixed;
    inset: 78px 0 auto 0;
    display: none;
    padding: 20px 24px 28px;
    border-bottom: 1px solid var(--line);
    border-left: 1px solid rgba(27, 35, 32, .12);
    background: var(--paper);
    box-shadow: -18px 0 44px rgba(27, 35, 32, .16), 0 18px 36px rgba(27, 35, 32, .1);
  }

  .home-page.menu-open .nav-menu {
    display: grid;
    gap: 6px;
  }

  .home-page .nav-link,
  .home-page .dropdown-toggle,
  .home-page .nav-cta {
    width: 100%;
    justify-content: flex-start;
    border-radius: var(--radius);
  }

  .home-page .dropdown-menu {
    position: static;
    opacity: 1;
    pointer-events: auto;
    transform: none;
    box-shadow: none;
    margin: 4px 0 8px;
  }

  .home-page .dropdown {
    padding-bottom: 0;
    margin-bottom: 0;
  }
}

@media (max-width: 1280px) {
  .collection-rail {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1180px) {
  .collection-heading {
    grid-template-columns: 1fr;
  }

  .collection-heading h2 {
    max-width: 12ch;
    font-size: clamp(2.7rem, 7vw, 5.4rem);
  }
}

@media (max-width: 1080px) {
  .landing-hero-grid,
  .proof-layout,
  .craft-grid,
  .home-cta-grid {
    grid-template-columns: 1fr;
  }

  .landing-hero-grid {
    min-height: auto;
  }

  .proof-layout {
    align-items: start;
    row-gap: clamp(34px, 6vw, 62px);
  }

  .proof-intro {
    position: static;
    align-self: auto;
  }

  .google-reviews {
    grid-column: auto;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .collection-heading,
  .collection-rail {
    grid-template-columns: 1fr;
  }

  .showcase-card,
  .showcase-card-wide,
  .showcase-card-tall {
    min-height: 460px;
  }

  .fabric-story {
    min-height: 680px;
    grid-template-columns: 1fr;
    align-items: end;
  }

  .fabric-copy {
    grid-column: 1;
    max-width: 620px;
    margin-left: auto;
  }
}

@media (max-width: 760px) {
  .landing-hero {
    min-height: auto;
  }

  .landing-hero-grid {
    grid-template-columns: 1fr;
    padding-top: 34px;
    gap: 24px;
  }

  .landing-hero-copy h1 {
    max-width: 100%;
    font-size: clamp(2.7rem, 12vw, 4rem);
    line-height: 1;
  }

  .landing-hero-copy .lead {
    max-width: 100%;
    font-size: clamp(1rem, 4.4vw, 1.15rem);
  }

  .landing-hero .hero-actions {
    gap: .65rem;
  }

  .landing-hero .hero-actions .button {
    flex: 1 1 155px;
    min-width: 0;
    padding-inline: .9rem;
  }

  .hero-composition {
    min-height: 520px;
  }

  .hero-frame-main {
    inset: 0 0 21% 0;
    border-radius: 6px 6px 44px 6px;
  }

  .hero-frame-left {
    width: 54%;
    height: 28%;
  }

  .hero-frame-bottom {
    right: 0;
    width: 52%;
    height: 21%;
  }

  .hero-seal {
    top: 18px;
    left: 18px;
  }

  .hero-proof-bar {
    grid-template-columns: 1fr;
    padding-bottom: 18px;
  }

  .hero-proof-tile {
    min-height: 118px;
  }

  .proof-slab-large,
  .proof-slab-red {
    grid-template-columns: 1fr;
  }

  .proof-number {
    font-size: clamp(6rem, 34vw, 10rem);
  }

  .proof-word {
    font-size: clamp(4rem, 22vw, 7rem);
  }

  .google-reviews {
    grid-template-columns: 1fr;
  }

  .google-review {
    min-height: 0;
  }

  .collection-rail {
    width: calc(100% - 32px);
  }

  .showcase-card,
  .showcase-card-wide,
  .showcase-card-tall {
    min-height: 390px;
    border-radius: 6px 6px 42px 6px;
  }

  .craft-strip {
    grid-template-columns: 1fr;
  }

  .craft-strip figure {
    min-height: 320px;
  }

  .craft-strip li {
    grid-template-columns: 48px 1fr;
  }

  .fabric-story {
    min-height: 640px;
    padding: 18px;
  }

  .fabric-canvas::after {
    background:
      linear-gradient(180deg, rgba(244, 240, 231, .04) 0%, rgba(244, 240, 231, .2) 42%, rgba(244, 240, 231, .8) 76%),
      linear-gradient(180deg, rgba(27, 35, 32, .02), rgba(27, 35, 32, .22));
  }

  .fabric-canvas img {
    object-position: 45% center;
  }

  .fabric-copy {
    padding: 22px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .solar-veil {
    animation: none;
  }

  .hero-frame img,
  .showcase-card img,
  .fabric-canvas img {
    transition: none;
  }
}
