/* ============ Multi-page additions on top of site.css ============ */

/* Top nav with real links + dropdown */
.nav-links { gap: 22px; }
.nav-links .has-sub { position: relative; }
.nav-links .has-sub > a::after { content: '▾'; margin-left: 5px; font-size: 9px; color: var(--ink-400); }
.nav-sub {
  position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(8px);
  background: var(--paper-000); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md); box-shadow: var(--shadow-lg);
  padding: 8px; min-width: 230px; display: flex; flex-direction: column; gap: 2px;
  opacity: 0; visibility: hidden; transition: all var(--dur-base) var(--ease-out); z-index: 60;
}
.nav-links .has-sub:hover .nav-sub { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(4px); }
.nav-sub a {
  padding: 9px 12px; border-radius: var(--radius-sm); font-size: 13px; letter-spacing: 0.02em;
  text-transform: none; color: var(--ink-800); white-space: nowrap;
}
.nav-sub a:hover { background: var(--green-050); color: var(--green-700); }
.nav-sub a b { display: block; font-family: var(--font-display); font-weight: 700; font-size: 13px; letter-spacing: 0.04em; text-transform: uppercase; }
.nav-sub a span { font-size: 11px; color: var(--ink-500); }
.nav-current { color: var(--green-700) !important; }
.lang { text-decoration: none; }

/* Breadcrumbs */
.crumbs { max-width: 1280px; margin: 0 auto; padding: 14px 32px 0; font-size: 12px; color: var(--ink-500); }
.crumbs a { color: var(--ink-500); } .crumbs a:hover { color: var(--green-700); }
.crumbs span { color: var(--ink-800); }
.crumbs i { color: var(--ink-300); font-style: normal; margin: 0 7px; }

/* Nav: keep everything on one centered line */
.nav-inner { align-items: center; }
.nav-links { gap: 16px; flex-wrap: nowrap; white-space: nowrap; align-items: center; justify-content: center; }
.nav-links > a, .nav-links .has-sub > a { font-size: 11px; letter-spacing: 0.06em; }
.nav-inner { gap: 18px; }

/* Page hero — unified: green base + darkened photo on every inner page */
.phero { position: relative; overflow: hidden; background: var(--green-800); border-bottom: none; }
.phero::before {
  content: ''; position: absolute; inset: 0; z-index: 0;
  background-image: linear-gradient(rgba(15,61,34,0.80), rgba(15,61,34,0.88)), var(--phero-img, url('images/hero-warehouse.jpg'));
  background-size: cover; background-position: center;
}
.phero .phero-in { position: relative; z-index: 1; }
.phero::before { display: none; }
.phero-bg { position: absolute; inset: 0; z-index: 0; }
.phero-bg img { width: 100%; height: 100%; object-fit: cover; display: block; }
.phero-bg::after { content: ''; position: absolute; inset: 0; background: linear-gradient(rgba(15,61,34,0.70), rgba(15,61,34,0.88)); }
.phero .eyebrow { color: var(--green-200); }
.phero h1 { color: var(--paper-000); }
.phero p { color: rgba(255,255,255,0.9); }
.phero-dark { background: var(--green-800); }
.phero-dark::before { background-image: linear-gradient(rgba(15,61,34,0.82), rgba(15,61,34,0.9)), var(--phero-img, url('images/hero-refurb.jpg')); }
/* secondary buttons on green hero stay light */
.phero .btn-secondary { border-color: rgba(255,255,255,0.5); color: #fff; }
.phero .btn-secondary:hover { background: rgba(255,255,255,0.1); }
.phero-in { max-width: 1280px; margin: 0 auto; padding: 48px 32px 52px; }
.phero h1 { font-family: var(--font-display); font-weight: 700; font-size: clamp(34px, 5vw, 56px); line-height: 1.08; letter-spacing: 0.01em; text-transform: uppercase; margin: 0 0 14px; max-width: 20ch; }
.phero p { font-size: 18px; line-height: 1.55; margin: 0; max-width: 60ch; }
.phero-cta { display: flex; gap: 12px; margin-top: 26px; flex-wrap: wrap; }
/* per-page hero images */
.phero-rr::before { background-image: linear-gradient(rgba(15,61,34,0.80),rgba(15,61,34,0.88)), url('images/hero-refurb.jpg'); }
.phero-wh::before { background-image: linear-gradient(rgba(15,61,34,0.80),rgba(15,61,34,0.88)), url('images/hero-warehouse.jpg'); }
.phero-fl::before { background-image: linear-gradient(rgba(15,61,34,0.80),rgba(15,61,34,0.88)), url('images/hero-label.jpg'); }
.phero-in2::before { background-image: linear-gradient(rgba(15,61,34,0.80),rgba(15,61,34,0.88)), url('images/wms-sales.png'); }
.phero-pk::before { background-image: linear-gradient(rgba(15,61,34,0.80),rgba(15,61,34,0.88)), url('images/photo-scan-1.jpg'); }

/* Prose / content blocks */
.prose-section { padding: 56px 32px; }
.prose-wrap { max-width: 820px; margin: 0 auto; }
.prose-wide { max-width: 1180px; margin: 0 auto; }
.prose-wrap h2, .prose-wide h2 { font-family: var(--font-display); font-weight: 700; font-size: clamp(26px, 3.4vw, 38px); line-height: 1.12; letter-spacing: 0.01em; text-transform: uppercase; color: var(--ink-900); margin: 0 0 16px; }
.prose-wrap h3, .prose-wide h3 { font-family: var(--font-display); font-weight: 700; font-size: 20px; letter-spacing: 0.02em; text-transform: uppercase; color: var(--ink-900); margin: 28px 0 10px; }
.prose-wrap p, .prose-wide p { font-size: 16px; line-height: 1.65; color: var(--ink-700); margin: 0 0 14px; }
.prose-wrap ul, .prose-wide ul { margin: 0 0 16px; padding: 0; list-style: none; display: flex; flex-direction: column; gap: 9px; }
.prose-wrap ul li, .prose-wide ul li { position: relative; padding-left: 26px; font-size: 15px; line-height: 1.55; color: var(--ink-700); }
.prose-wrap ul li::before, .prose-wide ul li::before {
  content: ''; position: absolute; left: 0; top: 4px; width: 16px; height: 16px; background: var(--green-600);
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='4 12 10 18 20 6'/></svg>") center/contain no-repeat;
          mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='4 12 10 18 20 6'/></svg>") center/contain no-repeat;
}
.lead-p { font-size: 19px !important; line-height: 1.6 !important; color: var(--ink-900) !important; }
/* A–D grade stickers */
.ad-stickers { display: flex; gap: 16px; flex-wrap: wrap; margin: 18px 0 4px; }
.ad-seal { display: flex; flex-direction: column; align-items: center; gap: 8px; }
.ad-seal span { width: 64px; height: 64px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 700; font-size: 30px; color: #fff; box-shadow: var(--shadow-md); border: 3px solid rgba(255,255,255,0.7); }
.ad-seal small { font-size: 12px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; color: var(--ink-700); }
.ad-a span { background: var(--green-600); }
.ad-b span { background: var(--kraft-500); }
.ad-c span { background: #C46A2D; }
.ad-d span { background: var(--ink-500); }

/* Step process (numbered) */
.steps { max-width: 900px; margin: 0 auto; display: grid; gap: 16px; }
.step-row { display: grid; grid-template-columns: 60px 1fr; gap: 20px; align-items: start; background: var(--paper-000); border: 1px solid var(--border-subtle); border-radius: var(--radius-md); padding: 22px 24px; }
.step-n { width: 48px; height: 48px; border-radius: 999px; background: var(--green-700); color: var(--paper-000); display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 700; font-size: 20px; }
.step-row h3 { margin: 4px 0 6px; font-family: var(--font-display); font-weight: 700; font-size: 20px; letter-spacing: 0.02em; text-transform: uppercase; color: var(--ink-900); }
.step-row p { margin: 0; font-size: 15px; line-height: 1.55; color: var(--ink-700); }

/* Mid-page CTA strip — green band so it stands clearly apart from the dark footer */
.cta-strip { background: var(--green-700); color: var(--paper-050); border-top: none; }
.cta-strip-in { max-width: 1180px; margin: 0 auto; padding: 52px 32px; display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.cta-strip h2 { font-family: var(--font-display); font-weight: 700; font-size: clamp(24px, 3vw, 36px); letter-spacing: 0.01em; text-transform: uppercase; color: var(--paper-050); margin: 0; max-width: 22ch; }
.cta-strip .cta-sub { display: block; font-family: var(--font-body); font-weight: 400; font-size: 15px; text-transform: none; letter-spacing: 0; color: rgba(255,255,255,0.85); margin-top: 8px; }
.cta-strip .btn-primary { background: var(--ink-900); color: #fff; }
.cta-strip .btn-primary:hover { background: #000; }
.cta-strip .btn-ghost { background: transparent; color: #fff; border: 1px solid rgba(255,255,255,0.5); }
.cta-strip .btn-ghost:hover { background: rgba(255,255,255,0.1); }
.cta-actions { display: flex; gap: 12px; flex-wrap: wrap; }

/* WeChat block in footer */
.footer-wechat { display: flex; align-items: center; gap: 12px; margin-top: 16px; }
.footer-wechat img { width: 132px; height: 132px; border-radius: var(--radius-sm); background: #fff; padding: 6px; }
.footer-wechat .fw-meta { font-size: 12px; line-height: 1.4; }
.footer-wechat .fw-eye { color: var(--green-500); font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; font-size: 10px; }
.footer-wechat .fw-id { font-family: var(--font-mono); color: var(--paper-200); }

/* FAQ accordion */
.faq-list { max-width: 820px; margin: 0 auto; display: flex; flex-direction: column; gap: 10px; }
.faq-item { background: var(--paper-000); border: 1px solid var(--border-subtle); border-radius: var(--radius-md); overflow: hidden; }
.faq-q { width: 100%; text-align: left; background: none; border: 0; cursor: pointer; padding: 18px 22px; display: flex; align-items: center; justify-content: space-between; gap: 16px; font-family: var(--font-display); font-weight: 700; font-size: 17px; letter-spacing: 0.01em; color: var(--ink-900); }
.faq-q::after { content: '+'; font-family: var(--font-body); font-size: 22px; color: var(--green-700); flex: none; transition: transform var(--dur-base); }
.faq-item.open .faq-q::after { content: '−'; }
.faq-a { max-height: 0; overflow: hidden; transition: max-height var(--dur-base) var(--ease-out); }
.faq-item.open .faq-a { max-height: 400px; }
.faq-a p { padding: 0 22px 20px; margin: 0; font-size: 15px; line-height: 1.6; color: var(--ink-700); }

/* Feature 2-col with image */
.feat { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; max-width: 1180px; margin: 0 auto; }
.feat-img { border-radius: var(--radius-md); overflow: hidden; box-shadow: 12px 12px 0 0 var(--green-700); aspect-ratio: 4/3; }
.feat-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.feat ul li { position: relative; padding-left: 26px; }
.feat ul li::before { content:''; position:absolute; left:0; top:4px; width:16px; height:16px; background: var(--green-600); -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='4 12 10 18 20 6'/></svg>") center/contain no-repeat; mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='4 12 10 18 20 6'/></svg>") center/contain no-repeat; }
.feat-rev .feat-img { box-shadow: -12px 12px 0 0 var(--green-700); order: -1; }

/* Mini case card */
.minicase { background: var(--green-700); color: var(--paper-000); border-radius: var(--radius-md); padding: 28px 32px; max-width: 820px; margin: 0 auto; display: grid; grid-template-columns: auto 1fr; gap: 28px; align-items: center; }
.minicase-num { font-family: var(--font-display); font-weight: 700; font-size: 56px; line-height: 1; }
.minicase p { margin: 0; font-size: 16px; line-height: 1.55; }
.minicase .nm { font-family: var(--font-display); font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 6px; }

/* Footer: force two columns side by side */
.footer-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; }

/* Section with darkened photo/video background, kraft-tinted so it stays on-brand */
.section-videobg { position: relative; overflow: hidden; background: var(--kraft-900); }
.section-videobg > .section-bg { position: absolute; inset: 0; z-index: 0; }
.section-videobg > .section-bg img,
.section-videobg > .section-bg video { width: 100%; height: 100%; object-fit: cover; display: block; }
.section-videobg > .section-bg::after {
  content: ''; position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(244,236,221,0.62), rgba(244,236,221,0.70)),
    linear-gradient(120deg, rgba(27,115,64,0.10), rgba(244,236,221,0.0) 60%);
}
.section-videobg > .section-inner { position: relative; z-index: 1; }
.section-videobg .eyebrow { color: var(--kraft-700); }
.section-videobg .h2-caps { color: var(--ink-900); }
.section-videobg .lead-center { color: var(--ink-700); }
/* keep the original cream-card look, just slightly translucent */
.section-videobg .pillar { background: rgba(255,255,255,0.85); border-color: var(--border-subtle); backdrop-filter: blur(3px); }
.section-videobg .pillar:not(.pillar-accent):hover { background: rgba(255,255,255,0.95); }
.section-videobg .pillar-accent:hover { background: var(--green-800); }
.section-videobg .pillar-title { color: var(--ink-900); }
.section-videobg .pillar-body { color: var(--ink-700); }
.section-videobg .pillar-ico-bg { background: var(--kraft-200); }
.section-videobg .pillar-ico-bg svg { stroke: var(--ink-900); }
.section-videobg .pillar-link { color: var(--green-700); }
.section-videobg .pillar-link:hover { color: var(--green-800); }
.section-videobg .pillar-accent { background: var(--green-700); }
.section-videobg .pillar-accent .pillar-title { color: #fff; }
.section-videobg .pillar-accent .pillar-body { color: rgba(255,255,255,0.92); }
.section-videobg .pillar-accent .pillar-ico-bg { background: rgba(255,255,255,0.16); }
.section-videobg .pillar-accent .pillar-ico-bg svg { stroke: #fff; }
.section-videobg .pillar-accent .pillar-link { color: #fff; }

/* CTA strip clearly separated from footer */
.cta-strip + .footer { border-top: none; }

@media (max-width: 760px) {
  .footer-cols { grid-template-columns: 1fr; gap: 28px; }
}
/* ===== Network map (desktop) ===== */
.netmap { position: relative; max-width: 1240px; margin: 0 auto; aspect-ratio: 1707/955; background: #fbf8f2; border-radius: var(--radius-md); overflow: visible; box-shadow: var(--shadow-md); border: 1px solid rgba(181,132,85,0.18); }
.netmap .netmap-img { position: absolute; inset: 0; background: url('images/world-map.png') center/contain no-repeat; opacity: 0.78; border-radius: var(--radius-md); }
.netmap .mpin { position: absolute; transform: translate(-50%,-74%); z-index: 2; display: flex; flex-direction: column; align-items: center; }
.netmap .mpin-head { width: 52px; height: 52px; border-radius: 50%; background: #fff; border: 4px solid var(--kraft-700); overflow: hidden; box-shadow: var(--shadow-lg); position: relative; }
.netmap .mpin-head::after { content: ''; position: absolute; left: 50%; top: calc(100% - 3px); transform: translateX(-50%); border: 9px solid transparent; border-top-color: var(--kraft-700); }
.netmap .mpin-head img { width: 100%; height: 100%; object-fit: cover; display: block; }
.netmap .mpin.live .mpin-head { animation: mpinpulse 2s ease-in-out infinite; }
@keyframes mpinpulse { 0%,100% { box-shadow: 0 6px 16px rgba(15,20,23,0.18), 0 0 0 0 rgba(46,160,85,0.45);} 50% { box-shadow: 0 6px 16px rgba(15,20,23,0.18), 0 0 0 12px rgba(46,160,85,0);} }
.netmap .mpin-label { margin-top: 14px; text-align: center; white-space: nowrap; background: #fff; border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 5px 11px; box-shadow: var(--shadow-sm); }
.netmap .mpin-label b { display: block; font-family: var(--font-display); font-weight: 700; font-size: 14px; letter-spacing: 0.02em; text-transform: uppercase; color: var(--ink-900); }
.netmap .mpin-label span { font-size: 11px; color: var(--ink-500); }
.netmap .mpin.cov .mpin-head { border-color: var(--ink-400); }
.netmap-legend { display: flex; gap: 22px; justify-content: center; margin-top: 18px; font-size: 12px; color: var(--ink-600); }
.netmap-legend span { display: inline-flex; align-items: center; gap: 7px; }
.netmap-legend i { width: 11px; height: 11px; border-radius: 50%; display: inline-block; }
.hubs-mobile { display: none; }
.minicase p, .minicase .nm, .minicase .minicase-num { color: #fff; }
@media (max-width: 760px) {
  .netmap, .netmap-legend { display: none; }
  .hubs-mobile { display: grid; grid-template-columns: 1fr; gap: 12px; }
}
@media (max-width: 960px) {
  .nav-links { display: none; }
  /* === overrides (latest) === */
}
/* keep nav on one line, never wrap; let it use full width */
.nav-inner { grid-template-columns: auto 1fr auto; }
.nav-links { gap: 14px; flex-wrap: nowrap !important; white-space: nowrap; }
.nav-links > a, .nav-links .has-sub > a { font-size: 11px; letter-spacing: 0.04em; }
@media (min-width: 961px) and (max-width: 1180px) {
  .nav-links { gap: 10px; }
  .nav-links > a, .nav-links .has-sub > a { font-size: 10px; letter-spacing: 0.02em; }
  .brand-logo { height: 30px; }
}
/* force every nav item onto the same baseline */
.nav-links { align-items: center !important; }
.nav-links .has-sub { display: inline-flex; align-items: center; }
.nav-links > a, .nav-links .has-sub > a { display: inline-flex; align-items: center; line-height: 1; padding: 4px 0; }
.nav-links a.nav-current, .nav-links .has-sub > a.nav-current { padding-bottom: 6px; }
/* hide breadcrumb bar */
.crumbs { display: none; }
/* lighter hero overlays so the darkened photo shows through */
.phero::before        { background-image: linear-gradient(rgba(15,61,34,0.52), rgba(15,61,34,0.72)), url('images/hero-warehouse.jpg'); }
.phero-dark::before   { background-image: linear-gradient(rgba(15,61,34,0.52), rgba(15,61,34,0.72)), url('images/hero-refurb.jpg'); }
.phero-rr::before     { background-image: linear-gradient(rgba(15,61,34,0.52), rgba(15,61,34,0.72)), url('images/hero-refurb.jpg'); }
.phero-wh::before     { background-image: linear-gradient(rgba(15,61,34,0.52), rgba(15,61,34,0.72)), url('images/hero-warehouse.jpg'); }
.phero-fl::before     { background-image: linear-gradient(rgba(15,61,34,0.52), rgba(15,61,34,0.72)), url('images/hero-label.jpg'); }
.phero-in2::before    { background-image: linear-gradient(rgba(15,61,34,0.58), rgba(15,61,34,0.78)), url('images/wms-sales.png'); }
.phero-pk::before     { background-image: linear-gradient(rgba(15,61,34,0.52), rgba(15,61,34,0.72)), url('images/photo-scan-1.jpg'); }
.phero h1, .phero p { text-shadow: 0 2px 16px rgba(0,0,0,0.40); }
/* current-page highlight in header */
.nav-links a.nav-current, .nav-links .has-sub > a.nav-current { color: var(--green-700) !important; border-bottom: 2px solid var(--green-700); padding-bottom: 3px; }
/* big CEO quote */
.ceo-quote { background: var(--green-700); color: #fff; border-radius: var(--radius-md); padding: 40px 44px; margin: 28px 0 0; position: relative; overflow: hidden; }
.ceo-quote .cq-mark { position: absolute; top: 6px; left: 22px; font-family: var(--font-display); font-weight: 700; font-size: 120px; line-height: 1; color: rgba(255,255,255,0.14); }
.ceo-quote blockquote { position: relative; margin: 0; font-family: var(--font-display); font-weight: 700; font-size: clamp(22px, 3vw, 32px); line-height: 1.2; letter-spacing: 0.01em; text-transform: uppercase; }
.ceo-quote .cq-by { position: relative; margin-top: 18px; display: flex; align-items: center; gap: 14px; }
.ceo-quote .cq-by img { width: 46px; }
.ceo-quote .cq-name { font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase; color: rgba(255,255,255,0.85); font-weight: 600; }

@media (max-width: 960px) {
  .nav-links { display: none; }
  .feat { grid-template-columns: 1fr; gap: 24px; }
  .feat-rev .feat-img { order: 0; }
  .cta-strip-in { flex-direction: column; align-items: flex-start; }
  .minicase { grid-template-columns: 1fr; gap: 14px; text-align: center; }
  .prose-section { padding: 36px 18px; }
  .phero-in { padding: 28px 18px 32px; }
  .crumbs { padding: 12px 18px 0; }
}

/* ===== Portal link in nav ===== */
.btn-portal-link {
  font-family: var(--font-display); font-weight: 700; font-size: 11px;
  letter-spacing: 0.1em; text-transform: uppercase; color: var(--green-700);
  border: 1px solid var(--green-700); border-radius: 999px; padding: 7px 16px;
  white-space: nowrap; transition: all var(--dur-base) var(--ease-out);
}
.btn-portal-link:hover { background: var(--green-700); color: #fff; }

/* ===== Mobile hamburger menu ===== */
.nav-toggle { display: none; background: none; border: 0; cursor: pointer; padding: 8px; color: var(--ink-900); }
.nav-toggle svg { width: 26px; height: 26px; }
@media (max-width: 960px) {
  .nav-inner { grid-template-columns: auto 1fr auto !important; }
  .nav-toggle { display: inline-flex; order: 3; }
  .nav-actions { order: 2; }
  .nav-links {
    display: flex !important; position: fixed; top: 0; right: 0; bottom: 0;
    width: min(84vw, 320px); flex-direction: column; align-items: stretch !important;
    justify-content: flex-start; gap: 4px !important; padding: 80px 22px 32px;
    background: var(--paper-000); box-shadow: -16px 0 40px rgba(0,0,0,0.18);
    transform: translateX(100%); transition: transform 0.28s var(--ease-out);
    z-index: 90; overflow-y: auto; white-space: normal;
  }
  body.nav-open .nav-links { transform: translateX(0); }
  body.nav-open::after { content:''; position: fixed; inset: 0; background: rgba(15,20,23,0.45); z-index: 80; }
  .nav-links > a, .nav-links .has-sub > a { font-size: 15px !important; letter-spacing: 0.04em !important; padding: 12px 8px !important; border-bottom: 1px solid var(--border-subtle); }
  .nav-links .has-sub { display: block; }
  .nav-sub { position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none; border: none; padding: 0 0 8px 14px; min-width: 0; background: transparent; }
  .nav-links .has-sub > a::after { float: right; }
}

/* ===== Mobile perf: disable heavy effects ===== */
@media (max-width: 760px) {
  .hero-slider, .feat-img, .wms-preview, .case-card, .ceo-quote { box-shadow: 0 8px 22px rgba(15,20,23,0.12) !important; }
  .section-bg video { display: none !important; }
  .section-videobg .section-bg { background-size: cover; background-position: center; }
  * { background-attachment: scroll !important; }
}


/* ===== Mobile nav — authoritative override ===== */
@media (max-width: 960px){
  body.nav-open{ overflow:hidden; }
  nav.nav .nav-links{
    position:fixed !important; top:0 !important; right:0 !important; bottom:0 !important; left:auto !important;
    width:min(86vw,330px) !important; height:100vh !important;
    transform:translateX(100%); transition:transform .28s ease;
    background:#fff !important; z-index:1000 !important;
    display:flex !important; flex-direction:column !important; align-items:stretch !important;
    justify-content:flex-start !important; gap:0 !important; padding:78px 22px 32px !important;
    overflow-y:auto !important; box-shadow:-16px 0 40px rgba(0,0,0,.18) !important; white-space:normal !important;
  }
  body.nav-open nav.nav .nav-links{ transform:translateX(0) !important; }
  body.nav-open::after{ content:''; position:fixed; inset:0; background:rgba(15,20,23,.5); z-index:990; }
  nav.nav .nav-links > a,
  nav.nav .nav-links .has-sub > a{ display:block !important; font-size:16px !important; letter-spacing:.03em !important; padding:13px 4px !important; border-bottom:1px solid var(--border-subtle); white-space:normal !important; }
  nav.nav .nav-links .has-sub{ display:block !important; position:static !important; }
  nav.nav .nav-links .nav-sub{ position:static !important; opacity:1 !important; visibility:visible !important; transform:none !important; box-shadow:none !important; border:0 !important; background:transparent !important; padding:0 0 10px 14px !important; min-width:0 !important; display:flex !important; flex-direction:column !important; }
  nav.nav .nav-links .nav-sub a{ font-size:14px !important; padding:9px 4px !important; border:0 !important; }
  .nav-toggle{ display:inline-flex !important; }
}
@media (max-width: 960px){
  body.nav-open nav.nav{ z-index:1001 !important; position:relative; }
}

/* ===== Block renderer helpers ===== */
.section-green { background: var(--green-700); color:#fff; }
.section-green h2, .section-green .h2-caps, .section-green .eyebrow { color:#fff; }
.section-dark { background: var(--ink-900); color:#fff; }
.section-dark h2, .section-dark .h2-caps { color:#fff; }
.prose-fig { margin:14px 0 20px; border-radius:10px; overflow:hidden; box-shadow:10px 10px 0 0 var(--green-700); }
.prose-fig img { width:100%; display:block; }
.prose-link { color:var(--green-700); font-weight:700; }
.feat { display:grid; grid-template-columns:1fr 1fr; gap:44px; align-items:center; max-width:1180px; margin:0 auto; }
.feat-rev > div:first-child { order:2; }
.feat-h { font-family:var(--font-display); font-weight:700; font-size:clamp(26px,3.4vw,38px); line-height:1.12; letter-spacing:.01em; text-transform:uppercase; color:var(--ink-900); margin:0 0 16px; }
.feat-p { font-size:16px; line-height:1.65; color:var(--ink-700); margin:0 0 14px; }
.feat ul { margin:0; padding:0; list-style:none; display:flex; flex-direction:column; gap:9px; }
.feat ul li { position:relative; padding-left:26px; font-size:15px; color:var(--ink-700); }
.feat ul li::before { content:''; position:absolute; left:0; top:4px; width:16px; height:16px; background:var(--green-600);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='4 12 10 18 20 6'/></svg>") center/contain no-repeat;
          mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='4 12 10 18 20 6'/></svg>") center/contain no-repeat; }
.feat-img img { width:100%; display:block; border-radius:10px; box-shadow:12px 12px 0 0 var(--green-700); }
.feat-rev .feat-img img { box-shadow:-12px 12px 0 0 var(--green-700); }
.banner-fig { border-radius:10px; overflow:hidden; box-shadow:var(--shadow-md); max-width:1080px; margin:0 auto; }
.banner-fig img { width:100%; display:block; }
.banner-cap { text-align:center; font-size:13px; color:var(--ink-500); margin-top:12px; }
@media (max-width:760px){ .feat{ grid-template-columns:1fr; gap:24px; } .feat-rev > div:first-child{ order:0; } }
