/* ================================================================
   The Banaras Silk Emporium – main.css
   MERGED: base + header/footer + home + category + product
   All inline styles removed; single stylesheet for entire site
   ================================================================ */

/* ── Google Fonts ─────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,600&family=Jost:wght@300;400;500;600&display=swap&display=swap');

/* ── CSS Custom Properties ────────────────────────────────────── */
:root{
  --cream:#faf5ee; --warm-white:#fffdf8;
  --gold:#b8900a; --gold-light:#d4a830; --gold-dark:#8a6800;
  --charcoal:#1a1410; --maroon:#6e1423; --maroon-dark:#4a0c17;
  --text-muted:#8a7a68; --border:#e5d9c8; --red:#b03030;
  --font-display:'Cormorant Garamond',Georgia,serif;
  --font-body:'Jost',sans-serif;
  --ease:cubic-bezier(.4,0,.2,1);
  --tr:.3s var(--ease);
  --sh-sm:0 2px 12px rgba(26,20,16,.08);
  --sh-md:0 8px 32px rgba(26,20,16,.14);
  --sh-lg:0 24px 64px rgba(26,20,16,.20);
  --max:1400px; --pad:40px;
}

/* ── Reset ────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);background:var(--cream);color:var(--charcoal);line-height:1.6;font-weight:300;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{text-decoration:none;color:inherit;transition:color var(--tr)}
img{display:block;max-width:100%;height:auto}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:var(--font-body)}
address{font-style:normal}

/* ── Accessibility ────────────────────────────────────────────── */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.sr-only-focusable:focus{position:static;width:auto;height:auto;clip:auto;white-space:normal}
.skip-link{position:absolute;top:-100%;left:0;background:var(--maroon);color:#fff;padding:10px 20px;z-index:999;font-size:14px;transition:top .2s}
.skip-link:focus{top:0}
:focus-visible{outline:2px solid var(--maroon);outline-offset:3px}

/* ── Typography utilities ─────────────────────────────────────── */
.section-eyebrow{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--maroon);font-weight:500;margin-bottom:12px;display:block}
.section-title{font-family:var(--font-display);font-size:clamp(28px,3.5vw,50px);font-weight:400;line-height:1.1;color:var(--charcoal);margin-bottom:16px}
.section-subtitle{font-size:15px;color:var(--text-muted);font-weight:300;max-width:560px;line-height:1.7}
.gold-divider{width:60px;height:2px;background:linear-gradient(90deg,var(--maroon),var(--gold));margin:20px 0}
.gold-divider.center{margin-left:auto;margin-right:auto}

/* ── Buttons ──────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 36px;font-family:var(--font-body);font-size:12px;letter-spacing:2px;font-weight:500;text-transform:uppercase;border-radius:0;transition:all var(--tr);cursor:pointer;white-space:nowrap}
.btn-primary{background:var(--maroon);color:#fff;border:2px solid var(--maroon)}
.btn-primary:hover{background:var(--maroon-dark);border-color:var(--maroon-dark)}
.btn-outline{background:transparent;color:var(--charcoal);border:2px solid var(--charcoal)}
.btn-outline:hover{background:var(--charcoal);color:#fff}
.btn-gold{background:var(--gold);color:#fff;border:2px solid var(--gold)}
.btn-gold:hover{background:var(--gold-dark);border-color:var(--gold-dark)}
.btn-outline-light{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.55)}
.btn-outline-light:hover{background:rgba(255,255,255,.12)}
.btn-sm{font-size:11px;padding:10px 14px;letter-spacing:1.5px}
.btn-block{width:100%;justify-content:center}

/* ═══════════════════════════════════════════════════════════════
   ANNOUNCEMENT BAR
   ═══════════════════════════════════════════════════════════════ */
.announcement-bar{background:var(--maroon);color:#f5e6c0;text-align:center;padding:9px 20px;font-size:11px;letter-spacing:1.8px;font-weight:400;text-transform:uppercase}
.announcement-bar a{color:#f5e6c0;text-decoration:underline}

/* ═══════════════════════════════════════════════════════════════
   HEADER
   ═══════════════════════════════════════════════════════════════ */
.site-header{background:var(--warm-white);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;box-shadow:var(--sh-sm)}
.header-inner{max-width:var(--max);margin:0 auto;padding:0 var(--pad);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;min-height:80px}
.nav-left{display:flex;gap:2px;align-items:center}
.nav-right{display:flex;gap:8px;align-items:center;justify-content:flex-end}

/* Logo */
.logo{text-align:center;line-height:1;display:block}
.logo-the{font-family:var(--font-display);font-size:12px;letter-spacing:1px;color:var(--maroon);font-weight:500;text-transform:uppercase;display:block}
.logo-name{font-family:var(--font-display);font-size:25px;font-weight:600;color:var(--charcoal);letter-spacing:.5px;display:block;line-height:1.1}
.logo-name em{color:var(--maroon);font-style:normal}
.logo-sub{font-family:var(--font-body);font-size:8px;letter-spacing:3px;color:var(--text-muted);text-transform:uppercase;display:block;margin-top:3px}

/* Nav items */
.nav-item{position:relative;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;font-weight:400;color:var(--charcoal);padding:26px 10px;transition:color var(--tr);white-space:nowrap}
.nav-item:hover,.nav-active{color:var(--maroon)}
.nav-item::after{content:'';position:absolute;bottom:0;left:10px;right:10px;height:2px;background:var(--maroon);transform:scaleX(0);transition:transform var(--tr)}
.nav-item:hover::after,.nav-active::after{transform:scaleX(1)}
.has-dropdown>span::after{content:' ▾';font-size:9px}

/* Dropdown */
.dropdown{display:none;position:absolute;top:100%;left:0;background:var(--warm-white);border:1px solid var(--border);border-top:2px solid var(--maroon);min-width:240px;box-shadow:var(--sh-md);z-index:200;padding:10px 0}
.has-dropdown:hover .dropdown{display:block}
.dropdown a{display:block;padding:9px 22px;font-size:11px;letter-spacing:1px;color:var(--charcoal);text-transform:uppercase;transition:background var(--tr),color var(--tr)}
.dropdown a:hover{background:var(--cream);color:var(--maroon)}

/* Header icon */
.header-icon{color:var(--charcoal);padding:8px;border-radius:50%;transition:color var(--tr),background var(--tr);display:flex;align-items:center;justify-content:center;position:relative}
.header-icon:hover{color:var(--maroon);background:var(--cream)}
.cart-count{position:absolute;top:2px;right:2px;background:var(--maroon);color:#fff;font-size:9px;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600}

/* Mobile menu toggle (hidden on desktop) */
.menu-toggle{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;border:none;background:none}
.menu-toggle span{display:block;width:22px;height:2px;background:var(--charcoal);transition:all .3s}

/* ═══════════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════════ */
.site-footer{background:var(--charcoal);color:rgba(255,255,255,.7);padding:64px var(--pad) 32px}
.footer-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:48px;margin-bottom:48px}
.footer-logo{font-family:var(--font-display);font-size:22px;color:#f5e6c0;letter-spacing:1px;margin-bottom:14px;line-height:1.3}
.footer-tagline{font-size:13px;line-height:1.7;color:rgba(255,255,255,.45);max-width:270px;margin-bottom:16px}
.footer-address{font-size:13px;line-height:1.9;color:rgba(255,255,255,.4)}
.footer-address a{color:rgba(255,255,255,.55)}
.footer-address a:hover{color:var(--gold-light)}
.footer-heading{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold-light);font-weight:500;margin-bottom:20px}
.footer-links{display:flex;flex-direction:column;gap:9px}
.footer-links a{font-size:13px;color:rgba(255,255,255,.5);transition:color var(--tr)}
.footer-links a:hover{color:var(--gold-light)}
.footer-eq-note{font-size:13px;color:rgba(255,255,255,.45);margin-bottom:14px;line-height:1.6}
.footer-form input{width:100%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);color:#fff;padding:12px 14px;font-family:var(--font-body);font-size:13px;margin-bottom:8px;outline:none;transition:border-color var(--tr)}
.footer-form input::placeholder{color:rgba(255,255,255,.35)}
.footer-form input:focus{border-color:var(--gold)}
.footer-bottom{max-width:var(--max);margin:0 auto;border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;align-items:center;font-size:12px;color:rgba(255,255,255,.3)}
.footer-bottom a{color:rgba(255,255,255,.4)}
.footer-bottom a:hover{color:var(--gold-light)}

/* ═══════════════════════════════════════════════════════════════
   PRODUCT CARD (shared – homepage + category)
   ═══════════════════════════════════════════════════════════════ */
.product-card{position:relative;overflow:hidden;cursor:pointer}
.product-card-img{position:relative;overflow:hidden;aspect-ratio:3/4;background:#eee5d8}
.product-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.product-card:hover .product-card-img img{transform:scale(1.06)}
.product-card-badge{position:absolute;top:14px;left:14px;background:var(--maroon);color:#fff;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;padding:4px 10px;font-weight:500}
.product-card-actions{position:absolute;bottom:0;left:0;right:0;background:rgba(26,20,16,.88);padding:14px;transform:translateY(100%);transition:transform var(--tr);display:flex;gap:8px}
.product-card:hover .product-card-actions{transform:translateY(0)}
.product-card-body{padding:16px 4px 8px}
.product-card-name{font-family:var(--font-display);font-size:19px;font-weight:400;color:var(--charcoal);margin-bottom:4px;line-height:1.3}
.product-card-type{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}
.product-card-price{font-size:14px;color:var(--text-muted)}
.product-card-price strong{color:var(--charcoal);font-weight:500}

/* ═══════════════════════════════════════════════════════════════
   HOMEPAGE – HERO
   ═══════════════════════════════════════════════════════════════ */
.hero{position:relative;height:90vh;min-height:560px;overflow:hidden}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease}
.hero-slide.active{opacity:1}
.hero-slide img{width:100%;height:100%;object-fit:cover;object-position:center top}
.hero-slide-fb{width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.hero-slide-fb-inner{text-align:center}
.hero-slide-fb-icon{font-family:var(--font-display);font-size:80px;color:rgba(255,255,255,.12);line-height:1}
.hero-slide-fb-text{font-family:var(--font-display);font-size:22px;color:rgba(255,255,255,.5);letter-spacing:5px;margin-top:12px}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(26,20,16,.72) 0%,rgba(26,20,16,.45) 50%,rgba(26,20,16,.18) 100%)}
.hero-content{position:absolute;top:50%;left:8%;transform:translateY(-50%);color:#fff;max-width:580px;z-index:2}
.hero-eyebrow{font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--gold-light);font-weight:400;margin-bottom:20px;animation:fadeUp .9s ease forwards}
.hero-title{font-family:var(--font-display);font-size:clamp(38px,5.5vw,78px);font-weight:300;line-height:1.05;margin-bottom:22px;animation:fadeUp .9s .1s ease both}
.hero-title em{font-style:italic;color:var(--gold-light)}
.hero-desc{font-size:15px;color:rgba(255,255,255,.8);line-height:1.8;font-weight:300;max-width:440px;margin-bottom:38px;animation:fadeUp .9s .2s ease both}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;animation:fadeUp .9s .3s ease both}
.hero-dots{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);display:flex;gap:10px;z-index:3}
.hero-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.35);cursor:pointer;transition:all var(--tr);border:1px solid rgba(255,255,255,.5)}
.hero-dot.active{background:var(--gold-light);transform:scale(1.3)}
.hero-badge{position:absolute;right:60px;top:50%;transform:translateY(-50%);width:150px;height:150px;border:1px solid rgba(212,168,48,.4);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2;text-align:center}
.hero-badge::before{content:'';position:absolute;width:120px;height:120px;border:1px solid rgba(212,168,48,.25);border-radius:50%}
.hero-badge-year{font-family:var(--font-display);font-size:36px;color:var(--gold-light);font-weight:300;line-height:1}
.hero-badge-text{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.6);line-height:1.5;margin-top:4px}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}

/* ── Stats strip ── */
.stats-strip{background:var(--maroon);padding:26px var(--pad)}
.stats-inner{max-width:var(--max);margin:0 auto;display:flex;justify-content:space-around;gap:24px}
.stat-item{text-align:center}
.stat-number{font-family:var(--font-display);font-size:38px;font-weight:300;color:#f5e6c0;line-height:1;margin-bottom:4px}
.stat-label{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:rgba(245,230,192,.55)}

/* ── Welcome section ── */
.welcome-section{max-width:var(--max);margin:0 auto;padding:100px var(--pad);display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.welcome-images{position:relative}
.welcome-img-main{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:top}
.welcome-img-accent{position:absolute;bottom:-32px;right:-32px;width:46%;aspect-ratio:1;object-fit:cover;border:6px solid var(--cream)}
.welcome-badge{position:absolute;top:-20px;left:-20px;width:110px;height:110px;background:var(--maroon);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#f5e6c0;text-align:center}
.welcome-badge strong{font-family:var(--font-display);font-size:30px;display:block;line-height:1;font-weight:300}
.welcome-badge span{font-size:9px;letter-spacing:1px;text-transform:uppercase;line-height:1.4}
.welcome-content{padding-right:10px}
.welcome-speciality{margin-top:32px}
.welcome-speciality-title{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--maroon);font-weight:500;margin-bottom:16px}
.speciality-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.spec-item{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:var(--warm-white);border:1px solid var(--border);font-size:13px;color:var(--charcoal)}
.spec-icon{color:var(--maroon);font-size:14px;flex-shrink:0;margin-top:1px}

/* ── Products section ── */
.products-section{background:var(--warm-white);padding:100px var(--pad)}
.products-inner{max-width:var(--max);margin:0 auto}
.products-header{text-align:center;margin-bottom:60px}
.products-tabs{display:flex;justify-content:center;gap:4px;margin-bottom:48px;flex-wrap:wrap}
.ptab{padding:10px 24px;font-family:var(--font-body);font-size:11px;letter-spacing:2px;text-transform:uppercase;font-weight:500;color:var(--text-muted);border:1px solid var(--border);background:var(--warm-white);cursor:pointer;transition:all var(--tr)}
.ptab.active,.ptab:hover{background:var(--maroon);color:#fff;border-color:var(--maroon)}
.products-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.products-cta{text-align:center;margin-top:48px}

/* ── Categories grid ── */
.categories-section{padding:100px var(--pad);max-width:var(--max);margin:0 auto}
.categories-header{text-align:center;margin-bottom:56px}
.categories-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;grid-template-rows:260px 260px;gap:14px}
.cat-card{position:relative;overflow:hidden;cursor:pointer;border-radius:1px}
.cat-card:first-child{grid-row:1/3}
.cat-bg{width:100%;height:100%;position:relative;overflow:hidden}
.cat-bg img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.cat-card:hover .cat-bg img{transform:scale(1.07)}
.cat-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,20,16,.75) 0%,transparent 55%);transition:background var(--tr)}
.cat-card:hover .cat-overlay{background:linear-gradient(to top,rgba(26,20,16,.88) 0%,rgba(26,20,16,.15) 65%)}
.cat-content{position:absolute;bottom:0;left:0;right:0;padding:26px;color:#fff}
.cat-label{font-family:var(--font-display);font-size:24px;font-weight:300;margin-bottom:5px}
.cat-sub{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:14px}
.cat-link{display:inline-flex;align-items:center;gap:6px;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gold-light);opacity:0;transform:translateY(8px);transition:all var(--tr)}
.cat-card:hover .cat-link{opacity:1;transform:translateY(0)}

/* ── History section ── */
.history-section{background:var(--charcoal);padding:100px var(--pad);position:relative;overflow:hidden}
.history-section::before{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 40px,rgba(212,168,48,.04) 40px,rgba(212,168,48,.04) 41px),repeating-linear-gradient(90deg,transparent,transparent 40px,rgba(212,168,48,.04) 40px,rgba(212,168,48,.04) 41px);pointer-events:none}
.history-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;position:relative;z-index:1}
.history-content .section-eyebrow{color:var(--gold-light)}
.history-content .section-title{color:#fff}
.history-text{font-size:15px;color:rgba(255,255,255,.6);line-height:1.85;font-weight:300;margin-bottom:16px}
.history-text em{color:var(--gold-light);font-style:italic}
.history-features{margin-top:36px;display:flex;flex-direction:column;gap:20px}
.history-feat{display:flex;gap:18px;align-items:flex-start;padding:18px 20px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-left:3px solid var(--maroon)}
.history-feat-icon{font-size:20px;flex-shrink:0}
.history-feat-title{font-family:var(--font-display);font-size:18px;font-weight:400;color:rgba(255,255,255,.9);margin-bottom:4px}
.history-feat-desc{font-size:13px;color:rgba(255,255,255,.5);line-height:1.6}
.history-visual{position:relative}
.history-img-main{width:100%;aspect-ratio:4/5;object-fit:cover}
.history-img-overlay{position:absolute;bottom:-24px;right:-24px;width:48%;aspect-ratio:1;object-fit:cover;border:5px solid var(--charcoal)}

/* ── Gallery strip ── */
.gallery-strip{padding:80px 0;background:var(--cream);text-align:center}
.gallery-strip-label{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--text-muted);margin-bottom:10px}
.gallery-strip-title{font-family:var(--font-display);font-size:30px;color:var(--charcoal);margin-bottom:40px}
.gallery-strip-title span{color:var(--maroon);font-style:italic}
.gallery-strip-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:4px}
.gs-item{aspect-ratio:1;overflow:hidden;position:relative}
.gs-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.gs-item:hover img{transform:scale(1.08)}
.gs-overlay{position:absolute;inset:0;background:rgba(110,20,35,.5);opacity:0;transition:opacity var(--tr);display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px}
.gs-item:hover .gs-overlay{opacity:1}

/* ── Testimonials ── */
.testimonials-section{padding:100px var(--pad);background:var(--warm-white)}
.testimonials-inner{max-width:1100px;margin:0 auto}
.testimonials-header{text-align:center;margin-bottom:60px}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.testimonial-card{background:var(--cream);border:1px solid var(--border);border-top:3px solid var(--maroon);padding:32px 26px}
.testimonial-stars{color:var(--gold);font-size:14px;letter-spacing:2px;margin-bottom:14px}
.testimonial-text{font-family:var(--font-display);font-size:17px;font-weight:300;color:var(--charcoal);line-height:1.7;font-style:italic;margin-bottom:22px}
.testimonial-author{font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--maroon);font-weight:500}
.testimonial-loc{font-size:12px;color:var(--text-muted);margin-top:4px}

/* ── Contact strip ── */
.contact-strip{background:var(--maroon);padding:60px var(--pad)}
.contact-strip-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:60px;align-items:center}
.contact-strip-title{font-family:var(--font-display);font-size:36px;font-weight:300;color:#fff;margin-bottom:10px}
.contact-strip-sub{font-size:14px;color:rgba(255,255,255,.65)}
.contact-details{display:flex;gap:32px;flex-wrap:wrap}
.contact-detail{text-align:center;color:rgba(255,255,255,.8)}
.contact-detail-icon{font-size:24px;margin-bottom:6px}
.contact-detail-label{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:4px}
.contact-detail-val{font-size:14px;font-weight:400}
.contact-detail-val a{color:rgba(255,255,255,.9)}

/* ═══════════════════════════════════════════════════════════════
   CATEGORY PAGES
   ═══════════════════════════════════════════════════════════════ */
/* Page hero */
.cat-page-hero{position:relative;height:54vh;min-height:360px;overflow:hidden;display:flex;align-items:flex-end}
.cat-hero-bg{position:absolute;inset:0}
.cat-hero-img{width:100%;height:100%;object-fit:cover;object-position:center 35%}
.cat-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,20,16,.88) 0%,rgba(26,20,16,.5) 55%,rgba(26,20,16,.22) 100%)}
.cat-hero-content{position:relative;z-index:2;max-width:var(--max);width:100%;margin:0 auto;padding:0 var(--pad) 52px}
.cat-breadcrumb-nav{margin-bottom:16px}
.cat-breadcrumb{display:flex;gap:8px;list-style:none;font-size:12px;color:rgba(255,255,255,.55);flex-wrap:wrap}
.cat-breadcrumb a{color:rgba(255,255,255,.55)}
.cat-breadcrumb a:hover{color:var(--gold-light)}
.cat-hero-eyebrow{font-size:11px;letter-spacing:3.5px;text-transform:uppercase;color:var(--gold-light);font-weight:500;margin-bottom:14px;display:block}
.cat-hero-title{font-family:var(--font-display);font-size:clamp(34px,5vw,70px);font-weight:300;color:#fff;line-height:1.05;margin-bottom:12px}
.cat-hero-title em{font-style:italic;color:var(--gold-light)}
.cat-hero-meta{display:flex;gap:20px;flex-wrap:wrap;font-size:13px;color:rgba(255,255,255,.6);align-items:center;list-style:none}
.cat-hero-meta li strong{color:rgba(255,255,255,.9)}

/* Filter bar */
.cat-filter-bar{background:var(--warm-white);border-bottom:1px solid var(--border);padding:14px var(--pad);position:sticky;top:80px;z-index:90;box-shadow:0 2px 8px rgba(0,0,0,.06)}
.cat-filter-inner{max-width:var(--max);margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:20px}
.cat-filter-tags{display:flex;gap:8px;flex-wrap:wrap}
.ftag{padding:7px 16px;font-family:var(--font-body);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;font-weight:500;color:var(--text-muted);border:1px solid var(--border);background:var(--warm-white);cursor:pointer;transition:all .25s}
.ftag.active,.ftag:hover{background:var(--maroon);color:#fff;border-color:var(--maroon)}
.cat-sort{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-muted)}
.cat-sort select{padding:6px 28px 6px 10px;border:1px solid var(--border);background:var(--cream);font-family:var(--font-body);font-size:12px;color:var(--charcoal);outline:none;cursor:pointer;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%238a7a68' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}
.cat-count{font-size:12px;color:var(--text-muted);white-space:nowrap}

/* Intro strip */
.cat-intro-strip{background:var(--cream);border-bottom:1px solid var(--border);padding:32px var(--pad)}
.cat-intro-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:40px;align-items:center}
.cat-intro-text{font-size:15px;color:var(--text-muted);line-height:1.8;font-weight:300}
.cat-intro-text strong{color:var(--charcoal);font-weight:500}
.cat-intro-badges{display:flex;gap:10px;flex-wrap:wrap;flex-shrink:0;list-style:none}
.ci-badge{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--border);background:var(--warm-white);font-size:11px;letter-spacing:1px;text-transform:uppercase;font-weight:500;color:var(--charcoal);white-space:nowrap}
.ci-badge.gold{background:var(--maroon);color:#fff;border-color:var(--maroon)}

/* Products grid */
.cat-products{max-width:var(--max);margin:0 auto;padding:52px var(--pad) 72px}
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}

/* Category product card */
.pcat-card{position:relative;overflow:hidden;cursor:pointer}
.pcat-img{position:relative;overflow:hidden;aspect-ratio:3/4;background:#ede5d8}
.pcat-img img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform .6s var(--ease)}
.pcat-card:hover .pcat-img img{transform:scale(1.06)}
.pcat-badge{position:absolute;top:12px;left:12px;background:var(--maroon);color:#fff;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;padding:4px 10px;font-weight:500;z-index:2}
.pcat-badge.gold{background:var(--gold)}
.pcat-badge.dark{background:var(--charcoal)}
.pcat-wish{position:absolute;top:12px;right:12px;z-index:2;width:34px;height:34px;background:rgba(255,255,255,.88);border:none;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .25s;backdrop-filter:blur(4px)}
.pcat-wish:hover{background:#fff;color:var(--red)}
.pcat-wish.active{color:var(--red)}
.pcat-actions{position:absolute;bottom:0;left:0;right:0;background:rgba(26,20,16,.88);padding:14px 12px;transform:translateY(100%);transition:transform .3s;display:flex;gap:8px}
.pcat-card:hover .pcat-actions{transform:translateY(0)}
.pcat-body{padding:14px 2px 6px}
.pcat-cat{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);margin-bottom:4px}
.pcat-name{font-family:var(--font-display);font-size:18px;font-weight:400;color:var(--charcoal);margin-bottom:4px;line-height:1.3}
.pcat-desc{font-size:12px;color:var(--text-muted);margin-bottom:6px;line-height:1.5}
.pcat-rating{display:flex;align-items:center;gap:5px;margin-top:3px}
.pcat-stars{color:var(--gold);font-size:11px;letter-spacing:1px}
.pcat-rc{font-size:11px;color:var(--text-muted)}

/* Load more */
.cat-load-more{text-align:center;padding:36px 0 0;display:flex;flex-direction:column;align-items:center;gap:16px}
.cat-load-note{font-size:13px;color:var(--text-muted)}
.cat-load-more .btn+.btn{margin-left:12px}

/* SEO section */
.cat-seo-section{background:var(--warm-white);border-top:1px solid var(--border);padding:72px var(--pad)}
.cat-seo-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.1fr 1fr;gap:72px;align-items:start}
.cat-seo-title{font-family:var(--font-display);font-size:clamp(26px,3vw,44px);font-weight:300;color:var(--charcoal);margin-bottom:8px;line-height:1.1}
.cat-seo-title em{font-style:italic;color:var(--maroon)}
.cat-seo-subtitle{font-size:13px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-muted);margin-bottom:4px}
.cat-seo-body p{font-size:15px;color:var(--text-muted);line-height:1.85;font-weight:300;margin-bottom:14px}
.cat-seo-body p strong{color:var(--charcoal);font-weight:500}
.cat-seo-actions{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap}
.cat-why-title{font-family:var(--font-display);font-size:22px;font-weight:400;color:var(--charcoal);margin-bottom:4px}
.cat-seo-features{display:flex;flex-direction:column;gap:14px;margin-top:4px}
.cat-sf{display:flex;gap:14px;align-items:flex-start;padding:16px 18px;background:var(--cream);border:1px solid var(--border);border-left:3px solid var(--maroon)}
.cat-sf-icon{font-size:18px;flex-shrink:0}
.cat-sf-title{font-size:13px;font-weight:500;color:var(--charcoal);margin-bottom:3px}
.cat-sf-desc{font-size:12px;color:var(--text-muted);line-height:1.5}
.cat-contact-box{margin-top:20px;padding:20px;background:var(--cream);border:1px solid var(--border);border-left:3px solid var(--maroon)}
.cat-contact-label{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--maroon);font-weight:500;margin-bottom:10px}
.cat-contact-box p{font-size:14px;color:var(--text-muted);line-height:1.8}
.cat-contact-box a{color:var(--charcoal)}
.cat-contact-box a:hover{color:var(--maroon)}

/* Related categories */
.cat-related{padding:72px var(--pad);background:var(--cream)}
.cat-related-inner{max-width:var(--max);margin:0 auto}
.cat-related-header{text-align:center;margin-bottom:40px}
.cat-related-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.cat-rel-card{position:relative;overflow:hidden;cursor:pointer;border:1px solid var(--border);text-decoration:none;display:block;transition:transform .3s,box-shadow .3s}
.cat-rel-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.cat-rel-img{aspect-ratio:4/3;overflow:hidden}
.cat-rel-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.cat-rel-card:hover .cat-rel-img img{transform:scale(1.06)}
.cat-rel-body{padding:16px;background:var(--warm-white)}
.cat-rel-name{font-family:var(--font-display);font-size:18px;font-weight:400;color:var(--charcoal);margin-bottom:4px}
.cat-rel-link{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--maroon)}

/* Enquiry strip */
.cat-enquiry-strip{background:var(--maroon);padding:60px var(--pad)}
.cat-enquiry-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:center}
.cat-eq-eyebrow{color:var(--gold-light)}
.cat-eq-title{font-family:var(--font-display);font-size:clamp(22px,3vw,42px);font-weight:300;color:#fff;margin-bottom:8px}
.cat-eq-sub{font-size:14px;color:rgba(255,255,255,.65)}
.cat-eq-actions{display:flex;gap:12px;flex-wrap:wrap;flex-shrink:0}

/* ═══════════════════════════════════════════════════════════════
   ABOUT PAGE
   ═══════════════════════════════════════════════════════════════ */
.page-hero{position:relative;height:52vh;min-height:360px;overflow:hidden;display:flex;align-items:flex-end}
.page-hero-bg{position:absolute;inset:0}
.page-hero-img{width:100%;height:100%;object-fit:cover;object-position:center 30%}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,20,16,.85) 0%,rgba(26,20,16,.45) 55%,rgba(26,20,16,.22) 100%)}
.page-hero-content{position:relative;z-index:2;max-width:var(--max);width:100%;margin:0 auto;padding:0 var(--pad) 52px}
.page-breadcrumb-nav{margin-bottom:16px}
.page-breadcrumb{display:flex;gap:8px;list-style:none;font-size:12px;color:rgba(255,255,255,.55);flex-wrap:wrap}
.page-breadcrumb a{color:rgba(255,255,255,.55)}
.page-breadcrumb a:hover{color:var(--gold-light)}
.page-hero-eyebrow{font-size:11px;letter-spacing:3.5px;text-transform:uppercase;color:var(--gold-light);font-weight:500;margin-bottom:14px;display:block}
.page-hero-title{font-family:var(--font-display);font-size:clamp(34px,5vw,70px);font-weight:300;color:#fff;line-height:1.05;margin-bottom:12px}
.page-hero-title em{font-style:italic;color:var(--gold-light)}
.page-hero-sub{font-size:14px;letter-spacing:2px;color:rgba(255,255,255,.6);text-transform:uppercase}

/* About intro */
.about-intro{padding:100px var(--pad);max-width:var(--max);margin:0 auto}
.about-intro-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-intro-images{position:relative}
.ai-img-main{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:top}
.ai-img-accent{position:absolute;bottom:-28px;right:-28px;width:44%;aspect-ratio:1;object-fit:cover;border:6px solid #fff}
.ai-est-badge{position:absolute;top:-18px;left:-18px;width:100px;height:100px;background:var(--maroon);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#f5e6c0;text-align:center}
.ai-est-badge strong{font-family:var(--font-display);font-size:26px;display:block;line-height:1;font-weight:300}
.ai-est-badge span{font-size:9px;letter-spacing:1px;text-transform:uppercase;line-height:1.4}
.about-para{font-size:15px;color:var(--text-muted);line-height:1.85;font-weight:300;margin-bottom:14px}
.about-para strong{color:var(--charcoal);font-weight:500}
.about-highlights{margin-top:32px;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.about-hl{display:flex;gap:14px;align-items:flex-start;padding:16px;background:var(--warm-white);border:1px solid var(--border);border-left:3px solid var(--maroon)}
.about-hl-icon{font-size:20px;flex-shrink:0;margin-top:2px}
.about-hl-title{font-size:13px;font-weight:500;color:var(--charcoal);margin-bottom:3px}
.about-hl-desc{font-size:12px;color:var(--text-muted);line-height:1.5}

/* About stats */
.about-stats{background:var(--maroon);padding:56px var(--pad)}
.about-stats-inner{max-width:var(--max);margin:0 auto;display:flex;justify-content:space-around;align-items:center;gap:24px;flex-wrap:wrap}
.astat{text-align:center;flex:1;min-width:140px}
.astat-num{font-family:var(--font-display);font-size:52px;font-weight:300;color:#f5e6c0;line-height:1}
.astat-label{font-size:13px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(245,230,192,.8);margin:6px 0 2px;font-weight:500}
.astat-desc{font-size:12px;color:rgba(245,230,192,.45)}
.astat-sep{width:1px;height:60px;background:rgba(245,230,192,.2);flex-shrink:0}

/* About speciality */
.about-speciality{padding:100px var(--pad);background:var(--warm-white)}
.about-speciality-inner{max-width:var(--max);margin:0 auto}
.about-spec-header{text-align:center;margin-bottom:60px}
.spec-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.spec-card{background:var(--cream);border:1px solid var(--border);border-top:3px solid var(--maroon);padding:28px 22px;transition:transform .3s,box-shadow .3s}
.spec-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.spec-card-icon{font-size:30px;margin-bottom:14px}
.spec-card-title{font-family:var(--font-display);font-size:20px;font-weight:400;color:var(--charcoal);margin-bottom:10px}
.spec-card-desc{font-size:13px;color:var(--text-muted);line-height:1.7;font-weight:300}

/* About history */
.about-history{background:var(--charcoal);padding:100px var(--pad);position:relative;overflow:hidden}
.about-history::before{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 40px,rgba(212,168,48,.04) 40px,rgba(212,168,48,.04) 41px),repeating-linear-gradient(90deg,transparent,transparent 40px,rgba(212,168,48,.04) 40px,rgba(212,168,48,.04) 41px);pointer-events:none}
.about-history-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;position:relative;z-index:1}
.history-para{font-size:15px;color:rgba(255,255,255,.6);line-height:1.85;font-weight:300;margin-bottom:14px}
.history-para strong{color:rgba(255,255,255,.85)}
.hist-img-main{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:top}
.hist-quote{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-left:3px solid var(--gold);padding:22px;margin-top:16px}
.hist-quote-mark{font-family:var(--font-display);font-size:56px;color:var(--gold-light);line-height:.6;margin-bottom:8px;opacity:.5}
.hist-quote p{font-family:var(--font-display);font-size:17px;font-style:italic;color:rgba(255,255,255,.7);line-height:1.7;margin-bottom:10px}
.hist-quote-attr{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gold-light);opacity:.7}

/* About product range */
.about-products{padding:100px var(--pad);background:var(--cream)}
.about-products-inner{max-width:var(--max);margin:0 auto}
.about-products-header{text-align:center;margin-bottom:56px}
.prod-range-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.prod-range-card{display:block;text-decoration:none;overflow:hidden;border:1px solid var(--border);background:var(--warm-white);transition:transform .3s,box-shadow .3s}
.prod-range-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.prc-img{aspect-ratio:4/3;overflow:hidden;background:#e8ddd0}
.prc-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.prod-range-card:hover .prc-img img{transform:scale(1.05)}
.prc-body{padding:22px}
.prc-title{font-family:var(--font-display);font-size:22px;font-weight:400;color:var(--charcoal);margin-bottom:8px}
.prc-desc{font-size:13px;color:var(--text-muted);line-height:1.6;font-weight:300}

/* About CTA */
.about-cta{background:var(--maroon);padding:72px var(--pad)}
.about-cta-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:center}
.about-cta-title{font-family:var(--font-display);font-size:clamp(26px,3.5vw,46px);font-weight:300;color:#fff;margin-bottom:10px}
.about-cta-sub{font-size:15px;color:rgba(255,255,255,.65)}
.about-cta-actions{display:flex;gap:14px;flex-wrap:wrap;flex-shrink:0}

/* ═══════════════════════════════════════════════════════════════
   CONTACT PAGE
   ═══════════════════════════════════════════════════════════════ */
.contact-section{max-width:var(--max);margin:0 auto;padding:80px var(--pad);display:grid;grid-template-columns:1fr 1.1fr;gap:72px;align-items:start}
.contact-info-label{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--maroon);font-weight:500;margin-bottom:12px;display:block}
.contact-info-title{font-family:var(--font-display);font-size:clamp(26px,3.5vw,46px);font-weight:300;color:var(--charcoal);line-height:1.1;margin-bottom:18px}
.contact-info-desc{font-size:15px;color:var(--text-muted);line-height:1.85;font-weight:300;margin-bottom:36px}
.contact-cards{display:flex;flex-direction:column;gap:14px;margin-bottom:36px}
.contact-card{display:flex;gap:18px;align-items:flex-start;padding:20px;background:var(--warm-white);border:1px solid var(--border);transition:border-color .3s,box-shadow .3s}
.contact-card:hover{border-color:var(--maroon);box-shadow:var(--sh-sm)}
.cc-icon{width:44px;height:44px;background:var(--maroon);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;color:#fff}
.cc-label{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);font-weight:500;margin-bottom:5px}
.cc-value{font-size:15px;color:var(--charcoal);font-weight:400;line-height:1.5}
.cc-value a{color:var(--charcoal)}
.cc-value a:hover{color:var(--maroon)}
.cc-note{font-size:12px;color:var(--text-muted);margin-top:3px}
.hours-block{background:var(--cream);border:1px solid var(--border);border-left:4px solid var(--maroon);padding:22px}
.hours-title{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--maroon);font-weight:500;margin-bottom:14px}
.hours-row{display:flex;justify-content:space-between;font-size:13px;padding:7px 0;border-bottom:1px solid var(--border)}
.hours-row:last-child{border-bottom:none}
.hours-day{color:var(--text-muted)}
.hours-time{color:var(--charcoal);font-weight:500}
.hours-open{color:#2e7d32;font-size:11px;letter-spacing:1px;text-transform:uppercase;font-weight:500}
.hours-note{font-size:12px;color:var(--text-muted);margin-left:8px}

/* Contact form */
.contact-form-panel{background:var(--warm-white);border:1px solid var(--border);padding:44px 40px}
.form-title{font-family:var(--font-display);font-size:30px;font-weight:400;color:var(--charcoal);margin-bottom:6px}
.form-sub{font-size:13px;color:var(--text-muted);margin-bottom:28px;line-height:1.6}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.form-label{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--charcoal);font-weight:500}
.form-label span{color:var(--maroon)}
.form-input,.form-select,.form-textarea{width:100%;padding:12px 14px;border:1px solid var(--border);background:var(--cream);font-family:var(--font-body);font-size:14px;color:var(--charcoal);outline:none;transition:border-color .3s,box-shadow .3s;-webkit-appearance:none;border-radius:0}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--maroon);box-shadow:0 0 0 3px rgba(110,20,35,.08)}
.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}
.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238a7a68' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;cursor:pointer}
.form-textarea{resize:vertical;min-height:120px;line-height:1.6}
.form-submit{width:100%;padding:16px;background:var(--maroon);color:#fff;border:2px solid var(--maroon);font-family:var(--font-body);font-size:12px;letter-spacing:2.5px;font-weight:500;text-transform:uppercase;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:10px;margin-top:4px}
.form-submit:hover{background:var(--maroon-dark);border-color:var(--maroon-dark)}
.form-note{font-size:12px;color:var(--text-muted);text-align:center;margin-top:12px;line-height:1.5}
.form-success{display:none;background:#e8f5e9;border:1px solid #a5d6a7;border-left:4px solid #2e7d32;padding:18px;font-size:14px;color:#1b5e20;margin-top:16px;line-height:1.6}

/* Map */
.map-section{background:var(--cream);padding:0 0 72px}
.map-section-inner{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.map-heading-eyebrow{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--maroon);font-weight:500;margin-bottom:10px;padding-top:60px;display:block}
.map-title{font-family:var(--font-display);font-size:34px;font-weight:300;color:var(--charcoal);margin-bottom:28px}
.map-embed{width:100%;height:420px;border:none;border:1px solid var(--border);display:block}
.map-address-bar{display:flex;gap:40px;padding:22px 26px;background:var(--warm-white);border:1px solid var(--border);border-top:none;flex-wrap:wrap}
.map-addr-item{display:flex;gap:12px;align-items:flex-start;font-size:14px}
.map-addr-icon{font-size:18px;flex-shrink:0;margin-top:2px}
.map-addr-label{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);font-weight:500;margin-bottom:3px}
.map-addr-val{color:var(--charcoal);line-height:1.5}
.map-addr-val a{color:var(--charcoal)}
.map-addr-val a:hover{color:var(--maroon)}

/* FAQ */
.faq-section{background:var(--warm-white);padding:72px var(--pad)}
.faq-inner{max-width:900px;margin:0 auto}
.faq-header{text-align:center;margin-bottom:44px}
.faq-list{display:flex;flex-direction:column;gap:2px}
.faq-item{border:1px solid var(--border);overflow:hidden}
.faq-question{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;cursor:pointer;font-weight:500;font-size:15px;color:var(--charcoal);background:var(--cream);transition:background .3s;user-select:none;list-style:none;gap:12px}
.faq-question:hover{background:var(--warm-white)}
.faq-question::-webkit-details-marker{display:none}
.faq-chevron{font-size:16px;color:var(--maroon);transition:transform .3s;flex-shrink:0}
details[open] .faq-chevron{transform:rotate(180deg)}
details[open] .faq-question{background:var(--warm-white);border-bottom:1px solid var(--border);color:var(--maroon)}
.faq-answer{padding:18px 22px;font-size:14px;color:var(--text-muted);line-height:1.8;background:var(--warm-white)}
.faq-answer a{color:var(--maroon)}

/* ═══════════════════════════════════════════════════════════════
   PRODUCT DETAIL PAGE
   ═══════════════════════════════════════════════════════════════ */
.product-page{max-width:var(--max);margin:0 auto;padding:48px var(--pad) 80px}
.breadcrumb{font-size:12px;color:var(--text-muted);display:flex;gap:8px;align-items:center;margin-bottom:32px}
.breadcrumb a{color:var(--text-muted)}
.breadcrumb a:hover{color:var(--maroon)}
.product-main{display:grid;grid-template-columns:1fr 1fr;gap:80px;margin-bottom:100px}

/* Gallery */
.product-gallery{position:relative}
.gallery-main{position:relative;overflow:hidden;margin-bottom:12px;cursor:zoom-in;background:#ede5d8}
.gallery-main-img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:top center;transition:transform .5s ease}
.gallery-main:hover .gallery-main-img{transform:scale(1.04)}
.gallery-badges{position:absolute;top:16px;left:16px;display:flex;flex-direction:column;gap:6px}
.gbadge{display:inline-block;padding:5px 12px;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;font-weight:500}
.gbadge-gold{background:var(--gold);color:#fff}
.gbadge-maroon{background:var(--maroon);color:#fff}
.gbadge-dark{background:var(--charcoal);color:var(--gold-light)}
.gallery-zoom{position:absolute;bottom:14px;right:14px;background:rgba(255,255,255,.88);border:1px solid var(--border);padding:7px 13px;font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);display:flex;align-items:center;gap:6px;backdrop-filter:blur(4px)}
.gallery-thumbs{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px}
.gallery-thumbs::-webkit-scrollbar{height:3px}
.gallery-thumbs::-webkit-scrollbar-track{background:var(--border)}
.gallery-thumbs::-webkit-scrollbar-thumb{background:var(--maroon)}
.gallery-thumb{flex-shrink:0;width:78px;height:94px;overflow:hidden;border:2px solid transparent;cursor:pointer;transition:border-color var(--tr);background:#e5ddd0;display:flex;align-items:center;justify-content:center}
.gallery-thumb.active{border-color:var(--maroon)}
.gallery-thumb:hover{border-color:var(--charcoal)}
.gallery-thumb img{width:100%;height:100%;object-fit:cover}

/* Product info */
.product-info{padding-top:8px}
.product-category-tag{display:inline-block;font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--maroon);border:1px solid var(--maroon);padding:5px 14px;margin-bottom:18px;font-weight:500}
.product-title{font-family:var(--font-display);font-size:clamp(28px,3vw,46px);font-weight:300;line-height:1.1;color:var(--charcoal);margin-bottom:14px}
.product-rating{display:flex;align-items:center;gap:10px;margin-bottom:26px;flex-wrap:wrap}
.rating-stars{color:var(--gold);font-size:14px;letter-spacing:2px}
.rating-count{font-size:13px;color:var(--text-muted)}
.rating-sep{width:1px;height:14px;background:var(--border)}
.verified-badge{font-size:11px;color:#2e7d32;display:flex;align-items:center;gap:4px}
.price-block{background:var(--cream);border:1px solid var(--border);border-left:4px solid var(--maroon);padding:20px 22px;margin-bottom:28px;display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.price-current{font-family:var(--font-display);font-size:36px;font-weight:400;color:var(--charcoal);line-height:1}
.price-original{font-size:18px;color:var(--text-muted);text-decoration:line-through}
.price-save{font-size:12px;letter-spacing:1px;text-transform:uppercase;color:#2e7d32;font-weight:500;background:rgba(46,125,50,.08);padding:4px 10px}
.price-note{font-size:12px;color:var(--text-muted);width:100%;margin-top:4px}
.variant-sec{margin-bottom:22px}
.variant-label{font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--charcoal);font-weight:500;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.variant-sel{color:var(--maroon);font-weight:300;letter-spacing:.5px;font-size:13px;text-transform:none}
.color-swatches{display:flex;gap:10px;flex-wrap:wrap}
.color-swatch{width:34px;height:34px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:all var(--tr)}
.color-swatch.active{box-shadow:0 0 0 2px var(--cream),0 0 0 4px var(--maroon)}
.color-swatch:hover{transform:scale(1.12)}
.size-pills{display:flex;gap:8px;flex-wrap:wrap}
.size-pill{padding:8px 18px;border:1px solid var(--border);font-size:12px;letter-spacing:1px;cursor:pointer;transition:all var(--tr);background:var(--warm-white);color:var(--charcoal)}
.size-pill.active,.size-pill:hover{border-color:var(--maroon);background:var(--maroon);color:#fff}
.qty-section{margin-bottom:24px}
.qty-control{display:inline-flex;border:1px solid var(--border);overflow:hidden}
.qty-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:20px;background:var(--warm-white);cursor:pointer;transition:background var(--tr);user-select:none;color:var(--charcoal)}
.qty-btn:hover{background:var(--cream)}
.qty-val{width:56px;height:44px;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:500;border-left:1px solid var(--border);border-right:1px solid var(--border);background:var(--warm-white)}
.product-cta{display:flex;gap:10px;margin-bottom:28px}
.btn-add-cart{flex:1;background:var(--charcoal);color:#fff;border:2px solid var(--charcoal);padding:16px 18px;font-family:var(--font-body);font-size:12px;letter-spacing:2px;font-weight:500;text-transform:uppercase;cursor:pointer;transition:all var(--tr);display:flex;align-items:center;justify-content:center;gap:8px}
.btn-add-cart:hover{background:var(--maroon);border-color:var(--maroon)}
.btn-enquire{flex:1;background:var(--maroon);color:#fff;border:2px solid var(--maroon);padding:16px 18px;font-family:var(--font-body);font-size:12px;letter-spacing:2px;font-weight:500;text-transform:uppercase;cursor:pointer;transition:all var(--tr)}
.btn-enquire:hover{background:var(--maroon-dark);border-color:var(--maroon-dark)}
.btn-wish{width:54px;height:54px;border:2px solid var(--border);background:var(--warm-white);display:flex;align-items:center;justify-content:center;font-size:20px;cursor:pointer;transition:all var(--tr);flex-shrink:0}
.btn-wish:hover{border-color:var(--red);color:var(--red)}
.trust-signals{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:32px;padding:18px;background:var(--cream);border:1px solid var(--border)}
.trust-item{text-align:center;display:flex;flex-direction:column;align-items:center;gap:5px}
.trust-icon{font-size:22px}
.trust-text{font-size:11px;color:var(--charcoal);line-height:1.4}
.product-meta{border-top:1px solid var(--border);padding-top:22px}
.meta-row{display:flex;font-size:13px;gap:8px;padding:7px 0;border-bottom:1px solid var(--border)}
.meta-row:last-child{border-bottom:none}
.meta-key{color:var(--text-muted);min-width:130px;background:var(--cream);padding:2px 8px}
.meta-val{color:var(--charcoal)}
.meta-val a{color:var(--maroon);text-decoration:underline}
.enquiry-box{margin-top:22px;padding:18px 20px;background:var(--cream);border:1px solid var(--border);border-left:4px solid var(--maroon)}
.enquiry-box-label{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--maroon);font-weight:500;margin-bottom:10px}
.enquiry-box p{font-size:14px;color:var(--text-muted);line-height:1.8}
.enquiry-box a{color:var(--charcoal)}
.enquiry-box a:hover{color:var(--maroon)}
.enquiry-box small{font-size:12px;color:var(--text-muted);display:block;margin-top:6px}

/* Tabs */
.product-tabs{margin-bottom:80px}
.tab-header{display:flex;border-bottom:1px solid var(--border);margin-bottom:40px;overflow-x:auto}
.tab-btn{padding:15px 26px;font-family:var(--font-body);font-size:11px;letter-spacing:2px;text-transform:uppercase;font-weight:500;color:var(--text-muted);border-bottom:2px solid transparent;cursor:pointer;transition:all var(--tr);background:none;margin-bottom:-1px;white-space:nowrap}
.tab-btn.active{color:var(--charcoal);border-bottom-color:var(--maroon)}
.tab-btn:hover{color:var(--charcoal)}
.tab-panel{display:none}
.tab-panel.active{display:block}
.tab-content{display:grid;grid-template-columns:1.2fr 1fr;gap:56px;align-items:start}
.desc-body p{font-size:15px;color:var(--text-muted);line-height:1.85;margin-bottom:14px;font-weight:300}
.desc-highlights{margin-top:24px}
.hl-item{display:flex;align-items:flex-start;gap:14px;padding:13px 0;border-bottom:1px solid var(--border)}
.hl-item:last-child{border-bottom:none}
.hl-icon{width:32px;height:32px;background:var(--cream);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.hl-title{font-size:13px;font-weight:500;color:var(--charcoal);margin-bottom:3px}
.hl-desc{font-size:12px;color:var(--text-muted);line-height:1.5}
.specs-table{width:100%;border-collapse:collapse}
.specs-table tr{border-bottom:1px solid var(--border)}
.specs-table tr:first-child{border-top:1px solid var(--border)}
.specs-table td{padding:13px 14px;font-size:13px;vertical-align:top}
.specs-table td:first-child{color:var(--text-muted);width:150px;background:var(--cream)}
.specs-table td:last-child{color:var(--charcoal)}
.care-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:20px}
.care-card{background:var(--cream);border:1px solid var(--border);padding:20px;text-align:center}
.care-icon{font-size:28px;margin-bottom:8px}
.care-title{font-size:12px;letter-spacing:1px;text-transform:uppercase;font-weight:500;margin-bottom:4px;color:var(--charcoal)}
.care-desc{font-size:12px;color:var(--text-muted)}
.reviews-summary{display:flex;gap:48px;align-items:center;margin-bottom:40px;padding:28px;background:var(--cream);border:1px solid var(--border)}
.rs-score{text-align:center}
.rs-number{font-family:var(--font-display);font-size:68px;font-weight:300;color:var(--charcoal);line-height:1}
.rs-stars{color:var(--gold);font-size:18px;letter-spacing:3px;margin:6px 0}
.rs-count{font-size:12px;color:var(--text-muted)}
.rs-bars{flex:1;display:flex;flex-direction:column;gap:8px}
.rs-bar-row{display:flex;align-items:center;gap:10px;font-size:12px}
.rs-bar-label{color:var(--gold);width:60px}
.rs-bar-track{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden}
.rs-bar-fill{height:100%;background:var(--gold);border-radius:3px}
.rs-bar-count{color:var(--text-muted);width:20px;text-align:right}
.review-card{padding:22px;border:1px solid var(--border);margin-bottom:16px;background:var(--warm-white)}
.review-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}
.review-author{font-weight:500;font-size:14px;color:var(--charcoal)}
.review-stars{color:var(--gold);font-size:13px;letter-spacing:2px;margin-top:3px}
.review-date{font-size:12px;color:var(--text-muted)}
.review-text{font-family:var(--font-display);font-size:16px;color:var(--text-muted);line-height:1.7;font-style:italic}
.related-section{border-top:1px solid var(--border);padding-top:56px}
.related-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:36px}
.related-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.sticky-cta{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--warm-white);border-top:1px solid var(--border);padding:14px 20px;z-index:200;box-shadow:0 -4px 20px rgba(0,0,0,.1);gap:10px}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE BREAKPOINTS
   ═══════════════════════════════════════════════════════════════ */
@media(max-width:1200px){
  :root{--pad:28px}
  .products-grid{grid-template-columns:repeat(3,1fr)}
  .cat-grid{grid-template-columns:repeat(3,1fr)}
  .cat-related-grid{grid-template-columns:repeat(3,1fr)}
  .gallery-strip-grid{grid-template-columns:repeat(4,1fr)}
  .gs-item:nth-child(n+5){display:none}
  .related-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:1024px){
  .hero-badge{display:none}
  .welcome-section{grid-template-columns:1fr;gap:56px}
  .welcome-img-accent{display:none}
  .categories-grid{grid-template-columns:1fr;grid-template-rows:auto}
  .cat-card:first-child{grid-row:auto}
  .cat-card{height:250px}
  .history-inner{grid-template-columns:1fr;gap:56px}
  .history-img-overlay{display:none}
  .testimonials-grid{grid-template-columns:1fr;max-width:500px;margin:0 auto}
  .contact-strip-inner{grid-template-columns:1fr;gap:36px}
  .cat-seo-inner{grid-template-columns:1fr;gap:40px}
  .cat-intro-inner{grid-template-columns:1fr}
  .cat-intro-badges{display:none}
  .cat-enquiry-inner{grid-template-columns:1fr;gap:28px}
  .about-intro-inner{grid-template-columns:1fr;gap:56px}
  .ai-img-accent{display:none}
  .about-history-inner{grid-template-columns:1fr;gap:48px}
  .about-cta-inner{grid-template-columns:1fr;gap:28px}
  .contact-section{grid-template-columns:1fr;gap:48px}
  .product-main{grid-template-columns:1fr;gap:48px}
  .tab-content{grid-template-columns:1fr;gap:36px}
  .spec-cards{grid-template-columns:repeat(2,1fr)}
  .prod-range-grid{grid-template-columns:repeat(2,1fr)}
  .astat-sep{display:none}
}
@media(max-width:768px){
  :root{--pad:20px}
  /* Header */
  .nav-left,.nav-right{display:none}
  .header-inner{grid-template-columns:auto 1fr auto;min-height:66px}
  .menu-toggle{display:flex}
  /* Hero */
  .hero{height:80vw;min-height:400px}
  .hero-content{left:5%;right:5%;max-width:none}
  .hero-title{font-size:clamp(30px,7vw,50px)}
  /* Sections */
  .stats-inner{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
  .products-grid{grid-template-columns:repeat(2,1fr)}
  .welcome-section,.products-section,.categories-section{padding:60px var(--pad)}
  .history-section,.testimonials-section{padding:60px var(--pad)}
  .gallery-strip-grid{grid-template-columns:repeat(3,1fr)}
  .gs-item:nth-child(n+4){display:none}
  .contact-strip{padding:40px var(--pad)}
  .contact-details{flex-direction:column;gap:20px;align-items:flex-start}
  .speciality-grid{grid-template-columns:1fr}
  /* Category */
  .cat-page-hero{height:65vw;min-height:280px}
  .cat-hero-content{padding:0 var(--pad) 32px}
  .cat-filter-bar{padding:12px var(--pad);top:66px}
  .cat-filter-tags{gap:6px}
  .ftag{padding:6px 12px;font-size:10px}
  .cat-sort{display:none}
  .cat-intro-strip{padding:24px var(--pad)}
  .cat-products{padding:32px var(--pad) 56px}
  .cat-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .cat-seo-section{padding:48px var(--pad)}
  .cat-related{padding:48px var(--pad)}
  .cat-related-grid{grid-template-columns:repeat(2,1fr)}
  .cat-enquiry-strip{padding:40px var(--pad)}
  .cat-hero-meta{gap:12px}
  .cat-load-more{flex-direction:column}
  .cat-load-more .btn+.btn{margin-left:0}
  /* About */
  .page-hero{height:60vw;min-height:280px}
  .page-hero-content{padding:0 var(--pad) 36px}
  .about-intro{padding:56px var(--pad)}
  .about-speciality{padding:56px var(--pad)}
  .about-history{padding:56px var(--pad)}
  .about-products{padding:56px var(--pad)}
  .about-cta{padding:48px var(--pad)}
  .about-highlights{grid-template-columns:1fr}
  .spec-cards{grid-template-columns:1fr}
  .prod-range-grid{grid-template-columns:1fr}
  /* Contact */
  .contact-section{padding:48px var(--pad)}
  .contact-form-panel{padding:28px 20px}
  .form-row{grid-template-columns:1fr}
  .map-section-inner{padding:0 var(--pad)}
  .map-address-bar{flex-direction:column;gap:20px}
  .faq-section{padding:48px var(--pad)}
  /* Footer */
  .footer-inner{grid-template-columns:1fr;gap:28px}
  .footer-bottom{flex-direction:column;gap:10px;text-align:center}
  /* Product */
  .product-page{padding:24px var(--pad) 100px}
  .product-cta{flex-wrap:wrap}
  .btn-add-cart,.btn-enquire{width:100%;flex:none}
  .btn-wish{width:100%}
  .trust-signals{grid-template-columns:repeat(2,1fr)}
  .related-grid{grid-template-columns:repeat(2,1fr)}
  .care-grid{grid-template-columns:repeat(2,1fr)}
  .tab-btn{padding:12px 12px;font-size:10px}
  .sticky-cta{display:flex}
  .reviews-summary{flex-direction:column}
}
@media(max-width:480px){
  .cat-grid{grid-template-columns:1fr}
  .pcat-img{aspect-ratio:3/2}
  .products-grid{grid-template-columns:1fr}
  .cat-related-grid{grid-template-columns:1fr}
  .related-grid{grid-template-columns:repeat(2,1fr)}
  .trust-signals{grid-template-columns:1fr}
}

/* ── Print styles ── */
@media print{.announcement-bar,.site-header,.sticky-cta,.cat-filter-bar,.site-footer{display:none}.product-page{padding:0}}
