.col-desktop-menu .col-megamenu-fullwidth{
    max-width:100%!important;
    padding:35px 35px!important;
}

.col-megamenu-custom-row{
    display: flex;
    gap:20px;
    flex-wrap:wrap;

}

.col-megamenu-custom-col{
    flex: 1;
}

.col-mobile-drawer .col-megamenu-custom-row{
    flex-direction: column;
}



:root {
    --primary-color: #000;
    --secondary-color: #f5f5f5; 
    --text-color: #000;
    --link-hover-color: #000;
    --sale-color: #900; 
}

.col-header-promo-bar{
    background-color: #eaebed;
    text-align:center;
    height:44px;
    display: flex;
    justify-content: center;
    align-items: center;
    

}

.col-header-promo-bar .container{
    width:100%;
}


.callout-menu{
    color: #ffffff;
    /* background-color: #5f67ba; */
    height: 34px;    
    font-size: 16px;
    font-weight: bold;
    display: flex;
    justify-content: center;
    align-items: center;
        background-image: linear-gradient(to right, #5b88c1, #5f3d7a);
}

.top-callout-scroll,.top-callout-scroll a{
       color: #333;
    font-size: 13px;
    font-weight: 500;
}

.top-callout-scroll {
    position: relative;
    height: 1.5em; 
    overflow: hidden;
  }

  .top-callout-scroll span {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    opacity: 0;
    transition: opacity 1s ease-in-out;
    z-index: 0;
    pointer-events: none;
  }

  .top-callout-scroll span.showing {
    opacity: 1;
    z-index: 1;
    pointer-events: auto;
  }
  
  

.btn.btn-white{ 
    background-color: #fff;
    color: var(--text-color);
    border: 1px solid #333;    
}

.btn.btn-white:hover{ 
    background-color: #CCC;;
}

.svgicon{ 
    height:24px;
    width:24px;
    fill:black;
}

.col-cart-icon-trigger{ 
    position:relative
}



.col-cart-drawer-rows .sp-callout{
    justify-content: center;;
}
.col-cart-drawer-empty{
    display: flex;
    justify-content: center;
    align-items: center;
    flex: 1;
    font-size:24px;

}
.col-cart-drawer-count-mini { 
    font-size: 12px;
    font-weight: bold;
    position: absolute;    
    top: 0px;
    right: -3px;
    
    
   
}

.col-mobile-drawer ul { 
    list-style:none;
    margin: 0; 
    padding: 0; 
}


button:active:focus, .col-mobile-toggle:hover,.col-mobile-toggle:focus,.col-mobile-toggle:active,.col-mobile-toggle:focus-visible,.col-mobile-toggle:target,.col-mobile-toggle:focus-within,.col-back-btn:hover,.col-back-btn:focus,.col-back-btn:active,.col-back-btn:focus-visible,.col-back-btn:target,.col-back-btn:focus-within,
.col-cart-close-btn:hover, .col-cart-close-btn:focus, .col-cart-close-btn:active, .col-cart-close-btn:focus-visible, .col-cart-close-btn:target, .col-cart-close-btn:focus-within {
    background-color: initial;
    outline: none;
}

.col-loader-animation{ 
    width: 5.313rem;
    height: 5.313rem;
    text-align: center;
    position: absolute;
    top: 50%;
    left: 50%;
    margin-top: -2.6565rem;
    margin-left: -2.6565rem;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

.col-loader-animation .columbia-group__one, 
.col-loader-animation .columbia-group__two,
.col-loader-animation .columbia-group__three,
.col-loader-animation .columbia-group__four {
  opacity: 0.1;
  animation: fadeCycle 1s infinite ease-in-out;
}

.col-loader-animation .columbia-group__one { animation-delay: 0.25s; } 
.col-loader-animation .columbia-group__two { animation-delay: 0.5s; } 

.col-loader-animation .columbia-group__four { animation-delay: 1s; } 

@keyframes fadeCycle { 
  0% { opacity: 0.1; }
  12.5% { opacity: 0.5; }
  25% { opacity: 0.1; }
  100% { opacity: 0.1; }
}

/* Header & Navigation */
.col-site-header{
    position: sticky; 
    top:0; 
    z-index:999; 
    background-color: #fff; 
}

.col-top-banner { 
    background-color: var(--secondary-color);
    text-align: center;
    padding: 10px 15px;
    font-size: 0.9em;
    position: relative;
    border-bottom: 1px solid #ddd;
}

.col-banner-toggle {
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    font-size: 1.4em;
    cursor: pointer;
    font-weight: bold;
}

.col-main-nav {
    border-bottom: 1px solid #eee;
    
}

.col-nav-container {    
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative; 
        padding: 0px 32px;
}

.col-logo {
    display: block;
    height: 28px; 
    flex-shrink: 0;
    margin-right: 20px; 
}
.col-logo img {
    height: 100%;
}

/* Desktop Menu */
.col-desktop-menu {
    display: flex;
    gap: 5px; 
    flex-grow: 1;
    justify-content: start; 
    list-style-type: none; 
    padding-left: 0; 
    margin: 0; 
}

.col-desktop-menu li{
    list-style: none;
}
.col-desktop-menu > li >  a {
    color:var(--text-color); 
    padding: 15px 15px; 
    display: block;
    border-bottom: 1px solid transparent; 
    transition: color 0.2s ease, border-bottom-color 0.2s ease;
    white-space: nowrap; 
    text-decoration: none;
}

.col-desktop-menu > li > a:hover,
.col-desktop-menu > li:hover > a {
    color: var(--link-hover-color);
    border-bottom-color: var(--link-hover-color);
}

.col-desktop-menu li a.col-sale,
.col-desktop-menu li.col-sale > a { 
    color: var(--sale-color);
}
.col-desktop-menu li a.col-sale:hover,
.col-desktop-menu li.col-sale:hover > a {
     border-bottom-color: var(--sale-color);
}

/* Icons & Search */
.col-nav-icons {
    display: flex;
    align-items: center;
    gap: 10px; 
}

.col-search-form {
    display: flex;
    align-items: center;
    background-color: var(--secondary-color);
    border-radius: 20px;    
}

#col-search-icon{ 
    padding: 0 10px;
    display: flex; 
    align-items: center; 
    cursor: pointer; 
}
#col-search-icon .svgicon .fa-search{ 
    font-size: 1.1em; 
    color: #555;
    
}


.col-search-form input {
    border: none;
    background: none;
    outline: none;
    padding: 8px 15px 8px 0px; 
    font-size: 0.9em;
}

.col-search-form button { 
    background: none;
    border: none;
    cursor: pointer;
    font-size: 1.1em;
    color: #555;
    padding: 8px 10px 8px 0px; 
    display: flex;
    align-items: center;
}

.col-icon-link {
    
    color: #000; 
    padding: 5px; 
    display: flex; 
    align-items: center;
    text-decoration: none;
    position:relative;
}

/* Megamenu */
.col-has-megamenu {
    
}

.col-megamenu {
    position: absolute;
    top: 100%; 
    left: 50%;
    transform: translateX(-50%); 
    width: 100vw;
    background-color: #fff;    
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.15);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.3s ease-in-out, visibility 0s linear 0.3s; 
    z-index: 998; 
    /* padding: 30px 40px;  */
    box-sizing: border-box;
}

.col-has-megamenu:hover .col-megamenu {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%); 
    pointer-events: auto;
    transition: opacity 0.3s ease-in-out, visibility 0s linear 0s;
}

.col-megamenu-content {
    display: flex;
    gap: 20px; 
    justify-content: flex-start;
    margin:0 auto; 
    max-width:1300px; 
    padding:30px 0;
}

.col-megamenu-col {
    flex: 1; 
    min-width: 200px; 
    padding: 0 10px; 
}
.col-megamenu-col:first-child { padding-left: 0; }
.col-megamenu-col:last-child { padding-right: 0; }

.col-megamenu-group-block { 
    margin-bottom: 25px;
}
.col-megamenu-group-block:last-child {
    margin-bottom: 0;
}

.col-megamenu-group-block h5 {
        font-size: 1.05em;
    margin-top: 0;
    margin-bottom: 7px;
    font-weight: bold;
    text-transform: capitalize;
    letter-spacing: .03em;
}

.col-megamenu-group-block h5 a {
    color: var(--text-color);
    padding:0; 
    border-bottom: none;
    text-decoration: none;
}

.col-megamenu-group-block h5 a:hover {
    color: var(--link-hover-color);
    border-bottom: none;
        padding-bottom: 0px;
}

.col-megamenu-group-block ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.col-megamenu-group-block ul li {
    margin-bottom: 5px; 
    list-style: none;
}

.col-megamenu-group-block ul li a {
    font-size: 0.95em;
    color: #555;
    transition: color 0.2s ease;
    padding: 0 0; 
    display: inline-block; 
    border-bottom: none;
    text-transform: none;
    font-weight: normal;
    text-decoration: none;
}
.col-megamenu-group-block ul li a:hover {
    color: var(--link-hover-color);
    border-bottom: none;
    padding-bottom: 0px;
}

/* Mobile Drawer Styles */
.col-mobile-toggle { 
    display: none; 
    background: none;
    border: none;
    cursor: pointer;
    padding: 5px; 
    line-height: 0;
    z-index: 1003; 
}

.col-hamburger-svg { 
    width: 28px; 
    height: 28px;
    display: block;
    vertical-align: middle;
}

.col-mobile-toggle .svgicon {
    width: 28px;
    height: 28px;
    fill: var(--text-color); 
}


.col-mobile-drawer {
    position: fixed;
    top: 0;
    width: 85%; 
    right: -85%; 
    height: 100%;
    background-color: #fff;
    box-shadow: -5px 0 15px rgba(0, 0, 0, 0.2);
    z-index: 10000; 
    transition: right 0.4s ease;
    overflow: hidden; 
}
.col-mobile-drawer ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.col-mobile-drawer.open {
    right: 0;
}

.col-close-btn {
    padding:0; 
    position: absolute;
    top: 0px; 
    right: 15px; 
    background: none;
    border: none;
    font-size: 2.5em;
    cursor: pointer;
    color: #333; 
    z-index: 1005; 
    line-height: 1.2; 
}

.col-drawer-panels {
    display: flex; 
    width: auto; 
    height: 100%;
    transition: transform 0.3s ease-in-out;
    transform: translateX(0%); 
}

.col-drawer-panel {
    width: 100%; 
    height: 100%;
    overflow-y: auto; 
    padding-top: 60px; 
    padding-bottom: 20px; 
    box-sizing: border-box;
    flex-shrink: 0; 
    position: relative; 
    background-color: #fff; 
    
}



.col-panel-header {
    padding: 0 20px 0  14px;
    display: flex;
    align-items: center;
    position: absolute; 
    top: 0;
    left: 0;
    width: 100%;
    background-color: #fff; 
    box-sizing: border-box;
    height: 60px; 
    z-index: 1004; 
    
}

.col-back-btn {
    background: none;
    border: none;
    font-size: 1em;
    font-weight: bold;
    cursor: pointer;
    color: #555;
    margin-right: 10px; 
    padding: 10px 5px 10px 0; 
    display: flex;
    align-items: center;
    text-transform:none; 
}
.col-back-btn .fa { 
    margin-right: 8px;
    font-size: 1.2em; 
}
.col-panel-header h4 { 
    margin: 0;
    font-size: 1.1em; 
    font-weight: bold;
    flex-grow: 1; 
    text-align: left;
}

ul.col-mobile-menu-items { 
    padding: 0 20px; 
    list-style: none; 
    margin:0;
}

.col-mobile-menu-items li { 
    list-style: none;
    
}
.col-mobile-menu-items li:last-child {
    border-bottom: none;
}

ul.col-accordion-content{
    margin-left:
}
.col-accordion-sub-title{ 
    font-size:20px;
    font-weight:600;
    padding:12px 0;
    color: var(--text-color); 
    list-style: none;
    
}

.col-mobile-menu-items li.col-accordion-sub-title {
    
}


.col-mobile-menu-items li a {
    display: flex;
    align-items: center;
    padding: 15px 0;
    font-size: 14px; 
    font-weight: bold;
    color: var(--text-color);
    
    text-decoration: none; 
}

li.col-has-accordion a svg{
    transform: rotate(90deg);    
    transition: transform 0.3s ease;
}

li.col-has-accordion.open svg{
    transform: rotate(270deg);
    
}

.col-mobile-menu-items li:last-child > a {
    border-bottom: none;
}

.col-mobile-menu-items li a .fa { 
    color: #aaa;
    font-size: 0.9em; 
    float: right; 
    line-height: inherit; 
}

.col-mobile-menu-items li a.col-drawer-link { 
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.col-mobile-menu-items li a.col-sale,
.col-mobile-menu-items li.col-sale > a { 
    color: var(--sale-color);
}
.col-mobile-menu-items li.col-sale > a .fa { 
     color: #aaa;
}

.col-has-accordion > a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: none !important; 
}
.col-mobile-menu-items li.col-has-accordion {
    
}


.col-has-accordion > a .fa { 
    transition: transform 0.3s ease;
    float: none; 
}
.col-has-accordion.open > a .fa {
    transform: rotate(180deg);
}

.col-accordion-content {
    list-style: none; 
    padding: 0 0 0 20px; 
    margin:0;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease-out;
    
}

ul.col-accordion-content{
    margin-left:2rem;
}
.col-accordion-content.open { } 
.col-accordion-content li {
    list-style: none;
    
}
.col-accordion-content li:first-child {
    
}
.col-accordion-content li a {
    font-size: 1em;
    font-weight: normal;
    padding: 12px 0; 
    border-bottom: none; 
    color: #555; 
}
.col-accordion-content li:last-child a{
    border-bottom: none;
}

.col-accordion-content li a .fa { 
    display: none;
}

.col-panel-raw-html { 
    padding: 15px 20px; 
    word-wrap: break-word; 
}
.col-panel-raw-html h4{ 
    font-size:20px;
    font-weight:600;
    margin-top: 0;
    margin-bottom: 15px;
    color: var(--text-color); 
}


/* Cart Drawer Styles */

.col-mobile-drawer{
    width: 450px; 
    right: -450px;

}
.col-cart-drawer {
    position: fixed;
    top: 0;
    width: 450px; 
    right: -450px; 
    height: 100%;
    background-color: #fff;
    
    z-index: 10000; 
    transition: right 0.4s ease;
    overflow: hidden; 
    display: flex;
    flex-direction: column;
}

.col-cart-drawer.open {
    right: 0;
    box-shadow: -5px 0 15px rgba(0, 0, 0, 0.2);
}

.col-cart-drawer-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 15px 20px;
    border-bottom: 1px solid #eee;
    flex-shrink: 0; 
}

.col-cart-drawer-title {
    font-size: 1.2em;
    font-weight: bold;
}

.col-cart-price-container{ 
    display: flex;
}

.col-cart-price-container > *{ 
    flex:1;
}

.col-cart-drawer-name{ 
    font-weight:bold;
}

.col-cart-drawer-price{ 
    text-align:right;
}

.col-cart-drawer-price .prod-sale-price{ 
    color: var(--sale-color);
}

.col-cart-drawer-rows{ 
    display:flex;
    flex-direction: column;
    gap: 20px;
    padding:20px;
    overflow-y: auto; 
    overflow-x:hidden;
    flex:1
}

.col-cart-drawer-rows > .row{ 
    border-bottom:1px solid #d8d8da;
    padding-bottom:20px;
}


.col-cart-drawer-total{ 
    flex:0; 
    background-color: #f5f5f5;
    padding:10px 20px 20px;
    flex-shrink: 0;
}

.col-cart-drawer-total-row{ 
    display: flex;
    justify-content: space-between;
    padding: 10px 0;    
    font-size:18px;
    font-weight:bold;
}   

.col-cart-drawer-total-buttons{ 
    display: flex;
    flex-direction:column;
    gap: 10px;
}


.col-cart-close-btn { 
    background: none;
    border: none;
    font-size: 2.5em; 
    line-height: 1;
    padding: 0;
    cursor: pointer;
    color: #555; 
}

.col-cart-drawer-content { 
    display: flex;
    flex-direction: column;
    flex-grow: 1; 
    overflow-y: hidden; 
    box-sizing: border-box;
    
}

.col-cart-drawer-content .col-loader-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    
    min-height: 150px; 
    color: #777;
    padding: 20px; 
}
.col-cart-drawer-content .col-loader-container .fa-spinner { 
    margin-bottom: 10px;
}

/* Overlay */
.col-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 9999; 
    display: none;
    opacity: 0;
    transition: opacity 0.4s ease;
}

.col-overlay.show {
    display: block;
    opacity: 1;
}

/* Media Queries */
@media (max-width: 1300px) { 

    .top-callout-scroll,.top-callout-scroll a{
        
        font-size:13px;
    }

    .col-desktop-menu {
        display: none;
    }
    .col-main-nav{
        
    }
    .col-nav-container{
        height: 60px; 
        padding: 0 10px; 
    }
    .col-mobile-toggle {
        display: flex; 
        align-items: center;
        
    }
    .col-logo {
       height:28px; 
       
       margin-right: auto; 
    }
    .col-nav-container .col-logo {
        order: 0; 
        margin-right: auto; 
    }
     .col-nav-container .col-desktop-menu { 
        display:none !important; 
        order: 1;
    }
    .col-nav-container .col-nav-icons {
        order: 2; 
        gap: 10px; 
    }


    #col-search-icon{
        padding: 0 5px; 
    }
    #col-search-icon .svgicon .fa-search { 
         font-size: 1.2em; 
         color: #000;
     }
    .col-search-form button{ 
        padding: 8px 5px;
    }
    .col-search-form input {
        display: none; 
    }
     .col-search-form {
        background: none;
        padding: 0;
     }
     
     .col-icon-link{ 
         
         padding: 5px; 
     }
     .col-icon-link .svgicon {
         width: 24px; 
         height: 24px;
     }


    


    .col-drawer-panel {
        width: 100%; 
    }
}


@media(max-width:499px){
    .col-cart-drawer {
        width: 85%;
        right: -85%;
    }

    .col-mobile-drawer{
        width: 85%;
        right: -85%;
    }
}

