/*
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: Arial, Helvetica, 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;
}

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

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

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

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

.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:80px !important;
  border-radius:50%;
  padding:10px;
}

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

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

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

.property-cards {
  display: flex;
  flex-wrap: wrap !important;
  justify-content: center;
  gap: 40px;
}

.property-card {
  min-height: 700px;
  flex-basis: 400px;
}

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

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

.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;
}

.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;
}

.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;
}

/* ============================
   HEADER LAYOUT
============================ */
.header-container {
  max-width: 1400px;
  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;
  }
}

@media (max-width: 400px) {
  .hero-banner {
    padding-left: 1em !important;
  }

  .already-have-a-location-in-mind {
    padding: 1em !important;
  }
}

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

#site-footer {
  background: #34485a; /* original rgb(52,72,90) */
  color: #f7f7f7;
  padding: 70px 40px;
  font-family: Roboto, sans-serif;
}

#site-footer a {
  color: #e7dbbb; /* pale-gold accent */
  text-decoration: none;
}

#site-footer h4 {
  color: #e7dbbb;
  margin-bottom: 20px;
  text-align: center;
}

/* ---------------------------
   CONTAINER
---------------------------- */
.footer-container {
  max-width: 960px;
  margin: 0 auto;
}

/* ---------------------------
   TOP ROW (3 columns)
---------------------------- */

.footer-top {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
  justify-content: space-between;
}

.footer-col {
  flex: 1 1 250px;
  min-width: 250px;
}

/* Logo column */
.footer-logo {
  display: block;
  margin: 0 auto 20px;
  max-width: 220px;
  height: auto;
}

/* Nav lists */
.footer-nav {
  list-style: none;
  padding: 0;
}

.footer-nav li {
  margin: 6px 0;
}

.footer-nav a:hover {
  opacity: 0.85;
}

/* Divider */
.footer-divider {
  border-top: 2px solid #777;
  margin: 40px 0;
}

/* ---------------------------
   BOTTOM ROW
---------------------------- */

.footer-bottom {
  text-align: center;
  color: #e7dbbb;
  line-height: 1.7;
}
