/* ==========================================================================
   Fabric Theme — Main Stylesheet
   ========================================================================== */

/* ─── 0. Custom Font: Modern Script ─────────────────────────────────────── */
@font-face {
  font-family: 'Modern Script';
  src: url('../fonts/modern-script.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

/* ─── 1. CSS Custom Properties (Design Tokens) ─────────────────────────── */
:root {
  /* Colors */
  --color-primary: #1a1a1a;
  --color-bg: #ffffff;
  --color-surface: #f7f5f2;
  --color-muted: #888888;
  --color-border: #e8e8e8;
  --color-accent: var(--color-gold, #c5a572);
  --color-footer-bg: #1a1a1a;
  --color-footer-text: #ffffff;

  /* Typography — Modern Script reserved for logo only */
  --font-heading: Georgia, 'Times New Roman', serif;
  --font-body: Arial, Helvetica, sans-serif;
  --font-script: 'Modern Script', cursive;
  --font-size-base: 15px;

  /* Spacing */
  --spacing-page-x: 48px;
  --spacing-section-y: 64px;
  --spacing-border: 1px solid var(--color-border);

  /* Transitions */
  --transition: 0.2s ease;
}

/* ─── 2. Base / Reset ───────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html {
  font-size: var(--font-size-base);
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-body);
  font-size: var(--font-size-base);
  color: var(--color-primary);
  background: var(--color-bg);
  line-height: 1.6;
  margin: 0;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  font-weight: 400;
  letter-spacing: -0.03em;
  line-height: 1.1;
  margin: 0;
}

a {
  text-decoration: none;
  color: inherit;
}

ul, ol {
  list-style: none;
  margin: 0;
  padding: 0;
}

img { max-width: 100%; display: block; }

button { cursor: pointer; }

p { margin: 0; }

.container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 var(--spacing-page-x);
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ─── 3. Announcement Bar ──────────────────────────────────────────────── */
.fabric-announce-bar {
  text-align: center;
  padding: 10px var(--spacing-page-x);
}
.fabric-announce-bar__text {
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #ffffff;
  margin: 0;
}

/* ─── 4. Header ─────────────────────────────────────────────────────────── */
.fabric-header {
  position: relative;
  background: var(--color-bg);
  border-top: 2px solid var(--color-gold, #c5a572);
  border-bottom: var(--spacing-border);
  z-index: 100;
}
.fabric-header--sticky {
  position: sticky;
  top: 0;
}
/* Account for WordPress admin bar when logged in as admin */
.admin-bar .fabric-header--sticky {
  top: 32px;
}
@media screen and (max-width: 782px) {
  .admin-bar .fabric-header--sticky {
    top: 46px;
  }
}
/* Consistent top spacing for all main content areas */
.fabric-main {
  min-height: 50vh;
}
.fabric-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px var(--spacing-page-x);
  gap: 32px;
}
.fabric-header--logo-center .fabric-header__inner {
  position: relative;
}
.fabric-header--logo-center .fabric-header__logo {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}
.fabric-header__logo a,
.fabric-header__site-name {
  font-family: var(--font-body);
  font-size: 24px;
  font-weight: 700;
  letter-spacing: 4px;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--color-gold, #c5a572);
}
.fabric-header__logo img { height: 60px; width: auto; }
.fabric-header__nav { flex: 1; display: flex; justify-content: center; }
.fabric-nav__list { display: flex; gap: 32px; align-items: center; }
.fabric-nav__list li { position: relative; }
.fabric-nav__list > li > a {
  font-family: var(--font-body);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--color-muted);
  transition: color var(--transition);
  padding: 4px 0;
}
.fabric-nav__list > li > a:hover,
.fabric-nav__list > li.current-menu-item > a { color: var(--color-primary); }

/* Dropdown */
.fabric-nav__list li ul {
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 180px;
  background: var(--color-bg);
  border: var(--spacing-border);
  padding: 8px 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(4px);
  transition: opacity var(--transition), transform var(--transition), visibility var(--transition);
  z-index: 200;
}
.fabric-nav__list li:hover > ul,
.fabric-nav__list li:focus-within > ul {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.fabric-nav__list li ul li a {
  display: block;
  padding: 8px 16px;
  font-size: 11px;
  letter-spacing: 1px;
  color: var(--color-muted);
  transition: color var(--transition), background var(--transition);
}
.fabric-nav__list li ul li a:hover { color: var(--color-primary); background: var(--color-surface); }

/* Fallback nav styles for wp_list_pages() output (page_item) and standard menu items */
.fabric-nav__list .page_item > a,
.fabric-nav__list .menu-item > a {
  display: block;
  padding: 0 4px;
  font-family: var(--font-body);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--color-primary);
  text-decoration: none;
  transition: opacity var(--transition);
}
.fabric-nav__list .page_item > a:hover,
.fabric-nav__list .menu-item > a:hover { opacity: 0.5; }

.fabric-mobile-nav__list .page_item > a,
.fabric-mobile-nav__list .menu-item > a {
  display: block;
  padding: 14px 0;
  font-family: var(--font-body);
  font-size: 13px;
  letter-spacing: 1px;
  text-transform: uppercase;
  border-bottom: 1px solid var(--color-border);
}

.fabric-header__actions { display: flex; align-items: center; gap: 16px; }
.fabric-header__action-btn {
  background: none;
  border: none;
  padding: 4px;
  color: var(--color-primary);
  display: flex;
  align-items: center;
  gap: 4px;
  transition: opacity var(--transition);
  text-decoration: none;
  position: relative;
}
.fabric-header__action-btn:hover { opacity: 0.6; }
.fabric-cart-count {
  font-size: 10px;
  font-weight: 700;
  min-width: 16px;
  height: 16px;
  background: var(--color-gold, #c5a572);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: -6px;
  right: -6px;
}
.fabric-header__hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  padding: 4px;
  width: 28px;
}
.fabric-header__hamburger span {
  display: block;
  height: 1.5px;
  background: var(--color-primary);
  transition: transform var(--transition), opacity var(--transition);
}
.fabric-header__hamburger[aria-expanded="true"] span:nth-child(1) { transform: rotate(45deg) translate(4.5px, 4.5px); }
.fabric-header__hamburger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.fabric-header__hamburger[aria-expanded="true"] span:nth-child(3) { transform: rotate(-45deg) translate(4.5px, -4.5px); }

/* Search bar */
.fabric-search-bar {
  border-top: var(--spacing-border);
  padding: 16px var(--spacing-page-x);
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--color-bg);
}
.fabric-search-bar[hidden] { display: none; }
.fabric-search-bar form { display: flex; flex: 1; gap: 0; max-width: 600px; margin: 0 auto; }
.fabric-search-bar input {
  flex: 1;
  border: 1px solid var(--color-primary);
  padding: 12px 16px;
  font-family: var(--font-body);
  font-size: 13px;
  outline: none;
  border-right: none;
}
.fabric-search-bar button[type="submit"] {
  background: var(--color-primary);
  color: #fff;
  border: none;
  padding: 12px 20px;
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
}
.fabric-search-bar__close {
  background: none;
  border: none;
  font-size: 18px;
  color: var(--color-muted);
  padding: 4px;
  margin-left: auto;
}

/* Mobile nav */
.fabric-mobile-nav {
  position: fixed;
  top: 0;
  left: 0;
  width: 85%;
  max-width: 320px;
  height: 100vh;
  background: var(--color-bg);
  border-right: var(--spacing-border);
  padding: 80px 32px 32px;
  z-index: 300;
  overflow-y: auto;
  transform: translateX(-100%);
  transition: transform 0.3s ease;
}
.fabric-mobile-nav:not([hidden]) { transform: translateX(0); }
.fabric-mobile-nav[hidden] { display: none !important; }
@media (min-width: 901px) {
  .fabric-mobile-nav, .fabric-mobile-overlay { display: none !important; }
}
.fabric-mobile-nav__list { display: flex; flex-direction: column; gap: 0; }
.fabric-mobile-nav__list li a {
  display: block;
  padding: 14px 0;
  font-family: var(--font-body);
  font-size: 13px;
  letter-spacing: 1px;
  text-transform: uppercase;
  border-bottom: var(--spacing-border);
  color: var(--color-primary);
}
.fabric-mobile-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.4);
  z-index: 299;
}
.fabric-mobile-overlay.is-active { display: block; }

/* Sticky header shadow on scroll */
.fabric-header--sticky.is-scrolled {
  box-shadow: 0 1px 16px rgba(0,0,0,0.06);
}

/* ─── 5. Buttons ─────────────────────────────────────────────────────────── */
.btn, .button, input[type="submit"] {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  padding: 14px 32px;
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: opacity var(--transition), background var(--transition), color var(--transition);
}
.btn--primary, .button:not(.btn--ghost) {
  background: var(--color-accent);
  color: #fff;
}
.btn--primary:hover, .button:not(.btn--ghost):hover { opacity: 0.85; }
.btn--ghost {
  background: transparent;
  color: var(--color-primary);
  border: 1px solid var(--color-primary);
}
.btn--ghost:hover { background: var(--color-primary); color: #fff; }
.btn--full { display: block; width: 100%; text-align: center; }

/* ─── 6. Breadcrumb ──────────────────────────────────────────────────────── */
.fabric-breadcrumb {
  padding: 14px var(--spacing-page-x);
  font-family: var(--font-body);
  font-size: 11px;
  color: var(--color-muted);
  letter-spacing: 1px;
  border-bottom: var(--spacing-border);
}
.fabric-breadcrumb a { color: var(--color-muted); transition: color var(--transition); }
.fabric-breadcrumb a:hover { color: var(--color-primary); }
.fabric-breadcrumb span.current { color: var(--color-primary); }

/* ─── 7. Homepage Sections ───────────────────────────────────────────────── */

/* Hero */
.fabric-hero {
  padding: 48px var(--spacing-page-x) 60px;
  border-bottom: var(--spacing-border);
  overflow: hidden;
}

.fabric-hero__inner {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 40px;
}
/* Hero with no image — add subtle surface background */
.fabric-hero:not(.fabric-hero--video):not(.fabric-hero--slideshow) .fabric-hero__inner:only-child {
  justify-content: flex-start;
}

/* Text / left column */
.fabric-hero__content,
.fabric-hero__text { flex: 1; max-width: 560px; }

.fabric-hero__eyebrow {
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 20px;
}

.fabric-hero__title {
  font-size: clamp(42px, 6vw, 72px);
  font-weight: 400;
  letter-spacing: -0.03em;
  line-height: 1.0;
  margin-bottom: 24px;
}

.fabric-hero__subtitle,
.fabric-hero__sub {
  font-size: 13px;
  color: #555;
  line-height: 1.7;
  max-width: 380px;
  margin-bottom: 32px;
}

/* CTA buttons row */
.fabric-hero__buttons,
.fabric-hero__actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

/* Make hero buttons auto-width (not full-width) */
.fabric-hero__buttons .btn,
.fabric-hero__actions .btn {
  display: inline-flex;
  width: auto;
}

/* Images / right column */
.fabric-hero__images {
  display: flex;
  gap: 12px;
  align-items: flex-end;
  flex-shrink: 0;
}
.fabric-hero__img-wrap { overflow: hidden; flex-shrink: 0; }
.fabric-hero__img-wrap--1 { width: 200px; height: 280px; }
.fabric-hero__img-wrap--2 { width: 160px; height: 220px; }
.fabric-hero__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}
.fabric-hero__img-wrap:hover .fabric-hero__img { transform: scale(1.03); }
/* Legacy aliases */
.fabric-hero__img--tall { width: 200px; height: 280px; overflow: hidden; }
.fabric-hero__img--short { width: 160px; height: 220px; overflow: hidden; }

/* Hero — video background */
.fabric-hero--video,
.fabric-hero--slideshow {
  position: relative;
  min-height: 85vh;
  display: flex;
  align-items: center;
}

.fabric-hero__video-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}

.fabric-hero__video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.fabric-hero__video-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
}

/* Hero — slideshow */
.fabric-hero__slideshow {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}

.fabric-hero__slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 0.8s ease;
}

.fabric-hero__slide.is-active {
  opacity: 1;
}

.fabric-hero__slide-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.fabric-hero__slide-dots {
  position: absolute;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  z-index: 2;
}

.fabric-hero__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  border: none;
  background: rgba(255, 255, 255, 0.5);
  cursor: pointer;
  padding: 0;
  transition: background 0.3s;
}

.fabric-hero__dot.is-active {
  background: #fff;
}

/* Hero inner — when video/slideshow is behind */
.fabric-hero__inner--overlay {
  position: relative;
  z-index: 1;
  color: #fff;
}

.fabric-hero__inner--overlay .fabric-hero__eyebrow,
.fabric-hero__inner--overlay .fabric-hero__title,
.fabric-hero__inner--overlay .fabric-hero__subtitle {
  color: #fff;
}

/* White button variant for video/slideshow hero */
.btn--white {
  background: #fff;
  color: #1a1a1a;
  border-color: #fff;
}

.btn--white:hover {
  background: transparent;
  color: #fff;
}

.btn--ghost-white {
  border-color: rgba(255, 255, 255, 0.7);
  color: #fff;
}

.btn--ghost-white:hover {
  background: rgba(255, 255, 255, 0.15);
  border-color: #fff;
}

/* Marquee */
.fabric-marquee {
  border-top: var(--spacing-border);
  border-bottom: var(--spacing-border);
  padding: 14px 0;
  overflow: hidden;
  white-space: nowrap;
}
.fabric-marquee__inner {
  display: inline-flex;
  gap: 0;
  animation: fabric-marquee-scroll 25s linear infinite;
}
.fabric-marquee__item {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--color-muted);
  padding: 0 40px;
}
@keyframes fabric-marquee-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* Category Split */
.fabric-category-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 460px;
  border-bottom: var(--spacing-border);
}
.fabric-cat-block {
  position: relative;
  display: flex;
  align-items: flex-end;
  padding: 48px;
  overflow: hidden;
  cursor: pointer;
  text-decoration: none;
}
.fabric-cat-block--light { background: var(--color-surface); border-right: var(--spacing-border); }
.fabric-cat-block--dark  { background: var(--color-primary); }
.fabric-cat-block__bg-img {
  position: absolute;
  inset: 0;
  object-fit: cover;
  width: 100%;
  height: 100%;
  opacity: 0.15;
  transition: opacity 0.4s ease, transform 0.6s ease;
}
.fabric-cat-block:hover .fabric-cat-block__bg-img { opacity: 0.25; transform: scale(1.04); }
.fabric-cat-block__label { position: relative; z-index: 1; }
.fabric-cat-block__eyebrow {
  font-family: var(--font-body);
  font-size: 9px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 10px;
}
.fabric-cat-block--dark .fabric-cat-block__eyebrow { color: #888; }
.fabric-cat-block__title {
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 400;
  letter-spacing: -0.02em;
  margin-bottom: 16px;
  line-height: 1.15;
}
.fabric-cat-block--light .fabric-cat-block__title { color: var(--color-primary); }
.fabric-cat-block--dark  .fabric-cat-block__title { color: #fff; }
.fabric-cat-block__arrow {
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: gap var(--transition);
}
.fabric-cat-block:hover .fabric-cat-block__arrow { gap: 16px; }
.fabric-cat-block--light .fabric-cat-block__arrow { color: var(--color-primary); }
.fabric-cat-block--dark  .fabric-cat-block__arrow { color: #fff; }
.fabric-cat-block__bg-text {
  position: absolute;
  top: 16px;
  right: 16px;
  font-size: 90px;
  font-weight: 700;
  opacity: 0.04;
  font-family: var(--font-body);
  letter-spacing: -4px;
  pointer-events: none;
  line-height: 1;
}
.fabric-cat-block--light .fabric-cat-block__bg-text { color: var(--color-primary); }
.fabric-cat-block--dark  .fabric-cat-block__bg-text { color: #fff; }

/* Section shared styles */
.fabric-section { padding: var(--spacing-section-y) var(--spacing-page-x); }
.fabric-section--surface { background: var(--color-surface); }
.fabric-section__header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 40px;
}
.fabric-section__title {
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 400;
  letter-spacing: -0.02em;
}
.fabric-section__link {
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--color-muted);
  border-bottom: 1px solid var(--color-border);
  padding-bottom: 2px;
  transition: color var(--transition), border-color var(--transition);
}
.fabric-section__link:hover { color: var(--color-primary); border-color: var(--color-primary); }

/* Product grid + card */
.fabric-product-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.fabric-product-card { display: flex; flex-direction: column; }
.fabric-product-card__img-wrap {
  position: relative;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  background: var(--color-surface);
  margin-bottom: 14px;
}
.fabric-product-card__img-wrap img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.5s ease;
}
.fabric-product-card:hover .fabric-product-card__img-wrap img { transform: scale(1.04); }
.fabric-product-card__badge {
  position: absolute;
  top: 12px;
  left: 12px;
  background: var(--color-primary);
  color: #fff;
  font-family: var(--font-body);
  font-size: 8px;
  letter-spacing: 2px;
  text-transform: uppercase;
  padding: 4px 8px;
}
.fabric-product-card__name {
  font-size: 14px;
  font-weight: 400;
  margin-bottom: 4px;
  line-height: 1.3;
}
.fabric-product-card__type {
  font-family: var(--font-body);
  font-size: 10px;
  color: var(--color-muted);
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.fabric-product-card__price {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
}
.fabric-product-card__price .per {
  font-weight: 400;
  color: var(--color-muted);
  font-size: 11px;
}
.fabric-product-card__swatches {
  display: flex;
  gap: 6px;
  margin-top: 8px;
}
.fabric-swatch-dot {
  width: 16px; height: 16px;
  border-radius: 50%;
  border: 1.5px solid transparent;
  cursor: pointer;
  transition: border-color var(--transition);
}
.fabric-swatch-dot.is-active,
.fabric-swatch-dot:hover { border-color: var(--color-primary); }

/* Brand story */
.fabric-brand-story {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
  padding: var(--spacing-section-y) var(--spacing-page-x);
  border-top: var(--spacing-border);
}
.fabric-brand-story__img { overflow: hidden; }
.fabric-brand-story__img img { width: 100%; aspect-ratio: 3/4; object-fit: cover; }
.fabric-brand-story__eyebrow {
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 20px;
}
.fabric-brand-story__title {
  font-size: clamp(32px, 3.5vw, 46px);
  font-weight: 400;
  letter-spacing: -0.03em;
  line-height: 1.1;
  margin-bottom: 24px;
}
.fabric-brand-story__body {
  font-size: 13px;
  color: #555;
  line-height: 1.8;
  margin-bottom: 32px;
}

/* Testimonials */
.fabric-testimonials { text-align: center; }
.fabric-testimonials__title {
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 400;
  letter-spacing: -0.02em;
  margin-bottom: 40px;
}
.fabric-testimonials__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  text-align: left;
}
.fabric-testimonial-card {
  background: var(--color-bg);
  padding: 32px;
}
.fabric-testimonial-card__stars {
  font-size: 13px;
  margin-bottom: 14px;
  color: var(--color-primary);
  letter-spacing: 3px;
}
.fabric-testimonial-card__quote {
  font-size: 14px;
  line-height: 1.7;
  margin-bottom: 16px;
  color: #333;
  font-style: italic;
}
.fabric-testimonial-card__author {
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--color-muted);
}

/* Newsletter */
.fabric-newsletter {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
  border-top: var(--spacing-border);
  flex-wrap: wrap;
}
.fabric-newsletter__title {
  font-size: clamp(24px, 3vw, 36px);
  font-weight: 400;
  letter-spacing: -0.02em;
  margin-bottom: 6px;
}
.fabric-newsletter__sub {
  font-size: 13px;
  color: var(--color-muted);
}
.fabric-newsletter__form {
  display: flex;
  gap: 0;
  flex-shrink: 0;
}
.fabric-newsletter__input {
  border: 1px solid var(--color-primary);
  padding: 14px 20px;
  font-size: 12px;
  font-family: var(--font-body);
  width: 280px;
  outline: none;
  border-right: none;
}
.fabric-newsletter__btn {
  background: var(--color-primary);
  color: #fff;
  border: none;
  padding: 14px 24px;
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
}
.fabric-newsletter__message { margin-top: 8px; font-size: 12px; }
.fabric-newsletter__message--success { color: #2d7a2d; }
.fabric-newsletter__message--error { color: #c0392b; }

/* ─── 8. Footer ─────────────────────────────────────────────────────────── */
.fabric-footer {
  background: var(--color-footer-bg);
  color: var(--color-footer-text);
}
.fabric-footer__inner { padding: 60px var(--spacing-page-x) 32px; }
.fabric-footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 48px;
  margin-bottom: 48px;
}
.fabric-footer__brand .custom-logo { height: 32px; width: auto; filter: brightness(0) invert(1); }
.fabric-footer__brand .fabric-header__site-name {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: #fff;
  margin-bottom: 16px;
  display: block;
}
.fabric-footer__desc {
  font-family: var(--font-body);
  font-size: 12px;
  color: #888;
  line-height: 1.7;
  margin: 12px 0 20px;
}
.fabric-footer__social { display: flex; gap: 16px; }
.fabric-footer__social a { color: #888; transition: color var(--transition); }
.fabric-footer__social a:hover { color: #fff; }
.fabric-footer__col-heading {
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: #888;
  margin-bottom: 20px;
}
.fabric-footer__col ul { display: flex; flex-direction: column; gap: 10px; }
.fabric-footer__col ul li {
  font-family: var(--font-body);
  font-size: 12px;
  color: #ccc;
  cursor: pointer;
  transition: color var(--transition);
}
.fabric-footer__col ul li:hover { color: #fff; }
.fabric-footer__bottom {
  border-top: 1px solid #333;
  padding-top: 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--font-body);
  font-size: 11px;
  color: #555;
  flex-wrap: wrap;
  gap: 12px;
}
.fabric-footer__bottom a { color: #555; transition: color var(--transition); }
.fabric-footer__bottom a:hover { color: #888; }

/* ─── 9. Blog Styles ─────────────────────────────────────────────────────── */

/* Blog archive */
.fabric-blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  padding: var(--spacing-section-y) var(--spacing-page-x);
}
.fabric-blog-card__img {
  aspect-ratio: 16/10;
  overflow: hidden;
  margin-bottom: 16px;
}
.fabric-blog-card__img img { width:100%; height:100%; object-fit:cover; transition: transform 0.4s ease; }
.fabric-blog-card:hover .fabric-blog-card__img img { transform: scale(1.04); }
.fabric-blog-card__cat {
  font-family: var(--font-body);
  font-size: 9px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 8px;
}
.fabric-blog-card__title { font-size: 18px; font-weight: 400; margin-bottom: 8px; line-height: 1.3; }
.fabric-blog-card__title a { text-decoration: none; }
.fabric-blog-card__excerpt { font-size: 12px; color: #555; line-height: 1.7; margin-bottom: 12px; }
.fabric-blog-card__date { font-family: var(--font-body); font-size: 10px; color: var(--color-muted); letter-spacing: 1px; }

/* Single post */
.fabric-post { max-width: 760px; margin: 0 auto; padding: var(--spacing-section-y) var(--spacing-page-x); }
.fabric-post__header { margin-bottom: 40px; }
.fabric-post__cat { font-family: var(--font-body); font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--color-muted); margin-bottom: 12px; }
.fabric-post__title { font-size: clamp(32px, 4vw, 52px); font-weight: 400; letter-spacing: -0.03em; margin-bottom: 16px; }
.fabric-post__meta { font-family: var(--font-body); font-size: 11px; color: var(--color-muted); }
.fabric-post__featured-img { margin-bottom: 40px; }
.fabric-post__featured-img img { width: 100%; aspect-ratio: 16/9; object-fit: cover; }
.fabric-post__content { font-size: 15px; line-height: 1.9; }
.fabric-post__content p { margin-bottom: 1.5em; }
.fabric-post__content h2 { font-size: 28px; margin: 2em 0 0.8em; }
.fabric-post__content h3 { font-size: 22px; margin: 1.8em 0 0.6em; }
.fabric-post__content blockquote { border-left: 3px solid var(--color-primary); margin: 2em 0; padding: 16px 24px; background: var(--color-surface); font-style: italic; font-size: 18px; }
.fabric-post__content figcaption { font-size: 11px; color: var(--color-muted); text-align: center; margin-top: 6px; letter-spacing: 1px; }
.fabric-post__content > p:first-child::first-letter { font-size: 4em; float: left; line-height: 0.8; margin: 0.05em 0.08em 0 0; font-family: var(--font-heading); }
.fabric-author-box { border-top: var(--spacing-border); padding-top: 32px; margin-top: 48px; display: flex; gap: 20px; align-items: flex-start; }
.fabric-author-box__avatar img { width: 64px; height: 64px; border-radius: 50%; object-fit: cover; }
.fabric-author-box__name { font-weight: 600; margin-bottom: 6px; }
.fabric-author-box__bio { font-size: 13px; color: #555; line-height: 1.6; }
.fabric-reading-progress { position: fixed; top: 0; left: 0; height: 2px; background: var(--color-primary); width: 0%; z-index: 9999; transition: width 0.1s linear; }

/* ─── 10. Page Layouts ───────────────────────────────────────────────────── */
/* (Old hero rules removed — see unified hero block at end of file) */

/* About values grid */
.fabric-values-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
  padding: var(--spacing-section-y) var(--spacing-page-x);
  border-top: var(--spacing-border);
}
.fabric-value-item__icon { font-size: 28px; margin-bottom: 16px; }
.fabric-value-item__title { font-size: 18px; font-weight: 400; margin-bottom: 10px; }
.fabric-value-item__text { font-size: 13px; color: #555; line-height: 1.7; }

/* Contact */
.fabric-contact-layout {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: 64px;
  padding: var(--spacing-section-y) var(--spacing-page-x);
}
.fabric-contact-form input,
.fabric-contact-form textarea,
.fabric-contact-form select {
  width: 100%;
  border: 1px solid var(--color-border);
  padding: 12px 16px;
  font-family: var(--font-body);
  font-size: 13px;
  margin-bottom: 16px;
  outline: none;
  transition: border-color var(--transition);
}
.fabric-contact-form input:focus,
.fabric-contact-form textarea:focus { border-color: var(--color-primary); }
.fabric-contact-form textarea { height: 160px; resize: vertical; }
.fabric-contact-info__item { margin-bottom: 24px; }
.fabric-contact-info__label { font-family: var(--font-body); font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--color-muted); margin-bottom: 6px; }
.fabric-contact-info__value { font-size: 13px; line-height: 1.6; }

/* FAQ */
.fabric-faq-container { padding: var(--spacing-section-y) var(--spacing-page-x); max-width: 800px; margin: 0 auto; }
.fabric-faq-group { margin-bottom: 40px; }
.fabric-faq-group__title { font-family: var(--font-body); font-size: 10px; letter-spacing: 3px; text-transform: uppercase; color: var(--color-muted); margin-bottom: 16px; padding-bottom: 10px; border-bottom: var(--spacing-border); }
.fabric-accordion-item { border-bottom: var(--spacing-border); }
.fabric-accordion-item__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 18px 0;
  cursor: pointer;
  font-size: 15px;
  font-weight: 400;
  background: none;
  border: none;
  width: 100%;
  text-align: left;
  color: var(--color-primary);
}
.fabric-accordion-item__icon { font-size: 20px; color: var(--color-muted); transition: transform var(--transition); flex-shrink: 0; }
.fabric-accordion-item__header[aria-expanded="true"] .fabric-accordion-item__icon { transform: rotate(45deg); }
.fabric-accordion-item__body { overflow: hidden; max-height: 0; transition: max-height 0.3s ease; }
.fabric-accordion-item__body.is-open { max-height: 400px; }
.fabric-accordion-item__content { padding: 0 0 18px; font-size: 13px; color: #555; line-height: 1.8; }

/* Wishlist */
.fabric-wishlist-container { padding: var(--spacing-section-y) var(--spacing-page-x); }
.fabric-wishlist-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.fabric-wishlist-empty { text-align: center; padding: 80px 0; }
.fabric-wishlist-empty__title { font-size: 28px; font-weight: 400; margin-bottom: 12px; }
.fabric-wishlist-empty__sub { font-size: 13px; color: var(--color-muted); margin-bottom: 32px; }
.fabric-wishlist-card { position: relative; }
.fabric-wishlist-card__remove {
  position: absolute;
  top: 10px;
  right: 10px;
  background: #fff;
  border: var(--spacing-border);
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  cursor: pointer;
  z-index: 1;
}

/* 404 */
.fabric-404 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 60vh;
  text-align: center;
  padding: var(--spacing-section-y) var(--spacing-page-x);
}
.fabric-404__number { font-size: clamp(80px, 15vw, 160px); font-weight: 400; letter-spacing: -0.05em; color: var(--color-surface); line-height: 1; margin-bottom: 16px; }
.fabric-404__title { font-size: 28px; font-weight: 400; margin-bottom: 12px; }
.fabric-404__sub { font-size: 13px; color: var(--color-muted); margin-bottom: 32px; }

/* Pagination */
.fabric-pagination { display: flex; justify-content: center; gap: 4px; padding: 32px var(--spacing-page-x); }
.fabric-pagination a,
.fabric-pagination span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: var(--spacing-border);
  font-family: var(--font-body);
  font-size: 12px;
  transition: background var(--transition), color var(--transition);
}
.fabric-pagination a:hover,
.fabric-pagination .current {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
}

/* ─── 11. Responsive ─────────────────────────────────────────────────────── */
@media (max-width: 1024px) {
  :root {
    --spacing-page-x: 32px;
    --spacing-section-y: 48px;
  }

  .fabric-product-grid { grid-template-columns: repeat(3, 1fr); }
  .fabric-footer__grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 768px) {
  :root {
    --spacing-page-x: 20px;
    --spacing-section-y: 40px;
  }

  .fabric-header__nav { display: none; }
  .fabric-header__hamburger { display: flex; }

  .fabric-hero {
    flex-direction: column;
    align-items: flex-start;
    padding-top: 48px;
  }
  .fabric-hero__images { width: 100%; }
  .fabric-hero__img--tall { flex: 1; height: 220px; }
  .fabric-hero__img--short { flex: 1; height: 180px; }

  .fabric-category-split { grid-template-columns: 1fr; }
  .fabric-cat-block--light { border-right: none; border-bottom: var(--spacing-border); }

  .fabric-product-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .fabric-wishlist-grid { grid-template-columns: repeat(2, 1fr); }

  .fabric-brand-story { grid-template-columns: 1fr; gap: 40px; }

  .fabric-testimonials__grid { grid-template-columns: 1fr; }

  .fabric-newsletter { flex-direction: column; align-items: flex-start; }
  .fabric-newsletter__form { flex-direction: column; width: 100%; }
  .fabric-newsletter__input { width: 100%; border-right: 1px solid var(--color-primary); border-bottom: none; }

  .fabric-footer__grid { grid-template-columns: 1fr; }

  .fabric-blog-grid { grid-template-columns: 1fr; }

  .fabric-contact-layout { grid-template-columns: 1fr; }

  .fabric-values-grid { grid-template-columns: 1fr; gap: 24px; }

  .fabric-post { padding: var(--spacing-section-y) var(--spacing-page-x); }

}

@media (max-width: 480px) {
  .fabric-product-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
  .fabric-wishlist-grid { grid-template-columns: 1fr 1fr; }
  .fabric-hero__actions { flex-direction: column; }
}

/* ─── Mobile nav close button ────────────────────────────────────────────── */
.fabric-mobile-nav__close {
  position: absolute;
  top: 16px;
  right: 16px;
  background: none;
  border: none;
  font-size: 20px;
  cursor: pointer;
  color: var(--color-primary);
  line-height: 1;
  padding: 4px 8px;
}


/* ─── Quantity +/- wrapper ───────────────────────────────────────────────── */
.fabric-qty-wrap {
  display: flex;
  align-items: stretch;
  gap: 0;
  margin-bottom: 0;
}

.fabric-qty-btn {
  width: 44px;
  height: 44px;
  background: var(--color-primary);
  color: #fff;
  border: none;
  font-size: 20px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.fabric-qty-btn:hover {
  opacity: 0.85;
}

.fabric-qty-wrap .quantity {
  flex: 1;
}

.fabric-qty-wrap .quantity input.qty {
  width: 100%;
  height: 44px;
  border: 1px solid var(--color-border);
  border-left: none;
  border-right: none;
  text-align: center;
  font-family: var(--font-heading);
  font-size: 16px;
  background: #fff;
  -moz-appearance: textfield;
}

.fabric-qty-wrap .quantity input.qty::-webkit-outer-spin-button,
.fabric-qty-wrap .quantity input.qty::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* ─── Search section title ───────────────────────────────────────────────── */
.fabric-search-section-title {
  font-size: 20px;
  font-weight: 400;
  letter-spacing: -0.5px;
  margin-bottom: 24px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--color-border);
}

/* ─── Tablet (768–1199px) ────────────────────────────────────────────────── */
@media (max-width: 1199px) {
  .container { padding: 0 24px; }

  /* Header */
  .fabric-header__nav { display: none; }
  .fabric-header__hamburger { display: flex; }

  /* Hero */
  .fabric-hero__inner { flex-direction: column; align-items: flex-start; gap: 32px; }
  .fabric-hero__images { width: 100%; }
  .fabric-hero__img-wrap--1 { flex: 1; width: auto; height: 220px; }
  .fabric-hero__img-wrap--2 { flex: 1; width: auto; height: 180px; }

  /* Category split */
  .fabric-category-split { grid-template-columns: 1fr; }

  /* Product grid */
  .fabric-product-grid { grid-template-columns: repeat(2, 1fr); }

  /* Brand story */
  .fabric-brand-story__inner { grid-template-columns: 1fr; }

  /* Testimonials */
  .fabric-testimonials__grid { grid-template-columns: repeat(2, 1fr); }

  /* Footer */
  .fabric-footer__grid { grid-template-columns: repeat(2, 1fr); }

  /* Blog */
  .fabric-blog-grid { grid-template-columns: repeat(2, 1fr); }

  /* About values */
  .fabric-values-grid { grid-template-columns: repeat(2, 1fr); }

  /* Contact */
  .fabric-contact-grid { grid-template-columns: 1fr; }

  /* Single post related */
  .fabric-related-posts__grid { grid-template-columns: repeat(2, 1fr); }
}

/* ─── Mobile (<768px) ────────────────────────────────────────────────────── */
@media (max-width: 767px) {
  .container { padding: 0 16px; }

  /* Header */
  .fabric-header { padding: 14px 16px; }
  .fabric-header__actions { gap: 12px; }
  .fabric-search-bar { top: 56px; }

  /* Announcement bar */
  .fabric-announcement-bar { font-size: 10px; padding: 6px 16px; }

  /* Hero */
  .fabric-hero { padding: 32px 0 40px; }
  .fabric-hero__eyebrow { font-size: 9px; }
  .fabric-hero__title { font-size: 40px; }
  .fabric-hero__subtitle { font-size: 13px; }
  .fabric-hero__buttons { flex-direction: column; align-items: flex-start; gap: 12px; }
  .fabric-hero__images { display: none; }

  /* Marquee */
  .fabric-marquee { padding: 12px 0; }

  /* Category split */
  .fabric-category-split__item { min-height: 220px; }
  .fabric-category-split__title { font-size: 28px; }

  /* Product grid → 1 col, or 2 col on small phones */
  .fabric-product-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .fabric-section { padding: 48px 0; }

  /* Brand story */
  .fabric-brand-story__image { aspect-ratio: 4/3; }
  .fabric-brand-story__title { font-size: 28px; }

  /* Testimonials */
  .fabric-testimonials__grid { grid-template-columns: 1fr; }

  /* Newsletter */
  .fabric-newsletter { padding: 48px 16px; }
  .fabric-newsletter__form { flex-direction: column; gap: 12px; }
  .fabric-newsletter__input,
  .fabric-newsletter__btn { width: 100%; }

  /* Footer */
  .fabric-footer__grid { grid-template-columns: 1fr; gap: 32px; }
  .fabric-footer__bottom { flex-direction: column; gap: 12px; text-align: center; }
  .fabric-footer__social { justify-content: center; }

  /* Blog */
  .fabric-blog-grid { grid-template-columns: 1fr; }

  /* About */
  .fabric-about-hero__title { font-size: 36px; }
  .fabric-values-grid { grid-template-columns: 1fr; }
  .fabric-team-grid { grid-template-columns: repeat(2, 1fr); }

  /* Contact */
  .fabric-contact-grid { gap: 40px; }

  /* FAQ */
  .fabric-faq-category { margin-bottom: 32px; }

  /* Wishlist */
  .fabric-wishlist-grid { grid-template-columns: repeat(2, 1fr); }

  /* 404 */
  .fabric-404__number { font-size: 120px; }

  /* Pagination */
  .fabric-pagination { gap: 4px; }
  .fabric-pagination a,
  .fabric-pagination span { width: 36px; height: 36px; font-size: 12px; }

  /* Single post */
  .fabric-post-related__grid { grid-template-columns: 1fr; }
  .fabric-post-header__title { font-size: 28px; }

  /* Search */
  .fabric-search-results-grid { grid-template-columns: 1fr; }
}

/* ─── Very small phones (<400px) ─────────────────────────────────────────── */
@media (max-width: 399px) {
  .fabric-product-grid { grid-template-columns: 1fr; }
  .fabric-wishlist-grid { grid-template-columns: 1fr; }
  .fabric-team-grid { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   QUICK VIEW MODAL
═══════════════════════════════════════════════════════════════════════════ */

/* Quick View trigger button on product card */
.fabric-product-card {
  position: relative;
}

.fabric-product-card__qv-btn {
  position: absolute;
  bottom: 130px; /* above the ATC button */
  left: 50%;
  transform: translateX(-50%);
  background: rgba(255, 255, 255, 0.95);
  color: var(--color-primary);
  border: 1px solid var(--color-border);
  font-family: var(--font-ui);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  padding: 8px 16px;
  cursor: pointer;
  white-space: nowrap;
  opacity: 0;
  transition: opacity 0.2s ease, transform 0.2s ease;
  transform: translateX(-50%) translateY(4px);
  z-index: 2;
  pointer-events: none;
}

.fabric-product-card:hover .fabric-product-card__qv-btn {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}

/* Modal overlay */
.fabric-qv-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
}

.fabric-qv-modal[hidden] { display: none; }

.fabric-qv-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(2px);
}

.fabric-qv-modal__box {
  position: relative;
  background: #fff;
  width: 100%;
  max-width: 860px;
  max-height: 90vh;
  overflow-y: auto;
  z-index: 1;
}

/* Loading spinner */
.fabric-qv-modal__loading {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 300px;
}

.fabric-qv-spinner {
  width: 36px;
  height: 36px;
  border: 3px solid var(--color-border);
  border-top-color: var(--color-primary);
  border-radius: 50%;
  animation: fabric-spin 0.7s linear infinite;
}

@keyframes fabric-spin { to { transform: rotate(360deg); } }

/* Quick View inner layout */
.fabric-qv__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  position: relative;
}

.fabric-qv__close {
  position: absolute;
  top: 12px;
  right: 12px;
  background: none;
  border: none;
  font-size: 22px;
  cursor: pointer;
  color: var(--color-muted);
  z-index: 2;
  line-height: 1;
  padding: 4px 8px;
}

.fabric-qv__close:hover { color: var(--color-primary); }

/* Gallery panel */
.fabric-qv__gallery {
  border-right: 1px solid var(--color-border);
  padding: 24px;
}

.fabric-qv__main-img {
  background: var(--color-surface);
  aspect-ratio: 4/5;
  overflow: hidden;
  position: relative;
  margin-bottom: 12px;
}

.fabric-qv__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.fabric-qv__img-placeholder {
  width: 100%;
  height: 100%;
  background: var(--color-surface);
}

.fabric-qv__video-btn {
  position: absolute;
  bottom: 12px;
  left: 12px;
  background: rgba(0,0,0,0.65);
  color: #fff;
  border: none;
  font-family: var(--font-ui);
  font-size: 10px;
  letter-spacing: 1px;
  padding: 6px 12px;
  cursor: pointer;
}

.fabric-qv__thumbs {
  display: flex;
  gap: 8px;
}

.fabric-qv__thumb {
  width: 60px;
  height: 75px;
  border: 1.5px solid transparent;
  cursor: pointer;
  padding: 0;
  background: none;
  overflow: hidden;
  flex-shrink: 0;
}

.fabric-qv__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.fabric-qv__thumb.is-active { border-color: var(--color-primary); }

/* Info panel */
.fabric-qv__info {
  padding: 32px 28px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.fabric-qv__type {
  font-family: var(--font-ui);
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--color-muted);
}

.fabric-qv__title {
  font-size: 24px;
  font-weight: 400;
  letter-spacing: -0.5px;
  line-height: 1.2;
}

.fabric-qv__title a {
  color: inherit;
  text-decoration: none;
}

.fabric-qv__price-row {
  display: flex;
  align-items: baseline;
  gap: 6px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--color-border);
}

.fabric-qv__price { font-family: var(--font-ui); font-size: 20px; font-weight: 600; }
.fabric-qv__per   { font-family: var(--font-ui); font-size: 12px; color: var(--color-muted); }
.fabric-qv__total { font-family: var(--font-ui); font-size: 12px; color: var(--color-muted); background: var(--color-surface); padding: 3px 8px; }

/* Swatches */
.fabric-qv__swatch-label {
  font-family: var(--font-ui);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 8px;
}

.fabric-qv__swatch-name { color: var(--color-primary); font-weight: 600; }

.fabric-qv__swatches { display: flex; gap: 8px; flex-wrap: wrap; }

.fabric-qv__swatch-btn {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 2px solid transparent;
  cursor: pointer;
  padding: 0;
  transition: border-color 0.15s;
}

.fabric-qv__swatch-btn[aria-checked="true"] {
  border-color: var(--color-primary);
  outline: 2px solid #fff;
  outline-offset: -4px;
}

/* Yard calc */
.fabric-qv__yard-label {
  font-family: var(--font-ui);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 8px;
}

.fabric--qv__yard-row {
  display: flex;
  align-items: center;
  gap: 0;
}

.fabric-qv__yard-row {
  display: flex;
  align-items: center;
  gap: 0;
}

.fabric-qv__yard-btn {
  width: 36px;
  height: 36px;
  background: var(--color-primary);
  color: #fff;
  border: none;
  cursor: pointer;
  font-size: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.fabric-qv__yard-input {
  width: 64px;
  height: 36px;
  border: 1px solid var(--color-border);
  border-left: none;
  border-right: none;
  text-align: center;
  font-family: var(--font-heading);
  font-size: 15px;
  -moz-appearance: textfield;
}
.fabric-qv__yard-input::-webkit-outer-spin-button,
.fabric-qv__yard-input::-webkit-inner-spin-button { -webkit-appearance: none; }

.fabric-qv__yard-unit {
  font-family: var(--font-ui);
  font-size: 12px;
  color: var(--color-muted);
  margin-left: 10px;
}

/* Standard qty input */
.fabric-qv__qty-input {
  width: 80px;
  height: 40px;
  border: 1px solid var(--color-border);
  text-align: center;
  font-family: var(--font-heading);
  font-size: 15px;
}

/* Buttons */
.fabric-qv__atc { margin-top: 4px; }

.fabric-qv__view-full {
  font-family: var(--font-ui);
  font-size: 11px;
  letter-spacing: 1px;
  color: var(--color-muted);
  text-decoration: underline;
  text-align: center;
}

.fabric-qv__sample {
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--color-muted);
  padding: 10px;
  border: 1px dashed var(--color-border);
  text-align: center;
}

.fabric-qv__sample a { color: var(--color-primary); }

/* Responsive */
@media (max-width: 767px) {
  .fabric-qv__inner { grid-template-columns: 1fr; }
  .fabric-qv__gallery { border-right: none; border-bottom: 1px solid var(--color-border); }
  .fabric-qv-modal__box { max-height: 95vh; }
  .fabric-product-card__qv-btn { display: none; } /* hide on touch — tap goes to product page */
}

/* ═══════════════════════════════════════════════════════════════════════════
   AJAX LIVE SEARCH DROPDOWN
═══════════════════════════════════════════════════════════════════════════ */
.fabric-search-bar__inner {
  position: relative;
  flex: 1;
}

.fabric-live-search-dropdown {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  background: #fff;
  border: 1px solid var(--color-border);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
  z-index: 9998;
  max-height: 420px;
  overflow-y: auto;
}

.fabric-live-search-dropdown[hidden] { display: none; }

.fabric-lsd__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.fabric-lsd__item {
  border-bottom: 1px solid var(--color-border);
}

.fabric-lsd__item:last-child { border-bottom: none; }

.fabric-lsd__link {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 16px;
  text-decoration: none;
  color: var(--color-primary);
  transition: background 0.15s;
}

.fabric-lsd__link:hover,
.fabric-lsd__link:focus {
  background: var(--color-surface);
  outline: none;
}

.fabric-lsd__img {
  width: 48px;
  height: 60px;
  object-fit: cover;
  flex-shrink: 0;
}

.fabric-lsd__img-placeholder {
  width: 48px;
  height: 60px;
  background: var(--color-surface);
  flex-shrink: 0;
}

.fabric-lsd__meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.fabric-lsd__type {
  font-family: var(--font-ui);
  font-size: 9px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--color-muted);
}

.fabric-lsd__name {
  font-family: var(--font-heading);
  font-size: 14px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.fabric-lsd__price {
  font-family: var(--font-ui);
  font-size: 13px;
  font-weight: 600;
}

.fabric-lsd__empty {
  padding: 20px 16px;
  font-family: var(--font-ui);
  font-size: 13px;
  color: var(--color-muted);
}

.fabric-lsd__view-all {
  display: block;
  padding: 12px 16px;
  font-family: var(--font-ui);
  font-size: 11px;
  letter-spacing: 1px;
  color: var(--color-muted);
  text-decoration: none;
  border-top: 1px solid var(--color-border);
  background: var(--color-surface);
  text-align: center;
}

.fabric-lsd__view-all:hover { color: var(--color-primary); }

/* ═══════════════════════════════════════════════════════════════════════════
   PENDING APPROVAL PAGE
═══════════════════════════════════════════════════════════════════════════ */
.fabric-pending-page {
  max-width: 520px;
  margin: 80px auto;
  text-align: center;
  padding: 0 16px;
}

.fabric-pending-page__icon {
  font-size: 56px;
  margin-bottom: 24px;
  line-height: 1;
}

.fabric-pending-page__title {
  font-size: 32px;
  font-weight: 400;
  letter-spacing: -0.5px;
  margin-bottom: 20px;
}

.fabric-pending-page__text {
  font-family: var(--font-ui);
  font-size: 14px;
  color: #555;
  line-height: 1.8;
  margin-bottom: 12px;
}

.fabric-pending-page__text--muted {
  font-size: 12px;
  color: var(--color-muted);
}

.fabric-pending-page__text a {
  color: var(--color-primary);
}

/* ═══════════════════════════════════════════════════════════════════════════
   TRUST STRIP
═══════════════════════════════════════════════════════════════════════════ */
.fabric-trust-strip {
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  padding: 20px 0;
}

.fabric-trust-strip__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.fabric-trust-strip__item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 8px 0;
}

.fabric-trust-strip__icon {
  font-size: 24px;
  flex-shrink: 0;
  line-height: 1;
}

.fabric-trust-strip__text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.fabric-trust-strip__title {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: 600;
  color: var(--color-primary);
}

.fabric-trust-strip__sub {
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--color-muted);
}

@media (max-width: 767px) {
  .fabric-trust-strip__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   HOW IT WORKS
═══════════════════════════════════════════════════════════════════════════ */
.fabric-how-it-works {
  background: var(--color-surface);
}

.fabric-hiw__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  margin-bottom: 40px;
  position: relative;
}

.fabric-hiw__item {
  padding: 0 32px;
  text-align: center;
  position: relative;
}

.fabric-hiw__item:not(:first-child) {
  border-left: 1px solid var(--color-border);
}

.fabric-hiw__number {
  display: inline-block;
  font-family: var(--font-heading);
  font-size: 48px;
  font-weight: 400;
  color: var(--color-border);
  line-height: 1;
  margin-bottom: 16px;
}

.fabric-hiw__title {
  font-size: 18px;
  font-weight: 400;
  margin-bottom: 12px;
  letter-spacing: -0.3px;
}

.fabric-hiw__body {
  font-family: var(--font-ui);
  font-size: 13px;
  color: #555;
  line-height: 1.8;
}

.fabric-hiw__cta {
  text-align: center;
}

@media (max-width: 767px) {
  .fabric-hiw__grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .fabric-hiw__item {
    padding: 0;
    border-left: none !important;
    padding-top: 24px;
    border-top: 1px solid var(--color-border);
  }
  .fabric-hiw__item:first-child { border-top: none; padding-top: 0; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   LOOKBOOK GRID
═══════════════════════════════════════════════════════════════════════════ */
.fabric-lookbook {
  padding-bottom: 0;
}

.fabric-lookbook__grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 4px;
  margin-top: 40px;
}

.fabric-lookbook__item {
  position: relative;
  overflow: hidden;
  aspect-ratio: 1;
  display: block;
}

.fabric-lookbook__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.fabric-lookbook__item:hover .fabric-lookbook__img {
  transform: scale(1.05);
}

.fabric-lookbook__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.35);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.3s;
}

.fabric-lookbook__item:hover .fabric-lookbook__overlay {
  opacity: 1;
}

.fabric-lookbook__footer {
  text-align: center;
  padding: 24px;
  border-top: 1px solid var(--color-border);
  margin-top: 4px;
}

.fabric-lookbook__handle {
  font-family: var(--font-ui);
  font-size: 12px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--color-muted);
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  padding-bottom: 2px;
}

.fabric-lookbook__handle:hover { color: var(--color-primary); }

@media (max-width: 767px) {
  .fabric-lookbook__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   LOGIN / REGISTER PAGE
═══════════════════════════════════════════════════════════════════════════ */
.fabric-auth-page {
  padding: 60px 0 80px;
}

.fabric-auth-wrap {
  max-width: 440px;
  margin: 0 auto;
}

.fabric-auth-brand {
  text-align: center;
  margin-bottom: 40px;
}

.fabric-auth-brand img { height: 40px; width: auto; margin: 0 auto 12px; }

.fabric-auth-brand__name {
  font-family: var(--font-heading);
  font-size: 28px;
  letter-spacing: -1px;
  display: block;
  margin-bottom: 8px;
}

.fabric-auth-brand__tagline {
  font-family: var(--font-ui);
  font-size: 12px;
  color: var(--color-muted);
  letter-spacing: 1px;
}

.fabric-auth-tabs {
  display: flex;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 32px;
}

.fabric-auth-tab {
  flex: 1;
  text-align: center;
  padding: 12px;
  font-family: var(--font-ui);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--color-muted);
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  text-decoration: none;
  transition: color 0.2s, border-color 0.2s;
}

.fabric-auth-tab.is-active {
  color: var(--color-primary);
  border-bottom-color: var(--color-primary);
}

.fabric-auth-form {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.fabric-auth-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.fabric-auth-label {
  font-family: var(--font-ui);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--color-muted);
}

.fabric-auth-label span { color: var(--color-primary); }

.fabric-auth-input {
  width: 100%;
  height: 44px;
  border: 1px solid var(--color-border);
  padding: 0 14px;
  font-family: var(--font-ui);
  font-size: 13px;
  color: var(--color-primary);
  background: #fff;
  outline: none;
  transition: border-color 0.2s;
}

.fabric-auth-input:focus { border-color: var(--color-primary); }

.fabric-auth-input-wrap {
  position: relative;
}

.fabric-auth-input-wrap .fabric-auth-input { padding-right: 44px; }

.fabric-auth-toggle-pwd {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  font-size: 16px;
  color: var(--color-muted);
  padding: 0;
  line-height: 1;
}

.fabric-auth-hint {
  font-family: var(--font-ui);
  font-size: 10px;
  color: var(--color-muted);
}

.fabric-auth-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.fabric-auth-check {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-ui);
  font-size: 12px;
  color: var(--color-muted);
  cursor: pointer;
}

.fabric-auth-forgot {
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--color-muted);
  text-decoration: underline;
}

.fabric-auth-error {
  background: #fff5f5;
  border: 1px solid #fca5a5;
  color: #dc2626;
  padding: 12px 14px;
  font-family: var(--font-ui);
  font-size: 12px;
  line-height: 1.5;
}

.fabric-auth-notice {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  padding: 14px 16px;
  font-family: var(--font-ui);
  font-size: 12px;
  color: #555;
  line-height: 1.6;
}

.fabric-auth-notice strong {
  font-size: 11px;
  letter-spacing: 1px;
  text-transform: uppercase;
  display: block;
  margin-bottom: 4px;
  color: var(--color-primary);
}

.fabric-auth-name-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.fabric-auth-switch {
  text-align: center;
  font-family: var(--font-ui);
  font-size: 12px;
  color: var(--color-muted);
}

.fabric-auth-switch a {
  color: var(--color-primary);
  text-decoration: underline;
}

/* Password show/hide JS — handled inline */
@media (max-width: 480px) {
  .fabric-auth-name-row { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   PAGE POLISH — auth, about, pending, contact (modern card/blue theme)
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Auth page (Login & Register) ───────────────────────────────────────── */
.fabric-auth-page { background: #f4f6f8; min-height: calc(100vh - 200px); padding: 48px 16px 80px; }
.fabric-auth-page .container { max-width: none; padding: 0; }
.fabric-auth-wrap {
  max-width: 460px;
  margin: 0 auto;
  background: #fff;
  border-radius: 16px;
  padding: 40px 36px;
  box-shadow: 0 4px 24px rgba(15,22,35,0.06), 0 1px 2px rgba(15,22,35,0.04);
}
.fabric-auth-brand { text-align: center; margin-bottom: 28px; }
.fabric-auth-brand img,
.fabric-auth-brand .custom-logo { max-height: 40px; width: auto; }
.fabric-auth-brand__name {
  font-family: var(--font-heading, var(--font-body));
  font-size: 24px;
  font-weight: 700;
  color: #0f1623;
  text-decoration: none;
  letter-spacing: -0.5px;
}
.fabric-auth-brand__tagline {
  font-size: 13px;
  color: #6b7280;
  margin: 8px 0 0;
  letter-spacing: 0;
  text-transform: none;
}
.fabric-auth-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
  background: #f4f6f8;
  border-radius: 10px;
  padding: 4px;
  margin-bottom: 28px;
}
.fabric-auth-tab {
  display: block;
  padding: 11px 12px;
  text-align: center;
  font-size: 13px;
  font-weight: 600;
  color: #6b7280;
  text-decoration: none;
  border-radius: 8px;
  transition: background 0.15s, color 0.15s;
  letter-spacing: 0;
  text-transform: none;
}
.fabric-auth-tab:hover { color: #0f1623; }
.fabric-auth-tab.is-active {
  background: #fff;
  color: #1d6dff;
  box-shadow: 0 1px 3px rgba(15,22,35,0.08);
}
.fabric-auth-form { display: flex; flex-direction: column; gap: 16px; }
.fabric-auth-name-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.fabric-auth-field { display: flex; flex-direction: column; gap: 6px; }
.fabric-auth-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #6b7280;
  margin: 0;
}
.fabric-auth-input,
.fabric-auth-page input[type="email"],
.fabric-auth-page input[type="password"],
.fabric-auth-page input[type="text"] {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid #d8dde6;
  border-radius: 8px;
  font-size: 14px;
  background: #fff;
  color: #0f1623;
  transition: border-color 0.15s, box-shadow 0.15s;
  font-family: inherit;
}
.fabric-auth-input:focus {
  outline: none;
  border-color: #1d6dff;
  box-shadow: 0 0 0 3px rgba(29,109,255,0.12);
}
.fabric-auth-input-wrap { position: relative; }
.fabric-auth-toggle-pwd {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  font-size: 16px;
  cursor: pointer;
  color: #9ca3af;
  padding: 4px;
}
.fabric-auth-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 13px;
  margin: -4px 0 4px;
}
.fabric-auth-check { display: flex; align-items: center; gap: 6px; color: #4a5568; cursor: pointer; }
.fabric-auth-forgot { color: #1d6dff; text-decoration: none; font-weight: 500; }
.fabric-auth-forgot:hover { text-decoration: underline; }
.fabric-auth-page .btn--primary,
.fabric-auth-page button[type="submit"].btn {
  background: #1d6dff;
  color: #fff;
  border: none;
  padding: 13px 20px;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s, transform 0.05s;
  text-transform: none;
  letter-spacing: 0;
  width: 100%;
  margin-top: 8px;
}
.fabric-auth-page .btn--primary:hover { background: #1558d6; }
.fabric-auth-page .btn--primary:active { transform: scale(0.99); }
.fabric-auth-switch {
  text-align: center;
  font-size: 13px;
  color: #6b7280;
  margin: 12px 0 0;
}
.fabric-auth-switch a { color: #1d6dff; font-weight: 600; text-decoration: none; margin-left: 4px; }
.fabric-auth-switch a:hover { text-decoration: underline; }
.fabric-auth-error {
  background: #fef2f2;
  color: #b91c1c;
  border: 1px solid #fecaca;
  border-radius: 8px;
  padding: 10px 14px;
  font-size: 13px;
}
.fabric-auth-notice {
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  color: #1e40af;
  border-radius: 8px;
  padding: 12px 14px;
  font-size: 13px;
  line-height: 1.5;
}
.fabric-auth-notice strong { color: #1e3a8a; }
.fabric-auth-hint { font-size: 12px; color: #9ca3af; margin-top: 2px; }

/* ── About page polish ──────────────────────────────────────────────────── */
/* (Old conflicting hero rules removed — see unified hero block at end of file) */
.fabric-brand-story {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  max-width: 1100px;
  margin: 0 auto;
  padding: 80px 24px;
  align-items: center;
}
.fabric-brand-story__img img {
  width: 100%;
  height: auto;
  border-radius: 16px;
  display: block;
}
.fabric-brand-story__body { font-size: 16px; line-height: 1.75; color: #4a5568; }
.fabric-brand-story__body p { margin: 0 0 16px; }
.fabric-values {
  background: #f4f6f8;
  padding: 80px 24px;
}
.fabric-values__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: 1100px;
  margin: 0 auto;
}
.fabric-values__item {
  background: #fff;
  border-radius: 12px;
  padding: 32px 28px;
  box-shadow: 0 1px 3px rgba(15,22,35,0.04);
  transition: transform 0.2s, box-shadow 0.2s;
}
.fabric-values__item:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(15,22,35,0.08);
}
.fabric-values__title {
  font-size: 18px;
  font-weight: 700;
  color: #0f1623;
  margin: 0 0 12px;
}
.fabric-values__text { color: #4a5568; line-height: 1.65; font-size: 14px; margin: 0; }
.fabric-about-cta {
  text-align: center;
  padding: 80px 24px;
  background: #fff;
}
.fabric-about-cta .btn {
  background: #1d6dff;
  color: #fff;
  padding: 14px 32px;
  border-radius: 10px;
  font-weight: 600;
  text-decoration: none;
  display: inline-block;
  transition: background 0.15s;
}
.fabric-about-cta .btn:hover { background: #1558d6; }

/* ── Pending approval page ─────────────────────────────────────────────── */
.fabric-pending-page {
  background: #f4f6f8;
  min-height: calc(100vh - 200px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 48px 16px;
}
.fabric-pending-card {
  max-width: 520px;
  background: #fff;
  border-radius: 16px;
  padding: 48px 36px;
  text-align: center;
  box-shadow: 0 4px 24px rgba(15,22,35,0.06);
}
.fabric-pending-card h1 {
  font-size: 26px;
  font-weight: 700;
  color: #0f1623;
  margin: 0 0 12px;
}
.fabric-pending-card p { color: #4a5568; line-height: 1.7; margin: 0 0 16px; }
.fabric-pending-card .btn {
  background: #1d6dff;
  color: #fff;
  padding: 12px 24px;
  border-radius: 8px;
  text-decoration: none;
  font-weight: 600;
  display: inline-block;
  margin-top: 8px;
}

@media (max-width: 768px) {
  .fabric-brand-story { grid-template-columns: 1fr; gap: 32px; padding: 48px 20px; }
  .fabric-values { padding: 48px 20px; }
  .fabric-values__grid { grid-template-columns: 1fr; }
  .fabric-auth-wrap { padding: 32px 24px; }
}

/* ============================================================
   MEGA MENU — Desktop
   ============================================================ */
.fabric-header { position: relative; }
.fabric-mega-nav { position: static; }
.fabric-nav__item--mega { position: static; }
.fabric-nav__link--has-mega { display: inline-flex; align-items: center; gap: 4px; }
.fabric-nav__chevron { transition: transform .2s ease; flex-shrink: 0; }
.fabric-nav__item--mega:hover .fabric-nav__chevron,
.fabric-nav__item--mega:focus-within .fabric-nav__chevron { transform: rotate(180deg); }

.fabric-mega-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    width: 100%;
    background: #ffffff;
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
    box-shadow: 0 12px 40px rgba(0,0,0,.08);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-6px);
    transition: opacity .2s ease, transform .2s ease, visibility .2s;
    z-index: 9999;
    pointer-events: none;
}
.fabric-nav__item--mega:hover .fabric-mega-dropdown,
.fabric-nav__item--mega:focus-within .fabric-mega-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: all;
}

.fabric-mega-dropdown__inner {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 32px;
    max-width: 1280px;
    margin: 0 auto;
    padding: 36px 40px;
}

.fabric-mega-col { padding: 0; border-right: 1px solid var(--color-border); padding-right: 32px; }
.fabric-mega-col:last-child  { border-right: none; padding-right: 0; }

.fabric-mega-col__heading {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--color-muted);
    margin: 0 0 14px;
    white-space: nowrap;
}

.fabric-mega-col__list {
    list-style: none;
    margin: 0;
    padding: 0;
    /* Override inherited .fabric-nav__list li ul rules */
    position: static !important;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
    background: none !important;
    border: none !important;
    min-width: 0 !important;
    transition: none !important;
}
.fabric-mega-col__list li {
    margin: 0 0 8px;
    padding: 0;
    list-style: none;
}
.fabric-mega-col__list a {
    /* Override inherited .fabric-nav__list li ul li a rules */
    padding: 4px 0 !important;
    font-size: 14px !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
    color: var(--color-primary) !important;
    background: none !important;
    text-decoration: none;
    line-height: 1.5;
    display: block;
    transition: color .15s;
}
.fabric-mega-col__list a:hover {
    color: var(--color-accent) !important;
    background: none !important;
}
.fabric-mega-col__viewall a {
    font-size: 13px !important;
    color: var(--color-muted) !important;
    margin-top: 6px;
}
.fabric-mega-col__viewall a:hover { color: var(--color-accent) !important; }

.fabric-mega-col__promo {
    margin-top: 24px;
    padding-top: 18px;
    border-top: 1px solid var(--color-border);
}
.fabric-mega-col__promo-label {
    font-size: 12px;
    color: var(--color-muted);
    margin: 0 0 10px;
}

/* ============================================================
   MOBILE NAVIGATION — Rebuilt
   ============================================================ */
.fabric-mobile-nav {
    position: fixed;
    top: 0; right: 0; bottom: 0;
    width: min(360px, 90vw);
    background: var(--color-bg);
    z-index: 1100;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    box-shadow: -4px 0 32px rgba(0,0,0,.12);
    transform: translateX(100%);
    transition: transform .28s cubic-bezier(.4,0,.2,1);
}
.fabric-mobile-nav:not([hidden]) { transform: translateX(0); }

.fabric-mobile-nav__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 24px;
    border-bottom: 1px solid var(--color-border);
    flex-shrink: 0;
}
.fabric-mobile-nav__title { font-size: 15px; font-weight: 500; }
.fabric-mobile-nav__close {
    background: none; border: none;
    font-size: 18px; cursor: pointer;
    color: var(--color-primary); padding: 4px;
    line-height: 1;
}

.fabric-mobile-nav__body { padding: 8px 0 24px; flex: 1; }

.fabric-mobile-nav__link {
    display: block;
    padding: 13px 24px;
    font-size: 15px;
    color: var(--color-primary);
    text-decoration: none;
    border-bottom: 1px solid var(--color-border);
    transition: background .1s;
}
.fabric-mobile-nav__link:hover { background: var(--color-surface); }

/* Mobile accordion section */
.fabric-mobile-nav__section { border-bottom: 1px solid var(--color-border); }
.fabric-mobile-nav__section-toggle {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 13px 24px;
    font-size: 15px;
    font-weight: 500;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--color-primary);
    text-align: left;
}
.fabric-mobile-nav__chevron { transition: transform .2s; flex-shrink: 0; }
.fabric-mobile-nav__section-toggle[aria-expanded="true"] .fabric-mobile-nav__chevron { transform: rotate(180deg); }

.fabric-mobile-nav__sub { padding: 4px 0 12px 24px; background: var(--color-surface); }
.fabric-mobile-nav__sub-heading {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--color-muted);
    padding: 12px 0 6px;
    margin: 0;
}
.fabric-mobile-nav__sub-link {
    display: block;
    padding: 7px 0;
    font-size: 14px;
    color: var(--color-primary);
    text-decoration: none;
}
.fabric-mobile-nav__sub-link:hover { color: var(--color-accent); }
.fabric-mobile-nav__sub-link--all { font-weight: 500; margin-top: 4px; }

.fabric-mobile-nav__actions { padding: 20px 24px; display: flex; flex-direction: column; gap: 10px; }
.btn--full { display: block; width: 100%; text-align: center; }

.fabric-mobile-overlay {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.45);
    z-index: 1090;
    opacity: 0;
    pointer-events: none;
    transition: opacity .28s;
}
.fabric-mobile-overlay.is-active { opacity: 1; pointer-events: all; }

/* Hide mega on mobile */
@media (max-width: 1023px) {
    .fabric-mega-nav { display: none; }
    .fabric-header__hamburger { display: flex !important; }
}
@media (min-width: 1024px) {
    .fabric-header__hamburger { display: none !important; }
    .fabric-mobile-nav, .fabric-mobile-overlay { display: none !important; }
}
/* Universal: respect the hidden attribute */
.fabric-mobile-nav[hidden] { display: none !important; }
.fabric-mobile-overlay:not(.is-active) { pointer-events: none; }

/* ============================================================
   FOOTER — 4 column grid + trust strip
   ============================================================ */
.fabric-footer__grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 40px;
    padding: 56px 0 40px;
}
@media (max-width: 900px) {
    .fabric-footer__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 540px) {
    .fabric-footer__grid { grid-template-columns: 1fr; }
}

/* Newsletter in footer */
.fabric-footer__newsletter { margin: 18px 0; }
.fabric-footer__newsletter-label { font-size: 12px; color: rgba(255,255,255,.7); display: block; margin-bottom: 8px; }
.fabric-footer__newsletter-row { display: flex; gap: 6px; }
.fabric-footer__newsletter-row input {
    flex: 1;
    padding: 9px 12px;
    font-size: 13px;
    border: 1px solid rgba(255,255,255,.2);
    border-radius: 4px;
    background: rgba(255,255,255,.1);
    color: #fff;
}
.fabric-footer__newsletter-row input::placeholder { color: rgba(255,255,255,.5); }
.fabric-footer__newsletter-row button {
    padding: 9px 16px;
    font-size: 13px;
    background: #fff;
    color: var(--color-footer-bg, #1a1a1a);
    border: none;
    border-radius: 4px;
    cursor: pointer;
    white-space: nowrap;
}
.fabric-footer__newsletter-msg { font-size: 12px; color: rgba(255,255,255,.7); margin-top: 6px; }

/* Trust strip */
.fabric-footer__trust {
    display: flex;
    flex-wrap: wrap;
    gap: 20px 40px;
    padding: 24px 0;
    border-top: 1px solid rgba(255,255,255,.1);
    border-bottom: 1px solid rgba(255,255,255,.1);
}
.fabric-footer__trust-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: rgba(255,255,255,.75);
}

.fabric-footer__bottom-links a { color: rgba(255,255,255,.6); text-decoration: none; }
.fabric-footer__bottom-links a:hover { color: #fff; }

/* ============================================================
   GUIDE PAGES — shared styles for size guide, care guide etc
   ============================================================ */
/* (Old hero rules removed — see unified hero block at end of file) */

.fabric-guide-section { margin-bottom: 48px; }
.fabric-guide-section h2 { font-size: 22px; margin-bottom: 20px; padding-bottom: 12px; border-bottom: 1px solid var(--color-border); }

.fabric-table-wrap { overflow-x: auto; }
.fabric-guide-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.fabric-guide-table th { background: var(--color-surface); text-align: left; padding: 10px 14px; font-weight: 600; font-size: 12px; text-transform: uppercase; letter-spacing: .05em; border-bottom: 2px solid var(--color-border); }
.fabric-guide-table td { padding: 10px 14px; border-bottom: 1px solid var(--color-border); vertical-align: top; }
.fabric-guide-table tr:hover td { background: var(--color-surface); }
.fabric-guide-table--sm { font-size: 13px; }
.fabric-guide-note { font-size: 12px; color: var(--color-muted); margin-top: 10px; }

.fabric-guide-cta { text-align: center; padding: 40px; background: var(--color-surface); border-radius: 8px; margin-top: 40px; }
.fabric-guide-cta p { margin-bottom: 16px; color: var(--color-muted); }

.fabric-yard-guide-calc { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; margin-top: 16px; }
.fabric-guide-select { padding: 10px 14px; border: 1px solid var(--color-border); border-radius: 4px; font-size: 14px; background: var(--color-bg); color: var(--color-primary); min-width: 220px; }
.fabric-guide-result { display: flex; flex-direction: column; }
.fabric-guide-result__yards { font-size: 24px; font-weight: 600; }
.fabric-guide-result__note { font-size: 12px; color: var(--color-muted); }

.fabric-measure-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 20px; }
.fabric-measure-item { padding: 16px; border: 1px solid var(--color-border); border-radius: 8px; }
.fabric-measure-item__name { font-weight: 600; margin-bottom: 6px; }
.fabric-measure-item__desc { font-size: 13px; color: var(--color-muted); }

.fabric-tips-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 20px; }
.fabric-tips-item { padding: 16px; background: var(--color-surface); border-radius: 8px; }
.fabric-tips-item__title { font-weight: 600; margin-bottom: 6px; }
.fabric-tips-item p { font-size: 13px; color: var(--color-muted); }

.fabric-care-symbols { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 16px; }
.fabric-care-symbol-item { padding: 16px; border: 1px solid var(--color-border); border-radius: 8px; text-align: center; }
.fabric-care-symbol-item__icon { font-size: 28px; display: block; margin-bottom: 8px; }
.fabric-care-symbol-item__name { font-weight: 600; font-size: 13px; margin-bottom: 4px; }
.fabric-care-symbol-item__desc { font-size: 12px; color: var(--color-muted); }

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.fabric-about-story__layout { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
@media (max-width: 768px) { .fabric-about-story__layout { grid-template-columns: 1fr; } }
.fabric-about-story__image img { width: 100%; border-radius: 4px; }
.fabric-values-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
@media (max-width: 768px) { .fabric-values-grid { grid-template-columns: 1fr; } }
.fabric-value-card { padding: 28px; background: var(--color-bg); border-radius: 8px; }
.fabric-value-card__title { font-size: 17px; margin-bottom: 10px; }
.fabric-about-sustain__layout { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
@media (max-width: 768px) { .fabric-about-sustain__layout { grid-template-columns: 1fr; } }
.fabric-about-sustain__stats { display: flex; flex-direction: column; gap: 20px; }
.fabric-about-sustain__stat { display: flex; flex-direction: column; }
.fabric-about-sustain__num { font-size: 32px; font-weight: 700; }

/* ============================================================
   SUSTAINABILITY PAGE
   ============================================================ */
.fabric-sustain-pillars { display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px; }
@media (max-width: 640px) { .fabric-sustain-pillars { grid-template-columns: 1fr; } }
.fabric-sustain-pillar { padding: 28px; border: 1px solid var(--color-border); border-radius: 8px; }
.fabric-sustain-pillar__icon { margin-bottom: 14px; color: var(--color-primary); }
.fabric-sustain-pillar__title { font-size: 17px; margin-bottom: 8px; }
.fabric-cert-list { display: flex; flex-direction: column; gap: 16px; }
.fabric-cert-item { display: flex; gap: 14px; align-items: flex-start; }
.fabric-cert-item__check { width: 28px; height: 28px; background: var(--color-surface); border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px; }
.fabric-cert-item__name { display: block; font-weight: 600; margin-bottom: 3px; }
.fabric-cert-item__desc { font-size: 13px; color: var(--color-muted); }
.fabric-metrics-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
@media (max-width: 768px) { .fabric-metrics-grid { grid-template-columns: repeat(2, 1fr); } }
.fabric-metric-item { text-align: center; padding: 24px 16px; background: var(--color-surface); border-radius: 8px; }
.fabric-metric-item__num { font-size: 36px; font-weight: 700; line-height: 1; margin-bottom: 8px; }
.fabric-metric-item__num sup { font-size: 18px; }
.fabric-metric-item__label { font-size: 13px; color: var(--color-muted); }

/* ============================================================
   WHOLESALE PAGE
   ============================================================ */
.fabric-wholesale-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: start; }
@media (max-width: 800px) { .fabric-wholesale-layout { grid-template-columns: 1fr; } }
.fabric-wholesale-benefit { display: flex; gap: 12px; margin-bottom: 20px; }
.fabric-wholesale-benefit__check { width: 24px; height: 24px; background: var(--color-surface); border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px; }
.fabric-wholesale-benefit strong { display: block; margin-bottom: 2px; }
.fabric-wholesale-benefit p { font-size: 13px; color: var(--color-muted); margin: 0; }
.fabric-wholesale-moq { margin-top: 32px; padding: 20px; background: var(--color-surface); border-radius: 8px; }
.fabric-wholesale-moq h3 { font-size: 15px; margin-bottom: 12px; }
.fabric-wholesale-form-heading { font-size: 20px; margin-bottom: 20px; }

/* ============================================================
   FAQ PAGE
   ============================================================ */
.fabric-faq-tabs { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 36px; }
.fabric-faq-tab {
    padding: 7px 16px;
    font-size: 13px;
    border: 1px solid var(--color-border);
    border-radius: 20px;
    background: none;
    cursor: pointer;
    color: var(--color-primary);
    transition: all .15s;
}
.fabric-faq-tab:hover, .fabric-faq-tab.is-active {
    background: var(--color-primary);
    color: var(--color-bg);
    border-color: var(--color-primary);
}
.fabric-faq-group__heading { font-size: 18px; margin: 32px 0 12px; color: var(--color-primary); }
.fabric-faq-cta { text-align: center; padding: 40px; background: var(--color-surface); border-radius: 8px; margin-top: 40px; }
.fabric-faq-cta h3 { margin-bottom: 6px; }
.fabric-faq-cta p { color: var(--color-muted); margin-bottom: 18px; }

/* ============================================================
   SAMPLES PAGE
   ============================================================ */
.fabric-how-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
@media (max-width: 640px) { .fabric-how-grid { grid-template-columns: 1fr; } }
.fabric-how-step { text-align: center; padding: 28px 20px; }
.fabric-how-step__num { font-size: 40px; font-weight: 700; color: var(--color-border); margin-bottom: 12px; line-height: 1; }
.fabric-how-step__title { font-size: 16px; margin-bottom: 8px; }

/* ============================================================
   FORMS — shared
   ============================================================ */
.fabric-contact-form .fabric-form-row { margin-bottom: 0; }
.fabric-form-row--2col { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
@media (max-width: 540px) { .fabric-form-row--2col { grid-template-columns: 1fr; } }
.fabric-form-group { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.fabric-form-group label { font-size: 13px; font-weight: 500; }
.fabric-form-group input,
.fabric-form-group select,
.fabric-form-group textarea {
    padding: 10px 12px;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    font-size: 14px;
    background: var(--color-bg);
    color: var(--color-primary);
    width: 100%;
    transition: border-color .15s;
}
.fabric-form-group input:focus,
.fabric-form-group select:focus,
.fabric-form-group textarea:focus { outline: none; border-color: var(--color-primary); }
.fabric-form-error { background: #fef2f2; border: 1px solid #fca5a5; color: #991b1b; padding: 10px 14px; border-radius: 4px; font-size: 13px; margin-bottom: 16px; }
.fabric-form-success { text-align: center; padding: 48px 24px; }
.fabric-form-success svg { margin: 0 auto 16px; color: #16a34a; }
.fabric-form-success h2 { margin-bottom: 8px; }

/* ============================================================
   HOMEPAGE SECTIONS — Aliza-style upgrade
   ============================================================ */

/* Shared section head — used across hero-weaves, testimonials etc */
.fabric-section__head--centered { text-align: center; max-width: 640px; margin: 0 auto 36px; }
.fabric-section__eyebrow {
    font-size: 11px;
    color: var(--color-muted);
    letter-spacing: .14em;
    text-transform: uppercase;
    margin: 0 0 8px;
    font-weight: 500;
}
.fabric-section__head--centered .fabric-section__title {
    font-size: clamp(24px, 3.5vw, 32px);
    font-family: var(--font-heading, Georgia, serif);
    margin: 0 0 8px;
    font-weight: 400;
}
.fabric-section__head--centered .fabric-section__sub {
    font-size: 14px;
    color: var(--color-muted);
    margin: 0;
    line-height: 1.6;
}

/* ── Hero Weaves (Aliza-style hero ingredients) ──────────────────────── */
.fabric-hero-weaves { padding: 64px 0; }
.fabric-weaves-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
@media (max-width: 900px) { .fabric-weaves-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .fabric-weaves-grid { grid-template-columns: 1fr; } }

.fabric-weave-card {
    display: block;
    text-decoration: none;
    text-align: center;
    padding: 32px 20px 28px;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    color: var(--color-primary);
    transition: transform .25s ease, border-color .25s, box-shadow .25s;
}
.fabric-weave-card:hover {
    transform: translateY(-4px);
    border-color: var(--color-primary);
    box-shadow: 0 12px 32px rgba(0,0,0,.06);
}
.fabric-weave-card__icon {
    font-size: 32px;
    margin-bottom: 14px;
    line-height: 1;
}
.fabric-weave-card__name {
    font-size: 18px;
    font-family: var(--font-heading, Georgia, serif);
    margin: 0 0 8px;
    font-weight: 400;
}
.fabric-weave-card__desc {
    font-size: 13px;
    color: var(--color-muted);
    line-height: 1.6;
    margin: 0 0 16px;
    min-height: 42px;
}
.fabric-weave-card__link {
    font-size: 11px;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--color-primary);
    border-bottom: 1px solid var(--color-primary);
    padding-bottom: 2px;
    transition: opacity .15s;
}
.fabric-weave-card:hover .fabric-weave-card__link { opacity: .7; }

/* ── Promo Banner ───────────────────────────────────────────────────── */
.fabric-promo-banner-section { padding: 32px 0; }
.fabric-promo-banner {
    color: #fff;
    padding: 56px 32px;
    text-align: center;
    border-radius: 8px;
    position: relative;
    overflow: hidden;
}
.fabric-promo-banner__eyebrow {
    font-size: 11px;
    color: rgba(255,255,255,.65);
    letter-spacing: .14em;
    text-transform: uppercase;
    margin: 0 0 10px;
    font-weight: 500;
}
.fabric-promo-banner__title {
    font-size: clamp(26px, 4vw, 38px);
    font-family: var(--font-heading, Georgia, serif);
    color: #fff;
    margin: 0 0 24px;
    font-weight: 400;
    line-height: 1.2;
}
.fabric-promo-banner__cta {
    display: inline-block;
    background: #fff;
    color: #1a1a1a;
    padding: 12px 28px;
    font-size: 12px;
    letter-spacing: .1em;
    text-transform: uppercase;
    text-decoration: none;
    border-radius: 2px;
    transition: opacity .15s, transform .15s;
}
.fabric-promo-banner__cta:hover { opacity: .85; transform: translateY(-1px); }

/* ── Testimonials (UPGRADED) ────────────────────────────────────────── */
.fabric-testimonials { padding: 64px 0; background: var(--color-surface); }
.fabric-testimonials__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    max-width: 1200px;
    margin: 0 auto;
}
@media (max-width: 900px) { .fabric-testimonials__grid { grid-template-columns: 1fr; } }

.fabric-testimonial-card {
    background: var(--color-bg);
    padding: 28px 24px;
    border-radius: 8px;
    margin: 0;
    display: flex;
    flex-direction: column;
}
.fabric-testimonial-card__stars {
    font-size: 14px;
    color: #d4a437;
    margin: 0 0 14px;
    letter-spacing: 2px;
}
.fabric-testimonial-card__quote {
    font-size: 14px;
    line-height: 1.7;
    color: var(--color-primary);
    margin: 0 0 20px;
    flex: 1;
    font-style: italic;
}
.fabric-testimonial-card__author {
    display: flex;
    align-items: center;
    gap: 12px;
    border-top: 1px solid var(--color-border);
    padding-top: 16px;
}
.fabric-testimonial-card__avatar {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: var(--color-primary);
    color: var(--color-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    font-weight: 500;
    flex-shrink: 0;
}
.fabric-testimonial-card__meta { display: flex; flex-direction: column; gap: 2px; }
.fabric-testimonial-card__name {
    font-size: 13px;
    font-weight: 500;
    color: var(--color-primary);
}
.fabric-testimonial-card__tag {
    font-size: 11px;
    color: var(--color-muted);
}

/* ── Newsletter (UPGRADED — bigger surface) ─────────────────────────── */
.fabric-newsletter-section { padding: 56px 0; }
.fabric-newsletter {
    background: var(--color-surface);
    border-radius: 12px;
    padding: 56px 32px;
    text-align: center;
    max-width: 720px;
    margin: 0 auto;
}
.fabric-newsletter__eyebrow {
    font-size: 11px;
    color: var(--color-muted);
    letter-spacing: .14em;
    text-transform: uppercase;
    margin: 0 0 10px;
    font-weight: 500;
}
.fabric-newsletter__title {
    font-size: clamp(24px, 3.5vw, 32px);
    font-family: var(--font-heading, Georgia, serif);
    margin: 0 0 8px;
    font-weight: 400;
}
.fabric-newsletter__sub {
    font-size: 14px;
    color: var(--color-muted);
    margin: 0 0 24px;
    line-height: 1.6;
}
.fabric-newsletter__form {
    display: flex;
    gap: 8px;
    max-width: 440px;
    margin: 0 auto 12px;
}
.fabric-newsletter__input {
    flex: 1;
    padding: 12px 16px;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    font-size: 14px;
    background: var(--color-bg);
    color: var(--color-primary);
    transition: border-color .15s;
}
.fabric-newsletter__input:focus { outline: none; border-color: var(--color-primary); }
.fabric-newsletter__btn {
    padding: 12px 24px;
    background: var(--color-primary);
    color: var(--color-bg);
    border: none;
    border-radius: 4px;
    font-size: 12px;
    letter-spacing: .08em;
    text-transform: uppercase;
    cursor: pointer;
    white-space: nowrap;
    transition: opacity .15s;
}
.fabric-newsletter__btn:hover { opacity: .85; }
.fabric-newsletter__small {
    font-size: 11px;
    color: var(--color-muted);
    margin: 0;
}
.fabric-newsletter__message {
    margin: 12px 0 0;
    font-size: 13px;
    color: var(--color-muted);
}
.fabric-newsletter__message:empty { display: none; }

@media (max-width: 540px) {
    .fabric-newsletter { padding: 40px 20px; }
    .fabric-newsletter__form { flex-direction: column; }
}

/* ============================================================
   HELP CENTER PAGE
   ============================================================ */
.fabric-help-tabs-wrap { padding: 24px 0 0; }
.fabric-help-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    justify-content: center;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--color-border);
}
.fabric-help-tab {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 10px 18px;
    font-size: 13px;
    font-weight: 500;
    color: var(--color-muted);
    text-decoration: none;
    border: 1px solid transparent;
    border-radius: 24px;
    transition: all .15s;
    white-space: nowrap;
}
.fabric-help-tab:hover { color: var(--color-primary); background: var(--color-surface); }
.fabric-help-tab.is-active {
    background: var(--color-primary);
    color: var(--color-bg);
    border-color: var(--color-primary);
}
.fabric-help-tab span[aria-hidden] { font-size: 14px; }

@media (max-width: 640px) {
    .fabric-help-tabs { justify-content: flex-start; overflow-x: auto; padding-bottom: 12px; }
    .fabric-help-tab { padding: 8px 14px; font-size: 12px; }
}

.fabric-help-content { padding-top: 40px; padding-bottom: 40px; }
.fabric-help-panel { display: none; }
.fabric-help-panel.is-active { display: block; }
.fabric-help-panel__heading {
    font-size: clamp(24px, 3.5vw, 30px);
    margin: 0 0 8px;
    font-weight: 400;
    font-family: var(--font-heading, Georgia, serif);
}
.fabric-help-panel__intro {
    font-size: 14px;
    color: var(--color-muted);
    margin: 0 0 32px;
}
.fabric-help-panel h3 {
    font-size: 17px;
    margin: 32px 0 12px;
    color: var(--color-primary);
    font-weight: 500;
}
.fabric-help-panel p, .fabric-help-list { font-size: 14px; line-height: 1.7; color: var(--color-primary); margin: 0 0 14px; }
.fabric-help-list { padding-left: 20px; }
.fabric-help-list li { margin-bottom: 8px; }
.fabric-help-faq-group { margin-bottom: 36px; }
.fabric-help-faq-group__heading {
    font-size: 16px;
    margin: 0 0 16px;
    color: var(--color-primary);
    font-weight: 500;
}

.fabric-help-cta {
    text-align: center;
    padding: 48px 24px;
    background: var(--color-surface);
    border-radius: 12px;
    margin: 32px auto 64px;
    max-width: 720px;
}
.fabric-help-cta h3 { font-size: 20px; margin: 0 0 6px; }
.fabric-help-cta p { color: var(--color-muted); margin: 0 0 20px; font-size: 14px; }
.fabric-help-cta__buttons { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }

/* ============================================================
   TRACK ORDER PAGE
   ============================================================ */
.fabric-track-form { background: var(--color-surface); padding: 32px; border-radius: 8px; }
.fabric-track-help { text-align: center; margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--color-border); }
.fabric-track-help p { font-size: 13px; color: var(--color-muted); margin: 0 0 12px; }

.fabric-track-result { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: 12px; padding: 32px; }
.fabric-track-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; padding-bottom: 24px; border-bottom: 1px solid var(--color-border); margin-bottom: 24px; flex-wrap: wrap; }
.fabric-track-header__title { font-size: 20px; margin: 0 0 4px; }
.fabric-track-header__date { font-size: 13px; color: var(--color-muted); margin: 0; }

.fabric-track-status {
    padding: 6px 12px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .05em;
    text-transform: uppercase;
    background: #f4f4f4;
    color: #555;
}
.fabric-track-status--processing { background: #fef9c3; color: #854d0e; }
.fabric-track-status--shipped { background: #dbeafe; color: #1e40af; }
.fabric-track-status--completed,
.fabric-track-status--delivered { background: #dcfce7; color: #166534; }
.fabric-track-status--cancelled,
.fabric-track-status--refunded { background: #fee2e2; color: #991b1b; }

.fabric-track-timeline {
    display: flex;
    justify-content: space-between;
    position: relative;
    margin: 32px 0;
    padding: 0 16px;
}
.fabric-track-timeline::before {
    content: '';
    position: absolute;
    top: 16px;
    left: 32px;
    right: 32px;
    height: 2px;
    background: var(--color-border);
    z-index: 1;
}
.fabric-track-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    position: relative;
    z-index: 2;
    flex: 1;
    max-width: 100px;
}
.fabric-track-step__dot {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--color-bg);
    border: 2px solid var(--color-border);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    font-weight: 600;
    color: var(--color-muted);
}
.fabric-track-step.is-done .fabric-track-step__dot {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: var(--color-bg);
}
.fabric-track-step.is-current .fabric-track-step__dot {
    box-shadow: 0 0 0 4px rgba(0,0,0,.08);
}
.fabric-track-step__label {
    font-size: 11px;
    color: var(--color-muted);
    text-align: center;
}
.fabric-track-step.is-done .fabric-track-step__label { color: var(--color-primary); font-weight: 500; }

.fabric-track-items { display: flex; flex-direction: column; gap: 12px; }
.fabric-track-item { display: flex; gap: 14px; align-items: center; padding: 12px 0; border-bottom: 1px solid var(--color-border); }
.fabric-track-item:last-child { border-bottom: none; }
.fabric-track-item__thumb img { width: 60px; height: 60px; object-fit: cover; border-radius: 4px; }
.fabric-track-item__info { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.fabric-track-item__name { font-size: 14px; font-weight: 500; }
.fabric-track-item__qty { font-size: 12px; color: var(--color-muted); }
.fabric-track-item__price { font-size: 14px; font-weight: 500; }

.fabric-track-summary { margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--color-border); }
.fabric-track-summary__row { display: flex; justify-content: space-between; padding: 4px 0; font-size: 14px; }
.fabric-track-summary__row--total { font-size: 16px; font-weight: 600; padding-top: 12px; margin-top: 8px; border-top: 1px solid var(--color-border); }

.fabric-track-shipping { margin-top: 24px; padding-top: 24px; border-top: 1px solid var(--color-border); }
.fabric-track-shipping h4 { font-size: 13px; text-transform: uppercase; letter-spacing: .08em; color: var(--color-muted); margin: 0 0 6px; font-weight: 500; }
.fabric-track-shipping p { font-size: 14px; line-height: 1.6; margin: 0; }

.fabric-track-courier { margin-top: 24px; padding: 16px; background: var(--color-surface); border-radius: 6px; }
.fabric-track-courier p { margin: 0 0 12px; font-size: 14px; }

/* ============================================================
   CONTACT PAGE — Aliza-style
   ============================================================ */
.fabric-contact-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    margin-bottom: 56px;
}
@media (max-width: 800px) { .fabric-contact-cards { grid-template-columns: 1fr; } }

.fabric-contact-card {
    display: block;
    padding: 32px 24px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: 12px;
    text-align: center;
    text-decoration: none;
    color: var(--color-primary);
    transition: transform .25s, border-color .25s, box-shadow .25s;
}
.fabric-contact-card:hover {
    transform: translateY(-4px);
    border-color: var(--color-primary);
    box-shadow: 0 12px 32px rgba(0,0,0,.06);
}
.fabric-contact-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    background: var(--color-bg);
    border-radius: 50%;
    margin-bottom: 16px;
    color: var(--color-primary);
}
.fabric-contact-card__title { font-size: 18px; margin: 0 0 6px; font-family: var(--font-heading, Georgia, serif); font-weight: 400; }
.fabric-contact-card__desc { font-size: 13px; color: var(--color-muted); margin: 0 0 12px; line-height: 1.5; }
.fabric-contact-card__action {
    font-size: 11px;
    letter-spacing: .08em;
    text-transform: uppercase;
    border-bottom: 1px solid currentColor;
    padding-bottom: 2px;
}

.fabric-contact-layout {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 48px;
    align-items: start;
}
@media (max-width: 800px) { .fabric-contact-layout { grid-template-columns: 1fr; gap: 32px; } }

.fabric-contact-form-wrap { padding: 32px; background: var(--color-surface); border-radius: 12px; }
.fabric-contact-form-heading { font-size: 22px; margin: 0 0 24px; font-family: var(--font-heading, Georgia, serif); font-weight: 400; }

.fabric-contact-info { display: flex; flex-direction: column; gap: 24px; }
.fabric-contact-info__block { padding: 20px; background: var(--color-bg); border: 1px solid var(--color-border); border-radius: 8px; }
.fabric-contact-info__title {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--color-muted);
    margin: 0 0 10px;
}
.fabric-contact-info__block p { font-size: 14px; line-height: 1.6; margin: 0; color: var(--color-primary); }
.fabric-contact-info__link {
    display: inline-block;
    margin-top: 10px;
    font-size: 12px;
    color: var(--color-primary);
    border-bottom: 1px solid currentColor;
    padding-bottom: 1px;
    text-decoration: none;
}
.fabric-contact-info ul a { color: var(--color-primary); text-decoration: none; }
.fabric-contact-info ul a:hover { color: var(--color-accent); }

/* ============================================================
   ABOUT PAGE — Aliza-style with images
   ============================================================ */
.fabric-about-page { padding-bottom: 0; }

.fabric-about-hero {
    position: relative;
    min-height: 480px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    display: flex;
    align-items: center;
    color: #fff;
    padding: 80px 0;
}
.fabric-about-hero__content { max-width: 720px; }
.fabric-about-hero__eyebrow {
    font-size: 13px;
    letter-spacing: .14em;
    text-transform: uppercase;
    margin: 0 0 14px;
    color: rgba(255,255,255,0.85);
}
.fabric-about-hero__title {
    font-size: clamp(36px, 6vw, 64px);
    font-family: var(--font-heading, Georgia, serif);
    color: #fff;
    margin: 0 0 20px;
    font-weight: 400;
    line-height: 1.1;
}
.fabric-about-hero__title em {
    font-style: italic;
    background: linear-gradient(120deg, #f6c177, #e3955d);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.fabric-about-hero__sub {
    font-size: 16px;
    line-height: 1.7;
    color: rgba(255,255,255,0.9);
    max-width: 620px;
    margin: 0;
}

/* About stats strip */
.fabric-about-stats-section { padding: 48px 0; border-bottom: 1px solid var(--color-border); }
.fabric-about-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    text-align: center;
}
@media (max-width: 640px) { .fabric-about-stats { grid-template-columns: repeat(2, 1fr); } }
.fabric-about-stat__num {
    font-size: clamp(28px, 4vw, 42px);
    font-weight: 700;
    color: var(--color-primary);
    line-height: 1;
    margin-bottom: 6px;
    font-family: var(--font-heading, Georgia, serif);
}
.fabric-about-stat__label { font-size: 12px; letter-spacing: .08em; text-transform: uppercase; color: var(--color-muted); }

/* Founder section */
.fabric-about-founder { padding: 80px 0; }
.fabric-about-founder__layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: center;
}
@media (max-width: 800px) { .fabric-about-founder__layout { grid-template-columns: 1fr; gap: 32px; } }
.fabric-about-founder__image img {
    width: 100%;
    aspect-ratio: 4 / 5;
    object-fit: cover;
    border-radius: 8px;
}
.fabric-about-founder__content h2 em { font-style: italic; color: var(--color-accent, #c5a847); }
.fabric-about-founder__content p { font-size: 15px; line-height: 1.8; margin: 0 0 16px; color: var(--color-primary); }

/* Pillars */
.fabric-pillars-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}
@media (max-width: 900px) { .fabric-pillars-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .fabric-pillars-grid { grid-template-columns: 1fr; } }
.fabric-pillar-card {
    background: var(--color-bg);
    padding: 28px 24px;
    border-radius: 8px;
    border: 1px solid var(--color-border);
    text-align: center;
    transition: transform .2s, box-shadow .2s;
}
.fabric-pillar-card:hover { transform: translateY(-3px); box-shadow: 0 8px 24px rgba(0,0,0,.06); }
.fabric-pillar-card__icon { font-size: 32px; line-height: 1; margin-bottom: 14px; }
.fabric-pillar-card__title { font-size: 16px; margin: 0 0 8px; font-family: var(--font-heading, Georgia, serif); font-weight: 500; }
.fabric-pillar-card p { font-size: 13px; color: var(--color-muted); line-height: 1.6; margin: 0; }

/* Mission */
.fabric-about-mission { padding: 80px 0; }
.fabric-about-mission__layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: center;
}
@media (max-width: 800px) { .fabric-about-mission__layout { grid-template-columns: 1fr; gap: 32px; } .fabric-about-mission__image { order: -1; } }
.fabric-about-mission__image img {
    width: 100%;
    aspect-ratio: 4 / 5;
    object-fit: cover;
    border-radius: 8px;
}
.fabric-about-mission__content h2 em { font-style: italic; color: var(--color-accent, #c5a847); }
.fabric-about-mission__content p { font-size: 15px; line-height: 1.8; margin: 0 0 16px; }

/* Hero weaves with photos */
.fabric-hero-weaves-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
@media (max-width: 900px) { .fabric-hero-weaves-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .fabric-hero-weaves-grid { grid-template-columns: 1fr; } }
.fabric-hero-weave-card {
    background: var(--color-bg);
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid var(--color-border);
    transition: transform .25s, box-shadow .25s;
}
.fabric-hero-weave-card:hover { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(0,0,0,.08); }
.fabric-hero-weave-card__image { aspect-ratio: 4/3; overflow: hidden; }
.fabric-hero-weave-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .5s;
}
.fabric-hero-weave-card:hover .fabric-hero-weave-card__image img { transform: scale(1.05); }
.fabric-hero-weave-card__body { padding: 24px; text-align: center; }
.fabric-hero-weave-card__icon { font-size: 24px; display: block; margin-bottom: 8px; line-height: 1; }
.fabric-hero-weave-card__name { font-size: 18px; margin: 0 0 8px; font-family: var(--font-heading, Georgia, serif); font-weight: 500; }
.fabric-hero-weave-card__body p { font-size: 13px; color: var(--color-muted); line-height: 1.6; margin: 0; }

/* About loom photo strip */
.fabric-about-loom {
    background-size: cover;
    background-position: center;
    padding: 96px 0;
    text-align: center;
}
.fabric-about-loom__content { max-width: 720px; margin: 0 auto; }

/* ============================================================
   BLOG / JOURNAL ARCHIVE
   ============================================================ */
.fabric-blog-hero {
    padding: 64px 0 32px;
    text-align: center;
    border-bottom: 1px solid var(--color-border);
}
.fabric-blog-hero__title {
    font-size: clamp(32px, 5vw, 48px);
    font-family: var(--font-heading, Georgia, serif);
    margin: 0 0 12px;
    font-weight: 400;
}
.fabric-blog-hero__sub {
    font-size: 15px;
    color: var(--color-muted);
    max-width: 600px;
    margin: 0 auto;
    line-height: 1.7;
}

.fabric-blog-filter-wrap { padding: 24px 0 0; }
.fabric-blog-filter {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    justify-content: center;
}
.fabric-blog-filter__item {
    padding: 7px 16px;
    font-size: 13px;
    border: 1px solid var(--color-border);
    border-radius: 20px;
    color: var(--color-primary);
    text-decoration: none;
    transition: all .15s;
}
.fabric-blog-filter__item:hover, .fabric-blog-filter__item.is-active {
    background: var(--color-primary);
    color: var(--color-bg);
    border-color: var(--color-primary);
}

.fabric-blog-grid-wrap { padding: 40px 0 64px; }
.fabric-blog-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
}
@media (max-width: 900px) { .fabric-blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .fabric-blog-grid { grid-template-columns: 1fr; } }

.fabric-blog-card { transition: transform .2s; }
.fabric-blog-card:hover { transform: translateY(-3px); }
.fabric-blog-card__link { display: block; text-decoration: none; color: inherit; }
.fabric-blog-card__image {
    position: relative;
    aspect-ratio: 16/10;
    overflow: hidden;
    border-radius: 8px;
    margin-bottom: 16px;
}
.fabric-blog-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .5s;
}
.fabric-blog-card:hover .fabric-blog-card__image img { transform: scale(1.04); }
.fabric-blog-card__category {
    position: absolute;
    top: 12px;
    left: 12px;
    padding: 4px 10px;
    background: rgba(255,255,255,0.95);
    color: var(--color-primary);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: .04em;
    text-transform: uppercase;
    border-radius: 3px;
}
.fabric-blog-card__title {
    font-size: 18px;
    line-height: 1.3;
    margin: 0 0 10px;
    font-family: var(--font-heading, Georgia, serif);
    font-weight: 500;
}
.fabric-blog-card__excerpt {
    font-size: 13px;
    color: var(--color-muted);
    line-height: 1.6;
    margin: 0 0 12px;
}
.fabric-blog-card__meta {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 11px;
    color: var(--color-muted);
}
.fabric-blog-card__author {
    display: flex;
    align-items: center;
    gap: 6px;
}
.fabric-blog-card__author img { width: 22px; height: 22px; border-radius: 50%; }
.fabric-blog-card__date::before, .fabric-blog-card__readtime::before { content: '·'; margin-right: 8px; }

/* Featured (first) card spans 2 cols */
.fabric-blog-card--featured {
    grid-column: span 2;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    align-items: center;
}
@media (max-width: 900px) { .fabric-blog-card--featured { grid-column: span 2; grid-template-columns: 1fr; } }
@media (max-width: 540px) { .fabric-blog-card--featured { grid-column: span 1; } }
.fabric-blog-card--featured .fabric-blog-card__link {
    display: contents;
}
.fabric-blog-card--featured .fabric-blog-card__image { aspect-ratio: 4/3; margin-bottom: 0; }
.fabric-blog-card--featured .fabric-blog-card__title { font-size: 24px; line-height: 1.25; }
.fabric-blog-card--featured .fabric-blog-card__excerpt { font-size: 14px; }

.fabric-pagination {
    margin-top: 48px;
    display: flex;
    justify-content: center;
    gap: 6px;
    flex-wrap: wrap;
}
.fabric-pagination .page-numbers {
    padding: 8px 14px;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    color: var(--color-primary);
    text-decoration: none;
    font-size: 13px;
}
.fabric-pagination .page-numbers.current,
.fabric-pagination .page-numbers:hover {
    background: var(--color-primary);
    color: var(--color-bg);
    border-color: var(--color-primary);
}

.fabric-blog-empty { text-align: center; padding: 64px 24px; }

/* ============================================================
   COMPARE PRODUCTS PAGE
   ============================================================ */
.fabric-compare-empty { text-align: center; padding: 64px 24px; max-width: 560px; margin: 0 auto; }
.fabric-compare-empty__icon { color: var(--color-muted); margin-bottom: 24px; }
.fabric-compare-empty h2 { font-size: 24px; margin: 0 0 12px; }
.fabric-compare-empty p { color: var(--color-muted); margin: 0 0 24px; line-height: 1.6; }
.fabric-compare-tip {
    margin-top: 48px;
    padding: 24px;
    background: var(--color-surface);
    border-radius: 8px;
    text-align: left;
}
.fabric-compare-tip h3 { font-size: 14px; margin: 0 0 12px; }
.fabric-compare-tip ol { padding-left: 20px; font-size: 13px; color: var(--color-muted); line-height: 1.8; }

.fabric-compare-table-wrap { overflow-x: auto; }
.fabric-compare-table {
    width: 100%;
    min-width: 720px;
    border-collapse: collapse;
    background: var(--color-bg);
}
.fabric-compare-table th,
.fabric-compare-table td {
    padding: 16px;
    border-bottom: 1px solid var(--color-border);
    text-align: left;
    vertical-align: top;
}
.fabric-compare-table tbody tr:hover td,
.fabric-compare-table tbody tr:hover th { background: var(--color-surface); }

.fabric-compare-table__feature-col {
    width: 160px;
    background: var(--color-surface);
}
.fabric-compare-table__feature {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--color-muted);
    background: var(--color-surface);
    width: 160px;
}
.fabric-compare-table__value { font-size: 14px; }

.fabric-compare-product { position: relative; padding-top: 24px; min-width: 200px; max-width: 280px; }
.fabric-compare-product__link { display: block; text-decoration: none; color: inherit; text-align: center; }
.fabric-compare-product__thumb {
    aspect-ratio: 1;
    margin-bottom: 12px;
    overflow: hidden;
    border-radius: 6px;
}
.fabric-compare-product__thumb img { width: 100%; height: 100%; object-fit: cover; }
.fabric-compare-product__name {
    font-size: 14px;
    margin: 0;
    font-weight: 500;
    line-height: 1.3;
}
.fabric-compare-product__remove {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 24px;
    height: 24px;
    background: var(--color-surface);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-muted);
    text-decoration: none;
    font-size: 16px;
    line-height: 1;
}
.fabric-compare-product__remove:hover { background: var(--color-primary); color: var(--color-bg); }

/* ============================================================
   FABRICLORE-STYLE LAYOUT — Hero, Process, Lead, Brands, Team etc
   ============================================================ */

.fabric-main--no-pad { padding-top: 0; }

/* ── Hero v2 — full-bleed with overlay ──────────────────────────────── */
.fabric-hero-v2 {
    position: relative;
    min-height: 78vh;
    display: flex;
    align-items: center;
    color: #fff;
    overflow: hidden;
}
.fabric-hero-v2__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
}
.fabric-hero-v2__bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.fabric-hero-v2__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.25) 60%, rgba(0,0,0,0.15) 100%);
    z-index: 1;
}
.fabric-hero-v2--center .fabric-hero-v2__overlay {
    background: linear-gradient(180deg, rgba(0,0,0,0.4), rgba(0,0,0,0.55));
}
.fabric-hero-v2__container { position: relative; z-index: 2; padding: 80px 0; }
.fabric-hero-v2__content { max-width: 600px; }
.fabric-hero-v2--center .fabric-hero-v2__content { max-width: 720px; margin: 0 auto; text-align: center; }
.fabric-hero-v2__eyebrow {
    font-size: 12px;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.85);
    margin: 0 0 14px;
}
.fabric-hero-v2__title {
    font-size: clamp(36px, 6vw, 64px);
    font-family: var(--font-heading, Georgia, serif);
    font-weight: 400;
    line-height: 1.1;
    color: #fff;
    margin: 0 0 24px;
}
.fabric-hero-v2__bullets {
    list-style: none;
    padding: 0;
    margin: 0 0 32px;
}
.fabric-hero-v2__bullets li {
    font-size: 17px;
    line-height: 1.7;
    color: rgba(255,255,255,0.9);
    padding: 2px 0;
}
.fabric-hero-v2__cta {
    background: #fff;
    color: #1a1a1a;
    border: none;
    padding: 14px 28px;
    font-size: 13px;
    letter-spacing: .1em;
    text-transform: uppercase;
    text-decoration: none;
    border-radius: 2px;
    display: inline-block;
    transition: opacity .15s, transform .15s;
}
.fabric-hero-v2__cta:hover { opacity: .9; transform: translateY(-1px); }

@media (max-width: 640px) {
    .fabric-hero-v2 { min-height: 60vh; }
    .fabric-hero-v2__bullets li { font-size: 15px; }
}

/* ── Mission tagline ────────────────────────────────────────────────── */
.fabric-mission-tagline {
    padding: 56px 0;
    background: var(--color-bg);
    text-align: center;
}
.fabric-mission-tagline blockquote {
    margin: 0;
    max-width: 880px;
    margin: 0 auto;
    padding: 0 24px;
}
.fabric-mission-tagline p {
    font-size: clamp(20px, 2.6vw, 28px);
    font-family: var(--font-heading, Georgia, serif);
    font-style: italic;
    line-height: 1.5;
    color: var(--color-primary);
    margin: 0;
}

/* ── 4-step process ─────────────────────────────────────────────────── */
.fabric-process-section { padding: 0; background: var(--color-bg); }
.fabric-process-list { display: flex; flex-direction: column; }

.fabric-process-step {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: stretch;
    min-height: 440px;
}
.fabric-process-step--reverse .fabric-process-step__image { order: 2; }
.fabric-process-step--reverse .fabric-process-step__content { order: 1; }

.fabric-process-step__image {
    overflow: hidden;
    background: var(--color-surface);
}
.fabric-process-step__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    min-height: 380px;
}

.fabric-process-step__content {
    padding: 64px 56px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    background: var(--color-bg);
}
.fabric-process-step__num {
    font-size: 64px;
    font-family: var(--font-heading, Georgia, serif);
    color: var(--color-border);
    line-height: 1;
    margin-bottom: 16px;
    display: block;
}
.fabric-process-step__title {
    font-size: clamp(24px, 3vw, 32px);
    font-family: var(--font-heading, Georgia, serif);
    font-weight: 400;
    margin: 0 0 14px;
    line-height: 1.2;
}
.fabric-process-step__body {
    font-size: 15px;
    line-height: 1.7;
    color: var(--color-muted);
    margin: 0 0 20px;
    max-width: 520px;
}
.fabric-process-step__links {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
}
.fabric-process-step__link {
    font-size: 13px;
    color: var(--color-primary);
    text-decoration: none;
    transition: opacity .15s;
}
.fabric-process-step__link:hover { opacity: .65; }

@media (max-width: 800px) {
    .fabric-process-step,
    .fabric-process-step--reverse {
        grid-template-columns: 1fr;
        min-height: auto;
    }
    .fabric-process-step--reverse .fabric-process-step__image { order: 0; }
    .fabric-process-step--reverse .fabric-process-step__content { order: 0; }
    .fabric-process-step__content { padding: 40px 24px; }
    .fabric-process-step__image img { min-height: 240px; max-height: 320px; }
    .fabric-process-step__num { font-size: 48px; }
}

/* ── Lead form section ──────────────────────────────────────────────── */
.fabric-lead-section {
    padding: 80px 0;
    background: var(--color-surface);
}
.fabric-lead-section__layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: start;
    max-width: 1100px;
    margin: 0 auto;
}
@media (max-width: 800px) { .fabric-lead-section__layout { grid-template-columns: 1fr; gap: 32px; } }

.fabric-lead-section__intro h2 { margin-bottom: 12px; text-align: left; }
.fabric-lead-section__intro p { text-align: left; }
.fabric-lead-section__usps {
    list-style: none;
    padding: 24px 0 0;
    margin: 24px 0 0;
    border-top: 1px solid var(--color-border);
}
.fabric-lead-section__usps li {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    padding: 6px 0;
    color: var(--color-primary);
}
.fabric-lead-section__usps li span {
    color: #16a34a;
    font-weight: 600;
}

.fabric-lead-section__form-wrap {
    background: var(--color-bg);
    padding: 32px;
    border-radius: 12px;
    border: 1px solid var(--color-border);
}
.fabric-lead-section__or {
    text-align: center;
    margin: 14px 0;
    font-size: 12px;
    color: var(--color-muted);
    text-transform: uppercase;
    letter-spacing: .1em;
}
.fabric-lead-section__privacy {
    font-size: 11px;
    color: var(--color-muted);
    text-align: center;
    margin: 16px 0 0;
}

/* ── Service cards section ──────────────────────────────────────────── */
.fabric-services-section { padding: 80px 0; background: var(--color-bg); }
.fabric-services-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
@media (max-width: 800px) { .fabric-services-grid { grid-template-columns: 1fr; } }

.fabric-service-card {
    background: var(--color-bg);
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid var(--color-border);
    transition: transform .25s, box-shadow .25s;
}
.fabric-service-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(0,0,0,.08);
}
.fabric-service-card__image { aspect-ratio: 16/10; overflow: hidden; }
.fabric-service-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .5s;
}
.fabric-service-card:hover .fabric-service-card__image img { transform: scale(1.04); }
.fabric-service-card__body { padding: 24px; }
.fabric-service-card__title {
    font-size: 18px;
    font-family: var(--font-heading, Georgia, serif);
    font-weight: 500;
    margin: 0 0 8px;
}
.fabric-service-card__body p {
    font-size: 13px;
    line-height: 1.6;
    color: var(--color-muted);
    margin: 0;
}

/* ── Brand wall ─────────────────────────────────────────────────────── */
.fabric-brands-section {
    padding: 80px 0;
    background: var(--color-surface);
    overflow: hidden;
}
.fabric-brands-section__intro {
    text-align: center;
    margin-bottom: 56px;
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
}
.fabric-brands-section__num {
    font-size: clamp(56px, 9vw, 96px);
    font-family: var(--font-heading, Georgia, serif);
    font-weight: 400;
    color: var(--color-primary);
    margin: 0;
    line-height: 1;
}
.fabric-brands-section__quote {
    font-style: italic;
    color: var(--color-muted);
    margin: 16px 0 0;
}
.fabric-brands-section__quote p {
    font-size: 17px;
    line-height: 1.6;
    margin: 0;
}

.fabric-brands-marquee {
    overflow: hidden;
    position: relative;
    mask-image: linear-gradient(90deg, transparent, #000 80px, #000 calc(100% - 80px), transparent);
    -webkit-mask-image: linear-gradient(90deg, transparent, #000 80px, #000 calc(100% - 80px), transparent);
}
.fabric-brands-marquee__track {
    display: flex;
    gap: 48px;
    animation: fabric-brands-scroll 36s linear infinite;
    width: max-content;
}
@keyframes fabric-brands-scroll {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}
.fabric-brand-tile {
    flex: 0 0 auto;
    height: 100px;
    width: 200px;
    background: var(--color-bg);
    border-radius: 6px;
    border: 1px solid var(--color-border);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px;
}
.fabric-brand-tile img {
    max-width: 100%;
    max-height: 60px;
    object-fit: contain;
    filter: grayscale(1);
    opacity: .65;
    transition: filter .3s, opacity .3s;
}
.fabric-brand-tile:hover img { filter: grayscale(0); opacity: 1; }
.fabric-brand-tile__name {
    font-family: var(--font-heading, Georgia, serif);
    font-size: 18px;
    color: var(--color-muted);
    letter-spacing: .04em;
}

/* ── Why Choose Us ──────────────────────────────────────────────────── */
.fabric-why-section {
    padding: 96px 0;
    background-size: cover;
    background-position: center;
    background-attachment: scroll;
    color: #fff;
}
.fabric-why-section__title {
    color: #fff;
    text-align: center;
    font-size: clamp(28px, 4vw, 40px);
    font-family: var(--font-heading, Georgia, serif);
    font-weight: 400;
    max-width: 800px;
    margin: 0 auto 56px;
    line-height: 1.2;
}
.fabric-why-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
    max-width: 1100px;
    margin: 0 auto;
}
@media (max-width: 800px) { .fabric-why-grid { grid-template-columns: 1fr; gap: 24px; } }
.fabric-why-card {
    padding: 28px;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 8px;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}
.fabric-why-card__num {
    font-size: 36px;
    font-family: var(--font-heading, Georgia, serif);
    color: rgba(255,255,255,0.4);
    line-height: 1;
    display: block;
    margin-bottom: 12px;
}
.fabric-why-card__title {
    font-size: 18px;
    color: #fff;
    margin: 0 0 10px;
    font-family: var(--font-heading, Georgia, serif);
    font-weight: 500;
}
.fabric-why-card p {
    font-size: 14px;
    line-height: 1.7;
    color: rgba(255,255,255,0.8);
    margin: 0;
}

/* ── Team CTA ────────────────────────────────────────────────────────── */
.fabric-team-cta { padding: 80px 0; background: var(--color-bg); }
.fabric-team-cta__layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 56px;
    align-items: center;
    max-width: 1100px;
    margin: 0 auto;
}
@media (max-width: 800px) {
    .fabric-team-cta__layout { grid-template-columns: 1fr; gap: 32px; }
    .fabric-team-cta__image { order: -1; }
}
.fabric-team-cta__title {
    font-size: clamp(26px, 3.5vw, 36px);
    font-family: var(--font-heading, Georgia, serif);
    font-weight: 400;
    line-height: 1.2;
    margin: 0 0 16px;
}
.fabric-team-cta__body {
    font-size: 15px;
    line-height: 1.8;
    color: var(--color-muted);
    margin: 0 0 24px;
}
.fabric-team-cta__image img {
    width: 100%;
    aspect-ratio: 1;
    object-fit: cover;
    border-radius: 8px;
}

/* ── Sustainability marquee ──────────────────────────────────────────── */
.fabric-sustain-marquee {
    background: #1a1a1a;
    color: rgba(255,255,255,0.7);
    overflow: hidden;
    padding: 18px 0;
}
.fabric-sustain-marquee__track {
    display: flex;
    gap: 56px;
    animation: fabric-sustain-scroll 30s linear infinite;
    white-space: nowrap;
    width: max-content;
}
@keyframes fabric-sustain-scroll {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}
.fabric-sustain-marquee__item {
    font-size: 14px;
    letter-spacing: .12em;
    text-transform: uppercase;
    flex: 0 0 auto;
}

/* ── Sticky WhatsApp FAB ─────────────────────────────────────────────── */
.fabric-whatsapp-fab {
    position: fixed;
    bottom: 24px;
    right: 24px;
    background: #25D366;
    color: #fff !important;
    border-radius: 999px;
    padding: 14px;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    text-decoration: none !important;
    font-size: 14px;
    font-weight: 500;
    box-shadow: 0 8px 24px rgba(37, 211, 102, 0.35);
    z-index: 9999;
    transition: transform .2s, box-shadow .2s;
}
.fabric-whatsapp-fab:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 32px rgba(37, 211, 102, 0.45);
}
.fabric-whatsapp-fab__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.fabric-whatsapp-fab__label { line-height: 1; }
@media (max-width: 540px) {
    .fabric-whatsapp-fab { padding: 14px; }
    .fabric-whatsapp-fab__label { display: none; }
}

/* ── Experience Studio page ──────────────────────────────────────────── */
.fabric-studio-hero {
    min-height: 460px;
    background-size: cover;
    background-position: center;
    color: #fff;
    display: flex;
    align-items: center;
    padding: 80px 0;
}
.fabric-studio-hero__title {
    font-size: clamp(36px, 6vw, 56px);
    color: #fff;
    margin: 0 0 16px;
    font-family: var(--font-heading, Georgia, serif);
    font-weight: 400;
}
.fabric-studio-hero__sub {
    font-size: 17px;
    color: rgba(255,255,255,0.9);
    max-width: 600px;
    line-height: 1.7;
    margin: 0 0 28px;
}
.fabric-studio-hero__cta { display: flex; gap: 12px; flex-wrap: wrap; }

.fabric-studio-features {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}
@media (max-width: 900px) { .fabric-studio-features { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .fabric-studio-features { grid-template-columns: 1fr; } }
.fabric-studio-feature {
    padding: 24px 20px;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    text-align: center;
}
.fabric-studio-feature__icon { font-size: 32px; display: block; margin-bottom: 12px; }
.fabric-studio-feature__title {
    font-size: 16px;
    margin: 0 0 8px;
    font-family: var(--font-heading, Georgia, serif);
    font-weight: 500;
}
.fabric-studio-feature p { font-size: 13px; color: var(--color-muted); line-height: 1.6; margin: 0; }

.fabric-studio-info-layout {
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    gap: 56px;
    align-items: start;
}
@media (max-width: 800px) { .fabric-studio-info-layout { grid-template-columns: 1fr; } }

.fabric-studio-info__block {
    padding: 16px 0;
    border-bottom: 1px solid var(--color-border);
}
.fabric-studio-info__block:last-of-type { border-bottom: none; }
.fabric-studio-info__block h4 {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--color-muted);
    margin: 0 0 8px;
}
.fabric-studio-info__block p { font-size: 15px; line-height: 1.6; margin: 0; }
.fabric-studio-info__block a { color: var(--color-primary); }
.fabric-studio-info__cta { margin-top: 24px; }

/* ── Team page ────────────────────────────────────────────────────────── */
.fabric-team-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}
@media (max-width: 900px) { .fabric-team-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .fabric-team-grid { grid-template-columns: 1fr; } }

.fabric-team-grid--leaders { grid-template-columns: repeat(3, 1fr); max-width: 1000px; margin: 0 auto; }
@media (max-width: 800px) { .fabric-team-grid--leaders { grid-template-columns: 1fr; } }

.fabric-team-card { text-align: center; }
.fabric-team-card__image {
    aspect-ratio: 4/5;
    border-radius: 8px;
    overflow: hidden;
    margin-bottom: 14px;
}
.fabric-team-card__image--small { aspect-ratio: 1; }
.fabric-team-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .5s;
}
.fabric-team-card:hover .fabric-team-card__image img { transform: scale(1.04); }
.fabric-team-card__name {
    font-size: 17px;
    font-family: var(--font-heading, Georgia, serif);
    font-weight: 500;
    margin: 0 0 4px;
}
.fabric-team-card__name--sm { font-size: 14px; }
.fabric-team-card__role {
    font-size: 12px;
    color: var(--color-muted);
    text-transform: uppercase;
    letter-spacing: .06em;
    margin: 0 0 10px;
}
.fabric-team-card__bio {
    font-size: 13px;
    color: var(--color-muted);
    line-height: 1.6;
    margin: 0;
}

/* ── Careers page ─────────────────────────────────────────────────────── */
.fabric-careers-perks {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}
@media (max-width: 900px) { .fabric-careers-perks { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .fabric-careers-perks { grid-template-columns: 1fr; } }
.fabric-careers-perk {
    padding: 24px 20px;
    background: var(--color-surface);
    border-radius: 8px;
    text-align: center;
}
.fabric-careers-perk__icon { font-size: 32px; display: block; margin-bottom: 12px; }
.fabric-careers-perk h3 {
    font-size: 15px;
    margin: 0 0 8px;
    font-family: var(--font-heading, Georgia, serif);
    font-weight: 500;
}
.fabric-careers-perk p { font-size: 13px; color: var(--color-muted); line-height: 1.6; margin: 0; }

.fabric-jobs-list { display: flex; flex-direction: column; gap: 14px; max-width: 880px; margin: 0 auto; }
.fabric-job-card {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 24px;
    padding: 24px;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    transition: border-color .15s, box-shadow .15s;
}
.fabric-job-card:hover { border-color: var(--color-primary); box-shadow: 0 4px 16px rgba(0,0,0,.06); }
.fabric-job-card__main { flex: 1; }
.fabric-job-card__title {
    font-size: 17px;
    margin: 0 0 4px;
    font-family: var(--font-heading, Georgia, serif);
    font-weight: 500;
}
.fabric-job-card__meta {
    font-size: 12px;
    color: var(--color-muted);
    margin: 0 0 8px;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.fabric-job-card__desc { font-size: 13px; color: var(--color-muted); line-height: 1.6; margin: 0; }
@media (max-width: 600px) {
    .fabric-job-card { flex-direction: column; align-items: flex-start; }
}

/* ── In The News page ─────────────────────────────────────────────────── */
.fabric-press-logos {
    display: flex;
    flex-wrap: wrap;
    gap: 32px;
    justify-content: center;
    align-items: center;
}
.fabric-press-logo {
    font-family: var(--font-heading, Georgia, serif);
    font-size: 16px;
    color: var(--color-muted);
    letter-spacing: .04em;
    padding: 8px 16px;
    border-bottom: 1px solid transparent;
    transition: color .15s, border-color .15s;
}

.fabric-news-list { display: flex; flex-direction: column; gap: 24px; }
.fabric-news-item {
    display: grid;
    grid-template-columns: 80px 1fr;
    gap: 24px;
    padding: 24px;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: 8px;
}
@media (max-width: 600px) { .fabric-news-item { grid-template-columns: 1fr; } }
.fabric-news-item__logo {
    width: 80px;
    height: 80px;
    border-radius: 8px;
    overflow: hidden;
    background: var(--color-surface);
}
.fabric-news-item__logo img { width: 100%; height: 100%; object-fit: cover; }
.fabric-news-item__meta {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 12px;
    color: var(--color-muted);
    margin: 0 0 8px;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.fabric-news-item__outlet { font-weight: 600; }
.fabric-news-item__date::before { content: '·'; margin-right: 8px; }
.fabric-news-item__title {
    font-size: 18px;
    margin: 0 0 8px;
    font-family: var(--font-heading, Georgia, serif);
    font-weight: 500;
    line-height: 1.3;
}
.fabric-news-item__title a { color: inherit; text-decoration: none; }
.fabric-news-item__title a:hover { color: var(--color-accent); }
.fabric-news-item__excerpt {
    font-size: 14px;
    line-height: 1.7;
    color: var(--color-muted);
    margin: 0 0 8px;
}
.fabric-news-item__link {
    font-size: 13px;
    color: var(--color-primary);
    text-decoration: none;
    border-bottom: 1px solid currentColor;
    padding-bottom: 1px;
}

/* ── btn--lg variation ────────────────────────────────────────────────── */
.btn--lg { padding: 14px 28px; font-size: 13px; }

/* ============================================================
   PAGE HERO — UNIFIED FIX (overrides all earlier conflicting rules)
   This block goes LAST in the file so it wins specificity battles.
   ============================================================ */
.fabric-page-hero,
main .fabric-page-hero {
    position: relative;
    background: var(--color-surface, #f7f5f0);
    color: var(--color-primary, #1a1a1a);
    padding: 56px 24px;
    min-height: 0;
    height: auto;
    display: block;
    overflow: hidden;
    border-bottom: 1px solid var(--color-border, #e5e2db);
    text-align: left;
    align-items: initial;
    justify-content: initial;
}
.fabric-page-hero--short,
main .fabric-page-hero--short {
    padding: 40px 24px;
}
.fabric-page-hero .container,
main .fabric-page-hero .container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0;
    text-align: left;
}
.fabric-page-hero__eyebrow,
main .fabric-page-hero__eyebrow {
    display: block;
    font-size: 12px;
    color: var(--color-muted, #777) !important;
    letter-spacing: .14em;
    text-transform: uppercase;
    margin: 0 0 10px;
    font-weight: 500;
    text-align: left;
    padding: 0;
}
.fabric-page-hero__title,
main .fabric-page-hero__title {
    position: relative;
    color: var(--color-primary, #1a1a1a) !important;
    font-size: clamp(28px, 4.2vw, 44px);
    font-family: var(--font-heading, Georgia, serif);
    font-weight: 400 !important;
    letter-spacing: -0.01em;
    line-height: 1.15;
    margin: 0 0 12px;
    padding: 0;
    text-align: left;
    text-shadow: none;
}
.fabric-page-hero__sub,
main .fabric-page-hero__sub {
    font-size: 15px;
    color: var(--color-muted, #666) !important;
    max-width: 620px;
    line-height: 1.6;
    margin: 0;
    text-align: left;
}
.fabric-page-hero__bg,
main .fabric-page-hero__bg {
    display: none !important;
}

/* Mobile */
@media (max-width: 600px) {
    .fabric-page-hero,
    main .fabric-page-hero { padding: 40px 20px; }
    .fabric-page-hero--short,
    main .fabric-page-hero--short { padding: 32px 20px; }
    .fabric-page-hero__title,
    main .fabric-page-hero__title { font-size: clamp(24px, 6vw, 32px); }
}

/* Keep the special photo-overlay heroes working (About hero, Studio hero, Loom strip)
   These have their own classes, NOT .fabric-page-hero, so they're untouched.
   But just in case any inherited dark variant exists, scope it: */
.fabric-page-hero.fabric-page-hero--dark {
    background: #0f1623;
    color: #fff;
}
.fabric-page-hero.fabric-page-hero--dark .fabric-page-hero__title,
.fabric-page-hero.fabric-page-hero--dark .fabric-page-hero__eyebrow,
.fabric-page-hero.fabric-page-hero--dark .fabric-page-hero__sub {
    color: #fff !important;
}
.fabric-page-hero.fabric-page-hero--dark .fabric-page-hero__eyebrow { color: rgba(255,255,255,0.75) !important; }
.fabric-page-hero.fabric-page-hero--dark .fabric-page-hero__sub     { color: rgba(255,255,255,0.85) !important; }

/* ============================================================
   WORDPRESS NAV MENU OUTPUT — keep styling consistent
   wp_nav_menu adds extra classes (menu-item, page_item etc).
   These rules make the output look identical to hard-coded markup.
   ============================================================ */

/* Header primary nav — wp_nav_menu fallback for menu-item class */
.fabric-nav__list .menu-item,
.fabric-nav__list .page_item {
    list-style: none;
}
.fabric-nav__list .menu-item > a,
.fabric-nav__list .page_item > a {
    /* Inherit the .fabric-nav__link styling */
    display: block;
    padding: 8px 14px;
    font-size: 13px;
    color: var(--color-primary, #1a1a1a);
    text-decoration: none;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    transition: color .15s;
}
.fabric-nav__list .menu-item > a:hover,
.fabric-nav__list .page_item > a:hover {
    color: var(--color-accent, #c5a847);
}

/* Submenu support — dropdown */
.fabric-nav__list .sub-menu,
.fabric-nav__list .children {
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 200px;
    background: var(--color-bg, #fff);
    border: 1px solid var(--color-border, #e5e2db);
    box-shadow: 0 8px 24px rgba(0,0,0,0.08);
    padding: 8px 0;
    list-style: none;
    margin: 0;
    opacity: 0;
    visibility: hidden;
    transform: translateY(4px);
    transition: opacity .2s, transform .2s, visibility .2s;
    z-index: 200;
}
.fabric-nav__list .menu-item-has-children,
.fabric-nav__list .page_item_has_children {
    position: relative;
}
.fabric-nav__list .menu-item-has-children:hover > .sub-menu,
.fabric-nav__list .menu-item-has-children:focus-within > .sub-menu,
.fabric-nav__list .page_item_has_children:hover > .children,
.fabric-nav__list .page_item_has_children:focus-within > .children {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.fabric-nav__list .sub-menu > li > a,
.fabric-nav__list .children > li > a {
    padding: 10px 16px;
    text-transform: none;
    letter-spacing: 0;
    font-size: 13px;
    display: block;
}
.fabric-nav__list .sub-menu > li > a:hover,
.fabric-nav__list .children > li > a:hover {
    background: var(--color-surface, #f7f5f0);
}

/* Mobile nav — wp_nav_menu output */
.fabric-mobile-nav__list {
    list-style: none;
    padding: 0;
    margin: 0;
}
.fabric-mobile-nav__list > li {
    border-bottom: 1px solid var(--color-border, #e5e2db);
}
.fabric-mobile-nav__list > li > a {
    display: block;
    padding: 14px 24px;
    font-size: 15px;
    color: var(--color-primary, #1a1a1a);
    text-decoration: none;
    transition: background .1s;
}
.fabric-mobile-nav__list > li > a:hover {
    background: var(--color-surface, #f7f5f0);
}
.fabric-mobile-nav__list .sub-menu,
.fabric-mobile-nav__list .children {
    list-style: none;
    padding: 0 0 12px 24px;
    margin: 0;
    background: var(--color-surface, #f7f5f0);
}
.fabric-mobile-nav__list .sub-menu > li > a,
.fabric-mobile-nav__list .children > li > a {
    display: block;
    padding: 8px 24px 8px 0;
    font-size: 14px;
    color: var(--color-primary, #1a1a1a);
    text-decoration: none;
}

/* Footer menus — wp_nav_menu output */
.fabric-footer__menu {
    list-style: none;
    padding: 0;
    margin: 0;
}
.fabric-footer__menu .menu-item,
.fabric-footer__menu .page_item,
.fabric-footer__menu li {
    list-style: none;
    margin: 0 0 8px;
}
.fabric-footer__menu a {
    color: rgba(255, 255, 255, 0.7);
    text-decoration: none;
    font-size: 13px;
    line-height: 1.5;
    transition: color .15s;
}
.fabric-footer__menu a:hover {
    color: #fff;
}

/* Footer bottom legal menu */
.fabric-footer__bottom-menu {
    list-style: none;
    padding: 0;
    margin: 0;
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0;
}
.fabric-footer__bottom-menu li {
    list-style: none;
    display: inline-block;
}
.fabric-footer__bottom-menu li:not(:last-child)::after {
    content: '·';
    margin: 0 10px;
    color: rgba(255, 255, 255, 0.4);
}
.fabric-footer__bottom-menu a {
    color: rgba(255, 255, 255, 0.6);
    text-decoration: none;
    font-size: 12px;
}
.fabric-footer__bottom-menu a:hover {
    color: #fff;
}

/* Current/active menu item indicator */
.fabric-nav__list .current-menu-item > a,
.fabric-nav__list .current_page_item > a {
    color: var(--color-accent, #c5a847);
    font-weight: 600;
}

/* ── Footer Contact column ── */
.fabric-footer__contact-list { list-style: none; padding: 0; margin: 0; }
.fabric-footer__contact-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 12px;
    font-size: 14px;
    line-height: 1.5;
    color: inherit;
}
.fabric-footer__contact-item a {
    color: inherit;
    text-decoration: none;
    transition: opacity 0.2s ease;
}
.fabric-footer__contact-item a:hover { opacity: 0.7; }

/* ── Modern Script applied ONLY to logo / site name ── */
.fabric-header__logo,
.fabric-header__logo a,
.fabric-header__logo span,
.site-title,
.site-title a {
  font-family: 'Modern Script', Georgia, cursive !important;
}

/* ============================================================================
   GOLD ACCENTS — Champagne gold (#c5a572) added sparingly across the site
   ============================================================================ */
:root {
  --color-gold: #c5a572;
  --color-gold-soft: #d4b88a;
  --color-gold-deep: #a88c5d;
}

/* ── 1. HOME PAGE — Hero button static gold, black on hover ───────────── */
.maison-home .maison-btn--ghost {
  border-color: var(--color-gold) !important;
  color: var(--color-gold) !important;
  background: transparent !important;
}
.maison-home .maison-btn--ghost:hover {
  background: #1a1a1a !important;
  border-color: #1a1a1a !important;
  color: #ffffff !important;
}

/* ── 2. HOME PAGE — Section dividers (Our Philosophy / Get in Touch) ──── */
.maison-home .maison-divider {
  background: var(--color-gold) !important;
  opacity: 1 !important;
  width: 60px !important;
}

/* ── 3. HOME PAGE — View All Fabrics button static gold, black on hover ── */
.maison-home .maison-btn--outline {
  color: var(--color-gold) !important;
  background: transparent !important;
  border-color: var(--color-gold) !important;
}
.maison-home .maison-btn--outline:hover {
  background: #1a1a1a !important;
  border-color: #1a1a1a !important;
  color: #ffffff !important;
}

/* ── 4. HOME PAGE — Featured Collection card titles gold on hover ─────── */
.maison-home .maison-collection-item__link:hover .maison-collection-item__title {
  color: var(--color-gold) !important;
  transition: color .25s ease;
}
.maison-home .maison-collection-item__title {
  transition: color .25s ease;
}

/* ── 5. HOME PAGE — Get in Touch email/phone link hover ───────────────── */
.maison-home .maison-contact__line a:hover {
  color: var(--color-gold) !important;
  border-bottom-color: var(--color-gold) !important;
}

/* ── 6. ABOUT PAGE — Section divider + CTA button gold border ─────────── */
.about-page .maison-divider,
.about-page .about-divider {
  background: var(--color-gold) !important;
  opacity: 1 !important;
}
.about-page .about-btn {
  border-color: var(--color-gold) !important;
  color: var(--color-gold) !important;
  background: transparent !important;
}
.about-page .about-btn:hover {
  background: #1a1a1a !important;
  border-color: #1a1a1a !important;
  color: #ffffff !important;
}
.about-page .about-card:hover {
  border-color: var(--color-gold) !important;
}
.about-page .about-card:hover .about-card__title {
  color: var(--color-gold) !important;
  transition: color .25s ease;
}

/* ── 7. FABRICS PAGE — Card hover, static gold buttons, black on hover ── */
.fabrics-page .fabric-card:hover {
  border-color: var(--color-gold) !important;
}
.fabrics-page .fabric-card:hover .fabric-card__title {
  color: var(--color-gold) !important;
  transition: color .25s ease;
}
.fabrics-page .fabric-card__btn {
  border-color: var(--color-gold) !important;
  color: var(--color-gold) !important;
  background: transparent !important;
}
.fabrics-page .fabric-card__btn:hover {
  background: #1a1a1a !important;
  border-color: #1a1a1a !important;
  color: #ffffff !important;
}
.fabrics-page .fabrics-cta__btn {
  border-color: var(--color-gold) !important;
  color: var(--color-gold) !important;
  background: transparent !important;
}
.fabrics-page .fabrics-cta__btn:hover {
  background: #ffffff !important;
  border-color: #ffffff !important;
  color: #1a1a1a !important;
}

/* ── 8. SHOP PAGE — Product card hover, active chip, ADD TO CART hover ── */
.shop-page .shop-product__title a:hover {
  color: var(--color-gold) !important;
}
.shop-page .shop-chip.is-active {
  background: var(--color-gold) !important;
  border-color: var(--color-gold) !important;
  color: #ffffff !important;
}
.shop-page .shop-product__atc {
  border-color: var(--color-gold) !important;
  color: var(--color-gold) !important;
  background: transparent !important;
}
.shop-page .shop-product__atc:hover {
  background: #1a1a1a !important;
  border-color: #1a1a1a !important;
  color: #ffffff !important;
}
.shop-page .shop-pagination .page-numbers.current,
.shop-page .shop-pagination .page-numbers:hover {
  background: var(--color-gold) !important;
  border-color: var(--color-gold) !important;
  color: #ffffff !important;
}

/* ── 9. SINGLE PRODUCT — Buy Now button gold static, black on hover ──── */
.sp-page .sp-btn--solid {
  background: var(--color-gold) !important;
  border-color: var(--color-gold) !important;
  color: #ffffff !important;
}
.sp-page .sp-btn--solid:hover {
  background: #1a1a1a !important;
  border-color: #1a1a1a !important;
  color: #ffffff !important;
}
.sp-page .sp-btn--outline {
  border-color: var(--color-gold) !important;
  color: var(--color-gold) !important;
}
.sp-page .sp-btn--outline:hover {
  background: #1a1a1a !important;
  border-color: #1a1a1a !important;
  color: #ffffff !important;
}
.sp-page .sp-gallery__badge {
  background: var(--color-gold) !important;
}
.sp-page .sp-gallery__thumb.is-active,
.sp-page .sp-gallery__thumb:hover {
  border-color: var(--color-gold) !important;
}

/* ── 10. HEADER — Active nav link gold underline ──────────────────────── */
.fabric-header .fabric-nav__item.current-menu-item .fabric-nav__link,
.fabric-header .fabric-nav__link:hover {
  color: var(--color-gold) !important;
  position: relative;
}
.fabric-header .fabric-nav__link {
  transition: color .2s ease;
}

/* ── 11. FOOTER — Contact item hover gold ─────────────────────────────── */
.fabric-footer__contact-item a:hover {
  color: var(--color-gold) !important;
  opacity: 1 !important;
}
.fabric-footer__menu a:hover {
  color: var(--color-gold) !important;
}

/* ── 12. LOGO — Subtle gold underline accent on hover ─────────────────── */
.fabric-header__logo a:hover {
  color: var(--color-gold) !important;
  transition: color .2s ease;
}

/* ── 13. ADDITIONAL STATIC GOLD ACCENTS ───────────────────────────────── */
/* Make all WooCommerce/theme prices permanently gold */
.price,
.price .amount,
.amount,
.sp-info__price,
.fabric-product-card__price,
.fabric-product-info__price,
.woocommerce-Price-amount {
  color: var(--color-gold, #c5a572) !important;
}

/* Make the wishlist heart icon in header permanently gold */
.fabric-header__actions a[href*="wishlist"] svg {
  stroke: var(--color-gold, #c5a572) !important;
}

