@import url("https://fonts.googleapis.com/css2?family=Outfit:wght@100..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Rubik:ital,wght@0,300..900;1,300..900&display=swap");

/* ====================
Reset Default CSS Start
==================== */

:root {
  --primary-font: "Outfit";
  --secondary-font: "Rubik";
  --primary-color: #9c8cff;
  --secondary-color: #000;
  --ac-20: #f4f2ff;
  --ac-40: #e4e0ff;
  --ac-60: #d2ccff;
  --ac-80: #b8aaff;
  --ac-120: #9c8cff;
  --ac-140: #7a65ff;
  --ac-160: #4f2fff;
  --ac-180: #2e1a80;
  --ac-ash: #6b7280;
  --ac-black: #000000;
  --ac-border: #e0d9ff;
  --ac-BG: #ffffff;
  --text-gradient: linear-gradient(91deg, #000 0.61%, #514869 100%);
  --background: linear-gradient(45deg, #fff, #f6f3ff);
  --box-shadow: 0 0 60px rgba(155, 140, 255, 0.356);
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  font-family: var(--primary-font);
}

h1,
h2,
h3,
h4,
h5 {
  font-family: var(--primary-font);
  margin-top: 0;
}

h6 {
  font-family: var(--secondary-font);
}

a {
  text-decoration: none !important;
}

p {
  color: var(--ac-ash);
  text-align: center;
  font-family: var(--secondary-font);
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 28.8px;
}

ul {
  margin: 0 !important;
  padding: 0 !important;
  list-style: none;
}

button {
  border: none;
  outline: none;
}

input {
  outline: none;
}

body {
  background: rgb(248, 248, 248) !important;
}

html,
body {
  overflow: hidden;
}

.container {
  max-width: 1400px !important;
  margin: auto;
  padding: 0 14px !important;
}

/*====================
Reset Default CSS End
====================*/

/* Webkit Scroll bar */

::-webkit-scrollbar {
  width: 12px;
  background: var(--ac-BG);
}

::-webkit-scrollbar-track {
  -webkit-box-shadow: inset 0 0 6px rgba(255, 255, 255, 0.3);
  border-radius: 10px;
}

::-webkit-scrollbar-thumb {
  border-radius: 10px;
  transition: 0.3s;
  background: var(--primary-color);
  -webkit-transition: 0.3s;
  -moz-transition: 0.3s;
  -ms-transition: 0.3s;
  -o-transition: 0.3s;
}

::-webkit-scrollbar-thumb:hover {
  -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.3);
}
/* Webkit Scroll bar */

/* Navbar Search bar Full Screen css Start */

#searchResults {
  width: 100%;
  max-height: 200px;
  background-color: var(--ac-160);
  color: var(--ac-BG);
  z-index: 999;
  padding: 20px;
  border-bottom-right-radius: 12px;
  border-bottom-left-radius: 12px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  display: none;
  overflow-y: auto;
}

@keyframes expand-button {
  0% {
    position: fixed;
    transform: scale(1);
  }
  50% {
    transform: scale(15);
  }
  100% {
    transform: scale(100);
  }
}
@keyframes slow-opacity {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes show-input {
  from {
    opacity: 0;
    width: 10%;
  }
  to {
    opacity: 1;
    width: 70%;
  }
}

#header .search_box {
  z-index: 100;
}
#header .search_box .expand {
  position: fixed;
  right: 0px;
  top: 0px;
  bottom: 0px;
  right: 0px;
  animation: expand-button 0.6s ease-in;
  transform: scale(100);
  z-index: 50;
}

#header .search_box .expand i {
  animation: slow-opacity 0.3s;
  opacity: 0;
}

#header .search_box .search {
  text-align: right;
  z-index: 100px;
}

#header .search_box .search .search__input {
  visibility: hidden;
  display: none;
  position: fixed;
}

#header .search_box .search .search__input {
  display: flex;
  gap: 10px;
  padding: 0px 20px;
  justify-content: center;
  align-items: center;
  top: 50%;
  left: 50%;
  transform: translate(-50%, 0%);
  width: 50%;
  z-index: 100;
}

#header .search_box .search__input input {
  width: 100% !important;
  border-radius: 6px;
  padding: 12px;
  background: var(--ac-border);
  color: var(--secondary-color);
  font-family: var(--secondary-font);
  font-size: 16px;
  border: 1px solid var(--primary-color);
  font-weight: 500;
}

#header .search_box .search__input .nav_src_btn {
  display: inline-block;
  border-radius: 6px;
  padding: 12px 30px;
  background: var(--primary-color);
  color: var(--ac-BG);
  font-family: var(--secondary-font);
  font-size: 16px;
  font-weight: 500;
  transition: 0.4s;
}

#header .search_box .search__input .nav_src_btn:hover {
  background: var(--secondary-color);
}

#header .search_box .search .search__input--show {
  visibility: visible;
  opacity: 0;
  animation: show-input 0.3s 0.6s ease-in forwards;
}

#header .search_box .search .search__button {
  width: 50px;
  height: 50px;
  border: 0;
  border-radius: 50%;
  background: transparent;
  border: 1px solid var(--primary-color);
  transition: 0.4s;
  -o-transition: 0.4s;
}

#header .search_box .search .search__button.expand {
  background: rgba(0, 0, 0, 0.5);
}

#header .search_box .search .search__button.expand:hover {
  background: rgba(0, 0, 0, 0.5);
}

#header .search_box .search .search__button.expand svg {
  display: none;
}

#header .search_box .search .search__button:hover {
  background: var(--primary-color);
  color: var(--ac-BG);
}

#header .search_box .search__button svg,
#header .search_box .search__button svg path {
  transition: 0.4s;
}

#header .search_box .search__button:hover svg path {
  fill: var(--secondary-color);
}

#header .search_box .search__button:hover svg rect {
  stroke: none;
}

#header .search_box .search .search__button svg {
  width: 49px;
  height: 49px;
}

@media screen and (max-width: 768px) {
  #header .search_box .search .search__input {
    gap: 4px;
    padding: 0px;
    width: 90% !important;
  }

  #header .search_box .search__input .nav_src_btn {
    padding: 12px 20px;
  }
}

/* Navbar Search bar Full Screen css End */

/* Back To Top Start */
#back-to-top {
  position: fixed;
  bottom: 20px;
  right: 20px;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  display: inline-block;
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  transition: 0.4s;
  z-index: 100;
  -webkit-transition: 0.4s;
  -moz-transition: 0.4s;
  -ms-transition: 0.4s;
  -o-transition: 0.4s;
}

#back-to-top svg rect {
  transition: 0.3s;
  -webkit-transition: 0.3s;
  -moz-transition: 0.3s;
  -ms-transition: 0.3s;
  -o-transition: 0.3s;
}

#back-to-top:hover svg rect {
  fill: var(--ac-black);
}

#back-to-top svg {
  width: 60px;
  height: 60px;
}

#back-to-top.show {
  opacity: 1;
  visibility: visible;
}
/* Back To Top End */

/* Hero Start */

#hero {
  width: 100%;
  min-height: 300px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: var(--ac-60);
  overflow: hidden;
}

#hero .hero-wrap {
  position: relative;
  width: 100%;
  text-align: center;
  z-index: 1;
}

#hero .hero-wrap .title {
  max-width: 800px;
  margin: auto;
  font-size: 48px;
  font-family: var(--primary-font);
  margin-bottom: 20px;
  font-weight: bold;
  color: var(--ac-BG);
  line-height: 63px;
}

#hero .hero-wrap .breadcrumb {
  display: inline-flex;
  align-items: center;
  background: var(--ac-BG);
  border-radius: 30px;
  align-items: center;
  justify-content: center;
  padding: 10px 20px;
  margin: 0;
  gap: 6px;
}

#hero .hero-wrap .breadcrumb p,
#hero .hero-wrap .breadcrumb a {
  font-size: 18px;
  font-weight: bold;
  display: block;
  text-align: center;
  color: var(--ac-ash);
  font-family: var(--secondary-font);
  border-radius: 30px;
  margin: 0;
}

#hero .hero-wrap .breadcrumb p {
  color: var(--primary-color);
}

@media screen and (max-width: 992px) {
  #hero .hero-wrap .title {
    font-size: 34px;
    line-height: 42px !important;
  }

  #hero .hero-wrap {
    text-align: center;
    padding: 50px 0;
  }

  #hero .shape2 svg {
    width: 240px;
    height: 240px;
  }

  #hero {
    min-height: 220px;
    max-height: 390px;
  }
}
/* Hero End */

/* Preloader Start */

.preloader {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--ac-BG);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9999;
  transition: opacity 1s ease;
  opacity: 1;
}

/* Fade out class */
.preloader.fade-out {
  opacity: 0;
}

.preloader .loader {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 50px;
  height: 50px;
  font-size: 0;
  color: var(--primary-color);
  display: inline-block;
  margin: -25px 0 0 -25px;
  text-indent: -9999em;
  -webkit-transform: translateZ(0);
  -ms-transform: translateZ(0);
  transform: translateZ(0);
}

.preloader .loader div {
  background-color: var(--primary-color);
  display: inline-block;
  float: none;
  position: absolute;
  top: 0;
  left: 0;
  width: 80px;
  height: 80px;
  opacity: 0.5;
  border-radius: 50%;
  -webkit-animation: ballPulseDouble 2s ease-in-out infinite;
  animation: ballPulseDouble 2s ease-in-out infinite;
}

.preloader .loader div:last-child {
  -webkit-animation-delay: -1s;
  animation-delay: -1s;
}

@-webkit-keyframes ballPulseDouble {
  0%,
  100% {
    -webkit-transform: scale(0);
    transform: scale(0);
  }
  50% {
    -webkit-transform: scale(1);
    transform: scale(1);
  }
}

@keyframes ballPulseDouble {
  0%,
  100% {
    -webkit-transform: scale(0);
    transform: scale(0);
  }
  50% {
    -webkit-transform: scale(1);
    transform: scale(1);
  }
}
/* Preloader End */
