@import url("https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Audiowide&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Audiowide&family=Rubik:ital,wght@0,300..900;1,300..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Anybody:ital,wght@0,100..900;1,100..900&family=Audiowide&family=Rubik:ital,wght@0,300..900;1,300..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=ABeeZee:ital@0;1&family=Anybody:ital,wght@0,100..900;1,100..900&family=Audiowide&family=Rubik:ital,wght@0,300..900;1,300..900&display=swap");
@import url('https://fonts.googleapis.com/css2?family=Comfortaa:wght@300..700&display=swap');
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

.container {
  width: 90%;
  margin: 0 auto;
}

.rubic {
  font-family: "Rubik", sans-serif !important;
}

.white {
  color: #fff !important;
}

.red {
  color: #bf1b21;
}

.pt-55 {
  padding: 55px 0;
}

.weight8 {
  font-weight: 800;
}

header {
  background-color: #bf1b21;
  width: 100%;
}

.logo {
  display: flex;
  justify-content: center;
  padding: 25px 0;
}

.logo img {
  display: block;
  width: 90px;
}

.menuLinks {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 16px;
  padding-top: 38px;
  font-family: "Montserrat", sans-serif;
  font-weight: 800;
  text-transform: uppercase;
}

.menuLinks li {
  list-style-type: none;
}

.menuLinks a {
  text-decoration: none;
  color: #323232;
}

.menu {
  font-family: "Montserrat", sans-serif;
  color: #f0f0f0;
  font-size: 20px;
  display: flex;
  gap: 40px;
}

.menu a {
  text-decoration: none;
  color: #f0f0f0;
}

.menu li {
  list-style-type: none;
}

.mobileMenu {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.button {
  border-top: 7px solid #bf1b21;
  border-bottom: 7px solid #bf1b21;
  border-radius: 5px;
  padding: 22px 35px;
}

.catalog h1 {
  font-size: 77px;
  font-family: "Anybody", sans-serif;
  font-weight:700;
}

.catalog span{
    font-weight:400;
}

.catalog .bike .color{
     font-family: "Comfortaa", sans-serif;
     font-size:26px;
}

.spec {
    position: relative;
    padding-left:22px;
}

.spec .arrow {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    height:11px;
    width:11px;
}

.bike{
    margin-top:80px;
}

.bikeImg{
    width:60%;
}

.bikeImg img{
    width:100%;
}

.bikeSpecs{
    width:40%;
}

.bikes {
  display: flex;
  gap: 63px;
}

.gallery{
    display:flex;
    gap:40px;
    align-items:center;
}

.gallery img{
width:100%;
}

.galleryPic{
    width:20%;
}

.specs {
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 100%;
}

.spec {
  width: 100%;
  display: flex;
}

.spec a{
    font-family: "Comfortaa", sans-serif;
    text-decoration:none;
    color:black;
    font-size:25px;
    font-weight:500;
}

.spec p {
  font-family: "Montserrat", sans-serif;
  font-family: 20px;
}

.spec p img{
    width:76px;
}

.bikeSpecs .desc {
  font-size: 20px;
  font-family: "ABeeZee", sans-serif;
  font-weight: 400;
  padding: 30px 0;
}

.price {
  display: flex;
  flex-direction: column;
}

.price a {
  font-family: "Montserrat", sans-serif;
  font-size: 26px;
  text-decoration: none;
  color: black;
  font-weight: 800;
  text-align: center;
}

.priceTag {
  font-size: 77px;
  font-family: "Anybody", sans-serif;
}

.chars{
    margin-top:120px;
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-bottom:50px;
}

.charsLeft h3{
    font-size:50px;
    font-family: "Montserrat", sans-serif;
    
}

.charsRight{
  display:flex;
}

.charsRight p{
    border:1px solid black;
    border-radius:50%;
    font-size:37px;
    height:50px;
    width:50px;
    cursor:pointer;
    
}

.hideChars{
    padding:0 18px;
}

.showChars{
    padding:0 14px;
}

.hideChars{
    margin-right:27px;
}


  .tableContainer {
    display: none;
  }

.tableContainer table{
    border-top:2px solid black;
    width:100%;
    border-collapse: collapse;
    margin-bottom:50px;
    font-family: "Montserrat", sans-serif;
    font-size:28px;
}

.tableContainer table th{
    text-align:left;
    border-bottom:2px solid black;
}

.tableContainer table th, .tableContainer table td{
    padding:15px 35px;
}

.tableContainer table tr td:nth-child(1),.tableContainer table tr th:nth-child(1){
    border-right:2px solid black;
}

footer {
  background-color: #2c2c2c;
  font-family: "Montserrat", sans-serif;
  color: #f0f0f0;
  font-size: 25px;
  padding: 50px 0;
}

.fBlocks {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.fBlock h1 {
  font-size: 22px;
  font-weight: 600;
}

.fBlock span {
  font-size: 130px !important;
  font-weight: 700;
}

.fLinks {
  display: flex;
}

.fLink:nth-child(2) {
  margin-left: 130px;
}

.fLink a {
  display: block;
  text-decoration: none;
  color: #f0f0f0;
}

.fCall,
.fCallMobile {
  display: flex;
  flex-direction: column;
  gap: 80px;
}

.fCall .phone,
.fCallMobile .phone {
  text-decoration: none;
}

.callback {
  border-top: 4px solid #0188e3;
  border-bottom: 4px solid #0188e3;
  text-decoration: none;
  padding: 12px 30px;
}

@media(max-width:1716px){
    .spec a{
    font-size:20px;
}
}
 @media(max-width:1435px){
    .spec a{
    font-size:15px;
}
.bikeSpecs .desc {
    font-size:15px;
    
}
}




 @media (max-width: 1265px) {
  .fLink:nth-child(2) {
    margin-left: 30px;
  }
}

@media (max-width: 1190px) {
  .fLinks {
    flex-direction: column;
  }
  .fLink:nth-child(2) {
    margin-left: 0;
    margin-top: 55px;
  }

  .fBlock span {
    font-size: 100px !important;
  }
  
}   

@media(max-width:1142px){
     .spec a{
    font-size:13px;
}


.bikeSpecs .desc {
    font-size:13px;
    
}

.priceTag {
    font-size: 50px;
}
.price a {
    font-size: 20px;
}
}


@media(max-width:1033px){
    .bikes{
        flex-direction:column;
        gap:30px;
    }
    
    .specs{
        flex-direction:row;
        justify-content:center;
    }
    
    .spec{
        width:auto;
    }
    .spec p a span{
        display:none;
    }
    
    .bikeImg{
        width:100%;
    }
    
    .bikeSpecs{
        width:100%;
    }
    .price {
 flex-direction:row;  
 justify-content:space-between;
 align-items:center;
    
}
.bike {
    margin-top: 17px;
}

.chars {
    margin-top: 15px;
}

.charsRight p{
    font-size:11px;
    height:15px;
    width:15px;
}

.hideChars{
    padding:0 5px;
}

.showChars{
    padding:0 4px;
}

.spec {
    position: relative;
    padding-top:22px;
}

.spec .arrow {
    position: absolute;
    top: 0;
    left:50%;
    transform: translateY(-50%);
    height:11px;
    width:11px;
    transform: rotate(90deg)
}

}

@media (max-width:960px){
    .menu{
        display:none;
    }
    .menuMobile{
        display:block;
        font-family: "Montserrat", sans-serif;
      color: #f0f0f0;
         font-size: 20px;
    }
}

@media(min-width:960px){
    .menuMobile{
        display:none;

    }
}

@media (max-width: 900px) {
  .hide-on-mobile {
    display: none;
  }
  .hide-on-desktop {
    display: block;
  }

  .fCallMobile {
    margin-top: 25px;
    gap: 40px;
  }

  .fLink {
    font-size: 12px;
  }

  .fBlock span {
    font-size: 40px !important;
  }

  .fBlock ul li {
    font-size: 16px;
  }

  .fCallMobile a {
    font-size: 12px;
  }

  .fBlock h1 {
    font-size: 8px;
  }
}

@media (min-width: 900px) {
  .hide-on-mobile {
    display: block;
  }
  .hide-on-desktop {
    display: none;
  }

  .fCallMobile {
    display: none;
  }
}

@media (max-width:820px){
    .tableContainer table {
     font-size:14px;   
    }
    
}

@media (max-width:720px){
    .catalog h1 {
        font-size:21px;
    }
    
    .catalog .bike .color {
     font-size:9px;   
    }
    
    .bikeSpecs .desc {
    font-size: 8px;
}



.charsLeft h3 {
    font-size:10px;
}

.priceTag{
    font-size:20px;
}

.price a{
    font-size:15px;
}

.button {
    border-top: 4px solid #bf1b21;
    border-bottom: 4px solid #bf1b21;
    border-radius: 5px;
    padding: 5px 20px;
}


    
}

@media (max-width:460px){
    .tableContainer table {
     font-size:10px;   
    }
    
    .tableContainer table th, .tableContainer table td {
    padding: 15px 15px;
}
    
}
