/* ─── RESET & TOKENS ─────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --green-deep:#0A2E22;
  --green-mid:#0F4030;
  --green-accent:#1A6B52;
  --green-light:#2A9D78;
  --gold:#C9993D;
  --gold-light:#E8BE6A;
  --cream:#F7F5F0;
  --cream-dark:#EDE9E1;
  --white:#FFFFFF;
  --text-primary:#1C1C1C;
  --text-sec:#5A5A5A;
  --text-muted:#9A9A9A;
  --border:#E2DDD5;
  --shadow-sm:0 2px 8px rgba(10,46,34,.08);
  --shadow-md:0 8px 32px rgba(10,46,34,.14);
  --shadow-lg:0 24px 64px rgba(10,46,34,.22);
  --radius-sm:8px;
  --radius-md:14px;
  --radius-lg:20px;
  --radius-xl:28px;
  --transition:all .28s cubic-bezier(.4,0,.2,1);
}
html{scroll-behavior:smooth}
/* ─── BACK TO SITE BUTTON ─────────────────────────────── */
.back-to-site{
  position:absolute;top:20px;left:24px;z-index:100;
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(255,255,255,0.12);
  border:1px solid rgba(255,255,255,0.25);
  color:#fff;font-size:13px;font-weight:500;
  padding:8px 16px;border-radius:100px;
  text-decoration:none;backdrop-filter:blur(8px);
  transition:var(--transition);
}
.back-to-site:hover{background:rgba(255,255,255,0.22)}
body{
  font-family:'DM Sans',sans-serif;
  background:var(--cream);
  color:var(--text-primary);
  min-height:100vh;
  overflow-x:hidden;
}

/* ─── HERO ────────────────────────────────────────────── */
.hero{
  background:var(--green-deep);
  position:relative;
  overflow:hidden;
  padding:80px 40px 72px;
  text-align:center;
}
.hero::before{
  content:'';
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 50% at 20% 50%,rgba(26,107,82,.25) 0%,transparent 70%),
    radial-gradient(ellipse 40% 60% at 80% 30%,rgba(201,153,61,.12) 0%,transparent 60%);
  pointer-events:none;
}
.hero-grain{
  position:absolute;inset:0;
  opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
  background-size:200px;
  pointer-events:none;
}
.hero-logo-mark{
  display:flex;justify-content:center;
  margin-bottom:20px;
}
.hero-emblem{
  width:80px;height:80px;
  animation:emblem-spin 60s linear infinite;
  filter:drop-shadow(0 0 18px rgba(201,153,61,.25));
}
@keyframes emblem-spin{to{transform:rotate(360deg)}}
.hero-wordmark{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(38px,7vw,88px);
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--cream);
  line-height:1;
  margin-bottom:8px;
}
.hero-wordmark span{color:var(--gold);}
.hero-tagline{
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);font-weight:500;
  margin-bottom:28px;
  opacity:.8;
}
.hero h1{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(32px,4.5vw,58px);
  font-weight:300;
  color:var(--cream);
  line-height:1.1;
  letter-spacing:-.01em;
  margin-bottom:16px;
  opacity:.75;
}
.hero h1 em{color:var(--gold);font-style:normal;}
.hero p{
  font-size:15px;color:rgba(247,245,240,.6);
  max-width:480px;margin:0 auto 48px;
  line-height:1.7;font-weight:300;
}
.hero-stats{
  display:flex;justify-content:center;gap:48px;flex-wrap:wrap;
}
.stat{text-align:center;}
.stat-num{
  font-family:'Cormorant Garamond',serif;
  font-size:32px;font-weight:500;color:var(--gold);
}
.stat-label{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:rgba(247,245,240,.45);margin-top:2px;}

/* ─── CATEGORY NAV ────────────────────────────────────── */
.nav-wrap{
  position:sticky;top:0;z-index:50;
  background:rgba(247,245,240,.88);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
}
.category-nav{
  max-width:1200px;margin:0 auto;
  display:flex;align-items:center;gap:0;
  padding:0 32px;
  overflow-x:auto;
  scrollbar-width:none;
}
.category-nav::-webkit-scrollbar{display:none}
.nav-brand{
  font-family:'Cormorant Garamond',serif;
  font-size:17px;font-weight:500;color:var(--green-mid);
  white-space:nowrap;margin-right:32px;
  padding:18px 0;border-right:1px solid var(--border);
  padding-right:32px;
}
.nav-tab{
  position:relative;display:flex;align-items:center;gap:8px;
  padding:18px 24px;
  font-size:13px;font-weight:500;letter-spacing:.01em;
  color:var(--text-sec);cursor:pointer;
  white-space:nowrap;border:none;background:none;
  transition:var(--transition);
  border-bottom:2px solid transparent;
}
.nav-tab:hover{color:var(--green-mid);}
.nav-tab.active{color:var(--green-mid);border-bottom-color:var(--green-mid);}
.nav-tab svg{width:16px;height:16px;flex-shrink:0}
.tab-count{
  background:var(--cream-dark);color:var(--text-muted);
  font-size:10px;padding:2px 6px;border-radius:20px;
  transition:var(--transition);
}
.nav-tab.active .tab-count{background:var(--green-mid);color:white;}

/* ─── MAIN ────────────────────────────────────────────── */
.main{max-width:1200px;margin:0 auto;padding:48px 32px 80px;}
.section{display:none;}
.section.active{display:block;animation:fadeIn .35s ease;}
@keyframes fadeIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

.section-header{margin-bottom:40px;}
.section-tag{
  font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--green-accent);font-weight:600;margin-bottom:8px;
}
.section-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(28px,4vw,42px);font-weight:400;
  color:var(--text-primary);line-height:1.15;margin-bottom:10px;
}
.section-desc{font-size:14px;color:var(--text-sec);line-height:1.7;max-width:560px;}

/* ─── FABRIC GRID ─────────────────────────────────────── */
.fabric-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:20px;
}
.fabric-card{
  background:white;
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
  cursor:pointer;
  transition:var(--transition);
  position:relative;
}
.fabric-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
  border-color:rgba(15,64,48,.2);
}
.fabric-card:focus-visible{
  outline:2px solid var(--green-mid);
  outline-offset:3px;
}
.card-visual{
  height:160px;
  position:relative;
  overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.card-visual svg{width:80px;height:80px;opacity:.85;transition:var(--transition);}
.fabric-card:hover .card-visual svg{transform:scale(1.08);opacity:1;}
.card-badge{
  position:absolute;top:12px;right:12px;
  font-size:9px;letter-spacing:.12em;text-transform:uppercase;
  font-weight:600;padding:4px 9px;border-radius:20px;
}
.badge-eco{background:rgba(42,157,120,.12);color:#1A6B52;border:1px solid rgba(42,157,120,.2);}
.badge-sw{background:rgba(15,64,48,.1);color:var(--green-mid);border:1px solid rgba(15,64,48,.15);}
.badge-lux{background:rgba(201,153,61,.1);color:#9B6D1A;border:1px solid rgba(201,153,61,.2);}
.badge-perf{background:rgba(30,100,180,.08);color:#1e5ab4;border:1px solid rgba(30,100,180,.15);}

.card-body{padding:18px 20px 20px;}
.card-gsm{
  font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--text-muted);font-weight:500;margin-bottom:4px;
}
.card-name{
  font-family:'Cormorant Garamond',serif;
  font-size:22px;font-weight:500;color:var(--text-primary);
  margin-bottom:6px;line-height:1.2;
}
.card-desc{font-size:12px;color:var(--text-sec);line-height:1.55;margin-bottom:14px;}
.card-products{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:14px;}
.product-pill{
  font-size:10px;background:var(--cream);
  color:var(--text-sec);padding:3px 9px;
  border-radius:20px;border:1px solid var(--border);
  transition:var(--transition);
}
.fabric-card:hover .product-pill{background:rgba(15,64,48,.05);border-color:rgba(15,64,48,.15);}
.card-cta{
  display:flex;align-items:center;gap:6px;
  font-size:12px;font-weight:500;color:var(--green-accent);
  transition:var(--transition);
}
.card-cta svg{width:14px;height:14px;transition:transform .2s;}
.fabric-card:hover .card-cta{color:var(--green-mid);}
.fabric-card:hover .card-cta svg{transform:translateX(3px);}

/* ─── MODAL ───────────────────────────────────────────── */
.modal-overlay{
  position:fixed;inset:0;z-index:100;
  background:rgba(10,46,34,.6);
  backdrop-filter:blur(12px);
  display:flex;align-items:flex-end;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity .3s ease;
}
@media(min-width:640px){.modal-overlay{align-items:center;}}
.modal-overlay.open{opacity:1;pointer-events:all;}
.modal{
  background:white;
  border-radius:var(--radius-xl) var(--radius-xl) 0 0;
  width:100%;max-width:680px;
  max-height:90vh;overflow-y:auto;
  transform:translateY(40px);
  transition:transform .35s cubic-bezier(.4,0,.2,1);
  scrollbar-width:thin;
  scrollbar-color:var(--border) transparent;
}
@media(min-width:640px){
  .modal{border-radius:var(--radius-xl);transform:translateY(20px) scale(.97);}
}
.modal-overlay.open .modal{transform:translateY(0) scale(1);}
.modal-header{
  position:relative;
  padding:32px 32px 0;
}
.modal-close{
  position:absolute;top:20px;right:20px;
  width:36px;height:36px;border-radius:50%;
  background:var(--cream);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:var(--transition);
  color:var(--text-sec);
}
.modal-close:hover{background:var(--cream-dark);color:var(--text-primary);}
.modal-close svg{width:16px;height:16px;}
.modal-visual{
  width:72px;height:72px;border-radius:var(--radius-md);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:16px;
}
.modal-visual svg{width:40px;height:40px;}
.modal-category{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);font-weight:500;margin-bottom:6px;}
.modal-name{
  font-family:'Cormorant Garamond',serif;
  font-size:32px;font-weight:400;color:var(--text-primary);margin-bottom:6px;
}
.modal-desc{font-size:14px;color:var(--text-sec);line-height:1.7;max-width:520px;}

.modal-specs{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;
  padding:24px 32px;
}
.spec-box{
  background:var(--cream);border-radius:var(--radius-sm);
  padding:14px 16px;
}
.spec-label{font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);font-weight:500;margin-bottom:4px;}
.spec-val{font-size:14px;font-weight:500;color:var(--text-primary);}

.modal-divider{
  height:1px;background:var(--border);margin:0 32px;
}
.products-section{padding:24px 32px 32px;}
.products-title{
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--green-accent);font-weight:600;margin-bottom:18px;
}
.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px;}
.product-item{
  background:var(--cream);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  padding:16px 14px;
  text-align:center;
  transition:var(--transition);
  cursor:pointer;
  position:relative;
  overflow:hidden;
}
.product-item:hover{
  background:var(--green-deep);
  border-color:var(--green-deep);
  transform:translateY(-3px);
  box-shadow:var(--shadow-md);
}
.product-item:hover .product-icon{color:var(--gold);}
.product-item:hover .product-name{color:white;}
.product-item:hover .product-note{color:rgba(255,255,255,.5);}
.product-item:focus-visible{outline:2px solid var(--green-mid);outline-offset:2px;}
.product-tap-hint{font-size:9px;color:var(--green-accent);margin-top:4px;opacity:0;transition:var(--transition);}
.product-item:hover .product-tap-hint{opacity:1;color:rgba(255,255,255,.55);}
.product-item.has-image{border-color:rgba(15,64,48,.3);}
.product-item.has-image .product-thumb{display:block;}
.product-item.has-image .product-icon{display:none;}
.product-thumb{display:none;width:100%;height:100px;object-fit:contain;border-radius:8px;margin-bottom:6px;background:var(--cream);}
.img-check{position:absolute;top:7px;right:7px;width:16px;height:16px;border-radius:50%;background:var(--gold);display:none;align-items:center;justify-content:center;}
.img-check svg{width:9px;height:9px;color:white;}
.product-item.has-image .img-check{display:flex;}

.product-icon{
  margin:0 auto 8px;
  width:32px;height:32px;
  color:var(--green-accent);
  transition:var(--transition);
  display:flex;align-items:center;justify-content:center;
}
.product-icon svg{width:28px;height:28px;}
.product-name{
  font-size:12px;font-weight:500;
  color:var(--text-primary);margin-bottom:3px;
  transition:var(--transition);
}
.product-note{font-size:10px;color:var(--text-muted);transition:var(--transition);}

.modal-footer{
  border-top:1px solid var(--border);
  padding:20px 32px;
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;flex-wrap:wrap;
}
.footer-note{font-size:12px;color:var(--text-muted);}
.footer-note strong{color:var(--green-mid);}
.cta-btn{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--green-mid);color:white;
  font-size:13px;font-weight:500;
  padding:10px 22px;border-radius:40px;
  border:none;cursor:pointer;
  transition:var(--transition);
  text-decoration:none;
}
.cta-btn:hover{background:var(--green-deep);transform:translateY(-1px);box-shadow:0 6px 20px rgba(15,64,48,.3);}
.cta-btn svg{width:14px;height:14px;}

/* ─── SWATCHES ────────────────────────────────────────── */
.tex-jersey{background:linear-gradient(135deg,#e8f5f0 25%,#d4ede6 50%,#e8f5f0 75%);background-size:8px 8px;}
.tex-terry{background:linear-gradient(45deg,#dce8e3 33%,#c8ddd6 33%,#c8ddd6 66%,#dce8e3 66%);background-size:6px 6px;}
.tex-fleece{background:linear-gradient(135deg,#2e2e2e 25%,#3a3a3a 50%,#2e2e2e 75%);background-size:4px 4px;}
.tex-rib{background:repeating-linear-gradient(90deg,#e2ecf0 0,#e2ecf0 3px,#cfdde5 3px,#cfdde5 6px);}
.tex-interlock{background:linear-gradient(135deg,#f0e8d8 25%,#e8d8c0 50%,#f0e8d8 75%);background-size:8px 8px;}
.tex-pique{background:repeating-linear-gradient(45deg,#e5edf2 0,#e5edf2 3px,#d5e0e8 3px,#d5e0e8 6px);}
.tex-waffle{background:repeating-linear-gradient(0deg,#e8e0d4 0,#e8e0d4 4px,#d8cfbe 4px,#d8cfbe 8px),repeating-linear-gradient(90deg,#e8e0d4 0,#e8e0d4 4px,#d8cfbe 4px,#d8cfbe 8px);}
.tex-lycra{background:linear-gradient(160deg,#1a2a4a 0%,#2a3a6a 50%,#1a2a4a 100%);}
.tex-twill{background:repeating-linear-gradient(45deg,#c8b88a 0,#c8b88a 4px,#b8a070 4px,#b8a070 8px);}
.tex-poplin{background:linear-gradient(135deg,#f5f0e8 25%,#ebe4d8 50%,#f5f0e8 75%);background-size:4px 4px;}
.tex-canvas{background:repeating-linear-gradient(90deg,#d4c8a8 0,#d4c8a8 3px,#c4b890 3px,#c4b890 6px);}
.tex-denim{background:repeating-linear-gradient(45deg,#3a5a80 0,#3a5a80 3px,#2a4870 3px,#2a4870 6px);}
.tex-oxford{background:repeating-linear-gradient(0deg,#e8e0cc 0,#e8e0cc 3px,#d8d0b8 3px,#d8d0b8 6px),repeating-linear-gradient(90deg,#e8e0cc 0,#e8e0cc 3px,#d8d0b8 3px,#d8d0b8 6px);}
.tex-ripstop{background:repeating-linear-gradient(0deg,#4a6640 0,#4a6640 2px,#5a7650 2px,#5a7650 12px),repeating-linear-gradient(90deg,#4a6640 0,#4a6640 2px,#5a7650 2px,#5a7650 12px);}
.tex-linen{background:repeating-linear-gradient(45deg,#e8dcc8 0,#e8dcc8 2px,#d8cca8 2px,#d8cca8 4px);}
.tex-satin{background:linear-gradient(120deg,#f0e8d0 0%,#fffaef 40%,#e8d8b0 60%,#fffaef 100%);}
.tex-velvet{background:linear-gradient(135deg,#4a2a6a 0%,#6a3a8a 30%,#3a1a5a 60%,#5a2a7a 100%);}
.tex-jacquard{background:repeating-linear-gradient(45deg,#c8b870 0,#c8b870 4px,#a89850 4px,#a89850 8px);}
.tex-microfiber{background:linear-gradient(135deg,#d8e8f8 25%,#c8d8e8 50%,#d8e8f8 75%);background-size:4px 4px;}
.tex-muslin{background:repeating-linear-gradient(0deg,#f0e8d8 0,#f0e8d8 2px,#e8dcc8 2px,#e8dcc8 4px),repeating-linear-gradient(90deg,#f0e8d8 0,#f0e8d8 2px,#e8dcc8 2px,#e8dcc8 8px);}
.tex-felt{background:linear-gradient(135deg,#8a4a2a 0%,#a05a3a 50%,#8a4a2a 100%);}
.tex-terry-home{background:linear-gradient(135deg,#e8f0f8 25%,#d8e4f0 50%,#e8f0f8 75%);background-size:6px 6px;}

/* ─── GARMENT PANEL ───────────────────────────────────── */
.garment-overlay{position:fixed;inset:0;z-index:200;background:rgba(10,46,34,.7);backdrop-filter:blur(16px);display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease;}
@media(min-width:640px){.garment-overlay{align-items:center;}}
.garment-overlay.open{opacity:1;pointer-events:all;}
.garment-panel{background:white;border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:620px;max-height:92vh;overflow-y:auto;transform:translateY(60px);transition:transform .38s cubic-bezier(.4,0,.2,1);scrollbar-width:thin;scrollbar-color:var(--border) transparent;}
@media(min-width:640px){.garment-panel{border-radius:var(--radius-xl);transform:translateY(30px) scale(.96);}}
.garment-overlay.open .garment-panel{transform:translateY(0) scale(1);}

.gpanel-topbar{display:flex;align-items:center;gap:10px;padding:18px 22px 14px;border-bottom:1px solid var(--border);position:sticky;top:0;background:white;z-index:10;}
.gpanel-back{display:flex;align-items:center;gap:6px;background:var(--cream);border:1px solid var(--border);border-radius:40px;padding:6px 14px 6px 10px;font-size:12px;font-weight:500;color:var(--text-sec);cursor:pointer;transition:var(--transition);flex-shrink:0;}
.gpanel-back:hover{background:var(--cream-dark);color:var(--text-primary);}
.gpanel-back svg{width:14px;height:14px;}
.gpanel-crumb{font-size:12px;color:var(--text-muted);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.gpanel-crumb strong{color:var(--green-mid);}
.gpanel-x{width:32px;height:32px;border-radius:50%;background:var(--cream);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);color:var(--text-sec);flex-shrink:0;}
.gpanel-x:hover{background:var(--cream-dark);}
.gpanel-x svg{width:14px;height:14px;}

.gpanel-img-zone{margin:22px 22px 0;border-radius:var(--radius-lg);overflow:hidden;position:relative;background:var(--cream);border:2px dashed var(--border);min-height:260px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);}
.gpanel-img-zone:hover{border-color:var(--green-accent);background:rgba(26,107,82,.04);}
.gpanel-img-zone.filled{display:block;border:1px solid var(--border);background:var(--cream);min-height:unset;overflow:visible;}
.gpanel-img-zone.filled:hover{background:var(--cream);}
.gpanel-img-zone img.gphoto{display:none;}
.gpanel-img-zone.filled img.gphoto{display:block;width:100%;height:auto;border-radius:var(--radius-lg);}
.gpanel-img-zone.filled .upl-placeholder{display:none;}
.upl-placeholder{text-align:center;padding:28px 22px;}
.upl-icon{width:60px;height:60px;border-radius:50%;background:rgba(26,107,82,.08);border:1.5px dashed var(--green-accent);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;transition:var(--transition);}
.gpanel-img-zone:hover .upl-icon{background:rgba(26,107,82,.15);}
.upl-icon svg{width:26px;height:26px;color:var(--green-accent);}
.upl-title{font-size:15px;font-weight:500;color:var(--text-primary);margin-bottom:4px;}
.upl-sub{font-size:11px;color:var(--text-muted);line-height:1.5;}
.upl-btn{display:inline-flex;align-items:center;gap:6px;margin-top:12px;background:var(--green-mid);color:white;font-size:12px;font-weight:500;padding:8px 18px;border-radius:40px;border:none;cursor:pointer;transition:var(--transition);}
.upl-btn:hover{background:var(--green-deep);}
.upl-btn svg{width:12px;height:12px;}
.change-btn{position:absolute;bottom:10px;right:10px;display:none;background:rgba(0,0,0,.55);backdrop-filter:blur(6px);color:white;font-size:11px;font-weight:500;padding:6px 12px;border-radius:40px;border:1px solid rgba(255,255,255,.2);cursor:pointer;align-items:center;gap:5px;}
.change-btn svg{width:11px;height:11px;}
.change-btn:hover{background:rgba(0,0,0,.75);}
.gpanel-img-zone.filled .change-btn{display:flex;}

.gp-info{padding:18px 22px 0;}
.gp-badge{display:inline-flex;align-items:center;gap:5px;font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;padding:4px 10px;border-radius:20px;background:var(--cream);border:1px solid var(--border);color:var(--text-sec);margin-bottom:10px;}
.gp-badge svg{width:12px;height:12px;}
.gp-name{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:400;color:var(--text-primary);margin-bottom:6px;line-height:1.15;}
.gp-fabric{font-size:13px;color:var(--text-sec);margin-bottom:14px;}
.gp-fabric span{font-weight:500;}
.gp-specs{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-bottom:18px;}
.gp-spec{background:var(--cream);border-radius:var(--radius-sm);padding:11px 13px;}
.gp-spec-lbl{font-size:9px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);font-weight:600;margin-bottom:3px;}
.gp-spec-val{font-size:13px;font-weight:500;color:var(--text-primary);}
.gp-section-title{font-size:10px;text-transform:uppercase;letter-spacing:.15em;color:var(--green-accent);font-weight:600;margin-bottom:9px;}
.gp-detail-row{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);}
.gp-detail-row:last-child{border-bottom:none;}
.gp-dicon{width:18px;height:18px;flex-shrink:0;margin-top:2px;}
.gp-dicon svg{width:16px;height:16px;}
.gp-dtext{font-size:13px;color:var(--text-sec);line-height:1.5;}
.gp-dtext strong{color:var(--text-primary);font-weight:500;}
.gp-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px;}
.gp-chip{font-size:11px;padding:4px 11px;border-radius:20px;background:var(--cream);border:1px solid var(--border);color:var(--text-sec);}

.gp-footer{border-top:1px solid var(--border);padding:16px 22px;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;position:sticky;bottom:0;background:white;}
.gp-fn{font-size:11px;color:var(--text-muted);}
.gp-fn strong{color:var(--green-mid);}
.gp-btns{display:flex;gap:8px;}
.btn-ol{display:inline-flex;align-items:center;gap:5px;background:transparent;color:var(--green-mid);font-size:12px;font-weight:500;padding:8px 14px;border-radius:40px;border:1.5px solid var(--green-mid);cursor:pointer;transition:var(--transition);text-decoration:none;}
.btn-ol:hover{background:rgba(15,64,48,.06);}
.btn-sl{display:inline-flex;align-items:center;gap:5px;background:var(--green-mid);color:white;font-size:12px;font-weight:500;padding:8px 16px;border-radius:40px;border:none;cursor:pointer;transition:var(--transition);text-decoration:none;}
.btn-sl:hover{background:var(--green-deep);transform:translateY(-1px);}
.btn-ol svg,.btn-sl svg{width:12px;height:12px;}

/* ─── ALL PRODUCTS GRID ───────────────────────────────── */
.product-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:16px;
}
.product-card{
  background:white;
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
  cursor:pointer;
  transition:var(--transition);
  position:relative;
}
.product-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
  border-color:rgba(15,64,48,.2);
}
.product-card:focus-visible{outline:2px solid var(--green-mid);outline-offset:3px;}
.pc-visual{
  height:200px;
  background:var(--cream);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;position:relative;
}
.pc-visual img{
  width:100%;height:100%;
  object-fit:contain;
  transition:transform .35s ease;
}
.product-card:hover .pc-visual img{transform:scale(1.04);}
.pc-visual .pc-icon{
  width:64px;height:64px;
  color:var(--green-accent);
  opacity:.6;
  transition:var(--transition);
}
.product-card:hover .pc-icon{opacity:1;color:var(--green-mid);}
.pc-fabric-count{
  position:absolute;top:10px;left:10px;
  font-size:9px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;
  padding:3px 8px;border-radius:20px;
  background:rgba(15,64,48,.85);color:white;
  backdrop-filter:blur(4px);
}
.pc-body{padding:14px 16px 16px;}
.pc-name{
  font-family:'Cormorant Garamond',serif;
  font-size:18px;font-weight:500;color:var(--text-primary);
  margin-bottom:3px;line-height:1.2;
}
.pc-note{font-size:11px;color:var(--text-muted);margin-bottom:10px;}
.pc-fabrics{display:flex;flex-wrap:wrap;gap:4px;}
.pc-pill{
  font-size:9px;background:var(--cream);color:var(--text-sec);
  padding:2px 8px;border-radius:20px;border:1px solid var(--border);
}

/* ─── FABRIC OPTIONS GRID (in product modal) ──────────── */
.fabric-options-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(150px,1fr));
  gap:12px;
}
.fabric-option-card{
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  overflow:hidden;
  cursor:pointer;
  transition:var(--transition);
}
.fabric-option-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-sm);
  border-color:rgba(15,64,48,.25);
}
.foc-visual{
  height:100px;
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.foc-visual img{width:100%;height:100%;object-fit:contain;background:var(--cream);}
.foc-visual .foc-svg{width:48px;height:48px;opacity:.8;}
.foc-body{padding:10px 12px 12px;background:white;}
.foc-name{font-size:12px;font-weight:500;color:var(--text-primary);margin-bottom:2px;}
.foc-gsm{font-size:10px;color:var(--text-muted);}
.foc-cta{
  display:flex;align-items:center;gap:4px;
  font-size:10px;font-weight:500;color:var(--green-accent);
  margin-top:6px;transition:var(--transition);
}
.foc-cta svg{width:10px;height:10px;transition:transform .2s;}
.fabric-option-card:hover .foc-cta{color:var(--green-mid);}
.fabric-option-card:hover .foc-cta svg{transform:translateX(2px);}

/* ─── RESPONSIVE ──────────────────────────────────────── */
@media(max-width:768px){
  .hero{padding:60px 24px 52px;}
  .hero-stats{gap:28px;}
  .main{padding:32px 20px 60px;}
  .modal-specs{grid-template-columns:repeat(2,1fr);}
  .modal-header,.products-section,.modal-footer{padding-left:20px;padding-right:20px;}
  .modal-specs{padding-left:20px;padding-right:20px;}
  .modal-divider{margin:0 20px;}
  .category-nav{padding:0 16px;}
  .nav-brand{display:none;}
}
@media(max-width:480px){
  .fabric-grid{grid-template-columns:1fr 1fr;}
  .modal-specs{grid-template-columns:1fr 1fr;}
  .gp-specs{grid-template-columns:repeat(2,1fr);}
  .gp-info{padding:14px 18px 0;}
  .gpanel-img-zone{margin:14px 18px 0;}
  .gp-footer{padding:13px 18px;}
  .gpanel-topbar{padding:14px 18px 12px;}
}
