/* ==========================
   Base / Typography
   ========================== */
:root {
   --brand-brown: #75503E;
   --soft-peach: #EFD9D1;
   --muted-text: #5a4a43;
   --page-bg: #F5EBDD;
}

html,
body {
   height: 100%;
}

body {
   font-family: 'Lato', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
   background-color: var(--page-bg);
   padding-top: 70px;
   /* compensate fixed navbar */
   color: var(--muted-text);
}

/* ==========================
   Utilities / Buttons
   ========================== */
.btn-reserve {
   background-color: var(--soft-peach);
   color: #000;
   border: none;
   border-radius: 6px;
   padding: 0.45rem 0.9rem;
}

.btn-reserve:hover {
   filter: brightness(0.95);
}

/* ==========================
   Navbar / Header
   ========================== */
.navbar {
   padding-top: 0.6rem;
   padding-bottom: 0.6rem;
   border-bottom: none;
}

.navbar-brand {
   font-family: 'Playfair Display', serif;
   font-size: 1.4rem;
   font-weight: 700;
   letter-spacing: 0.03em;
   margin-right: 0.75rem;
   color: var(--brand-brown);
}

@media (min-width:768px) {
   .navbar-brand {
      font-size: 1.6rem;
      letter-spacing: 0.04em;
   }
}

.navbar-nav .nav-link {
   font-family: 'Lato', sans-serif;
   font-weight: 400;
   letter-spacing: 0.02em;
   color: var(--brand-brown);
}

.navbar-nav .nav-link:hover {
   color: var(--soft-peach);
}

@media (max-width:767px) {
   body {
      padding-top: 80px;
   }
}

/* ==========================
   Services / Cards
   ========================== */
#services h2 {
   color: var(--brand-brown);
   font-family: 'Playfair Display', serif;
}

.card .card-title {
   font-family: 'Playfair Display', serif;
   font-weight: 600;
   color: var(--brand-brown);
   text-align: center;
}

.card .card-sub-title {
   font-weight: 600;
}

/* Badges unifié - Durée */
.badge.badge-duration {
   background: var(--soft-peach);
   color: var(--brand-brown);
   padding: 0.55rem 0.75rem;
   border-radius: 0.6rem;
   font-weight: 600;
   font-size: 0.9rem;
}

/* Badges unifié - Prix */
.badge.badge-price {
   background: var(--soft-peach);
   color: var(--brand-brown);
   padding: 0.55rem 0.75rem;
   border-radius: 0.6rem;
   font-weight: 600;
   font-size: 0.9rem;
}

/* card description & list */
.card-description {
   text-align: justify;
}

.card-description p {
   margin-bottom: 0.6rem;
   line-height: 1.5;
}

.card-list {
   margin-top: 0.5rem;
   padding-left: 2rem;
   display: inline-block;
   text-align: left;
}

.card-list li {
   margin-bottom: 0.35rem;
}

/* card visuals */
.card {
   border: none;
   box-shadow: 0 8px 24px rgba(117, 80, 62, 0.06);
   transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.card:hover {
   transform: translateY(-4px);
   box-shadow: 0 14px 34px rgba(117, 80, 62, 0.09);
}

.card-img-top {
   width: 100%;
   height: 300px;
   object-fit: cover;
   border-top-left-radius: 8px;
   border-top-right-radius: 8px;
}

@media (max-width:576px) {
   .card-img-top {
      height: 300px;
   }
}

/* ==========================
   Footer
   ========================== */
footer.bg-light {
   background-color: #FAF9F6;
   background-image: linear-gradient(rgba(250, 249, 246, 0.92), rgba(250, 249, 246, 0.92)), url('../assets/img/logo-info-section.png?v=1.0.0');
   background-size: cover;
   background-position: center;
   background-repeat: no-repeat;
}

footer h5 {
   color: var(--brand-brown);
   margin-bottom: 0.75rem;
   font-family: 'Montserrat', sans-serif;
   font-weight: 300;
}

footer p,
footer a {
   color: var(--muted-text);
   font-family: 'Montserrat', sans-serif;
   font-weight: 300;
}

footer a {
   color: var(--brand-brown);
   text-decoration: none;
}

footer a:hover {
   text-decoration: underline;
}

.footer-icon {
   width: 18px;
   height: 18px;
   vertical-align: -2px;
}

/* Brand italic for footer */
.brand-italic {
   font-family: 'Playfair Display', serif;
   font-style: italic;
   font-weight: 600;
   color: var(--brand-brown);
}

/* Map section */
#map h3 {
   color: var(--brand-brown);
   margin-bottom: 0.25rem;
}

#map p {
   color: var(--muted-text);
   margin-bottom: 1rem;
}

@media (max-width:576px) {
   #map .ratio {
      min-height: 200px;
   }
}

/* small helper -- keep legacy selector for compatibility if needed */
.btn-reserver {
   display: none !important;
}

/* Navbar always visible: removed mobile hide/show behavior
   Keep the fixed navbar and body top padding for all viewports */
@media (max-width: 767px) {

   /* ensure consistent spacing when navbar is fixed-top on small screens */
   body {
      padding-top: 80px;
   }
}

/* Opening announcement banner */
.opening-banner .p-3 {
   background: linear-gradient(90deg, rgba(239, 217, 209, 0.95) 0%, rgba(168, 187, 162, 0.06) 100%);
   border: 1px solid rgba(117, 80, 62, 0.06);
}

.opening-banner h4 {
   color: var(--brand-brown);
   font-family: 'Playfair Display', serif;
   font-weight: 600;
}

.opening-banner p {
   color: var(--brand-brown);
   margin-bottom: 0.6rem;
   white-space: pre-line;
}

.opening-banner .btn-reserve {
   background-color: var(--brand-brown);
   color: #fff;
}

.opening-banner .btn-reserve:hover {
   filter: brightness(0.95);
}

/* Head Spa info box (distinct but subtle, not a banner) */
.info-box {
   max-width: 920px;
   margin: 1.25rem auto;
   background: rgba(255, 255, 255, 0.92);
   padding: 1rem 1.25rem;
   border-radius: 8px;
   color: var(--muted-text);
   box-shadow: 0 6px 18px rgba(117, 80, 62, 0.04);
   background-image: url('../assets/img/logo-info-section.png?v=1.0.0');
   background-size: contain;
   background-position: right;
   background-repeat: no-repeat;
}

.info-box h4 {
   margin: 0 0 0.5rem 0;
   color: var(--brand-brown);
   font-family: 'Playfair Display', serif;
   font-size: 1.15rem;
}

.info-box p {
   margin: 0;
   line-height: 1.65;
   text-align: justify;
}