/*
Theme Name: Tristar Marble
Author: VMK Solutions
Version: 1.0
Description: Custom B2B theme for Tristar Marble — factory-direct quartz supply & procurement.
*/

/* Self-hosted display face (URW Gothic) for headings */
@font-face {
  font-family: 'Tristar Display';
  src: url('assets/fonts/urwgothic-400.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Tristar Display';
  src: url('assets/fonts/urwgothic-700.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

:root {
  --ink: #1A1A1A;
  --charcoal: #333333;
  --slate: #616161;
  --greige: #EFEEEA;
  --mist: #E3E1DC;
  --white: #FFFFFF;
}

/* Reset */
*,
*::before,
*::after {
  box-sizing: border-box;
}

* {
  margin: 0;
  padding: 0;
}

/* Base */
body {
  font-family: "Inter", system-ui, sans-serif;
  color: var(--slate);
  background: var(--white);
  line-height: 1.6;
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  color: var(--charcoal);
}

/* Layout */
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
}

/* Overline */
.overline {
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  font-weight: 500;
  font-size: 13px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--charcoal);
}

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-family: "Inter", sans-serif;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 15px 32px;
  border-radius: 0;
  text-decoration: none;
  transition: .2s;
}

.btn svg {
  display: block;
  flex: 0 0 auto;
}

.btn-primary {
  background: var(--charcoal);
  color: #fff;
}

.btn-primary:hover {
  background: var(--ink);
}

.btn-ghost {
  background: transparent;
  border: 1px solid var(--charcoal);
  color: var(--charcoal);
}

.btn-ghost:hover {
  background: var(--charcoal);
  color: #fff;
}

/* White-bordered ghost for dark backgrounds */
.btn-ghost-invert {
  background: transparent;
  border: 1px solid var(--white);
  color: var(--white);
}

.btn-ghost-invert:hover {
  background: var(--white);
  color: var(--charcoal);
}

/* ---------------------------------------------------------
   Site Header
--------------------------------------------------------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--white);
  border-bottom: 1px solid var(--mist);
  padding: 14px 0;
}

.site-header .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

/* Logo image */
.site-logo {
  text-decoration: none;
  display: inline-block;
  line-height: 0;
}

.site-logo img {
  display: block;
  height: 42px;
  width: auto;
}

/* Primary nav */
.nav-list {
  display: flex;
  gap: 30px;
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0;
}

.nav-list > li {
  position: relative;
}

.nav-list a {
  font-family: "Inter", sans-serif;
  font-size: 14px;
  letter-spacing: .02em;
  color: #616161;
  text-decoration: none;
  white-space: nowrap;
}

.nav-list a:hover {
  color: #333333;
}

.has-dropdown > a::after {
  content: "\25BE";
  font-size: 9px;
  margin-left: 6px;
  color: #9a968f;
  vertical-align: middle;
}

.dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  background: #FFFFFF;
  border: 1px solid #E3E1DC;
  min-width: 215px;
  padding: 8px 0;
  display: none;
  z-index: 60;
  box-shadow: 0 10px 26px rgba(0, 0, 0, .07);
}

.dropdown li {
  list-style: none;
}

.dropdown a {
  display: block;
  padding: 11px 18px;
  font-size: 13.5px;
  color: #616161;
}

.dropdown a:hover {
  background: #F5F0E8;
  color: #333333;
}

.has-dropdown:hover .dropdown {
  display: block;
}

.header-cta {
  flex-shrink: 0;
  padding: 11px 24px;
  font-size: 13px;
}

/* Hamburger */
.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: space-between;
  width: 28px;
  height: 20px;
  background: transparent;
  border: 0;
  cursor: pointer;
  padding: 0;
}

.nav-toggle span {
  display: block;
  height: 2px;
  width: 100%;
  background: var(--charcoal);
  transition: .2s;
}

/* ---------------------------------------------------------
   Hero
--------------------------------------------------------- */
.hero {
  position: relative;
  width: 100%;
  min-height: 70vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  background:
    linear-gradient(rgba(26,26,26,.55), rgba(26,26,26,.45)),
    url('assets/hero.jpg') center/cover no-repeat,
    #2a2724;
}

.hero .container {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding-top: 0;
  padding-bottom: 0;
}

.hero-eyebrow {
  font-family: "Inter", sans-serif;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: rgba(255,255,255,.85);
}

.hero h1 {
  font-family: 'Tristar Display', sans-serif;
  font-weight: 600;
  font-size: clamp(32px, 4.2vw, 52px);
  line-height: 1.08;
  color: #fff;
  max-width: 880px;
  margin-top: 18px;
  margin-left: auto;
  margin-right: auto;
}

.hero p {
  font-family: "Inter", sans-serif;
  font-size: 18px;
  line-height: 1.6;
  color: rgba(255,255,255,.85);
  max-width: 500px;
  margin-top: 20px;
  margin-left: auto;
  margin-right: auto;
}

.hero .btn-row {
  display: flex;
  gap: 16px;
  margin-top: 34px;
  flex-wrap: wrap;
  justify-content: center;
}

.btn-onimage {
  background: #fff;
  color: #333;
  border-radius: 0;
  text-transform: uppercase;
  letter-spacing: .1em;
  font-family: "Inter";
  font-weight: 600;
  font-size: 14px;
  padding: 15px 32px;
}

.btn-onimage:hover {
  background: #EFEEEA;
}

.btn-ghost-light {
  background: transparent;
  border: 1px solid #fff;
  color: #fff;
  border-radius: 0;
  text-transform: uppercase;
  letter-spacing: .1em;
  font-family: "Inter";
  font-weight: 600;
  font-size: 14px;
  padding: 15px 32px;
}

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

/* ---------------------------------------------------------
   Generic content
--------------------------------------------------------- */
.page-content {
  padding: 64px 0;
}

.page-content h1,
.page-content h2 {
  margin-bottom: 20px;
}

.page-content p {
  margin-bottom: 16px;
}

/* ---------------------------------------------------------
   Footer
--------------------------------------------------------- */
.site-footer {
  background: var(--charcoal);
  color: var(--mist);
  padding: 60px 0 30px;
}

.site-footer .site-logo img {
  height: 36px;
  width: auto;
}

.footer-cols {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 40px;
  margin-top: 44px;
}

.footer-col h4 {
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  font-weight: 700;
  font-size: 15px;
  letter-spacing: .04em;
  color: var(--white);
  margin-bottom: 16px;
}

.footer-col ul {
  list-style: none;
}

.footer-col li {
  font-family: "Inter", system-ui, sans-serif;
  font-size: 14px;
  line-height: 1.5;
  color: var(--mist);
  margin-bottom: 10px;
}

.footer-col a {
  font-family: "Inter", system-ui, sans-serif;
  font-size: 14px;
  color: var(--mist);
  text-decoration: none;
  transition: .2s;
}

.footer-col a:hover {
  color: var(--white);
}

.footer-statement {
  margin-top: 56px;
  padding-top: 40px;
  border-top: 1px solid rgba(227, 225, 220, .2);
}

.footer-statement h3 {
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  font-weight: 700;
  font-size: clamp(18px, 2vw, 24px);
  color: var(--white);
  line-height: 1.2;
}

.footer-statement p {
  font-family: "Inter", system-ui, sans-serif;
  font-size: 15px;
  color: var(--mist);
  line-height: 1.7;
  margin-top: 12px;
  max-width: 620px;
}

.footer-bottom {
  margin-top: 40px;
  padding-top: 20px;
  border-top: 1px solid rgba(227, 225, 220, .2);
  font-size: 13px;
  color: var(--mist);
}

.foot-contact .fc-block{ margin-bottom:16px; line-height:1.6; }
.foot-contact .fc-block:last-child{ margin-bottom:0; }
.foot-contact .fc-label{ display:block; font-family:"Inter",sans-serif; font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:#8a857d; margin-bottom:3px; }
.foot-contact a{ color:inherit; text-decoration:none; }
.foot-contact a:hover{ color:#A67C4F; }

@media (max-width: 860px) {
  .footer-cols {
    grid-template-columns: 1fr 1fr;
    gap: 32px;
  }
}

@media (max-width: 520px) {
  .footer-cols {
    grid-template-columns: 1fr;
  }
}

/* ---------------------------------------------------------
   Responsive
--------------------------------------------------------- */
@media (max-width: 860px) {
  .hero {
    min-height: 60vh;
  }

  .hero .container {
    padding-bottom: 9vh;
  }
}

@media (max-width: 860px) {
  .nav-toggle {
    display: flex;
  }

  .header-cta {
    display: none;
  }

  .main-nav {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--white);
    border-bottom: 1px solid var(--mist);
    display: none;
  }

  .main-nav.is-open {
    display: block;
  }

  .nav-list {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
    padding: 8px 24px 20px;
  }

  .nav-list > li {
    width: 100%;
  }

  .nav-list a {
    display: block;
    padding: 10px 0;
  }

  .has-dropdown > a::after {
    display: none;
  }

  .dropdown {
    position: static;
    display: block;
    border: none;
    box-shadow: none;
    padding: 4px 0 8px 16px;
    min-width: 0;
  }

  .dropdown a {
    padding: 8px 0;
  }

  .site-header .container {
    flex-wrap: wrap;
  }
}

/* ---------------------------------------------------------
   Homepage · Section 1 — Why Tristar benefits strip
--------------------------------------------------------- */
.why-tristar {
  background: var(--greige);
  padding: 90px 0;
}

.wt-intro {
  text-align: center;
  max-width: 820px;
  margin: 0 auto 56px;
}

.wt-intro h2 {
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  font-weight: 700;
  font-size: clamp(26px, 3vw, 38px);
  color: #333333;
  margin-top: 12px;
  line-height: 1.12;
  text-wrap: balance;
}

.wt-intro p {
  font-family: "Inter", sans-serif;
  font-size: 15.5px;
  color: #616161;
  line-height: 1.7;
  margin-top: 16px;
}

.compare {
  display: flex;
  gap: 24px;
  align-items: stretch;
}

.ccard {
  flex: 1;
  background: #FFFFFF;
  border: 1px solid #E3E1DC;
  padding: 34px 28px;
}

.ccard.muted {
  background: #F5F0E8;
}

.ccard.dark {
  background: #1A1A1A;
  border-color: #1A1A1A;
}

.ccard h3 {
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  font-weight: 700;
  font-size: 17px;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: #333333;
  margin: 0 0 16px;
  padding-bottom: 14px;
  border-bottom: 1px solid #E3E1DC;
}

.ccard.dark h3 {
  color: #FFFFFF;
  border-color: #3a3733;
}

.ccard ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.ccard li {
  font-family: "Inter", sans-serif;
  font-size: 15px;
  color: #616161;
  padding: 11px 0 11px 20px;
  position: relative;
}

.ccard li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 18px;
  width: 6px;
  height: 6px;
  background: #c4bdb0;
}

.ccard.dark li {
  color: #EFEEEA;
}

.ccard.dark li::before {
  background: #cfcabf;
}

.ccard.adv li::before {
  background: #333333;
}

@media (max-width: 860px) {
  .compare {
    flex-direction: column;
  }
}

/* ---------------------------------------------------------
   Homepage · Section 2 — Traditional vs Tristar model
--------------------------------------------------------- */
.tristar-model {
  background: var(--white);
  padding: 110px 0;
  border-top: 1px solid #E3E1DC;
  border-bottom: 1px solid #E3E1DC;
}

.tristar-model__heading {
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  font-weight: 600;
  font-size: clamp(26px, 3.4vw, 38px);
  color: var(--charcoal);
  margin-top: 12px;
}

.tristar-model__subline {
  font-family: "Inter", system-ui, sans-serif;
  font-weight: 400;
  font-size: 16px;
  color: var(--slate);
  max-width: 620px;
  margin-top: 14px;
}

.model-panel {
  background: var(--greige);
  border-radius: 0;
  padding: 36px;
  margin-top: 36px;
}

.model-row__label {
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  font-weight: 500;
  font-size: 13px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--slate);
}

.model-flow {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  margin-top: 14px;
}

.model-spacer {
  height: 28px;
}

.chip {
  background: var(--white);
  border: 1px solid var(--mist);
  color: var(--slate);
  font-family: "Inter", system-ui, sans-serif;
  font-size: 14px;
  padding: 10px 16px;
  border-radius: 0;
}

.chip--tristar {
  background: var(--charcoal);
  border: 1px solid var(--charcoal);
  color: var(--white);
}

.flow-arrow {
  color: var(--slate);
  font-size: 16px;
}

.flow-arrow--accent {
  color: var(--charcoal);
}

.model-callouts {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  margin-top: 32px;
}

.callout {
  flex: 1;
  min-width: 200px;
  background: var(--greige);
  border-radius: 0;
  padding: 20px 24px;
}

.callout__title {
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  font-weight: 600;
  font-size: 18px;
  color: var(--charcoal);
}

.model-benefits {
  display: flex;
  gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 32px;
}

.model-benefits span {
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  font-weight: 700;
  font-size: 15px;
  letter-spacing: .04em;
  color: #333333;
  border: 1px solid #333333;
  padding: 11px 22px;
}

/* Animated supply-chain diagram */
@keyframes tsFacOp{0%,1.5%{opacity:0}4.5%{opacity:1}96%{opacity:1}99.5%,100%{opacity:0}}
@keyframes tsA1{0%,4.5%{opacity:0}6%{opacity:1}96%{opacity:1}99.5%,100%{opacity:0}}
@keyframes tsExp{0%,6%{opacity:0}9%{opacity:1}32%{opacity:1}36.75%{opacity:.45}96%{opacity:.45}99.5%,100%{opacity:0}}
@keyframes tsA2{0%,9%{opacity:0}10.5%{opacity:1}96%{opacity:1}99.5%,100%{opacity:0}}
@keyframes tsImp{0%,10.5%{opacity:0}13.5%{opacity:1}32%{opacity:1}36.75%{opacity:.45}96%{opacity:.45}99.5%,100%{opacity:0}}
@keyframes tsA3{0%,13.5%{opacity:0}15%{opacity:1}96%{opacity:1}99.5%,100%{opacity:0}}
@keyframes tsDis{0%,15%{opacity:0}18%{opacity:1}32%{opacity:1}36.75%{opacity:.45}96%{opacity:.45}99.5%,100%{opacity:0}}
@keyframes tsA4{0%,18%{opacity:0}19.5%{opacity:1}96%{opacity:1}99.5%,100%{opacity:0}}
@keyframes tsFabOp{0%,19.5%{opacity:0}22.5%{opacity:1}96%{opacity:1}99.5%,100%{opacity:0}}
@keyframes tsTrad{0%,3%{opacity:0}6.75%{opacity:1}31.5%{opacity:1}35.25%,100%{opacity:0}}
@keyframes tsCap1{0%,22.5%{opacity:0}25.5%{opacity:1}33%{opacity:1}36%,100%{opacity:0}}
@keyframes tsX1{0%,31.5%{opacity:0}34.5%{opacity:1}96%{opacity:1}99.5%,100%{opacity:0}}
@keyframes tsX2{0%,33.75%{opacity:0}36.75%{opacity:1}96%{opacity:1}99.5%,100%{opacity:0}}
@keyframes tsX3{0%,36%{opacity:0}39%{opacity:1}96%{opacity:1}99.5%,100%{opacity:0}}
@keyframes tsLogo{0%,37.5%{opacity:0}41.25%{opacity:1}96%{opacity:1}99.5%,100%{opacity:0}}
@keyframes tsFly{0%,41.25%{stroke-dashoffset:640;opacity:0}42%{stroke-dashoffset:640;opacity:1}58.5%{stroke-dashoffset:0;opacity:1}96%{stroke-dashoffset:0;opacity:1}99.5%{stroke-dashoffset:0;opacity:0}100%{stroke-dashoffset:640;opacity:0}}
@keyframes tsHead{0%,59.25%{opacity:0}60.75%{opacity:1}96%{opacity:1}99.5%,100%{opacity:0}}
@keyframes tsCap2{0%,48.75%{opacity:0}53.25%{opacity:1}96%{opacity:1}99.5%,100%{opacity:0}}
@keyframes tsFacBox{0%,41.25%{fill:rgba(51,51,51,0)}44.25%{fill:rgba(51,51,51,1)}96%{fill:rgba(51,51,51,1)}99.5%,100%{fill:rgba(51,51,51,0)}}
@keyframes tsFacTxt{0%,41.25%{fill:#333333}44.25%{fill:#ffffff}96%{fill:#ffffff}99.5%,100%{fill:#333333}}
@keyframes tsFacPop{0%,41.25%{transform:scale(1)}42.75%{transform:scale(1.07)}45.75%{transform:scale(1)}}
@keyframes tsFabBox{0%,58.5%{fill:rgba(51,51,51,0)}60.75%{fill:rgba(51,51,51,1)}96%{fill:rgba(51,51,51,1)}99.5%,100%{fill:rgba(51,51,51,0)}}
@keyframes tsFabTxt{0%,58.5%{fill:#333333}60.75%{fill:#ffffff}96%{fill:#ffffff}99.5%,100%{fill:#333333}}
@keyframes tsFabPop{0%,58.5%{transform:scale(1)}60%{transform:scale(1.07)}63%{transform:scale(1)}}
.ts-fac{transform-box:fill-box;transform-origin:center;animation:tsFacOp 16s infinite,tsFacPop 16s infinite}
.ts-facbox{animation:tsFacBox 16s infinite}.ts-factxt{animation:tsFacTxt 16s infinite}
.ts-fab{transform-box:fill-box;transform-origin:center;animation:tsFabOp 16s infinite,tsFabPop 16s infinite}
.ts-fabbox{animation:tsFabBox 16s infinite}.ts-fabtxt{animation:tsFabTxt 16s infinite}
.ts-a1{animation:tsA1 16s infinite}.ts-a2{animation:tsA2 16s infinite}.ts-a3{animation:tsA3 16s infinite}.ts-a4{animation:tsA4 16s infinite}
.ts-exp{animation:tsExp 16s infinite}.ts-imp{animation:tsImp 16s infinite}.ts-dis{animation:tsDis 16s infinite}
.ts-trad{animation:tsTrad 16s infinite}.ts-cap1{animation:tsCap1 16s infinite}.ts-cap2{animation:tsCap2 16s infinite}
.ts-x1{animation:tsX1 16s infinite}.ts-x2{animation:tsX2 16s infinite}.ts-x3{animation:tsX3 16s infinite}
.ts-logo{animation:tsLogo 16s infinite}.ts-fly{stroke-dasharray:640;animation:tsFly 16s linear infinite}.ts-head{animation:tsHead 16s infinite}

/* ---------------------------------------------------------
   Homepage · Featured Quartz products
--------------------------------------------------------- */
.products {
  background: #FFFFFF;
  padding: 90px 0;
}

.products-intro {
  text-align: center;
  max-width: 980px;
  margin: 0 auto;
}

.eyebrow2 {
  font-family: "Inter", sans-serif;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: #616161;
}

.products h2 {
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  font-weight: 700;
  font-size: clamp(26px, 3.2vw, 36px);
  color: #333333;
  margin-top: 12px;
  line-height: 1.1;
}

.products .sub {
  font-family: "Inter", sans-serif;
  font-size: 16px;
  color: #616161;
  margin-top: 12px;
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}

.product-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  margin-top: 48px;
}

.product-card {
  display: block;
  text-decoration: none;
}

.product-card .imgwrap {
  overflow: hidden;
  aspect-ratio: 3 / 2;
  background: #EFEEEA;
}

.product-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .5s ease;
}

.product-card:hover img {
  transform: scale(1.04);
}

.product-card .name {
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  font-weight: 700;
  font-size: 17px;
  letter-spacing: .04em;
  color: #333333;
  margin-top: 14px;
}

.product-card .cat {
  font-family: "Inter", sans-serif;
  font-size: 12px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: #9a968f;
  margin-top: 4px;
}

.products .viewall {
  text-align: center;
  margin-top: 48px;
}

.collections-note {
  text-align: center;
  max-width: 640px;
  margin: 54px auto 0;
}

.collections-note h3 {
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  font-weight: 700;
  font-size: 20px;
  color: #333333;
}

.collections-note p {
  font-family: "Inter", sans-serif;
  font-size: 15px;
  color: #616161;
  line-height: 1.7;
  margin-top: 10px;
}

@media (max-width: 900px) {
  .product-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 560px) {
  .product-grid {
    grid-template-columns: 1fr;
  }
}

/* ---------------------------------------------------------
   Homepage · CTA band
--------------------------------------------------------- */
.cta-band {
  background: #1A1A1A;
  padding: 84px 0;
  text-align: center;
}

.cta-band .container {
  max-width: 760px;
}

.cta-eyebrow {
  font-family: "Inter", sans-serif;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: #b9b4ac;
}

.cta-band h2 {
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  font-weight: 700;
  font-size: clamp(28px, 3.4vw, 42px);
  color: #ffffff;
  margin-top: 14px;
  line-height: 1.1;
}

.cta-band p {
  font-family: "Inter", sans-serif;
  font-size: 17px;
  color: #cfcabf;
  max-width: 640px;
  margin: 14px auto 0;
  line-height: 1.6;
}

.cta-btns {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 30px;
}

.cta-btns .btn {
  min-width: 210px;
  justify-content: center;
}

/* ---------------------------------------------------------
   Homepage · How We Work
--------------------------------------------------------- */
.how {
  background: #FFFFFF;
  padding: 80px 0;
}

.how-intro {
  text-align: center;
  max-width: 620px;
  margin: 0 auto 48px;
}

.how h2 {
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  font-weight: 700;
  font-size: clamp(26px, 3vw, 36px);
  color: #333333;
  margin-top: 12px;
  line-height: 1.1;
}

.timeline {
  display: flex;
  justify-content: space-between;
  position: relative;
  margin-top: 52px;
  gap: 8px;
}

.timeline:before {
  content: "";
  position: absolute;
  top: 19px;
  left: 6%;
  right: 6%;
  height: 1px;
  background: #d6d2ca;
  z-index: 0;
}

.tstep {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
  z-index: 1;
}

.tdot {
  width: 40px;
  height: 40px;
  border: 1px solid #333333;
  background: #FFFFFF;
  color: #333333;
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  font-weight: 700;
  font-size: 15px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.tlabel {
  font-family: "Inter", sans-serif;
  font-weight: 600;
  font-size: 12.5px;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: #616161;
  margin-top: 14px;
}

@media (max-width: 760px) {
  .timeline {
    flex-wrap: wrap;
    row-gap: 28px;
  }

  .timeline:before {
    display: none;
  }

  .tstep {
    flex: 0 0 33%;
  }
}

/* ---------------------------------------------------------
   Homepage · Beliefs / Why Quartz
--------------------------------------------------------- */
.beliefs-band {
  position: relative;
  min-height: 480px;
  display: flex;
  align-items: center;
  text-align: center;
  background: linear-gradient(rgba(26,26,26,.5), rgba(26,26,26,.5)), url('assets/beliefs.jpg') center/cover no-repeat, #2a2724;
}

.beliefs-band .container {
  max-width: 780px;
  padding-bottom: 40px;
}

.eyebrow2.light {
  color: #cfcabf;
}

.band-h {
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  font-weight: 700;
  font-size: clamp(24px, 3vw, 36px);
  color: #ffffff;
  line-height: 1.18;
  margin-top: 14px;
}

.beliefs-panel {
  position: relative;
  z-index: 2;
  background: #FFFFFF;
  max-width: 1180px;
  margin: -90px auto 0;
  padding: 58px 56px 66px;
}

.beliefs-cols {
  display: flex;
  gap: 72px;
}

.bcol {
  flex: 1;
}

.bh {
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  font-weight: 700;
  font-size: clamp(22px, 2.4vw, 28px);
  color: #333333;
  line-height: 1.1;
}

.bcol p {
  font-family: "Inter", sans-serif;
  font-size: 15px;
  color: #616161;
  line-height: 1.7;
  margin-top: 16px;
  max-width: 460px;
}

.bcol .btn {
  margin-top: 28px;
}

.bcol .bsub {
  font-family: "Inter", sans-serif;
  font-size: 16px;
  font-weight: 600;
  color: #333333;
  margin-top: 10px;
}

.features .bh {
  margin-bottom: 6px;
}

.features .frow {
  display: flex;
  align-items: flex-start;
  gap: 18px;
  padding: 18px 0;
  border-bottom: 1px solid #E3E1DC;
}

.features .frow:first-of-type {
  border-top: 1px solid #E3E1DC;
  margin-top: 18px;
}

.features .ficon {
  flex: 0 0 52px;
  display: flex;
  justify-content: center;
  margin-top: 2px;
}

.features .ficon img {
  height: 38px;
  width: auto;
  max-width: 52px;
  display: block;
}

.features .ftext {
  display: flex;
  flex-direction: column;
}

.features .ftitle {
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  font-weight: 700;
  font-size: 15px;
  letter-spacing: .03em;
  color: #333333;
}

.features .fdesc {
  font-family: "Inter", sans-serif;
  font-size: 13px;
  color: #616161;
  line-height: 1.5;
  margin-top: 3px;
}

@media (max-width: 860px) {
  .beliefs-panel {
    margin: -50px 16px 0;
    padding: 40px 26px;
  }

  .beliefs-cols {
    flex-direction: column;
    gap: 40px;
  }
}

/* ---------------------------------------------------------
   Homepage · Gallery carousel
--------------------------------------------------------- */
.gallery {
  background: #FFFFFF;
  padding: 84px 0;
}

.gal-intro {
  text-align: center;
  max-width: 620px;
  margin: 0 auto 40px;
}

.gallery h2 {
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  font-weight: 700;
  font-size: clamp(26px, 3vw, 36px);
  color: #333333;
  margin-top: 12px;
  line-height: 1.1;
}

.gal-stage {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #EFEEEA;
  overflow: hidden;
}

.gal-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  visibility: hidden;
}

.gal-slide.is-active {
  opacity: 1;
  visibility: visible;
}

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

.gal-empty {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #EFEEEA;
}

.gal-soon {
  font-family: "Inter", sans-serif;
  font-weight: 600;
  letter-spacing: .2em;
  text-transform: uppercase;
  font-size: 13px;
  color: #b9b4ac;
}

.gal-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 18px 0;
  border-bottom: 1px solid #E3E1DC;
}

.gal-name {
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: 15px;
  color: #333333;
}

.gal-ctrls {
  display: flex;
  align-items: center;
  gap: 22px;
}

.gal-viewall {
  font-family: "Inter", sans-serif;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-size: 13px;
  color: #333333;
  text-decoration: none;
}

.gal-arrow {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 20px;
  line-height: 1;
  color: #333333;
  padding: 4px;
}

.gal-arrow:hover {
  color: #000000;
}

/* ---------------------------------------------------------
   Homepage · Beyond Quartz
--------------------------------------------------------- */
.beyond {
  background: #1A1A1A;
  padding: 96px 0;
}

.beyond-grid {
  display: flex;
  gap: 64px;
  align-items: flex-start;
}

.beyond-copy {
  flex: 1.3;
}

.beyond h2 {
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  font-weight: 700;
  font-size: clamp(28px, 3.4vw, 42px);
  color: #FFFFFF;
  margin-top: 12px;
  line-height: 1.1;
}

.beyond-sub {
  font-family: "Inter", sans-serif;
  font-size: 17px;
  color: #cfcabf;
  margin-top: 14px;
  line-height: 1.6;
}

.beyond-copy p {
  font-family: "Inter", sans-serif;
  font-size: 15px;
  color: #b9b4ac;
  line-height: 1.7;
  margin-top: 16px;
}

.beyond-tagline {
  color: #FFFFFF !important;
  font-style: normal;
  border-left: 2px solid #7C5A36;
  padding-left: 16px;
  margin-top: 24px;
}

.beyond-list {
  flex: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: #3a3733;
  border: 1px solid #3a3733;
}

.beyond-list span {
  background: #1A1A1A;
  color: #EFEEEA;
  font-family: "Inter", sans-serif;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: .04em;
  padding: 22px 20px;
}

.eyebrow2.light {
  color: #b9b4ac;
}

@media (max-width: 860px) {
  .beyond-grid {
    flex-direction: column;
    gap: 36px;
  }
}

/* ---------------------------------------------------------
   Collections page
--------------------------------------------------------- */
.col-intro {
  background: #FFFFFF;
  padding: 70px 0 34px;
  text-align: left;
}

.col-intro .container {
  max-width: 1200px;
}

.col-intro h2 {
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  font-weight: 700;
  font-size: clamp(26px, 3vw, 36px);
  color: #333333;
  margin-top: 12px;
  max-width: 760px;
}

.col-intro p {
  font-family: "Inter", sans-serif;
  font-size: 15.5px;
  color: #616161;
  line-height: 1.8;
  margin-top: 16px;
  max-width: 680px;
  margin-left: 0;
  margin-right: 0;
}

.col-listing {
  background: #FFFFFF;
  padding: 0 0 100px;
}

.col-strip {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  border-top: 1px solid #E3E1DC;
  border-bottom: 1px solid #E3E1DC;
  margin-bottom: 50px;
}

.col-strip span {
  font-family: "Inter", sans-serif;
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: #616161;
  padding: 18px 28px;
  border-left: 1px solid #E3E1DC;
}

.col-strip span:first-child {
  border-left: none;
}

.col-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 44px 30px;
}

.col-card {
  display: block;
  text-decoration: none;
  background: transparent;
  transition: box-shadow .35s ease, transform .35s ease;
}

.col-card:hover {
  box-shadow: 0 20px 44px rgba(0, 0, 0, .10);
}

.col-imgwrap {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: #E3E1DC;
}

.col-imgwrap img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: opacity .5s ease, transform .6s ease;
}

.col-slab {
  opacity: 0;
}

.col-card:hover .col-slab {
  opacity: 1;
}

.col-badge {
  position: absolute;
  top: 0;
  left: 18px;
  z-index: 3;
  background: #A67C4F;
  color: #FFFFFF;
  font-family: "Inter", sans-serif;
  font-weight: 600;
  font-size: 10.5px;
  letter-spacing: .2em;
  text-transform: uppercase;
  writing-mode: vertical-rl;
  padding: 14px 7px;
  clip-path: polygon(0 0, 100% 0, 100% calc(100% - 7px), 50% 100%, 0 calc(100% - 7px));
  transition: background .3s ease, box-shadow .3s ease;
}

.col-card:hover .col-badge {
  background: #7C5A36;
  box-shadow: 0 6px 14px rgba(0, 0, 0, .18);
}

.col-card:hover .col-imgwrap img {
  transform: scale(1.05);
}

.col-meta {
  padding: 16px 4px 6px;
}

.col-code {
  font-family: "Inter", sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: #9a968f;
}

.col-name {
  font-family: 'Tristar Display', "Century Gothic", sans-serif;
  font-weight: 700;
  font-size: 18px;
  color: #333333;
  margin-top: 5px;
}

.col-descriptor {
  font-family: "Inter", sans-serif;
  font-size: 13px;
  color: #616161;
  margin-top: 3px;
}

.col-link {
  display: inline-block;
  font-family: "Inter", sans-serif;
  font-weight: 600;
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #333333;
  margin-top: 12px;
  opacity: 0;
  transform: translateY(4px);
  transition: opacity .3s ease, transform .3s ease;
}

.col-card:hover .col-link {
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 900px) {
  .col-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 560px) {
  .col-grid {
    grid-template-columns: 1fr;
  }

  .col-link {
    opacity: 1;
    transform: none;
  }
}

/* ---------------------------------------------------------
   Quartz Product page
--------------------------------------------------------- */
.pd-overview{ padding:70px 0 80px; background:#fff; }
.pd-grid{ display:flex; gap:56px; align-items:flex-start; }
.pd-media{ flex:1; position:sticky; top:90px; }
.pd-stage{ aspect-ratio:7/4; background:#E3E1DC; overflow:hidden; }
.pd-stage img{ width:100%; height:100%; object-fit:cover; display:block; cursor:default; transform-origin:center; transition:transform .4s ease; }
.pd-thumbs{ display:flex; gap:10px; margin-top:14px; }
.pd-thumb{ font-family:"Inter",sans-serif; font-size:12px; letter-spacing:.1em; text-transform:uppercase; padding:10px 18px; border:1px solid #E3E1DC; background:#fff; color:#616161; cursor:pointer; }
.pd-thumb.is-on{ border-color:#333333; color:#333333; }
.pd-info{ flex:1; }
.pd-code{ font-family:"Inter",sans-serif; font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:#9a968f; }
.pd-name{ font-family:'Tristar Display',"Century Gothic",sans-serif; font-weight:700; font-size:clamp(32px,4vw,46px); color:#333; line-height:1.05; margin-top:6px; }
.pd-badge{ display:inline-block; background:#A67C4F; color:#fff; font-family:"Inter",sans-serif; font-weight:600; font-size:11px; letter-spacing:.16em; text-transform:uppercase; padding:6px 12px; margin-top:14px; }
.pd-statement{ font-family:"Inter",sans-serif; font-size:17px; color:#616161; line-height:1.6; margin-top:18px; max-width:480px; }
.pd-ctas{ display:flex; gap:12px; flex-wrap:wrap; margin-top:28px; }
.pd-trust{ list-style:none; margin:28px 0 0; padding:0; display:grid; grid-template-columns:1fr 1fr; gap:10px 24px; }
.pd-trust li{ font-family:"Inter",sans-serif; font-size:14px; color:#333; padding-left:24px; position:relative; }
.pd-trust li::before{ content:"\2713"; position:absolute; left:0; color:#7C5A36; font-weight:700; }
.pd-about{ background:#FFFFFF; padding:80px 0; }
.pd-about .container{ max-width:1200px; }
.pd-about p{ max-width:720px; }
.pd-about h2,.pd-gallery h2,.pd-slab h2,.pd-specs h2,.pd-why h2,.pd-fd h2,.pd-related h2{ font-family:'Tristar Display',"Century Gothic",sans-serif; font-weight:700; font-size:clamp(24px,2.8vw,34px); color:#333; }
.pd-about p,.pd-fd p{ font-family:"Inter",sans-serif; font-size:16px; color:#616161; line-height:1.8; margin-top:16px; }
.pd-gallery{ padding:80px 0; background:#fff; } .pd-gallery h2{ margin:8px 0 36px; }
.pd-gal-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.pd-gal-item{ aspect-ratio:4/3; background:#EFEEEA; overflow:hidden; } .pd-gal-item img{ width:100%; height:100%; object-fit:cover; }
.pd-soon{ display:flex; align-items:center; justify-content:center; } .pd-soon span{ font-family:"Inter",sans-serif; font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:#b9b4ac; }
.pd-slab{ padding:0 0 80px; background:#fff; } .pd-slab h2{ margin-bottom:24px; }
.pd-slab-img{ position:relative; background:#E3E1DC; } .pd-slab-img img{ width:100%; height:auto; display:block; cursor:zoom-in; }
.pd-slab-dl{ margin-top:20px; display:inline-block; }
.pd-specs{ padding:80px 0; background:#EFEEEA; }
.pd-spec-table{ width:100%; border-collapse:collapse; margin-top:28px; max-width:760px; }
.pd-spec-table tr{ border-bottom:1px solid #E3E1DC; }
.pd-spec-table th{ text-align:left; font-family:"Inter",sans-serif; font-weight:600; font-size:13px; letter-spacing:.06em; text-transform:uppercase; color:#9a968f; padding:16px 0; width:230px; vertical-align:top; }
.pd-spec-table td{ font-family:"Inter",sans-serif; font-size:15px; color:#333; padding:16px 0; }
.pd-downloads{ padding:80px 0; background:#fff; }
.pd-dl-grid{ display:flex; flex-wrap:wrap; gap:14px; margin-top:28px; }
.pd-dl{ font-family:"Inter",sans-serif; font-weight:600; font-size:13px; letter-spacing:.06em; text-transform:uppercase; color:#333; border:1px solid #333; padding:14px 22px; text-decoration:none; }
.pd-dl:hover{ background:#333; color:#fff; }
.pd-why{ padding:80px 0; background:#1A1A1A; } .pd-why h2{ color:#fff; margin-bottom:36px; }
.pd-why-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:#3a3733; border:1px solid #3a3733; }
.pd-why-card{ background:#1A1A1A; color:#EFEEEA; font-family:"Inter",sans-serif; font-weight:600; font-size:15px; padding:30px 26px; }
.pd-fd{ padding:80px 0; background:#fff; } .pd-fd .container{ max-width:760px; }
.pd-related{ padding:80px 0; background:#EFEEEA; } .pd-related h2{ margin-bottom:36px; }
.pd-rel-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
.pd-rel-card{ text-decoration:none; }
.pd-rel-img{ aspect-ratio:4/3; overflow:hidden; background:#E3E1DC; } .pd-rel-img img{ width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.pd-rel-card:hover .pd-rel-img img{ transform:scale(1.04); }
.pd-rel-code{ font-family:"Inter",sans-serif; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:#9a968f; margin-top:14px; }
.pd-rel-name{ font-family:'Tristar Display',"Century Gothic",sans-serif; font-weight:700; font-size:17px; color:#333; margin-top:4px; }
.pd-rel-link{ font-family:"Inter",sans-serif; font-weight:600; font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:#333; display:inline-block; margin-top:10px; }
@media(max-width:860px){ .pd-grid{ flex-direction:column; } .pd-media{ position:static; } .pd-gal-grid,.pd-why-grid,.pd-rel-grid{ grid-template-columns:1fr 1fr; } }
@media(max-width:560px){ .pd-gal-grid,.pd-why-grid,.pd-rel-grid{ grid-template-columns:1fr; } }

/* ---------------------------------------------------------
   Quartz Product page (refined layout)
--------------------------------------------------------- */
.pd-collection{ font-family:"Inter",sans-serif; font-weight:600; font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:#7C5A36; margin-bottom:8px; }
.pd-gal-item{ aspect-ratio:auto; background:transparent; overflow:visible; margin:0; }
.pd-gal-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:8px; }
.pd-gal-box{ aspect-ratio:4/3; background:#EFEEEA; overflow:hidden; display:flex; align-items:center; justify-content:center; }
.pd-gal-box img{ width:100%; height:100%; object-fit:cover; }
.pd-soon-t{ font-family:"Inter",sans-serif; font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:#b9b4ac; }
.pd-gal-item figcaption{ font-family:"Inter",sans-serif; font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:#616161; margin-top:10px; }
.pd-zoom{ position:absolute; bottom:16px; right:16px; background:rgba(0,0,0,.62); color:#fff; border:none; font-family:"Inter",sans-serif; font-size:11px; letter-spacing:.1em; text-transform:uppercase; padding:10px 16px; cursor:pointer; }
.pd-lightbox{ position:fixed; inset:0; background:rgba(20,18,16,.93); display:none; align-items:center; justify-content:center; z-index:9999; padding:30px; }
.pd-lightbox.open{ display:flex; }
.pd-lightbox img{ max-width:96%; max-height:94%; object-fit:contain; }
.pd-lightbox-close{ position:absolute; top:18px; right:28px; background:none; border:none; color:#fff; font-size:34px; line-height:1; cursor:pointer; }
.pd-fd{ background:#EFEEEA; padding:74px 0; }
.pd-fd .container{ max-width:1200px; text-align:left; }
.pd-fd p{ max-width:760px; }
.pd-spec-cols{ display:flex; gap:64px; margin-top:28px; flex-wrap:wrap; } .pd-spec-col{ flex:1; min-width:240px; }
.pd-spec-col h3{ font-family:'Tristar Display',"Century Gothic",sans-serif; font-weight:700; font-size:15px; letter-spacing:.06em; text-transform:uppercase; color:#333; margin-bottom:12px; }
.pd-app-list{ list-style:none; padding:0; margin:0; }
.pd-app-list li{ font-family:"Inter",sans-serif; font-size:15px; color:#333; padding:13px 0 13px 22px; border-bottom:1px solid #E3E1DC; position:relative; }
.pd-app-list li::before{ content:""; position:absolute; left:0; top:20px; width:6px; height:6px; background:#7C5A36; }
.pd-why-card{ display:flex; flex-direction:column; gap:14px; align-items:flex-start; }
.pd-why-card svg{ color:#EFEEEA; }
.pd-dl{ display:inline-flex; align-items:center; gap:10px; }
.pd-dl svg{ flex:0 0 auto; }
.pd-rel-grid{ gap:36px; } .pd-rel-name{ font-size:19px; }
.pd-final{ background:#1A1A1A; padding:90px 0; text-align:center; }
.pd-final h2{ color:#fff; font-size:clamp(28px,3.4vw,42px); }
.pd-final p{ font-family:"Inter",sans-serif; font-size:16px; color:#cfcabf; max-width:600px; margin:16px auto 0; line-height:1.7; }
.pd-final-btns{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:30px; }
.pd-gal-box.has-img{ position:relative; cursor:zoom-in; }
.pd-gal-box img{ transition:transform .5s ease; }
.pd-gal-box.has-img:hover img{ transform:scale(1.05); }
.pd-gal-zoom{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; background:rgba(26,26,26,0); opacity:0; transition:.3s ease; }
.pd-gal-box.has-img:hover .pd-gal-zoom{ background:rgba(26,26,26,.20); opacity:1; }
.pd-gal-zoom svg{ color:#fff; }
.pd-media-dl{ display:flex; gap:10px; margin-top:14px; flex-wrap:wrap; }
.pd-dl-btn{ display:inline-flex; align-items:center; gap:8px; font-size:13px; padding:11px 18px; }
.pd-dl-btn svg{ flex:0 0 auto; }

/* ---------------------------------------------------------
   Factory Direct Program page
--------------------------------------------------------- */
.fd-hero{ position:relative; min-height:58vh; display:flex; align-items:center; background:linear-gradient(rgba(26,26,26,.6),rgba(26,26,26,.5)), url('assets/hero2.jpg') center/cover no-repeat, #2a2724; }
.fd-hero .container{ max-width:840px; }
.fd-hero h1{ font-family:'Tristar Display',"Century Gothic",sans-serif; font-weight:700; color:#fff; font-size:clamp(32px,4.6vw,54px); line-height:1.08; margin-top:14px; }
.fd-hero p{ font-family:"Inter",sans-serif; font-size:16px; color:#EFEEEA; line-height:1.7; margin-top:16px; max-width:700px; }
.fd-hero-btns{ display:flex; gap:14px; margin-top:30px; flex-wrap:wrap; }
.fd-model{ background:#FFFFFF; padding:90px 0; }
.fd-model h2{ font-family:'Tristar Display',"Century Gothic",sans-serif; font-weight:700; font-size:clamp(28px,3.4vw,40px); color:#333; margin-top:12px; }
.fd-lead{ font-family:"Inter",sans-serif; font-size:16px; color:#616161; max-width:700px; margin-top:14px; line-height:1.7; }
.fd-compare{ display:flex; gap:30px; margin-top:48px; align-items:stretch; }
.fd-col{ flex:1; border:1px solid #E3E1DC; padding:36px 28px; text-align:center; }
.fd-col-dark{ background:#1A1A1A; border-color:#1A1A1A; }
.fd-col-label{ font-family:"Inter",sans-serif; font-weight:600; font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:#9a968f; margin-bottom:22px; }
.fd-col-dark .fd-col-label{ color:#b9b4ac; }
.fd-flow{ list-style:none; margin:0; padding:0; }
.fd-flow li{ font-family:'Tristar Display',"Century Gothic",sans-serif; font-weight:700; font-size:17px; color:#333; padding:10px 0; }
.fd-flow li:not(:last-child)::after{ content:"\2193"; display:block; color:#c4bdb0; font-size:14px; font-weight:400; margin-top:10px; }
.fd-col-dark .fd-flow li{ color:#fff; } .fd-col-dark .fd-flow li:not(:last-child)::after{ color:#6b6259; }
.fd-sec{ padding:90px 0; background:#FFFFFF; } .fd-greige{ background:#EFEEEA; }
.fd-head{ max-width:720px; margin-bottom:46px; }
.fd-head h2{ font-family:'Tristar Display',"Century Gothic",sans-serif; font-weight:700; font-size:clamp(28px,3.4vw,40px); color:#333; margin-top:12px; line-height:1.1; }
.fd-head p{ font-family:"Inter",sans-serif; font-size:16px; color:#616161; line-height:1.7; margin-top:16px; }
.fd-cards{ display:grid; gap:1px; background:#E3E1DC; border:1px solid #E3E1DC; }
.fd-cards-3{ grid-template-columns:repeat(3,1fr); } .fd-cards-4{ grid-template-columns:repeat(4,1fr); }
.fd-card{ background:#FFFFFF; padding:30px 26px; }
.fd-greige .fd-cards{ background:#d6d2ca; border-color:#d6d2ca; } .fd-greige .fd-card{ background:#EFEEEA; }
.fd-card h3{ font-family:'Tristar Display',"Century Gothic",sans-serif; font-weight:700; font-size:17px; color:#333; }
.fd-card p{ font-family:"Inter",sans-serif; font-size:13.5px; color:#616161; line-height:1.6; margin-top:8px; }
.fd-pillars{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.fd-pillar{ background:#FFFFFF; border:1px solid #E3E1DC; padding:34px 28px; text-align:center; }
.fd-pillar h3{ font-family:'Tristar Display',"Century Gothic",sans-serif; font-weight:700; font-size:17px; color:#333; margin-top:14px; }
.fd-pillar img{ height:48px; width:auto; display:inline-block; }
@media(max-width:900px){ .fd-cards-3,.fd-cards-4,.fd-pillars{ grid-template-columns:1fr 1fr; } .fd-compare{ flex-direction:column; } }
@media(max-width:560px){ .fd-cards-3,.fd-cards-4,.fd-pillars{ grid-template-columns:1fr; } }

/* ---------------------------------------------------------
   Sourcing Services page
--------------------------------------------------------- */
.ss-hero{ background:#1A1A1A; padding:96px 0; }
.ss-hero .container{ max-width:840px; }
.ss-hero h1{ font-family:'Tristar Display',"Century Gothic",sans-serif; font-weight:700; color:#fff; font-size:clamp(32px,4.6vw,54px); line-height:1.08; margin-top:14px; }
.ss-hero p{ font-family:"Inter",sans-serif; font-size:16px; color:#cfcabf; line-height:1.7; margin-top:16px; max-width:720px; }
.ss-hero-btns{ display:flex; gap:14px; margin-top:30px; flex-wrap:wrap; }
.ss-single{ max-width:460px; margin:40px auto 0; }
.ss-case{ display:flex; align-items:center; gap:24px; margin-top:44px; flex-wrap:wrap; justify-content:center; }
.ss-case-in{ display:flex; flex-direction:column; gap:10px; }
.ss-case-in span{ font-family:"Inter",sans-serif; font-weight:600; font-size:14px; color:#333; border:1px solid #E3E1DC; padding:12px 22px; text-align:center; background:#fff; }
.ss-case-arrow{ color:#b9b4ac; font-size:22px; }
.ss-case-node{ background:#1A1A1A; color:#fff; padding:26px 34px; text-align:center; font-family:'Tristar Display',"Century Gothic",sans-serif; font-weight:700; font-size:20px; display:flex; flex-direction:column; gap:8px; }
.ss-case-node small{ font-family:"Inter",sans-serif; font-weight:400; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:#b9b4ac; }
.ss-case-out{ font-family:"Inter",sans-serif; font-size:15px; color:#616161; max-width:260px; line-height:1.6; }
@media(max-width:760px){ .ss-case{ flex-direction:column; } .ss-case-arrow{ transform:rotate(90deg); } }
.src-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.src-img{ aspect-ratio:4/3; background:#EFEEEA; overflow:hidden; display:flex; align-items:center; justify-content:center; }
.src-img img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .5s ease; }
.src-card:hover .src-img img{ transform:scale(1.05); }
.src-soon{ font-family:"Inter",sans-serif; font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:#b9b4ac; }
.src-label{ font-family:'Tristar Display',"Century Gothic",sans-serif; font-weight:700; font-size:17px; color:#333333; margin-top:14px; }
@media(max-width:760px){ .src-grid{ grid-template-columns:1fr 1fr; } }
@media(max-width:460px){ .src-grid{ grid-template-columns:1fr; } }

/* ---------------------------------------------------------
   Why Tristar page
--------------------------------------------------------- */
.wt-split{ display:flex; gap:56px; align-items:center; }
.wt-text{ flex:1; }
.wt-text h2{ font-family:'Tristar Display',"Century Gothic",sans-serif; font-weight:700; font-size:clamp(28px,3.4vw,40px); color:#333333; margin-top:12px; line-height:1.1; }
.wt-text p{ font-family:"Inter",sans-serif; font-size:16px; color:#616161; line-height:1.7; margin-top:16px; }
.wt-img{ flex:1; aspect-ratio:4/3; overflow:hidden; }
.wt-img img{ width:100%; height:100%; object-fit:cover; display:block; }
@media(max-width:860px){ .wt-split{ flex-direction:column; } }

/* ---------------------------------------------------------
   Contact page
--------------------------------------------------------- */
.ct-grid{ display:flex; gap:48px; align-items:stretch; margin-top:40px; }
.ct-info{ flex:0 0 42%; background:#1A1A1A; padding:46px 40px; }
.ct-h{ font-family:'Tristar Display',"Century Gothic",sans-serif; font-weight:700; font-size:20px; color:#333; margin-bottom:18px; }
.ct-info .ct-h{ color:#FFFFFF; }
.ct-row{ display:flex; gap:16px; align-items:flex-start; padding:16px 0; border-bottom:1px solid #3a3733; }
.ct-row:last-of-type{ border-bottom:none; }
.ct-ico{ flex:0 0 22px; margin-top:2px; }
.ct-ico svg{ display:block; }
.ct-row .ct-label{ display:block; font-family:"Inter",sans-serif; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:#b9b4ac; margin-bottom:3px; }
.ct-row a,.ct-row .val{ font-family:"Inter",sans-serif; font-size:16px; color:#FFFFFF; text-decoration:none; }
.ct-row a:hover{ color:#A67C4F; }
.ct-btns{ display:flex; gap:12px; margin-top:28px; flex-wrap:wrap; }
.ct-form{ flex:1; }
.ct-form input,.ct-form textarea{ width:100%; font-family:"Inter",sans-serif; font-size:15px; padding:14px 16px; border:1px solid #E3E1DC; background:#fff; margin-bottom:14px; color:#333; }
.ct-form input:focus,.ct-form textarea:focus{ outline:none; border-color:#333; }
.ct-success{ background:#EFEEEA; border-left:3px solid #7C5A36; padding:16px 20px; font-family:"Inter",sans-serif; color:#333; margin-bottom:20px; }
@media(max-width:860px){ .ct-grid{ flex-direction:column; } .ct-info{ flex:auto; } }

/* ---------------------------------------------------------
   Contact popup (modal)
--------------------------------------------------------- */
.ct-modal{ position:fixed; inset:0; z-index:9999; display:none; }
.ct-modal.open{ display:block; }
.ct-modal-backdrop{ position:absolute; inset:0; background:rgba(20,19,17,.55); }
.ct-modal-card{ position:relative; z-index:1; width:92%; max-width:480px; margin:6vh auto 0; background:#fff; padding:40px 38px 32px; box-shadow:0 30px 80px rgba(0,0,0,.35); animation:ctmIn .25s ease; max-height:88vh; overflow:auto; }
@keyframes ctmIn{ from{ opacity:0; transform:translateY(14px);} to{ opacity:1; transform:none;} }
.ct-modal-close{ position:absolute; top:14px; right:16px; background:none; border:none; font-size:26px; line-height:1; color:#9a968f; cursor:pointer; }
.ct-modal-close:hover{ color:#1A1A1A; }
.ctm-eyebrow{ font-family:"Inter",sans-serif; font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:#A67C4F; margin-bottom:8px; }
.ctm-title{ font-family:'Tristar Display',"Century Gothic",sans-serif; font-weight:700; font-size:24px; color:#1A1A1A; margin:0 0 8px; }
.ctm-sub{ font-family:"Inter",sans-serif; font-size:14px; line-height:1.55; color:#6b6862; margin:0 0 22px; }
.ctm-form input,.ctm-form textarea{ width:100%; font-family:"Inter",sans-serif; font-size:15px; padding:13px 15px; border:1px solid #E3E1DC; background:#fff; margin-bottom:12px; color:#333; }
.ctm-form input:focus,.ctm-form textarea:focus{ outline:none; border-color:#333; }
.ctm-submit{ width:100%; margin-top:2px; }
.ctm-status{ font-family:"Inter",sans-serif; font-size:13px; margin-top:12px; color:#6b6862; }
.ctm-status.ok{ color:#2e7d32; } .ctm-status.err{ color:#b03a2e; }
.ctm-direct{ margin-top:22px; padding-top:18px; border-top:1px solid #E3E1DC; font-family:"Inter",sans-serif; font-size:13px; color:#9a968f; display:flex; gap:8px; flex-wrap:wrap; align-items:center; }
.ctm-direct a{ color:#333; text-decoration:none; } .ctm-direct a:hover{ color:#A67C4F; }
.ctm-submit{ display:inline-flex; align-items:center; justify-content:center; }
