

.ch-service-strip{
  background:#8DE635; /* tweak to match your exact green */
  color:#0D1729;
  position: relative;
  z-index: 0;
}

.ch-service-item{
  padding:14px 14px;
  text-align:center;
}

.ch-service-title{
  font-weight:800;
  font-size:18px;
  line-height:1.1;
}

.ch-service-sub{
  margin-top:4px;
  font-size:14px;
  line-height:1.2;
  opacity:0.95;
}

/* separators on desktop only */
@media (min-width: 992px){
  .ch-service-item + .ch-service-item{
    border-left:1px solid #0D1729;
  }
}

/* a bit tighter on small screens */
@media (max-width: 575.98px){
  .ch-service-title{ font-size:16px; }
  .ch-service-sub{ font-size:13px; }
}

/* =========================================================
   HEADER RIGHT: language/currency/account/cart in one row
   ========================================================= */
#header .tv-contact-account-cart-wrapper{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:12px;
  flex-wrap:nowrap;
}
#header .tvcms-header-lang,
#header .tvcms-header-currency{
  white-space:nowrap;
}

/* =========================================================
   Language + Currency dropdowns should overlay (ThemeVolty)
   ========================================================= */
#header #_desktop_language_selector,
#header #_desktop_currency_selector{
  position: relative;
}
#header #_desktop_language_selector ul.tv-language-dropdown,
#header #_desktop_currency_selector ul.tv-currency-dropdown{
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  left: auto;
  margin: 0;
  z-index: 4000;
}

/* =========================================================
   Z-index order: menu < search/account < language/currency
   ========================================================= */
#header{ position: relative; z-index: 1000; }

/* Megamenu dropdowns (lower than other dropdowns) */
#header #tvdesktop-megamenu ul.menu-dropdown,
#header #tvdesktop-megamenu .tv-sub-menu.menu-dropdown{
  z-index: 1500;
}

/* Search dropdown above menu (DO NOT change its positioning here) */
#header #_desktop_search{ position: relative; z-index: 2500; }

/* Account dropdown above menu */
#header .tvcms-header-myaccount{ position: relative; z-index: 2600; }
#header .tvcms-header-myaccount .tv-account-dropdown{ z-index: 2601; }

/* Language/Currency highest */
#header #_desktop_language_selector,
#header #_desktop_currency_selector{ z-index: 3000; }

/* =========================================================
   Service strip hidden on mobile
   ========================================================= */
@media (max-width: 991.98px){
  .ch-service-strip{ display:none !important; }
}

/* Add neon down arrow after menu text (desktop only) */
@media (min-width: 992px) {
  #tvdesktop-megamenu li.level-1:has(> span.icon-drop-mobile) > a > span::after{ content: " \25BE"; color: #8DE635; font-size: 0.85em; margin-left: 6px; position: relative; top: -1px; }
}

/* Kill CSS-injected icon arrows */ #tv-menu-horizontal li.level-1 > a::after, #tv-menu-horizontal li.parent > a::after, #tvdesktop-megamenu li.level-1 > a::after, #tvdesktop-megamenu li.parent > a::after{ content: none !important; display: none !important; }

/* Center the TOP LEVEL megamenu items (desktop only) */
@media (min-width: 992px) {
  #tv-menu-horizontal > ul.menu-content{
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    width: 100%;
  }

  /* Kill float behaviour on the top-level items (common in ThemeVolty) */
  #tv-menu-horizontal > ul.menu-content > li.level-1,
  #tv-menu-horizontal > ul.menu-content > li.tvmega-menu-title{
    float: none !important;
  }

  /* Optional: give items a consistent spacing */
  #tv-menu-horizontal > ul.menu-content > li{
    margin: 0 14px; /* tweak */
  }

  /* If the menu title "Mega Menu" should NOT be included in the centering, hide it */
  #tv-menu-horizontal > ul.menu-content > li.tvmega-menu-title{
    display: none !important;
  }
}

/* Mobile: stack menu items vertically in sidebar */
@media (max-width: 991px) {
  #tv-menu-horizontal > ul.menu-content{
    display: block !important;
    width: 100%;
  }
  #tv-menu-horizontal > ul.menu-content > li{
    margin: 0;
  }
  #tv-menu-horizontal > ul.menu-content > li.tvmega-menu-title{
    display: none !important;
  }
}
/* SPORTY/PUNCHY BRAND MARQUEE */
.ch-brands-marquee{ margin: 26px 0 10px; }

.ch-marquee{
  position: relative;
  overflow: hidden;
  border-radius: 16px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.10);
}

/* edge fades */
.ch-marquee::before,
.ch-marquee::after{
  content:"";
  position:absolute;
  top:0; bottom:0;
  width: 110px;
  z-index: 2;
  pointer-events:none;
}
.ch-marquee::before{
  left:0;
  background: linear-gradient(90deg, rgba(13,23,41,1) 0%, rgba(13,23,41,0) 100%);
}
.ch-marquee::after{
  right:0;
  background: linear-gradient(270deg, rgba(13,23,41,1) 0%, rgba(13,23,41,0) 100%);
}

/* the moving strip */
.ch-marquee-track{
  display:flex !important;
  width: max-content !important;
  will-change: transform;
  animation: chMarquee 40s linear infinite !important; /* faster = punchier */
  transform: translate3d(0,0,0);
}

.ch-marquee-group{
  display:flex;
  align-items:center;
  gap: 64px;
  padding: 18px 28px;
  white-space: nowrap;
  flex: 0 0 auto;
}

/* BIG, punchy text */
.ch-brand{
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: 52px;
  line-height: 1;
  text-decoration: none !important;

  color: rgba(234,240,255,.78);
  text-shadow: 0 2px 0 rgba(0,0,0,.35);
  transform: skewX(-8deg);
}

.ch-brand:hover{
  color: #EAF0FF;
  text-shadow: 0 0 0 rgba(0,0,0,0), 0 0 18px rgba(196,253,3,.18);
}

/* Pause on hover (optional) */
.ch-marquee:hover .ch-marquee-track{
  animation-play-state: paused;
}

@keyframes chMarquee{
  from { transform: translate3d(0,0,0); }
  to   { transform: translate3d(-50%,0,0); } /* because we duplicated the group */
}

/* scale down on smaller screens */
@media (max-width: 991.98px){
  .ch-brand{ font-size: 34px; }
  .ch-marquee-group{ gap: 36px; }
  .ch-marquee::before, .ch-marquee::after{ width: 80px; }
}
@media (max-width: 575.98px){
  .ch-brand{ font-size: 26px; }
}
/* Featured products: 16 desktop (8x2), 8 tablet (4x2), 4 mobile (2x2) */
.ch-featured-grid{
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

/* Tablet: 4 across, but only show 8 items total */
@media (max-width: 991.98px){
  .ch-featured-grid{
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  .ch-featured-item:nth-child(n+9){
    display: none;
  }
}

/* Mobile: 2 across, but only show 4 items total */
@media (max-width: 575.98px){
  .ch-featured-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .ch-featured-item:nth-child(n+5){
    display: none;
  }
}
/* Force grid even if theme tries to make product lists into flex/slider */
.ch-featured-grid{
  display:grid !important;
  gap:12px;
  grid-template-columns:repeat(6, minmax(0, 1fr));
  overflow:visible !important;
}

/* Kill common slider/flex behaviours applied to children */
.ch-featured-grid > .ch-featured-item{
  width:auto !important;
  max-width:none !important;
  flex:none !important;
  min-width:0 !important;
}

/* Make sure the included product miniature doesn't force fixed widths */
.ch-featured-grid .product-miniature{
  width:100% !important;
}

/* Tablet: 4 across, show 8 total */
@media (max-width: 991.98px){
  .ch-featured-grid{ grid-template-columns:repeat(4, minmax(0, 1fr)); }
  .ch-featured-item:nth-child(n+9){ display:none; }
}

/* Mobile: 2 across, show 4 total */
@media (max-width: 575.98px){
  .ch-featured-grid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
  .ch-featured-item:nth-child(n+5){ display:none; }
}

/* =========================================================
   CUSTOM HAMBURGER - Animated bars to X
   ========================================================= */
@media (max-width: 991px) {

  /* Hide the default Material Icon */
  .tvmobile-sliderbar-btn a i,
  .tvmobile-sliderbar-btn a .material-icons,
  .tvmobile-sliderbar-btn a svg,
  #tvcms-mobile-view-header .tvmobile-sliderbar-btn a i,
  #tvcms-mobile-view-header .tvmobile-sliderbar-btn a .material-icons,
  #tvcms-mobile-view-header .tvmobile-sliderbar-btn a svg {
    display: none !important;
  }

  /* The tap target */
  .tvmobile-sliderbar-btn a,
  #tvcms-mobile-view-header .tvmobile-sliderbar-btn a {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 44px !important;
    height: 44px !important;
    position: relative;
    padding: 0 !important;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
    background-color: transparent !important;
    color: transparent !important;
    border: none !important;
  }

  /* Top and bottom bars */
  .tvmobile-sliderbar-btn a::before,
  .tvmobile-sliderbar-btn a::after,
  #tvcms-mobile-view-header .tvmobile-sliderbar-btn a::before,
  #tvcms-mobile-view-header .tvmobile-sliderbar-btn a::after {
    content: "" !important;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    width: 26px;
    height: 3px;
    border-radius: 2px;
    background: #8DE635 !important;
    transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 0 6px rgba(141, 230, 53, 0.25);
  }

  /* Top bar */
  .tvmobile-sliderbar-btn a::before,
  #tvcms-mobile-view-header .tvmobile-sliderbar-btn a::before {
    top: 12px;
  }

  /* Bottom bar */
  .tvmobile-sliderbar-btn a::after,
  #tvcms-mobile-view-header .tvmobile-sliderbar-btn a::after {
    bottom: 12px;
  }

  /* Parent container */
  .tvmobile-sliderbar-btn,
  #tvcms-mobile-view-header .tvmobile-sliderbar-btn {
    position: relative;
  }

  /* ---- OPEN STATE ---- */

  .mobile-menu-open .tvmobile-sliderbar-btn a::before,
  .mobile-menu-open #tvcms-mobile-view-header .tvmobile-sliderbar-btn a::before {
    top: 50%;
    transform: translateX(-50%) translateY(-50%) rotate(45deg);
    background: #ffffff !important;
    box-shadow: 0 0 8px rgba(255, 255, 255, 0.3);
  }

  .mobile-menu-open .tvmobile-sliderbar-btn a::after,
  .mobile-menu-open #tvcms-mobile-view-header .tvmobile-sliderbar-btn a::after {
    bottom: 50%;
    transform: translateX(-50%) translateY(50%) rotate(-45deg);
    background: #ffffff !important;
    box-shadow: 0 0 8px rgba(255, 255, 255, 0.3);
  }
}

/* Middle bar via background gradient */
@media (max-width: 991px) {
  .tvmobile-sliderbar-btn a,
  #tvcms-mobile-view-header .tvmobile-sliderbar-btn a {
    background-image: linear-gradient(#8DE635, #8DE635) !important;
    background-size: 26px 3px !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    transition: background-size 0.25s cubic-bezier(0.4, 0, 0.2, 1),
                background-color 0.25s ease;
    border-radius: 8px;
  }

  .tvmobile-sliderbar-btn a:active,
  #tvcms-mobile-view-header .tvmobile-sliderbar-btn a:active {
    background-color: rgba(141, 230, 53, 0.08) !important;
  }

  .mobile-menu-open .tvmobile-sliderbar-btn a,
  .mobile-menu-open #tvcms-mobile-view-header .tvmobile-sliderbar-btn a {
    background-size: 0px 3px !important;
  }
}

/* ============================================================
   CH FOOTER REDESIGN - CSS OVERRIDES
   Add this via a custom CSS module, or include in your theme's
   custom.css / global.css file.
   ============================================================ */

/* ----- Reset existing theme footer styles ----- */
.ch-footer-redesign {
    background: #0E1527 !important;
    background-image: none !important;
    padding: 0 !important;
    overflow-x: hidden !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

.ch-footer-redesign *,
.ch-footer-redesign *::before,
.ch-footer-redesign *::after {
    box-sizing: border-box !important;
}

.ch-footer-redesign .tvfooter-logo-link-wrapper {
    padding: 0;
}

/* Hide the old layout wrappers if they still render */
.ch-footer-redesign .tvfooter-storelogo-weapper,
.ch-footer-redesign .tvfooter-storelogo-inner,
.ch-footer-redesign .tvfooter-storelogo-imformation,
.ch-footer-redesign .tvfooter-copy-payment-icon-wrapper,
.ch-footer-redesign .tvfooter-copy-payment-icon-content,
.ch-footer-redesign .tvfooter-copy-payment-icon-inner {
    display: none !important;
}


/* =============================================
   LOGO SECTION
   ============================================= */
.ch-footer-logo-section {
    padding: 40px 0 24px;
    text-align: center;
}

.ch-footer-logo-inner {
    display: flex;
    justify-content: center;
    align-items: center;
}

.ch-footer-logo-inner img {
    max-height: 70px;
    width: auto;
}


/* =============================================
   MAIN COLUMNS - 4-COLUMN GRID
   ============================================= */
.ch-footer-columns-section {
    padding: 40px 0 40px;
}

/* Hide the logo section if it still renders */
.ch-footer-logo-section {
    display: none !important;
}

.ch-footer-columns {
    display: grid;
    grid-template-columns: 1.3fr 1fr 0.8fr 1.4fr;
    gap: 32px;
    max-width: 1200px;
    margin: 0 auto;
}

/* Column base styles */
.ch-footer-col {
    min-width: 0;
}

/* ----- CRITICAL: Reset Bootstrap column widths from hook module outputs ----- */
/* The modules output their own col-xl-2, col-xl-3, col-xl-4 etc. wrappers     */
/* which would constrain content to ~16%/25%/33% inside our CSS Grid cells.     */
/* We force them all to full width so they fill their grid cell properly.        */
.ch-footer-col [class*="col-xl-"],
.ch-footer-col [class*="col-lg-"],
.ch-footer-col [class*="col-md-"],
.ch-footer-col [class*="col-sm-"] {
    width: 100% !important;
    max-width: 100% !important;
    flex: 0 0 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* Also reset in the bottom bar */
.ch-footer-bottom-inner [class*="col-xl-"],
.ch-footer-bottom-inner [class*="col-lg-"],
.ch-footer-bottom-inner [class*="col-md-"],
.ch-footer-bottom-inner [class*="col-sm-"] {
    width: auto !important;
    max-width: none !important;
    flex: none !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* ----- Hide currency selector from footer logo area ----- */
/* It's already in the header and the geo popup, no need to repeat it here */
.ch-footer-logo-section .tvheader-currency-wrapper,
.ch-footer-logo-section #tvcmsdesktop-currency-selector {
    display: none !important;
}

/* ----- Footer title rendered by theme module (tvfooter-title) ----- */
.ch-footer-col .tvfooter-title {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #8DE636 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
}

/* ----- Hide collapse toggle icons on desktop ----- */
.ch-footer-col .tvfooter-toggle-icon-wrapper,
.ch-footer-col .tvfooter-toggle-icon {
    display: none !important;
}

/* ----- Ensure link lists inside hook wrappers are visible ----- */
.ch-footer-col .collapse {
    display: block !important;
    height: auto !important;
}

/* ----- Footer title wrapper spacing ----- */
.ch-footer-col .tvfooter-title-wrapper {
    margin-bottom: 16px !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
    cursor: default !important;
}

/* ----- Account block specific ----- */
.ch-footer-col #block_myaccount_infos {
    width: 100% !important;
    max-width: 100% !important;
    flex: none !important;
    padding: 0 !important;
}

/* ----- Column headings (target hook-rendered h3/h4 and our custom title) ----- */
.ch-footer-col h3,
.ch-footer-col h4,
.ch-footer-col .h3,
.ch-footer-col .title_block,
.ch-footer-col .block-title,
.ch-footer-col .myaccount-title,
.ch-footer-col .ch-footer-col-title,
.ch-footer-col .tvnewsletter-title,
.ch-footer-col .tvfooter-title {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #8DE636 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    margin-bottom: 16px !important;
    padding: 0 !important;
    background: none !important;
    border: none !important;
}

/* ----- Links inside columns ----- */
.ch-footer-col a {
    display: block;
    font-size: 13px;
    color: rgba(255, 255, 255, 0.65) !important;
    text-decoration: none !important;
    padding: 4px 0 !important;
    line-height: 1.5;
    transition: color 0.2s ease;
}

.ch-footer-col a:hover {
    color: #fff !important;
    text-decoration: none !important;
}

/* ----- List resets inside columns ----- */
.ch-footer-col ul,
.ch-footer-col ol {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.ch-footer-col li {
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
}

/* Remove any expand/collapse arrows the theme may add */
.ch-footer-col .collapse-icons,
.ch-footer-col .navbar-toggler,
.ch-footer-col [data-toggle="collapse"] i,
.ch-footer-col .material-icons.add,
.ch-footer-col .material-icons.remove {
    display: none !important;
}


/* =============================================
   SHOP BY SPORT COLUMN
   ============================================= */
.ch-footer-sport-links ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.ch-footer-sport-links li {
    padding: 0;
    margin: 0;
}

.ch-footer-sport-links a {
    display: block;
    font-size: 13px;
    color: rgba(255, 255, 255, 0.65) !important;
    text-decoration: none;
    padding: 4px 0;
    line-height: 1.5;
    transition: color 0.2s ease;
}

.ch-footer-sport-links a:hover {
    color: #fff !important;
}


/* =============================================
   NEWSLETTER COLUMN
   ============================================= */
.ch-footer-col--newsletter .block_newsletter p,
.ch-footer-col--newsletter .block_newsletter .newsletter-description,
.ch-footer-col--newsletter [class*="newsletter"] p {
    font-size: 13px !important;
    color: rgba(255, 255, 255, 0.55) !important;
    line-height: 1.5 !important;
    margin-bottom: 12px !important;
}

.ch-footer-col--newsletter input[type="email"],
.ch-footer-col--newsletter input[type="text"],
.ch-footer-col--newsletter .form-control {
    background: rgba(255, 255, 255, 0.06) !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    border-right: none !important;
    border-radius: 4px 0 0 4px !important;
    color: #fff !important;
    font-size: 13px !important;
    padding: 10px 14px !important;
    height: auto !important;
    outline: none !important;
    box-shadow: none !important;
    width: 100% !important;
    min-width: 0 !important;
    flex: 1 !important;
}

.ch-footer-col--newsletter input[type="email"]::placeholder,
.ch-footer-col--newsletter input[type="text"]::placeholder,
.ch-footer-col--newsletter .form-control::placeholder {
    color: rgba(255, 255, 255, 0.35) !important;
}

.ch-footer-col--newsletter input[type="email"]:focus,
.ch-footer-col--newsletter input[type="text"]:focus,
.ch-footer-col--newsletter .form-control:focus {
    border-color: rgba(141, 230, 54, 0.5) !important;
    box-shadow: none !important;
}

.ch-footer-col--newsletter button[type="submit"],
.ch-footer-col--newsletter .btn-subscribe,
.ch-footer-col--newsletter .btn-primary,
.ch-footer-col--newsletter input[type="submit"] {
    background: #8DE636 !important;
    color: #0E1527 !important;
    border: none !important;
    border-radius: 0 4px 4px 0 !important;
    padding: 10px 18px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    text-transform: uppercase !important;
    letter-spacing: 0.3px !important;
    white-space: nowrap !important;
    transition: background 0.2s ease !important;
}

.ch-footer-col--newsletter button[type="submit"]:hover,
.ch-footer-col--newsletter .btn-subscribe:hover,
.ch-footer-col--newsletter .btn-primary:hover,
.ch-footer-col--newsletter input[type="submit"]:hover {
    background: #7dd02e !important;
}

/* Newsletter form row */
.ch-footer-col--newsletter form {
    display: flex !important;
    flex-wrap: wrap !important;
}

/* The input+button row should be full width within the form */
.ch-footer-col--newsletter .tvnewsleeter-input-button-wraper {
    display: flex !important;
    flex-wrap: nowrap !important;
    width: 100% !important;
}

/* Input takes remaining space */
.ch-footer-col--newsletter .input-wrapper {
    flex: 1 !important;
    min-width: 0 !important;
}

.ch-footer-col--newsletter .input-wrapper input {
    width: 100% !important;
}

/* Newsletter description text - must be full width to drop below input row */
.ch-footer-col--newsletter .tvnewsletter-description {
    width: 100% !important;
    flex-basis: 100% !important;
}

.ch-footer-col--newsletter .tvnewsletter-description,
.ch-footer-col--newsletter .tvnewsletter-description p {
    font-size: 13px !important;
    color: rgba(255, 255, 255, 0.55) !important;
    line-height: 1.5 !important;
    margin-top: 8px !important;
}

/* Newsletter label wrapper */
.ch-footer-col--newsletter .tvnewsletter-lable-wrapper {
    margin-bottom: 12px !important;
}

/* Newsletter title - force green to match other column headings */
.ch-footer-col--newsletter .tvnewsletter-title,
.ch-footer-col--newsletter #block-newsletter-label,
.ch-footer-col--newsletter .tvnewsletter-lable-wrapper p {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #8DE636 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    margin-bottom: 0 !important;
}

/* Newsletter inner wrappers - reset any width/padding constraints */
.ch-footer-col--newsletter .tvcms-newsletter-inner,
.ch-footer-col--newsletter .tvcms-newsletter-wrapper,
.ch-footer-col--newsletter .tv-newsletter-wrapeer,
.ch-footer-col--newsletter .tvnewsletter-block,
.ch-footer-col--newsletter .tvnewsletter-input {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* Newsletter button wrapper inside form */
.ch-footer-col--newsletter .tvnewsleteer-btn-wrapper {
    flex-shrink: 0;
}

.ch-footer-col--newsletter .tvnewsleteer-btn-wrapper .tvall-inner-btn {
    background: #8DE636 !important;
    color: #0E1527 !important;
    border: none !important;
    border-radius: 0 4px 4px 0 !important;
    padding: 10px 18px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    text-transform: uppercase !important;
    letter-spacing: 0.3px !important;
    white-space: nowrap !important;
    transition: background 0.2s ease !important;
    height: 100% !important;
}

.ch-footer-col--newsletter .tvnewsleteer-btn-wrapper .tvall-inner-btn:hover {
    background: #7dd02e !important;
}

/* Conditions/GDPR text */
.ch-footer-col--newsletter .condition,
.ch-footer-col--newsletter .gdpr_consent {
    font-size: 11px !important;
    color: rgba(255, 255, 255, 0.35) !important;
    margin-top: 8px !important;
}

.ch-footer-col--newsletter .condition a,
.ch-footer-col--newsletter .gdpr_consent a {
    color: rgba(255, 255, 255, 0.5) !important;
    display: inline !important;
    padding: 0 !important;
    font-size: 11px !important;
}


/* =============================================
   GO TO TOP BUTTON - repositioned to bottom-left
   to avoid overlap with WhatsApp widget
   ============================================= */
.ch-footer-redesign .tvbottom-to-top {
    text-align: center;
    padding: 0 0 24px;
}

.ch-footer-redesign .tvbottom-to-top-icon {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: rgba(255, 255, 255, 0.4);
    font-size: 12px;
    text-decoration: none;
    transition: color 0.2s ease;
}

.ch-footer-redesign .tvbottom-to-top-icon:hover {
    color: #8DE636;
}

.ch-footer-redesign .tvbottom-to-top-icon .material-icons {
    font-size: 18px;
}

/* Hide the back-to-top button completely */
.tvbottom-to-top,
div.tvbottom-to-top,
.footer-container .tvbottom-to-top,
footer .tvbottom-to-top,
footer#footer .tvbottom-to-top {
    display: none !important;
}


/* =============================================
   BOTTOM BAR - COPYRIGHT + PAYMENT ICONS
   ============================================= */
.ch-footer-bottom-bar {
    background: rgba(0, 0, 0, 0.2);
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding: 20px 0;
}

.ch-footer-bottom-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
    text-align: center;
}

/* Copyright text */
.ch-footer-bottom-inner .copyright,
.ch-footer-bottom-inner .tvcopyright-text,
.ch-footer-bottom-inner .tvcopylink,
.ch-footer-bottom-inner [class*="copyright"] {
    font-size: 12px !important;
    color: rgba(255, 255, 255, 0.4) !important;
    order: 1;
}

.ch-footer-bottom-inner .copyright a,
.ch-footer-bottom-inner .tvcopyright-text a,
.ch-footer-bottom-inner .tvcopylink a,
.ch-footer-bottom-inner [class*="copyright"] a {
    color: rgba(255, 255, 255, 0.5) !important;
    display: inline !important;
    padding: 0 !important;
    font-size: 12px !important;
}

.ch-footer-bottom-inner .tvcopylink p {
    font-size: 12px !important;
    color: rgba(255, 255, 255, 0.4) !important;
    margin: 0 !important;
}

/* Payment icons - SVG icons */
.ch-payment-icons {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 10px !important;
    order: 2;
}

.ch-pay-icon {
    width: 52px;
    max-width: 52px;
    height: 34px;
    flex: 0 0 52px;
    overflow: hidden;
    opacity: 0.9;
    transition: opacity 0.2s ease;
}

.ch-pay-icon:hover {
    opacity: 1;
}

.ch-pay-icon svg {
    width: 52px;
    max-width: 52px;
    height: 34px;
    display: block;
    border-radius: 4px;
}

/* Hide old payment icon hook output if it still renders */
.ch-footer-bottom-inner .tvfooter-payment-icon-img-block,
.ch-footer-bottom-inner .tvpayment-icon,
.ch-footer-bottom-inner [class*="payment-icon"]:not(.ch-payment-icons):not(.ch-pay-icon) {
    display: none !important;
}

/* Social media in bottom bar */
.ch-footer-bottom-inner [class*="social"] {
    order: 3;
}

.ch-footer-bottom-inner [class*="social"] a {
    display: inline-flex !important;
    padding: 0 6px !important;
    color: rgba(255, 255, 255, 0.4) !important;
    font-size: 16px !important;
}

.ch-footer-bottom-inner [class*="social"] a:hover {
    color: #8DE636 !important;
}


/* =============================================
   RESPONSIVE - TABLET (< 1200px)
   ============================================= */
@media (max-width: 1199px) {
    .ch-footer-columns {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 24px 32px;
    }
}


/* =============================================
   RESPONSIVE - MOBILE (< 768px)
   ============================================= */
@media (max-width: 767px) {

    /* Prevent horizontal overflow */
    .ch-footer-redesign {
        overflow-x: hidden !important;
    }

    .ch-footer-redesign .container {
        padding-left: 15px !important;
        padding-right: 15px !important;
        overflow: hidden !important;
    }

    .ch-footer-columns-section {
        padding: 20px 0 20px;
    }

    .ch-footer-columns {
        grid-template-columns: 1fr !important;
        gap: 0;
    }

    /* Each column stacks with a subtle divider */
    .ch-footer-col {
        border-bottom: 1px solid rgba(255, 255, 255, 0.06);
        padding: 14px 0;
        overflow: hidden !important;
    }

    .ch-footer-col:last-child {
        border-bottom: none;
    }

    /* Column headings on mobile */
    .ch-footer-col h3,
    .ch-footer-col h4,
    .ch-footer-col .h3,
    .ch-footer-col .title_block,
    .ch-footer-col .block-title,
    .ch-footer-col .myaccount-title,
    .ch-footer-col .ch-footer-col-title,
    .ch-footer-col .tvnewsletter-title,
    .ch-footer-col .tvfooter-title,
    .ch-footer-col #block-newsletter-label,
    .ch-footer-col .tvnewsletter-lable-wrapper p {
        margin-bottom: 10px !important;
        font-size: 13px !important;
        color: #8DE636 !important;
    }

    .ch-footer-col a {
        font-size: 13px;
        padding: 3px 0 !important;
    }

    /* Newsletter: force all wrappers to behave */
    .ch-footer-redesign .ch-footer-col--newsletter,
    .ch-footer-redesign .ch-footer-col--newsletter .block_newsletter,
    .ch-footer-redesign .ch-footer-col--newsletter .tvcms-newsletter-inner,
    .ch-footer-redesign .ch-footer-col--newsletter .tvcms-newsletter-wrapper,
    .ch-footer-redesign .ch-footer-col--newsletter .tv-newsletter-wrapeer,
    .ch-footer-redesign .ch-footer-col--newsletter .tvnewsletter-block,
    .ch-footer-redesign .ch-footer-col--newsletter .tvnewsletter-input {
        display: block !important;
        width: 100% !important;
        max-width: 100% !important;
        float: none !important;
        overflow: hidden !important;
        box-sizing: border-box !important;
    }

    .ch-footer-redesign .ch-footer-col--newsletter form {
        display: flex !important;
        flex-wrap: wrap !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    .ch-footer-redesign .ch-footer-col--newsletter .tvnewsleeter-input-button-wraper {
        display: flex !important;
        flex-wrap: nowrap !important;
        width: 100% !important;
        max-width: 100% !important;
        flex-direction: row !important;
        box-sizing: border-box !important;
    }

    .ch-footer-redesign .ch-footer-col--newsletter .input-wrapper {
        flex: 1 1 0% !important;
        min-width: 0 !important;
        width: 0 !important;
        max-width: none !important;
        display: block !important;
        overflow: hidden !important;
    }

    .ch-footer-redesign .ch-footer-col--newsletter .input-wrapper input,
    .ch-footer-redesign .ch-footer-col--newsletter input[type="email"],
    .ch-footer-redesign .ch-footer-col--newsletter input[name="email"] {
        border-radius: 4px 0 0 4px !important;
        border: 1px solid rgba(255, 255, 255, 0.2) !important;
        border-right: none !important;
        width: 100% !important;
        max-width: 100% !important;
        display: block !important;
        margin-bottom: 0 !important;
        height: 42px !important;
        padding: 10px 12px !important;
        background: rgba(255, 255, 255, 0.06) !important;
        color: #fff !important;
        font-size: 13px !important;
        box-sizing: border-box !important;
    }

    .ch-footer-redesign .ch-footer-col--newsletter .tvnewsleteer-btn-wrapper {
        flex: 0 0 auto !important;
        width: auto !important;
        display: block !important;
    }

    .ch-footer-redesign .ch-footer-col--newsletter .tvnewsleteer-btn-wrapper .tvall-inner-btn,
    .ch-footer-redesign .ch-footer-col--newsletter .tvnewsleteer-btn-wrapper button,
    .ch-footer-redesign .ch-footer-col--newsletter button[name="submitNewsletter"] {
        border-radius: 0 4px 4px 0 !important;
        width: auto !important;
        display: block !important;
        height: 42px !important;
        padding: 0 16px !important;
        background: #8DE636 !important;
        color: #0E1527 !important;
        border: none !important;
        font-size: 12px !important;
        font-weight: 600 !important;
        text-transform: uppercase !important;
        white-space: nowrap !important;
        line-height: 42px !important;
    }

    /* Newsletter description below form on mobile */
    .ch-footer-redesign .ch-footer-col--newsletter .tvnewsletter-description {
        width: 100% !important;
        margin-top: 8px !important;
    }

    .ch-footer-redesign .ch-footer-col--newsletter .tvnewsletter-description p {
        font-size: 12px !important;
        color: rgba(255, 255, 255, 0.5) !important;
        line-height: 1.4 !important;
    }

    /* Show "Subscribe" not "OK" on mobile */
    .ch-footer-redesign .ch-footer-col--newsletter .tvnewslatter-btn-title.hidden-lg-down {
        display: inline !important;
    }
    .ch-footer-redesign .ch-footer-col--newsletter .tvnewslatter-btn-title.hidden-xl-up {
        display: none !important;
    }

    /* Bottom bar - force centring */
    .ch-footer-bottom-bar {
        padding: 16px 0;
        width: 100% !important;
        overflow: hidden !important;
    }

    .ch-footer-bottom-inner {
        gap: 12px;
        width: 100% !important;
        text-align: center !important;
    }

    /* Copyright text centred */
    .ch-footer-bottom-inner .tvcopylink,
    .ch-footer-bottom-inner .tvcopylink a,
    .ch-footer-bottom-inner .tvcopylink p,
    .ch-footer-bottom-inner [class*="copyright"] {
        text-align: center !important;
        width: 100% !important;
    }

    /* Payment icons centred and constrained */
    .ch-payment-icons {
        display: flex !important;
        flex-wrap: wrap !important;
        justify-content: center !important;
        gap: 8px !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    .ch-pay-icon {
        width: 46px !important;
        height: 30px !important;
        max-width: 46px !important;
        flex: 0 0 46px !important;
    }

    .ch-pay-icon svg {
        width: 46px !important;
        height: 30px !important;
        max-width: 46px !important;
    }
}


/* =============================================
   UTILITY: HIDE THEME ELEMENTS WE DON'T WANT
   ============================================= */

/* If the theme renders a separate footer-before section, hide it */
.ch-footer-redesign .tvfooter-before {
    display: none !important;
}

/* Hide the right sticky sidebar and social block rendered by hooks */
.ch-footer-redesign .tvcmsright-sticky,
.ch-footer-redesign .block-social.tv-footer-social-icon,
.tvcmsright-sticky,
.tvsticky-up-arrow {
    display: none !important;
}

/* Clean up any stray theme padding/margins */
.ch-footer-redesign .container {
    max-width: 1200px;
}


/* =============================================
   NUCLEAR MOBILE OVERRIDES
   These use maximum specificity and come last
   to beat any theme mobile styles.
   ============================================= */
@media screen and (max-width: 991px) {

    /* Force single column on anything below desktop */
    footer .ch-footer-redesign .ch-footer-columns,
    footer#footer .ch-footer-redesign .ch-footer-columns,
    .footer-container.ch-footer-redesign .ch-footer-columns {
        grid-template-columns: 1fr !important;
        gap: 0 !important;
    }

    /* Contain everything */
    footer .ch-footer-redesign,
    footer#footer .ch-footer-redesign,
    .footer-container.ch-footer-redesign {
        overflow: hidden !important;
        max-width: 100vw !important;
    }

    footer .ch-footer-redesign .container,
    footer#footer .ch-footer-redesign .container {
        padding-left: 15px !important;
        padding-right: 15px !important;
        max-width: 100% !important;
        overflow: hidden !important;
    }

    /* Every column */
    footer .ch-footer-redesign .ch-footer-col,
    .ch-footer-redesign .ch-footer-col {
        max-width: 100% !important;
        overflow: hidden !important;
        padding: 14px 0 !important;
        border-bottom: 1px solid rgba(255,255,255,0.06) !important;
    }

    /* Every element inside a column */
    footer .ch-footer-redesign .ch-footer-col *,
    .ch-footer-redesign .ch-footer-col * {
        max-width: 100% !important;
        box-sizing: border-box !important;
    }

    /* ---- NEWSLETTER: Stack vertically on mobile ---- */

    /* Show the newsletter title */
    .ch-footer-redesign .ch-footer-col--newsletter .tvnewsletter-lable-wrapper,
    .ch-footer-redesign .ch-footer-col--newsletter .tvnewsletter-title,
    .ch-footer-redesign .ch-footer-col--newsletter #block-newsletter-label {
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
        color: #8DE636 !important;
        font-size: 13px !important;
        font-weight: 600 !important;
        text-transform: uppercase !important;
        margin-bottom: 10px !important;
    }

    /* All newsletter wrappers: block, full width */
    .ch-footer-redesign .ch-footer-col--newsletter .tvcms-newsletter-wrapper,
    .ch-footer-redesign .ch-footer-col--newsletter .tvcms-newsletter-inner,
    .ch-footer-redesign .ch-footer-col--newsletter .tv-newsletter-wrapeer,
    .ch-footer-redesign .ch-footer-col--newsletter .tvnewsletter-block,
    .ch-footer-redesign .ch-footer-col--newsletter .tvnewsletter-input,
    .ch-footer-redesign .ch-footer-col--newsletter .block_newsletter {
        display: block !important;
        width: 100% !important;
        max-width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
        float: none !important;
        position: static !important;
    }

    /* Form: column layout */
    .ch-footer-redesign .ch-footer-col--newsletter form {
        display: block !important;
        width: 100% !important;
    }

    /* Input+button wrapper: row */
    .ch-footer-redesign .ch-footer-col--newsletter .tvnewsleeter-input-button-wraper {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    /* Input wrapper: fill remaining space */
    .ch-footer-redesign .ch-footer-col--newsletter .input-wrapper {
        flex: 1 1 auto !important;
        min-width: 0 !important;
        width: 0 !important;
    }

    /* Email input */
    .ch-footer-redesign .ch-footer-col--newsletter input[name="email"],
    .ch-footer-redesign .ch-footer-col--newsletter .input-wrapper input {
        width: 100% !important;
        max-width: 100% !important;
        height: 44px !important;
        padding: 10px 12px !important;
        border: 1px solid rgba(255,255,255,0.2) !important;
        border-right: none !important;
        border-radius: 4px 0 0 4px !important;
        background: rgba(255,255,255,0.06) !important;
        color: #fff !important;
        font-size: 14px !important;
        margin: 0 !important;
        display: block !important;
    }

    /* Button wrapper: shrink to fit */
    .ch-footer-redesign .ch-footer-col--newsletter .tvnewsleteer-btn-wrapper {
        flex: 0 0 auto !important;
        width: auto !important;
    }

    /* Subscribe button */
    .ch-footer-redesign .ch-footer-col--newsletter .tvnewsleteer-btn-wrapper button,
    .ch-footer-redesign .ch-footer-col--newsletter .tvnewsleteer-btn-wrapper .tvall-inner-btn,
    .ch-footer-redesign .ch-footer-col--newsletter button[name="submitNewsletter"] {
        height: 44px !important;
        padding: 0 18px !important;
        border: none !important;
        border-radius: 0 4px 4px 0 !important;
        background: #8DE636 !important;
        color: #0E1527 !important;
        font-size: 12px !important;
        font-weight: 700 !important;
        text-transform: uppercase !important;
        white-space: nowrap !important;
        display: flex !important;
        align-items: center !important;
        cursor: pointer !important;
    }

    /* Show "Subscribe" text, hide "OK" */
    .ch-footer-redesign .ch-footer-col--newsletter .tvnewslatter-btn-title.hidden-lg-down {
        display: inline !important;
    }
    .ch-footer-redesign .ch-footer-col--newsletter .tvnewslatter-btn-title.hidden-xl-up {
        display: none !important;
    }

    /* Description */
    .ch-footer-redesign .ch-footer-col--newsletter .tvnewsletter-description {
        display: block !important;
        width: 100% !important;
        margin-top: 8px !important;
    }
    .ch-footer-redesign .ch-footer-col--newsletter .tvnewsletter-description p {
        font-size: 12px !important;
        color: rgba(255,255,255,0.5) !important;
    }

    /* Hidden action input */
    .ch-footer-redesign .ch-footer-col--newsletter input[type="hidden"] {
        display: none !important;
    }

    /* ---- BOTTOM BAR ---- */
    .ch-footer-redesign .ch-footer-bottom-bar,
    .ch-footer-redesign .ch-footer-bottom-inner {
        width: 100% !important;
        max-width: 100% !important;
        overflow: hidden !important;
    }

    .ch-footer-redesign .ch-footer-bottom-inner {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        text-align: center !important;
        gap: 12px !important;
    }

    /* Copyright */
    .ch-footer-redesign .ch-footer-bottom-inner .tvcopylink {
        width: 100% !important;
        text-align: center !important;
    }
    .ch-footer-redesign .ch-footer-bottom-inner .tvcopylink p {
        text-align: center !important;
        font-size: 11px !important;
    }

    /* Payment icons */
    .ch-footer-redesign .ch-payment-icons {
        display: flex !important;
        flex-wrap: wrap !important;
        justify-content: center !important;
        width: 100% !important;
        gap: 6px !important;
    }
    .ch-footer-redesign .ch-pay-icon {
        width: 44px !important;
        height: 28px !important;
        max-width: 44px !important;
        flex: 0 0 44px !important;
    }
    .ch-footer-redesign .ch-pay-icon svg {
        width: 44px !important;
        height: 28px !important;
    }
}
@media (min-width: 1200px) {
    #left-column.tv-left-right-panel-hide {
        left: 0 !important;
        opacity: 1 !important;
    }
}
@media (min-width: 1200px) {
    #left-column.tv-left-right-panel-hide {
        left: 0 !important;
        opacity: 1 !important;
    }
    .tvleft-column-close-btn {
        display: none !important;
    }
}