body {
    font-family: "Work Sans";
    font-weight: 400;
    color: #444;
    background: #c9cbcb;
    /*background: radial-gradient(ellipse at center, #b095cc 0%, #8a6fb3 40%, #5e4a87 100%);*/
}

a:hover {
    color: black;
    text-decoration: none;
}

a {
  padding-right: 5px;
  font-family: "Work Sans";
  font-weight: 400;
  color: #444;
}

h1 {
    font-family: "Work Sans";
    font-weight: 400;
    color: #444;
    text-align: center;
    font-size: 5vw;
}

h2 {
    font-family: "Work Sans";
    font-weight: 100;
    color: #444;
    text-align: center;
    font-size: 350%;
}

h3 {
    font-size: 1.75rem;
    font-weight: normal;
    color: white;
}

h4 {
   text-align: center;
   font-size: 3vw;
   color: #8A28D6;
   font-weight: bold;
}

@media (max-width: 768px) {
  h4 {
    font-size: 4vw;
  }
}

.responsiveText {
    display: none;
}

@media (max-width: 768px) {
    .responsiveText {
        display: block;
    }
}

.headerContainer {
  width: 100%;
  padding: 0 20px;

}

.headerRow {
  display: flex;
  align-items: center;
  width: 100%;
  position: relative;
  padding-top: 30px;
  padding-bottom: 20px;
}

@media (max-width: 768px) {
  .headerRow {
    flex-direction: column; 
    align-items: center;
  }

}

#NavFlex1 {
  display: flex;
  justify-content: flex-start;
}

#NavFlex2 {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}

#NavFlex3 {
  display: flex;
  justify-content: flex-end;
}


@media (max-width: 768px) {
  #NavFlex1,
  #NavFlex2,
  #NavFlex3 {
    flex: 1;
    margin-bottom: 2rem;
  }

  #NavFlex2 {
    position: static;          
    transform: none;          
  }
}

#NavFlex1,
#NavFlex2 {
  flex: 1;
}

#NavFlex1 {
  margin-bottom: 10px;   /* space between sofa and logo */
}



#NavBar {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 30px;
  margin-top: 10px;
  width: 100%;
  z-index: 1000;
}

.navbar {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

#NavBar.active {
  display: flex;   
}


/* Hamburger icon */
.hamburger {
  display: none;
  cursor: pointer;
  padding: 6px;
  width: fit-content;
  height: fit-content;
  
}

.hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: black;
  margin: 4px 0;
}

/* Mobile view */
@media (max-width: 768px) {

  .hamburger {
      display: block;
  }

  #NavBar {
      display: none;
      flex-direction: column;
      background: white;
      position: absolute;
      top: 50px;
      left: 0;
      width: 70%;
      text-align: center;
      gap: 0;
  }

  #NavBar.active {
    display: flex;
}

  #NavBar a {
      padding: 5px;
      display: block;
      border-top: 1px solid #eee;
  }

}


#footerContainer {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  justify-content: center;
}

.FooterCols1, .FooterCols3 {
    width: 35%;
    text-align: center;
    background-color: #282828;
    color: white;
    padding-top: 2%;
}

.FooterCols2 {
    width: 30%;
    text-align: center;
    justify-content: center;
    background-color: #282828;
    color: white;
    padding-top: 2%;
}

@media (max-width: 768px) {
  .FooterCols1,
  .FooterCols2,
  .FooterCols3 {
    width: 90%;
    margin-bottom: 1rem;
  }
}

#Sofa {
    width: 180px;
    height: auto;
}


#Logo {
    width: 450px;
    height: auto;
    display: block;
}


@media (max-width: 768px) {
  #Sofa {
    display: block;
    margin: 0 auto;
  }

  #Logo {
    width: 250px;
  }
}


.cameraLI {
    padding:0;
}

ul {
    padding-left:1.25rem;
    list-style-image: url('icons/Camera30.png');
}

 
  ul li::before {
    content: ''; /* No text */
    display: inline-block;
    /*width: 30px; /* Bullet width */
    height: 30px; /* Bullet height */
    background-image: url('icons/Camera30.png'); /* Custom image */
    background-size: cover; /* Make sure the image covers the entire box */
    margin-right: 10px; /* Space between the bullet and text */
  }

blockquote {
  border:2px solid #f0f0f0;
  padding:1.25rem;
  width: 95%;
}

* {
  box-sizing: border-box;
}


#GalleryContainer {
    justify-content: center;

}

.GalleryCols {
    display: flex;
    width: 95%;
    flex-wrap: wrap;
    justify-content: center;
}

.GalleryImg {
  width: 100%;
  height: auto;
  display: block;
}

#LandingPageContainer {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
  max-width: 1200px;
  margin: 0 auto;   /* centers the entire gallery */
}

.GalleryItem {
  padding: 5px;
}




#FooterP {
    color: #777;
    font-family: "Work Sans";
    font-weight: 400;
    font-size: 130%;
    line-height: 0.5em;
}

#AboutusFlex {
    /*display: flex;*/
    justify-content: center;
    /*width:95%;*/
}

#AboutUsDiv {
    display: flex;
    width: 95%;
    /*justify-content: space-between;*/
    justify-content: center;
    gap: 10px;
}

#AboutusImg {
    Width: 100%;
}

/* Container for the flip card */
.flip-card-portrait {
  flex: 0 0 19%;
  aspect-ratio: 191 / 270;
  perspective: 1000px;
  max-width: 15rem;
  box-sizing: border-box;
}


@media (max-width: 767.98px) {
  .flip-card-portrait {
    flex: 0 0 30%;
    margin: 0.25rem;
  }

  /* 5th and 10th images = 2nd row items */
  .flip-card-portrait:nth-child(5),
  .flip-card-portrait:nth-child(10) {
    flex: 0 0 30%;
  }
}

  .flip-card-landscape {
    flex: 0 0 23.75%;
  /*width: 100%; /* Parent controls scaling */
  aspect-ratio: 270 / 191;
  perspective: 1000px;
  max-width: 20rem;
  box-sizing: border-box;
  }

  @media (max-width: 767.98px) {
    .flip-card-landscape {
      flex: 0 0 47.5%;
      margin: 0.25rem;
    } 
  }

  .image-container {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  width: 100%;
}
  
  /* The inner part of the card */
  .flip-card-inner {
    position: relative;
    width: 100%;
    height: 100%;
    transform-style: preserve-3d; /* This preserves the 3D effect */
    transition: transform 0.6s; /* Smooth flip effect */
  }
  
  /* Front of the card */
  .flip-card-front, .flip-card-back {
    position: absolute;
    width: 100%;
    height: 100%;
    backface-visibility: hidden; /* Hides the back when flipped */
  }
  
  /* Style for the front of the card */
  .flip-card-front img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Ensures image covers the area */
  }
  
  /* Style for the back of the card */
  .flip-card-back {
    transform: rotateY(180deg); /* Initially rotate the back side */
  }
  
  .flip-card-back img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  
  /* Hover effect - flip the card */
  .flip-card-portrait:hover .flip-card-inner {
    transform: rotateY(180deg); /* Flip the inner container */
  }

    /* Hover effect - flip the card */
    .flip-card-landscape:hover .flip-card-inner {
        transform: rotateY(180deg); /* Flip the inner container */
      }
    



