@font-face {
  font-family: "illuzion-LMbold";
  src: url("fonts/LemonMilkBold.otf") format("opentype");
}
@font-face {
  font-family: "illuzion-LMlight";
  src: url("fonts/LemonMilkLight.otf") format("opentype");
}
@font-face {
  font-family: "illuzion-LMmedium";
  src: url("fonts/LemonMilkMedium.otf") format("opentype");
}
@font-face {
  font-family: "illuzion-LMreg";
  src: url("fonts/LemonMilkRegular.otf") format("opentype");
}
@font-face {
  font-family: "illuzion-AKbold";
  src: url("fonts/Akira.otf") format("opentype");
}
@font-face {
  font-family: "illuzion-kanitreg";
  src: url("fonts/Kanit-Regular.ttf") format("truetype");
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  font-size: 62.5%;
}

body {
  height: 100vh;
  width: 100vw;
  overflow-x: hidden;
  background: #07000f;
  scroll-behavior: smooth;
  color: #ffffff;

}
h1 {
  font-size: 12rem;
  /* font-family: "illuzion-LMbold"; */
  font-family: "illuzion-AKbold";
}
h2 {
  font-size: 10rem;
  /* font-family: "illuzion-LMbold"; */
  font-family: "illuzion-AKbold";
}
h3 {
  font-size: 8rem;
  /* font-family: "illuzion-LMbold"; */
  font-family: "illuzion-AKbold";
}
h4 {
  font-size: 4rem;
  /* font-family: "illuzion-LMreg"; */
  font-family: "illuzion-AKbold";
}
h5 {
  font-size: 3rem;
  /* font-family: "illuzion-LMreg"; */
  font-family: "illuzion-AKbold";
}
h6 {
  font-size: 2.5rem;
  /* font-family: "illuzion-LMreg"; */
  font-family: "illuzion-AKbold";
}
p {
  font-size: 1.8rem;
  /* font-family: "illuzion-LMreg"; */
  font-family: "illuzion-Kanitreg";
}
a {
  font-size: 1.8rem;
  /* font-family: "illuzion-LMbold"; */
  font-family: "illuzion-AKbold";
  text-decoration: none;
  color: white;
}


.sidemenu {
  display: flex;
  position: fixed;
  z-index: 10;
  width: 100vw;
  min-height: 100vh;
  background: #000000;
  top: -100%;
  transition: ease-in-out 0.8s 0.5s;
}
.asideanimation {
  display: flex;
  position: fixed;
  z-index: 10;
  width: 100vw;
  min-height: 100vh;
  background: #000000;
  top: 0%;
  transition: ease-in-out 0.8s;
}
.links {
  width: 70vw;
  padding: 4rem;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.sidemenu .links ul li {
  list-style: none;
  height: 7rem;
  overflow: hidden;
}
.sidemenu .links ul li a {
  font-size: 5rem;
  padding: 0.5rem;
  position: relative;
  top: 8rem;
  transition: ease-in-out 0.8s;
}
.asideanimation .links ul li {
  list-style: none;
  height: 7rem;
  overflow: hidden;
}
.asideanimation .links ul li a {
  font-size: 5rem;
  padding: 0.5rem;
  position: relative;
  top: 0rem;
  transition: ease-in-out 0.8s 0.5s;
}
.illusionhover {
  position: relative;
  display: inline-block;
  cursor: pointer;
  z-index: 1;
}
.illusionhover span {
  position: absolute;
  left: 0;
  opacity: 0;
  transition: all 0.3s ease;
  z-index: -1;
}
.illusionhover span:first-of-type {
  top: -5px;
  left: -2px;
  color: rgba(60, 60, 60, 1);
  transform: rotate(0deg);
  background: none;
}
.illusionhover span:last-of-type {
  top: 5px;
  left: 2px;
  color: rgb(97 97 97);
  transform: rotate(0deg);
  background: none;
}
.links .illusionhover span:first-of-type {
  top: -3px;
  left: 4px;
}
.links .illusionhover span:last-of-type {
  top: 12px;
  left: 4px;
}
.illusionhover:hover span {
  opacity: 1;
  z-index: -1;
}

.extralinks {
  background: #0e0e0e;
  width: 30vw;
  padding: 4rem;
  display: flex;
  flex-direction: column;
  justify-content: space-evenly;
}
.connections {
  position: relative;
}
.connections h5 {
  font-size: 1.6rem;
}
.connections a {
  font-family: "illuzion-LMreg";
  text-decoration: underline;
}
.connections span {
  position: absolute;
  font-size: 5rem;
  bottom: -1rem;
  right: 5rem;
}

main {
  position: relative;
  overflow-x: hidden;
}
.p_g1 {
  position: relative;
  width: 100vw;
  /* min-height: 100vh; */
}
.header {
  position: relative;
  top: 0rem;
  width: 100vw;
  min-height: 100vh;
}
.headerimg {
  position: absolute;
  width: 100vw;
  min-height: 100vh;
  top: 0rem;

  display: flex;
}

.colvid{
  width: 100%;
  height: 100vh;
}
.headerimg img {
  width: 100vw;
  height: 100vh;
  object-fit: cover;
}
.headerimg .colvid video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.headerimg  video {
  width: 100vw;
  height: 100vh;
  object-fit: cover;
}

.homepagetop {
  width: auto;
  z-index: 1;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.maintop {
  position: relative;
  width: 75rem;
  left: 50%;
  transform: translate(-50%, 0%);
}
.maintop h1 {
  text-shadow: 0px -1px 5px rgb(0 0 0 / 80%);
}
.maintop p {
  margin-bottom: 2rem;
  text-align: center;
  /* text-shadow: 0px -1px 5px rgb(0 0 0 / 80%); */
}
nav {
  position: absolute;
  top: 0rem;
  width: 100vw;
  background: #000000;
  display: flex;
  align-items: end;
  padding: 2rem 10rem;
  justify-content: space-between;
}
nav img {
  width: 15rem;
}
.hamburger {
  display: flex;
  gap: 2rem;
  z-index: 11;
}
.hamburger h6 {
  font-size: 1.8rem;
  /* font-family: "illuzion-bold"; */
}
.openaside {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  cursor: pointer;
}
.openaside span {
  width: 4rem;
  height: 0.2rem;
  background: white;
  cursor: pointer;
  transition: ease-in-out 0.5s;
}

.ham_menu.closeaside {
  display: flex;
  flex-direction: column;
  gap: 0rem;
  cursor: pointer;
}

.ham_menu.closeaside span:first-child {
  transform: rotate(45deg);
  width: 4rem;
  height: 0.2rem;
  background: white;
  transition: ease-in-out 0.5s;
}

.ham_menu.closeaside span:last-child {
  transform: rotate(-45deg);
  width: 4rem;
  height: 0.2rem;
  background: white;
  transition: ease-in-out 0.5s;
}
.topmarquee,
.bottommarquee {
  background: white;
  padding: 0.8rem 0rem;
  display: flex;
  overflow: hidden;
  gap: 3rem;
}

.diskcontainer {
  display: flex;
  gap: 3.5rem;
  justify-content: space-around;
  flex-shrink: none;
  animation: scroll 15s linear infinite;
}
@keyframes scroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(calc(-100% - 3rem));
  }
}

.bottommarquee {
  justify-content: flex-end;
}
.rightmovemar {
  display: flex;
  gap: 3.5rem;
  justify-content: space-around;
  flex-shrink: none;
  animation: scrollright 15s linear infinite;
}
@keyframes scrollright {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(calc(100% + 3rem));
  }
}
.diskcontainer h5 {
  font-size: 1.4rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  color: #000000;
  flex-shrink: 0;
  white-space: nowrap;
  font-family: "illuzion-LMlight";
}
.diskcontainer h5 span {
  content: "";
  position: relative;
  width: 0.5rem;
  height: 0.5rem;
  background: black;
  border-radius: 5rem;
  white-space: nowrap;
}

/* ========================HOMEPAGE UPCOMING EVENTS============================================================================================================= */
.upcomingeventshmpg{
  width: 100vw;
  min-height: 100vh;
  position: relative;
}
#swjscontainer{
  width: 100%;
  height: 100% !important;
  border: none !important;
}
.flyer_containerhmpg{
  position: relative;
}
.hmup{
  text-align: center;
  padding: 8rem 0rem;
}
.eventshmpg{
  padding: 4rem 30rem;
  position: relative;
}
.eve_hmpg{
  position: absolute;
  bottom: 0rem;
  padding: 2rem !important;
}
.flyer_containerhmpg::before{
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0rem;
  left: 0rem;
  background: linear-gradient(0deg, rgba(0,0,0,1) 0%, rgba(37,0,17,0) 65%);}

  .up-date{
    position: absolute;
    background: rgb(255 255 255 / 35%);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(10px);
    padding: 2rem;
    top: 55% !important;
    left: 0rem !important;
    /* right: 0rem !important; */
    text-align: center;
    border: 1px solid rgba(255, 255, 255, 0.3);
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    z-index: 1;
  }
  .up-date p{
    color: white !important;
  }
  .eventshmpg .owl-nav {
    position: absolute;
    top: 50%;
    width: 100%;
  }

  .eventshmpg .owl-prev,
.eventshmpg .owl-next {
  width: 40px;
  height: 40px;
  line-height: 40px;
  color: #0a69ed;
  border-radius: 50%;
  text-align: center;
  background: #fff;
  position: absolute;
}
.eventshmpg .owl-prev {
  left: -10rem;
  top: -30px;
  font-size: 4rem !important;
}
.eventshmpg .owl-next {
  right: -10rem;
  top: -30px;
  font-size: 4rem !important;
}

/* Styles for the dots container */
.owl-carousel .owl-dots {
  text-align: center; /* Center the dots */
  margin-top: 20px; /* Add space above the dots */
  z-index: 1000;
}

/* Styles for each dot */
.owl-carousel .owl-dot {
  display: inline-block; /* Inline display for each dot */
  width: 2rem; /* Width of each dot */
  height: 0.3rem; /* Height of each dot */
  margin: 5px; /* Space between dots */
  background: #4c4c4c !important; /* Default color */
  cursor: pointer; /* Pointer cursor on hover */
}

/* Styles for the active dot */
.owl-carousel .owl-dot.active {
  background-color: #ffffff !important; /* Color for active dot */
}


  
/* ======================== ABOUT ILLUZION EVENTS============================================================================================================= */
.aboutilluzion{
  display: flex;
  padding: 15rem 10rem;
  gap: 4rem;
  align-items: center;
  position: relative;
}

.about_illuzionimg{
  width: 55vw;
  height: 75vh;
  position: relative;
  overflow:hidden;
}
.about_illuzionimg img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.illuzionpara{
  width: 40vw;
  display: flex;
  flex-direction: column;
  text-align: justify;
}
.illuzionpara a{
  padding: 2rem ;
  border: 0.1rem solid white;
  text-align: center;
}
.tpdiv{
  width: 40vw;
  height: 90vh;
  background: #2a2a2a;
  position: absolute;
  right: 0rem;
}
.tpdiv img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(100%);
}
.tpdiv::after{
  content: "";
  height: 100%;
  width: 100%;
  position: absolute;
  background: rgb(0 0 0 / 46%);
  left: 0rem;
}
/* ========================HOME GALLERY============================================================================================================= */
.hmpg_gallery{
  position: relative;
  width: 100vw;
  min-height: 100vh;
}
.galhmtop, .galhmbott{
  position: relative;
  display: flex;
  flex-wrap: nowrap;
}
.gal_imgcontainer{
  width: 25vw;
  height: 50vh;
  border: 0.08rem solid #222222;
}
.gal_imgcontainer img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}



.gallbutton {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.ar {
  width: 20rem;
  height: 20rem;
  background: rgba(255, 255, 255, 0.2); /* Semi-transparent white background */
  border-radius: 50rem;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  backdrop-filter: blur(10px); /* Blur effect */
  -webkit-backdrop-filter: blur(10px); /* Safari support */
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1); /* Subtle shadow */
  border: 1px solid rgba(255, 255, 255, 0.3); /* Light border */
}

.ar span {
  font-size: 12rem;
  position: relative;
}

.circular-text {
  position: absolute;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}

.circular-text svg {
  position: absolute;
  width: 100%;
  height: 100%;
  transform: rotate(0deg);
  animation: rotate 10s linear infinite;
}

@keyframes rotate {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

/* =================================UPCOMING EVENT PAGE=================================================================================================== */

.pages-header {
  position: relative;
  top: 0rem;
  min-height: 80vh;
  width: 100vw;
  background-color: #010103;
  display: flex;
  justify-content: center;
  align-items: center;
}

.pages-header img {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}
.pages-header h3 {
  z-index: 1;
  font-size: 6rem;
}
.page_header_title {
  z-index: 1;
  text-align: center;
  padding: 0rem 20rem;
  position: relative;
}
.page_header_title span{
  color: transparent; 
  -webkit-text-stroke: 2px #ffffff; 
  font-weight: bold; /
}
.pages-p_g2-title {
  position: relative;
  display: flex;
  justify-content: center;
  gap: 2rem;
  padding: 2rem;
}
.pages-p_g2-title p {
  padding: 1rem;
  border: 0.1rem solid white;
  font-family: "Illuzion-AKbold";
}
.pages-p_g2-title p:nth-child(2) {
  background: white;
  color: black;
}
.page-title {
  text-align: center;
  padding: 4rem;
}

.events {
  display: flex;
  width: 100vw;
  min-height: 100vh;
  gap: 8rem;
  padding: 4rem 10rem;
  flex-direction: column;
}
.eventscontainer {
  position: relative;
  width: 100%;
  display: flex;
  /* flex-direction: column; */
  gap: 10rem;
  justify-content: space-evenly;
  flex-wrap: wrap;
}
.col2 {
  top: 10rem;
}
.eventcard {
  width: 25%;
  height: 100%;
  display: flex;
  flex-direction: column;
  position: relative;

}
.hmpgeve {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  position: relative;

}
.containerdate {
  position: absolute;
  background: rgb(255 255 255 / 35%);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  padding: 2rem;
  /* border-radius: 1rem; */
  top: -1rem;
  left: -2rem;
  text-align: center;
  border: 1px solid rgba(255, 255, 255, 0.3);
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

.containerdate p {
  color: black;
  font-family: "Illuzion-AKbold";
}

.flyer_container {
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.hmpgeveimg{
  width: 100%;
  height: 75vh;
  overflow: hidden;
}
.flyer_container img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.hmpgeveimg img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.details_container {
  padding: 2rem 0rem;
}
.details_container p {
  font-family: "illuzion-kanitreg";
}
.eve_res {
  font-size: 1.4rem;
  padding: 1.5rem;
  border: 0.1rem solid white;
  text-align: center;
  transition: ease-in-out 0.3s;
}
.eve_res:hover {
  background: white;
  color: black;
  font-size: 1.4rem;
  padding: 1.5rem;
}
.eve_res:hover a {
  color: black;
}

/* =========================RESERVATION============================================================================================================== */
.reservationtitle {
  display: flex;
  align-items: end;
}
.reservt {
  padding-bottom: 0rem;
}
.reserp {
  padding: 0rem 40rem;
  text-align: center;
  font-family: "illuzion-kanitreg";
}

.reservationformcontainer, .contactformcontainer {
  display: flex;
  justify-content: center;
  padding: 4rem 30rem;
}
.reservationformcontainer form, .contactformcontainer form {
  width: 100%;
}
.fieldcontainer {
  display: flex;
  padding: 2rem;
  gap: 4rem;
}
.fieldcontainer div {
  width: 100%;
}
.fieldcontainer div input, .message textarea, .fieldcontainer div input[type="date"]  {
  width: 100%;
  font-family: "illuzion-kanitreg";
  padding: 1rem;
  font-size: 1.8rem;
  background-color: transparent;
  border: none;
  border-bottom: 0.1rem solid #6e6e6e;
  outline: none;
  color: #ffffff;
  appearance: none;
}
#date {
  background-image: url('/images/reservation-folder/calendar.png'); /* Replace with your calendar icon URL */
  background-repeat: no-repeat;
  background-position: right 10px center;
  background-size: 20px;
}
.fieldcontainer div input::placeholder, .message textarea::placeholder {
  font-family: "illuzion-kanitreg";
  color: #6e6e6e;
}
.message {
  padding: 2rem;
  width: 100%;
}
.message textarea {
  width: 100%;
  font-family: "illuzion-kanitreg";
  padding: 1rem;
  font-size: 1.8rem;
}

.reservationformcontainer button, .contactformcontainer button{
  font-family: "illuzion-AKbold";
  padding: 2rem;
  font-size: 1.6rem;
  justify-content: center;
  text-align: center;
  position: relative;
  left: 50%;
  transform: translateX(-50%);

}
/* ============================CONTACT US====================================================================================================== */
.contactformcontainer {
  display: flex;
  justify-content: center;
  padding: 4rem 20rem;
  gap: 8rem;
  padding-top: 8rem;
}
.contp {
  text-align: center;
  font-family: "illuzion-kanitreg";
}
.iconset{
  display: flex;
  flex-direction: column;
  justify-content: space-around;
}

.contactformcontainer .iconset .c-iconset{
  display: flex;
  gap: 2rem;
}
.icon{
  width: 6rem;
  height: 6rem;

}
.icon img{
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.text p , .text p a{
  font-family: "Illuzion-Kanitreg";
}
.map{
  width: 100vw;
  height: 50vh;
  padding: 8rem 0rem 0rem 0rem; 
}
.map iframe {
  width: 100%; 
  height: 100%; 
  border: none; 
}
.contactusgrad::before{
  content: "";
  width: 100vw;
  height: 100%;
  background: linear-gradient(0deg, rgba(0,0,0,1) 0%, rgba(37,0,17,0) 100%);  top: 0rem;
  left: 0rem;
  position: absolute;
  z-index: -1;
}
/* ==========================ABOUT US====================================================================================================== */
.aboutus{
  height: 50vh;
}

.abtusheader{
  width: 100vw;
  min-height: 100vh;
  position: relative;
  display: flex;
  align-items: center;
}
.abtsimagecontainer{
  position:absolute;
  width:100vw;
  height: 100vh;
  top: 0rem;

}
.abtsimagecontainer img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(100%); 
  transition: filter 0.3s ease; 
  opacity: 0.6;
}
.abtimg{
  width: 100vw;
  height: 50vh;
  /* padding: 0rem 8rem; */
  z-index: 1;
}
.abtimg img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.aboutustitle{
  min-height:50vh ;
}
.aboutustitle img{
  object-fit: contain;
}
.topabt{
  padding: 8rem 10rem 4rem 10rem;
  display: flex;
  gap: 4rem;
}
.topabt p{
  padding: 1rem 1.5rem;
  border: 0.1rem solid white;
  font-family: "Illuzion-AKbold";

}
.topabt p:nth-child(2){
  background: white;
  color: black;
}

.sect2{
  display: flex;
  gap: 8rem;
  padding: 2rem 10rem 4rem 10rem;
  align-items: center;
}
.statscontainer{
  display: flex;
  gap: 4rem;
}
.stats h2{
  font-size: 8rem;
  color: transparent;
    -webkit-text-stroke: 2px #ffffff;
    font-weight: bold;
}
.stats p{
  font-family: "Illuzion-AKbold";
}
.paraaboutus p{
  text-align: justify;
}
.abtsimgcontainer{
  padding: 4rem 10rem ;
  width: 100vw;
  height: 70vh;
  position: relative;
}
.abtsimgcontainer img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  border: 0.1rem solid rgb(138, 131, 131);
}
.quotediv h5 span{
  color: transparent;
    -webkit-text-stroke: 0.1rem #ffffff;
    font-weight: bold;
}
.quotediv{
  position: absolute;
  bottom: 4rem;
  left:4rem;
}
.fnb{
  display: flex;
  gap: 8rem;
  padding: 4rem 10rem;
  width: 100vw;
  min-height: 100vh;
  align-items: center;
}
.fnbtext{
  display: flex;
  flex-direction: column;
  gap: 4rem;
}
.fnbtext p{
  font-family: "Illuzion-Kanitreg";
}
.menuqr{
  display: flex;
  align-items: center;
  gap: 4rem;
}
.menuqr a{
  font-family: "Illuzion-Kanitreg";
  text-decoration: underline;
}
.qr{
  width: 25vh;
  height: 25vh;
  overflow: hidden;
}
.qr img{
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.fnbimg{
  width: 30vw;
}
swiper-container {
  width: 100%;
  height: 80vh;
  border: 0.1rem solid rgb(138, 131, 131);
}
swiper-slide {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 30vw;
  height:100%;
}
swiper-slide img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.swiper-button-prev svg, .swiper-button-prev svg{
  fill:white !important;
}

.swiper-pagination-bullet-active{
  background: white !important;
  color: white;
}

.services{
  padding: 4rem 10rem;
}
.grid-container {
  display: grid;
  grid-template-columns: repeat(3, 1fr); /* Creates three equal columns */
  grid-template-rows: repeat(2, auto); /* Creates two rows */
  gap: 4rem; /* Adjusts the space between grid items */
}

.item1 {
  grid-column: span 2; 
  grid-row: 1; 
  text-align: right;
  margin: auto 0;
}

.item2 {
  grid-column: 1; 
  grid-row: 1; /* Keeps it in the first row */
  background-color: #e74c3c;
}

.item3 {
  grid-column: 1; 
  grid-row: 2; 
  background-color: #3498db;
}

.item4 {
  grid-column: 2; 
  grid-row: 2; 
  background-color: #2ecc71;
}

.item5 {
  grid-column: 3; 
  grid-row: 2; 
  background-color: #9b59b6;
}
.serv{
  min-height: 40vh;
  overflow: hidden;
  position: relative;
}
.serv h6{
  text-align: center;
  padding: 1rem;
  position: absolute;
  width: 100%;
  background: #0000009c;
  top: 50%;
  transform: translateY(-50%);
}

.serv img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}
/* ============================== GALLERY ========================================================================================== */
.gallery{
  padding: 8rem 10rem;
}
.row {
  display: -ms-flexbox; /* IE10 */
  display: flex;
  -ms-flex-wrap: wrap; /* IE10 */
  flex-wrap: wrap;
  padding: 0 4px;
}

/* Create four equal columns that sits next to each other */
.column {
  -ms-flex: 25%; /* IE10 */
  flex: 25%;
  max-width: 25%;
  padding: 0 4px;
}

.column img {
  margin-top: 8px;
  vertical-align: middle;
  width: 100%;
  border: 0.1rem solid #555;
}

/* ============================ffooter============================================================================================ */
footer{
  position: relative;
  width: 100vw;
  height: 40vh;
}
.ftrbg{
  width: 100vw;
  height: 40vh;
  position: absolute;
  top: 0rem;
  left: 0rem;
  z-index: -1;
}
.ftrbg img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.2;
}
.ftrbg::before{
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0rem;
  left:0rem;
  background: rgb(0,0,0);
  background: linear-gradient(180deg, rgba(0,0,0,1) 13%, rgba(37,0,17,0) 93%);
  
  }
  .ftrmain{
   padding-top: 4rem;
    
  }
  .ftrlogo{
    margin: 0rem 10rem;
    height: 10vh;
  }
  .ftrlogo img{
    height: 100%;
    object-fit: contain;
  }
  .ftr_r2{
    display: flex;
    padding: 3rem 10rem 0rem 10rem ;

  }

  .userfullinks ul {
    display: flex;
    gap: 3rem;
  }
  .userfullinks ul li a {
    font-size: 1.4rem;
  }
  .basefooter{
    display: flex;
    padding: 2rem 10rem;
    background: black;
    position: absolute;
    bottom: 0rem;
    width: 100vw;
    justify-content: space-between;
  }
  .basefooter a{
    font-family: "Illuzion-Kanitreg";
  }

  .asidelogo{
    position: absolute;
    top: 4rem;
    left: 4rem;
    width: 30rem;
  }
  .asidelogoimg{
    width: 100%;
    height: 100%;
    object-fit: contain;
  }




  /* ===================================================================================================================================== */

  @media screen and (max-width: 480px) and (min-width: 300px) {
    html {
      font-size: 42%;
    }
    h1{
      font-size: 8rem;
    }
    h3{
      font-size: 6rem;
    }
    h5{
      font-size: 2rem;
    }
    p{
      font-size: 1.8rem;
    }
    a{
      font-size: 1.6rem;
      color: white;
    }
    .sidemenu{
      flex-direction: column;
    }
    .asideanimation{
      flex-direction: column;
    }
    .links{
      width: 100vw;
      min-height: 60vh;
      padding: 12rem 3rem 2rem 3rem    
    }
    .extralinks{
      width: 100vw;
      min-height: 40vh;
    }
    .sidemenu .links ul li {
      list-style: none;
      height: 5rem;
      overflow: hidden;
  }
  
    .asideanimation .links ul li{
      height: 5rem;
    }

    .sidemenu .links ul li a {
      font-size: 2.8rem;
  }
    .asideanimation .links ul li a{
      font-size: 2.8rem;
    }
    .connections h5{
      font-size: 2rem;
    }
    nav{
      padding: 2rem 2rem;
      background: black;
      position: fixed;
      z-index: 100;
    }
    .nav_reservation{
      display: none;
    }
    .maintop{
      width: 100vw;
      left: 0rem;
      transform: none;
    }
    .maintop h1{
      text-align: center;
    }
    .maintop p{
      padding: 0rem 2rem;
    }
    .eventshmpg{
      padding: 4rem ;
    }
    .eventshmpg .owl-prev {
      left: -5rem;
      top: -30px;
      font-size: 3rem !important;
  }
  .eventshmpg .owl-next {
    right: -5rem;
    top: -30px;
    font-size: 3rem !important;
}
.tpdiv{
  top: 0rem;
  width: 100vw;
  height: 40vh;
}
.aboutilluzion{
flex-direction: column-reverse;
padding: 3rem;
}
.about_illuzionimg{
  width: 85vw;
  height: 50vh;
}
.illuzionpara{
  width: 100vw;
  padding: 3rem;
}
.upcomingeventshmpg{
  padding: 3rem 1rem;
}

.hmpg_gallery{
  display: flex;
}
.galhmtop, .galhmbott{
  flex-direction: column;
}
.gal_imgcontainer{
  width: 50vw;
  height: 25vh;
}

.p_g1{
  min-height: auto;
}
.aboutustitle img{
  object-fit: cover;
}
.sect2{
  flex-direction: column;
  padding: 3rem;
  gap: 2rem;
}
.statscontainer{
  flex-wrap: wrap;
  justify-content: center;
}
.statscontainer .stats{
  text-align: center;
}
.stats h2{
  font-size: 5rem;
}
.abtsimgcontainer{
  padding: 3rem;
  height: 85vh;
}
.quotediv{
  left: 1rem;
}
.fnb{
  padding: 3rem;
  flex-direction: column;
  gap:3rem;
}
.fnbimg{
  width: 100%;
}
.services{
  padding: 3rem;
}
.grid-container{
  display: flex;
  flex-direction: column;
}
.item1{
  text-align: left;
}
.serv{
  min-height: 25vh;
}
.page_header_title{
  padding: 0rem 2rem;
}
.events{
  flex-direction: column;
  padding: 4rem;
  gap: 10rem;
}
.eventscontainer{
  width: 100%;
}
.eventcard{
  width: 100%;
}
.containerdate{
  padding: 4rem;
}

.col2{
  top: 0rem;
}

.resetit{
  padding: 0rem 2rem;
}
.resetit h3{
  font-size: 5rem;
}
.reserp{
  padding: 3rem;
}
.reservationformcontainer, .contactformcontainer{
  padding: 3rem;
}
.fieldcontainer{
  flex-direction: column;
}
.pages-p_g2-title p{
  text-align: center;
}
.contactformcontainer{
  flex-direction:column;
}
.iconset{
  flex-direction: row;
  gap: 2.5rem;
}
.contactformcontainer .iconset .c-iconset{
  flex-direction: column;
  /* align-items: center; */
  justify-content: center;
}

/* Add these styles to your style.css file */

.message-container {
  display: none;
  padding: 15px;
  margin-bottom: 20px;
  border-radius: 4px;
  text-align: center;
  font-family: inherit;
}

.success-message {
  background-color: #4CAF50;
  color: white;
}

.error-message {
  background-color: #f44336;
  color: white;
}

/* Style for disabled button */
button[type="submit"]:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}
.text h6{
  font-size: 2rem;
}
.gallery{
  padding: 3rem;
}
.row{
  flex-direction: column;
}
.column{
  max-width: 100%;
}

.contactusgrad{
  padding: 0rem;
}
.contactusgrad::before{
  background: linear-gradient(0deg, rgba(0,0,0,1) 57%, rgba(37,0,17,0) 100%);
}
  footer{
    width: 100vw;
    height: 40vh;
  }
  .ftrlogo{
    padding: 0rem;
    margin: 0rem 3rem;
  }
  .ftr_r2{
    padding: 2rem 3rem;
    display: flex;
    flex-direction: column;
    
  }
  .userfullinks ul{
    display: flex;
    /* flex-direction: column; */
    gap: 2rem;
    flex-wrap: wrap;

  }
  .userfullinks ul li {
    list-style: none;
  }
  .basefooter{
    padding: 3rem;
    flex-direction: column;
  }

  }