/*
Theme Name: BlankSlate
Theme URI: https://opencollective.com/blankslate
Author: Web Guy
Author URI: https://opencollective.com/blankslate#section-contributors
Description: Donate: https://opencollective.com/blankslate. Learn: https://blankslate.me/. BlankSlate is the definitive WordPress boilerplate starter theme. I've carefully constructed the most clean and minimalist theme possible for designers and developers to use as a base to build websites for clients or to build completely custom themes from scratch. Clean, simple, unstyled, semi-minified, unformatted, and valid code, SEO-friendly, jQuery-enabled, no programmer comments, standardized and as white label as possible, and most importantly, the CSS is reset for cross-browser-compatability, with no intrusive visual CSS styles added whatsoever. A perfect skeleton theme. For support and suggestions, go to: https://github.com/webguyio/blankslate/issues. Thank you.
Tags: accessibility-ready, one-column, two-columns, custom-menu, featured-images, microformats, sticky-post, threaded-comments, translation-ready
Version: 2026
Requires at least: 5.2
Tested up to: 6.8
Requires PHP: 7.4
License: GNU General Public License v3 or Later
License URI: https://www.gnu.org/licenses/gpl.html
Text Domain: blankslate

BlankSlate WordPress Theme 2011-2026
BlankSlate is distributed under the terms of the GNU GPL
*/

body {
  margin: 0px;
  font-family: Roboto, sans-serif;
}

a {
  color: #1f3442;
}

h1, h2, h3, h4, h5, h6 {
  font-family: "Poiret One";
}

.header { /* Disable page header and "Edit Page" button */
  display: none;
}

#primary { /* Disable search, comments, etc. */
  display: none;
}

h2 {
  margin-top: 0px;
}

.wp-block-media-text {
  max-width: 1250px;
  margin: auto;
}

.hero-banner {
  margin-bottom: 20px !important;
  padding-top: 1em !important;
  padding-bottom: 1em !important;
  text-align: center;
}

.superblockslider {
  max-width: 1250px !important;
  max-height: 650px !important;
  margin: auto;
}

.superblockslider * {
  overflow: hidden;
}

.wp-block-heading {
  margin: auto;
  text-align: center;
}

.dinner-menu-img a {
  display: block;
  width: 100%;
}
.dinner-menu-img a img {
  margin: auto;
  display: block;
  width: 100%;
  max-width: 1250px;
  max-height: 400px;
  object-fit: cover;
}

.first-slider a {
  transition: 0.3s;
}

.first-slider a:hover {
  cursor: pointer;
  background-color: #f0f0f0 !important;
  color: #333 !important;
  text-shadow: none !important;
  transition: 0.3s;
}

.dinner-menu-slider {
  max-height: 450px !important;
}

.dinner-menu-slider:hover {
  cursor: pointer;
}

.dinner-menu-slider .superblockslider__button__navigation {
  display: none !important;
}

.dinner-menu-slider svg {
  fill: white;
}

.dinner-menu-img {
  margin-top: 30px;
  margin-bottom: 30px;
}

.the-stay-we-always-wanted h2 {
  text-align: left !important;
}

.the-stay-we-always-wanted p {
  line-height: 1.8em;
}

.learn-more-link a {
  text-decoration: none !important;
  font-weight: bold;
  font-family: Poiret One, sans-serif;
}

.slideshow-img {
  height: 100%;
}

.inner-blocks {
  height: 100%;
}

.amenity-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 1em !important;
  width: 120px;
  text-align: center;
}

.amenity-item p {
  color: rgb(231, 219, 187);
  margin-top:0.6em;
  font-size: 0.8em;
}

.amenity-item svg {
  width: 60px;
  height: 60px;
}

.amenity-item svg path {
  fill: rgb(231, 219, 187);
}

.policy-circle {
  background-color:#34485A;
  fill:#e7dbbb;
  min-width:40px !important;
  border-radius:50%;
  padding:10px;
}

.policy-row {
  display: flex;
  gap: 40px;
  flex-wrap: wrap;
  flex-direction: row;
  margin: 2em 1em 2em 1em !important;
  max-width: 1500px;
}

.policy-row > * {
  flex-basis: 375px;
  flex-grow: 1;
}

.amenities-supersection {
  margin-bottom: 0 !important;
}

.property-cards, .amenities-group {
  display: flex;
  flex-wrap: wrap;
}

/* 1. Base Styles (Mobile First: 1 Column) */
.property-cards {
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: 1fr !important; /* Default for mobile */
  gap: 30px !important;
  align-items: stretch !important;
  flex-direction: unset !important; /* Kills WP default flex */
  flex-wrap: wrap !important;
}

/* 2. Tablet Breakpoint (2 Columns) */
@media (min-width: 600px) {
  .property-cards {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* 3. Desktop Breakpoint (4 Columns) */
@media (min-width: 1024px) {
  .property-cards {
    grid-template-columns: repeat(4, 1fr) !important;
  }
}

.property-card {
  flex-basis: 300px;
  flex-grow: 1;
  max-width: 400px;
  padding: 0;
}

.property-card a {
  background-color: #fafafa;
  color: #34485A;
  border: 1px solid #34485A;
  transition: 0.2s;
}

.property-card a:hover {
  background-color: #34485A;
  color: #fafafa;
  transition: 0.2s;
}

.property-card img {
  aspect-ratio: auto 1024 / 768;
}

.property-card-details {
  padding: 15px;
}

.our-policy-heading {
  margin-top: 0.5em !important;
}

.our-policy-hr {
  width: max(50%, 250px) !important;
}

.wp-block-cover {
  min-height: 700px !important;
}

.wp-block-cover > * {
  font-family: "Poiret One";
  font-weight: bolder;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 1);
}

.amenities-group > .wp-block-group {
  /* background-color: red; */
  display: flex;
  flex-wrap: wrap !important;
  max-width: 1200px;
  justify-content: center;
}

.amenity-item {
  flex-basis: 120px !important;
}

.hotel-enquiry-form {
  max-width: 1000px;
  margin: 0 auto;
  font-family: inherit;
}

.hotel-enquiry-form label {
  font-size: 16px;
  margin-bottom: 5px;
  display: block;
}

.hotel-enquiry-form .form-row {
  display: flex;
  gap: 20px;
  flex-wrap: wrap; /* makes them break properly on mobile */
}

.hotel-enquiry-form .form-group {
  flex: 1;
  min-width: 220px;
}

.hotel-enquiry-form .form-group.full-width {
  margin-top: 15px;
}

.hotel-enquiry-form input,
.hotel-enquiry-form textarea {
  width: calc(100% - 10px);
  border: 2px solid #333;
  padding: 10px;
  font-size: 16px;
  background: #ffffff;
  border-radius: 2px;
}

.hotel-enquiry-form textarea {
  resize: vertical;
}

.hotel-enquiry-form .form-submit {
  text-align: center;
  margin-top: 25px;
}

.hotel-enquiry-form button {
  background-color: #2d4254;
  color: #fff;
  padding: 12px 40px;
  border: none;
  border-radius: 30px;
  font-size: 16px;
  cursor: pointer;
  font-weight: 500;
  transition: 0.2s ease;
}

.hotel-enquiry-form button:hover {
  background-color: #1e2f3d;
}

.discounts-offers-circle {
  background-color: #34485A;
  padding: 20px;
  border-radius: 50%;
  color: #F3EFE6;
  width: 35px;
}

.guest-reviews {
  display: flex;
  flex-wrap: wrap;
  max-width: 1500px;
  margin: 2em auto 2em auto !important;
}

.guest-reviews > * {
  flex-basis: 350px;
  flex-grow: 1
}

.our-story {
  margin-top: 2em;
  margin-bottom: 2em;
  max-width: 1100px;
}

.our-story p {
  line-height: 1.8em;
}

.our-story-heading {
  font-size: 2em;
  text-align: left !important;
}

.breakfast-and-dinner-main > * {
  width: 100%;
  max-width: 1400px;
}

.breakfast-and-dinner-main > .wp-block-gallery {
  margin: auto;
}

.breakfast-and-dinner-main > .wp-block-group {
  margin: auto;
}

.discount-items {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap !important;
  max-width: 1300px;
}

.discount-items > * {
  flex-basis: 400px;
  flex-grow: 1;
}

.location-items {
  flex-wrap: wrap !important;
}

.location-items > * {
  padding: 2em;
  flex-basis: 500px;
  min-height: 250px;
  margin: auto !important;
}

.tnc-main > *, .privacy-policy-main > * {
  max-width: 1400px;
  width: 100%;
  margin: auto! important;
}

.privacy-policy-main h2 {
  text-align: left;
}

.privacy-policy-main h3 {
  text-align: left;
}

.privacy-policy-main h4 {
  text-align: left;
}

.tnc-main h3 {
  text-align: left !important;
}

.property-main > * {
  width: 100%;
  max-width: 1400px;
  margin: auto;
}

.property-main iframe {
  margin: auto;
  width: 100%;
}

.property-main > .wp-block-group {
  flex-wrap: wrap;
}

.property-main > .wp-block-group > * {
  flex-basis: 0;
  flex-grow: 1;
  min-width: 300px;
}

/* ============================
   HEADER BASE
============================ */
#site-header {
  background: #fff;
  padding: 10px;
  border-bottom: 1px solid rgba(0,0,0,0.08);
  font-family: Roboto, sans-serif;
  position: sticky;
  top: 0;
  z-index: 1000;
}

#site-header a {
  font-weight: 400;
}

/* ============================
   HEADER LAYOUT
============================ */
.header-container {
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr auto 1fr; /* left | center | right */
  align-items: center;
  padding: 10px;
}

/* Left column (logo) */
.header-left {
  justify-self: start;
}

.logo {
  height: 60px;
  width: auto;
}

.header-logo > a > img {
    max-height: 75px;
}

/* Center column (nav container) */
.header-center {
  justify-self: center;
}

/* Right column (empty for symmetry, future buttons etc.) */
.header-right {
  justify-self: end;
}

/* ============================
   NAVIGATION
============================ */
nav {
  display: flex;
  flex-direction: row !important;
  margin: 0;
  padding: 0;
}

nav ul {
  display: flex !important;
  list-style: none; /* remove bullets everywhere */
  gap: 35px;
}

nav > ul > li > a {
  color: #31414e;       /* Azzurro theme navy-ish color */
  text-decoration: none;
  letter-spacing: 1px;
  font-size: 14px;
  font-weight: 500;
  text-transform: uppercase;
  transition: color 0.2s ease;
}

/* Hover effect */
.nav-menu > ul > li > a:hover {
  color: #666;
}

/* ============================
   DROPDOWN MENU (FINAL FIXED VERSION)
============================ */

/* Parent LI (for absolute submenu positioning) */
.nav-menu li {
  position: relative;
}

/* Submenu container */
.nav-menu li .sub-menu {
  position: absolute;
  top: 100%;                    /* directly below parent */
  left: 0;

  background: #fff;
  border: 1px solid rgba(0,0,0,0.15);
  padding: 8px 0;

  min-width: 180px;
  z-index: 999;

  /* Prevent ANY flex or grid nonsense from WP */
  display: block !important;
  flex-direction: column !important;
  flex-wrap: nowrap !important;

  /* Reset inherited styles */
  list-style: none !important;
  margin: 0 !important;
  padding-left: 0 !important;
  column-count: 1 !important;
  width: auto !important;
}

.nav-menu li .sub-menu {
  display: none !important;
}

.nav-menu li:hover > .sub-menu {
  display: block !important;
}

/* SUBMENU list items */
.nav-menu li .sub-menu li {
  display: block !important;  
  width: 100% !important;
}

/* Submenu anchor styling */
.nav-menu li .sub-menu li a {
  display: block !important;
  padding: 10px 18px;
  font-size: 14px;
  color: #31414e;
  text-decoration: none;
  white-space: nowrap; /* avoid wrapping */
  width: 100%;
}

/* Hover effect */
.nav-menu li .sub-menu li:hover {
  background: rgba(0,0,0,0.05);
}

/* Global cleanup — no bullets anywhere */
.nav-menu,
.nav-menu ul,
.nav-menu li,
.nav-menu .sub-menu {
  list-style: none !important;
  margin: 0;
  padding: 0;
}

/* ---------------------------
   HAMBURGER MENU
---------------------------- */

.hamburger {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
}

.hamburger span {
  display: block;
  width: 26px;
  height: 2px;
  background: #222;
  margin: 6px 0;
  transition: 0.3s ease;
}

/* Mobile breakpoint */

@media (max-width: 730px) {
  #main-nav {
    display: none;
  }

  .hamburger {
    display: block;
  }

  /* when menu is open */
  #main-nav.is-open {
    display: block;
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    background: #fff;
    padding: 20px 0;
    z-index: 999;
  }

  #main-nav .nav-menu {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
  }

  .room-details .wp-block-buttons {
    justify-content: center !important;
    width: 100%;
    display: flex;
  }

  .room-details .wp-block-button__link {
    display: inline-block !important;
    margin: 0 auto !important;
  }
}

@media (max-width: 600px) {
  .hero-banner {
    padding: 1em !important;
    font-size: 3em !important;
  }
}

@media (max-width: 400px) {
  .already-have-a-location-in-mind {
    padding: 1em !important;
  }
}

/* ---------------------------
   FOOTER STYLES
---------------------------- */

#site-footer {
    background: #34485a;
    color: #f7f7f7;
    padding: 80px 20px;
    font-family: 'Montserrat', sans-serif;
}

.footer-container {
    max-width: 1100px;
    margin: 0 auto;
}

.footer-top {
    display: flex;
    flex-wrap: wrap;
    gap: 40px;
    justify-content: center; /* Centered layout like image */
    text-align: center;
}

.footer-col {
    flex: 1 1 280px;
}

/* Typography & Links */
#site-footer h4 {
    color: #f7f7f7;
    letter-spacing: 4px;
    font-size: 1.5em !important;
    font-weight: 800;
    margin-bottom: 30px;
    margin-top: 0;
    font-size: 1.2rem;
    font-family: "Poiret One", sans-serif !important;
}

.footer-nav {
    list-style: none;
    padding: 0;
    margin: 0;
}

.footer-nav li {
    margin: 12px 0;
    text-transform: uppercase;
    letter-spacing: 2px;
    font-size: 0.85rem;
}

#site-footer a {
    color: #f7f7f7;
    text-decoration: none;
    transition: opacity 0.3s;
}

#site-footer a:hover {
    opacity: 0.7;
}

/* Location Dropdown Specifics */
.location-trigger strong {
    cursor: pointer;
    user-select: none;
    display: inline-flex;
    align-items: center;
    font-weight: 500;
}

.location-trigger strong::after {
    content: '';
    width: 7px;
    height: 7px;
    border-right: 1px solid #f7f7f7;
    border-bottom: 1px solid #f7f7f7;
    transform: rotate(45deg);
    margin-left: 10px;
    margin-bottom: 4px;
    transition: transform 0.3s ease;
}

/* Sub-nav Logic */
.sub-nav {
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transition: all 0.4s ease;
    list-style: none;
    padding: 0;
}

.location-trigger.is-open .sub-nav {
    max-height: 400px;
    opacity: 1;
    margin-top: 15px;
}

.location-trigger.is-open strong::after {
    transform: rotate(-135deg);
    margin-bottom: -2px;
}

/* Socials & Logo */
.footer-logo {
    max-width: 200px;
    margin: 0 auto 25px;
}

.footer-socials {
    display: flex;
    justify-content: center;
    gap: 15px;
    margin-top: 20px;
}

.footer-socials a {
    border: 3px solid #f7f7f7;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
}

/* Bottom Bar */
.footer-divider {
    border: 0;
    border-top: 1px solid rgba(255,255,255,0.15);
    margin: 60px 0 30px;
}

.footer-bottom {
    text-align: center;
    font-size: 0.75rem;
    letter-spacing: 1px;
    line-height: 2;
}

/* Apply gold color to headers and links + Underline logic */
#site-footer h4, 
#site-footer a {
    color: #e7dbbb !important;
}

.footer-nav > li:not(:last-child)::after {
    content: "";
    display: block;
    width: 30px;            /* Length of the line */
    height: 1px;            /* Thickness of the line */
    background: #e7dbbb;    /* The gold color */
    margin: 10px auto;      /* Centers it and adds vertical space */
    opacity: 0.5;           /* Makes it subtle */
}

/* 3. Ensure the sub-nav items don't get the divider lines */
.sub-nav li::after {
    display: none !important;
}

/* Remove underline from sub-navigation items only */
.sub-nav a {
    text-decoration: none !important;
}

/* Ensure social icon borders match the gold theme */
.footer-socials a {
    border-color: #e7dbbb;
}

.location-trigger strong {
    color: #e7dbbb;
}

/* ---------------------------
   NEW HOME STYLES
---------------------------- */

.home-hero-banner h2 {
  text-align: right !important;
  max-width: 1000px;
}

.home-hero-banner a {
  text-shadow: none !important;
  font-family: Roboto, sans-serif;
  border: 1px solid #34485a;
  transition: 0.3s;
}

.new-home-page-content {
  max-width: 1250px !important;
}

@media (max-width: 1300px) {
  .new-home-page-content {
    max-width: 90% !important;
  }
}

.home-hero-banner a:hover {
  cursor: pointer;
  background-color: #f0f0f0 !important;
  color: #333 !important;
  text-shadow: none !important;
  transition: 0.3s;
}

.home-hero-banner-items {
  margin-right: 10em !important;
} 

.advantages-h2 {
  text-align: left !important;
}

@media (max-width: 1200px) {
  .home-hero-banner-items {
    margin-right: 3.5em !important;
  }
}

@media (max-width: 600px) {
  .home-hero-banner h2 {
    font-size: 2em !important;
  }
  .advantages-h2 {
    font-size: 2em !important;
  }
  .more-than-1000 {
    font-size: 2em !important;
  }
  .home-hero-banner a {
    font-size: 1em !important;
  }
  .home-hero-banner-items {
    margin-right: 0 !important;
  }
  .home-hero-banner {
    min-height: 400px !important;
    max-height: 400px !important;
  }
  .advantages-grid {
    grid-template-columns: 1fr !important;
  }
  .advantages-grid h2, .advantages-grid h3, .advantages-grid p {
    text-align: center !important;
    margin: auto !important;
  }
  .amenity-item {
    max-width: 80px;
  }
  .amenity-item svg {
    width: 50px;
    height: 50px;
  }
  .amenity-item p {
    font-size: 0.7em;
  }
  summary {
    font-size: 0.9em !important;
  }
  .amenities-group {
    padding-right: 0 !important;
    padding-left: 0 !important;
  }
  .the-stay-we-always-wanted h2 {
    font-size: 2em !important;
  }
  #site-footer h4 {
    font-size: 1.2em !important;
  }
  #site-footer a {
    font-size: 0.8em !important;
  }
  .footer-col h4, li {
    font-size: 0.8em !important;
  }
  .property-cards a {
    font-size: 0.7em !important;
    padding: 10px !important;
  }
  .property-card {
    gap: 0;
  }
  .property-cards > h2 {
    font-size: 1.1em !important;
  }
  .property-cards p {
    font-size: 0.8em !important;
  }
  #site-header {
    padding: 0;
  }
  .header-logo img {
    max-width: 130px !important;
  }
  .discounts-offers-grid, .private-rooms-grid {
    grid-template-columns: 1fr !important;
  }
  .private-rooms-grid p {
    font-size: 0.8em !important;
  }
  .private-rooms-grid h2 {
    margin: auto !important;
  }
  .property-card {
    margin: auto !important;
  }
}

.properties-heading {
  font-size: 2.5em !important;
  margin-bottom: 0 !important;
}

.reviews-carousel {
  max-width: 100% !important;
}

.faq-heading {
  margin: auto !important;
}

/* Container styling */
.wp-block-details {
    border-top: 1px solid #ffffff66; /* Subtle white line above */
    padding-top: 20px !important;
    padding-bottom: 0;
    margin: 0 !important;
}

/* Remove the default triangle */
.wp-block-details summary {
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: pointer;
    font-weight: 500;
    font-size: 1.1rem;
    padding: 10px 0;
}

.wp-block-details summary::-webkit-details-marker {
    display: none;
}

/* Add the Plus (+) icon */
.wp-block-details summary::after {
    content: "+";
    font-size: 1.5rem;
    font-weight: 300;
    transition: transform 0.3s ease;
}

/* Change to Minus (-) when open */
.wp-block-details[open] summary::after {
    content: "\2013"; /* En dash for a cleaner minus look */
}

/* Content styling (the text that reveals) */
.wp-block-details p {
    padding-top: 15px;
    padding-bottom: 10px;
    opacity: 0.9;
    font-size: 0.95rem;
    line-height: 1.6;
}

/* Add a line at the very bottom of the last item */
.wp-block-details:last-of-type {
    padding-bottom: 20px !important;
    border-bottom: 1px solid #ffffff66;
}

/* Ensure the container spans 100% and remove theme restrictions */
.wp-block-details {
    width: 100% !important;
    max-width: 100% !important;
    border-top: 1px solid #ffffff66;
    margin-left: 0 !important;
    margin-right: 0 !important;
    box-sizing: border-box;
}

/* Make the summary (header) use the full width for the plus/minus icon */
.wp-block-details summary {
    list-style: none;
    display: flex;
    justify-content: space-between; /* This pushes the text left and icon right */
    align-items: center;
    width: 100%;
    cursor: pointer;
    font-weight: 500;
    padding: 10px 0;
}

/* Ensure content also follows the width */
.wp-block-details div, 
.wp-block-details p {
    width: 100%;
    padding-top: 15px;
}

/* Hide default marker for all browsers */
.wp-block-details summary::-webkit-details-marker {
    display: none;
}

.spacey-text {
  letter-spacing: 2px;
}

@media (max-width: 800px) {
    /* 1. Reset the main container to allow its children to mix */
    .wp-block-media-text {
        display: flex !important;
        flex-direction: column !important;
    }

    /* 2. This is the trick: display: contents makes the content wrapper 
       act as if it's not there, letting the Heading and Paragraphs 
       become direct children of the main flex box */
    .wp-block-media-text__content {
        display: contents !important;
    }

    /* 3. Assign the visual order */
    .wp-block-media-text__content .wp-block-heading {
        order: 1 !important;
        padding: 20px !important; /* Adds back padding lost from 'contents' */
        text-align: center;
    }

    .wp-block-media-text__media {
        order: 2 !important;
        margin: 0 !important;
    }

    /* Targets everything else in the content area (paragraphs, buttons, etc) */
    .wp-block-media-text__content > *:not(.wp-block-heading) {
        order: 3 !important;
        padding: 20px !important;
        margin: 0 !important;
    }

    .the-stay-we-always-wanted figure {
    width: min(90%, 250px);
    margin: auto;
  }
}

.reviews-carousel p {
  line-height: 1.6em;
}

.more-than-1000 {
  text-align: left !important;
}

.home-hero-banner h2 {
  text-shadow: none !important;
}

.amenities-group {
  margin-bottom: 3em !important;
}

.discounts-offers-grid * {
  padding: 15px;
}

.faq-heading {
  padding-top: 1em !important;
  padding-bottom: 1em !important;
}

.property-description {
  max-width: 600px;
}

.room-details {
  margin-top: 7em !important;
}
