﻿/* ==========================================================================
   novo-main.css - NOVO Theme CSS Bundle
   Auto-generated: do not edit directly.
   Source files (in order):
     - novo-tokens.css
     - novo-base.css
     - novo-buttons.css
     - novo-forms.css
     - novo-utilities.css
     - novo-animations.css
     - novo-widgets.css
     - novo-singles.css
     - novo-cf7.css
     - novo-header-footer.css
   Regenerate: .\build-css.ps1 from the novo-theme/ folder.
   ========================================================================== */

/* --------------------------------------------------------------------------
   Source: novo-tokens.css
   -------------------------------------------------------------------------- */
/**
 * novo-tokens.css
 * Single source of truth for all NOVO Imaging design tokens.
 * Import this file FIRST — all other CSS sheets depend on these variables.
 *
 * Source of truth: home-preview.html, header-preview.html, footer-preview.html
 */

:root {

  /* ── Colors ──────────────────────────────────────────── */
  --novo-navy:        #0B3954;
  --novo-navy3:       #0d4a6b;   /* medium-dark navy — gradient start stops, hero bg */
  --novo-navy-dark:   #071F2E;
  --novo-navy-mid:    #0d4a6b;
  --novo-navy-light:  #1a5e84;

  --novo-orange:      #F56D0D;
  --novo-orange-dark: #d95e00;
  --novo-orange-lite: #FFAB6E;

  --novo-grey-bg:     #F5F7FA;
  --novo-grey-bg2:    #ECEEF2;
  --novo-grey-tx:     #7A90A0;

  --novo-white:       #FFFFFF;
  --novo-border:      #E8EDF3;
  --novo-shadow:      rgba(11,57,84,.10);

  --novo-green:       #0fa360;
  --novo-blue:        #1a6090;

  /* ── Typography ─────────────────────────────────────── */
  --novo-font:        'Inter', sans-serif;

  --novo-fs-hero:     clamp(34px, 4.8vw, 60px);
  --novo-fs-h1:       clamp(28px, 3.8vw, 44px);
  --novo-fs-h2:       clamp(24px, 3vw, 36px);
  --novo-fs-h3:       clamp(18px, 2.2vw, 24px);
  --novo-fs-h4:       15px;
  --novo-fs-body:     16px;
  --novo-fs-sm:       13.5px;
  --novo-fs-xs:       11px;

  --novo-fw-regular:  400;
  --novo-fw-medium:   500;
  --novo-fw-semibold: 600;
  --novo-fw-bold:     700;
  --novo-fw-extrabold:800;
  --novo-fw-black:    900;

  --novo-lh-base:     1.6;
  --novo-lh-tight:    1.08;
  --novo-lh-heading:  1.1;
  --novo-lh-prose:    1.82;

  /* ── Spacing ─────────────────────────────────────────── */
  --novo-space-xs:    8px;
  --novo-space-sm:    14px;
  --novo-space-md:    24px;
  --novo-space-lg:    48px;
  --novo-space-xl:    72px;
  --novo-space-2xl:   96px;
  --novo-space-3xl:   112px;

  /* ── Layout ──────────────────────────────────────────── */
  --novo-container:   1200px;
  --novo-pad-desktop: 48px;
  --novo-pad-mobile:  20px;

  /* ── Radius ──────────────────────────────────────────── */
  --novo-radius-xs:   6px;
  --novo-radius-sm:   10px;
  --novo-radius-md:   14px;
  --novo-radius-card: 20px;
  --novo-radius-lg:   24px;
  --novo-radius-pill: 999px;

  /* ── Shadows ─────────────────────────────────────────── */
  --novo-shadow-xs:   0 1px 4px rgba(11,57,84,.06);
  --novo-shadow-sm:   0 2px 14px rgba(11,57,84,.10);
  --novo-shadow-card: 0 4px 24px rgba(11,57,84,.10);
  --novo-shadow-hover:0 28px 72px rgba(11,57,84,.13);
  --novo-shadow-lg:   0 36px 108px rgba(7,31,46,.26), 0 4px 18px rgba(7,31,46,.06);

  /* ── Transitions ─────────────────────────────────────── */
  --novo-transition:  all 0.25s ease;
  --novo-transition-bounce: all 0.32s cubic-bezier(.22,.68,0,1.2);

  /* ── Header ──────────────────────────────────────────── */
  --novo-hdr-h:       72px;
  --novo-topbar-h:    36px;

  /* ── Z-Index scale ───────────────────────────────────── */
  --novo-z-base:      0;
  --novo-z-above:     10;
  --novo-z-sticky:    100;
  --novo-z-header:    1000;
  --novo-z-topbar:    1001;
  --novo-z-overlay:   1100;
  --novo-z-modal:     1200;
  --novo-z-toast:     1300;

}

/* --------------------------------------------------------------------------
   Source: novo-base.css
   -------------------------------------------------------------------------- */
/**
 * novo-base.css
 * CSS reset, body defaults, typography base, containers.
 * Depends on: novo-tokens.css
 */

/* ── Self-hosted Inter ───────────────────────────────── */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('../fonts/inter/Inter-Light.woff2') format('woff2');
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/inter/Inter-Regular.woff2') format('woff2');
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/inter/Inter-Medium.woff2') format('woff2');
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/inter/Inter-SemiBold.woff2') format('woff2');
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('../fonts/inter/Inter-Bold.woff2') format('woff2');
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url('../fonts/inter/Inter-ExtraBold.woff2') format('woff2');
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url('../fonts/inter/Inter-Black.woff2') format('woff2');
}

/* ── Reset ───────────────────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  overflow-x: hidden; /* Moved from body — prevents horiz scroll without breaking Elementor stretch */
}

body {
  font-family: var(--novo-font);
  font-size: var(--novo-fs-body);
  font-weight: var(--novo-fw-regular);
  line-height: var(--novo-lh-base);
  color: var(--novo-navy);
  background: var(--novo-grey-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a {
  color: inherit;
  text-decoration: none;
  transition: color var(--novo-transition);
}

img, svg, video, canvas, audio, iframe, embed, object {
  display: block;
  max-width: 100%;
}

img { height: auto; }

ul, ol { list-style: none; }

/* Preserve list styles inside rich text / prose areas */
.novo-prose ul,
.entry-content ul,
.wp-block-list {
  list-style: disc;
  padding-left: 1.4em;
}
.novo-prose ol,
.entry-content ol {
  list-style: decimal;
  padding-left: 1.4em;
}

/* Restore list styles for WooCommerce and Contact Form 7 */
.woocommerce ul,
.woocommerce ol,
.woocommerce-page ul,
.woocommerce-page ol,
.wpcf7 ul,
.wpcf7 ol {
  list-style: revert;
  padding-left: revert;
}

/* Prevent the WooCommerce revert from bleeding into the site header nav */
.woocommerce .hdr-nav,
.woocommerce-page .hdr-nav,
.woocommerce .hdr-nav ul,
.woocommerce-page .hdr-nav ul,
.woocommerce .hdr-nav li,
.woocommerce-page .hdr-nav li {
  list-style: none !important;
  padding-left: 0 !important;
  margin-left: 0 !important;
}

/* Prevent WooCommerce list-style revert from adding double bullet in footer */
.woocommerce .ft-links,
.woocommerce-page .ft-links,
.woocommerce .ft-links li,
.woocommerce-page .ft-links li {
  list-style: none !important;
  padding-left: 0 !important;
}

button, input, optgroup, select, textarea {
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

button { cursor: pointer; }

/* ── Skip link ───────────────────────────────────────── */
.skip-link {
  position: absolute;
  top: -100%;
  left: 8px;
  z-index: var(--novo-z-toast);
  padding: 8px 20px;
  background: var(--novo-navy);
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  border-radius: 0 0 8px 8px;
  transition: top .2s;
}
.skip-link:focus { top: 0; }

/* ── Container ────────────────────────────────────────── */
.container {
  max-width: var(--novo-container);
  margin: 0 auto;
  padding: 0 var(--novo-pad-desktop);
}

@media (max-width: 768px) {
  .container { padding: 0 var(--novo-pad-mobile); }
}

/* ── Typography helpers ──────────────────────────────── */
.eyebrow {
  display: inline-block;
  font-size: var(--novo-fs-xs);
  font-weight: var(--novo-fw-bold);
  letter-spacing: 3.5px;
  text-transform: uppercase;
  color: var(--novo-orange);
  margin-bottom: 14px;
}

.title {
  font-size: var(--novo-fs-h1);
  font-weight: var(--novo-fw-black);
  color: var(--novo-navy);
  letter-spacing: -1.4px;
  line-height: var(--novo-lh-tight);
}
.title span { color: var(--novo-orange); }

.title-hero {
  font-size: var(--novo-fs-hero);
  font-weight: var(--novo-fw-black);
  line-height: 1.05;
  letter-spacing: -2.2px;
  color: #fff;
}
.title-hero em {
  font-style: normal;
  background: linear-gradient(95deg, var(--novo-orange) 0%, var(--novo-orange-lite) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.sub {
  font-size: var(--novo-fs-body);
  color: var(--novo-grey-tx);
  line-height: var(--novo-lh-prose);
}

.accent-bar {
  display: block;
  width: 50px;
  height: 4px;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--novo-orange), rgba(245,109,13,.22));
  margin: 18px 0 24px;
}
.accent-bar.center { margin: 18px auto 24px; }

/* ── Section wrapper defaults ─────────────────────────── */
.novo-section {
  padding: var(--novo-space-2xl) 0;
}

.novo-section-header {
  text-align: center;
  margin-bottom: var(--novo-space-lg);
}

/* ── Dividers ─────────────────────────────────────────── */
.novo-divider {
  height: 1px;
  background: var(--novo-border);
  border: none;
  margin: 0;
}

/* ── Prose body typography ───────────────────────────── */
.novo-prose {
  font-size: var(--novo-fs-body);
  line-height: 1.9;
  color: #3a4a57;
}
.novo-prose h2 {
  font-size: var(--novo-fs-h2);
  font-weight: var(--novo-fw-black);
  color: var(--novo-navy);
  letter-spacing: -1px;
  margin: 48px 0 16px;
  padding-bottom: 14px;
  border-bottom: 2px solid var(--novo-border);
}
.novo-prose h3 {
  font-size: var(--novo-fs-h3);
  font-weight: var(--novo-fw-extrabold);
  color: var(--novo-navy);
  margin: 36px 0 12px;
}
.novo-prose p { margin-bottom: 20px; }
.novo-prose a { color: var(--novo-orange); font-weight: var(--novo-fw-semibold); }
.novo-prose a:hover { text-decoration: underline; }
.novo-prose strong { font-weight: var(--novo-fw-bold); color: var(--novo-navy); }

/* ── Callout boxes ───────────────────────────────────── */
.callout {
  border-radius: var(--novo-radius-md);
  padding: 20px 24px;
  margin-bottom: 24px;
  display: flex;
  gap: 14px;
  align-items: flex-start;
}
.callout-success {
  background: rgba(15,163,96,.08);
  border: 1px solid rgba(15,163,96,.25);
  color: #065f46;
}
.callout-warning {
  background: rgba(245,109,13,.08);
  border: 1px solid rgba(245,109,13,.28);
  color: #7c3900;
}
.callout-info {
  background: rgba(11,57,84,.06);
  border: 1px solid rgba(11,57,84,.16);
  color: var(--novo-navy);
}
.callout i {
  font-size: 16px;
  margin-top: 2px;
  flex-shrink: 0;
}

/* ── Screen-reader only ──────────────────────────────── */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* ── Back-to-top button ──────────────────────────────── */
#back-to-top {
  position: fixed;
  bottom: 28px;
  right: 28px;
  z-index: var(--novo-z-overlay);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--novo-navy);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  border: none;
  box-shadow: 0 4px 20px rgba(11,57,84,.28);
  opacity: 0;
  transform: translateY(12px);
  pointer-events: none;
  transition: opacity .3s, transform .3s;
}
#back-to-top.visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
#back-to-top:hover {
  background: var(--novo-orange);
  box-shadow: 0 8px 32px rgba(245,109,13,.40);
}

/* ── Focus visible ────────────────────────────────────── */
:focus-visible {
  outline: 2px solid var(--novo-orange);
  outline-offset: 3px;
  border-radius: 4px;
}

/* ── Responsive images ────────────────────────────────── */
.wp-post-image,
.attachment-full,
.size-full {
  width: 100%;
  height: auto;
}

/* ── Elementor Container system (Elementor 3.6+ Flexbox/Grid Containers) ──── */
/* Full-width container: remove Elementor's default inner max-width cap and padding */
.e-con-full > .e-con-inner {
  max-width: none !important;
  padding-left:  0 !important;
  padding-right: 0 !important;
  width: 100%;
}

/* ── Header location: transparent + true full-width ──────
   Forces all Elementor wrappers inside the Theme Builder
   header template to be transparent and edge-to-edge so
   .hdr-outer can span 100 vw and no grey band appears.    */
.elementor-location-header {
  position: fixed !important;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  z-index: 1000;
  background-color: transparent !important;
}
/* Admin bar pushes fixed header down */
.admin-bar .elementor-location-header { top: 32px !important; }
@media (max-width: 782px) {
  .admin-bar .elementor-location-header { top: 46px !important; }
}
/* Strip margin/padding/background from container-structure wrappers in the header location
   (header template uses containers — section/column selectors removed as dead code) */
.elementor-location-header > .elementor,
.elementor-location-header .e-con,
.elementor-location-header .e-con-inner {
  margin:     0 !important;
  padding:    0 !important;
  background: transparent !important;
  max-width:  100% !important;
}
/* Zero padding/background on header widget containers — component HTML handles its own spacing */
.elementor-location-header .elementor-widget-container {
  padding:    0 !important;
  background: transparent !important;
}

/* Strip margin/padding/background from structural layout wrappers + template wrapper
   in the footer location — .site-footer internal spacing is unaffected */
.elementor-location-footer,
.elementor-location-footer > .elementor,
.elementor-location-footer .e-con,
.elementor-location-footer .e-con-inner {
  margin:     0 !important;
  padding:    0 !important;
  background: transparent !important;
  max-width:  100% !important;
}
/* Zero padding/background on footer widget containers — .site-footer handles its own spacing */
.elementor-location-footer .elementor-widget-container {
  padding:    0 !important;
  background: transparent !important;
}

/* ── Full-bleed widgets: zero Elementor wrappers ─────────────────────────── */
/* Direct widget-container zero for all full-bleed widgets */
.elementor-widget-novo_hero > .elementor-widget-container,
.elementor-widget-novo_cta_banner > .elementor-widget-container,
.elementor-widget-novo_news_hero > .elementor-widget-container,
.elementor-widget-novo_article_hero > .elementor-widget-container,
.elementor-widget-novo_product_hero > .elementor-widget-container {
  padding:          0 !important;
  background-color: transparent !important;
}

/* ── Fixed header compensation ────────────────────────────────────────────────
   All pages: #main-content padding pushes content below the fixed header.
   Hero pages: a negative margin pulls the dark hero background up behind
   the header so no body-grey gap appears.

   Elementor wraps every widget in section → container (flex) → column (flex)
   → widget-wrap (flex) → widget.  Negative margin on the *inner* hero element
   cannot escape that flex chain, so Elementor pages move the margin to the
   outermost .elementor-top-section wrapper instead.

   We also set display:flex on the Elementor root so the breadcrumb section's
   margin-bottom and the hero section's margin-top don't collapse (block
   margin-collapsing rules would merge two negatives into one).

   Non-Elementor heroes (.parts-hero in spare-parts-single.php) keep a direct
   negative margin because they sit right inside #main-content with no flex
   barrier.

   Admin bar: WordPress adds `html { margin-top: 32px }` which shifts the
   entire viewport — no extra offset needed here.                             */
#main-content {
  padding-top: calc(var(--novo-topbar-h, 36px) + var(--novo-hdr-h, 72px));
}

/* Flex column prevents margin-collapsing between breadcrumb & hero sections */
#main-content > .elementor {
  display: flex;
  flex-direction: column;
}

/* Direct margin — used by non-Elementor heroes (e.g. .parts-hero) */
.novo-hero,
.novo-news-hero,
.novo-article-hero,
.novo-product-hero,
.parts-hero {
  margin-top: calc(-1 * (var(--novo-topbar-h, 36px) + var(--novo-hdr-h, 72px)));
}

/* Elementor pages: move the pull-up to the section wrapper */
.elementor-top-section:has(.novo-hero),
.elementor-top-section:has(.novo-news-hero),
.elementor-top-section:has(.novo-article-hero),
.elementor-top-section:has(.novo-product-hero) {
  margin-top: calc(-1 * (var(--novo-topbar-h, 36px) + var(--novo-hdr-h, 72px)));
}
/* Reset the inner hero margin so it doesn't double-shift */
.elementor-top-section .novo-hero,
.elementor-top-section .novo-news-hero,
.elementor-top-section .novo-article-hero,
.elementor-top-section .novo-product-hero {
  margin-top: 0;
}

/* ── Fallback header/footer (Elementor Theme Builder not assigned) ─────────── */
.site-footer-fallback {
  background: var(--novo-navy-dark);
  color: #fff;
  padding: 40px 0;
  text-align: center;
}
.site-footer-fallback__copy {
  font-size: 13px;
  color: rgba(255,255,255,.5);
  margin: 0;
}
.logo-fallback .txt-accent { color: var(--novo-orange); }

/* --------------------------------------------------------------------------
   Source: novo-buttons.css
   -------------------------------------------------------------------------- */
/**
 * novo-buttons.css
 * All button variants — pixel-exact match to HTML source.
 * Depends on: novo-tokens.css
 */

/* ── Base ─────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 17px 40px;
  border-radius: var(--novo-radius-pill);
  font-family: var(--novo-font);
  font-size: 15px;
  font-weight: var(--novo-fw-bold);
  line-height: 1;
  cursor: pointer;
  text-decoration: none;
  border: none;
  white-space: nowrap;
  transition: transform .22s, box-shadow .22s, background .22s, color .22s, border-color .22s;
  -webkit-user-select: none;
  user-select: none;
}

.btn:focus-visible {
  outline: 2px solid var(--novo-orange);
  outline-offset: 3px;
}

/* ── Size modifiers ──────────────────────────────────── */
.btn-sm {
  padding: 11px 26px;
  font-size: 13.5px;
}

.btn-xs {
  padding: 8px 18px;
  font-size: 12px;
}

.btn-lg {
  padding: 19px 48px;
  font-size: 17px;
}

/* ── Primary (orange fill) ───────────────────────────── */
.btn-primary {
  background: var(--novo-orange);
  color: #fff;
  box-shadow: 0 8px 32px rgba(245,109,13,.45);
}
.btn-primary:hover {
  background: var(--novo-orange-dark);
  color: #fff;
  transform: translateY(-3px);
  box-shadow: 0 18px 52px rgba(245,109,13,.60);
}
.btn-primary:active { transform: translateY(-1px); }

/* ── Ghost (white outline, dark bg) ─────────────────── */
.btn-ghost {
  background: transparent;
  color: rgba(255,255,255,.80);
  border: 2px solid rgba(255,255,255,.28);
  padding: 17px 40px;
}
.btn-ghost:hover {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.65);
  color: #fff;
  transform: translateY(-3px);
}

/* ── Outline (navy border, light bg) ────────────────── */
.btn-outline {
  background: transparent;
  color: var(--novo-navy);
  border: 2px solid var(--novo-border);
}
.btn-outline:hover {
  border-color: var(--novo-orange);
  color: var(--novo-orange);
  transform: translateY(-2px);
}

/* ── Navy fill ───────────────────────────────────────── */
.btn-navy {
  background: var(--novo-navy);
  color: #fff;
  box-shadow: 0 8px 32px rgba(11,57,84,.28);
}
.btn-navy:hover {
  background: var(--novo-navy-dark);
  transform: translateY(-3px);
  box-shadow: 0 18px 52px rgba(11,57,84,.36);
}

/* ── Icon button ─────────────────────────────────────── */
.btn-icon {
  width: 44px;
  height: 44px;
  padding: 0;
  justify-content: center;
  border-radius: 50%;
  flex-shrink: 0;
}
.btn-icon.btn-sm {
  width: 36px;
  height: 36px;
}

/* ── Link button ─────────────────────────────────────── */
.btn-link {
  background: none;
  border: none;
  padding: 0;
  color: var(--novo-orange);
  font-weight: var(--novo-fw-bold);
  font-size: var(--novo-fs-sm);
  display: inline-flex;
  align-items: center;
  gap: 7px;
  transition: gap .2s, color .2s;
}
.btn-link:hover {
  gap: 11px;
  color: var(--novo-orange-dark);
}

/* ── Full-width (mobile utility) ─────────────────────── */
.btn-full {
  width: 100%;
  justify-content: center;
}

/* ── Loading state ───────────────────────────────────── */
.btn.loading {
  pointer-events: none;
  opacity: .7;
}
.btn.loading::after {
  content: '';
  display: inline-block;
  width: 14px;
  height: 14px;
  border: 2px solid rgba(255,255,255,.5);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin .7s linear infinite;
  margin-left: 6px;
}

/* ── Button group ────────────────────────────────────── */
.btn-group {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
}

@media (max-width: 480px) {
  .btn-group .btn { width: 100%; justify-content: center; }
}

/* -- Dark-background CTA button variants ----------------------------------
   Used by: widget-novo-cta-banner.php on navy/gradient CTA sections.
   ----------------------------------------------------------------------- */

.btn-white {
  background: #fff;
  color: var(--novo-navy);
  border: 1.5px solid rgba(255, 255, 255, 0.22);
  box-shadow: 0 4px 18px rgba(255, 255, 255, 0.10);
}
.btn-white:hover,
.btn-white:focus-visible {
  background: rgba(255, 255, 255, 0.90);
  box-shadow: 0 8px 28px rgba(255, 255, 255, 0.20);
  transform: translateY(-2px);
  color: var(--novo-navy);
}

.btn-ghost-white {
  background: transparent;
  color: #fff;
  border: 1.5px solid rgba(255, 255, 255, 0.40);
}
.btn-ghost-white:hover,
.btn-ghost-white:focus-visible {
  background: rgba(255, 255, 255, 0.10);
  border-color: rgba(255, 255, 255, 0.72);
  transform: translateY(-2px);
  color: #fff;
}

/* --------------------------------------------------------------------------
   Source: novo-forms.css
   -------------------------------------------------------------------------- */
/**
 * novo-forms.css
 * Form inputs, selects, textareas, checkboxes, and Contact Form 7 overrides.
 * Depends on: novo-tokens.css
 */

/* ── Group ───────────────────────────────────────────── */
.form-group {
  display: flex;
  flex-direction: column;
  gap: 7px;
  margin-bottom: 20px;
}

.form-label {
  font-size: 13px;
  font-weight: var(--novo-fw-semibold);
  color: var(--novo-navy);
  letter-spacing: .2px;
}

/* ── Base input / select / textarea ─────────────────── */
.form-input,
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 input[type="number"],
.wpcf7 input[type="url"],
.wpcf7 input[type="date"],
.wpcf7 select,
.wpcf7 textarea,
input.novo-input,
select.novo-input,
textarea.novo-input {
  width: 100%;
  padding: 14px 18px;
  background: #fff;
  border: 1.5px solid var(--novo-border);
  border-radius: var(--novo-radius-md);
  font-family: var(--novo-font);
  font-size: 14px;
  font-weight: var(--novo-fw-medium);
  color: var(--novo-navy);
  transition: border-color .22s, background .22s, box-shadow .22s;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
}

.form-input:hover,
.wpcf7 input[type="text"]:hover,
.wpcf7 input[type="email"]:hover,
.wpcf7 select:hover,
.wpcf7 textarea:hover,
input.novo-input:hover,
select.novo-input:hover {
  border-color: #c8d4dc;
}

.form-input:focus,
.wpcf7 input[type="text"]:focus,
.wpcf7 input[type="email"]:focus,
.wpcf7 input[type="tel"]:focus,
.wpcf7 select:focus,
.wpcf7 textarea:focus,
input.novo-input:focus,
select.novo-input:focus,
textarea.novo-input:focus {
  border-color: var(--novo-orange);
  background: rgba(245,109,13,.025);
  box-shadow: 0 0 0 4px rgba(245,109,13,.10);
}

.form-input::placeholder,
.wpcf7 input::placeholder,
.wpcf7 textarea::placeholder {
  color: #b0bec8;
  font-weight: var(--novo-fw-regular);
}

/* ── Select — custom arrow ───────────────────────────── */
.form-input[type=""],
select.form-input,
.wpcf7 select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237A90A0' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 16px center;
  padding-right: 42px;
  cursor: pointer;
  accent-color: var(--novo-orange, #F56D0D);
}

/* Selected option — works in Firefox; partial in Chrome/Edge (hover highlight remains OS-native) */
.nvo-cf7-wrap .wpcf7-form select option:checked {
  background: linear-gradient(0deg, var(--novo-orange, #F56D0D) 0%, var(--novo-orange, #F56D0D) 100%);
  color: #fff;
}

/* ── Textarea ────────────────────────────────────────── */
textarea.form-input,
.wpcf7 textarea {
  resize: vertical;
  min-height: 130px;
  line-height: 1.7;
}

/* ── Checkbox ────────────────────────────────────────── */
.form-checkbox {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  font-size: var(--novo-fs-sm);
  color: var(--novo-grey-tx);
  line-height: 1.6;
}
.form-checkbox input[type="checkbox"] {
  width: 18px;
  height: 18px;
  border: 2px solid var(--novo-border);
  border-radius: 5px;
  appearance: none;
  -webkit-appearance: none;
  flex-shrink: 0;
  margin-top: 2px;
  transition: border-color .2s, background .2s;
  cursor: pointer;
  position: relative;
}
.form-checkbox input[type="checkbox"]:checked {
  background: var(--novo-orange);
  border-color: var(--novo-orange);
}
.form-checkbox input[type="checkbox"]:checked::after {
  content: '';
  position: absolute;
  left: 4px;
  top: 2px;
  width: 6px;
  height: 9px;
  border: 2px solid #fff;
  border-top: none;
  border-left: none;
  transform: rotate(45deg);
}
.form-checkbox a { color: var(--novo-orange); font-weight: var(--novo-fw-semibold); }

/* ── Submit button ───────────────────────────────────── */
.wpcf7 input[type="submit"],
button[type="submit"].novo-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 16px 40px;
  border-radius: var(--novo-radius-pill);
  background: var(--novo-orange);
  color: #fff;
  font-family: var(--novo-font);
  font-size: 15px;
  font-weight: var(--novo-fw-bold);
  border: none;
  cursor: pointer;
  box-shadow: 0 8px 32px rgba(245,109,13,.38);
  transition: background .22s, transform .22s, box-shadow .22s;
  width: 100%;
}
.wpcf7 input[type="submit"]:hover,
button[type="submit"].novo-submit:hover {
  background: var(--novo-orange-dark);
  transform: translateY(-3px);
  box-shadow: 0 18px 52px rgba(245,109,13,.54);
}

/* ── CF7 wrappers ────────────────────────────────────── */
.wpcf7 { width: 100%; }
.wpcf7-form { display: flex; flex-direction: column; gap: 0; }
.wpcf7-form-control-wrap { display: block; width: 100%; }

/* Remove default CF7 borders and padding */
.wpcf7 .wpcf7-response-output {
  display: none !important;
}

/* ── Form toast success ──────────────────────────────── */
.novo-form-toast {
  display: none;
  align-items: center;
  gap: 14px;
  padding: 18px 22px;
  background: rgba(15,163,96,.09);
  border: 1.5px solid rgba(15,163,96,.28);
  border-radius: var(--novo-radius-md);
  color: #065f46;
  font-size: var(--novo-fs-sm);
  font-weight: var(--novo-fw-semibold);
  margin-top: 16px;
  animation: fadeUp .4s ease;
}
.novo-form-toast.visible { display: flex; }
.novo-form-toast i { font-size: 18px; color: var(--novo-green); flex-shrink: 0; }

/* ── Form error state ────────────────────────────────── */
.wpcf7 .wpcf7-not-valid {
  border-color: #e04040 !important;
  background: rgba(224,64,64,.03) !important;
}
.wpcf7 .wpcf7-not-valid-tip {
  font-size: 11.5px;
  color: #c0392b;
  font-weight: var(--novo-fw-semibold);
  margin-top: 5px;
  display: block;
}

/* ── Newsletter form (MC4WP) ─────────────────────────── */
.mc4wp-form { width: 100%; }
.mc4wp-form .mc4wp-form-fields {
  display: flex;
  gap: 10px;
}
.mc4wp-form input[type="email"] {
  flex: 1;
  padding: 14px 20px;
  background: rgba(255,255,255,.10);
  border: 1.5px solid rgba(255,255,255,.18);
  border-radius: var(--novo-radius-pill);
  font-family: var(--novo-font);
  font-size: 14px;
  color: #fff;
  outline: none;
  transition: border-color .22s, background .22s;
}
.mc4wp-form input[type="email"]::placeholder { color: rgba(255,255,255,.45); }
.mc4wp-form input[type="email"]:focus {
  border-color: var(--novo-orange);
  background: rgba(255,255,255,.15);
}
.mc4wp-form input[type="submit"] {
  padding: 14px 28px;
  background: var(--novo-orange);
  color: #fff;
  border: none;
  border-radius: var(--novo-radius-pill);
  font-family: var(--novo-font);
  font-size: 14px;
  font-weight: var(--novo-fw-bold);
  cursor: pointer;
  white-space: nowrap;
  transition: background .22s, transform .22s;
  box-shadow: 0 8px 28px rgba(245,109,13,.40);
  flex-shrink: 0;
}
.mc4wp-form input[type="submit"]:hover {
  background: var(--novo-orange-dark);
  transform: translateY(-2px);
}

@media (max-width: 480px) {
  .mc4wp-form .mc4wp-form-fields { flex-direction: column; }
  .mc4wp-form input[type="submit"] { width: 100%; }
}

/* ══════════════════════════════════════════════════════════════
   CF7 INTEGRATION — nvo-cf7-wrap context
   ══════════════════════════════════════════════════════════════
   All CF7 forms are wrapped in <div class="nvo-cf7-wrap"> so
   their markup can be styled consistently without leaking styles
   to unrelated CF7 forms elsewhere on the page.
   ══════════════════════════════════════════════════════════════ */

/* Container reset */
.nvo-cf7-wrap { width: 100%; }
.nvo-cf7-wrap .wpcf7 { width: 100%; }

/* CF7 adds <br> after each <span class="wpcf7-form-control-wrap">;
   remove those to avoid unwanted spacing. */
.nvo-cf7-wrap .wpcf7-form br { display: none; }

/* Default paragraph spacing used by CF7 auto-p */
.nvo-cf7-wrap .wpcf7-form > p {
  margin: 0 0 20px;
}
.nvo-cf7-wrap .wpcf7-form > p:last-of-type { margin-bottom: 0; }

/* Control-wrap block */
.nvo-cf7-wrap .wpcf7-form-control-wrap {
  display: block;
  width: 100%;
}

/* Label */
.nvo-cf7-wrap .wpcf7-form label {
  display: block;
  font-size: 13px;
  font-weight: var(--novo-fw-semibold);
  color: var(--novo-navy);
  letter-spacing: .2px;
  margin-bottom: 7px;
}

/* ── Two-column row helper (add class="nvo-cf7-row" to <p> in CF7 admin) ── */
.nvo-cf7-wrap .wpcf7-form .nvo-cf7-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 20px;
}
.nvo-cf7-wrap .wpcf7-form .nvo-cf7-row > span,
.nvo-cf7-wrap .wpcf7-form .nvo-cf7-row > label {
  display: flex;
  flex-direction: column;
  gap: 7px;
}
@media (max-width: 620px) {
  .nvo-cf7-wrap .wpcf7-form .nvo-cf7-row {
    grid-template-columns: 1fr;
  }
}

/* Submit button */
.nvo-cf7-wrap .wpcf7-form input[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 16px 40px;
  margin-top: 4px;
  border-radius: var(--novo-radius-pill);
  background: var(--novo-orange);
  color: #fff;
  font-family: var(--novo-font);
  font-size: 15px;
  font-weight: var(--novo-fw-bold);
  border: none;
  cursor: pointer;
  box-shadow: 0 8px 32px rgba(245,109,13,.38);
  transition: background .22s, transform .22s, box-shadow .22s;
}
.nvo-cf7-wrap .wpcf7-form input[type="submit"]:hover {
  background: var(--novo-orange-dark);
  transform: translateY(-3px);
  box-shadow: 0 18px 52px rgba(245,109,13,.54);
}
.nvo-cf7-wrap .wpcf7-form input[type="submit"]:disabled {
  opacity: .6;
  cursor: not-allowed;
  transform: none;
}

/* CF7 spinner — hide the default one; CF7 disables the button during submit */
.nvo-cf7-wrap .wpcf7-spinner { display: none !important; }

/* ── Response output (replaces inline toast) ─────────────── */
/* Hidden by default — only shown after submission (sent/failed/invalid/spam/aborted) */
.nvo-cf7-wrap .wpcf7-response-output {
  display: none;
  padding: 15px 20px;
  border-radius: var(--novo-radius-md);
  font-size: 14px;
  font-weight: var(--novo-fw-semibold);
  line-height: 1.5;
  margin-top: 16px;
  border-width: 1.5px;
  border-style: solid;
  animation: fadeUp .35s ease;
}
/* Show only after a submission result */
.nvo-cf7-wrap .wpcf7-form.sent .wpcf7-response-output,
.nvo-cf7-wrap .wpcf7-form.failed  .wpcf7-response-output,
.nvo-cf7-wrap .wpcf7-form.invalid .wpcf7-response-output,
.nvo-cf7-wrap .wpcf7-form.spam    .wpcf7-response-output,
.nvo-cf7-wrap .wpcf7-form.aborted .wpcf7-response-output {
  display: block;
}
/* Success */
.nvo-cf7-wrap .wpcf7-form.sent .wpcf7-response-output {
  background: rgba(15,163,96,.09);
  border-color: rgba(15,163,96,.30);
  color: #065f46;
}
/* Failure / invalid / spam */
.nvo-cf7-wrap .wpcf7-form.failed  .wpcf7-response-output,
.nvo-cf7-wrap .wpcf7-form.invalid .wpcf7-response-output,
.nvo-cf7-wrap .wpcf7-form.spam    .wpcf7-response-output,
.nvo-cf7-wrap .wpcf7-form.aborted .wpcf7-response-output {
  background: rgba(224,64,64,.06);
  border-color: rgba(224,64,64,.28);
  color: #c0392b;
}

/* ── Field validation states ─────────────────────────────── */
.nvo-cf7-wrap .wpcf7-not-valid {
  border-color: #e04040 !important;
  background: rgba(224,64,64,.04) !important;
}
.nvo-cf7-wrap .wpcf7-not-valid-tip {
  display: block;
  font-size: 11.5px;
  color: #c0392b;
  font-weight: var(--novo-fw-semibold);
  margin-top: 5px;
}

/* ── AJAX loading — pulse the submit button ──────────────── */
.nvo-cf7-wrap .wpcf7-form.submitting input[type="submit"] {
  opacity: .7;
  cursor: wait;
  pointer-events: none;
}

/* ── Form reset (flex column) ────────────────────────────── */
.nvo-cf7-wrap .wpcf7-form {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.nvo-cf7-wrap .wpcf7-form > br { display: none !important; }

/* ── .form-group layout (used when CF7 wraps rows in div.form-group) ── */
.nvo-cf7-wrap .wpcf7-form .form-group {
  display: flex;
  flex-direction: column;
  gap: 7px;
  margin-bottom: 18px;
}

/* ── Two-column row: <div class="form-group two-col"> ── */
.nvo-cf7-wrap .wpcf7-form .form-group.two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 12px;
}
/* Each <p> inside a two-col row acts as a flex column */
.nvo-cf7-wrap .wpcf7-form .form-group.two-col > p,
.nvo-cf7-wrap .wpcf7-form .form-group.two-col > span {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.nvo-cf7-wrap .wpcf7-form .form-group.two-col > p label,
.nvo-cf7-wrap .wpcf7-form .form-group.two-col > span label {
  margin-bottom: 0;
}
@media (max-width: 600px) {
  .nvo-cf7-wrap .wpcf7-form .form-group.two-col {
    grid-template-columns: 1fr;
  }
}
/* Two-field group — detected by a second <label> inside the same .form-group */
.nvo-cf7-wrap .wpcf7-form .form-group:has(label:nth-of-type(2)) {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
  column-gap: 16px;
  row-gap: 7px;
}
.nvo-cf7-wrap .wpcf7-form .form-group:has(label:nth-of-type(2)) > label:first-of-type { grid-column: 1; grid-row: 1; }
.nvo-cf7-wrap .wpcf7-form .form-group:has(label:nth-of-type(2)) > label:last-of-type  { grid-column: 2; grid-row: 1; }
.nvo-cf7-wrap .wpcf7-form .form-group:has(label:nth-of-type(2)) > span:first-of-type  { grid-column: 1; grid-row: 2; }
.nvo-cf7-wrap .wpcf7-form .form-group:has(label:nth-of-type(2)) > span:last-of-type   { grid-column: 2; grid-row: 2; }
@media (max-width: 600px) {
  .nvo-cf7-wrap .wpcf7-form .form-group:has(label:nth-of-type(2)) {
    grid-template-columns: 1fr;
  }
  .nvo-cf7-wrap .wpcf7-form .form-group:has(label:nth-of-type(2)) > label:last-of-type { grid-column: 1; grid-row: 3; }
  .nvo-cf7-wrap .wpcf7-form .form-group:has(label:nth-of-type(2)) > span:last-of-type  { grid-column: 1; grid-row: 4; }
}

/* ── Auto two-column: form-group with 2 <p> children (CF7 placeholder-only, no labels) ── */
.nvo-cf7-wrap .wpcf7-form .form-group:has(> p:nth-of-type(2)) {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 18px;
}
.nvo-cf7-wrap .wpcf7-form .form-group:has(> p:nth-of-type(2)) > p {
  margin: 0;
}
@media (max-width: 600px) {
  .nvo-cf7-wrap .wpcf7-form .form-group:has(> p:nth-of-type(2)) {
    grid-template-columns: 1fr;
  }
}

/* ── Required marker & abbr ──────────────────────────────── */
.nvo-cf7-wrap .wpcf7-form .req { color: var(--novo-orange, #F56D0D); }
.nvo-cf7-wrap .wpcf7-form abbr[title="required"] { display: none !important; }

/* ── Scoped field appearance: grey bg at rest, orange on focus ── */
/* Overrides the global white-bg .wpcf7 rules above for nvo-cf7-wrap contexts */
.nvo-cf7-wrap .wpcf7-form input:not([type="submit"]),
.nvo-cf7-wrap .wpcf7-form select,
.nvo-cf7-wrap .wpcf7-form textarea {
  background: var(--novo-grey-bg, #F7F8FA);
  border-color: transparent;
}
.nvo-cf7-wrap .wpcf7-form input::placeholder,
.nvo-cf7-wrap .wpcf7-form textarea::placeholder { color: #B0C0CC; }
.nvo-cf7-wrap .wpcf7-form select option:first-child { color: #B0C0CC; }
.nvo-cf7-wrap .wpcf7-form input:focus:not([type="submit"]),
.nvo-cf7-wrap .wpcf7-form select:focus,
.nvo-cf7-wrap .wpcf7-form textarea:focus {
  border-color: var(--novo-orange, #F56D0D);
  background: #fff;
  box-shadow: 0 0 0 4px rgba(245,109,13,.10);
}

/* ══════════════════════════════════════════════════════════════
   CONTEXT: Contact Form (nvo-cf-left)
   Two-column form left of map/address block
   Override CF7 global white-bg / visible-border to match reference:
     - grey background (#F7F8FA) + transparent border at rest
     - white background + orange border on focus
   ══════════════════════════════════════════════════════════════ */
.nvo-cf-left .nvo-cf7-wrap { margin-top: 4px; }

.nvo-cf-left .nvo-cf7-wrap .wpcf7 input[type="text"],
.nvo-cf-left .nvo-cf7-wrap .wpcf7 input[type="email"],
.nvo-cf-left .nvo-cf7-wrap .wpcf7 input[type="tel"],
.nvo-cf-left .nvo-cf7-wrap .wpcf7 select,
.nvo-cf-left .nvo-cf7-wrap .wpcf7 textarea {
  background: var(--novo-grey-bg, #F7F8FA);
  border-color: transparent;
}
.nvo-cf-left .nvo-cf7-wrap .wpcf7 input[type="text"]:hover,
.nvo-cf-left .nvo-cf7-wrap .wpcf7 input[type="email"]:hover,
.nvo-cf-left .nvo-cf7-wrap .wpcf7 input[type="tel"]:hover,
.nvo-cf-left .nvo-cf7-wrap .wpcf7 select:hover,
.nvo-cf-left .nvo-cf7-wrap .wpcf7 textarea:hover {
  border-color: transparent;
}
.nvo-cf-left .nvo-cf7-wrap .wpcf7 input[type="text"]:focus,
.nvo-cf-left .nvo-cf7-wrap .wpcf7 input[type="email"]:focus,
.nvo-cf-left .nvo-cf7-wrap .wpcf7 input[type="tel"]:focus,
.nvo-cf-left .nvo-cf7-wrap .wpcf7 select:focus,
.nvo-cf-left .nvo-cf7-wrap .wpcf7 textarea:focus {
  background: #fff;
  border-color: var(--novo-orange);
}

/* ══════════════════════════════════════════════════════════════
   CONTEXT: Trade-in / Valuation form-card (dark navy background)
   ══════════════════════════════════════════════════════════════ */
.form-card .nvo-cf7-wrap {
  padding: 0;             /* card itself has padding */
}
.form-card .nvo-cf7-wrap .wpcf7-form label,
.form-card .nvo-cf7-wrap .wpcf7-form p > strong,
.form-card .nvo-cf7-wrap .wpcf7-form p > b {
  color: rgba(255,255,255,.82);
}

/* Select options — dark bg so list is readable on all OS */
.form-card .nvo-cf7-wrap .wpcf7 select option {
  background: #0d2f45;
  color: #fff;
}
.form-card .nvo-cf7-wrap .wpcf7 input[type="text"],
.form-card .nvo-cf7-wrap .wpcf7 input[type="email"],
.form-card .nvo-cf7-wrap .wpcf7 input[type="tel"],
.form-card .nvo-cf7-wrap .wpcf7 input[type="number"],
.form-card .nvo-cf7-wrap .wpcf7 input[type="date"],
.form-card .nvo-cf7-wrap .wpcf7 select,
.form-card .nvo-cf7-wrap .wpcf7 textarea {
  background: rgba(255,255,255,.07);
  border-color: rgba(255,255,255,.16);
  color: #fff;
}
.form-card .nvo-cf7-wrap .wpcf7 input::placeholder,
.form-card .nvo-cf7-wrap .wpcf7 textarea::placeholder {
  color: rgba(255,255,255,.35);
}
.form-card .nvo-cf7-wrap .wpcf7 input:focus,
.form-card .nvo-cf7-wrap .wpcf7 select:focus,
.form-card .nvo-cf7-wrap .wpcf7 textarea:focus {
  border-color: var(--novo-orange);
  background: rgba(255,255,255,.11);
  box-shadow: 0 0 0 4px rgba(245,109,13,.15);
}

/* date picker calendar icon — keep it visible on dark bg */
.form-card .nvo-cf7-wrap .wpcf7 input[type="date"]::-webkit-calendar-picker-indicator {
  filter: invert(1) opacity(.55);
  cursor: pointer;
}

/* ── File input — light context ──────────────────────────── */
.nvo-cf7-wrap .wpcf7 input[type="file"] {
  width: 100%;
  padding: 11px 16px;
  background: var(--novo-grey-bg, #F7F8FA);
  border: 1.5px solid transparent;
  border-radius: var(--novo-radius-md);
  font-family: var(--novo-font);
  font-size: 13px;
  color: var(--novo-navy);
  cursor: pointer;
  transition: border-color .22s, background .22s;
}
.nvo-cf7-wrap .wpcf7 input[type="file"]::-webkit-file-upload-button,
.nvo-cf7-wrap .wpcf7 input[type="file"]::file-selector-button {
  padding: 6px 14px;
  margin-right: 12px;
  border: none;
  border-radius: 6px;
  background: var(--novo-navy, #0B3954);
  color: #fff;
  font-family: var(--novo-font);
  font-size: 12px;
  font-weight: var(--novo-fw-semibold);
  cursor: pointer;
  transition: background .2s;
}
.nvo-cf7-wrap .wpcf7 input[type="file"]::-webkit-file-upload-button:hover,
.nvo-cf7-wrap .wpcf7 input[type="file"]::file-selector-button:hover {
  background: var(--novo-navy-dark, #07273a);
}

/* ── File input — dark (form-card) context ───────────────── */
.form-card .nvo-cf7-wrap .wpcf7 input[type="file"] {
  background: rgba(255,255,255,.07);
  border-color: rgba(255,255,255,.16);
  color: rgba(255,255,255,.75);
}
.form-card .nvo-cf7-wrap .wpcf7 input[type="file"]::-webkit-file-upload-button,
.form-card .nvo-cf7-wrap .wpcf7 input[type="file"]::file-selector-button {
  background: rgba(255,255,255,.18);
  color: #fff;
}
.form-card .nvo-cf7-wrap .wpcf7 input[type="file"]::-webkit-file-upload-button:hover,
.form-card .nvo-cf7-wrap .wpcf7 input[type="file"]::file-selector-button:hover {
  background: rgba(255,255,255,.28);
}
.form-card .nvo-cf7-wrap .wpcf7-form.sent .wpcf7-response-output {
  background: rgba(15,163,96,.14);
  border-color: rgba(15,163,96,.40);
}

/* ══════════════════════════════════════════════════════════════
   CONTEXT: Enquiry strip (dark navy card)
   ══════════════════════════════════════════════════════════════ */
.enquiry-card .nvo-cf7-wrap { width: 100%; }
.enquiry-card .nvo-cf7-wrap .wpcf7-form label {
  color: var(--novo-navy);
}

/* ══════════════════════════════════════════════════════════════
   CONTEXT: Newsletter row (nvo-cf7-wrap--nl)
   Full-width dark section — email inline + submit
   ══════════════════════════════════════════════════════════════ */
.nvo-cf7-wrap--nl .wpcf7-form {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 12px;
}
/* Each <p> becomes a flex child */
.nvo-cf7-wrap--nl .wpcf7-form > p {
  margin: 0;
  flex: 1 1 260px;
}
/* The submit <p> should not grow */
.nvo-cf7-wrap--nl .wpcf7-form > p:last-of-type {
  flex: 0 0 auto;
}
.nvo-cf7-wrap--nl .wpcf7 input[type="email"] {
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.18);
  border-radius: var(--novo-radius-pill);
  color: #fff;
}
.nvo-cf7-wrap--nl .wpcf7 input[type="email"]::placeholder {
  color: rgba(255,255,255,.45);
}
.nvo-cf7-wrap--nl .wpcf7 input[type="email"]:focus {
  border-color: var(--novo-orange);
  background: rgba(255,255,255,.16);
}
.nvo-cf7-wrap--nl .wpcf7-form input[type="submit"] {
  border-radius: var(--novo-radius-pill);
  width: auto;
  padding: 14px 28px;
}
.nvo-cf7-wrap--nl .wpcf7-response-output {
  flex: 1 1 100%;
  margin-top: 8px;
}
@media (max-width: 540px) {
  .nvo-cf7-wrap--nl .wpcf7-form > p       { flex: 1 1 100%; }
  .nvo-cf7-wrap--nl .wpcf7-form input[type="submit"] { width: 100%; }
}

/* ══════════════════════════════════════════════════════════════
   CONTEXT: Sidebar newsletter (nvo-cf7-wrap--sidebar)
   Compact single-column inside article sidebar widget
   ══════════════════════════════════════════════════════════════ */
.nvo-cf7-wrap--sidebar .wpcf7-form > p {
  margin-bottom: 10px;
}
.nvo-cf7-wrap--sidebar .wpcf7 input[type="email"] {
  border-radius: var(--novo-radius-pill);
}
.nvo-cf7-wrap--sidebar .wpcf7-form input[type="submit"] {
  width: 100%;
  padding: 12px 24px;
  border-radius: var(--novo-radius-pill);
  font-size: 14px;
}

/* ══════════════════════════════════════════════════════════════
   Editor-only CF7 config notice
   ══════════════════════════════════════════════════════════════ */
.nvo-cf7-notice {
  padding: 12px 16px;
  background: #fff8e1;
  border: 1.5px solid #f59b00;
  border-radius: var(--novo-radius-md, 8px);
  font-size: 13px;
  color: #7c4a00;
  font-weight: 600;
  line-height: 1.4;
}

/* --------------------------------------------------------------------------
   Source: novo-utilities.css
   -------------------------------------------------------------------------- */
/**
 * novo-utilities.css
 * Badges, pills, tags, status indicators, trust elements, eyebrows,
 * dividers, and misc reusable micro-components.
 * Depends on: novo-tokens.css
 */

/* ── Status badges ───────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--novo-fs-xs);
  font-weight: var(--novo-fw-bold);
  padding: 5px 12px;
  border-radius: var(--novo-radius-pill);
  line-height: 1;
  border: 1px solid transparent;
  white-space: nowrap;
}

.badge i { font-size: 7px; }

.badge-green {
  background: rgba(15,163,96,.10);
  border-color: rgba(15,163,96,.28);
  color: var(--novo-green);
}
.badge-green i { animation: blink 1.8s ease infinite; }

.badge-blue {
  background: rgba(26,96,144,.10);
  border-color: rgba(26,96,144,.28);
  color: var(--novo-blue);
}

.badge-orange {
  background: rgba(245,109,13,.10);
  border-color: rgba(245,109,13,.28);
  color: var(--novo-orange);
}

.badge-grey {
  background: rgba(122,144,160,.10);
  border-color: rgba(122,144,160,.22);
  color: var(--novo-grey-tx);
}

.badge-navy {
  background: rgba(11,57,84,.08);
  border-color: rgba(11,57,84,.16);
  color: var(--novo-navy);
}

/* ── Availability specific ───────────────────────────── */
/* Class names use double-dash to match novo_avail_status() output in helpers.php */
.avail--in-stock {
  background: rgba(15,163,96,.10);
  border-color: rgba(15,163,96,.28);
  color: var(--novo-green);
}
.avail--in-stock i { animation: blink 1.8s ease infinite; }

.avail--pending,
.avail--incoming,
.avail--reserved {
  background: rgba(26,96,144,.10);
  border-color: rgba(26,96,144,.28);
  color: var(--novo-blue);
}

.avail--sold {
  background: rgba(122,144,160,.10);
  border-color: rgba(122,144,160,.22);
  color: var(--novo-grey-tx);
}

/* Availability dot */
.avail-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
}
.avail-dot.green  { background: var(--novo-green); animation: blink 1.8s ease infinite; }
.avail-dot.orange { background: var(--novo-orange-lite); }
.avail-dot.grey   { background: var(--novo-border); }
.avail-dot--green { background: var(--novo-green); animation: blink 1.8s ease infinite; }
.avail-dot--amber { background: var(--novo-orange-lite); }
.avail-dot--red   { background: #ef4444; }
.avail-dot--grey  { background: var(--novo-border); }

/* ── Trust pills ─────────────────────────────────────── */
.trust-pill {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 16px;
  border-radius: var(--novo-radius-pill);
  font-size: 12px;
  font-weight: var(--novo-fw-bold);
  border: 1px solid;
}

.tp-orange {
  background: rgba(245,109,13,.10);
  border-color: rgba(245,109,13,.28);
  color: var(--novo-orange-lite);
}
.tp-green {
  background: rgba(15,163,96,.12);
  border-color: rgba(15,163,96,.32);
  color: #4de3a0;
}
.tp-blue {
  background: rgba(91,192,235,.08);
  border-color: rgba(91,192,235,.24);
  color: #99d6f5;
}
.tp-white {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.22);
  color: rgba(255,255,255,.72);
}

/* ── Category / spec tags ────────────────────────────── */
.tag {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: var(--novo-fs-xs);
  font-weight: var(--novo-fw-bold);
  padding: 4px 11px;
  border-radius: var(--novo-radius-pill);
  background: rgba(11,57,84,.06);
  color: var(--novo-navy);
  border: 1px solid var(--novo-border);
  white-space: nowrap;
}

.tag-orange {
  background: rgba(245,109,13,.08);
  border-color: rgba(245,109,13,.22);
  color: var(--novo-orange);
}

.tag-green {
  background: rgba(15,163,96,.08);
  border-color: rgba(15,163,96,.22);
  color: var(--novo-green);
}

/* ── Tags row ────────────────────────────────────────── */
.tags-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

/* ── Filter pill (blog / equipment) ─────────────────── */
.filter-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 20px;
  border-radius: var(--novo-radius-pill);
  font-size: 13px;
  font-weight: var(--novo-fw-semibold);
  color: var(--novo-grey-tx);
  background: #fff;
  border: 1.5px solid var(--novo-border);
  cursor: pointer;
  transition: var(--novo-transition);
  -webkit-user-select: none;
  user-select: none;
}
.filter-pill:hover {
  border-color: var(--novo-orange);
  color: var(--novo-orange);
}
.filter-pill.active,
.filter-pill.is-active {
  background: var(--novo-navy);
  border-color: var(--novo-navy);
  color: #fff;
}

/* ── Eyebrow / section label ─────────────────────────── */
.section-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: var(--novo-fs-xs);
  font-weight: var(--novo-fw-black);
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--novo-orange);
  margin-bottom: 14px;
}
.section-eyebrow-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--novo-orange);
  animation: blink 1.8s ease infinite;
}

/* ── Divider bar (orange gradient) ──────────────────── */
.divider-orange {
  display: block;
  width: 50px;
  height: 4px;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--novo-orange), rgba(245,109,13,.22));
  margin: 18px 0 24px;
}
.divider-orange.center { margin: 18px auto 24px; }

/* ── Breadcrumb ──────────────────────────────────────── */
.novo-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: var(--novo-fw-semibold);
  color: var(--novo-grey-tx);
}
.novo-breadcrumb a { color: var(--novo-grey-tx); transition: color .2s; }
.novo-breadcrumb a:hover { color: var(--novo-orange); }
.novo-breadcrumb .sep { color: rgba(122,144,160,.5); }
.novo-breadcrumb .current { color: var(--novo-navy); font-weight: var(--novo-fw-bold); }

/* ── Stats / trust strip ─────────────────────────────── */
.trust-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background: #fff;
  border: 1px solid var(--novo-border);
  border-radius: var(--novo-radius-lg);
  overflow: hidden;
  box-shadow: var(--novo-shadow-sm);
}
.trust-strip-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 28px 20px;
  border-right: 1px solid var(--novo-border);
  text-align: center;
}
.trust-strip-item:last-child { border-right: none; }
.trust-strip-num {
  font-size: 32px;
  font-weight: var(--novo-fw-black);
  color: var(--novo-navy);
  letter-spacing: -1.5px;
  line-height: 1;
  margin-bottom: 6px;
}
.trust-strip-num span { color: var(--novo-orange); font-size: 22px; }
.trust-strip-label {
  font-size: 11px;
  font-weight: var(--novo-fw-bold);
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--novo-grey-tx);
}

@media (max-width: 768px) {
  .trust-strip { grid-template-columns: repeat(2, 1fr); }
  .trust-strip-item:nth-child(2) { border-right: none; }
  .trust-strip-item:nth-child(3) { border-top: 1px solid var(--novo-border); }
}
@media (max-width: 420px) {
  .trust-strip { grid-template-columns: 1fr 1fr; }
}

/* ── Note / info boxes ───────────────────────────────── */
.note-box {
  padding: 14px 18px;
  border-radius: var(--novo-radius-sm);
  font-size: 13px;
  line-height: 1.7;
  display: flex;
  gap: 10px;
  align-items: flex-start;
  margin-bottom: 16px;
}
.note-box i { margin-top: 2px; flex-shrink: 0; }
.note-info    { background: rgba(11,57,84,.05); border-left: 3px solid var(--novo-navy); color: var(--novo-navy); }
.note-warning { background: rgba(245,109,13,.07); border-left: 3px solid var(--novo-orange); color: #7c3900; }
.note-success { background: rgba(15,163,96,.07); border-left: 3px solid var(--novo-green); color: #065f46; }
.note-gdpr    { background: rgba(15,163,96,.07); border-left: 3px solid var(--novo-green); color: #065f46; }

/* ── Pull quote ──────────────────────────────────────── */
.pull-quote {
  margin: 32px 0;
  padding: 28px 36px;
  border-left: 4px solid var(--novo-orange);
  background: rgba(245,109,13,.04);
  border-radius: 0 var(--novo-radius-sm) var(--novo-radius-sm) 0;
}
.pull-quote p {
  font-size: 18px;
  font-weight: var(--novo-fw-semibold);
  font-style: italic;
  color: var(--novo-navy);
  line-height: 1.6;
  margin: 0;
}
.pull-quote cite {
  display: block;
  font-size: 12px;
  font-weight: var(--novo-fw-bold);
  color: var(--novo-grey-tx);
  margin-top: 12px;
  font-style: normal;
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* ── Reading time / meta ─────────────────────────────── */
.meta-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  font-weight: var(--novo-fw-semibold);
  color: var(--novo-grey-tx);
}
.meta-chip i { font-size: 11px; color: var(--novo-orange); }

/* --------------------------------------------------------------------------
   Source: novo-animations.css
   -------------------------------------------------------------------------- */
/**
 * novo-animations.css
 * All @keyframes and scroll-reveal utility classes.
 * All animation values lifted exactly from HTML source.
 * Depends on: novo-tokens.css
 */

/* ── @keyframes ──────────────────────────────────────── */

@keyframes fadeDown {
  from { opacity: 0; transform: translateY(-20px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes fadeLeft {
  from { opacity: 0; transform: translateX(32px); }
  to   { opacity: 1; transform: translateX(0); }
}

@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

@keyframes floatY {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-14px); }
}

@keyframes floatOrb {
  0%, 100% { transform: translateY(0) scale(1); }
  50%       { transform: translateY(-28px) scale(1.05); }
}

@keyframes blink {
  0%, 100% { opacity: 1; }
  50%       { opacity: .3; }
}

@keyframes marquee {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

@keyframes ringPulse {
  0%, 100% { opacity: 1;  transform: translate(-50%, -50%) scale(1);    }
  50%       { opacity: .5; transform: translate(-50%, -50%) scale(1.08); }
}

@keyframes ringPulseFixed {
  0%, 100% { opacity: 1; transform: translateY(-50%) scale(1); }
  50%       { opacity: .30; transform: translateY(-50%) scale(1.05); }
}

@keyframes scrollLine {
  0%   { transform: scaleY(0); transform-origin: top;    opacity: 1; }
  50%  { transform: scaleY(1); transform-origin: top;    opacity: 1; }
  51%  { transform-origin: bottom; }
  100% { transform: scaleY(0); transform-origin: bottom; opacity: 0; }
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

@keyframes spinSlow {
  to { transform: rotate(360deg); }
}

@keyframes shimmer {
  from { background-position: -400px 0; }
  to   { background-position:  400px 0; }
}

@keyframes countUp {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes slideIn {
  from { transform: translateX(-100%); opacity: 0; }
  to   { transform: translateX(0); opacity: 1; }
}

@keyframes slideDown {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes progressBar {
  from { width: 0; }
  to   { width: var(--progress, 0%); }
}

@keyframes floatPulse {
  0%, 100% { box-shadow: 0 8px 24px rgba(245,109,13,.35); }
  50%       { box-shadow: 0 8px 40px rgba(245,109,13,.55), 0 0 0 12px rgba(245,109,13,.08); }
}

@keyframes scanMove {
  0%   { top: -2px; }
  100% { top: 100%; }
}

@keyframes nvo-ring-pulse {
  0%, 100% { opacity: 1;  transform: translateY(-50%) scale(1); }
  50%       { opacity: .4; transform: translateY(-50%) scale(1.04); }
}

@keyframes nvo-float-orb {
  0%, 100% { transform: translateY(0) scale(1); }
  50%       { transform: translateY(-28px) scale(1.05); }
}

/* ── Scroll reveal — .novo-reveal ────────────────────── */
/* Base classes carry ONLY transition + will-change.
   The hidden state is applied by JS via .novo-reveal-init
   so elements are always visible without JS (editor, SSR). */
.novo-reveal {
  will-change: opacity, transform;
  transition:
    opacity  .8s cubic-bezier(.22,.68,0,1),
    transform .8s cubic-bezier(.22,.68,0,1);
}
.novo-reveal.visible {
  opacity: 1 !important;
  transform: translateY(0) !important;
}

/* Delay helpers */
.d1 { transition-delay: .07s; }
.d2 { transition-delay: .14s; }
.d3 { transition-delay: .21s; }
.d4 { transition-delay: .28s; }
.d5 { transition-delay: .35s; }
.d6 { transition-delay: .42s; }
.d7 { transition-delay: .50s; }
.d8 { transition-delay: .57s; }

/* HTML-reference aliases (.reveal + .vis) — maps to the canonical .novo-reveal system.
   Allows both class naming conventions to animate without breaking existing Elementor
   template data that may use the shorter names from the HTML reference pages. */
.reveal {
  will-change: opacity, transform;
  transition:
    opacity  .8s cubic-bezier(.22,.68,0,1),
    transform .8s cubic-bezier(.22,.68,0,1);
}
.reveal.revealed {
  opacity: 1 !important;
  transform: translateY(0) !important;
}

/* Fade from left */
.novo-reveal-left {
  will-change: opacity, transform;
  transition:
    opacity  .9s cubic-bezier(.22,.68,0,1),
    transform .9s cubic-bezier(.22,.68,0,1);
}
.novo-reveal-left.visible {
  opacity: 1 !important;
  transform: translateX(0) !important;
}

/* Scale in */
.novo-reveal-scale {
  will-change: opacity, transform;
  transition:
    opacity .7s ease,
    transform .7s cubic-bezier(.22,.68,0,1.2);
}
.novo-reveal-scale.visible {
  opacity: 1 !important;
  transform: scale(1) !important;
}

/* Hidden state — added by JS only to off-viewport elements */
.novo-reveal-init {
  opacity: 0;
  transform: translateY(36px);
}
.novo-reveal-init.novo-reveal-left  { transform: translateX(32px); }
.novo-reveal-init.novo-reveal-scale { transform: scale(.95); }

/* ── Perpetual animations (applied directly to elements) */
.anim-float {
  animation: floatY 9s ease-in-out infinite;
}

.anim-float-slow {
  animation: floatY 12s ease-in-out infinite;
}

.anim-blink {
  animation: blink 1.8s ease infinite;
}

.anim-spin-slow {
  animation: spinSlow 18s linear infinite;
}

.anim-marquee {
  animation: marquee 28s linear infinite;
}
.anim-marquee:hover {
  animation-play-state: paused;
}

/* ── Loading shimmer ─────────────────────────────────── */
.shimmer {
  background: linear-gradient(90deg, #f0f2f5 25%, #e4e7eb 37%, #f0f2f5 63%);
  background-size: 800px 100%;
  animation: shimmer 1.6s infinite;
}

/* ── Hero orbs (persistent) ──────────────────────────── */
.hero-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(90px);
  pointer-events: none;
}
.hero-orb-orange {
  background: var(--novo-orange);
  opacity: .14;
  animation: floatY 12s ease-in-out infinite;
}
.hero-orb-blue {
  background: #1A6090;
  opacity: .22;
  animation: floatY 10s ease-in-out infinite 3s;
}

/* ── Elementor editor: belt-and-suspenders visibility override ─ */
/* Primary fix is via PHP elementor/preview/enqueue_styles hook. */
.elementor-editor-active .novo-reveal-init {
  opacity: 1 !important;
  transform: none !important;
  transition: none !important;
}

/* -- Accessibility: prefers-reduced-motion --------------------------------
 * Disable all CSS-driven motion for users who opt out of animations.
 * JS counterUp() already checks this preference independently.
 * ----------------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {

  /* Scroll-reveal: show elements immediately, skip entrance transitions */
  .novo-reveal,
  .novo-reveal-left,
  .novo-reveal-scale {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
  .novo-reveal.visible,
  .novo-reveal-left.visible,
  .novo-reveal-scale.visible {
    opacity: 1;
    transform: none;
  }

  /* Brand marquee: freeze the scrolling track */
  .novo-brand-marquee-track,
  .novo-brand-marquee-outer {
    animation: none !important;
  }

  /* Decorative orbs, rings, and hero floating elements */
  [class*="hero-orb"],
  [class*="-ring"],
  .novo-orb,
  .cta-ring {
    animation: none !important;
  }

  /* Floating quote button pulse */
  .float-quote-btn--pulse {
    animation: none !important;
  }
}

/* --------------------------------------------------------------------------
   Source: novo-widgets.css
   -------------------------------------------------------------------------- */
/**
 * novo-widgets.css
 * Component styles for all 53 NOVO Elementor widgets.
 * Depends on: novo-tokens.css (--novo-* variables)
 *
 * Load order: after novo-animations (registered in enqueue.php)
 */

/* ═══════════════════════════════════════════════
   ELEMENTOR CONTAINER RESETS
   Prevent Elementor from stacking its own padding
   on top of each widget's built-in spacing.
═══════════════════════════════════════════════ */

/* Widget wrap: no extra box */
.elementor-element .elementor-widget-container {
  padding: 0 !important;
  margin:  0 !important;
}

/* Strip Elementor's column-gap-default 10 px inset from every NOVO widget section.
   Elementor's .elementor-column-gap-default rule applies padding:10px to
   .elementor-element-populated (.elementor-widget-wrap), clipping any widget that
   manages its own full-width background (hero, footer, contact form, CTA, marquee …).
   All importer sections use a single 100 % column, so the gap padding is always wrong.
   The [class*] attribute selector matches every Elementor widget type class built from
   a novo_* widget name (e.g. elementor-widget-novo_hero, elementor-widget-novo_contact_form). */
.elementor-section:has([class*="elementor-widget-novo_"]) > .elementor-container > .elementor-column > .elementor-widget-wrap,
.e-con:has([class*="elementor-widget-novo_"]) > .e-con-inner {
  padding: 0 !important;
}

/* CTA Banner also needs the outer SECTION padding zeroed so its background
   truly bleeds edge-to-edge with no extra section-level spacing. */
.elementor-section:has(.novo-cta-banner),
.e-con:has(.novo-cta-banner) {
  padding: 0 !important;
}

/* Flex Container (e-con) — let Elementor control padding normally.
   Section-level padding is handled by the :has() rules below. */

/* ─── Contact-page section auto-spacing via :has() ─────────────────────────
   Removes the need to configure each Elementor section manually.
   Works because Elementor containers have higher specificity than .e-con
   BUT our !important wins over non-!important ID rules.               ─── */

/* Zero padding on ALL ancestor containers of the stats card (prevents stacking) */
.e-con:has(.stats-card) {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  overflow: visible !important;
}
/* Apply grey bg + bottom padding ONLY on the innermost .e-con (no .e-con sits between it and the card) */
.e-con:not(:has(.e-con .stats-card)):has(.stats-card) {
  background: var(--novo-grey-bg, #F7F8FA) !important;
  padding-bottom: 72px !important;
}
/* Propagate overflow:visible up through all wrapping Elementor containers
   and strip any padding they may add so no gap appears below the hero */
.e-con:has(.e-con:has(.stats-card)) {
  overflow: visible !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}
/* Allow hero container to show overlapping stats card */
.e-con:has(.novo-hero) {
  overflow: visible !important;
}
/* CRITICAL: Elementor's .elementor-widget-container has overflow:hidden by default.
   This clips the stats card's margin-top:-64px. Override it. */
.e-con:has(.stats-card) .elementor-widget-container {
  overflow: visible !important;
}
/* ─── Trade-In trust strip overlap via :has() ─────────────────────────────
   Works for both legacy sections (.elementor-section) and new containers (.e-con). */
/* Zero padding + overflow visible on section/container holding the trust card */
.e-con:has(.tradein-trust-card),
.elementor-section:has(.tradein-trust-card) {
  padding-top: 0 !important;
  padding-bottom: 88px !important;
  overflow: visible !important;
}
/* Background variant — driven by class on .container div inside widget */
.e-con:has(.tradein-bg-grey),
.elementor-section:has(.tradein-bg-grey)  { background: var(--novo-grey-bg, #f4f6f9) !important; }
.e-con:has(.tradein-bg-white),
.elementor-section:has(.tradein-bg-white) { background: var(--novo-white, #fff) !important; }
.e-con:has(.tradein-bg-navy),
.elementor-section:has(.tradein-bg-navy)  { background: var(--novo-navy, #0b3954) !important; }
/* Propagate overflow:visible up through all wrapping Elementor containers */
.e-con:has(.e-con:has(.tradein-trust-card)) {
  overflow: visible !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}
/* Allow .elementor-widget-container to show the card's negative margin */
.e-con:has(.tradein-trust-card) .elementor-widget-container,
.elementor-section:has(.tradein-trust-card) .elementor-widget-container {
  overflow: visible !important;
}
/* Legacy section inner wrappers also need overflow visible */
.elementor-section:has(.tradein-trust-card) .elementor-container,
.elementor-section:has(.tradein-trust-card) .elementor-column,
.elementor-section:has(.tradein-trust-card) .elementor-widget-wrap {
  overflow: visible !important;
}
/* Dept cards section */
.e-con:has(.novo-dept-grid) {
  padding-top: 88px !important;
  padding-bottom: 88px !important;
  background: var(--novo-grey-bg, #F7F8FA) !important;
}
.e-con:has(.novo-dept-grid) .section-header,
.e-con:has(.dept-grid) .section-header {
  text-align: center !important;
  margin-bottom: 60px !important;
}
.e-con:has(.novo-dept-grid) .section-header .s-sub,
.e-con:has(.dept-grid) .section-header .s-sub {
  text-align: center !important;
  margin-inline: auto !important;
}
.e-con:has(.novo-dept-grid) .s-divider,
.e-con:has(.dept-grid) .s-divider { width: 60px; margin-left: auto !important; margin-right: auto !important; }
/* Contact form section — widget manages its own padding; no :has() override needed */
/* Team cards section */
.e-con:has(.team-grid) {
  padding-top: 96px !important;
  padding-bottom: 96px !important;
  background: var(--novo-grey-bg, #F7F8FA) !important;
}
.e-con:has(.team-grid) .section-header {
  text-align: center;
  margin-bottom: 56px;
}
.e-con:has(.team-grid) .section-header .s-sub {
  text-align: center;
  margin-inline: auto;
}
.e-con:has(.team-grid) .s-divider { width: 60px; }

/* Stats counter section header centering */
.e-con:has(.value-stats) .section-header,
.e-con:has(.stats-card) .section-header { text-align: center; }

/* ═══════════════════════════════════════════════
   CLASSIC ELEMENTOR LAYOUT (.elementor-section / .elementor-column)
   Parallels the .e-con rules above for pages that use the legacy layout.
   These selectors fire when Elementor renders sections as <section.elementor-section>
   rather than <div.e-con>.
═══════════════════════════════════════════════ */

/* Stats section overlap — pull the Elementor SECTION up 64px so it sits over
   the hero. Use transparent for the 64px overlap zone so the hero's own
   gradient shows through perfectly, with no colour-matching required. */
/* Hero section must allow overflow so the next section can overlap it */
.elementor-section:has(.novo-hero) {
  overflow: visible !important;
}
.elementor-section:has(.stats-card) {
  margin-top: -64px !important;
  position: relative;
  z-index: 1;
  padding-top: 0 !important;
  padding-bottom: 88px !important;
  background: linear-gradient(
    to bottom,
    transparent 64px,
    var(--novo-grey-bg, #F5F7FA) 64px
  ) !important;
}
/* Widget's own .stats-section carries a grey background that would cover
   the navy gradient zone — remove it so the section gradient shows through. */
.elementor-section:has(.stats-card) .stats-section {
  background: none !important;
  padding-bottom: 0 !important;
}
/* The section-level -64px margin now handles the overlap; reset card margin. */
.elementor-section:has(.stats-card) .stats-card {
  margin-top: 0 !important;
}

/* Dept cards section — classic layout */
.elementor-section:has(.novo-dept-grid) {
  padding-top: 88px !important;
  padding-bottom: 88px !important;
  background: var(--novo-grey-bg, #F5F7FA) !important;
}
.elementor-section:has(.novo-dept-grid) .section-header {
  text-align: center !important;
  margin-bottom: 60px !important;
}
.elementor-section:has(.novo-dept-grid) .section-header .s-sub {
  text-align: center !important;
  margin-inline: auto !important;
}
.elementor-section:has(.novo-dept-grid) .s-divider {
  width: 60px;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Team cards section — classic layout. Source: team-section { background: white; padding: 96px 0 } */
.elementor-section:has(.team-grid) {
  padding-top: 96px !important;
  padding-bottom: 96px !important;
  background: var(--novo-white, #fff) !important;
}
.elementor-section:has(.team-grid) .section-header {
  text-align: center !important;
  margin-bottom: 56px !important;
}
.elementor-section:has(.team-grid) .section-header .s-sub {
  text-align: center !important;
  margin-inline: auto !important;
}
.elementor-section:has(.team-grid) .s-divider { width: 60px; }

/* SVG icon color inheritance — fix Elementor inline SVG icons */
.elementor-widget-container svg {
  fill: currentColor;
  width: 1em;
  height: 1em;
  display: inline-block;
  vertical-align: -0.125em;
}

/* ═══════════════════════════════════════════════
   SHARED SECTION TYPOGRAPHY
═══════════════════════════════════════════════ */

/* Specificity: plain class selectors (0,1,0) cover non-Elementor contexts.
   The .elementor-widget-container prefix variants (0,2,0) beat Elementor Kit's
   global `body.elementor-kit-N h2/p` rules which land at (0,1,1). */
.novo-eyebrow,
.s-eyebrow,
.eyebrow,
.section-eyebrow,
.elementor-widget-container .novo-eyebrow,
.elementor-widget-container .s-eyebrow,
.elementor-widget-container .eyebrow,
.elementor-widget-container .section-eyebrow {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3.5px;
  text-transform: uppercase;
  color: var(--novo-orange);
  margin-bottom: 14px;
}

.novo-section-title,
.section-title,
.s-title,
.elementor-widget-container .novo-section-title,
.elementor-widget-container .section-title,
.elementor-widget-container .s-title { /* .section-title, .s-title — HTML-reference canonical names */
  font-size: clamp(28px, 4vw, 40px);
  font-weight: 900;
  color: var(--novo-navy);
  letter-spacing: -1px;
  line-height: 1.1;
  margin-bottom: 12px;
}
.novo-section-title span,
.section-title span,
.s-title span {
  color: var(--novo-orange);
}

.novo-section-sub,
.section-sub,
.s-sub,
.elementor-widget-container .novo-section-sub,
.elementor-widget-container .section-sub,
.elementor-widget-container .s-sub { /* .s-sub — HTML-reference canonical name */
  font-size: 16px;
  color: var(--novo-grey-tx);
  line-height: 1.75;
  max-width: 520px;
}

/* Canonical divider rule — shared by .s-divider, .divider, .section-divider, .novo-divider, and .novo-section-divider */
.s-divider,
.divider,
.novo-divider,
.section-divider,
.novo-section-divider {
  display: block;
  height: 4px;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--novo-orange), rgba(245,109,13,.25));
}
/* Positioning modifiers */
.s-divider.left,
.divider.left,
.novo-divider.left,
.section-divider.left { margin: 22px 0; width: 52px; }
.s-divider.center,
.divider.center,
.novo-divider.center,
.section-divider.center { margin: 22px auto; width: 56px; }
.novo-section-divider { margin: 22px 0; }
.novo-section-divider--center { margin: 22px auto; }

.novo-section-header,
.section-header {
  margin-bottom: 50px;
}
.section-header.center,
.section-header--center {
  text-align: center;
}
.section-header.center .s-divider,
.section-header--center .s-divider {
  margin-left: auto;
  margin-right: auto;
}
.section-header.center .s-sub,
.section-header.center .section-sub,
.section-header--center .s-sub,
.section-header--center .section-sub {
  margin-left: auto;
  margin-right: auto;
}

.novo-gradient-text {
  background: linear-gradient(95deg, var(--novo-orange) 0%, var(--novo-orange-lite) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ═══════════════════════════════════════════════
   HERO WIDGET
═══════════════════════════════════════════════ */

.novo-hero {
  min-height: 90vh;
  background: radial-gradient(ellipse at 65% 40%, var(--novo-navy-mid) 0%, var(--novo-navy) 45%, var(--novo-navy-dark) 100%);
  display: flex;
  align-items: center;
  padding: calc(var(--novo-topbar-h, 36px) + var(--novo-hdr-h, 72px) + 60px) 0 140px;
  position: relative;
  overflow: hidden;
}

.novo-hero .hero-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(90px);
  pointer-events: none;
}

.novo-hero .hero-orb-1 {
  width: 480px; height: 480px;
  background: var(--novo-orange); opacity: .14;
  top: -100px; right: -60px;
  animation: floatY 12s ease-in-out infinite;
}

.novo-hero .hero-orb-2 {
  width: 280px; height: 280px;
  background: #1A6090; opacity: .22;
  bottom: 60px; left: -80px;
  animation: floatY 10s ease-in-out infinite 3s;
}

.novo-hero-inner {
  position: relative;
  z-index: 2;
  max-width: 700px;
}

.novo-hero-title {
  font-size: var(--novo-fs-hero);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -2.2px;
  color: #fff;
  margin-bottom: 24px;
}

.novo-hero-sub {
  font-size: 17px;
  color: rgba(255,255,255,.60);
  line-height: 1.86;
  max-width: 540px;
  margin-bottom: 38px;
}

.novo-hero-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-bottom: 28px;
}

.novo-hero-trust {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 12px;
}

.trust-pill.tp-orange { background: rgba(245,109,13,.10); border-color: rgba(245,109,13,.28); color: var(--novo-orange-lite); }
.trust-pill.tp-green  { background: rgba(15,163,96,.12);  border-color: rgba(15,163,96,.32);  color: #4de3a0; }
.trust-pill.tp-blue   { background: rgba(91,192,235,.08); border-color: rgba(91,192,235,.24); color: #99d6f5; }
.trust-pill.tp-white  { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.22); color: rgba(255,255,255,.72); }
a.trust-pill { text-decoration: none; cursor: pointer; transition: background .2s, border-color .2s, color .2s; }
a.trust-pill.tp-white:hover  { background: rgba(245,109,13,.20); border-color: rgba(245,109,13,.45); color: var(--novo-orange-lite); }
a.trust-pill.tp-orange:hover { background: rgba(245,109,13,.22); border-color: rgba(245,109,13,.50); }
a.trust-pill.tp-green:hover  { background: rgba(15,163,96,.22);  border-color: rgba(15,163,96,.50);  }
a.trust-pill.tp-blue:hover   { background: rgba(91,192,235,.18); border-color: rgba(91,192,235,.45); }

.eyebrow-dot {
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--novo-orange);
}

/* ─── Centered hero variant — Contact page ────────────────────────────────── */
.novo-hero--centered {
  min-height: 100vh;
  padding: 100px 24px 160px;
  align-items: center;
  justify-content: center;
  text-align: center;
  background: radial-gradient(ellipse at 60% 40%, var(--novo-navy-mid, #0d4a6b) 0%, var(--novo-navy, #0B3954) 40%, var(--novo-navy-dark, #071F2E) 100%);
}
.novo-hero--centered .container { max-width: none; padding: 0; }
.novo-hero--centered .hero-layout  { display: block; }
.novo-hero--centered .hero-copy    { max-width: 780px; margin: 0 auto; text-align: center; }

/* Headline: larger, centered */
.novo-hero--centered .hero-h1 {
  font-size: clamp(48px, 7vw, 80px);
  letter-spacing: -2px;
  margin-bottom: 0;
}

/* Orange divider line between headline and sub-text */
.novo-hero--centered .hero-divider {
  width: 64px; height: 4px;
  background: linear-gradient(90deg, var(--novo-orange), rgba(245,109,13,.25));
  border-radius: 2px;
  margin: 28px auto;
  animation: fadeDown .6s ease .2s both;
}

/* Sub-text: larger, looser, centered */
.novo-hero--centered .hero-sub {
  font-size: 18px;
  color: rgba(255,255,255,.68);
  max-width: 600px;
  margin: 0 auto 48px;
}

/* Buttons + trust: center-aligned */
.novo-hero--centered .hero-btns  { justify-content: center; margin-bottom: 0; }
.novo-hero--centered .hero-trust { justify-content: center; margin-top: 28px; }

/* Badge: exact reference spec */
.novo-hero--centered .hero-badge {
  background: rgba(245,109,13,.15);
  border-color: rgba(245,109,13,.35);
  font-size: 11px;
  letter-spacing: 3px;
  padding: 8px 20px;
  border-radius: 50px;
  margin-bottom: 30px;
}
.novo-hero--centered .hero-badge i { font-size: 9px; }

/* Rings: centered, reference size and timing */
.novo-hero--centered .hero-ring  { width: 720px;  height: 720px;  left: 50%; border: 1px solid rgba(245,109,13,.10); animation-duration: 6s; }
.novo-hero--centered .hero-ring2 { width: 1080px; height: 1080px; left: 50%; border: 1px solid rgba(245,109,13,.05); animation-duration: 6s; animation-delay: .8s; }

/* Orbs: reference spec (smaller, more opaque, blurred with floatOrb) */
.novo-hero--centered.novo-hero .hero-orb { filter: blur(60px); }
.novo-hero--centered .hero-orb-1 {
  width: 300px; height: 300px;
  background: var(--novo-orange); opacity: .35;
  top: -60px; right: -40px;
  animation: floatOrb 8s ease-in-out infinite;
}
.novo-hero--centered .hero-orb-2 {
  width: 200px; height: 200px;
  background: #1A6090; opacity: .35;
  bottom: 80px; left: -40px;
  animation: floatOrb 8s ease-in-out infinite -3s;
}

/* Scroll hint */
.novo-hero--centered .hero-scroll {
  position: absolute; bottom: 36px; left: 50%; transform: translateX(-50%);
  z-index: 2; display: flex; flex-direction: column; align-items: center; gap: 8px;
  color: rgba(255,255,255,.35); font-size: 11px; font-weight: 600;
  letter-spacing: 2px; text-transform: uppercase;
  animation: fadeIn 1s ease 1s both;
}
.novo-hero--centered .hero-scroll-line {
  width: 1px; height: 40px;
  background: linear-gradient(to bottom, rgba(255,255,255,.3), transparent);
  animation: scrollLine 2s ease infinite;
}

@media (max-width: 768px) {
  .novo-hero--centered { padding: 80px 20px 120px; }
}
/* ─── End centered hero ───────────────────────────────────────────────────── */

/* ═══════════════════════════════════════════════
   BRAND MARQUEE WIDGET
═══════════════════════════════════════════════ */

.novo-brand-marquee-wrap {
  background: #fff;
  border-top: 1px solid var(--novo-border);
  border-bottom: 1px solid var(--novo-border);
  overflow: hidden;
  display: flex;
  align-items: center;
}

.novo-brand-marquee-eyebrow {
  flex-shrink: 0;
  padding: 26px 36px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--novo-grey-tx);
  border-right: 1px solid var(--novo-border);
  white-space: nowrap;
  display: flex;
  align-items: center;
}

.novo-brand-marquee-outer {
  overflow: hidden;
  flex: 1;
}

.novo-brand-marquee-track {
  display: flex;
  gap: 0;
  width: max-content;
  animation: marquee 28s linear infinite;
  list-style: none;
  margin: 0; padding: 0;
}

.novo-brand-marquee-track:hover {
  animation-play-state: paused;
}

.novo-brand-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 22px 44px;
  border-right: 1px solid var(--novo-border);
  font-size: 15px;
  font-weight: 800;
  color: #c4cdd5;
  letter-spacing: -.3px;
  transition: color .25s;
  cursor: default;
  white-space: nowrap;
}

.novo-brand-item:hover { color: var(--novo-navy); }

/* ═══════════════════════════════════════════════
   MODALITY GRID WIDGET
═══════════════════════════════════════════════ */

.novo-modality-grid {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  border-top: 1px solid var(--novo-border);
}

.novo-modality-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 24px 10px 22px;
  border-left: 1px solid var(--novo-border);
  cursor: pointer;
  text-decoration: none;
  position: relative;
  transition: background .25s;
  color: var(--novo-navy);
}

.novo-modality-item:first-child { border-left: none; }

.novo-modality-item:hover { background: rgba(245,109,13,.032); }

.novo-modality-item .mod-icon {
  width: 56px; height: 56px;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  color: var(--novo-navy);
  background: rgba(11,57,84,.06);
  border: 1.5px solid var(--novo-border);
  margin-bottom: 13px;
  transition: all .3s cubic-bezier(.22,.68,0,1.3);
}

.novo-modality-item:hover .mod-icon {
  background: var(--novo-orange);
  border-color: var(--novo-orange);
  color: #fff;
  transform: translateY(-6px);
  box-shadow: 0 14px 32px rgba(245,109,13,.36);
}

.novo-modality-item .mod-name {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .8px;
  color: var(--novo-navy);
  text-align: center;
  line-height: 1.4;
}

.novo-modality-item::after {
  content: '';
  position: absolute;
  bottom: 8px; left: 50%;
  transform: translateX(-50%) scaleX(0);
  width: 28px; height: 2px;
  background: var(--novo-orange);
  border-radius: 1px;
  transition: transform .3s;
}

.novo-modality-item:hover::after {
  transform: translateX(-50%) scaleX(1);
}

/* ═══════════════════════════════════════════════
   EQUIPMENT CATEGORY CARDS WIDGET
═══════════════════════════════════════════════ */

.novo-category-grid {
  display: grid;
  grid-template-columns: repeat(var(--eq-cat-cols, 4), 1fr);
  gap: 26px;
}

.novo-category-card {
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid var(--novo-border);
  position: relative;
  background: var(--novo-grey-bg);
  box-shadow: var(--novo-shadow-sm);
  transition: transform .35s cubic-bezier(.22,.68,0,1.2), box-shadow .35s;
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: var(--novo-navy);
}

.novo-category-card:hover {
  transform: translateY(-9px);
  box-shadow: 0 32px 80px rgba(11,57,84,.14);
}

/* ═══════════════════════════════════════════════
   EQUIPMENT CARD WIDGET
═══════════════════════════════════════════════ */

.novo-equipment-card {
  background: #fff;
  border-radius: var(--novo-radius-card);
  overflow: hidden;
  border: 1px solid var(--novo-border);
  box-shadow: var(--novo-shadow-card);
  display: flex;
  flex-direction: column;
  transition: transform .32s cubic-bezier(.22,.68,0,1.2), box-shadow .32s, border-color .32s;
}

.novo-equipment-card:hover {
  transform: translateY(-7px);
  box-shadow: var(--novo-shadow-hover);
  border-color: rgba(245,109,13,.22);
}

.novo-availability-dot {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: 4px 12px;
  border-radius: var(--novo-radius-pill);
}

.novo-availability-dot.in-stock {
  background: rgba(31,164,99,.18);
  border: 1px solid rgba(31,164,99,.36);
  color: #5de6a3;
}

.novo-availability-dot.pending {
  background: rgba(245,109,13,.18);
  border: 1px solid rgba(245,109,13,.35);
  color: var(--novo-orange-lite);
}

.novo-availability-dot.sold {
  background: rgba(122,144,160,.14);
  border: 1px solid rgba(122,144,160,.28);
  color: rgba(200,210,220,.80);
}

/* ═══════════════════════════════════════════════
   SPARE PARTS CARD WIDGET
═══════════════════════════════════════════════ */

.novo-parts-card {
  background: #fff;
  border-radius: var(--novo-radius-card);
  border: 1px solid var(--novo-border);
  box-shadow: var(--novo-shadow-card);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .32s cubic-bezier(.22,.68,0,1.2), box-shadow .32s;
}

.novo-parts-card:hover {
  transform: translateY(-7px);
  box-shadow: var(--novo-shadow-hover);
}

.parts-card-img-link { display: block; aspect-ratio: 4 / 3; overflow: hidden; }
.parts-card-img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s; }
.novo-parts-card:hover .parts-card-img:not(.parts-card-img-placeholder) { transform: scale(1.05); }
.parts-card-img-placeholder { display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, #0b3954, #1a6090); color: rgba(255,255,255,.35); font-size: 44px; }
.parts-card-body { padding: 18px 18px 20px; display: flex; flex-direction: column; flex: 1; gap: 8px; }
.parts-card-modality { align-self: flex-start; }
.parts-card-pn { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.2px; color: var(--novo-orange); }
.parts-card-title { font-size: 15px; font-weight: 800; color: var(--novo-navy); letter-spacing: -.3px; line-height: 1.35; margin: 0; }
.parts-card-title a { color: inherit; text-decoration: none; }
.parts-card-title a:hover { color: var(--novo-orange); }
.parts-card-compat { font-size: 12px; color: var(--novo-grey-tx); margin: 0; display: flex; align-items: center; gap: 6px; }
.parts-card-compat i { color: var(--novo-orange); font-size: 11px; flex-shrink: 0; }
.parts-card-badges { display: flex; flex-wrap: wrap; gap: 6px; }
.nvo-spc-cta { margin-top: 16px; }

/* ═══════════════════════════════════════════════
   BLOG CARD GRID WIDGET
═══════════════════════════════════════════════ */

.blog-grid-section { padding: 96px 0; }

.novo-load-more-wrap { text-align: center; margin-top: 48px; }
.novo-load-more { min-width: 220px; }

.novo-blog-grid {
  display: grid;
  grid-template-columns: repeat(var(--blog-cols, 3), 1fr);
  gap: 24px;
}
/* data-cols drives desktop column count (no inline style = responsive media queries work) */
.novo-blog-grid[data-cols="1"] { --blog-cols: 1; }
.novo-blog-grid[data-cols="2"] { --blog-cols: 2; }
.novo-blog-grid[data-cols="3"] { --blog-cols: 3; }
.novo-blog-grid[data-cols="4"] { --blog-cols: 4; }

.novo-blog-card {
  background: var(--novo-white);
  border-radius: var(--novo-radius-card);
  overflow: hidden;
  border: 1px solid var(--novo-border);
  box-shadow: var(--novo-shadow-card);
  display: flex;
  flex-direction: column;
  transition: transform .35s cubic-bezier(.22,.68,0,1.2), box-shadow .35s, border-color .35s;
}

.novo-blog-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--novo-shadow-hover);
  border-color: rgba(245,109,13,.22);
}

.novo-blog-card .blog-card-img-link {
  display: block;
  aspect-ratio: 16 / 9;
  overflow: hidden;
}

.novo-blog-card .blog-card-img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .35s;
}

.novo-blog-card:hover .blog-card-img { transform: scale(1.06); }

.novo-blog-card .blog-card-body {
  padding: 22px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.novo-blog-card .blog-card-title {
  font-size: 16px;
  font-weight: 800;
  color: var(--novo-navy);
  line-height: 1.3;
  margin-bottom: 10px;
  letter-spacing: -.3px;
  transition: color .2s;
}

.novo-blog-card:hover .blog-card-title,
.novo-blog-card .blog-card-title a:hover { color: var(--novo-orange); }

.novo-blog-card .blog-card-excerpt {
  font-size: 13.5px;
  color: var(--novo-grey-tx);
  line-height: 1.65;
  margin-bottom: 16px;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.novo-blog-card .blog-card-meta {
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px solid var(--novo-border);
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.novo-blog-card .meta-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  font-weight: 600;
  color: var(--novo-grey-tx);
}

.novo-blog-card .meta-chip i { color: var(--novo-orange); font-size: 10px; }

.novo-blog-card .btn-link {
  margin-top: 14px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 700;
  color: var(--novo-orange);
  text-decoration: none;
  transition: gap .2s;
}

.novo-blog-card:hover .btn-link { gap: 10px; }

/* Blog card image overlay badges + fallback thumbnail */
.novo-blog-card .blog-card-img-link { position: relative; }

.novo-blog-card .bcat {
  position: absolute;
  top: 10px; left: 10px;
  z-index: 2;
  background: rgba(255,255,255,.14);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.22);
  color: rgba(255,255,255,.92);
  font-size: 9.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  padding: 4px 10px;
  border-radius: 10px;
}

.novo-blog-card .brt {
  position: absolute;
  bottom: 8px; right: 8px;
  z-index: 2;
  background: rgba(11,57,84,.60);
  color: rgba(255,255,255,.85);
  font-size: 10px;
  font-weight: 600;
  padding: 3px 9px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  gap: 4px;
}
.novo-blog-card .brt i { color: var(--novo-orange); font-size: 9px; }

.novo-blog-card .blog-thumb-fallback {
  width: 100%; height: 100%;
  background: linear-gradient(135deg, var(--novo-navy) 0%, var(--novo-navy-dark) 100%);
}

.novo-view-all-wrap {
  text-align: center;
  margin-top: 44px;
}

/* ═══════════════════════════════════════════════
   NEWSLETTER SIGNUP WIDGET
   Matches home-preview.html .newsletter-section
═══════════════════════════════════════════════ */

.newsletter-section { padding: 96px 0; background: #fff; }
.newsletter-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: center;
}
.nl-left .title { font-size: clamp(28px, 3.8vw, 44px); }
.nl-bullets {
  list-style: none;
  margin-top: 28px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 0;
}
.nl-bullets li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  font-weight: 600;
  color: var(--novo-grey-tx, #7A90A0);
}
.nl-bullets li i,
.nl-bullets li svg { color: var(--novo-orange, #F56D0D); font-size: 12px; width: 14px; }
.nl-right {
  background: #fff;
  border-radius: 22px;
  border: 1px solid var(--novo-border, #E8EDF3);
  padding: 36px 32px;
  box-shadow: 0 8px 40px var(--novo-shadow, rgba(11,57,84,.07));
}
.nl-right h4 {
  font-size: 17px;
  font-weight: 800;
  color: var(--novo-navy, #0B3954);
  margin-bottom: 6px;
  letter-spacing: -.3px;
}
.nl-right > p {
  font-size: 13.5px;
  color: var(--novo-grey-tx, #7A90A0);
  margin-bottom: 24px;
  line-height: 1.65;
}
.nl-checks {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 24px;
}
.nl-check {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  color: var(--novo-navy, #0B3954);
  font-weight: 500;
  cursor: pointer;
}
.nl-check input[type=checkbox] {
  accent-color: var(--novo-orange, #F56D0D);
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  cursor: pointer;
}
.nl-fields {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 14px;
}
.nl-input {
  width: 100%;
  padding: 13px 16px;
  border: 1px solid var(--novo-border, #E8EDF3);
  border-radius: 10px;
  font-size: 14px;
  font-family: var(--novo-font, 'Inter', sans-serif);
  color: var(--novo-navy, #0B3954);
  background: var(--novo-grey-bg, #F5F7FA);
  outline: none;
  transition: border-color .2s, box-shadow .2s;
}
.nl-input:focus {
  border-color: var(--novo-orange, #F56D0D);
  box-shadow: 0 0 0 3px rgba(245,109,13,.10);
}
.nl-input::placeholder { color: var(--novo-grey-tx, #7A90A0); }
.nl-email-row {
  display: flex;
  gap: 10px;
  margin-bottom: 14px;
}
.nl-email-row .nl-input { flex: 1; }
.nl-submit {
  flex-shrink: 0;
  padding: 13px 24px;
  background: var(--novo-orange, #F56D0D);
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  border: none;
  border-radius: 10px;
  cursor: pointer;
  font-family: var(--novo-font, 'Inter', sans-serif);
  display: flex;
  align-items: center;
  gap: 8px;
  transition: background .2s, transform .2s;
  white-space: nowrap;
}
.nl-submit:hover {
  background: var(--novo-orange2, #DC5F07);
  transform: translateY(-2px);
}
.nl-disclaimer {
  font-size: 12px;
  color: var(--novo-grey-tx, #7A90A0);
  display: flex;
  align-items: center;
  gap: 7px;
  margin-top: 0;
  margin-bottom: 0;
}
.nl-disclaimer i { color: var(--novo-orange, #F56D0D); font-size: 11px; }

@media (max-width: 900px) {
  .newsletter-layout { grid-template-columns: 1fr; gap: 40px; }
}
@media (max-width: 560px) {
  .nl-fields { grid-template-columns: 1fr; }
  .nl-right { padding: 28px 20px; }
}

/* ── Dark / Navy Newsletter (blog page) ─────────────────────────── */
.nl-section {
  background: var(--novo-navy-dark, #071F2E);
  padding: 96px 0;
  position: relative;
  overflow: hidden;
}
.nl-section::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(ellipse at 80% 50%, rgba(245,109,13,.18) 0%, transparent 55%);
}
.nl-section::after {
  content: '';
  position: absolute;
  width: 600px;
  height: 600px;
  border: 1px solid rgba(245,109,13,.06);
  border-radius: 50%;
  top: 50%;
  right: -120px;
  transform: translateY(-50%);
  pointer-events: none;
}
.nl-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 460px;
  gap: 72px;
  align-items: center;
}
.nl-eyebrow {
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 3px;
  color: var(--novo-orange-light, #FF9A4D);
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.nl-title {
  font-size: clamp(26px, 3.5vw, 38px);
  font-weight: 900;
  color: #fff;
  line-height: 1.15;
  letter-spacing: -.8px;
  margin-bottom: 14px;
}
.nl-title span { color: var(--novo-orange, #F56D0D); }
.nl-sub {
  font-size: 15px;
  color: rgba(255,255,255,.52);
  line-height: 1.80;
  margin-bottom: 26px;
}
.nl-perks {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.nl-perk {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 13px;
  font-weight: 600;
  color: rgba(255,255,255,.58);
}
.nl-perk i, .nl-perk svg {
  color: var(--novo-orange, #F56D0D);
  font-size: 12px;
  width: 14px;
  flex-shrink: 0;
}
.nl-card {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 22px;
  padding: 32px;
  backdrop-filter: blur(10px);
}
.nl-card-title {
  font-size: 14px;
  font-weight: 800;
  color: #fff;
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 22px;
}
.nl-card-title i { color: var(--novo-orange-light, #FF9A4D); }
.nl-label {
  display: block;
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  color: rgba(255,255,255,.40);
  margin-bottom: 5px;
}
.nl-section .nl-input {
  width: 100%;
  padding: 12px 14px;
  margin-bottom: 12px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 10px;
  font-size: 13.5px;
  font-family: var(--novo-font, 'Inter', sans-serif);
  color: #fff;
  outline: none;
  transition: border-color .2s, background .2s;
  box-sizing: border-box;
}
.nl-section .nl-input::placeholder { color: rgba(255,255,255,.28); }
.nl-section .nl-input:focus {
  border-color: var(--novo-orange, #F56D0D);
  background: rgba(255,255,255,.10);
}
.nl-consent {
  font-size: 11px;
  color: rgba(255,255,255,.38);
  display: flex;
  align-items: flex-start;
  gap: 7px;
  margin-bottom: 16px;
  line-height: 1.55;
  cursor: pointer;
}
.nl-consent input { accent-color: var(--novo-orange, #F56D0D); flex-shrink: 0; margin-top: 2px; }
.nl-consent a { color: var(--novo-orange-light, #FF9A4D); text-decoration: underline; }
.nl-submit-full {
  width: 100%;
  justify-content: center;
  border-radius: 10px;
}
@media (max-width: 960px) {
  .nl-inner { grid-template-columns: 1fr; gap: 48px; }
}
@media (max-width: 560px) {
  .nl-card { padding: 24px 20px; }
}

/* ═══════════════════════════════════════════════
   PROCESS TIMELINE WIDGET
═══════════════════════════════════════════════ */

.novo-process-wrap { position: relative; }

/* Dark scheme (default — no --light modifier) matches source .process-section */
.novo-process-wrap:not(.novo-process-wrap--light):not(.novo-process-wrap--steps-visual) {
  padding: 112px 0;
  background: var(--novo-navy-dark, #071F2E);
  overflow: hidden;
}
.novo-process-wrap:not(.novo-process-wrap--light):not(.novo-process-wrap--steps-visual)::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 50% 130%, rgba(245,109,13,.14) 0%, transparent 55%);
  pointer-events: none;
}
.novo-process-wrap:not(.novo-process-wrap--light):not(.novo-process-wrap--steps-visual)::after {
  content: '';
  position: absolute; inset: 0;
  background-image: radial-gradient(circle, rgba(255,255,255,.024) 1px, transparent 1px);
  background-size: 38px 38px;
  pointer-events: none;
}
/* Dark scheme header overrides — use shared .eyebrow, .title, .sub classes */
.novo-process-wrap:not(.novo-process-wrap--light) .eyebrow { color: var(--novo-orange-lite, #ffb06b); }
.novo-process-wrap:not(.novo-process-wrap--light) .title { color: #fff; }
.novo-process-wrap:not(.novo-process-wrap--light) .title span { color: var(--novo-orange, #F56D0D); }
.novo-process-wrap:not(.novo-process-wrap--light) .sub { color: rgba(255,255,255,.50); }
.novo-process-wrap:not(.novo-process-wrap--light) .accent-bar { background: linear-gradient(90deg, var(--novo-orange, #F56D0D), rgba(245,109,13,.18)); }

/* Steps+Visual variant gets full section padding + white bg to match .process-section in the HTML prototype */
.novo-process-wrap--steps-visual {
  padding: 96px 0;
  background: var(--novo-white, #fff);
}

.novo-timeline {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
  list-style: none;
  padding: 0; margin: 0;
  position: relative;
}

.novo-timeline::before {
  content: '';
  position: absolute;
  top: 54px; left: 12.5%; right: 12.5%;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(245,109,13,.25) 20%, rgba(245,109,13,.25) 80%, transparent 100%);
  pointer-events: none;
}

.novo-timeline--vertical {
  grid-template-columns: 1fr;
  gap: 0;
}

.novo-timeline--vertical::before { display: none; }

.novo-timeline-step {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--novo-radius-card);
  padding: 32px 24px 28px;
  text-align: center;
  position: relative;
  transition: background .3s, border-color .3s;
}

.novo-process-wrap--light .novo-timeline-step {
  background: #fff;
  border-color: var(--novo-border);
  box-shadow: var(--novo-shadow-card);
}

.novo-timeline-step:hover {
  background: rgba(255,255,255,.08);
  border-color: rgba(245,109,13,.28);
}

.novo-process-wrap--light .novo-timeline-step:hover {
  background: #fff;
  box-shadow: var(--novo-shadow-hover);
}

/* Timeline child elements */
.novo-timeline-step .timeline-step-number {
  position: absolute;
  top: -16px; left: 50%;
  transform: translateX(-50%);
  width: 34px; height: 34px;
  border-radius: 50%;
  background: var(--novo-orange, #f56d0d);
  color: #fff;
  font-size: 13px; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 8px 22px rgba(245,109,13,.50);
  z-index: 2;
}

.novo-timeline-step .timeline-icon-wrap {
  width: 60px; height: 60px;
  border-radius: 18px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  color: rgba(255,255,255,.75);
  margin: 14px auto 18px;
}

/* Icon colour variants (cycle by index a→d) */
.novo-timeline-step .timeline-icon-wrap.tiv-a { background: rgba(245,109,13,.16); color: var(--novo-orange-lite, #f9a754); border-color: transparent; }
.novo-timeline-step .timeline-icon-wrap.tiv-b { background: rgba(26,96,144,.22);  color: #7ecce8; border-color: transparent; }
.novo-timeline-step .timeline-icon-wrap.tiv-c { background: rgba(15,163,96,.16);  color: #5de3a0; border-color: transparent; }
.novo-timeline-step .timeline-icon-wrap.tiv-d { background: rgba(255,255,255,.10); color: rgba(255,255,255,.72); border-color: transparent; }

.novo-process-wrap--light .novo-timeline-step .timeline-icon-wrap {
  background: rgba(11,57,84,.06);
  border-color: var(--novo-border);
  color: var(--novo-navy);
}
.novo-process-wrap--light .novo-timeline-step .timeline-icon-wrap.tiv-a { background: rgba(245,109,13,.10); color: var(--novo-orange); border-color: transparent; }
.novo-process-wrap--light .novo-timeline-step .timeline-icon-wrap.tiv-b { background: rgba(26,96,144,.10);  color: #1a6090; border-color: transparent; }
.novo-process-wrap--light .novo-timeline-step .timeline-icon-wrap.tiv-c { background: rgba(15,163,96,.10);  color: #0fa360; border-color: transparent; }
.novo-process-wrap--light .novo-timeline-step .timeline-icon-wrap.tiv-d { background: rgba(11,57,84,.06);   color: var(--novo-grey-tx, #7A90A0); border-color: transparent; }

.novo-timeline-step .timeline-step-title {
  font-size: 15px;
  font-weight: 800;
  color: #fff;
  margin-bottom: 8px;
  letter-spacing: -.2px;
}

.novo-process-wrap--light .novo-timeline-step .timeline-step-title {
  color: var(--novo-navy);
}

.novo-timeline-step .timeline-step-desc {
  font-size: 13px;
  color: rgba(255,255,255,.50);
  line-height: 1.65;
}

.novo-process-wrap--light .novo-timeline-step .timeline-step-desc {
  color: var(--novo-grey-tx);
}

.novo-timeline-step .timeline-connector { display: none; }

/* ═══════════════════════════════════════════════
   PROCESS TIMELINE — Steps + Visual Card layout
   (.novo-process-wrap--steps-visual)
═══════════════════════════════════════════════ */

.novo-process-wrap--steps-visual .novo-process-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: center;
}

.novo-process-steps {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-top: 40px;
}

.novo-step {
  display: flex;
  gap: 22px;
  align-items: flex-start;
  position: relative;
  padding-bottom: 36px;
}
.novo-step:last-child { padding-bottom: 0; }

.novo-step::after {
  content: '';
  position: absolute;
  left: 19px; top: 44px; bottom: 0;
  width: 2px;
  background: linear-gradient(180deg, rgba(245,109,13,.25) 0%, transparent 100%);
}
.novo-step:last-child::after { display: none; }

.novo-step-num {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--novo-orange, #f56d0d);
  color: #fff;
  font-size: 13px; font-weight: 900;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 4px 16px rgba(245,109,13,.35);
}

.novo-step-content { padding-top: 8px; }
.novo-step-title {
  font-size: 16px; font-weight: 800;
  color: var(--novo-navy, #0b3954);
  margin-bottom: 6px; letter-spacing: -.2px;
}
.novo-step-desc {
  font-size: 13.5px;
  color: var(--novo-grey-tx, #6b7a8d);
  line-height: 1.70;
}

/* Right: visual card */
.novo-process-visual { position: relative; }

.novo-pv-card {
  background: linear-gradient(145deg, var(--novo-navy, #0b3954), #071f2e);
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 24px 80px rgba(11,57,84,.30);
  aspect-ratio: 4 / 3;
  display: flex; align-items: center; justify-content: center;
  position: relative;
}
.novo-pv-card::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 70% 20%, rgba(245,109,13,.18) 0%, transparent 55%);
}
.novo-pv-card img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; opacity: .55;
}
.novo-pv-card > i {
  font-size: 80px;
  color: rgba(255,255,255,.08);
  position: relative; z-index: 1;
}

.novo-pv-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(7,31,46,.80) 100%);
  z-index: 1;
}

.novo-pv-badge {
  position: absolute; bottom: 0; left: 0; right: 0;
  z-index: 2;
  padding: 28px;
  display: flex; align-items: flex-end; gap: 16px;
}

.novo-pv-stat { text-align: left; }
.novo-pv-stat strong {
  display: block;
  font-size: 28px; font-weight: 900; color: #fff;
  letter-spacing: -1px;
}
.novo-pv-stat span {
  font-size: 11px; font-weight: 600;
  color: rgba(255,255,255,.45);
  text-transform: uppercase; letter-spacing: 1.5px;
}
.novo-pv-sep {
  width: 1px; height: 40px;
  background: rgba(255,255,255,.15);
  margin: 0 4px;
}

.novo-floating-badge {
  position: absolute;
  top: -20px; right: -20px;
  z-index: 3;
  background: var(--novo-orange, #f56d0d);
  color: #fff;
  border-radius: 16px;
  padding: 14px 18px;
  box-shadow: 0 8px 32px rgba(245,109,13,.45);
  text-align: center;
}
.novo-floating-badge strong {
  display: block;
  font-size: 22px; font-weight: 900; letter-spacing: -1px;
}
.novo-floating-badge span {
  font-size: 10.5px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 1.5px;
  opacity: .80;
}

@media (max-width: 1000px) {
  .novo-process-wrap--steps-visual .novo-process-grid { grid-template-columns: 1fr; gap: 48px; }
  .novo-process-visual { display: none; }
}

/* ═══════════════════════════════════════════════
   FAQ ACCORDION WIDGET
═══════════════════════════════════════════════ */

/* ── Section wrapper padding ── */
.faq-section,
.novo-faq-section {
  padding: 60px 0 100px;
}

/* ── Layout grid (sidebar + main) ── */
.faq-layout {
  display: grid;
  grid-template-columns: var(--faq-sidebar-w, 240px) 1fr;
  gap: 48px;
  align-items: start;
}

/* ── Category sidebar nav ── */
.cat-nav {
  position: sticky;
  top: 24px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.cat-nav-head {
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2.5px;
  color: var(--novo-grey-tx);
  padding: 0 14px 10px;
  border-bottom: 1px solid var(--novo-border);
  margin-bottom: 4px;
}
.cat-nav-item {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 11px 14px;
  border-radius: 12px;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--novo-grey-tx);
  cursor: pointer;
  transition: all .2s;
  border: 1.5px solid transparent;
  background: none;
  font-family: var(--novo-font);
  width: 100%;
  text-align: left;
}
.cat-nav-item:hover { color: var(--novo-navy); background: rgba(11,57,84,.04); }
.cat-nav-item.active {
  background: rgba(245,109,13,.08);
  border-color: rgba(245,109,13,.22);
  color: var(--novo-orange);
}
.cat-nav-item i { font-size: 13px; width: 16px; text-align: center; flex-shrink: 0; }
.cat-nav-count {
  margin-left: auto;
  font-size: 11px;
  font-weight: 700;
  color: var(--novo-grey-tx);
  background: var(--novo-grey-bg);
  border-radius: 20px;
  padding: 2px 8px;
}
.cat-nav-item.active .cat-nav-count { background: rgba(245,109,13,.15); color: var(--novo-orange); }

/* ── Main content area ── */
.faq-main { min-width: 0; }

/* Toolbar */
.faq-toolbar {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 28px;
}
.faq-result-count {
  font-size: 13px;
  font-weight: 600;
  color: var(--novo-grey-tx);
  margin-left: auto;
  white-space: nowrap;
}
.faq-result-count strong { color: var(--novo-navy); }
.toolbar-search {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
  background: #fff;
  border: 1.5px solid var(--novo-border);
  border-radius: 12px;
  padding: 11px 16px;
  min-width: 200px;
  transition: border-color .2s;
}
.toolbar-search:focus-within { border-color: var(--novo-orange); }
.toolbar-search i { color: var(--novo-grey-tx); font-size: 13px; flex-shrink: 0; }
.toolbar-search input {
  flex: 1;
  border: none;
  background: transparent;
  outline: none;
  font-size: 13.5px;
  font-family: var(--novo-font);
  color: var(--novo-navy);
}
.toolbar-search input::placeholder { color: var(--novo-grey-tx); }

/* Category group */
.faq-category-group { margin-bottom: 40px; }
.faq-category-group.hidden { display: none; }
.cat-group-head {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 0 20px;
  border-bottom: 1px solid var(--novo-border);
  margin-bottom: 4px;
}
.cat-group-icon {
  width: 40px; height: 40px;
  border-radius: 11px;
  background: rgba(245,109,13,.09);
  border: 1.5px solid rgba(245,109,13,.20);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  color: var(--novo-orange);
  flex-shrink: 0;
}
.cat-group-title {
  font-size: 18px;
  font-weight: 900;
  color: var(--novo-navy);
  letter-spacing: -.3px;
}
.cat-group-count {
  font-size: 12px;
  font-weight: 700;
  color: var(--novo-grey-tx);
  background: var(--novo-grey-bg);
  border: 1px solid var(--novo-border);
  border-radius: 20px;
  padding: 3px 10px;
  margin-left: auto;
}

/* ── Accordion items ── */
.accordion {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-top: 4px;
}
.acc-item {
  background: #fff;
  border: 1px solid var(--novo-border);
  border-radius: 16px;
  overflow: hidden;
  transition: border-color .25s, box-shadow .25s;
}
.acc-item:hover { border-color: rgba(245,109,13,.18); }
.acc-item.open {
  border-color: rgba(245,109,13,.28);
  box-shadow: 0 4px 24px rgba(245,109,13,.08);
}
.acc-item.hidden { display: none; }

.acc-trigger {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 20px 22px;
  width: 100%;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  font-family: var(--novo-font);
}
.acc-q {
  flex: 1;
  font-size: 15px;
  font-weight: 700;
  color: var(--novo-navy);
  line-height: 1.45;
  transition: color .2s;
}
.acc-item.open .acc-q { color: var(--novo-orange); }
.acc-icon {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--novo-grey-bg);
  border: 1.5px solid var(--novo-border);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background .25s, border-color .25s;
}
.acc-icon i { font-size: 11px; color: var(--novo-grey-tx); transition: color .2s, transform .3s; }
.acc-item.open .acc-icon { background: rgba(245,109,13,.10); border-color: rgba(245,109,13,.28); }
.acc-item.open .acc-icon i { color: var(--novo-orange); transform: rotate(180deg); }

.acc-body { display: none; padding: 0 22px 22px; }
.acc-item.open .acc-body { display: block; }
.acc-answer {
  font-size: 14.5px;
  color: var(--novo-grey-tx);
  line-height: 1.8;
  border-top: 1px solid var(--novo-border);
  padding-top: 18px;
}
.acc-answer strong { color: var(--novo-navy); font-weight: 700; }
.acc-answer a { color: var(--novo-orange); font-weight: 600; text-decoration: underline; }

.acc-helpful {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--novo-border);
  font-size: 12px;
  color: var(--novo-grey-tx);
  font-weight: 600;
}
.helpful-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 12px;
  border-radius: 50px;
  font-size: 12px;
  font-weight: 700;
  border: 1.5px solid var(--novo-border);
  background: #fff;
  color: var(--novo-grey-tx);
  cursor: pointer;
  font-family: var(--novo-font);
  transition: all .2s;
}
.helpful-btn:hover { border-color: var(--novo-orange); color: var(--novo-orange); }
.helpful-btn.voted { background: rgba(15,163,96,.09); border-color: rgba(15,163,96,.28); color: var(--novo-green); }

/* No results */
.no-results-faq {
  text-align: center;
  padding: 72px 24px;
}
.no-results-faq[hidden] { display: none; }
.no-results-faq i { font-size: 48px; color: var(--novo-border); display: block; margin-bottom: 16px; }
.no-results-faq p { font-size: 14px; color: var(--novo-grey-tx); }

/* Contact prompt */
.contact-prompt {
  margin-top: 48px;
  background: #fff;
  border: 1px solid var(--novo-border);
  border-radius: 20px;
  padding: 36px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 28px;
  align-items: center;
  box-shadow: var(--novo-shadow-card);
  position: relative;
  overflow: hidden;
}
.contact-prompt::before {
  content: '';
  position: absolute;
  right: -20px; top: -20px;
  width: 160px; height: 160px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(245,109,13,.06) 0%, transparent 70%);
  pointer-events: none;
}

/* Responsive: sidebar stacks on tablet/mobile */
@media (max-width: 900px) {
  .faq-layout {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .cat-nav {
    position: static;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 8px;
  }
  .cat-nav-head { display: none; }
  .cat-nav-item {
    padding: 8px 14px;
    border-radius: 50px;
    border: 1.5px solid var(--novo-border);
    width: auto;
  }
  .cat-nav-count { display: none; }
  .contact-prompt {
    grid-template-columns: 1fr;
  }
}

.novo-accordion {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.novo-accordion .accordion-item {
  background: #fff;
  border: 1px solid var(--novo-border);
  border-radius: 16px;
  overflow: hidden;
  transition: border-color .25s, box-shadow .25s;
}

.novo-accordion .accordion-item:hover { border-color: rgba(245,109,13,.18); }

.novo-accordion .accordion-item.open {
  border-color: rgba(245,109,13,.28);
  box-shadow: 0 4px 24px rgba(245,109,13,.08);
}

.novo-accordion .accordion-trigger {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 20px 22px;
  width: 100%;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  font-family: var(--novo-font);
}

.novo-accordion .accordion-question {
  flex: 1;
  font-size: 15px;
  font-weight: 700;
  color: var(--novo-navy);
  line-height: 1.45;
  transition: color .2s;
}

.novo-accordion .accordion-item.open .accordion-question { color: var(--novo-orange); }

.novo-accordion .accordion-chevron {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--novo-grey-bg);
  border: 1.5px solid var(--novo-border);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background .25s, border-color .25s;
}

.novo-accordion .accordion-chevron::after {
  content: '+';
  font-size: 18px;
  line-height: 1;
  color: var(--novo-grey-tx);
  transition: color .2s, transform .3s;
  display: block;
}

.novo-accordion .accordion-item.open .accordion-chevron {
  background: rgba(245,109,13,.10);
  border-color: rgba(245,109,13,.28);
}

.novo-accordion .accordion-item.open .accordion-chevron::after {
  color: var(--novo-orange);
  transform: rotate(45deg);
}

.novo-accordion .accordion-panel { padding: 0 22px 22px; }

.novo-accordion .accordion-panel[hidden] { display: none; }

.novo-accordion .accordion-body {
  font-size: 14.5px;
  color: var(--novo-grey-tx);
  line-height: 1.8;
  border-top: 1px solid var(--novo-border);
  padding-top: 18px;
}

.novo-accordion .accordion-body strong { color: var(--novo-navy); font-weight: 700; }
.novo-accordion .accordion-body a { color: var(--novo-orange); font-weight: 600; text-decoration: underline; }

/* ═══════════════════════════════════════════════
   TESTIMONIAL SLIDER WIDGET
═══════════════════════════════════════════════ */

/* Phase 3 — --ts-per-view previously owned by Elementor per_view control */
.ts-slider-wrap { position: relative; --ts-per-view: 3; }

.ts-track-outer {
  overflow: hidden;
  border-radius: 24px;
}

.ts-track {
  display: flex;
  transition: transform .55s cubic-bezier(.4,0,.2,1);
  will-change: transform;
}

.trust-card {
  flex: 0 0 calc(33.333% - 16px);
  margin: 0 8px;
  background: #fff;
  border-radius: 22px;
  border: 1px solid var(--novo-border);
  padding: 32px 28px;
  box-shadow: var(--novo-shadow-card);
  position: relative;
  overflow: hidden;
  transition: transform .3s, box-shadow .3s;
  display: flex;
  flex-direction: column;
}

.trust-card:hover { transform: translateY(-6px); box-shadow: 0 24px 64px rgba(11,57,84,.12); }

.trust-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--novo-orange), var(--novo-orange-lite));
  opacity: 0;
  transition: opacity .3s;
}

.trust-card:hover::before { opacity: 1; }

.trust-stars { display: flex; gap: 3px; margin-bottom: 18px; }
.trust-stars i { color: #FBBF24; font-size: 13px; }

.trust-quote-icon { font-size: 28px; color: rgba(245,109,13,.14); margin-bottom: 10px; display: block; }

.trust-card blockquote {
  font-size: 14.5px;
  color: var(--novo-navy);
  line-height: 1.78;
  margin-bottom: 22px;
  font-style: italic;
  flex: 1;
}

.trust-author {
  display: flex;
  align-items: center;
  gap: 13px;
  padding-top: 18px;
  border-top: 1px solid var(--novo-border);
}

.ta-avatar {
  width: 44px; height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  font-weight: 800;
  color: #fff;
  flex-shrink: 0;
  object-fit: cover;
}

.ava-a { background: linear-gradient(135deg, var(--novo-navy), var(--novo-navy-mid, #1a6090)); }
.ava-b { background: linear-gradient(135deg, var(--novo-orange), var(--novo-orange-lite)); }
.ava-c { background: linear-gradient(135deg, #2e9e6a, #48d495); }
.ava-d { background: linear-gradient(135deg, #5a3ec8, #9b6ff5); }
.ava-e { background: linear-gradient(135deg, #c82b3e, #f07589); }
.ava-f { background: linear-gradient(135deg, #0d7a5e, #3dd6aa); }

.ta-name { font-size: 14px; font-weight: 800; color: var(--novo-navy); }
.ta-role { font-size: 12.5px; color: var(--novo-grey-tx); }

/* Navigation arrows */
.ts-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  width: 48px; height: 48px;
  border-radius: 50%;
  background: #fff;
  border: 1px solid var(--novo-border);
  box-shadow: 0 4px 18px rgba(11,57,84,.10);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  color: var(--novo-navy);
  transition: background .2s, color .2s, box-shadow .2s, transform .2s;
}

.ts-arrow:hover {
  background: var(--novo-orange);
  color: #fff;
  border-color: var(--novo-orange);
  box-shadow: 0 8px 28px rgba(245,109,13,.36);
  transform: translateY(-50%) scale(1.08);
}

.ts-prev { left: -28px; }
.ts-next { right: -28px; }

/* Dots */
.ts-dots { display: flex; justify-content: center; gap: 8px; margin-top: 36px; }

.ts-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--novo-border);
  border: none;
  padding: 0;
  cursor: pointer;
  transition: background .3s, width .3s, border-radius .3s;
}

.ts-dot.active { background: var(--novo-orange); width: 28px; border-radius: 4px; }

/* Counter */
.ts-counter { text-align: center; margin-top: 14px; font-size: 12px; font-weight: 600; color: var(--novo-grey-tx); }
.ts-counter strong { color: var(--novo-navy); }

@media (max-width: 900px) {
  .trust-card { flex: 0 0 calc(50% - 16px); }
  .ts-prev { left: -16px; }
  .ts-next { right: -16px; }
}

@media (max-width: 580px) {
  .trust-card { flex: 0 0 calc(100% - 16px); }
}

/* ═══════════════════════════════════════════════
   TRUST STRIP — Trade-In variant
═══════════════════════════════════════════════ */

/* trust-section bg/padding removed — Elementor container handles it via :has() */

.tradein-trust-card {
  background: #fff;
  border-radius: 22px;
  box-shadow: 0 24px 80px rgba(11,57,84,.13);
  margin: -60px 0 0;
  display: flex;
  overflow: hidden;
  position: relative;
  z-index: 10;
}

.tradein-trust-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--novo-orange), var(--novo-orange-lite, #f98d46), var(--novo-orange));
  border-radius: 22px 22px 0 0;
}

.trust-item {
  flex: 1;
  text-align: center;
  padding: 34px 20px;
  border-left: 1px solid var(--novo-border);
  position: relative;
  transition: background .3s;
}

.trust-item:first-child { border-left: none; }

.trust-item::after {
  content: '';
  position: absolute;
  bottom: 0; left: 50%;
  transform: translateX(-50%) scaleX(0);
  width: 40px; height: 3px;
  background: var(--novo-orange);
  border-radius: 2px;
  transition: transform .35s;
}

.trust-item:hover::after { transform: translateX(-50%) scaleX(1); }
.trust-item:hover { background: rgba(245,109,13,.02); }

.trust-icon {
  width: 44px; height: 44px;
  border-radius: 12px;
  background: rgba(245,109,13,.10);
  border: 1px solid rgba(245,109,13,.18);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  color: var(--novo-orange);
  margin: 0 auto 12px;
}

.trust-label { font-size: 14px; font-weight: 800; color: var(--novo-navy); margin-bottom: 4px; }
.trust-sub   { font-size: 12px; color: var(--novo-grey-tx); line-height: 1.5; max-width: 130px; margin: 0 auto; }

@media (max-width: 768px) {
  .tradein-trust-card { flex-wrap: wrap; }
  .tradein-trust-card .trust-item { min-width: 50%; }
}

/* ═══════════════════════════════════════════════
   TRUST STRIP — Services Row variant (.trust-row)
   Used on: Services page trust bar
═══════════════════════════════════════════════ */

/* Override .trust-section padding/bg when wrapping the services-row layout */
.trust-section:has(.trust-row) {
  padding: 28px 0;
  background: var(--novo-white, #fff);
  border-top: 1px solid var(--novo-border);
  border-bottom: 1px solid var(--novo-border);
}

/* Testimonials grid / slider mode — grey bg + 96px padding matching .testimonials-section */
.trust-section:has(.tests-grid),
.trust-section:has(.ts-slider-wrap) {
  padding: 96px 0;
  background: var(--novo-grey-bg, #F7F8FA);
}
.trust-section:has(.tests-grid) .reveal,
.trust-section:has(.ts-slider-wrap) .reveal {
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
}

.trust-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0;
}

/* Horizontal icon + text layout for services-row trust items */
.trust-row .trust-item {
  flex: 0 1 auto;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 40px;
  border-right: 1px solid var(--novo-border);
  border-left: none;
  text-align: left;
}
.trust-row .trust-item:last-child { border-right: none; }

/* Suppress the orange bottom-line hover effect from trade-in variant */
.trust-row .trust-item::after { display: none; }
.trust-row .trust-item:hover  { background: transparent; }

/* Icon */
.trust-row .trust-item > i,
.trust-row .trust-item > svg {
  font-size: 22px;
  color: var(--novo-orange);
  flex-shrink: 0;
}

/* Text block */
.trust-row .trust-item strong {
  font-size: 14px;
  font-weight: 800;
  color: var(--novo-navy);
  display: block;
}
.trust-row .trust-item span {
  font-size: 12px;
  color: var(--novo-grey-tx);
}

@media (max-width: 720px) {
  .trust-row .trust-item {
    padding: 12px 20px;
    border-right: none;
    border-bottom: 1px solid var(--novo-border);
    width: 100%;
  }
  .trust-row .trust-item:last-child { border-bottom: none; }
}

/* ═══════════════════════════════════════════════
   STATS COUNTER WIDGET
═══════════════════════════════════════════════ */

.value-stats {
  display: grid;
  grid-template-columns: repeat(var(--stats-cols, 4), 1fr);
  margin-top: 36px;
  overflow: hidden;
  border-radius: var(--novo-radius-card);
  border: 1px solid var(--novo-border);
  background: #fff;
  box-shadow: var(--novo-shadow-card);
  position: relative;
}

.value-stats::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--novo-orange), var(--novo-orange-lite), var(--novo-orange));
  border-radius: var(--novo-radius-card) var(--novo-radius-card) 0 0;
}

.novo-stats--dark {
  background: var(--novo-navy-dark);
  border-color: rgba(255,255,255,.08);
}

.vstat {
  text-align: center;
  padding: 24px 16px;
  border-left: 1px solid var(--novo-border);
  position: relative;
  transition: background .3s;
}

.novo-stats--dark .vstat { border-color: rgba(255,255,255,.07); }
.vstat:first-child { border-left: none; }
.vstat:hover { background: rgba(245,109,13,.02); }

.vstat .stat-icon {
  font-size: 24px;
  color: var(--novo-orange);
  margin-bottom: 12px;
}

.vstat-num {
  font-size: 32px;
  font-weight: 900;
  color: var(--novo-navy);
  letter-spacing: -1.5px;
  line-height: 1;
  margin-bottom: 6px;
}

.novo-stats--dark .vstat-num { color: #fff; }

.vstat-num span:not(.novo-counter) {
  font-size: 22px;
  font-weight: 900;
  color: var(--novo-orange);
}

.vstat-label {
  font-size: 11.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--novo-grey-tx);
}

.novo-stats--dark .vstat-label { color: rgba(255,255,255,.45); }

@media (max-width: 580px) {
  .value-stats { --stats-cols: 1; }
  .vstat { border-left: none; border-top: 1px solid var(--novo-border); }
  .vstat:first-child { border-top: none; }
}

/* ═══════════════════════════════════════════════
   ABOUT — TRUST BAR SECTION
   Wrapper applied as Elementor section CSS class.
   Uses widget-novo-stats-counter inside; overrides
   its default centered layout to the horizontal
   icon-left style shown in the About page mockup.
═══════════════════════════════════════════════ */

/* ── Outer section: grey fill, padding, card overlap ── */
.trust-bar-section {
  background: var(--novo-grey-bg);
  padding: 0 0 72px;
}

/* Lift card over hero bottom edge (hero has 140px bottom padding) */
.trust-bar-section .value-stats {
  margin-top: -60px;
  position: relative;
  z-index: 10;
}

/* The stats-counter section header is unused on the trust bar */
.trust-bar-section .novo-section-header { display: none; }

/* ── Horizontal layout per cell: icon left, number+label stacked right ── */
.trust-bar-section .vstat {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: auto auto;
  column-gap: 16px;
  align-items: center;
  text-align: left;
  padding: 28px;
}

.trust-bar-section .vstat .stat-icon {
  grid-column: 1;
  grid-row: 1 / 3;
  width: 46px;
  height: 46px;
  background: rgba(245, 109, 13, .10);
  color: var(--novo-orange);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
  margin-bottom: 0;
  transition: background .3s, color .3s;
}

.trust-bar-section .vstat:hover .stat-icon {
  background: var(--novo-orange);
  color: #fff;
}

.trust-bar-section .vstat-num {
  grid-column: 2;
  grid-row: 1;
  font-size: 30px;
  margin-bottom: 0;
  letter-spacing: -1px;
}

.trust-bar-section .vstat-label {
  grid-column: 2;
  grid-row: 2;
  text-transform: none;
  letter-spacing: 0;
  font-size: 12.5px;
  font-weight: 500;
  margin-top: 4px;
}

/* ── Responsive ── */
@media (max-width: 900px) {
  .trust-bar-section .value-stats { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 580px) {
  .trust-bar-section .value-stats { grid-template-columns: 1fr; }
  .trust-bar-section .vstat {
    border-left: none;
    border-top: 1px solid var(--novo-border);
  }
  .trust-bar-section .vstat:first-child { border-top: none; }
}

/* ═══════════════════════════════════════════════
   SERVICES GRID WIDGET
   Three layout modes matching all HTML prototypes
═══════════════════════════════════════════════ */

/* Services grid widget: section-level top/bottom padding.
   NOTE: the global .elementor-element .elementor-widget-container { padding:0 !important } rule
   overrides widget-container rules, so we target the Elementor section instead. */
.elementor-section:has(.services-grid),
.e-con:has(.services-grid) {
  padding-top: 96px !important;
  padding-bottom: 96px !important;
}

/* ── grid-3: Services page — 3-col vertical cards with features ── */
.services-grid--3col {
  display: grid;
  grid-template-columns: repeat(var(--svc3-cols, 3), 1fr);
  gap: 24px;
  margin-top: 52px;
}

.services-grid--3col .service-card {
  background: var(--novo-white);
  border: 1px solid var(--novo-border);
  border-radius: 22px;
  padding: 36px 30px;
  display: flex;
  flex-direction: column;
  box-shadow: var(--novo-shadow-card);
  transition: transform .3s cubic-bezier(.22,.68,0,1.2), box-shadow .3s, border-color .3s;
  position: relative;
  overflow: hidden;
}

.services-grid--3col .service-card::before {
  content: '';
  position: absolute;
  right: -30px; top: -30px;
  width: 120px; height: 120px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(245,109,13,.07) 0%, transparent 70%);
  pointer-events: none;
  transition: opacity .3s;
}

.services-grid--3col .service-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 22px 64px rgba(11,57,84,.14);
  border-color: rgba(245,109,13,.22);
}

.services-grid--3col .service-card.featured {
  background: linear-gradient(145deg, var(--novo-navy), var(--novo-navy-dark));
  border-color: rgba(245,109,13,.25);
}

.services-grid--3col .service-card.featured .sc-icon {
  background: rgba(245,109,13,.18);
  border-color: rgba(245,109,13,.35);
  color: var(--novo-orange-lite);
}

.services-grid--3col .service-card.featured .sc-title { color: #fff; }
.services-grid--3col .service-card.featured .sc-desc  { color: rgba(255,255,255,.50); }

.services-grid--3col .service-card.featured .sc-feature {
  color: rgba(255,255,255,.60);
  border-color: rgba(255,255,255,.10);
}

.services-grid--3col .service-card.featured .sc-feature i { color: var(--novo-orange); }
.services-grid--3col .service-card.featured .sc-link     { color: var(--novo-orange-lite); }

.services-grid--3col .sc-icon-wrap { margin-bottom: 24px; }

.services-grid--3col .sc-icon {
  width: 60px; height: 60px;
  border-radius: 16px;
  background: rgba(245,109,13,.08);
  border: 1.5px solid rgba(245,109,13,.18);
  display: flex; align-items: center; justify-content: center;
  font-size: 22px;
  color: var(--novo-orange);
  transition: transform .3s;
}

.services-grid--3col .service-card:hover .sc-icon { transform: scale(1.1) rotate(-4deg); }

.services-grid--3col .sc-tag {
  display: inline-block;
  font-size: 9.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  padding: 3px 10px;
  border-radius: 20px;
  background: rgba(245,109,13,.09);
  border: 1px solid rgba(245,109,13,.20);
  color: var(--novo-orange);
  margin-bottom: 14px;
}
/* Featured (dark navy) card — make the tag badge more visible against the dark background */
.services-grid--3col .service-card.featured .sc-tag {
  background: rgba(245,109,13,.22);
  border-color: rgba(245,109,13,.45);
}

.services-grid--3col .sc-title {
  font-size: 20px;
  font-weight: 900;
  color: var(--novo-navy);
  letter-spacing: -.4px;
  line-height: 1.25;
  margin-bottom: 10px;
}

.services-grid--3col .sc-desc {
  font-size: 13.5px;
  color: var(--novo-grey-tx);
  line-height: 1.75;
  margin-bottom: 22px;
}

.services-grid--3col .sc-features {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 28px;
}

.services-grid--3col .sc-feature {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 13px;
  font-weight: 600;
  color: var(--novo-grey-tx);
  padding-bottom: 8px;
  border-bottom: 1px solid var(--novo-border);
}

.services-grid--3col .sc-feature:last-child { border-bottom: none; padding-bottom: 0; }

.services-grid--3col .sc-feature i {
  font-size: 11px;
  color: var(--novo-green);
  width: 16px;
  flex-shrink: 0;
}

.services-grid--3col .sc-link {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 13px;
  font-weight: 700;
  color: var(--novo-orange);
  margin-top: auto;
  cursor: pointer;
  transition: gap .2s;
  text-decoration: none;
}

.services-grid--3col .sc-link:hover { gap: 11px; }

/* ── grid-2: About page — 2-col horizontal flex cards ── */
.services-grid--2col {
  display: grid;
  grid-template-columns: repeat(var(--svc2-cols, 2), 1fr);
  gap: 28px;
}

.services-grid--2col .service-card {
  display: flex;
  gap: 24px;
  background: var(--novo-grey-bg);
  border-radius: 20px;
  padding: 32px;
  transition: background .3s, box-shadow .3s, transform .3s;
  position: relative;
  overflow: hidden;
}

.services-grid--2col .service-card::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
  background: var(--novo-orange);
  border-radius: 0 4px 4px 0;
  transform: scaleY(0);
  transform-origin: bottom;
  transition: transform .35s;
}

.services-grid--2col .service-card:hover::before { transform: scaleY(1); }

.services-grid--2col .service-card:hover {
  background: var(--novo-white);
  box-shadow: 0 16px 56px var(--novo-shadow);
  transform: translateX(6px);
}

.services-grid--2col .service-icon {
  width: 56px; height: 56px;
  background: rgba(245,109,13,.10);
  color: var(--novo-orange);
  border-radius: 16px;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
  transition: background .3s, color .3s;
}

.services-grid--2col .service-card:hover .service-icon {
  background: var(--novo-orange);
  color: #fff;
}

.services-grid--2col .service-body h4 {
  font-size: 16px;
  font-weight: 800;
  color: var(--novo-navy);
  margin-bottom: 8px;
}

.services-grid--2col .service-body p {
  font-size: 14px;
  color: var(--novo-grey-tx);
  line-height: 1.7;
}

/* Services grid (About page) — white section background + padding override.
   Padding is applied ONLY to the outermost wrapper to avoid double-stacking:
   - .elementor-section  (legacy sections)
   - .e-con              (new Elementor containers)
   The inner .elementor-container must NOT get padding — only background if needed. */
.elementor-section:has(.services-grid--2col) {
  background: var(--novo-white, #fff) !important;
  padding-top: 96px !important;
  padding-bottom: 96px !important;
}
.e-con:has(.services-grid--2col) {
  background: var(--novo-white, #fff) !important;
  padding-top: 96px !important;
  padding-bottom: 96px !important;
}
/* Force section header centred — target widget-container directly to beat Elementor inline styles */
.elementor-widget-container:has(.services-grid--2col) .section-header {
  text-align: center !important;
  margin-bottom: 56px !important;
}
.elementor-widget-container:has(.services-grid--2col) .section-header .eyebrow,
.elementor-widget-container:has(.services-grid--2col) .section-header .s-eyebrow,
.elementor-widget-container:has(.services-grid--2col) .section-header .section-title,
.elementor-widget-container:has(.services-grid--2col) .section-header .s-title {
  text-align: center !important;
}
.elementor-widget-container:has(.services-grid--2col) .section-header .s-divider,
.elementor-widget-container:has(.services-grid--2col) .section-header .section-sub,
.elementor-widget-container:has(.services-grid--2col) .section-header .s-sub {
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Value-cards section — padding (about page) */
.e-con:has(.values-grid),
.elementor-section:has(.values-grid) {
  padding-top: 96px !important;
  padding-bottom: 96px !important;
}

/* ── grid-4: Home page — 4-col compact svc-cards ── */
.svc-grid {
  display: grid;
  grid-template-columns: repeat(var(--svc4-cols, 4), 1fr);
  gap: 22px;
}

.svc-card {
  background: var(--novo-white);
  border-radius: 20px;
  border: 1px solid var(--novo-border);
  padding: 32px 24px;
  box-shadow: var(--novo-shadow-card);
  position: relative;
  overflow: hidden;
  transition: transform .32s cubic-bezier(.22,.68,0,1.2), box-shadow .32s, border-color .32s;
}

.svc-card::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  border-radius: 20px 20px 0 0;
  opacity: 0;
  transition: opacity .3s;
}

.svc-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 28px 72px rgba(11,57,84,.12);
  border-color: rgba(245,109,13,.15);
}

.svc-card:hover::after { opacity: 1; }

.svc-card-a::after { background: linear-gradient(90deg, var(--novo-navy), var(--novo-navy-light)); }
.svc-card-b::after { background: linear-gradient(90deg, var(--novo-orange), var(--novo-orange-lite)); }
.svc-card-c::after { background: linear-gradient(90deg, var(--novo-green), #48d495); }
.svc-card-d::after { background: linear-gradient(90deg, var(--novo-blue), var(--novo-navy3)); }

.svc-icon {
  width: 54px; height: 54px;
  border-radius: 15px;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px;
  margin-bottom: 20px;
}

.svc-icon-a { background: rgba(11,57,84,.08);   color: var(--novo-navy); }
.svc-icon-b { background: rgba(245,109,13,.10); color: var(--novo-orange); }
.svc-icon-c { background: rgba(15,163,96,.10);  color: var(--novo-green); }
.svc-icon-d { background: rgba(26,96,144,.10);  color: var(--novo-blue); }

.svc-card h4 {
  font-size: 15.5px;
  font-weight: 800;
  color: var(--novo-navy);
  margin-bottom: 10px;
  letter-spacing: -.3px;
}

.svc-card p {
  font-size: 13.5px;
  color: var(--novo-grey-tx);
  line-height: 1.72;
}

@media (max-width: 1000px) { .svc-grid { --svc4-cols: 2; } }
@media (max-width:  560px)  { .svc-grid { --svc4-cols: 1; } }

/* Responsive — services-grid--3col / --2col */
@media (max-width: 960px) { .services-grid--3col { --svc3-cols: 2; } }
@media (max-width: 600px) { .services-grid--3col { --svc3-cols: 1; } .services-grid--2col { --svc2-cols: 1; } }

/* ═══════════════════════════════════════════════
   TRUST STRIP WIDGET
═══════════════════════════════════════════════ */

.novo-trust-strip {
  display: grid;
  grid-template-columns: repeat(var(--ts-cols, 4), 1fr);
  border-top: 1px solid var(--novo-border);
  border-bottom: 1px solid var(--novo-border);
  padding: 28px 0;
  margin: 0;
}
/* Zero out Elementor section/column/row spacing that wraps the trust strip */
.elementor-widget-novo-trust-strip,
.elementor-widget-novo-trust-strip .elementor-widget-container {
  padding: 0 !important;
  margin: 0 !important;
}
.elementor-section:has(.elementor-widget-novo-trust-strip),
.e-con:has(.elementor-widget-novo-trust-strip),
.elementor-column:has(.elementor-widget-novo-trust-strip) {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.novo-trust-strip.bg-white { background: #fff; }
.novo-trust-strip.bg-grey  { background: var(--novo-grey-bg); }
.novo-trust-strip.bg-navy  { background: var(--novo-navy); }

.novo-trust-strip.has-dividers .trust-strip-item {
  border-right: 1px solid var(--novo-border);
}

.novo-trust-strip.bg-navy.has-dividers .trust-strip-item {
  border-color: rgba(255,255,255,.10);
}

.novo-trust-strip.has-dividers .trust-strip-item:last-child { border-right: none; }

.trust-strip-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 8px 20px;
}

.trust-strip-item .ts-icon { font-size: 28px; color: var(--novo-orange); margin-bottom: 10px; }

.trust-strip-item .ts-number {
  font-size: 36px;
  font-weight: 900;
  color: var(--novo-navy);
  letter-spacing: -1.5px;
  line-height: 1;
  margin-bottom: 4px;
}

.novo-trust-strip.bg-navy .trust-strip-item .ts-number { color: #fff; }

.trust-strip-item .ts-label {
  font-size: 13px;
  font-weight: 700;
  color: var(--novo-navy);
  text-transform: uppercase;
  letter-spacing: .5px;
}

.novo-trust-strip.bg-navy .trust-strip-item .ts-label { color: rgba(255,255,255,.72); }

.trust-strip-item .ts-desc { font-size: 12px; color: var(--novo-grey-tx); margin-top: 4px; line-height: 1.5; }

.novo-trust-strip.bg-navy .trust-strip-item .ts-desc { color: rgba(255,255,255,.40); }

/* ═══════════════════════════════════════════════
   VALUE PROPOSITION WIDGET
═══════════════════════════════════════════════ */

.novo-value-prop {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: center;
}

.novo-value-prop.img-right .vp-media { order: 2; }
.novo-value-prop.img-right .vp-content { order: 1; }

.novo-value-prop .vp-media { position: relative; }

.novo-value-prop .vp-img {
  width: 100%;
  border-radius: var(--novo-radius-lg);
  box-shadow: var(--novo-shadow-lg);
  display: block;
}

.novo-value-prop .vp-img-badge {
  position: absolute;
  top: -14px; right: -14px;
  background: rgba(245,109,13,.20);
  border: 1px solid rgba(245,109,13,.40);
  backdrop-filter: blur(10px);
  border-radius: var(--novo-radius-pill);
  padding: 9px 18px;
  font-size: 11.5px;
  font-weight: 700;
  color: var(--novo-orange-lite);
  animation: floatY 8s ease-in-out infinite;
}

.novo-value-prop .section-eyebrow {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3.5px;
  text-transform: uppercase;
  color: var(--novo-orange);
  margin-bottom: 14px;
}

.novo-value-prop .vp-title {
  font-size: clamp(28px, 3.8vw, 44px);
  font-weight: 900;
  color: var(--novo-navy);
  letter-spacing: -1.2px;
  line-height: 1.1;
  margin-bottom: 14px;
}

.novo-value-prop .vp-sub {
  font-size: 16px;
  color: var(--novo-grey-tx);
  line-height: 1.82;
  margin-bottom: 28px;
}

.novo-value-prop .vp-benefits {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-bottom: 32px;
}

.novo-value-prop .vp-benefit {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  font-size: 15px;
  color: var(--novo-navy);
  line-height: 1.6;
}

.novo-value-prop .benefit-icon {
  width: 36px; height: 36px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  flex-shrink: 0;
}

.novo-value-prop .benefit-icon.color-orange { background: rgba(245,109,13,.10); color: var(--novo-orange); }
.novo-value-prop .benefit-icon.color-navy   { background: rgba(11,57,84,.08);   color: var(--novo-navy); }
.novo-value-prop .benefit-icon.color-green  { background: rgba(15,163,96,.10);  color: var(--novo-green); }
.novo-value-prop .benefit-icon.color-blue   { background: rgba(26,96,144,.10);  color: var(--novo-blue); }

.novo-value-prop .benefit-title {
  display: block;
  font-size: 14px;
  font-weight: 700;
  color: var(--novo-navy);
  margin-bottom: 2px;
}

.novo-value-prop .benefit-desc {
  font-size: 13.5px;
  color: var(--novo-grey-tx);
  line-height: 1.65;
}

/* ═══════════════════════════════════════════════
   TEAM CARDS WIDGET
═══════════════════════════════════════════════ */

.team-grid {
  display: grid;
  grid-template-columns: repeat(var(--tm-cols, 3), 1fr);
  gap: 24px;
}

.team-grid .team-card {
  background: #fff;
  border-radius: var(--novo-radius-card);
  border: 1px solid var(--novo-border);
  box-shadow: var(--novo-shadow-card);
  overflow: hidden;
  transition: transform .32s cubic-bezier(.22,.68,0,1.2), box-shadow .32s;
  display: flex;
  flex-direction: column;
}

.team-grid .team-card:hover {
  transform: translateY(-7px);
  box-shadow: var(--novo-shadow-hover);
}

.team-grid .team-card-avatar {
  width: 100%;
  aspect-ratio: 1;
  overflow: hidden;
  background: linear-gradient(135deg, var(--novo-navy), var(--novo-navy-mid));
  display: flex;
  align-items: center;
  justify-content: center;
}

.team-grid.style-compact .team-card {
  flex-direction: row;
  align-items: center;
}

.team-grid.style-compact .team-card-avatar {
  width: 72px; height: 72px;
  flex-shrink: 0;
  border-radius: 12px;
  aspect-ratio: unset;
}

.team-grid .team-card-avatar img { width: 100%; height: 100%; object-fit: cover; }

.team-grid .avatar-placeholder { font-size: 32px; color: rgba(255,255,255,.5); }

.team-grid .team-card-info {
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
}

.team-grid .team-name { font-size: 15px; font-weight: 800; color: var(--novo-navy); display: block; }
.team-grid .team-role { font-size: 13px; color: var(--novo-grey-tx); }
.team-grid .team-dept { margin-top: 4px; }

.team-grid .team-social {
  display: flex;
  gap: 8px;
  margin-top: 12px;
}

.team-grid .social-btn {
  width: 32px; height: 32px;
  border-radius: 8px;
  background: var(--novo-grey-bg);
  border: 1px solid var(--novo-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  color: var(--novo-grey-tx);
  transition: background .2s, color .2s, border-color .2s;
  text-decoration: none;
}

.team-grid .social-btn:hover {
  background: var(--novo-orange);
  color: #fff;
  border-color: var(--novo-orange);
}

/* ─── Team Cards — Contact-page style (style-contact) ──────────────────────── */
.team-grid.style-contact {
  grid-template-columns: repeat(var(--tm-cols, 4), 1fr);
  gap: 24px;
}
.team-grid.style-contact .team-card {
  background: #fff;
  border-radius: 18px;
  padding: 32px 24px;
  text-align: center;
  box-shadow: 0 8px 36px rgba(11,57,84,.10);
  border: none;
  border-bottom: 3px solid var(--novo-orange);
  flex-direction: column;
  overflow: hidden;
  transition: transform .35s cubic-bezier(.22,.68,0,1.2), box-shadow .35s;
  position: relative;
  display: flex;
}
.team-grid.style-contact .team-card::before {
  content: '';
  position: absolute; top: -60px; right: -60px;
  width: 140px; height: 140px;
  background: radial-gradient(circle, rgba(245,109,13,.07) 0%, transparent 70%);
  pointer-events: none;
}
.team-grid.style-contact .team-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 28px 64px rgba(11,57,84,.16);
}
/* Circular avatar — wrapper owns the dashed ring so avatar can safely use overflow:hidden */
.team-grid.style-contact .team-avatar-wrap {
  position: relative;
  width: 88px; height: 88px;
  margin: 0 auto 18px; flex-shrink: 0;
  transition: transform .3s;
}
.team-grid.style-contact .team-avatar-wrap::after {
  content: '';
  position: absolute; inset: -5px; border-radius: 50%;
  border: 2px dashed rgba(245,109,13,.25);
  animation: spinSlow 20s linear infinite;
  pointer-events: none;
}
.team-grid.style-contact .team-avatar {
  width: 88px; height: 88px;
  background: linear-gradient(135deg, var(--novo-navy, #0B3954) 0%, #1a6090 100%);
  color: #fff; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; font-weight: 800;
  border: 3px solid rgba(245,109,13,.30);
  transition: border-color .3s;
  overflow: hidden;
  position: relative;
}
.team-grid.style-contact .team-avatar img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.team-grid.style-contact .team-card:hover .team-avatar-wrap {
  transform: scale(1.08);
}
.team-grid.style-contact .team-card:hover .team-avatar {
  border-color: var(--novo-orange);
}
/* Info area */
.team-grid.style-contact .team-card-info { padding: 0; gap: 0; flex: none; }
.team-grid.style-contact .team-name {
  display: block; font-size: 15px; font-weight: 800;
  color: var(--novo-navy, #0B3954); margin-bottom: 4px;
}
.team-grid.style-contact .team-role {
  display: block; font-size: 11px; font-weight: 700;
  color: var(--novo-orange); text-transform: uppercase;
  letter-spacing: 1.5px; margin-bottom: 18px;
}
/* Full-width contact link rows */
.team-grid.style-contact .team-link {
  display: flex; align-items: center; justify-content: center;
  gap: 8px; font-size: 13px;
  color: var(--novo-grey-tx, #7A90A0);
  background: var(--novo-grey-bg, #F7F8FA);
  padding: 8px 12px; border-radius: 8px;
  margin-bottom: 7px; text-decoration: none;
  transition: background .25s, color .25s, transform .2s;
}
.team-grid.style-contact .team-link:last-child { margin-bottom: 0; }
.team-grid.style-contact .team-link i {
  color: var(--novo-orange); font-size: 12px; width: 14px;
  text-align: center; flex-shrink: 0; transition: color .25s;
}
.team-grid.style-contact .team-link:hover {
  background: var(--novo-navy, #0B3954); color: #fff; transform: translateX(3px);
}
.team-grid.style-contact .team-link:hover i { color: var(--novo-orange-lite, #FFAB6E); }
/* ─── End team contact style ────────────────────────────────────────────────── */

/* ═══════════════════════════════════════════════
   DEPARTMENT CARDS WIDGET
═══════════════════════════════════════════════ */

.novo-dept-grid {
  display: grid;
  grid-template-columns: repeat(var(--dept-cols, 3), 1fr);
  gap: 28px;
  justify-items: center;
}
/* Centre cards when the last row isn't full */
.novo-dept-grid .dept-card {
  width: 100%;
}

/* Section header gets extra bottom margin to match reference */
.novo-dept-grid ~ * { /* handled by Elementor spacing */ }
.novo-section-header + .novo-dept-grid,
.novo-dept-grid { margin-top: 0; }
/* Section header above the grid */
.novo-dept-grid .novo-section-header { display: none; } /* header is output before grid; see below */

.novo-dept-grid .dept-card {
  background: #fff;
  border-radius: var(--novo-radius-card);
  border: none;
  border-top: 4px solid var(--novo-orange);
  padding: 40px 32px;
  box-shadow: 0 8px 40px rgba(11,57,84,.10);
  position: relative;
  overflow: hidden;
  transition: transform .35s cubic-bezier(.22,.68,0,1.2), box-shadow .35s;
}

.novo-dept-grid .dept-card::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(circle at 80% -20%, rgba(245,109,13,.06) 0%, transparent 60%);
  pointer-events: none;
  transition: opacity .35s;
  opacity: 0;
}
.novo-dept-grid .dept-card:hover::before { opacity: 1; }

.novo-dept-grid .dept-card.accent-navy  { border-top-color: var(--novo-navy); }
.novo-dept-grid .dept-card.accent-green { border-top-color: var(--novo-green); }
.novo-dept-grid .dept-card.accent-blue  { border-top-color: var(--novo-blue); }

.novo-dept-grid .dept-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 30px 72px rgba(11,57,84,.18);
}

/* Icon — reference-style wrapped box */
.novo-dept-grid .dept-icon {
  width: 60px; height: 60px;
  background: rgba(245,109,13,.10);
  color: var(--novo-orange);
  border-radius: 16px;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px;
  margin-bottom: 24px;
  transition: background .3s, color .3s, border-radius .3s;
}
.novo-dept-grid .dept-card:hover .dept-icon { background: var(--novo-orange); color: #fff; border-radius: 50%; }

.novo-dept-grid .dept-card.accent-navy  .dept-icon { background: rgba(11,57,84,.10);  color: var(--novo-navy); }
.novo-dept-grid .dept-card.accent-green .dept-icon { background: rgba(15,163,96,.10); color: var(--novo-green); }
.novo-dept-grid .dept-card.accent-blue  .dept-icon { background: rgba(26,96,144,.10); color: var(--novo-blue); }
.novo-dept-grid .dept-card.accent-navy:hover  .dept-icon { background: var(--novo-navy);  color: #fff; }
.novo-dept-grid .dept-card.accent-green:hover .dept-icon { background: var(--novo-green); color: #fff; }
.novo-dept-grid .dept-card.accent-blue:hover  .dept-icon { background: var(--novo-blue);  color: #fff; }

.novo-dept-grid .dept-count { position: absolute; top: 20px; right: 20px; }

.novo-dept-grid .dept-title { font-size: 19px; font-weight: 800; color: var(--novo-navy); margin-bottom: 10px; letter-spacing: -.3px; }
.novo-dept-grid .dept-desc  { font-size: 14px; color: var(--novo-grey-tx); line-height: 1.7; margin-bottom: 26px; }

/* Contact link rows (phone / email) — full-width pill rows */
.novo-dept-grid .dept-contact-link,
.novo-dept-grid .btn-link {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--novo-navy, #0B3954);
  background: var(--novo-grey-bg, #F7F8FA);
  padding: 11px 16px;
  border-radius: 10px;
  margin-bottom: 8px;
  text-decoration: none;
  transition: background .25s, color .25s, transform .2s;
  width: 100%;
}
.novo-dept-grid .dept-contact-link:last-child,
.novo-dept-grid .btn-link:last-child { margin-bottom: 0; }
.novo-dept-grid .dept-contact-link i,
.novo-dept-grid .btn-link i {
  color: var(--novo-orange); width: 15px; text-align: center; flex-shrink: 0; transition: color .25s;
}
.novo-dept-grid .dept-contact-link:hover,
.novo-dept-grid .btn-link:hover {
  background: var(--novo-navy, #0B3954); color: #fff; transform: translateX(4px);
}
.novo-dept-grid .dept-contact-link:hover i,
.novo-dept-grid .btn-link:hover i { color: var(--novo-orange-lite, #FFAB6E); }

/* ── Responsive ─────────────────────────────── */
@media (max-width: 1024px) {
  .novo-dept-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    padding-left: 16px;
    padding-right: 16px;
  }
  /* Center lone card on last row */
  .novo-dept-grid .dept-card:last-child:nth-child(odd) {
    grid-column: 1 / -1;
    width: calc(50% - 10px);
    justify-self: center;
  }
}
@media (max-width: 767px) {
  .novo-dept-grid {
    grid-template-columns: 1fr;
    gap: 24px;
    padding-left: 16px;
    padding-right: 16px;
  }
  .novo-dept-grid .dept-card {
    padding: 28px 24px;
  }
  /* Reset tablet lone-card centering — all cards are full width on mobile */
  .novo-dept-grid .dept-card:last-child:nth-child(odd) {
    grid-column: auto;
    width: 100%;
    justify-self: stretch;
  }
}


/* ═══════════════════════════════════════════════
   DEPARTMENT CARDS – SWITCHER LAYOUT (homepage)
   Matches home-preview.html .mod-section
═══════════════════════════════════════════════ */
.mod-section {
  background: transparent;
  padding: 0 0 56px;
  margin-top: -80px;
  position: relative;
  z-index: 3;
}
.mod-section::before {
  content: '';
  position: absolute;
  top: 80px; left: 0; right: 0; bottom: 0;
  background: var(--novo-grey-bg, #F5F7FA);
  z-index: -1;
}
.mod-card {
  background: #fff;
  border-radius: 24px;
  box-shadow: 0 36px 108px rgba(7,31,46,.26), 0 4px 18px rgba(7,31,46,.06);
  overflow: hidden;
  position: relative;
}
.mod-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--novo-orange, #F56D0D), var(--novo-orange-lite, #ffb06b) 50%, var(--novo-orange, #F56D0D));
}
.mod-section .dep-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.mod-section .dep-card {
  display: flex;
  align-items: center;
  gap: 28px;
  padding: 40px 44px;
  text-decoration: none;
  border-left: 1px solid var(--novo-border, #E8EDF3);
  position: relative;
  overflow: hidden;
  transition: background .25s;
}
.mod-section .dep-card:first-child { border-left: none; }
.mod-section .dep-card:hover { background: rgba(245,109,13,.032); }
.mod-section .dep-icon {
  width: 76px; height: 76px;
  border-radius: 22px;
  display: flex; align-items: center; justify-content: center;
  font-size: 30px;
  flex-shrink: 0;
  transition: all .32s cubic-bezier(.22,.68,0,1.3);
}
.mod-section .dep-icon-equip {
  background: rgba(11,57,84,.07);
  color: var(--novo-navy, #0B3954);
  border: 1.5px solid var(--novo-border, #E8EDF3);
}
.mod-section .dep-icon-parts {
  background: rgba(245,109,13,.09);
  color: var(--novo-orange, #F56D0D);
  border: 1.5px solid rgba(245,109,13,.25);
}
.mod-section .dep-card:hover .dep-icon-equip {
  background: var(--novo-navy, #0B3954); color: #fff;
  transform: scale(1.08);
  box-shadow: 0 14px 34px rgba(11,57,84,.28);
  border-color: var(--novo-navy, #0B3954);
}
.mod-section .dep-card:hover .dep-icon-parts {
  background: var(--novo-orange, #F56D0D); color: #fff;
  transform: scale(1.08);
  box-shadow: 0 14px 34px rgba(245,109,13,.38);
  border-color: var(--novo-orange, #F56D0D);
}
.mod-section .dep-label {
  font-size: 10.5px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 2px;
  color: var(--novo-grey-tx, #7A90A0);
  margin-bottom: 7px;
}
.mod-section .dep-title {
  font-size: 22px; font-weight: 900;
  color: var(--novo-navy, #0B3954);
  letter-spacing: -.5px;
  margin-bottom: 9px;
}
.mod-section .dep-desc {
  font-size: 14px;
  color: var(--novo-grey-tx, #7A90A0);
  line-height: 1.65;
  margin-bottom: 18px;
}
.mod-section .dep-btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13.5px; font-weight: 700;
  color: var(--novo-orange, #F56D0D);
  transition: gap .2s;
}
.mod-section .dep-card:hover .dep-btn { gap: 14px; }
.mod-section .dep-card::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0;
  width: 0; height: 3px;
  background: linear-gradient(90deg, var(--novo-orange, #F56D0D), var(--novo-orange-lite, #ffb06b));
  transition: width .38s cubic-bezier(.22,.68,0,1);
}
.mod-section .dep-card:hover::after { width: 100%; }

@media (max-width: 900px) {
  .mod-section .dep-grid { grid-template-columns: 1fr; }
  .mod-section .dep-card { border-left: none; border-top: 1px solid var(--novo-border, #E8EDF3); }
  .mod-section .dep-card:first-child { border-top: none; }
}
@media (max-width: 560px) {
  .mod-section .dep-card { padding: 28px 24px; gap: 18px; }
}


/* ═══════════════════════════════════════════════
   AVAILABLE SYSTEMS / FEATURED PRODUCTS (homepage)
   Matches home-preview.html .avail-section
═══════════════════════════════════════════════ */
.avail-section { padding: 96px 0; background: #fff; }
.avail-header {
  display: flex; align-items: flex-end; justify-content: space-between;
  margin-bottom: 48px; flex-wrap: wrap; gap: 20px;
}
.avail-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
}
.avail-card {
  background: #fff; border-radius: 16px;
  border: 1px solid var(--novo-border, #E8EDF3);
  overflow: hidden;
  display: flex; flex-direction: column;
  box-shadow: 0 2px 16px rgba(11,57,84,.10);
  transition: transform .3s cubic-bezier(.22,.68,0,1.2), box-shadow .3s, border-color .3s;
}
.avail-card:hover {
  transform: translateY(-7px);
  box-shadow: 0 22px 60px rgba(11,57,84,.12);
  border-color: rgba(245,109,13,.22);
}
/* Photo area */
.lc-photo { aspect-ratio: 4/3; position: relative; overflow: hidden; display: flex; align-items: center; justify-content: center; background: var(--novo-grey-bg, #f6f8fb); }
.lc-photo img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: contain; display: block; transition: transform .4s; }
.avail-card:hover .lc-photo img { transform: scale(1.02); }
/* Gradient overlay — bottom-darkens photo for legibility */
.lc-photo-overlay {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(to bottom, transparent 45%, rgba(0,0,0,.45) 100%);
}
/* Modality label — bottom-left of photo */
.lc-modality {
  position: absolute; bottom: 10px; left: 12px; z-index: 2;
  font-size: 10px; font-weight: 700; letter-spacing: .7px; text-transform: uppercase;
  color: rgba(255,255,255,.92); text-shadow: 0 1px 5px rgba(0,0,0,.6);
}
.lc-ph {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 80px; color: rgba(255,255,255,.32);
}
.lc-ph::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 65% 15%, rgba(245,109,13,.22) 0%, transparent 60%);
}
.lc-ph i { position: relative; z-index: 1; transition: transform .3s; }
.avail-card:hover .lc-ph i { transform: scale(1.06); }
.lc-navy   { background: linear-gradient(145deg, #071F2E 0%, #0d4a6b 100%); }
.lc-orange { background: linear-gradient(145deg, #5c2a00 0%, #c86000 100%); }
.lc-teal   { background: linear-gradient(145deg, #053545 0%, #0d8a9c 100%); }
.lc-purple { background: linear-gradient(145deg, #1e0f47 0%, #5a3ec8 100%); }
/* Availability badge */
.lc-avail {
  position: absolute; top: 12px; right: 12px; z-index: 3;
  font-size: 10.5px; font-weight: 700;
  padding: 5px 12px; border-radius: 20px; border: 1px solid transparent;
  display: flex; align-items: center; gap: 5px;
  backdrop-filter: blur(6px);
}
.lc-av-blink { font-size: 7px; animation: blink 1.8s ease infinite; }
.lc-av-green { background: rgba(18,183,106,.22); border-color: rgba(18,183,106,.40); color: #4de8a0; }
.lc-av-amber { background: rgba(247,144,9,.22);  border-color: rgba(247,144,9,.40);  color: #fdc16b; }
.lc-av-red   { background: rgba(220,38,38,.22);  border-color: rgba(220,38,38,.40);  color: #f87171; }
.lc-av-grey  { background: rgba(255,255,255,.14); border-color: rgba(255,255,255,.24); color: rgba(255,255,255,.75); }
.lc-av-blue  { background: rgba(26,96,144,.88); color: #fff; }
/* Body */
.lc-body { padding: 20px 20px 16px; flex: 1; display: flex; flex-direction: column; }
.lc-brand {
  font-size: 10.5px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 2px;
  color: var(--novo-orange, #F56D0D);
  margin-bottom: 6px;
}
.lc-name {
  font-size: 18px; font-weight: 900;
  color: var(--novo-navy, #0B3954);
  letter-spacing: -.5px; line-height: 1.2;
  margin-bottom: 14px;
  min-height: 65px;
}
.lc-yom {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; color: var(--novo-grey-tx, #7A90A0); font-weight: 500;
}
.lc-yom i { color: var(--novo-orange, #F56D0D); font-size: 12px; }
.lc-yom strong { color: var(--novo-navy, #0B3954); font-weight: 700; }
/* Meta row (YOM + modality chips) */
.lc-meta-row { display: flex; flex-wrap: wrap; gap: 5px 10px; margin-top: 6px; }
.lc-chip {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 12px; color: var(--novo-grey-tx, #7A90A0); font-weight: 500;
}
.lc-chip i { color: var(--novo-orange, #F56D0D); font-size: 11px; }
.lc-chip--mod { color: var(--novo-navy, #0B3954); font-weight: 600; }
.lc-label { font-weight: 700; color: var(--novo-navy, #0B3954); margin-right: 2px; }
/* Footer */
.lc-foot { padding: 16px 20px; border-top: 1px solid var(--novo-border, #E8EDF3); }
.lc-view {
  display: flex; align-items: center; justify-content: center;
  gap: 8px; font-size: 13.5px; font-weight: 700;
  color: #fff; background: var(--novo-navy, #0B3954);
  padding: 11px 0; border-radius: 10px;
  text-decoration: none;
  transition: background .2s, gap .2s;
}
.lc-view:hover { background: #0d4a6b; gap: 14px; }

@media (max-width: 1000px) { .avail-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px)  { .avail-grid { grid-template-columns: 1fr; } }


/* ═══════════════════════════════════════════════
   OEM BRANDS – GRID LAYOUT (homepage)
   Matches home-preview.html .brands-section
═══════════════════════════════════════════════ */
.brands-section { padding: 80px 0; background: var(--novo-grey-bg, #F5F7FA); border-top: 1px solid var(--novo-border, #E8EDF3); }
.brands-hd { text-align: center; margin-bottom: 52px; }
.brands-label {
  font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 2.5px;
  color: var(--novo-orange, #F56D0D);
  margin-bottom: 14px;
}
.brands-sub {
  font-size: 15px; color: var(--novo-grey-tx, #7A90A0);
  line-height: 1.75; max-width: 620px; margin: 0 auto;
}
.brands-row {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 16px;
}
.brand-tile {
  background: #fff;
  border: 1px solid var(--novo-border, #E8EDF3);
  border-radius: 16px;
  padding: 28px 16px;
  text-align: center;
  box-shadow: 0 2px 12px rgba(11,57,84,.10);
  transition: transform .3s cubic-bezier(.22,.68,0,1.2), box-shadow .3s, border-color .3s;
  cursor: default;
}
.brand-tile:hover {
  transform: translateY(-6px);
  box-shadow: 0 18px 48px rgba(11,57,84,.11);
  border-color: rgba(245,109,13,.22);
}
.brand-tile-inner { display: flex; flex-direction: column; align-items: center; gap: 14px; }
.brand-ico {
  font-size: 32px;
  color: var(--novo-navy, #0B3954);
  opacity: .55;
  transition: opacity .3s, color .3s;
}
.brand-tile:hover .brand-ico { opacity: 1; color: var(--novo-orange, #F56D0D); }
.brand-name { font-size: 13px; font-weight: 800; color: var(--novo-navy, #0B3954); letter-spacing: -.2px; }

@media (max-width: 900px) { .brands-row { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 480px) { .brands-row { grid-template-columns: repeat(2, 1fr); } }


/* ═══════════════════════════════════════════════
   FILTER PILLS WIDGET
═══════════════════════════════════════════════ */

.novo-filter-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 28px;
}

.novo-filter-pills .filter-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 18px;
  border-radius: var(--novo-radius-pill);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  background: #fff;
  color: var(--novo-grey-tx);
  border: 1.5px solid var(--novo-border);
  transition: all .2s;
  white-space: nowrap;
  font-family: var(--novo-font);
}

.novo-filter-pills .filter-pill:hover { border-color: var(--novo-orange); color: var(--novo-navy); }
.novo-filter-pills .filter-pill.active,
.novo-filter-pills .filter-pill.is-active { background: var(--novo-orange); border-color: var(--novo-orange); color: #fff; }

/* ═══════════════════════════════════════════════
   READING PROGRESS WIDGET
═══════════════════════════════════════════════ */

.novo-reading-progress {
  position: fixed;
  top: 0; left: 0;
  width: 0%;
  height: 3px;
  background: linear-gradient(90deg, var(--novo-orange), var(--novo-orange-lite));
  z-index: 9999;
  transition: width .15s linear;
  pointer-events: none;
}

/* ═══════════════════════════════════════════════
   TOC SIDEBAR WIDGET
═══════════════════════════════════════════════ */

.novo-toc {
  background: #fff;
  border: 1px solid var(--novo-border);
  border-radius: var(--novo-radius-card);
  padding: 24px;
  box-shadow: var(--novo-shadow-card);
}

.novo-toc.is-sticky { position: sticky; top: 88px; }

.novo-toc .toc-title {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--novo-grey-tx);
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--novo-border);
}

.novo-toc .toc-list { list-style: none; display: flex; flex-direction: column; gap: 4px; }

.novo-toc .toc-item a {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
  border-radius: 8px;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--novo-grey-tx);
  text-decoration: none;
  transition: background .15s, color .15s;
}

.novo-toc .toc-item a:hover,
.novo-toc .toc-item.active a {
  background: rgba(245,109,13,.06);
  color: var(--novo-orange);
}

.novo-toc .toc-item a::before {
  content: '';
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--novo-border);
  flex-shrink: 0;
  transition: background .15s;
}

.novo-toc .toc-item a:hover::before,
.novo-toc .toc-item.active a::before { background: var(--novo-orange); }

/* ═══════════════════════════════════════════════
   TRADE-IN PROCESS WIDGET
═══════════════════════════════════════════════ */

.novo-tradein-process { position: relative; padding: 96px 0; }
.novo-tradein-process.theme-dark  { background: var(--novo-navy-dark); color: #fff; }
.novo-tradein-process.theme-navy  { background: var(--novo-navy-dark); color: #fff; } /* widget outputs theme-navy */
.novo-tradein-process.theme-light { background: var(--novo-grey-bg); }
.novo-tradein-process.theme-white { background: #fff; }

/* ── Section header (shared .section-eyebrow / .section-title exist in utilities;
   add contrast overrides for dark background) ── */
.novo-tradein-process .section-header {
  text-align: center;
  margin-bottom: 64px;
  position: relative;
  z-index: 1;
}
.novo-tradein-process.theme-navy .section-title,
.novo-tradein-process.theme-dark .section-title {
  color: #fff;
}
.novo-tradein-process.theme-navy .section-sub,
.novo-tradein-process.theme-dark .section-sub {
  color: rgba(255, 255, 255, .55);
}

/* ── Steps grid ── */
.tradein-steps {
  display: grid;
  grid-template-columns: repeat(var(--steps-count, 4), 1fr);
  gap: 28px;
  position: relative;
  z-index: 1;
}

/* Horizontal connector line across icon centres */
.tradein-steps::before {
  content: '';
  position: absolute;
  top: 36px; /* half of 72px icon circle */
  left:  calc(100% / (var(--steps-count, 4) * 2));
  right: calc(100% / (var(--steps-count, 4) * 2));
  height: 2px;
  background: linear-gradient(90deg, var(--novo-orange), rgba(245, 109, 13, .15));
  z-index: 0;
  pointer-events: none;
}

.tradein-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
  z-index: 1;
}

.step-number {
  font-size: 10.5px;
  font-weight: 900;
  letter-spacing: 2.5px;
  color: var(--novo-orange);
  text-transform: uppercase;
  margin-bottom: 10px;
  opacity: .75;
}

.step-icon-wrap {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--novo-orange), var(--novo-orange-lite));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 26px;
  color: #fff;
  box-shadow: 0 8px 28px rgba(245, 109, 13, .35);
  border: 4px solid var(--novo-grey-bg);
  margin-bottom: 20px;
  transition: transform .3s;
}
.novo-tradein-process.theme-navy  .step-icon-wrap,
.novo-tradein-process.theme-dark  .step-icon-wrap { border-color: var(--novo-navy-dark); }
.novo-tradein-process.theme-white .step-icon-wrap { border-color: #fff; }
.tradein-step:hover .step-icon-wrap { transform: translateY(-3px); }

.step-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--novo-orange);
  background: rgba(245, 109, 13, .10);
  border: 1px solid rgba(245, 109, 13, .22);
  border-radius: 20px;
  padding: 3px 10px;
  margin-bottom: 12px;
}

.step-title {
  font-size: 16px;
  font-weight: 800;
  color: var(--novo-navy);
  margin: 0 0 8px;
  letter-spacing: -.2px;
  text-align: center;
}
.novo-tradein-process.theme-navy .step-title,
.novo-tradein-process.theme-dark .step-title { color: #fff; }

.step-desc {
  font-size: 13.5px;
  color: var(--novo-grey-tx);
  line-height: 1.65;
  margin: 0;
  text-align: center;
}
.novo-tradein-process.theme-navy .step-desc,
.novo-tradein-process.theme-dark .step-desc { color: rgba(255, 255, 255, .60); }

/* Connector arrow — hidden; connector is handled by ::before on .tradein-steps */
.step-connector { display: none; }

.tradein-cta {
  text-align: center;
  margin-top: 56px;
  position: relative;
  z-index: 1;
}

/* ── Responsive ── */
@media (max-width: 1100px) {
  .tradein-steps { grid-template-columns: repeat(2, 1fr); gap: 24px; }
  .tradein-steps::before { display: none; }
}
@media (max-width: 600px) {
  .tradein-steps { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════
   TRADE-IN TYPES WIDGET  (.type-card)
═══════════════════════════════════════════════ */

.novo-tradein-types { padding: 96px 0; background: var(--novo-grey-bg); }
.types-grid {
  display: grid;
  grid-template-columns: repeat(var(--tradein-cols, 4), 1fr);
  gap: 18px;
}
.type-card {
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid var(--novo-border);
  transition: transform .3s, box-shadow .3s, border-color .3s;
}
.type-card:hover { transform: translateY(-5px); box-shadow: 0 16px 48px rgba(11,57,84,.12); border-color: rgba(245,109,13,.22); }
.type-thumb {
  background: linear-gradient(135deg, var(--novo-navy) 0%, #0d4a6b 100%);
  aspect-ratio: 4 / 3;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 40px;
  color: rgba(255,255,255,.45);
  position: relative;
  overflow: hidden;
}
.type-thumb.t { background: linear-gradient(135deg, #0d3a5c 0%, #0d5e87 100%); }
.type-thumb.g { background: linear-gradient(135deg, #0d4a6b 0%, #0d6b82 100%); }
.type-thumb.d { background: linear-gradient(135deg, #071f2e 0%, #0d3754 100%); }
.type-thumb::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 75% 20%, rgba(245,109,13,.20) 0%, transparent 55%); }
.type-thumb i { position: relative; z-index: 1; transition: transform .3s; }
.type-card:hover .type-thumb i { transform: scale(1.12); }
.type-body  { padding: 16px 18px; background: #fff; }
.type-name  { font-size: 14.5px; font-weight: 800; color: var(--novo-navy); margin-bottom: 4px; }
.type-note  { font-size: 12px; color: var(--novo-grey-tx); line-height: 1.5; }
.novo-tradein-types .s-sub { max-width: 520px; margin: 0 auto; }

/* ═══════════════════════════════════════════════
   ABOUT TIMELINE WIDGET  (.timeline)
   Horizontal, all-above layout on desktop.
   Converts to vertical left-gutter on mobile ≤768px.
═══════════════════════════════════════════════ */

/* Section wrapper */
.timeline-section { padding: 96px 0; }

/* Section header */
.timeline-header { text-align: center; margin-bottom: 64px; }
.timeline-header .section-sub { max-width: 480px; margin: 16px auto 0; }

/* Horizontal container — all dots align to bottom baseline */
.timeline {
  position: relative;
  margin: 0 auto;
  display: flex;
  align-items: flex-end;
}

/* Horizontal gradient line runs through dot centres */
.timeline::before {
  content: '';
  position: absolute;
  left: 0; right: 0;
  bottom: 9px; /* half of 18px dot */
  height: 2px;
  background: linear-gradient(to right, var(--novo-orange, #f56d0d), rgba(245,109,13,.20));
  pointer-events: none;
}

/* Individual timeline column */
.tl-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0 8px;
}

/* Card — sits above the dot */
.tl-content {
  order: 1;
  width: 100%;
  background: #fff;
  border-radius: 16px;
  padding: 22px 18px;
  box-shadow: 0 6px 28px rgba(11,57,84,.10);
  border-left: 4px solid var(--novo-orange, #f56d0d);
  transition: transform .3s, box-shadow .3s;
  position: relative;
}

/* Short vertical connector from card bottom to the dot */
.tl-content::after {
  content: '';
  position: absolute;
  bottom: -22px;
  left: 50%;
  transform: translateX(-50%);
  width: 2px;
  height: 22px;
  background: linear-gradient(to bottom, rgba(245,109,13,.4), var(--novo-orange, #f56d0d));
  border-radius: 1px;
}

.tl-content:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 52px rgba(11,57,84,.16);
}

/* Dot spacer — sits below card (and below connector) */
.tl-spacer {
  order: 2;
  flex-shrink: 0;
  display: flex;
  justify-content: center;
  margin-top: 22px;
  position: relative;
  z-index: 1;
}

/* .right variant: same visual output on desktop (card above, dot below) */
.tl-item.right .tl-content { order: 1; }
.tl-item.right .tl-spacer  { order: 2; }

/* Empty placeholder — always hidden */
.tl-empty { display: none !important; }

/* Dot */
.tl-dot {
  width: 18px;
  height: 18px;
  background: var(--novo-orange, #f56d0d);
  border-radius: 50%;
  border: 3px solid #fff;
  box-shadow: 0 0 0 3px rgba(245,109,13,.30);
  flex-shrink: 0;
}

/* Year badge */
.tl-year {
  font-size: 11px;
  font-weight: 700;
  color: var(--novo-orange, #f56d0d);
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: 6px;
}

/* Card typography */
.tl-content h4 {
  font-size: 15px;
  font-weight: 800;
  color: var(--novo-navy, #0b3954);
  margin-bottom: 6px;
}

.tl-content p {
  font-size: 13.5px;
  color: var(--novo-grey-tx, #7a90a0);
  line-height: 1.65;
  margin: 0;
}

/* ── Mobile: vertical left-gutter layout ── */
@media (max-width: 768px) {
  .timeline {
    flex-direction: column;
    align-items: stretch;
  }

  .timeline::before {
    left: 20px; top: 0; bottom: 0; right: auto;
    width: 2px; height: auto;
    background: linear-gradient(to bottom, var(--novo-orange, #f56d0d), rgba(245,109,13,.15));
  }

  .tl-item,
  .tl-item.right {
    flex-direction: row;
    align-items: flex-start;
    gap: 16px;
    padding: 0;
    margin-bottom: 32px;
    flex: none;
  }

  .tl-item:last-child,
  .tl-item.right:last-child { margin-bottom: 0; }

  .tl-content {
    flex: 1;
    order: 2;
    margin-bottom: 0;
    padding: 20px 18px;
  }

  .tl-content::after { display: none; }

  .tl-spacer {
    order: 1;
    flex-shrink: 0;
    width: 40px;
    justify-content: flex-start;
    padding-left: 11px;
    padding-top: 4px;
    margin-top: 0;
  }

  .tl-item.right .tl-content { order: 2; }
  .tl-item.right .tl-spacer  { order: 1; }
}

/* ═══════════════════════════════════════════════
   REQUEST QUOTE CTA
═══════════════════════════════════════════════ */

.novo-request-quote {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 36px;
  border-radius: var(--novo-radius-pill);
  background: var(--novo-orange);
  color: #fff;
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
  transition: background .2s, transform .2s, box-shadow .2s;
  box-shadow: 0 8px 32px rgba(245,109,13,.40);
}

.novo-request-quote:hover {
  background: var(--novo-orange-dark);
  transform: translateY(-3px);
  box-shadow: 0 16px 42px rgba(245,109,13,.55);
  color: #fff;
}

/* ═══════════════════════════════════════════════
   SCROLL REVEAL — directional helpers only.
   Hidden state, transitions, and delay utilities
   are all owned by novo-animations.css.
═══════════════════════════════════════════════ */

/* Slide-from-left / slide-from-right variants used by the about-timeline widget */
.novo-reveal.left  { transform: translateX(-32px); }
.novo-reveal.right { transform: translateX(32px); }

/* ═══════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════ */

@media (max-width: 1100px) {
  .novo-newsletter-wrap { grid-template-columns: 1fr; gap: 40px; }
  .novo-value-prop      { gap: 52px; }
}

@media (max-width: 900px) {
  .novo-hero { padding: calc(var(--novo-topbar-h, 36px) + var(--novo-hdr-h, 72px) + 40px) 0 100px; }
  .novo-hero-title { font-size: clamp(32px, 6vw, 48px); }

  .novo-modality-grid { grid-template-columns: repeat(4, 1fr); }
  .novo-modality-item:nth-child(n+5)   { border-top: 1px solid var(--novo-border); }
  .novo-modality-item:nth-child(4n+1)  { border-left: none; }

  /* Responsive-control grids: set var fallbacks so Elementor tablet overrides work */
  .novo-category-grid { --eq-cat-cols: 2; }
  .value-stats        { --stats-cols: 2; }
  .team-grid     { --tm-cols: 2; }
  .novo-blog-grid     { --blog-cols: 2; grid-template-columns: repeat(2, 1fr); }
  .novo-dept-grid     { --dept-cols: 2; }
  /* Non-responsive grids: direct write is intentional */
  .novo-services-grid-3,
  .novo-services-grid-4 { grid-template-columns: repeat(2, 1fr); }
  .novo-timeline        { grid-template-columns: repeat(2, 1fr); }
  .novo-value-prop      { grid-template-columns: 1fr; }
  .novo-value-prop.img-right .vp-media   { order: 1; }
  .novo-value-prop.img-right .vp-content { order: 2; }
  .novo-trust-strip     { --ts-cols: 2; }
  .ts-slider-wrap       { --ts-per-view: 2; }
}

@media (max-width: 600px) {
  /* Category grid & modality grid use Elementor responsive controls for columns */
  .novo-category-grid { --eq-cat-cols: 2; }
  .novo-modality-grid { grid-template-columns: repeat(2, 1fr); }
  .novo-modality-item { border-left: none; border-top: 1px solid var(--novo-border); }
  .novo-modality-item:nth-child(-n+2) { border-top: none; }
  .novo-modality-item:nth-child(odd)  { border-left: none; }

  .novo-services-grid-2,
  .novo-services-grid-3,
  .novo-services-grid-4 { grid-template-columns: 1fr; }

  .novo-timeline   { grid-template-columns: 1fr; }
  .novo-timeline::before { display: none; }

  .value-stats     { --stats-cols: 2; }
  .novo-trust-strip { --ts-cols: 2; }
  .ts-slider-wrap   { --ts-per-view: 1; }
  /* Grids below use CSS vars controlled by Elementor responsive controls.
     Set variable fallbacks so stacking works when Elementor CSS hasn't generated yet. */
  .team-grid   { --tm-cols: 1; }
  .novo-blog-grid   { --blog-cols: 1; grid-template-columns: 1fr; }
  .novo-dept-grid   { --dept-cols: 1; }
  .types-grid       { --tradein-cols: 1; }
  .nvo-val-compact-grid,
  .values-grid  { --val-cols: 1; }

  .novo-hero-ctas .btn-primary,
  .novo-hero-ctas .btn-outline {
    width: 100%;
    justify-content: center;
  }
}


/* ═══════════════════════════════════════════════════════════
   ABOUT — VALUES SECTION  (.value-*)
   Three-column value cards: used in about-us page HTML widget.
═══════════════════════════════════════════════════════════ */
.values-header  { text-align: center; margin-bottom: 60px; }
.values-header .section-sub { margin: 0 auto; }
.values-grid    { display: grid; grid-template-columns: repeat(var(--val-cols, 3), 1fr); gap: 24px; }

.value-card {
  background: var(--novo-white);
  border-radius: 20px;
  padding: 40px 32px;
  box-shadow: 0 8px 40px var(--novo-shadow);
  position: relative;
  overflow: hidden;
  transition: transform .35s cubic-bezier(.22,.68,0,1.2), box-shadow .35s;
}
.value-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--novo-orange), var(--novo-orange-lite));
}
.value-card::after {
  content: '';
  position: absolute;
  bottom: -40px; right: -40px;
  width: 120px; height: 120px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(245,109,13,.07) 0%, transparent 70%);
  pointer-events: none;
  opacity: 0;
  transition: opacity .35s;
}
.value-card:hover::after { opacity: 1; }
.value-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 28px 70px rgba(11,57,84,.16);
}
.value-icon {
  width: 58px; height: 58px;
  background: rgba(245,109,13,.10);
  color: var(--novo-orange);
  border-radius: 16px;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px;
  margin-bottom: 24px;
  transition: background .3s, color .3s, border-radius .3s;
}
.value-card:hover .value-icon { background: var(--novo-orange); color: #fff; border-radius: 50%; }
.value-icon.vi-navy  { background: rgba(11,57,84,.10);       color: var(--novo-navy); }
.value-icon.vi-green { background: rgba(34,197,94,.12);      color: var(--novo-green); }
.value-icon.vi-blue  { background: rgba(26,96,144,.12);      color: var(--novo-blue); }
.value-icon.vi-orange { background: rgba(245,109,13,.10);    color: var(--novo-orange); }
.value-card h3 { font-size: 20px; font-weight: 800; color: var(--novo-navy); margin: 0 0 12px; }
.value-card p  { font-size: 14.5px; color: var(--novo-grey-tx); line-height: 1.75; margin: 0; }

@media (max-width: 1100px) { .values-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .values-grid { grid-template-columns: 1fr; } }



/* ═══════════════════════════════════════════════════════════
   HOME — SPARE PARTS PROMO  (.nvo-parts-*)
   Two-column: dark glass parts list left, text+CTA right.
═══════════════════════════════════════════════════════════ */
.nvo-parts-section  { padding: 112px 0; background: var(--novo-white); }
.nvo-parts-layout   { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center; }
.nvo-parts-visual   { position: relative; }

.nvo-parts-chip {
  position: absolute; top: -14px; right: -14px; z-index: 3;
  background: rgba(245,109,13,.20);
  border: 1px solid rgba(245,109,13,.40);
  backdrop-filter: blur(10px);
  border-radius: 50px;
  padding: 9px 18px;
  font-size: 11.5px; font-weight: 700;
  color: var(--novo-orange-lite);
  display: flex; align-items: center; gap: 7px;
  animation: floatY 8s ease-in-out infinite;
}
.nvo-parts-glass {
  background: var(--novo-navy-dark);
  border-radius: 24px; padding: 32px;
  box-shadow: 0 36px 88px rgba(7,31,46,.36);
  overflow: hidden; position: relative;
}
.nvo-parts-glass::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 80% 20%, rgba(245,109,13,.18) 0%, transparent 55%);
  pointer-events: none;
}
.nvo-parts-glass-title {
  font-size: 13px; font-weight: 700;
  color: rgba(255,255,255,.55);
  text-transform: uppercase; letter-spacing: 2.5px;
  margin-bottom: 22px;
}
.nvo-parts-list { display: flex; flex-direction: column; gap: 14px; position: relative; z-index: 1; }
.nvo-parts-row {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 16px; border-radius: 12px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
  transition: background .2s;
}
.nvo-parts-row:hover { background: rgba(255,255,255,.10); }
.nvo-parts-row-icon {
  width: 40px; height: 40px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 15px; flex-shrink: 0;
}
.nvo-pri-a { background: rgba(245,109,13,.18); color: var(--novo-orange-lite); }
.nvo-pri-b { background: rgba(26,96,144,.22);  color: #7ec8ef; }
.nvo-pri-c { background: rgba(15,163,96,.16);  color: #5de3a0; }
.nvo-pri-d { background: rgba(255,255,255,.10); color: rgba(255,255,255,.70); }
.nvo-parts-row-info  { flex: 1; }
.nvo-parts-row-name  { font-size: 13.5px; font-weight: 700; color: #fff; margin-bottom: 3px; }
.nvo-parts-row-compat{ font-size: 11.5px; color: rgba(255,255,255,.36); }
.nvo-parts-row-avail { font-size: 11.5px; font-weight: 700; color: #5de3a0; display: flex; align-items: center; gap: 5px; flex-shrink: 0; }

.nvo-parts-features {
  list-style: none;
  margin: 28px 0; padding: 0;
  display: flex; flex-direction: column; gap: 12px;
}
.nvo-parts-features li {
  display: flex; align-items: flex-start; gap: 12px;
  font-size: 15px; color: var(--novo-navy); font-weight: 500; line-height: 1.6;
}
.nvo-parts-feat-icon {
  width: 26px; height: 26px; border-radius: 8px;
  background: rgba(245,109,13,.10); color: var(--novo-orange);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; flex-shrink: 0; margin-top: 1px;
}
.nvo-parts-btn-row { display: flex; gap: 14px; flex-wrap: wrap; }

@media (max-width: 1000px) { .nvo-parts-layout { grid-template-columns: 1fr; gap: 40px; } }

/* ═══════════════════════════════════════════════════════════════════
   NEWS & PRESS PAGE
   Sections: hero, stats bar, featured story, filter pills,
             blog card grid widget, press kit, media contact
═══════════════════════════════════════════════════════════════════ */

/* ── Section-header utility ── */
/* s-eyebrow, s-title, s-sub, s-divider, section-header — defined in SHARED SECTION TYPOGRAPHY block */

/* ── News type tag badges ── */
.ntype { display: inline-flex; align-items: center; gap: 6px; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.5px; padding: 5px 13px; border-radius: 20px; margin-bottom: 14px; }
.ntype.press-release  { background: rgba(11,57,84,.09);    color: var(--novo-navy);    border: 1px solid rgba(11,57,84,.12); }
.ntype.media-coverage { background: rgba(31,164,99,.10);   color: #1fa463;             border: 1px solid rgba(31,164,99,.15); }
.ntype.award          { background: rgba(245,109,13,.10);  color: var(--novo-orange);  border: 1px solid rgba(245,109,13,.18); }
.ntype.company-update { background: rgba(122,144,160,.10); color: var(--novo-grey-tx); border: 1px solid rgba(122,144,160,.18); }

/* ── News hero ── */
.novo-news-hero {
  min-height: 88vh;
  background: radial-gradient(ellipse at 60% 40%, var(--novo-navy-mid) 0%, var(--novo-navy) 40%, var(--novo-navy-dark) 100%);
  display: flex; align-items: center;
  padding: calc(var(--novo-topbar-h, 36px) + var(--novo-hdr-h, 72px) + 60px) 24px 140px; position: relative; overflow: hidden;
}
.novo-news-hero::before {
  content: ''; position: absolute; width: 800px; height: 800px;
  border: 1px solid rgba(245,109,13,.08); border-radius: 50%;
  top: 50%; right: -200px; transform: translateY(-50%);
  animation: nvo-ring-pulse 7s ease-in-out infinite; pointer-events: none;
}
.novo-news-hero::after {
  content: ''; position: absolute; width: 500px; height: 500px;
  border: 1px solid rgba(245,109,13,.05); border-radius: 50%;
  top: 50%; right: -50px; transform: translateY(-50%);
  animation: nvo-ring-pulse 7s ease-in-out infinite .6s; pointer-events: none;
}
.novo-news-hero .hero-glow {
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse at 85% 20%, rgba(245,109,13,.20) 0%, transparent 50%),
    radial-gradient(ellipse at 10% 80%, rgba(245,109,13,.10) 0%, transparent 45%);
}
.novo-news-hero .hero-orb   { position: absolute; border-radius: 50%; filter: blur(72px); opacity: .28; pointer-events: none; animation: nvo-float-orb 9s ease-in-out infinite; }
.novo-news-hero .hero-orb-1 { width: 360px; height: 360px; background: var(--novo-orange); top: -80px;  right: -60px; }
.novo-news-hero .hero-orb-2 { width: 220px; height: 220px; background: #1A6090; bottom: 60px; left: -50px; animation-delay: -4s; }
.novo-news-hero .hero-grid  { position: relative; z-index: 2; display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center; }
.novo-news-hero .hero-badge { display: inline-flex; align-items: center; gap: 8px; background: rgba(245,109,13,.15); border: 1px solid rgba(245,109,13,.32); color: var(--novo-orange-lite); font-size: 11px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; padding: 8px 20px; border-radius: 50px; margin-bottom: 28px; }
.novo-news-hero .hero-headline    { font-size: clamp(42px,5.5vw,68px); font-weight: 900; line-height: 1.05; letter-spacing: -2px; color: #fff; margin-bottom: 24px; }
.novo-news-hero .hero-headline span { background: linear-gradient(90deg, var(--novo-orange), var(--novo-orange-lite)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.novo-news-hero .hero-sub   { font-size: 17px; color: rgba(255,255,255,.68); line-height: 1.8; margin-bottom: 36px; }
.novo-news-hero .hero-btns  { display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 22px; }
.novo-news-hero .hero-micro { display: flex; flex-wrap: wrap; gap: 18px; }
.novo-news-hero .hero-micro-item   { display: flex; align-items: center; gap: 6px; font-size: 12.5px; font-weight: 600; color: rgba(255,255,255,.42); }
.novo-news-hero .hero-micro-item i { color: var(--novo-orange); font-size: 11px; }
.novo-news-hero .hero-card       { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12); border-radius: 24px; padding: 32px; backdrop-filter: blur(12px); }
.novo-news-hero .hero-card-label { font-size: 11px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: rgba(255,255,255,.42); margin-bottom: 22px; display: flex; align-items: center; gap: 8px; }
.novo-news-hero .hero-card-label i { color: var(--novo-orange); }
.hnr { display: flex; align-items: flex-start; gap: 14px; padding: 15px 0; border-bottom: 1px solid rgba(255,255,255,.07); }
.hnr:last-child { border-bottom: none; padding-bottom: 0; }
.hnr-type { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.5px; padding: 3px 9px; border-radius: 8px; margin-bottom: 5px; display: inline-block; }
.hnr-type.pr { background: rgba(245,109,13,.18); color: var(--novo-orange-lite); }
.hnr-type.mc { background: rgba(31,164,99,.18);  color: #5de6a3; }
.hnr-type.aw { background: rgba(245,109,13,.18); color: var(--novo-orange-lite); }
.hnr-type.cu { background: rgba(255,255,255,.10); color: rgba(255,255,255,.60); }
.hnr-title   { font-size: 13.5px; font-weight: 700; color: #fff; line-height: 1.3; margin-bottom: 3px; }
.hnr-date    { font-size: 11px; color: rgba(255,255,255,.40); }

/* ── Stats bar ── */
.stats-section { background: var(--novo-grey-bg); padding: 0 0 72px; }
.stats-card {
  background: var(--novo-white); border-radius: 20px;
  box-shadow: 0 24px 80px rgba(11,57,84,.13);
  display: flex; overflow: hidden; position: relative;
  margin-top: -64px; z-index: 10;
}
.stats-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, var(--novo-orange), var(--novo-orange-lite), var(--novo-orange)); border-radius: 20px 20px 0 0; }
.stat-item { flex: 1; text-align: center; padding: 40px 24px; border-left: 1px solid var(--novo-border); position: relative; transition: background .3s; }
.stat-item:first-child { border-left: none; }
.stat-item::after { content: ''; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%) scaleX(0); width: 40px; height: 3px; background: var(--novo-orange); border-radius: 2px; transition: transform .35s ease; }
.stat-item:hover::after { transform: translateX(-50%) scaleX(1); }
.stat-item:hover { background: rgba(245,109,13,.02); }
.stat-num-wrap { display: flex; align-items: baseline; justify-content: center; gap: 2px; margin-bottom: 8px; }
.stat-num    { font-size: 44px; font-weight: 900; color: var(--novo-navy); line-height: 1; letter-spacing: -1px; }
.stat-suffix { font-size: 32px; font-weight: 900; color: var(--novo-orange); line-height: 1; }
.stat-label  { font-size: 13px; color: var(--novo-grey-tx); font-weight: 500; line-height: 1.45; max-width: 130px; margin: 0 auto; }

/* ── Featured story ── */
.feat-section { background: var(--novo-white); padding: 96px 0; }
.feat-card {
  display: grid; grid-template-columns: 45fr 55fr;
  border-radius: 24px; overflow: hidden;
  border: 1px solid var(--novo-border);
  box-shadow: 0 12px 60px rgba(11,57,84,.12); transition: box-shadow .35s;
}
.feat-card:hover { box-shadow: 0 28px 80px rgba(11,57,84,.18); }
.feat-visual {
  background: linear-gradient(135deg, var(--novo-navy) 0%, var(--novo-navy-mid) 50%, #0d5e87 100%);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 22px; padding: 60px 48px; position: relative; overflow: hidden; min-height: 400px;
}
.feat-visual::before {
  content: ''; position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 80% 18%, rgba(245,109,13,.28) 0%, transparent 55%),
    radial-gradient(ellipse at 15% 85%, rgba(245,109,13,.12) 0%, transparent 45%);
}
.feat-icon     { width: 90px; height: 90px; border-radius: 26px; background: rgba(245,109,13,.20); border: 2px solid rgba(245,109,13,.38); display: flex; align-items: center; justify-content: center; font-size: 38px; color: var(--novo-orange); position: relative; z-index: 1; }
.feat-vs-label { font-size: 15px; font-weight: 700; color: rgba(255,255,255,.65); position: relative; z-index: 1; text-align: center; max-width: 220px; line-height: 1.4; }
.feat-body     { padding: 48px; display: flex; flex-direction: column; justify-content: center; background: var(--novo-white); }
.feat-title    { font-size: clamp(22px,2.8vw,28px); font-weight: 900; color: var(--novo-navy); line-height: 1.2; letter-spacing: -.5px; margin-bottom: 18px; }
.feat-excerpt  { font-size: 15px; color: var(--novo-grey-tx); line-height: 1.85; margin-bottom: 26px; }
.feat-meta     { display: flex; align-items: center; gap: 14px; padding-top: 20px; border-top: 1px solid var(--novo-border); margin-bottom: 26px; flex-wrap: wrap; }
.feat-date-chip  { display: flex; align-items: center; gap: 6px; font-size: 12.5px; font-weight: 600; color: var(--novo-grey-tx); }
.feat-read-more  { display: inline-flex; align-items: center; gap: 8px; font-size: 14.5px; font-weight: 700; color: var(--novo-orange); transition: gap .2s; text-decoration: none; }
.feat-read-more:hover   { gap: 13px; color: var(--novo-orange-dark); }
.feat-read-more i       { transition: transform .2s; }
.feat-read-more:hover i { transform: translateX(3px); }

/* ── Press kit ── */
.nvo-kit-section { background: var(--novo-navy-dark); padding: 96px 0; position: relative; overflow: hidden; }
.nvo-kit-section::before { content: ''; position: absolute; inset: 0; pointer-events: none; background: radial-gradient(ellipse at 75% 50%, rgba(245,109,13,.18) 0%, transparent 55%); }
.nvo-kit-section::after  { content: ''; position: absolute; width: 600px; height: 600px; border: 1px solid rgba(245,109,13,.06); border-radius: 50%; top: 50%; right: -100px; transform: translateY(-50%); pointer-events: none; }
.nvo-kit-inner   { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr 380px; gap: 72px; align-items: start; }
.nvo-kit-eyebrow { font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: 3px; color: var(--novo-orange-lite); margin-bottom: 14px; }
.nvo-kit-title   { font-size: clamp(26px,3.5vw,36px); font-weight: 900; color: #fff; line-height: 1.15; letter-spacing: -.8px; margin-bottom: 14px; }
.nvo-kit-title span { color: var(--novo-orange); }
.nvo-kit-sub     { font-size: 15px; color: rgba(255,255,255,.50); line-height: 1.80; margin-bottom: 30px; }
.nvo-kit-downloads { display: flex; flex-direction: column; gap: 10px; }
.nvo-kit-dl {
  display: flex; align-items: center; gap: 14px;
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.10);
  border-radius: 12px; padding: 14px 18px;
  transition: background .25s, border-color .25s, transform .2s;
}
.nvo-kit-dl:hover  { background: rgba(255,255,255,.10); border-color: rgba(245,109,13,.30); transform: translateX(4px); }
.nvo-kit-dl-icon   { width: 36px; height: 36px; flex-shrink: 0; border-radius: 9px; background: rgba(245,109,13,.18); border: 1px solid rgba(245,109,13,.28); display: flex; align-items: center; justify-content: center; font-size: 14px; color: var(--novo-orange); }
.nvo-kit-dl-name   { font-size: 13.5px; font-weight: 700; color: #fff; display: block; margin-bottom: 2px; }
.nvo-kit-dl-size   { font-size: 11px; color: rgba(255,255,255,.38); }
.nvo-kit-dl-arrow  { margin-left: auto; color: rgba(255,255,255,.35); font-size: 13px; transition: color .2s; }
.nvo-kit-dl:hover .nvo-kit-dl-arrow { color: var(--novo-orange); }

/* ── Media contact card ── */
.nvo-contact-card { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12); border-radius: 22px; padding: 30px; }
.nvo-cc-label   { font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: 2px; color: rgba(255,255,255,.38); margin-bottom: 20px; }
.nvo-cc-profile { display: flex; align-items: center; gap: 16px; margin-bottom: 22px; padding-bottom: 22px; border-bottom: 1px solid rgba(255,255,255,.08); }
.nvo-cc-avatar  {
  width: 58px; height: 58px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg, var(--novo-navy) 0%, var(--novo-navy-mid) 100%);
  border: 2px solid rgba(255,255,255,.15);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; font-weight: 900; color: #fff; overflow: hidden;
}
.nvo-cc-avatar img { width: 100%; height: 100%; object-fit: cover; }
.nvo-cc-name    { font-size: 15px; font-weight: 800; color: #fff; display: block; margin-bottom: 2px; }
.nvo-cc-role    { font-size: 12px; color: rgba(255,255,255,.50); }
.nvo-cc-links   { display: flex; flex-direction: column; gap: 10px; }
.nvo-cc-link    {
  display: flex; align-items: center; gap: 10px;
  font-size: 13px; font-weight: 600; color: rgba(255,255,255,.70);
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08);
  border-radius: 10px; padding: 11px 14px;
  transition: background .2s, color .2s, border-color .2s; text-decoration: none;
}
.nvo-cc-link:hover { background: rgba(245,109,13,.15); border-color: rgba(245,109,13,.28); color: var(--novo-orange-lite); }
.nvo-cc-link i  { color: var(--novo-orange); width: 16px; text-align: center; flex-shrink: 0; }
.nvo-cc-avail   { margin-top: 8px; padding-top: 16px; border-top: 1px solid rgba(255,255,255,.08); font-size: 11px; color: rgba(255,255,255,.35); line-height: 1.6; }

/* ── News page responsive ── */
@media (max-width: 1100px) {
  .novo-news-hero .hero-grid  { grid-template-columns: 1fr; gap: 44px; }
  .feat-card { grid-template-columns: 1fr; }
  .feat-visual { min-height: 260px; }
  .nvo-kit-inner      { grid-template-columns: 1fr; }
  .novo-blog-grid     { --blog-cols: 2; }
}
@media (max-width: 768px) {
  .stats-card { flex-wrap: wrap; }
  .stat-item { min-width: 50%; }
  .novo-blog-grid { --blog-cols: 1; }
}

/* ═══════════════════════════════════════════════════════════
   HERO WIDGET  (.novo-hero two-column layout)
   ═══════════════════════════════════════════════════════════ */
.novo-hero { position: relative; overflow: hidden; padding: 120px 0 100px; background: radial-gradient(ellipse at 65% 40%, var(--novo-navy-mid) 0%, var(--novo-navy) 45%, var(--novo-navy-dark) 100%); }
.hero-dots  { position: absolute; inset: 0; background-image: radial-gradient(circle, rgba(255,255,255,.022) 1px, transparent 1px); background-size: 38px 38px; pointer-events: none; }
.hero-ring  { position: absolute; width: 700px; height: 700px; border-radius: 50%; border: 1px solid rgba(245,109,13,.06); top: 50%; left: 55%; transform: translate(-50%,-50%); pointer-events: none; animation: ringPulse 11s ease-in-out infinite; }
.hero-ring2 { position: absolute; width: 950px; height: 950px; border-radius: 50%; border: 1px solid rgba(245,109,13,.04); top: 50%; left: 55%; transform: translate(-50%,-50%); pointer-events: none; animation: ringPulse 11s ease-in-out infinite 1.4s; }
.hero-orb-1 { position: absolute; width: 420px; height: 420px; border-radius: 50%; background: radial-gradient(circle, rgba(245,109,13,.18) 0%, transparent 70%); top: -100px; right: 5%; pointer-events: none; }
.hero-orb-2 { position: absolute; width: 320px; height: 320px; border-radius: 50%; background: radial-gradient(circle, rgba(26,96,144,.22) 0%, transparent 70%); bottom: -80px; left: 8%; pointer-events: none; }

.hero-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; position: relative; z-index: 1; }

/* Left: copy */
.hero-copy { }
.hero-badge { display: inline-flex; align-items: center; gap: 8px; font-size: 12.5px; font-weight: 700; color: var(--novo-orange-lite); background: rgba(245,109,13,.12); border: 1px solid rgba(245,109,13,.22); border-radius: 20px; padding: 7px 16px; margin-bottom: 28px; }
.hero-badge i { font-size: 7px; color: var(--novo-orange); }
.hero-h1,
.hero-headline { font-size: clamp(38px, 5.2vw, 62px); font-weight: 900; color: #fff; line-height: 1.05; letter-spacing: -2px; margin-bottom: 22px; }
.hero-h1 em,
.hero-headline .hero-hl2 {
  display: block;
  font-style: normal;
  background: linear-gradient(90deg, var(--novo-orange), var(--novo-orange-lite));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.hero-headline .hero-hl1 { display: block; color: #fff; }
.hero-sub { font-size: 15.5px; color: rgba(255,255,255,.56); line-height: 1.82; margin-bottom: 36px; max-width: 540px; }
.hero-btns { display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 32px; }
.hero-trust { display: flex; flex-wrap: wrap; gap: 10px; }

/* Trust pills */
.trust-pill { display: inline-flex; align-items: center; gap: 7px; font-size: 12.5px; font-weight: 700; padding: 7px 15px; border-radius: 20px; }
.tp-white  { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.14); color: rgba(255,255,255,.75); }
.tp-orange { background: rgba(245,109,13,.14); border: 1px solid rgba(245,109,13,.28); color: var(--novo-orange-lite); }
.tp-green  { background: rgba(15,163,96,.12);  border: 1px solid rgba(15,163,96,.26);  color: #5de3a0; }
.tp-blue   { background: rgba(26,96,144,.14);  border: 1px solid rgba(26,96,144,.28);  color: #7ec8ef; }

/* Right: visual */
.hero-visual { position: relative; }

/* ── Hero Stats Card variant  (about-page right column) ───────────────────── */
.hero-card {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 24px;
  padding: 36px;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.hero-card-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: rgba(255,255,255,.45);
  margin-bottom: 28px;
}

/* ── Hero Accept List (Trade-In right column) ── */
.accept-list { display: flex; flex-direction: column; gap: 10px; }
.accept-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 12px;
  transition: background .2s;
}
.accept-row:hover { background: rgba(255,255,255,.09); }
.accept-icon {
  width: 36px;
  height: 36px;
  background: rgba(245,109,13,.18);
  border: 1px solid rgba(245,109,13,.28);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  color: var(--novo-orange, #f56d0d);
  flex-shrink: 0;
}
.accept-name { font-size: 13.5px; font-weight: 700; color: #fff; }
.accept-sub  { font-size: 11px; color: rgba(255,255,255,.40); margin-top: 1px; }
.accept-check {
  margin-left: auto;
  width: 20px;
  height: 20px;
  background: rgba(31,164,99,.20);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.accept-check i { color: #5de6a3; font-size: 9px; }
/* ── End Hero Accept List ── */

.hero-quick-stat {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 18px 0;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.hero-quick-stat:last-child { border-bottom: none; }
.hqs-icon {
  width: 48px;
  height: 48px;
  background: rgba(245,109,13,.18);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  color: var(--novo-orange, #f56d0d);
  flex-shrink: 0;
}
.hqs-num {
  font-size: 28px;
  font-weight: 900;
  color: #fff;
  line-height: 1;
  letter-spacing: -1px;
}
.hqs-num span { font-size: 20px; color: var(--novo-orange, #f56d0d); }
.hqs-label {
  font-size: 13px;
  color: rgba(255,255,255,.55);
  margin-top: 3px;
}
/* ── End Hero Stats Card ───────────────────────────────────────────────────── */

.hero-img-frame { border-radius: 22px; overflow: hidden; position: relative; box-shadow: 0 40px 100px rgba(0,0,0,.42); }
.hero-img-frame img { width: 100%; display: block; }

.hif-cert { position: absolute; top: 18px; left: 18px; display: flex; align-items: center; gap: 10px; background: rgba(7,31,46,.78); backdrop-filter: blur(12px); border: 1px solid rgba(255,255,255,.15); border-radius: 14px; padding: 10px 14px; }
.hif-cert-icon { font-size: 18px; color: var(--novo-orange-lite); }
.hif-cert-label { font-size: 12px; font-weight: 800; color: #fff; }
.hif-cert-sub   { font-size: 10.5px; color: rgba(255,255,255,.48); margin-top: 2px; }

.hif-bottom { position: absolute; bottom: 0; left: 0; right: 0; padding: 16px 18px 18px; background: linear-gradient(0deg, rgba(7,31,46,.88) 0%, transparent 100%); }
.hif-title  { font-size: 14px; font-weight: 800; color: #fff; margin-bottom: 8px; }
.hif-tags   { display: flex; flex-wrap: wrap; gap: 6px; }
.hif-tag    { font-size: 11px; font-weight: 700; padding: 4px 11px; border-radius: 20px; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.18); color: rgba(255,255,255,.80); }
.hif-tag.green { background: rgba(15,163,96,.20); border-color: rgba(15,163,96,.32); color: #5de3a0; }

/* Floating chips */
.hchip { position: absolute; display: flex; align-items: center; gap: 7px; padding: 9px 15px; border-radius: 30px; font-size: 12px; font-weight: 700; color: #fff; background: rgba(7,31,46,.80); backdrop-filter: blur(12px); border: 1px solid rgba(255,255,255,.15); white-space: nowrap; box-shadow: 0 8px 28px rgba(0,0,0,.28); animation: floatY 8s ease-in-out infinite; }
.hchip-1 { top: -14px; right: 30px; animation-delay: 0s; }
.hchip-2 { top: 50%;  right: -18px; transform: translateY(-50%); animation-delay: 2.5s; }
.hchip-3 { bottom: 60px; right: -10px; animation-delay: 5s; }

@media (max-width: 1100px) { .hero-layout { gap: 40px; } }
@media (max-width: 900px) {
  .hero-layout { grid-template-columns: 1fr; text-align: center; }
  .hero-sub   { margin-left: auto; margin-right: auto; }
  .hero-btns  { justify-content: center; }
  .hero-trust { justify-content: center; }
  .hero-visual { display: none; }
  .hero-card { display: none; }
}
@media (max-width: 560px) { .hero-h1 { font-size: 32px; } }

/* ═══════════════════════════════════════════════════════════
   AVAILABLE SYSTEMS CARD  (.avail-card)
   ═══════════════════════════════════════════════════════════ */
.avail-card { background: var(--novo-grey-bg, #f6f8fb); border-radius: 20px; border: 1px solid var(--novo-border, rgba(11,57,84,.10)); overflow: hidden; display: flex; flex-direction: column; transition: transform .32s cubic-bezier(.22,.68,0,1.2), box-shadow .32s; box-shadow: 0 2px 14px rgba(11,57,84,.07); }
.avail-card:hover { transform: translateY(-8px); box-shadow: 0 28px 72px rgba(11,57,84,.13); }

.avail-card-top { display: flex; align-items: center; justify-content: space-between; padding: 18px 18px 14px; }
.avail-thumb { width: 52px; height: 52px; border-radius: 14px; display: flex; align-items: center; justify-content: center; font-size: 22px; overflow: hidden; }
.avail-thumb img { width: 100%; height: 100%; object-fit: cover; }
.avail-thumb-blue   { background: linear-gradient(135deg, var(--novo-navy, #0b3954), #1a6090); color: #fff; }
.avail-thumb-orange { background: linear-gradient(135deg, #7c3900, #f56d0d); color: #fff; }
.avail-thumb-teal   { background: linear-gradient(135deg, #074a5e, #0d8a9c); color: #fff; }
.avail-thumb-purple { background: linear-gradient(135deg, #2d1a6b, #5a3ec8); color: #fff; }

.avail-status { display: inline-flex; align-items: center; gap: 6px; font-size: 11.5px; font-weight: 700; padding: 6px 13px; border-radius: 20px; }
.avail-status i { font-size: 7px; }
.avail-status-green { background: rgba(15,163,96,.10); border: 1px solid rgba(15,163,96,.28); color: #0fa360; }
.avail-status-blue  { background: rgba(26,96,144,.10); border: 1px solid rgba(26,96,144,.28); color: #1a6090; }
.avail-status-grey  { background: rgba(0,0,0,.06);    border: 1px solid rgba(0,0,0,.12);    color: #888; }

.avail-card-body { padding: 0 14px 10px; flex: 1; display: flex; flex-direction: column; }
.avail-brand { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.5px; color: var(--novo-grey-tx, #6b7a8d); margin-bottom: 4px; }
.avail-name  { font-size: 13.5px; font-weight: 800; color: var(--novo-navy, #0b3954); letter-spacing: -.3px; line-height: 1.3; margin-bottom: 8px; min-height: 53px; }
.avail-name a { color: inherit; text-decoration: none; }
.avail-name a:hover { color: var(--novo-orange, #f56d0d); }
.avail-meta  { display: flex; flex-direction: column; gap: 4px; margin-bottom: 8px; }
.avail-meta span { display: flex; align-items: center; gap: 6px; font-size: 11.5px; color: var(--novo-grey-tx, #6b7a8d); font-weight: 500; }
.avail-meta i { color: var(--novo-orange, #f56d0d); width: 12px; font-size: 10px; }
.avail-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.avail-tag  { font-size: 11px; font-weight: 700; padding: 4px 11px; border-radius: 20px; background: rgba(11,57,84,.06); color: var(--novo-navy, #0b3954); border: 1px solid var(--novo-border, rgba(11,57,84,.10)); }

.avail-card-footer { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; border-top: 1px solid var(--novo-border, rgba(11,57,84,.10)); background: #fff; }
.avail-cta  { display: inline-flex; align-items: center; gap: 7px; font-size: 13px; font-weight: 700; color: var(--novo-orange, #f56d0d); text-decoration: none; transition: gap .2s; }
.avail-cta:hover { gap: 11px; }
.avail-ref  { font-size: 10.5px; color: var(--novo-grey-tx, #6b7a8d); font-weight: 600; letter-spacing: .5px; }

/* ═══════════════════════════════════════════════════════════
   EQUIPMENT CATEGORY CARDS  (.equip-card)
   Already declared in previous sessions; ensure vars are mapped
   ═══════════════════════════════════════════════════════════ */
.equip-card { border-radius: 22px; overflow: hidden; border: 1px solid var(--novo-border, rgba(11,57,84,.10)); background: var(--novo-grey-bg, #f6f8fb); box-shadow: 0 4px 20px rgba(11,57,84,.07); transition: transform .35s cubic-bezier(.22,.68,0,1.2), box-shadow .35s; }
.equip-card:hover { transform: translateY(-9px); box-shadow: 0 32px 80px rgba(11,57,84,.14); }
.equip-thumb { width: 100%; height: 200px; display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; }
.equip-thumb-bg { position: absolute; inset: 0; }
.etb-blue   { background: linear-gradient(135deg, var(--novo-navy, #0b3954) 0%, #1a6090 100%); }
.etb-orange { background: linear-gradient(135deg, #7c3900 0%, #f56d0d 100%); }
.etb-teal   { background: linear-gradient(135deg, #074a5e 0%, #0d8a9c 100%); }
.equip-thumb-icon { position: relative; z-index: 1; font-size: 64px; opacity: .22; color: #fff; }
.equip-thumb-chip { position: absolute; top: 16px; right: 16px; z-index: 2; background: rgba(7,31,46,.7); backdrop-filter: blur(10px); border: 1px solid rgba(255,255,255,.18); border-radius: 20px; padding: 5px 13px; font-size: 11px; font-weight: 700; color: #fff; }
.equip-body { padding: 24px 22px 22px; }
.equip-body h3 { font-size: 17px; font-weight: 800; color: var(--novo-navy, #0b3954); margin-bottom: 8px; letter-spacing: -.4px; }
.equip-body p  { font-size: 13.5px; color: var(--novo-grey-tx, #6b7a8d); line-height: 1.70; margin-bottom: 18px; }
.equip-brands { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 20px; }
.equip-brand  { font-size: 11.5px; font-weight: 700; padding: 4px 12px; border-radius: 20px; background: rgba(11,57,84,.06); color: var(--novo-navy, #0b3954); border: 1px solid var(--novo-border, rgba(11,57,84,.10)); }
.equip-cta    { display: inline-flex; align-items: center; gap: 7px; font-size: 13px; font-weight: 700; color: var(--novo-orange, #f56d0d); text-decoration: none; }
.equip-cta i  { transition: transform .2s; }
.equip-card:hover .equip-cta i { transform: translateX(5px); }

/* ═══════════════════════════════════════════════════════════
   MODALITY GRID WRAPPER  (.mod-card)
   ═══════════════════════════════════════════════════════════ */
.mod-card { border-radius: 20px; border: 1px solid var(--novo-border, rgba(11,57,84,.10)); overflow: hidden; background: #fff; box-shadow: 0 4px 20px rgba(11,57,84,.06); }
.mod-card-hd { display: flex; align-items: center; justify-content: space-between; padding: 20px 24px; border-bottom: 1px solid var(--novo-border, rgba(11,57,84,.10)); flex-wrap: wrap; gap: 10px; }
.mod-badge { display: inline-flex; align-items: center; gap: 8px; font-size: 12.5px; font-weight: 700; color: var(--novo-navy, #0b3954); background: rgba(11,57,84,.06); border: 1px solid var(--novo-border, rgba(11,57,84,.10)); border-radius: 20px; padding: 6px 14px; }
.mod-count { font-size: 13.5px; font-weight: 600; color: var(--novo-grey-tx, #6b7a8d); }
.mod-count strong { color: var(--novo-navy, #0b3954); font-weight: 800; }

/* Modality grid — columns now set by Elementor responsive control (selectors) */
.novo-modality-grid { display: grid; gap: 10px; }

/* ═══════════════════════════════════════════════════════════
   DEPARTMENT CARDS — contact link
   ═══════════════════════════════════════════════════════════ */
.dept-contact-link { display: inline-flex; align-items: center; gap: 6px; font-size: 12.5px; font-weight: 600; color: var(--novo-grey-tx, #6b7a8d); text-decoration: none; transition: color .2s; }
.dept-contact-link:hover { color: var(--novo-orange, #f56d0d); }

/* ══════════════════════════════════════════════════════════════════════
   WHY SECTION  (.why-section)
   ══════════════════════════════════════════════════════════════════════ */
.why-section { padding: 96px 0; background: var(--novo-grey-bg); }

/* ── Why Card Grid — 3-column card layout (Trade-In "Why Choose NOVO") ── */
.why-card-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.why-card {
  background: #fff;
  border-radius: 20px;
  border: 1px solid var(--novo-border, rgba(11,57,84,.10));
  padding: 32px 28px;
  box-shadow: 0 4px 24px rgba(11,57,84,.06);
  transition: transform .35s cubic-bezier(.22,.68,0,1.2), box-shadow .35s, border-color .35s;
}
.why-card:hover { transform: translateY(-6px); box-shadow: 0 20px 60px rgba(11,57,84,.12); border-color: rgba(245,109,13,.20); }
.why-icon {
  width: 52px; height: 52px;
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px;
  margin-bottom: 18px;
}
.why-icon.a { background: rgba(11,57,84,.08);   color: var(--novo-navy, #0b3954); }
.why-icon.b { background: rgba(245,109,13,.10); color: var(--novo-orange, #f56d0d); }
.why-icon.c { background: rgba(31,164,99,.10);  color: #1fa463; }
.why-icon.d { background: rgba(26,96,144,.12);  color: #1a6090; }
.why-icon.e { background: rgba(245,109,13,.10); color: var(--novo-orange, #f56d0d); }
.why-icon.f { background: rgba(11,57,84,.08);   color: var(--novo-navy, #0b3954); }
.why-title { font-size: 16px; font-weight: 800; color: var(--novo-navy, #0b3954); margin-bottom: 9px; letter-spacing: -.2px; }
.why-desc  { font-size: 13.5px; color: var(--novo-grey-tx, #6b7a8d); line-height: 1.70; }

/* ── Legacy About-page why-grid (2 column list + card layout) ── */
.why-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}
.why-list { display: flex; flex-direction: column; gap: 20px; }
.why-item {
  display: flex;
  gap: 20px;
  align-items: flex-start;
  padding: 24px;
  background: var(--novo-white, #fff);
  border-radius: 16px;
  box-shadow: 0 4px 20px rgba(11,57,84,.10);
  transition: transform .3s, box-shadow .3s;
}
.why-item:hover { transform: translateX(6px); box-shadow: 0 12px 40px rgba(11,57,84,.14); }
.why-num {
  width: 38px;
  height: 38px;
  background: var(--novo-orange, #f56d0d);
  color: #fff;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 800;
  flex-shrink: 0;
}
.why-body h4 {
  font-size: 15px;
  font-weight: 800;
  color: var(--novo-navy, #0b3954);
  margin: 0 0 6px;
}
.why-body p {
  font-size: 13.5px;
  color: var(--novo-grey-tx, #6b7a8d);
  line-height: 1.65;
  margin: 0;
}

/* Right card */
.why-big-card {
  background: var(--novo-navy, #0b3954);
  border-radius: 24px;
  padding: 44px 40px;
  color: #fff;
  position: sticky;
  top: 80px;
}
.why-big-inner { display: flex; flex-direction: column; gap: 0; }
.why-quote {
  font-size: 88px;
  line-height: .7;
  color: var(--novo-orange, #f56d0d);
  margin-bottom: 16px;
}
.why-big-text {
  font-size: 18px;
  font-weight: 500;
  line-height: 1.7;
  color: rgba(255,255,255,.88);
  margin: 0 0 32px;
}
.why-big-author {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 36px;
}
.why-author-avatar {
  width: 48px; height: 48px;
  border-radius: 50%;
  background: var(--novo-orange, #f56d0d);
  color: #fff;
  font-size: 15px;
  font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.why-author-name {
  font-size: 15px;
  font-weight: 700;
  color: #fff;
}
.why-author-role {
  font-size: 12.5px;
  color: rgba(255,255,255,.55);
}
.why-counters {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  border-top: 1px solid rgba(255,255,255,.12);
  padding-top: 28px;
}
.why-counter {
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 14px;
  padding: 16px 18px;
}
.why-counter-num {
  font-size: 26px;
  font-weight: 800;
  color: #fff;
  line-height: 1;
  margin-bottom: 4px;
}
.why-counter-num span {
  font-size: 18px;
  color: var(--novo-orange, #f56d0d);
}
.why-counter-label {
  font-size: 12px;
  color: rgba(255,255,255,.55);
  line-height: 1.4;
}

@media (max-width: 960px) {
  .why-card-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .why-card-grid { grid-template-columns: 1fr; }
}
@media (max-width: 900px) {
  .why-grid { grid-template-columns: 1fr; gap: 48px; }
  .why-big-card { position: static; }
}
@media (max-width: 600px) {
  .why-counters { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════════════════════════════════
   PARTS FEATURE SECTION  (.nvo-parts-section)
   ══════════════════════════════════════════════════════════════════════ */
.nvo-parts-section { padding: 96px 0; }
.nvo-parts-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}

/* Left: visual */
.nvo-parts-visual { position: relative; }
.nvo-parts-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 700;
  color: var(--novo-orange, #f56d0d);
  background: rgba(245,109,13,.10);
  border: 1px solid rgba(245,109,13,.22);
  border-radius: 30px;
  padding: 7px 16px;
  margin-bottom: 20px;
}
.nvo-parts-glass {
  background: var(--novo-navy, #0b3954);
  border-radius: 20px;
  padding: 28px 24px;
  box-shadow: 0 28px 80px rgba(11,57,84,.20);
}
.nvo-parts-glass-title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: rgba(255,255,255,.45);
  margin-bottom: 18px;
}
.nvo-parts-list { display: flex; flex-direction: column; gap: 0; }
.nvo-parts-row {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 0;
  border-bottom: 1px solid rgba(255,255,255,.07);
}
.nvo-parts-row:last-child { border-bottom: none; }
.nvo-parts-row-icon {
  width: 36px; height: 36px;
  background: rgba(255,255,255,.08);
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  color: var(--novo-orange, #f56d0d);
  font-size: 14px;
  flex-shrink: 0;
}
.nvo-parts-row-info { flex: 1; min-width: 0; }
.nvo-parts-row-name {
  font-size: 13.5px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 2px;
}
.nvo-parts-row-compat {
  font-size: 11.5px;
  color: rgba(255,255,255,.45);
}
.nvo-parts-row-avail {
  font-size: 10.5px;
  font-weight: 700;
  border-radius: 20px;
  padding: 3px 10px;
  flex-shrink: 0;
}
.nvo-avail-in-stock { background: rgba(31,164,99,.18); color: #5de6a3; }
.nvo-avail-pending  { background: rgba(245,109,13,.18); color: #f9a754; }
.nvo-avail-eol      { background: rgba(255,255,255,.12); color: rgba(255,255,255,.50); }

/* Right: content */
.nvo-parts-right {}
.nvo-parts-features {
  list-style: none;
  margin: 20px 0 32px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.nvo-parts-features li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 14.5px;
  color: var(--novo-grey-tx, #6b7a8d);
  line-height: 1.5;
}
.nvo-parts-feat-icon {
  width: 22px; height: 22px;
  background: rgba(31,164,99,.12);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: #1fa463;
  font-size: 11px;
  flex-shrink: 0;
  margin-top: 1px;
}
.nvo-parts-btn-row {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 32px;
}

@media (max-width: 900px) {
  .nvo-parts-layout { grid-template-columns: 1fr; gap: 48px; }
}

/* ══════════════════════════════════════════════════════════════════════
   LOGO WIDGET  (.novo-logo-link)
   ══════════════════════════════════════════════════════════════════════ */
.novo-logo-link {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  flex-shrink: 0;
}
.novo-logo-icon {
  width: 38px; height: 38px;
  border-radius: 10px;
  background: linear-gradient(135deg, #F56D0D 0%, #d95e00 100%);
  display: flex; align-items: center; justify-content: center;
  font-size: 17px; font-weight: 900;
  color: #fff; letter-spacing: -1px;
  box-shadow: 0 4px 14px rgba(245,109,13,.36);
}
.novo-logo-text {
  display: flex;
  flex-direction: column;
  line-height: 1;
}
.novo-logo-name {
  font-size: 19px; font-weight: 900;
  color: #0B3954; letter-spacing: .5px;
  text-transform: uppercase;
  font-family: Inter, sans-serif;
}
.novo-logo-tagline {
  font-size: 8px; font-weight: 700;
  color: #7A90A0; letter-spacing: 3px;
  text-transform: uppercase; margin-top: 3px;
  font-family: Inter, sans-serif;
}
.novo-logo-img { display: block; width: auto; }

/* ══════════════════════════════════════════════════════════════════════════════
   CONTACT FORM  (.main-section)
   ══════════════════════════════════════════════════════════════════════════════ */
.main-section { padding: 96px 0; background: #fff; }

.main-grid {
  display: grid;
  grid-template-columns: 55fr 45fr;
  gap: 72px;
  align-items: start;
}

.form-sub {
  font-size: 15px; color: var(--novo-grey-tx, #7A90A0);
  line-height: 1.8; margin-bottom: 32px;
}
.map-col .section-sub { margin-bottom: 22px; }

.nvo-cf-toast {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 18px; border-radius: 12px;
  font-size: 14px; font-weight: 600; margin-top: 14px;
  background: #eaf9f0; border: 1.5px solid #6bc88a; color: #1a6b3a;
}
.nvo-cf-toast[hidden] { display: none; }
.nvo-cf-toast i { font-size: 18px; flex-shrink: 0; color: #2d9e5f; }
.nvo-cf-toast--error { background: #fef2f2; border-color: #f4a0a0; color: #9b1c1c; }
.nvo-cf-toast--error i { color: #e02424; }

.map-wrap {
  width: 100%; border-radius: 16px; overflow: hidden;
  margin-bottom: 24px; box-shadow: 0 8px 32px rgba(11,57,84,.10);
}
.map-embed { width: 100%; height: 260px; display: block; border: none; }

.addr-list { display: flex; flex-direction: column; gap: 12px; margin-bottom: 20px; }

.addr-card {
  display: flex; align-items: flex-start; gap: 16px;
  background: var(--novo-grey-bg, #F7F8FA);
  padding: 16px 18px; border-radius: 14px;
  transition: background .25s, box-shadow .25s;
}
.addr-card:hover { background: #fff; box-shadow: 0 6px 24px rgba(11,57,84,.10); }

.addr-icon {
  width: 40px; height: 40px; background: rgba(245,109,13,.12);
  color: var(--novo-orange); border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 15px; flex-shrink: 0; transition: background .25s, color .25s;
}
.addr-card:hover .addr-icon { background: var(--novo-orange); color: #fff; }

.addr-body h4 {
  font-size: 13px; font-weight: 700;
  color: var(--novo-navy, #0B3954); margin-bottom: 3px;
}
.addr-body p { font-size: 13px; color: var(--novo-grey-tx, #7A90A0); line-height: 1.5; }
.addr-body a {
  display: inline-block; font-size: 12px; font-weight: 700;
  color: var(--novo-orange); margin-top: 5px; transition: color .2s;
}
.addr-body a:hover { color: var(--novo-orange-dark, #d95e00); }


/* ══════════════════════════════════════════════════════════════════════
   TRADE-IN — FORM SECTION
   Widget: widget-novo-tradein-form (.form-section / .novo-tradein-form-section)
   ══════════════════════════════════════════════════════════════════════ */
.form-section,
.novo-tradein-form-section {
  background: var(--novo-navy-dark, #071a28);
  padding: 96px 0;
  position: relative;
  overflow: hidden;
}
.form-section::before,
.novo-tradein-form-section::before {
  content: '';
  position: absolute; inset: 0;
  pointer-events: none;
  background: radial-gradient(ellipse at 75% 50%, rgba(245,109,13,.18) 0%, transparent 55%);
}

.form-inner {
  position: relative; z-index: 1;
  display: grid;
  grid-template-columns: 1fr 480px;
  gap: 72px;
  align-items: start;
}

.form-eyebrow {
  font-size: 10.5px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 3px;
  color: var(--novo-orange-lite, #f9a754);
  margin-bottom: 14px;
}

.form-title {
  font-size: clamp(26px, 3.5vw, 38px); font-weight: 900;
  color: #fff; line-height: 1.15; letter-spacing: -.8px;
  margin-bottom: 14px;
}
.form-title span { color: var(--novo-orange, #f56d0d); }

.form-section .form-sub,
.novo-tradein-form-section .form-sub {
  font-size: 15px; color: rgba(255,255,255,.52);
  line-height: 1.80; margin-bottom: 28px;
}

.form-perks { display: flex; flex-direction: column; gap: 11px; }

.form-perk {
  display: flex; align-items: center; gap: 10px;
  font-size: 13px; font-weight: 600; color: rgba(255,255,255,.60);
}
.form-perk i { color: var(--novo-orange, #f56d0d); font-size: 12px; width: 14px; flex-shrink: 0; }

.form-card {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 22px; padding: 32px;
  backdrop-filter: blur(10px);
}

.fc-title {
  font-size: 14px; font-weight: 800; color: #fff;
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 22px;
}
.fc-title i { color: var(--novo-orange-lite, #f9a754); }

@media (max-width: 900px) {
  .form-inner { grid-template-columns: 1fr; }
}

.hours-card {
  background: var(--novo-grey-bg, #F7F8FA);
  border-radius: 14px; padding: 20px; border-left: 4px solid var(--novo-orange);
}
.hours-card h4 {
  font-size: 14px; font-weight: 800; color: var(--novo-navy, #0B3954);
  margin-bottom: 14px; display: flex; align-items: center; gap: 8px;
}
.hours-card h4 i { color: var(--novo-orange); font-size: 13px; }
.hours-table { width: 100%; border-collapse: collapse; }
.hours-table tr td { padding: 7px 0; font-size: 13px; border-bottom: 1px solid rgba(0,0,0,.06); }
.hours-table tr:last-child td { border-bottom: none; }
.hours-table td:first-child { color: var(--novo-navy, #0B3954); font-weight: 600; }
.hours-table td:last-child { text-align: right; color: var(--novo-grey-tx, #7A90A0); font-weight: 500; }
.closed { color: #D94040 !important; font-weight: 600 !important; }
.hours-note { font-size: 12px; color: var(--novo-grey-tx, #7A90A0); font-style: italic; margin-top: 12px; line-height: 1.5; }
.hours-note i { color: var(--novo-orange); margin-right: 5px; }

@media (max-width: 1100px) {
  .main-grid { grid-template-columns: 1fr; gap: 56px; }
}
@media (max-width: 768px) {
  .main-section { padding: 60px 0; }
  .nvo-cf-row { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════════════════════════════════
   CTA BANNER  (.cta-section / .novo-cta-banner)
   ══════════════════════════════════════════════════════════════════════ */
.cta-section,
.novo-cta-banner {
  background: var(--novo-navy, #0B3954);
  padding: 100px 0; position: relative;
  overflow: hidden; text-align: center;
}
/* Outer grey wrapper — applied by Elementor section settings;
   CSS class for when widget self-wraps */
.cta-outer-wrap {
  background: var(--novo-grey-bg, #F7F8FA);
  padding: 80px 0 0;
}
.novo-cta-banner::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 50% 130%, rgba(245,109,13,.26) 0%, transparent 50%);
  pointer-events: none; z-index: 0;
}
.novo-cta-banner::after {
  content: ''; position: absolute; inset: 0;
  background-image: radial-gradient(circle, rgba(255,255,255,.026) 1px, transparent 1px);
  background-size: 38px 38px; pointer-events: none; z-index: 0;
}
.cta-ring {
  position: absolute; border-radius: 50%;
  border: 1px solid rgba(245,109,13,.08);
  top: 50%; left: 50%; transform: translate(-50%,-50%);
  pointer-events: none;
}
.cta-ring-1 { width: 700px; height: 700px; }
.cta-ring-2 { width: 900px; height: 900px; }
.cta-inner { position: relative; z-index: 1; }
.cta-badge {
  display: inline-flex; align-items: center; gap: 7px;
  background: rgba(245,109,13,.14); border: 1px solid rgba(245,109,13,.28);
  color: var(--novo-orange-lite, #f9a754);
  font-size: 10px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 2.5px; padding: 7px 18px; border-radius: 20px;
  margin-bottom: 24px;
}
.cta-badge--plain {
  background: none; border: none; padding: 0;
  color: var(--novo-orange, #F56D0D);
  font-size: 11px; font-weight: 700; letter-spacing: 3px;
  text-transform: uppercase; margin-bottom: 18px;
  display: inline-block;
}
.cta-headline {
  font-size: clamp(30px, 5vw, 52px); font-weight: 900;
  color: #fff; line-height: 1.08;
  letter-spacing: -1px; margin-bottom: 20px;
}
.cta-headline span { color: var(--novo-orange, #f56d0d); }
.cta-sub {
  font-size: 17px; color: rgba(255,255,255,.62);
  line-height: 1.8; max-width: 520px; margin-bottom: 42px;
  margin-left: auto; margin-right: auto;
}
.cta-assurance { display: flex; flex-wrap: wrap; justify-content: center; gap: 14px; margin-top: 8px; }
.cta-assurance-item {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 13px; font-weight: 600; color: rgba(255,255,255,.55);
}
.cta-assurance-item i, .cta-assurance-item svg {
  color: var(--novo-orange, #f56d0d);
  fill: var(--novo-orange, #f56d0d); font-size: 13px;
}
.cta-btns { display: flex; flex-direction: row; flex-wrap: wrap; justify-content: center; gap: 14px; margin-top: 36px; }
.cta-section .btn,
.novo-cta-banner .btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 17px 40px; border-radius: var(--novo-radius-pill, 9999px);
  font-size: 15px; font-weight: 700; text-decoration: none;
  cursor: pointer; white-space: nowrap;
  transition: background .22s, transform .22s, box-shadow .22s, border-color .22s, color .22s;
}
.cta-section .btn-white,
.novo-cta-banner .btn-white {
  background: #fff; color: var(--novo-navy, #0b3954);
  border: none; box-shadow: 0 8px 32px rgba(0,0,0,.18);
}
.cta-section .btn-white:hover,
.novo-cta-banner .btn-white:hover {
  background: var(--novo-orange, #f56d0d); color: #fff;
  transform: translateY(-3px); box-shadow: 0 16px 48px rgba(245,109,13,.48);
}
.cta-section .btn-ghost-white,
.novo-cta-banner .btn-ghost-white {
  background: transparent; color: rgba(255,255,255,.80);
  border: 2px solid rgba(255,255,255,.26);
}
.cta-section .btn-ghost-white:hover,
.novo-cta-banner .btn-ghost-white:hover {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.55); color: #fff;
  transform: translateY(-3px);
}
@media (max-width: 900px) {
  .cta-section,
  .novo-cta-banner { padding: 80px 0; }
  .cta-sub { max-width: 100%; }
}
@media (max-width: 640px) {
  /* Phase 3 — flex-direction previously owned by Elementor buttons_direction control */
  .cta-btns { flex-direction: column; }
}


/* ═══════════════════════════════════════════════════════════
   HOME — AVAILABLE SYSTEMS SECTION WRAPPER (.avail-section)
   Widget: widget-novo-equipment-card (individual cards),
           section wrapper is native Elementor layout.
═══════════════════════════════════════════════════════════ */
.avail-section { padding: 96px 0; background: var(--novo-white); }
.avail-header  {
  display: flex; align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 48px; flex-wrap: wrap; gap: 20px;
}
.avail-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
}
@media (max-width: 1000px) { .avail-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width:  560px) { .avail-grid { grid-template-columns: 1fr; } }


/* ═══════════════════════════════════════════════════════════
   HOME — COMPACT VALUE CARDS (.val-card)
   Used in the home page value-section right column.
   Widget: widget-novo-value-cards (compact style variant).
═══════════════════════════════════════════════════════════ */
/* Compact value-cards grid — columns driven by Elementor responsive control (--val-cols) */
.nvo-val-compact-grid {
  display: grid;
  grid-template-columns: repeat(var(--val-cols, 2), 1fr);
  gap: 20px;
}

.val-card {
  background: var(--novo-white);
  border-radius: 20px;
  padding: 24px 22px;
  border: 1px solid var(--novo-border);
  box-shadow: 0 2px 16px rgba(11,57,84,.05);
  transition: transform .3s, box-shadow .3s;
}
.val-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 56px rgba(11,57,84,.11);
}
.val-icon {
  width: 48px; height: 48px;
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 14px;
  font-size: 20px; color: #fff;
}
.val-icon.vi-orange { background: linear-gradient(135deg, #ff7f2a, #f56d0d); }
.val-icon.vi-green  { background: linear-gradient(135deg, #12a15e, #0d8f53); }
.val-icon.vi-navy   { background: linear-gradient(135deg, #0b3954, #1a6090); }
.val-icon.vi-blue   { background: linear-gradient(135deg, #1a6090, #1575a8); }
.val-card h4 { font-size: 15.5px; font-weight: 800; color: var(--novo-navy); margin: 0 0 9px; }
.val-card p  { font-size: 13.5px; color: var(--novo-grey-tx); line-height: 1.72; margin: 0; }


/* ═══════════════════════════════════════════════════════════
   HOME — SEO CONTENT SECTION (.seo-section)
   Widget: widget-novo-seo-content
═══════════════════════════════════════════════════════════ */
.nvo-seo-section,
.seo-section { padding: 96px 0; background: var(--novo-grey-bg); }

.seo-intro {
  max-width: 820px; margin: 0 auto 56px;
  text-align: center;
}
.seo-intro-title {
  font-size: clamp(22px, 3vw, 34px);
  font-weight: 900; color: var(--novo-navy);
  letter-spacing: -1px; line-height: 1.10;
  margin-bottom: 18px;
}
.seo-intro-desc { font-size: 15px; color: var(--novo-grey-tx); line-height: 1.86; }

.seo-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}

.seo-card {
  background: var(--novo-white);
  border-radius: 18px;
  border: 1px solid var(--novo-border);
  padding: 30px 28px;
  box-shadow: 0 4px 20px var(--novo-shadow);
  transition: transform .3s, box-shadow .3s;
}
.seo-card:hover { transform: translateY(-5px); box-shadow: 0 20px 56px rgba(11,57,84,.11); }

.seo-card h3 {
  font-size: 16px; font-weight: 800; color: var(--novo-navy);
  margin-bottom: 12px; letter-spacing: -.3px;
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.seo-card h3 i,
.seo-card h3 svg { color: var(--novo-orange); font-size: 15px; flex-shrink: 0; }

.seo-card-body,
.seo-card-body p,
.seo-card > p {
  font-size: 13.5px; color: var(--novo-grey-tx);
  line-height: 1.80; margin-bottom: 18px;
}

.seo-link {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 13px; font-weight: 700; color: var(--novo-orange);
  transition: gap .2s;
}
.seo-link:hover { gap: 11px; }

@media (max-width: 760px) { .seo-grid { grid-template-columns: 1fr; } }


/* ═══════════════════════════════════════════════════════════
   ABOUT — WHO WE ARE / ABOUT INTRO (.who-section)
   Widget: widget-novo-about-intro
═══════════════════════════════════════════════════════════ */
.who-section { background: var(--novo-white); padding: 96px 0; }

.who-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}

.who-img-wrap { position: relative; }

.who-visual {
  border-radius: 24px;
  overflow: hidden;
  aspect-ratio: 1 / 1;
  background: linear-gradient(135deg, var(--novo-navy) 0%, #0b4a6b 50%, #0d5e87 100%);
  position: relative;
  box-shadow: 0 24px 72px rgba(11,57,84,.22);
}
.who-visual::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 80% 20%, rgba(245,109,13,.25) 0%, transparent 55%),
    radial-gradient(ellipse at 15% 80%, rgba(245,109,13,.12) 0%, transparent 45%);
}
.who-visual-inner {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 20px; padding: 40px;
}

/* Image mode — fills the card fully; border-radius clip comes from .who-visual overflow:hidden */
.who-visual-img {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  z-index: 2;
}

.who-visual-icon {
  width: 80px; height: 80px;
  background: rgba(245,109,13,.20);
  border: 2px solid rgba(245,109,13,.35);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 32px; color: var(--novo-orange);
  position: relative; z-index: 1;
}
.who-visual-icon i,
.who-visual-icon svg { font-size: 32px; color: var(--novo-orange); }

.who-visual-text {
  font-size: 20px; font-weight: 800; color: #fff;
  text-align: center; position: relative; z-index: 1;
  letter-spacing: -.5px;
}
.who-visual-sub {
  font-size: 14px; color: rgba(255,255,255,.55);
  text-align: center; position: relative; z-index: 1;
}

.who-badge {
  position: absolute; bottom: -20px; right: -20px;
  z-index: 10;
  background: var(--novo-orange); color: #fff;
  padding: 16px 22px; border-radius: 18px;
  box-shadow: 0 12px 36px rgba(245,109,13,.50);
  text-align: center;
}
.who-badge-num   { font-size: 28px; font-weight: 900; line-height: 1; letter-spacing: -1px; }
.who-badge-label { font-size: 11px; opacity: .85; font-weight: 600; margin-top: 3px; }

.who-deco {
  position: absolute; top: -16px; left: -16px;
  width: 80px; height: 80px;
  border: 3px solid var(--novo-orange);
  border-radius: 18px; opacity: .25; pointer-events: none;
}

.who-text .divider { width: 52px; }
.who-text p { font-size: 16px; color: var(--novo-grey-tx); line-height: 1.85; margin-bottom: 18px; }
.who-text p:last-of-type { margin-bottom: 32px; }

.who-highlights {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 14px; margin-bottom: 36px;
}
.highlight-item {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 14px 16px;
  background: var(--novo-grey-bg);
  border-radius: 12px;
  transition: background .25s;
}
.highlight-item:hover { background: #eef3f7; }
.highlight-item i,
.highlight-item svg { color: var(--novo-orange); font-size: 14px; margin-top: 2px; flex-shrink: 0; }
.highlight-item span { font-size: 13px; font-weight: 600; color: var(--novo-navy); line-height: 1.4; }

@media (max-width: 900px) {
  .who-grid { grid-template-columns: 1fr; gap: 48px; }
  .who-badge { bottom: -16px; right: 16px; }
}
@media (max-width: 600px) { .who-highlights { grid-template-columns: 1fr; } }


/* ═══════════════════════════════════════════════════════════
   PRODUCT SINGLE — QA / ENQUIRY FORM SECTION (.qa-section)
   Widget: widget-novo-qa-form
═══════════════════════════════════════════════════════════ */
.nvo-qa-section,
.qa-section {
  background: var(--novo-navy-dark, #082233);
  padding: 88px 0;
  position: relative;
  overflow: hidden;
}
.nvo-qa-section::before,
.qa-section::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(ellipse at 72% 50%, rgba(245,109,13,.18) 0%, transparent 55%);
}

.qa-inner {
  position: relative; z-index: 1;
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 64px; align-items: center;
}

.qa-eyebrow {
  display: flex; align-items: center; gap: 6px;
  font-size: 10.5px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 3px;
  color: var(--novo-orange-lite, #ff9a4d);
  margin-bottom: 10px;
}
.qa-eyebrow i,
.qa-eyebrow svg { font-size: 13px; }

.qa-title {
  font-size: clamp(26px, 3.5vw, 36px);
  font-weight: 900; color: #fff;
  line-height: 1.15; letter-spacing: -.8px;
  margin-bottom: 14px;
}
.qa-title span { color: var(--novo-orange); }

.qa-sub { font-size: 15px; color: rgba(255,255,255,.50); line-height: 1.80; }

.qa-features { display: flex; flex-direction: column; gap: 10px; margin-top: 24px; }
.qa-feat {
  display: flex; align-items: center; gap: 9px;
  font-size: 13px; font-weight: 600; color: rgba(255,255,255,.58);
}
.qa-feat i,
.qa-feat svg { color: var(--novo-orange); font-size: 12px; width: 14px; flex-shrink: 0; }

.qa-card {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 22px; padding: 30px;
  backdrop-filter: blur(10px);
}
.qa-card-title {
  display: flex; align-items: center; gap: 8px;
  font-size: 14px; font-weight: 800; color: #fff;
  margin-bottom: 20px;
}
.qa-card-title i,
.qa-card-title svg { color: var(--novo-orange-lite, #ff9a4d); }

/* CF7 inside qa-card — dark theme overrides */
.qa-card .wpcf7 label,
.qa-card .wpcf7-form label {
  display: block; font-size: 10.5px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 1.2px;
  color: rgba(255,255,255,.40); margin-bottom: 5px;
}
.qa-card .wpcf7-form input[type="text"],
.qa-card .wpcf7-form input[type="email"],
.qa-card .wpcf7-form input[type="tel"],
.qa-card .wpcf7-form select,
.qa-card .wpcf7-form textarea {
  width: 100%; padding: 11px 14px; margin-bottom: 12px;
  background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.14);
  border-radius: 10px; font-size: 13.5px; font-family: inherit; color: #fff;
  outline: none; transition: border-color .2s, background .2s;
}
.qa-card .wpcf7-form input::placeholder,
.qa-card .wpcf7-form textarea::placeholder { color: rgba(255,255,255,.28); }
.qa-card .wpcf7-form input:focus,
.qa-card .wpcf7-form select:focus,
.qa-card .wpcf7-form textarea:focus {
  border-color: var(--novo-orange); background: rgba(255,255,255,.10);
}
.qa-card .wpcf7-form .wpcf7-submit,
.qa-card .wpcf7-form input[type="submit"] {
  background: var(--novo-orange); color: #fff;
  border: none; border-radius: 10px; cursor: pointer;
  padding: 13px 24px; font-size: 13.5px; font-weight: 700;
  width: 100%; transition: background .2s, transform .2s;
}
.qa-card .wpcf7-form .wpcf7-submit:hover,
.qa-card .wpcf7-form input[type="submit"]:hover { background: #d45a00; transform: translateY(-2px); }

@media (max-width: 900px) {
  .qa-inner { grid-template-columns: 1fr; gap: 40px; }
  .qa-card  { max-width: 480px; }
}


/* ══════════════════════════════════════════════════════════════════════
   HOME — SERVICES SECTION  (.services-section)
   Widget: widget-novo-services-grid
   ══════════════════════════════════════════════════════════════════════ */
/* Background is controlled by the Elementor section wrapper or body context.
   Home page: gray body shows through. About page: white Elementor section wrapper. */
.services-section { padding: 112px 0; background: transparent; }


/* ══════════════════════════════════════════════════════════════════════
   HOME — VALUE SECTION  (.value-section / .value-layout)
   Widget: widget-novo-value-proposition (stats-cards mode)
   ══════════════════════════════════════════════════════════════════════ */
.value-section { padding: 112px 0; background: var(--novo-grey-bg, #F7F8FA); }

.value-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}

.value-right {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

@media (max-width: 1100px) {
  .value-layout { gap: 52px; }
}
@media (max-width: 900px) {
  .value-layout { grid-template-columns: 1fr; }
  .value-right  { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 540px) {
  .value-right  { grid-template-columns: 1fr; }
}

/* =============================================================
   NEW FEATURE CSS — appended from Fix Plan implementation
   ============================================================= */

/* ── Blog Card Footer ── */
.blog-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 20px 18px;
  border-top: 1px solid var(--novo-border);
}
.blog-author {
  display: flex;
  align-items: center;
  gap: 10px;
}
.blog-avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--novo-navy), var(--novo-navy-mid));
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  text-transform: uppercase;
}
.blog-author-name {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--novo-navy);
  line-height: 1.3;
}
.blog-date {
  display: block;
  font-size: 11.5px;
  color: var(--novo-grey-tx);
  line-height: 1.3;
}
.blog-foot .go-btn {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--novo-navy);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background 0.2s, transform 0.2s;
  text-decoration: none;
}
.blog-foot .go-btn:hover { background: var(--novo-navy-mid); transform: scale(1.08); }

/* ── Scroll To Top ── */
.scroll-top {
  position: fixed;
  bottom: 28px; right: 28px;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--novo-navy);
  color: #fff;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.3s, transform 0.3s;
  z-index: 9000;
  box-shadow: 0 4px 16px rgba(11,57,84,.22);
}
.scroll-top.visible { opacity: 1; transform: translateY(0); }
.scroll-top:hover { background: var(--novo-navy-mid); }
@media (max-width: 767px) { .scroll-top { bottom: 16px; right: 16px; } }

/* ── Testimonials Grid ── */
.tests-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 52px;
}
/* Hide any 4th+ cards — design always shows exactly 3 */
.tests-grid .trust-card:nth-child(n+4) { display: none; }
@media (max-width: 900px) { .tests-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .tests-grid { grid-template-columns: 1fr; } }

/* ── Trust Stat Card ── */
.trust-stat-card {
  display: flex;
  align-items: center;
  gap: 0;
  background: #fff;
  border-radius: var(--novo-radius-card);
  box-shadow: 0 8px 32px var(--novo-shadow);
  padding: 28px 32px;
  overflow: hidden;
}
.ts-stat-item {
  flex: 1;
  text-align: center;
  padding: 0 20px;
}
.ts-stat-divider {
  width: 1px;
  align-self: stretch;
  background: var(--novo-border);
}
.ts-stat-num {
  display: block;
  font-size: clamp(26px, 3vw, 32px);
  font-weight: 800;
  color: var(--novo-navy);
  line-height: 1.1;
}
.ts-stat-label {
  display: block;
  font-size: 12.5px;
  color: var(--novo-grey-tx);
  margin-top: 4px;
  line-height: 1.4;
}
@media (max-width: 600px) {
  .trust-stat-card { flex-direction: column; padding: 20px; }
  .ts-stat-divider { width: 100%; height: 1px; }
}

/* ── Floating Section Overlap ── */
.sec--float-up { margin-top: -60px; position: relative; z-index: 2; }
@media (max-width: 767px) { .sec--float-up { margin-top: -30px; } }

/* ── FAQ Helpful Vote ── */
.acc-helpful {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 0 4px;
  font-size: 13px;
  color: var(--novo-grey-tx);
}
.helpful-btn {
  background: none;
  border: 1px solid var(--novo-border);
  border-radius: var(--novo-radius-pill);
  padding: 4px 14px;
  font-size: 12.5px;
  color: var(--novo-grey-tx);
  cursor: pointer;
  transition: border-color 0.2s, color 0.2s, background 0.2s;
}
.helpful-btn:hover,
.helpful-btn.voted {
  border-color: var(--novo-green);
  color: var(--novo-green);
  background: rgba(31,164,99,.06);
}

/* ── Product Card Wishlist ── */
.pc-wishlist {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1px solid var(--novo-border);
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--novo-grey-tx);
  font-size: 15px;
  transition: border-color 0.2s, color 0.2s;
  flex-shrink: 0;
}
.pc-wishlist:hover,
.pc-wishlist[aria-pressed="true"] { border-color: #e53e3e; color: #e53e3e; }

/* ── Hero Accept List ── */
.hero-accept-list {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--novo-radius-card);
  padding: 32px 28px;
}
.al-title {
  font-size: 15px;
  font-weight: 700;
  color: rgba(255,255,255,.75);
  margin-bottom: 16px;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.al-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.al-item {
  display: flex;
  align-items: center;
  gap: 10px;
  color: #fff;
  font-size: 15px;
}
.al-item i { color: var(--novo-orange); }

/* ── Hero Posts Card ── */
.hero-posts-card {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--novo-radius-card);
  padding: 24px 22px;
}
.hpc-title {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--novo-orange);
  margin-bottom: 14px;
}
.hpc-list { display: flex; flex-direction: column; gap: 0; }
.hpc-item {
  display: block;
  padding: 12px 0;
  border-bottom: 1px solid rgba(255,255,255,.1);
  text-decoration: none;
}
.hpc-item:last-child { border-bottom: none; }
.hpc-meta { font-size: 11px; color: rgba(255,255,255,.5); margin-bottom: 3px; }
.hpc-item-title { font-size: 14px; color: #fff; font-weight: 500; line-height: 1.4; }
.hpc-item:hover .hpc-item-title { color: var(--novo-orange-lite); }

/* ── Hero Search Bar ── */
.hero-search-bar {
  display: flex;
  background: rgba(255,255,255,.1);
  border: 1.5px solid rgba(255,255,255,.20);
  border-radius: 16px;
  overflow: hidden;
  max-width: 560px;
  margin-top: 20px;
}
.hero-search-input {
  flex: 1;
  background: none;
  border: none;
  padding: 12px 18px;
  color: #fff;
  font-size: 15px;
  outline: none;
}
.hero-search-input::placeholder { color: rgba(255,255,255,.5); }
.hero-search-btn {
  background: var(--novo-orange);
  border: none;
  padding: 12px 26px;
  margin: 5px;
  border-radius: 12px;
  color: #fff;
  cursor: pointer;
  font-size: 13px;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  transition: background 0.2s;
}
.hero-search-btn:hover { background: var(--novo-orange-dark); }

/* ── Hero Jump Pills ── */
.hero-jump-pills {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin-top: 18px;
}
.hero-jump-pill {
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: var(--novo-radius-pill);
  padding: 6px 16px;
  font-size: 13px;
  color: rgba(255,255,255,.85);
  text-decoration: none;
  transition: background 0.2s, color 0.2s;
}
.hero-jump-pill:hover { background: rgba(255,255,255,.18); color: #fff; }

/* ── Hero Category Chips ── */
.hero-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 20px;
  animation: fadeDown .5s ease .4s both;
}
.hero-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  color: rgba(255,255,255,.5);
  cursor: pointer;
  padding: 5px 14px;
  border-radius: 50px;
  border: 1px solid rgba(255,255,255,.14);
  transition: all .2s;
  user-select: none;
}
.hero-chip:hover {
  color: #fff;
  border-color: rgba(245,109,13,.45);
  background: rgba(245,109,13,.10);
}
.hero-chip.active {
  color: #fff;
  border-color: var(--novo-orange);
  background: rgba(245,109,13,.15);
}
.hero-chip i { font-size: 10px; color: var(--novo-orange); }

/* ── Hero Global Reach ── */
.hero-global-reach {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13.5px;
  color: rgba(255,255,255,.65);
  margin-top: 16px;
}
.hero-global-reach i { color: var(--novo-orange-lite); }


/* ═══════════════════════════════════════════════════════════
   SERVICES PAGE — SERVICE PACKAGES (.packages-section)
   Widget: widget-novo-service-packages
═══════════════════════════════════════════════════════════ */
.novo-service-packages,
.packages-section { padding: 96px 0; }

.packages-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 52px;
}

.pkg-card {
  background: var(--novo-white, #fff);
  border: 1px solid var(--novo-border, rgba(11,57,84,.10));
  border-radius: 22px;
  padding: 36px 28px;
  display: flex;
  flex-direction: column;
  box-shadow: 0 3px 16px rgba(11,57,84,.08);
  transition: transform .3s cubic-bezier(.22,.68,0,1.2), box-shadow .3s, border-color .3s;
  position: relative;
}
.pkg-card.highlight {
  border-color: var(--novo-orange, #f56d0d);
  box-shadow: 0 8px 40px rgba(245,109,13,.18);
}
.pkg-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 56px rgba(11,57,84,.14);
}

.pkg-popular {
  position: absolute;
  top: 20px; right: 20px;
  background: var(--novo-orange, #f56d0d);
  color: #fff;
  font-size: 9.5px; font-weight: 800;
  text-transform: uppercase; letter-spacing: 1.5px;
  padding: 4px 12px;
  border-radius: 20px;
}

.pkg-icon {
  width: 52px; height: 52px;
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px;
  margin-bottom: 20px;
}
.pkg-icon.basic    { background: rgba(122,144,160,.10); color: var(--novo-grey-tx, #7a90a0); }
.pkg-icon.standard { background: rgba(245,109,13,.10);  color: var(--novo-orange, #f56d0d); }
.pkg-icon.premium  { background: rgba(11,57,84,.08);    color: var(--novo-navy, #0b3954); }

.pkg-name {
  font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 2px;
  color: var(--novo-grey-tx, #7a90a0);
  margin-bottom: 8px;
}
.pkg-title {
  font-size: 22px; font-weight: 900;
  color: var(--novo-navy, #0b3954);
  letter-spacing: -.5px;
  margin-bottom: 10px;
}
.pkg-desc {
  font-size: 13.5px;
  color: var(--novo-grey-tx, #7a90a0);
  line-height: 1.70;
  margin-bottom: 24px;
}

.pkg-features {
  list-style: none;
  display: flex; flex-direction: column;
  gap: 10px;
  margin: 0 0 32px;
  padding: 0;
  flex: 1;
}
.pkg-feature {
  display: flex; align-items: flex-start;
  gap: 10px;
  font-size: 13.5px; color: var(--novo-navy, #0b3954);
  font-weight: 500;
}
.pkg-feature i {
  font-size: 11px;
  color: #1fa463;
  margin-top: 3px; flex-shrink: 0;
}
.pkg-feature.no i    { color: var(--novo-border, rgba(11,57,84,.10)); }
.pkg-feature.no span { color: var(--novo-grey-tx, #7a90a0); }

/* CTA button — widget renders <a class="pkg-cta {tier}-btn"> */
a.pkg-cta {
  display: flex; align-items: center; justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 14px;
  border-radius: 14px;
  font-size: 14px; font-weight: 700;
  font-family: inherit;
  border: none;
  cursor: pointer;
  transition: all .2s;
  text-decoration: none;
  margin-top: auto;
}
a.pkg-cta.basic-btn    { background: var(--novo-grey-bg, #f7f8fa); color: var(--novo-navy, #0b3954); border: 1.5px solid var(--novo-border, rgba(11,57,84,.10)); }
a.pkg-cta.basic-btn:hover { border-color: var(--novo-orange, #f56d0d); color: var(--novo-orange, #f56d0d); }
a.pkg-cta.standard-btn { background: var(--novo-orange, #f56d0d); color: #fff; box-shadow: 0 6px 22px rgba(245,109,13,.35); }
a.pkg-cta.standard-btn:hover { background: #e05f00; transform: translateY(-2px); }
a.pkg-cta.premium-btn  { background: var(--novo-navy, #0b3954); color: #fff; box-shadow: 0 6px 22px rgba(11,57,84,.28); }
a.pkg-cta.premium-btn:hover { background: #071f2e; transform: translateY(-2px); }

@media (max-width: 1000px) {
  .packages-grid { grid-template-columns: 1fr; max-width: 480px; margin-left: auto; margin-right: auto; }
}
@media (max-width: 640px) {
  .packages-grid { max-width: 100%; }
}

/* ═══════════════════════════════════════════════
   LEGAL LAYOUT WIDGET (novo_legal_layout)
   Matches privacy-policy-preview.html, cookies-preview.html, sales-terms-preview.html
═══════════════════════════════════════════════ */

/* ── Updated Bar ── */
.updated-bar {
  background: var(--novo-white, #fff);
  border-bottom: 1px solid var(--novo-border, #E8EDF3);
  padding: 13px 0;
}
.updated-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
}
.updated-meta {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}
.updated-chip {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12.5px;
  color: var(--novo-grey-tx, #7A90A0);
  font-weight: 500;
}
.updated-chip i { color: var(--novo-orange, #F56D0D); font-size: 11px; }
.updated-chip strong { color: var(--novo-navy, #0B3954); }
.dl-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12.5px;
  font-weight: 700;
  color: var(--novo-orange, #F56D0D);
  border: 1.5px solid rgba(245,109,13,.25);
  border-radius: 20px;
  padding: 5px 14px;
  transition: background .2s, color .2s;
  text-decoration: none;
}
.dl-link:hover { background: var(--novo-orange, #F56D0D); color: #fff; }

/* ── Cookie Overview Cards ── */
.cookie-overview { padding: 60px 0 0; }
.cookie-overview-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 48px;
}
.co-card {
  background: var(--novo-white, #fff);
  border-radius: 20px;
  border: 1px solid var(--novo-border, #E8EDF3);
  padding: 22px 20px;
  text-align: center;
  box-shadow: 0 4px 20px var(--novo-shadow, rgba(11,57,84,.10));
  transition: box-shadow .3s, transform .3s;
}
.co-card:hover { box-shadow: 0 12px 40px rgba(11,57,84,.12); transform: translateY(-4px); }
.co-icon {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  margin: 0 auto 14px;
}
.co-icon.essential  { background: rgba(31,164,99,.10);  color: var(--novo-green, #0fa360); }
.co-icon.functional { background: rgba(11,57,84,.08);   color: var(--novo-navy, #0B3954); }
.co-icon.analytics  { background: rgba(245,109,13,.10); color: var(--novo-orange, #F56D0D); }
.co-icon.marketing  { background: rgba(124,92,252,.10); color: #7C5CFC; }
.co-card-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--novo-grey-tx, #7A90A0);
  margin-bottom: 4px;
}
.co-card-title { font-size: 15px; font-weight: 800; color: var(--novo-navy, #0B3954); margin-bottom: 6px; }
.co-card-desc  { font-size: 12.5px; color: var(--novo-grey-tx, #7A90A0); line-height: 1.60; }
.co-card-tag {
  display: inline-block;
  margin-top: 12px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: 4px 12px;
  border-radius: 20px;
}
.co-card-tag.required { background: rgba(31,164,99,.10);  color: var(--novo-green, #0fa360);  border: 1px solid rgba(31,164,99,.20); }
.co-card-tag.optional { background: rgba(245,109,13,.10); color: var(--novo-orange, #F56D0D); border: 1px solid rgba(245,109,13,.20); }

/* ── Terms / Clause Sections ── */
.terms-wrap { padding: 72px 0 96px; }
/* When cookie-overview precedes terms-wrap, no top padding needed */
.cookie-overview + .terms-wrap { padding-top: 0; }

.tc {
  background: var(--novo-white, #fff);
  border-radius: 24px;
  border: 1px solid var(--novo-border, #E8EDF3);
  box-shadow: 0 6px 40px var(--novo-shadow, rgba(11,57,84,.10));
  margin-bottom: 32px;
  overflow: hidden;
}
.tc-header {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 32px 40px 28px;
  border-bottom: 1px solid var(--novo-border, #E8EDF3);
}
.tc-icon {
  width: 54px;
  height: 54px;
  flex-shrink: 0;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
}
/* Privacy Policy variants */
.tc-icon.collect { background: rgba(11,57,84,.08);   color: var(--novo-navy, #0B3954); }
.tc-icon.rights  { background: rgba(245,109,13,.10); color: var(--novo-orange, #F56D0D); }
/* Cookie Policy variants */
.tc-icon.what    { background: rgba(11,57,84,.08);   color: var(--novo-navy, #0B3954); }
.tc-icon.types   { background: rgba(245,109,13,.10); color: var(--novo-orange, #F56D0D); }
.tc-icon.third   { background: rgba(124,92,252,.10); color: #7C5CFC; }
.tc-icon.manage  { background: rgba(31,164,99,.10);  color: var(--novo-green, #0fa360); }
/* Sales Terms variants */
.tc-icon.eq      { background: rgba(11,57,84,.08);   color: var(--novo-navy, #0B3954); }
.tc-icon.pts     { background: rgba(245,109,13,.10); color: var(--novo-orange, #F56D0D); }

.tc-htitle { font-size: 22px; font-weight: 900; color: var(--novo-navy, #0B3954); letter-spacing: -.4px; margin-bottom: 3px; }
.tc-hsub   { font-size: 13.5px; color: var(--novo-grey-tx, #7A90A0); }
.tc-badge  {
  margin-left: auto;
  flex-shrink: 0;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  padding: 5px 14px;
  border-radius: 20px;
  background: rgba(31,164,99,.10);
  color: var(--novo-green, #0fa360);
  border: 1px solid rgba(31,164,99,.18);
  white-space: nowrap;
}
.tc-body { padding: 10px 40px 36px; }

/* ── Clause accordion ── */
.clause {
  border-bottom: 1px solid var(--novo-border, #E8EDF3);
  padding: 24px 0;
}
.clause:last-child { border-bottom: none; padding-bottom: 0; }
.clause-head {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  cursor: pointer;
  user-select: none;
}
.clause-num {
  width: 32px;
  height: 32px;
  flex-shrink: 0;
  border-radius: 9px;
  background: var(--novo-grey-bg, #F5F7FA);
  border: 1px solid var(--novo-border, #E8EDF3);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 800;
  color: var(--novo-grey-tx, #7A90A0);
  margin-top: 1px;
  transition: background .2s, color .2s, border-color .2s;
}
.clause:hover .clause-num {
  background: rgba(245,109,13,.10);
  color: var(--novo-orange, #F56D0D);
  border-color: rgba(245,109,13,.25);
}
.clause-title {
  font-size: 15.5px;
  font-weight: 800;
  color: var(--novo-navy, #0B3954);
  line-height: 1.3;
  flex: 1;
  padding-top: 5px;
}
.clause-chevron {
  color: var(--novo-grey-tx, #7A90A0);
  font-size: 11px;
  margin-top: 7px;
  flex-shrink: 0;
  transition: transform .25s;
}
.clause.open .clause-chevron { transform: rotate(180deg); color: var(--novo-orange, #F56D0D); }
.clause-body { display: none; padding: 14px 0 0 46px; }
.clause.open .clause-body { display: block; }
.clause-body p { font-size: 14px; color: var(--novo-grey-tx, #7A90A0); line-height: 1.85; margin-bottom: 10px; }
.clause-body p:last-child { margin-bottom: 0; }
.clause-body ul {
  list-style: none;
  margin-top: 4px;
  display: flex;
  flex-direction: column;
  gap: 7px;
  margin-bottom: 10px;
}
.clause-body ul li {
  font-size: 13.5px;
  color: var(--novo-grey-tx, #7A90A0);
  line-height: 1.60;
  padding-left: 18px;
  position: relative;
}
.clause-body ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 8px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--novo-orange, #F56D0D);
}
.clause-body strong { color: var(--novo-navy, #0B3954); font-weight: 700; }

/* ── Note boxes ── */
.clause-note {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: rgba(245,109,13,.06);
  border: 1px solid rgba(245,109,13,.15);
  border-radius: 10px;
  padding: 12px 16px;
  margin-top: 12px;
  font-size: 13px;
  color: var(--novo-navy, #0B3954);
  line-height: 1.65;
}
.clause-note i { color: var(--novo-orange, #F56D0D); flex-shrink: 0; margin-top: 2px; font-size: 13px; }
.clause-note.info { background: rgba(11,57,84,.05); border-color: rgba(11,57,84,.12); }
.clause-note.info i { color: var(--novo-navy, #0B3954); }
.clause-note.gdpr { background: rgba(31,164,99,.06); border-color: rgba(31,164,99,.18); }
.clause-note.gdpr i { color: var(--novo-green, #0fa360); }

/* ── Rights grid (GDPR rights chips) ── */
.rights-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 12px; }
.right-chip {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px;
  background: var(--novo-grey-bg, #F5F7FA);
  border: 1px solid var(--novo-border, #E8EDF3);
  border-radius: 12px;
}
.right-chip i { color: var(--novo-green, #0fa360); font-size: 13px; flex-shrink: 0; margin-top: 2px; }
.right-chip strong { font-size: 13px; color: var(--novo-navy, #0B3954); display: block; margin-bottom: 2px; }
.right-chip span { font-size: 12px; color: var(--novo-grey-tx, #7A90A0); line-height: 1.5; }

/* ── Cookie table ── */
.cookie-table { width: 100%; border-collapse: collapse; margin-top: 12px; font-size: 13px; }
.cookie-table th {
  background: var(--novo-grey-bg, #F5F7FA);
  color: var(--novo-navy, #0B3954);
  font-weight: 700;
  padding: 10px 14px;
  text-align: left;
  border: 1px solid var(--novo-border, #E8EDF3);
}
.cookie-table td {
  padding: 10px 14px;
  border: 1px solid var(--novo-border, #E8EDF3);
  color: var(--novo-grey-tx, #7A90A0);
  vertical-align: top;
  line-height: 1.55;
}
.cookie-table tr:hover td { background: rgba(245,109,13,.03); }
.ct-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .8px;
  padding: 3px 10px;
  border-radius: 20px;
}
.ct-badge.essential  { background: rgba(31,164,99,.10);  color: var(--novo-green, #0fa360);  border: 1px solid rgba(31,164,99,.20); }
.ct-badge.functional { background: rgba(11,57,84,.08);   color: var(--novo-navy, #0B3954);   border: 1px solid rgba(11,57,84,.15); }
.ct-badge.analytics  { background: rgba(245,109,13,.10); color: var(--novo-orange, #F56D0D); border: 1px solid rgba(245,109,13,.20); }
.ct-badge.marketing  { background: rgba(124,92,252,.10); color: #7C5CFC;                     border: 1px solid rgba(124,92,252,.20); }

/* ── Browser steps (cookie management guide) ── */
.browser-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 12px; }
.browser-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px;
  background: var(--novo-grey-bg, #F5F7FA);
  border: 1px solid var(--novo-border, #E8EDF3);
  border-radius: 12px;
}
.browser-item i { color: var(--novo-navy3, #0d4a6b); font-size: 14px; flex-shrink: 0; margin-top: 2px; }
.browser-item strong { font-size: 13px; color: var(--novo-navy, #0B3954); display: block; margin-bottom: 3px; }
.browser-item span { font-size: 12px; color: var(--novo-grey-tx, #7A90A0); line-height: 1.55; }

/* ── Consent toggles (cookie policy visual) ── */
.consent-row {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 16px;
  background: var(--novo-grey-bg, #F5F7FA);
  border: 1px solid var(--novo-border, #E8EDF3);
  border-radius: 12px;
  margin-top: 8px;
}
.toggle-pill {
  width: 40px;
  height: 22px;
  border-radius: 11px;
  flex-shrink: 0;
  position: relative;
  transition: background .2s;
}
.toggle-pill::after {
  content: '';
  position: absolute;
  top: 3px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 4px rgba(0,0,0,.18);
  transition: left .2s;
}
.toggle-pill.on  { background: var(--novo-green, #0fa360); }
.toggle-pill.off { background: #CBD5E0; }
.toggle-pill.on::after  { left: 21px; }
.toggle-pill.off::after { left: 3px; }
.consent-label { flex: 1; }
.consent-label strong { font-size: 13.5px; color: var(--novo-navy, #0B3954); display: block; margin-bottom: 2px; }
.consent-label span { font-size: 12px; color: var(--novo-grey-tx, #7A90A0); }
.consent-tag {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: 3px 10px;
  border-radius: 20px;
  flex-shrink: 0;
}
.consent-tag.required { background: rgba(31,164,99,.10);  color: var(--novo-green, #0fa360);  border: 1px solid rgba(31,164,99,.20); }
.consent-tag.optional { background: rgba(245,109,13,.10); color: var(--novo-orange, #F56D0D); border: 1px solid rgba(245,109,13,.20); }

/* ── Responsive ── */
@media (max-width: 860px) {
  .cookie-overview-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
  .cookie-overview-grid { grid-template-columns: 1fr 1fr; }
  .tc-header { padding: 24px; flex-wrap: wrap; gap: 12px; }
  .tc-badge  { margin-left: 0; }
  .tc-body   { padding: 10px 24px 28px; }
  .clause-body { padding-left: 0; }
  .rights-grid { grid-template-columns: 1fr; }
  .cookie-table { font-size: 12px; }
  .browser-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .cookie-overview-grid { grid-template-columns: 1fr; }
}

/* --------------------------------------------------------------------------
   Source: novo-singles.css
   -------------------------------------------------------------------------- */
/* =============================================================
   NOVO Singles & Archive CSS
   Styles for: product hero, product body, part detail, enquiry strip,
   related items, floating quote, article hero, article body,
   legal layout, service packages, equipment archive, FAQ (full layout),
   breadcrumb bar.
   Uses --novo-* CSS tokens from novo-base.css
   ============================================================= */

/* ── Breadcrumb Bar ──────────────────────────────────────────── */
.novo-breadcrumb-bar {
	position: sticky;
	top: calc(var(--novo-topbar-h, 36px) + var(--novo-hdr-h, 72px));
	z-index: 300;
	padding: 0;
}
.novo-breadcrumb-bar--dark {
	background: var(--novo-navy-dark, #082233);
	border-bottom: 1px solid rgba(255,255,255,.06);
}
.novo-breadcrumb-bar--light {
	background: #fff;
	border-bottom: 1px solid var(--novo-border);
}
.breadcrumb-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 10px 0;
	min-height: 44px;
}
.novo-breadcrumb ol.breadcrumb-list {
	display: flex;
	align-items: center;
	gap: 7px;
	list-style: none;
	margin: 0;
	padding: 0;
	font-size: 12.5px;
}
.novo-breadcrumb-bar--dark .breadcrumb-list li,
.novo-breadcrumb-bar--dark .breadcrumb-list a {
	color: rgba(255,255,255,.38);
	text-decoration: none;
}
.novo-breadcrumb-bar--dark .breadcrumb-list a:hover { color: rgba(255,255,255,.7); }
.novo-breadcrumb-bar--dark .breadcrumb-current { color: rgba(255,255,255,.80) !important; font-weight: 600; }
.novo-breadcrumb-bar--light .breadcrumb-list li,
.novo-breadcrumb-bar--light .breadcrumb-list a { color: var(--novo-grey-tx); text-decoration: none; }
.novo-breadcrumb-bar--light .breadcrumb-list a:hover { color: var(--novo-navy); }
.novo-breadcrumb-bar--light .breadcrumb-current { color: var(--novo-navy) !important; font-weight: 600; }

/* ── Transparent / hero-integrated mode ─────────────────────────────── */
/*
 * The transparent breadcrumb overlays the hero section background.
 * Strategy: override sticky positioning to relative; use :has() CSS to
 * zero-out the Elementor section's height contribution so the hero's
 * dark background extends directly behind the transparent bar.
 */
.novo-breadcrumb-bar--transparent,
.novo-breadcrumb-bar--transparent.novo-breadcrumb-bar--sticky {
	position: relative !important;
	top: auto;
	background: transparent;
	border-bottom: none;
	z-index: 20;
}
.novo-breadcrumb-bar--transparent .breadcrumb-list li,
.novo-breadcrumb-bar--transparent .breadcrumb-list a {
	color: rgba(255,255,255,.40);
	text-decoration: none;
}
.novo-breadcrumb-bar--transparent .breadcrumb-list a:hover { color: rgba(255,255,255,.80); }
.novo-breadcrumb-bar--transparent .breadcrumb-current { color: rgba(255,255,255,.90) !important; font-weight: 600; }
.novo-breadcrumb-bar--transparent .breadcrumb-sep {
	color: rgba(255,255,255,.18) !important;
	font-size: 7px;
}
/* Pull hero section behind the transparent bar so its dark bg is visible */
.elementor-section:has(.novo-breadcrumb-bar--transparent),
.e-con:has(.novo-breadcrumb-bar--transparent) {
	overflow: visible !important;
	margin-bottom: -44px !important;
	position: relative !important;
	z-index: 20 !important;
}
.elementor-column:has(.novo-breadcrumb-bar--transparent),
.elementor-widget-wrap:has(.novo-breadcrumb-bar--transparent),
.novo-bc-transparent-mode {
	overflow: visible !important;
}
/* On mobile the negative pull causes the breadcrumb to overlap hero text — reset it */
@media (max-width: 768px) {
	.elementor-section:has(.novo-breadcrumb-bar--transparent),
	.e-con:has(.novo-breadcrumb-bar--transparent) {
		margin-bottom: 0 !important;
	}
}

.bc-actions {
	display: flex;
	gap: 8px;
	flex-shrink: 0;
}
.bc-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 5px 13px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 500;
	text-decoration: none;
	border: 1px solid rgba(255,255,255,.18);
	color: rgba(255,255,255,.70);
	background: transparent;
	transition: background .2s, color .2s;
	cursor: pointer;
}
.bc-btn:hover {
	background: rgba(255,255,255,.10);
	color: #fff;
}
.novo-breadcrumb-bar--light .bc-btn {
	border-color: var(--novo-border);
	color: var(--novo-grey-tx);
}
.novo-breadcrumb-bar--light .bc-btn:hover {
	background: var(--novo-grey-bg);
	color: var(--novo-navy);
}

/* ── Product Hero ─────────────────────────────────────────────── */
.novo-product-hero {
	position: relative;
	min-height: 88vh;
	display: flex;
	align-items: center;
	background: radial-gradient(ellipse at 60% 40%, var(--novo-navy3, #103a56) 0%, var(--novo-navy, #0B3954) 42%, var(--novo-navy-dark, #0a2d45) 100%);
	overflow: hidden;
	padding: calc(var(--novo-topbar-h, 36px) + var(--novo-hdr-h, 72px) + 100px) 0 80px;
}
.novo-product-hero::before,
.novo-product-hero::after {
	content: '';
	position: absolute;
	border-radius: 50%;
	pointer-events: none;
}
.novo-product-hero::before {
	width: 800px; height: 800px;
	top: 50%; left: 50%;
	transform: translate(-50%,-50%);
	border: 1px solid rgba(245,109,13,.08);
	animation: ringPulse 8s ease-in-out infinite;
}
.novo-product-hero::after {
	width: 500px; height: 500px;
	top: 50%; left: 50%;
	transform: translate(-50%,-50%);
	border: 1px solid rgba(245,109,13,.05);
	animation: ringPulse 8s ease-in-out infinite 2s;
}
.hero-glow {
	position: absolute;
	inset: 0;
	pointer-events: none;
	background:
		radial-gradient(ellipse 500px 300px at 90% 10%, rgba(245,109,13,.08) 0%, transparent 70%),
		radial-gradient(ellipse 400px 300px at 0% 80%, rgba(11,57,84,.40) 0%, transparent 60%);
}
.hero-orb {
	position: absolute;
	border-radius: 50%;
	pointer-events: none;
	filter: blur(60px);
	animation: floatOrb 12s ease-in-out infinite;
}
.hero-orb-1 {
	width: 320px; height: 320px;
	background: rgba(245,109,13,.12);
	top: -60px; right: 10%;
	animation-delay: 0s;
}
.hero-orb-2 {
	width: 200px; height: 200px;
	background: rgba(100,140,180,.12);
	bottom: 40px; left: 8%;
	animation-delay: 4s;
}
.hero-scanline {
	position: absolute;
	inset: 0;
	pointer-events: none;
	overflow: hidden;
}
.hero-scanline::after {
	content: '';
	position: absolute;
	left: 0; right: 0;
	height: 2px;
	background: linear-gradient(90deg, transparent 0%, rgba(245,109,13,.35) 50%, transparent 100%);
	animation: scanMove 8s linear infinite;
}
.product-hero-layout {
	display: grid;
	grid-template-columns: 1fr 520px;
	gap: 72px;
	align-items: center;
	position: relative;
	z-index: 2;
}
.product-hero-copy { display: flex; flex-direction: column; gap: 20px; }
.hero-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 11.5px;
	font-weight: 600;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--novo-orange);
	background: rgba(245,109,13,.12);
	border: 1px solid rgba(245,109,13,.25);
	padding: 6px 14px;
	border-radius: 999px;
	width: fit-content;
}
.hero-eyebrow .fa-circle { font-size: 5px; animation: blink 2s ease-in-out infinite; }
.hero-partnum {
	font-family: monospace;
	font-size: 13px;
	color: rgba(255,255,255,.40);
	background: rgba(255,255,255,.07);
	border: 1px solid rgba(255,255,255,.12);
	padding: 4px 12px;
	border-radius: 6px;
	width: fit-content;
}
.hero-headline {
	font-size: clamp(38px,5.5vw,68px);
	font-weight: 900;
	line-height: 1.04;
	letter-spacing: -2.5px;
	color: #fff;
	margin: 0;
}
.hero-headline span {
	background: linear-gradient(135deg, var(--novo-orange) 0%, #ffd27d 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}
.hero-model {
	font-size: 16px;
	color: rgba(255,255,255,.55);
	margin: 0;
}
.hero-pills { display: flex; flex-wrap: wrap; gap: 8px; }
.h-pill {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 7px 16px;
	border-radius: 999px;
	font-size: 12.5px;
	font-weight: 700;
	background: rgba(255,255,255,.08);
	border: 1px solid rgba(255,255,255,.12);
	color: rgba(255,255,255,.75);
}
.h-pill.green  { background: rgba(40,180,100,.14); border-color: rgba(40,180,100,.30); color: #4ad880; }
.h-pill.orange { background: rgba(245,109,13,.14); border-color: rgba(245,109,13,.30); color: var(--novo-orange); }
.hero-btns { display: flex; gap: 12px; flex-wrap: wrap; }
.hero-micro-trust { display: flex; gap: 18px; flex-wrap: wrap; }
.hmt-item {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 12px;
	color: rgba(255,255,255,.45);
}
.hmt-item i { color: var(--novo-orange); font-size: 11px; }

/* Hero Card */
.hero-card {
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.hc-gallery {
	position: relative;
	aspect-ratio: 4/3;
	background: linear-gradient(140deg, #f0f4f8 0%, #e2e8ef 100%);
	border-radius: 24px;
	overflow: hidden;
	border: 1px solid rgba(255,255,255,.18);
	box-shadow: 0 40px 100px rgba(0,0,0,.40), inset 0 1px 0 rgba(255,255,255,.80);
	cursor: zoom-in;
	margin-bottom: 2px;
}
.hc-gallery::before {
	content: '';
	position: absolute;
	inset: 0;
	pointer-events: none;
	background: radial-gradient(ellipse at 80% 18%, rgba(245,109,13,.09) 0%, transparent 55%);
}
.hc-gallery::after {
	content: '';
	position: absolute;
	top: 12px; left: 12px;
	width: 28px; height: 28px;
	border-top: 2px solid rgba(245,109,13,.45);
	border-left: 2px solid rgba(245,109,13,.45);
	border-radius: 4px 0 0 0;
	pointer-events: none;
}
.hc-corner-br {
	position: absolute;
	bottom: 12px; right: 12px;
	width: 28px; height: 28px;
	border-bottom: 2px solid rgba(245,109,13,.45);
	border-right: 2px solid rgba(245,109,13,.45);
	border-radius: 0 0 4px 0;
	pointer-events: none;
}
/* In-card prev/next nav arrows */
.hc-card-nav {
	position: absolute;
	top: 50%; transform: translateY(-50%);
	z-index: 3;
	width: 38px; height: 38px;
	background: rgba(0,0,0,.40);
	backdrop-filter: blur(6px);
	border: none;
	border-radius: 50%;
	color: #fff;
	font-size: 14px;
	cursor: pointer;
	display: flex; align-items: center; justify-content: center;
	transition: background .2s, opacity .2s;
	opacity: .8;
}
.hc-card-nav:hover { background: rgba(0,0,0,.70); opacity: 1; }
.hc-card-prev { left: 14px; }
.hc-card-next { right: 14px; }
.hc-gp {
	position: relative;
	z-index: 1;
	width: 100%; height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 18px;
	padding: 40px;
	text-align: center;
	transition: transform .3s;
}
/* When a real product photo is present, collapse the gp padding & strip the gray fallback background */
.hc-gp:has(.hc-product-img) { padding: 0; gap: 0; }
.hc-gallery:has(.hc-product-img) { background: none; }

/* ── Lightbox ────────────────────────────────────────────── */
.hc-lightbox {
	position: fixed;
	inset: 0;
	z-index: 99999;
	background: rgba(0,0,0,.92);
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: zoom-out;
	animation: lbFadeIn .18s ease;
}
@keyframes lbFadeIn { from { opacity: 0; } to { opacity: 1; } }
.hc-lb-img-wrap {
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: default;
}
.hc-lb-img {
	max-width: 90vw;
	max-height: 88vh;
	object-fit: contain;
	border-radius: 20px;
	transition: opacity .15s;
}
.hc-lb-close {
	position: fixed;
	top: 20px; right: 24px;
	width: 44px; height: 44px;
	background: rgba(255,255,255,.12);
	border: none;
	border-radius: 50%;
	color: #fff;
	font-size: 24px;
	line-height: 1;
	cursor: pointer;
	display: flex; align-items: center; justify-content: center;
	transition: background .2s;
	z-index: 2;
}
.hc-lb-close:hover { background: rgba(255,255,255,.28); }
.hc-lb-nav {
	position: fixed;
	top: 50%; transform: translateY(-50%);
	width: 52px; height: 52px;
	background: rgba(255,255,255,.12);
	border: none;
	border-radius: 50%;
	color: #fff;
	font-size: 18px;
	cursor: pointer;
	display: flex; align-items: center; justify-content: center;
	transition: background .2s;
	z-index: 2;
}
.hc-lb-nav:hover { background: rgba(255,255,255,.28); }
.hc-lb-prev { left: 20px; }
.hc-lb-next { right: 20px; }
.hc-lb-counter {
	position: fixed;
	bottom: 22px;
	left: 50%; transform: translateX(-50%);
	color: rgba(255,255,255,.55);
	font-size: 13px;
	font-weight: 500;
	letter-spacing: .5px;
}
.hc-product-img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	padding: 20px;
	display: block;
}
.hc-icon {
	width: 120px;
	height: 120px;
	background: #fff;
	border: 1px solid rgba(245,109,13,.20);
	border-radius: 32px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 48px;
	color: var(--novo-orange, #F56D0D);
	box-shadow: 0 16px 48px rgba(11,57,84,.14);
}
.hc-caption { font-size: 12px; font-weight: 600; color: var(--novo-grey-tx, #7A90A0); text-align: center; }
.hc-badge-tl {
	position: absolute;
	top: 14px; left: 14px;
	z-index: 2;
	background: rgba(40,180,100,.85);
	color: #fff;
	font-size: 11.5px;
	font-weight: 600;
	padding: 4px 10px;
	border-radius: 999px;
	display: flex;
	align-items: center;
	gap: 5px;
}
.hc-badge-tl::before {
	content: '';
	width: 6px; height: 6px;
	border-radius: 50%;
	background: #fff;
	animation: blink 2s ease-in-out infinite;
}
.hc-badge-br {
	position: absolute;
	bottom: 14px; right: 14px;
	z-index: 2;
	background: #fff;
	border: 1px solid var(--novo-border, #EEF2F6);
	color: var(--novo-navy, #0B3954);
	font-size: 11px;
	font-weight: 600;
	padding: 5px 12px;
	border-radius: 8px;
	display: flex;
	align-items: center;
	gap: 5px;
	box-shadow: 0 2px 10px rgba(11,57,84,.10);
}
/* Quick Enquiry Card (inside hero) */
.hc-qa {
	background: #fff;
	border: 1px solid var(--novo-border, #EEF2F6);
	border-radius: 16px;
	padding: 18px 20px;
	box-shadow: 0 6px 28px rgba(11,57,84,.10);
}
.hc-qa-head {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 13px;
}
.hc-qa-icon {
	width: 34px; height: 34px;
	border-radius: 10px;
	background: rgba(245,109,13,.10);
	color: var(--novo-orange, #F56D0D);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 13px;
	flex-shrink: 0;
}
.hc-qa-head strong { display: block; font-size: 13px; font-weight: 800; color: var(--novo-navy, #0B3954); line-height: 1.2; }
.hc-qa-head span   { display: block; font-size: 11.5px; color: var(--novo-grey-tx, #7A90A0); }
.hc-qa-row { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 8px; }
.hc-qa-input {
	width: 100%;
	padding: 9px 11px;
	background: var(--novo-grey-bg, #F7F8FA);
	border: 1px solid var(--novo-border, #EEF2F6);
	border-radius: 8px;
	font-size: 12.5px;
	color: var(--novo-navy, #0B3954);
	outline: none;
	transition: border-color .2s, background .2s;
}
.hc-qa-input:focus { border-color: var(--novo-orange, #F56D0D); background: #fff; }
.hc-qa-input::placeholder { color: var(--novo-grey-tx, #7A90A0); }
.hc-qa-input--solo { margin-bottom: 8px; }
.hc-qa-foot {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
	margin-top: 10px;
}
.hc-qa-consent { display: flex; align-items: center; gap: 5px; font-size: 11px; color: var(--novo-grey-tx, #7A90A0); cursor: pointer; }
.hc-qa-consent input { accent-color: var(--novo-orange, #F56D0D); flex-shrink: 0; }
.hc-qa-success {
	display: none;
	text-align: center;
	padding: 6px 0;
}
.hc-qa-success i { font-size: 22px; color: var(--novo-green, #28b464); margin-bottom: 5px; display: block; }
.hc-qa-success strong { color: var(--novo-navy, #0B3954); font-size: 12.5px; display: block; }
.hc-qa-success span   { font-size: 11.5px; color: var(--novo-grey-tx, #7A90A0); }

/* ── Product Body ─────────────────────────────────────────────── */
.novo-product-body {
	background: var(--novo-grey-bg);
	padding: 60px 0 88px;
}
.product-grid {
	display: grid;
	grid-template-columns: 380px 1fr;
	gap: 40px;
	align-items: start;
}
.summary-panel { position: sticky; top: 72px; }
.summary-card {
	background: #fff;
	border-radius: 22px;
	box-shadow: 0 4px 40px rgba(11,57,84,.10);
	overflow: hidden;
}
.summary-card-head {
	background: linear-gradient(135deg, var(--novo-navy) 0%, var(--novo-navy-dark, #082233) 100%);
	padding: 28px 28px 24px;
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.sc-head-badge {
	font-size: 11px;
	font-weight: 600;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--novo-orange);
	background: rgba(245,109,13,.15);
	border: 1px solid rgba(245,109,13,.25);
	padding: 3px 10px;
	border-radius: 999px;
	width: fit-content;
}
.sc-head-title { font-size: 18px; font-weight: 700; color: #fff; margin: 0; }
.sc-head-sub   { font-size: 13px; color: rgba(255,255,255,.55); margin: 0; }
.sc-avail {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 12px;
	font-weight: 600;
	padding: 4px 12px;
	border-radius: 999px;
	width: fit-content;
}
.sc-avail::before {
	content: '';
	width: 6px; height: 6px;
	border-radius: 50%;
	animation: blink 2s ease-in-out infinite;
}
.sc-avail.in-stock  { background: rgba(40,180,100,.15); color: #3ec878; }
.sc-avail.in-stock::before { background: #3ec878; }
.sc-avail.incoming  { background: rgba(240,180,0,.15);  color: #e6b800; }
.sc-avail.incoming::before { background: #e6b800; }
.sc-avail.reserved  { background: rgba(240,180,0,.15);  color: #e6b800; }
.sc-avail.reserved::before { background: #e6b800; }
.sc-avail.pending   { background: rgba(240,180,0,.15);  color: #e6b800; }
.sc-avail.pending::before  { background: #e6b800; }
.sc-avail.sold      { background: rgba(220,60,60,.15);  color: #e05555; }
.sc-avail.sold::before     { background: #e05555; animation: none; }

.sc-body { padding: 8px 0; }
.sc-spec-table { width: 100%; border-collapse: collapse; }
.sc-spec-table tr { transition: background .15s; }
.sc-spec-table tr:hover { background: var(--novo-grey-bg); }
.sc-spec-table td { padding: 11px 22px; font-size: 13.5px; border-bottom: 1px solid var(--novo-border); }
.sc-spec-table td:first-child { color: var(--novo-grey-tx); }
.sc-spec-table td:last-child  { color: var(--novo-navy); font-weight: 600; text-align: right; }
.sc-spec-table td.good        { color: #3ec878; }

.sc-cta {
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 18px 22px;
	border-top: 1px solid var(--novo-border);
}
.sc-team {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 14px 22px 18px;
	font-size: 12.5px;
	color: var(--novo-grey-tx);
}
.sc-avatars { display: flex; }
.sc-avatar {
	width: 28px; height: 28px;
	border-radius: 50%;
	border: 2px solid #fff;
	object-fit: cover;
	margin-left: -8px;
}
.sc-avatars .sc-avatar:first-child { margin-left: 0; }

/* Trust strip */
.sc-trust {
	display: flex;
	flex-direction: column;
	gap: 9px;
	padding: 16px 22px;
	border-top: 1px solid var(--novo-border);
}
.sc-trust-item {
	display: flex;
	align-items: center;
	gap: 9px;
	font-size: 12px;
	font-weight: 600;
	color: var(--novo-grey-tx);
}
.sc-trust-item i {
	color: var(--novo-orange);
	font-size: 12px;
	width: 14px;
	text-align: center;
	flex-shrink: 0;
}

/* Product Tabs */
.product-content { background: transparent; }
.product-tabs {
	display: flex;
	gap: 0;
	border-bottom: 1px solid var(--novo-border);
	margin-bottom: 28px;
}
.product-tab {
	padding: 12px 20px;
	font-size: 14px;
	font-weight: 500;
	color: var(--novo-grey-tx);
	background: none;
	border: none;
	border-bottom: 2px solid transparent;
	margin-bottom: -1px;
	cursor: pointer;
	transition: color .2s, border-color .2s;
}
.product-tab:hover { color: var(--novo-navy); }
.product-tab.active {
	color: var(--novo-orange);
	border-bottom-color: var(--novo-orange);
}
.tab-panel { display: none; }
.tab-panel--active { display: block; }

/* ── Part Detail ─────────────────────────────────────────────── */
.novo-part-detail { background: var(--novo-grey-bg); padding: 60px 0 88px; }
.sc-part-prefix { color: rgba(255,255,255,.55) !important; font-weight: 400 !important; }
.sc-part-number {
	font-family: monospace;
	font-size: 22px;
	font-weight: 700;
	color: #fff;
	letter-spacing: .05em;
}
.part-desc { background: #fff; border-radius: 16px; padding: 24px 28px; margin-bottom: 24px; }
.part-section-title {
	font-size: 16px;
	font-weight: 700;
	color: var(--novo-navy);
	display: flex;
	align-items: center;
	gap: 8px;
	margin: 0 0 14px;
}
.part-section-title i { color: var(--novo-orange); }
.part-compat-wrap { background: #fff; border-radius: 16px; padding: 24px 28px; margin-bottom: 24px; }
.part-compat-table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.part-compat-table th {
	text-align: left;
	padding: 10px 16px;
	font-size: 11.5px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: var(--novo-grey-tx);
	border-bottom: 2px solid var(--novo-border);
}
.part-compat-table td {
	padding: 11px 16px;
	border-bottom: 1px solid var(--novo-border);
	color: var(--novo-navy);
}
.part-compat-table tr:hover td { background: var(--novo-grey-bg); }
.compat-yes  { color: #3ec878; font-size: 12.5px; font-weight: 600; display: flex; align-items: center; gap: 5px; }
.compat-maybe{ color: var(--novo-grey-tx); font-size: 12.5px; display: flex; align-items: center; gap: 5px; }

/* ── Enquiry Strip ───────────────────────────────────────────── */
.novo-enquiry-strip {
	background: var(--novo-navy);
	padding: 80px 0;
}
.enquiry-layout {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 64px;
	align-items: center;
}
.enquiry-copy { color: #fff; }
.enquiry-copy .eyebrow {
	font-size: 11.5px;
	font-weight: 600;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--novo-orange);
	margin-bottom: 12px;
}
.enquiry-copy h2 { font-size: clamp(22px,3vw,36px); font-weight: 800; margin: 0 0 14px; color: #fff; }
.enquiry-copy p  { font-size: 15px; color: rgba(255,255,255,.55); line-height: 1.7; }
.enquiry-contacts { display: flex; flex-direction: column; gap: 10px; margin-top: 20px; }
.enquiry-contact-item {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 14px;
	color: rgba(255,255,255,.70);
	text-decoration: none;
	transition: color .2s;
}
.enquiry-contact-item:hover { color: var(--novo-orange); }
.enquiry-contact-item i { color: var(--novo-orange); width: 16px; }
.enquiry-card {
	background: rgba(255,255,255,.06);
	border: 1px solid rgba(255,255,255,.12);
	border-radius: 20px;
	padding: 32px 28px;
}
.enquiry-form-title { font-size: 17px; font-weight: 700; color: #fff; margin: 0 0 20px; }
.enq-row { margin-bottom: 12px; }
.enq-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.enq-field { display: flex; flex-direction: column; gap: 5px; }
.enq-field label { font-size: 12px; font-weight: 500; color: rgba(255,255,255,.50); }
.enq-field input,
.enq-field textarea,
.enq-field select {
	padding: 9px 13px;
	background: rgba(255,255,255,.07);
	border: 1px solid rgba(255,255,255,.14);
	border-radius: 10px;
	font-size: 13.5px;
	color: rgba(255,255,255,.85);
	outline: none;
	transition: border-color .2s;
	resize: vertical;
}
.enq-field input::placeholder,
.enq-field textarea::placeholder { color: rgba(255,255,255,.28); }
.enq-field input:focus,
.enq-field textarea:focus,
.enq-field select:focus { border-color: var(--novo-orange); }
.enq-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	margin-top: 14px;
}
.enq-consent { display: flex; align-items: center; gap: 6px; font-size: 12px; color: rgba(255,255,255,.40); cursor: pointer; }
.enq-success {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 14px;
	background: rgba(40,180,100,.12);
	border: 1px solid rgba(40,180,100,.25);
	border-radius: 10px;
	color: #4ad880;
	font-size: 13.5px;
	margin-top: 12px;
}

/* ── Related Items ───────────────────────────────────────────── */
.novo-related-items { padding: 72px 0 80px; background: var(--novo-grey-bg); }
.related-section .section-head { text-align: center; margin-bottom: 40px; }
.related-grid {
	display: grid;
	grid-template-columns: repeat(var(--rel-cols, 3), 1fr);
	gap: 24px;
}
.related-card {
	background: #fff;
	border-radius: 20px;
	border: 1px solid var(--novo-border);
	overflow: hidden;
	transition: transform .25s, box-shadow .25s, border-color .25s;
}
.related-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 32px rgba(11,57,84,.12);
	border-color: var(--novo-orange);
}
.rc-thumb-link { display: block; text-decoration: none; }
.rc-thumb {
	width: 100%;
	aspect-ratio: 16/9;
	background: var(--novo-grey-bg);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}
.rc-thumb img { width: 100%; height: 100%; object-fit: contain; }
.rc-thumb-placeholder { width: 100%; height: 100%; background: linear-gradient(135deg, var(--novo-grey-bg) 0%, #e0e8f0 100%); }
.rc-thumb--ct     { background: linear-gradient(135deg, #1a2f4a 0%, #0B3954 100%); }
.rc-thumb--mri    { background: linear-gradient(135deg, #1a3348 0%, #103a56 100%); }
.rc-thumb--xray   { background: linear-gradient(135deg, #2a2a3a 0%, #1a1a2a 100%); }
.rc-thumb--us     { background: linear-gradient(135deg, #1e3456 0%, #0B3954 100%); }
.rc-thumb--carm   { background: linear-gradient(135deg, #243050 0%, #162244 100%); }
.rc-thumb--spare  { background: linear-gradient(135deg, #3a2a1a 0%, #2a1a0a 100%); }
.rc-body { padding: 18px 18px 10px; }
.rc-brand { font-size: 11.5px; color: var(--novo-orange); font-weight: 600; text-transform: uppercase; letter-spacing: .06em; }
.rc-title { font-size: 15px; font-weight: 700; color: var(--novo-navy); margin: 6px 0 4px; line-height: 1.35; }
.rc-title a { text-decoration: none; color: inherit; }
.rc-title a:hover { color: var(--novo-orange); }
.rc-meta { font-size: 12.5px; color: var(--novo-grey-tx); margin: 0; }
.rc-foot { padding: 0 18px 18px; }
.rc-read-more {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	font-weight: 600;
	color: var(--novo-orange);
	text-decoration: none;
	transition: gap .2s;
}
.rc-read-more:hover { gap: 10px; }

/* ── Floating Quote Button ───────────────────────────────────── */
.novo-floating-quote {
	position: fixed;
	bottom: 28px;
	right: 28px;
	z-index: 9999;
	opacity: 0;
	transform: translateY(16px);
	pointer-events: none;
	transition: opacity .3s, transform .3s;
}
.novo-floating-quote.visible {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}
.float-quote-btn {
	display: inline-flex;
	align-items: center;
	gap: 9px;
	padding: 13px 22px;
	background: var(--novo-orange);
	color: #fff;
	border-radius: 999px;
	font-size: 14px;
	font-weight: 600;
	text-decoration: none;
	box-shadow: 0 8px 24px rgba(245,109,13,.35);
	transition: background .2s, box-shadow .2s, transform .2s;
}
.float-quote-btn:hover {
	background: #e05e00;
	box-shadow: 0 12px 32px rgba(245,109,13,.40);
	transform: translateY(-2px);
}
.float-quote-btn--pulse { animation: floatPulse 3s ease-in-out infinite; }

/* ── Article Hero ────────────────────────────────────────────── */
.novo-article-hero {
	position: relative;
	background: radial-gradient(ellipse at 65% 40%, var(--novo-navy3, #103a56) 0%, var(--novo-navy, #0B3954) 50%, var(--novo-navy-dark, #0a2d45) 100%);
	padding: calc(var(--novo-topbar-h, 36px) + var(--novo-hdr-h, 72px) + 36px) 0 0;
	overflow: hidden;
}
.novo-article-hero .hero-ring {
	position: absolute;
	width: 700px; height: 700px;
	border-radius: 50%;
	border: 1px solid rgba(245,109,13,.07);
	right: -200px;
	top: 50%;
	transform: translateY(-50%);
	animation: ringPulse 8s ease-in-out infinite;
}
.hero-inner {
	position: relative;
	z-index: 2;
	max-width: 840px;
	padding-bottom: 60px;
}
.hero-meta-top {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-bottom: 18px;
	flex-wrap: wrap;
}
.article-category {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	padding: 5px 13px;
	background: rgba(245,109,13,.12);
	border: 1px solid rgba(245,109,13,.25);
	border-radius: 999px;
	font-size: 11.5px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: var(--novo-orange);
}
.article-category .blink { font-size: 5px; animation: blink 2s ease-in-out infinite; }
.hero-read-time {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 12px;
	color: rgba(255,255,255,.45);
}
.hero-title {
	font-size: clamp(28px,4.5vw,52px);
	font-weight: 900;
	line-height: 1.1;
	letter-spacing: -2px;
	color: #fff;
	margin: 0 0 16px;
}
.hero-title span {
	background: linear-gradient(135deg, var(--novo-orange) 0%, #ffd27d 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}
.hero-excerpt {
	font-size: 17px;
	line-height: 1.7;
	color: rgba(255,255,255,.55);
	max-width: 680px;
	margin: 0 0 28px;
}
.hero-author-row {
	display: flex;
	align-items: center;
	gap: 14px;
	flex-wrap: wrap;
}
.author-avatar {
	width: 46px; height: 46px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--novo-orange) 0%, #c04e00 100%);
	color: #fff;
	font-size: 18px;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	flex-shrink: 0;
}
.author-avatar img { width: 100%; height: 100%; object-fit: cover; }
.author-info { display: flex; flex-direction: column; gap: 2px; }
.author-info strong { font-size: 13.5px; color: #fff; font-weight: 600; }
.author-info span   { font-size: 12px; color: rgba(255,255,255,.45); }
.hero-meta-divider { width: 1px; height: 28px; background: rgba(255,255,255,.15); }
.hero-date {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 12.5px;
	color: rgba(255,255,255,.45);
}
.hero-image-strip {
	position: relative;
	height: 380px;
	margin: 0 calc(-1 * ((100vw - 100%) / 2));
	overflow: hidden;
}
.hero-image-strip img { width: 100%; height: 100%; object-fit: cover; }
.hero-image-overlay {
	position: absolute;
	inset: 0;
	background: repeating-linear-gradient(0deg, transparent, transparent 39px, rgba(255,255,255,.04) 39px, rgba(255,255,255,.04) 40px),
	            repeating-linear-gradient(90deg, transparent, transparent 39px, rgba(255,255,255,.04) 39px, rgba(255,255,255,.04) 40px);
}
.hero-image-icon {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 80px;
	color: rgba(255,255,255,.08);
	background: var(--novo-navy-dark, #082233);
}
.hero-image-badge {
	position: absolute;
	bottom: 20px;
	left: 20px;
	display: flex;
	align-items: center;
	gap: 8px;
	background: rgba(11,57,84,.75);
	backdrop-filter: blur(8px);
	border: 1px solid rgba(255,255,255,.12);
	padding: 8px 16px;
	border-radius: 12px;
	font-size: 12.5px;
	font-weight: 500;
	color: rgba(255,255,255,.80);
}
.hero-image-badge i { color: var(--novo-orange); }

/* ── Article Body ─────────────────────────────────────────────── */
.novo-article-body { padding: 60px 0 100px; }
.article-layout {
	display: grid;
	grid-template-columns: 1fr 300px;
	gap: 48px;
	align-items: start;
}
.article-sidebar { position: sticky; top: 24px; display: flex; flex-direction: column; gap: 20px; }
.article-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	background: #fff;
	border: 1px solid var(--novo-border);
	border-radius: 16px;
	padding: 14px 20px;
	margin-bottom: 28px;
}
.toolbar-left { display: flex; align-items: center; gap: 10px; }
.toolbar-right { display: flex; align-items: center; gap: 8px; }
.toolbar-label { font-size: 12.5px; color: var(--novo-grey-tx); font-weight: 500; }
.share-btn {
	width: 32px; height: 32px;
	border-radius: 8px;
	border: 1px solid var(--novo-border);
	background: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 13px;
	color: var(--novo-grey-tx);
	cursor: pointer;
	text-decoration: none;
	transition: background .2s, color .2s, border-color .2s;
}
.share-btn:hover { background: var(--novo-navy); color: #fff; border-color: var(--novo-navy); }
.toolbar-print-btn, .save-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 13px;
	border-radius: 8px;
	font-size: 12.5px;
	font-weight: 500;
	cursor: pointer;
	border: 1px solid var(--novo-border);
	background: #fff;
	color: var(--novo-grey-tx);
	transition: all .2s;
}
.save-btn:hover { background: var(--novo-grey-bg); }
.save-btn.saved { background: var(--novo-orange); color: #fff; border-color: var(--novo-orange); }

/* Prose */
.prose { line-height: 1.85; font-size: 16.5px; color: #2d4a5c; }
.prose > * + * { margin-top: 1.2em; }
.prose h2 {
	font-size: 22px;
	font-weight: 700;
	color: var(--novo-navy);
	position: relative;
	padding-left: 16px;
	margin-top: 2em;
}
.prose h2::before {
	content: '';
	position: absolute;
	left: 0; top: .15em;
	width: 4px; height: 26px;
	background: var(--novo-orange);
	border-radius: 2px;
}
.prose h3 { font-size: 18px; font-weight: 700; color: var(--novo-navy); margin-top: 1.5em; }
.prose p  { margin: 0 0 1em; }
.prose a  { color: var(--novo-orange); text-decoration: underline; }
.prose ul, .prose ol { padding-left: 1.4em; margin-bottom: 1em; }
.prose li { margin-bottom: .4em; }
.pull-quote {
	border-left: 4px solid var(--novo-orange);
	padding: 12px 20px;
	margin: 24px 0;
	position: relative;
}
.pull-quote::before {
	content: '\201C';
	position: absolute;
	top: -8px; left: 16px;
	font-size: 60px;
	color: var(--novo-orange);
	opacity: .25;
	line-height: 1;
}
.pull-quote cite { display: block; font-size: 12.5px; color: var(--novo-grey-tx); margin-top: 8px; }
.callout {
	display: flex;
	gap: 12px;
	padding: 16px 18px;
	background: var(--novo-grey-bg);
	border-radius: 12px;
	border-left: 4px solid var(--novo-border);
	font-size: 14px;
}
.callout.warning { border-color: var(--novo-orange); background: rgba(245,109,13,.04); }
.callout.info    { border-color: #3b82f6; background: rgba(59,130,246,.04); }
.stat-row {
	display: grid;
	grid-template-columns: repeat(3,1fr);
	gap: 16px;
	margin: 24px 0;
}
.stat-box {
	text-align: center;
	padding: 20px;
	background: var(--novo-grey-bg);
	border-radius: 14px;
}
.prose-divider { border: none; border-top: 1px solid var(--novo-border); margin: 32px 0; }
.article-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 32px; }
.article-tag {
	padding: 5px 13px;
	background: var(--novo-grey-bg);
	border: 1px solid var(--novo-border);
	border-radius: 999px;
	font-size: 12.5px;
	color: var(--novo-navy);
	text-decoration: none;
	transition: all .2s;
}
.article-tag:hover { background: var(--novo-orange); color: #fff; border-color: var(--novo-orange); }
.author-card {
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 20px 22px;
	background: var(--novo-grey-bg);
	border-radius: 16px;
	border: 1px solid var(--novo-border);
	margin-top: 32px;
}
.author-card-avatar {
	width: 54px; height: 54px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--novo-orange) 0%, #c04e00 100%);
	color: #fff;
	font-size: 22px;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.author-card-info { display: flex; flex-direction: column; gap: 3px; }
.author-card-info strong { font-size: 15px; color: var(--novo-navy); }
.author-card-role { font-size: 12.5px; color: var(--novo-grey-tx); }

/* Sidebar Widgets */
.sidebar-widget {
	background: #fff;
	border: 1px solid var(--novo-border);
	border-radius: 18px;
	overflow: hidden;
}
.sw-head {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 14px 18px;
	border-bottom: 1px solid var(--novo-border);
}
.sw-head i { color: var(--novo-orange); font-size: 13px; }
.sw-head span { font-size: 11.5px; font-weight: 600; text-transform: uppercase; letter-spacing: .08em; color: var(--novo-grey-tx); }
.sw-body { padding: 16px 18px; }
.toc-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 2px; }
.toc-item a {
	display: block;
	padding: 6px 10px;
	border-radius: 8px;
	font-size: 13px;
	color: var(--novo-navy);
	text-decoration: none;
	transition: background .15s, color .15s;
}
.toc-item a:hover,
.toc-item a.active { background: var(--novo-grey-bg); color: var(--novo-orange); }
.toc-item--h3 a { padding-left: 22px; font-size: 12px; color: var(--novo-grey-tx); }

.cta-widget {
	background: var(--novo-navy) !important;
	border-color: transparent !important;
}
.cta-widget h3 { font-size: 16px; color: #fff; font-weight: 700; padding: 18px 18px 10px; margin: 0; }
.cta-widget p  { font-size: 13px; color: rgba(255,255,255,.55); padding: 0 18px 12px; margin: 0; }
.cta-widget a.btn { margin: 0 18px 18px; display: inline-flex; }

.newsletter-form { display: flex; flex-direction: column; gap: 8px; }
.newsletter-input {
	width: 100%;
	padding: 9px 13px;
	border: 1.5px solid var(--novo-border);
	border-radius: 10px;
	font-size: 13px;
	outline: none;
	transition: border-color .2s;
}
.newsletter-input:focus { border-color: var(--novo-orange); }
.newsletter-btn { width: 100%; justify-content: center; }

.related-mini { display: flex; flex-direction: column; gap: 14px; }
.rmc {
	display: flex;
	align-items: center;
	gap: 12px;
	text-decoration: none;
	transition: opacity .2s;
}
.rmc:hover { opacity: .8; }
.rmc-thumb {
	width: 52px; height: 52px;
	border-radius: 10px;
	object-fit: cover;
	flex-shrink: 0;
	background: var(--novo-grey-bg);
}
.rmc-thumb--placeholder { background: linear-gradient(135deg, #e8f0f7 0%, #ccd8e8 100%); }
.rmc-info { display: flex; flex-direction: column; gap: 3px; }
.rmc-title { font-size: 13px; font-weight: 600; color: var(--novo-navy); line-height: 1.35; }
.rmc-meta  { font-size: 11.5px; color: var(--novo-grey-tx); }

/* ── Legal Layout ─────────────────────────────────────────────── */
.updated-bar { background: #fff; border-bottom: 1px solid var(--novo-border); padding: 13px 0; }
.updated-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
}
.updated-chip {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	font-size: 13px;
	color: var(--novo-grey-tx);
}
.updated-chip i, .updated-chip svg { color: var(--novo-orange); fill: var(--novo-orange); width: 12px; height: 12px; flex-shrink: 0; }
.updated-chip strong { color: var(--novo-navy); }
.dl-link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 7px 15px;
	border: 1.5px solid var(--novo-orange);
	border-radius: 999px;
	font-size: 12.5px;
	font-weight: 600;
	color: var(--novo-orange);
	text-decoration: none;
	transition: background .2s, color .2s;
}
.dl-link:hover { background: var(--novo-orange); color: #fff; }

.cookie-overview { padding: 60px 0 0; }
.cookie-overview-grid {
	display: grid;
	grid-template-columns: repeat(4,1fr);
	gap: 16px;
}
.co-card {
	background: #fff;
	border-radius: 20px;
	border: 1px solid var(--novo-border);
	padding: 24px 20px;
	text-align: center;
	transition: transform .25s, box-shadow .25s;
}
.co-card:hover { transform: translateY(-4px); box-shadow: 0 12px 28px rgba(11,57,84,.09); }
.co-icon {
	width: 48px; height: 48px;
	border-radius: 14px;
	margin: 0 auto 14px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 20px;
}
.co-icon.essential  { background: rgba(40,180,100,.14); color: #3ec878; }
.co-icon.functional { background: rgba(11,57,84,.12);   color: var(--novo-navy); }
.co-icon.analytics  { background: rgba(245,109,13,.12); color: var(--novo-orange); }
.co-icon.marketing  { background: rgba(120,60,200,.12); color: #8b5cf6; }
.co-card-label { font-size: 10.5px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--novo-grey-tx); margin-bottom: 6px; }
.co-card-title { font-size: 14.5px; font-weight: 700; color: var(--novo-navy); margin-bottom: 8px; }
.co-card-desc  { font-size: 12.5px; color: var(--novo-grey-tx); line-height: 1.5; margin-bottom: 12px; }
.co-card-tag { display: inline-flex; padding: 3px 10px; border-radius: 999px; font-size: 11.5px; font-weight: 600; }
.co-card-tag.required { background: rgba(40,180,100,.12); color: #3ec878; }
.co-card-tag.optional { background: rgba(245,109,13,.12); color: var(--novo-orange); }

.terms-wrap { padding: 72px 0 96px; }
.tc {
	background: #fff;
	border: 1px solid var(--novo-border);
	border-radius: 24px;
	box-shadow: 0 4px 32px rgba(11,57,84,.08);
	margin-bottom: 32px;
	overflow: hidden;
}
.tc-header {
	display: flex;
	align-items: center;
	gap: 20px;
	padding: 32px 40px 28px;
	border-bottom: 1px solid var(--novo-border);
}
.tc-icon {
	width: 54px; height: 54px;
	border-radius: 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 22px;
	flex-shrink: 0;
}
.tc-icon.collect { background: rgba(11,57,84,.09);   color: var(--novo-navy); }
.tc-icon.rights  { background: rgba(40,180,100,.12); color: #3ec878; }
.tc-icon.what    { background: rgba(245,109,13,.12); color: var(--novo-orange); }
.tc-icon.types   { background: rgba(59,130,246,.12); color: #3b82f6; }
.tc-icon.third   { background: rgba(120,60,200,.12); color: #8b5cf6; }
.tc-icon.manage  { background: rgba(240,180,0,.12);  color: #f0b400; }
.tc-icon.eq      { background: rgba(11,57,84,.10);   color: var(--novo-navy); }
.tc-icon.pts     { background: rgba(245,109,13,.12); color: var(--novo-orange); }
.tc-htitle { font-size: 22px; font-weight: 900; color: var(--novo-navy); margin: 0 0 4px; letter-spacing: -.4px; }
.tc-hsub   { font-size: 13.5px; color: var(--novo-grey-tx); margin: 0; }
.tc-badge  {
	margin-left: auto;
	flex-shrink: 0;
	padding: 5px 14px;
	background: rgba(40,180,100,.10);
	color: #3ec878;
	font-size: 10px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1.5px;
	border-radius: 999px;
	border: 1px solid rgba(40,180,100,.20);
	align-self: center;
}
.tc-body { padding: 10px 40px 36px; }
.tc-body .prose { font-size: 15px; }

/* Clause accordion (inside tc-body) */
.clause { border-bottom: 1px solid var(--novo-border); padding: 24px 0; }
.clause:last-child { border-bottom: none; padding-bottom: 0; }
.clause-head {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	cursor: pointer;
	user-select: none;
}
.clause-num {
	width: 32px; height: 32px; flex-shrink: 0;
	border-radius: 9px;
	background: var(--novo-grey-bg);
	border: 1px solid var(--novo-border);
	display: flex; align-items: center; justify-content: center;
	font-size: 11px; font-weight: 800; color: var(--novo-grey-tx);
	margin-top: 1px;
	transition: background .2s, color .2s, border-color .2s;
}
.clause:hover .clause-num { background: rgba(245,109,13,.10); color: var(--novo-orange); border-color: rgba(245,109,13,.25); }
.clause-title { font-size: 15.5px; font-weight: 800; color: var(--novo-navy); line-height: 1.3; flex: 1; padding-top: 5px; }
.clause-chevron { color: var(--novo-grey-tx); font-size: 11px; flex-shrink: 0; margin-top: 7px; transition: transform .25s; }
.clause-head.open .clause-chevron { transform: rotate(180deg); color: var(--novo-orange); }
.clause-body { padding: 14px 0 0 46px; display: none; }
.clause-body.open { display: block; }
.clause-body p { font-size: 14px; color: var(--novo-grey-tx); line-height: 1.85; margin-bottom: 10px; }
.clause-body p:last-child { margin-bottom: 0; }
.clause-body ul { list-style: none; margin-top: 4px; padding: 0; display: flex; flex-direction: column; gap: 7px; }
.clause-body ul li { font-size: 13.5px; color: var(--novo-grey-tx); line-height: 1.60; padding-left: 18px; position: relative; }
.clause-body ul li::before { content: ''; position: absolute; left: 0; top: 8px; width: 5px; height: 5px; border-radius: 50%; background: var(--novo-orange); }
.clause-body strong { color: var(--novo-navy); font-weight: 700; }
.clause-note {
	padding: 12px 16px;
	border-radius: 10px;
	background: rgba(245,109,13,.06);
	border: 1px solid rgba(245,109,13,.15);
	font-size: 13px;
	color: var(--novo-navy);
	line-height: 1.65;
	margin: 10px 0;
	display: flex;
	gap: 10px;
	align-items: flex-start;
}
.clause-note i { color: var(--novo-orange); flex-shrink: 0; margin-top: 2px; font-size: 13px; }
.clause-note.info { background: rgba(11,57,84,.05); border-color: rgba(11,57,84,.12); }
.clause-note.info i { color: var(--novo-navy); }
.clause-note.warning { background: rgba(245,109,13,.07); border-left: 3px solid var(--novo-orange); }
.clause-note.gdpr    { background: rgba(40,180,100,.06); border-left: 3px solid #3ec878; }
.rights-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin: 12px 0; }
.right-chip {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 10px 14px;
	background: var(--novo-grey-bg);
	border-radius: 10px;
	font-size: 13px;
	color: var(--novo-navy);
}
.right-chip i { color: var(--novo-orange); width: 14px; }
.cookie-table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.cookie-table th { background: var(--novo-grey-bg); padding: 10px 14px; text-align: left; font-weight: 600; color: var(--novo-navy); border-bottom: 2px solid var(--novo-border); }
.cookie-table td { padding: 10px 14px; border-bottom: 1px solid var(--novo-border); color: var(--novo-navy); }
.cookie-table tr:hover td { background: var(--novo-grey-bg); }

/* ── Cookie Policy: ct-badge ── */
.ct-badge {
	display: inline-block; font-size: 10px; font-weight: 700;
	text-transform: uppercase; letter-spacing: .8px;
	padding: 3px 10px; border-radius: 20px;
}
.ct-badge.essential  { background: rgba(40,180,100,.10); color: #3ec878; border: 1px solid rgba(40,180,100,.20); }
.ct-badge.functional { background: rgba(11,57,84,.08);   color: var(--novo-navy); border: 1px solid rgba(11,57,84,.15); }
.ct-badge.analytics  { background: rgba(245,109,13,.10); color: var(--novo-orange); border: 1px solid rgba(245,109,13,.20); }
.ct-badge.marketing  { background: rgba(124,92,252,.10); color: #7C5CFC; border: 1px solid rgba(124,92,252,.20); }

/* ── Cookie Policy: browser grid ── */
.browser-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 12px; }
.browser-item {
	display: flex; align-items: flex-start; gap: 10px;
	padding: 12px 14px; background: var(--novo-grey-bg);
	border: 1px solid var(--novo-border); border-radius: 12px;
}
.browser-item i { color: var(--novo-navy); font-size: 14px; flex-shrink: 0; margin-top: 2px; }
.browser-item strong { font-size: 13px; color: var(--novo-navy); display: block; margin-bottom: 3px; }
.browser-item span { font-size: 12px; color: var(--novo-grey-tx); line-height: 1.55; }

/* ── Cookie Policy: consent toggles ── */
.consent-row {
	display: flex; align-items: center; gap: 14px;
	padding: 12px 16px; background: var(--novo-grey-bg);
	border: 1px solid var(--novo-border); border-radius: 12px; margin-top: 8px;
}
.toggle-pill {
	width: 40px; height: 22px; border-radius: 11px;
	flex-shrink: 0; position: relative; transition: background .2s;
}
.toggle-pill::after {
	content: ''; position: absolute; top: 3px;
	width: 16px; height: 16px; border-radius: 50%;
	background: #fff; box-shadow: 0 1px 4px rgba(0,0,0,.18); transition: left .2s;
}
.toggle-pill.on  { background: #3ec878; }
.toggle-pill.off { background: #CBD5E0; }
.toggle-pill.on::after  { left: 21px; }
.toggle-pill.off::after { left: 3px; }
.consent-label { flex: 1; }
.consent-label strong { font-size: 13.5px; color: var(--novo-navy); display: block; margin-bottom: 2px; }
.consent-label span { font-size: 12px; color: var(--novo-grey-tx); }
.consent-tag {
	font-size: 10px; font-weight: 700; text-transform: uppercase;
	letter-spacing: 1px; padding: 3px 10px; border-radius: 20px; flex-shrink: 0;
}
.consent-tag.required { background: rgba(40,180,100,.10); color: #3ec878; border: 1px solid rgba(40,180,100,.20); }
.consent-tag.optional { background: rgba(245,109,13,.10); color: var(--novo-orange); border: 1px solid rgba(245,109,13,.20); }

/* ── Terms Page: Returns & Contacts footer grid ── */
.tc-footer-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
	margin-top: 28px;
}
.tc-footer-box-r,
.tc-footer-box-c {
	border-radius: 12px;
	padding: 18px 20px;
}
.tc-footer-box-r { background: rgba(245,109,13,.05); border: 1px solid rgba(245,109,13,.15); }
.tc-footer-box-c { background: rgba(11,57,84,.04);   border: 1px solid rgba(11,57,84,.10); }
.tc-footer-head {
	font-size: 11px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 2px;
	margin-bottom: 10px;
	display: flex;
	align-items: center;
	gap: 7px;
}
.tc-footer-head.orange { color: var(--novo-orange); }
.tc-footer-head.navy   { color: var(--novo-navy); }
.tc-footer-head.navy i { color: var(--novo-orange); }
.tc-contacts-list {
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 6px;
	padding: 0;
	margin: 0;
}
@media (max-width: 640px) { .tc-footer-grid { grid-template-columns: 1fr; } }

/* ── Service Packages ─────────────────────────────────────────── */
.novo-service-packages { padding: 96px 0; }
.packages-section .section-head { text-align: center; max-width: 620px; margin: 0 auto 52px; }
.packages-grid {
	display: grid;
	grid-template-columns: repeat(var(--pkg-cols, 3), 1fr);
	gap: 20px;
}
.pkg-card {
	background: #fff;
	border-radius: 22px;
	border: 1.5px solid var(--novo-border);
	padding: 32px 28px;
	position: relative;
	transition: transform .25s, box-shadow .25s;
}
.pkg-card:hover { transform: translateY(-5px); box-shadow: 0 16px 40px rgba(11,57,84,.12); }
.pkg-card.highlight {
	border-color: var(--novo-orange);
	box-shadow: 0 8px 36px rgba(245,109,13,.15);
}
.pkg-popular {
	position: absolute;
	top: -13px;
	right: 24px;
	background: var(--novo-orange);
	color: #fff;
	font-size: 11.5px;
	font-weight: 700;
	padding: 4px 14px;
	border-radius: 999px;
}
.pkg-icon {
	width: 52px; height: 52px;
	border-radius: 14px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 20px;
	margin-bottom: 16px;
}
.pkg-icon.basic    { background: var(--novo-grey-bg); color: var(--novo-grey-tx); }
.pkg-icon.standard { background: rgba(245,109,13,.12); color: var(--novo-orange); }
.pkg-icon.premium  { background: rgba(11,57,84,.10);   color: var(--novo-navy); }
.pkg-name  { font-size: 11px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--novo-grey-tx); margin-bottom: 6px; }
.pkg-title { font-size: 22px; font-weight: 700; color: var(--novo-navy); margin-bottom: 8px; }
.pkg-desc  { font-size: 13.5px; color: var(--novo-grey-tx); line-height: 1.6; margin-bottom: 18px; }
.pkg-features { margin-bottom: 24px; }
.pkg-features ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.pkg-feature {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	font-size: 13.5px;
	color: var(--novo-navy);
}
.pkg-feature i { color: #3ec878; margin-top: 2px; width: 14px; flex-shrink: 0; }
.pkg-feature.no { color: var(--novo-grey-tx); }
.pkg-feature.no i { color: var(--novo-border); }
.pkg-cta { margin-top: auto; }
.basic-btn, .standard-btn, .premium-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	padding: 12px 20px;
	border-radius: 12px;
	font-size: 14px;
	font-weight: 600;
	text-decoration: none;
	transition: all .2s;
	cursor: pointer;
	border: none;
}
.basic-btn   { background: var(--novo-grey-bg); color: var(--novo-navy); border: 1.5px solid var(--novo-border); }
.basic-btn:hover { background: var(--novo-orange); color: #fff; border-color: var(--novo-orange); }
.standard-btn{ background: var(--novo-orange); color: #fff; }
.standard-btn:hover { background: #e05e00; }
.premium-btn { background: var(--novo-navy); color: #fff; }
.premium-btn:hover { background: var(--novo-navy-dark, #082233); }

/* ── Responsive ───────────────────────────────────────────────── */
@media (max-width: 1100px) {
	.product-hero-layout { grid-template-columns: 1fr; gap: 40px; }
	.product-hero-card { order: -1; }
	.product-grid { grid-template-columns: 1fr; }
	.summary-panel { position: static; }
	.cookie-overview-grid { grid-template-columns: repeat(2,1fr); }
}

@media (max-width: 900px) {
	.article-layout { grid-template-columns: 1fr; }
	.article-sidebar { position: static; }
	.packages-grid { --pkg-cols: 1; max-width: 480px; margin: 0 auto; }
	.enquiry-layout { grid-template-columns: 1fr; gap: 32px; }
	.catalogue-layout { grid-template-columns: 1fr; }
	.sidebar { position: static; }
}

@media (max-width: 680px) {
	.related-grid { --rel-cols: 1; }
	.stat-row     { grid-template-columns: 1fr; }
	.rights-grid  { grid-template-columns: 1fr; }
	.cookie-overview-grid { grid-template-columns: 1fr 1fr; }
	.tc-header    { flex-wrap: wrap; padding: 20px 22px 16px; }
	.tc-body      { padding: 8px 22px 24px; }
	.enq-row-2    { grid-template-columns: 1fr; }
	.form-inner   { grid-template-columns: 1fr; gap: 36px; }
	/* Breadcrumb action buttons hidden on mobile — matches source HTML shared.css */
	.bc-actions   { display: none; }
}

/* ══════════════════════════════════════════════════════════════
   TRADE-IN VALUATION FORM SECTION  (.form-section)
   Dark navy two-column layout: copy left, CF7 card right.
══════════════════════════════════════════════════════════════ */
.form-section {
	background: var(--novo-navy-dark, #071f2e);
	padding: 96px 0;
	position: relative;
	overflow: hidden;
}
.form-section::before {
	content: '';
	position: absolute;
	inset: 0;
	pointer-events: none;
	background: radial-gradient(ellipse at 75% 50%, rgba(245,109,13,.18) 0%, transparent 55%);
}
.form-section::after {
	content: '';
	position: absolute;
	width: 600px; height: 600px;
	border: 1px solid rgba(245,109,13,.06);
	border-radius: 50%;
	top: 50%; right: -100px;
	transform: translateY(-50%);
	pointer-events: none;
}
.form-inner {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1fr 480px;
	gap: 72px;
	align-items: start;
}
.form-left { color: #fff; }
.form-eyebrow {
	font-size: 10.5px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 3px;
	color: var(--novo-orange-light, #f9a458);
	margin-bottom: 14px;
	display: flex;
	align-items: center;
	gap: 8px;
}
.form-title {
	font-size: clamp(26px, 3.5vw, 38px);
	font-weight: 900;
	color: #fff;
	line-height: 1.15;
	letter-spacing: -.8px;
	margin-bottom: 14px;
}
.form-title span { color: var(--novo-orange); }
/* Scoped to dark .form-section — avoids overriding .form-sub on white-bg pages */
.form-section .form-sub,
.novo-tradein-form-section .form-sub {
	font-size: 15px;
	color: rgba(255,255,255,.52);
	line-height: 1.80;
	margin-bottom: 28px;
}
.form-perks { display: flex; flex-direction: column; gap: 11px; }
.form-perk  { display: flex; align-items: center; gap: 10px; font-size: 13px; font-weight: 600; color: rgba(255,255,255,.60); }
.form-perk i { color: var(--novo-orange); font-size: 12px; width: 14px; flex-shrink: 0; }
.form-perk svg { fill: var(--novo-orange); width: 14px; height: 14px; flex-shrink: 0; }
.form-card {
	background: rgba(255,255,255,.06);
	border: 1px solid rgba(255,255,255,.10);
	border-radius: 22px;
	padding: 32px;
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}

@media (max-width: 1100px) {
	.form-inner { grid-template-columns: 1fr; gap: 42px; }
}
/* ── Legal layout & updated-bar helpers ── */
.novo-legal-layout { display: block; width: 100%; }
.updated-meta      { display: flex; align-items: center; gap: 8px; }

/* ══════════════════════════════════════════════════════════════
   PRODUCT DETAIL AREA — inline layout (description + highlights + spec groups)
   Matches product-equipment-preview-.html .detail-area section
══════════════════════════════════════════════════════════════ */

/* Section labels */
.s-eyebrow {
	display: block;
	font-size: 10.5px;
	font-weight: 700;
	letter-spacing: 3.5px;
	text-transform: uppercase;
	color: var(--novo-orange, #F56D0D);
	margin-bottom: 8px;
}
.s-title {
	font-size: clamp(22px, 3vw, 30px);
	font-weight: 900;
	color: var(--novo-navy, #0B3954);
	letter-spacing: -1px;
	line-height: 1.1;
	margin: 0 0 6px;
}
.s-title span { color: var(--novo-orange, #F56D0D); }
.s-divider {
	display: block;
	width: 44px;
	height: 4px;
	border-radius: 2px;
	background: linear-gradient(90deg, var(--novo-orange, #F56D0D), rgba(245,109,13,.20));
	margin-bottom: 28px;
}

/* Description prose card */
.desc-card {
	background: #fff;
	border-radius: 20px;
	padding: 32px 36px;
	box-shadow: 0 4px 24px rgba(11,57,84,.08);
	border: 1px solid var(--novo-border, #EEF2F6);
	margin-bottom: 28px;
}
.desc-card p { font-size: 15px; color: var(--novo-grey-tx, #7A90A0); line-height: 1.90; margin-bottom: 16px; }
.desc-card p:last-child { margin-bottom: 0; }

/* Highlight cards grid */
.highlights-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 14px;
	margin-bottom: 36px;
}
.hl-card {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	background: #fff;
	border: 1px solid var(--novo-border, #EEF2F6);
	border-left: 3px solid var(--novo-orange, #F56D0D);
	border-radius: 16px;
	padding: 20px;
	box-shadow: 0 3px 16px rgba(11,57,84,.06);
	transition: transform .2s, box-shadow .2s;
}
.hl-card:hover { transform: translateY(-3px); box-shadow: 0 10px 32px rgba(11,57,84,.12); }
.hl-icon {
	width: 44px;
	height: 44px;
	flex-shrink: 0;
	border-radius: 12px;
	background: rgba(245,109,13,.10);
	color: var(--novo-orange, #F56D0D);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
	transition: background .2s, color .2s;
}
.hl-card:hover .hl-icon { background: var(--novo-orange, #F56D0D); color: #fff; }
.hl-card strong { display: block; font-size: 13px; font-weight: 800; color: var(--novo-navy, #0B3954); margin-bottom: 3px; }
.hl-card span   { font-size: 12px; color: var(--novo-grey-tx, #7A90A0); line-height: 1.55; }

/* Full spec groups */
.full-specs { margin-bottom: 28px; }
.spec-groups-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.sg {
	background: #fff;
	border: 1px solid var(--novo-border, #EEF2F6);
	border-radius: 16px;
	overflow: hidden;
}
.sg-head {
	display: flex;
	align-items: center;
	gap: 9px;
	padding: 13px 18px;
	background: var(--novo-navy, #0B3954);
	color: #fff;
	font-size: 11.5px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 1.5px;
}
.sg-head i {
	width: 26px;
	height: 26px;
	flex-shrink: 0;
	border-radius: 7px;
	background: rgba(245,109,13,.22);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 11px;
	color: var(--novo-orange-l, #FF8F3F);
}
.sg-table { width: 100%; border-collapse: collapse; }
.sg-table tr { transition: background .15s; }
.sg-table tr:hover { background: var(--novo-grey-bg, #F7F8FA); }
.sg-table tr:last-child td { border-bottom: none; }
.sg-table td { padding: 9px 18px; font-size: 12.5px; border-bottom: 1px solid var(--novo-border, #EEF2F6); vertical-align: middle; }
.sg-table td:first-child { color: var(--novo-grey-tx, #7A90A0); font-weight: 600; width: 50%; }
.sg-table td:last-child  { color: var(--novo-navy, #0B3954); font-weight: 700; }
.badge-mini {
	display: inline-block;
	background: rgba(245,109,13,.08);
	color: var(--novo-orange, #F56D0D);
	font-size: 10px;
	font-weight: 700;
	padding: 2px 8px;
	border-radius: 8px;
}

/* Thumbnail strip in hero card */
.hc-thumbs {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 8px;
}
.hc-thumb {
	aspect-ratio: 1;
	background: #fff;
	border: 2px solid var(--novo-border, #EEF2F6);
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
	color: var(--novo-grey-tx, #7A90A0);
	cursor: pointer;
	overflow: hidden;
	box-shadow: 0 2px 8px rgba(11,57,84,.08);
	transition: border-color .2s, color .2s, background .2s, transform .2s, box-shadow .2s;
}
/* Images inside thumbnails — fill and crop to square */
.hc-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	border-radius: 10px;
}
.hc-thumb:hover,
.hc-thumb.active {
	border-color: var(--novo-orange, #F56D0D);
	color: var(--novo-orange, #F56D0D);
	background: rgba(245,109,13,.06);
	transform: translateY(-2px);
	box-shadow: 0 6px 18px rgba(245,109,13,.18);
}

/* Responsive adjustments */
@media (max-width: 1100px) {
	.highlights-grid    { grid-template-columns: 1fr 1fr; }
	.spec-groups-grid   { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
	.highlights-grid    { grid-template-columns: 1fr; }
	.hc-thumbs          { grid-template-columns: repeat(4, 1fr); }
	.s-title            { font-size: 22px; }
}

/* --------------------------------------------------------------------------
   Source: novo-cf7.css
   -------------------------------------------------------------------------- */
/**
 * novo-cf7.css
 *
 * Styles for:
 *   1. The global Quote Popup modal (.nvo-quote-overlay / #nvoQuoteModal)
 *   2. CF7 form overrides inside .nvo-quote-body to match the NOVO
 *      design system (tokens from novo-tokens.css).
 *
 * @package novo
 */

/* ============================================================
   1. QUOTE MODAL OVERLAY
   ============================================================ */

.nvo-quote-overlay {
  position: fixed;
  inset: 0;
  z-index: var(--novo-z-modal, 1200);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  background: rgba(7, 31, 46, 0.72);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);

  /* Hidden by default */
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.22s ease, visibility 0.22s ease;
}

.nvo-quote-overlay--open,
.nvo-quote-overlay[aria-hidden="false"] {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

/* ── Dialog card ─────────────────────────────────────────── */
.nvo-quote-dialog {
  position: relative;
  background: var(--novo-white, #ffffff);
  border-radius: var(--novo-radius-lg, 24px);
  box-shadow: var(--novo-shadow-lg, 0 36px 108px rgba(7,31,46,.26));
  width: 100%;
  max-width: 440px;
  max-height: 88dvh;
  overflow-y: auto;
  padding: 28px 28px 24px;
  animation: nvoModalIn 0.28s cubic-bezier(.22,.68,0,1.2) both;
}

@keyframes nvoModalIn {
  from { opacity: 0; transform: translateY(18px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0)    scale(1); }
}

/* ── Close button ────────────────────────────────────────── */
.nvo-quote-close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 36px;
  height: 36px;
  border: none;
  border-radius: var(--novo-radius-pill, 999px);
  background: var(--novo-grey-bg, #F5F7FA);
  color: var(--novo-grey-tx, #7A90A0);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  transition: background 0.18s ease, color 0.18s ease;
  z-index: 1;
}

.nvo-quote-close:hover,
.nvo-quote-close:focus-visible {
  background: var(--novo-navy, #0B3954);
  color: var(--novo-white, #ffffff);
  outline: none;
}

/* ── Header ──────────────────────────────────────────────── */
.nvo-quote-head {
  margin-bottom: 24px;
}

.nvo-quote-title {
  font-size: var(--novo-fs-h3, clamp(18px, 2.2vw, 24px));
  font-weight: var(--novo-fw-bold, 700);
  color: var(--novo-navy-dark, #071F2E);
  margin: 0 0 6px;
  line-height: var(--novo-lh-tight, 1.08);
}

.nvo-quote-sub {
  font-size: var(--novo-fs-sm, 13.5px);
  color: var(--novo-grey-tx, #7A90A0);
  margin: 0;
}

/* ── Editor / no-CF7 notice ──────────────────────────────── */
.nvo-cf7-notice {
  font-size: var(--novo-fs-sm, 13.5px);
  color: var(--novo-grey-tx, #7A90A0);
  background: var(--novo-grey-bg, #F5F7FA);
  border-radius: var(--novo-radius-sm, 10px);
  padding: 12px 16px;
  margin: 0;
}

/* ============================================================
   2. CF7 FORM OVERRIDES inside .nvo-quote-body
   ============================================================ */

.nvo-quote-body .wpcf7 {
  margin: 0;
}

.nvo-quote-body .wpcf7-form {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* Individual field wrappers */
.nvo-quote-body .wpcf7-form-control-wrap {
  display: block;
  width: 100%;
}

/* All text-like inputs + textarea */
.nvo-quote-body input[type="text"],
.nvo-quote-body input[type="email"],
.nvo-quote-body input[type="tel"],
.nvo-quote-body input[type="url"],
.nvo-quote-body input[type="number"],
.nvo-quote-body select,
.nvo-quote-body textarea {
  width: 100%;
  padding: 11px 14px;
  font-family: var(--novo-font, 'Inter', sans-serif);
  font-size: var(--novo-fs-sm, 13.5px);
  color: var(--novo-navy-dark, #071F2E);
  background: var(--novo-grey-bg, #F5F7FA);
  border: 1.5px solid var(--novo-border, #E8EDF3);
  border-radius: var(--novo-radius-sm, 10px);
  outline: none;
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
  box-sizing: border-box;
}

.nvo-quote-body input[type="text"]:focus,
.nvo-quote-body input[type="email"]:focus,
.nvo-quote-body input[type="tel"]:focus,
.nvo-quote-body input[type="url"]:focus,
.nvo-quote-body input[type="number"]:focus,
.nvo-quote-body select:focus,
.nvo-quote-body textarea:focus {
  border-color: var(--novo-navy-light, #1a5e84);
  box-shadow: 0 0 0 3px rgba(26, 94, 132, 0.12);
  background: var(--novo-white, #ffffff);
}

.nvo-quote-body textarea {
  resize: vertical;
  min-height: 90px;
}

/* Submit button */
.nvo-quote-body input[type="submit"],
.nvo-quote-body .wpcf7-submit {
  width: 100%;
  padding: 13px 24px;
  font-family: var(--novo-font, 'Inter', sans-serif);
  font-size: var(--novo-fs-sm, 13.5px);
  font-weight: var(--novo-fw-semibold, 600);
  color: var(--novo-white, #ffffff);
  background: var(--novo-orange, #F56D0D);
  border: none;
  border-radius: var(--novo-radius-sm, 10px);
  cursor: pointer;
  transition: background 0.2s ease, transform 0.12s ease;
  letter-spacing: 0.01em;
  margin-top: 4px;
}

.nvo-quote-body input[type="submit"]:hover,
.nvo-quote-body .wpcf7-submit:hover {
  background: var(--novo-orange-dark, #d95e00);
}

.nvo-quote-body input[type="submit"]:active,
.nvo-quote-body .wpcf7-submit:active {
  transform: scale(0.98);
}

.nvo-quote-body input[type="submit"]:disabled,
.nvo-quote-body .wpcf7-submit:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

/* Validation error messages */
.nvo-quote-body .wpcf7-not-valid-tip {
  display: block;
  font-size: 11px;
  color: #cc3b3b;
  margin-top: 4px;
}

.nvo-quote-body .wpcf7-not-valid {
  border-color: #cc3b3b !important;
}

/* CF7 response output */
.nvo-quote-body .wpcf7-response-output {
  padding: 10px 14px;
  border-radius: var(--novo-radius-xs, 6px);
  font-size: var(--novo-fs-sm, 13.5px);
  margin-top: 4px;
  border: none;
}

.nvo-quote-body .wpcf7-mail-sent-ok {
  background: rgba(15, 163, 96, 0.1);
  color: #0a6b3e;
}

.nvo-quote-body .wpcf7-mail-sent-ng,
.nvo-quote-body .wpcf7-validation-errors,
.nvo-quote-body .wpcf7-spam-blocked {
  background: rgba(204, 59, 59, 0.1);
  color: #7a1f1f;
}

/* CF7 acceptance (GDPR checkbox) */
.nvo-quote-body .wpcf7-acceptance {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: var(--novo-fs-sm, 13.5px);
  color: var(--novo-grey-tx, #7A90A0);
}

.nvo-quote-body .wpcf7-acceptance input[type="checkbox"] {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  margin-top: 2px;
  accent-color: var(--novo-orange, #F56D0D);
  cursor: pointer;
}

/* ============================================================
   3. RESPONSIVE
   ============================================================ */

@media (max-width: 540px) {
  .nvo-quote-dialog {
    padding: 28px 22px 24px;
    border-radius: var(--novo-radius-md, 14px);
    max-height: 95dvh;
  }

  .nvo-quote-title {
    font-size: 18px;
  }
}


/* ============================================================
   4. MULTI-FORM WRAPPERS
   ============================================================ */

/* Form wrappers are hidden by default; JavaScript reveals the correct one */
.novo-cf7-form-wrap {
  display: block;
}

.novo-cf7-form-wrap[hidden] {
  display: none !important;
}

/* Editor notice shown when CF7 is not configured */
.nvo-cf7-notice {
  padding: 12px 16px;
  background: #fff3cd;
  border: 1px solid #ffc107;
  border-radius: 6px;
  font-size: 13px;
  color: #664d03;
}

/* --------------------------------------------------------------------------
   Source: novo-header-footer.css
   -------------------------------------------------------------------------- */
/* ============================================================
   NOVO Imaging — Header & Footer Styles
   Matches header-preview.html + footer-preview.html exactly
   ============================================================ */

/* ────────────────────────────────────────────────
   TOP BAR
──────────────────────────────────────────────── */
.top-bar {
  height: var(--novo-topbar-h, 36px);
  background: var(--novo-navy-dark);
  border-bottom: 1px solid rgba(255,255,255,.05);
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1001;
  overflow: hidden;
  transition: height .32s ease, opacity .32s ease;
  width: 100%;
}
.top-bar.hidden {
  height: 0;
  opacity: 0;
  pointer-events: none;
}
.top-bar-inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 48px;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.tb-left {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11.5px;
  font-weight: 500;
  color: rgba(255,255,255,.78);
}
.tb-pill {
  background: rgba(245,109,13,.20);
  border: 1px solid rgba(245,109,13,.36);
  color: var(--novo-orange-lite);
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: 2px 9px;
  border-radius: 20px;
  flex-shrink: 0;
}
.tb-sep-dot { color: rgba(255,255,255,.30); }
.tb-text   { color: rgba(255,255,255,.72); }
.tb-right  { display: flex; align-items: center; gap: 16px; flex-shrink: 0; }
.tb-right a {
  font-size: 11.5px;
  font-weight: 500;
  color: rgba(255,255,255,.80);
  transition: color .2s;
  white-space: nowrap;
}
.tb-right a:hover { color: #fff; }
.tb-right-sep {
  width: 1px;
  height: 12px;
  background: rgba(255,255,255,.18);
  flex-shrink: 0;
}

/* ────────────────────────────────────────────────
   MAIN HEADER — FLOATING CARD
──────────────────────────────────────────────── */
.hdr-outer {
  position: fixed;
  top: var(--novo-topbar-h, 36px);
  left: 0;
  right: 0;
  z-index: 1000;
  width: 100%;
  padding: 10px 20px 0;
  pointer-events: none;
  transition: top .3s ease;
}
.hdr-outer.scrolled { top: 0; }

/* ── WP Admin Bar offset (logged-in, screens ≥ 601 px) ──────────────────────
   The admin bar is 32 px tall and position:fixed at top:0 z-index:99999.
   Without these overrides the top-bar hides behind it and the nav card
   starts at the wrong position for logged-in users.                        */
@media screen and (min-width: 601px) {
  .admin-bar .top-bar            { top: 32px; }
  .admin-bar .hdr-outer          { top: calc(32px + var(--novo-topbar-h, 36px)); }
  .admin-bar .hdr-outer.scrolled { top: 32px; }
  .admin-bar .mob-drawer {
    top:        calc(32px + var(--novo-topbar-h, 36px) + var(--novo-hdr-h, 72px));
    max-height: calc(100vh - 32px - var(--novo-topbar-h, 36px) - var(--novo-hdr-h, 72px));
  }
}

.site-header {
  max-width: 1240px;
  margin: 0 auto;
  pointer-events: all;
  height: var(--novo-hdr-h, 72px);
  background: #fff;
  border-radius: 16px;
  border: 1px solid var(--novo-border);
  box-shadow: 0 4px 24px rgba(11,57,84,.09), 0 1px 3px rgba(11,57,84,.05);
  transition: box-shadow .3s ease;
}
.site-header.scrolled {
  box-shadow: 0 8px 48px rgba(11,57,84,.16), 0 2px 8px rgba(11,57,84,.08);
}
.hdr-inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 36px;
  height: 100%;
  display: flex;
  align-items: center;
}
/* nav wrapper must grow to push account+CTA to the right */
.hdr-inner > nav {
  flex: 1;
  display: flex;
  align-items: center;
  min-width: 0;
}

/* ── Logo ── */
.hdr-logo {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
  margin-right: 44px;
  text-decoration: none;
}
/* Logo image — sized by height so the width scales automatically.
   max-height ensures it never overflows the 72 px header card. */
.hdr-logo img {
  display: block;
  height: auto;     /* overridden by the inline style; fallback only */
  width: auto;
  max-height: calc(var(--novo-hdr-h, 72px) - 20px); /* 52 px ceiling */
  object-fit: contain;
  flex-shrink: 0;
}
.logo-mark {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  flex-shrink: 0;
  background: linear-gradient(135deg, var(--novo-orange) 0%, var(--novo-orange-dark) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 17px;
  font-weight: 900;
  color: #fff;
  letter-spacing: -1px;
  box-shadow: 0 4px 14px rgba(245,109,13,.36);
}
.logo-text    { display: flex; flex-direction: column; line-height: 1; }
.logo-name    { font-size: 19px; font-weight: 900; color: var(--novo-navy); letter-spacing: .5px; text-transform: uppercase; }
.logo-sub     { font-size: 8px; font-weight: 700; color: var(--novo-grey-tx); letter-spacing: 3px; text-transform: uppercase; margin-top: 3px; }

/* ── Nav ── */
.hdr-nav {
  display: flex;
  align-items: center;
  gap: 2px;
  flex: 1;
  list-style: none;
  margin: 0;
  padding: 0;
}
.nav-item { position: relative; }
.nav-link {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 8px 13px;
  border-radius: 8px;
  font-size: 13.5px;
  font-weight: 600;
  color: #3a546a;
  cursor: pointer;
  white-space: nowrap;
  position: relative;
  transition: color .2s;
  user-select: none;
  text-decoration: none;
}
/* .hdr-nav prefix gives (0,1,2) vs kit's (0,1,1) — naturally wins without !important */
.hdr-nav button.nav-link {
  border: 0;
  background: transparent;
  color: #3a546a;
  padding: 8px 13px;
  font: inherit;
  box-shadow: none;
  border-radius: 8px;
}
.hdr-nav a.nav-link {
  color: #3a546a;
}
button.nav-link:focus-visible {
  outline: 2px solid rgba(245,109,13,.5);
  outline-offset: 2px;
}
/* CSS-only chevron */
.nav-link .chv {
  display: inline-block;
  width: 0;
  height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 4.5px solid #b8c6d0;
  margin-top: 1px;
  transition: transform .25s ease, border-top-color .2s;
}
.nav-link:hover,
.nav-item:hover > .nav-link { color: var(--novo-orange); }
.nav-item:focus-within > .nav-link { color: var(--novo-orange); }
.nav-item:hover > .nav-link .chv { border-top-color: var(--novo-orange); transform: rotate(180deg); }
.nav-item:focus-within > .nav-link .chv { border-top-color: var(--novo-orange); transform: rotate(180deg); }
.nav-link.active { color: var(--novo-orange); font-weight: 700; }
.nav-link.active::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 13px;
  right: 13px;
  height: 2px;
  border-radius: 2px 2px 0 0;
  background: var(--novo-orange);
}

/* ── Dropdown ── */
@keyframes novo-drop-in {
  from { opacity: 0; transform: translateX(-50%) translateY(-8px); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}
.nav-dd {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%) translateY(-6px);
  background: #fff;
  border: 1px solid var(--novo-border);
  border-radius: 16px;
  box-shadow: 0 12px 48px rgba(11,57,84,.13), 0 2px 8px rgba(11,57,84,.05);
  padding: 6px;
  min-width: 240px;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .2s ease, transform .2s ease, visibility .2s;
  z-index: 900;
}
.nav-dd::before {
  content: '';
  position: absolute;
  top: -10px;
  left: 0;
  right: 0;
  height: 10px;
}
.nav-item:hover > .nav-dd {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
  animation: novo-drop-in .2s ease;
}
.nav-item.is-open > .nav-dd {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
  animation: novo-drop-in .2s ease;
}
.dd-section {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--novo-grey-tx);
  padding: 9px 14px 4px;
}
.dd-section-padded { padding-top: 14px; }
.dd-item {
  display: flex;
  flex-direction: column;
  padding: 9px 14px 9px 28px;
  border-radius: 10px;
  position: relative;
  text-decoration: none;
  color: inherit;
  transition: background .15s;
}
.dd-item::before {
  content: '';
  position: absolute;
  left: 13px;
  top: 50%;
  transform: translateY(-50%);
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--novo-border);
  transition: background .15s, transform .2s;
}
.dd-item:hover { background: var(--novo-grey-bg); }
.dd-item:hover::before { background: var(--novo-orange); transform: translateY(-50%) scale(1.3); }
.dd-label { font-size: 13px; font-weight: 700; color: var(--novo-navy); line-height: 1.3; }
.dd-desc  { font-size: 11px; font-weight: 500; color: var(--novo-grey-tx); margin-top: 1px; line-height: 1.3; }
.dd-hr    { height: 1px; background: var(--novo-border); margin: 4px 10px; }
.dd-view-all {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 14px;
  border-radius: 10px;
  margin-top: 2px;
  font-size: 12px;
  font-weight: 700;
  color: var(--novo-orange);
  transition: background .15s;
  text-decoration: none;
}
.dd-view-all:hover { background: rgba(245,109,13,.06); }
.dd-view-all::after { content: '→'; font-size: 13px; }
.dd-equip,
.dd-parts,
.dd-about { min-width: 260px; }

/* ── Account button ── */
.hdr-account {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--novo-grey-bg);
  border: 1.5px solid var(--novo-border);
  color: var(--novo-navy);
  font-size: 14px;
  cursor: pointer;
  text-decoration: none;
  flex-shrink: 0;
  transition: all .2s;
  margin-left: 10px;
}
.hdr-account:hover { background: var(--novo-navy); border-color: var(--novo-navy); color: #fff; }

/* ── CTA button ── */
.hdr-cta {
  display: inline-flex;
  align-items: center;
  padding: 10px 22px;
  border-radius: 50px;
  background: var(--novo-orange);
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  font-family: var(--novo-font);
  cursor: pointer;
  border: none;
  text-decoration: none;
  box-shadow: 0 4px 18px rgba(245,109,13,.28);
  transition: background .2s, transform .2s, box-shadow .2s;
  margin-left: 8px;
  flex-shrink: 0;
  white-space: nowrap;
}
.hdr-cta:hover {
  background: var(--novo-orange-dark);
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(245,109,13,.44);
}

/* ── Hamburger ── */
.hdr-burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 38px;
  height: 38px;
  border-radius: 9px;
  background: var(--novo-grey-bg);
  border: 1.5px solid var(--novo-border);
  padding: 9px;
  cursor: pointer;
  margin-left: 8px;
  flex-shrink: 0;
  transition: background .2s;
}
.hdr-burger:hover { background: #edf0f5; }
.hdr-burger span {
  display: block;
  height: 2px;
  background: var(--novo-navy);
  border-radius: 2px;
  transition: transform .3s, opacity .3s;
}
.hdr-burger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hdr-burger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.hdr-burger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ────────────────────────────────────────────────
   MOBILE DRAWER
──────────────────────────────────────────────── */
@keyframes novo-drawer-in {
  from { opacity: 0; transform: translateY(-12px); }
  to   { opacity: 1; transform: translateY(0); }
}
.mob-overlay {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 998;
  background: rgba(7,31,46,.65);
  backdrop-filter: blur(4px);
}
.mob-overlay.open { display: block; }
.mob-drawer {
  position: fixed;
  left: 0;
  right: 0;
  top: calc(var(--novo-topbar-h, 36px) + var(--novo-hdr-h, 72px));
  max-height: calc(100vh - var(--novo-topbar-h, 36px) - var(--novo-hdr-h, 72px));
  overflow-y: auto;
  z-index: 999;
  background: #fff;
  border-bottom: 1px solid var(--novo-border);
  box-shadow: 0 24px 64px rgba(11,57,84,.16);
  transform: translateY(-10px);
  opacity: 0;
  pointer-events: none;
  transition: transform .28s ease, opacity .28s ease;
}
.mob-drawer.open {
  transform: translateY(0);
  opacity: 1;
  pointer-events: all;
  animation: novo-drawer-in .28s ease;
}
.mob-inner {
  padding: 16px 28px 36px;
  max-width: 600px;
  margin: 0 auto;
}
.mob-section {
  display: block;
  font-size: 9px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 2.5px;
  color: var(--novo-grey-tx);
  padding: 20px 0 8px;
}
.mob-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 13px 0;
  border-bottom: 1px solid var(--novo-border);
  font-size: 14px;
  font-weight: 600;
  color: var(--novo-navy);
  text-decoration: none;
  transition: color .2s;
}
.mob-link:hover { color: var(--novo-orange); }
.mob-arr-char { font-size: 14px; color: var(--novo-border); transition: color .2s; }
.mob-link:hover .mob-arr-char { color: var(--novo-orange-lite); }
.mob-link--accent { color: var(--novo-orange); font-weight: 700; }
.mob-link--accent .mob-arr-char { color: var(--novo-orange-lite); }
.mob-cta-wrap { padding-top: 24px; display: flex; flex-direction: column; gap: 10px; }
.mob-cta-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 15px;
  border-radius: 14px;
  background: var(--novo-orange);
  color: #fff;
  font-size: 15px;
  font-weight: 700;
  font-family: var(--novo-font);
  text-decoration: none;
  box-shadow: 0 6px 22px rgba(245,109,13,.36);
  transition: background .2s;
}
.mob-cta-btn:hover { background: var(--novo-orange-dark); }
.mob-contact-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.mob-contact-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 12px;
  border-radius: 12px;
  border: 1.5px solid var(--novo-border);
  color: var(--novo-navy);
  font-size: 13px;
  font-weight: 600;
  font-family: var(--novo-font);
  text-decoration: none;
  transition: all .2s;
}
.mob-contact-btn:hover { border-color: var(--novo-orange); color: var(--novo-orange); }

/* ────────────────────────────────────────────────
   MAIN FOOTER
──────────────────────────────────────────────── */
.site-footer { background: var(--novo-navy-dark); }
.ft-wave {
  display: block;
  width: 100%;
  height: 3px;
  background: linear-gradient(90deg, transparent 0%, var(--novo-orange) 25%, var(--novo-orange) 75%, transparent 100%);
}
.ft-main { padding: 72px 0 60px; }
.ft-grid {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 48px;
  display: grid;
  grid-template-columns: 1.8fr 1fr 1fr 1fr;
  gap: 48px;
}

/* Brand column */
.ft-logo {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  margin-bottom: 22px;
}
.ft-logo-mark {
  width: 40px;
  height: 40px;
  border-radius: 11px;
  flex-shrink: 0;
  background: linear-gradient(135deg, var(--novo-orange) 0%, var(--novo-orange-dark) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 900;
  color: #fff;
  letter-spacing: -1px;
  box-shadow: 0 4px 20px rgba(245,109,13,.44);
}
.ft-logo-text { display: flex; flex-direction: column; line-height: 1; }
.ft-logo-name { font-size: 19px; font-weight: 900; color: #fff; letter-spacing: .5px; text-transform: uppercase; }
.ft-logo-sub  { font-size: 8px; font-weight: 700; color: rgba(255,255,255,.35); letter-spacing: 3px; text-transform: uppercase; margin-top: 3px; }
.ft-desc {
  font-size: 13.5px;
  line-height: 1.70;
  color: rgba(255,255,255,.48);
  margin-bottom: 28px;
  max-width: 254px;
}
.ft-stats {
  display: flex;
  align-items: center;
  gap: 0;
  margin-bottom: 30px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 14px;
  overflow: hidden;
}
.ft-stat {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 14px 10px;
  border-right: 1px solid rgba(255,255,255,.07);
}
.ft-stat:last-child { border-right: none; }
.ft-stat-n { font-size: 20px; font-weight: 900; color: #fff; line-height: 1; }
.ft-stat-l { font-size: 9.5px; font-weight: 600; color: rgba(255,255,255,.35); text-transform: uppercase; letter-spacing: 1px; margin-top: 4px; }
.ft-social { display: flex; gap: 9px; }
.ft-social-btn {
  width: 36px;
  height: 36px;
  border-radius: 9px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.10);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  color: rgba(255,255,255,.50);
  transition: all .2s;
}
.ft-social-btn:hover {
  background: var(--novo-orange);
  border-color: var(--novo-orange);
  color: #fff;
  transform: translateY(-2px);
}
.ft-social-abbr {
  font-size: 10px;
  font-weight: 900;
  font-family: 'Inter', sans-serif;
  letter-spacing: -0.5px;
  line-height: 1;
}
.ft-social-logo {
  display: block;
  width: 30px;
  height: 30px;
  object-fit: contain;
  filter: brightness(0) invert(0.5);
  transition: filter .2s;
}
.ft-social-btn:hover .ft-social-logo {
  filter: brightness(0) invert(1);
}

/* Nav columns */
.ft-col-head {
  font-size: 9.5px;
  font-weight: 800;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: rgba(255,255,255,.30);
  margin-bottom: 20px;
}
.ft-brand-col > .ft-col-head { margin-top: 28px; }
.ft-links { list-style: none; display: flex; flex-direction: column; gap: 1px; padding: 0; margin: 0; }
.ft-links a {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13.5px;
  font-weight: 500;
  color: rgba(255,255,255,.55);
  padding: 6px 0;
  transition: color .18s;
  position: relative;
}
.ft-links a::before {
  content: '';
  width: 4px;
  height: 4px;
  border-radius: 50%;
  flex-shrink: 0;
  background: rgba(255,255,255,.15);
  transition: background .18s, transform .18s;
}
.ft-links a:hover { color: #fff; }
.ft-links a:hover::before { background: var(--novo-orange); transform: scale(1.5); }
.ft-col-view-all {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 16px;
  font-size: 12px;
  font-weight: 700;
  color: var(--novo-orange);
  transition: color .2s, gap .2s;
  text-decoration: none;
}
.ft-col-view-all:hover { color: var(--novo-orange-lite); gap: 10px; }
.ft-col-divider { height: 1px; background: rgba(255,255,255,.07); margin: 24px 0; }

/* Contact card */
.ft-contact-card {
  background: rgba(255,255,255,.045);
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 14px;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.ft-contact-row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 9px 0;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.ft-contact-row:last-of-type { border-bottom: none; padding-bottom: 2px; }
.ft-contact-icon {
  width: 26px;
  height: 26px;
  border-radius: 6px;
  flex-shrink: 0;
  background: rgba(245,109,13,.12);
  border: 1px solid rgba(245,109,13,.18);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  color: var(--novo-orange);
}
.ft-contact-label {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: rgba(255,255,255,.28);
  margin-bottom: 2px;
}
.ft-contact-val { font-size: 12px; font-weight: 600; color: rgba(255,255,255,.72); }
.ft-contact-link { transition: color .18s; }
.ft-contact-link:hover { color: var(--novo-orange); }
.ft-cta-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 18px;
  padding: 14px;
  border-radius: 12px;
  background: var(--novo-orange);
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  font-family: 'Inter', sans-serif;
  box-shadow: 0 6px 24px rgba(245,109,13,.40);
  transition: background .2s, transform .2s, box-shadow .2s;
  text-decoration: none;
}
.ft-cta-btn:hover {
  background: var(--novo-orange-dark);
  transform: translateY(-2px);
  box-shadow: 0 10px 36px rgba(245,109,13,.55);
}

/* Divider */
.ft-hr-wrap { max-width: 1240px; margin: 0 auto; padding: 0 48px; }
.ft-hr { border: none; border-top: 1px solid rgba(255,255,255,.07); }

/* Bottom bar */
.ft-bottom { background: rgba(0,0,0,.28); padding: 22px 0; }
.ft-bottom-inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.ft-copy { font-size: 12px; font-weight: 500; color: rgba(255,255,255,.28); }
.ft-legal { display: flex; align-items: center; gap: 12px; }
.ft-legal a { font-size: 12px; font-weight: 500; color: rgba(255,255,255,.35); transition: color .18s; }
.ft-legal a:hover { color: rgba(255,255,255,.72); }
.ft-legal-sep { color: rgba(255,255,255,.14); font-size: 13px; }
.ft-cert {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 11px;
  font-weight: 600;
  color: rgba(255,255,255,.22);
  padding: 5px 14px;
  border-radius: 20px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.07);
}
.ft-cert i { font-size: 9px; color: rgba(245,109,13,.60); }

/* ── Higher-specificity overrides — beat Elementor's injected global a{color} ── */
.site-footer .ft-links a { color: rgba(255,255,255,.55); }
.site-footer .ft-links a:hover { color: #fff; }
.site-footer .ft-social-btn { color: rgba(255,255,255,.50); }
.site-footer a.ft-contact-link { color: rgba(255,255,255,.72); }
.site-footer .ft-legal a { color: rgba(255,255,255,.35); }
.site-footer .ft-legal a:hover { color: rgba(255,255,255,.72); }
.site-footer .ft-col-view-all { color: var(--novo-orange); }
.site-footer .ft-col-view-all:hover { color: var(--novo-orange-lite); }

/* ────────────────────────────────────────────────
   RESPONSIVE
──────────────────────────────────────────────── */
@media (max-width: 980px) {
  .hdr-nav,
  .hdr-cta,
  .hdr-account { display: none; }
  .hdr-burger { display: flex; }
}
@media (max-width: 1100px) {
  .ft-grid { grid-template-columns: 1fr 1fr; gap: 40px; }
  .ft-brand-col { grid-column: 1 / -1; }
}
@media (max-width: 700px) {
  .ft-grid { grid-template-columns: 1fr 1fr; padding: 0 24px; gap: 32px; }
  .ft-brand-col { grid-column: 1 / -1; }
  .ft-hr-wrap,
  .ft-bottom-inner { padding: 0 24px; }
  .ft-main { padding: 52px 0 44px; }
  .ft-bottom-inner { flex-direction: column; text-align: center; gap: 14px; }
}
@media (max-width: 600px) {
  .hdr-inner { padding: 0 20px; }
  .top-bar-inner { padding: 0 20px; }
  .tb-left .tb-text { display: none; }
}
@media (max-width: 480px) {
  .ft-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   ELEMENTOR THEME BUILDER — SECTION OVERRIDES
   Styles Elementor sections by the css_classes set in the
   JSON import templates (novo-topbar, novo-floating-header,
   novo-footer-prefooter, novo-footer-main, novo-footer-legal)
   ============================================================ */

/* Sticky wrapper for the whole header location */
.elementor-location-header {
  /* height:0 + overflow:visible = takes no space in page flow.
     The header elements inside use position:fixed so they are
     completely immune to any Elementor container padding/margin. */
  height: 0 !important;
  overflow: visible !important;
  position: static !important;
  z-index: auto !important;
  width: 100% !important;
}

/* ── Zero ALL Elementor-injected padding/margin inside the header location ──
   Uses longhand properties so they override both shorthand and longhand
   inline styles (e.g. style="padding-top:20px") that Elementor re-applies
   every time a widget control changes in the editor.
   Covers both Flexbox Container (.e-con) and legacy Section (.elementor-section)
   layouts, plus the root .elementor wrapper Elementor injects inside the location. */
.elementor-location-header > .elementor,
.elementor-location-header .e-con,
.elementor-location-header .e-con-inner,
.elementor-location-header .elementor-section,
.elementor-location-header .elementor-container,
.elementor-location-header .elementor-row,
.elementor-location-header .elementor-column,
.elementor-location-header .elementor-column-gap-default,
.elementor-location-header .elementor-column-wrap,
.elementor-location-header .elementor-widget-wrap,
.elementor-location-header .elementor-widget,
.elementor-location-header .elementor-widget-container {
  padding-top:    0 !important;
  padding-right:  0 !important;
  padding-bottom: 0 !important;
  padding-left:   0 !important;
  margin-top:     0 !important;
  margin-right:   0 !important;
  margin-bottom:  0 !important;
  margin-left:    0 !important;
  gap:            0 !important;
  row-gap:        0 !important;
  column-gap:     0 !important;
  min-height:     0 !important;
}

/* Elementor Pro sticky shadow — class is added to the container on scroll, no section prefix needed */
.elementor-sticky--active.novo-floating-header {
  box-shadow: 0 8px 48px rgba(11,57,84,.16), 0 2px 8px rgba(11,57,84,.08);
}

/* ── Elementor button widget — btn-primary / btn-outline variants ───── */
/* css_classes is placed on .elementor-widget-button, not on the <a> */
.elementor-widget-button.btn-primary .elementor-button {
  background: var(--novo-orange) !important;
  color: #fff !important;
  box-shadow: 0 4px 18px rgba(245,109,13,.32) !important;
  border-radius: 50px !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  padding: 10px 22px !important;
  border: none !important;
  text-decoration: none !important;
  transition: background .2s, transform .2s, box-shadow .2s !important;
}
.elementor-widget-button.btn-primary .elementor-button:hover {
  background: var(--novo-orange-dark) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 28px rgba(245,109,13,.44) !important;
}
.elementor-widget-button.btn-outline .elementor-button {
  background: transparent !important;
  color: var(--novo-navy) !important;
  border: 2px solid var(--novo-border) !important;
  border-radius: 50px !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  padding: 10px 22px !important;
  transition: all .2s !important;
}
.elementor-widget-button.btn-outline .elementor-button:hover {
  border-color: var(--novo-orange) !important;
  color: var(--novo-orange) !important;
}

/* ── Account icon inside floating header (HTML widget) ────────── */
.elementor-location-header .hdr-account {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--novo-grey-bg, #F5F7FA);
  border: 1.5px solid var(--novo-border, #E8EDF3);
  color: var(--novo-navy, #0B3954);
  font-size: 14px;
  text-decoration: none;
  flex-shrink: 0;
  transition: background .2s, border-color .2s, color .2s;
  cursor: pointer;
}
.elementor-location-header .hdr-account:hover {
  background: var(--novo-navy, #0B3954);
  border-color: var(--novo-navy, #0B3954);
  color: #fff;
}
/* ── Dropdown item orange dot (::before on <li>) ──────────────── */
.elementor-location-header .elementor-nav-menu--dropdown li.menu-item {
  position: relative;
}
.elementor-location-header .elementor-nav-menu--dropdown li.menu-item > a.elementor-sub-item {
  padding-left: 28px !important;
}
.elementor-location-header .elementor-nav-menu--dropdown li.menu-item::before {
  content: '';
  position: absolute;
  left: 13px;
  top: 50%;
  transform: translateY(-50%);
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--novo-border, #E8EDF3);
  transition: background .15s, transform .2s;
  pointer-events: none;
  z-index: 1;
}
.elementor-location-header .elementor-nav-menu--dropdown li.menu-item:hover::before {
  background: var(--novo-orange, #F56D0D) !important;
  transform: translateY(-50%) scale(1.3);
}

/* ── Section-label items (add CSS class "menu-section-label" in WP Admin → Menus) */
.elementor-location-header .elementor-nav-menu--dropdown li.menu-section-label > a.elementor-sub-item {
  font-size: 9px !important;
  font-weight: 800 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: var(--novo-grey-tx, #7A90A0) !important;
  cursor: default !important;
  pointer-events: none !important;
  padding: 9px 14px 4px 14px !important;
  background: none !important;
}
.elementor-location-header .elementor-nav-menu--dropdown li.menu-section-label::before {
  display: none !important;
}

/* ── HR divider items (add CSS class "dd-hr" in WP Admin → Menus) ── */
.elementor-location-header .elementor-nav-menu--dropdown li.dd-hr {
  height: 1px !important;
  background: var(--novo-border, #E8EDF3) !important;
  margin: 4px 10px !important;
  padding: 0 !important;
  pointer-events: none;
}
.elementor-location-header .elementor-nav-menu--dropdown li.dd-hr > a {
  display: none !important;
}
.elementor-location-header .elementor-nav-menu--dropdown li.dd-hr::before {
  display: none !important;
}

/* ── "View All" link items (add CSS class "dd-view-all" in WP Admin → Menus) */
.elementor-location-header .elementor-nav-menu--dropdown li.dd-view-all > a.elementor-sub-item {
  color: var(--novo-orange, #F56D0D) !important;
  font-weight: 700 !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  padding-left: 14px !important;
  margin-top: 2px;
}
.elementor-location-header .elementor-nav-menu--dropdown li.dd-view-all > a.elementor-sub-item::after {
  content: '→';
  font-size: 13px;
  flex-shrink: 0;
}
.elementor-location-header .elementor-nav-menu--dropdown li.dd-view-all > a.elementor-sub-item:hover {
  background: rgba(245,109,13,.06) !important;
}
.elementor-location-header .elementor-nav-menu--dropdown li.dd-view-all::before {
  display: none !important;
}

/* ── Description text appended by PHP nav_menu_item_title filter ── */
.elementor-location-header .nav-item-desc {
  display: block;
  font-size: 11px;
  font-weight: 500;
  color: var(--novo-grey-tx, #7A90A0);
  margin-top: 1px;
  line-height: 1.3;
  white-space: normal;
}

/* ── Footer sections ─────────────────────────────────────────── */
/* novo-prefooter: outer container wrapping the CTA banner widget.
   The widget itself renders .pre-footer background; we just strip inherited padding. */
.e-con.novo-prefooter,
.e-con.novo-prefooter > .e-con-inner {
  padding: 0 !important;
}
.e-con.novo-prefooter .elementor-widget-container {
  padding: 0 !important;
}
/* novo-footer-grid: 4-column main footer area */
.e-con.novo-footer-grid {
  background: var(--novo-navy-dark, #071F2E) !important;
  padding: 64px 0 48px !important;
}
.e-con.novo-footer-grid .elementor-widget-text-editor p {
  font-size: 13.5px;
  color: rgba(255,255,255,.55);
  line-height: 1.8;
}
.e-con.novo-footer-grid h3,
.e-con.novo-footer-grid h4 {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: rgba(255,255,255,.35);
  margin-bottom: 16px;
}
.e-con.novo-footer-grid a {
  color: rgba(255,255,255,.60);
  text-decoration: none;
  font-size: 13.5px;
  transition: color .2s;
}
.e-con.novo-footer-grid a:hover { color: #fff; }
/* novo-footer-legal: bottom legal bar */
.e-con.novo-footer-legal {
  background: var(--novo-navy-dark, #071F2E) !important;
  border-top: 1px solid rgba(255,255,255,.08);
  padding: 16px 0 !important;
}
.e-con.novo-footer-legal .elementor-widget-text-editor p {
  font-size: 12px;
  color: rgba(255,255,255,.35);
  margin: 0;
}
.e-con.novo-footer-legal a {
  color: rgba(255,255,255,.50);
  text-decoration: none;
  transition: color .2s;
}
.e-con.novo-footer-legal a:hover { color: #fff; }

/* ── Single Product sections ──────────────────────────────────── */
.e-con.novo-product-hero {
  background: var(--novo-grey-bg, #F5F7FA) !important;
  padding-top: 40px !important;
}
.e-con.novo-product-tabs {
  padding-top: 0 !important;
}

/* ── Single Post sections ─────────────────────────────────────── */
.e-con.novo-reading-bar-section {
  padding: 0 !important;
  margin: 0 !important;
}
.e-con.novo-article-header {
  background: var(--novo-grey-bg, #F5F7FA) !important;
  padding: 60px 0 40px !important;
}
.e-con.novo-article-body {
  padding: 48px 0 !important;
}

/* ── Responsive ──────────────────────────────────────── */
@media (max-width: 768px) {
  .hdr-outer { padding: 6px 12px 4px; }
  .site-header { border-radius: 12px; }
}

/* ── Mobile: decorative rings and orbs ───────────────────────────────────
   Rings are 700–1080px circles — purely cosmetic. Hide them on phones to
   eliminate potential overflow and reduce paint area.
   Orbs are blurred gradients — shrink rather than hide so the warm glow
   colour effect is preserved without overflowing the viewport.             */
@media (max-width: 600px) {
  .hero-ring,
  .hero-ring2,
  .novo-hero--centered .hero-ring,
  .novo-hero--centered .hero-ring2,
  .novo-article-hero .hero-ring,
  .novo-product-hero::before,
  .novo-product-hero::after {
    display: none;
  }

  .novo-hero .hero-orb-1              { width: 200px; height: 200px; }
  .novo-hero .hero-orb-2              { width: 140px; height: 140px; }
  .novo-hero--centered .hero-orb-1    { width: 160px; height: 160px; }
  .novo-hero--centered .hero-orb-2    { width: 120px; height: 120px; }
  .hero-orb-1                         { width: 180px; height: 180px; }
  .hero-orb-2                         { width: 140px; height: 140px; }
  .novo-news-hero .hero-orb-1         { width: 160px; height: 160px; }
  .novo-news-hero .hero-orb-2         { width: 110px; height: 110px; }

  .nl-section::before,
  .nl-section::after                  { display: none; }
}

