/* ============================================================
   AVD DesignProShop v6.0 — Unified Stylesheet
   Modern professional B2B AV equipment design
   Black / Gold / Cream palette
   ============================================================ */

/* ============================================================
   GLOBAL PAGINATION — pro/international style
   First < 1 2 3 ... 12 13 > Last
   ============================================================ */
.pagination{
  display:flex;align-items:center;justify-content:center;flex-wrap:wrap;
  gap:6px;margin:36px 0 12px;
  font-family:'Roboto','Kanit',sans-serif;
}
.pagination > *{
  min-width:38px;height:38px;padding:0 12px;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:13.5px;font-weight:600;
  color:#1a1a1d;background:#fff;
  border:1px solid #ddd6c2;
  text-decoration:none;
  transition:.18s;
  user-select:none;
}
.pagination .pg-num{font-variant-numeric:tabular-nums}
.pagination .pg-num:hover,
.pagination .pg-arrow:hover,
.pagination .pg-edge:hover{
  background:#fbf6e8;border-color:#c9a24a;color:#7a5a14;
}
.pagination .pg-num.current{
  background:#0e0f12;color:#fff;border-color:#0e0f12;
  font-weight:800;
}
.pagination .pg-edge{
  font-size:12px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;
}
.pagination .pg-arrow{
  font-size:18px;line-height:1;font-weight:700;
}
.pagination .pg-ellipsis{
  border:0;background:transparent;color:#888;cursor:default;
  font-weight:700;
}
.pagination .disabled{
  opacity:.4;cursor:default;pointer-events:none;
  background:#f7f5ee;
}
@media(max-width:680px){
  .pagination > *{min-width:34px;height:34px;padding:0 8px;font-size:12.5px}
  .pagination .pg-edge{font-size:10.5px;padding:0 8px}
}

/* ============================================================
   GLOBAL FONT FAMILY (v9.9)
   Latin/numeric: Roboto · Thai: Kanit (browser picks per glyph)
   This rule wins over every other font-family declaration.
   ============================================================ */
html, body, button, input, select, textarea, optgroup,
h1, h2, h3, h4, h5, h6, p, a, span, div, li, td, th, label,
.brand, .menu, .btn, .lux-eyebrow, .home-hero-title, .home-hero-lead,
.home-eyebrow, .footer-tagline, .why-title, .lux-head h2,
.cn-hero h1, .cn-form-head h2, .sol-hero h1, .sol-card-tagline,
.dc-hero h1, .dc-gate-card h3,
.product-card *, .footer-col *, .filter-title, .filter-group h3,
.cat-tile *, .cat-tile-meta h4, .cat-tile-meta small,
.mega-cat-link, .mega-pane-list a, .home-hero-actions .btn,
.btn-promo, .btn-gold, .btn-outline-light{
  font-family:'Roboto','Kanit',Arial,Helvetica,sans-serif !important;
}
/* Numeric/monospace use cases (token codes, file sizes, prices) keep mono feel */
.dc-token-input, .dc-token-counter, .dc-status-token, .dc-card-size,
.cn-hours-row .time{
  font-family:'Roboto Mono','Courier New',ui-monospace,monospace !important;
}

:root{
  --black:#0b0b0d;
  --dark:#141418;
  --dark-2:#1c1c22;
  --gold:#c9a24a;
  --gold-soft:#ead9a8;
  --gold-bright:#d8b65e;
  --cream:#f7f2e8;
  --white:#ffffff;
  --gray:#6b7280;
  --gray-soft:#9ca3af;
  --line:rgba(0,0,0,.09);
  --line-light:rgba(255,255,255,.12);
  --radius:22px;
  --radius-lg:32px;
  --container:1180px;
  --shadow:0 18px 50px rgba(0,0,0,.10);
  --shadow-lg:0 22px 60px rgba(0,0,0,.18);
  --shadow-xl:0 24px 70px rgba(0,0,0,.28);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Prompt','IBM Plex Sans Thai','Sarabun',Arial,Helvetica,sans-serif;
  background:var(--cream);
  color:var(--black);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button{font-family:inherit}

.container{width:min(var(--container),calc(100% - 40px));margin:auto}

/* ============================================================
   TOPBAR
   ============================================================ */
.topbar{background:var(--black);color:var(--gold-soft);font-size:12.5px;padding:6px 0}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.topbar a{color:var(--gold-soft)}
.topbar a:hover{color:var(--white)}
.topbar-tag{font-size:12.5px;letter-spacing:.3px;opacity:.85}
.topbar-contact{display:flex;align-items:center;gap:0;flex-wrap:wrap}
.topbar-contact .tb-item{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;color:var(--gold-soft);font-weight:500;font-size:12.5px;
  border:0;background:transparent;cursor:pointer;
  position:relative;text-decoration:none;line-height:1;font-family:inherit;
}
.topbar-contact .tb-item + .tb-item::before,
.topbar-contact .tb-lang::before{
  content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:1px;height:14px;background:rgba(201,162,74,.28);
}
.topbar-contact .tb-lang{position:relative}
.topbar-contact .tb-item:hover{color:var(--white)}
.topbar-contact .tb-ico{width:14px;height:14px;flex-shrink:0;opacity:.95}
.topbar-contact .tb-caret{font-size:9px;opacity:.7;margin-left:1px}
.tb-lang-menu{
  position:absolute;top:calc(100% + 6px);right:0;
  min-width:90px;background:rgba(15,15,18,.97);
  border:1px solid rgba(201,162,74,.25);border-radius:10px;
  padding:6px;display:flex;flex-direction:column;gap:2px;
  box-shadow:0 12px 30px rgba(0,0,0,.4);z-index:1100;
  /* Replace display:none toggle with opacity/visibility — lets us add a delay */
  opacity:0;visibility:hidden;transform:translateY(-4px);pointer-events:none;
  transition:opacity .18s ease, visibility .18s ease, transform .18s ease;
  transition-delay:.35s;            /* keep open 350ms after mouse leaves */
}
/* Invisible hover-bridge so the 6px gap between button and menu doesn't break hover */
.tb-lang-menu::before{
  content:"";position:absolute;left:0;right:0;top:-10px;height:10px;
}
.tb-lang:hover .tb-lang-menu,
.tb-lang:focus-within .tb-lang-menu,
.tb-lang-menu:hover{
  opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto;
  transition-delay:0s;              /* open immediately */
}
.tb-lang-menu a{
  display:flex;align-items:center;gap:9px;
  padding:7px 12px;border-radius:6px;
  font-size:12.5px;font-weight:600;color:#e5e7eb;letter-spacing:.5px;
  text-decoration:none;
}
.tb-lang-menu a:hover{background:rgba(201,162,74,.14);color:var(--gold-soft)}
.tb-lang-menu a.on{background:rgba(201,162,74,.18);color:var(--gold-soft)}
/* Flag icons — flat 18x12 inline SVG, rounded edges */
.flag-ico{
  width:18px;height:12px;display:inline-block;flex-shrink:0;
  border-radius:2px;
  box-shadow:0 0 0 1px rgba(255,255,255,.15);
  overflow:hidden;
  vertical-align:middle;
}
.tb-lang-btn .flag-ico{margin-right:2px}

/* ============================================================
   HEADER + NAV
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:999;
  background:#ffffff;
  border-bottom:1px solid #ececec;
  box-shadow:0 1px 0 rgba(0,0,0,.02);
}
.nav{height:96px;display:flex;align-items:center;justify-content:space-between;color:var(--black);gap:36px}
.brand{display:flex;align-items:center;gap:12px;font-weight:800;letter-spacing:.6px;color:var(--black);text-decoration:none}
.site-brand-logo{height:72px;width:auto;max-width:280px;display:block;object-fit:contain;background:transparent}
.brand-fallback{display:flex;align-items:center;gap:12px;color:var(--black)}
.logo-mark{
  width:42px;height:42px;border-radius:12px;
  background:linear-gradient(135deg,var(--gold),#fff0b3);
  color:var(--black);
  display:grid;place-items:center;font-weight:900;font-size:14px;
  flex-shrink:0;
}
.brand-text{display:inline-flex;flex-direction:column;color:var(--black);font-weight:800}
.brand small{display:block;color:#888;font-size:11px;font-weight:500;letter-spacing:1px;margin-top:-3px}

.menu{display:flex;align-items:center;gap:48px;font-size:18px;color:#1a1a1d}
.menu > li{position:relative;list-style:none}
.menu > li > a{
  color:#1a1a1d;display:inline-flex;align-items:center;gap:8px;
  padding:12px 4px;
  font-weight:600;transition:color .25s;letter-spacing:.2px;
  text-decoration:none;
}
.menu > li > a:hover,.menu > li > a.active{color:var(--gold)}
.menu .nav-arr{font-size:10px;opacity:.55;color:var(--gold)}

/* Dropdown */
.menu .dd{
  position:absolute;top:calc(100% + 12px);left:0;
  min-width:240px;
  background:rgba(15,15,18,.97);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid rgba(201,162,74,.22);
  border-radius:18px;
  padding:10px;
  box-shadow:0 22px 55px rgba(0,0,0,.55);
  list-style:none;
  opacity:0;visibility:hidden;transform:translateY(8px);
  transition:opacity .25s, transform .25s, visibility .25s;
  z-index:1000;
}
.menu li:hover > .dd{opacity:1;visibility:visible;transform:translateY(0)}
.menu .dd a{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:10px;
  color:#e5e7eb;font-size:13px;font-weight:500;
  transition:background .2s, color .2s, transform .2s;
}
.menu .dd a:hover{background:rgba(201,162,74,.12);color:var(--gold-soft);transform:translateX(2px)}
.menu .dd .dd-ico{
  width:26px;height:26px;display:grid;place-items:center;
  background:rgba(201,162,74,.12);border:1px solid rgba(201,162,74,.2);
  border-radius:8px;font-size:13px;flex-shrink:0;
}

.nav-actions{display:flex;align-items:center;gap:12px}
.nav-actions .btn{border-radius:6px}
/* Promotion button — solid black with subtle pulsing red dot */
.btn-promo{
  background:#0e0f12;color:#fff !important;
  border:1px solid #0e0f12;
  display:inline-flex;align-items:center;gap:8px;
  font-weight:700;letter-spacing:.4px;
  transition:.22s;
}
.btn-promo:hover{
  background:var(--gold);border-color:var(--gold);color:#0a0b0d !important;
  transform:translateY(-1px);
  box-shadow:0 8px 18px rgba(201,162,74,.32);
}
.btn-promo .btn-promo-dot{
  width:7px;height:7px;border-radius:50%;
  background:#e63946;flex-shrink:0;
  box-shadow:0 0 0 2px rgba(230,57,70,.28);
  animation:btn-promo-pulse 1.6s ease-in-out infinite;
}
.btn-promo:hover .btn-promo-dot{
  background:#0a0b0d;box-shadow:0 0 0 2px rgba(10,11,13,.25);
}
@keyframes btn-promo-pulse{
  0%,100%{box-shadow:0 0 0 2px rgba(230,57,70,.28)}
  50%   {box-shadow:0 0 0 6px rgba(230,57,70,.0)}
}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  border-radius:999px;padding:12px 20px;
  font-weight:700;font-size:14px;
  border:1px solid transparent;cursor:pointer;white-space:nowrap;
  transition:all .25s;font-family:inherit;text-decoration:none;
}
.btn-gold{background:var(--gold);color:var(--black);box-shadow:0 10px 30px rgba(201,162,74,.22)}
.btn-gold:hover{transform:translateY(-2px);background:var(--gold-bright);color:var(--black)}
.btn-dark{background:var(--black);color:var(--white)}
.btn-dark:hover{background:var(--dark-2);color:var(--white)}
.btn-light{background:var(--white);color:#111;border:1px solid #ddd}
.btn-light:hover{background:#f4f4f4}
.btn-outline{border-color:rgba(255,255,255,.22);color:var(--white);background:transparent}
.btn-outline:hover{border-color:var(--gold);color:var(--gold-soft)}
.btn-quote{border:1px solid #ddd;color:#111;background:white}
.btn-quote:hover{border-color:var(--gold);color:var(--gold-bright)}

.lang-btn{
  padding:8px 14px;border-radius:999px;font-size:12px;font-weight:600;
  border:1px solid rgba(255,255,255,.18);color:#e5e7eb;background:transparent;
  transition:.2s;
}
.lang-btn:hover{border-color:var(--gold);color:var(--gold-soft)}

.mobile-toggle{
  display:none;background:transparent;color:var(--black);
  border:1px solid #e5e5e5;border-radius:12px;
  padding:8px 12px;font-size:22px;cursor:pointer;
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  background:linear-gradient(135deg,#08080a 0%,#1b1b22 58%,#08080a 100%);
  color:white;padding:78px 0 64px;
  position:relative;overflow:hidden;
}
.hero:after{
  content:"";position:absolute;
  width:520px;height:520px;right:-160px;top:-190px;
  background:radial-gradient(circle,rgba(201,162,74,.26),transparent 63%);
  pointer-events:none;
}
.hero-grid{
  display:grid;grid-template-columns:1.1fr .9fr;
  gap:34px;align-items:center;
  position:relative;z-index:1;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 14px;border-radius:999px;
  background:rgba(201,162,74,.14);
  border:1px solid rgba(201,162,74,.32);
  color:var(--gold-soft);font-size:12px;font-weight:700;letter-spacing:.5px;
  margin-bottom:18px;
}
.hero h1{
  font-size:clamp(38px,6vw,68px);line-height:1.04;
  letter-spacing:-1.7px;margin-bottom:18px;font-weight:800;
}
.hero h1 span{color:var(--gold-soft)}
.hero p.lead{max-width:720px;color:#d1d5db;font-size:18px;margin-bottom:28px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:32px}
.hero-stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:12px;max-width:520px;
}
.stat{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;padding:18px;
}
.stat strong{
  display:block;color:var(--gold-soft);
  font-size:30px;font-weight:800;line-height:1;margin-bottom:6px;
}
.stat span{font-size:13px;color:#cfd3da}

.hero-card{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:30px;padding:18px;
  box-shadow:0 24px 70px rgba(0,0,0,.28);
}
.mock-screen{
  height:360px;border-radius:22px;
  background:linear-gradient(135deg,#1c1c22,#08080a);
  border:1px solid rgba(255,255,255,.08);
  display:grid;place-items:center;color:#888;
  text-align:center;padding:24px;
  position:relative;overflow:hidden;
}
.mock-screen:before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 30% 30%,rgba(201,162,74,.18),transparent 60%);
}
.mock-screen .mock-content{position:relative;z-index:1;color:var(--gold-soft);font-weight:800;font-size:18px;letter-spacing:1px}

.page-hero{
  background:linear-gradient(135deg,#08080a,#1b1b22);
  color:white;padding:76px 0 56px;
  position:relative;overflow:hidden;
}
.page-hero:after{
  content:"";position:absolute;
  width:440px;height:440px;right:-130px;top:-150px;
  background:radial-gradient(circle,rgba(201,162,74,.25),transparent 62%);
  pointer-events:none;
}
.breadcrumb{font-size:13px;color:var(--gold-soft);margin-bottom:14px;position:relative;z-index:1}
.breadcrumb a{color:var(--gold-soft);text-decoration:none;transition:.15s}
.breadcrumb a:hover{color:var(--white);text-decoration:underline;text-underline-offset:3px}
.page-hero h1{
  font-size:clamp(36px,5vw,62px);line-height:1.08;
  letter-spacing:-1.4px;margin-bottom:16px;
  position:relative;z-index:1;font-weight:800;
}
.page-hero p{max-width:780px;color:#d1d5db;font-size:18px;position:relative;z-index:1}

/* ============================================================
   SECTIONS / GRIDS
   ============================================================ */
section{padding:64px 0}
.section-head{
  display:flex;justify-content:space-between;
  gap:24px;align-items:flex-end;
  margin-bottom:28px;flex-wrap:wrap;
}
.section-head h2{
  font-size:clamp(28px,4vw,44px);line-height:1.15;
  letter-spacing:-.8px;font-weight:800;
}
.section-head p{color:#555;max-width:580px}

.dark-section{background:#111;color:white}
.dark-section .section-head p{color:#d1d5db}

.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.grid-6{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}

/* ============================================================
   CARDS — CATEGORY
   ============================================================ */
.category-card{
  background:#111;color:white;
  border-radius:22px;padding:28px;min-height:200px;
  display:flex;flex-direction:column;justify-content:space-between;
  box-shadow:var(--shadow);
  overflow:hidden;position:relative;
  transition:.25s;
}
.category-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.category-card:after{
  content:"";position:absolute;right:-45px;top:-45px;
  width:140px;height:140px;border-radius:50%;
  background:rgba(201,162,74,.18);
}
.category-card .cat-icon{
  width:54px;height:54px;border-radius:16px;
  background:rgba(201,162,74,.18);border:1px solid rgba(201,162,74,.3);
  display:grid;place-items:center;font-size:26px;color:var(--gold-soft);
  position:relative;z-index:1;margin-bottom:14px;
}
.category-card h3{font-size:22px;margin-bottom:8px;position:relative;z-index:1}
.category-card p{font-size:14px;color:#d1d5db;position:relative;z-index:1;margin-bottom:14px}
.category-card ul{list-style:none;display:grid;gap:6px;font-size:13px;color:#cbd5e1;margin-bottom:16px;position:relative;z-index:1}
.category-card ul li:before{content:"•";color:var(--gold);margin-right:8px}
.category-card .link-arrow{color:var(--gold-soft);font-weight:700;font-size:13px;position:relative;z-index:1}

/* ============================================================
   BRAND STRIP
   ============================================================ */
.brand-strip{padding:50px 0;background:#0e0e12;color:white}
.brand-strip h3{
  text-align:center;font-size:14px;
  color:var(--gold-soft);letter-spacing:2px;
  text-transform:uppercase;margin-bottom:24px;
}
.brand-boxes{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.brand-box{
  height:80px;border-radius:16px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  display:grid;place-items:center;
  font-weight:900;color:var(--gold-soft);
  font-size:14px;letter-spacing:1px;
  transition:.25s;cursor:pointer;
}
.brand-box:hover{background:rgba(201,162,74,.1);border-color:rgba(201,162,74,.3);transform:translateY(-3px)}

/* ============================================================
   PRODUCT CARD
   ============================================================ */
.product-card{
  background:white;border-radius:24px;overflow:hidden;
  border:1px solid var(--line);
  box-shadow:0 12px 34px rgba(0,0,0,.07);
  transition:.25s;display:flex;flex-direction:column;
}
.product-card:hover{transform:translateY(-5px);box-shadow:0 22px 48px rgba(0,0,0,.12)}
.product-img{
  height:210px;
  background:linear-gradient(135deg,#f8f8f8,#e6e6e6);
  display:grid;place-items:center;
  color:#777;font-weight:800;text-align:center;padding:18px;
  position:relative;overflow:hidden;
}
.product-img img{width:100%;height:100%;object-fit:cover}
.product-body{padding:20px;display:flex;flex-direction:column;flex:1}
.badge-row{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:10px}
.badge{
  display:inline-block;
  background:rgba(201,162,74,.16);color:#8a6412;
  font-size:11px;font-weight:900;
  padding:5px 9px;border-radius:999px;
  text-transform:uppercase;letter-spacing:.5px;
}
.badge.dark{background:#111;color:var(--gold-soft)}
.badge.green{background:rgba(34,197,94,.15);color:#0a7a38}
.badge.red{background:rgba(239,68,68,.14);color:#b91c1c}
.product-body h3{font-size:19px;line-height:1.25;margin-bottom:8px}
.product-body > p{font-size:14px;color:#666;margin-bottom:14px}
.specs{display:flex;gap:7px;flex-wrap:wrap;margin:auto 0 18px}
.specs span{
  background:#f2f2f2;color:#555;
  border-radius:999px;font-size:12px;padding:6px 9px;
}
.product-meta{
  display:flex;gap:8px;flex-wrap:wrap;
  font-size:12px;color:#777;margin-bottom:10px;
}
.product-meta span{padding:3px 8px;background:#f5f5f5;border-radius:999px}
.card-actions{display:flex;gap:8px}
.card-actions .btn{padding:10px 14px;font-size:13px;flex:1}
.link-gold{color:var(--gold-bright);font-weight:700;font-size:14px}
.link-gold:hover{color:var(--gold)}
.product-price{font-weight:900;color:#8a6412;font-size:16px;margin-bottom:10px}

/* ============================================================
   SOLUTION CARDS
   ============================================================ */
.solution-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.solution-card{
  min-height:300px;border-radius:28px;overflow:hidden;
  position:relative;color:white;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:24px;box-shadow:var(--shadow);
  background:linear-gradient(180deg,rgba(0,0,0,.08),rgba(0,0,0,.82)),linear-gradient(135deg,#24242c,#08080a);
  transition:.25s;
}
.solution-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.solution-card:after{
  content:"";position:absolute;right:-45px;top:-45px;
  width:150px;height:150px;border-radius:50%;
  background:rgba(201,162,74,.16);
}
.solution-icon{
  width:58px;height:58px;border-radius:18px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16);
  display:grid;place-items:center;font-size:26px;
  margin-bottom:auto;color:var(--gold-soft);
  position:relative;z-index:1;
}
.solution-card h3{
  font-size:25px;line-height:1.18;margin-bottom:8px;
  position:relative;z-index:1;color:white;
}
.solution-card p{font-size:14px;color:#d1d5db;margin-bottom:16px;position:relative;z-index:1}
.solution-tags{display:flex;gap:7px;flex-wrap:wrap;position:relative;z-index:1}
.solution-tags span{
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.12);
  border-radius:999px;padding:6px 9px;font-size:12px;color:var(--gold-soft);
}

/* Process steps */
.process{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.process-step{
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);
  border-radius:22px;padding:22px;min-height:150px;
}
.process-step strong{
  display:block;color:var(--gold-soft);
  font-size:28px;line-height:1;margin-bottom:12px;font-weight:800;
}
.process-step h3{font-size:18px;margin-bottom:6px;color:white}
.process-step p{font-size:13px;color:#cfd3da}

/* ============================================================
   WHY CHOOSE / FEATURE CARDS
   ============================================================ */
.why-card,.feature-card{
  background:white;border-radius:22px;padding:24px;
  box-shadow:0 12px 34px rgba(0,0,0,.07);
  border:1px solid var(--line);
}
.why-icon,.feature-icon{
  width:52px;height:52px;border-radius:16px;
  background:#111;color:var(--gold-soft);
  display:grid;place-items:center;font-size:22px;margin-bottom:16px;
}
.why-card h3,.feature-card h3{font-size:19px;margin-bottom:8px}
.why-card p,.feature-card p{font-size:14px;color:#666}

/* ============================================================
   CTA BAND
   ============================================================ */
.cta{
  background:linear-gradient(135deg,#111,#24242c);
  color:white;border-radius:34px;padding:42px;
  display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;
  box-shadow:var(--shadow);
}
.cta h2{
  font-size:clamp(28px,4vw,42px);line-height:1.16;
  margin-bottom:8px;color:white;
}
.cta p{color:#d1d5db}
.cta-actions{display:flex;gap:10px;flex-wrap:wrap}

/* ============================================================
   CONTACT FORM
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:24px;align-items:start}
.info-panel{
  background:#111;color:white;border-radius:32px;padding:34px;
  box-shadow:var(--shadow);position:sticky;top:100px;
}
.info-panel h2{
  font-size:34px;line-height:1.1;
  color:var(--gold-soft);margin-bottom:14px;
}
.info-panel p{color:#d1d5db;margin-bottom:18px}
.info-list{display:grid;gap:12px;margin:22px 0}
.info-item{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;padding:16px;
}
.info-item strong{display:block;color:white;margin-bottom:4px}
.info-item span{color:#d1d5db;font-size:14px}

.form-panel{
  background:white;border-radius:32px;padding:32px;
  box-shadow:var(--shadow);border:1px solid var(--line);
}
.form-panel h2{font-size:34px;line-height:1.15;margin-bottom:8px}
.form-panel > p{color:#666;margin-bottom:22px}

.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
input,select,textarea{
  width:100%;border:1px solid #ddd;border-radius:14px;
  padding:13px 14px;font-size:14px;margin-bottom:12px;
  font-family:inherit;outline:none;background:white;color:var(--black);
}
input:focus,select:focus,textarea:focus{border-color:var(--gold)}
textarea{min-height:130px;resize:vertical}
.form-note{font-size:13px;color:#777;margin:10px 0 0}

/* ============================================================
   FILTER SIDEBAR (products page)
   ============================================================ */
.layout{display:grid;grid-template-columns:290px 1fr;gap:24px;align-items:start}
.sidebar{
  position:sticky;top:96px;
  background:white;border-radius:var(--radius);padding:22px;
  box-shadow:var(--shadow);border:1px solid var(--line);
}
.filter-title{font-size:20px;margin-bottom:16px}
.filter-group{
  border-top:1px solid var(--line);
  padding-top:18px;margin-top:18px;
}
.filter-group h3{font-size:15px;margin-bottom:12px}
.check{
  display:flex;align-items:center;gap:9px;
  margin:10px 0;color:#444;font-size:14px;cursor:pointer;
}
.check input{accent-color:var(--gold)}

.content-head{
  display:flex;justify-content:space-between;
  gap:16px;align-items:center;
  margin-bottom:18px;flex-wrap:wrap;
}
.content-head h2{font-size:32px;line-height:1.2}
.tools{display:flex;gap:10px;flex-wrap:wrap}
.search,.sort{
  border:1px solid var(--line);background:white;
  border-radius:999px;padding:12px 16px;font-size:14px;
  outline:none;min-width:220px;margin-bottom:0;
}
.sort{min-width:160px}

.quick-tabs{margin-top:-28px;position:relative;z-index:5}
.tab-box{
  background:white;border-radius:24px;padding:16px;
  box-shadow:var(--shadow);
  display:grid;grid-template-columns:repeat(6,1fr);gap:10px;
}
.tab-btn{
  border:1px solid var(--line);background:#fff;
  border-radius:16px;padding:13px 10px;
  font-weight:800;cursor:pointer;transition:.2s;color:#333;
  font-family:inherit;font-size:14px;
}
.tab-btn:hover,.tab-btn.active{
  background:var(--black);color:var(--gold-soft);
  border-color:var(--black);
}

/* ============================================================
   PRODUCT DETAIL
   ============================================================ */
.breadcrumb-wrap{background:#111;color:#d1d5db;padding:18px 0;font-size:13px}
.breadcrumb-wrap a{color:var(--gold-soft)}
.breadcrumb-wrap a:hover{color:white}

.product-hero{
  background:linear-gradient(180deg,#15151b,#0b0b0d);
  color:white;padding:54px 0 70px;
}
.product-detail-grid{
  display:grid;grid-template-columns:.95fr 1.05fr;gap:38px;align-items:start;
}
.gallery{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:32px;padding:18px;
  box-shadow:0 22px 60px rgba(0,0,0,.24);
}
.main-image{
  height:460px;border-radius:24px;
  background:linear-gradient(135deg,#f8f8f8,#dddddd);
  display:grid;place-items:center;
  color:#555;font-weight:900;text-align:center;
  font-size:24px;padding:26px;overflow:hidden;
}
.main-image img,.main-image iframe{width:100%;height:100%;object-fit:cover;border-radius:18px;border:0}
.thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:12px}
.thumb{
  height:84px;border-radius:16px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.12);
  display:grid;place-items:center;
  color:#ddd;font-size:11px;cursor:pointer;
  overflow:hidden;
}
.thumb img{width:100%;height:100%;object-fit:cover}
.thumb.active{border-color:var(--gold);color:var(--gold-soft)}
.thumb.youtube{background:linear-gradient(135deg,#7f1d1d,#dc2626)}
.thumb.three60{background:linear-gradient(135deg,#1e3a8a,#3b82f6)}

.product-info .badge-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.product-info .badge{
  background:rgba(201,162,74,.16);color:var(--gold-soft);
  border:1px solid rgba(201,162,74,.25);
  font-size:12px;padding:6px 10px;
}
.product-info h1{
  font-size:clamp(34px,5vw,58px);line-height:1.05;
  letter-spacing:-1.3px;margin-bottom:16px;font-weight:800;
}
.lead{font-size:18px;color:#d1d5db;margin-bottom:24px;max-width:680px}

.key-specs{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:24px}
.key-spec{
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;padding:16px;
}
.key-spec strong{
  display:block;color:var(--gold-soft);
  font-size:18px;line-height:1.1;margin-bottom:4px;
}
.key-spec span{font-size:13px;color:#d1d5db}

.quote-box{
  background:white;color:#111;
  border-radius:26px;padding:22px;
  box-shadow:var(--shadow);margin-top:16px;
}
.quote-head{
  display:flex;justify-content:space-between;
  gap:14px;align-items:center;
  margin-bottom:16px;flex-wrap:wrap;
}
.quote-head h2{font-size:22px}
.price{font-size:20px;color:#8a6412;font-weight:900}
.quote-actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.quote-actions .btn{flex:1}
.trust-list{
  display:grid;grid-template-columns:repeat(2,1fr);gap:8px;
  color:#444;font-size:14px;
}
.trust-list span:before{content:'\2713';color:#0a7a38;font-weight:900;margin-right:7px}

.tabs-wrap{margin-top:-38px;position:relative;z-index:5}
.tabs{
  background:white;border-radius:24px;padding:12px;
  box-shadow:var(--shadow);
  display:flex;gap:8px;overflow:auto;
}
.tabs .tab-btn{
  border-radius:999px;padding:11px 18px;
  white-space:nowrap;color:#333;
}

.content-card{
  background:white;border-radius:var(--radius);padding:30px;
  box-shadow:0 12px 34px rgba(0,0,0,.07);
  border:1px solid var(--line);
}
.tab-panel{display:none}
.tab-panel.active{display:block}
.tab-panel h3{font-size:24px;margin-bottom:12px}
.tab-panel p{color:#555;margin-bottom:16px}
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:22px}
.feature{
  background:#f7f7f7;border-radius:18px;padding:18px;
  border:1px solid var(--line);
}
.feature strong{display:block;margin-bottom:6px}
.feature p{font-size:14px;margin:0}

.spec-table{
  width:100%;border-collapse:collapse;
  border-radius:18px;font-size:14px;overflow:hidden;
}
.spec-table tr{border-bottom:1px solid #eee}
.spec-table th,.spec-table td{
  text-align:left;padding:14px 16px;vertical-align:top;
}
.spec-table th{width:32%;background:#f7f7f7;color:#333;font-weight:600}

.download-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.download-card{
  background:#f7f7f7;border:1px solid var(--line);
  border-radius:18px;padding:20px;
}
.download-card h4{font-size:18px;margin-bottom:8px}
.download-card p{font-size:14px;color:#666;margin-bottom:14px}

.system-flow{
  background:#111;color:white;
  border-radius:30px;padding:34px;
  box-shadow:var(--shadow);
}
.system-flow h2{color:white;margin-bottom:8px}
.system-flow > p{color:#d1d5db;margin-bottom:0}
.flow-line{
  display:grid;grid-template-columns:repeat(6,1fr);
  gap:10px;margin-top:22px;
}
.flow-item{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;padding:16px;text-align:center;
  color:#d1d5db;font-size:13px;
}
.flow-item strong{display:block;color:var(--gold-soft);margin-bottom:4px;font-size:14px}

/* ============================================================
   BRANDS PAGE
   ============================================================ */
.brand-tools{margin-top:-30px;position:relative;z-index:5}
.tools-box{
  background:white;border-radius:24px;padding:16px;
  box-shadow:var(--shadow);
  display:flex;gap:12px;align-items:center;flex-wrap:wrap;
}
.tools-box .search{flex:1;min-width:250px;margin:0}
.chip{
  border:1px solid var(--line);background:#fff;
  border-radius:999px;padding:11px 16px;
  font-weight:800;cursor:pointer;transition:.2s;color:#333;
  font-family:inherit;font-size:13px;
}
.chip.active,.chip:hover{
  background:#111;color:var(--gold-soft);border-color:#111;
}

.brand-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.brand-card{
  background:white;border-radius:28px;overflow:hidden;
  border:1px solid var(--line);
  box-shadow:0 12px 34px rgba(0,0,0,.07);
  transition:.25s;display:flex;flex-direction:column;min-height:330px;
}
.brand-card:hover{transform:translateY(-5px);box-shadow:0 22px 48px rgba(0,0,0,.12)}
.brand-logo{
  height:150px;
  background:linear-gradient(135deg,#111,#262632);
  color:var(--gold-soft);
  display:grid;place-items:center;
  font-size:30px;font-weight:900;letter-spacing:1px;
  position:relative;overflow:hidden;
}
.brand-logo img{max-width:60%;max-height:60%;object-fit:contain;filter:brightness(1.05)}
.brand-logo:after{
  content:"";position:absolute;right:-45px;top:-45px;
  width:145px;height:145px;border-radius:50%;
  background:rgba(201,162,74,.16);
}
.brand-body{padding:22px;display:flex;flex-direction:column;flex:1}
.brand-body h3{font-size:24px;margin-bottom:8px}
.brand-body p{font-size:14px;color:#666;margin-bottom:16px}
.brand-cats{display:flex;gap:7px;flex-wrap:wrap;margin:auto 0 18px}
.brand-cats span{
  background:#f2f2f2;color:#555;
  border-radius:999px;font-size:12px;padding:6px 9px;
}

/* ============================================================
   FAQ / CONTACT EXTRAS
   ============================================================ */
.contact-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.contact-card{
  background:white;border-radius:22px;padding:24px;
  box-shadow:0 12px 34px rgba(0,0,0,.07);
  border:1px solid var(--line);
}
.contact-icon{
  width:52px;height:52px;border-radius:16px;
  background:#111;color:var(--gold-soft);
  display:grid;place-items:center;font-size:22px;margin-bottom:16px;
}
.contact-card h3{font-size:19px;margin-bottom:8px}
.contact-card p{font-size:14px;color:#666}

.map-box{
  background:linear-gradient(135deg,#e8e8e8,#fafafa);
  border:1px solid var(--line);border-radius:32px;
  min-height:360px;box-shadow:var(--shadow);
  display:grid;place-items:center;text-align:center;
  padding:30px;color:#555;
  position:relative;overflow:hidden;
}
.map-box:before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(90deg,rgba(0,0,0,.03) 1px,transparent 1px),
    linear-gradient(0deg,rgba(0,0,0,.03) 1px,transparent 1px);
  background-size:36px 36px;
}
.map-content{
  position:relative;z-index:1;background:white;
  border-radius:24px;padding:24px;
  box-shadow:0 10px 30px rgba(0,0,0,.08);max-width:520px;
}
.map-pin{
  width:58px;height:58px;border-radius:50%;
  background:var(--gold);color:#111;
  display:grid;place-items:center;
  margin:0 auto 14px;font-size:26px;font-weight:900;
}

.faq-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.faq-card{
  background:white;border-radius:22px;padding:24px;
  box-shadow:0 12px 34px rgba(0,0,0,.07);
  border:1px solid var(--line);
}
.faq-card h3{font-size:20px;margin-bottom:8px}
.faq-card p{color:#666;font-size:14px}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{
  background:#050506;color:#d1d5db;
  padding:44px 0 24px;margin-top:20px;
}
.footer-grid{
  display:grid;grid-template-columns:1.4fr repeat(3,1fr);
  gap:28px;margin-bottom:30px;
}
.site-footer h4{color:white;margin-bottom:12px;font-size:15px}
.site-footer ul{list-style:none;display:grid;gap:8px;font-size:14px;padding:0}
.site-footer a:hover{color:var(--gold-soft)}
.site-footer .footer-tagline{color:#9ca3af;font-size:14px;margin-bottom:16px;max-width:380px}
.footer-social{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}
.footer-social a{
  display:inline-flex;align-items:center;
  padding:8px 14px;border-radius:999px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  color:#d1d5db;font-size:13px;transition:.2s;
}
.footer-social a:hover{
  border-color:var(--gold);color:var(--gold-soft);
  background:rgba(201,162,74,.08);
}
.footer-nap{font-size:13px;color:#9ca3af;line-height:1.7}
.footer-nap p{margin:0}
.footer-nap a{color:#d1d5db}
.copyright{
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:20px;font-size:13px;color:#9ca3af;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
}

/* Floating social FAB stack — bottom-right */
.floating-social{
  position:fixed;right:20px;bottom:20px;z-index:998;
  display:flex;flex-direction:column;gap:10px;align-items:flex-end;
}
.fs-btn{
  position:relative;
  width:52px;height:52px;border-radius:50%;
  display:grid;place-items:center;
  color:#fff;text-decoration:none;
  box-shadow:0 4px 10px rgba(0,0,0,.12);
  transition:transform .22s cubic-bezier(.34,1.56,.64,1), background-color .2s;
}
.fs-btn:hover{transform:scale(1.08) translateX(-2px)}
.fs-btn svg{width:26px;height:26px;display:block}

/* Tooltip label that slides in from the right on hover */
.fs-btn::after{
  content:attr(data-label);
  position:absolute;right:calc(100% + 12px);top:50%;transform:translate(8px,-50%);
  background:#0a0a0c;color:#fff;
  padding:6px 12px;border-radius:8px;
  font-size:12px;font-weight:700;letter-spacing:.3px;
  white-space:nowrap;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .2s, transform .25s, visibility .2s;
  box-shadow:0 6px 18px rgba(0,0,0,.2);
}
.fs-btn::after{
  /* arrow pointing right toward the button */
}
.fs-btn:hover::after{opacity:1;visibility:visible;transform:translate(0,-50%)}

/* Brand colors */
.fs-line{background:#06c755}
.fs-facebook{background:#1877f2}
.fs-whatsapp{background:#25d366}
.fs-wechat{background:#07c160}

/* (Removed glow/pulse — kept buttons clean & solid) */

@media(max-width:640px){
  .floating-social{right:14px;bottom:14px;gap:8px}
  .fs-btn{width:46px;height:46px}
  .fs-btn svg{width:22px;height:22px}
  .fs-btn::after{display:none}
}

/* ============================================================
   FORMS / FLASH
   ============================================================ */
.flash-msg{
  background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.3);
  color:#0a7a38;border-radius:14px;padding:14px 18px;
  margin-bottom:22px;font-weight:600;
}
.flash-msg.error{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.3);color:#b91c1c}

.empty-state{
  background:white;border:1px dashed var(--line);
  border-radius:24px;padding:60px 30px;text-align:center;
  color:#777;
}
.empty-state h3{font-size:22px;margin-bottom:10px;color:#333}

/* ============================================================
   MOBILE NAV (off-canvas)
   ============================================================ */
.mob-nav{
  display:none;position:fixed;top:0;left:0;right:0;bottom:0;
  background:rgba(11,11,13,.98);backdrop-filter:blur(14px);
  z-index:1100;padding:90px 24px 40px;
  overflow-y:auto;
}
.mob-nav.open{display:block}
.mob-nav a{
  display:block;padding:14px 18px;
  border-radius:14px;color:#e5e7eb;font-size:16px;
  border:1px solid rgba(255,255,255,.08);margin-bottom:8px;
}
.mob-nav a:hover{background:rgba(201,162,74,.12);color:var(--gold-soft)}
.mob-nav .mob-sep{
  font-size:11px;text-transform:uppercase;letter-spacing:2px;
  color:var(--gold-soft);padding:18px 8px 8px;
  border:0;margin-bottom:0;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1060px){
  .menu{display:none}
  .mobile-toggle{display:block}
  .topbar-tag{display:none}
  .topbar-inner{justify-content:flex-end}
  .topbar-contact{flex-wrap:wrap;justify-content:flex-end}
  .hero-grid,.contact-grid,.cta,.product-detail-grid{grid-template-columns:1fr}
  .info-panel,.sidebar{position:static}
  .solution-grid,.grid-3{grid-template-columns:repeat(2,1fr)}
  .grid-4,.contact-cards,.brand-grid{grid-template-columns:repeat(2,1fr)}
  .grid-6,.brand-boxes{grid-template-columns:repeat(3,1fr)}
  .process,.flow-line{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .layout{grid-template-columns:1fr}
  .tab-box{grid-template-columns:repeat(3,1fr)}
  .section-head{display:block}
  .section-head p{margin-top:8px}
}
@media(max-width:640px){
  .container{width:min(100% - 28px,var(--container))}
  .hero,.page-hero{padding:52px 0 42px}
  .hero-stats,.form-row,.grid-3,.grid-4,.solution-grid,.brand-grid,
  .contact-cards,.faq-grid,.footer-grid,.feature-grid,.download-grid,
  .related-grid,.flow-line,.brand-boxes,.tab-box,.key-specs,
  .trust-list,.process,.product-grid{grid-template-columns:1fr}
  .cta{padding:28px}
  .cta-actions,.hero-actions,.card-actions,.quote-actions{flex-direction:column}
  .topbar-inner{flex-direction:column;align-items:flex-start;gap:6px}
  .topbar-contact{justify-content:flex-start;gap:0;flex-wrap:wrap}
  .topbar-contact .tb-item{padding:4px 8px;font-size:11.5px}
  .topbar-contact .tb-item span:not(.tb-caret){display:none}
  .topbar-contact .tb-item[href^="tel"] span,
  .tb-lang .tb-item span{display:inline}
  .product-img,.main-image{height:280px}
  .form-panel,.info-panel{padding:24px}
}

/* ============================================================
   v6.1 — Products page additions (matching mockup #4 / #8)
   ============================================================ */

/* Category navigation strip across products page */
.cat-nav-strip{
  display:grid;grid-template-columns:repeat(9,1fr);gap:8px;
  background:white;border-radius:20px;padding:14px;
  box-shadow:var(--shadow);
}
.cat-nav-item{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  padding:14px 8px;border-radius:14px;
  border:1px solid transparent;background:transparent;
  text-align:center;transition:.2s;cursor:pointer;
}
.cat-nav-item:hover{background:#f7f2e8;border-color:rgba(201,162,74,.3)}
.cat-nav-item.active{
  background:var(--black);color:var(--gold-soft);
  border-color:var(--black);
}
.cat-nav-icon{
  font-size:24px;color:var(--gold);
  width:42px;height:42px;display:grid;place-items:center;
  background:rgba(201,162,74,.12);border-radius:12px;
}
.cat-nav-item.active .cat-nav-icon{background:rgba(201,162,74,.22);color:var(--gold-soft)}
.cat-nav-label{
  font-size:10px;font-weight:800;letter-spacing:.5px;
  line-height:1.2;color:#333;
}
.cat-nav-item.active .cat-nav-label{color:var(--gold-soft)}

/* Sidebar category list */
.cat-list{list-style:none;padding:0;margin:0 0 8px;display:grid;gap:2px}
.cat-list li{margin:0}
.cat-list a{
  display:flex;justify-content:space-between;align-items:center;
  padding:11px 14px;border-radius:12px;
  font-size:14px;font-weight:600;color:#333;
  border:1px solid transparent;transition:.2s;
}
.cat-list a:hover{background:#f7f2e8;border-color:rgba(201,162,74,.3)}
.cat-list a.active{background:var(--black);color:var(--gold-soft);border-color:var(--black)}
.cat-list a span{font-size:13px;opacity:.6}

/* Filter checkbox layout — aligned like mockup */
.sidebar .filter-group{
  border-top:1px solid #e8e4d8;
  padding-top:18px;margin-top:18px;
}
.sidebar .filter-group h3{
  font-size:13px;font-weight:800;letter-spacing:.6px;
  color:#333;margin-bottom:14px;text-transform:uppercase;
}
.sidebar .check{
  display:grid;grid-template-columns:20px 1fr auto;align-items:center;gap:12px;
  margin:8px 0;color:#444;font-size:14px;cursor:pointer;
  padding:6px 8px;border-radius:8px;
  transition:.15s;line-height:1.3;
}
.sidebar .check:hover{background:#f7f2e8}
/* Custom round checkbox (replaces native square) */
.sidebar .check input[type="checkbox"],
.sidebar .check input[type="radio"]{
  -webkit-appearance:none;-moz-appearance:none;appearance:none;
  width:18px;height:18px;
  border:1.5px solid #c8c2b0;border-radius:50%;
  background:#fff;cursor:pointer;
  margin:0;padding:0;
  position:relative;flex-shrink:0;
  align-self:center;justify-self:center;
  transition:.15s;
  outline:none;
}
.sidebar .check input[type="checkbox"]:hover,
.sidebar .check input[type="radio"]:hover{border-color:var(--gold)}
.sidebar .check input[type="checkbox"]:checked,
.sidebar .check input[type="radio"]:checked{
  background:var(--gold);border-color:var(--gold);
}
.sidebar .check input[type="checkbox"]:checked::after{
  content:"";position:absolute;
  left:50%;top:48%;
  width:5px;height:9px;
  border:solid #fff;border-width:0 2px 2px 0;
  transform:translate(-50%,-55%) rotate(45deg);
}
.sidebar .check input[type="radio"]:checked::after{
  content:"";position:absolute;
  left:50%;top:50%;
  width:7px;height:7px;border-radius:50%;
  background:#fff;transform:translate(-50%,-50%);
}
.sidebar .check input[type="checkbox"]:focus-visible,
.sidebar .check input[type="radio"]:focus-visible{
  box-shadow:0 0 0 3px rgba(201,162,74,.25);
}
.sidebar .check-label{font-weight:500;line-height:1.3;align-self:center}
.sidebar .check-count{font-size:13px;color:#999;align-self:center}
/* "All" header option above the brand list */
.sidebar .check.check-all{
  background:#fbf7ec;border:1px solid #ece1c6;
  margin-bottom:8px;
}
.sidebar .check.check-all .check-label{font-weight:700;color:#1a1a1d;letter-spacing:.3px}
.sidebar .check.check-all .check-count{color:#7a5a14;font-weight:600}
.sidebar .show-more{
  display:inline-block;padding:4px 0;
  font-size:13px;color:var(--gold-bright);font-weight:700;
}
.sidebar input[type="range"]{
  width:100%;accent-color:var(--gold);
  height:6px;background:#e8e4d8;border-radius:999px;
}

/* Product card v6.1 — matching mockup with logo + bullets + bottom price + actions */
.product-card{position:relative}
.card-corner-badge{
  position:absolute;top:14px;right:14px;z-index:3;
  background:var(--gold);color:var(--black);
  font-size:10px;font-weight:900;letter-spacing:.6px;
  padding:5px 10px;border-radius:999px;
  text-transform:uppercase;
  box-shadow:0 6px 16px rgba(201,162,74,.35);
}
.card-corner-badge.new{background:#0a7a38;color:white}
.product-img{
  height:200px;background:#fff;
  border-bottom:1px solid #f0ede4;
}
.product-img img{
  width:100%;height:100%;object-fit:contain;padding:20px;
  mix-blend-mode:multiply;
}
.brand-logo-placeholder{
  font-family:'Prompt',sans-serif;
  font-weight:900;font-size:22px;letter-spacing:1px;
  color:#999;
}
.product-brand{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  font-size:11px;font-weight:800;letter-spacing:1px;
  color:var(--gold-bright);text-transform:uppercase;
  margin-bottom:6px;
}
.product-brand .pb-brand{color:var(--gold-bright);flex-shrink:0}
.product-brand .pb-sku{
  margin-left:auto;
  color:#888;font-weight:700;font-size:10.5px;letter-spacing:.6px;
  font-family:'Roboto Mono','Courier New',monospace;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:55%;
}
.product-card h3{
  font-size:18px;line-height:1.25;margin-bottom:6px;
  color:var(--black);font-weight:700;
}
.product-meta{
  font-size:12px;color:#777;margin-bottom:10px;
}
.product-meta span{
  background:#f5f0e2;color:#8a6412;
  padding:3px 8px;border-radius:999px;
}
.product-bullets{
  list-style:none;padding:0;margin:0 0 12px;
  display:grid;gap:4px;font-size:13px;color:#555;
}
.product-bullets li{position:relative;padding-left:14px}
.product-bullets li:before{
  content:"•";position:absolute;left:0;
  color:var(--gold);font-weight:900;
}
.product-price{
  font-size:18px;font-weight:900;color:var(--black);
  margin-bottom:14px;
}
/* Promotion price — original (struck-through black) + new (green) + savings tag */
.product-price.has-sale{
  display:flex;align-items:baseline;flex-wrap:wrap;gap:8px;
  margin-bottom:14px;
}
.product-price.has-sale .price-old{
  font-size:14px;font-weight:700;color:#1a1a1d;
  text-decoration:line-through;text-decoration-thickness:2px;
  text-decoration-color:rgba(192,57,43,.7);
  letter-spacing:.2px;
}
.product-price.has-sale .price-new{
  font-size:20px;font-weight:900;color:#0a8a3a;
  letter-spacing:-.3px;
}
.product-price.has-sale .price-save{
  font-size:11px;font-weight:800;letter-spacing:.6px;
  color:#fff;background:#0a8a3a;
  padding:3px 8px;border-radius:4px;
}
.product-price.quote-only{
  font-size:13px;color:#8a6412;
  background:#f7f2e8;padding:6px 10px;border-radius:8px;
  display:inline-block;
}
.card-actions{
  display:flex;gap:6px;align-items:center;
  border-top:1px solid #f0ede4;padding-top:12px;margin-top:auto;
}
.btn-icon{
  width:38px;height:38px;
  display:grid;place-items:center;
  background:#f7f2e8;color:#8a6412;
  border-radius:10px;font-size:14px;
  border:1px solid #e8d9b8;
  transition:.2s;text-decoration:none;
}
.btn-icon:hover{background:var(--gold);color:white}
.card-actions .btn-dark,
.card-actions .btn-gold{flex:1;font-size:12.5px;padding:10px 14px;text-align:center;justify-content:center;white-space:nowrap}

/* Pagination */
.pagination{
  display:flex;justify-content:center;gap:8px;
  margin:32px 0 0;flex-wrap:wrap;
}
.page-btn{
  min-width:40px;height:40px;
  display:grid;place-items:center;
  border-radius:10px;font-weight:700;
  background:white;color:#333;
  border:1px solid #e8e4d8;
  text-decoration:none;transition:.2s;
}
.page-btn:hover{border-color:var(--gold);color:var(--gold-bright)}
.page-btn.active{background:var(--black);color:var(--gold-soft);border-color:var(--black)}

/* Trust band at bottom of products page */
.trust-band{
  background:white;border-radius:24px;padding:28px;
  box-shadow:var(--shadow);
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
  border:1px solid #f0ede4;
}
.trust-item{
  display:flex;gap:14px;align-items:center;
}
.trust-icon{
  width:48px;height:48px;border-radius:12px;
  background:#f7f2e8;color:var(--gold-bright);
  display:grid;place-items:center;font-size:22px;
  border:1px solid #e8d9b8;flex-shrink:0;
}
.trust-item strong{display:block;font-size:14px;color:var(--black);margin-bottom:2px}
.trust-item span{font-size:12px;color:#777}

@media(max-width:1060px){
  .cat-nav-strip{grid-template-columns:repeat(5,1fr)}
  .trust-band{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  .cat-nav-strip{grid-template-columns:repeat(3,1fr);padding:10px;gap:6px}
  .cat-nav-item{padding:10px 4px}
  .cat-nav-icon{width:34px;height:34px;font-size:18px}
  .cat-nav-label{font-size:9px}
  .trust-band{grid-template-columns:1fr;padding:20px}
}

/* ============================================================
   v6.1 — Mega Menu (Products dropdown 5 columns)
   ============================================================ */
.menu .has-mega{position:static}
.mega-menu{
  position:absolute;
  top:100%;left:0;right:0;
  background:rgba(11,11,13,.98);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-top:1px solid rgba(201,162,74,.22);
  border-bottom:1px solid rgba(201,162,74,.22);
  box-shadow:0 28px 60px rgba(0,0,0,.55);
  opacity:0;visibility:hidden;
  transform:translateY(8px);
  transition:opacity .25s,transform .25s,visibility .25s;
  z-index:1000;
  padding:30px 0;
  pointer-events:none;
}
/* CLOSED state must be 100% non-interactive — no events in panel area */
.mega-menu{pointer-events:none !important}
/* JS-driven open state — explicit class avoids spurious :hover/:focus-within triggers */
.menu .has-mega.is-open > .mega-menu{
  opacity:1;visibility:visible;transform:translateY(0);
  pointer-events:auto !important;
}
/* Hover bridge — only exists/interactive when menu is open */
.menu .has-mega.is-open > .mega-menu::before{
  content:"";position:absolute;
  left:0;right:0;top:-8px;height:8px;
  background:transparent;
  pointer-events:auto;
}
.mega-inner{
  max-width:var(--container);margin:0 auto;
  padding:0 20px;
  display:grid;grid-template-columns:1.1fr 1.5fr 1fr 1fr 1fr;
  gap:32px;
}
.mega-col h4{
  color:var(--gold-bright);
  font-size:13px;font-weight:800;
  letter-spacing:.6px;
  margin-bottom:14px;
  padding-bottom:10px;
  border-bottom:1px solid rgba(201,162,74,.18);
  text-transform:uppercase;
}
.mega-col ul{list-style:none;display:grid;gap:2px;padding:0;margin:0}
.mega-col li{margin:0}
.mega-col a{
  display:block;padding:7px 8px;
  color:#e5e7eb;font-size:13.5px;font-weight:500;
  border-radius:8px;
  transition:.18s;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.mega-col a:hover{
  background:rgba(201,162,74,.12);
  color:var(--gold-soft);
  padding-left:12px;
}

@media(max-width:1100px){
  .mega-menu{display:none}
}

/* ============================================================
   v9.4 — Integrated cascade mega-menu (single panel, two columns)
   Categories on left, items on right — no gaps, no hover-loss
   ============================================================ */
.menu .has-cascade{position:relative}
.menu .has-cascade .mega-menu.mega-cascade{
  position:absolute;
  top:100%;left:0;right:auto;
  width:680px;
  padding:0 !important;
  background:#fff !important;
  border-radius:0 0 16px 16px;
  border-top:none !important;
  border-bottom:1px solid rgba(201,162,74,.3) !important;
  border-left:1px solid rgba(201,162,74,.3) !important;
  border-right:1px solid rgba(201,162,74,.3) !important;
  display:grid !important;
  grid-template-columns:240px 1fr;
  overflow:hidden;
  box-shadow:0 28px 60px rgba(0,0,0,.22) !important;
}

/* LEFT COLUMN — categories (pure white) */
.mega-cascade .mega-cats{
  list-style:none;margin:0;padding:14px 10px;
  background:#fff;
  border-right:1px solid rgba(201,162,74,.18);
}
.mega-cascade .mega-cat{margin:0}
.mega-cascade .mega-cat-link{
  display:flex !important;align-items:center;justify-content:space-between;gap:10px;
  padding:12px 14px !important;border-radius:8px;
  font-size:14px;font-weight:600;color:#1a1a1d !important;
  text-decoration:none;transition:.16s;
  white-space:normal !important;
  position:relative;
}
.mega-cascade .mega-cat-link span:first-child{flex:1;min-width:0}
.mega-cascade .mega-cat-link .cat-arr{
  color:#bdb8a8;font-size:18px;line-height:1;
  transition:transform .16s, color .16s;flex-shrink:0;
}
.mega-cascade .mega-cat.is-active .mega-cat-link,
.mega-cascade .mega-cat:hover .mega-cat-link{
  background:rgba(201,162,74,.1) !important;
  color:var(--gold) !important;
}
.mega-cascade .mega-cat.is-active .cat-arr,
.mega-cascade .mega-cat:hover .cat-arr{
  color:var(--gold);transform:translateX(3px);
}

/* RIGHT COLUMN — pure white pane area, content swaps without moving */
.mega-cascade .mega-panes{
  position:relative;background:#fff;
  min-height:340px;
}
.mega-cascade .mega-pane{
  position:absolute;inset:0;
  padding:18px 22px;
  opacity:0;visibility:hidden;
  transition:opacity .2s ease, visibility .2s ease;
  display:flex;flex-direction:column;
  pointer-events:none;
}
.mega-cascade .mega-pane.is-active{
  opacity:1;visibility:visible;pointer-events:auto;
}
.mega-cascade .mega-pane-list{
  list-style:none;margin:0;padding:0;
  display:grid;grid-template-columns:1fr;gap:1px;
  overflow-y:auto;flex:1;align-content:flex-start;
}
.mega-cascade .mega-pane-list li{margin:0}
.mega-cascade .mega-pane-list a{
  display:flex !important;align-items:center;gap:11px;
  padding:9px 12px !important;border-radius:8px;
  color:#333 !important;font-size:13.5px;font-weight:500;
  text-decoration:none;transition:.18s;
  white-space:nowrap !important;
  position:relative;
}
.mega-cascade .mega-pane-list a::before{
  content:"";width:8px;height:8px;border-radius:50%;
  background:var(--gold);
  box-shadow:0 0 0 2px rgba(201,162,74,.18);
  flex-shrink:0;transition:.18s;
}
.mega-cascade .mega-pane-list a:hover{
  background:rgba(201,162,74,.1) !important;
  color:var(--gold) !important;
}
.mega-cascade .mega-pane-list a:hover::before{
  background:var(--gold);
  box-shadow:0 0 0 4px rgba(201,162,74,.28);
  transform:scale(1.15);
}

/* Hide cascade on small screens — mobile uses .mob-nav */
@media(max-width:1100px){
  .mega-cascade{display:none}
}
@media(max-width:1280px){
  .menu .has-cascade .mega-menu.mega-cascade{
    /* Make sure narrow viewports don't push panel off-screen — anchor to right of menu */
    left:auto;right:0;
  }
}

/* Original full-width mega-menu (kept for backwards-compat if used elsewhere) */
.mega-menu{
  background:rgba(255,250,242,.98) !important;
  border-top:1px solid rgba(201,162,74,.3) !important;
  border-bottom:1px solid rgba(201,162,74,.3) !important;
  box-shadow:0 28px 60px rgba(0,0,0,.18) !important;
}
.mega-col h4{
  color:var(--gold-bright) !important;
  border-bottom-color:rgba(201,162,74,.25) !important;
}
.mega-col a{color:#333 !important}
.mega-col a:hover{
  background:rgba(201,162,74,.14) !important;
  color:var(--gold) !important;
}

/* About-style dropdown (li.dd) — also light bg */
.menu .dd{
  background:rgba(255,250,242,.98) !important;
  border:1px solid rgba(201,162,74,.3) !important;
  box-shadow:0 22px 55px rgba(0,0,0,.18) !important;
}
.menu .dd a{color:#333 !important}
.menu .dd a:hover{background:rgba(201,162,74,.14) !important;color:var(--gold) !important}
.menu .dd .dd-ico{
  background:rgba(201,162,74,.15) !important;
  border-color:rgba(201,162,74,.3) !important;
  color:var(--gold-bright) !important;
}

/* ============================================================
   v6.4 — Clean WHITE theme override (replaces cream palette)
   ============================================================ */
:root{
  --cream:#ffffff;
  --bg-soft:#f7f8fa;
  --bg-warm:#fafafa;
  --line-soft:#eef0f3;
}
body{background:#ffffff !important}

/* Page hero — keep dark, but borders softer */
.page-hero{padding:54px 0 38px}

/* Cards now sit on white background with subtle gray border */
.product-card,.why-card,.feature-card,.brand-card,.contact-card,.faq-card,
.solution-card,.category-card,.product-card,.empty-state,.sidebar,
.tools-box,.tab-box{
  background:#ffffff !important;
}
.product-img{
  background:#fff !important;
  border-bottom:1px solid #eef0f3 !important;
}
.brand-logo-placeholder{color:#c9c9c9 !important}

/* Sidebar */
.sidebar,.tools-box,.tab-box{
  background:#ffffff !important;
  border:1px solid #eef0f3 !important;
}
.sidebar .filter-group{border-top-color:#eef0f3 !important}
.sidebar .check:hover{background:#fff !important}

/* Cat-nav strip */
.cat-nav-strip{background:#ffffff !important;border:1px solid #eef0f3 !important}
.cat-nav-item:hover{background:#f7f8fa !important;border-color:#e6cf94 !important}
.cat-list a:hover{background:#f7f8fa !important;border-color:#e6cf94 !important}

/* Trust band */
.trust-band{background:#ffffff !important;border:1px solid #eef0f3 !important}

/* Section padding remains, but light cards */
.btn-icon{background:#fff !important;border-color:#eaecef !important;color:#8a6412 !important}
.btn-icon:hover{background:var(--gold) !important;color:white !important}

.product-meta span{background:#f6f7f9 !important;color:#666 !important}
.specs span{background:#f6f7f9 !important;color:#666 !important}
.product-price.quote-only{background:#fff !important}

/* ============================================================
   v6.4 — Product detail page polish (alignment fixes)
   ============================================================ */
body{background:#ffffff !important}

/* Page wrap on white */
.pd-wrap{padding:36px 0 80px;background:#ffffff}
.pd-bc{margin-bottom:28px;font-size:13px;color:#888}
.pd-bc a{color:#aa8a45}
.pd-bc .sep{margin:0 8px}

/* Gallery — keep white card, tighter shadow */
.pd-gallery{
  background:#ffffff !important;
  border:1px solid #eef0f3 !important;
  box-shadow:0 4px 18px rgba(0,0,0,.04) !important;
  padding:24px !important;
}
.pd-main{
  height:420px !important;
  background:#fff !important;
}
.pd-thumb{
  background:#fff !important;
  border:2px solid #f0f1f4 !important;
}
.pd-thumb.active{border-color:var(--gold) !important}

/* Brand tag and seller tag — repositioned */
.pd-gallery .brand-tag{
  top:32px !important;left:32px !important;
  font-size:18px !important;
  color:#1a1a1a !important;
}
.pd-gallery .seller-tag{
  top:32px !important;right:32px !important;
  background:var(--gold) !important;
  color:#1a1a1a !important;
  font-size:11px !important;
  padding:6px 12px !important;
  border-radius:6px !important;
  font-weight:900 !important;
}

/* Info column — better spacing */
.pd-info{padding-top:0 !important}
.pd-info h1{
  font-size:36px !important;
  font-weight:800 !important;
  letter-spacing:-.4px !important;
  margin-bottom:8px !important;
}
.pd-info .subtitle{
  font-size:17px !important;
  color:#666 !important;
  margin-bottom:16px !important;
}
.pd-rating-row{
  margin-bottom:16px !important;
  padding-bottom:16px !important;
  border-bottom:1px solid #eef0f3 !important;
}

/* 4-spec icons — cleaner border */
.pd-spec-grid{
  background:#ffffff !important;
  border:1px solid #eef0f3 !important;
  border-radius:14px !important;
  margin-bottom:24px !important;
}
.pd-spec{
  border-right-color:#eef0f3 !important;
  padding:18px 10px !important;
}

/* Price row */
.pd-price{
  font-size:36px !important;
  margin-bottom:4px !important;
}
.pd-vat{margin-bottom:20px !important}

/* Action buttons — equal width */
.pd-actions{margin-bottom:22px !important}
.pd-actions .btn{
  flex:1 !important;
  padding:14px 20px !important;
  font-size:14px !important;
  font-weight:700 !important;
}
.pd-actions .btn-gold{
  background:var(--gold) !important;
  color:#1a1a1a !important;
}
.pd-actions .btn-dark{
  background:#1a1a1a !important;
  color:white !important;
}

/* Trust row 4 items — tighter */
.pd-trust{
  padding-top:20px !important;
  border-top:1px solid #eef0f3 !important;
  gap:12px !important;
}
.pd-trust-item{align-items:flex-start !important;gap:8px !important}
.pd-trust-ico{
  width:30px !important;height:30px !important;
  background:#fff8eb !important;
  color:#aa8a45 !important;
  font-size:13px !important;
  flex-shrink:0 !important;
}
.pd-trust-item strong{
  font-size:12px !important;
  font-weight:700 !important;
  margin-bottom:3px !important;
  line-height:1.3 !important;
}
.pd-trust-item span{
  font-size:11px !important;
  color:#888 !important;
  line-height:1.35 !important;
}

/* Tabs */
.pd-tabs-wrap{margin-top:48px !important;border-bottom:1px solid #eef0f3 !important}
.pd-tabs button{
  padding:14px 22px !important;
  font-size:14px !important;
  font-weight:600 !important;
  color:#666 !important;
}
.pd-tabs button.active{
  color:#1a1a1a !important;
  border-bottom-color:var(--gold) !important;
}

/* Cards in tabs */
.pd-card{
  background:#ffffff !important;
  border:1px solid #eef0f3 !important;
  box-shadow:0 4px 18px rgba(0,0,0,.04) !important;
}
.pd-card h3{
  font-size:17px !important;
  font-weight:800 !important;
  letter-spacing:.4px !important;
  text-transform:uppercase !important;
  color:#1a1a1a !important;
  margin-bottom:16px !important;
  padding-bottom:12px !important;
  border-bottom:1px solid #eef0f3 !important;
}

/* Banner inside overview */
.pd-banner-img{
  background:linear-gradient(90deg,#1a1a1a,#2a2a35) !important;
  border-radius:12px !important;
}

/* Key features */
.pd-kf-ico{background:#fff8eb !important;color:#aa8a45 !important}

/* Spec table */
.pd-specs-table tr{border-bottom-color:#eef0f3 !important}
.pd-specs-table th{
  color:#666 !important;
  font-weight:600 !important;
}

/* Downloads */
.pd-dl-row .ico{background:#fff8eb !important;color:#aa8a45 !important}
.pd-dl-row:hover{background:#fff !important}

/* Video card */
.pd-video-card{
  background:#ffffff !important;
  border:1px solid #eef0f3 !important;
  box-shadow:0 4px 18px rgba(0,0,0,.04) !important;
}

/* Related products */
.pd-rel-card{
  background:#ffffff !important;
  border:1px solid #eef0f3 !important;
  box-shadow:0 4px 14px rgba(0,0,0,.04) !important;
}
.pd-rel-img{background:#fff !important}

/* Need help card stays dark — that's intentional from mockup */

/* Footer / page-hero stay dark — only main content goes white */
.page-hero{background:linear-gradient(135deg,#08080a,#1b1b22) !important}


/* ============================================================
   v6.5 — Help card moved to sidebar (under video)
   ============================================================ */
.pd-help-card-side{
  background:linear-gradient(135deg,#0b0b0d,#1c1c22);
  color:white;
  border-radius:20px;
  padding:24px;
  margin-top:18px;
  text-align:center;
  box-shadow:0 8px 28px rgba(0,0,0,.18);
}
.pd-help-side-avatar{
  width:70px;height:70px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--gold-soft));
  display:grid;place-items:center;
  font-size:32px;color:#1a1a1a;
  margin:0 auto 14px;
  box-shadow:0 6px 18px rgba(201,162,74,.35);
}
.pd-help-card-side h4{
  font-size:16px;color:var(--gold-soft);
  margin-bottom:6px;font-weight:800;
  letter-spacing:.3px;
}
.pd-help-card-side p{
  font-size:13px;color:#cfd3da;
  margin-bottom:16px;line-height:1.5;
}
.pd-help-card-side .btn-gold{background:var(--gold);color:#1a1a1a !important;padding:11px 16px;font-size:13px}
.pd-help-card-side .btn-line{background:#06c755;color:white !important;border:0;padding:11px 16px;font-size:13px}
.pd-help-card-side .btn-line:hover{background:#05a648}

/* ============================================================
   v6.11 — In-page Live Chat (functional, light theme)
   ============================================================ */
.pd-live-chat{
  position:relative;margin-top:18px;
  background:#ffffff;
  border:1px solid #ece6d4;
  border-radius:20px;padding:0;overflow:hidden;
  box-shadow:0 14px 40px rgba(0,0,0,.06), 0 0 0 1px rgba(201,162,74,.04);
  display:flex;flex-direction:column;
  flex:1 1 auto;
  min-height:420px;
}
.pd-specs-grid > div > .pd-live-chat:last-child{flex:1 1 auto}
/* Header */
.pd-lc-header{
  display:flex;align-items:center;gap:10px;
  padding:14px 16px;
  background:linear-gradient(135deg,#fff 0%,#fdfaf3 100%);
  border-bottom:1px solid #ece6d4;
  flex-shrink:0;
}
.pd-lc-avatar-mini{
  position:relative;
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--gold-soft));
  display:grid;place-items:center;
  color:#fff;font-weight:800;font-size:14px;
  flex-shrink:0;
  box-shadow:0 3px 8px rgba(201,162,74,.3);
}
.pd-lc-avatar-mini svg{width:60%;height:60%}
.pd-lc-online{
  position:absolute;right:-1px;bottom:-1px;
  width:12px;height:12px;border-radius:50%;
  background:#22c55e;border:2px solid #fff;
}
.pd-lc-header-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}
.pd-lc-header-info strong{font-size:13.5px;color:#1a1a1d;font-weight:800;letter-spacing:.2px}
.pd-lc-online-text{
  font-size:11px;color:#888;
  display:inline-flex;align-items:center;gap:5px;
}
.pd-lc-dot{
  width:7px;height:7px;border-radius:50%;background:#22c55e;
  flex-shrink:0;animation:lcPulse 2s ease-in-out infinite;
  box-shadow:0 0 0 0 rgba(34,197,94,.6);
}
@keyframes lcPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,.6)}
  50%{box-shadow:0 0 0 6px rgba(34,197,94,0)}
}
.pd-lc-badge{
  background:rgba(34,197,94,.14);color:#16a34a;
  border:1px solid rgba(34,197,94,.32);
  padding:2px 8px;border-radius:999px;
  font-size:9.5px;font-weight:800;letter-spacing:1px;
  flex-shrink:0;
}

/* Messages area — flex:1 fills available height in chat column */
.pd-lc-messages{
  flex:1 1 auto;overflow-y:auto;
  padding:14px;background:#fafafa;
  min-height:200px;
  display:flex;flex-direction:column;gap:10px;
  scroll-behavior:smooth;
}
.pd-lc-messages::-webkit-scrollbar{width:5px}
.pd-lc-messages::-webkit-scrollbar-thumb{background:rgba(201,162,74,.3);border-radius:5px}
.pd-lc-messages::-webkit-scrollbar-track{background:transparent}

.pd-lc-msg{
  display:flex;gap:8px;
  animation:lcSlideIn .28s ease-out;
  max-width:85%;
}
@keyframes lcSlideIn{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}
.pd-lc-msg-agent{align-self:flex-start}
.pd-lc-msg-user{align-self:flex-end;flex-direction:row-reverse}

.pd-lc-msg-avatar{
  width:28px;height:28px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--gold-soft));
  display:grid;place-items:center;
  color:#fff;font-size:11px;font-weight:800;
  flex-shrink:0;align-self:flex-end;
  box-shadow:0 2px 6px rgba(201,162,74,.3);
}
.pd-lc-msg-bubble{
  background:#fff;
  border:1px solid #ece6d4;
  border-radius:14px 14px 14px 4px;
  padding:10px 13px;
  box-shadow:0 2px 6px rgba(0,0,0,.04);
}
.pd-lc-msg-user .pd-lc-msg-bubble{
  background:linear-gradient(135deg,var(--gold) 0%,#d4b765 100%);
  border-color:transparent;
  border-radius:14px 14px 4px 14px;
  box-shadow:0 3px 10px rgba(201,162,74,.25);
}
.pd-lc-msg-bubble p{
  margin:0;font-size:13px;line-height:1.55;
  color:#444;font-weight:500;
  word-wrap:break-word;overflow-wrap:break-word;
}
.pd-lc-msg-user .pd-lc-msg-bubble p{color:#1a1a1d;font-weight:600}
.pd-lc-msg-bubble strong{font-weight:800;color:#1a1a1d}
.pd-lc-time{
  display:block;font-size:10px;color:#999;
  margin-top:4px;
}
.pd-lc-msg-user .pd-lc-time{color:rgba(26,26,29,.55)}

/* Typing dots */
.pd-lc-typing{padding:14px 16px;display:flex;gap:5px;align-items:center}
.pd-lc-typing span{
  width:7px;height:7px;border-radius:50%;
  background:#bbb;
  animation:lcTyping 1.2s ease-in-out infinite;
}
.pd-lc-typing span:nth-child(2){animation-delay:.2s}
.pd-lc-typing span:nth-child(3){animation-delay:.4s}
@keyframes lcTyping{
  0%,60%,100%{opacity:.3;transform:translateY(0)}
  30%{opacity:1;transform:translateY(-3px);background:var(--gold)}
}

/* Quick replies */
.pd-lc-quick{
  display:flex;flex-wrap:wrap;gap:6px;
  padding:10px 14px;
  background:#fff;border-top:1px solid #ece6d4;
  flex-shrink:0;
}
.pd-lc-quick button{
  padding:7px 12px;border-radius:999px;
  background:rgba(201,162,74,.08);
  border:1px solid rgba(201,162,74,.3);
  color:var(--gold-bright);
  font-size:11.5px;font-weight:600;cursor:pointer;
  transition:.2s;font-family:inherit;
  white-space:nowrap;
}
.pd-lc-quick button:hover{
  background:var(--gold);color:#fff;
  border-color:var(--gold);
  transform:translateY(-1px);
  box-shadow:0 3px 8px rgba(201,162,74,.3);
}

/* Input bar */
.pd-lc-input{
  display:flex;gap:8px;align-items:center;
  padding:12px 14px;
  background:#fff;border-top:1px solid #ece6d4;
  flex-shrink:0;
}
.pd-lc-input input{
  flex:1;height:40px;border-radius:999px;
  border:1px solid #ece6d4;
  padding:0 16px;font-size:13px;
  font-family:inherit;outline:none;
  background:#fafafa;transition:.2s;color:#1a1a1d;
}
.pd-lc-input input::placeholder{color:#999}
.pd-lc-input input:focus{
  border-color:var(--gold);background:#fff;
  box-shadow:0 0 0 3px rgba(201,162,74,.15);
}
.pd-lc-input button{
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),#d4b765);
  border:0;color:#1a1a1d;cursor:pointer;
  display:grid;place-items:center;
  transition:.2s;flex-shrink:0;
  box-shadow:0 3px 10px rgba(201,162,74,.3);
}
.pd-lc-input button:hover{
  transform:scale(1.06);
  box-shadow:0 5px 14px rgba(201,162,74,.45);
}
.pd-lc-input button svg{width:18px;height:18px}

/* ============================================================
   v6.11 — Related products carousel (scrollable horizontal)
   ============================================================ */
.pd-related-viewport{
  overflow:hidden;position:relative;
  margin:0 -2px;padding:6px 2px;
}
.pd-related-grid{
  display:flex !important;
  grid-template-columns:none !important;
  gap:18px;
  overflow-x:auto;
  scroll-behavior:smooth;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  padding-bottom:6px;
}
.pd-related-grid::-webkit-scrollbar{display:none}
.pd-related-grid > .pd-rel-card{
  flex:0 0 calc((100% - 72px) / 5);
  scroll-snap-align:start;
  min-width:0;
}
@media(max-width:980px){
  .pd-related-grid > .pd-rel-card{flex:0 0 calc((100% - 36px) / 3)}
}
@media(max-width:640px){
  .pd-related-grid > .pd-rel-card{flex:0 0 calc((100% - 18px) / 2)}
}

/* Tighten sidebar gap between cards */
.pd-specs-grid > div > .pd-card,
.pd-specs-grid > div > .pd-video-card{margin-bottom:18px}
.pd-specs-grid > div > .pd-card:first-child{margin-top:0}

/* Related grid - slight tweak for cleaner layout */
.pd-related-wrap{margin-top:48px;margin-bottom:24px}
.pd-related-head h3{font-size:20px;font-weight:800}

/* ============================================================
   v6.6 — Wider container (fix narrow body issue)
   ============================================================ */
:root{
  --container:1320px !important;
}
.container{
  width:min(1320px, calc(100% - 48px)) !important;
  max-width:1320px !important;
  margin-left:auto !important;
  margin-right:auto !important;
}

/* On large screens give it even more breathing room */
@media(min-width:1440px){
  .container{
    width:min(1400px, calc(100% - 64px)) !important;
    max-width:1400px !important;
  }
}

/* Mega-menu inner should also use the wider container */
.mega-inner{
  max-width:1320px !important;
}
@media(min-width:1440px){
  .mega-inner{max-width:1400px !important}
}

/* On smaller laptops (1280-1440), keep close to current container */
@media(min-width:1024px) and (max-width:1280px){
  .container{
    width:min(100%, calc(100% - 40px)) !important;
  }
}

/* ============================================================
   v6.7 — All header dropdowns: pure WHITE background
   ============================================================ */
.menu .dd, .mega-menu{
  background:#ffffff !important;
  border:1px solid #eef0f3 !important;
  border-radius:14px !important;
  box-shadow:0 18px 50px rgba(0,0,0,.15) !important;
}
.menu .dd a, .mega-col a{
  color:#1a1a1a !important;
  font-weight:500 !important;
}
.menu .dd a:hover, .mega-col a:hover{
  background:#fff !important;
  color:var(--gold-bright) !important;
}
.mega-col h4{
  color:#1a1a1a !important;
  font-weight:800 !important;
  border-bottom:1px solid #eef0f3 !important;
}
.menu .dd .dd-ico{
  background:#fff8eb !important;
  border-color:#f0e3c0 !important;
  color:var(--gold-bright) !important;
}

/* Mega menu specific shadows + border-radius */
.mega-menu{
  border-top:3px solid var(--gold) !important;
  border-bottom:1px solid #eef0f3 !important;
  border-radius:0 !important;
}

/* ============================================================
   v10.3 — About dropdown styled to match cascade pane
   (gold dot bullets, hover slide, white bg) — visual parity with Products
   ============================================================ */
.menu .dd{
  min-width:260px !important;
  padding:8px !important;
  list-style:none !important;
  border-radius:0 !important;
}
.menu .dd li{margin:0 !important}
.menu .dd a{
  display:flex !important;align-items:center !important;gap:11px !important;
  padding:11px 14px !important;
  font-size:13.5px !important;font-weight:500 !important;
  color:#333 !important;text-decoration:none !important;
  transition:.18s !important;
  border-radius:0 !important;
  white-space:normal !important;
  position:relative;
}
/* Gold dot bullet — same as the cascade pane items */
.menu .dd a::before{
  content:"";width:8px;height:8px;border-radius:50%;
  background:var(--gold);
  box-shadow:0 0 0 2px rgba(201,162,74,.18);
  flex-shrink:0;transition:.18s;
}
.menu .dd a:hover{
  background:rgba(201,162,74,.1) !important;
  color:var(--gold) !important;
}
.menu .dd a:hover::before{
  box-shadow:0 0 0 4px rgba(201,162,74,.28);
  transform:scale(1.15);
}
/* Hide the legacy emoji icon since we now have gold bullets */
.menu .dd .dd-ico{display:none !important}

/* Mobile nav stays dark for contrast over hamburger overlay */

/* ============================================================
   v6.9 — Layout polish: full-bleed container + 4-col grid + tools
   ============================================================ */

/* Container — wider for enterprise feel */
:root{--container:1500px !important}
.container{
  width:min(1500px, calc(100% - 32px)) !important;
  max-width:1500px !important;
  margin:0 auto !important;
}
@media(min-width:1600px){
  .container{
    width:min(1560px, calc(100% - 48px)) !important;
    max-width:1560px !important;
  }
}
.mega-inner{max-width:1500px !important}

/* PRODUCTS PAGE — 4-column grid */
.product-grid.grid-3{
  grid-template-columns:repeat(4,1fr) !important;
  gap:16px !important;
}
@media(max-width:1280px){
  .product-grid.grid-3{grid-template-columns:repeat(3,1fr) !important}
}
@media(max-width:980px){
  .product-grid.grid-3{grid-template-columns:repeat(2,1fr) !important}
}
@media(max-width:540px){
  .product-grid.grid-3{grid-template-columns:1fr !important}
}

/* Tools row — search wide, sort compact, button compact */
.tools-row{
  display:flex !important;
  gap:10px !important;
  align-items:center !important;
  flex-wrap:nowrap !important;
  width:100% !important;
}
.tools-row .tools-search-wrap{
  flex:1 1 auto !important;
  min-width:280px !important;
  max-width:none !important;
}
.tools-row .tools-search-wrap input{
  width:100% !important;
  height:44px !important;
  padding:0 50px 0 42px !important;
}
.tools-row .sort-select{
  flex:0 0 160px !important;
  width:160px !important;
  height:44px !important;
  padding:0 14px !important;
}
.tools-row .btn-search{
  flex:0 0 auto !important;
  height:44px !important;
  padding:0 24px !important;
  font-size:13px !important;
}

/* Funnel icon — fix shape (no oval), proper SVG */
.tools-search-wrap .funnel-btn{
  width:34px !important;
  height:34px !important;
  border-radius:50% !important;
  background:var(--gold) !important;
  color:white !important;
  border:0 !important;
  cursor:pointer !important;
  display:grid !important;
  place-items:center !important;
  position:absolute !important;
  right:6px !important;
  top:50% !important;
  transform:translateY(-50%) !important;
  padding:0 !important;
  flex-shrink:0 !important;
  transition:.2s;
  box-shadow:0 4px 10px rgba(201,162,74,.3);
}
.tools-search-wrap .funnel-btn:hover{
  background:var(--gold-bright) !important;
  transform:translateY(-50%) scale(1.06) !important;
}
.tools-search-wrap .funnel-btn svg{
  width:16px !important;
  height:16px !important;
  fill:currentColor !important;
}

/* Filter dropdown popup — full filter UI */
.filter-dropdown{
  position:absolute !important;
  z-index:100 !important;
  top:calc(100% + 12px) !important;
  right:0 !important;
  background:white !important;
  border:1px solid #eef0f3 !important;
  border-radius:18px !important;
  box-shadow:0 24px 60px rgba(0,0,0,.18) !important;
  padding:24px !important;
  min-width:380px !important;
  max-width:420px !important;
  max-height:560px !important;
  overflow-y:auto !important;
  display:none !important;
}
.filter-dropdown.open{display:block !important}
.filter-dropdown::before{
  content:'';
  position:absolute;
  top:-8px;right:14px;
  width:16px;height:16px;
  background:white;
  border-left:1px solid #eef0f3;
  border-top:1px solid #eef0f3;
  transform:rotate(45deg);
}
.filter-dropdown h4{
  font-size:13px !important;
  font-weight:800 !important;
  letter-spacing:.5px !important;
  color:#1a1a1a !important;
  margin-bottom:10px !important;
  padding-bottom:8px !important;
  border-bottom:1px solid #eef0f3 !important;
  text-transform:uppercase !important;
}
.filter-dropdown .fd-section{margin-bottom:18px}
.filter-dropdown .fd-section:last-of-type{margin-bottom:0}
.filter-dropdown .fd-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:6px;
}
.filter-dropdown .check{
  display:flex !important;
  align-items:center !important;
  gap:8px !important;
  padding:8px 10px !important;
  font-size:13px !important;
  cursor:pointer !important;
  border-radius:8px !important;
  border:1px solid transparent;
  transition:.15s;
}
.filter-dropdown .check:hover{background:#fafafa;border-color:#eee}
.filter-dropdown .check input{
  width:15px;height:15px;
  accent-color:var(--gold);
  flex-shrink:0;
}
.filter-dropdown .actions{
  display:flex;gap:8px;
  border-top:1px solid #eef0f3;
  padding-top:14px;margin-top:14px;
}
.filter-dropdown .actions .btn{flex:1;padding:10px;font-size:13px}


/* ============================================================
   v7.0 — Sidebar normal scroll + Filter & Compare modal
   ============================================================ */

/* SIDEBAR — remove sticky, scroll WITH page content */
.sidebar{
  position:static !important;
  max-height:none !important;
  overflow:visible !important;
  top:auto !important;
}

/* Replace funnel with Filter & Compare button */
.tools-search-wrap .funnel-btn{
  display:none !important;
}
.btn-fc{
  display:inline-flex;align-items:center;gap:8px;
  height:44px;padding:0 22px;
  background:white;border:2px solid var(--gold);
  color:var(--gold);
  border-radius:999px;
  font-weight:700;font-size:13px;
  cursor:pointer;transition:.2s;
  font-family:inherit;
  flex-shrink:0;
  white-space:nowrap;
}
.btn-fc:hover{
  background:var(--gold);color:white;
  transform:translateY(-1px);
  box-shadow:0 6px 16px rgba(201,162,74,.3);
}
.btn-fc svg{width:18px;height:18px;fill:currentColor;flex-shrink:0}

/* Filter & Compare MODAL */
.fc-modal{
  display:none;
  position:fixed;inset:0;z-index:5000;
  background:rgba(11,11,13,.55);
  backdrop-filter:blur(6px);
  align-items:flex-start;justify-content:center;
  padding:48px 16px;
  overflow-y:auto;
}
.fc-modal.open{display:flex}
.fc-modal-card{
  background:white;border-radius:24px;
  max-width:920px;width:100%;
  box-shadow:0 28px 70px rgba(0,0,0,.35);
  overflow:hidden;
  animation:fcSlide .25s ease-out;
}
@keyframes fcSlide{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
.fc-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 28px;
  background:linear-gradient(135deg,#1a1a1a,#2a2a35);
  color:white;
}
.fc-head h2{
  font-size:22px;font-weight:800;letter-spacing:-.3px;
  margin:0;display:flex;align-items:center;gap:10px;
}
.fc-head h2 svg{width:22px;height:22px;fill:var(--gold-soft)}
.fc-close{
  background:rgba(255,255,255,.1);border:0;
  width:36px;height:36px;border-radius:50%;
  color:white;font-size:18px;cursor:pointer;
  display:grid;place-items:center;transition:.2s;
}
.fc-close:hover{background:rgba(255,255,255,.2)}
.fc-body{padding:28px 28px 8px;max-height:65vh;overflow-y:auto}
.fc-body::-webkit-scrollbar{width:6px}
.fc-body::-webkit-scrollbar-thumb{background:rgba(201,162,74,.4);border-radius:6px}

.fc-row{display:grid;grid-template-columns:1fr auto 1fr;gap:14px;align-items:center;margin-bottom:24px}
.fc-row .fc-arrow{font-size:20px;color:#999;text-align:center}
.fc-row select{
  width:100%;height:46px;padding:0 14px;
  border:1px solid #eef0f3;border-radius:12px;
  background:white;font-size:14px;font-family:inherit;
  cursor:pointer;
}

.fc-section{margin-bottom:22px}
.fc-section h4{
  font-size:14px;font-weight:700;color:#1a1a1a;
  margin-bottom:12px;letter-spacing:.2px;
  text-transform:uppercase;
}
.fc-options{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
.fc-options label{
  display:flex;align-items:center;gap:8px;
  padding:10px 12px;border-radius:10px;
  border:1px solid #eef0f3;background:white;
  font-size:13px;cursor:pointer;
  transition:.15s;
}
.fc-options label:hover{background:#fafafa;border-color:rgba(201,162,74,.3)}
.fc-options label input{
  width:15px;height:15px;accent-color:var(--gold);flex-shrink:0;
}
.fc-options label input:checked + span{color:var(--gold-bright);font-weight:700}

/* Range slider rows */
.fc-range{display:grid;grid-template-columns:1fr;gap:6px}
.fc-range-meta{
  display:flex;justify-content:space-between;
  font-size:11px;color:#888;font-weight:600;
}
.fc-range-meta .min,.fc-range-meta .max{
  background:#16a34a;color:white;
  padding:4px 10px;border-radius:6px;
  font-size:11px;
}
.fc-range input[type="range"]{
  width:100%;accent-color:#16a34a;
  height:6px;background:#e8e8e8;border-radius:999px;
}

/* Footer actions */
.fc-foot{
  padding:18px 28px;
  background:#fafafa;border-top:1px solid #eef0f3;
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  flex-wrap:wrap;
}
.fc-foot .left{
  display:flex;align-items:center;gap:14px;
  font-size:13px;color:#666;
}
.fc-foot .clear{
  background:transparent;border:0;
  color:var(--gold-bright);font-weight:700;
  cursor:pointer;font-size:13px;
}
.fc-foot .clear:hover{color:var(--gold)}
.fc-foot .actions{display:flex;gap:10px}
.fc-foot .actions .btn{padding:11px 26px;font-size:13px}

/* Compare slot section in modal */
.fc-compare{
  margin-top:24px;padding-top:20px;
  border-top:2px dashed #eef0f3;
}
.fc-compare h4{
  font-size:14px;font-weight:700;color:#1a1a1a;
  margin-bottom:12px;text-transform:uppercase;
}
.fc-compare-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.fc-compare-slot{
  background:#fafafa;border:2px dashed #e8d9b8;
  border-radius:14px;padding:18px 12px;text-align:center;
  font-size:12px;color:#999;
  min-height:120px;display:grid;place-items:center;gap:6px;
  cursor:pointer;transition:.2s;
}
.fc-compare-slot:hover{background:#fff8eb;border-color:var(--gold)}
.fc-compare-slot .plus{font-size:32px;color:#ccc;line-height:1}
.fc-compare-slot:hover .plus{color:var(--gold)}

@media(max-width:780px){
  .fc-options{grid-template-columns:repeat(3,1fr)}
  .fc-row{grid-template-columns:1fr;gap:8px}
  .fc-row .fc-arrow{display:none}
  .fc-compare-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:540px){
  .fc-options{grid-template-columns:repeat(2,1fr)}
  .fc-modal{padding:16px}
}

/* ============================================================
   v7.1 — Advanced sidebar filters (Yamaha-style)
   ============================================================ */
.adv-filter h3{
  font-size:13px !important;
  font-weight:800 !important;
  letter-spacing:.4px !important;
  color:#1a1a1a !important;
  text-transform:uppercase !important;
  margin-bottom:12px !important;
}
.adv-range{padding:0 4px}
.adv-range input[type="range"]{
  width:100%;height:4px;
  background:#e5e7eb;border-radius:999px;
  accent-color:#16a34a;
  margin-bottom:8px;
}
.adv-range-meta{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:4px;
}
.badge-min,.badge-max{
  background:#16a34a;color:white;
  padding:3px 10px;border-radius:6px;
  font-size:11px;font-weight:700;letter-spacing:.2px;
  white-space:nowrap;
}
.adv-filter .check{
  font-size:13.5px !important;
  padding:6px 4px !important;
}
.adv-filter .check-count{font-size:11px !important;color:#999 !important}
.adv-filter .show-more{
  display:inline-block;
  padding:6px 0;
  font-size:13px;color:var(--gold-bright);
  font-weight:700;
}
.adv-filter .show-more:hover{color:var(--gold)}

/* Sidebar styling refinement */
.sidebar .filter-title{font-size:13px;letter-spacing:.4px;text-transform:uppercase;color:#1a1a1a;font-weight:800;margin-bottom:14px}
.sidebar .filter-group{padding-top:18px;margin-top:18px;border-top:1px solid #eef0f3}
.sidebar .filter-group:first-of-type{padding-top:0;margin-top:0;border-top:0}


/* ============================================================
   v7.2 — Product card badges: no overlap + discount badge
   ============================================================ */
.product-card{position:relative;overflow:hidden}

/* Stack BEST SELLER + NEW vertically (top-right) */
.badge-stack{
  position:absolute;top:14px;right:14px;
  display:flex;flex-direction:column;gap:6px;
  align-items:flex-end;z-index:3;
  pointer-events:none;
}
.badge-stack .card-corner-badge{
  position:static !important;
  display:inline-block;
  background:var(--gold);color:var(--black);
  font-size:10px;font-weight:900;letter-spacing:.5px;
  padding:5px 10px;border-radius:999px;
  text-transform:uppercase;
  box-shadow:0 4px 12px rgba(201,162,74,.35);
  white-space:nowrap;
}
.badge-stack .card-corner-badge.new{
  background:#16a34a;color:white;
  box-shadow:0 4px 12px rgba(22,163,74,.4);
}

/* Discount badge — green pill, top-LEFT corner */
.discount-badge{
  position:absolute;top:14px;left:14px;
  background:linear-gradient(135deg,#16a34a,#0a8a3a);
  color:white;
  font-size:13px;font-weight:900;letter-spacing:.3px;
  padding:6px 12px;
  border-radius:999px;
  z-index:4;
  box-shadow:0 6px 16px rgba(10,138,58,.4);
  animation:pulseDiscount 2s ease-in-out infinite;
}
@keyframes pulseDiscount{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.06)}
}

/* If a card has both stacks AND discount badge, ensure consistent spacing */
.product-card .product-img{padding-top:6px}


/* ============================================================
   v7.4 — Hover Quick View Popup (JD.com / Tmall style)
   ============================================================ */
.product-card{
  position:relative !important;
  overflow:visible !important;
}
.product-card .product-img,
.product-card .product-body{overflow:hidden}

/* The popup */
.quick-view{
  position:absolute;
  top:50%;left:calc(100% + 12px);
  transform:translateY(-50%) scale(.96);
  width:340px;
  background:white;
  border-radius:18px;
  box-shadow:0 22px 60px rgba(0,0,0,.22),0 0 0 1px rgba(0,0,0,.06);
  z-index:300;
  opacity:0;visibility:hidden;
  pointer-events:none;
  transition:opacity .25s ease, transform .25s ease, visibility .25s;
  overflow:hidden;
}
.product-card:hover .quick-view{
  opacity:1;visibility:visible;transform:translateY(-50%) scale(1);
  transition-delay:.3s;
  pointer-events:auto;
}
/* Arrow pointing to card */
.quick-view::before{
  content:'';
  position:absolute;left:-7px;top:50%;
  transform:translateY(-50%) rotate(45deg);
  width:14px;height:14px;
  background:white;
  border-left:1px solid rgba(0,0,0,.06);
  border-bottom:1px solid rgba(0,0,0,.06);
}
/* When card is on right edge — flip popup to left */
.product-grid .product-card:nth-child(4n) .quick-view,
.product-grid .product-card:last-child .quick-view{
  left:auto;right:calc(100% + 12px);
}
.product-grid .product-card:nth-child(4n) .quick-view::before,
.product-grid .product-card:last-child .quick-view::before{
  left:auto;right:-7px;
  border-left:0;border-bottom:0;
  border-right:1px solid rgba(0,0,0,.06);
  border-top:1px solid rgba(0,0,0,.06);
}

/* QV image */
.qv-img{
  height:200px;background:#fafafa;
  display:grid;place-items:center;
  position:relative;overflow:hidden;
  border-bottom:1px solid #eef0f3;
}
.qv-img img{width:100%;height:100%;object-fit:contain;padding:18px}
.qv-placeholder{
  font-family:'Prompt',sans-serif;
  font-weight:900;font-size:22px;letter-spacing:1px;
  color:#bbb;
}
.qv-tag{
  position:absolute;top:12px;
  font-size:10px;font-weight:900;letter-spacing:.5px;
  padding:4px 10px;border-radius:999px;
  text-transform:uppercase;
}
.qv-tag.gold{background:var(--gold);color:var(--black);right:12px}
.qv-tag.green{background:#16a34a;color:white;left:12px}

/* QV body */
.qv-body{padding:18px}
.qv-brand{
  font-size:11px;font-weight:800;letter-spacing:1px;
  color:var(--gold-bright);text-transform:uppercase;
  margin-bottom:6px;
}
.qv-title{
  font-size:17px;font-weight:800;color:var(--black);
  line-height:1.3;margin-bottom:6px;
}
.qv-model{
  font-size:11px;color:#999;font-weight:600;
  margin-bottom:10px;
}
.qv-desc{
  font-size:12.5px;color:#666;line-height:1.55;
  margin-bottom:12px;
}
.qv-specs{
  list-style:none;padding:0;margin:0 0 12px;
  display:grid;gap:6px;
  font-size:12.5px;color:#444;
}
.qv-specs li{
  display:flex;align-items:flex-start;gap:6px;
  padding:4px 0;
  border-bottom:1px dashed #f0ede4;
}
.qv-specs li:last-child{border-bottom:0}
.qv-specs li strong{color:#888;font-weight:600;flex-shrink:0;font-size:11.5px}
.qv-check{color:#16a34a;font-weight:900;flex-shrink:0}

.qv-meta{
  display:flex;justify-content:space-between;align-items:center;
  padding:8px 0;
  border-top:1px solid #eef0f3;
  margin-bottom:10px;
  font-size:11.5px;
}
.qv-cat{
  background:#f5f0e2;color:#8a6412;
  padding:3px 8px;border-radius:6px;font-weight:600;
}
.qv-stock{color:#16a34a;font-weight:700}

.qv-price-row{
  display:flex;align-items:center;gap:10px;
  margin-bottom:14px;
}
.qv-price{
  font-size:22px;font-weight:900;color:var(--black);
  line-height:1;
}
.qv-price.small{font-size:14px;font-weight:700;color:#8a6412}
.qv-disc{
  background:linear-gradient(135deg,#ef4444,#dc2626);
  color:white;font-weight:900;font-size:11px;
  padding:4px 8px;border-radius:6px;
}
.qv-actions{
  display:grid;grid-template-columns:1.2fr 1fr;gap:8px;
}
.qv-actions .btn{
  padding:10px 14px;font-size:12.5px;
  justify-content:center;
}

/* Hide quick-view on mobile / smaller screens (would block scrolling) */
@media(max-width:1100px){
  .quick-view{display:none !important}
}

/* ============================================================
   v7.5 — BIG Quick View Modal (920px, professional)
   ============================================================ */

/* Disable old per-card quick-view */
.quick-view{display:none !important}

/* Modal backdrop */
.qv-modal{
  display:none;
  position:fixed;inset:0;z-index:5000;
  background:rgba(11,11,13,.6);
  backdrop-filter:blur(8px);
  align-items:flex-start;justify-content:center;
  padding:48px 16px;overflow-y:auto;
}
.qv-modal.open{display:flex;animation:qvFade .25s}
@keyframes qvFade{from{opacity:0}to{opacity:1}}

.qv-card{
  background:white;border-radius:24px;
  max-width:920px;width:100%;
  box-shadow:0 30px 80px rgba(0,0,0,.4);
  overflow:hidden;position:relative;
  animation:qvSlide .3s ease-out;
}
@keyframes qvSlide{from{opacity:0;transform:translateY(-30px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}

.qv-close{
  position:absolute;top:16px;right:16px;z-index:10;
  width:38px;height:38px;border-radius:50%;
  background:rgba(0,0,0,.06);border:0;
  font-size:24px;color:#333;cursor:pointer;
  display:grid;place-items:center;transition:.2s;
  font-family:inherit;
}
.qv-close:hover{background:#1a1a1a;color:white;transform:rotate(90deg)}

/* 2-column grid */
.qv-grid{display:grid;grid-template-columns:.95fr 1.05fr;min-height:480px}

/* LEFT: Gallery */
.qv-gallery{
  background:#fafafa;padding:28px;
  display:flex;flex-direction:column;gap:14px;
  position:relative;
}
.qv-main-img{
  flex:1;background:white;border-radius:16px;
  display:grid;place-items:center;overflow:hidden;
  min-height:340px;border:1px solid #eef0f3;
}
.qv-main-img img{max-width:90%;max-height:90%;object-fit:contain}
.qv-no-img{font-weight:900;font-size:28px;letter-spacing:1px;color:#bbb}
.qv-tag-row{
  position:absolute;top:40px;left:40px;
  display:flex;flex-direction:column;gap:6px;align-items:flex-start;
}
.qv-modal-tag{
  font-size:10px;font-weight:900;letter-spacing:.5px;
  padding:5px 11px;border-radius:999px;text-transform:uppercase;
  box-shadow:0 4px 10px rgba(0,0,0,.2);
}
.qv-modal-tag.gold{background:var(--gold);color:var(--black)}
.qv-modal-tag.green{background:#16a34a;color:white}
.qv-modal-tag.red{background:linear-gradient(135deg,#ef4444,#dc2626);color:white}
.qv-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.qv-thumb-mini{
  height:60px;background:white;border-radius:10px;
  border:2px solid #eef0f3;cursor:pointer;
  display:grid;place-items:center;overflow:hidden;
  transition:.15s;
}
.qv-thumb-mini.active{border-color:var(--gold)}
.qv-thumb-mini:hover{border-color:var(--gold-soft)}
.qv-thumb-mini img{max-width:80%;max-height:80%;object-fit:contain}
.qv-thumb-mini .thumb-placeholder{font-size:18px;color:#ccc}

/* RIGHT: Details */
.qv-detail{padding:32px 32px 26px;display:flex;flex-direction:column;gap:14px;overflow-y:auto;max-height:80vh}
.qv-detail::-webkit-scrollbar{width:6px}
.qv-detail::-webkit-scrollbar-thumb{background:rgba(201,162,74,.4);border-radius:6px}

.qv-brand-label{
  font-size:11px;font-weight:800;letter-spacing:1.2px;
  color:var(--gold-bright);text-transform:uppercase;
  margin:0;
}
.qv-title-big{
  font-size:26px;font-weight:800;color:var(--black);
  line-height:1.2;letter-spacing:-.3px;margin:0;
}
.qv-meta-row{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  padding-bottom:12px;border-bottom:1px solid #eef0f3;
}
.qv-stars{color:var(--gold);font-size:14px;letter-spacing:1px}
.qv-rating{font-size:14px;font-weight:700;color:#1a1a1a}
.qv-reviews{font-size:13px;color:#888}
.qv-sku-tag{
  margin-left:auto;font-size:12px;color:#666;
  background:#fafafa;padding:4px 10px;border-radius:6px;
}
.qv-desc-big{
  font-size:14px;color:#555;line-height:1.65;margin:0;
}

/* 4-spec grid */
.qv-spec-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:8px;background:#fafafa;padding:12px;border-radius:12px;
}
.qv-spec-cell{
  text-align:center;padding:8px 4px;
  border-right:1px solid rgba(201,162,74,.18);
}
.qv-spec-cell:last-child{border-right:0}
.qv-spec-cell strong{display:block;font-size:14px;color:var(--black);font-weight:800;margin-bottom:2px;line-height:1.2;word-wrap:break-word}
.qv-spec-cell span{font-size:10.5px;color:#888;font-weight:500}

/* Feats list */
.qv-feats-section h4{
  font-size:11px;font-weight:800;letter-spacing:.5px;
  color:#1a1a1a;text-transform:uppercase;margin:0 0 8px;
}
.qv-feats-list{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:1fr 1fr;gap:6px;
  font-size:12.5px;color:#444;
}
.qv-feats-list li{
  display:flex;align-items:flex-start;gap:6px;
}
.qv-check{color:#16a34a;font-weight:900;flex-shrink:0}

/* Price block */
.qv-price-block{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 0;border-top:1px solid #eef0f3;border-bottom:1px solid #eef0f3;
  gap:12px;
}
.qv-price-big{
  font-size:28px;font-weight:900;color:var(--black);
  line-height:1;
}
.qv-vat{font-size:11px;color:#888;margin-top:3px}
.qv-disc-pill{
  background:linear-gradient(135deg,#ef4444,#dc2626);
  color:white;font-weight:900;font-size:18px;
  padding:8px 14px;border-radius:10px;letter-spacing:.5px;
}
.qv-disc-pill:empty{display:none}

/* Trust row */
.qv-trust-row{
  display:grid;grid-template-columns:repeat(3,1fr);gap:10px;
}
.qv-trust{
  display:flex;align-items:center;gap:6px;
  font-size:11.5px;color:#666;
  background:#fafafa;padding:8px 10px;border-radius:8px;
  border:1px solid #f0ede4;
}
.qv-trust span:first-child{font-size:14px}

/* CTA row */
.qv-cta-row{
  display:grid;grid-template-columns:1.2fr 1fr;gap:10px;margin-top:auto;
}
.qv-cta-row .btn{
  padding:13px 18px;font-size:13.5px;
  justify-content:center;font-weight:700;
}

/* Mobile / smaller — disable hover, just hide modal entirely */
@media(max-width:1100px){
  .qv-modal{display:none !important}
}
@media(max-width:780px){
  .qv-grid{grid-template-columns:1fr}
  .qv-spec-grid{grid-template-columns:repeat(2,1fr)}
  .qv-feats-list{grid-template-columns:1fr}
  .qv-trust-row{grid-template-columns:1fr}
  .qv-cta-row{grid-template-columns:1fr}
}

/* ============================================================
   v6.3 — Home page redesign (alternating dark/light + cream)
   ============================================================ */

/* HOME HERO */
.home-hero{
  position:relative;color:#fff;
  height:680px;             /* fixed height so the section never resizes between slides */
  overflow:hidden;background:#08080a;
}
/* Every slide stacks at the same coords — section height stays constant */
.home-hero-slide{
  position:absolute;inset:0;
  display:flex;align-items:center;
  padding:72px 0 80px;
  opacity:0;visibility:hidden;
  transition:opacity .6s ease, visibility .6s ease;
  pointer-events:none;
  will-change:opacity;
}
.home-hero-slide.active{
  opacity:1;visibility:visible;pointer-events:auto;
}
@media(max-width:780px){
  .home-hero{height:auto;min-height:560px}
}
.hero-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  color:#fff;font-size:14px;cursor:pointer;z-index:5;
  display:grid;place-items:center;transition:.2s;
  backdrop-filter:blur(6px);
}
.hero-arrow:hover{background:var(--gold);border-color:var(--gold);color:#0a0a0c}
.hero-arrow-left{left:18px}
.hero-arrow-right{right:18px}
.home-hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  background-repeat:no-repeat;
  background-color:#0e0e12;
  filter:saturate(.9);
}
.home-hero-bg:before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(135deg,#08080a 0%,#1b1b22 58%,#08080a 100%),
    radial-gradient(circle at 80% 30%,rgba(201,162,74,.15),transparent 60%);
  z-index:-1;
}
.home-hero-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(90deg,rgba(8,8,10,.96) 0%,rgba(8,8,10,.78) 45%,rgba(8,8,10,.45) 100%),
    radial-gradient(circle at 80% 30%,rgba(201,162,74,.18),transparent 60%);
}
.home-hero-inner{position:relative;z-index:2;width:min(var(--container),calc(100% - 40px))}
.home-hero-content{max-width:680px}
.home-eyebrow{
  display:inline-block;color:var(--gold-soft);font-weight:800;
  font-size:13px;letter-spacing:4px;margin-bottom:18px;
}
.home-hero-title{
  font-size:clamp(34px,5.2vw,56px);line-height:1.05;
  letter-spacing:-1.2px;margin-bottom:18px;font-weight:800;
  text-transform:uppercase;
}
.home-hero-title span{color:var(--gold-soft)}
.home-hero-lead{font-size:16px;color:#d1d5db;line-height:1.7;margin-bottom:28px;max-width:600px}
.trust-badges{display:flex;gap:24px;flex-wrap:wrap;margin-bottom:32px}
.trust-badge{display:flex;align-items:center;gap:12px}
.trust-badge svg{
  width:36px;height:36px;color:var(--gold);flex-shrink:0;
  background:rgba(201,162,74,.12);border:1px solid rgba(201,162,74,.32);
  border-radius:10px;padding:7px;
}
.trust-badge strong{display:block;font-size:11.5px;font-weight:800;letter-spacing:1px;color:#fff}
.trust-badge small{display:block;font-size:11px;color:#9ca3af;margin-top:2px}
.home-hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.btn-outline-light{border-color:rgba(255,255,255,.4);color:#fff;background:transparent}
.btn-outline-light:hover{background:rgba(255,255,255,.08);border-color:#fff;color:#fff}
.home-hero-dots{
  position:absolute;bottom:24px;left:0;right:0;
  display:flex;justify-content:center;gap:8px;z-index:5;
}
.home-hero-dots .dot{
  width:10px;height:10px;border-radius:50%;
  background:rgba(255,255,255,.35);
  border:0;padding:0;cursor:pointer;
  transition:width .25s, background .25s, border-radius .25s;
}
.home-hero-dots .dot:hover{background:rgba(255,255,255,.6)}
.home-hero-dots .dot.active{background:var(--gold);width:28px;border-radius:5px}
.home-hero-dots.solo{position:static;margin-top:24px}
.home-hero-dots.solo .dot{background:#d6d6d6}
.home-hero-dots.solo .dot.active{background:var(--gold)}

/* SHARED LUX SECTIONS — alternating dark/light/cream */
.lux-section{padding:64px 0}
.lux-light{background:#fff;color:#1a1a1d}
.lux-dark{background:#0a0a0c;color:#fff}
.lux-cream{background:#f3ede0}
.lux-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:24px;margin-bottom:30px;flex-wrap:wrap;
}
.lux-eyebrow{
  display:block;font-size:11.5px;font-weight:700;letter-spacing:2px;
  color:var(--gold);text-transform:uppercase;margin-bottom:8px;
}
.lux-eyebrow.gold{color:var(--gold-soft)}
.lux-dark .lux-eyebrow{color:var(--gold-soft)}
.lux-head h2{
  font-size:clamp(28px,3.2vw,40px);font-weight:800;
  letter-spacing:-.4px;line-height:1.1;margin:0;
}
.lux-head h2 .accent{color:var(--gold)}
.lux-light .lux-head h2{color:#1a1a1d}
.lux-dark .lux-head h2{color:#fff}
.lux-view-all{
  display:inline-flex;align-items:center;gap:8px;
  border:1px solid #d8d8d8;border-radius:999px;
  padding:10px 18px;font-size:11.5px;font-weight:800;letter-spacing:1.5px;
  color:#1a1a1d;text-decoration:none;transition:.2s;
  white-space:nowrap;
}
.lux-view-all:hover{background:#1a1a1d;color:var(--gold-soft);border-color:#1a1a1d}
.lux-dark .lux-view-all{border-color:rgba(255,255,255,.2);color:#fff}
.lux-dark .lux-view-all:hover{background:var(--gold);border-color:var(--gold);color:#0a0a0c}

/* CATEGORY TILES (light) — horizontal scroll carousel with arrows */
.cat-carousel{
  position:relative;
  margin:0 -8px;
}
.cat-tile-grid{
  display:flex;gap:14px;
  overflow-x:auto;scroll-behavior:smooth;
  padding:6px 56px;
  scrollbar-width:none;-ms-overflow-style:none;
  scroll-snap-type:x proximity;
  scroll-padding:56px;
  /* Centers when content fits, falls back to start when scrolling needed */
  justify-content:safe center;
}
.cat-tile-grid::-webkit-scrollbar{display:none}
.cat-tile-grid > .cat-tile{
  flex:0 0 175px;
  scroll-snap-align:start;
}
.cat-carousel-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:42px;height:42px;border-radius:50%;
  background:#fff;border:1px solid #e3dccb;
  cursor:pointer;display:grid;place-items:center;
  z-index:3;font-size:14px;color:#1a1a1d;
  box-shadow:0 6px 16px rgba(15,17,21,.1);
  transition:.2s;
}
.cat-carousel-arrow:hover{
  background:var(--gold);color:#fff;border-color:var(--gold);
  box-shadow:0 10px 22px rgba(201,162,74,.3);
}
.cat-carousel-arrow:disabled{
  opacity:.35;cursor:default;
}
.cat-carousel-arrow:disabled:hover{
  background:#fff;color:#1a1a1d;border-color:#e3dccb;
  box-shadow:0 6px 16px rgba(15,17,21,.1);
}
.cat-carousel-prev{left:-4px}
.cat-carousel-next{right:-4px}
.cat-tile{
  position:relative;
  background:#fff;border:1px solid #ececec;border-radius:14px;
  padding:10px 12px 14px;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  text-decoration:none;color:#1a1a1d;transition:.22s;overflow:hidden;
}
.cat-tile:hover{
  border-color:var(--gold);transform:translateY(-3px);
  box-shadow:0 14px 30px rgba(201,162,74,.14);background:#fff;
}
.cat-tile.active{
  border-color:var(--gold);background:#fff;
  box-shadow:0 14px 30px rgba(201,162,74,.18);
}
.cat-tile.active .cat-tile-arrow{background:var(--gold);color:#fff;border-color:var(--gold)}
.cat-tile-thumb{
  width:100%;aspect-ratio:1.7/1;
  background:transparent;
  display:grid;place-items:center;
  position:relative;
  padding:8px 10px 12px;
}
.cat-tile-thumb:after{
  content:"";position:absolute;
  left:18%;right:18%;bottom:8px;height:14px;
  background:radial-gradient(ellipse at center,rgba(0,0,0,.28) 0%,rgba(0,0,0,.12) 45%,transparent 75%);
  filter:blur(2px);z-index:0;
  transition:opacity .3s, transform .3s;
}
.cat-tile-thumb img{
  position:relative;z-index:1;
  max-width:100%;max-height:100%;
  width:auto;height:auto;
  object-fit:contain;display:block;
  filter:drop-shadow(0 10px 14px rgba(0,0,0,.25));
  transition:transform .3s, filter .3s;
}
.cat-tile:hover .cat-tile-thumb img{
  transform:translateY(-4px) scale(1.04);
  filter:drop-shadow(0 18px 22px rgba(0,0,0,.32));
}
.cat-tile:hover .cat-tile-thumb:after{opacity:.85;transform:scaleX(1.08)}
.cat-tile-icon{font-size:30px;line-height:1;color:var(--gold-soft);font-weight:900}
.cat-tile-meta{display:flex;flex-direction:column;align-items:center;gap:3px;width:100%}
.cat-tile-titlerow{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  width:auto;
}
.cat-tile-meta h4{
  font-size:13px;letter-spacing:.4px;font-weight:800;
  color:#1a1a1d;margin:0;line-height:1.2;
}
.cat-tile-meta small{
  font-size:10.5px;letter-spacing:1.2px;color:#888;font-weight:600;
  text-transform:uppercase;
}
.cat-tile-arrow{
  width:20px;height:20px;border-radius:50%;
  background:#fff;border:1px solid #e3dccb;
  display:inline-grid;place-items:center;
  font-size:11px;color:var(--gold);transition:.22s;
  line-height:1;flex-shrink:0;
}
.cat-tile:hover .cat-tile-arrow{
  background:var(--gold);color:#fff;border-color:var(--gold);
  transform:translateX(2px);
}

/* BRAND STRIP (dark) */
.brand-strip-section{padding:32px 0}
.brand-strip-row{
  display:flex;align-items:center;gap:24px;
}
.brand-strip-label{
  display:flex;flex-direction:column;flex-shrink:0;line-height:1.1;
}
.brand-strip-label small{font-size:10px;color:var(--gold-soft);letter-spacing:2px;font-weight:600}
.brand-strip-label strong{font-size:13px;color:#fff;letter-spacing:1.5px;font-weight:800;margin-top:3px}
.brand-strip-logos{
  flex:1;display:grid;
  grid-template-columns:repeat(7,1fr);
  align-items:center;gap:8px;
}
.brand-strip-logo{
  display:flex;align-items:center;justify-content:center;
  height:72px;padding:0 6px;overflow:hidden;
  font-size:16px;font-weight:900;letter-spacing:1px;color:#fff;
  text-decoration:none;opacity:.85;transition:.25s;font-family:inherit;
  text-transform:uppercase;
}
.brand-strip-logo img{
  --logo-scale:1;
  height:32px;width:auto;max-width:100%;
  object-fit:contain;display:block;
  transform:scale(var(--logo-scale));transform-origin:center;
  filter:brightness(0) invert(1);
  transition:filter .25s, opacity .25s;
}
.brand-strip-logo:hover{opacity:1;color:var(--gold-soft)}
.brand-strip-logo:hover img{filter:brightness(0) invert(1) sepia(1) saturate(4) hue-rotate(355deg)}
.brand-strip-text{display:inline-block;font-size:18px}
.brand-strip-all{
  flex-shrink:0;font-size:10.5px;font-weight:800;letter-spacing:1.5px;
  color:#fff;text-decoration:none;line-height:1.4;
  border-left:1px solid rgba(255,255,255,.15);padding-left:20px;
}
.brand-strip-all:hover{color:var(--gold-soft)}

/* LUX SOLUTION CARDS (light) */
.lux-solution-grid{
  display:grid;grid-template-columns:repeat(7,1fr);gap:12px;
}
.lux-solution-card{
  position:relative;border-radius:14px;overflow:hidden;
  aspect-ratio:.85/1;display:block;text-decoration:none;color:#fff;
  transition:.22s;background:#222;
}
.lux-solution-img{
  position:absolute;inset:0;
  background:linear-gradient(135deg,#2a2a36,#0a0a0c);
  background-size:cover;background-position:center;
}
.lux-solution-shade{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,0) 30%,rgba(0,0,0,.88) 100%);
}
.lux-solution-meta{
  position:absolute;left:0;right:0;bottom:0;padding:18px 14px 16px;
  display:flex;flex-direction:column;gap:3px;z-index:1;
}
.lux-solution-dot{
  width:18px;height:18px;border-radius:50%;
  background:var(--gold);margin-bottom:8px;
  box-shadow:0 0 0 4px rgba(201,162,74,.25);
}
.lux-solution-meta strong{font-size:13px;font-weight:800;color:#fff;line-height:1.2}
.lux-solution-meta small{font-size:11px;color:#d1d5db;font-weight:500;letter-spacing:.5px}
.lux-solution-arrow{
  position:absolute;right:12px;bottom:12px;z-index:1;
  width:26px;height:26px;border-radius:50%;
  background:rgba(255,255,255,.18);display:grid;place-items:center;
  font-size:13px;color:#fff;transition:.2s;
}
.lux-solution-card:hover{transform:translateY(-3px)}
.lux-solution-card:hover .lux-solution-arrow{background:var(--gold);color:#0a0a0c}

/* WHY CHOOSE (dark) */
.why-choose-section{padding:72px 0}
.why-grid{display:grid;grid-template-columns:.85fr 2.4fr;gap:48px;align-items:center}
.why-intro h2.why-title{
  font-size:clamp(34px,4.5vw,52px);font-weight:900;letter-spacing:-1px;
  line-height:1;margin:6px 0 16px;color:#fff;
}
.why-intro p{font-size:14px;color:#cfd3da;line-height:1.7;margin-bottom:22px;max-width:340px}
.why-features{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
}
.why-feature{padding:0 4px}
.why-icon{
  width:60px;height:60px;border-radius:50%;
  background:rgba(201,162,74,.12);border:1px solid rgba(201,162,74,.32);
  display:grid;place-items:center;color:var(--gold);margin-bottom:14px;
}
.why-icon svg{width:26px;height:26px}
.why-feature h4{font-size:13px;letter-spacing:1px;font-weight:800;color:#fff;margin:0 0 8px;text-transform:uppercase}
.why-feature p{font-size:12.5px;color:#9aa0a8;line-height:1.6;margin:0}

/* LUX PROJECT CARDS (light) */
.lux-project-grid{
  display:grid;grid-template-columns:repeat(6,1fr);gap:14px;
}
.lux-project-card{
  display:flex;flex-direction:column;text-decoration:none;
  border-radius:12px;overflow:hidden;background:#fff;
  border:1px solid #ececec;transition:.22s;
}
.lux-project-card:hover{transform:translateY(-3px);border-color:var(--gold);box-shadow:0 14px 30px rgba(201,162,74,.12)}
.lux-project-img{
  display:block;width:100%;aspect-ratio:1.35/1;
  background:linear-gradient(135deg,#3a3a48,#0a0a0c);
  background-size:cover;background-position:center;
}
.lux-project-meta{
  padding:12px 12px 14px;display:flex;flex-direction:column;gap:3px;
  color:#1a1a1d;
}
.lux-project-meta strong{font-size:12.5px;font-weight:700;line-height:1.3;color:#1a1a1d}
.lux-project-meta small{font-size:11px;color:var(--gold);font-weight:600;letter-spacing:.5px}

/* ACTION BAR — CREAM */
.action-bar-cream{background:#f3ede0;padding:34px 0}
.action-bar-row{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
}
.action-cream-item{
  display:flex;align-items:flex-start;gap:14px;
  padding:8px 22px;color:#1a1a1d;text-decoration:none;
  border-right:1px solid #e1d8c0;transition:.2s;
}
.action-cream-item:last-child{border-right:0}
.action-cream-item:hover{color:var(--gold)}
.action-cream-ico{
  width:46px;height:46px;border-radius:50%;flex-shrink:0;
  background:#0a0a0c;border:0;display:grid;place-items:center;color:var(--gold);
}
.action-cream-ico svg{width:22px;height:22px}
.action-cream-meta{display:flex;flex-direction:column;gap:2px;min-width:0}
.action-cream-meta strong{font-size:13px;font-weight:800;letter-spacing:.5px;color:#1a1a1d}
.action-cream-meta small{font-size:11.5px;color:#777;font-weight:500}
.action-cream-extra{font-size:12px;color:#1a1a1d;font-weight:600;margin-top:1px}

/* FOOTER REDESIGN v6.3 — larger, bolder typography for big screens */
.site-footer .footer-grid{
  display:grid;
  grid-template-columns:1.6fr 1fr 1fr 1fr 1.4fr;
  gap:40px;padding:60px 0 36px;
}
.footer-col h4{
  font-size:16px;font-weight:800;letter-spacing:1.6px;
  color:#fff;text-transform:uppercase;margin:0 0 18px;
}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:11px;padding:0;margin:0}
.footer-col ul a{
  color:#c8ccd3;font-size:15px;font-weight:500;text-decoration:none;
  transition:.18s;
}
.footer-col ul a:hover{color:var(--gold-soft)}
.footer-col-brand .footer-brand{
  display:inline-flex;align-items:center;text-decoration:none;
  margin-bottom:16px;
}
.footer-logo{height:54px;width:auto;max-width:240px;display:block;background:transparent}
.footer-tagline{
  font-size:15px;color:#b8bdc6;line-height:1.75;font-weight:400;
  margin:0 0 22px;max-width:380px;
}
.footer-social{display:flex;gap:12px;flex-wrap:wrap}
.footer-social a{
  width:42px;height:42px;border-radius:50%;
  display:grid;place-items:center;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  color:#e0e3e8;transition:.18s;
}
.footer-social a:hover{background:var(--gold);color:#0a0a0c;border-color:var(--gold)}
.footer-social svg{width:18px;height:18px}
.footer-cert{margin-top:22px}
.footer-cert-title{
  font-size:14px;font-weight:800;letter-spacing:1.4px;
  color:#fff;text-transform:uppercase;margin:0 0 12px;
}
.footer-cert-link{
  display:inline-block;background:#fff;padding:8px 12px;
  border-radius:8px;line-height:0;transition:.18s;
  border:1px solid rgba(255,255,255,.15);
}
.footer-cert-link:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,.35)}
.footer-cert-logo{height:64px;width:auto;max-width:160px;display:block}
.footer-col-contact .footer-contact-list{display:flex;flex-direction:column;gap:16px}
.footer-contact-list li{
  display:flex;gap:13px;align-items:flex-start;
  font-size:15px;color:#dde0e6;line-height:1.5;font-weight:500;
}
.footer-contact-list svg{
  width:18px;height:18px;color:var(--gold);flex-shrink:0;margin-top:3px;
}
.footer-contact-list a{color:#dde0e6;text-decoration:none;font-weight:500}
.footer-contact-list a:hover{color:var(--gold-soft)}
.footer-contact-list .muted{color:#a0a5ad;font-size:14px;font-weight:400}
/* CERTIFICATIONS — full-width row, title stacked above logos, all left-aligned */
.footer-certs-row{
  border-top:1px solid rgba(255,255,255,.1);
  padding:26px 0 22px;
  display:flex;flex-direction:column;align-items:flex-start;gap:14px;
}
.footer-certs-title{
  font-size:12px;font-weight:800;letter-spacing:1.6px;text-transform:uppercase;
  color:var(--gold-soft);margin:0;
}
.footer-certs-list{
  display:flex;align-items:center;flex-wrap:wrap;gap:12px;
  justify-content:flex-start;
}
.footer-cert-item{
  display:inline-block;background:#fff;
  padding:8px 14px;line-height:0;
  border:1px solid rgba(255,255,255,.12);
  transition:.18s;
}
.footer-cert-item:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.32)}
.footer-cert-item img{height:54px;width:auto;max-width:170px;display:block;object-fit:contain}
@media(max-width:780px){
  .footer-cert-item img{height:46px}
}

.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 0;border-top:1px solid rgba(255,255,255,.1);
  font-size:14px;color:#b8bdc6;font-weight:500;flex-wrap:wrap;gap:14px;
}
.footer-bottom p{margin:0}
.footer-legal{display:flex;align-items:center;gap:12px}
.footer-legal a{color:#dde0e6;text-decoration:none;font-weight:500}
.footer-legal a:hover{color:var(--gold-soft)}
.footer-legal .legal-sep{color:#555}

/* Extra-large screens: scale up further so the footer doesn't shrink visually */
@media(min-width:1600px){
  .site-footer .footer-grid{padding:72px 0 40px;gap:48px}
  .footer-col h4{font-size:17px}
  .footer-col ul a{font-size:16px}
  .footer-tagline{font-size:16px;max-width:420px}
  .footer-contact-list li{font-size:16px}
  .footer-contact-list .muted{font-size:15px}
  .footer-bottom{font-size:15px}
  .footer-logo{height:60px;max-width:260px}
  .footer-cert-logo{height:72px;max-width:180px}
}

/* HOME RESPONSIVE */
@media(max-width:1100px){
  .cat-tile-grid{grid-template-columns:repeat(5,1fr)}
  .brand-strip-row{flex-wrap:wrap}
  .brand-strip-logos{grid-template-columns:repeat(4,1fr);gap:14px}
  .brand-strip-all{border-left:0;padding-left:0}
  .lux-solution-grid{grid-template-columns:repeat(4,1fr)}
  .lux-project-grid{grid-template-columns:repeat(3,1fr)}
  .why-grid{grid-template-columns:1fr;gap:32px}
  .why-features{grid-template-columns:repeat(2,1fr)}
  .action-bar-row{grid-template-columns:repeat(2,1fr)}
  .action-cream-item:nth-child(2){border-right:0}
  .action-cream-item:nth-child(1),.action-cream-item:nth-child(2){border-bottom:1px solid #e1d8c0;padding-bottom:18px;margin-bottom:14px}
  .site-footer .footer-grid{grid-template-columns:repeat(3,1fr);gap:30px}
  .footer-col-brand{grid-column:1 / -1}
  .footer-col-contact{grid-column:1 / -1}
}
@media(max-width:780px){
  .home-hero{min-height:480px;padding:48px 0}
  .home-hero-title{font-size:30px;letter-spacing:-.6px}
  .trust-badges{gap:14px}
  .hero-arrow{display:none}
  .cat-tile-grid{grid-template-columns:repeat(3,1fr)}
  .brand-strip-logos{grid-template-columns:repeat(3,1fr)}
  .lux-solution-grid{grid-template-columns:repeat(2,1fr)}
  .lux-project-grid{grid-template-columns:repeat(2,1fr)}
  .action-bar-row{grid-template-columns:1fr}
  .action-cream-item{border-right:0;border-bottom:1px solid #e1d8c0;padding-bottom:14px}
  .action-cream-item:last-child{border-bottom:0}
  .site-footer .footer-grid{grid-template-columns:1fr 1fr}
  .footer-bottom{justify-content:center;text-align:center}
}
@media(max-width:520px){
  .cat-tile-grid{grid-template-columns:repeat(2,1fr)}
  .why-features{grid-template-columns:1fr}
  .site-footer .footer-grid{grid-template-columns:1fr}
}
