
:root {
  --menu-speed: 0.75s;
}

.menu-wrap {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 110;
}
.menu-wrap .toggler {
  position: absolute;
  top: 0;
  right: 0;
  opacity: 0;
  height: 50px;
  width: 50px;
  cursor: pointer;
  z-index: 2;
}
.menu-wrap .hamburger {
  position: absolute;
  top: 8px;
  z-index: 1;
  border-radius: 40px;
  height: 42px;
  width: 42px;
  padding: 20px 8px;
  right: 8px;
}

.menu-wrap .hamburger.color {
  background: rgba(100,100,100,0.2);
}

/* Hamburger line */
.menu-wrap .hamburger > div {
  position: relative;
  top: 0;
  right: 0;
  width: 100%;
  height: 2px;
  background: #fafafa;
  align-items: center;
  justify-content: center;
  transition: 0.4s;
}

/* Hamburger top & bottom line */
.menu-wrap .hamburger > div:before,
.menu-wrap .hamburger > div:after {
  content: "";
  position: absolute;
  top: 10px;
  left: 0;
  background: inherit;
  height: 2px;
  width: 100%;
  z-index: 1;
}
.menu-wrap .hamburger > div:after {
  top: -10px;
}

/* Toggler Animation */
.menu-wrap .toggler:checked + .hamburger > div {
  transform: rotate(135deg);
}
.menu-wrap .toggler:checked + .hamburger > div:before,
.menu-wrap .toggler:checked + .hamburger > div:after {
  top: 0;
  transform: rotate(90deg);
}

/* Rotate on hover when checked */
.menu-wrap .toggler:checked:hover + .hamburger > div {
  transform: rotate(225deg);
}
.menu {
  position: fixed;
  top: 0;
  right: 0;
  background: #111111;
  height: 100vh;
  width: 0;
  align-items: center;
  justify-content: center;
  text-align: center;
  opacity: 0;
  transition: all var(--menu-speed) ease;
}
.menu > div {
  position: relative;
  top: 0;
  right: 0;
  height: 100%;
  width: 100%;
  align-items: center;
  justify-content: center;
  text-align: center;
  opacity: 0;
  transition: opacity 0.4s ease-in;
}
.menu ul {
  list-style: none;
}
.menu li {
  padding: 0.5rem 0;
}
.menu > div a {
  text-decoration: none;
  color: #fafafa;
  opacity: 0;
  transition: opacity 1s ease-in;
}
.menu a:hover {
  color: rgb(230, 177, 177);
  transition: color 0.3s ease-in;
}

/* Show Menu */
.menu-wrap .toggler:checked ~ .menu {
  opacity: 1;
  width: 30vw;
  transition: all var(--menu-speed) ease;
}
.menu-wrap .toggler:checked ~ .menu > div {
  opacity: 1;
  transition: opacity 0.4s ease-in;
  overflow-y: scroll;
}


.menu-wrap .toggler:checked ~ .menu > div::-webkit-scrollbar {
  display: none;
}

/* Hide scrollbar for IE, Edge and Firefox */
.menu-wrap .toggler:checked ~ .menu > div {
  -ms-overflow-style: none;  /* IE and Edge */
  scrollbar-width: none;  /* Firefox */
}
.menu-wrap .toggler:checked ~ .menu > div a {
  opacity: 1;
  transition: opacity 1s ease-in;
}

@media (max-width: 500px) {
  .menu-wrap .toggler:checked ~ .menu {
    width: 65vw;
  }
}













.menu-wrap {
	min-width: 300px;
	max-width: 300px;
	background: #1d1919;
	color: #fff;
	-webkit-transition: all 0.3s;
	-o-transition: all 0.3s;
	transition: all 0.3s;
}

.menu-wrap.active {
	margin-left: -300px;
}

.menu-wrap .logo {
	display: block;
	width: 120px;
	height: 120px;
	margin: 0 auto;
}

.menu-wrap .logo span {
	display: block;
}

.menu-wrap ul.components {
	padding: 0;
}

.menu-wrap ul li {
	font-size: 16px;
}

.menu-wrap ul li>ul {
	margin-left: 10px;
}

.menu-wrap ul li>ul li {
	font-size: 14px;
}

.menu-wrap ul li a {
	padding: 10px 0;
	display: block;
	color: rgba(255, 255, 255, 0.8);
	border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.menu-wrap ul li a:hover {
	color: #d8a53f;
}

.menu-wrap ul li.active>a {
	background: transparent;
	color: #d8a53f  ;
}

@media (max-width: 991.98px) {
	.menu-wrap {
		margin-left: -300px;
	}
	.menu-wrap.active {
		margin-left: 0;
	}
}