/*
Theme Name: SQ Web
Theme URI: 
Author: SQ 3D
Author URI: 
Description: A custom theme made by SQ 3D team, tailored to your needs.
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 5.7
Version: 1.1.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: sq-web
Tags: 
*/

/* =============================================================================
   COCOTIERS HOTEL — GLOBAL STYLESHEET
   Covers: reset, CSS vars, typography, utilities, buttons, announcement bar,
   header/nav, mobile menu, footer, WhatsApp float, scroll-reveal, animations.
   Block-specific styles live in each block's own css/style.css.
   ========================================================================== */

/* ── 1. RESET ─────────────────────────────────────────────────────────────── */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--wp--preset--font-family--body, "Jost", sans-serif);
  font-size: var(--wp--preset--font-size--base, 1rem);
  color: var(--wp--preset--color--ink, #2c2c3e);
  background-color: var(--wp--preset--color--white, #ffffff);
  line-height: 1.7;
  overflow-x: hidden;
}

img,
video {
  display: block;
  max-width: 100%;
  height: auto;
}

a {
  text-decoration: none;
  color: inherit;
}

ul,
ol {
  list-style: none;
}

button {
  font-family: inherit;
  cursor: pointer;
  border: none;
  background: none;
}

:focus-visible {
  outline: 2px solid var(--wp--preset--color--teal, #2a9d8f);
  outline-offset: 3px;
}

/* Skip-to-content link (accessibility) */
.skip-to-content {
  position: absolute;
  top: -100%;
  left: 1rem;
  background: var(--wp--preset--color--teal, #2a9d8f);
  color: #fff;
  padding: 0.6rem 1.2rem;
  border-radius: 0 0 6px 6px;
  font-size: 0.85rem;
  font-weight: 600;
  z-index: 9999;
  transition: top 0.2s;
}

.skip-to-content:focus {
  top: 0;
}

/* ── 2. CSS CUSTOM PROPERTIES ─────────────────────────────────────────────── */
/* Shadow and radius tokens not expressible in theme.json */
:root {
  --shadow-sm: 0 2px 12px rgba(0, 0, 0, 0.08);
  --shadow-md: 0 8px 32px rgba(0, 0, 0, 0.12);
  --shadow-lg: 0 20px 60px rgba(0, 0, 0, 0.18);
  --radius: 12px;
  --transition: 0.35s cubic-bezier(0.4, 0, 0.2, 1);

  /* Convenience aliases for blocks that can't use wp preset vars */
  --color-teal: var(--wp--preset--color--teal, #2a9d8f);
  --color-teal-dark: var(--wp--preset--color--teal-dark, #1d7168);
  --color-teal-light: var(--wp--preset--color--teal-light, #4fc3b4);
  --color-teal-mist: var(--wp--preset--color--teal-mist, #e8f7f5);
  --color-sand: var(--wp--preset--color--sand, #f9f5ee);
  --color-charcoal: var(--wp--preset--color--charcoal, #1a1a2e);
  --color-ink: var(--wp--preset--color--ink, #2c2c3e);
  --color-stone: var(--wp--preset--color--stone, #6b7280);
  --color-white: var(--wp--preset--color--white, #ffffff);
  --color-gold: var(--wp--preset--color--gold, #c9a84c);

  --ff-display: var(
    --wp--preset--font-family--display,
    "Cormorant Garamond",
    Georgia,
    serif
  );
  --ff-body: var(--wp--preset--font-family--body, "Jost", sans-serif);
}

/* ── 3. UTILITY CLASSES ───────────────────────────────────────────────────── */
.container {
  max-width: var(--wp--style--global--content-size, 1200px);
  margin-inline: auto;
  padding-inline: 2rem;
}

/* Section eyebrow tag */
.section-tag {
  /* display: inline-block; */
  font-family: var(--ff-body);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-teal);
  margin-bottom: 0.75rem;
}

/* Section heading */
.section-title {
  font-family: var(--ff-display);
  font-size: clamp(2rem, 4vw, 3.2rem);
  font-weight: 400;
  color: var(--color-charcoal);
  line-height: 1.2;
}

.section-title em {
  font-style: italic;
  color: var(--color-teal);
}

/* scroll to top */
#scroll-to-top {
  /* Positioning */
  position: fixed;
  bottom: 110px;
  right: 2rem;
  z-index: 98;

  /* Appearance */
  background-color: #2a9d8f; /* Teal */
  color: #ffffff; /* White */
  border: none;
  border-radius: 50%;
  width: 50px;
  height: 50px;
  cursor: pointer;

  /* Flex centering for the SVG icon */
  display: flex;
  align-items: center;
  justify-content: center;

  /* Visibility - Controlled by JS toggle */
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease-in-out;
  box-shadow: 0 4px 12px rgba(26, 26, 46, 0.2); /* Using Charcoal for shadow */
}

/* The class toggled by your JavaScript */
#scroll-to-top.visible {
  opacity: 1;
  visibility: visible;
}

#scroll-to-top:hover {
  background-color: #1d7168; /* Teal Dark */
  transform: translateY(-3px);
  box-shadow: 0 6px 16px rgba(26, 26, 46, 0.3);
}

#scroll-to-top:active {
  transform: translateY(0);
}

/* Ensure the icon scales nicely */
#scroll-to-top svg {
  width: 24px;
  height: 24px;
}
/* Adjust for mobile screens to match your WhatsApp media query */
@media (max-width: 380px) {
  #scroll-to-top {
    bottom: 85px;
    right: 1rem;
    width: 45px;
    height: 45px;
  }
}

/* Scroll-reveal */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition:
    opacity 0.7s ease,
    transform 0.7s ease;
}

.reveal.is-visible {
  opacity: 1;
  transform: none;
}

/* ── 4. BUTTONS ───────────────────────────────────────────────────────────── */
/* Base — applies to .btn and to WP core/button */
.btn,
.wp-block-button__link {
  /* display: inline-flex; */
  align-items: center;
  gap: 0.5rem;
  padding: 0.9rem 2.2rem;
  font-family: var(--ff-body);
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border-radius: 3px;
  border: none;
  cursor: pointer;
  text-align: center;
  white-space: nowrap;
}

@media (prefers-reduced-motion: no-preference) {
  .btn,
  .wp-block-button__link {
    transition:
      background var(--transition),
      color var(--transition),
      border-color var(--transition),
      box-shadow var(--transition),
      transform var(--transition);
  }
}

/* Primary — solid teal */
.btn-primary,
.wp-block-button.is-style-fill .wp-block-button__link {
  background: var(--color-teal);
  color: var(--color-white) !important;
  border: none;
}

.btn-primary:hover,
.btn-primary:focus-visible,
.wp-block-button.is-style-fill .wp-block-button__link:hover,
.wp-block-button.is-style-fill .wp-block-button__link:focus-visible {
  background: var(--color-teal-dark) !important;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(42, 157, 143, 0.35);
}

/* Outline — transparent with teal border (light context) */
.btn-outline,
.wp-block-button.is-style-outline .wp-block-button__link {
  background: transparent;
  color: var(--white);
  border: 1.5px solid rgba(255, 255, 255, 0.7);
}

.btn-outline:hover,
.btn-outline:focus-visible,
.wp-block-button.is-style-outline .wp-block-button__link:hover,
.wp-block-button.is-style-outline .wp-block-button__link:focus-visible {
  background: rgba(255, 255, 255, 0.15) !important;
}

/* Outline on dark backgrounds (charcoal sections, hero covers) */
.has-charcoal-background-color
  .wp-block-button.is-style-outline
  .wp-block-button__link,
.wp-block-cover .wp-block-button.is-style-outline .wp-block-button__link,
.btn-outline.on-dark {
  color: var(--color-white) !important;
  border-color: rgba(255, 255, 255, 0.7) !important;
}

.has-charcoal-background-color
  .wp-block-button.is-style-outline
  .wp-block-button__link:hover,
.wp-block-cover .wp-block-button.is-style-outline .wp-block-button__link:hover,
.btn-outline.on-dark:hover {
  background: rgba(255, 255, 255, 0.15) !important;
  border-color: var(--color-white) !important;
}

/* White — for CTA banner on dark gradient bg */
.btn-white {
  background: var(--color-white);
  color: var(--color-teal-dark) !important;
  border: none;
}

.btn-white:hover,
.btn-white:focus-visible {
  background: var(--color-sand);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

/* ── 5. ANNOUNCEMENT BAR ──────────────────────────────────────────────────── */
.announcement-bar {
  background: var(--color-teal-dark);
  color: rgba(255, 255, 255, 0.92);
  text-align: center;
  padding: 0.55rem 1rem;
  font-family: var(--ff-body);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  position: relative;
  z-index: 1000;
}

.announcement-bar a {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.announcement-bar a:hover {
  color: var(--color-white);
}

/* Dismiss button */
.announcement-dismiss {
  position: absolute;
  right: 1rem;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: rgba(255, 255, 255, 0.65);
  cursor: pointer;
  padding: 0.2rem;
  line-height: 1;
  font-size: 1rem;
  transition: color var(--transition);
}

.announcement-dismiss:hover {
  color: var(--color-white);
}

.announcement-bar.is-hidden {
  display: none;
}

@media screen and (min-width: 769px) {
  .trp-floating-switcher {
    display: none !important;
  }

  .trp-block-container {
    display: block;
  }
}

@media screen and (max-width: 768px) {
  .trp-floating-switcher {
    display: block;
    z-index: 99 !important;
  }
  .trp-block-container {
    display: none !important;
  }
}

/* ==========================================================================
   COCOTIERS HOTEL – WORDPRESS NAVIGATION (SIMPLIFIED & FIXED)
   ========================================================================== */

/* ----- 1. HEADER BACKDROP (prevents overlay trapping) ----- */
.wp-block-template-part[class*="site-header"],
header.wp-block-template-part,
#site-header {
  position: sticky;
  top: 0;
  z-index: 900;
  border-bottom: 1px solid rgba(42, 157, 143, 0.12);
}

.wp-block-template-part[class*="site-header"]::before,
header.wp-block-template-part::before,
#site-header::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: rgba(255, 255, 255, 0.97);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  pointer-events: none;
}

/* ----- 2. HEADER INNER CONTAINER ----- */
.wp-block-template-part .wp-block-column > .wp-block-group {
  padding: 0 !important;
  min-height: 74px;
  align-items: center;
}

.wp-block-template-part .wp-block-group.alignfull {
  max-width: 1200px;
  margin-inline: auto;
  padding-inline: 2rem;
  width: 100%;
}

/* ----- 3. LOGO ----- */
/* .wp-block-site-logo img.custom-logo {
  height: 48px;
  width: auto;
  object-fit: contain;
} */

/* ----- 4. DESKTOP NAVIGATION (horizontal) ----- */
.wp-block-navigation,
.wp-block-navigation.is-layout-flex {
  gap: 0 !important;
  padding: 0 !important;
}

.wp-block-navigation__container {
  gap: 0.25rem; /* small gap between items */
}

.wp-block-navigation-item__content {
  font-family: var(--wp--preset--font-family--body, "Jost", sans-serif);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #2c2c3e;
  padding: 0.4rem 0.75rem;
  border-radius: 3px;
  text-decoration: none !important;
  position: relative;
  white-space: nowrap;
  transition: color 0.35s ease;
}

/* Teal underline accent */
.wp-block-navigation-item__content::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 50%;
  width: 0;
  height: 2px;
  background: #2a9d8f;
  transform: translateX(-50%);
  transition: width 0.35s ease;
}

.wp-block-navigation-item__content:hover,
.wp-block-navigation-item.current-menu-item .wp-block-navigation-item__content {
  color: #2a9d8f;
}

.wp-block-navigation-item__content:hover::after,
.wp-block-navigation-item.current-menu-item
  .wp-block-navigation-item__content::after {
  width: 60%;
}

/* Submenu container */
.wp-block-navigation__submenu-container {
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
  padding: 0.75rem 0;
  min-width: 200px;
  border: 1px solid rgba(42, 157, 143, 0.1);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: all 0.2s ease;
}

.wp-block-navigation-item.has-child:hover
  > .wp-block-navigation__submenu-container,
.wp-block-navigation-item.has-child:focus-within
  > .wp-block-navigation__submenu-container {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.wp-block-navigation__submenu-container .wp-block-navigation-item__content {
  font-size: 0.75rem;
  padding: 0.6rem 1.2rem;
  text-transform: none;
  letter-spacing: 0.05em;
  color: #2c2c3e;
}

.wp-block-navigation__submenu-container
  .wp-block-navigation-item__content:hover {
  background: rgba(42, 157, 143, 0.08);
  color: #2a9d8f;
}

/* Submenu toggle icon */
.wp-block-navigation-submenu__toggle {
  margin-left: 0.15rem;
  padding: 0;
  background: transparent;
  border: none;
  cursor: pointer;
}

/* ----- 5. BOOK NOW BUTTON (desktop) ----- */
.wp-block-navigation .wp-block-buttons {
  margin-left: 0.5rem;
}

.wp-block-navigation .wp-block-button__link {
  font-family: var(--wp--preset--font-family--body, "Jost", sans-serif);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  background: #2a9d8f !important;
  color: #fff !important;
  padding: 0.5rem 1.1rem !important;
  border-radius: 3px !important;
  text-decoration: none !important;
  transition: all 0.35s ease;
}

.wp-block-navigation .wp-block-button__link:hover {
  background: #1d7168 !important;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(42, 157, 143, 0.35);
}

/* ----- 6. RESPONSIVE WRAPPING (prevent horizontal scroll) ----- */
/* At 1024px and below, allow wrapping and reduce padding */
@media (max-width: 1024px) {
  .wp-block-navigation__container {
    flex-wrap: wrap;
    justify-content: center;
  }
  .wp-block-navigation-item__content {
    padding: 0.4rem 0.5rem;
    font-size: 0.72rem;
  }
  .wp-block-navigation .wp-block-button__link {
    padding: 0.4rem 0.9rem !important;
    font-size: 0.72rem;
  }
}

/* At 768px, ensure the header container doesn't overflow */
@media (max-width: 768px) {
  .wp-block-template-part .wp-block-group.alignfull {
    padding-inline: 1rem;
  }
}

/* ----- 7. MOBILE OVERLAY STYLES (only when open) ----- */
.wp-block-navigation__responsive-container.is-menu-open {
  background: rgba(26, 26, 46, 0.97) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}
/* Reduce gap between parent and children in overlay */
.wp-block-navigation__responsive-container.is-menu-open
  .wp-block-navigation__container {
  gap: 0.2rem; /* was 0.5rem */
}

/* Highlight current menu item in mobile overlay */
.wp-block-navigation__responsive-container.is-menu-open
  .wp-block-navigation-item.current-menu-item
  .wp-block-navigation-item__content {
  color: #4fc3b4 !important; /* teal light */
}

/* Optional: slightly reduce submenu item padding */
.wp-block-navigation__responsive-container.is-menu-open
  .wp-block-navigation__submenu-container
  .wp-block-navigation-item__content {
  padding: 0.25rem 1rem !important; /* was 0.5rem */
}

/* Remove excessive top padding from submenu in mobile overlay */
.wp-block-navigation__responsive-container.is-menu-open
  .wp-block-navigation__submenu-container {
  padding-top: 0.25rem !important; /* was 2em */
  padding-bottom: 0.25rem !important;
}

.wp-block-navigation__responsive-container.is-menu-open
  .wp-block-navigation__responsive-container-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 100%;
  /* padding: 5rem 2rem 3rem !important; */
}

.wp-block-navigation__responsive-container.is-menu-open
  .wp-block-navigation__container {
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
}

/* Overlay link style (using same body font for simplicity) */
.wp-block-navigation__responsive-container.is-menu-open
  .wp-block-navigation-item__content {
  font-family: var(
    --wp--preset--font-family--body,
    "Jost",
    sans-serif
  ) !important;
  font-size: 1rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  color: rgba(255, 255, 255, 0.9) !important;
  padding: 0.75rem 1rem !important;
  text-align: center;
}

.wp-block-navigation__responsive-container.is-menu-open
  .wp-block-navigation-item__content::after {
  display: none;
}

.wp-block-navigation__responsive-container.is-menu-open
  .wp-block-navigation-item__content:hover {
  color: #4fc3b4 !important;
}

/* Submenu in overlay – shown inline (no toggle needed) */
.wp-block-navigation__responsive-container.is-menu-open
  .wp-block-navigation__submenu-container {
  background: transparent;
  box-shadow: none;
  padding: 0.25rem 0;
  position: static;
  opacity: 1;
  visibility: visible;
  transform: none;
  border: none;
  text-align: center;
}

.wp-block-navigation__responsive-container.is-menu-open
  .wp-block-navigation__submenu-container
  .wp-block-navigation-item__content {
  font-size: 0.8rem !important;
  padding: 0.5rem 1rem !important;
  color: rgba(255, 255, 255, 0.7) !important;
}

/* Book Now button in overlay */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-buttons {
  margin-top: 2rem;
  width: 100%;
  justify-content: center;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-button__link {
  font-size: 0.9rem !important;
  padding: 0.9rem 2.5rem !important;
}

/* Close button */
.wp-block-navigation__responsive-container-close {
  background: rgba(255, 255, 255, 0.08) !important;
  border: 1px solid rgba(255, 255, 255, 0.18) !important;
  border-radius: 50%;
  color: rgba(255, 255, 255, 0.8) !important;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.35s ease;
}

.wp-block-navigation__responsive-container-close:hover {
  background: #2a9d8f !important;
  border-color: #2a9d8f !important;
  color: #fff !important;
}

/* ── 8. FOOTER ────────────────────────────────────────────────────────────── */
#site-footer,
footer.site-footer {
  background: var(--color-charcoal);
  color: rgba(255, 255, 255, 0.75);
  padding: 4.5rem 0 0;
}

.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1.5fr;
  gap: 3rem;
  padding-bottom: 3rem;
}

/* Brand column */
.footer-brand .logo-text {
  color: var(--color-teal-light);
  font-size: 1.7rem;
}
.footer-brand .logo-sub {
  color: rgba(255, 255, 255, 0.45);
}

.footer-brand p {
  font-size: 0.88rem;
  line-height: 1.7;
  margin: 1.2rem 0 1.6rem;
  color: rgba(255, 255, 255, 0.55);
}

/* Footer headings */
.footer-heading,
#site-footer h4,
footer.site-footer h4 {
  font-family: var(--ff-body);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-white);
  margin-bottom: 1.2rem;
}

/* Footer links */
.footer-links li {
  margin-bottom: 0.65rem;
}

.footer-links a {
  font-size: 0.88rem;
  color: rgba(255, 255, 255, 0.55);
}

@media (prefers-reduced-motion: no-preference) {
  .footer-links a {
    transition: color var(--transition);
  }
}

.footer-links a:hover {
  color: var(--color-teal-light);
}

/* Social icons */
.footer-social {
  display: flex;
  gap: 0.6rem;
  flex-wrap: wrap;
}

.social-link {
  width: 38px;
  height: 38px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.06);
  color: rgba(255, 255, 255, 0.65);

  & img {
    width: 24px;
    height: 24px;
  }
}

@media (prefers-reduced-motion: no-preference) {
  .social-link {
    transition:
      background var(--transition),
      color var(--transition),
      transform var(--transition);
  }
}

.social-link:hover {
  background: var(--color-teal);
  color: var(--color-white);
  transform: translateY(-3px);
}

/* Contact items */
.footer-contact-item {
  display: flex;
  align-items: flex-start;
  gap: 0.7rem;
  margin-bottom: 0.85rem;
  margin-top: 0;
}

.footer-contact-item svg {
  flex-shrink: 0;
  color: var(--color-teal-light);
  margin-top: 2px;
}

.footer-contact-item span,
.footer-contact-item a {
  font-size: 0.87rem;
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.5;
}

.footer-contact-item a:hover {
  color: var(--color-teal-light);
}

/* Award badges */
.footer-awards {
  display: flex;
  gap: 0.75rem;
  margin-top: 1.2rem;
  flex-wrap: wrap;
}

.award-badge {
  padding: 0.5rem 0.9rem;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 6px;
  font-size: 0.75rem;
  color: rgba(255, 255, 255, 0.6);
  letter-spacing: 0.05em;
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.award-badge strong {
  color: var(--color-gold);
  display: block;
  font-size: 0.8rem;
}

/* Footer bottom bar */
.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  padding: 1.5rem 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
}

.footer-bottom p {
  font-size: 0.78rem;
  color: rgba(255, 255, 255, 0.35);
}

.footer-bottom a {
  color: var(--color-teal-light);
}

.footer-bottom a:hover {
  color: var(--color-teal-light);
  text-decoration: underline;
}

/* Payment chips */
.payment-icons {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.payment-chip {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 4px;
  padding: 0.3rem 0.6rem;
  font-size: 0.68rem;
  color: rgba(255, 255, 255, 0.5);
  font-weight: 600;
  letter-spacing: 0.05em;
}

/* ── 9. WHATSAPP FLOATING BUTTON ──────────────────────────────────────────── */
.whatsapp-float {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  z-index: 99;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.6rem;
  pointer-events: none;
}

/* Tooltip bubble */
.whatsapp-bubble {
  background: var(--color-white);
  color: var(--color-ink);
  padding: 0.7rem 1.1rem;
  border-radius: 12px 12px 0 12px;
  box-shadow: var(--shadow-md);
  font-family: var(--ff-body);
  font-size: 0.82rem;
  font-weight: 500;
  line-height: 1.4;
  max-width: 220px;
  pointer-events: none;
  opacity: 0;
  transform: translateY(8px) scale(0.95);
}

@media (prefers-reduced-motion: no-preference) {
  .whatsapp-bubble {
    transition:
      opacity var(--transition),
      transform var(--transition);
  }
}

/* Show bubble on hover or when forced open */
.whatsapp-float:hover .whatsapp-bubble,
.whatsapp-float.bubble-visible .whatsapp-bubble {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

/* Close button inside bubble */
.whatsapp-bubble-close {
  display: inline-block;
  margin-left: 0.4rem;
  font-size: 0.9rem;
  line-height: 1;
  color: var(--color-stone);
  cursor: pointer;
  vertical-align: middle;
}

.whatsapp-bubble-close:hover {
  color: var(--color-ink);
}

/* The round WhatsApp button */
.whatsapp-btn {
  width: 58px;
  height: 58px;
  background: #25d366;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(37, 211, 102, 0.45);
  text-decoration: none;
  position: relative;
  pointer-events: auto;
}

@media (prefers-reduced-motion: no-preference) {
  .whatsapp-btn {
    transition:
      transform var(--transition),
      box-shadow var(--transition);
  }
}

.whatsapp-btn:hover,
.whatsapp-btn:focus-visible {
  transform: scale(1.1);
  box-shadow: 0 6px 28px rgba(37, 211, 102, 0.55);
}

/* Pulse ring */
.whatsapp-pulse {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: rgba(37, 211, 102, 0.4);
  animation: wa-pulse 2.2s ease-out infinite;
  pointer-events: none;
}

@keyframes wa-pulse {
  0% {
    transform: scale(1);
    opacity: 0.7;
  }
  70% {
    transform: scale(1.55);
    opacity: 0;
  }
  100% {
    transform: scale(1.55);
    opacity: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .whatsapp-pulse {
    display: none;
  }
}

/* Hide on very small screens if needed */
@media (max-width: 380px) {
  .whatsapp-float {
    bottom: 1rem;
    right: 1rem;
  }

  .whatsapp-btn {
    width: 50px;
    height: 50px;
  }
}

/* ── 10. SCROLL-REVEAL ANIMATIONS ─────────────────────────────────────────── */
@media (prefers-reduced-motion: no-preference) {
  @keyframes fadeUp {
    from {
      opacity: 0;
      transform: translateY(28px);
    }
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }

  @keyframes fadeIn {
    from {
      opacity: 0;
    }
    to {
      opacity: 1;
    }
  }

  @keyframes slideInLeft {
    from {
      opacity: 0;
      transform: translateX(-40px) scale(0.97);
    }
    to {
      opacity: 1;
      transform: none;
    }
  }

  @keyframes slideInRight {
    from {
      opacity: 0;
      transform: translateX(40px) scale(0.97);
    }
    to {
      opacity: 1;
      transform: none;
    }
  }

  /* Hero animations (applied via inline style on hero elements) */
  .hero-eyebrow {
    animation: fadeUp 0.8s 0.3s both;
  }
  .hero h1 {
    animation: fadeUp 0.9s 0.5s both;
  }
  .hero-desc {
    animation: fadeUp 0.9s 0.7s both;
  }
  .hero-actions {
    animation: fadeUp 0.9s 0.9s both;
  }
  .hero-scroll {
    animation: fadeIn 1s 1.3s both;
  }

  @keyframes heroZoom {
    from {
      transform: scale(1.08);
    }
    to {
      transform: scale(1);
    }
  }

  .hero-bg {
    animation: heroZoom 14s ease-out forwards;
  }

  @keyframes scrollBounce {
    0%,
    100% {
      transform: scaleY(1) translateY(0);
    }
    50% {
      transform: scaleY(0.6) translateY(6px);
    }
  }

  .scroll-line {
    animation: scrollBounce 2s 2s ease-in-out infinite;
  }
}

/* Reduced-motion fallback: just show everything */
@media (prefers-reduced-motion: reduce) {
  .reveal,
  .hero-eyebrow,
  .hero h1,
  .hero-desc,
  .hero-actions,
  .hero-scroll {
    opacity: 1;
    transform: none;
    animation: none;
    transition: none;
  }
}

/* ── 11. INTERACTIVE STATES & SHARED TRANSITIONS ──────────────────────────── */
@media (prefers-reduced-motion: no-preference) {
  /* Card lift — used by amenity cards and similar */
  .card-hover {
    transition:
      transform var(--transition),
      box-shadow var(--transition);
  }

  .card-hover:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-md);
  }

  /* Image hover zoom — used inside card/gallery items */
  .img-zoom {
    transition: transform 0.6s ease;
  }

  .img-zoom:hover {
    transform: scale(1.07);
  }
}

/* ── 12. RESPONSIVE ───────────────────────────────────────────────────────── */
@media (max-width: 1024px) {
  .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: 2.5rem;
  }
}

@media (max-width: 768px) {
  .container {
    padding-inline: 1.25rem;
  }

  .footer-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .footer-bottom {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.75rem;
  }
}

@media (max-width: 480px) {
  .footer-grid {
    padding-bottom: 2rem;
  }
  .footer-brand p {
    font-size: 0.84rem;
  }
}
/* =============================================================================
   COCOTIERS HOTEL — Contact Form 7 Full Styles
   ============================================================================= */

/* ── Form Header ── */
.cf7-form-header {
  margin-bottom: 2rem;
}

.cf7-form-header h3 {
  font-family: var(
    --wp--preset--font-family--display,
    "Cormorant Garamond",
    serif
  );
  font-size: 1.65rem;
  font-weight: 500;
  color: #1a1a2e;
  line-height: 1.2;
  margin-bottom: 0.35rem;
}

.cf7-form-header p {
  font-size: 0.9rem;
  color: #6b7280;
  margin: 0;
}

/* ── Grid Layout Fix (Crucial for CF7 Span Wrappers) ── */
.cf7-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
  margin-bottom: 1.25rem;
}

/* Forces CF7's internal span wrappers to occupy the full grid cell */
.cf7-row .wpcf7-form-control-wrap {
  display: block;
  width: 100%;
}

@media (max-width: 600px) {
  .cf7-row {
    grid-template-columns: 1fr;
  }
}

/* ── Labels ── */
.cf7-label,
.cf7-field-label {
  display: block;
  font-family: var(--wp--preset--font-family--body, "Jost", sans-serif);
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #1a1a2e;
  margin-bottom: 0.6rem;
}

.cf7-required {
  color: #2a9d8f;
  margin-left: 2px;
}

/* ── Text Inputs, Selects, & Textareas (Excluding Radio/Acceptance) ── */
.wpcf7-form-control:not(.wpcf7-submit):not(.wpcf7-radio):not(
    .wpcf7-acceptance
  ) {
  width: 100%;
  padding: 0.8rem 1rem;
  font-family: inherit;
  font-size: 0.92rem;
  color: #2c2c3e;
  background-color: #f9f5ee !important; /* The light sand background */
  border: 1.5px solid transparent !important;
  border-radius: 8px !important;
  outline: none;
  display: block;
  box-sizing: border-box;
  transition: all 0.3s ease;
}

.wpcf7-form-control:not(.wpcf7-submit):not(.wpcf7-radio):not(
    .wpcf7-acceptance
  ):focus {
  background-color: #ffffff !important;
  border-color: #2a9d8f !important;
  box-shadow: 0 0 0 3px rgba(42, 157, 143, 0.12);
}

.wpcf7 textarea {
  min-height: 130px;
  resize: vertical;
}

/* ── Subject "Pill" Tabs (Radio Buttons) ── */
.cf7-tabs .wpcf7-list-item {
  display: inline-block !important;
  margin: 0 8px 8px 0 !important;
}

/* Hide the actual radio circle */
.cf7-tabs input[type="radio"] {
  position: absolute !important;
  opacity: 0 !important;
  width: 0 !important;
  height: 0 !important;
  margin: 0 !important;
}

/* Style the text next to the hidden radio as a pill */
.cf7-tabs .wpcf7-list-item-label {
  display: inline-flex !important;
  align-items: center;
  padding: 0.5rem 1.2rem !important;
  border: 1.5px solid rgba(0, 0, 0, 0.1) !important;
  border-radius: 50px !important;
  background: #ffffff !important;
  color: #6b7280 !important;
  font-size: 0.8rem !important;
  font-weight: 500 !important;
  cursor: pointer;
  transition: all 0.3s ease;
}

/* Selected state */
.cf7-tabs input[type="radio"]:checked + .wpcf7-list-item-label {
  background: #2a9d8f !important;
  border-color: #2a9d8f !important;
  color: #ffffff !important;
}

.cf7-tabs .wpcf7-list-item-label:hover {
  border-color: #2a9d8f !important;
  color: #2a9d8f !important;
}

/* ── Privacy / Acceptance Row (No Background) ── */
.cf7-privacy-row {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  margin: 1.5rem 0;
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
}

.cf7-privacy-row .wpcf7-list-item {
  margin: 0;
  flex-shrink: 0;
}

.cf7-privacy-row input[type="checkbox"] {
  width: 18px !important;
  height: 18px !important;
  accent-color: #2a9d8f;
  margin-top: 3px;
  cursor: pointer;
}

.cf7-privacy-row .wpcf7-list-item-label {
  font-size: 0.85rem;
  color: #6b7280;
  line-height: 1.5;
}

.cf7-privacy-row a {
  color: #2a9d8f;
  text-decoration: underline;
}

/* ── Submit Button ── */
.cf7-submit,
.wpcf7-submit {
  width: 100%;
  padding: 1rem;
  background: #2a9d8f !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 8px !important;
  font-family: inherit;
  font-size: 0.88rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.3s ease;
}

.cf7-submit:hover,
.wpcf7-submit:hover {
  background: #1d7168 !important;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(42, 157, 143, 0.35);
}

/* ── Validation & Messages ── */
.wpcf7-not-valid-tip {
  color: #e05252;
  font-size: 0.75rem;
  margin-top: 5px;
  display: block;
}

.wpcf7-response-output {
  margin: 1.5rem 0 0 !important;
  padding: 1rem !important;
  border-radius: 8px !important;
  font-size: 0.88rem;
  border: none !important;
}

.wpcf7 form.sent .wpcf7-response-output {
  background: #e8f7f5 !important;
  color: #1d7168 !important;
  border-left: 4px solid #2a9d8f !important;
}

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.failed .wpcf7-response-output {
  background: #fef2f2 !important;
  color: #b91c1c !important;
  border-left: 4px solid #e05252 !important;
}

.map-embed-full {
  border-radius: 16px;
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  height: 420px;

  iframe {
    width: 100% !important;
    height: 100% !important;
    border: 0;
  }
}
/* ── Amenity Card Container ── */
.amenity-card {
  transition:
    transform 0.3s ease,
    box-shadow 0.3s ease;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
  /* display: flex;
  flex-direction: column;
  align-items: center; */
}

.amenity-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.1);
}

/* ── Icon Wrapper (The Circle) ── */
.amenity-card .wp-block-image {
  width: 54px !important;
  height: 54px !important;
  background-color: rgba(42, 157, 143, 0.1) !important; /* Light Teal Tint */
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 auto 1.5rem auto !important;
  padding: 0 !important;
}

/* ── The SVG Icon inside the Card ── */
.amenity-card .wp-block-image img {
  width: 26px !important;
  height: 26px !important;
  object-fit: contain;
  /* This filter converts a black SVG to Teal (#2A9D8F) */
  filter: invert(48%) sepia(79%) saturate(415%) hue-rotate(125deg)
    brightness(95%) contrast(88%);
}

.location-item .wp-block-image {
  width: 36px !important;
  height: 36px !important;
  background-color: rgba(42, 157, 143, 0.1) !important; /* Light Teal Tint */
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
}

/* ── The SVG Icon inside the Card ── */
.location-item .wp-block-image img {
  width: 18px !important;
  height: 18px !important;
  object-fit: contain;
  /* This filter converts a black SVG to Teal (#2A9D8F) */
  filter: invert(48%) sepia(79%) saturate(415%) hue-rotate(125deg)
    brightness(95%) contrast(88%);
}
/* Container styling to match contact.html */
.wp-block-bcn-breadcrumb-trail {
  /* border-bottom: 1px solid #eeeeee;
  font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
  font-size: 0.9rem;
  color: #666666; */
  display: flex;
  align-items: center;
  gap: 10px;
}

/* Style the links */
.wp-block-bcn-breadcrumb-trail a {
  color: #005aab; /* Matches your primary blue */
  text-decoration: none;
  transition: color 0.3s ease;
}

.wp-block-bcn-breadcrumb-trail a:hover {
  color: #003d73;
  text-decoration: underline;
}

/* Style the current page (unlinked) */
.wp-block-bcn-breadcrumb-trail .current-item {
  color: #666666;
  font-weight: 400;
}

/* Adjusting spacing for the separator */
.wp-block-bcn-breadcrumb-trail span {
  display: inline-flex;
  align-items: center;
}
