/*=====================================
Tamplate Name: Restaurant Template
Author: Themetech
Description: Restaurant Template
Version: 1.0
=========================================*/

/*==========================================
[Table of contents]

1.Header Area 
2.Popup Mobile Menu
3.Sticky Menu 
4.Hero
5.Common
6. Counter
7.service
8.about
9.special-dish
10. delicious-menu
11.our-chefs
12.testimonial
13.blog
14.Contact
15.Footer
16.Scroll Top 
17.Theme Switcher 
18.Preloader
============================================*/

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
body,html {
  font-family: 'DM Sans', sans-serif;
  overflow-x: hidden;
}

:root {
  --primary-color: #FD9900;
  --secondary-color: #0F172A;
  --main-color: #FD9900;
  --fontFamily-forum: 'Forum', cursive;
  --fontFamily-dm_sans: 'DM Sans', sans-serif;

/*======================
    font-size 
========================*/
  --fontSize-12: 12px;
  --fontSize-14: 14px;
  --fontSize-label-2: 1.2rem;

/*======================
    font-weight
========================*/
  --weight-regular: 400;
  --weight-bold: 700;
/*======================
  line-height
========================*/
  --lineHeight-1: 1em;
  --lineHeight-2: 1.2em;
  --lineHeight-3: 1.5em;
  --lineHeight-4: 1.6em;
  --lineHeight-5: 1.85em;
  --lineHeight-6: 1.4em;
  
/*======================
  letter-spacing
========================*/
  --letterSpacing-1: 0.15em;
  --letterSpacing-2: 0.4em;
  --letterSpacing-3: 0.2em;
  --letterSpacing-4: 0.3em;
  --letterSpacing-5: 3px;
  --white-alpha-20: hsla(0, 0%, 100%, 0.2);
  --white-alpha-10: hsla(0, 0%, 100%, 0.1);

/*======================
  SPACING
========================*/
  --section-space: 100px;

/*======================
  TRANSITION
========================*/
   --transition-1: 250ms ease;
   --transition-2: 500ms ease;
   --transition-3: 1000ms ease;
}
body[data-theme="light"] {
	--color: #000;
	--bar: #fff;
	--filter: filter(1);
	--background: #fff;
	--background-1: #f1f2f6;
	--background-2: #f1f2f6;
  --background-rgba: rgba(255, 255, 255, 0.3);
	--color-heading: #0f172a;
	--body-color: #3c3e41;
	--body-color-2: #F1F2F6;
	--btn-background: #fff;
	--progress-back: #fff;
	--slider-left-back: #fff;
	--menu-shadow: 0 0 10px rgb(0 0 0 / 20%);
	--all: 0 0 10px rgb(0 0 0 / 20%);
  --opacity: 0;
   
} 
body[data-theme="dark"] {
	--color: #fff;
	--bar: #000;
  --filter: filter(0);
  --background:  #10101a;
	--background-1: #0b0b13;
	--background-2: #141421;
  --background-rgba: rgba(0, 0, 0, 0.6);
	--btn-background: #000;
	--body-color: #a9afc3;
	--body-color-2: #a9afc3;
	--color-heading: #fff;
	--progress-back: #141421;
	--slider-left-back: #141421;
	--menu-shadow: 0 0 10px rgb(0 0 0 / 50%);
	--all: 0 0 10px rgb(0 0 0 / 0%);
  --opacity: .8;
}
.color-primary {
   color: var(--primary-color);
 }
 .color-secondary {
  color: var(--secondary-color);
}
.color-bg-primary {
  background-color: var(--primary-color);
}

/*======================
1.Header Area 
========================*/
.header-area {
	position: fixed;
	left: 0;
	top: 0%;
	right: 0;
	text-transform: capitalize;
	z-index: 99;
	padding: 10px 0;
	background: transparent;
  border-block-end: 1px solid var(--white-alpha-20);
}
.offcanvas-header {
  justify-content: space-between;
}
.logo a svg {
  color: var(--color);
}
.header-area .logo a {
	font-size: 22px;
}
.nav-link {
	color: #a9afc3 !important;
	font-weight: var(--weight-regular);
	z-index: 10;
	position: relative;
  font-size: var(--fontSize-14);
  text-transform: uppercase;
}

.nav-link.active {
	color: var(--main-color) !important;
	
}
li.nav-item {
	padding-right: 10px;
}
.header-area a:hover {
	color: var(--main-color) !important;
}
.cool-link {
  display: inline-block;
  text-decoration: none;
}
.cool-link::after {
  content: "";
  display: block;
  width: 0;
  height: 2px;
  background: var(--primary-color);
  transition: width 0.3s;
}
.cool-link:hover::after {
  width: 100%;
}

/*=======================
2.Popup Mobile Menu
=========================*/

.popup-mobile-menu {
	background: var(--background);
	transition: all 0.5s ease-out;
}
.navbar-light .navbar-toggler {
    border: none;
    box-shadow: none;
}
.btn-close:focus {
	box-shadow: none;
}
.navbar-toggler svg {
	color: var(--color);
}
.btn-close:focus {
	box-shadow: none;
}
.offcanvas-header button {
	background: none;
	border: none;
}
.offcanvas-header svg {
	color: var(--color);
}
.offcanvas-header button i {
    color: var(--color);
}
/*====================
3.Sticky Menu 
======================*/
.menu_fixed {
  position: fixed;
  top: 0;
	width: 100%;
	background: var(--background);
	box-shadow: var(--menu-shadow);
	transition: .3s;
	z-index: 99;
}

/*================================
4.Hero
==================================*/
.hero {
  width: 100%;
}
.hero-title {
  color: var(--body-color-2);
}
.carousel-caption p {
  color: var(--body-color-2);
}
.carousel-caption {
  width: 100%;
  top: 35%;
  left: 0;
}

/*========================
5.Common 
==========================*/
h1,
h2,
h3,
h4,
h5,
h6 {
	line-height: 120%;
	font-weight: 500;
	margin: 0 0 15px;
	text-transform: capitalize;
}
ol,ul {
  padding: 0 !important;
  margin: 0 !important;
}

a {
	text-decoration: none;
}

img {
	max-width: 100%;
	height: auto;
	border: 0;
	vertical-align: middle;
}
svg {
	fill: currentColor;
}
.heading {
  font-size: 40px;
  color: var(--color);
}
.subtitle {
  color: var(--primary-color);
  text-transform: uppercase;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 2px;
  margin-bottom: 20px;
  display: block;
}
.headline-1 {
  color: var(--color);
  font-weight: 400;
  line-height: var(--lineHeight-3);
  font-family: var(--fontFamily-forum);
}
.section-text {
  color: var(--body-color);
  font-size: var(--fontSize-body-4);
  margin-inline: auto;
  line-height: var(--lineHeight-5);
  margin-block: 15px 30px;
  text-align: justify;
  margin-right: 2rem;
}

/*================================
6. Counter
==================================*/
.cta-area {
  padding: var(--section-space) 0;
  background: url("../images/cta-sp-bg.svg"), linear-gradient(var(--background) 100%, var(--background) 100%);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
.single-counter h4 {
  color: var(--color);
  font-size: 48px;
}
.single-counter p {
  color: var(--body-color);
  font-size: 24px;
  margin-top: 10px;
}
/*================================
7.service
==================================*/
.service {
  padding: var(--section-space) 0;
  background-color: var(--background-1);
}
.service-card {
  text-align: center;
}
.card-content h3 {
  color: var(--body-color);
}
.btn-text {
  color: var(--primary-color);
  margin-inline: auto;
  letter-spacing: var(--letterSpacing-3);
  font-weight: var(--weight-bold);
  transition: var(--transition-1);
}
.btn-text:is(:hover, :focus-visible) { color: var(--white); }
.hover-underline::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 5px;
  border-block: 1px solid var(--gold-crayola);
  transform: scaleX(0.2);
  opacity: 0;
  transition: var(--transition-2);
}
.shine {
  position: relative;
  overflow: hidden;
}
.shine::before {
  background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.3) 100%);
  content: "";
  display: block;
  height: 100%;
  left: -78%;
  position: absolute;
  top: 0;
  transform: skewX(-25deg);
  width: 50%;
  z-index: 2;
}
.shine:hover::before, .shine:focus::before {
  -webkit-animation: shine 0.85s;
          animation: shine 0.85s;
}
@-webkit-keyframes shine {
  100% {
    left: 125%;
  }
}
@keyframes shine {
  100% {
    left: 125%;
  }
}

/*================================
8.about
==================================*/
.about {
  background-color: var(--background);
  padding: var(--section-space) 0;
}
.about-content h5 {
  color: var(--body-color);
}
.about-content h4 {
  color: var(--primary-color);
}

/*================================
9.special-dish
==================================*/
.special-dish {
  background-color: var(--background-1);
}
.special-dish-content {
  padding: 140px 120px;
  padding-inline-end: 0;
}
.special-dish .section-text {
  max-width: 100%;
  margin-block: 16px 40px;
}

.special-dish-content .del {
  text-decoration: none;
  color: var(--body-color);
  font-size: 18px;
}
.special-dish-content .span {
  margin-left: 1rem;
  color: var(--primary-color);
  font-size: 22px;
}
/*================================
10. delicious-menu
==================================*/
.delicious-menu {
  background-color: var(--background);  
  padding: var(--section-space) 0;
}
.menu .section-title { margin-block-end: 40px; }

.menu .grid-list { margin-block-end: 50px; }

.menu-card {
  display: flex;
  align-items: flex-start;
  gap: 20px;
}
.menu-book-box {
  border: 1px solid #EBECF1;
  border-radius: 18px;
  padding: 25px;
  -webkit-transition: all .2s linear;
  transition: all .2s linear;
}
.menu-book-box:hover {
  -webkit-transform: translateY(-6px);
  transform: translateY(-6px);
}
.menu-card .card-title {
  transition: var(--transition-1);
}
.hover\:card .card-banner .img-cover { transition: var(--transition-2); }

.hover\:card:is(:hover, :focus-within) .card-banner .img-cover {
  opacity: 0.7;
  transform: scale(1.05);
}
.widget-categories ul li {
  margin-bottom: 15px;
  list-style: none;
}

.widget-categories ul li a {
  font-size: var(--fontSize-label-2);
  position: relative;
  display: block;
  color: var(--color);
  -webkit-transition: all 0.2s ease-out;
  -moz-transition: all 0.2s ease-out;
  -ms-transition: all 0.2s ease-out;
  -o-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
}
.widget-categories ul li a:hover {
  color: var(--primary-color);
}


.widget-categories ul li a span {
  color: var(--primary-color);
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
  right: 0;
  z-index: 2;
  -webkit-transition: all 0.3s ease-out;
  -moz-transition: all 0.3s ease-out;
  -ms-transition: all 0.3s ease-out;
  -o-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}
.widget-categories p {
  color: var(--body-color);
  font-size: var(--fontSize-14);
}

/*================================
11.our-chefs
==================================*/
.our-chefs {
  background-color: var(--background-2);
  padding: var(--section-space) 0;
}
.our-team .team-row {
  margin-left: -40px;
  margin-right: -40px;
}

.our-team .team-wrap {
  padding: 0 40px;
}

.our-team .container-fluid {
  padding: 0 50px;
}

.team-img img {
  -webkit-transition: all .2s ease-in-out;
  -moz-transition: all .2s ease-in-out;
  -o-transition: all .2s ease-in-out;
  transition: all .2s ease-in-out;
  overflow: hidden;
  width: 100%;
}

.team-member,
.team-img {
  position: relative;
  overflow: hidden;
}

.team-title {
  color: var(--primary-color);
  font-size: var(--fontSize-label-2);
  margin: 30px 0 7px;
}
.team-member span {
  color: var(--body-color);
}
.overlay {
  background-color: rgba(20,20,20,.7);
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  -webkit-transition: all .2s ease-in-out;
  -moz-transition: all .2s ease-in-out;
  -o-transition: all .2s ease-in-out;
  transition: all .2s ease-in-out;
}

.team-details {
  opacity: 0;
  position: absolute;
  top: 50%;
  left: 0;
  padding: 5%;
  overflow: hidden;
  width: 100%;
  z-index: 2;
  -webkit-transition: all .2s ease-in-out;
  -moz-transition: all .2s ease-in-out;
  -o-transition: all .2s ease-in-out;
  transition: all .2s ease-in-out;
}
.team-details p {
  color: #fff;
}
.team-img:hover .team-details {
  opacity: 1;
  margin-top: -80px;
}
.team-img:hover .overlay {
  opacity: 1;
}
.socials a {
  display: inline-block;
  width: 37px;
  height: 37px;
  background-color: transparent;
}
.socials i {
  line-height: 37px;
  color: #616161;
  font-size: 14px;
  width: 37px;
  height: 37px;
  border-radius: 50%;
  text-align: center;
  -webkit-transition: all 0.2s linear;
  -moz-transition: all 0.2s linear;
  -o-transition: all 0.2s linear;
  -ms-transition: all 0.2s linear;
  transition: all 0.2s linear;
}
.team-details .socials i {
	color: #fff;
}
.socials a:hover i {
  color: #fff;
  background-color: var(--primary-color);
}

/*================================
12.testimonial
==================================*/
.testimonial {
  background: linear-gradient(var(--background-rgba), var(--background-rgba)), url('../images/testimonial/testimonial-bg.jpg');
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  overflow: hidden;
  padding: var(--section-space) 0;
  background-attachment: fixed;
}
.testimonial-item {
  padding: 30px;
  text-align: center;
	position: relative;
	border-radius: 5px;
}
.testimonial-img {
    justify-content: center;
    display: flex;
    margin-bottom: 10px;
}
.testimonial-img img {
  width: 20%;
  border-radius: 50%;
}
.testimonial-name h6 {
  color: var(--color);
  font-size: 14px;
}
.testimonial-item .rating {
  unicode-bidi: bidi-override;
  color: var(--main-color);
  font-size: 6px;
  width: 100%;
  margin: 0 auto;
}
.testimonial h3 {
  color: var(--body-color-2);
}
.testimonial-name h6 {
  color: var(--body-color-2);
}
.testimonial-item p {
  color: var(--body-color-2);
  max-width: 675px;
  margin: 1.5rem auto;
  font-size: 16px;
}
.slick-dots {
  position: absolute;
  left: -10px;
  bottom: 20px;
  display: block;
  width: 100%;
  padding: 0;
  list-style: none;
  text-align: center;
}
.slick-dots li {
  position: relative;
  display: inline-block;
  width: 20px;
  height: 6px;
  margin: 0 5px;
  padding: 0;
  cursor: pointer;
}
.slick-dots li button {
  display: none;
}
.slick-dots li:before {
  top: 1px;
  transition: all 0.5s;
  content: "";
  width: 20px;
  height: 6px;
  background-color: var(--body-color);
  position: absolute;
}
.slick-dots li.slick-active:before {
  top: 0;
  width: 20px;
  height: 8px;
  background-color: var(--primary-color);
}

/*=============================
13.blog
===============================*/
.blog {
  background-color: var(--background-2);
  padding: var(--section-space) 0;
}
/*=======================
14.Contact
=========================*/
.contact-area {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(100%, var(--background-rgba)), to(var(--background-rgba))), url('../images/contact/reservation-bg.png');
  background: linear-gradient(var(--background-rgba) 100%, var(--background-rgba) 100%), url('../images/contact/reservation-bg.png');
  background-repeat: no-repeat;
  background-size: cover;
  background-attachment: fixed;
  background-position: center;
  padding: var(--section-space) 0;
}
.contact-area h3 {
  color: var(--body-color-2);
}
.contact h6 {
  color: var(--body-color-2);
  font-weight: 600;
}
.contact p {
  color: var(--body-color-2);
}
.booking-form {
  background: rgba(16, 17, 19, 0.7);
  padding: 30px;
  z-index: 1;
  border-radius: 4px;
  background: linear-gradient(153deg, rgba(255, 255, 255, 0.36) 0%, rgba(255, 255, 255, 0.12) 100%);
  -webkit-backdrop-filter: blur(5px);
  backdrop-filter: blur(5px);
}
.form-control:focus {
  background: linear-gradient(153deg, rgba(255, 255, 255, 0.36) 0%, rgba(255, 255, 255, 0.12) 100%);
  -webkit-backdrop-filter: blur(5px);
  backdrop-filter: blur(5px);
  border-color: var(--primary-color);
  outline: 0;
  box-shadow: none;
}
.form-select:focus {
  background: linear-gradient(153deg, rgba(255, 255, 255, 0.36) 0%, rgba(255, 255, 255, 0.12) 100%);
  -webkit-backdrop-filter: blur(5px);
  backdrop-filter: blur(5px);
  border-color: var(--primary-color);
  outline: 0px;
  box-shadow: none;
}
.custom-form {
  background: linear-gradient(153deg, rgba(255, 255, 255, 0.36) 0%, rgba(255, 255, 255, 0.12) 100%);
  -webkit-backdrop-filter: blur(5px);
  backdrop-filter: blur(5px);
}

/*=======================
15.Footer
=========================*/
.footer-area {
  color: var(--color);
  background: -webkit-gradient(linear, left top, left bottom, color-stop(100%, var(--background-rgba)), to(var(--background-rgba))), url('../images/footer-bg.jpg');
  background: linear-gradient(var(--background-rgba) 100%, var(--background-rgba) 100%), url('../images/footer/footer-bg.jpg');
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-attachment: fixed;
}
.footer-copyright-area {
  border-top: 1px solid rgba(248,249,250,.05);;
  padding: 30px 0;

}
.footer-area p {
  color: var(--body-color-2);
  margin: 0;
  font-size: 14px;
}
.footer-area a {
  color: var(--body-color-2);
}

.footer-right {

  display: flex;
  justify-items: center;
    justify-content: space-between;
}

.footer-left {
  display: inline-block;
}

footer.footer-area {
  padding-top: 70px;
}
.address-box-middle .social-link {
  display: flex;
  cursor: pointer;
}

.address-box-middle .social-link i {
  background: var(--background);
  color: var(--primary-color);
  margin-right: 10px;
  height: 32px;
  width: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 100%;
  transition: .4s;
}
.address-box-middle .social-link i:hover {
  background: var(--primary-color);
  color: var(--white);
  border: none;
}
.address-box-middle {
  margin-top: 10px;
  margin-bottom: 40px;
}
.menu-item-link {
  text-transform: capitalize;
}
.footer-text h4 {
  color: var(--body-color-2);
}
.menu-item-link h2 {
  color: var(--body-color-2);
  font-size: 20px;
  text-transform: uppercase;
}
.menu-item-link ul li {
  list-style: none;
}
.menu-item-link ul li a {
  font-size: 14px;
  margin: 5px 0;
  display: inline-block;
  font-weight: 500;
  -webkit-transition: all .3s ease-in-out;
  transition: all .3s ease-in-out;

}
.menu-item-link ul li p {
  font-size: 14px;
  margin: 10px 0;
  display: block;
  font-weight: 500;
  text-transform: uppercase;
}
.menu-item-link ul li a:hover {
  margin-left: 4px;
 color: var(--primary-color);
}
/*=======================
16.Scroll Top 
=========================*/

.material-scrolltop.reveal:hover {
	background: var(--primary-color);
  box-shadow: none !important;
} 
.material-scrolltop.reveal {
	width: 50px;
	height: 50px;
	box-shadow: var(--all);
	background: var(--btn-background);
	z-index: 99;

}
.material-scrolltop.reveal i {
	font-size: 20px;
	color: var(--color);
}
.material-scrolltop.reveal:hover i {
	color: #fff;
} 
/*=======================
17.Theme Switcher 
=========================*/
.theme-switcher-label {
	align-items:center;
	border-left:0;
	cursor:pointer;
	display:flex;
	justify-content:center;
	position:fixed;
	right:20px;
	top: 25%;
	transition:.3s;
	z-index:99;
}
.theme-switcher-label:hover {
	background: var(--theme-icon-hover);
}
.theme-switcher-label .switch-handle {
 align-items:center;
 border-radius:50%;
 display:flex;
 justify-content:center;
 position:relative;
 transition:all .3s ease-in-out;
}
.theme-switcher-label .switch-handle i {
	background-color: var(--btn-background);
	box-shadow: var(--all);
	font-size: 23px;
	left: -54px;
	position: absolute;
	top: -14px;
	transition: .3s;
	color: var(--color);
	height: 50px;
	width: 50px;
	padding-top: 13px;
	text-align: center;
	border-radius: 4px;
}
.theme-switcher-label .theme-switcher {
 display:none;
}
.theme-switcher-label .light-text {
 color:#000;
}
.theme-switcher-label .dark-text {
 color:#666;
}
.theme-switcher-label.active {
 background-color:#eee;
}
.theme-switcher-label.active .light-text {
 opacity:0;
 visibility:hidden;
}
.theme-switcher-label.active .dark-text {
 opacity:1;
 visibility:visible;
}
.theme-switcher-label .dark-text {
 opacity:0;
 visibility:hidden;
}
.theme-switcher-label input {
 cursor:pointer;
}

/*===========================
18.Preloader
=============================*/

#loader-wrapper {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 999;
}

#loader {
  display: block;
  position: relative;
  left: 50%;
  top: 50%;
  width: 150px;
  height: 150px;
  margin: -75px 0 0 -75px;
  border-radius: 50%;
  border: 3px solid transparent;
  border-top-color: #3498db;
  z-index: 1001;
  -webkit-animation: spin 2s linear infinite;
          animation: spin 2s linear infinite;
}
#loader:before {
  content: "";
  position: absolute;
  top: 5px;
  left: 5px;
  right: 5px;
  bottom: 5px;
  border-radius: 50%;
  border: 3px solid transparent;
  border-top-color: #e74c3c;
  -webkit-animation: spin 3s linear infinite;
          animation: spin 3s linear infinite;
}
#loader:after {
  content: "";
  position: absolute;
  top: 15px;
  right: 15px;
  left: 15px;
  bottom: 15px;
  border-radius: 50%;
  border: 3px solid transparent;
  border-top-color: #f9c922;
  -webkit-animation: spin 1.5s linear infinite;
          animation: spin 1.5s linear infinite;
}

#loader-wrapper .loader-section {
  position: fixed;
  top: 0;
  width: 51%;
  height: 100%;
  background: var(--background-1);
  z-index: 1000;
  transform: translateX(0);
}

#loader-wrapper .loader-section.section-left {
  left: 0;
}

#loader-wrapper .loader-section.section-right {
  right: 0;
}

@-webkit-keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.loaded #loader-wrapper .loader-section.section-left {
  transform: translateX(-100%);
  transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
}

.loaded #loader-wrapper .loader-section.section-right {
  transform: translateX(100%);
  transition: all 0.7s 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
}

.loaded #loader {
  opacity: 0;
  transition: all 0.3s ease-out;
}

.loaded #loader-wrapper {
  visibility: hidden;
  transform: translateY(-100%);
  transition: all 0.3s 1s ease-out;
}

