/* Maison Travel — front-end styling. Airbnb-inspired design system (DESIGN-airbnb.md).
   Pure white canvas, Rausch accent, Inter (Cereal substitute), soft rounded photo-first cards.
   Scoped under .maison-* to avoid theme clashes. */
:root {
  --m-rausch: #ff385c;
  --m-rausch-active: #e00b41;
  --m-ink: #222222;
  --m-body: #3f3f3f;
  --m-muted: #6a6a6a;
  --m-muted-soft: #929292;
  --m-hairline: #dddddd;
  --m-hairline-soft: #ebebeb;
  --m-strong: #c1c1c1;
  --m-canvas: #ffffff;
  --m-soft: #f7f7f7;
  --m-fill: #f2f2f2;
  --m-shadow: rgba(0,0,0,.02) 0 0 0 1px, rgba(0,0,0,.04) 0 2px 6px 0, rgba(0,0,0,.1) 0 4px 8px 0;
  --m-r-sm: 8px;
  --m-r-md: 14px;
  --m-r-full: 9999px;
  --m-sans: "Inter", "Airbnb Cereal VF", Circular, -apple-system, system-ui, Roboto, "Helvetica Neue", sans-serif;
}

.maison-wrap { font-family: var(--m-sans); color: var(--m-ink); max-width: 1120px; margin: 0 auto; }
.maison-wrap *, .maison-wrap *::before, .maison-wrap *::after { box-sizing: border-box; }

/* ---- Search bar (pill with segments + Rausch orb) ---- */
.maison-searchbar {
  display: flex; align-items: stretch; background: var(--m-canvas);
  border: 1px solid var(--m-hairline); border-radius: var(--m-r-full);
  box-shadow: var(--m-shadow); padding: 6px 8px 6px 6px; margin: 8px 0 28px; gap: 0;
  text-align: left; /* reset any inherited centering (e.g. inside the hero) so labels align with their values */
}
.maison-seg { display: flex; flex-direction: column; justify-content: center; gap: 2px; padding: 8px 20px; position: relative; flex: 1 1 0; }
.maison-seg + .maison-seg::before { content: ""; position: absolute; left: 0; top: 12px; bottom: 12px; width: 1px; background: var(--m-hairline); }
.maison-seg__label { font-size: 12px; font-weight: 600; color: var(--m-ink); letter-spacing: .01em; }
.maison-seg__input { border: 0; background: transparent; padding: 2px 0; font-size: 14px; font-family: var(--m-sans); color: var(--m-ink); width: 100%; min-width: 90px; }
.maison-seg__input:focus { outline: none; }
.maison-seg__input::placeholder { color: var(--m-muted-soft); }

/* "Where" suggested destinations */
.maison-seg--where { position: relative; }
.maison-where__pop { position: absolute; top: calc(100% + 16px); left: 0; z-index: 30; width: 420px; max-width: 92vw;
  max-height: 420px; overflow-y: auto; background: #fff; border: 1px solid var(--m-hairline-soft); border-radius: var(--m-r-md);
  box-shadow: var(--m-shadow); padding: 18px 8px 12px; }
.maison-where__title { font-size: 13px; font-weight: 600; color: var(--m-ink); padding: 0 16px 8px; }
.maison-where__list { list-style: none; margin: 0; padding: 0; }
.maison-where__item { display: flex; align-items: center; gap: 16px; padding: 10px 16px; border-radius: var(--m-r-sm); cursor: pointer; }
.maison-where__item:hover { background: var(--m-soft); }
.maison-where__icon { flex: 0 0 auto; width: 48px; height: 48px; border-radius: 12px; background: var(--m-fill); display: flex; align-items: center; justify-content: center; }
.maison-where__icon svg { width: 24px; height: 24px; }
.maison-where__txt { display: flex; flex-direction: column; }
.maison-where__t { font-size: 15px; font-weight: 500; color: var(--m-ink); }
.maison-where__s { font-size: 14px; color: var(--m-muted); }

/* "When" calendar range picker */
.maison-seg--when { cursor: pointer; }
.maison-when__toggle { border: 0; background: transparent; padding: 2px 0; font-size: 14px; font-family: var(--m-sans); color: var(--m-ink); text-align: left; cursor: pointer; }
.maison-when__toggle.is-empty { color: var(--m-muted-soft); }
.maison-when__pop { position: absolute; top: calc(100% + 16px); left: 50%; transform: translateX(-50%); z-index: 30;
  width: 720px; max-width: 92vw; background: #fff; border: 1px solid var(--m-hairline-soft); border-radius: var(--m-r-md);
  box-shadow: var(--m-shadow); padding: 24px; }
.maison-when__cal { position: relative; }
.maison-cal__nav { position: absolute; top: 2px; left: 0; right: 0; display: flex; justify-content: space-between; }
.maison-cal__arrow { width: 36px; height: 36px; border-radius: 50%; border: 0; background: transparent; font-size: 20px; line-height: 1; color: var(--m-ink); cursor: pointer; }
.maison-cal__arrow:hover:not(:disabled) { background: var(--m-soft); }
.maison-cal__arrow:disabled { color: #dcdcdc; cursor: default; }
.maison-cal__months { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; }
.maison-cal__title { text-align: center; font-size: 16px; font-weight: 600; margin-bottom: 16px; }
.maison-cal__grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; }
.maison-cal__wd { text-align: center; font-size: 12px; color: var(--m-muted); padding-bottom: 8px; }
.maison-cal__day { border: 0; background: transparent; aspect-ratio: 1; border-radius: 50%; font-size: 14px; color: var(--m-ink); cursor: pointer; font-family: var(--m-sans); }
.maison-cal__day:hover:not(:disabled):not(.is-selected) { box-shadow: inset 0 0 0 1px var(--m-ink); }
.maison-cal__day.is-disabled { color: #dcdcdc; cursor: default; }
.maison-cal__day.is-range { background: var(--m-soft); border-radius: 0; }
.maison-cal__day.is-selected { background: var(--m-ink); color: #fff; }
@media (max-width: 744px) { .maison-cal__months { grid-template-columns: 1fr; gap: 24px; } }

/* "Who" stepper popover */
.maison-seg--who { cursor: pointer; }
/* Kill the default UA focus ring on search-bar controls; a subtle keyboard ring only on buttons.
   Text inputs get no ring — the caret already signals focus, and a ring on a full-width field
   looks like an error state. */
.maison-searchbar :focus, .maison-resv :focus { outline: none; }
.maison-searchbar button:focus-visible, .maison-resv button:focus-visible { box-shadow: 0 0 0 2px rgba(255,56,92,.35); border-radius: var(--m-r-sm); }
.maison-seg__input:focus, .maison-seg__input:focus-visible { outline: none; box-shadow: none; }
.maison-who__toggle { border: 0; background: transparent; padding: 2px 0; font-size: 14px; font-family: var(--m-sans); color: var(--m-ink); text-align: left; cursor: pointer; }
.maison-who__toggle.is-empty { color: var(--m-muted-soft); }
.maison-who__pop { position: absolute; top: calc(100% + 16px); right: 0; z-index: 30; width: 340px; max-width: 90vw;
  background: #fff; border: 1px solid var(--m-hairline-soft); border-radius: var(--m-r-md); box-shadow: var(--m-shadow); padding: 6px 22px; }
.maison-who__row { display: flex; justify-content: space-between; align-items: center; padding: 18px 0; }
.maison-who__row + .maison-who__row { border-top: 1px solid var(--m-hairline-soft); }
.maison-who__t { font-size: 15px; font-weight: 600; color: var(--m-ink); }
.maison-who__s { font-size: 13px; color: var(--m-muted); margin-top: 2px; }
.maison-stepper { display: flex; align-items: center; gap: 12px; }
.maison-stepper button { width: 32px; height: 32px; border-radius: 50%; border: 1px solid var(--m-strong); background: #fff; color: var(--m-ink);
  font-size: 18px; line-height: 1; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; transition: border-color .15s; }
.maison-stepper button:hover:not(:disabled) { border-color: var(--m-ink); }
.maison-stepper button:disabled { border-color: var(--m-hairline-soft); color: #d4d4d4; cursor: not-allowed; }
.maison-stepper span { min-width: 22px; text-align: center; font-size: 15px; color: var(--m-ink); }
.maison-orb {
  flex: 0 0 auto; align-self: center; margin-left: auto; border: 0; cursor: pointer;
  width: 48px; height: 48px; border-radius: var(--m-r-full); background: var(--m-rausch);
  color: #fff; display: inline-flex; align-items: center; justify-content: center; transition: background .15s;
}
.maison-orb:hover { background: var(--m-rausch-active); }
.maison-orb svg { width: 18px; height: 18px; stroke: #fff; }

/* ---- Buttons ---- */
.maison-btn {
  display: inline-block; border: 0; cursor: pointer; text-decoration: none; text-align: center;
  font-family: var(--m-sans); font-weight: 500; font-size: 15px; line-height: 1.25;
  padding: 13px 22px; border-radius: var(--m-r-sm); transition: background .15s, border-color .15s;
}
.maison-btn--primary { background: var(--m-rausch); color: #fff; }
.maison-btn--primary:hover { background: var(--m-rausch-active); color: #fff; }
.maison-btn--secondary { background: var(--m-canvas); color: var(--m-ink); border: 1px solid var(--m-ink); }
.maison-btn--secondary:hover { background: var(--m-soft); }

/* ---- Results grid (photo-first cards, marketplace density) ---- */
.maison-results { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: 24px 20px; margin-bottom: 44px; }
.maison-card { display: flex; flex-direction: column; background: var(--m-canvas); }
.maison-card__photo {
  display: block; position: relative; aspect-ratio: 20 / 19; border-radius: var(--m-r-md); overflow: hidden;
  background: linear-gradient(135deg, #f2f2f2 0%, #e7e7e7 100%);
}
.maison-card__photo svg { position: absolute; inset: 0; margin: auto; width: 46px; height: 46px; stroke: #c9c9c9; }
.maison-card__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s ease; }
.maison-card:hover .maison-card__img { transform: scale(1.04); }
.maison-card:hover .maison-card__photo { box-shadow: var(--m-shadow); }
.maison-card__badge {
  position: absolute; top: 12px; left: 12px; z-index: 2; background: var(--m-canvas); color: var(--m-ink);
  font-size: 12px; font-weight: 600; padding: 5px 11px; border-radius: var(--m-r-full); box-shadow: var(--m-shadow);
}
.maison-card__body { display: block; text-decoration: none; color: var(--m-ink); padding: 12px 2px 0; }
.maison-card__head { display: flex; justify-content: space-between; align-items: baseline; gap: 10px; }
.maison-card__title { font-size: 16px; font-weight: 600; color: var(--m-ink); margin: 0; line-height: 1.3;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.maison-card__rating { display: inline-flex; align-items: center; gap: 4px; font-size: 14px; color: var(--m-ink); white-space: nowrap; }
.maison-card__rating svg { width: 13px; height: 13px; fill: var(--m-ink); }
.maison-card__meta { color: var(--m-muted); font-size: 14px; line-height: 1.43; margin-top: 2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.maison-card__price { color: var(--m-ink); font-size: 15px; margin-top: 6px; }
.maison-card__price strong { font-weight: 600; }
.maison-card__price .m-muted { color: var(--m-muted); font-weight: 400; }

/* ---- Supplier comparison (compact expandable) ---- */
.maison-compare { margin-top: 8px; }
.maison-compare > summary { color: var(--m-ink); font-size: 13px; cursor: pointer; text-decoration: underline; list-style: none; }
.maison-compare > summary::-webkit-details-marker { display: none; }
.maison-compare ul { list-style: none; margin: 8px 0 0; padding: 10px 12px; background: var(--m-soft); border-radius: var(--m-r-sm); font-size: 14px; }
.maison-compare li { display: flex; justify-content: space-between; padding: 5px 0; color: var(--m-muted); }
.maison-compare li + li { border-top: 1px solid var(--m-hairline-soft); }
.maison-compare li.is-best { color: var(--m-ink); font-weight: 500; }
.maison-badge { background: var(--m-ink); color: #fff; font-size: 10px; letter-spacing: .04em; padding: 2px 8px; border-radius: var(--m-r-full); margin-left: 8px; }

/* ---- Hotel detail page ---- */
.maison-back { display: inline-block; color: var(--m-ink); font-size: 14px; text-decoration: none; margin-bottom: 8px; }
.maison-back:hover { text-decoration: underline; }
.maison-hotel__banner { aspect-ratio: 24 / 9; border-radius: var(--m-r-md); background: linear-gradient(135deg, #f2f2f2, #e7e7e7);
  display: flex; align-items: center; justify-content: center; margin-bottom: 18px; }
.maison-hotel__banner { overflow: hidden; }
.maison-hotel__banner svg { width: 60px; height: 60px; stroke: #c9c9c9; }
.maison-hotel__img { width: 100%; height: 100%; object-fit: cover; display: block; }
.maison-hotel__title { font-size: 26px; font-weight: 600; letter-spacing: -.02em; margin: 0 0 6px; color: var(--m-ink); }
.maison-hotel__meta { color: var(--m-ink); font-size: 15px; margin-bottom: 20px; }
.maison-hotel__meta .m-star { display: inline-flex; align-items: center; gap: 4px; }
.maison-guests { display: flex; flex-wrap: wrap; gap: 14px; margin: 4px 0 16px; }
.maison-guests .maison-field { display: flex; flex-direction: column; gap: 6px; }
.maison-guests .maison-field label { font-size: 12px; font-weight: 600; color: var(--m-ink); }
.maison-guests .maison-field input { border: 1px solid var(--m-hairline); border-radius: var(--m-r-sm); padding: 10px 12px; font-size: 14px; width: 92px; font-family: var(--m-sans); }
.maison-guests .maison-field input:focus { outline: none; border-color: var(--m-ink); }
.maison-rooms { border-top: 1px solid var(--m-hairline); }
.maison-room { display: flex; justify-content: space-between; align-items: center; gap: 18px; padding: 20px 4px; border-bottom: 1px solid var(--m-hairline); }
.maison-room__name { font-size: 16px; font-weight: 600; color: var(--m-ink); }
.maison-room__board { color: var(--m-muted); font-size: 14px; margin-top: 3px; }
.maison-room__aside { text-align: right; display: flex; flex-direction: column; align-items: flex-end; gap: 8px; }
.maison-room__price { font-size: 18px; font-weight: 600; color: var(--m-ink); }
.maison-room__price small { display: block; font-size: 13px; color: var(--m-muted); font-weight: 400; }

/* ---- Airbnb-style listing page ---- */
.maison-gallery { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; border-radius: var(--m-r-md); overflow: hidden; margin: 8px 0 22px; aspect-ratio: 2 / 1; }
.maison-gallery__main { overflow: hidden; }
.maison-gallery__main img { width: 100%; height: 100%; object-fit: cover; display: block; }
.maison-gallery__grid { display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 8px; }
.maison-gallery__grid img { width: 100%; height: 100%; object-fit: cover; display: block; }
.maison-gallery--empty { display: flex; align-items: center; justify-content: center; background: var(--m-fill); }
.maison-gallery--empty svg { width: 64px; height: 64px; stroke: #c9c9c9; }

.maison-l__title { font-size: 26px; font-weight: 600; letter-spacing: -.02em; margin: 6px 0 4px; color: var(--m-ink); }
.maison-l__sub { font-size: 16px; color: var(--m-ink); }
.maison-l__meta { font-size: 15px; color: var(--m-body); margin-top: 4px; }
.maison-l__star { display: inline-flex; align-items: center; gap: 4px; }

.maison-listing { display: grid; grid-template-columns: minmax(0, 1fr) 360px; column-gap: 48px; row-gap: 0;
  grid-template-areas: "head aside" "body aside"; align-items: start; }
.maison-listing__head { grid-area: head; }
.maison-listing__body { grid-area: body; }
.maison-listing__aside { grid-area: aside; position: sticky; top: 24px; }

.maison-l__section { padding: 24px 0; border-top: 1px solid var(--m-hairline); margin-top: 24px; }
.maison-l__h2 { font-size: 20px; font-weight: 600; margin: 0 0 16px; color: var(--m-ink); }
.maison-l__desc { font-size: 15px; line-height: 1.6; color: var(--m-body); margin: 0; }

.maison-l__fav { display: flex; justify-content: space-between; align-items: center; gap: 16px; border: 1px solid var(--m-hairline); border-radius: var(--m-r-md); padding: 16px 20px; margin-top: 16px; box-shadow: var(--m-shadow); }
.maison-l__favsub { font-size: 13px; color: var(--m-muted); margin-top: 2px; }
.maison-l__favrating { display: inline-flex; align-items: center; gap: 4px; font-size: 18px; font-weight: 600; }

.maison-l__highlights { display: grid; gap: 18px; }
.maison-l__hl { display: flex; gap: 16px; align-items: flex-start; }
.maison-l__hlicon { flex: 0 0 auto; }
.maison-l__hlsub { font-size: 13px; color: var(--m-muted); margin-top: 2px; }

.maison-l__amenities { display: grid; grid-template-columns: 1fr 1fr; gap: 16px 24px; }
.maison-l__amenity { display: flex; align-items: center; gap: 12px; font-size: 15px; color: var(--m-body); }

/* Sticky reservation card */
.maison-resv { border: 1px solid var(--m-hairline); border-radius: var(--m-r-md); box-shadow: var(--m-shadow); padding: 22px; }
.maison-resv__price { font-size: 15px; color: var(--m-ink); margin-bottom: 16px; }
.maison-resv__price strong { font-size: 22px; font-weight: 600; }
.maison-resv__from { color: var(--m-muted); font-size: 13px; }
.maison-resv__nights { color: var(--m-muted); font-size: 13px; }
.maison-resv__note { font-size: 13px; color: var(--m-muted); text-align: center; margin: 10px 0 0; }

/* Card: interactive dates (two cells) + guests field */
.maison-resv__stay { position: relative; }
.maison-resv__dates { display: grid; grid-template-columns: 1fr 1fr; width: 100%; border: 1px solid var(--m-strong); border-radius: var(--m-r-sm) var(--m-r-sm) 0 0; background: #fff; cursor: pointer; padding: 0; }
.maison-resv__dates .maison-resv__cell { text-align: left; padding: 10px 12px; }
.maison-resv__dates .maison-resv__cell + .maison-resv__cell { border-left: 1px solid var(--m-strong); }
.maison-resv__cell span { display: block; font-size: 10px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--m-ink); }
.maison-resv__cell b { font-size: 14px; font-weight: 400; color: var(--m-ink); }
.maison-resv__whobox { position: relative; margin-bottom: 14px; }
.maison-resv__guests { width: 100%; text-align: left; background: #fff; border: 1px solid var(--m-strong); border-top: 0; border-radius: 0 0 var(--m-r-sm) var(--m-r-sm); padding: 10px 12px; cursor: pointer; display: flex; flex-direction: column; gap: 2px; }
.maison-resv__glabel { font-size: 10px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--m-ink); }
.maison-resv__guests [data-who-val] { font-size: 14px; color: var(--m-ink); }
.maison-resv__roombox { position: relative; margin-bottom: 14px; }
.maison-resv__roomtoggle { width: 100%; text-align: left; background: #fff; border: 1px solid var(--m-strong);
  border-radius: var(--m-r-sm); padding: 10px 28px 10px 12px; cursor: pointer; display: flex; flex-direction: column; gap: 2px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23222' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 12px center; }
.maison-resv__rval { font-size: 14px; color: var(--m-ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.maison-room__pop { position: absolute; top: calc(100% + 8px); left: 0; right: 0; z-index: 30;
  max-height: 320px; overflow-y: auto; background: #fff; border: 1px solid var(--m-hairline-soft);
  border-radius: var(--m-r-md); box-shadow: var(--m-shadow); padding: 10px 8px; }
.maison-room__pop .maison-where__item[aria-selected] { background: var(--m-fill); }
/* Card add-ons: optional extras, each a tappable row with price; ticking updates the total live. */
.maison-resv__addons { margin: 0 0 14px; border: 1px solid var(--m-strong); border-radius: var(--m-r-sm); padding: 12px 14px; }
.maison-resv__addonstitle { display: block; font-size: 10px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--m-ink); margin-bottom: 8px; }
.maison-resv__addon { display: flex; align-items: center; gap: 10px; padding: 7px 0; font-size: 14px; color: var(--m-ink); cursor: pointer; }
.maison-resv__addon + .maison-resv__addon { border-top: 1px solid var(--m-hairline-soft); }
.maison-resv__addon input { accent-color: var(--m-rausch); width: 18px; height: 18px; flex: none; margin: 0; cursor: pointer; }
.maison-resv__addonname { flex: 1; }
.maison-resv__addonprice { color: var(--m-muted); font-size: 13px; font-weight: 500; }
.maison-resv__update { width: 100%; margin-bottom: 8px; }
.maison-resv__book { width: 100%; }
.maison-resv .maison-who__pop { left: 0; right: 0; width: auto; }
.maison-resv .maison-when__pop { left: auto; right: 0; transform: none; }
@media (max-width: 900px) { .maison-resv .maison-when__pop { right: auto; left: 0; } }

@media (max-width: 900px) {
  /* head → booking card → details/rooms */
  .maison-listing { grid-template-columns: 1fr; row-gap: 24px; grid-template-areas: "head" "aside" "body"; }
  .maison-listing__aside { position: static; }
  .maison-gallery { grid-template-columns: 1fr; aspect-ratio: auto; }
  .maison-gallery__grid { display: none; }
  .maison-gallery__main { aspect-ratio: 3 / 2; }
  .maison-l__amenities { grid-template-columns: 1fr; }
}

.maison-empty { color: var(--m-muted); font-size: 16px; padding: 32px 0; text-align: center; }

/* ---- Responsive ---- */
@media (max-width: 744px) {
  .maison-searchbar { flex-direction: column; border-radius: var(--m-r-md); padding: 8px; }
  .maison-seg { padding: 10px 12px; }
  .maison-seg + .maison-seg::before { display: none; }
  .maison-seg + .maison-seg { border-top: 1px solid var(--m-hairline-soft); }
  .maison-orb { width: 100%; border-radius: var(--m-r-sm); margin-top: 6px; }
  .maison-orb::after { content: "Search"; margin-left: 8px; font-weight: 500; }
  .maison-results { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) { .maison-results { grid-template-columns: 1fr; } }

/* ---- Motion: smooth, consistent easing + gentle popover entrances ---- */
:root { --m-ease: cubic-bezier(.4, 0, .2, 1); }

@keyframes maisonPop { from { opacity: 0; transform: translateY(-8px) scale(.985); } to { opacity: 1; transform: none; } }
@keyframes maisonFade { from { opacity: 0; } to { opacity: 1; } }

.maison-who__pop, .maison-where__pop, .maison-room__pop { animation: maisonPop .2s var(--m-ease) both; transform-origin: top; }
.maison-when__pop { animation: maisonFade .2s var(--m-ease) both; }

/* Smoother hovers/interactions (override the earlier snappier transitions) */
.maison-card { transition: transform .3s var(--m-ease), box-shadow .3s var(--m-ease); }
.maison-card__img { transition: transform .6s var(--m-ease); }
.maison-btn { transition: background .22s var(--m-ease), transform .22s var(--m-ease), box-shadow .22s var(--m-ease); }
.maison-btn--primary:hover { transform: translateY(-1px); }
.maison-orb { transition: background .22s var(--m-ease), transform .22s var(--m-ease); }
.maison-orb:hover { transform: scale(1.06); }
.maison-stepper button, .maison-cal__arrow { transition: background .18s var(--m-ease), border-color .18s var(--m-ease), color .18s var(--m-ease); }
.maison-cal__day { transition: box-shadow .15s var(--m-ease), background .15s var(--m-ease), color .15s var(--m-ease); }
.maison-room, .maison-resv, .maison-l__fav, .maison-search, .maison-searchbar { transition: box-shadow .25s var(--m-ease), transform .25s var(--m-ease); }
.maison-where__item { transition: background .16s var(--m-ease); }
.maison-seg__input, .maison-guests .maison-field input { transition: border-color .18s var(--m-ease), box-shadow .18s var(--m-ease); }
.maison-compare > summary, .maison-back, .maison-card__title a { transition: color .16s var(--m-ease); }
.maison-resv__addon input, .maison-stepper span { transition: all .15s var(--m-ease); }

@media (prefers-reduced-motion: reduce) {
  .maison-wrap *, .maison-who__pop, .maison-where__pop, .maison-when__pop { animation: none !important; transition: none !important; }
}

/* ---- Skeleton loaders (shimmer) ---- */
@keyframes maisonShimmer { 0% { background-position: -450px 0; } 100% { background-position: 450px 0; } }
.maison-skel, .maison-card__photo, .maison-hotel__banner, .maison-gallery__main, .maison-gallery__grid {
  background-image: linear-gradient(90deg, #eeeeee 25%, #f6f6f6 37%, #eeeeee 63%);
  background-size: 900px 100%; animation: maisonShimmer 1.4s infinite linear;
}
.maison-card__photo.is-loaded, .maison-hotel__banner.is-loaded, .maison-gallery__main.is-loaded, .maison-gallery__grid.is-loaded {
  animation: none; background-image: none;
}
/* Images fade in over the shimmer once loaded. Default is VISIBLE (opacity:1) so an image
   can never get stuck hidden if JS fails or a cached load event is missed. Only images JS
   marks as still-loading are hidden; they fade to opacity:1 when is-loaded is added. */
.maison-card__img, .maison-hotel__img, .maison-gallery img { transition: opacity .5s var(--m-ease), transform .6s var(--m-ease); }
.maison-card__img.is-loading, .maison-hotel__img.is-loading, .maison-gallery img.is-loading { opacity: 0; }
.maison-card__img.is-loaded, .maison-hotel__img.is-loaded, .maison-gallery img.is-loaded { opacity: 1; }

/* Skeleton cards shown while a new search loads */
.maison-skelcard { display: flex; flex-direction: column; }
.maison-skelcard__photo { aspect-ratio: 20 / 19; border-radius: var(--m-r-md); }
.maison-skelcard__line { height: 14px; border-radius: 6px; margin-top: 12px; }
.maison-skelcard__line.short { width: 55%; margin-top: 8px; }

@media (prefers-reduced-motion: reduce) {
  .maison-skel, .maison-card__photo, .maison-hotel__banner, .maison-gallery__main, .maison-gallery__grid { animation: none; }
  .maison-card__img, .maison-hotel__img, .maison-gallery img,
  .maison-card__img.is-loading, .maison-hotel__img.is-loading, .maison-gallery img.is-loading { opacity: 1; transition: none; }
}

/* ---- Smooth page transitions (View Transitions API — progressive enhancement) ---- */
/* Opt every same-origin navigation into a cross-document transition. Unsupported browsers ignore
   this and navigate normally, so it degrades cleanly. */
@view-transition { navigation: auto; }

@keyframes maison-vt-fade-in { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
@keyframes maison-vt-fade-out { from { opacity: 1; } to { opacity: 0; } }

::view-transition-old(root) { animation: maison-vt-fade-out .18s var(--m-ease) both; }
::view-transition-new(root) { animation: maison-vt-fade-in .34s var(--m-ease) both; }

/* Keep the header pinned across navigations so the chrome feels like a persistent app shell. */
.maison-site-header { view-transition-name: maison-header; }
/* Destination for the result-card → hotel photo morph (source name is set on the clicked card by JS). */
.maison-gallery__main { view-transition-name: maison-hero-img; }
::view-transition-group(maison-hero-img) { animation-duration: .38s; animation-timing-function: var(--m-ease); }

/* Navigation progress bar (nprogress-style) shown while the next page loads. */
.maison-nprogress { position: fixed; top: 0; left: 0; height: 3px; width: 0; z-index: 99999; pointer-events: none;
  background: linear-gradient(90deg, var(--m-rausch), #ff7a90); box-shadow: 0 0 10px rgba(255,56,92,.55);
  opacity: 0; border-radius: 0 2px 2px 0; transition: width .2s var(--m-ease), opacity .25s var(--m-ease); }
.maison-nprogress.is-active { opacity: 1; }
.maison-nprogress.is-done { transition: width .22s var(--m-ease), opacity .4s var(--m-ease) .12s; }

@media (prefers-reduced-motion: reduce) {
  ::view-transition-old(root), ::view-transition-new(root),
  ::view-transition-group(maison-hero-img) { animation: none !important; }
  .maison-nprogress { display: none; }
}

/* ---- Listing content polish (highlights / amenities / guest favourite) ---- */
.maison-l__section { padding: 28px 0; }
.maison-l__h2 { font-size: 20px; font-weight: 600; letter-spacing: -.01em; margin: 0 0 18px; }
.maison-l__desc { max-width: 62ch; font-size: 15px; line-height: 1.7; color: var(--m-body); }

/* Guest favourite */
.maison-l__fav { padding: 18px 22px; border-radius: var(--m-r-md); margin-top: 18px; }
.maison-l__fav strong { font-size: 17px; font-weight: 600; }
.maison-l__favsub { font-size: 14px; color: var(--m-muted); margin-top: 3px; }
.maison-l__favrating { font-size: 20px; font-weight: 600; gap: 6px; white-space: nowrap; }

/* Highlights — distinct icon, aligned text block */
.maison-l__highlights { gap: 22px; }
.maison-l__hl { display: flex; gap: 18px; align-items: flex-start; }
.maison-l__hlicon { flex: 0 0 auto; width: 28px; display: flex; justify-content: center; color: var(--m-ink); padding-top: 1px; }
.maison-l__hlicon svg { width: 26px; height: 26px; }
.maison-l__hltext { display: flex; flex-direction: column; gap: 3px; }
.maison-l__hltitle { font-size: 16px; font-weight: 500; color: var(--m-ink); line-height: 1.3; }
.maison-l__hlsub { font-size: 14px; color: var(--m-muted); line-height: 1.4; }

/* Amenities — aligned icon column, consistent rhythm */
.maison-l__amenities { grid-template-columns: 1fr 1fr; gap: 18px 32px; }
.maison-l__amenity { display: flex; align-items: center; gap: 16px; font-size: 16px; color: var(--m-ink); min-height: 28px; }
.maison-l__amicon { flex: 0 0 auto; width: 26px; display: flex; justify-content: center; color: #484848; }
.maison-l__amicon svg { width: 24px; height: 24px; }

/* ---- Theme-agnostic reset: neutralize theme element defaults inside our widget.
   :where() has ZERO specificity, so these never override our .maison-* component rules,
   but they do normalize whatever the active theme sets on base elements. ---- */
:where(.maison-wrap) { line-height: 1.4; font-size: 16px; text-align: left; }
:where(.maison-wrap) button { font: inherit; margin: 0; padding: 0; background: transparent; border: 0; color: inherit; text-align: inherit; line-height: inherit; -webkit-appearance: none; appearance: none; box-shadow: none; }
:where(.maison-wrap) input[type="text"], :where(.maison-wrap) input[type="number"], :where(.maison-wrap) input[type="date"] { font: inherit; margin: 0; color: inherit; background: transparent; box-shadow: none; }
:where(.maison-wrap) ul, :where(.maison-wrap) ol, :where(.maison-wrap) li { margin: 0; padding: 0; list-style: none; background: none; }
:where(.maison-wrap) a { text-decoration: none; color: inherit; box-shadow: none; }
:where(.maison-wrap) a:hover { color: inherit; }
:where(.maison-wrap) img { max-width: 100%; display: block; border: 0; border-radius: 0; box-shadow: none; }
:where(.maison-wrap) svg { display: block; }
:where(.maison-wrap) h1, :where(.maison-wrap) h2, :where(.maison-wrap) h3, :where(.maison-wrap) p { margin: 0; padding: 0; font-weight: inherit; color: inherit; }
:where(.maison-wrap) label { margin: 0; }
:where(.maison-wrap) details > summary { list-style: none; }

/* ---- Calendar fix: fixed 44px cells (not column-width), connected range, circular endpoints ---- */
.maison-cal__grid { grid-template-columns: repeat(7, 44px); justify-content: center; gap: 0; }
.maison-cal__wd { width: 44px; }
.maison-cal__day {
  width: 44px; height: 44px; aspect-ratio: auto; margin: 0; padding: 0;
  display: inline-flex; align-items: center; justify-content: center; border-radius: 50%;
}
.maison-cal__day:hover:not(:disabled):not(.is-selected) { box-shadow: inset 0 0 0 1.5px var(--m-ink); }
.maison-cal__day.is-range { background: var(--m-soft); border-radius: 0; box-shadow: none; }
.maison-cal__day.is-selected { background: var(--m-ink); color: #fff; border-radius: 50%; }
.maison-cal__grid > span:empty { width: 44px; height: 44px; }

/* ---- Landing hero (search bar inside a modern hero) ---- */
.maison-hero { position: relative; isolation: isolate; z-index: 5; border-radius: 22px; overflow: visible;
  padding: 84px 28px 52px; margin: 8px 0 34px; }
.maison-hero__bg { position: absolute; inset: 0; z-index: -1; border-radius: 22px; overflow: hidden;
  background-size: cover; background-position: center; }
.maison-hero__bg::after { content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(18,20,28,.30) 0%, rgba(18,20,28,.55) 100%); }
.maison-hero__body { max-width: 940px; margin: 0 auto; text-align: center; }
.maison-hero__title { color: #fff; font-family: var(--m-sans); font-size: 46px; font-weight: 700;
  letter-spacing: -.02em; line-height: 1.1; margin: 0 0 12px; text-shadow: 0 1px 24px rgba(0,0,0,.25); }
.maison-hero__sub { color: rgba(255,255,255,.94); font-size: 18px; line-height: 1.5; margin: 0 auto 30px; max-width: 620px; }
.maison-hero__search { max-width: 940px; margin: 0 auto; }
.maison-hero__search .maison-searchbar { margin: 0; box-shadow: 0 18px 50px rgba(0,0,0,.22); }
@media (max-width: 744px) {
  .maison-hero { padding: 52px 16px 34px; border-radius: 16px; }
  .maison-hero__bg { border-radius: 16px; }
  .maison-hero__title { font-size: 30px; }
  .maison-hero__sub { font-size: 16px; margin-bottom: 22px; }
}

/* ---- Showcase: Airbnb-style horizontal rows of property cards ---- */
.maison-showcase { margin: 8px 0 12px; }
.maison-row { margin: 0 0 30px; }
.maison-row__head { display: flex; align-items: flex-end; justify-content: space-between; margin: 0 0 14px; }
.maison-row__title { font-family: var(--m-sans); font-size: 22px; font-weight: 600; letter-spacing: -.01em;
  color: var(--m-ink); margin: 0; }
.maison-row__sub { font-size: 14px; color: var(--m-muted); margin: 3px 0 0; }
.maison-row__track { display: grid; grid-auto-flow: column;
  grid-auto-columns: minmax(210px, 1fr); gap: 20px;
  overflow-x: auto; scroll-snap-type: x mandatory;
  padding: 4px 0 8px; scrollbar-width: none; -webkit-overflow-scrolling: touch; }
.maison-row__track::-webkit-scrollbar { display: none; }

.maison-pcard { scroll-snap-align: start; display: flex; flex-direction: column;
  text-decoration: none; color: inherit;
  transition: transform var(--m-dur, .28s) var(--m-ease); }
.maison-pcard:hover { transform: translateY(-2px); }
.maison-pcard__photo { position: relative; aspect-ratio: 1/1; border-radius: var(--m-r-md);
  overflow: hidden; background: var(--m-fill); }
.maison-pcard__img { width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform .5s var(--m-ease); }
.maison-pcard:hover .maison-pcard__img { transform: scale(1.045); }
.maison-pcard__fav { position: absolute; top: 12px; left: 12px; z-index: 2;
  background: rgba(255,255,255,.95); color: var(--m-ink); font-size: 12px; font-weight: 600;
  padding: 6px 11px; border-radius: var(--m-r-full); box-shadow: 0 2px 6px rgba(0,0,0,.12); }
.maison-pcard__head { display: flex; align-items: center; justify-content: space-between;
  gap: 8px; margin: 11px 0 0; }
.maison-pcard__title { font-size: 15px; font-weight: 600; color: var(--m-ink); line-height: 1.3;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.maison-pcard__rating { display: inline-flex; align-items: center; gap: 4px; flex: none;
  font-size: 14px; color: var(--m-ink); }
.maison-pcard__rating svg { width: 13px; height: 13px; fill: var(--m-ink); }
.maison-pcard__loc { font-size: 14px; color: var(--m-muted); margin: 2px 0 0; }
.maison-pcard__price { font-size: 14px; color: var(--m-body); margin: 6px 0 0; }
.maison-pcard__price strong { color: var(--m-ink); font-weight: 600; }
@media (max-width: 744px) {
  .maison-row__track { grid-auto-columns: minmax(160px, 70%); gap: 14px; }
  .maison-row__title { font-size: 19px; }
}

/* ---- Auth modal (login / registration) ---- */
.maison-modal { position: fixed; inset: 0; z-index: 100000; display: flex; align-items: center; justify-content: center;
  font-family: var(--m-sans); padding: 16px; }
.maison-modal[hidden] { display: none; }
.maison-modal__overlay { position: absolute; inset: 0; background: rgba(0,0,0,.5); animation: maisonFade .2s var(--m-ease) both; }
.maison-modal__dialog { position: relative; z-index: 1; width: 420px; max-width: 100%; background: #fff; border-radius: 16px;
  box-shadow: 0 8px 28px rgba(0,0,0,.28); padding: 22px 24px 24px; animation: maisonPop .22s var(--m-ease) both; }
.maison-modal__close { position: absolute; top: 14px; left: 14px; width: 32px; height: 32px; border: 0; background: transparent;
  border-radius: 50%; font-size: 22px; line-height: 1; color: var(--m-ink); cursor: pointer; }
.maison-modal__close:hover { background: var(--m-fill); }
.maison-modal__head { text-align: center; border-bottom: 1px solid var(--m-hairline-soft); padding-bottom: 14px; margin-bottom: 20px; }
.maison-modal__logo { max-height: 30px; width: auto; margin: 2px auto 0; display: block; }
.maison-modal__orb { display: block; width: 30px; height: 30px; margin: 2px auto 0; border-radius: 50%; background: var(--m-rausch); }
.maison-modal__title { font-size: 15px; font-weight: 600; color: var(--m-ink); margin: 10px 0 0; }
.maison-modal__welcome { font-size: 22px; font-weight: 600; color: var(--m-ink); margin: 0 0 18px; letter-spacing: -.01em; }
.maison-auth__err { background: #fff5f6; border: 1px solid #ffc9d2; color: #b30020; font-size: 13.5px; line-height: 1.4;
  border-radius: 10px; padding: 10px 12px; margin-bottom: 14px; }
.maison-auth .maison-field { position: relative; margin-bottom: 12px; border: 1px solid var(--m-strong); border-radius: var(--m-r-sm);
  padding: 7px 12px; background: #fff; }
.maison-auth .maison-field:focus-within { border-color: var(--m-ink); box-shadow: 0 0 0 1px var(--m-ink); }
.maison-auth .maison-field label { display: block; font-size: 11px; color: var(--m-muted); }
.maison-auth .maison-field input { width: 100%; border: 0; background: transparent; font-size: 15px; font-family: var(--m-sans);
  color: var(--m-ink); padding: 2px 0 0; }
.maison-auth .maison-field input:focus { outline: none; box-shadow: none; }
.maison-auth__submit { width: 100%; margin-top: 6px; }
.maison-auth__foot { text-align: center; font-size: 14px; color: var(--m-muted); margin-top: 18px; }
.maison-auth__foot a { color: var(--m-rausch); font-weight: 600; text-decoration: none; margin-left: 4px; }
.maison-auth__foot a:hover { text-decoration: underline; }
@media (max-width: 480px) { .maison-modal__dialog { border-radius: 14px; } }

/* ---- Stepped "Confirm and pay" checkout ---- */
.maison-co { max-width: 1120px; margin: 0 auto; padding: 8px 24px 60px; font-family: var(--m-sans); color: var(--m-ink); }
.maison-co *, .maison-co *::before, .maison-co *::after { box-sizing: border-box; }
.maison-co__title { font-size: 30px; font-weight: 600; letter-spacing: -.02em; margin: 8px 0 26px; }
.maison-co__form { display: grid; grid-template-columns: 1fr 372px; gap: 48px; align-items: start; }
.maison-co__main { min-width: 0; }
.maison-co__aside { position: sticky; top: 96px; }

/* Step cards */
.maison-co__step { border: 1px solid var(--m-hairline); border-radius: 16px; padding: 20px 24px; margin-bottom: 20px; background: #fff; }
.maison-co__step.is-active { box-shadow: rgba(0,0,0,.04) 0 2px 8px 0; }
.maison-co__stephead { display: flex; align-items: center; justify-content: space-between; }
.maison-co__steptitle { font-size: 20px; font-weight: 600; color: var(--m-ink); margin: 0; display: flex; align-items: center; gap: 12px; }
.maison-co__step:not(.is-active):not(.is-done) .maison-co__steptitle { color: var(--m-muted-soft); }
.maison-co__num { flex: none; width: 26px; height: 26px; border-radius: 50%; background: var(--m-ink); color: #fff; font-size: 14px;
  display: inline-flex; align-items: center; justify-content: center; }
.maison-co__step:not(.is-active):not(.is-done) .maison-co__num { background: var(--m-fill); color: var(--m-muted); }
.maison-co__step.is-done .maison-co__num { background: var(--m-ink); }
.maison-co__done { font-size: 14px; color: var(--m-ink); text-decoration: underline; cursor: pointer; }
.maison-co__stephead { cursor: default; }
.maison-co__step.is-done .maison-co__stephead { cursor: pointer; }
.maison-co__stepbody { display: none; margin-top: 18px; }
.maison-co__step.is-active .maison-co__stepbody { display: block; }
.maison-co__hint, .maison-co__loggedin { font-size: 15px; color: var(--m-body); margin: 0 0 16px; }
.maison-co__continue { margin-top: 8px; }
.maison-co__login { margin: 0 12px 12px 0; }

/* WooCommerce billing fields inside step 2 */
.maison-co #customer_details .form-row { margin: 0 0 14px; }
.maison-co #customer_details label { font-size: 13px; color: var(--m-muted); display: block; margin-bottom: 4px; }
.maison-co #customer_details .input-text,
.maison-co #customer_details select,
.maison-co .select2-selection { border: 1px solid var(--m-strong) !important; border-radius: var(--m-r-sm) !important;
  padding: 11px 12px !important; font-size: 15px !important; font-family: var(--m-sans) !important; width: 100%; min-height: 44px; }
.maison-co #customer_details .input-text:focus { outline: none; border-color: var(--m-ink) !important; box-shadow: 0 0 0 1px var(--m-ink); }
.maison-co__invalid { border-color: var(--m-rausch) !important; box-shadow: 0 0 0 1px var(--m-rausch) !important; }
.maison-co__invalid-row > label { color: var(--m-rausch); }

/* Step 3: hide the redundant WC line-item table (the summary card covers it); keep payment + place order */
.maison-co #order_review .woocommerce-checkout-review-order-table { display: none; }
.maison-co #payment { background: transparent; border-radius: 12px; }
.maison-co #payment ul.payment_methods { border: 1px solid var(--m-hairline); border-radius: 12px; padding: 8px 14px; list-style: none; margin: 0 0 16px; }
.maison-co #payment .place-order { padding: 0; }
.maison-co #place_order { width: 100%; font-size: 16px; font-weight: 600; padding: 15px; border-radius: 10px;
  background: var(--m-rausch); color: #fff; border: 0; cursor: pointer; }
.maison-co #place_order:hover { background: var(--m-rausch-active); }

/* Reservation summary card */
.maison-cosum { border: 1px solid var(--m-hairline); border-radius: 16px; padding: 22px 24px; background: #fff;
  box-shadow: rgba(0,0,0,.02) 0 0 0 1px, rgba(0,0,0,.08) 0 6px 16px 0; }
.maison-cosum__title { font-size: 16px; font-weight: 600; color: var(--m-ink); }
.maison-cosum__sub { font-size: 14px; color: var(--m-muted); margin-top: 2px; }
.maison-cosum__meta { border-top: 1px solid var(--m-hairline-soft); border-bottom: 1px solid var(--m-hairline-soft);
  margin: 16px 0; padding: 14px 0; display: flex; flex-direction: column; gap: 10px; }
.maison-cosum__meta > div { display: flex; justify-content: space-between; gap: 12px; font-size: 14px; }
.maison-cosum__label { color: var(--m-muted); }
.maison-cosum__pricehead { font-size: 15px; font-weight: 600; margin-bottom: 10px; }
.maison-cosum__row { display: flex; justify-content: space-between; font-size: 14px; color: var(--m-body); margin-bottom: 8px; }
.maison-cosum__row--save { color: #008a05; }
/* Add-on sub-items sit slightly indented and muted, reading as extras beneath the room line. */
.maison-cosum__row--addon { color: var(--m-muted); font-size: 13px; padding-left: 12px; margin-bottom: 6px; }
.maison-cosum__total { display: flex; justify-content: space-between; font-size: 16px; font-weight: 600; color: var(--m-ink);
  border-top: 1px solid var(--m-hairline); margin-top: 8px; padding-top: 16px; }
.maison-co__reassure { margin-top: 16px; }
.maison-co__rare { display: block; background: #fff0f3; color: var(--m-ink); font-size: 14px; font-weight: 500;
  border-radius: 12px; padding: 12px 16px; }

@media (max-width: 900px) {
  .maison-co__form { grid-template-columns: 1fr; gap: 28px; }
  .maison-co__aside { position: static; order: -1; }
}

/* Declutter the classic checkout chrome on our stepped page (coupons are disabled on bookings). */
.maison-checkout-page .woocommerce-form-coupon-toggle,
.maison-checkout-page .woocommerce-info.woocommerce-no-js { display: none; }
.maison-checkout-page .woocommerce-checkout .blockUI.blockOverlay { border-radius: 16px; }

/* ---- Order confirmation ("thank you") ---- */
.maison-oc { max-width: 600px; margin: 0 auto; padding: 24px; text-align: center; font-family: var(--m-sans); color: var(--m-ink); }
.maison-oc__badge { display: inline-flex; align-items: center; justify-content: center; width: 64px; height: 64px;
  border-radius: 50%; margin: 12px auto 22px; }
.maison-oc__badge svg { width: 32px; height: 32px; }
.maison-oc__badge.is-confirmed { background: #008a05; }
.maison-oc__badge.is-pending { background: var(--m-ink); }
.maison-oc__title { font-size: 30px; font-weight: 600; letter-spacing: -.02em; margin: 0 0 10px; }
.maison-oc__sub { font-size: 16px; color: var(--m-body); line-height: 1.55; margin: 0 auto 28px; max-width: 470px; }
.maison-oc__card { border: 1px solid var(--m-hairline); border-radius: 16px; padding: 24px; text-align: left;
  box-shadow: var(--m-shadow); }
.maison-oc__hotel { font-size: 18px; font-weight: 600; margin-bottom: 16px; }
.maison-oc__hcn { display: flex; flex-direction: column; gap: 4px; background: var(--m-soft); border-radius: 12px;
  padding: 14px 16px; margin-bottom: 8px; }
.maison-oc__hcnlabel { font-size: 12px; text-transform: uppercase; letter-spacing: .04em; color: var(--m-muted); }
.maison-oc__hcnval { font-size: 20px; font-weight: 600; letter-spacing: .02em; color: var(--m-ink); }
.maison-oc__row { display: flex; justify-content: space-between; gap: 12px; padding: 12px 0;
  border-top: 1px solid var(--m-hairline-soft); font-size: 15px; }
.maison-oc__label { color: var(--m-muted); }
.maison-oc__value { color: var(--m-ink); font-weight: 500; text-align: right; }
.maison-oc__policy { font-size: 14px; color: var(--m-muted); margin: 20px auto 24px; max-width: 460px; }
.maison-oc__actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.maison-oc__actions .maison-btn { text-decoration: none; display: inline-flex; align-items: center; justify-content: center; }
@media (max-width: 480px) { .maison-oc__actions { flex-direction: column; } .maison-oc__actions .maison-btn { width: 100%; } }

/* ---- My Account — fully custom page (no WooCommerce sidebar) ---- */
/* The page's own "My account" post title is redundant beside our bespoke header/top-bar. */
.maison-account-page .wp-block-post-title,
.maison-account-page .entry-title { display: none; }
/* Single centred column; our template supplies all chrome. */
.maison-account-page .woocommerce-account .woocommerce { max-width: 940px; margin: 0 auto; font-family: var(--m-sans); }
.maison-account { font-family: var(--m-sans); }
/* WooCommerce floats .woocommerce-MyAccount-content right at 68.5% for its two-column layout;
   we've dropped the sidebar, so reset it to a full-width block. */
.maison-account-page .woocommerce-MyAccount-content { float: none; width: 100%; margin: 0; min-width: 0; }

/* Sub-page top bar: "‹ Account" back link + current page title. */
.maison-account__bar { margin-bottom: 22px; }
.maison-account__back { display: inline-flex; align-items: center; gap: 5px; text-decoration: none;
  font-size: 14px; font-weight: 600; color: var(--m-muted); margin-bottom: 12px;
  transition: color .18s var(--m-ease); }
.maison-account__back:hover { color: var(--m-ink); }
.maison-account__back svg { width: 17px; height: 17px; }
.maison-account__title { font-size: 30px; font-weight: 600; letter-spacing: -.025em; color: var(--m-ink); margin: 0; line-height: 1.1; }

/* Sub-page tabs — our own horizontal nav replacing the WooCommerce sidebar. */
.maison-account__tabs { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 30px;
  border-bottom: 1px solid var(--m-hairline-soft); padding-bottom: 0; }
.maison-account__tab { position: relative; text-decoration: none; font-size: 15px; font-weight: 500;
  color: var(--m-muted); padding: 10px 4px; margin-right: 18px; border-bottom: 2px solid transparent; margin-bottom: -1px;
  transition: color .18s var(--m-ease), border-color .18s var(--m-ease); }
.maison-account__tab:hover { color: var(--m-ink); }
.maison-account__tab.is-active { color: var(--m-ink); font-weight: 600; border-bottom-color: var(--m-ink); }

/* ---- Dashboard (card grid) ---- */
.maison-acc__head { margin-bottom: 30px; }
.maison-acc__eyebrow { font-size: 12px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase;
  color: var(--m-rausch); margin: 0 0 10px; }
.maison-acc__hello { font-size: 36px; font-weight: 600; letter-spacing: -.03em; color: var(--m-ink); margin: 0 0 14px; line-height: 1.08; }
.maison-acc__meta { display: flex; align-items: center; flex-wrap: wrap; gap: 12px; }
.maison-acc__badge { display: inline-flex; align-items: center; gap: 7px; padding: 7px 14px 7px 11px; border-radius: var(--m-r-full);
  background: var(--m-ink); color: #fff; font-size: 14px; font-weight: 600; letter-spacing: .01em; }
.maison-acc__badge svg { width: 15px; height: 15px; color: var(--m-rausch); }
.maison-acc__metasub { font-size: 14px; color: var(--m-muted); }

/* Card grid */
.maison-acc__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(232px, 1fr)); gap: 16px; margin-bottom: 36px; }
.maison-acc__card { display: flex; flex-direction: column; text-decoration: none; color: inherit;
  border: 1px solid var(--m-hairline-soft); border-radius: 18px; padding: 24px; background: #fff; min-height: 168px;
  transition: border-color .2s var(--m-ease), box-shadow .2s var(--m-ease), transform .2s var(--m-ease); }
.maison-acc__card:hover { border-color: transparent; transform: translateY(-2px);
  box-shadow: rgba(0,0,0,.03) 0 0 0 1px, rgba(0,0,0,.12) 0 14px 30px -10px; }
.maison-acc__cardicon { flex: none; width: 48px; height: 48px; border-radius: 14px; display: inline-flex; align-items: center;
  justify-content: center; background: var(--m-soft); color: var(--m-ink); margin-bottom: auto; }
.maison-acc__cardicon svg { width: 23px; height: 23px; }
.maison-acc__cardtitle { font-size: 17px; font-weight: 600; color: var(--m-ink); margin-top: 18px; }
.maison-acc__cardsub { font-size: 14px; color: var(--m-muted); margin-top: 3px; line-height: 1.35; }

/* Image CTA */
.maison-acc__cta { position: relative; overflow: hidden; border-radius: 22px; min-height: 220px; display: flex; align-items: flex-end;
  background-size: cover; background-position: center; isolation: isolate; }
.maison-acc__cta::after { content: ""; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(180deg, rgba(18,20,28,.15) 0%, rgba(18,20,28,.72) 100%); }
.maison-acc__ctabody { padding: 28px 32px; color: #fff; }
.maison-acc__ctatitle { font-size: 22px; font-weight: 600; letter-spacing: -.01em; }
.maison-acc__ctasub { font-size: 15px; color: rgba(255,255,255,.9); margin: 4px 0 16px; }
.maison-acc__ctabtn { display: inline-flex; align-items: center; background: #fff; color: var(--m-ink); text-decoration: none;
  font-weight: 600; font-size: 15px; padding: 12px 22px; border-radius: var(--m-r-full); transition: transform .18s var(--m-ease); }
.maison-acc__ctabtn:hover { transform: translateY(-1px); }

/* Account tables (bookings list etc.) */
.maison-account-page .woocommerce-orders-table, .maison-account-page .shop_table {
  border: 1px solid var(--m-hairline-soft); border-radius: 16px; border-collapse: separate; overflow: hidden; }
.maison-account-page .woocommerce-button.button, .maison-account-page .button {
  background: var(--m-ink) !important; color: #fff !important; border-radius: 10px !important; box-shadow: none !important; }

@media (max-width: 600px) {
  .maison-acc__hello { font-size: 28px; }
  .maison-account__title { font-size: 24px; }
  .maison-acc__grid { grid-template-columns: 1fr 1fr; gap: 12px; }
  .maison-acc__card { min-height: 148px; padding: 18px; }
}

/* ---- Homepage sections ([maison_home]) ---- */
.maison-home { padding-bottom: 8px; }
.maison-home__sec { margin: 64px 0; }
.maison-home__head { text-align: center; max-width: 640px; margin: 0 auto 34px; }
.maison-home__h2 { font-size: 30px; font-weight: 600; letter-spacing: -.02em; color: var(--m-ink); margin: 0 0 8px; }
.maison-home__lead { font-size: 16px; color: var(--m-muted); margin: 0; line-height: 1.55; }

/* Value props */
.maison-home__feats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.maison-feat { text-align: left; padding: 26px 24px; border: 1px solid var(--m-hairline-soft); border-radius: 18px; background: #fff;
  transition: transform .2s var(--m-ease), box-shadow .2s var(--m-ease); }
.maison-feat:hover { transform: translateY(-3px); box-shadow: rgba(0,0,0,.02) 0 0 0 1px, rgba(0,0,0,.1) 0 12px 28px -10px; }
.maison-feat__icon { display: inline-flex; align-items: center; justify-content: center; width: 46px; height: 46px;
  border-radius: 14px; background: var(--m-soft); color: var(--m-rausch); margin-bottom: 16px; }
.maison-feat__icon svg { width: 22px; height: 22px; }
.maison-feat__title { font-size: 17px; font-weight: 600; color: var(--m-ink); margin: 0 0 6px; }
.maison-feat__text { font-size: 14.5px; color: var(--m-muted); line-height: 1.55; margin: 0; }

/* Destinations */
.maison-home__dests { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.maison-dest { display: block; text-decoration: none; color: inherit; }
.maison-dest__photo { display: block; position: relative; aspect-ratio: 3/2; border-radius: 16px; overflow: hidden; background: var(--m-fill); }
.maison-dest__photo img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s var(--m-ease); }
.maison-dest:hover .maison-dest__photo img { transform: scale(1.05); }
.maison-dest__name { display: block; font-size: 17px; font-weight: 600; color: var(--m-ink); margin: 12px 0 0; }
.maison-dest__sub { display: block; font-size: 14px; color: var(--m-muted); margin-top: 2px; }

/* How it works */
.maison-home__steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.maison-step { text-align: center; padding: 8px; }
.maison-step__num { display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px; border-radius: 50%;
  background: var(--m-ink); color: #fff; font-size: 14px; font-weight: 600; margin-bottom: 14px; }
.maison-step__icon { display: block; width: 30px; height: 30px; margin: 0 auto 10px; color: var(--m-rausch); }
.maison-step__icon svg { width: 30px; height: 30px; }
.maison-step__title { font-size: 18px; font-weight: 600; margin: 0 0 6px; color: var(--m-ink); }
.maison-step__text { font-size: 14.5px; color: var(--m-muted); line-height: 1.55; margin: 0; max-width: 300px; margin-inline: auto; }

/* Image CTA */
.maison-home__cta { position: relative; overflow: hidden; border-radius: 22px; min-height: 320px; display: flex; align-items: center;
  justify-content: center; text-align: center; background-size: cover; background-position: center; isolation: isolate; margin: 64px 0; }
.maison-home__cta::after { content: ""; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(180deg, rgba(18,20,28,.35) 0%, rgba(18,20,28,.62) 100%); }
.maison-home__ctabody { color: #fff; padding: 40px 24px; max-width: 620px; }
.maison-home__ctatitle { font-size: 34px; font-weight: 700; letter-spacing: -.02em; margin: 0 0 10px; text-shadow: 0 1px 20px rgba(0,0,0,.25); }
.maison-home__ctasub { font-size: 17px; color: rgba(255,255,255,.92); margin: 0 0 24px; }
.maison-home__ctabtn { display: inline-flex; align-items: center; background: #fff; color: var(--m-ink); text-decoration: none;
  font-weight: 600; font-size: 16px; padding: 14px 28px; border-radius: var(--m-r-full); transition: transform .18s var(--m-ease); }
.maison-home__ctabtn:hover { transform: translateY(-2px); }

/* Membership teaser */
.maison-home__member { display: flex; align-items: center; justify-content: space-between; gap: 28px; flex-wrap: wrap;
  border: 1px solid var(--m-hairline); border-radius: 20px; padding: 32px 36px; margin: 0 0 64px;
  background: linear-gradient(135deg, #1f2430 0%, #2c3444 100%); color: #fff; }
.maison-home__eyebrow { font-size: 12px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--m-rausch); margin: 0 0 8px; }
.maison-home__memtitle { font-size: 26px; font-weight: 600; letter-spacing: -.01em; margin: 0 0 6px; color: #fff; }
.maison-home__member .maison-home__lead { color: rgba(255,255,255,.75); }
.maison-home__memaction .maison-btn { text-decoration: none; }

@media (max-width: 900px) {
  .maison-home__feats { grid-template-columns: 1fr 1fr; }
  .maison-home__dests { grid-template-columns: 1fr 1fr; }
  .maison-home__steps { grid-template-columns: 1fr; gap: 24px; }
}
@media (max-width: 560px) {
  .maison-home__feats, .maison-home__dests { grid-template-columns: 1fr; }
  .maison-home__ctatitle { font-size: 26px; }
  .maison-home__member { padding: 26px 22px; }
}
