/* CULTIVONS MALIN — HANDOFF DESIGN (genere) : colors_and_type + cm-components + kit (sans resets globaux).
   Charge APRES app.css pour primer. Voir handoff design system. */

/* =========================================================================
   CULTIVONS MALIN — COLORS & TYPE
   Single source of truth for the design system, ported 1:1 from the
   codebase SCSS tokens (assets/scss/_tokens.scss in the Symfony repo).
   Load this file first, then layer component styles on top.

   FONT NOTE: the modern system uses **Inter** ($cm-font-sans in tokens).
   Inter is NOT bundled in the repo (only legacy Open Sans + Roboto TTFs are),
   so we load Inter from Google Fonts here. See README "Visual Foundations".
   ========================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,400;0,14..32,500;0,14..32,600;0,14..32,700;0,14..32,800&display=swap');

:root {
  /* ---------- BRAND GREENS ---------- */
  --cm-green-primary:        #5A9A4C;  /* core brand green — CTAs, links, active */
  --cm-green-primary-hover:  #4A8A3C;
  --cm-green-primary-active: #3A7A2E;
  --cm-green-dark:           #1B4B2A;  /* deep forest — hero overlay, headings on tint */
  --cm-green-dark-hover:     #143820;
  --cm-green-light:          #E8F2DE;  /* pale wash — chips, soft backgrounds */
  --cm-green-light-strong:   #D4E8C5;
  --cm-yellow-accent:        #F4C72E;  /* sun yellow — accent CTA, slogan, stars */
  --cm-yellow-dark:          #C99A0F;

  /* ---------- NEUTRALS (Airbnb-style grey ramp) ---------- */
  --cm-neutral-0:    #FFFFFF;
  --cm-neutral-50:   #F7F7F7;
  --cm-neutral-100:  #EBEBEB;
  --cm-neutral-200:  #DDDDDD;
  --cm-neutral-300:  #C1C1C1;
  --cm-neutral-400:  #B0B0B0;
  --cm-neutral-500:  #717171;
  --cm-neutral-600:  #6A6A6A;
  --cm-neutral-700:  #484848;
  --cm-neutral-800:  #3F3F3F;
  --cm-neutral-900:  #222222;

  /* ---------- SEMANTIC ---------- */
  --cm-success:    #008A05;
  --cm-success-bg: #DFF3E0;
  --cm-warning:    #F4C72E;
  --cm-warning-bg: #FEF8E0;
  --cm-error:      #C13515;
  --cm-error-bg:   #FDECE9;
  --cm-info:       #428BFF;

  /* ---------- OVERLAYS ---------- */
  --cm-overlay-dark: rgba(0, 0, 0, 0.45);
  --cm-overlay-soft: rgba(0, 0, 0, 0.04);

  /* ---------- SEMANTIC ROLE ALIASES ---------- */
  --cm-bg:        var(--cm-neutral-0);
  --cm-bg-soft:   var(--cm-neutral-50);
  --cm-surface:   var(--cm-neutral-0);
  --cm-border:    var(--cm-neutral-200);
  --cm-border-subtle: var(--cm-neutral-100);
  --cm-fg:        var(--cm-neutral-900);   /* primary text */
  --cm-fg-muted:  var(--cm-neutral-500);   /* secondary text */
  --cm-fg-subtle: var(--cm-neutral-400);   /* placeholders */
  --cm-fg-on-dark: var(--cm-neutral-0);
  --cm-link:      var(--cm-green-primary);

  /* ---------- TYPOGRAPHY ---------- */
  --cm-font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --cm-font-display: var(--cm-font-sans);  /* display = same family, heavier weight */

  /* Static type scale (px) */
  --cm-text-display-xl: 44px;
  --cm-text-display-lg: 32px;
  --cm-text-display-md: 26px;
  --cm-text-h1:   26px;
  --cm-text-h2:   22px;
  --cm-text-h3:   18px;
  --cm-text-h4:   16px;
  --cm-text-lg:   18px;
  --cm-text-base: 16px;
  --cm-text-sm:   14px;
  --cm-text-xs:   13px;
  --cm-text-2xs:  12px;

  /* Fluid type (clamp) — mobile-first, holds at 390px */
  --cm-fluid-display: clamp(28px, 7vw, 44px);
  --cm-fluid-h1:      clamp(24px, 5.5vw, 34px);
  --cm-fluid-h2:      clamp(20px, 4.5vw, 26px);
  --cm-fluid-h3:      clamp(17px, 3.2vw, 20px);
  --cm-fluid-lead:    clamp(16px, 2.4vw, 18px);

  /* Weights */
  --cm-fw-regular:  400;
  --cm-fw-medium:   500;
  --cm-fw-semibold: 600;
  --cm-fw-bold:     700;
  --cm-fw-extra:    800;

  /* Line heights */
  --cm-lh-tight:   1.1;
  --cm-lh-snug:    1.2;
  --cm-lh-normal:  1.4;
  --cm-lh-relaxed: 1.5;
  --cm-lh-loose:   1.6;

  /* ---------- SPACING (4px grid) ---------- */
  --cm-space-0:  0;
  --cm-space-1:  2px;
  --cm-space-2:  4px;
  --cm-space-3:  8px;
  --cm-space-4:  12px;
  --cm-space-5:  16px;
  --cm-space-6:  20px;
  --cm-space-7:  24px;
  --cm-space-8:  32px;
  --cm-space-9:  40px;
  --cm-space-10: 48px;
  --cm-space-11: 64px;
  --cm-space-12: 96px;
  --cm-gutter:   16px;  /* constant mobile side gutter */

  /* ---------- RADIUS ---------- */
  --cm-radius-0:    0;
  --cm-radius-xs:   4px;
  --cm-radius-sm:   8px;
  --cm-radius-md:   12px;   /* buttons, fields */
  --cm-radius-lg:   14px;   /* cards */
  --cm-radius-xl:   20px;
  --cm-radius-2xl:  32px;   /* host CTA banner */
  --cm-radius-full: 9999px; /* pills, chips, search bar */

  /* ---------- SHADOWS (soft, layered) ---------- */
  --cm-shadow-sm:
    0 0 0 1px rgba(0, 0, 0, 0.02),
    0 1px 3px rgba(0, 0, 0, 0.04),
    0 1px 2px rgba(0, 0, 0, 0.05);
  --cm-shadow-md:
    0 2px 6px rgba(0, 0, 0, 0.05),
    0 4px 12px rgba(0, 0, 0, 0.08);
  --cm-shadow-lg:
    0 4px 12px rgba(0, 0, 0, 0.08),
    0 8px 28px rgba(0, 0, 0, 0.12);
  --cm-shadow-searchbar:
    0 1px 2px rgba(0, 0, 0, 0.08),
    0 6px 20px rgba(0, 0, 0, 0.08);
  --cm-shadow-soft:  0 8px 24px rgba(0, 0, 0, 0.08);
  --cm-shadow-up:    0 -8px 24px rgba(0, 0, 0, 0.08);
  --cm-focus-ring:   0 0 0 4px rgba(90, 154, 76, 0.25);

  /* ---------- MOTION ---------- */
  --cm-duration-fast: 160ms;
  --cm-duration-base: 260ms;
  --cm-duration-slow: 400ms;
  --cm-ease-standard: cubic-bezier(0.25, 0.1, 0.25, 1);
  --cm-ease-enter:    cubic-bezier(0.2, 0.6, 0.25, 1);
  --cm-ease-exit:     cubic-bezier(0.4, 0, 1, 1);
  --cm-ease-warm:     cubic-bezier(0.25, 0.8, 0.25, 1);
}

/* =========================================================================
   SEMANTIC TYPE PRESETS
   Apply these classes (or copy the declarations) for consistent type.
   ========================================================================= */

.cm-display {
  font-family: var(--cm-font-display);
  font-weight: var(--cm-fw-extra);
  font-size: var(--cm-fluid-display);
  line-height: var(--cm-lh-tight);
  letter-spacing: -0.6px;
  color: var(--cm-fg);
}

.cm-h1 {
  font-family: var(--cm-font-display);
  font-weight: var(--cm-fw-bold);
  font-size: var(--cm-fluid-h1);
  line-height: var(--cm-lh-tight);
  letter-spacing: -0.4px;
  color: var(--cm-fg);
}

.cm-h2 {
  font-family: var(--cm-font-display);
  font-weight: var(--cm-fw-bold);
  font-size: var(--cm-fluid-h2);
  line-height: var(--cm-lh-snug);
  color: var(--cm-fg);
}

.cm-h3 {
  font-family: var(--cm-font-sans);
  font-weight: var(--cm-fw-bold);
  font-size: var(--cm-fluid-h3);
  line-height: var(--cm-lh-snug);
  color: var(--cm-fg);
}

.cm-lead {
  font-family: var(--cm-font-sans);
  font-weight: var(--cm-fw-regular);
  font-size: var(--cm-fluid-lead);
  line-height: var(--cm-lh-relaxed);
  color: var(--cm-fg-muted);
}

.cm-body {
  font-family: var(--cm-font-sans);
  font-weight: var(--cm-fw-regular);
  font-size: var(--cm-text-base);
  line-height: var(--cm-lh-relaxed);
  color: var(--cm-fg);
}

.cm-small {
  font-family: var(--cm-font-sans);
  font-size: var(--cm-text-sm);
  line-height: var(--cm-lh-normal);
  color: var(--cm-fg-muted);
}

.cm-eyebrow {
  font-family: var(--cm-font-sans);
  font-weight: var(--cm-fw-semibold);
  font-size: var(--cm-text-2xs);
  text-transform: uppercase;
  letter-spacing: 1.2px;
  color: var(--cm-green-dark);
}


/* =========================================================================
   CULTIVONS MALIN — COMPONENTS
   Vanilla-CSS port of the codebase's cm-* component classes
   (assets/scss/_components/* + app.scss). Depends on colors_and_type.css.
   Load order:  colors_and_type.css  →  cm-components.css  →  your styles.
   ========================================================================= */

/* ---------------- BUTTONS ---------------- */
.cm-btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--cm-space-3);
  min-height: 48px; padding: 12px 22px;
  border: 1px solid transparent; border-radius: var(--cm-radius-md);
  font-family: var(--cm-font-sans); font-size: var(--cm-text-base);
  font-weight: var(--cm-fw-semibold); line-height: 1.1;
  text-align: center; text-decoration: none; white-space: nowrap;
  cursor: pointer; user-select: none; -webkit-tap-highlight-color: transparent;
  appearance: none; background: none;
  transition: background-color var(--cm-duration-fast) var(--cm-ease-standard),
              border-color var(--cm-duration-fast) var(--cm-ease-standard),
              color var(--cm-duration-fast) var(--cm-ease-standard),
              box-shadow var(--cm-duration-fast) var(--cm-ease-standard),
              transform var(--cm-duration-fast) var(--cm-ease-standard);
}
.cm-btn:active { transform: scale(0.98); }
.cm-btn:focus-visible { outline: none; box-shadow: var(--cm-focus-ring); }
.cm-btn:disabled, .cm-btn.is-disabled { opacity: 0.55; cursor: not-allowed; pointer-events: none; }
.cm-btn i, .cm-btn svg { flex-shrink: 0; font-size: 1.05em; }

.cm-btn--primary {
  background-color: var(--cm-green-primary); border-color: var(--cm-green-primary);
  color: #fff; box-shadow: 0 4px 12px rgba(90,154,76,0.24);
}
.cm-btn--primary:hover {
  background-color: var(--cm-green-primary-hover); border-color: var(--cm-green-primary-hover);
  color: #fff; box-shadow: 0 6px 16px rgba(90,154,76,0.30); transform: translateY(-1px);
}
.cm-btn--primary:active {
  background-color: var(--cm-green-primary-active); border-color: var(--cm-green-primary-active);
  box-shadow: 0 2px 8px rgba(90,154,76,0.22); transform: scale(0.98);
}

.cm-btn--ghost {
  background-color: #fff; border-color: var(--cm-neutral-200);
  color: var(--cm-neutral-900); box-shadow: var(--cm-shadow-sm);
}
.cm-btn--ghost:hover { border-color: var(--cm-neutral-900); transform: translateY(-1px); }
.cm-btn--ghost:active { background-color: var(--cm-neutral-50); transform: scale(0.98); }

.cm-btn--ghost-green {
  background-color: #fff; border-color: var(--cm-green-primary); color: var(--cm-green-primary);
}
.cm-btn--ghost-green:hover { background-color: var(--cm-green-light); color: var(--cm-green-dark); }

.cm-btn--accent {
  background-color: var(--cm-yellow-accent); border-color: var(--cm-yellow-accent);
  color: var(--cm-green-dark); font-weight: var(--cm-fw-bold);
  box-shadow: 0 4px 12px rgba(244,199,46,0.30);
}
.cm-btn--accent:hover {
  background-color: var(--cm-yellow-dark); border-color: var(--cm-yellow-dark);
  color: #fff; box-shadow: 0 6px 16px rgba(201,154,15,0.32); transform: translateY(-1px);
}

.cm-btn--dark {
  background-color: var(--cm-neutral-900); border-color: var(--cm-neutral-900); color: #fff;
}
.cm-btn--dark:hover { background-color: var(--cm-neutral-800); transform: translateY(-1px); }

.cm-btn--block { display: flex; width: 100%; }
.cm-btn--lg { min-height: 56px; padding: 16px 28px; font-size: var(--cm-text-lg); border-radius: var(--cm-radius-lg); }
.cm-btn--sm { min-height: 40px; padding: 8px 16px; font-size: var(--cm-text-sm); gap: var(--cm-space-2); }
.cm-btn--icon { min-height: 44px; width: 44px; padding: 0; border-radius: var(--cm-radius-full); gap: 0; }

/* ---------------- CHIPS ---------------- */
.cm-chip {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--cm-space-2);
  min-height: 40px; padding: 8px 16px;
  background-color: var(--cm-neutral-50); border: 1px solid var(--cm-neutral-100);
  border-radius: var(--cm-radius-full); color: var(--cm-neutral-700);
  font-family: var(--cm-font-sans); font-size: var(--cm-text-sm); font-weight: var(--cm-fw-medium);
  line-height: 1; text-decoration: none; white-space: nowrap; cursor: pointer;
  user-select: none; appearance: none;
  transition: background-color var(--cm-duration-fast) var(--cm-ease-standard),
              border-color var(--cm-duration-fast) var(--cm-ease-standard),
              color var(--cm-duration-fast) var(--cm-ease-standard),
              transform var(--cm-duration-fast) var(--cm-ease-standard);
}
.cm-chip i, .cm-chip svg { flex-shrink: 0; font-size: 0.95em; opacity: 0.8; }
.cm-chip:hover { background-color: var(--cm-neutral-100); border-color: var(--cm-neutral-200); color: var(--cm-neutral-900); }
.cm-chip:active { transform: scale(0.96); }
.cm-chip:focus-visible { outline: none; box-shadow: var(--cm-focus-ring); }
.cm-chip.is-active, .cm-chip[aria-pressed="true"] {
  background-color: var(--cm-green-light); border-color: var(--cm-green-primary);
  color: var(--cm-green-dark); font-weight: var(--cm-fw-semibold);
}
.cm-chip.is-active i { opacity: 1; color: var(--cm-green-primary); }
.cm-chip--solid { background-color: var(--cm-green-primary); border-color: var(--cm-green-primary); color: #fff; }
.cm-chip--solid i { color: #fff; opacity: 1; }
/* Region chip variant (pale-green pill with green-dark text) */
.cm-region-chip { background: var(--cm-green-light); border-color: transparent; color: var(--cm-green-dark); font-weight: var(--cm-fw-semibold); }
.cm-region-chip i { color: var(--cm-green-primary); }
.cm-region-chip:hover { background: var(--cm-green-light-strong); border-color: transparent; color: var(--cm-green-dark); }

.cm-chip-row { display: flex; align-items: center; gap: var(--cm-space-3); overflow-x: auto; scrollbar-width: none; padding-block: var(--cm-space-2); }
.cm-chip-row::-webkit-scrollbar { display: none; }
.cm-chip-row > .cm-chip { flex-shrink: 0; }

/* ---------------- CARDS (listing) ---------------- */
.cm-card {
  display: flex; flex-direction: column; background-color: #fff;
  border: 1px solid var(--cm-neutral-100); border-radius: 16px; overflow: hidden;
  text-decoration: none; color: inherit; box-shadow: 0 8px 24px rgba(0,0,0,0.06);
  transition: transform var(--cm-duration-base) var(--cm-ease-standard),
              box-shadow var(--cm-duration-base) var(--cm-ease-standard);
}
.cm-card:hover { transform: translateY(-3px); box-shadow: 0 12px 32px rgba(0,0,0,0.10); color: inherit; }
.cm-card:hover .cm-card__img { transform: scale(1.04); }
.cm-card:active { transform: scale(0.99); }
.cm-card__media { position: relative; display: block; aspect-ratio: 4 / 3; background-color: var(--cm-neutral-100); overflow: hidden; }
.cm-card__img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform var(--cm-duration-slow) var(--cm-ease-standard); }
.cm-card__badge {
  position: absolute; top: 12px; left: 12px; z-index: 2; display: inline-flex; align-items: center; gap: 4px;
  padding: 6px 12px; border-radius: var(--cm-radius-full);
  background-color: rgba(255,255,255,0.95); backdrop-filter: blur(4px); color: var(--cm-neutral-900);
  font-size: var(--cm-text-2xs); font-weight: var(--cm-fw-semibold); box-shadow: 0 2px 6px rgba(0,0,0,0.10);
}
.cm-card__badge i { color: var(--cm-green-primary); }
.cm-card__body { display: flex; flex-direction: column; gap: 4px; padding: var(--cm-space-4) var(--cm-space-5) var(--cm-space-5); }
.cm-card__title {
  margin: 0; font-size: var(--cm-text-base); font-weight: var(--cm-fw-semibold);
  line-height: var(--cm-lh-snug); color: var(--cm-neutral-900);
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.cm-card__location { font-size: var(--cm-text-sm); color: var(--cm-neutral-500); line-height: var(--cm-lh-normal); }
.cm-card__price { margin-top: 4px; font-size: var(--cm-text-base); color: var(--cm-neutral-900); }
.cm-card__price strong { font-weight: var(--cm-fw-bold); }
.cm-card__price span { font-size: var(--cm-text-sm); font-weight: var(--cm-fw-regular); color: var(--cm-neutral-500); }

/* ---------------- BADGES ---------------- */
.cm-badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 10px; border-radius: var(--cm-radius-full);
  font-size: var(--cm-text-2xs); font-weight: var(--cm-fw-semibold); line-height: 1; white-space: nowrap;
}
.cm-badge--available { background: var(--cm-success-bg); color: var(--cm-success); }
.cm-badge--verified { background: var(--cm-green-light); color: var(--cm-green-dark); }
.cm-badge--cat { background: var(--cm-neutral-100); color: var(--cm-neutral-700); }
.cm-rating { display: inline-flex; align-items: center; gap: 5px; font-weight: var(--cm-fw-semibold); color: var(--cm-neutral-900); }
.cm-rating i { color: var(--cm-yellow-accent); }
.cm-rating span { color: var(--cm-neutral-500); font-weight: var(--cm-fw-regular); }

/* ---------------- FORM FIELD ---------------- */
.cm-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: var(--cm-space-5); }
.cm-field__label { font-size: var(--cm-text-sm); font-weight: var(--cm-fw-semibold); color: var(--cm-neutral-800); line-height: var(--cm-lh-snug); }
.cm-field__input, .cm-field__select, .cm-field__textarea {
  width: 100%; min-height: 52px; padding: 14px 16px;
  border: 1px solid var(--cm-neutral-200); border-radius: var(--cm-radius-md);
  background-color: #fff; color: var(--cm-neutral-900);
  font-family: var(--cm-font-sans); font-size: 16px; line-height: var(--cm-lh-normal);
  appearance: none; -webkit-appearance: none;
  transition: border-color var(--cm-duration-fast) var(--cm-ease-standard), box-shadow var(--cm-duration-fast) var(--cm-ease-standard);
}
.cm-field__textarea { min-height: 96px; resize: vertical; }
.cm-field__input::placeholder, .cm-field__textarea::placeholder { color: var(--cm-neutral-400); }
.cm-field__input:hover, .cm-field__select:hover, .cm-field__textarea:hover { border-color: var(--cm-neutral-300); }
.cm-field__input:focus, .cm-field__select:focus, .cm-field__textarea:focus {
  outline: none; border-color: var(--cm-green-primary); box-shadow: var(--cm-focus-ring);
}
.cm-field__hint { font-size: var(--cm-text-xs); color: var(--cm-neutral-500); }
.cm-field__select {
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23717171'%3e%3cpath d='M4.427 6.427a.6.6 0 0 1 .848 0L8 9.152l2.725-2.725a.6.6 0 1 1 .848.848l-3.15 3.15a.6.6 0 0 1-.848 0l-3.15-3.15a.6.6 0 0 1 .002-.848z'/%3e%3c/svg%3e");
  background-repeat: no-repeat; background-position: right 14px center; background-size: 16px; padding-right: 40px;
}

/* ---------------- STEP CARD ---------------- */
.cm-step-card {
  background: #fff; border-radius: var(--cm-radius-xl); padding: 32px 24px; text-align: center; height: 100%;
  border: 1px solid var(--cm-neutral-100); box-shadow: var(--cm-shadow-sm);
  transition: transform var(--cm-duration-base) var(--cm-ease-standard), box-shadow var(--cm-duration-base) var(--cm-ease-standard);
}
.cm-step-card:hover { transform: translateY(-4px); box-shadow: var(--cm-shadow-md); }
.cm-step-card__icon {
  position: relative; width: 64px; height: 64px; border-radius: 50%;
  background-color: var(--cm-green-light); color: var(--cm-green-dark);
  display: inline-flex; align-items: center; justify-content: center; margin-bottom: 20px; font-size: 1.5rem;
}
.cm-step-card__num {
  position: absolute; top: -4px; right: -4px; width: 24px; height: 24px; border-radius: 50%;
  background: var(--cm-green-primary); color: #fff; font-size: 12px; font-weight: var(--cm-fw-bold);
  display: flex; align-items: center; justify-content: center; border: 2px solid #fff; box-shadow: 0 2px 6px rgba(0,0,0,0.12);
}
.cm-step-card__title { color: var(--cm-neutral-900); font-weight: var(--cm-fw-bold); font-size: var(--cm-text-h3); margin: 0 0 12px; line-height: var(--cm-lh-snug); }
.cm-step-card__text { color: var(--cm-neutral-500); font-size: var(--cm-text-sm); line-height: var(--cm-lh-relaxed); margin: 0; }

/* ---------------- HOST CTA BANNER ---------------- */
.cm-host-cta {
  background: linear-gradient(135deg, var(--cm-green-light) 0%, var(--cm-green-light-strong) 100%);
  border-radius: var(--cm-radius-2xl); padding: 56px 48px; overflow: hidden; position: relative;
}
.cm-host-cta__eyebrow { font-size: var(--cm-text-2xs); font-weight: var(--cm-fw-semibold); color: var(--cm-green-dark); text-transform: uppercase; letter-spacing: 1.2px; margin-bottom: 14px; display: inline-block; }
.cm-host-cta__title { font-family: var(--cm-font-display); font-size: clamp(1.5rem, 3vw, 2rem); font-weight: var(--cm-fw-bold); color: var(--cm-neutral-900); line-height: var(--cm-lh-tight); margin: 0 0 16px; letter-spacing: -0.5px; }
.cm-host-cta__lead { font-size: var(--cm-text-base); color: var(--cm-neutral-700); line-height: var(--cm-lh-relaxed); margin: 0 0 28px; max-width: 460px; }

/* ---------------- REVIEW CARD ---------------- */
.cm-review-card { background: #fff; border: 1px solid #eaeaea; border-radius: 14px; padding: 1.25rem 1.5rem; transition: box-shadow .18s ease; }
.cm-review-card:hover { box-shadow: 0 4px 18px rgba(0,0,0,0.06); }
.cm-review-card__head { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
.cm-review-card__avatar { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.cm-review-card__name { font-size: 0.95rem; font-weight: 700; color: #222; }
.cm-review-card__date { font-size: 0.8rem; color: var(--cm-neutral-500); }
.cm-review-card__rating { font-size: 0.9rem; letter-spacing: 1px; white-space: nowrap; margin-left: auto; }
.cm-review-card__rating .fa-star { color: #F4C72E; }
.cm-review-card__comment { color: #444; line-height: 1.55; font-size: 0.95rem; margin: 0; }

/* ---------------- SEARCH BAR ---------------- */
.cm-searchbar {
  max-width: 880px; margin: 0 auto; background: #fff; border: 1px solid var(--cm-neutral-200);
  border-radius: var(--cm-radius-full); box-shadow: var(--cm-shadow-searchbar); padding: 8px;
  display: flex; align-items: stretch; height: 68px; position: relative;
  transition: box-shadow var(--cm-duration-base) var(--cm-ease-standard);
}
.cm-searchbar:focus-within { box-shadow: 0 0 0 4px rgba(90,154,76,0.15), 0 6px 24px rgba(0,0,0,0.10); }
.cm-searchbar__field {
  flex: 1; display: grid; grid-template-rows: 14px 20px; align-content: center; row-gap: 4px;
  padding: 6px 24px; border-radius: var(--cm-radius-full); cursor: pointer; min-width: 0;
  transition: background-color var(--cm-duration-fast) var(--cm-ease-standard);
}
.cm-searchbar__field:hover { background-color: var(--cm-neutral-50); }
.cm-searchbar__label { font-size: var(--cm-text-2xs); font-weight: var(--cm-fw-semibold); color: var(--cm-neutral-900); line-height: 14px; margin: 0; }
.cm-searchbar__input, .cm-searchbar__select {
  width: 100%; display: block; border: none; background: transparent; margin: 0; padding: 0;
  font-family: var(--cm-font-sans); font-size: var(--cm-text-sm); line-height: 20px; height: 20px;
  color: var(--cm-neutral-700); outline: none; cursor: pointer; text-overflow: ellipsis; white-space: nowrap; overflow: hidden;
  appearance: none; -webkit-appearance: none;
}
.cm-searchbar__input::placeholder { color: var(--cm-neutral-500); }
.cm-searchbar__divider { width: 1px; background-color: var(--cm-neutral-200); margin: 14px 0; flex-shrink: 0; }
.cm-searchbar__submit {
  flex-shrink: 0; width: 52px; height: 52px; border-radius: 50%; background-color: var(--cm-green-primary);
  color: #fff; border: none; display: flex; align-items: center; justify-content: center; cursor: pointer;
  margin-left: 4px; align-self: center;
  transition: background-color var(--cm-duration-fast) var(--cm-ease-standard), transform var(--cm-duration-fast) var(--cm-ease-standard);
}
.cm-searchbar__submit:hover { background-color: var(--cm-green-primary-hover); transform: scale(1.05); }
.cm-searchbar__submit:active { transform: scale(0.98); }

/* ---------------- NAVBAR ---------------- */
.cm-navbar {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  min-height: 72px; padding: 0 32px; background: #fff; border-bottom: 1px solid var(--cm-neutral-100);
}
.cm-navbar__logo { height: 40px; width: auto; display: block; }
.cm-navbar__nav { display: flex; align-items: center; gap: 4px; }
.cm-nav-link {
  color: #222; padding: 0.5rem 0.75rem; border-radius: 999px; font-size: 0.95rem; font-weight: 500;
  text-decoration: none; transition: background-color 0.15s ease, color 0.15s ease;
}
.cm-nav-link:hover { background-color: #f7f7f7; color: var(--cm-green-dark); }
.cm-nav-link--accent { color: var(--cm-green-primary); font-weight: 600; }
.cm-nav-link--accent:hover { background-color: var(--cm-green-light); }
.cm-profile-btn {
  display: inline-flex; align-items: center; gap: 8px; padding: 0.4rem 0.6rem 0.4rem 0.9rem;
  border-radius: 999px; background: transparent; border: 1px solid #ddd; color: #222; cursor: pointer;
  box-shadow: 0 1px 2px rgba(0,0,0,0.04); transition: box-shadow .15s ease, border-color .15s ease;
}
.cm-profile-btn:hover { box-shadow: 0 2px 8px rgba(0,0,0,0.1); border-color: #ccc; }
.cm-profile-btn .fa-user-circle { color: #6c757d; font-size: 1.4em; }

/* profile dropdown menu */
.cm-menu { position: absolute; right: 0; top: calc(100% + 8px); width: 268px; background: #fff; border: 1px solid var(--cm-neutral-100); border-radius: 14px; box-shadow: var(--cm-shadow-lg); padding: 8px; z-index: 60; }
.cm-menu__head { display: flex; align-items: center; gap: 12px; padding: 8px 10px 10px; }
.cm-menu__avatar { width: 42px; height: 42px; border-radius: 50%; object-fit: cover; flex-shrink: 0; border: 2px solid var(--cm-green-light); }
.cm-menu__id { display: flex; flex-direction: column; min-width: 0; }
.cm-menu__name { font-size: 14px; font-weight: 700; color: var(--cm-neutral-900); line-height: 1.2; }
.cm-menu__email { font-size: 12px; color: var(--cm-neutral-500); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cm-menu__sep { height: 1px; background: var(--cm-neutral-100); margin: 4px 0; }
.cm-menu__item { display: flex; align-items: center; gap: 12px; width: 100%; border: none; background: none; padding: 10px 10px; border-radius: 9px; cursor: pointer; font: inherit; font-size: 14px; color: var(--cm-neutral-900); text-align: left; transition: background-color .12s ease; }
.cm-menu__item > i { width: 18px; text-align: center; color: var(--cm-neutral-500); font-size: 14px; flex-shrink: 0; }
.cm-menu__item > span { flex: 1; min-width: 0; }
.cm-menu__item > span.cm-menu__badge { flex: 0 0 auto; display: inline-flex; align-items: center; justify-content: center; min-width: 20px; height: 18px; }
.cm-menu__item:hover { background: var(--cm-green-light); }
.cm-menu__item--danger { color: var(--cm-error); }
.cm-menu__item--danger > i { color: var(--cm-error); }
.cm-menu__item--danger:hover { background: var(--cm-error-bg); }
.cm-menu__badge { flex-shrink: 0; background: var(--cm-yellow-accent); color: var(--cm-green-dark); font-size: 11px; font-weight: 700; border-radius: 999px; padding: 1px 8px; }

/* ---------------- FOOTER ---------------- */
.cm-footer { background-color: #f8f9fa; padding: 56px 32px 28px; font-size: 0.9rem; color: var(--cm-neutral-500); }
.cm-footer__top { display: grid; grid-template-columns: 1.2fr 2.4fr; gap: 48px; padding-bottom: 32px; border-bottom: 1px solid var(--cm-neutral-200); }
.cm-footer__logo { height: 36px; width: auto; display: block; margin-bottom: 14px; }
.cm-footer__pitch { margin: 0 0 18px; font-size: 14px; line-height: 1.5; color: var(--cm-neutral-500); max-width: 280px; }
.cm-footer__social { display: flex; gap: 10px; }
.cm-footer__social a { width: 38px; height: 38px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; background: #fff; border: 1px solid var(--cm-neutral-200); color: var(--cm-neutral-600); font-size: 15px; cursor: pointer; transition: all .15s ease; }
.cm-footer__social a:hover { background: var(--cm-green-primary); border-color: var(--cm-green-primary); color: #fff; transform: translateY(-2px); }
.cm-footer__cols { display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; }
.cm-footer__col { display: flex; flex-direction: column; gap: 10px; }
.cm-footer h6 { color: #222; letter-spacing: 0.5px; text-transform: uppercase; font-size: 0.76rem; font-weight: 700; margin: 0 0 4px; }
.cm-footer a { color: var(--cm-neutral-500); text-decoration: none; cursor: pointer; transition: color .12s ease; font-size: 14px; display: inline-flex; align-items: center; gap: 7px; }
.cm-footer a:hover { color: var(--cm-green-primary); }
.cm-footer__addr { font-size: 14px; line-height: 1.5; color: var(--cm-neutral-500); }
.cm-footer__bar { display: flex; justify-content: space-between; align-items: center; gap: 12px; flex-wrap: wrap; padding-top: 20px; font-size: 13px; }
.cm-footer__slogan { color: var(--cm-yellow-dark); font-weight: 600; font-style: italic; }
@media (max-width: 860px) {
  .cm-footer { padding: 40px 16px 24px; }
  .cm-footer__top { grid-template-columns: 1fr; gap: 28px; }
  .cm-footer__cols { grid-template-columns: 1fr 1fr; gap: 24px 16px; }
}

/* ---------------- SECTION RHYTHM ---------------- */
.cm-section { padding-block: 80px; }
.cm-section--tight { padding-block: 56px; }
.cm-section--soft { background-color: var(--cm-neutral-50); }
.cm-section__title { font-family: var(--cm-font-display); font-weight: var(--cm-fw-bold); font-size: var(--cm-fluid-h2); color: var(--cm-neutral-900); margin: 0 0 8px; letter-spacing: -0.4px; }
.cm-section__lead { font-size: var(--cm-fluid-lead); color: var(--cm-neutral-500); margin: 0; }


/* ---- HERO ---- */
.cm-hero {
  position: relative; min-height: 560px; display: flex; align-items: center;
  padding: 88px 0 72px;
  /* background image fournie par le dev (index.scss) */
  overflow: hidden;
}
.cm-hero__overlay {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: linear-gradient(180deg, rgba(27,75,42,0.62) 0%, rgba(27,75,42,0.34) 38%, rgba(20,56,32,0.74) 100%), rgba(0,0,0,0.30);
}
.cm-hero__content { position: relative; z-index: 1; width: 100%; }
.cm-hero__eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,0.16); color: #fff; font-size: 13px; font-weight: 600; letter-spacing: 0.2px;
  padding: 8px 16px; border-radius: var(--cm-radius-full); margin-bottom: 20px;
  border: 1px solid rgba(255,255,255,0.28); backdrop-filter: blur(6px);
}
.cm-hero__eyebrow i { color: var(--cm-yellow-accent); font-size: 12px; }
.cm-hero__title {
  color: #fff; font-family: var(--cm-font-display); font-weight: 800; font-size: var(--cm-fluid-display);
  line-height: 1.1; letter-spacing: -0.6px; margin: 0 0 16px; text-shadow: 0 2px 18px rgba(0,0,0,0.35); text-wrap: balance;
}
.cm-hero__title-accent { color: var(--cm-yellow-accent); }
.cm-hero__tagline { color: rgba(255,255,255,0.92); font-size: var(--cm-fluid-lead); line-height: 1.5; margin: 0 auto 40px; max-width: 600px; text-shadow: 0 1px 10px rgba(0,0,0,0.3); }
.cm-hero__trust { list-style: none; margin: 20px 0 0; padding: 0; display: flex; flex-wrap: wrap; justify-content: center; gap: 8px 24px; }
.cm-hero__trust li { display: inline-flex; align-items: center; gap: 7px; color: rgba(255,255,255,0.95); font-size: 14px; font-weight: 500; text-shadow: 0 1px 6px rgba(0,0,0,0.3); }
.cm-hero__trust i { color: var(--cm-yellow-accent); font-size: 13px; }
.cm-map-cta { display: inline-flex; align-items: center; gap: 8px; color: #fff; font-weight: 600; font-size: 14px; text-decoration: none; margin-top: 16px; opacity: 0.95; cursor: pointer; }
.cm-map-cta:hover { text-decoration: underline; }
.cm-hero__map-wrap { text-align: center; margin-top: 18px; }
.cm-hero__map-btn {
  display: inline-flex; align-items: center; gap: 10px; cursor: pointer;
  padding: 13px 26px; border-radius: var(--cm-radius-full);
  background: rgba(255,255,255,0.95); color: var(--cm-green-dark);
  font-family: var(--cm-font-sans); font-size: 15px; font-weight: 700; text-decoration: none;
  border: 1px solid rgba(255,255,255,0.7); box-shadow: 0 6px 20px rgba(0,0,0,0.22);
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
  transition: transform var(--cm-duration-fast) var(--cm-ease-standard), box-shadow var(--cm-duration-fast) var(--cm-ease-standard), background-color var(--cm-duration-fast) var(--cm-ease-standard);
}
.cm-hero__map-btn i { color: var(--cm-green-primary); font-size: 16px; }
.cm-hero__map-btn:hover { background: #fff; transform: translateY(-2px); box-shadow: 0 10px 28px rgba(0,0,0,0.28); }
.cm-hero__map-btn:active { transform: scale(0.98); }

/* ---- Section header ---- */
.cm-section__header { margin-bottom: 36px; }

/* ---- Grids ---- */
.cm-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; }
.cm-grid--steps { grid-template-columns: repeat(3, minmax(0, 1fr)); }
@media (max-width: 900px) { .cm-grid, .cm-grid--steps { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); } }
@media (max-width: 620px) { .cm-grid, .cm-grid--steps { grid-template-columns: minmax(0, 1fr); } }

/* ---- Regions scroll ---- */
.cm-regions__scroll { display: flex; gap: 10px; overflow-x: auto; padding: 4px 0 10px; scrollbar-width: none; }
.cm-regions__scroll::-webkit-scrollbar { display: none; }

/* ---- Partners ---- */
.cm-partners { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 28px 48px; }
.cm-partners img { max-height: 52px; max-width: 130px; object-fit: contain; filter: grayscale(1); opacity: 0.6; transition: filter .2s, opacity .2s; }
.cm-partners img:hover { filter: none; opacity: 1; }

/* ---- Host CTA layout ---- */
.cm-host-cta__grid { display: grid; grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr); gap: 32px; align-items: center; }
.cm-host-cta__image { border-radius: var(--cm-radius-xl); overflow: hidden; aspect-ratio: 4/3; }
.cm-host-cta__image img { width: 100%; height: 100%; object-fit: cover; }
@media (max-width: 760px) { .cm-host-cta__grid { grid-template-columns: minmax(0, 1fr); } .cm-host-cta__image { display: none; } }

/* ---- LISTINGS PAGE ---- */
.cm-listings { display: grid; grid-template-columns: 280px minmax(0, 1fr); gap: 32px; padding-block: 40px; }
.cm-filterbar { display: none; }
.cm-filter-card__done { display: none; }
@media (max-width: 860px) {
  .cm-listings { display: flex; flex-direction: column; gap: 0; padding-block: 20px; }
  .cm-listings__main { order: 1; }
  .cm-filter-card { order: 2; position: static; display: none; margin-top: 18px; }
  .cm-filter-card.is-open { display: block; }
  .cm-filterbar {
    display: inline-flex; align-items: center; gap: 8px; align-self: flex-start;
    margin: 0 0 18px; padding: 10px 18px; border: 1px solid var(--cm-neutral-300);
    border-radius: 999px; background: #fff; font: inherit; font-size: 14px; font-weight: 600;
    color: var(--cm-neutral-900); cursor: pointer; box-shadow: var(--cm-shadow-sm);
  }
  .cm-filterbar i { color: var(--cm-green-primary); }
  .cm-filterbar__count { background: var(--cm-green-primary); color: #fff; font-size: 11px; font-weight: 700; border-radius: 999px; min-width: 18px; height: 18px; display: inline-flex; align-items: center; justify-content: center; padding: 0 5px; }
  .cm-filter-card__done { display: flex; margin-top: 10px; }
}
.cm-filter-card { background: #fff; border: 1px solid var(--cm-neutral-100); border-radius: var(--cm-radius-lg); box-shadow: var(--cm-shadow-sm); padding: 22px; align-self: start; position: sticky; top: 96px; }
.cm-filter-card h2 { font-size: 18px; font-weight: 700; margin: 0 0 18px; display: flex; align-items: center; gap: 8px; }
.cm-filter-card h2 i { color: var(--cm-green-primary); }
.cm-range { width: 100%; accent-color: var(--cm-green-primary); }
.cm-listings__grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; }
@media (max-width: 1100px) { .cm-listings__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 520px) { .cm-listings__grid { grid-template-columns: minmax(0, 1fr); } }
.cm-listings__head { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 24px; gap: 16px; flex-wrap: wrap; }

/* ---- DETAIL PAGE ---- */
.cm-detail { padding-block: 32px; }
.cm-photo-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 8px; border-radius: var(--cm-radius-lg); overflow: hidden; aspect-ratio: 2.4/1; position: relative; }
.cm-photo-grid__main { grid-row: 1 / 3; grid-column: 1; }
.cm-photo-grid img { width: 100%; height: 100%; object-fit: cover; cursor: pointer; transition: filter .2s; }
.cm-photo-grid img:hover { filter: brightness(0.93); }
.cm-detail__body { display: grid; grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr); gap: 48px; margin-top: 36px; align-items: start; }
@media (max-width: 860px) { .cm-detail__body { grid-template-columns: minmax(0, 1fr); } .cm-photo-grid { grid-template-columns: minmax(0, 1fr); grid-template-rows: none; aspect-ratio: 16/10; } .cm-photo-grid__thumbs { display: none; } }
.cm-detail__section { padding: 28px 0; border-top: 1px solid var(--cm-neutral-100); }
.cm-detail__section:first-child { border-top: none; padding-top: 0; }
.cm-detail__section h2 { font-size: 22px; font-weight: 700; margin: 0 0 16px; }
.cm-features { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 18px; }
.cm-reviews-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 16px; }
@media (max-width: 760px) { .cm-reviews-grid { grid-template-columns: minmax(0, 1fr); } }
.cm-feature { display: flex; align-items: flex-start; gap: 12px; }
.cm-feature i { color: var(--cm-green-primary); font-size: 20px; width: 24px; text-align: center; margin-top: 2px; }
.cm-feature__label { font-weight: 600; font-size: 15px; }
.cm-feature__val { color: var(--cm-neutral-500); font-size: 14px; }

/* Reservation card */
.cm-resv { position: sticky; top: 96px; background: #fff; border: 1px solid var(--cm-neutral-200); border-radius: var(--cm-radius-lg); box-shadow: var(--cm-shadow-lg); padding: 24px; }
.cm-resv__price { font-size: 28px; font-weight: 800; color: var(--cm-neutral-900); }
.cm-resv__price small { font-size: 14px; font-weight: 400; color: var(--cm-neutral-500); }
.cm-resv__row { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 10px; }
.cm-resv__note { text-align: center; color: var(--cm-neutral-500); font-size: 13px; margin: 14px 0 0; }

.cm-host-banner { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding-bottom: 24px; border-bottom: 1px solid var(--cm-neutral-100); }
.cm-host-banner__avatar { width: 64px; height: 64px; border-radius: 50%; object-fit: cover; }

/* breadcrumb */
.cm-breadcrumb { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--cm-neutral-500); padding: 14px 0; }
.cm-breadcrumb a { cursor: pointer; }
.cm-breadcrumb a:hover { color: var(--cm-neutral-900); text-decoration: underline; }
.cm-breadcrumb__sep { color: var(--cm-neutral-300); }

/* ---- AUTH ---- */
.cm-auth { min-height: calc(100vh - 72px); display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); }
@media (max-width: 760px) { .cm-auth { grid-template-columns: minmax(0, 1fr); } .cm-auth__art { display: none; } }
.cm-auth__art { position: relative; background-size: cover; background-position: center; }
.cm-auth__art-overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(27,75,42,0.35), rgba(27,75,42,0.75)); display: flex; flex-direction: column; justify-content: flex-end; padding: 48px; }
.cm-auth__art-overlay h2 { color: #fff; font-size: 28px; font-weight: 800; margin: 0 0 8px; text-shadow: 0 2px 12px rgba(0,0,0,.4); }
.cm-auth__art-overlay p { color: rgba(255,255,255,0.9); margin: 0; }
.cm-auth__form { display: flex; align-items: center; justify-content: center; padding: 48px 32px; }
.cm-auth__inner { width: 100%; max-width: 380px; }
.cm-auth__tabs { display: flex; gap: 4px; background: var(--cm-neutral-50); border-radius: var(--cm-radius-full); padding: 4px; margin-bottom: 28px; }
.cm-auth__tab { flex: 1; padding: 10px; border: none; background: none; border-radius: var(--cm-radius-full); font-family: var(--cm-font-sans); font-weight: 600; font-size: 14px; color: var(--cm-neutral-500); cursor: pointer; transition: all .15s; }
.cm-auth__tab.is-active { background: #fff; color: var(--cm-green-dark); box-shadow: var(--cm-shadow-sm); }

/* Toast */
.cm-toast { position: fixed; top: 88px; right: 20px; z-index: 200; background: var(--cm-success-bg); color: var(--cm-success); border-radius: 12px; padding: 14px 18px; box-shadow: var(--cm-shadow-lg); font-size: 14px; font-weight: 600; display: flex; align-items: center; gap: 8px; animation: cmToast .24s var(--cm-ease-enter); }
@keyframes cmToast { from { opacity: 0; transform: translateX(20px); } to { opacity: 1; transform: translateX(0); } }

/* mobile reveal helpers */
.cm-stack { display: flex; flex-direction: column; gap: 12px; }

/* compact "comment ça marche" band */
.cm-steps-compact { display: flex; flex-direction: column; align-items: center; gap: 18px; }
.cm-steps-compact__title { font-family: var(--cm-font-display); font-weight: 700; font-size: 22px; color: var(--cm-neutral-900); margin: 0; letter-spacing: -0.3px; }
.cm-steps-compact__row { display: flex; align-items: center; justify-content: center; gap: 18px; flex-wrap: wrap; width: 100%; }
.cm-step-inline { display: flex; align-items: center; gap: 12px; max-width: 280px; }
.cm-step-inline__icon { position: relative; flex-shrink: 0; width: 46px; height: 46px; border-radius: 50%; background: var(--cm-green-light); color: var(--cm-green-dark); display: flex; align-items: center; justify-content: center; font-size: 18px; }
.cm-step-inline__num { position: absolute; top: -4px; right: -4px; width: 20px; height: 20px; border-radius: 50%; background: var(--cm-green-primary); color: #fff; font-size: 11px; font-weight: 700; display: flex; align-items: center; justify-content: center; border: 2px solid #fff; }
.cm-step-inline__title { font-weight: 700; font-size: 16px; color: var(--cm-neutral-900); line-height: 1.2; }
.cm-step-inline__text { margin: 2px 0 0; font-size: 13.5px; color: var(--cm-neutral-500); line-height: 1.35; }
.cm-step-inline__sep { color: var(--cm-neutral-300); font-size: 14px; }
@media (max-width: 760px) {
  .cm-steps-compact__row { flex-direction: column; align-items: stretch; gap: 14px; max-width: 420px; margin: 0 auto; }
  .cm-step-inline { max-width: none; }
  .cm-step-inline__sep { display: none; }
}

/* ============ ACCOUNT SPACE ============ */
.cm-account { background: var(--cm-neutral-50); min-height: calc(100vh - 72px); padding-block: 32px; }
.cm-account__grid { display: grid; grid-template-columns: 260px minmax(0, 1fr); gap: 28px; }
@media (max-width: 900px) { .cm-account__grid { grid-template-columns: minmax(0, 1fr); } }
.cm-account__header { margin-bottom: 28px; }
.cm-account__header h1 { font-size: 28px; font-weight: 800; margin: 0 0 6px; letter-spacing: -0.4px; }
.cm-account__header p { margin: 0; color: var(--cm-neutral-500); }

/* Sidebar */
.cm-sidebar { background: #fff; border: 1px solid var(--cm-neutral-100); border-radius: var(--cm-radius-lg); box-shadow: var(--cm-shadow-sm); padding: 22px; align-self: start; position: sticky; top: 96px; }
.cm-sidebar__id { text-align: center; padding-bottom: 18px; border-bottom: 1px solid var(--cm-neutral-100); margin-bottom: 14px; }
.cm-sidebar__avatar { width: 72px; height: 72px; border-radius: 50%; object-fit: cover; margin: 0 auto 10px; border: 3px solid var(--cm-green-light); }
.cm-sidebar__name { font-weight: 700; color: var(--cm-neutral-900); }
.cm-sidebar__email { font-size: 13px; color: var(--cm-neutral-500); overflow: hidden; text-overflow: ellipsis; }
.cm-sidebar__nav { display: flex; flex-direction: column; gap: 2px; }
.cm-sidebar__link { display: flex; align-items: center; gap: 10px; padding: 11px 12px; border-radius: 10px; border: none; background: none; font: inherit; font-size: 15px; color: var(--cm-neutral-700); cursor: pointer; text-align: left; transition: background .12s, color .12s; }
.cm-sidebar__link i { width: 18px; text-align: center; color: var(--cm-neutral-400); }
.cm-sidebar__link:hover { background: var(--cm-neutral-50); color: var(--cm-neutral-900); }
.cm-sidebar__link.is-active { background: var(--cm-green-light); color: var(--cm-green-dark); font-weight: 600; }
.cm-sidebar__link.is-active i { color: var(--cm-green-primary); }
.cm-sidebar__link--logout { color: var(--cm-error); }
.cm-sidebar__link--logout i { color: var(--cm-error); }
.cm-sidebar__badge { margin-left: auto; background: var(--cm-green-primary); color: #fff; font-size: 11px; font-weight: 700; border-radius: 999px; padding: 1px 8px; }
.cm-sidebar__cta { margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--cm-neutral-100); }

.cm-panel { background: #fff; border: 1px solid var(--cm-neutral-100); border-radius: var(--cm-radius-lg); box-shadow: var(--cm-shadow-sm); padding: 24px; }
.cm-panel__title { font-size: 17px; font-weight: 700; margin: 0 0 18px; display: flex; align-items: center; gap: 8px; }
.cm-panel__title i { color: var(--cm-green-primary); }

/* Profile */
.cm-profile-id { display: flex; align-items: center; gap: 20px; margin-bottom: 20px; }
.cm-profile-id__avatar { position: relative; }
.cm-profile-id__avatar img { width: 92px; height: 92px; border-radius: 50%; object-fit: cover; }
.cm-profile-id__edit { position: absolute; bottom: 0; right: 0; width: 30px; height: 30px; border-radius: 50%; background: var(--cm-green-primary); color: #fff; border: 2px solid #fff; display: flex; align-items: center; justify-content: center; font-size: 12px; cursor: pointer; }
.cm-profile-grid { display: grid; grid-template-columns: minmax(0,1fr) minmax(0,1fr); gap: 16px; }
@media (max-width: 560px) { .cm-profile-grid { grid-template-columns: minmax(0,1fr); } }
.cm-profile-cols { display: grid; grid-template-columns: minmax(0,1.7fr) minmax(0,1fr); gap: 20px; align-items: start; }
@media (max-width: 760px) { .cm-profile-cols { grid-template-columns: minmax(0,1fr); } }

/* Reservation tabs + cards */
.cm-tabs { display: flex; gap: 2px; overflow-x: auto; margin-bottom: 24px; scrollbar-width: none; border-bottom: 1px solid var(--cm-neutral-200); }
.cm-tabs::-webkit-scrollbar { display: none; }
.cm-tab { flex-shrink: 0; display: inline-flex; align-items: center; gap: 7px; padding: 12px 16px; border: none; background: none; border-bottom: 2px solid transparent; margin-bottom: -1px; font: inherit; font-size: 14px; font-weight: 500; color: var(--cm-neutral-500); cursor: pointer; white-space: nowrap; transition: color .12s, border-color .12s; }
.cm-tab:hover { color: var(--cm-neutral-900); }
.cm-tab.is-active { color: var(--cm-green-dark); border-bottom-color: var(--cm-green-primary); font-weight: 600; }
.cm-tab__count { background: var(--cm-neutral-100); color: var(--cm-neutral-600); font-size: 11px; font-weight: 700; border-radius: 999px; padding: 1px 7px; }
.cm-tab.is-active .cm-tab__count { background: var(--cm-green-light); color: var(--cm-green-dark); }
/* Mobile: uniform grid so every tab is visible and aligned (no scroll, no ragged wrap) */
@media (max-width: 620px) {
  .cm-tabs { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 8px; border-bottom: none; margin-bottom: 20px; overflow: visible; }
  .cm-tab { justify-content: center; padding: 11px 10px; border-bottom: none; margin-bottom: 0; border-radius: 12px; background: var(--cm-neutral-50); color: var(--cm-neutral-700); }
  .cm-tab.is-active { background: var(--cm-green-light); color: var(--cm-green-dark); }
}

.cm-resv-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 18px; }
@media (max-width: 1050px) { .cm-resv-grid { grid-template-columns: minmax(0, 1fr); } }
.cm-resv-card { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--cm-neutral-100); border-radius: 16px; overflow: hidden; box-shadow: var(--cm-shadow-sm); }
.cm-resv-card__media { position: relative; aspect-ratio: 16/9; cursor: pointer; overflow: hidden; }
.cm-resv-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; }
.cm-resv-card:hover .cm-resv-card__media img { transform: scale(1.04); }
.cm-status { position: absolute; top: 12px; left: 12px; padding: 5px 12px; border-radius: 999px; font-size: 12px; font-weight: 700; backdrop-filter: blur(4px); white-space: nowrap; }
.cm-status--pending { background: var(--cm-warning-bg); color: var(--cm-yellow-dark); }
.cm-status--confirmed { background: var(--cm-success-bg); color: var(--cm-success); }
.cm-status--past { background: rgba(255,255,255,0.92); color: var(--cm-neutral-600); }
.cm-resv-card__body { padding: 16px; flex: 1; }
.cm-resv-card__name { font-weight: 700; font-size: 15px; margin: 0 0 10px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.cm-resv-card__meta { display: flex; align-items: center; gap: 8px; color: var(--cm-neutral-600); font-size: 14px; margin: 0 0 6px; }
.cm-resv-card__meta i { color: var(--cm-neutral-400); width: 16px; }
.cm-resv-card__price { font-weight: 700; color: var(--cm-neutral-900); margin: 8px 0 0; }
.cm-resv-card__price span { font-weight: 400; font-size: 13px; color: var(--cm-neutral-500); }
.cm-resv-card__footer { display: flex; gap: 8px; padding: 0 16px 16px; flex-wrap: wrap; }
.cm-empty { text-align: center; padding: 56px 24px; background: #fff; border: 1px dashed var(--cm-neutral-200); border-radius: 16px; grid-column: 1 / -1; }
.cm-empty i { font-size: 36px; color: var(--cm-neutral-300); margin-bottom: 14px; }
.cm-empty h5 { font-weight: 700; margin: 0 0 6px; }
.cm-empty p { color: var(--cm-neutral-500); margin: 0 0 16px; }

/* Wallet */
.cm-wallet-hero { display: flex; justify-content: space-between; align-items: flex-end; gap: 24px; background: linear-gradient(135deg, var(--cm-green-dark), #2c6b40); color: #fff; border-radius: var(--cm-radius-xl); padding: 30px 32px; margin-bottom: 20px; flex-wrap: wrap; }
.cm-wallet-hero__label { margin: 0 0 4px; opacity: 0.8; font-size: 14px; }
.cm-wallet-hero__amount { margin: 0; font-size: 44px; font-weight: 800; letter-spacing: -1px; line-height: 1; }
.cm-wallet-hero__amount span { font-size: 24px; font-weight: 600; opacity: 0.9; }
.cm-wallet-hero__meta { margin: 8px 0 0; opacity: 0.85; font-size: 14px; }
.cm-wallet-hero__link { color: #fff; font-weight: 600; text-decoration: none; font-size: 14px; display: inline-flex; align-items: center; gap: 6px; border: 1px solid rgba(255,255,255,0.4); padding: 9px 16px; border-radius: 999px; }
.cm-wallet-hero__link:hover { background: rgba(255,255,255,0.12); }
.cm-wallet-stats { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; margin-bottom: 24px; }
@media (max-width: 860px) { .cm-wallet-stats { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); } }
.cm-stat { display: flex; align-items: center; gap: 14px; background: #fff; border: 1px solid var(--cm-neutral-100); border-radius: 14px; box-shadow: var(--cm-shadow-sm); padding: 18px; }
.cm-stat__icon { width: 46px; height: 46px; border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 18px; flex-shrink: 0; }
.cm-stat__label { font-size: 13px; color: var(--cm-neutral-500); margin: 0; }
.cm-stat__value { font-size: 22px; font-weight: 800; margin: 2px 0 0; }
.cm-wallet-table { width: 100%; border-collapse: collapse; }
.cm-wallet-table th { text-align: left; font-size: 12px; text-transform: uppercase; letter-spacing: 0.4px; color: var(--cm-neutral-500); padding: 10px 12px; border-bottom: 1px solid var(--cm-neutral-100); }
.cm-wallet-table td { padding: 14px 12px; border-bottom: 1px solid var(--cm-neutral-50); font-size: 14px; }
.cm-wallet-table tr:last-child td { border-bottom: none; }
.cm-wallet-table code { font-size: 12px; color: var(--cm-neutral-400); }
.cm-table-scroll { overflow-x: auto; }
.cm-table-scroll .cm-wallet-table { min-width: 360px; }

/* ============ MESSAGES ============ */
.cm-msg { display: grid; grid-template-columns: 320px minmax(0, 1fr); gap: 0; background: #fff; border: 1px solid var(--cm-neutral-100); border-radius: var(--cm-radius-lg); box-shadow: var(--cm-shadow-sm); overflow: hidden; min-height: 540px; }
.cm-msg__list { border-right: 1px solid var(--cm-neutral-100); display: flex; flex-direction: column; }
.cm-msg__search { padding: 14px; border-bottom: 1px solid var(--cm-neutral-100); }
.cm-msg__search input { width: 100%; border: 1px solid var(--cm-neutral-200); border-radius: 999px; padding: 9px 14px; font: inherit; font-size: 14px; outline: none; }
.cm-msg__search input:focus { border-color: var(--cm-green-primary); }
.cm-msg__convo { display: flex; align-items: center; gap: 12px; padding: 14px; border: none; background: none; width: 100%; text-align: left; cursor: pointer; border-bottom: 1px solid var(--cm-neutral-50); font: inherit; }
.cm-msg__convo:hover { background: var(--cm-neutral-50); }
.cm-msg__convo.is-active { background: var(--cm-green-light); }
.cm-msg__avatar { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.cm-msg__convo-main { flex: 1; min-width: 0; }
.cm-msg__convo-name { font-weight: 600; font-size: 14px; color: var(--cm-neutral-900); display: flex; justify-content: space-between; gap: 8px; }
.cm-msg__convo-time { font-weight: 400; font-size: 12px; color: var(--cm-neutral-400); flex-shrink: 0; }
.cm-msg__convo-preview { font-size: 13px; color: var(--cm-neutral-500); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; margin-top: 2px; }
.cm-msg__unread { width: 9px; height: 9px; border-radius: 50%; background: var(--cm-green-primary); flex-shrink: 0; }
.cm-msg__thread { display: flex; flex-direction: column; min-width: 0; }
.cm-msg__thread-head { display: flex; align-items: center; gap: 12px; padding: 16px 20px; border-bottom: 1px solid var(--cm-neutral-100); }
.cm-msg__thread-head h3 { margin: 0; font-size: 16px; font-weight: 700; }
.cm-msg__thread-head p { margin: 0; font-size: 13px; color: var(--cm-neutral-500); }
.cm-msg__body { flex: 1; padding: 20px; display: flex; flex-direction: column; gap: 12px; background: var(--cm-neutral-50); overflow-y: auto; }
.cm-msg__day { text-align: center; font-size: 12px; color: var(--cm-neutral-400); margin: 4px 0; }
.cm-bubble { max-width: 75%; padding: 11px 15px; border-radius: 18px; font-size: 14px; line-height: 1.45; }
.cm-bubble--them { align-self: flex-start; background: #fff; border: 1px solid var(--cm-neutral-100); border-bottom-left-radius: 5px; color: var(--cm-neutral-900); }
.cm-bubble--me { align-self: flex-end; background: var(--cm-green-primary); color: #fff; border-bottom-right-radius: 5px; }
.cm-msg__compose { display: flex; gap: 10px; padding: 14px 16px; border-top: 1px solid var(--cm-neutral-100); background: #fff; }
.cm-msg__compose input { flex: 1; border: 1px solid var(--cm-neutral-200); border-radius: 999px; padding: 11px 16px; font: inherit; font-size: 14px; outline: none; }
.cm-msg__compose input:focus { border-color: var(--cm-green-primary); }
.cm-msg__send { width: 46px; height: 46px; border-radius: 50%; border: none; background: var(--cm-green-primary); color: #fff; cursor: pointer; flex-shrink: 0; }
.cm-msg__send:hover { background: var(--cm-green-primary-hover); }
.cm-msg__back { display: none; }
.cm-msg-topbar { display: none; }

/* ============ MES ANNONCES ============ */
.cm-mysites { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 20px; }
@media (max-width: 1050px) { .cm-mysites { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); } }
@media (max-width: 640px) { .cm-mysites { grid-template-columns: minmax(0, 1fr); } }
.cm-mysite { background: #fff; border: 1px solid var(--cm-neutral-100); border-radius: 16px; overflow: hidden; box-shadow: var(--cm-shadow-sm); display: flex; flex-direction: column; }
.cm-mysite__media { position: relative; aspect-ratio: 16/10; overflow: hidden; }
.cm-mysite__media img { width: 100%; height: 100%; object-fit: cover; }
.cm-mysite__body { padding: 14px 16px; flex: 1; }
.cm-mysite__name { font-weight: 700; font-size: 15px; margin: 0 0 6px; }
.cm-mysite__meta { font-size: 13px; color: var(--cm-neutral-500); display: flex; gap: 14px; flex-wrap: wrap; }
.cm-mysite__stats { display: flex; gap: 18px; padding: 12px 16px; border-top: 1px solid var(--cm-neutral-50); font-size: 13px; color: var(--cm-neutral-600); }
.cm-mysite__stats span { white-space: nowrap; }
.cm-mysite__stats b { color: var(--cm-neutral-900); }
.cm-mysite__foot { display: flex; gap: 8px; padding: 0 16px 16px; }
@media (max-width: 860px) {
  .cm-msg { display: block; min-height: 0; border: none; box-shadow: none; background: none; border-radius: 0; overflow: visible; }
  .cm-msg__list { border: 1px solid var(--cm-neutral-100); border-radius: 14px; box-shadow: var(--cm-shadow-sm); background: #fff; max-height: none; overflow: hidden; }
  .cm-msg__thread { display: none; }
  .cm-msg.is-thread .cm-msg__list { display: none; }
  .cm-msg.is-thread .cm-msg__thread { display: flex; min-height: calc(100vh - 210px); border: 1px solid var(--cm-neutral-100); border-radius: 14px; box-shadow: var(--cm-shadow-sm); background: #fff; overflow: hidden; }
  .cm-msg__back { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; border: none; background: var(--cm-neutral-50); border-radius: 50%; color: var(--cm-neutral-700); cursor: pointer; flex-shrink: 0; }
  .cm-msg__back:active { transform: scale(0.94); }
  /* Full-screen Messages page on mobile */
  .cm-account--msg { padding-block: 0 56px; }
  .cm-account--msg .container { padding: 0; }
  .cm-account--msg .cm-account__grid { display: block; }
  .cm-account--msg .cm-account__header { display: none; }
  .cm-account--msg .cm-sidebar { display: none; }
  .cm-msg-topbar { display: flex; align-items: center; gap: 10px; padding: 12px 16px; background: #fff; border-bottom: 1px solid var(--cm-neutral-100); position: sticky; top: 0; z-index: 6; }
  .cm-msg-topbar__back { width: 38px; height: 38px; border: none; background: var(--cm-neutral-50); border-radius: 50%; color: var(--cm-neutral-700); cursor: pointer; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
  .cm-msg-topbar__back:active { transform: scale(0.94); }
  .cm-msg-topbar__title { font-weight: 700; font-size: 17px; }
  .cm-account--msg.is-thread-open .cm-msg-topbar { display: none; }
  .cm-account--msg .cm-msg__list { border: none; border-radius: 0; box-shadow: none; min-height: calc(100vh - 112px); }
  .cm-account--msg .cm-msg.is-thread .cm-msg__thread { border: none; border-radius: 0; box-shadow: none; min-height: calc(100vh - 56px); }
}

/* ============ MOBILE CHROME ============ */
/* Burger + drawer + bottom tab bar. Desktop hides mobile-only bits. */
.cm-burger, .cm-bottom-nav, .cm-drawer, .cm-drawer-overlay, .cm-msticky { display: none; }

@media (max-width: 860px) {
  .container { padding: 0 16px; }
  .cm-navbar { padding: 0 16px; min-height: 64px; }
  .cm-navbar__nav { display: none; }
  .cm-burger {
    display: inline-flex; align-items: center; justify-content: center;
    width: 44px; height: 44px; padding: 0; border: 1px solid var(--cm-neutral-200);
    border-radius: 999px; background: #fff; box-shadow: var(--cm-shadow-sm); cursor: pointer;
  }
  .cm-burger span { display: block; width: 18px; height: 2px; border-radius: 2px; background: var(--cm-neutral-900); position: relative; }
  .cm-burger span::before, .cm-burger span::after { content: ''; position: absolute; left: 0; width: 18px; height: 2px; border-radius: 2px; background: var(--cm-neutral-900); }
  .cm-burger span::before { top: -5px; }
  .cm-burger span::after { top: 5px; }

  /* search bar stacks (faithful to _searchbar.scss ≤767) */
  .cm-searchbar { flex-direction: column; height: auto; border-radius: 24px; padding: 12px; gap: 10px;
    background: rgba(255,255,255,0.16); backdrop-filter: blur(22px) saturate(180%); -webkit-backdrop-filter: blur(22px) saturate(180%);
    border: 1px solid rgba(255,255,255,0.35);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.5), 0 12px 40px rgba(0,0,0,0.28); }
  .cm-searchbar__divider { display: none; }
  .cm-searchbar__field { background: rgba(255,255,255,0.10); border: 1px solid rgba(255,255,255,0.22); border-radius: 16px; padding: 12px 16px; grid-template-rows: 14px 24px; min-height: 60px; }
  .cm-searchbar__field:hover, .cm-searchbar__field:focus-within { background: rgba(255,255,255,0.20); border-color: rgba(255,255,255,0.4); }
  .cm-searchbar__field-icon { color: var(--cm-yellow-accent); }
  .cm-searchbar__label { color: #fff; text-transform: uppercase; letter-spacing: 0.4px; }
  .cm-searchbar__input, .cm-searchbar__select { font-size: 16px; height: 24px; line-height: 24px; color: #fff; font-weight: 500; }
  .cm-searchbar__input::placeholder { color: rgba(255,255,255,0.75); }
  .cm-searchbar__select { background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23ffffff'%3e%3cpath d='M4.4 6.4a.6.6 0 0 1 .85 0L8 9.15l2.75-2.75a.6.6 0 1 1 .85.85l-3.18 3.18a.6.6 0 0 1-.85 0L4.4 7.25a.6.6 0 0 1 0-.85z'/%3e%3c/svg%3e"); background-repeat: no-repeat; background-position: right 2px center; background-size: 14px; padding-right: 22px; }
  .cm-searchbar__select option { color: #222; }
  .cm-searchbar__submit { width: 100%; height: 54px; border-radius: 16px; margin: 4px 0 0; gap: 10px;
    background: linear-gradient(180deg, #5FAA4A, var(--cm-green-primary-active));
    border: 1px solid rgba(255,255,255,0.35);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.45), 0 8px 22px rgba(27,75,42,0.5); }
  .cm-searchbar__submit::after { content: 'Rechercher'; font-weight: 600; font-size: 16px; }

  .cm-hero { min-height: 0; padding: 64px 0 36px; background-position: 100% center; }
  .cm-section { padding-block: 44px; }

  /* bottom tab bar */
  .cm-bottom-nav {
    display: flex; position: fixed; left: 0; right: 0; bottom: 0; z-index: 60;
    align-items: stretch; justify-content: space-around;
    background: rgba(255,255,255,0.96); backdrop-filter: saturate(180%) blur(12px);
    border-top: 1px solid var(--cm-neutral-100); box-shadow: 0 -4px 20px rgba(0,0,0,0.06);
  }
  .cm-bottom-nav__item {
    flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 3px; min-height: 56px; padding: 8px 4px 6px; border: none; background: none;
    color: var(--cm-neutral-500); font: inherit; font-size: 11px; font-weight: 500; cursor: pointer; position: relative;
  }
  .cm-bottom-nav__item i { font-size: 20px; height: 24px; display: flex; align-items: center; }
  .cm-bottom-nav__item.is-active { color: var(--cm-green-primary); font-weight: 600; }
  .cm-bottom-nav__badge { position: absolute; top: 6px; left: calc(50% + 8px); min-width: 16px; height: 16px; padding: 0 4px; border-radius: 999px; background: var(--cm-yellow-accent); color: var(--cm-green-dark); font-size: 10px; font-weight: 700; line-height: 16px; box-shadow: 0 0 0 2px #fff; }
  .cm-app { padding-bottom: 56px; }

  /* drawer */
  .cm-drawer-overlay { display: block; position: fixed; inset: 0; z-index: 70; background: var(--cm-overlay-dark); opacity: 0; pointer-events: none; transition: opacity .26s; }
  .cm-drawer-overlay.is-open { opacity: 1; pointer-events: auto; }
  .cm-drawer { display: flex; flex-direction: column; position: fixed; top: 0; right: 0; bottom: 0; z-index: 71; width: min(86vw, 340px); background: #fff; box-shadow: var(--cm-shadow-lg); transform: translateX(100%); transition: transform .26s var(--cm-ease-exit); overflow-y: auto; }
  .cm-drawer.is-open { transform: translateX(0); }
  .cm-drawer__head { display: flex; align-items: center; justify-content: space-between; padding: 20px; border-bottom: 1px solid var(--cm-neutral-100); }
  .cm-drawer__brand { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; color: var(--cm-green-dark); }
  .cm-drawer__brand i { color: var(--cm-green-primary); }
  .cm-drawer__close { width: 38px; height: 38px; border-radius: 50%; border: none; background: var(--cm-neutral-50); color: var(--cm-neutral-700); cursor: pointer; }
  .cm-drawer__nav { display: flex; flex-direction: column; padding: 12px; }
  .cm-drawer__item { display: flex; align-items: center; gap: 14px; min-height: 50px; padding: 12px; border: none; background: none; border-radius: 12px; font: inherit; font-size: 16px; font-weight: 500; color: var(--cm-neutral-900); cursor: pointer; text-align: left; }
  .cm-drawer__item i { width: 22px; text-align: center; color: var(--cm-neutral-500); }
  .cm-drawer__item--feature { color: var(--cm-green-dark); font-weight: 600; }
  .cm-drawer__item--feature i { color: var(--cm-green-primary); }
  .cm-drawer__item--logout { color: var(--cm-error); }
  .cm-drawer__item--logout i { color: var(--cm-error); }
  .cm-drawer__divider { height: 1px; background: var(--cm-neutral-100); margin: 8px 12px; }
  .cm-drawer__auth { display: flex; flex-direction: column; gap: 12px; padding: 12px; }

  /* detail: stack + hide desktop sticky card, show mobile sticky CTA */
  .cm-resv { position: static; box-shadow: var(--cm-shadow-md); }
  .cm-detail { padding-bottom: 80px; }
  .cm-msticky {
    display: flex; align-items: center; gap: 12px; position: fixed; left: 0; right: 0;
    bottom: 56px; z-index: 65; padding: 12px 16px; background: #fff;
    border-top: 1px solid var(--cm-neutral-100); box-shadow: 0 -8px 24px rgba(0,0,0,0.08);
  }
  .cm-msticky__info { flex: 1; min-width: 0; }
  .cm-msticky__price { font-size: 18px; font-weight: 700; line-height: 1.1; }
  .cm-msticky__price span { font-size: 13px; font-weight: 400; color: var(--cm-neutral-500); }
  .cm-msticky__meta { font-size: 12px; color: var(--cm-neutral-500); }
  .cm-msticky .cm-btn { flex: 0 0 auto; min-width: 140px; }

  /* account: sidebar → compact identity header + horizontal chip nav */
  .cm-account { padding-bottom: 72px; }
  .cm-account__grid { gap: 0; }
  .cm-sidebar { position: static; background: none; border: none; box-shadow: none; padding: 0; margin-bottom: 20px; }
  .cm-sidebar__id { display: flex; align-items: center; gap: 12px; text-align: left; padding: 0 0 14px; border-bottom: 1px solid var(--cm-neutral-100); margin-bottom: 14px; }
  .cm-sidebar__avatar { width: 46px; height: 46px; margin: 0; border-width: 2px; }
  .cm-sidebar__nav { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 8px; overflow: visible; padding-bottom: 0; }
  .cm-sidebar__link { border: none; background: var(--cm-neutral-50); border-radius: 12px; padding: 12px 14px; margin-bottom: 0; font-size: 14px; font-weight: 500; color: var(--cm-neutral-700); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .cm-sidebar__link i { width: 18px; text-align: center; }
  .cm-sidebar__link.is-active { background: var(--cm-green-light); color: var(--cm-green-dark); font-weight: 600; }
  .cm-sidebar__link.is-active i { color: var(--cm-green-primary); }
  .cm-sidebar__badge { margin-left: auto; background: var(--cm-neutral-200); color: var(--cm-neutral-700); }
  .cm-sidebar__link--logout { display: none; }
  .cm-sidebar__cta { display: none; }
}


/* ===== AJOUT HANDOFF : hero searchbar "liquid glass" sur DESKTOP (demande user) ===== */
@media (min-width: 861px) {
  .cm-hero .cm-searchbar {
    background: rgba(255,255,255,0.16);
    backdrop-filter: blur(22px) saturate(180%); -webkit-backdrop-filter: blur(22px) saturate(180%);
    border: 1px solid rgba(255,255,255,0.35);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.5), 0 12px 40px rgba(0,0,0,0.28);
  }
  .cm-hero .cm-searchbar__field:hover, .cm-hero .cm-searchbar__field:focus-within { background: rgba(255,255,255,0.18); }
  .cm-hero .cm-searchbar__label { color: #fff; text-transform: uppercase; letter-spacing: 0.4px; }
  .cm-hero .cm-searchbar__input, .cm-hero .cm-searchbar__select { color: #fff; font-weight: 500; }
  .cm-hero .cm-searchbar__input::placeholder { color: rgba(255,255,255,0.75); }
  .cm-hero .cm-searchbar__divider { background: rgba(255,255,255,0.28); }
  .cm-hero .cm-searchbar__field-icon { color: var(--cm-yellow-accent); }
  .cm-hero .cm-searchbar__select {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23ffffff'%3e%3cpath d='M4.4 6.4a.6.6 0 0 1 .85 0L8 9.15l2.75-2.75a.6.6 0 1 1 .85.85l-3.18 3.18a.6.6 0 0 1-.85 0L4.4 7.25a.6.6 0 0 1 0-.85z'/%3e%3c/svg%3e");
    background-repeat: no-repeat; background-position: right 12px center; background-size: 15px;
  }
  .cm-hero .cm-searchbar__select option { color: #222; }
}

/* ===== AJUSTEMENTS USER (02/06) ===== */
/* -- Accueil : partenaires plus grands -- */
.cm-partners__item img { max-width: 165px !important; width: 100% !important; max-height: 96px; object-fit: contain; }
@media (max-width: 767.98px) { .cm-partners__item img { max-width: 100% !important; max-height: 76px; } }
/* -- Accueil : searchbar hero labels + valeurs en blanc, bouton vert -- */
.cm-hero .cm-searchbar__label { color: #fff !important; }
.cm-hero .cm-searchbar__select, .cm-hero .cm-searchbar__input { color: #fff !important; -webkit-text-fill-color: #fff; }
.cm-hero .cm-searchbar__input::placeholder { color: rgba(255,255,255,0.80) !important; -webkit-text-fill-color: rgba(255,255,255,0.80); }
.cm-hero .cm-searchbar__select option { color: #222 !important; -webkit-text-fill-color: #222; }
.cm-hero .cm-searchbar__submit { background: var(--cm-green-primary) !important; background-image: none !important; border-color: var(--cm-green-primary) !important; color: #fff !important; }

/* -- Burger mobile : 3 barres nettes (markup dev .cm-burger__bars > span x3) -- */
.cm-burger .cm-burger__bars { display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 4px; width: 20px; height: auto; }
.cm-burger .cm-burger__bars span { display: block; width: 20px; height: 2px; border-radius: 2px; background: var(--cm-neutral-900); position: static; margin: 0; }
.cm-burger .cm-burger__bars span::before, .cm-burger .cm-burger__bars span::after { content: none !important; display: none !important; }

/* -- Onglets reservations : actif en VERT (pas bleu Bootstrap) + alignes -- */
.cm-tabs .nav-link.active, .cm-tabs .cm-tab.active, .cm-tabs .cm-tab.is-active {
  color: var(--cm-green-dark) !important; border-bottom-color: var(--cm-green-primary) !important; background-color: transparent !important;
}
.cm-tabs .nav-link.active .cm-tab__count, .cm-tabs .cm-tab.active .cm-tab__count { background: var(--cm-green-light) !important; color: var(--cm-green-dark) !important; }
@media (max-width: 620px) {
  .cm-tabs { display: flex !important; flex-wrap: wrap; gap: 8px; border-bottom: none; }
  .cm-tabs .nav-item { flex: 1 1 0; min-width: 0; display: flex; }
  .cm-tabs .cm-tab { width: 100%; justify-content: center; text-align: center; padding: 10px 6px; font-size: 13px; border-radius: 12px; border-bottom: none !important; margin-bottom: 0; background: var(--cm-neutral-50); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .cm-tabs .nav-link.active, .cm-tabs .cm-tab.active { background-color: var(--cm-green-light) !important; color: var(--cm-green-dark) !important; }
}

/* -- Footer : bloc regions (rangee pleine largeur) -- */
.cm-footer__regions { padding: 22px 0 4px; border-top: 1px solid var(--cm-neutral-200); margin-top: 8px; }
.cm-footer__regions h6 { color: #222; letter-spacing: 0.5px; text-transform: uppercase; font-size: 0.76rem; font-weight: 700; margin: 0 0 12px; }
.cm-footer__regions .list-inline-item { margin-right: .4rem; }
.cm-footer__regions a { color: var(--cm-neutral-500); text-decoration: none; }
.cm-footer__regions a:hover { color: var(--cm-green-primary); }
.cm-footer__bar { gap: 8px 18px; }

/* ===== AUTH (connexion/inscription) — fidèle au design ===== */
.cm-auth__art { background-image: url('/img/auth.webp'); background-size: cover; background-position: center; background-repeat: no-repeat; }
.cm-auth__logo { height: 38px; width: auto; display: block; margin-bottom: 24px; }
.cm-auth__error { display:flex; align-items:center; gap:7px; background: var(--cm-error-bg); color: var(--cm-error); border-radius: 10px; padding: 10px 14px; font-size: 14px; margin-bottom: 16px; }
.cm-auth__success { display:flex; align-items:center; gap:7px; background: var(--cm-success-bg); color: var(--cm-success); border-radius: 10px; padding: 10px 14px; font-size: 14px; margin-bottom: 16px; }
.cm-auth__row { display:flex; align-items:center; justify-content:space-between; gap:10px; flex-wrap:wrap; margin: 2px 0 18px; }
.cm-auth__remember { display:inline-flex; align-items:center; gap:8px; font-size:13px; color: var(--cm-neutral-600); cursor:pointer; margin:0; }
.cm-auth__link { font-size:13px; color: var(--cm-green-primary); text-decoration:none; }
.cm-auth__link:hover { text-decoration: underline; }
.cm-auth__note { text-align:center; margin-top:20px; font-size:13px; color: var(--cm-neutral-500); }
.cm-auth__note i { margin-right:5px; }
.cm-auth .cm-field .form-error, .cm-auth ul.form-error { color: var(--cm-error); font-size: 12px; margin: 4px 0 0; list-style: none; padding: 0; }

/* ===== AJUSTEMENTS USER v3 (breadcrumb gauche + burger net) ===== */
.cm-breadcrumb { justify-content: flex-start !important; text-align: left !important; }
.cm-breadcrumb__inner { margin: 0 auto 0 0 !important; max-width: none !important; width: 100% !important; justify-content: flex-start !important; text-align: left !important; padding-left: 0 !important; }
.cm-breadcrumb__list { display: flex; flex-wrap: wrap; justify-content: flex-start !important; padding-left: 0 !important; margin: 0 !important; list-style: none; }
.cm-burger { width: 44px !important; height: 44px !important; display: inline-flex !important; align-items: center; justify-content: center; padding: 0 !important; border: 1px solid var(--cm-neutral-200) !important; border-radius: 12px !important; background: #fff !important; box-shadow: var(--cm-shadow-sm); }
.cm-burger .cm-burger__bars { display: flex !important; flex-direction: column; justify-content: center; align-items: center; gap: 4px; width: 20px; height: auto; }
.cm-burger .cm-burger__bars span { display: block !important; width: 20px !important; height: 2px !important; border-radius: 2px; background: var(--cm-neutral-900) !important; position: static !important; margin: 0 !important; opacity: 1 !important; transform: none !important; top: auto !important; left: auto !important; }
.cm-burger .cm-burger__bars span::before, .cm-burger .cm-burger__bars span::after { content: none !important; display: none !important; }

/* ===== AJUSTEMENTS USER v4 : autocomplete ville (jQuery UI, sans allsites.css) ===== */
.ui-autocomplete { position: absolute; list-style: none; margin: 4px 0 0; padding: 6px; background: #fff; border: 1px solid var(--cm-neutral-200); border-radius: 12px; box-shadow: var(--cm-shadow-lg); z-index: 1100; max-height: 260px; overflow-y: auto; }
.ui-autocomplete .ui-menu-item { padding: 0; list-style: none; }
.ui-autocomplete .ui-menu-item-wrapper, .ui-autocomplete .ui-menu-item a { display: block; padding: 9px 12px; border-radius: 8px; cursor: pointer; font-size: 14px; color: var(--cm-neutral-900); text-decoration: none; }
.ui-autocomplete .ui-menu-item-wrapper.ui-state-active, .ui-autocomplete .ui-menu-item a.ui-state-active, .ui-autocomplete .ui-menu-item-wrapper.ui-state-focus { background: var(--cm-green-light); color: var(--cm-green-dark); }
.ui-helper-hidden-accessible { position: absolute; left: -9999px; }

/* ===== AJUSTEMENTS USER v5 : burger identique design (1 barre + 2 pseudo) ===== */
.cm-burger { width:44px !important; height:44px !important; display:inline-flex !important; align-items:center; justify-content:center; padding:0 !important; border:1px solid var(--cm-neutral-200) !important; border-radius:999px !important; background:#fff !important; box-shadow:var(--cm-shadow-sm); cursor:pointer; }
.cm-burger .cm-burger__bar { display:block !important; position:relative !important; width:18px !important; height:2px !important; border-radius:2px; background:var(--cm-neutral-900) !important; margin:0 !important; }
.cm-burger .cm-burger__bar::before, .cm-burger .cm-burger__bar::after { content:'' !important; display:block !important; position:absolute !important; left:0 !important; width:18px !important; height:2px !important; border-radius:2px; background:var(--cm-neutral-900) !important; }
.cm-burger .cm-burger__bar::before { top:-6px !important; }
.cm-burger .cm-burger__bar::after { top:6px !important; }

/* ===== AJUSTEMENTS USER v6 : fil d'Ariane complet (markup dev ol/li) ===== */
.cm-breadcrumb { display:flex !important; align-items:center; justify-content:flex-start !important; padding:14px 0; text-align:left !important; }
.cm-breadcrumb__inner { width:100%; margin:0 !important; max-width:none !important; padding:0 !important; }
.cm-breadcrumb__list { display:flex !important; flex-wrap:wrap; align-items:center; gap:6px; list-style:none !important; margin:0 !important; padding:0 !important; font-size:13px; color:var(--cm-neutral-500); }
.cm-breadcrumb__item { display:inline-flex !important; align-items:center; }
.cm-breadcrumb__item::before { content:none !important; }
.cm-breadcrumb__item:not(:last-child)::after { content:'\203A'; color:var(--cm-neutral-300); margin:0 2px 0 8px; }
.cm-breadcrumb__link { display:inline-flex; align-items:center; gap:5px; color:var(--cm-neutral-500); text-decoration:none; }
.cm-breadcrumb__link:hover { color:var(--cm-neutral-900); text-decoration:underline; }
.cm-breadcrumb__item--current span { color:var(--cm-neutral-900); font-weight:600; }
.cm-breadcrumb__icon { color:var(--cm-green-primary); flex-shrink:0; }

/* ===== AJUSTEMENTS USER v7 : fil d'Ariane = CSS dev (chevrons SVG) aligné via .container ===== */
.cm-breadcrumb { display:block !important; padding:14px 0 0 !important; justify-content:initial !important; }
.cm-breadcrumb .container { margin-left:auto; margin-right:auto; }
.cm-breadcrumb__item:not(:last-child)::after { content:none !important; }   /* annule mon séparateur ajouté en v6 */
.cm-breadcrumb__item + .cm-breadcrumb__item::before { content:'' !important; }  /* rétablit le chevron SVG du dev */

/* ===== AJUSTEMENTS USER v8 : carte mobile — récupère la place du bouton 'Voir la liste' supprimé ===== */
@media (max-width: 991.98px) {
  .cm-map-page__list-wrap { padding-bottom: calc(var(--cm-bottomnav-h, 64px) + env(safe-area-inset-bottom, 0px) + 10px) !important; }
  /* cartes terrains un peu plus grandes : image en 4/5 (plus haute que le 1/1) */
  .cm-map-page__list .cm-listing__media { aspect-ratio: 4 / 5 !important; }
}

/* ===== AJUSTEMENTS USER v9 : refonte mobile page 'Tous les terrains' ===== */
.cm-filter-card__head { display:flex; align-items:center; justify-content:space-between; }
.cm-filter-card__head h2 { margin:0; }
.cm-filter-card__close { display:none; width:36px; height:36px; border:none; background:var(--cm-neutral-50); border-radius:50%; color:var(--cm-neutral-700); cursor:pointer; flex-shrink:0; }
.cm-filter-card__actions { display:flex; flex-direction:column; gap:10px; margin-top:6px; }
.cm-mobile-search, .cm-cat-chips, .cm-filters-overlay { display:none; }
.cm-listings__empty { text-align:center; padding:64px 24px; background:#fff; border:1px solid var(--cm-neutral-100); border-radius:16px; }
.cm-listings__empty i { font-size:40px; color:var(--cm-neutral-300); margin-bottom:16px; }
.cm-listings__empty h2 { font-weight:700; margin:0 0 8px; font-size:20px; }
.cm-listings__empty p { color:var(--cm-neutral-500); margin:0; }

@media (max-width: 991.98px) {
  .cm-listings { display:block !important; padding-block:14px !important; }
  /* barre de recherche sticky facon Airbnb */
  .cm-mobile-search { display:flex; align-items:center; gap:12px; width:100%; position:sticky; top:70px; z-index:40; margin:0 0 14px; padding:13px 16px; border:1px solid var(--cm-neutral-200); border-radius:9999px; background:#fff; box-shadow:var(--cm-shadow-md); font:inherit; font-weight:600; color:var(--cm-neutral-900); cursor:pointer; text-align:left; }
  .cm-mobile-search > i { color:var(--cm-green-primary); font-size:16px; }
  .cm-mobile-search__text { flex:1; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; font-weight:600; }
  .cm-mobile-search__go { width:36px; height:36px; border-radius:50%; background:var(--cm-green-primary); color:#fff; display:inline-flex; align-items:center; justify-content:center; flex-shrink:0; }
  /* chips categories scrollables */
  .cm-cat-chips { display:flex; gap:8px; overflow-x:auto; padding:2px 0 14px; scrollbar-width:none; -webkit-overflow-scrolling:touch; }
  .cm-cat-chips::-webkit-scrollbar { display:none; }
  .cm-cat-chips .cm-chip { flex-shrink:0; }
  /* panneau filtres -> bottom-sheet */
  .cm-filterbar { display:none !important; }
  .cm-filters-overlay { display:block; position:fixed; inset:0; background:var(--cm-overlay-dark); z-index:1190; opacity:0; pointer-events:none; transition:opacity .3s; }
  .cm-filters-overlay:not([hidden]) { opacity:1; pointer-events:auto; }
  .cm-filter-card { position:fixed !important; left:0 !important; right:0 !important; bottom:0 !important; top:auto !important; width:auto !important; margin:0 !important; max-height:90vh; overflow-y:auto; border-radius:22px 22px 0 0 !important; box-shadow:0 -10px 40px rgba(0,0,0,0.25); transform:translateY(105%); transition:transform .32s var(--cm-ease-enter); z-index:1195; display:block !important; padding:16px 18px calc(20px + env(safe-area-inset-bottom,0px)); }
  .cm-filter-card.is-open { transform:translateY(0); }
  .cm-filter-card__head { position:sticky; top:0; background:#fff; z-index:2; padding:4px 0 14px; margin-bottom:14px; border-bottom:1px solid var(--cm-neutral-100); }
  .cm-filter-card__close { display:inline-flex; align-items:center; justify-content:center; }
  .cm-filter-card__done { display:none !important; }
  body.cm-sheet-open { overflow:hidden; }
  /* cartes pleine largeur, image plus grande */
  .cm-listings__grid { grid-template-columns:1fr !important; gap:18px; }
  .cm-listings__main .cm-card__media { aspect-ratio:16/11; }
  .cm-listings__main .cm-card__title { font-size:17px; }
}

/* ===== AJUSTEMENTS USER v10 : Devenir hôte (wizard) — champs au style design cm-field ===== */
.cm-wizard .mb-3 label { display:block !important; font-weight:600 !important; font-size:14px !important; color:var(--cm-neutral-800) !important; margin-bottom:6px !important; }
.cm-wizard .mb-3 .form-control, .cm-wizard .mb-3 .form-select, .cm-wizard .mb-3 textarea.form-control {
  width:100% !important; min-height:54px !important; padding:14px 16px !important;
  border:1px solid var(--cm-neutral-200) !important; border-radius:12px !important;
  background-color:#fff !important; color:var(--cm-neutral-900) !important;
  font-family:var(--cm-font-sans) !important; font-size:16px !important; line-height:1.4 !important;
  box-shadow:none !important; transition:border-color .16s ease, box-shadow .16s ease;
}
.cm-wizard .mb-3 textarea.form-control { min-height:130px !important; resize:vertical; }
.cm-wizard .mb-3 .form-control:hover, .cm-wizard .mb-3 .form-select:hover { border-color:var(--cm-neutral-300) !important; }
.cm-wizard .mb-3 .form-control:focus, .cm-wizard .mb-3 .form-select:focus, .cm-wizard .mb-3 textarea.form-control:focus {
  border-color:var(--cm-green-primary) !important; box-shadow:var(--cm-focus-ring) !important; outline:none !important;
}
.cm-wizard .mb-3 .form-control::placeholder, .cm-wizard .mb-3 textarea.form-control::placeholder { color:var(--cm-neutral-400) !important; }
.cm-wizard .mb-3 .form-select {
  appearance:none !important; -webkit-appearance:none !important;
  background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23717171'%3e%3cpath d='M4.427 6.427a.6.6 0 0 1 .848 0L8 9.152l2.725-2.725a.6.6 0 1 1 .848.848l-3.15 3.15a.6.6 0 0 1-.848 0l-3.15-3.15a.6.6 0 0 1 .002-.848z'/%3e%3c/svg%3e") !important;
  background-repeat:no-repeat !important; background-position:right 14px center !important; background-size:16px !important; padding-right:42px !important;
}
/* titres d'étape un poil plus présents + espacement champs */
.cm-wizard .mb-3 { margin-bottom:18px !important; }

/* ===== AJUSTEMENTS USER v11 : Devenir hôte (wizard) — relooking VISIBLE ===== */
/* Boutons : Suivant en vert (au lieu de noir) + pilule (desktop + mobile) */
.cm-wizard__btn { border-radius:9999px !important; }
.cm-wizard__btn--primary { background-color:var(--cm-green-primary) !important; color:#fff !important; box-shadow:0 4px 14px rgba(90,154,76,0.30) !important; }
.cm-wizard__btn--primary:hover { background-color:var(--cm-green-primary-hover) !important; }
.cm-wizard__btn--submit { box-shadow:0 4px 14px rgba(90,154,76,0.30) !important; }

@media (max-width: 991.98px) {
  /* fond doux + étape en CARTE blanche (look premium, clairement visible) */
  .cm-wizard__body { background:var(--cm-neutral-50) !important; align-items:flex-start !important; padding:20px 16px calc(96px + env(safe-area-inset-bottom,0px)) !important; }
  .cm-wizard__content { background:#fff; border:1px solid var(--cm-neutral-100); border-radius:22px; box-shadow:0 10px 30px rgba(0,0,0,0.06); padding:24px 20px; }
  .cm-wizard__step-title { font-size:24px !important; }
  .cm-wizard__step-lead { font-size:15px !important; margin-bottom:24px !important; }
  /* footer boutons plus grands/tactiles */
  .cm-wizard__footer { padding-left:16px; padding-right:16px; }
  .cm-wizard__btn { padding-top:14px !important; padding-bottom:14px !important; font-size:15px !important; }
  .cm-wizard__btn--primary, .cm-wizard__btn--submit { flex:1; justify-content:center; }
}

/* ===== AJUSTEMENTS USER v12 : burger caché sur DESKTOP (corrige le !important de v5) ===== */
@media (min-width: 992px) { .cm-burger, .cm-burger.d-lg-none { display: none !important; } }
