@tailwind base;
@tailwind components;
@tailwind utilities;
@import url('https://fonts.googleapis.com/css2?family=Josefin+Sans:ital,wght@0,100..700;1,100..700&display=swap');

.container-box {
        max-width: 1250px;
    }
        .large-container {
        max-width: 1650px;
    }

  .container-box, .large-container{
        margin-left: auto;
        margin-right: auto;
        padding-left: 15px;
        padding-right: 15px;
    }
    .paragraph{
        font-size: 18px;
    }

.bg-gray{
    background-color: #575757;
}
.marginY{
    margin-top:50px;
    margin-bottom:50px;
}

.heading{
    font-size: 48px;
    font-weight: bold;
    margin-bottom: 20px;
}
.grey-heading{
color:#575757;

}
.white-btn{
    background-color: white;
    font-size: 16px;
    font-weight: bold;
    padding: 10px 20px;
    margin-top:15px;
    margin-bottom:15px;
    border-radius: 5px;
    transition: 0.3s;
    color: black;

    display: flex;
    align-items: center;
}
.white-btn:hover{
    background-color: black;
    color:white;
}

.grey-menu .menu-item {
    margin: 0px !important;
}

.grey-menu .menu-item {
    padding: 5px 10px;
	list-style:none;
	font-size:11px;
    border-right: 1px solid #7f7f7f;
	transition:0.2s
}

.grey-menu .menu-item:nth-child(5) {
    border-right: 0px;
}
.grey-menu .menu-item:hover {
 color:#ea0000;
}
.main-menu {
    display: flex;
    align-items: baseline;
    padding-top:5px;
	margin-left:10px;
    text-transform: uppercase;
}
.main-menu li {
    position: relative;
    padding: 0px 10px;
	    line-height: 40px;
	    font-size: 14px;
    transition: 0.3s;
	border-bottom:3px solid transparent;
	
}
.main-menu > li:hover{
	border-bottom:3px solid #ea0000;
}

.main-menu li a {
color:black;    
}
.main-menu li > .sub-menu{
	
display:none;
	position:absolute;
	top:42px;
left:0px;
	background: #f1f1f1;
    z-index: 1;
	    width: 250px;
  
}
.main-menu li:hover > .sub-menu{
display:block;
}
.main-menu li > .sub-menu > li {
	position:relative;
    padding: 10px 10px 5px 15px;
	font-size:13px;
   line-height: 28px;
	
}
.main-menu li > .sub-menu > li:hover{
	background:#ea0000 !important;
	
}
.main-menu li > .sub-menu > li:hover > a{
	color:white !important;
}
.main-menu li > .sub-menu  li > .sub-menu{
display:none;
	position:absolute;
	left:250px;
	top:0px;
}
.main-menu li > .sub-menu  li:hover  > .sub-menu{
	display:block;
}
.menu-item .sub-menu li a span svg {
    transform: rotate(270deg);
}

/* MAIN DESIGN OF MOBILE MENU START */
.mobile-main-menu li {
  
    line-height: 40px;
    font-size: 14px;
    transition: 0.3s;
     border-bottom:2px solid #f1f1f1;
	
}
.mobile-main-menu > li:hover{
	border-bottom:2px solid #ea0000;
}
.mobile-main-menu > li:hover > a{
	color:#ea0000;
}


.mobile-main-menu li a {
color:black;    
}
.mobile-main-menu li > .sub-menu{
        display:none;
	    padding-top: 5px;
	background: #f1f1f1;
        z-index: 1;
	width: 100%;
  
}
.mobile-menu ul li a {
    color: black;
    font-weight: 600;
}
.mobile-main-menu li:hover > .sub-menu{
display:block;
}
/* .mobile-main-menu .sub-menu{
width:100% !important;
} */
.mobile-main-menu li > .sub-menu > li {
	padding:0px 12px;
	font-size:14px;
	
}
/* .mobile-main-menu li > .sub-menu > li:hover{
	background:#ea0000 !important;
	
} */
.mobile-main-menu li > .sub-menu > li:hover > a{
	color:#ea0000 !important;
}
.mobile-main-menu li > .sub-menu  li > .sub-menu{
display:none;

}
.mobile-main-menu  li > .sub-menu  li:hover  > .sub-menu{
	display:block;
}
/* MAIN DESIGN OF MOBILE MENU END */

.mobile-menu{
  width: 100%;
  height: 100vh;
  padding: 15px;
  background-color: white;
  position: absolute;
  z-index: 11;
  left:0px;
  text-transform: uppercase;

}
.hideMobileMenu{
 top:-75rem;
}
.showMobileMenu{
 top:0rem;
}
/* .mobile-menu ul li{
padding: 8px 10px;

}
.mobile-menu ul li div{
    width: 100%; 
display: flex;
align-items: center;
justify-content: space-between;
}
.mobile-menu ul li div{
    font-weight: bold;
}
.mobile-mega-menu  li div a{
    font-weight: 600;
    font-size: 15px;
}
.mobile-mega-menu{
    padding-top: 10px;
    padding-bottom: 10px;
}
.mobile-menu ul li .mobile-mega-menu{
        background-color: #efefef;

}
   .mobile-menu ul li:hover{
        background-color: #efefef;
    }
.mobile-menu ul li .mobile-mega-menu ul li{
    padding: 8px 10px;
}
    .mobile-menu ul li .mobile-mega-menu ul li div{
        display: flex;
        justify-content: space-between;

    } */
   

.paddingY{
    padding-top: 60px;
    padding-bottom: 60px;
}
   .slider-image {
            background-size: cover;
            background-position: center;
            transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
        }
.secondary-font{
  font-family: "Josefin Sans", sans-serif !important;
}
.primary-title{
 color:#ea0000;
}
.grey-title {
    color:#575757;    
}
 .white-title{
    color:white;
 }
 .black-title{
    color:black;
 }
  .secondary-black-title{
    color:black;

  }
 .secondary-title{
        font-size: 32px;
    line-height: 1.1;
        text-transform: uppercase;
        font-weight: 700;
        margin-bottom: 20px;
 }
.primary-title, .grey-title, .white-title, .black-title {
   
        font-size: 48px;
    line-height: 1.1;
        text-transform: uppercase;
        font-weight: 700;
        margin-bottom: 20px;
}
.archive-title, .product-category-title{
    line-height: 1.2;
        text-transform: uppercase;
        font-weight: 700;
        margin-bottom: 20px;
}
.archive-title{
	      font-size: 80px;
}
.product-category-title{  
	font-size: 62px;
}
.chat-side-buttons.show {
    z-index: 99;
}
.search-container{
    position:absolute;
    background-color: #fffffff0;
width: 100%;;
height: 100vh;
}

input.search {
    width: 100%;
    padding: 10px;
    border-bottom: 1px solid #ea0000;
    background-color: white;
    font-size: 32px;
      font-family: "Josefin Sans", sans-serif ;
}
input.search:focus-visible {
    outline: 2px solid #ffffff;
    outline-offset: 2px;
}
select option{
  font-family: "Josefin Sans", sans-serif !important;
}
.close-modal-icon{
    width: 54px;
    height: 54px;
    position: absolute;
z-index:9;
	    top: -4rem;
    right: 5px;
    transition: 0.3s;
    cursor: pointer;

}
.zoom-icon{
    transition: 0.4s;

}
.zoom-icon:hover{
   scale: 1.1;
}
.close-modal-icon:hover{
   transform: rotate(90deg);
    transition: 0.4s;
}

 .close-icon {
    width: 54px;
    height: 54px;
    margin-bottom: 50px;
    position: relative;
    cursor: pointer;
    transition: 0.3s;
  }

  .close-icon:hover {
    transform: rotate(90deg);
    transition: 0.4s;

  }

 .subsidiary-card {
            transition: all 0.3s ease;
                overflow: hidden;
    position: relative;
        }
        .subsidiary-card:hover {
            transform: translateY(-5px);
            box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1);
        }

            .post-card {
            transition: all 0.3s ease;
        }
        .post-card:hover {
            transform: translateY(-5px);
            box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1);
        }
        .category-tag {
            transition: all 0.2s ease;
        }
       .single-blog h1 {
    font-size: 36px;
}

.zoom-out{
    transition: 0.3s;

}
.zoom-out:hover{
    scale: 1.02;
}

.product-card{
    position: relative;
    overflow: hidden;
}

.product-card-layer {
    width: 100%;
    height: 60%;
    position: absolute;
    top: 0px;
    left: 0;
    z-index: 2;
    background: linear-gradient(to top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.75) 100%);
}
.product-card-box{
     position: absolute;
 top:50%;
 left:50%;
     z-index: 9;
    transform: translate(-50%,-50%);
    text-align: center;
}
.product-card-box h3{
    color: white;
    font-size: 50px;
    font-weight: bold;
    text-transform: uppercase;
}
.product-card-box button{
  font-family: "Josefin Sans", sans-serif ;

}
.product-card-img img{
        width: 100%;
      height: 100%;
    transition: 0.5s;
       object-fit: cover;
      transition: transform 0.5s ease;
}
.product-card:hover .product-card-img img{
    transform:scale(1.1);
}

.equipment-nav {
	width:100%;
    display: flex;
	flex-wrap:wrap;
    justify-content: center;
    align-items: center;
    gap: 26px;
    font-weight: 600;
    margin: 30px 0px;
}
.equipment-nav a {
    padding: 7px 15px 0px;
    background: #dddddd;
    line-height: 35px;
    transition: 0.3s;
    color: #1d2327;
    font-family: "Josefin Sans", sans-serif !important;
    border-bottom: 3px solid transparent;
    border-radius: 3px;
}
.equipment-nav a:hover{
    border-bottom: 3px solid #ea0000;
}
.product-detail h1{
font-size: 72px;
font-weight: bold;
	line-height:65px;
	text-transform:uppercase;
color:#575757;
	margin-top:10px;	
	margin-bottom:10px;
}
.product-detail p {
    font-family: "Josefin Sans", sans-serif !important;
}

.product-detail ul li p{
color:black;
}
.product-detail ul li{
display: flex;
margin-top:0px;
    align-items: baseline;
gap:6px;
}
.product-detail ul li span{
    font-size: 20px;
}
.product-detail ul li p{
    margin-bottom: 0px;

}


.compare-section{
    width: 100%;
    position:fixed;
	 left:0px;
    bottom:0px;
   z-index: 9999;
}
.leading-relaxed ul{
	margin-top:10px;
	margin-bottom:10px;
}
.leading-relaxed ul li:before {
    content: "•";
    font-size: 18px;
}
.leading-relaxed ul li {
    font-size: 15px;
    font-family: 'Josefin Sans';
	font-family: "Josefin Sans", sans-serif !important;
}

/* REQUEST A QUOTE FORM CSS START */

.global-form-lg .global-form-title {
    font-size: 48px;
    margin-top: 50px;  
     margin-bottom: 45px;
    color: #575757;
    text-transform: uppercase;
}
.global-form-lg {
    padding: 15px;
}
 
.global-form-label {
    font-family: "Josefin Sans", sans-serif;
    font-weight: 600;
    margin-top: 15px;
    font-size: 17px !important;
}
 
div#global-form input {
    padding: 4px 16px;
    border-radius: 8px;
    font-family: "Josefin Sans", sans-serif;
}
 
div#global-form select#small_category_id {
    font-family: "Josefin Sans", sans-serif;
}
 .global-form-label {
    display: flex;
    flex-direction: row-reverse;
    justify-content: left;
    gap: 3px;
}
.global-form-submit {
    background: #575757 !important;
    color: #fff !important;
    text-align: center !important;
    width: 100px !important;
    border-radius: 5px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    margin: 35px 0px 100px 0px !important;
    position: relative !important;
    line-height: 48px !important;
    font-size: 18px !important;
    text-transform: uppercase !important;
}


.global-form-submit:focus,  .disabled.global-form-submit {
    background: #ea0000 !important;
transition:0.3s;
}
.global-form-submit:hover{
        background: #ea0000 !important;
transition:0.3s;
}
/* REQUEST A QUOTE FORM CSS END */

.fade-in{
    opacity: 0;
            animation: fadeInSection 1.2s ease-out forwards;
}
  @keyframes fadeInSection {
            from {
                opacity: 0;
            }
            to {
                opacity: 1;
            }
        }


/* 3D CRANE CSS START */
  .crane-image {
      width: 100%;
      height: 100%;
      object-fit: contain;
      transition: opacity 0.3s ease;
    }
    .drag-area {
      cursor: grab;
      touch-action: pan-y;
    }
    .drag-area:active {
      cursor: grabbing;
    }
    
/*3D CRANE CSS END */
 /*  NEW MOBILE CSS CODE START */
        .sany-mobile-nav-container {
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            height: 100vh;
            background: white;
            z-index: 1000;
            transform: translateX(-100%);
            transition: transform 0.3s ease;
            display: flex;
            flex-direction: column;
        }
        
        .sany-mobile-nav-container.sany-active {
            transform: translateX(0);
        }
        
        /* Menu Header */
        .sany-nav-header {
            display: flex;
			text-transform:uppercase;
            align-items: center;
            padding: 16px;
            border-bottom: 1px solid #eaeaea;
            background: white;
        }
        
        .sany-nav-back-btn {
            background: none;
            border: none;
            font-size: 26px;
			font-weight: 600;
            color:#ea0000;
            margin-right: 12px;
            cursor: pointer;
            padding: 4px;
        }
        
        .sany-nav-title {
            font-size: 18px;
            font-weight: 600;
            flex-grow: 1;
        }
        
        .sany-nav-close-btn {
            background: none;
            border: none;
            font-size: 20px;
            cursor: pointer;
            padding: 4px;
        }
        
        /* Menu Items Container */
        .sany-nav-items-container {
            flex-grow: 1;
            overflow-y: auto;
        }
        
        /* Menu Items */
        .sany-nav-item {
            display: flex;
            justify-content: space-between;
            align-items: center;
			    text-transform: uppercase;
            padding:10px 15px;
            border-bottom: 1px solid #f0f0f0;
            color: #333;
            text-decoration: none;
            font-size: 16px;
            transition: background-color 0.2s;
			font-weight:bold;
        }
        
        .sany-nav-item:hover {
            background-color: #f8f8f8;
        }
        
        .sany-nav-item-arrow {
            color: #ea0000;
            font-size: 26px;
        }
        
.mobile-fixed-btn{
animation: moveup 4s  normal backwards;
}
.fadein{
animation: moveup 1s  ease-in normal backwards;	
}
@keyframes moveup {
  from {
	  opacity:0;
  }
  to {
	  
	  opacity:1;
  }
}
/*    NEW MOBILE CSS CODE END */
.red-star{
color:#ea0000;
}   
.error-msg {
background: #ffffffe3;
  color: #ea0000;
  font-size: 14px;
  border: 1px solid #ea0000;
  padding: 5px 10px;
  margin-top: 5px;
  border-radius: 3px;
}

/* FOOTER CSS CODE START */
.footer-left-col h2, .footer-right-col h2{
    font-size: 1.5rem;
    line-height: 2rem;
	    font-weight: 800;
	letter-spacing:1px;
	margin-bottom:10px;
}
.footer-left-col div #menu-footer-left-menu {

  font-family: "Josefin Sans", sans-serif ;
}
.footer-left-col div #menu-footer-left-menu li{
margin-bottom:8px;
}

ul#menu-footer-left-menu li a:hover {
    color: #ea0000;
    transition: 0.5s;
	text-decoration:none;
}
/* FOOTER CSS CODE END */

@keyframes ripple {
            0% { transform: scale(1); opacity: 1; }
            100% { transform: scale(1.2); opacity: 0; }
        }
        .ripple {
            position: absolute;
            width: 100%;
            height: 100%;
            background: rgba(255, 255, 255, 0.2);
            border-radius: 50%;
            animation: ripple 1s infinite;
            z-index: 0;
        }
     .product-card {
            transition: all 0.3s ease;
        }
        .product-card:hover {
            transform: translateY(-5px);
            box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1);
        }



        @media only screen and (min-width:1440px){
           .product-card-box{
    width: 500px !important;
}
        }
        @media only screen and (max-width:1440px){
                  .product-card-box h3{
    font-size: 35px;
}
 
        }


        @media only screen and (max-width:1024px){
     .primary-title, .grey-title, .white-title, .black-title{
                font-size: 46px;
            }
				.archive-title{
                font-size: 60px;
            }
			.product-category-title{  
	font-size: 56px;
}
   .product-detail h1 {
    font-size: 48px;
	   line-height: 50px;
			}
			.hambuger{
				display:flex;
			}
        }
   @media only screen and (min-width:1024px){
	.sany-mobile-nav-container, #mobile-fixed-btn{
display:none;
	}
	   
			.hambuger{
				display:none;
			}
            .product-card-box{
    width: 310px;
}
}
        @media only screen and (max-width:800px){
			.main-menu{
				padding-top:10px;
				    margin-left: 0px;
			}
            .main-menu li{
   font-size:13px;
   }
        }
   @media only screen and (min-width:769px){
        .mobile-menu{
            display: none;
        }
	   
    }
        @media only screen and (max-width:768px){
            .grey-title { font-size: 42px;}
                .primary-title, .grey-title, .white-title, .black-title{
                font-size: 42px;
            }
			
            .product-card-box h3{
    font-size: 40px;
}
		.product-category-title{  
	font-size: 52px;
}
input.search {
    font-size: 20px;
}
 .close-icon {
    width: 34px;
    height: 34px;
}
			.product-detail h1 {
				    font-size: 38px;
    line-height: 44px;
			}
            .product-card-box{
    width: 340px;
}
      
} 
    @media only screen and (max-width:767px){     
nav.menu-container {
    height: 70vh;
    overflow-y: scroll;
} 
}
        @media only screen and (max-width:640px){
        .primary-title, .grey-title, .white-title, .black-title{
                font-size: 32px;
            }
		
			.equipment-nav{
gap:10px;
			}
			.product-category-title{  
	font-size: 48px;
}
  nav.menu-container {
    height: 70vh;
    overflow-y: scroll;
}  
			.product-detail h1{
             font-size:32px;
				line-height:38px;
			}
			  .footer-left-col h2, .footer-right-col h2, ul#menu-footer-left-menu{
		  text-align:center;
	  }
				ul#menu-footer-left-menu {
    display: flex
;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
}
	  ul#menu-footer-left-menu li {
    border: 1px solid white;
    padding: 5px 7px;
    background: white;
    color: #ea0000;
    border-radius: 2px;
}


.product-card-box{
    width: 380px;
}

        }
  @media only screen and (max-width:480px){
        .primary-title, .grey-title, .white-title, .black-title{
                font-size: 30px;
	  }
	  .archive-title{
                font-size: 46px;
	  }
	.product-category-title{  
	font-size: 42px;
}

.product-card-box{
    width: 370px;
}
}
@media only screen and (max-width:360px){
		  .archive-title{
                font-size: 40px;
	  }
		.product-category-title{  
	font-size: 38px;
}
}
@media only screen and (min-width:250px){
	.menu-right-side{
		width:100%;
}
	.menu-left-side{
width:0%;		
	}
}

@media only screen and (min-width:768px){
	.menu-right-side{
		width:50%;
}
	.menu-left-side{
width:0%;		
	}
}


@media only screen and (min-width:1024px){
	.menu-right-side{
		width:30%;
}
	.menu-left-side{
width:70%;		
	}
}


@media only screen and (min-width:1600px){
	.menu-right-side{
		width:20%;
}
	.menu-left-side{
width:80%;		
	}
}







/* @layer components { 

    .margin-wrap-left {
        margin-left: calc((100% - 1510px) / 2);
        padding-left: 15px;
    }

    .margin-wrap-right {
        margin-right: calc((100% - 1510px) / 2);
        padding-right: 15px;
    }
    
    .container {
        max-width: 1620px !important;
        margin-left: auto;
        margin-right: auto;
        padding-left: 1rem;
        padding-right: 1rem;
    }



    .position-inherit {
        position: inherit;
    }


    .top-post {
        top: inherit !important;
    }

    .left-in {
        left: inherit;
    }

    .right-in {
        right: inherit;
    }

    .bottom-in {
        bottom: inherit;
    }

    .min-auto {
        min-width: auto;
    }

    .transnitone-anim {
        transition: 0.4s all ease-in-out;
    }

    .transnitone-anim-fast {
        transition: 0.1s all ease-in-out;
    }

    .transnitone-anim_border {
        transition: all .35s ease;
    }

    .image-white {
        filter: brightness(0) invert(1);
    }
    

} */
