.stripe-custom-input iframe{
    height:40px !important;
}
.stripe-custom-input iframe InputElement{
    height:40px !important;
}
.spinner-border.sm{
    width: 1.6rem !important;
    height: 1.6rem !important;
}
input.error {
    border: 1px solid #e65353 !important;
}
label.error {
    margin-top:3px;
    color: #e65353 !important;
}
.shipping-method-label{
    position: relative;
}
.shipping-method-label input[type=radio]{
    position: absolute;
    visibility: hidden;
}
.StripeElement {
    box-sizing: border-box;
    height: 40px;
    padding: 10px 12px;
    border: 2px solid #000000;
    border-radius: 4px;
    background-color: white;
    -webkit-transition: box-shadow 150ms ease;
    transition: box-shadow 150ms ease;
  }
 .acc-header {
    font-weight: bold;
    margin-top: 20px;
    font-size:16px;
}
.acc-header svg{
    display: none;
}
.quantity-selector .minus.disabled{
    background: #dddddd !important;
    cursor: not-allowed !important;
}
.cart-content .outofstock{
    background: #fff3f3;
}
.cart-content .outofstock .stock-message{
    display:block;
    text-transform: uppercase;
    color: #e65353;
    font-weight: bold;
}
/* ---------------------------------- */
.quick-view-modal {
    position: absolute;
    left: 0;
    right: 0;
    margin: auto;   
    bottom:-10px;
    opacity: 0;
    display: table;
    background: #000;
    color: #fff;
    max-width: min-content;
    -webkit-transition: all .2s ease-out;
    -moz-transition: all .2s ease-out;
    -o-transition: all .2s ease-out;
    transition: all .2s ease-out;
    
}
.quick-view-modal:hover{
    box-shadow: 10px 5px 15px #00000044 !important;
    -webkit-transition: all .2s ease-out;
    -moz-transition: all .2s ease-out;
    -o-transition: all .2s ease-out;
    transition: all .2s ease-out;
}
.st-product-single-item:hover .quick-view-modal{    
    bottom: 0;
    opacity: 1;   
    -webkit-transition: all .2s ease-out;
    -moz-transition: all .2s ease-out;
    -o-transition: all .2s ease-out;
    transition: all .2s ease-out;
}
.products .st-product-single-item .img-sec {
    padding-bottom: 0;
}
.product-quick-view-modal img {
    height: 400px;
    width: 100%;
    object-fit: cover;
}
.product-quick-view-modal .product-details-section .product-details__details {
    width: 100%;
}
.quick-view-modal-slider .slick-prev {
    left: 0;
    z-index: 9;
}
.quick-view-modal-slider .slick-next {
    right: 0;
    z-index: 9;
}
.quick-view-modal-slider .slick-prev:before, .quick-view-modal-slider .slick-next:before {    
    color: black; 
}
.quick-view-modal-slider  .slick-track {
    width: 100%;
}
.quick-view-modal-slider .slick-track {
    width: 100%;
}
.quick-view-modal-slider .bnr-slder-sngl.slick-slide.slick-current.slick-active {
    width: 100%;
}
/* modal start */
 /**
  * Modal
  */
 .modal-custom {
   display: flex;
   align-items: center;
   justify-content: center;
   position: relative;
   margin: 0 auto;
   background-color: #fff;
   width: 800px;
   /* max-width: 75rem;
   min-height: 20rem; */
   padding: 20px;
   border-radius: 5px;
   opacity: 0;
   /* overflow-y: auto; */
   visibility: hidden;
   box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
   -webkit-backface-visibility: hidden;
           backface-visibility: hidden;
   transform: scale(1.2);
   transition: all 0.6s cubic-bezier(0.55, 0, 0.1, 1);
 }
 .modal-custom .close-modal {
   position: absolute;
   cursor: pointer;
   top: 5px;
   right: 15px;
   z-index: 1;
   opacity: 0;
   font-size: 24px;
   color: #000;
   -webkit-backface-visibility: hidden;
           backface-visibility: hidden;
   transition: opacity 0.6s cubic-bezier(0.55, 0, 0.1, 1), transform 0.6s cubic-bezier(0.55, 0, 0.1, 1);
   transition-delay: 0.3s;
   text-decoration: none;
 }
 /* .modal-custom .close-modal svg {
   width: 1.75em;
   height: 1.75em;
 } */
 .modal-custom .modal-content {
   opacity: 0;
   -webkit-backface-visibility: hidden;
           backface-visibility: hidden;
   transition: opacity 0.6s cubic-bezier(0.55, 0, 0.1, 1);
   transition-delay: 0.3s;
   border: none;
 }
 .modal-custom.active {
   visibility: visible;
   opacity: 1;
   transform: scale(1);
 }
 .modal-custom.active .modal-content {
   opacity: 1;
 }
 .modal-custom.active .close-modal {
   transform: translateY(10px);
   opacity: 1;
 }
 
 
 @media only screen and (min-width: 40em) {
    .modal-overlay {
      display: flex;
      align-items: center;
      justify-content: center;
      position: fixed;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      z-index: 5;
      background-color: rgba(0, 0, 0, 0.15);
      opacity: 0;
      visibility: hidden;
      -webkit-backface-visibility: hidden;
              backface-visibility: hidden;
      transition: opacity 0.6s cubic-bezier(0.55, 0, 0.1, 1), visibility 0.6s cubic-bezier(0.55, 0, 0.1, 1);
    }
    .modal-overlay.active {
      opacity: 1;
      visibility: visible;
    }
  }
 /**
  * Mobile styling
  */
@media only screen and (max-width: 991px) { 
    .modal-custom {       
        width: 600px;
        overflow: auto;
        height: 100%;   
    }
    .modal-overlay.product-quick-view-modal{      
        padding: 50px;
    }
    .modal-custom .modal-content {      
        height: 100%;
    }
    .product-quick-view-modal img {
        height: 300px;       
        object-fit: contain;
    }
    
    .header-nav .nav-container-custom {
        position: fixed !important;
        top: 0;
        left: 0;
        background: #690005;
        color:#fff;
    }
    
    .header-nav .dropdown-main .label-outer {
        color: #fff;
    }
}
 @media only screen and (max-width:600px) { 
 
   .modal-custom {
     position: fixed;
     top: 0;
     left: 0;
     width: 100%;
     height: 100%;
     -webkit-overflow-scrolling: touch;
     border-radius: 0;
     transform: scale(1.1);     
   }
 
   .close-modal {
     right: 20px !important;
   }
 }
 @media only screen and (max-width:567px) { 
    .modal-custom {       
        padding: 15px;      
    }
    .product-details-section .product-page-variation-viewer .item>.rectangles-list>label:not(:last-child) {
        margin-right: 10px;
    }
    
    .product-details-section .product-page-variation-viewer .item>.rectangles-list>label {
        margin-bottom: 10px;
    }
 }
/* modal end */
.st-product-single-item .img-sec > .inner {
    /*position: relative !important;*/
}
.ruhlictic-logo{
    height: 60px;
    width: 100%;
    object-fit: contain;
}
button.btn.st-btn.st-btn-primary.text-uppercase.st-fs-13.w-100.d-flex.align-items-center.justify-content-center.st-ff-ss {
    display: table !important;
    width: auto !important;
    margin: 0 auto;
    background: transparent;
    color: #333;
    font-size: 16px !important;
    font-weight: 600 !important;
}
button.btn.st-btn.st-btn-primary.text-uppercase.st-fs-13.w-100.d-flex.align-items-center.justify-content-center.st-ff-ss:hover {    
    background-color: #efefef;
}
button.btn.st-btn.st-btn-primary.text-uppercase.st-fs-13.w-100.d-flex.align-items-center.justify-content-center.st-ff-ss span{
    margin: 0 !important;
}
.clnt-c {
    padding: 50px 0 35px;
  }
  
  .clnt-c .cnt-sldr .clnt-sngl-c .clnt-icn-c {
    display: table;
    width: 100%;
    margin: 15px 0;
    -webkit-transition: all 0.2s ease-out;
    transition: all 0.2s ease-out;
  }
  
  .clnt-c .cnt-sldr .clnt-sngl-c .clnt-icn-c:hover {
    -webkit-transition: all 0.2s ease-out;
    transition: all 0.2s ease-out;
  }
  
  .clnt-c .cnt-sldr .clnt-sngl-c .clnt-icn-c:hover img {
    -webkit-transform: scale(1.2);
            transform: scale(1.2);
    filter: gray;
    /* IE6-9 */
    -webkit-filter: grayscale(1);
    /* Google Chrome, Safari 6+ & Opera 15+ */
    filter: grayscale(1);
    /* Microsoft Edge and Firefox 35+ */
    -webkit-transition: all 0.4s ease-out;
    transition: all 0.4s ease-out;
  }
  
  .clnt-c .cnt-sldr .clnt-sngl-c .clnt-icn-c img {
    width: 125px;
    -o-object-fit: contain;
       object-fit: contain;
    display: table;
    margin: 0 auto;
    padding: 10px;
    -webkit-transition: all 0.2s ease-out;
    transition: all 0.2s ease-out;
  }
  
/* for home page */
.new-year-products-section .sec-content .item:not(:last-child) {
    margin-bottom: 0px; 
}
.new-year-products-section{
    /* margin-bottom: 10px;  */
}
#header-info-stripe {
    background: #FC74B0!important;
}
.swiper-slide img{
    width:100%;
}

.home-page-section .text-sec{
    /* padding-right:30px; */
}

.home-page-section .text-sec h1{
    font-size:60px;
    font-weight:bold;
}

.home-page-section .text-sec h2{
    font-size:40px;
    font-weight:bold;
    margin-top:10px;
}

.home-page-section .text-sec p{
    font-size:22px;
    /* font-weight:bold; */
}

@media (min-width: 1600px) {
    .container, .container-lg, .container-md, .container-sm, .container-xl, .container-xxl {
        max-width: 1550px;
    }
}

.new-year-products-section .sec-content .item img{
    width:auto !important;
}

.new-year-products-section .sec-content .item img.w-100{
    width:100% !important;
}

 .st-product-single-item {
    margin-bottom: 20px;
    /* padding: 20px;
    border: 2px solid #fff8f3;
    border-radius: 10px; */
}

/*
.home-page-section .st-product-single-item {
    margin-bottom: 20px;
    padding: 0px !important;
    border: none !important;
    border-radius: 0px !important;
} */

.st-product-single-item .text-sec .name {
    font-size: 22px !important;    
    margin-bottom: 10px !important;
}

.st-product-single-item .text-sec .price-container .price {
    color: #9e7556;
    font-size: 26px !important;
    font-weight: 700 !important;
}

.st-btn{
    border:1px solid #777 !important;
    background: #f2f2f2;
    background: linear-gradient(90deg,rgba(242, 242, 242, 1) 0%, rgba(209, 207, 207, 1) 100%) !important;
    transition: all ease-in-out 0.5s;
    color:#000 !important;
    border-radius: 24px !important;
    line-height: 30px !important; 
    height: 50px !important;
    padding:10px 16px !important;
}

.st-btn:hover{    
    background: #D1CFCF !important;
    background: linear-gradient(90deg,rgba(209, 207, 207, 1) 0%, rgba(242, 242, 242, 1) 100%) !important;
}


.st-btn.st-btn-primary{
    border:0px !important;
    background: #403c3c !important;
    background: linear-gradient(90deg,rgba(64, 60, 60, 1) 0%, rgba(0, 0, 0, 1) 100%) !important;    
    color:#fff !important;
}

.st-btn.st-btn-primary:hover{    
    background: #000000 !important;
    background: linear-gradient(90deg,rgba(0, 0, 0, 1) 0%, rgba(64, 60, 60, 1) 100%) !important;    
}

.sign-in-link i {
    background: #ddd;
    padding: 10px;
    border-radius: 50%;
}


.header-nav .header-menu-inner {
    border-bottom:  none !important;
    margin-bottom: 20px;
    margin-top: 20px;
}

.header-nav .dropdown-main .label-outer {    
    font-size: 15px !important;
    padding: 12px 15px;
    border-bottom:0px !important;
}

.dropdown-main .icon {
    display: none !important;
}

/* .header-nav .nav-container-custom{
    justify-content:left !important;
} */

.dropdown-main .st-line-height-0 {
    line-height: 1.1;
}



.st-heading .head-top {
    font-size: 18px;
    letter-spacing: 2px;
    background: #15191C;
    color: #fff;
    display: inline-block;
    padding: 10px 20px;
    border-radius: 20px;
    margin-bottom: 20px;
}

.st-heading .head-top.red {    
    background: #72061C;    
}

footer {
    background-color: #f4f4f6;    
}

#footer-newsletter {
    background-color: #f4f4f6;    
}

.footer-newsletter {
    background: #fff;
    padding: 50px;
    border-radius: 50px;
}

.footer-newsletter .item .inner h2 {
    font-size: 39px;
    color: #000000;
    font-weight: bold;
    margin-bottom: 20px;
}

.footer-newsletter .item .inner p{
    font-size:18px;
    color:#555555;
}

.footer-newsletter #subscribe_email{
    border-bottom:1px solid #444;
    padding:10px 10px 10px 0px !important;     
    height: 55px !important;
}

.footer-top .inner .head{
    color: #000 !important;
    font-size: 20px !important;
}

.footer-top .inner .head{
    color: #000 !important;
    font-size: 22px !important;
}

.footer-top .inner.link-widget{
    padding-left:50px;
}

footer .footer-top .item .links .link{
    color:#000 !important;
    font-size:14px;
}

.social-links span{
    color:#000000;
    padding-right:20px;
    font-size:24px;
    font-weight:bold;
}

.social-links a.link{
    color: #fff !important;
    background: #000;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: inline-block;
    margin-right: 5px !important;
    text-align: center;
    line-height: 40px;
}

.footer-bottom{
    color:#000 !important;
    font-size:16px !important;
    border-top: 1px solid #aaa;
    padding-top: 50px;
}

.footer-bottom .info a{
    color:#000 !important;
}


footer #footer-bottom{
    border:0px !important;
}

@media screen and (max-width: 567px){
    .home-page-section .text-sec h1{
        font-size:40px;
        margin-bottom:10px;
    }

    .home-page-section .text-sec h2{
        font-size:30px;        
        margin-top:10px;
        margin-bottom:10px;
    }
    .home-page-section .text-sec p{                
        margin-bottom:10px;
    }
    
    .home-page-section .item {
        margin-bottom: 20px !important;        
    }

    .st-product-single-item .text-sec .name {
        font-size: 18px !important;    
        margin-bottom: 8px !important;
    }

    .st-product-single-item .text-sec .price-container .price {        
        font-size: 22px !important;
        font-weight: 700 !important;
    }

    .footer-top .inner.link-widget{
        padding-left:0px;
    }

    .footer-top .inner .head{
        margin-top:20px;
    }
}


.header-nav {
    background: #12001f;
}

.header-nav a {
    color: #fff;
}

.dropdown-main:hover .dropdown-content {
    display: block;
}

.dropdown-content {
    background: #1c0033;
    border-radius: 6px;
}


/* ================= HEADER BAR ================= */
.header-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: linear-gradient(90deg, #12001f, #1c0033);
    padding: 14px 0;
}

/* LEFT / CENTER / RIGHT */
.lt-sec,
.ct-sec,
.rt-sec {
    display: flex;
    align-items: center;
}

/* CENTER LOGO */
.ct-sec {
    flex: 0 0 auto;
    justify-content: center;
}

.ruhlictic-logo {
    max-height: 48px;
}

/* LEFT MENU */
.header-left-menu {
    display: flex;
    gap: 28px;
}

.header-left-menu a {
    color: #fff;
    font-weight: 500;
    text-decoration: none;
    font-size: 15px;
}

/* RIGHT MENU */
.header-right-menu {
    display: flex;
    gap: 28px;
    align-items: center;
}

.header-right-menu a {
    color: #fff;
    font-weight: 500;
    text-decoration: none;
}

/* SEARCH */
.header-search input {
    background: rgba(255,255,255,0.12);
    border: none;
    color: #fff;
    padding: 8px 14px;
    border-radius: 20px;
    width: 200px;
}

.header-search input::placeholder {
    color: rgba(255,255,255,0.6);
}

.header-search i {
    color: #fff;
}

/* ================= MOBILE ================= */
@media (max-width: 991px) {
    .header-bar {
        padding: 12px 0;
    }

    .lt-sec,
    .rt-sec {
        flex: 1;
    }

    .ct-sec {
        position: absolute;
        left: 50%;
        transform: translateX(-50%);
    }

    /* Hide desktop menus */
    .header-left-menu,
    .header-right-menu {
        display: none;
    }

    /* Show icons only */
    .search-box {
        display: none;
    }

    .search-box-mobile {
        display: flex !important;
        gap: 16px;
    }
}

body{
    max-width:2560px;
    margin:0 auto;
}

.homepage-slider-section .container-fluid{
    padding:0px;
}

.nex-red-section{
    background:#93040F !important;
    padding:40px 0px;
}

.nex-red-section .text-sec p{
    font-size:24px;
    color:#fff;
    text-transform: uppercase;
    text-align:center;
}

.nex-gen-section{
    background: linear-gradient(180deg, #3F1986 0%, #0F0620 100%);

}

.nex-digital-section{
    background:#0F0620;
}

.nex-carousel-section{
    background: #0F0620;
}

.nex-round-section .container-fluid, .nex-puff-section .container-fluid,.nex-carousel-section .container-fluid{
    padding:0px;
}


/* Wrapper */
.nex-carousel-section .st-heading {
    position: relative;
    text-align: center;
    padding: 30px 0;
}

/* Horizontal yellow line */
.nex-carousel-section .st-heading::before {
    content: "";
    position: absolute;
    top: 44%;
    left: 0;
    width: 100%;
    height: 20px;
    background: #ffe84d;
    transform: translateY(-50%);
    z-index: 1;
    border-radius: 10px;
}

/* Text pill */
.nex-carousel-section .head-top {
    position: relative;
    display: inline-block;
    z-index: 2;
    padding: 18px 48px;
    font-size: 34px;
    font-weight: 800;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #fff;

    /* Dark glossy pill background */
    background: linear-gradient( 180deg, #3a2a1a4d 0%, #1c120896 100% );

    backdrop-filter: blur(8px) brightness(1.1);

    border-radius: 50px;

    /* Glow & depth */
    box-shadow:
        inset 0 0 15px rgba(255, 215, 120, 0.25),
        0 6px 18px rgba(0, 0, 0, 0.5);
}

.nex-carousel-section .sec-content  .d-flex.slick-slider{
    display:block !important;
}

.nex-carousel-section .sec-content .d-flex .item{
    
}

footer {
  background-color: #0F0620;
}
.footer-logo {
    padding:30px;
    background: #000;
    backdrop-filter: blur(8px) brightness(1.1);
    border-radius: 20px;
    box-shadow:
        inset 0 0 15px #0F0620,
        0 6px 18px #0F0620;
    border-top:1px solid #fff;
    border-bottom:1px solid #fff;
}

.footer-logo::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: 
        radial-gradient(ellipse 80% 50% at 50% 40%, rgba(147, 51, 234, 0.3) 0%, transparent 50%),
        radial-gradient(ellipse 60% 40% at 30% 60%, rgba(168, 85, 247, 0.2) 0%, transparent 50%);
       
    z-index: 0;
    pointer-events: none;
}

@media (max-width: 768px) {
    .nex-carousel-section  .head-top {
        font-size: 20px;
        padding: 12px 24px;
        letter-spacing: 1px;
    }

    .nex-carousel-section .st-heading::before {
        height: 6px;
    }
}

@media (max-width: 991px) {
    .nex-red-section{        
        padding:20px 0px;
    }
    .nex-red-section .text-sec p{
        font-size:18px;
        padding:10px;
        margin-bottom: 0px !important;
    }    
    .home-page-section .item {
        margin-bottom: 0px !important;
    }

    .nex-gen-section .item{
        width:100%;
    } 
}
@media (max-width: 567px) {    
    .home-page-section .item {
        margin-bottom: 0px !important;
    }

    
}



