/**
 * AORO Solar — Core Overrides
 * Handles global layout fixes, sticky navigation, and UI refinements.
 *
 * @package  SolakChild
 * @author   AORO Solar
 * @version  1.3.2
 */


/* ── Global: prevent horizontal scroll without breaking sticky contexts ── */
/* Robust Scroll Lock when mobile menu is active */
html.ekit-nav-menu-active,
body.ekit-nav-menu-active {
  overflow: hidden !important;
  /* Remove height/position as they can sometimes squash the viewport on mobile browsers */
  touch-action: none;
}


/**
 * ── Sticky Navigation ──
 * The <header> element is made sticky with a negative top offset equal
 * to the top-bar height (set via JS as --topbar-h). This causes the
 * informational top-bar to scroll out of view while the primary
 * navigation remains pinned at the viewport edge.
 */
header {
  position: -webkit-sticky !important;
  position: sticky !important;
  top: calc(var(--topbar-h, 0px) * -1) !important;
  z-index: 9999 !important;

}

/* Ensure nav container maintains stacking priority */
.aoro-sticky-header {
  z-index: 9999;
}


/**
 * ── Header Glassmorphism (Safe Implementation) ──
 * Applies the frosted-glass backdrop to a ::before pseudo-element.
 * Because the ::before element has no children, its backdrop-filter
 * CANNOT trap the mobile menu's fixed positioning!
 */
.elementor-element-44441fc5, .elementor-element.elementor-element-44441fc5.e-con-full.e-flex.e-con.e-child {
    border: 0;
    background: linear-gradient(256deg, rgb(7 20 38 / 54%) 0%, rgb(11 31 59 / 76%) 30%, rgb(18 60 74 / 93%) 65%, rgb(31 111 92 / 55%) 100%) !important;
    position: relative;
    border-radius: 20px !important;
    box-shadow: none;
    overflow: visible !important;
    margin-top: 30px !important;
}

/* The actual glassmorphism layer */
.elementor-element-44441fc5::before {
  content: "";
  position: absolute !important;
  inset: 0 !important;
  background: rgba(255, 255, 255, 0.02) !important;
  -webkit-backdrop-filter: blur(40px) saturate(2) !important;
  backdrop-filter: blur(40px) saturate(2) !important;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.45), inset 0 0 0 1px rgba(255, 255, 255, 0.1) !important;
  z-index: 0 !important;
  pointer-events: none !important;
  border-radius: 20px !important;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Ensure all actual header content sits above the glass background */
.elementor-element-44441fc5 > * {
  position: relative;
  z-index: 1;
}
 
.elementor-417 .elementor-element.elementor-element-81e2863 .elementor-button {
    padding: 10px !important;
}

/* ── Menu & Components Transition ── */
.elementor-element-1fc64985 .elementskit-menu-container {
  transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

/* 
 * ── Mobile Menu Viewport Escape ──
 * When the menu is active, we force the container to ignore ALL parent constraints
 * and occupy the full viewport. We also neutralize any parent containing blocks.
 */
body.ekit-nav-menu-active .elementskit-menu-container.elementskit-menu-offcanvas-elements {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  width: 100vw !important;
  height: 100dvh !important;
  margin: 0 !important;
  transform: none !important;
  z-index: 1000000 !important;
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* Neutralize common containing block traps on ancestors when menu is open */
body.ekit-nav-menu-active header,
body.ekit-nav-menu-active .elementor-element-44441fc5,
body.ekit-nav-menu-active .elementor-element-44441fc5 *,
body.ekit-nav-menu-active div.e-con,
body.ekit-nav-menu-active div.e-con-inner {
  transform: none !important;
  filter: none !important;
  perspective: none !important;
  contain: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  overflow: visible !important;
}

/* 
 * Ensure the glassmorphism ::before from our safe implementation 
 * doesn't interfere with the stacking context when menu is open.
 */
body.ekit-nav-menu-active .elementor-element-44441fc5::before {
  display: none !important;
}

 * ── Ultra-Premium Mobile Menu Styling ──
 * AORO Signature Green Gradient + Glassmorphism + Crisp White Typography
 */
@media (max-width: 1024px) {
  /* The Main Offcanvas Container */
  .elementskit-menu-container.elementskit-menu-offcanvas-elements {
    background-color: transparent !important;
    background-image: linear-gradient(
      135deg,
      #071426 0%,
      #0B1F3B 30%,
      #123C4A 65%,
      #1F6F5C 100%
    ) !important;
    -webkit-backdrop-filter: blur(20px) saturate(1.5) !important;
    backdrop-filter: blur(20px) saturate(1.5) !important;
    box-shadow: -10px 0 40px rgba(0, 0, 0, 0.5), inset 1px 0 0 rgba(255, 255, 255, 0.1) !important;
    border-left: 1px solid rgba(255, 255, 255, 0.08) !important;
    padding-top: 20px !important;
  }

  /* Safe Energy Animation Overlay (Strengthened) */
  .elementskit-menu-container.elementskit-menu-offcanvas-elements::after {
    content: "";
    position: absolute;
    inset: 0;
    /* Much stronger energy effect with higher opacity and larger spread */
    background: radial-gradient(
      circle at center,
      rgba(160, 255, 212, 0.4) 0%,
      rgba(31, 111, 92, 0) 75%
    );
    background-size: 300% 300%;
    background-position: center;
    pointer-events: none;
    z-index: 0;
    animation: aoroEnergyPulse 8s infinite alternate ease-in-out;
  }

  /* Ensure text and links sit above the animation */
  .elementskit-menu-container.elementskit-menu-offcanvas-elements > * {
    position: relative;
    z-index: 1;
  }

  @keyframes aoroEnergyPulse {
    0% { background-position: 0% 0%; opacity: 0.4; transform: scale(1); }
    50% { background-position: 100% 100%; opacity: 0.9; transform: scale(1.1); }
    100% { background-position: 0% 100%; opacity: 0.4; transform: scale(1); }
  }

  /* Typography & Links - Force White everywhere */
  .elementor-417 .elementor-element.elementor-element-1fc64985 .elementskit-navbar-nav > li > a,
  .elementskit-navbar-nav > li > a,
  .elementskit-navbar-nav .elementskit-submenu-panel > li > a {
    color: #FFFFFF !important;
    font-weight: 500 !important;
    letter-spacing: 0.5px !important;
    padding: 18px 25px !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06) !important;
    transition: all 0.3s ease !important;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
  }

  /* Remove default border on the last item to keep it clean */
  .elementskit-navbar-nav > li:last-child > a {
    border-bottom: none !important;
  }

  /* Hover & Active States */
  .elementskit-navbar-nav > li > a:hover,
  .elementskit-navbar-nav .elementskit-submenu-panel > li > a:hover,
  .elementskit-navbar-nav > li > a.active {
    background: rgba(255, 255, 255, 0.05) !important;
    color: #A0FFD4 !important; /* A soft, premium electric green accent */
    padding-left: 32px !important; /* Sleek indent on hover */
  }

  /* Submenu Indicators (Arrows) */
  .ekit_menu_responsive_tablet .elementskit-navbar-nav-default .elementskit-dropdown-has>a .elementskit-submenu-indicator {
    margin-left: auto;
    border: none !important;
  }

  .elementor-417 .elementor-element.elementor-element-1fc64985 .elementskit-navbar-nav > li > a .elementskit-submenu-indicator {
    color: #FFFFFF;
    fill: #FFFFFF;
    border: none !important;
  }

  .elementskit-menu-container .elementskit-submenu-indicator {
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1), color 0.3s ease !important;
  }

  /* Hover state for arrows */
  .elementskit-navbar-nav > li > a:hover .elementskit-submenu-indicator {
    color: #FFFFFF !important;
  }

  /* Specific Active state fix for Elementor Submenu Indicator */
  .elementor-417 .elementor-element.elementor-element-1fc64985 .elementskit-navbar-nav > li > a:active .elementskit-submenu-indicator {
    color: #FFFFFF;
    border-radius: 0 !important;
    border: none !important;
  }

  /* Arrow rotation when active/open */
  .elementskit-navbar-nav > li.elementskit-dropdown-isOpen > a .elementskit-submenu-indicator,
  .elementskit-navbar-nav > li.elementskit-dropdown-has.active > a .elementskit-submenu-indicator,
  .elementskit-navbar-nav > li > a[aria-expanded="true"] .elementskit-submenu-indicator,
  .elementskit-navbar-nav > li:hover > a .elementskit-submenu-indicator {
    transform: rotate(180deg) !important;
  }

  /* Submenus Backgrounds (Slightly darker indent) */
  .elementskit-navbar-nav .elementskit-submenu-panel {
    background: rgba(0, 0, 0, 0.15) !important;
    border-left: 2px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 0 !important; /* as requested */
  }

  /* Close Button Customization */
  .elementor-417 .elementor-element.elementor-element-1fc64985 .elementskit-menu-close {
    background: rgba(255, 255, 255, 0.1) !important;
    color: #FFFFFF !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    padding: 11px 11px 11px 11px;
    margin: 12px 12px 22px 12px !important;
    border-radius: 30px !important;
    width: 45px !important;
    height: 45px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    top: 10px !important;
    right: 10px !important;
    transition: all 0.3s ease !important;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2) !important;
  }

  .elementor-417 .elementor-element.elementor-element-1fc64985 .elementskit-menu-close:hover {
    background: #FFFFFF !important;
    color: #1F6F5C !important;
    transform: rotate(90deg) scale(1.1) !important;
  }
}


/**
 * ── Scroll Top Button ──
 * Custom positioning and branding for the back-to-top button.
 * Overrides theme defaults to match AORO green aesthetics.
 */
.scroll-top {
  position: fixed !important;
  right: 32px !important;
  bottom: 120px !important;
  height: 50px !important;
  width: 50px !important;
  cursor: pointer !important;
  display: block !important;
  border-radius: 50px !important;
  z-index: 10000 !important;
  -webkit-transition: all 300ms linear !important;
  transition: all 300ms linear !important;
}

.scroll-top svg,
.scroll-top svg circle,
.scroll-top svg path {
  color: #1F6F5C !important;
  fill: none !important;
  /* Only lines should be blue, no solid fill */
  stroke: #1F6F5C !important;
}

.scroll-top svg {
  border-radius: 50% !important;
  background: #ffffff !important;
}

/* Ensure the progress circle and icon match the blue brand color */
.scroll-top:after {
  color: #1F6F5C !important;
  border-color: #1F6F5C !important;
}

.scroll-top .progress-circle path {
  stroke: #1F6F5C !important;
}

/* Targeting the specific SVG circle provided by user */
svg circle[fill="#4F6ACA"],
svg g circle[fill="#4F6ACA"] {
  fill: #1F6F5C !important;
}

/* Chat widget border removal and clean look */
.joinchat__button,
.tawk-button,
.elementor-widget-whatsapp .elementor-button,
#chat-widget-container,
.wa-button,
.wa-chat-button,
.ht-ctc-chat,
#tidio-chat-iframe,
.chat-button {
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
}


/* ── "Superb" UI Global Transitions ── */
header .elementor-button,
.elementor-element-1acb398e .elementor-button,
.elementor-element-81e2863 .elementor-button,
.elementor-element-18482792 .elementor-button,
.elementskit-navbar-nav>li>a,
.elementor-icon-list-item>a,
.elementor-icon-list-item>.elementor-icon-list-text {
  transition: all 0.6s cubic-bezier(0.4, 0, 0.2, 1) !important;
}


/* Top Bar Icon Lists: Left (Contact) & Right (Client/Support) */
.elementor-417 .elementor-element.elementor-element-41a934b .elementor-icon-list-item>.elementor-icon-list-text,
.elementor-417 .elementor-element.elementor-element-41a934b .elementor-icon-list-item>a,
.elementor-417 .elementor-element.elementor-element-aa39577 .elementor-icon-list-item>.elementor-icon-list-text,
.elementor-417 .elementor-element.elementor-element-aa39577 .elementor-icon-list-item>a {
  font-size: 14px !important;
  padding-bottom: 2px !important;
  border-bottom: 2px solid transparent !important;
  /* Transparent base to prevent jump */
}

/* Main Navigation Menu Hover: 2px White Border Bottom */
.elementskit-navbar-nav>li>a {
  border-bottom: 2px solid transparent !important;
}

.elementskit-navbar-nav>li>a:hover {
  border-bottom-color: #FFFFFF !important;
  color: #FFFFFF !important;
}

/* Hover effect: Solid white bottom border */
.elementor-417 .elementor-element.elementor-element-41a934b .elementor-icon-list-item:hover>.elementor-icon-list-text,
.elementor-417 .elementor-element.elementor-element-41a934b .elementor-icon-list-item:hover>a,
.elementor-417 .elementor-element.elementor-element-aa39577 .elementor-icon-list-item:hover>.elementor-icon-list-text,
.elementor-417 .elementor-element.elementor-element-aa39577 .elementor-icon-list-item:hover>a {
  border-color: #FFFFFF !important;
  color: #FFFFFF !important;
}

/* ── Header Button Refinement ── */
/* Remove float animation */
.elementor-animation-float:hover,
.elementor-animation-float:focus,
.elementor-animation-float:active {
  transform: none !important;
}


/* ── Button Group Refinement: Survey, Services & Quote ── */

/* Spacing between buttons */
.elementor-element-1acb398e,
.elementor-element-81e2863 {
  margin-right: 5px !important;
}

/* Base styles to prevent distortion (layout shift) on hover */
.elementor-element-1acb398e .elementor-button,
.elementor-element-81e2863 .elementor-button,
.elementor-element-18482792 .elementor-button {
  border: 2px solid transparent !important;
}

/* Solar Survey (1acb398e) & Solar Quote (81e2863) */
.elementor-element-1acb398e .elementor-button:hover,
.elementor-element-81e2863 .elementor-button:hover {
  background-color: transparent !important;
  border-color: #FFFFFF !important;
  color: #FFFFFF !important;
}

.elementor-element-1acb398e .elementor-button:hover .elementor-button-text,
.elementor-element-81e2863 .elementor-button:hover .elementor-button-text {
  color: #FFFFFF !important;
}

/* View our services (18482792) */
.elementor-element-18482792 .elementor-button {
  border-radius: 0 !important;
}

.elementor-element-18482792 .elementor-button:hover {
  background-color: transparent !important;
  border-bottom-color: #FFFFFF !important;
  color: #FFFFFF !important;
}

.elementor-element-18482792 .elementor-button:hover .elementor-button-text {
  color: #FFFFFF !important;
}


/* Global sticky state hover fallback */
header.aoro-scrolled .elementor-button:hover {
  background-color: transparent !important;
  border-color: #FFF !important;
  color: #FFF !important;
}

/* ── Section Title Font Size (Desktop Only) ── */
@media (min-width: 1025px) {

  .elementor-23 .elementor-element.elementor-element-7eca56c2 .elementskit-section-title-wraper .elementskit-section-title span:last-child,
  .elementor-23 .elementor-element.elementor-element-7eca56c2 .elementskit-section-title-wraper .elementskit-section-title>span {
    font-size: 55px !important;
  }
}


/* ── Social Icons Hover (Modern Incline) ── */
.elementor-social-icon i,
.elementor-social-icon svg {
  transition: all 0.3s ease !important;
}

.elementor-social-icon:hover i,
.elementor-social-icon:hover svg {
  transform: rotate(12deg) scale(1.1) !important;
  color: #FFFFFF !important;
  /* Keep white/visible, avoid turning blue */
  fill: #FFFFFF !important;
}

/* ── Specific Text Editor Widget Styling ── */
.elementor-element.elementor-element-430328f8.animated-slow.elementor-widget.elementor-widget-text-editor.animated.slideInLeft p {
  color: #FFFFFF !important;
}


/**
 * ── Energy Reveal Effect ──
 */
.aoro-reveal-energy {
  opacity: 0 !important;
  filter: blur(15px) brightness(1.2);
  transform: translateY(20px) scale(0.98);
  transition: all 1.2s cubic-bezier(0.2, 0.8, 0.2, 1);
  will-change: opacity, filter, transform;
}

.aoro-reveal-energy.active {
  opacity: 1 !important;
  filter: blur(0) brightness(1);
  transform: translateY(0) scale(1);
  animation: energy-flash 1.5s cubic-bezier(0.2, 0.8, 0.2, 1) forwards;
}

@keyframes energy-flash {
  0% {
    filter: blur(15px) brightness(2);
  }

  20% {
    filter: blur(5px) brightness(1.5);
  }

  100% {
    filter: blur(0) brightness(1);
  }
}

.aoro-reveal-energy.delay-1 {
  transition-delay: 0.1s;
}

.aoro-reveal-energy.delay-2 {
  transition-delay: 0.2s;
}

.aoro-reveal-energy.delay-3 {
  transition-delay: 0.3s;
}


/* ── Admin Bar: ascuns pentru vizitatori nelogați (CSS safety net) ── */
body:not(.logged-in) #wpadminbar {
  display: none !important;
}

body:not(.logged-in) #wpadminbar ~ * {
  margin-top: 0 !important;
}

/* 
 * ── FORCE WHITE OVERRIDE ──
 * This targeting is ultra-specific to overwrite any inline or generated CSS
 * that is forcing the mobile menu links to black (#000000).
 */
@media (max-width: 1024px) {
  body .elementor-417 .elementor-element.elementor-element-1fc64985 .elementskit-navbar-nav > li > a,
  body .elementor-417 .elementor-element.elementor-element-1fc64985 .elementskit-navbar-nav > li > a:visited,
  body .elementor-417 .elementor-element.elementor-element-1fc64985 .elementskit-navbar-nav > li > a:focus,
  body .elementor-417 .elementor-element.elementor-element-1fc64985 .elementskit-navbar-nav .elementskit-submenu-panel > li > a,
  body .elementskit-menu-container .elementskit-navbar-nav > li > a {
    color: #FFFFFF !important;
  }
}

.elementor-element.elementor-element-2cf14de.e-con-full.e-flex.e-con.e-child {
    display: flex;
    justify-content: space-evenly;
}

/* ── Solar Assessment: Hide Header & Footer for Landing Page (Post 20136) ── */
.page-id-20136 header,
.page-id-20136 footer,
.page-id-20136 #masthead,
.page-id-20136 .site-footer,
.page-id-20136 .elementor-location-header,
.page-id-20136 .elementor-location-footer,
.page-id-20136 .si-footer,
.page-id-20136 .breadcumb-banner,
.page-id-20136 .elementor-95 {
  display: none !important;
}


.elementor-417 .elementor-element.elementor-element-7e93f8d7 {
    position: relative;
    overflow: visible;
}

.elementor-417 .elementor-element.elementor-element-7e93f8d7::after {
    content: "";
    position: absolute;
    bottom: -6px;
    left: 50%;
    transform: translateX(-50%);
    
    width: 80%;
    height: 5px;
    
    background: linear-gradient(90deg, #1F6F5C, #56ad56, #1F6F5C);
    border-radius: 10px;
    
    filter: blur(6px);
    opacity: 0.8;
}


/* ================================================================
   AORO EXPERT BLOG — FULL DESIGN SYSTEM
   All reusable article components for long-form SEO articles.
   Prefix: .aoro-blog-*  |  Brand tokens from :root in style.css
   ================================================================ */

/* ── WRAP: outer article container ── */
.aoro-wrap {
    font-family: 'Epilogue', sans-serif;
    color: #0a1612;
    line-height: 1.75;
}

/* ════════════════════════════════════
   HERO SECTION
   ════════════════════════════════════ */
.aoro-blog-hero {
    position: relative;
    min-height: 480px;
    display: flex;
    align-items: flex-end;
    border-radius: 20px;
    overflow: hidden;
    margin-bottom: 48px;
}

.aoro-blog-hero-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    z-index: 0;
}

.aoro-blog-hero-bg::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(160deg, rgba(10,22,18,.45) 0%, rgba(15,28,25,.92) 100%);
}

/* SVG solar corner decoration */
.aoro-blog-corner {
    position: absolute;
    top: 0; right: 0;
    width: 220px; height: 220px;
    opacity: .08;
    z-index: 1;
}

.aoro-blog-hero-content {
    position: relative;
    z-index: 2;
    padding: 40px 44px 44px;
    max-width: 820px;
}

.aoro-blog-hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(160,255,212,.12);
    border: 1px solid rgba(160,255,212,.3);
    border-radius: 40px;
    padding: 6px 16px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: #a0ffd4;
    margin-bottom: 20px;
}

.aoro-blog-hero-badge svg {
    width: 14px; height: 14px;
    flex-shrink: 0;
    color: #a0ffd4;
}

.aoro-blog-hero-title {
    font-size: clamp(26px, 4vw, 44px);
    font-weight: 800;
    line-height: 1.2;
    color: #ffffff;
    margin: 0 0 18px;
    letter-spacing: -.02em;
}

.aoro-blog-hero-excerpt {
    font-size: 17px;
    color: rgba(255,255,255,.78);
    margin: 0;
    max-width: 620px;
}


/* ════════════════════════════════════
   HERO ANIMATIONS — Energy Reveal
   ════════════════════════════════════ */

/* Animated energy pulse ring behind hero */
.aoro-blog-hero::before {
    content: '';
    position: absolute;
    top: 50%; left: 50%;
    width: 600px; height: 600px;
    transform: translate(-50%, -50%);
    border-radius: 50%;
    background: radial-gradient(circle, rgba(160,255,212,.10) 0%, transparent 65%);
    animation: aoroPulseRing 6s ease-in-out infinite alternate;
    z-index: 1;
    pointer-events: none;
}

@keyframes aoroPulseRing {
    0%   { transform: translate(-50%,-50%) scale(.85); opacity: .4; }
    100% { transform: translate(-50%,-50%) scale(1.15); opacity: .9; }
}

/* Scan-line shimmer across the hero */
.aoro-blog-hero::after {
    content: '';
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(
        0deg,
        transparent,
        transparent 3px,
        rgba(160,255,212,.015) 3px,
        rgba(160,255,212,.015) 4px
    );
    z-index: 1;
    pointer-events: none;
    animation: aoroScanMove 12s linear infinite;
}

@keyframes aoroScanMove {
    0%   { background-position-y: 0px; }
    100% { background-position-y: 100px; }
}

/* Floating energy particles (4 SVG dots via pseudo on hero-bg) */
.aoro-blog-hero-bg::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle 3px at 15% 25%, rgba(160,255,212,.7) 0%, transparent 100%),
        radial-gradient(circle 2px at 75% 15%, rgba(160,255,212,.5) 0%, transparent 100%),
        radial-gradient(circle 4px at 85% 70%, rgba(160,255,212,.6) 0%, transparent 100%),
        radial-gradient(circle 2px at 30% 80%, rgba(255,255,255,.4) 0%, transparent 100%),
        radial-gradient(circle 3px at 60% 40%, rgba(160,255,212,.4) 0%, transparent 100%);
    animation: aoroParticlesFloat 8s ease-in-out infinite alternate;
    z-index: 1;
    pointer-events: none;
}

@keyframes aoroParticlesFloat {
    0%   { opacity: .4; transform: translateY(0px); }
    100% { opacity: 1;  transform: translateY(-18px); }
}

/* ── Hero content: staggered reveal ── */
.aoro-blog-hero-content {
    position: relative;
    z-index: 2;
    padding: 40px 44px 44px;
    max-width: 820px;
}

.aoro-blog-hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(160,255,212,.12);
    border: 1px solid rgba(160,255,212,.3);
    border-radius: 40px;
    padding: 6px 16px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: #a0ffd4;
    margin-bottom: 20px;
    /* Animation */
    opacity: 0;
    transform: translateY(20px);
    animation: aoroSlideUp .7s cubic-bezier(.2,.8,.2,1) .1s forwards;
}

.aoro-blog-hero-badge svg {
    width: 14px; height: 14px;
    flex-shrink: 0;
    color: #a0ffd4;
    animation: aoroBoltPulse 2s ease-in-out infinite;
}

@keyframes aoroBoltPulse {
    0%, 100% { filter: drop-shadow(0 0 0px #a0ffd4); opacity: 1; }
    50%       { filter: drop-shadow(0 0 6px #a0ffd4); opacity: .7; }
}

.aoro-blog-hero-title {
    font-size: clamp(26px, 4vw, 44px);
    font-weight: 800;
    line-height: 1.2;
    color: #ffffff;
    margin: 0 0 18px;
    letter-spacing: -.02em;
    /* Animation */
    opacity: 0;
    transform: translateY(28px);
    animation: aoroSlideUp .85s cubic-bezier(.2,.8,.2,1) .3s forwards;
}

/* Green gradient shimmer on title */
.aoro-blog-hero-title em,
.aoro-blog-hero-title .aoro-hero-accent {
    font-style: normal;
    background: linear-gradient(90deg, #a0ffd4, #1F6F5C, #a0ffd4);
    background-size: 200% auto;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    animation: aoroGradientShift 4s linear infinite;
}

@keyframes aoroGradientShift {
    0%   { background-position: 0% center; }
    100% { background-position: 200% center; }
}

.aoro-blog-hero-excerpt {
    font-size: 17px;
    color: rgba(255,255,255,.78);
    margin: 0;
    max-width: 620px;
    /* Animation */
    opacity: 0;
    transform: translateY(20px);
    animation: aoroSlideUp .7s cubic-bezier(.2,.8,.2,1) .55s forwards;
}

/* Shared keyframe */
@keyframes aoroSlideUp {
    to { opacity: 1; transform: translateY(0); }
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
    .aoro-blog-hero::before,
    .aoro-blog-hero::after,
    .aoro-blog-hero-bg::before { animation: none !important; }
    .aoro-blog-hero-badge,
    .aoro-blog-hero-title,
    .aoro-blog-hero-excerpt { animation: none !important; opacity: 1 !important; transform: none !important; }
}

/* ════════════════════════════════════
   LAYOUT: main + sidebar
   ════════════════════════════════════ */
.aoro-blog-layout {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 48px;
    align-items: start;
    max-width: 1240px;
    margin: 0 auto;
    padding: 0 24px;
}

.aoro-blog-main { min-width: 0; }

.aoro-blog-sidebar {
    position: sticky;
    top: 100px;
    display: flex;
    flex-direction: column;
    gap: 28px;
}

/* ════════════════════════════════════
   TABLE OF CONTENTS
   ════════════════════════════════════ */
.aoro-toc {
    background: #fff;
    border: 1px solid rgba(31,111,92,.14);
    border-radius: 16px;
    padding: 24px 26px;
    box-shadow: 0 4px 20px rgba(31,111,92,.06);
}

.aoro-toc-title {
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--aoro-green);
    margin: 0 0 16px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.aoro-toc-title svg { width: 14px; height: 14px; }

.aoro-toc ol {
    margin: 0;
    padding-left: 20px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.aoro-toc ol li { font-size: 14px; font-weight: 500; }

.aoro-toc a {
    color: #0a1612;
    text-decoration: none;
    transition: color var(--aoro-t);
}

.aoro-toc a:hover { color: var(--aoro-green); }

/* ════════════════════════════════════
   TYPOGRAPHY — H2 / H3
   ════════════════════════════════════ */
.aoro-blog-main h2 {
    font-size: clamp(21px, 2.8vw, 28px);
    font-weight: 800;
    color: #0a1612;
    margin: 52px 0 18px;
    padding-left: 16px;
    border-left: 4px solid var(--aoro-green);
    line-height: 1.3;
    scroll-margin-top: 110px;
}

.aoro-blog-main h3 {
    font-size: clamp(17px, 2.2vw, 21px);
    font-weight: 700;
    color: #0a1612;
    margin: 36px 0 14px;
    scroll-margin-top: 110px;
}

.aoro-blog-main h3::before {
    content: '';
    display: inline-block;
    width: 8px; height: 8px;
    background: var(--aoro-green);
    border-radius: 50%;
    margin-right: 10px;
    vertical-align: middle;
    position: relative;
    top: -2px;
}

.aoro-blog-main p {
    font-size: 17px;
    line-height: 1.8;
    color: #1a2b25;
    margin: 0 0 22px;
}

.aoro-blog-main ul,
.aoro-blog-main ol {
    padding-left: 24px;
    margin: 0 0 22px;
}

.aoro-blog-main li {
    font-size: 16.5px;
    line-height: 1.75;
    margin-bottom: 8px;
    color: #1a2b25;
}

.aoro-blog-main a {
    color: var(--aoro-green);
    text-decoration: underline;
    text-decoration-color: rgba(31,111,92,.3);
    text-underline-offset: 3px;
    transition: color var(--aoro-t), text-decoration-color var(--aoro-t);
}

.aoro-blog-main a:hover {
    color: var(--aoro-green-dk);
    text-decoration-color: var(--aoro-green-dk);
}

/* ════════════════════════════════════
   INTRO PARAGRAPH (first <p> after H1)
   ════════════════════════════════════ */
.aoro-intro {
    font-size: 19px !important;
    font-weight: 500 !important;
    color: #1a2b25 !important;
    border-left: 3px solid var(--aoro-green-lt);
    padding-left: 20px;
    margin-bottom: 36px !important;
    line-height: 1.75 !important;
}

/* ════════════════════════════════════
   IMAGES
   ════════════════════════════════════ */
.aoro-blog-img-wrap {
    margin: 32px 0;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 8px 32px rgba(0,0,0,.10);
}

.aoro-blog-img-wrap img {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 16/9;
    object-fit: cover;
}

.aoro-blog-img-wrap figcaption {
    font-size: 13px;
    color: #64748b;
    padding: 10px 16px;
    background: #f8faf9;
    border-top: 1px solid rgba(31,111,92,.08);
    font-style: italic;
}

/* ════════════════════════════════════
   CTA BLOCK
   ════════════════════════════════════ */
.aoro-cta {
    background: linear-gradient(135deg, #0f1c19 0%, #1F6F5C 100%);
    border-radius: 18px;
    padding: 40px 44px;
    margin: 44px 0;
    position: relative;
    overflow: hidden;
    box-shadow: 0 12px 40px rgba(31,111,92,.25);
}

.aoro-cta::before {
    content: '';
    position: absolute;
    top: -60px; right: -60px;
    width: 240px; height: 240px;
    background: radial-gradient(circle, rgba(160,255,212,.15) 0%, transparent 70%);
    pointer-events: none;
}

.aoro-cta-label {
    display: inline-block;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: #a0ffd4;
    margin-bottom: 12px;
}

.aoro-cta h3,
.aoro-cta .aoro-cta-title {
    font-size: clamp(20px, 2.5vw, 26px);
    font-weight: 800;
    color: #ffffff;
    margin: 0 0 12px;
    line-height: 1.3;
}

.aoro-cta h3::before { display: none; }

.aoro-cta p,
.aoro-cta .aoro-cta-body {
    font-size: 16px;
    color: rgba(255,255,255,.82);
    margin: 0 0 26px;
    max-width: 560px;
}

.aoro-cta-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: #a0ffd4;
    color: #0a1612 !important;
    font-size: 15px;
    font-weight: 800;
    padding: 14px 30px;
    border-radius: 40px;
    text-decoration: none !important;
    transition: background var(--aoro-t), transform var(--aoro-t), box-shadow var(--aoro-t);
    box-shadow: 0 4px 20px rgba(160,255,212,.35);
}

.aoro-cta-btn:hover {
    background: #ffffff;
    color: #0a1612 !important;
    transform: translateY(-3px);
    box-shadow: 0 10px 30px rgba(160,255,212,.4);
}

.aoro-cta-btn svg { width: 16px; height: 16px; }

/* CTA Light variant */
.aoro-cta.aoro-cta--light {
    background: rgba(31,111,92,.06);
    border: 1px solid rgba(31,111,92,.18);
    box-shadow: none;
}

.aoro-cta.aoro-cta--light .aoro-cta-label { color: var(--aoro-green); }
.aoro-cta.aoro-cta--light .aoro-cta-title { color: #0a1612; }
.aoro-cta.aoro-cta--light .aoro-cta-body { color: #334e45; }

.aoro-cta.aoro-cta--light .aoro-cta-btn {
    background: var(--aoro-green);
    color: #ffffff !important;
    box-shadow: 0 4px 18px rgba(31,111,92,.3);
}

.aoro-cta.aoro-cta--light .aoro-cta-btn:hover {
    background: var(--aoro-green-dk);
    color: #ffffff !important;
}

/* ════════════════════════════════════
   HIGHLIGHT / INSIGHT BLOCK
   ════════════════════════════════════ */
.aoro-highlight {
    background: #0f1c19;
    border-left: 4px solid #a0ffd4;
    border-radius: 12px;
    padding: 26px 30px;
    margin: 36px 0;
    position: relative;
    overflow: hidden;
}

.aoro-highlight::after {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at top right, rgba(160,255,212,.08) 0%, transparent 60%);
    pointer-events: none;
}

.aoro-highlight p {
    font-size: 17px !important;
    font-weight: 600 !important;
    color: rgba(255,255,255,.92) !important;
    margin: 0 !important;
    font-style: italic;
    line-height: 1.7 !important;
    position: relative;
    z-index: 1;
}

.aoro-highlight .aoro-highlight-source {
    font-size: 13px !important;
    font-weight: 500 !important;
    color: rgba(160,255,212,.7) !important;
    font-style: normal !important;
    margin-top: 10px !important;
}

/* ════════════════════════════════════
   DATA TABLE BLOCK
   ════════════════════════════════════ */
.aoro-table-wrap {
    overflow-x: auto;
    border-radius: 14px;
    border: 1px solid rgba(31,111,92,.14);
    margin: 36px 0;
    box-shadow: 0 4px 18px rgba(0,0,0,.05);
}

.aoro-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 15px;
    background: #fff;
    border-radius: 14px;
    overflow: hidden;
}

.aoro-table thead tr {
    background: linear-gradient(90deg, #0f1c19, #1F6F5C);
}

.aoro-table thead th {
    color: #ffffff;
    font-weight: 700;
    font-size: 13px;
    letter-spacing: .05em;
    text-transform: uppercase;
    padding: 16px 20px;
    text-align: left;
    white-space: nowrap;
}

.aoro-table tbody tr {
    border-bottom: 1px solid rgba(31,111,92,.08);
    transition: background var(--aoro-t);
}

.aoro-table tbody tr:last-child { border-bottom: none; }

.aoro-table tbody tr:hover { background: rgba(31,111,92,.04); }

.aoro-table tbody td {
    padding: 14px 20px;
    color: #1a2b25;
    vertical-align: middle;
}

.aoro-table tbody tr:nth-child(even) td {
    background: rgba(31,111,92,.025);
}

/* ════════════════════════════════════
   FAQ SECTION
   ════════════════════════════════════ */
.aoro-faq { margin: 40px 0; }

.aoro-faq-title {
    font-size: 22px;
    font-weight: 800;
    color: #0a1612;
    margin: 0 0 24px;
    padding-left: 16px;
    border-left: 4px solid var(--aoro-green);
}

.aoro-faq-item {
    border: 1px solid rgba(31,111,92,.14);
    border-radius: 12px;
    margin-bottom: 12px;
    overflow: hidden;
    transition: box-shadow var(--aoro-t);
}

.aoro-faq-item:hover {
    box-shadow: 0 4px 18px rgba(31,111,92,.10);
}

.aoro-faq-q {
    width: 100%;
    background: none;
    border: none;
    text-align: left;
    padding: 20px 24px;
    font-size: 16px;
    font-weight: 700;
    color: #0a1612;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    font-family: 'Epilogue', sans-serif;
    transition: background var(--aoro-t), color var(--aoro-t);
}

.aoro-faq-q:hover { background: rgba(31,111,92,.04); }

.aoro-faq-q[aria-expanded="true"] {
    background: rgba(31,111,92,.06);
    color: var(--aoro-green);
}

.aoro-faq-icon {
    width: 22px; height: 22px;
    flex-shrink: 0;
    border-radius: 50%;
    background: rgba(31,111,92,.10);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background var(--aoro-t), transform var(--aoro-t);
}

.aoro-faq-q[aria-expanded="true"] .aoro-faq-icon {
    background: var(--aoro-green);
    transform: rotate(45deg);
}

.aoro-faq-icon svg { width: 12px; height: 12px; color: var(--aoro-green); }
.aoro-faq-q[aria-expanded="true"] .aoro-faq-icon svg { color: #fff; }

.aoro-faq-a {
    display: none;
    padding: 0 24px 22px;
    font-size: 15.5px;
    line-height: 1.75;
    color: #334e45;
    border-top: 1px solid rgba(31,111,92,.08);
    padding-top: 16px;
}

.aoro-faq-a.open { display: block; }

/* ════════════════════════════════════
   CONCLUSION
   ════════════════════════════════════ */
.aoro-conclusion {
    background: rgba(31,111,92,.05);
    border-radius: 16px;
    border: 1px solid rgba(31,111,92,.14);
    padding: 32px 36px;
    margin: 44px 0;
}

.aoro-conclusion-label {
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--aoro-green);
    display: block;
    margin-bottom: 10px;
}

.aoro-conclusion h2 {
    border: none !important;
    padding-left: 0 !important;
    margin-top: 0 !important;
    font-size: 22px !important;
}

.aoro-conclusion h2::before { display: none; }

/* ════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════ */
@media (max-width: 1024px) {
    .aoro-blog-layout {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .aoro-blog-sidebar {
        position: static;
        flex-direction: row;
        flex-wrap: wrap;
    }

    .aoro-toc { flex: 1 1 100%; }
}

@media (max-width: 767px) {
    .aoro-blog-hero { min-height: 360px; }
    .aoro-blog-hero-content { padding: 24px 22px 28px; }
    .aoro-cta { padding: 30px 24px; }
    .aoro-blog-layout { padding: 0 16px; }
    .aoro-table thead th,
    .aoro-table tbody td { padding: 12px 14px; font-size: 14px; }
    .aoro-highlight { padding: 20px 22px; }
    .aoro-conclusion { padding: 24px 22px; }
}


/* ════════════════════════════════════
   FULL-WIDTH ARTICLE BODY
   (used when theme handles sidebar)
   ════════════════════════════════════ */
.aoro-blog-body {
    max-width: 100%;
}

.aoro-blog-body h2 {
    font-size: clamp(21px, 2.8vw, 28px);
    font-weight: 800;
    color: #0a1612;
    margin: 52px 0 18px;
    padding-left: 16px;
    border-left: 4px solid var(--aoro-green);
    line-height: 1.3;
    scroll-margin-top: 110px;
}

.aoro-blog-body h3 {
    font-size: clamp(17px, 2.2vw, 21px);
    font-weight: 700;
    color: #0a1612;
    margin: 36px 0 14px;
    scroll-margin-top: 110px;
}

.aoro-blog-body h3::before {
    content: '';
    display: inline-block;
    width: 8px; height: 8px;
    background: var(--aoro-green);
    border-radius: 50%;
    margin-right: 10px;
    vertical-align: middle;
    position: relative;
    top: -2px;
}

.aoro-blog-body p {
    font-size: 17px;
    line-height: 1.8;
    color: #1a2b25;
    margin: 0 0 22px;
}

.aoro-blog-body ul,
.aoro-blog-body ol {
    padding-left: 24px;
    margin: 0 0 22px;
}

.aoro-blog-body li {
    font-size: 16.5px;
    line-height: 1.75;
    margin-bottom: 8px;
    color: #1a2b25;
}

.aoro-blog-body a {
    color: var(--aoro-green);
    text-decoration: underline;
    text-decoration-color: rgba(31,111,92,.3);
    text-underline-offset: 3px;
    transition: color var(--aoro-t), text-decoration-color var(--aoro-t);
}

.aoro-blog-body a:hover {
    color: var(--aoro-green-dk);
    text-decoration-color: var(--aoro-green-dk);
}

/* Overrides for blocks inside .aoro-blog-body that also use h2/h3 */
.aoro-blog-body .aoro-cta h3::before,
.aoro-blog-body .aoro-conclusion h2::before { display: none; }
.aoro-blog-body .aoro-conclusion h2 {
    border: none !important;
    padding-left: 0 !important;
    margin-top: 0 !important;
    font-size: 22px !important;
}

/* ════════════════════════════════════
   INLINE TABLE OF CONTENTS
   (full-width variant, no sidebar)
   ════════════════════════════════════ */
.aoro-toc-inline {
    background: rgba(31,111,92,.04);
    border: 1px solid rgba(31,111,92,.14);
    border-radius: 14px;
    padding: 22px 26px;
    margin-bottom: 36px;
}

.aoro-toc-inline .aoro-toc-title {
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--aoro-green);
    margin: 0 0 14px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.aoro-toc-inline .aoro-toc-title svg { width: 14px; height: 14px; flex-shrink: 0; }

.aoro-toc-list {
    margin: 0;
    padding-left: 20px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.aoro-toc-list li { font-size: 14.5px; font-weight: 500; }

.aoro-toc-list a {
    color: #0a1612;
    text-decoration: none;
    transition: color var(--aoro-t);
}

.aoro-toc-list a:hover { color: var(--aoro-green); }

/* ════════════════════════════════════
   IMAGE PLACEHOLDER
   (shown until client uploads image)
   ════════════════════════════════════ */
.aoro-img-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 14px;
    background: rgba(31,111,92,.04);
    border: 2px dashed rgba(31,111,92,.25);
    border-radius: 12px;
    padding: 40px 24px;
    text-align: center;
    min-height: 220px;
    cursor: default;
    transition: background var(--aoro-t), border-color var(--aoro-t);
}

.aoro-img-placeholder:hover {
    background: rgba(31,111,92,.08);
    border-color: rgba(31,111,92,.45);
}

.aoro-img-placeholder svg {
    width: 56px; height: 56px;
    opacity: .55;
}

.aoro-img-placeholder span {
    font-size: 13.5px;
    font-weight: 600;
    color: #64748b;
    max-width: 360px;
    line-height: 1.5;
}

@media (max-width: 767px) {
    .aoro-toc-inline { padding: 18px 18px; }
    .aoro-blog-body h2 { font-size: 20px; margin-top: 40px; }
    .aoro-blog-body h3 { font-size: 17px; }
    .aoro-img-placeholder { min-height: 160px; padding: 28px 16px; }
    .aoro-img-placeholder svg { width: 40px; height: 40px; }
}


/* ════════════════════════════════════
   INLINE HIGHLIGHTS — prices / savings
   Usage: <span class="aoro-saving">£1,008</span>
   ════════════════════════════════════ */
.aoro-saving,
.aoro-price,
.aoro-green {
    color: var(--aoro-green) !important;
    font-weight: 800 !important;
}

.aoro-saving {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: rgba(31,111,92,.08);
    border-radius: 6px;
    padding: 1px 8px;
    font-size: inherit;
}

.aoro-saving::before {
    content: '↑';
    font-size: .8em;
    color: var(--aoro-green);
}

.aoro-price {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: rgba(31,111,92,.06);
    border-radius: 6px;
    padding: 1px 8px;
    font-size: inherit;
}

/* Table — colour positive savings green, neutral grey */
.aoro-table td.aoro-td-good {
    color: var(--aoro-green) !important;
    font-weight: 800 !important;
}

.aoro-table td.aoro-td-better {
    color: var(--aoro-green) !important;
    font-weight: 800 !important;
    background: rgba(31,111,92,.06) !important;
}

/* ════════════════════════════════════
   STAT CARDS GRID
   ════════════════════════════════════ */
.aoro-stat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 16px;
    margin: 36px 0;
}

.aoro-stat-card {
    background: #fff;
    border: 1px solid rgba(31,111,92,.15);
    border-radius: 14px;
    padding: 22px 18px;
    text-align: center;
    box-shadow: 0 4px 18px rgba(31,111,92,.07);
    transition: transform var(--aoro-t), box-shadow var(--aoro-t);
}

.aoro-stat-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 28px rgba(31,111,92,.14);
}

.aoro-stat-card .aoro-stat-num {
    display: block;
    font-size: clamp(26px, 4vw, 36px);
    font-weight: 900;
    color: var(--aoro-green);
    line-height: 1.1;
    letter-spacing: -.02em;
    margin-bottom: 6px;
}

.aoro-stat-card .aoro-stat-label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: #64748b;
    line-height: 1.4;
    text-transform: uppercase;
    letter-spacing: .05em;
}

.aoro-stat-card .aoro-stat-sub {
    display: block;
    font-size: 12px;
    color: var(--aoro-green);
    font-weight: 700;
    margin-top: 4px;
}

@media (max-width: 480px) {
    .aoro-stat-grid { grid-template-columns: repeat(2, 1fr); }
}


/* ════════════════════════════════════
   FAQ — AORO OVERRIDE
   Force AORO green theme over any
   Solak / theme blue accordion styles.
   Very high specificity to win cascade.
   ════════════════════════════════════ */
html body .aoro-faq .aoro-faq-item {
    border: 1px solid rgba(31,111,92,.18) !important;
    border-radius: 12px !important;
    margin-bottom: 10px !important;
    background: #fff !important;
    overflow: hidden !important;
    box-shadow: none !important;
    transition: box-shadow .3s ease !important;
}

html body .aoro-faq .aoro-faq-item:hover {
    box-shadow: 0 4px 20px rgba(31,111,92,.12) !important;
}

html body .aoro-faq .aoro-faq-q {
    width: 100% !important;
    background: #fff !important;
    background-color: #fff !important;
    border: none !important;
    border-radius: 0 !important;
    text-align: left !important;
    padding: 18px 22px !important;
    font-size: 15.5px !important;
    font-weight: 700 !important;
    color: #0a1612 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    cursor: pointer !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 16px !important;
    font-family: 'Epilogue', sans-serif !important;
    transition: background .3s ease, color .3s ease !important;
    line-height: 1.4 !important;
}

html body .aoro-faq .aoro-faq-q:hover {
    background: rgba(31,111,92,.04) !important;
    color: var(--aoro-green) !important;
}

html body .aoro-faq .aoro-faq-q[aria-expanded="true"] {
    background: rgba(31,111,92,.06) !important;
    color: var(--aoro-green) !important;
}

/* Icon circle */
html body .aoro-faq .aoro-faq-icon {
    width: 26px !important;
    height: 26px !important;
    min-width: 26px !important;
    border-radius: 50% !important;
    background: rgba(31,111,92,.10) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: background .3s ease, transform .3s ease !important;
    flex-shrink: 0 !important;
}

html body .aoro-faq .aoro-faq-q[aria-expanded="true"] .aoro-faq-icon {
    background: var(--aoro-green) !important;
    transform: rotate(45deg) !important;
}

html body .aoro-faq .aoro-faq-icon svg {
    width: 12px !important;
    height: 12px !important;
    stroke: var(--aoro-green) !important;
    fill: none !important;
}

html body .aoro-faq .aoro-faq-q[aria-expanded="true"] .aoro-faq-icon svg {
    stroke: #fff !important;
}

/* Answer panel */
html body .aoro-faq .aoro-faq-a {
    display: none !important;
    padding: 16px 22px 20px !important;
    font-size: 15.5px !important;
    line-height: 1.75 !important;
    color: #334e45 !important;
    border-top: 1px solid rgba(31,111,92,.10) !important;
    background: #fff !important;
    margin: 0 !important;
}

html body .aoro-faq .aoro-faq-a.open {
    display: block !important;
}

/* FAQ Section title */
html body .aoro-faq .aoro-faq-title {
    font-size: clamp(21px, 2.8vw, 28px) !important;
    font-weight: 800 !important;
    color: #0a1612 !important;
    padding-left: 16px !important;
    border-left: 4px solid var(--aoro-green) !important;
    margin: 0 0 24px !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    background: none !important;
    border-radius: 0 !important;
}


/* ════════════════════════════════════
   CTA BLOCK — FLEX ROW REDESIGN
   Text left · Button right · Expert UX
   ════════════════════════════════════ */

/* Dark CTA */
html body .aoro-cta {
    background: linear-gradient(135deg, #0f1c19 0%, #1a4a3a 60%, #1F6F5C 100%) !important;
    border-radius: 16px !important;
    padding: 32px 36px !important;
    margin: 40px 0 !important;
    position: relative !important;
    overflow: hidden !important;
    box-shadow: 0 12px 40px rgba(31,111,92,.22) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 32px !important;
}

html body .aoro-cta::before {
    content: '' !important;
    position: absolute !important;
    top: -50px; right: -50px !important;
    width: 220px; height: 220px !important;
    background: radial-gradient(circle, rgba(160,255,212,.12) 0%, transparent 70%) !important;
    pointer-events: none !important;
}

.aoro-cta-text { flex: 1 1 auto; min-width: 0; }

html body .aoro-cta .aoro-cta-label {
    display: inline-block !important;
    font-size: 10px !important;
    font-weight: 800 !important;
    letter-spacing: .14em !important;
    text-transform: uppercase !important;
    color: #a0ffd4 !important;
    margin-bottom: 8px !important;
}

html body .aoro-cta .aoro-cta-title,
html body .aoro-cta h3 {
    font-size: clamp(17px, 2vw, 22px) !important;
    font-weight: 800 !important;
    color: #ffffff !important;
    margin: 0 0 6px !important;
    line-height: 1.3 !important;
}

html body .aoro-cta .aoro-cta-title::before,
html body .aoro-cta h3::before { display: none !important; }

html body .aoro-cta .aoro-cta-body,
html body .aoro-cta p {
    font-size: 14.5px !important;
    color: rgba(255,255,255,.75) !important;
    margin: 0 !important;
    line-height: 1.6 !important;
    max-width: 480px !important;
}

/* Outline white button */
html body .aoro-cta .aoro-cta-btn {
    flex-shrink: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    background: transparent !important;
    border: 2px solid #ffffff !important;
    color: #ffffff !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    padding: 12px 22px !important;
    border-radius: 8px !important;
    text-decoration: none !important;
    white-space: nowrap !important;
    transition: background .25s ease, color .25s ease, border-color .25s ease, transform .25s ease !important;
    letter-spacing: .02em !important;
}

html body .aoro-cta .aoro-cta-btn svg {
    width: 15px !important;
    height: 15px !important;
    flex-shrink: 0 !important;
}

html body .aoro-cta .aoro-cta-btn:hover {
    background: var(--aoro-green-dk) !important;
    border-color: var(--aoro-green-dk) !important;
    color: #ffffff !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(31,111,92,.35) !important;
    text-decoration: none !important;
}

/* Light CTA variant */
html body .aoro-cta.aoro-cta--light {
    background: rgba(31,111,92,.05) !important;
    border: 1px solid rgba(31,111,92,.18) !important;
    box-shadow: none !important;
}

html body .aoro-cta.aoro-cta--light .aoro-cta-label {
    color: var(--aoro-green) !important;
}

html body .aoro-cta.aoro-cta--light .aoro-cta-title,
html body .aoro-cta.aoro-cta--light h3,
html body .aoro-cta.aoro-cta--light p.aoro-cta-title {
    color: #0a1612 !important;
}

html body .aoro-cta.aoro-cta--light .aoro-cta-body,
html body .aoro-cta.aoro-cta--light p {
    color: #334e45 !important;
}

html body .aoro-cta.aoro-cta--light .aoro-cta-btn {
    background: transparent !important;
    border: 2px solid var(--aoro-green) !important;
    color: var(--aoro-green) !important;
}

html body .aoro-cta.aoro-cta--light .aoro-cta-btn:hover {
    background: var(--aoro-green-dk) !important;
    border-color: var(--aoro-green-dk) !important;
    color: #ffffff !important;
}

/* Stack on mobile */
@media (max-width: 640px) {
    html body .aoro-cta {
        flex-direction: column !important;
        align-items: flex-start !important;
        padding: 24px 22px !important;
        gap: 20px !important;
    }
    html body .aoro-cta .aoro-cta-btn { width: 100% !important; justify-content: center !important; }
}


/* ════════════════════════════════════
   FAQ — question text flex + icon right
   ════════════════════════════════════ */
html body .aoro-faq .aoro-faq-q-text {
    flex: 1 1 auto !important;
    text-align: left !important;
    padding-right: 12px !important;
    font-size: 15.5px !important;
    font-weight: 700 !important;
    color: inherit !important;
    line-height: 1.4 !important;
}

/* Pill CTA button */
html body .aoro-cta .aoro-cta-btn {
    border-radius: 50px !important;
}

/* Safety: no stray BR in buttons or TOC title */
html body .aoro-cta .aoro-cta-btn br,
html body .aoro-faq-q br,
html body .aoro-toc-title br { display: none !important; }

/* Ultra-bold conversion sums */
.aoro-saving,
.aoro-price,
.aoro-green {
    font-weight: 900 !important;
    letter-spacing: -0.01em;
}

.aoro-saving {
    background: rgba(31,111,92,.12) !important;
}

.aoro-price {
    background: rgba(31,111,92,.10) !important;
}


/* ================================================================
   AORO SOLAR — SYSTEMS PAGE CLASS PACK  v1.0
   Scope: .aoro-systems-wrap  |  Zero conflict with existing classes
   Usage: UX Booster → CSS field  OR  empire.css
   ================================================================ */

/* ── HERO ── */
.aoro-sys-hero{position:relative;min-height:520px;display:flex;align-items:flex-end;border-radius:20px;overflow:hidden;margin-bottom:56px}
.aoro-sys-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.aoro-sys-hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(160deg,rgba(10,22,18,.4) 0%,rgba(10,22,18,.92) 100%)}
.aoro-sys-hero::before{content:'';position:absolute;top:50%;left:50%;width:700px;height:700px;transform:translate(-50%,-50%);border-radius:50%;background:radial-gradient(circle,rgba(160,255,212,.09) 0%,transparent 65%);animation:sysHeroPulse 7s ease-in-out infinite alternate;z-index:1;pointer-events:none}
@keyframes sysHeroPulse{0%{transform:translate(-50%,-50%) scale(.85);opacity:.4}100%{transform:translate(-50%,-50%) scale(1.15);opacity:.9}}
.aoro-sys-hero-content{position:relative;z-index:2;padding:48px 52px 52px;max-width:860px}
.aoro-sys-hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(160,255,212,.12);border:1px solid rgba(160,255,212,.3);border-radius:40px;padding:6px 18px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#a0ffd4;margin-bottom:20px;opacity:0;transform:translateY(20px);animation:aoroSlideUp .7s cubic-bezier(.2,.8,.2,1) .1s forwards}
.aoro-sys-hero-h1{font-size:clamp(28px,4.5vw,52px);font-weight:800;line-height:1.15;color:#fff;margin:0 0 20px;letter-spacing:-.02em;opacity:0;transform:translateY(28px);animation:aoroSlideUp .85s cubic-bezier(.2,.8,.2,1) .3s forwards}
.aoro-sys-hero-h1 em{font-style:normal;background:linear-gradient(90deg,#a0ffd4,#1F6F5C,#a0ffd4);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:aoroGradientShift 4s linear infinite}
.aoro-sys-hero-sub{font-size:17px;color:rgba(255,255,255,.8);margin:0 0 28px;max-width:640px;opacity:0;transform:translateY(20px);animation:aoroSlideUp .7s cubic-bezier(.2,.8,.2,1) .5s forwards}
.aoro-sys-hero-checks{display:flex;flex-wrap:wrap;gap:10px 24px;margin-bottom:20px;opacity:0;animation:aoroSlideUp .7s cubic-bezier(.2,.8,.2,1) .65s forwards}
.aoro-sys-hero-checks span{font-size:14px;font-weight:600;color:rgba(255,255,255,.88);display:flex;align-items:center;gap:6px}
.aoro-sys-hero-checks span::before{content:'✔';color:#a0ffd4;font-size:12px}
.aoro-sys-hero-btns{display:flex;flex-wrap:wrap;gap:14px;opacity:0;animation:aoroSlideUp .7s cubic-bezier(.2,.8,.2,1) .8s forwards}

/* ── BUTTONS ── */
.aoro-sys-btn-primary{display:inline-flex;align-items:center;gap:9px;background:#a0ffd4;color:#0a1612 !important;font-size:15px;font-weight:800;padding:15px 32px;border-radius:40px;text-decoration:none !important;box-shadow:0 4px 22px rgba(160,255,212,.35);transition:background .3s,transform .3s,box-shadow .3s}
.aoro-sys-btn-primary:hover{background:#fff;transform:translateY(-3px);box-shadow:0 10px 32px rgba(160,255,212,.45);color:#0a1612 !important}
.aoro-sys-btn-ghost{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.08);color:#fff !important;font-size:15px;font-weight:700;padding:15px 32px;border-radius:40px;border:1px solid rgba(255,255,255,.25);text-decoration:none !important;transition:all .3s}
.aoro-sys-btn-ghost:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.5);transform:translateY(-2px);color:#fff !important}

/* ── SECTION HEADINGS ── */
.aoro-sys-section-label{display:block;font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:#1F6F5C;margin-bottom:8px}
.aoro-sys-section-title{font-size:clamp(24px,3.2vw,36px);font-weight:800;color:#0a1612;margin:0 0 14px;letter-spacing:-.02em;line-height:1.25}
.aoro-sys-section-sub{font-size:17px;color:#334e45;max-width:640px;margin:0 0 44px;line-height:1.75}
.aoro-sys-section-header{text-align:center}
.aoro-sys-section-header .aoro-sys-section-sub{margin-left:auto;margin-right:auto}

/* ── STATS STRIP ── */
.aoro-sys-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(31,111,92,.12);border-radius:16px;overflow:hidden;margin-bottom:56px;border:1px solid rgba(31,111,92,.14)}
.aoro-sys-stat{background:#fff;padding:28px 24px;text-align:center;transition:background .3s}
.aoro-sys-stat:hover{background:rgba(31,111,92,.04)}
.aoro-sys-stat-num{display:block;font-size:clamp(26px,3vw,36px);font-weight:900;color:#1F6F5C;letter-spacing:-.02em}
.aoro-sys-stat-label{display:block;font-size:13px;font-weight:600;color:#334e45;margin-top:4px}

/* ── SYSTEMS GRID ── */
.aoro-systems-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;margin-bottom:56px}
.aoro-sys-card{background:#fff;border:1px solid rgba(31,111,92,.14);border-radius:20px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.06);transition:transform .3s,box-shadow .3s,border-color .3s;display:flex;flex-direction:column}
.aoro-sys-card:hover{transform:translateY(-6px);box-shadow:0 16px 48px rgba(31,111,92,.16);border-color:rgba(31,111,92,.35)}
.aoro-sys-card--popular{border-color:#1F6F5C;box-shadow:0 8px 32px rgba(31,111,92,.18)}
.aoro-sys-card-top{background:linear-gradient(135deg,#0f1c19 0%,#1F6F5C 100%);padding:28px 28px 24px;position:relative;overflow:hidden}
.aoro-sys-card-top::after{content:'';position:absolute;top:-40px;right:-40px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(160,255,212,.18) 0%,transparent 70%);pointer-events:none}
.aoro-sys-card--popular .aoro-sys-card-top{background:linear-gradient(135deg,#0d2820 0%,#1F6F5C 50%,#27956d 100%)}
.aoro-sys-card-badge{display:inline-block;font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;background:#a0ffd4;color:#0a1612;border-radius:20px;padding:4px 12px;margin-bottom:14px}
.aoro-sys-card-kw{font-size:clamp(32px,4vw,44px);font-weight:900;color:#fff;letter-spacing:-.03em;line-height:1;margin-bottom:6px}
.aoro-sys-card-kw span{font-size:18px;font-weight:600;color:rgba(255,255,255,.7);margin-left:2px}
.aoro-sys-card-tagline{font-size:14px;font-weight:600;color:#a0ffd4;margin-bottom:4px}
.aoro-sys-card-desc{font-size:14px;color:rgba(255,255,255,.72);line-height:1.6}
.aoro-sys-card-body{padding:24px 28px;flex:1;display:flex;flex-direction:column}
.aoro-sys-card-savings{font-size:24px;font-weight:900;color:#1F6F5C;margin-bottom:2px}
.aoro-sys-card-savings-label{font-size:12px;color:#64748b;margin-bottom:18px;font-weight:500}
.aoro-sys-card-features{list-style:none;padding:0;margin:0 0 20px;display:flex;flex-direction:column;gap:9px}
.aoro-sys-card-features li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:#1a2b25;line-height:1.5}
.aoro-sys-card-features li::before{content:'';display:block;width:18px;height:18px;flex-shrink:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Ccircle cx='10' cy='10' r='10' fill='%231F6F5C' opacity='.12'/%3E%3Cpath d='M6 10l3 3 5-5' stroke='%231F6F5C' stroke-width='1.8' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") center/contain no-repeat;margin-top:1px}
.aoro-sys-card-bestfor{font-size:13px;font-weight:700;color:#1F6F5C;background:rgba(31,111,92,.07);border-radius:8px;padding:10px 14px;margin-bottom:20px;border-left:3px solid #1F6F5C}
.aoro-sys-card-cta{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 22px;background:rgba(31,111,92,.04);border-top:1px solid rgba(31,111,92,.1);text-decoration:none !important;font-size:14px;font-weight:800;color:#1F6F5C !important;transition:background .3s,color .3s;margin-top:auto}
.aoro-sys-card-cta:hover{background:#1F6F5C;color:#fff !important}
.aoro-sys-card-cta svg{width:16px;height:16px;flex-shrink:0;transition:transform .3s}
.aoro-sys-card-cta:hover svg{transform:translateX(4px)}

/* ── NOT SURE SECTION ── */
.aoro-sys-notsure{background:linear-gradient(135deg,#0f1c19 0%,#1a3830 100%);border-radius:20px;padding:52px 56px;margin-bottom:56px;position:relative;overflow:hidden}
.aoro-sys-notsure::before{content:'';position:absolute;top:-80px;right:-80px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(160,255,212,.12) 0%,transparent 65%);pointer-events:none}
.aoro-sys-notsure-inner{display:grid;grid-template-columns:1fr auto;gap:40px;align-items:center;position:relative;z-index:1}
.aoro-sys-notsure-label{font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#a0ffd4;margin-bottom:10px;display:block}
.aoro-sys-notsure-title{font-size:clamp(20px,2.8vw,30px);font-weight:800;color:#fff;margin:0 0 12px;line-height:1.3}
.aoro-sys-notsure-body{font-size:16px;color:rgba(255,255,255,.75);margin:0 0 24px;line-height:1.75}
.aoro-sys-notsure-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.aoro-sys-notsure-list li{font-size:15px;color:rgba(255,255,255,.85);font-weight:500;display:flex;align-items:center;gap:10px}
.aoro-sys-notsure-list li::before{content:'';width:20px;height:20px;flex-shrink:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Ccircle cx='10' cy='10' r='10' fill='%23a0ffd4' opacity='.2'/%3E%3Cpath d='M6 10l3 3 5-5' stroke='%23a0ffd4' stroke-width='1.8' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") center/contain no-repeat}
.aoro-sys-notsure-verdict{font-size:13px;font-weight:700;color:#a0ffd4;text-align:center;margin-bottom:16px;line-height:1.6}

/* ── BATTERY SECTION ── */
.aoro-sys-battery{margin-bottom:56px}
.aoro-sys-battery-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.aoro-sys-battery-card{border-radius:18px;overflow:hidden;border:1px solid rgba(31,111,92,.14);box-shadow:0 4px 20px rgba(0,0,0,.06);transition:transform .3s,box-shadow .3s}
.aoro-sys-battery-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px rgba(31,111,92,.14)}
.aoro-sys-battery-img{height:220px;overflow:hidden}
.aoro-sys-battery-img img{width:100%;height:100%;object-fit:cover;display:block}
.aoro-sys-battery-body{padding:28px 30px;background:#fff}
.aoro-sys-battery-head{font-size:20px;font-weight:800;color:#0a1612;margin:0 0 6px}
.aoro-sys-battery-sub{font-size:14px;color:#64748b;margin:0 0 18px}
.aoro-sys-battery-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.aoro-sys-battery-list li{font-size:15px;color:#1a2b25;display:flex;align-items:center;gap:10px}
.aoro-sys-battery-list li::before{content:'';width:18px;height:18px;flex-shrink:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Ccircle cx='10' cy='10' r='10' fill='%231F6F5C' opacity='.12'/%3E%3Cpath d='M6 10l3 3 5-5' stroke='%231F6F5C' stroke-width='1.8' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") center/contain no-repeat}
.aoro-sys-battery-note{grid-column:1/-1;background:rgba(31,111,92,.06);border:1px solid rgba(31,111,92,.18);border-radius:14px;padding:22px 28px;display:flex;align-items:flex-start;gap:16px}
.aoro-sys-battery-note-icon{width:40px;height:40px;flex-shrink:0;background:#1F6F5C;border-radius:50%;display:flex;align-items:center;justify-content:center}
.aoro-sys-battery-note-icon svg{width:18px;height:18px;color:#fff;stroke:#fff;fill:none}
.aoro-sys-battery-note-text{font-size:15px;color:#1a2b25;line-height:1.7}
.aoro-sys-battery-note-text strong{color:#1F6F5C}

/* ── WHAT'S INCLUDED ── */
.aoro-sys-included{background:#fff;border:1px solid rgba(31,111,92,.14);border-radius:20px;padding:44px 48px;margin-bottom:56px;box-shadow:0 4px 20px rgba(0,0,0,.05)}
.aoro-sys-included-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px;margin-top:32px}
.aoro-sys-included-item{display:flex;align-items:flex-start;gap:14px;padding:18px 20px;border-radius:14px;background:rgba(31,111,92,.04);border:1px solid rgba(31,111,92,.09);transition:background .3s,box-shadow .3s}
.aoro-sys-included-item:hover{background:rgba(31,111,92,.08);box-shadow:0 4px 14px rgba(31,111,92,.1)}
.aoro-sys-included-icon{width:38px;height:38px;flex-shrink:0;background:linear-gradient(135deg,#0f1c19,#1F6F5C);border-radius:10px;display:flex;align-items:center;justify-content:center}
.aoro-sys-included-icon svg{width:18px;height:18px;stroke:#a0ffd4;fill:none}
.aoro-sys-included-text{font-size:14px;font-weight:600;color:#0a1612;line-height:1.5}

/* ── BEFORE YOU CHOOSE ── */
.aoro-sys-warning{background:linear-gradient(135deg,#0f1c19 0%,#1a2820 100%);border-radius:20px;padding:44px 48px;margin-bottom:56px;border-left:4px solid #a0ffd4;box-shadow:0 8px 32px rgba(0,0,0,.12)}
.aoro-sys-warning-title{font-size:clamp(20px,2.5vw,26px);font-weight:800;color:#fff;margin:0 0 14px}
.aoro-sys-warning-body{font-size:16px;color:rgba(255,255,255,.78);margin:0 0 20px;line-height:1.75}
.aoro-sys-warning-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:24px 0}
.aoro-sys-warning-item{background:rgba(255,255,255,.05);border-radius:12px;padding:18px 20px;border:1px solid rgba(255,255,255,.08)}
.aoro-sys-warning-item-label{font-size:12px;font-weight:700;color:rgba(160,255,212,.7);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.aoro-sys-warning-item-text{font-size:14px;color:rgba(255,255,255,.75)}
.aoro-sys-warning-verdict{font-size:16px;font-weight:700;color:#a0ffd4;border-top:1px solid rgba(255,255,255,.1);padding-top:20px;margin-top:20px;line-height:1.7}

/* ── FINAL CTA ── */
.aoro-sys-final-cta{background:linear-gradient(135deg,#071426 0%,#0B1F3B 40%,#1F6F5C 100%);border-radius:20px;padding:60px 56px;text-align:center;position:relative;overflow:hidden;margin-bottom:20px}
.aoro-sys-final-cta::before{content:'';position:absolute;top:50%;left:50%;width:600px;height:600px;transform:translate(-50%,-50%);border-radius:50%;background:radial-gradient(circle,rgba(160,255,212,.12) 0%,transparent 65%);pointer-events:none;animation:sysHeroPulse 6s ease-in-out infinite alternate}
.aoro-sys-final-cta-label{display:block;font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:#a0ffd4;margin-bottom:12px}
.aoro-sys-final-cta-title{font-size:clamp(24px,3.5vw,40px);font-weight:800;color:#fff;margin:0 0 16px;line-height:1.25;letter-spacing:-.02em}
.aoro-sys-final-cta-body{font-size:17px;color:rgba(255,255,255,.78);margin:0 auto 32px;max-width:560px;line-height:1.75}
.aoro-sys-final-cta-btns{display:flex;justify-content:center;flex-wrap:wrap;gap:14px;position:relative;z-index:1}
.aoro-sys-final-cta-list{display:flex;justify-content:center;flex-wrap:wrap;gap:8px 28px;margin-top:28px;position:relative;z-index:1}
.aoro-sys-final-cta-list span{font-size:13px;font-weight:600;color:rgba(255,255,255,.7);display:flex;align-items:center;gap:6px}
.aoro-sys-final-cta-list span::before{content:'✔';color:#a0ffd4}

/* ── RESPONSIVE ── */
@media(max-width:960px){
  .aoro-sys-hero-content{padding:32px 28px 36px}
  .aoro-sys-notsure-inner{grid-template-columns:1fr}
  .aoro-sys-battery-grid{grid-template-columns:1fr}
  .aoro-sys-warning-grid{grid-template-columns:1fr}
  .aoro-sys-stats{grid-template-columns:repeat(2,1fr)}
  .aoro-sys-notsure{padding:36px 28px}
  .aoro-sys-included{padding:30px 24px}
  .aoro-sys-warning{padding:30px 24px}
  .aoro-sys-final-cta{padding:44px 28px}
}
@media(max-width:640px){
  .aoro-sys-hero{min-height:400px}
  .aoro-systems-grid{grid-template-columns:1fr}
  .aoro-sys-hero-btns{flex-direction:column}
  .aoro-sys-battery-img{height:180px}
  .aoro-sys-stats{grid-template-columns:repeat(2,1fr)}
}