/* CSS RESET */
*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

/* ---------------------------------------------------------------------- General Styles */
:root {
  /* Base font size for the entire website */
  font-size: 62.5%;

  /* ----------------------- Colors */
  /* m = modified */
  /* l = light */
  /* d = dark */
  --color-primary: rgb(135, 85, 46); /* Dark wood brown */
  --color-primary-m-l: rgba(135, 85, 46, 0.55); /* Lighter version */
  --color-primary-m-d: rgba(135, 85, 46, 0.85); /* Darker version */

  /* Secondary Color - Warm amber orange */
  --color-secondary: rgb(215, 124, 43); /* Amber orange */
  --color-secondary-m-l: rgba(215, 124, 43, 0.55); /* Lighter amber */
  --color-secondary-m-d: rgba(215, 124, 43, 0.85); /* Darker amber */

  /* Tertiary Color - Forest green */
  --color-tertiary: rgb(50, 100, 67); /* Earthy forest green */
  --color-tertiary-m-l: rgba(50, 100, 67, 0.55); /* Lighter green */
  --color-tertiary-m-d: rgba(50, 100, 67, 0.85); /* Darker green */

  /* Quaternary Color - Light beige (neutral background) */
  --color-quaternary: rgb(245, 239, 224); /* Light beige */
  --color-quaternary-m-l: rgba(245, 239, 224, 0.55); /* Lighter beige */
  --color-quaternary-m-d: rgba(245, 239, 224, 0.85);

  /* ----------------------- Padding */
  /* 
      xl     = extra large
      l      = large
      m      = medium
      s      = small
  */

  --padding-xl: calc(2rem + 6vh) calc(2rem + 6vw);
  --padding-l: calc(3rem + 4vh) calc(3rem + 4vw);
  --padding-m: calc(2rem + 2vh) calc(2rem + 2vw);
  --padding-s: calc(1rem + 1vh) calc(1rem + 1vw);

  /* ----------------------- Font Size */
  /* 
      l      = large
      m      = medium
      s      = small
      xs     = extra small
  */

  --font-size-l: calc(1.5rem + 2vw);
  --font-size-m: calc(1rem + 1.5vw);
  --font-size-s: calc(1.2rem + 0.6vw);
  --font-size-xs: calc(0.5rem + 0.8vw);

  /* ----------------------- Font Family */

  --font-family-main: "Fredoka", sans-serif;
  --font-family-sub: "Poppins", sans-serif;
}

body {
  font-family: var(--font-family-sub);
  line-height: 1.5;
  color: #fff;
}

.wrapper {
  display: grid;
  grid-template-columns:
    [container-start] 1fr [center-start] repeat(
      14,
      [col-start] minmax(min-content, 11rem) [col-end]
    )
    [center-end] 1fr [container-end];

  grid-template-rows: repeat(6, min-content);
  background-color: var(--color-primary);
}

a {
  text-decoration: none;
  color: var(--color-quaternary);
}

li {
  list-style: none;
}

/* ********************************************************************************************************** Header **/

#main-header {
  background-color: white;
  grid-column: center-start / center-end;
  padding: var(--padding-s);
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
}

.logo-container {
  height: 8rem;
  width: 8rem;
}

.logo-container img {
  width: 100%;
  height: 100%;
  border-radius: 0%;
}

.nav-menu {
  display: flex;
  align-items: center;
}

.hamburger {
  z-index: 1;
}

.nav-menu li {
  position: relative;
  padding-left: 1.5vw;
}

.nav-menu li a {
  position: relative;
  padding: 1rem 0.3rem;
  font-size: calc(1rem + 0.4vw);
  color: black;
  display: flex;
  gap: 0.5rem;
  align-items: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
}

.navbar {
  z-index: 1000;
}

.hamburger {
  display: none;
}

/* Nav Links Animation( Magic ) */
ul.nav-menu li a:link::before,
ul.nav-menu li a:visited::before,
ul.nav-menu li a:link::after,
ul.nav-menu li a:visited::after {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 0.15rem;
  background-color: black;
  transform: scaleX(0);
  transition: transform 0.6s cubic-bezier(1, 0, 0, 1);
}

ul.nav-menu li a:link::before,
ul.nav-menu li a:visited::before {
  top: 0;
  /* Transform-Origin is center by default */
  transform-origin: left;
}

ul.nav-menu li a:link::after,
ul.nav-menu li a:visited::after {
  bottom: 0;
  transform-origin: right;
}

ul.nav-menu li a:hover::before,
ul.nav-menu li a:active::before,
ul.nav-menu li a:hover::after,
ul.nav-menu li a:active::after {
  transform: scaleX(1);
}
@media screen and (max-width: 800px) {

    /* ---------------------------- Hamburger Menu */
    .hamburger {
        display: block;
        height: 5rem;
        width: 5rem;
        position: fixed;
        top: 3rem;
        right: 4rem;
        padding: 0.6rem;
        cursor: pointer;
        z-index: 100000000;
    }

    /* ----------------------- Hamburger Menu Line */
    .hamburger-line {

        position: absolute;
        background-color: rgb(50, 100, 67);
        height: 0.3rem;
        width: 3rem;
    }

    .hamburger-line:first-child {
        width: 6rem;
        top: 0;
        left: 0;
        transition: all 0.35s ease-in-out;
    }

    .hamburger-line:nth-child(2) {
        top: 1rem;
        width: 2.5rem;
        left: 0;
        transition: all 0.2s ease-in-out;
    }

    .hamburger-line:last-child {
        width: 4.5rem;
        top: 2rem;
        left: 0;
        transition: all 0.35s ease-in-out;
    }

    /* --- Toggling Nav Bar --- */
    .line-1 {
        transform: rotate(45deg) translate(0.3rem, 1.4rem);
        width: 3.5rem !important;
    }

    .line-2 {
        visibility: hidden;
    }

    .line-3 {
        transform: rotate(-45deg) translate(0, -1.15rem);
        width: 3.5rem !important;
    }

    .block.visible {
        transform: translateX(0);
    }

    /* --- Nav Links --- */
    nav.navbar,
    ul.nav-menu {
        flex-direction: column;
        justify-content: space-evenly;
        align-items: flex-start;
        gap: 2rem;

    }

        nav.navbar {
            position: fixed;
            top: 0;
            right: 0;
            width: 25rem;
            height: 100vh;
            padding: 8rem 2rem 4rem 0.2rem;
            background-color: orange;
            transform: translateX(100rem);
            transition: all 0.55s cubic-bezier(1, 0, 0, 1);
    
            /* ← Add these */
            overflow-y: auto;
            /* allow vertical scroll */
            overflow-x: hidden;
            /* prevent horizontal scroll */
            -webkit-overflow-scrolling: touch;
            /* smooth scrolling on iOS */
        }

    .nav-menu li a {
        color: white;
        display: flex;
        flex-direction: row;
        align-items: center;
        gap: 1rem;
        font-size: 1.6rem;
    }

    .logo-container {
        height: 6rem;
        width: 6rem;
    }

    /* ******************************************Know Us More Section */
    .more__contant p,
    .more__contant ul li p {
        font-size: 1.6rem;
    }

    .more__contant h3 {
        font-size: 2.5rem;
    }
}

@media screen and (max-width: 650px) {

    /* Image Gallary Section */
    .gallery img {
        height: 10rem;
        margin: 0 1rem;
    }
}

@media screen and (max-width: 390px) {
    /* Know Us More Section */

    .container1 h2 span {
        display: block;
        /* width: 200px; */
    }

    .image-slider::before {
        width: 8rem;
    }

    .image-slider::after {
        width: 8rem;
    }
}