@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400..900;1,400..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400..700;1,400..700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');

/* =========================
   Core / Variables
   ========================= */
:root {
  --color1: #57544d;
  --color2: #ffffff;
  --color3: #626262;
  --color4: #6c1116;
}

html { scroll-padding-top: 80px; }
body {
  font-family: "Lora", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  background: var(--color2);
  color: var(--color3);
  font-size: .9rem;
  line-height: 1.75;
}
a { text-decoration: none; color: #6c1116; }
a:hover { text-decoration: underline; }

a.totop {
  display: block;
  width: 40px;
  float: right;
  text-align: right;
  font-weight: 600;
}

h1 {
  font-family: "Playfair Display", serif;
  font-size: 1.55rem;
  font-weight: 400;
  text-transform: capitalize;
  color: #000;
  text-align: center;
  margin: .5rem 0;
}
h2 {
  font-family: "Playfair Display", serif;
  font-size: .7rem;
  font-weight: 700;
}

ul { padding-left: 1rem; }

/* =========================
   Buttons / Forms
   ========================= */
.btn-primary {
  border-radius: 0;
  font-weight: 700;
  color: var(--color2) !important;
  border-color: var(--color4) !important;
  background-color: var(--color4) !important;
  padding: .8rem 1.2rem;
}
.btn-primary:hover,
.btn-primary:active,
.btn-primary:focus {
  color: var(--color1) !important;
  border-color: #000 !important;
  background-color: var(--color2) !important;
}

.btn-secondary {
  background-color: #434740 !important;
  border-color: #434740 !important;
  border-radius: 0;
  padding: .35rem 2.75rem;
  font-weight: 700;
  color: var(--color2);
}
.btn-secondary:hover,
.btn-secondary:active,
.btn-secondary:focus {
  color: #434740 !important;
  border-color: #434740 !important;
  background-color: #fff !important;
}

.form-control {
  border: 1px solid #fff;
  border-radius: 0;
  font-size: .8rem;
}
.form-control:hover { border: 1px solid #000; }
.form-control::placeholder { color: #c0c0bf; }
.form-label { color: #000; }
label.required::after {
  content: '*';
  margin-left: 4px;
  position: relative;
  top: -4px;
}

/* =========================
   Containers
   ========================= */
.container { /* border: 1px solid #000; */ }

/* =========================
   Fancybox Widget
   ========================= */
#widget {
  width: 100%;
  max-width: 1280px;
  height: auto;
  display: none;
  overflow: visible;
}
#widget .fancybox-content { overflow: visible; }
.fancybox-widget .fancybox__backdrop {
  opacity: .25 !important;
  background: rgb(30, 30, 30);
}
.fancybox-widget .fancybox__slide { overflow-x: hidden !important; }

/* =========================
   Mobile Sidebar
   ========================= */
.sidebar {
  height: 100%;
  width: 100%;
  position: fixed;
  z-index: 10000;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.98);
  overflow-x: hidden;
  padding-top: 18px;
  font-family: "Montserrat", sans-serif;
}
.sidebar .navbar-nav {
  padding-left: 2rem;
  padding-right: 2rem;
  flex-direction: column;
}
.sidebar .navbar-nav .nav-item { padding: .25rem 0; font-size: 1rem; color: #3f3f3f; position: relative; }
.sidebar .navbar-nav .nav-item .nav-link {
  color: #fff;
  text-decoration: none;
  font-weight: 500;
  font-size: 1rem;
  text-align: center;
  text-transform: uppercase;
}
.sidebar .navbar-nav .nav-item .nav-link:hover,
.sidebar .navbar-nav .nav-item .nav-link:focus,
.sidebar .navbar-nav .nav-item .nav-link:active { color: #b5b5b5; }
.sidebar .navbar-nav:nth-of-type(1) { text-align: right; }
.sidebar .navbar-nav .nav-item .close-small {
  background: transparent; border: 0; border-radius: 0; color: #fff; cursor: pointer; margin: 0; position: relative; top: -5px; right: -1px;
}
.sidebar .navbar-nav .nav-item .close-small svg { fill: #fff; }
.sidebar .navbar-nav .nav-item .close-small:hover svg { fill: #656565; }

#main { padding: 0; position: relative; }
#main .blocked {
  background: var(--color3);
  height: 100%;
  width: 100%;
  display: none;
  opacity: .3;
  z-index: 1000;
  position: absolute;
  inset: 0;
}

/* =========================
   Header / Footer
   ========================= */
header {
  background: #7d8a73;
  z-index: 100;
  font-family: "Montserrat", sans-serif;
}
header .container-fluid { display: flex; justify-content: space-around; }
header .navbar .navbar-brand img { height: 100%; width: auto; max-height: 57px; }
header .navbar .navbar-nav .nav-link {
  text-transform: uppercase; font-size: .75rem; color: #fff; padding: 1rem 0;
}
header .navbar .navbar-nav .active,
header .navbar .navbar-nav .nav-link:hover,
header .navbar .navbar-nav .nav-link:focus { color: #713532; text-decoration: none; }
header .navbar .navbar-nav .nav-link span { position: relative; top: 3px; }
header .navbar .navbar-nav .dropdown-menu { border-radius: 0; }
header .navbar .navbar-nav .dropdown-menu .dropdown-item { font-size: .8rem; text-transform: uppercase; }
header .navbar .navbar-nav .dropdown-menu .dropdown-item:hover,
header .navbar .navbar-nav .dropdown-menu .dropdown-item:focus { background-color: #eee; color: #000; }
header .navbar .navbar-toggler { border: 1px solid #fff; border-radius: 0; }
header .navbar .navbar-toggler:focus { box-shadow: none !important; }
header .navbar .navbar-toggler .navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 1%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}
header .navbar .book-button { display: none; }
header .btn-primary {
  border: 1px solid var(--color2) !important;
  color: var(--color1) !important;
  background: var(--color2) !important;
  font-family: "Playfair Display", serif;
  font-size: .95rem;
  padding: .525rem 1.075rem;
}
header .btn-primary:hover,
header .btn-primary:focus,
header .btn-primary:active {
  border-color: #000 !important;
  color: var(--color1) !important;
  background: var(--color2) !important;
}

footer {
  background: #242323;
  padding: 2rem 0 1rem;
  color: #fff;
}
footer a { text-decoration: underline; color: #ddd; font-size: .7rem; }
footer a.alt span { margin-top: 1rem; display: block; }
footer .footer-logo { max-width: 177px; margin: 0 auto; }
footer .footer-logo img { width: 100%; height: auto; }
footer .footer-contact { display: flex; justify-content: space-evenly; }
footer .footer-location { text-align: center; padding: 1rem 0; font-size: 1rem; }
footer .footer-nav { text-transform: uppercase; font-size: .7rem; font-weight: 700; }
footer .footer-nav ul {
  list-style: none; padding: 0; margin: 0; text-align: left; column-count: 2; column-gap: 60px;
}
footer .footer-nav ul li { margin-bottom: .75rem; }
footer .footer-copyright { text-align: center; font-size: .75rem; }

/* =========================
   Splash / Visibility
   ========================= */
.splash-container { max-height: 85vh; overflow: hidden; }
.splash-container img { width: 100%; height: 100%; object-fit: cover; }

.visible { visibility: visible; opacity: 1; transition: opacity .25s linear; }
.hidden { visibility: hidden; opacity: 0; transition: visibility 0s .25s, opacity .25s linear; }

/* =========================
   Borders / Overlay
   ========================= */
.double-border { border: 2px solid #000; padding: 3px; margin: 0 auto; }
.double-border .overlay-container { border: 1px solid #000; padding: 5px; margin: 0 auto; }

.overlay-container { position: relative; overflow: hidden; }
.overlay-container .overlay-img { width: 100%; height: 100%; object-fit: cover; object-position: center; }
.overlay-container .overlay {
  position: absolute; inset: 0; z-index: 1; display: flex; align-items: center; justify-content: center; flex-direction: column; color: #000; padding: 1rem;
}
.overlay-container .overlay h1 { text-transform: capitalize; font-size: 2.5rem; }

.img-container-opacity { width: 100%; height: 100%; display: block; z-index: 10000; opacity: .5; }
.img-container-opacity img { width: 100%; height: 100%; object-fit: cover; object-position: center; }

.fancy-gallery { margin: .35rem; display: block; height: 316px; }
.fancy-gallery .overlay-container { height: 100%; }
.fancy-gallery .overlay-container img { height: 100%; width: 100%; object-fit: cover; }
.fancy-gallery:hover .overlay-container .overlay { background: rgba(115,115,115,0.6); }

/* =========================
   Rooms
   ========================= */
.room-container { text-align: center; margin-bottom: 1rem; font-size: .75rem; }
.room-container hr {
  width: 25%; border-top: 1px solid #000; margin: 0 auto 1rem; opacity: 1;
}
.room-container h2 { margin-bottom: 1rem; }
.room-container ul { list-style-position: inside; }

/* =========================
   Parallax
   ========================= */
.parallax, section { position: relative; }
.parallax .bg, .bg {
  position: absolute; inset: 0; z-index: -1; background-size: initial; background-position: center center; background-repeat: no-repeat;
}

/* =========================
   Gallery Slider
   ========================= */
#gallery-slider,
#gallery-slider .slick-slider,
#gallery-slider .slick-slider .slick-list,
#gallery-slider .slick-slider .slick-list .slick-track,
#gallery-slider .slick-slider .slick-list .slick-track .slick-slide {
  position: relative; height: 350px;
}
#gallery-slider .slick-slide a { display: block; height: 100%; width: 100%; position: relative; overflow: hidden; }
#gallery-slider .slick-slide a .slide-container { overflow: hidden; height: 100%; width: 100%; }
#gallery-slider .slick-slide img { height: 100%; width: 100%; object-fit: cover; object-position: center; }
#gallery-slider .arrow-next-cus, #gallery-slider .arrow-prev-cus { margin: -25px 2rem 0; width: 23px; height: 39px; }
#gallery-slider .slick-slide a:hover .overlay { position: absolute; inset: 0; background: rgba(115,115,115,0.6); z-index: 100; }

#gallery-slider, #gallery-slider a, #gallery-slider .slick-slide img { height: 350px; }

.container-gallery-slider,
.container-gallery-slider .slick-slider,
.container-gallery-slider .slick-slider .slick-list,
.container-gallery-slider .slick-slider .slick-list .slick-track,
.container-gallery-slider .slick-slider .slick-list .slick-track .slick-slide {
  position: relative; overflow: hidden; height: 245px;
}
.container-gallery-slider .slick-slide { height: auto; margin: 0 3px; }
.container-gallery-slider .slick-slide a {
  display: block; height: 100%; width: 100%; position: relative; overflow: hidden;
}
.container-gallery-slider .slick-slide a .slide-container { overflow: hidden; height: 100%; width: 100%; }
.container-gallery-slider .slick-slide img { height: 100%; width: 100%; object-fit: cover; object-position: center; }
.container-gallery-slider .arrow-next-cus, .container-gallery-slider .arrow-prev-cus { margin: -25px 2rem 0; width: 23px; height: 39px; }
.container-gallery-slider .slick-slide a:hover .overlay { position: absolute; inset: 0; background: rgba(115,115,115,0.6); z-index: 100; }

.container-room-gallery-slider,
.container-room-gallery-slider a,
.container-room-gallery-slider .slick-slide img { height: 245px; }

/* =========================
   Our Rooms Parallax
   ========================= */
#our-rooms { display: flex; align-items: center; justify-content: center; }
#our-rooms h1 { text-transform: uppercase; }
.parallax-text {
  height: auto; width: auto; max-width: 400px; padding: 2rem;
  background: rgba(255,255,255,0.75); color: #000; text-align: center; margin: 2rem;
}

#rooms-standard-info { padding-left: 2rem; padding-right: 2rem; }
#rooms-standard-info ul {
  list-style: none; padding-left: 0; margin-left: 0; text-align: center; margin-top: 1rem; font-size: 1.25rem;
}

.room-splash-container { height: auto; }

/* =========================
   Filler / Services / Things To Do
   ========================= */
#filler1 { height: 480px; margin: 0 auto; }

#our-services h1, #things-to-do h1, #contact-us h1 { text-transform: uppercase; }
#our-services h2, #things-to-do h2 { font-size: 1rem; font-weight: 700; margin: 1rem; }

/* =========================
   Contact Us
   ========================= */
#contact-us { background: #f5f5f5; }
#contact-us .container { max-width: 640px; }
#contact-us .btn-secondary {
  background-color: #242323 !important; border-color: #242323 !important; border-radius: 0;
  padding: .8rem 1.2rem; font-weight: 700; color: var(--color2);
}

/* =========================
   Icons / Utilities
   ========================= */
.icon {
  /* height: 45px; */
  height: 75px;
  margin: 0 auto;
  display: flex;
  justify-content: center !important;
  align-items: center !important;
}
.icon img { height: 100%; width: 100%; object-fit: contain; }
.icon svg { fill: #737373; }
.padding-box { padding: 1rem 3rem; }

/* =========================
   Chart (hidden by default)
   ========================= */
#chart { display: none; }
#chart h2 { font-size: 1.5rem; }
#chart h3 { font-size: 1.25rem; }

.fancybox-chart .fancybox__backdrop { opacity: .25 !important; background: rgb(30, 30, 30); }

.nobreak img.icon, div.amenities img {
  float: none; display: inline; width: 24px; height: 24px; margin: 0 3px 10px;
}
.nobreak { white-space: nowrap; }
div.amenities p { margin: 10px 0 0; text-align: left; font-size: 15px; }
div.amenities ul {
  list-style: none; margin: 0 0 10px; padding: 0 0 10px; border-bottom: 1px solid #E1C78A; overflow: hidden; min-width: 200px;
}
div.amenities ul li { margin: 0; padding-right: 10px; display: inline; white-space: nowrap; }

.mobile { display: block; }
.desktop { display: none; }

/* =========================
   BLOG: Content Container
   (keeps main blog content narrow & centered)
   ========================= */
.blog-content {
  max-width: 900px;
  margin: 0 auto;
  padding: 20px;
  line-height: 1.6;
}
.blog-content h1, .blog-content h3 { text-align: center; }
.blog-meta { text-align: center; margin-bottom: 20px; font-style: italic; color: #666; }

/* =========================
   BLOG: Table of Contents
   ========================= */
/* List reset (no bullets) */
.blog-table-of-contents { max-width: 900px; margin: 0 auto; text-align: left; }
.blog-table-of-contents ul { list-style: none !important; padding-left: 0; margin: 0; }
.blog-table-of-contents li { list-style: none !important; margin: 0 0 18px; }
.blog-table-of-contents li::marker { content: ""; }

/* Entry layout */
.blog-entry { display: flex; align-items: flex-start; gap: 16px; }

/* Thumbnail (larger & consistent) */
.blog-thumbnail {
  width: 440px;
  aspect-ratio: 16 / 9;
  height: auto;
  object-fit: cover;
  border-radius: 6px;
  flex-shrink: 0;
}

/* Title & snippet */
.entry-text a {
  font-size: 1.1rem;
  color: #1c75bc;
  font-weight: 700;
  text-decoration: none;
}
.entry-text a:hover { text-decoration: underline; }
.entry-text p { font-size: 1rem; color: #666; margin: 6px 0 0; }

/* =========================
   BLOG: Photo Gallery + Lightbox
   ========================= */
.blog-photo-gallery img {
  width: 100%;
  height: 300px;
  object-fit: cover;
  object-position: top;
  border-radius: 8px;
  box-shadow: 0 4px 6px rgba(0,0,0,.1);
  transition: transform .3s, box-shadow .3s;
  cursor: pointer;
}
.blog-photo-gallery img:hover { transform: scale(1.05); box-shadow: 0 6px 8px rgba(0,0,0,.2); }

.lightbox {
  display: none; position: fixed; inset: 0; background: rgba(0,0,0,.8);
  justify-content: center; align-items: center; z-index: 1000;
}
.lightbox img {
  max-width: 90%; max-height: 90%; border-radius: 8px; box-shadow: 0 4px 6px rgba(0,0,0,.2);
}
.lightbox .close {
  position: absolute; top: 20px; right: 20px; font-size: 2rem; color: #fff; cursor: pointer;
}
.blog-photo-gallery {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 10px; margin-top: 20px;
}

/* =========================
   Fancybox Global
   ========================= */
.fancybox__backdrop { background: rgba(255,255,255,1); }
.fancybox-is-open .fancybox__backdrop { opacity: 1; }
.f-button { background: none; box-shadow: none; }
.f-button:hover { color: #000; }
.is-close-btn svg { stroke: #434740 !important; }
.fancybox__nav { --f-button-svg-filter: initial; }
.fancybox__toolbar { text-shadow: none !important; --f-button-svg-filter: none !important; }

/* =========================
   Blog Layout (optional side columns)
   ========================= */
.blog-master {
  display: flex; width: 100%; margin-bottom: 40px; padding-bottom: 20px;
}
.blog-left, .blog-right {
  padding: 0; margin-left: 30px; margin-right: 30px; box-sizing: border-box;
}
.blog-left { flex-basis: 300px; }
.blog-right { flex-basis: 200px; }
.blog-middle {
  flex-grow: 1; padding: 20px; background-color: #fff; box-shadow: 0 0 10px rgba(0,0,0,.1);
}

/* =========================
   Visibility Animations
   ========================= */
.fade-in { opacity: 0; visibility: hidden; }
.shift-up { opacity: 0; transform: translateY(20px); visibility: hidden; }
.visible-row { opacity: 1; transform: translateY(0); transition: all 1s ease-in-out; visibility: visible; }

.blog-title {
  font-family: "Playfair Display", serif;
  font-size: 1.2rem;
  font-weight: 700;
  text-transform: none;
  color: #6c1116;
  text-align: center;
  margin: 1.5rem 0;
  line-height: 1.3;
}


/* =========================
   Responsive
   ========================= */

/* <= 991.98px (phones/tablets) */
@media (max-width: 991.98px) {
  .parallax .bg, .bg { background-size: cover; background-position: center center !important; }
  .mobile { display: block; }
  .desktop { display: none; }
}

/* <= 720px (TOC stacks) */
@media (max-width: 720px) {
  .blog-entry { flex-direction: column; }
  .blog-thumbnail { width: 100%; max-width: 100%; }
}

/* >= 576px */
@media (min-width: 576px) {
  .container { max-width: 100%; }
}

/* >= 768px */
@media (min-width: 768px) {
  .container { max-width: 100%; }
  body { font-size: .8rem; }
  h2 { font-size: 1.5rem; font-weight: 400; color: #000; }

  footer .footer-logo { margin: 0; }
  footer .footer-contact { display: block; }
  footer .footer-nav { margin-top: 3rem; }
  footer .footer-nav ul { text-align: right; }

  .shift-up { position: relative; z-index: 10; }
  .fade-in { position: relative; z-index: 10; }

  #gallery-slider, #gallery-slider a, #gallery-slider .slick-slide img { height: 785px; }
  #gallery-slider,
  #gallery-slider .slick-slider,
  #gallery-slider .slick-slider .slick-list,
  #gallery-slider .slick-slider .slick-list .slick-track,
  #gallery-slider .slick-slider .slick-list .slick-track .slick-slide,
  #gallery-slider .slick-slider .slick-list .slick-track .slick-slide img {
    position: relative; overflow: hidden; height: 785px;
  }

  .container-room-gallery-slider,
  .container-room-gallery-slider a,
  .container-room-gallery-slider .slick-slide img { height: 545px; }

  .container-gallery-slider,
  .container-gallery-slider .slick-slider,
  .container-gallery-slider .slick-slider .slick-list,
  .container-gallery-slider .slick-slider .slick-list .slick-track,
  .container-gallery-slider .slick-slider .slick-list .slick-track .slick-slide,
  .container-gallery-slider .slick-slider .slick-list .slick-track .slick-slide img {
    position: relative; overflow: hidden; height: 545px;
  }

  .padding-box { padding: 1.5rem 2.5rem; }

  .mobile { display: none; }
  .desktop { display: block; }
}

/* >= 992px */
@media (min-width: 992px) {
  .container { max-width: 100%; }

  #main { margin-right: 0 !important; transform: initial !important; opacity: 1 !important; }
  #navbarHeader .navbar-nav { justify-content: space-around; width: 100%; padding: 0 2rem; }

  header { position: sticky !important; width: 100%; top: 0; }
  header .navbar .book-button { display: block; }

  #rooms-standard-info {
    padding-right: calc(var(--bs-gutter-x) * 0.5);
    padding-left: calc(var(--bs-gutter-x) * 0.5);
  }
  #our-rooms { height: 598px; }
  #our-rooms .parallax-text { margin: 0; }

  #filler1 { max-width: 94%; height: 552px; }
  .room-splash-container { height: 100vh; }
}

/* >= 1200px */
@media (min-width: 1200px) {
  .container { max-width: 1280px; }
  .container-restrained { max-width: 1020px !important; }
  #our-services { max-width: 820px !important; }
  .parallax .bg, .bg { background-size: cover; }
}

/* iPad & similar: turn off parallax */
@media only screen and (max-device-width: 1366px) {
  .parallax { background-attachment: scroll; }
}
