/*
Theme Name: Adriatic Containers
Theme URI: https://adriatic-containers.com
Author: Adriatic Containers
Author URI: https://adriatic-containers.com
Description: Ultra-modern industrial theme for Adriatic Containers – Montenegro's premier container supplier.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: adriatic-containers
Tags: e-commerce, industrial, modern, containers, woocommerce
*/

/* ============================================================
   IMPORTS & FONTS
   ============================================================ */
   @import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,300&display=swap');

   /* ============================================================
      CSS VARIABLES
      ============================================================ */
   :root {
     --color-navy:       #0D1B2E;
     --color-navy-mid:   #1A2B4C;
     --color-navy-light: #243654;
     --color-orange:     #FF6B00;
     --color-orange-hot: #FF8C2A;
     --color-steel:      #F4F4F6;
     --color-steel-mid:  #E8E9EF;
     --color-white:      #FFFFFF;
     --color-text:       #1C1C2E;
     --color-muted:      #6B7280;
     --color-border:     #D1D5DB;
   
     --font-display: 'Poppins', sans-serif;
     --font-body:    'DM Sans', sans-serif;
   
     --space-xs:  0.5rem;
     --space-sm:  1rem;
     --space-md:  1.5rem;
     --space-lg:  2.5rem;
     --space-xl:  4rem;
     --space-2xl: 6rem;
     --space-3xl: 9rem;
   
     --radius-sm: 4px;
     --radius-md: 8px;
     --radius-lg: 16px;
     --radius-xl: 24px;
   
     --shadow-sm:  0 1px 3px rgba(13,27,46,.06);
     --shadow-md:  0 4px 16px rgba(13,27,46,.10);
     --shadow-lg:  0 10px 40px rgba(13,27,46,.14);
     --shadow-cta: 0 4px 20px rgba(255,107,0,.35);
   
     --transition-fast:   150ms cubic-bezier(.4,0,.2,1);
     --transition-normal: 300ms cubic-bezier(.4,0,.2,1);
     --transition-slow:   500ms cubic-bezier(.4,0,.2,1);
   
     --container-max: 1280px;
     --container-pad: clamp(1.25rem, 5vw, 3rem);
     --header-h:      72px;
   }
   
   /* ============================================================
      RESET & BASE
      ============================================================ */
   *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
   html { scroll-behavior: smooth; font-size: 16px; -webkit-text-size-adjust: 100%; }
   body {
     font-family: var(--font-body);
     font-size: 1rem;
     line-height: 1.65;
     color: var(--color-text);
     background: var(--color-white);
     -webkit-font-smoothing: antialiased;
     overflow-x: hidden;
   }
   img, video { display: block; max-width: 100%; height: auto; }
   a { color: inherit; text-decoration: none; }
   ul, ol { list-style: none; }
   button { cursor: pointer; border: none; background: none; font-family: inherit; }
   
   /* ============================================================
      UTILITIES
      ============================================================ */
   .container {
     width: 100%;
     max-width: var(--container-max);
     margin-inline: auto;
     padding-inline: var(--container-pad);
   }
   .section { padding-block: var(--space-3xl); }
   .section--tight { padding-block: var(--space-xl); }
   .section--dark { background: var(--color-navy); color: var(--color-white); }
   .section--steel { background: var(--color-steel); }
   
   .section-label {
     display: inline-flex;
     align-items: center;
     gap: .5rem;
     font-family: var(--font-display);
     font-size: .75rem;
     font-weight: 500;
     letter-spacing: .15em;
     text-transform: uppercase;
     color: var(--color-orange);
     margin-bottom: var(--space-sm);
   }
   .section-label::before {
     content: '';
     display: block;
     width: 24px;
     height: 2px;
     background: var(--color-orange);
     flex-shrink: 0;
   }
   .section-title {
     font-family: var(--font-display);
     font-size: clamp(2rem, 4vw, 3.25rem);
     font-weight: 700;
     line-height: 1.1;
     letter-spacing: -.02em;
     color: var(--color-navy);
   }
   .section-title--light { color: var(--color-white); }
   .section-subtitle {
     font-size: 1.125rem;
     color: var(--color-muted);
     max-width: 56ch;
     line-height: 1.7;
     margin-top: var(--space-sm);
   }
   .section-subtitle--light { color: rgba(255,255,255,.65); }
   .text-center { text-align: center; }
   
   /* ============================================================
      BUTTONS
      ============================================================ */
   .btn {
     display: inline-flex;
     align-items: center;
     justify-content: center;
     gap: .5rem;
     font-family: var(--font-display);
     font-size: .875rem;
     font-weight: 500;
     letter-spacing: .06em;
     text-transform: uppercase;
     padding: .875rem 2rem;
     border-radius: var(--radius-sm);
     transition: all var(--transition-normal);
     white-space: nowrap;
     position: relative;
     overflow: hidden;
   }
   .btn svg { width: 18px; height: 18px; flex-shrink: 0; }
   .btn--primary {
     background: var(--color-orange);
     color: var(--color-white);
     box-shadow: var(--shadow-cta);
   }
   .btn--primary:hover {
     background: var(--color-orange-hot);
     box-shadow: 0 6px 28px rgba(255,107,0,.5);
     transform: translateY(-1px);
   }
   .btn--outline {
     background: transparent;
     color: var(--color-white);
     border: 1.5px solid rgba(255,255,255,.35);
   }
   .btn--outline:hover {
     border-color: rgba(255,255,255,.7);
     background: rgba(255,255,255,.06);
   }
   .btn--outline-dark {
     background: transparent;
     color: var(--color-navy);
     border: 1.5px solid var(--color-navy);
   }
   .btn--outline-dark:hover {
     background: var(--color-navy);
     color: var(--color-white);
   }
   .btn--outline-light {
     background: transparent;
     color: var(--color-orange);
     border: 1.5px solid var(--color-orange);
   }
   .btn--outline-light:hover {
     background: var(--color-orange);
     color: var(--color-white);
   }
   .btn--lg { font-size: 1rem; padding: 1.1rem 2.5rem; }
   .btn--full { width: 100%; }
   
   /* ============================================================
      HEADER
      ============================================================ */
   #site-header {
     position: fixed;
     top: 0; left: 0; right: 0;
     z-index: 1000;
     height: var(--header-h);
     transition: all var(--transition-normal);
   }
   #site-header.scrolled {
     background: rgba(13,27,46,.97);
     backdrop-filter: blur(20px);
     -webkit-backdrop-filter: blur(20px);
     border-bottom: 1px solid rgba(255,255,255,.06);
     box-shadow: 0 4px 24px rgba(0,0,0,.25);
   }

   /* Solid header on all non-homepage pages (product, shop, pages, etc.) */
   body:not(.home) #site-header {
     background: rgba(13,27,46,.97);
     backdrop-filter: blur(20px);
     -webkit-backdrop-filter: blur(20px);
     border-bottom: 1px solid rgba(255,255,255,.06);
     box-shadow: 0 4px 24px rgba(0,0,0,.25);
   }
   .header__inner {
     height: var(--header-h);
     display: flex;
     align-items: center;
     justify-content: space-between;
     gap: var(--space-md);
   }
   .header__logo {
     display: flex;
     align-items: center;
     gap: .625rem;
     flex-shrink: 0;
   }
 .header__logo-img {
   display: block;
   width: auto;
   height: 50px;
   max-height: calc(var(--header-h) - 20px);
   max-width: 180px;
   object-fit: contain;
 }
 .header__logo-img--mobile {
   display: none;
 }
   .header__logo-mark {
     width: 38px; height: 38px;
     background: var(--color-orange);
     border-radius: 6px;
     display: flex;
     align-items: center;
     justify-content: center;
   }
   .header__logo-mark svg { width: 22px; height: 22px; color: var(--color-white); }
   .header__logo-text { display: flex; flex-direction: column; line-height: 1.1; }
   .header__logo-name {
     font-family: var(--font-display);
     font-weight: 700;
     font-size: 1.0625rem;
     letter-spacing: .04em;
     text-transform: uppercase;
     color: var(--color-white);
   }
   .header__logo-tagline {
     font-size: .625rem;
     letter-spacing: .18em;
     text-transform: uppercase;
     color: rgba(255,255,255,.45);
   }
   /* Phone: hidden on desktop (shown only in mobile menu) */
  .header__phone {
     display: none;
     align-items: center;
     gap: .5rem;
     font-size: .875rem;
     color: rgba(255,255,255,.7);
     font-weight: 500;
     transition: color var(--transition-fast);
   }
   .header__phone:hover { color: var(--color-white); }
   .header__phone svg { width: 16px; height: 16px; color: var(--color-orange); }
   .header__nav { display: flex; align-items: center; gap: var(--space-md); }
   .nav__menu { display: flex; align-items: center; gap: var(--space-sm); }
   .nav__item a {
     font-family: var(--font-display);
     font-size: .8125rem;
     font-weight: 400;
     letter-spacing: .08em;
     text-transform: uppercase;
     color: rgba(255,255,255,.75);
     padding: .375rem .625rem;
     border-radius: var(--radius-sm);
     transition: color var(--transition-fast);
     position: relative;
   }
   .nav__item a::after {
     content: '';
     position: absolute;
     bottom: -2px;
     left: .625rem; right: .625rem;
     height: 2px;
     background: var(--color-orange);
     transform: scaleX(0);
     transition: transform var(--transition-normal);
     transform-origin: left;
   }
  .nav__item a:hover,
  .nav__item.current-menu-item a { color: var(--color-white); }
  .nav__item a:hover::after,
  .nav__item.current-menu-item a::after { transform: scaleX(1); }

  /* Mega replaces WP flyout: empty/hidden sub-trees still steal pointer events otherwise */
  li.ac-nav-products-trigger > .sub-menu {
    display: none !important;
  }

  /* Products mega-menu: opened via .ac-nav-dropdown--open (JS), not :hover — avoids pointer-events / gap bugs */
  .nav-dropdown {
    position: relative;
  }
  /* Single hover hitbox: link + panel (JS wraps both in .ac-products-mega-wrap) */
  .ac-products-mega-wrap {
    position: relative;
    display: inline-flex;
    align-items: center;
    max-width: 100%;
  }
  .nav-dropdown .ac-products-mega-wrap > a {
    display: inline-flex !important;
    align-items: center;
    gap: 0.35rem;
  }
  /* Keep orange rule visible while mega is open (cursor on panel is not :hover on the link) */
  .nav-dropdown.ac-nav-dropdown--open > .ac-products-mega-wrap > a::after {
    transform: scaleX(1);
  }
  .nav-dropdown .dropdown-arrow {
    flex-shrink: 0;
    display: block;
    color: currentColor;
    opacity: 0.92;
    transition: transform 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  }
  .nav-dropdown.ac-nav-dropdown--open .dropdown-arrow {
    transform: rotate(180deg);
  }
  /* Outer shell: transparent top padding = continuous hover path from link to card */
  .nav-dropdown__content {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    padding-top: 10px;
    min-width: 280px;
    z-index: 100;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.15s ease, visibility 0.15s ease;
  }
  .nav-dropdown.ac-nav-dropdown--open .nav-dropdown__content {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }
  .nav-dropdown__grid {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 6px;
    background: rgba(13,27,46,.98);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-radius: 8px;
    border: 1px solid rgba(255,255,255,.08);
    box-shadow: 0 8px 32px rgba(0,0,0,.35), 0 2px 8px rgba(0,0,0,.2);
  }
  .nav-dropdown__item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    border-radius: 6px;
    transition: all var(--transition-fast);
    background: transparent;
  }
  .nav-dropdown__item:hover {
    background: rgba(255,255,255,.06);
  }
  .nav-dropdown__icon {
    width: 32px;
    height: 32px;
    border-radius: 6px;
    background: rgba(255,255,255,.06);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: all var(--transition-fast);
  }
  .nav-dropdown__item:hover .nav-dropdown__icon {
    background: rgba(255,255,255,.1);
    transform: scale(1.05);
  }
  .nav-dropdown__icon svg {
    width: 16px;
    height: 16px;
  }
  .nav-dropdown__text {
    flex: 1;
  }
  .nav-dropdown__title {
    font-family: var(--font-display);
    font-size: .8125rem;
    font-weight: 600;
    color: var(--color-white);
    line-height: 1.3;
    margin-bottom: 1px;
  }
  .nav-dropdown__desc {
    font-size: .6875rem;
    color: rgba(255,255,255,.5);
    line-height: 1.3;
  }

  .header__cta { display: flex; align-items: center; gap: .75rem; }

   /* Mobile icons container (account + cart + hamburger) */
   .header__mobile-icons {
     display: none;
     align-items: center;
     gap: .25rem;
   }
   .header__mobile-icon {
     display: flex;
     align-items: center;
     justify-content: center;
     width: 36px;
     height: 36px;
     border-radius: var(--radius-sm);
     color: rgba(255,255,255,.75);
     transition: color var(--transition-fast), background var(--transition-fast);
   }
   .header__mobile-icon:hover {
     color: var(--color-white);
     background: rgba(255,255,255,.08);
   }
   .header__mobile-icon svg {
     width: 20px;
     height: 20px;
   }
   .header__mobile-cart {
     position: relative;
   }
   .header__mobile-cart-count {
     position: absolute;
     top: 2px;
     right: 2px;
     min-width: 16px;
     height: 16px;
     padding: 0 4px;
     background: var(--color-orange);
     color: var(--color-white);
     font-family: var(--font-display);
     font-size: .625rem;
     font-weight: 700;
     line-height: 16px;
     text-align: center;
     border-radius: 100px;
   }

   .hamburger {
     display: none;
     flex-direction: column;
     justify-content: center;
     align-items: center;
     gap: 5px;
     width: 40px; height: 40px;
     cursor: pointer;
     padding: 8px;
     border-radius: var(--radius-sm);
     transition: background var(--transition-fast);
   }
   .hamburger:hover { background: rgba(255,255,255,.08); }
   .hamburger__bar {
     display: block;
     width: 22px; height: 2px;
     background: var(--color-white);
     border-radius: 2px;
     transition: all var(--transition-normal);
   }
   .hamburger.active .hamburger__bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
   .hamburger.active .hamburger__bar:nth-child(2) { opacity: 0; transform: scaleX(0); }
   .hamburger.active .hamburger__bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
   
   /* Mobile Menu */
   .mobile-menu {
     display: none;
     position: fixed;
     top: var(--header-h);
     left: 0; right: 0; bottom: 0;
     background: var(--color-navy);
     z-index: 999;
     padding: var(--space-lg) var(--container-pad);
     flex-direction: column;
     gap: var(--space-lg);
     overflow-y: auto;
     transform: translateX(100%);
     transition: transform var(--transition-normal);
   }
   .mobile-menu.open { display: flex; transform: translateX(0); }
  .mobile-menu__nav { display: flex; flex-direction: column; gap: .25rem; }
  .mobile-menu__nav a {
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 600;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: rgba(255,255,255,.75);
    padding: .75rem 0;
    border-bottom: 1px solid rgba(255,255,255,.06);
    display: block;
    transition: color var(--transition-fast);
  }
  .mobile-menu__nav a:hover { color: var(--color-orange); }

  /* Mobile Products Section */
  .mobile-menu__products {
    margin-top: var(--space-md);
    padding-top: var(--space-md);
    border-top: 2px solid rgba(255,255,255,.1);
  }
  .mobile-menu__label {
    font-family: var(--font-display);
    font-size: .75rem;
    font-weight: 600;
    letter-spacing: .15em;
    text-transform: uppercase;
    color: rgba(255,255,255,.4);
    margin-bottom: var(--space-sm);
  }
  .mobile-menu__product-link {
    display: block;
    font-family: var(--font-display);
    font-size: 1.125rem;
    font-weight: 500;
    color: rgba(255,255,255,.7);
    padding: .625rem 0;
    padding-left: var(--space-sm);
    border-left: 2px solid transparent;
    transition: all var(--transition-fast);
  }
  .mobile-menu__product-link:hover {
    color: var(--color-white);
    border-left-color: var(--color-orange);
    padding-left: var(--space-md);
  }

  .mobile-menu__actions {
     display: flex;
     flex-direction: column;
     gap: .75rem;
     margin-top: auto;
     padding-bottom: 6rem;
   }
   .mobile-menu__actions .btn { width: 100%; padding: 1rem; font-size: 1rem; }
   
   /* WPML */
   .wpml-ls-statics-shortcode_actions { margin-left: var(--space-sm); }
   .wpml-ls-statics-shortcode_actions a {
     font-family: var(--font-display);
     font-size: .75rem;
     font-weight: 500;
     letter-spacing: .08em;
     text-transform: uppercase;
     color: rgba(255,255,255,.5);
     transition: color var(--transition-fast);
   }
   .wpml-ls-statics-shortcode_actions a:hover { color: var(--color-white); }
   
   /* ============================================================
      HERO
      ============================================================ */
   .hero {
     min-height: 100vh;
     min-height: 100svh;
     position: relative;
     overflow: hidden;
     background: var(--color-navy);
     display: flex;
     flex-direction: column;
   }
   .hero__bg { position: absolute; inset: 0; z-index: 0; }
   .hero__bg-img { width: 100%; height: 100%; object-fit: cover; object-position: center; }
   .hero__bg-overlay {
     position: absolute; inset: 0;
     background: linear-gradient(105deg, rgba(13,27,46,.93) 0%, rgba(13,27,46,.72) 55%, rgba(13,27,46,.28) 100%);
   }
   .hero__bg-accent {
     position: absolute;
     bottom: -1px; left: 0; right: 0;
     height: 200px;
     background: linear-gradient(to bottom, transparent, var(--color-navy));
     z-index: 1;
   }
   .hero__inner {
     position: relative;
     z-index: 2;
     display: flex;
     flex-direction: column;
     justify-content: center;
     padding-top: calc(var(--header-h) + var(--space-2xl));
     padding-bottom: var(--space-2xl);
     min-height: 100vh;
     min-height: 100svh;
   }
   .hero__content { max-width: 720px; }
   .hero__eyebrow {
     display: inline-flex;
     align-items: center;
     gap: .625rem;
     background: rgba(255,107,0,.12);
     border: 1px solid rgba(255,107,0,.25);
     padding: .375rem .875rem;
     border-radius: 100px;
     margin-bottom: var(--space-lg);
     animation: fadeInUp .6s ease both;
   }
   .hero__eyebrow svg { width: 14px; height: 14px; color: var(--color-orange); }
   .hero__eyebrow-text {
     font-size: .75rem;
     font-weight: 500;
     letter-spacing: .12em;
     text-transform: uppercase;
     color: var(--color-orange);
   }
   .hero__title {
     font-family: var(--font-display);
     font-size: clamp(3rem, 7vw, 5.5rem);
     font-weight: 700;
     line-height: 1.0;
     letter-spacing: -.025em;
     color: var(--color-white);
     margin-bottom: var(--space-md);
     animation: fadeInUp .6s .1s ease both;
   }
   .hero__title em { font-style: normal; color: var(--color-orange); }
   .hero__subtitle {
     font-size: clamp(1rem, 2vw, 1.25rem);
     color: rgba(255,255,255,.65);
     line-height: 1.7;
     max-width: 52ch;
     margin-bottom: var(--space-lg);
     font-weight: 300;
     animation: fadeInUp .6s .2s ease both;
   }
   .hero__actions {
     display: flex;
     align-items: center;
     gap: var(--space-sm);
     flex-wrap: wrap;
     animation: fadeInUp .6s .3s ease both;
   }
   .hero__stats {
     display: flex;
     gap: var(--space-xl);
     margin-top: var(--space-2xl);
     padding-top: var(--space-lg);
     border-top: 1px solid rgba(255,255,255,.08);
     animation: fadeInUp .6s .4s ease both;
   }
   .hero__stat-number {
     font-family: var(--font-display);
     font-size: 2.25rem;
     font-weight: 700;
     color: var(--color-white);
     line-height: 1;
     letter-spacing: -.02em;
   }
   .hero__stat-number span { color: var(--color-orange); }
   .hero__stat-label {
     font-size: .8125rem;
     color: rgba(255,255,255,.45);
     letter-spacing: .06em;
     text-transform: uppercase;
     margin-top: .25rem;
   }
   .hero__scroll {
     position: absolute;
     bottom: 3rem; right: var(--container-pad);
     z-index: 2;
     display: flex;
     flex-direction: column;
     align-items: center;
     gap: .5rem;
     animation: fadeIn 1s .8s ease both;
   }
   .hero__scroll-line {
     width: 1px; height: 60px;
     background: linear-gradient(to bottom, rgba(255,255,255,.4), transparent);
     animation: scrollLine 2s ease infinite;
   }
   .hero__scroll-text {
     font-size: .625rem;
     letter-spacing: .2em;
     text-transform: uppercase;
     color: rgba(255,255,255,.3);
     writing-mode: vertical-rl;
   }
   
   /* ============================================================
      TRUST BAR
      ============================================================ */
   .trust-bar {
     background: var(--color-navy-light);
     border-top: 1px solid rgba(255,255,255,.06);
     border-bottom: 1px solid rgba(255,255,255,.04);
     padding-block: 1.25rem;
   }
   .trust-bar__inner {
     display: flex;
     align-items: center;
     justify-content: space-between;
     gap: var(--space-md);
     flex-wrap: wrap;
   }
   .trust-item { display: flex; align-items: center; gap: .75rem; flex: 1; min-width: 180px; }
   .trust-item__icon {
     width: 40px; height: 40px;
     background: rgba(255,107,0,.12);
     border-radius: var(--radius-md);
     display: flex; align-items: center; justify-content: center;
     flex-shrink: 0;
   }
   .trust-item__icon svg { width: 20px; height: 20px; color: var(--color-orange); }
   .trust-item__title {
     font-family: var(--font-display);
     font-size: .875rem;
     font-weight: 600;
     letter-spacing: .02em;
     color: var(--color-white);
     line-height: 1.2;
   }
   .trust-item__sub { font-size: .75rem; color: rgba(255,255,255,.45); margin-top: .125rem; }
   .trust-bar__divider { width: 1px; height: 36px; background: rgba(255,255,255,.08); flex-shrink: 0; }
   
   /* ============================================================
      CATEGORIES — full-bleed horizontal showcase (WooCommerce)
      ============================================================ */
   .section--categories { overflow: hidden; }
   .categories__header {
     text-align: center;
     max-width: 720px;
     margin-inline: auto;
     margin-bottom: var(--space-xl);
   }
   .cat-showcase {
     width: 100vw;
     margin-inline: calc(50% - 50vw);
     padding-bottom: var(--space-md);
   }
   .cat-showcase__toolbar {
     display: flex;
     align-items: center;
     justify-content: space-between;
     gap: var(--space-md);
     flex-wrap: wrap;
     margin-bottom: var(--space-md);
   }
   .cat-showcase__hint {
     font-family: var(--font-display);
     font-size: .75rem;
     font-weight: 500;
     letter-spacing: .12em;
     text-transform: uppercase;
     color: var(--color-muted);
     margin: 0;
   }
   .cat-showcase__nav { display: flex; gap: .5rem; }
   .cat-showcase__btn {
     width: 48px; height: 48px;
     border-radius: 50%;
     display: flex; align-items: center; justify-content: center;
     background: var(--color-white);
     color: var(--color-navy);
     border: 1px solid var(--color-border);
     box-shadow: var(--shadow-sm);
     transition: transform var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast), color var(--transition-fast);
   }
   .cat-showcase__btn:hover {
     background: var(--color-navy);
     color: var(--color-white);
     border-color: transparent;
     box-shadow: var(--shadow-md);
     transform: scale(1.04);
   }
   .cat-showcase__btn svg { width: 22px; height: 22px; }
   .cat-showcase__scroll {
     overflow-x: auto;
     overflow-y: hidden;
     -webkit-overflow-scrolling: touch;
     scroll-snap-type: x mandatory;
     scroll-padding-inline: max(var(--container-pad), calc((100vw - var(--container-max)) / 2 + var(--container-pad)));
     outline: none;
   }
   .cat-showcase__scroll:focus-visible {
     box-shadow: inset 0 0 0 2px var(--color-orange);
     border-radius: var(--radius-md);
   }
   .cat-showcase__track {
     display: flex;
     gap: clamp(.875rem, 2vw, 1.25rem);
     padding-inline: max(var(--container-pad), calc((100vw - var(--container-max)) / 2 + var(--container-pad)));
     padding-block: .25rem 1rem;
     min-height: 1px;
   }
   .cat-showcase__card {
     position: relative;
     flex: 0 0 min(960px, calc(70vw - 2.75rem));
     scroll-snap-align: start;
     min-height: clamp(280px, 42vw, 400px);
     border-radius: var(--radius-xl);
     overflow: hidden;
     display: block;
     background-color: var(--color-navy);
     background-image: var(--cat-bg);
     background-size: cover;
     background-position: center;
     box-shadow: 0 24px 64px rgba(13,27,46,.12), 0 4px 16px rgba(13,27,46,.06);
     transition: transform var(--transition-normal), box-shadow var(--transition-normal);
   }
   .cat-showcase__card::before {
     content: '';
     position: absolute; inset: 0;
     background: linear-gradient(105deg, rgba(13,27,46,.82) 0%, rgba(13,27,46,.45) 42%, rgba(13,27,46,.25) 100%);
     z-index: 0;
     transition: opacity var(--transition-normal);
   }
   .cat-showcase__card:hover {
     transform: translateY(-4px) scale(1.01);
     box-shadow: 0 32px 80px rgba(13,27,46,.16), 0 8px 24px rgba(13,27,46,.08);
   }
   .cat-showcase__card:hover::before {
     opacity: .92;
   }
   .cat-showcase__card-inner {
     position: relative;
     z-index: 1;
     height: 100%;
     min-height: inherit;
     display: flex;
     flex-direction: column;
     justify-content: flex-end;
     align-items: flex-start;
     padding: clamp(1.75rem, 4vw, 3rem);
     max-width: 36rem;
   }
   .cat-showcase__eyebrow {
     display: inline-block;
     font-family: var(--font-display);
     font-size: .6875rem;
     font-weight: 600;
     letter-spacing: .2em;
     text-transform: uppercase;
     color: rgba(255,255,255,.55);
     margin-bottom: .75rem;
   }
   .cat-showcase__title {
     font-family: var(--font-display);
     font-size: clamp(1.75rem, 3.5vw, 2.75rem);
     font-weight: 600;
     letter-spacing: -.03em;
     line-height: 1.08;
     color: var(--color-white);
     margin-bottom: .75rem;
   }
   .cat-showcase__desc {
     font-size: clamp(.9375rem, 1.5vw, 1.0625rem);
     line-height: 1.55;
     color: rgba(255,255,255,.72);
     margin-bottom: var(--space-lg);
     max-width: 40ch;
   }
   .cat-showcase__cta {
     display: inline-flex;
     align-items: center;
     gap: .625rem;
     font-family: var(--font-display);
     font-size: .8125rem;
     font-weight: 500;
     letter-spacing: .1em;
     text-transform: uppercase;
     color: var(--color-white);
     padding: .625rem 0;
     border-bottom: 1px solid rgba(255,255,255,.35);
     transition: gap var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);
   }
   .cat-showcase__card:hover .cat-showcase__cta {
     gap: 1rem;
     border-color: var(--color-orange);
     color: var(--color-orange);
   }
   .cat-showcase__cta svg {
     width: 18px; height: 18px;
     transition: transform var(--transition-fast);
   }
   .cat-showcase__card:hover .cat-showcase__cta svg { transform: translateX(5px); }
   .cat-showcase__scroll::-webkit-scrollbar { height: 6px; }
   .cat-showcase__scroll::-webkit-scrollbar-track { background: rgba(13,27,46,.06); border-radius: 100px; }
   .cat-showcase__scroll::-webkit-scrollbar-thumb { background: rgba(13,27,46,.2); border-radius: 100px; }
   @media (prefers-reduced-motion: reduce) {
     .cat-showcase__card { transition: none; }
     .cat-showcase__card:hover { transform: none; }
   }
   
   /* ============================================================
      PRODUCT CARDS / WOOCOMMERCE
      ============================================================ */
   ul.products {
     display: grid;
     grid-template-columns: repeat(3, 1fr);
     gap: var(--space-md);
     list-style: none;
     margin: 0; padding: 0;
   }
   ul.products li.product {
     background: var(--color-white);
     border: 1px solid var(--color-border);
     border-radius: var(--radius-lg);
     overflow: hidden;
     transition: all var(--transition-normal);
     display: flex;
     flex-direction: column;
     position: relative;
   }
   ul.products li.product:hover {
     border-color: rgba(255,107,0,.3);
     box-shadow: var(--shadow-lg);
     transform: translateY(-4px);
   }
   ul.products li.product .woocommerce-LoopProduct-link { display: block; overflow: hidden; }
   ul.products li.product img {
     width: 100%;
     aspect-ratio: 4/3;
     object-fit: cover;
     transition: transform var(--transition-slow);
   }
   ul.products li.product:hover img { transform: scale(1.04); }
   ul.products li.product .product-content { padding: var(--space-md); display: flex; flex-direction: column; flex: 1; }
   ul.products li.product .woocommerce-loop-product__title,
   ul.products li.product h2 {
     font-family: var(--font-display);
     font-size: 1.125rem;
     font-weight: 600;
     color: var(--color-navy);
     line-height: 1.25;
     margin-bottom: .5rem;
     letter-spacing: .01em;
   }
   .product-specs { display: flex; flex-direction: column; gap: .375rem; margin-block: var(--space-sm); flex: 1; }
   .product-spec { display: flex; align-items: center; gap: .5rem; font-size: .8125rem; color: var(--color-muted); }
   .product-spec svg { width: 14px; height: 14px; color: var(--color-orange); flex-shrink: 0; }
   ul.products li.product .price {
     font-family: var(--font-display);
     font-size: 1.375rem;
     font-weight: 700;
     color: var(--color-navy);
     display: block;
     margin-bottom: var(--space-sm);
   }
   ul.products li.product .button,
   ul.products li.product .add_to_cart_button {
     display: inline-flex;
     align-items: center;
     justify-content: center;
     gap: .5rem;
     width: 100%;
     padding: .875rem var(--space-md);
     background: var(--color-orange);
     color: var(--color-white);
     font-family: var(--font-display);
     font-size: .8125rem;
     font-weight: 500;
     letter-spacing: .06em;
     text-transform: uppercase;
     border-radius: var(--radius-sm);
     border: none;
     transition: all var(--transition-normal);
     box-shadow: var(--shadow-cta);
   }
   ul.products li.product .button:hover {
     background: var(--color-orange-hot);
     transform: translateY(-1px);
     box-shadow: 0 6px 24px rgba(255,107,0,.45);
   }
   .product-badge {
     position: absolute;
     top: .875rem; left: .875rem;
     background: var(--color-navy);
     color: var(--color-white);
     font-size: .6875rem;
     font-weight: 600;
     letter-spacing: .1em;
     text-transform: uppercase;
     padding: .25rem .625rem;
     border-radius: 100px;
     z-index: 2;
   }
   .product-badge--new { background: var(--color-orange); }
   
   /* ============================================================
      WHY ADRIATIC / USP
      ============================================================ */
   .why-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3xl); align-items: center; }
   .why-image { position: relative; border-radius: var(--radius-xl); overflow: hidden; }
   .why-image img { width: 100%; aspect-ratio: 4/5; object-fit: cover; }
   .why-image__badge {
     position: absolute;
     bottom: var(--space-lg); right: var(--space-lg);
     background: var(--color-orange);
     color: var(--color-white);
     border-radius: var(--radius-md);
     padding: 1rem 1.25rem;
     text-align: center;
     min-width: 110px;
   }
   .why-image__badge-number { font-family: var(--font-display); font-size: 2.5rem; font-weight: 700; line-height: 1; display: block; }
   .why-image__badge-text { font-size: .75rem; letter-spacing: .08em; text-transform: uppercase; opacity: .85; margin-top: .25rem; }
   .why-features { display: flex; flex-direction: column; gap: var(--space-md); margin-top: var(--space-lg); }
   .why-feature { display: flex; gap: var(--space-md); align-items: flex-start; }
   .why-feature__icon {
     width: 48px; height: 48px;
     background: rgba(255,107,0,.08);
     border: 1px solid rgba(255,107,0,.15);
     border-radius: var(--radius-md);
     display: flex; align-items: center; justify-content: center;
     flex-shrink: 0;
   }
   .why-feature__icon svg { width: 22px; height: 22px; color: var(--color-orange); }
   .why-feature__title { font-family: var(--font-display); font-size: 1rem; font-weight: 600; color: var(--color-navy); margin-bottom: .25rem; }
   .why-feature__desc { font-size: .9375rem; color: var(--color-muted); line-height: 1.6; }
   
   /* ============================================================
      PROCESS
      ============================================================ */
   .process-header { text-align: center; max-width: 600px; margin-inline: auto; margin-bottom: var(--space-2xl); }
   .process-steps {
     display: grid;
     grid-template-columns: repeat(4, 1fr);
     gap: var(--space-md);
     position: relative;
   }
   .process-steps::before {
     content: '';
     position: absolute;
     top: 2rem;
     left: calc(12.5% + 1.5rem);
     right: calc(12.5% + 1.5rem);
     height: 1px;
     background: linear-gradient(to right, transparent, rgba(255,107,0,.3), rgba(255,107,0,.3), transparent);
     z-index: 0;
   }
   .process-step { text-align: center; position: relative; z-index: 1; }
   .process-step__number {
     width: 4rem; height: 4rem;
     background: var(--color-white);
     border: 2px solid var(--color-border);
     border-radius: 50%;
     display: flex; align-items: center; justify-content: center;
     margin: 0 auto var(--space-md);
     font-family: var(--font-display);
     font-size: 1.125rem; font-weight: 700;
     color: var(--color-navy);
     transition: all var(--transition-normal);
   }
   .process-step:hover .process-step__number {
     background: var(--color-orange);
     border-color: var(--color-orange);
     color: var(--color-white);
     box-shadow: var(--shadow-cta);
   }
   .process-step__icon { margin-bottom: .75rem; }
   .process-step__icon svg { width: 28px; height: 28px; color: var(--color-orange); }
   .process-step__title { font-family: var(--font-display); font-size: 1rem; font-weight: 600; color: var(--color-navy); margin-bottom: .5rem; }
   .process-step__desc { font-size: .875rem; color: var(--color-muted); line-height: 1.6; }
   
   /* ============================================================
      TESTIMONIALS — Marquee
      ============================================================ */
   .testimonials-section {
     background: var(--color-navy);
     position: relative;
     overflow: hidden;
     padding-bottom: var(--space-2xl);
   }
   .testimonials-section::before {
     content: '';
     position: absolute;
     top: -100px; right: -100px;
     width: 600px; height: 600px;
     background: radial-gradient(circle, rgba(255,107,0,.06) 0%, transparent 70%);
     pointer-events: none;
   }
   .testimonials-header {
     text-align: center;
     max-width: 680px;
     margin-inline: auto;
     margin-bottom: var(--space-xl);
   }

   /* ── Aggregate rating ── */
   .tmc-aggregate {
     display: flex;
     align-items: center;
     justify-content: center;
     gap: .5rem;
     flex-wrap: wrap;
     margin-top: var(--space-md);
   }
   .tmc-aggregate__stars { display: flex; gap: 3px; }
   .tmc-aggregate__stars svg {
     width: 20px; height: 20px;
     fill: rgba(255,255,255,.2);
     stroke: none;
   }
   .tmc-aggregate__stars svg.filled { fill: var(--color-orange); }
   .tmc-aggregate__score {
     font-family: var(--font-display);
     font-size: 1.25rem;
     font-weight: 700;
     color: var(--color-white);
   }
   .tmc-aggregate__sep  { color: rgba(255,255,255,.4); font-size: .9375rem; }
   .tmc-aggregate__count { font-size: .875rem; color: rgba(255,255,255,.5); }

   /* ── Marquee track ── */
   @keyframes tmc-scroll-left {
     0%   { transform: translateX(0); }
     100% { transform: translateX(-50%); }
   }
   @keyframes tmc-scroll-right {
     0%   { transform: translateX(-50%); }
     100% { transform: translateX(0); }
   }

   .tmc-track {
     overflow: hidden;
     margin-bottom: var(--space-md);
     /* Edge fade — cards disappear smoothly on both sides */
     -webkit-mask-image: linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
     mask-image:         linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
   }

   .tmc-track__inner {
     display: flex;
     gap: var(--space-md);
     width: max-content;
     will-change: transform;
   }
   .tmc-track__inner--left  { animation: tmc-scroll-left  400s linear infinite; }
   .tmc-track__inner--right { animation: tmc-scroll-right 440s linear infinite; }

   /* Pause on hover/focus-within for accessibility */
   .tmc-track:hover .tmc-track__inner,
   .tmc-track:focus-within .tmc-track__inner { animation-play-state: paused; }

   /* Respect prefers-reduced-motion */
   @media (prefers-reduced-motion: reduce) {
     .tmc-track__inner { animation: none !important; }
     .tmc-track { overflow-x: auto; -webkit-mask-image: none; mask-image: none; }
   }

   /* ── Individual card ── */
   .tmc-card {
     flex-shrink: 0;
     width: 280px;
     background: rgba(255,255,255,.05);
     border: 1px solid rgba(255,255,255,.07);
     border-radius: var(--radius-lg);
     padding: var(--space-md);
     display: flex;
     flex-direction: column;
     gap: .625rem;
   }

   .tmc-card__top { display: flex; flex-direction: column; gap: .25rem; }

   .tmc-stars { display: flex; gap: 2px; }
   .tmc-stars svg {
     width: 14px; height: 14px;
     fill: rgba(255,255,255,.2);
     stroke: none;
   }
   .tmc-stars svg.filled { fill: var(--color-orange); }

   .tmc-card__title {
     font-family: var(--font-display);
     font-size: .875rem;
     font-weight: 600;
     color: var(--color-white);
     margin: 0;
   }

   .tmc-card__body {
     font-size: .8125rem;
     color: rgba(255,255,255,.65);
     line-height: 1.65;
     font-style: italic;
     margin: 0;
     flex: 1;
   }

   .tmc-card__author {
     display: flex;
     align-items: center;
     gap: .625rem;
     margin-top: auto;
   }

   .tmc-avatar {
     width: 36px; height: 36px;
     border-radius: 50%;
     background: rgba(255,255,255,.08);
     display: flex; align-items: center; justify-content: center;
     font-family: var(--font-display);
     font-weight: 700;
     font-size: .75rem;
     color: var(--color-orange);
     flex-shrink: 0;
   }

   .tmc-name {
     font-family: var(--font-display);
     font-size: .8125rem;
     font-weight: 600;
     color: rgba(255,255,255,.9);
   }
   .tmc-country { font-size: .75rem; color: rgba(255,255,255,.35); margin-top: .1rem; }

   /* ── Card hover glow (subtle) ── */
   .tmc-card {
     cursor: default;
     transition: border-color .25s ease, box-shadow .25s ease, transform .25s ease;
   }
   .tmc-card:hover {
     border-color: rgba(255, 107, 0, .35);
     box-shadow: 0 0 0 1px rgba(255,107,0,.12), 0 8px 30px rgba(0,0,0,.35);
     transform: translateY(-3px) scale(1.02);
     z-index: 2;
   }

   /* ── Review bubble ── */
   #tmc-bubble {
     --tmcb-arrow: 50%;
     position: absolute;
     z-index: 99999;
     width: 340px;
     background: rgba(8, 17, 36, 0.88);
     backdrop-filter: blur(28px) saturate(180%);
     -webkit-backdrop-filter: blur(28px) saturate(180%);
     border: 1px solid rgba(255, 107, 0, .22);
     border-radius: 20px;
     padding: 1.25rem 1.375rem 1.125rem;
     pointer-events: none;
     opacity: 0;
     transform: translateY(calc(-100% - 18px)) scale(.94);
     transform-origin: bottom center;
     transition: opacity .22s ease, transform .28s cubic-bezier(.16,1,.3,1);
     box-shadow:
       0 4px 6px rgba(0,0,0,.12),
       0 16px 48px rgba(0,0,0,.55),
       0 0 0 1px rgba(255,255,255,.04),
       inset 0 1px 0 rgba(255,255,255,.06);
   }
   #tmc-bubble.is-visible {
     opacity: 1;
     transform: translateY(calc(-100% - 14px)) scale(1);
     pointer-events: auto;
   }
   /* Arrow pointing downward to the card */
   #tmc-bubble::after {
     content: '';
     position: absolute;
     bottom: -8px;
     left: var(--tmcb-arrow, 50%);
     transform: translateX(-50%) rotate(45deg);
     width: 15px; height: 15px;
     background: rgba(8, 17, 36, 0.88);
     border-right: 1px solid rgba(255,107,0,.22);
     border-bottom: 1px solid rgba(255,107,0,.22);
     border-radius: 0 0 4px 0;
   }
   /* Animated ambient glow blob */
   .tmcb-glow {
     position: absolute;
     inset: 0;
     border-radius: inherit;
     background: radial-gradient(ellipse at 60% 0%, rgba(255,107,0,.12) 0%, transparent 65%);
     pointer-events: none;
   }
   /* Stars inside bubble */
   .tmcb-stars {
     display: flex;
     gap: 3px;
     margin-bottom: .625rem;
   }
   .tmcb-stars svg {
     width: 14px; height: 14px;
     fill: rgba(255,255,255,.18);
     stroke: none;
   }
   .tmcb-stars svg.filled { fill: var(--color-orange, #FF6B00); }

   /* Title */
   .tmcb-title {
     font-family: var(--font-display);
     font-size: .875rem;
     font-weight: 600;
     color: #fff;
     margin: 0 0 .5rem;
     line-height: 1.3;
   }
   /* Body */
   .tmcb-body {
     font-size: .8125rem;
     color: rgba(255,255,255,.72);
     line-height: 1.7;
     font-style: italic;
     margin: 0 0 .875rem;
   }
   /* Author row */
   .tmcb-author {
     display: flex;
     align-items: center;
     gap: .625rem;
     padding-top: .75rem;
     border-top: 1px solid rgba(255,255,255,.07);
   }
   .tmcb-avatar {
     width: 34px; height: 34px;
     border-radius: 50%;
     background: rgba(255,107,0,.18);
     border: 1px solid rgba(255,107,0,.3);
     display: flex; align-items: center; justify-content: center;
     font-family: var(--font-display);
     font-weight: 700;
     font-size: .75rem;
     color: var(--color-orange, #FF6B00);
     flex-shrink: 0;
   }
   .tmcb-name {
     font-family: var(--font-display);
     font-size: .8125rem;
     font-weight: 600;
     color: rgba(255,255,255,.9);
   }

   /* Hide on touch devices (no hover) */
   @media (hover: none) {
     #tmc-bubble { display: none !important; }
   }

   /* ── Legacy classes kept for potential reuse elsewhere ── */
   .testimonial-name  { font-family: var(--font-display); font-size: .9375rem; font-weight: 600; color: var(--color-white); }
   .testimonial-role  { font-size: .8125rem; color: rgba(255,255,255,.4); margin-top: .125rem; }
   .testimonial-avatar {
     width: 44px; height: 44px;
     border-radius: 50%;
     background: rgba(255,255,255,.08);
     display: flex; align-items: center; justify-content: center;
     font-family: var(--font-display); font-weight: 700; font-size: 1rem;
     color: var(--color-orange);
     flex-shrink: 0;
     overflow: hidden;
   }
   
   /* ============================================================
      PRODUCT REVIEW STYLES (ac-reviews plugin)
      ============================================================ */

   /* Aggregate rating line under product title */
   .ac-product-rating {
     display: flex;
     align-items: center;
     gap: .5rem;
     flex-wrap: wrap;
     margin-top: .375rem;
     margin-bottom: var(--space-sm, .75rem);
   }
   .ac-product-rating .ac-star-row { display: inline-flex; gap: 2px; color: var(--color-orange, #FF6B00); }
   .ac-product-rating__score {
     font-family: var(--font-display);
     font-size: .9375rem;
     font-weight: 700;
     color: var(--color-navy, #1a2a44);
   }
   .ac-product-rating__sep,
   .ac-product-rating__max  { color: rgba(0,0,0,.35); font-size: .875rem; }
   .ac-product-rating__count { font-size: .8125rem; color: rgba(0,0,0,.45); }
   .ac-rating-link { color: inherit; text-decoration: underline dotted; }

   /* Reviews tab panel */
   .ac-reviews-tab { max-width: 900px; }

   .ac-reviews-empty { color: var(--color-muted); font-size: .9375rem; padding: var(--space-lg); }

   /* Summary block (score + bar chart) */
   .ac-reviews-summary {
     display: flex;
     gap: var(--space-xl, 3rem);
     align-items: flex-start;
     flex-wrap: wrap;
     padding: var(--space-lg, 1.5rem) 0 var(--space-xl, 3rem);
     border-bottom: 1px solid var(--color-border, #e5e7eb);
     margin-bottom: var(--space-xl, 3rem);
   }
   .ac-reviews-summary__score {
     display: flex;
     flex-direction: column;
     align-items: center;
     gap: .375rem;
     min-width: 110px;
   }
   .ac-reviews-summary__number {
     font-family: var(--font-display);
     font-size: 3rem;
     font-weight: 700;
     color: var(--color-navy, #1a2a44);
     line-height: 1;
   }
   .ac-reviews-summary__stars { color: var(--color-orange, #FF6B00); }
   .ac-reviews-summary__count { font-size: .8125rem; color: var(--color-muted); text-align: center; }

   .ac-reviews-summary__bars { flex: 1; min-width: 200px; display: flex; flex-direction: column; gap: .5rem; }
   .ac-reviews-summary__bar-row { display: flex; align-items: center; gap: .5rem; font-size: .8125rem; }
   .ac-reviews-summary__bar-label { width: 28px; color: var(--color-muted); text-align: right; flex-shrink: 0; }
   .ac-reviews-summary__bar-track {
     flex: 1;
     height: 8px;
     background: var(--color-border, #e5e7eb);
     border-radius: 4px;
     overflow: hidden;
   }
   .ac-reviews-summary__bar-fill {
     height: 100%;
     background: var(--color-orange, #FF6B00);
     border-radius: 4px;
     transition: width .4s ease;
   }
   .ac-reviews-summary__bar-count { width: 22px; color: var(--color-muted); font-size: .75rem; flex-shrink: 0; }

   /* Review list */
   .ac-reviews-list { display: flex; flex-direction: column; gap: var(--space-lg, 1.5rem); }

   .ac-review-card {
     padding: var(--space-lg, 1.5rem);
     border: 1px solid var(--color-border, #e5e7eb);
     border-radius: var(--radius-lg, 12px);
     background: var(--color-white, #fff);
   }
   .ac-review-card__header {
     display: flex;
     align-items: center;
     justify-content: space-between;
     gap: .75rem;
     margin-bottom: .5rem;
     flex-wrap: wrap;
   }
   .ac-review-card__stars { color: var(--color-orange, #FF6B00); }
   .ac-review-card__date  { font-size: .8125rem; color: var(--color-muted); }
   .ac-review-card__title {
     font-family: var(--font-display);
     font-size: .9375rem;
     font-weight: 600;
     color: var(--color-navy, #1a2a44);
     margin: 0 0 .375rem;
   }
   .ac-review-card__body {
     font-size: .9375rem;
     color: var(--color-text, #374151);
     line-height: 1.7;
     margin: 0 0 var(--space-md, 1rem);
   }
   .ac-review-card__author { display: flex; align-items: center; gap: .625rem; }
   .ac-review-card__avatar {
     width: 38px; height: 38px;
     border-radius: 50%;
     background: var(--color-steel, #e8eef4);
     display: flex; align-items: center; justify-content: center;
     font-family: var(--font-display); font-weight: 700; font-size: .75rem;
     color: var(--color-navy, #1a2a44);
     flex-shrink: 0;
   }
   .ac-review-card__name { font-family: var(--font-display); font-size: .875rem; font-weight: 600; color: var(--color-navy, #1a2a44); }
   .ac-review-card__country { font-size: .75rem; color: var(--color-muted); margin-top: .1rem; }

   /* star row util */
   .ac-star-row { display: inline-flex; gap: 2px; }

   /* ============================================================
      CTA BANNER
      ============================================================ */
   .cta-banner {
     background: var(--color-orange);
     position: relative;
     overflow: hidden;
     padding-block: var(--space-2xl);
   }
   .cta-banner::before {
     content: '';
     position: absolute;
     top: 50%; left: 50%;
     transform: translate(-50%, -50%);
     width: 800px; height: 800px;
     background: radial-gradient(circle, rgba(255,255,255,.08) 0%, transparent 65%);
     pointer-events: none;
   }
   .cta-banner::after {
     content: '';
     position: absolute; inset: 0;
     background-image: repeating-linear-gradient(-45deg, transparent, transparent 20px, rgba(0,0,0,.03) 20px, rgba(0,0,0,.03) 21px);
     pointer-events: none;
   }
   .cta-inner {
     position: relative; z-index: 1;
     display: flex;
     align-items: center;
     justify-content: space-between;
     gap: var(--space-lg);
     flex-wrap: wrap;
   }
   .cta-title {
     font-family: var(--font-display);
     font-size: clamp(1.75rem, 3.5vw, 2.75rem);
     font-weight: 700;
     color: var(--color-white);
     letter-spacing: -.02em;
     line-height: 1.1;
     margin-bottom: .5rem;
   }
   .cta-subtitle { font-size: 1.0625rem; color: rgba(255,255,255,.8); line-height: 1.6; max-width: 50ch; }
   .cta-actions { display: flex; gap: var(--space-sm); flex-wrap: wrap; }
   .btn--cta-white {
     background: var(--color-white);
     color: var(--color-orange);
     font-family: var(--font-display);
     font-size: .9375rem; font-weight: 600;
     letter-spacing: .04em; text-transform: uppercase;
     padding: 1rem 2.25rem;
     border-radius: var(--radius-sm);
     display: inline-flex; align-items: center; gap: .5rem;
     transition: all var(--transition-normal);
     box-shadow: 0 4px 20px rgba(0,0,0,.15);
   }
   .btn--cta-white:hover { background: rgba(255,255,255,.92); transform: translateY(-1px); box-shadow: 0 8px 28px rgba(0,0,0,.2); }
   .btn--cta-outline {
     background: transparent;
     color: var(--color-white);
     border: 2px solid rgba(255,255,255,.5);
     font-family: var(--font-display);
     font-size: .9375rem; font-weight: 500;
     letter-spacing: .04em; text-transform: uppercase;
     padding: 1rem 2rem;
     border-radius: var(--radius-sm);
     display: inline-flex; align-items: center; gap: .5rem;
     transition: all var(--transition-normal);
   }
   .btn--cta-outline:hover { border-color: rgba(255,255,255,.9); background: rgba(255,255,255,.08); }
   
   /* ============================================================
      FOOTER
      ============================================================ */
   #site-footer { background: var(--color-navy); color: rgba(255,255,255,.6); }
   .footer-main {
     padding-block: var(--space-3xl);
     display: grid;
     grid-template-columns: 2fr 1fr 1fr 1.5fr;
     gap: var(--space-2xl);
     border-bottom: 1px solid rgba(255,255,255,.06);
   }
   .footer-logo { display: flex; align-items: center; gap: .625rem; margin-bottom: var(--space-md); }
 .footer-logo-img {
   display: block;
   width: auto;
   height: 30px;
   max-width: 180px;
   object-fit: contain;
 }
   .footer-logo-mark {
     width: 36px; height: 36px;
     background: var(--color-orange);
     border-radius: 6px;
     display: flex; align-items: center; justify-content: center;
   }
   .footer-logo-mark svg { width: 20px; height: 20px; color: var(--color-white); }
   .footer-logo-name { font-family: var(--font-display); font-size: 1rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--color-white); }
   .footer-desc { font-size: .9375rem; line-height: 1.7; max-width: 34ch; margin-bottom: var(--space-lg); }
   .footer-social { display: flex; gap: .625rem; }
   .footer-social-link {
     width: 36px; height: 36px;
     background: rgba(255,255,255,.06);
     border: 1px solid rgba(255,255,255,.08);
     border-radius: var(--radius-sm);
     display: flex; align-items: center; justify-content: center;
     transition: all var(--transition-fast);
   }
   .footer-social-link:hover { background: rgba(255,107,0,.15); border-color: rgba(255,107,0,.3); }
   .footer-social-link svg { width: 16px; height: 16px; color: rgba(255,255,255,.6); transition: color var(--transition-fast); }
   .footer-social-link:hover svg { color: var(--color-orange); }
   .footer-col-title {
     font-family: var(--font-display);
     font-size: .8125rem; font-weight: 600;
     letter-spacing: .12em; text-transform: uppercase;
     color: var(--color-white);
     margin-bottom: var(--space-md);
   }
   .footer-links { display: flex; flex-direction: column; gap: .5rem; }
   .footer-links a { font-size: .9375rem; color: rgba(255,255,255,.5); transition: color var(--transition-fast); display: flex; align-items: center; gap: .375rem; }
   .footer-links a::before {
     content: '';
     width: 4px; height: 4px;
     background: var(--color-orange);
     border-radius: 50%;
     opacity: 0;
     transition: opacity var(--transition-fast);
     flex-shrink: 0;
   }
   .footer-links a:hover { color: rgba(255,255,255,.85); }
   .footer-links a:hover::before { opacity: 1; }
   .footer-contact-item { display: flex; align-items: flex-start; gap: .75rem; margin-bottom: 1rem; }
   .footer-contact-item svg { width: 16px; height: 16px; color: var(--color-orange); flex-shrink: 0; margin-top: 3px; }
   .footer-contact-item span,
   .footer-contact-item a { font-size: .9375rem; color: rgba(255,255,255,.55); line-height: 1.5; }
   .footer-contact-item a { transition: color var(--transition-fast); }
   .footer-contact-item a:hover { color: var(--color-orange); }
   .footer-bottom {
     padding-block: var(--space-md);
     display: flex;
     align-items: center;
     justify-content: space-between;
     gap: var(--space-sm);
     flex-wrap: wrap;
   }
   .footer-copyright { font-size: .8125rem; color: rgba(255,255,255,.3); }
   .footer-bottom-links { display: flex; gap: var(--space-md); }
   .footer-bottom-links a { font-size: .8125rem; color: rgba(255,255,255,.3); transition: color var(--transition-fast); }
   .footer-bottom-links a:hover { color: rgba(255,255,255,.6); }
   /* Footer Trust Blocks (Certs + Payments) - Shared Style */
   .footer-certs,
   .footer-payments { margin-top: var(--space-md); }
   .footer-certs-header,
   .footer-payments-header {
     display: flex;
     align-items: center;
     gap: .375rem;
     margin-bottom: .5rem;
   }
   .footer-certs-header svg,
   .footer-payments-header svg {
     width: 14px;
     height: 14px;
     color: #16A34A;
   }
   .footer-certs-header span,
   .footer-payments-header span {
     font-size: .7rem;
     font-weight: 600;
     color: rgba(255,255,255,.85);
     letter-spacing: .03em;
   }
   .footer-certs-list,
   .footer-payments-list {
     display: flex;
     flex-wrap: wrap;
     gap: .375rem;
   }
   .footer-cert-badge,
   .footer-payment-item {
     display: flex;
     align-items: center;
     gap: .3rem;
     padding: .3rem .55rem;
     background: rgba(255,255,255,.08);
     border: 1px solid rgba(255,255,255,.12);
     border-radius: 5px;
     font-size: .6rem;
     color: rgba(255,255,255,.7);
     font-weight: 500;
     transition: all var(--transition-fast);
   }
   .footer-cert-badge:hover,
   .footer-payment-item:hover {
     background: rgba(255,255,255,.12);
     border-color: rgba(255,255,255,.2);
   }
   .footer-cert-badge svg,
   .footer-payment-item svg {
     color: rgba(255,255,255,.6);
     flex-shrink: 0;
   }
   
   /* ============================================================
      FLOATING WHATSAPP
      ============================================================ */
   .float-whatsapp {
     position: fixed;
     bottom: 1.5rem; right: 1.5rem;
     z-index: 9999;
     width: 56px; height: 56px;
     background: #25D366;
     border-radius: 50%;
     display: flex; align-items: center; justify-content: center;
     box-shadow: 0 4px 20px rgba(37,211,102,.4);
     transition: all var(--transition-normal);
     cursor: pointer;
   }
   .float-whatsapp:hover { transform: scale(1.08); box-shadow: 0 6px 28px rgba(37,211,102,.55); }
   .float-whatsapp svg { width: 28px; height: 28px; color: var(--color-white); }
   .float-whatsapp::before {
     content: '';
     position: absolute; inset: -4px;
     background: rgba(37,211,102,.3);
     border-radius: 50%;
     animation: pulse 2s ease infinite;
   }
   
   /* ============================================================
      WOOCOMMERCE MISC
      ============================================================ */
   .woocommerce-message, .woocommerce-error, .woocommerce-info {
     border-radius: var(--radius-md);
     padding: 1rem 1.25rem;
     border-left: 4px solid var(--color-orange);
     background: rgba(255,107,0,.06);
     color: var(--color-text);
     font-size: .9375rem;
     margin-bottom: var(--space-md);
   }
   .woocommerce-error { border-color: #e53e3e; background: rgba(229,62,62,.05); }
   
   /* ============================================================
      ANIMATIONS
      ============================================================ */
   @keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
   @keyframes fadeInUp { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: translateY(0); } }
   @keyframes scrollLine {
     0%   { opacity: 0; transform: scaleY(0); transform-origin: top; }
     40%  { opacity: 1; transform: scaleY(1); transform-origin: top; }
     60%  { opacity: 1; transform: scaleY(1); transform-origin: bottom; }
     100% { opacity: 0; transform: scaleY(0); transform-origin: bottom; }
   }
   @keyframes pulse {
     0%, 100% { transform: scale(1); opacity: .4; }
     50%       { transform: scale(1.25); opacity: 0; }
   }
   .reveal { opacity: 0; transform: translateY(32px); transition: opacity .6s ease, transform .6s ease; }
   .reveal.visible { opacity: 1; transform: translateY(0); }
   .reveal--delay-1 { transition-delay: .1s; }
   .reveal--delay-2 { transition-delay: .2s; }
   .reveal--delay-3 { transition-delay: .3s; }
   .reveal--delay-4 { transition-delay: .4s; }
   
   /* ============================================================
      RESPONSIVE – TABLET
      ============================================================ */
   @media (max-width: 1024px) {
     /* Header: desktop nav + WPML do not fit; use hamburger + #mobile-menu instead */
     .header__nav { display: none; }
     .header__cta { display: none; }
     .header__mobile-icons { display: flex; }
     .hamburger { display: flex; }
     .footer-main { grid-template-columns: 1fr 1fr; gap: var(--space-lg); }
     .why-grid, .coverage-inner { grid-template-columns: 1fr; gap: var(--space-xl); }
     .why-image img { aspect-ratio: 16/9; }
     .cat-showcase__card { flex-basis: min(720px, calc(100vw - 2.5rem)); min-height: 260px; }
     ul.products { grid-template-columns: repeat(2, 1fr); }
     .testimonials-grid { grid-template-columns: 1fr 1fr; }
     .process-steps { grid-template-columns: repeat(2, 1fr); }
     .process-steps::before { display: none; }
   }
   
   /* ============================================================
      RESPONSIVE – MOBILE
      ============================================================ */
 @media (max-width: 768px) {
   :root { --header-h: 64px; }
   .header__logo-img { display: none; }
   .header__logo-img--mobile { display: block; height: 32px; width: 32px; object-fit: contain; }
   .footer-logo-img { height: 26px; max-width: 150px; }
    /* Prevent flex/grid children from forcing horizontal overflow on small screens */
    .header__inner { gap: 0.5rem; min-width: 0; }
    .footer-main > .footer-brand,
    .footer-main > .footer-col { min-width: 0; }
     .ac-breadcrumb { display: none; }
     .hero__stats { gap: var(--space-md); flex-wrap: wrap; }
     .hero__stat-number { font-size: 1.75rem; }
     .hero__actions { flex-direction: column; width: 100%; }
     .hero__actions .btn { width: 100%; }
     .hero__scroll { display: none; }
     .cat-showcase__card { flex-basis: calc(100vw - 2.25rem); min-height: 300px; }
     .cat-showcase__toolbar { flex-direction: column; align-items: flex-start; }
     ul.products { grid-template-columns: 1fr; }
     .trust-bar__inner { flex-direction: column; align-items: flex-start; }
     .trust-bar__divider { display: none; }
     .process-steps { grid-template-columns: 1fr; }
     .testimonials-grid { grid-template-columns: 1fr; }
     .cta-inner { flex-direction: column; }
     .cta-actions { flex-direction: column; width: 100%; }
     .cta-actions .btn { width: 100%; }
     .footer-main { grid-template-columns: 1fr; }
     .footer-bottom { flex-direction: column; align-items: flex-start; }
     /* About page grids — tablet: 2-col intermediate */
     .responsive-2col       { grid-template-columns: 1fr !important; }
     .stats-grid            { grid-template-columns: 1fr 1fr !important; }
     .values-grid           { grid-template-columns: 1fr 1fr !important; }
     .team-grid             { grid-template-columns: 1fr 1fr !important; }
     .ac-about-location-grid { grid-template-columns: 1fr !important; }
     /* Contact page main 2-col grid */
     .ac-contact-grid       { grid-template-columns: 1fr !important; }
   }

  /* ============================================================
     RESPONSIVE – SMALL PHONES (≤480px)
     ============================================================ */
 @media (max-width: 480px) {
   /* Compact header on narrow phones (Chrome mobile / small viewports) */
   .header__logo-img { display: none; }
   .header__logo-img--mobile { display: block; height: 28px; width: 28px; object-fit: contain; }
   .footer-logo-img { height: 22px; max-width: 130px; }
    #site-header .header__wrap { padding-left: 0.75rem; padding-right: 0.75rem; }
    .hamburger { width: 36px; height: 36px; padding: 6px; }
    /* Footer: let text use full width of column */
    .footer-desc { max-width: none; }
    .footer-bottom-links { flex-wrap: wrap; row-gap: 0.5rem; }
    .cta-banner { padding-block: var(--space-xl); }
    .cta-title { font-size: clamp(1.35rem, 6vw, 2rem); }

    /* About page grids — fully single-column */
    .stats-grid  { grid-template-columns: 1fr !important; }
    .values-grid { grid-template-columns: 1fr !important; }
    .team-grid   { grid-template-columns: 1fr 1fr !important; }

    /* Foldable product template */
    .ac-foldable-hero-grid                           { grid-template-columns: 1fr !important; }
    .ac-foldable-hero-gallery                        { position: static !important; }
    .ac-foldable-overview-grid,
    .ac-foldable-delivery-grid                       { grid-template-columns: 1fr !important; }
    .ac-foldable-config-grid                         { grid-template-columns: 1fr 1fr !important; }
    .ac-foldable-related-grid                        { grid-template-columns: 1fr 1fr !important; }
    .ac-foldable-specs-table > div                   { grid-template-columns: 130px 1fr !important; }
  }

  @media print {
    #site-header, #site-footer, .float-whatsapp, .mobile-menu { display: none !important; }
    body { background: white; color: black; }
    .hero { min-height: auto; padding: 2rem 0; }
  }

/* ============================================================
   BATCH PRE-ORDER: WooCommerce overrides for batch products
   (Full batch UI is in the plugin's batch-frontend.css;
    these overrides integrate with the theme's existing styles)
   ============================================================ */

/* Hide the default WooCommerce price on batch product pages
   (the batch card shows the dynamic tier price instead) */
.ac-product-info .price,
.ac-product-info .woocommerce-Price-amount {
  display: none;
}

/* Style the WooCommerce add-to-cart button to match the batch CTA */
.ac-product-info .single_add_to_cart_button,
.ac-product-info button[type="submit"].button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 18px 24px;
  background: linear-gradient(135deg, var(--color-orange) 0%, var(--color-orange-hot) 100%);
  color: var(--color-white);
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  border: none;
  border-radius: var(--radius-lg);
  cursor: pointer;
  transition: all var(--transition-normal);
  box-shadow: var(--shadow-cta);
  margin: 16px 0 8px;
}

.ac-product-info .single_add_to_cart_button:hover,
.ac-product-info button[type="submit"].button:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 32px rgba(255,107,0,.45);
}

/* Quantity input for batch products */
.ac-product-info .quantity input.qty {
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 10px 14px;
  font-size: 16px;
  font-family: var(--font-body);
  text-align: center;
  width: 80px;
}

/* WooCommerce notices on batch pages */
.ac-product-info .woocommerce-message,
.ac-product-info .woocommerce-error,
.ac-product-info .woocommerce-info {
  margin-bottom: 16px;
  border-radius: var(--radius-md);
}

/* Related products grid responsive */
@media (max-width: 768px) {
  .ac-related-section div[style*="grid-template-columns:repeat(3"] {
    grid-template-columns: 1fr !important;
  }
}
@media (min-width: 769px) and (max-width: 1024px) {
  .ac-related-section div[style*="grid-template-columns:repeat(3"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* ── Header full-width override ── */
#site-header .header__wrap {
  width: 100%;
  padding-left: clamp(1rem, 2.5vw, 2rem);
  padding-right: clamp(1rem, 2.5vw, 2rem);
}

/* Account icon button in header */
.header__account {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  min-width: 42px;
}
.header__account svg,
.header__account img,
.header__account span {
  pointer-events: none;
}

/* Affiliate dashboard My Account styles integration */
.woocommerce-account .woocommerce-MyAccount-content .ac-aff-stats {
  margin-bottom: 24px;
}
.woocommerce-account .woocommerce-MyAccount-content .ac-aff-link-section {
  margin-bottom: 24px;
}

/* ============================================================
   MARITIME SINGLE PRODUCT
   ============================================================ */

.mar-hero-grid {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: var(--space-2xl);
  align-items: start;
}

.mar-gallery-sticky {
  position: sticky;
  top: calc(var(--header-h) + 1.5rem);
}

.mar-gallery-main {
  border-radius: var(--radius-xl);
  overflow: hidden;
  background: var(--color-navy);
  aspect-ratio: 4/3;
  position: relative;
  cursor: zoom-in;
}

.mar-gallery-main--sold::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(13, 27, 46, 0.15) 0%, rgba(13, 27, 46, 0.25) 100%);
  pointer-events: none;
  z-index: 2;
  transition: background 0.4s cubic-bezier(0.4,0,0.2,1);
}

.mar-gallery-main--sold:hover::after {
  background: linear-gradient(180deg, rgba(13, 27, 46, 0.0) 0%, rgba(13, 27, 46, 0.0) 100%);
}

.mar-gallery-main--sold .mar-sold-ribbon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(-4deg);
  z-index: 3;
  font-family: var(--font-display);
  font-size: clamp(0.7rem, 2vw, 0.8125rem);
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-white);
  padding: 0.65rem 1.5rem;
  border: 2px solid rgba(255, 255, 255, 0.85);
  border-radius: 100px;
  background: rgba(13, 27, 46, 0.75);
  backdrop-filter: blur(8px);
  pointer-events: none;
  text-align: center;
  max-width: 90%;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
}

.mar-overview-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--space-2xl);
}

.mar-delivery-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xl);
}

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

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

.mar-tabs {
  display: flex;
  gap: 0.375rem;
  flex-wrap: wrap;
  margin-bottom: var(--space-xl);
  border-bottom: 2px solid var(--color-border);
  padding-bottom: 0;
}

.mar-tabs__btn {
  font-family: var(--font-display);
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 0.75rem 1.25rem;
  background: none;
  border: none;
  cursor: pointer;
  border-bottom: 3px solid transparent;
  color: var(--color-muted);
  margin-bottom: -2px;
  transition: color var(--transition-fast), border-color var(--transition-fast);
}

.mar-tabs__btn:hover,
.mar-tabs__btn:focus-visible {
  color: var(--color-navy);
  outline: none;
}

.mar-tabs__btn--active {
  border-bottom-color: #1a6ebb;
  color: var(--color-navy);
}

.mar-sold-callout {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
  padding: var(--space-md);
  margin-bottom: var(--space-lg);
  background: linear-gradient(135deg, rgba(26, 110, 187, 0.08) 0%, rgba(13, 27, 46, 0.06) 100%);
  border: 1px solid rgba(26, 110, 187, 0.22);
  border-radius: var(--radius-lg);
}

.mar-sold-callout p {
  margin: 0;
  font-size: 0.9375rem;
  color: var(--color-text);
  line-height: 1.6;
}

/* WooCommerce purchase form (maritime) — match batch CTA styling */
.mar-product-purchase .single_add_to_cart_button,
.mar-product-purchase button[type="submit"].button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 18px 24px;
  background: linear-gradient(135deg, var(--color-orange) 0%, var(--color-orange-hot) 100%);
  color: var(--color-white);
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: none;
  border-radius: var(--radius-lg);
  cursor: pointer;
  transition: all var(--transition-normal);
  box-shadow: var(--shadow-cta);
  margin: 16px 0 8px;
}

.mar-product-purchase .single_add_to_cart_button:hover,
.mar-product-purchase button[type="submit"].button:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 32px rgba(255, 107, 0, 0.45);
}

.mar-product-purchase .quantity {
  margin-bottom: 0.5rem;
}

.mar-product-purchase .quantity input.qty {
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 10px 14px;
  font-size: 16px;
  font-family: var(--font-body);
  text-align: center;
  width: 80px;
}

.mar-product-purchase .woocommerce-message,
.mar-product-purchase .woocommerce-error,
.mar-product-purchase .woocommerce-info {
  margin-bottom: 16px;
  border-radius: var(--radius-md);
}

body.maritime-qty-one .mar-product-purchase .quantity {
  display: none !important;
}

body.maritime-qty-one .mar-product-purchase .single_add_to_cart_button,
body.maritime-qty-one .mar-product-purchase button[type="submit"].button {
  margin-top: 0;
}

.mar-product-purchase form.cart {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem;
}

body.maritime-qty-one .mar-product-purchase form.cart {
  display: block;
}

/* Long description + rich product spec block (editor HTML can omit <style> if rules live here) */
.mar-product-description {
  font-size: 0.9375rem;
  line-height: 1.75;
  color: var(--color-text);
}

.mar-product-description > *:first-child {
  margin-top: 0;
}

.mar-product-description .alignwide,
.mar-product-description .alignfull {
  max-width: none;
}

.mar-product-description #adriatic-pro-spec {
  font-family: var(--font-body);
  color: var(--color-text);
  max-width: var(--container-max);
  margin: 0 auto;
  line-height: 1.6;
}

.mar-product-description #adriatic-pro-spec .ac-label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-display);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-orange);
  margin-bottom: var(--space-sm);
}

.mar-product-description #adriatic-pro-spec .ac-label::before {
  content: '';
  display: block;
  width: 24px;
  height: 2px;
  background: var(--color-orange);
}

.mar-product-description #adriatic-pro-spec h2 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 2.75rem);
  font-weight: 700;
  line-height: 1.1;
  color: var(--color-navy);
  margin-bottom: var(--space-md);
}

.mar-product-description #adriatic-pro-spec .feature-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--space-md);
  margin: var(--space-lg) 0;
}

.mar-product-description #adriatic-pro-spec .feature-card {
  padding: var(--space-lg);
  background: var(--color-steel);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-steel-mid);
}

.mar-product-description #adriatic-pro-spec .feature-card h3 {
  font-family: var(--font-display);
  font-size: 1.25rem;
  color: var(--color-navy-mid);
  margin-bottom: 0.75rem;
  display: flex;
  align-items: center;
  gap: 10px;
}

.mar-product-description #adriatic-pro-spec .tech-blueprint {
  background: var(--color-navy);
  color: var(--color-white);
  border-radius: var(--radius-xl);
  padding: var(--space-xl) var(--space-lg);
  margin: var(--space-2xl) 0;
}

.mar-product-description #adriatic-pro-spec .spec-row {
  display: grid;
  grid-template-columns: 1fr 2fr;
  padding: 12px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.mar-product-description #adriatic-pro-spec .spec-row:last-child {
  border: none;
}

.mar-product-description #adriatic-pro-spec .spec-label {
  color: var(--color-muted);
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.mar-product-description #adriatic-pro-spec .spec-value {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1rem;
}

.mar-product-description #adriatic-pro-spec .badge-new {
  display: inline-block;
  background: var(--color-orange);
  color: #fff;
  font-family: var(--font-display);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 50px;
  margin-bottom: var(--space-sm);
}

.mar-product-description #adriatic-pro-spec .use-cases {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-sm);
  margin: var(--space-lg) 0;
}

.mar-product-description #adriatic-pro-spec .use-case-pill {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  background: var(--color-steel);
  border-radius: var(--radius-md);
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--color-navy);
  border: 1px solid var(--color-steel-mid);
}

.mar-product-description #adriatic-pro-spec .conversion-bar {
  background: var(--color-orange);
  color: white;
  padding: var(--space-md) var(--space-lg);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: var(--space-xl);
}

@media (max-width: 768px) {
  .mar-product-description #adriatic-pro-spec .spec-row {
    grid-template-columns: 1fr;
    gap: 4px;
  }

  .mar-product-description #adriatic-pro-spec .conversion-bar {
    flex-direction: column;
    text-align: center;
    gap: 15px;
  }
}

.mar-use-card {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-md);
  transition: border-color var(--transition-normal), box-shadow var(--transition-normal);
}

.mar-use-card:hover {
  border-color: rgba(26, 110, 187, 0.3);
  box-shadow: var(--shadow-md);
}

.mar-related-card {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: block;
  transition: border-color var(--transition-normal), box-shadow var(--transition-normal), transform var(--transition-normal);
  text-decoration: none;
}

.mar-related-card:hover {
  border-color: rgba(26, 110, 187, 0.3);
  box-shadow: var(--shadow-lg);
  transform: translateY(-4px);
}

@media (max-width: 1024px) {
  .mar-gallery-sticky {
    position: static;
  }
}

@media (max-width: 768px) {
  .mar-hero-grid,
  .mar-overview-grid,
  .mar-delivery-grid,
  .mar-use-grid,
  .mar-related-grid {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 769px) and (max-width: 1024px) {
  .mar-related-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .mar-related-section .mar-related-grid {
    grid-template-columns: 1fr;
  }
}
@media (min-width: 769px) and (max-width: 1024px) {
  .mar-related-section .mar-related-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ============================================================
   SOLD & BATCH CARD STATES
   ============================================================ */

/* Sold price panel on maritime single product page */
.mar-sold-panel {
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: var(--space-lg);
  border: 1px solid var(--color-border);
}

.mar-sold-panel__stamp {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.875rem var(--space-md);
  background: linear-gradient(135deg, rgba(255, 107, 0, 0.1) 0%, rgba(255, 140, 42, 0.08) 100%);
  border-bottom: 1px solid rgba(255, 107, 0, 0.15);
}

.mar-sold-panel__stamp-label {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  font-family: var(--font-display);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-orange);
}

.mar-sold-panel__body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-lg);
  padding: var(--space-md);
  background: var(--color-navy);
}

.mar-sold-panel__price-section {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.mar-sold-panel__price-label {
  font-size: 0.6875rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.4);
}

.mar-sold-panel__price-ref {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 700;
  color: var(--color-white);
  text-decoration: line-through;
  opacity: 0.5;
}

.mar-sold-panel__price-note {
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.45);
}

.mar-sold-panel__cta-section {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: center;
  gap: 1rem;
}

.mar-sold-panel__cta-title {
  font-family: var(--font-display);
  font-size: 0.9375rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-orange);
  text-align: right;
}

.mar-sold-panel__cta-section .btn--outline-light {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.875rem 1.5rem;
  font-size: 0.8125rem;
  white-space: nowrap;
}

@media (max-width: 768px) {
  .mar-sold-panel__body {
    grid-template-columns: 1fr;
    gap: var(--space-md);
  }

  .mar-sold-panel__cta-section {
    align-items: stretch;
  }

  .mar-sold-panel__cta-title {
    text-align: center;
  }
  
  .mar-sold-panel__cta-section .btn--outline-light {
    justify-content: center;
    width: 100%;
  }
}

/* Sold state on any product card */
.ac-card-sold-overlay {
  position: relative;
}

.ac-card-sold-overlay::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.7) 0%, rgba(255, 255, 255, 0.85) 100%);
  pointer-events: none;
  z-index: 1;
}

.ac-card-badge--sold {
  background: #6B7280 !important;
  position: relative;
  z-index: 2;
}

.ac-card-cta--reference {
  background: transparent !important;
  color: var(--color-navy) !important;
  border: 1.5px solid var(--color-navy);
  box-shadow: none !important;
}

.ac-card-cta--reference:hover {
  background: var(--color-navy) !important;
  color: var(--color-white) !important;
  transform: translateY(-1px) !important;
}

.ac-card-price--sold {
  text-decoration: line-through;
  opacity: 0.5;
}

.ac-card-status--sold {
  font-family: var(--font-display);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

/* Batch mini-progress on card */
.ac-batch-card-mini {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding: 0.625rem;
  background: rgba(255, 107, 0, 0.04);
  border: 1px solid rgba(255, 107, 0, 0.12);
  border-radius: var(--radius-md);
  margin-top: 0.5rem;
}

.ac-batch-mini-bar {
  height: 4px;
  border-radius: 2px;
  background: var(--color-steel-mid);
  overflow: hidden;
  position: relative;
}

.ac-batch-mini-bar__fill {
  height: 4px;
  border-radius: 2px;
  background: var(--color-orange);
  transition: width 0.3s ease;
}

.ac-batch-mini-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  font-size: 0.75rem;
  color: var(--color-muted);
  line-height: 1.4;
}

.ac-batch-mini-meta strong {
  color: var(--color-navy);
  font-weight: 600;
}

.ac-batch-mini-price {
  font-family: var(--font-display);
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--color-orange);
}

.ac-card-badge--batch {
  background: var(--color-orange) !important;
}

/* ============================================================
   WAITLIST SECTION (TESLA/APPLE STYLE)
   ============================================================ */
.ac-waitlist-section {
  margin: var(--space-3xl) auto;
  max-width: 680px;
  padding: 0 var(--space-md);
}

/* Waitlist inside product hero column — no duplicate scroll, tighter spacing */
.ac-waitlist-section--product-hero {
  margin: 0 0 var(--space-lg);
  max-width: none;
  padding: 0;
}

.ac-waitlist-section--product-hero .ac-waitlist-card {
  padding: var(--space-xl) var(--space-lg);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.18);
}

.ac-waitlist-section--product-hero .ac-waitlist-icon {
  width: 48px;
  height: 48px;
  margin-bottom: 1rem;
}

.ac-waitlist-section--product-hero .ac-waitlist-heading {
  font-size: clamp(1.25rem, 3.5vw, 1.625rem);
}

.ac-waitlist-section--product-hero .ac-waitlist-text {
  margin-bottom: 1.5rem;
  font-size: 0.9375rem;
}

.ac-waitlist-card {
  background: linear-gradient(135deg, #1a1a1a 0%, #2d2d2d 100%);
  border-radius: var(--radius-xl);
  padding: var(--space-3xl) var(--space-2xl);
  text-align: center;
  box-shadow: 0 20px 60px rgba(0,0,0,0.3);
  position: relative;
  overflow: hidden;
}

.ac-waitlist-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--color-orange), transparent);
}

.ac-waitlist-icon {
  width: 64px;
  height: 64px;
  color: var(--color-orange);
  margin: 0 auto 1.5rem;
  stroke-width: 1.5;
}

.ac-waitlist-heading {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 700;
  color: #ffffff;
  margin: 0 0 1rem;
  letter-spacing: -0.02em;
}

.ac-waitlist-text {
  font-size: 1rem;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.7);
  margin: 0 0 2.5rem;
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}

.ac-waitlist-form {
  max-width: 500px;
  margin: 0 auto 1.5rem;
}

.ac-waitlist-inputs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  margin-bottom: 1rem;
}

.ac-waitlist-input {
  font-family: var(--font-body);
  font-size: 0.9375rem;
  padding: 0.875rem 1rem;
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.08);
  color: #ffffff;
  transition: all 0.2s ease;
  width: 100%;
}

.ac-waitlist-input:focus {
  outline: none;
  border-color: var(--color-orange);
  background: rgba(255, 255, 255, 0.12);
  box-shadow: 0 0 0 3px rgba(255, 107, 0, 0.15);
}

.ac-waitlist-input::placeholder {
  color: rgba(255, 255, 255, 0.4);
}

.ac-waitlist-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.625rem;
  width: 100%;
  font-family: var(--font-display);
  font-size: 0.9375rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 1rem 2rem;
  border: none;
  border-radius: var(--radius-md);
  background: var(--color-orange);
  color: #ffffff;
  cursor: pointer;
  transition: all 0.3s ease;
  box-shadow: 0 4px 14px rgba(255, 107, 0, 0.3);
}

.ac-waitlist-btn:hover:not(:disabled) {
  background: var(--color-orange-hot);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(255, 107, 0, 0.4);
}

.ac-waitlist-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.ac-waitlist-btn-icon {
  width: 16px;
  height: 16px;
  transition: transform 0.3s ease;
}

.ac-waitlist-btn:hover:not(:disabled) .ac-waitlist-btn-icon {
  transform: translateX(3px);
}

.ac-waitlist-success {
  text-align: center;
  padding: 2rem 0;
}

.ac-waitlist-check {
  width: 80px;
  height: 80px;
  color: #10b981;
  margin: 0 auto 1.5rem;
  animation: checkScale 0.5s ease;
}

@keyframes checkScale {
  0% { transform: scale(0); opacity: 0; }
  50% { transform: scale(1.1); }
  100% { transform: scale(1); opacity: 1; }
}

.ac-waitlist-success-text {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 700;
  color: #ffffff;
  margin: 0 0 0.5rem;
}

.ac-waitlist-success-sub {
  font-size: 1rem;
  color: rgba(255, 255, 255, 0.7);
  margin: 0;
}

.ac-waitlist-privacy {
  font-size: 0.8125rem;
  color: rgba(255, 255, 255, 0.5);
  margin: 0;
}

.ac-waitlist-privacy a {
  color: rgba(255, 255, 255, 0.7);
  text-decoration: underline;
  transition: color 0.2s ease;
}

.ac-waitlist-privacy a:hover {
  color: var(--color-orange);
}

@media (max-width: 640px) {
  .ac-waitlist-card {
    padding: var(--space-2xl) var(--space-lg);
  }
  
  .ac-waitlist-heading {
    font-size: 1.5rem;
  }
  
  .ac-waitlist-inputs {
    grid-template-columns: 1fr;
  }
}

/* Coming Soon badge for archive cards */
.ac-badge--coming-soon,
.ac-card-badge--coming-soon {
  background: #6B7280 !important;
}

/* ============================================================
   BATCH "OPENING SOON" TEASER (archive / featured cards)
   ============================================================ */
.ac-batch-soon-mini {
  flex: 1;
  margin-top: 0.125rem;
}

.ac-batch-soon-mini__inner {
  position: relative;
  padding: 0.875rem 1rem;
  border-radius: var(--radius-md);
  background: linear-gradient(145deg, #fafafa 0%, #f4f4f5 100%);
  border: 1px solid rgba(0, 0, 0, 0.06);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.8) inset;
}

.ac-batch-soon-mini__inner::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.65rem;
  bottom: 0.65rem;
  width: 3px;
  border-radius: 0 2px 2px 0;
  background: linear-gradient(180deg, var(--color-orange) 0%, #e85d00 100%);
}

.ac-batch-soon-mini__kicker {
  display: block;
  font-family: var(--font-display);
  font-size: 0.5625rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 0.35rem;
  padding-left: 0.5rem;
}

.ac-batch-soon-mini__title {
  font-family: var(--font-display);
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--color-navy);
  line-height: 1.25;
  margin: 0 0 0.4rem;
  letter-spacing: -0.02em;
  padding-left: 0.5rem;
}

.ac-batch-soon-mini__text {
  font-size: 0.75rem;
  line-height: 1.55;
  color: var(--color-muted);
  margin: 0;
  padding-left: 0.5rem;
}

.ac-batch-soon-mini__meta {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  margin: 0.65rem 0 0;
  padding-left: 0.5rem;
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--color-navy);
  letter-spacing: 0.02em;
}

.ac-batch-soon-mini__dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-orange);
  flex-shrink: 0;
  box-shadow: 0 0 0 2px rgba(255, 107, 0, 0.2);
}