/*
Theme Name: Johnny's Hardware
Theme URI: https://johnnyshardware.com/
Author: Johnny's Hardware
Description: Static B2B hardware sourcing website converted into a WordPress theme.
Version: 1.0.0
Text Domain: johnnys-hardware
*/

/* ============ TOKENS ============ */
:root{
  --blue:#1E50A2;
  --blue-700:#16407E;
  --blue-900:#0E2A5C;
  --cream:#FFF2DF;
  --cream-2:#FBE8C8;
  --yellow:#FDCA17;
  --orange:#F26C2A;
  --ink:#0E1A2B;
  --ink-2:#324054;
  --muted:#5C6B80;
  --line:#E5DCC6;
  --line-2:#EEE5D0;
  --white:#FFFFFF;
  --bg:#FAF6EE;
  --radius:6px;
  --radius-lg:8px;
  --shadow-sm:0 1px 2px rgba(14,26,43,.06), 0 1px 1px rgba(14,26,43,.04);
  --shadow:0 8px 24px -12px rgba(14,26,43,.18), 0 2px 4px rgba(14,26,43,.06);
  --shadow-lg:0 24px 48px -20px rgba(14,26,43,.30), 0 4px 12px rgba(14,26,43,.08);
  --container:1240px;
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:'Manrope', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size:16px;
  line-height:1.55;
  color:var(--ink);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
.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;
}

h1,h2,h3,h4,h5{
  font-family:'Archivo', sans-serif;
  font-weight:800;
  letter-spacing:-0.02em;
  color:var(--ink);
  margin:0;
  line-height:1.1;
  text-wrap:balance;
}
h2{font-size:clamp(28px, 3.4vw, 44px);}
h3{font-size:24px;}
h4{font-size:18px;}
p{margin:0;}
a{color:inherit;text-decoration:none;}

.container{max-width:var(--container);margin:0 auto;padding:0 28px;}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 18px;
  border-radius:var(--radius);
  font-family:'Manrope',sans-serif;
  font-weight:700;
  font-size:14px;
  letter-spacing:-0.005em;
  border:1px solid transparent;
  cursor:pointer;
  transition: transform .15s ease, background .15s ease, color .15s ease, border-color .15s ease, box-shadow .15s ease;
  white-space:nowrap;
}
.btn-lg{padding:15px 24px;font-size:15px;}
.btn-block{width:100%;justify-content:center;}
.btn svg{transition:transform .2s ease;}
.btn:hover svg{transform:translateX(2px);}

.btn-primary{background:var(--blue);color:#fff;box-shadow:0 4px 0 var(--blue-900), 0 6px 12px -4px rgba(30,80,162,.4);}
.btn-primary:hover{background:var(--blue-700);transform:translateY(-1px);box-shadow:0 5px 0 var(--blue-900), 0 8px 18px -4px rgba(30,80,162,.5);}
.btn-primary:active{transform:translateY(2px);box-shadow:0 1px 0 var(--blue-900);}

.btn-yellow{background:var(--yellow);color:var(--ink);box-shadow:0 4px 0 #C49B00, 0 6px 12px -4px rgba(253,202,23,.5);}
.btn-yellow:hover{background:#FFD536;transform:translateY(-1px);}
.btn-yellow:active{transform:translateY(2px);box-shadow:0 1px 0 #C49B00;}

.btn-outline{background:transparent;color:var(--ink);border-color:var(--ink);}
.btn-outline:hover{background:var(--ink);color:var(--white);}

.btn-ghost-light{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.5);backdrop-filter:blur(4px);}
.btn-ghost-light:hover{background:rgba(255,255,255,.15);border-color:#fff;}

.btn-link{
  display:inline-flex;align-items:center;gap:6px;
  font-weight:700;font-size:14px;color:var(--blue);
  border-bottom:2px solid var(--blue);
  padding-bottom:2px;
  transition: gap .15s ease, color .15s ease, border-color .15s ease;
}
.btn-link:hover{gap:10px;color:var(--orange);border-color:var(--orange);}
.btn-link.sm{font-size:13px;}

/* ============ UTILITY BAR ============ */
.utility{
  background:var(--ink);color:#CBD3DF;font-size:12.5px;
  border-bottom:1px solid #1d2937;
}
.utility-inner{display:flex;justify-content:space-between;align-items:center;padding:8px 28px;}
.utility-left,.utility-right{display:flex;align-items:center;gap:14px;}
.util-item{display:inline-flex;align-items:center;gap:6px;}
.util-divider{width:1px;height:12px;background:#37445A;}
.utility a{color:#CBD3DF;transition:color .15s;}
.utility a:hover{color:var(--yellow);}

/* ============ HEADER ============ */
.header{
  position:sticky;top:0;z-index:50;
  background:#fff;
  border-bottom:1px solid var(--line-2);
  transition:box-shadow .2s ease;
}
.header.scrolled{box-shadow:var(--shadow);}
.header-inner{
  max-width:1360px;
  display:flex;align-items:center;justify-content:space-between;gap:32px;
  padding:26px 28px;
}
.brand{display:flex;align-items:center;}
.brand img{height:64px;width:auto;display:block;object-fit:contain;}
.nav{display:flex;align-items:center;gap:4px;}
.nav a{
  position:relative;
  padding:8px 14px;
  font-size:14px;font-weight:600;color:var(--ink-2);
  border-radius:4px;
  transition:color .15s, background .15s;
}
.nav a:hover{color:var(--blue);}
.nav a.active{color:var(--blue);}
.nav a.active::after{
  content:"";position:absolute;left:14px;right:14px;bottom:-19px;height:3px;background:var(--yellow);
}
/* Non-clickable nav label (Products) — looks like a nav link but is just a span */
.nav .nav-label{
  position:relative;
  display:inline-flex;
  align-items:center;
  padding:8px 14px;
  font-size:14px;font-weight:600;color:var(--ink-2);
  border-radius:4px;
  cursor:default;
  user-select:none;
  transition:color .15s;
}
.nav .nav-label:hover{color:var(--blue);}
.nav .nav-label.active{color:var(--blue);}
.nav .nav-label.active::after{
  content:"";position:absolute;left:14px;right:14px;bottom:-19px;height:3px;background:var(--yellow);
}
.nav-item{position:relative;}
.has-dropdown .nav-link{display:flex;align-items:center;gap:6px;}
.has-dropdown .nav-link::before{
  content:"";
  width:5px;
  height:5px;
  border-right:1.5px solid currentColor;
  border-bottom:1.5px solid currentColor;
  transform:rotate(45deg) translateY(-1px);
  order:2;
}
.dropdown{
  position:absolute;
  top:calc(100% + 14px);
  left:0;
  min-width:190px;
  padding:8px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:6px;
  box-shadow:0 18px 45px rgba(15,35,60,.14);
  opacity:0;
  visibility:hidden;
  transform:translateY(6px);
  transition:opacity .15s ease, transform .15s ease, visibility .15s ease;
  z-index:80;
}
.dropdown::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:-15px;
  height:15px;
}
.has-dropdown:hover .dropdown,
.has-dropdown:focus-within .dropdown{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}
.dropdown a{
  display:block;
  padding:10px 12px;
  border-radius:4px;
  color:var(--ink-2);
  white-space:nowrap;
}
.dropdown a:hover{
  background:#FAF6EE;
  color:var(--blue);
}
.nav-search{
  width:38px;
  height:38px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--line);
  border-radius:4px;
  background:#fff;
  color:var(--ink-2);
  cursor:pointer;
  transition:color .15s ease, border-color .15s ease, background .15s ease;
}
.nav-search:hover{
  color:var(--blue);
  border-color:var(--blue);
  background:#FAF6EE;
}
.header-cta{display:flex;align-items:center;gap:10px;}
.menu-btn{display:none;background:none;border:1px solid var(--line);border-radius:4px;width:42px;height:42px;flex-direction:column;justify-content:center;align-items:center;gap:4px;cursor:pointer;}
.menu-btn span{display:block;width:18px;height:2px;background:var(--ink);}

/* ============ HERO ============ */
.hero{
  position:relative;
  overflow:hidden;
  color:#fff;
  background:#0a1730;
  min-height:min(720px, 88vh);
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.hero-fallback,
.hero-video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
}
.hero-fallback img{width:100%;height:100%;object-fit:cover;}
.hero-video{z-index:1;}
.hero-overlay{
  position:absolute;inset:0;z-index:2;
  background:
    linear-gradient(120deg, rgba(14,42,92,.92) 0%, rgba(14,42,92,.78) 45%, rgba(30,80,162,.55) 100%),
    radial-gradient(900px 500px at 80% 30%, rgba(253,202,23,.10), transparent 60%);
}
.hero-inner{position:relative;z-index:3;padding:96px 28px 120px;}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;font-weight:700;letter-spacing:.16em;
  color:var(--yellow);
  padding:8px 14px;
  border:1px solid rgba(253,202,23,.35);
  background:rgba(253,202,23,.06);
  border-radius:999px;
  margin-bottom:24px;
}
.hero-eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--yellow);box-shadow:0 0 0 4px rgba(253,202,23,.18);}
.hero-title{
  font-size:clamp(36px, 5.6vw, 72px);
  font-weight:900;
  line-height:1.02;
  color:#fff;
  letter-spacing:-0.025em;
  max-width:1000px;
  margin-bottom:22px;
}
.hero-title .hl{
  background: linear-gradient(transparent 62%, rgba(253,202,23,.35) 62%, rgba(253,202,23,.35) 92%, transparent 92%);
  padding:0 4px;
}
.hero-sub{
  font-size:clamp(15px, 1.4vw, 18px);
  color:#D7E0EF;
  max-width:660px;
  margin-bottom:32px;
}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:56px;}

.trust-strip{
  list-style:none;margin:0;padding:0;
  display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:14px;
  max-width:860px;
}
.trust-strip li{
  display:flex;align-items:center;gap:14px;
  padding:14px 18px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius);
  backdrop-filter:blur(4px);
}
.trust-strip li svg{color:var(--yellow);flex:none;}
.trust-strip li span{display:flex;flex-direction:column;}
.trust-strip li b{font-size:14px;font-weight:700;color:#fff;letter-spacing:-0.005em;}
.trust-strip li small{font-size:12px;color:#A8B5C9;}

/* ============ SECTIONS ============ */
.section{padding:96px 0;position:relative;}
.section-cream{background:var(--cream);}
.section-dark{background:var(--ink);color:#D7E0EF;}
.section-dark h2,.section-dark h3,.section-dark h4{color:#fff;}
.section-blue{background:var(--blue);background-image:linear-gradient(135deg, var(--blue) 0%, var(--blue-700) 100%); color:#E6EEFA;}
.section-blue h2,.section-blue h3,.section-blue h4{color:#fff;}

.section-head{margin-bottom:48px;max-width:760px;}
.section-head.row{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;max-width:none;flex-wrap:wrap;}
.section-head h2{margin-top:8px;}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;font-weight:700;letter-spacing:.18em;
  color:var(--blue);
  text-transform:uppercase;
}
.eyebrow.light{color:var(--yellow);}
.kbar{display:inline-block;width:28px;height:3px;background:var(--blue);border-radius:1px;}
.kbar.yellow{background:var(--yellow);}
.section-head.light h2{color:#fff;}
.lede{font-size:17px;color:var(--muted);margin-top:14px;}
.lede.light{color:#B9C5D9;}
h2.light{color:#fff;}

/* ============ PRODUCT OVERVIEW ============ */
.supply-stack{display:flex;flex-direction:column;gap:34px;}
.supply-block{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:0 18px 45px rgba(15,35,60,.06);
}
.supply-hero{
  display:grid;
  grid-template-columns:minmax(280px, .92fr) minmax(0, 1.08fr);
  min-height:320px;
}
.supply-hero.reverse{grid-template-columns:minmax(0, 1.08fr) minmax(280px, .92fr);}
.supply-hero.reverse .supply-media{order:2;}
.supply-media{background:#F2E8D0;overflow:hidden;}
.supply-media img{width:100%;height:100%;object-fit:cover;display:block;}
.supply-copy{
  padding:42px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:flex-start;
  gap:16px;
}
.supply-copy h3{font-size:34px;line-height:1.05;}
.supply-copy p{max-width:620px;color:var(--muted);font-size:16px;}
.supply-tags{
  list-style:none;
  margin:2px 0 0;
  padding:0;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.supply-tags li{
  font-size:12px;
  font-weight:800;
  color:var(--ink-2);
  background:#FAF6EE;
  border:1px solid var(--line);
  border-radius:3px;
  padding:7px 10px;
}
.line-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
  padding:22px;
  background:#fff;
  border-top:1px solid var(--line);
}
.line-grid.compact{grid-template-columns:repeat(4,minmax(0,1fr));}
.line-grid.compact.safety-home-grid{grid-template-columns:repeat(5,minmax(0,1fr));}
.line-card{
  min-height:254px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:0 0 18px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  gap:14px;
  color:var(--ink);
  transition:background .15s ease, color .15s ease, border-color .15s ease, transform .15s ease, box-shadow .15s ease;
}
.line-card:hover{
  background:var(--ink);
  border-color:var(--ink);
  color:#fff;
  transform:translateY(-2px);
  box-shadow:var(--shadow);
}
.line-card img{
  width:100%;
  height:196px;
  object-fit:cover;
  background:#FAF8F1;
  display:block;
}
.line-card span,
.line-card small{
  margin-left:18px;
  margin-right:18px;
}
.line-placeholder{
  width:100%;
  height:178px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,#FFFDF7 0%,#F7EFDD 100%);
  border:1px dashed #D8C8A5;
  border-radius:4px;
  color:#8B7A58;
  font-size:12px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.line-card:hover .line-placeholder{
  background:rgba(255,255,255,.06);
  border-color:rgba(253,202,23,.65);
  color:var(--yellow);
}
.line-card span{
  font-size:16px;
  font-weight:900;
  line-height:1.2;
}
.line-card small{
  color:var(--muted);
  font-size:12.5px;
  line-height:1.45;
}
.line-card:hover small{color:#C7D2E3;}
.line-card.text-only{justify-content:center;min-height:138px;}

/* ============ WHY US ============ */
.why-grid{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0;
  border:1px solid #1d2937;border-radius:var(--radius-lg);overflow:hidden;
  background:#0E1A2B;
}
.why-item{
  padding:32px 28px;
  border-right:1px solid #1d2937;
  border-bottom:1px solid #1d2937;
  position:relative;
  transition: background .2s;
}
.why-item:hover{background:#142238;}
.why-item:nth-child(3n){border-right:none;}
.why-item:nth-last-child(-n+3){border-bottom:none;}
.why-num{
  font-family:'Archivo',sans-serif;font-weight:900;font-size:32px;
  color:var(--yellow);
  margin-bottom:14px;
  letter-spacing:-0.02em;
}
.why-item h4{font-size:19px;color:#fff;margin-bottom:8px;}
.why-item p{font-size:14px;color:#9FB0CB;line-height:1.55;}

/* ============ QC STEPS ============ */
.quality-grid{
  display:grid;
  grid-template-columns:.95fr 1.25fr;
  gap:44px;
  align-items:center;
}
.quality-media{
  position:relative;
}
.quality-media img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow);
}
.quality-note{
  position:absolute;
  left:22px;
  right:22px;
  bottom:22px;
  padding:16px 18px;
  background:rgba(14,26,43,.88);
  color:#fff;
  border-left:4px solid var(--yellow);
  border-radius:var(--radius);
  backdrop-filter:blur(4px);
}
.quality-note b{
  display:block;
  font-family:'Archivo',sans-serif;
  font-size:17px;
  margin-bottom:4px;
}
.quality-note span{
  display:block;
  font-size:13px;
  color:#D7E0EF;
  line-height:1.45;
}
.qc-steps{
  list-style:none;margin:0;padding:0;
  display:grid;grid-template-columns:1fr;gap:12px;
  position:relative;
  counter-reset:step;
}
.qc-steps::before{display:none;}
.qc-steps li{
  position:relative;
  padding:18px 18px 18px 92px;
  min-height:86px;
  text-align:left;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  z-index:1;
}
.qc-num{
  position:absolute;
  left:18px;
  top:18px;
  width:50px;height:50px;border-radius:50%;
  background:#fff;
  border:2px solid var(--blue);
  color:var(--blue);
  font-family:'Archivo',sans-serif;font-weight:900;font-size:17px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 0 var(--blue-900);
  transition: background .2s, color .2s;
}
.qc-steps li:hover .qc-num{background:var(--yellow);border-color:var(--yellow);color:var(--ink);box-shadow:0 4px 0 #C49B00;}
.qc-steps li h4{font-size:16px;margin-bottom:5px;}
.qc-steps li p{font-size:13.5px;color:var(--muted);line-height:1.5;}

/* ============ APPLICATIONS ============ */
.apps-grid{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;
}
.apps-grid-6{grid-template-columns:repeat(3,minmax(0,1fr));}
.app{
  position:relative;
  aspect-ratio:1/1.05;
  border-radius:var(--radius);
  background-size:cover;background-position:center;
  overflow:hidden;
  display:flex;align-items:flex-end;
  padding:18px;
  color:#fff;
  font-family:'Archivo',sans-serif;font-weight:800;font-size:17px;
  letter-spacing:-0.01em;
  transition: transform .2s;
}
.app::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(14,26,43,.0) 30%, rgba(14,26,43,.85) 100%);
}
.app span{position:relative;z-index:1;}
.app:hover{transform:translateY(-2px);}
.app:hover::before{background:linear-gradient(180deg, rgba(30,80,162,.0) 20%, rgba(30,80,162,.9) 100%);}

/* ============ OEM ============ */
.oem-grid{
  display:grid;grid-template-columns:1.05fr 1fr;gap:60px;align-items:center;
}
.oem-copy h2{margin:8px 0 16px;}
.oem-highlights{list-style:none;margin:28px 0 36px;padding:0;display:flex;flex-direction:column;gap:14px;}
.oem-highlights li{
  display:flex;align-items:flex-start;gap:14px;
  padding:14px 16px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.12);
  border-left:3px solid var(--yellow);
  border-radius:var(--radius);
}
.oem-highlights li svg{color:var(--yellow);margin-top:2px;flex:none;}
.oem-highlights li b{display:block;color:#fff;font-size:15px;}
.oem-highlights li span{font-size:13.5px;color:#B9C5D9;}
.oem-media{position:relative;}
.oem-media img{border-radius:var(--radius-lg);width:100%;aspect-ratio:4/3;object-fit:cover;}
.oem-stat{
  position:absolute;bottom:-28px;left:-28px;right:24px;
  background:var(--yellow);color:var(--ink);
  border-radius:var(--radius);
  padding:18px 22px;
  display:grid;grid-template-columns:1fr 1fr;gap:18px;
  box-shadow:var(--shadow-lg);
}
.oem-stat .stat b{display:block;font-family:'Archivo',sans-serif;font-weight:900;font-size:32px;letter-spacing:-0.025em;}
.oem-stat .stat span{font-size:12.5px;font-weight:600;color:var(--ink-2);}

/* ============ ABOUT ============ */
.about-grid{
  display:grid;grid-template-columns:1fr 1.05fr;gap:60px;align-items:center;
}
.about-media{position:relative;}
.about-media img{border-radius:var(--radius-lg);width:100%;aspect-ratio:4/4.2;object-fit:cover;}
.about-badge{
  position:absolute;right:-24px;bottom:32px;
  background:var(--blue);color:#fff;
  padding:18px 22px;border-radius:var(--radius);
  display:flex;align-items:center;gap:14px;
  max-width:300px;
  box-shadow:var(--shadow-lg);
}
.badge-num{font-family:'Archivo',sans-serif;font-weight:900;font-size:48px;line-height:1;letter-spacing:-0.03em;color:var(--yellow);}
.badge-num small{font-size:14px;display:block;margin-top:2px;color:#fff;font-weight:700;letter-spacing:.05em;}
.badge-text{font-size:13px;line-height:1.4;}

.about-copy h2{margin:8px 0 18px;}
.about-copy p{color:var(--ink-2);font-size:16px;margin-bottom:28px;}
.about-pillars{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;
  padding:20px;
  background:var(--cream);
  border-radius:var(--radius);
  border:1px solid var(--line);
  margin-bottom:28px;
}
.about-pillars b{display:block;font-family:'Archivo',sans-serif;font-weight:800;font-size:15px;color:var(--blue);}
.about-pillars span{font-size:13px;color:var(--muted);}

.about-home{
  background:#fff;
}
.about-home-intro{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(300px,420px);
  gap:34px;
  align-items:center;
  margin-bottom:42px;
}
.about-home-intro h2{
  margin:8px 0 18px;
  max-width:920px;
  text-transform:uppercase;
}
.about-home-intro p{
  max-width:920px;
  color:var(--ink-2);
  font-size:17px;
  line-height:1.75;
}
.about-home-media{
  width:100%;
  max-width:420px;
  justify-self:end;
}
.about-home-media img{
  width:100%;
  aspect-ratio:5/4;
  max-height:320px;
  object-fit:cover;
  object-position:center;
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
}
.about-feature-stack{
  display:flex;
  flex-direction:column;
  gap:28px;
}
.about-feature{
  display:grid;
  grid-template-columns:minmax(340px,.9fr) minmax(0,1.1fr);
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.about-feature.reverse{
  grid-template-columns:minmax(0,1.1fr) minmax(340px,.9fr);
}
.about-feature.reverse .about-feature-media{
  order:2;
  border-right:0;
  border-left:1px solid var(--line);
}
.about-feature-media{
  min-height:320px;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:hidden;
  background:#F7EFDD;
  border-right:1px solid var(--line);
  color:#8B7A58;
  padding:0 !important;
}
.about-feature-media::before{
  content:none !important;
  display:none !important;
}
.about-feature-media img{
  width:100%;
  height:100%;
  min-height:320px;
  object-fit:cover;
  display:block;
}
.about-feature-copy{
  padding:38px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.about-feature-copy > span{
  font-family:'Archivo',sans-serif;
  font-size:13px;
  font-weight:900;
  color:var(--blue);
  letter-spacing:.16em;
  margin-bottom:12px;
}
.about-feature-copy h3{
  font-size:38px;
  line-height:1.15;
  margin-bottom:18px;
}
.about-feature-copy p{
  color:var(--ink-2);
  font-size:18px;
  line-height:1.75;
}

/* ============ SECTION ACCENT DIVIDER ============ */
.section-accent{
  background:var(--cream);
  padding:0;
  display:flex;
  justify-content:center;
}
.section-accent span{
  display:block;
  width:72px;
  height:3px;
  background:var(--yellow);
  border-radius:2px;
}

/* ============ ABOUT — OUR STORY ============ */
.about-story-grid{
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);
  gap:64px;
  align-items:center;
}
.about-story-copy h2{font-size:clamp(32px,4vw,46px);line-height:1.1;margin:14px 0 22px;}
.about-story-copy p{
  color:var(--ink-2);
  font-size:17px;
  line-height:1.78;
  margin-bottom:16px;
}
.about-story-signature{
  margin-top:28px;
  padding-top:22px;
  border-top:1px solid var(--line);
}
.about-story-signature b{
  display:block;
  font-family:'Archivo',sans-serif;
  font-size:18px;
  color:var(--ink);
}
.about-story-signature span{font-size:14px;color:var(--muted);}
.about-story-media{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow);
}
.about-story-media img{display:block;width:100%;height:100%;object-fit:cover;}
.about-story-badge{
  position:absolute;
  left:24px;bottom:24px;
  background:var(--yellow);
  color:var(--ink);
  padding:14px 18px;
  border-radius:12px;
  box-shadow:0 8px 24px rgba(0,0,0,.18);
}
.about-story-badge b{
  display:block;
  font-family:'Archivo',sans-serif;
  font-size:22px;
  line-height:1;
  margin-bottom:4px;
}
.about-story-badge span{font-size:12px;font-weight:600;letter-spacing:.04em;}

/* ============ ABOUT — WHY US ============ */
.whyus-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:24px;
  margin-top:48px;
  background:transparent;
}
.whyus-card{
  position:relative;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:34px 30px 30px;
  overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.whyus-card::before{
  content:"";
  position:absolute;
  left:0;right:0;top:0;
  height:3px;
  background:var(--blue);
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .3s ease;
}
.whyus-card:hover{
  transform:translateY(-6px);
  box-shadow:0 22px 44px rgba(15,30,80,.10);
  border-color:rgba(30,80,162,.25);
}
.whyus-card:hover::before{transform:scaleX(1);}
.whyus-card .whyus-num{
  position:absolute;
  top:22px;
  right:24px;
  font-family:'Archivo',sans-serif;
  font-weight:900;
  font-size:13px;
  color:var(--muted);
  letter-spacing:.12em;
  opacity:.55;
}
.whyus-icon{
  width:56px;height:56px;
  border-radius:14px;
  background:#F4F8FF;
  color:var(--blue);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-bottom:22px;
  transition:background .25s ease, color .25s ease, transform .25s ease;
}
.whyus-card:hover .whyus-icon{
  background:var(--blue);
  color:#fff;
  transform:scale(1.05);
}
.whyus-card h4{
  font-family:'Archivo',sans-serif;
  font-size:20px;
  line-height:1.25;
  margin-bottom:12px;
  color:var(--ink);
  letter-spacing:-0.01em;
}
.whyus-card p{
  color:var(--ink-2);
  font-size:15px;
  line-height:1.7;
}

@media (max-width: 900px){
  .about-story-grid{grid-template-columns:1fr;gap:36px;}
  .whyus-grid{grid-template-columns:1fr 1fr;}
}
@media (max-width: 600px){
  .whyus-grid{grid-template-columns:1fr;}
}

/* ============ CERTIFICATIONS ============ */
.cert-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:24px;
}
.cert-card{
  display:flex;
  flex-direction:column;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.cert-card:hover{
  transform:translateY(-3px);
  border-color:var(--blue);
  box-shadow:var(--shadow-lg);
}
.cert-media{
  aspect-ratio:4/3;
  background:#FAF6EE;
  overflow:hidden;
  border-bottom:1px solid var(--line);
}
.cert-media img{
  width:100%;
  height:100%;
  object-fit:contain;
  padding:14px;
}
.cert-body{
  padding:20px;
}
.cert-body span{
  display:inline-flex;
  font-size:11px;
  font-weight:800;
  letter-spacing:.13em;
  text-transform:uppercase;
  color:var(--blue);
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:3px;
  padding:4px 8px;
  margin-bottom:12px;
}
.cert-body h4{font-size:20px;margin-bottom:8px;}
.cert-body p{font-size:14px;color:var(--muted);}
.buyer-wall{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:12px;
  margin-top:28px;
}
.buyer-wall span{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:58px;
  padding:10px 12px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  font-family:'Archivo',sans-serif;
  font-weight:800;
  color:var(--ink-2);
  text-align:center;
  box-shadow:var(--shadow-sm);
}

/* ============ CATALOG BAND ============ */
.catalog-band{
  background:var(--ink);
  color:#D7E0EF;
  border-top:3px solid var(--yellow);
}
.catalog-band-inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:28px;
  padding:32px 28px;
}
.catalog-band h2{
  color:#fff;
  font-size:clamp(24px, 3vw, 34px);
  margin:8px 0 8px;
}
.catalog-band p{
  color:#B9C5D9;
  max-width:760px;
}

/* ============ BLOG ============ */
.blog-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;}
.blog-card{
  background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-lg);overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .2s, box-shadow .2s, border-color .2s;
}
.blog-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--blue);}
.blog-media{aspect-ratio:16/10;overflow:hidden;}
.blog-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s;}
.blog-card:hover .blog-media img{transform:scale(1.04);}
.blog-body{padding:22px;display:flex;flex-direction:column;gap:10px;flex:1;}
.blog-tag{
  align-self:flex-start;
  font-size:11px;font-weight:800;letter-spacing:.14em;
  padding:4px 10px;border-radius:3px;
  background:var(--cream);color:var(--blue);border:1px solid var(--line);
}
.blog-card h4{font-size:18px;letter-spacing:-0.015em;}
.blog-card p{color:var(--muted);font-size:14px;flex:1;}
.blog-meta{font-size:12px;color:var(--muted);font-weight:600;letter-spacing:.04em;text-transform:uppercase;}

/* ============ FAQ ============ */
.faq-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:60px;align-items:start;}
.faq-intro h2{margin:8px 0 16px;}
.faq-intro .lede{margin-bottom:28px;}
.faq-list{display:flex;flex-direction:column;gap:10px;}
.faq-list details{
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:#fff;
  transition: border-color .15s, box-shadow .15s;
}
.faq-list details[open]{border-color:var(--blue);box-shadow:var(--shadow);}
.faq-list summary{
  cursor:pointer;list-style:none;
  padding:18px 22px;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  font-family:'Archivo',sans-serif;font-weight:700;font-size:16px;
  letter-spacing:-0.005em;
}
.faq-list summary::-webkit-details-marker{display:none;}
.faq-list summary .ico{
  width:24px;height:24px;border-radius:50%;
  background:var(--cream);color:var(--blue);
  position:relative;flex:none;
  transition:background .15s, transform .2s;
}
.faq-list summary .ico::before,
.faq-list summary .ico::after{
  content:"";position:absolute;background:var(--blue);
  top:50%;left:50%;transform:translate(-50%,-50%);
}
.faq-list summary .ico::before{width:10px;height:2px;}
.faq-list summary .ico::after{width:2px;height:10px;transition:transform .2s;}
.faq-list details[open] summary .ico{background:var(--yellow);}
.faq-list details[open] summary .ico::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0;}
.faq-list .ans{
  padding:0 22px 20px;
  color:var(--ink-2);
  font-size:14.5px;
  line-height:1.6;
}

/* ============ CTA / FORM ============ */
.cta-section{padding:96px 0;}
.cta-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:64px;align-items:start;}
.cta-copy h2{margin:8px 0 14px;}
.cta-points{list-style:none;margin:24px 0 32px;padding:0;display:flex;flex-direction:column;gap:10px;}
.cta-points li{display:flex;align-items:center;gap:10px;font-weight:600;color:var(--ink);font-size:15px;}
.cta-points li svg{color:var(--blue);flex:none;background:var(--yellow);border-radius:50%;padding:4px;width:22px;height:22px;}
.cta-contact{display:grid;grid-template-columns:1fr 1fr;gap:18px;padding:18px;border:1px dashed var(--line);border-radius:var(--radius);background:#fff;}
.cta-contact small{display:block;font-size:11.5px;font-weight:700;letter-spacing:.14em;color:var(--muted);text-transform:uppercase;margin-bottom:4px;}
.cta-contact a{font-family:'Archivo',sans-serif;font-weight:700;color:var(--blue);font-size:15px;}

.cta-form{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:32px;
  box-shadow:var(--shadow);
}
.form-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px;}
.form-head h3{font-size:24px;}
.form-pill{font-size:11px;font-weight:800;letter-spacing:.14em;background:var(--yellow);color:var(--ink);padding:5px 10px;border-radius:3px;}
.cta-form .grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;}
.cta-form label{display:block;margin-bottom:14px;}
.cta-form label > span{
  display:block;font-size:12px;font-weight:700;color:var(--ink-2);
  letter-spacing:.04em;text-transform:uppercase;margin-bottom:6px;
}
.cta-form input,.cta-form select,.cta-form textarea{
  width:100%;
  padding:12px 14px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  font-family:inherit;font-size:14.5px;color:var(--ink);
  background:#FAF6EE;
  transition:border-color .15s, background .15s, box-shadow .15s;
}
.cta-form input:focus,.cta-form select:focus,.cta-form textarea:focus{
  outline:none;border-color:var(--blue);background:#fff;
  box-shadow:0 0 0 3px rgba(30,80,162,.12);
}
.cta-form textarea{resize:vertical;min-height:100px;}
.form-foot{font-size:12px;color:var(--muted);margin-top:12px;text-align:center;}

.cta-form.submitted{position:relative;}
.cta-form .success-msg{
  display:none;
  background:#0E2A5C;color:#fff;
  padding:18px;border-radius:var(--radius);
  font-weight:600;text-align:center;
  margin-bottom:18px;
  border-left:4px solid var(--yellow);
}
.cta-form.submitted .success-msg{display:block;}

/* ============ FOOTER ============ */
.footer{background:var(--ink);color:#9FB0CB;padding:64px 0 24px;}
.footer-inner{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;
  padding-bottom:40px;border-bottom:1px solid #1d2937;
}
.footer-brand img{display:block;height:auto;width:auto;max-height:72px;max-width:220px;margin-bottom:18px;object-fit:contain;filter:brightness(1.1);}
.footer-brand p{font-size:14px;line-height:1.6;color:#9FB0CB;margin-bottom:20px;max-width:380px;}
.foot-contact{display:flex;flex-direction:column;gap:6px;font-size:13.5px;}
.foot-contact b{color:#fff;font-weight:700;margin-right:6px;}
.footer-social{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:18px;
}
.footer-social a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:38px;
  height:38px;
  border:1px solid #29364A;
  border-radius:50%;
  color:#D7E0EF;
  transition:color .15s, border-color .15s, background .15s, transform .15s;
}
.footer-social a:hover{
  color:var(--ink);
  background:var(--yellow);
  border-color:var(--yellow);
  transform:translateY(-2px);
}
.footer-social svg{display:block;}
.foot-col h5{color:#fff;font-size:14px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:16px;}
.foot-col a{display:block;padding:4px 0;font-size:14px;color:#9FB0CB;transition:color .15s;}
.foot-col a:hover{color:var(--yellow);}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  padding-top:22px;font-size:13px;color:#7B8AA0;
  flex-wrap:wrap;
}
.foot-links{display:flex;gap:18px;}
.foot-links a{color:#7B8AA0;}
.foot-links a:hover{color:var(--yellow);}

/* ============ ABOUT PAGE ============ */
.about-hero{
  background:linear-gradient(180deg,#FFF8EC 0%,#fff 100%);
  padding:72px 0;
}
.about-hero-inner{
  display:grid;
  grid-template-columns:minmax(0, .95fr) minmax(360px, 1.05fr);
  gap:54px;
  align-items:center;
}
.about-hero-copy h1{
  font-size:clamp(38px,5vw,64px);
  line-height:1;
  margin:18px 0 22px;
}
.about-hero-copy p{
  color:var(--ink-2);
  font-size:18px;
  max-width:660px;
}
.about-hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:30px;}
.about-hero-media img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
}
.about-stats{padding:28px 0;}
.about-stat-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:1px;
  background:var(--line);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
}
.about-stat-grid div{
  background:#fff;
  padding:24px;
}
.about-stat-grid b{
  display:block;
  font-family:'Archivo',sans-serif;
  font-size:34px;
  line-height:1;
  color:var(--blue);
  margin-bottom:8px;
}
.about-stat-grid span{font-size:13px;font-weight:700;color:var(--ink-2);}
.about-capability-stack{display:flex;flex-direction:column;gap:34px;}
.about-capability{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(360px,1.1fr);
  align-items:stretch;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:0 18px 45px rgba(15,35,60,.06);
}
.about-capability.reverse{grid-template-columns:minmax(360px,1.1fr) minmax(0,.9fr);}
.about-capability.reverse .capability-copy{order:2;}
.capability-copy{
  padding:42px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:16px;
}
.capability-num{
  width:42px;
  height:42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  background:var(--blue);
  color:#fff;
  font-family:'Archivo',sans-serif;
  font-size:14px;
  font-weight:900;
}
.capability-copy h3{font-size:34px;}
.capability-copy p{color:var(--muted);font-size:16px;}
.capability-list{
  margin:4px 0 0;
  padding:0;
  list-style:none;
  display:grid;
  gap:9px;
}
.capability-list li{
  position:relative;
  padding-left:20px;
  color:var(--ink-2);
  font-size:14px;
  font-weight:700;
}
.capability-list li::before{
  content:"";
  position:absolute;
  left:0;
  top:.65em;
  width:8px;
  height:8px;
  background:var(--yellow);
  border-radius:50%;
}
.capability-media{
  min-height:360px;
  background:#FAF6EE;
  display:grid;
  align-items:stretch;
}
.capability-media > img{
  width:100%;
  height:100%;
  min-height:360px;
  object-fit:cover;
}
.product-line-media{
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:1px;
  background:var(--line);
}
.product-line-media img{
  width:100%;
  height:100%;
  min-height:360px;
  object-fit:cover;
}
.about-line-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:4px;}
.about-line-chips a{
  padding:9px 12px;
  border:1px solid var(--line);
  border-radius:4px;
  background:#FAF6EE;
  color:var(--ink-2);
  font-size:13px;
  font-weight:800;
}
.about-line-chips a:hover{border-color:var(--blue);color:var(--blue);}
.cert-strip{
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:1px;
  background:var(--line);
}
.cert-strip img{
  width:100%;
  height:100%;
  min-height:360px;
  object-fit:contain;
  background:#fff;
  padding:26px;
}
.about-cta{padding:72px 0;}
.about-cta-inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:40px;
}
.about-cta-inner p{max-width:680px;}

/* ============ CONTACT PAGE ============ */
.contact-hero{
  background:linear-gradient(180deg,#FFF8EC 0%,#fff 100%);
  padding:72px 0;
}
.contact-hero-inner{
  display:grid;
  grid-template-columns:minmax(0,1fr) 420px;
  gap:54px;
  align-items:center;
}
.contact-hero h1{
  font-size:clamp(38px,5vw,62px);
  line-height:1;
  margin:18px 0 22px;
}
.contact-hero p{
  max-width:760px;
  color:var(--ink-2);
  font-size:18px;
}
.contact-direct{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  overflow:hidden;
}
.contact-direct div{
  padding:24px;
  border-bottom:1px solid var(--line);
}
.contact-direct div:last-child{border-bottom:0;}
.contact-direct small{
  display:block;
  font-size:11.5px;
  font-weight:800;
  letter-spacing:.14em;
  color:var(--muted);
  text-transform:uppercase;
  margin-bottom:6px;
}
.contact-direct a,
.contact-direct span{
  font-family:'Archivo',sans-serif;
  font-weight:800;
  color:var(--blue);
  font-size:18px;
}
.contact-grid{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(440px,1.1fr);
  gap:64px;
  align-items:start;
}
.contact-copy h2{margin:8px 0 14px;}
.contact-note{
  padding:20px;
  border:1px dashed var(--line);
  border-radius:var(--radius);
  background:#fff;
}
.contact-note b{
  display:block;
  font-family:'Archivo',sans-serif;
  color:var(--ink);
  margin-bottom:6px;
}
.contact-note span{color:var(--muted);font-size:14px;}

/* ============ FAQ PAGE ============ */
.faq-hero{
  background:linear-gradient(180deg,#FFF8EC 0%,#fff 100%);
  padding:72px 0;
}
.faq-hero-inner{
  display:grid;
  grid-template-columns:minmax(0,1fr) 380px;
  gap:54px;
  align-items:center;
}
.faq-hero h1{
  font-size:clamp(38px,5vw,62px);
  line-height:1;
  margin:18px 0 22px;
}
.faq-hero p{
  max-width:760px;
  color:var(--ink-2);
  font-size:18px;
}
.faq-quick{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
.faq-quick a{
  min-height:58px;
  display:flex;
  align-items:center;
  gap:10px;
  padding:14px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  font-weight:800;
  color:var(--ink-2);
  transition:transform .15s ease, border-color .15s ease, color .15s ease, box-shadow .15s ease;
}
.faq-quick a .num{
  font-size:12px;
  font-weight:900;
  color:var(--muted);
  background:#F4F1EA;
  padding:4px 8px;
  border-radius:6px;
  letter-spacing:.5px;
}
.faq-quick a:hover{
  border-color:var(--blue);
  color:var(--blue);
  transform:translateY(-2px);
  box-shadow:0 8px 20px rgba(15,30,80,.08);
}
.faq-quick a:hover .num{background:var(--blue);color:#fff;}
.faq-quick a.is-active{
  border-color:var(--blue);
  color:var(--blue);
  background:#F4F8FF;
}
.faq-quick a.is-active .num{background:var(--blue);color:#fff;}

/* Sticky scroll-spy TOC inside side panel */
.faq-toc{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:18px;
  box-shadow:var(--shadow);
  margin-bottom:18px;
}
.faq-toc-label{
  font-size:11px;
  font-weight:900;
  letter-spacing:1.4px;
  color:var(--muted);
  text-transform:uppercase;
  margin-bottom:12px;
  padding-left:4px;
}
.faq-toc a{
  position:relative;
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:10px;
  color:var(--ink-2);
  font-weight:600;
  font-size:14.5px;
  line-height:1.3;
  transition:background .15s ease, color .15s ease;
}
.faq-toc a .num{
  font-size:11px;
  font-weight:900;
  color:var(--muted);
  background:#F4F1EA;
  padding:3px 7px;
  border-radius:5px;
  letter-spacing:.4px;
  flex-shrink:0;
  transition:background .15s ease, color .15s ease;
}
.faq-toc a:hover{background:#F4F8FF;color:var(--blue);}
.faq-toc a.is-active{
  background:#F4F8FF;
  color:var(--blue);
  font-weight:800;
}
.faq-toc a.is-active::before{
  content:"";
  position:absolute;
  left:-18px;
  top:8px;
  bottom:8px;
  width:3px;
  background:var(--blue);
  border-radius:0 3px 3px 0;
}
.faq-toc a.is-active .num{background:var(--blue);color:#fff;}

.faq-side-cta h3{font-size:22px;margin-bottom:10px;}
.faq-side-cta p{color:var(--muted);font-size:14px;margin-bottom:18px;}
.faq-page-grid{
  display:grid;
  grid-template-columns:320px minmax(0,1fr);
  gap:48px;
  align-items:start;
}
.faq-side{
  position:sticky;
  top:120px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:26px;
  box-shadow:var(--shadow);
}
.faq-side h3{font-size:24px;margin-bottom:10px;}
.faq-side p{color:var(--muted);font-size:14.5px;margin-bottom:22px;}
.faq-page-list{display:flex;flex-direction:column;gap:34px;}
.faq-group{
  scroll-margin-top:110px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:24px;
}
.faq-group-head{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:18px;
}
.faq-group-head span{
  width:38px;
  height:38px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--blue);
  color:#fff;
  border-radius:50%;
  font-family:'Archivo',sans-serif;
  font-size:13px;
  font-weight:900;
}
.faq-group-head h2{font-size:28px;}

/* ============ OEM / ODM PAGE ============ */
.oem-page-hero{
  background:linear-gradient(135deg,var(--blue-900) 0%,var(--blue) 100%);
  color:#E6EEFA;
  padding:78px 0;
  overflow:hidden;
}
.oem-page-hero h1,
.oem-page-hero h2{color:#fff;}
.oem-page-hero-inner{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(380px,.92fr);
  gap:54px;
  align-items:center;
}
.oem-page-copy h1{
  font-size:clamp(38px,5vw,64px);
  line-height:1;
  margin:18px 0 22px;
}
.oem-page-copy p{font-size:18px;color:#C7D2E3;max-width:720px;}
.oem-page-media{position:relative;}
.oem-page-media::before{
  content:"";
  position:absolute;
  inset:24px -24px -24px 24px;
  border:2px solid rgba(253,202,23,.45);
  border-radius:var(--radius-lg);
}
.oem-page-media img{
  position:relative;
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
}
.oem-service-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
}
.oem-service-grid article{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:24px;
  box-shadow:var(--shadow-sm);
}
.oem-service-grid span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:38px;
  height:38px;
  border-radius:50%;
  background:var(--blue);
  color:#fff;
  font-family:'Archivo',sans-serif;
  font-size:13px;
  font-weight:900;
  margin-bottom:18px;
}
.oem-service-grid h3{font-size:22px;margin-bottom:10px;}
.oem-service-grid p{color:var(--muted);font-size:14.5px;}
.oem-process{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
}
.oem-process div{
  padding:26px 22px;
  background:#fff;
  border-right:1px solid var(--line);
}
.oem-process div:last-child{border-right:0;}
.oem-process b{
  display:block;
  font-family:'Archivo',sans-serif;
  font-size:26px;
  color:var(--blue);
  margin-bottom:18px;
}
.oem-process h4{font-size:18px;margin-bottom:8px;}
.oem-process p{font-size:13.5px;color:var(--muted);}
.oem-detail-grid{
  display:grid;
  grid-template-columns:minmax(0,.92fr) minmax(420px,1.08fr);
  gap:60px;
  align-items:start;
}
.oem-buyer-list{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.oem-buyer-list div{
  background:#fff;
  border:1px solid var(--line);
  border-left:4px solid var(--yellow);
  border-radius:var(--radius);
  padding:20px;
}
.oem-buyer-list b{
  display:block;
  font-family:'Archivo',sans-serif;
  color:var(--ink);
  margin-bottom:6px;
}
.oem-buyer-list span{font-size:14px;color:var(--muted);}

/* ============ SOLUTIONS PAGE ============ */
.solutions-hero{
  background:linear-gradient(180deg,#FFF8EC 0%,#fff 100%);
  padding:72px 0;
}
.solutions-hero-inner{
  display:grid;
  grid-template-columns:minmax(0,1fr) 420px;
  gap:54px;
  align-items:center;
}
.solutions-hero h1{
  font-size:clamp(38px,5vw,62px);
  line-height:1;
  margin:18px 0 22px;
}
.solutions-hero p{
  max-width:760px;
  color:var(--ink-2);
  font-size:18px;
}
.solution-jump{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
.solution-jump a{
  min-height:64px;
  display:flex;
  align-items:center;
  padding:14px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  font-weight:900;
  color:var(--ink-2);
}
.solution-jump a:hover{border-color:var(--blue);color:var(--blue);}
.solution-stack{display:flex;flex-direction:column;gap:34px;}
.solution-block{
  scroll-margin-top:110px;
  display:grid;
  grid-template-columns:minmax(360px,1.05fr) minmax(0,.95fr);
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:0 18px 45px rgba(15,35,60,.06);
}
.solution-block.reverse{grid-template-columns:minmax(0,.95fr) minmax(360px,1.05fr);}
.solution-block.reverse .solution-media{order:2;}
.solution-media img{
  width:100%;
  height:100%;
  min-height:420px;
  object-fit:cover;
}
.solution-copy{
  padding:42px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:flex-start;
  gap:16px;
}
.solution-copy > span{
  font-size:11px;
  font-weight:900;
  letter-spacing:.16em;
  color:var(--blue);
}
.solution-copy h2{font-size:36px;}
.solution-copy p{color:var(--muted);font-size:16px;}
.solution-products{
  width:100%;
  padding:18px;
  background:#FAF6EE;
  border:1px solid var(--line);
  border-radius:var(--radius);
}
.solution-products b{
  display:block;
  font-family:'Archivo',sans-serif;
  margin-bottom:10px;
}
.solution-products ul{
  margin:0;
  padding-left:18px;
  color:var(--ink-2);
  font-size:14px;
}
.solution-products li + li{margin-top:6px;}
.solution-steps{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:1px;
  background:var(--line);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
}
.solution-steps div{
  background:#fff;
  padding:26px;
}
.solution-steps b{
  display:block;
  font-family:'Archivo',sans-serif;
  color:var(--blue);
  font-size:28px;
  margin-bottom:16px;
}
.solution-steps span{font-weight:800;color:var(--ink-2);}

/* ============ INSIGHTS PAGE ============ */
.insights-hero{
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(90deg,rgba(14,42,92,.92) 0%,rgba(30,80,162,.82) 45%,rgba(14,42,92,.56) 100%),
    url("assets/home-fasteners-screws.webp") center 45% / cover no-repeat;
  padding:92px 0 104px;
}
.insights-hero-inner{
  display:block;
}
.insights-hero-copy{max-width:780px;}
.insights-hero .eyebrow,
.insights-hero h1{color:#fff;}
.insights-hero .eyebrow{color:#D8E5FF;}
.insights-hero h1{
  font-size:clamp(38px,5vw,62px);
  line-height:1;
  margin:18px 0 22px;
}
.insights-hero p{
  max-width:760px;
  color:#D8E5FF;
  font-size:18px;
}
.insights-hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:30px;
}
.insights-hero .btn-outline{
  color:#fff;
  border-color:rgba(255,255,255,.72);
  background:rgba(255,255,255,.08);
}
.insights-hero .btn-outline:hover{
  background:#fff;
  color:var(--blue);
}
.insight-feature{
  display:grid;
  grid-template-columns:minmax(360px,1.05fr) minmax(0,.95fr);
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow);
  margin-bottom:28px;
  color:var(--ink);
}
.insight-feature-media img{
  width:100%;
  height:100%;
  min-height:380px;
  object-fit:cover;
}
.insight-feature-copy{
  padding:42px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:flex-start;
  gap:14px;
}
.insight-feature-copy h2{font-size:34px;}
.insight-feature-copy p{color:var(--muted);font-size:16px;}
.insight-meta{
  font-size:12px;
  color:var(--muted);
  font-weight:800;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.insight-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
}
.insight-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  color:var(--ink);
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.insight-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--blue);}
.insight-card img{
  width:100%;
  aspect-ratio:16/10;
  object-fit:cover;
}
.insight-card div{padding:22px;display:flex;flex-direction:column;gap:10px;}
.insight-card h3{font-size:20px;}
.insight-card p{color:var(--muted);font-size:14px;}
.insight-topic-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
}
.insight-topic-grid div{
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:24px;
  background:#fff;
}
.insight-topic-grid h3{font-size:22px;margin-bottom:10px;}
.insight-topic-grid p{color:var(--muted);font-size:14.5px;}
.insight-error{
  padding:24px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  color:var(--muted);
}

/* ============ ARTICLE TEMPLATE ============ */
.article-hero{
  background:linear-gradient(180deg,#FFF8EC 0%,#fff 100%);
  padding:72px 0 56px;
}
.article-hero-inner{max-width:900px;}
.article-back{
  display:inline-flex;
  margin-bottom:22px;
  font-size:13px;
  font-weight:800;
  color:var(--blue);
}
.article-hero h1{
  font-size:clamp(38px,5vw,62px);
  line-height:1;
  margin:18px 0 20px;
}
.article-hero p{
  color:var(--ink-2);
  font-size:18px;
  max-width:760px;
}
.article-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) 320px;
  gap:48px;
  align-items:start;
}
.article-body{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.article-main-image{
  width:100%;
  aspect-ratio:16/8;
  object-fit:cover;
}
.article-body section{padding:34px 38px;border-top:1px solid var(--line);}
.article-body h2{font-size:30px;margin-bottom:14px;}
.article-body p{font-size:16px;color:var(--ink-2);}
.article-side{
  position:sticky;
  top:120px;
  display:flex;
  flex-direction:column;
  gap:16px;
}
.article-sticky-form{
  padding:22px;
  box-shadow:var(--shadow-lg);
}
.article-sticky-form .form-head{
  align-items:flex-start;
  gap:12px;
  margin-bottom:18px;
}
.article-sticky-form .form-head h3{
  font-size:22px;
  line-height:1.08;
}
.article-sticky-form .form-pill{
  flex:none;
  padding:5px 8px;
}
.article-sticky-form label{margin-bottom:12px;}
.article-sticky-form input,
.article-sticky-form select,
.article-sticky-form textarea{
  padding:10px 12px;
  font-size:14px;
}
.article-sticky-form textarea{min-height:96px;}
.article-sticky-form .btn{min-height:42px;justify-content:center;}
.article-sticky-form .form-foot{
  margin-top:10px;
  text-align:left;
  line-height:1.45;
}
.article-checklist{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:24px;
  box-shadow:var(--shadow-sm);
}
.article-checklist h3{font-size:22px;margin-bottom:14px;}
.article-checklist ul{
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.article-checklist li{
  position:relative;
  padding-left:20px;
  color:var(--ink-2);
  font-size:14px;
  font-weight:700;
}
.article-checklist li::before{
  content:"";
  position:absolute;
  left:0;
  top:.65em;
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--yellow);
}

/* ============ PRODUCT CATEGORY PAGE ============ */
.product-hero{
  background:linear-gradient(135deg,var(--blue-900) 0%,var(--blue) 100%);
  color:#E6EEFA;
  padding:78px 0;
  overflow:hidden;
}
.product-hero h1{color:#fff;}
.product-hero-inner{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(440px,1.05fr);
  gap:54px;
  align-items:center;
}
.product-hero h1{
  font-size:clamp(38px,5vw,64px);
  line-height:1;
  margin:18px 0 22px;
}
.product-hero p{font-size:18px;color:#C7D2E3;max-width:760px;}
.product-hero-media{position:relative;}
.product-hero-media::before{
  content:"";
  position:absolute;
  inset:24px -24px -24px 24px;
  border:2px solid rgba(253,202,23,.45);
  border-radius:var(--radius-lg);
}
.product-hero-media img{
  position:relative;
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
}
.product-image-placeholder{
  position:relative;
  min-height:260px;
  width:100%;
  aspect-ratio:4/3;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px dashed rgba(253,202,23,.75);
  border-radius:var(--radius-lg);
  background:linear-gradient(135deg,rgba(255,255,255,.12),rgba(255,255,255,.04));
  color:rgba(255,255,255,.82);
  font-family:'Archivo',sans-serif;
  font-size:18px;
  font-weight:900;
  letter-spacing:.02em;
  text-align:center;
}
.catalog-layout{
  display:grid;
  grid-template-columns:260px minmax(0,1fr);
  gap:34px;
  align-items:start;
}
.catalog-sidebar{
  position:sticky;
  top:120px;
}
.catalog-sidebar-inner{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:18px;
  box-shadow:var(--shadow-sm);
}
.catalog-sidebar h3{
  font-size:20px;
  margin-bottom:14px;
}
.catalog-sidebar a{
  display:block;
  padding:10px 12px;
  border-radius:4px;
  color:var(--ink-2);
  font-size:14px;
  font-weight:800;
}
.catalog-sidebar a:hover{
  background:#FAF6EE;
  color:var(--blue);
}
.catalog-head{
  margin-bottom:24px;
  max-width:760px;
}
.catalog-group{
  scroll-margin-top:110px;
  display:grid;
  grid-template-columns:minmax(360px,390px) minmax(0,1fr);
  gap:0;
  align-items:stretch;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.catalog-group + .catalog-group{margin-top:18px;}
.catalog-group-media{
  background:var(--ink);
  padding:0;
  min-height:100%;
}
.catalog-group-media > img{
  width:100%;
  height:100%;
  min-height:0;
  object-fit:cover;
  background:#FAF8F1;
}
.catalog-group-media .product-image-placeholder{
  min-height:100%;
  aspect-ratio:auto;
  border-color:rgba(253,202,23,.55);
  background:rgba(255,255,255,.05);
  font-size:15px;
}
.fasteners-catalog-container,
.product-catalog-wide-container{
  width:min(1540px, calc(100vw - 220px));
  max-width:none;
  margin-left:clamp(72px, 8vw, 160px);
  margin-right:auto;
  padding-left:0;
  padding-right:0;
}
.fasteners-catalog-layout,
.product-catalog-wide-layout{
  grid-template-columns:250px minmax(0,1fr);
  gap:30px;
}
.fasteners-catalog-layout .catalog-sidebar-inner,
.product-catalog-wide-layout .catalog-sidebar-inner{
  padding:18px;
  border-left:4px solid var(--blue);
}
.fasteners-catalog-layout .catalog-sidebar h3,
.product-catalog-wide-layout .catalog-sidebar h3{
  font-size:20px;
  line-height:1.15;
}
.fasteners-catalog-layout .catalog-sidebar a,
.product-catalog-wide-layout .catalog-sidebar a{
  padding:10px 12px;
  font-size:14px;
}
.fasteners-catalog-layout .catalog-group,
.product-catalog-wide-layout .catalog-group{
  grid-template-columns:minmax(460px,48%) minmax(0,1fr);
  min-height:330px;
}
.fasteners-catalog-layout .catalog-group-media,
.product-catalog-wide-layout .catalog-group-media{
  display:flex;
  align-items:center;
  justify-content:center;
  background:
    linear-gradient(135deg,rgba(30,80,162,.05),rgba(253,202,23,.12)),
    #FAF8F1;
}
.fasteners-catalog-layout .catalog-group-media > img,
.product-catalog-wide-layout .catalog-group-media > img{
  object-fit:contain;
  padding:12px;
}
.fasteners-catalog-layout .catalog-group-body,
.product-catalog-wide-layout .catalog-group-body{
  padding:34px 36px;
}
.fasteners-catalog-layout .catalog-group-body > *,
.product-catalog-wide-layout .catalog-group-body > *{
  max-width:620px;
}
.catalog-group-body{padding:28px;}
.catalog-group-title{
  display:grid;
  grid-template-columns:48px minmax(0,1fr);
  gap:16px;
  margin-bottom:20px;
}
.catalog-group-title > span{
  width:42px;
  height:42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  background:var(--blue);
  color:#fff;
  font-family:'Archivo',sans-serif;
  font-weight:900;
}
.catalog-group-title h2{font-size:30px;margin-bottom:8px;}
.catalog-group-title p{color:var(--muted);font-size:15px;}
.product-category-grid{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:1px;
  background:var(--line);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
}
.product-category-card{
  min-height:190px;
  padding:18px;
  background:#fff;
  display:flex;
  flex-direction:column;
  gap:14px;
  color:var(--ink);
}
.product-category-card:hover{background:var(--ink);color:#fff;}
.product-category-card img{
  width:100%;
  height:126px;
  object-fit:contain;
  background:#FAF8F1;
  border:1px solid #F0E5CC;
  border-radius:4px;
  padding:12px;
}
.product-category-card span{
  font-size:16px;
  font-weight:900;
}
.product-line-stack{display:flex;flex-direction:column;gap:22px;}
.product-line-block{
  scroll-margin-top:110px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:28px;
  box-shadow:var(--shadow-sm);
}
.product-line-head{
  display:grid;
  grid-template-columns:56px minmax(0,1fr);
  gap:18px;
  margin-bottom:20px;
}
.product-line-head > span{
  width:46px;
  height:46px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--blue);
  color:#fff;
  border-radius:50%;
  font-family:'Archivo',sans-serif;
  font-weight:900;
}
.product-line-head h2{font-size:30px;margin-bottom:8px;}
.product-line-head p{color:var(--muted);font-size:15px;}
.product-chip-grid{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.product-chip-grid span{
  padding:8px 11px;
  background:#FAF6EE;
  border:1px solid var(--line);
  border-radius:4px;
  color:var(--ink-2);
  font-size:13px;
  font-weight:800;
}
.catalog-quote-btn{
  margin-top:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  padding:10px 15px;
  border-radius:4px;
  background:var(--blue);
  color:#fff;
  font-size:13px;
  font-weight:900;
  box-shadow:0 3px 0 var(--blue-900), 0 10px 18px -14px rgba(0,51,160,.75);
}
.catalog-quote-btn:hover{
  background:var(--blue-700);
  color:#fff;
  transform:translateY(-1px);
}
.fastener-support-grid{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(420px,1.1fr);
  gap:60px;
  align-items:start;
}
.fastener-support-list{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.fastener-support-list div{
  background:#fff;
  border:1px solid var(--line);
  border-left:4px solid var(--yellow);
  border-radius:var(--radius);
  padding:20px;
}
.fastener-support-list b{
  display:block;
  font-family:'Archivo',sans-serif;
  margin-bottom:6px;
}
.fastener-support-list span{font-size:14px;color:var(--muted);}

.fastener-intent-section{padding-top:72px;}
.fastener-intent-grid{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(520px,1.1fr);
  gap:56px;
  align-items:start;
}
.fastener-intent-grid h2{margin:10px 0 16px;}
.fastener-intent-cards{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.fastener-intent-cards article,
.fastener-rfq-grid article,
.feature-solve-grid article,
.application-card-grid article{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:22px;
  box-shadow:var(--shadow-sm);
}
.fastener-intent-cards b{
  display:block;
  font-family:'Archivo',sans-serif;
  font-size:18px;
  margin-bottom:8px;
}
.fastener-intent-cards span,
.fastener-buyer-note span{
  color:var(--muted);
  font-size:14px;
}
.fastener-buyer-note{
  display:grid;
  grid-template-columns:110px minmax(0,1fr);
  gap:12px;
  align-items:start;
  margin-bottom:18px;
  padding:14px;
  border-left:4px solid var(--yellow);
  background:#FFF9E8;
  border-radius:var(--radius);
}
.fastener-buyer-note b{
  font-family:'Archivo',sans-serif;
  font-size:14px;
}
.product-link-grid a{
  padding:8px 11px;
  background:#F4F8FF;
  border:1px solid #D8E3F6;
  border-radius:4px;
  color:var(--blue);
  font-size:13px;
  font-weight:900;
}
.product-link-grid a:hover{
  background:var(--blue);
  border-color:var(--blue);
  color:#fff;
}
.fastener-rfq-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}
.fastener-rfq-grid span,
.feature-solve-grid span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:38px;
  height:38px;
  margin-bottom:16px;
  border-radius:50%;
  background:var(--blue);
  color:#fff;
  font-family:'Archivo',sans-serif;
  font-weight:900;
}
.fastener-rfq-grid h3,
.feature-solve-grid h3,
.application-card-grid h3{
  font-size:20px;
  margin-bottom:10px;
}
.fastener-rfq-grid p,
.feature-solve-grid p,
.application-card-grid p{
  color:var(--muted);
  font-size:14.5px;
}

/* ============ PRODUCT DETAIL PAGE ============ */
.product-detail-hero{
  background:linear-gradient(135deg,var(--blue-900) 0%,var(--blue) 100%);
  color:#E6EEFA;
  padding:78px 0;
  overflow:hidden;
}
.product-detail-hero-inner{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(430px,.9fr);
  gap:56px;
  align-items:center;
}
.product-detail-copy h1{
  color:#fff;
  font-size:clamp(38px,5vw,64px);
  line-height:1;
  margin:18px 0 22px;
}
.product-detail-copy p{
  max-width:760px;
  color:#C7D2E3;
  font-size:18px;
}
.product-detail-media{
  position:relative;
  padding:18px;
  background:#fff;
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
}
.product-detail-media::before{
  content:"";
  position:absolute;
  inset:36px -20px -20px 36px;
  border:2px solid rgba(253,202,23,.45);
  border-radius:var(--radius-lg);
}
.product-detail-media img{
  position:relative;
  width:100%;
  aspect-ratio:4/3;
  object-fit:contain;
  border-radius:var(--radius);
  background:#FAF8F1;
}
.product-summary-grid,
.product-problem-grid,
.related-products{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(420px,1.1fr);
  gap:56px;
  align-items:start;
}
.product-summary-grid h2,
.product-problem-grid h2,
.related-products h2{margin:10px 0 16px;}
.product-facts,
.problem-list{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.product-facts div,
.problem-list div{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:20px;
}
.product-facts b,
.problem-list b{
  display:block;
  font-family:'Archivo',sans-serif;
  margin-bottom:6px;
}
.product-facts span,
.problem-list span{
  color:var(--muted);
  font-size:14px;
}
.feature-solve-grid,
.application-card-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}
.spec-table-wrap{
  overflow:auto;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
}
.spec-table{
  width:100%;
  border-collapse:collapse;
  background:#fff;
}
.spec-table th,
.spec-table td{
  padding:16px 18px;
  border-bottom:1px solid var(--line);
  text-align:left;
  vertical-align:top;
}
.spec-table tr:last-child th,
.spec-table tr:last-child td{border-bottom:0;}
.spec-table th{
  width:240px;
  background:#FAF6EE;
  font-family:'Archivo',sans-serif;
  color:var(--ink);
}
.spec-table td{color:var(--muted);}
.related-product-links{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
}
.related-product-links a{
  min-height:58px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:12px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:#fff;
  color:var(--blue);
  font-weight:900;
  text-align:center;
}
.related-product-links a:hover{
  background:var(--blue);
  border-color:var(--blue);
  color:#fff;
}

/* ============ RESPONSIVE ============ */
@media (max-width: 1100px){
  .header{position:sticky;}
  .header-inner{position:relative;}
  .nav{
    display:none;
    position:absolute;
    top:100%;
    left:18px;
    right:18px;
    z-index:90;
    padding:12px;
    background:#fff;
    border:1px solid var(--line);
    border-radius:0 0 8px 8px;
    box-shadow:0 18px 45px rgba(15,35,60,.16);
  }
  .nav.is-open{
    display:flex;
    flex-direction:column;
    align-items:stretch;
    gap:2px;
  }
  .nav a{
    padding:11px 12px;
    border-radius:4px;
  }
  .nav a.active::after{display:none;}
  .nav-item{width:100%;}
  .has-dropdown .nav-link{justify-content:space-between;}
  .dropdown{
    position:static;
    min-width:0;
    padding:0 0 4px 12px;
    border:0;
    box-shadow:none;
    opacity:1;
    visibility:visible;
    transform:none;
    background:transparent;
  }
  .dropdown::before{display:none;}
  .dropdown a{
    padding:9px 12px;
    font-size:13px;
    color:var(--muted);
  }
  .nav-search{
    width:100%;
    height:42px;
    justify-content:flex-start;
    padding:0 12px;
  }
  .menu-btn{display:flex;}
  .blog-grid,.cert-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .supply-hero,.supply-hero.reverse{grid-template-columns:1fr;}
  .supply-hero.reverse .supply-media{order:0;}
  .supply-media{aspect-ratio:16/8;}
  .line-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
  .line-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr));}
  .line-grid.compact.safety-home-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
  .quality-grid{grid-template-columns:1fr;gap:28px;}
  .apps-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .oem-grid,.about-grid,.faq-grid,.cta-grid{grid-template-columns:1fr;gap:40px;}
  .about-home-intro{
    grid-template-columns:1fr;
  }
  .about-home-media{
    max-width:520px;
    justify-self:start;
  }
  .about-feature,
  .about-feature.reverse{
    grid-template-columns:1fr;
  }
  .about-feature.reverse .about-feature-media{
    order:0;
    border-left:0;
  }
  .about-feature-media{
    min-height:260px;
    border-right:0;
    border-bottom:1px solid var(--line);
  }
  .about-feature-media img{min-height:260px;}
  .about-badge{right:24px;}
  .oem-stat{left:0;right:0;}
  .why-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .why-item:nth-child(3n){border-right:1px solid #1d2937;}
  .why-item:nth-child(2n){border-right:none;}
  .why-item:nth-last-child(-n+3){border-bottom:1px solid #1d2937;}
  .why-item:nth-last-child(-n+2){border-bottom:none;}
  .footer-inner{grid-template-columns:1fr 1fr;gap:32px;}
  .catalog-band-inner{align-items:flex-start;flex-direction:column;}
  .buyer-wall{grid-template-columns:repeat(3,minmax(0,1fr));}
  .fasteners-catalog-container,
  .product-catalog-wide-container{
    width:auto;
    max-width:var(--container);
    margin-left:auto;
    margin-right:auto;
    padding-left:28px;
    padding-right:28px;
  }
  .about-hero-inner,
  .about-capability,
  .about-capability.reverse{
    grid-template-columns:1fr;
  }
  .about-capability.reverse .capability-copy{order:0;}
  .about-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .about-cta-inner{align-items:flex-start;flex-direction:column;}
  .contact-hero-inner,
  .contact-grid,
  .faq-hero-inner,
  .faq-page-grid,
  .oem-page-hero-inner,
  .oem-detail-grid,
  .solutions-hero-inner,
  .solution-block,
  .solution-block.reverse,
  .insight-feature,
  .article-layout,
  .product-hero-inner,
  .product-detail-hero-inner,
  .fastener-intent-grid,
  .product-summary-grid,
  .product-problem-grid,
  .related-products,
  .fastener-support-grid,
  .catalog-layout,
  .catalog-group{
    grid-template-columns:1fr;
    gap:36px;
  }
  .fasteners-catalog-layout .catalog-group,
  .product-catalog-wide-layout .catalog-group{
    grid-template-columns:1fr;
  }
  .catalog-sidebar{position:static;}
  .catalog-group-media{
    min-height:0;
    aspect-ratio:16/9;
  }
  .catalog-group-media > img{min-height:0;}
  .catalog-group-media .product-image-placeholder{min-height:220px;}
  .article-side{position:static;}
  .solution-block.reverse .solution-media{order:0;}
  .faq-side{position:static;}
  .oem-service-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .oem-process{grid-template-columns:1fr;}
  .oem-process div{border-right:0;border-bottom:1px solid var(--line);}
  .oem-process div:last-child{border-bottom:0;}
  .solution-steps{grid-template-columns:repeat(2,minmax(0,1fr));}
  .insight-grid{grid-template-columns:1fr 1fr;}
  .insight-topic-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .fastener-rfq-grid,
  .feature-solve-grid,
  .application-card-grid,
  .related-product-links{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width: 720px){
  .utility-left .util-item:nth-child(3){display:none;}
  .header-inner{padding:16px 18px;}
  .brand img{height:42px;max-width:180px;}
  .header-cta{gap:8px;}
  .header-cta .btn{
    padding:8px 11px;
    min-height:36px;
    font-size:12px;
    border-radius:4px;
    box-shadow:0 3px 0 var(--blue-900), 0 4px 10px -4px rgba(30,80,162,.35);
  }
  .header-cta .btn svg{width:13px;height:13px;}
  .menu-btn{width:36px;height:36px;}
  .section{padding:64px 0;}
  .container{padding:0 18px;}
  .hero-inner{padding:64px 18px 96px;}
  .hero-title{font-size:36px;}
  .trust-strip{grid-template-columns:1fr;}
  .blog-grid,.apps-grid,.cert-grid{grid-template-columns:1fr 1fr;}
  .supply-copy{padding:30px;}
  .supply-copy h3{font-size:28px;}
  .line-grid,.line-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr));}
  .line-grid.compact.safety-home-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .quality-note{position:static;border-radius:0 0 var(--radius-lg) var(--radius-lg);}
  .quality-media img{border-radius:var(--radius-lg) var(--radius-lg) 0 0;}
  .why-grid{grid-template-columns:1fr;}
  .why-item{border-right:none !important;}
  .footer-inner{grid-template-columns:1fr 1fr;}
  .cta-form{padding:22px;}
  .cta-form .grid-2{grid-template-columns:1fr;}
  .about-pillars{grid-template-columns:1fr;}
  .about-home-intro p{font-size:16px;}
  .about-feature-copy{padding:28px;}
  .about-feature-copy h3{font-size:25px;}
  .about-feature-media{min-height:220px;}
  .about-feature-media img{min-height:220px;}
  .form-head{flex-direction:column;align-items:flex-start;gap:8px;}
  .buyer-wall{grid-template-columns:repeat(2,minmax(0,1fr));}
  .about-hero{padding:48px 0;}
  .about-hero-inner{gap:30px;}
  .about-hero-copy h1{font-size:36px;}
  .capability-copy{padding:30px;}
  .capability-copy h3{font-size:28px;}
  .capability-media,
  .capability-media > img,
  .product-line-media img,
  .cert-strip img{min-height:280px;}
  .product-line-media,
  .cert-strip{grid-template-columns:1fr;}
  .product-detail-hero{padding:52px 0;}
  .product-detail-copy h1{font-size:34px;}
  .fastener-intent-cards,
  .product-facts,
  .problem-list{grid-template-columns:1fr;}
  .fastener-buyer-note{grid-template-columns:1fr;}
  .spec-table th{width:150px;}
}
@media (max-width: 480px){
  .utility{display:none;}
  .blog-grid,.apps-grid,.cert-grid,.buyer-wall,.line-grid,.line-grid.compact{grid-template-columns:1fr;}
  .line-grid.compact.safety-home-grid{grid-template-columns:1fr;}
  .footer-inner{grid-template-columns:1fr;}
  .hero-title{font-size:30px;}
  .about-home-intro h2{font-size:30px;}
  .about-feature-copy{padding:24px;}
  .about-feature-copy h3{font-size:23px;}
  .about-feature-copy p{font-size:15px;}
  .about-stat-grid{grid-template-columns:1fr;}
  .about-hero-actions{flex-direction:column;}
  .contact-hero{padding:48px 0;}
  .contact-hero h1{font-size:34px;}
  .contact-direct div{padding:20px;}
  .faq-hero{padding:48px 0;}
  .faq-hero h1{font-size:34px;}
  .faq-quick{grid-template-columns:1fr;}
  .faq-group{padding:18px;}
  .faq-group-head h2{font-size:24px;}
  .oem-page-hero{padding:52px 0;}
  .oem-page-copy h1{font-size:34px;}
  .oem-service-grid,
  .oem-buyer-list{grid-template-columns:1fr;}
  .solutions-hero{padding:48px 0;}
  .solutions-hero h1{font-size:34px;}
  .solution-jump,
  .solution-steps{grid-template-columns:1fr;}
  .solution-copy{padding:28px;}
  .solution-copy h2{font-size:28px;}
  .solution-media img{min-height:280px;}
  .insights-hero{padding:48px 0;}
  .insights-hero h1{font-size:34px;}
  .insight-grid,
  .insight-topic-grid{grid-template-columns:1fr;}
  .insight-feature-copy{padding:28px;}
  .insight-feature-copy h2{font-size:28px;}
  .insight-feature-media img{min-height:260px;}
  .article-hero{padding:48px 0;}
  .article-hero h1{font-size:34px;}
  .article-body section{padding:26px 22px;}
  .article-body h2{font-size:24px;}
  .fastener-rfq-grid,
  .feature-solve-grid,
  .application-card-grid,
  .related-product-links{grid-template-columns:1fr;}
  .product-detail-media{padding:12px;}
  .product-detail-media::before{display:none;}
  .spec-table th,
  .spec-table td{display:block;width:100%;}
  .spec-table th{border-bottom:0;padding-bottom:6px;}
  .spec-table td{padding-top:6px;}
  .product-hero{padding:52px 0;}
  .product-hero h1{font-size:34px;}
  .product-category-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .product-line-block{padding:22px;}
  .catalog-group{gap:0;}
  .catalog-group-body{padding:22px;}
  .catalog-group-title{grid-template-columns:1fr;}
  .catalog-quote-btn{width:100%;}
  .fastener-support-list{grid-template-columns:1fr;}
}

/* ============ FASTENERS CATEGORY PAGE UPGRADE ============ */
.fasteners-placeholder-media img{
  padding:0;
  aspect-ratio:5/4;
  object-fit:cover;
  background:#0E1A2B;
}
.fastener-quick-grid{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:14px;
}
.fastener-quick-card{
  display:flex;
  min-height:210px;
  flex-direction:column;
  gap:10px;
  padding:18px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  color:var(--ink);
  box-shadow:var(--shadow-sm);
}
.fastener-quick-card:hover{
  transform:translateY(-2px);
  border-color:#D8E3F6;
  box-shadow:var(--shadow-md);
}
.fastener-quick-card > span{
  width:36px;
  height:36px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  background:var(--blue);
  color:#fff;
  font-family:'Archivo',sans-serif;
  font-weight:900;
  font-size:13px;
}
.fastener-quick-card img{
  width:100%;
  height:94px;
  object-fit:contain;
  padding:10px;
  background:#FAF8F1;
  border:1px solid #F0E5CC;
  border-radius:4px;
}
.fastener-quick-card h3{
  font-size:18px;
  margin:2px 0 0;
}
.fastener-quick-card p{
  color:var(--muted);
  font-size:13px;
  margin:0;
}
.fastener-category-expanded{
  display:block;
}
.fastener-category-expanded .catalog-group-body{
  padding:34px 40px;
}
.fastener-category-expanded .catalog-group-body > *{
  max-width:none !important;
}
.fastener-category-subgrid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:16px;
  margin:18px 0;
}
.fastener-category-subgrid > div,
.fastener-spec-fields{
  background:#FAF8F1;
  border:1px solid #F0E5CC;
  border-radius:var(--radius);
  padding:18px;
}
.fastener-category-subgrid h3,
.fastener-spec-fields h3{
  font-size:18px;
  margin-bottom:12px;
}
.fastener-check-list{
  display:grid;
  gap:9px;
  margin:0;
  padding:0;
  list-style:none;
}
.fastener-check-list li{
  position:relative;
  padding-left:20px;
  color:var(--muted);
  font-size:14px;
  line-height:1.5;
}
.fastener-check-list li::before{
  content:"";
  position:absolute;
  left:0;
  top:.62em;
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--yellow);
}
.fastener-mini-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.fastener-mini-tags span{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:7px 10px;
  border-radius:4px;
  background:#fff;
  border:1px solid var(--line);
  color:var(--ink-2);
  font-size:12.5px;
  font-weight:800;
}
.fastener-mini-tags.spec-tags span{
  background:#F4F8FF;
  border-color:#D8E3F6;
  color:var(--blue);
}
/* Catalog page toolbar (Screwfix-style) */
.catalog-toolbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:14px;
  padding:14px 18px;
  margin-bottom:24px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:10px;
}
.catalog-count{font-size:14px;color:var(--ink-2);font-weight:600;}
.catalog-count::before{
  content:"";display:inline-block;width:8px;height:8px;border-radius:50%;
  background:var(--blue);margin-right:8px;vertical-align:middle;
}
.catalog-breadcrumb{font-size:13px;color:var(--muted);}
.catalog-breadcrumb a{color:var(--ink-2);}
.catalog-breadcrumb a:hover{color:var(--blue);}
.catalog-breadcrumb span{margin:0 6px;color:#C7CFDC;}
.catalog-breadcrumb b{color:var(--ink);font-weight:700;}

/* Sidebar count chip */
.catalog-sidebar a .cat-count{
  float:right;
  background:#F1EBDA;
  color:var(--muted);
  font-size:11.5px;
  font-weight:800;
  padding:2px 8px;
  border-radius:10px;
}
.catalog-sidebar a:hover .cat-count{background:var(--yellow);color:var(--ink);}

/* Category block header */
.catalog-cat-block{
  scroll-margin-top:100px;
  margin-bottom:36px;
}
.catalog-cat-block + .catalog-cat-block{padding-top:8px;}
.catalog-cat-head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:14px;
  padding-bottom:14px;
  margin-bottom:18px;
  border-bottom:2px solid var(--line);
}
.catalog-cat-head h2{
  font-size:26px;
  margin:0;
  letter-spacing:-0.01em;
}
.catalog-cat-head span{
  font-size:13px;
  color:var(--muted);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.fastener-product-matrix{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:20px;
  margin-top:0;
}
.fastener-product-card{
  display:flex;
  flex-direction:column;
  padding:18px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:#fff;
  color:var(--ink);
  box-shadow:0 8px 18px -18px rgba(15,23,42,.45);
}
.fastener-product-card:hover{
  border-color:#D8E3F6;
  transform:translateY(-2px);
  box-shadow:var(--shadow-sm);
}
.fastener-product-card img{
  width:100%;
  aspect-ratio:1/1;
  object-fit:contain;
  padding:16px;
  margin-bottom:16px;
  border-radius:8px;
  border:1px solid #F0E5CC;
  background:#FAF8F1;
}
.fastener-product-card b{
  display:block;
  font-family:'Archivo',sans-serif;
  font-size:15px;
  line-height:1.25;
  margin-bottom:3px;
}
.fastener-product-card small{
  color:var(--blue);
  font-size:12px;
  font-weight:900;
  margin-bottom:8px;
}
.fastener-product-card p{
  color:var(--muted);
  font-size:12.8px;
  line-height:1.45;
  margin:0;
}
.fastener-application-grid{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.fastener-application-grid article{
  display:flex;
  flex-direction:column;
}
.fastener-application-grid img,
.fastener-service-card img{
  width:100%;
  height:150px;
  object-fit:contain;
  padding:14px;
  margin-bottom:16px;
  border-radius:var(--radius);
  border:1px solid #F0E5CC;
  background:#FAF8F1;
}
.fastener-application-grid b{
  display:block;
  margin-top:auto;
  padding-top:14px;
  color:var(--blue);
  font-size:13px;
  line-height:1.45;
}
.fastener-checklist-table-wrap{
  overflow:auto;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
}
.fastener-checklist-table{
  min-width:860px;
  margin:0;
}
.fastener-checklist-table thead th{
  background:var(--ink);
  color:#fff;
}
.fastener-service-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.fastener-service-card{
  padding:22px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
}
.fastener-service-card h3{
  font-size:22px;
  margin-bottom:10px;
}
.fastener-service-card p{
  color:var(--muted);
  font-size:14.5px;
}
.fastener-process-grid{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:1px;
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  background:var(--line);
  box-shadow:var(--shadow-sm);
}
.fastener-process-grid article{
  min-height:230px;
  padding:22px;
  background:#fff;
}
.fastener-process-grid span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:38px;
  height:38px;
  margin-bottom:18px;
  border-radius:50%;
  background:var(--blue);
  color:#fff;
  font-family:'Archivo',sans-serif;
  font-weight:900;
}
.fastener-process-grid h3{
  font-size:18px;
  margin-bottom:10px;
}
.fastener-process-grid p{
  color:var(--muted);
  font-size:13.8px;
  line-height:1.5;
}
.fastener-faq-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.fastener-faq-grid article{
  padding:22px;
  background:#fff;
  border:1px solid var(--line);
  border-left:4px solid var(--yellow);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
}
.fastener-faq-grid h3{
  font-size:19px;
  margin-bottom:10px;
}
.fastener-faq-grid p{
  color:var(--muted);
  font-size:14.5px;
}
@media (max-width: 1180px){
  .fastener-quick-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
  .fastener-category-expanded{grid-template-columns:1fr !important;}
  .fastener-product-matrix{grid-template-columns:repeat(2,minmax(0,1fr));}
  .fastener-application-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .fastener-process-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
}
@media (max-width: 720px){
  .fastener-quick-grid,
  .fastener-category-subgrid,
  .fastener-service-grid,
  .fastener-faq-grid{grid-template-columns:1fr;}
  .fastener-application-grid{grid-template-columns:1fr;}
  .fastener-product-matrix{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;}
  .fastener-process-grid{grid-template-columns:1fr;}
  .fastener-product-card{min-height:0;padding:12px;}
}

/* ============ COMMON NAILS PRODUCT PAGE UPGRADE ============ */
.product-breadcrumb{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  margin-bottom:18px;
  color:rgba(255,255,255,.72);
  font-size:13px;
  font-weight:800;
}
.product-breadcrumb a{color:#fff;}
.product-breadcrumb a:hover{color:var(--yellow);}
.product-image-placeholder-card img{
  padding:24px;
  background:#FAF8F1;
  object-fit:contain;
}
.product-snapshot-grid,
.product-overview-wide,
.quality-control-product-grid{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(520px,1.1fr);
  gap:56px;
  align-items:start;
}
.product-snapshot-list{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.product-snapshot-list div{
  padding:18px;
  background:#fff;
  border:1px solid var(--line);
  border-left:4px solid var(--yellow);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
}
.product-snapshot-list b{
  display:block;
  margin-bottom:6px;
  font-family:'Archivo',sans-serif;
  font-size:14px;
}
.product-snapshot-list span{
  color:var(--muted);
  font-size:13.5px;
  line-height:1.45;
}
.product-gallery-grid{
  display:grid;
  grid-template-columns:2fr repeat(2,1fr);
  gap:14px;
}
.product-gallery-grid article{
  padding:16px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
}
.product-gallery-grid article:first-child{
  grid-row:span 2;
}
.product-gallery-grid img{
  width:100%;
  height:190px;
  object-fit:contain;
  padding:14px;
  background:#FAF8F1;
  border:1px solid #F0E5CC;
  border-radius:var(--radius);
}
.product-gallery-grid article:first-child img{height:430px;}
.product-gallery-grid h3{
  margin-top:12px;
  font-size:17px;
}
.product-overview-wide p + p{
  margin-top:14px;
  color:var(--muted);
  line-height:1.7;
}
.product-feature-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
}
.product-feature-grid article{
  padding:22px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
}
.product-feature-grid span,
.qc-check-grid span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:38px;
  height:38px;
  margin-bottom:16px;
  border-radius:50%;
  background:var(--blue);
  color:#fff;
  font-family:'Archivo',sans-serif;
  font-weight:900;
}
.product-feature-grid h3{
  font-size:20px;
  margin-bottom:10px;
}
.product-feature-grid p{
  color:var(--muted);
  font-size:14.5px;
  line-height:1.55;
}
.enhanced-problem-list{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.product-spec-table{
  min-width:980px;
}
.product-spec-table thead th{
  background:var(--ink);
  color:#fff;
}
.mfp-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}
.mfp-grid article{
  padding:24px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
}
.mfp-grid h3{
  font-size:22px;
  margin-bottom:14px;
}
.mfp-grid ul{
  display:grid;
  gap:10px;
  margin:0;
  padding:0;
  list-style:none;
}
.mfp-grid li{
  position:relative;
  padding-left:20px;
  color:var(--muted);
  font-size:14.5px;
  line-height:1.5;
}
.mfp-grid li::before{
  content:"";
  position:absolute;
  left:0;
  top:.62em;
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--yellow);
}
.product-application-grid{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.product-application-grid article{
  display:flex;
  flex-direction:column;
}
.product-application-grid img{
  width:100%;
  height:150px;
  object-fit:contain;
  padding:14px;
  margin-bottom:16px;
  border-radius:var(--radius);
  border:1px solid #F0E5CC;
  background:#FAF8F1;
}
.qc-check-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.qc-check-grid div{
  padding:18px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
}
.qc-check-grid span{
  width:34px;
  height:34px;
  margin:0 10px 0 0;
  vertical-align:middle;
  font-size:12px;
}
.qc-check-grid b{
  font-size:14.5px;
}
.related-product-card-grid{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:12px;
}
.related-product-card-grid a{
  display:block;
  padding:18px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  color:var(--ink);
  box-shadow:var(--shadow-sm);
}
.related-product-card-grid a:hover{
  transform:translateY(-2px);
  border-color:#D8E3F6;
  box-shadow:var(--shadow-md);
}
.related-product-card-grid h3{
  font-size:18px;
  margin-bottom:8px;
}
.related-product-card-grid p{
  color:var(--muted);
  font-size:13.5px;
  line-height:1.45;
}
.product-faq-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.product-faq-grid article{
  padding:22px;
  background:#fff;
  border:1px solid var(--line);
  border-left:4px solid var(--yellow);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
}
.product-faq-grid h3{
  font-size:19px;
  margin-bottom:10px;
}
.product-faq-grid p{
  color:var(--muted);
  font-size:14.5px;
  line-height:1.55;
}
@media (max-width: 1180px){
  .product-snapshot-grid,
  .product-overview-wide,
  .quality-control-product-grid{grid-template-columns:1fr;}
  .product-feature-grid,
  .mfp-grid,
  .product-application-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .related-product-card-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
}
@media (max-width: 720px){
  .product-snapshot-list,
  .product-gallery-grid,
  .product-feature-grid,
  .enhanced-problem-list,
  .mfp-grid,
  .product-application-grid,
  .qc-check-grid,
  .related-product-card-grid,
  .product-faq-grid{grid-template-columns:1fr;}
  .product-gallery-grid article:first-child{grid-row:auto;}
  .product-gallery-grid article:first-child img,
  .product-gallery-grid img{height:220px;}
}

/* =====================================================================
   PRODUCT DETAIL PAGE (PDP) — Amazon / Screwfix style
   ===================================================================== */

/* --- Top: gallery + buy box --- */
.pdp-top{padding:36px 0 8px;}
.pdp-top-grid{
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);
  gap:48px;
  margin-top:18px;
  align-items:start;
}

/* Gallery */
.pdp-gallery{position:sticky;top:96px;}
.pdp-main-image{
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  background:#fff;
  aspect-ratio:1/1;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  padding:28px;
}
.pdp-main-image img{
  width:100%;height:100%;
  object-fit:contain;
  transition:opacity .2s ease;
}
.pdp-thumbs{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:10px;
  margin-top:12px;
}
.pdp-thumb{
  border:1px solid var(--line);
  border-radius:8px;
  background:#fff;
  padding:6px;
  cursor:pointer;
  aspect-ratio:1/1;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .15s, box-shadow .15s;
}
.pdp-thumb img{width:100%;height:100%;object-fit:contain;}
.pdp-thumb:hover{border-color:#C3D2EC;}
.pdp-thumb.is-active{border-color:var(--blue);box-shadow:0 0 0 1px var(--blue) inset;}

/* Buy box */
.pdp-buybox{padding-top:4px;}
.pdp-badge{
  display:inline-block;
  background:#FFF3D6;
  color:#8A5A00;
  font-family:'Archivo',sans-serif;
  font-weight:800;
  font-size:12px;
  letter-spacing:.04em;
  padding:6px 12px;
  border-radius:6px;
  margin-bottom:14px;
}
.pdp-buybox h1{
  font-size:clamp(24px,3vw,32px);
  line-height:1.2;
  letter-spacing:-0.01em;
  margin-bottom:12px;
}
.pdp-sku{font-size:13.5px;color:var(--muted);margin-bottom:22px;}
.pdp-sku a{color:var(--blue);font-weight:700;}

.pdp-highlights{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1px;
  background:var(--line);
  border:1px solid var(--line);
  border-radius:10px;
  overflow:hidden;
  margin-bottom:24px;
}
.pdp-highlights li{
  background:#fff;
  padding:12px 16px;
  display:flex;flex-direction:column;gap:2px;
}
.pdp-highlights li span{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;}
.pdp-highlights li b{font-family:'Archivo',sans-serif;font-size:15px;color:var(--ink);}

.pdp-selectors{margin-bottom:22px;max-width:260px;}
.pdp-selectors label span{
  display:block;font-size:13px;font-weight:700;color:var(--ink-2);margin-bottom:6px;
}
.pdp-selectors select{
  width:100%;
  padding:12px 14px;
  border:1px solid var(--line);
  border-radius:8px;
  background:#fff;
  font-size:15px;
  font-family:inherit;
  color:var(--ink);
}

.pdp-cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:24px;}

.pdp-trust{display:flex;flex-direction:column;gap:10px;}
.pdp-trust li{
  display:flex;align-items:center;gap:10px;
  font-size:14px;color:var(--ink-2);
}
.pdp-trust li svg{color:var(--blue);flex:none;}

/* --- Description + Features + Specifications --- */
.pdp-info-grid{
  display:grid;
  grid-template-columns:minmax(0,1.5fr) minmax(0,1fr);
  gap:48px;
  align-items:start;
}
.pdp-description h2,
.pdp-specs h2{font-size:24px;margin-bottom:18px;}
.pdp-description p{
  color:var(--ink-2);
  font-size:16px;
  line-height:1.75;
  margin-bottom:16px;
}
.pdp-description h3{
  font-size:19px;
  margin:30px 0 14px;
  padding-top:24px;
  border-top:1px solid var(--line);
}
.pdp-feature-list{display:flex;flex-direction:column;gap:12px;list-style:none;margin:0;padding:0;}
.pdp-feature-list li{
  position:relative;
  padding-left:24px;
  color:var(--ink-2);
  font-size:15.5px;
  line-height:1.6;
}
.pdp-feature-list li::before{
  content:"";
  position:absolute;
  left:4px;top:9px;
  width:7px;height:7px;
  border-radius:50%;
  background:var(--ink);
}

/* Specifications — clean key/value with horizontal dividers */
.pdp-specs{
  position:sticky;top:96px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:26px;
  box-shadow:var(--shadow-sm);
}
.pdp-spec-list{margin-bottom:22px;}
.pdp-spec-list > div{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:18px;
  padding:13px 0;
  border-bottom:1px solid var(--line);
}
.pdp-spec-list > div:first-child{padding-top:0;}
.pdp-spec-list > div:last-child{border-bottom:none;}
.pdp-spec-list dt{
  font-size:14px;
  color:var(--muted);
  flex:none;
}
.pdp-spec-list dd{
  font-family:'Archivo',sans-serif;
  font-weight:700;
  font-size:14.5px;
  color:var(--ink);
  text-align:right;
}

/* --- Documents --- */
.pdp-doc-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}
.pdp-doc-card{
  display:flex;
  align-items:center;
  gap:16px;
  padding:20px 22px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  transition:transform .18s, box-shadow .18s, border-color .18s;
}
.pdp-doc-card:hover{
  transform:translateY(-3px);
  box-shadow:0 14px 30px rgba(15,30,80,.08);
  border-color:var(--blue);
}
.pdp-doc-icon{
  width:48px;height:48px;flex:none;
  border-radius:10px;
  background:#F4F8FF;
  color:var(--blue);
  display:inline-flex;align-items:center;justify-content:center;
}
.pdp-doc-text{display:flex;flex-direction:column;gap:3px;flex:1;}
.pdp-doc-text b{font-family:'Archivo',sans-serif;font-size:16px;color:var(--ink);}
.pdp-doc-text small{font-size:13px;color:var(--muted);}
.pdp-doc-dl{color:var(--muted);flex:none;transition:color .18s, transform .18s;}
.pdp-doc-card:hover .pdp-doc-dl{color:var(--blue);transform:translateY(2px);}

/* --- PDP FAQ uses shared .faq-list accordion --- */
.pdp-faq-list{max-width:900px;}

/* --- Back to top button --- */
.back-to-top{
  position:fixed;
  right:26px;bottom:26px;
  width:48px;height:48px;
  border-radius:50%;
  background:var(--blue);
  color:#fff;
  border:none;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 26px rgba(15,30,80,.28);
  opacity:0;
  visibility:hidden;
  transform:translateY(12px);
  transition:opacity .25s, visibility .25s, transform .25s, background .15s;
  z-index:90;
}
.back-to-top.is-visible{opacity:1;visibility:visible;transform:translateY(0);}
.back-to-top:hover{background:var(--blue-700,#16407f);transform:translateY(-3px);}

@media (max-width: 980px){
  .pdp-top-grid{grid-template-columns:1fr;gap:30px;}
  .pdp-gallery{position:static;}
  .pdp-info-grid{grid-template-columns:1fr;gap:32px;}
  .pdp-specs{position:static;}
}
@media (max-width: 600px){
  .pdp-thumbs{grid-template-columns:repeat(5,1fr);}
  .pdp-highlights{grid-template-columns:1fr;}
  .pdp-doc-grid{grid-template-columns:1fr;}
  .pdp-cta-row .btn{flex:1;justify-content:center;}
  .back-to-top{right:16px;bottom:16px;}
}

/* =====================================================================
   CATALOG FILTER PANEL (category page)
   ===================================================================== */
.catalog-shown{color:var(--blue);font-weight:700;margin-left:4px;}

.catalog-filter{
  margin-top:16px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:12px;
  padding:18px;
}
.catalog-filter-head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:14px;
}
.catalog-filter-head h3{margin:0;font-size:15px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);}
.catalog-filter-clear{
  background:none;border:none;cursor:pointer;
  font-size:12.5px;font-weight:700;color:var(--blue);
}
.catalog-filter-clear:hover{text-decoration:underline;}
.filter-group{padding-top:14px;border-top:1px solid var(--line);margin-top:14px;}
.filter-group:first-of-type{padding-top:0;border-top:none;margin-top:0;}
.filter-group h4{
  font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  color:var(--muted);margin-bottom:10px;
}
.filter-check{
  display:flex;align-items:center;gap:9px;
  padding:5px 0;cursor:pointer;
  font-size:14px;color:var(--ink-2);
}
.filter-check input{
  width:16px;height:16px;flex:none;
  accent-color:var(--blue);cursor:pointer;
}
.filter-check:hover{color:var(--blue);}

.catalog-empty{
  text-align:center;
  padding:48px 20px;
  background:#fff;
  border:1px dashed var(--line);
  border-radius:var(--radius-lg);
}
.catalog-empty p{color:var(--muted);margin-bottom:16px;font-size:15px;}

@media (max-width: 900px){
  .catalog-filter{margin-top:14px;}
}

/* =====================================================================
   PDP — ORDER INFORMATION (MOQ / lead time / price tiers)
   ===================================================================== */
.order-info-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
  margin-bottom:28px;
}
.order-info-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:22px;
  display:flex;flex-direction:column;gap:4px;
}
.order-info-label{font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);}
.order-info-value{font-family:'Archivo',sans-serif;font-size:24px;color:var(--blue);line-height:1.1;}
.order-info-card small{font-size:13px;color:var(--ink-2);}

.price-tier-wrap{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:8px 24px 20px;
}
.price-tier-table{width:100%;border-collapse:collapse;}
.price-tier-table th,
.price-tier-table td{
  text-align:left;
  padding:15px 12px;
  border-bottom:1px solid var(--line);
  font-size:15px;
}
.price-tier-table thead th{
  font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:800;
}
.price-tier-table tbody tr:last-child td{border-bottom:none;}
.price-tier-table td b{font-family:'Archivo',sans-serif;}
.tier-featured{background:#F4F8FF;}
.tier-badge{
  display:inline-block;margin-left:8px;
  background:var(--yellow);color:var(--ink);
  font-size:11px;font-weight:800;padding:2px 8px;border-radius:10px;vertical-align:middle;
}
.tier-cta{text-align:right;}
.tier-cta a{color:var(--blue);font-weight:700;font-size:14px;}
.tier-cta a:hover{text-decoration:underline;}
.price-tier-note{margin-top:14px;font-size:13px;color:var(--muted);}

/* =====================================================================
   PDP — RELATED PRODUCTS
   ===================================================================== */
.related-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
  margin-top:8px;
}
.related-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:16px;
  display:flex;flex-direction:column;
  transition:transform .18s, box-shadow .18s, border-color .18s;
}
.related-card:hover{
  transform:translateY(-3px);
  box-shadow:0 14px 30px rgba(15,30,80,.08);
  border-color:var(--blue);
}
.related-img{
  aspect-ratio:1/1;
  background:#FAF8F1;
  border:1px solid #F0E5CC;
  border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  padding:14px;margin-bottom:12px;
}
.related-img img{width:100%;height:100%;object-fit:contain;}
.related-card b{font-family:'Archivo',sans-serif;font-size:16px;color:var(--ink);margin-bottom:5px;}
.related-card p{font-size:13.5px;color:var(--muted);line-height:1.5;}

@media (max-width: 900px){
  .order-info-grid{grid-template-columns:1fr 1fr;}
  .related-grid{grid-template-columns:1fr 1fr;}
}
@media (max-width: 600px){
  .order-info-grid{grid-template-columns:1fr 1fr;}
  .related-grid{grid-template-columns:1fr 1fr;}
  .price-tier-table th:nth-child(3),
  .price-tier-table td:nth-child(3){display:none;}
}

/* =====================================================================
   CATEGORY PAGE — SEO INTRO / INTERNAL LINKS
   ===================================================================== */
.seo-intro-grid{
  display:grid;
  grid-template-columns:minmax(0,1.7fr) minmax(0,1fr);
  gap:48px;
  align-items:start;
}
.seo-intro-copy h2{font-size:clamp(26px,3vw,34px);line-height:1.15;margin:12px 0 18px;}
.seo-intro-copy p{
  color:var(--ink-2);
  font-size:16px;
  line-height:1.75;
  margin-bottom:16px;
}
.seo-intro-copy strong{color:var(--ink);font-weight:700;}
.seo-intro-links{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:24px 26px;
  box-shadow:var(--shadow-sm);
}
.seo-intro-links h3{
  font-size:13px;text-transform:uppercase;letter-spacing:.06em;
  color:var(--muted);margin:0 0 12px;
}
.seo-intro-links h3:not(:first-child){margin-top:22px;padding-top:18px;border-top:1px solid var(--line);}
.seo-intro-links ul{list-style:none;margin:0;padding:0;}
.seo-intro-links li{margin-bottom:8px;}
.seo-intro-links a{
  color:var(--ink-2);font-size:15px;font-weight:600;
  display:inline-flex;align-items:center;gap:6px;
}
.seo-intro-links a::before{
  content:"›";color:var(--blue);font-weight:800;
}
.seo-intro-links a:hover{color:var(--blue);}

@media (max-width: 900px){
  .seo-intro-grid{grid-template-columns:1fr;gap:28px;}
}
