/* ═══════════════════════════════════════════════
   JUTE BENGAL — Shared Stylesheet
   Covers: Landing Page, Products, Get a Quote
═══════════════════════════════════════════════ */

/* ── LANDING PAGE & SHARED BASE ── */

/* ── RESET & TOKENS ─────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
:root{
  --green:  #2d4a32;
  --green2: #3d5e42;
  --green3: #5a7d5f;
  --sand:   #c9a87c;
  --sand2:  #e2c99a;
  --cream:  #f6f1e9;
  --parch:  #ede6d8;
  --warm:   #faf8f4;
  --text:   #2a2a2a;
  --mid:    #5a5a5a;
  --light:  #8a8a8a;
  --serif:  'Playfair Display',Georgia,serif;
  --sans:   'Jost',system-ui,sans-serif;
  --ease:   cubic-bezier(.22,.68,0,1.2);
  --r:      10px;
}
html{scroll-behavior:smooth;}
body{font-family:var(--sans);background:var(--warm);color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased;}

/* ── NAV ─────────────────────────────────────────────── */
nav{
  position:sticky;top:0;z-index:1000;pointer-events:all;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 60px;height:74px;
  background:rgba(250,248,244,0.97);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(0,0,0,0.07);
}
.nav-logo img{display:none;}
.wordmark{
  display:flex;flex-direction:column;
  text-decoration:none;gap:0px;
  position:relative;
}
.wordmark-top{
  font-family:'Playfair Display',Georgia,serif;
  font-size:1.85rem;font-weight:700;
  letter-spacing:0.18em;
  text-transform:uppercase;
  background:linear-gradient(
    105deg,
    #1e3322 0%,
    #2d4a32 20%,
    #3d6b42 42%,
    #c9a87c 68%,
    #e2c99a 82%,
    #c9a87c 100%
  );
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  line-height:1;
}
.wordmark-bottom{
  font-family:'Playfair Display',Georgia,serif;
  font-size:0.46rem;font-weight:400;
  letter-spacing:0.55em;
  text-transform:uppercase;
  color:#a0b0a2;
  padding-left:1px;
  margin-top:4px;
}
.wordmark::after{
  content:'';
  display:block;
  width:100%;height:1px;
  margin-top:5px;
  background:linear-gradient(90deg,
    transparent 0%,
    #3d6b42 25%,
    #c9a87c 60%,
    transparent 100%
  );
}
.nav-links{display:flex;align-items:center;gap:34px;list-style:none;}
.nav-links a{
  text-decoration:none;font-size:0.83rem;
  font-weight:500;letter-spacing:0.04em;color:var(--text);
  position:relative;transition:color .2s;
}
.nav-links a::after{
  content:'';position:absolute;bottom:-3px;left:0;right:100%;
  height:1.5px;background:var(--green);
  transition:right .25s var(--ease);
}
.nav-links a:hover{color:var(--green);}
.nav-links a:hover::after{right:0;}
.nav-cta{
  background:var(--sand)!important;color:var(--text)!important;
  padding:10px 22px;border-radius:4px;
  font-weight:600!important;letter-spacing:0.06em!important;
  transition:background .2s,transform .15s!important;
}
.nav-cta:hover{background:#b8946a!important;transform:translateY(-1px);}
.nav-cta::after{display:none!important;}

/* ── HERO ────────────────────────────────────────────── */
.hero{
  position:relative;width:100%;
  min-height:600px;overflow:hidden;
  display:flex;align-items:center;
  background:#f0ebe0;
}
.hero-bg{
  position:absolute;inset:0;
  background:url('../images/hero-bg.png') center/cover no-repeat;
}
.hero-mask{
  position:absolute;inset:0;
  background:linear-gradient(
    97deg,
    #ede8de 0%,
    rgba(237,232,222,0.97) 20%,
    rgba(237,232,222,0.88) 34%,
    rgba(237,232,222,0.60) 48%,
    rgba(237,232,222,0.20) 62%,
    rgba(237,232,222,0.05) 74%,
    transparent 82%
  );
}
.hero-content{
  position:relative;z-index:2;
  padding:64px 0 52px 72px;
  max-width:530px;
}
.hero-eyebrow{
  display:flex;align-items:center;gap:10px;
  font-size:0.67rem;font-weight:600;
  letter-spacing:0.22em;text-transform:uppercase;
  color:var(--text);opacity:0.55;margin-bottom:22px;
  animation:riseUp .6s .1s var(--ease) both;
}
.hero-eyebrow::before{content:'';display:block;width:32px;height:1px;background:currentColor;}
.hero-content h1{
  font-family:var(--serif);
  font-size:3.35rem;font-weight:700;
  color:var(--green);line-height:1.1;
  animation:riseUp .7s .2s var(--ease) both;
}
.hero-content h1 em{
  font-style:italic;font-weight:400;
  color:var(--sand);display:block;
  font-size:3.35rem;line-height:1.18;
  margin-top:4px;
}
.hero-rule{
  width:52px;height:1.5px;
  background:rgba(0,0,0,0.18);
  margin:22px 0;
  animation:riseUp .7s .3s var(--ease) both;
}
.hero-content p{
  font-size:0.88rem;font-weight:400;
  color:rgba(0,0,0,0.55);line-height:1.8;
  margin-bottom:32px;
  animation:riseUp .7s .35s var(--ease) both;
}
.hero-btns{
  display:flex;gap:12px;margin-bottom:52px;
  animation:riseUp .7s .42s var(--ease) both;
}
.btn-filled{
  background:var(--green);color:#fff;
  padding:13px 24px;border-radius:4px;
  font-size:0.82rem;font-weight:600;letter-spacing:0.05em;
  text-decoration:none;display:inline-flex;align-items:center;gap:5px;
  transition:background .2s,transform .15s;
  box-shadow:0 4px 14px rgba(45,74,50,0.28);
}
.btn-filled:hover{background:#1e3422;transform:translateY(-2px);}
.btn-outlined{
  border:1.5px solid rgba(0,0,0,0.3);color:var(--text);
  padding:13px 24px;border-radius:4px;
  font-size:0.82rem;font-weight:500;text-decoration:none;
  transition:background .2s,transform .15s;background:rgba(255,255,255,0.5);
}
.btn-outlined:hover{background:rgba(255,255,255,0.8);transform:translateY(-2px);}
.hero-stats{
  display:flex;align-items:center;
  animation:riseUp .7s .5s var(--ease) both;
}
.stat-item{
  display:flex;align-items:center;gap:10px;
  padding-right:24px;
}
.stat-item+.stat-item{
  padding-left:24px;
  border-left:1px solid rgba(0,0,0,0.14);
}
.stat-icon{
  width:36px;height:36px;border-radius:50%;
  border:1.5px solid rgba(0,0,0,0.22);
  display:flex;align-items:center;justify-content:center;
  font-size:0.95rem;flex-shrink:0;
  background:rgba(255,255,255,0.5);
}
.stat-text{
  font-size:0.64rem;font-weight:600;
  letter-spacing:0.1em;text-transform:uppercase;
  color:rgba(0,0,0,0.52);line-height:1.35;
}

/* ── FEATURES ────────────────────────────────────────── */
.features{
  display:grid;grid-template-columns:repeat(3,1fr);
  background:#fff;border-bottom:1px solid rgba(0,0,0,0.07);
}
.feat{
  padding:30px 44px;
  display:flex;align-items:flex-start;gap:16px;
  border-right:1px solid rgba(0,0,0,0.07);
  transition:background .2s;
}
.feat:last-child{border-right:none;}
.feat:hover{background:var(--cream);}
.feat-icon{
  flex-shrink:0;width:50px;height:50px;border-radius:50%;
  background:var(--cream);border:1px solid rgba(0,0,0,0.07);
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;box-shadow:0 2px 8px rgba(0,0,0,0.05);
}
.feat-body h3{font-family:var(--serif);font-size:1rem;color:var(--green);margin-bottom:5px;font-weight:600;}
.feat-body p{font-size:0.78rem;color:var(--mid);line-height:1.6;}

/* ── SECTION INTRO ───────────────────────────────────── */
.sec-intro{
  display:flex;align-items:center;gap:20px;
  margin:52px 68px 0;
}
.sec-intro::before,.sec-intro::after{content:'';flex:1;height:1px;background:rgba(0,0,0,0.1);}
.sec-intro span{
  font-family:var(--serif);font-size:1.05rem;
  font-style:italic;color:var(--mid);white-space:nowrap;
}

/* ── PRODUCTS ────────────────────────────────────────── */
.products{padding:28px 68px 72px;background:var(--warm);}
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.prod-card{
  border-radius:var(--r);overflow:hidden;background:#fff;
  box-shadow:0 2px 16px rgba(0,0,0,0.07),0 0 0 1px rgba(0,0,0,0.04);
  transition:transform .3s var(--ease),box-shadow .3s;
}
.prod-card:hover{
  transform:translateY(-7px);
  box-shadow:0 20px 48px rgba(0,0,0,0.13),0 0 0 1px rgba(0,0,0,0.04);
}
.prod-img{overflow:hidden;height:230px;position:relative;}
.prod-img img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .5s var(--ease);
}
.prod-card:hover .prod-img img{transform:scale(1.06);}
.prod-body{padding:24px 26px 28px;}
.prod-body h3{font-family:var(--serif);font-size:1rem;font-weight:600;color:var(--text);margin-bottom:5px;}
.prod-body .sub{font-size:0.75rem;color:var(--light);margin-bottom:18px;font-weight:300;}
.btn-dark{
  display:inline-flex;align-items:center;gap:5px;
  background:var(--green);color:#fff;
  padding:9px 20px;border-radius:4px;
  font-size:0.76rem;font-weight:600;letter-spacing:0.06em;
  text-decoration:none;transition:background .2s,transform .15s;
}
.btn-dark:hover{background:#1e3422;transform:translateY(-1px);}
.btn-dark::after{content:' ›';}

/* ── CAROUSEL ────────────────────────────────────────── */
.carousel-wrap {
  position: relative;
  padding: 0 56px;
}
.car-viewport {
  overflow: hidden;
  border-radius: var(--r);
}
.car-track {
  display: flex;
  gap: 24px;
  transition: transform .5s cubic-bezier(.4,0,.2,1);
  will-change: transform;
}
.car-track .prod-card {
  flex: 0 0 calc((100% - 48px) / 3);
  min-width: 0;
}
.car-arrow {
  position: absolute; top: 50%; transform: translateY(-60%);
  z-index: 10; width: 44px; height: 44px;
  border-radius: 50%; border: 1.5px solid rgba(0,0,0,0.12);
  background: #fff; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: var(--green);
  box-shadow: 0 2px 12px rgba(0,0,0,0.1);
  transition: background .2s, box-shadow .2s, transform .2s;
}
.car-arrow:hover {
  background: var(--green); color: #fff;
  box-shadow: 0 4px 20px rgba(45,74,50,0.25);
  transform: translateY(-60%) scale(1.08);
}
.car-prev { left: 0; }
.car-next { right: 0; }
.car-dots {
  display: flex; justify-content: center;
  gap: 8px; margin-top: 28px;
}
.car-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: rgba(0,0,0,0.15); border: none; cursor: pointer;
  padding: 0; transition: background .25s, transform .25s;
}
.car-dot.active {
  background: var(--green);
  transform: scale(1.3);
}

/* ── ABOUT US ────────────────────────────────────────── */
.about {
  background: var(--warm);
  padding: 0 0 0;
  overflow: hidden;
}

.about-eyebrow-row {
  display: flex;
  align-items: center;
  padding: 72px 68px 0;
  margin-bottom: 10px;
}
.about-eyebrow {
  font-size: 0.68rem; font-weight: 600;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--sand); display: flex; align-items: center; gap: 12px;
}
.about-eyebrow::before {
  content: ''; display: block;
  width: 36px; height: 1.5px; background: var(--sand);
}
.about-eyebrow::after {
  content: ''; display: block;
  width: 36px; height: 1.5px; background: var(--sand);
}

.about-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  padding: 32px 68px 68px;
  align-items: start;
}

/* LEFT */
.about-title {
  font-family: var(--serif);
  font-size: 2.8rem; font-weight: 700;
  color: var(--green); line-height: 1.15;
  margin-bottom: 20px;
}
.about-title em {
  font-style: italic; font-weight: 400;
  color: var(--sand); display: block;
}
.about-rule {
  width: 48px; height: 2px;
  background: linear-gradient(90deg, var(--green), var(--sand));
  margin-bottom: 22px; border-radius: 2px;
}
.about-lead {
  font-family: var(--serif);
  font-size: 1.05rem; font-style: italic;
  color: var(--mid); line-height: 1.75;
  margin-bottom: 18px; font-weight: 400;
}
.about-body {
  font-size: 0.86rem; font-weight: 300;
  color: var(--mid); line-height: 1.9;
  margin-bottom: 36px;
}
.about-cta-row {
  display: flex; gap: 14px; align-items: center;
}
.btn-about-primary {
  background: var(--green); color: #fff;
  padding: 12px 24px; border-radius: 4px;
  font-size: 0.82rem; font-weight: 600;
  letter-spacing: 0.05em; text-decoration: none;
  transition: background .2s, transform .15s;
  box-shadow: 0 4px 14px rgba(45,74,50,0.22);
}
.btn-about-primary:hover { background: #1e3422; transform: translateY(-2px); }
.btn-about-ghost {
  font-size: 0.82rem; font-weight: 500;
  color: var(--green); text-decoration: none;
  letter-spacing: 0.04em;
  border-bottom: 1.5px solid var(--sand);
  padding-bottom: 2px;
  transition: color .2s, border-color .2s;
}
.btn-about-ghost:hover { color: var(--sand); border-color: var(--green); }

/* RIGHT: mosaic stats */
.about-right {
  display: flex; flex-direction: column; gap: 24px;
  padding-top: 8px;
}
.about-mosaic {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.about-stat-card {
  border-radius: 12px; padding: 28px 24px;
  display: flex; flex-direction: column; gap: 6px;
  transition: transform .25s var(--ease), box-shadow .25s;
}
.about-stat-card:hover { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(0,0,0,0.1); }
.ac1 { background: var(--green); }
.ac2 { background: var(--cream); border: 1px solid rgba(0,0,0,0.07); }
.ac3 { background: var(--cream); border: 1px solid rgba(0,0,0,0.07); }
.ac4 { background: var(--parch); border: 1px solid rgba(0,0,0,0.07); }
.asc-num {
  font-family: var(--serif);
  font-size: 2.4rem; font-weight: 700; line-height: 1;
}
.ac1 .asc-num { color: var(--sand2); }
.ac2 .asc-num, .ac3 .asc-num, .ac4 .asc-num { color: var(--green); }
.asc-label {
  font-size: 0.72rem; font-weight: 500;
  letter-spacing: 0.08em; text-transform: uppercase;
}
.ac1 .asc-label { color: rgba(255,255,255,0.65); }
.ac2 .asc-label, .ac3 .asc-label, .ac4 .asc-label { color: var(--light); }

/* Pull quote */
.about-quote {
  background: var(--green);
  border-radius: 12px; padding: 28px 32px;
  position: relative;
  overflow: hidden;
}
.about-quote::before {
  content: '';
  position: absolute; bottom: -20px; right: -20px;
  width: 120px; height: 120px; border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.06);
}
.aq-mark {
  font-family: var(--serif);
  font-size: 4rem; color: var(--sand);
  line-height: 0.7; margin-bottom: 10px;
  opacity: 0.7;
}
.about-quote p {
  font-family: var(--serif);
  font-style: italic; font-size: 1rem;
  color: rgba(255,255,255,0.88); line-height: 1.65;
  margin-bottom: 14px;
}
.aq-attr {
  font-size: 0.7rem; font-weight: 500;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--sand2); opacity: 0.8;
}

/* Values strip */
.about-values {
  display: grid; grid-template-columns: repeat(4,1fr);
  border-top: 1px solid rgba(0,0,0,0.07);
  background: var(--cream);
}
.av-item {
  padding: 36px 40px;
  border-right: 1px solid rgba(0,0,0,0.07);
  transition: background .2s;
}
.av-item:last-child { border-right: none; }
.av-item:hover { background: var(--parch); }
.av-icon { font-size: 1.6rem; margin-bottom: 12px; }
.av-item h4 {
  font-family: var(--serif);
  font-size: 0.95rem; font-weight: 600;
  color: var(--green); margin-bottom: 8px;
}
.av-item p {
  font-size: 0.78rem; font-weight: 300;
  color: var(--mid); line-height: 1.7;
}

/* ── WORKSHOP CAROUSEL ───────────────────────────────── */
.workshop {
  background: var(--green);
  padding: 80px 0 0;
  overflow: hidden;
}
.ws-header {
  text-align: center;
  padding: 0 68px 48px;
  position: relative; z-index: 1;
}
.ws-eyebrow {
  display: inline-block;
  font-size: 0.68rem; font-weight: 600;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--sand2); margin-bottom: 14px;
}
.ws-title {
  font-family: var(--serif);
  font-size: 2.2rem; color: #fff;
  font-weight: 700; margin-bottom: 12px;
}
.ws-sub {
  font-size: 0.86rem; font-weight: 300;
  color: rgba(255,255,255,0.55);
  max-width: 520px; margin: 0 auto; line-height: 1.8;
}
.ws-carousel {
  position: relative;
}
.ws-track {
  position: relative;
  width: 100%;
}
.ws-slide {
  display: none;
  animation: wsFade .55s ease both;
}
.ws-slide.active { display: block; }
@keyframes wsFade {
  from { opacity: 0; transform: scale(1.015); }
  to   { opacity: 1; transform: scale(1); }
}
.ws-img-wrap {
  position: relative;
  width: 100%;
  height: 520px;
  overflow: hidden;
}
.ws-img-wrap img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
}
/* Dark gradient at bottom for caption legibility */
.ws-img-wrap::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(
    to top,
    rgba(30,50,35,0.92) 0%,
    rgba(30,50,35,0.55) 30%,
    transparent 60%
  );
}
.ws-caption {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  z-index: 2;
  padding: 40px 68px 60px;
  display: flex; flex-direction: column; gap: 8px;
}
.wsc-num {
  font-size: 0.68rem; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--sand2); opacity: 0.85;
}
.ws-caption h3 {
  font-family: var(--serif);
  font-size: 1.8rem; color: #fff;
  font-weight: 700; line-height: 1.2;
}
.ws-caption p {
  font-size: 0.84rem; font-weight: 300;
  color: rgba(255,255,255,0.72);
  max-width: 480px; line-height: 1.7;
}
/* Arrows */
.ws-arrow {
  position: absolute; top: 50%; transform: translateY(-50%);
  z-index: 10; width: 52px; height: 52px;
  border-radius: 50%; border: 1.5px solid rgba(255,255,255,0.3);
  background: rgba(255,255,255,0.1);
  backdrop-filter: blur(8px);
  cursor: pointer; color: #fff;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s, border-color .2s, transform .2s;
}
.ws-arrow:hover {
  background: rgba(255,255,255,0.22);
  border-color: rgba(255,255,255,0.6);
  transform: translateY(-50%) scale(1.08);
}
.ws-prev { left: 28px; }
.ws-next { right: 28px; }
/* Progress bar */
.ws-progress {
  position: absolute; bottom: 0; left: 0; right: 0;
  height: 3px; background: rgba(255,255,255,0.12);
  z-index: 5;
}
.ws-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--green2), var(--sand));
  width: 33.33%;
  transition: width .5s ease;
}
/* Dots */
.ws-dots {
  position: absolute; bottom: 20px; right: 68px;
  z-index: 5;
  display: flex; gap: 8px; align-items: center;
}
.ws-dot {
  width: 8px; height: 8px; border-radius: 50%;
  border: none; cursor: pointer; padding: 0;
  background: rgba(255,255,255,0.3);
  transition: background .25s, transform .25s;
}
.ws-dot.active {
  background: var(--sand);
  transform: scale(1.3);
}

/* ── SUSTAINABILITY ──────────────────────────────────── */
.sustain{
  background:var(--green);
  padding:84px 68px 76px;
  position:relative;overflow:hidden;
}
.sustain::before{
  content:'';position:absolute;top:-120px;right:-120px;
  width:480px;height:480px;border-radius:50%;
  border:1px solid rgba(255,255,255,0.05);pointer-events:none;
}
.sustain::after{
  content:'';position:absolute;bottom:-80px;left:-80px;
  width:320px;height:320px;border-radius:50%;
  border:1px solid rgba(255,255,255,0.04);pointer-events:none;
}
.sustain-hdr{text-align:center;margin-bottom:60px;position:relative;z-index:1;}
.sustain-tag{
  display:inline-block;font-size:0.67rem;font-weight:600;
  letter-spacing:0.22em;text-transform:uppercase;
  color:var(--sand2);margin-bottom:14px;
}
.sustain-hdr h2{
  font-family:var(--serif);font-size:2.4rem;
  color:#fff;font-weight:400;font-style:italic;
  margin-bottom:14px;line-height:1.2;
}
.sustain-hdr h2 strong{font-style:normal;font-weight:700;}
.sustain-hdr p{
  color:rgba(255,255,255,0.5);font-size:0.88rem;
  font-weight:300;max-width:440px;margin:0 auto;line-height:1.85;
}
.sustain-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:20px;margin-bottom:44px;position:relative;z-index:1;
}
.s-card{
  background:rgba(255,255,255,0.055);
  border:1px solid rgba(255,255,255,0.09);
  border-radius:var(--r);padding:28px 22px;
  transition:background .25s,transform .25s var(--ease);
}
.s-card:hover{background:rgba(255,255,255,0.1);transform:translateY(-5px);}
.s-icon{
  width:48px;height:48px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;margin-bottom:18px;
}
.s-card h3{font-family:var(--serif);font-size:0.95rem;color:#fff;margin-bottom:10px;font-weight:600;}
.s-card p{font-size:0.78rem;color:rgba(255,255,255,0.5);line-height:1.75;margin-bottom:20px;font-weight:300;}
.s-stat{border-top:1px solid rgba(255,255,255,0.09);padding-top:14px;}
.s-num{font-family:var(--serif);font-size:1.65rem;color:var(--sand2);font-weight:700;display:block;line-height:1;margin-bottom:3px;}
.s-unit{font-size:0.65rem;color:rgba(255,255,255,0.36);letter-spacing:0.04em;font-weight:300;}
.sustain-quote{
  background:rgba(255,255,255,0.055);
  border:1px solid rgba(201,168,124,0.22);
  border-radius:var(--r);padding:32px 40px;
  display:flex;align-items:center;justify-content:space-between;gap:32px;
  position:relative;z-index:1;
}
.sq-label{font-size:0.65rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--sand2);display:block;margin-bottom:10px;}
.sq-left p{font-family:var(--serif);font-style:italic;font-size:1.05rem;color:rgba(255,255,255,0.8);line-height:1.65;margin:0;max-width:520px;}
.sq-certs{display:flex;flex-direction:column;gap:10px;flex-shrink:0;}
.cert{
  background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.12);
  color:rgba(255,255,255,0.75);padding:8px 18px;border-radius:20px;
  font-size:0.73rem;font-weight:500;letter-spacing:0.04em;white-space:nowrap;
  transition:background .2s;cursor:default;
}
.cert:hover{background:rgba(255,255,255,0.13);}

/* ── BOTTOM SPLIT ────────────────────────────────────── */
.bottom{display:grid;grid-template-columns:1fr 1fr;}

.mat-panel{background:var(--parch);padding:60px 68px;}
.mat-rule{display:flex;align-items:center;gap:16px;margin-bottom:30px;}
.mat-rule::before,.mat-rule::after{content:'';flex:1;height:1px;background:rgba(0,0,0,0.12);}
.mat-rule span{font-family:var(--serif);font-size:1.2rem;color:var(--text);font-weight:600;white-space:nowrap;}
.mat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.mat-card{
  border-radius:8px;overflow:hidden;background:#fff;
  box-shadow:0 2px 10px rgba(0,0,0,0.07);
  transition:transform .2s,box-shadow .2s;
}
.mat-card:hover{transform:translateY(-3px);box-shadow:0 8px 22px rgba(0,0,0,0.11);}
.mat-swatch{height:90px;overflow:hidden;}
.mat-swatch img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s;}
.mat-card:hover .mat-swatch img{transform:scale(1.07);}
.mat-info{padding:12px 14px 14px;}
.mat-info h4{font-family:var(--serif);font-size:0.88rem;color:var(--text);font-weight:600;margin-bottom:3px;}
.mat-info p{font-size:0.7rem;color:var(--light);font-weight:300;}

.cta-panel{
  background:var(--green);
  display:flex;flex-direction:column;justify-content:center;
}
.cta-inner{padding:56px 60px;}
.cta-inner h2{font-family:var(--serif);font-size:1.75rem;color:#fff;font-weight:600;margin-bottom:10px;line-height:1.25;}
.cta-inner>p{color:rgba(255,255,255,0.58);font-size:0.8rem;font-weight:300;line-height:1.8;margin-bottom:28px;}
.cta-form{display:flex;flex-direction:column;gap:12px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.cta-inp{
  background:rgba(255,255,255,0.92);border:1.5px solid transparent;
  border-radius:4px;padding:11px 15px;
  color:var(--text);font-size:0.8rem;
  font-family:var(--sans);outline:none;width:100%;
  transition:border .2s,box-shadow .2s;
}
.cta-inp::placeholder{color:#aaa;}
.cta-inp:focus{border-color:var(--sand);box-shadow:0 0 0 3px rgba(201,168,124,0.2);background:#fff;}
.ck-row{display:flex;align-items:center;gap:8px;font-size:0.72rem;color:rgba(255,255,255,0.48);}
.ck-row input{accent-color:var(--sand);}
.btn-submit{
  background:var(--sand);color:var(--text);border:none;
  padding:13px;border-radius:4px;font-weight:600;font-size:0.82rem;
  cursor:pointer;letter-spacing:0.06em;font-family:var(--sans);
  width:100%;transition:background .2s,transform .15s,box-shadow .2s;
  box-shadow:0 4px 14px rgba(0,0,0,0.18);
}
.btn-submit:hover{background:#b8946a;transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,0,0,0.22);}
.form-note{font-size:0.63rem;color:rgba(255,255,255,0.26);line-height:1.5;text-align:center;}

/* ── CONTACT US ──────────────────────────────────────── */
.contact-section{background:var(--parch);padding:96px 0;}
.contact-inner{max-width:1120px;margin:0 auto;padding:0 48px;}
.contact-hdr{text-align:center;margin-bottom:56px;}
.contact-eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-size:0.65rem;font-weight:600;letter-spacing:0.22em;
  text-transform:uppercase;color:var(--sand);margin-bottom:14px;
}
.contact-eyebrow::before,.contact-eyebrow::after{content:'';display:block;width:32px;height:1px;background:var(--sand);}
.contact-title{
  font-family:var(--serif);font-size:2.2rem;font-weight:700;
  color:var(--green);margin-bottom:12px;
}
.contact-title em{font-style:italic;font-weight:400;color:var(--sand);}
.contact-sub{font-size:0.88rem;color:var(--mid);line-height:1.8;max-width:480px;margin:0 auto;}

/* Main layout — two columns */
.contact-layout{
  display:grid;grid-template-columns:1fr 1.1fr;
  gap:24px;align-items:start;
}

/* Left — cards stack */
.contact-cards-col{display:flex;flex-direction:column;gap:14px;}
.contact-card{
  background:#fff;border:1px solid rgba(0,0,0,0.07);
  border-radius:12px;padding:20px 24px;
  display:flex;align-items:center;gap:18px;
  text-decoration:none;
  box-shadow:0 2px 12px rgba(0,0,0,0.05);
  transition:transform .22s var(--ease),box-shadow .22s;
}
.contact-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.1);}
.cc-icon{
  width:48px;height:48px;border-radius:12px;
  background:var(--cream);border:1px solid rgba(0,0,0,0.07);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.cc-body{flex:1;}
.cc-label{
  display:block;font-size:0.62rem;font-weight:700;
  letter-spacing:0.16em;text-transform:uppercase;
  color:var(--light);margin-bottom:3px;
}
.cc-value{
  display:block;font-size:0.92rem;font-weight:500;color:var(--green);
}
.cc-arrow{
  font-size:1rem;color:var(--sand);
  transition:transform .2s;flex-shrink:0;
}
.contact-card:hover .cc-arrow{transform:translateX(4px);}

/* Right — address + CTA combined card */
.contact-right-col{display:flex;flex-direction:column;gap:20px;}
.contact-address-card{
  background:var(--green);border-radius:16px;
  padding:36px 36px 32px;
  display:flex;flex-direction:column;gap:0;
  box-shadow:0 8px 32px rgba(45,74,50,0.2);
  flex:1;
}
.cac-icon{
  width:48px;height:48px;border-radius:12px;
  background:rgba(255,255,255,0.1);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:20px;flex-shrink:0;
}
.cac-label{
  font-size:0.62rem;font-weight:700;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--sand2);margin-bottom:10px;
}
.cac-name{
  font-family:var(--serif);font-size:1.4rem;font-weight:700;
  color:#fff;margin-bottom:12px;
}
.cac-addr{
  font-size:0.85rem;color:rgba(255,255,255,0.6);
  line-height:1.9;margin-bottom:24px;
}
.cac-maps{
  display:inline-flex;align-items:center;gap:8px;
  font-size:0.78rem;font-weight:600;color:var(--sand2);
  text-decoration:none;letter-spacing:0.04em;
  border-bottom:1px solid rgba(201,168,124,0.3);
  padding-bottom:2px;transition:color .2s;
  margin-bottom:28px;
}
.cac-maps:hover{color:#fff;}

/* CTA inside address card */
.cac-cta-divider{width:100%;height:1px;background:rgba(255,255,255,0.1);margin:4px 0 24px;}
.cac-cta-label{
  font-size:0.7rem;font-weight:600;letter-spacing:0.14em;
  text-transform:uppercase;color:rgba(255,255,255,0.4);margin-bottom:14px;
}
.cac-cta-btns{display:flex;gap:12px;flex-wrap:wrap;}
.cac-btn-primary{
  background:var(--sand);color:var(--text);
  padding:11px 22px;border-radius:6px;
  font-size:0.78rem;font-weight:600;letter-spacing:0.05em;
  text-decoration:none;transition:background .2s,transform .15s;
  display:inline-block;
}
.cac-btn-primary:hover{background:#b8946a;transform:translateY(-1px);}
.cac-btn-ghost{
  background:rgba(255,255,255,0.08);color:#fff;
  padding:11px 22px;border-radius:6px;
  font-size:0.78rem;font-weight:500;
  text-decoration:none;border:1px solid rgba(255,255,255,0.18);
  transition:background .2s;display:inline-block;
}
.cac-btn-ghost:hover{background:rgba(255,255,255,0.15);}

/* WhatsApp card */
.contact-wa-card{
  background:#fff;border:1px solid rgba(0,0,0,0.07);
  border-radius:12px;padding:20px 24px;
  display:flex;align-items:center;gap:18px;
  text-decoration:none;
  box-shadow:0 2px 12px rgba(0,0,0,0.05);
  transition:transform .22s var(--ease),box-shadow .22s;
}
.contact-wa-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.1);}
.wa-icon{
  width:48px;height:48px;border-radius:12px;
  background:#e8f5e9;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  font-size:1.4rem;
}
.wa-body{flex:1;}
.wa-label{display:block;font-size:0.62rem;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--light);margin-bottom:3px;}
.wa-value{display:block;font-size:0.92rem;font-weight:500;color:#25a244;}
.wa-arrow{font-size:1rem;color:#25a244;transition:transform .2s;}
.contact-wa-card:hover .wa-arrow{transform:translateX(4px);}

@media(max-width:768px){
  .contact-layout{grid-template-columns:1fr;}
  .contact-inner{padding:0 24px;}
  .contact-title{font-size:1.7rem;}
}

.contact-section {
  background: #ede8de;
  padding: 80px 0 0;
  overflow: hidden;
}
.contact-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 68px 80px;
}
.contact-hdr {
  text-align: center;
  margin-bottom: 52px;
}
.contact-eyebrow {
  display: inline-flex; align-items: center; gap: 12px;
  font-size: 0.68rem; font-weight: 600;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--sand); margin-bottom: 16px;
}
.contact-eyebrow::before,
.contact-eyebrow::after {
  content: ''; display: block;
  width: 32px; height: 1.5px; background: var(--sand);
}
.contact-title {
  font-family: var(--serif);
  font-size: 2.6rem; font-weight: 700;
  color: var(--green); line-height: 1.15;
  margin-bottom: 14px;
}
.contact-title em {
  font-style: italic; font-weight: 400;
  color: var(--sand);
}
.contact-sub {
  font-size: 0.88rem; font-weight: 300;
  color: var(--mid); max-width: 460px;
  margin: 0 auto; line-height: 1.8;
}

/* Cards */
.contact-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 44px;
}
.contact-card {
  background: #fff;
  border: 1px solid rgba(0,0,0,0.07);
  border-radius: 14px;
  padding: 26px 22px;
  display: flex; align-items: center; gap: 16px;
  text-decoration: none;
  transition: transform .25s var(--ease), box-shadow .25s, border-color .25s;
  box-shadow: 0 2px 12px rgba(0,0,0,0.05);
}
.contact-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 14px 36px rgba(45,74,50,0.12);
  border-color: var(--sand);
}
.cc-icon {
  width: 52px; height: 52px; flex-shrink: 0;
  background: #f0ebe0;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s;
}
.contact-card:hover .cc-icon { background: #e8dfc8; }
.cc-body {
  flex: 1; min-width: 0;
  display: flex; flex-direction: column; gap: 4px;
}
.cc-label {
  font-size: 0.66rem; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--light);
}
.cc-value {
  font-family: var(--serif);
  font-size: 0.9rem; font-weight: 600;
  color: var(--green); white-space: nowrap;
  overflow: hidden; text-overflow: ellipsis;
}
.cc-arrow {
  font-size: 1rem; color: var(--sand);
  flex-shrink: 0; opacity: 0;
  transform: translateX(-4px);
  transition: opacity .2s, transform .2s;
}
.contact-card:hover .cc-arrow {
  opacity: 1; transform: translateX(0);
}


/* Corporate Address Card */
.contact-address-card{
  display:flex;align-items:flex-start;gap:18px;
  background:#fff;border:1px solid rgba(0,0,0,0.07);
  border-radius:12px;padding:28px 32px;
  box-shadow:0 2px 16px rgba(0,0,0,0.05);
  margin-top:8px;
}
.cac-icon{
  width:44px;height:44px;border-radius:50%;
  background:var(--cream);border:1px solid rgba(0,0,0,0.08);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.cac-label{
  font-size:0.62rem;font-weight:700;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--sand);margin-bottom:6px;
}
.cac-name{
  font-family:var(--serif);font-size:1.05rem;font-weight:600;
  color:var(--green);margin-bottom:6px;
}
.cac-addr{
  font-size:0.82rem;font-weight:400;color:var(--mid);
  line-height:1.8;margin-bottom:12px;
}
.cac-maps{
  font-size:0.75rem;font-weight:600;color:var(--sand);
  text-decoration:none;letter-spacing:0.04em;
  border-bottom:1px solid var(--sand2);
  transition:color .2s;
}
.cac-maps:hover{color:#a07845;}

/* Map */
.contact-map {
  display: block;
  width: 100%; height: 360px;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 4px 28px rgba(0,0,0,0.1);
  border: 1px solid rgba(0,0,0,0.07);
  text-decoration: none;
  position: relative;
  cursor: pointer;
  transition: box-shadow .25s, transform .25s;
}
.contact-map:hover {
  box-shadow: 0 12px 40px rgba(45,74,50,0.15);
  transform: translateY(-3px);
}
.map-static {
  width: 100%; height: 100%;
  position: relative;
  background: #e8e0d0;
}
.map-bg {
  width: 100%; height: 100%;
  overflow: hidden;
}
.map-bg img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  filter: saturate(0.7) sepia(0.15);
}
/* Fallback map if image fails */
.map-fallback {
  background:
    linear-gradient(rgba(232,224,208,0.6), rgba(232,224,208,0.6)),
    repeating-linear-gradient(0deg, transparent, transparent 40px, rgba(180,170,150,0.3) 40px, rgba(180,170,150,0.3) 41px),
    repeating-linear-gradient(90deg, transparent, transparent 60px, rgba(180,170,150,0.3) 60px, rgba(180,170,150,0.3) 61px);
}
/* Road-like decorative lines on fallback */
.map-fallback::before {
  content: '';
  position: absolute; inset: 0;
  background:
    linear-gradient(45deg, transparent 48%, rgba(200,185,160,0.5) 48%, rgba(200,185,160,0.5) 52%, transparent 52%),
    linear-gradient(-20deg, transparent 35%, rgba(210,195,170,0.4) 35%, rgba(210,195,170,0.4) 38%, transparent 38%),
    linear-gradient(80deg, transparent 55%, rgba(205,190,165,0.4) 55%, rgba(205,190,165,0.4) 58%, transparent 58%);
}
/* Pin card overlay */
.map-pin-wrap {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(237,232,222,0.22);
}
.map-pin-card {
  background: #fff;
  border-radius: 14px;
  padding: 18px 24px;
  display: flex; align-items: center; gap: 14px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.14);
  border: 1px solid rgba(0,0,0,0.06);
  max-width: 380px; width: 90%;
  transition: transform .2s;
}
.contact-map:hover .map-pin-card { transform: scale(1.02); }
.map-pin-icon {
  width: 44px; height: 44px;
  background: #f0ebe0; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.map-pin-text {
  flex: 1;
  display: flex; flex-direction: column; gap: 2px;
}
.map-pin-text strong {
  font-family: var(--serif);
  font-size: 0.95rem; color: var(--green); font-weight: 700;
}
.map-pin-text span {
  font-size: 0.74rem; color: var(--light); font-weight: 300;
}
.map-pin-open {
  font-size: 0.72rem; font-weight: 600;
  color: var(--sand); letter-spacing: 0.04em;
  white-space: nowrap;
  border-bottom: 1px solid var(--sand);
  padding-bottom: 1px;
}
/* Map decorative grid bg */
.map-static::after {
  content: '';
  position: absolute; inset: 0;
  background:
    repeating-linear-gradient(0deg, transparent, transparent 44px, rgba(180,168,145,0.2) 44px, rgba(180,168,145,0.2) 45px),
    repeating-linear-gradient(90deg, transparent, transparent 64px, rgba(180,168,145,0.2) 64px, rgba(180,168,145,0.2) 65px);
  pointer-events: none;
}
/* Fake road lines for visual interest */
.map-static::before {
  content: '';
  position: absolute; inset: 0;
  background:
    linear-gradient(35deg, transparent 30%, rgba(210,198,175,0.55) 30%, rgba(210,198,175,0.55) 32%, transparent 32%),
    linear-gradient(-15deg, transparent 20%, rgba(215,203,180,0.45) 20%, rgba(215,203,180,0.45) 22%, transparent 22%),
    linear-gradient(75deg, transparent 50%, rgba(208,196,173,0.45) 50%, rgba(208,196,173,0.45) 52%, transparent 52%),
    linear-gradient(110deg, transparent 42%, rgba(212,200,177,0.4) 42%, rgba(212,200,177,0.4) 44%, transparent 44%);
  pointer-events: none;
}


/* ── FOOTER ──────────────────────────────────────────── */
footer{background:#1e2e21;color:rgba(255,255,255,0.38);text-align:center;padding:22px;font-size:0.72rem;letter-spacing:0.05em;}

/* ── ANIMATIONS ──────────────────────────────────────── */
@keyframes riseUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}


/* ── PRODUCTS PAGE ── */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
:root{
  --green:#2d4a32;--green2:#3d6b42;--sand:#c9a87c;--sand2:#e2c99a;
  --cream:#f6f1e9;--parch:#ede8de;--warm:#faf8f4;
  --text:#2a2a2a;--mid:#5a5a5a;--light:#8a8a8a;
  --serif:'Playfair Display',Georgia,serif;
  --sans:'Jost',system-ui,sans-serif;
  --ease:cubic-bezier(.22,.68,0,1.2);
  --r:10px;
}
html{scroll-behavior:smooth;}
body{font-family:var(--sans);background:var(--warm);color:var(--text);-webkit-font-smoothing:antialiased;overflow-x:hidden;}

/* ── NAV ── */
nav{
  position:sticky;top:0;z-index:300;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 60px;height:74px;
  background:rgba(250,248,244,0.97);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(0,0,0,0.07);
}
.nav-logo img{height:72px;width:auto;display:block;position:relative;top:10px;filter:drop-shadow(0 3px 8px rgba(0,0,0,0.1));}
.nav-links{display:flex;align-items:center;gap:34px;list-style:none;}
.nav-links a{text-decoration:none;font-size:0.83rem;font-weight:500;letter-spacing:0.04em;color:var(--text);position:relative;transition:color .2s;}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;right:100%;height:1.5px;background:var(--green);transition:right .25s var(--ease);}
.nav-links a:hover{color:var(--green);}
.nav-links a:hover::after{right:0;}
.nav-links a.active{color:var(--green);}
.nav-links a.active::after{right:0;}
.nav-cta{background:var(--sand)!important;color:var(--text)!important;padding:10px 22px;border-radius:4px;font-weight:600!important;letter-spacing:0.06em!important;}
.nav-cta:hover{background:#b8946a!important;}
.nav-cta::after{display:none!important;}
.wordmark{display:flex;flex-direction:column;text-decoration:none;gap:0;position:relative;}
.wordmark-top{font-family:var(--serif);font-size:1.85rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;background:linear-gradient(105deg,#1e3322 0%,#2d4a32 20%,#3d6b42 42%,#c9a87c 68%,#e2c99a 82%,#c9a87c 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;}
.wordmark-bottom{font-family:var(--serif);font-size:0.46rem;font-weight:400;letter-spacing:0.55em;text-transform:uppercase;color:#a0b0a2;padding-left:1px;margin-top:4px;}
.wordmark::after{content:'';display:block;width:100%;height:1px;margin-top:5px;background:linear-gradient(90deg,transparent 0%,#3d6b42 25%,#c9a87c 60%,transparent 100%);}

/* ── PAGE HERO ── */
.page-hero{
  background:var(--green);
  padding:64px 68px 56px;
  position:relative;overflow:hidden;
}
.page-hero::before{
  content:'';position:absolute;right:-60px;top:-60px;
  width:360px;height:360px;border-radius:50%;
  border:1px solid rgba(255,255,255,0.06);pointer-events:none;
}
.page-hero::after{
  content:'';position:absolute;left:-40px;bottom:-80px;
  width:240px;height:240px;border-radius:50%;
  border:1px solid rgba(255,255,255,0.04);pointer-events:none;
}
.ph-eyebrow{font-size:0.67rem;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--sand2);display:block;margin-bottom:14px;}
.page-hero h1{font-family:var(--serif);font-size:2.8rem;color:#fff;font-weight:700;line-height:1.15;margin-bottom:12px;}
.page-hero h1 em{font-style:italic;font-weight:400;color:var(--sand);}
.page-hero p{color:rgba(255,255,255,0.58);font-size:0.88rem;font-weight:300;max-width:460px;line-height:1.8;}
.ph-stats{display:flex;gap:48px;margin-top:40px;}
.ph-stat{}
.ph-stat-num{font-family:var(--serif);font-size:2rem;font-weight:700;color:var(--sand2);display:block;line-height:1;}
.ph-stat-lbl{font-size:0.68rem;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.45);margin-top:4px;display:block;}

/* ── FILTER BAR ── */
.filter-bar{
  position:sticky;top:74px;z-index:200;
  background:rgba(250,248,244,0.98);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(0,0,0,0.07);
  padding:0 68px;
  display:flex;align-items:center;gap:0;
}
.filter-group{display:flex;align-items:center;gap:8px;padding:16px 0;}
.filter-group+.filter-group{
  margin-left:32px;padding-left:32px;
  border-left:1px solid rgba(0,0,0,0.1);
}
.filter-label{font-size:0.67rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--light);margin-right:4px;white-space:nowrap;}
.filter-btn{
  padding:6px 14px;border-radius:20px;
  border:1.5px solid rgba(0,0,0,0.12);
  background:transparent;cursor:pointer;
  font-family:var(--sans);font-size:0.76rem;font-weight:500;
  color:var(--mid);letter-spacing:0.03em;
  transition:all .2s;white-space:nowrap;
}
.filter-btn:hover{border-color:var(--green);color:var(--green);background:rgba(45,74,50,0.04);}
.filter-btn.active{background:var(--green);border-color:var(--green);color:#fff;}
.filter-count{
  margin-left:auto;
  font-size:0.75rem;color:var(--light);
  font-weight:400;white-space:nowrap;
  padding:16px 0;
}
.filter-count span{color:var(--green);font-weight:600;}

/* ── PRODUCT GRID ── */
.products-page{padding:48px 68px 80px;}

.prod-item:hover .pi-img img{transform:scale(1.05);}
.pi-overlay{
  position:absolute;inset:0;z-index:1;
  background:rgba(45,74,50,0.72);
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .3s;
  pointer-events:none;
}
.prod-item:hover .prod-item:hover .pi-overlay{opacity:1;}
.pi-btn{
  background:#fff;color:var(--green);
  padding:11px 24px;border-radius:4px;
  font-size:0.8rem;font-weight:600;letter-spacing:0.05em;
  text-decoration:none;
  transform:translateY(8px);
  transition:transform .3s var(--ease),background .2s;
}
.prod-item:hover .pi-btn{transform:translateY(0);}
.pi-btn:hover{background:var(--sand);color:var(--text);}
.pi-badge{
  position:absolute;top:12px;left:12px;
  background:rgba(45,74,50,0.88);color:#fff;
  font-size:0.62rem;font-weight:600;letter-spacing:0.1em;
  text-transform:uppercase;padding:4px 10px;border-radius:20px;
  backdrop-filter:blur(4px);
}
.pi-body{padding:16px 18px 20px;display:flex;flex-direction:column;flex:1;}
.pi-cat{font-size:0.68rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--mid);display:block;margin-bottom:4px;}
.pi-name{font-family:var(--serif);font-size:1rem;font-weight:600;color:var(--text);margin-bottom:6px;line-height:1.3;}
.pi-desc{font-size:0.74rem;color:var(--light);line-height:1.55;margin-bottom:12px;font-weight:300;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.pi-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:12px;border-top:1px solid rgba(0,0,0,0.06);}
.pi-price{font-size:0.72rem;font-weight:500;color:var(--mid);}
.pi-cta{
  font-size:0.76rem;font-weight:600;color:var(--green);
  text-decoration:none;letter-spacing:0.04em;
  border-bottom:1.5px solid var(--sand);padding-bottom:1px;
  transition:color .2s,border-color .2s;
}
.pi-cta:hover{color:var(--sand);border-color:var(--green);}

/* No results */
.no-results{
  grid-column:1/-1;text-align:center;
  padding:80px 0;display:none;
}
.no-results.show{display:block;}
.no-results p{font-family:var(--serif);font-size:1.2rem;color:var(--light);font-style:italic;}


/* ── PRODUCT GRID ────────────────────────────────────── */
.products-page { padding: 40px 68px 80px; }
.prod-grid-layout {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.cat-header {
  grid-column: 1 / -1;
  display: flex; align-items: center; gap: 16px;
  margin: 40px 0 8px;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--green);
}
.cat-header:first-child { margin-top: 0; }
.cat-header h2 {
  font-family: var(--serif);
  font-size: 1.35rem; font-weight: 700; color: var(--green);
}
.cat-header::after { display: none; }
.no-results {
  grid-column: 1/-1; text-align: center;
  padding: 60px 0; display: none;
}
.no-results.show { display: block; }
.no-results p { font-family: var(--serif); font-size: 1.1rem; color: var(--light); font-style: italic; }

/* Cards */
.prod-item {
  background: #fff;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,0.08);
  box-shadow: 0 2px 10px rgba(0,0,0,0.05);
  transition: transform .3s, box-shadow .3s;
  display: flex; flex-direction: column;
}
.prod-item.hidden { display: none; }
.prod-item:hover {
  transform: translateY(-5px);
  box-shadow: 0 14px 36px rgba(0,0,0,0.12);
}

/* Image area */
.pi-img {
  position: relative;
  width: 100%; height: 240px;
  overflow: hidden;
  background: #f8f8f8;
  flex-shrink: 0;
}
.pi-img img {
  width: 100%; height: 100%;
  object-fit: contain;
  padding: 16px;
  display: block;
  transition: transform .4s;
}
.prod-item:hover .pi-img img { transform: scale(1.04); }

/* Gallery */
.gallery-wrap {
  position: relative;
  width: 100%; height: 240px;
  overflow: hidden;
  flex-shrink: 0;
  z-index: 4;
}
.gallery-img {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  object-fit: contain;
  padding: 16px;
  opacity: 0;
  transition: opacity .4s ease;
  pointer-events: none;
  background: #f8f8f8;
}
.gallery-img.active {
  opacity: 1;
  pointer-events: auto;
  cursor: zoom-in;
  z-index: 5;
}

/* Overlay */


.pi-btn {
  background: #fff; color: var(--green);
  padding: 10px 22px; border-radius: 4px;
  font-size: 0.8rem; font-weight: 600;
  text-decoration: none; letter-spacing: 0.04em;
}
.pi-btn:hover { background: var(--sand); color: var(--text); }

/* Badge & code */
.pi-badge {
  position: absolute; top: 10px; left: 10px; z-index: 4;
  background: rgba(45,74,50,0.85); color: #fff;
  font-size: 0.6rem; font-weight: 600; letter-spacing: 0.1em;
  text-transform: uppercase; padding: 3px 9px;
  border-radius: 20px; backdrop-filter: blur(4px);
}
.pi-code {
  position: absolute; top: 10px; right: 10px; z-index: 4;
  background: rgba(0,0,0,0.5); color: rgba(255,255,255,0.9);
  font-size: 0.58rem; font-weight: 600; letter-spacing: 0.06em;
  padding: 3px 8px; border-radius: 3px;
}

/* Gallery controls */
.gallery-dots {
  position: absolute; bottom: 8px; left: 50%;
  transform: translateX(-50%); z-index: 5;
  display: flex; gap: 5px;
}
.gdot {
  width: 6px; height: 6px; border-radius: 50%;
  background: rgba(255,255,255,0.45); border: none;
  cursor: pointer; padding: 0;
  transition: background .2s, transform .2s;
}
.gdot.active { background: #fff; transform: scale(1.3); }
.gal-prev, .gal-next {
  position: absolute; top: 50%; transform: translateY(-50%);
  z-index: 5; width: 28px; height: 28px; border-radius: 50%;
  background: rgba(255,255,255,0.15); border: 1px solid rgba(255,255,255,0.3);
  color: #fff; font-size: 1rem; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity .2s, background .2s;
}
.real-product:hover .gal-prev,
.real-product:hover .gal-next { opacity: 1; }
.gal-prev { left: 8px; }
.gal-next { right: 8px; }
.gal-prev:hover, .gal-next:hover { background: rgba(255,255,255,0.3); }

/* Body */
.pi-body { padding: 16px 18px 18px; flex: 1; display: flex; flex-direction: column; }
.pi-cat { font-size: 0.65rem; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--sand); display: block; margin-bottom: 4px; }
.pi-name { font-family: var(--serif); font-size: 0.95rem; font-weight: 700; color: var(--text); margin-bottom: 5px; line-height: 1.3; }
.pi-desc { font-size: 0.74rem; color: var(--light); line-height: 1.55; margin-bottom: 12px; font-weight: 300; flex: 1; }
.pi-footer { display: flex; align-items: center; justify-content: space-between; padding-top: 10px; border-top: 1px solid rgba(0,0,0,0.06); margin-top: auto; }
.pi-price { font-size: 0.72rem; font-weight: 500; color: var(--mid); }
.pi-cta { font-size: 0.74rem; font-weight: 600; color: var(--green); text-decoration: none; border-bottom: 1.5px solid var(--sand); padding-bottom: 1px; transition: color .2s; }
.pi-cta:hover { color: var(--sand); }
.pi-specs { margin: 8px 0 12px; border-top: 1px solid rgba(0,0,0,0.06); padding-top: 10px; display: flex; flex-direction: column; gap: 4px; }
.spec-row { display: flex; gap: 8px; font-size: 0.72rem; }
.spec-k { color: var(--light); font-weight: 500; min-width: 64px; flex-shrink: 0; }
.spec-v { color: var(--text); font-weight: 400; }
.btn-dark-green { display: inline-flex; align-items: center; gap: 5px; background: var(--green); color: #fff; padding: 9px 18px; border-radius: 4px; font-size: 0.76rem; font-weight: 600; text-decoration: none; transition: background .2s; margin-top: 4px; }
.btn-dark-green:hover { background: #1e3422; }
.btn-dark-green::after { content: ' ›'; }

/* ── CTA BANNER ── */
.cta-banner{
  background:var(--green);
  margin:0 68px 80px;border-radius:16px;
  padding:52px 60px;
  display:flex;align-items:center;justify-content:space-between;gap:40px;
  position:relative;overflow:hidden;
}
.cta-banner::before{content:'';position:absolute;right:-60px;top:-60px;width:280px;height:280px;border-radius:50%;border:1px solid rgba(255,255,255,0.06);}
.cb-text h2{font-family:var(--serif);font-size:1.8rem;color:#fff;font-weight:700;margin-bottom:8px;}
.cb-text p{color:rgba(255,255,255,0.58);font-size:0.86rem;font-weight:300;line-height:1.7;max-width:420px;}
.cb-btns{display:flex;gap:14px;flex-shrink:0;}
.btn-sand{background:var(--sand);color:var(--text);padding:13px 28px;border-radius:4px;font-size:0.84rem;font-weight:600;letter-spacing:0.05em;text-decoration:none;transition:background .2s,transform .15s;box-shadow:0 4px 14px rgba(0,0,0,0.18);}
.btn-sand:hover{background:#b8946a;transform:translateY(-2px);}
.btn-ghost-w{border:1.5px solid rgba(255,255,255,0.35);color:#fff;padding:13px 28px;border-radius:4px;font-size:0.84rem;font-weight:500;text-decoration:none;transition:all .2s;}
.btn-ghost-w:hover{background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.6);}


/* ── GALLERY IN CARD ─────────────────────────────────── */
.

.gallery-wrap { position: relative; width: 100%; height: 260px; overflow: hidden; display: block; flex-shrink: 0; }
.gallery-img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: contain; padding: 16px; opacity: 0; transition: opacity .45s ease; pointer-events: none; background: #f8f8f8; }
.gallery-img.active { opacity: 1; pointer-events: auto; cursor: zoom-in; z-index: 2; }
.gallery-dots { position:absolute; bottom:10px; left:50%; transform:translateX(-50%); display:flex; gap:6px; z-index:5; }
.gdot { width:6px; height:6px; border-radius:50%; background:rgba(255,255,255,0.5); cursor:pointer; transition:background .2s, transform .2s; border:none; padding:0; }
.gdot.active { background:#fff; transform:scale(1.3); }
.gal-prev, .gal-next { position:absolute; top:50%; transform:translateY(-50%); z-index:5; background:rgba(255,255,255,0.18); backdrop-filter:blur(4px); border:1px solid rgba(255,255,255,0.3); color:#fff; width:30px; height:30px; border-radius:50%; cursor:pointer; font-size:1.1rem; display:flex; align-items:center; justify-content:center; opacity:0; transition:opacity .2s, background .2s; }
.real-product:hover .gal-prev, .real-product:hover .gal-next { opacity:1; }
.gal-prev { left:10px; } .gal-next { right:10px; }
.gal-prev:hover, .gal-next:hover { background:rgba(255,255,255,0.32); }
.pi-code { position:absolute; top:12px; right:12px; background:rgba(0,0,0,0.55); color:rgba(255,255,255,0.9); font-size:0.6rem; font-weight:600; letter-spacing:0.08em; padding:3px 8px; border-radius:3px; backdrop-filter:blur(4px); }

/* ── SPECS TABLE ─────────────────────────────────────── */
.pi-specs { margin: 12px 0 16px; border-top:1px solid rgba(0,0,0,0.07); padding-top:12px; display:flex; flex-direction:column; gap:5px; }
.spec-row { display:flex; align-items:baseline; gap:8px; font-size:0.74rem; }
.spec-k { color:var(--light); font-weight:500; min-width:72px; flex-shrink:0; letter-spacing:0.02em; }
.spec-v { color:var(--text); font-weight:400; }


/* ── FOOTER ── */
footer{background:#1e2e21;color:rgba(255,255,255,0.38);text-align:center;padding:22px;font-size:0.72rem;letter-spacing:0.05em;}

@keyframes fadeIn{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);}}


/* ── GET A QUOTE PAGE ── */

/* ── RESET & TOKENS — identical to index.html ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
:root{
  --green:#2d4a32;--green2:#3d5e42;--green3:#5a7d5f;
  --sand:#c9a87c;--sand2:#e2c99a;
  --cream:#f6f1e9;--parch:#ede6d8;--warm:#faf8f4;
  --text:#2a2a2a;--mid:#5a5a5a;--light:#8a8a8a;
  --serif:'Playfair Display',Georgia,serif;
  --sans:'Jost',system-ui,sans-serif;
  --ease:cubic-bezier(.22,.68,0,1.2);--r:10px;
}
html{scroll-behavior:smooth;}
body{font-family:var(--sans);background:var(--warm);color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased;}

/* NAV — exact copy */
nav{position:sticky;top:0;z-index:300;display:flex;align-items:center;justify-content:space-between;padding:0 60px;height:74px;background:rgba(250,248,244,0.97);backdrop-filter:blur(14px);border-bottom:1px solid rgba(0,0,0,0.07);}
.wordmark{display:flex;flex-direction:column;text-decoration:none;gap:0;position:relative;}
.wordmark-top{font-family:var(--serif);font-size:1.85rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;background:linear-gradient(105deg,#1e3322 0%,#2d4a32 20%,#3d6b42 42%,#c9a87c 68%,#e2c99a 82%,#c9a87c 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;}
.wordmark-bottom{font-family:var(--serif);font-size:0.46rem;font-weight:400;letter-spacing:0.55em;text-transform:uppercase;color:#a0b0a2;padding-left:1px;margin-top:4px;}
.wordmark::after{content:'';display:block;width:100%;height:1px;margin-top:5px;background:linear-gradient(90deg,transparent 0%,#3d6b42 25%,#c9a87c 60%,transparent 100%);}
.nav-links{display:flex;align-items:center;gap:34px;list-style:none;}
.nav-links a{text-decoration:none;font-size:0.83rem;font-weight:500;letter-spacing:0.04em;color:var(--text);position:relative;transition:color .2s;}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;right:100%;height:1.5px;background:var(--green);transition:right .25s var(--ease);}
.nav-links a:hover{color:var(--green);}
.nav-links a:hover::after{right:0;}
.nav-cta{background:var(--sand)!important;color:var(--text)!important;padding:10px 22px;border-radius:4px;font-weight:600!important;letter-spacing:0.06em!important;transition:background .2s,transform .15s!important;}
.nav-cta:hover{background:#b8946a!important;transform:translateY(-1px);}
.nav-cta::after{display:none!important;}

/* PAGE HERO — styled like the about/contact headers in landing */
.page-hero{background:var(--green);padding:80px 68px 72px;display:flex;align-items:center;justify-content:center;gap:48px;border-bottom:none;position:relative;overflow:hidden;}
.page-hero::before{content:'';position:absolute;right:-60px;top:-60px;width:300px;height:300px;border-radius:50%;border:1px solid rgba(255,255,255,0.07);pointer-events:none;}
.page-hero::after{content:'';position:absolute;right:80px;top:30px;width:160px;height:160px;border-radius:50%;border:1px solid rgba(255,255,255,0.05);pointer-events:none;}
.ph-left{flex:1;text-align:center;}
.ph-eyebrow{display:inline-flex;align-items:center;justify-content:center;gap:12px;font-size:0.68rem;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--sand2);margin-bottom:16px;}
.ph-eyebrow::before,.ph-eyebrow::after{content:'';display:block;width:32px;height:1.5px;background:var(--sand2);}
.ph-title{font-family:var(--serif);font-size:2.8rem;font-weight:700;color:#fff;line-height:1.1;margin-bottom:16px;}
.ph-title em{font-style:italic;font-weight:400;color:var(--sand2);letter-spacing:0.01em;font-size:inherit;}
.ph-sub{font-size:0.88rem;font-weight:300;color:rgba(255,255,255,0.62);line-height:1.8;max-width:520px;margin:0 auto;}
.ph-right{display:none;}
.ph-pill{background:#fff;border:1px solid rgba(0,0,0,0.08);border-radius:8px;padding:14px 20px;display:flex;align-items:center;gap:12px;font-size:0.78rem;color:var(--mid);box-shadow:0 2px 8px rgba(0,0,0,0.05);min-width:230px;text-decoration:none;}
.ph-pill-icon{width:36px;height:36px;border-radius:8px;background:var(--cream);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;}
.ph-pill-body strong{display:block;color:var(--green);font-weight:600;font-size:0.82rem;margin-bottom:2px;}

/* FORM WRAP */
.form-wrap{max-width:1060px;margin:0 auto;padding:52px 24px 88px;}

/* FORM SECTIONS — styled like prod-card */
.form-section{background:#fff;border:1px solid rgba(0,0,0,0.07);border-radius:var(--r);padding:36px 40px 32px;margin-bottom:20px;box-shadow:0 2px 16px rgba(0,0,0,0.05),0 0 0 1px rgba(0,0,0,0.03);position:relative;overflow:hidden;animation:riseUp .55s var(--ease) both;}
.form-section::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,var(--green) 0%,var(--sand) 100%);border-radius:var(--r) 0 0 var(--r);}
.form-section:nth-child(1){animation-delay:.06s}
.form-section:nth-child(2){animation-delay:.12s}
.form-section:nth-child(3){animation-delay:.18s}
.form-section:nth-child(4){animation-delay:.24s}
.form-section:nth-child(5){animation-delay:.30s}
.form-section:nth-child(6){animation-delay:.36s}
.form-section:nth-child(7){animation-delay:.42s}
@keyframes riseUp{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:translateY(0);}}

/* Section label */
.section-label{display:flex;align-items:center;gap:16px;margin-bottom:26px;padding-bottom:18px;border-bottom:1px solid rgba(0,0,0,0.06);}
.sl-num{font-family:var(--serif);font-size:2rem;font-weight:700;color:var(--sand2);line-height:1;flex-shrink:0;opacity:0.55;}
.sl-title{font-family:var(--serif);font-size:1.05rem;font-weight:600;color:var(--green);margin-bottom:3px;}
.sl-sub{font-size:0.72rem;font-weight:400;color:var(--light);}

/* Grid rows */
.row{display:grid;gap:12px;margin-bottom:12px;}
.row:last-child{margin-bottom:0;}
.row.c2{grid-template-columns:1fr 1fr;}
.row.c3{grid-template-columns:1fr 1fr 1fr;}
.row.c4{grid-template-columns:1.6fr 1fr 18px 1fr;align-items:center;}
.x-sep{font-size:0.8rem;font-weight:500;color:var(--light);text-align:center;user-select:none;}

/* Inputs — match cta-inp from landing */
input,select,textarea{width:100%;font-family:var(--sans);font-size:0.82rem;color:var(--text);background:rgba(250,248,244,0.8);border:1.5px solid rgba(0,0,0,0.1);border-radius:4px;padding:11px 15px;transition:border .2s,box-shadow .2s,background .2s;outline:none;-webkit-appearance:none;appearance:none;}
input::placeholder,textarea::placeholder{color:rgba(90,90,90,0.42);}
input:focus,select:focus,textarea:focus{border-color:var(--sand);box-shadow:0 0 0 3px rgba(201,168,124,0.15);background:#fff;}
select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7' fill='none'%3E%3Cpath d='M1 1l4.5 4.5L10 1' stroke='%232d4a32' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 13px center;padding-right:36px;cursor:pointer;background-color:rgba(250,248,244,0.8);}
select:focus{background-color:#fff;}
textarea{resize:vertical;min-height:100px;line-height:1.7;}

/* Print block */
.print-block{background:var(--cream);border-radius:8px;padding:18px 20px;margin-top:4px;border:1px solid rgba(0,0,0,0.05);}
.print-block-title{font-size:0.68rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--green);margin-bottom:14px;opacity:0.7;}
.print-row{display:grid;grid-template-columns:70px 1fr 18px 1fr;gap:10px;align-items:center;margin-bottom:10px;}
.print-row:last-child{margin-bottom:0;}
.print-tag{font-size:0.73rem;font-weight:600;color:var(--green);}

.field-note{font-size:0.7rem;color:var(--light);font-style:italic;margin-top:8px;padding-left:2px;}
.req{color:var(--sand);font-weight:700;}

/* Submit — match btn-filled from landing */
.submit-area{text-align:center;padding:44px 0 12px;}
.btn-submit-main{background:var(--green);color:#fff;border:none;font-family:var(--sans);font-size:0.85rem;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;padding:16px 64px;border-radius:4px;cursor:pointer;box-shadow:0 6px 20px rgba(45,74,50,0.28);transition:background .2s,transform .15s,box-shadow .2s;}
.btn-submit-main:hover{background:#1e3422;transform:translateY(-2px);box-shadow:0 10px 30px rgba(45,74,50,0.35);}
.btn-submit-main:active{transform:translateY(0);}
.submit-note{font-size:0.73rem;color:var(--light);margin-top:14px;line-height:1.7;}
.submit-note a{color:var(--sand);text-decoration:none;border-bottom:1px solid var(--sand2);}

/* Success — styled like about-quote block */
.success-wrap{display:none;background:var(--green);border-radius:var(--r);padding:64px 48px;text-align:center;margin-top:28px;animation:riseUp .5s var(--ease) both;}
.success-wrap h3{font-family:var(--serif);font-size:2rem;color:#fff;margin-bottom:10px;}
.success-sand{width:52px;height:2px;background:var(--sand);margin:18px auto;border-radius:2px;}
.success-wrap p{font-size:0.86rem;color:rgba(255,255,255,0.6);line-height:1.8;max-width:440px;margin:0 auto;}

/* Footer — exact */
footer{background:#1e2e21;color:rgba(255,255,255,0.38);text-align:center;padding:22px;font-size:0.72rem;letter-spacing:0.05em;}
footer a{color:var(--sand2);text-decoration:none;}

@media(max-width:768px){
  nav{padding:0 20px;}
  .nav-links{display:none;}
  .page-hero{flex-direction:column;padding:40px 24px 36px;gap:24px;}
  .ph-right{flex-direction:row;flex-wrap:wrap;}
  .ph-pill{min-width:0;flex:1;}
  .ph-title{font-size:2rem;}
  .form-section{padding:22px 18px;}
  .row.c2,.row.c3,.row.c4{grid-template-columns:1fr;}
  .x-sep{display:none;}
  .print-row{grid-template-columns:60px 1fr;}
}


/* ═══════════════════════════════════════════════════════════
   MOBILE FIXES (appended) — applies to all pages
   ═══════════════════════════════════════════════════════════ */

/* Prevent horizontal overflow at the document level.
   Without overflow-x:hidden on <html>, wide flex children
   (e.g. .car-track on the landing carousel) cause the
   layout viewport to expand on mobile. */
html { overflow-x: hidden; max-width: 100vw; }
body { overflow-x: hidden; max-width: 100vw; }

@media (max-width: 768px) {

  /* ── LANDING CAROUSEL: make it a native swipe strip on mobile.
        The desktop JS sets transform:translateX() on .car-track;
        we neutralise that and let overflow-x:auto on the viewport
        handle scrolling. */
  .carousel-wrap { padding: 0 !important; }
  .car-viewport {
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    scroll-snap-type: x mandatory !important;
    border-radius: 0 !important;
  }
  .car-viewport::-webkit-scrollbar { display: none; }
  .car-track {
    transform: none !important;
    transition: none !important;
    padding: 0 16px 16px !important;
    gap: 16px !important;
  }
  .car-track .prod-card {
    flex: 0 0 calc(100vw - 32px) !important;
    min-width: calc(100vw - 32px) !important;
    max-width: calc(100vw - 32px) !important;
    scroll-snap-align: center !important;
  }
  /* Hide the desktop prev/next arrows on touch — swipe instead. */
  .car-arrow { display: none !important; }

  /* ── PRODUCTS PAGE: page-hero stats row was overflowing
        (4 stats × big gap). Wrap into a 2×2 grid. */
  .ph-stats {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 8px !important;
    margin-top: 24px !important;
    width: 100% !important;
  }
  .ph-stat { min-width: 0 !important; text-align: center !important; }
  .ph-stat-num { font-size: 1.4rem !important; }
  .ph-stat-lbl { font-size: 0.6rem !important; }

  /* Filter group: allow horizontal scroll so the buttons don't
     push the page wider than the viewport. */
  .filter-bar {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 6px !important;
  }
  .filter-group {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    gap: 6px !important;
    padding: 10px 12px !important;
    scrollbar-width: none;
  }
  .filter-group::-webkit-scrollbar { display: none; }
  .filter-group .filter-label { flex-shrink: 0; }
  .filter-count { padding: 0 14px 8px !important; font-size: 0.7rem !important; }

  /* Product spec rows — wrap long values onto their own line. */
  .spec-row {
    flex-wrap: wrap !important;
    row-gap: 2px !important;
  }
  .spec-v { word-break: break-word !important; }

  /* "Customise / Compare" buttons row in the product card. */
  .cb-btns {
    flex-wrap: wrap !important;
    gap: 8px !important;
    width: 100% !important;
  }
  .cb-btns .btn-sand,
  .cb-btns .btn-ghost-w {
    flex: 1 1 auto !important;
    text-align: center !important;
    min-width: 0 !important;
  }

  /* Gallery navigation arrows — bump tap target to 44px. */
  .gal-prev, .gal-next {
    width: 40px !important;
    height: 40px !important;
    font-size: 1.4rem !important;
  }

  /* Carousel dot buttons — extend hit area without changing visuals. */
  .car-dot, .ws-dot {
    position: relative;
  }
  .car-dot::before, .ws-dot::before {
    content: '';
    position: absolute;
    inset: -12px;
  }

  /* Make sure no element forces extra horizontal space. */
  img, video, iframe { max-width: 100%; height: auto; }

  /* Features row on landing — base CSS class is .features (3-col grid).
     The earlier mobile rule targeted .feat-grid (which doesn't exist),
     so the 3 columns were squashing on phones. */
  .features {
    grid-template-columns: 1fr 1fr !important;
    padding: 8px 12px !important;
  }
  .feat {
    padding: 18px 14px !important;
    gap: 10px !important;
    border-right: none !important;
    border-bottom: 1px solid rgba(0,0,0,0.07) !important;
  }
  .feat:nth-child(odd) { border-right: 1px solid rgba(0,0,0,0.07) !important; }
  .feat-icon { width: 38px !important; height: 38px !important; font-size: 1rem !important; }
  .feat-body h3 { font-size: 0.85rem !important; }
  .feat-body p { font-size: 0.7rem !important; }

  /* CTA banner — was margin:0 68px which left almost no room on phones. */
  .cta-banner {
    margin: 0 16px 48px !important;
    padding: 32px 22px !important;
    flex-direction: column !important;
    align-items: stretch !important;
    text-align: center !important;
    gap: 22px !important;
  }
  .cb-text h2 { font-size: 1.4rem !important; }
  .cb-text p { font-size: 0.8rem !important; }
  .cb-btns {
    flex-direction: column !important;
    width: 100% !important;
  }
  .cta-banner .btn-sand,
  .cta-banner .btn-ghost-w {
    width: 100% !important;
    text-align: center !important;
    box-sizing: border-box !important;
  }

  /* Section intro divider — long text was clipping on phones. */
  .sec-intro { margin: 32px 20px 0 !important; }
  .sec-intro span { font-size: 0.85rem !important; white-space: normal !important; text-align: center !important; }

  /* PRODUCTS PAGE: force 2-up grid on phones (overrides the
     inline rule in products.html that targeted .prod-grid). */
  .prod-grid-layout {
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
    padding: 14px !important;
  }
  .prod-item { min-width: 0 !important; }
  .pi-img { height: 150px !important; flex-shrink: 0 !important; }
  .pi-body { padding: 12px 12px 14px !important; }
  .pi-name {
    font-size: 0.82rem !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    min-height: 2.2em !important;
  }
  .pi-desc {
    font-size: 0.7rem !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    flex: 0 0 auto !important;
    min-height: 2.3em !important;
  }
  .pi-cat  { font-size: 0.58rem !important; }
  /* Keep specs visible; the body itself still varies in height,
     but grid stretching + fixed image height keeps the photos
     of each ROW aligned (next row starts on a fresh line). */
  .pi-specs { font-size: 0.65rem !important; }
  .pi-specs .spec-row { gap: 4px !important; }
  .pi-footer { flex-direction: column; align-items: flex-start; gap: 6px; }
  .cat-header h2 { font-size: 1.1rem !important; }
}

/* Keep 2-up even on very narrow phones (override 480px rule). */
@media (max-width: 480px) {
  .prod-grid-layout {
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
  }
  .pi-img { height: 130px !important; }
}
