/* ============================================================
   BERJAYA HARDWARE — Industrial B2B catalogue
   Design system. Stack: pure HTML/CSS/JS.
   Fonts: Bebas Neue (display) · Plus Jakarta Sans (body/UI) · DM Mono (specs)
   ============================================================ */

:root {
  /* ---- Berjaya / BEHCO brand (main shell) ---- */
  --brand:         #ED1B24;          /* BEHCO logo red — secondary accent across the site */
  --brand-press:   #c4131b;
  --brand-ink:     #14171c;          /* near-black charcoal */
  --on-brand:      #ffffff;

  /* ---- Neutrals ---- */
  --ink:        #14171c;
  --ink-2:      #474e57;
  --ink-3:      #6b727b;
  --line:       #e2e6ea;
  --line-2:     #eef1f4;
  --bg:         #ffffff;
  --bg-2:       #f4f6f8;
  --bg-3:       #e9edf1;
  --ink-panel:  #14171c;             /* dark panels / hero */

  /* ---- Per-brand themes default to Berjaya; overridden by .theme-* ---- */
  --theme:        var(--brand);
  --theme-ink:    var(--brand-ink);
  --theme-on:     #ffffff;

  /* ---- Fonts ---- */
  --font-display: 'Bebas Neue', 'Arial Narrow', sans-serif;
  --font-body:    'Plus Jakarta Sans', system-ui, sans-serif;
  --font-mono:    'DM Mono', ui-monospace, monospace;

  /* ---- Shape ---- */
  --radius:     8px;
  --radius-sm:  5px;
  --shadow:     0 1px 2px rgba(20,23,28,.06), 0 2px 8px rgba(20,23,28,.04);
  --shadow-mid: 0 6px 24px rgba(20,23,28,.10);
  --shadow-lg:  0 16px 48px rgba(20,23,28,.16);

  /* ---- Fluid scale (CLAUDE.md) ---- */
  --maxw:      1360px;
  --gutter:    clamp(16px, 3vw, 36px);
  --section-y: clamp(48px, 6vw, 92px);

  /* ---- Motion (emil-design-eng / impeccable) — never bare ease ---- */
  --ease-out:    cubic-bezier(0.23, 1, 0.32, 1);
  --ease-in-out: cubic-bezier(0.77, 0, 0.175, 1);
  --t-fast: 0.14s var(--ease-out);   /* press */
  --t-base: 0.22s var(--ease-out);   /* hover/state */
}

/* per-brand theme classes (set on <body> of brand/product pages) */
.theme-cromwell { --theme:#FF5100; --theme-ink:#3d1500; --theme-on:#fff; }
.theme-kennedy  { --theme:#D6231C; --theme-ink:#3d0807; --theme-on:#fff; }
.theme-total    { --theme:#006B73; --theme-ink:#003136; --theme-on:#fff; }
.theme-bosch    { --theme:#003E66; --theme-ink:#001f33; --theme-on:#fff; }
.theme-stanley  { --theme:#FFD20A; --theme-ink:#4a3c00; --theme-on:#111; }

/* ============================================================ RESET */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:16px; -webkit-text-size-adjust:100%; }
html,body { overflow-x:hidden; }
body {
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.55;
  font-size:15px;
  -webkit-font-smoothing:antialiased;
}
img,svg { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
ul { list-style:none; }
button { font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
input,textarea,select { font-family:inherit; font-size:1rem; }
:focus-visible { outline:2px solid var(--brand); outline-offset:2px; }

.skip-link { position:absolute; left:-9999px; top:0; background:var(--ink); color:#fff; padding:10px 16px; z-index:200; }
.skip-link:focus { left:8px; top:8px; }

/* ============================================================ TYPE */
h1,h2,h3,h4 { line-height:1.1; font-weight:700; color:inherit; }
.display { font-family:var(--font-display); font-weight:400; letter-spacing:.01em; line-height:.95; }
.mono { font-family:var(--font-mono); }
.eyebrow {
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:.16em;
  text-transform:uppercase; color:var(--brand-press); font-weight:500;
}

/* ============================================================ LAYOUT */
.container { width:100%; max-width:var(--maxw); margin:0 auto; padding:0 var(--gutter); }
.section { padding:var(--section-y) 0; }
.section--in { padding:clamp(26px,3vw,40px) 0 clamp(40px,5vw,64px); }   /* tighter top, keep gap below */
.section--alt { background:var(--bg-2); }
.section-head { display:flex; align-items:flex-end; justify-content:space-between; gap:1rem; margin-bottom:clamp(20px,2.5vw,32px); flex-wrap:wrap; }
.section-head h2 { font-family:var(--font-display); font-weight:400; font-size:clamp(2rem,4vw,3.1rem); letter-spacing:.01em; text-transform:uppercase; }
.section-head h2::before { content:""; display:block; width:46px; height:4px; background:var(--brand); border-radius:2px; margin-bottom:.7rem; }
.section-head .link { font-weight:600; font-size:.9rem; color:var(--brand-press); display:inline-flex; align-items:center; gap:.35rem; }
.section-head .link:hover { gap:.6rem; }
@media (min-width:1700px){ :root{ --maxw:1500px; } body{ font-size:16px; } }
@media (min-width:2100px){ :root{ --maxw:1640px; } }

/* ============================================================ BUTTONS */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  font-weight:700; font-size:.9rem; line-height:1; letter-spacing:.01em;
  padding:.85rem 1.5rem; border-radius:var(--radius-sm);
  transition:background var(--t-base), color var(--t-base), border-color var(--t-base), transform var(--t-fast);
  white-space:nowrap;
}
.btn:active { transform:scale(.97); }
.btn--primary { background:var(--brand); color:#fff; }
.btn--theme   { background:var(--theme); color:var(--theme-on); }
.btn--dark    { background:var(--ink); color:#fff; }
.btn--outline { border:1.5px solid var(--line); color:var(--ink); background:#fff; }
.btn--ghost   { color:var(--ink); border:1.5px solid currentColor; }
.btn--lg { padding:1.05rem 2rem; font-size:1rem; }
.btn--full { width:100%; }
@media (hover:hover) and (pointer:fine){
  .btn--primary:hover{ background:var(--brand-press); }
  .btn--outline:hover{ border-color:var(--ink); }
  .btn--dark:hover{ background:#000; }
  .btn--theme:hover{ filter:brightness(.93); }
}

/* ============================================================ TOP UTILITY BAR */
.utilbar { background:var(--brand); color:#fff; font-size:.78rem; }
.utilbar__in { display:flex; align-items:center; justify-content:space-between; gap:1rem; height:34px; }
.utilbar a { color:#fff; }
.utilbar svg { color:#fff; }
.utilbar__msg { display:flex; align-items:center; gap:.5rem; }
.utilbar__right { display:flex; align-items:center; gap:1.2rem; }
.utilbar__right a { display:inline-flex; align-items:center; gap:.4rem; }
.utilbar__right a svg { width:13px; height:13px; }
.utilbar__right a:hover { opacity:.82; }
@media (max-width:640px){ .utilbar__right .hide-sm { display:none; } }

/* ============================================================ HEADER */
.header { position:sticky; top:0; z-index:90; background:#fff; border-bottom:1px solid var(--line); }
.header__in { display:grid; grid-template-columns:auto minmax(0,1fr) auto; align-items:center; gap:clamp(14px,2.5vw,32px); height:74px; }
.logo { display:flex; align-items:center; gap:.6rem; flex-shrink:0; }
.logo__img { height:clamp(38px,4vw,48px); width:auto; }
.logo__div { width:1.5px; height:32px; background:var(--line); }
.logo__desc { font-family:var(--font-display); font-size:1.05rem; line-height:.9; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-3); }
@media (max-width:480px){ .logo__div, .logo__desc { display:none; } }
.logo__mark { width:40px; height:40px; background:var(--brand); border-radius:6px; display:grid; place-items:center; color:#fff; font-family:var(--font-display); font-size:1.6rem; }
.logo__txt { font-family:var(--font-display); font-size:1.7rem; line-height:.9; letter-spacing:.02em; color:var(--ink); }
.logo__txt small { display:block; font-family:var(--font-mono); font-size:.5rem; letter-spacing:.22em; color:var(--ink-3); }

.search { width:100%; max-width:640px; margin:0 auto; position:relative; }
.search input {
  width:100%; height:46px; border:2px solid var(--ink); border-radius:var(--radius-sm);
  padding:0 52px 0 16px; font-size:.95rem; background:#fff; color:var(--ink);
  transition:border-color var(--t-base);
}
.search input::placeholder { color:var(--ink-3); }
.search button {
  position:absolute; right:0; top:0; height:46px; width:48px; background:var(--brand);
  border-radius:0 3px 3px 0; color:#fff; display:grid; place-items:center; transition:background var(--t-base);
}
.search button:active { transform:scale(.94); }
@media (hover:hover){ .search button:hover{ background:var(--brand-press); } }

/* search autocomplete dropdown */
.searchac { position:fixed; z-index:2000; background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-lg); max-height:min(70vh,440px); overflow-y:auto; }
.searchac__item, .searchac__all { display:flex; align-items:center; gap:11px; width:100%; text-align:left; padding:10px 13px; font-size:.86rem; transition:background var(--t-base); }
.searchac__item img, .searchac__noimg { width:40px; height:40px; flex-shrink:0; object-fit:contain; background:var(--bg-2); border-radius:var(--radius-sm); padding:3px; }
.searchac__noimg { display:grid; place-items:center; color:var(--ink-3); }
.searchac__noimg svg { width:18px; height:18px; }
.searchac__txt { display:flex; flex-direction:column; min-width:0; }
.searchac__nm { font-weight:600; color:var(--ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.searchac__br { font-size:.74rem; color:var(--ink-3); }
.searchac__all { border-top:1px solid var(--line); font-weight:700; color:var(--brand); gap:8px; }
.searchac__all svg { width:16px; height:16px; flex-shrink:0; }
.searchac__loading { padding:14px 13px; font-size:.86rem; color:var(--ink-3); }
.searchac__item.is-active, .searchac__all.is-active { background:var(--bg-2); }
@media (hover:hover){ .searchac__item:hover, .searchac__all:hover { background:var(--bg-2); } }

.header__actions { display:flex; align-items:center; gap:.4rem; flex-shrink:0; justify-self:end; }
.iconbtn { width:46px; height:46px; border-radius:var(--radius-sm); display:grid; place-items:center; color:var(--ink); position:relative; transition:background var(--t-base); }
@media (hover:hover){ .iconbtn:hover{ background:var(--bg-2); } }
.iconbtn:active { transform:scale(.94); }
.iconbtn__label { display:none; }
.badge { position:absolute; top:4px; right:6px; min-width:18px; height:18px; padding:0 4px; border-radius:9px; background:var(--brand); color:#fff; font-size:.66rem; font-weight:700; display:grid; place-items:center; }
.badge:empty { display:none; }
.burger { display:none; }

/* quote button highlighted */
.quotebtn { background:var(--ink); color:#fff; border-radius:var(--radius-sm); padding:0 1rem; height:46px; display:flex; align-items:center; gap:.5rem; font-weight:700; font-size:.85rem; position:relative; transition:background var(--t-base); }
@media (hover:hover){ .quotebtn:hover{ background:#000; } }
.quotebtn:active { transform:scale(.97); }

/* language dropdown (in header) */
.langdrop { position:relative; }
.langdrop__btn { display:flex; align-items:center; gap:.3rem; height:46px; padding:0 .7rem; border-radius:var(--radius-sm); font-weight:600; font-size:.82rem; color:var(--ink); transition:background var(--t-base); }
.langdrop__btn span { font-family:var(--font-body); }
.langdrop__btn svg { width:18px; height:18px; }
.langdrop__btn .chev { width:14px; height:14px; transition:transform var(--t-base); }
.langdrop.open .langdrop__btn .chev { transform:rotate(180deg); }
@media (hover:hover){ .langdrop__btn:hover{ background:var(--bg-2); } }
.langdrop__menu { position:absolute; top:calc(100% + 6px); right:0; min-width:170px; background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-lg); padding:6px; opacity:0; visibility:hidden; transform:translateY(-6px); transition:opacity var(--t-base), transform var(--t-base), visibility var(--t-base); z-index:95; }
.langdrop.open .langdrop__menu { opacity:1; visibility:visible; transform:none; }
.langdrop__menu button { display:flex; align-items:center; gap:.5rem; width:100%; text-align:left; padding:.6rem .7rem; border-radius:var(--radius-sm); font-size:.86rem; font-weight:600; color:var(--ink-2); transition:background var(--t-base), color var(--t-base); }
.langdrop__menu button.is-active { color:var(--brand); }
.langdrop__menu button.is-active::after { content:"✓"; margin-left:auto; }
@media (hover:hover){ .langdrop__menu button:hover{ background:var(--bg-2); color:var(--ink); } }
@media (max-width:768px){ .langdrop__btn span.langdrop__lbl{ display:none; } }

/* ============================================================ MAIN NAV */
.mainnav { background:#fff; border-bottom:1px solid var(--line); position:sticky; top:74px; z-index:80; }
.mainnav__in { display:flex; align-items:center; gap:.3rem; height:48px; }
.mainnav a { font-weight:600; font-size:.86rem; padding:.55rem .9rem; border-radius:var(--radius-sm); color:var(--ink-2); transition:color var(--t-base), background var(--t-base); }
.mainnav a.is-active { color:var(--brand); }
@media (hover:hover){ .mainnav a:hover{ color:var(--ink); background:var(--bg-2); } }
.mainnav__spacer { flex:1; }
.mainnav__shop { color:var(--brand)!important; font-weight:700!important; display:inline-flex; align-items:center; gap:.35rem; }

/* ============================================================ TRUST STRIP */
.trust { background:var(--bg-2); border-bottom:1px solid var(--line); }
.trust__in { display:flex; align-items:center; gap:clamp(10px,2.5vw,34px); height:46px; overflow-x:auto; scrollbar-width:none; }
.trust__in::-webkit-scrollbar{ display:none; }
.trust__item { display:flex; align-items:center; gap:.5rem; font-size:.8rem; color:var(--ink-2); white-space:nowrap; font-weight:500; }
.trust__item svg { color:var(--brand); width:18px; height:18px; flex-shrink:0; }

/* ============================================================ SHELL: rail + content */
.shell { display:grid; grid-template-columns:264px minmax(0,1fr); gap:clamp(20px,2.5vw,36px); align-items:start; padding-top:clamp(20px,3vw,34px); }
.content { min-width:0; }
.rail { position:sticky; top:140px; }
.rail__title { font-family:var(--font-display); font-size:1.15rem; letter-spacing:.04em; text-transform:uppercase; padding:0 0 .6rem; border-bottom:3px solid var(--brand); margin-bottom:.4rem; }
.rail__list a {
  display:flex; align-items:center; gap:.7rem; padding:.62rem .6rem; border-radius:var(--radius-sm);
  font-size:.86rem; font-weight:500; color:var(--ink-2); border-left:3px solid transparent;
  transition:background var(--t-base), color var(--t-base), border-color var(--t-base);
}
.rail__list a:active { transform:scale(.99); }
@media (hover:hover){ .rail__list a:hover{ background:var(--bg-2); color:var(--ink); border-left-color:var(--brand); } }
.rail__list svg { width:18px; height:18px; color:var(--ink-3); flex-shrink:0; }
.rail__list .count { margin-left:auto; font-family:var(--font-mono); font-size:.7rem; color:var(--ink-3); }

/* ============================================================ HERO CAROUSEL */
.hero { position:relative; background:var(--ink-panel); border-radius:var(--radius); overflow:hidden; }
.hero__track { display:flex; transition:transform .6s var(--ease-in-out); }
.hero__slide { min-width:100%; position:relative; display:flex; }
.slide {
  position:relative; display:flex; flex-direction:column; justify-content:center; align-items:flex-start;
  flex:1; width:100%; min-height:clamp(320px,32vw,440px); padding:clamp(32px,5vw,68px);
  background-color:#111419; background-position:center; background-size:cover; background-repeat:no-repeat;
  color:#fff; overflow:hidden;
}
.slide::before { content:""; position:absolute; inset:0; background:linear-gradient(90deg, rgba(13,15,19,.96) 0%, rgba(13,15,19,.82) 34%, rgba(13,15,19,.42) 62%, rgba(13,15,19,.08) 100%); pointer-events:none; }
/* Slogan / brand-statement slide: solid dark with a faint red glow instead of a photo */
.slide--brand { background:#14171c; }
.slide--brand::before { background:radial-gradient(130% 110% at 100% 0%, rgba(237,27,36,.30) 0%, rgba(20,23,28,0) 55%); }
/* Cromwell promotion slide: same wording format as the other slides (red eyebrow + big display
   title + grey sub + red button), with the same soft left scrim for legibility. The finished
   banner is shown whole (object-fit:contain) so the logo strip is never cropped; the navy fill
   matches the artwork (#172A4B) and the scrim fades out before the tools so they stay clear. */
.slide--promo { background:#172A4B; padding:0; }
.slide--promo::before { content:""; z-index:1; background:linear-gradient(90deg, rgba(8,15,31,.94) 0%, rgba(8,15,31,.6) 32%, rgba(23,42,75,0) 54%); }
.slide--promo__img { position:absolute; inset:0; width:100%; height:100%; object-fit:contain; object-position:center; display:block; z-index:0; }
.slide--promo__copy { position:absolute; inset:0 auto 0 0; z-index:2; display:flex; flex-direction:column; justify-content:center; padding:clamp(32px,5vw,68px); padding-right:0; max-width:min(580px,52%); }
@media (max-width:600px){ .slide--promo__copy{ max-width:74%; } }
.slide__body { max-width:600px; position:relative; z-index:1; }
.slide__eyebrow { font-family:var(--font-mono); font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--brand); margin-bottom:1rem; }
.slide__title { font-family:var(--font-display); font-weight:400; font-size:clamp(2.6rem,5.5vw,4.6rem); line-height:.92; text-transform:uppercase; margin-bottom:.9rem; color:#fff; }
.slide__sub { color:#c8ced6; font-size:1.02rem; margin-bottom:1.8rem; max-width:46ch; }
.slide__visual { position:absolute; right:clamp(24px,4vw,64px); top:50%; transform:translateY(-50%); z-index:0; opacity:.92; }
.slide__visual img { max-height:clamp(220px,26vw,330px); width:auto; filter:drop-shadow(0 24px 48px rgba(0,0,0,.55)); }
@media (max-width:860px){ .slide__visual{ display:none; } }

/* language switcher */
.langsw { display:inline-flex; align-items:center; gap:2px; }
.langsw button { font-size:.74rem; font-weight:600; color:#aeb5be; padding:2px 7px; border-radius:4px; transition:color var(--t-base), background var(--t-base); }
.langsw button.is-active { color:#fff; background:rgba(255,255,255,.14); }
@media (hover:hover){ .langsw button:hover{ color:#fff; } }
.langsw__sep { color:rgba(255,255,255,.25); }
.hero__dots { position:absolute; bottom:16px; left:0; right:0; display:flex; gap:8px; justify-content:center; z-index:3; }
.hero__dots button { width:8px; height:8px; border-radius:50%; background:rgba(255,255,255,.4); transition:background var(--t-base), width var(--t-base); }
.hero__dots button.is-active { background:var(--brand); width:22px; border-radius:4px; }
.hero__arrow { position:absolute; top:50%; transform:translateY(-50%); width:42px; height:42px; border-radius:50%; background:rgba(255,255,255,.12); color:#fff; display:grid; place-items:center; z-index:3; transition:background var(--t-base); }
.hero__arrow:active { transform:translateY(-50%) scale(.92); }
@media (hover:hover){ .hero__arrow:hover{ background:rgba(255,255,255,.25); } }
.hero__arrow--prev { left:14px; } .hero__arrow--next { right:14px; }

/* ============================================================ PROMO TILES */
.promos { display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(12px,1.5vw,18px); margin-top:clamp(14px,1.8vw,20px); }
.promo { position:relative; border-radius:var(--radius); overflow:hidden; aspect-ratio:2.02/1; display:flex; align-items:flex-end; padding:22px; color:#fff; background-color:var(--ink); background-size:cover; background-position:center; isolation:isolate; }
.promo::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(10,12,15,.28) 0%, rgba(10,12,15,.55) 52%, rgba(10,12,15,.9) 100%); z-index:-1; transition:background var(--t-base); }
@media (hover:hover){ .promo:hover::after { background:linear-gradient(180deg, rgba(10,12,15,.2) 0%, rgba(10,12,15,.5) 52%, rgba(10,12,15,.88) 100%); } }
.promo h3 { font-family:var(--font-display); font-weight:400; font-size:1.5rem; letter-spacing:.02em; text-transform:uppercase; }
.promo span { font-size:.82rem; color:#c4cad2; }
@media (hover:hover){ .promo:hover img{ transform:scale(1.06); } }

/* ============================================================ CATEGORY TILES (homepage grid) */
.cat-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:clamp(10px,1.4vw,16px); }
.subcat-block { margin-bottom:clamp(24px,3vw,36px); }
.subcat-block:empty { display:none; }
/* L1/L2 category carousels duplicate the desktop rail, so only show them where the rail is hidden */
.subcat-block--raildup { display:none; }
@media (max-width:1024px){ .subcat-block--raildup { display:block; } }
.subcat__h { font-family:var(--font-display); font-weight:400; font-size:clamp(1.3rem,2.4vw,1.85rem); letter-spacing:.01em; text-transform:uppercase; margin-bottom:clamp(12px,1.6vw,16px); }
.cat-tile { background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:16px; display:flex; flex-direction:column; gap:.6rem; transition:border-color var(--t-base), box-shadow var(--t-base), transform var(--t-fast); }
.cat-tile:active { transform:scale(.99); }
.cat-tile__img { aspect-ratio:1; display:grid; place-items:center; background:var(--bg-2); border-radius:var(--radius-sm); overflow:hidden; }
.cat-tile__img img { width:100%; height:100%; object-fit:contain; mix-blend-mode:multiply; }
.cat-tile__name { font-weight:600; font-size:.84rem; line-height:1.25; }
.cat-tile__count { font-family:var(--font-mono); font-size:.7rem; color:var(--ink-3); }
@media (hover:hover){ .cat-tile:hover{ border-color:var(--theme); box-shadow:var(--shadow-mid); } }

/* ============================================================ PRODUCT CARD */
.prod-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(210px,1fr)); gap:clamp(12px,1.5vw,18px); }
.pcard { background:#fff; border:1px solid var(--line); border-radius:var(--radius); display:flex; flex-direction:column; overflow:hidden; transition:border-color var(--t-base), box-shadow var(--t-base), transform var(--t-base); }
.pcard__imgwrap { aspect-ratio:1; background:#fff; padding:14px; display:flex; align-items:center; justify-content:center; overflow:hidden; }
.pcard__imgwrap img { width:100%; height:100%; object-fit:contain; mix-blend-mode:multiply; }
.pcard__body { padding:12px 14px 14px; display:flex; flex-direction:column; gap:.4rem; flex:1; border-top:1px solid var(--line-2); }
.pcard__brand { font-family:var(--font-mono); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }
.pcard__name { font-size:.84rem; font-weight:600; line-height:1.3; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; min-height:3.2em; }
.pcard__sku { font-family:var(--font-mono); font-size:.68rem; color:var(--ink-3); }
.pcard__foot { margin-top:auto; display:flex; align-items:center; justify-content:space-between; gap:.5rem; padding-top:.5rem; }
.pcard__price { font-weight:800; font-size:1rem; }
.pcard__price small { font-weight:500; font-size:.66rem; color:var(--ink-3); }
.pcard__rfq { font-size:.74rem; font-weight:700; color:var(--brand-press); font-family:var(--font-mono); }
.pcard__add { width:38px; height:38px; border-radius:var(--radius-sm); background:var(--ink); color:#fff; display:grid; place-items:center; flex-shrink:0; transition:background var(--t-base); }
.pcard__add:active { transform:scale(.92); }
@media (hover:hover){ .pcard:hover{ border-color:var(--ink-3); box-shadow:var(--shadow-mid); transform:translateY(-2px); } .pcard__add:hover{ background:var(--brand); } }
.stockdot { display:inline-flex; align-items:center; gap:.35rem; font-size:.7rem; color:var(--ink-3); }
.stockdot::before { content:""; width:7px; height:7px; border-radius:50%; background:#16a34a; }
.stockdot--low::before { background:#d97706; }
.stockdot--out::before { background:#9ca3af; }

/* ============================================================ PRODUCT CAROUSEL */
.pcarousel { position:relative; min-width:0; }
.pcarousel__track { display:flex; gap:16px; overflow-x:auto; min-width:0; scroll-snap-type:x proximity; scrollbar-width:none; -webkit-overflow-scrolling:touch; padding:4px 2px 6px; }
.pcarousel__track::-webkit-scrollbar { display:none; }
.pcarousel__track > * { flex:0 0 calc((100% - 64px) / 5); scroll-snap-align:start; }
.pcarousel__track > .spinner { flex:0 0 auto; }
.pcarousel__arrow { position:absolute; top:38%; transform:translateY(-50%); width:44px; height:44px; border-radius:50%; background:#fff; border:1px solid var(--line); box-shadow:var(--shadow-mid); display:grid; place-items:center; color:var(--ink); z-index:5; transition:opacity var(--t-base), background var(--t-base), color var(--t-base); }
.pcarousel__arrow--prev { left:-6px; } .pcarousel__arrow--next { right:-6px; }
.pcarousel__arrow:active { transform:translateY(-50%) scale(.92); }
.pcarousel__arrow.is-hidden { opacity:0; pointer-events:none; }
@media (hover:hover){ .pcarousel__arrow:hover{ background:var(--ink); color:#fff; } }
@media (max-width:1100px){ .pcarousel__track > * { flex-basis:calc((100% - 48px)/4); } }
@media (max-width:820px){ .pcarousel__track > * { flex-basis:calc((100% - 32px)/3); } }
@media (max-width:600px){
  .pcarousel__track { gap:10px; }
  .pcarousel__track > * { flex-basis:calc((100% - 20px)/3); }
  .pcarousel__arrow { display:grid; width:34px; height:34px; }
  .pcarousel__arrow--prev { left:-3px; } .pcarousel__arrow--next { right:-3px; }
  /* compact product card so 3 fit per row */
  .pcard__imgwrap { padding:8px; }
  .pcard__body { padding:8px 9px 10px; gap:.3rem; }
  .pcard__brand { font-size:.6rem; }
  .pcard__name { font-size:.74rem; -webkit-line-clamp:2; min-height:2em; }
  .pcard__sku, .pcard__price small { display:none; }
  .pcard__price { font-size:.82rem; }
  .pcard__add { width:30px; height:30px; }
  .stockdot { font-size:.6rem; }
}

/* category carousel (brand pages): flowing 2-row when many; single row when ≤8 (no empty second row) */
.pcarousel__track.cat-track { display:grid; grid-auto-flow:column; grid-template-rows:repeat(2,1fr); grid-auto-columns:clamp(140px,15vw,176px); align-items:stretch; gap:clamp(10px,1.4vw,16px); }
.pcarousel__track.cat-track.is-single { grid-template-rows:1fr; }
.cat-carousel .pcarousel__arrow { top:50%; }

/* ============================================================ HOMEPAGE TRUSTED BRANDS (themed tiles + logo strip) */
.brandlogos { margin-top:clamp(24px,3vw,36px); padding-top:clamp(24px,3vw,32px); border-top:1px solid var(--line); display:flex; flex-direction:column; gap:clamp(10px,1.6vw,20px); }
.brandlogos__row { overflow:hidden; -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent); mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent); }
.brandlogos__track { display:flex; width:max-content; align-items:center; will-change:transform; }
.brandlogos__row--rtl .brandlogos__track { animation:brandscroll-right 64s linear infinite; }
.brandlogos__row--ltr .brandlogos__track { animation:brandscroll-left 64s linear infinite; }
.brandlogos__track a { flex:0 0 auto; display:grid; place-items:center; height:50px; width:clamp(96px,11vw,150px); margin-right:clamp(26px,3.6vw,52px); }
.brandlogos__track img { max-height:40px; max-width:100%; width:auto; object-fit:contain; mix-blend-mode:multiply; filter:grayscale(45%) saturate(.7); opacity:.58; transition:filter var(--t-base) var(--ease-out), opacity var(--t-base) var(--ease-out), transform var(--t-base) var(--ease-out); }
@keyframes brandscroll-left  { from{ transform:translateX(0); }    to{ transform:translateX(-50%); } }
@keyframes brandscroll-right { from{ transform:translateX(-50%); } to{ transform:translateX(0); } }
@media (hover:hover) and (pointer:fine){
  .brandlogos__row:hover .brandlogos__track { animation-play-state:paused; }
  .brandlogos__track a:hover img { filter:grayscale(0) saturate(1); opacity:1; transform:scale(1.12); }
}
@media (max-width:560px){
  .brandlogos__track a { height:42px; width:clamp(82px,26vw,110px); margin-right:clamp(20px,7vw,34px); }
  .brandlogos__track img { max-height:32px; }
}

/* ============================================================ BRAND MARQUEE (auto-scroll, minimal) */
.brand-marquee { position:relative; overflow:hidden; padding:8px 0;
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent);
  mask-image:linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent); }
.bmq__track { display:flex; align-items:center; gap:clamp(44px,6vw,96px); width:max-content; animation:bmq 42s linear infinite; }
.brand-marquee:hover .bmq__track { animation-play-state:paused; }
@keyframes bmq { to { transform:translateX(-50%); } }
.bmq__item { flex:0 0 auto; display:grid; place-items:center; height:48px; filter:grayscale(1); opacity:.5; transition:filter var(--t-base), opacity var(--t-base), transform var(--t-base); }
.bmq__item img { max-height:48px; max-width:128px; width:auto; object-fit:contain; }
.bmq__item span { font-family:var(--font-display); font-size:1.7rem; color:var(--ink-2); letter-spacing:.02em; }
@media (hover:hover){ .bmq__item:hover { filter:grayscale(0); opacity:1; transform:scale(1.05); } }
@media (prefers-reduced-motion:reduce){ .bmq__track { animation:none; flex-wrap:wrap; justify-content:center; width:auto; } }

/* ============================================================ BRAND BANNER (marquee of logos) */
.brandband { background:transparent; border:none; padding:0; }
.brandband__grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(120px,1fr)); gap:clamp(14px,2vw,28px); align-items:center; }
.brandchip { aspect-ratio:16/9; display:grid; place-items:center; padding:10px 14px; background:transparent; border:none; transition:transform var(--t-base), opacity var(--t-base); }
.brandchip img { max-height:50px; max-width:100%; width:auto; object-fit:contain; }
.brandchip__txt { font-family:var(--font-display); font-size:1.7rem; color:var(--ink-2); letter-spacing:.02em; }
.brandchip:active { transform:scale(.97); }
@media (hover:hover){ .brandchip:hover{ transform:translateY(-3px); } }

/* ============================================================ E-PROCUREMENT */
.eproc { background:var(--ink-panel); color:#fff; border-radius:var(--radius); overflow:hidden; }
.eproc__top { display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(24px,4vw,56px); padding:clamp(28px,4vw,60px); align-items:center; }
.eproc__top h2 { font-family:var(--font-display); font-weight:400; font-size:clamp(2.2rem,4.5vw,3.6rem); text-transform:uppercase; line-height:.95; margin-bottom:1rem; }
.eproc__top p { color:#c4cad2; font-size:.98rem; margin-bottom:.9rem; }
.eproc__feats { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:rgba(255,255,255,.1); }
.efeat { background:var(--ink-panel); padding:clamp(20px,2.5vw,30px); }
.efeat__icon { width:42px; height:42px; border-radius:var(--radius-sm); background:rgba(255,255,255,.08); display:grid; place-items:center; color:var(--brand); margin-bottom:.9rem; }
.efeat h4 { font-size:1rem; margin-bottom:.4rem; color:#fff; }
.efeat p { font-size:.85rem; color:#aeb5be; line-height:1.5; }

/* ============================================================ CATALOGUE STRIP */
.catalogues { display:grid; grid-template-columns:repeat(auto-fill,minmax(168px,1fr)); gap:clamp(14px,1.8vw,22px); }
.catalogue { border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:#fff; transition:box-shadow var(--t-base), transform var(--t-base), border-color var(--t-base); }
.catalogue__cover { position:relative; aspect-ratio:3/4; background:var(--bg-2); display:grid; place-items:center; overflow:hidden; }
.catalogue__img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center; }
.catalogue__overlay { position:absolute; inset:0; display:grid; place-items:center; background:rgba(13,15,19,.45); opacity:0; transition:opacity var(--t-base); z-index:3; }
.catalogue__dl { width:54px; height:54px; border-radius:50%; background:var(--brand); display:grid; place-items:center; color:#fff; box-shadow:var(--shadow-mid); transform:scale(.82); transition:transform var(--t-base); }
.catalogue__dl svg { width:24px; height:24px; }
.catalogue__canvas { position:absolute; inset:0; width:100%; height:100%; object-fit:contain; object-position:center; opacity:0; transition:opacity .35s var(--ease-out); background:#fff; }
.catalogue__cover.is-rendered .catalogue__canvas, .catalogue__canvas.is-rendered { opacity:1; }
.catalogue__ph { font-family:var(--font-display); font-size:1.5rem; color:var(--ink-3); text-align:center; padding:1rem; transition:opacity .3s; }
.catalogue__cover.is-rendered .catalogue__ph { opacity:0; }
.catalogue__ph::after { content:""; display:block; width:22px; height:22px; margin:.7rem auto 0; border:2px solid var(--line); border-top-color:var(--brand); border-radius:50%; animation:spin .8s linear infinite; }
.catalogue__ph--solo::after { display:none; }
.catalogue__meta { padding:14px 14px 16px; }
.catalogue__meta b { font-size:.86rem; font-weight:700; display:block; line-height:1.3; color:var(--ink); }
.catalogue__meta span { font-family:var(--font-mono); font-size:.66rem; color:var(--ink-3); text-transform:uppercase; letter-spacing:.1em; margin-top:.35rem; display:block; }
@media (hover:hover){
  .catalogue:hover{ box-shadow:var(--shadow-mid); transform:translateY(-4px); border-color:transparent; }
  .catalogue:hover .catalogue__overlay{ opacity:1; }
  .catalogue:hover .catalogue__dl{ transform:scale(1); }
}

/* ---- homepage catalogue: featured + list ---- */
.cat-split { display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(18px,2.5vw,32px); align-items:stretch; }
.cat-hero { position:relative; border-radius:var(--radius); overflow:hidden; min-height:clamp(300px,30vw,400px); display:flex; align-items:flex-end; background-color:var(--ink); background-size:cover; background-position:center; color:#fff; isolation:isolate; transition:box-shadow var(--t-base); }
.cat-hero::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(10,12,15,.15) 0%, rgba(10,12,15,.55) 55%, rgba(10,12,15,.92) 100%); z-index:0; }
.cat-hero__body { position:relative; z-index:1; padding:clamp(22px,3vw,38px); max-width:90%; }
.cat-hero__tag { font-family:var(--font-mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:#fff; background:var(--brand); padding:4px 10px; border-radius:20px; display:inline-block; margin-bottom:.9rem; }
.cat-hero__body h3 { font-family:var(--font-display); font-weight:400; font-size:clamp(1.9rem,3.4vw,2.9rem); text-transform:uppercase; line-height:.94; color:#fff; }
.cat-hero__body p { color:#d6dbe1; margin:.6rem 0 1.2rem; font-size:.95rem; max-width:40ch; }
@media (hover:hover){ .cat-hero:hover{ box-shadow:var(--shadow-lg); } .cat-hero:hover .btn--primary{ background:var(--brand-press); } }

.cat-list { display:flex; flex-direction:column; gap:10px; }
.cat-row { display:flex; align-items:center; gap:14px; padding:11px 14px; background:#fff; border:1px solid var(--line); border-radius:var(--radius-sm); transition:border-color var(--t-base), box-shadow var(--t-base), transform var(--t-base); }
.cat-row__thumb { width:46px; height:60px; flex-shrink:0; background:var(--bg-2); border-radius:3px; overflow:hidden; position:relative; }
.cat-row__thumb .catalogue__canvas { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:top center; background:#fff; }
.cat-row__main { flex:1; min-width:0; }
.cat-row__main b { font-size:.85rem; font-weight:700; display:block; line-height:1.25; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; color:var(--ink); }
.cat-row__main > span { font-family:var(--font-mono); font-size:.65rem; text-transform:uppercase; letter-spacing:.08em; color:var(--ink-3); }
.cat-row__dl { width:34px; height:34px; border-radius:50%; background:var(--bg-2); display:grid; place-items:center; color:var(--ink-2); flex-shrink:0; transition:background var(--t-base), color var(--t-base); }
.cat-row__dl svg { width:17px; height:17px; }
@media (hover:hover){ .cat-row:hover{ border-color:var(--brand); box-shadow:var(--shadow); transform:translateX(3px); } .cat-row:hover .cat-row__dl{ background:var(--brand); color:#fff; } }
.cat-row--more { justify-content:center; gap:.5rem; background:transparent; border-style:dashed; font-weight:700; font-size:.85rem; color:var(--brand); }
@media (hover:hover){ .cat-row--more:hover{ background:#fff; transform:none; } }
@media (max-width:768px){ .cat-split{ grid-template-columns:1fr; } }

/* ---- catalogue page: grouped by brand ---- */
.cat-group { margin-bottom:clamp(30px,4vw,52px); }
.cat-group__head { display:flex; align-items:baseline; gap:14px; padding-bottom:.7rem; margin-bottom:1.3rem; border-bottom:2px solid var(--line); }
.cat-group__head h2 { font-family:var(--font-display); font-weight:400; font-size:clamp(1.5rem,2.8vw,2.1rem); text-transform:uppercase; letter-spacing:.02em; }
.cat-group__head h2::before { content:""; display:inline-block; width:9px; height:9px; background:var(--brand); border-radius:50%; margin-right:.55rem; vertical-align:middle; }
.cat-group__count { font-size:.72rem; color:var(--ink-3); }

/* ============================================================ FOOTER */
.footer { background:var(--ink); color:#aeb5be; margin-top:var(--section-y); border-top:4px solid var(--brand); }
.footer__grid { display:grid; grid-template-columns:1.4fr repeat(3,1fr); gap:clamp(24px,3vw,48px); padding:clamp(40px,5vw,68px) 0 40px; }
.footer h5 { color:#fff; font-family:var(--font-mono); font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; margin-bottom:1.1rem; }
.footer a { display:block; padding:.32rem 0; font-size:.86rem; transition:color var(--t-base); }
@media (hover:hover){ .footer a:hover{ color:#fff; } }
.footer__brand .logo__txt { color:#fff; }
.footer__brand p { font-size:.86rem; margin:1rem 0; max-width:38ch; }
.footer__contact li { display:flex; gap:.6rem; font-size:.86rem; padding:.32rem 0; }
.footer__contact svg { color:var(--brand); width:18px; flex-shrink:0; }
.footer__bottom { border-top:1px solid rgba(255,255,255,.1); padding:18px 0; font-size:.78rem; display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; }

/* ============================================================ FLOATING ACTIONS */
.fab { position:fixed; right:clamp(12px,2.5vw,22px); bottom:clamp(12px,2.5vw,22px); bottom:calc(clamp(12px,2.5vw,22px) + env(safe-area-inset-bottom,0px)); display:flex; flex-direction:column; gap:12px; z-index:95; }
.fab a, .fab button { width:clamp(48px,11vw,56px); height:clamp(48px,11vw,56px); border-radius:50%; display:grid; place-items:center; color:#fff; box-shadow:var(--shadow-lg); transition:transform var(--t-base), box-shadow var(--t-base); }
.fab svg { width:46%; height:46%; }
.fab a:active, .fab button:active { transform:scale(.92); }
@media (hover:hover){ .fab a:hover, .fab button:hover { transform:translateY(-2px); } }
.fab__wa { background:#25d366; }
.fab__top { background:var(--ink); opacity:0; pointer-events:none; transform:translateY(8px); transition:opacity var(--t-base), transform var(--t-base); }
.fab__top.show { opacity:1; pointer-events:auto; transform:none; }

/* ============================================================ UTILITIES */
.hide { display:none!important; }
.empty { text-align:center; padding:60px 20px; color:var(--ink-3); }
.spinner { width:34px; height:34px; border:3px solid var(--line); border-top-color:var(--brand); border-radius:50%; margin:50px auto; animation:spin .8s linear infinite; }
@keyframes spin { to{ transform:rotate(360deg); } }

/* ============================================================ CROMWELL SUB-BRANDS */
.subbrand-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:clamp(10px,1.4vw,16px); }
.subbrand { background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:16px 14px 14px; display:flex; flex-direction:column; align-items:center; text-align:center; gap:.35rem; transition:border-color var(--t-base), box-shadow var(--t-base), transform var(--t-base); }
.subbrand__logo { height:46px; display:grid; place-items:center; }
.subbrand__logo img { max-height:46px; max-width:122px; width:auto; object-fit:contain; transition:transform var(--t-base); }
.subbrand__logo b { font-family:var(--font-display); font-weight:400; font-size:1.35rem; color:var(--ink-2); }
.subbrand__name { font-weight:600; font-size:.84rem; line-height:1.2; color:var(--ink); }
.subbrand__count { font-size:.68rem; color:var(--ink-3); }
.subbrand:active { transform:scale(.99); }
@media (hover:hover){ .subbrand:hover { border-color:var(--theme); box-shadow:var(--shadow-mid); transform:translateY(-3px); } .subbrand:hover .subbrand__logo img { transform:scale(1.08); } }

/* ============================================================ BRAND PAGE HERO */
.brandhero { background:var(--theme); color:var(--theme-on); }
.brandhero__in { display:flex; align-items:center; gap:clamp(20px,3.5vw,48px); padding:clamp(28px,4vw,56px) 0; }
.brandhero__logo { background:#fff; border-radius:var(--radius); padding:18px 28px; min-width:170px; min-height:96px; display:grid; place-items:center; flex-shrink:0; box-shadow:var(--shadow-mid); }
.brandhero__logo img { max-height:66px; max-width:190px; object-fit:contain; }
.brandhero__logo span { font-family:var(--font-display); font-size:2.1rem; color:var(--ink); }
.brandhero__body h1 { font-family:var(--font-display); font-weight:400; font-size:clamp(2.4rem,5vw,4.2rem); text-transform:uppercase; letter-spacing:.02em; line-height:.95; color:var(--theme-on); }
.brandhero__body p { opacity:.92; margin:.5rem 0 1.3rem; font-size:1.02rem; }
.brandhero .btn--theme { background:#fff; color:var(--theme-ink); }
@media (hover:hover){ .brandhero .btn--theme:hover{ filter:none; background:#f1f1f1; } }
@media (max-width:680px){ .brandhero__in { flex-direction:column; align-items:flex-start; } }

/* brand-page search */
.brandsearch { position:relative; margin-bottom:1.2rem; max-width:520px; }
.brandsearch svg { position:absolute; left:14px; top:50%; transform:translateY(-50%); width:18px; height:18px; color:var(--ink-3); }
.brandsearch input { width:100%; height:46px; border:1.5px solid var(--line); border-radius:var(--radius-sm); padding:0 16px 0 42px; font-size:.92rem; transition:border-color var(--t-base); }
.brandsearch input:focus { border-color:var(--theme); outline:none; }

/* ============================================================ PRODUCT DETAIL */
.pdp { display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1fr); gap:clamp(24px,4vw,56px); align-items:start; margin:1rem 0 2.4rem; }
.pdp__gallery { position:sticky; top:130px; }
.pdp__main { position:relative; aspect-ratio:4/5; max-height:78vh; background:#fff; border:1px solid var(--line); border-radius:var(--radius); display:grid; place-items:center; padding:clamp(20px,3vw,44px); overflow:hidden; }
.pdp__main img { width:100%; height:100%; object-fit:contain; object-position:center; mix-blend-mode:multiply; cursor:zoom-in; }
.pdp__zoom { position:absolute; right:12px; bottom:12px; width:40px; height:40px; border-radius:50%; background:#fff; border:1px solid var(--line); display:grid; place-items:center; color:var(--ink); box-shadow:var(--shadow); }
.pdp__thumbs { display:flex; gap:10px; margin-top:12px; flex-wrap:wrap; }
.pdp__thumb { width:64px; height:64px; border:1px solid var(--line); border-radius:var(--radius-sm); padding:6px; background:#fff; transition:border-color var(--t-base); }
.pdp__thumb img { width:100%; height:100%; object-fit:contain; mix-blend-mode:multiply; }
.pdp__thumb.is-active { border-color:var(--theme); border-width:2px; }
@media (hover:hover){ .pdp__thumb:hover{ border-color:var(--ink-3); } }

.pdp__brandtag { display:inline-flex; align-items:center; gap:.55rem; font-family:var(--font-mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--theme); font-weight:500; }
.pdp__brandlogo { height:40px; width:auto; max-width:140px; object-fit:contain; }
.pdp__variation { margin:1.1rem 0 .2rem; }
.pdp__variation label { display:block; font-size:.8rem; font-weight:700; margin-bottom:.4rem; text-transform:uppercase; letter-spacing:.04em; color:var(--ink-2); }
.pdp__variation select { width:100%; max-width:340px; border:1.5px solid var(--line); border-radius:var(--radius-sm); padding:.75rem .85rem; font-size:1rem; background:#fff; cursor:pointer; transition:border-color var(--t-base); }
.pdp__variation select:focus { outline:none; border-color:var(--theme); }
/* colour swatch picker */
.pdp__variation--swatch label { text-transform:none; letter-spacing:0; font-size:.95rem; font-weight:600; color:var(--ink-2); }
.pdp__variation--swatch .pdp__varname { color:var(--ink); font-weight:700; }
.pdp__swgroup { margin-top:.6rem; }
.pdp__swglabel { display:block; font-size:.7rem; font-weight:600; text-transform:uppercase; letter-spacing:.05em; color:var(--ink-3); margin:.4rem 0 .3rem; }
.pdp__swatches { display:flex; flex-wrap:wrap; gap:.25rem; }
.pdp__swatch { min-width:44px; min-height:44px; display:inline-flex; align-items:center; justify-content:center; padding:0; border:none; background:none; cursor:pointer; border-radius:50%; }
.pdp__chip { display:block; width:30px; height:30px; border-radius:50%; box-shadow:inset 0 0 0 1px rgba(0,0,0,.18), 0 1px 2px rgba(0,0,0,.12); transition:transform var(--t-fast); }
@media (hover:hover) and (pointer:fine) { .pdp__swatch:hover .pdp__chip { transform:scale(1.12); } }
.pdp__swatch:active .pdp__chip { transform:scale(.94); }
.pdp__swatch.is-active .pdp__chip,
.pdp__swatch:focus-visible .pdp__chip { box-shadow:inset 0 0 0 1px rgba(0,0,0,.18), 0 0 0 2px #fff, 0 0 0 4px var(--theme); }
.pdp__swatch:focus-visible { outline:none; }
.pdp__title { font-size:clamp(1.5rem,2.6vw,2.1rem); font-weight:700; line-height:1.18; margin:.5rem 0 .8rem; }
.pdp__ids { display:flex; flex-wrap:wrap; gap:.4rem 1.4rem; font-size:.8rem; color:var(--ink-3); padding-bottom:1rem; border-bottom:1px solid var(--line); margin-bottom:1rem; }
.pdp__ids b { color:var(--ink); font-weight:600; }
.pdp__price { font-size:1.9rem; font-weight:800; margin:.7rem 0; }
.pdp__price small { font-size:.8rem; font-weight:500; color:var(--ink-3); }
.pdp__rfq { display:inline-flex; align-items:center; gap:.5rem; font-weight:700; color:var(--theme); background:var(--bg-2); padding:.7rem 1rem; border-radius:var(--radius-sm); margin:.7rem 0; font-size:1rem; }
.pdp__buy { display:flex; gap:.7rem; align-items:stretch; margin-top:1rem; }
.pdp__qty { height:auto; }
.pdp__qty input { width:54px; text-align:center; border:none; font-family:var(--font-mono); font-size:.95rem; -moz-appearance:textfield; }
.pdp__qty input::-webkit-outer-spin-button, .pdp__qty input::-webkit-inner-spin-button { -webkit-appearance:none; margin:0; }
.pdp__buy .btn { flex:1; }
.pdp__trade { display:flex; gap:.8rem; align-items:center; margin-top:1.4rem; padding:1rem; background:var(--bg-2); border-radius:var(--radius); }
.pdp__trade svg { color:var(--theme); width:26px; flex-shrink:0; }
.pdp__trade b { display:block; font-size:.9rem; } .pdp__trade span { font-size:.8rem; color:var(--ink-3); }

.pdp__tabs { margin-top:1rem; }
.tabbar { display:flex; gap:2px; border-bottom:2px solid var(--line); overflow-x:auto; scrollbar-width:none; }
.tabbar::-webkit-scrollbar { display:none; }
.tab { padding:.85rem 1.3rem; font-weight:700; font-size:.92rem; color:var(--ink-3); border-bottom:3px solid transparent; margin-bottom:-2px; white-space:nowrap; transition:color var(--t-base), border-color var(--t-base); }
.tab.is-active { color:var(--ink); border-bottom-color:var(--theme); }
@media (hover:hover){ .tab:not(.is-active):hover{ color:var(--ink-2); } }
@media (max-width:600px){
  .tabbar { overflow-x:visible; gap:0; }
  .tab { flex:1; padding:.7rem .35rem; font-size:.76rem; white-space:normal; text-align:center; line-height:1.2; }
}
.tabpanel { display:none; padding:1.6rem 0; max-width:900px; }
.tabpanel.is-active { display:block; }
.pdp__desc { white-space:pre-line; color:var(--ink-2); line-height:1.7; }
.tabpanel p, .tabpanel li { color:var(--ink-2); line-height:1.7; }
.tabpanel p { margin:0 0 .8rem; }
.tabpanel ul { padding-left:1.2rem; list-style:disc; margin:.6rem 0; }
.tabpanel h2, .tabpanel h3, .tabpanel h4 { color:var(--ink); font-size:1.04rem; font-weight:700; line-height:1.3; margin:1.5rem 0 .55rem; }
.tabpanel > :first-child { margin-top:0; }

.spectable { width:100%; border-collapse:collapse; }
.spectable th, .spectable td { text-align:left; padding:.7rem 1rem; border-bottom:1px solid var(--line); font-size:.88rem; vertical-align:top; }
.spectable th { width:38%; color:var(--ink-3); font-weight:600; background:var(--bg-2); }
.spectable td { color:var(--ink); font-family:var(--font-mono); font-size:.84rem; }

.pdp__docs { display:flex; flex-direction:column; gap:8px; max-width:520px; }
.pdp__doc { display:flex; align-items:center; gap:.7rem; padding:.9rem 1rem; border:1px solid var(--line); border-radius:var(--radius-sm); font-weight:600; font-size:.88rem; transition:border-color var(--t-base), background var(--t-base); }
.pdp__doc svg { color:var(--theme); width:20px; }
@media (hover:hover){ .pdp__doc:hover{ border-color:var(--theme); background:var(--bg-2); } }

.lightbox { position:fixed; inset:0; background:rgba(10,12,15,.9); z-index:150; display:none; place-items:center; padding:40px; }
.lightbox.open { display:grid; }
.lightbox img { max-width:90vw; max-height:88vh; object-fit:contain; }
.lightbox__x { position:absolute; top:20px; right:20px; width:46px; height:46px; border-radius:50%; background:rgba(255,255,255,.15); color:#fff; display:grid; place-items:center; }

@media (max-width:860px){
  .pdp { grid-template-columns:1fr; }
  .pdp__gallery { position:static; }
}

/* ============================================================ QUOTE PAGE + FORMS */
.card { background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:clamp(18px,2.5vw,28px); }
.quote-layout { display:grid; grid-template-columns:minmax(0,1fr) 380px; gap:clamp(20px,2.5vw,32px); align-items:start; margin-bottom:3rem; }
.quote-items__head h2 { font-family:var(--font-display); font-weight:400; font-size:1.5rem; text-transform:uppercase; letter-spacing:.02em; margin-bottom:.6rem; }
.qrow { display:flex; gap:14px; align-items:center; padding:14px 0; border-bottom:1px solid var(--line-2); }
.qrow:last-child { border-bottom:none; }
.qrow__img { width:64px; height:64px; flex-shrink:0; background:var(--bg-2); border-radius:var(--radius-sm); display:grid; place-items:center; overflow:hidden; }
.qrow__img img { width:100%; height:100%; object-fit:contain; mix-blend-mode:multiply; }
.qrow__main { flex:1; min-width:0; }
.qrow__name { font-size:.9rem; font-weight:600; line-height:1.3; display:block; }
.qrow__sku { font-size:.72rem; color:var(--ink-3); }
.qrow__right { display:flex; align-items:center; gap:14px; flex-shrink:0; }
.qrow__price { font-weight:800; font-size:.95rem; min-width:70px; text-align:right; }
.qrow__rfq { color:var(--brand); font-weight:700; font-size:.78rem; }
.qrow__rm { width:34px; height:34px; display:grid; place-items:center; color:var(--ink-3); border-radius:var(--radius-sm); transition:color var(--t-base), background var(--t-base); }
@media (hover:hover){ .qrow__rm:hover{ color:var(--brand); background:var(--bg-2); } }
@media (max-width:520px){ .qrow{ flex-wrap:wrap; } .qrow__right{ width:100%; justify-content:space-between; } }

.quote-side { position:sticky; top:130px; }
.quote-layout--wide { grid-template-columns:minmax(0,.82fr) minmax(0,1.18fr); }
.formgrid { display:grid; grid-template-columns:1fr 1fr; gap:0 16px; }
.formgrid .fg--full { grid-column:1 / -1; }
@media (max-width:1024px){ .quote-layout--wide { grid-template-columns:minmax(0,1fr) minmax(0,1.25fr); } }
@media (max-width:860px){ .quote-layout--wide { grid-template-columns:1fr; } }
@media (max-width:520px){ .formgrid { grid-template-columns:1fr; } }
.quote-form h2 { font-family:var(--font-display); font-weight:400; font-size:1.5rem; text-transform:uppercase; letter-spacing:.02em; margin-bottom:1rem; }
.fg { margin-bottom:1rem; }
.fg label { display:block; font-size:.82rem; font-weight:600; margin-bottom:.35rem; }
.fg input, .fg textarea, .fg select { width:100%; border:1.5px solid var(--line); border-radius:var(--radius-sm); padding:.7rem .8rem; font-size:1rem; transition:border-color var(--t-base); background:#fff; }
.fg input:focus, .fg textarea:focus, .fg select:focus { outline:none; border-color:var(--brand); }
.fg textarea { resize:vertical; }
.consent { display:flex; align-items:flex-start; gap:.5rem; font-size:.8rem; color:var(--ink-2); margin:.4rem 0 1rem; line-height:1.4; }
.consent input { margin-top:2px; width:16px; height:16px; flex-shrink:0; }
.methodtoggle { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.method { display:flex; align-items:center; justify-content:center; gap:.45rem; padding:.78rem; border:1.5px solid var(--line); border-radius:var(--radius-sm); font-weight:700; font-size:.88rem; color:var(--ink-2); background:#fff; cursor:pointer; transition:border-color var(--t-base), background var(--t-base), color var(--t-base); }
.method.is-active { border-color:var(--brand); background:var(--brand); color:#fff; }
.method:active { transform:scale(.98); }
@media (hover:hover){ .method:not(.is-active):hover{ border-color:var(--ink-3); } }
.fg.has-error input, .fg.has-error textarea, .fg.has-error select { border-color:var(--brand); background:#fff5f5; }
.fg__err { display:block; color:var(--brand); font-size:.76rem; font-weight:600; margin-top:.35rem; }
.consent.has-error { color:var(--brand); }
.consent-err { display:block; color:var(--brand); font-size:.78rem; font-weight:700; margin:.2rem 0; }
.consent-err:empty { display:none; }
.form-msg { font-size:.82rem; margin-top:.7rem; text-align:center; }
.form-msg.is-err { color:var(--brand); } .form-msg.is-ok { color:#16a34a; }
.rfq-done { text-align:center; padding:1rem 0 .25rem; }
.rfq-done__check { display:inline-flex; align-items:center; justify-content:center; width:60px; height:60px; border-radius:50%; background:#dcfce7; color:#15803d; margin-bottom:1.1rem; }
.rfq-done__check svg { width:28px; height:28px; stroke-width:3; }
.rfq-done h2 { font-family:var(--font-display); font-weight:400; font-size:1.8rem; text-transform:uppercase; letter-spacing:.01em; margin:0 0 .5rem; }
.rfq-done__lead { color:var(--ink-2); max-width:36ch; margin:0 auto 1.4rem; line-height:1.6; }
.rfq-done__ref { display:inline-flex; flex-direction:column; align-items:center; gap:.1rem; padding:.7rem 1.6rem; background:var(--bg-2); border:1px solid var(--line); border-radius:12px; margin-bottom:1.4rem; }
.rfq-done__ref span { font-family:var(--font-mono); font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); }
.rfq-done__ref b { font-family:var(--font-mono); font-size:1.3rem; letter-spacing:.04em; color:var(--ink); white-space:nowrap; }
.rfq-done__next { list-style:none; margin:0 auto 1.5rem; padding:0; display:flex; flex-direction:column; gap:.55rem; text-align:left; max-width:340px; }
.rfq-done__next li { display:flex; align-items:flex-start; gap:.6rem; color:var(--ink-2); font-size:.9rem; line-height:1.45; }
.rfq-done__next svg { width:16px; height:16px; color:var(--ink-3); flex:none; margin-top:.15rem; }
.rfq-done__next b { color:var(--ink); }
@media (max-width:860px){ .quote-layout { grid-template-columns:1fr; } .quote-side { position:static; } }

/* generic two-column form layout (contact / e-proc) */
.formgrid { display:grid; grid-template-columns:1fr 1fr; gap:0 18px; }
@media (max-width:560px){ .formgrid { grid-template-columns:1fr; } }
.fg--full { grid-column:1 / -1; }

/* ============================================================ ABOUT / CONTACT */
.about-hero { margin:0 0 clamp(24px,3.5vw,44px); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-mid); }
.about-hero img { width:100%; height:auto; display:block; }
.awards-grid { display:flex; flex-wrap:wrap; justify-content:center; gap:clamp(12px,1.8vw,22px); }
.award { flex:0 1 clamp(150px,30%,250px); background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:clamp(16px,2vw,26px); aspect-ratio:1; display:grid; place-items:center; transition:box-shadow var(--t-base), transform var(--t-base); }
.award img { max-width:100%; max-height:100%; object-fit:contain; }
@media (hover:hover){ .award:hover{ box-shadow:var(--shadow-mid); transform:translateY(-3px); } }
@media (max-width:680px){ .award { flex-basis:calc(50% - 11px); } }
.about-grid { display:grid; grid-template-columns:1.4fr 1fr; gap:clamp(24px,4vw,56px); align-items:start; margin-bottom:1rem; }
.about-copy p { color:var(--ink-2); font-size:1.02rem; margin-bottom:1rem; line-height:1.75; }
.about-stats { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.astat { background:var(--bg-2); border-radius:var(--radius); padding:22px; text-align:center; }
.astat__n { display:block; font-size:clamp(2.2rem,4vw,3.2rem); color:var(--brand); line-height:1; }
.astat__n small { font-size:.5em; }
.astat__l { font-size:.82rem; color:var(--ink-2); font-weight:600; margin-top:.3rem; display:block; }
@media (max-width:768px){ .about-grid { grid-template-columns:1fr; } }

.values-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(12px,1.6vw,18px); }
@media (max-width:860px){ .values-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .values-grid{ grid-template-columns:1fr; } }
.value { border:1px solid var(--line); border-radius:var(--radius); padding:22px; transition:border-color var(--t-base), box-shadow var(--t-base); }
.value svg { width:30px; height:30px; color:var(--brand); margin-bottom:.8rem; }
.value h3 { font-size:1.05rem; margin-bottom:.35rem; }
.value p { font-size:.88rem; color:var(--ink-2); line-height:1.55; }
@media (hover:hover){ .value:hover{ border-color:var(--ink-3); box-shadow:var(--shadow); } }

.contact-grid { display:grid; grid-template-columns:1.3fr 380px; gap:clamp(22px,3vw,40px); align-items:start; margin-bottom:3rem; }
.cinfo { display:flex; align-items:center; gap:14px; padding:14px; border:1px solid var(--line); border-radius:var(--radius); margin-bottom:12px; transition:border-color var(--t-base), box-shadow var(--t-base); }
.cinfo__ic { width:46px; height:46px; border-radius:var(--radius-sm); background:var(--brand); color:#fff; display:grid; place-items:center; flex-shrink:0; }
.cinfo__ic svg { width:22px; }
.cinfo b { display:block; font-size:.95rem; } .cinfo span { font-size:.84rem; color:var(--ink-3); }
@media (hover:hover){ .cinfo:hover{ border-color:var(--ink-3); box-shadow:var(--shadow); } }
.contact-map { margin-top:8px; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); }
.contact-map iframe { display:block; }
@media (max-width:860px){ .contact-grid { grid-template-columns:1fr; } }

/* ============================================================ PAGE REDESIGN — shared (eproc / about / contact) */
.pagehead__eyebrow { display:block; font-family:var(--font-mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--brand); font-weight:500; margin-bottom:.8rem; }
.pagehead--lead .pagehead__title::before { display:none; }
.lead { color:var(--ink-2); font-size:clamp(1rem,1.3vw,1.12rem); line-height:1.7; max-width:64ch; }

/* e-procurement two-column hero */
.eproc-hero { display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(28px,4.5vw,64px); align-items:center; }
.eproc-hero .pagehead { margin:0; }
.eproc-hero__media { position:relative; }
.eproc-hero__media::before { content:""; position:absolute; right:-16px; bottom:-16px; width:58%; height:62%; background:var(--brand); border-radius:var(--radius); z-index:0; }
.eproc-hero__media::after { content:""; position:absolute; left:-16px; top:-16px; width:42%; height:42%; border:1px solid var(--line); border-radius:var(--radius); z-index:0; }
.eproc-hero__media img { position:relative; z-index:1; width:100%; aspect-ratio:5/4; object-fit:cover; display:block; border-radius:var(--radius); box-shadow:var(--shadow-lg); }
@media (max-width:860px){
  .eproc-hero { grid-template-columns:1fr; gap:clamp(24px,5vw,36px); }
  .eproc-hero__media { max-width:480px; margin:0 auto; }
}

/* feature / benefit cards (icon chip + title + text) */
.feature-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(12px,1.6vw,18px); }
.feature { border:1px solid var(--line); border-radius:var(--radius); padding:clamp(20px,2.4vw,28px); background:#fff; transition:border-color var(--t-base), box-shadow var(--t-base), transform var(--t-base); }
.feature__ic { width:46px; height:46px; border-radius:var(--radius-sm); background:var(--brand); color:#fff; display:grid; place-items:center; margin-bottom:1rem; }
.feature__ic svg { width:22px; height:22px; }
.feature h3 { font-size:1.05rem; margin-bottom:.4rem; }
.feature p { font-size:.9rem; color:var(--ink-2); line-height:1.6; }
@media (hover:hover){ .feature:hover{ border-color:var(--ink-3); box-shadow:var(--shadow-mid); transform:translateY(-3px); } }
@media (max-width:880px){ .feature-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:540px){ .feature-grid{ grid-template-columns:1fr; } }

/* numbered process steps */
.steps { display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(16px,2.4vw,32px); }
.step { position:relative; min-width:0; padding-top:1.2rem; border-top:3px solid var(--line); }
.step__img { width:100%; height:auto; aspect-ratio:16/10; object-fit:cover; border-radius:var(--radius); background:var(--ink-soft,#f3f4f6); display:block; margin-bottom:1rem; }
.step__n { font-family:var(--font-display); font-weight:400; font-size:clamp(2.2rem,3.6vw,3rem); color:var(--brand); line-height:1; display:block; margin-bottom:.6rem; }
.step h3 { font-size:1.05rem; margin-bottom:.4rem; }
.step p { font-size:.9rem; color:var(--ink-2); line-height:1.6; }
@media (max-width:880px){ .steps{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .steps{ grid-template-columns:1fr; } }

/* dark band (explainer) */
.darkband { background:var(--ink-panel); color:#fff; border-radius:var(--radius); padding:clamp(28px,4.5vw,64px); }
.darkband__grid { display:grid; grid-template-columns:1fr 1fr; gap:clamp(24px,4vw,56px); align-items:center; }
.darkband h2 { font-family:var(--font-display); font-weight:400; font-size:clamp(2rem,4vw,3.2rem); text-transform:uppercase; line-height:.95; color:#fff; margin-bottom:1rem; }
.darkband p { color:#c4cad2; font-size:.98rem; margin-bottom:.9rem; }
.darkband__points { display:grid; gap:14px; }
.darkband__pt { display:flex; gap:12px; align-items:flex-start; }
.darkband__pt i, .darkband__pt svg { color:var(--brand); flex-shrink:0; width:22px; height:22px; margin-top:2px; }
.darkband__pt b { display:block; color:#fff; font-size:1rem; }
.darkband__pt span { color:#aeb5be; font-size:.88rem; }
@media (max-width:768px){ .darkband__grid{ grid-template-columns:1fr; } }

/* ERP / compatibility strip */
.chipstrip { display:flex; flex-wrap:wrap; gap:10px; align-items:center; }
.chipstrip__item { font-family:var(--font-mono); font-size:.82rem; letter-spacing:.03em; color:var(--ink-2); border:1px solid var(--line); border-radius:100px; padding:.5rem 1rem; background:#fff; }

/* statement band (about) */
.statement { background:var(--ink-panel); color:#fff; border-radius:var(--radius); padding:clamp(40px,6.5vw,84px) clamp(24px,5vw,64px); text-align:center; }
.statement__line { font-family:var(--font-display); font-weight:400; font-size:clamp(2.2rem,5.4vw,4.2rem); text-transform:uppercase; line-height:1.04; letter-spacing:.01em; color:#fff; max-width:20ch; margin:0 auto; }
.statement__hl { color:var(--brand); }
.statement__sub { display:block; margin:1.3rem auto 0; max-width:56ch; color:#c4cad2; font-size:clamp(.95rem,1.2vw,1.05rem); line-height:1.65; }

/* centered CTA band */
.cta-band { text-align:center; background:var(--bg-2); border-radius:var(--radius); padding:clamp(32px,5vw,64px); }
.cta-band h2 { font-family:var(--font-display); font-weight:400; font-size:clamp(2rem,4.5vw,3.2rem); text-transform:uppercase; line-height:.95; }
.cta-band p { color:var(--ink-2); max-width:54ch; margin:.7rem auto 1.5rem; }
.cta-band__btns { display:flex; gap:.8rem; justify-content:center; flex-wrap:wrap; }

/* About: photographic backgrounds with readability scrim */
body[data-page="about"] .statement {
  background-image:linear-gradient(rgba(16,19,24,.72), rgba(16,19,24,.84)), url('assets/bg-statement.png');
  background-size:cover; background-position:center;
}
body[data-page="about"] .cta-band {
  background-image:linear-gradient(rgba(244,246,248,.80), rgba(244,246,248,.88)), url('assets/bg-cta.png');
  background-size:cover; background-position:center;
}

/* E-procurement partner section background (left-weighted scrim keeps text legible) */
#partner {
  background-image:linear-gradient(90deg, rgba(244,246,248,.95) 0%, rgba(244,246,248,.88) 42%, rgba(244,246,248,.62) 100%), url('assets/bg-partner.png');
  background-size:cover; background-position:center right; background-repeat:no-repeat;
}
@media (max-width:860px){
  #partner { background-image:linear-gradient(rgba(244,246,248,.92), rgba(244,246,248,.92)), url('assets/bg-partner.png'); }
}

/* contact channel cards */
.channel-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(12px,1.5vw,16px); margin-bottom:clamp(22px,3vw,36px); }
.channel { display:flex; align-items:center; gap:13px; padding:clamp(15px,1.7vw,19px); border:1px solid var(--line); border-radius:var(--radius); background:#fff; transition:border-color var(--t-base), box-shadow var(--t-base), transform var(--t-base); }
.channel__ic { width:46px; height:46px; border-radius:var(--radius-sm); background:var(--brand); display:grid; place-items:center; flex-shrink:0; }
.channel__ic svg { width:22px; height:22px; color:#fff; stroke:#fff; }
.channel__ic--wa { background:#25d366; }
.channel__txt { display:flex; flex-direction:column; min-width:0; }
.channel__txt b { font-size:.96rem; color:var(--ink); line-height:1.2; }
.channel__txt span { font-size:.83rem; color:var(--ink-3); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; margin-top:2px; }
.channel__go { width:16px; height:16px; color:var(--ink-3); margin-left:auto; flex-shrink:0; transition:transform var(--t-base) var(--ease-out), color var(--t-base); }
@media (hover:hover){ .channel:hover{ border-color:var(--ink-3); box-shadow:var(--shadow-mid); transform:translateY(-3px); } .channel:hover .channel__go{ color:var(--brand); transform:translate(2px,-2px); } }
@media (max-width:860px){ .channel-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:420px){ .channel-grid{ grid-template-columns:1fr; } }

/* contact two-column (form + map/info) */
.contact-cols { display:grid; grid-template-columns:1fr 1fr; gap:clamp(20px,3vw,40px); align-items:start; margin-bottom:3rem; }
.contact-aside { display:flex; flex-direction:column; gap:16px; }
.infocard { border:1px solid var(--line); border-radius:var(--radius); padding:clamp(18px,2.2vw,24px); }
.infocard h3 { font-size:1.05rem; margin-bottom:.5rem; display:flex; align-items:center; gap:.5rem; }
.infocard h3 svg { width:18px; height:18px; color:var(--brand); }
.infocard p { font-size:.9rem; color:var(--ink-2); line-height:1.6; }
@media (max-width:860px){ .contact-cols{ grid-template-columns:1fr; } }

/* ============================================================ RESPONSIVE */
/* Category grid is redundant on desktop (left rail covers it) — show only when rail is hidden */
.cat-section { display:none; }
@media (max-width:1024px){
  .shell { grid-template-columns:1fr; }
  .rail { position:static; display:none; }       /* rail folds into nav drawer on tablet/mobile */
  .cat-section { display:block; }
  .eproc__feats { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:860px){
  .slide { grid-template-columns:1fr; text-align:left; }
  .slide__visual { display:none; }
  .eproc__top { grid-template-columns:1fr; }
}
@media (max-width:768px){
  .header__in { grid-template-columns:1fr auto; height:auto; gap:10px; padding:10px var(--gutter); }
  .logo { grid-row:1; grid-column:1; }
  .header__actions { grid-row:1; grid-column:2; }
  .search { grid-row:2; grid-column:1 / -1; max-width:none; margin:0; }
  .mainnav { display:none; }
  .burger { display:grid; place-items:center; width:46px; height:46px; }
  .iconbtn__label { display:none; }
  .promos { grid-template-columns:1fr; }
  /* footer: brand full-width, the three link columns share one row */
  .footer__grid { grid-template-columns:repeat(3,1fr); gap:1.2rem 1rem; }
  .footer__brand { grid-column:1 / -1; }
  .footer__grid h5 { font-size:.7rem; }
  .footer__grid a { font-size:.82rem; }
}
@media (max-width:480px){
  .prod-grid { grid-template-columns:repeat(2,1fr); }
  .quotebtn span.hide-sm { display:none; }
}

/* ============================================================ MOBILE CARD GRIDS (2-up) + section trims */
@media (max-width:768px){
  /* card grids: two per row instead of one */
  .feature-grid { grid-template-columns:1fr 1fr; }
  .steps { grid-template-columns:1fr 1fr; }
  .values-grid { grid-template-columns:1fr 1fr; }
  .feature, .value { padding:16px 14px; }
  .feature__ic, .value svg { margin-bottom:.6rem; }
  /* homepage Procurement section: shorter (2-up features already; trim the intro) */
  .eproc__top p[data-i18n="eproc.p2"] { display:none; }
  .efeat { padding:16px 14px; }
  .efeat p { font-size:.8rem; }
  /* contact channel cards: allow shrink so they don't overflow the row */
  .channel { min-width:0; }
}
@media (max-width:420px){
  .feature, .value, .efeat, .step { font-size:.95rem; }
}

/* ============================================================ TRUST STRIP MARQUEE (mobile only) */
.trust__dupe { display:none; }
@media (max-width:768px){
  .trust { overflow:hidden;
    -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
    mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); }
  .trust__in { max-width:none; width:max-content; padding:0; gap:0; overflow:visible; animation:trustscroll 24s linear infinite; }
  .trust__dupe { display:flex; }
  .trust__item { margin-right:32px; }
}
@keyframes trustscroll { from{ transform:translateX(0); } to{ transform:translateX(-50%); } }

/* ============================================================ LISTING (shop / brand) */
.crumb { display:flex; align-items:center; gap:.4rem; flex-wrap:wrap; font-size:.78rem; color:var(--ink-3); margin-bottom:1rem; }
.crumb a { color:var(--ink-3); transition:color var(--t-base); }
.crumb a:hover { color:var(--brand); }
.crumb span { color:var(--ink); font-weight:600; }
.crumb svg { width:13px; height:13px; opacity:.5; }

.listhead { display:flex; align-items:flex-end; justify-content:space-between; gap:1rem; margin-bottom:1.2rem; flex-wrap:wrap; }
.listhead__title { font-family:var(--font-display); font-weight:400; font-size:clamp(1.9rem,3.4vw,2.8rem); text-transform:uppercase; letter-spacing:.01em; line-height:1; }
.listhead__title::before { content:""; display:block; width:40px; height:4px; background:var(--brand); border-radius:2px; margin-bottom:.5rem; }
.listhead__count { font-size:.78rem; color:var(--ink-3); margin-top:.35rem; }
.sortbox { font-size:.78rem; color:var(--ink-3); display:flex; align-items:center; gap:.5rem; font-weight:600; }
.sortbox select { border:1px solid var(--line); border-radius:var(--radius-sm); padding:.5rem .7rem; font-size:.84rem; font-weight:600; color:var(--ink); background:#fff; cursor:pointer; }

.rail__subs { margin:.1rem 0 .5rem .9rem; padding-left:.6rem; border-left:1px solid var(--line); }
.rail__subs a { padding:.4rem .5rem; font-size:.8rem; border-left:none; }
.rail__subs a.is-active { color:var(--brand); font-weight:700; }
.rail__subs--l3 { margin:.1rem 0 .45rem .55rem; padding-left:.55rem; border-left:1px dashed var(--line); }
.rail__subs--l3 a { padding:.32rem .5rem; font-size:.76rem; color:var(--ink-3); }
.rail__subs--l3 a.is-active { color:var(--brand); font-weight:700; }
.rail__ico { width:28px; height:28px; object-fit:contain; mix-blend-mode:multiply; flex-shrink:0; background:var(--bg-2); border-radius:4px; padding:2px; }

/* ---- shop filter bar ---- */
.filterbar { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:14px; }
.filterbar:empty { display:none; }
.filt { position:relative; }
.filt > summary { list-style:none; cursor:pointer; display:inline-flex; align-items:center; gap:.5rem; padding:.6rem 1rem; border:1.5px solid var(--line); border-radius:100px; font-size:.85rem; font-weight:600; color:var(--ink); background:#fff; user-select:none; transition:border-color var(--t-base), background var(--t-base); }
.filt > summary::-webkit-details-marker { display:none; }
.filt > summary svg { width:15px; height:15px; transition:transform var(--t-base) var(--ease-out); }
.filt[open] > summary { border-color:var(--ink); }
.filt[open] > summary svg { transform:rotate(180deg); }
@media (hover:hover){ .filt > summary:hover { border-color:var(--ink-3); } }
.filt__panel { position:absolute; top:calc(100% + 6px); left:0; z-index:60; width:max-content; max-width:min(86vw,300px); background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-lg); padding:12px; }
.filt__search { width:100%; border:1.5px solid var(--line); border-radius:var(--radius-sm); padding:.5rem .65rem; font-size:.9rem; margin-bottom:8px; }
.filt__search:focus { outline:none; border-color:var(--brand); }
.filt__opts { display:flex; flex-direction:column; gap:2px; max-height:280px; overflow-y:auto; }
.filt__opts label { display:flex; align-items:center; gap:.55rem; padding:.4rem .45rem; border-radius:var(--radius-sm); font-size:.86rem; cursor:pointer; transition:background var(--t-base); }
@media (hover:hover){ .filt__opts label:hover { background:var(--bg-2); } }
.filt__opts input { width:16px; height:16px; flex-shrink:0; accent-color:var(--brand); }
.filt__lbl { flex:1; min-width:0; }
.filt__ct { font-family:var(--font-mono); font-size:.72rem; color:var(--ink-3); }
.filt__range { display:flex; align-items:center; gap:6px; margin-top:10px; padding-top:10px; border-top:1px solid var(--line); }
.filt__range input { width:100%; min-width:0; border:1.5px solid var(--line); border-radius:var(--radius-sm); padding:.45rem .5rem; font-size:.86rem; }
.filt__range input:focus { outline:none; border-color:var(--brand); }
.filt__go { flex-shrink:0; background:var(--ink); color:#fff; font-weight:700; font-size:.8rem; padding:.5rem .9rem; border-radius:var(--radius-sm); transition:background var(--t-base), transform var(--t-fast); }
.filt__go:active { transform:scale(.95); }
@media (hover:hover){ .filt__go:hover { background:#000; } }

.filterchips { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:16px; }
.filterchips:empty { display:none; }
.chip { display:inline-flex; align-items:center; gap:.4rem; padding:.4rem .8rem; border-radius:100px; font-size:.8rem; font-weight:600; background:var(--bg-2); color:var(--ink); border:1px solid var(--line); transition:background var(--t-base), transform var(--t-fast); }
.chip svg { width:13px; height:13px; }
.chip:active { transform:scale(.95); }
@media (hover:hover){ .chip:hover { background:var(--bg-3); } }
.chip--clear { background:transparent; color:var(--brand); border-color:transparent; }
@media (hover:hover){ .chip--clear:hover { background:transparent; text-decoration:underline; } }

.pager { display:flex; align-items:center; justify-content:center; gap:.3rem; margin-top:2.4rem; flex-wrap:wrap; }
.pager__btn { min-width:40px; height:40px; padding:0 .5rem; border:1px solid var(--line); border-radius:var(--radius-sm); display:grid; place-items:center; font-weight:600; font-size:.86rem; color:var(--ink); background:#fff; transition:border-color var(--t-base), background var(--t-base), color var(--t-base); }
.pager__btn:active { transform:scale(.95); }
.pager__btn.is-active { background:var(--ink); color:#fff; border-color:var(--ink); }
.pager__btn[disabled] { opacity:.4; pointer-events:none; }
@media (hover:hover){ .pager__btn:not(.is-active):hover{ border-color:var(--ink); } }
.pager__dots { padding:0 .3rem; color:var(--ink-3); }

/* ============================================================ PAGE HEAD + BRAND DIRECTORY */
.pagehead { margin:1rem 0 2rem; max-width:760px; }
.pagehead__title { font-family:var(--font-display); font-weight:400; font-size:clamp(2.4rem,5vw,3.8rem); text-transform:uppercase; letter-spacing:.01em; line-height:1; }
.pagehead__title::before { content:""; display:block; width:52px; height:5px; background:var(--brand); border-radius:2px; margin-bottom:.9rem; }
.pagehead__sub { color:var(--ink-2); margin-top:.7rem; font-size:1rem; }

.brandfeat { margin-bottom:2.6rem; }
.brandfeat__h { font-family:var(--font-mono); font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); margin-bottom:1rem; }
.brandfeat__grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:clamp(12px,1.5vw,18px); }
.brandfeat__card { position:relative; border-radius:var(--radius); min-height:150px; display:flex; flex-direction:column; background:var(--theme); color:var(--theme-on); overflow:hidden; transition:transform var(--t-base), box-shadow var(--t-base); }
.brandfeat__logobox { flex:1; background:#fff; display:grid; place-items:center; padding:20px; }
.brandfeat__logobox img { max-height:56px; max-width:82%; width:auto; object-fit:contain; transition:transform var(--t-base); }
.brandfeat__logobox b { font-family:var(--font-display); font-weight:400; font-size:1.9rem; color:var(--ink); }
.brandfeat__cta { padding:13px 18px; font-size:.84rem; font-weight:700; display:flex; align-items:center; gap:.4rem; }
.brandfeat__card:active { transform:scale(.99); }
@media (hover:hover){ .brandfeat__card:hover{ transform:translateY(-3px); box-shadow:var(--shadow-mid); } .brandfeat__card:hover .brandfeat__cta{ gap:.7rem; } .brandfeat__card:hover .brandfeat__logobox img{ transform:scale(1.06); } }

/* Cromwell-as-hero: one large lead card + four stacked supporting cards */
.brandfeat__lead { display:grid; grid-template-columns:1.25fr 1fr; gap:clamp(12px,1.6vw,20px); align-items:stretch; }
.brandfeat__side { display:grid; grid-template-columns:1fr 1fr; grid-template-rows:1fr 1fr; gap:clamp(10px,1.2vw,14px); }
.brandfeat__card--hero { min-height:clamp(320px,38vw,460px); }
.brandfeat__card--hero .brandfeat__logobox { padding:clamp(28px,4vw,52px); }
.brandfeat__card--hero .brandfeat__logobox img { max-height:clamp(72px,9vw,120px); max-width:74%; }
.brandfeat__cta--hero { flex-direction:column; align-items:flex-start; gap:.45rem; padding:clamp(16px,2vw,22px) clamp(18px,2.2vw,24px); }
.brandfeat__cta--hero b { font-family:var(--font-display); font-weight:400; font-size:clamp(1.15rem,1.9vw,1.6rem); line-height:1.15; text-transform:uppercase; letter-spacing:.01em; }
.brandfeat__cta--hero > span { display:inline-flex; align-items:center; gap:.4rem; font-size:.84rem; opacity:.92; }
@media (hover:hover){ .brandfeat__card--hero:hover .brandfeat__cta--hero > span { gap:.7rem; } }
/* the four supporting cards: brand-colour band + enlarged logo, in a 2x2 */
.brandfeat__side .brandfeat__logobox { padding:clamp(10px,1.6vw,18px); }
.brandfeat__side .brandfeat__logobox img { max-height:clamp(58px,7.5vw,96px); max-width:90%; }
@media (max-width:767px){
  .brandfeat__lead { grid-template-columns:1fr; }
  .brandfeat__card--hero { min-height:200px; }
}

.brandfilter { position:relative; max-width:520px; margin:0 0 clamp(16px,2.2vw,24px); }
.brandfilter svg { position:absolute; left:15px; top:50%; transform:translateY(-50%); width:18px; height:18px; color:var(--ink-3); pointer-events:none; }
.brandfilter input { width:100%; padding:.82rem 1rem .82rem 44px; border:1.5px solid var(--line); border-radius:var(--radius-sm); font-size:1rem; background:#fff; transition:border-color var(--t-base); }
.brandfilter input:focus { outline:none; border-color:var(--brand); }
.brandfilter__none { color:var(--ink-2); margin:0 0 1.6rem; font-size:.95rem; }

.az-nav { display:flex; flex-wrap:wrap; gap:4px; padding:14px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); margin-bottom:1.6rem; position:sticky; top:74px; background:var(--bg); z-index:40; }
.az-nav a { width:32px; height:32px; display:grid; place-items:center; border-radius:var(--radius-sm); font-weight:700; font-size:.84rem; color:var(--ink-2); transition:background var(--t-base), color var(--t-base); }
@media (hover:hover){ .az-nav a:hover{ background:var(--brand); color:#fff; } }
.az-group { margin-bottom:2rem; scroll-margin-top:130px; }
.az-letter { font-family:var(--font-display); font-size:2rem; color:var(--brand); border-bottom:2px solid var(--line); padding-bottom:.3rem; margin-bottom:1rem; }
.brand-list { display:grid; grid-template-columns:repeat(auto-fill,minmax(190px,1fr)); gap:8px; }
.brandtile { display:flex; align-items:center; justify-content:space-between; gap:.5rem; padding:.8rem 1rem; border:1px solid var(--line); border-radius:var(--radius-sm); font-weight:600; font-size:.88rem; }
.brandtile.is-live { color:var(--ink); background:#fff; transition:border-color var(--t-base), box-shadow var(--t-base), transform var(--t-base); }
.brandtile.is-live svg { color:var(--brand); }
.brandtile.is-live:active { transform:scale(.99); }
@media (hover:hover){ .brandtile.is-live:hover{ border-color:var(--brand); box-shadow:var(--shadow); } }
.brandtile.is-soon { color:var(--ink-3); background:var(--bg-2); cursor:default; }
.brandtile__logo { width:38px; height:28px; object-fit:contain; flex-shrink:0; mix-blend-mode:multiply; }
.brandtile.is-soon .brandtile__logo { opacity:.5; }
.brandtile__logo--ph { display:grid; place-items:center; background:var(--bg-3); border-radius:4px; font-weight:800; color:var(--ink-3); font-size:.85rem; mix-blend-mode:normal; }
.brandtile__nm { flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.brandtile__ct { font-size:.72rem; color:var(--ink-3); flex-shrink:0; }

/* ============================================================ QUOTE / MOBILE DRAWERS */
.qdrawer, .mdrawer { position:fixed; inset:0; z-index:120; visibility:hidden; }
.qdrawer.open, .mdrawer.open { visibility:visible; }
.qdrawer__scrim { position:absolute; inset:0; background:rgba(10,12,15,.5); opacity:0; transition:opacity var(--t-base); }
.qdrawer.open .qdrawer__scrim, .mdrawer.open .qdrawer__scrim { opacity:1; }
.qdrawer__panel, .mdrawer__panel { position:absolute; top:0; right:0; height:100%; width:min(420px,92vw); background:#fff; display:flex; flex-direction:column; box-shadow:var(--shadow-lg); transform:translateX(100%); transition:transform .3s var(--ease-out); }
.mdrawer__panel { left:0; right:auto; transform:translateX(-100%); width:min(360px,86vw); }
.qdrawer.open .qdrawer__panel { transform:none; }
.mdrawer.open .mdrawer__panel { transform:none; }
.qdrawer__head { display:flex; align-items:center; justify-content:space-between; padding:18px 20px; border-bottom:1px solid var(--line); }
.qdrawer__head strong { font-family:var(--font-display); font-size:1.3rem; letter-spacing:.03em; }
.qdrawer__x { width:38px; height:38px; border-radius:var(--radius-sm); display:grid; place-items:center; transition:background var(--t-base); }
.qdrawer__x:active { transform:scale(.92); }
@media (hover:hover){ .qdrawer__x:hover{ background:var(--bg-2); } }
.qdrawer__body { flex:1; overflow-y:auto; padding:8px 16px; }
.qdrawer__foot { border-top:1px solid var(--line); padding:16px; display:flex; flex-direction:column; gap:10px; }
.qdrawer__note { font-size:.76rem; color:var(--ink-3); line-height:1.45; }
.qdrawer__clear { font-size:.8rem; color:var(--ink-3); text-decoration:underline; padding:.3rem; }

.qitem { display:flex; gap:12px; padding:14px 4px; border-bottom:1px solid var(--line-2); }
.qitem__img { width:60px; height:60px; flex-shrink:0; background:var(--bg-2); border-radius:var(--radius-sm); display:grid; place-items:center; overflow:hidden; }
.qitem__img img { width:100%; height:100%; object-fit:contain; mix-blend-mode:multiply; }
.qitem__main { flex:1; min-width:0; }
.qitem__name { font-size:.82rem; font-weight:600; line-height:1.3; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.qitem__sku { font-size:.68rem; color:var(--ink-3); margin:.2rem 0 .5rem; }
.qitem__row { display:flex; align-items:center; justify-content:space-between; }
.qty { display:inline-flex; align-items:center; border:1px solid var(--line); border-radius:var(--radius-sm); overflow:hidden; }
.qty button { width:30px; height:30px; display:grid; place-items:center; font-size:1rem; color:var(--ink); transition:background var(--t-base); }
.qty span { min-width:34px; text-align:center; font-family:var(--font-mono); font-size:.85rem; }
@media (hover:hover){ .qty button:hover{ background:var(--bg-2); } }
.qitem__rm { width:34px; height:34px; display:grid; place-items:center; color:var(--ink-3); border-radius:var(--radius-sm); transition:color var(--t-base), background var(--t-base); }
@media (hover:hover){ .qitem__rm:hover{ color:var(--brand); background:var(--bg-2); } }

.mdrawer__nav { padding:10px 16px; display:flex; flex-direction:column; }
.mdrawer__nav a { padding:.85rem .4rem; font-weight:600; border-bottom:1px solid var(--line-2); }
.mdrawer__cats { padding:0 16px 24px; overflow-y:auto; }
.mdrawer__cats a { display:block; padding:.55rem .4rem; font-size:.86rem; color:var(--ink-2); border-bottom:1px solid var(--line-2); }

/* ---------- toast ---------- */
.toast { position:fixed; left:50%; bottom:26px; transform:translateX(-50%) translateY(20px); background:var(--ink); color:#fff; padding:12px 22px; border-radius:var(--radius); font-size:.86rem; font-weight:600; box-shadow:var(--shadow-lg); z-index:200; opacity:0; pointer-events:none; transition:opacity var(--t-base), transform var(--t-base); }
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }

/* ============================================================ FAQ */
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
.faq__list { max-width:880px; margin:0 auto; }
.faq__item { border-bottom:1px solid var(--line); }
.faq__item summary {
  list-style:none; cursor:pointer; padding:22px 44px 22px 4px; position:relative;
  font-family:var(--font-display); font-size:clamp(1.05rem,2.2vw,1.3rem); line-height:1.3;
  color:var(--ink); transition:color var(--t-base) var(--ease-out);
}
.faq__item summary::-webkit-details-marker { display:none; }
.faq__item summary::after {
  content:""; position:absolute; right:8px; top:50%; width:12px; height:12px;
  margin-top:-9px; border-right:2px solid var(--ink-2); border-bottom:2px solid var(--ink-2);
  transform:rotate(45deg); transition:transform var(--t-base) var(--ease-out);
}
.faq__item[open] summary::after { transform:rotate(-135deg); margin-top:-3px; }
@media (hover:hover) and (pointer:fine){ .faq__item summary:hover { color:var(--brand); } }
.faq__item summary:focus-visible { outline:2px solid var(--brand); outline-offset:3px; border-radius:4px; }
.faq__item p { padding:0 4px 24px; margin:0; max-width:68ch; color:var(--ink-2); line-height:1.7; }

/* ============================================================ REDUCED MOTION */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after { animation-duration:.01ms!important; animation-iteration-count:1!important; transition-duration:.01ms!important; scroll-behavior:auto!important; }
}

/* ============================================================ AUDIT FIXES (batch 2 + 4) */

/* iOS Safari auto-zooms any focused input under 16px. Force 16px on mobile. */
@media (max-width:768px){
  .search input, .brandsearch input, .filt__search, .filt__range input, .sortbox select { font-size:16px; }
}

/* Two-up optional field group on the quote form (PO ref + delivery) */
.fg2 { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
@media (max-width:600px){ .fg2 { grid-template-columns:1fr; gap:0; } }

/* Honest note under the price filter */
.filt__hint { margin:.5rem 0 0; font-size:.74rem; line-height:1.4; color:var(--ink-3); }

/* Indicative subtotal on the quote page */
.qsubtotal {
  display:flex; flex-wrap:wrap; align-items:baseline; gap:.4rem .7rem;
  margin-top:.4rem; padding:1rem 1.1rem; border-top:1px solid var(--line);
  background:var(--bg-2); border-radius:0 0 var(--radius) var(--radius);
}
.qsubtotal span { font-weight:600; color:var(--ink-2); }
.qsubtotal b { font-size:1.15rem; font-family:var(--font-mono); }
.qsubtotal small { flex-basis:100%; color:var(--ink-3); font-size:.76rem; }

/* Submitted-quote summary card in the success state */
.rfq-summary-wrap { text-align:left; border:1px solid var(--line); border-radius:12px; overflow:hidden; margin:0 0 1.6rem; }
.rfq-summary-wrap__head { background:var(--bg-2); padding:.65rem 1rem; font-family:var(--font-mono); font-size:.68rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); border-bottom:1px solid var(--line); }
.rfq-summary { width:100%; border-collapse:collapse; font-size:.88rem; }
.rfq-summary td { padding:.7rem 1rem; border-bottom:1px solid var(--line-2); vertical-align:middle; }
.rfq-summary tr:last-child td { border-bottom:0; }
.rfq-summary__n { width:1.6rem; color:var(--ink-3); font-family:var(--font-mono); font-size:.8rem; }
.rfq-summary__nm { display:block; color:var(--ink); line-height:1.35; }
.rfq-summary__sku { display:block; color:var(--ink-3); font-size:.76rem; margin-top:.15rem; }
.rfq-summary__qty { text-align:right; white-space:nowrap; font-weight:700; font-family:var(--font-mono); color:var(--ink); }

/* Brand-page hero search (replaces the old Browse categories button) */
.brandhero__search { max-width:440px; margin-top:1.1rem; }

/* Brand-logo facet on search results */
.brandfacet__lbl { font-family:var(--font-mono); font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); margin:0 0 .6rem; }
.brandfacet { display:flex; gap:.6rem; flex-wrap:wrap; margin:0 0 1.4rem; }
.brandfacet__chip { display:inline-flex; align-items:center; gap:.5rem; background:#fff; border:1.5px solid var(--line); border-radius:10px; padding:.5rem .8rem; cursor:pointer; font:inherit; color:var(--ink-2); transition:border-color var(--t-base), box-shadow var(--t-base); min-height:44px; }
.brandfacet__chip img { height:22px; max-width:90px; object-fit:contain; display:block; }
.brandfacet__chip .brandfacet__ct { font-family:var(--font-mono); font-size:.7rem; color:var(--ink-3); }
.brandfacet__chip.is-active { border-color:var(--brand); box-shadow:inset 0 0 0 1px var(--brand); color:var(--ink); }
.brandfacet__all { font-weight:700; }
.brandfacet__chip:active { transform:scale(.97); }
@media (hover:hover) and (pointer:fine){ .brandfacet__chip:hover{ border-color:var(--brand); } }

/* Footer trademark / image-source disclaimer line */
.foot-legal { flex-basis:100%; order:-1; font-size:11px; line-height:1.5; color:inherit; opacity:.6; margin-bottom:.7rem; max-width:80ch; }

/* Sidebar brands that have no online catalogue yet (greyed, not clickable) */
.rail__list .rail__soon { display:flex; align-items:center; gap:.7rem; padding:.62rem .6rem; border-radius:var(--radius-sm); font-size:.86rem; font-weight:500; color:var(--ink-3); opacity:.5; border-left:3px solid transparent; cursor:default; }
.rail__badge { margin-left:auto; font-family:var(--font-mono); font-size:.56rem; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); border:1px solid var(--line); border-radius:6px; padding:1px 6px; }
.mdrawer__cats a.is-soon { opacity:.5; pointer-events:none; }

/* Brand logo beside each sidebar item */
.rail__bl { width:30px; height:22px; flex:none; display:flex; align-items:center; justify-content:center; }
.rail__bl img { max-width:30px; max-height:22px; object-fit:contain; display:block; }
.rail__soon .rail__bl img { filter:grayscale(1); }

/* Brand strip on the shop page (you're viewing Cromwell; logos jump to other brands) */
.shopbrands { display:flex; align-items:center; gap:.6rem; flex-wrap:wrap; margin:0 0 1.3rem; }
.shopbrands__lbl { font-family:var(--font-mono); font-size:.68rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); margin-right:.2rem; }

/* Branded placeholder when a product has no photo yet (cleaner than a broken icon) */
.pcard__ph { font-family:var(--font-display); font-weight:400; font-size:1.5rem; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-3); opacity:.45; text-align:center; padding:0 10px; }

/* ============================================================ MOBILE POLISH (home sections)
   Two targeted mobile fixes:
   1) "Shop by Brand" — drop the boxed card + name + count; show just the logo, the whole tile taps through.
   2) Catalogue blocks — guard against any right-edge bleed so content stays inside the gutter.
   (The Cromwell promo slide keeps its original layout; its copy was shortened instead.) */

/* 1) Shop by Brand = clean logo wall (mobile/tablet, where .cat-section is shown) */
@media (max-width:1024px){
  .cat-section .cat-grid{ grid-template-columns:repeat(3,1fr); gap:10px; }
  .cat-section .cat-tile{ border:none; background:transparent; padding:0; gap:0; box-shadow:none; }
  .cat-section .cat-tile:active{ transform:scale(.95); }
  .cat-section .cat-tile__img{ aspect-ratio:3/2; background:transparent; border-radius:0; }  /* no grey chip — logo only */
  .cat-section .cat-tile__name,
  .cat-section .cat-tile__count{ display:none; }
}
@media (max-width:420px){
  .cat-section .cat-grid{ grid-template-columns:repeat(2,1fr); }
}

/* 2) Catalogue hero + download rows: never bleed past the right gutter */
@media (max-width:768px){
  .cat-split{ max-width:100%; }
  .cat-hero,
  .cat-list,
  .cat-row,
  .catalogues,
  .catalogue{ max-width:100%; min-width:0; }
}
