@import url("https://fonts.googleapis.com/css2?family=Marcellus&family=Inter:wght@400;500;600;700&display=swap");

/* ═══════════════════════════════════════
   1. VARIABLES & RESET
═══════════════════════════════════════ */
:root {
  --navy:       #0b1623;
  --navy-soft:  #13202e;
  --cream:      #faf8f3;
  --cream-dark: #f0ece2;
  --gold:       #c9a84c;
  --gold-light: #e3c16a;
  --red:        #c44b30;
  --text:       #1c2733;
  --muted:      #68778a;
  --border:     #e2dcd0;
  --white:      #ffffff;
  --sh-sm:  0 4px 16px rgba(11,22,35,.07);
  --sh-md:  0 12px 32px rgba(11,22,35,.13);
  --sh-lg:  0 24px 56px rgba(11,22,35,.18);
  --ease:   cubic-bezier(.4,0,.2,1);
  --header-h: 68px;
}

*, *::before, *::after { box-sizing: border-box; }

html {
  font-size: 16px;
  scroll-behavior: smooth;
  min-height: 100%;
}

body {
  font-family: Inter, system-ui, -apple-system, sans-serif;
  background: var(--cream);
  color: var(--text);
  padding-top: var(--header-h);
  margin: 0;
  line-height: 1.65;
}

h1, h2, h3, h4, h5, h6,
.display-5, .display-6,
.navbar-brand {
  font-family: Marcellus, Georgia, serif;
  line-height: 1.1;
}

a { text-decoration: none; }
img { display: block; max-width: 100%; }
ul { padding-left: 0; }
li { list-style: none; }

/* ═══════════════════════════════════════
   2. HEADER – fixed, scroll effect
═══════════════════════════════════════ */
.site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1050;
  transition: box-shadow .35s var(--ease);
}

.site-header.is-scrolled {
  box-shadow: 0 4px 28px rgba(0,0,0,.45);
}

.top-strip {
  background: var(--navy);
  color: #9cb0c2;
  font-size: .8rem;
  padding: .55rem 0;
  letter-spacing: .3px;
}

.top-strip a { color: #b8cad8; }
.top-strip a:hover { color: #fff; }

.main-nav {
  background: rgba(11,22,35,.97);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.main-nav .container { min-height: 68px; display: flex; align-items: center; }

.main-nav .navbar-brand {
  color: #fff;
  font-size: 1.25rem;
  letter-spacing: .8px;
  display: flex;
  align-items: center;
  gap: .5rem;
}

.brand-dot {
  display: inline-block;
  width: 7px; height: 7px;
  background: var(--gold);
  border-radius: 50%;
}

.main-nav .nav-link {
  color: #b0bfcc;
  font-size: .875rem;
  letter-spacing: .3px;
  padding: .5rem .9rem !important;
  transition: color .25s var(--ease);
  position: relative;
}

.main-nav .nav-link::after {
  content: '';
  position: absolute;
  bottom: -2px; left: .9rem; right: .9rem;
  height: 1px;
  background: var(--gold);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .3s var(--ease);
}

.main-nav .nav-link:hover { color: #fff; }
.main-nav .nav-link:hover::after { transform: scaleX(1); }

.btn-brand {
  background: var(--gold);
  border: 2px solid var(--gold);
  color: var(--navy);
  font-weight: 700;
  font-size: .8rem;
  letter-spacing: .6px;
  padding: .48rem 1.4rem;
  border-radius: 2px;
  transition: background .25s var(--ease), color .25s var(--ease);
  white-space: nowrap;
}

.btn-brand:hover {
  background: transparent;
  color: var(--gold);
}

/* ═══════════════════════════════════════
   3. MAIN LAYOUT
═══════════════════════════════════════ */
.main-shell {
  padding-top: 0;
  padding-bottom: 5rem;
}

.full-bleed {
  width: 100vw;
  margin-left: calc(50% - 50vw);
}

/* ═══════════════════════════════════════
   4. SECTION TITLES
═══════════════════════════════════════ */
.section-kicker {
  display: block;
  font-family: Inter, sans-serif;
  text-transform: uppercase;
  letter-spacing: 4px;
  font-size: .7rem;
  color: var(--red);
  margin-bottom: .5rem;
}

.section-divider {
  display: block;
  width: 40px; height: 2px;
  background: var(--gold);
  margin: .9rem auto 0;
}

/* ═══════════════════════════════════════
   5. HERO CAROUSEL
═══════════════════════════════════════ */

/* Outer wrapper — gives position:relative context for the search bar overlay */
.hero-wrap { position: relative; }

.boliin-hero { position: relative; }

.hero-slide {
  min-height: calc(100vh - var(--header-h));
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: center;
}

.hero-content {
  color: #fff;
  padding-top: 2rem;
  padding-bottom: 130px;
  max-width: 700px;
}

.hero-overline {
  font-family: Inter, sans-serif;
  text-transform: uppercase;
  letter-spacing: 6px;
  font-size: .78rem;
  color: rgba(255,255,255,.65);
  margin-bottom: 1.2rem;
}

.hero-title {
  font-size: clamp(2.6rem, 5.5vw, 5.8rem);
  line-height: .95;
  margin-bottom: 1.8rem;
  text-shadow: 0 2px 24px rgba(0,0,0,.35);
}

.hero-sub {
  font-family: Inter, sans-serif;
  text-transform: uppercase;
  letter-spacing: 3.5px;
  font-size: .72rem;
  color: rgba(255,255,255,.6);
  display: flex;
  align-items: center;
  gap: .8rem;
}

.hero-sub::before {
  content: '';
  display: inline-block;
  width: 36px; height: 1px;
  background: var(--gold);
  flex-shrink: 0;
}

/* Hero carousel controls */
.boliin-hero .carousel-control-prev,
.boliin-hero .carousel-control-next {
  width: 52px; height: 52px;
  top: 50%; transform: translateY(-50%);
  bottom: auto;
  opacity: 1;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.25);
  border-radius: 0;
  backdrop-filter: blur(6px);
  transition: background .25s var(--ease), border-color .25s var(--ease);
}

.boliin-hero .carousel-control-prev { left: 28px; }
.boliin-hero .carousel-control-next { right: 28px; }

.boliin-hero .carousel-control-prev:hover,
.boliin-hero .carousel-control-next:hover {
  background: rgba(255,255,255,.22);
  border-color: rgba(255,255,255,.5);
}

/* ═══════════════════════════════════════
   6. HERO SEARCH BAR
═══════════════════════════════════════ */

/*
 * The search bar sits OUTSIDE the carousel in the DOM (.hero-wrap > sibling).
 * position:absolute bottom:0 positions it relative to .hero-wrap.
 * z-index > carousel controls so it stays on top.
 */
.hero-search-wrap {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  z-index: 20;
}

/* Season info bar below the hero search */
.search-season-info {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .4rem .6rem;
  background: rgba(11,22,35,.72);
  backdrop-filter: blur(6px);
  padding: .5rem 1.2rem;
  font-size: .74rem;
  color: rgba(255,255,255,.78);
}
.ssi-item {
  display: flex;
  align-items: center;
  gap: .35rem;
}
.ssi-item.summer strong { color: #f4c55a; }
.ssi-item.winter strong { color: #91c8f6; }
.ssi-item.weekly strong { color: #a8d8a8; }
.ssi-icon { font-size: .9rem; line-height: 1; }
.ssi-sep  { color: rgba(255,255,255,.25); font-size: .9rem; }

.search-validation-msg {
  font-size: .8rem;
  font-weight: 600;
  padding: .35rem 1.2rem;
  letter-spacing: .01em;
}
.search-validation-msg.svm-error {
  background: rgba(180, 40, 40, .82);
  color: #fff;
}
.search-validation-msg.svm-ok {
  background: rgba(26, 80, 40, .78);
  color: #d0f0d0;
}
@media (max-width: 575px) {
  .search-season-info { flex-direction: column; align-items: flex-start; }
  .ssi-sep { display: none; }
}

.hero-search-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 108px;
  background: #fff;
  box-shadow: 0 -2px 0 var(--gold), 0 12px 40px rgba(0,0,0,.28);
}

.hero-search-grid > div {
  padding: .7rem 1.4rem;
  border-right: 1px solid #ebe8e2;
}

.hero-search-grid > div:last-child { border-right: 0; }

.hero-search-grid label {
  display: block;
  font-family: Inter, sans-serif;
  text-transform: uppercase;
  font-size: .62rem;
  letter-spacing: 1.5px;
  color: #9aaab6;
  margin-bottom: .2rem;
}

.hero-search-grid .form-control {
  border: 0;
  padding: 0;
  border-radius: 0;
  min-height: 26px;
  font-size: .9rem;
  color: var(--text);
  background: transparent;
  box-shadow: none;
}

.hero-search-grid .form-control:focus { box-shadow: none; }

/* 3-column variant: Dates | Guests | Search */
.hero-search-grid--3col {
  grid-template-columns: 2fr 1fr 108px;
}

.hero-search-btn { padding: 0 !important; }

.hero-search-btn .btn {
  width: 100%; height: 100%;
  border-radius: 0; border: 0;
  background: var(--red);
  color: #fff;
  font-weight: 700;
  text-transform: uppercase;
  font-size: .72rem;
  letter-spacing: 1.2px;
  transition: background .25s var(--ease);
}

.hero-search-btn .btn:focus { box-shadow: none; }
.hero-search-btn .btn:hover { background: #a83a22; }

/* ═══════════════════════════════════════
   7. WELCOME / EXPERIENCE SECTION
═══════════════════════════════════════ */

/* Welcome section — two-column layout */
.welcome-section { padding: 5rem 0; background: #fff; }

.welcome-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}

.welcome-title {
  font-size: clamp(1.5rem, 2.5vw, 2.1rem);
  line-height: 1.3;
  margin: .75rem 0 1.25rem;
}

.welcome-para {
  color: var(--muted);
  line-height: 1.8;
  margin-bottom: 1rem;
  font-size: .96rem;
}

.welcome-perfect-for {
  margin-top: 1.75rem;
  padding: 1.5rem;
  background: var(--cream);
  border-left: 3px solid var(--gold);
}

.welcome-perfect-for h4 {
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--gold);
  margin-bottom: .9rem;
}

.welcome-pf-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.welcome-pf-list li {
  font-size: .9rem;
  color: var(--dark);
  padding: .35rem 0;
  padding-left: 1.4rem;
  position: relative;
}

.welcome-pf-list li::before {
  content: '✔';
  position: absolute;
  left: 0;
  color: var(--gold);
  font-size: .75rem;
  top: .42rem;
}

.welcome-carousel-wrap {
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 12px 40px rgba(0,0,0,.12);
}

@media (max-width: 900px) {
  .welcome-grid {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }
  .welcome-carousel-wrap { order: -1; }
}

/* Legacy .experience-header kept for any remaining uses */
.experience-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 2rem;
  padding: 5rem 0 2.5rem;
}

.experience-header h2 { font-size: clamp(1.8rem,3vw,2.6rem); margin: 0; }
.experience-header p { color: var(--muted); max-width: 360px; line-height: 1.7; margin: 0; }

.experience-section {
  position: relative;
  overflow: hidden;
  background: #fff;
}

.experience-slide {
  min-height: 460px;
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: center;
  position: relative;
}

.experience-slide::before {
  content: '';
  position: absolute; left: 0; top: 0;
  width: 310px; height: 100%;
  background: rgba(196,75,48,.9);
}

.experience-panel {
  position: relative; z-index: 2;
  background: #fff;
  margin-left: 10%;
  max-width: 320px;
  padding: 2.2rem;
  box-shadow: 0 16px 48px rgba(0,0,0,.22);
}

.ep-icon {
  width: 54px; height: 54px;
  display: flex; align-items: center; justify-content: center;
  background: #fff5ee;
  color: var(--red);
  font-size: 1.4rem;
  margin-bottom: 1.2rem;
}

.experience-panel h3 { font-size: 1.4rem; margin-bottom: .7rem; }

.experience-panel p {
  font-size: .88rem;
  color: #5a6777;
  line-height: 1.75;
  margin-bottom: 1.4rem;
}

.btn-more {
  display: inline-block;
  border: 1px solid var(--navy);
  color: var(--navy);
  font-size: .75rem;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: .55rem 1.6rem;
  transition: all .25s var(--ease);
}

.btn-more:hover { background: var(--navy); color: #fff; }

.experience-section .carousel-control-prev,
.experience-section .carousel-control-next {
  width: 46px; height: 36px;
  top: auto; bottom: 0;
  opacity: 1;
  background: var(--navy);
  border-radius: 0;
  border: 0;
  transition: background .2s;
}

.experience-section .carousel-control-prev { left: 38%; }
.experience-section .carousel-control-next { left: calc(38% + 50px); }

.experience-section .carousel-control-prev:hover,
.experience-section .carousel-control-next:hover { background: var(--red); }

/* ═══════════════════════════════════════
   8. ROOMS SECTION – carousel of 4 cards
═══════════════════════════════════════ */
.rooms-section { padding: 5rem 0 4rem; }

.rooms-head {
  text-align: center;
  margin-bottom: 3.5rem;
}

.rooms-head h2 { font-size: clamp(2rem,3.5vw,3rem); margin-top: .5rem; }

/* Carousel wrapper */
.chalet-group-carousel {
  position: relative;
}

/* Custom nav bar above the carousel */
.cgc-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.2rem;
  margin-bottom: 1.8rem;
}

.cgc-btn {
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 1.5px solid var(--border);
  background: #fff;
  color: var(--navy);
  font-size: 1.1rem;
  line-height: 1;
  cursor: pointer;
  transition: all .22s var(--ease);
  box-shadow: var(--sh-sm);
  display: flex; align-items: center; justify-content: center;
}

.cgc-btn:hover {
  background: var(--navy);
  border-color: var(--navy);
  color: #fff;
  box-shadow: var(--sh-md);
}

/* Card as a full link */
.room-card-link {
  display: block;
  color: inherit;
  text-decoration: none;
  height: 100%;
}

.room-card-link:hover { color: inherit; }

/* Dots */
.carousel-dots {
  display: flex;
  justify-content: center;
  gap: .55rem;
  margin-top: 2.5rem;
}

.carousel-dots button {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #c5bdb0;
  border: 0;
  padding: 0;
  cursor: pointer;
  transition: all .3s var(--ease);
}

.carousel-dots button.active {
  background: var(--navy);
  width: 26px;
  border-radius: 4px;
}

/* Room card */
.room-card {
  background: #fff;
  border: 1px solid #eae6df;
  transition: transform .3s var(--ease), box-shadow .3s var(--ease);
  overflow: hidden;
}

.room-card:hover {
  transform: translateY(-7px);
  box-shadow: var(--sh-lg);
}

.room-img-wrap {
  position: relative;
  overflow: hidden;
}

.room-img-wrap::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--gold);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .35s var(--ease);
}

.room-card:hover .room-img-wrap::after { transform: scaleX(1); }

.room-img-wrap img {
  width: 100%;
  height: 210px;
  object-fit: cover;
  transition: transform .6s var(--ease);
}

.room-card:hover .room-img-wrap img { transform: scale(1.05); }

.room-badge {
  position: absolute;
  top: 12px; left: 12px;
  background: var(--navy);
  color: #fff;
  font-size: .58rem;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: .25rem .6rem;
}

.room-season-badge {
  position: absolute;
  top: 12px; right: 12px;
  z-index: 10;
  font-size: .65rem;
  font-weight: 600;
  padding: .22rem .6rem;
  border-radius: 20px;
  letter-spacing: .02em;
  backdrop-filter: blur(4px);
  pointer-events: none;
  white-space: nowrap;
}
.room-season-badge.year-round {
  background: rgba(28, 39, 51, .82);
  color: #d4c48a;
  border: 1px solid rgba(201,168,76,.45);
}
.room-season-badge.summer-only {
  background: rgba(201, 100, 0, .88);
  color: #fff;
  border: 1px solid rgba(255,180,50,.3);
}

.room-body { padding: 1.25rem; }

.room-stars { color: #f4b41a; font-size: .8rem; letter-spacing: 1px; }
.room-score { color: var(--muted); font-size: .8rem; }

.room-number {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--gold);
}
.room-title {
  font-size: 1.1rem;
  margin: .15rem 0 .6rem;
}

.room-price {
  color: var(--red);
  font-size: 1.55rem;
  line-height: 1;
  margin-bottom: 1rem;
}

.room-price small { font-size: .82rem; color: #8e9aa4; }

.room-meta {
  display: flex;
  justify-content: space-between;
  background: var(--cream);
  padding: .65rem .9rem;
  font-size: .78rem;
  color: #5e6b78;
  border-top: 1px solid #ede9e0;
  margin: 0 -1.25rem -1.25rem;
}

/* Mobile horizontal scroll fallback */
.rooms-mobile-scroll {
  display: flex;
  gap: 1rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  padding-bottom: .75rem;
  scrollbar-width: thin;
  scrollbar-color: #c5bdb0 transparent;
}

.rooms-mobile-scroll::-webkit-scrollbar { height: 4px; }
.rooms-mobile-scroll::-webkit-scrollbar-thumb { background: #c5bdb0; border-radius: 2px; }

.rooms-mobile-scroll .room-item {
  flex: 0 0 80vw;
  max-width: 320px;
  scroll-snap-align: start;
}

/* ═══════════════════════════════════════
   9. DETAIL PAGE
═══════════════════════════════════════ */

/* ── Amenities grid ────────────────────────────────────────────────────── */
.amenities-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: .75rem;
  margin-top: 1.5rem;
}

.amenity-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .45rem;
  padding: 1rem .75rem;
  border: 1px solid #e2dcd0;
  border-radius: 6px;
  text-align: center;
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .8px;
  color: #68778a;
  transition: border-color .2s, background .2s;
}

.amenity-item:hover {
  border-color: var(--gold);
  background: var(--cream);
  color: var(--dark);
}

.amenity-icon { font-size: 1.5rem; }

/* ── Off-season monthly rental note (cottages 4-5-6) ───────────────────── */
.off-season-rental-note {
  display: flex;
  align-items: center;
  gap: .65rem;
  margin-top: 1.25rem;
  padding: .85rem 1rem;
  background: #faf6ec;
  border: 1px solid #e8dcb6;
  border-left: 4px solid var(--gold, #c9a84c);
  border-radius: 6px;
  font-size: .9rem;
  color: #614c12;
}
.off-season-rental-note .osr-icon { font-size: 1.25rem; }

/* ── Mosaic hero ───────────────────────────────────────────────────────── */
.det-mosaic-wrap {
  display: grid;
  grid-template-columns: 1fr 280px;
  grid-template-rows: 520px;
  gap: 4px;
  overflow: hidden;
}

.det-mosaic-main {
  cursor: pointer;
  overflow: hidden;
  position: relative;
}

.det-mosaic-main::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0);
  transition: background .2s;
}

.det-mosaic-main:hover::after { background: rgba(0,0,0,.08); }

.det-mosaic-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s var(--ease);
}

.det-mosaic-main:hover .det-mosaic-img { transform: scale(1.03); }

.det-mosaic-side {
  display: grid;
  grid-template-rows: repeat(4, 1fr);
  gap: 4px;
}

.det-mosaic-thumb {
  cursor: pointer;
  overflow: hidden;
  position: relative;
}

.det-mosaic-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .4s var(--ease);
}

.det-mosaic-thumb:hover img { transform: scale(1.06); opacity: .85; }

.det-mosaic-more::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(11,22,35,.55);
}

.det-mosaic-badge {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: .9rem;
  font-weight: 600;
  letter-spacing: .5px;
}

/* ── Horizontal gallery strip ──────────────────────────────────────────── */
.det-gallery-strip {
  position: relative;
}

.det-gallery-strip::before,
.det-gallery-strip::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  width: 60px;
  pointer-events: none;
  z-index: 1;
}

.det-gallery-strip::before { left: 0;  background: linear-gradient(to right, var(--cream), transparent); }
.det-gallery-strip::after  { right: 0; background: linear-gradient(to left,  var(--cream), transparent); }

.det-gallery-scroll {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: .4rem 0 .8rem;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
}

.det-gallery-scroll::-webkit-scrollbar { height: 5px; }
.det-gallery-scroll::-webkit-scrollbar-thumb { background: var(--border); border-radius: 99px; }

.det-gallery-item {
  flex: 0 0 160px;
  height: 110px;
  overflow: hidden;
  cursor: pointer;
  scroll-snap-align: start;
  border-radius: 2px;
  position: relative;
}

.det-gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s var(--ease), opacity .2s;
}

.det-gallery-item:hover img { transform: scale(1.07); opacity: .88; }

.booking-panel {
  background: var(--navy);
  color: #fff;
  padding: 2.2rem;
  position: sticky;
  top: calc(var(--header-h) + 1.5rem);
}

.bp-title { font-size: 1.45rem; margin-bottom: .25rem; }
.bp-location { color: #7a96ae; font-size: .85rem; margin-bottom: 1.4rem; display: flex; gap: .4rem; align-items: center; }
.bp-location::before { content: '◎'; font-size: .7rem; }

.bp-price {
  font-family: Marcellus, serif;
  font-size: 2.2rem;
  color: var(--gold);
  line-height: 1;
  margin-bottom: .3rem;
}

.bp-price small { font-size: .82rem; color: #6e89a0; font-family: Inter, sans-serif; }

.bp-capacity {
  color: #7a96ae; font-size: .85rem;
  padding: .9rem 0;
  border-top: 1px solid rgba(255,255,255,.1);
  border-bottom: 1px solid rgba(255,255,255,.1);
  margin: 1rem 0 1.2rem;
}

.bp-description { color: #9db4c5; font-size: .88rem; line-height: 1.75; margin-bottom: 1.4rem; }

.bp-benefits { margin-bottom: 0; }
.bp-benefits li {
  color: #8aa2b4;
  font-size: .85rem;
  padding: .4rem 0;
  border-bottom: 1px solid rgba(255,255,255,.07);
  display: flex; align-items: center; gap: .6rem;
}
.bp-benefits li::before { content: '✓'; color: var(--gold); flex-shrink: 0; }
.bp-benefits li:last-child { border-bottom: 0; }

/* ── Booking panel pricing rules ─────────────────────── */
.bp-pricing-rules {
  border: 1px solid #e0dbd2;
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 1.1rem;
  font-size: .82rem;
}
.bp-pr-title {
  padding: .55rem .85rem;
  background: var(--navy);
  color: #fff;
  font-weight: 700;
  font-size: .75rem;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.bp-pr-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: .5rem;
  padding: .55rem .85rem;
  border-bottom: 1px solid #f0ece6;
}
.bp-pr-row.summer  { border-left: 3px solid #e8a000; }
.bp-pr-row.winter  { border-left: 3px solid #3a6bab; }
.bp-pr-row.winter-na { border-left: 3px solid #ccc; padding: .5rem .85rem; color: #999; }
.bp-pr-season  { display: block; font-weight: 600; color: #1c2733; }
.bp-pr-detail  { display: block; color: #68778a; font-size: .76rem; margin-top: .1rem; }
.bp-pr-price   { font-weight: 700; color: var(--gold); white-space: nowrap; }
.bp-pr-na      { color: #aaa; font-style: italic; }
.bp-pr-weekly  { padding: .5rem .85rem; background: #fafaf7; color: #5a5a5a; border-top: 1px solid #f0ece6; }
.bp-pr-pets    { padding: .45rem .85rem; background: #fdf6ec; color: #7a5a1e; font-size: .78rem; }

/* ── Availability picker min-nights message ──────────── */
.bp-min-nights-msg {
  padding: .5rem .75rem;
  border-radius: 8px;
  font-size: .8rem;
  font-weight: 600;
  margin: .5rem 0;
}
.bp-min-nights-msg.bp-min-info {
  background: #eef4ff;
  color: #2a5bab;
  border: 1px solid #c0d6f7;
}
.bp-min-nights-msg.bp-min-warn {
  background: #fff3cd;
  color: #856404;
  border: 1px solid #ffc107;
}
.bp-min-nights-msg.bp-min-error {
  background: #fef2f2;
  color: #b91c1c;
  border: 1px solid #fca5a5;
}

.btn-book {
  display: block; width: 100%;
  background: var(--gold);
  border: 0; color: var(--navy);
  font-weight: 700; font-size: .8rem;
  letter-spacing: 1.2px; text-transform: uppercase;
  padding: 1.05rem;
  text-align: center;
  transition: all .25s var(--ease);
  margin-top: 1.8rem;
}

.btn-book:hover { background: #b89240; color: #000; }

.btn-book-disabled {
  background: #8a9aaa !important;
  color: #fff !important;
  cursor: not-allowed !important;
  opacity: .7;
}
.btn-book-disabled:hover { background: #8a9aaa !important; color: #fff !important; }

/* ── Availability picker inside booking panel ── */
.bp-avail-section { margin: 1.2rem 0 1rem; }

.bp-avail-label {
  display: block;
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .8px;
  color: #7a96ae;
  margin-bottom: .45rem;
}

.bp-avail-input {
  width: 100%;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.2);
  color: #fff;
  padding: .6rem .9rem;
  font-size: .88rem;
  border-radius: 2px;
  cursor: pointer;
  transition: border-color .2s;
}
.bp-avail-input:focus { outline: none; border-color: var(--gold); }
.bp-avail-input::placeholder { color: rgba(255,255,255,.35); }

/* flatpickr inside dark panel */
.booking-panel .flatpickr-calendar { background: var(--navy-soft); border-color: rgba(255,255,255,.15); }
.booking-panel .flatpickr-day      { color: #cdd8e0; }
.booking-panel .flatpickr-day:hover,
.booking-panel .flatpickr-day.inRange { background: rgba(201,168,76,.25); border-color: transparent; }
.booking-panel .flatpickr-day.selected,
.booking-panel .flatpickr-day.startRange,
.booking-panel .flatpickr-day.endRange { background: var(--gold); border-color: var(--gold); color: var(--navy); }
.booking-panel .flatpickr-months    { background: var(--navy-soft); }
.booking-panel .flatpickr-weekdays  { background: var(--navy-soft); }

.bp-avail-result {
  margin-top: .55rem;
  padding: .6rem .9rem;
  border-radius: 2px;
  font-size: .82rem;
  min-height: 36px;
  display: flex;
  align-items: center;
  transition: background .3s, color .3s;
}
.avail-idle     { background: rgba(255,255,255,.07); color: rgba(255,255,255,.45); }
.avail-checking { background: rgba(255,255,255,.07); color: rgba(255,255,255,.55); }
.avail-ok       { background: rgba(34,197,94,.15);   color: #4ade80; font-weight: 600; }
.avail-no       { background: rgba(220,38,38,.15);   color: #f87171; font-weight: 600; flex-direction: column; align-items: flex-start; gap: .5rem; }

.avail-occupied-list { width: 100%; }
.avail-occupied-list strong { font-size: .72rem; text-transform: uppercase; letter-spacing: .5px; color: rgba(248,113,113,.8); display: block; margin-bottom: .3rem; }
.avail-occupied-list ul { margin: 0; padding: 0 0 0 1rem; list-style: disc; }
.avail-occupied-list li { font-size: .78rem; color: rgba(255,255,255,.6); line-height: 1.6; }

/* ═══════════════════════════════════════
   10. PAGE HEADER BAND
═══════════════════════════════════════ */
.page-band {
  background: linear-gradient(135deg, var(--navy) 0%, #1b3048 100%);
  color: #fff;
  padding: 3.2rem 0;
  margin-bottom: 3rem;
  margin-left: calc(50% - 50vw);
  width: 100vw;
}

.page-band .pb-kicker { color: var(--gold); font-size: .7rem; letter-spacing: 3px; text-transform: uppercase; margin-bottom: .5rem; font-family: Inter, sans-serif; }
.page-band h1 { font-size: clamp(1.6rem,3vw,2.2rem); margin: 0; }

/* ═══════════════════════════════════════
   11. FORMS – Booking create
═══════════════════════════════════════ */
.form-card {
  background: #fff;
  border: 1px solid var(--border);
  padding: 2.5rem;
}

.form-label {
  font-size: .76rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .6px;
  color: #4a5568;
  margin-bottom: .45rem;
}

.form-control,
.form-select {
  border: 1px solid #d5cfc6;
  border-radius: 0;
  min-height: 48px;
  font-size: .95rem;
  background: var(--cream);
  color: var(--text);
  transition: border-color .2s var(--ease), box-shadow .2s var(--ease);
}

.form-control:focus,
.form-select:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(201,168,76,.15);
  background: #fff;
  outline: 0;
}

.sidebar-info {
  background: #fff;
  border-left: 3px solid var(--gold);
  padding: 2rem;
  border: 1px solid var(--border);
  border-left-width: 3px;
  border-left-color: var(--gold);
}

.sidebar-info h5 {
  font-size: .75rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--navy);
  margin-bottom: 1.2rem;
  padding-bottom: .75rem;
  border-bottom: 1px solid var(--border);
}

.sidebar-info li {
  font-size: .88rem;
  color: var(--muted);
  padding: .55rem 0;
  border-bottom: 1px solid #ede9e0;
  display: flex; align-items: center; gap: .5rem;
}

.sidebar-info li:last-child { border-bottom: 0; }
.sidebar-info li::before { content: '✓'; color: var(--gold); font-size: .8rem; }

/* ── Min-nights badge ───────────────────────────────── */
.min-nights-badge {
  display: inline-block;
  padding: .3rem .75rem;
  border-radius: 20px;
  font-size: .78rem;
  font-weight: 600;
  background: #eef4ff;
  color: #2a5bab;
  border: 1px solid #c0d6f7;
  margin-top: .4rem;
}
.winter-unavail-msg {
  padding: .5rem .75rem;
  background: #fff3cd;
  border: 1px solid #ffc107;
  border-radius: 8px;
  font-size: .82rem;
  color: #856404;
  margin-top: .5rem;
}

/* ── Pet section ────────────────────────────────────── */
.pet-section { border-top: 1px solid #e8e0d5; padding-top: 1.5rem; }
.pet-info-box {
  background: #fdf6ec;
  border: 1px solid #f0d9a8;
  border-radius: 8px;
  padding: .85rem 1rem;
  font-size: .88rem;
  color: #5a4a2e;
}
.pet-info-box ul { padding-left: 1.2rem; margin: .4rem 0 0; }
.pet-info-box li { margin-bottom: .2rem; }

/* ── Payment option section ─────────────────────────── */
.payment-option-section { 
  border-top: 1px solid #e8e0d5; 
  padding-top: 1.5rem; 
  margin-top: 1.5rem;
}
.payment-info-box {
    background: #fef3e2;
    border: 1px solid #f0d89f;
    border-radius: 8px;
    padding: .85rem 1rem;
    font-size: .88rem;
    color: #5a4a2e;
}
.payment-option-section .form-check {
    padding: .8rem 1rem;
    background: #f9fafb;
    border: 2px solid #e5e7eb;
    border-radius: 8px;
    transition: all .2s;
    margin-bottom: .5rem;
}
.payment-option-section .form-check:hover {
    background: #f3f4f6;
    border-color: #c9a84c;
}
.payment-option-section .form-check-input:checked {
    background-color: #c9a84c;
    border-color: #c9a84c;
}
.payment-option-section .form-check-label {
    margin-left: .3rem;
    font-size: .9rem;
}

/* ── Pricing rules card ─────────────────────────────── */
.pricing-rules-card {
  background: #fff;
  border: 1px solid #e0dbd2;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
.pricing-rules-title {
  margin: 0;
  padding: .9rem 1.1rem;
  font-size: .85rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  background: var(--navy);
  color: #fff;
}
.pricing-rule-item {
  display: flex;
  flex-direction: column;
  gap: .15rem;
  padding: .85rem 1.1rem;
  border-bottom: 1px solid #f0ece6;
}
.pricing-rule-item.summer { border-left: 3px solid #e8a000; }
.pricing-rule-item.winter { border-left: 3px solid #3a6bab; }
.rule-label { font-weight: 600; font-size: .88rem; color: #2d2d2d; }
.rule-detail { font-size: .8rem; color: #68778a; }
.rule-price { font-size: 1rem; font-weight: 700; color: var(--gold); }
.pricing-rule-note {
  padding: .75rem 1.1rem;
  font-size: .8rem;
  color: #5a5a5a;
  background: #fafaf7;
}

/* ── Live price breakdown card ──────────────────────── */
.price-breakdown-card {
  background: #fff;
  border: 1px solid #e0dbd2;
  border-radius: 12px;
  padding: 1.2rem 1.3rem;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
.price-breakdown-card h5 {
  font-size: .85rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  margin-bottom: 1rem;
  color: var(--navy);
}
.price-row {
  display: flex;
  justify-content: space-between;
  font-size: .88rem;
  padding: .3rem 0;
  border-bottom: 1px solid #f0ece6;
  color: #444;
}
.price-total {
  display: flex;
  justify-content: space-between;
  font-size: 1rem;
  font-weight: 700;
  padding: .5rem 0 .3rem;
  color: var(--navy);
}
.price-deposit, .price-balance {
  display: flex;
  justify-content: space-between;
  font-size: .82rem;
  padding: .25rem 0;
  color: #68778a;
}
.price-deposit { color: #2a7a4b; font-weight: 600; }

.btn-submit {
  background: var(--navy);
  color: #fff;
  border: 0;
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: .95rem 2.5rem;
  border-radius: 0;
  transition: background .25s var(--ease);
}

.btn-submit:hover { background: #1e3650; color: #fff; }

/* ═══════════════════════════════════════
   12. CONFIRMATION PAGE
═══════════════════════════════════════ */
.conf-header {
  background: linear-gradient(135deg, var(--navy) 0%, #1b3048 100%);
  color: #fff;
  padding: 3rem 2.5rem;
  border-left: 4px solid var(--gold);
}

.conf-header .conf-check {
  width: 56px; height: 56px;
  border-radius: 50%;
  background: rgba(201,168,76,.18);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem;
  color: var(--gold);
  margin-bottom: 1.2rem;
}

.conf-header h1 { font-size: 1.7rem; margin: 0 0 .4rem; }
.conf-header p { color: #8aa2b5; font-size: .9rem; margin: 0; }

.conf-body { background: #fff; border: 1px solid var(--border); }

.conf-row {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: .5rem 1rem;
  padding: 1.1rem 2.5rem;
  border-bottom: 1px solid #f0ece4;
  align-items: baseline;
}

.conf-row:last-child { border-bottom: 0; }

.conf-label {
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  color: #9aaab6;
  font-family: Inter, sans-serif;
  font-weight: 600;
  padding-top: .1rem;
}

.conf-value { font-size: .95rem; color: var(--text); }
.conf-value.highlight { font-weight: 700; font-size: 1.05rem; color: var(--navy); }
.conf-value code { font-size: .85rem; background: var(--cream); padding: .2rem .5rem; color: var(--navy); }

.conf-actions {
  display: flex;
  gap: .75rem;
  flex-wrap: wrap;
  padding: 1.6rem 2.5rem;
  border-top: 1px solid #f0ece4;
  background: var(--cream);
}

/* ── Payment confirmation button variants ── */
.btn-conf-primary {
  display: inline-block; padding: .7rem 1.8rem;
  background: #0b1623; color: #fff;
  font-size: .8rem; font-weight: 700; letter-spacing: .8px; text-transform: uppercase;
  border: 0; text-decoration: none; transition: background .2s;
}
.btn-conf-primary:hover { background: var(--navy); color: #fff; }

.btn-conf-outline {
  display: inline-block; padding: .7rem 1.8rem;
  background: transparent; color: #0b1623;
  font-size: .8rem; font-weight: 700; letter-spacing: .8px; text-transform: uppercase;
  border: 1px solid #0b1623; text-decoration: none; transition: all .2s;
}
.btn-conf-outline:hover { background: #0b1623; color: #fff; }

.btn-conf-gold {
  display: inline-block; padding: .7rem 1.8rem;
  background: var(--gold); color: #0b1623;
  font-size: .8rem; font-weight: 700; letter-spacing: .8px; text-transform: uppercase;
  border: 0; text-decoration: none; transition: background .2s;
}
.btn-conf-gold:hover { background: #b8943c; color: #fff; }

/* ── Payment status badges ── */
.status-badge {
  display: inline-block; padding: .25rem .85rem;
  font-size: .72rem; font-weight: 700; letter-spacing: .6px; text-transform: uppercase;
}
.status-paid    { background: #e6f4ec; color: #1a7a40; }
.status-partial { background: #fef3e2; color: #8a5500; }
.status-pending { background: #fef3e2; color: #8a5500; }
.status-cancelled { background: #fdecea; color: #b71c1c; }

/* ═══════════════════════════════════════
   13. CANCELLATION PAGE
═══════════════════════════════════════ */
.cancel-card {
  background: #fff;
  border: 1px solid var(--border);
  padding: 0;
  overflow: hidden;
}

.cancel-card-head {
  background: var(--cream-dark);
  border-bottom: 1px solid var(--border);
  padding: 1.8rem 2.2rem;
}

.cancel-card-head h1 { font-size: 1.5rem; margin: 0; }
.cancel-card-head p { color: var(--muted); font-size: .88rem; margin: .4rem 0 0; }
.cancel-card-body { padding: 2.2rem; }

/* ═══════════════════════════════════════
   14. FOOTER
═══════════════════════════════════════ */
.app-footer {
  background: var(--navy);
  color: #8fa4b8;
  padding: 5rem 0 2.5rem;
  margin-top: 0;
}

.app-footer h5 {
  color: #fff;
  font-size: .76rem;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  font-family: Inter, sans-serif;
  margin-bottom: 1.4rem;
  padding-bottom: .75rem;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.app-footer p { font-size: .87rem; line-height: 1.8; }

.footer-link {
  color: #7a96ae;
  display: block;
  font-size: .87rem;
  padding: .25rem 0;
  transition: color .2s var(--ease);
}

.footer-link:hover { color: var(--gold); }

.footer-map {
  border-radius: 6px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.08);
  opacity: .9;
  transition: opacity .2s;
}
.footer-map:hover { opacity: 1; }

.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.08);
  margin-top: 2.5rem;
  padding-top: 1.5rem;
  font-size: .8rem;
  color: #4e6070;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .5rem;
}

/* ═══════════════════════════════════════
   15. UTILITIES
═══════════════════════════════════════ */
.text-gold { color: var(--gold) !important; }
.bg-navy  { background: var(--navy) !important; }
.btn:focus, .btn:active:focus { box-shadow: none; }

.alert { border-radius: 0; border-width: 0 0 0 3px; }
.alert-danger { border-color: var(--red); }
.alert-info { border-color: var(--gold); }

/* ═══════════════════════════════════════
   14a. THINGS TO DO PAGE
═══════════════════════════════════════ */

/* ── Hero ── */
.ttd-hero {
  background:
    linear-gradient(to bottom, rgba(8,15,25,.55) 0%, rgba(8,15,25,.75) 100%),
    url('https://images.unsplash.com/photo-1464146072230-91cabc968266?auto=format&fit=crop&w=1920&q=80')
    center / cover no-repeat;
  padding: 5rem 0 4rem;
  color: #fff;
}

.ttd-hero-content h1 { font-size: clamp(2rem,4vw,3.4rem); margin: .4rem 0 .8rem; }
.ttd-hero-content p  { color: rgba(255,255,255,.7); max-width: 560px; font-size: .95rem; line-height: 1.8; margin: 0; }

/* ── Filters ── */
.ttd-filters-wrap {
  background: var(--cream-dark);
  border-bottom: 1px solid var(--border);
  padding: .85rem 0;
  position: sticky;
  top: var(--header-h);
  z-index: 90;
}

.ttd-filters {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
}

.ttd-filter {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--muted);
  font-size: .76rem;
  font-weight: 600;
  letter-spacing: .5px;
  text-transform: uppercase;
  padding: .4rem 1rem;
  cursor: pointer;
  transition: all .2s var(--ease);
  font-family: Inter, sans-serif;
}

.ttd-filter:hover  { border-color: var(--navy); color: var(--navy); }
.ttd-filter.active { background: var(--navy); border-color: var(--navy); color: #fff; }

/* ── Filter active with custom color ── */
.ttd-filter.active {
  background: var(--cat-color, var(--navy));
  border-color: var(--cat-color, var(--navy));
  color: #fff;
}

/* ── Count row ── */
.ttd-count-row {
  padding: 1.5rem 0 .5rem;
  display: flex;
  align-items: baseline;
  gap: .6rem;
}

#ttdCount {
  font-family: Marcellus, serif;
  font-size: 1.5rem;
  color: var(--navy);
}

.ttd-count-sub { font-size: .82rem; color: var(--muted); }

/* ── Activity cards grid ── */
.ttd-grid { padding-top: 1.5rem; padding-bottom: 3rem; }

.ttd-card {
  background: #fff;
  border: 1px solid var(--border);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  height: 100%;
  transition: transform .3s var(--ease), box-shadow .3s var(--ease);
}

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

.ttd-img-wrap {
  position: relative;
  height: 220px;
  overflow: hidden;
  flex-shrink: 0;
}

.ttd-img-wrap img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .6s var(--ease);
}

.ttd-card:hover .ttd-img-wrap img { transform: scale(1.05); }

.ttd-cat-badge {
  position: absolute;
  top: 14px; left: 14px;
  color: #fff;
  font-size: .62rem;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: .3rem .7rem;
  backdrop-filter: blur(4px);
}

.ttd-city-badge {
  position: absolute;
  bottom: 10px; right: 10px;
  background: rgba(11,22,35,.65);
  color: rgba(255,255,255,.92);
  font-size: .68rem;
  padding: .25rem .6rem;
  backdrop-filter: blur(4px);
}

.ttd-body {
  padding: 1.3rem 1.3rem .8rem;
  flex: 1;
}

.ttd-title {
  font-size: 1.1rem;
  margin: 0 0 .65rem;
  line-height: 1.2;
}

.ttd-desc {
  font-size: .875rem;
  color: var(--muted);
  line-height: 1.75;
  margin: 0;
}

.ttd-footer {
  padding: .85rem 1.3rem;
  border-top: 1px solid #f0ece4;
  background: var(--cream);
}

.ttd-btn-chalets {
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .5px;
  text-transform: uppercase;
  color: var(--navy);
  transition: color .2s var(--ease);
  display: inline-flex;
  align-items: center;
  gap: .3rem;
}

.ttd-btn-chalets:hover { color: var(--gold); }

/* ── Empty state ── */
.ttd-empty {
  text-align: center;
  padding: 4rem 1rem;
}

/* ── Responsive ── */
@media (max-width: 767.98px) {
  .ttd-hero { padding: 3rem 0 2.5rem; }
  .ttd-filters-wrap { position: static; }
  .ttd-img-wrap { height: 180px; }
  .ttd-legend { padding: 1rem 0 .25rem; }
}

/* ═══════════════════════════════════════
   14b. SEARCH RESULTS PAGE (Search.cshtml)
═══════════════════════════════════════ */

/* ── Sticky refinement bar ── */
.srp-bar {
  background: var(--navy);
  padding: 1rem 0;
  position: sticky;
  top: var(--header-h);
  z-index: 100;
  box-shadow: 0 4px 24px rgba(0,0,0,.35);
}

.srp-form {
  display: flex;
  align-items: stretch;
  gap: 0;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  max-width: 860px;
}

.srp-field {
  flex: 1 1 0;
  padding: .7rem 1.1rem;
  border-right: 1px solid rgba(255,255,255,.1);
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
}

.srp-field label {
  font-size: .62rem;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: rgba(255,255,255,.45);
  font-family: Inter, sans-serif;
  margin-bottom: .25rem;
  display: block;
}

.srp-input {
  background: transparent;
  border: 0;
  color: #fff;
  font-size: .9rem;
  padding: 0;
  width: 100%;
  outline: 0;
  cursor: pointer;
}

.srp-input::placeholder { color: rgba(255,255,255,.3); }
.srp-input:focus { box-shadow: none; }

/* Override Flatpickr inside srp-bar */
.srp-bar .flatpickr-input,
.srp-bar .flatpickr-alt-input {
  background: transparent !important;
  border: 0 !important;
  color: #fff !important;
  font-size: .9rem !important;
  padding: 0 !important;
  box-shadow: none !important;
  width: 100% !important;
  cursor: pointer !important;
  min-height: auto !important;
}

.srp-submit {
  background: var(--gold);
  border: 0;
  color: var(--navy);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 0 1.8rem;
  cursor: pointer;
  white-space: nowrap;
  transition: background .2s var(--ease);
  flex-shrink: 0;
}

.srp-submit:hover { background: #b89240; }

/* ── Results header ── */
.srp-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 2rem;
  padding: 2.5rem 0 1.5rem;
  border-bottom: 1px solid var(--border);
  margin-bottom: 2.5rem;
  flex-wrap: wrap;
}

.srp-back {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .8rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: .75rem;
  transition: color .2s;
}

.srp-back:hover { color: var(--navy); }

.srp-count {
  font-size: clamp(1.4rem,2.5vw,2rem);
  margin: 0 0 .75rem;
}

.srp-count span { color: var(--muted); font-size: .85em; }

.srp-tags {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}

.srp-tag {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  background: var(--cream-dark);
  border: 1px solid var(--border);
  font-size: .8rem;
  color: var(--text);
  padding: .35rem .8rem;
}

.srp-tag em { color: var(--muted); font-style: normal; }

.srp-price-note { text-align: right; padding-top: .5rem; }

/* ── Seasonal context banner on Search page ── */
.srp-season-banner {
  display: flex;
  align-items: center;
  gap: .7rem;
  font-size: .8rem;
  padding: .6rem 1.2rem;
  margin: 0;
}
.srp-season-banner.summer {
  background: rgba(201,168,76,.12);
  border-left: 3px solid var(--gold);
  color: #5a4a1a;
}
.srp-season-banner.winter {
  background: rgba(60,110,180,.10);
  border-left: 3px solid #6aace0;
  color: #1a3050;
}
.srp-season-banner.browse-all {
  background: rgba(11,22,35,.05);
  border-left: 3px solid var(--muted);
  color: var(--muted);
}
.ssb-icon  { font-size: 1.1rem; flex-shrink: 0; }
.ssb-note  { font-style: italic; opacity: .75; }
.srp-price-base {
  font-family: Marcellus, serif;
  font-size: 1.8rem;
  color: var(--navy);
  display: block;
  line-height: 1;
}
.srp-price-sub { font-size: .78rem; color: var(--muted); }

/* ── Result cards ── */
.srp-grid { margin-bottom: 4rem; }

.srp-card {
  background: #fff;
  border: 1px solid var(--border);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .3s var(--ease), box-shadow .3s var(--ease);
  height: 100%;
}

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

.srp-img-wrap {
  position: relative;
  overflow: hidden;
  height: 250px;
  flex-shrink: 0;
}

.srp-img-wrap img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .6s var(--ease);
}

.srp-card:hover .srp-img-wrap img { transform: scale(1.05); }

.srp-avail-badge {
  position: absolute;
  top: 14px; left: 14px;
  background: rgba(22,116,60,.9);
  color: #fff;
  font-size: .62rem;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: .28rem .65rem;
  backdrop-filter: blur(4px);
}

.srp-overlay-info {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(11,22,35,.65));
  padding: 1.5rem .9rem .6rem;
  display: flex;
  justify-content: flex-end;
}

.srp-overlay-info span {
  font-size: .72rem;
  color: rgba(255,255,255,.9);
  background: rgba(0,0,0,.3);
  padding: .2rem .55rem;
  backdrop-filter: blur(4px);
}

.srp-body {
  padding: 1.4rem 1.4rem .9rem;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: .45rem;
}

.srp-location {
  font-size: .78rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .8px;
}

.srp-title {
  font-size: 1.15rem;
  margin: 0;
  line-height: 1.2;
}

.srp-stars { display: flex; align-items: center; gap: .4rem; }
.srp-stars span:first-child { color: #f4b41a; font-size: .85rem; letter-spacing: 1px; }
.srp-score { font-size: .85rem; font-weight: 700; color: var(--text); }
.srp-reviews { font-size: .78rem; color: var(--muted); }

.srp-amenities {
  display: flex;
  gap: .6rem;
  flex-wrap: wrap;
  margin-top: .15rem;
}

.srp-amenities span {
  font-size: .72rem;
  color: var(--muted);
  background: var(--cream);
  padding: .2rem .55rem;
  border: 1px solid var(--border);
}

.srp-footer {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: .75rem;
  margin-top: auto;
  padding-top: 1rem;
  border-top: 1px solid #f0ece4;
}

.srp-pricing { line-height: 1.2; }

.srp-price-main {
  font-family: Marcellus, serif;
  font-size: 1.6rem;
  color: var(--red);
  line-height: 1;
}

.srp-price-detail {
  font-size: .74rem;
  color: var(--muted);
  margin-top: .15rem;
}

.srp-total-hint {
  display: block;
  font-size: .72rem;
  color: var(--gold);
  font-weight: 600;
  margin-top: .1rem;
}

.srp-btn-detail {
  display: inline-block;
  border: 1px solid var(--navy);
  color: var(--navy);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .8px;
  text-transform: uppercase;
  padding: .5rem 1.1rem;
  transition: all .2s var(--ease);
  white-space: nowrap;
  flex-shrink: 0;
}

.srp-btn-detail:hover { background: var(--navy); color: #fff; }

/* Book bar at bottom of card */
.srp-book-bar {
  border-top: 1px solid #f0ece4;
  padding: .85rem 1.4rem;
  background: var(--cream);
}

.srp-btn-book {
  display: block;
  background: var(--gold);
  color: var(--navy);
  text-align: center;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .8px;
  text-transform: uppercase;
  padding: .75rem;
  transition: background .2s var(--ease);
}

.srp-btn-book:hover { background: #b89240; color: #000; }

/* ── Empty state ── */
.srp-empty {
  text-align: center;
  padding: 5rem 1rem;
  max-width: 480px;
  margin: 0 auto;
}

.srp-empty-icon {
  font-size: 3.5rem;
  margin-bottom: 1.5rem;
  opacity: .5;
}

.srp-empty h2 { font-size: 1.8rem; margin-bottom: .75rem; }
.srp-empty p { color: var(--muted); line-height: 1.8; }

/* ── Responsive ── */
@media (max-width: 991.98px) {
  .srp-form { max-width: 100%; }
  .srp-header { flex-direction: column; gap: 1rem; }
  .srp-price-note { text-align: left; padding-top: 0; }
}

@media (max-width: 767.98px) {
  .srp-bar { position: static; }
  .srp-form { flex-direction: column; }
  .srp-field { border-right: 0; border-bottom: 1px solid rgba(255,255,255,.1); }
  .srp-submit { padding: .85rem 1.5rem; }
  .srp-img-wrap { height: 200px; }
  .srp-header { padding: 1.5rem 0 1rem; margin-bottom: 1.5rem; }
}

/* ═══════════════════════════════════════
   15a. FLATPICKR LUXURY THEME
═══════════════════════════════════════ */

/* ── Trigger inputs ── */
.flatpickr-input { cursor: pointer; }
.flatpickr-input[readonly] { cursor: pointer; }

/* ── Calendar container ── */
.flatpickr-calendar {
  background: #fff;
  border: 1px solid var(--border);
  border-top: 3px solid var(--gold);
  border-radius: 0;
  box-shadow: 0 24px 64px rgba(11,22,35,.22);
  font-family: Inter, system-ui, sans-serif;
  padding: 0;
  animation: fp-fadein .18s ease;
}

@keyframes fp-fadein {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Month header ── */
.flatpickr-months {
  background: var(--navy);
  padding: .45rem 0 .35rem;
  border-radius: 0;
}

.flatpickr-month { color: #fff !important; height: 36px; }

.flatpickr-current-month {
  font-family: Marcellus, Georgia, serif;
  font-size: 1rem;
  color: #fff !important;
  letter-spacing: .3px;
  padding: 0 4px;
}

/* Month name span and dropdown: always white text on dark header */
.flatpickr-current-month span.cur-month {
  color: #fff !important;
  font-family: Marcellus, Georgia, serif;
  font-weight: 600;
}

.flatpickr-current-month .flatpickr-monthDropdown-months {
  background: var(--navy) !important;
  color: #fff !important;
  border: 0;
  font-family: Marcellus, serif;
  font-size: 1rem;
  -webkit-appearance: none;
  appearance: none;
  cursor: pointer;
}

.flatpickr-current-month .flatpickr-monthDropdown-months option {
  background: var(--navy);
  color: #fff;
}

.flatpickr-current-month input.cur-year {
  color: #fff !important;
  font-weight: 400;
}

.flatpickr-current-month input.cur-year:hover { background: rgba(255,255,255,.1); }

.flatpickr-prev-month,
.flatpickr-next-month {
  fill: #ffffff;
  color: #ffffff !important;
  opacity: 1 !important;
  top: 6px;
  padding: 5px 10px;
  transition: fill .2s, color .2s;
}

.flatpickr-prev-month svg,
.flatpickr-next-month svg {
  fill: #ffffff !important;
}

.flatpickr-prev-month:hover,
.flatpickr-next-month:hover { fill: var(--gold) !important; color: var(--gold) !important; }

.flatpickr-prev-month:hover svg,
.flatpickr-next-month:hover svg { fill: var(--gold) !important; }

/* ── Weekday row ── */
.flatpickr-weekdays {
  background: rgba(11,22,35,.88);
  padding: .35rem 0;
}

span.flatpickr-weekday {
  background: transparent;
  color: rgba(255,255,255,.38);
  font-size: .66rem;
  letter-spacing: 1px;
  text-transform: uppercase;
  font-family: Inter, sans-serif;
}

/* ── Days grid ── */
.flatpickr-days { border: 0; border-bottom: 1px solid #f0ece4; }

.dayContainer { padding: .5rem .4rem; gap: 1px; }

.flatpickr-day {
  border-radius: 0;
  font-size: .86rem;
  border: 0;
  color: var(--text);
  height: 38px;
  line-height: 38px;
  max-width: 38px;
  transition: background .15s, color .15s;
}

.flatpickr-day:hover,
.flatpickr-day:focus {
  background: rgba(201,168,76,.15);
  border-color: transparent;
  outline: 0;
}

/* Today */
.flatpickr-day.today {
  font-weight: 700;
  border-bottom: 2px solid var(--gold) !important;
  border-top: 0; border-left: 0; border-right: 0;
}

.flatpickr-day.today:hover { background: rgba(201,168,76,.15); }

/* Selected / range endpoints */
.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange,
.flatpickr-day.selected:hover,
.flatpickr-day.startRange:hover,
.flatpickr-day.endRange:hover,
.flatpickr-day.selected:focus,
.flatpickr-day.startRange:focus,
.flatpickr-day.endRange:focus {
  background: var(--gold) !important;
  border-color: var(--gold) !important;
  color: var(--navy) !important;
  font-weight: 700;
}

/* Range in-between */
.flatpickr-day.inRange,
.flatpickr-day.inRange:hover {
  background: rgba(201,168,76,.18) !important;
  border-color: transparent !important;
  box-shadow: -5px 0 0 rgba(201,168,76,.18), 5px 0 0 rgba(201,168,76,.18) !important;
  color: var(--text);
}

/* Out-of-month days */
.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay { color: #cac3b8; }

/* Disabled days */
.flatpickr-day.disabled,
.flatpickr-day.disabled:hover {
  color: #d4cdc5;
  background: transparent;
  text-decoration: line-through;
  cursor: not-allowed;
}

/* ── Two-month layout ── */
.flatpickr-calendar.multiMonth { width: auto !important; }
.flatpickr-rContainer { display: inline-block; }

.flatpickr-calendar.multiMonth .flatpickr-rContainer + .flatpickr-rContainer {
  border-left: 1px solid var(--border);
}

/* ── Footer (time / buttons) ── */
.flatpickr-time { border-top: 1px solid var(--border); }
.flatpickr-time .flatpickr-am-pm { color: var(--gold); }

/* ── Alt input inside hero search ── */
.hero-search-grid .flatpickr-input,
.hero-search-grid .flatpickr-alt-input {
  border: 0 !important;
  padding: 0 !important;
  border-radius: 0 !important;
  min-height: 30px;
  font-size: .95rem;
  color: var(--text);
  background: transparent !important;
  box-shadow: none !important;
  width: 100%;
  cursor: pointer;
}

/* ── Alt input inside booking form ── */
.form-card .flatpickr-alt-input {
  border: 1px solid #d5cfc6;
  border-radius: 0;
  min-height: 48px;
  font-size: .95rem;
  background: var(--cream);
  color: var(--text);
  padding: .375rem .75rem;
  width: 100%;
  cursor: pointer;
  transition: border-color .2s var(--ease), box-shadow .2s var(--ease);
}

.form-card .flatpickr-alt-input:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(201,168,76,.15);
  background: #fff;
  outline: 0;
}

/* ── Date input wrapper with icon ── */
.date-input-wrap { position: relative; }

.date-input-wrap .cal-icon {
  position: absolute;
  right: .75rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--gold);
  font-size: .85rem;
  pointer-events: none;
  z-index: 1;
}

/* Responsive calendar */
@media (max-width: 767.98px) {
  .flatpickr-calendar { font-size: .9rem; }
  .dayContainer { padding: .35rem .25rem; }
  .flatpickr-day { height: 34px; line-height: 34px; max-width: 34px; font-size: .82rem; }
}

/* ═══════════════════════════════════════
   15b. STATS BAND
═══════════════════════════════════════ */
.stats-band {
  background: var(--navy);
  padding: 2.8rem 0;
}

.stats-grid {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0;
}

.stat-item {
  flex: 1 1 160px;
  text-align: center;
  padding: 1.2rem 1.5rem;
}

.stat-number {
  font-family: Marcellus, serif;
  font-size: 2.4rem;
  color: #fff;
  line-height: 1;
  margin-bottom: .35rem;
}

.stat-number span {
  font-size: 1.2rem;
  color: var(--gold);
  font-family: Inter, sans-serif;
  font-weight: 700;
}

.stat-label {
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: #6a8499;
  font-family: Inter, sans-serif;
}

.stat-sep {
  width: 1px;
  height: 48px;
  background: rgba(255,255,255,.1);
  flex-shrink: 0;
}

/* ═══════════════════════════════════════
   15c. REVIEWS SECTION
═══════════════════════════════════════ */
.reviews-section {
  background: var(--cream-dark);
  padding: 5rem 0 4.5rem;
}

.reviews-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 2rem;
  margin-bottom: 3rem;
}

.reviews-head h2 { font-size: clamp(1.8rem,3vw,2.4rem); margin: .4rem 0 0; }

.reviews-stars-summary {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-shrink: 0;
}

.rss-score {
  font-family: Marcellus, serif;
  font-size: 3rem;
  line-height: 1;
  color: var(--navy);
}

.review-card {
  background: #fff;
  padding: 2rem;
  border: 1px solid var(--border);
  height: 100%;
  display: flex;
  flex-direction: column;
  transition: transform .3s var(--ease), box-shadow .3s var(--ease);
}

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

.review-stars {
  color: #f4b41a;
  font-size: .9rem;
  letter-spacing: 2px;
  margin-bottom: 1.1rem;
}

.review-quote {
  font-size: .9rem;
  line-height: 1.8;
  color: #3d4f5e;
  font-style: italic;
  flex: 1;
  margin: 0 0 1.5rem;
  padding: 0;
  border: 0;
  position: relative;
}

.review-quote::before {
  content: '\201C';
  font-family: Marcellus, serif;
  font-size: 3.5rem;
  color: var(--gold);
  line-height: 0;
  vertical-align: -1.2rem;
  margin-right: .2rem;
  opacity: .6;
}

.review-author {
  display: flex;
  align-items: center;
  gap: .9rem;
  border-top: 1px solid var(--border);
  padding-top: 1.2rem;
}

.review-avatar {
  width: 42px; height: 42px;
  border-radius: 50%;
  background: var(--navy);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-family: Marcellus, serif;
  font-size: 1.1rem;
  flex-shrink: 0;
}

.review-name {
  font-weight: 600;
  font-size: .88rem;
  color: var(--navy);
}

.review-meta {
  font-size: .75rem;
  color: var(--muted);
  margin-top: .15rem;
}

.reviews-nav {
  display: flex;
  gap: .5rem;
  justify-content: center;
  margin-top: 2.5rem;
}

.rev-nav-btn {
  width: 46px; height: 46px;
  background: #fff;
  border: 1px solid var(--border);
  color: var(--navy);
  font-size: 1.1rem;
  cursor: pointer;
  transition: all .25s var(--ease);
  display: flex; align-items: center; justify-content: center;
}

.rev-nav-btn:hover {
  background: var(--navy);
  border-color: var(--navy);
  color: #fff;
}

/* ═══════════════════════════════════════
   15d. CTA BAND
═══════════════════════════════════════ */
.cta-band {
  background: linear-gradient(135deg, #0b1623 0%, #1b3048 60%, #0d2035 100%);
  padding: 5rem 0;
  position: relative;
  overflow: hidden;
}

.cta-band::before {
  content: '';
  position: absolute;
  top: -60px; right: -60px;
  width: 320px; height: 320px;
  border-radius: 50%;
  background: rgba(201,168,76,.07);
}

.cta-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2.5rem;
  flex-wrap: wrap;
}

.cta-btn {
  font-size: .82rem;
  padding: .85rem 2.5rem;
  flex-shrink: 0;
  letter-spacing: .8px;
}

/* ═══════════════════════════════════════
   16. RESPONSIVE
═══════════════════════════════════════ */
@media (max-width: 1199.98px) {
  :root { --header-h: 68px; }
  .experience-slide::before { width: 260px; }
  .experience-panel { margin-left: 8%; }
}

@media (max-width: 991.98px) {
  :root { --header-h: 68px; }

  .stat-sep { display: none; }
  .stats-grid { gap: 0; }
  .stat-item { flex: 1 1 140px; }

  .reviews-head { flex-direction: column; align-items: flex-start; gap: 1rem; }
  .cta-inner { flex-direction: column; align-items: flex-start; }

  .hero-content { padding-bottom: 160px; }
  /* 3-col variant becomes 2-col on tablet */
  .hero-search-grid--3col { grid-template-columns: 1fr 1fr; }
  .hero-search-grid--3col .hero-search-btn { grid-column: span 2; height: 52px; }
  .hero-search-grid--3col > div:nth-child(2) { border-right: 0; }
  /* legacy 4-col */
  .hero-search-grid:not(.hero-search-grid--3col) { grid-template-columns: 1fr 1fr; }
  .hero-search-grid:not(.hero-search-grid--3col) .hero-search-btn { grid-column: span 2; height: 52px; }
  .hero-search-grid:not(.hero-search-grid--3col) > div:nth-child(2) { border-right: 0; }

  .experience-header { flex-direction: column; align-items: flex-start; gap: .75rem; }
  .experience-slide::before { width: 190px; }
  .experience-panel { margin-left: 5%; max-width: 290px; }
  .experience-section .carousel-control-prev { left: 42%; }
  .experience-section .carousel-control-next { left: calc(42% + 50px); }

  .chalet-group-carousel { padding: 0; }
  .detail-cover { height: 360px; }
  .booking-panel { position: static; margin-top: 2rem; }
  .conf-row { grid-template-columns: 140px 1fr; padding: 1rem 1.5rem; }
  .conf-actions { padding: 1.4rem 1.5rem; }
  .conf-header { padding: 2.5rem 1.5rem; }
}

@media (max-width: 767.98px) {
  :root { --header-h: 64px; }
  .stat-item { flex: 1 1 44%; padding: 1rem; }
  .stat-number { font-size: 2rem; }
  .reviews-section { padding: 3.5rem 0 3rem; }
  .cta-band { padding: 3.5rem 0; }

  /* 3-col variant: stacks to 1 column on mobile */
  .hero-search-grid--3col { grid-template-columns: 1fr; }
  .hero-search-grid--3col > div { border-right: 0; border-bottom: 1px solid #ebe8e2; }
  .hero-search-grid--3col > div:last-child { border-bottom: 0; }
  .hero-search-grid--3col .hero-search-btn { grid-column: 1; height: 52px; }
  .hero-content { padding-bottom: 240px; }

  .experience-slide::before { display: none; }
  .experience-panel { margin: 0 5%; max-width: none; width: 90%; }
  .experience-section .carousel-control-prev { left: 36%; }
  .experience-section .carousel-control-next { left: calc(36% + 52px); }
  .experience-header { padding: 3rem 0 1.5rem; }

  .rooms-section { padding: 3rem 0 2.5rem; }
  .chalet-group-carousel { padding: 0; }
  .detail-cover { height: 260px; }
  .form-card { padding: 1.5rem; }
  .page-band { padding: 2rem 0; margin-bottom: 2rem; }

  .conf-row { grid-template-columns: 1fr; gap: .1rem; padding: .9rem 1.2rem; }
  .conf-label { margin-bottom: 0; }
  .conf-header { padding: 2rem 1.2rem; }
  .conf-actions { padding: 1.2rem; flex-direction: column; }
  .conf-actions .btn { text-align: center; }

  .cancel-card-head { padding: 1.4rem 1.5rem; }
  .cancel-card-body { padding: 1.5rem; }
  .app-footer { padding: 3rem 0 2rem; }
  .footer-bottom { flex-direction: column; }
}

@media (max-width: 575.98px) {
  .hero-title { font-size: 2.3rem; }
  .hero-content { padding-bottom: 310px; }
  .boliin-hero .carousel-control-prev { left: 10px; }
  .boliin-hero .carousel-control-next { right: 10px; }
  .chalet-group-carousel { padding: 0; }
  .cgc-btn { width: 38px; height: 38px; font-size: 1rem; }
  .rooms-mobile-scroll .room-item { flex: 0 0 88vw; }
}

/* ─── Language switcher ─── */
.lang-switch { display: flex; align-items: center; }
.lang-switch form { display: flex; }
.lang-btn {
  background: transparent;
  border: 1px solid rgba(255,255,255,.4);
  color: rgba(255,255,255,.65);
  padding: .22rem .6rem;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .5px;
  cursor: pointer;
  transition: background .2s, color .2s, border-color .2s;
  line-height: 1.5;
}
.lang-btn:first-of-type { border-radius: 3px 0 0 3px; border-right: none; }
.lang-btn:last-of-type  { border-radius: 0 3px 3px 0; }
.lang-btn.active,
.lang-btn:hover         { background: rgba(255,255,255,.18); color: #fff; }

/* ─── Mobile: make language switch unmistakably visible inside burger menu.
       The header is dark but Bootstrap's collapsed menu drops onto a light
       background, which made the white-on-white buttons invisible (as the
       owners reported). Repaint with high contrast borders, a stronger
       color, and a dedicated row with a 🌐 hint so guests notice it. ─── */
@media (max-width: 991.98px) {
  .lang-switch {
    width: 100%;
    justify-content: center;
    padding: .65rem 0;
    margin-top: .25rem;
    border-top: 1px solid rgba(0,0,0,.08);
  }
  .lang-switch::before {
    content: "🌐";
    font-size: 1.05rem;
    margin-right: .5rem;
    line-height: 1.5;
  }
  .lang-btn {
    background: #fff;
    border: 1.5px solid var(--gold, #c9a84c);
    color: #614c12;
    padding: .42rem 1.1rem;
    font-size: .85rem;
    min-width: 56px;
    text-align: center;
  }
  .lang-btn.active {
    background: var(--gold, #c9a84c);
    color: #fff;
    border-color: var(--gold, #c9a84c);
  }
  .lang-btn:hover {
    background: #faf6ec;
    color: #614c12;
  }
  .lang-btn.active:hover {
    background: var(--gold, #c9a84c);
    color: #fff;
  }
}

/* ---------------------------------------
   AUTH PAGES (Login / Register)
--------------------------------------- */
.auth-page {
  min-height: calc(100vh - var(--header-h) - 120px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 3rem 1rem;
}

.auth-card {
  background: #fff;
  width: 100%;
  max-width: 460px;
  padding: 2.8rem 2.6rem;
  box-shadow: var(--sh-lg);
  border-top: 3px solid var(--gold);
}

.auth-header { text-align: center; margin-bottom: 2rem; }
.auth-title  { font-size: 1.8rem; margin: .4rem 0 .5rem; }
.auth-subtitle { color: var(--muted); font-size: .88rem; }

.auth-field { margin-bottom: 1.2rem; }
.auth-field label {
  display: block;
  font-size: .78rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .6px;
  color: var(--navy);
  margin-bottom: .4rem;
}
.auth-field .form-control {
  border: 1.5px solid var(--border);
  border-radius: 2px;
  padding: .7rem 1rem;
  font-size: .92rem;
  width: 100%;
  transition: border-color .2s;
}
.auth-field .form-control:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(201,168,76,.15);
}
.auth-error { color: var(--red); font-size: .8rem; display: block; margin-top: .25rem; }
.auth-hint  { color: var(--muted); font-size: .78rem; display: block; margin-top: .25rem; }
.auth-alert {
  background: #fff4f2;
  border-left: 3px solid var(--red);
  padding: .75rem 1rem;
  font-size: .85rem;
  color: var(--red);
  margin-bottom: 1.2rem;
}

.auth-remember { margin-bottom: 1.5rem; }
.auth-check-label {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .85rem;
  color: var(--muted);
  cursor: pointer;
}

.btn-auth-submit {
  display: block; width: 100%;
  background: var(--navy);
  color: #fff;
  border: none;
  padding: .95rem;
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .22s var(--ease);
  margin-bottom: 1.5rem;
}
.btn-auth-submit:hover { background: var(--gold); color: var(--navy); }

.auth-footer {
  text-align: center;
  font-size: .85rem;
  color: var(--muted);
  border-top: 1px solid var(--border);
  padding-top: 1.2rem;
}
.auth-footer a { color: var(--gold); font-weight: 600; margin-left: .3rem; }
.auth-footer a:hover { text-decoration: underline; }

/* ── Profile page (wider card with two-column layout) ───────────────────── */
.auth-card-wide { max-width: 880px; }

.auth-alert-ok {
  background: #ecfdf5;
  border-left: 3px solid #10b981;
  color: #065f46;
}

.profile-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  margin-bottom: 1.5rem;
}

.profile-section-title {
  font-size: .9rem;
  text-transform: uppercase;
  letter-spacing: .8px;
  color: var(--gold);
  font-weight: 700;
  margin: 0 0 1rem;
  padding-bottom: .5rem;
  border-bottom: 1px solid var(--border);
}

.profile-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.profile-actions {
  display: flex;
  gap: 1rem;
  align-items: center;
  border-top: 1px solid var(--border);
  padding-top: 1.5rem;
}

.profile-actions .btn-auth-submit { margin-bottom: 0; flex: 1; }

.btn-auth-ghost {
  display: inline-block;
  padding: .95rem 1.5rem;
  border: 1.5px solid var(--navy);
  color: var(--navy);
  background: transparent;
  text-transform: uppercase;
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: 1px;
  text-decoration: none;
  transition: background .22s var(--ease), color .22s var(--ease);
}
.btn-auth-ghost:hover { background: var(--navy); color: #fff; }

@media (max-width: 760px) {
  .profile-grid { grid-template-columns: 1fr; gap: 1rem; }
  .profile-row  { grid-template-columns: 1fr; }
  .profile-actions { flex-direction: column; }
  .profile-actions .btn-auth-ghost { width: 100%; text-align: center; }
}

/* nav user dropdown */
.nav-user-btn { display: flex; align-items: center; gap: .5rem; }
.nav-user-avatar {
  width: 28px; height: 28px;
  background: var(--gold);
  color: var(--navy);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  flex-shrink: 0;
}
.nav-dropdown {
  border: 1px solid var(--border);
  border-radius: 2px;
  box-shadow: var(--sh-md);
  min-width: 180px;
}
.nav-dropdown .dropdown-item { font-size: .88rem; padding: .6rem 1rem; }
.nav-dropdown .dropdown-item:hover { background: var(--cream); color: var(--navy); }

/* ---------------------------------------
   ADMIN DASHBOARD
--------------------------------------- */
.admin-page { padding: 2.5rem 2rem 4rem; max-width: 1300px; margin: 0 auto; }
.admin-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 2rem; flex-wrap: wrap; gap: 1rem; }
.admin-title { font-size: clamp(1.5rem,3vw,2.2rem); margin: .25rem 0 0; }
.admin-header-actions { display: flex; gap: .75rem; }

.admin-kpi-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(170px,1fr)); gap: 1rem; margin-bottom: 2rem; }
.admin-kpi { background: #fff; border: 1px solid #e2dcd0; border-radius: 8px; padding: 1.25rem 1.5rem; text-align: center; }
.admin-kpi .kpi-val { font-size: 2rem; font-weight: 700; color: var(--navy); font-family: var(--font-serif); }
.admin-kpi .kpi-label { font-size: .72rem; text-transform: uppercase; letter-spacing: 1px; color: var(--muted); margin-top: .25rem; }
.kpi-green .kpi-val { color: #16a34a; }
.kpi-amber .kpi-val { color: #d97706; }
.kpi-red   .kpi-val { color: #dc2626; }
.kpi-gold  .kpi-val { color: var(--gold); }

.admin-quick-links { display: grid; grid-template-columns: repeat(auto-fill,minmax(180px,1fr)); gap: 1rem; margin-bottom: 2rem; }
.admin-quick-card { display: flex; align-items: center; gap: .75rem; background: #fff; border: 1px solid #e2dcd0; border-radius: 8px; padding: 1rem 1.25rem; text-decoration: none; color: var(--dark); transition: border-color .2s, box-shadow .2s; }
.admin-quick-card:hover { border-color: var(--gold); box-shadow: 0 4px 16px rgba(0,0,0,.07); color: var(--dark); }
.aqc-icon { font-size: 1.5rem; }

/* Group headers above each quick-link block (Operations vs Administration) */
.admin-section-header {
  display: flex;
  align-items: center;
  gap: .65rem;
  margin: 2rem 0 1rem;
  padding-bottom: .55rem;
  border-bottom: 2px solid var(--gold, #c9a84c);
}
.admin-section-header--secondary { border-bottom-color: #b3b8c2; }
.ash-icon  { font-size: 1.4rem; line-height: 1; }
.ash-title { margin: 0; font-size: 1rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--dark, #1c2733); }

.admin-section { margin-top: 2rem; }
.admin-section-title { font-size: 1.1rem; margin-bottom: 1rem; padding-bottom: .5rem; border-bottom: 1px solid #e2dcd0; }

.admin-table-wrap { overflow-x: auto; border-radius: 8px; border: 1px solid #e2dcd0; background: #fff; }
.admin-table { width: 100%; border-collapse: collapse; font-size: .875rem; }
.admin-table th { background: var(--cream); font-size: .72rem; text-transform: uppercase; letter-spacing: .8px; padding: .75rem 1rem; text-align: left; color: var(--muted); border-bottom: 1px solid #e2dcd0; }
.admin-table td { padding: .75rem 1rem; border-bottom: 1px solid #f0ebe3; vertical-align: middle; }
.admin-table tr:last-child td { border-bottom: none; }
.admin-table tr:hover td { background: #faf8f5; }
.admin-link { color: var(--gold); font-weight: 600; text-decoration: none; }
.admin-link:hover { text-decoration: underline; }

/* Bookings list — high-contrast "View" button so it never disappears against the row background */
.btn-admin-view {
    display: inline-flex; align-items: center; gap: .35rem;
    padding: .35rem .75rem;
    background: var(--navy); color: #fff !important;
    border: 1px solid var(--navy);
    border-radius: 6px;
    font-size: .78rem; font-weight: 600;
    text-decoration: none !important;
    white-space: nowrap;
    transition: background .15s, color .15s, border-color .15s, transform .1s;
}
.btn-admin-view:hover {
    background: var(--gold); color: var(--navy) !important;
    border-color: var(--gold);
    transform: translateY(-1px);
}
.btn-admin-view:active { transform: translateY(0); }

/* Payment-source mini-badges (Stripe vs cash/cheque vs mixed) shown under the
   PaymentStatus column on the admin bookings list. Kept tiny so they don't
   compete with the primary status badge. */
.pay-source {
    display: inline-flex; align-items: center; gap: .2rem;
    margin-top: .25rem;
    padding: .12rem .45rem;
    border-radius: 8px;
    font-size: .65rem; font-weight: 600;
    letter-spacing: .3px;
    border: 1px solid transparent;
}
.pay-source-stripe { background: #ede9fe; color: #5b21b6; border-color: #c4b5fd; }
.pay-source-manual { background: #ecfdf5; color: #047857; border-color: #a7f3d0; }
.pay-source-mixed  { background: #fef3c7; color: #92400e; border-color: #fcd34d; }
.pay-source-none   { background: #f3f4f6; color: #6b7280; border-color: #e5e7eb; }
.text-center { text-align: center; }
.text-green { color: #16a34a; font-weight: 600; }
.text-red   { color: #dc2626; font-weight: 600; }

.admin-badge { display: inline-block; padding: .2rem .65rem; border-radius: 12px; font-size: .72rem; font-weight: 600; text-transform: uppercase; letter-spacing: .5px; }
.pay-pending        { background: #fff3cd; color: #856404; }
.pay-partiallypaid  { background: #dbeafe; color: #1e40af; }
.pay-paid           { background: #dcfce7; color: #15803d; }
.pay-failed         { background: #fee2e2; color: #b91c1c; }
.pay-refunded       { background: #f3e8ff; color: #7e22ce; }
.pay-refundpending  { background: #fff7e6; color: #92400e; }
.bk-pending       { background: #fff3cd; color: #856404; }
.bk-confirmed     { background: #dcfce7; color: #15803d; }
.bk-cancelled     { background: #fee2e2; color: #b91c1c; }
.bk-expired       { background: #f1f5f9; color: #64748b; }

.admin-filters { display: flex; gap: .5rem; flex-wrap: wrap; margin-bottom: 1.5rem; }
.admin-filter-btn { padding: .4rem 1rem; border-radius: 20px; font-size: .8rem; border: 1px solid #e2dcd0; background: #fff; color: var(--dark); text-decoration: none; transition: background .2s, border-color .2s; }
.admin-filter-btn:hover, .admin-filter-btn.active { background: var(--navy); color: #fff; border-color: var(--navy); }

.admin-detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; align-items: start; }
@media (max-width: 768px) { .admin-detail-grid { grid-template-columns: 1fr; } }

.admin-detail-card { background: #fff; border: 1px solid #e2dcd0; border-radius: 8px; padding: 1.5rem; }
.admin-detail-card h3 { font-size: .85rem; text-transform: uppercase; letter-spacing: 1px; color: var(--gold); margin-bottom: .75rem; }

.admin-info-table { width: 100%; border-collapse: collapse; font-size: .88rem; }
.admin-info-table td { padding: .5rem .25rem; border-bottom: 1px solid #f0ebe3; vertical-align: top; }
.admin-info-table td:first-child { color: var(--muted); width: 40%; }
.admin-info-table th { font-size: .72rem; text-transform: uppercase; letter-spacing: .8px; color: var(--muted); padding: .4rem .25rem; text-align: left; }

.admin-invoice-table { width: 100%; border-collapse: collapse; font-size: .9rem; }
.admin-invoice-table td { padding: .5rem 0; border-bottom: 1px solid #f0ebe3; }
.admin-invoice-table td:last-child { text-align: right; }
.admin-invoice-table .invoice-total td { border-top: 2px solid var(--navy); border-bottom: none; padding-top: .75rem; font-size: 1rem; }

.admin-action-card { background: #fff; border: 1px solid #e2dcd0; border-radius: 8px; padding: 1.25rem 1.5rem; margin-top: 1rem; }
.admin-action-card h4 { margin: 0 0 .5rem; font-size: .9rem; }
.admin-action-danger { border-color: #fca5a5; background: #fff5f5; }

.admin-form-row { margin-bottom: 1.25rem; }
.admin-form-row label { display: block; font-size: .82rem; color: var(--muted); margin-bottom: .4rem; }
.admin-form-row small { display: block; font-size: .75rem; color: var(--muted); margin-top: .3rem; }
.admin-input { border: 1px solid #e2dcd0; border-radius: 5px; padding: .45rem .75rem; font-size: .88rem; background: #fff; }
.admin-input-group { display: flex; align-items: center; gap: .4rem; }
.admin-input-group span { font-size: .88rem; color: var(--muted); }
.admin-pricing-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px,1fr)); gap: 1.5rem; }

.admin-settings-form  { margin-bottom: 3rem; }
.admin-section-desc   { font-size: .85rem; color: var(--muted); margin: .25rem 0 1.25rem; }
.admin-save-row       { margin-top: 1.25rem; }
.admin-section-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; margin-bottom: 1.25rem; flex-wrap: wrap; }

/* ── Rule cards ── */
.admin-rules-section  { margin-top: 2rem; }
.admin-rule-card {
  background: #fff;
  border: 1px solid #e2dcd0;
  border-radius: 8px;
  margin-bottom: .75rem;
  overflow: hidden;
}
.admin-rule-card.rule-inactive { opacity: .65; }
.admin-rule-card.rule-new { border-style: dashed; border-color: var(--gold); }

.admin-rule-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .9rem 1.25rem;
  cursor: pointer;
  user-select: none;
  gap: 1rem;
}
.admin-rule-header:hover { background: #faf8f4; }

.ard-info   { display: flex; align-items: center; gap: .75rem; flex-wrap: wrap; font-size: .85rem; }
.ard-status { font-size: .75rem; font-weight: 700; letter-spacing: .5px; white-space: nowrap; }
.ard-status.status-on  { color: #15803d; }
.ard-status.status-off { color: #9ca3af; }
.ard-name   { font-weight: 700; color: var(--navy); }
.ard-meta   { color: var(--muted); }
.ard-chalets { font-style: italic; max-width: 280px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ard-chevron { color: var(--muted); font-size: .9rem; transition: transform .2s; }
.admin-rule-header[aria-expanded="true"] .ard-chevron { transform: rotate(180deg); }
.ard-new-title { padding: 1rem 1.25rem .25rem; font-size: .95rem; color: var(--gold); margin: 0; }

/* ── Rule edit form ── */
.admin-rule-form  { padding: 1.25rem; border-top: 1px solid #f0ebe3; }
.arf-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 1rem;
  margin-bottom: 1.25rem;
}
.arf-field label        { display: block; font-size: .78rem; color: var(--muted); margin-bottom: .3rem; }
.arf-field input,
.arf-field select       { width: 100%; }

.arf-chalets-section    { margin-bottom: 1.25rem; }
.arf-chalets-label      { display: block; font-size: .78rem; color: var(--muted); margin-bottom: .5rem; font-weight: 600; }
.arf-applies-toggle     { display: flex; gap: 1.5rem; margin-bottom: .75rem; }
.arf-radio              { display: flex; align-items: center; gap: .4rem; font-size: .85rem; cursor: pointer; }
.arf-radio input        { width: auto; cursor: pointer; }

.arf-chalet-checkboxes  { display: flex; flex-wrap: wrap; gap: .5rem .75rem; padding: .75rem; background: #faf8f4; border: 1px solid #e2dcd0; border-radius: 6px; }
.arf-chalet-cb          { display: flex; align-items: center; gap: .35rem; font-size: .82rem; cursor: pointer; white-space: nowrap; }
.arf-chalet-cb input    { width: auto; cursor: pointer; }

.arf-actions            { display: flex; align-items: center; gap: .6rem; flex-wrap: wrap; padding-top: .75rem; border-top: 1px solid #f0ebe3; }
.btn-sm                 { padding: .35rem .9rem !important; font-size: .8rem !important; }
.admin-empty-state      { text-align: center; padding: 2rem; color: var(--muted); font-style: italic; }

.btn-admin-primary  { display: inline-flex; align-items: center; gap: .4rem; padding: .55rem 1.4rem; background: var(--navy); color: #fff; border: none; border-radius: 6px; font-size: .88rem; font-weight: 600; cursor: pointer; text-decoration: none; transition: background .2s; }
.btn-admin-primary:hover  { background: #0f1d2a; color: #fff; }
.btn-admin-secondary { display: inline-flex; align-items: center; gap: .4rem; padding: .55rem 1.4rem; background: var(--cream); color: var(--navy); border: 1px solid #e2dcd0; border-radius: 6px; font-size: .88rem; font-weight: 600; cursor: pointer; text-decoration: none; transition: background .2s; }
.btn-admin-secondary:hover { background: #e2dcd0; }
.btn-admin-ghost   { display: inline-flex; align-items: center; gap: .4rem; padding: .45rem 1rem; background: transparent; color: var(--muted); border: 1px solid #e2dcd0; border-radius: 6px; font-size: .82rem; cursor: pointer; text-decoration: none; transition: border-color .2s, color .2s; }
.btn-admin-ghost:hover { border-color: var(--navy); color: var(--navy); }
.btn-admin-danger  { display: inline-flex; align-items: center; gap: .4rem; padding: .55rem 1.4rem; background: #dc2626; color: #fff; border: none; border-radius: 6px; font-size: .88rem; font-weight: 600; cursor: pointer; transition: background .2s; }
.btn-admin-danger:hover { background: #b91c1c; }

.admin-alert { padding: .85rem 1.2rem; border-radius: 6px; font-size: .88rem; margin-bottom: 1.5rem; }
.admin-alert-ok  { background: #dcfce7; color: #15803d; border-left: 4px solid #16a34a; }
.admin-alert-err { background: #fee2e2; color: #b91c1c; border-left: 4px solid #dc2626; }

/* ---------------------------------------
   MY BOOKINGS PAGE
--------------------------------------- */
.my-bookings-page { padding: 3rem 0 4rem; }

.mb-head { margin-bottom: 2.5rem; }
.mb-head h1 { font-size: clamp(1.8rem,3vw,2.4rem); margin: .4rem 0 .5rem; }
.mb-welcome  { color: var(--muted); font-size: .92rem; }

.mb-empty {
  text-align: center;
  padding: 4rem 2rem;
  background: #fff;
  border: 1px solid var(--border);
}
.mb-empty-icon { font-size: 3rem; margin-bottom: 1rem; }
.mb-empty h3   { font-size: 1.4rem; margin-bottom: .5rem; }
.mb-empty p    { color: var(--muted); margin-bottom: 1.5rem; }

.mb-list { display: flex; flex-direction: column; gap: 1.2rem; }

.mb-card {
  display: grid;
  grid-template-columns: 200px 1fr;
  background: #fff;
  border: 1px solid var(--border);
  overflow: hidden;
  transition: box-shadow .2s var(--ease);
}
.mb-card:hover { box-shadow: var(--sh-md); }

.mb-card-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}

.mb-card-body { padding: 1.4rem 1.6rem; display: flex; flex-direction: column; gap: .9rem; }

.mb-card-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; flex-wrap: wrap; }
.mb-chalet-title { font-size: 1.15rem; margin: 0 0 .2rem; }
.mb-location { font-size: .8rem; color: var(--muted); }

.mb-badges { display: flex; gap: .4rem; flex-wrap: wrap; }
.mb-badge {
  padding: .22rem .65rem;
  border-radius: 99px;
  font-size: .72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .4px;
}
.status-confirmed { background: #e6f4ea; color: #1e7e34; }
.status-pending   { background: #fff8e1; color: #856404; }
.status-cancelled { background: #fde8e8; color: #9c2222; }
.status-expired   { background: #f0f0f0; color: #666; }
.pay-paid           { background: #e6f4ea; color: #1e7e34; }
.pay-pending        { background: #fff8e1; color: #856404; }
.pay-failed         { background: #fde8e8; color: #9c2222; }
.pay-refunded       { background: #e8f0fe; color: #1a56db; }
.pay-refundpending  { background: #fff7e6; color: #92400e; }

.mb-card-dates {
  display: flex;
  align-items: center;
  gap: 1.2rem;
  flex-wrap: wrap;
  padding: .8rem 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.mb-date-sep { color: var(--muted); font-size: 1.1rem; }
.mb-date-item { display: flex; flex-direction: column; }
.mb-date-label { font-size: .7rem; text-transform: uppercase; letter-spacing: .5px; color: var(--muted); }
.mb-date-val   { font-size: .92rem; font-weight: 600; color: var(--navy); margin-top: .1rem; }

.mb-card-footer { display: flex; justify-content: space-between; align-items: center; gap: 1rem; flex-wrap: wrap; }
.mb-total-label  { font-size: .75rem; color: var(--muted); text-transform: uppercase; letter-spacing: .4px; display: block; }
.mb-total-amount { font-size: 1.35rem; font-family: Marcellus,serif; color: var(--navy); }

.mb-actions { display: flex; gap: .6rem; flex-wrap: wrap; }
.btn-mb-manage, .btn-mb-view {
  padding: .5rem 1.1rem;
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .4px;
  cursor: pointer;
  transition: all .2s var(--ease);
  text-decoration: none;
  display: inline-block;
}
.btn-mb-manage {
  background: var(--navy);
  color: #fff;
  border: 1.5px solid var(--navy);
}
.btn-mb-manage:hover { background: var(--gold); border-color: var(--gold); color: var(--navy); }
.btn-mb-view {
  background: transparent;
  color: var(--navy);
  border: 1.5px solid var(--border);
}
.btn-mb-view:hover { border-color: var(--navy); }

@media (max-width: 640px) {
  .mb-card { grid-template-columns: 1fr; }
  .mb-card-img { height: 180px; }
  .auth-card { padding: 2rem 1.4rem; }
}

/* ── Admin pagination ── */
.admin-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .75rem 1rem;
  border-top: 1px solid #e2dcd0;
  background: var(--cream);
  border-radius: 0 0 8px 8px;
  flex-wrap: wrap;
  gap: .5rem;
}
.pg-info {
  font-size: .8rem;
  color: var(--muted);
}
.pg-nav {
  display: flex;
  gap: .25rem;
  align-items: center;
  flex-wrap: wrap;
}
.pg-nav a,
.pg-nav button {
  min-width: 2rem;
  height: 2rem;
  padding: 0 .5rem;
  border: 1px solid #d6cfc4;
  background: #fff;
  border-radius: 5px;
  font-size: .8rem;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--navy);
  text-decoration: none;
  color: var(--navy);
  transition: background .15s, border-color .15s;
}
.pg-nav a:hover,
.pg-nav button:hover:not(:disabled) {
  background: var(--gold);
  border-color: var(--gold);
  color: #fff;
}
.pg-nav a.active,
.pg-nav button.active {
  background: var(--navy);
  border-color: var(--navy);
  color: #fff;
  font-weight: 600;
  pointer-events: none;
}
.pg-nav button:disabled {
  opacity: .35;
  cursor: default;
}
.pg-ellipsis {
  padding: 0 .35rem;
  color: var(--muted);
  font-size: .8rem;
}
.pg-size-form {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-size: .8rem;
  color: var(--muted);
}
.pg-size-form select {
  height: 2rem;
  padding: 0 .5rem;
  border: 1px solid #d6cfc4;
  border-radius: 5px;
  background: #fff;
  font-size: .8rem;
  cursor: pointer;
}

/* ── Admin create-booking form ── */
.admin-create-grid {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.adm-field-row {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
}
.adm-field {
  display: flex;
  flex-direction: column;
  flex: 1 1 160px;
  min-width: 140px;
}
.adm-label {
  font-size: .78rem;
  font-weight: 600;
  color: var(--muted);
  margin-bottom: .25rem;
  text-transform: uppercase;
  letter-spacing: .03em;
}
.admin-input-full {
  width: 100%;
  box-sizing: border-box;
}

/* ── ThingsToDo activity link buttons ── */
.ttd-btn-wrap {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
}
.ttd-btn-site {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  padding: .45rem .9rem;
  border-radius: 6px;
  font-size: .8rem;
  font-weight: 600;
  text-decoration: none;
  border: 1.5px solid var(--navy);
  color: var(--navy);
  background: transparent;
  transition: background .15s, color .15s;
  white-space: nowrap;
}
.ttd-btn-site:hover {
  background: var(--navy);
  color: #fff;
}
.ttd-btn-chalets {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  padding: .45rem .9rem;
  border-radius: 6px;
  font-size: .8rem;
  font-weight: 600;
  text-decoration: none;
  background: var(--gold);
  color: #fff;
  border: 1.5px solid var(--gold);
  transition: background .15s;
  white-space: nowrap;
}
.ttd-btn-chalets:hover {
  background: #b8832a;
  border-color: #b8832a;
  color: #fff;
}

/* ─────────────────────────────────────────────────────────────────────────
   Admin search bar + KPIs (Lot I)
   ───────────────────────────────────────────────────────────────────────── */
.admin-search-bar {
  background: #fff;
  border: 1px solid #e8ecf2;
  border-radius: 10px;
  padding: 1rem 1.2rem;
  margin: 1rem 0 1.2rem;
  box-shadow: 0 1px 3px rgba(20, 30, 50, .04);
}
.adm-search-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1.2fr auto;
  gap: 1rem;
  align-items: end;
}
@media (max-width: 900px) {
  .adm-search-row { grid-template-columns: 1fr 1fr; }
  .adm-search-actions { grid-column: 1 / -1; justify-content: flex-end; }
}
.adm-search-field { display: flex; flex-direction: column; gap: .35rem; }
.adm-search-label {
  font-size: .78rem;
  font-weight: 600;
  color: #5a6478;
  text-transform: uppercase;
  letter-spacing: .03em;
}
.adm-search-actions { display: flex; gap: .5rem; align-items: center; }

.adm-kpi-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: .9rem;
  margin: 1rem 0 1.4rem;
}
.adm-kpi {
  background: #fff;
  border: 1px solid #e8ecf2;
  border-left: 4px solid var(--gold);
  border-radius: 10px;
  padding: .9rem 1.1rem;
  display: flex;
  flex-direction: column;
  gap: .25rem;
  box-shadow: 0 1px 3px rgba(20, 30, 50, .04);
}
.adm-kpi-label {
  font-size: .75rem;
  font-weight: 600;
  color: #5a6478;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.adm-kpi-value {
  font-size: 1.55rem;
  font-weight: 700;
  color: var(--navy);
  line-height: 1.1;
}
.adm-kpi-value small {
  font-size: .85rem;
  color: #98a3b6;
  font-weight: 500;
}
.adm-kpi-hint {
  font-size: .72rem;
  color: #98a3b6;
}

/* ─────────────────────────────────────────────────────────────────────────
   Global availability calendar (Lot J)
   ───────────────────────────────────────────────────────────────────────── */
.cal-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin: 1.2rem 0 .8rem;
  flex-wrap: wrap;
}
.cal-nav-btn {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  padding: .5rem 1rem;
  border-radius: 6px;
  background: #fff;
  border: 1px solid #d6dde8;
  color: var(--navy);
  font-weight: 600;
  font-size: .9rem;
  text-decoration: none;
  transition: background .15s;
}
.cal-nav-btn:hover { background: #f4f6fa; }
.cal-nav-btn.cal-today { background: var(--gold); color: #fff; border-color: var(--gold); }
.cal-nav-btn.cal-today:hover { background: #b8832a; border-color: #b8832a; }
.cal-month-title {
  margin: 0;
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--navy);
  text-transform: capitalize;
  min-width: 220px;
  text-align: center;
}

.cal-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 1.2rem;
  justify-content: center;
  margin: 0 0 1rem;
  font-size: .82rem;
  color: #5a6478;
}
.cal-legend span { display: inline-flex; align-items: center; gap: .4rem; }
.cal-swatch {
  display: inline-block;
  width: 14px;
  height: 14px;
  border-radius: 3px;
  border: 1px solid rgba(0,0,0,.08);
}
.cal-swatch-free    { background: #f4f6fa; }
.cal-swatch-booked  { background: #2e7d57; }
.cal-swatch-pending { background: #d8a542; }
.cal-swatch-today   { background: #fff; border: 2px solid #4a90e2; }

.cal-grid-wrap {
  background: #fff;
  border: 1px solid #e8ecf2;
  border-radius: 10px;
  overflow-x: auto;
  box-shadow: 0 1px 3px rgba(20, 30, 50, .04);
}
.cal-grid {
  border-collapse: separate;
  border-spacing: 0;
  width: 100%;
  font-size: .82rem;
  table-layout: fixed;
}
.cal-grid thead th { position: sticky; top: 0; background: #f4f6fa; z-index: 2; }
.cal-row-head {
  background: #f4f6fa;
  border-right: 1px solid #e2e6ee;
  border-bottom: 1px solid #e2e6ee;
  padding: .55rem .7rem;
  text-align: left;
  font-weight: 600;
  width: 200px;
  min-width: 180px;
  position: sticky;
  left: 0;
  z-index: 3;
  display: table-cell;
}
.cal-grid thead .cal-row-head { z-index: 4; }
.cal-chalet-num { display: block; font-size: .75rem; color: var(--gold); font-weight: 700; }
.cal-chalet-name { display: block; font-size: .85rem; color: var(--navy); }

.cal-day-head {
  width: 32px;
  min-width: 32px;
  padding: .35rem .15rem;
  text-align: center;
  border-bottom: 1px solid #e2e6ee;
  border-right: 1px solid #eef0f5;
  color: #5a6478;
  font-weight: 600;
}
.cal-day-num  { display: block; font-size: .9rem; color: var(--navy); }
.cal-day-name { display: block; font-size: .65rem; text-transform: uppercase; color: #98a3b6; }
.cal-weekend  { background: #fbfafa; }
.cal-today-col { background: #eef4fc !important; }
.cal-today-col .cal-day-num { color: #1f5fb8; }

.cal-cell {
  height: 38px;
  border-right: 1px solid #eef0f5;
  border-bottom: 1px solid #eef0f5;
  background: #fff;
  position: relative;
  vertical-align: middle;
  padding: 0;
}
.cal-cell-booked   { background: #2e7d57; }
.cal-cell-pending  { background: #d8a542; }
.cal-cell-partial  { background: #4a90c8; }
.cal-cell-arrival  { border-top-left-radius: 18px; border-bottom-left-radius: 18px; }
.cal-cell-departure{ border-top-right-radius: 18px; border-bottom-right-radius: 18px; }
.cal-cell-link {
  display: block;
  width: 100%;
  height: 100%;
  color: #fff;
  text-decoration: none;
  font-size: .72rem;
  line-height: 1.1;
  padding: .25rem .35rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cal-cell-name {
  font-weight: 600;
  text-shadow: 0 1px 2px rgba(0,0,0,.2);
}
.cal-cell:hover .cal-cell-link { opacity: .85; }

/* ───────────────────────────────────────────────────────────────────────────
   Lots D + E — admin carousel + content management
   ─────────────────────────────────────────────────────────────────────────── */
.admin-tabs {
  display: flex;
  gap: .35rem;
  flex-wrap: wrap;
  border-bottom: 1px solid #e2dcd0;
  margin: 1.2rem 0 1.5rem;
}
.admin-tab {
  padding: .65rem 1.2rem;
  font-size: .85rem;
  font-weight: 600;
  color: #68778a;
  text-decoration: none;
  border: 1px solid transparent;
  border-bottom: 2px solid transparent;
  border-radius: 6px 6px 0 0;
  margin-bottom: -1px;
  transition: all .15s ease;
}
.admin-tab:hover {
  color: #1c2733;
  background: #f6f1e6;
}
.admin-tab.active {
  color: #1c2733;
  background: #fff;
  border-color: #e2dcd0;
  border-bottom-color: #fff;
}

.slide-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 1rem;
  margin-bottom: 1.5rem;
}
.slide-card {
  background: #fff;
  border: 1px solid #e2dcd0;
  border-radius: 10px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: border-color .15s ease;
}
.slide-card:hover { border-color: #c5b68f; }
.slide-card.is-inactive { opacity: .65; }
.slide-card-img {
  width: 100%;
  height: 170px;
  background-size: cover;
  background-position: center;
  background-color: #1c2733;
}
.slide-card-body {
  padding: .85rem 1rem 1rem;
  display: flex;
  flex-direction: column;
  gap: .35rem;
}
.slide-card-meta {
  display: flex;
  justify-content: space-between;
  font-size: .72rem;
  color: #68778a;
  text-transform: uppercase;
  letter-spacing: .5px;
}
.slide-pos { font-weight: 600; }
.slide-status.ok  { color: #2e7d57; }
.slide-status.off { color: #b5651d; }
.slide-overline {
  font-size: .72rem;
  color: #68778a;
  text-transform: uppercase;
  letter-spacing: .8px;
}
.slide-title {
  font-weight: 600;
  font-size: 1rem;
  color: #1c2733;
}
.slide-edit {
  margin-top: .6rem;
  border-top: 1px dashed #e2dcd0;
  padding-top: .6rem;
}
.slide-edit summary {
  cursor: pointer;
  font-size: .8rem;
  color: #1c2733;
  font-weight: 600;
}
.slide-form {
  margin-top: .8rem;
  display: flex;
  flex-direction: column;
  gap: .6rem;
}

.adm-checkbox {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .85rem;
  color: #1c2733;
  cursor: pointer;
}
.adm-checkbox input[type="checkbox"] { width: 16px; height: 16px; }

.btn-admin-danger {
  display: inline-block;
  padding: .55rem 1.1rem;
  font-size: .8rem;
  font-weight: 600;
  border-radius: 4px;
  border: 1px solid #c0392b;
  background: #fff;
  color: #c0392b;
  cursor: pointer;
  transition: all .15s ease;
  text-decoration: none;
}
.btn-admin-danger:hover { background: #c0392b; color: #fff; }

.empty-state {
  background: #f6f1e6;
  border: 1px dashed #d4c8aa;
  border-radius: 8px;
  padding: 2rem 1.5rem;
  text-align: center;
  color: #68778a;
  margin-bottom: 1.5rem;
}

