@import url(https://fonts.googleapis.com/css2?family=Montserrat:wght@100;200;300;400;500;600;700;800;900&display=swap);
@import url(https://use.typekit.net/tca4olu.css);
@import url(https://fonts.googleapis.com/css2?family=Oleo+Script+Swash+Caps&display=swap);
#location-message-bar p, *, ul {
  margin: 0;
  padding: 0
}
.btn-link-sm, .tp-btn-5, .tp-btn-black, .tp-btn-text {
  letter-spacing: -.02em
}
.breadcrumb li, h1, h2, h3, h4, h5, h6, p {
  font-weight: 400
}
.tp-btn-3, .tp-btn-black, .tp-btn-text, a .hotel-name {
  font-family: var(--tritary-font)
}
.back-to-top-wrapper, .mean-container .mean-nav ul li > a.mean-expand i, .transition-3, a, button, input, li, p, select, textarea {
  -webkit-transition: .3s ease-out;
  -moz-transition: .3s ease-out;
  -ms-transition: .3s ease-out;
  -o-transition: .3s ease-out;
  transition: .3s ease-out
}
.back-to-top-btn {
  -webkit-transition: transform .3s ease-out;
  -moz-transition: transform .3s ease-out;
  -ms-transition: transform .3s ease-out;
  -o-transition: transform .3s ease-out
}
a, button, h1, h2, h3, h4, h5, h6 {
  transition: color .3s ease-out
}
:root {
  --primary-font: 'Montserrat', sans-serif;
  --secondary-font: 'Montserrat', sans-serif;
  --tritary-font: "ff-scala-jewel-crystal", sans-serif;
  --primary-color: #C51A1B;
  --primary-lt-color: #F59736;
  --primary-t-color: #EF7F1A;
  --tp-border-primary: #00715d;
  --secondary-color: #1A1E20;
  --secondary-lt-color: #303436;
  --secondary-alt-color: #47e3e3;
  --secondary-d-color: #C2AFF0;
  --secondary-t-color: #8d8d8d;
  --tritary-color: #3498db;
  --tritary-d-color: #a4e043;
  --white-color: #fff;
  --black-color: #000;
  --grey-color: #444;
  --grey-lt-color: #fcfaf7;
  --lt-grey-color: #283734;
  --tp-text-body: #ddd;
  --tp-grey-3: #f4f9f8;
  --font-color: #C51A1B;
  --font-lt-color: #444444;
  --font-sec-color: #061135;
  --font-awesome: "FontAwesome Pro";
  --font-sm-size: 14px;
  --font-size: 16px;
  --font-lg-size: 24px;
  --font-xl-size: 36px;
  --font-xxl-size: 48px;
  --line-height: 1.5;
  --line-lg-height: 21px;
  --line-xl-height: 24px;
  --line-xxl-height: 36px;
  --font-thin: 100;
  --font-xlt: 200;
  --font-lt: 300;
  --font-reg: 400;
  --font-med: 500;
  --font-sbold: 600;
  --font-bold: 700;
  --font-xbold: 800;
  --font-black: 900;
  --bdr-5-radius: 5px;
  --bdr-10-radius: 10px;
  --bdr-20-radius: 20px;
  --bdr-30-radius: 30px;
  --background-color: #1e1e1e;
  --card-background: #2c2c2c;
  --text-color: #e0e0e0;
  --heading-color: #ffffff;
  --accent-color: #9F0600;
  --rating-background: #1e90ff;
  --rating-text-color: #ffffff;
  --button-color: #1e90ff;
  --button-hover-color: #005fa3;
  --border-color: #3a3a3a
}
* {
  box-sizing: border-box
}
body {
  font-family: var(--primary-font);
  font-size: var(--font-size);
  line-height: 30px;
  background: #111314
}
.m-img img, img {
  max-width: 100%
}
a {
  text-decoration: none
}
h1, h2, h3, h4, h5, h6 {
  font-family: var(--secondary-font);
  color: var(--font-color);
  margin-top: 0;
  line-height: 1.2
}
h1 {
  font-size: 30px
}
h2 {
  font-size: 26px
}
h3 {
  font-size: 22px
}
h4 {
  font-size: 20px
}
.contact__info-icon i, .filter-header, h5 {
  font-size: 18px
}
h6, p {
  font-size: var(--font-size)
}
p {
  font-family: var(--primary-font);
  color: var(--tp-text-body);
  margin-bottom: 15px;
  line-height: 30px
}
a:focus, a:hover, a:not([href]):not([class]), a:not([href]):not([class]):hover {
  color: inherit;
  text-decoration: none
}
.button:focus, a:focus {
  text-decoration: none;
  outline: 0
}
a, button {
  color: inherit;
  outline: 0;
  border: none;
  background: 0 0
}
button:hover {
  cursor: pointer
}
.date-input:focus, .filter-section input[type=range]:focus, .nav-btn:focus, button:focus {
  outline: 0
}
.uppercase {
  text-transform: uppercase
}
.capitalize, .tpblog__meta .date, .tpblog__meta .user {
  text-transform: capitalize
}
input[type=email], input[type=number], input[type=password], input[type=tel], input[type=text], input[type=url], textarea {
  outline: 0;
  background-color: rgba(239, 240, 242, 0);
  height: 33px;
  width: 100%;
  line-height: 54px;
  font-size: 16px;
  color: #fff;
  padding-right: 29px;
  border: none;
  border-bottom: 1px solid #fff
}
.booking-summary p span, [dir=rtl] input[type=email], [dir=rtl] input[type=number], [dir=rtl] input[type=password], [dir=rtl] input[type=tel], [dir=rtl] input[type=text], [dir=rtl] input[type=url], [dir=rtl] textarea {
  text-align: right
}
input[type=email]::-webkit-input-placeholder, input[type=number]::-webkit-input-placeholder, input[type=password]::-webkit-input-placeholder, input[type=tel]::-webkit-input-placeholder, input[type=text]::-webkit-input-placeholder, input[type=url]::-webkit-input-placeholder, textarea::-webkit-input-placeholder {
  color: #6f7775
}
input[type=email]::-moz-placeholder, input[type=number]::-moz-placeholder, input[type=password]::-moz-placeholder, input[type=tel]::-moz-placeholder, input[type=text]::-moz-placeholder, input[type=url]::-moz-placeholder, textarea::-moz-placeholder {
  color: #6f7775
}
input[type=email]:-moz-placeholder, input[type=number]:-moz-placeholder, input[type=password]:-moz-placeholder, input[type=tel]:-moz-placeholder, input[type=text]:-moz-placeholder, input[type=url]:-moz-placeholder, textarea:-moz-placeholder {
  color: #6f7775
}
input[type=email]:-ms-input-placeholder, input[type=number]:-ms-input-placeholder, input[type=password]:-ms-input-placeholder, input[type=tel]:-ms-input-placeholder, input[type=text]:-ms-input-placeholder, input[type=url]:-ms-input-placeholder, textarea:-ms-input-placeholder {
  color: #6f7775
}
input[type=email]::placeholder, input[type=number]::placeholder, input[type=password]::placeholder, input[type=tel]::placeholder, input[type=text]::placeholder, input[type=url]::placeholder, textarea::placeholder {
  color: #6f7775
}
input[type=color] {
  appearance: none;
  -moz-appearance: none;
  -webkit-appearance: none;
  background: 0 0;
  border: 0;
  cursor: pointer;
  height: 100%;
  width: 100%;
  padding: 0;
  border-radius: 50%
}
::-moz-selection {
  background: var(--primary-color);
  color: var(--white-color) !important;
  text-shadow: none
}
::selection {
  background: var(--primary-color);
  color: var(--white-color) !important;
  text-shadow: none
}
::-moz-placeholder {
  color: var(--black-color);
  font-size: var(--font-sm-size);
  opacity: 1
}
::placeholder {
  color: var(--black-color);
  font-size: var(--font-sm-size);
  opacity: 1
}
.hero-banner {
  padding: 80px 0;
}
.hero-banner .banner-section, .hero-home-banner .banner-section, .profile__content, .tp-instagram img, .w-img img {
  width: 100%
}
.pt-60{
    padding-top:60px;
}
.back-to-top-btn, .back-to-top-wrapper {
  width: 44px;
  height: 44px;
  border-radius: 50%
}
.fix, .no-scroll, .sidebar-btn-menu {
  overflow: hidden
}
.clear {
  clear: both
}
.z-index-1 {
  z-index: 1
}
.z-index-11 {
  z-index: 11
}
.overflow-y-visible {
  overflow-x: hidden;
  overflow-y: visible
}
.img-pic, .p-relative {
  position: relative
}
.p-absolute, body.background_image .banderole_wrapper {
  position: absolute
}
.include-bg {
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat
}
.demo {
  transition: color .3s linear, transform .2s
}
[dir=rtl] .demo {
  margin-left: 0;
  margin-right: 15px
}
.ticket-footer .btn + .btn, div.demo img {
  margin-left: 10px
}
[tp-theme=tp-theme-dark] .demo {
  color: #ff0
}
.tp-dropcap::first-letter {
  font-size: 50px;
  font-weight: 700;
  float: left;
  text-align: center;
  color: var(--black-color);
  background-color: var(--white-color);
  box-shadow: 0 16px 32px 0 rgba(0, 0, 0, .06);
  margin-right: 5px;
  line-height: inherit
}
.class {
  stroke-dasharray: 189px, 191px;
  stroke-dashoffset: 0px
}
.back-to-top-wrapper {
  position: fixed;
  right: 50px;
  bottom: 0;
  cursor: pointer;
  display: block;
  z-index: 99;
  opacity: 0;
  visibility: hidden;
  transition: visibility .3s, opacity .3s, bottom .3s
}
.btn-link-sm, .tp-btn, .tp-btn-3, .tp-btn-5, .tp-btn-black, .tp-btn-sec, .tp-btn-text {
  color: var(--white-color);
  z-index: 1;
  text-align: center;
  overflow: hidden;
  display: inline-block
}
.back-to-top-wrapper.back-to-top-btn-show {
  visibility: visible;
  opacity: 1;
  bottom: 50px
}
.back-to-top-btn {
  display: inline-block;
  text-align: center;
  background: #283734;
  box-shadow: 0 8px 16px rgba(3, 4, 28, .3);
  color: var(--white-color);
  transition: transform .3s ease-out
}
.back-to-top-btn svg {
  transform: translateY(-2px)
}
.back-to-top-btn:hover {
  transform: translateY(-4px)
}
.tp-button {
  text-align: center;
  padding: 25px 0 0
}
.btn-link-sm, .tp-btn, .tp-btn-3, .tp-btn-5, .tp-btn-black, .tp-btn-sec {
  font-size: 14px;
  padding: 3px 20px;
  font-weight: 300;
  background: var(--primary-color);
  position: relative;
  transition: .5s linear;
  border-radius: 4px;
  margin: 0 auto;
  cursor: pointer
}
.tp-btn-sec {
  background: #515455
}
.tp-button .tp-btn, .webstory:hover .webstory-details:after {
  width: 80%
}
.btn-link-sm:hover, .content-description, .hotel-brand strong, .mean-container .mean-nav ul li a.mean-expand.mean-clicked, .mean-container .mean-nav ul li a.mean-expand:hover i, .mean-container .mean-nav ul li a:hover i, .mean-container .mean-nav ul li span.mean-expand.mean-clicked, .mean-container .mean-nav ul li span.mean-expand:hover i, .mean-container .mean-nav ul li span:hover i, .mean-container .mean-nav ul li.dropdown-opened > a.mean-expand.mean-clicked i, .mean-container .mean-nav ul li.dropdown-opened > span.mean-expand.mean-clicked i, .tp-btn-3:hover, .tp-btn-5:hover, .tp-btn-black:hover, .tp-btn-sec:hover, .tp-btn:hover {
  color: var(--white-color)
}
.tp-btn-3:hover, .tp-btn-4:hover, .tp-btn-black:hover {
  color: #283734
}
.guest-info, .tp-btn + .tp-btn {
  margin-top: 10px
}
.btn-link-sm:hover::before, .tp-btn-3:hover::before, .tp-btn-5:hover::before, .tp-btn-black:hover::before, .tp-btn-sec:hover::before, .tp-btn:hover::before {
  transform: translate3d(0, 0, 0) scale3d(1, 1, 1);
  transition: transform .4s cubic-bezier(.1, 0, .3, 1)
}
.btn-link-sm:hover::after, .tp-btn-3:hover::after, .tp-btn-5:hover::after, .tp-btn-black:hover::after, .tp-btn-sec:hover::after, .tp-btn:hover::after {
  transform: translate3d(0, 0, 0);
  transition-duration: 50ms;
  transition-delay: 0.4s;
  transition-timing-function: linear
}
.btn-link-sm::before, .tp-btn-3::before, .tp-btn-5::before, .tp-btn-black::before, .tp-btn-sec::before, .tp-btn::before {
  position: absolute;
  content: "";
  background-color: #283734;
  width: 120%;
  height: 0;
  padding-bottom: 120%;
  top: -110%;
  border-radius: 50%;
  left: -10%;
  transform: translate3d(0, 68%, 0) scale3d(0, 0, 0);
  z-index: -1
}
.btn-link-sm::after, .tp-btn-3::after, .tp-btn-5::after, .tp-btn-black::after, .tp-btn-sec::after, .tp-btn::after {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #283734;
  transform: translate3d(0, -100%, 0);
  transition: transform .4s cubic-bezier(.1, 0, .3, 1);
  z-index: -1
}
.breadcrumb li, .hero-home-banner, .title, .tp-btn-text {
  position: relative
}
.tp-btn-3::after, .tp-btn-3::before, .tp-btn-3:hover, .tp-btn-black::after, .tp-btn-black::before {
  background-color: var(--white-color)
}
.tp-btn-3 {
  font-size: 13px;
  font-weight: 500;
  background: var(--primary-color);
  padding: 15px 45px;
  text-transform: uppercase
}
.btn-link-sm, .tp-btn-4, .tp-btn-5, .tp-btn-black, .tp-btn-text {
  font-weight: 700;
  text-transform: uppercase
}
.tp-btn-5:hover, .tp-btn-black {
  background-color: var(--lt-grey-color)
}
.tp-btn-5 {
  font-size: 16px;
  padding: 15px 43px
}
.tp-btn-black {
  font-size: 16px;
  padding: 15px 49px
}
.tp-btn-black::after {
  width: 110%
}
.tp-btn-text {
  font-size: 16px;
  transition: .3s
}
.tp-btn-text::after, .tp-btn-text::before {
  background-color: #283734
}
.tp-btn-text:hover {
  color: #fbd45b
}
.btn-link-sm {
  font-size: 14px;
  color: var(--font-color);
  background: #f6eddf;
  padding: 5px 30px
}
.tp-btn-4 {
  color: #6f7775;
  font-size: 14px
}
.grey-bg-1 {
  background: var(--grey-lt-color)
}
.grey-bg-2 {
  background: var(--lt-grey-color)
}
.grey-bg-3 {
  background: var(--tp-grey-3)
}
.white-bg {
  background: var(--white-color)
}
.black-bg {
  background: var(--black-color)
}
.theme-bg, .tpblog:hover .btn-link-sm {
  background: var(--primary-lt-color)
}
.close-popup:hover, .contact-info-list li:hover .icon, .done-button:hover, .theme-bg-2 {
  background: var(--primary-color)
}
.theme-bg-3 {
  background: var(--primary-t-color)
}
.black-color {
  color: #283734 !important
}
.tp-swiper-dot .swiper-pagination-bullet {
  width: 8px;
  height: 8px;
  background-color: var(--grey-lt-color);
  opacity: 1;
  margin: 0 9px;
  position: relative
}
.tp-swiper-dot .swiper-pagination-bullet::after {
  position: absolute;
  content: "";
  left: 50%;
  top: 50%;
  width: calc(100% + 16px);
  height: calc(100% + 16px);
  background-color: transparent;
  border: 2px solid transparent;
  border-radius: 50%;
  transform: translate(-50%, -50%) scale(0)
}
.tp-swiper-dot .swiper-pagination-bullet button {
  font-size: 0
}
.theme-package .btn:hover, .tp-swiper-dot .swiper-pagination-bullet.swiper-pagination-bullet-active {
  background-color: var(--primary-color)
}
.tp-swiper-dot .swiper-pagination-bullet.swiper-pagination-bullet-active::after {
  border-color: var(--primary-color);
  transform: translate(-50%, -50%) scale(1)
}
.tp-swiper-arrow {
  width: 80px;
  height: 80px;
  line-height: 80px;
  font-size: 20px;
  text-align: center;
  background-color: var(--white-color);
  color: var(--black-color)
}
.tp-swiper-arrow:hover {
  background-color: var(--black-color);
  color: var(--white-color)
}
.breadcrumb-title {
  font-size: 32px;
  font-weight: 600
}
.breadcrumb {
  display: flex;
  gap: 10px;
  padding: 0;
  margin: 0
}
.breadcrumb li + li {
  padding: 0 0 0 20px;
  margin: 0;
  color: #a9a9a9
}
.breadcrumb li + li:before {
  position: absolute;
  content: "\f101";
  font-family: var(--font-awesome);
  left: 0;
  font-size: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--font-color)
}
.about-counter-text span, .breadcrumb li a {
  font-size: 16px;
  color: var(--tp-text-body)
}
.breadcrumb li a:hover, .footer-bottom .bottom-inner .copyright p a, .mean-container .mean-nav ul li a:hover, .mean-container .mean-nav ul li span:hover, .mean-container .mean-nav ul li.dropdown-opened > a, .mean-container .mean-nav ul li.dropdown-opened > span {
  color: var(--primary-color)
}
.breadcrumb-bg {
  background: #000;
  padding: 25px 0
}
.section {
  padding: 80px 0
}
.subtitle {
  color: var(--secondary-t-color);
  font-weight: 700
}
.title {
  font-size: 36px;
  font-weight: 800;
  margin: 0 0 10px;
  padding: 0 0 10px
}
.title:after {
  background: var(--primary-color);
  content: ' ';
  height: 3px;
  width: 120px;
  position: absolute;
  left: 0;
  bottom: 0
}
.text-center .title:after {
  left: 50%;
  transform: translateX(-50%)
}
.filter-section, .service-details-contact-info .bottom-box h2 a, .service-details-contact-info .bottom-box h3 a, .theme-package ul li, .white-text {
  color: #fff
}
.white-text a {
  color: #98a8a5
}
.hero-banner h1, .hero-home-banner h1 {
  color: var(--white-color);
  text-shadow: 5px 3px 8px #000
}
.white-text a i {
  color: #fbd45b !important
}
.hero-home-banner {
  padding: 0;
  min-height: 100vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-content: center;
  align-items: center;
  justify-content: center
}
.hero-home-banner .banner-section .banner-box {
  background: rgba(0, 0, 0, .1);
  backdrop-filter: blur(10px);
  border: 3px solid rgba(0, 0, 0, .4);
  padding: 40px;
  color: #fff;
  text-align: center;
  font-size: 24px;
  border-radius: 5px;
  box-shadow: inset 0 0 25px rgba(0, 0, 0, .6);
  margin-bottom: 25px;
  display: block
}
#myVideo, .hero-banner video {
  position: absolute;
  left: 0;
  top: 0;
  min-width: 100%;
  min-height: 100%;
  z-index: -1
}
.hero-banner {
  background: #1a1a1a;
  padding: 80px 0px;
  color: #fff;
  min-height: 80vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

/* Heading styles */
.hero-banner h1 {
  font-size: 52px;
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: -1px;
  margin-bottom: 20px;
  color: #fff;
}

/* Span inside h1 */
.hero-banner h1 span {
  display: block;
  color: var(--primary-color);
  margin-top: 10px;
}

/* Unordered list styles */
.hero-banner ul {
  list-style: none;
  padding: 0;
  margin: 30px 0 0;
  font-size: 18px;
  font-weight: 400;
  color: #e0e0e0;
  max-width: 600px;
}

.hero-banner ul li {
  margin: 15px 0;
  padding-left: 30px;
  position: relative;
}

.hero-banner ul li::before {
  content: "✔";
  position: absolute;
  left: 0;
  color: #00cc99;
  font-size: 20px;
}

.hero-home-banner h1 {
  font-size: 2em;
  font-weight: 600;
  text-align: center;
  margin-bottom: 60px
}
.profile_text, .profile_text h1, .profile_text strong {
  text-shadow: 1px 1px 3px #000;
  color: var(--white-color)
}
.hero-text {
  background: var(--secondary-color);
  font-size: 26px;
  padding: 30px;
  text-align: center;
  color: var(--white-color)
}
.hero-text strong {
  position: relative;
  padding-bottom: 10px
}
.hero-text strong:after {
  position: absolute;
  background: var(--primary-color);
  height: 3px;
  width: 100%;
  left: 0;
  bottom: 0;
  content: ' '
}
.mean-remove {
  display: none !important
}
.mean-container {
  margin-bottom: 40px
}
.mean-container a.meanmenu-reveal {
  width: 22px;
  height: 22px;
  padding: 13px 13px 11px;
  position: absolute;
  top: 0;
  right: 0;
  cursor: pointer;
  color: var(--white-color);
  text-decoration: none;
  text-indent: -9999em;
  font-size: 1px;
  font-weight: 700;
  display: none !important
}
.mean-container a.meanmenu-reveal span {
  display: block;
  background: var(--white-color);
  height: 3px;
  margin-top: 3px
}
.mean-container .mean-push {
  float: left;
  width: 100%;
  padding: 0;
  margin: 0;
  clear: both
}
.mean-container .mean-nav {
  background: 0 0;
  margin-top: 0;
  float: left;
  width: 100%;
  margin-bottom: 50px
}
.mean-container .mean-nav .wrapper {
  width: 100%;
  padding: 0;
  margin: 0
}
.mean-container .mean-nav > ul {
  padding: 0;
  margin: 0;
  width: 100%;
  list-style-type: none;
  display: block !important
}
.mean-container .mean-nav > ul > li:first-child > a {
  border-top: 0
}
.mean-container .mean-nav ul {
  padding: 0;
  margin: 0;
  width: 100%;
  list-style-type: none;
  overflow: hidden
}
.mean-container .mean-nav ul li {
  position: relative;
  float: left;
  width: 100%
}
.mean-container .mean-nav ul li.dropdown-opened > a.mean-expand.mean-clicked, .mean-container .mean-nav ul li.dropdown-opened > span.mean-expand.mean-clicked {
  background: var(--primary-color);
  color: var(--white-color);
  border-color: var(--primary-color)
}
.mean-container .mean-nav ul li.mean-last {
  border-bottom: none;
  margin-bottom: 0
}
.mean-container .mean-nav ul li > a.mean-expand i {
  display: inline-block
}
.mean-container .mean-nav ul li > a > i, .payment-btn:active::before, .theme-package input[type=radio], .theme-type-full input[type=radio], .type-checkboxes input[type=checkbox], .type-checkboxes input[type=radio] {
  display: none
}
.mean-container .mean-nav ul li a, .mean-container .mean-nav ul li span {
  display: block;
  float: left;
  margin: 0;
  text-align: left;
  text-decoration: none;
  width: 100%;
  padding: 10px 0;
  font-size: 14px;
  line-height: 1.5;
  font-weight: 700;
  color: var(--tp-text-body);
  text-transform: capitalize
}
[dir=rtl] .mean-container .mean-nav ul li a, [dir=rtl] .mean-container .mean-nav ul li span {
  float: right;
  text-align: right
}
.mean-container .mean-nav ul li a.mean-expand, .mean-container .mean-nav ul li span.mean-expand {
  text-align: center;
  position: absolute;
  right: 0;
  z-index: 2;
  background: 0 0;
  border: 1px solid #ebebeb !important;
  font-size: 14px;
  margin-top: 6px;
  padding: 0 !important;
  height: 30px;
  width: 30px;
  color: var(--font-color);
  top: 0;
  font-weight: 400;
  line-height: 30px;
  transition: background .3s, color .3s, border-color .3s
}
[dir=rtl] .mean-container .mean-nav ul li a.mean-expand, [dir=rtl] .mean-container .mean-nav ul li span.mean-expand {
  right: auto;
  left: 0;
  text-align: center
}
.mean-container .mean-nav ul li a.mean-expand.mean-clicked:hover, .mean-container .mean-nav ul li a.mean-expand:hover, .mean-container .mean-nav ul li span.mean-expand.mean-clicked:hover, .mean-container .mean-nav ul li span.mean-expand:hover {
  background: var(--primary-color);
  color: var(--white-color);
  border-color: var(--primary-color) !important
}
.mean-container .mean-nav ul li a.mean-expand.mean-clicked:hover i, .mean-container .mean-nav ul li span.mean-expand.mean-clicked:hover i {
  color: var(--white-color);
  transform: rotate(45deg)
}
.mean-container .mean-nav ul li li a {
  width: 80%;
  padding: 10px 10%;
  text-shadow: none !important;
  visibility: visible
}
.mean-container .mean-nav ul li li li a {
  width: 70%;
  padding: 10px 15%
}
.mean-container .mean-nav ul li li li li a {
  width: 60%;
  padding: 10px 20%
}
.mean-container .mean-nav ul li li li li li a {
  width: 50%;
  padding: 10px 25%
}
.mean-container .mean-bar {
  padding: 4px 0;
  background: 0 0;
  float: left;
  width: 100%;
  position: relative;
  min-height: 42px;
  z-index: 999999
}
.mean-container .mean-bar, .mean-container .mean-bar * {
  -webkit-box-sizing: content-box;
  -moz-box-sizing: content-box;
  box-sizing: content-box
}
.blog-banner-title, .blog-banner-title-black {
  position: absolute;
  top: 0;
  left: 0;
  text-align: left;
  padding: 60px 50px;
  font-size: 24px
}
@media only screen and (min-width:992px) and (max-width:1199px) {
  .title {
    font-size: 32px
  }
  .blog-banner-title, .blog-banner-title-black {
    padding: 43px 34px
  }
  .tp-menu-bar {
    margin-left: 15px
  }
}
@media only screen and (min-width:576px) and (max-width:767px) {
  .blog-banner-title, .blog-banner-title-black {
    padding: 79px 76px
  }
}
.blog-banner-title-black {
  color: var(--font-color)
}
.postbox__comment-text p {
  font-size: 16px;
  margin-top: 11px
}
.tp-sidebar-menu {
  position: fixed;
  right: 100%;
  top: 0;
  width: 320px;
  height: 100%;
  background: var(--white-color) none repeat scroll 0 0;
  overflow-y: scroll;
  box-shadow: -5px 0 20px -5px rgba(0, 0, 0, .5);
  transition: .3s cubic-bezier(.785, .135, .15, .86);
  z-index: 9999;
  padding: 30px
}
.hotel-rating, .page-by-dropdown, .sort-by-dropdown, .tp-menu {
  display: flex;
  align-items: center
}
.tp-sidebar-menu.sidebar-opened {
  right: 0
}
.body-overlay {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 999999;
  width: 100%;
  height: 100%;
  background: rgba(24, 24, 24, .6);
  visibility: hidden;
  opacity: 0;
  transition: opacity .45s ease-in-out, visibility .45s ease-in-out
}
.tpblog__thumb a img, .tpblog__thumb-2 img {
  -webkit-transition: .4s ease-out;
  -moz-transition: .4s ease-out;
  -ms-transition: .4s ease-out;
  -o-transition: .4s ease-out
}
.body-overlay.apply, .tpblog-3:hover .plus-icon, .tpblog-3:hover .tpblog-3__img::before {
  opacity: 1;
  visibility: visible
}
.offcan-social-title {
  color: var(--white-color);
  font-size: 18px;
  font-weight: 500;
  margin-bottom: 15px;
  display: inline-block
}
.tpoffcanvas-social {
  height: 100%;
  display: flex;
  flex-direction: column
}
.tp-menu-bar {
  display: none;
  font-size: 20px;
  color: #283734;
  font-weight: 400
}
@media only screen and (min-width:992px) and (max-width:1199px), only screen and (min-width:768px) and (max-width:991px), only screen and (min-width:576px) and (max-width:767px), (max-width:767px) {
  .tp-menu-bar {
    display: block
  }
}
.text-black a {
  color: var(--font-color) !important;
  font-size: 27px
}
.banderole_wrapper {
  display: block;
  height: 100px;
  overflow: hidden;
  pointer-events: none;
  position: relative;
  width: 100%;
  z-index: 0
}
@media (min-width:480px) {
  body.background_image .banderole_wrapper {
    left: calc(50% - 232.5px);
    width: 465px
  }
}
@media (min-width:768px) {
  body.background_image .banderole_wrapper {
    left: calc(50% - 375px);
    width: 750px
  }
}
@media (min-width:985px) {
  body.background_image .banderole_wrapper {
    left: calc(50% - 484px);
    width: 968px
  }
}
@media (min-width:1200px) {
  body.background_image .banderole_wrapper {
    left: calc(50% - 585px);
    width: 1170px
  }
}
.banderole_wrapper .container {
  height: inherit;
  position: relative;
  z-index: 5
}
.banderole_wrapper .banderole {
  display: block;
  height: 35.5px;
  position: absolute;
  top: 50%;
  transform: skew(-40deg);
  width: 100%
}
.banderole_wrapper .banderole .banderole_section {
  background-color: #303436;
  height: 25px;
  left: -4.9%;
  position: absolute;
  top: 25px;
  width: 85%
}
.banderole_wrapper .banderole .banderole_section:nth-child(2) {
  background-color: #45484a;
  border-radius: 3px 0;
  height: 37.5px;
  left: 80%;
  top: 12.5px;
  width: .5%;
  z-index: 3
}
.banderole_wrapper .banderole .banderole_section:nth-child(3) {
  left: auto;
  right: -5.35%;
  top: 12.5px;
  width: 25%;
  z-index: 2
}
.footer_container_banderole_background {
  background-color: #1a1e20;
  height: 20px;
  position: relative;
  top: -17px;
  width: 100%
}
.footer-area {
  position: relative;
  display: block;
  background: #1a1e20;
  z-index: 0;
  margin-top: -17px
}
.footer-top {
  position: relative;
  display: block;
  padding-top: 60px
}
.footer-bottom {
  position: relative;
  display: block;
  border-top: 1px solid rgba(255, 255, 255, .1)
}
.footer-bottom .bottom-inner {
  position: relative;
  display: block;
  text-align: center;
  padding: 15px 0
}
.copyright, .footer-bottom .bottom-inner .copyright {
  position: relative;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-content: center;
  justify-content: center
}
.footer-bottom .bottom-inner .copyright p {
  color: #a5b9ad;
  font-size: 16px;
  font-weight: 500;
  font-family: var(--primary-font);
  margin: 0
}
.footer-bottom .bottom-inner .copyright ul {
  display: flex;
  color: #fff;
  list-style: none;
  flex-wrap: wrap
}
.footer-bottom .bottom-inner .copyright ul li {
  padding: 10px 20px;
  position: relative
}
.footer-bottom .bottom-inner .copyright ul li + li:before {
  content: '|';
  position: absolute;
  left: 0
}
.section-wrapper {
  min-height: 655px
}
.about-img {
  right: 0;
  bottom: 0
}
.about-area {
  padding: 45px 0
}
.about-area ul {
  list-style: none;
  padding: 0;
  margin: 0
}
.about-area ul li {
  padding: 0 0 4px 32px;
  position: relative
}
.about-area ul li:before {
  content: "\f00c";
  font-weight: 700;
  background: var(--secondary-color);
  color: #d9fcde;
  height: 20px;
  width: 20px;
  border-radius: 20px;
  line-height: 20px;
  font-size: 11px;
  text-align: center;
  font-family: var(--font-awesome);
  position: absolute;
  left: 0;
  top: 5px
}
.active .tpblog .tpblog__content, .tpblog:hover .tpblog__content, ul.tabs li:hover {
  background: #303436
}
.about-wapper {
  margin-left: 0
}
@media (prefers-reduced-motion :no-preference) {
  .about-main-img {
    position: relative;
    animation: linear forwards fade-in;
    animation-timeline: view();
    animation-range: entry 200px;
    opacity: 0;
    transform: scale(.8) rotate(-5deg)
  }
  @keyframes fade-in {
    from {
      transform: scale(.8) rotate(-5deg);
      opacity: 0
    }
    to {
      transform: scale(1) rotate(0);
      opacity: 1
    }
  }
}
.about-main-img img {
  width: 100%;
  object-fit: cover;
  border-radius: 35px;
  height: 500px
}
.about-counter {
  background-color: #fff;
  box-shadow: 0 6px 24px 0 rgba(0, 0, 0, .04);
  display: inline-block;
  padding: 15px 21px;
  z-index: 9;
  position: absolute;
  bottom: -50px;
  left: 102px;
  right: 110px
}
.about-counter-icon span {
  font-size: 44px;
  color: var(--font-color);
  background: #f9f4e8;
  height: 70px;
  width: 70px;
  display: inline-block;
  text-align: center;
  line-height: 84px;
  border-radius: 50%
}
.about-counter-text h3, .counter-title {
  font-size: 48px;
  color: var(--primary-color)
}
.about-counter-icon {
  float: left;
  margin-right: 26px
}
.about-counter-text {
  float: right
}
.counter-title {
  line-height: 1;
  margin: 0
}
.about-img {
  position: relative;
  z-index: -1
}
.tp-about-bg {
  position: absolute;
  z-index: -1
}
.about-btns, .custom-booking-form {
  display: flex;
  align-items: center;
  gap: 15px
}
.about-call, .guest-counter {
  display: flex;
  align-items: center;
  gap: 10px
}
.about-call i {
  height: 48px;
  width: 48px;
  background: var(--primary-t-color);
  color: var(--grey-lt-color);
  text-align: center;
  line-height: 51px;
  font-size: 20px;
  border-radius: 10px
}
.about-call strong {
  display: flex;
  flex-direction: column;
  line-height: 1.2
}
.about-call span {
  color: var(--primary-t-color);
  font-size: 12px
}
.profile_content {
  display: flex;
  padding: 15px;
  align-items: flex-end;
  gap: 25px;
  background-position: top center;
  background-size: 100% 100%;
  position: relative
}
.profile_blog:after {
  position: absolute;
  content: ' ';
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  background: rgba(0, 0, 0, .6);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(10px);
  z-index: 1
}
.profile_blog_row {
  align-items: flex-end
}
.profile_img {
  width: 170px;
  flex: 0 0 170px;
  overflow: hidden;
  border: 2px solid #303436;
  border-radius: 4px;
  position: relative
}
.img-pic:before, .profile_img:before {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  content: ' ';
  background: 0 0
}
.profile_img img {
  width: 170px;
  height: 170px
}
.profile_text {
  margin-top: 25px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px
}
.profile_text h1, .profile_text strong {
  font-size: 21px;
  font-weight: 500
}
.profile__nav {
  background-color: #1a1e20;
  border-radius: 0 0 8px 8px;
  display: flex
}
.like_menu ul, .profile_menu ul {
  display: flex;
  gap: 10px;
  list-style: none;
  padding: 10px 0
}
.like_menu ul {
  padding: 10px;
  gap: 15px
}
.profile_menu ul li {
  padding: 0 10px;
  position: relative
}
.like_menu li button, .profile_menu li a {
  color: #b1b3b3;
  font-weight: 400;
  padding: 0 14px;
  display: block;
  text-decoration: none;
  cursor: pointer
}
.profile_menu ul li + li {
  border-left: 1px solid rgba(255, 255, 255, .1)
}
.profile_menu li a {
  font-size: 13px
}
.like_menu li button {
  font-size: 16px;
  background: #45484a;
  border-radius: 4px;
  position: relative
}
.like_menu li button.unfollow i, .like_menu li button.unlike i {
  color: #0076ff
}
.like_menu li button span {
  position: absolute;
  top: -5px;
  right: -5px;
  background: #dc3545;
  height: 20px;
  line-height: 20px;
  min-width: 20px;
  font-size: 14px;
  border-radius: 50%
}
.profile_menu ul li.active:after, .profile_menu ul li:hover:after {
  position: absolute;
  background: var(--primary-color);
  width: 80%;
  height: 2px;
  content: ' ';
  bottom: -10px;
  left: 50%;
  transform: translateX(-50%)
}
.error-page__tagline {
  font-size: 34px;
  color: var(--font-color);
  padding-top: 40px;
  padding-bottom: 20px
}
.error-page__form-input {
  position: relative;
  display: block;
  max-width: 570px;
  width: 100%;
  margin: 0 auto
}
.error-page__form {
  position: relative;
  display: block;
  margin: 32px auto 20px
}
.error-page__form input[type=search] {
  height: 61px;
  width: 100%;
  border: none;
  outline: 0;
  background-color: var(--grey-lt-color);
  font-size: 16px;
  color: rgba(var(--tp-text-body), .6);
  font-weight: 500;
  padding-left: 50px;
  padding-right: 75px
}
.error-page__form button[type=submit] {
  background-color: transparent;
  color: var(--font-color);
  font-size: 16px;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 70px;
  outline: 0;
  border: none;
  display: flex;
  align-items: center;
  padding: 0
}
.date-heading {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  width: 100%;
  font-weight: 700;
  font-size: 17px;
  margin-top: 25px
}
.tpblog {
  position: relative;
  margin-bottom: 20px;
  display: block;
  cursor: pointer
}
.active .tpblog:after {
  border: 15px solid #0000;
  border-top-color: #303436;
  content: " ";
  height: 0;
  left: 50%;
  margin-left: -15px;
  pointer-events: none;
  position: absolute;
  width: 0
}
.tpblog__catagori {
  position: absolute;
  left: 0;
  bottom: 0;
  background: var(--primary-color);
  z-index: 11
}
.tpblog__catagori span {
  font-size: 14px;
  color: var(--white-color);
  display: inline-block;
  padding: 15px 30px;
  line-height: 1;
  font-weight: 700
}
.tpblog__thumb a img {
  transition: .4s ease-out;
  z-index: 2;
  position: relative
}
.tpblog__meta i, .tpblog__meta-2 i {
  color: var(--primary-color);
  padding-right: 6px
}
.tpblog__meta .date, .tpblog__meta .user {
  color: #6f7775;
  font-size: 14px;
  text-transform: capitalize
}
@media only screen and (min-width:992px) and (max-width:1199px), only screen and (min-width:576px) and (max-width:767px) {
  .tpblog__meta .date {
    padding-right: 6px
  }
}
.tpblog__meta .date a {
  color: var(--tp-text-body);
  font-size: 14px;
  margin-bottom: 30px
}
.tpblog__thumb {
  position: relative;
  overflow: hidden;
  border-radius: 10px 10px 0 0
}
.filter-section input[type=range], .img-container .img-pic img, .tab-img img, .tpblog__thumb img, .webstory-img img {
  width: 100%
}
.tpblog__thumb .event_type {
  position: absolute;
  top: 0;
  left: 0;
  background: var(--primary-color);
  color: var(--white-color);
  font-size: 12px;
  padding: 0 15px;
  border-radius: 0 0 10px
}
.tpblog__content .tp-blog-title, .tpblog__content p {
  font-size: 16px;
  display: -webkit-box;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical
}
.tpblog__content {
  padding: 10px;
  background: #1a1e20;
  border-radius: 0 0 10px 10px;
  border-top: 3px solid var(--primary-color);
  border-bottom: 5px solid #303436
}
.tpblog__content[data-sold=Available] {
  border-top: 3px solid #5cb85c !important
}
.tpblog__content .tp-blog-title {
  font-weight: 300;
  color: var(--primary-t-color);
  font-family: var(--primary-font);
  transition: .3s;
  -webkit-line-clamp: 2;
  color: #f1f1f1;
  line-height: 26px;
  height: 52px
}
.tpblog__content p {
  -webkit-line-clamp: 3
}
.tpblog__arrow-box span {
  position: absolute;
  right: 0;
  left: 0;
  text-align: center;
  opacity: 0;
  visibility: hidden;
  cursor: pointer;
  transition: .6s;
  z-index: 1;
  top: 50%;
  transform: translateY(-50%)
}
.tpblog__arrow-box span a {
  height: 40px;
  width: 40px;
  text-align: center;
  line-height: 40px;
  display: inline-block;
  color: var(--font-color);
  background: var(--primary-lt-color)
}
.blog-meta .views:hover, .tpblog:hover .tpblog__thumb a img {
  transform: scale(1.1)
}
.tpblog__catagori-2 {
  position: absolute;
  left: 0;
  bottom: 0
}
.tpblog__catagori-2 span {
  font-size: 14px;
  color: var(--white-color);
  display: inline-block;
  padding: 25px 30px;
  line-height: 1;
  font-weight: 700;
  z-index: 9;
  position: relative
}
.contact__info ul li a i, .contact__info ul li a span, .contact__info-text h4, .contact__line a {
  color: #283734;
  font-size: 18px
}
.tpblog__meta-2 .date {
  font-size: 14px;
  color: #6f7775
}
.tpblog__meta-2 .date a {
  color: var(--tp-text-body);
  font-size: 14px;
  margin-bottom: 30px
}
.tpblog-3__meta .Comments, .tpblog-3__meta .user, .tpblog__meta-2 .user {
  font-size: 14px;
  color: #6f7775;
  text-transform: capitalize
}
@media only screen and (min-width:992px) and (max-width:1199px), only screen and (min-width:576px) and (max-width:767px), (max-width:767px) {
  .tpblog__meta-2 .date, .tpblog__meta-2 .user {
    padding-right: 6px;
    font-size: 14px
  }
}
.hotel-image, .my-toast-body, .popup-content, .room-img, .social-sharing [data-tooltip], .tpblog__thumb-2 {
  position: relative
}
.tpblog__thumb-2 img {
  width: 100%;
  object-fit: cover;
  transition: .4s ease-out
}
.tpblog:hover .tpblog__content::before, .tpblog__thumb-2::before {
  -webkit-transition: .4s ease-out;
  -moz-transition: .4s ease-out;
  -ms-transition: .4s ease-out;
  -o-transition: .4s ease-out
}
.tpblog__thumb-2::before {
  position: absolute;
  content: "";
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(180deg, rgba(3, 4, 28, 0) 0, rgba(3, 4, 28, .4) 58.32%, #283734 100%);
  transition: .4s ease-out;
  z-index: 9
}
.tpblog__content-2 {
  padding: 20px 30px;
  box-shadow: 0 0 18px 0 rgba(0, 0, 0, .1)
}
@media only screen and (min-width:576px) and (max-width:767px) {
  .tpblog__content-2 {
    padding: 25px 20px
  }
}
.tpblog__content-2 .tp-blog-title {
  font-size: 24px;
  font-weight: 400;
  color: var(--font-color)
}
@media only screen and (min-width:992px) and (max-width:1199px) {
  .tpblog__content-2 .tp-blog-title {
    font-size: 20px
  }
  .blog-padding {
    padding-bottom: 70px;
    padding-top: 70px
  }
}
@media only screen and (min-width:576px) and (max-width:767px) {
  .tpblog__content-2 .tp-blog-title {
    font-size: 19px
  }
  .user a {
    font-size: 14px
  }
}
.tpblog__arrow-box-2 {
  position: absolute;
  transition: .3s;
  transform: translate(-50%, -50%);
  background: var(--grey-lt-color);
  height: 30px;
  width: 30px;
  text-align: center;
  line-height: 30px;
  color: var(--font-color);
  bottom: 35px;
  right: 16px
}
.tpblog:hover .tp-btn-4 {
  color: var(--primary-t-color)
}
.tpblog:hover .tpblog__arrow-box-2 {
  background: var(--primary-lt-color)
}
.tpblog:hover .tpblog__thumb::before {
  opacity: 1;
  visibility: visible;
  -webkit-transform: perspective(400px) rotateX(0) scaleY(1);
  -ms-transform: perspective(400px) rotateX(0) scaleY(1);
  transform: perspective(400px) rotateX(0) scaleY(1);
  transition: .4s ease-out;
  -webkit-transition: .4s ease-out;
  -moz-transition: .4s ease-out;
  -ms-transition: .4s ease-out;
  -o-transition: .4s ease-out
}
.tpblog:hover .tpblog__content::before {
  opacity: 1;
  visibility: visible;
  transform: translateX(0);
  transition: .4s ease-out
}
.tpblog-3__content, .tpblog-3__img::before {
  -webkit-transition: .4s ease-out;
  -moz-transition: .4s ease-out;
  -ms-transition: .4s ease-out;
  -o-transition: .4s ease-out
}
.tpblog:hover .tpblog__content::after {
  opacity: 1;
  visibility: visible;
  transform: translateX(0)
}
.tpblog:hover .tpblog__thumb-2 img {
  transform: scale(1.17) rotate(2deg)
}
.date a {
  text-transform: capitalize
}
.blog-area {
  padding: 65px 0
}
.tpblog-3__content {
  padding: 14px 40px 20px 30px;
  background: var(--grey-lt-color);
  transition: .4s ease-out;
  position: relative
}
.tpblog-3__content::before {
  position: absolute;
  content: "";
  bottom: 0;
  left: auto;
  right: 0;
  height: 4px;
  width: 0;
  opacity: 0;
  background-color: #fbd45a;
  transition: .3s linear
}
.tpblog-3__img .date, .tpblog-3__meta .date {
  left: 30px;
  position: absolute;
  text-align: center;
  text-transform: capitalize
}
.tpblog-3__img .date, .tpblog-3__meta .date, .tpblog-3__meta .date a {
  background: #fbd45b;
  font-weight: 700
}
.tpblog-3__img .date {
  padding: 7px 20px;
  font-size: 14px;
  bottom: 0
}
@media only screen and (min-width:768px) and (max-width:991px) {
  .text-black a {
    color: #fff !important
  }
  .tpblog-3__meta .user {
    font-size: 15px;
    margin-right: 10px
  }
}
.tpblog-3__meta .user i {
  color: #1c806e;
  font-size: 14px;
  padding-right: 8px
}
.tpblog-3__meta .Comments i {
  color: #1c806e;
  font-size: 14px;
  padding-right: 8px
}
.tpblog-3__meta .date {
  bottom: 145px;
  padding: 7px 20px;
  font-size: 14px
}
@media only screen and (min-width:768px) and (max-width:991px) {
  .tpblog-3__meta .date {
    bottom: 140px
  }
  .tp-accordion .title {
    font-size: 33px;
    line-height: 40px
  }
}
@media only screen and (min-width:576px) and (max-width:767px) {
  .date a {
    font-size: 14px
  }
  .tpblog-3__meta .date {
    bottom: 137px
  }
  .contact__social .icon ul li a {
    margin-left: 0
  }
}
.tpblog-3__meta .date a {
  font-size: 14px;
  color: var(--font-color);
  padding: 11px 20px;
  line-height: 0
}
.tpblog-3:hover .tpblog-3__content::before {
  width: 100%;
  left: 0;
  right: auto;
  opacity: 1
}
.tpblog-3:hover:hover .tpblog-3__content {
  background: #fff
}
.tpblog-3__img::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(40, 55, 52, .52);
  content: "";
  opacity: 0;
  visibility: hidden;
  transition: .4s ease-out
}
.tpblog-3__img .plus-icon {
  position: absolute;
  top: 50%;
  right: 0;
  text-align: center;
  color: var(--white-color);
  font-size: 30px;
  transform: translateY(-50%);
  left: 0;
  margin: 0 auto;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: .4s ease-out;
  -moz-transition: .4s ease-out;
  -ms-transition: .4s ease-out;
  -o-transition: .4s ease-out;
  transition: .4s ease-out
}
.social-sharing [data-tooltip]:hover::after, .social-sharing [data-tooltip]:hover::before {
  transform: translateX(-50%);
  opacity: 0;
  transition: opacity .2s ease-in-out, top .2s ease-in-out;
  left: 50%
}
.tp-blog-title {
  font-size: 24px;
  font-weight: 400;
  color: var(--font-color)
}
.contact__social .icon ul li {
  list-style: none;
  display: inline-block
}
.contact__social .icon ul li a {
  margin-right: 25px;
  color: #00715d;
  font-size: 18px
}
.contact__social .icon ul li a:hover {
  color: #283734
}
.contact__line a {
  font-weight: 400
}
.contact__info-icon {
  position: absolute;
  top: 0;
  left: 0
}
.contact__info-item {
  position: relative;
  padding-left: 30px
}
.contact__info ul li {
  list-style: none;
  padding-bottom: 15px
}
.contact__info ul li a span {
  font-weight: 400;
  font-family: var(--primary-font)
}
.contact__info ul li a i {
  margin-right: 20px
}
.contact__info ul li a:hover {
  color: #fbd45b
}
@media only screen and (min-width:768px) and (max-width:991px), only screen and (min-width:576px) and (max-width:767px), (max-width:767px) {
  .contact {
    padding-right: 0
  }
}
@media only screen and (min-width:576px) and (max-width:767px), (max-width:767px) {
  .postbox__banner-img {
    margin-bottom: 30px
  }
  .tp-header__bottom {
    padding: 35px 50px
  }
  .tpblog-3__content {
    padding: 14px 10px 21px 13px
  }
  .tpblog-3__meta .user {
    margin-right: 12px;
    font-size: 14px
  }
  .tpblog-3__meta .user i {
    font-size: 14px;
    padding-right: 5px
  }
  .tpblog-3__meta .Comments {
    padding-right: 0;
    font-size: 14px
  }
  .tpblog-3__meta .Comments i {
    font-size: 14px;
    padding-right: 5px
  }
  .contact {
    margin-left: 0
  }
}
.main-contact-form-area {
  position: relative;
  display: block;
  padding: 80px 0;
  z-index: 10;
  overflow: hidden
}
.contact-form--style1 {
  position: relative;
  display: block;
  background: #1a1E20e6;
  padding: 60px 70px;
  border-radius: 8px;
  box-shadow: 0 5px 20px rgba(0, 0, 0, .15);
  margin: 0
}
.btn-one, ul.tabs li, ul.tabs li span {
  display: inline-block
}
.contact-form--style1::before {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  background: var(--primary-color);
  height: 10px;
  content: "";
  border-top-left-radius: 8px;
  border-top-right-radius: 8px
}
.contact-form--style1 .subtitle {
  font-size: 16px;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 10px
}
.contact-form--style1 .title {
  color: var(--white-color);
  font-size: 28px;
  font-weight: 700;
  margin-bottom: 30px
}
.contact-form form .input-box {
  position: relative;
  margin-bottom: 20px
}
.contact-form form input[type=date], .contact-form form input[type=email], .contact-form form input[type=tel], .contact-form form input[type=text], .contact-form form select, .contact-form form textarea {
  background-color: var(--secondary-color);
  width: 100%;
  height: 48px;
  border: 1px solid #515455;
  box-shadow: inset 0 1px 1px rgba(17, 19, 20, .075);
  color: #fff;
  font-size: 14px;
  font-weight: 500;
  padding: 0 20px 0 45px;
  border-radius: 6px;
  transition: border-color .3s, box-shadow .3s;
  font-family: var(--primary-font)
}
.contact-form form textarea {
  height: 140px;
  padding: 15px 20px 15px 45px
}
.contact-form form .input-icon {
  position: absolute;
  left: 15px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--primary-color);
  font-size: 16px;
  transition: color .3s
}
.contact-form form input:focus, .contact-form form select:focus, .contact-form form textarea:focus {
  border-color: var(--primary-color);
  box-shadow: 0 0 8px rgba(197, 26, 27, .3)
}
ul.tabs, ul.tabs li {
  border-bottom: 3px solid #45484a
}
.contact-form form input:focus + .input-icon, .contact-form form select:focus + .input-icon, .contact-form form textarea:focus + .input-icon, .details-section p strong, .hotel-brand p, .room-specs ul li i, .service-details-contact-info .bottom-box h2 a:hover, .service-details-contact-info .bottom-box h3 a:hover, .ticket-details p strong {
  color: var(--primary-color)
}
.contact-form form select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: var(--secondary-color) url('data:image/svg+xml;utf8,<svg fill="%23fff" height="24" viewBox="0 0 24 24" width="24" xmlns="http://www.w3.org/2000/svg"><path d="M7 10l5 5 5-5z"/></svg>') no-repeat right 15px center
}
.contact-form form ::-webkit-input-placeholder {
  color: #737c76;
  transition: opacity .3s
}
.contact-form form input:focus::-webkit-input-placeholder {
  opacity: .5
}
.contact-form form .button-box {
  padding-top: 15px;
  text-align: center
}
.btn-one {
  position: relative;
  padding: 5px 20px !important;
  background-color: var(--primary-color);
  color: var(--white-color);
  font-size: 15px;
  font-weight: 600;
  border-radius: 6px;
  overflow: hidden;
  transition: .4s;
  z-index: 1
}
.btn-one::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #aa0808;
  transform: translateX(-100%);
  transition: transform .4s;
  z-index: -1
}
.btn-one:hover::before {
  transform: translateX(0)
}
.btn-one .txt {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px
}
.btn-one i {
  font-size: 16px;
  transition: transform .3s
}
.btn-one:hover i {
  transform: rotate(360deg)
}
.contact-info-box {
  background: #1a1E20e6;
  padding: 60px 70px;
  border-radius: 8px;
  box-shadow: 0 5px 20px rgba(0, 0, 0, .15);
  height: 100%
}
.kata-box, .student-enrolled, .student_img img, .student_more_info, .style_img img, .team-box {
  border-radius: 10px
}
.team-box, .user-details-section {
  box-shadow: rgba(149, 157, 165, .2) 0 8px 24px
}
.contact-info-box .sec-title {
  padding-bottom: 30px
}
.contact-info-box .sec-title h2 {
  color: var(--white-color);
  font-size: 28px;
  font-weight: 700
}
.contact-info-list li {
  display: flex;
  gap: 15px;
  margin-bottom: 15px;
  align-items:center;
}
.contact-info-list li .icon {
  background: var(--primary-color);
  width: 60px;
  height: 60px;
  line-height: 60px;
  border-radius: 50%;
  text-align: center;
  color: var(--white-color);
  font-size: 18px;
  transition: background .3s;
  flex: 0 0 auto
}
.contact-info-list li .text h4 {
  color: var(--white-color);
  font-size: 18px;
  font-weight: 700;
  margin: 0
}
.contact-info-list li .text p, .contact-info-list li .text p a {
  color: #a1a7ab;
  font-size: 16px;
  line-height: 20px;
  margin:0px;
}
.social-links ul {
  list-style: none;
  padding: 0;
  display: flex;
  gap: 10px
}
.kata-box span, .student-user {
  flex-direction: column;
  gap: 15px
}
.social-links ul li{
    margin:0px;
}
.social-links ul li a {
  color: var(--white-color);
  font-size: 32px;
  text-decoration: none
}
@media (max-width:1024px) {
  .profile_blog_content {
    position: relative;
    bottom: auto;
    right: auto;
    left: auto
  }
  .contact-form--style1, .contact-info-box {
    padding: 40px 50px
  }
}
@media (max-width:991px) {
  .main-contact-form-area .col-lg-5, .main-contact-form-area .col-lg-7 {
    width: 100%
  }
  .contact-info-box {
    margin-top: 30px;
    height: auto
  }
}
@media (max-width:767px) {
  .back-to-top-wrapper {
    right: 20px;
    bottom: 20px
  }
  .tp-btn-black {
    padding: 8px 36px
  }
  .blog-banner-title, .blog-banner-title-black {
    padding: 40px 26px
  }
  .postbox__wrapper {
    padding-right: 0
  }
  .postbox__comment-avater {
    height: 50px;
    width: 54px;
    margin-right: 15px
  }
  .tp-header__bottom {
    padding: 25px 30px
  }
  .error-page__tagline {
    font-size: 29px
  }
  .tpblog__content-2 {
    padding: 17px 26px
  }
  .tpblog__content-2 .tp-blog-title {
    font-size: 20px
  }
  .tpblog-3__meta .date {
    bottom: 136px
  }
  .blog-area-3 {
    padding-bottom: 40px;
    padding-top: 60px
  }
  .contact-form--style1, .contact-info-box {
    padding: 30px
  }
  .btn-one {
    padding: 3px 15px !important
  }
}
.page-content {
  position: relative;
  display: block;
  line-height: 1.6
}
.page-content .container {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 15px
}
.page-content h2 {
  font-size: 32px;
  font-weight: 700;
  margin: 30px 0 20px;
  color: var(--tp-text-body); /* Match body text color */
  position: relative;
  padding-bottom: 12px;
}

.page-content h2::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 60px; /* Slightly wider than h3 for hierarchy */
  height: 4px;
  background-color: var(--primary-color); /* Use theme’s primary color */
  border-radius: 2px;
}

.page-content h3 {
  font-size: 26px;
  font-weight: 700;
  margin: 40px 0 20px;
  position: relative;
  padding-bottom: 10px;
  color: var(--tp-text-body);
}

.page-content h3::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 50px;
  height: 3px;
  background-color: var(--primary-color);
  border-radius: 2px;
}

.page-content h4 {
  font-size: 20px;
  font-weight: 600;
  margin: 30px 0 15px;
  color: var(--tp-text-body);
}

.page-content p {
  margin: 0 0 20px;
  font-size: 16px;
  line-height: 28px;
  color: var(--tp-text-body);
}

.page-content p strong {
  font-weight: 700;
}

.page-content a {
  text-decoration: none;
  color: var(--primary-color); /* Use theme’s primary color for links */
  transition: color 0.3s ease, text-decoration 0.3s ease;
}

.page-content a:hover {
  text-decoration: underline;
  color: var(--primary-color-dark, var(--primary-color)); /* Darker shade if defined, else fallback */
}

.page-content ul {
  margin: 0 0 20px 25px;
  padding: 0;
  list-style: none;
  color: var(--tp-text-body);
}

.page-content ul li {
  position: relative;
  padding-left: 25px;
  font-size: 16px;
  line-height: 26px;
  margin-bottom: 10px;
}

.page-content ul li::before {
  content: '\f058';
  font-family: var(--font-awesome);
  font-weight: 900;
  color: var(--primary-color);
  position: absolute;
  left: 0;
  top: 2px;
  font-size: 14px;
}

.page-content ol {
  margin: 0 0 20px 25px;
  padding: 0;
  list-style: decimal; /* Use numbers for ordered lists */
  color: var(--tp-text-body);
}

.page-content ol li {
  font-size: 16px;
  line-height: 26px;
  margin-bottom: 10px;
  padding-left: 10px;
}

.page-content ol ul {
  margin: 10px 0 10px 25px; /* Nested ul inside ol */
}

.page-content ol ul li{
  padding-left:25px; /* Nested ul inside ol */
}

.page-content ol ul li::before {
  content: '\f058'; /* Maintain consistent bullet for nested ul */
  font-family: var(--font-awesome);
  font-weight: 900;
  color: var(--primary-color);
  position: absolute;
  left: 0;
  top: 2px;
  font-size: 14px;
}
.google-map-area {
  position: relative;
  display: block;
  background: #fff;
  z-index: 10
}
.google-map-area .auto-container {
  max-width: 100%;
  padding: 0
}
.contact-page-map-outer {
  position: relative;
  display: block;
  z-index: 10
}
.contact-page-map-outer .map-canvas {
  position: relative;
  width: 100%;
  height: 675px
}
.tp-form-box {
  font-size: 16px;
  color: var(--white-color);
  font-weight: 400;
  text-transform: capitalize
}
.tp-form-title {
  font-size: 24px;
  color: #fbd45b
}
.kata-box span i, .student-title {
  font-size: 19px;
  text-align: center
}
@media only screen and (min-width:576px) and (max-width:767px) {
  .tp-accordion {
    margin-top: 50px
  }
}
.tpmap-wrapper iframe {
  filter: saturate(0);
  width: 100%;
  height: 339px
}
.service-details-contact-info {
  position: relative;
  display: block;
  background: var(--primary-t-color);
  padding: 60px 65px 55px;
  margin-top: 30px
}
.service-details-contact-info .top-box {
  position: relative;
  display: block;
  margin-bottom: 15px
}
.service-details-contact-info .top-box .icon {
  position: relative;
  display: block;
  width: 80px;
  height: 80px;
  background: var(--primary-color);
  border-radius: 50%;
  text-align: center;
  color: var(--white-color);
  font-size: 25px;
  margin: 0 auto 25px
}
.service-details-contact-info .top-box .icon span::before {
  position: relative;
  display: inline-block;
  line-height: 80px
}
.service-details-contact-info .top-box h4 {
  color: #fff;
  font-size: 24px;
  line-height: 29px;
  font-weight: 700
}
.service-details-contact-info .bottom-box {
  position: relative;
  display: block;
  padding-top: 15px;
  border-top: 1px solid rgba(255, 255, 255, .1)
}
.service-details-contact-info .bottom-box p {
  color: rgba(255, 255, 255, .7);
  font-size: 16px;
  line-height: 26px;
  font-weight: 600;
  margin: 0
}
.service-details-contact-info .bottom-box h2, .service-details-contact-info .bottom-box h3 {
  font-size: 24px;
  line-height: 26px;
  font-weight: 800;
  margin-top: 11px
}
.student-enrolled {
  background: #fff;
  overflow: hidden
}
.student-title {
  display: block;
  padding: 25px;
  background: var(--primary-lt-color);
  color: var(--white-color);
  font-weight: 700
}
.students-active {
  max-height: 380px;
  margin: 25px
}
.student-user {
  display: flex;
  align-items: center
}
.student-user img {
  max-width: 290px
}
.kata-box {
  position: relative;
  overflow: hidden;
  display: block
}
.kata-box span {
  position: absolute;
  color: #fff;
  font-size: 24px;
  top: 50%;
  left: 0;
  text-align: center;
  font-weight: 700;
  width: 100%;
  padding: 15px;
  transform: translateY(-50%);
  display: flex;
  align-items: center
}
.kata-box span i {
  width: 60px;
  height: 40px;
  line-height: 40px;
  background: red;
  border-radius: 5px
}
.team-box {
  padding: 5px;
  display: flex;
  flex-direction: column;
  gap: 7px;
  position: relative;
  overflow: hidden
}
.student_img {
  overflow: hidden;
  position: relative
}
.blurred, .custom-slider {
  position: relative;
  overflow: hidden
}
.blurred:after {
  position: absolute;
  height: 100%;
  width: 100%;
  background: 0 0;
  top: 0;
  left: 0;
  content: ' ';
  backdrop-filter: blur(7px);
  transition: filter .3s
}
.student_img img {
  width: 100%;
  min-height: 240px
}
.style_img {
  position: absolute;
  bottom: 10px;
  right: 10px
}
.style_img img {
  width: 65px
}
.student_info {
  padding: 10px;
  margin: 0
}
.student_info h4 {
  padding: 0;
  margin: 0 0 5px;
  text-transform: capitalize;
  color: var(--white-color);
  font-weight: 400;
  font-size: 16px
}
.instructor-record, .student-record, .user-box p, ul.tabs {
  margin: 0;
  padding: 0
}
.student_info h4 span {
  font-size: 14px;
  padding-left: 5px
}
.student-record {
  font-size: 15px;
  display: flex;
  justify-content: space-between
}
.instructor-record {
  font-size: 14px;
  line-height: 1.3;
  color: #b1b3b3
}
.student_more_info {
  position: absolute;
  bottom: -30px;
  right: 0;
  left: 0;
  padding: 5px;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  transition: bottom .3s .1s
}
.user-box, .user-details {
  padding: 15px;
  display: flex
}
.team-box:hover .student_more_info {
  bottom: 0
}
.student_more_info a {
  bottom: 0;
  width: 100%;
  height: 32px;
  line-height: 32px;
  text-align: center;
  border-radius: 10px;
  font-size: 14px;
  background-image: linear-gradient(47deg, #d73232 0, #d31f1f 100%);
  box-shadow: 0 8px 29px 0 rgba(211, 32, 49, .6)
}
.gallery {
  columns: 3;
  margin: auto;
  max-width: 100%;
  column-gap: 15px
}
.gallery img {
  width: 100%;
  border-radius: .4em
}
@media screen and (max-width:767px) {
  .gallery {
    columns: 1;
    max-width: 100%
  }
}
@media screen and (min-width:768px) and (max-width:1024px) {
  .gallery {
    columns: 2;
    max-width: 100%
  }
}
.user-details {
  list-style: none;
  width: 100%;
  flex-direction: column;
  gap: 10px
}
.user-details li {
  display: flex;
  justify-content: space-between;
  gap: 20px
}
.user-details li i {
  margin: 0 10px 0 0
}
.user-box {
  border-radius: 3px;
  justify-content: center;
  align-items: stretch;
  flex-direction: column;
  background: #e8ebed
}
.user-box-footer {
  display: flex;
  justify-content: space-between
}
.user-box.active {
  background: #e9f6f8
}
ul.tabs {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  gap: 5px
}
ul.tabs li {
  padding: 5px 15px;
  cursor: pointer;
  font-size: 14px;
  color: #fff;
  position: relative;
  background: #1a1e20;
  border-radius: 3px 3px 0 0;
  transition: .3s;
  margin-bottom: -3px
}
ul.tabs li span {
  text-align: center;
  color: #868889;
  position: relative
}
ul.tabs li.current, ul.tabs li:hover {
  color: #fff;
  position: relative;
  transition: .3s;
  background: var(--primary-color);
  border-color: var(--primary-color) !important
}
.tab-content {
  display: none;
  padding: 15px 0
}
.tab-content.current {
  display: inherit
}
.tab-img {
  border: 3px solid #303436;
  border-radius: 4px;
  overflow: hidden
}
.content-description ol, .content-description ul {
  padding: 0 0 0 20px;
  margin-bottom: 15px;
  color: var(--tp-text-body)
}
.content-title {
  padding: 5px 0 8px;
  position: relative;
  color: var(--white-color);
  font-size: 17px
}
.content-title:after, .room-box h3:after {
  background: linear-gradient(90deg, #c51a1b 49%, #771718 87%, #11131400);
  border-radius: 2px 0 0 2px;
  content: " ";
  display: block;
  height: 2px;
  margin-top: 3px
}
.event__area {
  padding: 25px 0 0
}
.content-hint {
  background-color: #771718;
  border-radius: 4px;
  color: #b1b3b3;
  font-size: 12px;
  font-weight: 400;
  line-height: 16px;
  text-decoration: none;
  padding: 10px
}
.event-info {
  background-color: #1a1e20 !important;
  padding: 15px;
  border-radius: 5px 5px 0 0;
  color: var(--white-color)
}
.event-date, .event-reg {
  display: flex;
  gap: 20px;
  align-items: baseline;
  color: var(--white-color)
}
.sidebar-btn-menu ul, .sidebar-menu ul {
  flex-direction: column;
  margin: 0;
  list-style: none
}
.event-date {
  color: #868889;
  font-size: 14px;
  line-height: 19px
}
.event-date strong {
  color: var(--white-color);
  font-size: 16px
}
.event-info:last-child {
  margin: 0 0 25px;
  border-radius: 5px
}
.event-registration {
  background-color: #1a1e20;
  border-radius: 5px;
  margin-bottom: 10px;
  min-height: 1px;
  overflow: hidden;
  padding: 15px;
  position: relative;
  width: 100%
}

/* Base styling for the invitation card */
.invitation-card {
    border-top: 1px solid #444;
    padding-top: 20px;
    text-align: center;
    margin-top: 20px;
    background-color: #2c2c2c;
    color: #fff;
    border-radius: 8px;
    padding: 20px;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

.invitation-card h3 {
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 10px;
    color: #fff;
}

.invitation-card h6 {
    font-size: 18px;
    font-weight: bold;
    color: #ddd;
    margin-bottom: 10px;
}

.invitation-card p {
    font-size: 16px;
    color: #ccc;
    margin-bottom: 15px;
}

.invitation-card small.form-text {
    font-size: 12px;
    color: #999;
    display: block;
    margin-top: 5px;
}

.invitation-card .highlight-box {
    background-color: #444;
    padding: 15px;
    border-radius: 5px;
    margin-bottom: 20px;
}

.invitation-card .highlight-box p {
    font-size: 14px;
    color: #ccc;
    margin: 0;
}

.invitation-card .highlight-box .price {
    font-size: 18px;
    font-weight: bold;
    color: #fff;
    margin: 10px 0 0 0;
}

.invitation-card .highlight-box .price span {
  font-size: 0.9em;
  color: #666;
}

.invitation-card .step {
    display: none;
}

.invitation-card .step.active {
    display: block;
}

.invitation-card .form-check {
    text-align: left;
    margin-bottom: 15px;
}

.invitation-card .form-check-label {
    color: #ccc;
    font-size: 14px;
    margin-left: 5px;
}

.invitation-card .form-check-input {
    margin-top: 0;
    vertical-align: middle;
    background-color: #333;
    border: 1px solid #555;
}

.invitation-card .form-check-input:checked {
    background-color: #e74c3c;
    border-color: #e74c3c;
}

.invitation-card .mb-3 {
    margin-bottom: 15px;
}

.invitation-card .form-label {
    display: block;
    font-size: 14px;
    color: #ddd;
    text-align: left;
    margin-bottom: 5px;
}

.invitation-card .form-control {
    width: 100%;
    padding: 10px;
    background-color: #333;
    border: 1px solid #555;
    border-radius: 5px;
    color: #fff;
    font-size: 14px;
    box-sizing: border-box;
}

.invitation-card .form-control:focus {
    outline: none;
    border-color: #e74c3c;
    box-shadow: 0 0 5px rgba(231, 76, 60, 0.5);
}

.invitation-card .form-control[readonly] {
    background-color: #444;
    opacity: 1;
}

.invitation-card .input-group {
    display: flex;
    align-items: center;
    background-color: #333;
    border: 1px solid #555;
    border-radius: 5px;
    overflow: hidden;
}

.invitation-card .input-group .btn {
    padding: 10px;
    background-color: #333;
    border: none;
    color: #ccc;
    font-size: 16px;
    cursor: pointer;
    transition: background-color 0.3s;
}

.invitation-card .input-group .btn:hover {
    background-color: #444;
}

.invitation-card .input-group .form-control {
    border: none;
    flex: 1;
    text-align: center;
}

.invitation-card .tp-btn {
    background-color: #e74c3c;
    color: #fff;
    border-radius: 5px;
    padding: 10px 20px;
    text-transform: uppercase;
    font-weight: bold;
    border: none;
    display: inline-block;
    text-decoration: none;
    cursor: pointer;
    transition: background-color 0.3s;
}

.invitation-card .tp-btn:hover {
    background-color: #c0392b;
}

.invitation-card .tp-btn-sec {
    background-color: #6c757d;
}

.invitation-card .tp-btn-sec:hover {
    background-color: #5a6268;
}

.invitation-card .tp-button {
    margin-top: 20px;
}

.invitation-card .tp-button .tp-btn,
.invitation-card .tp-button .tp-btn-sec {
    margin: 5px;
}

.invitation-card #add-to-calendar {
    background-color: #3498db;
}

.invitation-card #add-to-calendar:hover {
    background-color: #2980b9;
}

/* PayPal button container */
.invitation-card #paypal-button-container {
    margin-top: 15px;
    display: inline-block;
}

@media (max-width: 480px) {
    .invitation-card {
        padding: 15px;
    }

    .invitation-card h3 {
        font-size: 20px;
    }

    .invitation-card p {
        font-size: 14px;
    }

    .invitation-card .tp-btn,
    .invitation-card .tp-btn-sec {
        padding: 8px 15px;
        font-size: 14px;
    }
}

.tp-button .tp-btn {
    background-color: #e74c3c; /* Red button for "Register" */
    color: #fff;
    border-radius: 5px;
}

.tp-button .tp-btn:hover {
    background-color: #c0392b; /* Darker red on hover */
}

.tp-button .tp-btn-sec {
    background-color: #666; /* Gray button for "Add to Calendar" */
    color: #fff;
    border-radius: 5px;
}

.tp-button .tp-btn-sec:hover {
    background-color: #555; /* Darker gray on hover */
}
.event-type {
  background: var(--primary-color);
  color: var(--white-color);
  font-size: 12px;
  height: 24px;
  line-height: 24px;
  padding: 0 5px;
  border-radius: 5px;
  display: inline-block
}
#show-more:hover, .sidebar-profile {
  background: var(--secondary-color)
}
.sidebar-btn-menu ul {
  display: flex;
  padding: 0;
  gap: 10px
}
.sidebar-btn-menu ul li, .sidebar-menu ul li {
  padding: 0
}
.sidebar-btn-menu ul li a {
  display: block;
  padding: 5px 10px;
  color: #fff;
  font-weight: 700;
  background: #c51a1b;
  border-radius: 5px;
  text-align: center
}
.sidebar-btn-menu + .sidebar-menu, .sidebar-menu + .sidebar-menu {
  margin-top: 20px
}
.sidebar-menu {
  border: 1px solid #45484a;
  border-radius: 5px;
  overflow: hidden
}
.sidebar-menu strong {
  background: #45484a;
  display: block;
  text-align: center;
  padding: 5px;
  color: #fff
}
.sidebar-menu ul {
  display: flex;
  padding: 0
}
.sidebar-menu ul li + li {
  border-top: 1px solid #45484a
}
.sidebar-menu ul li a {
  display: block;
  padding: 5px 10px;
  color: #b1b3b3
}
.sidebar-menu ul li a:hover, .sidebar-menu ul li.active a {
  background: #515455;
  color: #fff
}
.sidebar-profile {
  padding: 10px;
  margin-bottom: 20px;
  border-radius: 5px;
  color: #868889;
  display: flex;
  flex-direction: column
}
.verified {
  color: #27aa1c
}
.profile-card {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  color: #b1b3b3;
  background: #1a1e20;
  padding: 10px 60px 10px 20px;
  border-radius: 10px;
  position: relative;
  height: 100%
}
.profile-card:hover {
  color: #b1b3b3;
  background: #303436
}
.profile-card img {
  border: 2px solid #303436;
  border-radius: 5px;
  flex-shrink: 0;
  height: 60px;
  margin-right: 10px;
  width: 60px
}
.profile-card i {
  font-size: 24px;
  position: absolute;
  right: 20px
}
.profile-card strong {
  font-size: 17px
}
.profile-card p {
  font-size: 12px;
  line-height: 16px;
  padding: 0;
  margin: 0
}
.main-contact-form-area .row + .content-title {
  margin-top: 25px
}
.img-thumb {
  width: 45px
}
.filter-checkboxes input, input[type=submit] + input[type=reset] {
  margin-right: 10px
}
input[type=submit] {
  background: #ff3533 !important
}
.img {
  width: 36px;
  height: 36px;
  border-radius: 5px;
  background: #ddd
}
.img-container {
  align-items: stretch;
  display: flex;
  flex-wrap: wrap;
  padding: 5px;
  gap: 2%
}
.img-container .img-pic {
  align-items: stretch;
  display: flex;
  flex-basis: 23.5%;
  flex-grow: 0;
  flex-shrink: 0;
  position: relative
}
.img-container .img-pic span {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  text-align: center;
  color: var(--white-color);
  font-size: 10px;
  line-height: 13px
}
.summary-result {
  background: linear-gradient(160deg, #1a1e20 0, #202528 100%);
  border-radius: 15px;
  margin-bottom: 25px;
  padding: 20px;
  box-shadow: 0 6px 15px rgba(0, 0, 0, .25)
}
.summary-result-featured {
  border: 3px solid var(--primary-color);
  margin: 25px 0 0
}
.summary-description {
  display: flex;
  flex-direction: column;
  color: #a0a3a7
}
.summary-description .summary-date {
  color: #a0a3a7;
  font-weight: 600;
  line-height: 18px;
  margin-bottom: 12px;
  font-size: 15px
}
.summary-description .summary-date b {
  display: block;
  font-size: 13px;
  font-weight: 300;
  color: #b1b3b3
}
.summary-description h3, .summary-result h3 {
  color: #fff;
  font-size: 18px;
  font-weight: 600;
  line-height: 20px;
  margin: 0 0 15px;
  letter-spacing: -.5px
}
.summary-description p {
  color: #b1b3b3;
  margin-top: 18px;
  line-height: 1.6;
  font-size: 16px
}
.summary-distance, .summary-people {
  color: #b1b3b3
}
.summary-btn {
  background: 0 0;
  border: 2px solid var(--primary-color);
  margin-right: auto;
  padding: 8px 20px;
  border-radius: 25px;
  color: #fff;
  font-weight: 600;
  margin-top: 30px;
  transition: background-color .3s, color .3s;
  box-shadow: none
}
.summary-btn:hover {
  background-color: var(--primary-color);
  color: #fff;
  border-color: var(--primary-color)
}
.ui-widget.ui-widget-content {
  border: 1px solid #c5c5c5;
  overflow: scroll;
  overflow-x: hidden;
  max-height: 200px
}
.suggest-flex {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 10px 0
}
.suggest {
  background: #515455;
  border-radius: 10px;
  color: #b1b3b3;
  display: inline-block !important;
  font-weight: 400;
  margin-bottom: 5px;
  padding: 3px 12px;
  width: unset;
  font-size: 14px;
  cursor: pointer
}
.social-sharing {
  display: flex;
  align-items: center;
  gap: 15px;
  font-family: Arial, sans-serif;
  margin-top: 20px
}
.social-sharing > span {
  font-size: .95em;
  color: #fff;
  margin-right: 8px
}
.social-sharing a, .social-sharing button.copy-link-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 12px;
  text-decoration: none;
  color: #fff;
  font-size: 1.4em;
  transition: .3s;
  position: relative;
  cursor: pointer;
  box-shadow: 0 2px 5px rgba(0, 0, 0, .1)
}
.social-sharing a:hover, .social-sharing button.copy-link-btn:hover {
  transform: scale(1.1) translateY(-2px);
  box-shadow: 0 4px 8px rgba(0, 0, 0, .25)
}
.social-sharing a:active, .social-sharing button.copy-link-btn:active {
  transform: scale(.95);
  box-shadow: 0 1px 3px rgba(0, 0, 0, .15)
}
.social-sharing a.facebook, .social-sharing button.facebook {
  background-color: #3b5998
}
.social-sharing a.twitter, .social-sharing button.twitter {
  background-color: #1da1f2
}
.social-sharing a.linkedin, .social-sharing button.linkedin {
  background-color: #0077b5
}
.social-sharing a.pinterest, .social-sharing button.pinterest {
  background-color: #e60023
}
.social-sharing a.whatsapp, .social-sharing button.whatsapp {
  background-color: #25d366
}
.social-sharing a.email, .social-sharing button.email {
  background-color: #ea4335
}
.social-sharing button.copy-link-btn {
  background-color: #4caf50
}
.social-sharing [data-tooltip]:hover::before {
  content: attr(data-tooltip);
  position: absolute;
  background: rgba(30, 30, 30, .9);
  color: #fff;
  padding: 3px 6px;
  border-radius: 6px;
  white-space: nowrap;
  z-index: 1000;
  font-size: 12px;
  line-height: 14px
}
.social-sharing [data-tooltip]:hover::after {
  content: '';
  position: absolute;
  border-top: 6px solid rgba(30, 30, 30, .9);
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  z-index: 1001
}
.social-sharing [data-tooltip]:hover::after, .social-sharing [data-tooltip]:hover::before {
  opacity: 1;
  top: -25px
}
.filter-section label, .hotel-type {
  font-size: 14px
}
.filter-box {
  border: 1px solid #3c3c3c;
  margin-bottom: 25px
}
.filter-section input[type=range] {
  -webkit-appearance: none;
  height: 6px;
  background: #ddd;
  border-radius: 5px;
  outline: 0;
  opacity: .7;
  transition: opacity .15s ease-in-out
}
.filter-section input[type=range]::-moz-range-track, .filter-section input[type=range]::-webkit-slider-runnable-track {
  width: 100%;
  height: 6px;
  background: #ff9c98;
  border-radius: 5px
}
.filter-section input[type=range]::-moz-range-thumb, .filter-section input[type=range]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 15px;
  height: 15px;
  margin-top: -5px;
  background: #9f0600;
  cursor: pointer;
  border-radius: 50%;
  box-shadow: 0 0 2px rgba(0, 0, 0, .2)
}
.filter-checkboxes label {
  justify-content: space-between
}
.filter-checkboxes .count {
  color: #888
}
.page-by-dropdown {
  justify-content: flex-end
}
.page-by-dropdown label, .sort-by-dropdown label {
  margin-right: 10px;
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  width: 100px
}
#page-options, #sort-options {
  padding: 5px 10px;
  font-size: 16px;
  border: 1px solid #3c3c3c;
  border-radius: 4px;
  cursor: pointer;
  background: #111314;
  color: #959595
}
#sort-options:focus {
  outline: 0;
  border-color: var(--primary-color)
}
#hotel-list {
  display: flex;
  flex-direction: column;
  min-height: 300px;
  position: relative
}
.hotel-card {
  background-color: var(--card-background);
  border: 3px solid #c51a1b;
  border-radius: 10px;
  padding: 15px;
  margin-bottom: 20px;
  color: var(--text-color);
  box-shadow: 0 2px 10px rgba(0, 0, 0, .1);
  transition: box-shadow .3s
}
#filter-button, .availability-btn, .facility-box {
  transition: background-color .3s
}
.hotel-card:hover {
  box-shadow: 0 4px 12px rgba(0, 0, 0, .2)
}
.hotel-type {
  position: absolute;
  top: 10px;
  left: 10px;
  background: #c00;
  color: #fff;
  padding: 2px 10px;
  z-index: 1
}
.hotel-type[data-htype=Couple-Friendly] {
  background-color: #c00
}
.hotel-type[data-htype=Couple-Exclusive] {
  background-color: #000
}
.hotel-image img {
  border-radius: 3px;
  width: 100%;
  height: auto
}
.hotel-name {
  margin: 0
}
a .hotel-name {
  font-size: 28px;
  color: var(--heading-color);
  text-decoration: none
}
.hotel-highlights h4 {
  color: #e93536;
  font-size: 17px;
  font-weight: 600;
  padding: 0 0 0 15px;
  position: relative
}
.hotel-highlights h4:before {
  background: #e93536;
  height: 100%;
  width: 8px;
  left: 0;
  position: absolute;
  content: ' '
}
.hotel-highlights ul {
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: 14px;
  line-height: 1.5
}
.hotel-highlights ul li {
  padding: 0 0 0 20px;
  margin: 0;
  position: relative
}
.hotel-content ul li:before, .hotel-highlights ul li:before {
  position: absolute;
  font-family: var(--font-awesome);
  content: '\f004';
  left: 0;
  font-weight: 700;
  color: #c51a1b
}
.hotel-header {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 10px
}
.hotel-reviews {
  display: flex;
  justify-content: flex-end;
  font-size: 14px;
  margin-bottom: 25px;
  line-height: 18px;
  gap: 10px;
  align-items: center
}
.rating-text {
  font-weight: 700;
  text-align: right
}
.rating-value {
  background-color: #00c853;
  color: var(--rating-text-color);
  font-weight: 700;
  padding: 0 8px;
  border-radius: 5px 5px 5px 0;
  margin-right: 8px;
  min-width: 40px;
  height: 40px;
  line-height: 40px;
  text-align: center
}
.rating-reviews {
  color: #aaa;
  font-weight: 400
}
.hotel-location {
  font-size: 14px;
  margin: 10px 0;
  color: #aaa
}
.hotel-location a {
  color: var(--accent-color);
  text-decoration: none
}
.hotel-location i {
  margin-right: 5px;
  color: #c51a1b
}
.hotel-description {
  font-size: 14px;
  color: var(--text-color);
  margin: 10px 0;
  line-height: 20px
}
.availability-btn {
  background-color: #c51a1b;
  color: var(--rating-text-color);
  padding: 5px 15px;
  text-decoration: none;
  display: block;
  width: 100%;
  text-align: center;
  border-radius: 5px;
  font-weight: 700;
  font-size: 14px
}
.availability-btn:hover {
  background-color: #aa0808
}
.star {
  color: #ffc107;
  margin-right: 2px;
  font-size: 14px
}
.thumb-icon {
  color: #00c853;
  font-size: 14px;
  margin-left: 15px
}
.price-section {
  text-align: right;
  color: #333;
  line-height: 24px;
  margin-bottom: 25px
}
.nights-adults {
  font-size: 14px;
  color: #aaa
}
.hotels-price {
  font-size: 21px;
  font-weight: 700;
  color: #fff;
  text-align: right
}
.facility-box, .map-btn, .map-button {
  text-align: center
}
.hotels-price span.regular-price {
  font-size: 14px;
  color: red;
  text-decoration: line-through
}
.hotels-price span.theme-price {
  font-size: 14px;
  color: #aaa;
  display: block
}
.new-price i {
  font-size: 16px;
  color: #aaa;
  margin-left: 5px
}
.taxes {
  font-size: 12px;
  color: #aaa
}
#hotel-list .loading {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: none
}
.loader, .spinner {
  border: 8px solid #f3f3f3;
  border-radius: 50%;
  border-top: 8px solid #3498db;
  width: 50px;
  height: 50px;
  animation: 1s linear infinite spin
}
@keyframes spin {
  0% {
    transform: rotate(0)
  }
  100% {
    transform: rotate(360deg)
  }
}
#mapModal, .locationModal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, .5);
  z-index: 1000;
  align-items: center;
  justify-content: center;
  overflow: auto
}
#loader, .map-button {
  left: 50%;
  transform: translateX(-50%)
}
#mapModal > div {
  position: relative;
  width: 80%;
  height: 80%;
  background-color: #fff;
  margin: auto;
  border-radius: 10px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, .2);
  overflow: hidden
}
#mapModal > div > span, .location-modal-content .close-button {
  position: absolute;
  top: 10px;
  right: 20px;
  font-size: 24px;
  font-weight: 700;
  color: #333;
  cursor: pointer;
  z-index: 1001
}
#mapModal > div > span:hover, .location-modal-content .close-button:hover {
  color: #000
}
#mapIframe {
  width: 100%;
  height: 100%;
  border: none;
  border-radius: 5px
}
.facility-box, .facility-span {
  display: flex;
  color: #fff;
  border-radius: 8px;
  font-size: 14px
}
.facility-box {
  max-width: 100%;
  flex-direction: row;
  justify-content: flex-start;
  align-self: stretch;
  flex-grow: 1;
  align-items: center;
  min-width: 15%;
  flex: auto;
  align-items: center;
  padding: 5px 13px;
  background-color: #1f1f1f
}
#sort-options, .filter-box {
  max-width: 320px;
  width: 100%
}
.facility-box i, .facility-span i {
  font-size: 16px;
  margin-right: 10px;
  color: #c51a1b
}
.facility-box:hover {
  background-color: #333
}
.facilities-container, .facilities-container-ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 10px;
  padding: 15px 0
}
.facilities-container-ul {
  justify-content: flex-start
}
.facility-span {
  align-items: center;
  justify-content: space-between
}
.map-button, .room-box h3, .room-box h4 {
  color: var(--primary-color)
}
.hotel-sidebar, .map-button {
  display: flex;
  flex-direction: column;
  gap: 15px
}
.hotel-bnr, .hotel-map {
  background-color: #1a1e20;
  border-radius: 5px;
  margin-bottom: 10px;
  min-height: 1px;
  overflow: hidden;
  padding: 0;
  position: relative;
  width: 100%;
  line-height: 0
}
#show-more, .map-btn {
  background: var(--primary-color)
}
#loader, #show-more, .map-button, .room-img span {
  position: absolute
}
.hotel-map img {
  min-width: 100%;
  max-height: 336px
}
.hotel-bnr img {
  min-height: 336px
}
.map-button {
  bottom: 10px;
  line-height: 24px
}
.floating-btn, .location-modal-content, .slider-nav {
  transform: translateY(-50%)
}
.map-button i {
  font-size: 46px
}
.map-btn {
  display: inline-block;
  font-size: 14px;
  padding: 3px 20px;
  font-weight: 300;
  color: var(--white-color);
  position: relative;
  transition: .5s linear;
  overflow: hidden;
  z-index: 1;
  border-radius: 4px;
  margin: 0 auto
}
.hotel-brand, .hotel-highlight {
  background: #1f1f1f;
  padding: 10px
}
.display-hotels {
  padding-bottom: 60px;
  position: relative
}
.display-hotels h3, .end-of-list h3 {
  text-align: left
}
.end-of-list h3 {
  text-align: center
}
#loader {
  bottom: 0
}
.hotel-container {
  position: relative;
  padding: 0 0 60px
}
.hotel-content {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 10;
  overflow: hidden;
  transition: .5s ease-out;
  text-align: justify
}
.hotel-content ul {
  list-style: none;
  margin: 0;
  padding: 0;
  line-height: 1.5
}
.hotel-content ul li {
  padding: 0 0 0 25px;
  color: #fff;
  margin: 0;
  position: relative
}
.hotel-content.expanded {
  -webkit-line-clamp: unset
}
#show-more {
  padding: 3px 10px;
  color: #fff;
  border: none;
  cursor: pointer;
  bottom: 10px;
  border-radius: 3px
}
#filter-button:hover, #location-message-bar {
  background-color: #c51a1b
}
.aside-block, .hotel-highlight ul {
  flex-direction: column;
  display: flex
}
.hotel-brand {
  display: flex;
  color: #fff;
  border-radius: 3px;
  gap: 10px
}
.hotel-brand img {
  width: 120px
}
.hotel-highlight {
  color: #fff
}
.hotel-highlight ul {
  padding: 0;
  margin: 0;
  list-style: none;
  gap: 5px
}
.hotel-highlight ul li {
  list-style: none;
  padding: 0 0 0 25px;
  position: relative
}
.hotel-highlight ul li::before {
  content: "\f058";
  font-family: var(--font-awesome);
  font-weight: 900;
  color: var(--primary-color);
  position: absolute;
  left: 0;
  top: 0
}
.room-box {
  background: #1f1f1f;
  margin: 0 0 25px
}
.room-box h3 {
  font-size: 20px;
  font-weight: 600
}
.room-box h4 {
  font-size: 16px;
  padding: 5px 0 0;
  margin: 10px 0 0
}
.room-specs ul {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  margin: 10px 0;
  list-style: none
}
.room-specs ul li {
  font-size: var(--font-sm-size)
}
.room-desc {
  padding: 15px;
  color: #fff
}
.room-img span {
  padding: 10px 25px;
  color: #fff;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, .5);
  cursor: pointer
}
.sticky-aside, .swiper-aside {
  position: -webkit-sticky;
  position: sticky;
  top: 80px;
  z-index: 1;
  background: #fff;
  box-shadow: rgba(0, 0, 0, .1) 0 10px 24px;
  padding: 15px;
  margin-bottom: 25px;
  color: #000
}
.swiper-aside {
  top: 0
}
.aside-heading {
  border-bottom: 1px solid #ddd;
  padding: 15px 10px;
  margin: 0
}
.aside-block {
  min-height: 300px
}
#package-options, .aside-block form {
  display: flex;
  flex-direction: column;
  gap: 10px
}
.aside-block span {
  display: block;
  font-size: 14px;
  text-align: center;
  margin-top: 15px
}
.aside-block iframe {
  height: 320px;
  width: 100%;
  background: #f6f6f6;
  margin: 0 auto
}
.floating-btn {
  position: fixed;
  top: 50%;
  right: 0;
  background-color: #d81b1b;
  color: #fff;
  width: 40px;
  padding: 20px 10px;
  border-radius: 5px 0 0 5px;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  writing-mode: vertical-rl;
  text-orientation: upright
}
.book-now {
  text-decoration: none;
  font-size: 16px;
  letter-spacing: -3px;
  text-align: center;
  line-height: 1.5;
  display: block;
  color: #fff !important
}
.modal-btn, ul.acomo-specs li {
  font-size: var(--font-sm-size)
}
.modal-accomodation {
  background: 0 0;
  border: none;
  border-radius: 0
}
.modal-accomodation .modal-footer, .modal-accomodation .modal-header {
  border: none;
  padding: 10px 0
}
.modal-accomodation .modal-header span {
  margin-left: auto;
  cursor: pointer;
  color: #fff
}
.modal-accomodation .modal-header span i {
  color: red
}
.modal-accomodation .modal-body {
  background: #fff;
  border-radius: 0
}
.modal-accomodation .btn-close, .modal-accomodation .btn-close:hover {
  color: red !important
}
.modal-accomodation h1, .modal-accomodation h2, .modal-accomodation h3, .modal-accomodation h4, .modal-accomodation h5, .modal-accomodation h6, .modal-accomodation p, .modal-accomodation ul {
  color: #45443f
}
.modal-descp {
  margin-bottom: 10px
}
.modal-descp p {
  font-size: 15px
}
.modal-btn {
  text-decoration: underline;
  cursor: pointer
}
ul.acomo-specs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 10px 0;
  list-style: none
}
ul.acomo-specs li {
  min-width: 40%
}
#location-message-bar {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  color: #f8d7da;
  padding: 10px;
  text-align: center;
  z-index: 999;
  display: flex;
  flex-direction: row;
  align-content: center;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px
}
#close-location-message {
  background-color: #f5c6cb;
  padding: 5px 25px;
  border: none;
  color: #721c24;
  cursor: pointer;
  border-radius: 5px;
  box-shadow: rgba(100, 100, 111, .2) 0 7px 29px 0
}
#location-message-bar button {
  margin: 5px;
  padding: 6px 12px;
  border: none;
  border-radius: 4px;
  cursor: pointer
}
#allow-location-button {
  background-color: #00c853;
  color: #fff
}
.hotel-sort {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between
}
.filter-relative {
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 20px;
  justify-content: space-between;
  flex-wrap: wrap
}
#filter-button {
  padding: 10px 20px;
  background-color: #000;
  border-radius: 4px;
  color: #fff;
  border: none;
  cursor: pointer;
  font-size: 16px;
  display: flex;
  gap: 10px;
  align-items: center
}
.filter-box {
  padding: 20px;
  background-color: #000;
  box-shadow: 0 4px 8px rgba(0, 0, 0, .1);
  max-height: 400px;
  overflow-y: auto;
  position: absolute;
  top: calc(100% + 5px);
  left: 0;
  z-index: 1000;
  display: none;
  border-radius: 4px;
  scrollbar-width: thin;
  scrollbar-color: #888 #000
}
.assistance-popup.active, .custom-date-picker.active, .filter-box.show, .guest-dropdown.active, .popup-overlay.active {
  display: block
}
.filter-box::-webkit-scrollbar {
  width: 8px
}
.filter-box::-webkit-scrollbar-track {
  background: #000;
  border-radius: 10px
}
.filter-box::-webkit-scrollbar-thumb {
  background-color: #888;
  border-radius: 10px;
  border: 2px solid #c51a1b
}
.filter-box::-webkit-scrollbar-thumb:hover {
  background-color: #c51a1b
}
.filter-header {
  color: #fff;
  font-weight: 700;
  margin-bottom: 10px
}
.filter-section, .package-container {
  margin-bottom: 20px
}
.filter-section label {
  display: block;
  color: #fff;
  margin-bottom: 5px
}
.filter-checkboxes label {
  display: block;
  margin-bottom: 8px;
  color: #fff
}
.filter-checkboxes input[type=checkbox], .filter-checkboxes input[type=radio], .room-choice input[type=checkbox] {
  margin-right: 5px
}
.type-checkboxes {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 10px
}
.type-checkboxes label {
  display: inline-block;
  margin-right: 10px;
  border-radius: 5px;
  cursor: pointer;
  transition: background .3s
}
.type-checkboxes input[type=checkbox] + span, .type-checkboxes input[type=radio] + span {
  background: #000;
  color: #fff;
  padding: 10px 15px;
  border-radius: 4px
}
.type-checkboxes input[type=checkbox]:checked + span, .type-checkboxes input[type=radio]:checked + span {
  background: #c00;
  color: #fff
}
.type-checkboxes label:hover span {
  background: #444
}
.locationModal {
  display: none;
  position: fixed;
  z-index: 99;
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  height: 100vh;
  overflow: auto;
  background-color: rgba(0, 0, 0, .4);
  backdrop-filter: blur(5px)
}
.location-modal-header {
  font-size: 18px;
  font-weight: 700
}
.location-modal-content {
  background-color: #2c2c2c;
  margin: 0 auto;
  padding: 20px;
  border-radius: 8px;
  width: 90%;
  max-width: 500px;
  color: #fff;
  box-shadow: 0 4px 8px rgba(0, 0, 0, .2);
  text-align: left;
  position: relative;
  top: 50%
}
.location-modal-content h2 {
  margin-top: 0;
  font-size: 1.5em;
  font-weight: 700
}
.location-modal-content p {
  font-size: 1em;
  margin: 10px 0
}
.location-modal-footer {
  display: flex;
  flex-shrink: 0;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end
}
.agree-button, .cancel-button {
  background-color: #1e1e1e;
  color: #fff;
  border: none;
  padding: 5px 20px;
  border-radius: 5px;
  cursor: pointer
}
.agree-button {
  background-color: #d32f2f
}
.agree-button:hover, .cancel-button:hover {
  opacity: .9
}
.club-details {
  margin: 10px 0 15px;
  text-align: center
}
.club-details h4 {
  color: #fff;
  font-weight: 700;
  font-size: 18px;
  margin: 0
}
.available, .sold-out {
  background-color: transparent;
  padding: 0;
  font-size: 14px;
  text-align: center;
  display: inline-block;
  margin: 0;
  border-radius: 0
}
.available {
  color: #156418
}
#consent-banner a:hover, .sold-out {
  color: #f44336
}
.status {
  font-size: 14px;
  display: flex;
  align-items: center;
  gap: 5px;
  color: #fff
}
.theme-container {
  padding: 0;
  position: relative
}
.custom-slider-wrapper {
  display: flex;
  transition: transform .5s;
  will-change: transform
}
.custom-slide {
  flex: 0 0 25%;
  min-width: 180px;
  padding: 5px;
  scroll-snap-align: start;
  box-sizing: border-box
}
.custom-slide img {
  max-width: 100%;
  height: auto;
  margin-bottom: 10px
}
.slider-nav {
  position: absolute;
  top: 50%;
  width: 100%;
  display: flex;
  justify-content: space-between
}
.slider-pagination, .theme-type-full h2:after {
  transform: translateX(-50%);
  position: absolute;
  left: 50%
}
.slider-nav button {
  background: #5a5a5a75;
  border: none;
  padding: 10px;
  color: #fff;
  font-size: 20px;
  cursor: pointer;
  transition: .3s;
  z-index: 2;
  border-radius: 8px
}
.slider-nav button:hover {
  background: #a31515
}
.slider-pagination {
  display: flex;
  bottom: 10px;
  gap: 5px
}
.assistance-popup, .qr-overlay {
  transform: translate(-50%, -50%)
}
.slider-pagination span {
  display: inline-block;
  width: 10px;
  height: 10px;
  background: #ddd;
  border-radius: 50%;
  cursor: pointer;
  transition: .3s
}
.theme-type-full, .theme-type-full input[type=radio]:checked + img {
  border-radius: 8px
}
.slider-pagination span.active {
  background: #c51a1b
}
.theme-type-full {
  background: rgba(76, 76, 76, .22);
  padding: 10px;
  box-shadow: inset 1px -2px 60px 4px rgb(0 0 0 / 100%), inset 1px -1px 36px -18px rgb(0 0 0 / 64%);
  transition: .3s;
  cursor: pointer;
  text-align: center
}
.collapsible-icon, .theme-package {
  transition: transform .3s
}
.theme-type-full img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
  aspect-ratio: 1.33/1;
  transition: .3s
}
.theme-type-full h2 {
  font-size: 18px;
  font-weight: 700;
  position: relative;
  margin-bottom: 0;
  padding: 10px;
  text-align: center;
  color: #fff;
  transition: color .3s
}
.theme-type-full h2:after {
  background: linear-gradient(90deg, #11131400 0, #c51a1b 40%, #771718 80%, #11131400);
  height: 2px;
  width: 50%;
  content: ' ';
  bottom: -10px;
  transition: .3s
}
.theme-package input[type=radio]:checked + img + h4, .theme-type-full input[type=radio]:checked ~ h2, .theme-type-full:hover h2 {
  color: #c51a1b
}
.theme-type-full input[type=radio]:checked ~ h2:after, .theme-type-full:hover h2:after {
  width: 80%;
  height: 4px
}
.theme-type-full:has(input:checked), .theme-type-full:hover {
  background: rgba(0, 0, 0, .3);
  border: 3px solid rgba(255, 0, 0, .8);
  transform: scale(1.01)
}
.logo-slider .swiper-slide {
  background: #000;
  border-radius: 3px;
  overflow: hidden;
  text-align: center;
  color: #fff
}
.logo-slider .swiper-slide img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
  aspect-ratio: 1.33/1
}
.logo-slider .swiper-slide span {
  display: block;
  text-align: center;
  font-weight: 700;
  margin-top: 10px;
  color: #fff
}
.theme-package {
  width: 100%;
  background-color: #1e1e1e;
  border-radius: 10px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, .5);
  overflow: hidden;
  text-align: center;
  margin-bottom: 15px;
  position: relative;
  display: inline-block;
  cursor: pointer
}
.theme-package:hover {
  transform: translateY(-5px);
  box-shadow: 0 0 15px rgba(255, 0, 0, .7);
  transition: transform .3s, box-shadow .3s
}
.theme-package img {
  width: 100%;
  height: auto;
  border-bottom: 3px solid #b41a1b;
  transition: .3s
}
.package-item-enhanced h3, .theme-package h4 {
  font-size: 1.5em;
  font-weight: 700;
  margin: 15px 0;
  color: #f1f1f1;
  text-transform: uppercase;
  letter-spacing: 1px
}
.package-item-description p, .theme-package span {
  display: block;
  margin-top: 20px;
  font-size: 1.4em;
  font-weight: 700;
  color: var(--primary-color);
  margin-bottom: 15px
}
.theme-package:after {
  width: 50%;
  height: 2px;
  background: linear-gradient(90deg, #11131400 0, #c51a1b 40%, #771718 80%, #11131400);
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  transition: .3s
}
.theme-package .price {
  font-size: 1.5em;
  color: var(--primary-color)
}
.theme-package:has(input[type=radio]:checked), .theme-package:hover {
  transform: translateY(-2px);
  box-shadow: 0 0 10px rgba(255, 0, 0, .8);
  transition: transform .3s, box-shadow .3s
}
.webstory-details:after, .webstory-img:after {
  content: ' ';
  transform: translateX(-50%);
  position: absolute
}
.theme-package:has(input[type=radio]:checked):after, .theme-package:hover:after {
  width: 80%;
  height: 4px
}
.theme-package .btn {
  background-color: var(--primary-color);
  color: #fff;
  padding: 12px 25px;
  border-radius: 30px;
  text-decoration: none;
  display: inline-block;
  margin-top: 15px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  transition: background-color .3s
}
.content-description h3, .custom-booking-section h3, .details-section h4, .post-navigation a, .ticket-footer .btn, .ticket-header h3 {
  font-weight: var(--font-bold)
}
.event-itinerary {
    margin-bottom: 30px;
}

.itinerary-day {
    margin-bottom: 20px;
}

.itinerary-header {
    font-size: 16px;
    font-weight: bold;
    text-transform: uppercase;
    margin-bottom: 15px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.3);
    padding-bottom: 5px;
}

.itinerary-header span {
    margin-right: 5px;
}

.itinerary-details {
    font-size: 0.95em;
    line-height: 1.6;
}

.itinerary-details p {
    margin: 5px 0;
}

.itinerary-details h4 {
    font-size: 1.2em;
    font-weight: bold;
    text-transform: uppercase;
    margin: 15px 0 10px;
    color: #fff;
}

.itinerary-details strong {
    font-weight: bold;
    color: #fff;
}
.cart-table tbody tr, .ticket-footer .btn {
  transition: background .3s
}
.cart-header {
  font-size: 1.5rem;
  font-weight: 700;
  margin-bottom: 15px;
  color: #fff
}
.cart-table {
  width: 100%;
  border-collapse: collapse;
  background: #1e1e1e;
  border: 1px solid #333;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 2px 5px rgba(0, 0, 0, .5)
}
.status-box .status, .status-box .unknown div {
  border-radius: 3px;
  padding: 10px
}
.cart-table thead {
  background-color: #333;
  color: #fff;
  text-align: left
}
.cart-table thead th {
  padding: 12px 15px;
  font-size: 14px;
  font-weight: 600;
  text-transform: uppercase
}
.cart-table tbody tr:nth-child(2n) {
  background-color: #242424
}
.cart-table tbody tr:hover {
  background-color: #2e2e2e
}
.cart-table tbody td {
  padding: 12px 15px;
  font-size: 14px;
  color: #e0e0e0
}
.grand-total-row {
  background-color: #4caf50;
  color: #fff;
  font-weight: 700
}
.grand-total-row td {
  padding: 12px 15px
}
.btn-toast-close {
  position: absolute;
  top: 10px;
  right: 10px
}
.status-box {
  width: 100%;
  line-height: 1.4;
  color: #fff
}
.status-box .status {
  font-size: 14px;
  margin: 10px 0
}
.status-box .waiting, .status-waiting {
  background-color: #444
}
.status-waiting {
  font-size: 18px;
  color: #fff;
  text-align: center
}
.status-box .confirmed {
  background-color: #3f8c31
}
.status-box .rejected {
  background-color: #c62c27
}
.status-box .unknown {
  padding: 10px;
  display: flex;
  flex-direction: column;
  gap: 15px;
  align-items: stretch;
  background: #1a1e20
}
.status-box .unknown div:last-child {
  background: #771718;
  padding: 10px;
  border-radius: 3px
}
.status-box .unknown div span {
  min-width: 120px;
  display: inline-flex
}
.status-box .no-registration {
  background-color: #e2e3e5;
  color: #383d41
}
.error {
  background-color: #f8d7da;
  color: #721c24
}
.event_reg_form {
  background: #1a1e20;
  padding: 10px;
  margin-bottom: 15px;
  text-align: right
}
.select-box select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-color: #1a1e20;
  color: #fff;
  border: 1px solid #444;
  border-radius: 4px;
  padding: 5px 40px 5px 10px;
  font-size: 14px;
  font-family: Arial, sans-serif;
  cursor: pointer;
  outline: 0;
  width: 100%;
  box-sizing: border-box;
  position: relative;
  background-image: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 16 16"%3E%3Cpath fill="%23fff" d="M5 6l3 3 3-3H5z"/%3E%3C/svg%3E');
  background-repeat: no-repeat;
  background-position: right 10px center
}
.select-box .register-button {
  padding: 3px 20px;
  background: var(--primary-color);
  color: #fff;
  border-radius: 3px
}
.select-box select:hover {
  border-color: #666
}
.select-box select:focus {
  border-color: var(--primary-color);
  box-shadow: 0 0 5px rgba(0, 123, 255, .5)
}
.collapsible-container {
  background-color: transparent;
  color: #868889;
  border-top: 1px solid #444;
  border-bottom: 1px solid #444;
  margin: 10px 0;
  font-family: Arial, sans-serif;
  overflow: hidden
}
.ticket, .ticket-qr {
  background: var(--secondary-color)
}
.content-description h3, .profile_blog_content, .registration-container, .ticket {
  font-family: var(--primary-font)
}
.collapsible-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 5px;
  cursor: pointer;
  font-size: 14px
}
.qr-text, .ticket-footer .btn {
  font-size: var(--font-sm-size)
}
.collapsible-container.active .collapsible-icon {
  transform: rotate(90deg)
}
.collapsible-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height .3s, padding .3s;
  padding: 0
}
.collapsible-container.active .collapsible-content {
  max-height: 190px
}
.collapsible-content textarea {
  width: 100%;
  padding: 10px;
  border: 1px solid #515455;
  border-radius: 5px;
  background-color: transparent;
  color: #515455;
  font-size: 14px;
  line-height: 1.5;
  height: 100px;
  resize: none;
  outline: 0
}
.collapsible-content textarea::placeholder {
  color: #777
}
.ticket {
  border-radius: var(--bdr-10-radius);
  margin: 0 0 20px auto;
  padding: 20px;
  color: var(--text-color);
  box-shadow: 0 4px 8px rgba(0, 0, 0, .4)
}
.ticket-header {
  padding: 0 0 15px;
  margin-bottom: 20px;
  border-bottom: 1px solid #35383a
}
.ticket-header h3 {
  font-size: 20px;
  color: var(--primary-color);
  margin: 0
}
.ticket-header span {
  font-size: 16px;
  color: var(--secondary-t-color)
}
.qr-text, .registration-container, .ticket-details p {
  color: var(--text-color)
}
.ticket-body {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: wrap;
  gap: 20px
}
.ticket-qr {
  flex: 0 0 30%;
  max-width: 30%;
  text-align: center;
  padding: 15px;
  border: 1px solid #35383a;
  border-radius: 5px
}
.qr-text {
  margin: 10px 0 0
}
.ticket-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding-left: 20px
}
.ticket-details p {
  font-size: var(--font-size);
  margin: 8px 0;
  line-height: var(--line-height)
}
.ticket-footer {
  padding-top: 10px;
  margin-top: 10px;
  border-top: 1px solid #35383a
}
.ticket-footer .btn {
  display: inline-block;
  padding: 10px 20px;
  background: var(--primary-color);
  color: var(--white-color);
  text-decoration: none;
  border-radius: 5px
}
.ticket-footer .btn:hover {
  background: #a50b0c
}
.ticket-footer .btn:active {
  background: var(--primary-t-color);
  transform: translateY(0)
}
.registration-container {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin-bottom: 20px
}
.registration-section {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 20px;
  background: #1a1e20 !important;
  border-radius: 5px;
  padding: 15px
}
.qr-and-details {
  display: flex;
  gap: 20px
}
.qr-section {
  flex: 0 0 30%;
  text-align: center
}
.qr-image {
  border-radius: 5px;
  box-shadow: 0 4px 6px rgba(0, 0, 0, .2);
  width: 100%;
  height: auto;
  padding: 10px;
  background: #fff;
  border: 2px solid var(--primary-color);
  border-radius: var(--bdr-10-radius);
  box-shadow: 0 4px 8px rgba(0, 0, 0, .3)
}
.qr-text {
  margin-top: 8px;
  font-style: italic
}
.details-section {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 10px
}
.details-section h4 {
  font-size: var(--font-size);
  color: var(--primary-color);
  margin: 0 0 10px;
  text-transform: uppercase
}
.details-section p {
  font-size: var(--font-sm-size);
  margin: 0;
  color: var(--text-color);
  line-height: var(--line-height)
}
.calendar-container {
  position: absolute;
  top: 40px;
  left: 0;
  background: #1e1e1e;
  border: 1px solid #444;
  border-radius: 5px;
  padding: 10px;
  width: 300px;
  box-shadow: 0 2px 5px rgba(0, 0, 0, .5);
  z-index: 1000;
  text-align: center;
  color: #f1f1f1
}
.calendar-header, .date-picker-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px
}
.nav-btn {
  background: 0 0;
  border: none;
  color: #f1f1f1;
  font-size: 20px;
  cursor: pointer;
  margin: 0 10px
}
.month-year-container {
  display: flex;
  align-items: center;
  gap: 5px
}
.calendar-dates, .calendar-days {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 5px
}
.month-year-container select {
  background: #333;
  color: #fff;
  border: 1px solid #555;
  padding: 5px !important;
  font-size: 14px;
  border-radius: 5px
}
.calendar-days {
  font-size: 14px;
  color: #ccc
}
.calendar-dates button, .calendar-days span {
  text-align: center;
  padding: 5px;
  font-size: 14px
}
.calendar-dates button, .calendar-dates span {
  background: 0 0;
  border: 1px solid transparent;
  border-radius: 3px;
  cursor: pointer;
  color: #f1f1f1
}
.calendar-dates button:hover, .calendar-dates span:hover {
  background: #444;
  color: #f1f1f1
}
.calendar-dates button.selected, .calendar-dates span.selected {
  background: var(--primary-color);
  color: #fff !important
}
.calendar-dates button.disabled, .calendar-dates span.disabled {
  color: #555;
  cursor: not-allowed
}
.time-container {
  position: absolute;
  background: #1e1e1e;
  border: 1px solid #3e3e3e;
  border-radius: 8px;
  padding: 0;
  z-index: 1000;
  color: #e0e0e0;
  box-shadow: 0 4px 8px rgba(0, 0, 0, .4);
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center
}
.time-container select, .toggle-period {
  font-size: 16px;
  background: #2e2e2e;
  color: #e0e0e0
}
.room-list, .webstory {
  flex-direction: column
}
.time-container select {
  margin: 10px 5px;
  padding: 10px;
  border: 1px solid #555;
  border-radius: 6px;
  box-shadow: inset 0 2px 4px rgba(0, 0, 0, .3)
}
.toggle-period {
  margin: 10px;
  padding: 10px 15px;
  cursor: pointer;
  display: inline-block;
  border-radius: 6px;
  text-align: center;
  border: 1px solid #555;
  box-shadow: 0 2px 4px rgba(0, 0, 0, .4);
  transition: background .3s, box-shadow .3s
}
.toggle-period:hover {
  background: #3e3e3e;
  box-shadow: 0 4px 8px rgba(0, 0, 0, .6)
}
.time-container select:focus, .toggle-period:focus {
  outline: 0;
  border: 1px solid #777;
  box-shadow: 0 0 4px rgba(255, 255, 255, .8)
}
.webstory {
  display: flex;
  background: #1b1d1e;
  border-radius: 15px;
  overflow: hidden;
  transition: .3s
}
.webstory-details {
  display: block;
  text-align: center;
  padding: 15px;
  position: relative
}
.webstory-details:after {
  background: var(--primary-color);

  height: 3px;
  width: 50%;
  bottom: 0;
  left: 50%;
  transition: .3s
}
.webstory-img {
  display: block;
  position: relative
}
.webstory-img:before {
  width: 100%;
  height: 100%;
  position: absolute;
  content: ' ';
  top: 0;
  left: 0;
  background: url("../img/webstory.png") rgba(0, 0, 0, .3);
  background-size: 60px;
  background-position: center 80%;
  background-repeat: no-repeat;
  transition: .3s
}
.webstory:hover .webstory-img:before {
  background: url("../img/webstory.png") rgba(0, 0, 0, .6);
  background-size: 60px;
  background-position: center 80%;
  background-repeat: no-repeat
}
.webstory-img:after {
  width: 60%;
  height: 1px;
  bottom: 20px;
  left: 50%;
  border-bottom: 5px dashed rgba(255, 255, 255, .8)
}
.webstory-title {
  color: #bfbfbf;
  font-size: 17px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  padding: 0 10px;
  display: block
}
.webstory-details .story-details {
  color: #fff;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
  padding: 0;
  margin: 0
}
#consent-banner {
  position: fixed;
  bottom: 20px;
  left: 20px;
  width: 90%;
  max-width: 500px;
  background-color: #1a1a1a;
  color: #d4d4d4;
  padding: 20px;
  text-align: center;
  z-index: 1000;
  border-radius: 10px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, .4);
  display: none;
  box-sizing: border-box;
  animation: .4s ease-out slideUpMinimal;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol"
}
@keyframes slideUpMinimal {
  from {
    opacity: 0;
    transform: translateY(50px)
  }
  to {
    opacity: 1;
    transform: translateY(0)
  }
}
#consent-banner p {
  margin: 0 0 15px;
  font-size: .95rem;
  line-height: 1.4;
  font-weight: 400
}
#consent-banner button {
  background-color: #00c853;
  color: #fff;
  padding: 10px 20px;
  border: none;
  cursor: pointer;
  margin: 0 8px;
  border-radius: 8px;
  font-weight: 500;
  text-transform: none;
  letter-spacing: 0;
  transition: background-color .2s, transform .2s, box-shadow .2s
}
#consent-banner button.reject {
  background-color: #f44336
}
#consent-banner button:hover {
  background-color: #00993f;
  transform: scale(1.03);
  box-shadow: 0 3px 10px rgba(0, 0, 0, .25)
}
#consent-banner button:active {
  transform: scale(1);
  box-shadow: none
}
#consent-banner a {
  color: #00bcd4;
  text-decoration: underline dotted;
  font-weight: 500;
  transition: color .2s
}
.blog_profile__area {
  padding: 80px 0;
  background: linear-gradient(135deg, var(--secondary-color) 0, var(--secondary-lt-color) 70%, var(--accent-color) 100%);
  position: relative;
  overflow: hidden
}
.blog_profile__area::after {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: radial-gradient(circle, rgba(255, 255, 255, .1) 0, transparent 70%);
  animation: 15s ease-in-out infinite pulse
}
.profile_content {
  border-radius: var(--bdr-20-radius);
  overflow: hidden;
  box-shadow: 0 15px 35px rgba(0, 0, 0, .4), inset 0 0 10px rgba(255, 255, 255, .1);
  background: rgba(255, 255, 255, .05);
  backdrop-filter: blur(5px)
}
.profile_blog {
  position: relative;
  background-size: cover;
  background-position: center;
  transition: transform .5s
}
.profile_blog::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to bottom, rgba(0, 0, 0, .7), rgba(0, 0, 0, .3));
  z-index: 1;
  transition: opacity .3s
}
.profile_blog:hover::before {
  opacity: .8
}
.profile_blog_content {
  position: relative;
  z-index: 2;
  color: var(--white-color);
  padding: 10px;
  animation: .8s ease-out slideIn;
    width:100%;
}
.profile_text h1 {
  font-size: var(--font-lg-size);
  text-shadow: 3px 3px 6px rgba(0, 0, 0, .6), 0 0 20px rgba(255, 255, 255, .2);
  margin-bottom: 5px;
  color: var(--heading-color);
  letter-spacing: 1px;
  background: linear-gradient(to right, var(--heading-color), var(--accent-color));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent
}
.blog-meta span, .profile_text .meta-info {
  color: var(--tp-text-body);
  font-size: var(--font-size)
}
.profile_text h1::selection {
  background: var(--primary-color);
  -webkit-text-fill-color: var(--white-color);
  color: var(--white-color)
}
.profile_text .meta-info {
  font-family: var(--secondary-font);
  padding: 8px 15px;
  background: rgba(255, 255, 255, .1);
  border-radius: var(--bdr-10-radius);
  display: inline-block
}
.blog-meta .views, .date-picker-date.selected {
  color: var(--white-color)
}
.img-pic {
    width: 100%;    
}
.img-pic img {
    width: 100%;
  border-radius: var(--bdr-10-radius);
  transition: .4s;
  filter: brightness(1.1) contrast(1.05)
}
.blog-card, .blog-meta, .gallery-images img {
  border-radius: var(--bdr-10-radius)
}
.postbox__area {
  padding: 60px 0;
  position: relative;
  z-index: 1
}
.blog-card {
  background: var(--card-background);
  padding: 35px;
  box-shadow: 0 8px 25px rgba(0, 0, 0, .25);
  margin-bottom: 35px;
  transition: transform .3s, box-shadow .3s;
  position: relative;
  overflow: hidden
}
.blog-meta {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  background: var(--secondary-lt-color);
  padding: 15px 20px;
  margin-bottom: 25px;
  box-shadow: inset 0 2px 5px rgba(0, 0, 0, .1)
}
.post-navigation, .post-navigation a {
  display: flex;
  border-radius: var(--bdr-5-radius);
  position: relative
}
.gallery-images img, .post-navigation {
  box-shadow: 0 5px 15px rgba(0, 0, 0, .2)
}
.blog-meta span {
  padding: 5px 10px;
  transition: color .3s
}
.blog-meta .views {
  background: var(--accent-color);
  padding: 8px 18px;
  border-radius: var(--bdr-20-radius);
  box-shadow: 0 3px 10px rgba(0, 0, 0, .2);
  transition: transform .3s
}
.blog-gallery::before, .post-navigation::before {
  content: '';
  position: absolute;
  top: 0;
  height: 100%;
  background: linear-gradient(45deg, rgba(255, 255, 255, .1), transparent);
  z-index: 0;
  width: 100%;
  left: 0
}
.content-description h3 {
  color: var(--heading-color);
  font-size: var(--font-size);
  position: relative
}
.date-input, .post-navigation a {
  font-family: var(--secondary-font)
}
.post-navigation {
  justify-content: space-between;
  padding: 15px;
  margin-top: 25px;
  background: var(--secondary-color);
  overflow: hidden
}
.post-navigation::before {
  opacity: .5
}
.post-navigation a {
  align-items: center;
  gap: 12px;
  color: var(--primary-color);
  z-index: 1;
  padding: 10px 15px;
  transition: .3s
}
.post-navigation a:hover {
  color: var(--primary-color);
  text-decoration: none;
  background: rgba(255, 255, 255, .1)
}
.blog-gallery {
  margin: 40px 0;
  padding: 20px;
  background: rgba(255, 255, 255, .05);
  border-radius: var(--bdr-20-radius);
  box-shadow: 0 5px 20px rgba(0, 0, 0, .15);
  overflow: hidden;
  position: relative
}
.blog-gallery::before {
  opacity: .3;
  pointer-events: none
}
.gallery-images {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 20px;
  position: relative;
  z-index: 1
}
.gallery-images img {
  width: 100%;
  height: auto;
  object-fit: cover;
  border: 3px solid var(--white-color);
  transition: .4s;
  animation: .6s ease-out forwards fadeIn;
  opacity: 0;
  cursor: pointer
}
@media (max-width:768px) {
  .social-sharing {
    gap: 10px
  }
  .social-sharing a, .social-sharing button.copy-link-btn {
    width: 35px;
    height: 35px;
    font-size: 1.2em
  }
  .filter-relative {
    flex-direction: column;
    align-items: stretch;
    gap: 10px
  }
  #filter-button {
    width: 100%;
    justify-content: center
  }
  .filter-box {
    position: static;
    margin-top: 10px
  }
  .hotel-sort {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px
  }
  .ticket-body {
    flex-direction: column;
    text-align: center
  }
  .ticket-qr {
    width: 100%;
    max-width: none
  }
  .ticket-content {
    padding-left: 0
  }
  .registration-section {
    flex-direction: column;
    align-items: center
  }
  .qr-section {
    flex: 0 0 auto;
    width: 100%;
    max-width: 300px
  }
  .details-section {
    text-align: center
  }
  .gallery-images {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 15px
  }
  .gallery-images img {
    max-height: 250px
  }
  .blog-gallery {
    padding: 15px;
    margin: 30px 0
  }
}
@media (max-width:480px) {
  .registration-container, .ticket {
    padding: 15px
  }
  .ticket-header h3 {
    font-size: var(--font-size)
  }
  .ticket-footer .btn {
    padding: 8px 15px;
    font-size: var(--font-sm-size)
  }
  .registration-section {
    padding: 10px
  }
  .details-section h4 {
    font-size: var(--font-sm-size)
  }
  .gallery-images {
    grid-template-columns: 1fr;
    gap: 10px
  }
}
@keyframes fadeIn {
  0% {
    opacity: 0;
    transform: translateY(20px)
  }
  100% {
    opacity: 1;
    transform: translateY(0)
  }
}
.blog-card .blog-gallery {
  background: var(--card-background);
  box-shadow: none
}
.blog-gallery + .content-description {
  margin-top: 30px
}
.custom-booking-section {
  background: var(--card-background);
  border-radius: var(--bdr-10-radius);
  padding: 20px;
  margin: 20px 0;
  box-shadow: 0 4px 15px rgba(0, 0, 0, .3);
  border: 1px solid var(--border-color)
}
.guest-option, .pets-toggle, .room-name {
  margin-bottom: 10px
}
.custom-booking-section h3 {
  color: var(--heading-color);
  font-family: var(--primary-font);
  font-size: var(--font-lg-size);
  margin-bottom: 15px
}
.date-selection, .guest-selection {
  position: relative;
  flex: 1
}
.date-input-container {
  display: flex;
  background: var(--secondary-color);
  border: 1px solid var(--border-color);
  border-radius: var(--bdr-5-radius);
  padding: 10px
}
.date-input, .date-picker-header button {
  background: 0 0;
  color: var(--text-color);
  font-size: var(--font-size);
  cursor: pointer
}
.date-input {
  flex: 1;
  border: none;
  padding: 5px
}
.guest-input, .guest-option {
  justify-content: space-between
}
.date-separator {
  color: var(--text-color);
  padding: 0 10px;
  align-self: center
}
.custom-date-picker, .guest-dropdown {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--card-background);
  border: 1px solid var(--border-color);
  border-radius: var(--bdr-5-radius);
  padding: 15px;
  z-index: 1000;
  box-shadow: 0 4px 15px rgba(0, 0, 0, .3)
}
.date-picker-header button {
  border: none
}
.date-picker-date:hover, .guest-counter button {
  background: var(--secondary-lt-color)
}
.date-picker-header button:hover {
  color: var(--accent-color)
}
.date-picker-month {
  color: var(--heading-color);
  font-family: var(--primary-font);
  font-size: var(--font-size);
  font-weight: var(--font-med)
}
.booking-summary h5, .guest-input, .guest-option label, .pets-toggle {
  font-family: var(--secondary-font)
}
.date-picker-body {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 5px;
  text-align: center
}
.guest-input, .guest-option, .pets-toggle {
  display: flex;
  color: var(--text-color)
}
.date-picker-day {
  color: var(--text-color);
  font-size: var(--font-sm-size);
  padding: 5px
}
.guest-counter button, .guest-counter span, .guest-input, .guest-option label, .pets-toggle {
  font-size: var(--font-size)
}
.date-picker-date {
  padding: 5px;
  color: var(--text-color);
  cursor: pointer;
  border-radius: var(--bdr-5-radius)
}
.date-picker-date.selected, .guest-counter button:hover {
  background: var(--accent-color)
}
.date-picker-date.in-range {
  background: #c44d4d;
  color: var(--white-color)
}
.date-picker-date.disabled {
  color: var(--grey-color);
  cursor: not-allowed
}
.guest-input {
  background: var(--secondary-color);
  border: 1px solid var(--border-color);
  border-radius: var(--bdr-5-radius);
  padding: 10px;
  cursor: pointer;
  align-items: center
}
.guest-input i {
  color: var(--text-color)
}
.guest-option {
  align-items: center
}
.guest-counter button {
  border: none;
  color: var(--text-color);
  width: 30px;
  height: 30px;
  border-radius: var(--bdr-5-radius);
  cursor: pointer
}
.guest-counter span {
  color: var(--text-color)
}
.guest-info a, .guest-info p {
  font-size: var(--font-sm-size)
}
.guest-info p {
  color: var(--text-color);
  margin: 5px 0
}
.guest-info a {
  color: var(--accent-color);
  text-decoration: none
}
.pets-toggle {
  justify-content: space-between;
  align-items: center
}
.toggle-switch {
  position: relative;
  display: inline-block;
  width: 40px;
  height: 20px
}
.toggle-switch input {
  opacity: 0;
  width: 0;
  height: 0
}
.toggle-slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: var(--grey-color);
  border-radius: 20px;
  transition: .4s
}
.toggle-slider:before {
  position: absolute;
  content: "";
  height: 16px;
  width: 16px;
  left: 2px;
  bottom: 2px;
  background-color: var(--white-color);
  border-radius: 50%;
  transition: .4s
}
.custom-booking-form .tp-btn, .done-button {
  background: var(--accent-color);
  color: var(--white-color);
  font-family: var(--primary-font);
  font-size: var(--font-size);
  cursor: pointer
}
.toggle-switch input:checked + .toggle-slider {
  background-color: var(--accent-color)
}
.toggle-switch input:checked + .toggle-slider:before {
  transform: translateX(20px)
}
.toggle-switch input:focus + .toggle-slider {
  box-shadow: 0 0 5px var(--accent-color)
}
.done-button {
  border: none;
  padding: 8px 15px;
  border-radius: var(--bdr-5-radius);
  width: 100%;
  margin-top: 10px
}
.custom-booking-form .tp-btn {
  border: none;
  padding: 12px;
  border-radius: var(--bdr-5-radius);
  font-weight: var(--font-sbold);
  transition: .3s;
  flex: 0 0 auto
}
#availability-result, #package-selection, #price-breakdown {
  background: var(--secondary-color);
  border-radius: var(--bdr-5-radius)
}
.custom-booking-form .tp-btn:hover {
  background: var(--primary-color);
  box-shadow: 0 5px 15px rgba(197, 26, 27, .3)
}
#availability-result, #package-selection {
  margin-top: 15px;
  padding: 10px;
  color: var(--text-color)
}
#package-selection h4, #payment-details h4 {
  color: var(--heading-color);
  font-size: var(--font-lg-size);
  margin-bottom: 10px
}
.booking-summary {
  padding: 48px 30px 38px;
  background: var(--secondary-color);
  position: relative;
  overflow: hidden;
  color: var(--text-color)
}
#payment-details h4::after, #payment-details::before, .booking-summary::before, .payment-btn {
  background: var(--primary-color)
}
.booking-summary::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 10px
}
.booking-summary h5 {
  color: var(--font-color);
  margin-top: 0;
  font-weight: 400;
  line-height: 1.2;
  margin-bottom: 20px;
  letter-spacing: 1px;
  position: relative;
  padding-bottom: 8px
}
#price-breakdown .price-item, .booking-summary .price-breakdown .price-item, .booking-summary p {
  color: var(--white-color);
  font-family: var(--secondary-font);
  transition: color .3s;
  font-size: var(--font-size);
  display: flex
}
#payment-details h4, #price-breakdown .price-total, .highlight strong, .room-price .price, .summary-section h3 {
  font-weight: var(--font-bold)
}
.highlight, .popup-content p, .qr-instructions, .summary-section {
  line-height: var(--line-height)
}
.booking-summary p {
  margin-bottom: 12px;
  justify-content: space-between;
  align-items: flex-start
}
#payment-details h4, .highlight, .payment-btn, .popup-content h4, .qr-title, .summary-section {
  font-family: var(--primary-font)
}
.booking-summary p strong {
  color: var(--secondary-t-color);
  font-weight: var(--font-med);
  flex: 0 0 40%
}
#payment-details {
  padding: 30px;
  background: var(--card-background);
  position: relative;
  overflow: hidden;
  color: var(--text-color)
}
#payment-details::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 6px;
  border-top-left-radius: var(--bdr-10-radius);
  border-top-right-radius: var(--bdr-10-radius)
}
#payment-details h4 {
  color: var(--primary-color);
  font-size: var(--font-lg-size);
  margin-bottom: 20px;
  text-transform: uppercase;
  letter-spacing: 1px;
  position: relative;
  padding-bottom: 8px
}
#payment-details h4::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 40px;
  height: 2px
}
#price-breakdown {
  margin-top: 15px;
  margin-bottom: 20px;
  padding: 15px;
  border: 1px solid rgba(48, 52, 54, .5);
  transition: border-color .3s, background .3s
}
#price-breakdown .price-item, .booking-summary .price-breakdown .price-item {
  justify-content: space-between;
  align-items: center;
  margin-bottom: 15px;
  padding: 8px 0;
  border-bottom: 1px dashed rgba(255, 255, 255, .1)
}
#price-breakdown .price-item:hover, .booking-summary .price-breakdown .price-item:hover {
  color: var(--primary-lt-color)
}
#price-breakdown .price-item .label, .booking-summary .price-breakdown .price-item .label {
  font-weight: var(--font-med);
  color: var(--secondary-t-color);
  flex: 0 0 40%
}
#price-breakdown .price-item .value, .booking-summary .price-breakdown .price-item .value {
  font-weight: var(--font-sbold);
  color: var(--white-color);
  text-align: right
}
#price-breakdown .price-total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: var(--white-color);
  font-size: var(--font-size)
}
#price-breakdown .price-total .label, .booking-summary .price-breakdown .price-total .label, .form-check-label {
  color: var(--white-color);
  flex: 0 0 40%
}
#price-breakdown .price-total .value, .booking-summary .price-breakdown .price-total .value {
  font-weight: var(--font-xbold)
}
.payment-btn {
  display: inline-block;
  padding: 10px 45px 10px 25px;
  color: var(--white-color);
  font-size: var(--font-size);
  font-weight: var(--font-sbold);
  text-align: center;
  text-transform: uppercase;
  border: none;
  border-radius: var(--bdr-5-radius);
  cursor: pointer;
  transition: background .3s, transform .2s;
  position: relative;
  overflow: hidden
}
.payment-btn::after {
  content: "➔";
  position: absolute;
  right: 15px;
  font-size: 18px;
  opacity: 0;
  transition: opacity .3s, right .3s
}
.payment-btn:hover::after {
  opacity: 1;
  right: 10px
}
.booking-summary .price-breakdown {
  margin-top: 15px;
  margin-bottom: 20px;
  padding: 15px;
  background: rgba(48, 52, 54, .7);
  border-radius: var(--bdr-5-radius);
  border: 1px solid rgba(48, 52, 54, .5);
  transition: border-color .3s, background .3s
}
.booking-summary .price-breakdown .price-total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: var(--white-color);
  font-size: 22px;
  font-weight: var(--font-bold)
}
.booking-summary small {
  color: var(--secondary-t-color);
  font-size: var(--font-sm-size);
  font-style: italic;
  display: block;
  margin-top: 15px;
  text-align: center
}
.assistance-popup {
  display: none;
  position: fixed;
  top: 50%;
  left: 50%;
  background: var(--white-color);
  border-radius: var(--bdr-10-radius);
  padding: 20px;
  z-index: 1000;
  width: 90%;
  max-width: 400px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, .3)
}
.popup-content img {
  width: 100%;
  max-width: 150px;
  margin: 0 auto;
  display: block
}
.popup-content h4 {
  font-size: var(--font-lg-size);
  color: var(--font-sec-color);
  margin: 15px 0;
  text-align: center
}
.close-popup, .popup-content p, .room-price .price {
  font-size: var(--font-size)
}
.popup-content p {
  font-family: var(--secondary-font);
  color: var(--font-lt-color);
  text-align: center
}
.close-popup {
  position: absolute;
  top: -10px;
  right: -10px;
  background: var(--accent-color);
  color: var(--white-color);
  border: none;
  border-radius: 50%;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer
}
.popup-overlay {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, .5);
  z-index: 999
}
.package-item-enhanced, .room-item {
  background-color: var(--card-background)
}
.room-list {
  display: flex;
  gap: 20px
}
.room-item {
  display: flex;
  flex-direction: column;
  padding: 20px;
  border: 1px solid var(--border-color);
  border-radius: var(--bdr-10-radius);
  color: var(--text-color)
}
@media (min-width:768px) {
  .room-item {
    flex-direction: row;
    align-items: flex-start
  }
}
/* Hide all room items except the active one when a room is selected */
.room-list.room-selected .room-item:not(.active) {
    display: none;
}

/* Style the Edit button */
.edit-room {
    margin-left: 10px;
}
.room-details {
  flex: 2;
  margin-right: 20px
}
.room-name {
  font-size: var(--font-lg-size);
  color: var(--heading-color)
}
.confirmation-text, .room-price .taxes {
  color: var(--secondary-t-color)
}
.room-amenities {
  margin: 0;
  padding: 0;
  list-style: none
}
.room-choice, .room-guests, .room-price {
  margin-right: 20px;
  display: flex
}
.room-amenities li, .room-choice p {
  margin: 5px 0;
  font-size: var(--font-sm-size)
}
.room-amenities i {
  margin-right: 5px;
  color: var(--accent-color)
}
.room-guests {
  flex: 1;
  align-items: center;
  justify-content: center
}
.room-guests i {
  font-size: 1.2em;
  color: var(--secondary-alt-color);
  margin: 0 2px
}
.room-price {
  flex: 1;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center
}
.confirmation-text, .info-text, .room-price .taxes {
  font-size: var(--font-sm-size)
}
.room-choice {
  flex: 1.5;
  flex-direction: column;
  justify-content: center
}
.room-select {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center
}
.room-select button, .room-select select {
  margin-bottom: 10px;
  padding: 8px 12px;
  border-radius: var(--bdr-5-radius);
  border: 1px solid var(--border-color);
  background-color: var(--secondary-color);
  color: var(--text-color)
}
.room-select button {
  background-color: var(--accent-color);
  color: var(--white-color);
  border: none;
  cursor: pointer
}
.room-select button:hover {
  background-color: #700400
}
.package-item-enhanced {
  display: flex;
  padding: 0;
  border: 1px solid var(--border-color);
  border-radius: var(--bdr-10-radius);
  color: var(--text-color);
  box-shadow: 0 2px 5px rgba(0, 0, 0, .1);
  transition: transform .2s ease-in-out, box-shadow .2s ease-in-out;
  position: relative;
  overflow: hidden
}
.package-item-enhanced img {
  width: 100%;
  border-radius: var(--bdr-10-radius) var(--bdr-10-radius) 0 0;
  object-fit: cover;
  display: block;
  border-bottom: 3px solid #b41a1b
}
.package-item-enhanced .package-item-description {
  padding: 15px
}
.package-item-enhanced ul {
  margin: 15px 0 0;
  padding: 0;
  list-style: none
}
.package-item-enhanced ul li {
  margin-bottom: 5px;
  position: relative;
  padding-left: 15px
}
.package-item-enhanced ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 6px;
  height: 6px;
  background-color: var(--primary-color);
  border-radius: 50%;
  display: inline-block
}
.package-item-enhanced input[type=radio] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0
}
.package-item-enhanced label {
  flex-direction: column;
  cursor: pointer;
  height: 100%;
  padding: inherit;
  border-radius: inherit;
  box-sizing: border-box;
  width: 100%
}
.package-item-enhanced input[type=radio]:checked + label {
  border: 2px solid var(--primary-color)
}
.package-item-enhanced input[type=radio]:checked + label::after {
  content: '\f00c';
  font-family: var(--font-awesome);
  font-weight: 900;
  position: absolute;
  top: 15px;
  right: 15px;
  color: var(--primary-color);
  font-size: 1.2em;
  border: 2px solid;
  height: 30px;
  width: 30px;
  text-align: center;
  line-height: 24px
}
.package-item-enhanced::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border-radius: inherit;
  padding: 2px;
  background: linear-gradient(45deg, var(--primary-color-light), var(--secondary-color-light), var(--primary-color-light));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: destination-out;
  mask-composite: exclude;
  pointer-events: none;
  opacity: 0;
  transition: opacity .3s ease-in-out
}
.package-item-enhanced input[type=radio]:checked + label::before, .package-item-enhanced input[type=radio]:focus + label::before, .package-item-enhanced:hover::before, .qr-code-wrapper:hover .qr-overlay {
  opacity: 1
}
.booking-area {
  padding: 70px 0
}
.info-text {
  color: #868889
}
.highlight {
  background: #2c2c2c;
  padding: 20px;
  border-radius: 8px;
  margin: 20px 0;
  border-left: 4px solid var(--primary-color);
  color: var(--tp-text-body);
  font-size: var(--font-size);
  box-shadow: 0 2px 10px rgba(0, 0, 0, .3)
}
.qr-code, .qr-img-container {
  border-radius: var(--bdr-5-radius)
}
.highlight .icon {
  color: var(--primary-color);
  margin-right: 10px;
  font-size: var(--font-lg-size);
  vertical-align: middle
}
.highlight strong {
  color: var(--white-color);
  display: block;
  margin-bottom: 8px
}
.highlight span {
  margin: 5px 0;
  color: var(--tp-text-body);
  font-size: var(--font-sm-size)
}
.summary-section {
  background: #1a1E20e6;
  padding: 30px;
  color: var(--tp-text-body);
  font-size: var(--font-size);
  position: sticky;
  top: 20px
}
.summary-section::before {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  background: var(--primary-color);
  height: 12px;
  content: "";
  border-top-left-radius: 8px;
  border-top-right-radius: 8px
}
.summary-section h3 {
  color: var(--white-color);
  font-size: var(--font-lg-size);
  position: relative
}
.summary-section .rating {
  margin-bottom: 15px;
  display: flex;
  align-items: center
}
.summary-section .rating i {
  margin-right: 6px;
  font-size: var(--font-size);
  color: var(--rating-background);
  transition: transform .2s
}
.summary-section .rating i:hover {
  transform: scale(1.2)
}
.summary-section .badge {
  background: var(--primary-lt-color);
  color: var(--black-color);
  padding: 4px 10px;
  border-radius: 12px;
  font-size: var(--font-sm-size);
  margin-left: 10px;
  font-weight: var(--font-med)
}
.summary-section p {
  color: var(--tp-text-body);
  margin-bottom: 12px
}
.summary-section .details {
  padding: 20px 0;
  border-top: 1px dashed rgba(255, 255, 255, .2)
}
.summary-section .details h4 {
  color: var(--white-color);
  font-size: var(--font-size);
  font-weight: var(--font-sbold);
  margin-bottom: 20px;
  text-transform: uppercase;
  letter-spacing: 1px
}
.summary-section .price {
  display: flex;
  justify-content: space-between;
  font-size: var(--font-lg-size);
  font-weight: var(--font-bold);
  color: var(--white-color);
  margin: 20px 0;
  padding: 10px;
  background: rgba(255, 255, 255, .05);
  border-radius: 5px
}
.summary-section .taxes {
  color: var(--secondary-t-color);
  font-size: var(--font-sm-size);
  text-align: right;
  margin-bottom: 12px;
  font-style: italic
}
.summary-section .price-info {
  padding: 15px 0;
  color: var(--tp-text-body);
  border-bottom: 1px dashed rgba(255, 255, 255, .2)
}
.summary-section .price-info .icon {
  color: var(--primary-t-color);
  margin-right: 8px;
  font-size: 18px
}
.summary-section .payment-schedule {
  margin: 15px 0;
  color: var(--tp-text-body);
  padding: 10px;
  background: rgba(255, 255, 255, .03);
  border-radius: 5px
}
.summary-section .payment-schedule strong {
  color: var(--white-color);
  font-weight: var(--font-bold);
  text-transform: uppercase;
  display: block;
  margin-bottom: 5px
}
.summary-section .cancellation {
  margin: 15px 0;
  padding: 15px;
  background: rgba(255, 255, 255, .03);
  border-radius: 5px
}
.summary-section .cancellation strong {
  color: var(--white-color);
  font-weight: var(--font-bold);
  display: block;
  text-transform: uppercase;
  margin-bottom: 8px
}
.summary-section .cancellation .free {
  color: var(--primary-t-color);
  font-weight: var(--font-med);
  display: flex;
  align-items: center
}
.summary-section .cancellation .free::before {
  content: "\f00c";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-right: 8px;
  font-size: 14px
}
.summary-section .cancellation .fee {
  color: var(--accent-color);
  font-weight: var(--font-med);
  display: flex;
  align-items: center
}
.summary-section .cancellation .fee::before {
  content: "\f071";
  font-family: var(--font-awesome);
  font-weight: 900;
  margin-right: 8px;
  font-size: 14px
}
.summary-section .availability-warning {
  background: #3a3a3a;
  padding: 12px;
  border-radius: 5px;
  color: var(--white-color);
  font-size: var(--font-sm-size);
  margin-top: 20px;
  text-align: center;
  text-transform: uppercase;
  font-weight: var(--font-med);
  transition: background .3s
}
.summary-section .availability-warning:hover {
  background: #4a4a4a
}
.qr-img-container {
  background: #1a1e20;
  padding: 15px;
  margin-bottom: 20px;
  text-align: center
}
.qr-title {
  font-size: var(--fon-size);
  color: var(--heading-color);
  margin-bottom: 10px;
  font-weight: var(--font-bold);
  text-transform: uppercase;
  letter-spacing: 1px
}
.qr-code-wrapper {
  position: relative;
  display: inline-block;
  margin-bottom: 10px
}
.qr-code {
  max-width: 100%;
  height: auto;
  background: var(--background-color);
  padding: 5px
}
.qr-overlay {
  position: absolute;
  top: 50%;
  left: 50%;
  opacity: 0;
  transition: opacity .3s
}
.qr-download-btn {
  background-color: var(--accent-color);
  color: var(--rating-text-color);
  border: none;
  padding: 8px 15px;
  border-radius: var(--bdr-5-radius);
  cursor: pointer;
  font-family: var(--secondary-font);
  font-size: var(--font-sm-size);
  font-weight: var(--font-sbold);
  transition: background-color .3s
}
.qr-download-btn:hover {
  background-color: darken(var(--accent-color), 10%)
}
.qr-instructions {
  font-family: var(--tritary-font);
  font-size: var(--font-sm-size);
  color: var(--tp-text-body);
  margin-top: 10px;
  font-weight: var(--font-lt)
}
@media (max-width:768px) {
  .custom-booking-form {
    flex-direction: column;
    align-items: stretch
  }
  .custom-booking-form .tp-btn, .date-selection, .guest-selection {
    flex: none
  }
  .qr-img-container {
    padding: 10px
  }
  .qr-title {
    font-size: var(--font-size)
  }
  .qr-code {
    max-width: 80%
  }
}
@supports not (color:darken(#9F0600, 10%)) {
  .qr-download-btn:hover {
    background-color: #850500
  }
}
.toast-body {
  padding: var(--bs-toast-padding-x);
  word-wrap: break-word;
  display: flex;
  justify-content: space-between;
  align-items: center
}
.form-group {
  margin-bottom: 15px
}
.deselect-icon {
  color: #dc3545;
  position: absolute;
  top: 20px;
  right: 20px;
  height: 30px;
  width: 30px;
  line-height: 30px;
  border: 2px solid #dc3545;
  background: rgba(0, 0, 0, .9)
}
.deselect-icon:before {
  content: '\f00c';
  font-family: var(--font-awesome);
  font-weight: 900;
  text-align: center;
  line-height: 24px
}
.deselect-icon:hover {
  color: #a71d2a;
  background: #000
}
.package-item-enhanced label, .theme-type-full {
  position: relative;
  display: inline-block
}
.unread-count {
  position: absolute;
  top: -5px;
  right: -5px;
  background: red;
  color: #fff;
  border-radius: 50%;
  padding: 2px 6px;
  font-size: 12px;
  font-weight: 700
}
/* Hero text and room status styling */
.hero-text {
    background: var(--secondary-color, #f0f0f0);
    font-size: clamp(2rem, 2.5vw, 2rem);
    padding: clamp(2rem, 3vw, 2rem);
    text-align: center;
    color: var(--white-color, #ffffff);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    z-index: 1;
    width: 100%;
}

.room-status {
    min-height: 240px;
    max-width: 80%;
    background: var(--black-color, #000000);
    border-radius: 30px;
    margin: 0 auto;
    position: relative;
    overflow: hidden;
    transition: transform 0.3s ease;
    display: block;
}

.room-status img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 30px;
    display: block;
}

.room-status span {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: var(--white-color, #ffffff);
    font-size: clamp(1.5rem, 2rem, 2rem);
    text-align: center;
    z-index: 1;
    font-weight: bold;
    text-shadow: 1px 1px #000;
    white-space: normal;
    overflow: hidden;
    text-overflow: ellipsis;
}

.el {
    background: var(--black-color, #000);
}

.el:before {
    content: ' ';
    position: absolute;
    background: #ffe875;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -webkit-mask: radial-gradient(circle at 50% 50%, white 2px, transparent 2.5px) 50% 50% / 15px 15px, url("../img/noise-mask.webp") 256px 50% / 256px 256px;
    mask: radial-gradient(circle at 50% 50%, white 2px, transparent 2.5px) 50% 50% / 15px 15px, url("../img/noise-mask.webp") 256px 50% / 256px 256px;
    -webkit-mask-composite: source-in, xor;
    mask-composite: intersect;
    -webkit-animation: flicker 20s infinite linear;
    animation: flicker 20s infinite linear;
    z-index: 0;
}

@keyframes flicker {
    to {
        mask-position: 50% 50%, 0 50%;
    }
}

/* Enhanced content section styling */
.content-section {
    padding: 30px;
    background: var(--secondary-color);
    margin: 3rem auto;
    max-width: 90%;
    border-radius: 5px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
    position: relative;
    color: var(--white-color, #ffffff);
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.content-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 4px;
    background: var(--primary-color);
    border-radius: 25px 25px 0 0;
}

.content-section h2 {
    font-size: 24px;
    margin-bottom: 1.5rem;
    text-align: left;
    font-weight: 700;
    position: relative;
    color: var(--primary-color);
    letter-spacing: 0.02em;
}

.content-section h2::after {
    content: '';
    display: block;
    width: 60px;
    height: 3px;
    background: var(--primary-color);
    margin: 0.5rem 0 0;
    border-radius: 2px;
}
.content-section p {
    font-size: var(--font-size);
    text-align: justify;
    color: #e0e0e0;
    margin: 0 auto;
}

.content-section p + h2{
    margin-top:25px;
}
.content-section a {
    color: var(--primary-color);
    text-decoration: none;
    font-weight: 600;
    transition: color 0.3s ease, text-decoration 0.3s ease;
    border-bottom: 1px solid transparent;
}

.content-section a:hover {
    color: #ff6b6b;
    border-bottom: 1px solid #ff6b6b;
}

.content-section {
    opacity: 0;
    transform: translateY(20px);
    animation: fadeInUp 0.6s ease-out forwards;
}
/* Image Wrapper for Video Icon */
.image-wrapper {
    position: relative;
    display: inline-block;
    cursor: pointer;
}

.image-wrapper img {
    transition: opacity 0.3s ease;
}

.image-wrapper img:hover {
    opacity: 0.8;
}

/* Creative Video Icon */
.video-icon {
    position: absolute;
    bottom: 15px;
    right: 15px;
    width: 80px;
    height: 50px;
    background: #c0392b;
    border-radius: 3px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 10;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3); /* Subtle shadow for depth */
    transition: transform 0.3s ease, background 0.3s ease;
}

/* Play triangle */
.video-icon::before {
    content: '';
    width: 0;
    height: 0;
    border-left: 18px solid #fff;
    border-top: 12px solid transparent;
    border-bottom: 12px solid transparent;
    margin-left: 4px;
    filter: drop-shadow(1px 1px 1px rgba(0, 0, 0, 0.2)); /* Slight shadow on triangle */
}

/* Pulse animation on hover */
.video-icon:hover {
    background: #f00;
    animation: pulse 1.5s infinite; /* Pulse effect */
}

/* Pulse keyframe animation */
@keyframes pulse {
    0% {
        transform: scale(1);
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3);
    }
    50% {
        transform: scale(1.05);
        box-shadow: 0 6px 12px rgba(0, 0, 0, 0.4);
    }
    100% {
        transform: scale(1);
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3);
    }
}

/* Lightbox Styles (Unchanged) */
.lightbox {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.9);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
}

.lightbox-content {
    position: relative;
    max-width: 90%;
    width: 800px;
}

.lightbox video {
    width: 100%;
    max-height: 80vh;
}

.lightbox-close {
    position: absolute;
    top: -30px;
    right: -30px;
    color: #fff;
    font-size: 30px;
    cursor: pointer;
}

.lightbox-close:hover {
    color: #ccc;
}

/* Responsive Adjustments */
@media (max-width: 768px) {
    .lightbox-content {
        width: 95%;
    }

    .lightbox-close {
        top: -20px;
        right: 0;
        font-size: 24px;
    }

    .video-icon {
        width: 40px;
        height: 40px;
    }

    .video-icon::before {
        border-left: 14px solid #fff;
        border-top: 10px solid transparent;
        border-bottom: 10px solid transparent;
    }
}

@keyframes fadeInUp {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Media queries */
@media (prefers-reduced-motion: reduce) {
    .el:before {
        animation: none;
    }
}

@media (max-width: 1200px) {
    .room-status {
        max-width: 82%;
    }
}

@media (max-width: 992px) {
    .hero-text {
        font-size: clamp(1.25rem, 2.5vw, 1.5rem);
        padding: clamp(1rem, 2vw, 1.5rem);
    }
    .room-status {
        max-width: 85%;
        min-height: 220px;
    }
}

@media (max-width: 768px) {
    .hero-text {
        font-size: clamp(1.125rem, 2.5vw, 1.375rem);
        padding: clamp(0.75rem, 2vw, 1.25rem);
    }
    .room-status {
        max-width: 90%;
        min-height: 200px;
    }
    .room-status img {
        border-radius: 30px;
    }
    .room-status span {
        width: 85%;
    }
    .el:before {
        -webkit-mask-size: 12px 12px, 200px 200px;
        mask-size: 12px 12px, 200px 200px;
    }
}

@media (max-width: 576px) {
    .hero-text {
        font-size: clamp(1rem, 2.5vw, 1.25rem);
        padding: clamp(0.5rem, 2vw, 1rem);
    }
    .room-status {
        max-width: 95%;
        min-height: 180px;
        border-radius: 20px;
    }
    .room-status img {
        border-radius: 20px;
    }
    .room-status span {
        padding: 8px;
        border-radius: 8px;
        width: 90%;
    }
    .el:before {
        -webkit-mask-size: 10px 10px, 160px 160px;
        mask-size: 10px 10px, 160px 160px;
    }
}

@media (max-width: 480px) {
    .hero-text {
        font-size: clamp(0.875rem, 2.5vw, 1.125rem);
    }
    .room-status {
        min-height: 150px;
        border-radius: 20px;
    }
    .room-status img {
        border-radius: 20px;
    }
    .room-status span {
        padding: 6px;
        border-radius: 6px;
    }
    .el:before {
        -webkit-mask-size: 8px 8px, 120px 120px;
        mask-size: 8px 8px, 120px 120px;
    }
}