/* ============================================================
   steels-main.css
   Steels Corporate Theme — Component Stylesheet
   All UI components: header, nav, hero slider, sections,
   product cards, footer, animations, responsive overrides.
   ============================================================ */


/* ============================================================
   SECTION 1: SITE HEADER & TOP BAR
   ============================================================ */

/* ── Site Header wrapper ──────────────────────────────────── */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: var(--z-sticky);
  transition: background var(--transition-slow),
              box-shadow var(--transition-slow),
              transform var(--transition-slow);
}

/* Scrolled state — injected by JS */
.site-header.is-scrolled {
  box-shadow: 0 2px 24px rgba(0,0,0,0.18);
}

.site-header.is-scrolled .topbar {
  height: 0;
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
}

/* Hidden on scroll-down, visible on scroll-up */
.site-header.is-hidden {
  transform: translateY(-100%);
}

/* ── Top Utility Bar ──────────────────────────────────────── */
.topbar {
  background: var(--clr-dark);
  height: var(--topbar-height);
  display: flex;
  align-items: center;
  transition: height var(--transition-slow), opacity var(--transition-slow);
  overflow: hidden;
}

.topbar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  width: 100%;
}

.topbar__left {
  display: flex;
  align-items: center;
  gap: var(--space-6);
}

.topbar__right {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.topbar__contact-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  color: var(--clr-silver);
  letter-spacing: var(--ls-wide);
  transition: color var(--transition-fast);
}

.topbar__contact-link:hover { color: var(--clr-white); }

.topbar__icon {
  width: 13px;
  height: 13px;
  flex-shrink: 0;
  color: var(--clr-accent);
}

/* Topbar navigation */
.topbar__nav .topbar__menu {
  display: flex;
  align-items: center;
  gap: 0;
  list-style: none;
}

.topbar__menu li a {
  display: block;
  padding: var(--space-1) var(--space-4);
  font-size: var(--text-xs);
  color: var(--clr-silver);
  letter-spacing: var(--ls-wide);
  border-right: 1px solid rgba(255,255,255,0.1);
  transition: color var(--transition-fast);
}

.topbar__menu li:first-child a { padding-left: 0; }
.topbar__menu li:last-child a { border-right: none; }
.topbar__menu li a:hover { color: var(--clr-white); }

/* Social links in topbar */
.topbar .social-links--topbar {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  border-left: 1px solid rgba(255,255,255,0.1);
  padding-left: var(--space-4);
  margin-left: var(--space-2);
}

.topbar .social-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  color: var(--clr-slate);
  transition: color var(--transition-fast);
}

.topbar .social-link:hover { color: var(--clr-white); }
.topbar .social-link svg { width: 13px; height: 13px; }


/* ── Primary Navigation Bar ───────────────────────────────── */
.nav-bar {
  background: var(--clr-navy);
  height: var(--nav-height);
  display: flex;
  align-items: center;
  position: relative;
}

/* Subtle bottom accent line */
.nav-bar::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--clr-accent) 0%, transparent 60%);
  opacity: 0;
  transition: opacity var(--transition-slow);
}

.site-header.is-scrolled .nav-bar::after { opacity: 1; }

.nav-bar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  width: 100%;
  height: 100%;
}


/* ── Logo ─────────────────────────────────────────────────── */
.site-logo {
  display: flex;
  flex-direction: column;
  gap: 2px;
  text-decoration: none;
  flex-shrink: 0;
}

.site-logo__img {
  max-height: 52px;
  width: auto;
}

.site-logo__text {
  font-family: var(--font-display);
  font-size: 1.6rem;
  font-weight: var(--fw-black);
  letter-spacing: -0.04em;
  color: var(--clr-white);
  line-height: 1;
  text-transform: uppercase;
}

/* Accent the "S" in Steels */
.site-logo__text::first-letter {
  color: var(--clr-accent);
}

.site-logo__tagline {
  font-size: var(--text-xs);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--clr-slate);
  line-height: 1;
}

.site-logo--footer .site-logo__text { font-size: 1.4rem; }
.site-logo--footer .site-logo__tagline { color: var(--clr-slate); }


/* ── Nav Menu ─────────────────────────────────────────────── */
.nav-bar__nav {
  flex: 1;
  display: flex;
  justify-content: center;
  height: 100%;
}

.nav-menu {
  display: flex;
  align-items: center;
  list-style: none;
  height: 100%;
  gap: 0;
}

.nav-menu > .menu-item {
  position: relative;
  height: 100%;
  display: flex;
  align-items: center;
}

/* Nav links */
.nav-link {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0 var(--space-5);
  height: 100%;
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wide);
  color: var(--clr-text-on-dark);
  text-decoration: none;
  white-space: nowrap;
  transition: color var(--transition-fast);
  position: relative;
}

/* Animated underline */
.nav-link::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: var(--space-5);
  right: var(--space-5);
  height: 2px;
  background: var(--clr-accent);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition-base);
}

.nav-menu > .menu-item:hover > .nav-link,
.nav-menu > .menu-item.current-menu-item > .nav-link,
.nav-menu > .menu-item.current-menu-ancestor > .nav-link {
  color: var(--clr-white);
}

.nav-menu > .menu-item:hover > .nav-link::after,
.nav-menu > .menu-item.current-menu-item > .nav-link::after,
.nav-menu > .menu-item.current-menu-ancestor > .nav-link::after {
  transform: scaleX(1);
}

.nav-link[aria-current="page"] { color: var(--clr-white); }
.nav-link[aria-current="page"]::after { transform: scaleX(1); }

/* Dropdown caret */
.dropdown-indicator {
  width: 10px;
  height: 10px;
  transition: transform var(--transition-base);
  flex-shrink: 0;
}

.menu-item:hover > .nav-link .dropdown-indicator {
  transform: rotate(180deg);
}


/* ── Dropdown Menus ───────────────────────────────────────── */
.sub-menu {
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 240px;
  background: var(--clr-white);
  border-top: 3px solid var(--clr-accent);
  box-shadow: var(--shadow-lg);
  border-radius: 0 0 var(--radius) var(--radius);
  list-style: none;
  opacity: 0;
  visibility: hidden;
  transform: translateY(12px);
  transition: opacity var(--transition-base),
              visibility var(--transition-base),
              transform var(--transition-base);
  z-index: var(--z-dropdown);
  padding: var(--space-3) 0;
}

.menu-item:hover > .sub-menu,
.menu-item:focus-within > .sub-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.sub-menu .menu-item { position: relative; }

.sub-menu .nav-link {
  display: block;
  padding: var(--space-3) var(--space-6);
  height: auto;
  color: var(--clr-text-secondary);
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  letter-spacing: normal;
  transition: background var(--transition-fast), color var(--transition-fast);
}

.sub-menu .nav-link::after { display: none; }

.sub-menu .menu-item:hover > .nav-link {
  background: var(--clr-off-white);
  color: var(--clr-accent);
}

/* Third-level dropdown */
.sub-menu .sub-menu {
  top: -3px;
  left: 100%;
}


/* ── Nav Controls (right side) ────────────────────────────── */
.nav-bar__controls {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-shrink: 0;
}

/* Search button */
.nav-search-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-full);
  color: var(--clr-silver);
  cursor: pointer;
  transition: color var(--transition-fast), background var(--transition-fast);
  background: transparent;
}

.nav-search-btn:hover,
.nav-search-btn[aria-expanded="true"] {
  color: var(--clr-white);
  background: rgba(255,255,255,0.08);
}

.nav-icon { width: 18px; height: 18px; }

/* Navigation CTA */
.nav-cta { flex-shrink: 0; }

/* Hamburger — mobile only */
.hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 40px;
  height: 40px;
  cursor: pointer;
  background: transparent;
  border: none;
  padding: var(--space-2);
}

.hamburger__bar {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--clr-white);
  border-radius: var(--radius-full);
  transition: transform var(--transition-base), opacity var(--transition-base);
  transform-origin: center;
}

/* Active hamburger → X */
.hamburger[aria-expanded="true"] .hamburger__bar--top {
  transform: translateY(7px) rotate(45deg);
}
.hamburger[aria-expanded="true"] .hamburger__bar--mid {
  opacity: 0;
  transform: scaleX(0);
}
.hamburger[aria-expanded="true"] .hamburger__bar--bot {
  transform: translateY(-7px) rotate(-45deg);
}


/* ── Search Overlay ───────────────────────────────────────── */
.search-overlay {
  position: fixed;
  inset: 0;
  z-index: var(--z-overlay);
  background: rgba(10, 18, 30, 0.97);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity var(--transition-slow);
  pointer-events: none;
}

.search-overlay:not([hidden]) {
  opacity: 1;
  pointer-events: all;
}

.search-overlay__inner {
  width: 100%;
  padding-block: var(--space-20);
}

.search-overlay__prompt {
  font-size: var(--text-md);
  color: var(--clr-slate);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  margin-bottom: var(--space-8);
  text-align: center;
}

/* WP Search form inside overlay */
.search-overlay .search-form {
  display: flex;
  align-items: stretch;
  max-width: 720px;
  margin: 0 auto;
  border-bottom: 2px solid var(--clr-steel);
  padding-bottom: var(--space-4);
}

.search-overlay .search-field {
  flex: 1;
  background: transparent;
  border: none;
  color: var(--clr-white);
  font-size: var(--text-xl);
  font-weight: var(--fw-light);
  outline: none;
  padding: var(--space-4) 0;
}

.search-overlay .search-field::placeholder {
  color: var(--clr-slate);
}

.search-overlay .search-submit {
  background: transparent;
  border: none;
  color: var(--clr-accent);
  cursor: pointer;
  padding: 0 var(--space-4);
  font-size: var(--text-md);
  font-weight: var(--fw-bold);
  transition: transform var(--transition-fast);
}

.search-overlay .search-submit:hover { transform: scale(1.1); }

/* Search hints */
.search-overlay__hints {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  margin-top: var(--space-8);
  flex-wrap: wrap;
}

.search-overlay__hint-label {
  font-size: var(--text-sm);
  color: var(--clr-slate);
}

.search-hint-tag {
  padding: var(--space-1) var(--space-4);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: var(--radius-full);
  font-size: var(--text-sm);
  color: var(--clr-silver);
  transition: border-color var(--transition-fast), color var(--transition-fast);
}

.search-hint-tag:hover {
  border-color: var(--clr-accent);
  color: var(--clr-accent);
}

/* Close button */
.search-overlay__close {
  position: absolute;
  top: var(--space-6);
  right: var(--space-6);
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-full);
  background: rgba(255,255,255,0.05);
  color: var(--clr-silver);
  transition: background var(--transition-fast), color var(--transition-fast);
  cursor: pointer;
}

.search-overlay__close:hover {
  background: rgba(255,255,255,0.1);
  color: var(--clr-white);
}

.search-overlay__close svg { width: 20px; height: 20px; }

/* Nav overlay backdrop */
.nav-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  z-index: calc(var(--z-sticky) - 1);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-slow);
}

.nav-overlay.is-visible {
  opacity: 1;
  pointer-events: all;
}


/* ============================================================
   SECTION 2: HERO SLIDER
   ============================================================ */

.hero-slider {
  position: relative;
  width: 100%;
  height: 100vh;
  min-height: 580px;
  max-height: 900px;
  overflow: hidden;
  background: var(--clr-dark);
  margin-top: var(--header-total);
}

/* Each slide */
.hero-slide {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-end;
  opacity: 0;
  transition: opacity 1s var(--ease-in-out);
  pointer-events: none;
}

.hero-slide.is-active {
  opacity: 1;
  pointer-events: auto;
  z-index: 1;
}

/* Slide background */
.hero-slide__bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transform: scale(1.06);
  transition: transform 8s var(--ease-out);
}

.hero-slide.is-active .hero-slide__bg {
  transform: scale(1);
}

/* Multi-layer overlay for readability */
.hero-slide__overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to right, rgba(10,18,30,0.92) 0%, rgba(10,18,30,0.4) 60%, transparent 100%),
    linear-gradient(to top, rgba(10,18,30,0.7) 0%, transparent 50%);
}

/* Content container */
.hero-slide__content {
  position: relative;
  z-index: 2;
  width: 100%;
  padding-bottom: clamp(4rem, 8vw, 7rem);
}

.hero-slide__inner {
  max-width: 760px;
}

/* Slide label / eyebrow */
.hero-slide__label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--clr-accent);
  margin-bottom: var(--space-5);

  /* Animation state */
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s var(--ease-out-expo) 0.3s,
              transform 0.6s var(--ease-out-expo) 0.3s;
}

.hero-slide__label::before {
  content: '';
  display: block;
  width: 32px;
  height: 2px;
  background: var(--clr-accent);
  flex-shrink: 0;
}

.hero-slide.is-active .hero-slide__label {
  opacity: 1;
  transform: translateY(0);
}

/* Headline */
.hero-slide__title {
  font-size: var(--text-hero);
  font-weight: var(--fw-black);
  line-height: 1.05;
  letter-spacing: var(--ls-tight);
  color: var(--clr-white);
  margin-bottom: var(--space-6);

  opacity: 0;
  transform: translateY(32px);
  transition: opacity 0.7s var(--ease-out-expo) 0.5s,
              transform 0.7s var(--ease-out-expo) 0.5s;
}

.hero-slide.is-active .hero-slide__title {
  opacity: 1;
  transform: translateY(0);
}

/* Subheading */
.hero-slide__sub {
  font-size: var(--text-md);
  line-height: var(--lh-snug);
  color: rgba(255,255,255,0.8);
  font-weight: var(--fw-light);
  margin-bottom: var(--space-10);
  max-width: 600px;

  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.7s var(--ease-out-expo) 0.65s,
              transform 0.7s var(--ease-out-expo) 0.65s;
}

.hero-slide.is-active .hero-slide__sub {
  opacity: 1;
  transform: translateY(0);
}

/* CTA buttons */
.hero-slide__actions {
  display: flex;
  align-items: center;
  gap: var(--space-5);
  flex-wrap: wrap;

  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s var(--ease-out-expo) 0.8s,
              transform 0.6s var(--ease-out-expo) 0.8s;
}

.hero-slide.is-active .hero-slide__actions {
  opacity: 1;
  transform: translateY(0);
}

/* Slider controls */
.hero-controls {
  position: absolute;
  bottom: var(--space-10);
  right: var(--space-12);
  z-index: 10;
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.hero-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border: 1px solid rgba(255,255,255,0.25);
  border-radius: var(--radius-full);
  background: rgba(255,255,255,0.05);
  color: var(--clr-white);
  cursor: pointer;
  transition: background var(--transition-base), border-color var(--transition-base);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.hero-arrow:hover {
  background: var(--clr-accent);
  border-color: var(--clr-accent);
}

.hero-arrow svg { width: 18px; height: 18px; }

/* Slide dots / progress */
.hero-dots {
  position: absolute;
  bottom: var(--space-10);
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.hero-dot {
  width: 6px;
  height: 6px;
  border-radius: var(--radius-full);
  background: rgba(255,255,255,0.3);
  cursor: pointer;
  transition: background var(--transition-base), width var(--transition-base);
  border: none;
  padding: 0;
}

.hero-dot.is-active {
  background: var(--clr-accent);
  width: 28px;
}

/* Progress bar */
.hero-progress {
  position: absolute;
  bottom: 0;
  left: 0;
  height: 3px;
  background: var(--clr-accent);
  width: 0%;
  z-index: 10;
  transition: width linear;
}

/* Scroll indicator */
.hero-scroll-hint {
  position: absolute;
  bottom: var(--space-8);
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  color: rgba(255,255,255,0.5);
  font-size: var(--text-xs);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  animation: scrollBounce 2s infinite var(--ease-in-out);
}

@keyframes scrollBounce {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%       { transform: translateX(-50%) translateY(6px); }
}

.hero-scroll-hint svg { width: 20px; height: 20px; }


/* ============================================================
   SECTION 3: PAGE HERO (interior pages)
   ============================================================ */

.page-hero {
  position: relative;
  min-height: 380px;
  display: flex;
  align-items: flex-end;
  padding-bottom: var(--space-16);
  margin-top: var(--header-total);
  overflow: hidden;
}

.page-hero__bg {
  position: absolute;
  inset: 0;
  background: var(--clr-navy);
  background-image:
    radial-gradient(ellipse at 70% 50%, var(--clr-navy-light) 0%, transparent 70%);
}

/* Geometric grid pattern overlay */
.page-hero__bg::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(var(--clr-steel) 1px, transparent 1px),
    linear-gradient(90deg, var(--clr-steel) 1px, transparent 1px);
  background-size: 60px 60px;
  opacity: 0.07;
}

.page-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, rgba(10,18,30,0.85) 40%, rgba(10,18,30,0.3));
}

.page-hero__content {
  position: relative;
  z-index: 2;
}

.page-hero__title {
  font-size: var(--text-3xl);
  font-weight: var(--fw-black);
  color: var(--clr-white);
  line-height: var(--lh-tight);
  letter-spacing: var(--ls-tight);
  margin-bottom: var(--space-5);
  margin-top: var(--space-5);
}

.page-hero__subtitle {
  font-size: var(--text-md);
  color: rgba(255,255,255,0.75);
  max-width: 640px;
  line-height: var(--lh-snug);
  margin-bottom: var(--space-8);
}


/* ============================================================
   SECTION 4: BREADCRUMBS
   ============================================================ */

.breadcrumbs {
  margin-bottom: var(--space-5);
}

.breadcrumbs__list {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-2);
  list-style: none;
}

.breadcrumbs__item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.5);
}

.breadcrumbs__link {
  color: rgba(255,255,255,0.65);
  transition: color var(--transition-fast);
}

.breadcrumbs__link:hover { color: var(--clr-accent); }

.breadcrumbs__sep { color: rgba(255,255,255,0.3); }


/* ============================================================
   SECTION 5: STATISTICS / COUNTERS
   ============================================================ */

.stats-band {
  background: var(--clr-accent);
  padding-block: var(--space-16);
  position: relative;
  overflow: hidden;
}

/* Subtle cross-hatch texture */
.stats-band::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg width='20' height='20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 10h20M10 0v20' stroke='rgba(255,255,255,0.06)' stroke-width='1'/%3E%3C/svg%3E");
  background-size: 20px 20px;
}

.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  position: relative;
}

.stat-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--space-6) var(--space-8);
  border-right: 1px solid rgba(255,255,255,0.2);
  position: relative;
}

.stat-item:last-child { border-right: none; }

.stat-item__number {
  font-size: clamp(2.5rem, 4vw, 4rem);
  font-weight: var(--fw-black);
  color: var(--clr-white);
  line-height: 1;
  letter-spacing: var(--ls-tight);
  margin-bottom: var(--space-2);
  font-variant-numeric: tabular-nums;
}

.stat-item__label {
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: rgba(255,255,255,0.8);
}


/* ============================================================
   SECTION 6: ABOUT / INTRO SECTION
   ============================================================ */

.about-section {
  background: var(--clr-white);
}

.about-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(3rem, 6vw, 6rem);
  align-items: center;
}

.about-image-wrap {
  position: relative;
}

.about-image-wrap img {
  width: 100%;
  height: 520px;
  object-fit: cover;
  border-radius: var(--radius-md);
  display: block;
}

/* Accent shape behind image */
.about-image-wrap::before {
  content: '';
  position: absolute;
  top: -20px;
  left: -20px;
  right: 20px;
  bottom: 20px;
  border: 3px solid var(--clr-accent);
  border-radius: var(--radius-md);
  z-index: 0;
}

.about-image-wrap img { position: relative; z-index: 1; }

/* Experience badge overlay */
.about-badge {
  position: absolute;
  bottom: var(--space-8);
  right: calc(-1 * var(--space-8));
  z-index: 2;
  background: var(--clr-navy);
  color: var(--clr-white);
  padding: var(--space-6) var(--space-8);
  border-radius: var(--radius-md);
  text-align: center;
  box-shadow: var(--shadow-xl);
}

.about-badge__number {
  font-size: 3rem;
  font-weight: var(--fw-black);
  color: var(--clr-accent);
  line-height: 1;
  letter-spacing: var(--ls-tight);
}

.about-badge__label {
  font-size: var(--text-xs);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--clr-silver);
  margin-top: var(--space-1);
}

/* Content side */
.about-content .eyebrow { margin-bottom: var(--space-4); }

.about-content h2 {
  margin-bottom: var(--space-5);
}

.about-content p {
  margin-bottom: var(--space-5);
  line-height: var(--lh-loose);
}

/* Inline features list */
.about-features {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  margin: var(--space-8) 0;
  list-style: none;
}

.about-feature {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-text-primary);
}

.about-feature::before {
  content: '';
  display: block;
  width: 8px;
  height: 8px;
  background: var(--clr-accent);
  border-radius: var(--radius-full);
  flex-shrink: 0;
}


/* ============================================================
   SECTION 7: SECTORS GRID
   ============================================================ */

.sectors-section {
  background: var(--clr-navy);
}

.sectors-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
  gap: var(--space-1);
}

.sector-card {
  position: relative;
  overflow: hidden;
  height: 340px;
  cursor: pointer;
  background: var(--clr-navy-mid);
}

.sector-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slower);
}

.sector-card:hover .sector-card__img {
  transform: scale(1.08);
}

.sector-card__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(10,18,30,0.92) 0%, rgba(10,18,30,0.2) 50%, transparent 100%);
  transition: background var(--transition-slow);
}

.sector-card:hover .sector-card__overlay {
  background: linear-gradient(to top, rgba(10,18,30,0.96) 0%, rgba(10,18,30,0.4) 60%, rgba(10,18,30,0.1) 100%);
}

.sector-card__content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--space-8);
}

.sector-card__icon {
  width: 48px;
  height: 48px;
  margin-bottom: var(--space-4);
  color: var(--clr-accent);
  transform: translateY(0);
  transition: transform var(--transition-base);
}

.sector-card__title {
  font-size: var(--text-lg);
  font-weight: var(--fw-bold);
  color: var(--clr-white);
  margin-bottom: var(--space-3);
}

.sector-card__desc {
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.7);
  line-height: var(--lh-snug);
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height var(--transition-slow), opacity var(--transition-slow);
}

.sector-card:hover .sector-card__desc {
  max-height: 80px;
  opacity: 1;
}

.sector-card__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-4);
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--clr-accent);
  opacity: 0;
  transform: translateY(8px);
  transition: opacity var(--transition-base) 0.1s, transform var(--transition-base) 0.1s;
}

.sector-card:hover .sector-card__link {
  opacity: 1;
  transform: translateY(0);
}

.sector-card__link svg { width: 14px; height: 14px; }


/* ============================================================
   SECTION 8: FEATURED PRODUCTS (Homepage)
   ============================================================ */

.featured-products {
  background: var(--clr-off-white);
}

.featured-products__header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: var(--space-12);
  gap: var(--space-8);
}

.featured-products__header .section-header { margin-bottom: 0; }


/* ============================================================
   SECTION 9: PRODUCT CARDS (shared archive & featured)
   ============================================================ */

.products-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-8);
}

.products-grid--related {
  grid-template-columns: repeat(3, 1fr);
}

.product-card {
  display: flex;
  flex-direction: column;
  background: var(--clr-white);
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.product-card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-4px);
}

/* Image wrapper */
.product-card__img-wrap {
  position: relative;
  overflow: hidden;
  height: 240px;
  background: var(--clr-mist);
  flex-shrink: 0;
}

.product-card__img,
.product-card__img-placeholder {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slower);
}

.product-card__img-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--clr-mist);
}

.product-card__img-placeholder svg { width: 80px; height: 80px; }

.product-card:hover .product-card__img {
  transform: scale(1.06);
}

/* Hover overlay */
.product-card__overlay {
  position: absolute;
  inset: 0;
  background: rgba(13, 27, 46, 0.75);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity var(--transition-base);
}

.product-card:hover .product-card__overlay { opacity: 1; }

.product-card__overlay-text {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--clr-white);
  transform: translateY(8px);
  transition: transform var(--transition-base);
}

.product-card:hover .product-card__overlay-text { transform: translateY(0); }
.product-card__overlay-text svg { width: 16px; height: 16px; }

/* Category badge */
.product-card__badge {
  position: absolute;
  top: var(--space-4);
  left: var(--space-4);
  padding: var(--space-1) var(--space-4);
  background: var(--clr-accent);
  color: var(--clr-white);
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  border-radius: var(--radius-sm);
}

/* Card body */
.product-card__body {
  flex: 1;
  padding: var(--space-6);
}

.product-card__sku {
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--clr-accent);
  margin-bottom: var(--space-2);
}

.product-card__title {
  font-size: var(--text-md);
  font-weight: var(--fw-bold);
  line-height: var(--lh-snug);
  margin-bottom: var(--space-3);
  color: var(--clr-text-primary);
}

.product-card__title-link {
  color: inherit;
  text-decoration: none;
  transition: color var(--transition-fast);
}

.product-card__title-link:hover { color: var(--clr-accent); }

.product-card__excerpt {
  font-size: var(--text-sm);
  color: var(--clr-text-muted);
  line-height: var(--lh-normal);
  margin-bottom: var(--space-4);
}

/* Mini specs strip */
.product-card__specs {
  display: flex;
  gap: var(--space-6);
  padding-top: var(--space-4);
  border-top: 1px solid var(--clr-mist);
  margin-top: var(--space-4);
}

.product-card__spec {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.product-card__spec-label {
  font-size: var(--text-xs);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--clr-text-muted);
  font-weight: var(--fw-medium);
}

.product-card__spec-value {
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
}

/* Card footer */
.product-card__footer {
  padding: var(--space-4) var(--space-6) var(--space-6);
  border-top: 1px solid var(--clr-mist);
}

.product-card__cta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--clr-navy);
  transition: color var(--transition-fast), gap var(--transition-base);
}

.product-card__cta:hover {
  color: var(--clr-accent);
  gap: var(--space-4);
}

.product-card__cta svg { width: 14px; height: 14px; }


/* ============================================================
   SECTION 10: PRODUCTS ARCHIVE FILTER TABS
   ============================================================ */

.products-filter {
  background: var(--clr-white);
  border-bottom: 1px solid var(--clr-mist);
  position: sticky;
  top: var(--header-total);
  z-index: var(--z-raised);
  box-shadow: var(--shadow-sm);
}

.products-filter__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  padding-block: 0;
}

.filter-tabs {
  display: flex;
  align-items: stretch;
  gap: 0;
  list-style: none;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.filter-tabs::-webkit-scrollbar { display: none; }

.filter-tab { flex-shrink: 0; }

.filter-tab__btn {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-5) var(--space-6);
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wide);
  color: var(--clr-text-muted);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  transition: color var(--transition-fast), border-color var(--transition-fast);
  white-space: nowrap;
}

.filter-tab__btn:hover { color: var(--clr-text-primary); }

.filter-tab__btn.is-active {
  color: var(--clr-accent);
  border-bottom-color: var(--clr-accent);
  font-weight: var(--fw-semibold);
}

.filter-tab__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 var(--space-2);
  background: var(--clr-mist);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  color: var(--clr-text-muted);
}

.filter-tab__btn.is-active .filter-tab__count {
  background: var(--clr-accent-glow);
  color: var(--clr-accent);
}

/* Sort select */
.sort-select {
  padding: var(--space-2) var(--space-5);
  border: 1px solid var(--clr-mist);
  border-radius: var(--radius);
  font-size: var(--text-sm);
  color: var(--clr-text-secondary);
  background: var(--clr-white);
  cursor: pointer;
  appearance: auto;
  flex-shrink: 0;
}

/* Archive count text */
.archive-count {
  font-size: var(--text-sm);
  color: var(--clr-text-muted);
  margin-bottom: var(--space-8);
}

/* Archive empty state */
.archive-empty {
  text-align: center;
  padding: var(--space-24) var(--space-8);
}

.archive-empty__icon {
  width: 80px;
  height: 80px;
  margin: 0 auto var(--space-8);
}

.archive-empty__title {
  font-size: var(--text-xl);
  margin-bottom: var(--space-4);
}

.archive-empty__text {
  color: var(--clr-text-muted);
  max-width: 480px;
  margin: 0 auto var(--space-10);
}

.archive-empty__actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

/* Pagination */
.archive-pagination .pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  margin-top: var(--space-16);
  flex-wrap: wrap;
}

.archive-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  height: 44px;
  padding: 0 var(--space-3);
  border: 1px solid var(--clr-mist);
  border-radius: var(--radius);
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-text-secondary);
  transition: all var(--transition-fast);
  text-decoration: none;
}

.archive-pagination .page-numbers:hover {
  border-color: var(--clr-accent);
  color: var(--clr-accent);
}

.archive-pagination .page-numbers.current {
  background: var(--clr-accent);
  border-color: var(--clr-accent);
  color: var(--clr-white);
}

.archive-pagination .page-numbers.prev,
.archive-pagination .page-numbers.next {
  gap: var(--space-2);
  padding: 0 var(--space-5);
}


/* ============================================================
   SECTION 11: SINGLE PRODUCT
   ============================================================ */

/* Product hero */
.product-hero {
  position: relative;
  min-height: 480px;
  display: flex;
  align-items: flex-end;
  padding-bottom: var(--space-16);
  margin-top: var(--header-total);
  overflow: hidden;
  background: var(--clr-navy);
}

.product-hero--has-image {
  background: linear-gradient(to right, var(--clr-dark) 30%, transparent);
}

.product-hero--has-image::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--hero-bg, none) center / cover no-repeat;
  z-index: 0;
}

.product-hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(to right, rgba(10,18,30,0.95) 0%, rgba(10,18,30,0.7) 50%, rgba(10,18,30,0.3) 100%),
    linear-gradient(to top, rgba(10,18,30,0.6) 0%, transparent 40%);
}

.product-hero__inner {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: var(--space-12);
  align-items: end;
  width: 100%;
}

.product-category-tag {
  display: inline-flex;
  align-items: center;
  padding: var(--space-1) var(--space-5);
  background: rgba(232,81,26,0.15);
  border: 1px solid var(--clr-accent);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--clr-accent);
  margin-bottom: var(--space-5);
  transition: background var(--transition-fast);
}

.product-category-tag:hover { background: rgba(232,81,26,0.25); }

.product-hero__title {
  font-size: var(--text-3xl);
  font-weight: var(--fw-black);
  color: var(--clr-white);
  line-height: var(--lh-tight);
  letter-spacing: var(--ls-tight);
  margin-bottom: var(--space-4);
}

.product-hero__sku {
  font-size: var(--text-sm);
  color: var(--clr-slate);
  margin-bottom: var(--space-5);
}

.product-hero__sku-label {
  font-weight: var(--fw-semibold);
  color: var(--clr-silver);
  margin-right: var(--space-2);
}

.product-hero__excerpt p {
  font-size: var(--text-md);
  color: rgba(255,255,255,0.75);
  line-height: var(--lh-snug);
  margin-bottom: var(--space-8);
}

.product-hero__actions {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

/* Quick stats panel */
.product-hero__quickstats {
  background: rgba(255,255,255,0.05);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-md);
  padding: var(--space-8);
}

.product-hero__quickstats-title {
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--clr-accent);
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid rgba(255,255,255,0.1);
}

.quickstats-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.quickstats-item {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-4);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}

.quickstats-item:last-child { border-bottom: none; padding-bottom: 0; }

.quickstats-label {
  font-size: var(--text-xs);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wide);
  color: var(--clr-slate);
  text-transform: uppercase;
  flex-shrink: 0;
}

.quickstats-value {
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-white);
  text-align: right;
}

/* Product body layout */
.product-body {
  padding-block: var(--space-16);
  background: var(--clr-white);
}

.product-layout {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: var(--space-12);
  align-items: start;
}

/* Tabs */
.product-tabs {
  display: flex;
  align-items: stretch;
  gap: 0;
  border-bottom: 2px solid var(--clr-mist);
  margin-bottom: var(--space-10);
  overflow-x: auto;
  scrollbar-width: none;
}

.product-tabs::-webkit-scrollbar { display: none; }

.product-tab {
  padding: var(--space-4) var(--space-6);
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wide);
  color: var(--clr-text-muted);
  border: none;
  background: none;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  white-space: nowrap;
  transition: color var(--transition-fast), border-color var(--transition-fast);
}

.product-tab:hover { color: var(--clr-text-primary); }

.product-tab.is-active {
  color: var(--clr-accent);
  border-bottom-color: var(--clr-accent);
  font-weight: var(--fw-semibold);
}

/* Tab panels */
.tab-panel { display: none; }
.tab-panel.is-active { display: block; }

/* WP content styles */
.product-content.wp-content > * + * { margin-top: var(--space-5); }
.product-content.wp-content h2 { margin-top: var(--space-10); }
.product-content.wp-content h3 { margin-top: var(--space-8); }
.product-content.wp-content ul { list-style: disc; padding-left: var(--space-6); }
.product-content.wp-content ol { list-style: decimal; padding-left: var(--space-6); }
.product-content.wp-content li { margin-bottom: var(--space-2); color: var(--clr-text-secondary); }
.product-content.wp-content img { border-radius: var(--radius); width: 100%; }
.product-content.wp-content blockquote {
  border-left: 4px solid var(--clr-accent);
  padding-left: var(--space-6);
  font-style: italic;
  color: var(--clr-text-muted);
}

/* Specs table */
.specs-section { margin-bottom: var(--space-12); }
.specs-section__title { font-size: var(--text-xl); margin-bottom: var(--space-3); }

.specs-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: var(--space-8);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.specs-table thead tr {
  background: var(--clr-navy);
  color: var(--clr-white);
}

.specs-table th {
  padding: var(--space-4) var(--space-6);
  text-align: left;
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}

.specs-table__row { border-bottom: 1px solid var(--clr-mist); }

.specs-table__row:nth-child(even) { background: var(--clr-off-white); }
.specs-table__row:hover { background: var(--clr-mist); }

.specs-table__label {
  padding: var(--space-4) var(--space-6);
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
  width: 40%;
}

.specs-table__value {
  padding: var(--space-4) var(--space-6);
  font-size: var(--text-sm);
  color: var(--clr-text-secondary);
}

/* Highlights grid */
.highlights-section { margin-bottom: var(--space-12); }
.highlights-section__title { font-size: var(--text-xl); margin-bottom: var(--space-3); }

.highlights-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 180px), 1fr));
  gap: var(--space-5);
  margin-top: var(--space-8);
}

.highlight-card {
  padding: var(--space-6) var(--space-5);
  background: var(--clr-navy);
  border-radius: var(--radius);
  text-align: center;
  border-bottom: 3px solid var(--clr-accent);
}

.highlight-card__value {
  font-size: var(--text-2xl);
  font-weight: var(--fw-black);
  color: var(--clr-white);
  letter-spacing: var(--ls-tight);
  margin-bottom: var(--space-2);
}

.highlight-card__label {
  font-size: var(--text-xs);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--clr-slate);
}

/* Video embed */
.video-section__title { font-size: var(--text-xl); margin-bottom: var(--space-3); }

.video-embed-wrap {
  position: relative;
  padding-bottom: 56.25%; /* 16:9 */
  height: 0;
  overflow: hidden;
  border-radius: var(--radius-md);
  margin-top: var(--space-8);
  box-shadow: var(--shadow-lg);
}

.video-embed-wrap iframe,
.video-embed-wrap video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
}


/* ============================================================
   SECTION 12: PRODUCT SIDEBAR
   ============================================================ */

.product-sidebar {
  position: sticky;
  top: calc(var(--header-total) + var(--space-8));
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

/* Sidebar cards */
.sidebar-card {
  padding: var(--space-8);
  border-radius: var(--radius-md);
  border: 1px solid var(--clr-mist);
  background: var(--clr-white);
  box-shadow: var(--shadow-sm);
}

.sidebar-card--enquiry {
  background: var(--clr-navy);
  border-color: transparent;
}

.sidebar-card--enquiry .sidebar-card__title { color: var(--clr-white); }
.sidebar-card--enquiry .sidebar-card__text  { color: var(--clr-text-on-dark); margin-bottom: var(--space-6); }

.sidebar-card--download {
  display: flex;
  align-items: center;
  gap: var(--space-5);
}

.sidebar-card__icon { flex-shrink: 0; }
.sidebar-card__icon svg { width: 40px; height: 40px; }

.sidebar-card__title {
  font-size: var(--text-md);
  font-weight: var(--fw-bold);
  color: var(--clr-text-primary);
  margin-bottom: var(--space-3);
}

.sidebar-card__text {
  font-size: var(--text-sm);
  color: var(--clr-text-muted);
  line-height: var(--lh-snug);
}

.sidebar-card__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-accent);
  text-decoration: none;
  transition: gap var(--transition-base);
  margin-top: var(--space-2);
}

.sidebar-card__link:hover { gap: var(--space-4); }

/* Contact links in sidebar */
.sidebar-contact-link {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-sm);
  color: var(--clr-text-secondary);
  transition: color var(--transition-fast);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--clr-mist);
}

.sidebar-contact-link:last-child { border-bottom: none; }
.sidebar-contact-link:hover { color: var(--clr-accent); }
.sidebar-contact-link svg { width: 16px; height: 16px; flex-shrink: 0; color: var(--clr-accent); }

/* Tag list */
.sidebar-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-3);
  list-style: none;
}

.sidebar-tag {
  display: inline-block;
  padding: var(--space-1) var(--space-4);
  background: var(--clr-mist);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--fw-medium);
  color: var(--clr-text-secondary);
  text-decoration: none;
  transition: background var(--transition-fast), color var(--transition-fast);
}

.sidebar-tag:hover {
  background: var(--clr-accent-glow);
  color: var(--clr-accent);
}

/* Share buttons */
.share-buttons {
  display: flex;
  gap: var(--space-3);
  margin-top: var(--space-3);
}

.share-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius);
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  text-decoration: none;
  transition: opacity var(--transition-fast), transform var(--transition-fast);
  border: 1px solid transparent;
}

.share-btn:hover { opacity: 0.85; transform: translateY(-1px); }

.share-btn svg { width: 14px; height: 14px; }

.share-btn--linkedin {
  background: #0077b5;
  color: var(--clr-white);
}

.share-btn--email {
  background: var(--clr-mist);
  color: var(--clr-text-secondary);
  border-color: var(--clr-mist);
}


/* ============================================================
   SECTION 13: FOOTER
   ============================================================ */

.site-footer { background: var(--clr-dark); }

/* CTA Band */
.footer-cta-band {
  background: var(--clr-accent);
  padding-block: var(--space-12);
}

.footer-cta-band__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-10);
}

.footer-cta-band__title {
  font-size: var(--text-xl);
  font-weight: var(--fw-black);
  color: var(--clr-white);
  margin-bottom: var(--space-3);
}

.footer-cta-band__sub {
  color: rgba(255,255,255,0.8);
  font-size: var(--text-base);
}

.footer-cta-band__actions {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-shrink: 0;
}

.footer-cta-band .btn--primary {
  background: var(--clr-white);
  color: var(--clr-accent);
}

.footer-cta-band .btn--primary:hover {
  background: var(--clr-dark);
  color: var(--clr-white);
}

.footer-cta-band .btn--secondary {
  border-color: rgba(255,255,255,0.5);
  color: var(--clr-white);
}

/* Footer body */
.footer-body { padding-block: var(--space-20); }

.footer-body__grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: var(--space-10);
}

/* Brand col */
.footer-brand {
  margin-bottom: var(--space-8);
}

.footer-brand .site-logo__text { font-size: 1.8rem; }

.footer-brand__tagline {
  margin-top: var(--space-5);
  font-size: var(--text-sm);
  line-height: var(--lh-loose);
  color: var(--clr-slate);
}

/* Contact info */
.footer-contact {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  font-style: normal;
  margin-bottom: var(--space-8);
}

.footer-contact__item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  font-size: var(--text-sm);
  color: var(--clr-slate);
  line-height: var(--lh-snug);
}

.footer-contact__icon {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  margin-top: 2px;
  color: var(--clr-accent);
}

.footer-contact__item a {
  color: var(--clr-slate);
  transition: color var(--transition-fast);
}

.footer-contact__item a:hover { color: var(--clr-accent); }

/* Social links in footer */
.social-links--footer {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.social-links--footer .social-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-full);
  color: var(--clr-slate);
  transition: background var(--transition-base), border-color var(--transition-base), color var(--transition-base);
}

.social-links--footer .social-link:hover {
  background: var(--clr-accent);
  border-color: var(--clr-accent);
  color: var(--clr-white);
}

.social-links--footer .social-link svg { width: 14px; height: 14px; }

/* Footer nav columns */
.footer-col__title {
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--clr-white);
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.footer-nav {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  list-style: none;
}

.footer-nav__item {}

.footer-nav__link {
  font-size: var(--text-sm);
  color: var(--clr-slate);
  text-decoration: none;
  transition: color var(--transition-fast), padding-left var(--transition-base);
  display: block;
  line-height: var(--lh-snug);
}

.footer-nav__link:hover {
  color: var(--clr-accent);
  padding-left: var(--space-2);
}

.footer-col__cta { margin-top: var(--space-8); }

/* Certifications band */
.footer-certs {
  background: rgba(255,255,255,0.03);
  border-top: 1px solid rgba(255,255,255,0.06);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  padding-block: var(--space-6);
}

.footer-certs__inner {
  display: flex;
  align-items: center;
  gap: var(--space-8);
  flex-wrap: wrap;
}

.footer-certs__label {
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--clr-slate);
  flex-shrink: 0;
}

.footer-certs__badges {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.cert-badge {
  display: inline-block;
  padding: var(--space-1) var(--space-4);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide);
  color: var(--clr-silver);
}

/* Legal bar */
.footer-legal {
  padding-block: var(--space-6);
  background: rgba(0,0,0,0.2);
}

.footer-legal__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  flex-wrap: wrap;
}

.footer-legal__copy {
  font-size: var(--text-xs);
  color: var(--clr-slate);
}

.footer-legal__menu {
  display: flex;
  align-items: center;
  gap: 0;
  list-style: none;
}

.footer-legal__menu li a {
  display: block;
  padding: var(--space-1) var(--space-4);
  font-size: var(--text-xs);
  color: var(--clr-slate);
  border-right: 1px solid rgba(255,255,255,0.1);
  transition: color var(--transition-fast);
}

.footer-legal__menu li:last-child a { border-right: none; }
.footer-legal__menu li a:hover { color: var(--clr-accent); }

/* Scroll to top */
.scroll-to-top {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-full);
  color: var(--clr-slate);
  cursor: pointer;
  transition: background var(--transition-base), color var(--transition-base);
  flex-shrink: 0;
}

.scroll-to-top:hover {
  background: var(--clr-accent);
  border-color: var(--clr-accent);
  color: var(--clr-white);
}

.scroll-to-top svg { width: 18px; height: 18px; }

/* Contact band at product archive bottom */
.products-contact-band__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-10);
}

.products-contact-band__copy h2 { margin-block: var(--space-3); }

.products-contact-band__actions {
  display: flex;
  gap: var(--space-4);
  flex-shrink: 0;
}


/* ============================================================
   SECTION 14: SCROLL ANIMATIONS
   ============================================================ */

/* Base state — elements hidden before animation */
.animations-enabled .animate-on-scroll {
  opacity: 0;
  transition: opacity 0.7s var(--ease-out-expo),
              transform 0.7s var(--ease-out-expo);
}

.animations-enabled .animate-on-scroll[data-animation="fade-up"] {
  transform: translateY(40px);
}

.animations-enabled .animate-on-scroll[data-animation="fade-left"] {
  transform: translateX(40px);
}

.animations-enabled .animate-on-scroll[data-animation="fade-right"] {
  transform: translateX(-40px);
}

.animations-enabled .animate-on-scroll[data-animation="scale-up"] {
  transform: scale(0.92);
}

/* Visible state — triggered by IntersectionObserver */
.animations-enabled .animate-on-scroll.is-visible {
  opacity: 1;
  transform: none;
}

/* Stagger delays (data-delay attribute maps to CSS) */
.animate-on-scroll[data-delay="0"]   { transition-delay: 0ms; }
.animate-on-scroll[data-delay="100"] { transition-delay: 100ms; }
.animate-on-scroll[data-delay="200"] { transition-delay: 200ms; }
.animate-on-scroll[data-delay="300"] { transition-delay: 300ms; }
.animate-on-scroll[data-delay="400"] { transition-delay: 400ms; }
.animate-on-scroll[data-delay="500"] { transition-delay: 500ms; }
.animate-on-scroll[data-delay="600"] { transition-delay: 600ms; }


/* ============================================================
   SECTION 15: HOMEPAGE SECTIONS
   ============================================================ */

/* Latest news / insights */
.insights-section { background: var(--clr-white); }

.news-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--space-8);
}

.news-card {
  background: var(--clr-white);
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.news-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
}

.news-card--featured {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-column: 1;
}

.news-card__img-wrap {
  overflow: hidden;
  height: 240px;
}

.news-card--featured .news-card__img-wrap { height: 100%; min-height: 300px; }

.news-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slower);
}

.news-card:hover .news-card__img { transform: scale(1.05); }

.news-card__body {
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.news-card__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.news-card__category {
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--clr-accent);
}

.news-card__date {
  font-size: var(--text-xs);
  color: var(--clr-text-muted);
}

.news-card__title {
  font-size: var(--text-md);
  font-weight: var(--fw-bold);
  line-height: var(--lh-snug);
  color: var(--clr-text-primary);
  margin-bottom: var(--space-4);
}

.news-card__link {
  color: inherit;
  transition: color var(--transition-fast);
}

.news-card__link:hover { color: var(--clr-accent); }

.news-card__excerpt {
  font-size: var(--text-sm);
  color: var(--clr-text-muted);
  line-height: var(--lh-normal);
}

.news-col {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.news-col .news-card {
  display: flex;
  flex-direction: row;
  height: auto;
}

.news-col .news-card__img-wrap {
  width: 100px;
  flex-shrink: 0;
  height: auto;
  min-height: 100px;
}

.news-col .news-card__body {
  padding: var(--space-4) var(--space-5);
}

.news-col .news-card__title { font-size: var(--text-sm); }


/* Process / features section */
.process-section { background: var(--clr-navy); }

.process-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  position: relative;
}

.process-grid::before {
  content: '';
  position: absolute;
  top: 32px;
  left: 10%;
  right: 10%;
  height: 1px;
  background: rgba(255,255,255,0.1);
  z-index: 0;
}

.process-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--space-8) var(--space-6);
  position: relative;
  z-index: 1;
}

.process-step__num {
  width: 64px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--clr-navy-mid);
  border: 2px solid var(--clr-accent);
  border-radius: var(--radius-full);
  font-size: var(--text-md);
  font-weight: var(--fw-black);
  color: var(--clr-accent);
  margin-bottom: var(--space-6);
  flex-shrink: 0;
}

.process-step__title {
  font-size: var(--text-base);
  font-weight: var(--fw-bold);
  color: var(--clr-white);
  margin-bottom: var(--space-3);
}

.process-step__text {
  font-size: var(--text-sm);
  color: var(--clr-slate);
  line-height: var(--lh-snug);
}


/* ============================================================
   SECTION 16: RESPONSIVE — MOBILE & TABLET
   ============================================================ */

@media (max-width: 1199px) {
  /* Hide right-most nav CTA on mid-size */
  .nav-cta { display: none; }

  .footer-body__grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-10);
  }

  .footer-col--brand { grid-column: 1 / -1; }

  .about-badge { right: 0; }
}

@media (max-width: 1023px) {
  /* Tablet: stack hero layout */
  .product-hero__inner {
    grid-template-columns: 1fr;
  }

  .product-hero__quickstats { display: none; }

  .product-layout {
    grid-template-columns: 1fr;
  }

  .product-sidebar {
    position: static;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-5);
  }

  .sidebar-card--enquiry { grid-column: 1 / -1; }

  .products-grid { grid-template-columns: repeat(2, 1fr); }
  .products-grid--related { grid-template-columns: repeat(2, 1fr); }

  .about-layout { grid-template-columns: 1fr; }
  .about-image-wrap { display: none; }

  .news-grid {
    grid-template-columns: 1fr;
  }

  .news-card--featured {
    grid-template-columns: 1fr;
    grid-column: 1;
  }

  .news-card--featured .news-card__img-wrap { height: 240px; }

  .process-grid { grid-template-columns: repeat(2, 1fr); }
  .process-grid::before { display: none; }

  .footer-cta-band__inner { flex-direction: column; text-align: center; }
  .footer-cta-band__actions { justify-content: center; }

  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .stat-item { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.15); }
  .stat-item:nth-child(2n) { border-right: none; }
  .stat-item:nth-last-child(-n+2) { border-bottom: none; }
}

@media (max-width: 767px) {
  /* Mobile: hamburger menu */
  .hamburger { display: flex; }
  .nav-cta   { display: none; }

  .nav-bar__nav {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: min(320px, 90vw);
    background: var(--clr-navy);
    padding: var(--space-20) var(--space-6) var(--space-8);
    overflow-y: auto;
    transform: translateX(100%);
    transition: transform var(--transition-slow);
    z-index: calc(var(--z-sticky) + 1);
    justify-content: flex-start;
    height: auto;
  }

  .nav-bar__nav.is-open {
    transform: translateX(0);
  }

  .nav-menu {
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    height: auto;
    width: 100%;
  }

  .nav-menu > .menu-item {
    height: auto;
    width: 100%;
    flex-direction: column;
    align-items: flex-start;
  }

  .nav-link {
    height: auto;
    padding: var(--space-4) 0;
    width: 100%;
    border-bottom: 1px solid rgba(255,255,255,0.06);
  }

  .nav-link::after { display: none; }

  .sub-menu {
    position: static;
    opacity: 1;
    visibility: visible;
    transform: none;
    box-shadow: none;
    border: none;
    border-radius: 0;
    background: rgba(255,255,255,0.04);
    padding: var(--space-2) 0;
    margin-left: var(--space-4);
    display: none;
  }

  .menu-item.is-open > .sub-menu { display: block; }

  .sub-menu .nav-link {
    color: var(--clr-slate);
    padding: var(--space-3) var(--space-4);
    font-size: var(--text-sm);
    border-bottom: 1px solid rgba(255,255,255,0.04);
  }

  .topbar { display: none; }

  .hero-slider {
    height: 80vh;
    min-height: 480px;
  }

  .hero-slide__actions {
    flex-direction: column;
    align-items: flex-start;
  }

  .hero-controls { display: none; }

  .products-grid,
  .products-grid--related { grid-template-columns: 1fr; }

  .filter-tabs { padding-bottom: var(--space-2); }

  .products-filter__inner { flex-direction: column; align-items: flex-start; gap: 0; }
  .products-filter__sort { width: 100%; padding-block: var(--space-3); border-top: 1px solid var(--clr-mist); }

  .sectors-grid { grid-template-columns: 1fr; }
  .sector-card { height: 260px; }

  .stats-grid { grid-template-columns: repeat(2, 1fr); }

  .footer-body__grid { grid-template-columns: 1fr; }

  .footer-cta-band__inner { flex-direction: column; text-align: center; }
  .footer-cta-band__actions { flex-direction: column; align-items: stretch; }

  .footer-legal__inner { flex-direction: column; gap: var(--space-4); }
  .footer-legal__menu { flex-wrap: wrap; }

  .process-grid { grid-template-columns: 1fr; }

  .product-sidebar {
    grid-template-columns: 1fr;
  }

  .product-hero__actions { flex-direction: column; align-items: flex-start; }

  .news-col .news-card { flex-direction: column; }
  .news-col .news-card__img-wrap { width: 100%; height: 160px; }

  .about-badge { display: none; }

  .footer-certs__inner { flex-direction: column; align-items: flex-start; gap: var(--space-4); }

  .products-contact-band__inner { flex-direction: column; }
  .products-contact-band__actions { flex-direction: column; }
}

@media (max-width: 479px) {
  .btn--lg { padding: var(--space-4) var(--space-6); font-size: var(--text-sm); }

  .hero-dots { bottom: var(--space-6); }

  .stat-item__number { font-size: 2rem; }
}


/* ============================================================
   SECTION 17: BLOG / NEWS COMPONENTS
   ============================================================ */

/* Blog layout (index.php + single.php) */
.blog-layout {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: var(--space-12);
  align-items: start;
}

.blog-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-8);
}

/* Blog card */
.blog-card {
  background: var(--clr-white);
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-base), transform var(--transition-base);
  display: flex;
  flex-direction: column;
}

.blog-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
}

.blog-card__img-wrap {
  position: relative;
  overflow: hidden;
  height: 220px;
  background: var(--clr-mist);
  flex-shrink: 0;
}

.blog-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slower);
}

.blog-card:hover .blog-card__img { transform: scale(1.05); }

.blog-card__img-overlay {
  position: absolute;
  inset: 0;
  background: rgba(13,27,46,0);
  transition: background var(--transition-base);
}

.blog-card:hover .blog-card__img-overlay {
  background: rgba(13,27,46,0.15);
}

.blog-card__body {
  flex: 1;
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
}

.blog-card__meta {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
}

.blog-card__category {
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--clr-accent);
  text-decoration: none;
}

.blog-card__date,
.blog-card__read-time {
  font-size: var(--text-xs);
  color: var(--clr-text-muted);
}

.blog-card__title {
  font-size: var(--text-md);
  font-weight: var(--fw-bold);
  line-height: var(--lh-snug);
  color: var(--clr-text-primary);
  margin-bottom: var(--space-3);
}

.blog-card__title-link {
  color: inherit;
  text-decoration: none;
  transition: color var(--transition-fast);
}

.blog-card__title-link:hover { color: var(--clr-accent); }

.blog-card__excerpt {
  font-size: var(--text-sm);
  color: var(--clr-text-muted);
  line-height: var(--lh-normal);
  flex: 1;
  margin-bottom: var(--space-5);
}

.blog-card__cta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--clr-navy);
  text-decoration: none;
  transition: color var(--transition-fast), gap var(--transition-base);
  margin-top: auto;
}

.blog-card__cta:hover { color: var(--clr-accent); gap: var(--space-4); }
.blog-card__cta svg { width: 14px; height: 14px; }


/* ============================================================
   SECTION 18: SINGLE POST
   ============================================================ */

.post-hero {
  position: relative;
  min-height: 420px;
  display: flex;
  align-items: flex-end;
  padding-bottom: var(--space-16);
  margin-top: var(--header-total);
  overflow: hidden;
  background: var(--clr-navy);
}

.post-hero--has-image::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--post-hero-bg, none) center / cover no-repeat;
  z-index: 0;
}

.post-hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(to top, rgba(10,18,30,0.95) 0%, rgba(10,18,30,0.6) 50%, rgba(10,18,30,0.3) 100%);
}

.post-hero__content { position: relative; z-index: 2; }

.post-hero__title {
  font-size: var(--text-2xl);
  font-weight: var(--fw-black);
  color: var(--clr-white);
  letter-spacing: var(--ls-tight);
  line-height: var(--lh-snug);
  max-width: 820px;
  margin-bottom: var(--space-6);
}

.post-hero__meta { margin-bottom: var(--space-4); }

/* Byline */
.post-byline {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.post-byline__avatar-img {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-full);
  object-fit: cover;
  border: 2px solid rgba(255,255,255,0.2);
}

.post-byline__author {
  display: block;
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-white);
}

.post-byline__details {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.6);
}

/* Post layout */
.post-layout {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: var(--space-12);
  align-items: start;
}

.post-content-wrap { min-width: 0; }

.post-featured-img { margin-bottom: var(--space-10); }
.post-featured-img__img {
  width: 100%;
  max-height: 520px;
  object-fit: cover;
  border-radius: var(--radius-md);
}

/* WP post content */
.post-content.wp-content { font-size: var(--text-base); line-height: var(--lh-loose); }
.post-content.wp-content h2 { font-size: var(--text-xl); margin-top: var(--space-12); margin-bottom: var(--space-5); }
.post-content.wp-content h3 { font-size: var(--text-lg); margin-top: var(--space-10); margin-bottom: var(--space-4); }
.post-content.wp-content p  { margin-bottom: var(--space-5); color: var(--clr-text-secondary); }
.post-content.wp-content ul,
.post-content.wp-content ol { padding-left: var(--space-6); margin-bottom: var(--space-6); }
.post-content.wp-content li { margin-bottom: var(--space-2); color: var(--clr-text-secondary); }
.post-content.wp-content img { border-radius: var(--radius); width: 100%; margin-block: var(--space-6); }
.post-content.wp-content blockquote {
  border-left: 4px solid var(--clr-accent);
  padding: var(--space-4) var(--space-8);
  margin: var(--space-8) 0;
  background: var(--clr-off-white);
  border-radius: 0 var(--radius) var(--radius) 0;
  font-size: var(--text-md);
  font-style: italic;
  color: var(--clr-text-secondary);
}

.post-content.wp-content a {
  color: var(--clr-accent);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.post-content.wp-content a:hover { color: var(--clr-accent-dark); }

.post-content.wp-content code {
  background: var(--clr-mist);
  padding: 2px 6px;
  border-radius: var(--radius-sm);
  font-size: 0.9em;
  font-family: var(--font-mono);
}

.post-content.wp-content pre {
  background: var(--clr-dark);
  color: #e2e8f0;
  padding: var(--space-6);
  border-radius: var(--radius);
  overflow-x: auto;
  margin-block: var(--space-6);
}

.post-content.wp-content pre code {
  background: none;
  padding: 0;
  font-size: var(--text-sm);
}

.post-content.wp-content table {
  width: 100%;
  border-collapse: collapse;
  margin-block: var(--space-8);
  font-size: var(--text-sm);
}

.post-content.wp-content th,
.post-content.wp-content td {
  padding: var(--space-3) var(--space-5);
  border: 1px solid var(--clr-mist);
}

.post-content.wp-content th {
  background: var(--clr-navy);
  color: var(--clr-white);
  font-weight: var(--fw-semibold);
  text-align: left;
}

.post-content.wp-content tr:nth-child(even) { background: var(--clr-off-white); }

/* Post tags */
.post-tags {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-10);
  padding-top: var(--space-8);
  border-top: 1px solid var(--clr-mist);
}

.post-tags__label {
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-muted);
}

/* Post navigation */
.post-nav {
  display: flex;
  gap: var(--space-6);
  margin-top: var(--space-10);
  padding-top: var(--space-8);
  border-top: 1px solid var(--clr-mist);
}

.post-nav__link {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  flex: 1;
  text-decoration: none;
  padding: var(--space-5);
  border: 1px solid var(--clr-mist);
  border-radius: var(--radius);
  transition: border-color var(--transition-fast), background var(--transition-fast);
}

.post-nav__link:hover {
  border-color: var(--clr-accent);
  background: var(--clr-off-white);
}

.post-nav__link--next { text-align: right; }

.post-nav__dir {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--clr-accent);
}

.post-nav__link--next .post-nav__dir { justify-content: flex-end; }
.post-nav__dir svg { width: 14px; height: 14px; }

.post-nav__title {
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-primary);
  line-height: var(--lh-snug);
}

/* Author box */
.author-box {
  display: flex;
  align-items: flex-start;
  gap: var(--space-6);
  margin-top: var(--space-10);
  padding: var(--space-8);
  background: var(--clr-off-white);
  border-radius: var(--radius-md);
  border: 1px solid var(--clr-mist);
}

.author-box__avatar-img {
  width: 80px;
  height: 80px;
  border-radius: var(--radius-full);
  object-fit: cover;
  flex-shrink: 0;
  border: 3px solid var(--clr-white);
  box-shadow: var(--shadow-sm);
}

.author-box__name {
  font-size: var(--text-md);
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-2);
}

.author-box__bio {
  font-size: var(--text-sm);
  color: var(--clr-text-muted);
  margin-bottom: var(--space-4);
  line-height: var(--lh-normal);
}

.author-box__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-accent);
  text-decoration: none;
  transition: gap var(--transition-base);
}

.author-box__link:hover { gap: var(--space-4); }
.author-box__link svg { width: 14px; height: 14px; }

/* Post sidebar sticky */
.post-sidebar { position: sticky; top: calc(var(--header-total) + var(--space-8)); }


/* ============================================================
   SECTION 19: PAGE CONTENT
   ============================================================ */

.page-content-wrap { max-width: 900px; }

.page-content.wp-content { font-size: var(--text-base); line-height: var(--lh-loose); }
.page-content.wp-content h2 { font-size: var(--text-xl); margin-top: var(--space-12); margin-bottom: var(--space-4); }
.page-content.wp-content h3 { font-size: var(--text-lg); margin-top: var(--space-8); margin-bottom: var(--space-3); }
.page-content.wp-content p  { margin-bottom: var(--space-5); }
.page-content.wp-content ul,
.page-content.wp-content ol { padding-left: var(--space-6); margin-bottom: var(--space-5); }
.page-content.wp-content img { border-radius: var(--radius); width: 100%; }

/* page-hero with background image */
.page-hero--has-image::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--page-hero-bg, none) center / cover no-repeat;
  z-index: 0;
}

.page-hero--has-image .page-hero__content { position: relative; z-index: 2; }


/* ============================================================
   SECTION 20: 404 PAGE
   ============================================================ */

.error-404 { min-height: 70vh; display: flex; align-items: center; margin-top: var(--header-total); }

.error-404__inner {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-16);
  align-items: center;
}

.error-404__number {
  font-size: clamp(5rem, 12vw, 10rem);
  font-weight: var(--fw-black);
  letter-spacing: var(--ls-tight);
  color: var(--clr-mist);
  line-height: 1;
  display: block;
}

.error-404__line {
  width: 3px;
  height: 200px;
  background: linear-gradient(to bottom, var(--clr-accent), transparent);
  margin: auto;
  border-radius: var(--radius-full);
}

.error-404__content h1 {
  font-size: var(--text-2xl);
  margin-bottom: var(--space-4);
}

.error-404__content p {
  font-size: var(--text-md);
  color: var(--clr-text-muted);
  margin-bottom: var(--space-8);
}

.error-404__search { margin-bottom: var(--space-8); }

.error-404__search .search-form {
  display: flex;
  border: 2px solid var(--clr-mist);
  border-radius: var(--radius);
  overflow: hidden;
  max-width: 480px;
}

.error-404__search .search-field {
  flex: 1;
  padding: var(--space-4) var(--space-5);
  border: none;
  outline: none;
  font-size: var(--text-base);
  background: var(--clr-white);
  color: var(--clr-text-primary);
}

.error-404__search .search-submit {
  padding: var(--space-4) var(--space-6);
  background: var(--clr-accent);
  color: var(--clr-white);
  font-weight: var(--fw-semibold);
  cursor: pointer;
  transition: background var(--transition-fast);
}

.error-404__search .search-submit:hover { background: var(--clr-accent-dark); }

.error-404__links-label {
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-muted);
  margin-bottom: var(--space-4);
}


/* ============================================================
   SECTION 21: SEARCH RESULTS
   ============================================================ */

.search-refine {
  background: var(--clr-off-white);
  padding-block: var(--space-6);
  border-bottom: 1px solid var(--clr-mist);
}

.search-refine__inner .search-form {
  display: flex;
  max-width: 640px;
  border: 2px solid var(--clr-mist);
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--clr-white);
}

.search-refine__inner .search-field {
  flex: 1;
  padding: var(--space-4) var(--space-5);
  border: none;
  outline: none;
  font-size: var(--text-base);
  background: transparent;
}

.search-refine__inner .search-submit {
  padding: var(--space-4) var(--space-6);
  background: var(--clr-navy);
  color: var(--clr-white);
  font-weight: var(--fw-semibold);
  cursor: pointer;
  font-size: var(--text-sm);
  letter-spacing: var(--ls-wide);
  transition: background var(--transition-fast);
}

.search-refine__inner .search-submit:hover { background: var(--clr-accent); }


/* ============================================================
   SECTION 22: SIDEBAR COMPONENTS
   ============================================================ */

.blog-sidebar { min-width: 0; }

.blog-sidebar .sidebar { display: flex; flex-direction: column; gap: var(--space-6); }

/* Sidebar product list */
.sidebar-product-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  list-style: none;
  margin-top: var(--space-4);
}

.sidebar-product-item {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--clr-mist);
}

.sidebar-product-item:last-child { border-bottom: none; padding-bottom: 0; }

.sidebar-product-item__img-link {
  width: 60px;
  height: 60px;
  flex-shrink: 0;
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--clr-mist);
}

.sidebar-product-item__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-base);
}

.sidebar-product-item:hover .sidebar-product-item__img { transform: scale(1.05); }

.sidebar-product-item__title {
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  line-height: var(--lh-snug);
  margin-bottom: var(--space-1);
}

.sidebar-product-item__title a {
  color: var(--clr-text-primary);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.sidebar-product-item__title a:hover { color: var(--clr-accent); }

.sidebar-product-item__sku {
  font-size: var(--text-xs);
  color: var(--clr-text-muted);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}

/* Sidebar category list */
.sidebar-cat-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  list-style: none;
  margin-top: var(--space-4);
}

.sidebar-cat-item { border-bottom: 1px solid var(--clr-mist); }
.sidebar-cat-item:last-child { border-bottom: none; }

.sidebar-cat-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) 0;
  font-size: var(--text-sm);
  color: var(--clr-text-secondary);
  text-decoration: none;
  transition: color var(--transition-fast), padding-left var(--transition-base);
}

.sidebar-cat-link:hover {
  color: var(--clr-accent);
  padding-left: var(--space-2);
}

.sidebar-cat-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 22px;
  background: var(--clr-mist);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  color: var(--clr-text-muted);
}


/* ============================================================
   SECTION 23: RESPONSIVE ADDITIONS
   ============================================================ */

@media (max-width: 1023px) {
  .blog-layout   { grid-template-columns: 1fr; }
  .blog-sidebar  { order: -1; }
  .blog-sidebar .sidebar {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: var(--space-5);
  }
  .post-layout   { grid-template-columns: 1fr; }
  .post-sidebar  { position: static; order: -1; display: grid; grid-template-columns: repeat(2, 1fr); }
  .error-404__inner { grid-template-columns: 1fr; text-align: center; }
  .error-404__line { display: none; }
}

@media (max-width: 767px) {
  .blog-grid     { grid-template-columns: 1fr; }
  .post-hero__title { font-size: var(--text-2xl); }
  .author-box    { flex-direction: column; }
  .post-nav      { flex-direction: column; }
  .post-sidebar  { grid-template-columns: 1fr; }
}
