html { overflow-x: clip; -webkit-text-size-adjust: 100%; text-size-adjust: 100%; touch-action: manipulation; background: #111; }
:root {
      --orange: #63C0E7;
      --blue:   #63C0E7;
      --blue-dk:#3AABD8;
      --dark:   #111111;
      --dark2:  #1a1a1a;
      --dark3:  #2a2a2a;
      --mid:    #444;
      --muted:  #888;
      --light:  #f5f5f5;
      --white:  #ffffff;
    }
/* Truetone shared styles — auto-extracted */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
body { background: #111; font-family: 'Inter', Arial, sans-serif; background: #111 !important; color: var(--dark); -webkit-font-smoothing: antialiased;
}
.nav-logo { flex: 1; display: flex; align-items: center; }
.nav-logo img { height: 44px; width: auto; display: block; filter: brightness(0) invert(1); }
.nav-links { display: flex; gap: 20px; list-style: none; align-items: center; height: 100%; }
.nav-links > li { position: static; height: 100%; display: flex; align-items: center; }
.nav-links > li > a { color: #ccc; text-decoration: none; font-size: clamp(10px, 1vw, 13px); /* fluid type */ font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; transition: color 0.2s; white-space: nowrap; display: flex; align-items: center; gap: 4px; }
/* ── Suppress visited link color change ──────────────────── */ a:visited { color: inherit; }
.nav-links > li > a:hover, .nav-links > li.active > a { color: var(--orange); }
.nav-links > li > a .chevron { font-size: 9px; opacity: 0.5; transition: transform 0.2s; }
.nav-links > li:hover > a .chevron { transform: rotate(180deg); opacity: 1; }
.nav-links > li:hover .dropdown { opacity: 1; visibility: visible; transform: translateY(0); transition: opacity 0.2s ease, transform 0.2s ease; }
.dropdown-group { min-width: 140px; position: relative; z-index: 1; }
.dropdown-ghost { position: absolute; right: -10px; bottom: -16px; font-size: 140px; font-weight: 900; color: rgba(255,255,255,0.04); line-height: 1; user-select: none; pointer-events: none; letter-spacing: -0.02em; text-transform: uppercase; white-space: nowrap; z-index: 0; }
.dropdown-label { display: block; font-size: 9px; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; color: var(--orange); margin-bottom: 14px; }
.dropdown a { display: block; color: #777; text-decoration: none; font-size: 13px; font-weight: 500; padding: 5px 0; transition: color 0.15s; white-space: nowrap; }
.dropdown a:hover { color: var(--white); }
.dropdown a.active { color: var(--orange); }
.dropdown-images { display: flex; gap: 16px; margin-left: auto; padding-left: 48px; padding-right: 32px; align-items: flex-start; flex-shrink: 0; position: relative; z-index: 1; }
.dropdown-img-card { display: block; text-decoration: none; width: 280px; flex-shrink: 0; text-align: center; }
.dropdown-img-card img { filter: grayscale(100%); transition: filter 0.35s ease; width: 100%; height: 190px; object-fit: cover; border-radius: 3px; display: block; }
.dropdown-img-card:hover img { filter: grayscale(0%); }
.nav-right { flex: 1; justify-content: flex-end; display: flex; align-items: center; gap: 16px; margin-left: 24px; }
.nav-search { background: #222; border: 1px solid #333; border-radius: 4px; color: var(--white); font-size: 12px; font-family: 'Inter', sans-serif; outline: none; transition: border-color 0.2s; }
.nav-search:focus { border-color: var(--orange); }
.nav-search::placeholder { color: #555; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; margin-bottom: 48px; }
.footer-brand p { font-size: 13px; color: #f5f5f5; line-height: 1.7; }
.footer-address a:hover { color: #f5f5f5; }
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.footer-col ul a { color: #f5f5f5; text-decoration: none; font-size: 13px; font-weight: 400; transition: color 0.2s; }
.footer-col ul a:hover { color: var(--orange); }
.footer-bottom { border-top: 1px solid #1a1a1a; padding-top: 24px; display: flex; justify-content: space-between; align-items: center; }
.footer-bottom-right { display: flex; align-items: center; gap: 24px; }
.social-links a:hover { border-color: var(--orange); color: var(--orange); }
.nav-search-btn-mobile { display: none; }

@media (max-width: 1024px) {
  .nav-search-btn-mobile { display: flex; margin-right: 25px; }
}
@media (max-width: 1024px) {
  /* ── Hamburger ── */
  nav { height: 60px; position: relative; }
  .nav-cart-btn.nav-cart-btn-mobile { display: flex; margin-right: 14px; }
  .nav-right { display: none; }
  nav.mobile-open ~ .nav-overlay,
  nav.mobile-open + * .nav-overlay { display: block; }
}
.footer-signup-label { font-size: 9px; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; color: var(--orange); display: block; margin-bottom: 8px; }
.footer-signup-heading { font-size: 18px; font-weight: 900; color: var(--white); text-transform: uppercase; letter-spacing: -0.01em; line-height: 1.1; margin-bottom: 6px; }
.footer-signup-sub { font-size: 12px; color: #666; line-height: 1.6; max-width: 320px; }
.footer-signup-form { display: flex; gap: 0; flex-shrink: 0; position: relative; }
.footer-signup-input { font-family: 'Inter', sans-serif; font-size: 13px; color: var(--white); background: #1a1a1a; border: 1px solid #2a2a2a; border-right: none; border-radius: 2px 0 0 2px; padding: 11px 16px; width: 240px; outline: none; transition: border-color 0.2s; }
.footer-signup-input::placeholder { color: #555; }
.footer-signup-input:focus { border-color: var(--orange); }
.footer-signup-btn { font-family: 'Inter', sans-serif; font-size: 11px; font-weight: 800; letter-spacing: 0.1em; text-transform: uppercase; background: var(--orange); color: var(--dark); border: none; padding: 11px 20px; cursor: pointer; border-radius: 0 2px 2px 0; transition: background 0.2s; white-space: nowrap; }
.footer-signup-btn:hover { background: var(--blue-dk); color: var(--white); }



/* ─── NAV CART BUTTON ─── */ .nav-cart-btn { position: relative; background: none; border: none; cursor: pointer; color: #ccc; display: flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; transition: color 0.2s; padding: 0; }
.nav-cart-btn:hover { color: var(--blue); }
.nav-cart-btn svg { width: 20px; height: 20px; fill: currentColor; }
.cart-badge { position: absolute; top: -6px; right: -8px; background: var(--blue); color: var(--dark); font-size: 9px; font-weight: 900; width: 16px; height: 16px; border-radius: 50%; display: flex; align-items: center; justify-content: center; opacity: 0; transform: scale(0); transition: opacity 0.2s, transform 0.2s; }
.cart-badge.visible { opacity: 1; transform: scale(1); }
/* ─── CART DRAWER ─── */ /* Overlay */ .cart-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.65); z-index: 800; opacity: 0; visibility: hidden; transition: opacity 0.3s ease, visibility 0s linear 0.3s; backdrop-filter: blur(2px); }
.cart-overlay.open { opacity: 1; visibility: visible; transition: opacity 0.3s ease; }
/* Drawer shell */ .cart-drawer { position: fixed; top: 0; right: 0; width: 400px; max-width: 100vw; height: 100vh; background: #111; z-index: 900; display: flex; flex-direction: column; transform: translateX(100%); transition: transform 0.38s cubic-bezier(0.22, 1, 0.36, 1); box-shadow: -12px 0 60px rgba(0,0,0,0.5); }
.cart-drawer.open { transform: translateX(0); }
/* Header */ .cart-drawer-header { display: flex; align-items: center; justify-content: space-between; padding: 22px 24px; border-bottom: 1px solid rgba(255,255,255,0.08); flex-shrink: 0; background: #111; }
.cart-drawer-title { font-size: 11px; font-weight: 900; text-transform: uppercase; letter-spacing: 0.18em; color: #fff; display: flex; align-items: center; gap: 10px; }
.cart-drawer-title svg { width: 16px; height: 16px; fill: var(--blue); flex-shrink: 0; }
.cart-count-label { background: var(--blue); color: #111; font-size: 9px; font-weight: 900; letter-spacing: 0.1em; padding: 3px 8px; border-radius: 2px; text-transform: uppercase; }
.cart-close-btn { background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1); cursor: pointer; color: #aaa; width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; transition: background 0.2s, color 0.2s; border-radius: 2px; }
.cart-close-btn:hover { background: rgba(255,255,255,0.12); color: #fff; }
.cart-close-btn svg { width: 16px; height: 16px; fill: currentColor; }
/* Scrollable item area */ .cart-items-area { flex: 1; overflow-y: auto; padding: 0; scrollbar-width: thin; scrollbar-color: rgba(255,255,255,0.1) transparent; }
.cart-items-area::-webkit-scrollbar { width: 4px; }
.cart-items-area::-webkit-scrollbar-track { background: transparent; }
.cart-items-area::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 2px; }
/* Empty state */ .cart-empty { display: flex; flex-direction: column; align-items: center; justify-content: center; height: 100%; gap: 14px; padding: 64px 32px; text-align: center; }
.cart-empty svg { width: 40px; height: 40px; fill: rgba(255,255,255,0.1); }
.cart-empty p { font-size: 12px; font-weight: 600; color: rgba(255,255,255,0.3); letter-spacing: 0.04em; text-transform: uppercase; }
.cart-empty a { font-size: 10px; font-weight: 900; text-transform: uppercase; letter-spacing: 0.14em; color: var(--blue); text-decoration: none; border-bottom: 1px solid rgba(99,192,231,0.3); padding-bottom: 2px; transition: border-color 0.2s; }
.cart-empty a:hover { border-color: var(--blue); }
/* Cart items */ .cart-item { display: grid; grid-template-columns: 72px 1fr 28px; gap: 14px; align-items: start; padding: 18px 24px; border-bottom: 1px solid rgba(255,255,255,0.06); animation: slideInItem 0.22s ease; }
from { opacity: 0; transform: translateX(16px); }
to { opacity: 1; transform: translateX(0); }
.cart-item-img { width: 72px; height: 72px; object-fit: contain; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: 2px; }
.cart-item-info { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.cart-item-brand { font-size: 8px; font-weight: 900; letter-spacing: 0.2em; text-transform: uppercase; color: var(--blue); }
.cart-item-name { font-size: 12px; font-weight: 700; color: #fff; line-height: 1.35; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cart-item-price { font-size: 14px; font-weight: 900; color: #fff; margin-top: 4px; letter-spacing: -0.01em; }
.cart-item-qty { display: flex; align-items: center; margin-top: 10px; border: 1px solid rgba(255,255,255,0.12); width: fit-content; border-radius: 2px; overflow: hidden; }
.qty-btn { background: rgba(255,255,255,0.04); border: none; width: 26px; height: 26px; cursor: pointer; font-size: 15px; font-weight: 700; color: #aaa; display: flex; align-items: center; justify-content: center; transition: background 0.15s, color 0.15s; }
.qty-btn:hover { background: rgba(99,192,231,0.15); color: var(--blue); }
.qty-val { width: 30px; text-align: center; font-size: 12px; font-weight: 700; color: #fff; border-left: 1px solid rgba(255,255,255,0.12); border-right: 1px solid rgba(255,255,255,0.12); height: 26px; line-height: 26px; }
.cart-item-remove { background: none; border: none; cursor: pointer; color: rgba(255,255,255,0.2); padding: 2px; transition: color 0.2s; flex-shrink: 0; margin-top: 2px; }
.cart-item-remove:hover { color: #e55; }
.cart-item-remove svg { width: 14px; height: 14px; fill: currentColor; display: block; }
/* Footer */ .cart-footer { padding: 20px 24px; border-top: 1px solid rgba(255,255,255,0.08); flex-shrink: 0; background: #111; }
.cart-subtotal { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 4px; }
.cart-subtotal-label { font-size: 9px; font-weight: 900; text-transform: uppercase; letter-spacing: 0.18em; color: rgba(255,255,255,0.4); }
.cart-subtotal-amount { font-size: 24px; font-weight: 900; color: #fff; letter-spacing: -0.03em; }
.cart-shipping-note { font-size: 10px; color: rgba(255,255,255,0.25); font-weight: 500; margin-bottom: 18px; letter-spacing: 0.01em; }
/* Checkout button */ .cart-checkout-btn { display: flex; align-items: center; justify-content: center; gap: 9px; width: 100%; background: var(--blue); color: #111; border: none; font-family: 'Inter', sans-serif; font-size: 11px; font-weight: 900; letter-spacing: 0.16em; text-transform: uppercase; padding: 15px 24px; cursor: pointer; text-decoration: none; transition: background 0.2s, transform 0.15s; margin-bottom: 10px; border-radius: 2px; }
.cart-checkout-btn:hover { background: var(--blue-dk); }
.cart-checkout-btn:active { transform: scale(0.99); }
.cart-checkout-btn svg { width: 14px; height: 14px; fill: currentColor; flex-shrink: 0; }
/* Express checkout buttons */ .cart-divider { display: flex; align-items: center; gap: 10px; margin: 12px 0 10px; }
.cart-divider::before, .cart-divider::after { content: ''; flex: 1; height: 1px; background: rgba(255,255,255,0.08); }
.cart-divider span { font-size: 9px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,0.25); }
.cart-express-btns { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; margin-bottom: 14px; }
.cart-express-btn { display: flex; align-items: center; justify-content: center; height: 44px; border: none; border-radius: 6px; cursor: pointer; transition: filter 0.15s; overflow: hidden; }
.cart-express-btn:hover { filter: brightness(0.92); }
.cart-express-btn:active { filter: brightness(0.85); transform: scale(0.98); }
/* Shop Pay — purple #5A31F4 */ .cart-express-btn.shop-pay { background: #5A31F4; }
.cart-express-btn.shop-pay svg { height: 70px; width: auto; }
/* PayPal — yellow #FFC439 */ .cart-express-btn.paypal { background: #FFC439; }
.cart-express-btn.paypal svg { height: 28px; width: auto; }
/* Google Pay — black */ .cart-express-btn.google-pay { background: #000; border: 1px solid rgba(255,255,255,0.15); }
.cart-express-btn.google-pay svg { height: 56px; width: 56px; }
/* Venmo — blue #008CFF */ .cart-express-btn.venmo { background: #008CFF; }
.cart-express-btn.venmo svg { height: 22px; width: auto; }
/* Fix blue underline on cart item name links */ .cart-item-name-link { text-decoration: none; color: inherit; }
.cart-item-img-link { text-decoration: none; }
/* Add-to-cart button states */ .btn-buy.loading { opacity: 0.6; pointer-events: none; }
.btn-buy.added { background: #2a9a5a !important; color: #fff !important; }
/* ── Cart label ───────────────────────────── */ .nav-cart-label { font-size: 12px; font-weight: 600; letter-spacing: 0.08em; color: currentColor; margin-left: 6px; line-height: 1; }

/* ── Product price display ──────────────────────────────────── */ .product-price { display: block; font-size: 20px; font-weight: 800; color: #111; letter-spacing: 0.01em; margin: 8px 0 4px; }
/* ── Product detail panel — buy section ───────────────────── */ .shopify-buy-section { margin-bottom: 28px; }
.price-display { display: flex; align-items: baseline; gap: 12px; margin-bottom: 16px; }
.price-amount { font-size: 32px; font-weight: 900; color: var(--dark); letter-spacing: -0.02em; }
.price-note { font-size: 12px; font-weight: 600; color: var(--muted); text-transform: uppercase; letter-spacing: 0.06em; }
.shopify-loading { display: flex; align-items: center; gap: 10px; color: var(--muted); font-size: 13px; font-weight: 500; padding: 8px 0; }
.loading-dots { display: flex; gap: 4px; }
.loading-dots span { width: 6px; height: 6px; background: var(--blue); border-radius: 50%; animation: dot-pulse 1.2s ease-in-out infinite; }
.loading-dots span:nth-child(2) { animation-delay: 0.2s; }
.loading-dots span:nth-child(3) { animation-delay: 0.4s; }
0%, 80%, 100% { opacity: 0.3; transform: scale(0.8); }
40% { opacity: 1; transform: scale(1); }
.shopify-buttons-row { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 10px; }
.shopify-note { font-size: 11px; color: var(--muted); font-weight: 500; margin-top: 6px; display: flex; align-items: center; gap: 5px; }
.manual-link { display: inline-flex; align-items: center; gap: 8px; color: #888; text-decoration: none; font-size: 13px; font-weight: 700; letter-spacing: 0.04em; margin-top: 4px; transition: color 0.2s; }
.manual-link:hover { color: #444; }
.manual-link svg { width: 16px; height: 16px; fill: currentColor; }
.btn-disabled { opacity: 0.45; cursor: not-allowed !important; pointer-events: none; }
.btn-added { background: #2a9a5a !important; border-color: #2a9a5a !important; color: var(--white) !important; }
/* ── US-only sales banner ───────────────────────────────────── */ .us-only-banner { background: #111; text-align: center; padding: 16px 24px; font-family: 'Inter', sans-serif; font-size: 13px; color: #aaa; }
.us-only-banner p { margin: 0; }
.us-only-banner strong { color: #fff; }
.us-only-banner a { color: var(--blue, #63C0E7); text-decoration: none; }
.us-only-banner a:hover { text-decoration: underline; }
/* ── Geo: international visitor states ─────────────────────── */ body.geo-intl button.btn-buy, body.geo-intl a.btn-buy, body.geo-intl .btn-buy { opacity: 0.38 !important; pointer-events: none !important; cursor: not-allowed !important; }
body.geo-intl .btn-pp-buy { opacity: 0.38 !important; pointer-events: none !important; cursor: not-allowed !important; }
body.geo-intl .btn-learn { opacity: 0.55 !important; }
body.geo-intl .purchase-price { display: none !important; }
body.geo-intl .purchase-price-intl { display: block !important; }
body.geo-intl .purchase-intl-note { display: block !important; }
.geo-disabled-wrap { position: relative; display: flex; flex: 1; flex-direction: column; }
.geo-disabled-wrap > button, .geo-disabled-wrap > a { flex: 1; width: 100%; }
.geo-notice { /* Always in DOM, shown/hidden via opacity + visibility */ position: absolute; bottom: calc(100% + 8px); left: 50%; transform: translateX(-50%); white-space: nowrap; background: #111; color: #e0e0e0; font-size: 11px; font-family: 'Inter', sans-serif; font-weight: 500; letter-spacing: 0.02em; padding: 6px 10px; border-radius: 4px; pointer-events: auto; /* hoverable — keeps tooltip alive */ z-index: 200; opacity: 0; visibility: hidden; /* Fade OUT: 0.3s fade after 0.5s delay when cursor leaves */ transition: opacity 0.3s ease 0.5s, visibility 0s linear 0.8s; }
.geo-notice::after { content: ''; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); border: 5px solid transparent; border-top-color: #111; }
/* Extend hover zone: invisible bridge fills the 8px gap so cursor can travel from button into tooltip without flickering */ .geo-notice::before { content: ''; position: absolute; top: 100%; left: 0; right: 0; height: 13px; /* covers the 8px gap + arrow height */ }
.geo-notice a { color: var(--blue, #63C0E7); text-decoration: none; }
.geo-notice a:hover { text-decoration: underline; }
/* Show on wrapper hover OR tooltip hover — instant appear, delayed disappear */ .geo-disabled-wrap:hover .geo-notice, .geo-notice:hover { opacity: 1; visibility: visible; /* Fade IN: instant, no delay */ transition: opacity 0.15s ease 0s, visibility 0s linear 0s; }
body.geo-intl .geo-disabled { opacity: 0.38 !important; pointer-events: none !important; }
/* ── Price color: black on product cards ───────────────────── */ .product-price { color: #111 !important; }
.product-card .product-price { color: #111 !important; }
/* ── Desktop search icon + animated input ── */ .nav-search-wrap { display: flex; align-items: center; flex-direction: row; gap: 0; position: relative; }
.nav-search-icon { background: none; border: none; cursor: pointer; color: #ccc; padding: 4px; display: flex; align-items: center; flex-shrink: 0; transition: color 0.2s; }
.nav-search-icon:hover { color: var(--white); }
.nav-search { position: absolute; right: 100%; top: 50%; transform: translateY(-50%); width: 0; opacity: 0; padding: 0; border-width: 0; pointer-events: none; transition: width 0.25s ease, opacity 0.2s ease, padding 0.25s ease, border-width 0.25s ease; overflow: hidden; margin-right: 0; }
.nav-search-wrap.open .nav-search { width: clamp(80px, 15vw, 150px); opacity: 1; padding: 7px 14px; border-width: 1px; pointer-events: auto; margin-right: 6px; }
.nav-search-btn-mobile:hover { color: var(--white); }
.nav-search-mobile-drop.open { display: flex; }
.nav-search-mobile-input { width: 100%; background: #222; border: 1px solid #333; border-radius: 4px; color: var(--white); padding: 10px 14px; font-size: 14px; font-family: 'Inter', sans-serif; outline: none; }
.nav-search-mobile-input:focus { border-color: var(--blue); }
.nav-search-mobile-input::placeholder { color: #555; }


/* ── Gap rules: nav/announce/mobile/footer — below 50-page threshold ── */
:root {
      --orange: #63C0E7;
      --blue:   #63C0E7;
      --blue-dk:#3AABD8;
      --dark:   #111111;
      --dark2:  #1a1a1a;
      --dark3:  #2a2a2a;
      --mid:    #444;
      --muted:  #888;
      --light:  #f5f5f5;
      --white:  #ffffff;
    }

    .dropdown hr { display: none; }

    .dropdown-img-card span {
      display: block;
      color: #ccc;
      font-size: 9px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      margin-top: 8px;
      text-align: center;
      transition: color 0.15s;
    }

    .dropdown-img-card:hover span { color: var(--white); }

    .nav-hamburger {
      display: none;
      flex-direction: column;
      justify-content: center;
      gap: 5px;
      background: none;
      border: none;
      cursor: pointer;
      padding: 4px;
      z-index: 210;
    }
@media (max-width: 1024px) {
  .nav-hamburger { display: flex; }
  .footer-grid { grid-template-columns: 1fr 1fr 1fr; gap: 24px; }
}

    .nav-hamburger span {
      display: block;
      width: 24px;
      height: 2px;
      background: var(--white);
      border-radius: 2px;
      transition: transform 0.25s, opacity 0.25s;
    }

    .nav-hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }

    .nav-hamburger.open span:nth-child(2) { opacity: 0; }

    .nav-hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

    .footer-brand { max-width: 280px; }

    .footer-logo { text-align: left; margin-bottom: 16px; }

    .footer-logo img {
      height: 44px;
      width: auto;
      display: inline-block;
      opacity: 0.8;
      filter: brightness(0) invert(1);
    }

    .footer-address {
      margin-top: 16px;
      font-style: normal;
      font-size: 12px;
      color: #888;
      line-height: 1.8;
    }

    .footer-address a { color: #888; text-decoration: none; transition: color 0.2s; }

    .footer-col h4 {
      font-size: 10px;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: 0.14em;
      color: var(--orange);
      margin-bottom: 18px;
    }

    .footer-bottom p { font-size: 11px; color: #f5f5f5; }

    .dealer-resources-link {
      font-size: 11px;
      color: var(--orange);
      text-decoration: none;
      letter-spacing: 0.03em;
      transition: color 0.2s;
    }

    .dealer-resources-link:hover { color: #3AABD8; }

    .social-links { display: flex; gap: 12px; }

    .social-links a {
      width: 32px;
      height: 32px;
      border: 1px solid #2a2a2a;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      color: #f5f5f5;
      text-decoration: none;
      font-size: 11px;
      font-weight: 700;
      transition: border-color 0.2s, color 0.2s;
    }

      .nav-overlay {
        display: none;
        position: fixed;
        inset: 0;
        background: rgba(0,0,0,0.55);
        backdrop-filter: blur(2px);
        -webkit-backdrop-filter: blur(2px);
        z-index: 398;
      }

      nav.mobile-open .nav-links {
        transform: translateX(0);
        visibility: visible;
        pointer-events: auto;
      }

      .nav-links > li:last-child { border-bottom: none; }

      

      

      

      

      .dropdown-label {
        display: block;
        margin-top: 12px; margin-bottom: 4px;
        font-size: 9px; letter-spacing: 0.14em;
        color: var(--blue);
      }

      .dropdown a {
        display: block;
        padding: 8px 0;
        font-size: 13px;
        color: #777;
        white-space: normal;
        word-break: break-word;
        line-height: 1.4;
        text-decoration: none;
      }

      .dropdown a:hover { color: #fff; }

      

.announce-bar { background: var(--dark); color: var(--orange); text-align: center; font-size: 12px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; padding: 9px 16px; }

/* ── Universal responsive breakpoints ── */
@media (max-width: 1600px) {
  nav { padding: 0 32px; }
  .nav-links { gap: clamp(10px, 1.2vw, 18px); }
  .nav-links > li > a { font-size: clamp(9.5px, 0.85vw, 11.5px); letter-spacing: 0.025em; }
}
@media (max-width: 1200px) {
  .footer-grid { gap: 28px; }
}
@media (max-width: 900px) {
  .footer-grid { grid-template-columns: 1fr 1fr !important; gap: 32px; }
  .footer-bottom { flex-direction: column; gap: 12px; text-align: center; }
}

/* ── Shop grid: border per card instead of background + gap trick
   (eliminates gray rectangles on empty grid cells) ────────────── */
.shop-grid { background: transparent !important; gap: 0 !important; }
.shop-card { border: 1px solid #e0e0e0; }
.shop-section:nth-child(even) .shop-card { border-color: #d4d4d4; }

/* ── Overflow containment (all screen sizes): prevents any section
   child from pushing the document wider than the viewport, which
   causes iOS Safari to zoom-lock on rotation ──────────────────── */
.hero, .story, .features, .gallery, .specs, .shop-section,
.cat-section, .page-header, .products-section, .locator-body,
.search-section, .intl-callout, footer {
  overflow-x: hidden;
  max-width: 100%;
}

@media (max-width: 1024px) {
  /* ── Layout fixes: applies to landscape phones + tablets ─────────
     Matches the hamburger-nav breakpoint so content layout and
     nav mode are always in sync. ──────────────────────────────── */
  .page-header { padding: 48px 40px 40px !important; }
  .products-section { padding: 40px 32px !important; }
  .products-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; gap: 16px !important; }
  .story { padding: 60px 40px !important; grid-template-columns: 1fr !important; gap: 40px !important; }
  .features { padding: 60px 40px !important; }
  .gallery { padding: 60px 40px !important; }
  .specs { grid-template-columns: 1fr !important; padding: 60px 40px !important; gap: 48px !important; }
  .outputs-grid { grid-template-columns: 1fr !important; }
  .shop-section { padding: 60px 40px !important; }
  .shop-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  .cat-section { padding: 48px 40px !important; }
  .hero { padding-left: 40px !important; padding-right: 40px !important; }
  .product-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  .product-card { border: 1px solid #e0e0e0 !important; }
  footer { padding: 48px 40px 28px !important; }
  .footer-grid { grid-template-columns: repeat(3, 1fr) !important; gap: 32px !important; }
  .footer-brand { grid-column: 1 / -1 !important; max-width: 100% !important; }
  .footer-signup { flex-direction: column !important; align-items: flex-start !important; gap: 20px !important; }
  .footer-signup-form { width: 100% !important; }
  .footer-signup-input { flex: 1 !important; min-width: 0 !important; width: 100% !important; }
  .announce-bar { font-size: 10px !important; padding: 8px 16px !important; }

  /* ── Hero: force single-column at mobile nav sizes ──────────── */
  .hero { grid-template-columns: 1fr !important; }
  .hero-content { text-align: center !important; padding: 48px 40px !important; }
  .hero-image { display: none !important; }
  .hero-mobile-img { display: block !important; }
  .hero-bg-number { display: none !important; }
  .hero p { margin-left: auto !important; margin-right: auto !important; }
  .hero-ctas { justify-content: center !important; flex-direction: column !important; align-items: center !important; }
  .hero-ctas .btn-buy {
    font-size: 14px !important;
    padding: 18px 28px !important;
    letter-spacing: 0.1em !important;
    width: 100% !important;
    max-width: 320px !important;
  }

  /* ── Dealer locator ─────────────────────────────────────────── */
  .locator-body {
    flex-direction: column !important;
    height: auto !important;
    min-height: 0 !important;
  }
  #map {
    width: 100% !important;
    height: 50vh !important;
    min-height: 280px !important;
    max-height: 400px !important;
    touch-action: pan-x pan-y !important;
  }
  .dealer-list-panel {
    width: 100% !important;
    border-right: none !important;
    border-top: 1px solid #e8e8e8 !important;
    max-height: 60vh !important;
    order: 2 !important;
  }
}

@media (max-width: 768px) {
  /* ── Tighter padding for portrait phones ─────────────────────── */
  .page-header { padding: 48px 24px 40px !important; }
  .products-section { padding: 40px 20px !important; }
  .story { padding: 60px 24px !important; }
  .features { padding: 60px 24px !important; }
  .gallery { padding: 60px 24px !important; }
  .specs { padding: 60px 24px !important; }
  .shop-section { padding: 60px 24px !important; }
  .cat-section { padding: 48px 24px !important; }
  .hero { padding-left: 24px !important; padding-right: 24px !important; }
  .hero-content { padding: 48px 24px !important; }
  footer { padding: 48px 24px 28px !important; }
  .trust-bar { flex-wrap: wrap !important; }
  .trust-item { min-width: 50% !important; border-right: none !important; border-bottom: 1px solid rgba(0,0,0,0.1) !important; padding: 16px 20px !important; }

  /* ── Card centering for narrow screens ───────────────────────── */
  .shop-card-body { align-items: center !important; text-align: center !important; padding: 16px 14px 20px !important; }
  .shop-card-badge { align-self: center !important; }
  .shop-card-actions { justify-content: center !important; }
  .shop-card-image img { padding: 16px !important; }
  .card-body { align-items: center !important; text-align: center !important; padding: 16px 14px 20px !important; }
  .card-model { align-self: center !important; }
  .card-actions { justify-content: center !important; }
  .card-image img { padding: 16px !important; }
}
@media (max-width: 480px) {
  .nav-cart-label { display: none; }
  .footer-grid { grid-template-columns: 1fr 1fr !important; }
  .announce-bar { font-size: 11px; padding: 8px 12px; }
  .hero h1 { font-size: clamp(48px, 20vw, 80px); }
}
@media (max-width: 1024px) {
  .product-detail { grid-template-columns: 1fr !important; }
  .manual-cta { grid-template-columns: 1fr !important; }
  .manual-col { padding: 40px 24px !important; border-right: none !important; }
  .video-thumbs { flex-wrap: wrap !important; }
}
@media (max-width: 1024px) {
  .manual-col-inner { flex-direction: column !important; }
  .manual-preview img { max-width: 100% !important; height: auto !important; }
  .video-thumbs { overflow-x: auto !important; -webkit-overflow-scrolling: touch !important; }
  .product-info { overflow-x: hidden !important; max-width: 100% !important; }
  .product-detail { overflow: hidden !important; }
}
.product-info { background: var(--white) !important; }
@media (max-width: 1024px) {
  .gallery-grid { grid-template-columns: 1fr 1fr !important; }
  .dist-grid { grid-template-columns: 1fr 1fr !important; }
  .difference-grid { grid-template-columns: 1fr !important; }
}
@media (max-width: 1024px) {
  .distributors { padding: 40px 24px 60px !important; }
  .dist-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; gap: 12px !important; }
  .dist-card { word-wrap: break-word !important; overflow-wrap: break-word !important; }
  .region-block { margin-bottom: 40px !important; }
}
@media (max-width: 480px) {
  .dist-grid { grid-template-columns: 1fr !important; }
}
.announce-bar { position: relative; z-index: 500; }
@media (max-width: 1024px) {
  .ps-card-actions { flex-direction: column !important; }
  .btn-buy, .btn-learn, .btn-dealer { font-size: 9px !important; padding: 10px 8px !important; letter-spacing: 0.05em !important; }
}
@media (max-width: 1024px) {
  .product-info .btn-buy {
    font-size: 14px !important;
    padding: 18px 28px !important;
    letter-spacing: 0.1em !important;
    width: 100% !important;
  }
  .product-info .btn-outline {
    font-size: 12px !important;
    padding: 13px 22px !important;
    letter-spacing: 0.06em !important;
    width: 100% !important;
  }
}
@media (max-width: 1024px) {
  .compare-image-section { padding: 40px 24px 0 !important; }
  .compare-table-section { padding: 40px 24px !important; }
  table.compare { display: block !important; overflow-x: auto !important; -webkit-overflow-scrolling: touch !important; }
  .cards-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
table.compare thead th:first-child,
table.compare td:first-child {
  position: sticky !important;
  left: 0 !important;
  background: var(--white) !important;
  z-index: 2 !important;
}
table.compare tbody tr:nth-child(even) td:first-child {
  background: var(--light) !important;
}
@media (max-width: 480px) {
  .cards-grid { grid-template-columns: 1fr !important; }
}

/* ── Scroll hint arrow ───────────────────────────────────── */

/* ── Table scroll indicator ──────────────────────────────── */
.table-scroll-wrap {
  position: sticky;
  top: 64px;
  z-index: 10;
  width: 45%;
  margin: 16px auto 20px;
}
.table-scroll-track {
  width: 100%;
  height: 8px;
  background: rgba(99,192,231,0.15);
  border-radius: 4px;
  position: relative;
  overflow: visible;
  cursor: pointer;
  touch-action: none;
}
.table-scroll-fill {
  height: 100%;
  background: var(--blue);
  border-radius: 4px;
  width: 0%;
  transition: width 0.1s ease-out;
  pointer-events: none;
}
.table-scroll-arrow {
  position: absolute;
  top: -20px;
  left: 0%;
  transform: translateX(-50%);
  font-size: 16px;
  color: var(--blue);
  pointer-events: none;
  opacity: 0;
  filter: drop-shadow(0 0 4px var(--blue));
}
@keyframes scrollGlow {
  0% { left: -100%; opacity: 0; }
  20% { opacity: 1; }
  100% { left: 100%; opacity: 0; }
}
.table-scroll-track .glow {
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, var(--blue), rgba(99,192,231,0.6), transparent);
  animation: scrollGlow 1.5s ease-in-out forwards;
  pointer-events: none;
  border-radius: 4px;
  box-shadow: 0 0 12px var(--blue), 0 0 24px rgba(99,192,231,0.4);
}
@keyframes fillNudge {
  0% { width: 0%; }
  40% { width: 35%; }
  60% { width: 20%; }
  80% { width: 30%; }
  100% { width: 0%; }
}
@keyframes arrowNudge {
  0% { left: 0%; opacity: 1; }
  40% { left: 35%; opacity: 1; }
  60% { left: 20%; opacity: 1; }
  80% { left: 30%; opacity: 1; }
  95% { left: 0%; opacity: 1; }
  100% { left: 0%; opacity: 0; }
}

/* ── Mobile nav drawer (global) ──────────────────────────── */
@media (max-width: 1024px) {
  .nav-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.55);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    z-index: 398;
  }
  .nav-links {
    position: fixed !important;
    right: 0 !important;
    width: min(300px, 82vw) !important;
    
    flex-direction: column !important;
    justify-content: flex-start !important;
    background: #141414 !important;
    padding: 0 0 32px !important;
    gap: 0 !important;
    z-index: 400 !important;
    overflow-y: scroll !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch;
    overflow-anchor: none;
    transform: translateX(100%) !important;
    transition: transform 0.32s cubic-bezier(0.22, 1, 0.36, 1) !important;
    box-shadow: -8px 0 40px rgba(0,0,0,0.6) !important;
    border-left: 1px solid #222 !important;
    display: flex !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }
  nav.mobile-open .nav-links {
    transform: translateX(0) !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }
  .nav-links > li {
    height: auto !important;
    width: 100% !important;
    border-bottom: 1px solid rgba(255,255,255,0.05) !important;
    flex-shrink: 0 !important;
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
  }
  .nav-links > li:last-child { border-bottom: none !important; }
  .nav-links > li > a {
    padding: 16px 28px !important;
    font-size: 13px !important;
    letter-spacing: 0.05em !important;
    width: 100% !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
  }
  .dropdown {
    min-height: fit-content !important;
    position: static !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
    box-shadow: none !important;
    border-top: none !important;
    transition: none !important;
    display: none !important;
    flex-direction: column !important;
    width: 100% !important;
    background: rgba(0,0,0,0.3) !important;
    border-left: 3px solid var(--blue) !important;
    padding: 6px 0 12px 20px !important;
    gap: 0 !important;
    overflow: visible !important;
    min-width: 0 !important;
  }
  .nav-links > li.dropdown-open > .dropdown {
    display: flex !important;
  }
  .dropdown-group { min-width: 0 !important; width: 100% !important; flex: none !important; }
  .dropdown-ghost { display: none !important; }
  .dropdown-images { display: none !important; }
  .nav-links > li.dropdown-open > a .chevron {
    transform: rotate(180deg) !important;
    opacity: 1 !important;
  }
}
.form-group label { color: #ccc !important; }
.form-group label .req { color: var(--blue) !important; }
#map { position: relative; z-index: 1; }
.locator-body { position: relative; z-index: 1; }
@media (max-width: 1024px) {
  .dealer-list-panel { display: flex !important; flex-direction: column !important; min-height: 300px !important; }
  .dealer-list { flex: 1 !important; overflow-y: auto !important; }
}
#map { touch-action: none !important; }
.leaflet-container { touch-action: none !important; }
.leaflet-control-attribution { font-size: 8px !important; background: rgba(255,255,255,0.4) !important; color: #aaa !important; box-shadow: none !important; padding: 2px 5px !important; }
.leaflet-control-attribution a { color: #aaa !important; }
@media (max-width: 1024px) {
  .contact-section { padding: 40px 24px !important; grid-template-columns: 1fr !important; gap: 40px !important; }
  .info-section { padding: 40px 24px !important; }
  .intro-band { padding: 40px 24px !important; flex-direction: column !important; }
  .intro-callout { width: 100% !important; }
  .contact-form-col, .contact-info-col { width: 100% !important; }
}
.contact-section { background: var(--white) !important; }
.contact-form-col, .contact-info-col { background: var(--white) !important; }
@media (max-width: 1024px) {
  .nav-links { max-height: calc(100dvh - 60px) !important; overflow-y: auto !important; }
}
@media (max-width: 1024px) {
  .featured-section { padding: 0 24px 40px !important; }
  .featured-grid { grid-template-columns: 1fr !important; gap: 16px !important; }
  .roster-section { padding: 40px 24px !important; }
}
.faq-content { background: var(--white) !important; }
.faq-body { background: var(--white) !important; }
